further revisions to rendering framework for id uniqueness, main spec rendering, and various reported issues

This commit is contained in:
Grahame Grieve 2024-07-12 05:09:21 +08:00
parent dd02db3aae
commit d8f7b98573
11 changed files with 292 additions and 62 deletions

View File

@ -343,6 +343,24 @@ public class Element extends Base implements NamedItem {
} }
} }
public void setChildValue(String name, Base value) {
if (children == null)
children = new NamedItemList<Element>();
for (Element child : children) {
if (name.equals(child.getName())) {
if (!child.isPrimitive())
throw new Error("Cannot set a value of a non-primitive type ("+name+" on "+this.getName()+")");
child.setValue(value.primitiveValue());
}
}
try {
setProperty(name.hashCode(), name, value);
} catch (FHIRException e) {
throw new Error(e);
}
}
public List<Element> getChildren(String name) { public List<Element> getChildren(String name) {
List<Element> res = new ArrayList<Element>(); List<Element> res = new ArrayList<Element>();
if (children.size() > 20) { if (children.size() > 20) {
@ -478,6 +496,11 @@ public class Element extends Base implements NamedItem {
children.add(i, ne); children.add(i, ne);
childForValue = ne; childForValue = ne;
break; break;
} else if (p.getName().endsWith("[x]") && name.startsWith(p.getName().replace("[x]", ""))) {
Element ne = new Element(p.getName(), p).setFormat(format);
children.add(i, ne);
childForValue = ne;
break;
} }
} }
@ -485,7 +508,7 @@ public class Element extends Base implements NamedItem {
throw new Error("Cannot set property "+name+" on "+this.name); throw new Error("Cannot set property "+name+" on "+this.name);
else if (value.isPrimitive()) { else if (value.isPrimitive()) {
if (childForValue.property.getName().endsWith("[x]")) if (childForValue.property.getName().endsWith("[x]"))
childForValue.name = name+Utilities.capitalize(value.fhirType()); childForValue.name = childForValue.name.replace("[x]", "")+Utilities.capitalize(value.fhirType());
childForValue.setValue(value.primitiveValue()); childForValue.setValue(value.primitiveValue());
} else { } else {
Element ve = (Element) value; Element ve = (Element) value;
@ -693,6 +716,7 @@ public class Element extends Base implements NamedItem {
public Element getNamedChild(String name) { public Element getNamedChild(String name) {
return getNamedChild(name, true); return getNamedChild(name, true);
} }
public Element getNamedChild(String name, boolean exception) { public Element getNamedChild(String name, boolean exception) {
if (children == null) if (children == null)
return null; return null;
@ -1163,7 +1187,9 @@ public class Element extends Base implements NamedItem {
} }
public void removeChild(String name) { public void removeChild(String name) {
children.removeIf(n -> name.equals(n.getName())); if (children.removeIf(n -> name.equals(n.getName()))) {
children.clearMap();
}
} }
public boolean isProhibited() { public boolean isProhibited() {

View File

@ -24,13 +24,9 @@ public class ActorDefinitionRenderer extends ResourceRenderer {
@Override @Override
public void buildNarrative(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException, FHIRException, EOperationOutcome { public void buildNarrative(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException, FHIRException, EOperationOutcome {
if (r.isDirect()) {
renderResourceTechDetails(r, x); renderResourceTechDetails(r, x);
genSummaryTable(status, x, (ActorDefinition) r.getBase()); genSummaryTable(status, x, r);
render(status, x, (ActorDefinition) r.getBase(), r); render(status, x, r);
} else {
throw new Error("ActorDefinitionRenderer only renders native resources directly");
}
} }
@Override @Override
@ -38,35 +34,35 @@ public class ActorDefinitionRenderer extends ResourceRenderer {
return canonicalTitle(r); return canonicalTitle(r);
} }
public void render(RenderingStatus status, XhtmlNode x, ActorDefinition acd, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException { public void render(RenderingStatus status, XhtmlNode x, ResourceWrapper acd) throws FHIRFormatError, DefinitionException, IOException {
XhtmlNode tbl = x.table("grid"); XhtmlNode tbl = x.table("grid");
XhtmlNode tr = tbl.tr(); XhtmlNode tr = tbl.tr();
tr.td().b().tx(context.formatPhrase(RenderingContext.ACTOR_DEF_ACT, acd.getName()) + " "); tr.td().b().tx(context.formatPhrase(RenderingContext.ACTOR_DEF_ACT, context.getTranslated(acd.child("name"))) + " ");
tr.td().tx(acd.getTitle()); tr.td().tx(context.getTranslated(acd.child("title")));
tr.td().tx(context.formatPhrase(RenderingContext.ACTOR_DEF_TYP, acd.getType().toCode()) + " "); tr.td().tx(context.formatPhrase(RenderingContext.ACTOR_DEF_TYP, acd.primitiveValue("type")) + " ");
XhtmlNode td = tbl.tr().td().colspan("3"); XhtmlNode td = tbl.tr().td().colspan("3");
addMarkdown(td, acd.getDocumentation()); addMarkdown(td, context.getTranslated(acd.child("documentation")));
if (acd.hasReference()) { if (acd.has("reference")) {
tbl.tr().td().tx(context.formatPhrase(RenderingContext.GENERAL_REFS)); tbl.tr().td().tx(context.formatPhrase(RenderingContext.GENERAL_REFS));
td = tr.td().colspan("2"); td = tr.td().colspan("2");
boolean first = true; boolean first = true;
for (UrlType t : acd.getReference()) { for (ResourceWrapper t : acd.children("reference")) {
if (first) first = false; else x.br(); if (first) first = false; else x.br();
renderUri(status, td, wrapWC(r, t)); renderUri(status, td, t);
} }
} }
if (acd.hasCapabilities()) { if (acd.has("capabilities")) {
tbl.tr().td().tx(context.formatPhrase(RenderingContext.ACTOR_DEF_CAP)); tbl.tr().td().tx(context.formatPhrase(RenderingContext.ACTOR_DEF_CAP));
td = tr.td().colspan("2"); td = tr.td().colspan("2");
renderCanonical(status, r, td, CapabilityStatement.class, acd.getCapabilitiesElement()); renderCanonical(status, td, acd.child("capabilities"));
} }
if (acd.hasDerivedFrom()) { if (acd.has("derivedFrom")) {
tbl.tr().td().tx(context.formatPhrase(RenderingContext.ACTOR_DEF_DER)); tbl.tr().td().tx(context.formatPhrase(RenderingContext.ACTOR_DEF_DER));
td = tr.td().colspan("2"); td = tr.td().colspan("2");
boolean first = true; boolean first = true;
for (UrlType t : acd.getReference()) { for (ResourceWrapper t : acd.children("reference")) {
if (first) first = false; else x.br(); if (first) first = false; else x.br();
renderUri(status, r, td, t); renderUri(status, td, t);
} }
} }
} }

View File

@ -69,7 +69,11 @@ public class BundleRenderer extends ResourceRenderer {
if (id != null && !context.hasAnchor(anchor)) { if (id != null && !context.hasAnchor(anchor)) {
context.addAnchor(anchor); context.addAnchor(anchor);
root.an(context.prefixAnchor(anchor)); root.an(context.prefixAnchor(anchor));
root.an(context.prefixAnchor("hc"+anchor)); }
anchor = "hc"+anchor;
if (id != null && !context.hasAnchor(anchor)) {
context.addAnchor(anchor);
root.an(context.prefixAnchor(anchor));
} }
} }
root.hr(); root.hr();
@ -100,8 +104,10 @@ public class BundleRenderer extends ResourceRenderer {
xn = new XhtmlNode(); xn = new XhtmlNode();
xn.para().b().tx(context.formatPhrase(RenderingContext.BUNDLE_REV_EXCP, e.getMessage()) + " "); xn.para().b().tx(context.formatPhrase(RenderingContext.BUNDLE_REV_EXCP, e.getMessage()) + " ");
} }
} else {
xn.stripAnchorsByName(context.getAnchors());
} }
root.blockquote().para().addChildren(xn); root.blockquote().addChildren(xn);
} }
if (be.has("request")) { if (be.has("request")) {
renderRequest(x, be.child("request")); renderRequest(x, be.child("request"));

View File

@ -1830,7 +1830,7 @@ public class DataRenderer extends Renderer implements CodeResolver {
x.addText(q.child("high").primitiveValue("value").toString()); x.addText(q.child("high").primitiveValue("value").toString());
else else
x.tx("?"); x.tx("?");
if (q.child("low").has("unit")) if (q.has("low") && q.child("low").has("unit"))
x.tx(" "+q.child("low").child("unit")); x.tx(" "+q.child("low").child("unit"));
} }
@ -2071,7 +2071,7 @@ public class DataRenderer extends Renderer implements CodeResolver {
private boolean renderExpression(CommaSeparatedStringBuilder c, ResourceWrapper p) { private boolean renderExpression(CommaSeparatedStringBuilder c, ResourceWrapper p) {
ResourceWrapper exp = p.extensionValue("http://hl7.org/fhir/StructureDefinition/cqf-expression"); ResourceWrapper exp = p.extensionValue("http://hl7.org/fhir/StructureDefinition/cqf-expression");
if (exp == null) { if (exp == null || !exp.has("value")) {
return false; return false;
} }
c.append(exp.child("value").primitiveValue("expression")); c.append(exp.child("value").primitiveValue("expression"));

View File

@ -52,8 +52,10 @@ public class ProfileDrivenRenderer extends ResourceRenderer {
generateByProfile(status, r, sd, r, sd.getSnapshot().getElement(), ed, context.getProfileUtilities().getChildList(sd, ed), x, r.fhirType(), context.isTechnicalMode(), 0); generateByProfile(status, r, sd, r, sd.getSnapshot().getElement(), ed, context.getProfileUtilities().getChildList(sd, ed), x, r.fhirType(), context.isTechnicalMode(), 0);
} }
} catch (Exception e) { } catch (Exception e) {
if (DEBUG) {
System.out.println(context.formatPhrase(RenderingContext.PROF_DRIV_ERR_GEN_NARR) +r.fhirType()+"/"+r.getId()+": "+e.getMessage()); System.out.println(context.formatPhrase(RenderingContext.PROF_DRIV_ERR_GEN_NARR) +r.fhirType()+"/"+r.getId()+": "+e.getMessage());
e.printStackTrace(); e.printStackTrace();
}
x.para().b().style("color: maroon").tx(context.formatPhrase(RenderingContext.PROF_DRIV_EXCP, e.getMessage())+" "); x.para().b().style("color: maroon").tx(context.formatPhrase(RenderingContext.PROF_DRIV_EXCP, e.getMessage())+" ");
} }
} }

View File

@ -362,7 +362,7 @@ public class QuestionnaireRenderer extends TerminologyRenderer {
defn.getPieces().add(gen.new Piece(null, (context.formatPhrase(RenderingContext.QUEST_OPTIONS)+" "), null)); defn.getPieces().add(gen.new Piece(null, (context.formatPhrase(RenderingContext.QUEST_OPTIONS)+" "), null));
if (context.getDefinitionsTarget() == null) { if (context.getDefinitionsTarget() == null) {
// if we don't have a definitions target, we'll add them below. // if we don't have a definitions target, we'll add them below.
defn.getPieces().add(gen.new Piece("#opt-item."+i.primitiveValue("linkId"), Integer.toString(i.children("answerOption").size())+" "+Utilities.pluralize("option", i.children("answerOption").size()), null)); defn.getPieces().add(gen.new Piece("#"+context.prefixAnchor("opt-item."+i.primitiveValue("linkId")), Integer.toString(i.children("answerOption").size())+" "+Utilities.pluralize("option", i.children("answerOption").size()), null));
} else { } else {
defn.getPieces().add(gen.new Piece(context.getDefinitionsTarget()+"#item."+i.primitiveValue("linkId"), Integer.toString(i.children("answerOption").size())+" "+Utilities.pluralize("option", i.children("answerOption").size()), null)); defn.getPieces().add(gen.new Piece(context.getDefinitionsTarget()+"#item."+i.primitiveValue("linkId"), Integer.toString(i.children("answerOption").size())+" "+Utilities.pluralize("option", i.children("answerOption").size()), null));
} }

View File

@ -40,6 +40,8 @@ import org.hl7.fhir.utilities.xhtml.XhtmlNode;
*/ */
public class Renderer { public class Renderer {
protected static final boolean DEBUG = false;
public static class RenderingStatus { public static class RenderingStatus {
private boolean extensions; private boolean extensions;

View File

@ -245,7 +245,6 @@ public abstract class ResourceRenderer extends DataRenderer {
actual = type; actual = type;
} }
if (actual != null && actual.hasPrimitiveValue()) { if (actual != null && actual.hasPrimitiveValue()) {
System.out.println("displayReference: "+actual);
if ("#".equals(actual.primitiveValue())) { if ("#".equals(actual.primitiveValue())) {
return "this resource"; return "this resource";
} else { } else {
@ -344,9 +343,12 @@ public abstract class ResourceRenderer extends DataRenderer {
} else if (rr.getResource() == null) { } else if (rr.getResource() == null) {
String disp = display != null && display.hasPrimitiveValue() ? displayDataType(display) : "??"; String disp = display != null && display.hasPrimitiveValue() ? displayDataType(display) : "??";
x.ah(context.prefixLocalHref(rr.getWebPath())).tx(disp); x.ah(context.prefixLocalHref(rr.getWebPath())).tx(disp);
} else { } else if (rr.getResource() != null) {
String disp = display != null && display.hasPrimitiveValue() ? displayDataType(display) : RendererFactory.factory(rr.getResource(), context.forContained()).buildSummary(rr.getResource()); String disp = display != null && display.hasPrimitiveValue() ? displayDataType(display) : RendererFactory.factory(rr.getResource(), context.forContained()).buildSummary(rr.getResource());
x.ah(context.prefixLocalHref(rr.getWebPath())).tx(disp); x.ah(context.prefixLocalHref(rr.getWebPath())).tx(disp);
} else {
String disp = display != null && display.hasPrimitiveValue() ? displayDataType(display) : "??";
x.ah(context.prefixLocalHref(rr.getWebPath())).tx(disp);
} }
} else if (display != null && id != null) { } else if (display != null && id != null) {
renderDataType(status, x, display); renderDataType(status, x, display);
@ -829,12 +831,24 @@ public abstract class ResourceRenderer extends DataRenderer {
// first thing we do is lay down the resource anchors. // first thing we do is lay down the resource anchors.
if (!Utilities.noString(r.getId())) { if (!Utilities.noString(r.getId())) {
if (!context.isSecondaryLang()) { if (!context.isSecondaryLang()) {
x.an(context.prefixAnchor(r.getScopedId())); String sid = r.getScopedId();
x.an(context.prefixAnchor("hc"+r.getScopedId())); if (!context.hasAnchor(sid)) {
context.addAnchor(sid);
x.an(context.prefixAnchor(sid));
}
sid = "hc"+sid;
if (!context.hasAnchor(sid)) {
context.addAnchor(sid);
x.an(context.prefixAnchor(sid));
}
} }
if (context.getLocale() != null) { if (context.getLocale() != null) {
String langSuffix = "-"+context.getLocale().toLanguageTag(); String langSuffix = "-"+context.getLocale().toLanguageTag();
x.an(context.prefixAnchor("hc"+r.getScopedId()+langSuffix)); String sid = r.getScopedId()+langSuffix;
if (!context.hasAnchor(sid)) {
context.addAnchor(sid);
x.an(context.prefixAnchor(sid));
}
} }
} }
@ -1050,6 +1064,99 @@ public abstract class ResourceRenderer extends DataRenderer {
} }
} }
public void genSummaryTable(RenderingStatus status, XhtmlNode x, ResourceWrapper cr) throws IOException {
if (context.isShowSummaryTable() && cr != null) {
XhtmlNode tbl = x.table("grid");
genSummaryTableContent(status, tbl, cr);
}
}
protected void genSummaryTableContent(RenderingStatus status, XhtmlNode tbl, ResourceWrapper cr) throws IOException {
XhtmlNode tr;
if (cr.has("url")) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL)+":");
tr.td().code().tx(cr.primitiveValue("url"));
} else if (cr.hasExtension("http://hl7.org/fhir/5.0/StructureDefinition/extension-NamingSystem.url")) {
status.setExtensions(true);
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL)+":");
tr.td().code().tx(cr.extensionString("http://hl7.org/fhir/5.0/StructureDefinition/extension-NamingSystem.url"));
} else if (!context.isContained()) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL));
tr.td();
}
if (cr.has("version")) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_VER)+":");
renderDataType(status, tr.td(), cr.child("version"));
} else if (cr.hasExtension("http://terminology.hl7.org/StructureDefinition/ext-namingsystem-version")) {
status.setExtensions(true);
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_VER)+":");
renderDataType(status, tr.td(), cr.extensionValue("http://hl7.org/fhir/5.0/StructureDefinition/extension-NamingSystem.version"));
}
String name = context.getTranslated(cr.child("name"));
String title = context.getTranslated(cr.child("title"));
if (name != null) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_NAME)+":");
tr.td().tx(name);
}
if (title != null && !title.equalsIgnoreCase(name)) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_TITLE)+":");
tr.td().tx(title);
}
if (cr.has("status") && !context.isContained()) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_STATUS)+":");
tr.td().tx(describeStatus(status, cr));
}
if (cr.has("description")) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINITION)+":");
tr.td().markdown(context.getTranslated(cr.child("description")), "description");
}
if (cr.has("publisher")) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.CANON_REND_PUBLISHER)+":");
buildPublisherLinks( tr.td(), cr);
}
if (cr.hasExtension(ToolingExtensions.EXT_WORKGROUP)) {
status.setExtensions(true);
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.CANON_REND_COMMITTEE)+":");
renderCommitteeLink(tr.td(), cr);
}
if (cr.has("copyright")) {
tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_COPYRIGHT)+":");
tr.td().markdown(context.getTranslated(cr.child("copyright")), "copyright");
}
if (cr.hasExtension(ToolingExtensions.EXT_FMM_LEVEL)) {
status.setExtensions(true);
// Use hard-coded spec link to point to current spec because DSTU2 had maturity listed on a different page
tr = tbl.tr();
tr.td().ah("http://hl7.org/fhir/versions.html#maturity", "Maturity Level").attribute("class", "fmm").tx(context.formatPhrase(RenderingContext.CANON_REND_COMMITTEE)+":");
renderDataType(status, tr.td(), cr.extensionValue(ToolingExtensions.EXT_FMM_LEVEL));
}
}
public void genSummaryTable(RenderingStatus status, XhtmlNode x, CanonicalResource cr) throws IOException { public void genSummaryTable(RenderingStatus status, XhtmlNode x, CanonicalResource cr) throws IOException {
if (context.isShowSummaryTable() && cr != null) { if (context.isShowSummaryTable() && cr != null) {
XhtmlNode tbl = x.table("grid"); XhtmlNode tbl = x.table("grid");
@ -1063,12 +1170,12 @@ public abstract class ResourceRenderer extends DataRenderer {
if (cr.hasUrl()) { if (cr.hasUrl()) {
tr = tbl.tr(); tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL)+":"); tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL)+":");
tr.td().tx(cr.getUrl()); tr.td().code().tx(cr.getUrl());
} else if (cr.hasExtension("http://hl7.org/fhir/5.0/StructureDefinition/extension-NamingSystem.url")) { } else if (cr.hasExtension("http://hl7.org/fhir/5.0/StructureDefinition/extension-NamingSystem.url")) {
status.setExtensions(true); status.setExtensions(true);
tr = tbl.tr(); tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL)); tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL));
tr.td().tx(ToolingExtensions.readStringExtension(cr, "http://hl7.org/fhir/5.0/StructureDefinition/extension-NamingSystem.url")+":"); tr.td().code().tx(ToolingExtensions.readStringExtension(cr, "http://hl7.org/fhir/5.0/StructureDefinition/extension-NamingSystem.url")+":");
} else if (!context.isContained()) { } else if (!context.isContained()) {
tr = tbl.tr(); tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL)); tr.td().tx(context.formatPhrase(RenderingContext.GENERAL_DEFINING_URL));
@ -1115,14 +1222,14 @@ public abstract class ResourceRenderer extends DataRenderer {
if (cr.hasPublisher()) { if (cr.hasPublisher()) {
tr = tbl.tr(); tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.CANON_REND_PUBLISHER)+":"); tr.td().tx(context.formatPhrase(RenderingContext.CANON_REND_PUBLISHER)+":");
tr.td().tx(buildPublisherLinks(cr)); buildPublisherLinks(tr.td(), cr);
} }
if (cr.hasExtension(ToolingExtensions.EXT_WORKGROUP)) { if (cr.hasExtension(ToolingExtensions.EXT_WORKGROUP)) {
status.setExtensions(true); status.setExtensions(true);
tr = tbl.tr(); tr = tbl.tr();
tr.td().tx(context.formatPhrase(RenderingContext.CANON_REND_COMMITTEE)+":"); tr.td().tx(context.formatPhrase(RenderingContext.CANON_REND_COMMITTEE)+":");
tr.td().tx(renderCommitteeLink(cr)); renderCommitteeLink(tr.td(), cr);
} }
if (cr.hasCopyright()) { if (cr.hasCopyright()) {
@ -1141,68 +1248,137 @@ public abstract class ResourceRenderer extends DataRenderer {
} }
protected String renderCommitteeLink(CanonicalResource cr) { protected void renderCommitteeLink(XhtmlNode x, ResourceWrapper cr) {
String code = ToolingExtensions.readStringExtension(cr, ToolingExtensions.EXT_WORKGROUP); String code = cr.extensionString(ToolingExtensions.EXT_WORKGROUP);
CodeSystem cs = context.getContext().fetchCodeSystem("http://terminology.hl7.org/CodeSystem/hl7-work-group"); CodeSystem cs = context.getContext().fetchCodeSystem("http://terminology.hl7.org/CodeSystem/hl7-work-group");
if (cs == null || !cs.hasWebPath()) if (cs == null || !cs.hasWebPath())
return code; x.tx(code);
else { else {
ConceptDefinitionComponent cd = CodeSystemUtilities.findCode(cs.getConcept(), code); ConceptDefinitionComponent cd = CodeSystemUtilities.findCode(cs.getConcept(), code);
if (cd == null) { if (cd == null) {
return code; x.tx(code);
} else { } else {
return "<a href=\""+cs.getWebPath()+"#"+cs.getId()+"-"+cd.getCode()+"\">"+cd.getDisplay()+"</a>"; x.ah(cs.getWebPath()+"#"+cs.getId()+"-"+cd.getCode()).tx(cd.getDisplay());
} }
} }
} }
private String buildPublisherLinks(CanonicalResource cr) { private void buildPublisherLinks(XhtmlNode x, CanonicalResource cr) {
CommaSeparatedStringBuilder b = new CommaSeparatedStringBuilder(". ");
boolean useName = false; boolean useName = false;
for (ContactDetail cd : cr.getContact()) { for (ContactDetail cd : cr.getContact()) {
if (!cd.hasName()) { if (!cd.hasName()) {
useName = true; useName = true;
} }
} }
boolean first = true;
if (!useName) { if (!useName) {
b.append(Utilities.escapeXml(cr.getPublisher())); x.tx(Utilities.escapeXml(cr.getPublisher()));
first = false;
} }
for (ContactDetail cd : cr.getContact()) { for (ContactDetail cd : cr.getContact()) {
String name = cd.hasName() ? cd.getName() : cr.getPublisher(); String name = cd.hasName() ? cd.getName() : cr.getPublisher();
b.append(renderContact(name, cd.getTelecom())); if (cd.hasTelecom()) {
if (first) first = false; else x.tx(". ");
renderContact(x, name, cd.getTelecom());
}
} }
return b.toString();
} }
private String renderContact(String name, List<ContactPoint> telecom) { private void buildPublisherLinks(XhtmlNode x, ResourceWrapper cr) {
boolean useName = false;
for (ResourceWrapper cd : cr.children("contact")) {
if (!cd.has("name")) {
useName = true;
}
}
boolean first = true;
if (!useName) {
x.tx(Utilities.escapeXml(cr.primitiveValue("publisher")));
first = false;
}
for (ResourceWrapper cd : cr.children("contact")) {
String name = cd.has("name") ? cd.primitiveValue("name") : cr.primitiveValue("publisher");
if (cd.has("telecom")) {
if (first) first = false; else x.tx(". ");
renderContactW(x, name, cd.children("telecom"));
}
}
}
private void renderContactW(XhtmlNode x, String name, List<ResourceWrapper> telecom) {
List<String> urls = new ArrayList<>();
for (ResourceWrapper t : telecom) {
if ("url".equals(t.primitiveValue()) && t.has("value")) {
urls.add(t.primitiveValue("value"));
}
}
if (urls.size() == 1) {
x.ah(urls.get(0)).tx(name);
} else { // if (urls.size() == 0) {
x.tx(name);
}
for (ResourceWrapper t : telecom) {
String system = t.primitiveValue("system");
String value = t.primitiveValue("value");
if ("url".equals(system) && value != null && urls.size() != 1) {
x.tx(", ");
x.ah(t.primitiveValue("value")).tx("Link");
}
if ("email".equals(system) && value != null) {
x.tx(", ");
x.ah("mailto:"+t.primitiveValue("value")).tx("Email");
}
if ("phone".equals(system) && value != null) {
x.tx(", ");
x.tx(t.primitiveValue("value"));
}
if ("fax".equals(system) && value != null) {
x.tx(", ");
x.tx("Fax:"+t.primitiveValue("value"));
}
}
}
private void renderContact(XhtmlNode x, String name, List<ContactPoint> telecom) {
List<String> urls = new ArrayList<>(); List<String> urls = new ArrayList<>();
for (ContactPoint t : telecom) { for (ContactPoint t : telecom) {
if (t.getSystem() == ContactPointSystem.URL && t.hasValue()) { if (t.getSystem() == ContactPointSystem.URL && t.hasValue()) {
urls.add(t.getValue()); urls.add(t.getValue());
} }
} }
StringBuilder b = new StringBuilder();
if (urls.size() == 1) { if (urls.size() == 1) {
b.append("<a href=\""+Utilities.escapeXml(urls.get(0))+"\">"+Utilities.escapeXml(name)+"</a>"); x.ah(urls.get(0)).tx(name);
} else if (urls.size() == 1) { } else { // if (urls.size() == 0) {
b.append(Utilities.escapeXml(name)); x.tx(name);
} }
for (ContactPoint t : telecom) { for (ContactPoint t : telecom) {
b.append(", "); if (t.getSystem() == ContactPointSystem.URL && t.hasValue() && urls.size() != 1) {
if (t.getSystem() == ContactPointSystem.URL && t.hasValue() && urls.size() > 1) { x.tx(", ");
b.append("<a href=\""+Utilities.escapeXml(t.getValue())+"\">Link</a>"); x.ah(t.getValue()).tx("Link");
} }
if (t.getSystem() == ContactPointSystem.EMAIL && t.hasValue()) { if (t.getSystem() == ContactPointSystem.EMAIL && t.hasValue()) {
b.append("<a href=\"mailto:"+Utilities.escapeXml(t.getValue())+"\">Email</a>"); x.tx(", ");
x.ah("mailto:"+t.getValue()).tx("Email");
} }
if (t.getSystem() == ContactPointSystem.PHONE && t.hasValue()) { if (t.getSystem() == ContactPointSystem.PHONE && t.hasValue()) {
b.append(Utilities.escapeXml(t.getValue())); x.tx(", ");
x.tx(t.getValue());
} }
if (t.getSystem() == ContactPointSystem.FAX && t.hasValue()) { if (t.getSystem() == ContactPointSystem.FAX && t.hasValue()) {
b.append("Fax:"+Utilities.escapeXml(t.getValue())); x.tx(", ");
x.tx("Fax:"+t.getValue());
} }
} }
return b.toString(); }
protected String describeStatus(RenderingStatus status, ResourceWrapper cr) {
String s = describeStatus(cr.primitiveValue("status"), cr.primitiveValue("experimental"), cr.child("date"), cr.extensionString("http://hl7.org/fhir/StructureDefinition/valueset-deprecated"));
if (cr.hasExtension(ToolingExtensions.EXT_STANDARDS_STATUS)) {
status.setExtensions(true);
s = s + presentStandardsStatus(cr.extensionString(ToolingExtensions.EXT_STANDARDS_STATUS));
}
return s;
} }
protected String describeStatus(RenderingStatus status, CanonicalResource cr) { protected String describeStatus(RenderingStatus status, CanonicalResource cr) {
@ -1245,4 +1421,21 @@ public abstract class ResourceRenderer extends DataRenderer {
} }
} }
protected String describeStatus(String status, String experimental, ResourceWrapper dt, String deprecated) {
String sfx = dt != null ? " as of "+displayDataType(dt) : "";
if ("true".equals(deprecated)) {
if ("retired".equals(status)) {
return "Deprecated + Retired"+sfx;
} else {
return "Deprecated"+sfx;
}
} else {
switch (status) {
case "active": return ("true".equals(experimental) ? "Experimental" : "Active")+sfx;
case "draft": return "Draft"+sfx;
case "retired": return "Retired"+sfx;
default: return "Unknown"+sfx;
}
}
}
} }

