R4 Ballot #1 (Mixed Normative/Trial use)

This page is part of the FHIR Specification (v3.3.0: R4 Ballot 2). The current version which supercedes this version is 5.0.0. For a full list of available versions, see the Directory of published versions . Page versions: R5 R4B R4 R3 R2

Date.profile.xml

Modeling and Methodology Work GroupMaturity Level: N/ABallot Status: Informative

Raw XML (canonical form)

StructureDefinition for date

<StructureDefinition xmlns="http://hl7.org/fhir">
  <id value="date"/> 
  <text> 
    <status value="generated"/> 
    <div xmlns="http://www.w3.org/1999/xhtml">to do</div> 
  </text> 
  <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-ballot-status">
    <valueString value="Normative"/> 
  </extension> 
  <url value="http://hl7.org/fhir/StructureDefinition/date"/> 
  <name value="date"/> 
  <status value="draft"/> 
  <date value="2018-04-03T12:05:46+10:00"/> 
  <publisher value="HL7 FHIR Standard"/> 
  <contact> 
    <telecom> 
      <system value="url"/> 
      <value value="http://hl7.org/fhir"/> 
    </telecom> 
  </contact> 
  <description value="Base StructureDefinition for date Type: A date or partial date (e.g. just year or year
   + month). There is no time zone. The format is a union of the schema types gYear, gYearMonth
   and date.  Dates SHALL be valid dates."/> 
  <fhirVersion value="3.3.0"/> 
  <kind value="primitive-type"/> 
  <abstract value="false"/> 
  <type value="date"/> 
  <baseDefinition value="http://hl7.org/fhir/StructureDefinition/Element"/> 
  <derivation value="specialization"/> 
  <snapshot> 
    <element id="date">
      <path value="date"/> 
      <short value="Primitive Type date"/> 
      <definition value="A date or partial date (e.g. just year or year + month). There is no time zone. The format
       is a union of the schema types gYear, gYearMonth and date.  Dates SHALL be valid dates."/> 
      <min value="0"/> 
      <max value="*"/> 
      <base> 
        <path value="date"/> 
        <min value="0"/> 
        <max value="*"/> 
      </base> 
      <constraint> 
        <key value="ele-1"/> 
        <severity value="error"/> 
        <human value="All FHIR elements must have a @value or children"/> 
        <expression value="hasValue() | (children().count() &gt; id.count())"/> 
        <xpath value="@value|f:*|h:div"/> 
        <source value="Element"/> 
      </constraint> 
      <isModifier value="false"/> 
      <isSummary value="false"/> 
    </element> 
    <element id="date.id">
      <path value="date.id"/> 
      <representation value="xmlAttr"/> 
      <short value="xml:id (or equivalent in JSON)"/> 
      <definition value="unique id for the element within a resource (for internal references)"/> 
      <min value="0"/> 
      <max value="1"/> 
      <base> 
        <path value="Element.id"/> 
        <min value="0"/> 
        <max value="1"/> 
      </base> 
      <type> 
        <code value="string"/> 
      </type> 
      <isModifier value="false"/> 
      <isSummary value="false"/> 
    </element> 
    <element id="date.extension">
      <path value="date.extension"/> 
      <short value="Additional Content defined by implementations"/> 
      <definition value="May be used to represent additional information that is not part of the basic definition
       of the resource. To make the use of extensions safe and manageable, there is a strict
       set of governance  applied to the definition and use of extensions. Though any implementer
       can define an extension, there is a set of requirements that SHALL be met as part of the
       definition of the extension."/> 
      <comment value="There can be no stigma associated with the use of extensions by any application, project,
       or standard - regardless of the institution or jurisdiction that uses or defines the extensions.
        The use of extensions is what allows the FHIR specification to retain a core level of
       simplicity for everyone."/> 
      <alias value="extensions"/> 
      <alias value="user content"/> 
      <min value="0"/> 
      <max value="*"/> 
      <base> 
        <path value="Element.extension"/> 
        <min value="0"/> 
        <max value="*"/> 
      </base> 
      <type> 
        <code value="Extension"/> 
      </type> 
      <isModifier value="false"/> 
      <isSummary value="false"/> 
    </element> 
    <element id="date.value">
      <path value="date.value"/> 
      <representation value="xmlAttr"/> 
      <short value="Primitive value for date"/> 
      <definition value="The actual value"/> 
      <min value="0"/> 
      <max value="1"/> 
      <base> 
        <path value="date.value"/> 
        <min value="0"/> 
        <max value="1"/> 
      </base> 
    <!--  Note: primitive values do not have an assigned type. e.g. this is compiler magic. XML,
       JSON and RDF types provided by extension  -->
      <type> 
        <extension url="http://hl7.org/fhir/StructureDefinition/regex">
          <valueString value="([0-9]([0-9]([0-9][1-9]|[1-9]0)|[1-9]00)|[1-9]000)(-(0[1-9]|1[0-2])(-(0[1-9]|[1-2][0-9]|3[0-1]))?)?"/> 
        </extension> 
        <code> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-json-type">
            <valueString value="string"/> 
          </extension> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-xml-type">
            <valueString value="xsd:gYear OR xsd:gYearMonth OR xsd:date"/> 
          </extension> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-rdf-type">
            <valueString value="xsd:gYear OR xsd:gYearMonth OR xsd:date"/> 
          </extension> 
        </code> 
      </type> 
      <isModifier value="false"/> 
      <isSummary value="false"/> 
    </element> 
  </snapshot> 
  <differential> 
    <element id="date">
      <path value="date"/> 
      <short value="Primitive Type date"/> 
      <definition value="A date or partial date (e.g. just year or year + month). There is no time zone. The format
       is a union of the schema types gYear, gYearMonth and date.  Dates SHALL be valid dates."/> 
      <min value="0"/> 
      <max value="*"/> 
    </element> 
    <element id="date.value">
      <path value="date.value"/> 
      <representation value="xmlAttr"/> 
      <short value="Primitive value for date"/> 
      <definition value="Primitive value for date"/> 
      <min value="0"/> 
      <max value="1"/> 
    <!--  Note: primitive values do not have an assigned type. e.g. this is compiler magic. XML,
       JSON and RDF types provided by extension  -->
      <type> 
        <extension url="http://hl7.org/fhir/StructureDefinition/regex">
          <valueString value="([0-9]([0-9]([0-9][1-9]|[1-9]0)|[1-9]00)|[1-9]000)(-(0[1-9]|1[0-2])(-(0[1-9]|[1-2][0-9]|3[0-1]))?)?"/> 
        </extension> 
        <code> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-json-type">
            <valueString value="string"/> 
          </extension> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-xml-type">
            <valueString value="xsd:gYear OR xsd:gYearMonth OR xsd:date"/> 
          </extension> 
          <extension url="http://hl7.org/fhir/StructureDefinition/structuredefinition-rdf-type">
            <valueString value="xsd:gYear OR xsd:gYearMonth OR xsd:date"/> 
          </extension> 
        </code> 
      </type> 
    </element> 
  </differential> 
</StructureDefinition> 

Usage note: every effort has been made to ensure that the examples are correct and useful, but they are not a normative part of the specification.