NIFI-9742: Use dependent property Display Names in documentation

This closes #5820

Signed-off-by: David Handermann <exceptionfactory@apache.org>
This commit is contained in:
Matthew Burgess 2022-03-01 12:40:06 -05:00 committed by exceptionfactory
parent 58f93d1f8b
commit 5591bec44b
No known key found for this signature in database
GPG Key ID: 29B6A52D2AAE8DBA
1 changed files with 36 additions and 11 deletions

View File

@ -609,23 +609,48 @@ public class HtmlDocumentationWriter implements DocumentationWriter {
for (final PropertyDependency dependency : dependencies) { for (final PropertyDependency dependency : dependencies) {
final Set<String> dependentValues = dependency.getDependentValues(); final Set<String> dependentValues = dependency.getDependentValues();
final String prefix = (capitalizeThe ? "The" : "the") + " <" + dependency.getPropertyDisplayName() + "> Property "; final String prefix = (capitalizeThe ? "The" : "the") + " <" + dependency.getPropertyDisplayName() + "> Property ";
final String suffix; String suffix = "";
if (dependentValues == null) { if (dependentValues == null) {
suffix = "has a value specified."; suffix = "has a value specified.";
} else if (dependentValues.size() == 1) {
final String requiredValue = dependentValues.iterator().next();
suffix = "has a value of \"" + requiredValue + "\".";
} else { } else {
final StringBuilder sb = new StringBuilder("is set to one of the following values: "); PropertyDescriptor dependencyProperty = null;
for (PropertyDescriptor prop : properties) {
for (final String dependentValue : dependentValues) { if (prop.getName().equals(dependency.getPropertyName())) {
sb.append("\"").append(dependentValue).append("\", "); dependencyProperty = prop;
break;
}
} }
if (null == dependencyProperty) {
throw new XMLStreamException("No property was found matching the name '" + dependency.getPropertyName() + "'");
}
if (dependentValues.size() == 1) {
final String requiredValue = dependentValues.iterator().next();
final List<AllowableValue> allowableValues = dependencyProperty.getAllowableValues();
if (allowableValues != null) {
for (AllowableValue av : allowableValues) {
if (requiredValue.equals(av.getValue())) {
suffix = "has a value of \"" + av.getDisplayName() + "\".";
break;
}
}
}
} else {
final StringBuilder sb = new StringBuilder("is set to one of the following values: ");
// Delete the trailing ", " for (final String dependentValue : dependentValues) {
sb.setLength(sb.length() - 2); for (AllowableValue av : dependencyProperty.getAllowableValues()) {
if (dependentValue.equals(av.getValue())) {
sb.append("\"").append(av.getDisplayName()).append("\", ");
break;
}
}
}
suffix = sb.toString(); // Delete the trailing ", "
sb.setLength(sb.length() - 2);
suffix = sb.toString();
}
} }
final String elementName = dependencies.size() > 1 ? "li" : "strong"; final String elementName = dependencies.size() > 1 ? "li" : "strong";