UNPKG

cytoscape-angular

Version:
182 lines 24.1 kB
class BaseLayoutOptionsImpl { ready(e) { // tslint:disable-next-line:no-console console.debug(`layout ready, cytoscape.LayoutEventObject: ${JSON.stringify(e)}`); // on layoutready } stop(e) { // tslint:disable-next-line:no-console console.debug(`layout stop, cytoscape.LayoutEventObject: ${JSON.stringify(e)}`); // on layoutstop } } export class NullLayoutOptionsImpl extends BaseLayoutOptionsImpl { constructor() { super(...arguments); this.name = 'null'; } } export class AnimateLayoutOptionsImpl extends BaseLayoutOptionsImpl { constructor() { super(...arguments); // the zoom level to set (prob want fit = false if set) this.zoom = null; // the pan level to set (prob want fit = false if set) this.pan = null; // whether to transition the node positions this.animate = false; // duration of animation in ms if enabled this.animationDuration = 500; // easing of animation if enabled this.animationEasing = undefined; // a function that determines whether the node should be animated. // All nodes animated by default on animate enabled. Non-animated nodes are // positioned immediately when the layout starts this.animateFilter = (node, i) => true; } } export class PresetLayoutOptionsImpl extends AnimateLayoutOptionsImpl { constructor() { super(...arguments); this.name = 'preset'; // transform a given node position. Useful for changing flow direction in discrete layouts this.transform = (node, position) => position; } } export class ShapedLayoutOptionsImpl extends AnimateLayoutOptionsImpl { constructor() { super(...arguments); // whether to fit to viewport this.fit = true; // fit padding this.padding = 30; // constrain layout bounds this.boundingBox = null; // prevents node overlap, may overflow boundingBox if not enough space this.avoidOverlap = true; // Excludes the label when calculating node bounding boxes for the layout algorithm this.nodeDimensionsIncludeLabels = false; // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up this.spacingFactor = 1.75; // a sorting function to order the nodes; e.g. function(a, b){ return a.data('weight') - b.data('weight') } this.sort = null; // transform a given node position. Useful for changing flow direction in discrete layouts this.transform = (node, position) => position; } } export class GridLayoutOptionsImpl extends ShapedLayoutOptionsImpl { constructor() { super(...arguments); this.name = 'grid'; // extra spacing around nodes when avoidOverlap: true this.avoidOverlapPadding = 10; // uses all available space on false, uses minimal space on true this.condense = false; // force num of rows in the grid this.rows = null; // force num of columns in the grid this.cols = null; // returns { row, col } for element // (node: NodeSingular) => return { row: number; col: number; } this.position = null; } } export class RandomLayoutOptionsImpl extends AnimateLayoutOptionsImpl { constructor() { super(...arguments); this.name = 'random'; this.fit = true; this.padding = 20; // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h } this.boundingBox = null; // transform a given node position. Useful for changing flow direction in discrete layouts this.transform = (node, position) => position; } } export class CircleLayoutOptionsImpl extends ShapedLayoutOptionsImpl { constructor() { super(...arguments); this.name = 'circle'; this.startAngle = 3 / 2 * Math.PI; // where nodes start in radians this.sweep = null; // how many radians should be between the first and last node (defaults to full circle) } } // Note: "radius" is not part of concentric, imperfect extension export class ConcentricLayoutOptionsImpl { constructor() { this.name = 'concentric'; // where nodes start in radians, e.g. 3 / 2 * Math.PI, this.startAngle = 3 / 2 * Math.PI; // height of layout area (overrides container height) this.height = null; // width of layout area (overrides container width) this.width = null; } concentric(node) { return 0; } levelWidth(node) { return 0; } } export class BreadthFirstLayoutOptionsImpl extends ShapedLayoutOptionsImpl { constructor() { super(...arguments); this.name = 'breadthfirst'; // whether the tree is directed downwards (or edges can point in any direction if false) this.directed = false; // put depths in concentric circles if true, put depths top down if false this.circle = false; // whether to shift nodes down their natural BFS depths in order to avoid upwards edges (DAGS only) this.maximal = false; this.grid = false; // whether to create an even grid into which the DAG is placed (circle:false only) } } export class CoseLayoutOptionsImpl extends ShapedLayoutOptionsImpl { constructor() { super(...arguments); this.name = 'cose'; // Number of iterations between consecutive screen positions update this.refresh = 20; // Randomize the initial positions of the nodes (true) or use existing positions (false) this.randomize = false; // Extra spacing between components in non-compound graphs this.componentSpacing = 40; // Node repulsion (overlapping) multiplier this.nodeOverlap = 4; // Nesting factor (multiplier) to compute ideal edge length for nested edges this.nestingFactor = 1.2; // Gravity force (constant) this.gravity = 1; // Maximum number of iterations to perform this.numIter = 1000; // Initial temperature (maximum node displacement) this.initialTemp = 1000; // Cooling factor (how the temperature is reduced between consecutive iterations this.coolingFactor = 0.99; // Lower temperature threshold (below this point the layout will end) this.minTemp = 1.0; // Node repulsion (non overlapping) multiplier this.nodeRepulsion = (node) => 2048; // Ideal edge (non nested) length this.idealEdgeLength = (edge) => 32; // Divisor to compute edge forces this.edgeElasticity = (edge) => 32; } } export class DagreLayoutOptionsImpl extends ShapedLayoutOptionsImpl { constructor() { super(); this.name = 'dagre'; this.nodeSep = null; // the separation between adjacent nodes in the same rank this.edgeSep = null; // the separation between adjacent edges in the same rank this.rankSep = null; // the separation between each rank in the layout // TB for top to bottom flow, 'LR' for left to right this.rankDir = 'TB'; // Type of algorithm to assign a rank to each node in the input graph. // Possible values: 'network-simplex', 'tight-tree' or 'longest-path' this.ranker = null; // number of ranks to keep between the source and target of the edge this.minLen = (edge) => 1; this.edgeWeight = (edge) => 1; // higher weight edges are generally made shorter and straighter than lower weight edges } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout-options-impl.js","sourceRoot":"","sources":["../../../../../projects/cytoscape-angular/src/lib/layout/layout-options-impl.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AnimatedLayoutOptions,\n  BoundingBox12,\n  BoundingBoxWH,\n  SortingFunction\n} from 'cytoscape'\n\nclass BaseLayoutOptionsImpl {\n\n  ready(e: cytoscape.LayoutEventObject): void {\n    // tslint:disable-next-line:no-console\n    console.debug(`layout ready, cytoscape.LayoutEventObject: ${JSON.stringify(e)}`) // on layoutready\n  }\n\n  stop(e: cytoscape.LayoutEventObject): void {\n    // tslint:disable-next-line:no-console\n    console.debug(`layout stop, cytoscape.LayoutEventObject: ${JSON.stringify(e)}`) // on layoutstop\n  }\n}\n\nexport class NullLayoutOptionsImpl extends BaseLayoutOptionsImpl {\n  name = 'null'\n}\n\nexport class AnimateLayoutOptionsImpl  extends BaseLayoutOptionsImpl implements AnimatedLayoutOptions  {\n\n  // the zoom level to set (prob want fit = false if set)\n  zoom: number =  null\n  // the pan level to set (prob want fit = false if set)\n  pan: number =  null\n  // whether to transition the node positions\n  animate = false\n  // duration of animation in ms if enabled\n  animationDuration = 500\n  // easing of animation if enabled\n  animationEasing = undefined\n  // a function that determines whether the node should be animated.\n  // All nodes animated by default on animate enabled.  Non-animated nodes are\n  // positioned immediately when the layout starts\n  animateFilter = ( node, i ) => true\n}\n\nexport class PresetLayoutOptionsImpl  extends AnimateLayoutOptionsImpl {\n  name = 'preset'\n\n  fit?: boolean\n  padding?: number\n\n  // map of (node id) => (position obj); or function(node){ return somPos; }\n  positions: null\n  // transform a given node position. Useful for changing flow direction in discrete layouts\n  transform = (node, position ) => position\n}\n\nexport class ShapedLayoutOptionsImpl extends AnimateLayoutOptionsImpl {\n\n  // whether to fit to viewport\n  fit = true\n  // fit padding\n  padding = 30\n  // constrain layout bounds\n  boundingBox?: BoundingBox12 | BoundingBoxWH | undefined = null\n\n  // prevents node overlap, may overflow boundingBox if not enough space\n  avoidOverlap = true\n\n  // Excludes the label when calculating node bounding boxes for the layout algorithm\n  nodeDimensionsIncludeLabels = false\n  // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up\n  spacingFactor = 1.75\n\n  // a sorting function to order the nodes; e.g. function(a, b){ return a.data('weight') - b.data('weight') }\n  sort?: SortingFunction = null\n  // transform a given node position. Useful for changing flow direction in discrete layouts\n  transform = (node, position ) => position\n}\n\n\nexport class GridLayoutOptionsImpl  extends ShapedLayoutOptionsImpl {\n  name = 'grid'\n\n  // extra spacing around nodes when avoidOverlap: true\n  avoidOverlapPadding = 10\n  // uses all available space on false, uses minimal space on true\n  condense = false\n  // force num of rows in the grid\n  rows?: number | undefined = null\n  // force num of columns in the grid\n  cols?: number | undefined = null\n  // returns { row, col } for element\n  // (node: NodeSingular) => return { row: number; col: number; }\n  position = null\n}\n\nexport class RandomLayoutOptionsImpl extends AnimateLayoutOptionsImpl {\n  name = 'random'\n\n  fit = true\n  padding = 20\n  // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h }\n  boundingBox: cytoscape.BoundingBox12 | cytoscape.BoundingBoxWH | undefined = null\n  // transform a given node position. Useful for changing flow direction in discrete layouts\n  transform = (node, position ) => position\n}\n\nexport class CircleLayoutOptionsImpl extends ShapedLayoutOptionsImpl {\n  name =  'circle'\n\n  radius: number // the radius of the circle\n  startAngle: number = 3 / 2 * Math.PI // where nodes start in radians\n  sweep: number = null // how many radians should be between the first and last node (defaults to full circle)\n  clockwise: true // whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false)\n}\n\n// Note: \"radius\" is not part of concentric, imperfect extension\nexport class ConcentricLayoutOptionsImpl {\n  name = 'concentric'\n  // how many radians should be between the first and last node (defaults to full circle)\n  sweep?: number\n  // whether the layout should go clockwise (true) or counterclockwise/anticlockwise (false)\n  clockwise?: boolean\n  // where nodes start in radians, e.g. 3 / 2 * Math.PI,\n  startAngle: number = 3 / 2 * Math.PI\n  fit: boolean\n  nodeDimensionsIncludeLabels: true\n  equidistant: false // whether levels have an equal radial distance betwen them, may cause bounding box overflow\n  minNodeSpacing: 10 // min spacing between outside of nodes (used for radius adjustment)\n  boundingBox: null // constrain layout bounds; { x1, y1, x2, y2 } or { x1, y1, w, h }\n  // height of layout area (overrides container height)\n  height = null\n  // width of layout area (overrides container width)\n  width = null\n  // Applies a multiplicative factor (>0) to expand or compress the overall area that the nodes take up\n  spacingFactor: null\n\n  concentric(node: { degree(): number }): number {\n    return 0\n  }\n\n  levelWidth(node: { maxDegree(): number }): number {\n    return 0\n  }\n}\n\nexport class BreadthFirstLayoutOptionsImpl extends ShapedLayoutOptionsImpl {\n  name = 'breadthfirst'\n\n  // whether the tree is directed downwards (or edges can point in any direction if false)\n  directed = false\n  // put depths in concentric circles if true, put depths top down if false\n  circle = false\n  // the roots of the trees\n  roots?: string\n  // how many times to try to position the nodes in a maximal way (i.e. no backtracking)\n  maximalAdjustments: number\n  // whether to shift nodes down their natural BFS depths in order to avoid upwards edges (DAGS only)\n  maximal = false\n  grid = false // whether to create an even grid into which the DAG is placed (circle:false only)\n  nodeDimensionsIncludeLabels: false // Excludes the label when calculating node bounding boxes for the layout algorithm\n}\n\nexport class CoseLayoutOptionsImpl extends ShapedLayoutOptionsImpl {\n  name = 'cose'\n\n  // The layout animates only after this many milliseconds for animate:true\n  // (prevents flashing on fast runs)\n  animationThreshold: 250\n\n  // Number of iterations between consecutive screen positions update\n  refresh = 20\n\n  // Randomize the initial positions of the nodes (true) or use existing positions (false)\n  randomize = false\n\n  // Extra spacing between components in non-compound graphs\n  componentSpacing = 40\n\n  // Node repulsion (overlapping) multiplier\n  nodeOverlap = 4\n\n  // Nesting factor (multiplier) to compute ideal edge length for nested edges\n  nestingFactor = 1.2\n\n  // Gravity force (constant)\n  gravity = 1\n\n  // Maximum number of iterations to perform\n  numIter = 1000\n\n  // Initial temperature (maximum node displacement)\n  initialTemp = 1000\n\n  // Cooling factor (how the temperature is reduced between consecutive iterations\n  coolingFactor = 0.99\n\n  // Lower temperature threshold (below this point the layout will end)\n  minTemp = 1.0\n\n  // Node repulsion (non overlapping) multiplier\n  nodeRepulsion =  ( node ) => 2048\n\n  // Ideal edge (non nested) length\n  idealEdgeLength = ( edge ) => 32\n\n  // Divisor to compute edge forces\n  edgeElasticity = ( edge ) => 32\n}\n\ntype RankDir = 'LR' | 'TB'\ntype Ranker = 'network-simplex' | 'tight-tree' | 'longest-path'\n\nexport class DagreLayoutOptionsImpl extends ShapedLayoutOptionsImpl {\n  constructor() {\n    super()\n  }\n\n  name = 'dagre'\n\n  nodeSep: number = null // the separation between adjacent nodes in the same rank\n  edgeSep: number = null // the separation between adjacent edges in the same rank\n  rankSep: number = null // the separation between each rank in the layout\n  // TB for top to bottom flow, 'LR' for left to right\n  rankDir: RankDir = 'TB'\n  // Type of algorithm to assign a rank to each node in the input graph.\n  // Possible values: 'network-simplex', 'tight-tree' or 'longest-path'\n  ranker: Ranker = null\n  // number of ranks to keep between the source and target of the edge\n  minLen = ( edge ) => 1\n  edgeWeight = ( edge ) => 1 // higher weight edges are generally made shorter and straighter than lower weight edges\n}\n"]}