improvements in rendering profiles
This commit is contained in:
parent
c794c9393b
commit
07f4743cd1
|
@ -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())+")");
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue