From 7c3b5b65ec9bb08c61435b25ffd7d2d3c67eea9b Mon Sep 17 00:00:00 2001 From: bcliang Date: Sun, 25 Aug 2019 15:09:13 -0700 Subject: [PATCH 1/7] sync w/ changes in plotly/dash-core-components PR#604 --- src/lib/components/ExtendableGraph.react.js | 86 ++++++++++----------- 1 file changed, 43 insertions(+), 43 deletions(-) diff --git a/src/lib/components/ExtendableGraph.react.js b/src/lib/components/ExtendableGraph.react.js index b0c3c6e..918ad95 100644 --- a/src/lib/components/ExtendableGraph.react.js +++ b/src/lib/components/ExtendableGraph.react.js @@ -64,67 +64,67 @@ const filterEventData = (gd, eventData, event) => { return filteredEventData; }; -function generateId() { - const charAmount = 36; - const length = 7; - return ( - 'graph-' + - Math.random() - .toString(charAmount) - .substring(2, length) - ); -} - /** * ExtendableGraph can be used to render any plotly.js-powered data vis. * * You can define callbacks based on user interaction with ExtendableGraphs such * as hovering, clicking or selecting */ -const ExtendableGraphWithDefaults = props => { - const id = props.id ? props.id : generateId(); - return ; -}; - class ExtendableGraph extends Component { constructor(props) { super(props); + this.gd = React.createRef(); this.bindEvents = this.bindEvents.bind(this); this._hasPlotted = false; + this._prevGd = null; this.graphResize = this.graphResize.bind(this); } plot(props) { - const {figure, id, animate, animation_options, config} = props; - const gd = document.getElementById(id); + const {figure, animate, animation_options, config} = props; + const gd = this.gd.current; if ( animate && this._hasPlotted && figure.data.length === gd.data.length ) { - return Plotly.animate(id, figure, animation_options); + return Plotly.animate(gd, figure, animation_options); } - return Plotly.react(id, { + return Plotly.react(gd, { data: figure.data, layout: clone(figure.layout), frames: figure.frames, config: config, }).then(() => { - if (!this._hasPlotted) { - const gd = document.getElementById(id); - if (gd) { - this.bindEvents(); - Plotly.Plots.resize(gd); - this._hasPlotted = true; + const gd = this.gd.current; + + // double-check gd hasn't been unmounted + if (!gd) { + return; + } + + // in case we've made a new DOM element, transfer events + if (this._hasPlotted && gd !== this._prevGd) { + if (this._prevGd && this._prevGd.removeAllListeners) { + this._prevGd.removeAllListeners(); + Plotly.purge(this._prevGd); } + this._hasPlotted = false; + } + + if (!this._hasPlotted) { + this.bindEvents(); + Plotly.Plots.resize(gd); + this._hasPlotted = true; + this._prevGd = gd; } }); } extend(props) { - const {id, extendData} = props; - const gd = document.getElementById(id); + const {extendData} = props; + const gd = this.gd.current; let updateData, traceIndices, maxPoints; if (extendData) { @@ -158,24 +158,24 @@ class ExtendableGraph extends Component { if (i < updateData.length - 1) { if (traceIndices[i] < gd.data.length) { Plotly.extendTraces( - id, + gd, updateObject, [traceIndices[i]], maxPoints ); } else { - Plotly.addTraces(id, value); + Plotly.addTraces(gd, value); } } else { if (traceIndices[i] < gd.data.length) { return Plotly.extendTraces( - id, + gd, updateObject, [traceIndices[i]], maxPoints ); } - return Plotly.addTraces(id, value); + return Plotly.addTraces(gd, value); } } } @@ -184,16 +184,16 @@ class ExtendableGraph extends Component { } graphResize() { - const graphDiv = document.getElementById(this.props.id); - if (graphDiv) { - Plotly.Plots.resize(graphDiv); + const gd = this.gd.current; + if (gd) { + Plotly.Plots.resize(gd); } } bindEvents() { - const {id, setProps, clear_on_unhover} = this.props; + const {setProps, clear_on_unhover} = this.props; - const gd = document.getElementById(id); + const gd = this.gd.current; gd.on('plotly_click', eventData => { const clickData = filterEventData(gd, eventData, 'click'); @@ -249,8 +249,10 @@ class ExtendableGraph extends Component { } componentWillUnmount() { - if (this.eventEmitter) { - this.eventEmitter.removeAllListeners(); + const gd = this.gd.current; + if (gd && gd.removeAllListeners) { + gd.removeAllListeners(); + Plotly.purge(gd); } window.removeEventListener('resize', this.graphResize); } @@ -297,6 +299,7 @@ class ExtendableGraph extends Component {
Date: Sun, 25 Aug 2019 15:32:18 -0700 Subject: [PATCH 2/7] package.json cleanup --- README.md | 2 +- package.json | 4 +--- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 11e3d83..7f880db 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ ![PyPI - Python Version](https://img.shields.io/pypi/pyversions/dash-extendable-graph.svg) [![PyPI - License](https://img.shields.io/pypi/l/dash-extendable-graph.svg)](./LICENSE) -dash-extendable-graph is a Dash component library. This library contains a single component: `ExtendableGraph`. The component is a fork of the Graph() component of [dash-core-components](https://github.com/plotly/dash-core-components) (v 1.0.0). However, the `extendData` for this component has been modified to follow an api that matches the format of `figure['data']` (as opposed to the api defined `Graph.extendData` and `Plotly.extendTraces()`). +dash-extendable-graph is a Dash component library. This library contains a single component: `ExtendableGraph`. The component is a fork of the Graph() component of [dash-core-components](https://github.com/plotly/dash-core-components) (v 1.1.1). However, the `extendData` for this component has been modified to follow an api that matches the format of `figure['data']` (as opposed to the api defined `Graph.extendData` and `Plotly.extendTraces()`). Note: plotly.js is required. However, the library is NOT explicitly listed in `MANIFEST.in` or in `dash_extendable_graph\__init__.py` as a way to reduce bundle size. Plotly.js is already distributed with the dash-core-components package, and most projects will import dcc as well as dash-extendable-graph. diff --git a/package.json b/package.json index ef6b57c..ef12f1d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "dash_extendable_graph", - "version": "1.0.2", + "version": "1.0.3", "description": "plotly-dash custom component. Adds Plotly.extendTraces() support to dash_core_components.Graph()", "homepage": "https://github.com/bcliang/dash-extendable-graph", "main": "build/index.js", @@ -35,7 +35,6 @@ "babel-eslint": "^10.0.2", "babel-loader": "^8.0.6", "component-playground": "^3.0.0", - "copyfiles": "^2.1.1", "css-loader": "^1.0.1", "eslint": "^5.16.0", "eslint-config-prettier": "^3.6.0", @@ -45,7 +44,6 @@ "prettier": "^1.16.4", "prop-types": "^15.7.2", "react": "^16.8.6", - "react-docgen": "^4.1.1", "react-dom": "^16.8.6", "style-loader": "^0.23.1", "styled-jsx": "^3.1.1", From cdfd916e09d8b926f7f3436127cc30f3f7aaea7f Mon Sep 17 00:00:00 2001 From: bcliang Date: Sun, 25 Aug 2019 15:34:21 -0700 Subject: [PATCH 3/7] fix docstrings, use ramda equals in component bindEvents() --- src/lib/components/ExtendableGraph.react.js | 51 ++++++++++++--------- 1 file changed, 29 insertions(+), 22 deletions(-) diff --git a/src/lib/components/ExtendableGraph.react.js b/src/lib/components/ExtendableGraph.react.js index 918ad95..89298c6 100644 --- a/src/lib/components/ExtendableGraph.react.js +++ b/src/lib/components/ExtendableGraph.react.js @@ -1,6 +1,6 @@ import React, {Component} from 'react'; import PropTypes from 'prop-types'; -import {contains, filter, clone, has, isNil, type, omit} from 'ramda'; +import {contains, filter, clone, has, isNil, type, omit, equals} from 'ramda'; /* global Plotly:true */ const filterEventData = (gd, eventData, event) => { @@ -191,7 +191,14 @@ class ExtendableGraph extends Component { } bindEvents() { - const {setProps, clear_on_unhover} = this.props; + const { + setProps, + clear_on_unhover, + relayoutData, + restyleData, + hoverData, + selectedData, + } = this.props; const gd = this.gd.current; @@ -209,30 +216,30 @@ class ExtendableGraph extends Component { setProps({clickAnnotationData}); }); gd.on('plotly_hover', eventData => { - const hoverData = filterEventData(gd, eventData, 'hover'); - if (!isNil(hoverData)) { - setProps({hoverData}); + const hover = filterEventData(gd, eventData, 'hover'); + if (!isNil(hover) && !equals(hover, hoverData)) { + setProps({hoverData: hover}); } }); gd.on('plotly_selected', eventData => { - const selectedData = filterEventData(gd, eventData, 'selected'); - if (!isNil(selectedData)) { - setProps({selectedData}); + const selected = filterEventData(gd, eventData, 'selected'); + if (!isNil(selected) && !equals(selected, selectedData)) { + setProps({selectedData: selected}); } }); gd.on('plotly_deselect', () => { setProps({selectedData: null}); }); gd.on('plotly_relayout', eventData => { - const relayoutData = filterEventData(gd, eventData, 'relayout'); - if (!isNil(relayoutData)) { - setProps({relayoutData}); + const relayout = filterEventData(gd, eventData, 'relayout'); + if (!isNil(relayout) && !equals(relayout, relayoutData)) { + setProps({relayoutData: relayout}); } }); gd.on('plotly_restyle', eventData => { - const restyleData = filterEventData(gd, eventData, 'restyle'); - if (!isNil(restyleData)) { - setProps({restyleData}); + const restyle = filterEventData(gd, eventData, 'restyle'); + if (!isNil(restyle) && !equals(restyle, restyleData)) { + setProps({restyleData: restyle}); } }); gd.on('plotly_unhover', () => { @@ -274,7 +281,7 @@ class ExtendableGraph extends Component { return; } - const figureChanged = this.props.figure !== nextProps.figure; + const figureChanged = !equals(this.props.figure, nextProps.figure); if (figureChanged) { this.plot(nextProps); } @@ -437,7 +444,7 @@ const graphPropTypes = { */ edits: PropTypes.exact({ /** - * annotationPosition: the main anchor of the annotation, which is the + * The main anchor of the annotation, which is the * text (if no arrow) or the arrow (which drags the whole thing leaving * the arrow length & direction unchanged) */ @@ -559,12 +566,12 @@ const graphPropTypes = { * Remove mode bar button by name. * All modebar button names at https://github.com/plotly/plotly.js/blob/master/src/components/modebar/buttons.js * Common names include: - * - sendDataToCloud - * - (2D): zoom2d, pan2d, select2d, lasso2d, zoomIn2d, zoomOut2d, autoScale2d, resetScale2d - * - (Cartesian): hoverClosestCartesian, hoverCompareCartesian - * - (3D): zoom3d, pan3d, orbitRotation, tableRotation, handleDrag3d, resetCameraDefault3d, resetCameraLastSave3d, hoverClosest3d - * - (Geo): zoomInGeo, zoomOutGeo, resetGeo, hoverClosestGeo - * - hoverClosestGl2d, hoverClosestPie, toggleHover, resetViews + * sendDataToCloud; + * (2D) zoom2d, pan2d, select2d, lasso2d, zoomIn2d, zoomOut2d, autoScale2d, resetScale2d; + * (Cartesian) hoverClosestCartesian, hoverCompareCartesian; + * (3D) zoom3d, pan3d, orbitRotation, tableRotation, handleDrag3d, resetCameraDefault3d, resetCameraLastSave3d, hoverClosest3d; + * (Geo) zoomInGeo, zoomOutGeo, resetGeo, hoverClosestGeo; + * hoverClosestGl2d, hoverClosestPie, toggleHover, resetViews. */ modeBarButtonsToRemove: PropTypes.array, From c977dda548ef9c90b4c382f82107d90a8d3a242a Mon Sep 17 00:00:00 2001 From: bcliang Date: Tue, 27 Aug 2019 09:17:38 -0700 Subject: [PATCH 4/7] fix eslint-utils vuln --- package-lock.json | 563 ++++++++++++++++++---------------------------- package.json | 13 +- 2 files changed, 229 insertions(+), 347 deletions(-) diff --git a/package-lock.json b/package-lock.json index 65c0d94..6eeb854 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "dash_extendable_graph", - "version": "1.0.2", + "version": "1.0.3", "lockfileVersion": 1, "requires": true, "dependencies": { @@ -1500,15 +1500,15 @@ } }, "acorn": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.1.tgz", - "integrity": "sha512-jPTiwtOxaHNaAPg/dmrJ/beuzLRnXtB0kQPQ8JpotKJgTB6rX6c8mlf315941pyjBSaPg8NHXS9fhP4u17DpGA==", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.0.0.tgz", + "integrity": "sha512-PaF/MduxijYYt7unVGRuds1vBC9bFxbNf+VWqhOClfdgy7RlVkQqt610ig1/yxTgsDIfW1cWDel5EBbOy3jdtQ==", "dev": true }, "acorn-jsx": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", - "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.2.tgz", + "integrity": "sha512-tiNTrP1MP0QrChmD2DdupCr6HWSFeKVw5d/dHTu4Y7rkAkRhU/Dt7dphAfIUyxtHpl/eBVip5uTNSpQJHylpAw==", "dev": true }, "ajv": { @@ -1808,17 +1808,28 @@ } }, "babel-eslint": { - "version": "10.0.2", - "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.0.2.tgz", - "integrity": "sha512-UdsurWPtgiPgpJ06ryUnuaSXC2s0WoSZnQmEpbAH65XZSdwowgN5MvyP7e88nW07FYXv72erVtpBkxyDVKhH1Q==", + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.0.3.tgz", + "integrity": "sha512-z3U7eMY6r/3f3/JB9mTsLjyxrv0Yb1zb8PCWCLpguxfCzBIZUwy23R1t/XKewP+8mEN2Ck8Dtr4q20z6ce6SoA==", "dev": true, "requires": { "@babel/code-frame": "^7.0.0", "@babel/parser": "^7.0.0", "@babel/traverse": "^7.0.0", "@babel/types": "^7.0.0", - "eslint-scope": "3.7.1", - "eslint-visitor-keys": "^1.0.0" + "eslint-visitor-keys": "^1.0.0", + "resolve": "^1.12.0" + }, + "dependencies": { + "resolve": { + "version": "1.12.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", + "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } + } } }, "babel-loader": { @@ -2271,9 +2282,9 @@ "dev": true }, "callsites": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.0.0.tgz", - "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", "dev": true }, "camelcase": { @@ -2388,45 +2399,6 @@ "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", "dev": true }, - "cliui": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", - "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", - "dev": true, - "requires": { - "string-width": "^3.1.0", - "strip-ansi": "^5.2.0", - "wrap-ansi": "^5.1.0" - }, - "dependencies": { - "ansi-regex": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", - "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", - "dev": true - }, - "string-width": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", - "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", - "dev": true, - "requires": { - "emoji-regex": "^7.0.1", - "is-fullwidth-code-point": "^2.0.0", - "strip-ansi": "^5.1.0" - } - }, - "strip-ansi": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", - "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", - "dev": true, - "requires": { - "ansi-regex": "^4.1.0" - } - } - } - }, "co": { "version": "4.6.0", "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", @@ -2635,20 +2607,6 @@ "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", "dev": true }, - "copyfiles": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/copyfiles/-/copyfiles-2.1.1.tgz", - "integrity": "sha512-y6DZHve80whydXzBal7r70TBgKMPKesVRR1Sn/raUu7Jh/i7iSLSyGvYaq0eMJ/3Y/CKghwzjY32q1WzEnpp3Q==", - "dev": true, - "requires": { - "glob": "^7.0.5", - "minimatch": "^3.0.3", - "mkdirp": "^0.5.1", - "noms": "0.0.0", - "through2": "^2.0.1", - "yargs": "^13.2.4" - } - }, "core-js-compat": { "version": "3.1.4", "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.1.4.tgz", @@ -2717,6 +2675,19 @@ "sha.js": "^2.4.8" } }, + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "dev": true, + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, "crypto-browserify": { "version": "3.12.0", "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.12.0.tgz", @@ -3113,78 +3084,71 @@ "dev": true }, "eslint": { - "version": "5.16.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.16.0.tgz", - "integrity": "sha512-S3Rz11i7c8AA5JPv7xAH+dOyq/Cu/VXHiHXBPOU1k/JAM5dXqQPt3qcrhpHSorXmrpu2g0gkIBVXAqCpzfoZIg==", + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.2.2.tgz", + "integrity": "sha512-mf0elOkxHbdyGX1IJEUsNBzCDdyoUgljF3rRlgfyYh0pwGnreLc0jjD6ZuleOibjmnUWZLY2eXwSooeOgGJ2jw==", "dev": true, "requires": { "@babel/code-frame": "^7.0.0", - "ajv": "^6.9.1", + "ajv": "^6.10.0", "chalk": "^2.1.0", "cross-spawn": "^6.0.5", "debug": "^4.0.1", "doctrine": "^3.0.0", - "eslint-scope": "^4.0.3", - "eslint-utils": "^1.3.1", - "eslint-visitor-keys": "^1.0.0", - "espree": "^5.0.1", + "eslint-scope": "^5.0.0", + "eslint-utils": "^1.4.2", + "eslint-visitor-keys": "^1.1.0", + "espree": "^6.1.1", "esquery": "^1.0.1", "esutils": "^2.0.2", "file-entry-cache": "^5.0.1", "functional-red-black-tree": "^1.0.1", - "glob": "^7.1.2", + "glob-parent": "^5.0.0", "globals": "^11.7.0", "ignore": "^4.0.6", "import-fresh": "^3.0.0", "imurmurhash": "^0.1.4", - "inquirer": "^6.2.2", - "js-yaml": "^3.13.0", + "inquirer": "^6.4.1", + "is-glob": "^4.0.0", + "js-yaml": "^3.13.1", "json-stable-stringify-without-jsonify": "^1.0.1", "levn": "^0.3.0", - "lodash": "^4.17.11", + "lodash": "^4.17.14", "minimatch": "^3.0.4", "mkdirp": "^0.5.1", "natural-compare": "^1.4.0", "optionator": "^0.8.2", - "path-is-inside": "^1.0.2", "progress": "^2.0.0", "regexpp": "^2.0.1", - "semver": "^5.5.1", - "strip-ansi": "^4.0.0", - "strip-json-comments": "^2.0.1", + "semver": "^6.1.2", + "strip-ansi": "^5.2.0", + "strip-json-comments": "^3.0.1", "table": "^5.2.3", - "text-table": "^0.2.0" + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" }, "dependencies": { - "cross-spawn": { - "version": "6.0.5", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", - "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "glob-parent": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.0.0.tgz", + "integrity": "sha512-Z2RwiujPRGluePM6j699ktJYxmPpJKCfpGA13jz2hmFZC7gKetzrWvg5KN3+OsIFmydGyZ1AVwERCq1w/ZZwRg==", "dev": true, "requires": { - "nice-try": "^1.0.4", - "path-key": "^2.0.1", - "semver": "^5.5.0", - "shebang-command": "^1.2.0", - "which": "^1.2.9" + "is-glob": "^4.0.1" } }, - "eslint-scope": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", - "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", - "dev": true, - "requires": { - "esrecurse": "^4.1.0", - "estraverse": "^4.1.1" - } + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true } } }, "eslint-config-prettier": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-3.6.0.tgz", - "integrity": "sha512-ixJ4U3uTLXwJts4rmSVW/lMXjlGwCijhBJHk8iVqKKSifeI0qgFEfWl8L63isfc8Od7EiBALF6BX3jKLluf/jQ==", + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.1.0.tgz", + "integrity": "sha512-k9fny9sPjIBQ2ftFTesJV21Rg4R/7a7t7LCtZVrYQiHEp8Nnuk3EGaDmsKSAnsPj0BYcgB2zxzHa2NTkIxcOLg==", "dev": true, "requires": { "get-stdin": "^6.0.0" @@ -3218,9 +3182,9 @@ } }, "eslint-module-utils": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.3.0.tgz", - "integrity": "sha512-lmDJgeOOjk8hObTysjqH7wyMi+nsHwwvfBykwfhjR1LNdd7C2uFJBvx4OpWYpXOw4df1yE1cDEVd1yLHitk34w==", + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.4.1.tgz", + "integrity": "sha512-H6DOj+ejw7Tesdgbfs4jeS4YMFrT8uI8xwd1gtQqXssaR0EQ26L+2O/w6wkYFy2MymON0fTwHmXBvvfLNZVZEw==", "dev": true, "requires": { "debug": "^2.6.8", @@ -3297,21 +3261,22 @@ } }, "eslint-plugin-import": { - "version": "2.16.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.16.0.tgz", - "integrity": "sha512-z6oqWlf1x5GkHIFgrSvtmudnqM6Q60KM4KvpWi5ubonMjycLjndvd5+8VAZIsTlHC03djdgJuyKG6XO577px6A==", + "version": "2.18.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.18.2.tgz", + "integrity": "sha512-5ohpsHAiUBRNaBWAF08izwUGlbrJoJJ+W9/TBwsGoR1MnlgfwMIKrFeSjWbt6moabiXW9xNvtFz+97KHRfI4HQ==", "dev": true, "requires": { + "array-includes": "^3.0.3", "contains-path": "^0.1.0", "debug": "^2.6.9", "doctrine": "1.5.0", "eslint-import-resolver-node": "^0.3.2", - "eslint-module-utils": "^2.3.0", + "eslint-module-utils": "^2.4.0", "has": "^1.0.3", - "lodash": "^4.17.11", "minimatch": "^3.0.4", + "object.values": "^1.1.0", "read-pkg-up": "^2.0.0", - "resolve": "^1.9.0" + "resolve": "^1.11.0" }, "dependencies": { "debug": { @@ -3344,22 +3309,33 @@ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", "dev": true + }, + "resolve": { + "version": "1.12.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", + "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } } } }, "eslint-plugin-react": { - "version": "7.12.4", - "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.12.4.tgz", - "integrity": "sha512-1puHJkXJY+oS1t467MjbqjvX53uQ05HXwjqDgdbGBqf5j9eeydI54G3KwiJmWciQ0HTBacIKw2jgwSBSH3yfgQ==", + "version": "7.14.3", + "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.14.3.tgz", + "integrity": "sha512-EzdyyBWC4Uz2hPYBiEJrKCUi2Fn+BJ9B/pJQcjw5X+x/H2Nm59S4MJIvL4O5NEE0+WbnQwEBxWY03oUk+Bc3FA==", "dev": true, "requires": { "array-includes": "^3.0.3", "doctrine": "^2.1.0", "has": "^1.0.3", - "jsx-ast-utils": "^2.0.1", + "jsx-ast-utils": "^2.1.0", + "object.entries": "^1.1.0", "object.fromentries": "^2.0.0", - "prop-types": "^15.6.2", - "resolve": "^1.9.0" + "object.values": "^1.1.0", + "prop-types": "^15.7.2", + "resolve": "^1.10.1" }, "dependencies": { "doctrine": { @@ -3370,13 +3346,22 @@ "requires": { "esutils": "^2.0.2" } + }, + "resolve": { + "version": "1.12.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.12.0.tgz", + "integrity": "sha512-B/dOmuoAik5bKcD6s6nXDCjzUKnaDvdkRyAk6rsmsKLipWj4797iothd7jmmUhWTfinVMU+wc56rYKsit2Qy4w==", + "dev": true, + "requires": { + "path-parse": "^1.0.6" + } } } }, "eslint-scope": { - "version": "3.7.1", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-3.7.1.tgz", - "integrity": "sha1-PWPD7f2gLgbgGkUq2IyqzHzctug=", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", + "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", "dev": true, "requires": { "esrecurse": "^4.1.0", @@ -3384,26 +3369,29 @@ } }, "eslint-utils": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", - "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==", - "dev": true + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.2.tgz", + "integrity": "sha512-eAZS2sEUMlIeCjBeubdj45dmBHQwPHWyBcT1VSYB7o9x9WRRqKxyUoiXlRjyAwzN7YEzHJlYg0NmzDRWx6GP4Q==", + "dev": true, + "requires": { + "eslint-visitor-keys": "^1.0.0" + } }, "eslint-visitor-keys": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", - "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", + "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", "dev": true }, "espree": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", - "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-6.1.1.tgz", + "integrity": "sha512-EYbr8XZUhWbYCqQRW0duU5LxzL5bETN6AjKBGy1302qqzPaCH10QbRg3Wvco79Z8x9WbiE8HYB4e75xl6qUYvQ==", "dev": true, "requires": { - "acorn": "^6.0.7", - "acorn-jsx": "^5.0.0", - "eslint-visitor-keys": "^1.0.0" + "acorn": "^7.0.0", + "acorn-jsx": "^5.0.2", + "eslint-visitor-keys": "^1.1.0" } }, "esprima": { @@ -3536,9 +3524,9 @@ } }, "external-editor": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", - "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", + "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", "dev": true, "requires": { "chardet": "^0.7.0", @@ -3728,9 +3716,9 @@ } }, "flatted": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz", - "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", + "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==", "dev": true }, "flush-write-stream": { @@ -4436,12 +4424,6 @@ "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", "dev": true }, - "get-caller-file": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", - "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", - "dev": true - }, "get-stdin": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", @@ -4739,9 +4721,9 @@ "dev": true }, "import-fresh": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.0.0.tgz", - "integrity": "sha512-pOnA9tfM3Uwics+SaBLCNyZZZbK+4PTu0OPZtLlMIrv17EdBoC15S9Kn8ckJ9TZTyKb3ywNE5y1yeDxxGA7nTQ==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.1.0.tgz", + "integrity": "sha512-PpuksHKGt8rXfWEr9m9EHIpgyyaltBy8+eF6GJM0QCAxMgxCfucMF3mjecK2QsJr0amJW7gTqh5/wht0z2UhEQ==", "dev": true, "requires": { "parent-module": "^1.0.0", @@ -4781,9 +4763,9 @@ "dev": true }, "inquirer": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.2.tgz", - "integrity": "sha512-Z2rREiXA6cHRR9KBOarR3WuLlFzlIfAEIiB45ll5SSadMg7WqOh1MKEjjndfuH5ewXdixWCxqnVfGOQzPeiztA==", + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.5.2.tgz", + "integrity": "sha512-cntlB5ghuB0iuO65Ovoi8ogLHiWGs/5yNrtUcKjFhSSiVeAIVpD7koaSU9RM8mpXw5YDi9RdYXGQMaOURB7ycQ==", "dev": true, "requires": { "ansi-escapes": "^3.2.0", @@ -4792,30 +4774,13 @@ "cli-width": "^2.0.0", "external-editor": "^3.0.3", "figures": "^2.0.0", - "lodash": "^4.17.11", + "lodash": "^4.17.12", "mute-stream": "0.0.7", "run-async": "^2.2.0", "rxjs": "^6.4.0", "string-width": "^2.1.0", - "strip-ansi": "^5.0.0", + "strip-ansi": "^5.1.0", "through": "^2.3.6" - }, - "dependencies": { - "ansi-regex": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", - "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", - "dev": true - }, - "strip-ansi": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", - "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", - "dev": true, - "requires": { - "ansi-regex": "^4.1.0" - } - } } }, "invariant": { @@ -5117,12 +5082,13 @@ "dev": true }, "jsx-ast-utils": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.0.1.tgz", - "integrity": "sha1-6AGxs5mF4g//yHtA43SAgOLcrH8=", + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.2.1.tgz", + "integrity": "sha512-v3FxCcAf20DayI+uxnCuw795+oOIkVu6EnJ1+kSzhqqTZHNkTZ7B66ZgLp4oLJ/gbA64cI0B7WRoHZMSRdyVRQ==", "dev": true, "requires": { - "array-includes": "^3.0.3" + "array-includes": "^3.0.3", + "object.assign": "^4.1.0" } }, "keygrip": { @@ -5809,16 +5775,6 @@ "semver": "^5.3.0" } }, - "noms": { - "version": "0.0.0", - "resolved": "https://registry.npmjs.org/noms/-/noms-0.0.0.tgz", - "integrity": "sha1-2o69nzr51nYJGbJ9nNyAkqczKFk=", - "dev": true, - "requires": { - "inherits": "^2.0.1", - "readable-stream": "~1.0.31" - } - }, "normalize-package-data": { "version": "2.5.0", "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", @@ -5981,6 +5937,18 @@ "object-keys": "^1.0.11" } }, + "object.entries": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.0.tgz", + "integrity": "sha512-l+H6EQ8qzGRxbkHOd5I/aHRhHDKoQXQ8g0BYt4uSweQU1/J6dZUOyWh9a2Vky35YCKjzmgxOzta2hH6kf9HuXA==", + "dev": true, + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.12.0", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, "object.fromentries": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.0.tgz", @@ -6002,6 +5970,18 @@ "isobject": "^3.0.1" } }, + "object.values": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.0.tgz", + "integrity": "sha512-8mf0nKLAoFX6VlNVdhGj31SVYpaNFtUnuoOXWyFEstsWRgU837AK+JYM0iAxwkSzGRbwn8cbFmgbyxj1j4VbXg==", + "dev": true, + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.12.0", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, "on-finished": { "version": "2.3.0", "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", @@ -6217,12 +6197,6 @@ "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", "dev": true }, - "path-is-inside": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", - "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", - "dev": true - }, "path-key": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", @@ -6372,9 +6346,9 @@ "dev": true }, "prettier": { - "version": "1.16.4", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.16.4.tgz", - "integrity": "sha512-ZzWuos7TI5CKUeQAtFd6Zhm2s6EpAD/ZLApIhsF9pRvRtM1RFo61dM/4MSRUA0SuLugA/zgrZD8m0BaY46Og7g==", + "version": "1.18.2", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.18.2.tgz", + "integrity": "sha512-OeHeMc0JhFE9idD4ZdtNibzY0+TPHSpSSb9h8FqtP+YnoZZ1sl8Vc9b1sasjfymH3SonAF4QcA2+mzHPhMvIiw==", "dev": true }, "private": { @@ -6818,18 +6792,6 @@ "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", "dev": true }, - "require-directory": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", - "dev": true - }, - "require-main-filename": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", - "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", - "dev": true - }, "requires-port": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", @@ -6958,9 +6920,9 @@ } }, "rxjs": { - "version": "6.4.0", - "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.4.0.tgz", - "integrity": "sha512-Z9Yfa11F6B9Sg/BK9MnqnQ+aQYicPLtilXBp2yUtDt2JRCE0h26d33EnfO3ZxoNxG0T92OUucP3Ct7cpfkdFfw==", + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz", + "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==", "dev": true, "requires": { "tslib": "^1.9.0" @@ -7020,12 +6982,6 @@ "integrity": "sha512-ke8UG8ulpFOxO8f8gRYabHQe/ZntKlcig2Mp+8+URDP1D8vJZ0KUt7LYo07q25Z/+JVSgpr/cui9PIp5H6/+nA==", "dev": true }, - "set-blocking": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", - "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", - "dev": true - }, "set-value": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", @@ -7492,6 +7448,17 @@ "requires": { "is-fullwidth-code-point": "^2.0.0", "strip-ansi": "^4.0.0" + }, + "dependencies": { + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "dev": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } } }, "string.prototype.padend": { @@ -7512,12 +7479,20 @@ "dev": true }, "strip-ansi": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", - "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", "dev": true, "requires": { - "ansi-regex": "^3.0.0" + "ansi-regex": "^4.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", + "dev": true + } } }, "strip-bom": { @@ -7527,9 +7502,9 @@ "dev": true }, "strip-json-comments": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", - "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", + "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==", "dev": true }, "style-loader": { @@ -7588,22 +7563,28 @@ } }, "table": { - "version": "5.2.3", - "resolved": "https://registry.npmjs.org/table/-/table-5.2.3.tgz", - "integrity": "sha512-N2RsDAMvDLvYwFcwbPyF3VmVSSkuF+G1e+8inhBLtHpvwXGw4QRPEZhihQNeEN0i1up6/f6ObCJXNdlRG3YVyQ==", + "version": "5.4.6", + "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", + "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", "dev": true, "requires": { - "ajv": "^6.9.1", - "lodash": "^4.17.11", + "ajv": "^6.10.2", + "lodash": "^4.17.14", "slice-ansi": "^2.1.0", "string-width": "^3.0.0" }, "dependencies": { - "ansi-regex": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", - "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", - "dev": true + "ajv": { + "version": "6.10.2", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", + "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", + "dev": true, + "requires": { + "fast-deep-equal": "^2.0.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } }, "string-width": { "version": "3.1.0", @@ -7615,15 +7596,6 @@ "is-fullwidth-code-point": "^2.0.0", "strip-ansi": "^5.1.0" } - }, - "strip-ansi": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", - "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", - "dev": true, - "requires": { - "ansi-regex": "^4.1.0" - } } } }, @@ -8050,6 +8022,12 @@ "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", "dev": true }, + "v8-compile-cache": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", + "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==", + "dev": true + }, "validate-npm-package-license": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", @@ -8247,12 +8225,6 @@ "isexe": "^2.0.0" } }, - "which-module": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", - "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", - "dev": true - }, "wordwrap": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", @@ -8268,45 +8240,6 @@ "errno": "~0.1.7" } }, - "wrap-ansi": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", - "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", - "dev": true, - "requires": { - "ansi-styles": "^3.2.0", - "string-width": "^3.0.0", - "strip-ansi": "^5.0.0" - }, - "dependencies": { - "ansi-regex": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", - "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", - "dev": true - }, - "string-width": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", - "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", - "dev": true, - "requires": { - "emoji-regex": "^7.0.1", - "is-fullwidth-code-point": "^2.0.0", - "strip-ansi": "^5.1.0" - } - }, - "strip-ansi": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", - "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", - "dev": true, - "requires": { - "ansi-regex": "^4.1.0" - } - } - } - }, "wrappy": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", @@ -8328,58 +8261,6 @@ "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", "dev": true }, - "y18n": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", - "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", - "dev": true - }, - "yargs": { - "version": "13.3.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.0.tgz", - "integrity": "sha512-2eehun/8ALW8TLoIl7MVaRUrg+yCnenu8B4kBlRxj3GJGDKU1Og7sMXPNm1BYyM1DOJmTZ4YeN/Nwxv+8XJsUA==", - "dev": true, - "requires": { - "cliui": "^5.0.0", - "find-up": "^3.0.0", - "get-caller-file": "^2.0.1", - "require-directory": "^2.1.1", - "require-main-filename": "^2.0.0", - "set-blocking": "^2.0.0", - "string-width": "^3.0.0", - "which-module": "^2.0.0", - "y18n": "^4.0.0", - "yargs-parser": "^13.1.1" - }, - "dependencies": { - "ansi-regex": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", - "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", - "dev": true - }, - "string-width": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", - "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", - "dev": true, - "requires": { - "emoji-regex": "^7.0.1", - "is-fullwidth-code-point": "^2.0.0", - "strip-ansi": "^5.1.0" - } - }, - "strip-ansi": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", - "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", - "dev": true, - "requires": { - "ansi-regex": "^4.1.0" - } - } - } - }, "yargs-parser": { "version": "13.1.1", "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.1.tgz", diff --git a/package.json b/package.json index ef12f1d..c733bfc 100644 --- a/package.json +++ b/package.json @@ -32,18 +32,19 @@ "@babel/plugin-proposal-object-rest-spread": "^7.4.0", "@babel/preset-env": "^7.5.4", "@babel/preset-react": "^7.0.0", - "babel-eslint": "^10.0.2", + "babel-eslint": "^10.0.3", "babel-loader": "^8.0.6", "component-playground": "^3.0.0", "css-loader": "^1.0.1", - "eslint": "^5.16.0", - "eslint-config-prettier": "^3.6.0", - "eslint-plugin-import": "^2.16.0", - "eslint-plugin-react": "^7.12.4", + "eslint": "^6.2.2", + "eslint-config-prettier": "^6.1.0", + "eslint-plugin-import": "^2.18.2", + "eslint-plugin-react": "^7.14.3", "npm-run-all": "^4.1.5", - "prettier": "^1.16.4", + "prettier": "^1.18.2", "prop-types": "^15.7.2", "react": "^16.8.6", + "react-docgen": "^4.1.1", "react-dom": "^16.8.6", "style-loader": "^0.23.1", "styled-jsx": "^3.1.1", From 121427d100b1d32cff0dd58d208ef00171374a68 Mon Sep 17 00:00:00 2001 From: bcliang Date: Tue, 27 Aug 2019 12:59:50 -0700 Subject: [PATCH 5/7] fix tests to match dash[testing] fixture updates --- tests/requirements.txt | 4 +++- tests/test_component.py | 4 ++-- tests/test_extend_maxpoints.py | 4 ++-- tests/test_extend_then_add.py | 4 ++-- tests/test_extend_trace_selectively.py | 4 ++-- tests/test_multiple_trace_types.py | 4 ++-- 6 files changed, 13 insertions(+), 11 deletions(-) diff --git a/tests/requirements.txt b/tests/requirements.txt index 3ee84ef..54b7c68 100644 --- a/tests/requirements.txt +++ b/tests/requirements.txt @@ -2,7 +2,9 @@ # Switch into a virtual environment # pip install -r requirements.txt -chromedriver-binary==74.0.3729.6 +chromedriver-binary==76.0.3809.126 +dash[testing] +pytest>=5.1.1 ipdb percy selenium diff --git a/tests/test_component.py b/tests/test_component.py index ec3d193..c616350 100644 --- a/tests/test_component.py +++ b/tests/test_component.py @@ -13,7 +13,7 @@ # extending a trace works -def test_component(dash_duo): +def test_extg001_render_component(dash_duo): app = dash.Dash(__name__) app.layout = html.Div([ deg.ExtendableGraph( @@ -49,7 +49,7 @@ def trace_will_extend(n_intervals): def display_data(trigger, figure): return json.dumps(figure['data'][0]) - dash_duo.startServer(app) + dash_duo.start_server(app) graph = dash_duo.find_element("#trace_will_extend") comparison = json.dumps( diff --git a/tests/test_extend_maxpoints.py b/tests/test_extend_maxpoints.py index b741eb7..2390328 100644 --- a/tests/test_extend_maxpoints.py +++ b/tests/test_extend_maxpoints.py @@ -13,7 +13,7 @@ # extending a trace works -def test_extend_maxpoints(dash_duo): +def test_extg002_define_maxpoints(dash_duo): app = dash.Dash(__name__) app.layout = html.Div([ deg.ExtendableGraph( @@ -49,7 +49,7 @@ def trace_will_extend_then_add(n_intervals, figure): def display_data(trigger, figure): return json.dumps(figure['data']) - dash_duo.startServer(app) + dash_duo.start_server(app) graph = dash_duo.find_element("#trace_will_extend_with_window") comparison = json.dumps([ diff --git a/tests/test_extend_then_add.py b/tests/test_extend_then_add.py index eccdfc9..b3aff3c 100644 --- a/tests/test_extend_then_add.py +++ b/tests/test_extend_then_add.py @@ -13,7 +13,7 @@ # extending a trace works -def test_extend_then_add_trace(dash_duo): +def test_extg003_extend_then_add_trace(dash_duo): app = dash.Dash(__name__) app.layout = html.Div([ deg.ExtendableGraph( @@ -54,7 +54,7 @@ def trace_will_extend_then_add(n_intervals): def display_data(trigger, figure): return json.dumps(figure['data']) - dash_duo.startServer(app) + dash_duo.start_server(app) graph = dash_duo.find_element("#trace_will_extend_and_add") comparison = json.dumps([ diff --git a/tests/test_extend_trace_selectively.py b/tests/test_extend_trace_selectively.py index 4d11b93..53fd55e 100644 --- a/tests/test_extend_trace_selectively.py +++ b/tests/test_extend_trace_selectively.py @@ -13,7 +13,7 @@ # extending a trace works -def test_extend_trace_selectively(dash_duo): +def test_extg004_extend_trace_selectively(dash_duo): app = dash.Dash(__name__) app.layout = html.Div([ deg.ExtendableGraph(id='extend_trace_selectively', @@ -47,7 +47,7 @@ def display_data(trigger, figure): return json.dumps(figure['data']) - dash_duo.startServer(app) + dash_duo.start_server(app) graph = dash_duo.find_element("#extend_trace_selectively") comparison = json.dumps( diff --git a/tests/test_multiple_trace_types.py b/tests/test_multiple_trace_types.py index 20667c0..9040739 100644 --- a/tests/test_multiple_trace_types.py +++ b/tests/test_multiple_trace_types.py @@ -13,7 +13,7 @@ # extending a trace works -def test_multiple_trace_types(dash_duo): +def test_extg005_multiple_trace_types(dash_duo): app = dash.Dash(__name__) app.layout = html.Div([ deg.ExtendableGraph(id='multi_trace_types', figure=dict(data=[])), @@ -43,7 +43,7 @@ def display_data(trigger, figure): return json.dumps(figure['data']) - dash_duo.startServer(app) + dash_duo.start_server(app) graph = dash_duo.find_element("#multi_trace_types") comparison = json.dumps( From 4db8f0bdf9489c87539fbb432e99b7a2b687965b Mon Sep 17 00:00:00 2001 From: bcliang Date: Wed, 28 Aug 2019 08:21:47 -0700 Subject: [PATCH 6/7] stick with !== for large objects --- README.md | 4 ++-- src/lib/components/ExtendableGraph.react.js | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 7f880db..e593cad 100644 --- a/README.md +++ b/README.md @@ -26,13 +26,13 @@ $ pip install dash-extendable-graph General examples may be found in `usage.py` -### extendData keys +### extendData properties 1. `updateData` [list]: a list of dictionaries, each containing representing trace data (e.g `dict(x=[1], y=[1])`) 2. `traceIndices` [list, optional]: identify the traces that should be extended. If the specified trace index does not exist, the corresponding trace shall be appended to the figure. 3. `maxPoints` [number, optional]: define the maximum number of points to plot in the figure (per trace). -Based on the [`Plotly.extendTraces()` api](https://github.com/plotly/plotly.js/blob/master/src/plot_api/plot_api.js#L979). +Based on the [`Plotly.extendTraces()` api](https://github.com/plotly/plotly.js/blob/master/src/plot_api/plot_api.js#L979). However, the `updateData` key has been modified to better match the contents of `Plotly.plot()` (e.g. `Graph.figure`). Aside from following dash-familiar styling, this component allows the user to extend traces of different types in a single call (`Plotly.extendTraces()` takes a map of key:val and assumes all traces will share the same data keys). ### Code diff --git a/src/lib/components/ExtendableGraph.react.js b/src/lib/components/ExtendableGraph.react.js index 89298c6..5d2e3f9 100644 --- a/src/lib/components/ExtendableGraph.react.js +++ b/src/lib/components/ExtendableGraph.react.js @@ -281,7 +281,7 @@ class ExtendableGraph extends Component { return; } - const figureChanged = !equals(this.props.figure, nextProps.figure); + const figureChanged = this.props.figure !== nextProps.figure; if (figureChanged) { this.plot(nextProps); } From 12864e65722106cbbc157d980b3c268480452540 Mon Sep 17 00:00:00 2001 From: bcliang Date: Wed, 28 Aug 2019 08:27:12 -0700 Subject: [PATCH 7/7] npm build 1.0.3 --- README.md | 6 ++- dash_extendable_graph/ExtendableGraph.py | 14 +++--- .../dash_extendable_graph.dev.js | 2 +- .../dash_extendable_graph.min.js | 2 +- dash_extendable_graph/metadata.json | 47 +++++++++++++++++-- dash_extendable_graph/package.json | 15 +++--- 6 files changed, 64 insertions(+), 22 deletions(-) diff --git a/README.md b/README.md index e593cad..f789630 100644 --- a/README.md +++ b/README.md @@ -115,7 +115,11 @@ $ python usage.py ## Tests -- Run the tests with `$pytest tests` +Integration tests for the component can be found in `tests/` + +`$pytest --headless tests` + +(note: the `--headless` param runs tests without the GUI) ### Create a production build and publish: diff --git a/dash_extendable_graph/ExtendableGraph.py b/dash_extendable_graph/ExtendableGraph.py index d2ad605..5e0228b 100644 --- a/dash_extendable_graph/ExtendableGraph.py +++ b/dash_extendable_graph/ExtendableGraph.py @@ -73,7 +73,7 @@ class ExtendableGraph(Component): unless a separate `edits` config item overrides individual parts - edits (dict; optional): A set of editable properties. edits has the following type: dict containing keys 'annotationPosition', 'annotationTail', 'annotationText', 'axisTitleText', 'colorbarPosition', 'colorbarTitleText', 'legendPosition', 'legendText', 'shapePosition', 'titleText'. Those keys have the following types: - - annotationPosition (boolean; optional): annotationPosition: the main anchor of the annotation, which is the + - annotationPosition (boolean; optional): The main anchor of the annotation, which is the text (if no arrow) or the arrow (which drags the whole thing leaving the arrow length & direction unchanged) - annotationTail (boolean; optional): Just for annotations with arrows, change the length and direction of the arrow @@ -107,12 +107,12 @@ class ExtendableGraph(Component): - modeBarButtonsToRemove (list; optional): Remove mode bar button by name. All modebar button names at https://github.com/plotly/plotly.js/blob/master/src/components/modebar/buttons.js Common names include: - - sendDataToCloud -- (2D): zoom2d, pan2d, select2d, lasso2d, zoomIn2d, zoomOut2d, autoScale2d, resetScale2d -- (Cartesian): hoverClosestCartesian, hoverCompareCartesian -- (3D): zoom3d, pan3d, orbitRotation, tableRotation, handleDrag3d, resetCameraDefault3d, resetCameraLastSave3d, hoverClosest3d -- (Geo): zoomInGeo, zoomOutGeo, resetGeo, hoverClosestGeo -- hoverClosestGl2d, hoverClosestPie, toggleHover, resetViews +sendDataToCloud; +(2D) zoom2d, pan2d, select2d, lasso2d, zoomIn2d, zoomOut2d, autoScale2d, resetScale2d; +(Cartesian) hoverClosestCartesian, hoverCompareCartesian; +(3D) zoom3d, pan3d, orbitRotation, tableRotation, handleDrag3d, resetCameraDefault3d, resetCameraLastSave3d, hoverClosest3d; +(Geo) zoomInGeo, zoomOutGeo, resetGeo, hoverClosestGeo; +hoverClosestGl2d, hoverClosestPie, toggleHover, resetViews. - modeBarButtonsToAdd (list; optional): Add mode bar button using config objects - modeBarButtons (boolean | number | string | dict | list; optional): Fully custom mode bar buttons as nested array, where the outer arrays represents button groups, and diff --git a/dash_extendable_graph/dash_extendable_graph.dev.js b/dash_extendable_graph/dash_extendable_graph.dev.js index 1206275..d4438e5 100644 --- a/dash_extendable_graph/dash_extendable_graph.dev.js +++ b/dash_extendable_graph/dash_extendable_graph.dev.js @@ -4043,7 +4043,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _int /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! prop-types */ \"prop-types\");\n/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ramda */ \"./node_modules/ramda/es/index.js\");\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); }\n\nfunction _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\n\n/* global Plotly:true */\n\nvar filterEventData = function filterEventData(gd, eventData, event) {\n var filteredEventData;\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"contains\"])(event, ['click', 'hover', 'selected'])) {\n var points = [];\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(eventData)) {\n return null;\n }\n /*\r\n * remove `data`, `layout`, `xaxis`, etc\r\n * objects from the event data since they're so big\r\n * and cause JSON stringify ciricular structure errors.\r\n *\r\n * also, pull down the `customdata` point from the data array\r\n * into the event object\r\n */\n\n\n var data = gd.data;\n\n for (var i = 0; i < eventData.points.length; i++) {\n var fullPoint = eventData.points[i];\n var pointData = Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"filter\"])(function (o) {\n return !Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"contains\"])(Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"type\"])(o), ['Object', 'Array']);\n }, fullPoint);\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('curveNumber', fullPoint) && Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('pointNumber', fullPoint) && Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('customdata', data[pointData.curveNumber])) {\n pointData.customdata = data[pointData.curveNumber].customdata[fullPoint.pointNumber];\n } // specific to histogram. see https://github.com/plotly/plotly.js/pull/2113/\n\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('pointNumbers', fullPoint)) {\n pointData.pointNumbers = fullPoint.pointNumbers;\n }\n\n points[i] = pointData;\n }\n\n filteredEventData = {\n points: points\n };\n } else if (event === 'relayout' || event === 'restyle') {\n /*\r\n * relayout shouldn't include any big objects\r\n * it will usually just contain the ranges of the axes like\r\n * \"xaxis.range[0]\": 0.7715822247381828,\r\n * \"xaxis.range[1]\": 3.0095292008680063`\r\n */\n filteredEventData = eventData;\n }\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('range', eventData)) {\n filteredEventData.range = eventData.range;\n }\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('lassoPoints', eventData)) {\n filteredEventData.lassoPoints = eventData.lassoPoints;\n }\n\n return filteredEventData;\n};\n\nfunction generateId() {\n var charAmount = 36;\n var length = 7;\n return 'graph-' + Math.random().toString(charAmount).substring(2, length);\n}\n/**\r\n * ExtendableGraph can be used to render any plotly.js-powered data vis.\r\n *\r\n * You can define callbacks based on user interaction with ExtendableGraphs such\r\n * as hovering, clicking or selecting\r\n */\n\n\nvar ExtendableGraphWithDefaults = function ExtendableGraphWithDefaults(props) {\n var id = props.id ? props.id : generateId();\n return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(ExtendableGraph, _extends({}, props, {\n id: id\n }));\n};\n\nvar ExtendableGraph =\n/*#__PURE__*/\nfunction (_Component) {\n _inherits(ExtendableGraph, _Component);\n\n function ExtendableGraph(props) {\n var _this;\n\n _classCallCheck(this, ExtendableGraph);\n\n _this = _possibleConstructorReturn(this, _getPrototypeOf(ExtendableGraph).call(this, props));\n _this.bindEvents = _this.bindEvents.bind(_assertThisInitialized(_this));\n _this._hasPlotted = false;\n _this.graphResize = _this.graphResize.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n _createClass(ExtendableGraph, [{\n key: \"plot\",\n value: function plot(props) {\n var _this2 = this;\n\n var figure = props.figure,\n id = props.id,\n animate = props.animate,\n animation_options = props.animation_options,\n config = props.config;\n var gd = document.getElementById(id);\n\n if (animate && this._hasPlotted && figure.data.length === gd.data.length) {\n return Plotly.animate(id, figure, animation_options);\n }\n\n return Plotly.react(id, {\n data: figure.data,\n layout: Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"clone\"])(figure.layout),\n frames: figure.frames,\n config: config\n }).then(function () {\n if (!_this2._hasPlotted) {\n var _gd = document.getElementById(id);\n\n if (_gd) {\n _this2.bindEvents();\n\n Plotly.Plots.resize(_gd);\n _this2._hasPlotted = true;\n }\n }\n });\n }\n }, {\n key: \"extend\",\n value: function extend(props) {\n var id = props.id,\n extendData = props.extendData;\n var gd = document.getElementById(id);\n var updateData, traceIndices, maxPoints;\n\n if (extendData) {\n var createDataObject = function createDataObject(data) {\n var dataprops = Object.keys(data);\n var ret = {};\n\n for (var i = 0; i < dataprops.length; i++) {\n ret[dataprops[i]] = [data[dataprops[i]]];\n }\n\n return ret;\n };\n\n if (gd.data.length < 1) {\n // figure has no pre-existing data. redirect to plot()\n props.figure.data = extendData;\n return this.plot(props);\n }\n\n if (Array.isArray(extendData) && Array.isArray(extendData[0])) {\n var _extendData = _slicedToArray(extendData, 3);\n\n updateData = _extendData[0];\n traceIndices = _extendData[1];\n maxPoints = _extendData[2];\n } else {\n updateData = extendData;\n }\n\n if (!traceIndices) {\n traceIndices = Array.from(Array(updateData.length).keys());\n }\n\n var _iteratorNormalCompletion = true;\n var _didIteratorError = false;\n var _iteratorError = undefined;\n\n try {\n for (var _iterator = updateData.entries()[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {\n var _step$value = _slicedToArray(_step.value, 2),\n i = _step$value[0],\n value = _step$value[1];\n\n var updateObject = createDataObject(value);\n\n if (i < updateData.length - 1) {\n if (traceIndices[i] < gd.data.length) {\n Plotly.extendTraces(id, updateObject, [traceIndices[i]], maxPoints);\n } else {\n Plotly.addTraces(id, value);\n }\n } else {\n if (traceIndices[i] < gd.data.length) {\n return Plotly.extendTraces(id, updateObject, [traceIndices[i]], maxPoints);\n }\n\n return Plotly.addTraces(id, value);\n }\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally {\n try {\n if (!_iteratorNormalCompletion && _iterator[\"return\"] != null) {\n _iterator[\"return\"]();\n }\n } finally {\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n }\n\n return this.plot(props);\n }\n }, {\n key: \"graphResize\",\n value: function graphResize() {\n var graphDiv = document.getElementById(this.props.id);\n\n if (graphDiv) {\n Plotly.Plots.resize(graphDiv);\n }\n }\n }, {\n key: \"bindEvents\",\n value: function bindEvents() {\n var _this$props = this.props,\n id = _this$props.id,\n setProps = _this$props.setProps,\n clear_on_unhover = _this$props.clear_on_unhover;\n var gd = document.getElementById(id);\n gd.on('plotly_click', function (eventData) {\n var clickData = filterEventData(gd, eventData, 'click');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(clickData)) {\n setProps({\n clickData: clickData\n });\n }\n });\n gd.on('plotly_clickannotation', function (eventData) {\n var clickAnnotationData = Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"omit\"])(['event', 'fullAnnotation'], eventData);\n setProps({\n clickAnnotationData: clickAnnotationData\n });\n });\n gd.on('plotly_hover', function (eventData) {\n var hoverData = filterEventData(gd, eventData, 'hover');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(hoverData)) {\n setProps({\n hoverData: hoverData\n });\n }\n });\n gd.on('plotly_selected', function (eventData) {\n var selectedData = filterEventData(gd, eventData, 'selected');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(selectedData)) {\n setProps({\n selectedData: selectedData\n });\n }\n });\n gd.on('plotly_deselect', function () {\n setProps({\n selectedData: null\n });\n });\n gd.on('plotly_relayout', function (eventData) {\n var relayoutData = filterEventData(gd, eventData, 'relayout');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(relayoutData)) {\n setProps({\n relayoutData: relayoutData\n });\n }\n });\n gd.on('plotly_restyle', function (eventData) {\n var restyleData = filterEventData(gd, eventData, 'restyle');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(restyleData)) {\n setProps({\n restyleData: restyleData\n });\n }\n });\n gd.on('plotly_unhover', function () {\n if (clear_on_unhover) {\n setProps({\n hoverData: null\n });\n }\n });\n }\n }, {\n key: \"componentDidMount\",\n value: function componentDidMount() {\n var _this3 = this;\n\n this.plot(this.props).then(function () {\n window.addEventListener('resize', _this3.graphResize);\n });\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n if (this.eventEmitter) {\n this.eventEmitter.removeAllListeners();\n }\n\n window.removeEventListener('resize', this.graphResize);\n }\n }, {\n key: \"shouldComponentUpdate\",\n value: function shouldComponentUpdate(nextProps) {\n return this.props.id !== nextProps.id || JSON.stringify(this.props.style) !== JSON.stringify(nextProps.style);\n }\n }, {\n key: \"componentWillReceiveProps\",\n value: function componentWillReceiveProps(nextProps) {\n var idChanged = this.props.id !== nextProps.id;\n\n if (idChanged) {\n /*\r\n * then the dom needs to get re-rendered with a new ID.\r\n * the graph will get updated in componentDidUpdate\r\n */\n return;\n }\n\n var figureChanged = this.props.figure !== nextProps.figure;\n\n if (figureChanged) {\n this.plot(nextProps);\n }\n\n var extendDataChanged = this.props.extendData !== nextProps.extendData;\n\n if (extendDataChanged) {\n this.extend(nextProps);\n }\n }\n }, {\n key: \"componentDidUpdate\",\n value: function componentDidUpdate(prevProps) {\n if (prevProps.id !== this.props.id) {\n this.plot(this.props);\n }\n }\n }, {\n key: \"render\",\n value: function render() {\n var _this$props2 = this.props,\n className = _this$props2.className,\n id = _this$props2.id,\n style = _this$props2.style,\n loading_state = _this$props2.loading_state;\n return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"div\", {\n key: id,\n id: id,\n \"data-dash-is-loading\": loading_state && loading_state.is_loading || undefined,\n style: style,\n className: className\n });\n }\n }]);\n\n return ExtendableGraph;\n}(react__WEBPACK_IMPORTED_MODULE_0__[\"Component\"]);\n\nvar graphPropTypes = {\n /**\r\n * The ID of this component, used to identify dash components\r\n * in callbacks. The ID needs to be unique across all of the\r\n * components in an app.\r\n */\n id: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Data from latest click event. Read-only.\r\n */\n clickData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Data from latest click annotation event. Read-only.\r\n */\n clickAnnotationData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Data from latest hover event. Read-only.\r\n */\n hoverData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * If True, `clear_on_unhover` will clear the `hoverData` property\r\n * when the user \"unhovers\" from a point.\r\n * If False, then the `hoverData` property will be equal to the\r\n * data from the last point that was hovered over.\r\n */\n clear_on_unhover: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Data from latest select event. Read-only.\r\n */\n selectedData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Data from latest relayout event which occurs\r\n * when the user zooms or pans on the plot or other\r\n * layout-level edits. Has the form `{: }`\r\n * describing the changes made. Read-only.\r\n */\n relayoutData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Data that should be appended to existing traces. Has the form\r\n * `[updateData, traceIndices, maxPoints]`, where `updateData` is an array\r\n * containing data objects to extend, `traceIndices` (optional) is an array\r\n * of trace indices that should be extended, and `maxPoints` (optional) is\r\n * either an integer defining the maximum number of points allowed or an\r\n * object with key:value pairs matching `updateData`\r\n * Reference the Plotly.extendTraces API for full usage:\r\n * https://plot.ly/javascript/plotlyjs-function-reference/#plotlyextendtraces\r\n */\n extendData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.oneOfType([prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.array, prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object]),\n\n /**\r\n * Data from latest restyle event which occurs\r\n * when the user toggles a legend item, changes\r\n * parcoords selections, or other trace-level edits.\r\n * Has the form `[edits, indices]`, where `edits` is an object\r\n * `{: }` describing the changes made,\r\n * and `indices` is an array of trace indices that were edited.\r\n * Read-only.\r\n */\n restyleData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.array,\n\n /**\r\n * Plotly `figure` object. See schema:\r\n * https://plot.ly/javascript/reference\r\n *\r\n * `config` is set separately by the `config` property\r\n */\n figure: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.exact({\n data: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object),\n layout: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n frames: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object)\n }),\n\n /**\r\n * Generic style overrides on the plot div\r\n */\n style: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * className of the parent div\r\n */\n className: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Beta: If true, animate between updates using\r\n * plotly.js's `animate` function\r\n */\n animate: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Beta: Object containing animation settings.\r\n * Only applies if `animate` is `true`\r\n */\n animation_options: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Plotly.js config options.\r\n * See https://plot.ly/javascript/configuration-options/\r\n * for more info.\r\n */\n config: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.exact({\n /**\r\n * No interactivity, for export or image generation\r\n */\n staticPlot: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Base URL for a Plotly cloud instance, if `showSendToCloud` is enabled\r\n */\n plotlyServerURL: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * We can edit titles, move annotations, etc - sets all pieces of `edits`\r\n * unless a separate `edits` config item overrides individual parts\r\n */\n editable: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * A set of editable properties\r\n */\n edits: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.exact({\n /**\r\n * annotationPosition: the main anchor of the annotation, which is the\r\n * text (if no arrow) or the arrow (which drags the whole thing leaving\r\n * the arrow length & direction unchanged)\r\n */\n annotationPosition: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Just for annotations with arrows, change the length and direction of the arrow\r\n */\n annotationTail: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n annotationText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n axisTitleText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n colorbarPosition: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n colorbarTitleText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n legendPosition: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Edit the trace name fields from the legend\r\n */\n legendText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n shapePosition: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * The global `layout.title`\r\n */\n titleText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool\n }),\n\n /**\r\n * DO autosize once regardless of layout.autosize\r\n * (use default width or height values otherwise)\r\n */\n autosizable: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Whether to change layout size when the window size changes\r\n */\n responsive: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Set the length of the undo/redo queue\r\n */\n queueLength: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * If we DO autosize, do we fill the container or the screen?\r\n */\n fillFrame: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * If we DO autosize, set the frame margins in percents of plot size\r\n */\n frameMargins: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * Mousewheel or two-finger scroll zooms the plot\r\n */\n scrollZoom: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Double click interaction (false, 'reset', 'autosize' or 'reset+autosize')\r\n */\n doubleClick: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.oneOf([false, 'reset', 'autosize', 'reset+autosize']),\n\n /**\r\n * New users see some hints about interactivity\r\n */\n showTips: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Enable axis pan/zoom drag handles\r\n */\n showAxisDragHandles: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Enable direct range entry at the pan/zoom drag points\r\n * (drag handles must be enabled above)\r\n */\n showAxisRangeEntryBoxes: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Link to open this plot in plotly\r\n */\n showLink: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * If we show a link, does it contain data or just link to a plotly file?\r\n */\n sendData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Text appearing in the sendData link\r\n */\n linkText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Display the mode bar (true, false, or 'hover')\r\n */\n displayModeBar: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.oneOf([true, false, 'hover']),\n\n /**\r\n * Should we include a modebar button to send this data to a\r\n * Plotly Cloud instance, linked by `plotlyServerURL`.\r\n * By default this is false.\r\n */\n showSendToCloud: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Remove mode bar button by name.\r\n * All modebar button names at https://github.com/plotly/plotly.js/blob/master/src/components/modebar/buttons.js\r\n * Common names include:\r\n * - sendDataToCloud\r\n * - (2D): zoom2d, pan2d, select2d, lasso2d, zoomIn2d, zoomOut2d, autoScale2d, resetScale2d\r\n * - (Cartesian): hoverClosestCartesian, hoverCompareCartesian\r\n * - (3D): zoom3d, pan3d, orbitRotation, tableRotation, handleDrag3d, resetCameraDefault3d, resetCameraLastSave3d, hoverClosest3d\r\n * - (Geo): zoomInGeo, zoomOutGeo, resetGeo, hoverClosestGeo\r\n * - hoverClosestGl2d, hoverClosestPie, toggleHover, resetViews\r\n */\n modeBarButtonsToRemove: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.array,\n\n /**\r\n * Add mode bar button using config objects\r\n */\n modeBarButtonsToAdd: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.array,\n\n /**\r\n * Fully custom mode bar buttons as nested array,\r\n * where the outer arrays represents button groups, and\r\n * the inner arrays have buttons config objects or names of default buttons\r\n */\n modeBarButtons: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.any,\n\n /**\r\n * Modifications to how the toImage modebar button works\r\n */\n toImageButtonOptions: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.exact({\n /**\r\n * The file format to create\r\n */\n format: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.oneOf(['jpeg', 'png', 'webp', 'svg']),\n\n /**\r\n * The name given to the downloaded file\r\n */\n filename: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Width of the downloaded file, in px\r\n */\n width: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * Height of the downloaded file, in px\r\n */\n height: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * Extra resolution to give the file after\r\n * rendering it with the given width and height\r\n */\n scale: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number\n }),\n\n /**\r\n * Add the plotly logo on the end of the mode bar\r\n */\n displaylogo: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Add the plotly logo even with no modebar\r\n */\n watermark: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Increase the pixel ratio for Gl plot images\r\n */\n plotGlPixelRatio: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * URL to topojson files used in geo charts\r\n */\n topojsonURL: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Mapbox access token (required to plot mapbox trace types)\r\n * If using an Mapbox Atlas server, set this option to '',\r\n * so that plotly.js won't attempt to authenticate to the public Mapbox server.\r\n */\n mapboxAccessToken: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.any,\n\n /**\r\n * The locale to use. Locales may be provided with the plot\r\n * (`locales` below) or by loading them on the page, see:\r\n * https://github.com/plotly/plotly.js/blob/master/dist/README.md#to-include-localization\r\n */\n locale: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Localization definitions, if you choose to provide them with the\r\n * plot rather than registering them globally.\r\n */\n locales: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object\n }),\n\n /**\r\n * Function that updates the state tree.\r\n */\n setProps: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.func,\n\n /**\r\n * Object that holds the loading state object coming from dash-renderer\r\n */\n loading_state: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.shape({\n /**\r\n * Determines if the component is loading or not\r\n */\n is_loading: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Holds which property is loading\r\n */\n prop_name: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Holds the name of the component that is loading\r\n */\n component_name: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string\n })\n};\nvar graphDefaultProps = {\n clickData: null,\n clickAnnotationData: null,\n hoverData: null,\n selectedData: null,\n relayoutData: null,\n extendData: null,\n restyleData: null,\n figure: {\n data: [],\n layout: {},\n frames: []\n },\n animate: false,\n animation_options: {\n frame: {\n redraw: false\n },\n transition: {\n duration: 750,\n ease: 'cubic-in-out'\n }\n },\n clear_on_unhover: false,\n config: {}\n};\nExtendableGraphWithDefaults.propTypes = graphPropTypes;\nExtendableGraph.propTypes = graphPropTypes;\nExtendableGraphWithDefaults.defaultProps = graphDefaultProps;\nExtendableGraph.defaultProps = graphDefaultProps;\n/* harmony default export */ __webpack_exports__[\"default\"] = (ExtendableGraphWithDefaults);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_extendable_graph/./src/lib/components/ExtendableGraph.react.js?db56"],"names":["filterEventData","gd","eventData","event","filteredEventData","contains","points","isNil","data","i","length","fullPoint","pointData","filter","o","type","has","curveNumber","customdata","pointNumber","pointNumbers","range","lassoPoints","generateId","charAmount","Math","random","toString","substring","ExtendableGraphWithDefaults","props","id","ExtendableGraph","bindEvents","bind","_hasPlotted","graphResize","figure","animate","animation_options","config","document","getElementById","Plotly","react","layout","clone","frames","then","Plots","resize","extendData","updateData","traceIndices","maxPoints","createDataObject","dataprops","Object","keys","ret","plot","Array","isArray","from","entries","value","updateObject","extendTraces","addTraces","graphDiv","setProps","clear_on_unhover","on","clickData","clickAnnotationData","omit","hoverData","selectedData","relayoutData","restyleData","window","addEventListener","eventEmitter","removeAllListeners","removeEventListener","nextProps","JSON","stringify","style","idChanged","figureChanged","extendDataChanged","extend","prevProps","className","loading_state","is_loading","undefined","Component","graphPropTypes","PropTypes","string","object","bool","oneOfType","array","exact","arrayOf","staticPlot","plotlyServerURL","editable","edits","annotationPosition","annotationTail","annotationText","axisTitleText","colorbarPosition","colorbarTitleText","legendPosition","legendText","shapePosition","titleText","autosizable","responsive","queueLength","number","fillFrame","frameMargins","scrollZoom","doubleClick","oneOf","showTips","showAxisDragHandles","showAxisRangeEntryBoxes","showLink","sendData","linkText","displayModeBar","showSendToCloud","modeBarButtonsToRemove","modeBarButtonsToAdd","modeBarButtons","any","toImageButtonOptions","format","filename","width","height","scale","displaylogo","watermark","plotGlPixelRatio","topojsonURL","mapboxAccessToken","locale","locales","func","shape","prop_name","component_name","graphDefaultProps","frame","redraw","transition","duration","ease","propTypes","defaultProps"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;;AAEA,IAAMA,eAAe,GAAG,SAAlBA,eAAkB,CAACC,EAAD,EAAKC,SAAL,EAAgBC,KAAhB,EAA0B;AAC9C,MAAIC,iBAAJ;;AACA,MAAIC,sDAAQ,CAACF,KAAD,EAAQ,CAAC,OAAD,EAAU,OAAV,EAAmB,UAAnB,CAAR,CAAZ,EAAqD;AACjD,QAAMG,MAAM,GAAG,EAAf;;AAEA,QAAIC,mDAAK,CAACL,SAAD,CAAT,EAAsB;AAClB,aAAO,IAAP;AACH;AAED;;;;;;;;;;AAQA,QAAMM,IAAI,GAAGP,EAAE,CAACO,IAAhB;;AAEA,SAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGP,SAAS,CAACI,MAAV,CAAiBI,MAArC,EAA6CD,CAAC,EAA9C,EAAkD;AAC9C,UAAME,SAAS,GAAGT,SAAS,CAACI,MAAV,CAAiBG,CAAjB,CAAlB;AACA,UAAMG,SAAS,GAAGC,oDAAM,CAAC,UAASC,CAAT,EAAY;AACjC,eAAO,CAACT,sDAAQ,CAACU,kDAAI,CAACD,CAAD,CAAL,EAAU,CAAC,QAAD,EAAW,OAAX,CAAV,CAAhB;AACH,OAFuB,EAErBH,SAFqB,CAAxB;;AAGA,UACIK,iDAAG,CAAC,aAAD,EAAgBL,SAAhB,CAAH,IACAK,iDAAG,CAAC,aAAD,EAAgBL,SAAhB,CADH,IAEAK,iDAAG,CAAC,YAAD,EAAeR,IAAI,CAACI,SAAS,CAACK,WAAX,CAAnB,CAHP,EAIE;AACEL,iBAAS,CAACM,UAAV,GACIV,IAAI,CAACI,SAAS,CAACK,WAAX,CAAJ,CAA4BC,UAA5B,CACIP,SAAS,CAACQ,WADd,CADJ;AAIH,OAd6C,CAgB9C;;;AACA,UAAIH,iDAAG,CAAC,cAAD,EAAiBL,SAAjB,CAAP,EAAoC;AAChCC,iBAAS,CAACQ,YAAV,GAAyBT,SAAS,CAACS,YAAnC;AACH;;AAEDd,YAAM,CAACG,CAAD,CAAN,GAAYG,SAAZ;AACH;;AACDR,qBAAiB,GAAG;AAACE,YAAM,EAANA;AAAD,KAApB;AACH,GAzCD,MAyCO,IAAIH,KAAK,KAAK,UAAV,IAAwBA,KAAK,KAAK,SAAtC,EAAiD;AACpD;;;;;;AAMAC,qBAAiB,GAAGF,SAApB;AACH;;AACD,MAAIc,iDAAG,CAAC,OAAD,EAAUd,SAAV,CAAP,EAA6B;AACzBE,qBAAiB,CAACiB,KAAlB,GAA0BnB,SAAS,CAACmB,KAApC;AACH;;AACD,MAAIL,iDAAG,CAAC,aAAD,EAAgBd,SAAhB,CAAP,EAAmC;AAC/BE,qBAAiB,CAACkB,WAAlB,GAAgCpB,SAAS,CAACoB,WAA1C;AACH;;AACD,SAAOlB,iBAAP;AACH,CA3DD;;AA6DA,SAASmB,UAAT,GAAsB;AAClB,MAAMC,UAAU,GAAG,EAAnB;AACA,MAAMd,MAAM,GAAG,CAAf;AACA,SACI,WACAe,IAAI,CAACC,MAAL,GACKC,QADL,CACcH,UADd,EAEKI,SAFL,CAEe,CAFf,EAEkBlB,MAFlB,CAFJ;AAMH;AAED;;;;;;;;AAMA,IAAMmB,2BAA2B,GAAG,SAA9BA,2BAA8B,CAAAC,KAAK,EAAI;AACzC,MAAMC,EAAE,GAAGD,KAAK,CAACC,EAAN,GAAWD,KAAK,CAACC,EAAjB,GAAsBR,UAAU,EAA3C;AACA,SAAO,2DAAC,eAAD,eAAqBO,KAArB;AAA4B,MAAE,EAAEC;AAAhC,KAAP;AACH,CAHD;;IAKMC,e;;;;;AACF,2BAAYF,KAAZ,EAAmB;AAAA;;AAAA;;AACf,yFAAMA,KAAN;AACA,UAAKG,UAAL,GAAkB,MAAKA,UAAL,CAAgBC,IAAhB,+BAAlB;AACA,UAAKC,WAAL,GAAmB,KAAnB;AACA,UAAKC,WAAL,GAAmB,MAAKA,WAAL,CAAiBF,IAAjB,+BAAnB;AAJe;AAKlB;;;;yBAEIJ,K,EAAO;AAAA;;AAAA,UACDO,MADC,GACiDP,KADjD,CACDO,MADC;AAAA,UACON,EADP,GACiDD,KADjD,CACOC,EADP;AAAA,UACWO,OADX,GACiDR,KADjD,CACWQ,OADX;AAAA,UACoBC,iBADpB,GACiDT,KADjD,CACoBS,iBADpB;AAAA,UACuCC,MADvC,GACiDV,KADjD,CACuCU,MADvC;AAER,UAAMvC,EAAE,GAAGwC,QAAQ,CAACC,cAAT,CAAwBX,EAAxB,CAAX;;AAEA,UACIO,OAAO,IACP,KAAKH,WADL,IAEAE,MAAM,CAAC7B,IAAP,CAAYE,MAAZ,KAAuBT,EAAE,CAACO,IAAH,CAAQE,MAHnC,EAIE;AACE,eAAOiC,MAAM,CAACL,OAAP,CAAeP,EAAf,EAAmBM,MAAnB,EAA2BE,iBAA3B,CAAP;AACH;;AACD,aAAOI,MAAM,CAACC,KAAP,CAAab,EAAb,EAAiB;AACpBvB,YAAI,EAAE6B,MAAM,CAAC7B,IADO;AAEpBqC,cAAM,EAAEC,mDAAK,CAACT,MAAM,CAACQ,MAAR,CAFO;AAGpBE,cAAM,EAAEV,MAAM,CAACU,MAHK;AAIpBP,cAAM,EAAEA;AAJY,OAAjB,EAKJQ,IALI,CAKC,YAAM;AACV,YAAI,CAAC,MAAI,CAACb,WAAV,EAAuB;AACnB,cAAMlC,GAAE,GAAGwC,QAAQ,CAACC,cAAT,CAAwBX,EAAxB,CAAX;;AACA,cAAI9B,GAAJ,EAAQ;AACJ,kBAAI,CAACgC,UAAL;;AACAU,kBAAM,CAACM,KAAP,CAAaC,MAAb,CAAoBjD,GAApB;AACA,kBAAI,CAACkC,WAAL,GAAmB,IAAnB;AACH;AACJ;AACJ,OAdM,CAAP;AAeH;;;2BAEML,K,EAAO;AAAA,UACHC,EADG,GACeD,KADf,CACHC,EADG;AAAA,UACCoB,UADD,GACerB,KADf,CACCqB,UADD;AAEV,UAAMlD,EAAE,GAAGwC,QAAQ,CAACC,cAAT,CAAwBX,EAAxB,CAAX;AACA,UAAIqB,UAAJ,EAAgBC,YAAhB,EAA8BC,SAA9B;;AAEA,UAAIH,UAAJ,EAAgB;AAAA,YAiBHI,gBAjBG,GAiBZ,SAASA,gBAAT,CAA0B/C,IAA1B,EAAgC;AAC5B,cAAMgD,SAAS,GAAGC,MAAM,CAACC,IAAP,CAAYlD,IAAZ,CAAlB;AACA,cAAMmD,GAAG,GAAG,EAAZ;;AACA,eAAK,IAAIlD,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAG+C,SAAS,CAAC9C,MAA9B,EAAsCD,CAAC,EAAvC,EAA2C;AACvCkD,eAAG,CAACH,SAAS,CAAC/C,CAAD,CAAV,CAAH,GAAoB,CAACD,IAAI,CAACgD,SAAS,CAAC/C,CAAD,CAAV,CAAL,CAApB;AACH;;AACD,iBAAOkD,GAAP;AACH,SAxBW;;AACZ,YAAI1D,EAAE,CAACO,IAAH,CAAQE,MAAR,GAAiB,CAArB,EAAwB;AACpB;AACAoB,eAAK,CAACO,MAAN,CAAa7B,IAAb,GAAoB2C,UAApB;AACA,iBAAO,KAAKS,IAAL,CAAU9B,KAAV,CAAP;AACH;;AAED,YAAI+B,KAAK,CAACC,OAAN,CAAcX,UAAd,KAA6BU,KAAK,CAACC,OAAN,CAAcX,UAAU,CAAC,CAAD,CAAxB,CAAjC,EAA+D;AAAA,2CACnBA,UADmB;;AAC1DC,oBAD0D;AAC9CC,sBAD8C;AAChCC,mBADgC;AAE9D,SAFD,MAEO;AACHF,oBAAU,GAAGD,UAAb;AACH;;AAED,YAAI,CAACE,YAAL,EAAmB;AACfA,sBAAY,GAAGQ,KAAK,CAACE,IAAN,CAAWF,KAAK,CAACT,UAAU,CAAC1C,MAAZ,CAAL,CAAyBgD,IAAzB,EAAX,CAAf;AACH;;AAfW;AAAA;AAAA;;AAAA;AA0BZ,+BAAyBN,UAAU,CAACY,OAAX,EAAzB,8HAA+C;AAAA;AAAA,gBAAnCvD,CAAmC;AAAA,gBAAhCwD,KAAgC;;AAC3C,gBAAMC,YAAY,GAAGX,gBAAgB,CAACU,KAAD,CAArC;;AACA,gBAAIxD,CAAC,GAAG2C,UAAU,CAAC1C,MAAX,GAAoB,CAA5B,EAA+B;AAC3B,kBAAI2C,YAAY,CAAC5C,CAAD,CAAZ,GAAkBR,EAAE,CAACO,IAAH,CAAQE,MAA9B,EAAsC;AAClCiC,sBAAM,CAACwB,YAAP,CACIpC,EADJ,EAEImC,YAFJ,EAGI,CAACb,YAAY,CAAC5C,CAAD,CAAb,CAHJ,EAII6C,SAJJ;AAMH,eAPD,MAOO;AACHX,sBAAM,CAACyB,SAAP,CAAiBrC,EAAjB,EAAqBkC,KAArB;AACH;AACJ,aAXD,MAWO;AACH,kBAAIZ,YAAY,CAAC5C,CAAD,CAAZ,GAAkBR,EAAE,CAACO,IAAH,CAAQE,MAA9B,EAAsC;AAClC,uBAAOiC,MAAM,CAACwB,YAAP,CACHpC,EADG,EAEHmC,YAFG,EAGH,CAACb,YAAY,CAAC5C,CAAD,CAAb,CAHG,EAIH6C,SAJG,CAAP;AAMH;;AACD,qBAAOX,MAAM,CAACyB,SAAP,CAAiBrC,EAAjB,EAAqBkC,KAArB,CAAP;AACH;AACJ;AAlDW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAmDf;;AAED,aAAO,KAAKL,IAAL,CAAU9B,KAAV,CAAP;AACH;;;kCAEa;AACV,UAAMuC,QAAQ,GAAG5B,QAAQ,CAACC,cAAT,CAAwB,KAAKZ,KAAL,CAAWC,EAAnC,CAAjB;;AACA,UAAIsC,QAAJ,EAAc;AACV1B,cAAM,CAACM,KAAP,CAAaC,MAAb,CAAoBmB,QAApB;AACH;AACJ;;;iCAEY;AAAA,wBACgC,KAAKvC,KADrC;AAAA,UACFC,EADE,eACFA,EADE;AAAA,UACEuC,QADF,eACEA,QADF;AAAA,UACYC,gBADZ,eACYA,gBADZ;AAGT,UAAMtE,EAAE,GAAGwC,QAAQ,CAACC,cAAT,CAAwBX,EAAxB,CAAX;AAEA9B,QAAE,CAACuE,EAAH,CAAM,cAAN,EAAsB,UAAAtE,SAAS,EAAI;AAC/B,YAAMuE,SAAS,GAAGzE,eAAe,CAACC,EAAD,EAAKC,SAAL,EAAgB,OAAhB,CAAjC;;AACA,YAAI,CAACK,mDAAK,CAACkE,SAAD,CAAV,EAAuB;AACnBH,kBAAQ,CAAC;AAACG,qBAAS,EAATA;AAAD,WAAD,CAAR;AACH;AACJ,OALD;AAMAxE,QAAE,CAACuE,EAAH,CAAM,wBAAN,EAAgC,UAAAtE,SAAS,EAAI;AACzC,YAAMwE,mBAAmB,GAAGC,kDAAI,CAC5B,CAAC,OAAD,EAAU,gBAAV,CAD4B,EAE5BzE,SAF4B,CAAhC;AAIAoE,gBAAQ,CAAC;AAACI,6BAAmB,EAAnBA;AAAD,SAAD,CAAR;AACH,OAND;AAOAzE,QAAE,CAACuE,EAAH,CAAM,cAAN,EAAsB,UAAAtE,SAAS,EAAI;AAC/B,YAAM0E,SAAS,GAAG5E,eAAe,CAACC,EAAD,EAAKC,SAAL,EAAgB,OAAhB,CAAjC;;AACA,YAAI,CAACK,mDAAK,CAACqE,SAAD,CAAV,EAAuB;AACnBN,kBAAQ,CAAC;AAACM,qBAAS,EAATA;AAAD,WAAD,CAAR;AACH;AACJ,OALD;AAMA3E,QAAE,CAACuE,EAAH,CAAM,iBAAN,EAAyB,UAAAtE,SAAS,EAAI;AAClC,YAAM2E,YAAY,GAAG7E,eAAe,CAACC,EAAD,EAAKC,SAAL,EAAgB,UAAhB,CAApC;;AACA,YAAI,CAACK,mDAAK,CAACsE,YAAD,CAAV,EAA0B;AACtBP,kBAAQ,CAAC;AAACO,wBAAY,EAAZA;AAAD,WAAD,CAAR;AACH;AACJ,OALD;AAMA5E,QAAE,CAACuE,EAAH,CAAM,iBAAN,EAAyB,YAAM;AAC3BF,gBAAQ,CAAC;AAACO,sBAAY,EAAE;AAAf,SAAD,CAAR;AACH,OAFD;AAGA5E,QAAE,CAACuE,EAAH,CAAM,iBAAN,EAAyB,UAAAtE,SAAS,EAAI;AAClC,YAAM4E,YAAY,GAAG9E,eAAe,CAACC,EAAD,EAAKC,SAAL,EAAgB,UAAhB,CAApC;;AACA,YAAI,CAACK,mDAAK,CAACuE,YAAD,CAAV,EAA0B;AACtBR,kBAAQ,CAAC;AAACQ,wBAAY,EAAZA;AAAD,WAAD,CAAR;AACH;AACJ,OALD;AAMA7E,QAAE,CAACuE,EAAH,CAAM,gBAAN,EAAwB,UAAAtE,SAAS,EAAI;AACjC,YAAM6E,WAAW,GAAG/E,eAAe,CAACC,EAAD,EAAKC,SAAL,EAAgB,SAAhB,CAAnC;;AACA,YAAI,CAACK,mDAAK,CAACwE,WAAD,CAAV,EAAyB;AACrBT,kBAAQ,CAAC;AAACS,uBAAW,EAAXA;AAAD,WAAD,CAAR;AACH;AACJ,OALD;AAMA9E,QAAE,CAACuE,EAAH,CAAM,gBAAN,EAAwB,YAAM;AAC1B,YAAID,gBAAJ,EAAsB;AAClBD,kBAAQ,CAAC;AAACM,qBAAS,EAAE;AAAZ,WAAD,CAAR;AACH;AACJ,OAJD;AAKH;;;wCAEmB;AAAA;;AAChB,WAAKhB,IAAL,CAAU,KAAK9B,KAAf,EAAsBkB,IAAtB,CAA2B,YAAM;AAC7BgC,cAAM,CAACC,gBAAP,CAAwB,QAAxB,EAAkC,MAAI,CAAC7C,WAAvC;AACH,OAFD;AAGH;;;2CAEsB;AACnB,UAAI,KAAK8C,YAAT,EAAuB;AACnB,aAAKA,YAAL,CAAkBC,kBAAlB;AACH;;AACDH,YAAM,CAACI,mBAAP,CAA2B,QAA3B,EAAqC,KAAKhD,WAA1C;AACH;;;0CAEqBiD,S,EAAW;AAC7B,aACI,KAAKvD,KAAL,CAAWC,EAAX,KAAkBsD,SAAS,CAACtD,EAA5B,IACAuD,IAAI,CAACC,SAAL,CAAe,KAAKzD,KAAL,CAAW0D,KAA1B,MAAqCF,IAAI,CAACC,SAAL,CAAeF,SAAS,CAACG,KAAzB,CAFzC;AAIH;;;8CAEyBH,S,EAAW;AACjC,UAAMI,SAAS,GAAG,KAAK3D,KAAL,CAAWC,EAAX,KAAkBsD,SAAS,CAACtD,EAA9C;;AACA,UAAI0D,SAAJ,EAAe;AACX;;;;AAIA;AACH;;AAED,UAAMC,aAAa,GAAG,KAAK5D,KAAL,CAAWO,MAAX,KAAsBgD,SAAS,CAAChD,MAAtD;;AACA,UAAIqD,aAAJ,EAAmB;AACf,aAAK9B,IAAL,CAAUyB,SAAV;AACH;;AAED,UAAMM,iBAAiB,GACnB,KAAK7D,KAAL,CAAWqB,UAAX,KAA0BkC,SAAS,CAAClC,UADxC;;AAEA,UAAIwC,iBAAJ,EAAuB;AACnB,aAAKC,MAAL,CAAYP,SAAZ;AACH;AACJ;;;uCAEkBQ,S,EAAW;AAC1B,UAAIA,SAAS,CAAC9D,EAAV,KAAiB,KAAKD,KAAL,CAAWC,EAAhC,EAAoC;AAChC,aAAK6B,IAAL,CAAU,KAAK9B,KAAf;AACH;AACJ;;;6BAEQ;AAAA,yBACyC,KAAKA,KAD9C;AAAA,UACEgE,SADF,gBACEA,SADF;AAAA,UACa/D,EADb,gBACaA,EADb;AAAA,UACiByD,KADjB,gBACiBA,KADjB;AAAA,UACwBO,aADxB,gBACwBA,aADxB;AAGL,aACI;AACI,WAAG,EAAEhE,EADT;AAEI,UAAE,EAAEA,EAFR;AAGI,gCACKgE,aAAa,IAAIA,aAAa,CAACC,UAAhC,IAA+CC,SAJvD;AAMI,aAAK,EAAET,KANX;AAOI,iBAAS,EAAEM;AAPf,QADJ;AAWH;;;;EA1NyBI,+C;;AA6N9B,IAAMC,cAAc,GAAG;AACnB;;;;;AAKApE,IAAE,EAAEqE,iDAAS,CAACC,MANK;;AAOnB;;;AAGA5B,WAAS,EAAE2B,iDAAS,CAACE,MAVF;;AAYnB;;;AAGA5B,qBAAmB,EAAE0B,iDAAS,CAACE,MAfZ;;AAiBnB;;;AAGA1B,WAAS,EAAEwB,iDAAS,CAACE,MApBF;;AAsBnB;;;;;;AAMA/B,kBAAgB,EAAE6B,iDAAS,CAACG,IA5BT;;AA8BnB;;;AAGA1B,cAAY,EAAEuB,iDAAS,CAACE,MAjCL;;AAmCnB;;;;;;AAMAxB,cAAY,EAAEsB,iDAAS,CAACE,MAzCL;;AA2CnB;;;;;;;;;;AAUAnD,YAAU,EAAEiD,iDAAS,CAACI,SAAV,CAAoB,CAACJ,iDAAS,CAACK,KAAX,EAAkBL,iDAAS,CAACE,MAA5B,CAApB,CArDO;;AAuDnB;;;;;;;;;AASAvB,aAAW,EAAEqB,iDAAS,CAACK,KAhEJ;;AAkEnB;;;;;;AAMApE,QAAM,EAAE+D,iDAAS,CAACM,KAAV,CAAgB;AACpBlG,QAAI,EAAE4F,iDAAS,CAACO,OAAV,CAAkBP,iDAAS,CAACE,MAA5B,CADc;AAEpBzD,UAAM,EAAEuD,iDAAS,CAACE,MAFE;AAGpBvD,UAAM,EAAEqD,iDAAS,CAACO,OAAV,CAAkBP,iDAAS,CAACE,MAA5B;AAHY,GAAhB,CAxEW;;AA8EnB;;;AAGAd,OAAK,EAAEY,iDAAS,CAACE,MAjFE;;AAmFnB;;;AAGAR,WAAS,EAAEM,iDAAS,CAACC,MAtFF;;AAwFnB;;;;AAIA/D,SAAO,EAAE8D,iDAAS,CAACG,IA5FA;;AA8FnB;;;;AAIAhE,mBAAiB,EAAE6D,iDAAS,CAACE,MAlGV;;AAoGnB;;;;;AAKA9D,QAAM,EAAE4D,iDAAS,CAACM,KAAV,CAAgB;AACpB;;;AAGAE,cAAU,EAAER,iDAAS,CAACG,IAJF;;AAMpB;;;AAGAM,mBAAe,EAAET,iDAAS,CAACC,MATP;;AAWpB;;;;AAIAS,YAAQ,EAAEV,iDAAS,CAACG,IAfA;;AAiBpB;;;AAGAQ,SAAK,EAAEX,iDAAS,CAACM,KAAV,CAAgB;AACnB;;;;;AAKAM,wBAAkB,EAAEZ,iDAAS,CAACG,IANX;;AAQnB;;;AAGAU,oBAAc,EAAEb,iDAAS,CAACG,IAXP;AAanBW,oBAAc,EAAEd,iDAAS,CAACG,IAbP;AAenBY,mBAAa,EAAEf,iDAAS,CAACG,IAfN;AAiBnBa,sBAAgB,EAAEhB,iDAAS,CAACG,IAjBT;AAmBnBc,uBAAiB,EAAEjB,iDAAS,CAACG,IAnBV;AAqBnBe,oBAAc,EAAElB,iDAAS,CAACG,IArBP;;AAuBnB;;;AAGAgB,gBAAU,EAAEnB,iDAAS,CAACG,IA1BH;AA4BnBiB,mBAAa,EAAEpB,iDAAS,CAACG,IA5BN;;AA8BnB;;;AAGAkB,eAAS,EAAErB,iDAAS,CAACG;AAjCF,KAAhB,CApBa;;AAwDpB;;;;AAIAmB,eAAW,EAAEtB,iDAAS,CAACG,IA5DH;;AA8DpB;;;AAGAoB,cAAU,EAAEvB,iDAAS,CAACG,IAjEF;;AAmEpB;;;AAGAqB,eAAW,EAAExB,iDAAS,CAACyB,MAtEH;;AAwEpB;;;AAGAC,aAAS,EAAE1B,iDAAS,CAACG,IA3ED;;AA6EpB;;;AAGAwB,gBAAY,EAAE3B,iDAAS,CAACyB,MAhFJ;;AAkFpB;;;AAGAG,cAAU,EAAE5B,iDAAS,CAACG,IArFF;;AAuFpB;;;AAGA0B,eAAW,EAAE7B,iDAAS,CAAC8B,KAAV,CAAgB,CACzB,KADyB,EAEzB,OAFyB,EAGzB,UAHyB,EAIzB,gBAJyB,CAAhB,CA1FO;;AAiGpB;;;AAGAC,YAAQ,EAAE/B,iDAAS,CAACG,IApGA;;AAsGpB;;;AAGA6B,uBAAmB,EAAEhC,iDAAS,CAACG,IAzGX;;AA2GpB;;;;AAIA8B,2BAAuB,EAAEjC,iDAAS,CAACG,IA/Gf;;AAiHpB;;;AAGA+B,YAAQ,EAAElC,iDAAS,CAACG,IApHA;;AAsHpB;;;AAGAgC,YAAQ,EAAEnC,iDAAS,CAACG,IAzHA;;AA2HpB;;;AAGAiC,YAAQ,EAAEpC,iDAAS,CAACC,MA9HA;;AAgIpB;;;AAGAoC,kBAAc,EAAErC,iDAAS,CAAC8B,KAAV,CAAgB,CAAC,IAAD,EAAO,KAAP,EAAc,OAAd,CAAhB,CAnII;;AAqIpB;;;;;AAKAQ,mBAAe,EAAEtC,iDAAS,CAACG,IA1IP;;AA4IpB;;;;;;;;;;;AAWAoC,0BAAsB,EAAEvC,iDAAS,CAACK,KAvJd;;AAyJpB;;;AAGAmC,uBAAmB,EAAExC,iDAAS,CAACK,KA5JX;;AA8JpB;;;;;AAKAoC,kBAAc,EAAEzC,iDAAS,CAAC0C,GAnKN;;AAqKpB;;;AAGAC,wBAAoB,EAAE3C,iDAAS,CAACM,KAAV,CAAgB;AAClC;;;AAGAsC,YAAM,EAAE5C,iDAAS,CAAC8B,KAAV,CAAgB,CAAC,MAAD,EAAS,KAAT,EAAgB,MAAhB,EAAwB,KAAxB,CAAhB,CAJ0B;;AAKlC;;;AAGAe,cAAQ,EAAE7C,iDAAS,CAACC,MARc;;AASlC;;;AAGA6C,WAAK,EAAE9C,iDAAS,CAACyB,MAZiB;;AAalC;;;AAGAsB,YAAM,EAAE/C,iDAAS,CAACyB,MAhBgB;;AAiBlC;;;;AAIAuB,WAAK,EAAEhD,iDAAS,CAACyB;AArBiB,KAAhB,CAxKF;;AAgMpB;;;AAGAwB,eAAW,EAAEjD,iDAAS,CAACG,IAnMH;;AAqMpB;;;AAGA+C,aAAS,EAAElD,iDAAS,CAACG,IAxMD;;AA0MpB;;;AAGAgD,oBAAgB,EAAEnD,iDAAS,CAACyB,MA7MR;;AA+MpB;;;AAGA2B,eAAW,EAAEpD,iDAAS,CAACC,MAlNH;;AAoNpB;;;;;AAKAoD,qBAAiB,EAAErD,iDAAS,CAAC0C,GAzNT;;AA2NpB;;;;;AAKAY,UAAM,EAAEtD,iDAAS,CAACC,MAhOE;;AAkOpB;;;;AAIAsD,WAAO,EAAEvD,iDAAS,CAACE;AAtOC,GAAhB,CAzGW;;AAkVnB;;;AAGAhC,UAAQ,EAAE8B,iDAAS,CAACwD,IArVD;;AAuVnB;;;AAGA7D,eAAa,EAAEK,iDAAS,CAACyD,KAAV,CAAgB;AAC3B;;;AAGA7D,cAAU,EAAEI,iDAAS,CAACG,IAJK;;AAK3B;;;AAGAuD,aAAS,EAAE1D,iDAAS,CAACC,MARM;;AAS3B;;;AAGA0D,kBAAc,EAAE3D,iDAAS,CAACC;AAZC,GAAhB;AA1VI,CAAvB;AA0WA,IAAM2D,iBAAiB,GAAG;AACtBvF,WAAS,EAAE,IADW;AAEtBC,qBAAmB,EAAE,IAFC;AAGtBE,WAAS,EAAE,IAHW;AAItBC,cAAY,EAAE,IAJQ;AAKtBC,cAAY,EAAE,IALQ;AAMtB3B,YAAU,EAAE,IANU;AAOtB4B,aAAW,EAAE,IAPS;AAQtB1C,QAAM,EAAE;AAAC7B,QAAI,EAAE,EAAP;AAAWqC,UAAM,EAAE,EAAnB;AAAuBE,UAAM,EAAE;AAA/B,GARc;AAStBT,SAAO,EAAE,KATa;AAUtBC,mBAAiB,EAAE;AACf0H,SAAK,EAAE;AACHC,YAAM,EAAE;AADL,KADQ;AAIfC,cAAU,EAAE;AACRC,cAAQ,EAAE,GADF;AAERC,UAAI,EAAE;AAFE;AAJG,GAVG;AAmBtB9F,kBAAgB,EAAE,KAnBI;AAoBtB/B,QAAM,EAAE;AApBc,CAA1B;AAuBAX,2BAA2B,CAACyI,SAA5B,GAAwCnE,cAAxC;AACAnE,eAAe,CAACsI,SAAhB,GAA4BnE,cAA5B;AAEAtE,2BAA2B,CAAC0I,YAA5B,GAA2CP,iBAA3C;AACAhI,eAAe,CAACuI,YAAhB,GAA+BP,iBAA/B;AAEenI,0FAAf","file":"./src/lib/components/ExtendableGraph.react.js.js","sourcesContent":["import React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport {contains, filter, clone, has, isNil, type, omit} from 'ramda';\r\n/* global Plotly:true */\r\n\r\nconst filterEventData = (gd, eventData, event) => {\r\n    let filteredEventData;\r\n    if (contains(event, ['click', 'hover', 'selected'])) {\r\n        const points = [];\r\n\r\n        if (isNil(eventData)) {\r\n            return null;\r\n        }\r\n\r\n        /*\r\n         * remove `data`, `layout`, `xaxis`, etc\r\n         * objects from the event data since they're so big\r\n         * and cause JSON stringify ciricular structure errors.\r\n         *\r\n         * also, pull down the `customdata` point from the data array\r\n         * into the event object\r\n         */\r\n        const data = gd.data;\r\n\r\n        for (let i = 0; i < eventData.points.length; i++) {\r\n            const fullPoint = eventData.points[i];\r\n            const pointData = filter(function(o) {\r\n                return !contains(type(o), ['Object', 'Array']);\r\n            }, fullPoint);\r\n            if (\r\n                has('curveNumber', fullPoint) &&\r\n                has('pointNumber', fullPoint) &&\r\n                has('customdata', data[pointData.curveNumber])\r\n            ) {\r\n                pointData.customdata =\r\n                    data[pointData.curveNumber].customdata[\r\n                        fullPoint.pointNumber\r\n                    ];\r\n            }\r\n\r\n            // specific to histogram. see https://github.com/plotly/plotly.js/pull/2113/\r\n            if (has('pointNumbers', fullPoint)) {\r\n                pointData.pointNumbers = fullPoint.pointNumbers;\r\n            }\r\n\r\n            points[i] = pointData;\r\n        }\r\n        filteredEventData = {points};\r\n    } else if (event === 'relayout' || event === 'restyle') {\r\n        /*\r\n         * relayout shouldn't include any big objects\r\n         * it will usually just contain the ranges of the axes like\r\n         * \"xaxis.range[0]\": 0.7715822247381828,\r\n         * \"xaxis.range[1]\": 3.0095292008680063`\r\n         */\r\n        filteredEventData = eventData;\r\n    }\r\n    if (has('range', eventData)) {\r\n        filteredEventData.range = eventData.range;\r\n    }\r\n    if (has('lassoPoints', eventData)) {\r\n        filteredEventData.lassoPoints = eventData.lassoPoints;\r\n    }\r\n    return filteredEventData;\r\n};\r\n\r\nfunction generateId() {\r\n    const charAmount = 36;\r\n    const length = 7;\r\n    return (\r\n        'graph-' +\r\n        Math.random()\r\n            .toString(charAmount)\r\n            .substring(2, length)\r\n    );\r\n}\r\n\r\n/**\r\n * ExtendableGraph can be used to render any plotly.js-powered data vis.\r\n *\r\n * You can define callbacks based on user interaction with ExtendableGraphs such\r\n * as hovering, clicking or selecting\r\n */\r\nconst ExtendableGraphWithDefaults = props => {\r\n    const id = props.id ? props.id : generateId();\r\n    return <ExtendableGraph {...props} id={id} />;\r\n};\r\n\r\nclass ExtendableGraph extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n        this.bindEvents = this.bindEvents.bind(this);\r\n        this._hasPlotted = false;\r\n        this.graphResize = this.graphResize.bind(this);\r\n    }\r\n\r\n    plot(props) {\r\n        const {figure, id, animate, animation_options, config} = props;\r\n        const gd = document.getElementById(id);\r\n\r\n        if (\r\n            animate &&\r\n            this._hasPlotted &&\r\n            figure.data.length === gd.data.length\r\n        ) {\r\n            return Plotly.animate(id, figure, animation_options);\r\n        }\r\n        return Plotly.react(id, {\r\n            data: figure.data,\r\n            layout: clone(figure.layout),\r\n            frames: figure.frames,\r\n            config: config,\r\n        }).then(() => {\r\n            if (!this._hasPlotted) {\r\n                const gd = document.getElementById(id);\r\n                if (gd) {\r\n                    this.bindEvents();\r\n                    Plotly.Plots.resize(gd);\r\n                    this._hasPlotted = true;\r\n                }\r\n            }\r\n        });\r\n    }\r\n\r\n    extend(props) {\r\n        const {id, extendData} = props;\r\n        const gd = document.getElementById(id);\r\n        let updateData, traceIndices, maxPoints;\r\n\r\n        if (extendData) {\r\n            if (gd.data.length < 1) {\r\n                // figure has no pre-existing data. redirect to plot()\r\n                props.figure.data = extendData;\r\n                return this.plot(props);\r\n            }\r\n\r\n            if (Array.isArray(extendData) && Array.isArray(extendData[0])) {\r\n                [updateData, traceIndices, maxPoints] = extendData;\r\n            } else {\r\n                updateData = extendData;\r\n            }\r\n\r\n            if (!traceIndices) {\r\n                traceIndices = Array.from(Array(updateData.length).keys());\r\n            }\r\n\r\n            function createDataObject(data) {\r\n                const dataprops = Object.keys(data);\r\n                const ret = {};\r\n                for (let i = 0; i < dataprops.length; i++) {\r\n                    ret[dataprops[i]] = [data[dataprops[i]]];\r\n                }\r\n                return ret;\r\n            }\r\n\r\n            for (const [i, value] of updateData.entries()) {\r\n                const updateObject = createDataObject(value);\r\n                if (i < updateData.length - 1) {\r\n                    if (traceIndices[i] < gd.data.length) {\r\n                        Plotly.extendTraces(\r\n                            id,\r\n                            updateObject,\r\n                            [traceIndices[i]],\r\n                            maxPoints\r\n                        );\r\n                    } else {\r\n                        Plotly.addTraces(id, value);\r\n                    }\r\n                } else {\r\n                    if (traceIndices[i] < gd.data.length) {\r\n                        return Plotly.extendTraces(\r\n                            id,\r\n                            updateObject,\r\n                            [traceIndices[i]],\r\n                            maxPoints\r\n                        );\r\n                    }\r\n                    return Plotly.addTraces(id, value);\r\n                }\r\n            }\r\n        }\r\n\r\n        return this.plot(props);\r\n    }\r\n\r\n    graphResize() {\r\n        const graphDiv = document.getElementById(this.props.id);\r\n        if (graphDiv) {\r\n            Plotly.Plots.resize(graphDiv);\r\n        }\r\n    }\r\n\r\n    bindEvents() {\r\n        const {id, setProps, clear_on_unhover} = this.props;\r\n\r\n        const gd = document.getElementById(id);\r\n\r\n        gd.on('plotly_click', eventData => {\r\n            const clickData = filterEventData(gd, eventData, 'click');\r\n            if (!isNil(clickData)) {\r\n                setProps({clickData});\r\n            }\r\n        });\r\n        gd.on('plotly_clickannotation', eventData => {\r\n            const clickAnnotationData = omit(\r\n                ['event', 'fullAnnotation'],\r\n                eventData\r\n            );\r\n            setProps({clickAnnotationData});\r\n        });\r\n        gd.on('plotly_hover', eventData => {\r\n            const hoverData = filterEventData(gd, eventData, 'hover');\r\n            if (!isNil(hoverData)) {\r\n                setProps({hoverData});\r\n            }\r\n        });\r\n        gd.on('plotly_selected', eventData => {\r\n            const selectedData = filterEventData(gd, eventData, 'selected');\r\n            if (!isNil(selectedData)) {\r\n                setProps({selectedData});\r\n            }\r\n        });\r\n        gd.on('plotly_deselect', () => {\r\n            setProps({selectedData: null});\r\n        });\r\n        gd.on('plotly_relayout', eventData => {\r\n            const relayoutData = filterEventData(gd, eventData, 'relayout');\r\n            if (!isNil(relayoutData)) {\r\n                setProps({relayoutData});\r\n            }\r\n        });\r\n        gd.on('plotly_restyle', eventData => {\r\n            const restyleData = filterEventData(gd, eventData, 'restyle');\r\n            if (!isNil(restyleData)) {\r\n                setProps({restyleData});\r\n            }\r\n        });\r\n        gd.on('plotly_unhover', () => {\r\n            if (clear_on_unhover) {\r\n                setProps({hoverData: null});\r\n            }\r\n        });\r\n    }\r\n\r\n    componentDidMount() {\r\n        this.plot(this.props).then(() => {\r\n            window.addEventListener('resize', this.graphResize);\r\n        });\r\n    }\r\n\r\n    componentWillUnmount() {\r\n        if (this.eventEmitter) {\r\n            this.eventEmitter.removeAllListeners();\r\n        }\r\n        window.removeEventListener('resize', this.graphResize);\r\n    }\r\n\r\n    shouldComponentUpdate(nextProps) {\r\n        return (\r\n            this.props.id !== nextProps.id ||\r\n            JSON.stringify(this.props.style) !== JSON.stringify(nextProps.style)\r\n        );\r\n    }\r\n\r\n    componentWillReceiveProps(nextProps) {\r\n        const idChanged = this.props.id !== nextProps.id;\r\n        if (idChanged) {\r\n            /*\r\n             * then the dom needs to get re-rendered with a new ID.\r\n             * the graph will get updated in componentDidUpdate\r\n             */\r\n            return;\r\n        }\r\n\r\n        const figureChanged = this.props.figure !== nextProps.figure;\r\n        if (figureChanged) {\r\n            this.plot(nextProps);\r\n        }\r\n\r\n        const extendDataChanged =\r\n            this.props.extendData !== nextProps.extendData;\r\n        if (extendDataChanged) {\r\n            this.extend(nextProps);\r\n        }\r\n    }\r\n\r\n    componentDidUpdate(prevProps) {\r\n        if (prevProps.id !== this.props.id) {\r\n            this.plot(this.props);\r\n        }\r\n    }\r\n\r\n    render() {\r\n        const {className, id, style, loading_state} = this.props;\r\n\r\n        return (\r\n            <div\r\n                key={id}\r\n                id={id}\r\n                data-dash-is-loading={\r\n                    (loading_state && loading_state.is_loading) || undefined\r\n                }\r\n                style={style}\r\n                className={className}\r\n            />\r\n        );\r\n    }\r\n}\r\n\r\nconst graphPropTypes = {\r\n    /**\r\n     * The ID of this component, used to identify dash components\r\n     * in callbacks. The ID needs to be unique across all of the\r\n     * components in an app.\r\n     */\r\n    id: PropTypes.string,\r\n    /**\r\n     * Data from latest click event. Read-only.\r\n     */\r\n    clickData: PropTypes.object,\r\n\r\n    /**\r\n     * Data from latest click annotation event. Read-only.\r\n     */\r\n    clickAnnotationData: PropTypes.object,\r\n\r\n    /**\r\n     * Data from latest hover event. Read-only.\r\n     */\r\n    hoverData: PropTypes.object,\r\n\r\n    /**\r\n     * If True, `clear_on_unhover` will clear the `hoverData` property\r\n     * when the user \"unhovers\" from a point.\r\n     * If False, then the `hoverData` property will be equal to the\r\n     * data from the last point that was hovered over.\r\n     */\r\n    clear_on_unhover: PropTypes.bool,\r\n\r\n    /**\r\n     * Data from latest select event. Read-only.\r\n     */\r\n    selectedData: PropTypes.object,\r\n\r\n    /**\r\n     * Data from latest relayout event which occurs\r\n     * when the user zooms or pans on the plot or other\r\n     * layout-level edits. Has the form `{<attr string>: <value>}`\r\n     * describing the changes made. Read-only.\r\n     */\r\n    relayoutData: PropTypes.object,\r\n\r\n    /**\r\n     * Data that should be appended to existing traces. Has the form\r\n     * `[updateData, traceIndices, maxPoints]`, where `updateData` is an array\r\n     * containing data objects to extend, `traceIndices` (optional) is an array\r\n     * of trace indices that should be extended, and `maxPoints` (optional) is\r\n     * either an integer defining the maximum number of points allowed or an\r\n     * object with key:value pairs matching `updateData`\r\n     * Reference the Plotly.extendTraces API for full usage:\r\n     * https://plot.ly/javascript/plotlyjs-function-reference/#plotlyextendtraces\r\n     */\r\n    extendData: PropTypes.oneOfType([PropTypes.array, PropTypes.object]),\r\n\r\n    /**\r\n     * Data from latest restyle event which occurs\r\n     * when the user toggles a legend item, changes\r\n     * parcoords selections, or other trace-level edits.\r\n     * Has the form `[edits, indices]`, where `edits` is an object\r\n     * `{<attr string>: <value>}` describing the changes made,\r\n     * and `indices` is an array of trace indices that were edited.\r\n     * Read-only.\r\n     */\r\n    restyleData: PropTypes.array,\r\n\r\n    /**\r\n     * Plotly `figure` object. See schema:\r\n     * https://plot.ly/javascript/reference\r\n     *\r\n     * `config` is set separately by the `config` property\r\n     */\r\n    figure: PropTypes.exact({\r\n        data: PropTypes.arrayOf(PropTypes.object),\r\n        layout: PropTypes.object,\r\n        frames: PropTypes.arrayOf(PropTypes.object),\r\n    }),\r\n\r\n    /**\r\n     * Generic style overrides on the plot div\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    /**\r\n     * className of the parent div\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Beta: If true, animate between updates using\r\n     * plotly.js's `animate` function\r\n     */\r\n    animate: PropTypes.bool,\r\n\r\n    /**\r\n     * Beta: Object containing animation settings.\r\n     * Only applies if `animate` is `true`\r\n     */\r\n    animation_options: PropTypes.object,\r\n\r\n    /**\r\n     * Plotly.js config options.\r\n     * See https://plot.ly/javascript/configuration-options/\r\n     * for more info.\r\n     */\r\n    config: PropTypes.exact({\r\n        /**\r\n         * No interactivity, for export or image generation\r\n         */\r\n        staticPlot: PropTypes.bool,\r\n\r\n        /**\r\n         * Base URL for a Plotly cloud instance, if `showSendToCloud` is enabled\r\n         */\r\n        plotlyServerURL: PropTypes.string,\r\n\r\n        /**\r\n         * We can edit titles, move annotations, etc - sets all pieces of `edits`\r\n         * unless a separate `edits` config item overrides individual parts\r\n         */\r\n        editable: PropTypes.bool,\r\n\r\n        /**\r\n         * A set of editable properties\r\n         */\r\n        edits: PropTypes.exact({\r\n            /**\r\n             * annotationPosition: the main anchor of the annotation, which is the\r\n             * text (if no arrow) or the arrow (which drags the whole thing leaving\r\n             * the arrow length & direction unchanged)\r\n             */\r\n            annotationPosition: PropTypes.bool,\r\n\r\n            /**\r\n             * Just for annotations with arrows, change the length and direction of the arrow\r\n             */\r\n            annotationTail: PropTypes.bool,\r\n\r\n            annotationText: PropTypes.bool,\r\n\r\n            axisTitleText: PropTypes.bool,\r\n\r\n            colorbarPosition: PropTypes.bool,\r\n\r\n            colorbarTitleText: PropTypes.bool,\r\n\r\n            legendPosition: PropTypes.bool,\r\n\r\n            /**\r\n             * Edit the trace name fields from the legend\r\n             */\r\n            legendText: PropTypes.bool,\r\n\r\n            shapePosition: PropTypes.bool,\r\n\r\n            /**\r\n             * The global `layout.title`\r\n             */\r\n            titleText: PropTypes.bool,\r\n        }),\r\n\r\n        /**\r\n         * DO autosize once regardless of layout.autosize\r\n         * (use default width or height values otherwise)\r\n         */\r\n        autosizable: PropTypes.bool,\r\n\r\n        /**\r\n         * Whether to change layout size when the window size changes\r\n         */\r\n        responsive: PropTypes.bool,\r\n\r\n        /**\r\n         * Set the length of the undo/redo queue\r\n         */\r\n        queueLength: PropTypes.number,\r\n\r\n        /**\r\n         * If we DO autosize, do we fill the container or the screen?\r\n         */\r\n        fillFrame: PropTypes.bool,\r\n\r\n        /**\r\n         * If we DO autosize, set the frame margins in percents of plot size\r\n         */\r\n        frameMargins: PropTypes.number,\r\n\r\n        /**\r\n         * Mousewheel or two-finger scroll zooms the plot\r\n         */\r\n        scrollZoom: PropTypes.bool,\r\n\r\n        /**\r\n         * Double click interaction (false, 'reset', 'autosize' or 'reset+autosize')\r\n         */\r\n        doubleClick: PropTypes.oneOf([\r\n            false,\r\n            'reset',\r\n            'autosize',\r\n            'reset+autosize',\r\n        ]),\r\n\r\n        /**\r\n         * New users see some hints about interactivity\r\n         */\r\n        showTips: PropTypes.bool,\r\n\r\n        /**\r\n         * Enable axis pan/zoom drag handles\r\n         */\r\n        showAxisDragHandles: PropTypes.bool,\r\n\r\n        /**\r\n         * Enable direct range entry at the pan/zoom drag points\r\n         * (drag handles must be enabled above)\r\n         */\r\n        showAxisRangeEntryBoxes: PropTypes.bool,\r\n\r\n        /**\r\n         * Link to open this plot in plotly\r\n         */\r\n        showLink: PropTypes.bool,\r\n\r\n        /**\r\n         * If we show a link, does it contain data or just link to a plotly file?\r\n         */\r\n        sendData: PropTypes.bool,\r\n\r\n        /**\r\n         * Text appearing in the sendData link\r\n         */\r\n        linkText: PropTypes.string,\r\n\r\n        /**\r\n         * Display the mode bar (true, false, or 'hover')\r\n         */\r\n        displayModeBar: PropTypes.oneOf([true, false, 'hover']),\r\n\r\n        /**\r\n         * Should we include a modebar button to send this data to a\r\n         * Plotly Cloud instance, linked by `plotlyServerURL`.\r\n         * By default this is false.\r\n         */\r\n        showSendToCloud: PropTypes.bool,\r\n\r\n        /**\r\n         * Remove mode bar button by name.\r\n         * All modebar button names at https://github.com/plotly/plotly.js/blob/master/src/components/modebar/buttons.js\r\n         * Common names include:\r\n         *  - sendDataToCloud\r\n         * - (2D): zoom2d, pan2d, select2d, lasso2d, zoomIn2d, zoomOut2d, autoScale2d, resetScale2d\r\n         * - (Cartesian): hoverClosestCartesian, hoverCompareCartesian\r\n         * - (3D): zoom3d, pan3d, orbitRotation, tableRotation, handleDrag3d, resetCameraDefault3d, resetCameraLastSave3d, hoverClosest3d\r\n         * - (Geo): zoomInGeo, zoomOutGeo, resetGeo, hoverClosestGeo\r\n         * - hoverClosestGl2d, hoverClosestPie, toggleHover, resetViews\r\n         */\r\n        modeBarButtonsToRemove: PropTypes.array,\r\n\r\n        /**\r\n         * Add mode bar button using config objects\r\n         */\r\n        modeBarButtonsToAdd: PropTypes.array,\r\n\r\n        /**\r\n         * Fully custom mode bar buttons as nested array,\r\n         * where the outer arrays represents button groups, and\r\n         * the inner arrays have buttons config objects or names of default buttons\r\n         */\r\n        modeBarButtons: PropTypes.any,\r\n\r\n        /**\r\n         * Modifications to how the toImage modebar button works\r\n         */\r\n        toImageButtonOptions: PropTypes.exact({\r\n            /**\r\n             * The file format to create\r\n             */\r\n            format: PropTypes.oneOf(['jpeg', 'png', 'webp', 'svg']),\r\n            /**\r\n             * The name given to the downloaded file\r\n             */\r\n            filename: PropTypes.string,\r\n            /**\r\n             * Width of the downloaded file, in px\r\n             */\r\n            width: PropTypes.number,\r\n            /**\r\n             * Height of the downloaded file, in px\r\n             */\r\n            height: PropTypes.number,\r\n            /**\r\n             * Extra resolution to give the file after\r\n             * rendering it with the given width and height\r\n             */\r\n            scale: PropTypes.number,\r\n        }),\r\n\r\n        /**\r\n         * Add the plotly logo on the end of the mode bar\r\n         */\r\n        displaylogo: PropTypes.bool,\r\n\r\n        /**\r\n         * Add the plotly logo even with no modebar\r\n         */\r\n        watermark: PropTypes.bool,\r\n\r\n        /**\r\n         * Increase the pixel ratio for Gl plot images\r\n         */\r\n        plotGlPixelRatio: PropTypes.number,\r\n\r\n        /**\r\n         * URL to topojson files used in geo charts\r\n         */\r\n        topojsonURL: PropTypes.string,\r\n\r\n        /**\r\n         * Mapbox access token (required to plot mapbox trace types)\r\n         * If using an Mapbox Atlas server, set this option to '',\r\n         * so that plotly.js won't attempt to authenticate to the public Mapbox server.\r\n         */\r\n        mapboxAccessToken: PropTypes.any,\r\n\r\n        /**\r\n         * The locale to use. Locales may be provided with the plot\r\n         * (`locales` below) or by loading them on the page, see:\r\n         * https://github.com/plotly/plotly.js/blob/master/dist/README.md#to-include-localization\r\n         */\r\n        locale: PropTypes.string,\r\n\r\n        /**\r\n         * Localization definitions, if you choose to provide them with the\r\n         * plot rather than registering them globally.\r\n         */\r\n        locales: PropTypes.object,\r\n    }),\r\n\r\n    /**\r\n     * Function that updates the state tree.\r\n     */\r\n    setProps: PropTypes.func,\r\n\r\n    /**\r\n     * Object that holds the loading state object coming from dash-renderer\r\n     */\r\n    loading_state: PropTypes.shape({\r\n        /**\r\n         * Determines if the component is loading or not\r\n         */\r\n        is_loading: PropTypes.bool,\r\n        /**\r\n         * Holds which property is loading\r\n         */\r\n        prop_name: PropTypes.string,\r\n        /**\r\n         * Holds the name of the component that is loading\r\n         */\r\n        component_name: PropTypes.string,\r\n    }),\r\n};\r\n\r\nconst graphDefaultProps = {\r\n    clickData: null,\r\n    clickAnnotationData: null,\r\n    hoverData: null,\r\n    selectedData: null,\r\n    relayoutData: null,\r\n    extendData: null,\r\n    restyleData: null,\r\n    figure: {data: [], layout: {}, frames: []},\r\n    animate: false,\r\n    animation_options: {\r\n        frame: {\r\n            redraw: false,\r\n        },\r\n        transition: {\r\n            duration: 750,\r\n            ease: 'cubic-in-out',\r\n        },\r\n    },\r\n    clear_on_unhover: false,\r\n    config: {},\r\n};\r\n\r\nExtendableGraphWithDefaults.propTypes = graphPropTypes;\r\nExtendableGraph.propTypes = graphPropTypes;\r\n\r\nExtendableGraphWithDefaults.defaultProps = graphDefaultProps;\r\nExtendableGraph.defaultProps = graphDefaultProps;\r\n\r\nexport default ExtendableGraphWithDefaults;\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/lib/components/ExtendableGraph.react.js\n"); +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! prop-types */ \"prop-types\");\n/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ramda */ \"./node_modules/ramda/es/index.js\");\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); }\n\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); }\n\nfunction _iterableToArrayLimit(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"] != null) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; }\n\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n/* global Plotly:true */\n\nvar filterEventData = function filterEventData(gd, eventData, event) {\n var filteredEventData;\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"contains\"])(event, ['click', 'hover', 'selected'])) {\n var points = [];\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(eventData)) {\n return null;\n }\n /*\r\n * remove `data`, `layout`, `xaxis`, etc\r\n * objects from the event data since they're so big\r\n * and cause JSON stringify ciricular structure errors.\r\n *\r\n * also, pull down the `customdata` point from the data array\r\n * into the event object\r\n */\n\n\n var data = gd.data;\n\n for (var i = 0; i < eventData.points.length; i++) {\n var fullPoint = eventData.points[i];\n var pointData = Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"filter\"])(function (o) {\n return !Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"contains\"])(Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"type\"])(o), ['Object', 'Array']);\n }, fullPoint);\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('curveNumber', fullPoint) && Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('pointNumber', fullPoint) && Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('customdata', data[pointData.curveNumber])) {\n pointData.customdata = data[pointData.curveNumber].customdata[fullPoint.pointNumber];\n } // specific to histogram. see https://github.com/plotly/plotly.js/pull/2113/\n\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('pointNumbers', fullPoint)) {\n pointData.pointNumbers = fullPoint.pointNumbers;\n }\n\n points[i] = pointData;\n }\n\n filteredEventData = {\n points: points\n };\n } else if (event === 'relayout' || event === 'restyle') {\n /*\r\n * relayout shouldn't include any big objects\r\n * it will usually just contain the ranges of the axes like\r\n * \"xaxis.range[0]\": 0.7715822247381828,\r\n * \"xaxis.range[1]\": 3.0095292008680063`\r\n */\n filteredEventData = eventData;\n }\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('range', eventData)) {\n filteredEventData.range = eventData.range;\n }\n\n if (Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"has\"])('lassoPoints', eventData)) {\n filteredEventData.lassoPoints = eventData.lassoPoints;\n }\n\n return filteredEventData;\n};\n/**\r\n * ExtendableGraph can be used to render any plotly.js-powered data vis.\r\n *\r\n * You can define callbacks based on user interaction with ExtendableGraphs such\r\n * as hovering, clicking or selecting\r\n */\n\n\nvar ExtendableGraph =\n/*#__PURE__*/\nfunction (_Component) {\n _inherits(ExtendableGraph, _Component);\n\n function ExtendableGraph(props) {\n var _this;\n\n _classCallCheck(this, ExtendableGraph);\n\n _this = _possibleConstructorReturn(this, _getPrototypeOf(ExtendableGraph).call(this, props));\n _this.gd = react__WEBPACK_IMPORTED_MODULE_0___default.a.createRef();\n _this.bindEvents = _this.bindEvents.bind(_assertThisInitialized(_this));\n _this._hasPlotted = false;\n _this._prevGd = null;\n _this.graphResize = _this.graphResize.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n _createClass(ExtendableGraph, [{\n key: \"plot\",\n value: function plot(props) {\n var _this2 = this;\n\n var figure = props.figure,\n animate = props.animate,\n animation_options = props.animation_options,\n config = props.config;\n var gd = this.gd.current;\n\n if (animate && this._hasPlotted && figure.data.length === gd.data.length) {\n return Plotly.animate(gd, figure, animation_options);\n }\n\n return Plotly.react(gd, {\n data: figure.data,\n layout: Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"clone\"])(figure.layout),\n frames: figure.frames,\n config: config\n }).then(function () {\n var gd = _this2.gd.current; // double-check gd hasn't been unmounted\n\n if (!gd) {\n return;\n } // in case we've made a new DOM element, transfer events\n\n\n if (_this2._hasPlotted && gd !== _this2._prevGd) {\n if (_this2._prevGd && _this2._prevGd.removeAllListeners) {\n _this2._prevGd.removeAllListeners();\n\n Plotly.purge(_this2._prevGd);\n }\n\n _this2._hasPlotted = false;\n }\n\n if (!_this2._hasPlotted) {\n _this2.bindEvents();\n\n Plotly.Plots.resize(gd);\n _this2._hasPlotted = true;\n _this2._prevGd = gd;\n }\n });\n }\n }, {\n key: \"extend\",\n value: function extend(props) {\n var extendData = props.extendData;\n var gd = this.gd.current;\n var updateData, traceIndices, maxPoints;\n\n if (extendData) {\n var createDataObject = function createDataObject(data) {\n var dataprops = Object.keys(data);\n var ret = {};\n\n for (var i = 0; i < dataprops.length; i++) {\n ret[dataprops[i]] = [data[dataprops[i]]];\n }\n\n return ret;\n };\n\n if (gd.data.length < 1) {\n // figure has no pre-existing data. redirect to plot()\n props.figure.data = extendData;\n return this.plot(props);\n }\n\n if (Array.isArray(extendData) && Array.isArray(extendData[0])) {\n var _extendData = _slicedToArray(extendData, 3);\n\n updateData = _extendData[0];\n traceIndices = _extendData[1];\n maxPoints = _extendData[2];\n } else {\n updateData = extendData;\n }\n\n if (!traceIndices) {\n traceIndices = Array.from(Array(updateData.length).keys());\n }\n\n var _iteratorNormalCompletion = true;\n var _didIteratorError = false;\n var _iteratorError = undefined;\n\n try {\n for (var _iterator = updateData.entries()[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {\n var _step$value = _slicedToArray(_step.value, 2),\n i = _step$value[0],\n value = _step$value[1];\n\n var updateObject = createDataObject(value);\n\n if (i < updateData.length - 1) {\n if (traceIndices[i] < gd.data.length) {\n Plotly.extendTraces(gd, updateObject, [traceIndices[i]], maxPoints);\n } else {\n Plotly.addTraces(gd, value);\n }\n } else {\n if (traceIndices[i] < gd.data.length) {\n return Plotly.extendTraces(gd, updateObject, [traceIndices[i]], maxPoints);\n }\n\n return Plotly.addTraces(gd, value);\n }\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally {\n try {\n if (!_iteratorNormalCompletion && _iterator[\"return\"] != null) {\n _iterator[\"return\"]();\n }\n } finally {\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n }\n\n return this.plot(props);\n }\n }, {\n key: \"graphResize\",\n value: function graphResize() {\n var gd = this.gd.current;\n\n if (gd) {\n Plotly.Plots.resize(gd);\n }\n }\n }, {\n key: \"bindEvents\",\n value: function bindEvents() {\n var _this$props = this.props,\n setProps = _this$props.setProps,\n clear_on_unhover = _this$props.clear_on_unhover,\n relayoutData = _this$props.relayoutData,\n restyleData = _this$props.restyleData,\n hoverData = _this$props.hoverData,\n selectedData = _this$props.selectedData;\n var gd = this.gd.current;\n gd.on('plotly_click', function (eventData) {\n var clickData = filterEventData(gd, eventData, 'click');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(clickData)) {\n setProps({\n clickData: clickData\n });\n }\n });\n gd.on('plotly_clickannotation', function (eventData) {\n var clickAnnotationData = Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"omit\"])(['event', 'fullAnnotation'], eventData);\n setProps({\n clickAnnotationData: clickAnnotationData\n });\n });\n gd.on('plotly_hover', function (eventData) {\n var hover = filterEventData(gd, eventData, 'hover');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(hover) && !Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"equals\"])(hover, hoverData)) {\n setProps({\n hoverData: hover\n });\n }\n });\n gd.on('plotly_selected', function (eventData) {\n var selected = filterEventData(gd, eventData, 'selected');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(selected) && !Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"equals\"])(selected, selectedData)) {\n setProps({\n selectedData: selected\n });\n }\n });\n gd.on('plotly_deselect', function () {\n setProps({\n selectedData: null\n });\n });\n gd.on('plotly_relayout', function (eventData) {\n var relayout = filterEventData(gd, eventData, 'relayout');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(relayout) && !Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"equals\"])(relayout, relayoutData)) {\n setProps({\n relayoutData: relayout\n });\n }\n });\n gd.on('plotly_restyle', function (eventData) {\n var restyle = filterEventData(gd, eventData, 'restyle');\n\n if (!Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"isNil\"])(restyle) && !Object(ramda__WEBPACK_IMPORTED_MODULE_2__[\"equals\"])(restyle, restyleData)) {\n setProps({\n restyleData: restyle\n });\n }\n });\n gd.on('plotly_unhover', function () {\n if (clear_on_unhover) {\n setProps({\n hoverData: null\n });\n }\n });\n }\n }, {\n key: \"componentDidMount\",\n value: function componentDidMount() {\n var _this3 = this;\n\n this.plot(this.props).then(function () {\n window.addEventListener('resize', _this3.graphResize);\n });\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n var gd = this.gd.current;\n\n if (gd && gd.removeAllListeners) {\n gd.removeAllListeners();\n Plotly.purge(gd);\n }\n\n window.removeEventListener('resize', this.graphResize);\n }\n }, {\n key: \"shouldComponentUpdate\",\n value: function shouldComponentUpdate(nextProps) {\n return this.props.id !== nextProps.id || JSON.stringify(this.props.style) !== JSON.stringify(nextProps.style);\n }\n }, {\n key: \"componentWillReceiveProps\",\n value: function componentWillReceiveProps(nextProps) {\n var idChanged = this.props.id !== nextProps.id;\n\n if (idChanged) {\n /*\r\n * then the dom needs to get re-rendered with a new ID.\r\n * the graph will get updated in componentDidUpdate\r\n */\n return;\n }\n\n var figureChanged = this.props.figure !== nextProps.figure;\n\n if (figureChanged) {\n this.plot(nextProps);\n }\n\n var extendDataChanged = this.props.extendData !== nextProps.extendData;\n\n if (extendDataChanged) {\n this.extend(nextProps);\n }\n }\n }, {\n key: \"componentDidUpdate\",\n value: function componentDidUpdate(prevProps) {\n if (prevProps.id !== this.props.id) {\n this.plot(this.props);\n }\n }\n }, {\n key: \"render\",\n value: function render() {\n var _this$props2 = this.props,\n className = _this$props2.className,\n id = _this$props2.id,\n style = _this$props2.style,\n loading_state = _this$props2.loading_state;\n return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(\"div\", {\n key: id,\n id: id,\n ref: this.gd,\n \"data-dash-is-loading\": loading_state && loading_state.is_loading || undefined,\n style: style,\n className: className\n });\n }\n }]);\n\n return ExtendableGraph;\n}(react__WEBPACK_IMPORTED_MODULE_0__[\"Component\"]);\n\nvar graphPropTypes = {\n /**\r\n * The ID of this component, used to identify dash components\r\n * in callbacks. The ID needs to be unique across all of the\r\n * components in an app.\r\n */\n id: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Data from latest click event. Read-only.\r\n */\n clickData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Data from latest click annotation event. Read-only.\r\n */\n clickAnnotationData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Data from latest hover event. Read-only.\r\n */\n hoverData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * If True, `clear_on_unhover` will clear the `hoverData` property\r\n * when the user \"unhovers\" from a point.\r\n * If False, then the `hoverData` property will be equal to the\r\n * data from the last point that was hovered over.\r\n */\n clear_on_unhover: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Data from latest select event. Read-only.\r\n */\n selectedData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Data from latest relayout event which occurs\r\n * when the user zooms or pans on the plot or other\r\n * layout-level edits. Has the form `{: }`\r\n * describing the changes made. Read-only.\r\n */\n relayoutData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Data that should be appended to existing traces. Has the form\r\n * `[updateData, traceIndices, maxPoints]`, where `updateData` is an array\r\n * containing data objects to extend, `traceIndices` (optional) is an array\r\n * of trace indices that should be extended, and `maxPoints` (optional) is\r\n * either an integer defining the maximum number of points allowed or an\r\n * object with key:value pairs matching `updateData`\r\n * Reference the Plotly.extendTraces API for full usage:\r\n * https://plot.ly/javascript/plotlyjs-function-reference/#plotlyextendtraces\r\n */\n extendData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.oneOfType([prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.array, prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object]),\n\n /**\r\n * Data from latest restyle event which occurs\r\n * when the user toggles a legend item, changes\r\n * parcoords selections, or other trace-level edits.\r\n * Has the form `[edits, indices]`, where `edits` is an object\r\n * `{: }` describing the changes made,\r\n * and `indices` is an array of trace indices that were edited.\r\n * Read-only.\r\n */\n restyleData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.array,\n\n /**\r\n * Plotly `figure` object. See schema:\r\n * https://plot.ly/javascript/reference\r\n *\r\n * `config` is set separately by the `config` property\r\n */\n figure: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.exact({\n data: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object),\n layout: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n frames: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.arrayOf(prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object)\n }),\n\n /**\r\n * Generic style overrides on the plot div\r\n */\n style: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * className of the parent div\r\n */\n className: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Beta: If true, animate between updates using\r\n * plotly.js's `animate` function\r\n */\n animate: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Beta: Object containing animation settings.\r\n * Only applies if `animate` is `true`\r\n */\n animation_options: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object,\n\n /**\r\n * Plotly.js config options.\r\n * See https://plot.ly/javascript/configuration-options/\r\n * for more info.\r\n */\n config: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.exact({\n /**\r\n * No interactivity, for export or image generation\r\n */\n staticPlot: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Base URL for a Plotly cloud instance, if `showSendToCloud` is enabled\r\n */\n plotlyServerURL: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * We can edit titles, move annotations, etc - sets all pieces of `edits`\r\n * unless a separate `edits` config item overrides individual parts\r\n */\n editable: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * A set of editable properties\r\n */\n edits: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.exact({\n /**\r\n * The main anchor of the annotation, which is the\r\n * text (if no arrow) or the arrow (which drags the whole thing leaving\r\n * the arrow length & direction unchanged)\r\n */\n annotationPosition: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Just for annotations with arrows, change the length and direction of the arrow\r\n */\n annotationTail: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n annotationText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n axisTitleText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n colorbarPosition: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n colorbarTitleText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n legendPosition: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Edit the trace name fields from the legend\r\n */\n legendText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n shapePosition: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * The global `layout.title`\r\n */\n titleText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool\n }),\n\n /**\r\n * DO autosize once regardless of layout.autosize\r\n * (use default width or height values otherwise)\r\n */\n autosizable: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Whether to change layout size when the window size changes\r\n */\n responsive: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Set the length of the undo/redo queue\r\n */\n queueLength: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * If we DO autosize, do we fill the container or the screen?\r\n */\n fillFrame: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * If we DO autosize, set the frame margins in percents of plot size\r\n */\n frameMargins: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * Mousewheel or two-finger scroll zooms the plot\r\n */\n scrollZoom: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Double click interaction (false, 'reset', 'autosize' or 'reset+autosize')\r\n */\n doubleClick: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.oneOf([false, 'reset', 'autosize', 'reset+autosize']),\n\n /**\r\n * New users see some hints about interactivity\r\n */\n showTips: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Enable axis pan/zoom drag handles\r\n */\n showAxisDragHandles: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Enable direct range entry at the pan/zoom drag points\r\n * (drag handles must be enabled above)\r\n */\n showAxisRangeEntryBoxes: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Link to open this plot in plotly\r\n */\n showLink: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * If we show a link, does it contain data or just link to a plotly file?\r\n */\n sendData: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Text appearing in the sendData link\r\n */\n linkText: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Display the mode bar (true, false, or 'hover')\r\n */\n displayModeBar: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.oneOf([true, false, 'hover']),\n\n /**\r\n * Should we include a modebar button to send this data to a\r\n * Plotly Cloud instance, linked by `plotlyServerURL`.\r\n * By default this is false.\r\n */\n showSendToCloud: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Remove mode bar button by name.\r\n * All modebar button names at https://github.com/plotly/plotly.js/blob/master/src/components/modebar/buttons.js\r\n * Common names include:\r\n * sendDataToCloud;\r\n * (2D) zoom2d, pan2d, select2d, lasso2d, zoomIn2d, zoomOut2d, autoScale2d, resetScale2d;\r\n * (Cartesian) hoverClosestCartesian, hoverCompareCartesian;\r\n * (3D) zoom3d, pan3d, orbitRotation, tableRotation, handleDrag3d, resetCameraDefault3d, resetCameraLastSave3d, hoverClosest3d;\r\n * (Geo) zoomInGeo, zoomOutGeo, resetGeo, hoverClosestGeo;\r\n * hoverClosestGl2d, hoverClosestPie, toggleHover, resetViews.\r\n */\n modeBarButtonsToRemove: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.array,\n\n /**\r\n * Add mode bar button using config objects\r\n */\n modeBarButtonsToAdd: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.array,\n\n /**\r\n * Fully custom mode bar buttons as nested array,\r\n * where the outer arrays represents button groups, and\r\n * the inner arrays have buttons config objects or names of default buttons\r\n */\n modeBarButtons: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.any,\n\n /**\r\n * Modifications to how the toImage modebar button works\r\n */\n toImageButtonOptions: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.exact({\n /**\r\n * The file format to create\r\n */\n format: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.oneOf(['jpeg', 'png', 'webp', 'svg']),\n\n /**\r\n * The name given to the downloaded file\r\n */\n filename: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Width of the downloaded file, in px\r\n */\n width: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * Height of the downloaded file, in px\r\n */\n height: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * Extra resolution to give the file after\r\n * rendering it with the given width and height\r\n */\n scale: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number\n }),\n\n /**\r\n * Add the plotly logo on the end of the mode bar\r\n */\n displaylogo: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Add the plotly logo even with no modebar\r\n */\n watermark: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Increase the pixel ratio for Gl plot images\r\n */\n plotGlPixelRatio: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.number,\n\n /**\r\n * URL to topojson files used in geo charts\r\n */\n topojsonURL: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Mapbox access token (required to plot mapbox trace types)\r\n * If using an Mapbox Atlas server, set this option to '',\r\n * so that plotly.js won't attempt to authenticate to the public Mapbox server.\r\n */\n mapboxAccessToken: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.any,\n\n /**\r\n * The locale to use. Locales may be provided with the plot\r\n * (`locales` below) or by loading them on the page, see:\r\n * https://github.com/plotly/plotly.js/blob/master/dist/README.md#to-include-localization\r\n */\n locale: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Localization definitions, if you choose to provide them with the\r\n * plot rather than registering them globally.\r\n */\n locales: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.object\n }),\n\n /**\r\n * Function that updates the state tree.\r\n */\n setProps: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.func,\n\n /**\r\n * Object that holds the loading state object coming from dash-renderer\r\n */\n loading_state: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.shape({\n /**\r\n * Determines if the component is loading or not\r\n */\n is_loading: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.bool,\n\n /**\r\n * Holds which property is loading\r\n */\n prop_name: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string,\n\n /**\r\n * Holds the name of the component that is loading\r\n */\n component_name: prop_types__WEBPACK_IMPORTED_MODULE_1___default.a.string\n })\n};\nvar graphDefaultProps = {\n clickData: null,\n clickAnnotationData: null,\n hoverData: null,\n selectedData: null,\n relayoutData: null,\n extendData: null,\n restyleData: null,\n figure: {\n data: [],\n layout: {},\n frames: []\n },\n animate: false,\n animation_options: {\n frame: {\n redraw: false\n },\n transition: {\n duration: 750,\n ease: 'cubic-in-out'\n }\n },\n clear_on_unhover: false,\n config: {}\n};\nExtendableGraph.propTypes = graphPropTypes;\nExtendableGraph.defaultProps = graphDefaultProps;\n/* harmony default export */ __webpack_exports__[\"default\"] = (ExtendableGraph);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_extendable_graph/./src/lib/components/ExtendableGraph.react.js?db56"],"names":["filterEventData","gd","eventData","event","filteredEventData","contains","points","isNil","data","i","length","fullPoint","pointData","filter","o","type","has","curveNumber","customdata","pointNumber","pointNumbers","range","lassoPoints","ExtendableGraph","props","React","createRef","bindEvents","bind","_hasPlotted","_prevGd","graphResize","figure","animate","animation_options","config","current","Plotly","react","layout","clone","frames","then","removeAllListeners","purge","Plots","resize","extendData","updateData","traceIndices","maxPoints","createDataObject","dataprops","Object","keys","ret","plot","Array","isArray","from","entries","value","updateObject","extendTraces","addTraces","setProps","clear_on_unhover","relayoutData","restyleData","hoverData","selectedData","on","clickData","clickAnnotationData","omit","hover","equals","selected","relayout","restyle","window","addEventListener","removeEventListener","nextProps","id","JSON","stringify","style","idChanged","figureChanged","extendDataChanged","extend","prevProps","className","loading_state","is_loading","undefined","Component","graphPropTypes","PropTypes","string","object","bool","oneOfType","array","exact","arrayOf","staticPlot","plotlyServerURL","editable","edits","annotationPosition","annotationTail","annotationText","axisTitleText","colorbarPosition","colorbarTitleText","legendPosition","legendText","shapePosition","titleText","autosizable","responsive","queueLength","number","fillFrame","frameMargins","scrollZoom","doubleClick","oneOf","showTips","showAxisDragHandles","showAxisRangeEntryBoxes","showLink","sendData","linkText","displayModeBar","showSendToCloud","modeBarButtonsToRemove","modeBarButtonsToAdd","modeBarButtons","any","toImageButtonOptions","format","filename","width","height","scale","displaylogo","watermark","plotGlPixelRatio","topojsonURL","mapboxAccessToken","locale","locales","func","shape","prop_name","component_name","graphDefaultProps","frame","redraw","transition","duration","ease","propTypes","defaultProps"],"mappings":"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","file":"./src/lib/components/ExtendableGraph.react.js.js","sourcesContent":["import React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport {contains, filter, clone, has, isNil, type, omit, equals} from 'ramda';\r\n/* global Plotly:true */\r\n\r\nconst filterEventData = (gd, eventData, event) => {\r\n    let filteredEventData;\r\n    if (contains(event, ['click', 'hover', 'selected'])) {\r\n        const points = [];\r\n\r\n        if (isNil(eventData)) {\r\n            return null;\r\n        }\r\n\r\n        /*\r\n         * remove `data`, `layout`, `xaxis`, etc\r\n         * objects from the event data since they're so big\r\n         * and cause JSON stringify ciricular structure errors.\r\n         *\r\n         * also, pull down the `customdata` point from the data array\r\n         * into the event object\r\n         */\r\n        const data = gd.data;\r\n\r\n        for (let i = 0; i < eventData.points.length; i++) {\r\n            const fullPoint = eventData.points[i];\r\n            const pointData = filter(function(o) {\r\n                return !contains(type(o), ['Object', 'Array']);\r\n            }, fullPoint);\r\n            if (\r\n                has('curveNumber', fullPoint) &&\r\n                has('pointNumber', fullPoint) &&\r\n                has('customdata', data[pointData.curveNumber])\r\n            ) {\r\n                pointData.customdata =\r\n                    data[pointData.curveNumber].customdata[\r\n                        fullPoint.pointNumber\r\n                    ];\r\n            }\r\n\r\n            // specific to histogram. see https://github.com/plotly/plotly.js/pull/2113/\r\n            if (has('pointNumbers', fullPoint)) {\r\n                pointData.pointNumbers = fullPoint.pointNumbers;\r\n            }\r\n\r\n            points[i] = pointData;\r\n        }\r\n        filteredEventData = {points};\r\n    } else if (event === 'relayout' || event === 'restyle') {\r\n        /*\r\n         * relayout shouldn't include any big objects\r\n         * it will usually just contain the ranges of the axes like\r\n         * \"xaxis.range[0]\": 0.7715822247381828,\r\n         * \"xaxis.range[1]\": 3.0095292008680063`\r\n         */\r\n        filteredEventData = eventData;\r\n    }\r\n    if (has('range', eventData)) {\r\n        filteredEventData.range = eventData.range;\r\n    }\r\n    if (has('lassoPoints', eventData)) {\r\n        filteredEventData.lassoPoints = eventData.lassoPoints;\r\n    }\r\n    return filteredEventData;\r\n};\r\n\r\n/**\r\n * ExtendableGraph can be used to render any plotly.js-powered data vis.\r\n *\r\n * You can define callbacks based on user interaction with ExtendableGraphs such\r\n * as hovering, clicking or selecting\r\n */\r\nclass ExtendableGraph extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n        this.gd = React.createRef();\r\n        this.bindEvents = this.bindEvents.bind(this);\r\n        this._hasPlotted = false;\r\n        this._prevGd = null;\r\n        this.graphResize = this.graphResize.bind(this);\r\n    }\r\n\r\n    plot(props) {\r\n        const {figure, animate, animation_options, config} = props;\r\n        const gd = this.gd.current;\r\n\r\n        if (\r\n            animate &&\r\n            this._hasPlotted &&\r\n            figure.data.length === gd.data.length\r\n        ) {\r\n            return Plotly.animate(gd, figure, animation_options);\r\n        }\r\n        return Plotly.react(gd, {\r\n            data: figure.data,\r\n            layout: clone(figure.layout),\r\n            frames: figure.frames,\r\n            config: config,\r\n        }).then(() => {\r\n            const gd = this.gd.current;\r\n\r\n            // double-check gd hasn't been unmounted\r\n            if (!gd) {\r\n                return;\r\n            }\r\n\r\n            // in case we've made a new DOM element, transfer events\r\n            if (this._hasPlotted && gd !== this._prevGd) {\r\n                if (this._prevGd && this._prevGd.removeAllListeners) {\r\n                    this._prevGd.removeAllListeners();\r\n                    Plotly.purge(this._prevGd);\r\n                }\r\n                this._hasPlotted = false;\r\n            }\r\n\r\n            if (!this._hasPlotted) {\r\n                this.bindEvents();\r\n                Plotly.Plots.resize(gd);\r\n                this._hasPlotted = true;\r\n                this._prevGd = gd;\r\n            }\r\n        });\r\n    }\r\n\r\n    extend(props) {\r\n        const {extendData} = props;\r\n        const gd = this.gd.current;\r\n        let updateData, traceIndices, maxPoints;\r\n\r\n        if (extendData) {\r\n            if (gd.data.length < 1) {\r\n                // figure has no pre-existing data. redirect to plot()\r\n                props.figure.data = extendData;\r\n                return this.plot(props);\r\n            }\r\n\r\n            if (Array.isArray(extendData) && Array.isArray(extendData[0])) {\r\n                [updateData, traceIndices, maxPoints] = extendData;\r\n            } else {\r\n                updateData = extendData;\r\n            }\r\n\r\n            if (!traceIndices) {\r\n                traceIndices = Array.from(Array(updateData.length).keys());\r\n            }\r\n\r\n            function createDataObject(data) {\r\n                const dataprops = Object.keys(data);\r\n                const ret = {};\r\n                for (let i = 0; i < dataprops.length; i++) {\r\n                    ret[dataprops[i]] = [data[dataprops[i]]];\r\n                }\r\n                return ret;\r\n            }\r\n\r\n            for (const [i, value] of updateData.entries()) {\r\n                const updateObject = createDataObject(value);\r\n                if (i < updateData.length - 1) {\r\n                    if (traceIndices[i] < gd.data.length) {\r\n                        Plotly.extendTraces(\r\n                            gd,\r\n                            updateObject,\r\n                            [traceIndices[i]],\r\n                            maxPoints\r\n                        );\r\n                    } else {\r\n                        Plotly.addTraces(gd, value);\r\n                    }\r\n                } else {\r\n                    if (traceIndices[i] < gd.data.length) {\r\n                        return Plotly.extendTraces(\r\n                            gd,\r\n                            updateObject,\r\n                            [traceIndices[i]],\r\n                            maxPoints\r\n                        );\r\n                    }\r\n                    return Plotly.addTraces(gd, value);\r\n                }\r\n            }\r\n        }\r\n\r\n        return this.plot(props);\r\n    }\r\n\r\n    graphResize() {\r\n        const gd = this.gd.current;\r\n        if (gd) {\r\n            Plotly.Plots.resize(gd);\r\n        }\r\n    }\r\n\r\n    bindEvents() {\r\n        const {\r\n            setProps,\r\n            clear_on_unhover,\r\n            relayoutData,\r\n            restyleData,\r\n            hoverData,\r\n            selectedData,\r\n        } = this.props;\r\n\r\n        const gd = this.gd.current;\r\n\r\n        gd.on('plotly_click', eventData => {\r\n            const clickData = filterEventData(gd, eventData, 'click');\r\n            if (!isNil(clickData)) {\r\n                setProps({clickData});\r\n            }\r\n        });\r\n        gd.on('plotly_clickannotation', eventData => {\r\n            const clickAnnotationData = omit(\r\n                ['event', 'fullAnnotation'],\r\n                eventData\r\n            );\r\n            setProps({clickAnnotationData});\r\n        });\r\n        gd.on('plotly_hover', eventData => {\r\n            const hover = filterEventData(gd, eventData, 'hover');\r\n            if (!isNil(hover) && !equals(hover, hoverData)) {\r\n                setProps({hoverData: hover});\r\n            }\r\n        });\r\n        gd.on('plotly_selected', eventData => {\r\n            const selected = filterEventData(gd, eventData, 'selected');\r\n            if (!isNil(selected) && !equals(selected, selectedData)) {\r\n                setProps({selectedData: selected});\r\n            }\r\n        });\r\n        gd.on('plotly_deselect', () => {\r\n            setProps({selectedData: null});\r\n        });\r\n        gd.on('plotly_relayout', eventData => {\r\n            const relayout = filterEventData(gd, eventData, 'relayout');\r\n            if (!isNil(relayout) && !equals(relayout, relayoutData)) {\r\n                setProps({relayoutData: relayout});\r\n            }\r\n        });\r\n        gd.on('plotly_restyle', eventData => {\r\n            const restyle = filterEventData(gd, eventData, 'restyle');\r\n            if (!isNil(restyle) && !equals(restyle, restyleData)) {\r\n                setProps({restyleData: restyle});\r\n            }\r\n        });\r\n        gd.on('plotly_unhover', () => {\r\n            if (clear_on_unhover) {\r\n                setProps({hoverData: null});\r\n            }\r\n        });\r\n    }\r\n\r\n    componentDidMount() {\r\n        this.plot(this.props).then(() => {\r\n            window.addEventListener('resize', this.graphResize);\r\n        });\r\n    }\r\n\r\n    componentWillUnmount() {\r\n        const gd = this.gd.current;\r\n        if (gd && gd.removeAllListeners) {\r\n            gd.removeAllListeners();\r\n            Plotly.purge(gd);\r\n        }\r\n        window.removeEventListener('resize', this.graphResize);\r\n    }\r\n\r\n    shouldComponentUpdate(nextProps) {\r\n        return (\r\n            this.props.id !== nextProps.id ||\r\n            JSON.stringify(this.props.style) !== JSON.stringify(nextProps.style)\r\n        );\r\n    }\r\n\r\n    componentWillReceiveProps(nextProps) {\r\n        const idChanged = this.props.id !== nextProps.id;\r\n        if (idChanged) {\r\n            /*\r\n             * then the dom needs to get re-rendered with a new ID.\r\n             * the graph will get updated in componentDidUpdate\r\n             */\r\n            return;\r\n        }\r\n\r\n        const figureChanged = this.props.figure !== nextProps.figure;\r\n        if (figureChanged) {\r\n            this.plot(nextProps);\r\n        }\r\n\r\n        const extendDataChanged =\r\n            this.props.extendData !== nextProps.extendData;\r\n        if (extendDataChanged) {\r\n            this.extend(nextProps);\r\n        }\r\n    }\r\n\r\n    componentDidUpdate(prevProps) {\r\n        if (prevProps.id !== this.props.id) {\r\n            this.plot(this.props);\r\n        }\r\n    }\r\n\r\n    render() {\r\n        const {className, id, style, loading_state} = this.props;\r\n\r\n        return (\r\n            <div\r\n                key={id}\r\n                id={id}\r\n                ref={this.gd}\r\n                data-dash-is-loading={\r\n                    (loading_state && loading_state.is_loading) || undefined\r\n                }\r\n                style={style}\r\n                className={className}\r\n            />\r\n        );\r\n    }\r\n}\r\n\r\nconst graphPropTypes = {\r\n    /**\r\n     * The ID of this component, used to identify dash components\r\n     * in callbacks. The ID needs to be unique across all of the\r\n     * components in an app.\r\n     */\r\n    id: PropTypes.string,\r\n    /**\r\n     * Data from latest click event. Read-only.\r\n     */\r\n    clickData: PropTypes.object,\r\n\r\n    /**\r\n     * Data from latest click annotation event. Read-only.\r\n     */\r\n    clickAnnotationData: PropTypes.object,\r\n\r\n    /**\r\n     * Data from latest hover event. Read-only.\r\n     */\r\n    hoverData: PropTypes.object,\r\n\r\n    /**\r\n     * If True, `clear_on_unhover` will clear the `hoverData` property\r\n     * when the user \"unhovers\" from a point.\r\n     * If False, then the `hoverData` property will be equal to the\r\n     * data from the last point that was hovered over.\r\n     */\r\n    clear_on_unhover: PropTypes.bool,\r\n\r\n    /**\r\n     * Data from latest select event. Read-only.\r\n     */\r\n    selectedData: PropTypes.object,\r\n\r\n    /**\r\n     * Data from latest relayout event which occurs\r\n     * when the user zooms or pans on the plot or other\r\n     * layout-level edits. Has the form `{<attr string>: <value>}`\r\n     * describing the changes made. Read-only.\r\n     */\r\n    relayoutData: PropTypes.object,\r\n\r\n    /**\r\n     * Data that should be appended to existing traces. Has the form\r\n     * `[updateData, traceIndices, maxPoints]`, where `updateData` is an array\r\n     * containing data objects to extend, `traceIndices` (optional) is an array\r\n     * of trace indices that should be extended, and `maxPoints` (optional) is\r\n     * either an integer defining the maximum number of points allowed or an\r\n     * object with key:value pairs matching `updateData`\r\n     * Reference the Plotly.extendTraces API for full usage:\r\n     * https://plot.ly/javascript/plotlyjs-function-reference/#plotlyextendtraces\r\n     */\r\n    extendData: PropTypes.oneOfType([PropTypes.array, PropTypes.object]),\r\n\r\n    /**\r\n     * Data from latest restyle event which occurs\r\n     * when the user toggles a legend item, changes\r\n     * parcoords selections, or other trace-level edits.\r\n     * Has the form `[edits, indices]`, where `edits` is an object\r\n     * `{<attr string>: <value>}` describing the changes made,\r\n     * and `indices` is an array of trace indices that were edited.\r\n     * Read-only.\r\n     */\r\n    restyleData: PropTypes.array,\r\n\r\n    /**\r\n     * Plotly `figure` object. See schema:\r\n     * https://plot.ly/javascript/reference\r\n     *\r\n     * `config` is set separately by the `config` property\r\n     */\r\n    figure: PropTypes.exact({\r\n        data: PropTypes.arrayOf(PropTypes.object),\r\n        layout: PropTypes.object,\r\n        frames: PropTypes.arrayOf(PropTypes.object),\r\n    }),\r\n\r\n    /**\r\n     * Generic style overrides on the plot div\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    /**\r\n     * className of the parent div\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Beta: If true, animate between updates using\r\n     * plotly.js's `animate` function\r\n     */\r\n    animate: PropTypes.bool,\r\n\r\n    /**\r\n     * Beta: Object containing animation settings.\r\n     * Only applies if `animate` is `true`\r\n     */\r\n    animation_options: PropTypes.object,\r\n\r\n    /**\r\n     * Plotly.js config options.\r\n     * See https://plot.ly/javascript/configuration-options/\r\n     * for more info.\r\n     */\r\n    config: PropTypes.exact({\r\n        /**\r\n         * No interactivity, for export or image generation\r\n         */\r\n        staticPlot: PropTypes.bool,\r\n\r\n        /**\r\n         * Base URL for a Plotly cloud instance, if `showSendToCloud` is enabled\r\n         */\r\n        plotlyServerURL: PropTypes.string,\r\n\r\n        /**\r\n         * We can edit titles, move annotations, etc - sets all pieces of `edits`\r\n         * unless a separate `edits` config item overrides individual parts\r\n         */\r\n        editable: PropTypes.bool,\r\n\r\n        /**\r\n         * A set of editable properties\r\n         */\r\n        edits: PropTypes.exact({\r\n            /**\r\n             * The main anchor of the annotation, which is the\r\n             * text (if no arrow) or the arrow (which drags the whole thing leaving\r\n             * the arrow length & direction unchanged)\r\n             */\r\n            annotationPosition: PropTypes.bool,\r\n\r\n            /**\r\n             * Just for annotations with arrows, change the length and direction of the arrow\r\n             */\r\n            annotationTail: PropTypes.bool,\r\n\r\n            annotationText: PropTypes.bool,\r\n\r\n            axisTitleText: PropTypes.bool,\r\n\r\n            colorbarPosition: PropTypes.bool,\r\n\r\n            colorbarTitleText: PropTypes.bool,\r\n\r\n            legendPosition: PropTypes.bool,\r\n\r\n            /**\r\n             * Edit the trace name fields from the legend\r\n             */\r\n            legendText: PropTypes.bool,\r\n\r\n            shapePosition: PropTypes.bool,\r\n\r\n            /**\r\n             * The global `layout.title`\r\n             */\r\n            titleText: PropTypes.bool,\r\n        }),\r\n\r\n        /**\r\n         * DO autosize once regardless of layout.autosize\r\n         * (use default width or height values otherwise)\r\n         */\r\n        autosizable: PropTypes.bool,\r\n\r\n        /**\r\n         * Whether to change layout size when the window size changes\r\n         */\r\n        responsive: PropTypes.bool,\r\n\r\n        /**\r\n         * Set the length of the undo/redo queue\r\n         */\r\n        queueLength: PropTypes.number,\r\n\r\n        /**\r\n         * If we DO autosize, do we fill the container or the screen?\r\n         */\r\n        fillFrame: PropTypes.bool,\r\n\r\n        /**\r\n         * If we DO autosize, set the frame margins in percents of plot size\r\n         */\r\n        frameMargins: PropTypes.number,\r\n\r\n        /**\r\n         * Mousewheel or two-finger scroll zooms the plot\r\n         */\r\n        scrollZoom: PropTypes.bool,\r\n\r\n        /**\r\n         * Double click interaction (false, 'reset', 'autosize' or 'reset+autosize')\r\n         */\r\n        doubleClick: PropTypes.oneOf([\r\n            false,\r\n            'reset',\r\n            'autosize',\r\n            'reset+autosize',\r\n        ]),\r\n\r\n        /**\r\n         * New users see some hints about interactivity\r\n         */\r\n        showTips: PropTypes.bool,\r\n\r\n        /**\r\n         * Enable axis pan/zoom drag handles\r\n         */\r\n        showAxisDragHandles: PropTypes.bool,\r\n\r\n        /**\r\n         * Enable direct range entry at the pan/zoom drag points\r\n         * (drag handles must be enabled above)\r\n         */\r\n        showAxisRangeEntryBoxes: PropTypes.bool,\r\n\r\n        /**\r\n         * Link to open this plot in plotly\r\n         */\r\n        showLink: PropTypes.bool,\r\n\r\n        /**\r\n         * If we show a link, does it contain data or just link to a plotly file?\r\n         */\r\n        sendData: PropTypes.bool,\r\n\r\n        /**\r\n         * Text appearing in the sendData link\r\n         */\r\n        linkText: PropTypes.string,\r\n\r\n        /**\r\n         * Display the mode bar (true, false, or 'hover')\r\n         */\r\n        displayModeBar: PropTypes.oneOf([true, false, 'hover']),\r\n\r\n        /**\r\n         * Should we include a modebar button to send this data to a\r\n         * Plotly Cloud instance, linked by `plotlyServerURL`.\r\n         * By default this is false.\r\n         */\r\n        showSendToCloud: PropTypes.bool,\r\n\r\n        /**\r\n         * Remove mode bar button by name.\r\n         * All modebar button names at https://github.com/plotly/plotly.js/blob/master/src/components/modebar/buttons.js\r\n         * Common names include:\r\n         * sendDataToCloud;\r\n         * (2D) zoom2d, pan2d, select2d, lasso2d, zoomIn2d, zoomOut2d, autoScale2d, resetScale2d;\r\n         * (Cartesian) hoverClosestCartesian, hoverCompareCartesian;\r\n         * (3D) zoom3d, pan3d, orbitRotation, tableRotation, handleDrag3d, resetCameraDefault3d, resetCameraLastSave3d, hoverClosest3d;\r\n         * (Geo) zoomInGeo, zoomOutGeo, resetGeo, hoverClosestGeo;\r\n         * hoverClosestGl2d, hoverClosestPie, toggleHover, resetViews.\r\n         */\r\n        modeBarButtonsToRemove: PropTypes.array,\r\n\r\n        /**\r\n         * Add mode bar button using config objects\r\n         */\r\n        modeBarButtonsToAdd: PropTypes.array,\r\n\r\n        /**\r\n         * Fully custom mode bar buttons as nested array,\r\n         * where the outer arrays represents button groups, and\r\n         * the inner arrays have buttons config objects or names of default buttons\r\n         */\r\n        modeBarButtons: PropTypes.any,\r\n\r\n        /**\r\n         * Modifications to how the toImage modebar button works\r\n         */\r\n        toImageButtonOptions: PropTypes.exact({\r\n            /**\r\n             * The file format to create\r\n             */\r\n            format: PropTypes.oneOf(['jpeg', 'png', 'webp', 'svg']),\r\n            /**\r\n             * The name given to the downloaded file\r\n             */\r\n            filename: PropTypes.string,\r\n            /**\r\n             * Width of the downloaded file, in px\r\n             */\r\n            width: PropTypes.number,\r\n            /**\r\n             * Height of the downloaded file, in px\r\n             */\r\n            height: PropTypes.number,\r\n            /**\r\n             * Extra resolution to give the file after\r\n             * rendering it with the given width and height\r\n             */\r\n            scale: PropTypes.number,\r\n        }),\r\n\r\n        /**\r\n         * Add the plotly logo on the end of the mode bar\r\n         */\r\n        displaylogo: PropTypes.bool,\r\n\r\n        /**\r\n         * Add the plotly logo even with no modebar\r\n         */\r\n        watermark: PropTypes.bool,\r\n\r\n        /**\r\n         * Increase the pixel ratio for Gl plot images\r\n         */\r\n        plotGlPixelRatio: PropTypes.number,\r\n\r\n        /**\r\n         * URL to topojson files used in geo charts\r\n         */\r\n        topojsonURL: PropTypes.string,\r\n\r\n        /**\r\n         * Mapbox access token (required to plot mapbox trace types)\r\n         * If using an Mapbox Atlas server, set this option to '',\r\n         * so that plotly.js won't attempt to authenticate to the public Mapbox server.\r\n         */\r\n        mapboxAccessToken: PropTypes.any,\r\n\r\n        /**\r\n         * The locale to use. Locales may be provided with the plot\r\n         * (`locales` below) or by loading them on the page, see:\r\n         * https://github.com/plotly/plotly.js/blob/master/dist/README.md#to-include-localization\r\n         */\r\n        locale: PropTypes.string,\r\n\r\n        /**\r\n         * Localization definitions, if you choose to provide them with the\r\n         * plot rather than registering them globally.\r\n         */\r\n        locales: PropTypes.object,\r\n    }),\r\n\r\n    /**\r\n     * Function that updates the state tree.\r\n     */\r\n    setProps: PropTypes.func,\r\n\r\n    /**\r\n     * Object that holds the loading state object coming from dash-renderer\r\n     */\r\n    loading_state: PropTypes.shape({\r\n        /**\r\n         * Determines if the component is loading or not\r\n         */\r\n        is_loading: PropTypes.bool,\r\n        /**\r\n         * Holds which property is loading\r\n         */\r\n        prop_name: PropTypes.string,\r\n        /**\r\n         * Holds the name of the component that is loading\r\n         */\r\n        component_name: PropTypes.string,\r\n    }),\r\n};\r\n\r\nconst graphDefaultProps = {\r\n    clickData: null,\r\n    clickAnnotationData: null,\r\n    hoverData: null,\r\n    selectedData: null,\r\n    relayoutData: null,\r\n    extendData: null,\r\n    restyleData: null,\r\n    figure: {data: [], layout: {}, frames: []},\r\n    animate: false,\r\n    animation_options: {\r\n        frame: {\r\n            redraw: false,\r\n        },\r\n        transition: {\r\n            duration: 750,\r\n            ease: 'cubic-in-out',\r\n        },\r\n    },\r\n    clear_on_unhover: false,\r\n    config: {},\r\n};\r\n\r\nExtendableGraph.propTypes = graphPropTypes;\r\nExtendableGraph.defaultProps = graphDefaultProps;\r\n\r\nexport default ExtendableGraph;\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/lib/components/ExtendableGraph.react.js\n"); /***/ }), diff --git a/dash_extendable_graph/dash_extendable_graph.min.js b/dash_extendable_graph/dash_extendable_graph.min.js index 048ffee..b1e5246 100644 --- a/dash_extendable_graph/dash_extendable_graph.min.js +++ b/dash_extendable_graph/dash_extendable_graph.min.js @@ -1 +1 @@ -window.dash_extendable_graph=function(t){var e={};function n(r){if(e[r])return e[r].exports;var o=e[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var o in t)n.d(r,o,function(e){return t[e]}.bind(null,o));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=2)}([function(t,e){t.exports=window.PropTypes},function(t,e){t.exports=window.React},function(t,e,n){"use strict";n.r(e);var r=n(1),o=n.n(r),a=n(0),i=n.n(a);function u(t){return null!=t&&"object"==typeof t&&!0===t["@@functional/placeholder"]}function l(t){return function e(n){return 0===arguments.length||u(n)?e:t.apply(this,arguments)}}function c(t){return function e(n,r){switch(arguments.length){case 0:return e;case 1:return u(n)?e:l(function(e){return t(n,e)});default:return u(n)&&u(r)?e:u(n)?l(function(e){return t(e,r)}):u(r)?l(function(e){return t(n,e)}):t(n,r)}}}function s(t){for(var e,n=[];!(e=t.next()).done;)n.push(e.value);return n}function f(t,e,n){for(var r=0,o=n.length;r=0;)p(e=g[n],t)&&!m(r,e)&&(r[r.length]=e),n-=1;return r}):l(function(t){return Object(t)!==t?[]:Object.keys(t)}),j=l(function(t){return null===t?"Null":void 0===t?"Undefined":Object.prototype.toString.call(t).slice(8,-1)});function w(t,e,n,r){var o=s(t);function a(t,e){return x(t,e,n.slice(),r.slice())}return!f(function(t,e){return!f(a,e,t)},s(e),o)}function x(t,e,n,r){if(y(t,e))return!0;var o,a,i=j(t);if(i!==j(e))return!1;if(null==t||null==e)return!1;if("function"==typeof t["fantasy-land/equals"]||"function"==typeof e["fantasy-land/equals"])return"function"==typeof t["fantasy-land/equals"]&&t["fantasy-land/equals"](e)&&"function"==typeof e["fantasy-land/equals"]&&e["fantasy-land/equals"](t);if("function"==typeof t.equals||"function"==typeof e.equals)return"function"==typeof t.equals&&t.equals(e)&&"function"==typeof e.equals&&e.equals(t);switch(i){case"Arguments":case"Array":case"Object":if("function"==typeof t.constructor&&"Promise"===(o=t.constructor,null==(a=String(o).match(/^function (\w*)/))?"":a[1]))return t===e;break;case"Boolean":case"Number":case"String":if(typeof t!=typeof e||!y(t.valueOf(),e.valueOf()))return!1;break;case"Date":if(!y(t.valueOf(),e.valueOf()))return!1;break;case"Error":return t.name===e.name&&t.message===e.message;case"RegExp":if(t.source!==e.source||t.global!==e.global||t.ignoreCase!==e.ignoreCase||t.multiline!==e.multiline||t.sticky!==e.sticky||t.unicode!==e.unicode)return!1}for(var u=n.length-1;u>=0;){if(n[u]===t)return r[u]===e;u-=1}switch(i){case"Map":return t.size===e.size&&w(t.entries(),e.entries(),n.concat([t]),r.concat([e]));case"Set":return t.size===e.size&&w(t.values(),e.values(),n.concat([t]),r.concat([e]));case"Arguments":case"Array":case"Object":case"Boolean":case"Number":case"String":case"Date":case"Error":case"RegExp":case"Int8Array":case"Uint8Array":case"Uint8ClampedArray":case"Int16Array":case"Uint16Array":case"Int32Array":case"Uint32Array":case"Float32Array":case"Float64Array":case"ArrayBuffer":break;default:return!1}var l=O(t);if(l.length!==O(e).length)return!1;var c=n.concat([t]),s=r.concat([e]);for(u=l.length-1;u>=0;){var f=l[u];if(!p(f,e)||!x(e[f],t[f],c,s))return!1;u-=1}return!0}var P=c(function(t,e){return x(t,e,[],[])});function _(t,e){return function(t,e,n){var r,o;if("function"==typeof t.indexOf)switch(typeof e){case"number":if(0===e){for(r=1/e;n=0}var k=c(_),A=l(function(t){return null==t}),S=Array.isArray||function(t){return null!=t&&t.length>=0&&"[object Array]"===Object.prototype.toString.call(t)};function D(t){return null!=t&&"function"==typeof t["@@transducer/step"]}function E(t,e,n){return function(){if(0===arguments.length)return n();var r=Array.prototype.slice.call(arguments,0),o=r.pop();if(!S(o)){for(var a=0;a0&&(t.hasOwnProperty(0)&&t.hasOwnProperty(t.length-1)))))}),B=function(){function t(t){this.f=t}return t.prototype["@@transducer/init"]=function(){throw new Error("init not implemented on XWrap")},t.prototype["@@transducer/result"]=function(t){return t},t.prototype["@@transducer/step"]=function(t,e){return this.f(t,e)},t}();var R=c(function(t,e){return function(t,e){switch(t){case 0:return function(){return e.apply(this,arguments)};case 1:return function(t){return e.apply(this,arguments)};case 2:return function(t,n){return e.apply(this,arguments)};case 3:return function(t,n,r){return e.apply(this,arguments)};case 4:return function(t,n,r,o){return e.apply(this,arguments)};case 5:return function(t,n,r,o,a){return e.apply(this,arguments)};case 6:return function(t,n,r,o,a,i){return e.apply(this,arguments)};case 7:return function(t,n,r,o,a,i,u){return e.apply(this,arguments)};case 8:return function(t,n,r,o,a,i,u,l){return e.apply(this,arguments)};case 9:return function(t,n,r,o,a,i,u,l,c){return e.apply(this,arguments)};case 10:return function(t,n,r,o,a,i,u,l,c,s){return e.apply(this,arguments)};default:throw new Error("First argument to _arity must be a non-negative integer no greater than ten")}}(t.length,function(){return t.apply(e,arguments)})});function z(t,e,n){for(var r=n.next();!r.done;){if((e=t["@@transducer/step"](e,r.value))&&e["@@transducer/reduced"]){e=e["@@transducer/value"];break}r=n.next()}return t["@@transducer/result"](e)}function N(t,e,n,r){return t["@@transducer/result"](n[r](R(t["@@transducer/step"],t),e))}var q="undefined"!=typeof Symbol?Symbol.iterator:"@@iterator";function I(t,e,n){if("function"==typeof t&&(t=function(t){return new B(t)}(t)),T(n))return function(t,e,n){for(var r=0,o=n.length;r=0;)p(e=v[n],t)&&!m(r,e)&&(r[r.length]=e),n-=1;return r}):l(function(t){return Object(t)!==t?[]:Object.keys(t)}),j=l(function(t){return null===t?"Null":void 0===t?"Undefined":Object.prototype.toString.call(t).slice(8,-1)});function w(t,e,n,r){var o=s(t);function a(t,e){return x(t,e,n.slice(),r.slice())}return!f(function(t,e){return!f(a,e,t)},s(e),o)}function x(t,e,n,r){if(y(t,e))return!0;var o,a,u=j(t);if(u!==j(e))return!1;if(null==t||null==e)return!1;if("function"==typeof t["fantasy-land/equals"]||"function"==typeof e["fantasy-land/equals"])return"function"==typeof t["fantasy-land/equals"]&&t["fantasy-land/equals"](e)&&"function"==typeof e["fantasy-land/equals"]&&e["fantasy-land/equals"](t);if("function"==typeof t.equals||"function"==typeof e.equals)return"function"==typeof t.equals&&t.equals(e)&&"function"==typeof e.equals&&e.equals(t);switch(u){case"Arguments":case"Array":case"Object":if("function"==typeof t.constructor&&"Promise"===(o=t.constructor,null==(a=String(o).match(/^function (\w*)/))?"":a[1]))return t===e;break;case"Boolean":case"Number":case"String":if(typeof t!=typeof e||!y(t.valueOf(),e.valueOf()))return!1;break;case"Date":if(!y(t.valueOf(),e.valueOf()))return!1;break;case"Error":return t.name===e.name&&t.message===e.message;case"RegExp":if(t.source!==e.source||t.global!==e.global||t.ignoreCase!==e.ignoreCase||t.multiline!==e.multiline||t.sticky!==e.sticky||t.unicode!==e.unicode)return!1}for(var i=n.length-1;i>=0;){if(n[i]===t)return r[i]===e;i-=1}switch(u){case"Map":return t.size===e.size&&w(t.entries(),e.entries(),n.concat([t]),r.concat([e]));case"Set":return t.size===e.size&&w(t.values(),e.values(),n.concat([t]),r.concat([e]));case"Arguments":case"Array":case"Object":case"Boolean":case"Number":case"String":case"Date":case"Error":case"RegExp":case"Int8Array":case"Uint8Array":case"Uint8ClampedArray":case"Int16Array":case"Uint16Array":case"Int32Array":case"Uint32Array":case"Float32Array":case"Float64Array":case"ArrayBuffer":break;default:return!1}var l=O(t);if(l.length!==O(e).length)return!1;var c=n.concat([t]),s=r.concat([e]);for(i=l.length-1;i>=0;){var f=l[i];if(!p(f,e)||!x(e[f],t[f],c,s))return!1;i-=1}return!0}var _=c(function(t,e){return x(t,e,[],[])});function P(t,e){return function(t,e,n){var r,o;if("function"==typeof t.indexOf)switch(typeof e){case"number":if(0===e){for(r=1/e;n=0}var A=c(P),k=l(function(t){return null==t}),D=Array.isArray||function(t){return null!=t&&t.length>=0&&"[object Array]"===Object.prototype.toString.call(t)};function S(t){return null!=t&&"function"==typeof t["@@transducer/step"]}function T(t,e,n){return function(){if(0===arguments.length)return n();var r=Array.prototype.slice.call(arguments,0),o=r.pop();if(!D(o)){for(var a=0;a0&&(t.hasOwnProperty(0)&&t.hasOwnProperty(t.length-1)))))}),R=function(){function t(t){this.f=t}return t.prototype["@@transducer/init"]=function(){throw new Error("init not implemented on XWrap")},t.prototype["@@transducer/result"]=function(t){return t},t.prototype["@@transducer/step"]=function(t,e){return this.f(t,e)},t}();var z=c(function(t,e){return function(t,e){switch(t){case 0:return function(){return e.apply(this,arguments)};case 1:return function(t){return e.apply(this,arguments)};case 2:return function(t,n){return e.apply(this,arguments)};case 3:return function(t,n,r){return e.apply(this,arguments)};case 4:return function(t,n,r,o){return e.apply(this,arguments)};case 5:return function(t,n,r,o,a){return e.apply(this,arguments)};case 6:return function(t,n,r,o,a,u){return e.apply(this,arguments)};case 7:return function(t,n,r,o,a,u,i){return e.apply(this,arguments)};case 8:return function(t,n,r,o,a,u,i,l){return e.apply(this,arguments)};case 9:return function(t,n,r,o,a,u,i,l,c){return e.apply(this,arguments)};case 10:return function(t,n,r,o,a,u,i,l,c,s){return e.apply(this,arguments)};default:throw new Error("First argument to _arity must be a non-negative integer no greater than ten")}}(t.length,function(){return t.apply(e,arguments)})});function N(t,e,n){for(var r=n.next();!r.done;){if((e=t["@@transducer/step"](e,r.value))&&e["@@transducer/reduced"]){e=e["@@transducer/value"];break}r=n.next()}return t["@@transducer/result"](e)}function q(t,e,n,r){return t["@@transducer/result"](n[r](z(t["@@transducer/step"],t),e))}var B="undefined"!=typeof Symbol?Symbol.iterator:"@@iterator";function L(t,e,n){if("function"==typeof t&&(t=function(t){return new R(t)}(t)),E(n))return function(t,e,n){for(var r=0,o=n.length;r