diff --git a/CHANGELOG.md b/CHANGELOG.md index 3129878f..91ab0801 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,25 +6,36 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] +## [0.1.0] - 2019-04-05 + ### Added -* `demos/usage-dag-edges.py`: Show different types of edges in a DAG -* `demos/usage-elements-extra.py`: Shows how to load external layouts, otherwise same app as `usage-elements.py`. -* `demos/usage-preset-animation.py`: Example of animating nodes using the preset layout. -* `demos/usage-reset-button.py`: Example of resetting the graph position using a button. -* `dash_cytoscape.load_extra_layouts()`: A new function that can be called before initializing the Dash app (`app = dash.Dash(__name__)`) to load the JS bundle containing the external layouts. -* `webpack.[dev|prod].extra.config.js`: Two new webpack configs for external layouts. +* Four new demos: + * `demos/usage-dag-edges.py`: Example of edges in a directed acyclic graph (DAG). It uses the new `dash_cytoscape.utils.Tree` class. + * `demos/usage-elements-extra.py`: Example of loading external layouts. + * `demos/usage-preset-animation.py`: Example of animating nodes using the preset layout. + * `demos/usage-reset-button.py`: Example of resetting the graph position using a button. + * `demos/usage-remove-selected-elements.py`: Example to show how to remove selected elements with button. +* `dash_cytoscape/dash_cytoscape_extra.[min|dev].js`: New bundles containing the extra layouts. Those bundles are double in size compared to the default bundles. Therefore, they are only loaded when the user uses `load_extra_layouts()` to limit bandwidth usage and maximize loading speed. Please view [fast3g-cytoscape](demos/images/fast3g-cytoscape.PNG) for an example of the impact on loading time. +* `dash_cytoscape._display_default_values()`: A helper function to display the default prop values by reading `metadata.json`. Useful for documentation. +* `dash_cytoscape.load_extra_layouts()`: A function that can be called before initializing the Dash app (`app = dash.Dash(__name__)`) to load the JS bundle containing the external layouts. * `src/lib/extra_index.js`: Loads external layouts before exporting the `Cytoscape` class. Needed to generate the new bundles. +* `webpack.[dev|prod].extra.config.js`: Two new webpack config files for external layouts. * Images of new external layouts. -* `dash_cytoscape/dash_cytoscape_extra.[min|dev].js`: New bundles containing the extra layouts. Those bundles are double in size compared to the default bundles. Therefore, they are only loaded when the user uses `load_extra_layouts()` to limit bandwidth usage and maximize loading speed. Please view [fast3g-cytoscape](demos/images/fast3g-cytoscape.PNG) for an example of the impact on loading time. -* `dash_cytoscape._display_default_values()`: A util function to display the default prop values by reading `metadata.json`. Useful for documentation. +* The ability for the user to feed a dictionary with keys `nodes` and `edges` to the `elements` prop of `Cytoscape`, instead of a list. The values corresponding to these keys will be, respectively, lists of nodes and edges in the graph. + ### Changed * `usage-events.py`: Added IDs for the edges in order to pass Percy tests. -* `src/lib/components/Cytoscape.react.js`: Updated docstring to include information about new external layouts and warning about nodes that can't be modified by a callback. Added more default props for a better expected behavior. +* `src/lib/components/Cytoscape.react.js`: Updated component docstring to include information about new external layouts and a warning about nodes that can't be modified by a callback. Added more default props for a better expected behavior. * `package.json`: Added new builds for the extra layouts, modified `npm build:all` to include new builds. Added external layouts as dependencies. +* `MANIFEST.in`: Included new `dash_cytoscape.[min|dev].js` files. * `README.md`: Moved images, added more images at the end, added useful links. +### Fixed +* Removing selected elements will now cause the corresponding JSON data to be cleared. Fixed by [PR #49](https://github.com/plotly/dash-cytoscape/pull/49), fixes [issue #45](https://github.com/plotly/dash-cytoscape/issues/45). + + ## [0.0.5] - 2019-03-08 ### Added diff --git a/MANIFEST.in b/MANIFEST.in index 45e60baf..30445a61 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -1,5 +1,7 @@ include dash_cytoscape/dash_cytoscape.min.js include dash_cytoscape/dash_cytoscape.dev.js +include dash_cytoscape/dash_cytoscape_extra.min.js +include dash_cytoscape/dash_cytoscape_extra.dev.js include dash_cytoscape/metadata.json include dash_cytoscape/package.json include README.md diff --git a/dash_cytoscape/dash_cytoscape.dev.js b/dash_cytoscape/dash_cytoscape.dev.js index 1e58e863..b4b1015c 100644 --- a/dash_cytoscape/dash_cytoscape.dev.js +++ b/dash_cytoscape/dash_cytoscape.dev.js @@ -275,7 +275,7 @@ eval("module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\ /***/ (function(module, exports, __webpack_require__) { "use strict"; - eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _reactCytoscapejs = __webpack_require__(/*! react-cytoscapejs */ \"./node_modules/react-cytoscapejs/dist/react-cytoscape.js\");\n\nvar _reactCytoscapejs2 = _interopRequireDefault(_reactCytoscapejs);\n\nvar _lodash = __webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\");\n\nvar _lodash2 = _interopRequireDefault(_lodash);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /**\r\n * JavaScript Requirements: cytoscape\r\n * React.js requirements: react-cytoscapejs\r\n */\n\n\n/**\r\nA Component Library for Dash aimed at facilitating network visualization in\r\nPython, wrapped around [Cytoscape.js](http://js.cytoscape.org/).\r\n */\nvar Cytoscape = function (_Component) {\n _inherits(Cytoscape, _Component);\n\n function Cytoscape(props) {\n _classCallCheck(this, Cytoscape);\n\n var _this = _possibleConstructorReturn(this, (Cytoscape.__proto__ || Object.getPrototypeOf(Cytoscape)).call(this, props));\n\n _this.handleCy = _this.handleCy.bind(_this);\n _this._handleCyCalled = false;\n return _this;\n }\n\n _createClass(Cytoscape, [{\n key: 'generateNode',\n value: function generateNode(event) {\n var ele = event.target;\n\n var isParent = ele.isParent(),\n isChildless = ele.isChildless(),\n isChild = ele.isChild(),\n isOrphan = ele.isOrphan(),\n renderedPosition = ele.renderedPosition(),\n relativePosition = ele.relativePosition(),\n parent = ele.parent(),\n style = ele.style();\n\n // Trim down the element objects to only the data contained\n var edgesData = ele.connectedEdges().map(function (ele) {\n return ele.data();\n }),\n childrenData = ele.children().map(function (ele) {\n return ele.data();\n }),\n ancestorsData = ele.ancestors().map(function (ele) {\n return ele.data();\n }),\n descendantsData = ele.descendants().map(function (ele) {\n return ele.data();\n }),\n siblingsData = ele.siblings().map(function (ele) {\n return ele.data();\n });\n\n var timeStamp = event.timeStamp;\n\n var _ele$json = ele.json(),\n classes = _ele$json.classes,\n data = _ele$json.data,\n grabbable = _ele$json.grabbable,\n group = _ele$json.group,\n locked = _ele$json.locked,\n position = _ele$json.position,\n selected = _ele$json.selected,\n selectable = _ele$json.selectable;\n\n var parentData = void 0;\n if (parent) {\n parentData = parent.data();\n } else {\n parentData = null;\n }\n\n var nodeObject = {\n // Nodes attributes\n edgesData: edgesData,\n renderedPosition: renderedPosition,\n timeStamp: timeStamp,\n // From ele.json()\n classes: classes,\n data: data,\n grabbable: grabbable,\n group: group,\n locked: locked,\n position: position,\n selectable: selectable,\n selected: selected,\n // Compound Nodes additional attributes\n ancestorsData: ancestorsData,\n childrenData: childrenData,\n descendantsData: descendantsData,\n parentData: parentData,\n siblingsData: siblingsData,\n isParent: isParent,\n isChildless: isChildless,\n isChild: isChild,\n isOrphan: isOrphan,\n relativePosition: relativePosition,\n // Styling\n style: style\n };\n return nodeObject;\n }\n }, {\n key: 'generateEdge',\n value: function generateEdge(event) {\n var ele = event.target;\n\n var midpoint = ele.midpoint(),\n isLoop = ele.isLoop(),\n isSimple = ele.isSimple(),\n sourceData = ele.source().data(),\n sourceEndpoint = ele.sourceEndpoint(),\n style = ele.style(),\n targetData = ele.target().data(),\n targetEndpoint = ele.targetEndpoint();\n\n var timeStamp = event.timeStamp;\n\n var _ele$json2 = ele.json(),\n classes = _ele$json2.classes,\n data = _ele$json2.data,\n grabbable = _ele$json2.grabbable,\n group = _ele$json2.group,\n locked = _ele$json2.locked,\n selectable = _ele$json2.selectable,\n selected = _ele$json2.selected;\n\n var edgeObject = {\n // Edges attributes\n isLoop: isLoop,\n isSimple: isSimple,\n midpoint: midpoint,\n sourceData: sourceData,\n sourceEndpoint: sourceEndpoint,\n targetData: targetData,\n targetEndpoint: targetEndpoint,\n timeStamp: timeStamp,\n // From ele.json()\n classes: classes,\n data: data,\n grabbable: grabbable,\n group: group,\n locked: locked,\n selectable: selectable,\n selected: selected,\n // Styling\n style: style\n };\n\n return edgeObject;\n }\n }, {\n key: 'handleCy',\n value: function handleCy(cy) {\n var _this2 = this;\n\n // If the cy pointer has not been modified, and handleCy has already\n // been called before, than we don't run this function.\n if (cy === this._cy && this._handleCyCalled) {\n return;\n }\n this._cy = cy;\n window.cy = cy;\n this._handleCyCalled = true;\n\n // ///////////////////////////////////// CONSTANTS /////////////////////////////////////////\n var SELECT_THRESHOLD = 100;\n\n var selectedNodes = cy.collection();\n var selectedEdges = cy.collection();\n\n // ///////////////////////////////////// FUNCTIONS /////////////////////////////////////////\n var refreshLayout = _lodash2.default.debounce(function () {\n /**\r\n * Refresh Layout if needed\r\n */\n var _props = _this2.props,\n autoRefreshLayout = _props.autoRefreshLayout,\n layout = _props.layout;\n\n\n if (autoRefreshLayout) {\n cy.layout(layout).run();\n }\n }, SELECT_THRESHOLD);\n\n var sendSelectedNodesData = _lodash2.default.debounce(function () {\n /**\r\n This function is repetitively called every time a node is selected\r\n or unselected, but keeps being debounced if it is called again\r\n within 100 ms (given by SELECT_THRESHOLD). Effectively, it only\r\n runs when all the nodes have been correctly selected/unselected and\r\n added/removed from the selectedNodes collection, and then updates\r\n the selectedNodeData prop.\r\n */\n var nodeData = selectedNodes.map(function (el) {\n return el.data();\n });\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n selectedNodeData: nodeData\n });\n }\n }, SELECT_THRESHOLD);\n\n var sendSelectedEdgesData = _lodash2.default.debounce(function () {\n var edgeData = selectedEdges.map(function (el) {\n return el.data();\n });\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n selectedEdgeData: edgeData\n });\n }\n }, SELECT_THRESHOLD);\n\n // /////////////////////////////////////// EVENTS //////////////////////////////////////////\n cy.on('tap', 'node', function (event) {\n var nodeObject = _this2.generateNode(event);\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n tapNode: nodeObject,\n tapNodeData: nodeObject.data\n });\n }\n });\n\n cy.on('tap', 'edge', function (event) {\n var edgeObject = _this2.generateEdge(event);\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n tapEdge: edgeObject,\n tapEdgeData: edgeObject.data\n });\n }\n });\n\n cy.on('mouseover', 'node', function (event) {\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n mouseoverNodeData: event.target.data()\n });\n }\n });\n\n cy.on('mouseover', 'edge', function (event) {\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n mouseoverEdgeData: event.target.data()\n });\n }\n });\n\n cy.on('select', 'node', function (event) {\n var ele = event.target;\n\n selectedNodes.merge(ele);\n sendSelectedNodesData();\n });\n\n cy.on('unselect remove', 'node', function (event) {\n var ele = event.target;\n\n selectedNodes.unmerge(ele);\n sendSelectedNodesData();\n });\n\n cy.on('select', 'edge', function (event) {\n var ele = event.target;\n\n selectedEdges.merge(ele);\n sendSelectedEdgesData();\n });\n\n cy.on('unselect remove', 'edge', function (event) {\n var ele = event.target;\n\n selectedEdges.unmerge(ele);\n sendSelectedEdgesData();\n });\n\n cy.on('add remove', function () {\n refreshLayout();\n });\n }\n }, {\n key: 'render',\n value: function render() {\n var _props2 = this.props,\n id = _props2.id,\n style = _props2.style,\n className = _props2.className,\n elements = _props2.elements,\n stylesheet = _props2.stylesheet,\n layout = _props2.layout,\n pan = _props2.pan,\n zoom = _props2.zoom,\n panningEnabled = _props2.panningEnabled,\n userPanningEnabled = _props2.userPanningEnabled,\n minZoom = _props2.minZoom,\n maxZoom = _props2.maxZoom,\n zoomingEnabled = _props2.zoomingEnabled,\n userZoomingEnabled = _props2.userZoomingEnabled,\n boxSelectionEnabled = _props2.boxSelectionEnabled,\n autoungrabify = _props2.autoungrabify,\n autolock = _props2.autolock,\n autounselectify = _props2.autounselectify;\n\n\n return _react2.default.createElement(_reactCytoscapejs2.default, {\n id: id,\n cy: this.handleCy,\n className: className,\n style: style,\n elements: _reactCytoscapejs2.default.normalizeElements(elements),\n stylesheet: stylesheet,\n layout: layout,\n pan: pan,\n zoom: zoom,\n panningEnabled: panningEnabled,\n userPanningEnabled: userPanningEnabled,\n minZoom: minZoom,\n maxZoom: maxZoom,\n zoomingEnabled: zoomingEnabled,\n userZoomingEnabled: userZoomingEnabled,\n boxSelectionEnabled: boxSelectionEnabled,\n autoungrabify: autoungrabify,\n autolock: autolock,\n autounselectify: autounselectify\n });\n }\n }]);\n\n return Cytoscape;\n}(_react.Component);\n\nCytoscape.propTypes = {\n // HTML attribute props\n\n /**\r\n * The ID used to identify this component in Dash callbacks.\r\n */\n id: _propTypes2.default.string,\n\n /**\r\n * Sets the class name of the element (the value of an element's html\r\n * class attribute).\r\n */\n className: _propTypes2.default.string,\n\n /**\r\n * Add inline styles to the root element.\r\n */\n style: _propTypes2.default.object,\n\n // Dash specific props\n\n /**\r\n * Dash-assigned callback that should be called whenever any of the\r\n * properties change.\r\n */\n setProps: _propTypes2.default.func,\n\n // Common props\n\n /**\r\n * A list of dictionaries representing the elements of the networks.\r\n * 1. Each dictionary describes an element, and specifies its purpose.\r\n * - `group` (string): Either 'nodes' or 'edges'. If not given, it's automatically inferred.\r\n * - `data` (dictionary): Element specific data.\r\n * - `id` (string): Reference to the element, useful for selectors and edges. Randomly assigned if not given.\r\n * - `label` (string): Optional name for the element, useful when `data(label)` is given to a style's `content` or `label`. It is only a convention.\r\n * - `parent` (string): Only for nodes. Optional reference to another node. Needed to create compound nodes.\r\n * - `source` (string): Only for edges. The id of the source node, which is where the edge starts.\r\n * - `target` (string): Only for edges. The id of the target node, where the edge ends.\r\n * - `position` (dictionary): Only for nodes. The position of the node.\r\n * - `x` (number): The x-coordinate of the node.\r\n * - `y` (number): The y-coordinate of the node.\r\n * - `selected` (boolean): If the element is selected upon initialisation.\r\n * - `selectable` (boolean): If the element can be selected.\r\n * - `locked` (boolean): Only for nodes. If the position is immutable.\r\n * - `grabbable` (boolean): Only for nodes. If the node can be grabbed and moved by the user.\r\n * - `classes` (string): Space separated string of class names of the element. Those classes can be selected by a style selector.\r\n *\r\n * 2. The [official Cytoscape.js documentation](http://js.cytoscape.org/#notation/elements-json) offers an extensive overview and examples of element declaration.\r\n */\n elements: _propTypes2.default.arrayOf(_propTypes2.default.object),\n\n /**\r\n * A list of dictionaries representing the styles of the elements.\r\n * 1. Each dictionary requires the following keys:\r\n * - `selector` (string): Which elements you are styling. Generally, you select a group of elements (node, edges, both), a class (that you declare in the element dictionary), or an element by ID.\r\n * - `style` (dictionary): What aspects of the elements you want to modify. This could be the size or color of a node, the shape of an edge arrow, or many more.\r\n *\r\n * 2. Both [the selector string](http://js.cytoscape.org/#selectors) and\r\n * [the style dictionary](http://js.cytoscape.org/#style/node-body) are\r\n * exhaustively documented in the Cytoscape.js docs. Although methods such\r\n * as `cy.elements(...)` and `cy.filter(...)` are not available, the selector\r\n * string syntax stays the same.\r\n */\n stylesheet: _propTypes2.default.arrayOf(_propTypes2.default.object),\n\n /**\r\n * A dictionary specifying how to set the position of the elements in your\r\n * graph. The `'name'` key is required, and indicates which layout (algorithm) to\r\n * use.\r\n * 1. The layouts available by default are:\r\n * - `random`: Randomly assigns positions\r\n * - `preset`: Assigns position based on the `position` key in element dictionaries\r\n * - `circle`: Single-level circle, with optional radius\r\n * - `concentric`: Multi-level circle, with optional radius\r\n * - `grid`: Square grid, optionally with numbers of `rows` and `cols`\r\n * - `breadthfirst`: Tree structure built using BFS, with optional `roots`\r\n * - `cose`: Force-directed physics simulation\r\n *\r\n * 2. Some external layouts are also included. To use them, run\r\n * `dash_cytoscape.load_extra_layouts()` before creating your Dash app. Be careful about\r\n * using the extra layouts when not necessary, since they require supplementary bandwidth\r\n * for loading, which impacts the startup time of the app.\r\n * - `cose-bilkent`: https://github.com/cytoscape/cytoscape.js-cose-bilkent\r\n * - `cola`: https://github.com/cytoscape/cytoscape.js-cola\r\n * - `euler`: https://github.com/cytoscape/cytoscape.js-dagre\r\n * - `spread`: https://github.com/cytoscape/cytoscape.js-spread\r\n * - `dagre`: https://github.com/cytoscape/cytoscape.js-dagre\r\n * - `klay`: https://github.com/cytoscape/cytoscape.js-klay\r\n *\r\n * 3. The keys accepted by `layout` vary depending on the algorithm, but some\r\n * keys are accepted by all layouts:\r\n * - `fit` (boolean): Whether to render the nodes in order to fit the canvas.\r\n * - `padding` (number): Padding around the sides of the canvas, if fit is enabled.\r\n * - `animate` (boolean): Whether to animate change in position when the layout changes.\r\n * - `animationDuration` (number): Duration of animation in milliseconds, if enabled.\r\n * - `boundingBox` (dictionary): How to constrain the layout in a specific area. Keys accepted are either `x1, y1, x2, y2` or `x1, y1, w, h`, all of which receive a pixel value.\r\n *\r\n * 4. The complete list of layouts and their accepted options are available\r\n * on the [Cytoscape.js docs](http://js.cytoscape.org/#layouts). For the\r\n * external layouts, the options are listed in the \"API\" section of the\r\n * README.\r\n * Note that certain keys are not supported in Dash since the value is a\r\n * JavaScript function or a callback. Please visit [this issue](https://github.com/plotly/dash-cytoscape/issues/25)\r\n * for more information.\r\n */\n layout: _propTypes2.default.object,\n\n // Viewport Manipulation\n\n /**\r\n * Dictionary indicating the initial panning position of the graph. The\r\n * following keys are accepted:\r\n * - `x` (number): The x-coordinate of the position.\r\n * - `y` (number): The y-coordinate of the position.\r\n */\n pan: _propTypes2.default.object,\n\n /**\r\n * The initial zoom level of the graph. You can set `minZoom` and\r\n * `maxZoom` to set restrictions on the zoom level.\r\n */\n zoom: _propTypes2.default.number,\n\n // Viewport Mutability and gesture Toggling\n /**\r\n * Whether panning the graph is enabled (i.e., the position of the graph is\r\n * mutable overall).\r\n */\n panningEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether user events (e.g. dragging the graph background) are allowed to\r\n * pan the graph.\r\n */\n userPanningEnabled: _propTypes2.default.bool,\n\n /**\r\n * A minimum bound on the zoom level of the graph. The viewport can not be\r\n * scaled smaller than this zoom level.\r\n */\n minZoom: _propTypes2.default.number,\n\n /**\r\n * A maximum bound on the zoom level of the graph. The viewport can not be\r\n * scaled larger than this zoom level.\r\n */\n maxZoom: _propTypes2.default.number,\n\n /**\r\n * Whether zooming the graph is enabled (i.e., the zoom level of the graph\r\n * is mutable overall).\r\n */\n zoomingEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether user events (e.g. dragging the graph background) are allowed\r\n * to pan the graph.\r\n */\n userZoomingEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether box selection (i.e. drag a box overlay around, and release it\r\n * to select) is enabled. If enabled, the user must taphold to pan the graph.\r\n */\n boxSelectionEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be ungrabified (not grabbable by user) by\r\n * default (if true, overrides individual node state).\r\n */\n autoungrabify: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be locked (not draggable at all) by default\r\n * (if true, overrides individual node state).\r\n */\n autolock: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be unselectified (immutable selection state) by\r\n * default (if true, overrides individual element state).\r\n */\n autounselectify: _propTypes2.default.bool,\n\n /**\r\n * Whether the layout should be refreshed when elements are added or removed.\r\n */\n autoRefreshLayout: _propTypes2.default.bool,\n\n // User Events Props\n\n /**\r\n * The complete node dictionary returned when you tap or click it. Read-only.\r\n *\r\n * 1. Node-specific items:\r\n * - `edgesData` (dictionary)\r\n * - `renderedPosition` (dictionary)\r\n * - `timeStamp` (number)\r\n *\r\n * 2. General items (for all elements):\r\n * - `classes` (string)\r\n * - `data` (dictionary)\r\n * - `grabbable` (boolean)\r\n * - `group` (string)\r\n * - `locked` (boolean)\r\n * - `position` (dictionary)\r\n * - `selectable` (boolean)\r\n * - `selected` (boolean)\r\n * - `style` (dictionary)\r\n *\r\n * 3. Items for compound nodes:\r\n * - `ancestorsData` (dictionary)\r\n * - `childrenData` (dictionary)\r\n * - `descendantsData` (dictionary)\r\n * - `parentData` (dictionary)\r\n * - `siblingsData` (dictionary)\r\n * - `isParent` (boolean)\r\n * - `isChildless` (boolean)\r\n * - `isChild` (boolean)\r\n * - `isOrphan` (boolean)\r\n * - `relativePosition` (dictionary)\r\n */\n tapNode: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of a node returned when you tap or click it. Read-only.\r\n */\n tapNodeData: _propTypes2.default.object,\n\n /**\r\n * The complete edge dictionary returned when you tap or click it. Read-only.\r\n *\r\n * 1. Edge-specific items:\r\n * - `isLoop` (boolean)\r\n * - `isSimple` (boolean)\r\n * - `midpoint` (dictionary)\r\n * - `sourceData` (dictionary)\r\n * - `sourceEndpoint` (dictionary)\r\n * - `targetData` (dictionary)\r\n * - `targetEndpoint` (dictionary)\r\n * - `timeStamp` (number)\r\n *\r\n * 2. General items (for all elements):\r\n * - `classes` (string)\r\n * - `data` (dictionary)\r\n * - `grabbable` (boolean)\r\n * - `group` (string)\r\n * - `locked` (boolean)\r\n * - `selectable` (boolean)\r\n * - `selected` (boolean)\r\n * - `style` (dictionary)\r\n */\n tapEdge: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of an edge returned when you tap or click it. Read-only.\r\n */\n tapEdgeData: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of a node returned when you hover over it. Read-only.\r\n */\n mouseoverNodeData: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of an edge returned when you hover over it. Read-only.\r\n */\n mouseoverEdgeData: _propTypes2.default.object,\n\n /**\r\n * The list of data dictionaries of all selected nodes (e.g. using\r\n * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n */\n selectedNodeData: _propTypes2.default.array,\n\n /**\r\n * The list of data dictionaries of all selected edges (e.g. using\r\n * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n */\n selectedEdgeData: _propTypes2.default.array\n};\n\nCytoscape.defaultProps = {\n style: { width: '600px', height: '600px' },\n layout: { name: 'grid' },\n pan: { x: 0, y: 0 },\n zoom: 1,\n minZoom: 1e-50,\n maxZoom: 1e50,\n zoomingEnabled: true,\n userZoomingEnabled: true,\n panningEnabled: true,\n userPanningEnabled: true,\n boxSelectionEnabled: false,\n autolock: false,\n autoungrabify: false,\n autounselectify: false,\n autoRefreshLayout: true\n};\n\nexports.default = Cytoscape;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_cytoscape/./src/lib/components/Cytoscape.react.js?642c"],"names":["Cytoscape","props","handleCy","bind","_handleCyCalled","event","ele","target","isParent","isChildless","isChild","isOrphan","renderedPosition","relativePosition","parent","style","edgesData","connectedEdges","map","data","childrenData","children","ancestorsData","ancestors","descendantsData","descendants","siblingsData","siblings","timeStamp","json","classes","grabbable","group","locked","position","selected","selectable","parentData","nodeObject","midpoint","isLoop","isSimple","sourceData","source","sourceEndpoint","targetData","targetEndpoint","edgeObject","cy","_cy","window","SELECT_THRESHOLD","selectedNodes","collection","selectedEdges","refreshLayout","_","debounce","autoRefreshLayout","layout","run","sendSelectedNodesData","nodeData","el","setProps","selectedNodeData","sendSelectedEdgesData","edgeData","selectedEdgeData","on","generateNode","tapNode","tapNodeData","generateEdge","tapEdge","tapEdgeData","mouseoverNodeData","mouseoverEdgeData","merge","unmerge","id","className","elements","stylesheet","pan","zoom","panningEnabled","userPanningEnabled","minZoom","maxZoom","zoomingEnabled","userZoomingEnabled","boxSelectionEnabled","autoungrabify","autolock","autounselectify","CytoscapeComponent","normalizeElements","Component","propTypes","PropTypes","string","object","func","arrayOf","number","bool","array","defaultProps","width","height","name","x","y"],"mappings":"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","file":"./src/lib/components/Cytoscape.react.js.js","sourcesContent":["/**\r\n * JavaScript Requirements: cytoscape\r\n * React.js requirements: react-cytoscapejs\r\n */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport CytoscapeComponent from 'react-cytoscapejs';\r\nimport _ from 'lodash';\r\n\r\n\r\n/**\r\nA Component Library for Dash aimed at facilitating network visualization in\r\nPython, wrapped around [Cytoscape.js](http://js.cytoscape.org/).\r\n */\r\nclass Cytoscape extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.handleCy = this.handleCy.bind(this);\r\n        this._handleCyCalled = false;\r\n    }\r\n\r\n    generateNode(event) {\r\n        const ele = event.target;\r\n\r\n        const isParent = ele.isParent(),\r\n            isChildless = ele.isChildless(),\r\n            isChild = ele.isChild(),\r\n            isOrphan = ele.isOrphan(),\r\n            renderedPosition = ele.renderedPosition(),\r\n            relativePosition = ele.relativePosition(),\r\n            parent = ele.parent(),\r\n            style = ele.style();\r\n\r\n        // Trim down the element objects to only the data contained\r\n        const edgesData = ele.connectedEdges().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            childrenData = ele.children().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            ancestorsData = ele.ancestors().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            descendantsData = ele.descendants().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            siblingsData = ele.siblings().map(ele => {\r\n                return ele.data()\r\n            });\r\n\r\n        const {timeStamp} = event;\r\n        const {\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            position,\r\n            selected,\r\n            selectable\r\n        } = ele.json();\r\n\r\n        let parentData;\r\n        if (parent) {\r\n            parentData = parent.data();\r\n        } else {\r\n            parentData = null;\r\n        }\r\n\r\n        const nodeObject = {\r\n            // Nodes attributes\r\n            edgesData,\r\n            renderedPosition,\r\n            timeStamp,\r\n            // From ele.json()\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            position,\r\n            selectable,\r\n            selected,\r\n            // Compound Nodes additional attributes\r\n            ancestorsData,\r\n            childrenData,\r\n            descendantsData,\r\n            parentData,\r\n            siblingsData,\r\n            isParent,\r\n            isChildless,\r\n            isChild,\r\n            isOrphan,\r\n            relativePosition,\r\n            // Styling\r\n            style\r\n        };\r\n        return nodeObject;\r\n    }\r\n\r\n\r\n    generateEdge(event) {\r\n        const ele = event.target;\r\n\r\n        const midpoint = ele.midpoint(),\r\n            isLoop = ele.isLoop(),\r\n            isSimple = ele.isSimple(),\r\n            sourceData = ele.source().data(),\r\n            sourceEndpoint = ele.sourceEndpoint(),\r\n            style = ele.style(),\r\n            targetData = ele.target().data(),\r\n            targetEndpoint = ele.targetEndpoint();\r\n\r\n        const {timeStamp} = event;\r\n        const {\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            selectable,\r\n            selected,\r\n        } = ele.json();\r\n\r\n        const edgeObject = {\r\n            // Edges attributes\r\n            isLoop,\r\n            isSimple,\r\n            midpoint,\r\n            sourceData,\r\n            sourceEndpoint,\r\n            targetData,\r\n            targetEndpoint,\r\n            timeStamp,\r\n            // From ele.json()\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            selectable,\r\n            selected,\r\n            // Styling\r\n            style\r\n        };\r\n\r\n        return edgeObject;\r\n    }\r\n\r\n    handleCy(cy) {\r\n        // If the cy pointer has not been modified, and handleCy has already\r\n        // been called before, than we don't run this function.\r\n        if (cy === this._cy && this._handleCyCalled) {\r\n            return;\r\n        }\r\n        this._cy = cy;\r\n        window.cy = cy;\r\n        this._handleCyCalled = true;\r\n\r\n        // ///////////////////////////////////// CONSTANTS /////////////////////////////////////////\r\n        const SELECT_THRESHOLD = 100;\r\n\r\n        const selectedNodes = cy.collection();\r\n        const selectedEdges = cy.collection();\r\n\r\n        // ///////////////////////////////////// FUNCTIONS /////////////////////////////////////////\r\n        const refreshLayout = _.debounce(() => {\r\n            /**\r\n             * Refresh Layout if needed\r\n             */\r\n            const {\r\n                autoRefreshLayout,\r\n                layout\r\n            } = this.props;\r\n\r\n            if (autoRefreshLayout) {\r\n                cy.layout(layout).run()\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        const sendSelectedNodesData = _.debounce(() => {\r\n            /**\r\n            This function is repetitively called every time a node is selected\r\n            or unselected, but keeps being debounced if it is called again\r\n            within 100 ms (given by SELECT_THRESHOLD). Effectively, it only\r\n            runs when all the nodes have been correctly selected/unselected and\r\n            added/removed from the selectedNodes collection, and then updates\r\n            the selectedNodeData prop.\r\n             */\r\n            const nodeData = selectedNodes.map(el => el.data());\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    selectedNodeData: nodeData\r\n                })\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        const sendSelectedEdgesData = _.debounce(() => {\r\n            const edgeData = selectedEdges.map(el => el.data());\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    selectedEdgeData: edgeData\r\n                })\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        // /////////////////////////////////////// EVENTS //////////////////////////////////////////\r\n        cy.on('tap', 'node', event => {\r\n            const nodeObject = this.generateNode(event);\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    tapNode: nodeObject,\r\n                    tapNodeData: nodeObject.data\r\n                });\r\n            }\r\n        });\r\n\r\n        cy.on('tap', 'edge', event => {\r\n            const edgeObject = this.generateEdge(event);\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    tapEdge: edgeObject,\r\n                    tapEdgeData: edgeObject.data\r\n                });\r\n            }\r\n        });\r\n\r\n        cy.on('mouseover', 'node', event => {\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    mouseoverNodeData: event.target.data()\r\n                })\r\n            }\r\n        });\r\n\r\n        cy.on('mouseover', 'edge', event => {\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    mouseoverEdgeData: event.target.data()\r\n                })\r\n            }\r\n        });\r\n\r\n        cy.on('select', 'node', event => {\r\n            const ele = event.target;\r\n\r\n            selectedNodes.merge(ele);\r\n            sendSelectedNodesData();\r\n        });\r\n\r\n        cy.on('unselect remove', 'node', event => {\r\n            const ele = event.target;\r\n\r\n            selectedNodes.unmerge(ele);\r\n            sendSelectedNodesData();\r\n        });\r\n\r\n        cy.on('select', 'edge', event => {\r\n            const ele = event.target;\r\n\r\n            selectedEdges.merge(ele);\r\n            sendSelectedEdgesData();\r\n        });\r\n\r\n        cy.on('unselect remove', 'edge', event => {\r\n            const ele = event.target;\r\n\r\n            selectedEdges.unmerge(ele);\r\n            sendSelectedEdgesData();\r\n        });\r\n\r\n        cy.on('add remove', () => {\r\n            refreshLayout();\r\n        });\r\n    }\r\n\r\n    render() {\r\n        const {\r\n            // HTML attribute props\r\n            id,\r\n            style,\r\n            className,\r\n            // Common props\r\n            elements,\r\n            stylesheet,\r\n            layout,\r\n            // Viewport Manipulation\r\n            pan,\r\n            zoom,\r\n            // Viewport Mutability and gesture Toggling\r\n            panningEnabled,\r\n            userPanningEnabled,\r\n            minZoom,\r\n            maxZoom,\r\n            zoomingEnabled,\r\n            userZoomingEnabled,\r\n            boxSelectionEnabled,\r\n            autoungrabify,\r\n            autolock,\r\n            autounselectify\r\n        } = this.props;\r\n\r\n        return (\r\n            <CytoscapeComponent\r\n                id={id}\r\n                cy={this.handleCy}\r\n                className={className}\r\n                style={style}\r\n                elements={CytoscapeComponent.normalizeElements(elements)}\r\n                stylesheet={stylesheet}\r\n                layout={layout}\r\n                pan={pan}\r\n                zoom={zoom}\r\n                panningEnabled={panningEnabled}\r\n                userPanningEnabled={userPanningEnabled}\r\n                minZoom={minZoom}\r\n                maxZoom={maxZoom}\r\n                zoomingEnabled={zoomingEnabled}\r\n                userZoomingEnabled={userZoomingEnabled}\r\n                boxSelectionEnabled={boxSelectionEnabled}\r\n                autoungrabify={autoungrabify}\r\n                autolock={autolock}\r\n                autounselectify={autounselectify}\r\n            />\r\n        )\r\n    }\r\n}\r\n\r\n\r\nCytoscape.propTypes = {\r\n    // HTML attribute props\r\n\r\n    /**\r\n     * The ID used to identify this component in Dash callbacks.\r\n     */\r\n    id: PropTypes.string,\r\n\r\n    /**\r\n     * Sets the class name of the element (the value of an element's html\r\n     * class attribute).\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Add inline styles to the root element.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    // Dash specific props\r\n\r\n    /**\r\n     * Dash-assigned callback that should be called whenever any of the\r\n     * properties change.\r\n     */\r\n    setProps: PropTypes.func,\r\n\r\n    // Common props\r\n\r\n    /**\r\n     * A list of dictionaries representing the elements of the networks.\r\n     *     1. Each dictionary describes an element, and specifies its purpose.\r\n     *         - `group` (string): Either 'nodes' or 'edges'. If not given, it's automatically inferred.\r\n     *         - `data` (dictionary): Element specific data.\r\n     *              - `id` (string): Reference to the element, useful for selectors and edges. Randomly assigned if not given.\r\n     *              - `label` (string): Optional name for the element, useful when `data(label)` is given to a style's `content` or `label`. It is only a convention.\r\n     *              - `parent` (string): Only for nodes. Optional reference to another node. Needed to create compound nodes.\r\n     *              - `source` (string): Only for edges. The id of the source node, which is where the edge starts.\r\n     *              - `target` (string): Only for edges. The id of the target node, where the edge ends.\r\n     *         - `position` (dictionary): Only for nodes. The position of the node.\r\n     *              - `x` (number): The x-coordinate of the node.\r\n     *              - `y` (number): The y-coordinate of the node.\r\n     *         - `selected` (boolean): If the element is selected upon initialisation.\r\n     *         - `selectable` (boolean): If the element can be selected.\r\n     *         - `locked` (boolean): Only for nodes. If the position is immutable.\r\n     *         - `grabbable` (boolean): Only for nodes. If the node can be grabbed and moved by the user.\r\n     *         - `classes` (string): Space separated string of class names of the element. Those classes can be selected by a style selector.\r\n     *\r\n     *     2. The [official Cytoscape.js documentation](http://js.cytoscape.org/#notation/elements-json) offers an extensive overview and examples of element declaration.\r\n     */\r\n    elements: PropTypes.arrayOf(PropTypes.object),\r\n\r\n    /**\r\n     * A list of dictionaries representing the styles of the elements.\r\n     *     1. Each dictionary requires the following keys:\r\n     *         - `selector` (string): Which elements you are styling. Generally, you select a group of elements (node, edges, both), a class (that you declare in the element dictionary), or an element by ID.\r\n     *         - `style` (dictionary): What aspects of the elements you want to modify. This could be the size or color of a node, the shape of an edge arrow, or many more.\r\n     *\r\n     *     2. Both [the selector string](http://js.cytoscape.org/#selectors) and\r\n     *     [the style dictionary](http://js.cytoscape.org/#style/node-body) are\r\n     *     exhaustively documented in the Cytoscape.js docs. Although methods such\r\n     *     as `cy.elements(...)` and `cy.filter(...)` are not available, the selector\r\n     *     string syntax stays the same.\r\n     */\r\n    stylesheet: PropTypes.arrayOf(PropTypes.object),\r\n\r\n    /**\r\n     * A dictionary specifying how to set the position of the elements in your\r\n     * graph. The `'name'` key is required, and indicates which layout (algorithm) to\r\n     * use.\r\n     *     1. The layouts available by default are:\r\n     *         - `random`: Randomly assigns positions\r\n     *         - `preset`: Assigns position based on the `position` key in element dictionaries\r\n     *         - `circle`: Single-level circle, with optional radius\r\n     *         - `concentric`: Multi-level circle, with optional radius\r\n     *         - `grid`: Square grid, optionally with numbers of `rows` and `cols`\r\n     *         - `breadthfirst`: Tree structure built using BFS, with optional `roots`\r\n     *         - `cose`: Force-directed physics simulation\r\n     *\r\n     *     2. Some external layouts are also included. To use them, run\r\n     *     `dash_cytoscape.load_extra_layouts()` before creating your Dash app. Be careful about\r\n     *     using the extra layouts when not necessary, since they require supplementary bandwidth\r\n     *     for loading, which impacts the startup time of the app.\r\n     *         - `cose-bilkent`: https://github.com/cytoscape/cytoscape.js-cose-bilkent\r\n     *         - `cola`: https://github.com/cytoscape/cytoscape.js-cola\r\n     *         - `euler`: https://github.com/cytoscape/cytoscape.js-dagre\r\n     *         - `spread`: https://github.com/cytoscape/cytoscape.js-spread\r\n     *         - `dagre`: https://github.com/cytoscape/cytoscape.js-dagre\r\n     *         - `klay`: https://github.com/cytoscape/cytoscape.js-klay\r\n     *\r\n     *     3. The keys accepted by `layout` vary depending on the algorithm, but some\r\n     *     keys are accepted by all layouts:\r\n     *         - `fit` (boolean): Whether to render the nodes in order to fit the canvas.\r\n     *         - `padding` (number): Padding around the sides of the canvas, if fit is enabled.\r\n     *         - `animate` (boolean): Whether to animate change in position when the layout changes.\r\n     *         - `animationDuration` (number): Duration of animation in milliseconds, if enabled.\r\n     *         - `boundingBox` (dictionary): How to constrain the layout in a specific area. Keys accepted are either `x1, y1, x2, y2` or `x1, y1, w, h`, all of which receive a pixel value.\r\n     *\r\n     *     4. The complete list of layouts and their accepted options are available\r\n     *     on the [Cytoscape.js docs](http://js.cytoscape.org/#layouts). For the\r\n     *     external layouts, the options are listed in the \"API\" section of the\r\n     *     README.\r\n     *     Note that certain keys are not supported in Dash since the value is a\r\n     *     JavaScript function or a callback. Please visit [this issue](https://github.com/plotly/dash-cytoscape/issues/25)\r\n     *     for more information.\r\n     */\r\n    layout: PropTypes.object,\r\n\r\n    // Viewport Manipulation\r\n\r\n    /**\r\n     * Dictionary indicating the initial panning position of the graph. The\r\n     * following keys are accepted:\r\n     *     - `x` (number): The x-coordinate of the position.\r\n     *     - `y` (number): The y-coordinate of the position.\r\n     */\r\n    pan: PropTypes.object,\r\n\r\n    /**\r\n     * The initial zoom level of the graph. You can set `minZoom` and\r\n     * `maxZoom` to set restrictions on the zoom level.\r\n     */\r\n    zoom: PropTypes.number,\r\n\r\n    // Viewport Mutability and gesture Toggling\r\n    /**\r\n     * Whether panning the graph is enabled (i.e., the position of the graph is\r\n     * mutable overall).\r\n     */\r\n    panningEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether user events (e.g. dragging the graph background) are allowed to\r\n     * pan the graph.\r\n     */\r\n    userPanningEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * A minimum bound on the zoom level of the graph. The viewport can not be\r\n     * scaled smaller than this zoom level.\r\n     */\r\n    minZoom: PropTypes.number,\r\n\r\n    /**\r\n     * A maximum bound on the zoom level of the graph. The viewport can not be\r\n     * scaled larger than this zoom level.\r\n     */\r\n    maxZoom: PropTypes.number,\r\n\r\n    /**\r\n     * Whether zooming the graph is enabled (i.e., the zoom level of the graph\r\n     * is mutable overall).\r\n     */\r\n    zoomingEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether user events (e.g. dragging the graph background) are allowed\r\n     * to pan the graph.\r\n     */\r\n    userZoomingEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether box selection (i.e. drag a box overlay around, and release it\r\n     * to select) is enabled. If enabled, the user must taphold to pan the graph.\r\n     */\r\n    boxSelectionEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be ungrabified (not grabbable by user) by\r\n     * default (if true, overrides individual node state).\r\n     */\r\n    autoungrabify: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be locked (not draggable at all) by default\r\n     * (if true, overrides individual node state).\r\n     */\r\n    autolock: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be unselectified (immutable selection state) by\r\n     * default (if true, overrides individual element state).\r\n     */\r\n    autounselectify: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether the layout should be refreshed when elements are added or removed.\r\n     */\r\n    autoRefreshLayout: PropTypes.bool,\r\n\r\n    // User Events Props\r\n\r\n    /**\r\n     * The complete node dictionary returned when you tap or click it. Read-only.\r\n     *\r\n     *     1. Node-specific items:\r\n     *         - `edgesData` (dictionary)\r\n     *         - `renderedPosition` (dictionary)\r\n     *         - `timeStamp` (number)\r\n     *\r\n     *     2. General items (for all elements):\r\n     *         - `classes` (string)\r\n     *         - `data` (dictionary)\r\n     *         - `grabbable` (boolean)\r\n     *         - `group` (string)\r\n     *         - `locked` (boolean)\r\n     *         - `position` (dictionary)\r\n     *         - `selectable` (boolean)\r\n     *         - `selected` (boolean)\r\n     *         - `style` (dictionary)\r\n     *\r\n     *     3. Items for compound nodes:\r\n     *         - `ancestorsData` (dictionary)\r\n     *         - `childrenData` (dictionary)\r\n     *         - `descendantsData` (dictionary)\r\n     *         - `parentData` (dictionary)\r\n     *         - `siblingsData` (dictionary)\r\n     *         - `isParent` (boolean)\r\n     *         - `isChildless` (boolean)\r\n     *         - `isChild` (boolean)\r\n     *         - `isOrphan` (boolean)\r\n     *         - `relativePosition` (dictionary)\r\n     */\r\n    tapNode: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of a node returned when you tap or click it. Read-only.\r\n     */\r\n    tapNodeData: PropTypes.object,\r\n\r\n    /**\r\n     * The complete edge dictionary returned when you tap or click it. Read-only.\r\n     *\r\n     *     1. Edge-specific items:\r\n     *         - `isLoop` (boolean)\r\n     *         - `isSimple` (boolean)\r\n     *         - `midpoint` (dictionary)\r\n     *         - `sourceData` (dictionary)\r\n     *         - `sourceEndpoint` (dictionary)\r\n     *         - `targetData` (dictionary)\r\n     *         - `targetEndpoint` (dictionary)\r\n     *         - `timeStamp` (number)\r\n     *\r\n     *     2. General items (for all elements):\r\n     *         - `classes` (string)\r\n     *         - `data` (dictionary)\r\n     *         - `grabbable` (boolean)\r\n     *         - `group` (string)\r\n     *         - `locked` (boolean)\r\n     *         - `selectable` (boolean)\r\n     *         - `selected` (boolean)\r\n     *         - `style` (dictionary)\r\n     */\r\n    tapEdge: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of an edge returned when you tap or click it. Read-only.\r\n     */\r\n    tapEdgeData: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of a node returned when you hover over it. Read-only.\r\n     */\r\n    mouseoverNodeData: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of an edge returned when you hover over it. Read-only.\r\n     */\r\n    mouseoverEdgeData: PropTypes.object,\r\n\r\n    /**\r\n     * The list of data dictionaries of all selected nodes (e.g. using\r\n     * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n     */\r\n    selectedNodeData: PropTypes.array,\r\n\r\n    /**\r\n     * The list of data dictionaries of all selected edges (e.g. using\r\n     * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n     */\r\n    selectedEdgeData: PropTypes.array\r\n};\r\n\r\nCytoscape.defaultProps = {\r\n    style: {width: '600px', height: '600px'},\r\n    layout: {name: 'grid'},\r\n    pan: {x: 0, y: 0},\r\n    zoom: 1,\r\n    minZoom: 1e-50,\r\n    maxZoom: 1e50,\r\n    zoomingEnabled: true,\r\n    userZoomingEnabled: true,\r\n    panningEnabled: true,\r\n    userPanningEnabled: true,\r\n    boxSelectionEnabled: false,\r\n    autolock: false,\r\n    autoungrabify: false,\r\n    autounselectify: false,\r\n    autoRefreshLayout: true\r\n};\r\n\r\nexport default Cytoscape;"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/lib/components/Cytoscape.react.js\n"); +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _reactCytoscapejs = __webpack_require__(/*! react-cytoscapejs */ \"./node_modules/react-cytoscapejs/dist/react-cytoscape.js\");\n\nvar _reactCytoscapejs2 = _interopRequireDefault(_reactCytoscapejs);\n\nvar _lodash = __webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\");\n\nvar _lodash2 = _interopRequireDefault(_lodash);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /**\r\n * JavaScript Requirements: cytoscape\r\n * React.js requirements: react-cytoscapejs\r\n */\n\n\n/**\r\nA Component Library for Dash aimed at facilitating network visualization in\r\nPython, wrapped around [Cytoscape.js](http://js.cytoscape.org/).\r\n */\nvar Cytoscape = function (_Component) {\n _inherits(Cytoscape, _Component);\n\n function Cytoscape(props) {\n _classCallCheck(this, Cytoscape);\n\n var _this = _possibleConstructorReturn(this, (Cytoscape.__proto__ || Object.getPrototypeOf(Cytoscape)).call(this, props));\n\n _this.handleCy = _this.handleCy.bind(_this);\n _this._handleCyCalled = false;\n return _this;\n }\n\n _createClass(Cytoscape, [{\n key: 'generateNode',\n value: function generateNode(event) {\n var ele = event.target;\n\n var isParent = ele.isParent(),\n isChildless = ele.isChildless(),\n isChild = ele.isChild(),\n isOrphan = ele.isOrphan(),\n renderedPosition = ele.renderedPosition(),\n relativePosition = ele.relativePosition(),\n parent = ele.parent(),\n style = ele.style();\n\n // Trim down the element objects to only the data contained\n var edgesData = ele.connectedEdges().map(function (ele) {\n return ele.data();\n }),\n childrenData = ele.children().map(function (ele) {\n return ele.data();\n }),\n ancestorsData = ele.ancestors().map(function (ele) {\n return ele.data();\n }),\n descendantsData = ele.descendants().map(function (ele) {\n return ele.data();\n }),\n siblingsData = ele.siblings().map(function (ele) {\n return ele.data();\n });\n\n var timeStamp = event.timeStamp;\n\n var _ele$json = ele.json(),\n classes = _ele$json.classes,\n data = _ele$json.data,\n grabbable = _ele$json.grabbable,\n group = _ele$json.group,\n locked = _ele$json.locked,\n position = _ele$json.position,\n selected = _ele$json.selected,\n selectable = _ele$json.selectable;\n\n var parentData = void 0;\n if (parent) {\n parentData = parent.data();\n } else {\n parentData = null;\n }\n\n var nodeObject = {\n // Nodes attributes\n edgesData: edgesData,\n renderedPosition: renderedPosition,\n timeStamp: timeStamp,\n // From ele.json()\n classes: classes,\n data: data,\n grabbable: grabbable,\n group: group,\n locked: locked,\n position: position,\n selectable: selectable,\n selected: selected,\n // Compound Nodes additional attributes\n ancestorsData: ancestorsData,\n childrenData: childrenData,\n descendantsData: descendantsData,\n parentData: parentData,\n siblingsData: siblingsData,\n isParent: isParent,\n isChildless: isChildless,\n isChild: isChild,\n isOrphan: isOrphan,\n relativePosition: relativePosition,\n // Styling\n style: style\n };\n return nodeObject;\n }\n }, {\n key: 'generateEdge',\n value: function generateEdge(event) {\n var ele = event.target;\n\n var midpoint = ele.midpoint(),\n isLoop = ele.isLoop(),\n isSimple = ele.isSimple(),\n sourceData = ele.source().data(),\n sourceEndpoint = ele.sourceEndpoint(),\n style = ele.style(),\n targetData = ele.target().data(),\n targetEndpoint = ele.targetEndpoint();\n\n var timeStamp = event.timeStamp;\n\n var _ele$json2 = ele.json(),\n classes = _ele$json2.classes,\n data = _ele$json2.data,\n grabbable = _ele$json2.grabbable,\n group = _ele$json2.group,\n locked = _ele$json2.locked,\n selectable = _ele$json2.selectable,\n selected = _ele$json2.selected;\n\n var edgeObject = {\n // Edges attributes\n isLoop: isLoop,\n isSimple: isSimple,\n midpoint: midpoint,\n sourceData: sourceData,\n sourceEndpoint: sourceEndpoint,\n targetData: targetData,\n targetEndpoint: targetEndpoint,\n timeStamp: timeStamp,\n // From ele.json()\n classes: classes,\n data: data,\n grabbable: grabbable,\n group: group,\n locked: locked,\n selectable: selectable,\n selected: selected,\n // Styling\n style: style\n };\n\n return edgeObject;\n }\n }, {\n key: 'handleCy',\n value: function handleCy(cy) {\n var _this2 = this;\n\n // If the cy pointer has not been modified, and handleCy has already\n // been called before, than we don't run this function.\n if (cy === this._cy && this._handleCyCalled) {\n return;\n }\n this._cy = cy;\n window.cy = cy;\n this._handleCyCalled = true;\n\n // ///////////////////////////////////// CONSTANTS /////////////////////////////////////////\n var SELECT_THRESHOLD = 100;\n\n var selectedNodes = cy.collection();\n var selectedEdges = cy.collection();\n\n // ///////////////////////////////////// FUNCTIONS /////////////////////////////////////////\n var refreshLayout = _lodash2.default.debounce(function () {\n /**\r\n * Refresh Layout if needed\r\n */\n var _props = _this2.props,\n autoRefreshLayout = _props.autoRefreshLayout,\n layout = _props.layout;\n\n\n if (autoRefreshLayout) {\n cy.layout(layout).run();\n }\n }, SELECT_THRESHOLD);\n\n var sendSelectedNodesData = _lodash2.default.debounce(function () {\n /**\r\n This function is repetitively called every time a node is selected\r\n or unselected, but keeps being debounced if it is called again\r\n within 100 ms (given by SELECT_THRESHOLD). Effectively, it only\r\n runs when all the nodes have been correctly selected/unselected and\r\n added/removed from the selectedNodes collection, and then updates\r\n the selectedNodeData prop.\r\n */\n var nodeData = selectedNodes.map(function (el) {\n return el.data();\n });\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n selectedNodeData: nodeData\n });\n }\n }, SELECT_THRESHOLD);\n\n var sendSelectedEdgesData = _lodash2.default.debounce(function () {\n var edgeData = selectedEdges.map(function (el) {\n return el.data();\n });\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n selectedEdgeData: edgeData\n });\n }\n }, SELECT_THRESHOLD);\n\n // /////////////////////////////////////// EVENTS //////////////////////////////////////////\n cy.on('tap', 'node', function (event) {\n var nodeObject = _this2.generateNode(event);\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n tapNode: nodeObject,\n tapNodeData: nodeObject.data\n });\n }\n });\n\n cy.on('tap', 'edge', function (event) {\n var edgeObject = _this2.generateEdge(event);\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n tapEdge: edgeObject,\n tapEdgeData: edgeObject.data\n });\n }\n });\n\n cy.on('mouseover', 'node', function (event) {\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n mouseoverNodeData: event.target.data()\n });\n }\n });\n\n cy.on('mouseover', 'edge', function (event) {\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n mouseoverEdgeData: event.target.data()\n });\n }\n });\n\n cy.on('select', 'node', function (event) {\n var ele = event.target;\n\n selectedNodes.merge(ele);\n sendSelectedNodesData();\n });\n\n cy.on('unselect remove', 'node', function (event) {\n var ele = event.target;\n\n selectedNodes.unmerge(ele);\n sendSelectedNodesData();\n });\n\n cy.on('select', 'edge', function (event) {\n var ele = event.target;\n\n selectedEdges.merge(ele);\n sendSelectedEdgesData();\n });\n\n cy.on('unselect remove', 'edge', function (event) {\n var ele = event.target;\n\n selectedEdges.unmerge(ele);\n sendSelectedEdgesData();\n });\n\n cy.on('add remove', function () {\n refreshLayout();\n });\n }\n }, {\n key: 'render',\n value: function render() {\n var _props2 = this.props,\n id = _props2.id,\n style = _props2.style,\n className = _props2.className,\n elements = _props2.elements,\n stylesheet = _props2.stylesheet,\n layout = _props2.layout,\n pan = _props2.pan,\n zoom = _props2.zoom,\n panningEnabled = _props2.panningEnabled,\n userPanningEnabled = _props2.userPanningEnabled,\n minZoom = _props2.minZoom,\n maxZoom = _props2.maxZoom,\n zoomingEnabled = _props2.zoomingEnabled,\n userZoomingEnabled = _props2.userZoomingEnabled,\n boxSelectionEnabled = _props2.boxSelectionEnabled,\n autoungrabify = _props2.autoungrabify,\n autolock = _props2.autolock,\n autounselectify = _props2.autounselectify;\n\n\n return _react2.default.createElement(_reactCytoscapejs2.default, {\n id: id,\n cy: this.handleCy,\n className: className,\n style: style,\n elements: _reactCytoscapejs2.default.normalizeElements(elements),\n stylesheet: stylesheet,\n layout: layout,\n pan: pan,\n zoom: zoom,\n panningEnabled: panningEnabled,\n userPanningEnabled: userPanningEnabled,\n minZoom: minZoom,\n maxZoom: maxZoom,\n zoomingEnabled: zoomingEnabled,\n userZoomingEnabled: userZoomingEnabled,\n boxSelectionEnabled: boxSelectionEnabled,\n autoungrabify: autoungrabify,\n autolock: autolock,\n autounselectify: autounselectify\n });\n }\n }]);\n\n return Cytoscape;\n}(_react.Component);\n\nCytoscape.propTypes = {\n // HTML attribute props\n\n /**\r\n * The ID used to identify this component in Dash callbacks.\r\n */\n id: _propTypes2.default.string,\n\n /**\r\n * Sets the class name of the element (the value of an element's html\r\n * class attribute).\r\n */\n className: _propTypes2.default.string,\n\n /**\r\n * Add inline styles to the root element.\r\n */\n style: _propTypes2.default.object,\n\n // Dash specific props\n\n /**\r\n * Dash-assigned callback that should be called whenever any of the\r\n * properties change.\r\n */\n setProps: _propTypes2.default.func,\n\n // Common props\n\n /**\r\n * A list of dictionaries representing the elements of the networks.\r\n * 1. Each dictionary describes an element, and specifies its purpose.\r\n * - `group` (string): Either 'nodes' or 'edges'. If not given, it's automatically inferred.\r\n * - `data` (dictionary): Element specific data.\r\n * - `id` (string): Reference to the element, useful for selectors and edges. Randomly assigned if not given.\r\n * - `label` (string): Optional name for the element, useful when `data(label)` is given to a style's `content` or `label`. It is only a convention.\r\n * - `parent` (string): Only for nodes. Optional reference to another node. Needed to create compound nodes.\r\n * - `source` (string): Only for edges. The id of the source node, which is where the edge starts.\r\n * - `target` (string): Only for edges. The id of the target node, where the edge ends.\r\n * - `position` (dictionary): Only for nodes. The position of the node.\r\n * - `x` (number): The x-coordinate of the node.\r\n * - `y` (number): The y-coordinate of the node.\r\n * - `selected` (boolean): If the element is selected upon initialisation.\r\n * - `selectable` (boolean): If the element can be selected.\r\n * - `locked` (boolean): Only for nodes. If the position is immutable.\r\n * - `grabbable` (boolean): Only for nodes. If the node can be grabbed and moved by the user.\r\n * - `classes` (string): Space separated string of class names of the element. Those classes can be selected by a style selector.\r\n *\r\n * 2. The [official Cytoscape.js documentation](http://js.cytoscape.org/#notation/elements-json) offers an extensive overview and examples of element declaration.\r\n */\n elements: _propTypes2.default.arrayOf(_propTypes2.default.object),\n\n /**\r\n * A list of dictionaries representing the styles of the elements.\r\n * 1. Each dictionary requires the following keys:\r\n * - `selector` (string): Which elements you are styling. Generally, you select a group of elements (node, edges, both), a class (that you declare in the element dictionary), or an element by ID.\r\n * - `style` (dictionary): What aspects of the elements you want to modify. This could be the size or color of a node, the shape of an edge arrow, or many more.\r\n *\r\n * 2. Both [the selector string](http://js.cytoscape.org/#selectors) and\r\n * [the style dictionary](http://js.cytoscape.org/#style/node-body) are\r\n * exhaustively documented in the Cytoscape.js docs. Although methods such\r\n * as `cy.elements(...)` and `cy.filter(...)` are not available, the selector\r\n * string syntax stays the same.\r\n */\n stylesheet: _propTypes2.default.arrayOf(_propTypes2.default.object),\n\n /**\r\n * A dictionary specifying how to set the position of the elements in your\r\n * graph. The `'name'` key is required, and indicates which layout (algorithm) to\r\n * use.\r\n * 1. The layouts available by default are:\r\n * - `random`: Randomly assigns positions\r\n * - `preset`: Assigns position based on the `position` key in element dictionaries\r\n * - `circle`: Single-level circle, with optional radius\r\n * - `concentric`: Multi-level circle, with optional radius\r\n * - `grid`: Square grid, optionally with numbers of `rows` and `cols`\r\n * - `breadthfirst`: Tree structure built using BFS, with optional `roots`\r\n * - `cose`: Force-directed physics simulation\r\n *\r\n * 2. Some external layouts are also included. To use them, run\r\n * `dash_cytoscape.load_extra_layouts()` before creating your Dash app. Be careful about\r\n * using the extra layouts when not necessary, since they require supplementary bandwidth\r\n * for loading, which impacts the startup time of the app.\r\n * - `cose-bilkent`: https://github.com/cytoscape/cytoscape.js-cose-bilkent\r\n * - `cola`: https://github.com/cytoscape/cytoscape.js-cola\r\n * - `euler`: https://github.com/cytoscape/cytoscape.js-dagre\r\n * - `spread`: https://github.com/cytoscape/cytoscape.js-spread\r\n * - `dagre`: https://github.com/cytoscape/cytoscape.js-dagre\r\n * - `klay`: https://github.com/cytoscape/cytoscape.js-klay\r\n *\r\n * 3. The keys accepted by `layout` vary depending on the algorithm, but some\r\n * keys are accepted by all layouts:\r\n * - `fit` (boolean): Whether to render the nodes in order to fit the canvas.\r\n * - `padding` (number): Padding around the sides of the canvas, if fit is enabled.\r\n * - `animate` (boolean): Whether to animate change in position when the layout changes.\r\n * - `animationDuration` (number): Duration of animation in milliseconds, if enabled.\r\n * - `boundingBox` (dictionary): How to constrain the layout in a specific area. Keys accepted are either `x1, y1, x2, y2` or `x1, y1, w, h`, all of which receive a pixel value.\r\n *\r\n * 4. The complete list of layouts and their accepted options are available\r\n * on the [Cytoscape.js docs](http://js.cytoscape.org/#layouts). For the\r\n * external layouts, the options are listed in the \"API\" section of the\r\n * README.\r\n * Note that certain keys are not supported in Dash since the value is a\r\n * JavaScript function or a callback. Please visit [this issue](https://github.com/plotly/dash-cytoscape/issues/25)\r\n * for more information.\r\n */\n layout: _propTypes2.default.object,\n\n // Viewport Manipulation\n\n /**\r\n * Dictionary indicating the initial panning position of the graph. The\r\n * following keys are accepted:\r\n * - `x` (number): The x-coordinate of the position.\r\n * - `y` (number): The y-coordinate of the position.\r\n */\n pan: _propTypes2.default.object,\n\n /**\r\n * The initial zoom level of the graph. You can set `minZoom` and\r\n * `maxZoom` to set restrictions on the zoom level.\r\n */\n zoom: _propTypes2.default.number,\n\n // Viewport Mutability and gesture Toggling\n /**\r\n * Whether panning the graph is enabled (i.e., the position of the graph is\r\n * mutable overall).\r\n */\n panningEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether user events (e.g. dragging the graph background) are allowed to\r\n * pan the graph.\r\n */\n userPanningEnabled: _propTypes2.default.bool,\n\n /**\r\n * A minimum bound on the zoom level of the graph. The viewport can not be\r\n * scaled smaller than this zoom level.\r\n */\n minZoom: _propTypes2.default.number,\n\n /**\r\n * A maximum bound on the zoom level of the graph. The viewport can not be\r\n * scaled larger than this zoom level.\r\n */\n maxZoom: _propTypes2.default.number,\n\n /**\r\n * Whether zooming the graph is enabled (i.e., the zoom level of the graph\r\n * is mutable overall).\r\n */\n zoomingEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether user events (e.g. dragging the graph background) are allowed\r\n * to pan the graph.\r\n */\n userZoomingEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether box selection (i.e. drag a box overlay around, and release it\r\n * to select) is enabled. If enabled, the user must taphold to pan the graph.\r\n */\n boxSelectionEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be ungrabified (not grabbable by user) by\r\n * default (if true, overrides individual node state).\r\n */\n autoungrabify: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be locked (not draggable at all) by default\r\n * (if true, overrides individual node state).\r\n */\n autolock: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be unselectified (immutable selection state) by\r\n * default (if true, overrides individual element state).\r\n */\n autounselectify: _propTypes2.default.bool,\n\n /**\r\n * Whether the layout should be refreshed when elements are added or removed.\r\n */\n autoRefreshLayout: _propTypes2.default.bool,\n\n // User Events Props\n\n /**\r\n * The complete node dictionary returned when you tap or click it. Read-only.\r\n *\r\n * 1. Node-specific items:\r\n * - `edgesData` (dictionary)\r\n * - `renderedPosition` (dictionary)\r\n * - `timeStamp` (number)\r\n *\r\n * 2. General items (for all elements):\r\n * - `classes` (string)\r\n * - `data` (dictionary)\r\n * - `grabbable` (boolean)\r\n * - `group` (string)\r\n * - `locked` (boolean)\r\n * - `position` (dictionary)\r\n * - `selectable` (boolean)\r\n * - `selected` (boolean)\r\n * - `style` (dictionary)\r\n *\r\n * 3. Items for compound nodes:\r\n * - `ancestorsData` (dictionary)\r\n * - `childrenData` (dictionary)\r\n * - `descendantsData` (dictionary)\r\n * - `parentData` (dictionary)\r\n * - `siblingsData` (dictionary)\r\n * - `isParent` (boolean)\r\n * - `isChildless` (boolean)\r\n * - `isChild` (boolean)\r\n * - `isOrphan` (boolean)\r\n * - `relativePosition` (dictionary)\r\n */\n tapNode: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of a node returned when you tap or click it. Read-only.\r\n */\n tapNodeData: _propTypes2.default.object,\n\n /**\r\n * The complete edge dictionary returned when you tap or click it. Read-only.\r\n *\r\n * 1. Edge-specific items:\r\n * - `isLoop` (boolean)\r\n * - `isSimple` (boolean)\r\n * - `midpoint` (dictionary)\r\n * - `sourceData` (dictionary)\r\n * - `sourceEndpoint` (dictionary)\r\n * - `targetData` (dictionary)\r\n * - `targetEndpoint` (dictionary)\r\n * - `timeStamp` (number)\r\n *\r\n * 2. General items (for all elements):\r\n * - `classes` (string)\r\n * - `data` (dictionary)\r\n * - `grabbable` (boolean)\r\n * - `group` (string)\r\n * - `locked` (boolean)\r\n * - `selectable` (boolean)\r\n * - `selected` (boolean)\r\n * - `style` (dictionary)\r\n */\n tapEdge: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of an edge returned when you tap or click it. Read-only.\r\n */\n tapEdgeData: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of a node returned when you hover over it. Read-only.\r\n */\n mouseoverNodeData: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of an edge returned when you hover over it. Read-only.\r\n */\n mouseoverEdgeData: _propTypes2.default.object,\n\n /**\r\n * The list of data dictionaries of all selected nodes (e.g. using\r\n * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n */\n selectedNodeData: _propTypes2.default.array,\n\n /**\r\n * The list of data dictionaries of all selected edges (e.g. using\r\n * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n */\n selectedEdgeData: _propTypes2.default.array\n};\n\nCytoscape.defaultProps = {\n style: { width: '600px', height: '600px' },\n layout: { name: 'grid' },\n pan: { x: 0, y: 0 },\n zoom: 1,\n minZoom: 1e-50,\n maxZoom: 1e50,\n zoomingEnabled: true,\n userZoomingEnabled: true,\n panningEnabled: true,\n userPanningEnabled: true,\n boxSelectionEnabled: false,\n autolock: false,\n autoungrabify: false,\n autounselectify: false,\n autoRefreshLayout: true\n};\n\nexports.default = Cytoscape;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_cytoscape/./src/lib/components/Cytoscape.react.js?642c"],"names":["Cytoscape","props","handleCy","bind","_handleCyCalled","event","ele","target","isParent","isChildless","isChild","isOrphan","renderedPosition","relativePosition","parent","style","edgesData","connectedEdges","map","data","childrenData","children","ancestorsData","ancestors","descendantsData","descendants","siblingsData","siblings","timeStamp","json","classes","grabbable","group","locked","position","selected","selectable","parentData","nodeObject","midpoint","isLoop","isSimple","sourceData","source","sourceEndpoint","targetData","targetEndpoint","edgeObject","cy","_cy","window","SELECT_THRESHOLD","selectedNodes","collection","selectedEdges","refreshLayout","_","debounce","autoRefreshLayout","layout","run","sendSelectedNodesData","nodeData","el","setProps","selectedNodeData","sendSelectedEdgesData","edgeData","selectedEdgeData","on","generateNode","tapNode","tapNodeData","generateEdge","tapEdge","tapEdgeData","mouseoverNodeData","mouseoverEdgeData","merge","unmerge","id","className","elements","stylesheet","pan","zoom","panningEnabled","userPanningEnabled","minZoom","maxZoom","zoomingEnabled","userZoomingEnabled","boxSelectionEnabled","autoungrabify","autolock","autounselectify","CytoscapeComponent","normalizeElements","Component","propTypes","PropTypes","string","object","func","arrayOf","number","bool","array","defaultProps","width","height","name","x","y"],"mappings":"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","file":"./src/lib/components/Cytoscape.react.js.js","sourcesContent":["/**\r\n * JavaScript Requirements: cytoscape\r\n * React.js requirements: react-cytoscapejs\r\n */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport CytoscapeComponent from 'react-cytoscapejs';\r\nimport _ from 'lodash';\r\n\r\n\r\n/**\r\nA Component Library for Dash aimed at facilitating network visualization in\r\nPython, wrapped around [Cytoscape.js](http://js.cytoscape.org/).\r\n */\r\nclass Cytoscape extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.handleCy = this.handleCy.bind(this);\r\n        this._handleCyCalled = false;\r\n    }\r\n\r\n    generateNode(event) {\r\n        const ele = event.target;\r\n\r\n        const isParent = ele.isParent(),\r\n            isChildless = ele.isChildless(),\r\n            isChild = ele.isChild(),\r\n            isOrphan = ele.isOrphan(),\r\n            renderedPosition = ele.renderedPosition(),\r\n            relativePosition = ele.relativePosition(),\r\n            parent = ele.parent(),\r\n            style = ele.style();\r\n\r\n        // Trim down the element objects to only the data contained\r\n        const edgesData = ele.connectedEdges().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            childrenData = ele.children().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            ancestorsData = ele.ancestors().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            descendantsData = ele.descendants().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            siblingsData = ele.siblings().map(ele => {\r\n                return ele.data()\r\n            });\r\n\r\n        const {timeStamp} = event;\r\n        const {\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            position,\r\n            selected,\r\n            selectable\r\n        } = ele.json();\r\n\r\n        let parentData;\r\n        if (parent) {\r\n            parentData = parent.data();\r\n        } else {\r\n            parentData = null;\r\n        }\r\n\r\n        const nodeObject = {\r\n            // Nodes attributes\r\n            edgesData,\r\n            renderedPosition,\r\n            timeStamp,\r\n            // From ele.json()\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            position,\r\n            selectable,\r\n            selected,\r\n            // Compound Nodes additional attributes\r\n            ancestorsData,\r\n            childrenData,\r\n            descendantsData,\r\n            parentData,\r\n            siblingsData,\r\n            isParent,\r\n            isChildless,\r\n            isChild,\r\n            isOrphan,\r\n            relativePosition,\r\n            // Styling\r\n            style\r\n        };\r\n        return nodeObject;\r\n    }\r\n\r\n\r\n    generateEdge(event) {\r\n        const ele = event.target;\r\n\r\n        const midpoint = ele.midpoint(),\r\n            isLoop = ele.isLoop(),\r\n            isSimple = ele.isSimple(),\r\n            sourceData = ele.source().data(),\r\n            sourceEndpoint = ele.sourceEndpoint(),\r\n            style = ele.style(),\r\n            targetData = ele.target().data(),\r\n            targetEndpoint = ele.targetEndpoint();\r\n\r\n        const {timeStamp} = event;\r\n        const {\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            selectable,\r\n            selected,\r\n        } = ele.json();\r\n\r\n        const edgeObject = {\r\n            // Edges attributes\r\n            isLoop,\r\n            isSimple,\r\n            midpoint,\r\n            sourceData,\r\n            sourceEndpoint,\r\n            targetData,\r\n            targetEndpoint,\r\n            timeStamp,\r\n            // From ele.json()\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            selectable,\r\n            selected,\r\n            // Styling\r\n            style\r\n        };\r\n\r\n        return edgeObject;\r\n    }\r\n\r\n    handleCy(cy) {\r\n        // If the cy pointer has not been modified, and handleCy has already\r\n        // been called before, than we don't run this function.\r\n        if (cy === this._cy && this._handleCyCalled) {\r\n            return;\r\n        }\r\n        this._cy = cy;\r\n        window.cy = cy;\r\n        this._handleCyCalled = true;\r\n\r\n        // ///////////////////////////////////// CONSTANTS /////////////////////////////////////////\r\n        const SELECT_THRESHOLD = 100;\r\n\r\n        const selectedNodes = cy.collection();\r\n        const selectedEdges = cy.collection();\r\n\r\n        // ///////////////////////////////////// FUNCTIONS /////////////////////////////////////////\r\n        const refreshLayout = _.debounce(() => {\r\n            /**\r\n             * Refresh Layout if needed\r\n             */\r\n            const {\r\n                autoRefreshLayout,\r\n                layout\r\n            } = this.props;\r\n\r\n            if (autoRefreshLayout) {\r\n                cy.layout(layout).run()\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        const sendSelectedNodesData = _.debounce(() => {\r\n            /**\r\n             This function is repetitively called every time a node is selected\r\n             or unselected, but keeps being debounced if it is called again\r\n             within 100 ms (given by SELECT_THRESHOLD). Effectively, it only\r\n             runs when all the nodes have been correctly selected/unselected and\r\n             added/removed from the selectedNodes collection, and then updates\r\n             the selectedNodeData prop.\r\n             */\r\n            const nodeData = selectedNodes.map(el => el.data());\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    selectedNodeData: nodeData\r\n                })\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        const sendSelectedEdgesData = _.debounce(() => {\r\n            const edgeData = selectedEdges.map(el => el.data());\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    selectedEdgeData: edgeData\r\n                })\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        // /////////////////////////////////////// EVENTS //////////////////////////////////////////\r\n        cy.on('tap', 'node', event => {\r\n            const nodeObject = this.generateNode(event);\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    tapNode: nodeObject,\r\n                    tapNodeData: nodeObject.data\r\n                });\r\n            }\r\n        });\r\n\r\n        cy.on('tap', 'edge', event => {\r\n            const edgeObject = this.generateEdge(event);\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    tapEdge: edgeObject,\r\n                    tapEdgeData: edgeObject.data\r\n                });\r\n            }\r\n        });\r\n\r\n        cy.on('mouseover', 'node', event => {\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    mouseoverNodeData: event.target.data()\r\n                })\r\n            }\r\n        });\r\n\r\n        cy.on('mouseover', 'edge', event => {\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    mouseoverEdgeData: event.target.data()\r\n                })\r\n            }\r\n        });\r\n\r\n        cy.on('select', 'node', event => {\r\n            const ele = event.target;\r\n\r\n            selectedNodes.merge(ele);\r\n            sendSelectedNodesData();\r\n        });\r\n\r\n        cy.on('unselect remove', 'node', event => {\r\n            const ele = event.target;\r\n\r\n            selectedNodes.unmerge(ele);\r\n            sendSelectedNodesData();\r\n        });\r\n\r\n        cy.on('select', 'edge', event => {\r\n            const ele = event.target;\r\n\r\n            selectedEdges.merge(ele);\r\n            sendSelectedEdgesData();\r\n        });\r\n\r\n        cy.on('unselect remove', 'edge', event => {\r\n            const ele = event.target;\r\n\r\n            selectedEdges.unmerge(ele);\r\n            sendSelectedEdgesData();\r\n        });\r\n\r\n        cy.on('add remove', () => {\r\n            refreshLayout();\r\n        });\r\n    }\r\n\r\n    render() {\r\n        const {\r\n            // HTML attribute props\r\n            id,\r\n            style,\r\n            className,\r\n            // Common props\r\n            elements,\r\n            stylesheet,\r\n            layout,\r\n            // Viewport Manipulation\r\n            pan,\r\n            zoom,\r\n            // Viewport Mutability and gesture Toggling\r\n            panningEnabled,\r\n            userPanningEnabled,\r\n            minZoom,\r\n            maxZoom,\r\n            zoomingEnabled,\r\n            userZoomingEnabled,\r\n            boxSelectionEnabled,\r\n            autoungrabify,\r\n            autolock,\r\n            autounselectify\r\n        } = this.props;\r\n\r\n        return (\r\n            <CytoscapeComponent\r\n                id={id}\r\n                cy={this.handleCy}\r\n                className={className}\r\n                style={style}\r\n                elements={CytoscapeComponent.normalizeElements(elements)}\r\n                stylesheet={stylesheet}\r\n                layout={layout}\r\n                pan={pan}\r\n                zoom={zoom}\r\n                panningEnabled={panningEnabled}\r\n                userPanningEnabled={userPanningEnabled}\r\n                minZoom={minZoom}\r\n                maxZoom={maxZoom}\r\n                zoomingEnabled={zoomingEnabled}\r\n                userZoomingEnabled={userZoomingEnabled}\r\n                boxSelectionEnabled={boxSelectionEnabled}\r\n                autoungrabify={autoungrabify}\r\n                autolock={autolock}\r\n                autounselectify={autounselectify}\r\n            />\r\n        )\r\n    }\r\n}\r\n\r\n\r\nCytoscape.propTypes = {\r\n    // HTML attribute props\r\n\r\n    /**\r\n     * The ID used to identify this component in Dash callbacks.\r\n     */\r\n    id: PropTypes.string,\r\n\r\n    /**\r\n     * Sets the class name of the element (the value of an element's html\r\n     * class attribute).\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Add inline styles to the root element.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    // Dash specific props\r\n\r\n    /**\r\n     * Dash-assigned callback that should be called whenever any of the\r\n     * properties change.\r\n     */\r\n    setProps: PropTypes.func,\r\n\r\n    // Common props\r\n\r\n    /**\r\n     * A list of dictionaries representing the elements of the networks.\r\n     *     1. Each dictionary describes an element, and specifies its purpose.\r\n     *         - `group` (string): Either 'nodes' or 'edges'. If not given, it's automatically inferred.\r\n     *         - `data` (dictionary): Element specific data.\r\n     *              - `id` (string): Reference to the element, useful for selectors and edges. Randomly assigned if not given.\r\n     *              - `label` (string): Optional name for the element, useful when `data(label)` is given to a style's `content` or `label`. It is only a convention.\r\n     *              - `parent` (string): Only for nodes. Optional reference to another node. Needed to create compound nodes.\r\n     *              - `source` (string): Only for edges. The id of the source node, which is where the edge starts.\r\n     *              - `target` (string): Only for edges. The id of the target node, where the edge ends.\r\n     *         - `position` (dictionary): Only for nodes. The position of the node.\r\n     *              - `x` (number): The x-coordinate of the node.\r\n     *              - `y` (number): The y-coordinate of the node.\r\n     *         - `selected` (boolean): If the element is selected upon initialisation.\r\n     *         - `selectable` (boolean): If the element can be selected.\r\n     *         - `locked` (boolean): Only for nodes. If the position is immutable.\r\n     *         - `grabbable` (boolean): Only for nodes. If the node can be grabbed and moved by the user.\r\n     *         - `classes` (string): Space separated string of class names of the element. Those classes can be selected by a style selector.\r\n     *\r\n     *     2. The [official Cytoscape.js documentation](http://js.cytoscape.org/#notation/elements-json) offers an extensive overview and examples of element declaration.\r\n     */\r\n    elements: PropTypes.arrayOf(PropTypes.object),\r\n\r\n    /**\r\n     * A list of dictionaries representing the styles of the elements.\r\n     *     1. Each dictionary requires the following keys:\r\n     *         - `selector` (string): Which elements you are styling. Generally, you select a group of elements (node, edges, both), a class (that you declare in the element dictionary), or an element by ID.\r\n     *         - `style` (dictionary): What aspects of the elements you want to modify. This could be the size or color of a node, the shape of an edge arrow, or many more.\r\n     *\r\n     *     2. Both [the selector string](http://js.cytoscape.org/#selectors) and\r\n     *     [the style dictionary](http://js.cytoscape.org/#style/node-body) are\r\n     *     exhaustively documented in the Cytoscape.js docs. Although methods such\r\n     *     as `cy.elements(...)` and `cy.filter(...)` are not available, the selector\r\n     *     string syntax stays the same.\r\n     */\r\n    stylesheet: PropTypes.arrayOf(PropTypes.object),\r\n\r\n    /**\r\n     * A dictionary specifying how to set the position of the elements in your\r\n     * graph. The `'name'` key is required, and indicates which layout (algorithm) to\r\n     * use.\r\n     *     1. The layouts available by default are:\r\n     *         - `random`: Randomly assigns positions\r\n     *         - `preset`: Assigns position based on the `position` key in element dictionaries\r\n     *         - `circle`: Single-level circle, with optional radius\r\n     *         - `concentric`: Multi-level circle, with optional radius\r\n     *         - `grid`: Square grid, optionally with numbers of `rows` and `cols`\r\n     *         - `breadthfirst`: Tree structure built using BFS, with optional `roots`\r\n     *         - `cose`: Force-directed physics simulation\r\n     *\r\n     *     2. Some external layouts are also included. To use them, run\r\n     *     `dash_cytoscape.load_extra_layouts()` before creating your Dash app. Be careful about\r\n     *     using the extra layouts when not necessary, since they require supplementary bandwidth\r\n     *     for loading, which impacts the startup time of the app.\r\n     *         - `cose-bilkent`: https://github.com/cytoscape/cytoscape.js-cose-bilkent\r\n     *         - `cola`: https://github.com/cytoscape/cytoscape.js-cola\r\n     *         - `euler`: https://github.com/cytoscape/cytoscape.js-dagre\r\n     *         - `spread`: https://github.com/cytoscape/cytoscape.js-spread\r\n     *         - `dagre`: https://github.com/cytoscape/cytoscape.js-dagre\r\n     *         - `klay`: https://github.com/cytoscape/cytoscape.js-klay\r\n     *\r\n     *     3. The keys accepted by `layout` vary depending on the algorithm, but some\r\n     *     keys are accepted by all layouts:\r\n     *         - `fit` (boolean): Whether to render the nodes in order to fit the canvas.\r\n     *         - `padding` (number): Padding around the sides of the canvas, if fit is enabled.\r\n     *         - `animate` (boolean): Whether to animate change in position when the layout changes.\r\n     *         - `animationDuration` (number): Duration of animation in milliseconds, if enabled.\r\n     *         - `boundingBox` (dictionary): How to constrain the layout in a specific area. Keys accepted are either `x1, y1, x2, y2` or `x1, y1, w, h`, all of which receive a pixel value.\r\n     *\r\n     *     4. The complete list of layouts and their accepted options are available\r\n     *     on the [Cytoscape.js docs](http://js.cytoscape.org/#layouts). For the\r\n     *     external layouts, the options are listed in the \"API\" section of the\r\n     *     README.\r\n     *     Note that certain keys are not supported in Dash since the value is a\r\n     *     JavaScript function or a callback. Please visit [this issue](https://github.com/plotly/dash-cytoscape/issues/25)\r\n     *     for more information.\r\n     */\r\n    layout: PropTypes.object,\r\n\r\n    // Viewport Manipulation\r\n\r\n    /**\r\n     * Dictionary indicating the initial panning position of the graph. The\r\n     * following keys are accepted:\r\n     *     - `x` (number): The x-coordinate of the position.\r\n     *     - `y` (number): The y-coordinate of the position.\r\n     */\r\n    pan: PropTypes.object,\r\n\r\n    /**\r\n     * The initial zoom level of the graph. You can set `minZoom` and\r\n     * `maxZoom` to set restrictions on the zoom level.\r\n     */\r\n    zoom: PropTypes.number,\r\n\r\n    // Viewport Mutability and gesture Toggling\r\n    /**\r\n     * Whether panning the graph is enabled (i.e., the position of the graph is\r\n     * mutable overall).\r\n     */\r\n    panningEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether user events (e.g. dragging the graph background) are allowed to\r\n     * pan the graph.\r\n     */\r\n    userPanningEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * A minimum bound on the zoom level of the graph. The viewport can not be\r\n     * scaled smaller than this zoom level.\r\n     */\r\n    minZoom: PropTypes.number,\r\n\r\n    /**\r\n     * A maximum bound on the zoom level of the graph. The viewport can not be\r\n     * scaled larger than this zoom level.\r\n     */\r\n    maxZoom: PropTypes.number,\r\n\r\n    /**\r\n     * Whether zooming the graph is enabled (i.e., the zoom level of the graph\r\n     * is mutable overall).\r\n     */\r\n    zoomingEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether user events (e.g. dragging the graph background) are allowed\r\n     * to pan the graph.\r\n     */\r\n    userZoomingEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether box selection (i.e. drag a box overlay around, and release it\r\n     * to select) is enabled. If enabled, the user must taphold to pan the graph.\r\n     */\r\n    boxSelectionEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be ungrabified (not grabbable by user) by\r\n     * default (if true, overrides individual node state).\r\n     */\r\n    autoungrabify: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be locked (not draggable at all) by default\r\n     * (if true, overrides individual node state).\r\n     */\r\n    autolock: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be unselectified (immutable selection state) by\r\n     * default (if true, overrides individual element state).\r\n     */\r\n    autounselectify: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether the layout should be refreshed when elements are added or removed.\r\n     */\r\n    autoRefreshLayout: PropTypes.bool,\r\n\r\n    // User Events Props\r\n\r\n    /**\r\n     * The complete node dictionary returned when you tap or click it. Read-only.\r\n     *\r\n     *     1. Node-specific items:\r\n     *         - `edgesData` (dictionary)\r\n     *         - `renderedPosition` (dictionary)\r\n     *         - `timeStamp` (number)\r\n     *\r\n     *     2. General items (for all elements):\r\n     *         - `classes` (string)\r\n     *         - `data` (dictionary)\r\n     *         - `grabbable` (boolean)\r\n     *         - `group` (string)\r\n     *         - `locked` (boolean)\r\n     *         - `position` (dictionary)\r\n     *         - `selectable` (boolean)\r\n     *         - `selected` (boolean)\r\n     *         - `style` (dictionary)\r\n     *\r\n     *     3. Items for compound nodes:\r\n     *         - `ancestorsData` (dictionary)\r\n     *         - `childrenData` (dictionary)\r\n     *         - `descendantsData` (dictionary)\r\n     *         - `parentData` (dictionary)\r\n     *         - `siblingsData` (dictionary)\r\n     *         - `isParent` (boolean)\r\n     *         - `isChildless` (boolean)\r\n     *         - `isChild` (boolean)\r\n     *         - `isOrphan` (boolean)\r\n     *         - `relativePosition` (dictionary)\r\n     */\r\n    tapNode: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of a node returned when you tap or click it. Read-only.\r\n     */\r\n    tapNodeData: PropTypes.object,\r\n\r\n    /**\r\n     * The complete edge dictionary returned when you tap or click it. Read-only.\r\n     *\r\n     *     1. Edge-specific items:\r\n     *         - `isLoop` (boolean)\r\n     *         - `isSimple` (boolean)\r\n     *         - `midpoint` (dictionary)\r\n     *         - `sourceData` (dictionary)\r\n     *         - `sourceEndpoint` (dictionary)\r\n     *         - `targetData` (dictionary)\r\n     *         - `targetEndpoint` (dictionary)\r\n     *         - `timeStamp` (number)\r\n     *\r\n     *     2. General items (for all elements):\r\n     *         - `classes` (string)\r\n     *         - `data` (dictionary)\r\n     *         - `grabbable` (boolean)\r\n     *         - `group` (string)\r\n     *         - `locked` (boolean)\r\n     *         - `selectable` (boolean)\r\n     *         - `selected` (boolean)\r\n     *         - `style` (dictionary)\r\n     */\r\n    tapEdge: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of an edge returned when you tap or click it. Read-only.\r\n     */\r\n    tapEdgeData: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of a node returned when you hover over it. Read-only.\r\n     */\r\n    mouseoverNodeData: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of an edge returned when you hover over it. Read-only.\r\n     */\r\n    mouseoverEdgeData: PropTypes.object,\r\n\r\n    /**\r\n     * The list of data dictionaries of all selected nodes (e.g. using\r\n     * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n     */\r\n    selectedNodeData: PropTypes.array,\r\n\r\n    /**\r\n     * The list of data dictionaries of all selected edges (e.g. using\r\n     * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n     */\r\n    selectedEdgeData: PropTypes.array\r\n};\r\n\r\nCytoscape.defaultProps = {\r\n    style: {width: '600px', height: '600px'},\r\n    layout: {name: 'grid'},\r\n    pan: {x: 0, y: 0},\r\n    zoom: 1,\r\n    minZoom: 1e-50,\r\n    maxZoom: 1e50,\r\n    zoomingEnabled: true,\r\n    userZoomingEnabled: true,\r\n    panningEnabled: true,\r\n    userPanningEnabled: true,\r\n    boxSelectionEnabled: false,\r\n    autolock: false,\r\n    autoungrabify: false,\r\n    autounselectify: false,\r\n    autoRefreshLayout: true\r\n};\r\n\r\nexport default Cytoscape;"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/lib/components/Cytoscape.react.js\n"); /***/ }), diff --git a/dash_cytoscape/dash_cytoscape_extra.dev.js b/dash_cytoscape/dash_cytoscape_extra.dev.js index da282290..9b18b63e 100644 --- a/dash_cytoscape/dash_cytoscape_extra.dev.js +++ b/dash_cytoscape/dash_cytoscape_extra.dev.js @@ -5711,7 +5711,7 @@ eval("module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\ /***/ (function(module, exports, __webpack_require__) { "use strict"; - eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _reactCytoscapejs = __webpack_require__(/*! react-cytoscapejs */ \"./node_modules/react-cytoscapejs/dist/react-cytoscape.js\");\n\nvar _reactCytoscapejs2 = _interopRequireDefault(_reactCytoscapejs);\n\nvar _lodash = __webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\");\n\nvar _lodash2 = _interopRequireDefault(_lodash);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /**\r\n * JavaScript Requirements: cytoscape\r\n * React.js requirements: react-cytoscapejs\r\n */\n\n\n/**\r\nA Component Library for Dash aimed at facilitating network visualization in\r\nPython, wrapped around [Cytoscape.js](http://js.cytoscape.org/).\r\n */\nvar Cytoscape = function (_Component) {\n _inherits(Cytoscape, _Component);\n\n function Cytoscape(props) {\n _classCallCheck(this, Cytoscape);\n\n var _this = _possibleConstructorReturn(this, (Cytoscape.__proto__ || Object.getPrototypeOf(Cytoscape)).call(this, props));\n\n _this.handleCy = _this.handleCy.bind(_this);\n _this._handleCyCalled = false;\n return _this;\n }\n\n _createClass(Cytoscape, [{\n key: 'generateNode',\n value: function generateNode(event) {\n var ele = event.target;\n\n var isParent = ele.isParent(),\n isChildless = ele.isChildless(),\n isChild = ele.isChild(),\n isOrphan = ele.isOrphan(),\n renderedPosition = ele.renderedPosition(),\n relativePosition = ele.relativePosition(),\n parent = ele.parent(),\n style = ele.style();\n\n // Trim down the element objects to only the data contained\n var edgesData = ele.connectedEdges().map(function (ele) {\n return ele.data();\n }),\n childrenData = ele.children().map(function (ele) {\n return ele.data();\n }),\n ancestorsData = ele.ancestors().map(function (ele) {\n return ele.data();\n }),\n descendantsData = ele.descendants().map(function (ele) {\n return ele.data();\n }),\n siblingsData = ele.siblings().map(function (ele) {\n return ele.data();\n });\n\n var timeStamp = event.timeStamp;\n\n var _ele$json = ele.json(),\n classes = _ele$json.classes,\n data = _ele$json.data,\n grabbable = _ele$json.grabbable,\n group = _ele$json.group,\n locked = _ele$json.locked,\n position = _ele$json.position,\n selected = _ele$json.selected,\n selectable = _ele$json.selectable;\n\n var parentData = void 0;\n if (parent) {\n parentData = parent.data();\n } else {\n parentData = null;\n }\n\n var nodeObject = {\n // Nodes attributes\n edgesData: edgesData,\n renderedPosition: renderedPosition,\n timeStamp: timeStamp,\n // From ele.json()\n classes: classes,\n data: data,\n grabbable: grabbable,\n group: group,\n locked: locked,\n position: position,\n selectable: selectable,\n selected: selected,\n // Compound Nodes additional attributes\n ancestorsData: ancestorsData,\n childrenData: childrenData,\n descendantsData: descendantsData,\n parentData: parentData,\n siblingsData: siblingsData,\n isParent: isParent,\n isChildless: isChildless,\n isChild: isChild,\n isOrphan: isOrphan,\n relativePosition: relativePosition,\n // Styling\n style: style\n };\n return nodeObject;\n }\n }, {\n key: 'generateEdge',\n value: function generateEdge(event) {\n var ele = event.target;\n\n var midpoint = ele.midpoint(),\n isLoop = ele.isLoop(),\n isSimple = ele.isSimple(),\n sourceData = ele.source().data(),\n sourceEndpoint = ele.sourceEndpoint(),\n style = ele.style(),\n targetData = ele.target().data(),\n targetEndpoint = ele.targetEndpoint();\n\n var timeStamp = event.timeStamp;\n\n var _ele$json2 = ele.json(),\n classes = _ele$json2.classes,\n data = _ele$json2.data,\n grabbable = _ele$json2.grabbable,\n group = _ele$json2.group,\n locked = _ele$json2.locked,\n selectable = _ele$json2.selectable,\n selected = _ele$json2.selected;\n\n var edgeObject = {\n // Edges attributes\n isLoop: isLoop,\n isSimple: isSimple,\n midpoint: midpoint,\n sourceData: sourceData,\n sourceEndpoint: sourceEndpoint,\n targetData: targetData,\n targetEndpoint: targetEndpoint,\n timeStamp: timeStamp,\n // From ele.json()\n classes: classes,\n data: data,\n grabbable: grabbable,\n group: group,\n locked: locked,\n selectable: selectable,\n selected: selected,\n // Styling\n style: style\n };\n\n return edgeObject;\n }\n }, {\n key: 'handleCy',\n value: function handleCy(cy) {\n var _this2 = this;\n\n // If the cy pointer has not been modified, and handleCy has already\n // been called before, than we don't run this function.\n if (cy === this._cy && this._handleCyCalled) {\n return;\n }\n this._cy = cy;\n window.cy = cy;\n this._handleCyCalled = true;\n\n // ///////////////////////////////////// CONSTANTS /////////////////////////////////////////\n var SELECT_THRESHOLD = 100;\n\n var selectedNodes = cy.collection();\n var selectedEdges = cy.collection();\n\n // ///////////////////////////////////// FUNCTIONS /////////////////////////////////////////\n var refreshLayout = _lodash2.default.debounce(function () {\n /**\r\n * Refresh Layout if needed\r\n */\n var _props = _this2.props,\n autoRefreshLayout = _props.autoRefreshLayout,\n layout = _props.layout;\n\n\n if (autoRefreshLayout) {\n cy.layout(layout).run();\n }\n }, SELECT_THRESHOLD);\n\n var sendSelectedNodesData = _lodash2.default.debounce(function () {\n /**\r\n This function is repetitively called every time a node is selected\r\n or unselected, but keeps being debounced if it is called again\r\n within 100 ms (given by SELECT_THRESHOLD). Effectively, it only\r\n runs when all the nodes have been correctly selected/unselected and\r\n added/removed from the selectedNodes collection, and then updates\r\n the selectedNodeData prop.\r\n */\n var nodeData = selectedNodes.map(function (el) {\n return el.data();\n });\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n selectedNodeData: nodeData\n });\n }\n }, SELECT_THRESHOLD);\n\n var sendSelectedEdgesData = _lodash2.default.debounce(function () {\n var edgeData = selectedEdges.map(function (el) {\n return el.data();\n });\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n selectedEdgeData: edgeData\n });\n }\n }, SELECT_THRESHOLD);\n\n // /////////////////////////////////////// EVENTS //////////////////////////////////////////\n cy.on('tap', 'node', function (event) {\n var nodeObject = _this2.generateNode(event);\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n tapNode: nodeObject,\n tapNodeData: nodeObject.data\n });\n }\n });\n\n cy.on('tap', 'edge', function (event) {\n var edgeObject = _this2.generateEdge(event);\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n tapEdge: edgeObject,\n tapEdgeData: edgeObject.data\n });\n }\n });\n\n cy.on('mouseover', 'node', function (event) {\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n mouseoverNodeData: event.target.data()\n });\n }\n });\n\n cy.on('mouseover', 'edge', function (event) {\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n mouseoverEdgeData: event.target.data()\n });\n }\n });\n\n cy.on('select', 'node', function (event) {\n var ele = event.target;\n\n selectedNodes.merge(ele);\n sendSelectedNodesData();\n });\n\n cy.on('unselect remove', 'node', function (event) {\n var ele = event.target;\n\n selectedNodes.unmerge(ele);\n sendSelectedNodesData();\n });\n\n cy.on('select', 'edge', function (event) {\n var ele = event.target;\n\n selectedEdges.merge(ele);\n sendSelectedEdgesData();\n });\n\n cy.on('unselect remove', 'edge', function (event) {\n var ele = event.target;\n\n selectedEdges.unmerge(ele);\n sendSelectedEdgesData();\n });\n\n cy.on('add remove', function () {\n refreshLayout();\n });\n }\n }, {\n key: 'render',\n value: function render() {\n var _props2 = this.props,\n id = _props2.id,\n style = _props2.style,\n className = _props2.className,\n elements = _props2.elements,\n stylesheet = _props2.stylesheet,\n layout = _props2.layout,\n pan = _props2.pan,\n zoom = _props2.zoom,\n panningEnabled = _props2.panningEnabled,\n userPanningEnabled = _props2.userPanningEnabled,\n minZoom = _props2.minZoom,\n maxZoom = _props2.maxZoom,\n zoomingEnabled = _props2.zoomingEnabled,\n userZoomingEnabled = _props2.userZoomingEnabled,\n boxSelectionEnabled = _props2.boxSelectionEnabled,\n autoungrabify = _props2.autoungrabify,\n autolock = _props2.autolock,\n autounselectify = _props2.autounselectify;\n\n\n return _react2.default.createElement(_reactCytoscapejs2.default, {\n id: id,\n cy: this.handleCy,\n className: className,\n style: style,\n elements: _reactCytoscapejs2.default.normalizeElements(elements),\n stylesheet: stylesheet,\n layout: layout,\n pan: pan,\n zoom: zoom,\n panningEnabled: panningEnabled,\n userPanningEnabled: userPanningEnabled,\n minZoom: minZoom,\n maxZoom: maxZoom,\n zoomingEnabled: zoomingEnabled,\n userZoomingEnabled: userZoomingEnabled,\n boxSelectionEnabled: boxSelectionEnabled,\n autoungrabify: autoungrabify,\n autolock: autolock,\n autounselectify: autounselectify\n });\n }\n }]);\n\n return Cytoscape;\n}(_react.Component);\n\nCytoscape.propTypes = {\n // HTML attribute props\n\n /**\r\n * The ID used to identify this component in Dash callbacks.\r\n */\n id: _propTypes2.default.string,\n\n /**\r\n * Sets the class name of the element (the value of an element's html\r\n * class attribute).\r\n */\n className: _propTypes2.default.string,\n\n /**\r\n * Add inline styles to the root element.\r\n */\n style: _propTypes2.default.object,\n\n // Dash specific props\n\n /**\r\n * Dash-assigned callback that should be called whenever any of the\r\n * properties change.\r\n */\n setProps: _propTypes2.default.func,\n\n // Common props\n\n /**\r\n * A list of dictionaries representing the elements of the networks.\r\n * 1. Each dictionary describes an element, and specifies its purpose.\r\n * - `group` (string): Either 'nodes' or 'edges'. If not given, it's automatically inferred.\r\n * - `data` (dictionary): Element specific data.\r\n * - `id` (string): Reference to the element, useful for selectors and edges. Randomly assigned if not given.\r\n * - `label` (string): Optional name for the element, useful when `data(label)` is given to a style's `content` or `label`. It is only a convention.\r\n * - `parent` (string): Only for nodes. Optional reference to another node. Needed to create compound nodes.\r\n * - `source` (string): Only for edges. The id of the source node, which is where the edge starts.\r\n * - `target` (string): Only for edges. The id of the target node, where the edge ends.\r\n * - `position` (dictionary): Only for nodes. The position of the node.\r\n * - `x` (number): The x-coordinate of the node.\r\n * - `y` (number): The y-coordinate of the node.\r\n * - `selected` (boolean): If the element is selected upon initialisation.\r\n * - `selectable` (boolean): If the element can be selected.\r\n * - `locked` (boolean): Only for nodes. If the position is immutable.\r\n * - `grabbable` (boolean): Only for nodes. If the node can be grabbed and moved by the user.\r\n * - `classes` (string): Space separated string of class names of the element. Those classes can be selected by a style selector.\r\n *\r\n * 2. The [official Cytoscape.js documentation](http://js.cytoscape.org/#notation/elements-json) offers an extensive overview and examples of element declaration.\r\n */\n elements: _propTypes2.default.arrayOf(_propTypes2.default.object),\n\n /**\r\n * A list of dictionaries representing the styles of the elements.\r\n * 1. Each dictionary requires the following keys:\r\n * - `selector` (string): Which elements you are styling. Generally, you select a group of elements (node, edges, both), a class (that you declare in the element dictionary), or an element by ID.\r\n * - `style` (dictionary): What aspects of the elements you want to modify. This could be the size or color of a node, the shape of an edge arrow, or many more.\r\n *\r\n * 2. Both [the selector string](http://js.cytoscape.org/#selectors) and\r\n * [the style dictionary](http://js.cytoscape.org/#style/node-body) are\r\n * exhaustively documented in the Cytoscape.js docs. Although methods such\r\n * as `cy.elements(...)` and `cy.filter(...)` are not available, the selector\r\n * string syntax stays the same.\r\n */\n stylesheet: _propTypes2.default.arrayOf(_propTypes2.default.object),\n\n /**\r\n * A dictionary specifying how to set the position of the elements in your\r\n * graph. The `'name'` key is required, and indicates which layout (algorithm) to\r\n * use.\r\n * 1. The layouts available by default are:\r\n * - `random`: Randomly assigns positions\r\n * - `preset`: Assigns position based on the `position` key in element dictionaries\r\n * - `circle`: Single-level circle, with optional radius\r\n * - `concentric`: Multi-level circle, with optional radius\r\n * - `grid`: Square grid, optionally with numbers of `rows` and `cols`\r\n * - `breadthfirst`: Tree structure built using BFS, with optional `roots`\r\n * - `cose`: Force-directed physics simulation\r\n *\r\n * 2. Some external layouts are also included. To use them, run\r\n * `dash_cytoscape.load_extra_layouts()` before creating your Dash app. Be careful about\r\n * using the extra layouts when not necessary, since they require supplementary bandwidth\r\n * for loading, which impacts the startup time of the app.\r\n * - `cose-bilkent`: https://github.com/cytoscape/cytoscape.js-cose-bilkent\r\n * - `cola`: https://github.com/cytoscape/cytoscape.js-cola\r\n * - `euler`: https://github.com/cytoscape/cytoscape.js-dagre\r\n * - `spread`: https://github.com/cytoscape/cytoscape.js-spread\r\n * - `dagre`: https://github.com/cytoscape/cytoscape.js-dagre\r\n * - `klay`: https://github.com/cytoscape/cytoscape.js-klay\r\n *\r\n * 3. The keys accepted by `layout` vary depending on the algorithm, but some\r\n * keys are accepted by all layouts:\r\n * - `fit` (boolean): Whether to render the nodes in order to fit the canvas.\r\n * - `padding` (number): Padding around the sides of the canvas, if fit is enabled.\r\n * - `animate` (boolean): Whether to animate change in position when the layout changes.\r\n * - `animationDuration` (number): Duration of animation in milliseconds, if enabled.\r\n * - `boundingBox` (dictionary): How to constrain the layout in a specific area. Keys accepted are either `x1, y1, x2, y2` or `x1, y1, w, h`, all of which receive a pixel value.\r\n *\r\n * 4. The complete list of layouts and their accepted options are available\r\n * on the [Cytoscape.js docs](http://js.cytoscape.org/#layouts). For the\r\n * external layouts, the options are listed in the \"API\" section of the\r\n * README.\r\n * Note that certain keys are not supported in Dash since the value is a\r\n * JavaScript function or a callback. Please visit [this issue](https://github.com/plotly/dash-cytoscape/issues/25)\r\n * for more information.\r\n */\n layout: _propTypes2.default.object,\n\n // Viewport Manipulation\n\n /**\r\n * Dictionary indicating the initial panning position of the graph. The\r\n * following keys are accepted:\r\n * - `x` (number): The x-coordinate of the position.\r\n * - `y` (number): The y-coordinate of the position.\r\n */\n pan: _propTypes2.default.object,\n\n /**\r\n * The initial zoom level of the graph. You can set `minZoom` and\r\n * `maxZoom` to set restrictions on the zoom level.\r\n */\n zoom: _propTypes2.default.number,\n\n // Viewport Mutability and gesture Toggling\n /**\r\n * Whether panning the graph is enabled (i.e., the position of the graph is\r\n * mutable overall).\r\n */\n panningEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether user events (e.g. dragging the graph background) are allowed to\r\n * pan the graph.\r\n */\n userPanningEnabled: _propTypes2.default.bool,\n\n /**\r\n * A minimum bound on the zoom level of the graph. The viewport can not be\r\n * scaled smaller than this zoom level.\r\n */\n minZoom: _propTypes2.default.number,\n\n /**\r\n * A maximum bound on the zoom level of the graph. The viewport can not be\r\n * scaled larger than this zoom level.\r\n */\n maxZoom: _propTypes2.default.number,\n\n /**\r\n * Whether zooming the graph is enabled (i.e., the zoom level of the graph\r\n * is mutable overall).\r\n */\n zoomingEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether user events (e.g. dragging the graph background) are allowed\r\n * to pan the graph.\r\n */\n userZoomingEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether box selection (i.e. drag a box overlay around, and release it\r\n * to select) is enabled. If enabled, the user must taphold to pan the graph.\r\n */\n boxSelectionEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be ungrabified (not grabbable by user) by\r\n * default (if true, overrides individual node state).\r\n */\n autoungrabify: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be locked (not draggable at all) by default\r\n * (if true, overrides individual node state).\r\n */\n autolock: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be unselectified (immutable selection state) by\r\n * default (if true, overrides individual element state).\r\n */\n autounselectify: _propTypes2.default.bool,\n\n /**\r\n * Whether the layout should be refreshed when elements are added or removed.\r\n */\n autoRefreshLayout: _propTypes2.default.bool,\n\n // User Events Props\n\n /**\r\n * The complete node dictionary returned when you tap or click it. Read-only.\r\n *\r\n * 1. Node-specific items:\r\n * - `edgesData` (dictionary)\r\n * - `renderedPosition` (dictionary)\r\n * - `timeStamp` (number)\r\n *\r\n * 2. General items (for all elements):\r\n * - `classes` (string)\r\n * - `data` (dictionary)\r\n * - `grabbable` (boolean)\r\n * - `group` (string)\r\n * - `locked` (boolean)\r\n * - `position` (dictionary)\r\n * - `selectable` (boolean)\r\n * - `selected` (boolean)\r\n * - `style` (dictionary)\r\n *\r\n * 3. Items for compound nodes:\r\n * - `ancestorsData` (dictionary)\r\n * - `childrenData` (dictionary)\r\n * - `descendantsData` (dictionary)\r\n * - `parentData` (dictionary)\r\n * - `siblingsData` (dictionary)\r\n * - `isParent` (boolean)\r\n * - `isChildless` (boolean)\r\n * - `isChild` (boolean)\r\n * - `isOrphan` (boolean)\r\n * - `relativePosition` (dictionary)\r\n */\n tapNode: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of a node returned when you tap or click it. Read-only.\r\n */\n tapNodeData: _propTypes2.default.object,\n\n /**\r\n * The complete edge dictionary returned when you tap or click it. Read-only.\r\n *\r\n * 1. Edge-specific items:\r\n * - `isLoop` (boolean)\r\n * - `isSimple` (boolean)\r\n * - `midpoint` (dictionary)\r\n * - `sourceData` (dictionary)\r\n * - `sourceEndpoint` (dictionary)\r\n * - `targetData` (dictionary)\r\n * - `targetEndpoint` (dictionary)\r\n * - `timeStamp` (number)\r\n *\r\n * 2. General items (for all elements):\r\n * - `classes` (string)\r\n * - `data` (dictionary)\r\n * - `grabbable` (boolean)\r\n * - `group` (string)\r\n * - `locked` (boolean)\r\n * - `selectable` (boolean)\r\n * - `selected` (boolean)\r\n * - `style` (dictionary)\r\n */\n tapEdge: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of an edge returned when you tap or click it. Read-only.\r\n */\n tapEdgeData: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of a node returned when you hover over it. Read-only.\r\n */\n mouseoverNodeData: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of an edge returned when you hover over it. Read-only.\r\n */\n mouseoverEdgeData: _propTypes2.default.object,\n\n /**\r\n * The list of data dictionaries of all selected nodes (e.g. using\r\n * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n */\n selectedNodeData: _propTypes2.default.array,\n\n /**\r\n * The list of data dictionaries of all selected edges (e.g. using\r\n * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n */\n selectedEdgeData: _propTypes2.default.array\n};\n\nCytoscape.defaultProps = {\n style: { width: '600px', height: '600px' },\n layout: { name: 'grid' },\n pan: { x: 0, y: 0 },\n zoom: 1,\n minZoom: 1e-50,\n maxZoom: 1e50,\n zoomingEnabled: true,\n userZoomingEnabled: true,\n panningEnabled: true,\n userPanningEnabled: true,\n boxSelectionEnabled: false,\n autolock: false,\n autoungrabify: false,\n autounselectify: false,\n autoRefreshLayout: true\n};\n\nexports.default = Cytoscape;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_cytoscape/./src/lib/components/Cytoscape.react.js?642c"],"names":["Cytoscape","props","handleCy","bind","_handleCyCalled","event","ele","target","isParent","isChildless","isChild","isOrphan","renderedPosition","relativePosition","parent","style","edgesData","connectedEdges","map","data","childrenData","children","ancestorsData","ancestors","descendantsData","descendants","siblingsData","siblings","timeStamp","json","classes","grabbable","group","locked","position","selected","selectable","parentData","nodeObject","midpoint","isLoop","isSimple","sourceData","source","sourceEndpoint","targetData","targetEndpoint","edgeObject","cy","_cy","window","SELECT_THRESHOLD","selectedNodes","collection","selectedEdges","refreshLayout","_","debounce","autoRefreshLayout","layout","run","sendSelectedNodesData","nodeData","el","setProps","selectedNodeData","sendSelectedEdgesData","edgeData","selectedEdgeData","on","generateNode","tapNode","tapNodeData","generateEdge","tapEdge","tapEdgeData","mouseoverNodeData","mouseoverEdgeData","merge","unmerge","id","className","elements","stylesheet","pan","zoom","panningEnabled","userPanningEnabled","minZoom","maxZoom","zoomingEnabled","userZoomingEnabled","boxSelectionEnabled","autoungrabify","autolock","autounselectify","CytoscapeComponent","normalizeElements","Component","propTypes","PropTypes","string","object","func","arrayOf","number","bool","array","defaultProps","width","height","name","x","y"],"mappings":"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","file":"./src/lib/components/Cytoscape.react.js.js","sourcesContent":["/**\r\n * JavaScript Requirements: cytoscape\r\n * React.js requirements: react-cytoscapejs\r\n */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport CytoscapeComponent from 'react-cytoscapejs';\r\nimport _ from 'lodash';\r\n\r\n\r\n/**\r\nA Component Library for Dash aimed at facilitating network visualization in\r\nPython, wrapped around [Cytoscape.js](http://js.cytoscape.org/).\r\n */\r\nclass Cytoscape extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.handleCy = this.handleCy.bind(this);\r\n        this._handleCyCalled = false;\r\n    }\r\n\r\n    generateNode(event) {\r\n        const ele = event.target;\r\n\r\n        const isParent = ele.isParent(),\r\n            isChildless = ele.isChildless(),\r\n            isChild = ele.isChild(),\r\n            isOrphan = ele.isOrphan(),\r\n            renderedPosition = ele.renderedPosition(),\r\n            relativePosition = ele.relativePosition(),\r\n            parent = ele.parent(),\r\n            style = ele.style();\r\n\r\n        // Trim down the element objects to only the data contained\r\n        const edgesData = ele.connectedEdges().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            childrenData = ele.children().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            ancestorsData = ele.ancestors().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            descendantsData = ele.descendants().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            siblingsData = ele.siblings().map(ele => {\r\n                return ele.data()\r\n            });\r\n\r\n        const {timeStamp} = event;\r\n        const {\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            position,\r\n            selected,\r\n            selectable\r\n        } = ele.json();\r\n\r\n        let parentData;\r\n        if (parent) {\r\n            parentData = parent.data();\r\n        } else {\r\n            parentData = null;\r\n        }\r\n\r\n        const nodeObject = {\r\n            // Nodes attributes\r\n            edgesData,\r\n            renderedPosition,\r\n            timeStamp,\r\n            // From ele.json()\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            position,\r\n            selectable,\r\n            selected,\r\n            // Compound Nodes additional attributes\r\n            ancestorsData,\r\n            childrenData,\r\n            descendantsData,\r\n            parentData,\r\n            siblingsData,\r\n            isParent,\r\n            isChildless,\r\n            isChild,\r\n            isOrphan,\r\n            relativePosition,\r\n            // Styling\r\n            style\r\n        };\r\n        return nodeObject;\r\n    }\r\n\r\n\r\n    generateEdge(event) {\r\n        const ele = event.target;\r\n\r\n        const midpoint = ele.midpoint(),\r\n            isLoop = ele.isLoop(),\r\n            isSimple = ele.isSimple(),\r\n            sourceData = ele.source().data(),\r\n            sourceEndpoint = ele.sourceEndpoint(),\r\n            style = ele.style(),\r\n            targetData = ele.target().data(),\r\n            targetEndpoint = ele.targetEndpoint();\r\n\r\n        const {timeStamp} = event;\r\n        const {\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            selectable,\r\n            selected,\r\n        } = ele.json();\r\n\r\n        const edgeObject = {\r\n            // Edges attributes\r\n            isLoop,\r\n            isSimple,\r\n            midpoint,\r\n            sourceData,\r\n            sourceEndpoint,\r\n            targetData,\r\n            targetEndpoint,\r\n            timeStamp,\r\n            // From ele.json()\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            selectable,\r\n            selected,\r\n            // Styling\r\n            style\r\n        };\r\n\r\n        return edgeObject;\r\n    }\r\n\r\n    handleCy(cy) {\r\n        // If the cy pointer has not been modified, and handleCy has already\r\n        // been called before, than we don't run this function.\r\n        if (cy === this._cy && this._handleCyCalled) {\r\n            return;\r\n        }\r\n        this._cy = cy;\r\n        window.cy = cy;\r\n        this._handleCyCalled = true;\r\n\r\n        // ///////////////////////////////////// CONSTANTS /////////////////////////////////////////\r\n        const SELECT_THRESHOLD = 100;\r\n\r\n        const selectedNodes = cy.collection();\r\n        const selectedEdges = cy.collection();\r\n\r\n        // ///////////////////////////////////// FUNCTIONS /////////////////////////////////////////\r\n        const refreshLayout = _.debounce(() => {\r\n            /**\r\n             * Refresh Layout if needed\r\n             */\r\n            const {\r\n                autoRefreshLayout,\r\n                layout\r\n            } = this.props;\r\n\r\n            if (autoRefreshLayout) {\r\n                cy.layout(layout).run()\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        const sendSelectedNodesData = _.debounce(() => {\r\n            /**\r\n            This function is repetitively called every time a node is selected\r\n            or unselected, but keeps being debounced if it is called again\r\n            within 100 ms (given by SELECT_THRESHOLD). Effectively, it only\r\n            runs when all the nodes have been correctly selected/unselected and\r\n            added/removed from the selectedNodes collection, and then updates\r\n            the selectedNodeData prop.\r\n             */\r\n            const nodeData = selectedNodes.map(el => el.data());\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    selectedNodeData: nodeData\r\n                })\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        const sendSelectedEdgesData = _.debounce(() => {\r\n            const edgeData = selectedEdges.map(el => el.data());\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    selectedEdgeData: edgeData\r\n                })\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        // /////////////////////////////////////// EVENTS //////////////////////////////////////////\r\n        cy.on('tap', 'node', event => {\r\n            const nodeObject = this.generateNode(event);\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    tapNode: nodeObject,\r\n                    tapNodeData: nodeObject.data\r\n                });\r\n            }\r\n        });\r\n\r\n        cy.on('tap', 'edge', event => {\r\n            const edgeObject = this.generateEdge(event);\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    tapEdge: edgeObject,\r\n                    tapEdgeData: edgeObject.data\r\n                });\r\n            }\r\n        });\r\n\r\n        cy.on('mouseover', 'node', event => {\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    mouseoverNodeData: event.target.data()\r\n                })\r\n            }\r\n        });\r\n\r\n        cy.on('mouseover', 'edge', event => {\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    mouseoverEdgeData: event.target.data()\r\n                })\r\n            }\r\n        });\r\n\r\n        cy.on('select', 'node', event => {\r\n            const ele = event.target;\r\n\r\n            selectedNodes.merge(ele);\r\n            sendSelectedNodesData();\r\n        });\r\n\r\n        cy.on('unselect remove', 'node', event => {\r\n            const ele = event.target;\r\n\r\n            selectedNodes.unmerge(ele);\r\n            sendSelectedNodesData();\r\n        });\r\n\r\n        cy.on('select', 'edge', event => {\r\n            const ele = event.target;\r\n\r\n            selectedEdges.merge(ele);\r\n            sendSelectedEdgesData();\r\n        });\r\n\r\n        cy.on('unselect remove', 'edge', event => {\r\n            const ele = event.target;\r\n\r\n            selectedEdges.unmerge(ele);\r\n            sendSelectedEdgesData();\r\n        });\r\n\r\n        cy.on('add remove', () => {\r\n            refreshLayout();\r\n        });\r\n    }\r\n\r\n    render() {\r\n        const {\r\n            // HTML attribute props\r\n            id,\r\n            style,\r\n            className,\r\n            // Common props\r\n            elements,\r\n            stylesheet,\r\n            layout,\r\n            // Viewport Manipulation\r\n            pan,\r\n            zoom,\r\n            // Viewport Mutability and gesture Toggling\r\n            panningEnabled,\r\n            userPanningEnabled,\r\n            minZoom,\r\n            maxZoom,\r\n            zoomingEnabled,\r\n            userZoomingEnabled,\r\n            boxSelectionEnabled,\r\n            autoungrabify,\r\n            autolock,\r\n            autounselectify\r\n        } = this.props;\r\n\r\n        return (\r\n            <CytoscapeComponent\r\n                id={id}\r\n                cy={this.handleCy}\r\n                className={className}\r\n                style={style}\r\n                elements={CytoscapeComponent.normalizeElements(elements)}\r\n                stylesheet={stylesheet}\r\n                layout={layout}\r\n                pan={pan}\r\n                zoom={zoom}\r\n                panningEnabled={panningEnabled}\r\n                userPanningEnabled={userPanningEnabled}\r\n                minZoom={minZoom}\r\n                maxZoom={maxZoom}\r\n                zoomingEnabled={zoomingEnabled}\r\n                userZoomingEnabled={userZoomingEnabled}\r\n                boxSelectionEnabled={boxSelectionEnabled}\r\n                autoungrabify={autoungrabify}\r\n                autolock={autolock}\r\n                autounselectify={autounselectify}\r\n            />\r\n        )\r\n    }\r\n}\r\n\r\n\r\nCytoscape.propTypes = {\r\n    // HTML attribute props\r\n\r\n    /**\r\n     * The ID used to identify this component in Dash callbacks.\r\n     */\r\n    id: PropTypes.string,\r\n\r\n    /**\r\n     * Sets the class name of the element (the value of an element's html\r\n     * class attribute).\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Add inline styles to the root element.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    // Dash specific props\r\n\r\n    /**\r\n     * Dash-assigned callback that should be called whenever any of the\r\n     * properties change.\r\n     */\r\n    setProps: PropTypes.func,\r\n\r\n    // Common props\r\n\r\n    /**\r\n     * A list of dictionaries representing the elements of the networks.\r\n     *     1. Each dictionary describes an element, and specifies its purpose.\r\n     *         - `group` (string): Either 'nodes' or 'edges'. If not given, it's automatically inferred.\r\n     *         - `data` (dictionary): Element specific data.\r\n     *              - `id` (string): Reference to the element, useful for selectors and edges. Randomly assigned if not given.\r\n     *              - `label` (string): Optional name for the element, useful when `data(label)` is given to a style's `content` or `label`. It is only a convention.\r\n     *              - `parent` (string): Only for nodes. Optional reference to another node. Needed to create compound nodes.\r\n     *              - `source` (string): Only for edges. The id of the source node, which is where the edge starts.\r\n     *              - `target` (string): Only for edges. The id of the target node, where the edge ends.\r\n     *         - `position` (dictionary): Only for nodes. The position of the node.\r\n     *              - `x` (number): The x-coordinate of the node.\r\n     *              - `y` (number): The y-coordinate of the node.\r\n     *         - `selected` (boolean): If the element is selected upon initialisation.\r\n     *         - `selectable` (boolean): If the element can be selected.\r\n     *         - `locked` (boolean): Only for nodes. If the position is immutable.\r\n     *         - `grabbable` (boolean): Only for nodes. If the node can be grabbed and moved by the user.\r\n     *         - `classes` (string): Space separated string of class names of the element. Those classes can be selected by a style selector.\r\n     *\r\n     *     2. The [official Cytoscape.js documentation](http://js.cytoscape.org/#notation/elements-json) offers an extensive overview and examples of element declaration.\r\n     */\r\n    elements: PropTypes.arrayOf(PropTypes.object),\r\n\r\n    /**\r\n     * A list of dictionaries representing the styles of the elements.\r\n     *     1. Each dictionary requires the following keys:\r\n     *         - `selector` (string): Which elements you are styling. Generally, you select a group of elements (node, edges, both), a class (that you declare in the element dictionary), or an element by ID.\r\n     *         - `style` (dictionary): What aspects of the elements you want to modify. This could be the size or color of a node, the shape of an edge arrow, or many more.\r\n     *\r\n     *     2. Both [the selector string](http://js.cytoscape.org/#selectors) and\r\n     *     [the style dictionary](http://js.cytoscape.org/#style/node-body) are\r\n     *     exhaustively documented in the Cytoscape.js docs. Although methods such\r\n     *     as `cy.elements(...)` and `cy.filter(...)` are not available, the selector\r\n     *     string syntax stays the same.\r\n     */\r\n    stylesheet: PropTypes.arrayOf(PropTypes.object),\r\n\r\n    /**\r\n     * A dictionary specifying how to set the position of the elements in your\r\n     * graph. The `'name'` key is required, and indicates which layout (algorithm) to\r\n     * use.\r\n     *     1. The layouts available by default are:\r\n     *         - `random`: Randomly assigns positions\r\n     *         - `preset`: Assigns position based on the `position` key in element dictionaries\r\n     *         - `circle`: Single-level circle, with optional radius\r\n     *         - `concentric`: Multi-level circle, with optional radius\r\n     *         - `grid`: Square grid, optionally with numbers of `rows` and `cols`\r\n     *         - `breadthfirst`: Tree structure built using BFS, with optional `roots`\r\n     *         - `cose`: Force-directed physics simulation\r\n     *\r\n     *     2. Some external layouts are also included. To use them, run\r\n     *     `dash_cytoscape.load_extra_layouts()` before creating your Dash app. Be careful about\r\n     *     using the extra layouts when not necessary, since they require supplementary bandwidth\r\n     *     for loading, which impacts the startup time of the app.\r\n     *         - `cose-bilkent`: https://github.com/cytoscape/cytoscape.js-cose-bilkent\r\n     *         - `cola`: https://github.com/cytoscape/cytoscape.js-cola\r\n     *         - `euler`: https://github.com/cytoscape/cytoscape.js-dagre\r\n     *         - `spread`: https://github.com/cytoscape/cytoscape.js-spread\r\n     *         - `dagre`: https://github.com/cytoscape/cytoscape.js-dagre\r\n     *         - `klay`: https://github.com/cytoscape/cytoscape.js-klay\r\n     *\r\n     *     3. The keys accepted by `layout` vary depending on the algorithm, but some\r\n     *     keys are accepted by all layouts:\r\n     *         - `fit` (boolean): Whether to render the nodes in order to fit the canvas.\r\n     *         - `padding` (number): Padding around the sides of the canvas, if fit is enabled.\r\n     *         - `animate` (boolean): Whether to animate change in position when the layout changes.\r\n     *         - `animationDuration` (number): Duration of animation in milliseconds, if enabled.\r\n     *         - `boundingBox` (dictionary): How to constrain the layout in a specific area. Keys accepted are either `x1, y1, x2, y2` or `x1, y1, w, h`, all of which receive a pixel value.\r\n     *\r\n     *     4. The complete list of layouts and their accepted options are available\r\n     *     on the [Cytoscape.js docs](http://js.cytoscape.org/#layouts). For the\r\n     *     external layouts, the options are listed in the \"API\" section of the\r\n     *     README.\r\n     *     Note that certain keys are not supported in Dash since the value is a\r\n     *     JavaScript function or a callback. Please visit [this issue](https://github.com/plotly/dash-cytoscape/issues/25)\r\n     *     for more information.\r\n     */\r\n    layout: PropTypes.object,\r\n\r\n    // Viewport Manipulation\r\n\r\n    /**\r\n     * Dictionary indicating the initial panning position of the graph. The\r\n     * following keys are accepted:\r\n     *     - `x` (number): The x-coordinate of the position.\r\n     *     - `y` (number): The y-coordinate of the position.\r\n     */\r\n    pan: PropTypes.object,\r\n\r\n    /**\r\n     * The initial zoom level of the graph. You can set `minZoom` and\r\n     * `maxZoom` to set restrictions on the zoom level.\r\n     */\r\n    zoom: PropTypes.number,\r\n\r\n    // Viewport Mutability and gesture Toggling\r\n    /**\r\n     * Whether panning the graph is enabled (i.e., the position of the graph is\r\n     * mutable overall).\r\n     */\r\n    panningEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether user events (e.g. dragging the graph background) are allowed to\r\n     * pan the graph.\r\n     */\r\n    userPanningEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * A minimum bound on the zoom level of the graph. The viewport can not be\r\n     * scaled smaller than this zoom level.\r\n     */\r\n    minZoom: PropTypes.number,\r\n\r\n    /**\r\n     * A maximum bound on the zoom level of the graph. The viewport can not be\r\n     * scaled larger than this zoom level.\r\n     */\r\n    maxZoom: PropTypes.number,\r\n\r\n    /**\r\n     * Whether zooming the graph is enabled (i.e., the zoom level of the graph\r\n     * is mutable overall).\r\n     */\r\n    zoomingEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether user events (e.g. dragging the graph background) are allowed\r\n     * to pan the graph.\r\n     */\r\n    userZoomingEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether box selection (i.e. drag a box overlay around, and release it\r\n     * to select) is enabled. If enabled, the user must taphold to pan the graph.\r\n     */\r\n    boxSelectionEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be ungrabified (not grabbable by user) by\r\n     * default (if true, overrides individual node state).\r\n     */\r\n    autoungrabify: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be locked (not draggable at all) by default\r\n     * (if true, overrides individual node state).\r\n     */\r\n    autolock: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be unselectified (immutable selection state) by\r\n     * default (if true, overrides individual element state).\r\n     */\r\n    autounselectify: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether the layout should be refreshed when elements are added or removed.\r\n     */\r\n    autoRefreshLayout: PropTypes.bool,\r\n\r\n    // User Events Props\r\n\r\n    /**\r\n     * The complete node dictionary returned when you tap or click it. Read-only.\r\n     *\r\n     *     1. Node-specific items:\r\n     *         - `edgesData` (dictionary)\r\n     *         - `renderedPosition` (dictionary)\r\n     *         - `timeStamp` (number)\r\n     *\r\n     *     2. General items (for all elements):\r\n     *         - `classes` (string)\r\n     *         - `data` (dictionary)\r\n     *         - `grabbable` (boolean)\r\n     *         - `group` (string)\r\n     *         - `locked` (boolean)\r\n     *         - `position` (dictionary)\r\n     *         - `selectable` (boolean)\r\n     *         - `selected` (boolean)\r\n     *         - `style` (dictionary)\r\n     *\r\n     *     3. Items for compound nodes:\r\n     *         - `ancestorsData` (dictionary)\r\n     *         - `childrenData` (dictionary)\r\n     *         - `descendantsData` (dictionary)\r\n     *         - `parentData` (dictionary)\r\n     *         - `siblingsData` (dictionary)\r\n     *         - `isParent` (boolean)\r\n     *         - `isChildless` (boolean)\r\n     *         - `isChild` (boolean)\r\n     *         - `isOrphan` (boolean)\r\n     *         - `relativePosition` (dictionary)\r\n     */\r\n    tapNode: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of a node returned when you tap or click it. Read-only.\r\n     */\r\n    tapNodeData: PropTypes.object,\r\n\r\n    /**\r\n     * The complete edge dictionary returned when you tap or click it. Read-only.\r\n     *\r\n     *     1. Edge-specific items:\r\n     *         - `isLoop` (boolean)\r\n     *         - `isSimple` (boolean)\r\n     *         - `midpoint` (dictionary)\r\n     *         - `sourceData` (dictionary)\r\n     *         - `sourceEndpoint` (dictionary)\r\n     *         - `targetData` (dictionary)\r\n     *         - `targetEndpoint` (dictionary)\r\n     *         - `timeStamp` (number)\r\n     *\r\n     *     2. General items (for all elements):\r\n     *         - `classes` (string)\r\n     *         - `data` (dictionary)\r\n     *         - `grabbable` (boolean)\r\n     *         - `group` (string)\r\n     *         - `locked` (boolean)\r\n     *         - `selectable` (boolean)\r\n     *         - `selected` (boolean)\r\n     *         - `style` (dictionary)\r\n     */\r\n    tapEdge: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of an edge returned when you tap or click it. Read-only.\r\n     */\r\n    tapEdgeData: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of a node returned when you hover over it. Read-only.\r\n     */\r\n    mouseoverNodeData: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of an edge returned when you hover over it. Read-only.\r\n     */\r\n    mouseoverEdgeData: PropTypes.object,\r\n\r\n    /**\r\n     * The list of data dictionaries of all selected nodes (e.g. using\r\n     * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n     */\r\n    selectedNodeData: PropTypes.array,\r\n\r\n    /**\r\n     * The list of data dictionaries of all selected edges (e.g. using\r\n     * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n     */\r\n    selectedEdgeData: PropTypes.array\r\n};\r\n\r\nCytoscape.defaultProps = {\r\n    style: {width: '600px', height: '600px'},\r\n    layout: {name: 'grid'},\r\n    pan: {x: 0, y: 0},\r\n    zoom: 1,\r\n    minZoom: 1e-50,\r\n    maxZoom: 1e50,\r\n    zoomingEnabled: true,\r\n    userZoomingEnabled: true,\r\n    panningEnabled: true,\r\n    userPanningEnabled: true,\r\n    boxSelectionEnabled: false,\r\n    autolock: false,\r\n    autoungrabify: false,\r\n    autounselectify: false,\r\n    autoRefreshLayout: true\r\n};\r\n\r\nexport default Cytoscape;"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/lib/components/Cytoscape.react.js\n"); +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar _propTypes2 = _interopRequireDefault(_propTypes);\n\nvar _reactCytoscapejs = __webpack_require__(/*! react-cytoscapejs */ \"./node_modules/react-cytoscapejs/dist/react-cytoscape.js\");\n\nvar _reactCytoscapejs2 = _interopRequireDefault(_reactCytoscapejs);\n\nvar _lodash = __webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\");\n\nvar _lodash2 = _interopRequireDefault(_lodash);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /**\r\n * JavaScript Requirements: cytoscape\r\n * React.js requirements: react-cytoscapejs\r\n */\n\n\n/**\r\nA Component Library for Dash aimed at facilitating network visualization in\r\nPython, wrapped around [Cytoscape.js](http://js.cytoscape.org/).\r\n */\nvar Cytoscape = function (_Component) {\n _inherits(Cytoscape, _Component);\n\n function Cytoscape(props) {\n _classCallCheck(this, Cytoscape);\n\n var _this = _possibleConstructorReturn(this, (Cytoscape.__proto__ || Object.getPrototypeOf(Cytoscape)).call(this, props));\n\n _this.handleCy = _this.handleCy.bind(_this);\n _this._handleCyCalled = false;\n return _this;\n }\n\n _createClass(Cytoscape, [{\n key: 'generateNode',\n value: function generateNode(event) {\n var ele = event.target;\n\n var isParent = ele.isParent(),\n isChildless = ele.isChildless(),\n isChild = ele.isChild(),\n isOrphan = ele.isOrphan(),\n renderedPosition = ele.renderedPosition(),\n relativePosition = ele.relativePosition(),\n parent = ele.parent(),\n style = ele.style();\n\n // Trim down the element objects to only the data contained\n var edgesData = ele.connectedEdges().map(function (ele) {\n return ele.data();\n }),\n childrenData = ele.children().map(function (ele) {\n return ele.data();\n }),\n ancestorsData = ele.ancestors().map(function (ele) {\n return ele.data();\n }),\n descendantsData = ele.descendants().map(function (ele) {\n return ele.data();\n }),\n siblingsData = ele.siblings().map(function (ele) {\n return ele.data();\n });\n\n var timeStamp = event.timeStamp;\n\n var _ele$json = ele.json(),\n classes = _ele$json.classes,\n data = _ele$json.data,\n grabbable = _ele$json.grabbable,\n group = _ele$json.group,\n locked = _ele$json.locked,\n position = _ele$json.position,\n selected = _ele$json.selected,\n selectable = _ele$json.selectable;\n\n var parentData = void 0;\n if (parent) {\n parentData = parent.data();\n } else {\n parentData = null;\n }\n\n var nodeObject = {\n // Nodes attributes\n edgesData: edgesData,\n renderedPosition: renderedPosition,\n timeStamp: timeStamp,\n // From ele.json()\n classes: classes,\n data: data,\n grabbable: grabbable,\n group: group,\n locked: locked,\n position: position,\n selectable: selectable,\n selected: selected,\n // Compound Nodes additional attributes\n ancestorsData: ancestorsData,\n childrenData: childrenData,\n descendantsData: descendantsData,\n parentData: parentData,\n siblingsData: siblingsData,\n isParent: isParent,\n isChildless: isChildless,\n isChild: isChild,\n isOrphan: isOrphan,\n relativePosition: relativePosition,\n // Styling\n style: style\n };\n return nodeObject;\n }\n }, {\n key: 'generateEdge',\n value: function generateEdge(event) {\n var ele = event.target;\n\n var midpoint = ele.midpoint(),\n isLoop = ele.isLoop(),\n isSimple = ele.isSimple(),\n sourceData = ele.source().data(),\n sourceEndpoint = ele.sourceEndpoint(),\n style = ele.style(),\n targetData = ele.target().data(),\n targetEndpoint = ele.targetEndpoint();\n\n var timeStamp = event.timeStamp;\n\n var _ele$json2 = ele.json(),\n classes = _ele$json2.classes,\n data = _ele$json2.data,\n grabbable = _ele$json2.grabbable,\n group = _ele$json2.group,\n locked = _ele$json2.locked,\n selectable = _ele$json2.selectable,\n selected = _ele$json2.selected;\n\n var edgeObject = {\n // Edges attributes\n isLoop: isLoop,\n isSimple: isSimple,\n midpoint: midpoint,\n sourceData: sourceData,\n sourceEndpoint: sourceEndpoint,\n targetData: targetData,\n targetEndpoint: targetEndpoint,\n timeStamp: timeStamp,\n // From ele.json()\n classes: classes,\n data: data,\n grabbable: grabbable,\n group: group,\n locked: locked,\n selectable: selectable,\n selected: selected,\n // Styling\n style: style\n };\n\n return edgeObject;\n }\n }, {\n key: 'handleCy',\n value: function handleCy(cy) {\n var _this2 = this;\n\n // If the cy pointer has not been modified, and handleCy has already\n // been called before, than we don't run this function.\n if (cy === this._cy && this._handleCyCalled) {\n return;\n }\n this._cy = cy;\n window.cy = cy;\n this._handleCyCalled = true;\n\n // ///////////////////////////////////// CONSTANTS /////////////////////////////////////////\n var SELECT_THRESHOLD = 100;\n\n var selectedNodes = cy.collection();\n var selectedEdges = cy.collection();\n\n // ///////////////////////////////////// FUNCTIONS /////////////////////////////////////////\n var refreshLayout = _lodash2.default.debounce(function () {\n /**\r\n * Refresh Layout if needed\r\n */\n var _props = _this2.props,\n autoRefreshLayout = _props.autoRefreshLayout,\n layout = _props.layout;\n\n\n if (autoRefreshLayout) {\n cy.layout(layout).run();\n }\n }, SELECT_THRESHOLD);\n\n var sendSelectedNodesData = _lodash2.default.debounce(function () {\n /**\r\n This function is repetitively called every time a node is selected\r\n or unselected, but keeps being debounced if it is called again\r\n within 100 ms (given by SELECT_THRESHOLD). Effectively, it only\r\n runs when all the nodes have been correctly selected/unselected and\r\n added/removed from the selectedNodes collection, and then updates\r\n the selectedNodeData prop.\r\n */\n var nodeData = selectedNodes.map(function (el) {\n return el.data();\n });\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n selectedNodeData: nodeData\n });\n }\n }, SELECT_THRESHOLD);\n\n var sendSelectedEdgesData = _lodash2.default.debounce(function () {\n var edgeData = selectedEdges.map(function (el) {\n return el.data();\n });\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n selectedEdgeData: edgeData\n });\n }\n }, SELECT_THRESHOLD);\n\n // /////////////////////////////////////// EVENTS //////////////////////////////////////////\n cy.on('tap', 'node', function (event) {\n var nodeObject = _this2.generateNode(event);\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n tapNode: nodeObject,\n tapNodeData: nodeObject.data\n });\n }\n });\n\n cy.on('tap', 'edge', function (event) {\n var edgeObject = _this2.generateEdge(event);\n\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n tapEdge: edgeObject,\n tapEdgeData: edgeObject.data\n });\n }\n });\n\n cy.on('mouseover', 'node', function (event) {\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n mouseoverNodeData: event.target.data()\n });\n }\n });\n\n cy.on('mouseover', 'edge', function (event) {\n if (typeof _this2.props.setProps === 'function') {\n _this2.props.setProps({\n mouseoverEdgeData: event.target.data()\n });\n }\n });\n\n cy.on('select', 'node', function (event) {\n var ele = event.target;\n\n selectedNodes.merge(ele);\n sendSelectedNodesData();\n });\n\n cy.on('unselect remove', 'node', function (event) {\n var ele = event.target;\n\n selectedNodes.unmerge(ele);\n sendSelectedNodesData();\n });\n\n cy.on('select', 'edge', function (event) {\n var ele = event.target;\n\n selectedEdges.merge(ele);\n sendSelectedEdgesData();\n });\n\n cy.on('unselect remove', 'edge', function (event) {\n var ele = event.target;\n\n selectedEdges.unmerge(ele);\n sendSelectedEdgesData();\n });\n\n cy.on('add remove', function () {\n refreshLayout();\n });\n }\n }, {\n key: 'render',\n value: function render() {\n var _props2 = this.props,\n id = _props2.id,\n style = _props2.style,\n className = _props2.className,\n elements = _props2.elements,\n stylesheet = _props2.stylesheet,\n layout = _props2.layout,\n pan = _props2.pan,\n zoom = _props2.zoom,\n panningEnabled = _props2.panningEnabled,\n userPanningEnabled = _props2.userPanningEnabled,\n minZoom = _props2.minZoom,\n maxZoom = _props2.maxZoom,\n zoomingEnabled = _props2.zoomingEnabled,\n userZoomingEnabled = _props2.userZoomingEnabled,\n boxSelectionEnabled = _props2.boxSelectionEnabled,\n autoungrabify = _props2.autoungrabify,\n autolock = _props2.autolock,\n autounselectify = _props2.autounselectify;\n\n\n return _react2.default.createElement(_reactCytoscapejs2.default, {\n id: id,\n cy: this.handleCy,\n className: className,\n style: style,\n elements: _reactCytoscapejs2.default.normalizeElements(elements),\n stylesheet: stylesheet,\n layout: layout,\n pan: pan,\n zoom: zoom,\n panningEnabled: panningEnabled,\n userPanningEnabled: userPanningEnabled,\n minZoom: minZoom,\n maxZoom: maxZoom,\n zoomingEnabled: zoomingEnabled,\n userZoomingEnabled: userZoomingEnabled,\n boxSelectionEnabled: boxSelectionEnabled,\n autoungrabify: autoungrabify,\n autolock: autolock,\n autounselectify: autounselectify\n });\n }\n }]);\n\n return Cytoscape;\n}(_react.Component);\n\nCytoscape.propTypes = {\n // HTML attribute props\n\n /**\r\n * The ID used to identify this component in Dash callbacks.\r\n */\n id: _propTypes2.default.string,\n\n /**\r\n * Sets the class name of the element (the value of an element's html\r\n * class attribute).\r\n */\n className: _propTypes2.default.string,\n\n /**\r\n * Add inline styles to the root element.\r\n */\n style: _propTypes2.default.object,\n\n // Dash specific props\n\n /**\r\n * Dash-assigned callback that should be called whenever any of the\r\n * properties change.\r\n */\n setProps: _propTypes2.default.func,\n\n // Common props\n\n /**\r\n * A list of dictionaries representing the elements of the networks.\r\n * 1. Each dictionary describes an element, and specifies its purpose.\r\n * - `group` (string): Either 'nodes' or 'edges'. If not given, it's automatically inferred.\r\n * - `data` (dictionary): Element specific data.\r\n * - `id` (string): Reference to the element, useful for selectors and edges. Randomly assigned if not given.\r\n * - `label` (string): Optional name for the element, useful when `data(label)` is given to a style's `content` or `label`. It is only a convention.\r\n * - `parent` (string): Only for nodes. Optional reference to another node. Needed to create compound nodes.\r\n * - `source` (string): Only for edges. The id of the source node, which is where the edge starts.\r\n * - `target` (string): Only for edges. The id of the target node, where the edge ends.\r\n * - `position` (dictionary): Only for nodes. The position of the node.\r\n * - `x` (number): The x-coordinate of the node.\r\n * - `y` (number): The y-coordinate of the node.\r\n * - `selected` (boolean): If the element is selected upon initialisation.\r\n * - `selectable` (boolean): If the element can be selected.\r\n * - `locked` (boolean): Only for nodes. If the position is immutable.\r\n * - `grabbable` (boolean): Only for nodes. If the node can be grabbed and moved by the user.\r\n * - `classes` (string): Space separated string of class names of the element. Those classes can be selected by a style selector.\r\n *\r\n * 2. The [official Cytoscape.js documentation](http://js.cytoscape.org/#notation/elements-json) offers an extensive overview and examples of element declaration.\r\n */\n elements: _propTypes2.default.arrayOf(_propTypes2.default.object),\n\n /**\r\n * A list of dictionaries representing the styles of the elements.\r\n * 1. Each dictionary requires the following keys:\r\n * - `selector` (string): Which elements you are styling. Generally, you select a group of elements (node, edges, both), a class (that you declare in the element dictionary), or an element by ID.\r\n * - `style` (dictionary): What aspects of the elements you want to modify. This could be the size or color of a node, the shape of an edge arrow, or many more.\r\n *\r\n * 2. Both [the selector string](http://js.cytoscape.org/#selectors) and\r\n * [the style dictionary](http://js.cytoscape.org/#style/node-body) are\r\n * exhaustively documented in the Cytoscape.js docs. Although methods such\r\n * as `cy.elements(...)` and `cy.filter(...)` are not available, the selector\r\n * string syntax stays the same.\r\n */\n stylesheet: _propTypes2.default.arrayOf(_propTypes2.default.object),\n\n /**\r\n * A dictionary specifying how to set the position of the elements in your\r\n * graph. The `'name'` key is required, and indicates which layout (algorithm) to\r\n * use.\r\n * 1. The layouts available by default are:\r\n * - `random`: Randomly assigns positions\r\n * - `preset`: Assigns position based on the `position` key in element dictionaries\r\n * - `circle`: Single-level circle, with optional radius\r\n * - `concentric`: Multi-level circle, with optional radius\r\n * - `grid`: Square grid, optionally with numbers of `rows` and `cols`\r\n * - `breadthfirst`: Tree structure built using BFS, with optional `roots`\r\n * - `cose`: Force-directed physics simulation\r\n *\r\n * 2. Some external layouts are also included. To use them, run\r\n * `dash_cytoscape.load_extra_layouts()` before creating your Dash app. Be careful about\r\n * using the extra layouts when not necessary, since they require supplementary bandwidth\r\n * for loading, which impacts the startup time of the app.\r\n * - `cose-bilkent`: https://github.com/cytoscape/cytoscape.js-cose-bilkent\r\n * - `cola`: https://github.com/cytoscape/cytoscape.js-cola\r\n * - `euler`: https://github.com/cytoscape/cytoscape.js-dagre\r\n * - `spread`: https://github.com/cytoscape/cytoscape.js-spread\r\n * - `dagre`: https://github.com/cytoscape/cytoscape.js-dagre\r\n * - `klay`: https://github.com/cytoscape/cytoscape.js-klay\r\n *\r\n * 3. The keys accepted by `layout` vary depending on the algorithm, but some\r\n * keys are accepted by all layouts:\r\n * - `fit` (boolean): Whether to render the nodes in order to fit the canvas.\r\n * - `padding` (number): Padding around the sides of the canvas, if fit is enabled.\r\n * - `animate` (boolean): Whether to animate change in position when the layout changes.\r\n * - `animationDuration` (number): Duration of animation in milliseconds, if enabled.\r\n * - `boundingBox` (dictionary): How to constrain the layout in a specific area. Keys accepted are either `x1, y1, x2, y2` or `x1, y1, w, h`, all of which receive a pixel value.\r\n *\r\n * 4. The complete list of layouts and their accepted options are available\r\n * on the [Cytoscape.js docs](http://js.cytoscape.org/#layouts). For the\r\n * external layouts, the options are listed in the \"API\" section of the\r\n * README.\r\n * Note that certain keys are not supported in Dash since the value is a\r\n * JavaScript function or a callback. Please visit [this issue](https://github.com/plotly/dash-cytoscape/issues/25)\r\n * for more information.\r\n */\n layout: _propTypes2.default.object,\n\n // Viewport Manipulation\n\n /**\r\n * Dictionary indicating the initial panning position of the graph. The\r\n * following keys are accepted:\r\n * - `x` (number): The x-coordinate of the position.\r\n * - `y` (number): The y-coordinate of the position.\r\n */\n pan: _propTypes2.default.object,\n\n /**\r\n * The initial zoom level of the graph. You can set `minZoom` and\r\n * `maxZoom` to set restrictions on the zoom level.\r\n */\n zoom: _propTypes2.default.number,\n\n // Viewport Mutability and gesture Toggling\n /**\r\n * Whether panning the graph is enabled (i.e., the position of the graph is\r\n * mutable overall).\r\n */\n panningEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether user events (e.g. dragging the graph background) are allowed to\r\n * pan the graph.\r\n */\n userPanningEnabled: _propTypes2.default.bool,\n\n /**\r\n * A minimum bound on the zoom level of the graph. The viewport can not be\r\n * scaled smaller than this zoom level.\r\n */\n minZoom: _propTypes2.default.number,\n\n /**\r\n * A maximum bound on the zoom level of the graph. The viewport can not be\r\n * scaled larger than this zoom level.\r\n */\n maxZoom: _propTypes2.default.number,\n\n /**\r\n * Whether zooming the graph is enabled (i.e., the zoom level of the graph\r\n * is mutable overall).\r\n */\n zoomingEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether user events (e.g. dragging the graph background) are allowed\r\n * to pan the graph.\r\n */\n userZoomingEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether box selection (i.e. drag a box overlay around, and release it\r\n * to select) is enabled. If enabled, the user must taphold to pan the graph.\r\n */\n boxSelectionEnabled: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be ungrabified (not grabbable by user) by\r\n * default (if true, overrides individual node state).\r\n */\n autoungrabify: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be locked (not draggable at all) by default\r\n * (if true, overrides individual node state).\r\n */\n autolock: _propTypes2.default.bool,\n\n /**\r\n * Whether nodes should be unselectified (immutable selection state) by\r\n * default (if true, overrides individual element state).\r\n */\n autounselectify: _propTypes2.default.bool,\n\n /**\r\n * Whether the layout should be refreshed when elements are added or removed.\r\n */\n autoRefreshLayout: _propTypes2.default.bool,\n\n // User Events Props\n\n /**\r\n * The complete node dictionary returned when you tap or click it. Read-only.\r\n *\r\n * 1. Node-specific items:\r\n * - `edgesData` (dictionary)\r\n * - `renderedPosition` (dictionary)\r\n * - `timeStamp` (number)\r\n *\r\n * 2. General items (for all elements):\r\n * - `classes` (string)\r\n * - `data` (dictionary)\r\n * - `grabbable` (boolean)\r\n * - `group` (string)\r\n * - `locked` (boolean)\r\n * - `position` (dictionary)\r\n * - `selectable` (boolean)\r\n * - `selected` (boolean)\r\n * - `style` (dictionary)\r\n *\r\n * 3. Items for compound nodes:\r\n * - `ancestorsData` (dictionary)\r\n * - `childrenData` (dictionary)\r\n * - `descendantsData` (dictionary)\r\n * - `parentData` (dictionary)\r\n * - `siblingsData` (dictionary)\r\n * - `isParent` (boolean)\r\n * - `isChildless` (boolean)\r\n * - `isChild` (boolean)\r\n * - `isOrphan` (boolean)\r\n * - `relativePosition` (dictionary)\r\n */\n tapNode: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of a node returned when you tap or click it. Read-only.\r\n */\n tapNodeData: _propTypes2.default.object,\n\n /**\r\n * The complete edge dictionary returned when you tap or click it. Read-only.\r\n *\r\n * 1. Edge-specific items:\r\n * - `isLoop` (boolean)\r\n * - `isSimple` (boolean)\r\n * - `midpoint` (dictionary)\r\n * - `sourceData` (dictionary)\r\n * - `sourceEndpoint` (dictionary)\r\n * - `targetData` (dictionary)\r\n * - `targetEndpoint` (dictionary)\r\n * - `timeStamp` (number)\r\n *\r\n * 2. General items (for all elements):\r\n * - `classes` (string)\r\n * - `data` (dictionary)\r\n * - `grabbable` (boolean)\r\n * - `group` (string)\r\n * - `locked` (boolean)\r\n * - `selectable` (boolean)\r\n * - `selected` (boolean)\r\n * - `style` (dictionary)\r\n */\n tapEdge: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of an edge returned when you tap or click it. Read-only.\r\n */\n tapEdgeData: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of a node returned when you hover over it. Read-only.\r\n */\n mouseoverNodeData: _propTypes2.default.object,\n\n /**\r\n * The data dictionary of an edge returned when you hover over it. Read-only.\r\n */\n mouseoverEdgeData: _propTypes2.default.object,\n\n /**\r\n * The list of data dictionaries of all selected nodes (e.g. using\r\n * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n */\n selectedNodeData: _propTypes2.default.array,\n\n /**\r\n * The list of data dictionaries of all selected edges (e.g. using\r\n * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n */\n selectedEdgeData: _propTypes2.default.array\n};\n\nCytoscape.defaultProps = {\n style: { width: '600px', height: '600px' },\n layout: { name: 'grid' },\n pan: { x: 0, y: 0 },\n zoom: 1,\n minZoom: 1e-50,\n maxZoom: 1e50,\n zoomingEnabled: true,\n userZoomingEnabled: true,\n panningEnabled: true,\n userPanningEnabled: true,\n boxSelectionEnabled: false,\n autolock: false,\n autoungrabify: false,\n autounselectify: false,\n autoRefreshLayout: true\n};\n\nexports.default = Cytoscape;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_cytoscape/./src/lib/components/Cytoscape.react.js?642c"],"names":["Cytoscape","props","handleCy","bind","_handleCyCalled","event","ele","target","isParent","isChildless","isChild","isOrphan","renderedPosition","relativePosition","parent","style","edgesData","connectedEdges","map","data","childrenData","children","ancestorsData","ancestors","descendantsData","descendants","siblingsData","siblings","timeStamp","json","classes","grabbable","group","locked","position","selected","selectable","parentData","nodeObject","midpoint","isLoop","isSimple","sourceData","source","sourceEndpoint","targetData","targetEndpoint","edgeObject","cy","_cy","window","SELECT_THRESHOLD","selectedNodes","collection","selectedEdges","refreshLayout","_","debounce","autoRefreshLayout","layout","run","sendSelectedNodesData","nodeData","el","setProps","selectedNodeData","sendSelectedEdgesData","edgeData","selectedEdgeData","on","generateNode","tapNode","tapNodeData","generateEdge","tapEdge","tapEdgeData","mouseoverNodeData","mouseoverEdgeData","merge","unmerge","id","className","elements","stylesheet","pan","zoom","panningEnabled","userPanningEnabled","minZoom","maxZoom","zoomingEnabled","userZoomingEnabled","boxSelectionEnabled","autoungrabify","autolock","autounselectify","CytoscapeComponent","normalizeElements","Component","propTypes","PropTypes","string","object","func","arrayOf","number","bool","array","defaultProps","width","height","name","x","y"],"mappings":"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","file":"./src/lib/components/Cytoscape.react.js.js","sourcesContent":["/**\r\n * JavaScript Requirements: cytoscape\r\n * React.js requirements: react-cytoscapejs\r\n */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport CytoscapeComponent from 'react-cytoscapejs';\r\nimport _ from 'lodash';\r\n\r\n\r\n/**\r\nA Component Library for Dash aimed at facilitating network visualization in\r\nPython, wrapped around [Cytoscape.js](http://js.cytoscape.org/).\r\n */\r\nclass Cytoscape extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.handleCy = this.handleCy.bind(this);\r\n        this._handleCyCalled = false;\r\n    }\r\n\r\n    generateNode(event) {\r\n        const ele = event.target;\r\n\r\n        const isParent = ele.isParent(),\r\n            isChildless = ele.isChildless(),\r\n            isChild = ele.isChild(),\r\n            isOrphan = ele.isOrphan(),\r\n            renderedPosition = ele.renderedPosition(),\r\n            relativePosition = ele.relativePosition(),\r\n            parent = ele.parent(),\r\n            style = ele.style();\r\n\r\n        // Trim down the element objects to only the data contained\r\n        const edgesData = ele.connectedEdges().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            childrenData = ele.children().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            ancestorsData = ele.ancestors().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            descendantsData = ele.descendants().map(ele => {\r\n                return ele.data()\r\n            }),\r\n            siblingsData = ele.siblings().map(ele => {\r\n                return ele.data()\r\n            });\r\n\r\n        const {timeStamp} = event;\r\n        const {\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            position,\r\n            selected,\r\n            selectable\r\n        } = ele.json();\r\n\r\n        let parentData;\r\n        if (parent) {\r\n            parentData = parent.data();\r\n        } else {\r\n            parentData = null;\r\n        }\r\n\r\n        const nodeObject = {\r\n            // Nodes attributes\r\n            edgesData,\r\n            renderedPosition,\r\n            timeStamp,\r\n            // From ele.json()\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            position,\r\n            selectable,\r\n            selected,\r\n            // Compound Nodes additional attributes\r\n            ancestorsData,\r\n            childrenData,\r\n            descendantsData,\r\n            parentData,\r\n            siblingsData,\r\n            isParent,\r\n            isChildless,\r\n            isChild,\r\n            isOrphan,\r\n            relativePosition,\r\n            // Styling\r\n            style\r\n        };\r\n        return nodeObject;\r\n    }\r\n\r\n\r\n    generateEdge(event) {\r\n        const ele = event.target;\r\n\r\n        const midpoint = ele.midpoint(),\r\n            isLoop = ele.isLoop(),\r\n            isSimple = ele.isSimple(),\r\n            sourceData = ele.source().data(),\r\n            sourceEndpoint = ele.sourceEndpoint(),\r\n            style = ele.style(),\r\n            targetData = ele.target().data(),\r\n            targetEndpoint = ele.targetEndpoint();\r\n\r\n        const {timeStamp} = event;\r\n        const {\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            selectable,\r\n            selected,\r\n        } = ele.json();\r\n\r\n        const edgeObject = {\r\n            // Edges attributes\r\n            isLoop,\r\n            isSimple,\r\n            midpoint,\r\n            sourceData,\r\n            sourceEndpoint,\r\n            targetData,\r\n            targetEndpoint,\r\n            timeStamp,\r\n            // From ele.json()\r\n            classes,\r\n            data,\r\n            grabbable,\r\n            group,\r\n            locked,\r\n            selectable,\r\n            selected,\r\n            // Styling\r\n            style\r\n        };\r\n\r\n        return edgeObject;\r\n    }\r\n\r\n    handleCy(cy) {\r\n        // If the cy pointer has not been modified, and handleCy has already\r\n        // been called before, than we don't run this function.\r\n        if (cy === this._cy && this._handleCyCalled) {\r\n            return;\r\n        }\r\n        this._cy = cy;\r\n        window.cy = cy;\r\n        this._handleCyCalled = true;\r\n\r\n        // ///////////////////////////////////// CONSTANTS /////////////////////////////////////////\r\n        const SELECT_THRESHOLD = 100;\r\n\r\n        const selectedNodes = cy.collection();\r\n        const selectedEdges = cy.collection();\r\n\r\n        // ///////////////////////////////////// FUNCTIONS /////////////////////////////////////////\r\n        const refreshLayout = _.debounce(() => {\r\n            /**\r\n             * Refresh Layout if needed\r\n             */\r\n            const {\r\n                autoRefreshLayout,\r\n                layout\r\n            } = this.props;\r\n\r\n            if (autoRefreshLayout) {\r\n                cy.layout(layout).run()\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        const sendSelectedNodesData = _.debounce(() => {\r\n            /**\r\n             This function is repetitively called every time a node is selected\r\n             or unselected, but keeps being debounced if it is called again\r\n             within 100 ms (given by SELECT_THRESHOLD). Effectively, it only\r\n             runs when all the nodes have been correctly selected/unselected and\r\n             added/removed from the selectedNodes collection, and then updates\r\n             the selectedNodeData prop.\r\n             */\r\n            const nodeData = selectedNodes.map(el => el.data());\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    selectedNodeData: nodeData\r\n                })\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        const sendSelectedEdgesData = _.debounce(() => {\r\n            const edgeData = selectedEdges.map(el => el.data());\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    selectedEdgeData: edgeData\r\n                })\r\n            }\r\n        }, SELECT_THRESHOLD);\r\n\r\n        // /////////////////////////////////////// EVENTS //////////////////////////////////////////\r\n        cy.on('tap', 'node', event => {\r\n            const nodeObject = this.generateNode(event);\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    tapNode: nodeObject,\r\n                    tapNodeData: nodeObject.data\r\n                });\r\n            }\r\n        });\r\n\r\n        cy.on('tap', 'edge', event => {\r\n            const edgeObject = this.generateEdge(event);\r\n\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    tapEdge: edgeObject,\r\n                    tapEdgeData: edgeObject.data\r\n                });\r\n            }\r\n        });\r\n\r\n        cy.on('mouseover', 'node', event => {\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    mouseoverNodeData: event.target.data()\r\n                })\r\n            }\r\n        });\r\n\r\n        cy.on('mouseover', 'edge', event => {\r\n            if (typeof this.props.setProps === 'function') {\r\n                this.props.setProps({\r\n                    mouseoverEdgeData: event.target.data()\r\n                })\r\n            }\r\n        });\r\n\r\n        cy.on('select', 'node', event => {\r\n            const ele = event.target;\r\n\r\n            selectedNodes.merge(ele);\r\n            sendSelectedNodesData();\r\n        });\r\n\r\n        cy.on('unselect remove', 'node', event => {\r\n            const ele = event.target;\r\n\r\n            selectedNodes.unmerge(ele);\r\n            sendSelectedNodesData();\r\n        });\r\n\r\n        cy.on('select', 'edge', event => {\r\n            const ele = event.target;\r\n\r\n            selectedEdges.merge(ele);\r\n            sendSelectedEdgesData();\r\n        });\r\n\r\n        cy.on('unselect remove', 'edge', event => {\r\n            const ele = event.target;\r\n\r\n            selectedEdges.unmerge(ele);\r\n            sendSelectedEdgesData();\r\n        });\r\n\r\n        cy.on('add remove', () => {\r\n            refreshLayout();\r\n        });\r\n    }\r\n\r\n    render() {\r\n        const {\r\n            // HTML attribute props\r\n            id,\r\n            style,\r\n            className,\r\n            // Common props\r\n            elements,\r\n            stylesheet,\r\n            layout,\r\n            // Viewport Manipulation\r\n            pan,\r\n            zoom,\r\n            // Viewport Mutability and gesture Toggling\r\n            panningEnabled,\r\n            userPanningEnabled,\r\n            minZoom,\r\n            maxZoom,\r\n            zoomingEnabled,\r\n            userZoomingEnabled,\r\n            boxSelectionEnabled,\r\n            autoungrabify,\r\n            autolock,\r\n            autounselectify\r\n        } = this.props;\r\n\r\n        return (\r\n            <CytoscapeComponent\r\n                id={id}\r\n                cy={this.handleCy}\r\n                className={className}\r\n                style={style}\r\n                elements={CytoscapeComponent.normalizeElements(elements)}\r\n                stylesheet={stylesheet}\r\n                layout={layout}\r\n                pan={pan}\r\n                zoom={zoom}\r\n                panningEnabled={panningEnabled}\r\n                userPanningEnabled={userPanningEnabled}\r\n                minZoom={minZoom}\r\n                maxZoom={maxZoom}\r\n                zoomingEnabled={zoomingEnabled}\r\n                userZoomingEnabled={userZoomingEnabled}\r\n                boxSelectionEnabled={boxSelectionEnabled}\r\n                autoungrabify={autoungrabify}\r\n                autolock={autolock}\r\n                autounselectify={autounselectify}\r\n            />\r\n        )\r\n    }\r\n}\r\n\r\n\r\nCytoscape.propTypes = {\r\n    // HTML attribute props\r\n\r\n    /**\r\n     * The ID used to identify this component in Dash callbacks.\r\n     */\r\n    id: PropTypes.string,\r\n\r\n    /**\r\n     * Sets the class name of the element (the value of an element's html\r\n     * class attribute).\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Add inline styles to the root element.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    // Dash specific props\r\n\r\n    /**\r\n     * Dash-assigned callback that should be called whenever any of the\r\n     * properties change.\r\n     */\r\n    setProps: PropTypes.func,\r\n\r\n    // Common props\r\n\r\n    /**\r\n     * A list of dictionaries representing the elements of the networks.\r\n     *     1. Each dictionary describes an element, and specifies its purpose.\r\n     *         - `group` (string): Either 'nodes' or 'edges'. If not given, it's automatically inferred.\r\n     *         - `data` (dictionary): Element specific data.\r\n     *              - `id` (string): Reference to the element, useful for selectors and edges. Randomly assigned if not given.\r\n     *              - `label` (string): Optional name for the element, useful when `data(label)` is given to a style's `content` or `label`. It is only a convention.\r\n     *              - `parent` (string): Only for nodes. Optional reference to another node. Needed to create compound nodes.\r\n     *              - `source` (string): Only for edges. The id of the source node, which is where the edge starts.\r\n     *              - `target` (string): Only for edges. The id of the target node, where the edge ends.\r\n     *         - `position` (dictionary): Only for nodes. The position of the node.\r\n     *              - `x` (number): The x-coordinate of the node.\r\n     *              - `y` (number): The y-coordinate of the node.\r\n     *         - `selected` (boolean): If the element is selected upon initialisation.\r\n     *         - `selectable` (boolean): If the element can be selected.\r\n     *         - `locked` (boolean): Only for nodes. If the position is immutable.\r\n     *         - `grabbable` (boolean): Only for nodes. If the node can be grabbed and moved by the user.\r\n     *         - `classes` (string): Space separated string of class names of the element. Those classes can be selected by a style selector.\r\n     *\r\n     *     2. The [official Cytoscape.js documentation](http://js.cytoscape.org/#notation/elements-json) offers an extensive overview and examples of element declaration.\r\n     */\r\n    elements: PropTypes.arrayOf(PropTypes.object),\r\n\r\n    /**\r\n     * A list of dictionaries representing the styles of the elements.\r\n     *     1. Each dictionary requires the following keys:\r\n     *         - `selector` (string): Which elements you are styling. Generally, you select a group of elements (node, edges, both), a class (that you declare in the element dictionary), or an element by ID.\r\n     *         - `style` (dictionary): What aspects of the elements you want to modify. This could be the size or color of a node, the shape of an edge arrow, or many more.\r\n     *\r\n     *     2. Both [the selector string](http://js.cytoscape.org/#selectors) and\r\n     *     [the style dictionary](http://js.cytoscape.org/#style/node-body) are\r\n     *     exhaustively documented in the Cytoscape.js docs. Although methods such\r\n     *     as `cy.elements(...)` and `cy.filter(...)` are not available, the selector\r\n     *     string syntax stays the same.\r\n     */\r\n    stylesheet: PropTypes.arrayOf(PropTypes.object),\r\n\r\n    /**\r\n     * A dictionary specifying how to set the position of the elements in your\r\n     * graph. The `'name'` key is required, and indicates which layout (algorithm) to\r\n     * use.\r\n     *     1. The layouts available by default are:\r\n     *         - `random`: Randomly assigns positions\r\n     *         - `preset`: Assigns position based on the `position` key in element dictionaries\r\n     *         - `circle`: Single-level circle, with optional radius\r\n     *         - `concentric`: Multi-level circle, with optional radius\r\n     *         - `grid`: Square grid, optionally with numbers of `rows` and `cols`\r\n     *         - `breadthfirst`: Tree structure built using BFS, with optional `roots`\r\n     *         - `cose`: Force-directed physics simulation\r\n     *\r\n     *     2. Some external layouts are also included. To use them, run\r\n     *     `dash_cytoscape.load_extra_layouts()` before creating your Dash app. Be careful about\r\n     *     using the extra layouts when not necessary, since they require supplementary bandwidth\r\n     *     for loading, which impacts the startup time of the app.\r\n     *         - `cose-bilkent`: https://github.com/cytoscape/cytoscape.js-cose-bilkent\r\n     *         - `cola`: https://github.com/cytoscape/cytoscape.js-cola\r\n     *         - `euler`: https://github.com/cytoscape/cytoscape.js-dagre\r\n     *         - `spread`: https://github.com/cytoscape/cytoscape.js-spread\r\n     *         - `dagre`: https://github.com/cytoscape/cytoscape.js-dagre\r\n     *         - `klay`: https://github.com/cytoscape/cytoscape.js-klay\r\n     *\r\n     *     3. The keys accepted by `layout` vary depending on the algorithm, but some\r\n     *     keys are accepted by all layouts:\r\n     *         - `fit` (boolean): Whether to render the nodes in order to fit the canvas.\r\n     *         - `padding` (number): Padding around the sides of the canvas, if fit is enabled.\r\n     *         - `animate` (boolean): Whether to animate change in position when the layout changes.\r\n     *         - `animationDuration` (number): Duration of animation in milliseconds, if enabled.\r\n     *         - `boundingBox` (dictionary): How to constrain the layout in a specific area. Keys accepted are either `x1, y1, x2, y2` or `x1, y1, w, h`, all of which receive a pixel value.\r\n     *\r\n     *     4. The complete list of layouts and their accepted options are available\r\n     *     on the [Cytoscape.js docs](http://js.cytoscape.org/#layouts). For the\r\n     *     external layouts, the options are listed in the \"API\" section of the\r\n     *     README.\r\n     *     Note that certain keys are not supported in Dash since the value is a\r\n     *     JavaScript function or a callback. Please visit [this issue](https://github.com/plotly/dash-cytoscape/issues/25)\r\n     *     for more information.\r\n     */\r\n    layout: PropTypes.object,\r\n\r\n    // Viewport Manipulation\r\n\r\n    /**\r\n     * Dictionary indicating the initial panning position of the graph. The\r\n     * following keys are accepted:\r\n     *     - `x` (number): The x-coordinate of the position.\r\n     *     - `y` (number): The y-coordinate of the position.\r\n     */\r\n    pan: PropTypes.object,\r\n\r\n    /**\r\n     * The initial zoom level of the graph. You can set `minZoom` and\r\n     * `maxZoom` to set restrictions on the zoom level.\r\n     */\r\n    zoom: PropTypes.number,\r\n\r\n    // Viewport Mutability and gesture Toggling\r\n    /**\r\n     * Whether panning the graph is enabled (i.e., the position of the graph is\r\n     * mutable overall).\r\n     */\r\n    panningEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether user events (e.g. dragging the graph background) are allowed to\r\n     * pan the graph.\r\n     */\r\n    userPanningEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * A minimum bound on the zoom level of the graph. The viewport can not be\r\n     * scaled smaller than this zoom level.\r\n     */\r\n    minZoom: PropTypes.number,\r\n\r\n    /**\r\n     * A maximum bound on the zoom level of the graph. The viewport can not be\r\n     * scaled larger than this zoom level.\r\n     */\r\n    maxZoom: PropTypes.number,\r\n\r\n    /**\r\n     * Whether zooming the graph is enabled (i.e., the zoom level of the graph\r\n     * is mutable overall).\r\n     */\r\n    zoomingEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether user events (e.g. dragging the graph background) are allowed\r\n     * to pan the graph.\r\n     */\r\n    userZoomingEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether box selection (i.e. drag a box overlay around, and release it\r\n     * to select) is enabled. If enabled, the user must taphold to pan the graph.\r\n     */\r\n    boxSelectionEnabled: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be ungrabified (not grabbable by user) by\r\n     * default (if true, overrides individual node state).\r\n     */\r\n    autoungrabify: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be locked (not draggable at all) by default\r\n     * (if true, overrides individual node state).\r\n     */\r\n    autolock: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether nodes should be unselectified (immutable selection state) by\r\n     * default (if true, overrides individual element state).\r\n     */\r\n    autounselectify: PropTypes.bool,\r\n\r\n    /**\r\n     * Whether the layout should be refreshed when elements are added or removed.\r\n     */\r\n    autoRefreshLayout: PropTypes.bool,\r\n\r\n    // User Events Props\r\n\r\n    /**\r\n     * The complete node dictionary returned when you tap or click it. Read-only.\r\n     *\r\n     *     1. Node-specific items:\r\n     *         - `edgesData` (dictionary)\r\n     *         - `renderedPosition` (dictionary)\r\n     *         - `timeStamp` (number)\r\n     *\r\n     *     2. General items (for all elements):\r\n     *         - `classes` (string)\r\n     *         - `data` (dictionary)\r\n     *         - `grabbable` (boolean)\r\n     *         - `group` (string)\r\n     *         - `locked` (boolean)\r\n     *         - `position` (dictionary)\r\n     *         - `selectable` (boolean)\r\n     *         - `selected` (boolean)\r\n     *         - `style` (dictionary)\r\n     *\r\n     *     3. Items for compound nodes:\r\n     *         - `ancestorsData` (dictionary)\r\n     *         - `childrenData` (dictionary)\r\n     *         - `descendantsData` (dictionary)\r\n     *         - `parentData` (dictionary)\r\n     *         - `siblingsData` (dictionary)\r\n     *         - `isParent` (boolean)\r\n     *         - `isChildless` (boolean)\r\n     *         - `isChild` (boolean)\r\n     *         - `isOrphan` (boolean)\r\n     *         - `relativePosition` (dictionary)\r\n     */\r\n    tapNode: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of a node returned when you tap or click it. Read-only.\r\n     */\r\n    tapNodeData: PropTypes.object,\r\n\r\n    /**\r\n     * The complete edge dictionary returned when you tap or click it. Read-only.\r\n     *\r\n     *     1. Edge-specific items:\r\n     *         - `isLoop` (boolean)\r\n     *         - `isSimple` (boolean)\r\n     *         - `midpoint` (dictionary)\r\n     *         - `sourceData` (dictionary)\r\n     *         - `sourceEndpoint` (dictionary)\r\n     *         - `targetData` (dictionary)\r\n     *         - `targetEndpoint` (dictionary)\r\n     *         - `timeStamp` (number)\r\n     *\r\n     *     2. General items (for all elements):\r\n     *         - `classes` (string)\r\n     *         - `data` (dictionary)\r\n     *         - `grabbable` (boolean)\r\n     *         - `group` (string)\r\n     *         - `locked` (boolean)\r\n     *         - `selectable` (boolean)\r\n     *         - `selected` (boolean)\r\n     *         - `style` (dictionary)\r\n     */\r\n    tapEdge: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of an edge returned when you tap or click it. Read-only.\r\n     */\r\n    tapEdgeData: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of a node returned when you hover over it. Read-only.\r\n     */\r\n    mouseoverNodeData: PropTypes.object,\r\n\r\n    /**\r\n     * The data dictionary of an edge returned when you hover over it. Read-only.\r\n     */\r\n    mouseoverEdgeData: PropTypes.object,\r\n\r\n    /**\r\n     * The list of data dictionaries of all selected nodes (e.g. using\r\n     * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n     */\r\n    selectedNodeData: PropTypes.array,\r\n\r\n    /**\r\n     * The list of data dictionaries of all selected edges (e.g. using\r\n     * Shift+Click to select multiple nodes, or Shift+Drag to use box selection). Read-only.\r\n     */\r\n    selectedEdgeData: PropTypes.array\r\n};\r\n\r\nCytoscape.defaultProps = {\r\n    style: {width: '600px', height: '600px'},\r\n    layout: {name: 'grid'},\r\n    pan: {x: 0, y: 0},\r\n    zoom: 1,\r\n    minZoom: 1e-50,\r\n    maxZoom: 1e50,\r\n    zoomingEnabled: true,\r\n    userZoomingEnabled: true,\r\n    panningEnabled: true,\r\n    userPanningEnabled: true,\r\n    boxSelectionEnabled: false,\r\n    autolock: false,\r\n    autoungrabify: false,\r\n    autounselectify: false,\r\n    autoRefreshLayout: true\r\n};\r\n\r\nexport default Cytoscape;"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/lib/components/Cytoscape.react.js\n"); /***/ }), diff --git a/dash_cytoscape/package.json b/dash_cytoscape/package.json index 24830c28..78a09c0c 100644 --- a/dash_cytoscape/package.json +++ b/dash_cytoscape/package.json @@ -1,6 +1,6 @@ { "name": "dash-cytoscape", - "version": "0.0.5", + "version": "0.1.0", "description": "A Component Library for Dash aimed at facilitating network visualization in Python, wrapped around Cytoscape.js", "main": "build/index.js", "scripts": { diff --git a/package.json b/package.json index 24830c28..78a09c0c 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "dash-cytoscape", - "version": "0.0.5", + "version": "0.1.0", "description": "A Component Library for Dash aimed at facilitating network visualization in Python, wrapped around Cytoscape.js", "main": "build/index.js", "scripts": {