FHIR Extensions Pack
5.1.0 - 5.1.0 (April 2024) International flag

This page is part of the FHIR Core Extensions Registry (v5.1.0: Release 5.1) based on FHIR (HL7® FHIR® Standard) v5.0.0. This is the current published version. For a full list of available versions, see the Directory of published versions

StructureMap: FML Conversion for CoverageEligibilityRequest: R5 to R4

Official URL: http://hl7.org/fhir/StructureMap/CoverageEligibilityRequest5to4 Version: 5.1.0
Standards status: Trial-use Maturity Level: 1 Computable Name: CoverageEligibilityRequest5to4

FMLConversionforCoverageEligibilityRequestR5toR4

/// url = 'http://hl7.org/fhir/StructureMap/CoverageEligibilityRequest5to4'
/// name = 'CoverageEligibilityRequest5to4'
/// title = 'FML Conversion for CoverageEligibilityRequest: R5 to R4'
/// status = 'active'

conceptmap "EligibilityRequestPurpose" {
  prefix s = "http://hl7.org/fhir/eligibilityrequest-purpose"
  prefix t = "http://hl7.org/fhir/4.0/eligibilityrequest-purpose"

  s:"auth-requirements" - t:"auth-requirements"
  s:benefits - t:benefits
  s:discovery - t:discovery
  s:validation - t:validation
}

conceptmap "EligibilityRequestStatus" {
  prefix s = "http://hl7.org/fhir/fm-status"
  prefix t = "http://hl7.org/fhir/4.0/fm-status"

  s:active - t:active
  s:cancelled - t:cancelled
  s:draft - t:draft
  s:"entered-in-error" - t:"entered-in-error"
}

uses "http://hl7.org/fhir/StructureDefinition/CoverageEligibilityRequest" alias CoverageEligibilityRequestR5 as source
uses "http://hl7.org/fhir/4.0/StructureDefinition/CoverageEligibilityRequest" alias CoverageEligibilityRequestR4 as target

imports "http://hl7.org/fhir/StructureMap/*5to4"

group CoverageEligibilityRequest(source src : CoverageEligibilityRequestR5, target tgt : CoverageEligibilityRequestR4) extends DomainResource <<type+>> {
  src.identifier -> tgt.identifier;
  src.status as v -> tgt.status = translate(v, '#EligibilityRequestStatus', 'code');
  src.priority -> tgt.priority;
  src.purpose as v -> tgt.purpose = translate(v, '#EligibilityRequestPurpose', 'code');
  src.patient -> tgt.patient;
  src.serviced : date -> tgt.serviced; // src.event as s -> tgt.event as t then CoverageEligibilityRequestEvent(s,t);
  src.serviced : Period -> tgt.serviced;
  src.created -> tgt.created;
  src.enterer -> tgt.enterer;
  src.provider -> tgt.provider;
  src.insurer -> tgt.insurer;
  src.facility -> tgt.facility;
  src.supportingInfo as s -> tgt.supportingInfo as t then CoverageEligibilityRequestSupportingInfo(s, t);
  src.insurance as s -> tgt.insurance as t then CoverageEligibilityRequestInsurance(s, t);
  src.item as s -> tgt.item as t then CoverageEligibilityRequestItem(s, t);
}

// group CoverageEligibilityRequestEvent(source src, target tgt) extends BackboneElement {
// src.type -> tgt.type;
// src.when : dateTime -> tgt.when;
// src.when : Period -> tgt.when;
// }
group CoverageEligibilityRequestSupportingInfo(source src, target tgt) extends BackboneElement {
  src.sequence -> tgt.sequence;
  src.information -> tgt.information;
  src.appliesToAll -> tgt.appliesToAll;
}

group CoverageEligibilityRequestInsurance(source src, target tgt) extends BackboneElement {
  src.focal -> tgt.focal;
  src.coverage -> tgt.coverage;
  src.businessArrangement -> tgt.businessArrangement;
}

group CoverageEligibilityRequestItem(source src, target tgt) extends BackboneElement {
  src.supportingInfoSequence -> tgt.supportingInfoSequence;
  src.category -> tgt.category;
  src.productOrService -> tgt.productOrService;
  src.modifier -> tgt.modifier;
  src.provider -> tgt.provider;
  src.quantity -> tgt.quantity;
  src.unitPrice -> tgt.unitPrice;
  src.facility -> tgt.facility;
  src.diagnosis as s -> tgt.diagnosis as t then CoverageEligibilityRequestItemDiagnosis(s, t);
  src.detail -> tgt.detail;
}

group CoverageEligibilityRequestItemDiagnosis(source src, target tgt) extends BackboneElement {
  src.diagnosis : CodeableConcept -> tgt.diagnosis;
  src.diagnosis : Reference -> tgt.diagnosis;
}