improvements in rendering profiles

This commit is contained in:
Grahame Grieve 2019-08-23 14:58:04 +10:00
parent c794c9393b
commit 07f4743cd1
3 changed files with 159 additions and 91 deletions

View File

@ -264,14 +264,15 @@ public class ProfileUtilities extends TranslatingUtilities {
public String display; public String display;
public String url; public String url;
} }
boolean isDatatype(String typeSimple); public boolean isDatatype(String typeSimple);
boolean isResource(String typeSimple); public boolean isResource(String typeSimple);
boolean hasLinkFor(String typeSimple); public boolean hasLinkFor(String typeSimple);
String getLinkFor(String corePath, String typeSimple); public String getLinkFor(String corePath, String typeSimple);
BindingResolution resolveBinding(StructureDefinition def, ElementDefinitionBindingComponent binding, String path) throws FHIRException; public BindingResolution resolveBinding(StructureDefinition def, ElementDefinitionBindingComponent binding, String path) throws FHIRException;
BindingResolution resolveBinding(StructureDefinition def, String url, String path) throws FHIRException; public BindingResolution resolveBinding(StructureDefinition def, String url, String path) throws FHIRException;
String getLinkForProfile(StructureDefinition profile, String url); public String getLinkForProfile(StructureDefinition profile, String url);
boolean prependLinks(); public boolean prependLinks();
public String getLinkForUrl(String corePath, String s);
} }
@ -547,7 +548,7 @@ public class ProfileUtilities extends TranslatingUtilities {
first = false; first = false;
else else
b.append("|"); b.append("|");
b.append(tr.getCode()); b.append(tr.getWorkingCode());
} }
return b.toString(); return b.toString();
} }
@ -560,7 +561,7 @@ public class ProfileUtilities extends TranslatingUtilities {
first = false; first = false;
else else
b.append("|"); b.append("|");
b.append(tr.getCode()); b.append(tr.getWorkingCode());
if (tr.hasProfile()) { if (tr.hasProfile()) {
b.append("("); b.append("(");
b.append(tr.getProfile()); b.append(tr.getProfile());
@ -632,7 +633,7 @@ public class ProfileUtilities extends TranslatingUtilities {
} }
if (outcome.getType().size() > 1) { if (outcome.getType().size() > 1) {
for (TypeRefComponent t : outcome.getType()) { for (TypeRefComponent t : outcome.getType()) {
if (!t.getCode().equals("Reference")) if (!t.getWorkingCode().equals("Reference"))
throw new DefinitionException(diffMatches.get(0).getPath()+" has children ("+differential.getElement().get(diffCursor).getPath()+") and multiple types ("+typeCode(outcome.getType())+") in profile "+profileName); throw new DefinitionException(diffMatches.get(0).getPath()+" has children ("+differential.getElement().get(diffCursor).getPath()+") and multiple types ("+typeCode(outcome.getType())+") in profile "+profileName);
} }
} }
@ -650,7 +651,7 @@ public class ProfileUtilities extends TranslatingUtilities {
baseCursor++; baseCursor++;
} else if (diffMatches.size() == 1 && (slicingDone || (!isImplicitSlicing(diffMatches.get(0), cpath) && !(diffMatches.get(0).hasSlicing() || (isExtension(diffMatches.get(0)) && diffMatches.get(0).hasSliceName()))))) {// one matching element in the differential } else if (diffMatches.size() == 1 && (slicingDone || (!isImplicitSlicing(diffMatches.get(0), cpath) && !(diffMatches.get(0).hasSlicing() || (isExtension(diffMatches.get(0)) && diffMatches.get(0).hasSliceName()))))) {// one matching element in the differential
ElementDefinition template = null; ElementDefinition template = null;
if (diffMatches.get(0).hasType() && diffMatches.get(0).getType().size() == 1 && diffMatches.get(0).getType().get(0).hasProfile() && !"Reference".equals(diffMatches.get(0).getType().get(0).getCode())) { if (diffMatches.get(0).hasType() && diffMatches.get(0).getType().size() == 1 && diffMatches.get(0).getType().get(0).hasProfile() && !"Reference".equals(diffMatches.get(0).getType().get(0).getWorkingCode())) {
CanonicalType p = diffMatches.get(0).getType().get(0).getProfile().get(0); CanonicalType p = diffMatches.get(0).getType().get(0).getProfile().get(0);
StructureDefinition sd = context.fetchResource(StructureDefinition.class, p.getValue()); StructureDefinition sd = context.fetchResource(StructureDefinition.class, p.getValue());
if (sd != null) { if (sd != null) {
@ -1202,7 +1203,7 @@ public class ProfileUtilities extends TranslatingUtilities {
String s = n.substring(rn.length()); String s = n.substring(rn.length());
if (!s.contains(".")) { if (!s.contains(".")) {
if (ed.hasSliceName() && ed.getType().size() == 1) { if (ed.hasSliceName() && ed.getType().size() == 1) {
typeList.add(new TypeSlice(ed, ed.getTypeFirstRep().getCode())); typeList.add(new TypeSlice(ed, ed.getTypeFirstRep().getWorkingCode()));
} else if (!ed.hasSliceName() && !s.equals("[x]")) { } else if (!ed.hasSliceName() && !s.equals("[x]")) {
if (isDataType(s)) if (isDataType(s))
typeList.add(new TypeSlice(ed, s)); typeList.add(new TypeSlice(ed, s));
@ -1229,7 +1230,7 @@ public class ProfileUtilities extends TranslatingUtilities {
private List<TypeRefComponent> getByTypeName(List<TypeRefComponent> type, String t) { private List<TypeRefComponent> getByTypeName(List<TypeRefComponent> type, String t) {
List<TypeRefComponent> res = new ArrayList<TypeRefComponent>(); List<TypeRefComponent> res = new ArrayList<TypeRefComponent>();
for (TypeRefComponent tr : type) { for (TypeRefComponent tr : type) {
if (t.equals(tr.getCode())) if (t.equals(tr.getWorkingCode()))
res.add(tr); res.add(tr);
} }
return res; return res;
@ -1423,9 +1424,9 @@ public class ProfileUtilities extends TranslatingUtilities {
System.out.println("Failed to find referenced profile: " + type.getProfile()); System.out.println("Failed to find referenced profile: " + type.getProfile());
} }
if (sd == null) if (sd == null)
sd = context.fetchTypeDefinition(type.getCode()); sd = context.fetchTypeDefinition(type.getWorkingCode());
if (sd == null) if (sd == null)
System.out.println("XX: failed to find profle for type: " + type.getCode()); // debug GJM System.out.println("XX: failed to find profle for type: " + type.getWorkingCode()); // debug GJM
return sd; return sd;
} }
@ -1442,7 +1443,7 @@ public class ProfileUtilities extends TranslatingUtilities {
boolean first = true; boolean first = true;
for (TypeRefComponent type : types) { for (TypeRefComponent type : types) {
if (first) first = false; else b.append(", "); if (first) first = false; else b.append(", ");
b.append(type.getCode()); b.append(type.getWorkingCode());
if (type.hasTargetProfile()) if (type.hasTargetProfile())
b.append("{"+type.getTargetProfile()+"}"); b.append("{"+type.getTargetProfile()+"}");
else if (type.hasProfile()) else if (type.hasProfile())
@ -1456,7 +1457,7 @@ public class ProfileUtilities extends TranslatingUtilities {
if (types.isEmpty()) if (types.isEmpty())
return false; return false;
for (TypeRefComponent type : types) { for (TypeRefComponent type : types) {
String t = type.getCode(); String t = type.getWorkingCode();
if (!isDataType(t) && !isPrimitive(t)) if (!isDataType(t) && !isPrimitive(t))
return false; return false;
} }
@ -1916,15 +1917,11 @@ public class ProfileUtilities extends TranslatingUtilities {
// } // }
boolean ok = false; boolean ok = false;
CommaSeparatedStringBuilder b = new CommaSeparatedStringBuilder(); CommaSeparatedStringBuilder b = new CommaSeparatedStringBuilder();
String t = ts.getCode(); String t = ts.getWorkingCode();
if (t == null && ts.getCodeElement().hasExtension(ToolingExtensions.EXT_XML_TYPE))
t = "*"; //
for (TypeRefComponent td : base.getType()) {; for (TypeRefComponent td : base.getType()) {;
String tt = td.getCode(); String tt = td.getWorkingCode();
if (tt == null && td.getCodeElement().hasExtension(ToolingExtensions.EXT_JSON_TYPE))
tt = "*"; //
b.append(tt); b.append(tt);
if (td.hasCode() && (tt.equals(t) || "Extension".equals(tt) || if (td.hasCode() && (tt.equals(t) || "Extension".equals(tt) || (t.equals("uri") && tt.equals("string")) || // work around for old badly generated SDs
"Element".equals(tt) || "*".equals(tt) || "Element".equals(tt) || "*".equals(tt) ||
(("Resource".equals(tt) || ("DomainResource".equals(tt)) && pkp.isResource(t))))) (("Resource".equals(tt) || ("DomainResource".equals(tt)) && pkp.isResource(t)))))
ok = true; ok = true;
@ -1995,7 +1992,7 @@ public class ProfileUtilities extends TranslatingUtilities {
private boolean hasBindableType(ElementDefinition ed) { private boolean hasBindableType(ElementDefinition ed) {
for (TypeRefComponent tr : ed.getType()) { for (TypeRefComponent tr : ed.getType()) {
if (Utilities.existsInList(tr.getCode(), "Coding", "CodeableConcept", "Quantity", "uri", "string", "code")) if (Utilities.existsInList(tr.getWorkingCode(), "Coding", "CodeableConcept", "Quantity", "uri", "string", "code"))
return true; return true;
} }
return false; return false;
@ -2276,7 +2273,7 @@ public class ProfileUtilities extends TranslatingUtilities {
c.addPiece(checkForNoChange(tl, gen.new Piece(null,", ", null))); c.addPiece(checkForNoChange(tl, gen.new Piece(null,", ", null)));
tl = t; tl = t;
if (t.hasTarget()) { if (t.hasTarget()) {
c.getPieces().add(gen.new Piece(corePath+"references.html", t.getCode(), null)); c.getPieces().add(gen.new Piece(corePath+"references.html", t.getWorkingCode(), null));
c.getPieces().add(gen.new Piece(null, "(", null)); c.getPieces().add(gen.new Piece(null, "(", null));
boolean tfirst = true; boolean tfirst = true;
for (UriType u : t.getTargetProfile()) { for (UriType u : t.getTargetProfile()) {
@ -2284,27 +2281,7 @@ public class ProfileUtilities extends TranslatingUtilities {
tfirst = false; tfirst = false;
else else
c.addPiece(gen.new Piece(null, " | ", null)); c.addPiece(gen.new Piece(null, " | ", null));
if (u.getValue().startsWith("http://hl7.org/fhir/StructureDefinition/")) { genTargetLink(gen, profileBaseFileName, corePath, c, t, u.getValue());
StructureDefinition sd = context.fetchResource(StructureDefinition.class, u.getValue());
if (sd != null) {
String disp = sd.hasTitle() ? sd.getTitle() : sd.getName();
c.addPiece(checkForNoChange(t, gen.new Piece(checkPrepend(corePath, sd.getUserString("path")), disp, null)));
} else {
String rn = u.getValue().substring(40);
c.addPiece(checkForNoChange(t, gen.new Piece(pkp.getLinkFor(corePath, rn), rn, null)));
}
} else if (Utilities.isAbsoluteUrl(u.getValue())) {
StructureDefinition sd = context.fetchResource(StructureDefinition.class, u.getValue());
if (sd != null) {
String disp = sd.hasTitle() ? sd.getTitle() : sd.getName();
String ref = pkp.getLinkForProfile(null, sd.getUrl());
if (ref.contains("|"))
ref = ref.substring(0, ref.indexOf("|"));
c.addPiece(checkForNoChange(t, gen.new Piece(ref, disp, null)));
} else
c.addPiece(checkForNoChange(t, gen.new Piece(null, u.getValue(), null)));
} else if (t.hasTargetProfile() && u.getValue().startsWith("#"))
c.addPiece(checkForNoChange(t, gen.new Piece(corePath+profileBaseFileName+"."+u.getValue().substring(1).toLowerCase()+".html", u.getValue(), null)));
} }
c.getPieces().add(gen.new Piece(null, ")", null)); c.getPieces().add(gen.new Piece(null, ")", null));
if (t.getAggregation().size() > 0) { if (t.getAggregation().size() > 0) {
@ -2319,24 +2296,22 @@ public class ProfileUtilities extends TranslatingUtilities {
} }
c.getPieces().add(gen.new Piece(corePath+"valueset-resource-aggregation-mode.html", "}", null)); c.getPieces().add(gen.new Piece(corePath+"valueset-resource-aggregation-mode.html", "}", null));
} }
} else if (t.hasProfile() && (!t.getCode().equals("Extension") || isProfiledType(t.getProfile()))) { // a profiled type } else if (t.hasProfile() && (!t.getWorkingCode().equals("Extension") || isProfiledType(t.getProfile()))) { // a profiled type
String ref; String ref;
ref = pkp.getLinkForProfile(profile, t.getProfile().get(0).getValue()); ref = pkp.getLinkForProfile(profile, t.getProfile().get(0).getValue());
if (ref != null) { if (ref != null) {
String[] parts = ref.split("\\|"); String[] parts = ref.split("\\|");
if (parts[0].startsWith("http:") || parts[0].startsWith("https:")) { if (parts[0].startsWith("http:") || parts[0].startsWith("https:")) {
// c.addPiece(checkForNoChange(t, gen.new Piece(parts[0], "<" + parts[1] + ">", t.getCode()))); Lloyd // c.addPiece(checkForNoChange(t, gen.new Piece(parts[0], "<" + parts[1] + ">", t.getCode()))); Lloyd
c.addPiece(checkForNoChange(t, gen.new Piece(parts[0], parts[1], t.getCode()))); c.addPiece(checkForNoChange(t, gen.new Piece(parts[0], parts[1], t.getWorkingCode())));
} else { } else {
// c.addPiece(checkForNoChange(t, gen.new Piece((t.getProfile().startsWith(corePath)? corePath: "")+parts[0], "<" + parts[1] + ">", t.getCode()))); // c.addPiece(checkForNoChange(t, gen.new Piece((t.getProfile().startsWith(corePath)? corePath: "")+parts[0], "<" + parts[1] + ">", t.getCode())));
c.addPiece(checkForNoChange(t, gen.new Piece((t.getProfile().get(0).getValue().startsWith(corePath+"StructureDefinition")? corePath: "")+parts[0], parts[1], t.getCode()))); c.addPiece(checkForNoChange(t, gen.new Piece((t.getProfile().get(0).getValue().startsWith(corePath+"StructureDefinition")? corePath: "")+parts[0], parts[1], t.getWorkingCode())));
} }
} else } else
c.addPiece(checkForNoChange(t, gen.new Piece((t.getProfile().get(0).getValue().startsWith(corePath)? corePath: "")+ref, t.getCode(), null))); c.addPiece(checkForNoChange(t, gen.new Piece((t.getProfile().get(0).getValue().startsWith(corePath)? corePath: "")+ref, t.getWorkingCode(), null)));
} else { } else {
String tc = t.getCode(); String tc = t.getWorkingCode();
if (Utilities.noString(tc) && t.getCodeElement().hasExtension(ToolingExtensions.EXT_JSON_TYPE))
tc = "string";
if (pkp != null && pkp.hasLinkFor(tc)) { if (pkp != null && pkp.hasLinkFor(tc)) {
c.addPiece(checkForNoChange(t, gen.new Piece(pkp.getLinkFor(corePath, tc), tc, null))); c.addPiece(checkForNoChange(t, gen.new Piece(pkp.getLinkFor(corePath, tc), tc, null)));
} else } else
@ -2346,6 +2321,31 @@ public class ProfileUtilities extends TranslatingUtilities {
return c; return c;
} }
public void genTargetLink(HierarchicalTableGenerator gen, String profileBaseFileName, String corePath, Cell c, TypeRefComponent t, String u) {
if (u.startsWith("http://hl7.org/fhir/StructureDefinition/")) {
StructureDefinition sd = context.fetchResource(StructureDefinition.class, u);
if (sd != null) {
String disp = sd.hasTitle() ? sd.getTitle() : sd.getName();
c.addPiece(checkForNoChange(t, gen.new Piece(checkPrepend(corePath, sd.getUserString("path")), disp, null)));
} else {
String rn = u.substring(40);
c.addPiece(checkForNoChange(t, gen.new Piece(pkp.getLinkFor(corePath, rn), rn, null)));
}
} else if (Utilities.isAbsoluteUrl(u)) {
StructureDefinition sd = context.fetchResource(StructureDefinition.class, u);
if (sd != null) {
String disp = sd.hasTitle() ? sd.getTitle() : sd.getName();
String ref = pkp.getLinkForProfile(null, sd.getUrl());
if (ref.contains("|"))
ref = ref.substring(0, ref.indexOf("|"));
c.addPiece(checkForNoChange(t, gen.new Piece(ref, disp, null)));
} else
c.addPiece(checkForNoChange(t, gen.new Piece(null, u, null)));
} else if (t.hasTargetProfile() && u.startsWith("#"))
c.addPiece(checkForNoChange(t, gen.new Piece(corePath+profileBaseFileName+"."+u.substring(1).toLowerCase()+".html", u, null)));
}
private boolean isProfiledType(List<CanonicalType> theProfile) { private boolean isProfiledType(List<CanonicalType> theProfile) {
for (CanonicalType next : theProfile){ for (CanonicalType next : theProfile){
if (StringUtils.defaultString(next.getValueAsString()).contains(":")) { if (StringUtils.defaultString(next.getValueAsString()).contains(":")) {
@ -2537,7 +2537,7 @@ public class ProfileUtilities extends TranslatingUtilities {
StructureDefinition profile = profiles == null ? null : profiles.get(profiles.size()-1); StructureDefinition profile = profiles == null ? null : profiles.get(profiles.size()-1);
String s = tail(element.getPath()); String s = tail(element.getPath());
if (element.hasSliceName()) if (element.hasSliceName())
s = element.getSliceName(); s = s +":"+element.getSliceName();
Row typesRow = null; Row typesRow = null;
List<ElementDefinition> children = getChildren(all, element); List<ElementDefinition> children = getChildren(all, element);
@ -2577,13 +2577,13 @@ public class ProfileUtilities extends TranslatingUtilities {
row.setIcon("icon_choice.gif", HierarchicalTableGenerator.TEXT_ICON_CHOICE); row.setIcon("icon_choice.gif", HierarchicalTableGenerator.TEXT_ICON_CHOICE);
typesRow = row; typesRow = row;
} }
} else if (hasDef && element.getType().get(0).getCode() != null && element.getType().get(0).getCode().startsWith("@")) } else if (hasDef && element.getType().get(0).getWorkingCode() != null && element.getType().get(0).getWorkingCode().startsWith("@"))
row.setIcon("icon_reuse.png", HierarchicalTableGenerator.TEXT_ICON_REUSE); row.setIcon("icon_reuse.png", HierarchicalTableGenerator.TEXT_ICON_REUSE);
else if (hasDef && isPrimitive(element.getType().get(0).getCode())) else if (hasDef && isPrimitive(element.getType().get(0).getWorkingCode()))
row.setIcon("icon_primitive.png", HierarchicalTableGenerator.TEXT_ICON_PRIMITIVE); row.setIcon("icon_primitive.png", HierarchicalTableGenerator.TEXT_ICON_PRIMITIVE);
else if (hasDef && element.getType().get(0).hasTarget()) else if (hasDef && element.getType().get(0).hasTarget())
row.setIcon("icon_reference.png", HierarchicalTableGenerator.TEXT_ICON_REFERENCE); row.setIcon("icon_reference.png", HierarchicalTableGenerator.TEXT_ICON_REFERENCE);
else if (hasDef && isDataType(element.getType().get(0).getCode())) else if (hasDef && isDataType(element.getType().get(0).getWorkingCode()))
row.setIcon("icon_datatype.gif", HierarchicalTableGenerator.TEXT_ICON_DATATYPE); row.setIcon("icon_datatype.gif", HierarchicalTableGenerator.TEXT_ICON_DATATYPE);
else else
row.setIcon("icon_resource.png", HierarchicalTableGenerator.TEXT_ICON_RESOURCE); row.setIcon("icon_resource.png", HierarchicalTableGenerator.TEXT_ICON_RESOURCE);
@ -2653,12 +2653,13 @@ public class ProfileUtilities extends TranslatingUtilities {
} else { } else {
row.setIcon("icon_slice.png", HierarchicalTableGenerator.TEXT_ICON_SLICE); row.setIcon("icon_slice.png", HierarchicalTableGenerator.TEXT_ICON_SLICE);
slicingRow = row; slicingRow = row;
row.getCells().get(2).getPieces().clear();
for (Cell cell : row.getCells()) for (Cell cell : row.getCells())
for (Piece p : cell.getPieces()) { for (Piece p : cell.getPieces()) {
p.addStyle("font-style: italic"); p.addStyle("font-style: italic");
} }
} }
} else if (element.hasSliceName()) {
row.setIcon("icon_slice_item.png", HierarchicalTableGenerator.TEXT_ICON_SLICE_ITEM);
} }
if (used.used || showMissing) if (used.used || showMissing)
rows.add(row); rows.add(row);
@ -2713,17 +2714,17 @@ public class ProfileUtilities extends TranslatingUtilities {
// genElement(defPath, gen, row.getSubRows(), child, all, profiles, showMissing, profileBaseFileName, true, false, corePath, imagePath, false, logicalModel, isConstraintMode, allInvariants); // genElement(defPath, gen, row.getSubRows(), child, all, profiles, showMissing, profileBaseFileName, true, false, corePath, imagePath, false, logicalModel, isConstraintMode, allInvariants);
} }
if (typesRow != null) { if (typesRow != null) {
makeChoiceRows(typesRow.getSubRows(), element, gen, corePath); makeChoiceRows(typesRow.getSubRows(), element, gen, corePath, profileBaseFileName);
} }
} }
return slicingRow; return slicingRow;
} }
private void makeChoiceRows(List<Row> subRows, ElementDefinition element, HierarchicalTableGenerator gen, String corePath) { private void makeChoiceRows(List<Row> subRows, ElementDefinition element, HierarchicalTableGenerator gen, String corePath, String profileBaseFileName) {
// create a child for each choice // create a child for each choice
for (TypeRefComponent tr : element.getType()) { for (TypeRefComponent tr : element.getType()) {
Row choicerow = gen.new Row(); Row choicerow = gen.new Row();
String t = tr.getCode(); String t = tr.getWorkingCode();
if (isReference(t)) { if (isReference(t)) {
choicerow.getCells().add(gen.new Cell(null, null, tail(element.getPath()).replace("[x]", Utilities.capitalize(t)), null, null)); choicerow.getCells().add(gen.new Cell(null, null, tail(element.getPath()).replace("[x]", Utilities.capitalize(t)), null, null));
choicerow.getCells().add(gen.new Cell()); choicerow.getCells().add(gen.new Cell());
@ -2732,7 +2733,7 @@ public class ProfileUtilities extends TranslatingUtilities {
Cell c = gen.new Cell(); Cell c = gen.new Cell();
choicerow.getCells().add(c); choicerow.getCells().add(c);
if (ADD_REFERENCE_TO_TABLE) { if (ADD_REFERENCE_TO_TABLE) {
if (tr.getCode().equals("canonical")) if (tr.getWorkingCode().equals("canonical"))
c.getPieces().add(gen.new Piece(corePath+"datatypes.html#canonical", "canonical", null)); c.getPieces().add(gen.new Piece(corePath+"datatypes.html#canonical", "canonical", null));
else else
c.getPieces().add(gen.new Piece(corePath+"references.html#Reference", "Reference", null)); c.getPieces().add(gen.new Piece(corePath+"references.html#Reference", "Reference", null));
@ -2742,7 +2743,7 @@ public class ProfileUtilities extends TranslatingUtilities {
for (CanonicalType rt : tr.getTargetProfile()) { for (CanonicalType rt : tr.getTargetProfile()) {
if (!first) if (!first)
c.getPieces().add(gen.new Piece(null, " | ", null)); c.getPieces().add(gen.new Piece(null, " | ", null));
c.getPieces().add(gen.new Piece(null, pkp.getLinkFor(corePath, rt.asStringValue()), null)); genTargetLink(gen, profileBaseFileName, corePath, c, tr, rt.getValue());
first = false; first = false;
} }
if (ADD_REFERENCE_TO_TABLE) if (ADD_REFERENCE_TO_TABLE)
@ -3058,9 +3059,13 @@ public class ProfileUtilities extends TranslatingUtilities {
if (definition.hasFixed()) { if (definition.hasFixed()) {
if (!c.getPieces().isEmpty()) c.addPiece(gen.new Piece("br")); if (!c.getPieces().isEmpty()) c.addPiece(gen.new Piece("br"));
c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(null, translate("sd.table", "Fixed Value")+": ", null).addStyle("font-weight:bold"))); c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(null, translate("sd.table", "Fixed Value")+": ", null).addStyle("font-weight:bold")));
if (!useTableForFixedValues || definition.getFixed().isPrimitive()) if (!useTableForFixedValues || definition.getFixed().isPrimitive()) {
c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(null, buildJson(definition.getFixed()), null).addStyle("color: darkgreen"))); String s = buildJson(definition.getFixed());
else { String link = null;
if (Utilities.isAbsoluteUrl(s))
link = pkp.getLinkForUrl(corePath, s);
c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(link, s, null).addStyle("color: darkgreen")));
} else {
c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(null, "As shown", null).addStyle("color: darkgreen"))); c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(null, "As shown", null).addStyle("color: darkgreen")));
genFixedValue(gen, row, definition.getFixed(), snapshot, false, corePath); genFixedValue(gen, row, definition.getFixed(), snapshot, false, corePath);
} }
@ -3182,9 +3187,11 @@ public class ProfileUtilities extends TranslatingUtilities {
c.addPiece(gen.new Piece("br")); c.addPiece(gen.new Piece("br"));
c.getPieces().add(gen.new Piece(null, "Fixed Value: ", null).addStyle("font-weight: bold")); c.getPieces().add(gen.new Piece(null, "Fixed Value: ", null).addStyle("font-weight: bold"));
String s = b.primitiveValue(); String s = b.primitiveValue();
if (Utilities.noString(s)) // ok. let's see if we can find a relevant link for this
System.out.print("t"); String link = null;
c.getPieces().add(gen.new Piece(null, s, null).addStyle("color: darkgreen")); if (Utilities.isAbsoluteUrl(s))
link = pkp.getLinkForUrl(corePath, s);
c.getPieces().add(gen.new Piece(link, s, null).addStyle("color: darkgreen"));
} else { } else {
c = gen.new Cell(); c = gen.new Cell();
row.getCells().add(c); row.getCells().add(c);
@ -3321,7 +3328,11 @@ public class ProfileUtilities extends TranslatingUtilities {
if (definition.hasFixed()) { if (definition.hasFixed()) {
if (!c.getPieces().isEmpty()) c.addPiece(gen.new Piece("br")); if (!c.getPieces().isEmpty()) c.addPiece(gen.new Piece("br"));
c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(null, "Fixed Value: ", null).addStyle("font-weight:bold"))); c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(null, "Fixed Value: ", null).addStyle("font-weight:bold")));
c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(null, buildJson(definition.getFixed()), null).addStyle("color: darkgreen"))); String s = buildJson(definition.getFixed());
String link = null;
if (Utilities.isAbsoluteUrl(s))
link = pkp.getLinkForUrl(corePath, s);
c.getPieces().add(checkForNoChange(definition.getFixed(), gen.new Piece(link, s, null).addStyle("color: darkgreen")));
} else if (definition.hasPattern()) { } else if (definition.hasPattern()) {
if (!c.getPieces().isEmpty()) c.addPiece(gen.new Piece("br")); if (!c.getPieces().isEmpty()) c.addPiece(gen.new Piece("br"));
c.getPieces().add(checkForNoChange(definition.getPattern(), gen.new Piece(null, "Required Pattern: ", null).addStyle("font-weight:bold"))); c.getPieces().add(checkForNoChange(definition.getPattern(), gen.new Piece(null, "Required Pattern: ", null).addStyle("font-weight:bold")));
@ -3740,24 +3751,24 @@ public class ProfileUtilities extends TranslatingUtilities {
// what we have to check for here is running off the base profile into a data type profile // what we have to check for here is running off the base profile into a data type profile
ElementDefinition ed = cmp.snapshot.get(child.getBaseIndex()); ElementDefinition ed = cmp.snapshot.get(child.getBaseIndex());
ElementDefinitionComparer ccmp; ElementDefinitionComparer ccmp;
if (ed.getType().isEmpty() || isAbstract(ed.getType().get(0).getCode()) || ed.getType().get(0).getCode().equals(ed.getPath())) { if (ed.getType().isEmpty() || isAbstract(ed.getType().get(0).getWorkingCode()) || ed.getType().get(0).getWorkingCode().equals(ed.getPath())) {
ccmp = new ElementDefinitionComparer(true, cmp.snapshot, cmp.base, cmp.prefixLength, cmp.name); ccmp = new ElementDefinitionComparer(true, cmp.snapshot, cmp.base, cmp.prefixLength, cmp.name);
} else if (ed.getType().get(0).getCode().equals("Extension") && child.getSelf().getType().size() == 1 && child.getSelf().getType().get(0).hasProfile()) { } else if (ed.getType().get(0).getWorkingCode().equals("Extension") && child.getSelf().getType().size() == 1 && child.getSelf().getType().get(0).hasProfile()) {
StructureDefinition profile = context.fetchResource(StructureDefinition.class, child.getSelf().getType().get(0).getProfile().get(0).getValue()); StructureDefinition profile = context.fetchResource(StructureDefinition.class, child.getSelf().getType().get(0).getProfile().get(0).getValue());
if (profile==null) if (profile==null)
ccmp = null; // this might happen before everything is loaded. And we don't so much care about sot order in this case ccmp = null; // this might happen before everything is loaded. And we don't so much care about sot order in this case
else else
ccmp = new ElementDefinitionComparer(true, profile.getSnapshot().getElement(), ed.getType().get(0).getCode(), child.getSelf().getPath().length(), cmp.name); ccmp = new ElementDefinitionComparer(true, profile.getSnapshot().getElement(), ed.getType().get(0).getWorkingCode(), child.getSelf().getPath().length(), cmp.name);
} else if (ed.getType().size() == 1 && !ed.getType().get(0).getCode().equals("*")) { } else if (ed.getType().size() == 1 && !ed.getType().get(0).getWorkingCode().equals("*")) {
StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs(ed.getType().get(0).getCode())); StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs(ed.getType().get(0).getWorkingCode()));
if (profile==null) if (profile==null)
throw new FHIRException("Unable to resolve profile " + sdNs(ed.getType().get(0).getCode()) + " in element " + ed.getPath()); throw new FHIRException("Unable to resolve profile " + sdNs(ed.getType().get(0).getWorkingCode()) + " in element " + ed.getPath());
ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), ed.getType().get(0).getCode(), child.getSelf().getPath().length(), cmp.name); ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), ed.getType().get(0).getWorkingCode(), child.getSelf().getPath().length(), cmp.name);
} else if (child.getSelf().getType().size() == 1) { } else if (child.getSelf().getType().size() == 1) {
StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs(child.getSelf().getType().get(0).getCode())); StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs(child.getSelf().getType().get(0).getWorkingCode()));
if (profile==null) if (profile==null)
throw new FHIRException("Unable to resolve profile " + sdNs(ed.getType().get(0).getCode()) + " in element " + ed.getPath()); throw new FHIRException("Unable to resolve profile " + sdNs(ed.getType().get(0).getWorkingCode()) + " in element " + ed.getPath());
ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), child.getSelf().getType().get(0).getCode(), child.getSelf().getPath().length(), cmp.name); ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), child.getSelf().getType().get(0).getWorkingCode(), child.getSelf().getPath().length(), cmp.name);
} else if (ed.getPath().endsWith("[x]") && !child.getSelf().getPath().endsWith("[x]")) { } else if (ed.getPath().endsWith("[x]") && !child.getSelf().getPath().endsWith("[x]")) {
String edLastNode = ed.getPath().replaceAll("(.*\\.)*(.*)", "$2"); String edLastNode = ed.getPath().replaceAll("(.*\\.)*(.*)", "$2");
String childLastNode = child.getSelf().getPath().replaceAll("(.*\\.)*(.*)", "$2"); String childLastNode = child.getSelf().getPath().replaceAll("(.*\\.)*(.*)", "$2");
@ -3768,27 +3779,27 @@ public class ProfileUtilities extends TranslatingUtilities {
if (sd == null) if (sd == null)
throw new Error("Unable to find profile '"+p+"' at "+ed.getId()); throw new Error("Unable to find profile '"+p+"' at "+ed.getId());
ccmp = new ElementDefinitionComparer(false, sd.getSnapshot().getElement(), p, child.getSelf().getPath().length(), cmp.name); ccmp = new ElementDefinitionComparer(false, sd.getSnapshot().getElement(), p, child.getSelf().getPath().length(), cmp.name);
} else if (child.getSelf().hasType() && child.getSelf().getType().get(0).getCode().equals("Reference")) { } else if (child.getSelf().hasType() && child.getSelf().getType().get(0).getWorkingCode().equals("Reference")) {
for (TypeRefComponent t: child.getSelf().getType()) { for (TypeRefComponent t: child.getSelf().getType()) {
if (!t.getCode().equals("Reference")) { if (!t.getWorkingCode().equals("Reference")) {
throw new Error("Can't have children on an element with a polymorphic type - you must slice and constrain the types first (sortElements: "+ed.getPath()+":"+typeCode(ed.getType())+")"); throw new Error("Can't have children on an element with a polymorphic type - you must slice and constrain the types first (sortElements: "+ed.getPath()+":"+typeCode(ed.getType())+")");
} }
} }
StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs(ed.getType().get(0).getCode())); StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs(ed.getType().get(0).getWorkingCode()));
ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), ed.getType().get(0).getCode(), child.getSelf().getPath().length(), cmp.name); ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), ed.getType().get(0).getWorkingCode(), child.getSelf().getPath().length(), cmp.name);
} else if (!child.getSelf().hasType() && ed.getType().get(0).getCode().equals("Reference")) { } else if (!child.getSelf().hasType() && ed.getType().get(0).getWorkingCode().equals("Reference")) {
for (TypeRefComponent t: ed.getType()) { for (TypeRefComponent t: ed.getType()) {
if (!t.getCode().equals("Reference")) { if (!t.getWorkingCode().equals("Reference")) {
throw new Error("Not handled yet (sortElements: "+ed.getPath()+":"+typeCode(ed.getType())+")"); throw new Error("Not handled yet (sortElements: "+ed.getPath()+":"+typeCode(ed.getType())+")");
} }
} }
StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs(ed.getType().get(0).getCode())); StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs(ed.getType().get(0).getWorkingCode()));
ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), ed.getType().get(0).getCode(), child.getSelf().getPath().length(), cmp.name); ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), ed.getType().get(0).getWorkingCode(), child.getSelf().getPath().length(), cmp.name);
} else { } else {
// this is allowed if we only profile the extensions // this is allowed if we only profile the extensions
StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs("Element")); StructureDefinition profile = context.fetchResource(StructureDefinition.class, sdNs("Element"));
if (profile==null) if (profile==null)
throw new FHIRException("Unable to resolve profile " + sdNs(ed.getType().get(0).getCode()) + " in element " + ed.getPath()); throw new FHIRException("Unable to resolve profile " + sdNs(ed.getType().get(0).getWorkingCode()) + " in element " + ed.getPath());
ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), "Element", child.getSelf().getPath().length(), cmp.name); ccmp = new ElementDefinitionComparer(false, profile.getSnapshot().getElement(), "Element", child.getSelf().getPath().length(), cmp.name);
// throw new Error("Not handled yet (sortElements: "+ed.getPath()+":"+typeCode(ed.getType())+")"); // throw new Error("Not handled yet (sortElements: "+ed.getPath()+":"+typeCode(ed.getType())+")");
} }

