angular-xml-editor
Version:
XML editor component for Angular
218 lines (217 loc) • 20.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import { XmlCursorPos, XMLCursorPositions } from '../cursor/xmlCursorPos.class';
import { XmlRuleAttribut } from './xmlRuleAttribut.class';
import { Xml2html } from '../xml-html-converter/xml2html.class';
var XmlEditRuleCheckAttributes = /** @class */ (function () {
function XmlEditRuleCheckAttributes(xmlSchema) {
this.xmlSchema = xmlSchema;
}
/**
* @param {?} cursorPosToCheck
* @return {?}
*/
XmlEditRuleCheckAttributes.prototype.AttributesAllowedAtThisCursorPos = /**
* @param {?} cursorPosToCheck
* @return {?}
*/
function (cursorPosToCheck) {
if (!cursorPosToCheck) {
return [];
}
/** @type {?} */
var parentNode = this.getRelevantParentNodeForCursorPos(cursorPosToCheck);
/** @type {?} */
var parentName = Xml2html.getTagNameFromNode(parentNode);
return this.getAttributesForElementName(parentName);
};
/**
* @param {?} cursorPosToCheck
* @return {?}
*/
XmlEditRuleCheckAttributes.prototype.getRelevantParentNodeForCursorPos = /**
* @param {?} cursorPosToCheck
* @return {?}
*/
function (cursorPosToCheck) {
if (cursorPosToCheck) {
/** @type {?} */
var parentNode = cursorPosToCheck.ActualNode;
switch (parentNode.nodeType) {
case Node.COMMENT_NODE:
case Node.TEXT_NODE:
parentNode = parentNode.parentElement;
break;
case Node.ELEMENT_NODE:
switch (cursorPosToCheck.PosAtNode) {
case XMLCursorPositions.CursorInEmptyNode:
case XMLCursorPositions.CursorInsideTextNode:
case XMLCursorPositions.CursorOnCompleteNode:
break;
case XMLCursorPositions.CursorBehindNode:
case XMLCursorPositions.CursorInFrontOfNode:
parentNode = parentNode.parentElement;
break;
default:
throw new Error("unhandled cursorPosToCheck.PosAmNode \"" + cursorPosToCheck.PosAtNode + "\"/" + XmlCursorPos.getXmlCursorPositionDebugName(cursorPosToCheck.PosAtNode) + "\" ");
}
break;
default:
throw new Error("unhandled parentNode.nodeType \"" + parentNode.nodeType + "\"");
}
return parentNode;
}
};
/**
* @param {?} elementName
* @return {?}
*/
XmlEditRuleCheckAttributes.prototype.getAttributesForElementName = /**
* @param {?} elementName
* @return {?}
*/
function (elementName) {
/** @type {?} */
var xsdNode = this.xmlSchema.findXsdNodeForTagName(elementName);
return this.getAttributesForElement(xsdNode, new Set([xsdNode]));
};
/**
* @param {?} xsdNode
* @param {?} alreadyAddedElements
* @return {?}
*/
XmlEditRuleCheckAttributes.prototype.getAttributesForElement = /**
* @param {?} xsdNode
* @param {?} alreadyAddedElements
* @return {?}
*/
function (xsdNode, alreadyAddedElements) {
var _this = this;
/** @type {?} */
var attributes = [];
if (xsdNode) {
alreadyAddedElements.add(xsdNode);
/** @type {?} */
var childNodes = Array.prototype.slice.call(xsdNode.childNodes);
childNodes.forEach(function (child) {
if (xsdNode.nodeType === Node.ELEMENT_NODE) {
/** @type {?} */
var childElem = /** @type {?} */ (child);
if (childElem) {
if (child.localName === 'attribute') {
// is attribute
attributes = attributes.concat([
new XmlRuleAttribut({
attribName: childElem.attributes.getNamedItem('name').value,
required: _this.isRequiredAttribute(childElem),
xsdRawNode: childElem,
fixedValues: _this.getFixedValues(childElem),
defaultValue: _this.getDefaultValue(childElem)
})
]);
}
else {
// no attribute
if (!alreadyAddedElements.has(child)) {
/** @type {?} */
var subNodeAttributes = _this.getAttributesForElement(child, alreadyAddedElements);
attributes = attributes.concat(subNodeAttributes);
}
else {
// Element already added
}
}
}
}
});
}
return attributes;
};
/**
* the default value for this attribute
* @param {?} childElem
* @return {?}
*/
XmlEditRuleCheckAttributes.prototype.getDefaultValue = /**
* the default value for this attribute
* @param {?} childElem
* @return {?}
*/
function (childElem) {
/** @type {?} */
var attrib = childElem.attributes.getNamedItem('default');
if (attrib !== null) {
return attrib.value;
}
return undefined;
};
/**
* is this attribute required?
* @param {?} childElem
* @return {?}
*/
XmlEditRuleCheckAttributes.prototype.isRequiredAttribute = /**
* is this attribute required?
* @param {?} childElem
* @return {?}
*/
function (childElem) {
/** @type {?} */
var attrib = childElem.attributes.getNamedItem('use');
/** @type {?} */
var value = attrib !== null && attrib.value === 'required';
return value;
};
/**
* get the allowes values for this attribute
* @param {?} xsdNode
* @param {?=} alreadyChecked
* @return {?}
*/
XmlEditRuleCheckAttributes.prototype.getFixedValues = /**
* get the allowes values for this attribute
* @param {?} xsdNode
* @param {?=} alreadyChecked
* @return {?}
*/
function (xsdNode, alreadyChecked) {
var _this = this;
if (alreadyChecked === void 0) { alreadyChecked = []; }
/** @type {?} */
var values = [];
/** @type {?} */
var childNodes = Array.prototype.slice.call(xsdNode.childNodes);
childNodes.forEach(function (child) {
if (xsdNode.nodeType === Node.ELEMENT_NODE) {
/** @type {?} */
var childElem = /** @type {?} */ (child);
if (childElem) {
if (child.localName === 'enumeration') {
values = values.concat([childElem.attributes.getNamedItem('value').value]);
}
else {
// no attribute
if (alreadyChecked.indexOf(child) === -1) {
/** @type {?} */
var subNodeAttributes = _this.getFixedValues(child, alreadyChecked);
values = values.concat(subNodeAttributes);
}
else {
// Element already added
}
}
}
}
});
return values;
};
return XmlEditRuleCheckAttributes;
}());
export { XmlEditRuleCheckAttributes };
if (false) {
/** @type {?} */
XmlEditRuleCheckAttributes.prototype.xmlSchema;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xmlEditRuleCheckAttributes.class.js","sourceRoot":"ng://angular-xml-editor/","sources":["lib/code/xml-rules-check/xmlEditRuleCheckAttributes.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { XmlCursorPos, XMLCursorPositions } from '../cursor/xmlCursorPos.class';\r\nimport { XmlRuleAttribut } from './xmlRuleAttribut.class';\r\nimport { XmlSchema } from './xmlSchema.class';\r\nimport { Xml2html } from '../xml-html-converter/xml2html.class';\r\n\r\nexport class XmlEditRuleCheckAttributes {\r\n  constructor(private xmlSchema: XmlSchema) {}\r\n\r\n  AttributesAllowedAtThisCursorPos(cursorPosToCheck: XmlCursorPos): XmlRuleAttribut[] {\r\n    if (!cursorPosToCheck) {\r\n      return [];\r\n    }\r\n    const parentNode = this.getRelevantParentNodeForCursorPos(cursorPosToCheck);\r\n    const parentName = Xml2html.getTagNameFromNode(parentNode);\r\n    return this.getAttributesForElementName(parentName);\r\n  }\r\n\r\n  getRelevantParentNodeForCursorPos(cursorPosToCheck: XmlCursorPos): Node {\r\n    if (cursorPosToCheck) {\r\n      let parentNode = cursorPosToCheck.ActualNode;\r\n\r\n      switch (parentNode.nodeType) {\r\n        case Node.COMMENT_NODE:\r\n        case Node.TEXT_NODE:\r\n          parentNode = parentNode.parentElement;\r\n          break;\r\n\r\n        case Node.ELEMENT_NODE:\r\n          switch (cursorPosToCheck.PosAtNode) {\r\n            case XMLCursorPositions.CursorInEmptyNode:\r\n            case XMLCursorPositions.CursorInsideTextNode:\r\n            case XMLCursorPositions.CursorOnCompleteNode:\r\n              break;\r\n\r\n            case XMLCursorPositions.CursorBehindNode:\r\n            case XMLCursorPositions.CursorInFrontOfNode:\r\n              parentNode = parentNode.parentElement;\r\n              break;\r\n\r\n            default:\r\n              throw new Error(`unhandled cursorPosToCheck.PosAmNode \"${cursorPosToCheck.PosAtNode}\"/${XmlCursorPos.getXmlCursorPositionDebugName(cursorPosToCheck.PosAtNode)}\" `);\r\n          }\r\n          break;\r\n\r\n        default:\r\n          throw new Error(`unhandled parentNode.nodeType \"${parentNode.nodeType}\"`);\r\n      }\r\n      return parentNode;\r\n    }\r\n  }\r\n\r\n  getAttributesForElementName(elementName: string): XmlRuleAttribut[] {\r\n    const xsdNode = this.xmlSchema.findXsdNodeForTagName(elementName);\r\n    return this.getAttributesForElement(xsdNode, new Set([xsdNode]));\r\n  }\r\n\r\n  getAttributesForElement(xsdNode: Node, alreadyAddedElements: Set<Node>): XmlRuleAttribut[] {\r\n    let attributes: XmlRuleAttribut[] = [];\r\n\r\n    if (xsdNode) {\r\n      alreadyAddedElements.add(xsdNode);\r\n\r\n      const childNodes = Array.prototype.slice.call(xsdNode.childNodes);\r\n\r\n      childNodes.forEach(child => {\r\n        if (xsdNode.nodeType === Node.ELEMENT_NODE) {\r\n          const childElem = child as Element;\r\n          if (childElem) {\r\n            if (child.localName === 'attribute') {\r\n              // is attribute\r\n              attributes = attributes.concat([\r\n                new XmlRuleAttribut({\r\n                  attribName: childElem.attributes.getNamedItem('name').value,\r\n                  required: this.isRequiredAttribute(childElem),\r\n                  xsdRawNode: childElem,\r\n                  fixedValues: this.getFixedValues(childElem),\r\n                  defaultValue: this.getDefaultValue(childElem)\r\n                })\r\n              ]);\r\n            } else {\r\n              // no attribute\r\n              if (!alreadyAddedElements.has(child)) {\r\n                const subNodeAttributes = this.getAttributesForElement(child, alreadyAddedElements);\r\n                attributes = attributes.concat(subNodeAttributes);\r\n              } else {\r\n                // Element already added\r\n              }\r\n            }\r\n          }\r\n        }\r\n      });\r\n    }\r\n\r\n    return attributes;\r\n  }\r\n\r\n  /** the default value for this attribute */\r\n  private getDefaultValue(childElem: Element) {\r\n    const attrib = childElem.attributes.getNamedItem('default');\r\n    if (attrib !== null) {\r\n      return attrib.value;\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /** is this attribute required? */\r\n  private isRequiredAttribute(childElem: Element) {\r\n    const attrib = childElem.attributes.getNamedItem('use');\r\n    const value = attrib !== null && attrib.value === 'required';\r\n    return value;\r\n  }\r\n\r\n  /** get the allowes values for this attribute */\r\n  private getFixedValues(xsdNode: Element, alreadyChecked: Node[] = []): string[] {\r\n    let values: string[] = [];\r\n\r\n    const childNodes = Array.prototype.slice.call(xsdNode.childNodes);\r\n    childNodes.forEach(child => {\r\n      if (xsdNode.nodeType === Node.ELEMENT_NODE) {\r\n        const childElem = child as Element;\r\n        if (childElem) {\r\n          if (child.localName === 'enumeration') {\r\n            values = values.concat([childElem.attributes.getNamedItem('value').value]);\r\n          } else {\r\n            // no attribute\r\n            if (alreadyChecked.indexOf(child) === -1) {\r\n              const subNodeAttributes = this.getFixedValues(child, alreadyChecked);\r\n              values = values.concat(subNodeAttributes);\r\n            } else {\r\n              // Element already added\r\n            }\r\n          }\r\n        }\r\n      }\r\n    });\r\n\r\n    return values;\r\n  }\r\n}\r\n"]}