diff --git a/dash_core_components/Store.py b/dash_core_components/Store.py new file mode 100644 index 000000000..4bc15e1f8 --- /dev/null +++ b/dash_core_components/Store.py @@ -0,0 +1,67 @@ +# AUTO GENERATED FILE - DO NOT EDIT + +from dash.development.base_component import Component, _explicitize_args + + +class Store(Component): + """A Store component. +Easily keep data on the client side with this component. +The data is not inserted in the DOM. +Data can be in memory, localStorage or sessionStorage. +The data will be kept with the id as key. + +Keyword arguments: +- id (string; required): The key of the storage. +- storage_type (a value equal to: 'local', 'session', 'memory'; optional): The type of the web storage. + +memory: only kept in memory, reset on page refresh. +local: window.localStorage, data is kept after the browser quit. +session: window.sessionStorage, data is cleared once the browser quit. +- data (dict | list | number | string; optional): The stored data for the id. +- clear_data (boolean; optional): Set to true to remove the data contained in `data_key`. +- modified_timestamp (number; optional): The last time the storage was modified. + +Available events: """ + @_explicitize_args + def __init__(self, id=Component.REQUIRED, storage_type=Component.UNDEFINED, data=Component.UNDEFINED, clear_data=Component.UNDEFINED, modified_timestamp=Component.UNDEFINED, **kwargs): + self._prop_names = ['id', 'storage_type', 'data', 'clear_data', 'modified_timestamp'] + self._type = 'Store' + self._namespace = 'dash_core_components' + self._valid_wildcard_attributes = [] + self.available_events = [] + self.available_properties = ['id', 'storage_type', 'data', 'clear_data', 'modified_timestamp'] + self.available_wildcard_properties = [] + + _explicit_args = kwargs.pop('_explicit_args') + _locals = locals() + _locals.update(kwargs) # For wildcard attrs + args = {k: _locals[k] for k in _explicit_args if k != 'children'} + + for k in ['id']: + if k not in args: + raise TypeError( + 'Required argument `' + k + '` was not specified.') + super(Store, self).__init__(**args) + + def __repr__(self): + if(any(getattr(self, c, None) is not None + for c in self._prop_names + if c is not self._prop_names[0]) + or any(getattr(self, c, None) is not None + for c in self.__dict__.keys() + if any(c.startswith(wc_attr) + for wc_attr in self._valid_wildcard_attributes))): + props_string = ', '.join([c+'='+repr(getattr(self, c, None)) + for c in self._prop_names + if getattr(self, c, None) is not None]) + wilds_string = ', '.join([c+'='+repr(getattr(self, c, None)) + for c in self.__dict__.keys() + if any([c.startswith(wc_attr) + for wc_attr in + self._valid_wildcard_attributes])]) + return ('Store(' + props_string + + (', ' + wilds_string if wilds_string != '' else '') + ')') + else: + return ( + 'Store(' + + repr(getattr(self, self._prop_names[0], None)) + ')') diff --git a/dash_core_components/_imports_.py b/dash_core_components/_imports_.py index 7a36d0500..80e87da1e 100644 --- a/dash_core_components/_imports_.py +++ b/dash_core_components/_imports_.py @@ -13,6 +13,7 @@ from .RadioItems import RadioItems from .RangeSlider import RangeSlider from .Slider import Slider +from .Store import Store from .SyntaxHighlighter import SyntaxHighlighter from .Tab import Tab from .Tabs import Tabs @@ -36,6 +37,7 @@ "RadioItems", "RangeSlider", "Slider", + "Store", "SyntaxHighlighter", "Tab", "Tabs", diff --git a/dash_core_components/dash_core_components.dev.js b/dash_core_components/dash_core_components.dev.js index 4ba140392..1b87dca04 100644 --- a/dash_core_components/dash_core_components.dev.js +++ b/dash_core_components/dash_core_components.dev.js @@ -12910,7 +12910,7 @@ eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n}); /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar React = _interopRequireDefault(_react).default;\n\nvar Component = _react.Component;\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar PropTypes = _interopRequireDefault(_propTypes).default;\n\nvar _ramda = __webpack_require__(/*! ramda */ \"./node_modules/ramda/index.js\");\n\nvar contains = _ramda.contains;\nvar filter = _ramda.filter;\nvar has = _ramda.has;\nvar isNil = _ramda.isNil;\nvar type = _ramda.type;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/* global Plotly:true */\n\nvar filterEventData = function filterEventData(gd, eventData, event) {\n var filteredEventData = void 0;\n if (contains(event, ['click', 'hover', 'selected'])) {\n var points = [];\n\n if (isNil(eventData)) {\n return null;\n }\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 var data = gd.data;\n\n for (var i = 0; i < eventData.points.length; i++) {\n var fullPoint = eventData.points[i];\n var pointData = filter(function (o) {\n return !contains(type(o), ['Object', 'Array']);\n }, fullPoint);\n if (has('curveNumber', fullPoint) && has('pointNumber', fullPoint) && has('customdata', data[pointData.curveNumber])) {\n pointData.customdata = data[pointData.curveNumber].customdata[fullPoint.pointNumber];\n }\n\n // specific to histogram. see https://github.com/plotly/plotly.js/pull/2113/\n if (has('pointNumbers', fullPoint)) {\n pointData.pointNumbers = fullPoint.pointNumbers;\n }\n\n points[i] = pointData;\n }\n filteredEventData = { points: points };\n } else if (event === 'relayout') {\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 if (has('range', eventData)) {\n filteredEventData.range = eventData.range;\n }\n if (has('lassoPoints', eventData)) {\n filteredEventData.lassoPoints = eventData.lassoPoints;\n }\n return filteredEventData;\n};\n\nvar PlotlyGraph = function (_Component) {\n _inherits(PlotlyGraph, _Component);\n\n function PlotlyGraph(props) {\n _classCallCheck(this, PlotlyGraph);\n\n var _this = _possibleConstructorReturn(this, (PlotlyGraph.__proto__ || Object.getPrototypeOf(PlotlyGraph)).call(this, props));\n\n _this.bindEvents = _this.bindEvents.bind(_this);\n _this._hasPlotted = false;\n return _this;\n }\n\n _createClass(PlotlyGraph, [{\n key: 'plot',\n value: function plot(props) {\n var _this2 = this;\n\n var id = props.id,\n figure = props.figure,\n animate = props.animate,\n animation_options = props.animation_options,\n config = props.config;\n\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 return Plotly.react(id, figure.data, figure.layout, config).then(function () {\n if (!_this2._hasPlotted) {\n _this2.bindEvents();\n Plotly.Plots.resize(document.getElementById(id));\n _this2._hasPlotted = true;\n }\n });\n }\n }, {\n key: 'bindEvents',\n value: function bindEvents() {\n var _props = this.props,\n id = _props.id,\n fireEvent = _props.fireEvent,\n setProps = _props.setProps,\n clear_on_unhover = _props.clear_on_unhover;\n\n\n var gd = document.getElementById(id);\n\n gd.on('plotly_click', function (eventData) {\n var clickData = filterEventData(gd, eventData, 'click');\n if (!isNil(clickData)) {\n if (setProps) {\n setProps({ clickData: clickData });\n }\n if (fireEvent) {\n fireEvent({ event: 'click' });\n }\n }\n });\n gd.on('plotly_hover', function (eventData) {\n var hoverData = filterEventData(gd, eventData, 'hover');\n if (!isNil(hoverData)) {\n if (setProps) {\n setProps({ hoverData: hoverData });\n }\n if (fireEvent) {\n fireEvent({ event: 'hover' });\n }\n }\n });\n gd.on('plotly_selected', function (eventData) {\n var selectedData = filterEventData(gd, eventData, 'selected');\n if (!isNil(selectedData)) {\n if (setProps) {\n setProps({ selectedData: selectedData });\n }\n if (fireEvent) {\n fireEvent({ event: 'selected' });\n }\n }\n });\n gd.on('plotly_deselect', function () {\n if (setProps) {\n setProps({ selectedData: null });\n }\n if (fireEvent) {\n fireEvent({ event: 'selected' });\n }\n });\n gd.on('plotly_relayout', function (eventData) {\n var relayoutData = filterEventData(gd, eventData, 'relayout');\n if (!isNil(relayoutData)) {\n if (setProps) {\n setProps({ relayoutData: relayoutData });\n }\n if (fireEvent) {\n fireEvent({ event: 'relayout' });\n }\n }\n });\n gd.on('plotly_unhover', function () {\n if (clear_on_unhover) {\n if (setProps) {\n setProps({ hoverData: null });\n }\n if (fireEvent) {\n fireEvent({ event: 'unhover' });\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', function () {\n Plotly.Plots.resize(document.getElementById(_this3.props.id));\n });\n });\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n if (this.eventEmitter) {\n this.eventEmitter.removeAllListeners();\n }\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 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 }, {\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 _props2 = this.props,\n className = _props2.className,\n id = _props2.id,\n style = _props2.style;\n\n\n return React.createElement('div', {\n key: id,\n id: id,\n style: style,\n className: className\n });\n }\n }]);\n\n return PlotlyGraph;\n}(Component);\n\nexports.default = PlotlyGraph;\n\n\nPlotlyGraph.propTypes = {\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: PropTypes.string,\n /**\r\n * Data from latest click event\r\n */\n clickData: PropTypes.object,\n\n /**\r\n * Data from latest hover event\r\n */\n hoverData: PropTypes.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: PropTypes.bool,\n\n /**\r\n * Data from latest select event\r\n */\n selectedData: PropTypes.object,\n\n /**\r\n * Data from latest relayout event which occurs\r\n * when the user zooms or pans on the plot\r\n */\n relayoutData: PropTypes.object,\n\n /**\r\n * Plotly `figure` object. See schema:\r\n * https://plot.ly/javascript/reference\r\n */\n figure: PropTypes.object,\n\n /**\r\n * Generic style overrides on the plot div\r\n */\n style: PropTypes.object,\n\n /**\r\n * className of the parent div\r\n */\n className: PropTypes.string,\n\n /**\r\n * Beta: If true, animate between updates using\r\n * plotly.js's `animate` function\r\n */\n animate: PropTypes.bool,\n\n /**\r\n * Beta: Object containing animation settings.\r\n * Only applies if `animate` is `true`\r\n */\n animation_options: PropTypes.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: PropTypes.shape({\n /**\r\n * no interactivity, for export or image generation\r\n */\n staticPlot: PropTypes.bool,\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: PropTypes.bool,\n\n /**\r\n * a set of editable properties\r\n */\n edits: PropTypes.shape({\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: PropTypes.bool,\n\n /**\r\n * just for annotations with arrows, change the length and direction of the arrow\r\n */\n annotationTail: PropTypes.bool,\n\n annotationText: PropTypes.bool,\n\n axisTitleText: PropTypes.bool,\n\n colorbarPosition: PropTypes.bool,\n\n colorbarTitleText: PropTypes.bool,\n\n legendPosition: PropTypes.bool,\n\n /**\r\n * edit the trace name fields from the legend\r\n */\n legendText: PropTypes.bool,\n\n shapePosition: PropTypes.bool,\n\n /**\r\n * the global `layout.title`\r\n */\n titleText: PropTypes.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: PropTypes.bool,\n\n /**\r\n * set the length of the undo/redo queue\r\n */\n queueLength: PropTypes.number,\n\n /**\r\n * if we DO autosize, do we fill the container or the screen?\r\n */\n fillFrame: PropTypes.bool,\n\n /**\r\n * if we DO autosize, set the frame margins in percents of plot size\r\n */\n frameMargins: PropTypes.number,\n\n /**\r\n * mousewheel or two-finger scroll zooms the plot\r\n */\n scrollZoom: PropTypes.bool,\n\n /**\r\n * double click interaction (false, 'reset', 'autosize' or 'reset+autosize')\r\n */\n doubleClick: PropTypes.oneOf([false, 'reset', 'autosize', 'reset+autosize']),\n\n /**\r\n * new users see some hints about interactivity\r\n */\n showTips: PropTypes.bool,\n\n /**\r\n * enable axis pan/zoom drag handles\r\n */\n showAxisDragHandles: PropTypes.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: PropTypes.bool,\n\n /**\r\n * link to open this plot in plotly\r\n */\n showLink: PropTypes.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: PropTypes.bool,\n\n /**\r\n * text appearing in the sendData link\r\n */\n linkText: PropTypes.string,\n\n /**\r\n * display the mode bar (true, false, or 'hover')\r\n */\n displayModeBar: PropTypes.oneOf([true, false, 'hover']),\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: PropTypes.array,\n\n /**\r\n * add mode bar button using config objects\r\n */\n modeBarButtonsToAdd: PropTypes.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: PropTypes.any,\n\n /**\r\n * add the plotly logo on the end of the mode bar\r\n */\n displaylogo: PropTypes.bool,\n\n /**\r\n * increase the pixel ratio for Gl plot images\r\n */\n plotGlPixelRatio: PropTypes.number,\n\n /**\r\n * URL to topojson files used in geo charts\r\n */\n topojsonURL: PropTypes.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: PropTypes.any\n }),\n\n /**\r\n *\r\n */\n dashEvents: PropTypes.oneOf(['click', 'hover', 'selected', 'relayout', 'unhover']),\n\n /**\r\n * Function that updates the state tree.\r\n */\n setProps: PropTypes.func,\n\n /**\r\n * Function that fires events\r\n */\n fireEvent: PropTypes.func\n};\n\nPlotlyGraph.defaultProps = {\n /* eslint-disable no-magic-numbers */\n id: 'graph-' + Math.random().toString(36).substring(2, 7),\n /* eslint-enable no-magic-numbers */\n clickData: null,\n hoverData: null,\n selectedData: null,\n relayoutData: null,\n figure: { data: [], layout: {} },\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 staticPlot: false,\n editable: false,\n edits: {\n annotationPosition: false,\n annotationTail: false,\n annotationText: false,\n axisTitleText: false,\n colorbarPosition: false,\n colorbarTitleText: false,\n legendPosition: false,\n legendText: false,\n shapePosition: false,\n titleText: false\n },\n autosizable: false,\n queueLength: 0,\n fillFrame: false,\n frameMargins: 0,\n scrollZoom: false,\n doubleClick: 'reset+autosize',\n showTips: true,\n showAxisDragHandles: true,\n showAxisRangeEntryBoxes: true,\n showLink: false,\n sendData: true,\n linkText: 'Edit chart',\n showSources: false,\n displayModeBar: 'hover',\n modeBarButtonsToRemove: [],\n modeBarButtonsToAdd: [],\n modeBarButtons: false,\n displaylogo: true,\n plotGlPixelRatio: 2,\n topojsonURL: 'https://cdn.plot.ly/',\n mapboxAccessToken: null\n }\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_core_components/./src/components/Graph.react.js?2a5f"],"names":["React","Component","PropTypes","contains","filter","has","isNil","type","filterEventData","gd","eventData","event","filteredEventData","points","data","i","length","fullPoint","pointData","o","curveNumber","customdata","pointNumber","pointNumbers","range","lassoPoints","PlotlyGraph","props","bindEvents","bind","_hasPlotted","id","figure","animate","animation_options","config","document","getElementById","Plotly","react","layout","then","Plots","resize","fireEvent","setProps","clear_on_unhover","on","clickData","hoverData","selectedData","relayoutData","plot","window","addEventListener","eventEmitter","removeAllListeners","nextProps","JSON","stringify","style","idChanged","figureChanged","prevProps","className","propTypes","string","object","bool","shape","staticPlot","editable","edits","annotationPosition","annotationTail","annotationText","axisTitleText","colorbarPosition","colorbarTitleText","legendPosition","legendText","shapePosition","titleText","autosizable","queueLength","number","fillFrame","frameMargins","scrollZoom","doubleClick","oneOf","showTips","showAxisDragHandles","showAxisRangeEntryBoxes","showLink","sendData","linkText","displayModeBar","modeBarButtonsToRemove","array","modeBarButtonsToAdd","modeBarButtons","any","displaylogo","plotGlPixelRatio","topojsonURL","mapboxAccessToken","dashEvents","func","defaultProps","Math","random","toString","substring","frame","redraw","transition","duration","ease","showSources"],"mappings":"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","file":"./src/components/Graph.react.js.js","sourcesContent":["import React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport {contains, filter, has, isNil, type} 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 (has('curveNumber', fullPoint) &&\r\n                has('pointNumber', fullPoint) &&\r\n                has('customdata', data[pointData.curveNumber])\r\n            ) {\r\n                pointData.customdata = data[\r\n                    pointData.curveNumber\r\n                ].customdata[fullPoint.pointNumber];\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        }\r\n        filteredEventData = {points}\r\n    } else if (event === 'relayout') {\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\nexport default class PlotlyGraph 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    }\r\n\r\n    plot(props) {\r\n        const {id, figure, animate, animation_options, config} = props;\r\n        const gd = document.getElementById(id);\r\n\r\n        if (animate && this._hasPlotted && figure.data.length === gd.data.length) {\r\n            return Plotly.animate(id, figure, animation_options);\r\n        }\r\n        return Plotly.react(id, figure.data, figure.layout, config).then(\r\n            () => {\r\n                if (!this._hasPlotted) {\r\n                    this.bindEvents();\r\n                    Plotly.Plots.resize(document.getElementById(id));\r\n                    this._hasPlotted = true;\r\n                }\r\n            }\r\n        );\r\n    }\r\n\r\n    bindEvents() {\r\n        const {id, fireEvent, 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                if (setProps) {setProps({clickData});}\r\n                if (fireEvent) {fireEvent({event: 'click'});}\r\n            }\r\n        });\r\n        gd.on('plotly_hover', (eventData) => {\r\n            const hoverData = filterEventData(gd, eventData, 'hover');\r\n            if (!isNil(hoverData)) {\r\n                if (setProps) {setProps({hoverData});}\r\n                if (fireEvent) {fireEvent({event: 'hover'})}\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                if (setProps) {setProps({selectedData});}\r\n                if (fireEvent) {fireEvent({event: 'selected'});}\r\n            }\r\n        });\r\n        gd.on('plotly_deselect', () => {\r\n            if (setProps) {setProps({selectedData: null});}\r\n            if (fireEvent) {fireEvent({event: 'selected'});}\r\n        });\r\n        gd.on('plotly_relayout', (eventData) => {\r\n            const relayoutData = filterEventData(gd, eventData, 'relayout');\r\n            if (!isNil(relayoutData)) {\r\n                if (setProps) {setProps({relayoutData});}\r\n                if (fireEvent) {fireEvent({event: 'relayout'});}\r\n            }\r\n        });\r\n        gd.on('plotly_unhover', () => {\r\n            if (clear_on_unhover) {\r\n                if (setProps) {setProps({hoverData: null});}\r\n                if (fireEvent) {fireEvent({event: 'unhover'});}\r\n            }\r\n        });\r\n    }\r\n\r\n    componentDidMount() {\r\n        this.plot(this.props).then(() => {\r\n            window.addEventListener('resize', () => {\r\n                Plotly.Plots.resize(document.getElementById(this.props.id));\r\n            });\r\n        });\r\n    }\r\n\r\n    componentWillUnmount() {\r\n        if (this.eventEmitter) {\r\n            this.eventEmitter.removeAllListeners();\r\n        }\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\r\n        if (figureChanged) {\r\n            this.plot(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} = this.props;\r\n\r\n        return (\r\n            <div\r\n                key={id}\r\n                id={id}\r\n                style={style}\r\n                className={className}\r\n            />\r\n        );\r\n\r\n    }\r\n}\r\n\r\nPlotlyGraph.propTypes = {\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\r\n     */\r\n    clickData: PropTypes.object,\r\n\r\n    /**\r\n     * Data from latest hover event\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\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\r\n     */\r\n    relayoutData: PropTypes.object,\r\n\r\n    /**\r\n     * Plotly `figure` object. See schema:\r\n     * https://plot.ly/javascript/reference\r\n     */\r\n    figure: PropTypes.object,\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    /**\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.shape({\r\n        /**\r\n         * no interactivity, for export or image generation\r\n         */\r\n        staticPlot: PropTypes.bool,\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.shape({\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         * 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([\r\n            true, false, 'hover'\r\n        ]),\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         * add the plotly logo on the end of the mode bar\r\n         */\r\n        displaylogo: 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    /**\r\n     *\r\n     */\r\n    dashEvents: PropTypes.oneOf([\r\n        'click',\r\n        'hover',\r\n        'selected',\r\n        'relayout',\r\n        'unhover'\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     * Function that fires events\r\n     */\r\n    fireEvent: PropTypes.func\r\n}\r\n\r\nPlotlyGraph.defaultProps = {\r\n    /* eslint-disable no-magic-numbers */\r\n    id: 'graph-' + Math.random().toString(36).substring(2,7),\r\n    /* eslint-enable no-magic-numbers */\r\n    clickData: null,\r\n    hoverData: null,\r\n    selectedData: null,\r\n    relayoutData: null,\r\n    figure: {data: [], layout: {}},\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        staticPlot: false,\r\n        editable: false,\r\n        edits: {\r\n            annotationPosition: false,\r\n            annotationTail: false,\r\n            annotationText: false,\r\n            axisTitleText: false,\r\n            colorbarPosition: false,\r\n            colorbarTitleText: false,\r\n            legendPosition: false,\r\n            legendText: false,\r\n            shapePosition: false,\r\n            titleText: false\r\n        },\r\n        autosizable: false,\r\n        queueLength: 0,\r\n        fillFrame: false,\r\n        frameMargins: 0,\r\n        scrollZoom: false,\r\n        doubleClick: 'reset+autosize',\r\n        showTips: true,\r\n        showAxisDragHandles: true,\r\n        showAxisRangeEntryBoxes: true,\r\n        showLink: false,\r\n        sendData: true,\r\n        linkText: 'Edit chart',\r\n        showSources: false,\r\n        displayModeBar: 'hover',\r\n        modeBarButtonsToRemove: [],\r\n        modeBarButtonsToAdd: [],\r\n        modeBarButtons: false,\r\n        displaylogo: true,\r\n        plotGlPixelRatio: 2,\r\n        topojsonURL: 'https://cdn.plot.ly/',\r\n        mapboxAccessToken: null\r\n    }\r\n};\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/components/Graph.react.js\n"); +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar React = _interopRequireDefault(_react).default;\n\nvar Component = _react.Component;\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar PropTypes = _interopRequireDefault(_propTypes).default;\n\nvar _ramda = __webpack_require__(/*! ramda */ \"./node_modules/ramda/index.js\");\n\nvar contains = _ramda.contains;\nvar filter = _ramda.filter;\nvar clone = _ramda.clone;\nvar has = _ramda.has;\nvar isNil = _ramda.isNil;\nvar type = _ramda.type;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/* global Plotly:true */\n\nvar filterEventData = function filterEventData(gd, eventData, event) {\n var filteredEventData = void 0;\n if (contains(event, ['click', 'hover', 'selected'])) {\n var points = [];\n\n if (isNil(eventData)) {\n return null;\n }\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 var data = gd.data;\n\n for (var i = 0; i < eventData.points.length; i++) {\n var fullPoint = eventData.points[i];\n var pointData = filter(function (o) {\n return !contains(type(o), ['Object', 'Array']);\n }, fullPoint);\n if (has('curveNumber', fullPoint) && has('pointNumber', fullPoint) && has('customdata', data[pointData.curveNumber])) {\n pointData.customdata = data[pointData.curveNumber].customdata[fullPoint.pointNumber];\n }\n\n // specific to histogram. see https://github.com/plotly/plotly.js/pull/2113/\n if (has('pointNumbers', fullPoint)) {\n pointData.pointNumbers = fullPoint.pointNumbers;\n }\n\n points[i] = pointData;\n }\n filteredEventData = { points: points };\n } else if (event === 'relayout') {\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 if (has('range', eventData)) {\n filteredEventData.range = eventData.range;\n }\n if (has('lassoPoints', eventData)) {\n filteredEventData.lassoPoints = eventData.lassoPoints;\n }\n return filteredEventData;\n};\n\nvar PlotlyGraph = function (_Component) {\n _inherits(PlotlyGraph, _Component);\n\n function PlotlyGraph(props) {\n _classCallCheck(this, PlotlyGraph);\n\n var _this = _possibleConstructorReturn(this, (PlotlyGraph.__proto__ || Object.getPrototypeOf(PlotlyGraph)).call(this, props));\n\n _this.bindEvents = _this.bindEvents.bind(_this);\n _this._hasPlotted = false;\n return _this;\n }\n\n _createClass(PlotlyGraph, [{\n key: 'plot',\n value: function plot(props) {\n var _this2 = this;\n\n var id = props.id,\n figure = props.figure,\n animate = props.animate,\n animation_options = props.animation_options,\n config = props.config;\n\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 return Plotly.react(id, figure.data, clone(figure.layout), config).then(function () {\n if (!_this2._hasPlotted) {\n _this2.bindEvents();\n Plotly.Plots.resize(document.getElementById(id));\n _this2._hasPlotted = true;\n }\n });\n }\n }, {\n key: 'bindEvents',\n value: function bindEvents() {\n var _props = this.props,\n id = _props.id,\n fireEvent = _props.fireEvent,\n setProps = _props.setProps,\n clear_on_unhover = _props.clear_on_unhover;\n\n\n var gd = document.getElementById(id);\n\n gd.on('plotly_click', function (eventData) {\n var clickData = filterEventData(gd, eventData, 'click');\n if (!isNil(clickData)) {\n if (setProps) {\n setProps({ clickData: clickData });\n }\n if (fireEvent) {\n fireEvent({ event: 'click' });\n }\n }\n });\n gd.on('plotly_hover', function (eventData) {\n var hoverData = filterEventData(gd, eventData, 'hover');\n if (!isNil(hoverData)) {\n if (setProps) {\n setProps({ hoverData: hoverData });\n }\n if (fireEvent) {\n fireEvent({ event: 'hover' });\n }\n }\n });\n gd.on('plotly_selected', function (eventData) {\n var selectedData = filterEventData(gd, eventData, 'selected');\n if (!isNil(selectedData)) {\n if (setProps) {\n setProps({ selectedData: selectedData });\n }\n if (fireEvent) {\n fireEvent({ event: 'selected' });\n }\n }\n });\n gd.on('plotly_deselect', function () {\n if (setProps) {\n setProps({ selectedData: null });\n }\n if (fireEvent) {\n fireEvent({ event: 'selected' });\n }\n });\n gd.on('plotly_relayout', function (eventData) {\n var relayoutData = filterEventData(gd, eventData, 'relayout');\n if (!isNil(relayoutData)) {\n if (setProps) {\n setProps({ relayoutData: relayoutData });\n }\n if (fireEvent) {\n fireEvent({ event: 'relayout' });\n }\n }\n });\n gd.on('plotly_unhover', function () {\n if (clear_on_unhover) {\n if (setProps) {\n setProps({ hoverData: null });\n }\n if (fireEvent) {\n fireEvent({ event: 'unhover' });\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', function () {\n Plotly.Plots.resize(document.getElementById(_this3.props.id));\n });\n });\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n if (this.eventEmitter) {\n this.eventEmitter.removeAllListeners();\n }\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 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 }, {\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 _props2 = this.props,\n className = _props2.className,\n id = _props2.id,\n style = _props2.style;\n\n\n return React.createElement('div', {\n key: id,\n id: id,\n style: style,\n className: className\n });\n }\n }]);\n\n return PlotlyGraph;\n}(Component);\n\nexports.default = PlotlyGraph;\n\n\nPlotlyGraph.propTypes = {\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: PropTypes.string,\n /**\r\n * Data from latest click event\r\n */\n clickData: PropTypes.object,\n\n /**\r\n * Data from latest hover event\r\n */\n hoverData: PropTypes.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: PropTypes.bool,\n\n /**\r\n * Data from latest select event\r\n */\n selectedData: PropTypes.object,\n\n /**\r\n * Data from latest relayout event which occurs\r\n * when the user zooms or pans on the plot\r\n */\n relayoutData: PropTypes.object,\n\n /**\r\n * Plotly `figure` object. See schema:\r\n * https://plot.ly/javascript/reference\r\n */\n figure: PropTypes.object,\n\n /**\r\n * Generic style overrides on the plot div\r\n */\n style: PropTypes.object,\n\n /**\r\n * className of the parent div\r\n */\n className: PropTypes.string,\n\n /**\r\n * Beta: If true, animate between updates using\r\n * plotly.js's `animate` function\r\n */\n animate: PropTypes.bool,\n\n /**\r\n * Beta: Object containing animation settings.\r\n * Only applies if `animate` is `true`\r\n */\n animation_options: PropTypes.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: PropTypes.shape({\n /**\r\n * no interactivity, for export or image generation\r\n */\n staticPlot: PropTypes.bool,\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: PropTypes.bool,\n\n /**\r\n * a set of editable properties\r\n */\n edits: PropTypes.shape({\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: PropTypes.bool,\n\n /**\r\n * just for annotations with arrows, change the length and direction of the arrow\r\n */\n annotationTail: PropTypes.bool,\n\n annotationText: PropTypes.bool,\n\n axisTitleText: PropTypes.bool,\n\n colorbarPosition: PropTypes.bool,\n\n colorbarTitleText: PropTypes.bool,\n\n legendPosition: PropTypes.bool,\n\n /**\r\n * edit the trace name fields from the legend\r\n */\n legendText: PropTypes.bool,\n\n shapePosition: PropTypes.bool,\n\n /**\r\n * the global `layout.title`\r\n */\n titleText: PropTypes.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: PropTypes.bool,\n\n /**\r\n * set the length of the undo/redo queue\r\n */\n queueLength: PropTypes.number,\n\n /**\r\n * if we DO autosize, do we fill the container or the screen?\r\n */\n fillFrame: PropTypes.bool,\n\n /**\r\n * if we DO autosize, set the frame margins in percents of plot size\r\n */\n frameMargins: PropTypes.number,\n\n /**\r\n * mousewheel or two-finger scroll zooms the plot\r\n */\n scrollZoom: PropTypes.bool,\n\n /**\r\n * double click interaction (false, 'reset', 'autosize' or 'reset+autosize')\r\n */\n doubleClick: PropTypes.oneOf([false, 'reset', 'autosize', 'reset+autosize']),\n\n /**\r\n * new users see some hints about interactivity\r\n */\n showTips: PropTypes.bool,\n\n /**\r\n * enable axis pan/zoom drag handles\r\n */\n showAxisDragHandles: PropTypes.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: PropTypes.bool,\n\n /**\r\n * link to open this plot in plotly\r\n */\n showLink: PropTypes.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: PropTypes.bool,\n\n /**\r\n * text appearing in the sendData link\r\n */\n linkText: PropTypes.string,\n\n /**\r\n * display the mode bar (true, false, or 'hover')\r\n */\n displayModeBar: PropTypes.oneOf([true, false, 'hover']),\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: PropTypes.array,\n\n /**\r\n * add mode bar button using config objects\r\n */\n modeBarButtonsToAdd: PropTypes.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: PropTypes.any,\n\n /**\r\n * add the plotly logo on the end of the mode bar\r\n */\n displaylogo: PropTypes.bool,\n\n /**\r\n * increase the pixel ratio for Gl plot images\r\n */\n plotGlPixelRatio: PropTypes.number,\n\n /**\r\n * URL to topojson files used in geo charts\r\n */\n topojsonURL: PropTypes.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: PropTypes.any\n }),\n\n /**\r\n *\r\n */\n dashEvents: PropTypes.oneOf(['click', 'hover', 'selected', 'relayout', 'unhover']),\n\n /**\r\n * Function that updates the state tree.\r\n */\n setProps: PropTypes.func,\n\n /**\r\n * Function that fires events\r\n */\n fireEvent: PropTypes.func\n};\n\nPlotlyGraph.defaultProps = {\n /* eslint-disable no-magic-numbers */\n id: 'graph-' + Math.random().toString(36).substring(2, 7),\n /* eslint-enable no-magic-numbers */\n clickData: null,\n hoverData: null,\n selectedData: null,\n relayoutData: null,\n figure: { data: [], layout: {} },\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 staticPlot: false,\n editable: false,\n edits: {\n annotationPosition: false,\n annotationTail: false,\n annotationText: false,\n axisTitleText: false,\n colorbarPosition: false,\n colorbarTitleText: false,\n legendPosition: false,\n legendText: false,\n shapePosition: false,\n titleText: false\n },\n autosizable: false,\n queueLength: 0,\n fillFrame: false,\n frameMargins: 0,\n scrollZoom: false,\n doubleClick: 'reset+autosize',\n showTips: true,\n showAxisDragHandles: true,\n showAxisRangeEntryBoxes: true,\n showLink: false,\n sendData: true,\n linkText: 'Edit chart',\n showSources: false,\n displayModeBar: 'hover',\n modeBarButtonsToRemove: [],\n modeBarButtonsToAdd: [],\n modeBarButtons: false,\n displaylogo: true,\n plotGlPixelRatio: 2,\n topojsonURL: 'https://cdn.plot.ly/',\n mapboxAccessToken: null\n }\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_core_components/./src/components/Graph.react.js?2a5f"],"names":["React","Component","PropTypes","contains","filter","clone","has","isNil","type","filterEventData","gd","eventData","event","filteredEventData","points","data","i","length","fullPoint","pointData","o","curveNumber","customdata","pointNumber","pointNumbers","range","lassoPoints","PlotlyGraph","props","bindEvents","bind","_hasPlotted","id","figure","animate","animation_options","config","document","getElementById","Plotly","react","layout","then","Plots","resize","fireEvent","setProps","clear_on_unhover","on","clickData","hoverData","selectedData","relayoutData","plot","window","addEventListener","eventEmitter","removeAllListeners","nextProps","JSON","stringify","style","idChanged","figureChanged","prevProps","className","propTypes","string","object","bool","shape","staticPlot","editable","edits","annotationPosition","annotationTail","annotationText","axisTitleText","colorbarPosition","colorbarTitleText","legendPosition","legendText","shapePosition","titleText","autosizable","queueLength","number","fillFrame","frameMargins","scrollZoom","doubleClick","oneOf","showTips","showAxisDragHandles","showAxisRangeEntryBoxes","showLink","sendData","linkText","displayModeBar","modeBarButtonsToRemove","array","modeBarButtonsToAdd","modeBarButtons","any","displaylogo","plotGlPixelRatio","topojsonURL","mapboxAccessToken","dashEvents","func","defaultProps","Math","random","toString","substring","frame","redraw","transition","duration","ease","showSources"],"mappings":"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","file":"./src/components/Graph.react.js.js","sourcesContent":["import React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport {contains, filter, clone, has, isNil, type} 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 (has('curveNumber', fullPoint) &&\r\n                has('pointNumber', fullPoint) &&\r\n                has('customdata', data[pointData.curveNumber])\r\n            ) {\r\n                pointData.customdata = data[\r\n                    pointData.curveNumber\r\n                ].customdata[fullPoint.pointNumber];\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        }\r\n        filteredEventData = {points}\r\n    } else if (event === 'relayout') {\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\nexport default class PlotlyGraph 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    }\r\n\r\n    plot(props) {\r\n        const {id, figure, animate, animation_options, config} = props;\r\n        const gd = document.getElementById(id);\r\n\r\n        if (animate && this._hasPlotted && figure.data.length === gd.data.length) {\r\n            return Plotly.animate(id, figure, animation_options);\r\n        }\r\n        return Plotly.react(id, figure.data, clone(figure.layout), config).then(() => {\r\n            if (!this._hasPlotted) {\r\n                this.bindEvents();\r\n                Plotly.Plots.resize(document.getElementById(id));\r\n                this._hasPlotted = true;\r\n            }\r\n        });\r\n    }\r\n\r\n    bindEvents() {\r\n        const {id, fireEvent, 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                if (setProps) {setProps({clickData});}\r\n                if (fireEvent) {fireEvent({event: 'click'});}\r\n            }\r\n        });\r\n        gd.on('plotly_hover', (eventData) => {\r\n            const hoverData = filterEventData(gd, eventData, 'hover');\r\n            if (!isNil(hoverData)) {\r\n                if (setProps) {setProps({hoverData});}\r\n                if (fireEvent) {fireEvent({event: 'hover'})}\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                if (setProps) {setProps({selectedData});}\r\n                if (fireEvent) {fireEvent({event: 'selected'});}\r\n            }\r\n        });\r\n        gd.on('plotly_deselect', () => {\r\n            if (setProps) {setProps({selectedData: null});}\r\n            if (fireEvent) {fireEvent({event: 'selected'});}\r\n        });\r\n        gd.on('plotly_relayout', (eventData) => {\r\n            const relayoutData = filterEventData(gd, eventData, 'relayout');\r\n            if (!isNil(relayoutData)) {\r\n                if (setProps) {setProps({relayoutData});}\r\n                if (fireEvent) {fireEvent({event: 'relayout'});}\r\n            }\r\n        });\r\n        gd.on('plotly_unhover', () => {\r\n            if (clear_on_unhover) {\r\n                if (setProps) {setProps({hoverData: null});}\r\n                if (fireEvent) {fireEvent({event: 'unhover'});}\r\n            }\r\n        });\r\n    }\r\n\r\n    componentDidMount() {\r\n        this.plot(this.props).then(() => {\r\n            window.addEventListener('resize', () => {\r\n                Plotly.Plots.resize(document.getElementById(this.props.id));\r\n            });\r\n        });\r\n    }\r\n\r\n    componentWillUnmount() {\r\n        if (this.eventEmitter) {\r\n            this.eventEmitter.removeAllListeners();\r\n        }\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\r\n        if (figureChanged) {\r\n            this.plot(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} = this.props;\r\n\r\n        return (\r\n            <div\r\n                key={id}\r\n                id={id}\r\n                style={style}\r\n                className={className}\r\n            />\r\n        );\r\n\r\n    }\r\n}\r\n\r\nPlotlyGraph.propTypes = {\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\r\n     */\r\n    clickData: PropTypes.object,\r\n\r\n    /**\r\n     * Data from latest hover event\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\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\r\n     */\r\n    relayoutData: PropTypes.object,\r\n\r\n    /**\r\n     * Plotly `figure` object. See schema:\r\n     * https://plot.ly/javascript/reference\r\n     */\r\n    figure: PropTypes.object,\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    /**\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.shape({\r\n        /**\r\n         * no interactivity, for export or image generation\r\n         */\r\n        staticPlot: PropTypes.bool,\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.shape({\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         * 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([\r\n            true, false, 'hover'\r\n        ]),\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         * add the plotly logo on the end of the mode bar\r\n         */\r\n        displaylogo: 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    /**\r\n     *\r\n     */\r\n    dashEvents: PropTypes.oneOf([\r\n        'click',\r\n        'hover',\r\n        'selected',\r\n        'relayout',\r\n        'unhover'\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     * Function that fires events\r\n     */\r\n    fireEvent: PropTypes.func\r\n}\r\n\r\nPlotlyGraph.defaultProps = {\r\n    /* eslint-disable no-magic-numbers */\r\n    id: 'graph-' + Math.random().toString(36).substring(2,7),\r\n    /* eslint-enable no-magic-numbers */\r\n    clickData: null,\r\n    hoverData: null,\r\n    selectedData: null,\r\n    relayoutData: null,\r\n    figure: {data: [], layout: {}},\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        staticPlot: false,\r\n        editable: false,\r\n        edits: {\r\n            annotationPosition: false,\r\n            annotationTail: false,\r\n            annotationText: false,\r\n            axisTitleText: false,\r\n            colorbarPosition: false,\r\n            colorbarTitleText: false,\r\n            legendPosition: false,\r\n            legendText: false,\r\n            shapePosition: false,\r\n            titleText: false\r\n        },\r\n        autosizable: false,\r\n        queueLength: 0,\r\n        fillFrame: false,\r\n        frameMargins: 0,\r\n        scrollZoom: false,\r\n        doubleClick: 'reset+autosize',\r\n        showTips: true,\r\n        showAxisDragHandles: true,\r\n        showAxisRangeEntryBoxes: true,\r\n        showLink: false,\r\n        sendData: true,\r\n        linkText: 'Edit chart',\r\n        showSources: false,\r\n        displayModeBar: 'hover',\r\n        modeBarButtonsToRemove: [],\r\n        modeBarButtonsToAdd: [],\r\n        modeBarButtons: false,\r\n        displaylogo: true,\r\n        plotGlPixelRatio: 2,\r\n        topojsonURL: 'https://cdn.plot.ly/',\r\n        mapboxAccessToken: null\r\n    }\r\n};\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/components/Graph.react.js\n"); /***/ }), @@ -13010,6 +13010,18 @@ eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n}); /***/ }), +/***/ "./src/components/Store.react.js": +/*!***************************************!*\ + !*** ./src/components/Store.react.js ***! + \***************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _slicedToArray = function () { function sliceIterator(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\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar _ramda = __webpack_require__(/*! ramda */ \"./node_modules/ramda/index.js\");\n\nvar R = _interopRequireDefault(_ramda).default;\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar React = _interopRequireDefault(_react).default;\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar PropTypes = _interopRequireDefault(_propTypes).default;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction dataCheck(data, old) {\n // Assuming data and old are of the same type.\n if (R.isNil(old) || R.isNil(data)) {\n return true;\n }\n var type = R.type(data);\n if (type === 'Array') {\n if (data.length !== old.length) {\n return true;\n }\n for (var i = 0; i < data.length; i++) {\n if (data[i] !== old[i]) {\n return true;\n }\n }\n } else if (R.contains(type, ['String', 'Number'])) {\n return old !== data;\n } else if (type === 'Object') {\n return R.any(function (_ref) {\n var _ref2 = _slicedToArray(_ref, 2),\n k = _ref2[0],\n v = _ref2[1];\n\n return old[k] !== v;\n })(Object.entries(data));\n }\n return false;\n}\n\nvar MemStore = function () {\n function MemStore() {\n _classCallCheck(this, MemStore);\n\n this._data = {};\n this._modified = -1;\n }\n\n _createClass(MemStore, [{\n key: 'getItem',\n value: function getItem(key) {\n return this._data[key];\n }\n }, {\n key: 'setItem',\n value: function setItem(key, value) {\n this._data[key] = value;\n this.setModified(key);\n }\n }, {\n key: 'removeItem',\n value: function removeItem(key) {\n delete this._data[key];\n this.setModified(key);\n }\n\n // noinspection JSUnusedLocalSymbols\n\n }, {\n key: 'setModified',\n value: function setModified(_) {\n this._modified = Date.now();\n }\n\n // noinspection JSUnusedLocalSymbols\n\n }, {\n key: 'getModified',\n value: function getModified(_) {\n return this._modified;\n }\n }]);\n\n return MemStore;\n}();\n\nvar WebStore = function () {\n function WebStore(storage) {\n _classCallCheck(this, WebStore);\n\n this._storage = storage;\n }\n\n _createClass(WebStore, [{\n key: 'getItem',\n value: function getItem(key) {\n return JSON.parse(this._storage.getItem(key));\n }\n }, {\n key: 'setItem',\n value: function setItem(key, value) {\n this._storage.setItem(key, JSON.stringify(value));\n this.setModified(key);\n }\n }, {\n key: 'removeItem',\n value: function removeItem(key) {\n this._storage.removeItem(key);\n this._storage.removeItem(key + '-timestamp');\n }\n }, {\n key: 'setModified',\n value: function setModified(key) {\n this._storage.setItem(key + '-timestamp', Date.now());\n }\n }, {\n key: 'getModified',\n value: function getModified(key) {\n return Number.parseInt(this._storage.getItem(key + '-timestamp'), 10) || -1;\n }\n }]);\n\n return WebStore;\n}();\n\nvar _localStore = new WebStore(window.localStorage);\nvar _sessionStore = new WebStore(window.sessionStorage);\n\n/**\r\n * Easily keep data on the client side with this component.\r\n * The data is not inserted in the DOM.\r\n * Data can be in memory, localStorage or sessionStorage.\r\n * The data will be kept with the id as key.\r\n */\n\nvar Store = function (_React$Component) {\n _inherits(Store, _React$Component);\n\n function Store(props) {\n _classCallCheck(this, Store);\n\n var _this = _possibleConstructorReturn(this, (Store.__proto__ || Object.getPrototypeOf(Store)).call(this, props));\n\n if (props.storage_type === 'local') {\n _this._backstore = _localStore;\n } else if (props.storage_type === 'session') {\n _this._backstore = _sessionStore;\n } else if (props.storage_type === 'memory') {\n _this._backstore = new MemStore();\n }\n\n _this.onStorageChange = _this.onStorageChange.bind(_this);\n return _this;\n }\n\n _createClass(Store, [{\n key: 'onStorageChange',\n value: function onStorageChange(e) {\n var _props = this.props,\n id = _props.id,\n setProps = _props.setProps;\n\n if (e.key === id && setProps && e.newValue !== e.oldValue) {\n setProps({\n data: JSON.parse(e.newValue),\n modified_timestamp: this._backstore.getModified(id)\n });\n }\n }\n }, {\n key: 'componentWillMount',\n value: function componentWillMount() {\n var _props2 = this.props,\n setProps = _props2.setProps,\n id = _props2.id,\n data = _props2.data,\n storage_type = _props2.storage_type;\n\n if (storage_type !== 'memory') {\n window.addEventListener('storage', this.onStorageChange);\n }\n\n var old = this._backstore.getItem(id);\n if (R.isNil(old) && data) {\n // Initial data mount\n this._backstore.setItem(id, data);\n if (setProps) {\n setProps({\n modified_timestamp: this._backstore.getModified(id)\n });\n }\n return;\n }\n\n if (setProps && dataCheck(old, data)) {\n setProps({\n data: old,\n modified_timestamp: this._backstore.getModified(id)\n });\n }\n }\n }, {\n key: 'componentWillUnmount',\n value: function componentWillUnmount() {\n if (this.props.storage_type !== 'memory') {\n window.removeEventListener('storage', this.onStorageChange);\n }\n }\n }, {\n key: 'componentDidUpdate',\n value: function componentDidUpdate() {\n var _props3 = this.props,\n data = _props3.data,\n id = _props3.id,\n clear_data = _props3.clear_data,\n setProps = _props3.setProps;\n\n if (clear_data) {\n this._backstore.removeItem(id);\n if (setProps) {\n setProps({\n clear_data: false,\n data: null,\n modified_timestamp: this._backstore.getModified(id)\n });\n }\n } else if (data) {\n var old = this._backstore.getItem(id);\n // Only set the data if it's not the same data.\n if (dataCheck(data, old)) {\n this._backstore.setItem(id, data);\n if (setProps) {\n setProps({\n modified_timestamp: this._backstore.getModified(id)\n });\n }\n }\n }\n }\n }, {\n key: 'render',\n value: function render() {\n return null;\n }\n }]);\n\n return Store;\n}(React.Component);\n\nexports.default = Store;\n\n\nStore.defaultProps = {\n storage_type: 'memory',\n clear_data: false,\n modified_timestamp: -1\n};\n\nStore.propTypes = {\n /**\r\n * The key of the storage.\r\n */\n id: PropTypes.string.isRequired,\n\n /**\r\n * The type of the web storage.\r\n *\r\n * memory: only kept in memory, reset on page refresh.\r\n * local: window.localStorage, data is kept after the browser quit.\r\n * session: window.sessionStorage, data is cleared once the browser quit.\r\n */\n storage_type: PropTypes.oneOf(['local', 'session', 'memory']),\n\n /**\r\n * The stored data for the id.\r\n */\n data: PropTypes.oneOfType([PropTypes.object, PropTypes.array, PropTypes.number, PropTypes.string]),\n\n /**\r\n * Set to true to remove the data contained in `data_key`.\r\n */\n clear_data: PropTypes.bool,\n\n /**\r\n * The last time the storage was modified.\r\n */\n modified_timestamp: PropTypes.number,\n\n /**\r\n * Dash-assigned callback that gets fired when the value changes.\r\n */\n setProps: PropTypes.func\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_core_components/./src/components/Store.react.js?389e"],"names":["R","React","PropTypes","dataCheck","data","old","isNil","type","length","i","contains","any","k","v","Object","entries","MemStore","_data","_modified","key","value","setModified","_","Date","now","WebStore","storage","_storage","JSON","parse","getItem","setItem","stringify","removeItem","Number","parseInt","_localStore","window","localStorage","_sessionStore","sessionStorage","Store","props","storage_type","_backstore","onStorageChange","bind","e","id","setProps","newValue","oldValue","modified_timestamp","getModified","addEventListener","removeEventListener","clear_data","Component","defaultProps","propTypes","string","isRequired","oneOf","oneOfType","object","array","number","bool","func"],"mappings":"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","file":"./src/components/Store.react.js.js","sourcesContent":["import R from 'ramda';\r\nimport React from 'react';\r\nimport PropTypes from 'prop-types';\r\n\r\nfunction dataCheck(data, old) {\r\n    // Assuming data and old are of the same type.\r\n    if (R.isNil(old) || R.isNil(data)) {\r\n        return true;\r\n    }\r\n    const type = R.type(data);\r\n    if (type === 'Array')\r\n    {\r\n        if (data.length !== old.length) {\r\n            return true;\r\n        }\r\n        for (let i=0;i < data.length;i++) {\r\n            if (data[i] !== old[i]) {\r\n                return true;\r\n            }\r\n        }\r\n    }\r\n    else if (R.contains(type, ['String', 'Number']))\r\n    {\r\n        return old !== data\r\n    }\r\n    else if (type === 'Object')\r\n    {\r\n        return R.any(([k,v]) => old[k] !== v)(Object.entries(data));\r\n    }\r\n    return false;\r\n}\r\n\r\nclass MemStore  {\r\n    constructor() {\r\n        this._data = {};\r\n        this._modified = -1;\r\n    }\r\n\r\n    getItem(key) {\r\n        return this._data[key];\r\n    }\r\n\r\n    setItem(key, value) {\r\n        this._data[key] = value;\r\n        this.setModified(key);\r\n    }\r\n\r\n    removeItem(key) {\r\n        delete this._data[key];\r\n        this.setModified(key);\r\n    }\r\n\r\n    // noinspection JSUnusedLocalSymbols\r\n    setModified(_) {\r\n        this._modified = Date.now();\r\n    }\r\n\r\n    // noinspection JSUnusedLocalSymbols\r\n    getModified(_) {\r\n        return this._modified;\r\n    }\r\n}\r\n\r\nclass WebStore {\r\n    constructor(storage) {\r\n        this._storage = storage;\r\n    }\r\n\r\n    getItem(key) {\r\n        return JSON.parse(this._storage.getItem(key));\r\n    }\r\n\r\n    setItem(key, value) {\r\n        this._storage.setItem(key, JSON.stringify(value));\r\n        this.setModified(key);\r\n    }\r\n\r\n    removeItem(key) {\r\n        this._storage.removeItem(key);\r\n        this._storage.removeItem(`${key}-timestamp`);\r\n    }\r\n\r\n    setModified(key) {\r\n        this._storage.setItem(`${key}-timestamp`, Date.now())\r\n    }\r\n\r\n    getModified(key) {\r\n        return Number.parseInt(\r\n            this._storage.getItem(`${key}-timestamp`), 10) || -1;\r\n    }\r\n}\r\n\r\nconst _localStore = new WebStore(window.localStorage);\r\nconst _sessionStore = new WebStore(window.sessionStorage);\r\n\r\n/**\r\n * Easily keep data on the client side with this component.\r\n * The data is not inserted in the DOM.\r\n * Data can be in memory, localStorage or sessionStorage.\r\n * The data will be kept with the id as key.\r\n */\r\nexport default class Store extends React.Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        if (props.storage_type === 'local') {\r\n            this._backstore = _localStore;\r\n        } else if (props.storage_type === 'session') {\r\n            this._backstore = _sessionStore;\r\n        } else if (props.storage_type === 'memory') {\r\n            this._backstore = new MemStore();\r\n        }\r\n\r\n        this.onStorageChange = this.onStorageChange.bind(this);\r\n    }\r\n\r\n    onStorageChange(e) {\r\n        const { id, setProps } = this.props;\r\n        if (e.key === id && setProps && e.newValue !== e.oldValue) {\r\n            setProps({\r\n                data: JSON.parse(e.newValue),\r\n                modified_timestamp: this._backstore.getModified(id)\r\n            });\r\n        }\r\n    }\r\n\r\n    componentWillMount() {\r\n        const { setProps, id, data, storage_type } = this.props;\r\n        if (storage_type !== 'memory') {\r\n            window.addEventListener('storage', this.onStorageChange);\r\n        }\r\n\r\n        const old = this._backstore.getItem(id);\r\n        if (R.isNil(old) && data) {\r\n            // Initial data mount\r\n            this._backstore.setItem(id, data);\r\n            if (setProps) {\r\n                setProps({\r\n                    modified_timestamp: this._backstore.getModified(id)\r\n                })\r\n            }\r\n            return;\r\n        }\r\n\r\n        if (setProps && dataCheck(old, data)) {\r\n            setProps({\r\n                data: old,\r\n                modified_timestamp: this._backstore.getModified(id)\r\n            });\r\n        }\r\n    }\r\n\r\n    componentWillUnmount() {\r\n        if (this.props.storage_type !== 'memory') {\r\n            window.removeEventListener('storage', this.onStorageChange);\r\n        }\r\n    }\r\n\r\n    componentDidUpdate() {\r\n        const { data, id, clear_data, setProps } = this.props;\r\n        if (clear_data) {\r\n            this._backstore.removeItem(id);\r\n            if (setProps) {\r\n                setProps({\r\n                    clear_data: false,\r\n                    data: null,\r\n                    modified_timestamp: this._backstore.getModified(id)\r\n                })\r\n            }\r\n        } else if (data) {\r\n            const old = this._backstore.getItem(id);\r\n            // Only set the data if it's not the same data.\r\n            if (dataCheck(data, old))\r\n            {\r\n                this._backstore.setItem(id, data);\r\n                if (setProps) {\r\n                    setProps({\r\n                        modified_timestamp: this._backstore.getModified(id)\r\n                    })\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    render() {\r\n        return null;\r\n    }\r\n}\r\n\r\nStore.defaultProps = {\r\n    storage_type: 'memory',\r\n    clear_data: false,\r\n    modified_timestamp: -1\r\n};\r\n\r\nStore.propTypes = {\r\n    /**\r\n     * The key of the storage.\r\n     */\r\n    id: PropTypes.string.isRequired,\r\n\r\n    /**\r\n     * The type of the web storage.\r\n     *\r\n     * memory: only kept in memory, reset on page refresh.\r\n     * local: window.localStorage, data is kept after the browser quit.\r\n     * session: window.sessionStorage, data is cleared once the browser quit.\r\n     */\r\n    storage_type: PropTypes.oneOf(['local', 'session', 'memory']),\r\n\r\n    /**\r\n     * The stored data for the id.\r\n     */\r\n    data: PropTypes.oneOfType([\r\n        PropTypes.object,\r\n        PropTypes.array,\r\n        PropTypes.number,\r\n        PropTypes.string,\r\n    ]),\r\n\r\n    /**\r\n     * Set to true to remove the data contained in `data_key`.\r\n     */\r\n    clear_data: PropTypes.bool,\r\n\r\n    /**\r\n     * The last time the storage was modified.\r\n     */\r\n    modified_timestamp: PropTypes.number,\r\n\r\n    /**\r\n     * Dash-assigned callback that gets fired when the value changes.\r\n     */\r\n    setProps: PropTypes.func\r\n};\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/components/Store.react.js\n"); + +/***/ }), + /***/ "./src/components/SyntaxHighlighter.react.js": /*!***************************************************!*\ !*** ./src/components/SyntaxHighlighter.react.js ***! @@ -13042,7 +13054,7 @@ eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n}); /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _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; }; /* eslint-disable react/prop-types */\n\n\nvar _style = __webpack_require__(/*! styled-jsx/style */ \"./node_modules/styled-jsx/style.js\");\n\nvar _JSXStyle = _interopRequireDefault(_style).default;\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar React = _interopRequireDefault(_react).default;\n\nvar Component = _react.Component;\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar PropTypes = _interopRequireDefault(_propTypes).default;\n\nvar _ramda = __webpack_require__(/*! ramda */ \"./node_modules/ramda/index.js\");\n\nvar R = _interopRequireDefault(_ramda).default;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar EnhancedTab = function EnhancedTab(_ref) {\n var id = _ref.id,\n label = _ref.label,\n selected = _ref.selected,\n className = _ref.className,\n style = _ref.style,\n selectedClassName = _ref.selectedClassName,\n selected_style = _ref.selected_style,\n selectHandler = _ref.selectHandler,\n value = _ref.value,\n disabled = _ref.disabled,\n disabled_style = _ref.disabled_style,\n disabled_className = _ref.disabled_className,\n mobile_breakpoint = _ref.mobile_breakpoint,\n amountOfTabs = _ref.amountOfTabs,\n colors = _ref.colors;\n\n var tabStyle = style;\n if (disabled) {\n tabStyle = _extends({ tabStyle: tabStyle }, disabled_style);\n }\n if (selected) {\n tabStyle = _extends({ tabStyle: tabStyle }, selected_style);\n }\n var tabClassName = 'tab ' + (className || '');\n if (disabled) {\n tabClassName += 'tab--disabled ' + (disabled_className || '');\n }\n if (selected) {\n tabClassName += ' tab--selected ' + (selectedClassName || '');\n }\n var labelDisplay = void 0;\n if (R.is(Array, label)) {\n // label is an array, so it has children that we want to render\n labelDisplay = label[0].props.children;\n } else {\n // else it is a string, so we just want to render that\n labelDisplay = label;\n }\n return React.createElement(\n 'div',\n {\n id: id,\n style: tabStyle,\n onClick: function onClick() {\n if (!disabled) {\n selectHandler(value);\n }\n },\n className: _JSXStyle.dynamic([['2188997408', [colors.background, colors.border, colors.border, colors.border, colors.primary, mobile_breakpoint, colors.border, amountOfTabs, colors.primary]]]) + ' ' + (tabClassName || '')\n },\n React.createElement(\n 'span',\n {\n className: _JSXStyle.dynamic([['2188997408', [colors.background, colors.border, colors.border, colors.border, colors.primary, mobile_breakpoint, colors.border, amountOfTabs, colors.primary]]])\n },\n labelDisplay\n ),\n React.createElement(_JSXStyle, {\n styleId: '2188997408',\n css: '.tab.__jsx-style-dynamic-selector{display:inline-block;background-color:' + colors.background + ';border:1px solid ' + colors.border + ';border-bottom:none;padding:20px 25px;-webkit-transition:background-color,color 200ms;transition:background-color,color 200ms;width:100%;text-align:center;box-sizing:border-box;}.tab.__jsx-style-dynamic-selector:last-of-type{border-right:1px solid ' + colors.border + ';border-bottom:1px solid ' + colors.border + ';}.tab.__jsx-style-dynamic-selector:hover{cursor:pointer;}.tab--selected.__jsx-style-dynamic-selector{border-top:2px solid ' + colors.primary + ';color:black;background-color:white;}.tab--selected.__jsx-style-dynamic-selector:hover{background-color:white;}.tab--disabled.__jsx-style-dynamic-selector{color:#d6d6d6;}@media screen and (min-width:' + mobile_breakpoint + 'px){.tab.__jsx-style-dynamic-selector{border:1px solid ' + colors.border + ';border-right:none;width:calc(100% / ' + amountOfTabs + ');}.tab--selected.__jsx-style-dynamic-selector,.tab.__jsx-style-dynamic-selector:last-of-type.tab--selected{border-bottom:none;border-top:2px solid ' + colors.primary + ';}}\\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src\\components\\Tabs.react.js"],"names":[],"mappings":"AAwDwB,AAG0C,AAW+B,AAIrC,AAGmC,AAK3B,AAGT,AAKoC,AAM3B,cAV3B,CAXA,IAsB0D,EArCR,EAuBlD,uBAQ0B,IAbV,EAPyC,UAQ9B,EAa6B,GA/BN,EAqC9C,gBAlBJ,oBARA,OAqBI,CA/BmB,mBACD,kBACuB,wFAC9B,WACO,kBACI,sBAC1B","file":"src\\components\\Tabs.react.js","sourceRoot":"C:/Users/t4rk/dev/plotly/dash-core-components","sourcesContent":["/* eslint-disable react/prop-types */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport R from 'ramda';\r\n\r\nconst EnhancedTab = ({\r\n    id,\r\n    label,\r\n    selected,\r\n    className,\r\n    style,\r\n    selectedClassName,\r\n    selected_style,\r\n    selectHandler,\r\n    value,\r\n    disabled,\r\n    disabled_style,\r\n    disabled_className,\r\n    mobile_breakpoint,\r\n    amountOfTabs,\r\n    colors,\r\n}) => {\r\n    let tabStyle = style;\r\n    if (disabled) {\r\n        tabStyle = {tabStyle, ...disabled_style};\r\n    }\r\n    if (selected) {\r\n        tabStyle = {tabStyle, ...selected_style};\r\n    }\r\n    let tabClassName = `tab ${className || ''}`;\r\n    if (disabled) {\r\n        tabClassName += `tab--disabled ${disabled_className || ''}`;\r\n    }\r\n    if (selected) {\r\n        tabClassName += ` tab--selected ${selectedClassName || ''}`;\r\n    }\r\n    let labelDisplay;\r\n    if (R.is(Array, label)) {\r\n        // label is an array, so it has children that we want to render\r\n        labelDisplay = label[0].props.children;\r\n    } else {\r\n        // else it is a string, so we just want to render that\r\n        labelDisplay = label;\r\n    }\r\n    return (\r\n        <div\r\n            className={tabClassName}\r\n            id={id}\r\n            style={tabStyle}\r\n            onClick={() => {\r\n                if (!disabled) {\r\n                    selectHandler(value);\r\n                }\r\n            }}\r\n        >\r\n            <span>{labelDisplay}</span>\r\n            <style jsx>{`\r\n                .tab {\r\n                    display: inline-block;\r\n                    background-color: ${colors.background};\r\n                    border: 1px solid ${colors.border};\r\n                    border-bottom: none;\r\n                    padding: 20px 25px;\r\n                    transition: background-color, color 200ms;\r\n                    width: 100%;\r\n                    text-align: center;\r\n                    box-sizing: border-box;\r\n                }\r\n                .tab:last-of-type {\r\n                    border-right: 1px solid ${colors.border};\r\n                    border-bottom: 1px solid ${colors.border};\r\n                }\r\n                .tab:hover {\r\n                    cursor: pointer;\r\n                }\r\n                .tab--selected {\r\n                    border-top: 2px solid ${colors.primary};\r\n                    color: black;\r\n                    background-color: white;\r\n                }\r\n                .tab--selected:hover {\r\n                    background-color: white;\r\n                }\r\n                .tab--disabled {\r\n                    color: #d6d6d6;\r\n                }\r\n\r\n                @media screen and (min-width: ${mobile_breakpoint}px) {\r\n                    .tab {\r\n                        border: 1px solid ${colors.border};\r\n                        border-right: none;\r\n                        width: calc(100% / ${amountOfTabs});\r\n                    }\r\n                    .tab--selected,\r\n                    .tab:last-of-type.tab--selected {\r\n                        border-bottom: none;\r\n                        border-top: 2px solid ${colors.primary};\r\n                    }\r\n                }\r\n            `}</style>\r\n        </div>\r\n    );\r\n};\r\n\r\n/**\r\n * A Dash component that lets you render pages with tabs - the Tabs component's children\r\n * can be dcc.Tab components, which can hold a label that will be displayed as a tab, and can in turn hold\r\n * children components that will be that tab's content.\r\n */\r\nexport default class Tabs extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.selectHandler = this.selectHandler.bind(this);\r\n        this.parseChildrenToArray = this.parseChildrenToArray.bind(this);\r\n\r\n        this.parseChildrenToArray();\r\n\r\n        if (!this.props.value) {\r\n            // if no value specified on Tabs component, set it to the first child's (which should be a Tab component) value\r\n            const value =\r\n                this.props.children[0].props.children.props.value || 'tab-1';\r\n            this.state = {\r\n                selected: value,\r\n            };\r\n            if (this.props.setProps) {\r\n                // updating the prop in Dash is necessary so that callbacks work\r\n                this.props.setProps({\r\n                    value: value,\r\n                });\r\n            }\r\n        } else {\r\n            this.state = {\r\n                selected: this.props.value,\r\n            };\r\n        }\r\n    }\r\n    parseChildrenToArray() {\r\n        if (this.props.children && !R.is(Array, this.props.children)) {\r\n            // if dcc.Tabs.children contains just one single element, it gets passed as an object\r\n            // instead of an array - so we put in in a array ourselves!\r\n            this.props.children = [this.props.children];\r\n        }\r\n    }\r\n    selectHandler(value) {\r\n        this.setState({\r\n            selected: value,\r\n        });\r\n        if (this.props.setProps) {\r\n            this.props.setProps({value: value});\r\n        }\r\n    }\r\n    componentWillReceiveProps(newProps) {\r\n        const value = newProps.value;\r\n        if (typeof value !== 'undefined') {\r\n            this.setState({\r\n                selected: value,\r\n            });\r\n        }\r\n    }\r\n    render() {\r\n        let EnhancedTabs;\r\n        let selectedTab;\r\n        let selectedTabContent;\r\n\r\n        if (this.props.children) {\r\n            this.parseChildrenToArray();\r\n\r\n            const amountOfTabs = this.props.children.length;\r\n\r\n            window.console.log('this.props.children', this.props.children);\r\n            EnhancedTabs = this.props.children.map((child, index) => {\r\n                // TODO: handle components that are not dcc.Tab components (throw error)\r\n                // enhance Tab components coming from Dash (as dcc.Tab) with methods needed for handling logic\r\n                let childProps;\r\n\r\n                window.console.log('child', child);\r\n\r\n                if (child.props.children) {\r\n                    // if props appears on .children, props are coming from Dash\r\n                    childProps = child.props.children.props;\r\n                } else {\r\n                    // else props are coming from React (Demo.react.js)\r\n                    window.console.log('child props', child.props);\r\n                    childProps = child.props;\r\n                }\r\n\r\n                if (!childProps.value) {\r\n                    childProps.value = `tab-${index + 1}`;\r\n                }\r\n\r\n                return (\r\n                    <EnhancedTab\r\n                        key={index}\r\n                        id={childProps.id}\r\n                        label={childProps.label}\r\n                        selected={this.state.selected === childProps.value}\r\n                        selectHandler={this.selectHandler}\r\n                        className={childProps.className}\r\n                        style={childProps.style}\r\n                        selectedClassName={childProps.selected_className}\r\n                        selected_style={childProps.selected_style}\r\n                        value={childProps.value}\r\n                        disabled={childProps.disabled}\r\n                        disabled_style={childProps.disabled_style}\r\n                        disabled_classname={childProps.disabled_className}\r\n                        mobile_breakpoint={this.props.mobile_breakpoint}\r\n                        amountOfTabs={amountOfTabs}\r\n                        colors={this.props.colors}\r\n                    />\r\n                );\r\n            });\r\n\r\n            selectedTab = this.props.children.filter(child => {\r\n                return child.props.children.props.value === this.state.selected;\r\n            });\r\n            if ('props' in selectedTab[0]) {\r\n                selectedTabContent = selectedTab[0].props.children;\r\n            }\r\n        }\r\n\r\n        const tabContainerClass = this.props.vertical\r\n            ? 'tab-container tab-container--vert'\r\n            : 'tab-container';\r\n\r\n        const tabContentClass = this.props.vertical\r\n            ? 'tab-content tab-content--vert'\r\n            : 'tab-content';\r\n\r\n        const tabParentClass = this.props.vertical\r\n            ? 'tab-parent tab-parent--vert'\r\n            : 'tab-parent';\r\n\r\n        return (\r\n            <div\r\n                className={`${tabParentClass} ${this.props.parent_className ||\r\n                    ''}`}\r\n                style={this.props.parent_style}\r\n            >\r\n                <div\r\n                    className={`${tabContainerClass} ${this.props.className ||\r\n                        ''}`}\r\n                    style={this.props.style}\r\n                >\r\n                    {EnhancedTabs}\r\n                </div>\r\n                <div\r\n                    className={`${tabContentClass} ${this.props\r\n                        .content_className || ''}`}\r\n                    style={this.props.content_style}\r\n                >\r\n                    {selectedTabContent || ''}\r\n                </div>\r\n                <style jsx>{`\r\n                    .tab-parent {\r\n                        display: flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-container {\r\n                        display: flex;\r\n                    }\r\n                    .tab-container--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-content--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    @media screen and (min-width: ${this.props\r\n                            .mobile_breakpoint}px) {\r\n                        :global(.tab-container--vert .tab) {\r\n                            width: auto;\r\n                            border-right: none !important;\r\n                            border-bottom: none;\r\n                        }\r\n                        :global(.tab-container--vert .tab:last-of-type) {\r\n                            border-bottom: 1px solid ${this.props.colors.border} !important;\r\n                        }\r\n                        :global(.tab-container--vert .tab--selected) {\r\n                            border: 1px solid ${this.props.colors.border};\r\n                            border-left: 2px solid ${this.props.colors.primary};\r\n                            border-right: none;\r\n                        }\r\n\r\n                        .tab-parent--vert {\r\n                            display: inline-flex;\r\n                            flex-direction: row;\r\n                        }\r\n                    }\r\n                `}</style>\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nTabs.defaultProps = {\r\n    mobile_breakpoint: 800,\r\n    colors: {\r\n        border: '#d6d6d6',\r\n        primary: '#1975FA',\r\n        background: '#f9f9f9',\r\n    },\r\n};\r\n\r\nTabs.propTypes = {\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    /**\r\n     * The value of the currently selected Tab\r\n     */\r\n    value: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tabs container holding the individual Tab components.\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends (inline) styles to the Tabs container holding the individual Tab components.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_style: PropTypes.object,\r\n\r\n    /**\r\n     * Renders the tabs vertically (on the side)\r\n     */\r\n    vertical: PropTypes.bool,\r\n\r\n    /**\r\n     * Breakpoint at which tabs are rendered full width (can be 0 if you don't want full width tabs on mobile)\r\n     */\r\n    mobile_breakpoint: PropTypes.number,\r\n\r\n    /**\r\n     * Array that holds Tab components\r\n     */\r\n    children: PropTypes.node,\r\n\r\n    /**\r\n     * Holds the colors used by the Tabs and Tab components. If you set these, you should specify colors for all properties, so:\r\n     * colors: {\r\n     *    border: '#d6d6d6',\r\n     *    primary: '#1975FA',\r\n     *    background: '#f9f9f9'\r\n     *  }\r\n     */\r\n    colors: PropTypes.shape({\r\n        border: PropTypes.string,\r\n        primary: PropTypes.string,\r\n        background: PropTypes.string,\r\n    }),\r\n};\r\n"]} */\\n/*@ sourceURL=src\\\\components\\\\Tabs.react.js */',\n dynamic: [colors.background, colors.border, colors.border, colors.border, colors.primary, mobile_breakpoint, colors.border, amountOfTabs, colors.primary]\n })\n );\n};\n\n/**\r\n * A Dash component that lets you render pages with tabs - the Tabs component's children\r\n * can be dcc.Tab components, which can hold a label that will be displayed as a tab, and can in turn hold\r\n * children components that will be that tab's content.\r\n */\n\nvar Tabs = function (_Component) {\n _inherits(Tabs, _Component);\n\n function Tabs(props) {\n _classCallCheck(this, Tabs);\n\n var _this = _possibleConstructorReturn(this, (Tabs.__proto__ || Object.getPrototypeOf(Tabs)).call(this, props));\n\n _this.selectHandler = _this.selectHandler.bind(_this);\n _this.parseChildrenToArray = _this.parseChildrenToArray.bind(_this);\n\n _this.parseChildrenToArray();\n\n if (!_this.props.value) {\n // if no value specified on Tabs component, set it to the first child's (which should be a Tab component) value\n var value = _this.props.children[0].props.children.props.value || 'tab-1';\n _this.state = {\n selected: value\n };\n if (_this.props.setProps) {\n // updating the prop in Dash is necessary so that callbacks work\n _this.props.setProps({\n value: value\n });\n }\n } else {\n _this.state = {\n selected: _this.props.value\n };\n }\n return _this;\n }\n\n _createClass(Tabs, [{\n key: 'parseChildrenToArray',\n value: function parseChildrenToArray() {\n if (this.props.children && !R.is(Array, this.props.children)) {\n // if dcc.Tabs.children contains just one single element, it gets passed as an object\n // instead of an array - so we put in in a array ourselves!\n this.props.children = [this.props.children];\n }\n }\n }, {\n key: 'selectHandler',\n value: function selectHandler(value) {\n this.setState({\n selected: value\n });\n if (this.props.setProps) {\n this.props.setProps({ value: value });\n }\n }\n }, {\n key: 'componentWillReceiveProps',\n value: function componentWillReceiveProps(newProps) {\n var value = newProps.value;\n if (typeof value !== 'undefined') {\n this.setState({\n selected: value\n });\n }\n }\n }, {\n key: 'render',\n value: function render() {\n var _this2 = this;\n\n var EnhancedTabs = void 0;\n var selectedTab = void 0;\n var selectedTabContent = void 0;\n\n if (this.props.children) {\n this.parseChildrenToArray();\n\n var amountOfTabs = this.props.children.length;\n\n window.console.log('this.props.children', this.props.children);\n EnhancedTabs = this.props.children.map(function (child, index) {\n // TODO: handle components that are not dcc.Tab components (throw error)\n // enhance Tab components coming from Dash (as dcc.Tab) with methods needed for handling logic\n var childProps = void 0;\n\n window.console.log('child', child);\n\n if (child.props.children) {\n // if props appears on .children, props are coming from Dash\n childProps = child.props.children.props;\n } else {\n // else props are coming from React (Demo.react.js)\n window.console.log('child props', child.props);\n childProps = child.props;\n }\n\n if (!childProps.value) {\n childProps.value = 'tab-' + (index + 1);\n }\n\n return React.createElement(EnhancedTab, {\n key: index,\n id: childProps.id,\n label: childProps.label,\n selected: _this2.state.selected === childProps.value,\n selectHandler: _this2.selectHandler,\n className: childProps.className,\n style: childProps.style,\n selectedClassName: childProps.selected_className,\n selected_style: childProps.selected_style,\n value: childProps.value,\n disabled: childProps.disabled,\n disabled_style: childProps.disabled_style,\n disabled_classname: childProps.disabled_className,\n mobile_breakpoint: _this2.props.mobile_breakpoint,\n amountOfTabs: amountOfTabs,\n colors: _this2.props.colors\n });\n });\n\n selectedTab = this.props.children.filter(function (child) {\n return child.props.children.props.value === _this2.state.selected;\n });\n if ('props' in selectedTab[0]) {\n selectedTabContent = selectedTab[0].props.children;\n }\n }\n\n var tabContainerClass = this.props.vertical ? 'tab-container tab-container--vert' : 'tab-container';\n\n var tabContentClass = this.props.vertical ? 'tab-content tab-content--vert' : 'tab-content';\n\n var tabParentClass = this.props.vertical ? 'tab-parent tab-parent--vert' : 'tab-parent';\n\n return React.createElement(\n 'div',\n {\n style: this.props.parent_style,\n className: _JSXStyle.dynamic([['4169397056', [this.props.mobile_breakpoint, this.props.colors.border, this.props.colors.border, this.props.colors.primary]]]) + ' ' + (tabParentClass + ' ' + (this.props.parent_className || ''))\n },\n React.createElement(\n 'div',\n {\n style: this.props.style,\n className: _JSXStyle.dynamic([['4169397056', [this.props.mobile_breakpoint, this.props.colors.border, this.props.colors.border, this.props.colors.primary]]]) + ' ' + (tabContainerClass + ' ' + (this.props.className || ''))\n },\n EnhancedTabs\n ),\n React.createElement(\n 'div',\n {\n style: this.props.content_style,\n className: _JSXStyle.dynamic([['4169397056', [this.props.mobile_breakpoint, this.props.colors.border, this.props.colors.border, this.props.colors.primary]]]) + ' ' + (tabContentClass + ' ' + (this.props.content_className || ''))\n },\n selectedTabContent || ''\n ),\n React.createElement(_JSXStyle, {\n styleId: '4169397056',\n css: '.tab-parent.__jsx-style-dynamic-selector{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}.tab-container.__jsx-style-dynamic-selector{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;}.tab-container--vert.__jsx-style-dynamic-selector{display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}.tab-content--vert.__jsx-style-dynamic-selector{display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}@media screen and (min-width:' + this.props.mobile_breakpoint + 'px){.tab-container--vert .tab{width:auto;border-right:none !important;border-bottom:none;}.tab-container--vert .tab:last-of-type{border-bottom:1px solid ' + this.props.colors.border + ' !important;}.tab-container--vert .tab--selected{border:1px solid ' + this.props.colors.border + ';border-left:2px solid ' + this.props.colors.primary + ';border-right:none;}.tab-parent--vert.__jsx-style-dynamic-selector{display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;}}\\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src\\components\\Tabs.react.js"],"names":[],"mappings":"AA6P4B,AAGsC,AAIA,AAGO,AAIA,AAKL,AAKqD,AAGlB,AAM1B,WAbS,6BACV,MAOgC,aANvD,KAGA,UArBsB,AAI1B,uBAqB0B,KAlBA,AAIA,AAmBC,aAJvB,qCAzBJ,mBA8BI,SAvBJ,AAIA","file":"src\\components\\Tabs.react.js","sourceRoot":"C:/Users/t4rk/dev/plotly/dash-core-components","sourcesContent":["/* eslint-disable react/prop-types */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport R from 'ramda';\r\n\r\nconst EnhancedTab = ({\r\n    id,\r\n    label,\r\n    selected,\r\n    className,\r\n    style,\r\n    selectedClassName,\r\n    selected_style,\r\n    selectHandler,\r\n    value,\r\n    disabled,\r\n    disabled_style,\r\n    disabled_className,\r\n    mobile_breakpoint,\r\n    amountOfTabs,\r\n    colors,\r\n}) => {\r\n    let tabStyle = style;\r\n    if (disabled) {\r\n        tabStyle = {tabStyle, ...disabled_style};\r\n    }\r\n    if (selected) {\r\n        tabStyle = {tabStyle, ...selected_style};\r\n    }\r\n    let tabClassName = `tab ${className || ''}`;\r\n    if (disabled) {\r\n        tabClassName += `tab--disabled ${disabled_className || ''}`;\r\n    }\r\n    if (selected) {\r\n        tabClassName += ` tab--selected ${selectedClassName || ''}`;\r\n    }\r\n    let labelDisplay;\r\n    if (R.is(Array, label)) {\r\n        // label is an array, so it has children that we want to render\r\n        labelDisplay = label[0].props.children;\r\n    } else {\r\n        // else it is a string, so we just want to render that\r\n        labelDisplay = label;\r\n    }\r\n    return (\r\n        <div\r\n            className={tabClassName}\r\n            id={id}\r\n            style={tabStyle}\r\n            onClick={() => {\r\n                if (!disabled) {\r\n                    selectHandler(value);\r\n                }\r\n            }}\r\n        >\r\n            <span>{labelDisplay}</span>\r\n            <style jsx>{`\r\n                .tab {\r\n                    display: inline-block;\r\n                    background-color: ${colors.background};\r\n                    border: 1px solid ${colors.border};\r\n                    border-bottom: none;\r\n                    padding: 20px 25px;\r\n                    transition: background-color, color 200ms;\r\n                    width: 100%;\r\n                    text-align: center;\r\n                    box-sizing: border-box;\r\n                }\r\n                .tab:last-of-type {\r\n                    border-right: 1px solid ${colors.border};\r\n                    border-bottom: 1px solid ${colors.border};\r\n                }\r\n                .tab:hover {\r\n                    cursor: pointer;\r\n                }\r\n                .tab--selected {\r\n                    border-top: 2px solid ${colors.primary};\r\n                    color: black;\r\n                    background-color: white;\r\n                }\r\n                .tab--selected:hover {\r\n                    background-color: white;\r\n                }\r\n                .tab--disabled {\r\n                    color: #d6d6d6;\r\n                }\r\n\r\n                @media screen and (min-width: ${mobile_breakpoint}px) {\r\n                    .tab {\r\n                        border: 1px solid ${colors.border};\r\n                        border-right: none;\r\n                        width: calc(100% / ${amountOfTabs});\r\n                    }\r\n                    .tab--selected,\r\n                    .tab:last-of-type.tab--selected {\r\n                        border-bottom: none;\r\n                        border-top: 2px solid ${colors.primary};\r\n                    }\r\n                }\r\n            `}</style>\r\n        </div>\r\n    );\r\n};\r\n\r\n/**\r\n * A Dash component that lets you render pages with tabs - the Tabs component's children\r\n * can be dcc.Tab components, which can hold a label that will be displayed as a tab, and can in turn hold\r\n * children components that will be that tab's content.\r\n */\r\nexport default class Tabs extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.selectHandler = this.selectHandler.bind(this);\r\n        this.parseChildrenToArray = this.parseChildrenToArray.bind(this);\r\n\r\n        this.parseChildrenToArray();\r\n\r\n        if (!this.props.value) {\r\n            // if no value specified on Tabs component, set it to the first child's (which should be a Tab component) value\r\n            const value =\r\n                this.props.children[0].props.children.props.value || 'tab-1';\r\n            this.state = {\r\n                selected: value,\r\n            };\r\n            if (this.props.setProps) {\r\n                // updating the prop in Dash is necessary so that callbacks work\r\n                this.props.setProps({\r\n                    value: value,\r\n                });\r\n            }\r\n        } else {\r\n            this.state = {\r\n                selected: this.props.value,\r\n            };\r\n        }\r\n    }\r\n    parseChildrenToArray() {\r\n        if (this.props.children && !R.is(Array, this.props.children)) {\r\n            // if dcc.Tabs.children contains just one single element, it gets passed as an object\r\n            // instead of an array - so we put in in a array ourselves!\r\n            this.props.children = [this.props.children];\r\n        }\r\n    }\r\n    selectHandler(value) {\r\n        this.setState({\r\n            selected: value,\r\n        });\r\n        if (this.props.setProps) {\r\n            this.props.setProps({value: value});\r\n        }\r\n    }\r\n    componentWillReceiveProps(newProps) {\r\n        const value = newProps.value;\r\n        if (typeof value !== 'undefined') {\r\n            this.setState({\r\n                selected: value,\r\n            });\r\n        }\r\n    }\r\n    render() {\r\n        let EnhancedTabs;\r\n        let selectedTab;\r\n        let selectedTabContent;\r\n\r\n        if (this.props.children) {\r\n            this.parseChildrenToArray();\r\n\r\n            const amountOfTabs = this.props.children.length;\r\n\r\n            window.console.log('this.props.children', this.props.children);\r\n            EnhancedTabs = this.props.children.map((child, index) => {\r\n                // TODO: handle components that are not dcc.Tab components (throw error)\r\n                // enhance Tab components coming from Dash (as dcc.Tab) with methods needed for handling logic\r\n                let childProps;\r\n\r\n                window.console.log('child', child);\r\n\r\n                if (child.props.children) {\r\n                    // if props appears on .children, props are coming from Dash\r\n                    childProps = child.props.children.props;\r\n                } else {\r\n                    // else props are coming from React (Demo.react.js)\r\n                    window.console.log('child props', child.props);\r\n                    childProps = child.props;\r\n                }\r\n\r\n                if (!childProps.value) {\r\n                    childProps.value = `tab-${index + 1}`;\r\n                }\r\n\r\n                return (\r\n                    <EnhancedTab\r\n                        key={index}\r\n                        id={childProps.id}\r\n                        label={childProps.label}\r\n                        selected={this.state.selected === childProps.value}\r\n                        selectHandler={this.selectHandler}\r\n                        className={childProps.className}\r\n                        style={childProps.style}\r\n                        selectedClassName={childProps.selected_className}\r\n                        selected_style={childProps.selected_style}\r\n                        value={childProps.value}\r\n                        disabled={childProps.disabled}\r\n                        disabled_style={childProps.disabled_style}\r\n                        disabled_classname={childProps.disabled_className}\r\n                        mobile_breakpoint={this.props.mobile_breakpoint}\r\n                        amountOfTabs={amountOfTabs}\r\n                        colors={this.props.colors}\r\n                    />\r\n                );\r\n            });\r\n\r\n            selectedTab = this.props.children.filter(child => {\r\n                return child.props.children.props.value === this.state.selected;\r\n            });\r\n            if ('props' in selectedTab[0]) {\r\n                selectedTabContent = selectedTab[0].props.children;\r\n            }\r\n        }\r\n\r\n        const tabContainerClass = this.props.vertical\r\n            ? 'tab-container tab-container--vert'\r\n            : 'tab-container';\r\n\r\n        const tabContentClass = this.props.vertical\r\n            ? 'tab-content tab-content--vert'\r\n            : 'tab-content';\r\n\r\n        const tabParentClass = this.props.vertical\r\n            ? 'tab-parent tab-parent--vert'\r\n            : 'tab-parent';\r\n\r\n        return (\r\n            <div\r\n                className={`${tabParentClass} ${this.props.parent_className ||\r\n                    ''}`}\r\n                style={this.props.parent_style}\r\n            >\r\n                <div\r\n                    className={`${tabContainerClass} ${this.props.className ||\r\n                        ''}`}\r\n                    style={this.props.style}\r\n                >\r\n                    {EnhancedTabs}\r\n                </div>\r\n                <div\r\n                    className={`${tabContentClass} ${this.props\r\n                        .content_className || ''}`}\r\n                    style={this.props.content_style}\r\n                >\r\n                    {selectedTabContent || ''}\r\n                </div>\r\n                <style jsx>{`\r\n                    .tab-parent {\r\n                        display: flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-container {\r\n                        display: flex;\r\n                    }\r\n                    .tab-container--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-content--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    @media screen and (min-width: ${this.props\r\n                            .mobile_breakpoint}px) {\r\n                        :global(.tab-container--vert .tab) {\r\n                            width: auto;\r\n                            border-right: none !important;\r\n                            border-bottom: none;\r\n                        }\r\n                        :global(.tab-container--vert .tab:last-of-type) {\r\n                            border-bottom: 1px solid ${this.props.colors.border} !important;\r\n                        }\r\n                        :global(.tab-container--vert .tab--selected) {\r\n                            border: 1px solid ${this.props.colors.border};\r\n                            border-left: 2px solid ${this.props.colors.primary};\r\n                            border-right: none;\r\n                        }\r\n\r\n                        .tab-parent--vert {\r\n                            display: inline-flex;\r\n                            flex-direction: row;\r\n                        }\r\n                    }\r\n                `}</style>\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nTabs.defaultProps = {\r\n    mobile_breakpoint: 800,\r\n    colors: {\r\n        border: '#d6d6d6',\r\n        primary: '#1975FA',\r\n        background: '#f9f9f9',\r\n    },\r\n};\r\n\r\nTabs.propTypes = {\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    /**\r\n     * The value of the currently selected Tab\r\n     */\r\n    value: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tabs container holding the individual Tab components.\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends (inline) styles to the Tabs container holding the individual Tab components.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_style: PropTypes.object,\r\n\r\n    /**\r\n     * Renders the tabs vertically (on the side)\r\n     */\r\n    vertical: PropTypes.bool,\r\n\r\n    /**\r\n     * Breakpoint at which tabs are rendered full width (can be 0 if you don't want full width tabs on mobile)\r\n     */\r\n    mobile_breakpoint: PropTypes.number,\r\n\r\n    /**\r\n     * Array that holds Tab components\r\n     */\r\n    children: PropTypes.node,\r\n\r\n    /**\r\n     * Holds the colors used by the Tabs and Tab components. If you set these, you should specify colors for all properties, so:\r\n     * colors: {\r\n     *    border: '#d6d6d6',\r\n     *    primary: '#1975FA',\r\n     *    background: '#f9f9f9'\r\n     *  }\r\n     */\r\n    colors: PropTypes.shape({\r\n        border: PropTypes.string,\r\n        primary: PropTypes.string,\r\n        background: PropTypes.string,\r\n    }),\r\n};\r\n"]} */\\n/*@ sourceURL=src\\\\components\\\\Tabs.react.js */',\n dynamic: [this.props.mobile_breakpoint, this.props.colors.border, this.props.colors.border, this.props.colors.primary]\n })\n );\n }\n }]);\n\n return Tabs;\n}(Component);\n\nexports.default = Tabs;\n\n\nTabs.defaultProps = {\n mobile_breakpoint: 800,\n colors: {\n border: '#d6d6d6',\n primary: '#1975FA',\n background: '#f9f9f9'\n }\n};\n\nTabs.propTypes = {\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: PropTypes.string,\n\n /**\r\n * The value of the currently selected Tab\r\n */\n value: PropTypes.string,\n\n /**\r\n * Appends a class to the Tabs container holding the individual Tab components.\r\n */\n className: PropTypes.string,\n\n /**\r\n * Appends a class to the Tab content container holding the children of the Tab that is selected.\r\n */\n content_className: PropTypes.string,\n\n /**\r\n * Appends a class to the top-level parent container holding both the Tabs container and the content container.\r\n */\n parent_className: PropTypes.string,\n\n /**\r\n * Appends (inline) styles to the Tabs container holding the individual Tab components.\r\n */\n style: PropTypes.object,\n\n /**\r\n * Appends (inline) styles to the top-level parent container holding both the Tabs container and the content container.\r\n */\n parent_style: PropTypes.object,\n\n /**\r\n * Appends (inline) styles to the tab content container holding the children of the Tab that is selected.\r\n */\n content_style: PropTypes.object,\n\n /**\r\n * Renders the tabs vertically (on the side)\r\n */\n vertical: PropTypes.bool,\n\n /**\r\n * Breakpoint at which tabs are rendered full width (can be 0 if you don't want full width tabs on mobile)\r\n */\n mobile_breakpoint: PropTypes.number,\n\n /**\r\n * Array that holds Tab components\r\n */\n children: PropTypes.node,\n\n /**\r\n * Holds the colors used by the Tabs and Tab components. If you set these, you should specify colors for all properties, so:\r\n * colors: {\r\n * border: '#d6d6d6',\r\n * primary: '#1975FA',\r\n * background: '#f9f9f9'\r\n * }\r\n */\n colors: PropTypes.shape({\n border: PropTypes.string,\n primary: PropTypes.string,\n background: PropTypes.string\n })\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_core_components/./src/components/Tabs.react.js?416c"],"names":["React","Component","PropTypes","R","EnhancedTab","id","label","selected","className","style","selectedClassName","selected_style","selectHandler","value","disabled","disabled_style","disabled_className","mobile_breakpoint","amountOfTabs","colors","tabStyle","tabClassName","labelDisplay","is","Array","props","children","background","border","primary","Tabs","bind","parseChildrenToArray","state","setProps","setState","newProps","EnhancedTabs","selectedTab","selectedTabContent","length","window","console","log","map","child","index","childProps","selected_className","filter","tabContainerClass","vertical","tabContentClass","tabParentClass","parent_style","parent_className","content_style","content_className","defaultProps","propTypes","string","object","bool","number","node","shape"],"mappings":"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","file":"./src/components/Tabs.react.js.js","sourcesContent":["/* eslint-disable react/prop-types */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport R from 'ramda';\r\n\r\nconst EnhancedTab = ({\r\n    id,\r\n    label,\r\n    selected,\r\n    className,\r\n    style,\r\n    selectedClassName,\r\n    selected_style,\r\n    selectHandler,\r\n    value,\r\n    disabled,\r\n    disabled_style,\r\n    disabled_className,\r\n    mobile_breakpoint,\r\n    amountOfTabs,\r\n    colors,\r\n}) => {\r\n    let tabStyle = style;\r\n    if (disabled) {\r\n        tabStyle = {tabStyle, ...disabled_style};\r\n    }\r\n    if (selected) {\r\n        tabStyle = {tabStyle, ...selected_style};\r\n    }\r\n    let tabClassName = `tab ${className || ''}`;\r\n    if (disabled) {\r\n        tabClassName += `tab--disabled ${disabled_className || ''}`;\r\n    }\r\n    if (selected) {\r\n        tabClassName += ` tab--selected ${selectedClassName || ''}`;\r\n    }\r\n    let labelDisplay;\r\n    if (R.is(Array, label)) {\r\n        // label is an array, so it has children that we want to render\r\n        labelDisplay = label[0].props.children;\r\n    } else {\r\n        // else it is a string, so we just want to render that\r\n        labelDisplay = label;\r\n    }\r\n    return (\r\n        <div\r\n            className={tabClassName}\r\n            id={id}\r\n            style={tabStyle}\r\n            onClick={() => {\r\n                if (!disabled) {\r\n                    selectHandler(value);\r\n                }\r\n            }}\r\n        >\r\n            <span>{labelDisplay}</span>\r\n            <style jsx>{`\r\n                .tab {\r\n                    display: inline-block;\r\n                    background-color: ${colors.background};\r\n                    border: 1px solid ${colors.border};\r\n                    border-bottom: none;\r\n                    padding: 20px 25px;\r\n                    transition: background-color, color 200ms;\r\n                    width: 100%;\r\n                    text-align: center;\r\n                    box-sizing: border-box;\r\n                }\r\n                .tab:last-of-type {\r\n                    border-right: 1px solid ${colors.border};\r\n                    border-bottom: 1px solid ${colors.border};\r\n                }\r\n                .tab:hover {\r\n                    cursor: pointer;\r\n                }\r\n                .tab--selected {\r\n                    border-top: 2px solid ${colors.primary};\r\n                    color: black;\r\n                    background-color: white;\r\n                }\r\n                .tab--selected:hover {\r\n                    background-color: white;\r\n                }\r\n                .tab--disabled {\r\n                    color: #d6d6d6;\r\n                }\r\n\r\n                @media screen and (min-width: ${mobile_breakpoint}px) {\r\n                    .tab {\r\n                        border: 1px solid ${colors.border};\r\n                        border-right: none;\r\n                        width: calc(100% / ${amountOfTabs});\r\n                    }\r\n                    .tab--selected,\r\n                    .tab:last-of-type.tab--selected {\r\n                        border-bottom: none;\r\n                        border-top: 2px solid ${colors.primary};\r\n                    }\r\n                }\r\n            `}</style>\r\n        </div>\r\n    );\r\n};\r\n\r\n/**\r\n * A Dash component that lets you render pages with tabs - the Tabs component's children\r\n * can be dcc.Tab components, which can hold a label that will be displayed as a tab, and can in turn hold\r\n * children components that will be that tab's content.\r\n */\r\nexport default class Tabs extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.selectHandler = this.selectHandler.bind(this);\r\n        this.parseChildrenToArray = this.parseChildrenToArray.bind(this);\r\n\r\n        this.parseChildrenToArray();\r\n\r\n        if (!this.props.value) {\r\n            // if no value specified on Tabs component, set it to the first child's (which should be a Tab component) value\r\n            const value =\r\n                this.props.children[0].props.children.props.value || 'tab-1';\r\n            this.state = {\r\n                selected: value,\r\n            };\r\n            if (this.props.setProps) {\r\n                // updating the prop in Dash is necessary so that callbacks work\r\n                this.props.setProps({\r\n                    value: value,\r\n                });\r\n            }\r\n        } else {\r\n            this.state = {\r\n                selected: this.props.value,\r\n            };\r\n        }\r\n    }\r\n    parseChildrenToArray() {\r\n        if (this.props.children && !R.is(Array, this.props.children)) {\r\n            // if dcc.Tabs.children contains just one single element, it gets passed as an object\r\n            // instead of an array - so we put in in a array ourselves!\r\n            this.props.children = [this.props.children];\r\n        }\r\n    }\r\n    selectHandler(value) {\r\n        this.setState({\r\n            selected: value,\r\n        });\r\n        if (this.props.setProps) {\r\n            this.props.setProps({value: value});\r\n        }\r\n    }\r\n    componentWillReceiveProps(newProps) {\r\n        const value = newProps.value;\r\n        if (typeof value !== 'undefined') {\r\n            this.setState({\r\n                selected: value,\r\n            });\r\n        }\r\n    }\r\n    render() {\r\n        let EnhancedTabs;\r\n        let selectedTab;\r\n        let selectedTabContent;\r\n\r\n        if (this.props.children) {\r\n            this.parseChildrenToArray();\r\n\r\n            const amountOfTabs = this.props.children.length;\r\n\r\n            window.console.log('this.props.children', this.props.children);\r\n            EnhancedTabs = this.props.children.map((child, index) => {\r\n                // TODO: handle components that are not dcc.Tab components (throw error)\r\n                // enhance Tab components coming from Dash (as dcc.Tab) with methods needed for handling logic\r\n                let childProps;\r\n\r\n                window.console.log('child', child);\r\n\r\n                if (child.props.children) {\r\n                    // if props appears on .children, props are coming from Dash\r\n                    childProps = child.props.children.props;\r\n                } else {\r\n                    // else props are coming from React (Demo.react.js)\r\n                    window.console.log('child props', child.props);\r\n                    childProps = child.props;\r\n                }\r\n\r\n                if (!childProps.value) {\r\n                    childProps.value = `tab-${index + 1}`;\r\n                }\r\n\r\n                return (\r\n                    <EnhancedTab\r\n                        key={index}\r\n                        id={childProps.id}\r\n                        label={childProps.label}\r\n                        selected={this.state.selected === childProps.value}\r\n                        selectHandler={this.selectHandler}\r\n                        className={childProps.className}\r\n                        style={childProps.style}\r\n                        selectedClassName={childProps.selected_className}\r\n                        selected_style={childProps.selected_style}\r\n                        value={childProps.value}\r\n                        disabled={childProps.disabled}\r\n                        disabled_style={childProps.disabled_style}\r\n                        disabled_classname={childProps.disabled_className}\r\n                        mobile_breakpoint={this.props.mobile_breakpoint}\r\n                        amountOfTabs={amountOfTabs}\r\n                        colors={this.props.colors}\r\n                    />\r\n                );\r\n            });\r\n\r\n            selectedTab = this.props.children.filter(child => {\r\n                return child.props.children.props.value === this.state.selected;\r\n            });\r\n            if ('props' in selectedTab[0]) {\r\n                selectedTabContent = selectedTab[0].props.children;\r\n            }\r\n        }\r\n\r\n        const tabContainerClass = this.props.vertical\r\n            ? 'tab-container tab-container--vert'\r\n            : 'tab-container';\r\n\r\n        const tabContentClass = this.props.vertical\r\n            ? 'tab-content tab-content--vert'\r\n            : 'tab-content';\r\n\r\n        const tabParentClass = this.props.vertical\r\n            ? 'tab-parent tab-parent--vert'\r\n            : 'tab-parent';\r\n\r\n        return (\r\n            <div\r\n                className={`${tabParentClass} ${this.props.parent_className ||\r\n                    ''}`}\r\n                style={this.props.parent_style}\r\n            >\r\n                <div\r\n                    className={`${tabContainerClass} ${this.props.className ||\r\n                        ''}`}\r\n                    style={this.props.style}\r\n                >\r\n                    {EnhancedTabs}\r\n                </div>\r\n                <div\r\n                    className={`${tabContentClass} ${this.props\r\n                        .content_className || ''}`}\r\n                    style={this.props.content_style}\r\n                >\r\n                    {selectedTabContent || ''}\r\n                </div>\r\n                <style jsx>{`\r\n                    .tab-parent {\r\n                        display: flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-container {\r\n                        display: flex;\r\n                    }\r\n                    .tab-container--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-content--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    @media screen and (min-width: ${this.props\r\n                            .mobile_breakpoint}px) {\r\n                        :global(.tab-container--vert .tab) {\r\n                            width: auto;\r\n                            border-right: none !important;\r\n                            border-bottom: none;\r\n                        }\r\n                        :global(.tab-container--vert .tab:last-of-type) {\r\n                            border-bottom: 1px solid ${this.props.colors.border} !important;\r\n                        }\r\n                        :global(.tab-container--vert .tab--selected) {\r\n                            border: 1px solid ${this.props.colors.border};\r\n                            border-left: 2px solid ${this.props.colors.primary};\r\n                            border-right: none;\r\n                        }\r\n\r\n                        .tab-parent--vert {\r\n                            display: inline-flex;\r\n                            flex-direction: row;\r\n                        }\r\n                    }\r\n                `}</style>\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nTabs.defaultProps = {\r\n    mobile_breakpoint: 800,\r\n    colors: {\r\n        border: '#d6d6d6',\r\n        primary: '#1975FA',\r\n        background: '#f9f9f9',\r\n    },\r\n};\r\n\r\nTabs.propTypes = {\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    /**\r\n     * The value of the currently selected Tab\r\n     */\r\n    value: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tabs container holding the individual Tab components.\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends (inline) styles to the Tabs container holding the individual Tab components.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_style: PropTypes.object,\r\n\r\n    /**\r\n     * Renders the tabs vertically (on the side)\r\n     */\r\n    vertical: PropTypes.bool,\r\n\r\n    /**\r\n     * Breakpoint at which tabs are rendered full width (can be 0 if you don't want full width tabs on mobile)\r\n     */\r\n    mobile_breakpoint: PropTypes.number,\r\n\r\n    /**\r\n     * Array that holds Tab components\r\n     */\r\n    children: PropTypes.node,\r\n\r\n    /**\r\n     * Holds the colors used by the Tabs and Tab components. If you set these, you should specify colors for all properties, so:\r\n     * colors: {\r\n     *    border: '#d6d6d6',\r\n     *    primary: '#1975FA',\r\n     *    background: '#f9f9f9'\r\n     *  }\r\n     */\r\n    colors: PropTypes.shape({\r\n        border: PropTypes.string,\r\n        primary: PropTypes.string,\r\n        background: PropTypes.string,\r\n    }),\r\n};\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/components/Tabs.react.js\n"); +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _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; }; /* eslint-disable react/prop-types */\n\n\nvar _style = __webpack_require__(/*! styled-jsx/style */ \"./node_modules/styled-jsx/style.js\");\n\nvar _JSXStyle = _interopRequireDefault(_style).default;\n\nvar _react = __webpack_require__(/*! react */ \"react\");\n\nvar React = _interopRequireDefault(_react).default;\n\nvar Component = _react.Component;\n\nvar _propTypes = __webpack_require__(/*! prop-types */ \"./node_modules/prop-types/index.js\");\n\nvar PropTypes = _interopRequireDefault(_propTypes).default;\n\nvar _ramda = __webpack_require__(/*! ramda */ \"./node_modules/ramda/index.js\");\n\nvar R = _interopRequireDefault(_ramda).default;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar EnhancedTab = function EnhancedTab(_ref) {\n var id = _ref.id,\n label = _ref.label,\n selected = _ref.selected,\n className = _ref.className,\n style = _ref.style,\n selectedClassName = _ref.selectedClassName,\n selected_style = _ref.selected_style,\n selectHandler = _ref.selectHandler,\n value = _ref.value,\n disabled = _ref.disabled,\n disabled_style = _ref.disabled_style,\n disabled_className = _ref.disabled_className,\n mobile_breakpoint = _ref.mobile_breakpoint,\n amountOfTabs = _ref.amountOfTabs,\n colors = _ref.colors;\n\n var tabStyle = style;\n if (disabled) {\n tabStyle = _extends({ tabStyle: tabStyle }, disabled_style);\n }\n if (selected) {\n tabStyle = _extends({ tabStyle: tabStyle }, selected_style);\n }\n var tabClassName = 'tab ' + (className || '');\n if (disabled) {\n tabClassName += 'tab--disabled ' + (disabled_className || '');\n }\n if (selected) {\n tabClassName += ' tab--selected ' + (selectedClassName || '');\n }\n var labelDisplay = void 0;\n if (R.is(Array, label)) {\n // label is an array, so it has children that we want to render\n labelDisplay = label[0].props.children;\n } else {\n // else it is a string, so we just want to render that\n labelDisplay = label;\n }\n return React.createElement(\n 'div',\n {\n id: id,\n style: tabStyle,\n onClick: function onClick() {\n if (!disabled) {\n selectHandler(value);\n }\n },\n className: _JSXStyle.dynamic([['2188997408', [colors.background, colors.border, colors.border, colors.border, colors.primary, mobile_breakpoint, colors.border, amountOfTabs, colors.primary]]]) + ' ' + (tabClassName || '')\n },\n React.createElement(\n 'span',\n {\n className: _JSXStyle.dynamic([['2188997408', [colors.background, colors.border, colors.border, colors.border, colors.primary, mobile_breakpoint, colors.border, amountOfTabs, colors.primary]]])\n },\n labelDisplay\n ),\n React.createElement(_JSXStyle, {\n styleId: '2188997408',\n css: '.tab.__jsx-style-dynamic-selector{display:inline-block;background-color:' + colors.background + ';border:1px solid ' + colors.border + ';border-bottom:none;padding:20px 25px;-webkit-transition:background-color,color 200ms;transition:background-color,color 200ms;width:100%;text-align:center;box-sizing:border-box;}.tab.__jsx-style-dynamic-selector:last-of-type{border-right:1px solid ' + colors.border + ';border-bottom:1px solid ' + colors.border + ';}.tab.__jsx-style-dynamic-selector:hover{cursor:pointer;}.tab--selected.__jsx-style-dynamic-selector{border-top:2px solid ' + colors.primary + ';color:black;background-color:white;}.tab--selected.__jsx-style-dynamic-selector:hover{background-color:white;}.tab--disabled.__jsx-style-dynamic-selector{color:#d6d6d6;}@media screen and (min-width:' + mobile_breakpoint + 'px){.tab.__jsx-style-dynamic-selector{border:1px solid ' + colors.border + ';border-right:none;width:calc(100% / ' + amountOfTabs + ');}.tab--selected.__jsx-style-dynamic-selector,.tab.__jsx-style-dynamic-selector:last-of-type.tab--selected{border-bottom:none;border-top:2px solid ' + colors.primary + ';}}\\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src\\components\\Tabs.react.js"],"names":[],"mappings":"AAwDwB,AAG0C,AAW+B,AAIrC,AAGmC,AAK3B,AAGT,AAKoC,AAM3B,cAV3B,CAXA,IAsB0D,EArCR,EAuBlD,uBAQ0B,IAbV,EAPyC,UAQ9B,EAa6B,GA/BN,EAqC9C,gBAlBJ,oBARA,OAqBI,CA/BmB,mBACD,kBACuB,wFAC9B,WACO,kBACI,sBAC1B","file":"src\\components\\Tabs.react.js","sourceRoot":"C:/Users/t4rk/dev/plotly/dash-core-components","sourcesContent":["/* eslint-disable react/prop-types */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport R from 'ramda';\r\n\r\nconst EnhancedTab = ({\r\n    id,\r\n    label,\r\n    selected,\r\n    className,\r\n    style,\r\n    selectedClassName,\r\n    selected_style,\r\n    selectHandler,\r\n    value,\r\n    disabled,\r\n    disabled_style,\r\n    disabled_className,\r\n    mobile_breakpoint,\r\n    amountOfTabs,\r\n    colors,\r\n}) => {\r\n    let tabStyle = style;\r\n    if (disabled) {\r\n        tabStyle = {tabStyle, ...disabled_style};\r\n    }\r\n    if (selected) {\r\n        tabStyle = {tabStyle, ...selected_style};\r\n    }\r\n    let tabClassName = `tab ${className || ''}`;\r\n    if (disabled) {\r\n        tabClassName += `tab--disabled ${disabled_className || ''}`;\r\n    }\r\n    if (selected) {\r\n        tabClassName += ` tab--selected ${selectedClassName || ''}`;\r\n    }\r\n    let labelDisplay;\r\n    if (R.is(Array, label)) {\r\n        // label is an array, so it has children that we want to render\r\n        labelDisplay = label[0].props.children;\r\n    } else {\r\n        // else it is a string, so we just want to render that\r\n        labelDisplay = label;\r\n    }\r\n    return (\r\n        <div\r\n            className={tabClassName}\r\n            id={id}\r\n            style={tabStyle}\r\n            onClick={() => {\r\n                if (!disabled) {\r\n                    selectHandler(value);\r\n                }\r\n            }}\r\n        >\r\n            <span>{labelDisplay}</span>\r\n            <style jsx>{`\r\n                .tab {\r\n                    display: inline-block;\r\n                    background-color: ${colors.background};\r\n                    border: 1px solid ${colors.border};\r\n                    border-bottom: none;\r\n                    padding: 20px 25px;\r\n                    transition: background-color, color 200ms;\r\n                    width: 100%;\r\n                    text-align: center;\r\n                    box-sizing: border-box;\r\n                }\r\n                .tab:last-of-type {\r\n                    border-right: 1px solid ${colors.border};\r\n                    border-bottom: 1px solid ${colors.border};\r\n                }\r\n                .tab:hover {\r\n                    cursor: pointer;\r\n                }\r\n                .tab--selected {\r\n                    border-top: 2px solid ${colors.primary};\r\n                    color: black;\r\n                    background-color: white;\r\n                }\r\n                .tab--selected:hover {\r\n                    background-color: white;\r\n                }\r\n                .tab--disabled {\r\n                    color: #d6d6d6;\r\n                }\r\n\r\n                @media screen and (min-width: ${mobile_breakpoint}px) {\r\n                    .tab {\r\n                        border: 1px solid ${colors.border};\r\n                        border-right: none;\r\n                        width: calc(100% / ${amountOfTabs});\r\n                    }\r\n                    .tab--selected,\r\n                    .tab:last-of-type.tab--selected {\r\n                        border-bottom: none;\r\n                        border-top: 2px solid ${colors.primary};\r\n                    }\r\n                }\r\n            `}</style>\r\n        </div>\r\n    );\r\n};\r\n\r\n/**\r\n * A Dash component that lets you render pages with tabs - the Tabs component's children\r\n * can be dcc.Tab components, which can hold a label that will be displayed as a tab, and can in turn hold\r\n * children components that will be that tab's content.\r\n */\r\nexport default class Tabs extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.selectHandler = this.selectHandler.bind(this);\r\n        this.parseChildrenToArray = this.parseChildrenToArray.bind(this);\r\n\r\n        this.parseChildrenToArray();\r\n\r\n        if (!this.props.value) {\r\n            // if no value specified on Tabs component, set it to the first child's (which should be a Tab component) value\r\n            const value =\r\n                this.props.children[0].props.children.props.value || 'tab-1';\r\n            this.state = {\r\n                selected: value,\r\n            };\r\n            if (this.props.setProps) {\r\n                // updating the prop in Dash is necessary so that callbacks work\r\n                this.props.setProps({\r\n                    value: value,\r\n                });\r\n            }\r\n        } else {\r\n            this.state = {\r\n                selected: this.props.value,\r\n            };\r\n        }\r\n    }\r\n    parseChildrenToArray() {\r\n        if (this.props.children && !R.is(Array, this.props.children)) {\r\n            // if dcc.Tabs.children contains just one single element, it gets passed as an object\r\n            // instead of an array - so we put in in a array ourselves!\r\n            this.props.children = [this.props.children];\r\n        }\r\n    }\r\n    selectHandler(value) {\r\n        this.setState({\r\n            selected: value,\r\n        });\r\n        if (this.props.setProps) {\r\n            this.props.setProps({value: value});\r\n        }\r\n    }\r\n    componentWillReceiveProps(newProps) {\r\n        const value = newProps.value;\r\n        if (typeof value !== 'undefined') {\r\n            this.setState({\r\n                selected: value,\r\n            });\r\n        }\r\n    }\r\n    render() {\r\n        let EnhancedTabs;\r\n        let selectedTab;\r\n        let selectedTabContent;\r\n\r\n        if (this.props.children) {\r\n            this.parseChildrenToArray();\r\n\r\n            const amountOfTabs = this.props.children.length;\r\n\r\n            EnhancedTabs = this.props.children.map((child, index) => {\r\n                // TODO: handle components that are not dcc.Tab components (throw error)\r\n                // enhance Tab components coming from Dash (as dcc.Tab) with methods needed for handling logic\r\n                let childProps;\r\n\r\n\r\n                if (child.props.children) {\r\n                    // if props appears on .children, props are coming from Dash\r\n                    childProps = child.props.children.props;\r\n                } else {\r\n                    // else props are coming from React (Demo.react.js)\r\n                    childProps = child.props;\r\n                }\r\n\r\n                if (!childProps.value) {\r\n                    childProps.value = `tab-${index + 1}`;\r\n                }\r\n\r\n                return (\r\n                    <EnhancedTab\r\n                        key={index}\r\n                        id={childProps.id}\r\n                        label={childProps.label}\r\n                        selected={this.state.selected === childProps.value}\r\n                        selectHandler={this.selectHandler}\r\n                        className={childProps.className}\r\n                        style={childProps.style}\r\n                        selectedClassName={childProps.selected_className}\r\n                        selected_style={childProps.selected_style}\r\n                        value={childProps.value}\r\n                        disabled={childProps.disabled}\r\n                        disabled_style={childProps.disabled_style}\r\n                        disabled_classname={childProps.disabled_className}\r\n                        mobile_breakpoint={this.props.mobile_breakpoint}\r\n                        amountOfTabs={amountOfTabs}\r\n                        colors={this.props.colors}\r\n                    />\r\n                );\r\n            });\r\n\r\n            selectedTab = this.props.children.filter(child => {\r\n                return child.props.children.props.value === this.state.selected;\r\n            });\r\n            if ('props' in selectedTab[0]) {\r\n                selectedTabContent = selectedTab[0].props.children;\r\n            }\r\n        }\r\n\r\n        const tabContainerClass = this.props.vertical\r\n            ? 'tab-container tab-container--vert'\r\n            : 'tab-container';\r\n\r\n        const tabContentClass = this.props.vertical\r\n            ? 'tab-content tab-content--vert'\r\n            : 'tab-content';\r\n\r\n        const tabParentClass = this.props.vertical\r\n            ? 'tab-parent tab-parent--vert'\r\n            : 'tab-parent';\r\n\r\n        return (\r\n            <div\r\n                className={`${tabParentClass} ${this.props.parent_className ||\r\n                    ''}`}\r\n                style={this.props.parent_style}\r\n            >\r\n                <div\r\n                    className={`${tabContainerClass} ${this.props.className ||\r\n                        ''}`}\r\n                    style={this.props.style}\r\n                >\r\n                    {EnhancedTabs}\r\n                </div>\r\n                <div\r\n                    className={`${tabContentClass} ${this.props\r\n                        .content_className || ''}`}\r\n                    style={this.props.content_style}\r\n                >\r\n                    {selectedTabContent || ''}\r\n                </div>\r\n                <style jsx>{`\r\n                    .tab-parent {\r\n                        display: flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-container {\r\n                        display: flex;\r\n                    }\r\n                    .tab-container--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-content--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    @media screen and (min-width: ${this.props\r\n                            .mobile_breakpoint}px) {\r\n                        :global(.tab-container--vert .tab) {\r\n                            width: auto;\r\n                            border-right: none !important;\r\n                            border-bottom: none;\r\n                        }\r\n                        :global(.tab-container--vert .tab:last-of-type) {\r\n                            border-bottom: 1px solid ${this.props.colors.border} !important;\r\n                        }\r\n                        :global(.tab-container--vert .tab--selected) {\r\n                            border: 1px solid ${this.props.colors.border};\r\n                            border-left: 2px solid ${this.props.colors.primary};\r\n                            border-right: none;\r\n                        }\r\n\r\n                        .tab-parent--vert {\r\n                            display: inline-flex;\r\n                            flex-direction: row;\r\n                        }\r\n                    }\r\n                `}</style>\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nTabs.defaultProps = {\r\n    mobile_breakpoint: 800,\r\n    colors: {\r\n        border: '#d6d6d6',\r\n        primary: '#1975FA',\r\n        background: '#f9f9f9',\r\n    },\r\n};\r\n\r\nTabs.propTypes = {\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    /**\r\n     * The value of the currently selected Tab\r\n     */\r\n    value: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tabs container holding the individual Tab components.\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends (inline) styles to the Tabs container holding the individual Tab components.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_style: PropTypes.object,\r\n\r\n    /**\r\n     * Renders the tabs vertically (on the side)\r\n     */\r\n    vertical: PropTypes.bool,\r\n\r\n    /**\r\n     * Breakpoint at which tabs are rendered full width (can be 0 if you don't want full width tabs on mobile)\r\n     */\r\n    mobile_breakpoint: PropTypes.number,\r\n\r\n    /**\r\n     * Array that holds Tab components\r\n     */\r\n    children: PropTypes.node,\r\n\r\n    /**\r\n     * Holds the colors used by the Tabs and Tab components. If you set these, you should specify colors for all properties, so:\r\n     * colors: {\r\n     *    border: '#d6d6d6',\r\n     *    primary: '#1975FA',\r\n     *    background: '#f9f9f9'\r\n     *  }\r\n     */\r\n    colors: PropTypes.shape({\r\n        border: PropTypes.string,\r\n        primary: PropTypes.string,\r\n        background: PropTypes.string,\r\n    }),\r\n};\r\n"]} */\\n/*@ sourceURL=src\\\\components\\\\Tabs.react.js */',\n dynamic: [colors.background, colors.border, colors.border, colors.border, colors.primary, mobile_breakpoint, colors.border, amountOfTabs, colors.primary]\n })\n );\n};\n\n/**\r\n * A Dash component that lets you render pages with tabs - the Tabs component's children\r\n * can be dcc.Tab components, which can hold a label that will be displayed as a tab, and can in turn hold\r\n * children components that will be that tab's content.\r\n */\n\nvar Tabs = function (_Component) {\n _inherits(Tabs, _Component);\n\n function Tabs(props) {\n _classCallCheck(this, Tabs);\n\n var _this = _possibleConstructorReturn(this, (Tabs.__proto__ || Object.getPrototypeOf(Tabs)).call(this, props));\n\n _this.selectHandler = _this.selectHandler.bind(_this);\n _this.parseChildrenToArray = _this.parseChildrenToArray.bind(_this);\n\n _this.parseChildrenToArray();\n\n if (!_this.props.value) {\n // if no value specified on Tabs component, set it to the first child's (which should be a Tab component) value\n var value = _this.props.children[0].props.children.props.value || 'tab-1';\n _this.state = {\n selected: value\n };\n if (_this.props.setProps) {\n // updating the prop in Dash is necessary so that callbacks work\n _this.props.setProps({\n value: value\n });\n }\n } else {\n _this.state = {\n selected: _this.props.value\n };\n }\n return _this;\n }\n\n _createClass(Tabs, [{\n key: 'parseChildrenToArray',\n value: function parseChildrenToArray() {\n if (this.props.children && !R.is(Array, this.props.children)) {\n // if dcc.Tabs.children contains just one single element, it gets passed as an object\n // instead of an array - so we put in in a array ourselves!\n this.props.children = [this.props.children];\n }\n }\n }, {\n key: 'selectHandler',\n value: function selectHandler(value) {\n this.setState({\n selected: value\n });\n if (this.props.setProps) {\n this.props.setProps({ value: value });\n }\n }\n }, {\n key: 'componentWillReceiveProps',\n value: function componentWillReceiveProps(newProps) {\n var value = newProps.value;\n if (typeof value !== 'undefined') {\n this.setState({\n selected: value\n });\n }\n }\n }, {\n key: 'render',\n value: function render() {\n var _this2 = this;\n\n var EnhancedTabs = void 0;\n var selectedTab = void 0;\n var selectedTabContent = void 0;\n\n if (this.props.children) {\n this.parseChildrenToArray();\n\n var amountOfTabs = this.props.children.length;\n\n EnhancedTabs = this.props.children.map(function (child, index) {\n // TODO: handle components that are not dcc.Tab components (throw error)\n // enhance Tab components coming from Dash (as dcc.Tab) with methods needed for handling logic\n var childProps = void 0;\n\n if (child.props.children) {\n // if props appears on .children, props are coming from Dash\n childProps = child.props.children.props;\n } else {\n // else props are coming from React (Demo.react.js)\n childProps = child.props;\n }\n\n if (!childProps.value) {\n childProps.value = 'tab-' + (index + 1);\n }\n\n return React.createElement(EnhancedTab, {\n key: index,\n id: childProps.id,\n label: childProps.label,\n selected: _this2.state.selected === childProps.value,\n selectHandler: _this2.selectHandler,\n className: childProps.className,\n style: childProps.style,\n selectedClassName: childProps.selected_className,\n selected_style: childProps.selected_style,\n value: childProps.value,\n disabled: childProps.disabled,\n disabled_style: childProps.disabled_style,\n disabled_classname: childProps.disabled_className,\n mobile_breakpoint: _this2.props.mobile_breakpoint,\n amountOfTabs: amountOfTabs,\n colors: _this2.props.colors\n });\n });\n\n selectedTab = this.props.children.filter(function (child) {\n return child.props.children.props.value === _this2.state.selected;\n });\n if ('props' in selectedTab[0]) {\n selectedTabContent = selectedTab[0].props.children;\n }\n }\n\n var tabContainerClass = this.props.vertical ? 'tab-container tab-container--vert' : 'tab-container';\n\n var tabContentClass = this.props.vertical ? 'tab-content tab-content--vert' : 'tab-content';\n\n var tabParentClass = this.props.vertical ? 'tab-parent tab-parent--vert' : 'tab-parent';\n\n return React.createElement(\n 'div',\n {\n style: this.props.parent_style,\n className: _JSXStyle.dynamic([['4169397056', [this.props.mobile_breakpoint, this.props.colors.border, this.props.colors.border, this.props.colors.primary]]]) + ' ' + (tabParentClass + ' ' + (this.props.parent_className || ''))\n },\n React.createElement(\n 'div',\n {\n style: this.props.style,\n className: _JSXStyle.dynamic([['4169397056', [this.props.mobile_breakpoint, this.props.colors.border, this.props.colors.border, this.props.colors.primary]]]) + ' ' + (tabContainerClass + ' ' + (this.props.className || ''))\n },\n EnhancedTabs\n ),\n React.createElement(\n 'div',\n {\n style: this.props.content_style,\n className: _JSXStyle.dynamic([['4169397056', [this.props.mobile_breakpoint, this.props.colors.border, this.props.colors.border, this.props.colors.primary]]]) + ' ' + (tabContentClass + ' ' + (this.props.content_className || ''))\n },\n selectedTabContent || ''\n ),\n React.createElement(_JSXStyle, {\n styleId: '4169397056',\n css: '.tab-parent.__jsx-style-dynamic-selector{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}.tab-container.__jsx-style-dynamic-selector{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;}.tab-container--vert.__jsx-style-dynamic-selector{display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}.tab-content--vert.__jsx-style-dynamic-selector{display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}@media screen and (min-width:' + this.props.mobile_breakpoint + 'px){.tab-container--vert .tab{width:auto;border-right:none !important;border-bottom:none;}.tab-container--vert .tab:last-of-type{border-bottom:1px solid ' + this.props.colors.border + ' !important;}.tab-container--vert .tab--selected{border:1px solid ' + this.props.colors.border + ';border-left:2px solid ' + this.props.colors.primary + ';border-right:none;}.tab-parent--vert.__jsx-style-dynamic-selector{display:-webkit-inline-box;display:-webkit-inline-flex;display:-ms-inline-flexbox;display:inline-flex;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;}}\\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src\\components\\Tabs.react.js"],"names":[],"mappings":"AA0P4B,AAGsC,AAIA,AAGO,AAIA,AAKL,AAKqD,AAGlB,AAM1B,WAbS,6BACV,MAOgC,aANvD,KAGA,UArBsB,AAI1B,uBAqB0B,KAlBA,AAIA,AAmBC,aAJvB,qCAzBJ,mBA8BI,SAvBJ,AAIA","file":"src\\components\\Tabs.react.js","sourceRoot":"C:/Users/t4rk/dev/plotly/dash-core-components","sourcesContent":["/* eslint-disable react/prop-types */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport R from 'ramda';\r\n\r\nconst EnhancedTab = ({\r\n    id,\r\n    label,\r\n    selected,\r\n    className,\r\n    style,\r\n    selectedClassName,\r\n    selected_style,\r\n    selectHandler,\r\n    value,\r\n    disabled,\r\n    disabled_style,\r\n    disabled_className,\r\n    mobile_breakpoint,\r\n    amountOfTabs,\r\n    colors,\r\n}) => {\r\n    let tabStyle = style;\r\n    if (disabled) {\r\n        tabStyle = {tabStyle, ...disabled_style};\r\n    }\r\n    if (selected) {\r\n        tabStyle = {tabStyle, ...selected_style};\r\n    }\r\n    let tabClassName = `tab ${className || ''}`;\r\n    if (disabled) {\r\n        tabClassName += `tab--disabled ${disabled_className || ''}`;\r\n    }\r\n    if (selected) {\r\n        tabClassName += ` tab--selected ${selectedClassName || ''}`;\r\n    }\r\n    let labelDisplay;\r\n    if (R.is(Array, label)) {\r\n        // label is an array, so it has children that we want to render\r\n        labelDisplay = label[0].props.children;\r\n    } else {\r\n        // else it is a string, so we just want to render that\r\n        labelDisplay = label;\r\n    }\r\n    return (\r\n        <div\r\n            className={tabClassName}\r\n            id={id}\r\n            style={tabStyle}\r\n            onClick={() => {\r\n                if (!disabled) {\r\n                    selectHandler(value);\r\n                }\r\n            }}\r\n        >\r\n            <span>{labelDisplay}</span>\r\n            <style jsx>{`\r\n                .tab {\r\n                    display: inline-block;\r\n                    background-color: ${colors.background};\r\n                    border: 1px solid ${colors.border};\r\n                    border-bottom: none;\r\n                    padding: 20px 25px;\r\n                    transition: background-color, color 200ms;\r\n                    width: 100%;\r\n                    text-align: center;\r\n                    box-sizing: border-box;\r\n                }\r\n                .tab:last-of-type {\r\n                    border-right: 1px solid ${colors.border};\r\n                    border-bottom: 1px solid ${colors.border};\r\n                }\r\n                .tab:hover {\r\n                    cursor: pointer;\r\n                }\r\n                .tab--selected {\r\n                    border-top: 2px solid ${colors.primary};\r\n                    color: black;\r\n                    background-color: white;\r\n                }\r\n                .tab--selected:hover {\r\n                    background-color: white;\r\n                }\r\n                .tab--disabled {\r\n                    color: #d6d6d6;\r\n                }\r\n\r\n                @media screen and (min-width: ${mobile_breakpoint}px) {\r\n                    .tab {\r\n                        border: 1px solid ${colors.border};\r\n                        border-right: none;\r\n                        width: calc(100% / ${amountOfTabs});\r\n                    }\r\n                    .tab--selected,\r\n                    .tab:last-of-type.tab--selected {\r\n                        border-bottom: none;\r\n                        border-top: 2px solid ${colors.primary};\r\n                    }\r\n                }\r\n            `}</style>\r\n        </div>\r\n    );\r\n};\r\n\r\n/**\r\n * A Dash component that lets you render pages with tabs - the Tabs component's children\r\n * can be dcc.Tab components, which can hold a label that will be displayed as a tab, and can in turn hold\r\n * children components that will be that tab's content.\r\n */\r\nexport default class Tabs extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.selectHandler = this.selectHandler.bind(this);\r\n        this.parseChildrenToArray = this.parseChildrenToArray.bind(this);\r\n\r\n        this.parseChildrenToArray();\r\n\r\n        if (!this.props.value) {\r\n            // if no value specified on Tabs component, set it to the first child's (which should be a Tab component) value\r\n            const value =\r\n                this.props.children[0].props.children.props.value || 'tab-1';\r\n            this.state = {\r\n                selected: value,\r\n            };\r\n            if (this.props.setProps) {\r\n                // updating the prop in Dash is necessary so that callbacks work\r\n                this.props.setProps({\r\n                    value: value,\r\n                });\r\n            }\r\n        } else {\r\n            this.state = {\r\n                selected: this.props.value,\r\n            };\r\n        }\r\n    }\r\n    parseChildrenToArray() {\r\n        if (this.props.children && !R.is(Array, this.props.children)) {\r\n            // if dcc.Tabs.children contains just one single element, it gets passed as an object\r\n            // instead of an array - so we put in in a array ourselves!\r\n            this.props.children = [this.props.children];\r\n        }\r\n    }\r\n    selectHandler(value) {\r\n        this.setState({\r\n            selected: value,\r\n        });\r\n        if (this.props.setProps) {\r\n            this.props.setProps({value: value});\r\n        }\r\n    }\r\n    componentWillReceiveProps(newProps) {\r\n        const value = newProps.value;\r\n        if (typeof value !== 'undefined') {\r\n            this.setState({\r\n                selected: value,\r\n            });\r\n        }\r\n    }\r\n    render() {\r\n        let EnhancedTabs;\r\n        let selectedTab;\r\n        let selectedTabContent;\r\n\r\n        if (this.props.children) {\r\n            this.parseChildrenToArray();\r\n\r\n            const amountOfTabs = this.props.children.length;\r\n\r\n            EnhancedTabs = this.props.children.map((child, index) => {\r\n                // TODO: handle components that are not dcc.Tab components (throw error)\r\n                // enhance Tab components coming from Dash (as dcc.Tab) with methods needed for handling logic\r\n                let childProps;\r\n\r\n\r\n                if (child.props.children) {\r\n                    // if props appears on .children, props are coming from Dash\r\n                    childProps = child.props.children.props;\r\n                } else {\r\n                    // else props are coming from React (Demo.react.js)\r\n                    childProps = child.props;\r\n                }\r\n\r\n                if (!childProps.value) {\r\n                    childProps.value = `tab-${index + 1}`;\r\n                }\r\n\r\n                return (\r\n                    <EnhancedTab\r\n                        key={index}\r\n                        id={childProps.id}\r\n                        label={childProps.label}\r\n                        selected={this.state.selected === childProps.value}\r\n                        selectHandler={this.selectHandler}\r\n                        className={childProps.className}\r\n                        style={childProps.style}\r\n                        selectedClassName={childProps.selected_className}\r\n                        selected_style={childProps.selected_style}\r\n                        value={childProps.value}\r\n                        disabled={childProps.disabled}\r\n                        disabled_style={childProps.disabled_style}\r\n                        disabled_classname={childProps.disabled_className}\r\n                        mobile_breakpoint={this.props.mobile_breakpoint}\r\n                        amountOfTabs={amountOfTabs}\r\n                        colors={this.props.colors}\r\n                    />\r\n                );\r\n            });\r\n\r\n            selectedTab = this.props.children.filter(child => {\r\n                return child.props.children.props.value === this.state.selected;\r\n            });\r\n            if ('props' in selectedTab[0]) {\r\n                selectedTabContent = selectedTab[0].props.children;\r\n            }\r\n        }\r\n\r\n        const tabContainerClass = this.props.vertical\r\n            ? 'tab-container tab-container--vert'\r\n            : 'tab-container';\r\n\r\n        const tabContentClass = this.props.vertical\r\n            ? 'tab-content tab-content--vert'\r\n            : 'tab-content';\r\n\r\n        const tabParentClass = this.props.vertical\r\n            ? 'tab-parent tab-parent--vert'\r\n            : 'tab-parent';\r\n\r\n        return (\r\n            <div\r\n                className={`${tabParentClass} ${this.props.parent_className ||\r\n                    ''}`}\r\n                style={this.props.parent_style}\r\n            >\r\n                <div\r\n                    className={`${tabContainerClass} ${this.props.className ||\r\n                        ''}`}\r\n                    style={this.props.style}\r\n                >\r\n                    {EnhancedTabs}\r\n                </div>\r\n                <div\r\n                    className={`${tabContentClass} ${this.props\r\n                        .content_className || ''}`}\r\n                    style={this.props.content_style}\r\n                >\r\n                    {selectedTabContent || ''}\r\n                </div>\r\n                <style jsx>{`\r\n                    .tab-parent {\r\n                        display: flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-container {\r\n                        display: flex;\r\n                    }\r\n                    .tab-container--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-content--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    @media screen and (min-width: ${this.props\r\n                            .mobile_breakpoint}px) {\r\n                        :global(.tab-container--vert .tab) {\r\n                            width: auto;\r\n                            border-right: none !important;\r\n                            border-bottom: none;\r\n                        }\r\n                        :global(.tab-container--vert .tab:last-of-type) {\r\n                            border-bottom: 1px solid ${this.props.colors.border} !important;\r\n                        }\r\n                        :global(.tab-container--vert .tab--selected) {\r\n                            border: 1px solid ${this.props.colors.border};\r\n                            border-left: 2px solid ${this.props.colors.primary};\r\n                            border-right: none;\r\n                        }\r\n\r\n                        .tab-parent--vert {\r\n                            display: inline-flex;\r\n                            flex-direction: row;\r\n                        }\r\n                    }\r\n                `}</style>\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nTabs.defaultProps = {\r\n    mobile_breakpoint: 800,\r\n    colors: {\r\n        border: '#d6d6d6',\r\n        primary: '#1975FA',\r\n        background: '#f9f9f9',\r\n    },\r\n};\r\n\r\nTabs.propTypes = {\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    /**\r\n     * The value of the currently selected Tab\r\n     */\r\n    value: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tabs container holding the individual Tab components.\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends (inline) styles to the Tabs container holding the individual Tab components.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_style: PropTypes.object,\r\n\r\n    /**\r\n     * Renders the tabs vertically (on the side)\r\n     */\r\n    vertical: PropTypes.bool,\r\n\r\n    /**\r\n     * Breakpoint at which tabs are rendered full width (can be 0 if you don't want full width tabs on mobile)\r\n     */\r\n    mobile_breakpoint: PropTypes.number,\r\n\r\n    /**\r\n     * Array that holds Tab components\r\n     */\r\n    children: PropTypes.node,\r\n\r\n    /**\r\n     * Holds the colors used by the Tabs and Tab components. If you set these, you should specify colors for all properties, so:\r\n     * colors: {\r\n     *    border: '#d6d6d6',\r\n     *    primary: '#1975FA',\r\n     *    background: '#f9f9f9'\r\n     *  }\r\n     */\r\n    colors: PropTypes.shape({\r\n        border: PropTypes.string,\r\n        primary: PropTypes.string,\r\n        background: PropTypes.string,\r\n    }),\r\n};\r\n"]} */\\n/*@ sourceURL=src\\\\components\\\\Tabs.react.js */',\n dynamic: [this.props.mobile_breakpoint, this.props.colors.border, this.props.colors.border, this.props.colors.primary]\n })\n );\n }\n }]);\n\n return Tabs;\n}(Component);\n\nexports.default = Tabs;\n\n\nTabs.defaultProps = {\n mobile_breakpoint: 800,\n colors: {\n border: '#d6d6d6',\n primary: '#1975FA',\n background: '#f9f9f9'\n }\n};\n\nTabs.propTypes = {\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: PropTypes.string,\n\n /**\r\n * The value of the currently selected Tab\r\n */\n value: PropTypes.string,\n\n /**\r\n * Appends a class to the Tabs container holding the individual Tab components.\r\n */\n className: PropTypes.string,\n\n /**\r\n * Appends a class to the Tab content container holding the children of the Tab that is selected.\r\n */\n content_className: PropTypes.string,\n\n /**\r\n * Appends a class to the top-level parent container holding both the Tabs container and the content container.\r\n */\n parent_className: PropTypes.string,\n\n /**\r\n * Appends (inline) styles to the Tabs container holding the individual Tab components.\r\n */\n style: PropTypes.object,\n\n /**\r\n * Appends (inline) styles to the top-level parent container holding both the Tabs container and the content container.\r\n */\n parent_style: PropTypes.object,\n\n /**\r\n * Appends (inline) styles to the tab content container holding the children of the Tab that is selected.\r\n */\n content_style: PropTypes.object,\n\n /**\r\n * Renders the tabs vertically (on the side)\r\n */\n vertical: PropTypes.bool,\n\n /**\r\n * Breakpoint at which tabs are rendered full width (can be 0 if you don't want full width tabs on mobile)\r\n */\n mobile_breakpoint: PropTypes.number,\n\n /**\r\n * Array that holds Tab components\r\n */\n children: PropTypes.node,\n\n /**\r\n * Holds the colors used by the Tabs and Tab components. If you set these, you should specify colors for all properties, so:\r\n * colors: {\r\n * border: '#d6d6d6',\r\n * primary: '#1975FA',\r\n * background: '#f9f9f9'\r\n * }\r\n */\n colors: PropTypes.shape({\n border: PropTypes.string,\n primary: PropTypes.string,\n background: PropTypes.string\n })\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://dash_core_components/./src/components/Tabs.react.js?416c"],"names":["React","Component","PropTypes","R","EnhancedTab","id","label","selected","className","style","selectedClassName","selected_style","selectHandler","value","disabled","disabled_style","disabled_className","mobile_breakpoint","amountOfTabs","colors","tabStyle","tabClassName","labelDisplay","is","Array","props","children","background","border","primary","Tabs","bind","parseChildrenToArray","state","setProps","setState","newProps","EnhancedTabs","selectedTab","selectedTabContent","length","map","child","index","childProps","selected_className","filter","tabContainerClass","vertical","tabContentClass","tabParentClass","parent_style","parent_className","content_style","content_className","defaultProps","propTypes","string","object","bool","number","node","shape"],"mappings":"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","file":"./src/components/Tabs.react.js.js","sourcesContent":["/* eslint-disable react/prop-types */\r\nimport React, {Component} from 'react';\r\nimport PropTypes from 'prop-types';\r\nimport R from 'ramda';\r\n\r\nconst EnhancedTab = ({\r\n    id,\r\n    label,\r\n    selected,\r\n    className,\r\n    style,\r\n    selectedClassName,\r\n    selected_style,\r\n    selectHandler,\r\n    value,\r\n    disabled,\r\n    disabled_style,\r\n    disabled_className,\r\n    mobile_breakpoint,\r\n    amountOfTabs,\r\n    colors,\r\n}) => {\r\n    let tabStyle = style;\r\n    if (disabled) {\r\n        tabStyle = {tabStyle, ...disabled_style};\r\n    }\r\n    if (selected) {\r\n        tabStyle = {tabStyle, ...selected_style};\r\n    }\r\n    let tabClassName = `tab ${className || ''}`;\r\n    if (disabled) {\r\n        tabClassName += `tab--disabled ${disabled_className || ''}`;\r\n    }\r\n    if (selected) {\r\n        tabClassName += ` tab--selected ${selectedClassName || ''}`;\r\n    }\r\n    let labelDisplay;\r\n    if (R.is(Array, label)) {\r\n        // label is an array, so it has children that we want to render\r\n        labelDisplay = label[0].props.children;\r\n    } else {\r\n        // else it is a string, so we just want to render that\r\n        labelDisplay = label;\r\n    }\r\n    return (\r\n        <div\r\n            className={tabClassName}\r\n            id={id}\r\n            style={tabStyle}\r\n            onClick={() => {\r\n                if (!disabled) {\r\n                    selectHandler(value);\r\n                }\r\n            }}\r\n        >\r\n            <span>{labelDisplay}</span>\r\n            <style jsx>{`\r\n                .tab {\r\n                    display: inline-block;\r\n                    background-color: ${colors.background};\r\n                    border: 1px solid ${colors.border};\r\n                    border-bottom: none;\r\n                    padding: 20px 25px;\r\n                    transition: background-color, color 200ms;\r\n                    width: 100%;\r\n                    text-align: center;\r\n                    box-sizing: border-box;\r\n                }\r\n                .tab:last-of-type {\r\n                    border-right: 1px solid ${colors.border};\r\n                    border-bottom: 1px solid ${colors.border};\r\n                }\r\n                .tab:hover {\r\n                    cursor: pointer;\r\n                }\r\n                .tab--selected {\r\n                    border-top: 2px solid ${colors.primary};\r\n                    color: black;\r\n                    background-color: white;\r\n                }\r\n                .tab--selected:hover {\r\n                    background-color: white;\r\n                }\r\n                .tab--disabled {\r\n                    color: #d6d6d6;\r\n                }\r\n\r\n                @media screen and (min-width: ${mobile_breakpoint}px) {\r\n                    .tab {\r\n                        border: 1px solid ${colors.border};\r\n                        border-right: none;\r\n                        width: calc(100% / ${amountOfTabs});\r\n                    }\r\n                    .tab--selected,\r\n                    .tab:last-of-type.tab--selected {\r\n                        border-bottom: none;\r\n                        border-top: 2px solid ${colors.primary};\r\n                    }\r\n                }\r\n            `}</style>\r\n        </div>\r\n    );\r\n};\r\n\r\n/**\r\n * A Dash component that lets you render pages with tabs - the Tabs component's children\r\n * can be dcc.Tab components, which can hold a label that will be displayed as a tab, and can in turn hold\r\n * children components that will be that tab's content.\r\n */\r\nexport default class Tabs extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n\r\n        this.selectHandler = this.selectHandler.bind(this);\r\n        this.parseChildrenToArray = this.parseChildrenToArray.bind(this);\r\n\r\n        this.parseChildrenToArray();\r\n\r\n        if (!this.props.value) {\r\n            // if no value specified on Tabs component, set it to the first child's (which should be a Tab component) value\r\n            const value =\r\n                this.props.children[0].props.children.props.value || 'tab-1';\r\n            this.state = {\r\n                selected: value,\r\n            };\r\n            if (this.props.setProps) {\r\n                // updating the prop in Dash is necessary so that callbacks work\r\n                this.props.setProps({\r\n                    value: value,\r\n                });\r\n            }\r\n        } else {\r\n            this.state = {\r\n                selected: this.props.value,\r\n            };\r\n        }\r\n    }\r\n    parseChildrenToArray() {\r\n        if (this.props.children && !R.is(Array, this.props.children)) {\r\n            // if dcc.Tabs.children contains just one single element, it gets passed as an object\r\n            // instead of an array - so we put in in a array ourselves!\r\n            this.props.children = [this.props.children];\r\n        }\r\n    }\r\n    selectHandler(value) {\r\n        this.setState({\r\n            selected: value,\r\n        });\r\n        if (this.props.setProps) {\r\n            this.props.setProps({value: value});\r\n        }\r\n    }\r\n    componentWillReceiveProps(newProps) {\r\n        const value = newProps.value;\r\n        if (typeof value !== 'undefined') {\r\n            this.setState({\r\n                selected: value,\r\n            });\r\n        }\r\n    }\r\n    render() {\r\n        let EnhancedTabs;\r\n        let selectedTab;\r\n        let selectedTabContent;\r\n\r\n        if (this.props.children) {\r\n            this.parseChildrenToArray();\r\n\r\n            const amountOfTabs = this.props.children.length;\r\n\r\n            EnhancedTabs = this.props.children.map((child, index) => {\r\n                // TODO: handle components that are not dcc.Tab components (throw error)\r\n                // enhance Tab components coming from Dash (as dcc.Tab) with methods needed for handling logic\r\n                let childProps;\r\n\r\n\r\n                if (child.props.children) {\r\n                    // if props appears on .children, props are coming from Dash\r\n                    childProps = child.props.children.props;\r\n                } else {\r\n                    // else props are coming from React (Demo.react.js)\r\n                    childProps = child.props;\r\n                }\r\n\r\n                if (!childProps.value) {\r\n                    childProps.value = `tab-${index + 1}`;\r\n                }\r\n\r\n                return (\r\n                    <EnhancedTab\r\n                        key={index}\r\n                        id={childProps.id}\r\n                        label={childProps.label}\r\n                        selected={this.state.selected === childProps.value}\r\n                        selectHandler={this.selectHandler}\r\n                        className={childProps.className}\r\n                        style={childProps.style}\r\n                        selectedClassName={childProps.selected_className}\r\n                        selected_style={childProps.selected_style}\r\n                        value={childProps.value}\r\n                        disabled={childProps.disabled}\r\n                        disabled_style={childProps.disabled_style}\r\n                        disabled_classname={childProps.disabled_className}\r\n                        mobile_breakpoint={this.props.mobile_breakpoint}\r\n                        amountOfTabs={amountOfTabs}\r\n                        colors={this.props.colors}\r\n                    />\r\n                );\r\n            });\r\n\r\n            selectedTab = this.props.children.filter(child => {\r\n                return child.props.children.props.value === this.state.selected;\r\n            });\r\n            if ('props' in selectedTab[0]) {\r\n                selectedTabContent = selectedTab[0].props.children;\r\n            }\r\n        }\r\n\r\n        const tabContainerClass = this.props.vertical\r\n            ? 'tab-container tab-container--vert'\r\n            : 'tab-container';\r\n\r\n        const tabContentClass = this.props.vertical\r\n            ? 'tab-content tab-content--vert'\r\n            : 'tab-content';\r\n\r\n        const tabParentClass = this.props.vertical\r\n            ? 'tab-parent tab-parent--vert'\r\n            : 'tab-parent';\r\n\r\n        return (\r\n            <div\r\n                className={`${tabParentClass} ${this.props.parent_className ||\r\n                    ''}`}\r\n                style={this.props.parent_style}\r\n            >\r\n                <div\r\n                    className={`${tabContainerClass} ${this.props.className ||\r\n                        ''}`}\r\n                    style={this.props.style}\r\n                >\r\n                    {EnhancedTabs}\r\n                </div>\r\n                <div\r\n                    className={`${tabContentClass} ${this.props\r\n                        .content_className || ''}`}\r\n                    style={this.props.content_style}\r\n                >\r\n                    {selectedTabContent || ''}\r\n                </div>\r\n                <style jsx>{`\r\n                    .tab-parent {\r\n                        display: flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-container {\r\n                        display: flex;\r\n                    }\r\n                    .tab-container--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    .tab-content--vert {\r\n                        display: inline-flex;\r\n                        flex-direction: column;\r\n                    }\r\n                    @media screen and (min-width: ${this.props\r\n                            .mobile_breakpoint}px) {\r\n                        :global(.tab-container--vert .tab) {\r\n                            width: auto;\r\n                            border-right: none !important;\r\n                            border-bottom: none;\r\n                        }\r\n                        :global(.tab-container--vert .tab:last-of-type) {\r\n                            border-bottom: 1px solid ${this.props.colors.border} !important;\r\n                        }\r\n                        :global(.tab-container--vert .tab--selected) {\r\n                            border: 1px solid ${this.props.colors.border};\r\n                            border-left: 2px solid ${this.props.colors.primary};\r\n                            border-right: none;\r\n                        }\r\n\r\n                        .tab-parent--vert {\r\n                            display: inline-flex;\r\n                            flex-direction: row;\r\n                        }\r\n                    }\r\n                `}</style>\r\n            </div>\r\n        );\r\n    }\r\n}\r\n\r\nTabs.defaultProps = {\r\n    mobile_breakpoint: 800,\r\n    colors: {\r\n        border: '#d6d6d6',\r\n        primary: '#1975FA',\r\n        background: '#f9f9f9',\r\n    },\r\n};\r\n\r\nTabs.propTypes = {\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    /**\r\n     * The value of the currently selected Tab\r\n     */\r\n    value: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tabs container holding the individual Tab components.\r\n     */\r\n    className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the Tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends a class to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_className: PropTypes.string,\r\n\r\n    /**\r\n     * Appends (inline) styles to the Tabs container holding the individual Tab components.\r\n     */\r\n    style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the top-level parent container holding both the Tabs container and the content container.\r\n     */\r\n    parent_style: PropTypes.object,\r\n\r\n    /**\r\n     * Appends (inline) styles to the tab content container holding the children of the Tab that is selected.\r\n     */\r\n    content_style: PropTypes.object,\r\n\r\n    /**\r\n     * Renders the tabs vertically (on the side)\r\n     */\r\n    vertical: PropTypes.bool,\r\n\r\n    /**\r\n     * Breakpoint at which tabs are rendered full width (can be 0 if you don't want full width tabs on mobile)\r\n     */\r\n    mobile_breakpoint: PropTypes.number,\r\n\r\n    /**\r\n     * Array that holds Tab components\r\n     */\r\n    children: PropTypes.node,\r\n\r\n    /**\r\n     * Holds the colors used by the Tabs and Tab components. If you set these, you should specify colors for all properties, so:\r\n     * colors: {\r\n     *    border: '#d6d6d6',\r\n     *    primary: '#1975FA',\r\n     *    background: '#f9f9f9'\r\n     *  }\r\n     */\r\n    colors: PropTypes.shape({\r\n        border: PropTypes.string,\r\n        primary: PropTypes.string,\r\n        background: PropTypes.string,\r\n    }),\r\n};\r\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/components/Tabs.react.js\n"); /***/ }), @@ -13078,7 +13090,7 @@ eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n}); /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Upload = exports.DatePickerRange = exports.DatePickerSingle = exports.Textarea = exports.Link = exports.Location = exports.Markdown = exports.Interval = exports.Tab = exports.Tabs = exports.SyntaxHighlighter = exports.Slider = exports.RangeSlider = exports.RadioItems = exports.Input = exports.Graph = exports.Dropdown = exports.ConfirmDialogProvider = exports.ConfirmDialog = exports.Checklist = undefined;\n\nvar _ConfirmDialog = __webpack_require__(/*! ./components/ConfirmDialog.react */ \"./src/components/ConfirmDialog.react.js\");\n\nvar ConfirmDialog = _interopRequireDefault(_ConfirmDialog).default;\n\nvar _ConfirmDialogProvider = __webpack_require__(/*! ./components/ConfirmDialogProvider.react */ \"./src/components/ConfirmDialogProvider.react.js\");\n\nvar ConfirmDialogProvider = _interopRequireDefault(_ConfirmDialogProvider).default;\n\nvar _Dropdown = __webpack_require__(/*! ./components/Dropdown.react */ \"./src/components/Dropdown.react.js\");\n\nvar Dropdown = _interopRequireDefault(_Dropdown).default;\n\nvar _Input = __webpack_require__(/*! ./components/Input.react */ \"./src/components/Input.react.js\");\n\nvar Input = _interopRequireDefault(_Input).default;\n\nvar _Graph = __webpack_require__(/*! ./components/Graph.react */ \"./src/components/Graph.react.js\");\n\nvar Graph = _interopRequireDefault(_Graph).default;\n\nvar _RangeSlider = __webpack_require__(/*! ./components/RangeSlider.react */ \"./src/components/RangeSlider.react.js\");\n\nvar RangeSlider = _interopRequireDefault(_RangeSlider).default;\n\nvar _Slider = __webpack_require__(/*! ./components/Slider.react */ \"./src/components/Slider.react.js\");\n\nvar Slider = _interopRequireDefault(_Slider).default;\n\nvar _RadioItems = __webpack_require__(/*! ./components/RadioItems.react */ \"./src/components/RadioItems.react.js\");\n\nvar RadioItems = _interopRequireDefault(_RadioItems).default;\n\nvar _Checklist = __webpack_require__(/*! ./components/Checklist.react */ \"./src/components/Checklist.react.js\");\n\nvar Checklist = _interopRequireDefault(_Checklist).default;\n\nvar _SyntaxHighlighter = __webpack_require__(/*! ./components/SyntaxHighlighter.react */ \"./src/components/SyntaxHighlighter.react.js\");\n\nvar SyntaxHighlighter = _interopRequireDefault(_SyntaxHighlighter).default;\n\nvar _Interval = __webpack_require__(/*! ./components/Interval.react */ \"./src/components/Interval.react.js\");\n\nvar Interval = _interopRequireDefault(_Interval).default;\n\nvar _Markdown = __webpack_require__(/*! ./components/Markdown.react */ \"./src/components/Markdown.react.js\");\n\nvar Markdown = _interopRequireDefault(_Markdown).default;\n\nvar _Location = __webpack_require__(/*! ./components/Location.react */ \"./src/components/Location.react.js\");\n\nvar Location = _interopRequireDefault(_Location).default;\n\nvar _Link = __webpack_require__(/*! ./components/Link.react */ \"./src/components/Link.react.js\");\n\nvar Link = _interopRequireDefault(_Link).default;\n\nvar _Textarea = __webpack_require__(/*! ./components/Textarea.react */ \"./src/components/Textarea.react.js\");\n\nvar Textarea = _interopRequireDefault(_Textarea).default;\n\nvar _DatePickerSingle = __webpack_require__(/*! ./components/DatePickerSingle.react */ \"./src/components/DatePickerSingle.react.js\");\n\nvar DatePickerSingle = _interopRequireDefault(_DatePickerSingle).default;\n\nvar _DatePickerRange = __webpack_require__(/*! ./components/DatePickerRange.react */ \"./src/components/DatePickerRange.react.js\");\n\nvar DatePickerRange = _interopRequireDefault(_DatePickerRange).default;\n\nvar _Upload = __webpack_require__(/*! ./components/Upload.react */ \"./src/components/Upload.react.js\");\n\nvar Upload = _interopRequireDefault(_Upload).default;\n\nvar _Tabs = __webpack_require__(/*! ./components/Tabs.react */ \"./src/components/Tabs.react.js\");\n\nvar Tabs = _interopRequireDefault(_Tabs).default;\n\nvar _Tab = __webpack_require__(/*! ./components/Tab.react */ \"./src/components/Tab.react.js\");\n\nvar Tab = _interopRequireDefault(_Tab).default;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/* eslint-disable import/prefer-default-export */\nexports.Checklist = Checklist;\nexports.ConfirmDialog = ConfirmDialog;\nexports.ConfirmDialogProvider = ConfirmDialogProvider;\nexports.Dropdown = Dropdown;\nexports.Graph = Graph;\nexports.Input = Input;\nexports.RadioItems = RadioItems;\nexports.RangeSlider = RangeSlider;\nexports.Slider = Slider;\nexports.SyntaxHighlighter = SyntaxHighlighter;\nexports.Tabs = Tabs;\nexports.Tab = Tab;\nexports.Interval = Interval;\nexports.Markdown = Markdown;\nexports.Location = Location;\nexports.Link = Link;\nexports.Textarea = Textarea;\nexports.DatePickerSingle = DatePickerSingle;\nexports.DatePickerRange = DatePickerRange;\nexports.Upload = Upload;//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9kYXNoX2NvcmVfY29tcG9uZW50cy8uL3NyYy9pbmRleC5qcz9iNjM1Il0sIm5hbWVzIjpbIkNvbmZpcm1EaWFsb2ciLCJDb25maXJtRGlhbG9nUHJvdmlkZXIiLCJEcm9wZG93biIsIklucHV0IiwiR3JhcGgiLCJSYW5nZVNsaWRlciIsIlNsaWRlciIsIlJhZGlvSXRlbXMiLCJDaGVja2xpc3QiLCJTeW50YXhIaWdobGlnaHRlciIsIkludGVydmFsIiwiTWFya2Rvd24iLCJMb2NhdGlvbiIsIkxpbmsiLCJUZXh0YXJlYSIsIkRhdGVQaWNrZXJTaW5nbGUiLCJEYXRlUGlja2VyUmFuZ2UiLCJVcGxvYWQiLCJUYWJzIiwiVGFiIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQ0E7O0lBQU9BLGE7O0FBQ1A7O0lBQU9DLHFCOztBQUNQOztJQUFPQyxROztBQUNQOztJQUFPQyxLOztBQUNQOztJQUFPQyxLOztBQUNQOztJQUFPQyxXOztBQUNQOztJQUFPQyxNOztBQUNQOztJQUFPQyxVOztBQUNQOztJQUFPQyxTOztBQUNQOztJQUFPQyxpQjs7QUFDUDs7SUFBT0MsUTs7QUFDUDs7SUFBT0MsUTs7QUFDUDs7SUFBT0MsUTs7QUFDUDs7SUFBT0MsSTs7QUFDUDs7SUFBT0MsUTs7QUFDUDs7SUFBT0MsZ0I7O0FBQ1A7O0lBQU9DLGU7O0FBQ1A7O0lBQU9DLE07O0FBQ1A7O0lBQU9DLEk7O0FBQ1A7O0lBQU9DLEc7Ozs7QUFwQlA7UUF1QklYLFMsR0FBQUEsUztRQUNBUixhLEdBQUFBLGE7UUFDQUMscUIsR0FBQUEscUI7UUFDQUMsUSxHQUFBQSxRO1FBQ0FFLEssR0FBQUEsSztRQUNBRCxLLEdBQUFBLEs7UUFDQUksVSxHQUFBQSxVO1FBQ0FGLFcsR0FBQUEsVztRQUNBQyxNLEdBQUFBLE07UUFDQUcsaUIsR0FBQUEsaUI7UUFDQVMsSSxHQUFBQSxJO1FBQ0FDLEcsR0FBQUEsRztRQUNBVCxRLEdBQUFBLFE7UUFDQUMsUSxHQUFBQSxRO1FBQ0FDLFEsR0FBQUEsUTtRQUNBQyxJLEdBQUFBLEk7UUFDQUMsUSxHQUFBQSxRO1FBQ0FDLGdCLEdBQUFBLGdCO1FBQ0FDLGUsR0FBQUEsZTtRQUNBQyxNLEdBQUFBLE0iLCJmaWxlIjoiLi9zcmMvaW5kZXguanMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBpbXBvcnQvcHJlZmVyLWRlZmF1bHQtZXhwb3J0ICovXHJcbmltcG9ydCBDb25maXJtRGlhbG9nIGZyb20gJy4vY29tcG9uZW50cy9Db25maXJtRGlhbG9nLnJlYWN0JztcclxuaW1wb3J0IENvbmZpcm1EaWFsb2dQcm92aWRlciBmcm9tICcuL2NvbXBvbmVudHMvQ29uZmlybURpYWxvZ1Byb3ZpZGVyLnJlYWN0J1xyXG5pbXBvcnQgRHJvcGRvd24gZnJvbSAnLi9jb21wb25lbnRzL0Ryb3Bkb3duLnJlYWN0JztcclxuaW1wb3J0IElucHV0IGZyb20gJy4vY29tcG9uZW50cy9JbnB1dC5yZWFjdCc7XHJcbmltcG9ydCBHcmFwaCBmcm9tICcuL2NvbXBvbmVudHMvR3JhcGgucmVhY3QnO1xyXG5pbXBvcnQgUmFuZ2VTbGlkZXIgZnJvbSAnLi9jb21wb25lbnRzL1JhbmdlU2xpZGVyLnJlYWN0JztcclxuaW1wb3J0IFNsaWRlciBmcm9tICcuL2NvbXBvbmVudHMvU2xpZGVyLnJlYWN0JztcclxuaW1wb3J0IFJhZGlvSXRlbXMgZnJvbSAnLi9jb21wb25lbnRzL1JhZGlvSXRlbXMucmVhY3QnO1xyXG5pbXBvcnQgQ2hlY2tsaXN0IGZyb20gJy4vY29tcG9uZW50cy9DaGVja2xpc3QucmVhY3QnO1xyXG5pbXBvcnQgU3ludGF4SGlnaGxpZ2h0ZXIgZnJvbSAnLi9jb21wb25lbnRzL1N5bnRheEhpZ2hsaWdodGVyLnJlYWN0JztcclxuaW1wb3J0IEludGVydmFsIGZyb20gJy4vY29tcG9uZW50cy9JbnRlcnZhbC5yZWFjdCc7XHJcbmltcG9ydCBNYXJrZG93biBmcm9tICcuL2NvbXBvbmVudHMvTWFya2Rvd24ucmVhY3QnO1xyXG5pbXBvcnQgTG9jYXRpb24gZnJvbSAnLi9jb21wb25lbnRzL0xvY2F0aW9uLnJlYWN0JztcclxuaW1wb3J0IExpbmsgZnJvbSAnLi9jb21wb25lbnRzL0xpbmsucmVhY3QnO1xyXG5pbXBvcnQgVGV4dGFyZWEgZnJvbSAnLi9jb21wb25lbnRzL1RleHRhcmVhLnJlYWN0JztcclxuaW1wb3J0IERhdGVQaWNrZXJTaW5nbGUgZnJvbSAnLi9jb21wb25lbnRzL0RhdGVQaWNrZXJTaW5nbGUucmVhY3QnO1xyXG5pbXBvcnQgRGF0ZVBpY2tlclJhbmdlIGZyb20gJy4vY29tcG9uZW50cy9EYXRlUGlja2VyUmFuZ2UucmVhY3QnO1xyXG5pbXBvcnQgVXBsb2FkIGZyb20gJy4vY29tcG9uZW50cy9VcGxvYWQucmVhY3QnO1xyXG5pbXBvcnQgVGFicyBmcm9tICcuL2NvbXBvbmVudHMvVGFicy5yZWFjdCc7XHJcbmltcG9ydCBUYWIgZnJvbSAnLi9jb21wb25lbnRzL1RhYi5yZWFjdCc7XHJcblxyXG5leHBvcnQge1xyXG4gICAgQ2hlY2tsaXN0LFxyXG4gICAgQ29uZmlybURpYWxvZyxcclxuICAgIENvbmZpcm1EaWFsb2dQcm92aWRlcixcclxuICAgIERyb3Bkb3duLFxyXG4gICAgR3JhcGgsXHJcbiAgICBJbnB1dCxcclxuICAgIFJhZGlvSXRlbXMsXHJcbiAgICBSYW5nZVNsaWRlcixcclxuICAgIFNsaWRlcixcclxuICAgIFN5bnRheEhpZ2hsaWdodGVyLFxyXG4gICAgVGFicyxcclxuICAgIFRhYixcclxuICAgIEludGVydmFsLFxyXG4gICAgTWFya2Rvd24sXHJcbiAgICBMb2NhdGlvbixcclxuICAgIExpbmssXHJcbiAgICBUZXh0YXJlYSxcclxuICAgIERhdGVQaWNrZXJTaW5nbGUsXHJcbiAgICBEYXRlUGlja2VyUmFuZ2UsXHJcbiAgICBVcGxvYWRcclxufTtcclxuIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/index.js\n"); +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Store = exports.Upload = exports.DatePickerRange = exports.DatePickerSingle = exports.Textarea = exports.Link = exports.Location = exports.Markdown = exports.Interval = exports.Tab = exports.Tabs = exports.SyntaxHighlighter = exports.Slider = exports.RangeSlider = exports.RadioItems = exports.Input = exports.Graph = exports.Dropdown = exports.ConfirmDialogProvider = exports.ConfirmDialog = exports.Checklist = undefined;\n\nvar _ConfirmDialog = __webpack_require__(/*! ./components/ConfirmDialog.react */ \"./src/components/ConfirmDialog.react.js\");\n\nvar ConfirmDialog = _interopRequireDefault(_ConfirmDialog).default;\n\nvar _ConfirmDialogProvider = __webpack_require__(/*! ./components/ConfirmDialogProvider.react */ \"./src/components/ConfirmDialogProvider.react.js\");\n\nvar ConfirmDialogProvider = _interopRequireDefault(_ConfirmDialogProvider).default;\n\nvar _Dropdown = __webpack_require__(/*! ./components/Dropdown.react */ \"./src/components/Dropdown.react.js\");\n\nvar Dropdown = _interopRequireDefault(_Dropdown).default;\n\nvar _Input = __webpack_require__(/*! ./components/Input.react */ \"./src/components/Input.react.js\");\n\nvar Input = _interopRequireDefault(_Input).default;\n\nvar _Graph = __webpack_require__(/*! ./components/Graph.react */ \"./src/components/Graph.react.js\");\n\nvar Graph = _interopRequireDefault(_Graph).default;\n\nvar _RangeSlider = __webpack_require__(/*! ./components/RangeSlider.react */ \"./src/components/RangeSlider.react.js\");\n\nvar RangeSlider = _interopRequireDefault(_RangeSlider).default;\n\nvar _Slider = __webpack_require__(/*! ./components/Slider.react */ \"./src/components/Slider.react.js\");\n\nvar Slider = _interopRequireDefault(_Slider).default;\n\nvar _RadioItems = __webpack_require__(/*! ./components/RadioItems.react */ \"./src/components/RadioItems.react.js\");\n\nvar RadioItems = _interopRequireDefault(_RadioItems).default;\n\nvar _Checklist = __webpack_require__(/*! ./components/Checklist.react */ \"./src/components/Checklist.react.js\");\n\nvar Checklist = _interopRequireDefault(_Checklist).default;\n\nvar _SyntaxHighlighter = __webpack_require__(/*! ./components/SyntaxHighlighter.react */ \"./src/components/SyntaxHighlighter.react.js\");\n\nvar SyntaxHighlighter = _interopRequireDefault(_SyntaxHighlighter).default;\n\nvar _Interval = __webpack_require__(/*! ./components/Interval.react */ \"./src/components/Interval.react.js\");\n\nvar Interval = _interopRequireDefault(_Interval).default;\n\nvar _Markdown = __webpack_require__(/*! ./components/Markdown.react */ \"./src/components/Markdown.react.js\");\n\nvar Markdown = _interopRequireDefault(_Markdown).default;\n\nvar _Location = __webpack_require__(/*! ./components/Location.react */ \"./src/components/Location.react.js\");\n\nvar Location = _interopRequireDefault(_Location).default;\n\nvar _Link = __webpack_require__(/*! ./components/Link.react */ \"./src/components/Link.react.js\");\n\nvar Link = _interopRequireDefault(_Link).default;\n\nvar _Textarea = __webpack_require__(/*! ./components/Textarea.react */ \"./src/components/Textarea.react.js\");\n\nvar Textarea = _interopRequireDefault(_Textarea).default;\n\nvar _DatePickerSingle = __webpack_require__(/*! ./components/DatePickerSingle.react */ \"./src/components/DatePickerSingle.react.js\");\n\nvar DatePickerSingle = _interopRequireDefault(_DatePickerSingle).default;\n\nvar _DatePickerRange = __webpack_require__(/*! ./components/DatePickerRange.react */ \"./src/components/DatePickerRange.react.js\");\n\nvar DatePickerRange = _interopRequireDefault(_DatePickerRange).default;\n\nvar _Upload = __webpack_require__(/*! ./components/Upload.react */ \"./src/components/Upload.react.js\");\n\nvar Upload = _interopRequireDefault(_Upload).default;\n\nvar _Tabs = __webpack_require__(/*! ./components/Tabs.react */ \"./src/components/Tabs.react.js\");\n\nvar Tabs = _interopRequireDefault(_Tabs).default;\n\nvar _Tab = __webpack_require__(/*! ./components/Tab.react */ \"./src/components/Tab.react.js\");\n\nvar Tab = _interopRequireDefault(_Tab).default;\n\nvar _Store = __webpack_require__(/*! ./components/Store.react */ \"./src/components/Store.react.js\");\n\nvar Store = _interopRequireDefault(_Store).default;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.Checklist = Checklist;\nexports.ConfirmDialog = ConfirmDialog;\nexports.ConfirmDialogProvider = ConfirmDialogProvider;\nexports.Dropdown = Dropdown;\nexports.Graph = Graph;\nexports.Input = Input;\nexports.RadioItems = RadioItems;\nexports.RangeSlider = RangeSlider;\nexports.Slider = Slider;\nexports.SyntaxHighlighter = SyntaxHighlighter;\nexports.Tabs = Tabs;\nexports.Tab = Tab;\nexports.Interval = Interval;\nexports.Markdown = Markdown;\nexports.Location = Location;\nexports.Link = Link;\nexports.Textarea = Textarea;\nexports.DatePickerSingle = DatePickerSingle;\nexports.DatePickerRange = DatePickerRange;\nexports.Upload = Upload;\nexports.Store = Store; /* eslint-disable import/prefer-default-export *///# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9kYXNoX2NvcmVfY29tcG9uZW50cy8uL3NyYy9pbmRleC5qcz9iNjM1Il0sIm5hbWVzIjpbIkNvbmZpcm1EaWFsb2ciLCJDb25maXJtRGlhbG9nUHJvdmlkZXIiLCJEcm9wZG93biIsIklucHV0IiwiR3JhcGgiLCJSYW5nZVNsaWRlciIsIlNsaWRlciIsIlJhZGlvSXRlbXMiLCJDaGVja2xpc3QiLCJTeW50YXhIaWdobGlnaHRlciIsIkludGVydmFsIiwiTWFya2Rvd24iLCJMb2NhdGlvbiIsIkxpbmsiLCJUZXh0YXJlYSIsIkRhdGVQaWNrZXJTaW5nbGUiLCJEYXRlUGlja2VyUmFuZ2UiLCJVcGxvYWQiLCJUYWJzIiwiVGFiIiwiU3RvcmUiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFDQTs7SUFBT0EsYTs7QUFDUDs7SUFBT0MscUI7O0FBQ1A7O0lBQU9DLFE7O0FBQ1A7O0lBQU9DLEs7O0FBQ1A7O0lBQU9DLEs7O0FBQ1A7O0lBQU9DLFc7O0FBQ1A7O0lBQU9DLE07O0FBQ1A7O0lBQU9DLFU7O0FBQ1A7O0lBQU9DLFM7O0FBQ1A7O0lBQU9DLGlCOztBQUNQOztJQUFPQyxROztBQUNQOztJQUFPQyxROztBQUNQOztJQUFPQyxROztBQUNQOztJQUFPQyxJOztBQUNQOztJQUFPQyxROztBQUNQOztJQUFPQyxnQjs7QUFDUDs7SUFBT0MsZTs7QUFDUDs7SUFBT0MsTTs7QUFDUDs7SUFBT0MsSTs7QUFDUDs7SUFBT0MsRzs7QUFDUDs7SUFBT0MsSzs7OztRQUdIWixTLEdBQUFBLFM7UUFDQVIsYSxHQUFBQSxhO1FBQ0FDLHFCLEdBQUFBLHFCO1FBQ0FDLFEsR0FBQUEsUTtRQUNBRSxLLEdBQUFBLEs7UUFDQUQsSyxHQUFBQSxLO1FBQ0FJLFUsR0FBQUEsVTtRQUNBRixXLEdBQUFBLFc7UUFDQUMsTSxHQUFBQSxNO1FBQ0FHLGlCLEdBQUFBLGlCO1FBQ0FTLEksR0FBQUEsSTtRQUNBQyxHLEdBQUFBLEc7UUFDQVQsUSxHQUFBQSxRO1FBQ0FDLFEsR0FBQUEsUTtRQUNBQyxRLEdBQUFBLFE7UUFDQUMsSSxHQUFBQSxJO1FBQ0FDLFEsR0FBQUEsUTtRQUNBQyxnQixHQUFBQSxnQjtRQUNBQyxlLEdBQUFBLGU7UUFDQUMsTSxHQUFBQSxNO1FBQ0FHLEssR0FBQUEsSyxFQTVDSiIsImZpbGUiOiIuL3NyYy9pbmRleC5qcy5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnQgKi9cclxuaW1wb3J0IENvbmZpcm1EaWFsb2cgZnJvbSAnLi9jb21wb25lbnRzL0NvbmZpcm1EaWFsb2cucmVhY3QnO1xyXG5pbXBvcnQgQ29uZmlybURpYWxvZ1Byb3ZpZGVyIGZyb20gJy4vY29tcG9uZW50cy9Db25maXJtRGlhbG9nUHJvdmlkZXIucmVhY3QnXHJcbmltcG9ydCBEcm9wZG93biBmcm9tICcuL2NvbXBvbmVudHMvRHJvcGRvd24ucmVhY3QnO1xyXG5pbXBvcnQgSW5wdXQgZnJvbSAnLi9jb21wb25lbnRzL0lucHV0LnJlYWN0JztcclxuaW1wb3J0IEdyYXBoIGZyb20gJy4vY29tcG9uZW50cy9HcmFwaC5yZWFjdCc7XHJcbmltcG9ydCBSYW5nZVNsaWRlciBmcm9tICcuL2NvbXBvbmVudHMvUmFuZ2VTbGlkZXIucmVhY3QnO1xyXG5pbXBvcnQgU2xpZGVyIGZyb20gJy4vY29tcG9uZW50cy9TbGlkZXIucmVhY3QnO1xyXG5pbXBvcnQgUmFkaW9JdGVtcyBmcm9tICcuL2NvbXBvbmVudHMvUmFkaW9JdGVtcy5yZWFjdCc7XHJcbmltcG9ydCBDaGVja2xpc3QgZnJvbSAnLi9jb21wb25lbnRzL0NoZWNrbGlzdC5yZWFjdCc7XHJcbmltcG9ydCBTeW50YXhIaWdobGlnaHRlciBmcm9tICcuL2NvbXBvbmVudHMvU3ludGF4SGlnaGxpZ2h0ZXIucmVhY3QnO1xyXG5pbXBvcnQgSW50ZXJ2YWwgZnJvbSAnLi9jb21wb25lbnRzL0ludGVydmFsLnJlYWN0JztcclxuaW1wb3J0IE1hcmtkb3duIGZyb20gJy4vY29tcG9uZW50cy9NYXJrZG93bi5yZWFjdCc7XHJcbmltcG9ydCBMb2NhdGlvbiBmcm9tICcuL2NvbXBvbmVudHMvTG9jYXRpb24ucmVhY3QnO1xyXG5pbXBvcnQgTGluayBmcm9tICcuL2NvbXBvbmVudHMvTGluay5yZWFjdCc7XHJcbmltcG9ydCBUZXh0YXJlYSBmcm9tICcuL2NvbXBvbmVudHMvVGV4dGFyZWEucmVhY3QnO1xyXG5pbXBvcnQgRGF0ZVBpY2tlclNpbmdsZSBmcm9tICcuL2NvbXBvbmVudHMvRGF0ZVBpY2tlclNpbmdsZS5yZWFjdCc7XHJcbmltcG9ydCBEYXRlUGlja2VyUmFuZ2UgZnJvbSAnLi9jb21wb25lbnRzL0RhdGVQaWNrZXJSYW5nZS5yZWFjdCc7XHJcbmltcG9ydCBVcGxvYWQgZnJvbSAnLi9jb21wb25lbnRzL1VwbG9hZC5yZWFjdCc7XHJcbmltcG9ydCBUYWJzIGZyb20gJy4vY29tcG9uZW50cy9UYWJzLnJlYWN0JztcclxuaW1wb3J0IFRhYiBmcm9tICcuL2NvbXBvbmVudHMvVGFiLnJlYWN0JztcclxuaW1wb3J0IFN0b3JlIGZyb20gJy4vY29tcG9uZW50cy9TdG9yZS5yZWFjdCc7XHJcblxyXG5leHBvcnQge1xyXG4gICAgQ2hlY2tsaXN0LFxyXG4gICAgQ29uZmlybURpYWxvZyxcclxuICAgIENvbmZpcm1EaWFsb2dQcm92aWRlcixcclxuICAgIERyb3Bkb3duLFxyXG4gICAgR3JhcGgsXHJcbiAgICBJbnB1dCxcclxuICAgIFJhZGlvSXRlbXMsXHJcbiAgICBSYW5nZVNsaWRlcixcclxuICAgIFNsaWRlcixcclxuICAgIFN5bnRheEhpZ2hsaWdodGVyLFxyXG4gICAgVGFicyxcclxuICAgIFRhYixcclxuICAgIEludGVydmFsLFxyXG4gICAgTWFya2Rvd24sXHJcbiAgICBMb2NhdGlvbixcclxuICAgIExpbmssXHJcbiAgICBUZXh0YXJlYSxcclxuICAgIERhdGVQaWNrZXJTaW5nbGUsXHJcbiAgICBEYXRlUGlja2VyUmFuZ2UsXHJcbiAgICBVcGxvYWQsXHJcbiAgICBTdG9yZVxyXG59O1xyXG4iXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/index.js\n"); /***/ }),