View File

@ -989,6 +989,7 @@ public abstract class BaseWorkerContext implements IWorkerContext {
result.addAll(maps.values()); result.addAll(maps.values());
result.addAll(transforms.values()); result.addAll(transforms.values());
result.addAll(plans.values()); result.addAll(plans.values());
result.addAll(questionnaires.values());
return result; return result;
} }
} }
@ -1139,5 +1140,59 @@ public abstract class BaseWorkerContext implements IWorkerContext {
return res; return res;
} }
public String getLinkForUrl(String corePath, String url) {
for (CodeSystem r : codeSystems.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (ValueSet r : valueSets.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (ConceptMap r : maps.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (StructureMap r : transforms.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (StructureDefinition r : structures.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (ImplementationGuide r : guides.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (CapabilityStatement r : capstmts.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (SearchParameter r : searchParameters.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (Questionnaire r : questionnaires.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (OperationDefinition r : operations.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
for (PlanDefinition r : plans.values())
if (url.equals(r.getUrl()))
return r.getUserString("path");
if (url.equals("http://loinc.org"))
return corePath+"loinc.html";
if (url.equals("http://unitsofmeasure.org"))
return corePath+"ucum.html";
if (url.equals("http://snomed.info/sct"))
return corePath+"snomed.html";
return null;
}
} }

View File

@ -451,4 +451,6 @@ public interface IWorkerContext {
public StructureDefinition fetchTypeDefinition(String typeName); public StructureDefinition fetchTypeDefinition(String typeName);
public void setUcumService(UcumService ucumService); public void setUcumService(UcumService ucumService);
public String getLinkForUrl(String corePath, String s);
} }