ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
123 lines • 14.3 kB
JavaScript
/**
* 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"]}