UNPKG

cytoscape-angular

Version:
197 lines 45.9 kB
import { FieldInfo, FieldsetInfo, FormInfo } from '../fluid-form/form-info'; class StyleFieldInfo extends FieldInfo { constructor(styleName, type, hint, options) { super(styleName, styleName, type, hint); this.options = options; } fieldType(model) { switch (this.type) { case 'percent': return 'number'; case 'ShapePolygonPoints': case 'NodeShape': case 'LineStyle': case 'TextTransformation': case 'FontStyle': case 'FontWeight': case 'Colour': return 'string'; default: return super.fieldType(model); } } } export function createStyleCoreFormInfo() { return new FormInfo('Core Styles', [ new FieldsetInfo('Background', [ new StyleFieldInfo('active-bg-color', 'Colour', 'The colour of the indicator shown when the background is grabbed by the user.'), new StyleFieldInfo('active-bg-opacity', 'number', 'The opacity of the active background indicator.'), new StyleFieldInfo('active-bg-size', 'number', 'The size of the active background indicator..') ]), new FieldsetInfo('Selection Box', [ new StyleFieldInfo('selection-box-color', 'Colour', 'The background colour of the selection box used for drag selection.'), new StyleFieldInfo('selection-box-border-color', 'Colour', 'The colour of the border of the selection box used for drag selection.'), new StyleFieldInfo('selection-box-border-width', 'number', 'The size of the border on the selection box.'), new StyleFieldInfo('selection-box-opacity', 'number', 'The opacity of the selection box.'), new StyleFieldInfo('', 'number', '') ]), new FieldsetInfo('Texture During Viewport Gestures', [ new StyleFieldInfo('outside-texture-bg-color', 'Colour', 'The colour of the area outside the viewport texture when initOptions.textureOnViewport === true.'), new StyleFieldInfo('outside-texture-bg-opacity', 'number', 'The opacity of the area outside the viewport texture.'), ]), ], false); } function fieldSorter(field1, field2) { if (!field1) { return field2 ? 1 : 0; } else if (!field2) { return -1; } else { const label1 = typeof field1.label === 'function' ? field1.label() : field1.label; const label2 = typeof field2.label === 'function' ? field2.label() : field2.label; return label1.localeCompare(label2); } } export function createStyleEdgeFieldSets() { const fieldsetInfos = []; return fieldsetInfos; } export function createStyleNodeFieldSets() { const fieldsetInfos = []; let nodeFieldInfos = []; nodeFieldInfos.push(new StyleFieldInfo('label', 'string', 'The text to display for an element’s label.')); nodeFieldInfos.push(new StyleFieldInfo('source-label', 'string', 'The text to display for a node’s source label.')); nodeFieldInfos.push(new StyleFieldInfo('target-label', 'string', 'The text to display for a node’s target label.')); nodeFieldInfos.push(new StyleFieldInfo('color', 'Colour', 'The colour of the element’s label.')); nodeFieldInfos.push(new StyleFieldInfo('font-family', 'string', 'A comma-separated list of font names to use on the label text.')); /** * https://developer.mozilla.org/en-US/docs/Web/CSS/font-family */ nodeFieldInfos.push(new StyleFieldInfo('font-size', 'string', 'The size of the label text.')); /** * https://developer.mozilla.org/en-US/docs/Web/CSS/font-style */ nodeFieldInfos.push(new StyleFieldInfo('font-style', 'FontStyle', 'A CSS font style to be applied to the label text.')); nodeFieldInfos.push(new StyleFieldInfo('font-weight', 'FontWeight', 'A CSS font weight to be applied to the label text.')); nodeFieldInfos.push(new StyleFieldInfo('text-max-width', 'string', 'The maximum width for wrapped text, applied when "text-wrap" is set to wrap. For only manual newlines (i.e.\\n), set a very large value like 1000px such that only your newline characters would apply.')); let textWrapStyleFieldInfo = new StyleFieldInfo('text-wrap', 'options', 'A wrapping style to apply to the label text; may be "none" for no wrapping (including manual newlines ) or "wrap" for manual and/ or autowrapping.'); textWrapStyleFieldInfo.options = [ { label: 'none', value: 'none' }, { label: 'wrap', value: 'wrap' }, { label: 'ellipsis', value: 'ellipsis' } ]; nodeFieldInfos.push(textWrapStyleFieldInfo); /** * Node label alignment: */ nodeFieldInfos.push(new StyleFieldInfo('text-halign', 'options', 'The vertical alignment of a node’s label.', [ { name: '', label: '' }, { label: 'left', value: 'left' }, { label: 'center', value: 'center' }, { labe: 'right', value: 'right' } ])); nodeFieldInfos.push(new StyleFieldInfo('text-valign', 'options', 'The vertical alignment of a node’s label.', [ { name: '', label: '' }, { label: 'top', value: 'top' }, { label: 'center', value: 'center' }, { label: 'bottom', value: 'bottom' } ])); nodeFieldInfos.push(new StyleFieldInfo('text-opacity', 'number', 'The opacity of the label text, including its outline.')); nodeFieldInfos.push(new StyleFieldInfo('text-transform', 'TextTransformation', 'A transformation to apply to the label text.')); fieldsetInfos.push(new FieldsetInfo('Label', nodeFieldInfos)); nodeFieldInfos = []; nodeFieldInfos.push(new StyleFieldInfo('content', 'string', 'The CSS content field')); nodeFieldInfos.push(new StyleFieldInfo('width', 'string', 'The width of the node’s body. This property can take on the special value label so the width is automatically based on the node’s label.')); nodeFieldInfos.push(new StyleFieldInfo('height', 'string', 'The height of the node’s body. This property can take on the special value label so the height is automatically based on the node’s label.')); nodeFieldInfos.push(new StyleFieldInfo('background-color', 'Colour', 'The colour of the node’s body.')); nodeFieldInfos.push(new StyleFieldInfo('background-blacken', 'number', ' Blackens the node’s body for values from 0 to 1; whitens the node’s body for values from 0 to -1.')); nodeFieldInfos.push(new StyleFieldInfo('background-opacity', 'number', 'The opacity level of the node’s background colour.')); nodeFieldInfos.push(new StyleFieldInfo('border-width', 'string', 'The size of the node’s border.')); nodeFieldInfos.push(new StyleFieldInfo('border-style', 'LineStyle', 'The style of the node’s border.')); nodeFieldInfos.push(new StyleFieldInfo('border-color', 'Colour', 'The colour of the node’s border.')); nodeFieldInfos.push(new StyleFieldInfo('border-opacity', 'percent', 'The opacity of the node’s border. A value between [0 1].')); nodeFieldInfos.push(new StyleFieldInfo('shape', 'NodeShape', 'The shape of the node’s body.')); nodeFieldInfos.push(new StyleFieldInfo('shape-polygon-points', 'ShapePolygonPoints', '')); nodeFieldInfos.push(new StyleFieldInfo('overlay-color', 'Colour', 'The colour of the overlay on top of nodes or edges.')); nodeFieldInfos.push(new StyleFieldInfo('overlay-padding', 'string', 'The area outside of the element within which the overlay is shown.')); nodeFieldInfos.push(new StyleFieldInfo('overlay-opacity', 'number', 'The opacity of the overlay.')); nodeFieldInfos.push(new StyleFieldInfo('padding-left', 'string', ' Padding increases node dimensions by adding spacing around the label of nodes whose heights and widths are the value \'label\', or it can be used to add spacing between a compound node parent and its children.')); nodeFieldInfos.push(new StyleFieldInfo('padding-right', 'string', ' Padding increases node dimensions by adding spacing around the label of nodes whose heights and widths are the value \'label\', or it can be used to add spacing between a compound node parent and its children.')); nodeFieldInfos.push(new StyleFieldInfo('padding-top', 'string', ' Padding increases node dimensions by adding spacing around the label of nodes whose heights and widths are the value \'label\', or it can be used to add spacing between a compound node parent and its children.')); nodeFieldInfos.push(new StyleFieldInfo('padding-bottom', 'string', ' Padding increases node dimensions by adding spacing around the label of nodes whose heights and widths are the value \'label\', or it can be used to add spacing between a compound node parent and its children.')); fieldsetInfos.push(new FieldsetInfo('Node', nodeFieldInfos)); nodeFieldInfos = []; /** * Edge label alignment: */ nodeFieldInfos.push(new StyleFieldInfo('source-text-offset', 'number', 'For the source label of an edge, how far from the source node the label should be placed.')); nodeFieldInfos.push(new StyleFieldInfo('target-text-offset', 'number', 'For the target label of an edge, how far from the target node the label should be placed.')); /** * Margins: */ nodeFieldInfos.push(new StyleFieldInfo('text-margin-x', 'number', 'A margin that shifts the label along the x- axis.')); nodeFieldInfos.push(new StyleFieldInfo('text-margin-y', 'number', 'A margin that shifts the label along the y- axis.')); nodeFieldInfos.push(new StyleFieldInfo('source-text-margin-x', 'number', '(For the source label of an edge.)')); nodeFieldInfos.push(new StyleFieldInfo('source-text-margin-y', 'number', '(For the source label of an edge.)')); nodeFieldInfos.push(new StyleFieldInfo('target-text-margin-x', 'number', '(For the target label of an edge.)')); nodeFieldInfos.push(new StyleFieldInfo('target-text-margin-y', 'number', '(For the target label of an edge.)')); /** * Rotating text: */ nodeFieldInfos.push(new StyleFieldInfo('text-rotation', 'number', 'A rotation angle that is applied to the label. For edges, the special value autorotate can be used to align the label to the edge. For nodes, the label is rotated along its anchor point on the node, so a label margin may help for some usecases. The special value none can be used to denote 0deg. Rotations works best with left- to - right text.')); nodeFieldInfos.push(new StyleFieldInfo('source-text-rotation', 'number', '(For the source label of an edge.)')); nodeFieldInfos.push(new StyleFieldInfo('target-text-rotation', 'number', '(For the target label of an edge.)')); /** * Outline: */ nodeFieldInfos.push(new StyleFieldInfo('text-outline-color', 'Colour', 'The colour of the outline around the element’s label text.')); nodeFieldInfos.push(new StyleFieldInfo('text-outline-opacity', 'number', 'The opacity of the outline on label text.')); nodeFieldInfos.push(new StyleFieldInfo('text-outline-width', 'string', 'The size of the outline on label text.')); /** * Shadow: */ nodeFieldInfos.push(new StyleFieldInfo('text-shadow-blur', 'number', 'The shadow blur distance.')); nodeFieldInfos.push(new StyleFieldInfo('text-shadow-color', 'Colour', 'The colour of the shadow.')); nodeFieldInfos.push(new StyleFieldInfo('text-shadow-offset-x', 'number', 'The x offset relative to the text where the shadow will be displayed, can be negative. If you set blur to 0, add an offset to view your shadow.')); nodeFieldInfos.push(new StyleFieldInfo('text-shadow-offset-y', 'number', 'The y offset relative to the text where the shadow will be displayed, can be negative. If you set blur to 0, add an offset to view your shadow.')); nodeFieldInfos.push(new StyleFieldInfo('text-shadow-opacity', 'number', 'The opacity of the shadow on the text; the shadow is disabled for 0 (default value).')); /** * Background: */ nodeFieldInfos.push(new StyleFieldInfo('text-background-padding', 'string', 'The padding provides visual spacing between the text and the edge of the background.')); nodeFieldInfos.push(new StyleFieldInfo('text-background-color', 'Colour', 'A colour to apply on the text background.')); nodeFieldInfos.push(new StyleFieldInfo('text-background-opacity', 'number', 'The opacity of the label background; the background is disabled for 0 (default value).')); nodeFieldInfos.push(new StyleFieldInfo('text-background-shape', 'options', 'The shape to use for the label background.', [ { name: '', label: '' }, { label: 'rectangle', value: 'rectangle' }, { label: 'roundrectangle', value: 'roundrectangle' } ])); nodeFieldInfos.push(new StyleFieldInfo('text-border-opacity', 'number', 'The width of the border around the label; the border is disabled for 0 (default value).')); nodeFieldInfos.push(new StyleFieldInfo('text-border-width', 'number', 'The width of the border around the label.')); nodeFieldInfos.push(new StyleFieldInfo('text-border-style', 'LineStyle', 'The style of the border around the label.')); nodeFieldInfos.push(new StyleFieldInfo('text-border-color', 'Colour', 'The colour of the border around the label.')); fieldsetInfos.push(new FieldsetInfo('Advanced Text', nodeFieldInfos)); nodeFieldInfos = []; /** * Interactivity: */ nodeFieldInfos.push(new StyleFieldInfo('min-zoomed-font-size', 'number', 'If zooming makes the effective font size of the label smaller than this, then no label is shown.Note that because of performance optimisations, the label may be shown at font sizes slightly smaller than this value. This effect is more pronounced at larger screen pixel ratios. However, it is guaranteed that the label will be shown at sizes equal to or greater than the value specified.')); nodeFieldInfos.push(new StyleFieldInfo('text-events', 'options', 'Whether events should occur on an element if the label receives an event. You may want a style applied to the text onactive so you know the text is activatable.', [ { label: 'yes', value: 'yes' }, { label: 'no', value: 'no' } ])); fieldsetInfos.push(new FieldsetInfo('Interactivity', nodeFieldInfos)); return fieldsetInfos; } /** * Defaults to a blank node */ export class StylesheetImpl { constructor(selector = 'node', style = {}) { this.selector = selector; this.style = style; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"style.js","sourceRoot":"","sources":["../../../../../projects/cytoscape-angular/src/lib/style/style.ts"],"names":[],"mappings":"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","sourcesContent":["import { StylesheetStyle } from 'cytoscape'\nimport { FieldInfo, FieldsetInfo, FieldType, FormInfo } from '../fluid-form/form-info'\n\nclass StyleFieldInfo extends FieldInfo {\n  constructor(styleName: string, type: FieldType, hint: string, options?: object[] | string) {\n    super(styleName, styleName, type, hint)\n    this.options = options\n  }\n\n  fieldType(model: object): FieldType {\n    switch (this.type) {\n      case 'percent' :\n        return 'number'\n      case 'ShapePolygonPoints':\n      case 'NodeShape':\n      case 'LineStyle':\n      case 'TextTransformation':\n      case 'FontStyle':\n      case 'FontWeight':\n      case 'Colour':\n        return 'string'\n      default:\n        return super.fieldType(model)\n    }\n  }\n}\n\nexport function createStyleCoreFormInfo() {\n  return new FormInfo('Core Styles',\n    [\n      new FieldsetInfo('Background', [\n        new StyleFieldInfo('active-bg-color', 'Colour',\n          'The colour of the indicator shown when the background is grabbed by the user.'),\n        new StyleFieldInfo('active-bg-opacity', 'number',\n          'The opacity of the active background indicator.'),\n        new StyleFieldInfo('active-bg-size', 'number',\n          'The size of the active background indicator..')\n      ]),\n\n      new FieldsetInfo('Selection Box', [\n        new StyleFieldInfo('selection-box-color', 'Colour',\n          'The background colour of the selection box used for drag selection.'),\n          new StyleFieldInfo('selection-box-border-color', 'Colour',\n            'The colour of the border of the selection box used for drag selection.'),\n          new StyleFieldInfo('selection-box-border-width', 'number',\n            'The size of the border on the selection box.'),\n          new StyleFieldInfo('selection-box-opacity', 'number',\n          'The opacity of the selection box.'),\n        new StyleFieldInfo('', 'number',\n          '')\n      ]),\n      new FieldsetInfo('Texture During Viewport Gestures', [\n        new StyleFieldInfo('outside-texture-bg-color', 'Colour',\n          'The colour of the area outside the viewport texture when initOptions.textureOnViewport === true.'),\n        new StyleFieldInfo('outside-texture-bg-opacity', 'number',\n          'The opacity of the area outside the viewport texture.'),\n      ]),\n    ], false)\n}\n\nfunction fieldSorter(field1: FieldInfo, field2: FieldInfo): number {\n  if (!field1) {\n    return field2 ? 1: 0\n  } else if (!field2) {\n    return -1\n  } else {\n    const label1 = typeof field1.label === 'function' ? field1.label() : field1.label\n    const label2 = typeof field2.label === 'function' ? field2.label() : field2.label\n    return label1.localeCompare(label2);\n  }\n}\n\nexport function createStyleEdgeFieldSets() {\n  const fieldsetInfos: FieldsetInfo[] = []\n  return fieldsetInfos\n}\n\nexport function createStyleNodeFieldSets() {\n  const fieldsetInfos: FieldsetInfo[] = []\n\n  let nodeFieldInfos: FieldInfo[] = []\n  nodeFieldInfos.push(new StyleFieldInfo('label', 'string', 'The text to display for an element’s label.'))\n  nodeFieldInfos.push(new StyleFieldInfo('source-label', 'string', 'The text to display for a node’s source label.'))\n  nodeFieldInfos.push(new StyleFieldInfo('target-label', 'string', 'The text to display for a node’s target label.'))\n  nodeFieldInfos.push(new StyleFieldInfo('color', 'Colour', 'The colour of the element’s label.'))\n  nodeFieldInfos.push(new StyleFieldInfo('font-family', 'string', 'A comma-separated list of font names to use on the label text.'))\n  /**\n   * https://developer.mozilla.org/en-US/docs/Web/CSS/font-family\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('font-size', 'string', 'The size of the label text.'))\n  /**\n   * https://developer.mozilla.org/en-US/docs/Web/CSS/font-style\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('font-style', 'FontStyle', 'A CSS font style to be applied to the label text.'))\n  nodeFieldInfos.push(new StyleFieldInfo('font-weight', 'FontWeight', 'A CSS font weight to be applied to the label text.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-max-width', 'string', 'The maximum width for wrapped text, applied when \"text-wrap\" is set to wrap. For only manual newlines (i.e.\\\\n), set a very large value like 1000px such that only your newline characters would apply.'))\n  let textWrapStyleFieldInfo = new StyleFieldInfo('text-wrap', 'options',\n    'A wrapping style to apply to the label text; may be \"none\" for no wrapping (including manual newlines ) or \"wrap\" for manual and/ or autowrapping.')\n  textWrapStyleFieldInfo.options = [\n    {label: 'none', value: 'none'},\n    {label: 'wrap', value: 'wrap'},\n    {label: 'ellipsis', value: 'ellipsis'}\n    ]\n  nodeFieldInfos.push(textWrapStyleFieldInfo)\n  /**\n   * Node label alignment:\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('text-halign', 'options',\n    'The vertical alignment of a node’s label.', [\n      {name: '', label: ''},\n      {label: 'left', value: 'left'},\n      {label: 'center', value: 'center'},\n      {labe: 'right', value: 'right'}]))\n  nodeFieldInfos.push(new StyleFieldInfo('text-valign', 'options',\n    'The vertical alignment of a node’s label.', [\n      {name: '', label: ''},\n      {label: 'top', value: 'top'},\n      {label: 'center', value: 'center'},\n      {label: 'bottom', value: 'bottom'}]))\n  nodeFieldInfos.push(new StyleFieldInfo('text-opacity', 'number', 'The opacity of the label text, including its outline.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-transform', 'TextTransformation', 'A transformation to apply to the label text.'))\n  fieldsetInfos.push(new FieldsetInfo('Label', nodeFieldInfos))\n  nodeFieldInfos = []\n\n  nodeFieldInfos.push(new StyleFieldInfo('content', 'string', 'The CSS content field'))\n  nodeFieldInfos.push(new StyleFieldInfo('width', 'string', 'The width of the node’s body. This property can take on the special value label so the width is automatically based on the node’s label.'))\n  nodeFieldInfos.push(new StyleFieldInfo('height', 'string', 'The height of the node’s body. This property can take on the special value label so the height is automatically based on the node’s label.'))\n  nodeFieldInfos.push(new StyleFieldInfo('background-color', 'Colour', 'The colour of the node’s body.'))\n  nodeFieldInfos.push(new StyleFieldInfo('background-blacken', 'number', '   Blackens the node’s body for values from 0 to 1; whitens the node’s body for values from 0 to -1.'))\n  nodeFieldInfos.push(new StyleFieldInfo('background-opacity', 'number', 'The opacity level of the node’s background colour.'))\n  nodeFieldInfos.push(new StyleFieldInfo('border-width', 'string', 'The size of the node’s border.'))\n  nodeFieldInfos.push(new StyleFieldInfo('border-style', 'LineStyle', 'The style of the node’s border.'))\n  nodeFieldInfos.push(new StyleFieldInfo('border-color', 'Colour', 'The colour of the node’s border.'))\n  nodeFieldInfos.push(new StyleFieldInfo('border-opacity', 'percent', 'The opacity of the node’s border. A value between [0 1].'))\n  nodeFieldInfos.push(new StyleFieldInfo('shape', 'NodeShape', 'The shape of the node’s body.'))\n  nodeFieldInfos.push(new StyleFieldInfo('shape-polygon-points', 'ShapePolygonPoints', ''))\n  nodeFieldInfos.push(new StyleFieldInfo('overlay-color', 'Colour', 'The colour of the overlay on top of nodes or edges.'))\n  nodeFieldInfos.push(new StyleFieldInfo('overlay-padding', 'string', 'The area outside of the element within which the overlay is shown.'))\n  nodeFieldInfos.push(new StyleFieldInfo('overlay-opacity', 'number', 'The opacity of the overlay.'))\n  nodeFieldInfos.push(new StyleFieldInfo('padding-left', 'string', '   Padding increases node dimensions by adding spacing around the label of nodes whose heights and widths are the value \\'label\\', or it can be used to add spacing between a compound node parent and its children.'))\n  nodeFieldInfos.push(new StyleFieldInfo('padding-right', 'string', '   Padding increases node dimensions by adding spacing around the label of nodes whose heights and widths are the value \\'label\\', or it can be used to add spacing between a compound node parent and its children.'))\n  nodeFieldInfos.push(new StyleFieldInfo('padding-top', 'string', '   Padding increases node dimensions by adding spacing around the label of nodes whose heights and widths are the value \\'label\\', or it can be used to add spacing between a compound node parent and its children.'))\n  nodeFieldInfos.push(new StyleFieldInfo('padding-bottom', 'string', '   Padding increases node dimensions by adding spacing around the label of nodes whose heights and widths are the value \\'label\\', or it can be used to add spacing between a compound node parent and its children.'))\n  fieldsetInfos.push(new FieldsetInfo('Node', nodeFieldInfos))\n  nodeFieldInfos = []\n\n  /**\n   * Edge label alignment:\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('source-text-offset', 'number', 'For the source label of an edge, how far from the source node the label should be placed.'))\n  nodeFieldInfos.push(new StyleFieldInfo('target-text-offset', 'number', 'For the target label of an edge, how far from the target node the label should be placed.'))\n  /**\n   * Margins:\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('text-margin-x', 'number', 'A margin that shifts the label along the x- axis.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-margin-y', 'number', 'A margin that shifts the label along the y- axis.'))\n  nodeFieldInfos.push(new StyleFieldInfo('source-text-margin-x', 'number', '(For the source label of an edge.)'))\n  nodeFieldInfos.push(new StyleFieldInfo('source-text-margin-y', 'number', '(For the source label of an edge.)'))\n  nodeFieldInfos.push(new StyleFieldInfo('target-text-margin-x', 'number', '(For the target label of an edge.)'))\n  nodeFieldInfos.push(new StyleFieldInfo('target-text-margin-y', 'number', '(For the target label of an edge.)'))\n  /**\n   * Rotating text:\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('text-rotation', 'number', 'A rotation angle that is applied to the label. For edges, the special value autorotate can be used to align the label to the edge. For nodes, the label is rotated along its anchor point on the node, so a label margin may help for some usecases. The special value none can be used to denote 0deg. Rotations works best with left- to - right text.'))\n  nodeFieldInfos.push(new StyleFieldInfo('source-text-rotation', 'number', '(For the source label of an edge.)'))\n  nodeFieldInfos.push(new StyleFieldInfo('target-text-rotation', 'number', '(For the target label of an edge.)'))\n  /**\n   * Outline:\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('text-outline-color', 'Colour', 'The colour of the outline around the element’s label text.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-outline-opacity', 'number', 'The opacity of the outline on label text.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-outline-width', 'string', 'The size of the outline on label text.'))\n  /**\n   * Shadow:\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('text-shadow-blur', 'number', 'The shadow blur distance.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-shadow-color', 'Colour', 'The colour of the shadow.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-shadow-offset-x', 'number', 'The x offset relative to the text where the shadow will be displayed, can be negative.  If you set blur to 0, add an offset to view your shadow.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-shadow-offset-y', 'number', 'The y offset relative to the text where the shadow will be displayed, can be negative.  If you set blur to 0, add an offset to view your shadow.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-shadow-opacity', 'number', 'The opacity of the shadow on the text; the shadow is disabled for 0 (default value).'))\n  /**\n   * Background:\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('text-background-padding', 'string', 'The padding provides visual spacing between the text and the edge of the background.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-background-color', 'Colour', 'A colour to apply on the text background.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-background-opacity', 'number', 'The opacity of the label background; the background is disabled for 0 (default value).'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-background-shape', 'options',\n    'The shape to use for the label background.', [\n      {name: '', label: ''},\n      {label: 'rectangle', value: 'rectangle'},\n      {label: 'roundrectangle', value: 'roundrectangle'}\n    ]))\n  nodeFieldInfos.push(new StyleFieldInfo('text-border-opacity', 'number', 'The width of the border around the label; the border is disabled for 0 (default value).'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-border-width', 'number', 'The width of the border around the label.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-border-style', 'LineStyle', 'The style of the border around the label.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-border-color', 'Colour', 'The colour of the border around the label.'))\n  fieldsetInfos.push(new FieldsetInfo('Advanced Text', nodeFieldInfos))\n  nodeFieldInfos = []\n\n  /**\n   * Interactivity:\n   */\n  nodeFieldInfos.push(new StyleFieldInfo('min-zoomed-font-size', 'number', 'If zooming makes the effective font size of the label smaller than this, then no label is shown.Note that because of performance optimisations, the label may be shown at font sizes slightly smaller than this value. This effect is more pronounced at larger screen pixel ratios. However, it is guaranteed that the label will be shown at sizes equal to or greater than the value specified.'))\n  nodeFieldInfos.push(new StyleFieldInfo('text-events', 'options',\n    'Whether events should occur on an element if the label receives an event. You may want a style applied to the text onactive so you know the text is activatable.', [\n      {label: 'yes', value: 'yes'},\n      {label: 'no', value: 'no'}\n    ]))\n  fieldsetInfos.push(new FieldsetInfo('Interactivity', nodeFieldInfos))\n  return fieldsetInfos\n}\n\n/**\n * Defaults to a blank node\n */\nexport class StylesheetImpl implements StylesheetStyle {\n  constructor(\n    public selector: string = 'node',\n    public style: cytoscape.Css.Node | cytoscape.Css.Edge | cytoscape.Css.Core = {}\n  ) {\n  }\n}\n"]}