UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

123 lines 14.3 kB
/** * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ export function nzTypeDefinition() { return item => item; } export const NZ_GRAPH_LAYOUT_SETTING = { animation: { /** Default duration for graph animations in ms. */ duration: 250 }, graph: { /** Graph parameter for metanode. */ meta: { /** * Dagre's nodesep param - number of pixels that * separate nodes horizontally in the layout. * * See https://github.com/cpettitt/dagre/wiki#configuring-the-layout */ nodeSep: 50, /** * Dagre's ranksep param - number of pixels * between each rank in the layout. * * See https://github.com/cpettitt/dagre/wiki#configuring-the-layout */ rankSep: 40, /** * Dagre's edgesep param - number of pixels that separate * edges horizontally in the layout. */ edgeSep: 5 }, /** * Padding is used to correctly position the graph SVG inside of its parent * element. The padding amounts are applied using an SVG transform of X and * Y coordinates. */ padding: { paddingTop: 10, paddingLeft: 0 } }, subscene: { meta: { paddingTop: 20, paddingBottom: 20, paddingLeft: 20, paddingRight: 20, /** * Used to leave room for the label on top of the highest node in * the groupCore graph. */ labelHeight: 20, /** X-space between each extracted node and the groupCore graph. */ extractXOffset: 0, /** Y-space between each extracted node. */ extractYOffset: 0 } }, nodeSize: { /** Size of meta nodes. */ meta: { radius: 2, width: 160, maxLabelWidth: 0, /** A scale for the node's height based on number of nodes inside */ // Hack - set this as an any type to avoid issues in exporting a type // from an external module. height: 100, /** The radius of the circle denoting the expand button. */ expandButtonRadius: 3 }, /** Size of op nodes. */ op: { width: 160, height: 100, radius: 1, labelOffset: 10, maxLabelWidth: 40 }, /** Size of bridge nodes. */ bridge: { // NOTE: bridge nodes will normally be invisible, but they must // take up some space so that the layout step leaves room for // their edges. width: 10, height: 10, radius: 2, labelOffset: 0 } }, shortcutSize: { /** Size of shortcuts for op nodes */ op: { width: 10, height: 4 }, /** Size of shortcuts for meta nodes */ meta: { width: 12, height: 4, radius: 1 }, /** Size of shortcuts for series nodes */ series: { width: 14, height: 4 } }, annotations: { /** Maximum possible width of the bounding box for in annotations */ inboxWidth: 50, /** Maximum possible width of the bounding box for out annotations */ outboxWidth: 50, /** X-space between the shape and each annotation-node. */ xOffset: 10, /** Y-space between each annotation-node. */ yOffset: 3, /** X-space between each annotation-node and its label. */ labelOffset: 2, /** Defines the max width for annotation label */ maxLabelWidth: 120 }, constant: { size: { width: 4, height: 4 } }, minimap: { /** The maximum width/height the minimap can have. */ size: 150 } }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interface.js","sourceRoot":"/home/vsts/work/1/s/components/graph/","sources":["interface.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAuDH,MAAM,UAAU,gBAAgB;IAC9B,OAAO,IAAI,CAAC,EAAE,CAAC,IAAS,CAAC;AAC3B,CAAC;AAYD,MAAM,CAAC,MAAM,uBAAuB,GAAoB;IACtD,SAAS,EAAE;QACT,mDAAmD;QACnD,QAAQ,EAAE,GAAG;KACd;IACD,KAAK,EAAE;QACL,oCAAoC;QACpC,IAAI,EAAE;YACJ;;;;;eAKG;YACH,OAAO,EAAE,EAAE;YACX;;;;;eAKG;YACH,OAAO,EAAE,EAAE;YACX;;;eAGG;YACH,OAAO,EAAE,CAAC;SACX;QACD;;;;WAIG;QACH,OAAO,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,WAAW,EAAE,CAAC,EAAE;KAC5C;IACD,QAAQ,EAAE;QACR,IAAI,EAAE;YACJ,UAAU,EAAE,EAAE;YACd,aAAa,EAAE,EAAE;YACjB,WAAW,EAAE,EAAE;YACf,YAAY,EAAE,EAAE;YAChB;;;eAGG;YACH,WAAW,EAAE,EAAE;YACf,mEAAmE;YACnE,cAAc,EAAE,CAAC;YACjB,2CAA2C;YAC3C,cAAc,EAAE,CAAC;SAClB;KACF;IACD,QAAQ,EAAE;QACR,0BAA0B;QAC1B,IAAI,EAAE;YACJ,MAAM,EAAE,CAAC;YACT,KAAK,EAAE,GAAG;YACV,aAAa,EAAE,CAAC;YAChB,oEAAoE;YACpE,qEAAqE;YACrE,2BAA2B;YAC3B,MAAM,EAAE,GAAG;YACX,2DAA2D;YAC3D,kBAAkB,EAAE,CAAC;SACtB;QACD,wBAAwB;QACxB,EAAE,EAAE;YACF,KAAK,EAAE,GAAG;YACV,MAAM,EAAE,GAAG;YACX,MAAM,EAAE,CAAC;YACT,WAAW,EAAE,EAAE;YACf,aAAa,EAAE,EAAE;SAClB;QACD,4BAA4B;QAC5B,MAAM,EAAE;YACN,+DAA+D;YAC/D,6DAA6D;YAC7D,eAAe;YACf,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,CAAC;YACT,WAAW,EAAE,CAAC;SACf;KACF;IACD,YAAY,EAAE;QACZ,qCAAqC;QACrC,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE;QAC5B,uCAAuC;QACvC,IAAI,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE;QACzC,yCAAyC;QACzC,MAAM,EAAE;YACN,KAAK,EAAE,EAAE;YACT,MAAM,EAAE,CAAC;SACV;KACF;IACD,WAAW,EAAE;QACX,oEAAoE;QACpE,UAAU,EAAE,EAAE;QACd,qEAAqE;QACrE,WAAW,EAAE,EAAE;QACf,0DAA0D;QAC1D,OAAO,EAAE,EAAE;QACX,4CAA4C;QAC5C,OAAO,EAAE,CAAC;QACV,0DAA0D;QAC1D,WAAW,EAAE,CAAC;QACd,iDAAiD;QACjD,aAAa,EAAE,GAAG;KACnB;IACD,QAAQ,EAAE,EAAE,IAAI,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;IAC3C,OAAO,EAAE;QACP,qDAAqD;QACrD,IAAI,EAAE,GAAG;KACV;CACF,CAAC","sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport {\n  HierarchyBaseEdgeInfo,\n  HierarchyBaseNodeInfo,\n  HierarchyGraphDef,\n  HierarchyGraphEdgeDef,\n  HierarchyGraphNodeDef,\n  HierarchyGraphNodeInfo,\n  HierarchyGraphOption\n} from '@nx-component/hierarchy-graph';\nimport { LayoutSetting } from '@nx-component/hierarchy-graph/dist/types';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nexport interface NzGraphDataDef extends HierarchyGraphDef {\n  nodes: NzGraphNodeDef[];\n  edges: NzGraphEdgeDef[];\n}\n\nexport interface NzGraphNodeDef extends HierarchyGraphNodeDef {\n  label?: string;\n}\n\nexport interface NzGraphEdgeDef extends HierarchyGraphEdgeDef {\n  label?: string;\n}\n\n// tslint:disable-next-line:no-empty-interface\nexport interface NzGraphOption extends HierarchyGraphOption {}\nexport declare type NzRankDirection = 'TB' | 'BT' | 'LR' | 'RL';\n\nexport interface NzGraphGroupNode extends HierarchyGraphNodeInfo {\n  nodes: Array<NzGraphNode | NzGraphGroupNode>;\n  edges: NzGraphEdge[];\n  [key: string]: NzSafeAny;\n}\n\nexport interface NzGraphNode extends HierarchyBaseNodeInfo {\n  id: NzSafeAny;\n  // TODO\n  name: NzSafeAny;\n  label?: string;\n  [key: string]: NzSafeAny;\n}\n\nexport interface NzGraphEdge extends HierarchyBaseEdgeInfo {\n  id: NzSafeAny;\n  v: NzSafeAny;\n  w: NzSafeAny;\n  label?: string;\n}\n\n// tslint:disable-next-line:no-empty-interface\nexport interface NzLayoutSetting extends LayoutSetting {}\n\nexport function nzTypeDefinition<T>(): (item: unknown) => T {\n  return item => item as T;\n}\n\n// tslint:disable:no-shadowed-variable\nexport type NzDeepPartial<T> = {\n  [P in keyof T]?: T[P] extends Array<infer U>\n    ? Array<NzDeepPartial<U>>\n    : T[P] extends ReadonlyArray<infer U>\n    ? ReadonlyArray<NzDeepPartial<U>>\n    : NzDeepPartial<T[P]>;\n};\n\nexport type NzGraphLayoutSetting = NzDeepPartial<NzLayoutSetting>;\nexport const NZ_GRAPH_LAYOUT_SETTING: NzLayoutSetting = {\n  animation: {\n    /** Default duration for graph animations in ms. */\n    duration: 250\n  },\n  graph: {\n    /** Graph parameter for metanode. */\n    meta: {\n      /**\n       * Dagre's nodesep param - number of pixels that\n       * separate nodes horizontally in the layout.\n       *\n       * See https://github.com/cpettitt/dagre/wiki#configuring-the-layout\n       */\n      nodeSep: 50,\n      /**\n       * Dagre's ranksep param - number of pixels\n       * between each rank in the layout.\n       *\n       * See https://github.com/cpettitt/dagre/wiki#configuring-the-layout\n       */\n      rankSep: 40,\n      /**\n       * Dagre's edgesep param - number of pixels that separate\n       * edges horizontally in the layout.\n       */\n      edgeSep: 5\n    },\n    /**\n     * Padding is used to correctly position the graph SVG inside of its parent\n     * element. The padding amounts are applied using an SVG transform of X and\n     * Y coordinates.\n     */\n    padding: { paddingTop: 10, paddingLeft: 0 }\n  },\n  subscene: {\n    meta: {\n      paddingTop: 20,\n      paddingBottom: 20,\n      paddingLeft: 20,\n      paddingRight: 20,\n      /**\n       * Used to leave room for the label on top of the highest node in\n       * the groupCore graph.\n       */\n      labelHeight: 20,\n      /** X-space between each extracted node and the groupCore graph. */\n      extractXOffset: 0,\n      /** Y-space between each extracted node. */\n      extractYOffset: 0\n    }\n  },\n  nodeSize: {\n    /** Size of meta nodes. */\n    meta: {\n      radius: 2,\n      width: 160,\n      maxLabelWidth: 0,\n      /** A scale for the node's height based on number of nodes inside */\n      // Hack - set this as an any type to avoid issues in exporting a type\n      // from an external module.\n      height: 100,\n      /** The radius of the circle denoting the expand button. */\n      expandButtonRadius: 3\n    },\n    /** Size of op nodes. */\n    op: {\n      width: 160,\n      height: 100,\n      radius: 1, // for making annotation touching ellipse\n      labelOffset: 10,\n      maxLabelWidth: 40\n    },\n    /** Size of bridge nodes. */\n    bridge: {\n      // NOTE: bridge nodes will normally be invisible, but they must\n      // take up some space so that the layout step leaves room for\n      // their edges.\n      width: 10,\n      height: 10,\n      radius: 2,\n      labelOffset: 0\n    }\n  },\n  shortcutSize: {\n    /** Size of shortcuts for op nodes */\n    op: { width: 10, height: 4 },\n    /** Size of shortcuts for meta nodes */\n    meta: { width: 12, height: 4, radius: 1 },\n    /** Size of shortcuts for series nodes */\n    series: {\n      width: 14,\n      height: 4\n    }\n  },\n  annotations: {\n    /** Maximum possible width of the bounding box for in annotations */\n    inboxWidth: 50,\n    /** Maximum possible width of the bounding box for out annotations */\n    outboxWidth: 50,\n    /** X-space between the shape and each annotation-node. */\n    xOffset: 10,\n    /** Y-space between each annotation-node. */\n    yOffset: 3,\n    /** X-space between each annotation-node and its label. */\n    labelOffset: 2,\n    /** Defines the max width for annotation label */\n    maxLabelWidth: 120\n  },\n  constant: { size: { width: 4, height: 4 } },\n  minimap: {\n    /** The maximum width/height the minimap can have. */\n    size: 150\n  }\n};\n\n// Zoom interface\n\nexport interface NzZoomTransform {\n  x: number;\n  y: number;\n  k: number;\n}\n\nexport interface RelativePositionInfo {\n  topLeft: { x: number; y: number };\n  bottomRight: { x: number; y: number };\n}\n"]}