View File

@ -2779,7 +2779,9 @@ public class StructureDefinitionRenderer extends ResourceRenderer {
} else { } else {
StructureDefinition sd = context.getWorker().fetchTypeDefinition(t); StructureDefinition sd = context.getWorker().fetchTypeDefinition(t);
if (sd == null) { if (sd == null) {
if (DEBUG) {
System.out.println("Unable to find "+t); System.out.println("Unable to find "+t);
}
sd = context.getWorker().fetchTypeDefinition(t); sd = context.getWorker().fetchTypeDefinition(t);
} else if (sd.getKind() == StructureDefinitionKind.PRIMITIVETYPE) { } else if (sd.getKind() == StructureDefinitionKind.PRIMITIVETYPE) {
used = true; used = true;

View File

@ -31,7 +31,6 @@ import org.hl7.fhir.utilities.xhtml.XhtmlNode;
public abstract class TerminologyRenderer extends ResourceRenderer { public abstract class TerminologyRenderer extends ResourceRenderer {
private static final boolean DEBUG = false;
public TerminologyRenderer(RenderingContext context) { public TerminologyRenderer(RenderingContext context) {

View File

@ -1012,4 +1012,8 @@ public class RenderingContext extends RenderingI18nContext {
public void addAnchor(String anchor) { public void addAnchor(String anchor) {
anchors.add(anchor); anchors.add(anchor);
} }
public Set<String> getAnchors() {
return anchors;
}
} }