jiskattema/spot

View on GitHub
dist/js/index.chunk.a0b0125d2cc0e82e332c.js

Summary

Maintainability
A
0 mins
Test Coverage
(window.webpackJsonp=window.webpackJsonp||[]).push([["index"],{0:function(t,n,l){l("a26e"),t.exports=l("9218")},"035a":function(module,exports,__webpack_require__){eval("var app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar BaseWidget = __webpack_require__(/*! ./base-widget */ \"26ef\"); // var Vis = require('vis');\n\n\nvar Vis = __webpack_require__(/*! visGraph3d */ \"5bf9\");\n\nvar colors = __webpack_require__(/*! ../../colors */ \"eb63\");\n\nvar misval = Spot.util.misval;\n\nvar util = __webpack_require__(/*! ./util */ \"2b41\");\n\nfunction _deinitChart(view) {\n  if (view._graph3d) {\n    delete view._graph3d;\n  }\n\n  view.isInitialized = false;\n}\n\nfunction _initChart(view) {\n  // Configure plot\n  view._config = view.model.scatterConfig();\n  var filter = view.model.filter;\n  var primary = filter.partitions.get(1, 'rank');\n  var secondary = filter.partitions.get(2, 'rank');\n  var tertiary = filter.partitions.get(3, 'rank'); // axes labels\n\n  if (primary.showLabel) {\n    view._config.xLabel = primary.label;\n  } else {\n    view._config.xLabel = '';\n  }\n\n  if (secondary.showLabel) {\n    view._config.yLabel = secondary.label;\n  } else {\n    view._config.yLabel = '';\n  }\n\n  if (tertiary.showLabel) {\n    view._config.zLabel = tertiary.label;\n  } else {\n    view._config.zLabel = '';\n  } // set ranges\n\n\n  view._config.xMin = primary.minval;\n  view._config.xMax = primary.maxval;\n  view._config.yMin = secondary.minval;\n  view._config.yMax = secondary.maxval;\n  view._config.zMin = tertiary.minval;\n  view._config.zMax = tertiary.maxval; // force a square full size plot\n\n  var width = view.el.offsetWidth;\n  var height = view.el.offsetHeight;\n  view._config.width = width + 'px';\n  view._config.height = height + 'px'; // click callback\n\n  view._config.onclick = function (point) {\n    var groupx = primary.groups.models[point.i];\n    primary.updateSelection(groupx);\n    var groupy = secondary.groups.models[point.j];\n    secondary.updateSelection(groupy);\n    var groupz = tertiary.groups.models[point.k];\n    tertiary.updateSelection(groupz);\n    view.model.filter.updateDataFilter();\n    app.me.dataview.getData();\n  }; // add dummy data point\n\n\n  var visData = new Vis.DataSet();\n  visData.add({\n    x: 0,\n    y: 0,\n    z: 0,\n    style: colors.unselectedColor.hex()\n  }); // add plot to the DOM\n\n  view._graph3d = new Vis.Graph3d(view.el, visData, view._config); // monkeypatch the float -> color function to use our own scale\n  // This probably breaks Visjs but not the parts we use\n\n  view._graph3d._hsv2rgb = function (h, s, v) {\n    // is called for hue in [0, 240]\n    return colors.getColorFloat(h / 240.0).hex();\n  };\n\n  view.isInitialized = true;\n}\n\nfunction _update(view) {\n  if (!view.isInitialized) {\n    return;\n  }\n\n  var filter = view.model.filter;\n  var primary = filter.partitions.get(1, 'rank');\n  var secondary = filter.partitions.get(2, 'rank');\n  var tertiary = filter.partitions.get(3, 'rank');\n\n  var valueFn = function valueFn(group) {\n    if (group.count !== misval) {\n      return parseFloat(group.count) || null;\n    }\n\n    return null;\n  };\n\n  var colorFn;\n  var dataMin = 0;\n  var dataMax = 1;\n  var aggregate = filter.aggregates.get(1, 'rank');\n\n  if (aggregate) {\n    dataMin = filter.data.reduce(function (prev, curr) {\n      if (prev.aa === misval || curr.aa === misval) {\n        return curr;\n      }\n\n      return prev.aa < curr.aa ? prev : curr;\n    }).aa;\n    dataMax = filter.data.reduce(function (prev, curr) {\n      if (prev.aa === misval || curr.aa === misval) {\n        return curr;\n      }\n\n      return prev.aa < curr.aa ? curr : prev;\n    }).aa;\n\n    colorFn = function colorFn(aa) {\n      if (aa !== misval) {\n        var c = parseFloat(aa) || 0;\n        c = (c - dataMin) / (dataMax - dataMin);\n        return colors.getColorFloat(c).hex();\n      }\n\n      return 0;\n    }; // update Vis.Graph3d config\n    // BUG: the legend leads to inifite loop in step.next() (or so) when manully forcing the colors in data.style\n\n\n    view._graph3d.defaultValueMin = dataMin;\n    view._graph3d.defaultValueMax = dataMax; // update Vis.Graph3d config\n    // TODO: view._graph3d.showLegend = true;\n  } else {\n    colorFn = function colorFn(group) {\n      return colors.getColor(0).hex();\n    }; // update Vis.Graph3d config\n\n\n    view._graph3d.showLegend = false;\n  } // update the data\n\n\n  var visData = new Vis.DataSet();\n  var Fx = primary.filterFunction();\n  var Fy = secondary.filterFunction();\n  var Fz = tertiary.filterFunction();\n\n  var dotColor = function dotColor(group) {\n    if (Fx(group.a) && Fy(group.b) && Fz(group.c)) {\n      return colorFn(group.aa);\n    } else {\n      return colors.unselectedColor.hex();\n    }\n  };\n\n  filter.data.forEach(function (group) {\n    if (valueFn(group)) {\n      var i = util.partitionValueToIndex(primary, group.a);\n      var j = util.partitionValueToIndex(secondary, group.b);\n      var k = util.partitionValueToIndex(tertiary, group.c);\n\n      if (i >= 0 && j >= 0 && k >= 0) {\n        visData.add({\n          x: primary.groups.models[i].value,\n          y: secondary.groups.models[j].value,\n          z: tertiary.groups.models[k].value,\n          style: dotColor(group),\n          i: i,\n          j: j,\n          k: k\n        });\n      }\n    }\n  });\n\n  view._graph3d.setData(visData);\n\n  view._graph3d.valueRange.min = dataMin;\n  view._graph3d.valueRange.max = dataMax;\n\n  view._graph3d.redraw();\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner mdl-card__media\"></div>',\n  update: function update() {\n    _update(this);\n  },\n  initChart: function initChart() {\n    _initChart(this);\n  },\n  deinitChart: function deinitChart() {\n    _deinitChart(this);\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"035a.js","sources":["webpack:///./src/widgets/views/scatter.js?10ad"],"sourcesContent":["var app = require('ampersand-app');\nvar Spot = require('spot-framework');\nvar BaseWidget = require('./base-widget');\n// var Vis = require('vis');\nvar Vis = require('visGraph3d');\nvar colors = require('../../colors');\nvar misval = Spot.util.misval;\nvar util = require('./util');\n\nfunction deinitChart (view) {\n  if (view._graph3d) {\n    delete view._graph3d;\n  }\n  view.isInitialized = false;\n}\n\nfunction initChart (view) {\n  // Configure plot\n  view._config = view.model.scatterConfig();\n\n  var filter = view.model.filter;\n  var primary = filter.partitions.get(1, 'rank');\n  var secondary = filter.partitions.get(2, 'rank');\n  var tertiary = filter.partitions.get(3, 'rank');\n\n  // axes labels\n  if (primary.showLabel) {\n    view._config.xLabel = primary.label;\n  } else {\n    view._config.xLabel = '';\n  }\n  if (secondary.showLabel) {\n    view._config.yLabel = secondary.label;\n  } else {\n    view._config.yLabel = '';\n  }\n  if (tertiary.showLabel) {\n    view._config.zLabel = tertiary.label;\n  } else {\n    view._config.zLabel = '';\n  }\n\n  // set ranges\n  view._config.xMin = primary.minval;\n  view._config.xMax = primary.maxval;\n  view._config.yMin = secondary.minval;\n  view._config.yMax = secondary.maxval;\n  view._config.zMin = tertiary.minval;\n  view._config.zMax = tertiary.maxval;\n\n  // force a square full size plot\n  var width = view.el.offsetWidth;\n  var height = view.el.offsetHeight;\n\n  view._config.width = width + 'px';\n  view._config.height = height + 'px';\n\n  // click callback\n  view._config.onclick = function (point) {\n    var groupx = primary.groups.models[point.i];\n    primary.updateSelection(groupx);\n\n    var groupy = secondary.groups.models[point.j];\n    secondary.updateSelection(groupy);\n\n    var groupz = tertiary.groups.models[point.k];\n    tertiary.updateSelection(groupz);\n\n    view.model.filter.updateDataFilter();\n    app.me.dataview.getData();\n  };\n\n  // add dummy data point\n  var visData = new Vis.DataSet();\n  visData.add({x: 0, y: 0, z: 0, style: colors.unselectedColor.hex()});\n\n  // add plot to the DOM\n  view._graph3d = new Vis.Graph3d(view.el, visData, view._config);\n\n  // monkeypatch the float -> color function to use our own scale\n  // This probably breaks Visjs but not the parts we use\n  view._graph3d._hsv2rgb = function (h, s, v) {\n    // is called for hue in [0, 240]\n    return colors.getColorFloat(h / 240.0).hex();\n  };\n\n  view.isInitialized = true;\n}\n\nfunction update (view) {\n  if (!view.isInitialized) {\n    return;\n  }\n\n  var filter = view.model.filter;\n\n  var primary = filter.partitions.get(1, 'rank');\n  var secondary = filter.partitions.get(2, 'rank');\n  var tertiary = filter.partitions.get(3, 'rank');\n\n  var valueFn = function (group) {\n    if (group.count !== misval) {\n      return parseFloat(group.count) || null;\n    }\n    return null;\n  };\n\n  var colorFn;\n  var dataMin = 0;\n  var dataMax = 1;\n  var aggregate = filter.aggregates.get(1, 'rank');\n  if (aggregate) {\n    dataMin = filter.data.reduce(function (prev, curr) {\n      if (prev.aa === misval || curr.aa === misval) {\n        return curr;\n      }\n      return prev.aa < curr.aa ? prev : curr;\n    }).aa;\n\n    dataMax = filter.data.reduce(function (prev, curr) {\n      if (prev.aa === misval || curr.aa === misval) {\n        return curr;\n      }\n      return prev.aa < curr.aa ? curr : prev;\n    }).aa;\n\n    colorFn = function (aa) {\n      if (aa !== misval) {\n        var c = parseFloat(aa) || 0;\n        c = (c - dataMin) / (dataMax - dataMin);\n        return colors.getColorFloat(c).hex();\n      }\n      return 0;\n    };\n\n    // update Vis.Graph3d config\n    // BUG: the legend leads to inifite loop in step.next() (or so) when manully forcing the colors in data.style\n    view._graph3d.defaultValueMin = dataMin;\n    view._graph3d.defaultValueMax = dataMax;\n\n    // update Vis.Graph3d config\n    // TODO: view._graph3d.showLegend = true;\n  } else {\n    colorFn = function (group) {\n      return colors.getColor(0).hex();\n    };\n\n    // update Vis.Graph3d config\n    view._graph3d.showLegend = false;\n  }\n\n  // update the data\n  var visData = new Vis.DataSet();\n\n  var Fx = primary.filterFunction();\n  var Fy = secondary.filterFunction();\n  var Fz = tertiary.filterFunction();\n\n  var dotColor = function (group) {\n    if (Fx(group.a) && Fy(group.b) && Fz(group.c)) {\n      return colorFn(group.aa);\n    } else {\n      return colors.unselectedColor.hex();\n    }\n  };\n\n  filter.data.forEach(function (group) {\n    if (valueFn(group)) {\n      var i = util.partitionValueToIndex(primary, group.a);\n      var j = util.partitionValueToIndex(secondary, group.b);\n      var k = util.partitionValueToIndex(tertiary, group.c);\n\n      if (i >= 0 && j >= 0 && k >= 0) {\n        visData.add({\n          x: primary.groups.models[i].value,\n          y: secondary.groups.models[j].value,\n          z: tertiary.groups.models[k].value,\n          style: dotColor(group),\n          i: i,\n          j: j,\n          k: k\n        });\n      }\n    }\n  });\n  view._graph3d.setData(visData);\n  view._graph3d.valueRange.min = dataMin;\n  view._graph3d.valueRange.max = dataMax;\n  view._graph3d.redraw();\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner mdl-card__media\"></div>',\n\n  update: function () {\n    update(this);\n  },\n\n  initChart: function () {\n    initChart(this);\n  },\n\n  deinitChart: function () {\n    deinitChart(this);\n  }\n});\n"],"mappings":"AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAEA;AAGA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAGA;AACA;AACA;AADA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAPA;AASA;AACA;AACA;AACA;AAAA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAbA","sourceRoot":""}\n//# sourceURL=webpack-internal:///035a\n")},"0b9a":function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nmodule.exports = View.extend({\n  template: templates.configurePartition.group,\n  bindings: {\n    'model.label': {\n      type: 'text',\n      hook: 'group-label'\n    },\n    'model.count': {\n      type: 'text',\n      hook: 'group-count'\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMGI5YS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtcGFydGl0aW9uL2dyb3VwLmpzP2JjOTMiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFZpZXcuZXh0ZW5kKHtcbiAgdGVtcGxhdGU6IHRlbXBsYXRlcy5jb25maWd1cmVQYXJ0aXRpb24uZ3JvdXAsXG4gIGJpbmRpbmdzOiB7XG4gICAgJ21vZGVsLmxhYmVsJzoge1xuICAgICAgdHlwZTogJ3RleHQnLFxuICAgICAgaG9vazogJ2dyb3VwLWxhYmVsJ1xuICAgIH0sXG4gICAgJ21vZGVsLmNvdW50Jzoge1xuICAgICAgdHlwZTogJ3RleHQnLFxuICAgICAgaG9vazogJ2dyb3VwLWNvdW50J1xuICAgIH1cbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFGQTtBQUxBO0FBRkEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///0b9a\n")},"0b9d":function(module,exports,__webpack_require__){eval("/**\n * @classdesc Radar Chart class\n * @class RadarChart\n * @augments BaseChart\n */\nvar BaseChart = __webpack_require__(/*! ./base-chart */ \"6339\");\n\nmodule.exports = BaseChart.extend({\n  initialize: function initialize() {\n    this.slots.reset([{\n      description: 'Group by',\n      type: 'partition',\n      rank: 1,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }]);\n  },\n  chartjsConfig: function chartjsConfig() {\n    return {\n      type: 'radar',\n      data: {\n        datasets: [],\n        labels: []\n      },\n      options: {\n        title: {\n          display: true,\n          position: 'top'\n        },\n        tooltips: {}\n      }\n    };\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMGI5ZC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9yYWRhcmNoYXJ0LmpzP2ZjNTQiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAY2xhc3NkZXNjIFJhZGFyIENoYXJ0IGNsYXNzXG4gKiBAY2xhc3MgUmFkYXJDaGFydFxuICogQGF1Z21lbnRzIEJhc2VDaGFydFxuICovXG5cbnZhciBCYXNlQ2hhcnQgPSByZXF1aXJlKCcuL2Jhc2UtY2hhcnQnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBCYXNlQ2hhcnQuZXh0ZW5kKHtcbiAgaW5pdGlhbGl6ZTogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMuc2xvdHMucmVzZXQoW1xuICAgICAge1xuICAgICAgICBkZXNjcmlwdGlvbjogJ0dyb3VwIGJ5JyxcbiAgICAgICAgdHlwZTogJ3BhcnRpdGlvbicsXG4gICAgICAgIHJhbms6IDEsXG4gICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY2F0ZWdvcmlhbCcsICdkYXRldGltZScsICdkdXJhdGlvbicsICdjb250aW51b3VzJywgJ3RleHQnXVxuICAgICAgfVxuICAgIF0pO1xuICB9LFxuICBjaGFydGpzQ29uZmlnOiBmdW5jdGlvbiAoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHR5cGU6ICdyYWRhcicsXG4gICAgICBkYXRhOiB7XG4gICAgICAgIGRhdGFzZXRzOiBbXSxcbiAgICAgICAgbGFiZWxzOiBbXVxuICAgICAgfSxcbiAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgdGl0bGU6IHtcbiAgICAgICAgICBkaXNwbGF5OiB0cnVlLFxuICAgICAgICAgIHBvc2l0aW9uOiAndG9wJ1xuICAgICAgICB9LFxuICAgICAgICB0b29sdGlwczoge1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBOzs7OztBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBTEE7QUFOQTtBQWVBO0FBNUJBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///0b9d\n")},"0d07":function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar moment = __webpack_require__(/*! moment-timezone */ \"6c9d\");\n\nvar TimeZonesSelect = __webpack_require__(/*! ../configure-facet/time-zones-select */ \"f3d5\");\n\nmodule.exports = View.extend({\n  template: templates.configurePartition.partitionDatetime,\n  derived: {\n    minvalAsText: {\n      deps: ['model.minval', 'model.isDatetime'],\n      fn: function fn() {\n        if (this.model.isDatetime) {\n          return this.model.minval.toISOString();\n        } else {\n          return 'not a date';\n        }\n      }\n    },\n    maxvalAsText: {\n      deps: ['model.maxval', 'model.isDatetime'],\n      fn: function fn() {\n        if (this.model.isDatetime) {\n          return this.model.maxval.toISOString();\n        } else {\n          return 'not a date';\n        }\n      }\n    }\n  },\n  bindings: {\n    'model.isDatetime': {\n      type: 'toggle',\n      hook: 'group-datetime-panel'\n    },\n    'minvalAsText': {\n      type: 'value',\n      hook: 'group-startdate-input'\n    },\n    'maxvalAsText': {\n      type: 'value',\n      hook: 'group-enddate-input'\n    }\n  },\n  events: {\n    'change [data-hook=time-units]': function changeDataHookTimeUnits() {\n      var value = this.queryByHook('time-units').value;\n      this.model.groupingDatetime = value;\n    },\n    'click [data-hook~=group-datetimerange-button]': function clickDataHookGroupDatetimerangeButton() {\n      var partition = this.model;\n      partition.reset();\n      this.queryByHook('group-startdate-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('group-enddate-input').dispatchEvent(new window.Event('input'));\n      this.parent.resetFilter = true;\n    },\n    'change [data-hook~=group-startdate-input]': function changeDataHookGroupStartdateInput() {\n      var d = moment(this.queryByHook('group-startdate-input').value);\n\n      if (d.isValid()) {\n        this.model.minval = d;\n      }\n\n      this.parent.resetFilter = true;\n    },\n    'change [data-hook~=group-enddate-input]': function changeDataHookGroupEnddateInput() {\n      var d = moment(this.queryByHook('group-enddate-input').value);\n\n      if (d.isValid()) {\n        this.model.maxval = d;\n      }\n\n      this.parent.resetFilter = true;\n    }\n  },\n  subviews: {\n    timeZones: {\n      hook: 'time-zones',\n      prepareView: function prepareView(el) {\n        return new TimeZonesSelect({\n          el: el,\n          field: 'zone',\n          model: this.model\n        });\n      }\n    }\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.queryByHook('time-units').value = this.model.groupingDatetime;\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMGQwNy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtcGFydGl0aW9uL3BhcnRpdGlvbi1kYXRldGltZS5qcz82ZDk2Il0sInNvdXJjZXNDb250ZW50IjpbInZhciBWaWV3ID0gcmVxdWlyZSgnYW1wZXJzYW5kLXZpZXcnKTtcbnZhciB0ZW1wbGF0ZXMgPSByZXF1aXJlKCcuLi8uLi90ZW1wbGF0ZXMnKTtcbnZhciBtb21lbnQgPSByZXF1aXJlKCdtb21lbnQtdGltZXpvbmUnKTtcbnZhciBUaW1lWm9uZXNTZWxlY3QgPSByZXF1aXJlKCcuLi9jb25maWd1cmUtZmFjZXQvdGltZS16b25lcy1zZWxlY3QnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuY29uZmlndXJlUGFydGl0aW9uLnBhcnRpdGlvbkRhdGV0aW1lLFxuICBkZXJpdmVkOiB7XG4gICAgbWludmFsQXNUZXh0OiB7XG4gICAgICBkZXBzOiBbJ21vZGVsLm1pbnZhbCcsICdtb2RlbC5pc0RhdGV0aW1lJ10sXG4gICAgICBmbjogZnVuY3Rpb24gKCkge1xuICAgICAgICBpZiAodGhpcy5tb2RlbC5pc0RhdGV0aW1lKSB7XG4gICAgICAgICAgcmV0dXJuIHRoaXMubW9kZWwubWludmFsLnRvSVNPU3RyaW5nKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcmV0dXJuICdub3QgYSBkYXRlJztcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sXG4gICAgbWF4dmFsQXNUZXh0OiB7XG4gICAgICBkZXBzOiBbJ21vZGVsLm1heHZhbCcsICdtb2RlbC5pc0RhdGV0aW1lJ10sXG4gICAgICBmbjogZnVuY3Rpb24gKCkge1xuICAgICAgICBpZiAodGhpcy5tb2RlbC5pc0RhdGV0aW1lKSB7XG4gICAgICAgICAgcmV0dXJuIHRoaXMubW9kZWwubWF4dmFsLnRvSVNPU3RyaW5nKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcmV0dXJuICdub3QgYSBkYXRlJztcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfSxcbiAgYmluZGluZ3M6IHtcbiAgICAnbW9kZWwuaXNEYXRldGltZSc6IHtcbiAgICAgIHR5cGU6ICd0b2dnbGUnLFxuICAgICAgaG9vazogJ2dyb3VwLWRhdGV0aW1lLXBhbmVsJ1xuICAgIH0sXG5cbiAgICAnbWludmFsQXNUZXh0Jzoge1xuICAgICAgdHlwZTogJ3ZhbHVlJyxcbiAgICAgIGhvb2s6ICdncm91cC1zdGFydGRhdGUtaW5wdXQnXG4gICAgfSxcbiAgICAnbWF4dmFsQXNUZXh0Jzoge1xuICAgICAgdHlwZTogJ3ZhbHVlJyxcbiAgICAgIGhvb2s6ICdncm91cC1lbmRkYXRlLWlucHV0J1xuICAgIH1cblxuICB9LFxuICBldmVudHM6IHtcbiAgICAnY2hhbmdlIFtkYXRhLWhvb2s9dGltZS11bml0c10nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB2YXIgdmFsdWUgPSB0aGlzLnF1ZXJ5QnlIb29rKCd0aW1lLXVuaXRzJykudmFsdWU7XG4gICAgICB0aGlzLm1vZGVsLmdyb3VwaW5nRGF0ZXRpbWUgPSB2YWx1ZTtcbiAgICB9LFxuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1kYXRldGltZXJhbmdlLWJ1dHRvbl0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB2YXIgcGFydGl0aW9uID0gdGhpcy5tb2RlbDtcbiAgICAgIHBhcnRpdGlvbi5yZXNldCgpO1xuXG4gICAgICB0aGlzLnF1ZXJ5QnlIb29rKCdncm91cC1zdGFydGRhdGUtaW5wdXQnKS5kaXNwYXRjaEV2ZW50KG5ldyB3aW5kb3cuRXZlbnQoJ2lucHV0JykpO1xuICAgICAgdGhpcy5xdWVyeUJ5SG9vaygnZ3JvdXAtZW5kZGF0ZS1pbnB1dCcpLmRpc3BhdGNoRXZlbnQobmV3IHdpbmRvdy5FdmVudCgnaW5wdXQnKSk7XG4gICAgICB0aGlzLnBhcmVudC5yZXNldEZpbHRlciA9IHRydWU7XG4gICAgfSxcbiAgICAnY2hhbmdlIFtkYXRhLWhvb2t+PWdyb3VwLXN0YXJ0ZGF0ZS1pbnB1dF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB2YXIgZCA9IG1vbWVudCh0aGlzLnF1ZXJ5QnlIb29rKCdncm91cC1zdGFydGRhdGUtaW5wdXQnKS52YWx1ZSk7XG4gICAgICBpZiAoZC5pc1ZhbGlkKCkpIHtcbiAgICAgICAgdGhpcy5tb2RlbC5taW52YWwgPSBkO1xuICAgICAgfVxuICAgICAgdGhpcy5wYXJlbnQucmVzZXRGaWx0ZXIgPSB0cnVlO1xuICAgIH0sXG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj1ncm91cC1lbmRkYXRlLWlucHV0XSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHZhciBkID0gbW9tZW50KHRoaXMucXVlcnlCeUhvb2soJ2dyb3VwLWVuZGRhdGUtaW5wdXQnKS52YWx1ZSk7XG4gICAgICBpZiAoZC5pc1ZhbGlkKCkpIHtcbiAgICAgICAgdGhpcy5tb2RlbC5tYXh2YWwgPSBkO1xuICAgICAgfVxuICAgICAgdGhpcy5wYXJlbnQucmVzZXRGaWx0ZXIgPSB0cnVlO1xuICAgIH1cbiAgfSxcbiAgc3Vidmlld3M6IHtcbiAgICB0aW1lWm9uZXM6IHtcbiAgICAgIGhvb2s6ICd0aW1lLXpvbmVzJyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBUaW1lWm9uZXNTZWxlY3Qoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBmaWVsZDogJ3pvbmUnLFxuICAgICAgICAgIG1vZGVsOiB0aGlzLm1vZGVsXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH1cbiAgfSxcbiAgcmVuZGVyOiBmdW5jdGlvbiAoKSB7XG4gICAgdGhpcy5yZW5kZXJXaXRoVGVtcGxhdGUodGhpcyk7XG5cbiAgICB0aGlzLnF1ZXJ5QnlIb29rKCd0aW1lLXVuaXRzJykudmFsdWUgPSB0aGlzLm1vZGVsLmdyb3VwaW5nRGF0ZXRpbWU7XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBUkE7QUFVQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFSQTtBQVhBO0FBc0JBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFLQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUZBO0FBVkE7QUFnQkE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBMUJBO0FBNEJBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUtBO0FBUkE7QUFEQTtBQVlBO0FBQ0E7QUFFQTtBQUNBO0FBcEZBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///0d07\n")},1:function(module,exports){eval("/* (ignored) *///# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy93cyAoaWdub3JlZCk/MDU3NyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiAoaWdub3JlZCkgKi8iXSwibWFwcGluZ3MiOiJBQUFBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///1\n")},1002:function(module,exports,__webpack_require__){eval('var View = __webpack_require__(/*! ampersand-view */ "2883");\n\nvar templates = __webpack_require__(/*! ../../templates */ "4324");\n\nvar app = __webpack_require__(/*! ampersand-app */ "fcbc");\n\nvar DatasetView = __webpack_require__(/*! ./dataset */ "5eb6");\n\nmodule.exports = View.extend({\n  template: templates.datasets.datasetCollection,\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.renderCollection(app.me.datasets, DatasetView, this.queryByHook(\'items\'));\n    return this;\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTAwMi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9kYXRhc2V0cy9kYXRhc2V0LWNvbGxlY3Rpb24uanM/OTQ4MyJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgVmlldyA9IHJlcXVpcmUoJ2FtcGVyc2FuZC12aWV3Jyk7XG52YXIgdGVtcGxhdGVzID0gcmVxdWlyZSgnLi4vLi4vdGVtcGxhdGVzJyk7XG52YXIgYXBwID0gcmVxdWlyZSgnYW1wZXJzYW5kLWFwcCcpO1xuXG52YXIgRGF0YXNldFZpZXcgPSByZXF1aXJlKCcuL2RhdGFzZXQnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuZGF0YXNldHMuZGF0YXNldENvbGxlY3Rpb24sXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVuZGVyV2l0aFRlbXBsYXRlKHRoaXMpO1xuICAgIHRoaXMucmVuZGVyQ29sbGVjdGlvbihhcHAubWUuZGF0YXNldHMsIERhdGFzZXRWaWV3LCB0aGlzLnF1ZXJ5QnlIb29rKCdpdGVtcycpKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQU5BIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///1002\n')},"1c81":function(module,exports,__webpack_require__){eval("/**\n * @classdesc Extends the Chart base class, and adds configuration.\n * @class HorizontalBarChart\n * @augments BaseChart\n */\nvar BaseChart = __webpack_require__(/*! ./base-chart */ \"6339\");\n\nvar moment = __webpack_require__(/*! moment-timezone */ \"6c9d\");\n\nmodule.exports = BaseChart.extend({\n  initialize: function initialize() {\n    this.slots.reset([{\n      description: 'Group by',\n      type: 'partition',\n      rank: 1,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Subdivide by',\n      type: 'partition',\n      rank: 2,\n      required: false,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Bar height',\n      type: 'aggregate',\n      rank: 1,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }, {\n      description: 'Error bar',\n      type: 'aggregate',\n      rank: 2,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }]);\n  },\n  chartjsConfig: function chartjsConfig() {\n    return {\n      type: 'horizontalBarError',\n      data: {\n        datasets: [],\n        labels: []\n      },\n      options: {\n        title: {\n          display: true,\n          position: 'top'\n        },\n        scales: {\n          xAxes: [{\n            ticks: {\n              beginAtZero: true\n            },\n            stacked: true,\n            display: false,\n            scaleLabel: {\n              display: true\n            },\n            time: {\n              parser: function parser(label) {\n                return moment(label, moment.ISO_8601);\n              }\n            }\n          }],\n          yAxes: [{\n            ticks: {\n              mirror: true\n            },\n            gridLines: {\n              display: false\n            },\n            scaleLabel: {\n              display: true\n            },\n            stacked: true,\n            time: {\n              parser: function parser(label) {\n                return moment(label, moment.ISO_8601);\n              }\n            }\n          }]\n        },\n        tooltips: {}\n      }\n    };\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMWM4MS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9ob3Jpem9udGFsYmFyY2hhcnQuanM/YmFkYyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBjbGFzc2Rlc2MgRXh0ZW5kcyB0aGUgQ2hhcnQgYmFzZSBjbGFzcywgYW5kIGFkZHMgY29uZmlndXJhdGlvbi5cbiAqIEBjbGFzcyBIb3Jpem9udGFsQmFyQ2hhcnRcbiAqIEBhdWdtZW50cyBCYXNlQ2hhcnRcbiAqL1xuXG52YXIgQmFzZUNoYXJ0ID0gcmVxdWlyZSgnLi9iYXNlLWNoYXJ0Jyk7XG52YXIgbW9tZW50ID0gcmVxdWlyZSgnbW9tZW50LXRpbWV6b25lJyk7XG5cbm1vZHVsZS5leHBvcnRzID0gQmFzZUNoYXJ0LmV4dGVuZCh7XG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnNsb3RzLnJlc2V0KFtcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdHcm91cCBieScsXG4gICAgICAgIHR5cGU6ICdwYXJ0aXRpb24nLFxuICAgICAgICByYW5rOiAxLFxuICAgICAgICByZXF1aXJlZDogdHJ1ZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NhdGVnb3JpYWwnLCAnZGF0ZXRpbWUnLCAnZHVyYXRpb24nLCAnY29udGludW91cycsICd0ZXh0J11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnU3ViZGl2aWRlIGJ5JyxcbiAgICAgICAgdHlwZTogJ3BhcnRpdGlvbicsXG4gICAgICAgIHJhbms6IDIsXG4gICAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NhdGVnb3JpYWwnLCAnZGF0ZXRpbWUnLCAnZHVyYXRpb24nLCAnY29udGludW91cycsICd0ZXh0J11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnQmFyIGhlaWdodCcsXG4gICAgICAgIHR5cGU6ICdhZ2dyZWdhdGUnLFxuICAgICAgICByYW5rOiAxLFxuICAgICAgICByZXF1aXJlZDogZmFsc2UsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjb250aW51b3VzJywgJ2R1cmF0aW9uJ11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnRXJyb3IgYmFyJyxcbiAgICAgICAgdHlwZTogJ2FnZ3JlZ2F0ZScsXG4gICAgICAgIHJhbms6IDIsXG4gICAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NvbnRpbnVvdXMnLCAnZHVyYXRpb24nXVxuICAgICAgfVxuICAgIF0pO1xuICB9LFxuICBjaGFydGpzQ29uZmlnOiBmdW5jdGlvbiAoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHR5cGU6ICdob3Jpem9udGFsQmFyRXJyb3InLFxuICAgICAgZGF0YToge1xuICAgICAgICBkYXRhc2V0czogW10sXG4gICAgICAgIGxhYmVsczogW11cbiAgICAgIH0sXG4gICAgICBvcHRpb25zOiB7XG4gICAgICAgIHRpdGxlOiB7XG4gICAgICAgICAgZGlzcGxheTogdHJ1ZSxcbiAgICAgICAgICBwb3NpdGlvbjogJ3RvcCdcbiAgICAgICAgfSxcbiAgICAgICAgc2NhbGVzOiB7XG4gICAgICAgICAgeEF4ZXM6IFt7XG4gICAgICAgICAgICB0aWNrczoge1xuICAgICAgICAgICAgICBiZWdpbkF0WmVybzogdHJ1ZVxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHN0YWNrZWQ6IHRydWUsXG4gICAgICAgICAgICBkaXNwbGF5OiBmYWxzZSxcbiAgICAgICAgICAgIHNjYWxlTGFiZWw6IHtcbiAgICAgICAgICAgICAgZGlzcGxheTogdHJ1ZVxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHRpbWU6IHtcbiAgICAgICAgICAgICAgcGFyc2VyOiBmdW5jdGlvbiAobGFiZWwpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gbW9tZW50KGxhYmVsLCBtb21lbnQuSVNPXzg2MDEpO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfV0sXG4gICAgICAgICAgeUF4ZXM6IFt7XG4gICAgICAgICAgICB0aWNrczoge1xuICAgICAgICAgICAgICBtaXJyb3I6IHRydWVcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBncmlkTGluZXM6IHtcbiAgICAgICAgICAgICAgZGlzcGxheTogZmFsc2VcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBzY2FsZUxhYmVsOiB7XG4gICAgICAgICAgICAgIGRpc3BsYXk6IHRydWVcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBzdGFja2VkOiB0cnVlLFxuICAgICAgICAgICAgdGltZToge1xuICAgICAgICAgICAgICBwYXJzZXI6IGZ1bmN0aW9uIChsYWJlbCkge1xuICAgICAgICAgICAgICAgIHJldHVybiBtb21lbnQobGFiZWwsIG1vbWVudC5JU09fODYwMSk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XVxuICAgICAgICB9LFxuICAgICAgICB0b29sdGlwczoge1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBOzs7OztBQU1BO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUxBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUxBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUxBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUxBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFEQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFUQTtBQWVBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBWEE7QUFoQkE7QUFrQ0E7QUF2Q0E7QUFOQTtBQWlEQTtBQW5GQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///1c81\n")},2:function(module,exports){eval("/* (ignored) *///# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy91dGlsIChpZ25vcmVkKT9hNTE1Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIChpZ25vcmVkKSAqLyJdLCJtYXBwaW5ncyI6IkFBQUEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///2\n")},"22e9":function(module,exports,__webpack_require__){eval("var app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar $ = __webpack_require__(/*! jquery */ \"802c\");\n\nvar PageView = __webpack_require__(/*! ./base */ \"b966\");\n\nvar templates = __webpack_require__(/*! ../templates */ \"4324\");\n\nvar WidgetFrameView = __webpack_require__(/*! ./analyze/widget-frame */ \"5122\");\n\nvar FacetbarItemView = __webpack_require__(/*! ./analyze/facetbar-item */ \"6b2d\");\n\nvar sortablejs = __webpack_require__(/*! sortablejs */ \"4776\");\n\nvar AnalyzeHelp = __webpack_require__(/*! ./help/analyze */ \"b43e\"); // NOTE: gridster does not work properly with require()\n// workaround via browserify-shim (configured in package.json)\n\n\n__webpack_require__(/*! gridster */ \"cc37\");\n\nfunction _initializeCharts(view) {\n  var gridster = view._widgetsGridster; // BUGFIX: can sometimes get called before gridster is fully initialized\n\n  if (!gridster) {\n    return;\n  }\n\n  var i;\n\n  for (i = 0; i < gridster.$widgets.length; i++) {\n    var chartView = $(gridster.$widgets[i]).data('spotWidgetFrameView')._subviews[0];\n\n    chartView.model.updateConfiguration();\n\n    if (chartView.model.isConfigured) {\n      if (!chartView.model.filter.isInitialized) {\n        if (chartView.isInitialized) {\n          chartView.deinitChart(); // deininit charts that had a filter released\n        }\n\n        chartView.model.filter.initDataFilter();\n      }\n\n      if (chartView.isInitialized) {// noop\n      } else {\n        chartView.initChart();\n      }\n    } else {\n      if (chartView.isInitialized) {\n        chartView.deinitChart();\n      }\n\n      if (chartView.model.filter.isInitialized) {\n        chartView.model.filter.releaseDataFilter();\n      }\n    }\n  }\n}\n\nfunction _deinitializeCharts(view) {\n  var gridster = view._widgetsGridster;\n  var i;\n\n  for (i = 0; i < gridster.$widgets.length; i++) {\n    var chartView = $(gridster.$widgets[i]).data('spotWidgetFrameView')._subviews[0];\n\n    if (chartView.isInitialized) {\n      chartView.deinitChart();\n    }\n\n    if (chartView.model.isConfigured) {\n      chartView.model.filter.releaseDataFilter();\n    }\n  }\n}\n\nfunction _updateCharts(view) {\n  var gridster = view._widgetsGridster;\n  var i;\n\n  for (i = 0; i < gridster.$widgets.length; i++) {\n    var chartView = $(gridster.$widgets[i]).data('spotWidgetFrameView')._subviews[0];\n\n    if (chartView.isInitialized) {\n      chartView.update();\n    }\n  }\n}\n/**\n * Add a widget to the analyze page for the given filter\n *\n * view {View}             Ampersand View instance of the analyze page\n * filter {Filter}         Spot filter instance to create the widget for\n * editModeHint {boolean}  Try to start plot in editMode (ie. accepts dnd of facets) [true] or in interaction mode (false)\n */\n\n\nfunction addWidgetForFilter(view, filter, editModeHint) {\n  var gridster = view._widgetsGridster;\n  var row = filter.row || 1;\n  var col = filter.col || 1;\n  var sizeX = filter.size_x || 3;\n  var sizeY = filter.size_y || 3;\n  var el = gridster.add_widget('<div class=\"widgetOuterFrame\"></div>', sizeX, sizeY, col, row);\n  var frameView = new WidgetFrameView({\n    model: filter\n  }); // render, and render content of widget frame\n\n  view.renderSubview(frameView, el[0]);\n  frameView.renderContent(); // link element and view so we can:\n  // a) on remove, get to the HTMLElement from the WidgetFrameView\n  // b) on resize, get to the WidgetFrameView from the HTMLElement\n\n  frameView.gridsterHook = el[0];\n  $(el[0]).data('spotWidgetFrameView', frameView); // try to initialize and render possibly present data\n  // only follow editModeHint when the widget is configured, default to true\n\n  var chartView = frameView.widget;\n  chartView.model.updateConfiguration();\n\n  if (chartView.model.isConfigured) {\n    if (!filter.isInitialized) {\n      filter.initDataFilter();\n    }\n\n    if (!chartView.isInitialized) {\n      chartView.initChart();\n    }\n\n    chartView.update();\n    frameView.editMode = editModeHint;\n  } else {\n    // widget is not configured, ignore editModeHint\n    // and always go to edit mode\n    frameView.editMode = true;\n  }\n\n  filter.on('newData', function () {\n    chartView.update();\n  });\n}\n\nmodule.exports = PageView.extend({\n  template: templates.analyze.page,\n  session: {\n    fullscreenMode: ['boolean', true, true]\n  },\n  initialize: function initialize() {\n    this.pageName = 'analyze';\n    this.fullscreenMode = app.fullscreenMode; // this.helpTemplate = templates.help.analyze;\n\n    this.helpSteps = AnalyzeHelp.steps;\n    this.helpHints = AnalyzeHelp.hints; // // show existing dataset list\n    // app.me.datasets.forEach(function (dataset, i) {\n    //   if (dataset.isActive) {\n    //     console.log('dataset: ', dataset);\n    //     dataset.facets.forEach(function (facet, j) {\n    //       console.log('facet: ', facet);\n    //     });\n    //   }\n    // });\n\n    app.on('refresh', function () {\n      _initializeCharts(this);\n\n      app.me.dataview.getData();\n    }, this);\n    this.once('remove', function () {\n      // remove callbacks for 'app#refresh'\n      app.off('refresh'); // remove callbacks for 'filter#newData'\n\n      app.me.dataview.filters.forEach(function (filter) {\n        filter.off('newData');\n      });\n    });\n\n    if (app.me.dataview.datasetIds.length === 0) {\n      app.message({\n        text: 'No data to analyze, please upload and/or select some datasets',\n        type: 'ok'\n      });\n    }\n  },\n  derived: {\n    dataString: {\n      deps: ['model.dataTotal', 'model.dataSelected'],\n      fn: function fn() {\n        var percentage;\n\n        if (this.model.dataTotal > 0) {\n          percentage = 100.0 * this.model.dataSelected / this.model.dataTotal;\n        } else {\n          percentage = 0;\n        }\n\n        return this.model.dataTotal + ' total, ' + this.model.dataSelected + ' selected (' + percentage.toPrecision(3) + '%)';\n      }\n    }\n  },\n  bindings: {\n    'fullscreenMode': [{\n      type: 'toggle',\n      hook: 'chart-bar',\n      invert: true\n    }, {\n      type: 'toggle',\n      hook: 'facet-bar',\n      invert: true\n    }],\n    'dataString': {\n      type: 'text',\n      hook: 'data-string'\n    }\n  },\n  events: {\n    'click #viewAll': 'viewAll',\n    'click #fullscreenButton': 'toggleFullscreen',\n    'click #resetFiltersButton': 'resetFilters',\n    'click #saveSessionButton': 'saveSession',\n    'click .widgetIcon': 'addChart'\n  },\n  saveSession: function saveSession() {\n    app.saveCurrentSession();\n  },\n  addChart: function addChart(ev) {\n    // what icon was clicked?\n    var target = ev.target || ev.srcElement;\n    var id = target.id;\n    var filter = this.model.filters.add({\n      chartType: id\n    });\n    addWidgetForFilter(this, filter, true);\n  },\n  toggleFullscreen: function toggleFullscreen() {\n    app.fullscreenMode = !app.fullscreenMode;\n    this.fullscreenMode = app.fullscreenMode;\n  },\n  resetFilters: function resetFilters() {\n    app.me.dataview.pause();\n    app.me.dataview.filters.forEach(function (filter) {\n      // undo drill downs\n      while (filter.zoomHistory.length > 0) {\n        filter.zoomOut();\n      } // and clear possible selection\n\n\n      filter.zoomOut();\n    });\n    app.me.dataview.play();\n    app.me.dataview.getData();\n    app.message({\n      text: 'Reselected all data',\n      type: 'ok'\n    });\n  },\n  viewAll: function viewAll() {\n    this._subviews.forEach(function (v) {\n      if (v._values && v._values.hasOwnProperty('editMode')) {\n        v.editMode = false;\n      }\n    });\n  },\n  render: function render(opts) {\n    this.renderWithTemplate(this);\n    this.renderCollection(this.model.facets, FacetbarItemView, this.queryByHook('facet-bar-items'), {\n      filter: function filter(m) {\n        return m.isActive;\n      }\n    });\n    return this;\n  },\n  renderContent: function renderContent() {\n    var widgetNeedsData = false;\n    var el = document.getElementById('facetBar');\n    this._facetsSortable = sortablejs.create(el, {\n      draggable: '.mdl-chip',\n      dataIdAttr: 'data-id',\n      sort: false,\n      group: {\n        name: 'facets',\n        pull: 'clone',\n        put: false\n      },\n      onStart: function onStart(evt) {\n        var item = evt.item;\n        var facetId = item.getAttribute('data-id');\n        var facet = app.me.dataview.facets.get(facetId);\n        app.trigger('dragStart', facet.type);\n      },\n      onEnd: function onEnd(evt) {\n        app.trigger('dragEnd');\n      },\n      onAdd: function onAdd(evt) {\n        var item = evt.item;\n        item.remove();\n      }\n    });\n    this._widgetsGridster = $('[id~=widgets]').gridster({\n      widget_base_dimensions: [100, 100],\n      min_cols: 1,\n      max_cols: 20,\n      avoid_overlapped_widgets: false,\n      widget_selector: 'div',\n      draggable: {\n        enabled: true,\n        handle: '.widgetDragBar',\n        stop: function stop() {\n          var widgets = this.$widgets;\n          var i = 0;\n\n          for (i = 0; i < widgets.length; i++) {\n            // $.each\n            var widget = widgets[i];\n            var data = $(widget).data();\n            var filter = data['spotWidgetFrameView'].model.filter;\n            var grid = data['coords'].grid;\n            filter.row = grid.row;\n            filter.col = grid.col;\n            filter.size_x = grid.size_x;\n            filter.size_y = grid.size_y;\n          }\n        }\n      },\n      resize: {\n        enabled: true,\n        start: function start(e, ui, widget) {\n          var view = widget.data('spotWidgetFrameView')._subviews[0];\n\n          view.deinitChart();\n        },\n        stop: function stop(e, ui, widget) {\n          var view = widget.data('spotWidgetFrameView')._subviews[0];\n\n          var filter = view.model.filter;\n\n          if (view.isInitialized) {\n            view.update();\n          } // keep track of the position of the chart\n\n\n          var info = widget.data('coords').grid;\n          filter.row = info.row;\n          filter.col = info.col;\n          filter.size_x = info.size_x;\n          filter.size_y = info.size_y;\n\n          if (view.model.isConfigured) {\n            view.initChart();\n          }\n\n          if (view.isInitialized) {\n            view.update();\n          }\n        }\n      }\n    }).data('gridster');\n    this.on('remove', function () {\n      this._facetsSortable.destroy();\n\n      this._widgetsGridster.destroy();\n    }); // pause dataset to prevent needless data updates\n\n    this.model.pause(); // add widgets for each filter to the page\n\n    this.model.filters.forEach(function (filter) {\n      addWidgetForFilter(this, filter, false);\n\n      if (!filter.data || filter.data.length === 0) {\n        widgetNeedsData = true;\n      }\n    }, this); // done, unpause the dataset\n\n    this.model.play();\n\n    if (widgetNeedsData) {\n      app.me.dataview.getData();\n    } // do a last pass to render data\n\n\n    _updateCharts(this);\n  },\n  initializeCharts: function initializeCharts() {\n    _initializeCharts(this);\n  },\n  deinitializeCharts: function deinitializeCharts() {\n    _deinitializeCharts(this);\n  },\n  updateCharts: function updateCharts() {\n    _updateCharts(this);\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"22e9.js","sources":["webpack:///./src/pages/analyze.js?25a3"],"sourcesContent":["var app = require('ampersand-app');\nvar $ = require('jquery');\nvar PageView = require('./base');\nvar templates = require('../templates');\nvar WidgetFrameView = require('./analyze/widget-frame');\nvar FacetbarItemView = require('./analyze/facetbar-item');\nvar sortablejs = require('sortablejs');\n\nvar AnalyzeHelp = require('./help/analyze');\n\n// NOTE: gridster does not work properly with require()\n// workaround via browserify-shim (configured in package.json)\nrequire('gridster');\n\nfunction initializeCharts (view) {\n  var gridster = view._widgetsGridster;\n\n  // BUGFIX: can sometimes get called before gridster is fully initialized\n  if (!gridster) {\n    return;\n  }\n\n  var i;\n  for (i = 0; i < gridster.$widgets.length; i++) {\n    var chartView = $(gridster.$widgets[i]).data('spotWidgetFrameView')._subviews[0];\n    chartView.model.updateConfiguration();\n\n    if (chartView.model.isConfigured) {\n      if (!chartView.model.filter.isInitialized) {\n        if (chartView.isInitialized) {\n          chartView.deinitChart(); // deininit charts that had a filter released\n        }\n        chartView.model.filter.initDataFilter();\n      }\n      if (chartView.isInitialized) {\n        // noop\n      } else {\n        chartView.initChart();\n      }\n    } else {\n      if (chartView.isInitialized) {\n        chartView.deinitChart();\n      }\n      if (chartView.model.filter.isInitialized) {\n        chartView.model.filter.releaseDataFilter();\n      }\n    }\n  }\n}\n\nfunction deinitializeCharts (view) {\n  var gridster = view._widgetsGridster;\n\n  var i;\n  for (i = 0; i < gridster.$widgets.length; i++) {\n    var chartView = $(gridster.$widgets[i]).data('spotWidgetFrameView')._subviews[0];\n    if (chartView.isInitialized) {\n      chartView.deinitChart();\n    }\n    if (chartView.model.isConfigured) {\n      chartView.model.filter.releaseDataFilter();\n    }\n  }\n}\n\nfunction updateCharts (view) {\n  var gridster = view._widgetsGridster;\n\n  var i;\n  for (i = 0; i < gridster.$widgets.length; i++) {\n    var chartView = $(gridster.$widgets[i]).data('spotWidgetFrameView')._subviews[0];\n    if (chartView.isInitialized) {\n      chartView.update();\n    }\n  }\n}\n/**\n * Add a widget to the analyze page for the given filter\n *\n * view {View}             Ampersand View instance of the analyze page\n * filter {Filter}         Spot filter instance to create the widget for\n * editModeHint {boolean}  Try to start plot in editMode (ie. accepts dnd of facets) [true] or in interaction mode (false)\n */\nfunction addWidgetForFilter (view, filter, editModeHint) {\n  var gridster = view._widgetsGridster;\n  var row = filter.row || 1;\n  var col = filter.col || 1;\n  var sizeX = filter.size_x || 3;\n  var sizeY = filter.size_y || 3;\n\n  var el = gridster.add_widget('<div class=\"widgetOuterFrame\"></div>', sizeX, sizeY, col, row);\n  var frameView = new WidgetFrameView({\n    model: filter\n  });\n\n  // render, and render content of widget frame\n  view.renderSubview(frameView, el[0]);\n  frameView.renderContent();\n\n  // link element and view so we can:\n  // a) on remove, get to the HTMLElement from the WidgetFrameView\n  // b) on resize, get to the WidgetFrameView from the HTMLElement\n  frameView.gridsterHook = el[0];\n  $(el[0]).data('spotWidgetFrameView', frameView);\n\n  // try to initialize and render possibly present data\n  // only follow editModeHint when the widget is configured, default to true\n  var chartView = frameView.widget;\n  chartView.model.updateConfiguration();\n  if (chartView.model.isConfigured) {\n    if (!filter.isInitialized) {\n      filter.initDataFilter();\n    }\n    if (!chartView.isInitialized) {\n      chartView.initChart();\n    }\n    chartView.update();\n\n    frameView.editMode = editModeHint;\n  } else {\n    // widget is not configured, ignore editModeHint\n    // and always go to edit mode\n    frameView.editMode = true;\n  }\n\n  filter.on('newData', function () {\n    chartView.update();\n  });\n}\n\nmodule.exports = PageView.extend({\n  template: templates.analyze.page,\n  session: {\n    fullscreenMode: ['boolean', true, true]\n  },\n  initialize: function () {\n    this.pageName = 'analyze';\n    this.fullscreenMode = app.fullscreenMode;\n    // this.helpTemplate = templates.help.analyze;\n    this.helpSteps = AnalyzeHelp.steps;\n    this.helpHints = AnalyzeHelp.hints;\n\n\n\n\n    // // show existing dataset list\n    // app.me.datasets.forEach(function (dataset, i) {\n    //   if (dataset.isActive) {\n    //     console.log('dataset: ', dataset);\n    //     dataset.facets.forEach(function (facet, j) {\n    //       console.log('facet: ', facet);\n    //     });\n    //   }\n    // });\n\n\n\n\n    app.on('refresh', function () {\n      initializeCharts(this);\n      app.me.dataview.getData();\n    }, this);\n\n    this.once('remove', function () {\n      // remove callbacks for 'app#refresh'\n      app.off('refresh');\n\n      // remove callbacks for 'filter#newData'\n      app.me.dataview.filters.forEach(function (filter) {\n        filter.off('newData');\n      });\n    });\n\n    if (app.me.dataview.datasetIds.length === 0) {\n      app.message({\n        text: 'No data to analyze, please upload and/or select some datasets',\n        type: 'ok'\n      });\n    }\n  },\n  derived: {\n    dataString: {\n      deps: ['model.dataTotal', 'model.dataSelected'],\n      fn: function () {\n        var percentage;\n        if (this.model.dataTotal > 0) {\n          percentage = 100.0 * this.model.dataSelected / this.model.dataTotal;\n        } else {\n          percentage = 0;\n        }\n        return this.model.dataTotal +\n          ' total, ' +\n          this.model.dataSelected +\n          ' selected (' +\n          percentage.toPrecision(3) +\n          '%)';\n      }\n    }\n  },\n  bindings: {\n    'fullscreenMode': [\n      { type: 'toggle', hook: 'chart-bar', invert: true },\n      { type: 'toggle', hook: 'facet-bar', invert: true }\n    ],\n    'dataString': {\n      type: 'text',\n      hook: 'data-string'\n    }\n  },\n  events: {\n    'click #viewAll': 'viewAll',\n    'click #fullscreenButton': 'toggleFullscreen',\n    'click #resetFiltersButton': 'resetFilters',\n    'click #saveSessionButton': 'saveSession',\n    'click .widgetIcon': 'addChart'\n  },\n  saveSession: function () {\n    app.saveCurrentSession();\n  },\n  addChart: function (ev) {\n    // what icon was clicked?\n    var target = ev.target || ev.srcElement;\n    var id = target.id;\n\n    var filter = this.model.filters.add({ chartType: id });\n    addWidgetForFilter(this, filter, true);\n  },\n  toggleFullscreen: function () {\n    app.fullscreenMode = !app.fullscreenMode;\n    this.fullscreenMode = app.fullscreenMode;\n  },\n  resetFilters: function () {\n    app.me.dataview.pause();\n    app.me.dataview.filters.forEach(function (filter) {\n      // undo drill downs\n      while (filter.zoomHistory.length > 0) {\n        filter.zoomOut();\n      }\n      // and clear possible selection\n      filter.zoomOut();\n    });\n    app.me.dataview.play();\n    app.me.dataview.getData();\n    app.message({\n      text: 'Reselected all data',\n      type: 'ok'\n    });\n  },\n  viewAll: function () {\n    this._subviews.forEach(function (v) {\n      if (v._values && v._values.hasOwnProperty('editMode')) {\n        v.editMode = false;\n      }\n    });\n  },\n  render: function (opts) {\n    this.renderWithTemplate(this);\n\n    this.renderCollection(this.model.facets, FacetbarItemView, this.queryByHook('facet-bar-items'), {\n      filter: function (m) {\n        return m.isActive;\n      }\n    });\n\n    return this;\n  },\n  renderContent: function () {\n    var widgetNeedsData = false;\n\n    var el = document.getElementById('facetBar');\n    this._facetsSortable = sortablejs.create(el, {\n      draggable: '.mdl-chip',\n      dataIdAttr: 'data-id',\n      sort: false,\n      group: {\n        name: 'facets',\n        pull: 'clone',\n        put: false\n      },\n      onStart: function (evt) {\n        var item = evt.item;\n        var facetId = item.getAttribute('data-id');\n        var facet = app.me.dataview.facets.get(facetId);\n        app.trigger('dragStart', facet.type);\n      },\n      onEnd: function (evt) {\n        app.trigger('dragEnd');\n      },\n      onAdd: function (evt) {\n        var item = evt.item;\n        item.remove();\n      }\n    });\n    this._widgetsGridster = $('[id~=widgets]').gridster({\n      widget_base_dimensions: [100, 100],\n      min_cols: 1,\n      max_cols: 20,\n      avoid_overlapped_widgets: false,\n      widget_selector: 'div',\n      draggable: {\n        enabled: true,\n        handle: '.widgetDragBar',\n        stop: function () {\n          var widgets = this.$widgets;\n          var i = 0;\n          for (i = 0; i < widgets.length; i++) { // $.each\n            var widget = widgets[i];\n            var data = $(widget).data();\n            var filter = data['spotWidgetFrameView'].model.filter;\n            var grid = data['coords'].grid;\n\n            filter.row = grid.row;\n            filter.col = grid.col;\n            filter.size_x = grid.size_x;\n            filter.size_y = grid.size_y;\n          }\n        }\n      },\n      resize: {\n        enabled: true,\n        start: function (e, ui, widget) {\n          var view = widget.data('spotWidgetFrameView')._subviews[0];\n          view.deinitChart();\n        },\n        stop: function (e, ui, widget) {\n          var view = widget.data('spotWidgetFrameView')._subviews[0];\n          var filter = view.model.filter;\n          if (view.isInitialized) {\n            view.update();\n          }\n\n          // keep track of the position of the chart\n          var info = widget.data('coords').grid;\n          filter.row = info.row;\n          filter.col = info.col;\n          filter.size_x = info.size_x;\n          filter.size_y = info.size_y;\n          if (view.model.isConfigured) {\n            view.initChart();\n          }\n          if (view.isInitialized) {\n            view.update();\n          }\n        }\n      }\n    }).data('gridster');\n\n    this.on('remove', function () {\n      this._facetsSortable.destroy();\n      this._widgetsGridster.destroy();\n    });\n\n    // pause dataset to prevent needless data updates\n    this.model.pause();\n\n    // add widgets for each filter to the page\n    this.model.filters.forEach(function (filter) {\n      addWidgetForFilter(this, filter, false);\n\n      if (!filter.data || filter.data.length === 0) {\n        widgetNeedsData = true;\n      }\n    }, this);\n\n    // done, unpause the dataset\n    this.model.play();\n\n    if (widgetNeedsData) {\n      app.me.dataview.getData();\n    }\n\n    // do a last pass to render data\n    updateCharts(this);\n  },\n  initializeCharts: function () {\n    initializeCharts(this);\n  },\n  deinitializeCharts: function () {\n    deinitializeCharts(this);\n  },\n  updateCharts: function () {\n    updateCharts(this);\n  }\n});\n"],"mappings":"AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AAGA;AACA;AACA;AADA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AADA;AACA;AAIA;AACA;AAGA;AACA;AACA;AAAA;AACA;AAGA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AACA;AACA;AACA;AACA;AACA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAMA;AAfA;AADA;AAmBA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AAFA;AALA;AAUA;AACA;AACA;AACA;AACA;AACA;AALA;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAHA;AAMA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AArBA;AAuBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAjBA;AAmBA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAzBA;AAzBA;AAsDA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA5PA","sourceRoot":""}\n//# sourceURL=webpack-internal:///22e9\n")},2413:function(module,exports,__webpack_require__){eval("/**\n * @classdesc pie chart class\n * @class PieChart\n * @augments BaseChart\n */\nvar BaseChart = __webpack_require__(/*! ./base-chart */ \"6339\");\n\nmodule.exports = BaseChart.extend({\n  initialize: function initialize() {\n    this.slots.reset([{\n      description: 'Group by',\n      type: 'partition',\n      rank: 1,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Pie size',\n      type: 'aggregate',\n      rank: 1,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }]);\n  },\n  chartjsConfig: function chartjsConfig() {\n    return {\n      type: 'pie',\n      data: {\n        datasets: [],\n        labels: []\n      },\n      options: {\n        title: {\n          display: true,\n          position: 'top'\n        },\n        tooltips: {}\n      }\n    };\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjQxMy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9waWVjaGFydC5qcz9mMzE5Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGNsYXNzZGVzYyBwaWUgY2hhcnQgY2xhc3NcbiAqIEBjbGFzcyBQaWVDaGFydFxuICogQGF1Z21lbnRzIEJhc2VDaGFydFxuICovXG5cbnZhciBCYXNlQ2hhcnQgPSByZXF1aXJlKCcuL2Jhc2UtY2hhcnQnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBCYXNlQ2hhcnQuZXh0ZW5kKHtcbiAgaW5pdGlhbGl6ZTogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMuc2xvdHMucmVzZXQoW1xuICAgICAge1xuICAgICAgICBkZXNjcmlwdGlvbjogJ0dyb3VwIGJ5JyxcbiAgICAgICAgdHlwZTogJ3BhcnRpdGlvbicsXG4gICAgICAgIHJhbms6IDEsXG4gICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY2F0ZWdvcmlhbCcsICdkYXRldGltZScsICdkdXJhdGlvbicsICdjb250aW51b3VzJywgJ3RleHQnXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdQaWUgc2l6ZScsXG4gICAgICAgIHR5cGU6ICdhZ2dyZWdhdGUnLFxuICAgICAgICByYW5rOiAxLFxuICAgICAgICByZXF1aXJlZDogZmFsc2UsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjb250aW51b3VzJywgJ2R1cmF0aW9uJ11cbiAgICAgIH1cbiAgICBdKTtcbiAgfSxcbiAgY2hhcnRqc0NvbmZpZzogZnVuY3Rpb24gKCkge1xuICAgIHJldHVybiB7XG4gICAgICB0eXBlOiAncGllJyxcbiAgICAgIGRhdGE6IHtcbiAgICAgICAgZGF0YXNldHM6IFtdLFxuICAgICAgICBsYWJlbHM6IFtdXG4gICAgICB9LFxuICAgICAgb3B0aW9uczoge1xuICAgICAgICB0aXRsZToge1xuICAgICAgICAgIGRpc3BsYXk6IHRydWUsXG4gICAgICAgICAgcG9zaXRpb246ICd0b3AnXG4gICAgICAgIH0sXG4gICAgICAgIHRvb2x0aXBzOiB7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9O1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFMQTtBQU5BO0FBZUE7QUFuQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///2413\n")},"26ef":function(module,exports,__webpack_require__){eval("/**\n * Base Widget\n *\n * Base class to hold widget interaction. Extend and override properties for each chart.\n * @class BaseWidget\n */\nvar AmpersandView = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nmodule.exports = AmpersandView.extend({\n  props: {\n    /**\n     * Boolean indicating if a chart has been added to the DOM\n     */\n    isInitialized: {\n      type: 'boolean',\n      required: true,\n      default: false\n    }\n  },\n\n  /**\n   * Initialize the chart and add it to the DOM\n   * Override for your specific widget.\n   */\n  initChart: function initChart() {\n    console.error('Can not call virtual method');\n  },\n\n  /**\n   * Update the widget\n   * Override for your specific widget.\n   */\n  update: function update() {\n    console.error('Can not call virtual method');\n  },\n\n  /**\n   * Remove the widget from the DOM and free any associated data\n   * Override for your specific widget.\n   */\n  deinitChart: function deinitChart() {\n    console.error('Can not call virtual method');\n  },\n  renderContent: function renderContent() {}\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjZlZi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL3ZpZXdzL2Jhc2Utd2lkZ2V0LmpzPzc2OGQiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBCYXNlIFdpZGdldFxuICpcbiAqIEJhc2UgY2xhc3MgdG8gaG9sZCB3aWRnZXQgaW50ZXJhY3Rpb24uIEV4dGVuZCBhbmQgb3ZlcnJpZGUgcHJvcGVydGllcyBmb3IgZWFjaCBjaGFydC5cbiAqIEBjbGFzcyBCYXNlV2lkZ2V0XG4gKi9cbnZhciBBbXBlcnNhbmRWaWV3ID0gcmVxdWlyZSgnYW1wZXJzYW5kLXZpZXcnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBBbXBlcnNhbmRWaWV3LmV4dGVuZCh7XG4gIHByb3BzOiB7XG4gICAgLyoqXG4gICAgICogQm9vbGVhbiBpbmRpY2F0aW5nIGlmIGEgY2hhcnQgaGFzIGJlZW4gYWRkZWQgdG8gdGhlIERPTVxuICAgICAqL1xuICAgIGlzSW5pdGlhbGl6ZWQ6IHtcbiAgICAgIHR5cGU6ICdib29sZWFuJyxcbiAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgZGVmYXVsdDogZmFsc2VcbiAgICB9XG4gIH0sXG5cbiAgLyoqXG4gICAqIEluaXRpYWxpemUgdGhlIGNoYXJ0IGFuZCBhZGQgaXQgdG8gdGhlIERPTVxuICAgKiBPdmVycmlkZSBmb3IgeW91ciBzcGVjaWZpYyB3aWRnZXQuXG4gICAqL1xuICBpbml0Q2hhcnQ6IGZ1bmN0aW9uICgpIHtcbiAgICBjb25zb2xlLmVycm9yKCdDYW4gbm90IGNhbGwgdmlydHVhbCBtZXRob2QnKTtcbiAgfSxcblxuICAvKipcbiAgICogVXBkYXRlIHRoZSB3aWRnZXRcbiAgICogT3ZlcnJpZGUgZm9yIHlvdXIgc3BlY2lmaWMgd2lkZ2V0LlxuICAgKi9cbiAgdXBkYXRlOiBmdW5jdGlvbiAoKSB7XG4gICAgY29uc29sZS5lcnJvcignQ2FuIG5vdCBjYWxsIHZpcnR1YWwgbWV0aG9kJyk7XG4gIH0sXG5cbiAgLyoqXG4gICAqIFJlbW92ZSB0aGUgd2lkZ2V0IGZyb20gdGhlIERPTSBhbmQgZnJlZSBhbnkgYXNzb2NpYXRlZCBkYXRhXG4gICAqIE92ZXJyaWRlIGZvciB5b3VyIHNwZWNpZmljIHdpZGdldC5cbiAgICovXG4gIGRlaW5pdENoYXJ0OiBmdW5jdGlvbiAoKSB7XG4gICAgY29uc29sZS5lcnJvcignQ2FuIG5vdCBjYWxsIHZpcnR1YWwgbWV0aG9kJyk7XG4gIH0sXG5cbiAgcmVuZGVyQ29udGVudDogZnVuY3Rpb24gKCkge1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFKQTtBQUNBO0FBVUE7Ozs7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7O0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7OztBQUlBO0FBQ0E7QUFDQTtBQUVBO0FBcENBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///26ef\n")},2960:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar TimeZonesSelect = __webpack_require__(/*! ./time-zones-select */ \"f3d5\");\n\nvar DurationUnitsSelect = __webpack_require__(/*! ./duration-units-select */ \"4916\");\n\nmodule.exports = View.extend({\n  template: templates.configureFacet.facetTransformDuration,\n  bindings: {\n    'model.transformedReference': {\n      type: 'value',\n      hook: 'transform-duration-transformedreference-input'\n    }\n  },\n  events: {\n    'change [data-hook~=transform-duration-transformedreference-input]': function changeDataHookTransformDurationTransformedreferenceInput() {\n      this.model.transformedReference = this.queryByHook('transform-duration-transformedreference-input').value;\n    }\n  },\n  subviews: {\n    durationUnits: {\n      hook: 'duration-units',\n      prepareView: function prepareView(el) {\n        return new DurationUnitsSelect({\n          el: el,\n          field: 'units',\n          model: this.model\n        });\n      }\n    },\n    transformedDurationUnits: {\n      hook: 'transformed-duration-units',\n      prepareView: function prepareView(el) {\n        return new DurationUnitsSelect({\n          el: el,\n          field: 'transformedUnits',\n          model: this.model\n        });\n      }\n    },\n    timeZones: {\n      hook: 'transformed-duration-zone',\n      prepareView: function prepareView(el) {\n        return new TimeZonesSelect({\n          el: el,\n          field: 'transformedZone',\n          model: this.model\n        });\n      }\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMjk2MC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQvZmFjZXQtdHJhbnNmb3JtLWR1cmF0aW9uLmpzPzQyMGYiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xudmFyIFRpbWVab25lc1NlbGVjdCA9IHJlcXVpcmUoJy4vdGltZS16b25lcy1zZWxlY3QnKTtcbnZhciBEdXJhdGlvblVuaXRzU2VsZWN0ID0gcmVxdWlyZSgnLi9kdXJhdGlvbi11bml0cy1zZWxlY3QnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuY29uZmlndXJlRmFjZXQuZmFjZXRUcmFuc2Zvcm1EdXJhdGlvbixcbiAgYmluZGluZ3M6IHtcbiAgICAnbW9kZWwudHJhbnNmb3JtZWRSZWZlcmVuY2UnOiB7XG4gICAgICB0eXBlOiAndmFsdWUnLFxuICAgICAgaG9vazogJ3RyYW5zZm9ybS1kdXJhdGlvbi10cmFuc2Zvcm1lZHJlZmVyZW5jZS1pbnB1dCdcbiAgICB9XG4gIH0sXG4gIGV2ZW50czoge1xuICAgICdjaGFuZ2UgW2RhdGEtaG9va349dHJhbnNmb3JtLWR1cmF0aW9uLXRyYW5zZm9ybWVkcmVmZXJlbmNlLWlucHV0XSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMubW9kZWwudHJhbnNmb3JtZWRSZWZlcmVuY2UgPSB0aGlzLnF1ZXJ5QnlIb29rKCd0cmFuc2Zvcm0tZHVyYXRpb24tdHJhbnNmb3JtZWRyZWZlcmVuY2UtaW5wdXQnKS52YWx1ZTtcbiAgICB9XG4gIH0sXG4gIHN1YnZpZXdzOiB7XG4gICAgZHVyYXRpb25Vbml0czoge1xuICAgICAgaG9vazogJ2R1cmF0aW9uLXVuaXRzJyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBEdXJhdGlvblVuaXRzU2VsZWN0KHtcbiAgICAgICAgICBlbDogZWwsXG4gICAgICAgICAgZmllbGQ6ICd1bml0cycsXG4gICAgICAgICAgbW9kZWw6IHRoaXMubW9kZWxcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgICB0cmFuc2Zvcm1lZER1cmF0aW9uVW5pdHM6IHtcbiAgICAgIGhvb2s6ICd0cmFuc2Zvcm1lZC1kdXJhdGlvbi11bml0cycsXG4gICAgICBwcmVwYXJlVmlldzogZnVuY3Rpb24gKGVsKSB7XG4gICAgICAgIHJldHVybiBuZXcgRHVyYXRpb25Vbml0c1NlbGVjdCh7XG4gICAgICAgICAgZWw6IGVsLFxuICAgICAgICAgIGZpZWxkOiAndHJhbnNmb3JtZWRVbml0cycsXG4gICAgICAgICAgbW9kZWw6IHRoaXMubW9kZWxcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgICB0aW1lWm9uZXM6IHtcbiAgICAgIGhvb2s6ICd0cmFuc2Zvcm1lZC1kdXJhdGlvbi16b25lJyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBUaW1lWm9uZXNTZWxlY3Qoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBmaWVsZDogJ3RyYW5zZm9ybWVkWm9uZScsXG4gICAgICAgICAgbW9kZWw6IHRoaXMubW9kZWxcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfVxuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBREE7QUFNQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBS0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBS0E7QUFSQTtBQVVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFLQTtBQVJBO0FBVUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUtBO0FBUkE7QUFyQkE7QUFiQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///2960\n")},"2b41":function(module,exports,__webpack_require__){eval("var colors = __webpack_require__(/*! ../../colors */ \"eb63\");\n/**\n * Get the index in chartjs datastructures from the group value\n * with proper fallbacks\n * @params {Partition} partition (optional)\n * @params {Object} value value\n * @returns {number|null} index\n */\n\n\nfunction partitionValueToIndex(partition, value) {\n  var group;\n\n  if (!partition) {\n    // no(sub)partitioning return first element\n    return 0;\n  } // with (sub)partitioning\n\n\n  group = partition.groups.get(value, 'value');\n\n  if (group) {\n    // string in partition\n    return group.groupIndex;\n  } else {\n    // string not in partition\n    return -1;\n  }\n}\n/**\n * prepare data structure, reuse as much of the previous data arrays as possible\n * to prevent massive animations on every update\n * @params{ChartJSData} chartData ChartJS data structure\n * @params{Partition} partitionA X-axis\n * @params{Partition} partitionB Y-axis\n * @params{Object} options Options: perItem, multiDimensional, doubleDatasets\n */\n\n\nfunction resizeChartjsData(chartData, partitionA, partitionB, options) {\n  var x = partitionA ? partitionA.groups.length : 1;\n  var y = partitionB ? partitionB.groups.length : 1;\n  options = options || {};\n  var perItem = options.perItem || false;\n  var multiDimensional = options.multiDimensional || false;\n  var doubleDatasets = options.doubleDatasets || false;\n  var totalDatasets = doubleDatasets ? 2 * y : y;\n  var i;\n  var j;\n  var cut; // match the number of labels needed\n\n  cut = chartData.labels.length - x;\n\n  if (cut > 0) {\n    chartData.labels.splice(0, cut);\n  } // labels on the primary axis\n\n\n  for (i = 0; i < x; i++) {\n    chartData.labels[i] = partitionA.groups.models[i].label;\n  } // match the number of datasets needed\n\n\n  cut = chartData.datasets.length - totalDatasets;\n\n  if (cut > 0) {\n    // BUGFIX: weird behavious for linechart selections and plots\n    // when we remove datasets from the front, everything shifts one place to the 'left',\n    // which will cause issues for linecharts where we use an extra dataset at the back for selections.\n    //\n    // Solution: remove from the back\n    chartData.datasets.splice(chartData.datasets.length, cut);\n  }\n\n  for (j = 0; j < totalDatasets; j++) {\n    // update or assign data structure:\n    chartData.datasets[j] = chartData.datasets[j] || {\n      data: [],\n      error: []\n    }; // match the existing number of groups to the updated number of groups\n\n    cut = chartData.datasets[j].data.length - x;\n\n    if (cut > 0) {\n      chartData.datasets[j].data.splice(0, cut);\n    }\n\n    cut = chartData.datasets[j].error.length - x;\n\n    if (cut > 0) {\n      chartData.datasets[j].error.splice(0, cut);\n    } // clear out old data / pre-allocate new data\n\n\n    for (i = 0; i < x; i++) {\n      if (multiDimensional) {\n        chartData.datasets[j].data[i] = {};\n        chartData.datasets[j].error[i] = {};\n      } else {\n        chartData.datasets[j].data[i] = 0;\n        chartData.datasets[j].error[i] = 0;\n      }\n    }\n  } // set metadata for main datasets\n\n\n  for (j = 0; j < y; j++) {\n    // set dataset color\n    if (perItem) {\n      chartData.datasets[j].backgroundColor = [];\n      chartData.datasets[j].borderColor = [];\n\n      for (i = 0; i < x; i++) {\n        chartData.datasets[j].backgroundColor[i] = colors.getColor(0).css(); // chartData.datasets[j].borderColor[i] = colors.getColor(0).css();\n      }\n    } else {\n      chartData.datasets[j].backgroundColor = colors.getColor(j).css();\n      chartData.datasets[j].borderColor = colors.getColor(j).css();\n      chartData.datasets[j].fill = false;\n    } // add a legend entry\n\n\n    if (partitionB) {\n      chartData.datasets[j].label = partitionB.groups.models[j].label;\n    }\n  }\n\n  if (!doubleDatasets) {\n    return;\n  } // set metadata for doubled datasets\n\n\n  for (j = y; j < 2 * y; j++) {\n    chartData.datasets[j].borderDash = [15, 5]; // striped lines\n\n    chartData.datasets[j].borderWidth = 1; // thin lines\n\n    chartData.datasets[j].pointRadius = 0; // no points\n\n    chartData.datasets[j].fill = false; // set dataset color\n\n    if (perItem) {\n      chartData.datasets[j].backgroundColor = [];\n      chartData.datasets[j].borderColor = [];\n\n      for (i = 0; i < x; i++) {\n        chartData.datasets[j].backgroundColor[i] = colors.getColor(0).css(); // chartData.datasets[j].borderColor[i] = colors.getColor(0).css();\n      }\n    } else {\n      chartData.datasets[j].backgroundColor = colors.getColor(j - y).css();\n      chartData.datasets[j].borderColor = colors.getColor(j - y).css();\n    } // add a legend entry\n\n\n    if (partitionB) {\n      chartData.datasets[j].label = partitionB.groups.models[j - y].label;\n    }\n  }\n}\n\nmodule.exports = {\n  partitionValueToIndex: partitionValueToIndex,\n  resizeChartjsData: resizeChartjsData\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMmI0MS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL3ZpZXdzL3V0aWwuanM/YmRjOCJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgY29sb3JzID0gcmVxdWlyZSgnLi4vLi4vY29sb3JzJyk7XG5cbi8qKlxuICogR2V0IHRoZSBpbmRleCBpbiBjaGFydGpzIGRhdGFzdHJ1Y3R1cmVzIGZyb20gdGhlIGdyb3VwIHZhbHVlXG4gKiB3aXRoIHByb3BlciBmYWxsYmFja3NcbiAqIEBwYXJhbXMge1BhcnRpdGlvbn0gcGFydGl0aW9uIChvcHRpb25hbClcbiAqIEBwYXJhbXMge09iamVjdH0gdmFsdWUgdmFsdWVcbiAqIEByZXR1cm5zIHtudW1iZXJ8bnVsbH0gaW5kZXhcbiAqL1xuZnVuY3Rpb24gcGFydGl0aW9uVmFsdWVUb0luZGV4IChwYXJ0aXRpb24sIHZhbHVlKSB7XG4gIHZhciBncm91cDtcblxuICBpZiAoIXBhcnRpdGlvbikge1xuICAgIC8vIG5vKHN1YilwYXJ0aXRpb25pbmcgcmV0dXJuIGZpcnN0IGVsZW1lbnRcbiAgICByZXR1cm4gMDtcbiAgfVxuXG4gIC8vIHdpdGggKHN1YilwYXJ0aXRpb25pbmdcbiAgZ3JvdXAgPSBwYXJ0aXRpb24uZ3JvdXBzLmdldCh2YWx1ZSwgJ3ZhbHVlJyk7XG5cbiAgaWYgKGdyb3VwKSB7XG4gICAgLy8gc3RyaW5nIGluIHBhcnRpdGlvblxuICAgIHJldHVybiBncm91cC5ncm91cEluZGV4O1xuICB9IGVsc2Uge1xuICAgIC8vIHN0cmluZyBub3QgaW4gcGFydGl0aW9uXG4gICAgcmV0dXJuIC0xO1xuICB9XG59XG5cbi8qKlxuICogcHJlcGFyZSBkYXRhIHN0cnVjdHVyZSwgcmV1c2UgYXMgbXVjaCBvZiB0aGUgcHJldmlvdXMgZGF0YSBhcnJheXMgYXMgcG9zc2libGVcbiAqIHRvIHByZXZlbnQgbWFzc2l2ZSBhbmltYXRpb25zIG9uIGV2ZXJ5IHVwZGF0ZVxuICogQHBhcmFtc3tDaGFydEpTRGF0YX0gY2hhcnREYXRhIENoYXJ0SlMgZGF0YSBzdHJ1Y3R1cmVcbiAqIEBwYXJhbXN7UGFydGl0aW9ufSBwYXJ0aXRpb25BIFgtYXhpc1xuICogQHBhcmFtc3tQYXJ0aXRpb259IHBhcnRpdGlvbkIgWS1heGlzXG4gKiBAcGFyYW1ze09iamVjdH0gb3B0aW9ucyBPcHRpb25zOiBwZXJJdGVtLCBtdWx0aURpbWVuc2lvbmFsLCBkb3VibGVEYXRhc2V0c1xuICovXG5mdW5jdGlvbiByZXNpemVDaGFydGpzRGF0YSAoY2hhcnREYXRhLCBwYXJ0aXRpb25BLCBwYXJ0aXRpb25CLCBvcHRpb25zKSB7XG4gIHZhciB4ID0gcGFydGl0aW9uQSA/IHBhcnRpdGlvbkEuZ3JvdXBzLmxlbmd0aCA6IDE7XG4gIHZhciB5ID0gcGFydGl0aW9uQiA/IHBhcnRpdGlvbkIuZ3JvdXBzLmxlbmd0aCA6IDE7XG5cbiAgb3B0aW9ucyA9IG9wdGlvbnMgfHwge307XG4gIHZhciBwZXJJdGVtID0gb3B0aW9ucy5wZXJJdGVtIHx8IGZhbHNlO1xuICB2YXIgbXVsdGlEaW1lbnNpb25hbCA9IG9wdGlvbnMubXVsdGlEaW1lbnNpb25hbCB8fCBmYWxzZTtcbiAgdmFyIGRvdWJsZURhdGFzZXRzID0gb3B0aW9ucy5kb3VibGVEYXRhc2V0cyB8fCBmYWxzZTtcblxuICB2YXIgdG90YWxEYXRhc2V0cyA9IGRvdWJsZURhdGFzZXRzID8gMiAqIHkgOiB5O1xuXG4gIHZhciBpO1xuICB2YXIgajtcbiAgdmFyIGN1dDtcblxuICAvLyBtYXRjaCB0aGUgbnVtYmVyIG9mIGxhYmVscyBuZWVkZWRcbiAgY3V0ID0gY2hhcnREYXRhLmxhYmVscy5sZW5ndGggLSB4O1xuICBpZiAoY3V0ID4gMCkge1xuICAgIGNoYXJ0RGF0YS5sYWJlbHMuc3BsaWNlKDAsIGN1dCk7XG4gIH1cblxuICAvLyBsYWJlbHMgb24gdGhlIHByaW1hcnkgYXhpc1xuICBmb3IgKGkgPSAwOyBpIDwgeDsgaSsrKSB7XG4gICAgY2hhcnREYXRhLmxhYmVsc1tpXSA9IHBhcnRpdGlvbkEuZ3JvdXBzLm1vZGVsc1tpXS5sYWJlbDtcbiAgfVxuXG4gIC8vIG1hdGNoIHRoZSBudW1iZXIgb2YgZGF0YXNldHMgbmVlZGVkXG4gIGN1dCA9IGNoYXJ0RGF0YS5kYXRhc2V0cy5sZW5ndGggLSB0b3RhbERhdGFzZXRzO1xuICBpZiAoY3V0ID4gMCkge1xuICAgIC8vIEJVR0ZJWDogd2VpcmQgYmVoYXZpb3VzIGZvciBsaW5lY2hhcnQgc2VsZWN0aW9ucyBhbmQgcGxvdHNcbiAgICAvLyB3aGVuIHdlIHJlbW92ZSBkYXRhc2V0cyBmcm9tIHRoZSBmcm9udCwgZXZlcnl0aGluZyBzaGlmdHMgb25lIHBsYWNlIHRvIHRoZSAnbGVmdCcsXG4gICAgLy8gd2hpY2ggd2lsbCBjYXVzZSBpc3N1ZXMgZm9yIGxpbmVjaGFydHMgd2hlcmUgd2UgdXNlIGFuIGV4dHJhIGRhdGFzZXQgYXQgdGhlIGJhY2sgZm9yIHNlbGVjdGlvbnMuXG4gICAgLy9cbiAgICAvLyBTb2x1dGlvbjogcmVtb3ZlIGZyb20gdGhlIGJhY2tcbiAgICBjaGFydERhdGEuZGF0YXNldHMuc3BsaWNlKGNoYXJ0RGF0YS5kYXRhc2V0cy5sZW5ndGgsIGN1dCk7XG4gIH1cblxuICBmb3IgKGogPSAwOyBqIDwgdG90YWxEYXRhc2V0czsgaisrKSB7XG4gICAgLy8gdXBkYXRlIG9yIGFzc2lnbiBkYXRhIHN0cnVjdHVyZTpcbiAgICBjaGFydERhdGEuZGF0YXNldHNbal0gPSBjaGFydERhdGEuZGF0YXNldHNbal0gfHwge2RhdGE6IFtdLCBlcnJvcjogW119O1xuXG4gICAgLy8gbWF0Y2ggdGhlIGV4aXN0aW5nIG51bWJlciBvZiBncm91cHMgdG8gdGhlIHVwZGF0ZWQgbnVtYmVyIG9mIGdyb3Vwc1xuICAgIGN1dCA9IGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5kYXRhLmxlbmd0aCAtIHg7XG4gICAgaWYgKGN1dCA+IDApIHtcbiAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5kYXRhLnNwbGljZSgwLCBjdXQpO1xuICAgIH1cbiAgICBjdXQgPSBjaGFydERhdGEuZGF0YXNldHNbal0uZXJyb3IubGVuZ3RoIC0geDtcbiAgICBpZiAoY3V0ID4gMCkge1xuICAgICAgY2hhcnREYXRhLmRhdGFzZXRzW2pdLmVycm9yLnNwbGljZSgwLCBjdXQpO1xuICAgIH1cblxuICAgIC8vIGNsZWFyIG91dCBvbGQgZGF0YSAvIHByZS1hbGxvY2F0ZSBuZXcgZGF0YVxuICAgIGZvciAoaSA9IDA7IGkgPCB4OyBpKyspIHtcbiAgICAgIGlmIChtdWx0aURpbWVuc2lvbmFsKSB7XG4gICAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5kYXRhW2ldID0ge307XG4gICAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5lcnJvcltpXSA9IHt9O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY2hhcnREYXRhLmRhdGFzZXRzW2pdLmRhdGFbaV0gPSAwO1xuICAgICAgICBjaGFydERhdGEuZGF0YXNldHNbal0uZXJyb3JbaV0gPSAwO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIC8vIHNldCBtZXRhZGF0YSBmb3IgbWFpbiBkYXRhc2V0c1xuICBmb3IgKGogPSAwOyBqIDwgeTsgaisrKSB7XG4gICAgLy8gc2V0IGRhdGFzZXQgY29sb3JcbiAgICBpZiAocGVySXRlbSkge1xuICAgICAgY2hhcnREYXRhLmRhdGFzZXRzW2pdLmJhY2tncm91bmRDb2xvciA9IFtdO1xuICAgICAgY2hhcnREYXRhLmRhdGFzZXRzW2pdLmJvcmRlckNvbG9yID0gW107XG4gICAgICBmb3IgKGkgPSAwOyBpIDwgeDsgaSsrKSB7XG4gICAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5iYWNrZ3JvdW5kQ29sb3JbaV0gPSBjb2xvcnMuZ2V0Q29sb3IoMCkuY3NzKCk7XG4gICAgICAgIC8vIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5ib3JkZXJDb2xvcltpXSA9IGNvbG9ycy5nZXRDb2xvcigwKS5jc3MoKTtcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgY2hhcnREYXRhLmRhdGFzZXRzW2pdLmJhY2tncm91bmRDb2xvciA9IGNvbG9ycy5nZXRDb2xvcihqKS5jc3MoKTtcbiAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5ib3JkZXJDb2xvciA9IGNvbG9ycy5nZXRDb2xvcihqKS5jc3MoKTtcbiAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5maWxsID0gZmFsc2U7XG4gICAgfVxuXG4gICAgLy8gYWRkIGEgbGVnZW5kIGVudHJ5XG4gICAgaWYgKHBhcnRpdGlvbkIpIHtcbiAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5sYWJlbCA9IHBhcnRpdGlvbkIuZ3JvdXBzLm1vZGVsc1tqXS5sYWJlbDtcbiAgICB9XG4gIH1cblxuICBpZiAoIWRvdWJsZURhdGFzZXRzKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gc2V0IG1ldGFkYXRhIGZvciBkb3VibGVkIGRhdGFzZXRzXG4gIGZvciAoaiA9IHk7IGogPCAyICogeTsgaisrKSB7XG4gICAgY2hhcnREYXRhLmRhdGFzZXRzW2pdLmJvcmRlckRhc2ggPSBbMTUsIDVdOyAvLyBzdHJpcGVkIGxpbmVzXG4gICAgY2hhcnREYXRhLmRhdGFzZXRzW2pdLmJvcmRlcldpZHRoID0gMTsgLy8gdGhpbiBsaW5lc1xuICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5wb2ludFJhZGl1cyA9IDA7IC8vIG5vIHBvaW50c1xuICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5maWxsID0gZmFsc2U7XG5cbiAgICAvLyBzZXQgZGF0YXNldCBjb2xvclxuICAgIGlmIChwZXJJdGVtKSB7XG4gICAgICBjaGFydERhdGEuZGF0YXNldHNbal0uYmFja2dyb3VuZENvbG9yID0gW107XG4gICAgICBjaGFydERhdGEuZGF0YXNldHNbal0uYm9yZGVyQ29sb3IgPSBbXTtcbiAgICAgIGZvciAoaSA9IDA7IGkgPCB4OyBpKyspIHtcbiAgICAgICAgY2hhcnREYXRhLmRhdGFzZXRzW2pdLmJhY2tncm91bmRDb2xvcltpXSA9IGNvbG9ycy5nZXRDb2xvcigwKS5jc3MoKTtcbiAgICAgICAgLy8gY2hhcnREYXRhLmRhdGFzZXRzW2pdLmJvcmRlckNvbG9yW2ldID0gY29sb3JzLmdldENvbG9yKDApLmNzcygpO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBjaGFydERhdGEuZGF0YXNldHNbal0uYmFja2dyb3VuZENvbG9yID0gY29sb3JzLmdldENvbG9yKGogLSB5KS5jc3MoKTtcbiAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5ib3JkZXJDb2xvciA9IGNvbG9ycy5nZXRDb2xvcihqIC0geSkuY3NzKCk7XG4gICAgfVxuXG4gICAgLy8gYWRkIGEgbGVnZW5kIGVudHJ5XG4gICAgaWYgKHBhcnRpdGlvbkIpIHtcbiAgICAgIGNoYXJ0RGF0YS5kYXRhc2V0c1tqXS5sYWJlbCA9IHBhcnRpdGlvbkIuZ3JvdXBzLm1vZGVsc1tqIC0geV0ubGFiZWw7XG4gICAgfVxuICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICBwYXJ0aXRpb25WYWx1ZVRvSW5kZXg6IHBhcnRpdGlvblZhbHVlVG9JbmRleCxcbiAgcmVzaXplQ2hhcnRqc0RhdGE6IHJlc2l6ZUNoYXJ0anNEYXRhXG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUVBOzs7Ozs7Ozs7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBOzs7Ozs7Ozs7O0FBUUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBRUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///2b41\n")},3:function(module,exports){eval("/* (ignored) *///# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy91dGlsIChpZ25vcmVkKT9iYmZmIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIChpZ25vcmVkKSAqLyJdLCJtYXBwaW5ncyI6IkFBQUEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///3\n")},"37f6":function(module,exports,__webpack_require__){eval("/**\n * @classdesc Scatter Chart class\n * @class ScatterChart\n * @augments BaseChart\n */\nvar BaseChart = __webpack_require__(/*! ./base-chart */ \"6339\");\n\nmodule.exports = BaseChart.extend({\n  initialize: function initialize() {\n    this.slots.reset([{\n      description: 'X axis',\n      type: 'partition',\n      rank: 1,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Y axis',\n      type: 'partition',\n      rank: 2,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Z axis',\n      type: 'partition',\n      rank: 3,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Color by',\n      type: 'aggregate',\n      rank: 1,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }]);\n  },\n  scatterConfig: function scatterConfig() {\n    return {\n      width: '600px',\n      height: '600px',\n      style: 'dot-color',\n      tooltip: true,\n      tooltipStyle: {\n        dot: {\n          border: 'none',\n          borderRadius: '0px'\n        }\n      },\n      showPerspective: true,\n      showGrid: true,\n      showShadow: false,\n      showLegend: false,\n      keepAspectRatio: false,\n      verticalRatio: 1\n    };\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMzdmNi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9zY2F0dGVyLmpzPzc5NjQiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAY2xhc3NkZXNjIFNjYXR0ZXIgQ2hhcnQgY2xhc3NcbiAqIEBjbGFzcyBTY2F0dGVyQ2hhcnRcbiAqIEBhdWdtZW50cyBCYXNlQ2hhcnRcbiAqL1xuXG52YXIgQmFzZUNoYXJ0ID0gcmVxdWlyZSgnLi9iYXNlLWNoYXJ0Jyk7XG5cbm1vZHVsZS5leHBvcnRzID0gQmFzZUNoYXJ0LmV4dGVuZCh7XG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnNsb3RzLnJlc2V0KFtcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdYIGF4aXMnLFxuICAgICAgICB0eXBlOiAncGFydGl0aW9uJyxcbiAgICAgICAgcmFuazogMSxcbiAgICAgICAgcmVxdWlyZWQ6IHRydWUsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjYXRlZ29yaWFsJywgJ2RhdGV0aW1lJywgJ2R1cmF0aW9uJywgJ2NvbnRpbnVvdXMnLCAndGV4dCddXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBkZXNjcmlwdGlvbjogJ1kgYXhpcycsXG4gICAgICAgIHR5cGU6ICdwYXJ0aXRpb24nLFxuICAgICAgICByYW5rOiAyLFxuICAgICAgICByZXF1aXJlZDogdHJ1ZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NhdGVnb3JpYWwnLCAnZGF0ZXRpbWUnLCAnZHVyYXRpb24nLCAnY29udGludW91cycsICd0ZXh0J11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnWiBheGlzJyxcbiAgICAgICAgdHlwZTogJ3BhcnRpdGlvbicsXG4gICAgICAgIHJhbms6IDMsXG4gICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY2F0ZWdvcmlhbCcsICdkYXRldGltZScsICdkdXJhdGlvbicsICdjb250aW51b3VzJywgJ3RleHQnXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdDb2xvciBieScsXG4gICAgICAgIHR5cGU6ICdhZ2dyZWdhdGUnLFxuICAgICAgICByYW5rOiAxLFxuICAgICAgICByZXF1aXJlZDogZmFsc2UsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjb250aW51b3VzJywgJ2R1cmF0aW9uJ11cbiAgICAgIH1cbiAgICBdKTtcbiAgfSxcbiAgc2NhdHRlckNvbmZpZzogZnVuY3Rpb24gKCkge1xuICAgIHJldHVybiB7XG4gICAgICB3aWR0aDogJzYwMHB4JyxcbiAgICAgIGhlaWdodDogJzYwMHB4JyxcbiAgICAgIHN0eWxlOiAnZG90LWNvbG9yJyxcbiAgICAgIHRvb2x0aXA6IHRydWUsXG4gICAgICB0b29sdGlwU3R5bGU6IHtcbiAgICAgICAgZG90OiB7XG4gICAgICAgICAgYm9yZGVyOiAnbm9uZScsXG4gICAgICAgICAgYm9yZGVyUmFkaXVzOiAnMHB4J1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAgc2hvd1BlcnNwZWN0aXZlOiB0cnVlLFxuICAgICAgc2hvd0dyaWQ6IHRydWUsXG4gICAgICBzaG93U2hhZG93OiBmYWxzZSxcbiAgICAgIHNob3dMZWdlbmQ6IGZhbHNlLFxuICAgICAga2VlcEFzcGVjdFJhdGlvOiBmYWxzZSxcbiAgICAgIHZlcnRpY2FsUmF0aW86IDFcbiAgICB9O1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQURBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBaEJBO0FBa0JBO0FBcERBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///37f6\n")},"3f86":function(module,exports,__webpack_require__){eval("// This app view is responsible for rendering all content that goes into\n// <html>. It's initted right away and renders itself on DOM ready.\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\"); // var setFavicon = require('favicon-setter');\n\n\nvar View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar ViewSwitcher = __webpack_require__(/*! ampersand-view-switcher */ \"253d\");\n\nvar localLinks = __webpack_require__(/*! local-links */ \"a238\");\n\nvar domify = __webpack_require__(/*! domify */ \"2d1c\");\n\nvar templates = __webpack_require__(/*! ../templates */ \"4324\");\n\nfunction checkConnection(model) {\n  if (model.sessionType === 'server' && !model.isConnected) {\n    app.message({\n      text: 'Trying to connect to database ' + window.location.hostname,\n      type: 'error'\n    });\n  } // retry\n\n\n  window.setTimeout(function () {\n    checkConnection(model);\n  }, 4000);\n}\n/**\n * [exports description]\n * @module pages/main\n */\n\n\nmodule.exports = View.extend({\n  /**\n   * [template description]\n   * @type {any}\n   */\n  template: templates.main,\n  autoRender: true,\n  initialize: function initialize() {\n    this.pageName = 'main'; // this marks the correct nav item selected\n\n    this.listenTo(app, 'page', this.handleNewPage); // periodically check database connection\n\n    checkConnection(this.model);\n    this.model.on('change:isConnected', function () {\n      if (this.model.isConnected) {\n        app.message({\n          text: 'Connected to  ' + window.location.hostname,\n          type: 'ok'\n        });\n      }\n    }, this);\n  },\n  events: {\n    'click a[href]': 'handleLinkClick',\n    'click [data-hook~=help-button]': 'startHelp',\n    'click [data-hook~=menu-button]': 'handleMenu',\n    'click .mdl-menu__item': 'menuAction'\n  },\n  menuAction: function menuAction(item) {\n    var id = item.target.id;\n    console.log('pressed', id, 'button');\n    app.navigate(id); // switch(id) {\n    //   case 'home':\n    //     console.log('pressed home button');\n    //     app.navigate(id);\n    //     break;\n    //   case 'share':\n    //     console.log('pressed share button');\n    //     app.navigate(id);\n    //     break;\n    //   default:\n    //     // code block\n    // }\n  },\n  startHelp: function startHelp() {\n    app.startHelp();\n  },\n  render: function render() {\n    // some additional stuff we want to add to the document head\n    document.head.appendChild(domify(templates.head()));\n    document.title = 'Spot'; // main renderer\n\n    this.renderWithTemplate(this); // init and configure our page switcher\n\n    this.pageSwitcher = new ViewSwitcher(this.queryByHook('page-container'), {\n      show: function show(newView, oldView) {\n        document.scrollTop = 0; // store an additional reference, just because\n\n        app.currentPage = newView;\n      }\n    }); // setting a favicon for fun (note, it's dynamic)\n    // setFavicon('/favicon.ico');\n\n    return this;\n  },\n  handleNewPage: function handleNewPage(view) {\n    // tell the view switcher to render the new page\n    this.pageSwitcher.set(view); // update responsive layout (Material Design)\n\n    window.componentHandler.upgradeDom(); // second rendering pass; absolute sizes in pixels is now available for\n    // widgets that need them (ie. the SVG elements)\n\n    if (view.renderContent) {\n      view.renderContent();\n    }\n  },\n  // Handles all `<a>` clicks in the app not handled\n  // by another view. This lets us determine if this is\n  // a click that should be handled internally by the app.\n  handleLinkClick: function handleLinkClick(e) {\n    // This module determines whether a click event is\n    // a local click (making sure the for modifier keys, etc)\n    // and dealing with browser quirks to determine if this\n    // event was from clicking an internal link. That we should\n    // treat like local navigation.\n    var localPath = localLinks.pathname(e); // fixes navigation problem on Windows platform\n\n    if (navigator.platform === 'Win32') {\n      localPath = localPath.replace('/C:', '');\n    }\n\n    if (localPath) {\n      e.preventDefault();\n      app.navigate(localPath);\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiM2Y4Ni5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9tYWluLmpzP2VhNjciXSwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBhcHAgdmlldyBpcyByZXNwb25zaWJsZSBmb3IgcmVuZGVyaW5nIGFsbCBjb250ZW50IHRoYXQgZ29lcyBpbnRvXG4vLyA8aHRtbD4uIEl0J3MgaW5pdHRlZCByaWdodCBhd2F5IGFuZCByZW5kZXJzIGl0c2VsZiBvbiBET00gcmVhZHkuXG52YXIgYXBwID0gcmVxdWlyZSgnYW1wZXJzYW5kLWFwcCcpO1xuLy8gdmFyIHNldEZhdmljb24gPSByZXF1aXJlKCdmYXZpY29uLXNldHRlcicpO1xudmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIFZpZXdTd2l0Y2hlciA9IHJlcXVpcmUoJ2FtcGVyc2FuZC12aWV3LXN3aXRjaGVyJyk7XG52YXIgbG9jYWxMaW5rcyA9IHJlcXVpcmUoJ2xvY2FsLWxpbmtzJyk7XG52YXIgZG9taWZ5ID0gcmVxdWlyZSgnZG9taWZ5Jyk7XG52YXIgdGVtcGxhdGVzID0gcmVxdWlyZSgnLi4vdGVtcGxhdGVzJyk7XG5cbmZ1bmN0aW9uIGNoZWNrQ29ubmVjdGlvbiAobW9kZWwpIHtcbiAgaWYgKG1vZGVsLnNlc3Npb25UeXBlID09PSAnc2VydmVyJyAmJiAhbW9kZWwuaXNDb25uZWN0ZWQpIHtcbiAgICBhcHAubWVzc2FnZSh7XG4gICAgICB0ZXh0OiAnVHJ5aW5nIHRvIGNvbm5lY3QgdG8gZGF0YWJhc2UgJyArIHdpbmRvdy5sb2NhdGlvbi5ob3N0bmFtZSxcbiAgICAgIHR5cGU6ICdlcnJvcidcbiAgICB9KTtcbiAgfVxuXG4gIC8vIHJldHJ5XG4gIHdpbmRvdy5zZXRUaW1lb3V0KGZ1bmN0aW9uICgpIHtcbiAgICBjaGVja0Nvbm5lY3Rpb24obW9kZWwpO1xuICB9LCA0MDAwKTtcbn1cblxuLyoqXG4gKiBbZXhwb3J0cyBkZXNjcmlwdGlvbl1cbiAqIEBtb2R1bGUgcGFnZXMvbWFpblxuICovXG5tb2R1bGUuZXhwb3J0cyA9IFZpZXcuZXh0ZW5kKHtcbiAgLyoqXG4gICAqIFt0ZW1wbGF0ZSBkZXNjcmlwdGlvbl1cbiAgICogQHR5cGUge2FueX1cbiAgICovXG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMubWFpbixcbiAgYXV0b1JlbmRlcjogdHJ1ZSxcbiAgaW5pdGlhbGl6ZTogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucGFnZU5hbWUgPSAnbWFpbic7XG4gICAgLy8gdGhpcyBtYXJrcyB0aGUgY29ycmVjdCBuYXYgaXRlbSBzZWxlY3RlZFxuICAgIHRoaXMubGlzdGVuVG8oYXBwLCAncGFnZScsIHRoaXMuaGFuZGxlTmV3UGFnZSk7XG5cbiAgICAvLyBwZXJpb2RpY2FsbHkgY2hlY2sgZGF0YWJhc2UgY29ubmVjdGlvblxuICAgIGNoZWNrQ29ubmVjdGlvbih0aGlzLm1vZGVsKTtcblxuICAgIHRoaXMubW9kZWwub24oJ2NoYW5nZTppc0Nvbm5lY3RlZCcsIGZ1bmN0aW9uICgpIHtcbiAgICAgIGlmICh0aGlzLm1vZGVsLmlzQ29ubmVjdGVkKSB7XG4gICAgICAgIGFwcC5tZXNzYWdlKHtcbiAgICAgICAgICB0ZXh0OiAnQ29ubmVjdGVkIHRvICAnICsgd2luZG93LmxvY2F0aW9uLmhvc3RuYW1lLFxuICAgICAgICAgIHR5cGU6ICdvaydcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSwgdGhpcyk7XG4gIH0sXG4gIGV2ZW50czoge1xuICAgICdjbGljayBhW2hyZWZdJzogJ2hhbmRsZUxpbmtDbGljaycsXG4gICAgJ2NsaWNrIFtkYXRhLWhvb2t+PWhlbHAtYnV0dG9uXSc6ICdzdGFydEhlbHAnLFxuICAgICdjbGljayBbZGF0YS1ob29rfj1tZW51LWJ1dHRvbl0nOiAnaGFuZGxlTWVudScsXG4gICAgJ2NsaWNrIC5tZGwtbWVudV9faXRlbSc6ICdtZW51QWN0aW9uJ1xuICB9LFxuICBtZW51QWN0aW9uOiBmdW5jdGlvbihpdGVtKXtcbiAgICB2YXIgaWQgPSBpdGVtLnRhcmdldC5pZDtcbiAgICBjb25zb2xlLmxvZygncHJlc3NlZCcsIGlkLCAnYnV0dG9uJyk7XG4gICAgYXBwLm5hdmlnYXRlKGlkKTtcbiAgICAvLyBzd2l0Y2goaWQpIHtcbiAgICAvLyAgIGNhc2UgJ2hvbWUnOlxuICAgIC8vICAgICBjb25zb2xlLmxvZygncHJlc3NlZCBob21lIGJ1dHRvbicpO1xuICAgIC8vICAgICBhcHAubmF2aWdhdGUoaWQpO1xuICAgIC8vICAgICBicmVhaztcbiAgICAvLyAgIGNhc2UgJ3NoYXJlJzpcbiAgICAvLyAgICAgY29uc29sZS5sb2coJ3ByZXNzZWQgc2hhcmUgYnV0dG9uJyk7XG4gICAgLy8gICAgIGFwcC5uYXZpZ2F0ZShpZCk7XG4gICAgLy8gICAgIGJyZWFrO1xuICAgIC8vICAgZGVmYXVsdDpcbiAgICAvLyAgICAgLy8gY29kZSBibG9ja1xuICAgIC8vIH1cbiAgfSwgIFxuICBzdGFydEhlbHA6IGZ1bmN0aW9uICgpIHtcbiAgICBhcHAuc3RhcnRIZWxwKCk7XG4gIH0sXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIC8vIHNvbWUgYWRkaXRpb25hbCBzdHVmZiB3ZSB3YW50IHRvIGFkZCB0byB0aGUgZG9jdW1lbnQgaGVhZFxuICAgIGRvY3VtZW50LmhlYWQuYXBwZW5kQ2hpbGQoZG9taWZ5KHRlbXBsYXRlcy5oZWFkKCkpKTtcbiAgICBkb2N1bWVudC50aXRsZSA9ICdTcG90JztcblxuICAgIC8vIG1haW4gcmVuZGVyZXJcbiAgICB0aGlzLnJlbmRlcldpdGhUZW1wbGF0ZSh0aGlzKTtcblxuICAgIC8vIGluaXQgYW5kIGNvbmZpZ3VyZSBvdXIgcGFnZSBzd2l0Y2hlclxuICAgIHRoaXMucGFnZVN3aXRjaGVyID0gbmV3IFZpZXdTd2l0Y2hlcih0aGlzLnF1ZXJ5QnlIb29rKCdwYWdlLWNvbnRhaW5lcicpLCB7XG4gICAgICBzaG93OiBmdW5jdGlvbiAobmV3Vmlldywgb2xkVmlldykge1xuICAgICAgICBkb2N1bWVudC5zY3JvbGxUb3AgPSAwO1xuXG4gICAgICAgIC8vIHN0b3JlIGFuIGFkZGl0aW9uYWwgcmVmZXJlbmNlLCBqdXN0IGJlY2F1c2VcbiAgICAgICAgYXBwLmN1cnJlbnRQYWdlID0gbmV3VmlldztcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIC8vIHNldHRpbmcgYSBmYXZpY29uIGZvciBmdW4gKG5vdGUsIGl0J3MgZHluYW1pYylcbiAgICAvLyBzZXRGYXZpY29uKCcvZmF2aWNvbi5pY28nKTtcblxuICAgIHJldHVybiB0aGlzO1xuICB9LFxuICBoYW5kbGVOZXdQYWdlOiBmdW5jdGlvbiAodmlldykge1xuICAgIC8vIHRlbGwgdGhlIHZpZXcgc3dpdGNoZXIgdG8gcmVuZGVyIHRoZSBuZXcgcGFnZVxuICAgIHRoaXMucGFnZVN3aXRjaGVyLnNldCh2aWV3KTtcblxuICAgIC8vIHVwZGF0ZSByZXNwb25zaXZlIGxheW91dCAoTWF0ZXJpYWwgRGVzaWduKVxuICAgIHdpbmRvdy5jb21wb25lbnRIYW5kbGVyLnVwZ3JhZGVEb20oKTtcblxuICAgIC8vIHNlY29uZCByZW5kZXJpbmcgcGFzczsgYWJzb2x1dGUgc2l6ZXMgaW4gcGl4ZWxzIGlzIG5vdyBhdmFpbGFibGUgZm9yXG4gICAgLy8gd2lkZ2V0cyB0aGF0IG5lZWQgdGhlbSAoaWUuIHRoZSBTVkcgZWxlbWVudHMpXG4gICAgaWYgKHZpZXcucmVuZGVyQ29udGVudCkge1xuICAgICAgdmlldy5yZW5kZXJDb250ZW50KCk7XG4gICAgfVxuICB9LFxuICAvLyBIYW5kbGVzIGFsbCBgPGE+YCBjbGlja3MgaW4gdGhlIGFwcCBub3QgaGFuZGxlZFxuICAvLyBieSBhbm90aGVyIHZpZXcuIFRoaXMgbGV0cyB1cyBkZXRlcm1pbmUgaWYgdGhpcyBpc1xuICAvLyBhIGNsaWNrIHRoYXQgc2hvdWxkIGJlIGhhbmRsZWQgaW50ZXJuYWxseSBieSB0aGUgYXBwLlxuICBoYW5kbGVMaW5rQ2xpY2s6IGZ1bmN0aW9uIChlKSB7XG4gICAgLy8gVGhpcyBtb2R1bGUgZGV0ZXJtaW5lcyB3aGV0aGVyIGEgY2xpY2sgZXZlbnQgaXNcbiAgICAvLyBhIGxvY2FsIGNsaWNrIChtYWtpbmcgc3VyZSB0aGUgZm9yIG1vZGlmaWVyIGtleXMsIGV0YylcbiAgICAvLyBhbmQgZGVhbGluZyB3aXRoIGJyb3dzZXIgcXVpcmtzIHRvIGRldGVybWluZSBpZiB0aGlzXG4gICAgLy8gZXZlbnQgd2FzIGZyb20gY2xpY2tpbmcgYW4gaW50ZXJuYWwgbGluay4gVGhhdCB3ZSBzaG91bGRcbiAgICAvLyB0cmVhdCBsaWtlIGxvY2FsIG5hdmlnYXRpb24uXG4gICAgdmFyIGxvY2FsUGF0aCA9IGxvY2FsTGlua3MucGF0aG5hbWUoZSk7XG5cbiAgICAvLyBmaXhlcyBuYXZpZ2F0aW9uIHByb2JsZW0gb24gV2luZG93cyBwbGF0Zm9ybVxuICAgIGlmIChuYXZpZ2F0b3IucGxhdGZvcm0gPT09ICdXaW4zMicpIHtcbiAgICAgIGxvY2FsUGF0aCA9IGxvY2FsUGF0aC5yZXBsYWNlKCcvQzonLCAnJyk7XG4gICAgfVxuXG4gICAgaWYgKGxvY2FsUGF0aCkge1xuICAgICAgZS5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgYXBwLm5hdmlnYXRlKGxvY2FsUGF0aCk7XG4gICAgfVxuICB9XG5cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBOzs7Ozs7QUFJQTtBQUNBOzs7O0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFKQTtBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFOQTtBQVVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUdBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUExR0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///3f86\n")},4324:function(module,exports,__webpack_require__){eval('var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }\n\n;\n\n(function (root, factory) {\n  if (true) {\n    !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === \'function\' ?\n\t\t\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n  } else {}\n})(this, function () {\n  function pug_classes_object(val) {\n    var classString = \'\',\n        padding = \'\';\n\n    for (var key in val) {\n      if (key && val[key] && pug_has_own_property.call(val, key)) {\n        var classString = classString + padding + key;\n        var padding = \' \';\n      }\n    }\n\n    return classString;\n  }\n\n  function pug_classes_array(val, escaping) {\n    var classString = \'\',\n        className,\n        padding = \'\',\n        escapeEnabled = Array.isArray(escaping);\n\n    for (var i = 0; i < val.length; i++) {\n      var className = pug_classes(val[i]);\n      if (!className) continue;\n      escapeEnabled && escaping[i] && (className = pug_escape(className));\n      var classString = classString + padding + className;\n      var padding = \' \';\n    }\n\n    return classString;\n  }\n\n  function pug_merge(e, r) {\n    if (1 === arguments.length) {\n      for (var t = e[0], g = 1; g < e.length; g++) {\n        t = pug_merge(t, e[g]);\n      }\n\n      return t;\n    }\n\n    for (var n in r) {\n      if ("class" === n) {\n        var a = e[n] || [];\n        e[n] = (Array.isArray(a) ? a : [a]).concat(r[n] || []);\n      } else if ("style" === n) {\n        var a = pug_style(e[n]);\n        a = a && ";" !== a[a.length - 1] ? a + ";" : a;\n        var l = pug_style(r[n]);\n        l = l && ";" !== l[l.length - 1] ? l + ";" : l, e[n] = a + l;\n      } else e[n] = r[n];\n    }\n\n    return e;\n  }\n\n  function pug_classes(s, r) {\n    return Array.isArray(s) ? pug_classes_array(s, r) : s && "object" == _typeof(s) ? pug_classes_object(s) : s || "";\n  }\n\n  function pug_style(r) {\n    if (!r) return "";\n\n    if ("object" == _typeof(r)) {\n      var t = "";\n\n      for (var e in r) {\n        pug_has_own_property.call(r, e) && (t = t + e + ":" + r[e] + ";");\n      }\n\n      return t;\n    }\n\n    return r + "";\n  }\n\n  function pug_attr(t, e, n, f) {\n    return e !== !1 && null != e && (e || "class" !== t && "style" !== t) ? e === !0 ? " " + (f ? t : t + \'="\' + t + \'"\') : ("function" == typeof e.toJSON && (e = e.toJSON()), "string" == typeof e || (e = JSON.stringify(e), n || -1 === e.indexOf(\'"\')) ? (n && (e = pug_escape(e)), " " + t + \'="\' + e + \'"\') : " " + t + "=\'" + e.replace(/\'/g, "&#39;") + "\'") : "";\n  }\n\n  function pug_attrs(t, r) {\n    var a = "";\n\n    for (var s in t) {\n      if (pug_has_own_property.call(t, s)) {\n        var u = t[s];\n\n        if ("class" === s) {\n          u = pug_classes(u), a = pug_attr(s, u, !1, r) + a;\n          continue;\n        }\n\n        "style" === s && (u = pug_style(u)), a += pug_attr(s, u, !1, r);\n      }\n    }\n\n    return a;\n  }\n\n  function pug_escape(e) {\n    var a = "" + e,\n        t = /["&<>]/.exec(a);\n    if (!t) return e;\n    var r,\n        c,\n        n,\n        s = "";\n\n    for (r = t.index, c = 0; r < a.length; r++) {\n      switch (a.charCodeAt(r)) {\n        case 34:\n          n = "&quot;";\n          break;\n\n        case 38:\n          n = "&amp;";\n          break;\n\n        case 60:\n          n = "&lt;";\n          break;\n\n        case 62:\n          n = "&gt;";\n          break;\n\n        default:\n          continue;\n      }\n\n      c !== r && (s += a.substring(c, r)), c = r + 1, s += n;\n    }\n\n    return c !== r ? s + a.substring(c, r) : s;\n  }\n\n  function pug_rethrow(n, e, r, t) {\n    if (!(n instanceof Error)) throw n;\n    if (!("undefined" == typeof window && e || t)) throw n.message += " on line " + r, n;\n\n    try {\n      t = t || __webpack_require__(/*! fs */ "9412").readFileSync(e, "utf8");\n    } catch (i) {\n      pug_rethrow(n, null, r);\n    }\n\n    var a = 3,\n        o = t.split("\\n"),\n        h = Math.max(r - a, 0),\n        s = Math.min(o.length, r + a),\n        a = o.slice(h, s).map(function (n, e) {\n      var t = e + h + 1;\n      return (t == r ? "  > " : "    ") + t + "| " + n;\n    }).join("\\n");\n    throw n.path = e, n.message = (e || "Pug") + ":" + r + "\\n" + a + "\\n\\n" + n.message, n;\n  }\n\n  var pug = {\n    merge: function pug_merge(e, r) {\n      if (1 === arguments.length) {\n        for (var t = e[0], g = 1; g < e.length; g++) {\n          t = pug_merge(t, e[g]);\n        }\n\n        return t;\n      }\n\n      for (var n in r) {\n        if ("class" === n) {\n          var a = e[n] || [];\n          e[n] = (Array.isArray(a) ? a : [a]).concat(r[n] || []);\n        } else if ("style" === n) {\n          var a = pug_style(e[n]);\n          a = a && ";" !== a[a.length - 1] ? a + ";" : a;\n          var l = pug_style(r[n]);\n          l = l && ";" !== l[l.length - 1] ? l + ";" : l, e[n] = a + l;\n        } else e[n] = r[n];\n      }\n\n      return e;\n    },\n    classes: function pug_classes(s, r) {\n      return Array.isArray(s) ? pug_classes_array(s, r) : s && "object" == _typeof(s) ? pug_classes_object(s) : s || "";\n    },\n    style: function pug_style(r) {\n      if (!r) return "";\n\n      if ("object" == _typeof(r)) {\n        var t = "";\n\n        for (var e in r) {\n          pug_has_own_property.call(r, e) && (t = t + e + ":" + r[e] + ";");\n        }\n\n        return t;\n      }\n\n      return r + "";\n    },\n    attr: function pug_attr(t, e, n, f) {\n      return e !== !1 && null != e && (e || "class" !== t && "style" !== t) ? e === !0 ? " " + (f ? t : t + \'="\' + t + \'"\') : ("function" == typeof e.toJSON && (e = e.toJSON()), "string" == typeof e || (e = JSON.stringify(e), n || -1 === e.indexOf(\'"\')) ? (n && (e = pug_escape(e)), " " + t + \'="\' + e + \'"\') : " " + t + "=\'" + e.replace(/\'/g, "&#39;") + "\'") : "";\n    },\n    attrs: function pug_attrs(t, r) {\n      var a = "";\n\n      for (var s in t) {\n        if (pug_has_own_property.call(t, s)) {\n          var u = t[s];\n\n          if ("class" === s) {\n            u = pug_classes(u), a = pug_attr(s, u, !1, r) + a;\n            continue;\n          }\n\n          "style" === s && (u = pug_style(u)), a += pug_attr(s, u, !1, r);\n        }\n      }\n\n      return a;\n    },\n    escape: function pug_escape(e) {\n      var a = "" + e,\n          t = /["&<>]/.exec(a);\n      if (!t) return e;\n      var r,\n          c,\n          n,\n          s = "";\n\n      for (r = t.index, c = 0; r < a.length; r++) {\n        switch (a.charCodeAt(r)) {\n          case 34:\n            n = "&quot;";\n            break;\n\n          case 38:\n            n = "&amp;";\n            break;\n\n          case 60:\n            n = "&lt;";\n            break;\n\n          case 62:\n            n = "&gt;";\n            break;\n\n          default:\n            continue;\n        }\n\n        c !== r && (s += a.substring(c, r)), c = r + 1, s += n;\n      }\n\n      return c !== r ? s + a.substring(c, r) : s;\n    },\n    rethrow: function pug_rethrow(n, e, r, t) {\n      if (!(n instanceof Error)) throw n;\n      if (!("undefined" == typeof window && e || t)) throw n.message += " on line " + r, n;\n\n      try {\n        t = t || __webpack_require__(/*! fs */ "9412").readFileSync(e, "utf8");\n      } catch (i) {\n        pug_rethrow(n, null, r);\n      }\n\n      var a = 3,\n          o = t.split("\\n"),\n          h = Math.max(r - a, 0),\n          s = Math.min(o.length, r + a),\n          a = o.slice(h, s).map(function (n, e) {\n        var t = e + h + 1;\n        return (t == r ? "  > " : "    ") + t + "| " + n;\n      }).join("\\n");\n      throw n.path = e, n.message = (e || "Pug") + ":" + r + "\\n" + a + "\\n\\n" + n.message, n;\n    }\n  };\n  var puglatizer = {};\n  puglatizer["analyze"] = {};\n\n  puglatizer["analyze"]["facetbarItem"] = function template(a) {\n    var t,\n        e,\n        c = "";\n\n    try {\n      e = 1, c += \'<span class="mdl-chip variableChip" data-hook="facet-bar-item" id="">\', e = 2, c += \'<span class="mdl-chip__text" data-hook="facet-bar-item-button"></span></span>\';\n    } catch (p) {\n      pug.rethrow(p, t, e);\n    }\n\n    return c;\n  };\n\n  puglatizer["analyze"]["page"] = function template(t) {\n    var a,\n        o,\n        l = "";\n\n    try {\n      o = 1, l += \'<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">\', o = 2, l += \'<main class="mdl-layout__content" style="background-color: white;">\', o = 3, l += \'<header class="demo-header mdl-layout__header spot-color-top-bar mdl-color-text--grey-600">\', o = 5, l += \'<div class="mdl-layout__header-row">\', o = 6, l += \'<span class="mdl-layout-title unselectable">\', o = 6, l += "Analyze</span>", o = 8, l += \'<div class="mdl-layout-spacer"></div>\', o = 10, l += \'<span class="unselectable" data-hook="data-string"></span>\', o = 12, l += \'<div class="mdl-layout-spacer"></div>\', o = 14, l += \'<span data-position="bottom" data-step="0" data-hint=""></span>\', o = 16, l += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" id="saveSessionButton" data-hintPosition="bottom" data-position="bottom" data-hint="This buttons saves the current session.">\', o = 17, l += \'<i class="material-icons">\', o = 17, l += "save</i></button>", o = 18, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="saveSessionButton">\', o = 19, l += "Save the session</div>", o = 21, l += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" id="resetFiltersButton" data-position="bottom" data-step="1" data-hint="This button clears all existing filters.">\', o = 22, l += \'<i class="material-icons">\', o = 22, l += "clear_all</i></button>", o = 23, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="resetFiltersButton">\', o = 24, l += "Clear all filters of all plots</div>", o = 26, l += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" id="viewAll" data-position="bottom" data-step="2" data-hint="This button closes all configuration windows">\', o = 27, l += \'<i class="material-icons">\', o = 27, l += "crop_original</i></button>", o = 28, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="viewAll">\', o = 29, l += "Close all configuration windows</div>", o = 31, l += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" id="fullscreenButton" data-position="bottom" data-step="3" data-hint="This button hides facet and chart bars.">\', o = 32, l += \'<i class="material-icons">\', o = 32, l += "fullscreen</i></button>", o = 33, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="fullscreenButton">\', o = 34, l += "Show or hide chart and facet bars</div></div>", o = 36, l += \'<div class="chartBar spot-color-top-bar mdl-color-text--grey-600" data-hook="chart-bar" data-position="bottom" data-step="4" data-hint="These are the available chart types. If you want to add a chart, just &lt;b&gt;click&lt;/b&gt; on its icon and it will be created! Simple, right? ">\', o = 37, l += \'<span class="chartBarText">\', o = 37, l += "Click on a chart icon to start a new plot</span>", o = 39, l += \'<div class="mdl-cell mdl-cell--12-col horizontalbarchartIcon widgetIcon" data-hook="horizontalbarchart" id="horizontalbarchart" data-position="bottom" data-step="5" data-hint="This adds a horizontal bar chart(histogram). This is good for categorical facets."></div>\', o = 40, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="horizontalbarchart">\', o = 41, l += "Click to add a horizontal bar chart</div>", o = 43, l += \'<div class="mdl-cell mdl-cell--12-col barchartIcon widgetIcon" data-hook="barchart" id="barchart" data-position="bottom" data-step="6" data-hint="This adds a vertical bar chart."></div>\', o = 44, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="barchart">\', o = 45, l += "Click to add a bar chart</div>", o = 47, l += \'<div class="mdl-cell mdl-cell--12-col linechartIcon widgetIcon" data-hook="linechart" id="linechart" data-position="bottom" data-step="7" data-hint="This adds a line chart."></div>\', o = 48, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="linechart">\', o = 49, l += "Click to add a line chart</div>", o = 51, l += \'<div class="mdl-cell mdl-cell--12-col piechartIcon widgetIcon" data-hook="piechart" id="piechart" data-position="bottom" data-step="8" data-hint="This adds a pie chart."></div>\', o = 52, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="piechart">\', o = 53, l += "Click to add a pie chart</div>", o = 55, l += \'<div class="mdl-cell mdl-cell--12-col bubbleplotIcon widgetIcon" data-hook="bubbleplot" id="bubbleplot" data-position="bottom" data-step="9" data-hint="This adds a buble chart."></div>\', o = 56, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="bubbleplot">\', o = 57, l += "Click to add a bubbleplot chart</div>", o = 59, l += \'<div class="mdl-cell mdl-cell--12-col scatterchartIcon widgetIcon" data-hook="scatterchart" id="scatterchart" data-position="bottom" data-step="10" data-hint="This adds a 3D scatter chart."></div>\', o = 60, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="scatterchart">\', o = 61, l += "Click to add a 3d scatter chart</div>", o = 63, l += \'<div class="mdl-cell mdl-cell--12-col radarchartIcon widgetIcon" data-hook="radarchart" id="radarchart" data-position="bottom" data-step="11" data-hint="This adds a radar chart."></div>\', o = 64, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="radarchart">\', o = 65, l += "Click to add a radar chart</div>", o = 67, l += \'<div class="mdl-cell mdl-cell--12-col networkchartIcon widgetIcon" data-hook="networkchart" id="networkchart" data-position="bottom" data-step="12" data-hint="This adds a network chart."></div>\', o = 68, l += \'<div class="mdl-tooltip mdl-tooltip--large" for="networkchart">\', o = 69, l += "Click to add a network chart</div></div>", o = 71, l += \'<div class="facetBar spot-color-top-bar" data-hook="facet-bar" id="facet-bar" data-position="bottom" data-step="13" data-hint="This is where you will have your variables(facets). Just &lt;b&gt;drag and drop&lt;/b&gt; these facets to field of the charts to visualize.">\', o = 72, l += \'<span class="facetBarText">\', o = 72, l += "Drop variable on a chart, or click to edit</span>", o = 73, l += \'<div class="facetBarItems" data-hook="facet-bar-items" id="facetBar"></div></div>\', o = 74, l += \'<div class="mdl-tooltip mdl-tooltip--large" id="facet-bar-tooltip" for="facet-bar">\', o = 75, l += "Drop variable on a chart, or click to edit</div></header>", o = 77, l += \'<div class="widgetDropZone" id="widgets" data-hook="widgets"></div></main></div>\';\n    } catch (i) {\n      pug.rethrow(i, a, o);\n    }\n\n    return l;\n  };\n\n  puglatizer["analyze"]["slot"] = function template(t) {\n    var o,\n        a,\n        d = "";\n\n    try {\n      a = 1, d += \'<div class="slot mdl-shadow--2dp" data-hook="slot">\', a = 2, d += \'<div class="slotText clickTarget">\', a = 3, d += \'<b data-hook="description"></b>\', a = 4, d += "<br/>", a = 5, d += \'<i data-hook="required"></i></div>\', a = 6, d += \'<div class="slotChip clickTarget" data-hook="drop-zone">\', a = 7, d += \'<span data-hook="chip-text"></span></div>\', a = 8, d += \'<div class="slotButton" data-hook="button-div">\', a = 9, d += \'<button class="mdl-button mdl-js-button mdl-button--icon" data-hook="delete">\', a = 10, d += \'<i class="material-icons">\', a = 10, d += "delete</i></button></div></div>";\n    } catch (i) {\n      pug.rethrow(i, o, a);\n    }\n\n    return d;\n  };\n\n  puglatizer["analyze"]["widgetFrame"] = function template(t) {\n    var o,\n        l,\n        i = "";\n\n    try {\n      l = 1, i += \'<div class="widgetFrame mdl-color--white mdl-shadow--2dp">\', l = 3, i += \'<div class="configView" data-hook="config-view">\', l = 4, i += \'<div class="widgetDragBar">\', l = 5, i += \'<button class="mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect" data-hook="close" id="chartDeleteButton2">\', l = 6, i += \'<i class="material-icons">\', l = 6, i += "delete</i></button>", l = 7, i += \'<div class="mdl-tooltip mdl-tooltip--large" for="chartDeleteButton2">\', l = 8, i += "Delete this chart</div>", l = 9, i += \'<span class="widgetHeader" data-hook="widgetHeader"></span>\', l = 10, i += \'<div class="mdl-layout-spacer"></div>\', l = 11, i += \'<button class="mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect" data-hook="edit" style="float: right" id="chartDoneButton">\', l = 12, i += \'<i class="material-icons">\', l = 12, i += "done</i></button>", l = 13, i += \'<div class="mdl-tooltip mdl-tooltip--large" for="chartDoneButton">\', l = 14, i += "Close configuration view</div></div>", l = 16, i += \'<div class="slots" data-hook="slots"></div></div>\', l = 18, i += \'<div class="widgetView" data-hook="widget"></div>\', l = 20, i += \'<div class="plotMenu" data-hook="plot-menu" style="width: 100%;">\', l = 21, i += \'<div class="widgetDragBar">\', l = 22, i += \'<button class="mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect" data-hook="close" id="chartDeleteButton1">\', l = 23, i += \'<i class="material-icons">\', l = 23, i += "delete</i></button>", l = 24, i += \'<div class="mdl-tooltip mdl-tooltip--large" for="chartDeleteButton1">\', l = 25, i += "Delete this chart</div>", l = 26, i += \'<button class="mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect" data-hook="zoom-out" id="chartUndoButton">\', l = 27, i += \'<i class="material-icons">\', l = 27, i += "undo</i></button>", l = 28, i += \'<div class="mdl-tooltip mdl-tooltip--large" for="chartUndoButton">\', l = 29, i += "Undo selection</div>", l = 30, i += \'<button class="mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect" data-hook="zoom-in" id="chartZoomButton">\', l = 31, i += \'<i class="material-icons">\', l = 31, i += "zoom_in</i></button>", l = 32, i += \'<div class="mdl-tooltip mdl-tooltip--large" for="chartZoomButton">\', l = 33, i += "Zoom into selected region</div>", l = 34, i += \'<button class="mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect" data-hook="save" id="chartSave">\', l = 35, i += \'<i class="material-icons">\', l = 35, i += "save</i></button>", l = 36, i += \'<div class="mdl-tooltip mdl-tooltip--large" for="chartSave">\', l = 37, i += "Save this chart</div>", l = 38, i += \'<div class="mdl-layout-spacer"></div>\', l = 39, i += \'<button class="mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect" data-hook="edit" style="float: right;" id="chartConfButton">\', l = 40, i += \'<i class="material-icons">\', l = 40, i += "create</i></button>", l = 41, i += \'<div class="mdl-tooltip mdl-tooltip--large" for="chartConfButton">\', l = 42, i += "Open configuration view</div></div></div></div>";\n    } catch (a) {\n      pug.rethrow(a, o, l);\n    }\n\n    return i;\n  };\n\n  puglatizer["configureDataset"] = {};\n\n  puglatizer["configureDataset"]["facet"] = function template(t) {\n    var l,\n        a,\n        d = "";\n\n    try {\n      a = 1, d += \'<div class="mdl-card mdl-shadow--2dp" data-hook="fullitem" style="min-height: inherit">\', a = 2, d += \'<div class="mdl-card__title">\', a = 3, d += \'<h2 class="mdl-card__title-text" data-hook="name"></h2></div>\', a = 5, d += \'<div class="mdl-card__supporting-text" data-hook="description"></div>\', a = 7, d += \'<div class="mdl-card__actions mdl-card--border" data-hook="actions">\', a = 8, d += \'<button class="mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect unselectable" data-hook="removeFacet">\', a = 9, d += "Delete</button>", a = 10, d += \'<button class="mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect unselectable" data-hook="duplicateFacet">\', a = 11, d += "Copy </button>", a = 12, d += \'<button class="mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect unselectable" data-hook="configureFacet" style="float: right">\', a = 13, d += \'<i class="material-icons">\', a = 13, d += "settings</i></button></div>", a = 15, d += \'<div class="mdl-card__menu">\', a = 16, d += "<span>", a = 17, d += \'<label class="mdl-switch mdl-js-switch mdl-js-ripple-effect" data-hook="cblabel" for="">\', a = 18, d += \'<input class="mdl-switch__input" data-hook="cb" type="checkbox" id=""/></label>\', a = 19, d += \'<span class="mdl-switch__label"></span></span></div></div>\';\n    } catch (e) {\n      pug.rethrow(e, l, a);\n    }\n\n    return d;\n  };\n\n  puglatizer["configureDataset"]["page"] = function template(t) {\n    var l,\n        a,\n        d = "";\n\n    try {\n      a = 1, d += \'<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">\', a = 2, d += \'<main class="mdl-layout__content" style="background-color: white;">\', a = 3, d += \'<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">\', a = 4, d += \'<header class="demo-header mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600">\', a = 5, d += \'<div class="mdl-layout__header-row">\', a = 6, d += \'<span class="mdl-layout-title">\', a = 6, d += "Configure dataset</span>", a = 8, d += \'<div class="mdl-layout-spacer"></div>\', a = 10, d += \'<span class="unselectable" data-hook="data-string">\', a = 11, d += "Select and configure facets</span>", a = 13, d += \'<div class="mdl-layout-spacer"></div>\', a = 15, d += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" data-hook="enable-all-button" id="eab">\', a = 16, d += \'<i class="material-icons">\', a = 16, d += "check_box</i></button>", a = 17, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="eab">\', a = 18, d += "Enable all facets</div>", a = 20, d += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" data-hook="disable-all-button" id="dab">\', a = 21, d += \'<i class="material-icons">\', a = 21, d += "check_box_outline_blank</i></button>", a = 22, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="dab">\', a = 23, d += "Disable all facets</div>", a = 25, d += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" data-hook="add-button" id="tt2">\', a = 26, d += \'<i class="material-icons">\', a = 26, d += "add</i></button>", a = 27, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="tt2">\', a = 28, d += "Add a new facet</div>", a = 30, d += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" data-hook="rescan-button" id="tt1">\', a = 31, d += \'<i class="material-icons">\', a = 31, d += "autorenew</i></button>", a = 32, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="tt1">\', a = 33, d += "Analyze data and autoconfigure facets</div>", a = 35, d += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" data-hook="search-button" id="tt3">\', a = 36, d += \'<i class="material-icons">\', a = 36, d += "search</i></button>", a = 37, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="tt3">\', a = 38, d += "Show or hide search bar</div></div>", a = 40, d += \'<div class="mdl-layout__header-row" data-hook="search-bar">\', a = 41, d += \'<div class="mdl-layout-spacer"></div>\', a = 42, d += \'<span class="mdl-color--white mdl-color-text--primary searchBar">\', a = 44, d += \'<span class="mdl-textfield searchBar">\', a = 45, d += \'<input class="mdl-textfield__input searchBar" data-hook="facet-selector" type="text" id="tt5"/>\', a = 46, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="tt5">\', a = 47, d += "Search facet name and description</div></span>", a = 49, d += "<span>", a = 50, d += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" data-hook="clear-button" id="tt4">\', a = 51, d += \'<i class="material-icons">\', a = 51, d += "close</i></button>", a = 52, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="tt4">\', a = 53, d += "Clear search</div></span></span>", a = 54, d += \'<div class="mdl-layout-spacer"></div></div></header>\', a = 56, d += \'<div data-hook="widgets">\', a = 58, d += \'<div class="mdl-grid">\', a = 59, d += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col">\', a = 60, d += \'<input class="mdl-textfield__input" type="text" id="name"/>\', a = 61, d += \'<label class="mdl-textfield__label" for="name">\', a = 62, d += "Dataset name</label></div>", a = 64, d += \'<div class="mdl-textfield mdl-js-textfield mdl-cell mdl-cell mdl-cell--7-col">\', a = 65, d += \'<textarea class="mdl-textfield__input" type="text" rows="3" id="description"></textarea>\', a = 66, d += \'<label class="mdl-textfield__label" for="description">\', a = 67, d += "Dataset description</label></div></div>", a = 69, d += \'<div class="mdl-grid" data-hook="facet-list"></div></div></div></main></div>\';\n    } catch (e) {\n      pug.rethrow(e, l, a);\n    }\n\n    return d;\n  };\n\n  puglatizer["configureFacet"] = {};\n\n  puglatizer["configureFacet"]["categorialRule"] = function template(t) {\n    var e,\n        o,\n        a = "";\n\n    try {\n      o = 1, a += "<tr>", o = 2, a += "<td>", o = 3, a += \'<input class="mdl-textfield__input" data-hook="category-expression-input" type="text"/></td>\', o = 4, a += "<td>", o = 5, a += \'<input class="mdl-textfield__input" data-hook="category-group-input" type="text"/></td>\', o = 6, a += \'<td data-hook="category-value-count"></td>\', o = 7, a += "<td>", o = 8, a += \'<button class="mdl-button mdl-js-button mdl-js-ripple-effect" data-hook="category-remove">\', o = 9, a += \'<i class="material-icons">\', o = 9, a += "remove</i></button></td></tr>";\n    } catch (d) {\n      pug.rethrow(d, e, o);\n    }\n\n    return a;\n  };\n\n  puglatizer["configureFacet"]["categorialtransform"] = function template(t) {\n    var r,\n        e,\n        a = "";\n\n    try {} catch (c) {\n      pug.rethrow(c, r, e);\n    }\n\n    return a;\n  };\n\n  puglatizer["configureFacet"]["continuousRule"] = function template(t) {\n    var o,\n        e,\n        n = "";\n\n    try {\n      e = 1, n += "<tr>", e = 2, n += "<td>", e = 3, n += \'<input class="mdl-textfield__input" data-hook="continuous-x-input" type="text"/></td>\', e = 4, n += "<td>", e = 5, n += \'<input class="mdl-textfield__input" data-hook="continuous-fx-input" type="text"/></td>\', e = 6, n += "<td>", e = 7, n += \'<button class="mdl-button mdl-js-button mdl-js-ripple-effect" data-hook="continuous-remove">\', e = 8, n += \'<i class="material-icons">\', e = 8, n += "remove</i></button></td></tr>";\n    } catch (u) {\n      pug.rethrow(u, o, e);\n    }\n\n    return n;\n  };\n\n  puglatizer["configureFacet"]["facetDefine"] = function template(l) {\n    var e,\n        d,\n        i = "";\n\n    try {\n      d = 1, i += \'<div class="mdl-grid">\', d = 2, i += \'<div class="mdl-cell mdl-cell--12-col mdl-grid">\', d = 3, i += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetInfoIcon"></div>\', d = 4, i += \'<div class="mdl-cell mdl-cell--1-col"></div>\', d = 5, i += \'<div class="mdl-cell mdl-cell--8-col">\', d = 6, i += \'<div class="mdl-grid">\', d = 8, i += \'<div class="mdl-cell mdl-cell--12-col" id="define-name-div">\', d = 9, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label fullwidth">\', d = 10, i += \'<input class="mdl-textfield__input" id="define-name" data-hook="define-name-input" type="text"/>\', d = 14, i += \'<label class="mdl-textfield__label" for="define-name">\', d = 14, i += "Name</label></div></div>", d = 15, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="define-name-div">\', d = 16, i += "Set a descriptive name for this facet. The name is used to identify this facet on plots and in menus. </div>", d = 18, i += \'<div class="mdl-cell mdl-cell--12-col" id="define-units-div">\', d = 19, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label fullwidth">\', d = 20, i += \'<input class="mdl-textfield__input" id="define-units" data-hook="define-units-input" type="text"/>\', d = 24, i += \'<label class="mdl-textfield__label" for="define-units">\', d = 24, i += "Units</label></div></div>", d = 25, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="define-units-div">\', d = 26, i += "Set units for this facet. Units are printed on plots where applicable.</div>", d = 28, i += \'<div class="mdl-cell mdl-cell--12-col" id="define-description-div">\', d = 29, i += \'<div class="mdl-textfield mdl-js-textfield mdl textfield--floating-label fullwidth">\', d = 30, i += \'<textarea class="mdl-textfield__input" id="define-description" data-hook="define-description-input" type="text" rows="5">\', d = 34, i += " </textarea>", d = 35, i += \'<label class="mdl-textfield__label" for="define-description">\', d = 35, i += "Description</label></div></div>", d = 36, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="define-description-div">\', d = 37, i += "Give a description of the facet. What do its values mean? How are they calculated?</div></div></div>", d = 39, i += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\', d = 41, i += \'<div class="mdl-cell mdl-cell--12-col mdl-grid">\', d = 42, i += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetTypeIcon"></div>\', d = 43, i += \'<div class="mdl-cell mdl-cell--1-col"></div>\', d = 44, i += \'<div class="mdl-cell mdl-cell--8-col">\', d = 46, i += \'<div class="mdl-grid mdl-cell mdl-cell--12-col">\', d = 48, i += \'<div class="mdl-grid mdl-cell mdl-cell--12-col" id="define-type-div">\', d = 49, i += \'<div class="mdl-cell mdl-cell--3-col">\', d = 50, i += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="define-type-categorial">\', d = 51, i += \'<input class="mdl-radio__button" id="define-type-categorial" data-hook="define-type-categorial" type="radio" name="type" value="categorial"/>\', d = 57, i += \'<span class="mdl-radio__label">\', d = 57, i += "Categorial</span></label></div>", d = 59, i += \'<div class="mdl-cell mdl-cell--3-col">\', d = 60, i += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="define-type-continuous">\', d = 61, i += \'<input class="mdl-radio__button" id="define-type-continuous" data-hook="define-type-continuous" type="radio" name="type" value="continuous"/>\', d = 67, i += \'<span class="mdl-radio__label">\', d = 67, i += "Continuous</span></label></div>", d = 69, i += \'<div class="mdl-cell mdl-cell--3-col">\', d = 70, i += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="define-type-datetime">\', d = 71, i += \'<input class="mdl-radio__button" id="define-type-datetime" data-hook="define-type-datetime" type="radio" name="type" value="datetime"/>\', d = 77, i += \'<span class="mdl-radio__label">\', d = 77, i += "Datetime</span></label></div>", d = 79, i += \'<div class="mdl-cell mdl-cell--3-col">\', d = 80, i += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="define-type-duration">\', d = 81, i += \'<input class="mdl-radio__button" id="define-type-duration" data-hook="define-type-duration" type="radio" name="type" value="duration"/>\', d = 87, i += \'<span class="mdl-radio__label">\', d = 87, i += "Duration</span></label></div>", d = 89, i += \'<div class="mdl-cell mdl-cell--3-col">\', d = 90, i += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="define-type-text">\', d = 91, i += \'<input class="mdl-radio__button" id="define-type-text" data-hook="define-type-text" type="radio" name="type" value="text"/>\', d = 97, i += \'<span class="mdl-radio__label">\', d = 97, i += "Text</span></label></div></div>", d = 99, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="define-type-div">\', d = 100, i += "What values does this facet take? Is it a continuous value (length, weight, amount)? Or a label, category (\'important\', \'urgent\', or a day of the week, ...). Or is it a date, time or duration? Or arbitrary text?</div></div></div>", d = 102, i += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\', d = 104, i += \'<div class="mdl-cell mdl-cell--12-col mdl-grid">\', d = 105, i += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetBaseValueIcon"></div>\', d = 106, i += \'<div class="mdl-cell mdl-cell--1-col"></div>\', d = 107, i += \'<div class="mdl-cell mdl-cell--8-col">\', d = 109, i += \'<div class="mdl-grid mdl-cell mdl-cell--12-col">\', d = 111, i += \'<div class="mdl-cell mdl-cell--12-col" id="define-missing-div">\', d = 112, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label fullwidth">\', d = 113, i += \'<input class="mdl-textfield__input" id="define-missing-input" data-hook="define-missing-input" type="text"/>\', d = 117, i += \'<label class="mdl-textfield__label" for="define-missing-input">\', d = 117, i += "Missing data indicator</label></div></div>", d = 118, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="define-missing-div">\', d = 119, i += "Invalid, undefined, or missing data are dealt with automatically, but sometimes a special value is used to indicate the data is missing. Enter those values here. Example: 999, \'x\', \'missing\'</div>", d = 122, i += \'<div class="mdl-cell mdl-cell--12-col" id="define-accessor-div">\', d = 123, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label fullwidth">\', d = 124, i += \'<input class="mdl-textfield__input" id="define-accessor-input" data-hook="define-accessor-input" type="text"/>\', d = 128, i += \'<label class="mdl-textfield__label" for="define-accessor-input">\', d = 128, i += "Property name or index</label></div></div>", d = 129, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="define-accessor-div">\', d = 130, i += "How we derive the facet value from a data object? Enter a property name (for JSON or SQL columns), or index (for arrays). Use \'.\' notation to access nested properties.</div>", d = 133, i += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="define-rescan-div">\', d = 134, i += \'<button class="mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--accent" data-hook="define-rescan-button">\', d = 134, i += "Scan dataset</button></div>", d = 137, i += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="define-minimum-div" data-hook="define-minimum-div">\', d = 138, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--10-col" id="define-minimum-div">\', d = 139, i += \'<input class="mdl-textfield__input" id="define-minimum" data-hook="define-minimum-input" type="text"/>\', d = 143, i += \'<label class="mdl-textfield__label" for="sample4">\', d = 143, i += "Minimum value</label></div>", d = 145, i += \'<div class="mdl-cell mdl-cell--1-col">\', d = 146, i += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-button--colored" data-hook="button-minval-missing">\', d = 147, i += \'<i class="material-icons">\', d = 147, i += "cancel</i></button></div>", d = 149, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="define-minimum-div">\', d = 150, i += "Set minimum value.</div></div>", d = 153, i += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="define-maximum-div" data-hook="define-maximum-div">\', d = 154, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--10-col" id="define-maximum-div">\', d = 155, i += \'<input class="mdl-textfield__input" id="define-maximum" data-hook="define-maximum-input" type="text"/>\', d = 159, i += \'<label class="mdl-textfield__label" for="sample4">\', d = 159, i += "Maximum value</label></div>", d = 161, i += \'<div class="mdl-cell mdl-cell--1-col">\', d = 162, i += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-button--colored" data-hook="button-maxval-missing">\', d = 163, i += \'<i class="material-icons">\', d = 163, i += "cancel</i></button></div>", d = 165, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="define-maximum-div">\', d = 166, i += "Set maximum value.</div></div></div></div>", d = 168, i += \'<div class="mdl-cell mdl-cell--2-col"></div></div></div>\';\n    } catch (t) {\n      pug.rethrow(t, e, d);\n    }\n\n    return i;\n  };\n\n  puglatizer["configureFacet"]["facetTransformCategorial"] = function template(l) {\n    var t,\n        d,\n        o = "";\n\n    try {\n      d = 1, o += \'<div class="mdl-grid" data-hook="transform-categorial-panel">\', d = 3, o += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetCategorialIcon"></div>\', d = 5, o += \'<div class="mdl-cell mdl-cell--1-col"></div>\', d = 7, o += \'<div class="mdl-cell mdl-cell--8-col">\', d = 8, o += \'<div class="mdl-grid" id="transform-categorial-div">\', d = 10, o += \'<div class="mdl-cell mdl-cell--4-col" data-hook="categorial-addone-button">\', d = 11, o += \'<button class="mdl-button mdl-js-button mdl-js-ripple-effect">\', d = 11, o += "Add a rule</button></div>", d = 13, o += \'<div class="mdl-cell mdl-cell--4-col" data-hook="categorial-removeall-button">\', d = 14, o += \'<button class="mdl-button mdl-js-button mdl-js-ripple-effect">\', d = 14, o += "Remove all rules</button></div>", d = 16, o += \'<div class="mdl-cell mdl-cell--12-col">\', d = 17, o += "<table>", d = 18, o += "<thead>", d = 19, o += "<tr>", d = 20, o += "<th>", d = 20, o += "Text</th>", d = 21, o += "<th>", d = 21, o += "Group</th>", d = 22, o += "<th>", d = 22, o += "Count</th>", d = 23, o += "<th>", d = 23, o += "Remove</th></tr></thead>", d = 24, o += \'<tbody data-hook="categorial-rules-table"></tbody></table></div></div>\', d = 26, o += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="transform-categorial-div">\', d = 26, o += " ", d = 27, o += "Assign facet values to grous.</div></div>", d = 29, o += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\';\n    } catch (a) {\n      pug.rethrow(a, t, d);\n    }\n\n    return o;\n  };\n\n  puglatizer["configureFacet"]["facetTransformContinuous"] = function template(l) {\n    var e,\n        d,\n        a = "";\n\n    try {\n      d = 1, a += \'<div class="mdl-grid" data-hook="transform-continuous-panel">\', d = 3, a += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetContinuousIcon"></div>\', d = 5, a += \'<div class="mdl-cell mdl-cell--1-col"></div>\', d = 7, a += \'<div class="mdl-cell mdl-cell--8-col mdl-grid">\', d = 9, a += \'<div class="mdl-cell mdl-cell--4-col">\', d = 10, a += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="define-transform-none">\', d = 11, a += \'<input class="mdl-radio__button" id="define-transform-none" data-hook="define-transform-none" type="radio" name="transformtype" value="none"/>\', d = 17, a += \'<span class="mdl-radio__label">\', d = 17, a += "No transform</span></label></div>", d = 19, a += \'<div class="mdl-cell mdl-cell--4-col">\', d = 20, a += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="define-transform-percentiles">\', d = 21, a += \'<input class="mdl-radio__button" id="define-transform-percentiles" data-hook="define-transform-percentiles" type="radio" name="transformtype" value="percentiles"/>\', d = 27, a += \'<span class="mdl-radio__label">\', d = 27, a += "Percentiles</span></label></div></div>", d = 29, a += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\';\n    } catch (s) {\n      pug.rethrow(s, e, d);\n    }\n\n    return a;\n  };\n\n  puglatizer["configureFacet"]["facetTransformDatetime"] = function template(l) {\n    var e,\n        d,\n        t = "";\n\n    try {\n      d = 1, t += \'<div class="mdl-grid" data-hook="transform-time-panel">\', d = 3, t += \'<div class="mdl-grid mdl-cell mdl-cell--12-col">\', d = 4, t += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetTimeIcon"></div>\', d = 5, t += \'<div class="mdl-cell mdl-cell--1-col"></div>\', d = 7, t += \'<div class="mdl-cell mdl-cell--8-col mdl-grid">\', d = 9, t += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="transform-time-format-div">\', d = 10, t += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--6-col">\', d = 11, t += \'<input class="mdl-textfield__input" id="transform-time-format" data-hook="transform-time-format-input" type="text"/>\', d = 15, t += \'<label class="mdl-textfield__label" for="transform-time-format">\', d = 15, t += "Input time format</label></div>", d = 17, t += \'<div class="mdl-cell mdl-cell--6-col" data-hook="time-zones"></div></div>\', d = 19, t += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="transform-time-transformedformat-div">\', d = 20, t += \'<div class="mdl-cell mdl-cell--6-col">\', d = 21, t += "Select datetime part</div>", d = 22, t += \'<div class="mdl-cell mdl-cell--6-col" data-hook="time-parts"></div></div>\', d = 24, t += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="transform-time-transformedreference-div">\', d = 25, t += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--6-col">\', d = 26, t += \'<input class="mdl-textfield__input" id="transform-time-transformedreference" data-hook="transform-time-transformedreference-input" type="text"/>\', d = 30, t += \'<label class="mdl-textfield__label" for="transform-time-transformedreference">\', d = 30, t += "Add/subtract reference time</label></div>", d = 32, t += \'<div class="mdl-cell mdl-cell--6-col" data-hook="transformed-time-zones"></div></div></div>\', d = 34, t += \'<div class="mdl-cell mdl-cell--2-col"></div></div></div>\';\n    } catch (m) {\n      pug.rethrow(m, e, d);\n    }\n\n    return t;\n  };\n\n  puglatizer["configureFacet"]["facetTransformDuration"] = function template(l) {\n    var d,\n        e,\n        c = "";\n\n    try {\n      e = 1, c += \'<div class="mdl-grid" data-hook="transform-duration-panel">\', e = 3, c += \'<div class="mdl-grid mdl-cell mdl-cell--12-col">\', e = 4, c += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetTimeIcon"></div>\', e = 5, c += \'<div class="mdl-cell mdl-cell--1-col"></div>\', e = 7, c += \'<div class="mdl-cell mdl-cell--8-col mdl-grid">\', e = 9, c += \'<div class="mdl-cell mdl-cell--12-col mdl-grid">\', e = 10, c += \'<div class="mdl-cell mdl-cell--6-col">\', e = 11, c += "Input units </div>", e = 12, c += \'<div class="mdl-cell mdl-cell--6-col" data-hook="duration-units"></div></div>\', e = 14, c += \'<div class="mdl-cell mdl-cell--12-col mdl-grid">\', e = 15, c += \'<div class="mdl-cell mdl-cell--6-col">\', e = 16, c += "Output units</div>", e = 17, c += \'<div class="mdl-cell mdl-cell--6-col" data-hook="transformed-duration-units"></div></div>\', e = 19, c += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="transform-duration-transformedreference-div">\', e = 20, c += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--6-col">\', e = 21, c += \'<input class="mdl-textfield__input" id="transform-duration-transformedreference" data-hook="transform-duration-transformedreference-input" type="text"/>\', e = 25, c += \'<label class="mdl-textfield__label" for="transform-duration-transformedreference">\', e = 25, c += "Add/subtract reference time</label></div>", e = 27, c += \'<div class="mdl-cell mdl-cell--6-col" data-hook="transformed-duration-zone"></div></div></div>\', e = 29, c += \'<div class="mdl-cell mdl-cell--2-col"></div></div></div>\';\n    } catch (i) {\n      pug.rethrow(i, d, e);\n    }\n\n    return c;\n  };\n\n  puglatizer["configureFacet"]["page"] = function template(a) {\n    var d,\n        t,\n        o = "";\n\n    try {\n      t = 1, o += \'<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">\', t = 2, o += \'<main class="mdl-layout__content" style="background-color: white;">\', t = 3, o += \'<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">\', t = 4, o += \'<header class="demo-header mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600">\', t = 5, o += \'<div class="mdl-layout__header-row">\', t = 6, o += \'<span class="mdl-layout-title">\', t = 6, o += "Configure facet</span></div></header>", t = 8, o += "<main>", t = 9, o += \'<div data-hook="facet-define"></div>\', t = 11, o += \'<div data-hook="transform-categorial-panel">\', t = 12, o += \'<div data-hook="facet-transform-categorial"></div></div>\', t = 13, o += \'<div data-hook="transform-continuous-panel">\', t = 14, o += \'<div data-hook="facet-transform-continuous"></div></div>\', t = 15, o += \'<div data-hook="transform-datetime-panel">\', t = 16, o += \'<div data-hook="facet-transform-datetime"></div></div>\', t = 17, o += \'<div data-hook="transform-duration-panel">\', t = 18, o += \'<div data-hook="facet-transform-duration"></div></div></main></div></main></div>\';\n    } catch (e) {\n      pug.rethrow(e, d, t);\n    }\n\n    return o;\n  };\n\n  puglatizer["configurePartition"] = {};\n\n  puglatizer["configurePartition"]["group"] = function template(t) {\n    var r,\n        o,\n        a = "";\n\n    try {\n      o = 1, a += "<tr>", o = 2, a += \'<td data-hook="group-label"></td>\', o = 3, a += \'<td data-hook="group-count"></td></tr>\';\n    } catch (d) {\n      pug.rethrow(d, r, o);\n    }\n\n    return a;\n  };\n\n  puglatizer["configurePartition"]["page"] = function template(l) {\n    var d,\n        t,\n        i = "";\n\n    try {\n      t = 1, i += \'<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">\', t = 2, i += \'<main class="mdl-layout__content" style="background-color: white;">\', t = 4, i += \'<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">\', t = 5, i += \'<header class="demo-header mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600">\', t = 6, i += \'<div class="mdl-layout__header-row">\', t = 7, i += \'<span class="mdl-layout-title">\', t = 7, i += "Configure partition</span></div></header>", t = 9, i += "<main>", t = 10, i += \'<div class="mdl-grid" data-hook="partition-general">\', t = 11, i += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetInfoIcon"></div>\', t = 12, i += \'<div class="mdl-cell mdl-cell--1-col"></div>\', t = 13, i += \'<div class="mdl-cell mdl-cell--8-col">\', t = 14, i += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="partition-label-div">\', t = 15, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--12-col">\', t = 16, i += \'<input class="mdl-textfield__input" id="partition-title" data-hook="partition-title-input" type="text"/>\', t = 20, i += \'<label class="mdl-textfield__label" for="">\', t = 20, i += "Label</label></div></div>", t = 22, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="partition-label-div">\', t = 23, i += "The label along this axis</div>", t = 25, i += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="partition-options-div">\', t = 26, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--3-col">\', t = 27, i += \'<label class="mdl-checkbox mdl-js-checkbox mdl-js-ripple-effect" for="partition-cb1">\', t = 28, i += \'<input class="mdl-checkbox__input" type="checkbox" id="partition-cb1" data-hook="show-label"/>\', t = 29, i += \'<span class="mdl-checkbox__label">\', t = 29, i += "Show label</span></label></div>", t = 31, i += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--3-col">\', t = 32, i += \'<label class="mdl-checkbox mdl-js-checkbox mdl-js-ripple-effect" for="partition-cb2">\', t = 33, i += \'<input class="mdl-checkbox__input" type="checkbox" id="partition-cb2" data-hook="show-legend"/>\', t = 34, i += \'<span class="mdl-checkbox__label">\', t = 34, i += "Show legend</span></label></div>", t = 36, i += "\x3c!-- div.mdl-textfield.mdl-js-textfield.mdl-textfield--floating-label.mdl-cell.mdl-cell--3-col--\x3e", t = 37, i += \'\x3c!--   label(for="partition-cb3").mdl-checkbox.mdl-js-checkbox.mdl-js-ripple-effect--\x3e\', t = 38, i += \'\x3c!--     input(type="checkbox" id="partition-cb3" data-hook="accumulative").mdl-checkbox__input--\x3e\', t = 39, i += "\x3c!--     span.mdl-checkbox__label Accumulative--\x3e", t = 41, i += "\x3c!-- div.mdl-textfield.mdl-js-textfield.mdl-textfield--floating-label.mdl-cell.mdl-cell--3-col--\x3e", t = 42, i += \'\x3c!--   label(for="partition-cb4").mdl-checkbox.mdl-js-checkbox.mdl-js-ripple-effect--\x3e\', t = 43, i += \'\x3c!--     input(type="checkbox" id="partition-cb4" data-hook="relative").mdl-checkbox__input--\x3e\', t = 44, i += "\x3c!--     span.mdl-checkbox__label Relative--\x3e</div>", t = 46, i += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="partition-options-div">\', t = 47, i += "Set various options for this partition</div></div>", t = 49, i += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\', t = 51, i += \'<div class="mdl-grid" data-hook="partition-continuous"></div>\', t = 52, i += \'<div class="mdl-grid" data-hook="partition-categorial"></div>\', t = 53, i += \'<div class="mdl-grid" data-hook="partition-datetime"></div>\', t = 54, i += \'<div class="mdl-grid" data-hook="partition-duration"></div>\', t = 55, i += \'<div class="mdl-grid" data-hook="partition-text"></div></main></div></main></div>\';\n    } catch (e) {\n      pug.rethrow(e, d, t);\n    }\n\n    return i;\n  };\n\n  puglatizer["configurePartition"]["partitionCategorial"] = function template(l) {\n    var t,\n        d,\n        o = "";\n\n    try {\n      d = 1, o += \'<div class="mdl-grid" data-hook="group-categorial-panel">\', d = 2, o += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetCategorialIcon"></div>\', d = 3, o += \'<div class="mdl-cell mdl-cell--1-col"></div>\', d = 4, o += \'<div class="mdl-cell mdl-cell--8-col">\', d = 5, o += \'<div class="mdl-cell mdl-cell--12-col">\', d = 6, o += \'<table style="width: 100%">\', d = 7, o += "<thead>", d = 8, o += "<tr>", d = 9, o += "<th>", d = 10, o += \'<button class="mdl-button mdl-js-button" data-hook="group-order-abc">\', d = 10, o += "label</button></th>", d = 11, o += "<th>", d = 12, o += \'<button class="mdl-button mdl-js-button" data-hook="group-order-count">\', d = 12, o += "count</button></th></tr></thead>", d = 13, o += \'<tbody data-hook="groups-table"></tbody></table></div></div>\', d = 14, o += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\';\n    } catch (c) {\n      pug.rethrow(c, t, d);\n    }\n\n    return o;\n  };\n\n  puglatizer["configurePartition"]["partitionContinuous"] = function template(l) {\n    var d,\n        i,\n        e = "";\n\n    try {\n      i = 1, e += \'<div class="mdl-grid" data-hook="group-continuous-panel">\', i = 2, e += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetContinuousIcon"></div>\', i = 3, e += \'<div class="mdl-cell mdl-cell--1-col"></div>\', i = 4, e += \'<div class="mdl-cell mdl-cell--8-col">\', i = 5, e += \'<div class="mdl-grid mdl-cell mdl-cell--12-col">\', i = 7, e += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="group-range-div">\', i = 8, e += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col">\', i = 9, e += \'<input class="mdl-textfield__input" id="group-minimum" data-hook="group-minimum-input" type="text" pattern="-?[0-9]*(.[0-9]+)?(e[+-][0-9]+)?"/>\', i = 14, e += \'<label class="mdl-textfield__label" for="group-minimum">\', i = 14, e += "Minimum value</label>", i = 15, e += \'<span class="mdl-textfield__error">\', i = 15, e += "Input is not a number!</span></div>", i = 17, e += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col">\', i = 18, e += \'<input class="mdl-textfield__input" id="group-maximum" data-hook="group-maximum-input" type="text" pattern="-?[0-9]*(.[0-9]+)?(e[+-][0-9]+)?"/>\', i = 23, e += \'<label class="mdl-textfield__label" for="group-maximum">\', i = 23, e += "Maximum value</label>", i = 24, e += \'<span class="mdl-textfield__error">\', i = 24, e += "Input is not a number!</span></div>", i = 26, e += \'<div class="mdl-cell mdl-cell--4-col" data-hook="group-range-button">\', i = 27, e += \'<button class="mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--accent">\', i = 27, e += "Reset ranges</button></div></div>", i = 29, e += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="group-range-div">\', i = 30, e += "Reset mininum and maximum values.</div>", i = 33, e += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="group-param-div">\', i = 34, e += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--12-col">\', i = 35, e += \'<input class="mdl-textfield__input" id="group-param" data-hook="group-param-input" type="text" pattern="-?[0-9]*(.[0-9]+)?"/>\', i = 40, e += \'<label class="mdl-textfield__label" for="sample4">\', i = 40, e += "Number of bins or binsize</label>", i = 41, e += \'<span class="mdl-textfield__error">\', i = 41, e += "Input is not a number!</span></div></div>", i = 43, e += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="group-param-div">\', i = 44, e += "Set the number of bins, or the bin size</div>", i = 47, e += \'<div class="mdl-grid mdl-cell mdl-cell--12-col" id="group-distribution-div">\', i = 49, e += \'<div class="mdl-cell mdl-cell--3-col">\', i = 50, e += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="group-fixedn">\', i = 51, e += \'<input class="mdl-radio__button" id="group-fixedn" data-hook="group-fixedn-input" type="radio" name="group-distribution" value="fixedn"/>\', i = 57, e += \'<span class="mdl-radio__label">\', i = 57, e += "Fixed number of bins</span></label></div>", i = 59, e += \'<div class="mdl-cell mdl-cell--3-col">\', i = 60, e += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="group-fixedsc">\', i = 61, e += \'<input class="mdl-radio__button" id="group-fixedsc" data-hook="group-fixedsc-input" type="radio" name="group-distribution" value="fixedsc"/>\', i = 67, e += \'<span class="mdl-radio__label">\', i = 67, e += "Fixed bin size (centered)</span></label></div>", i = 69, e += \'<div class="mdl-cell mdl-cell--3-col">\', i = 70, e += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="group-fixeds">\', i = 71, e += \'<input class="mdl-radio__button" id="group-fixeds" data-hook="group-fixeds-input" type="radio" name="group-distribution" value="fixeds"/>\', i = 77, e += \'<span class="mdl-radio__label">\', i = 77, e += "Fixed bin size</span></label></div>", i = 79, e += \'<div class="mdl-cell mdl-cell--3-col">\', i = 80, e += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="group-log">\', i = 81, e += \'<input class="mdl-radio__button" id="group-log" data-hook="group-log-input" type="radio" name="group-distribution" value="log"/>\', i = 87, e += \'<span class="mdl-radio__label">\', i = 87, e += "Logarithmic</span></label></div></div></div></div>", i = 89, e += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\';\n    } catch (a) {\n      pug.rethrow(a, d, i);\n    }\n\n    return e;\n  };\n\n  puglatizer["configurePartition"]["partitionDatetime"] = function template(l) {\n    var t,\n        e,\n        d = "";\n\n    try {\n      e = 1, d += \'<div class="mdl-grid" data-hook="group-datetime-panel">\', e = 2, d += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetTimeIcon"></div>\', e = 3, d += \'<div class="mdl-cell mdl-cell--1-col"></div>\', e = 4, d += \'<div class="mdl-cell mdl-cell--8-col mdl-grid">\', e = 5, d += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="group-datetimerange-div">\', e = 6, d += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--3-col">\', e = 7, d += \'<input class="mdl-textfield__input" id="group-startdate" data-hook="group-startdate-input" type="text"/>\', e = 11, d += \'<label class="mdl-textfield__label" for="group-startdate">\', e = 11, d += "Start date</label></div>", e = 13, d += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--3-col">\', e = 14, d += \'<input class="mdl-textfield__input" id="group-enddate" data-hook="group-enddate-input" type="text"/>\', e = 18, d += \'<label class="mdl-textfield__label" for="group-enddate">\', e = 18, d += "End date</label></div>", e = 20, d += \'<div class="mdl-cell mdl-cell--3-col">\', e = 21, d += \'<div data-hook="time-zones"></div></div>\', e = 23, d += \'<div class="mdl-cell mdl-cell--3-col">\', e = 24, d += \'<select data-hook="time-units">\', e = 25, d += \'<option value="auto">\', e = 25, d += "auto</option>", e = 26, d += \'<option value="milliseconds">\', e = 26, d += "milliseconds</option>", e = 27, d += \'<option value="seconds">\', e = 27, d += "seconds</option>", e = 28, d += \'<option value="minutes">\', e = 28, d += "minutes</option>", e = 29, d += \'<option value="hours">\', e = 29, d += "hours</option>", e = 30, d += \'<option value="days">\', e = 30, d += "days</option>", e = 31, d += \'<option value="weeks">\', e = 31, d += "weeks</option>", e = 32, d += \'<option value="months">\', e = 32, d += "months</option>", e = 33, d += \'<option value="years">\', e = 33, d += "years</option></select></div></div>", e = 35, d += \'<div class="mdl-cell mdl-cell--12-col" data-hook="group-datetimerange-button">\', e = 36, d += \'<button class="mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--accent">\', e = 36, d += "Reset ranges</button></div></div>", e = 38, d += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\';\n    } catch (o) {\n      pug.rethrow(o, t, e);\n    }\n\n    return d;\n  };\n\n  puglatizer["configurePartition"]["partitionDuration"] = function template(l) {\n    var d,\n        t,\n        e = "";\n\n    try {\n      t = 1, e += \'<div class="mdl-grid" data-hook="group-duration-panel">\', t = 2, e += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetTimeIcon"></div>\', t = 3, e += \'<div class="mdl-cell mdl-cell--1-col"></div>\', t = 4, e += \'<div class="mdl-cell mdl-cell--8-col">\', t = 5, e += \'<div class="mdl-grid mdl-cell mdl-cell--12-col">\', t = 7, e += \'<div class="mdl-cell mdl-cell--12-col mdl-grid" id="group-durationrange-div">\', t = 8, e += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col">\', t = 9, e += \'<input class="mdl-textfield__input" id="group-startduration" data-hook="group-startduration-input" type="text"/>\', t = 13, e += \'<label class="mdl-textfield__label" for="group-startduration">\', t = 13, e += "Start interval</label></div>", t = 15, e += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col">\', t = 16, e += \'<input class="mdl-textfield__input" id="group-endduration" data-hook="group-endduration-input" type="text"/>\', t = 20, e += \'<label class="mdl-textfield__label" for="group-endduration">\', t = 20, e += "End interval</label></div>", t = 22, e += \'<div class="mdl-cell mdl-cell--4-col" data-hook="group-durationrange-button">\', t = 23, e += \'<button class="mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--accent">\', t = 23, e += "Reset ranges</button></div></div>", t = 25, e += \'<div class="mdl-tooltip mdl-tooltip--large mdl-tooltip--right" for="group-durationrange-div">\', t = 26, e += "Reset start and end interval</div></div></div>", t = 28, e += \'<div class="mdl-cell mdl-cell--2-col"></div></div>\';\n    } catch (i) {\n      pug.rethrow(i, d, t);\n    }\n\n    return e;\n  };\n\n  puglatizer["configurePartition"]["partitionText"] = function template(l) {\n    var d,\n        c,\n        t = "";\n\n    try {\n      c = 1, t += \'<div class="mdl-grid" data-hook="group-text-panel">\', c = 2, t += \'<div class="mdl-cell mdl-cell--1-col facetIcon facetTextIcon"></div>\', c = 3, t += \'<div class="mdl-cell mdl-cell--1-col"></div>\', c = 4, t += \'<div class="mdl-cell mdl-cell--8-col">\', c = 5, t += \'<div class="mdl-grid mdl-cell mdl-cell--12-col">\', c = 7, t += \'<div class="mdl-cell mdl-cell--3-col" data-hook="group-order-abc">\', c = 8, t += \'<button class="mdl-button mdl-js-button mdl-js-ripple-effect">\', c = 8, t += "Order alfabetically</button></div>", c = 10, t += \'<div class="mdl-cell mdl-cell--3-col" data-hook="group-order-count">\', c = 11, t += \'<button class="mdl-button mdl-js-button mdl-js-ripple-effect">\', c = 11, t += "Order by count</button></div></div></div></div>";\n    } catch (e) {\n      pug.rethrow(e, d, c);\n    }\n\n    return t;\n  };\n\n  puglatizer["datasets"] = {};\n\n  puglatizer["datasets"]["dataset"] = function template(t) {\n    var a,\n        d,\n        l = "";\n\n    try {\n      d = 1, l += \'<div class="mdl-card mdl-shadow--2dp" data-hook="dataset" style="min-height: inherit">\', d = 2, l += \'<div class="mdl-card__title">\', d = 3, l += \'<h2 class="mdl-card__title-text" data-hook="name"></h2></div>\', d = 5, l += \'<div class="mdl-card__supporting-text" data-hook="description"></div>\', d = 7, l += \'<div class="mdl-card__actions mdl-card--border">\', d = 8, l += \'<a class="mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect" data-hook="delete">\', d = 9, l += "Delete</a>", d = 10, l += \'<button class="mdl-button mdl-js button mdl-button--icon mdl-button--colored" data-hook="settings" style="float: right">\', d = 11, l += \'<i class="material-icons">\', d = 11, l += "settings</i></button></div>", d = 13, l += \'<div class="mdl-card__menu">\', d = 14, l += \'<span class="mdl-spinner mdl-js-spinner is-active" data-hook="cbspinner"></span>\', d = 15, l += \'<span data-hook="cbtoggle">\', d = 16, l += \'<label class="mdl-switch mdl-js-switch mdl-js-ripple-effect" data-hook="cblabel" for="">\', d = 17, l += \'<input class="mdl-switch__input" data-hook="cb" type="checkbox" id=""/></label>\', d = 18, l += \'<span class="mdl-switch__label"></span></span></div></div>\';\n    } catch (s) {\n      pug.rethrow(s, a, d);\n    }\n\n    return l;\n  };\n\n  puglatizer["datasets"]["datasetCollection"] = function template(t) {\n    var a,\n        e,\n        r = "";\n\n    try {\n      e = 1, r += \'<div data-hook="items" style="display: flex; flex-wrap: wrap;"></div>\';\n    } catch (i) {\n      pug.rethrow(i, a, e);\n    }\n\n    return r;\n  };\n\n  puglatizer["datasets"]["page"] = function template(t) {\n    var a,\n        l,\n        d = "";\n\n    try {\n      l = 1, d += \'<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">\', l = 2, d += \'<main class="mdl-layout__content" style="background-color: white;">\', l = 3, d += "<div>", l = 5, d += \'<div class="mdl-grid">\', l = 6, d += \'<dialog class="mdl-dialog" data-hook="CSV-settings">\', l = 7, d += \'<div class="mdl-dialog__content">\', l = 8, d += \'<section class="mdl-grid" id="csv-settings-table" name="csv-settings-table">\', l = 9, d += "<div>", l = 10, d += \'<table class="mdl-data-table mdl-js-data-table">\', l = 11, d += "<tbody>", l = 12, d += "<tr>", l = 13, d += "<td>", l = 13, d += "Headers</td>", l = 14, d += "<td>", l = 15, d += "<span>", l = 16, d += \'<label class="mdl-checkbox mdl-js-checkbox mdl-js-ripple-effect" for="CSV-header-columns">\', l = 17, d += "Enable", l = 18, d += \'<input class="mdl-checkbox__input" type="checkbox" id="CSV-header-columns"/></label></span></td></tr>\', l = 19, d += "<tr>", l = 20, d += "<td>", l = 20, d += "Delimiter</td>", l = 21, d += "<td>", l = 22, d += "<span>", l = 23, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-separator-comma">\', l = 24, d += \'<input class="mdl-radio__button" type="radio" id="CSV-separator-comma" name="CSV-separator-options" value="comma"/></label></span>\', l = 25, d += \'<span class="mdl-typography--title-color-contrast">\', l = 26, d += ",</span></td>", l = 27, d += "<td>", l = 28, d += "<span>", l = 29, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-separator-colon">\', l = 30, d += \'<input class="mdl-radio__button" type="radio" id="CSV-separator-colon" name="CSV-separator-options" value="colon"/></label></span>\', l = 31, d += \'<span class="mdl-typography--title-color-contrast">\', l = 32, d += ":</span></td>", l = 33, d += "<td>", l = 34, d += "<span>", l = 35, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-separator-semicolon">\', l = 36, d += \'<input class="mdl-radio__button" type="radio" id="CSV-separator-semicolon" name="CSV-separator-options" value="semicolon"/></label></span>\', l = 37, d += \'<span class="mdl-typography--title-color-contrast">\', l = 38, d += ";</span></td>", l = 39, d += "<td>", l = 40, d += "<span>", l = 41, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-separator-pipe">\', l = 42, d += \'<input class="mdl-radio__button" type="radio" id="CSV-separator-pipe" name="CSV-separator-options" value="pipe"/></label></span>\', l = 43, d += \'<span class="mdl-typography--title-color-contrast">\', l = 44, d += "|</span></td>", l = 45, d += "<td>", l = 46, d += "<span>", l = 47, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-separator-tab">\', l = 48, d += \'<input class="mdl-radio__button" type="radio" id="CSV-separator-tab" name="CSV-separator-options" value="tab"/></label></span>\', l = 49, d += "<span>", l = 50, d += "Tab</span></td>", l = 51, d += "<td>", l = 52, d += "<span>", l = 53, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-separator-other">\', l = 54, d += \'<input class="mdl-radio__button" type="radio" data-hook="CSV-separator-other" id="CSV-separator-other" name="CSV-separator-options" value="other"/></label></span>\', l = 55, d += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label" style="width: fit-content;">\', l = 56, d += \'<input class="mdl-textfield__input" data-hook="CSV-separator-other-input" type="text" id="CSV-separator-other-input" name="CSV-separator-other-input"/>\', l = 57, d += \'<label class="mdl-textfield__label" for="CSV-separator-other-input">\', l = 58, d += "Other</label></div></td></tr>", l = 59, d += "<tr>", l = 60, d += "<td>", l = 60, d += "Quoting</td>", l = 61, d += "<td>", l = 62, d += "<span>", l = 63, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-quote-none">\', l = 64, d += \'<input class="mdl-radio__button" type="radio" id="CSV-quote-none" name="CSV-quote" value="none"/></label></span>\', l = 65, d += "<span>", l = 66, d += "None</span></td>", l = 67, d += "<td>", l = 68, d += "<span>", l = 69, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-quote-single">\', l = 70, d += \'<input class="mdl-radio__button" type="radio" id="CSV-quote-single" name="CSV-quote" value="single"/></label></span>\', l = 71, d += \'<span class="mdl-typography--title-color-contrast">\', l = 72, d += "\'</span></td>", l = 73, d += "<td>", l = 74, d += "<span>", l = 75, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-quote-double">\', l = 76, d += \'<input class="mdl-radio__button" type="radio" id="CSV-quote-double" name="CSV-quote" value="double"/></label></span>\', l = 77, d += \'<span class="mdl-typography--title-color-contrast">\', l = 78, d += \'"</span></td></tr>\', l = 79, d += "<tr>", l = 80, d += "<td>", l = 80, d += "Comments</td>", l = 81, d += "<td>", l = 82, d += "<span>", l = 83, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-comment-pound">\', l = 84, d += \'<input class="mdl-radio__button" type="radio" id="CSV-comment-pound" name="CSV-comment" value="pound"/></label></span>\', l = 85, d += \'<span class="mdl-typography--title-color-contrast">\', l = 86, d += "#</span></td>", l = 87, d += "<td>", l = 88, d += "<span>", l = 89, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-comment-exclamation">\', l = 90, d += \'<input class="mdl-radio__button" type="radio" id="CSV-comment-exclamation" name="CSV-comment" value="exclamation"/></label></span>\', l = 91, d += \'<span class="mdl-typography--title-color-contrast">\', l = 92, d += "!</span></td>", l = 93, d += "<td>", l = 94, d += "<span>", l = 95, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-comment-slash">\', l = 96, d += \'<input class="mdl-radio__button" type="radio" id="CSV-comment-slash" name="CSV-comment" value="slash"/></label></span>\', l = 97, d += \'<span class="mdl-typography--title-color-contrast">\', l = 98, d += "/</span></td>", l = 99, d += "<td>", l = 100, d += "<span>", l = 101, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-comment-dash">\', l = 102, d += \'<input class="mdl-radio__button" type="radio" id="CSV-comment-dash" name="CSV-comment" value="dash"/></label></span>\', l = 103, d += \'<span class="mdl-typography--title-color-contrast">\', l = 104, d += "-</span></td>", l = 105, d += "<td>", l = 106, d += "<span>", l = 107, d += \'<label class="mdl-radio mdl-js-radio mdl-js-ripple-effect" for="CSV-comment-percent">\', l = 108, d += \'<input class="mdl-radio__button" type="radio" id="CSV-comment-percent" name="CSV-comment" value="percent"/></label></span>\', l = 109, d += \'<span class="mdl-typography--title-color-contrast">\', l = 110, d += "%</span></td></tr></tbody></table></div></section>", l = 112, d += \'<div class="mdl-dialog__actions mdl-dialog__actions">\', l = 114, d += \'<button class="mdl-button close" data-hook="CSV-settings-close" type="button">\', l = 114, d += "Close</button></div></div></dialog></div>", l = 116, d += \'<dialog class="mdl-dialog" data-hook="session-download-cloud">\', l = 117, d += \'<div class="mdl-dialog__content">\', l = 118, d += "<p></p>", l = 119, d += "Enter the url of the session. <br/>Make sure that you saved your current session!", l = 120, d += \'<div class="mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--12-col">\', l = 121, d += \'<input class="mdl-textfield__input" id="session-import-remote-link" data-hook="session-import-remote-link" type="text"/></div></div>\', l = 122, d += \'<div class="mdl-dialog__actions mdl-dialog__actions">\', l = 123, d += \'<button class="mdl-button" data-hook="session-download-cloud-get" type="button">\', l = 123, d += "Import</button>", l = 124, d += \'<button class="mdl-button close" data-hook="session-download-cloud-close-button" type="button">\', l = 124, d += "Cancel</button></div></dialog>", l = 127, d += \'<header class="mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600">\', l = 128, d += \'<div class="mdl-layout__header-row">\', l = 129, d += \'<span class="mdl-layout-title" style="padding: 0; text-align: center;">\', l = 129, d += "Datasets</span>", l = 131, d += \'<div class="mdl-layout-spacer"></div>\', l = 133, d += \'<button class="mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect" data-hook="search-button" id="tt3" data-position="bottom" data-step="1" data-intro="You can search available datasets here.">\', l = 134, d += \'<i class="material-icons">\', l = 134, d += "search</i></button>", l = 136, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="tt3">\', l = 137, d += "Show or hide search bar</div></div>", l = 139, d += \'<div class="mdl-layout__header-row" data-hook="search-bar">\', l = 140, d += \'<div class="mdl-layout-spacer"></div>\', l = 141, d += \'<span class="mdl-color--white mdl-color-text--primary searchBar">\', l = 143, d += \'<span class="mdl-textfield searchBar">\', l = 144, d += \'<input class="mdl-textfield__input searchBar" data-hook="dataset-selector" type="text" id="tt5"/>\', l = 145, d += \'<div class="mdl-tooltip mdl-tooltip--large" for="tt5">\', l = 146, d += "Search facet name and description</div></span></span></div>", l = 148, d += \'<div data-hook="add-datasets-div" id="add-datasets-div">\', l = 149, d += \'<div style="display: flex; align-items: center; justify-content: center;">\', l = 150, d += \'<div class="data-page-card-button mdl-card mdl-shadow--2dp">\', l = 151, d += \'<div class="mdl-card__title">\', l = 152, d += \'<button class="mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect serverconnect-btn" data-hook="server-connect" id="serverButton">\', l = 153, d += "Connect</button></div>", l = 154, d += \'<div class="mdl-card__supporting-text">\', l = 155, d += "Connect to a PostgreSQL server.</div></div>", l = 157, d += \'<div class="data-page-card-button mdl-card mdl-shadow--2dp">\', l = 158, d += \'<div class="mdl-card__title">\', l = 159, d += \'<label class="mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect jsonupload-btn" for="jsonuploadBtn" id="jsonUploadLabel">\', l = 160, d += "Import JSON</label>", l = 161, d += \'<input class="fileBtn" type="file" accept=".json" data-hook="json-upload-input" id="jsonuploadBtn"/></div>\', l = 162, d += \'<div class="mdl-card__supporting-text">\', l = 163, d += "Import a JSON file from your computer.</div></div>", l = 165, d += \'<div class="data-page-card-button mdl-card mdl-shadow--2dp">\', l = 166, d += \'<div class="mdl-card__title">\', l = 167, d += \'<label class="mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect csvupload-btn" for="csvuploadBtn">\', l = 168, d += "Import CSV</label>", l = 169, d += \'<input class="fileBtn" type="file" accept=".csv,.txt,.tsv" data-hook="csv-upload-input" id="csvuploadBtn"/></div>\', l = 170, d += \'<div class="mdl-card__supporting-text">\', l = 171, d += "Import a CSV file from your computer.</div>", l = 172, d += \'<div class="mdl-card__menu">\', l = 173, d += \'<button class="mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect" data-hook="CSV-settings-button" id="csv-settings-button">\', l = 174, d += \'<i class="material-icons">\', l = 174, d += "settings</i></button></div></div>", l = 176, d += \'<div class="data-page-card-button mdl-card mdl-shadow--2dp">\', l = 177, d += \'<div class="mdl-card__title">\', l = 178, d += \'<label class="mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect datadownload-btn" for="dataDownloadBtn">\', l = 179, d += "Download data</label>", l = 180, d += \'<a class="fileBtn" data-hook="data-download" id="dataDownloadBtn" download="download"></a></div>\', l = 181, d += \'<div class="mdl-card__supporting-text">\', l = 182, d += "Download the current data to your computer.</div></div></div></div>", l = 184, d += \'<div data-hook="dataset-items" style="width: 100%"></div></header>\', l = 187, d += \'<header class="mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600">\', l = 188, d += \'<div class="mdl-layout__header-row">\', l = 189, d += \'<span class="mdl-layout-title" style="padding: 0; text-align: center;">\', l = 189, d += "Sessions</span></div>", l = 191, d += \'<div data-hook="add-sessions-div" style="display: flex; align-items: center; justify-content: center;">\', l = 192, d += \'<div class="data-page-card-button mdl-card mdl-shadow--2dp">\', l = 193, d += \'<div class="mdl-card__title">\', l = 194, d += \'<a class="mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect sessiondownload-btn" data-hook="session-download" download="download">\', l = 195, d += "Export session</a></div>", l = 196, d += \'<div class="mdl-card__supporting-text">\', l = 197, d += "Save the current dashboard to your computer.</div></div>", l = 199, d += \'<div class="data-page-card-button mdl-card mdl-shadow--2dp">\', l = 200, d += \'<div class="mdl-card__title">\', l = 201, d += \'<label class="mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect sessionupload-btn" for="sessionuploadBtn" data-hook="session-upload">\', l = 202, d += "Import session</label>", l = 203, d += \'<input class="fileBtn" type="file" accept=".json" data-hook="session-upload-input" id="sessionuploadBtn"/></div>\', l = 204, d += \'<div class="mdl-card__supporting-text">\', l = 205, d += "Import a saved dashboard from your computer.</div></div>", l = 207, d += \'<div class="data-page-card-button mdl-card mdl-shadow--2dp">\', l = 208, d += \'<div class="mdl-card__title">\', l = 209, d += \'<a class="mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect sessionclouddown-btn" data-hook="session-cloud-download" cloud-download="cloud-download">\', l = 210, d += "Session by URL</a></div>", l = 211, d += \'<div class="mdl-card__supporting-text">\', l = 212, d += "Import a dashboard using URL.</div></div></div>", l = 214, d += \'<div data-hook="session-items" style="width: 100%"></div></header></div></main></div>\';\n    } catch (o) {\n      pug.rethrow(o, a, l);\n    }\n\n    return d;\n  };\n\n  puglatizer["datasets"]["session"] = function template(a) {\n    var d,\n        s,\n        t = "";\n\n    try {\n      s = 1, t += \'<div class="mdl-card mdl-shadow--2dp" data-hook="session" style="min-height: inherit">\', s = 2, t += \'<div class="mdl-card__title">\', s = 3, t += \'<h2 class="mdl-card__title-text" data-hook="date"></h2></div>\', s = 5, t += \'<div class="mdl-card__supporting-text" data-hook="description"></div>\', s = 7, t += \'<div class="mdl-card__actions mdl-card--border">\', s = 8, t += \'<a class="mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect" data-hook="delete">\', s = 9, t += "Delete</a></div>", s = 11, t += \'<div class="mdl-card__menu">\', s = 12, t += \'<span class="mdl-spinner mdl-js-spinner is-active" data-hook="cbspinner"></span>\', s = 13, t += \'<span data-hook="cbtoggle">\', s = 14, t += \'<label class="mdl-switch mdl-js-switch mdl-js-ripple-effect" data-hook="cblabel" for="">\', s = 15, t += \'<input class="mdl-switch__input" data-hook="cb" type="checkbox" id=""/></label>\', s = 16, t += \'<span class="mdl-switch__label"></span></span></div></div>\';\n    } catch (l) {\n      pug.rethrow(l, d, s);\n    }\n\n    return t;\n  };\n\n  puglatizer["datasets"]["sessionCollection"] = function template(t) {\n    var e,\n        a,\n        r = "";\n\n    try {\n      a = 1, r += \'<div data-hook="session-collection-items" style="display: flex; flex-wrap: wrap;"></div>\';\n    } catch (i) {\n      pug.rethrow(i, e, a);\n    }\n\n    return r;\n  };\n\n  puglatizer["head"] = function template(e) {\n    var t,\n        a,\n        n = "";\n\n    try {\n      a = 1, n += "<head>", a = 2, n += \'<meta charset="utf-8"/>\', a = 3, n += \'<meta http-equiv="X-UA-Compatible" content="IE=edge"/>\', a = 4, n += \'<meta name="description" content="Spot - extensible facet browser"/>\', a = 5, n += \'<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0"/>\', a = 6, n += "<title>", a = 7, n += "Spot</title>", a = 9, n += "\x3c!-- Add to homescreen for Chrome on Android --\x3e", a = 10, n += \'<meta name="mobile-web-app-capable" content="yes"/>\', a = 13, n += "\x3c!-- Add to homescreen for Safari on iOS --\x3e", a = 14, n += \'<meta name="apple-mobile-web-app-capable" content="yes"/>\', a = 15, n += \'<meta name="apple-mobile-web-app-status-bar-style" content="black"/>\', a = 16, n += \'<meta name="apple-mobile-web-app-title" content="Spot"/>\', a = 19, n += "\x3c!-- Tile icon for Win8 (144x144 + tile color) --\x3e", a = 21, n += \'<meta name="msapplication-TileColor" content="#3372DF"/></head>\';\n    } catch (o) {\n      pug.rethrow(o, t, a);\n    }\n\n    return n;\n  };\n\n  puglatizer["help"] = {};\n\n  puglatizer["help"]["analyze"] = function template(a) {\n    var e,\n        t,\n        p = "";\n\n    try {\n      t = 1, p += \'<div data-hook="analyze-help" id="analyze-help" data-position="bottom" data-step="1">\', t = 2, p += "<h4>", t = 2, p += "Analyze page Help</h4>", t = 3, p += "<p></p>", t = 4, p += "Text here<br />", t = 5, p += "\\n", t = 5, p += "<br /></div>";\n    } catch (r) {\n      pug.rethrow(r, e, t);\n    }\n\n    return p;\n  };\n\n  puglatizer["help"]["menuButtons"] = function template(e) {\n    var t,\n        a,\n        o = "";\n\n    try {\n      a = 1, o += \'<div data-hook="welcome-info" id="welcome-info" data-position="bottom" data-step="1">\', a = 2, o += "<p></p>", a = 3, o += "<h6>", a = 3, o += "You will find the following buttons on the left menu:</h6>", a = 4, o += "<lu>", a = 5, o += "<li>", a = 6, o += \'<i class="material-icons" role="presentation">\', a = 6, o += "menu</i>", a = 7, o += "button controls the menu drawer.</li>", a = 8, o += "<li>", a = 9, o += \'<i class="material-icons" role="presentation">\', a = 9, o += "home</i>", a = 10, o += "button opens the homepage. This is where you are at now.</li>", a = 11, o += "<li>", a = 12, o += \'<i class="material-icons" role="presentation">\', a = 12, o += "storage</i>", a = 13, o += "button takes you to Datasets page. In Datasets page, you can upload your dataset or use existing datasets. You can also configure your datasets.</li>", a = 14, o += "<li>", a = 15, o += \'<i class="material-icons" role="presentation">\', a = 15, o += "insert_chart</i>", a = 16, o += "button takes you to Analyze page. In Analyze page, you can create your dashboard in a few clicks by creating new charts.</li>", a = 17, o += "<li>", a = 18, o += \'<i class="material-icons" role="presentation">\', a = 18, o += "share</i>", a = 19, o += "button takes you to Share page. In share page, you can share your current session or load the session which is shared with you.</li>", a = 20, o += "<li>", a = 21, o += \'<i class="material-icons" role="presentation">\', a = 21, o += "help</i>", a = 22, o += "button guides you about the user interface.</li></lu></div>";\n    } catch (i) {\n      pug.rethrow(i, t, a);\n    }\n\n    return o;\n  };\n\n  puglatizer["help"]["welcome"] = function template(e) {\n    var t,\n        a,\n        o = "";\n\n    try {\n      a = 1, o += \'<div data-hook="welcome-info" id="welcome-info" data-position="bottom" data-step="1">\', a = 2, o += "<h4>", a = 2, o += "Welcome to SPOT!</h4>", a = 3, o += "<p></p>", a = 4, o += \'This software is being developed by the  <a href="https://www.esciencecenter.nl" target="_blank">Netherlands eScience Center</a>.<br />\', a = 5, o += "\\n", a = 5, o += "<br />", a = 6, o += "\\n", a = 6, o += \'SPOT is a free and an open source software. The license of the SPOT is  <a href="http://www.apache.org/licenses/LICENSE-2.0" target="_blank">Apache 2.0</a>.<br />\', a = 7, o += "\\n", a = 7, o += "<br />", a = 8, o += "\\n", a = 8, o += \'For the online tutorial of SPOT, please check <a href="https://nlesc.github.io/spot-tutorial/tutorial" target="_blank">this link</a>.<br />\', a = 9, o += "\\n", a = 9, o += "<br />", a = 10, o += "\\n", a = 10, o += "<br />", a = 11, o += "\\n", a = 11, o += \'The desktop version of SPOT can be downloaded from <a href="https://github.com/NLeSC/spot-desktop-app/releases" target="_blank">this link</a>.<br />\', a = 12, o += "\\n", a = 12, o += "<br>", a = 13, o += "\\n", a = 13, o += "You can click the button below to start a demo session. The demo session has <b>Kaggle Titanic Survival</b> dataset.", a = 15, o += "\\n", a = 15, o += "<br><br> Happy SPOTTING!<br></div>";\n    } catch (n) {\n      pug.rethrow(n, t, a);\n    }\n\n    return o;\n  };\n\n  puglatizer["home"] = function template(s) {\n    var a,\n        l,\n        e = "";\n\n    try {\n      l = 1, e += \'<main class="mdl-layout__content home-content bgspotImage">\', l = 2, e += \'<div class="content-grid mdl-grid mdl-cell--middle">\', l = 4, e += \'<div class="mdl-cell mdl-cell--12-col mdl-cell--0-offset mdl-shadow--2dp spot-cell spot-trans spot-color4">\', l = 6, e += \'<span class="cardTitleText material-icons menuIcon">\', l = 6, e += "explore</span>", l = 7, e += \'<span class="cardTitleText">\', l = 7, e += " SPOT: interactive, fast facet browser</span>", l = 8, e += "<ul>", l = 9, e += "<li>", l = 10, e += \'<p class="cardText">\', l = 10, e += "SPOT is an interactive, fast data visualization tool. It was primarily designed as data exploration and analysis tool for complex multi-dimensional datasets. Users can visualize the data only with a few clicks. SPOT can be used to compare different datasets. It is also possible to connect to a Postresql server to analyze big datasets.</p></li></ul></div>", l = 12, e += \'<div class="mdl-cell mdl-cell--4-col spot-cell spot-trans spot-color4">\', l = 13, e += \'<span class="cardTitleText material-icons menuIcon">\', l = 13, e += "merge_type</span>", l = 14, e += \'<span class="cardTitleText">\', l = 14, e += "Highlights</span>", l = 15, e += "<ul>", l = 16, e += "<li>", l = 17, e += \'<div class="cardText">\', l = 17, e += "Specifically designed for scientific data visualization</div></li>", l = 18, e += "<li>", l = 19, e += \'<div class="cardText">\', l = 19, e += "Fully animated and interactive charts</div></li>", l = 20, e += "<li>", l = 21, e += \'<div class="cardText">\', l = 21, e += "Exploration sessions can be saved</div></li>", l = 22, e += "<li>", l = 23, e += \'<div class="cardText">\', l = 23, e += "Database connection (Postgresql)</div></li></ul></div>", l = 25, e += \'<div class="mdl-cell mdl-cell--4-col spot-cell spot-trans spot-color4">\', l = 26, e += \'<span class="cardTitleText material-icons menuIcon">\', l = 26, e += "extension</span>", l = 27, e += \'<span class="cardTitleText">\', l = 27, e += "  Modern tools</span>", l = 28, e += "<ul>", l = 29, e += "<li>", l = 30, e += \'<div class="cardText">\', l = 30, e += "Viewer is fully standalone (no server required)</div></li>", l = 31, e += "<li>", l = 32, e += \'<div class="cardText">\', l = 32, e += "Responsive interface: material design lite</div></li>", l = 33, e += "<li>", l = 34, e += \'<div class="cardText">\', l = 34, e += "Fast filtering (~1M data points in ~30ms)</div></li>", l = 35, e += "<li>", l = 36, e += \'<div class="cardText">\', l = 36, e += "Cross platform (desktop, mobile and tablet)</div></li></ul></div>", l = 38, e += \'<div class="mdl-cell mdl-cell--4-col mdl-shadow--2dp spot-cell spot-trans spot-color4">\', l = 39, e += \'<span class="cardTitleText material-icons menuIcon">\', l = 39, e += "lock_open</span>", l = 40, e += \'<span class="cardTitleText">\', l = 40, e += "  Open Source</span>", l = 41, e += "<ul>", l = 42, e += "<li>", l = 43, e += \'<div class="cardText">\', l = 43, e += "Permissive Open source Licence (Apache 2.0)</div></li>", l = 44, e += "<li>", l = 45, e += \'<div class="cardText">\', l = 45, e += "Continuous Integration</div></li>", l = 46, e += "<li>", l = 47, e += \'<div class="cardText">\', l = 47, e += "Documented (jsdoc) and tested (jasmine)</div></li>", l = 48, e += "<li>", l = 49, e += \'<div class="cardText">\', l = 49, e += "Generic tool to be useful in any scientific project</div></li></ul></div></div>", l = 51, e += \'<div class="mdl-layout-spacer"></div>\', l = 53, e += \'<footer class="mdl-mega-footer spot-cell spot-trans spot-color4">\', l = 54, e += \'<div class="spot-footer">\', l = 58, e += \'<div class="spot-footer-item">\', l = 59, e += \'<a class="spotlink" data-hook="demo-session" href="">\', l = 60, e += \'<span class="footerImg material-icons menuIcon">\', l = 60, e += "ondemand_video</span>", l = 61, e += \'<span class="footerItem">\', l = 61, e += "Demo</span></a></div>", l = 62, e += \'<div class="spot-footer-item">\', l = 63, e += \'<a class="spotlink" data-hook="tutorialpage" href="https://nlesc.github.io/spot-tutorial/tutorial" target="_blank">\', l = 64, e += \'<span class="footerImg material-icons menuIcon">\', l = 64, e += "link</span>", l = 65, e += \'<span class="footerItem">\', l = 65, e += "Tutorial</span></a></div>", l = 66, e += \'<div class="spot-footer-item">\', l = 67, e += \'<a class="spotlink" data-hook="githubpage" href="https://github.com/NLeSC/spot" target="_blank">\', l = 68, e += \'<span class="footerImg material-icons menuIcon">\', l = 68, e += "link</span>", l = 69, e += \'<span class="footerItem">\', l = 69, e += "Project</span></a></div></div>", l = 70, e += \'<div class="spot-footer">\', l = 71, e += \'<span class="versionText">\', l = 71, e += "Version 0.2.0</span></div></footer></main>";\n    } catch (t) {\n      pug.rethrow(t, a, l);\n    }\n\n    return e;\n  };\n\n  puglatizer["main"] = function template(a) {\n    var l,\n        s,\n        t = "";\n\n    try {\n      s = 1, t += "<body>", s = 2, t += \'<div class="mdl-layout mdl-js-layout" data-hook="test">\', s = 4, t += \'<div class="mdl-layout__header-row mdl-color--blue-grey-900">\', s = 5, t += "\x3c!-- Title--\x3e", s = 6, t += \'<span class="mdl-layout-title mdl-layout--large-screen-only">\', s = 7, t += \'<a data-hook="nlescpage" href="https://www.esciencecenter.nl" target="_blank">\', s = 8, t += \'<div class="demo-avatar"></div></a></span>\', s = 9, t += "\x3c!-- Add spacer, to align navigation to the right--\x3e", s = 10, t += \'<div class="mdl-layout-spacer"></div>\', s = 11, t += "\x3c!-- Navigation. We hide it in small screens.--\x3e", s = 12, t += \'<nav class="mdl-navigation mdl-layout--large-screen-only">\', s = 13, t += \'<a class="mdl-navigation__link" href="/home">\', s = 13, t += "Home</a>", s = 14, t += \'<a class="mdl-navigation__link" href="/datasets">\', s = 14, t += "Data</a>", s = 15, t += \'<a class="mdl-navigation__link" href="/analyze">\', s = 15, t += "Analysis</a>", s = 16, t += \'<a class="mdl-navigation__link" href="#" data-hook="help-button" id="help-button">\', s = 17, t += \'<i class="material-icons">\', s = 17, t += "help</i></a></nav></div>", s = 24, t += \'<div class="mdl-drawer mdl-layout__drawer mdl-color--blue-grey-900 mdl-layout--small-screen-only">\', s = 25, t += \'<span class="mdl-layout-title">\', s = 27, t += \'<a data-hook="nlescpage" href="https://www.esciencecenter.nl" target="_blank">\', s = 28, t += \'<div class="demo-avatar" style="margin-top: 20px; margin-bottom: 50px;"></div></a></span>\', s = 29, t += \'<nav class="mdl-navigation">\', s = 30, t += \'<a class="mdl-navigation__link" href="/home">\', s = 30, t += "Home</a>", s = 31, t += \'<a class="mdl-navigation__link" href="/datasets">\', s = 31, t += "Data</a>", s = 32, t += \'<a class="mdl-navigation__link" href="/analyze">\', s = 32, t += "Dashboard</a>", s = 33, t += \'<a class="mdl-navigation__link" href="#" data-hook="help-button" id="help-button">\', s = 34, t += \'<i class="material-icons">\', s = 34, t += "help</i>", s = 35, t += "<span>", s = 35, t += "Help</span></a></nav>", s = 37, t += \'<div class="mdl-drawer-separator"></div>\', s = 38, t += \'<div class="mdl-layout-spacer" style="margin-top: 20px;"></div>\', s = 40, t += \'<nav class="mdl-navigation">\', s = 41, t += \'<a class="mdl-navigation__link" href="https://nlesc.github.io/spot-tutorial/tutorial">\', s = 41, t += "Tutorial</a>", s = 42, t += \'<a class="mdl-navigation__link" href="https://github.com/NLeSC/spot">\', s = 42, t += "Github</a></nav>", s = 44, t += \'<div class="mdl-drawer-separator"></div>\', s = 45, t += \'<div class="mdl-layout-spacer" style="margin-bottom: 20px;"></div>\', s = 46, t += \'<span class="versionText">\', s = 46, t += "Version 0.2.0</span></div>", s = 49, t += \'<div class="mdl-grid">\', s = 50, t += \'<dialog class="mdl-dialog" data-hook="main-dialog" id="main-dialog" style="border: none; width: min-content; background: transparent;">\', s = 51, t += \'<div class="mdl-dialog__content">\', s = 53, t += \'<p2 class="mdl-progress mdl-js-progress mdl-progress__indeterminate"></p2></div></dialog></div>\', s = 58, t += \'<main class="mdl-layout__content" data-hook="page-container"></main>\', s = 60, t += \'<div class="mdl-progress mdl-js-progress" id="progress-bar" style="width: 100%; height: 5%; display: none"></div>\', s = 62, t += \'<div class="mdl-js-snackbar mdl-snackbar" id="snack-bar" aria-live="assertive" aria-atomic="true" aria-relevant="text">\', s = 63, t += \'<div class="mdl-snackbar__text"></div>\', s = 64, t += \'<button class="mdl-snackbar__action" type="button"></button></div></div></body>\';\n    } catch (i) {\n      pug.rethrow(i, l, s);\n    }\n\n    return t;\n  };\n\n  return puglatizer;\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"4324.js","sources":["webpack:///./src/templates.js?8262"],"sourcesContent":[";(function(root,factory){\r\n    if (typeof define === 'function' && define.amd) {\r\n        define([], factory);\r\n    } else if (typeof exports === 'object') {\r\n        module.exports = factory();\r\n    } else {\r\n        if (typeof root === 'undefined' || root !== Object(root)) {\r\n            throw new Error('puglatizer: window does not exist or is not an object');\r\n        }\r\n        root.puglatizer = factory();\r\n    }\r\n}(this, function () {\r\n    function pug_classes_object(val) { var classString = '', padding = ''; for (var key in val) { if (key && val[key] && pug_has_own_property.call(val, key)) { var classString = classString + padding + key; var padding = ' '; } } return classString; }    function pug_classes_array(val, escaping) { var classString = '', className, padding = '', escapeEnabled = Array.isArray(escaping); for (var i = 0; i < val.length; i++) { var className = pug_classes(val[i]); if (!className) continue; escapeEnabled && escaping[i] && (className = pug_escape(className)); var classString = classString + padding + className; var padding = ' '; } return classString; }    function pug_merge(e,r){if(1===arguments.length){for(var t=e[0],g=1;g<e.length;g++)t=pug_merge(t,e[g]);return t}for(var n in r)if(\"class\"===n){var a=e[n]||[];e[n]=(Array.isArray(a)?a:[a]).concat(r[n]||[])}else if(\"style\"===n){var a=pug_style(e[n]);a=a&&\";\"!==a[a.length-1]?a+\";\":a;var l=pug_style(r[n]);l=l&&\";\"!==l[l.length-1]?l+\";\":l,e[n]=a+l}else e[n]=r[n];return e}\r\n    function pug_classes(s,r){return Array.isArray(s)?pug_classes_array(s,r):s&&\"object\"==typeof s?pug_classes_object(s):s||\"\"}\r\n    function pug_style(r){if(!r)return\"\";if(\"object\"==typeof r){var t=\"\";for(var e in r)pug_has_own_property.call(r,e)&&(t=t+e+\":\"+r[e]+\";\");return t}return r+\"\"}\r\n    function pug_attr(t,e,n,f){return e!==!1&&null!=e&&(e||\"class\"!==t&&\"style\"!==t)?e===!0?\" \"+(f?t:t+'=\"'+t+'\"'):(\"function\"==typeof e.toJSON&&(e=e.toJSON()),\"string\"==typeof e||(e=JSON.stringify(e),n||-1===e.indexOf('\"'))?(n&&(e=pug_escape(e)),\" \"+t+'=\"'+e+'\"'):\" \"+t+\"='\"+e.replace(/'/g,\"&#39;\")+\"'\"):\"\"}\r\n    function pug_attrs(t,r){var a=\"\";for(var s in t)if(pug_has_own_property.call(t,s)){var u=t[s];if(\"class\"===s){u=pug_classes(u),a=pug_attr(s,u,!1,r)+a;continue}\"style\"===s&&(u=pug_style(u)),a+=pug_attr(s,u,!1,r)}return a}\r\n    function pug_escape(e){var a=\"\"+e,t=(/[\"&<>]/).exec(a);if(!t)return e;var r,c,n,s=\"\";for(r=t.index,c=0;r<a.length;r++){switch(a.charCodeAt(r)){case 34:n=\"&quot;\";break;case 38:n=\"&amp;\";break;case 60:n=\"&lt;\";break;case 62:n=\"&gt;\";break;default:continue}c!==r&&(s+=a.substring(c,r)),c=r+1,s+=n}return c!==r?s+a.substring(c,r):s}\r\n    function pug_rethrow(n,e,r,t){if(!(n instanceof Error))throw n;if(!(\"undefined\"==typeof window&&e||t))throw n.message+=\" on line \"+r,n;try{t=t||require(\"fs\").readFileSync(e,\"utf8\")}catch(i){pug_rethrow(n,null,r)}var a=3,o=t.split(\"\\n\"),h=Math.max(r-a,0),s=Math.min(o.length,r+a),a=o.slice(h,s).map(function(n,e){var t=e+h+1;return(t==r?\"  > \":\"    \")+t+\"| \"+n}).join(\"\\n\");throw n.path=e,n.message=(e||\"Pug\")+\":\"+r+\"\\n\"+a+\"\\n\\n\"+n.message,n}\r\n    var pug = {\r\n    \tmerge:function pug_merge(e,r){if(1===arguments.length){for(var t=e[0],g=1;g<e.length;g++)t=pug_merge(t,e[g]);return t}for(var n in r)if(\"class\"===n){var a=e[n]||[];e[n]=(Array.isArray(a)?a:[a]).concat(r[n]||[])}else if(\"style\"===n){var a=pug_style(e[n]);a=a&&\";\"!==a[a.length-1]?a+\";\":a;var l=pug_style(r[n]);l=l&&\";\"!==l[l.length-1]?l+\";\":l,e[n]=a+l}else e[n]=r[n];return e},\r\n    \tclasses:function pug_classes(s,r){return Array.isArray(s)?pug_classes_array(s,r):s&&\"object\"==typeof s?pug_classes_object(s):s||\"\"},\r\n    \tstyle:function pug_style(r){if(!r)return\"\";if(\"object\"==typeof r){var t=\"\";for(var e in r)pug_has_own_property.call(r,e)&&(t=t+e+\":\"+r[e]+\";\");return t}return r+\"\"},\r\n    \tattr:function pug_attr(t,e,n,f){return e!==!1&&null!=e&&(e||\"class\"!==t&&\"style\"!==t)?e===!0?\" \"+(f?t:t+'=\"'+t+'\"'):(\"function\"==typeof e.toJSON&&(e=e.toJSON()),\"string\"==typeof e||(e=JSON.stringify(e),n||-1===e.indexOf('\"'))?(n&&(e=pug_escape(e)),\" \"+t+'=\"'+e+'\"'):\" \"+t+\"='\"+e.replace(/'/g,\"&#39;\")+\"'\"):\"\"},\r\n    \tattrs:function pug_attrs(t,r){var a=\"\";for(var s in t)if(pug_has_own_property.call(t,s)){var u=t[s];if(\"class\"===s){u=pug_classes(u),a=pug_attr(s,u,!1,r)+a;continue}\"style\"===s&&(u=pug_style(u)),a+=pug_attr(s,u,!1,r)}return a},\r\n    \tescape:function pug_escape(e){var a=\"\"+e,t=(/[\"&<>]/).exec(a);if(!t)return e;var r,c,n,s=\"\";for(r=t.index,c=0;r<a.length;r++){switch(a.charCodeAt(r)){case 34:n=\"&quot;\";break;case 38:n=\"&amp;\";break;case 60:n=\"&lt;\";break;case 62:n=\"&gt;\";break;default:continue}c!==r&&(s+=a.substring(c,r)),c=r+1,s+=n}return c!==r?s+a.substring(c,r):s},\r\n    \trethrow:function pug_rethrow(n,e,r,t){if(!(n instanceof Error))throw n;if(!(\"undefined\"==typeof window&&e||t))throw n.message+=\" on line \"+r,n;try{t=t||require(\"fs\").readFileSync(e,\"utf8\")}catch(i){pug_rethrow(n,null,r)}var a=3,o=t.split(\"\\n\"),h=Math.max(r-a,0),s=Math.min(o.length,r+a),a=o.slice(h,s).map(function(n,e){var t=e+h+1;return(t==r?\"  > \":\"    \")+t+\"| \"+n}).join(\"\\n\");throw n.path=e,n.message=(e||\"Pug\")+\":\"+r+\"\\n\"+a+\"\\n\\n\"+n.message,n}\r\n    }\r\n\r\n    var puglatizer = {}\r\n    puglatizer[\"analyze\"] = {}\r\n    puglatizer[\"analyze\"][\"facetbarItem\"] = function template(a){var t,e,c=\"\";try{e=1,c+='<span class=\"mdl-chip variableChip\" data-hook=\"facet-bar-item\" id=\"\">',e=2,c+='<span class=\"mdl-chip__text\" data-hook=\"facet-bar-item-button\"></span></span>'}catch(p){pug.rethrow(p,t,e)}return c};\r\n\r\n    puglatizer[\"analyze\"][\"page\"] = function template(t){var a,o,l=\"\";try{o=1,l+='<div class=\"mdl-layout mdl-js-layout mdl-layout--fixed-header\">',o=2,l+='<main class=\"mdl-layout__content\" style=\"background-color: white;\">',o=3,l+='<header class=\"demo-header mdl-layout__header spot-color-top-bar mdl-color-text--grey-600\">',o=5,l+='<div class=\"mdl-layout__header-row\">',o=6,l+='<span class=\"mdl-layout-title unselectable\">',o=6,l+=\"Analyze</span>\",o=8,l+='<div class=\"mdl-layout-spacer\"></div>',o=10,l+='<span class=\"unselectable\" data-hook=\"data-string\"></span>',o=12,l+='<div class=\"mdl-layout-spacer\"></div>',o=14,l+='<span data-position=\"bottom\" data-step=\"0\" data-hint=\"\"></span>',o=16,l+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" id=\"saveSessionButton\" data-hintPosition=\"bottom\" data-position=\"bottom\" data-hint=\"This buttons saves the current session.\">',o=17,l+='<i class=\"material-icons\">',o=17,l+=\"save</i></button>\",o=18,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"saveSessionButton\">',o=19,l+=\"Save the session</div>\",o=21,l+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" id=\"resetFiltersButton\" data-position=\"bottom\" data-step=\"1\" data-hint=\"This button clears all existing filters.\">',o=22,l+='<i class=\"material-icons\">',o=22,l+=\"clear_all</i></button>\",o=23,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"resetFiltersButton\">',o=24,l+=\"Clear all filters of all plots</div>\",o=26,l+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" id=\"viewAll\" data-position=\"bottom\" data-step=\"2\" data-hint=\"This button closes all configuration windows\">',o=27,l+='<i class=\"material-icons\">',o=27,l+=\"crop_original</i></button>\",o=28,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"viewAll\">',o=29,l+=\"Close all configuration windows</div>\",o=31,l+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" id=\"fullscreenButton\" data-position=\"bottom\" data-step=\"3\" data-hint=\"This button hides facet and chart bars.\">',o=32,l+='<i class=\"material-icons\">',o=32,l+=\"fullscreen</i></button>\",o=33,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"fullscreenButton\">',o=34,l+=\"Show or hide chart and facet bars</div></div>\",o=36,l+='<div class=\"chartBar spot-color-top-bar mdl-color-text--grey-600\" data-hook=\"chart-bar\" data-position=\"bottom\" data-step=\"4\" data-hint=\"These are the available chart types. If you want to add a chart, just &lt;b&gt;click&lt;/b&gt; on its icon and it will be created! Simple, right? \">',o=37,l+='<span class=\"chartBarText\">',o=37,l+=\"Click on a chart icon to start a new plot</span>\",o=39,l+='<div class=\"mdl-cell mdl-cell--12-col horizontalbarchartIcon widgetIcon\" data-hook=\"horizontalbarchart\" id=\"horizontalbarchart\" data-position=\"bottom\" data-step=\"5\" data-hint=\"This adds a horizontal bar chart(histogram). This is good for categorical facets.\"></div>',o=40,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"horizontalbarchart\">',o=41,l+=\"Click to add a horizontal bar chart</div>\",o=43,l+='<div class=\"mdl-cell mdl-cell--12-col barchartIcon widgetIcon\" data-hook=\"barchart\" id=\"barchart\" data-position=\"bottom\" data-step=\"6\" data-hint=\"This adds a vertical bar chart.\"></div>',o=44,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"barchart\">',o=45,l+=\"Click to add a bar chart</div>\",o=47,l+='<div class=\"mdl-cell mdl-cell--12-col linechartIcon widgetIcon\" data-hook=\"linechart\" id=\"linechart\" data-position=\"bottom\" data-step=\"7\" data-hint=\"This adds a line chart.\"></div>',o=48,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"linechart\">',o=49,l+=\"Click to add a line chart</div>\",o=51,l+='<div class=\"mdl-cell mdl-cell--12-col piechartIcon widgetIcon\" data-hook=\"piechart\" id=\"piechart\" data-position=\"bottom\" data-step=\"8\" data-hint=\"This adds a pie chart.\"></div>',o=52,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"piechart\">',o=53,l+=\"Click to add a pie chart</div>\",o=55,l+='<div class=\"mdl-cell mdl-cell--12-col bubbleplotIcon widgetIcon\" data-hook=\"bubbleplot\" id=\"bubbleplot\" data-position=\"bottom\" data-step=\"9\" data-hint=\"This adds a buble chart.\"></div>',o=56,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"bubbleplot\">',o=57,l+=\"Click to add a bubbleplot chart</div>\",o=59,l+='<div class=\"mdl-cell mdl-cell--12-col scatterchartIcon widgetIcon\" data-hook=\"scatterchart\" id=\"scatterchart\" data-position=\"bottom\" data-step=\"10\" data-hint=\"This adds a 3D scatter chart.\"></div>',o=60,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"scatterchart\">',o=61,l+=\"Click to add a 3d scatter chart</div>\",o=63,l+='<div class=\"mdl-cell mdl-cell--12-col radarchartIcon widgetIcon\" data-hook=\"radarchart\" id=\"radarchart\" data-position=\"bottom\" data-step=\"11\" data-hint=\"This adds a radar chart.\"></div>',o=64,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"radarchart\">',o=65,l+=\"Click to add a radar chart</div>\",o=67,l+='<div class=\"mdl-cell mdl-cell--12-col networkchartIcon widgetIcon\" data-hook=\"networkchart\" id=\"networkchart\" data-position=\"bottom\" data-step=\"12\" data-hint=\"This adds a network chart.\"></div>',o=68,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"networkchart\">',o=69,l+=\"Click to add a network chart</div></div>\",o=71,l+='<div class=\"facetBar spot-color-top-bar\" data-hook=\"facet-bar\" id=\"facet-bar\" data-position=\"bottom\" data-step=\"13\" data-hint=\"This is where you will have your variables(facets). Just &lt;b&gt;drag and drop&lt;/b&gt; these facets to field of the charts to visualize.\">',o=72,l+='<span class=\"facetBarText\">',o=72,l+=\"Drop variable on a chart, or click to edit</span>\",o=73,l+='<div class=\"facetBarItems\" data-hook=\"facet-bar-items\" id=\"facetBar\"></div></div>',o=74,l+='<div class=\"mdl-tooltip mdl-tooltip--large\" id=\"facet-bar-tooltip\" for=\"facet-bar\">',o=75,l+=\"Drop variable on a chart, or click to edit</div></header>\",o=77,l+='<div class=\"widgetDropZone\" id=\"widgets\" data-hook=\"widgets\"></div></main></div>'}catch(i){pug.rethrow(i,a,o)}return l};\r\n\r\n    puglatizer[\"analyze\"][\"slot\"] = function template(t){var o,a,d=\"\";try{a=1,d+='<div class=\"slot mdl-shadow--2dp\" data-hook=\"slot\">',a=2,d+='<div class=\"slotText clickTarget\">',a=3,d+='<b data-hook=\"description\"></b>',a=4,d+=\"<br/>\",a=5,d+='<i data-hook=\"required\"></i></div>',a=6,d+='<div class=\"slotChip clickTarget\" data-hook=\"drop-zone\">',a=7,d+='<span data-hook=\"chip-text\"></span></div>',a=8,d+='<div class=\"slotButton\" data-hook=\"button-div\">',a=9,d+='<button class=\"mdl-button mdl-js-button mdl-button--icon\" data-hook=\"delete\">',a=10,d+='<i class=\"material-icons\">',a=10,d+=\"delete</i></button></div></div>\"}catch(i){pug.rethrow(i,o,a)}return d};\r\n\r\n    puglatizer[\"analyze\"][\"widgetFrame\"] = function template(t){var o,l,i=\"\";try{l=1,i+='<div class=\"widgetFrame mdl-color--white mdl-shadow--2dp\">',l=3,i+='<div class=\"configView\" data-hook=\"config-view\">',l=4,i+='<div class=\"widgetDragBar\">',l=5,i+='<button class=\"mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect\" data-hook=\"close\" id=\"chartDeleteButton2\">',l=6,i+='<i class=\"material-icons\">',l=6,i+=\"delete</i></button>\",l=7,i+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"chartDeleteButton2\">',l=8,i+=\"Delete this chart</div>\",l=9,i+='<span class=\"widgetHeader\" data-hook=\"widgetHeader\"></span>',l=10,i+='<div class=\"mdl-layout-spacer\"></div>',l=11,i+='<button class=\"mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect\" data-hook=\"edit\" style=\"float: right\" id=\"chartDoneButton\">',l=12,i+='<i class=\"material-icons\">',l=12,i+=\"done</i></button>\",l=13,i+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"chartDoneButton\">',l=14,i+=\"Close configuration view</div></div>\",l=16,i+='<div class=\"slots\" data-hook=\"slots\"></div></div>',l=18,i+='<div class=\"widgetView\" data-hook=\"widget\"></div>',l=20,i+='<div class=\"plotMenu\" data-hook=\"plot-menu\" style=\"width: 100%;\">',l=21,i+='<div class=\"widgetDragBar\">',l=22,i+='<button class=\"mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect\" data-hook=\"close\" id=\"chartDeleteButton1\">',l=23,i+='<i class=\"material-icons\">',l=23,i+=\"delete</i></button>\",l=24,i+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"chartDeleteButton1\">',l=25,i+=\"Delete this chart</div>\",l=26,i+='<button class=\"mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect\" data-hook=\"zoom-out\" id=\"chartUndoButton\">',l=27,i+='<i class=\"material-icons\">',l=27,i+=\"undo</i></button>\",l=28,i+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"chartUndoButton\">',l=29,i+=\"Undo selection</div>\",l=30,i+='<button class=\"mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect\" data-hook=\"zoom-in\" id=\"chartZoomButton\">',l=31,i+='<i class=\"material-icons\">',l=31,i+=\"zoom_in</i></button>\",l=32,i+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"chartZoomButton\">',l=33,i+=\"Zoom into selected region</div>\",l=34,i+='<button class=\"mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect\" data-hook=\"save\" id=\"chartSave\">',l=35,i+='<i class=\"material-icons\">',l=35,i+=\"save</i></button>\",l=36,i+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"chartSave\">',l=37,i+=\"Save this chart</div>\",l=38,i+='<div class=\"mdl-layout-spacer\"></div>',l=39,i+='<button class=\"mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect\" data-hook=\"edit\" style=\"float: right;\" id=\"chartConfButton\">',l=40,i+='<i class=\"material-icons\">',l=40,i+=\"create</i></button>\",l=41,i+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"chartConfButton\">',l=42,i+=\"Open configuration view</div></div></div></div>\"}catch(a){pug.rethrow(a,o,l)}return i};\r\n\r\n    puglatizer[\"configureDataset\"] = {}\r\n    puglatizer[\"configureDataset\"][\"facet\"] = function template(t){var l,a,d=\"\";try{a=1,d+='<div class=\"mdl-card mdl-shadow--2dp\" data-hook=\"fullitem\" style=\"min-height: inherit\">',a=2,d+='<div class=\"mdl-card__title\">',a=3,d+='<h2 class=\"mdl-card__title-text\" data-hook=\"name\"></h2></div>',a=5,d+='<div class=\"mdl-card__supporting-text\" data-hook=\"description\"></div>',a=7,d+='<div class=\"mdl-card__actions mdl-card--border\" data-hook=\"actions\">',a=8,d+='<button class=\"mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect unselectable\" data-hook=\"removeFacet\">',a=9,d+=\"Delete</button>\",a=10,d+='<button class=\"mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect unselectable\" data-hook=\"duplicateFacet\">',a=11,d+=\"Copy </button>\",a=12,d+='<button class=\"mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect unselectable\" data-hook=\"configureFacet\" style=\"float: right\">',a=13,d+='<i class=\"material-icons\">',a=13,d+=\"settings</i></button></div>\",a=15,d+='<div class=\"mdl-card__menu\">',a=16,d+=\"<span>\",a=17,d+='<label class=\"mdl-switch mdl-js-switch mdl-js-ripple-effect\" data-hook=\"cblabel\" for=\"\">',a=18,d+='<input class=\"mdl-switch__input\" data-hook=\"cb\" type=\"checkbox\" id=\"\"/></label>',a=19,d+='<span class=\"mdl-switch__label\"></span></span></div></div>'}catch(e){pug.rethrow(e,l,a)}return d};\r\n\r\n    puglatizer[\"configureDataset\"][\"page\"] = function template(t){var l,a,d=\"\";try{a=1,d+='<div class=\"mdl-layout mdl-js-layout mdl-layout--fixed-header\">',a=2,d+='<main class=\"mdl-layout__content\" style=\"background-color: white;\">',a=3,d+='<div class=\"mdl-layout mdl-js-layout mdl-layout--fixed-header\">',a=4,d+='<header class=\"demo-header mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600\">',a=5,d+='<div class=\"mdl-layout__header-row\">',a=6,d+='<span class=\"mdl-layout-title\">',a=6,d+=\"Configure dataset</span>\",a=8,d+='<div class=\"mdl-layout-spacer\"></div>',a=10,d+='<span class=\"unselectable\" data-hook=\"data-string\">',a=11,d+=\"Select and configure facets</span>\",a=13,d+='<div class=\"mdl-layout-spacer\"></div>',a=15,d+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" data-hook=\"enable-all-button\" id=\"eab\">',a=16,d+='<i class=\"material-icons\">',a=16,d+=\"check_box</i></button>\",a=17,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"eab\">',a=18,d+=\"Enable all facets</div>\",a=20,d+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" data-hook=\"disable-all-button\" id=\"dab\">',a=21,d+='<i class=\"material-icons\">',a=21,d+=\"check_box_outline_blank</i></button>\",a=22,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"dab\">',a=23,d+=\"Disable all facets</div>\",a=25,d+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" data-hook=\"add-button\" id=\"tt2\">',a=26,d+='<i class=\"material-icons\">',a=26,d+=\"add</i></button>\",a=27,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"tt2\">',a=28,d+=\"Add a new facet</div>\",a=30,d+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" data-hook=\"rescan-button\" id=\"tt1\">',a=31,d+='<i class=\"material-icons\">',a=31,d+=\"autorenew</i></button>\",a=32,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"tt1\">',a=33,d+=\"Analyze data and autoconfigure facets</div>\",a=35,d+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" data-hook=\"search-button\" id=\"tt3\">',a=36,d+='<i class=\"material-icons\">',a=36,d+=\"search</i></button>\",a=37,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"tt3\">',a=38,d+=\"Show or hide search bar</div></div>\",a=40,d+='<div class=\"mdl-layout__header-row\" data-hook=\"search-bar\">',a=41,d+='<div class=\"mdl-layout-spacer\"></div>',a=42,d+='<span class=\"mdl-color--white mdl-color-text--primary searchBar\">',a=44,d+='<span class=\"mdl-textfield searchBar\">',a=45,d+='<input class=\"mdl-textfield__input searchBar\" data-hook=\"facet-selector\" type=\"text\" id=\"tt5\"/>',a=46,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"tt5\">',a=47,d+=\"Search facet name and description</div></span>\",a=49,d+=\"<span>\",a=50,d+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" data-hook=\"clear-button\" id=\"tt4\">',a=51,d+='<i class=\"material-icons\">',a=51,d+=\"close</i></button>\",a=52,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"tt4\">',a=53,d+=\"Clear search</div></span></span>\",a=54,d+='<div class=\"mdl-layout-spacer\"></div></div></header>',a=56,d+='<div data-hook=\"widgets\">',a=58,d+='<div class=\"mdl-grid\">',a=59,d+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col\">',a=60,d+='<input class=\"mdl-textfield__input\" type=\"text\" id=\"name\"/>',a=61,d+='<label class=\"mdl-textfield__label\" for=\"name\">',a=62,d+=\"Dataset name</label></div>\",a=64,d+='<div class=\"mdl-textfield mdl-js-textfield mdl-cell mdl-cell mdl-cell--7-col\">',a=65,d+='<textarea class=\"mdl-textfield__input\" type=\"text\" rows=\"3\" id=\"description\"></textarea>',a=66,d+='<label class=\"mdl-textfield__label\" for=\"description\">',a=67,d+=\"Dataset description</label></div></div>\",a=69,d+='<div class=\"mdl-grid\" data-hook=\"facet-list\"></div></div></div></main></div>'}catch(e){pug.rethrow(e,l,a)}return d};\r\n\r\n    puglatizer[\"configureFacet\"] = {}\r\n    puglatizer[\"configureFacet\"][\"categorialRule\"] = function template(t){var e,o,a=\"\";try{o=1,a+=\"<tr>\",o=2,a+=\"<td>\",o=3,a+='<input class=\"mdl-textfield__input\" data-hook=\"category-expression-input\" type=\"text\"/></td>',o=4,a+=\"<td>\",o=5,a+='<input class=\"mdl-textfield__input\" data-hook=\"category-group-input\" type=\"text\"/></td>',o=6,a+='<td data-hook=\"category-value-count\"></td>',o=7,a+=\"<td>\",o=8,a+='<button class=\"mdl-button mdl-js-button mdl-js-ripple-effect\" data-hook=\"category-remove\">',o=9,a+='<i class=\"material-icons\">',o=9,a+=\"remove</i></button></td></tr>\"}catch(d){pug.rethrow(d,e,o)}return a};\r\n\r\n    puglatizer[\"configureFacet\"][\"categorialtransform\"] = function template(t){var r,e,a=\"\";try{}catch(c){pug.rethrow(c,r,e)}return a};\r\n\r\n    puglatizer[\"configureFacet\"][\"continuousRule\"] = function template(t){var o,e,n=\"\";try{e=1,n+=\"<tr>\",e=2,n+=\"<td>\",e=3,n+='<input class=\"mdl-textfield__input\" data-hook=\"continuous-x-input\" type=\"text\"/></td>',e=4,n+=\"<td>\",e=5,n+='<input class=\"mdl-textfield__input\" data-hook=\"continuous-fx-input\" type=\"text\"/></td>',e=6,n+=\"<td>\",e=7,n+='<button class=\"mdl-button mdl-js-button mdl-js-ripple-effect\" data-hook=\"continuous-remove\">',e=8,n+='<i class=\"material-icons\">',e=8,n+=\"remove</i></button></td></tr>\"}catch(u){pug.rethrow(u,o,e)}return n};\r\n\r\n    puglatizer[\"configureFacet\"][\"facetDefine\"] = function template(l){var e,d,i=\"\";try{d=1,i+='<div class=\"mdl-grid\">',d=2,i+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\">',d=3,i+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetInfoIcon\"></div>',d=4,i+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',d=5,i+='<div class=\"mdl-cell mdl-cell--8-col\">',d=6,i+='<div class=\"mdl-grid\">',d=8,i+='<div class=\"mdl-cell mdl-cell--12-col\" id=\"define-name-div\">',d=9,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label fullwidth\">',d=10,i+='<input class=\"mdl-textfield__input\" id=\"define-name\" data-hook=\"define-name-input\" type=\"text\"/>',d=14,i+='<label class=\"mdl-textfield__label\" for=\"define-name\">',d=14,i+=\"Name</label></div></div>\",d=15,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"define-name-div\">',d=16,i+=\"Set a descriptive name for this facet. The name is used to identify this facet on plots and in menus. </div>\",d=18,i+='<div class=\"mdl-cell mdl-cell--12-col\" id=\"define-units-div\">',d=19,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label fullwidth\">',d=20,i+='<input class=\"mdl-textfield__input\" id=\"define-units\" data-hook=\"define-units-input\" type=\"text\"/>',d=24,i+='<label class=\"mdl-textfield__label\" for=\"define-units\">',d=24,i+=\"Units</label></div></div>\",d=25,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"define-units-div\">',d=26,i+=\"Set units for this facet. Units are printed on plots where applicable.</div>\",d=28,i+='<div class=\"mdl-cell mdl-cell--12-col\" id=\"define-description-div\">',d=29,i+='<div class=\"mdl-textfield mdl-js-textfield mdl textfield--floating-label fullwidth\">',d=30,i+='<textarea class=\"mdl-textfield__input\" id=\"define-description\" data-hook=\"define-description-input\" type=\"text\" rows=\"5\">',d=34,i+=\" </textarea>\",d=35,i+='<label class=\"mdl-textfield__label\" for=\"define-description\">',d=35,i+=\"Description</label></div></div>\",d=36,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"define-description-div\">',d=37,i+=\"Give a description of the facet. What do its values mean? How are they calculated?</div></div></div>\",d=39,i+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>',d=41,i+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\">',d=42,i+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetTypeIcon\"></div>',d=43,i+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',d=44,i+='<div class=\"mdl-cell mdl-cell--8-col\">',d=46,i+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\">',d=48,i+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\" id=\"define-type-div\">',d=49,i+='<div class=\"mdl-cell mdl-cell--3-col\">',d=50,i+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"define-type-categorial\">',d=51,i+='<input class=\"mdl-radio__button\" id=\"define-type-categorial\" data-hook=\"define-type-categorial\" type=\"radio\" name=\"type\" value=\"categorial\"/>',d=57,i+='<span class=\"mdl-radio__label\">',d=57,i+=\"Categorial</span></label></div>\",d=59,i+='<div class=\"mdl-cell mdl-cell--3-col\">',d=60,i+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"define-type-continuous\">',d=61,i+='<input class=\"mdl-radio__button\" id=\"define-type-continuous\" data-hook=\"define-type-continuous\" type=\"radio\" name=\"type\" value=\"continuous\"/>',d=67,i+='<span class=\"mdl-radio__label\">',d=67,i+=\"Continuous</span></label></div>\",d=69,i+='<div class=\"mdl-cell mdl-cell--3-col\">',d=70,i+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"define-type-datetime\">',d=71,i+='<input class=\"mdl-radio__button\" id=\"define-type-datetime\" data-hook=\"define-type-datetime\" type=\"radio\" name=\"type\" value=\"datetime\"/>',d=77,i+='<span class=\"mdl-radio__label\">',d=77,i+=\"Datetime</span></label></div>\",d=79,i+='<div class=\"mdl-cell mdl-cell--3-col\">',d=80,i+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"define-type-duration\">',d=81,i+='<input class=\"mdl-radio__button\" id=\"define-type-duration\" data-hook=\"define-type-duration\" type=\"radio\" name=\"type\" value=\"duration\"/>',d=87,i+='<span class=\"mdl-radio__label\">',d=87,i+=\"Duration</span></label></div>\",d=89,i+='<div class=\"mdl-cell mdl-cell--3-col\">',d=90,i+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"define-type-text\">',d=91,i+='<input class=\"mdl-radio__button\" id=\"define-type-text\" data-hook=\"define-type-text\" type=\"radio\" name=\"type\" value=\"text\"/>',d=97,i+='<span class=\"mdl-radio__label\">',d=97,i+=\"Text</span></label></div></div>\",d=99,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"define-type-div\">',d=100,i+=\"What values does this facet take? Is it a continuous value (length, weight, amount)? Or a label, category ('important', 'urgent', or a day of the week, ...). Or is it a date, time or duration? Or arbitrary text?</div></div></div>\",d=102,i+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>',d=104,i+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\">',d=105,i+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetBaseValueIcon\"></div>',d=106,i+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',d=107,i+='<div class=\"mdl-cell mdl-cell--8-col\">',d=109,i+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\">',d=111,i+='<div class=\"mdl-cell mdl-cell--12-col\" id=\"define-missing-div\">',d=112,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label fullwidth\">',d=113,i+='<input class=\"mdl-textfield__input\" id=\"define-missing-input\" data-hook=\"define-missing-input\" type=\"text\"/>',d=117,i+='<label class=\"mdl-textfield__label\" for=\"define-missing-input\">',d=117,i+=\"Missing data indicator</label></div></div>\",d=118,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"define-missing-div\">',d=119,i+=\"Invalid, undefined, or missing data are dealt with automatically, but sometimes a special value is used to indicate the data is missing. Enter those values here. Example: 999, 'x', 'missing'</div>\",d=122,i+='<div class=\"mdl-cell mdl-cell--12-col\" id=\"define-accessor-div\">',d=123,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label fullwidth\">',d=124,i+='<input class=\"mdl-textfield__input\" id=\"define-accessor-input\" data-hook=\"define-accessor-input\" type=\"text\"/>',d=128,i+='<label class=\"mdl-textfield__label\" for=\"define-accessor-input\">',d=128,i+=\"Property name or index</label></div></div>\",d=129,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"define-accessor-div\">',d=130,i+=\"How we derive the facet value from a data object? Enter a property name (for JSON or SQL columns), or index (for arrays). Use '.' notation to access nested properties.</div>\",d=133,i+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"define-rescan-div\">',d=134,i+='<button class=\"mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--accent\" data-hook=\"define-rescan-button\">',d=134,i+=\"Scan dataset</button></div>\",d=137,i+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"define-minimum-div\" data-hook=\"define-minimum-div\">',d=138,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--10-col\" id=\"define-minimum-div\">',d=139,i+='<input class=\"mdl-textfield__input\" id=\"define-minimum\" data-hook=\"define-minimum-input\" type=\"text\"/>',d=143,i+='<label class=\"mdl-textfield__label\" for=\"sample4\">',d=143,i+=\"Minimum value</label></div>\",d=145,i+='<div class=\"mdl-cell mdl-cell--1-col\">',d=146,i+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-button--colored\" data-hook=\"button-minval-missing\">',d=147,i+='<i class=\"material-icons\">',d=147,i+=\"cancel</i></button></div>\",d=149,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"define-minimum-div\">',d=150,i+=\"Set minimum value.</div></div>\",d=153,i+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"define-maximum-div\" data-hook=\"define-maximum-div\">',d=154,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--10-col\" id=\"define-maximum-div\">',d=155,i+='<input class=\"mdl-textfield__input\" id=\"define-maximum\" data-hook=\"define-maximum-input\" type=\"text\"/>',d=159,i+='<label class=\"mdl-textfield__label\" for=\"sample4\">',d=159,i+=\"Maximum value</label></div>\",d=161,i+='<div class=\"mdl-cell mdl-cell--1-col\">',d=162,i+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-button--colored\" data-hook=\"button-maxval-missing\">',d=163,i+='<i class=\"material-icons\">',d=163,i+=\"cancel</i></button></div>\",d=165,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"define-maximum-div\">',d=166,i+=\"Set maximum value.</div></div></div></div>\",d=168,i+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div></div>'}catch(t){pug.rethrow(t,e,d)}return i};\r\n\r\n    puglatizer[\"configureFacet\"][\"facetTransformCategorial\"] = function template(l){var t,d,o=\"\";try{d=1,o+='<div class=\"mdl-grid\" data-hook=\"transform-categorial-panel\">',d=3,o+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetCategorialIcon\"></div>',d=5,o+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',d=7,o+='<div class=\"mdl-cell mdl-cell--8-col\">',d=8,o+='<div class=\"mdl-grid\" id=\"transform-categorial-div\">',d=10,o+='<div class=\"mdl-cell mdl-cell--4-col\" data-hook=\"categorial-addone-button\">',d=11,o+='<button class=\"mdl-button mdl-js-button mdl-js-ripple-effect\">',d=11,o+=\"Add a rule</button></div>\",d=13,o+='<div class=\"mdl-cell mdl-cell--4-col\" data-hook=\"categorial-removeall-button\">',d=14,o+='<button class=\"mdl-button mdl-js-button mdl-js-ripple-effect\">',d=14,o+=\"Remove all rules</button></div>\",d=16,o+='<div class=\"mdl-cell mdl-cell--12-col\">',d=17,o+=\"<table>\",d=18,o+=\"<thead>\",d=19,o+=\"<tr>\",d=20,o+=\"<th>\",d=20,o+=\"Text</th>\",d=21,o+=\"<th>\",d=21,o+=\"Group</th>\",d=22,o+=\"<th>\",d=22,o+=\"Count</th>\",d=23,o+=\"<th>\",d=23,o+=\"Remove</th></tr></thead>\",d=24,o+='<tbody data-hook=\"categorial-rules-table\"></tbody></table></div></div>',d=26,o+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"transform-categorial-div\">',d=26,o+=\" \",d=27,o+=\"Assign facet values to grous.</div></div>\",d=29,o+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>'}catch(a){pug.rethrow(a,t,d)}return o};\r\n\r\n    puglatizer[\"configureFacet\"][\"facetTransformContinuous\"] = function template(l){var e,d,a=\"\";try{d=1,a+='<div class=\"mdl-grid\" data-hook=\"transform-continuous-panel\">',d=3,a+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetContinuousIcon\"></div>',d=5,a+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',d=7,a+='<div class=\"mdl-cell mdl-cell--8-col mdl-grid\">',d=9,a+='<div class=\"mdl-cell mdl-cell--4-col\">',d=10,a+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"define-transform-none\">',d=11,a+='<input class=\"mdl-radio__button\" id=\"define-transform-none\" data-hook=\"define-transform-none\" type=\"radio\" name=\"transformtype\" value=\"none\"/>',d=17,a+='<span class=\"mdl-radio__label\">',d=17,a+=\"No transform</span></label></div>\",d=19,a+='<div class=\"mdl-cell mdl-cell--4-col\">',d=20,a+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"define-transform-percentiles\">',d=21,a+='<input class=\"mdl-radio__button\" id=\"define-transform-percentiles\" data-hook=\"define-transform-percentiles\" type=\"radio\" name=\"transformtype\" value=\"percentiles\"/>',d=27,a+='<span class=\"mdl-radio__label\">',d=27,a+=\"Percentiles</span></label></div></div>\",d=29,a+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>'}catch(s){pug.rethrow(s,e,d)}return a};\r\n\r\n    puglatizer[\"configureFacet\"][\"facetTransformDatetime\"] = function template(l){var e,d,t=\"\";try{d=1,t+='<div class=\"mdl-grid\" data-hook=\"transform-time-panel\">',d=3,t+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\">',d=4,t+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetTimeIcon\"></div>',d=5,t+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',d=7,t+='<div class=\"mdl-cell mdl-cell--8-col mdl-grid\">',d=9,t+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"transform-time-format-div\">',d=10,t+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--6-col\">',d=11,t+='<input class=\"mdl-textfield__input\" id=\"transform-time-format\" data-hook=\"transform-time-format-input\" type=\"text\"/>',d=15,t+='<label class=\"mdl-textfield__label\" for=\"transform-time-format\">',d=15,t+=\"Input time format</label></div>\",d=17,t+='<div class=\"mdl-cell mdl-cell--6-col\" data-hook=\"time-zones\"></div></div>',d=19,t+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"transform-time-transformedformat-div\">',d=20,t+='<div class=\"mdl-cell mdl-cell--6-col\">',d=21,t+=\"Select datetime part</div>\",d=22,t+='<div class=\"mdl-cell mdl-cell--6-col\" data-hook=\"time-parts\"></div></div>',d=24,t+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"transform-time-transformedreference-div\">',d=25,t+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--6-col\">',d=26,t+='<input class=\"mdl-textfield__input\" id=\"transform-time-transformedreference\" data-hook=\"transform-time-transformedreference-input\" type=\"text\"/>',d=30,t+='<label class=\"mdl-textfield__label\" for=\"transform-time-transformedreference\">',d=30,t+=\"Add/subtract reference time</label></div>\",d=32,t+='<div class=\"mdl-cell mdl-cell--6-col\" data-hook=\"transformed-time-zones\"></div></div></div>',d=34,t+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div></div>'}catch(m){pug.rethrow(m,e,d)}return t};\r\n\r\n    puglatizer[\"configureFacet\"][\"facetTransformDuration\"] = function template(l){var d,e,c=\"\";try{e=1,c+='<div class=\"mdl-grid\" data-hook=\"transform-duration-panel\">',e=3,c+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\">',e=4,c+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetTimeIcon\"></div>',e=5,c+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',e=7,c+='<div class=\"mdl-cell mdl-cell--8-col mdl-grid\">',e=9,c+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\">',e=10,c+='<div class=\"mdl-cell mdl-cell--6-col\">',e=11,c+=\"Input units </div>\",e=12,c+='<div class=\"mdl-cell mdl-cell--6-col\" data-hook=\"duration-units\"></div></div>',e=14,c+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\">',e=15,c+='<div class=\"mdl-cell mdl-cell--6-col\">',e=16,c+=\"Output units</div>\",e=17,c+='<div class=\"mdl-cell mdl-cell--6-col\" data-hook=\"transformed-duration-units\"></div></div>',e=19,c+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"transform-duration-transformedreference-div\">',e=20,c+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--6-col\">',e=21,c+='<input class=\"mdl-textfield__input\" id=\"transform-duration-transformedreference\" data-hook=\"transform-duration-transformedreference-input\" type=\"text\"/>',e=25,c+='<label class=\"mdl-textfield__label\" for=\"transform-duration-transformedreference\">',e=25,c+=\"Add/subtract reference time</label></div>\",e=27,c+='<div class=\"mdl-cell mdl-cell--6-col\" data-hook=\"transformed-duration-zone\"></div></div></div>',e=29,c+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div></div>'}catch(i){pug.rethrow(i,d,e)}return c};\r\n\r\n    puglatizer[\"configureFacet\"][\"page\"] = function template(a){var d,t,o=\"\";try{t=1,o+='<div class=\"mdl-layout mdl-js-layout mdl-layout--fixed-header\">',t=2,o+='<main class=\"mdl-layout__content\" style=\"background-color: white;\">',t=3,o+='<div class=\"mdl-layout mdl-js-layout mdl-layout--fixed-header\">',t=4,o+='<header class=\"demo-header mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600\">',t=5,o+='<div class=\"mdl-layout__header-row\">',t=6,o+='<span class=\"mdl-layout-title\">',t=6,o+=\"Configure facet</span></div></header>\",t=8,o+=\"<main>\",t=9,o+='<div data-hook=\"facet-define\"></div>',t=11,o+='<div data-hook=\"transform-categorial-panel\">',t=12,o+='<div data-hook=\"facet-transform-categorial\"></div></div>',t=13,o+='<div data-hook=\"transform-continuous-panel\">',t=14,o+='<div data-hook=\"facet-transform-continuous\"></div></div>',t=15,o+='<div data-hook=\"transform-datetime-panel\">',t=16,o+='<div data-hook=\"facet-transform-datetime\"></div></div>',t=17,o+='<div data-hook=\"transform-duration-panel\">',t=18,o+='<div data-hook=\"facet-transform-duration\"></div></div></main></div></main></div>'}catch(e){pug.rethrow(e,d,t)}return o};\r\n\r\n    puglatizer[\"configurePartition\"] = {}\r\n    puglatizer[\"configurePartition\"][\"group\"] = function template(t){var r,o,a=\"\";try{o=1,a+=\"<tr>\",o=2,a+='<td data-hook=\"group-label\"></td>',o=3,a+='<td data-hook=\"group-count\"></td></tr>'}catch(d){pug.rethrow(d,r,o)}return a};\r\n\r\n    puglatizer[\"configurePartition\"][\"page\"] = function template(l){var d,t,i=\"\";try{t=1,i+='<div class=\"mdl-layout mdl-js-layout mdl-layout--fixed-header\">',t=2,i+='<main class=\"mdl-layout__content\" style=\"background-color: white;\">',t=4,i+='<div class=\"mdl-layout mdl-js-layout mdl-layout--fixed-header\">',t=5,i+='<header class=\"demo-header mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600\">',t=6,i+='<div class=\"mdl-layout__header-row\">',t=7,i+='<span class=\"mdl-layout-title\">',t=7,i+=\"Configure partition</span></div></header>\",t=9,i+=\"<main>\",t=10,i+='<div class=\"mdl-grid\" data-hook=\"partition-general\">',t=11,i+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetInfoIcon\"></div>',t=12,i+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',t=13,i+='<div class=\"mdl-cell mdl-cell--8-col\">',t=14,i+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"partition-label-div\">',t=15,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--12-col\">',t=16,i+='<input class=\"mdl-textfield__input\" id=\"partition-title\" data-hook=\"partition-title-input\" type=\"text\"/>',t=20,i+='<label class=\"mdl-textfield__label\" for=\"\">',t=20,i+=\"Label</label></div></div>\",t=22,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"partition-label-div\">',t=23,i+=\"The label along this axis</div>\",t=25,i+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"partition-options-div\">',t=26,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--3-col\">',t=27,i+='<label class=\"mdl-checkbox mdl-js-checkbox mdl-js-ripple-effect\" for=\"partition-cb1\">',t=28,i+='<input class=\"mdl-checkbox__input\" type=\"checkbox\" id=\"partition-cb1\" data-hook=\"show-label\"/>',t=29,i+='<span class=\"mdl-checkbox__label\">',t=29,i+=\"Show label</span></label></div>\",t=31,i+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--3-col\">',t=32,i+='<label class=\"mdl-checkbox mdl-js-checkbox mdl-js-ripple-effect\" for=\"partition-cb2\">',t=33,i+='<input class=\"mdl-checkbox__input\" type=\"checkbox\" id=\"partition-cb2\" data-hook=\"show-legend\"/>',t=34,i+='<span class=\"mdl-checkbox__label\">',t=34,i+=\"Show legend</span></label></div>\",t=36,i+=\"<!-- div.mdl-textfield.mdl-js-textfield.mdl-textfield--floating-label.mdl-cell.mdl-cell--3-col-->\",t=37,i+='<!--   label(for=\"partition-cb3\").mdl-checkbox.mdl-js-checkbox.mdl-js-ripple-effect-->',t=38,i+='<!--     input(type=\"checkbox\" id=\"partition-cb3\" data-hook=\"accumulative\").mdl-checkbox__input-->',t=39,i+=\"<!--     span.mdl-checkbox__label Accumulative-->\",t=41,i+=\"<!-- div.mdl-textfield.mdl-js-textfield.mdl-textfield--floating-label.mdl-cell.mdl-cell--3-col-->\",t=42,i+='<!--   label(for=\"partition-cb4\").mdl-checkbox.mdl-js-checkbox.mdl-js-ripple-effect-->',t=43,i+='<!--     input(type=\"checkbox\" id=\"partition-cb4\" data-hook=\"relative\").mdl-checkbox__input-->',t=44,i+=\"<!--     span.mdl-checkbox__label Relative--></div>\",t=46,i+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"partition-options-div\">',t=47,i+=\"Set various options for this partition</div></div>\",t=49,i+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>',t=51,i+='<div class=\"mdl-grid\" data-hook=\"partition-continuous\"></div>',t=52,i+='<div class=\"mdl-grid\" data-hook=\"partition-categorial\"></div>',t=53,i+='<div class=\"mdl-grid\" data-hook=\"partition-datetime\"></div>',t=54,i+='<div class=\"mdl-grid\" data-hook=\"partition-duration\"></div>',t=55,i+='<div class=\"mdl-grid\" data-hook=\"partition-text\"></div></main></div></main></div>'}catch(e){pug.rethrow(e,d,t)}return i};\r\n\r\n    puglatizer[\"configurePartition\"][\"partitionCategorial\"] = function template(l){var t,d,o=\"\";try{d=1,o+='<div class=\"mdl-grid\" data-hook=\"group-categorial-panel\">',d=2,o+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetCategorialIcon\"></div>',d=3,o+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',d=4,o+='<div class=\"mdl-cell mdl-cell--8-col\">',d=5,o+='<div class=\"mdl-cell mdl-cell--12-col\">',d=6,o+='<table style=\"width: 100%\">',d=7,o+=\"<thead>\",d=8,o+=\"<tr>\",d=9,o+=\"<th>\",d=10,o+='<button class=\"mdl-button mdl-js-button\" data-hook=\"group-order-abc\">',d=10,o+=\"label</button></th>\",d=11,o+=\"<th>\",d=12,o+='<button class=\"mdl-button mdl-js-button\" data-hook=\"group-order-count\">',d=12,o+=\"count</button></th></tr></thead>\",d=13,o+='<tbody data-hook=\"groups-table\"></tbody></table></div></div>',d=14,o+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>'}catch(c){pug.rethrow(c,t,d)}return o};\r\n\r\n    puglatizer[\"configurePartition\"][\"partitionContinuous\"] = function template(l){var d,i,e=\"\";try{i=1,e+='<div class=\"mdl-grid\" data-hook=\"group-continuous-panel\">',i=2,e+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetContinuousIcon\"></div>',i=3,e+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',i=4,e+='<div class=\"mdl-cell mdl-cell--8-col\">',i=5,e+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\">',i=7,e+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"group-range-div\">',i=8,e+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col\">',i=9,e+='<input class=\"mdl-textfield__input\" id=\"group-minimum\" data-hook=\"group-minimum-input\" type=\"text\" pattern=\"-?[0-9]*(.[0-9]+)?(e[+-][0-9]+)?\"/>',i=14,e+='<label class=\"mdl-textfield__label\" for=\"group-minimum\">',i=14,e+=\"Minimum value</label>\",i=15,e+='<span class=\"mdl-textfield__error\">',i=15,e+=\"Input is not a number!</span></div>\",i=17,e+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col\">',i=18,e+='<input class=\"mdl-textfield__input\" id=\"group-maximum\" data-hook=\"group-maximum-input\" type=\"text\" pattern=\"-?[0-9]*(.[0-9]+)?(e[+-][0-9]+)?\"/>',i=23,e+='<label class=\"mdl-textfield__label\" for=\"group-maximum\">',i=23,e+=\"Maximum value</label>\",i=24,e+='<span class=\"mdl-textfield__error\">',i=24,e+=\"Input is not a number!</span></div>\",i=26,e+='<div class=\"mdl-cell mdl-cell--4-col\" data-hook=\"group-range-button\">',i=27,e+='<button class=\"mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--accent\">',i=27,e+=\"Reset ranges</button></div></div>\",i=29,e+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"group-range-div\">',i=30,e+=\"Reset mininum and maximum values.</div>\",i=33,e+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"group-param-div\">',i=34,e+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--12-col\">',i=35,e+='<input class=\"mdl-textfield__input\" id=\"group-param\" data-hook=\"group-param-input\" type=\"text\" pattern=\"-?[0-9]*(.[0-9]+)?\"/>',i=40,e+='<label class=\"mdl-textfield__label\" for=\"sample4\">',i=40,e+=\"Number of bins or binsize</label>\",i=41,e+='<span class=\"mdl-textfield__error\">',i=41,e+=\"Input is not a number!</span></div></div>\",i=43,e+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"group-param-div\">',i=44,e+=\"Set the number of bins, or the bin size</div>\",i=47,e+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\" id=\"group-distribution-div\">',i=49,e+='<div class=\"mdl-cell mdl-cell--3-col\">',i=50,e+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"group-fixedn\">',i=51,e+='<input class=\"mdl-radio__button\" id=\"group-fixedn\" data-hook=\"group-fixedn-input\" type=\"radio\" name=\"group-distribution\" value=\"fixedn\"/>',i=57,e+='<span class=\"mdl-radio__label\">',i=57,e+=\"Fixed number of bins</span></label></div>\",i=59,e+='<div class=\"mdl-cell mdl-cell--3-col\">',i=60,e+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"group-fixedsc\">',i=61,e+='<input class=\"mdl-radio__button\" id=\"group-fixedsc\" data-hook=\"group-fixedsc-input\" type=\"radio\" name=\"group-distribution\" value=\"fixedsc\"/>',i=67,e+='<span class=\"mdl-radio__label\">',i=67,e+=\"Fixed bin size (centered)</span></label></div>\",i=69,e+='<div class=\"mdl-cell mdl-cell--3-col\">',i=70,e+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"group-fixeds\">',i=71,e+='<input class=\"mdl-radio__button\" id=\"group-fixeds\" data-hook=\"group-fixeds-input\" type=\"radio\" name=\"group-distribution\" value=\"fixeds\"/>',i=77,e+='<span class=\"mdl-radio__label\">',i=77,e+=\"Fixed bin size</span></label></div>\",i=79,e+='<div class=\"mdl-cell mdl-cell--3-col\">',i=80,e+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"group-log\">',i=81,e+='<input class=\"mdl-radio__button\" id=\"group-log\" data-hook=\"group-log-input\" type=\"radio\" name=\"group-distribution\" value=\"log\"/>',i=87,e+='<span class=\"mdl-radio__label\">',i=87,e+=\"Logarithmic</span></label></div></div></div></div>\",i=89,e+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>'}catch(a){pug.rethrow(a,d,i)}return e};\r\n\r\n    puglatizer[\"configurePartition\"][\"partitionDatetime\"] = function template(l){var t,e,d=\"\";try{e=1,d+='<div class=\"mdl-grid\" data-hook=\"group-datetime-panel\">',e=2,d+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetTimeIcon\"></div>',e=3,d+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',e=4,d+='<div class=\"mdl-cell mdl-cell--8-col mdl-grid\">',e=5,d+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"group-datetimerange-div\">',e=6,d+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--3-col\">',e=7,d+='<input class=\"mdl-textfield__input\" id=\"group-startdate\" data-hook=\"group-startdate-input\" type=\"text\"/>',e=11,d+='<label class=\"mdl-textfield__label\" for=\"group-startdate\">',e=11,d+=\"Start date</label></div>\",e=13,d+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--3-col\">',e=14,d+='<input class=\"mdl-textfield__input\" id=\"group-enddate\" data-hook=\"group-enddate-input\" type=\"text\"/>',e=18,d+='<label class=\"mdl-textfield__label\" for=\"group-enddate\">',e=18,d+=\"End date</label></div>\",e=20,d+='<div class=\"mdl-cell mdl-cell--3-col\">',e=21,d+='<div data-hook=\"time-zones\"></div></div>',e=23,d+='<div class=\"mdl-cell mdl-cell--3-col\">',e=24,d+='<select data-hook=\"time-units\">',e=25,d+='<option value=\"auto\">',e=25,d+=\"auto</option>\",e=26,d+='<option value=\"milliseconds\">',e=26,d+=\"milliseconds</option>\",e=27,d+='<option value=\"seconds\">',e=27,d+=\"seconds</option>\",e=28,d+='<option value=\"minutes\">',e=28,d+=\"minutes</option>\",e=29,d+='<option value=\"hours\">',e=29,d+=\"hours</option>\",e=30,d+='<option value=\"days\">',e=30,d+=\"days</option>\",e=31,d+='<option value=\"weeks\">',e=31,d+=\"weeks</option>\",e=32,d+='<option value=\"months\">',e=32,d+=\"months</option>\",e=33,d+='<option value=\"years\">',e=33,d+=\"years</option></select></div></div>\",e=35,d+='<div class=\"mdl-cell mdl-cell--12-col\" data-hook=\"group-datetimerange-button\">',e=36,d+='<button class=\"mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--accent\">',e=36,d+=\"Reset ranges</button></div></div>\",e=38,d+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>'}catch(o){pug.rethrow(o,t,e)}return d};\r\n\r\n    puglatizer[\"configurePartition\"][\"partitionDuration\"] = function template(l){var d,t,e=\"\";try{t=1,e+='<div class=\"mdl-grid\" data-hook=\"group-duration-panel\">',t=2,e+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetTimeIcon\"></div>',t=3,e+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',t=4,e+='<div class=\"mdl-cell mdl-cell--8-col\">',t=5,e+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\">',t=7,e+='<div class=\"mdl-cell mdl-cell--12-col mdl-grid\" id=\"group-durationrange-div\">',t=8,e+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col\">',t=9,e+='<input class=\"mdl-textfield__input\" id=\"group-startduration\" data-hook=\"group-startduration-input\" type=\"text\"/>',t=13,e+='<label class=\"mdl-textfield__label\" for=\"group-startduration\">',t=13,e+=\"Start interval</label></div>\",t=15,e+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--4-col\">',t=16,e+='<input class=\"mdl-textfield__input\" id=\"group-endduration\" data-hook=\"group-endduration-input\" type=\"text\"/>',t=20,e+='<label class=\"mdl-textfield__label\" for=\"group-endduration\">',t=20,e+=\"End interval</label></div>\",t=22,e+='<div class=\"mdl-cell mdl-cell--4-col\" data-hook=\"group-durationrange-button\">',t=23,e+='<button class=\"mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--accent\">',t=23,e+=\"Reset ranges</button></div></div>\",t=25,e+='<div class=\"mdl-tooltip mdl-tooltip--large mdl-tooltip--right\" for=\"group-durationrange-div\">',t=26,e+=\"Reset start and end interval</div></div></div>\",t=28,e+='<div class=\"mdl-cell mdl-cell--2-col\"></div></div>'}catch(i){pug.rethrow(i,d,t)}return e};\r\n\r\n    puglatizer[\"configurePartition\"][\"partitionText\"] = function template(l){var d,c,t=\"\";try{c=1,t+='<div class=\"mdl-grid\" data-hook=\"group-text-panel\">',c=2,t+='<div class=\"mdl-cell mdl-cell--1-col facetIcon facetTextIcon\"></div>',c=3,t+='<div class=\"mdl-cell mdl-cell--1-col\"></div>',c=4,t+='<div class=\"mdl-cell mdl-cell--8-col\">',c=5,t+='<div class=\"mdl-grid mdl-cell mdl-cell--12-col\">',c=7,t+='<div class=\"mdl-cell mdl-cell--3-col\" data-hook=\"group-order-abc\">',c=8,t+='<button class=\"mdl-button mdl-js-button mdl-js-ripple-effect\">',c=8,t+=\"Order alfabetically</button></div>\",c=10,t+='<div class=\"mdl-cell mdl-cell--3-col\" data-hook=\"group-order-count\">',c=11,t+='<button class=\"mdl-button mdl-js-button mdl-js-ripple-effect\">',c=11,t+=\"Order by count</button></div></div></div></div>\"}catch(e){pug.rethrow(e,d,c)}return t};\r\n\r\n    puglatizer[\"datasets\"] = {}\r\n    puglatizer[\"datasets\"][\"dataset\"] = function template(t){var a,d,l=\"\";try{d=1,l+='<div class=\"mdl-card mdl-shadow--2dp\" data-hook=\"dataset\" style=\"min-height: inherit\">',d=2,l+='<div class=\"mdl-card__title\">',d=3,l+='<h2 class=\"mdl-card__title-text\" data-hook=\"name\"></h2></div>',d=5,l+='<div class=\"mdl-card__supporting-text\" data-hook=\"description\"></div>',d=7,l+='<div class=\"mdl-card__actions mdl-card--border\">',d=8,l+='<a class=\"mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect\" data-hook=\"delete\">',d=9,l+=\"Delete</a>\",d=10,l+='<button class=\"mdl-button mdl-js button mdl-button--icon mdl-button--colored\" data-hook=\"settings\" style=\"float: right\">',d=11,l+='<i class=\"material-icons\">',d=11,l+=\"settings</i></button></div>\",d=13,l+='<div class=\"mdl-card__menu\">',d=14,l+='<span class=\"mdl-spinner mdl-js-spinner is-active\" data-hook=\"cbspinner\"></span>',d=15,l+='<span data-hook=\"cbtoggle\">',d=16,l+='<label class=\"mdl-switch mdl-js-switch mdl-js-ripple-effect\" data-hook=\"cblabel\" for=\"\">',d=17,l+='<input class=\"mdl-switch__input\" data-hook=\"cb\" type=\"checkbox\" id=\"\"/></label>',d=18,l+='<span class=\"mdl-switch__label\"></span></span></div></div>'}catch(s){pug.rethrow(s,a,d)}return l};\r\n\r\n    puglatizer[\"datasets\"][\"datasetCollection\"] = function template(t){var a,e,r=\"\";try{e=1,r+='<div data-hook=\"items\" style=\"display: flex; flex-wrap: wrap;\"></div>'}catch(i){pug.rethrow(i,a,e)}return r};\r\n\r\n    puglatizer[\"datasets\"][\"page\"] = function template(t){var a,l,d=\"\";try{l=1,d+='<div class=\"mdl-layout mdl-js-layout mdl-layout--fixed-header\">',l=2,d+='<main class=\"mdl-layout__content\" style=\"background-color: white;\">',l=3,d+=\"<div>\",l=5,d+='<div class=\"mdl-grid\">',l=6,d+='<dialog class=\"mdl-dialog\" data-hook=\"CSV-settings\">',l=7,d+='<div class=\"mdl-dialog__content\">',l=8,d+='<section class=\"mdl-grid\" id=\"csv-settings-table\" name=\"csv-settings-table\">',l=9,d+=\"<div>\",l=10,d+='<table class=\"mdl-data-table mdl-js-data-table\">',l=11,d+=\"<tbody>\",l=12,d+=\"<tr>\",l=13,d+=\"<td>\",l=13,d+=\"Headers</td>\",l=14,d+=\"<td>\",l=15,d+=\"<span>\",l=16,d+='<label class=\"mdl-checkbox mdl-js-checkbox mdl-js-ripple-effect\" for=\"CSV-header-columns\">',l=17,d+=\"Enable\",l=18,d+='<input class=\"mdl-checkbox__input\" type=\"checkbox\" id=\"CSV-header-columns\"/></label></span></td></tr>',l=19,d+=\"<tr>\",l=20,d+=\"<td>\",l=20,d+=\"Delimiter</td>\",l=21,d+=\"<td>\",l=22,d+=\"<span>\",l=23,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-separator-comma\">',l=24,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-separator-comma\" name=\"CSV-separator-options\" value=\"comma\"/></label></span>',l=25,d+='<span class=\"mdl-typography--title-color-contrast\">',l=26,d+=\",</span></td>\",l=27,d+=\"<td>\",l=28,d+=\"<span>\",l=29,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-separator-colon\">',l=30,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-separator-colon\" name=\"CSV-separator-options\" value=\"colon\"/></label></span>',l=31,d+='<span class=\"mdl-typography--title-color-contrast\">',l=32,d+=\":</span></td>\",l=33,d+=\"<td>\",l=34,d+=\"<span>\",l=35,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-separator-semicolon\">',l=36,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-separator-semicolon\" name=\"CSV-separator-options\" value=\"semicolon\"/></label></span>',l=37,d+='<span class=\"mdl-typography--title-color-contrast\">',l=38,d+=\";</span></td>\",l=39,d+=\"<td>\",l=40,d+=\"<span>\",l=41,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-separator-pipe\">',l=42,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-separator-pipe\" name=\"CSV-separator-options\" value=\"pipe\"/></label></span>',l=43,d+='<span class=\"mdl-typography--title-color-contrast\">',l=44,d+=\"|</span></td>\",l=45,d+=\"<td>\",l=46,d+=\"<span>\",l=47,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-separator-tab\">',l=48,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-separator-tab\" name=\"CSV-separator-options\" value=\"tab\"/></label></span>',l=49,d+=\"<span>\",l=50,d+=\"Tab</span></td>\",l=51,d+=\"<td>\",l=52,d+=\"<span>\",l=53,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-separator-other\">',l=54,d+='<input class=\"mdl-radio__button\" type=\"radio\" data-hook=\"CSV-separator-other\" id=\"CSV-separator-other\" name=\"CSV-separator-options\" value=\"other\"/></label></span>',l=55,d+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label\" style=\"width: fit-content;\">',l=56,d+='<input class=\"mdl-textfield__input\" data-hook=\"CSV-separator-other-input\" type=\"text\" id=\"CSV-separator-other-input\" name=\"CSV-separator-other-input\"/>',l=57,d+='<label class=\"mdl-textfield__label\" for=\"CSV-separator-other-input\">',l=58,d+=\"Other</label></div></td></tr>\",l=59,d+=\"<tr>\",l=60,d+=\"<td>\",l=60,d+=\"Quoting</td>\",l=61,d+=\"<td>\",l=62,d+=\"<span>\",l=63,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-quote-none\">',l=64,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-quote-none\" name=\"CSV-quote\" value=\"none\"/></label></span>',l=65,d+=\"<span>\",l=66,d+=\"None</span></td>\",l=67,d+=\"<td>\",l=68,d+=\"<span>\",l=69,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-quote-single\">',l=70,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-quote-single\" name=\"CSV-quote\" value=\"single\"/></label></span>',l=71,d+='<span class=\"mdl-typography--title-color-contrast\">',l=72,d+=\"'</span></td>\",l=73,d+=\"<td>\",l=74,d+=\"<span>\",l=75,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-quote-double\">',l=76,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-quote-double\" name=\"CSV-quote\" value=\"double\"/></label></span>',l=77,d+='<span class=\"mdl-typography--title-color-contrast\">',l=78,d+='\"</span></td></tr>',l=79,d+=\"<tr>\",l=80,d+=\"<td>\",l=80,d+=\"Comments</td>\",l=81,d+=\"<td>\",l=82,d+=\"<span>\",l=83,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-comment-pound\">',l=84,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-comment-pound\" name=\"CSV-comment\" value=\"pound\"/></label></span>',l=85,d+='<span class=\"mdl-typography--title-color-contrast\">',l=86,d+=\"#</span></td>\",l=87,d+=\"<td>\",l=88,d+=\"<span>\",l=89,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-comment-exclamation\">',l=90,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-comment-exclamation\" name=\"CSV-comment\" value=\"exclamation\"/></label></span>',l=91,d+='<span class=\"mdl-typography--title-color-contrast\">',l=92,d+=\"!</span></td>\",l=93,d+=\"<td>\",l=94,d+=\"<span>\",l=95,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-comment-slash\">',l=96,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-comment-slash\" name=\"CSV-comment\" value=\"slash\"/></label></span>',l=97,d+='<span class=\"mdl-typography--title-color-contrast\">',l=98,d+=\"/</span></td>\",l=99,d+=\"<td>\",l=100,d+=\"<span>\",l=101,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-comment-dash\">',l=102,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-comment-dash\" name=\"CSV-comment\" value=\"dash\"/></label></span>',l=103,d+='<span class=\"mdl-typography--title-color-contrast\">',l=104,d+=\"-</span></td>\",l=105,d+=\"<td>\",l=106,d+=\"<span>\",l=107,d+='<label class=\"mdl-radio mdl-js-radio mdl-js-ripple-effect\" for=\"CSV-comment-percent\">',l=108,d+='<input class=\"mdl-radio__button\" type=\"radio\" id=\"CSV-comment-percent\" name=\"CSV-comment\" value=\"percent\"/></label></span>',l=109,d+='<span class=\"mdl-typography--title-color-contrast\">',l=110,d+=\"%</span></td></tr></tbody></table></div></section>\",l=112,d+='<div class=\"mdl-dialog__actions mdl-dialog__actions\">',l=114,d+='<button class=\"mdl-button close\" data-hook=\"CSV-settings-close\" type=\"button\">',l=114,d+=\"Close</button></div></div></dialog></div>\",l=116,d+='<dialog class=\"mdl-dialog\" data-hook=\"session-download-cloud\">',l=117,d+='<div class=\"mdl-dialog__content\">',l=118,d+=\"<p></p>\",l=119,d+=\"Enter the url of the session. <br/>Make sure that you saved your current session!\",l=120,d+='<div class=\"mdl-textfield mdl-js-textfield mdl-textfield--floating-label mdl-cell mdl-cell--12-col\">',l=121,d+='<input class=\"mdl-textfield__input\" id=\"session-import-remote-link\" data-hook=\"session-import-remote-link\" type=\"text\"/></div></div>',l=122,d+='<div class=\"mdl-dialog__actions mdl-dialog__actions\">',l=123,d+='<button class=\"mdl-button\" data-hook=\"session-download-cloud-get\" type=\"button\">',l=123,d+=\"Import</button>\",l=124,d+='<button class=\"mdl-button close\" data-hook=\"session-download-cloud-close-button\" type=\"button\">',l=124,d+=\"Cancel</button></div></dialog>\",l=127,d+='<header class=\"mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600\">',l=128,d+='<div class=\"mdl-layout__header-row\">',l=129,d+='<span class=\"mdl-layout-title\" style=\"padding: 0; text-align: center;\">',l=129,d+=\"Datasets</span>\",l=131,d+='<div class=\"mdl-layout-spacer\"></div>',l=133,d+='<button class=\"mdl-button mdl-js-button mdl-button--icon mdl-js-ripple-effect\" data-hook=\"search-button\" id=\"tt3\" data-position=\"bottom\" data-step=\"1\" data-intro=\"You can search available datasets here.\">',l=134,d+='<i class=\"material-icons\">',l=134,d+=\"search</i></button>\",l=136,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"tt3\">',l=137,d+=\"Show or hide search bar</div></div>\",l=139,d+='<div class=\"mdl-layout__header-row\" data-hook=\"search-bar\">',l=140,d+='<div class=\"mdl-layout-spacer\"></div>',l=141,d+='<span class=\"mdl-color--white mdl-color-text--primary searchBar\">',l=143,d+='<span class=\"mdl-textfield searchBar\">',l=144,d+='<input class=\"mdl-textfield__input searchBar\" data-hook=\"dataset-selector\" type=\"text\" id=\"tt5\"/>',l=145,d+='<div class=\"mdl-tooltip mdl-tooltip--large\" for=\"tt5\">',l=146,d+=\"Search facet name and description</div></span></span></div>\",l=148,d+='<div data-hook=\"add-datasets-div\" id=\"add-datasets-div\">',l=149,d+='<div style=\"display: flex; align-items: center; justify-content: center;\">',l=150,d+='<div class=\"data-page-card-button mdl-card mdl-shadow--2dp\">',l=151,d+='<div class=\"mdl-card__title\">',l=152,d+='<button class=\"mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect serverconnect-btn\" data-hook=\"server-connect\" id=\"serverButton\">',l=153,d+=\"Connect</button></div>\",l=154,d+='<div class=\"mdl-card__supporting-text\">',l=155,d+=\"Connect to a PostgreSQL server.</div></div>\",l=157,d+='<div class=\"data-page-card-button mdl-card mdl-shadow--2dp\">',l=158,d+='<div class=\"mdl-card__title\">',l=159,d+='<label class=\"mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect jsonupload-btn\" for=\"jsonuploadBtn\" id=\"jsonUploadLabel\">',l=160,d+=\"Import JSON</label>\",l=161,d+='<input class=\"fileBtn\" type=\"file\" accept=\".json\" data-hook=\"json-upload-input\" id=\"jsonuploadBtn\"/></div>',l=162,d+='<div class=\"mdl-card__supporting-text\">',l=163,d+=\"Import a JSON file from your computer.</div></div>\",l=165,d+='<div class=\"data-page-card-button mdl-card mdl-shadow--2dp\">',l=166,d+='<div class=\"mdl-card__title\">',l=167,d+='<label class=\"mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect csvupload-btn\" for=\"csvuploadBtn\">',l=168,d+=\"Import CSV</label>\",l=169,d+='<input class=\"fileBtn\" type=\"file\" accept=\".csv,.txt,.tsv\" data-hook=\"csv-upload-input\" id=\"csvuploadBtn\"/></div>',l=170,d+='<div class=\"mdl-card__supporting-text\">',l=171,d+=\"Import a CSV file from your computer.</div>\",l=172,d+='<div class=\"mdl-card__menu\">',l=173,d+='<button class=\"mdl-button mdl-button--icon mdl-js-button mdl-js-ripple-effect\" data-hook=\"CSV-settings-button\" id=\"csv-settings-button\">',l=174,d+='<i class=\"material-icons\">',l=174,d+=\"settings</i></button></div></div>\",l=176,d+='<div class=\"data-page-card-button mdl-card mdl-shadow--2dp\">',l=177,d+='<div class=\"mdl-card__title\">',l=178,d+='<label class=\"mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect datadownload-btn\" for=\"dataDownloadBtn\">',l=179,d+=\"Download data</label>\",l=180,d+='<a class=\"fileBtn\" data-hook=\"data-download\" id=\"dataDownloadBtn\" download=\"download\"></a></div>',l=181,d+='<div class=\"mdl-card__supporting-text\">',l=182,d+=\"Download the current data to your computer.</div></div></div></div>\",l=184,d+='<div data-hook=\"dataset-items\" style=\"width: 100%\"></div></header>',l=187,d+='<header class=\"mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600\">',l=188,d+='<div class=\"mdl-layout__header-row\">',l=189,d+='<span class=\"mdl-layout-title\" style=\"padding: 0; text-align: center;\">',l=189,d+=\"Sessions</span></div>\",l=191,d+='<div data-hook=\"add-sessions-div\" style=\"display: flex; align-items: center; justify-content: center;\">',l=192,d+='<div class=\"data-page-card-button mdl-card mdl-shadow--2dp\">',l=193,d+='<div class=\"mdl-card__title\">',l=194,d+='<a class=\"mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect sessiondownload-btn\" data-hook=\"session-download\" download=\"download\">',l=195,d+=\"Export session</a></div>\",l=196,d+='<div class=\"mdl-card__supporting-text\">',l=197,d+=\"Save the current dashboard to your computer.</div></div>\",l=199,d+='<div class=\"data-page-card-button mdl-card mdl-shadow--2dp\">',l=200,d+='<div class=\"mdl-card__title\">',l=201,d+='<label class=\"mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect sessionupload-btn\" for=\"sessionuploadBtn\" data-hook=\"session-upload\">',l=202,d+=\"Import session</label>\",l=203,d+='<input class=\"fileBtn\" type=\"file\" accept=\".json\" data-hook=\"session-upload-input\" id=\"sessionuploadBtn\"/></div>',l=204,d+='<div class=\"mdl-card__supporting-text\">',l=205,d+=\"Import a saved dashboard from your computer.</div></div>\",l=207,d+='<div class=\"data-page-card-button mdl-card mdl-shadow--2dp\">',l=208,d+='<div class=\"mdl-card__title\">',l=209,d+='<a class=\"mdl-button mdl-js-button mdl-button--raised mdl-color--blue-grey-900 mdl-color-text--white mdl-js-ripple-effect sessionclouddown-btn\" data-hook=\"session-cloud-download\" cloud-download=\"cloud-download\">',l=210,d+=\"Session by URL</a></div>\",l=211,d+='<div class=\"mdl-card__supporting-text\">',l=212,d+=\"Import a dashboard using URL.</div></div></div>\",l=214,d+='<div data-hook=\"session-items\" style=\"width: 100%\"></div></header></div></main></div>'}catch(o){pug.rethrow(o,a,l)}return d};\r\n\r\n    puglatizer[\"datasets\"][\"session\"] = function template(a){var d,s,t=\"\";try{s=1,t+='<div class=\"mdl-card mdl-shadow--2dp\" data-hook=\"session\" style=\"min-height: inherit\">',s=2,t+='<div class=\"mdl-card__title\">',s=3,t+='<h2 class=\"mdl-card__title-text\" data-hook=\"date\"></h2></div>',s=5,t+='<div class=\"mdl-card__supporting-text\" data-hook=\"description\"></div>',s=7,t+='<div class=\"mdl-card__actions mdl-card--border\">',s=8,t+='<a class=\"mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect\" data-hook=\"delete\">',s=9,t+=\"Delete</a></div>\",s=11,t+='<div class=\"mdl-card__menu\">',s=12,t+='<span class=\"mdl-spinner mdl-js-spinner is-active\" data-hook=\"cbspinner\"></span>',s=13,t+='<span data-hook=\"cbtoggle\">',s=14,t+='<label class=\"mdl-switch mdl-js-switch mdl-js-ripple-effect\" data-hook=\"cblabel\" for=\"\">',s=15,t+='<input class=\"mdl-switch__input\" data-hook=\"cb\" type=\"checkbox\" id=\"\"/></label>',s=16,t+='<span class=\"mdl-switch__label\"></span></span></div></div>'}catch(l){pug.rethrow(l,d,s)}return t};\r\n\r\n    puglatizer[\"datasets\"][\"sessionCollection\"] = function template(t){var e,a,r=\"\";try{a=1,r+='<div data-hook=\"session-collection-items\" style=\"display: flex; flex-wrap: wrap;\"></div>'}catch(i){pug.rethrow(i,e,a)}return r};\r\n\r\n    puglatizer[\"head\"] = function template(e){var t,a,n=\"\";try{a=1,n+=\"<head>\",a=2,n+='<meta charset=\"utf-8\"/>',a=3,n+='<meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\"/>',a=4,n+='<meta name=\"description\" content=\"Spot - extensible facet browser\"/>',a=5,n+='<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, minimum-scale=1.0\"/>',a=6,n+=\"<title>\",a=7,n+=\"Spot</title>\",a=9,n+=\"<!-- Add to homescreen for Chrome on Android -->\",a=10,n+='<meta name=\"mobile-web-app-capable\" content=\"yes\"/>',a=13,n+=\"<!-- Add to homescreen for Safari on iOS -->\",a=14,n+='<meta name=\"apple-mobile-web-app-capable\" content=\"yes\"/>',a=15,n+='<meta name=\"apple-mobile-web-app-status-bar-style\" content=\"black\"/>',a=16,n+='<meta name=\"apple-mobile-web-app-title\" content=\"Spot\"/>',a=19,n+=\"<!-- Tile icon for Win8 (144x144 + tile color) -->\",a=21,n+='<meta name=\"msapplication-TileColor\" content=\"#3372DF\"/></head>'}catch(o){pug.rethrow(o,t,a)}return n};\r\n\r\n    puglatizer[\"help\"] = {}\r\n    puglatizer[\"help\"][\"analyze\"] = function template(a){var e,t,p=\"\";try{t=1,p+='<div data-hook=\"analyze-help\" id=\"analyze-help\" data-position=\"bottom\" data-step=\"1\">',t=2,p+=\"<h4>\",t=2,p+=\"Analyze page Help</h4>\",t=3,p+=\"<p></p>\",t=4,p+=\"Text here<br />\",t=5,p+=\"\\n\",t=5,p+=\"<br /></div>\"}catch(r){pug.rethrow(r,e,t)}return p};\r\n\r\n    puglatizer[\"help\"][\"menuButtons\"] = function template(e){var t,a,o=\"\";try{a=1,o+='<div data-hook=\"welcome-info\" id=\"welcome-info\" data-position=\"bottom\" data-step=\"1\">',a=2,o+=\"<p></p>\",a=3,o+=\"<h6>\",a=3,o+=\"You will find the following buttons on the left menu:</h6>\",a=4,o+=\"<lu>\",a=5,o+=\"<li>\",a=6,o+='<i class=\"material-icons\" role=\"presentation\">',a=6,o+=\"menu</i>\",a=7,o+=\"button controls the menu drawer.</li>\",a=8,o+=\"<li>\",a=9,o+='<i class=\"material-icons\" role=\"presentation\">',a=9,o+=\"home</i>\",a=10,o+=\"button opens the homepage. This is where you are at now.</li>\",a=11,o+=\"<li>\",a=12,o+='<i class=\"material-icons\" role=\"presentation\">',a=12,o+=\"storage</i>\",a=13,o+=\"button takes you to Datasets page. In Datasets page, you can upload your dataset or use existing datasets. You can also configure your datasets.</li>\",a=14,o+=\"<li>\",a=15,o+='<i class=\"material-icons\" role=\"presentation\">',a=15,o+=\"insert_chart</i>\",a=16,o+=\"button takes you to Analyze page. In Analyze page, you can create your dashboard in a few clicks by creating new charts.</li>\",a=17,o+=\"<li>\",a=18,o+='<i class=\"material-icons\" role=\"presentation\">',a=18,o+=\"share</i>\",a=19,o+=\"button takes you to Share page. In share page, you can share your current session or load the session which is shared with you.</li>\",a=20,o+=\"<li>\",a=21,o+='<i class=\"material-icons\" role=\"presentation\">',a=21,o+=\"help</i>\",a=22,o+=\"button guides you about the user interface.</li></lu></div>\"}catch(i){pug.rethrow(i,t,a)}return o};\r\n\r\n    puglatizer[\"help\"][\"welcome\"] = function template(e){var t,a,o=\"\";try{a=1,o+='<div data-hook=\"welcome-info\" id=\"welcome-info\" data-position=\"bottom\" data-step=\"1\">',a=2,o+=\"<h4>\",a=2,o+=\"Welcome to SPOT!</h4>\",a=3,o+=\"<p></p>\",a=4,o+='This software is being developed by the  <a href=\"https://www.esciencecenter.nl\" target=\"_blank\">Netherlands eScience Center</a>.<br />',a=5,o+=\"\\n\",a=5,o+=\"<br />\",a=6,o+=\"\\n\",a=6,o+='SPOT is a free and an open source software. The license of the SPOT is  <a href=\"http://www.apache.org/licenses/LICENSE-2.0\" target=\"_blank\">Apache 2.0</a>.<br />',a=7,o+=\"\\n\",a=7,o+=\"<br />\",a=8,o+=\"\\n\",a=8,o+='For the online tutorial of SPOT, please check <a href=\"https://nlesc.github.io/spot-tutorial/tutorial\" target=\"_blank\">this link</a>.<br />',a=9,o+=\"\\n\",a=9,o+=\"<br />\",a=10,o+=\"\\n\",a=10,o+=\"<br />\",a=11,o+=\"\\n\",a=11,o+='The desktop version of SPOT can be downloaded from <a href=\"https://github.com/NLeSC/spot-desktop-app/releases\" target=\"_blank\">this link</a>.<br />',a=12,o+=\"\\n\",a=12,o+=\"<br>\",a=13,o+=\"\\n\",a=13,o+=\"You can click the button below to start a demo session. The demo session has <b>Kaggle Titanic Survival</b> dataset.\",a=15,o+=\"\\n\",a=15,o+=\"<br><br> Happy SPOTTING!<br></div>\"}catch(n){pug.rethrow(n,t,a)}return o};\r\n\r\n    puglatizer[\"home\"] = function template(s){var a,l,e=\"\";try{l=1,e+='<main class=\"mdl-layout__content home-content bgspotImage\">',l=2,e+='<div class=\"content-grid mdl-grid mdl-cell--middle\">',l=4,e+='<div class=\"mdl-cell mdl-cell--12-col mdl-cell--0-offset mdl-shadow--2dp spot-cell spot-trans spot-color4\">',l=6,e+='<span class=\"cardTitleText material-icons menuIcon\">',l=6,e+=\"explore</span>\",l=7,e+='<span class=\"cardTitleText\">',l=7,e+=\" SPOT: interactive, fast facet browser</span>\",l=8,e+=\"<ul>\",l=9,e+=\"<li>\",l=10,e+='<p class=\"cardText\">',l=10,e+=\"SPOT is an interactive, fast data visualization tool. It was primarily designed as data exploration and analysis tool for complex multi-dimensional datasets. Users can visualize the data only with a few clicks. SPOT can be used to compare different datasets. It is also possible to connect to a Postresql server to analyze big datasets.</p></li></ul></div>\",l=12,e+='<div class=\"mdl-cell mdl-cell--4-col spot-cell spot-trans spot-color4\">',l=13,e+='<span class=\"cardTitleText material-icons menuIcon\">',l=13,e+=\"merge_type</span>\",l=14,e+='<span class=\"cardTitleText\">',l=14,e+=\"Highlights</span>\",l=15,e+=\"<ul>\",l=16,e+=\"<li>\",l=17,e+='<div class=\"cardText\">',l=17,e+=\"Specifically designed for scientific data visualization</div></li>\",l=18,e+=\"<li>\",l=19,e+='<div class=\"cardText\">',l=19,e+=\"Fully animated and interactive charts</div></li>\",l=20,e+=\"<li>\",l=21,e+='<div class=\"cardText\">',l=21,e+=\"Exploration sessions can be saved</div></li>\",l=22,e+=\"<li>\",l=23,e+='<div class=\"cardText\">',l=23,e+=\"Database connection (Postgresql)</div></li></ul></div>\",l=25,e+='<div class=\"mdl-cell mdl-cell--4-col spot-cell spot-trans spot-color4\">',l=26,e+='<span class=\"cardTitleText material-icons menuIcon\">',l=26,e+=\"extension</span>\",l=27,e+='<span class=\"cardTitleText\">',l=27,e+=\"  Modern tools</span>\",l=28,e+=\"<ul>\",l=29,e+=\"<li>\",l=30,e+='<div class=\"cardText\">',l=30,e+=\"Viewer is fully standalone (no server required)</div></li>\",l=31,e+=\"<li>\",l=32,e+='<div class=\"cardText\">',l=32,e+=\"Responsive interface: material design lite</div></li>\",l=33,e+=\"<li>\",l=34,e+='<div class=\"cardText\">',l=34,e+=\"Fast filtering (~1M data points in ~30ms)</div></li>\",l=35,e+=\"<li>\",l=36,e+='<div class=\"cardText\">',l=36,e+=\"Cross platform (desktop, mobile and tablet)</div></li></ul></div>\",l=38,e+='<div class=\"mdl-cell mdl-cell--4-col mdl-shadow--2dp spot-cell spot-trans spot-color4\">',l=39,e+='<span class=\"cardTitleText material-icons menuIcon\">',l=39,e+=\"lock_open</span>\",l=40,e+='<span class=\"cardTitleText\">',l=40,e+=\"  Open Source</span>\",l=41,e+=\"<ul>\",l=42,e+=\"<li>\",l=43,e+='<div class=\"cardText\">',l=43,e+=\"Permissive Open source Licence (Apache 2.0)</div></li>\",l=44,e+=\"<li>\",l=45,e+='<div class=\"cardText\">',l=45,e+=\"Continuous Integration</div></li>\",l=46,e+=\"<li>\",l=47,e+='<div class=\"cardText\">',l=47,e+=\"Documented (jsdoc) and tested (jasmine)</div></li>\",l=48,e+=\"<li>\",l=49,e+='<div class=\"cardText\">',l=49,e+=\"Generic tool to be useful in any scientific project</div></li></ul></div></div>\",l=51,e+='<div class=\"mdl-layout-spacer\"></div>',l=53,e+='<footer class=\"mdl-mega-footer spot-cell spot-trans spot-color4\">',l=54,e+='<div class=\"spot-footer\">',l=58,e+='<div class=\"spot-footer-item\">',l=59,e+='<a class=\"spotlink\" data-hook=\"demo-session\" href=\"\">',l=60,e+='<span class=\"footerImg material-icons menuIcon\">',l=60,e+=\"ondemand_video</span>\",l=61,e+='<span class=\"footerItem\">',l=61,e+=\"Demo</span></a></div>\",l=62,e+='<div class=\"spot-footer-item\">',l=63,e+='<a class=\"spotlink\" data-hook=\"tutorialpage\" href=\"https://nlesc.github.io/spot-tutorial/tutorial\" target=\"_blank\">',l=64,e+='<span class=\"footerImg material-icons menuIcon\">',l=64,e+=\"link</span>\",l=65,e+='<span class=\"footerItem\">',l=65,e+=\"Tutorial</span></a></div>\",l=66,e+='<div class=\"spot-footer-item\">',l=67,e+='<a class=\"spotlink\" data-hook=\"githubpage\" href=\"https://github.com/NLeSC/spot\" target=\"_blank\">',l=68,e+='<span class=\"footerImg material-icons menuIcon\">',l=68,e+=\"link</span>\",l=69,e+='<span class=\"footerItem\">',l=69,e+=\"Project</span></a></div></div>\",l=70,e+='<div class=\"spot-footer\">',l=71,e+='<span class=\"versionText\">',l=71,e+=\"Version 0.2.0</span></div></footer></main>\"}catch(t){pug.rethrow(t,a,l)}return e};\r\n\r\n    puglatizer[\"main\"] = function template(a){var l,s,t=\"\";try{s=1,t+=\"<body>\",s=2,t+='<div class=\"mdl-layout mdl-js-layout\" data-hook=\"test\">',s=4,t+='<div class=\"mdl-layout__header-row mdl-color--blue-grey-900\">',s=5,t+=\"<!-- Title-->\",s=6,t+='<span class=\"mdl-layout-title mdl-layout--large-screen-only\">',s=7,t+='<a data-hook=\"nlescpage\" href=\"https://www.esciencecenter.nl\" target=\"_blank\">',s=8,t+='<div class=\"demo-avatar\"></div></a></span>',s=9,t+=\"<!-- Add spacer, to align navigation to the right-->\",s=10,t+='<div class=\"mdl-layout-spacer\"></div>',s=11,t+=\"<!-- Navigation. We hide it in small screens.-->\",s=12,t+='<nav class=\"mdl-navigation mdl-layout--large-screen-only\">',s=13,t+='<a class=\"mdl-navigation__link\" href=\"/home\">',s=13,t+=\"Home</a>\",s=14,t+='<a class=\"mdl-navigation__link\" href=\"/datasets\">',s=14,t+=\"Data</a>\",s=15,t+='<a class=\"mdl-navigation__link\" href=\"/analyze\">',s=15,t+=\"Analysis</a>\",s=16,t+='<a class=\"mdl-navigation__link\" href=\"#\" data-hook=\"help-button\" id=\"help-button\">',s=17,t+='<i class=\"material-icons\">',s=17,t+=\"help</i></a></nav></div>\",s=24,t+='<div class=\"mdl-drawer mdl-layout__drawer mdl-color--blue-grey-900 mdl-layout--small-screen-only\">',s=25,t+='<span class=\"mdl-layout-title\">',s=27,t+='<a data-hook=\"nlescpage\" href=\"https://www.esciencecenter.nl\" target=\"_blank\">',s=28,t+='<div class=\"demo-avatar\" style=\"margin-top: 20px; margin-bottom: 50px;\"></div></a></span>',s=29,t+='<nav class=\"mdl-navigation\">',s=30,t+='<a class=\"mdl-navigation__link\" href=\"/home\">',s=30,t+=\"Home</a>\",s=31,t+='<a class=\"mdl-navigation__link\" href=\"/datasets\">',s=31,t+=\"Data</a>\",s=32,t+='<a class=\"mdl-navigation__link\" href=\"/analyze\">',s=32,t+=\"Dashboard</a>\",s=33,t+='<a class=\"mdl-navigation__link\" href=\"#\" data-hook=\"help-button\" id=\"help-button\">',s=34,t+='<i class=\"material-icons\">',s=34,t+=\"help</i>\",s=35,t+=\"<span>\",s=35,t+=\"Help</span></a></nav>\",s=37,t+='<div class=\"mdl-drawer-separator\"></div>',s=38,t+='<div class=\"mdl-layout-spacer\" style=\"margin-top: 20px;\"></div>',s=40,t+='<nav class=\"mdl-navigation\">',s=41,t+='<a class=\"mdl-navigation__link\" href=\"https://nlesc.github.io/spot-tutorial/tutorial\">',s=41,t+=\"Tutorial</a>\",s=42,t+='<a class=\"mdl-navigation__link\" href=\"https://github.com/NLeSC/spot\">',s=42,t+=\"Github</a></nav>\",s=44,t+='<div class=\"mdl-drawer-separator\"></div>',s=45,t+='<div class=\"mdl-layout-spacer\" style=\"margin-bottom: 20px;\"></div>',s=46,t+='<span class=\"versionText\">',s=46,t+=\"Version 0.2.0</span></div>\",s=49,t+='<div class=\"mdl-grid\">',s=50,t+='<dialog class=\"mdl-dialog\" data-hook=\"main-dialog\" id=\"main-dialog\" style=\"border: none; width: min-content; background: transparent;\">',s=51,t+='<div class=\"mdl-dialog__content\">',s=53,t+='<p2 class=\"mdl-progress mdl-js-progress mdl-progress__indeterminate\"></p2></div></dialog></div>',s=58,t+='<main class=\"mdl-layout__content\" data-hook=\"page-container\"></main>',s=60,t+='<div class=\"mdl-progress mdl-js-progress\" id=\"progress-bar\" style=\"width: 100%; height: 5%; display: none\"></div>',s=62,t+='<div class=\"mdl-js-snackbar mdl-snackbar\" id=\"snack-bar\" aria-live=\"assertive\" aria-atomic=\"true\" aria-relevant=\"text\">',s=63,t+='<div class=\"mdl-snackbar__text\"></div>',s=64,t+='<button class=\"mdl-snackbar__action\" type=\"button\"></button></div></div></body>'}catch(i){pug.rethrow(i,l,s)}return t};\r\n\r\n\r\n    return puglatizer;\r\n}));\r\n"],"mappings":";;AAAA;AACA;AADA;AACA;AACA;AAAA;AAAA;AAAA;AACA,WAOA;AACA;AACA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AADA;AAAA;AACA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAPA;AAUA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AACA;AAEA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///4324\n')},48248:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nmodule.exports = View.extend({\n  template: templates.datasets.session,\n  derived: {// facetsURL: {\n    //   deps: ['model.id'],\n    //   fn: function () {\n    //     return this.model.id;\n    //   }\n    // }\n  },\n  props: {\n    bussy: ['boolean', true, false]\n  },\n  bindings: {\n    'bussy': [{\n      hook: 'cbtoggle',\n      type: 'toggle',\n      invert: true\n    }, {\n      hook: 'cbspinner',\n      type: 'toggle',\n      invert: false\n    }],\n    // 'model.show': {\n    //   hook: 'session',\n    //   type: 'toggle'\n    // },\n    'model.date': {\n      hook: 'date',\n      type: 'text'\n    },\n    'model.name': {\n      hook: 'name',\n      type: 'text'\n    },\n    // material design hooks\n    'model.isActive': [{\n      hook: 'cb',\n      type: 'booleanAttribute',\n      name: 'checked'\n    }, {\n      type: 'toggle',\n      hook: 'settings',\n      invert: true\n    }],\n    'model.id': [{\n      hook: 'cb',\n      type: 'attribute',\n      name: 'id'\n    }, {\n      hook: 'cblabel',\n      type: 'attribute',\n      name: 'for'\n    }]\n  },\n  events: {\n    'change': 'toggleActive',\n    // 'click [data-hook~=settings]': function () { app.navigate('/dataset/' + this.model.id); },\n    'click [data-hook~=delete]': 'deleteSession'\n  },\n  toggleActive: function toggleActive() {\n    var that = this;\n    that.bussy = !that.busy;\n    that.model.isActive = !that.model.isActive; //   // if (that.model.facets.length === 0) {\n    //   //   // Automatically scan the dataset if there are no facets\n    //   //   that.model.scan();\n    //   //   that.model.once('syncFacets', function () {\n    //   //     app.me.toggleDataset(that.model);\n    //   //     that.bussy = !that.bussy;\n    //   //   });\n    //   // } else {\n    //   //   // BUGFIX: we cant show/hide the spinner from within the event loop; so\n    //   //   //  * activate the spinner,\n    //   //   //  * exit the event loop (ie. redraw the page),\n    //   //   //  * and toggle the dataset via the timeout\n    //   //   window.setTimeout(function () {\n    //   //     app.me.toggleDataset(that.model);\n    //   //     that.bussy = !that.bussy;\n    //   //   }, 500);\n    //   // }\n\n    that.bussy = !that.bussy;\n  },\n  deleteSession: function deleteSession() {\n    console.log('Deleting the session'); //   // if (this.model.isActive) {\n    //   //   this.bussy = true;\n    //   //   app.me.toggleDataset(this.model);\n    //   //   this.bussy = false;\n    //   // }\n\n    console.log(this.model);\n    app.removeSessionFromLocalStorage(this.model.id);\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDgyNDguanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvcGFnZXMvZGF0YXNldHMvc2Vzc2lvbi12aWV3LmpzPzYzOTMiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xudmFyIGFwcCA9IHJlcXVpcmUoJ2FtcGVyc2FuZC1hcHAnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuZGF0YXNldHMuc2Vzc2lvbixcbiAgZGVyaXZlZDoge1xuICAgIC8vIGZhY2V0c1VSTDoge1xuICAgIC8vICAgZGVwczogWydtb2RlbC5pZCddLFxuICAgIC8vICAgZm46IGZ1bmN0aW9uICgpIHtcbiAgICAvLyAgICAgcmV0dXJuIHRoaXMubW9kZWwuaWQ7XG4gICAgLy8gICB9XG4gICAgLy8gfVxuICB9LFxuICBwcm9wczoge1xuICAgIGJ1c3N5OiBbJ2Jvb2xlYW4nLCB0cnVlLCBmYWxzZV1cbiAgfSxcbiAgYmluZGluZ3M6IHtcbiAgICAnYnVzc3knOiBbXG4gICAgICB7XG4gICAgICAgIGhvb2s6ICdjYnRvZ2dsZScsXG4gICAgICAgIHR5cGU6ICd0b2dnbGUnLFxuICAgICAgICBpbnZlcnQ6IHRydWVcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGhvb2s6ICdjYnNwaW5uZXInLFxuICAgICAgICB0eXBlOiAndG9nZ2xlJyxcbiAgICAgICAgaW52ZXJ0OiBmYWxzZVxuICAgICAgfVxuICAgIF0sXG4gICAgLy8gJ21vZGVsLnNob3cnOiB7XG4gICAgLy8gICBob29rOiAnc2Vzc2lvbicsXG4gICAgLy8gICB0eXBlOiAndG9nZ2xlJ1xuICAgIC8vIH0sXG4gICAgJ21vZGVsLmRhdGUnOiB7XG4gICAgICBob29rOiAnZGF0ZScsXG4gICAgICB0eXBlOiAndGV4dCdcbiAgICB9LCAgICBcbiAgICAnbW9kZWwubmFtZSc6IHtcbiAgICAgIGhvb2s6ICduYW1lJyxcbiAgICAgIHR5cGU6ICd0ZXh0J1xuICAgIH0sXG4gICAgLy8gbWF0ZXJpYWwgZGVzaWduIGhvb2tzXG4gICAgJ21vZGVsLmlzQWN0aXZlJzogW1xuICAgICAge1xuICAgICAgICBob29rOiAnY2InLFxuICAgICAgICB0eXBlOiAnYm9vbGVhbkF0dHJpYnV0ZScsXG4gICAgICAgIG5hbWU6ICdjaGVja2VkJ1xuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgdHlwZTogJ3RvZ2dsZScsXG4gICAgICAgIGhvb2s6ICdzZXR0aW5ncycsXG4gICAgICAgIGludmVydDogdHJ1ZVxuICAgICAgfVxuICAgIF0sXG4gICAgJ21vZGVsLmlkJzogW1xuICAgICAgeyBob29rOiAnY2InLCB0eXBlOiAnYXR0cmlidXRlJywgbmFtZTogJ2lkJyB9LFxuICAgICAgeyBob29rOiAnY2JsYWJlbCcsIHR5cGU6ICdhdHRyaWJ1dGUnLCBuYW1lOiAnZm9yJyB9XG4gICAgXVxuICB9LFxuICBldmVudHM6IHtcbiAgICAnY2hhbmdlJzogJ3RvZ2dsZUFjdGl2ZScsXG4gICAgLy8gJ2NsaWNrIFtkYXRhLWhvb2t+PXNldHRpbmdzXSc6IGZ1bmN0aW9uICgpIHsgYXBwLm5hdmlnYXRlKCcvZGF0YXNldC8nICsgdGhpcy5tb2RlbC5pZCk7IH0sXG4gICAgJ2NsaWNrIFtkYXRhLWhvb2t+PWRlbGV0ZV0nOiAnZGVsZXRlU2Vzc2lvbidcbiAgfSxcbiAgdG9nZ2xlQWN0aXZlOiBmdW5jdGlvbiAoKSB7XG4gICAgdmFyIHRoYXQgPSB0aGlzO1xuXG4gICAgdGhhdC5idXNzeSA9ICF0aGF0LmJ1c3k7XG4gICAgdGhhdC5tb2RlbC5pc0FjdGl2ZSA9ICF0aGF0Lm1vZGVsLmlzQWN0aXZlO1xuXG4gIC8vICAgLy8gaWYgKHRoYXQubW9kZWwuZmFjZXRzLmxlbmd0aCA9PT0gMCkge1xuICAvLyAgIC8vICAgLy8gQXV0b21hdGljYWxseSBzY2FuIHRoZSBkYXRhc2V0IGlmIHRoZXJlIGFyZSBubyBmYWNldHNcbiAgLy8gICAvLyAgIHRoYXQubW9kZWwuc2NhbigpO1xuICAvLyAgIC8vICAgdGhhdC5tb2RlbC5vbmNlKCdzeW5jRmFjZXRzJywgZnVuY3Rpb24gKCkge1xuICAvLyAgIC8vICAgICBhcHAubWUudG9nZ2xlRGF0YXNldCh0aGF0Lm1vZGVsKTtcbiAgLy8gICAvLyAgICAgdGhhdC5idXNzeSA9ICF0aGF0LmJ1c3N5O1xuICAvLyAgIC8vICAgfSk7XG4gIC8vICAgLy8gfSBlbHNlIHtcbiAgLy8gICAvLyAgIC8vIEJVR0ZJWDogd2UgY2FudCBzaG93L2hpZGUgdGhlIHNwaW5uZXIgZnJvbSB3aXRoaW4gdGhlIGV2ZW50IGxvb3A7IHNvXG4gIC8vICAgLy8gICAvLyAgKiBhY3RpdmF0ZSB0aGUgc3Bpbm5lcixcbiAgLy8gICAvLyAgIC8vICAqIGV4aXQgdGhlIGV2ZW50IGxvb3AgKGllLiByZWRyYXcgdGhlIHBhZ2UpLFxuICAvLyAgIC8vICAgLy8gICogYW5kIHRvZ2dsZSB0aGUgZGF0YXNldCB2aWEgdGhlIHRpbWVvdXRcbiAgLy8gICAvLyAgIHdpbmRvdy5zZXRUaW1lb3V0KGZ1bmN0aW9uICgpIHtcbiAgLy8gICAvLyAgICAgYXBwLm1lLnRvZ2dsZURhdGFzZXQodGhhdC5tb2RlbCk7XG4gIC8vICAgLy8gICAgIHRoYXQuYnVzc3kgPSAhdGhhdC5idXNzeTtcbiAgLy8gICAvLyAgIH0sIDUwMCk7XG4gIC8vICAgLy8gfVxuXG4gICAgdGhhdC5idXNzeSA9ICF0aGF0LmJ1c3N5O1xuICB9LFxuICBkZWxldGVTZXNzaW9uOiBmdW5jdGlvbiAoKSB7XG4gICAgY29uc29sZS5sb2coJ0RlbGV0aW5nIHRoZSBzZXNzaW9uJylcbiAgLy8gICAvLyBpZiAodGhpcy5tb2RlbC5pc0FjdGl2ZSkge1xuICAvLyAgIC8vICAgdGhpcy5idXNzeSA9IHRydWU7XG4gIC8vICAgLy8gICBhcHAubWUudG9nZ2xlRGF0YXNldCh0aGlzLm1vZGVsKTtcbiAgLy8gICAvLyAgIHRoaXMuYnVzc3kgPSBmYWxzZTtcbiAgLy8gICAvLyB9XG4gICAgY29uc29sZS5sb2codGhpcy5tb2RlbCk7XG4gICAgYXBwLnJlbW92ZVNlc3Npb25Gcm9tTG9jYWxTdG9yYWdlKHRoaXMubW9kZWwuaWQpO1xuICB9LFxuICByZW5kZXI6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnJlbmRlcldpdGhUZW1wbGF0ZSh0aGlzKTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFOQTtBQVFBO0FBQ0E7QUFEQTtBQUdBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFIQTtBQU1BO0FBQ0E7QUFDQTtBQUhBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUhBO0FBTUE7QUFDQTtBQUNBO0FBSEE7QUFNQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUF4Q0E7QUEyQ0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUtBO0FBQ0E7QUFFQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQW5HQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///48248\n")},4916:function(module,exports,__webpack_require__){eval("var Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar timeUtil = Spot.util.time; // this.model should be a DurationTransform\n\nvar DurationUnitsView = View.extend({\n  template: '<option data-hook=\"option\"> </option>',\n  render: function render() {\n    this.renderWithTemplate(this);\n  },\n  bindings: {\n    'model.description': [{\n      hook: 'option',\n      type: 'text'\n    }, {\n      hook: 'option',\n      type: 'attribute',\n      name: 'value'\n    }]\n  }\n});\nmodule.exports = View.extend({\n  template: '<select data-hook=\"options\"> </select>',\n  initialize: function initialize(options) {\n    this.field = options.field;\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.renderCollection(timeUtil.durationUnits, DurationUnitsView, this.queryByHook('options'));\n    var value = this.model[this.field];\n    this.queryByHook('options').value = value;\n  },\n  events: {\n    'change [data-hook=\"options\"]': 'changeDurationUnits'\n  },\n  changeDurationUnits: function changeDurationUnits() {\n    var value = this.queryByHook('options').value;\n    this.model[this.field] = value;\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNDkxNi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQvZHVyYXRpb24tdW5pdHMtc2VsZWN0LmpzP2JlODEiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFNwb3QgPSByZXF1aXJlKCdzcG90LWZyYW1ld29yaycpO1xudmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRpbWVVdGlsID0gU3BvdC51dGlsLnRpbWU7XG5cbi8vIHRoaXMubW9kZWwgc2hvdWxkIGJlIGEgRHVyYXRpb25UcmFuc2Zvcm1cblxudmFyIER1cmF0aW9uVW5pdHNWaWV3ID0gVmlldy5leHRlbmQoe1xuICB0ZW1wbGF0ZTogJzxvcHRpb24gZGF0YS1ob29rPVwib3B0aW9uXCI+IDwvb3B0aW9uPicsXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVuZGVyV2l0aFRlbXBsYXRlKHRoaXMpO1xuICB9LFxuICBiaW5kaW5nczoge1xuICAgICdtb2RlbC5kZXNjcmlwdGlvbic6IFtcbiAgICAgIHtcbiAgICAgICAgaG9vazogJ29wdGlvbicsXG4gICAgICAgIHR5cGU6ICd0ZXh0J1xuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgaG9vazogJ29wdGlvbicsXG4gICAgICAgIHR5cGU6ICdhdHRyaWJ1dGUnLFxuICAgICAgICBuYW1lOiAndmFsdWUnXG4gICAgICB9XG4gICAgXVxuICB9XG59KTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiAnPHNlbGVjdCBkYXRhLWhvb2s9XCJvcHRpb25zXCI+IDwvc2VsZWN0PicsXG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uIChvcHRpb25zKSB7XG4gICAgdGhpcy5maWVsZCA9IG9wdGlvbnMuZmllbGQ7XG4gIH0sXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVuZGVyV2l0aFRlbXBsYXRlKHRoaXMpO1xuICAgIHRoaXMucmVuZGVyQ29sbGVjdGlvbih0aW1lVXRpbC5kdXJhdGlvblVuaXRzLCBEdXJhdGlvblVuaXRzVmlldywgdGhpcy5xdWVyeUJ5SG9vaygnb3B0aW9ucycpKTtcblxuICAgIHZhciB2YWx1ZSA9IHRoaXMubW9kZWxbdGhpcy5maWVsZF07XG4gICAgdGhpcy5xdWVyeUJ5SG9vaygnb3B0aW9ucycpLnZhbHVlID0gdmFsdWU7XG4gIH0sXG4gIGV2ZW50czoge1xuICAgICdjaGFuZ2UgW2RhdGEtaG9vaz1cIm9wdGlvbnNcIl0nOiAnY2hhbmdlRHVyYXRpb25Vbml0cydcbiAgfSxcbiAgY2hhbmdlRHVyYXRpb25Vbml0czogZnVuY3Rpb24gKCkge1xuICAgIHZhciB2YWx1ZSA9IHRoaXMucXVlcnlCeUhvb2soJ29wdGlvbnMnKS52YWx1ZTtcbiAgICB0aGlzLm1vZGVsW3RoaXMuZmllbGRdID0gdmFsdWU7XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFDQTtBQUhBO0FBTkE7QUFMQTtBQW9CQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFsQkEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///4916\n")},"4b1e":function(module,exports,__webpack_require__){eval("var PageView = __webpack_require__(/*! ./base */ \"b966\");\n\nvar templates = __webpack_require__(/*! ../templates */ \"4324\");\n\nvar FacetCollectionView = __webpack_require__(/*! ./configure-dataset/facet-collection */ \"701f\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar $ = __webpack_require__(/*! jquery */ \"802c\"); // Assumption:\n// this.model instanceof Dataset\n// this.collection instanceof facet-collection\n\n\nmodule.exports = PageView.extend({\n  template: templates.configureDataset.page,\n  render: function render() {\n    this.renderWithTemplate();\n\n    if (this.collection) {\n      this.collection.sort();\n      this.renderCollection(this.collection, FacetCollectionView, this.queryByHook('facet-list'));\n    }\n\n    this.query('#description').value = this.model.description; // material design lite does not like this via bindings...\n    // Automatically scan the dataset if necessary\n\n    if (this.model.facets.length === 0) {\n      this.model.scan();\n    }\n  },\n  initialize: function initialize() {\n    this.isLockedDown = app.me.isLockedDown;\n    this.needle = this.collection.needle;\n    this.showSearch = this.collection.showSearch;\n    this.on('remove', function () {\n      this.collection.needle = this.needle;\n      this.collection.showSearch = this.showSearch;\n      this.model.facets.off('add');\n    });\n    this.model.facets.on('add', function () {\n      setTimeout(function () {\n        window.componentHandler.upgradeDom();\n      }, 20);\n    });\n    this.update();\n  },\n  session: {\n    needle: 'string',\n    showSearch: 'boolean',\n    isLockedDown: 'boolean'\n  },\n  bindings: {\n    'isLockedDown': [{\n      type: 'toggle',\n      hook: 'add-button',\n      invert: 'yes'\n    }, {\n      type: 'toggle',\n      hook: 'rescan-button',\n      invert: 'yes'\n    }],\n    'showSearch': {\n      type: 'toggle',\n      hook: 'search-bar'\n    },\n    'needle': {\n      type: 'value',\n      hook: 'facet-selector'\n    },\n    'model.name': {\n      type: 'attribute',\n      selector: '#name',\n      name: 'value'\n    }\n  },\n  events: {\n    'input [data-hook~=facet-selector]': 'input',\n    'input #name': 'setName',\n    'input #description': 'setDescription',\n    'click #eab': 'enableAllFacets',\n    'click #dab': 'disableAllFacets',\n    'click [data-hook~=add-button]': 'add',\n    'click [data-hook~=rescan-button]': 'rescan',\n    'click [data-hook~=search-button]': 'search',\n    'click [data-hook~=clear-button]': 'clear'\n  },\n  enableAllFacets: function enableAllFacets() {\n    var i;\n    var f = $('[data-hook~=cblabel]');\n\n    for (i = 0; i < f.length; i++) {\n      var c = f[i].classList;\n\n      if (!c.contains('is-checked')) {\n        f[i].click();\n      }\n    }\n  },\n  disableAllFacets: function disableAllFacets() {\n    var i;\n    var f = $('[data-hook~=cblabel]');\n\n    for (i = 0; i < f.length; i++) {\n      var c = f[i].classList;\n\n      if (c.contains('is-checked')) {\n        f[i].click();\n      }\n    }\n  },\n  input: function input() {\n    var select = this.el.querySelector('[data-hook~=\"facet-selector\"]');\n    this.needle = select.value;\n    this.update();\n  },\n  setName: function setName() {\n    var field = this.query('#name');\n    this.model.name = field.value;\n  },\n  setDescription: function setDescription() {\n    var field = this.query('#description');\n    this.model.description = field.value;\n  },\n  add: function add() {\n    this.collection.add({\n      name: 'New Facet'\n    });\n  },\n  rescan: function rescan() {\n    this.model.scan();\n  },\n  search: function search() {\n    this.showSearch = !this.showSearch;\n\n    if (this.showSearch) {\n      this.queryByHook('facet-selector').focus();\n    }\n  },\n  clear: function clear() {\n    this.needle = '';\n    this.update();\n  },\n  update: function update() {\n    // build regexp for searching\n    try {\n      var regexp = new RegExp(this.needle, 'i'); // case insensitive search\n      // search through collection, check both name and description\n\n      this.collection.forEach(function (e) {\n        var hay = e.name + e.description;\n        e.show = regexp.test(hay.toLowerCase());\n      });\n    } catch (error) {}\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNGIxZS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZGF0YXNldC5qcz9jMzdiIl0sInNvdXJjZXNDb250ZW50IjpbInZhciBQYWdlVmlldyA9IHJlcXVpcmUoJy4vYmFzZScpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uL3RlbXBsYXRlcycpO1xudmFyIEZhY2V0Q29sbGVjdGlvblZpZXcgPSByZXF1aXJlKCcuL2NvbmZpZ3VyZS1kYXRhc2V0L2ZhY2V0LWNvbGxlY3Rpb24nKTtcbnZhciBhcHAgPSByZXF1aXJlKCdhbXBlcnNhbmQtYXBwJyk7XG52YXIgJCA9IHJlcXVpcmUoJ2pxdWVyeScpO1xuXG4vLyBBc3N1bXB0aW9uOlxuLy8gdGhpcy5tb2RlbCBpbnN0YW5jZW9mIERhdGFzZXRcbi8vIHRoaXMuY29sbGVjdGlvbiBpbnN0YW5jZW9mIGZhY2V0LWNvbGxlY3Rpb25cblxubW9kdWxlLmV4cG9ydHMgPSBQYWdlVmlldy5leHRlbmQoe1xuICB0ZW1wbGF0ZTogdGVtcGxhdGVzLmNvbmZpZ3VyZURhdGFzZXQucGFnZSxcbiAgcmVuZGVyOiBmdW5jdGlvbiAoKSB7XG4gICAgdGhpcy5yZW5kZXJXaXRoVGVtcGxhdGUoKTtcblxuICAgIGlmICh0aGlzLmNvbGxlY3Rpb24pIHtcbiAgICAgIHRoaXMuY29sbGVjdGlvbi5zb3J0KCk7XG4gICAgICB0aGlzLnJlbmRlckNvbGxlY3Rpb24odGhpcy5jb2xsZWN0aW9uLCBGYWNldENvbGxlY3Rpb25WaWV3LCB0aGlzLnF1ZXJ5QnlIb29rKCdmYWNldC1saXN0JykpO1xuICAgIH1cbiAgICB0aGlzLnF1ZXJ5KCcjZGVzY3JpcHRpb24nKS52YWx1ZSA9IHRoaXMubW9kZWwuZGVzY3JpcHRpb247IC8vIG1hdGVyaWFsIGRlc2lnbiBsaXRlIGRvZXMgbm90IGxpa2UgdGhpcyB2aWEgYmluZGluZ3MuLi5cblxuICAgIC8vIEF1dG9tYXRpY2FsbHkgc2NhbiB0aGUgZGF0YXNldCBpZiBuZWNlc3NhcnlcbiAgICBpZiAodGhpcy5tb2RlbC5mYWNldHMubGVuZ3RoID09PSAwKSB7XG4gICAgICB0aGlzLm1vZGVsLnNjYW4oKTtcbiAgICB9XG4gIH0sXG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLmlzTG9ja2VkRG93biA9IGFwcC5tZS5pc0xvY2tlZERvd247XG4gICAgdGhpcy5uZWVkbGUgPSB0aGlzLmNvbGxlY3Rpb24ubmVlZGxlO1xuICAgIHRoaXMuc2hvd1NlYXJjaCA9IHRoaXMuY29sbGVjdGlvbi5zaG93U2VhcmNoO1xuXG4gICAgdGhpcy5vbigncmVtb3ZlJywgZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5jb2xsZWN0aW9uLm5lZWRsZSA9IHRoaXMubmVlZGxlO1xuICAgICAgdGhpcy5jb2xsZWN0aW9uLnNob3dTZWFyY2ggPSB0aGlzLnNob3dTZWFyY2g7XG4gICAgICB0aGlzLm1vZGVsLmZhY2V0cy5vZmYoJ2FkZCcpO1xuICAgIH0pO1xuXG4gICAgdGhpcy5tb2RlbC5mYWNldHMub24oJ2FkZCcsIGZ1bmN0aW9uICgpIHtcbiAgICAgIHNldFRpbWVvdXQoZnVuY3Rpb24gKCkge1xuICAgICAgICB3aW5kb3cuY29tcG9uZW50SGFuZGxlci51cGdyYWRlRG9tKCk7XG4gICAgICB9LCAyMCk7XG4gICAgfSk7XG5cbiAgICB0aGlzLnVwZGF0ZSgpO1xuICB9LFxuICBzZXNzaW9uOiB7XG4gICAgbmVlZGxlOiAnc3RyaW5nJyxcbiAgICBzaG93U2VhcmNoOiAnYm9vbGVhbicsXG4gICAgaXNMb2NrZWREb3duOiAnYm9vbGVhbidcbiAgfSxcbiAgYmluZGluZ3M6IHtcbiAgICAnaXNMb2NrZWREb3duJzogW1xuICAgICAgeyB0eXBlOiAndG9nZ2xlJywgaG9vazogJ2FkZC1idXR0b24nLCBpbnZlcnQ6ICd5ZXMnIH0sXG4gICAgICB7IHR5cGU6ICd0b2dnbGUnLCBob29rOiAncmVzY2FuLWJ1dHRvbicsIGludmVydDogJ3llcycgfVxuICAgIF0sXG4gICAgJ3Nob3dTZWFyY2gnOiB7XG4gICAgICB0eXBlOiAndG9nZ2xlJyxcbiAgICAgIGhvb2s6ICdzZWFyY2gtYmFyJ1xuICAgIH0sXG4gICAgJ25lZWRsZSc6IHtcbiAgICAgIHR5cGU6ICd2YWx1ZScsXG4gICAgICBob29rOiAnZmFjZXQtc2VsZWN0b3InXG4gICAgfSxcbiAgICAnbW9kZWwubmFtZSc6IHtcbiAgICAgIHR5cGU6ICdhdHRyaWJ1dGUnLFxuICAgICAgc2VsZWN0b3I6ICcjbmFtZScsXG4gICAgICBuYW1lOiAndmFsdWUnXG4gICAgfVxuICB9LFxuICBldmVudHM6IHtcbiAgICAnaW5wdXQgW2RhdGEtaG9va349ZmFjZXQtc2VsZWN0b3JdJzogJ2lucHV0JyxcbiAgICAnaW5wdXQgI25hbWUnOiAnc2V0TmFtZScsXG4gICAgJ2lucHV0ICNkZXNjcmlwdGlvbic6ICdzZXREZXNjcmlwdGlvbicsXG4gICAgJ2NsaWNrICNlYWInOiAnZW5hYmxlQWxsRmFjZXRzJyxcbiAgICAnY2xpY2sgI2RhYic6ICdkaXNhYmxlQWxsRmFjZXRzJyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349YWRkLWJ1dHRvbl0nOiAnYWRkJyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349cmVzY2FuLWJ1dHRvbl0nOiAncmVzY2FuJyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349c2VhcmNoLWJ1dHRvbl0nOiAnc2VhcmNoJyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349Y2xlYXItYnV0dG9uXSc6ICdjbGVhcidcbiAgfSxcbiAgZW5hYmxlQWxsRmFjZXRzOiBmdW5jdGlvbiAoKSB7XG4gICAgdmFyIGk7XG4gICAgdmFyIGYgPSAkKCdbZGF0YS1ob29rfj1jYmxhYmVsXScpO1xuICAgIGZvciAoaSA9IDA7IGkgPCBmLmxlbmd0aDsgaSsrKSB7XG4gICAgICB2YXIgYyA9IGZbaV0uY2xhc3NMaXN0O1xuICAgICAgaWYgKCFjLmNvbnRhaW5zKCdpcy1jaGVja2VkJykpIHtcbiAgICAgICAgZltpXS5jbGljaygpO1xuICAgICAgfVxuICAgIH1cbiAgfSxcbiAgZGlzYWJsZUFsbEZhY2V0czogZnVuY3Rpb24gKCkge1xuICAgIHZhciBpO1xuICAgIHZhciBmID0gJCgnW2RhdGEtaG9va349Y2JsYWJlbF0nKTtcbiAgICBmb3IgKGkgPSAwOyBpIDwgZi5sZW5ndGg7IGkrKykge1xuICAgICAgdmFyIGMgPSBmW2ldLmNsYXNzTGlzdDtcbiAgICAgIGlmIChjLmNvbnRhaW5zKCdpcy1jaGVja2VkJykpIHtcbiAgICAgICAgZltpXS5jbGljaygpO1xuICAgICAgfVxuICAgIH1cbiAgfSxcbiAgaW5wdXQ6IGZ1bmN0aW9uICgpIHtcbiAgICB2YXIgc2VsZWN0ID0gdGhpcy5lbC5xdWVyeVNlbGVjdG9yKCdbZGF0YS1ob29rfj1cImZhY2V0LXNlbGVjdG9yXCJdJyk7XG4gICAgdGhpcy5uZWVkbGUgPSBzZWxlY3QudmFsdWU7XG5cbiAgICB0aGlzLnVwZGF0ZSgpO1xuICB9LFxuICBzZXROYW1lOiBmdW5jdGlvbiAoKSB7XG4gICAgdmFyIGZpZWxkID0gdGhpcy5xdWVyeSgnI25hbWUnKTtcbiAgICB0aGlzLm1vZGVsLm5hbWUgPSBmaWVsZC52YWx1ZTtcbiAgfSxcbiAgc2V0RGVzY3JpcHRpb246IGZ1bmN0aW9uICgpIHtcbiAgICB2YXIgZmllbGQgPSB0aGlzLnF1ZXJ5KCcjZGVzY3JpcHRpb24nKTtcbiAgICB0aGlzLm1vZGVsLmRlc2NyaXB0aW9uID0gZmllbGQudmFsdWU7XG4gIH0sXG4gIGFkZDogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMuY29sbGVjdGlvbi5hZGQoe25hbWU6ICdOZXcgRmFjZXQnfSk7XG4gIH0sXG4gIHJlc2NhbjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMubW9kZWwuc2NhbigpO1xuICB9LFxuICBzZWFyY2g6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnNob3dTZWFyY2ggPSAhdGhpcy5zaG93U2VhcmNoO1xuICAgIGlmICh0aGlzLnNob3dTZWFyY2gpIHtcbiAgICAgIHRoaXMucXVlcnlCeUhvb2soJ2ZhY2V0LXNlbGVjdG9yJykuZm9jdXMoKTtcbiAgICB9XG4gIH0sXG4gIGNsZWFyOiBmdW5jdGlvbiAoKSB7XG4gICAgdGhpcy5uZWVkbGUgPSAnJztcbiAgICB0aGlzLnVwZGF0ZSgpO1xuICB9LFxuICB1cGRhdGU6IGZ1bmN0aW9uICgpIHtcbiAgICAvLyBidWlsZCByZWdleHAgZm9yIHNlYXJjaGluZ1xuICAgIHRyeSB7XG4gICAgICB2YXIgcmVnZXhwID0gbmV3IFJlZ0V4cCh0aGlzLm5lZWRsZSwgJ2knKTsgLy8gY2FzZSBpbnNlbnNpdGl2ZSBzZWFyY2hcblxuICAgICAgLy8gc2VhcmNoIHRocm91Z2ggY29sbGVjdGlvbiwgY2hlY2sgYm90aCBuYW1lIGFuZCBkZXNjcmlwdGlvblxuICAgICAgdGhpcy5jb2xsZWN0aW9uLmZvckVhY2goZnVuY3Rpb24gKGUpIHtcbiAgICAgICAgdmFyIGhheSA9IGUubmFtZSArIGUuZGVzY3JpcHRpb247XG4gICAgICAgIGUuc2hvdyA9IHJlZ2V4cC50ZXN0KGhheS50b0xvd2VyQ2FzZSgpKTtcbiAgICAgIH0pO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgfVxuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBRUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBS0E7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFFQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQWJBO0FBbUJBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBVEE7QUFXQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBcElBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///4b1e\n")},5122:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar SlotView = __webpack_require__(/*! ./slot */ \"de8e\");\n\nvar $ = __webpack_require__(/*! jquery */ \"802c\");\n\nvar FileSaver = __webpack_require__(/*! file-saver */ \"23bf\"); // NOTE: gridster does not work properly with require()\n// workaround via browserify-shim (configured in package.json)\n\n\n__webpack_require__(/*! gridster */ \"cc37\");\n\nfunction removeWidget(view, filter) {\n  // Remove the filter from the dataset\n  var filters = filter.collection;\n  filters.remove(filter);\n  filter.off('newData'); // Remove gridster stuff\n\n  var gridster = $('[id~=widgets]').gridster().data('gridster');\n  gridster.remove_widget(view.gridsterHook); // Remove ampersand stuff\n\n  var p = view.parent._subviews;\n  p.splice(p.indexOf(view), 1);\n  view.remove();\n}\n\nmodule.exports = View.extend({\n  template: templates.analyze.widgetFrame,\n  initialize: function initialize(opts) {\n    this.editMode = false; // on initialization we have a Filter as model,\n    // but we need to have a (chart specific) model instead\n    // So, create the proper model and swap it for the filter.\n\n    var filter = this.model;\n    this.model = app.widgetFactory.newModel({\n      modelType: filter.chartType,\n      filter: filter\n    });\n    this.widgetHeader = filter.chartType;\n  },\n  props: {\n    editMode: 'boolean',\n    chartType: 'string'\n  },\n  derived: {\n    'showMenu': {\n      deps: ['editMode', 'mouseOver'],\n      fn: function fn() {\n        // never show in edit mode\n        if (this.editMode) return false; // http://stackoverflow.com/questions/4817029/whats-the-best-way-to-detect-a-touch-screen-device-using-javascript/4819886#4819886\n\n        var touch = 'ontouchstart' in window || navigator.maxTouchPoints;\n        return touch || this.mouseOver;\n      }\n    }\n  },\n  session: {\n    mouseOver: ['boolean', true, false]\n  },\n  bindings: {\n    'editMode': {\n      hook: 'config-view',\n      type: 'toggle',\n      invert: false\n    },\n    'showMenu': {\n      type: 'toggle',\n      hook: 'plot-menu'\n    },\n    'widgetHeader': {\n      hook: 'widgetHeader',\n      type: 'text'\n    }\n  },\n  events: {\n    'click [data-hook~=\"close\"]': 'closeWidget',\n    'click [data-hook~=\"zoom-in\"]': 'zoomIn',\n    'click [data-hook~=\"zoom-out\"]': 'zoomOut',\n    'click [data-hook~=\"save\"]': 'savePlot',\n    'click [data-hook~=\"edit\"]': function clickDataHookEdit() {\n      this.editMode = !this.editMode;\n    },\n    'mouseenter .widgetFrame': 'mouseEnter',\n    'mouseleave .widgetFrame': 'mouseLeave'\n  },\n  zoomIn: function zoomIn(ev) {\n    this.model.filter.zoomIn();\n    app.me.dataview.getData();\n  },\n  zoomOut: function zoomOut() {\n    this.model.filter.zoomOut();\n    app.me.dataview.getData();\n  },\n  savePlot: function savePlot() {\n    // Save the image to disk, but add a white background;\n    // for this we need to make temporary copy\n    // actual onscreen canvas\n    var canvas = this.el.getElementsByTagName('canvas')[0];\n    var ctx = canvas.getContext('2d'); // temporary canvas\n\n    var tempCanvas = document.createElement('canvas');\n    var tempCtx = tempCanvas.getContext('2d');\n    tempCanvas.width = ctx.canvas.width;\n    tempCanvas.height = ctx.canvas.height;\n    tempCtx.fillStyle = 'white';\n    tempCtx.fillRect(0, 0, tempCanvas.width, tempCanvas.height);\n    tempCtx.drawImage(canvas, 0, 0); // use plot type as filename\n\n    var imageName = this.model.modelType;\n    tempCtx.canvas.toBlob(function (blob) {\n      FileSaver.saveAs(blob, imageName);\n    }, 'image/png');\n  },\n  mouseEnter: function mouseEnter() {\n    this.mouseOver = true;\n  },\n  mouseLeave: function mouseLeave() {\n    this.mouseOver = false;\n  },\n  closeWidget: function closeWidget() {\n    removeWidget(this, this.model.filter);\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.renderCollection(this.model.slots, SlotView, this.queryByHook('slots'));\n    return this;\n  },\n  renderContent: function renderContent() {\n    // Propagate to subview\n    this.widget.renderContent();\n  },\n  subviews: {\n    widget: {\n      hook: 'widget',\n      constructor: function constructor(options) {\n        // NOTE: view type (barchart, bubblechart, ...) is determined from options.model.modelType\n        options.model = options.parent.model;\n        return app.viewFactory.newView(options);\n      }\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTEyMi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9hbmFseXplL3dpZGdldC1mcmFtZS5qcz83N2Q5Il0sInNvdXJjZXNDb250ZW50IjpbInZhciBWaWV3ID0gcmVxdWlyZSgnYW1wZXJzYW5kLXZpZXcnKTtcbnZhciB0ZW1wbGF0ZXMgPSByZXF1aXJlKCcuLi8uLi90ZW1wbGF0ZXMnKTtcbnZhciBhcHAgPSByZXF1aXJlKCdhbXBlcnNhbmQtYXBwJyk7XG52YXIgU2xvdFZpZXcgPSByZXF1aXJlKCcuL3Nsb3QnKTtcbnZhciAkID0gcmVxdWlyZSgnanF1ZXJ5Jyk7XG52YXIgRmlsZVNhdmVyID0gcmVxdWlyZSgnZmlsZS1zYXZlcicpO1xuXG4vLyBOT1RFOiBncmlkc3RlciBkb2VzIG5vdCB3b3JrIHByb3Blcmx5IHdpdGggcmVxdWlyZSgpXG4vLyB3b3JrYXJvdW5kIHZpYSBicm93c2VyaWZ5LXNoaW0gKGNvbmZpZ3VyZWQgaW4gcGFja2FnZS5qc29uKVxucmVxdWlyZSgnZ3JpZHN0ZXInKTtcblxuZnVuY3Rpb24gcmVtb3ZlV2lkZ2V0ICh2aWV3LCBmaWx0ZXIpIHtcbiAgLy8gUmVtb3ZlIHRoZSBmaWx0ZXIgZnJvbSB0aGUgZGF0YXNldFxuICB2YXIgZmlsdGVycyA9IGZpbHRlci5jb2xsZWN0aW9uO1xuICBmaWx0ZXJzLnJlbW92ZShmaWx0ZXIpO1xuICBmaWx0ZXIub2ZmKCduZXdEYXRhJyk7XG5cbiAgLy8gUmVtb3ZlIGdyaWRzdGVyIHN0dWZmXG4gIHZhciBncmlkc3RlciA9ICQoJ1tpZH49d2lkZ2V0c10nKS5ncmlkc3RlcigpLmRhdGEoJ2dyaWRzdGVyJyk7XG4gIGdyaWRzdGVyLnJlbW92ZV93aWRnZXQodmlldy5ncmlkc3Rlckhvb2spO1xuXG4gIC8vIFJlbW92ZSBhbXBlcnNhbmQgc3R1ZmZcbiAgdmFyIHAgPSB2aWV3LnBhcmVudC5fc3Vidmlld3M7XG4gIHAuc3BsaWNlKHAuaW5kZXhPZih2aWV3KSwgMSk7XG4gIHZpZXcucmVtb3ZlKCk7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gVmlldy5leHRlbmQoe1xuICB0ZW1wbGF0ZTogdGVtcGxhdGVzLmFuYWx5emUud2lkZ2V0RnJhbWUsXG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uIChvcHRzKSB7XG4gICAgdGhpcy5lZGl0TW9kZSA9IGZhbHNlO1xuXG4gICAgLy8gb24gaW5pdGlhbGl6YXRpb24gd2UgaGF2ZSBhIEZpbHRlciBhcyBtb2RlbCxcbiAgICAvLyBidXQgd2UgbmVlZCB0byBoYXZlIGEgKGNoYXJ0IHNwZWNpZmljKSBtb2RlbCBpbnN0ZWFkXG4gICAgLy8gU28sIGNyZWF0ZSB0aGUgcHJvcGVyIG1vZGVsIGFuZCBzd2FwIGl0IGZvciB0aGUgZmlsdGVyLlxuICAgIHZhciBmaWx0ZXIgPSB0aGlzLm1vZGVsO1xuXG4gICAgdGhpcy5tb2RlbCA9IGFwcC53aWRnZXRGYWN0b3J5Lm5ld01vZGVsKHtcbiAgICAgIG1vZGVsVHlwZTogZmlsdGVyLmNoYXJ0VHlwZSxcbiAgICAgIGZpbHRlcjogZmlsdGVyXG4gICAgfSk7XG4gICAgdGhpcy53aWRnZXRIZWFkZXIgPSBmaWx0ZXIuY2hhcnRUeXBlO1xuICB9LFxuICBwcm9wczoge1xuICAgIGVkaXRNb2RlOiAnYm9vbGVhbicsXG4gICAgY2hhcnRUeXBlOiAnc3RyaW5nJ1xuICB9LFxuICBkZXJpdmVkOiB7XG4gICAgJ3Nob3dNZW51Jzoge1xuICAgICAgZGVwczogWydlZGl0TW9kZScsICdtb3VzZU92ZXInXSxcbiAgICAgIGZuOiBmdW5jdGlvbiAoKSB7XG4gICAgICAgIC8vIG5ldmVyIHNob3cgaW4gZWRpdCBtb2RlXG4gICAgICAgIGlmICh0aGlzLmVkaXRNb2RlKSByZXR1cm4gZmFsc2U7XG5cbiAgICAgICAgLy8gaHR0cDovL3N0YWNrb3ZlcmZsb3cuY29tL3F1ZXN0aW9ucy80ODE3MDI5L3doYXRzLXRoZS1iZXN0LXdheS10by1kZXRlY3QtYS10b3VjaC1zY3JlZW4tZGV2aWNlLXVzaW5nLWphdmFzY3JpcHQvNDgxOTg4NiM0ODE5ODg2XG4gICAgICAgIHZhciB0b3VjaCA9ICdvbnRvdWNoc3RhcnQnIGluIHdpbmRvdyB8fCBuYXZpZ2F0b3IubWF4VG91Y2hQb2ludHM7XG4gICAgICAgIHJldHVybiB0b3VjaCB8fCB0aGlzLm1vdXNlT3ZlcjtcbiAgICAgIH1cbiAgICB9XG4gIH0sXG4gIHNlc3Npb246IHtcbiAgICBtb3VzZU92ZXI6IFsnYm9vbGVhbicsIHRydWUsIGZhbHNlXVxuICB9LFxuICBiaW5kaW5nczoge1xuICAgICdlZGl0TW9kZSc6IHtcbiAgICAgIGhvb2s6ICdjb25maWctdmlldycsXG4gICAgICB0eXBlOiAndG9nZ2xlJyxcbiAgICAgIGludmVydDogZmFsc2VcbiAgICB9LFxuICAgICdzaG93TWVudSc6IHtcbiAgICAgIHR5cGU6ICd0b2dnbGUnLFxuICAgICAgaG9vazogJ3Bsb3QtbWVudSdcbiAgICB9LFxuICAgICd3aWRnZXRIZWFkZXInOiB7XG4gICAgICBob29rOiAnd2lkZ2V0SGVhZGVyJyxcbiAgICAgIHR5cGU6ICd0ZXh0J1xuICAgIH1cbiAgfSxcbiAgZXZlbnRzOiB7XG4gICAgJ2NsaWNrIFtkYXRhLWhvb2t+PVwiY2xvc2VcIl0nOiAnY2xvc2VXaWRnZXQnLFxuICAgICdjbGljayBbZGF0YS1ob29rfj1cInpvb20taW5cIl0nOiAnem9vbUluJyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349XCJ6b29tLW91dFwiXSc6ICd6b29tT3V0JyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349XCJzYXZlXCJdJzogJ3NhdmVQbG90JyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349XCJlZGl0XCJdJzogZnVuY3Rpb24gKCkgeyB0aGlzLmVkaXRNb2RlID0gIXRoaXMuZWRpdE1vZGU7IH0sXG5cbiAgICAnbW91c2VlbnRlciAud2lkZ2V0RnJhbWUnOiAnbW91c2VFbnRlcicsXG4gICAgJ21vdXNlbGVhdmUgLndpZGdldEZyYW1lJzogJ21vdXNlTGVhdmUnXG4gIH0sXG4gIHpvb21JbjogZnVuY3Rpb24gKGV2KSB7XG4gICAgdGhpcy5tb2RlbC5maWx0ZXIuem9vbUluKCk7XG4gICAgYXBwLm1lLmRhdGF2aWV3LmdldERhdGEoKTtcbiAgfSxcbiAgem9vbU91dDogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMubW9kZWwuZmlsdGVyLnpvb21PdXQoKTtcbiAgICBhcHAubWUuZGF0YXZpZXcuZ2V0RGF0YSgpO1xuICB9LFxuICBzYXZlUGxvdDogZnVuY3Rpb24gKCkge1xuICAgIC8vIFNhdmUgdGhlIGltYWdlIHRvIGRpc2ssIGJ1dCBhZGQgYSB3aGl0ZSBiYWNrZ3JvdW5kO1xuICAgIC8vIGZvciB0aGlzIHdlIG5lZWQgdG8gbWFrZSB0ZW1wb3JhcnkgY29weVxuXG4gICAgLy8gYWN0dWFsIG9uc2NyZWVuIGNhbnZhc1xuICAgIHZhciBjYW52YXMgPSB0aGlzLmVsLmdldEVsZW1lbnRzQnlUYWdOYW1lKCdjYW52YXMnKVswXTtcbiAgICB2YXIgY3R4ID0gY2FudmFzLmdldENvbnRleHQoJzJkJyk7XG5cbiAgICAvLyB0ZW1wb3JhcnkgY2FudmFzXG4gICAgdmFyIHRlbXBDYW52YXMgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdjYW52YXMnKTtcbiAgICB2YXIgdGVtcEN0eCA9IHRlbXBDYW52YXMuZ2V0Q29udGV4dCgnMmQnKTtcblxuICAgIHRlbXBDYW52YXMud2lkdGggPSBjdHguY2FudmFzLndpZHRoO1xuICAgIHRlbXBDYW52YXMuaGVpZ2h0ID0gY3R4LmNhbnZhcy5oZWlnaHQ7XG4gICAgdGVtcEN0eC5maWxsU3R5bGUgPSAnd2hpdGUnO1xuICAgIHRlbXBDdHguZmlsbFJlY3QoMCwgMCwgdGVtcENhbnZhcy53aWR0aCwgdGVtcENhbnZhcy5oZWlnaHQpO1xuICAgIHRlbXBDdHguZHJhd0ltYWdlKGNhbnZhcywgMCwgMCk7XG5cbiAgICAvLyB1c2UgcGxvdCB0eXBlIGFzIGZpbGVuYW1lXG4gICAgdmFyIGltYWdlTmFtZSA9IHRoaXMubW9kZWwubW9kZWxUeXBlO1xuXG4gICAgdGVtcEN0eC5jYW52YXMudG9CbG9iKGZ1bmN0aW9uIChibG9iKSB7XG4gICAgICBGaWxlU2F2ZXIuc2F2ZUFzKGJsb2IsIGltYWdlTmFtZSk7XG4gICAgfSwgJ2ltYWdlL3BuZycpO1xuICB9LFxuICBtb3VzZUVudGVyOiBmdW5jdGlvbiAoKSB7XG4gICAgdGhpcy5tb3VzZU92ZXIgPSB0cnVlO1xuICB9LFxuICBtb3VzZUxlYXZlOiBmdW5jdGlvbiAoKSB7XG4gICAgdGhpcy5tb3VzZU92ZXIgPSBmYWxzZTtcbiAgfSxcbiAgY2xvc2VXaWRnZXQ6IGZ1bmN0aW9uICgpIHtcbiAgICByZW1vdmVXaWRnZXQodGhpcywgdGhpcy5tb2RlbC5maWx0ZXIpO1xuICB9LFxuICByZW5kZXI6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnJlbmRlcldpdGhUZW1wbGF0ZSh0aGlzKTtcbiAgICB0aGlzLnJlbmRlckNvbGxlY3Rpb24odGhpcy5tb2RlbC5zbG90cywgU2xvdFZpZXcsIHRoaXMucXVlcnlCeUhvb2soJ3Nsb3RzJykpO1xuICAgIHJldHVybiB0aGlzO1xuICB9LFxuICByZW5kZXJDb250ZW50OiBmdW5jdGlvbiAoKSB7XG4gICAgLy8gUHJvcGFnYXRlIHRvIHN1YnZpZXdcbiAgICB0aGlzLndpZGdldC5yZW5kZXJDb250ZW50KCk7XG4gIH0sXG4gIHN1YnZpZXdzOiB7XG4gICAgd2lkZ2V0OiB7XG4gICAgICBob29rOiAnd2lkZ2V0JyxcbiAgICAgIGNvbnN0cnVjdG9yOiBmdW5jdGlvbiAob3B0aW9ucykge1xuICAgICAgICAvLyBOT1RFOiB2aWV3IHR5cGUgKGJhcmNoYXJ0LCBidWJibGVjaGFydCwgLi4uKSBpcyBkZXRlcm1pbmVkIGZyb20gb3B0aW9ucy5tb2RlbC5tb2RlbFR5cGVcbiAgICAgICAgb3B0aW9ucy5tb2RlbCA9IG9wdGlvbnMucGFyZW50Lm1vZGVsO1xuICAgICAgICByZXR1cm4gYXBwLnZpZXdGYWN0b3J5Lm5ld1ZpZXcob3B0aW9ucyk7XG4gICAgICB9XG4gICAgfVxuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUdBO0FBQ0E7QUFDQTtBQURBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFBQTtBQUVBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFUQTtBQURBO0FBYUE7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBS0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFGQTtBQVZBO0FBZUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUVBO0FBQ0E7QUFSQTtBQVVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQU5BO0FBREE7QUFoSEEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///5122\n")},"56f6":function(module,exports,__webpack_require__){eval('var View = __webpack_require__(/*! ampersand-view */ "2883");\n\nvar templates = __webpack_require__(/*! ../../templates */ "4324");\n\nvar app = __webpack_require__(/*! ampersand-app */ "fcbc");\n\nvar SessionView = __webpack_require__(/*! ./session-view */ "48248");\n\nmodule.exports = View.extend({\n  template: templates.datasets.sessionCollection,\n  initialize: function initialize() {},\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.renderCollection(app.sessions, SessionView, this.queryByHook(\'session-collection-items\'));\n    return this;\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNTZmNi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9kYXRhc2V0cy9zZXNzaW9uLWNvbGxlY3Rpb24uanM/N2UyZiJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgVmlldyA9IHJlcXVpcmUoJ2FtcGVyc2FuZC12aWV3Jyk7XG52YXIgdGVtcGxhdGVzID0gcmVxdWlyZSgnLi4vLi4vdGVtcGxhdGVzJyk7XG52YXIgYXBwID0gcmVxdWlyZSgnYW1wZXJzYW5kLWFwcCcpO1xuXG52YXIgU2Vzc2lvblZpZXcgPSByZXF1aXJlKCcuL3Nlc3Npb24tdmlldycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFZpZXcuZXh0ZW5kKHtcbiAgdGVtcGxhdGU6IHRlbXBsYXRlcy5kYXRhc2V0cy5zZXNzaW9uQ29sbGVjdGlvbixcbiAgaW5pdGlhbGl6ZTogZnVuY3Rpb24gKCkge1xuICB9LFxuICByZW5kZXI6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnJlbmRlcldpdGhUZW1wbGF0ZSh0aGlzKTtcbiAgICB0aGlzLnJlbmRlckNvbGxlY3Rpb24oYXBwLnNlc3Npb25zLCBTZXNzaW9uVmlldywgdGhpcy5xdWVyeUJ5SG9vaygnc2Vzc2lvbi1jb2xsZWN0aW9uLWl0ZW1zJykpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFSQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///56f6\n')},"5eb6":function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nmodule.exports = View.extend({\n  template: templates.datasets.dataset,\n  derived: {\n    facetsURL: {\n      deps: ['model.id'],\n      fn: function fn() {\n        return '/dataset/' + this.model.id;\n      }\n    }\n  },\n  props: {\n    bussy: ['boolean', true, false]\n  },\n  bindings: {\n    'bussy': [{\n      hook: 'cbtoggle',\n      type: 'toggle',\n      invert: true\n    }, {\n      hook: 'cbspinner',\n      type: 'toggle',\n      invert: false\n    }],\n    'model.show': {\n      hook: 'dataset',\n      type: 'toggle'\n    },\n    'model.name': {\n      hook: 'name',\n      type: 'text'\n    },\n    'model.description': {\n      hook: 'description',\n      type: 'text'\n    },\n    // material design hooks\n    'model.isActive': [{\n      hook: 'cb',\n      type: 'booleanAttribute',\n      name: 'checked'\n    }, {\n      type: 'toggle',\n      hook: 'settings',\n      invert: true\n    }],\n    'model.id': [{\n      hook: 'cb',\n      type: 'attribute',\n      name: 'id'\n    }, {\n      hook: 'cblabel',\n      type: 'attribute',\n      name: 'for'\n    }]\n  },\n  events: {\n    'change': 'toggleActive',\n    'click [data-hook~=settings]': function clickDataHookSettings() {\n      app.navigate('/dataset/' + this.model.id);\n    },\n    'click [data-hook~=delete]': 'deleteDataset'\n  },\n  toggleActive: function toggleActive() {\n    var that = this;\n    that.bussy = !that.busy;\n\n    if (that.model.facets.length === 0) {\n      // Automatically scan the dataset if there are no facets\n      that.model.scan();\n      that.model.once('syncFacets', function () {\n        app.me.toggleDataset(that.model);\n        that.bussy = !that.bussy;\n      });\n    } else {\n      // BUGFIX: we cant show/hide the spinner from within the event loop; so\n      //  * activate the spinner,\n      //  * exit the event loop (ie. redraw the page),\n      //  * and toggle the dataset via the timeout\n      window.setTimeout(function () {\n        app.me.toggleDataset(that.model);\n        that.bussy = !that.bussy;\n      }, 500);\n    }\n  },\n  deleteDataset: function deleteDataset() {\n    if (this.model.isActive) {\n      this.bussy = true;\n      app.me.toggleDataset(this.model);\n      this.bussy = false;\n    }\n\n    console.log(this.model);\n    app.removeDatasetFromLocalStorage(this.model);\n    app.me.datasets.remove(this.model);\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNWViNi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9kYXRhc2V0cy9kYXRhc2V0LmpzP2U1M2MiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xudmFyIGFwcCA9IHJlcXVpcmUoJ2FtcGVyc2FuZC1hcHAnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuZGF0YXNldHMuZGF0YXNldCxcbiAgZGVyaXZlZDoge1xuICAgIGZhY2V0c1VSTDoge1xuICAgICAgZGVwczogWydtb2RlbC5pZCddLFxuICAgICAgZm46IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgcmV0dXJuICcvZGF0YXNldC8nICsgdGhpcy5tb2RlbC5pZDtcbiAgICAgIH1cbiAgICB9XG4gIH0sXG4gIHByb3BzOiB7XG4gICAgYnVzc3k6IFsnYm9vbGVhbicsIHRydWUsIGZhbHNlXVxuICB9LFxuICBiaW5kaW5nczoge1xuICAgICdidXNzeSc6IFtcbiAgICAgIHtcbiAgICAgICAgaG9vazogJ2NidG9nZ2xlJyxcbiAgICAgICAgdHlwZTogJ3RvZ2dsZScsXG4gICAgICAgIGludmVydDogdHJ1ZVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgaG9vazogJ2Nic3Bpbm5lcicsXG4gICAgICAgIHR5cGU6ICd0b2dnbGUnLFxuICAgICAgICBpbnZlcnQ6IGZhbHNlXG4gICAgICB9XG4gICAgXSxcbiAgICAnbW9kZWwuc2hvdyc6IHtcbiAgICAgIGhvb2s6ICdkYXRhc2V0JyxcbiAgICAgIHR5cGU6ICd0b2dnbGUnXG4gICAgfSxcbiAgICAnbW9kZWwubmFtZSc6IHtcbiAgICAgIGhvb2s6ICduYW1lJyxcbiAgICAgIHR5cGU6ICd0ZXh0J1xuICAgIH0sXG4gICAgJ21vZGVsLmRlc2NyaXB0aW9uJzoge1xuICAgICAgaG9vazogJ2Rlc2NyaXB0aW9uJyxcbiAgICAgIHR5cGU6ICd0ZXh0J1xuICAgIH0sXG5cbiAgICAvLyBtYXRlcmlhbCBkZXNpZ24gaG9va3NcbiAgICAnbW9kZWwuaXNBY3RpdmUnOiBbXG4gICAgICB7XG4gICAgICAgIGhvb2s6ICdjYicsXG4gICAgICAgIHR5cGU6ICdib29sZWFuQXR0cmlidXRlJyxcbiAgICAgICAgbmFtZTogJ2NoZWNrZWQnXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICB0eXBlOiAndG9nZ2xlJyxcbiAgICAgICAgaG9vazogJ3NldHRpbmdzJyxcbiAgICAgICAgaW52ZXJ0OiB0cnVlXG4gICAgICB9XG4gICAgXSxcbiAgICAnbW9kZWwuaWQnOiBbXG4gICAgICB7IGhvb2s6ICdjYicsIHR5cGU6ICdhdHRyaWJ1dGUnLCBuYW1lOiAnaWQnIH0sXG4gICAgICB7IGhvb2s6ICdjYmxhYmVsJywgdHlwZTogJ2F0dHJpYnV0ZScsIG5hbWU6ICdmb3InIH1cbiAgICBdXG4gIH0sXG4gIGV2ZW50czoge1xuICAgICdjaGFuZ2UnOiAndG9nZ2xlQWN0aXZlJyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349c2V0dGluZ3NdJzogZnVuY3Rpb24gKCkgeyBhcHAubmF2aWdhdGUoJy9kYXRhc2V0LycgKyB0aGlzLm1vZGVsLmlkKTsgfSxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349ZGVsZXRlXSc6ICdkZWxldGVEYXRhc2V0J1xuICB9LFxuICB0b2dnbGVBY3RpdmU6IGZ1bmN0aW9uICgpIHtcbiAgICB2YXIgdGhhdCA9IHRoaXM7XG5cbiAgICB0aGF0LmJ1c3N5ID0gIXRoYXQuYnVzeTtcbiAgICBpZiAodGhhdC5tb2RlbC5mYWNldHMubGVuZ3RoID09PSAwKSB7XG4gICAgICAvLyBBdXRvbWF0aWNhbGx5IHNjYW4gdGhlIGRhdGFzZXQgaWYgdGhlcmUgYXJlIG5vIGZhY2V0c1xuICAgICAgdGhhdC5tb2RlbC5zY2FuKCk7XG4gICAgICB0aGF0Lm1vZGVsLm9uY2UoJ3N5bmNGYWNldHMnLCBmdW5jdGlvbiAoKSB7XG4gICAgICAgIGFwcC5tZS50b2dnbGVEYXRhc2V0KHRoYXQubW9kZWwpO1xuICAgICAgICB0aGF0LmJ1c3N5ID0gIXRoYXQuYnVzc3k7XG4gICAgICB9KTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gQlVHRklYOiB3ZSBjYW50IHNob3cvaGlkZSB0aGUgc3Bpbm5lciBmcm9tIHdpdGhpbiB0aGUgZXZlbnQgbG9vcDsgc29cbiAgICAgIC8vICAqIGFjdGl2YXRlIHRoZSBzcGlubmVyLFxuICAgICAgLy8gICogZXhpdCB0aGUgZXZlbnQgbG9vcCAoaWUuIHJlZHJhdyB0aGUgcGFnZSksXG4gICAgICAvLyAgKiBhbmQgdG9nZ2xlIHRoZSBkYXRhc2V0IHZpYSB0aGUgdGltZW91dFxuICAgICAgd2luZG93LnNldFRpbWVvdXQoZnVuY3Rpb24gKCkge1xuICAgICAgICBhcHAubWUudG9nZ2xlRGF0YXNldCh0aGF0Lm1vZGVsKTtcbiAgICAgICAgdGhhdC5idXNzeSA9ICF0aGF0LmJ1c3N5O1xuICAgICAgfSwgNTAwKTtcbiAgICB9XG4gIH0sXG4gIGRlbGV0ZURhdGFzZXQ6IGZ1bmN0aW9uICgpIHtcbiAgICBpZiAodGhpcy5tb2RlbC5pc0FjdGl2ZSkge1xuICAgICAgdGhpcy5idXNzeSA9IHRydWU7XG4gICAgICBhcHAubWUudG9nZ2xlRGF0YXNldCh0aGlzLm1vZGVsKTtcbiAgICAgIHRoaXMuYnVzc3kgPSBmYWxzZTtcbiAgICB9XG4gICAgY29uc29sZS5sb2codGhpcy5tb2RlbCk7XG4gICAgYXBwLnJlbW92ZURhdGFzZXRGcm9tTG9jYWxTdG9yYWdlKHRoaXMubW9kZWwpO1xuICAgIGFwcC5tZS5kYXRhc2V0cy5yZW1vdmUodGhpcy5tb2RlbCk7XG4gIH0sXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVuZGVyV2l0aFRlbXBsYXRlKHRoaXMpO1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUpBO0FBREE7QUFRQTtBQUNBO0FBREE7QUFHQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBSEE7QUFNQTtBQUNBO0FBQ0E7QUFIQTtBQU1BO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFIQTtBQU1BO0FBQ0E7QUFDQTtBQUhBO0FBTUE7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBekNBO0FBNENBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFDQTtBQUhBO0FBS0E7QUFDQTtBQUVBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBaEdBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///5eb6\n")},6339:function(module,exports,__webpack_require__){eval("/**\n * @classdesc Base class to hold configuration for charts. Extend and override properties for each chart.\n * @class BaseChart\n */\nvar AmpersandModel = __webpack_require__(/*! ampersand-model */ \"3bfc\");\n\nvar Slots = __webpack_require__(/*! ./slots */ \"e96a\");\n\nfunction titleForChart(chart) {\n  var title = '';\n  var aggregates = chart.filter.aggregates;\n\n  if (aggregates.length === 0) {\n    title = 'count';\n  } else {\n    aggregates.forEach(function (aggregate) {\n      title += aggregate.operation + ' of ' + aggregate.label;\n    });\n  }\n\n  title += ' by';\n  var partitions = chart.filter.partitions;\n  partitions.forEach(function (partition) {\n    title += ' ' + partition.facetName;\n  });\n  return title;\n}\n\nmodule.exports = AmpersandModel.extend({\n  collections: {\n    slots: Slots\n  },\n  session: {\n    /**\n     * Filter instance\n     * @memberof! Chart\n     * @type {Filter}\n     */\n    filter: ['any', true, false],\n\n    /**\n     * True if the charts is properly configured; ie. all required slots are filled.\n     */\n    isConfigured: ['boolean', true, false]\n  },\n  getTitle: function getTitle() {\n    return titleForChart(this);\n  },\n  updateConfiguration: function updateConfiguration() {\n    // without filter instance it cannot be configured\n    if (!this.filter) {\n      this.isConfigured = false;\n    }\n\n    var configured = true; // check if all required slots are filled\n\n    this.slots.forEach(function (slot) {\n      if (slot.required) {\n        if (slot.type === 'partition') {\n          if (!this.filter.partitions.get(slot.rank, 'rank')) {\n            configured = false;\n          }\n        } else if (slot.type === 'aggregate') {\n          if (!this.filter.aggregates.get(slot.rank, 'rank')) {\n            configured = false;\n          }\n        } else {\n          console.error('Illegal slot');\n          configured = false;\n        }\n      }\n    }, this);\n    this.isConfigured = configured;\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjMzOS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9iYXNlLWNoYXJ0LmpzPzM5MzIiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAY2xhc3NkZXNjIEJhc2UgY2xhc3MgdG8gaG9sZCBjb25maWd1cmF0aW9uIGZvciBjaGFydHMuIEV4dGVuZCBhbmQgb3ZlcnJpZGUgcHJvcGVydGllcyBmb3IgZWFjaCBjaGFydC5cbiAqIEBjbGFzcyBCYXNlQ2hhcnRcbiAqL1xudmFyIEFtcGVyc2FuZE1vZGVsID0gcmVxdWlyZSgnYW1wZXJzYW5kLW1vZGVsJyk7XG52YXIgU2xvdHMgPSByZXF1aXJlKCcuL3Nsb3RzJyk7XG5cbmZ1bmN0aW9uIHRpdGxlRm9yQ2hhcnQgKGNoYXJ0KSB7XG4gIHZhciB0aXRsZSA9ICcnO1xuXG4gIHZhciBhZ2dyZWdhdGVzID0gY2hhcnQuZmlsdGVyLmFnZ3JlZ2F0ZXM7XG4gIGlmIChhZ2dyZWdhdGVzLmxlbmd0aCA9PT0gMCkge1xuICAgIHRpdGxlID0gJ2NvdW50JztcbiAgfSBlbHNlIHtcbiAgICBhZ2dyZWdhdGVzLmZvckVhY2goZnVuY3Rpb24gKGFnZ3JlZ2F0ZSkge1xuICAgICAgdGl0bGUgKz0gYWdncmVnYXRlLm9wZXJhdGlvbiArICcgb2YgJyArIGFnZ3JlZ2F0ZS5sYWJlbDtcbiAgICB9KTtcbiAgfVxuXG4gIHRpdGxlICs9ICcgYnknO1xuXG4gIHZhciBwYXJ0aXRpb25zID0gY2hhcnQuZmlsdGVyLnBhcnRpdGlvbnM7XG4gIHBhcnRpdGlvbnMuZm9yRWFjaChmdW5jdGlvbiAocGFydGl0aW9uKSB7XG4gICAgdGl0bGUgKz0gJyAnICsgcGFydGl0aW9uLmZhY2V0TmFtZTtcbiAgfSk7XG4gIHJldHVybiB0aXRsZTtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBBbXBlcnNhbmRNb2RlbC5leHRlbmQoe1xuICBjb2xsZWN0aW9uczoge1xuICAgIHNsb3RzOiBTbG90c1xuICB9LFxuICBzZXNzaW9uOiB7XG4gICAgLyoqXG4gICAgICogRmlsdGVyIGluc3RhbmNlXG4gICAgICogQG1lbWJlcm9mISBDaGFydFxuICAgICAqIEB0eXBlIHtGaWx0ZXJ9XG4gICAgICovXG4gICAgZmlsdGVyOiBbJ2FueScsIHRydWUsIGZhbHNlXSxcbiAgICAvKipcbiAgICAgKiBUcnVlIGlmIHRoZSBjaGFydHMgaXMgcHJvcGVybHkgY29uZmlndXJlZDsgaWUuIGFsbCByZXF1aXJlZCBzbG90cyBhcmUgZmlsbGVkLlxuICAgICAqL1xuICAgIGlzQ29uZmlndXJlZDogWydib29sZWFuJywgdHJ1ZSwgZmFsc2VdXG4gIH0sXG4gIGdldFRpdGxlOiBmdW5jdGlvbiAoKSB7XG4gICAgcmV0dXJuIHRpdGxlRm9yQ2hhcnQodGhpcyk7XG4gIH0sXG4gIHVwZGF0ZUNvbmZpZ3VyYXRpb246IGZ1bmN0aW9uICgpIHtcbiAgICAvLyB3aXRob3V0IGZpbHRlciBpbnN0YW5jZSBpdCBjYW5ub3QgYmUgY29uZmlndXJlZFxuICAgIGlmICghdGhpcy5maWx0ZXIpIHtcbiAgICAgIHRoaXMuaXNDb25maWd1cmVkID0gZmFsc2U7XG4gICAgfVxuXG4gICAgdmFyIGNvbmZpZ3VyZWQgPSB0cnVlO1xuXG4gICAgLy8gY2hlY2sgaWYgYWxsIHJlcXVpcmVkIHNsb3RzIGFyZSBmaWxsZWRcbiAgICB0aGlzLnNsb3RzLmZvckVhY2goZnVuY3Rpb24gKHNsb3QpIHtcbiAgICAgIGlmIChzbG90LnJlcXVpcmVkKSB7XG4gICAgICAgIGlmIChzbG90LnR5cGUgPT09ICdwYXJ0aXRpb24nKSB7XG4gICAgICAgICAgaWYgKCF0aGlzLmZpbHRlci5wYXJ0aXRpb25zLmdldChzbG90LnJhbmssICdyYW5rJykpIHtcbiAgICAgICAgICAgIGNvbmZpZ3VyZWQgPSBmYWxzZTtcbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSBpZiAoc2xvdC50eXBlID09PSAnYWdncmVnYXRlJykge1xuICAgICAgICAgIGlmICghdGhpcy5maWx0ZXIuYWdncmVnYXRlcy5nZXQoc2xvdC5yYW5rLCAncmFuaycpKSB7XG4gICAgICAgICAgICBjb25maWd1cmVkID0gZmFsc2U7XG4gICAgICAgICAgfVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoJ0lsbGVnYWwgc2xvdCcpO1xuICAgICAgICAgIGNvbmZpZ3VyZWQgPSBmYWxzZTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sIHRoaXMpO1xuXG4gICAgdGhpcy5pc0NvbmZpZ3VyZWQgPSBjb25maWd1cmVkO1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7QUFJQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFEQTtBQUdBO0FBQ0E7Ozs7O0FBS0E7QUFDQTtBQUFBOzs7QUFHQTtBQVZBO0FBWUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQTlDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///6339\n")},6535:function(module,exports,__webpack_require__){eval("/**\n * @classdesc Extends the BaseChart class, and adds configuration.\n * @class BarChart\n * @augments BaseChart\n *\n */\nvar BaseChart = __webpack_require__(/*! ./base-chart */ \"6339\");\n\nvar moment = __webpack_require__(/*! moment-timezone */ \"6c9d\");\n\nmodule.exports = BaseChart.extend({\n  initialize: function initialize() {\n    this.slots.reset([{\n      description: 'Group by',\n      type: 'partition',\n      rank: 1,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Subdivide by',\n      type: 'partition',\n      rank: 2,\n      required: false,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Bar height',\n      type: 'aggregate',\n      rank: 1,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }, {\n      description: 'Error bar',\n      type: 'aggregate',\n      rank: 2,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }]);\n  },\n  chartjsConfig: function chartjsConfig() {\n    return {\n      type: 'barError',\n      data: {\n        datasets: [],\n        labels: []\n      },\n      options: {\n        title: {\n          display: true,\n          position: 'top'\n        },\n        scales: {\n          xAxes: [{\n            stacked: true,\n            position: 'bottom',\n            scaleLabel: {\n              display: true,\n              labelString: ''\n            },\n            time: {\n              parser: function parser(label) {\n                return moment(label, moment.ISO_8601);\n              }\n            }\n          }],\n          yAxes: [{\n            stacked: true,\n            position: 'left',\n            scaleLabel: {\n              display: true,\n              labelString: ''\n            },\n            time: {\n              parser: function parser(label) {\n                return moment(label, moment.ISO_8601);\n              }\n            }\n          }]\n        },\n        tooltips: {},\n        errorCapWidth: 0.25\n      }\n    };\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjUzNS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9iYXJjaGFydC5qcz84YmU0Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGNsYXNzZGVzYyBFeHRlbmRzIHRoZSBCYXNlQ2hhcnQgY2xhc3MsIGFuZCBhZGRzIGNvbmZpZ3VyYXRpb24uXG4gKiBAY2xhc3MgQmFyQ2hhcnRcbiAqIEBhdWdtZW50cyBCYXNlQ2hhcnRcbiAqXG4gKi9cbnZhciBCYXNlQ2hhcnQgPSByZXF1aXJlKCcuL2Jhc2UtY2hhcnQnKTtcbnZhciBtb21lbnQgPSByZXF1aXJlKCdtb21lbnQtdGltZXpvbmUnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBCYXNlQ2hhcnQuZXh0ZW5kKHtcbiAgaW5pdGlhbGl6ZTogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMuc2xvdHMucmVzZXQoW1xuICAgICAge1xuICAgICAgICBkZXNjcmlwdGlvbjogJ0dyb3VwIGJ5JyxcbiAgICAgICAgdHlwZTogJ3BhcnRpdGlvbicsXG4gICAgICAgIHJhbms6IDEsXG4gICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY2F0ZWdvcmlhbCcsICdkYXRldGltZScsICdkdXJhdGlvbicsICdjb250aW51b3VzJywgJ3RleHQnXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdTdWJkaXZpZGUgYnknLFxuICAgICAgICB0eXBlOiAncGFydGl0aW9uJyxcbiAgICAgICAgcmFuazogMixcbiAgICAgICAgcmVxdWlyZWQ6IGZhbHNlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY2F0ZWdvcmlhbCcsICdkYXRldGltZScsICdkdXJhdGlvbicsICdjb250aW51b3VzJywgJ3RleHQnXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdCYXIgaGVpZ2h0JyxcbiAgICAgICAgdHlwZTogJ2FnZ3JlZ2F0ZScsXG4gICAgICAgIHJhbms6IDEsXG4gICAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NvbnRpbnVvdXMnLCAnZHVyYXRpb24nXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdFcnJvciBiYXInLFxuICAgICAgICB0eXBlOiAnYWdncmVnYXRlJyxcbiAgICAgICAgcmFuazogMixcbiAgICAgICAgcmVxdWlyZWQ6IGZhbHNlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY29udGludW91cycsICdkdXJhdGlvbiddXG4gICAgICB9XG4gICAgXSk7XG4gIH0sXG4gIGNoYXJ0anNDb25maWc6IGZ1bmN0aW9uICgpIHtcbiAgICByZXR1cm4ge1xuICAgICAgdHlwZTogJ2JhckVycm9yJyxcbiAgICAgIGRhdGE6IHtcbiAgICAgICAgZGF0YXNldHM6IFtdLFxuICAgICAgICBsYWJlbHM6IFtdXG4gICAgICB9LFxuICAgICAgb3B0aW9uczoge1xuICAgICAgICB0aXRsZToge1xuICAgICAgICAgIGRpc3BsYXk6IHRydWUsXG4gICAgICAgICAgcG9zaXRpb246ICd0b3AnXG4gICAgICAgIH0sXG4gICAgICAgIHNjYWxlczoge1xuICAgICAgICAgIHhBeGVzOiBbe1xuICAgICAgICAgICAgc3RhY2tlZDogdHJ1ZSxcbiAgICAgICAgICAgIHBvc2l0aW9uOiAnYm90dG9tJyxcbiAgICAgICAgICAgIHNjYWxlTGFiZWw6IHtcbiAgICAgICAgICAgICAgZGlzcGxheTogdHJ1ZSxcbiAgICAgICAgICAgICAgbGFiZWxTdHJpbmc6ICcnXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgdGltZToge1xuICAgICAgICAgICAgICBwYXJzZXI6IGZ1bmN0aW9uIChsYWJlbCkge1xuICAgICAgICAgICAgICAgIHJldHVybiBtb21lbnQobGFiZWwsIG1vbWVudC5JU09fODYwMSk7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XSxcbiAgICAgICAgICB5QXhlczogW3tcbiAgICAgICAgICAgIHN0YWNrZWQ6IHRydWUsXG4gICAgICAgICAgICBwb3NpdGlvbjogJ2xlZnQnLFxuICAgICAgICAgICAgc2NhbGVMYWJlbDoge1xuICAgICAgICAgICAgICBkaXNwbGF5OiB0cnVlLFxuICAgICAgICAgICAgICBsYWJlbFN0cmluZzogJydcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB0aW1lOiB7XG4gICAgICAgICAgICAgIHBhcnNlcjogZnVuY3Rpb24gKGxhYmVsKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIG1vbWVudChsYWJlbCwgbW9tZW50LklTT184NjAxKTtcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1dXG4gICAgICAgIH0sXG4gICAgICAgIHRvb2x0aXBzOiB7XG4gICAgICAgIH0sXG4gICAgICAgIGVycm9yQ2FwV2lkdGg6IDAuMjVcbiAgICAgIH1cbiAgICB9O1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztBQU1BO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUxBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUxBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUxBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUxBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQVBBO0FBYUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBUEE7QUFkQTtBQTRCQTtBQUVBO0FBbkNBO0FBTkE7QUE0Q0E7QUE5RUEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///6535\n")},6668:function(module,exports,__webpack_require__){eval("var PageView = __webpack_require__(/*! ./base */ \"b966\");\n\nvar templates = __webpack_require__(/*! ../templates */ \"4324\");\n\nvar FacetDefineView = __webpack_require__(/*! ./configure-facet/facet-define */ \"b24e\");\n\nvar FacetTransformContinuousView = __webpack_require__(/*! ./configure-facet/facet-transform-continuous */ \"f77a\");\n\nvar FacetTransformCategorialView = __webpack_require__(/*! ./configure-facet/facet-transform-categorial */ \"96da\");\n\nvar FacetTransformDatetimeView = __webpack_require__(/*! ./configure-facet/facet-transform-datetime */ \"9ae5\");\n\nvar FacetTransformDurationView = __webpack_require__(/*! ./configure-facet/facet-transform-duration */ \"2960\");\n\nmodule.exports = PageView.extend({\n  initialize: function initialize() {\n    this.pageName = 'configureFacet';\n  },\n  template: templates.configureFacet.page,\n  bindings: {\n    'model.isCategorial': {\n      hook: 'transform-categorial-panel',\n      type: 'toggle'\n    },\n    'model.isContinuous': {\n      hook: 'transform-continuous-panel',\n      type: 'toggle'\n    },\n    'model.isDatetime': {\n      hook: 'transform-datetime-panel',\n      type: 'toggle'\n    },\n    'model.isDuration': {\n      hook: 'transform-duration-panel',\n      type: 'toggle'\n    }\n  },\n  subviews: {\n    facetDefine: {\n      hook: 'facet-define',\n      prepareView: function prepareView(el) {\n        return new FacetDefineView({\n          el: el,\n          model: this.model\n        });\n      }\n    },\n    transformContinuous: {\n      hook: 'facet-transform-continuous',\n      prepareView: function prepareView(el) {\n        return new FacetTransformContinuousView({\n          el: el,\n          model: this.model.continuousTransform\n        });\n      }\n    },\n    transformCategorial: {\n      hook: 'facet-transform-categorial',\n      prepareView: function prepareView(el) {\n        return new FacetTransformCategorialView({\n          el: el,\n          model: this.model.categorialTransform\n        });\n      }\n    },\n    transformDatetime: {\n      hook: 'facet-transform-datetime',\n      prepareView: function prepareView(el) {\n        return new FacetTransformDatetimeView({\n          el: el,\n          model: this.model.datetimeTransform\n        });\n      }\n    },\n    transformDuration: {\n      hook: 'facet-transform-duration',\n      prepareView: function prepareView(el) {\n        return new FacetTransformDurationView({\n          el: el,\n          model: this.model.durationTransform\n        });\n      }\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNjY2OC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQuanM/NjA4OCJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgUGFnZVZpZXcgPSByZXF1aXJlKCcuL2Jhc2UnKTtcbnZhciB0ZW1wbGF0ZXMgPSByZXF1aXJlKCcuLi90ZW1wbGF0ZXMnKTtcblxudmFyIEZhY2V0RGVmaW5lVmlldyA9IHJlcXVpcmUoJy4vY29uZmlndXJlLWZhY2V0L2ZhY2V0LWRlZmluZScpO1xuXG52YXIgRmFjZXRUcmFuc2Zvcm1Db250aW51b3VzVmlldyA9IHJlcXVpcmUoJy4vY29uZmlndXJlLWZhY2V0L2ZhY2V0LXRyYW5zZm9ybS1jb250aW51b3VzJyk7XG52YXIgRmFjZXRUcmFuc2Zvcm1DYXRlZ29yaWFsVmlldyA9IHJlcXVpcmUoJy4vY29uZmlndXJlLWZhY2V0L2ZhY2V0LXRyYW5zZm9ybS1jYXRlZ29yaWFsJyk7XG52YXIgRmFjZXRUcmFuc2Zvcm1EYXRldGltZVZpZXcgPSByZXF1aXJlKCcuL2NvbmZpZ3VyZS1mYWNldC9mYWNldC10cmFuc2Zvcm0tZGF0ZXRpbWUnKTtcbnZhciBGYWNldFRyYW5zZm9ybUR1cmF0aW9uVmlldyA9IHJlcXVpcmUoJy4vY29uZmlndXJlLWZhY2V0L2ZhY2V0LXRyYW5zZm9ybS1kdXJhdGlvbicpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFBhZ2VWaWV3LmV4dGVuZCh7XG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnBhZ2VOYW1lID0gJ2NvbmZpZ3VyZUZhY2V0JztcbiAgfSxcbiAgdGVtcGxhdGU6IHRlbXBsYXRlcy5jb25maWd1cmVGYWNldC5wYWdlLFxuICBiaW5kaW5nczoge1xuICAgICdtb2RlbC5pc0NhdGVnb3JpYWwnOiB7XG4gICAgICBob29rOiAndHJhbnNmb3JtLWNhdGVnb3JpYWwtcGFuZWwnLFxuICAgICAgdHlwZTogJ3RvZ2dsZSdcbiAgICB9LFxuICAgICdtb2RlbC5pc0NvbnRpbnVvdXMnOiB7XG4gICAgICBob29rOiAndHJhbnNmb3JtLWNvbnRpbnVvdXMtcGFuZWwnLFxuICAgICAgdHlwZTogJ3RvZ2dsZSdcbiAgICB9LFxuICAgICdtb2RlbC5pc0RhdGV0aW1lJzoge1xuICAgICAgaG9vazogJ3RyYW5zZm9ybS1kYXRldGltZS1wYW5lbCcsXG4gICAgICB0eXBlOiAndG9nZ2xlJ1xuICAgIH0sXG4gICAgJ21vZGVsLmlzRHVyYXRpb24nOiB7XG4gICAgICBob29rOiAndHJhbnNmb3JtLWR1cmF0aW9uLXBhbmVsJyxcbiAgICAgIHR5cGU6ICd0b2dnbGUnXG4gICAgfVxuICB9LFxuICBzdWJ2aWV3czoge1xuICAgIGZhY2V0RGVmaW5lOiB7XG4gICAgICBob29rOiAnZmFjZXQtZGVmaW5lJyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBGYWNldERlZmluZVZpZXcoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBtb2RlbDogdGhpcy5tb2RlbFxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9LFxuICAgIHRyYW5zZm9ybUNvbnRpbnVvdXM6IHtcbiAgICAgIGhvb2s6ICdmYWNldC10cmFuc2Zvcm0tY29udGludW91cycsXG4gICAgICBwcmVwYXJlVmlldzogZnVuY3Rpb24gKGVsKSB7XG4gICAgICAgIHJldHVybiBuZXcgRmFjZXRUcmFuc2Zvcm1Db250aW51b3VzVmlldyh7XG4gICAgICAgICAgZWw6IGVsLFxuICAgICAgICAgIG1vZGVsOiB0aGlzLm1vZGVsLmNvbnRpbnVvdXNUcmFuc2Zvcm1cbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgICB0cmFuc2Zvcm1DYXRlZ29yaWFsOiB7XG4gICAgICBob29rOiAnZmFjZXQtdHJhbnNmb3JtLWNhdGVnb3JpYWwnLFxuICAgICAgcHJlcGFyZVZpZXc6IGZ1bmN0aW9uIChlbCkge1xuICAgICAgICByZXR1cm4gbmV3IEZhY2V0VHJhbnNmb3JtQ2F0ZWdvcmlhbFZpZXcoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBtb2RlbDogdGhpcy5tb2RlbC5jYXRlZ29yaWFsVHJhbnNmb3JtXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH0sXG4gICAgdHJhbnNmb3JtRGF0ZXRpbWU6IHtcbiAgICAgIGhvb2s6ICdmYWNldC10cmFuc2Zvcm0tZGF0ZXRpbWUnLFxuICAgICAgcHJlcGFyZVZpZXc6IGZ1bmN0aW9uIChlbCkge1xuICAgICAgICByZXR1cm4gbmV3IEZhY2V0VHJhbnNmb3JtRGF0ZXRpbWVWaWV3KHtcbiAgICAgICAgICBlbDogZWwsXG4gICAgICAgICAgbW9kZWw6IHRoaXMubW9kZWwuZGF0ZXRpbWVUcmFuc2Zvcm1cbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgICB0cmFuc2Zvcm1EdXJhdGlvbjoge1xuICAgICAgaG9vazogJ2ZhY2V0LXRyYW5zZm9ybS1kdXJhdGlvbicsXG4gICAgICBwcmVwYXJlVmlldzogZnVuY3Rpb24gKGVsKSB7XG4gICAgICAgIHJldHVybiBuZXcgRmFjZXRUcmFuc2Zvcm1EdXJhdGlvblZpZXcoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBtb2RlbDogdGhpcy5tb2RlbC5kdXJhdGlvblRyYW5zZm9ybVxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBRkE7QUFiQTtBQWtCQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFQQTtBQVNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFQQTtBQVNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFQQTtBQVNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFQQTtBQVNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFQQTtBQXJDQTtBQXZCQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///6668\n")},"6b2d":function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar $ = __webpack_require__(/*! jquery */ \"802c\");\n\nmodule.exports = View.extend({\n  template: templates.analyze.facetbarItem,\n  bindings: {\n    'model.name': '[data-hook~=\"facet-bar-item-button\"]',\n    'model.id': {\n      type: 'attribute',\n      hook: 'facet-bar-item',\n      name: 'data-id'\n    }\n  },\n  events: {\n    'click [data-hook~=facet-bar-item-button]': 'editFacet',\n    'mouseenter': 'enter',\n    'dragstart': 'dragStart',\n    'dragend': 'dragEnd'\n  },\n  editFacet: function editFacet() {\n    if (!app.me.isLockedDown) {\n      app.navigate('facet/' + this.model.id);\n    }\n  },\n  enter: function enter(e) {\n    var tip = document.getElementById('facet-bar-tooltip');\n\n    if (tip) {\n      tip.innerHTML = this.model.description; // Position the tooltip below the mouse pointer\n\n      $('#facet-bar-tooltip').css('left', e.pageX);\n    }\n  },\n  dragStart: function dragStart(e) {\n    var tip = document.getElementById('facet-bar-tooltip');\n    tip.classList.remove('is-active');\n  },\n  dragEnd: function dragEnd(e) {\n    var tip = document.getElementById('facet-bar-tooltip');\n    tip.classList.add('is-active');\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNmIyZC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9hbmFseXplL2ZhY2V0YmFyLWl0ZW0uanM/NWMzZiJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgVmlldyA9IHJlcXVpcmUoJ2FtcGVyc2FuZC12aWV3Jyk7XG52YXIgdGVtcGxhdGVzID0gcmVxdWlyZSgnLi4vLi4vdGVtcGxhdGVzJyk7XG52YXIgYXBwID0gcmVxdWlyZSgnYW1wZXJzYW5kLWFwcCcpO1xudmFyICQgPSByZXF1aXJlKCdqcXVlcnknKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuYW5hbHl6ZS5mYWNldGJhckl0ZW0sXG4gIGJpbmRpbmdzOiB7XG4gICAgJ21vZGVsLm5hbWUnOiAnW2RhdGEtaG9va349XCJmYWNldC1iYXItaXRlbS1idXR0b25cIl0nLFxuICAgICdtb2RlbC5pZCc6IHtcbiAgICAgIHR5cGU6ICdhdHRyaWJ1dGUnLFxuICAgICAgaG9vazogJ2ZhY2V0LWJhci1pdGVtJyxcbiAgICAgIG5hbWU6ICdkYXRhLWlkJ1xuICAgIH1cbiAgfSxcbiAgZXZlbnRzOiB7XG4gICAgJ2NsaWNrIFtkYXRhLWhvb2t+PWZhY2V0LWJhci1pdGVtLWJ1dHRvbl0nOiAnZWRpdEZhY2V0JyxcbiAgICAnbW91c2VlbnRlcic6ICdlbnRlcicsXG4gICAgJ2RyYWdzdGFydCc6ICdkcmFnU3RhcnQnLFxuICAgICdkcmFnZW5kJzogJ2RyYWdFbmQnXG4gIH0sXG4gIGVkaXRGYWNldDogZnVuY3Rpb24gKCkge1xuICAgIGlmICghYXBwLm1lLmlzTG9ja2VkRG93bikge1xuICAgICAgYXBwLm5hdmlnYXRlKCdmYWNldC8nICsgdGhpcy5tb2RlbC5pZCk7XG4gICAgfVxuICB9LFxuICBlbnRlcjogZnVuY3Rpb24gKGUpIHtcbiAgICB2YXIgdGlwID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ2ZhY2V0LWJhci10b29sdGlwJyk7XG4gICAgaWYgKHRpcCkge1xuICAgICAgdGlwLmlubmVySFRNTCA9IHRoaXMubW9kZWwuZGVzY3JpcHRpb247XG4gICAgICAvLyBQb3NpdGlvbiB0aGUgdG9vbHRpcCBiZWxvdyB0aGUgbW91c2UgcG9pbnRlclxuICAgICAgJCgnI2ZhY2V0LWJhci10b29sdGlwJykuY3NzKCdsZWZ0JywgZS5wYWdlWCk7XG4gICAgfVxuICB9LFxuICBkcmFnU3RhcnQ6IGZ1bmN0aW9uIChlKSB7XG4gICAgdmFyIHRpcCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdmYWNldC1iYXItdG9vbHRpcCcpO1xuICAgIHRpcC5jbGFzc0xpc3QucmVtb3ZlKCdpcy1hY3RpdmUnKTtcbiAgfSxcbiAgZHJhZ0VuZDogZnVuY3Rpb24gKGUpIHtcbiAgICB2YXIgdGlwID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ2ZhY2V0LWJhci10b29sdGlwJyk7XG4gICAgdGlwLmNsYXNzTGlzdC5hZGQoJ2lzLWFjdGl2ZScpO1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUZBO0FBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUpBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFwQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///6b2d\n")},"6d22":function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nmodule.exports = View.extend({\n  template: templates.configurePartition.partitionContinuous,\n  bindings: {\n    'model.isContinuous': {\n      type: 'toggle',\n      hook: 'group-continuous-panel'\n    },\n    'model.minval': {\n      type: 'value',\n      hook: 'group-minimum-input'\n    },\n    'model.maxval': {\n      type: 'value',\n      hook: 'group-maximum-input'\n    },\n    'model.groupingParam': {\n      type: 'value',\n      hook: 'group-param-input'\n    },\n    'model.groupFixedN': {\n      type: 'booleanAttribute',\n      hook: 'group-fixedn-input',\n      name: 'checked'\n    },\n    'model.groupFixedSC': {\n      type: 'booleanAttribute',\n      hook: 'group-fixedsc-input',\n      name: 'checked'\n    },\n    'model.groupFixedS': {\n      type: 'booleanAttribute',\n      hook: 'group-fixeds-input',\n      name: 'checked'\n    },\n    'model.groupLog': {\n      type: 'booleanAttribute',\n      hook: 'group-log-input',\n      name: 'checked'\n    }\n  },\n  events: {\n    'change [data-hook~=group-minimum-input]': function changeDataHookGroupMinimumInput() {\n      this.model.minval = parseInt(this.queryByHook('group-minimum-input').value);\n      this.parent.resetFilter = true;\n    },\n    'change [data-hook~=group-maximum-input]': function changeDataHookGroupMaximumInput() {\n      this.model.maxval = parseInt(this.queryByHook('group-maximum-input').value);\n      this.parent.resetFilter = true;\n    },\n    'click [data-hook~=group-range-button]': function clickDataHookGroupRangeButton() {\n      var partition = this.model;\n      partition.reset();\n      this.queryByHook('group-minimum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('group-maximum-input').dispatchEvent(new window.Event('input'));\n      this.parent.resetFilter = true;\n    },\n    'change [data-hook~=group-param-input]': function changeDataHookGroupParamInput() {\n      this.model.groupingParam = parseInt(this.queryByHook('group-param-input').value);\n      this.parent.resetFilter = true;\n    },\n    'click [data-hook~=group-fixedn-input]': function clickDataHookGroupFixednInput() {\n      this.model.groupingContinuous = 'fixedn';\n      this.parent.resetFilter = true;\n    },\n    'click [data-hook~=group-fixedsc-input]': function clickDataHookGroupFixedscInput() {\n      this.model.groupingContinuous = 'fixedsc';\n      this.parent.resetFilter = true;\n    },\n    'click [data-hook~=group-fixeds-input]': function clickDataHookGroupFixedsInput() {\n      this.model.groupingContinuous = 'fixeds';\n      this.parent.resetFilter = true;\n    },\n    'click [data-hook~=group-log-input]': function clickDataHookGroupLogInput() {\n      this.model.groupingContinuous = 'log';\n      this.parent.resetFilter = true;\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNmQyMi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtcGFydGl0aW9uL3BhcnRpdGlvbi1jb250aW51b3VzLmpzPzU4MDIiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFZpZXcuZXh0ZW5kKHtcbiAgdGVtcGxhdGU6IHRlbXBsYXRlcy5jb25maWd1cmVQYXJ0aXRpb24ucGFydGl0aW9uQ29udGludW91cyxcbiAgYmluZGluZ3M6IHtcbiAgICAnbW9kZWwuaXNDb250aW51b3VzJzoge1xuICAgICAgdHlwZTogJ3RvZ2dsZScsXG4gICAgICBob29rOiAnZ3JvdXAtY29udGludW91cy1wYW5lbCdcbiAgICB9LFxuXG4gICAgJ21vZGVsLm1pbnZhbCc6IHtcbiAgICAgIHR5cGU6ICd2YWx1ZScsXG4gICAgICBob29rOiAnZ3JvdXAtbWluaW11bS1pbnB1dCdcbiAgICB9LFxuICAgICdtb2RlbC5tYXh2YWwnOiB7XG4gICAgICB0eXBlOiAndmFsdWUnLFxuICAgICAgaG9vazogJ2dyb3VwLW1heGltdW0taW5wdXQnXG4gICAgfSxcbiAgICAnbW9kZWwuZ3JvdXBpbmdQYXJhbSc6IHtcbiAgICAgIHR5cGU6ICd2YWx1ZScsXG4gICAgICBob29rOiAnZ3JvdXAtcGFyYW0taW5wdXQnXG4gICAgfSxcbiAgICAnbW9kZWwuZ3JvdXBGaXhlZE4nOiB7XG4gICAgICB0eXBlOiAnYm9vbGVhbkF0dHJpYnV0ZScsXG4gICAgICBob29rOiAnZ3JvdXAtZml4ZWRuLWlucHV0JyxcbiAgICAgIG5hbWU6ICdjaGVja2VkJ1xuICAgIH0sXG4gICAgJ21vZGVsLmdyb3VwRml4ZWRTQyc6IHtcbiAgICAgIHR5cGU6ICdib29sZWFuQXR0cmlidXRlJyxcbiAgICAgIGhvb2s6ICdncm91cC1maXhlZHNjLWlucHV0JyxcbiAgICAgIG5hbWU6ICdjaGVja2VkJ1xuICAgIH0sXG4gICAgJ21vZGVsLmdyb3VwRml4ZWRTJzoge1xuICAgICAgdHlwZTogJ2Jvb2xlYW5BdHRyaWJ1dGUnLFxuICAgICAgaG9vazogJ2dyb3VwLWZpeGVkcy1pbnB1dCcsXG4gICAgICBuYW1lOiAnY2hlY2tlZCdcbiAgICB9LFxuICAgICdtb2RlbC5ncm91cExvZyc6IHtcbiAgICAgIHR5cGU6ICdib29sZWFuQXR0cmlidXRlJyxcbiAgICAgIGhvb2s6ICdncm91cC1sb2ctaW5wdXQnLFxuICAgICAgbmFtZTogJ2NoZWNrZWQnXG4gICAgfVxuICB9LFxuICBldmVudHM6IHtcbiAgICAnY2hhbmdlIFtkYXRhLWhvb2t+PWdyb3VwLW1pbmltdW0taW5wdXRdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5tb2RlbC5taW52YWwgPSBwYXJzZUludCh0aGlzLnF1ZXJ5QnlIb29rKCdncm91cC1taW5pbXVtLWlucHV0JykudmFsdWUpO1xuICAgICAgdGhpcy5wYXJlbnQucmVzZXRGaWx0ZXIgPSB0cnVlO1xuICAgIH0sXG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj1ncm91cC1tYXhpbXVtLWlucHV0XSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMubW9kZWwubWF4dmFsID0gcGFyc2VJbnQodGhpcy5xdWVyeUJ5SG9vaygnZ3JvdXAtbWF4aW11bS1pbnB1dCcpLnZhbHVlKTtcbiAgICAgIHRoaXMucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9LFxuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1yYW5nZS1idXR0b25dJzogZnVuY3Rpb24gKCkge1xuICAgICAgdmFyIHBhcnRpdGlvbiA9IHRoaXMubW9kZWw7XG4gICAgICBwYXJ0aXRpb24ucmVzZXQoKTtcblxuICAgICAgdGhpcy5xdWVyeUJ5SG9vaygnZ3JvdXAtbWluaW11bS1pbnB1dCcpLmRpc3BhdGNoRXZlbnQobmV3IHdpbmRvdy5FdmVudCgnaW5wdXQnKSk7XG4gICAgICB0aGlzLnF1ZXJ5QnlIb29rKCdncm91cC1tYXhpbXVtLWlucHV0JykuZGlzcGF0Y2hFdmVudChuZXcgd2luZG93LkV2ZW50KCdpbnB1dCcpKTtcbiAgICAgIHRoaXMucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9LFxuXG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj1ncm91cC1wYXJhbS1pbnB1dF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLmdyb3VwaW5nUGFyYW0gPSBwYXJzZUludCh0aGlzLnF1ZXJ5QnlIb29rKCdncm91cC1wYXJhbS1pbnB1dCcpLnZhbHVlKTtcbiAgICAgIHRoaXMucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9LFxuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1maXhlZG4taW5wdXRdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5tb2RlbC5ncm91cGluZ0NvbnRpbnVvdXMgPSAnZml4ZWRuJztcbiAgICAgIHRoaXMucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9LFxuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1maXhlZHNjLWlucHV0XSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMubW9kZWwuZ3JvdXBpbmdDb250aW51b3VzID0gJ2ZpeGVkc2MnO1xuICAgICAgdGhpcy5wYXJlbnQucmVzZXRGaWx0ZXIgPSB0cnVlO1xuICAgIH0sXG4gICAgJ2NsaWNrIFtkYXRhLWhvb2t+PWdyb3VwLWZpeGVkcy1pbnB1dF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLmdyb3VwaW5nQ29udGludW91cyA9ICdmaXhlZHMnO1xuICAgICAgdGhpcy5wYXJlbnQucmVzZXRGaWx0ZXIgPSB0cnVlO1xuICAgIH0sXG4gICAgJ2NsaWNrIFtkYXRhLWhvb2t+PWdyb3VwLWxvZy1pbnB1dF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLmdyb3VwaW5nQ29udGludW91cyA9ICdsb2cnO1xuICAgICAgdGhpcy5wYXJlbnQucmVzZXRGaWx0ZXIgPSB0cnVlO1xuICAgIH1cbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFLQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBS0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBakNBO0FBdUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQXJDQTtBQXpDQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///6d22\n")},"701f":function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nmodule.exports = View.extend({\n  template: templates.configureDataset.facet,\n  initialize: function initialize() {\n    this.isLockedDown = app.me.isLockedDown;\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n    window.componentHandler.upgradeDom(this.el);\n    return this;\n  },\n  session: {\n    'isLockedDown': 'boolean'\n  },\n  bindings: {\n    'isLockedDown': {\n      type: 'toggle',\n      hook: 'actions',\n      invert: 'yes'\n    },\n    'model.name': '[data-hook~=name]',\n    'model.description': '[data-hook~=description]',\n    'model.show': {\n      type: 'toggle',\n      hook: 'fullitem'\n    },\n    //    'model.isCategorial': {\n    //      type: 'booleanClass',\n    //      hook: 'typeIcon',\n    //      name: 'facetCategorialIcon'\n    //    },\n    //    'model.isContinuous': {\n    //      type: 'booleanClass',\n    //      hook: 'typeIcon',\n    //      name: 'facetContinuousIcon'\n    // },\n    //    'model.isDatetime': {\n    //      type: 'booleanClass',\n    //      hook: 'typeIcon',\n    //      name: 'facetDatetimeIcon'\n    //    },\n    //    'model.isDuration': {\n    //      type: 'booleanClass',\n    //      hook: 'typeIcon',\n    //      name: 'facetDurationIcon'\n    //    },\n    //    'model.isText': {\n    //      type: 'booleanClass',\n    //      hook: 'typeIcon',\n    //      name: 'facetTextIcon'\n    //    }\n    // material design hooks\n    'model.id': [{\n      hook: 'cb',\n      type: 'attribute',\n      name: 'id'\n    }, {\n      hook: 'cblabel',\n      type: 'attribute',\n      name: 'for'\n    }],\n    'model.isActive': {\n      hook: 'cb',\n      type: 'booleanAttribute',\n      name: 'checked'\n    }\n  },\n  events: {\n    'change': 'togglePower',\n    'click [data-hook~=configureFacet]': 'configureFacet',\n    'click [data-hook~=removeFacet]': 'removeFacet',\n    'click [data-hook~=duplicateFacet]': 'duplicateFacet'\n  },\n  togglePower: function togglePower(ev) {\n    this.model.isActive = !this.model.isActive;\n\n    if (this.model.isCategorial) {\n      this.model.setCategories();\n    } else if (this.model.isContinuous || this.model.isDatetime || this.model.isDuration) {\n      this.model.setMinMax();\n    }\n  },\n  configureFacet: function configureFacet(ev) {\n    app.navigate('facet/' + this.model.id);\n  },\n  removeFacet: function removeFacet(ev) {\n    this.collection.remove(this.model);\n  },\n  duplicateFacet: function duplicateFacet(ev) {\n    // make a copy with new name and id\n    var duplicateFacet = this.model.toJSON();\n    duplicateFacet.name += ' copy';\n    delete duplicateFacet.id;\n    this.collection.add(duplicateFacet);\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzAxZi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZGF0YXNldC9mYWNldC1jb2xsZWN0aW9uLmpzPzBjOTEiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xudmFyIGFwcCA9IHJlcXVpcmUoJ2FtcGVyc2FuZC1hcHAnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuY29uZmlndXJlRGF0YXNldC5mYWNldCxcbiAgaW5pdGlhbGl6ZTogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMuaXNMb2NrZWREb3duID0gYXBwLm1lLmlzTG9ja2VkRG93bjtcbiAgfSxcbiAgcmVuZGVyOiBmdW5jdGlvbiAoKSB7XG4gICAgdGhpcy5yZW5kZXJXaXRoVGVtcGxhdGUodGhpcyk7XG4gICAgd2luZG93LmNvbXBvbmVudEhhbmRsZXIudXBncmFkZURvbSh0aGlzLmVsKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfSxcbiAgc2Vzc2lvbjoge1xuICAgICdpc0xvY2tlZERvd24nOiAnYm9vbGVhbidcbiAgfSxcbiAgYmluZGluZ3M6IHtcbiAgICAnaXNMb2NrZWREb3duJzoge1xuICAgICAgdHlwZTogJ3RvZ2dsZScsXG4gICAgICBob29rOiAnYWN0aW9ucycsXG4gICAgICBpbnZlcnQ6ICd5ZXMnXG4gICAgfSxcbiAgICAnbW9kZWwubmFtZSc6ICdbZGF0YS1ob29rfj1uYW1lXScsXG4gICAgJ21vZGVsLmRlc2NyaXB0aW9uJzogJ1tkYXRhLWhvb2t+PWRlc2NyaXB0aW9uXScsXG4gICAgJ21vZGVsLnNob3cnOiB7XG4gICAgICB0eXBlOiAndG9nZ2xlJyxcbiAgICAgIGhvb2s6ICdmdWxsaXRlbSdcbiAgICB9LFxuLy8gICAgJ21vZGVsLmlzQ2F0ZWdvcmlhbCc6IHtcbi8vICAgICAgdHlwZTogJ2Jvb2xlYW5DbGFzcycsXG4vLyAgICAgIGhvb2s6ICd0eXBlSWNvbicsXG4vLyAgICAgIG5hbWU6ICdmYWNldENhdGVnb3JpYWxJY29uJ1xuLy8gICAgfSxcbi8vICAgICdtb2RlbC5pc0NvbnRpbnVvdXMnOiB7XG4vLyAgICAgIHR5cGU6ICdib29sZWFuQ2xhc3MnLFxuLy8gICAgICBob29rOiAndHlwZUljb24nLFxuLy8gICAgICBuYW1lOiAnZmFjZXRDb250aW51b3VzSWNvbidcbi8vIH0sXG4vLyAgICAnbW9kZWwuaXNEYXRldGltZSc6IHtcbi8vICAgICAgdHlwZTogJ2Jvb2xlYW5DbGFzcycsXG4vLyAgICAgIGhvb2s6ICd0eXBlSWNvbicsXG4vLyAgICAgIG5hbWU6ICdmYWNldERhdGV0aW1lSWNvbidcbi8vICAgIH0sXG4vLyAgICAnbW9kZWwuaXNEdXJhdGlvbic6IHtcbi8vICAgICAgdHlwZTogJ2Jvb2xlYW5DbGFzcycsXG4vLyAgICAgIGhvb2s6ICd0eXBlSWNvbicsXG4vLyAgICAgIG5hbWU6ICdmYWNldER1cmF0aW9uSWNvbidcbi8vICAgIH0sXG4vLyAgICAnbW9kZWwuaXNUZXh0Jzoge1xuLy8gICAgICB0eXBlOiAnYm9vbGVhbkNsYXNzJyxcbi8vICAgICAgaG9vazogJ3R5cGVJY29uJyxcbi8vICAgICAgbmFtZTogJ2ZhY2V0VGV4dEljb24nXG4vLyAgICB9XG4gICAgLy8gbWF0ZXJpYWwgZGVzaWduIGhvb2tzXG4gICAgJ21vZGVsLmlkJzogW1xuICAgICAgeyBob29rOiAnY2InLCB0eXBlOiAnYXR0cmlidXRlJywgbmFtZTogJ2lkJyB9LFxuICAgICAgeyBob29rOiAnY2JsYWJlbCcsIHR5cGU6ICdhdHRyaWJ1dGUnLCBuYW1lOiAnZm9yJyB9XG4gICAgXSxcbiAgICAnbW9kZWwuaXNBY3RpdmUnOiB7XG4gICAgICBob29rOiAnY2InLFxuICAgICAgdHlwZTogJ2Jvb2xlYW5BdHRyaWJ1dGUnLFxuICAgICAgbmFtZTogJ2NoZWNrZWQnXG4gICAgfVxuICB9LFxuICBldmVudHM6IHtcbiAgICAnY2hhbmdlJzogJ3RvZ2dsZVBvd2VyJyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349Y29uZmlndXJlRmFjZXRdJzogJ2NvbmZpZ3VyZUZhY2V0JyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349cmVtb3ZlRmFjZXRdJzogJ3JlbW92ZUZhY2V0JyxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349ZHVwbGljYXRlRmFjZXRdJzogJ2R1cGxpY2F0ZUZhY2V0J1xuICB9LFxuICB0b2dnbGVQb3dlcjogZnVuY3Rpb24gKGV2KSB7XG4gICAgdGhpcy5tb2RlbC5pc0FjdGl2ZSA9ICF0aGlzLm1vZGVsLmlzQWN0aXZlO1xuXG4gICAgaWYgKHRoaXMubW9kZWwuaXNDYXRlZ29yaWFsKSB7XG4gICAgICB0aGlzLm1vZGVsLnNldENhdGVnb3JpZXMoKTtcbiAgICB9IGVsc2UgaWYgKHRoaXMubW9kZWwuaXNDb250aW51b3VzIHx8IHRoaXMubW9kZWwuaXNEYXRldGltZSB8fCB0aGlzLm1vZGVsLmlzRHVyYXRpb24pIHtcbiAgICAgIHRoaXMubW9kZWwuc2V0TWluTWF4KCk7XG4gICAgfVxuICB9LFxuICBjb25maWd1cmVGYWNldDogZnVuY3Rpb24gKGV2KSB7XG4gICAgYXBwLm5hdmlnYXRlKCdmYWNldC8nICsgdGhpcy5tb2RlbC5pZCk7XG4gIH0sXG4gIHJlbW92ZUZhY2V0OiBmdW5jdGlvbiAoZXYpIHtcbiAgICB0aGlzLmNvbGxlY3Rpb24ucmVtb3ZlKHRoaXMubW9kZWwpO1xuICB9LFxuICBkdXBsaWNhdGVGYWNldDogZnVuY3Rpb24gKGV2KSB7XG4gICAgLy8gbWFrZSBhIGNvcHkgd2l0aCBuZXcgbmFtZSBhbmQgaWRcbiAgICB2YXIgZHVwbGljYXRlRmFjZXQgPSB0aGlzLm1vZGVsLnRvSlNPTigpO1xuICAgIGR1cGxpY2F0ZUZhY2V0Lm5hbWUgKz0gJyBjb3B5JztcbiAgICBkZWxldGUgZHVwbGljYXRlRmFjZXQuaWQ7XG5cbiAgICB0aGlzLmNvbGxlY3Rpb24uYWRkKGR1cGxpY2F0ZUZhY2V0KTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBS0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUExQ0E7QUFnREE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUpBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUF6RkEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///701f\n")},"71a3":function(module,exports,__webpack_require__){eval("/**\n * @classdesc bubble plot class\n * @class BubblePlot\n * @augments BaseChart\n */\nvar BaseChart = __webpack_require__(/*! ./base-chart */ \"6339\");\n\nvar moment = __webpack_require__(/*! moment-timezone */ \"6c9d\");\n\nfunction ttLabel(tooltip, data) {\n  var point = data.datasets[tooltip.datasetIndex].data[tooltip.index];\n  var axes = data.datasets[0].spotAxes;\n  var label = [axes.x + ': ' + point.a, axes.y + ': ' + point.b];\n\n  if (axes.r) {\n    label.push('radius (' + axes.r + ') ' + point.bb);\n  }\n\n  if (axes.c) {\n    label.push('color (' + axes.c + ' ) ' + point.aa);\n  }\n\n  label.push('Number of points in bin ' + point.count);\n  return label;\n}\n\nmodule.exports = BaseChart.extend({\n  initialize: function initialize() {\n    this.slots.reset([{\n      description: 'X axis',\n      type: 'partition',\n      rank: 1,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Y axis',\n      type: 'partition',\n      rank: 2,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Point color',\n      type: 'aggregate',\n      rank: 1,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }, {\n      description: 'Point size',\n      type: 'aggregate',\n      rank: 2,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }, {\n      description: 'X error',\n      type: 'aggregate',\n      rank: 3,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }, {\n      description: 'Y error',\n      type: 'aggregate',\n      rank: 4,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }]);\n  },\n  chartjsConfig: function chartjsConfig() {\n    return {\n      type: 'bubbleError',\n      data: {\n        datasets: []\n      },\n      options: {\n        animation: false,\n        title: {\n          display: true,\n          position: 'top'\n        },\n        legend: {\n          display: false\n        },\n        scales: {\n          xAxes: [{\n            type: 'linear',\n            position: 'bottom',\n            gridLines: {\n              zeroLineColor: 'rgba(0,255,0,1)'\n            },\n            scaleLabel: {\n              display: true\n            },\n            time: {\n              parser: function parser(label) {\n                return moment(label, moment.ISO_8601);\n              }\n            }\n          }],\n          yAxes: [{\n            type: 'linear',\n            position: 'left',\n            gridLines: {\n              zeroLineColor: 'rgba(0,255,0,1)'\n            },\n            scaleLabel: {\n              display: true\n            },\n            time: {\n              parser: function parser(label) {\n                return moment(label, moment.ISO_8601);\n              }\n            }\n          }]\n        },\n        tooltips: {\n          enabled: true,\n          mode: 'single',\n          callbacks: {\n            label: ttLabel\n          }\n        }\n      }\n    };\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiNzFhMy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9idWJibGVwbG90LmpzPzY4NzIiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAY2xhc3NkZXNjIGJ1YmJsZSBwbG90IGNsYXNzXG4gKiBAY2xhc3MgQnViYmxlUGxvdFxuICogQGF1Z21lbnRzIEJhc2VDaGFydFxuICovXG5cbnZhciBCYXNlQ2hhcnQgPSByZXF1aXJlKCcuL2Jhc2UtY2hhcnQnKTtcbnZhciBtb21lbnQgPSByZXF1aXJlKCdtb21lbnQtdGltZXpvbmUnKTtcblxuZnVuY3Rpb24gdHRMYWJlbCAodG9vbHRpcCwgZGF0YSkge1xuICB2YXIgcG9pbnQgPSBkYXRhLmRhdGFzZXRzW3Rvb2x0aXAuZGF0YXNldEluZGV4XS5kYXRhW3Rvb2x0aXAuaW5kZXhdO1xuICB2YXIgYXhlcyA9IGRhdGEuZGF0YXNldHNbMF0uc3BvdEF4ZXM7XG5cbiAgdmFyIGxhYmVsID0gW1xuICAgIGF4ZXMueCArICc6ICcgKyBwb2ludC5hLFxuICAgIGF4ZXMueSArICc6ICcgKyBwb2ludC5iXG4gIF07XG4gIGlmIChheGVzLnIpIHtcbiAgICBsYWJlbC5wdXNoKCdyYWRpdXMgKCcgKyBheGVzLnIgKyAnKSAnICsgcG9pbnQuYmIpO1xuICB9XG4gIGlmIChheGVzLmMpIHtcbiAgICBsYWJlbC5wdXNoKCdjb2xvciAoJyArIGF4ZXMuYyArICcgKSAnICsgcG9pbnQuYWEpO1xuICB9XG4gIGxhYmVsLnB1c2goJ051bWJlciBvZiBwb2ludHMgaW4gYmluICcgKyBwb2ludC5jb3VudCk7XG4gIHJldHVybiBsYWJlbDtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBCYXNlQ2hhcnQuZXh0ZW5kKHtcbiAgaW5pdGlhbGl6ZTogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMuc2xvdHMucmVzZXQoW1xuICAgICAge1xuICAgICAgICBkZXNjcmlwdGlvbjogJ1ggYXhpcycsXG4gICAgICAgIHR5cGU6ICdwYXJ0aXRpb24nLFxuICAgICAgICByYW5rOiAxLFxuICAgICAgICByZXF1aXJlZDogdHJ1ZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NhdGVnb3JpYWwnLCAnZGF0ZXRpbWUnLCAnZHVyYXRpb24nLCAnY29udGludW91cycsICd0ZXh0J11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnWSBheGlzJyxcbiAgICAgICAgdHlwZTogJ3BhcnRpdGlvbicsXG4gICAgICAgIHJhbms6IDIsXG4gICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY2F0ZWdvcmlhbCcsICdkYXRldGltZScsICdkdXJhdGlvbicsICdjb250aW51b3VzJywgJ3RleHQnXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdQb2ludCBjb2xvcicsXG4gICAgICAgIHR5cGU6ICdhZ2dyZWdhdGUnLFxuICAgICAgICByYW5rOiAxLFxuICAgICAgICByZXF1aXJlZDogZmFsc2UsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjb250aW51b3VzJywgJ2R1cmF0aW9uJ11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnUG9pbnQgc2l6ZScsXG4gICAgICAgIHR5cGU6ICdhZ2dyZWdhdGUnLFxuICAgICAgICByYW5rOiAyLFxuICAgICAgICByZXF1aXJlZDogZmFsc2UsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjb250aW51b3VzJywgJ2R1cmF0aW9uJ11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnWCBlcnJvcicsXG4gICAgICAgIHR5cGU6ICdhZ2dyZWdhdGUnLFxuICAgICAgICByYW5rOiAzLFxuICAgICAgICByZXF1aXJlZDogZmFsc2UsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjb250aW51b3VzJywgJ2R1cmF0aW9uJ11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnWSBlcnJvcicsXG4gICAgICAgIHR5cGU6ICdhZ2dyZWdhdGUnLFxuICAgICAgICByYW5rOiA0LFxuICAgICAgICByZXF1aXJlZDogZmFsc2UsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjb250aW51b3VzJywgJ2R1cmF0aW9uJ11cbiAgICAgIH1cbiAgICBdKTtcbiAgfSxcbiAgY2hhcnRqc0NvbmZpZzogZnVuY3Rpb24gKCkge1xuICAgIHJldHVybiB7XG4gICAgICB0eXBlOiAnYnViYmxlRXJyb3InLFxuICAgICAgZGF0YToge1xuICAgICAgICBkYXRhc2V0czogW11cbiAgICAgIH0sXG4gICAgICBvcHRpb25zOiB7XG4gICAgICAgIGFuaW1hdGlvbjogZmFsc2UsXG4gICAgICAgIHRpdGxlOiB7XG4gICAgICAgICAgZGlzcGxheTogdHJ1ZSxcbiAgICAgICAgICBwb3NpdGlvbjogJ3RvcCdcbiAgICAgICAgfSxcbiAgICAgICAgbGVnZW5kOiB7XG4gICAgICAgICAgZGlzcGxheTogZmFsc2VcbiAgICAgICAgfSxcbiAgICAgICAgc2NhbGVzOiB7XG4gICAgICAgICAgeEF4ZXM6IFt7XG4gICAgICAgICAgICB0eXBlOiAnbGluZWFyJyxcbiAgICAgICAgICAgIHBvc2l0aW9uOiAnYm90dG9tJyxcbiAgICAgICAgICAgIGdyaWRMaW5lczoge1xuICAgICAgICAgICAgICB6ZXJvTGluZUNvbG9yOiAncmdiYSgwLDI1NSwwLDEpJ1xuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHNjYWxlTGFiZWw6IHtcbiAgICAgICAgICAgICAgZGlzcGxheTogdHJ1ZVxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHRpbWU6IHtcbiAgICAgICAgICAgICAgcGFyc2VyOiBmdW5jdGlvbiAobGFiZWwpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gbW9tZW50KGxhYmVsLCBtb21lbnQuSVNPXzg2MDEpO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfV0sXG4gICAgICAgICAgeUF4ZXM6IFt7XG4gICAgICAgICAgICB0eXBlOiAnbGluZWFyJyxcbiAgICAgICAgICAgIHBvc2l0aW9uOiAnbGVmdCcsXG4gICAgICAgICAgICBncmlkTGluZXM6IHtcbiAgICAgICAgICAgICAgemVyb0xpbmVDb2xvcjogJ3JnYmEoMCwyNTUsMCwxKSdcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBzY2FsZUxhYmVsOiB7XG4gICAgICAgICAgICAgIGRpc3BsYXk6IHRydWVcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB0aW1lOiB7XG4gICAgICAgICAgICAgIHBhcnNlcjogZnVuY3Rpb24gKGxhYmVsKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIG1vbWVudChsYWJlbCwgbW9tZW50LklTT184NjAxKTtcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1dXG4gICAgICAgIH0sXG4gICAgICAgIHRvb2x0aXBzOiB7XG4gICAgICAgICAgZW5hYmxlZDogdHJ1ZSxcbiAgICAgICAgICBtb2RlOiAnc2luZ2xlJyxcbiAgICAgICAgICBjYWxsYmFja3M6IHtcbiAgICAgICAgICAgIGxhYmVsOiB0dExhYmVsXG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBOzs7OztBQU1BO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBREE7QUFHQTtBQUNBO0FBREE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBVEE7QUFlQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBREE7QUFHQTtBQUNBO0FBREE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBVEE7QUFoQkE7QUFnQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBSEE7QUF6Q0E7QUFMQTtBQXVEQTtBQXZHQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///71a3\n")},"7bdf":function(module,exports,__webpack_require__){eval("/* WEBPACK VAR INJECTION */(function(process) {function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar PageView = __webpack_require__(/*! ./base */ \"b966\");\n\nvar templates = __webpack_require__(/*! ../templates */ \"4324\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar $ = __webpack_require__(/*! jquery */ \"802c\");\n\nvar dialogPolyfill = __webpack_require__(/*! dialog-polyfill */ \"5c00\");\n\nvar SessionModel = __webpack_require__(/*! ./datasets/session-model */ \"bdff\");\n\nvar DatasetCollectionView = __webpack_require__(/*! ./datasets/dataset-collection */ \"1002\");\n\nvar SessionCollectionView = __webpack_require__(/*! ./datasets/session-collection */ \"56f6\");\n\nmodule.exports = PageView.extend({\n  template: templates.datasets.page,\n  initialize: function initialize() {\n    this.pageName = 'datasets';\n    this.helpTemplate = ''; // // display or hide elements\n    // var serverButton = document.getElementById('serverButton-card');\n    // console.log(serverButton);\n    // if ( process.env.MODE !== 'server' ) {\n    //   // serverButton.style.display = 'inherit';\n    //   // serverButton.style.display = 'none';\n    //   // serverButton.style.display = 'inline';\n    // }\n\n    var localStorageDatasets = app.getDatasetsFromLocalStorage();\n    localStorageDatasets.forEach(function (dset, index) {\n      app.me.datasets.add(dset);\n      console.log(\"[\" + index + \"]: \" + dset.id + '  ', dset.name);\n    });\n    var localStorageSessions = app.getSessionsFromLocalStorage();\n    localStorageSessions.forEach(function (sess, index) {\n      var now = new Date();\n      var sessMod = new SessionModel({\n        id: sess.id,\n        name: 'Local session',\n        date: now.toLocaleString()\n      });\n      app.sessions.add(sessMod);\n    });\n  },\n  events: {\n    'change [data-hook~=json-upload-input]': 'importJSON',\n    'change [data-hook~=csv-upload-input]': 'importCSV',\n    'click [data-hook~=server-connect]': 'connectToServer',\n    'input [data-hook~=dataset-selector]': 'input',\n    'input [data-hook~=CSV-separator-other-input]': 'setOtherSeperator',\n    'click [data-hook~=search-button]': 'search',\n    'click [data-hook~=clear-button]': 'clear',\n    'click [data-hook~=CSV-settings-button]': 'showCSVSettings',\n    'click [data-hook~=CSV-settings-close]': 'closeCSVSettings',\n    'click [data-hook~=session-cloud-upload]': 'uploadSessionZenodo',\n    'click [data-hook~=session-cloud-download]': 'showCloudDownloadInfo',\n    'click [data-hook~=session-download]': 'exportSession',\n    'change [data-hook~=session-upload-input]': 'importLocalSession',\n    'click [data-hook~=data-download]': 'exportData',\n    'click [data-hook~=session-download-cloud-close-button]': 'closeCloudDownloadInfo',\n    'click [data-hook~=session-download-cloud-get]': 'getRemoteSession',\n    'click [data-hook~=session-upload-cloud-close-button]': 'closeCloudUploadInfo',\n    'click #CSV-separator-comma': function clickCSVSeparatorComma() {\n      app.CSVSeparator = ',';\n    },\n    'click #CSV-separator-colon': function clickCSVSeparatorColon() {\n      app.CSVSeparator = ':';\n    },\n    'click #CSV-separator-semicolon': function clickCSVSeparatorSemicolon() {\n      app.CSVSeparator = ';';\n    },\n    'click #CSV-separator-pipe': function clickCSVSeparatorPipe() {\n      app.CSVSeparator = '|';\n    },\n    'click #CSV-separator-tab': function clickCSVSeparatorTab() {\n      app.CSVSeparator = '\\t';\n    },\n    'click #CSV-separator-other': function clickCSVSeparatorOther() {\n      this.el.querySelector('[data-hook~=\"CSV-separator-other-input\"]').focus();\n    },\n    'click #CSV-header-columns': function clickCSVHeaderColumns() {\n      app.CSVHeaders = this.query('#CSV-header-columns').checked;\n    },\n    'click #CSV-quote-single': function clickCSVQuoteSingle() {\n      app.CSVQuote = '\\'';\n    },\n    'click #CSV-quote-double': function clickCSVQuoteDouble() {\n      app.CSVQuote = '\"';\n    },\n    'click #CSV-quote-none': function clickCSVQuoteNone() {\n      app.CSVQuote = null;\n    },\n    'click #CSV-comment-pound': function clickCSVCommentPound() {\n      app.CSVComment = '#';\n    },\n    'click #CSV-comment-exclamation': function clickCSVCommentExclamation() {\n      app.CSVComment = '!';\n    },\n    'click #CSV-comment-slash': function clickCSVCommentSlash() {\n      app.CSVComment = '/';\n    },\n    'click #CSV-comment-dash': function clickCSVCommentDash() {\n      app.CSVComment = '-';\n    },\n    'click #CSV-comment-percent': function clickCSVCommentPercent() {\n      app.CSVComment = '%';\n    }\n  },\n  render: function render() {\n    // Reset the CSV parsing dialog.\n    // NOTE: we could do this via bindings, but this is easier (less code)\n    this.renderWithTemplate(this);\n    this.query('#CSV-header-columns').checked = app.CSVHeaders;\n\n    if (app.CSVSeparator === ',') {\n      this.query('#CSV-separator-comma').checked = true;\n    } else if (app.CSVSeparator === ':') {\n      this.query('#CSV-separator-colon').checked = true;\n    } else if (app.CSVSeparator === ';') {\n      this.query('#CSV-separator-semicolon').checked = true;\n    } else if (app.CSVSeparator === '|') {\n      this.query('#CSV-separator-pipe').checked = true;\n    } else if (app.CSVSeparator === '\\t') {\n      this.query('#CSV-separator-tab').checked = true;\n    }\n\n    if (app.CSVQuote === '\"') {\n      this.query('#CSV-quote-double').checked = true;\n    } else if (app.CSVQuote === '\\'') {\n      this.query('#CSV-quote-single').checked = true;\n    } else if (app.CSVQuote === null) {\n      this.query('#CSV-quote-none').checked = true;\n    }\n\n    if (app.CSVComment === '#') {\n      this.query('#CSV-comment-pound').checked = true;\n    } else if (app.CSVComment === '!') {\n      this.query('#CSV-comment-exclamation').checked = true;\n    } else if (app.CSVComment === '/') {\n      this.query('#CSV-comment-slash').checked = true;\n    } else if (app.CSVComment === '-') {\n      this.query('#CSV-comment-dash').checked = true;\n    } else if (app.CSVComment === 'percent') {\n      this.query('#CSV-comment-percent').checked = true;\n    } // mdl hook ups\n\n\n    this.once('remove', function () {\n      app.me.datasets.off('add');\n    });\n    app.me.datasets.on('add', function () {\n      window.componentHandler.upgradeDom();\n    });\n    app.sessions.on('add', function () {\n      window.componentHandler.upgradeDom();\n    });\n  },\n  session: {\n    needle: 'string',\n    showSearch: 'boolean'\n  },\n  subviews: {\n    datasets: {\n      hook: 'dataset-items',\n      constructor: DatasetCollectionView\n    },\n    sessions: {\n      hook: 'session-items',\n      constructor: SessionCollectionView\n    }\n  },\n  bindings: {\n    'model.isLockedDown': {\n      type: 'toggle',\n      hook: 'add-datasets-div',\n      invert: true\n    },\n    'showSearch': {\n      type: 'toggle',\n      hook: 'search-bar'\n    },\n    'needle': {\n      type: 'value',\n      hook: 'dataset-selector'\n    }\n  },\n  input: function input() {\n    var select = this.el.querySelector('[data-hook~=\"dataset-selector\"]');\n    this.needle = select.value;\n    this.update();\n  },\n  setOtherSeperator: function setOtherSeperator() {\n    var select = this.el.querySelector('[data-hook~=\"CSV-separator-other-input\"]');\n    app.CSVSeparator = select.value;\n  },\n  search: function search() {\n    this.showSearch = !this.showSearch;\n\n    if (this.showSearch) {\n      this.queryByHook('dataset-selector').focus();\n    }\n  },\n  clear: function clear() {\n    this.needle = '';\n    this.update();\n  },\n  update: function update() {\n    // build regexp for searching\n    try {\n      var regexp = new RegExp(this.needle, 'i'); // case insensitive search\n      // search through collection, check both name and description\n\n      this.model.datasets.forEach(function (e) {\n        var hay = e.name + e.URL + e.description;\n        e.show = regexp.test(hay.toLowerCase());\n      });\n    } catch (error) {}\n  },\n  connectToServer: function connectToServer() {\n    app.me = new Spot({\n      sessionType: 'server'\n    });\n    app.message({\n      text: 'Connecting to server at ' + process.env.DB_SERVER + \":\" + process.env.DB_SERVER_PORT,\n      type: 'ok'\n    });\n    app.me.connectToServer();\n    app.me.socket.emit('getDatasets');\n    app.navigate('home');\n    setTimeout(function () {\n      app.navigate('datasets');\n    }, 100);\n  },\n  showCSVSettings: function showCSVSettings() {\n    var dialog = this.queryByHook('CSV-settings');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.showModal();\n  },\n  closeCSVSettings: function closeCSVSettings() {\n    var dialog = this.queryByHook('CSV-settings');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.close();\n  },\n  showCloudUploadInfo: function showCloudUploadInfo() {\n    var dialog = this.queryByHook('session-upload-cloud');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.showModal();\n  },\n  closeCloudUploadInfo: function closeCloudUploadInfo() {\n    var dialog = this.queryByHook('session-upload-cloud');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.close();\n  },\n  showCloudDownloadInfo: function showCloudDownloadInfo() {\n    var dialog = this.queryByHook('session-download-cloud');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.showModal();\n  },\n  closeCloudDownloadInfo: function closeCloudDownloadInfo() {\n    var dialog = this.queryByHook('session-download-cloud');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.close();\n  },\n  /////////////////////////////////////////////\n  importJSON: function importJSON() {\n    console.log('called function importJSON');\n    app.importJSON();\n  },\n  importCSV: function importCSV() {\n    console.log('called function importCSV');\n    app.importCSV();\n  },\n  getRemoteSession: function getRemoteSession() {\n    console.log('called function getRemoteSession');\n    var sessionUrl = this.queryByHook('session-import-remote-link').value; // TODO: verify the link\n\n    if (sessionUrl !== '') {\n      console.log('Downloading:', sessionUrl);\n      this.closeCloudDownloadInfo();\n      app.message({\n        text: 'Downloading the session. Please wait.',\n        type: 'ok'\n      });\n      app.importRemoteSession(sessionUrl);\n    }\n  },\n  exportSession: function exportSession() {\n    console.log('called function exportSession');\n    app.exportSession();\n  },\n  exportData: function exportData() {\n    console.log('called function exportData');\n  },\n  importLocalSession: function importLocalSession() {\n    console.log('called function importLocalSession');\n    app.importLocalSession();\n  },\n  uploadSessionZenodo: function uploadSessionZenodo() {\n    var that = this;\n    var json = app.me.toJSON();\n\n    if (app.me.sessionType === 'client') {\n      app.me.datasets.forEach(function (dataset, i) {\n        json.datasets[i].data = dataset.data;\n      });\n    }\n\n    var sessionData = new window.Blob([JSON.stringify(json)], {\n      type: 'application/json'\n    });\n    var shareLink = this.queryByHook('session-upload-cloud-link');\n    var shareDirectLink = this.queryByHook('session-upload-cloud-link-direct');\n    var fileformData = new FormData();\n    var zenodo_id = null;\n    fileformData.append(\"file\", sessionData, \"sessionfile.json\");\n    var metadata = {\n      metadata: {\n        'title': 'SPOT Session',\n        'upload_type': 'dataset',\n        'creators': [{\n          'name': 'Faruk, Diblen',\n          'affiliation': 'NLeSC'\n        }]\n      }\n    }; // console.log(\"Creating a DOI\");\n\n    app.zenodoRequest({\n      url_addition: \"\",\n      requestType: \"doi\",\n      bodyData: {}\n    }).then(function (doi_data) {\n      // console.log(\"doi_data: \", doi_data);\n      zenodo_id = doi_data.id; // console.log(\"Zenodo id:\", zenodo_id);\n      // console.log(\"Uploading file\");\n\n      app.zenodoRequest({\n        url_addition: zenodo_id + \"/files\",\n        requestType: \"upload\",\n        bodyData: fileformData\n      }).then(function (upload_data) {\n        // console.log(\"upload_data: \", upload_data);\n        // console.log(\"direct link: \", upload_data.links.download);\n        metadata.metadata = _objectSpread({}, metadata.metadata, {\n          'description': '<p><a href=\"' + \"http\" + '://' + \"127.0.0.1\" + \":\" + \"9966\" + '/#session=' + 'https://sandbox.zenodo.org/record/' + zenodo_id + '/files/sessionfile.json' + '\">Open with SPOT</a></p>' // console.log('<p><a href=\"' + process.env.PROTOCOL + '://' + process.env.BASE_URL + \":\" + process.env.PORT + '/#session=' + 'https://sandbox.zenodo.org/record/' + zenodo_id + '/files/sessionfile.json' + '\">Open with SPOT</a></p>');\n          // console.log(\"Setting the metadata\");\n\n        });\n        app.zenodoRequest({\n          url_addition: zenodo_id,\n          requestType: \"meta\",\n          bodyData: metadata\n        }).then(function (metadata_data) {\n          // console.log(\"metadata_data: \", metadata_data);\n          // console.log(\"Publishing...\");\n          app.zenodoRequest({\n            url_addition: zenodo_id + \"/actions/publish\",\n            requestType: \"publish\",\n            bodyData: {}\n          }).then(function (publish_data) {\n            // console.log(\"publish_data: \", publish_data);\n            // console.log(\"links: \", publish_data.links.record_html);\n            shareLink.value = publish_data.links.record_html;\n            shareDirectLink.value = \"http\" + '://' + \"127.0.0.1\" + \":\" + \"9966\" + '/#session=' + 'https://sandbox.zenodo.org/record/' + zenodo_id + '/files/sessionfile.json';\n            that.showCloudUploadInfo();\n          }).catch(function (error_publish) {\n            console.error(error_publish);\n          });\n        }).catch(function (error_metadata) {\n          console.error(error_metadata);\n        });\n      }).catch(function (error_upload) {\n        console.error(error_upload);\n      });\n    }).catch(function (error_doi) {\n      console.error(error_doi);\n    });\n  }\n});\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../node_modules/process/browser.js */ \"26d5\")))//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"7bdf.js","sources":["webpack:///./src/pages/datasets.js?9c37"],"sourcesContent":["var Spot = require('spot-framework');\nvar PageView = require('./base');\nvar templates = require('../templates');\nvar app = require('ampersand-app');\nvar $ = require('jquery');\n\nconst dialogPolyfill = require('dialog-polyfill');\nvar SessionModel = require('./datasets/session-model');\n\nvar DatasetCollectionView = require('./datasets/dataset-collection');\nvar SessionCollectionView = require('./datasets/session-collection');\n\nmodule.exports = PageView.extend({\n  template: templates.datasets.page,\n  initialize: function () {\n    this.pageName = 'datasets';\n    this.helpTemplate = '';\n\n\n    // // display or hide elements\n    // var serverButton = document.getElementById('serverButton-card');\n    // console.log(serverButton);\n    // if ( process.env.MODE !== 'server' ) {\n    //   // serverButton.style.display = 'inherit';\n    //   // serverButton.style.display = 'none';\n    //   // serverButton.style.display = 'inline';\n    // }\n\n\n    var localStorageDatasets = app.getDatasetsFromLocalStorage();\n    localStorageDatasets.forEach(function(dset, index) {\n      app.me.datasets.add(dset);\n      console.log(\"[\" + index + \"]: \" + dset.id + '  ', dset.name);\n    });\n\n    var localStorageSessions = app.getSessionsFromLocalStorage();\n    localStorageSessions.forEach(function(sess, index) {\n      const now = new Date();\n      var sessMod = new SessionModel({\n        id: sess.id,\n        name: 'Local session',\n        date: now.toLocaleString()\n      });\n      app.sessions.add(sessMod);\n    });\n\n  },\n  events: {\n    'change [data-hook~=json-upload-input]': 'importJSON',\n    'change [data-hook~=csv-upload-input]': 'importCSV',\n    'click [data-hook~=server-connect]': 'connectToServer',\n\n    'input [data-hook~=dataset-selector]': 'input',\n    'input [data-hook~=CSV-separator-other-input]': 'setOtherSeperator',\n    'click [data-hook~=search-button]': 'search',\n    'click [data-hook~=clear-button]': 'clear',\n\n    'click [data-hook~=CSV-settings-button]': 'showCSVSettings',\n    'click [data-hook~=CSV-settings-close]': 'closeCSVSettings',\n\n    'click [data-hook~=session-cloud-upload]': 'uploadSessionZenodo',\n    'click [data-hook~=session-cloud-download]': 'showCloudDownloadInfo',\n    'click [data-hook~=session-download]': 'exportSession',\n    'change [data-hook~=session-upload-input]': 'importLocalSession',\n    'click [data-hook~=data-download]': 'exportData',\n\n    'click [data-hook~=session-download-cloud-close-button]': 'closeCloudDownloadInfo',\n    'click [data-hook~=session-download-cloud-get]': 'getRemoteSession',\n    'click [data-hook~=session-upload-cloud-close-button]': 'closeCloudUploadInfo',\n\n    'click #CSV-separator-comma': function () { app.CSVSeparator = ','; },\n    'click #CSV-separator-colon': function () { app.CSVSeparator = ':'; },\n    'click #CSV-separator-semicolon': function () { app.CSVSeparator = ';'; },\n    'click #CSV-separator-pipe': function () { app.CSVSeparator = '|'; },\n    'click #CSV-separator-tab': function () { app.CSVSeparator = '\\t'; },\n    'click #CSV-separator-other': function () { this.el.querySelector('[data-hook~=\"CSV-separator-other-input\"]').focus(); },\n    'click #CSV-header-columns': function () { app.CSVHeaders = this.query('#CSV-header-columns').checked; },\n    'click #CSV-quote-single': function () { app.CSVQuote = '\\''; },\n    'click #CSV-quote-double': function () { app.CSVQuote = '\"'; },\n    'click #CSV-quote-none': function () { app.CSVQuote = null; },\n    'click #CSV-comment-pound': function () { app.CSVComment = '#'; },\n    'click #CSV-comment-exclamation': function () { app.CSVComment = '!'; },\n    'click #CSV-comment-slash': function () { app.CSVComment = '/'; },\n    'click #CSV-comment-dash': function () { app.CSVComment = '-'; },\n    'click #CSV-comment-percent': function () { app.CSVComment = '%'; }\n  },\n  render: function () {\n    // Reset the CSV parsing dialog.\n    // NOTE: we could do this via bindings, but this is easier (less code)\n    this.renderWithTemplate(this);\n    this.query('#CSV-header-columns').checked = app.CSVHeaders;\n\n    if (app.CSVSeparator === ',') {\n      this.query('#CSV-separator-comma').checked = true;\n    } else if (app.CSVSeparator === ':') {\n      this.query('#CSV-separator-colon').checked = true;\n    } else if (app.CSVSeparator === ';') {\n      this.query('#CSV-separator-semicolon').checked = true;\n    } else if (app.CSVSeparator === '|') {\n      this.query('#CSV-separator-pipe').checked = true;\n    } else if (app.CSVSeparator === '\\t') {\n      this.query('#CSV-separator-tab').checked = true;\n    }\n\n    if (app.CSVQuote === '\"') {\n      this.query('#CSV-quote-double').checked = true;\n    } else if (app.CSVQuote === '\\'') {\n      this.query('#CSV-quote-single').checked = true;\n    } else if (app.CSVQuote === null) {\n      this.query('#CSV-quote-none').checked = true;\n    }\n\n    if (app.CSVComment === '#') {\n      this.query('#CSV-comment-pound').checked = true;\n    } else if (app.CSVComment === '!') {\n      this.query('#CSV-comment-exclamation').checked = true;\n    } else if (app.CSVComment === '/') {\n      this.query('#CSV-comment-slash').checked = true;\n    } else if (app.CSVComment === '-') {\n      this.query('#CSV-comment-dash').checked = true;\n    } else if (app.CSVComment === 'percent') {\n      this.query('#CSV-comment-percent').checked = true;\n    }\n\n    // mdl hook ups\n    this.once('remove', function () {\n      app.me.datasets.off('add');\n    });\n    app.me.datasets.on('add', function () {\n      window.componentHandler.upgradeDom();\n    });\n    app.sessions.on('add', function () {\n      window.componentHandler.upgradeDom();\n    });\n  },\n  session: {\n    needle: 'string',\n    showSearch: 'boolean'\n  },\n  subviews: {\n    datasets: {\n      hook: 'dataset-items',\n      constructor: DatasetCollectionView\n    },\n    sessions: {\n      hook: 'session-items',\n      constructor: SessionCollectionView\n    }\n  },\n  bindings: {\n    'model.isLockedDown': {\n      type: 'toggle',\n      hook: 'add-datasets-div',\n      invert: true\n    },\n    'showSearch': {\n      type: 'toggle',\n      hook: 'search-bar'\n    },\n    'needle': {\n      type: 'value',\n      hook: 'dataset-selector'\n    }\n  },\n  input: function () {\n    var select = this.el.querySelector('[data-hook~=\"dataset-selector\"]');\n    this.needle = select.value;\n\n    this.update();\n  },\n  setOtherSeperator: function () {\n    var select = this.el.querySelector('[data-hook~=\"CSV-separator-other-input\"]');\n    app.CSVSeparator = select.value;\n  },\n  search: function () {\n    this.showSearch = !this.showSearch;\n    if (this.showSearch) {\n      this.queryByHook('dataset-selector').focus();\n    }\n  },\n  clear: function () {\n    this.needle = '';\n    this.update();\n  },\n  update: function () {\n    // build regexp for searching\n    try {\n      var regexp = new RegExp(this.needle, 'i'); // case insensitive search\n\n      // search through collection, check both name and description\n      this.model.datasets.forEach(function (e) {\n        var hay = e.name + e.URL + e.description;\n        e.show = regexp.test(hay.toLowerCase());\n      });\n    } catch (error) {\n    }\n  },\n\n  connectToServer: function () {\n    app.me = new Spot({\n      sessionType: 'server'\n    });\n    app.message({\n      text: 'Connecting to server at ' + process.env.DB_SERVER + \":\" + process.env.DB_SERVER_PORT,\n      type: 'ok'\n    });\n    app.me.connectToServer();\n    app.me.socket.emit('getDatasets');\n\n    app.navigate('home');\n    setTimeout(function () {\n      app.navigate('datasets');\n    }, 100);\n  },\n  showCSVSettings: function () {\n    var dialog = this.queryByHook('CSV-settings');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.showModal();\n  },\n  closeCSVSettings: function () {\n    var dialog = this.queryByHook('CSV-settings');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.close();\n  },\n  showCloudUploadInfo: function () {\n    var dialog = this.queryByHook('session-upload-cloud');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.showModal();\n  },\n  closeCloudUploadInfo: function () {\n    var dialog = this.queryByHook('session-upload-cloud');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.close();\n  },\n\n  showCloudDownloadInfo: function () {\n    var dialog = this.queryByHook('session-download-cloud');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.showModal();\n  },\n  closeCloudDownloadInfo: function () {\n    var dialog = this.queryByHook('session-download-cloud');\n    dialogPolyfill.registerDialog(dialog);\n    dialog.close();\n  },\n\n  /////////////////////////////////////////////\n  importJSON: function () {\n    console.log('called function importJSON');\n    app.importJSON();\n  },\n\n  importCSV: function () {\n    console.log('called function importCSV');\n    app.importCSV();\n  },\n\n  getRemoteSession: function () {\n    console.log('called function getRemoteSession');\n    var sessionUrl = this.queryByHook('session-import-remote-link').value;\n\n    // TODO: verify the link\n    if (sessionUrl !== '') {\n      console.log('Downloading:', sessionUrl);\n      this.closeCloudDownloadInfo();\n\n      app.message({\n        text: 'Downloading the session. Please wait.',\n        type: 'ok'\n      });\n\n      app.importRemoteSession(sessionUrl);\n    }\n  },\n\n\n  exportSession: function () {\n    console.log('called function exportSession');\n    app.exportSession();\n  },\n\n  exportData: function () {\n    console.log('called function exportData');\n  },\n\n  importLocalSession: function () {\n    console.log('called function importLocalSession');\n    app.importLocalSession();\n  },\n  uploadSessionZenodo: function () {\n\n    var that = this;\n\n    var json = app.me.toJSON();\n    if (app.me.sessionType === 'client') {\n      app.me.datasets.forEach(function (dataset, i) {\n        json.datasets[i].data = dataset.data;\n      });\n    }\n\n    var sessionData = new window.Blob([JSON.stringify(json)], {type: 'application/json'});\n    var shareLink = this.queryByHook('session-upload-cloud-link');\n    var shareDirectLink = this.queryByHook('session-upload-cloud-link-direct');\n\n    var fileformData = new FormData();\n    var zenodo_id = null;\n\n    fileformData.append(\"file\", sessionData, \"sessionfile.json\");\n\n    var metadata =  {\n      metadata: {\n        'title': 'SPOT Session',\n        'upload_type': 'dataset',\n        'creators': [{'name': 'Faruk, Diblen',\n        'affiliation': 'NLeSC'}]\n      }\n    };\n    \n    // console.log(\"Creating a DOI\");\n    app.zenodoRequest({\n      url_addition:\"\",\n      requestType:\"doi\",\n      bodyData:{}\n    }).then(function(doi_data) {\n\n      // console.log(\"doi_data: \", doi_data);\n      zenodo_id = doi_data.id;\n      // console.log(\"Zenodo id:\", zenodo_id);\n\n      // console.log(\"Uploading file\");\n      app.zenodoRequest({\n        url_addition:zenodo_id + \"/files\", \n        requestType:\"upload\", \n        bodyData:fileformData\n      }).then(function(upload_data) {\n      \n        // console.log(\"upload_data: \", upload_data);\n        // console.log(\"direct link: \", upload_data.links.download);\n\n        metadata.metadata = {\n          ...metadata.metadata,\n          'description': '<p><a href=\"' + process.env.PROTOCOL + '://' + process.env.BASE_URL + \":\" + process.env.PORT + '/#session=' + 'https://sandbox.zenodo.org/record/' + zenodo_id + '/files/sessionfile.json' + '\">Open with SPOT</a></p>'\n        }\n        // console.log('<p><a href=\"' + process.env.PROTOCOL + '://' + process.env.BASE_URL + \":\" + process.env.PORT + '/#session=' + 'https://sandbox.zenodo.org/record/' + zenodo_id + '/files/sessionfile.json' + '\">Open with SPOT</a></p>');\n        // console.log(\"Setting the metadata\");\n        app.zenodoRequest({\n          url_addition: zenodo_id,\n          requestType: \"meta\",\n          bodyData: metadata\n        }).then(function(metadata_data) {\n\n          // console.log(\"metadata_data: \", metadata_data);\n\n          // console.log(\"Publishing...\");\n          app.zenodoRequest({\n            url_addition: zenodo_id + \"/actions/publish\", \n            requestType: \"publish\", \n            bodyData: {}\n          }).then(function(publish_data) {\n  \n            // console.log(\"publish_data: \", publish_data);\n            // console.log(\"links: \", publish_data.links.record_html);\n            shareLink.value = publish_data.links.record_html;\n            shareDirectLink.value = process.env.PROTOCOL + '://' + process.env.BASE_URL + \":\" + process.env.PORT + '/#session=' + 'https://sandbox.zenodo.org/record/' + zenodo_id + '/files/sessionfile.json';\n            that.showCloudUploadInfo();\n          }).catch(function(error_publish){\n            console.error(error_publish);\n          });\n\n        }).catch(function(error_metadata){\n          console.error(error_metadata);\n        });\n\n      }).catch(function(error_upload){\n        console.error(error_upload);\n      });\n\n    }).catch(function(error_doi){\n      console.error(error_doi);\n    }); \n\n  },\n\n\n\n});\n\n"],"mappings":";;;;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AACA;AAAA;AAAA;AArCA;AAuCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AALA;AAUA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAVA;AAeA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AADA;AAGA;AACA;AACA;AAFA;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAFA;AAKA;AACA;AACA;AAGA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AADA;AAHA;AADA;AACA;AASA;AACA;AACA;AACA;AAHA;AAMA;AACA;AAGA;AACA;AAAA;AACA;AACA;AACA;AAHA;AAMA;AACA;AAEA;AAEA;AAGA;AACA;AANA;AAMA;AACA;AACA;AACA;AAHA;AAMA;AAEA;AACA;AACA;AACA;AACA;AAHA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAjXA;A","sourceRoot":""}\n//# sourceURL=webpack-internal:///7bdf\n")},"8ab4":function(module,exports,__webpack_require__){eval("var PageView = __webpack_require__(/*! ./base */ \"b966\");\n\nvar templates = __webpack_require__(/*! ../templates */ \"4324\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nmodule.exports = PageView.extend({\n  initialize: function initialize() {\n    this.pageName = 'home';\n    this.helpTemplate = '';\n    app.detectMobile();\n    app.startWelcome();\n  },\n  pageTitle: 'Home',\n  template: templates.home,\n  events: {\n    'click [data-hook~=demo-session]': 'demoSessionOnline'\n  },\n  bindings: {},\n  renderContent: function renderContent() {},\n  demoSessionOnline: function demoSessionOnline() {\n    app.busy({\n      enable: true\n    });\n    app.importRemoteSession('https://raw.githubusercontent.com/NLeSC/spot/master/dist/demo.json');\n    app.busy({\n      enable: false\n    });\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOGFiNC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9ob21lLmpzPzgwNzMiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFBhZ2VWaWV3ID0gcmVxdWlyZSgnLi9iYXNlJyk7XG52YXIgdGVtcGxhdGVzID0gcmVxdWlyZSgnLi4vdGVtcGxhdGVzJyk7XG52YXIgYXBwID0gcmVxdWlyZSgnYW1wZXJzYW5kLWFwcCcpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFBhZ2VWaWV3LmV4dGVuZCh7XG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnBhZ2VOYW1lID0gJ2hvbWUnO1xuICAgIHRoaXMuaGVscFRlbXBsYXRlID0gJyc7XG4gICAgYXBwLmRldGVjdE1vYmlsZSgpO1xuICAgIGFwcC5zdGFydFdlbGNvbWUoKTtcbiAgfSxcbiAgcGFnZVRpdGxlOiAnSG9tZScsXG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuaG9tZSxcbiAgZXZlbnRzOiB7XG4gICAgJ2NsaWNrIFtkYXRhLWhvb2t+PWRlbW8tc2Vzc2lvbl0nOiAnZGVtb1Nlc3Npb25PbmxpbmUnXG4gIH0sXG4gIGJpbmRpbmdzOiB7XG5cbiAgfSxcblxuICByZW5kZXJDb250ZW50OiBmdW5jdGlvbiAoKSB7XG5cbiAgfSxcbiAgZGVtb1Nlc3Npb25PbmxpbmU6IGZ1bmN0aW9uICgpIHtcbiAgICBhcHAuYnVzeSh7ZW5hYmxlOiB0cnVlfSk7XG4gICAgYXBwLmltcG9ydFJlbW90ZVNlc3Npb24oJ2h0dHBzOi8vcmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbS9OTGVTQy9zcG90L21hc3Rlci9kaXN0L2RlbW8uanNvbicpO1xuICAgIGFwcC5idXN5KHtlbmFibGU6IGZhbHNlfSk7fVxuXG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFJQTtBQUdBO0FBQ0E7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQXRCQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///8ab4\n")},"8f0f":function(module,exports,__webpack_require__){eval("/*** IMPORTS FROM imports-loader ***/\n(function() {\n\n/**\n * @classdesc network chart (sigma.js)\n * @class NetworkChart\n * @augments BaseChart\n */\nvar BaseChart = __webpack_require__(/*! ./base-chart */ \"6339\");\n\nmodule.exports = BaseChart.extend({\n  initialize: function initialize() {\n    this.slots.reset([{\n      description: 'From',\n      type: 'partition',\n      rank: 1,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'To',\n      type: 'partition',\n      rank: 2,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Relation',\n      type: 'partition',\n      rank: 3,\n      required: false,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }]);\n  },\n  sigmaConfig: function sigmaConfig() {\n    return {\n      drawEdges: true,\n      labelSize: 'proportional'\n    };\n  }\n});\n}.call(window));//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOGYwZi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9zaWdtYS5qcz9iMDEwIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGNsYXNzZGVzYyBuZXR3b3JrIGNoYXJ0IChzaWdtYS5qcylcbiAqIEBjbGFzcyBOZXR3b3JrQ2hhcnRcbiAqIEBhdWdtZW50cyBCYXNlQ2hhcnRcbiAqL1xuXG52YXIgQmFzZUNoYXJ0ID0gcmVxdWlyZSgnLi9iYXNlLWNoYXJ0Jyk7XG5cbm1vZHVsZS5leHBvcnRzID0gQmFzZUNoYXJ0LmV4dGVuZCh7XG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnNsb3RzLnJlc2V0KFtcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdGcm9tJyxcbiAgICAgICAgdHlwZTogJ3BhcnRpdGlvbicsXG4gICAgICAgIHJhbms6IDEsXG4gICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY2F0ZWdvcmlhbCcsICdkYXRldGltZScsICdkdXJhdGlvbicsICdjb250aW51b3VzJywgJ3RleHQnXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdUbycsXG4gICAgICAgIHR5cGU6ICdwYXJ0aXRpb24nLFxuICAgICAgICByYW5rOiAyLFxuICAgICAgICByZXF1aXJlZDogdHJ1ZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NhdGVnb3JpYWwnLCAnZGF0ZXRpbWUnLCAnZHVyYXRpb24nLCAnY29udGludW91cycsICd0ZXh0J11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnUmVsYXRpb24nLFxuICAgICAgICB0eXBlOiAncGFydGl0aW9uJyxcbiAgICAgICAgcmFuazogMyxcbiAgICAgICAgcmVxdWlyZWQ6IGZhbHNlLFxuICAgICAgICBzdXBwb3J0ZWRGYWNldHM6IFsnY2F0ZWdvcmlhbCcsICdkYXRldGltZScsICdkdXJhdGlvbicsICdjb250aW51b3VzJywgJ3RleHQnXVxuICAgICAgfVxuICAgIF0pO1xuICB9LFxuICBzaWdtYUNvbmZpZzogZnVuY3Rpb24gKCkge1xuICAgIHJldHVybiB7XG4gICAgICBkcmF3RWRnZXM6IHRydWUsXG4gICAgICBsYWJlbFNpemU6ICdwcm9wb3J0aW9uYWwnXG4gICAgfTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiI7OztBQUFBOzs7OztBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQS9CQTtBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///8f0f\n")},9218:function(module,exports,__webpack_require__){eval("function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\nvar Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar Router = __webpack_require__(/*! ./router */ \"aa00\");\n\nvar MainView = __webpack_require__(/*! ./pages/main */ \"3f86\");\n\nvar DatasetsView = __webpack_require__(/*! ./pages/datasets */ \"7bdf\");\n\nvar domReady = __webpack_require__(/*! domready */ \"3ca4\");\n\nvar widgetFactory = __webpack_require__(/*! ./widgets/widget-factory */ \"f2bc\");\n\nvar viewFactory = __webpack_require__(/*! ./widgets/view-factory */ \"a6e8\");\n\nvar Collection = __webpack_require__(/*! ampersand-collection */ \"7bd3\");\n\nvar SessionModel = __webpack_require__(/*! ./pages/datasets/session-model */ \"bdff\");\n\nvar dialogPolyfill = __webpack_require__(/*! dialog-polyfill */ \"5c00\");\n\nvar Help = __webpack_require__(/*! intro.js */ \"0444\");\n\nvar templates = __webpack_require__(/*! ./templates */ \"4324\");\n\nvar csv = __webpack_require__(/*! csv */ \"00a7\");\n\nvar $ = __webpack_require__(/*! jquery */ \"802c\");\n\n__webpack_require__(/*! babel-polyfill */ \"a26e\");\n\n__webpack_require__(/*! mdl */ \"9d69\");\n\nvar sessionCollection = Collection.extend({\n  mainIndex: 'id',\n  indexes: ['name'],\n  model: SessionModel\n}); // attach our app to `window` so we can\n// easily access it from the console.\n\nwindow.app = app; // Extends our main app singleton\n\napp.extend({\n  /**\n   * [fullscreenMode description]\n   * @type {Boolean}\n   */\n  fullscreenMode: false,\n\n  /**\n   * [demoSession description]\n   * @type {Boolean}\n   */\n  demoSession: false,\n\n  /**\n   * [mobileBrowser description]\n   * @type {Boolean}\n   */\n  mobileBrowser: false,\n\n  /**\n   * [me description]\n   * @type {Spot}\n   */\n  me: new Spot(),\n\n  /**\n   * [widgetFactory description]\n   * @type {any}\n   */\n  widgetFactory: widgetFactory,\n\n  /**\n   * [viewFactory description]\n   * @type {any}\n   */\n  viewFactory: viewFactory,\n\n  /**\n   * [router description]\n   * @type {Router}\n   */\n  router: new Router(),\n\n  /**\n   * [CSVSeparator description]\n   * @type {String}\n   */\n  CSVSeparator: ',',\n\n  /**\n   * [CSVHeaders description]\n   * @type {Boolean}\n   */\n  CSVHeaders: true,\n\n  /**\n   * [CSVQuote description]\n   * @type {String}\n   */\n  CSVQuote: '\"',\n\n  /**\n   * [CSVComment description]\n   * @type {String}\n   */\n  CSVComment: '#',\n  helper: {\n    enabled: false,\n    instance: new Help()\n  },\n\n  /**\n   * [sessions description]\n   * @type {any}\n   */\n  sessions: new sessionCollection(),\n\n  /**\n   * This is where it all starts\n   */\n  init: function init() {\n    // Create and attach our main view\n    this.mainView = new MainView({\n      model: this.me,\n      el: document.body\n    }); // this kicks off our backbutton tracking (browser history)\n    // and will cause the first matching handler in the router\n    // to fire.\n\n    this.router.history.start({\n      root: '/',\n      pushState: true,\n      hashChange: true\n    });\n  },\n\n  /**\n   * This is a helper for navigating around the app.\n     this gets called by a global click handler that handles\n     all the <a> tags in the app.\n     it expects a url pathname for example: \"/costello/settings\"\n   * @param  {any} page [description]\n   */\n  navigate: function navigate(page) {\n    // clean all help items before navigating to new page\n    app.stopHelp();\n    var url = page.charAt(0) === '/' ? page.slice(1) : page;\n    this.router.history.navigate(url, {\n      trigger: true\n    });\n  },\n\n  /**\n   * [description]\n   * @param  {any} percentage [description]\n   */\n  progress: function progress(percentage) {\n    var progressBar = document.getElementById('progress-bar');\n    progressBar.MaterialProgress.setProgress(percentage);\n    progressBar.style.display = 'inherit';\n  },\n\n  /**\n   * [description]\n   * @param  {boolean} status [description]\n   */\n  busy: function busy(callBack) {\n    var that = this;\n    var dialog = document.getElementById('main-dialog');\n    dialogPolyfill.registerDialog(dialog);\n    console.log(dialog);\n    dialog.open = !dialog.open;\n    console.log(dialog);\n  },\n\n  /**\n   * [description]\n   * @param  {any} options [description]\n   */\n  message: function message(options) {\n    var snackbarContainer = document.getElementById('snack-bar');\n    var snackData = {\n      message: options.text\n    }; // BUGFIX: during app initialization, the snackbar is not always ready yet\n\n    if (!snackbarContainer.MaterialSnackbar) {\n      return;\n    }\n\n    var progressBar = document.getElementById('progress-bar');\n    progressBar.style.display = 'none';\n\n    if (options.type === 'error') {\n      console.warn(options.text, options.error);\n      snackData.timeout = 10000; // show error for 10 seconds\n    } else {\n      console.log(options.text);\n      snackData.timeout = 2750;\n    }\n\n    snackbarContainer.MaterialSnackbar.showSnackbar(snackData);\n  },\n\n  /**\n   * [description]\n   */\n  startHelp: function startHelp() {\n    console.log(app.currentPage.helpTemplate);\n    console.log(app.currentPage.helpHints);\n    console.log(app.currentPage.helpSteps);\n\n    if ((!app.currentPage.helpTemplate || app.currentPage.helpTemplate === '') && (!app.currentPage.helpHints || app.currentPage.helpHints() === []) && (!app.currentPage.helpSteps || app.currentPage.helpTemplate === [])) {\n      console.log('No Help item was found for this page! Exiting.');\n      return;\n    }\n\n    console.log(app.helper.enabled);\n\n    if (app.helper.enabled) {\n      console.log('Closing existing help!');\n      app.stopHelp();\n      return;\n    }\n\n    app.helper.enabled = true;\n    console.log(\"app.helper: \", app.helper);\n\n    if (app.currentPage.helpTemplate && app.currentPage.helpTemplate !== '') {\n      console.log(\"Setting intros...\");\n      app.helper.instance.setOptions({\n        steps: [{\n          intro: window[app.currentPage.helpTemplate]()\n        }]\n      });\n    }\n\n    app.helper.instance.setOptions({\n      hints: app.currentPage.helpHints(),\n      steps: app.currentPage.helpSteps()\n    });\n    app.helper.instance.onhintsadded(function () {\n      console.log('all hints added');\n    });\n    app.helper.instance.onhintclick(function (hintElement, item, stepId) {\n      console.log('hint clicked', hintElement, item, stepId);\n    });\n    app.helper.instance.onhintclose(function (stepId) {\n      console.log('hint closed', stepId);\n    });\n    app.helper.instance.addHints();\n    app.helper.instance.showHints(); // app.helper.start();\n  },\n  stopHelp: function stopHelp() {\n    if (app.helper.enabled) {\n      console.log('Closing existing help!'); // app.helper.instance.helper.exit();\n\n      app.helper.instance.hideHints();\n      app.helper.enabled = false;\n      return;\n    }\n  },\n\n  /**\n   * [description]\n   */\n  startWelcome: function startWelcome() {\n    var welcome = Help();\n    welcome.setOption('tooltipClass', 'welcome-dialog');\n    welcome.setOptions({\n      'showStepNumbers': false,\n      'showBullets': false,\n      'showProgress': false,\n      'skipLabel': 'Exit',\n      'doneLabel': 'Start demo',\n      'tooltipPosition': 'auto',\n      steps: [{\n        intro: templates.help.welcome()\n      }]\n    });\n    welcome.onchange(function (targetElement) {\n      if (this._currentStep === this._introItems.length - 1) {\n        $('.introjs-skipbutton').css('color', 'green');\n      }\n    });\n    welcome.oncomplete(function () {\n      window.localStorage.setItem('spotWelcome', 'done');\n      app.message({\n        text: 'Starting the demo session.',\n        type: 'ok'\n      });\n      app.importRemoteSession('https://raw.githubusercontent.com/NLeSC/spot/master/dist/demo.json');\n    }); // add a flag when we exit\n\n    welcome.onexit(function () {\n      window.localStorage.setItem('spotWelcome', 'done');\n    });\n    var spotWelcome = window.localStorage.getItem('spotWelcome') === 'done';\n\n    if (spotWelcome) {// console.log('No need to show welcome dialog again.');\n    } else {\n      console.log('Starting the welcome dialog.');\n      welcome.start();\n    }\n  },\n\n  /**\n   * [description]\n   * @return {boolean} [description]\n   */\n  detectMobile: function detectMobile() {\n    var check = false;\n\n    if (navigator.userAgent.match(/Android/i) || navigator.userAgent.match(/webOS/i) || navigator.userAgent.match(/iPhone/i) || navigator.userAgent.match(/iPad/i) || navigator.userAgent.match(/iPod/i) || navigator.userAgent.match(/BlackBerry/i) || navigator.userAgent.match(/Windows Phone/i)) {\n      check = true;\n    } else {\n      check = false;\n    }\n\n    app.mobileBrowser = check;\n    return check;\n  },\n\n  /**\n   * [description]\n   * @return {} [description]\n   */\n  addDatasetToLocalStorage: function addDatasetToLocalStorage(dataset) {\n    console.log('Adding a dataset to the local storage');\n    console.log(dataset);\n    var allDatasets = this.getDatasetsFromLocalStorage(); // allDatasets.forEach(function(dset, index) {\n    //   console.log(\"[\" + index + \"]: \" + dset.id + '  ', dset.name);\n    // });\n\n    allDatasets.push(dataset);\n    localStorage.setItem('datasets', JSON.stringify(allDatasets));\n  },\n\n  /**\n  * [description]\n  * @return {} [description]\n  */\n  removeDatasetFromLocalStorage: function removeDatasetFromLocalStorage(dataset) {\n    console.log('Removing a dataset from the local storage');\n    console.log(dataset);\n    var allDatasets = this.getDatasetsFromLocalStorage();\n    allDatasets.forEach(function (dset, index) {\n      console.log(\"[\" + index + \"]: \" + dset.id + '  ', dset.name);\n      if (dataset.id === dset.id) allDatasets.splice(index, 1);\n    }); // var index = allDatasets.indexOf(dataset);\n    // if (index > -1) {\n    //   allDatasets.splice(index, 1);\n    // }\n\n    localStorage.setItem('datasets', allDatasets);\n  },\n\n  /**\n  * [description]\n  * @return {} [description]\n  */\n  getDatasetsFromLocalStorage: function getDatasetsFromLocalStorage() {\n    console.log('Getting a list of datasets from the local storage');\n    var allDatasets = JSON.parse(localStorage.getItem('datasets') || \"[]\");\n    return allDatasets;\n  },\n\n  /**\n   * [description]\n   * @return {} [description]\n   */\n  addSessionToLocalStorage: function addSessionToLocalStorage(session) {\n    console.log('Adding a session to the local storage');\n    console.log(session);\n    var allSessions = this.getSessionsFromLocalStorage(); // allDatasets.forEach(function(dset, index) {\n    //   console.log(\"[\" + index + \"]: \" + dset.id + '  ', dset.name);\n    // });\n\n    allSessions.push(session);\n    localStorage.setItem('sessions', JSON.stringify(allSessions));\n  },\n\n  /**\n  * [description]\n  * @return {} [description]\n  */\n  removeSessionFromLocalStorage: function removeSessionFromLocalStorage(input_session) {\n    console.log('Removing a session from the local storage');\n    console.log(input_session);\n    var allSessions = this.getSessionsFromLocalStorage();\n    allSessions.forEach(function (sess, index) {\n      console.log(\"[\" + index + \"]: \" + sess.id + '  ', sess.name);\n      if (input_session.id === sess.id) allSessions.splice(index, 1);\n    });\n    localStorage.setItem('sessions', allSessions);\n  },\n\n  /**\n  * [description]\n  * @return {} [description]\n  */\n  getSessionsFromLocalStorage: function getSessionsFromLocalStorage() {\n    console.log('Getting a list of sessions from the local storage');\n    var allSessions = JSON.parse(localStorage.getItem('sessions') || \"[]\");\n    return allSessions;\n  },\n  getCurrentSession: function getCurrentSession() {\n    var json = app.me.toJSON();\n\n    if (app.me.sessionType === 'client') {\n      // for client datasets, also save the data in the session file\n      app.me.datasets.forEach(function (dataset, i) {\n        json.datasets[i].data = dataset.data;\n      });\n    } // json.saveDate = Date().toLocaleString();\n\n\n    var currentSession = json;\n    return currentSession;\n  },\n  saveCurrentSession: function saveCurrentSession() {\n    var currentSession = this.getCurrentSession();\n    this.addSessionToLocalStorage(currentSession);\n  },\n  importRemoteSession: function importRemoteSession(sessionUrl) {\n    // console.log('app.js: Getting the remote session.');\n    var that = this;\n    app.busy({\n      enable: true\n    });\n    var urlParts = sessionUrl.replace('http://', '').replace('https://', '').split(/[/?#]/);\n    var domain = urlParts[0];\n\n    if (domain === \"sandbox.zenodo.org\" || domain === \"zenodo.org\") {\n      // get files using a proxy to fix CORS issues\n      sessionUrl = 'http://localhost:8000/' + sessionUrl;\n    }\n\n    that.zenodoRequest({\n      base_url: sessionUrl,\n      url_addition: \"\",\n      requestType: \"download\",\n      zenodoId: '',\n      fileHash: ''\n    }).then(function (download_data) {\n      // console.log(download_data);\n      app.busy({\n        enable: false\n      });\n      app.message({\n        text: 'Session was imported succesfully',\n        type: 'ok'\n      });\n      app.loadSessionBlob(download_data);\n    }).catch(function (error_download) {\n      app.busy({\n        enable: false\n      });\n      app.message({\n        text: 'Could not import the session',\n        type: 'error',\n        error: ev\n      });\n      console.error(error_download);\n    });\n  },\n\n  /**\n   * [description]\n   * @param  {any} data [description]\n   */\n  loadSessionBlob: function loadSessionBlob(data) {\n    console.log('Loading the session.');\n    app.me = new Spot(data);\n\n    if (data.sessionType === 'server') {\n      app.me.connectToServer(data.address);\n    } else if (data.sessionType === 'client') {\n      // add data from the session file to the dataset\n      data.datasets.forEach(function (d, i) {\n        app.me.datasets.models[i].crossfilter.add(d.data);\n        app.me.datasets.models[i].isActive = false; // we'll turn it on later\n      }); // merge all the data into the app.me.dataview\n      // by toggling the active datasets back on\n\n      data.datasets.forEach(function (d, i) {\n        if (d.isActive) {\n          app.me.toggleDataset(app.me.datasets.models[i]);\n        }\n      });\n    } // and automatically go to the analyze page\n\n\n    app.navigate('/analyze');\n    app.navigate('/datasets');\n    app.navigate('/analyze');\n  },\n  importJSON: function importJSON() {\n    // var fileLoader = this.queryByHook('json-upload-input');\n    var fileLoader = document.getElementById('jsonuploadBtn');\n    var uploadedFile = fileLoader.files[0];\n    var reader = new window.FileReader();\n    var dataURL = fileLoader.files[0].name; // TODO: enforce spot.driver === 'client'\n\n    var dataset = app.me.datasets.add({\n      name: dataURL,\n      URL: dataURL,\n      description: 'uploaded JSON file'\n    });\n\n    reader.onload = function (ev) {\n      app.message({\n        text: 'Processing',\n        type: 'ok'\n      });\n\n      try {\n        dataset.data = JSON.parse(ev.target.result); // automatically analyze dataset\n\n        dataset.scan();\n        dataset.facets.forEach(function (facet, i) {\n          if (i < 20) {\n            facet.isActive = true;\n\n            if (facet.isCategorial) {\n              facet.setCategories();\n            } else if (facet.isContinuous || facet.isDatetime || facet.isDuration) {\n              facet.setMinMax();\n            }\n          }\n        });\n        app.message({\n          text: dataURL + ' was uploaded succesfully. Configured ' + dataset.facets.length + ' facets',\n          type: 'ok'\n        });\n        window.componentHandler.upgradeDom(); // Automatically activate dataset if it is the only one\n\n        if (app.me.datasets.length === 1) {\n          $('.mdl-switch').click(); // only way to get the switch in the 'on' position\n        }\n      } catch (ev) {\n        app.me.datasets.remove(dataset);\n        app.message({\n          text: 'Error parsing JSON file: ' + ev,\n          type: 'error',\n          error: ev\n        });\n      }\n    };\n\n    reader.onerror = function (ev) {\n      var error = ev.srcElement.error;\n      app.message({\n        text: 'File loading problem: ' + error,\n        type: 'error',\n        error: ev\n      });\n    };\n\n    reader.onprogress = function (ev) {\n      if (ev.lengthComputable) {\n        // ev.loaded and ev.total are ProgressEvent properties\n        app.progress(parseInt(100.0 * ev.loaded / ev.total));\n      }\n    };\n\n    reader.readAsText(uploadedFile);\n  },\n  importCSV: function importCSV() {\n    // var fileLoader = this.queryByHook('csv-upload-input');\n    var fileLoader = document.getElementById('csvuploadBtn');\n    var uploadedFile = fileLoader.files[0];\n    var reader = new window.FileReader();\n    var dataURL = fileLoader.files[0].name; // TODO: enforce spot.driver === 'client'\n\n    var dataset = app.me.datasets.add({\n      name: dataURL,\n      URL: dataURL,\n      description: 'Imported CSV file'\n    });\n\n    reader.onload = function (ev) {\n      app.message({\n        text: 'Processing',\n        type: 'ok'\n      });\n      var options = {\n        columns: app.CSVHeaders,\n        // treat first line as header with column names\n        relax_column_count: false,\n        // accept malformed lines\n        delimiter: app.CSVSeparator,\n        // field delimieter\n        quote: app.CSVQuote,\n        // String quoting character\n        comment: app.CSVComment,\n        // Treat all the characters after this one as a comment.\n        trim: true // ignore white space around delimiter\n\n      };\n      csv.parse(ev.target.result, options, function (err, data) {\n        if (err) {\n          app.me.datasets.remove(dataset);\n          app.message({\n            text: 'Error parsing CSV file: ' + err.message,\n            type: 'error',\n            error: ev\n          });\n        } else {\n          dataset.data = data; // automatically analyze dataset\n\n          dataset.scan();\n          dataset.facets.forEach(function (facet, i) {\n            if (i < 20) {\n              facet.isActive = true;\n\n              if (facet.isCategorial) {\n                facet.setCategories();\n              } else if (facet.isContinuous || facet.isDatetime || facet.isDuration) {\n                facet.setMinMax();\n              }\n            }\n          });\n          app.addDatasetToLocalStorage(dataset);\n          app.message({\n            text: dataURL + ' was uploaded succesfully. Configured ' + dataset.facets.length + ' facets',\n            type: 'ok'\n          });\n          window.componentHandler.upgradeDom(); // Automatically activate dataset if it is the only one\n\n          if (app.me.datasets.length === 1) {\n            $('.mdl-switch').click(); // only way to get the switch in the 'on' position\n          }\n        }\n      });\n    };\n\n    reader.onerror = function (ev) {\n      app.me.datasets.remove(dataset);\n      app.message({\n        text: 'File loading problem: ' + reader.error,\n        type: 'error',\n        error: reader.error\n      });\n    };\n\n    reader.onprogress = function (ev) {\n      if (ev.lengthComputable) {\n        // ev.loaded and ev.total are ProgressEvent properties\n        app.progress(parseInt(100.0 * ev.loaded / ev.total));\n      }\n    };\n\n    reader.readAsText(uploadedFile);\n  },\n  exportSession: function exportSession() {\n    var json = app.me.toJSON();\n\n    if (app.me.sessionType === 'client') {\n      // for client datasets, also save the data in the session file\n      app.me.datasets.forEach(function (dataset, i) {\n        json.datasets[i].data = dataset.data;\n      });\n    }\n\n    var blob = new window.Blob([JSON.stringify(json)], {\n      type: 'application/json'\n    });\n    var url = window.URL.createObjectURL(blob);\n    var element = document.createElement('a');\n    element.download = 'session.json';\n    element.href = url;\n    element.click();\n    window.URL.revokeObjectURL(url);\n  },\n  exportData: function exportData() {\n    var chartsData = [];\n    var partitionRankToName = {\n      1: 'a',\n      2: 'b',\n      3: 'c',\n      4: 'd'\n    };\n    var aggregateRankToName = {\n      1: 'aa',\n      2: 'bb',\n      3: 'cc',\n      4: 'dd',\n      5: 'ee'\n    };\n    app.me.dataview.filters.forEach(function (filter) {\n      var map = {};\n      var axis = [];\n      filter.partitions.forEach(function (partition) {\n        map[partitionRankToName[partition.rank]] = partition.facetName;\n        axis.push(partition.facetName);\n      });\n      filter.aggregates.forEach(function (aggregate) {\n        map[aggregateRankToName[aggregate.rank]] = aggregate.operation + ' ' + aggregate.facetName;\n      });\n      map['count'] = 'count';\n      var data = [];\n      filter.data.forEach(function (d) {\n        var mapped = {};\n        Object.keys(d).forEach(function (k) {\n          if (map[k]) {\n            mapped[map[k]] = d[k];\n          }\n        });\n        data.push(mapped);\n      });\n      chartsData.push({\n        chartType: filter.chartType,\n        axis: axis.join(','),\n        data: data\n      });\n    });\n    var blob = new window.Blob([JSON.stringify(chartsData)], {\n      type: 'application/json'\n    });\n    var url = window.URL.createObjectURL(blob);\n    var element = document.createElement('a');\n    element.download = 'data.json';\n    element.href = url;\n    element.click();\n    window.URL.revokeObjectURL(url);\n  },\n  importLocalSession: function importLocalSession() {\n    // var fileLoader = this.queryByHook('session-upload-input');\n    var fileLoader = document.getElementById('sessionuploadBtn');\n    var uploadedFile = fileLoader.files[0];\n    var reader = new window.FileReader();\n\n    reader.onload = function (ev) {\n      var data = JSON.parse(ev.target.result);\n      app.loadSessionBlob(data);\n      app.message({\n        text: 'Session \"' + uploadedFile.name + '\" was uploaded succesfully',\n        type: 'ok'\n      });\n    };\n\n    reader.onerror = function (ev) {\n      app.message({\n        text: 'Could not load Session \"' + uploadedFile.name + '\"',\n        type: 'error',\n        error: ev\n      });\n    };\n\n    reader.readAsText(uploadedFile);\n  },\n  zenodoRequest: function () {\n    var _zenodoRequest = _asyncToGenerator(\n    /*#__PURE__*/\n    regeneratorRuntime.mark(function _callee(zenodoParams) {\n      var url_addition, requestType, bodyData, base_url, zenodoToken, url, params, request_options, response, data;\n      return regeneratorRuntime.wrap(function _callee$(_context) {\n        while (1) {\n          switch (_context.prev = _context.next) {\n            case 0:\n              url_addition = zenodoParams.url_addition;\n              requestType = zenodoParams.requestType;\n              bodyData = zenodoParams.bodyData; // console.log('requestType:', requestType);\n\n              base_url = new URL(\"https://sandbox.zenodo.org/api/deposit/depositions\");\n\n              if (zenodoParams.base_url) {\n                base_url = zenodoParams.base_url;\n              }\n\n              zenodoToken = \"AddYourTokenHere\";\n\n              if (url_addition) {\n                // console.log(\" Addition is provided: \", url_addition);\n                base_url = base_url + \"/\" + url_addition;\n              }\n\n              url = new URL(base_url), params = {\n                access_token: zenodoToken\n              };\n              Object.keys(params).forEach(function (key) {\n                url.searchParams.append(key, params[key]);\n              }); // console.log('Zenodo base_url:', base_url);\n              // console.log('Zenodo url:', url);\n\n              request_options = {};\n\n              if (requestType === \"doi\") {\n                request_options = {\n                  cache: \"no-cache\",\n                  method: \"POST\",\n                  headers: {\n                    \"Content-Type\": \"application/json\"\n                  },\n                  body: JSON.stringify(bodyData)\n                };\n              } else if (requestType === \"upload\") {\n                request_options = {\n                  cache: \"no-cache\",\n                  method: \"POST\",\n                  body: bodyData\n                };\n              } else if (requestType === \"publish\") {\n                request_options = {\n                  cache: \"no-cache\",\n                  method: \"POST\"\n                };\n              } else if (requestType === \"meta\") {\n                request_options = {\n                  cache: \"no-cache\",\n                  method: \"PUT\",\n                  headers: {\n                    \"Content-Type\": \"application/json\"\n                  },\n                  body: JSON.stringify(bodyData)\n                };\n              } else if (requestType === \"download\") {\n                request_options = {\n                  cache: \"no-cache\",\n                  method: \"GET\",\n                  withCredentials: true\n                };\n              } else {\n                console.error('Unknown method');\n              } // console.log('request_options: ', request_options);\n\n\n              _context.next = 13;\n              return fetch(url, request_options);\n\n            case 13:\n              response = _context.sent;\n              _context.next = 16;\n              return response.json();\n\n            case 16:\n              data = _context.sent;\n              return _context.abrupt(\"return\", data);\n\n            case 18:\n            case \"end\":\n              return _context.stop();\n          }\n        }\n      }, _callee);\n    }));\n\n    function zenodoRequest(_x) {\n      return _zenodoRequest.apply(this, arguments);\n    }\n\n    return zenodoRequest;\n  }()\n});\n/**\n * run it on domReady\n */\n\ndomReady(function () {\n  app.init();\n\n  if (false) {}\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"9218.js","sources":["webpack:///./src/app.js?1112"],"sourcesContent":["var Spot = require('spot-framework');\nvar app = require('ampersand-app');\nvar Router = require('./router');\nvar MainView = require('./pages/main');\nvar DatasetsView = require('./pages/datasets');\nvar domReady = require('domready');\nvar widgetFactory = require('./widgets/widget-factory');\nvar viewFactory = require('./widgets/view-factory');\nvar Collection = require('ampersand-collection');\n\nvar SessionModel = require('./pages/datasets/session-model');\nvar dialogPolyfill = require('dialog-polyfill');\n\nvar Help = require('intro.js');\nvar templates = require('./templates');\nvar csv = require('csv');\nvar $ = require('jquery');\n\nrequire('babel-polyfill');\nrequire('mdl');\n\nvar sessionCollection = Collection.extend({\n  mainIndex: 'id',\n  indexes: ['name'],\n  model: SessionModel\n});\n\n// attach our app to `window` so we can\n// easily access it from the console.\nwindow.app = app;\n\n// Extends our main app singleton\napp.extend({\n  /**\n   * [fullscreenMode description]\n   * @type {Boolean}\n   */\n  fullscreenMode: false,\n  /**\n   * [demoSession description]\n   * @type {Boolean}\n   */\n  demoSession: false,\n  /**\n   * [mobileBrowser description]\n   * @type {Boolean}\n   */\n  mobileBrowser: false,\n  /**\n   * [me description]\n   * @type {Spot}\n   */\n  me: new Spot(),\n  /**\n   * [widgetFactory description]\n   * @type {any}\n   */\n  widgetFactory: widgetFactory,\n  /**\n   * [viewFactory description]\n   * @type {any}\n   */\n  viewFactory: viewFactory,\n  /**\n   * [router description]\n   * @type {Router}\n   */\n  router: new Router(),\n  /**\n   * [CSVSeparator description]\n   * @type {String}\n   */\n  CSVSeparator: ',',\n  /**\n   * [CSVHeaders description]\n   * @type {Boolean}\n   */\n  CSVHeaders: true,\n  /**\n   * [CSVQuote description]\n   * @type {String}\n   */\n  CSVQuote: '\"',\n  /**\n   * [CSVComment description]\n   * @type {String}\n   */\n  CSVComment: '#',\n\n  helper: {enabled: false, instance: new Help()},\n\n  /**\n   * [sessions description]\n   * @type {any}\n   */\n  sessions: new sessionCollection(),\n  /**\n   * This is where it all starts\n   */\n  init: function () {\n    // Create and attach our main view\n    this.mainView = new MainView({\n      model: this.me,\n      el: document.body\n    });\n\n    // this kicks off our backbutton tracking (browser history)\n    // and will cause the first matching handler in the router\n    // to fire.\n    this.router.history.start({\n      root: '/',\n      pushState: true,\n      hashChange: true\n    });\n  },\n  /**\n   * This is a helper for navigating around the app.\n     this gets called by a global click handler that handles\n     all the <a> tags in the app.\n     it expects a url pathname for example: \"/costello/settings\"\n   * @param  {any} page [description]\n   */\n  navigate: function (page) {\n\n    // clean all help items before navigating to new page\n    app.stopHelp();\n\n    var url = (page.charAt(0) === '/') ? page.slice(1) : page;\n    this.router.history.navigate(url, {\n      trigger: true\n    });\n  },\n  /**\n   * [description]\n   * @param  {any} percentage [description]\n   */\n  progress: function (percentage) {\n    var progressBar = document.getElementById('progress-bar');\n    progressBar.MaterialProgress.setProgress(percentage);\n\n    progressBar.style.display = 'inherit';\n  },\n  /**\n   * [description]\n   * @param  {boolean} status [description]\n   */\n  busy: function (callBack) {\n    var that = this;\n\n    var dialog = document.getElementById('main-dialog');\n    dialogPolyfill.registerDialog(dialog);\n\n    console.log(dialog);\n    dialog.open = !dialog.open;\n    console.log(dialog);\n  },\n  /**\n   * [description]\n   * @param  {any} options [description]\n   */\n  message: function (options) {\n    var snackbarContainer = document.getElementById('snack-bar');\n    var snackData = { message: options.text };\n\n    // BUGFIX: during app initialization, the snackbar is not always ready yet\n    if (!snackbarContainer.MaterialSnackbar) {\n      return;\n    }\n\n    var progressBar = document.getElementById('progress-bar');\n    progressBar.style.display = 'none';\n\n    if (options.type === 'error') {\n      console.warn(options.text, options.error);\n      snackData.timeout = 10000; // show error for 10 seconds\n    } else {\n      console.log(options.text);\n      snackData.timeout = 2750;\n    }\n    snackbarContainer.MaterialSnackbar.showSnackbar(snackData);\n  },\n\n  /**\n   * [description]\n   */\n  startHelp: function () {\n\n    console.log(app.currentPage.helpTemplate);\n    console.log(app.currentPage.helpHints);\n    console.log(app.currentPage.helpSteps);\n    if (\n      (!app.currentPage.helpTemplate || app.currentPage.helpTemplate === '') &&\n      (!app.currentPage.helpHints || app.currentPage.helpHints() === []) &&\n      (!app.currentPage.helpSteps || app.currentPage.helpTemplate === [])\n    ) {\n      console.log('No Help item was found for this page! Exiting.')\n      return;\n    }\n\n    console.log(app.helper.enabled);\n\n    if (app.helper.enabled) {\n      console.log('Closing existing help!');\n      app.stopHelp();\n      return;\n    }\n\n    app.helper.enabled = true;\n\n    console.log(\"app.helper: \", app.helper);\n\n    if (app.currentPage.helpTemplate && app.currentPage.helpTemplate !== '') {\n      console.log(\"Setting intros...\");\n      app.helper.instance.setOptions({\n        steps: [\n          {\n            intro: window[app.currentPage.helpTemplate]()\n          }\n        ]\n      });\n    }\n\n    app.helper.instance.setOptions({\n      hints: app.currentPage.helpHints(),\n      steps: app.currentPage.helpSteps()\n    });\n\n    app.helper.instance.onhintsadded(function() {\n        console.log('all hints added');\n    });\n    app.helper.instance.onhintclick(function(hintElement, item, stepId) {\n        console.log('hint clicked', hintElement, item, stepId);\n    });\n    app.helper.instance.onhintclose(function (stepId) {\n        console.log('hint closed', stepId);\n    });\n\n    app.helper.instance.addHints();\n    app.helper.instance.showHints();\n    // app.helper.start();\n  },\n  stopHelp: function () {\n    if (app.helper.enabled) {\n      console.log('Closing existing help!');\n      // app.helper.instance.helper.exit();\n      app.helper.instance.hideHints();\n      app.helper.enabled = false;\n      return;\n    }\n  },\n  /**\n   * [description]\n   */\n  startWelcome: function () {\n    var welcome = Help();\n    welcome.setOption('tooltipClass', 'welcome-dialog');\n    welcome.setOptions({\n      'showStepNumbers': false,\n      'showBullets': false,\n      'showProgress': false,\n      'skipLabel': 'Exit',\n      'doneLabel': 'Start demo',\n      'tooltipPosition': 'auto',\n      steps: [\n        {\n          intro: templates.help.welcome()\n        }\n      ]\n    });\n\n    welcome.onchange(function (targetElement) {\n      if (this._currentStep === this._introItems.length - 1) {\n        $('.introjs-skipbutton').css('color', 'green');\n      }\n    });\n\n    welcome.oncomplete(function () {\n      window.localStorage.setItem('spotWelcome', 'done');\n      app.message({\n        text: 'Starting the demo session.',\n        type: 'ok'\n      });\n      app.importRemoteSession('https://raw.githubusercontent.com/NLeSC/spot/master/dist/demo.json');\n    });\n\n    // add a flag when we exit\n    welcome.onexit(function () {\n      window.localStorage.setItem('spotWelcome', 'done');\n    });\n\n    var spotWelcome = window.localStorage.getItem('spotWelcome') === 'done';\n    if (spotWelcome) {\n      // console.log('No need to show welcome dialog again.');\n    } else {\n      console.log('Starting the welcome dialog.');\n      welcome.start();\n    }\n  },\n  /**\n   * [description]\n   * @return {boolean} [description]\n   */\n  detectMobile: function () {\n    var check = false;\n    if (navigator.userAgent.match(/Android/i) ||\n    navigator.userAgent.match(/webOS/i) ||\n    navigator.userAgent.match(/iPhone/i) ||\n    navigator.userAgent.match(/iPad/i) ||\n    navigator.userAgent.match(/iPod/i) ||\n    navigator.userAgent.match(/BlackBerry/i) ||\n    navigator.userAgent.match(/Windows Phone/i)\n   ) {\n      check = true;\n    } else {\n      check = false;\n    }\n    app.mobileBrowser = check;\n    return check;\n  },\n\n  /**\n   * [description]\n   * @return {} [description]\n   */\n  addDatasetToLocalStorage: function(dataset) {\n    console.log('Adding a dataset to the local storage');\n    console.log(dataset);\n    var allDatasets = this.getDatasetsFromLocalStorage();\n    // allDatasets.forEach(function(dset, index) {\n    //   console.log(\"[\" + index + \"]: \" + dset.id + '  ', dset.name);\n    // });\n    allDatasets.push(dataset);\n    localStorage.setItem('datasets', JSON.stringify(allDatasets));\n  },\n    /**\n   * [description]\n   * @return {} [description]\n   */\n  removeDatasetFromLocalStorage: function(dataset) {\n    console.log('Removing a dataset from the local storage');\n    console.log(dataset);\n    var allDatasets = this.getDatasetsFromLocalStorage();\n    allDatasets.forEach(function(dset, index) {\n      console.log(\"[\" + index + \"]: \" + dset.id + '  ', dset.name);\n      if ( dataset.id === dset.id )\n        allDatasets.splice(index, 1);\n    });\n    // var index = allDatasets.indexOf(dataset);\n    // if (index > -1) {\n    //   allDatasets.splice(index, 1);\n    // }\n    localStorage.setItem('datasets', allDatasets);\n  },\n    /**\n   * [description]\n   * @return {} [description]\n   */\n  getDatasetsFromLocalStorage: function() {\n    console.log('Getting a list of datasets from the local storage');\n    var allDatasets = JSON.parse(localStorage.getItem('datasets') || \"[]\");\n    return allDatasets;\n  },\n  /**\n   * [description]\n   * @return {} [description]\n   */\n  addSessionToLocalStorage: function(session) {\n    console.log('Adding a session to the local storage');\n    console.log(session);\n    var allSessions = this.getSessionsFromLocalStorage();\n    // allDatasets.forEach(function(dset, index) {\n    //   console.log(\"[\" + index + \"]: \" + dset.id + '  ', dset.name);\n    // });\n    allSessions.push(session);\n    localStorage.setItem('sessions', JSON.stringify(allSessions));\n  },\n    /**\n   * [description]\n   * @return {} [description]\n   */\n  removeSessionFromLocalStorage: function(input_session) {\n    console.log('Removing a session from the local storage');\n    console.log(input_session);\n    var allSessions = this.getSessionsFromLocalStorage();\n    allSessions.forEach(function(sess, index) {\n      console.log(\"[\" + index + \"]: \" + sess.id + '  ', sess.name);\n      if ( input_session.id === sess.id )\n        allSessions.splice(index, 1);\n    });\n\n    localStorage.setItem('sessions', allSessions);\n  },\n    /**\n   * [description]\n   * @return {} [description]\n   */\n  getSessionsFromLocalStorage: function() {\n    console.log('Getting a list of sessions from the local storage');\n    var allSessions = JSON.parse(localStorage.getItem('sessions') || \"[]\");\n    return allSessions;\n  },\n  getCurrentSession: function () {\n    var json = app.me.toJSON();\n    if (app.me.sessionType === 'client') {\n      // for client datasets, also save the data in the session file\n      app.me.datasets.forEach(function (dataset, i) {\n        json.datasets[i].data = dataset.data;\n      });\n    }\n    // json.saveDate = Date().toLocaleString();\n    var currentSession = json;\n    return currentSession;\n  },\n  saveCurrentSession: function () {\n    var currentSession = this.getCurrentSession();\n    this.addSessionToLocalStorage(currentSession);\n  },\n  importRemoteSession: function (sessionUrl) {\n    // console.log('app.js: Getting the remote session.');\n    var that = this;\n\n    app.busy({enable: true});\n\n    var urlParts = sessionUrl.replace('http://','').replace('https://','').split(/[/?#]/);\n    var domain = urlParts[0];\n\n    if ( (domain === \"sandbox.zenodo.org\") || (domain === \"zenodo.org\") ) {\n      // get files using a proxy to fix CORS issues\n      sessionUrl = 'http://localhost:8000/' + sessionUrl;\n    }\n\n    that.zenodoRequest({\n      base_url: sessionUrl,\n      url_addition:\"\",\n      requestType:\"download\",\n      zenodoId: '',\n      fileHash: ''\n    }).then(function(download_data) {\n      // console.log(download_data);\n      app.busy({enable: false});\n      app.message({\n        text: 'Session was imported succesfully',\n        type: 'ok'\n      });\n      app.loadSessionBlob(download_data);\n    }).catch(function(error_download){\n      app.busy({enable: false});\n      app.message({\n        text: 'Could not import the session',\n        type: 'error',\n        error: ev\n      });\n      console.error(error_download);\n    });\n\n  },\n  /**\n   * [description]\n   * @param  {any} data [description]\n   */\n  loadSessionBlob: function (data) {\n    console.log('Loading the session.');\n    app.me = new Spot(data);\n\n    if (data.sessionType === 'server') {\n      app.me.connectToServer(data.address);\n    } else if (data.sessionType === 'client') {\n      // add data from the session file to the dataset\n      data.datasets.forEach(function (d, i) {\n        app.me.datasets.models[i].crossfilter.add(d.data);\n        app.me.datasets.models[i].isActive = false; // we'll turn it on later\n      });\n      // merge all the data into the app.me.dataview\n      // by toggling the active datasets back on\n      data.datasets.forEach(function (d, i) {\n        if (d.isActive) {\n          app.me.toggleDataset(app.me.datasets.models[i]);\n        }\n      });\n    }\n    // and automatically go to the analyze page\n    app.navigate('/analyze');    \n    app.navigate('/datasets');\n    app.navigate('/analyze');\n  },\n  importJSON: function () {\n    // var fileLoader = this.queryByHook('json-upload-input');\n    var fileLoader = document.getElementById('jsonuploadBtn');\n    var uploadedFile = fileLoader.files[0];\n    var reader = new window.FileReader();\n    var dataURL = fileLoader.files[0].name;\n\n    // TODO: enforce spot.driver === 'client'\n\n    var dataset = app.me.datasets.add({\n      name: dataURL,\n      URL: dataURL,\n      description: 'uploaded JSON file'\n    });\n\n    reader.onload = function (ev) {\n      app.message({\n        text: 'Processing',\n        type: 'ok'\n      });\n      try {\n        dataset.data = JSON.parse(ev.target.result);\n\n        // automatically analyze dataset\n        dataset.scan();\n        dataset.facets.forEach(function (facet, i) {\n          if (i < 20) {\n            facet.isActive = true;\n\n            if (facet.isCategorial) {\n              facet.setCategories();\n            } else if (facet.isContinuous || facet.isDatetime || facet.isDuration) {\n              facet.setMinMax();\n            }\n          }\n        });\n        app.message({\n          text: dataURL + ' was uploaded succesfully. Configured ' + dataset.facets.length + ' facets',\n          type: 'ok'\n        });\n        window.componentHandler.upgradeDom();\n\n        // Automatically activate dataset if it is the only one\n        if (app.me.datasets.length === 1) {\n          $('.mdl-switch').click(); // only way to get the switch in the 'on' position\n        }\n      } catch (ev) {\n        app.me.datasets.remove(dataset);\n        app.message({\n          text: 'Error parsing JSON file: ' + ev,\n          type: 'error',\n          error: ev\n        });\n      }\n    };\n\n    reader.onerror = function (ev) {\n      var error = ev.srcElement.error;\n\n      app.message({\n        text: 'File loading problem: ' + error,\n        type: 'error',\n        error: ev\n      });\n    };\n\n    reader.onprogress = function (ev) {\n      if (ev.lengthComputable) {\n        // ev.loaded and ev.total are ProgressEvent properties\n        app.progress(parseInt(100.0 * ev.loaded / ev.total));\n      }\n    };\n\n    reader.readAsText(uploadedFile);\n  },\n  importCSV: function () {\n    // var fileLoader = this.queryByHook('csv-upload-input');\n    var fileLoader = document.getElementById('csvuploadBtn');\n    var uploadedFile = fileLoader.files[0];\n    var reader = new window.FileReader();\n    var dataURL = fileLoader.files[0].name;\n\n    // TODO: enforce spot.driver === 'client'\n\n    var dataset = app.me.datasets.add({\n      name: dataURL,\n      URL: dataURL,\n      description: 'Imported CSV file'\n    });\n\n    reader.onload = function (ev) {\n      app.message({\n        text: 'Processing',\n        type: 'ok'\n      });\n      var options = {\n        columns: app.CSVHeaders, // treat first line as header with column names\n        relax_column_count: false, // accept malformed lines\n        delimiter: app.CSVSeparator, // field delimieter\n        quote: app.CSVQuote, // String quoting character\n        comment: app.CSVComment, // Treat all the characters after this one as a comment.\n        trim: true // ignore white space around delimiter\n      };\n\n      csv.parse(ev.target.result, options, function (err, data) {\n        if (err) {\n          app.me.datasets.remove(dataset);\n          app.message({\n            text: 'Error parsing CSV file: ' + err.message,\n            type: 'error',\n            error: ev\n          });\n        } else {\n          dataset.data = data;\n\n          // automatically analyze dataset\n          dataset.scan();\n          dataset.facets.forEach(function (facet, i) {\n            if (i < 20) {\n              facet.isActive = true;\n\n              if (facet.isCategorial) {\n                facet.setCategories();\n              } else if (facet.isContinuous || facet.isDatetime || facet.isDuration) {\n                facet.setMinMax();\n              }\n            }\n          });\n          app.addDatasetToLocalStorage(dataset);\n          app.message({\n            text: dataURL + ' was uploaded succesfully. Configured ' + dataset.facets.length + ' facets',\n            type: 'ok'\n          });\n          window.componentHandler.upgradeDom();\n\n          // Automatically activate dataset if it is the only one\n          if (app.me.datasets.length === 1) {\n            $('.mdl-switch').click(); // only way to get the switch in the 'on' position\n          }\n        }\n      });\n    };\n\n    reader.onerror = function (ev) {\n      app.me.datasets.remove(dataset);\n      app.message({\n        text: 'File loading problem: ' + reader.error,\n        type: 'error',\n        error: reader.error\n      });\n    };\n\n    reader.onprogress = function (ev) {\n      if (ev.lengthComputable) {\n        // ev.loaded and ev.total are ProgressEvent properties\n        app.progress(parseInt(100.0 * ev.loaded / ev.total));\n      }\n    };\n\n    reader.readAsText(uploadedFile);\n  },\n  exportSession: function () {\n    var json = app.me.toJSON();\n\n    if (app.me.sessionType === 'client') {\n      // for client datasets, also save the data in the session file\n      app.me.datasets.forEach(function (dataset, i) {\n        json.datasets[i].data = dataset.data;\n      });\n    }\n    var blob = new window.Blob([JSON.stringify(json)], {type: 'application/json'});\n    var url = window.URL.createObjectURL(blob);\n\n    var element = document.createElement('a');\n    element.download = 'session.json';\n    element.href = url;\n    element.click();\n\n    window.URL.revokeObjectURL(url);\n  },\n  exportData: function () {\n    var chartsData = [];\n\n    var partitionRankToName = {1: 'a', 2: 'b', 3: 'c', 4: 'd'};\n    var aggregateRankToName = {1: 'aa', 2: 'bb', 3: 'cc', 4: 'dd', 5: 'ee'};\n\n    app.me.dataview.filters.forEach(function (filter) {\n      var map = {};\n      var axis = [];\n      filter.partitions.forEach(function (partition) {\n        map[partitionRankToName[partition.rank]] = partition.facetName;\n        axis.push(partition.facetName);\n      });\n      filter.aggregates.forEach(function (aggregate) {\n        map[aggregateRankToName[aggregate.rank]] = aggregate.operation + ' ' + aggregate.facetName;\n      });\n      map['count'] = 'count';\n\n      var data = [];\n      filter.data.forEach(function (d) {\n        var mapped = {};\n        Object.keys(d).forEach(function (k) {\n          if (map[k]) {\n            mapped[map[k]] = d[k];\n          }\n        });\n        data.push(mapped);\n      });\n      chartsData.push({\n        chartType: filter.chartType,\n        axis: axis.join(','),\n        data: data\n      });\n    });\n\n    var blob = new window.Blob([JSON.stringify(chartsData)], {type: 'application/json'});\n    var url = window.URL.createObjectURL(blob);\n\n    var element = document.createElement('a');\n    element.download = 'data.json';\n    element.href = url;\n    element.click();\n\n    window.URL.revokeObjectURL(url);\n  },\n  importLocalSession: function () {\n    // var fileLoader = this.queryByHook('session-upload-input');\n    var fileLoader = document.getElementById('sessionuploadBtn');\n    var uploadedFile = fileLoader.files[0];\n    var reader = new window.FileReader();\n\n    reader.onload = function (ev) {\n      var data = JSON.parse(ev.target.result);\n      app.loadSessionBlob(data);\n      app.message({\n        text: 'Session \"' + uploadedFile.name + '\" was uploaded succesfully',\n        type: 'ok'\n      });\n    };\n\n    reader.onerror = function (ev) {\n      app.message({\n        text: 'Could not load Session \"' + uploadedFile.name + '\"',\n        type: 'error',\n        error: ev\n      });\n    };\n\n    reader.readAsText(uploadedFile);\n  },\n  zenodoRequest: async function(zenodoParams) {\n\n    var url_addition = zenodoParams.url_addition;\n    var requestType = zenodoParams.requestType;\n    var bodyData = zenodoParams.bodyData;\n    // console.log('requestType:', requestType);\n\n    var base_url = new URL(\"https://sandbox.zenodo.org/api/deposit/depositions\");\n\n    if (zenodoParams.base_url){\n      base_url = zenodoParams.base_url;\n    }\n\n    var zenodoToken = process.env.ZENODO_TOKEN;\n    if (url_addition) {\n      // console.log(\" Addition is provided: \", url_addition);\n      base_url = base_url + \"/\" + url_addition;\n    }\n    var url = new URL(base_url),\n    params = {\n      access_token: zenodoToken\n    };\n    Object.keys(params).forEach(function(key){\n      url.searchParams.append(key, params[key]);\n    });\n\n    // console.log('Zenodo base_url:', base_url);\n    // console.log('Zenodo url:', url);\n\n    var request_options = {};\n\n    if (requestType === \"doi\") {\n      request_options = {\n        cache: \"no-cache\",\n        method: \"POST\",\n        headers: {\n          \"Content-Type\": \"application/json\",\n        },\n        body: JSON.stringify(bodyData)\n      }\n    }\n    else if (requestType === \"upload\") {\n      request_options = {\n        cache: \"no-cache\",\n        method: \"POST\",\n        body: bodyData\n      }\n    }\n    else if (requestType === \"publish\") {\n      request_options = {\n        cache: \"no-cache\",\n        method: \"POST\",\n      }\n    }\n    else if (requestType === \"meta\") {\n      request_options = {\n        cache: \"no-cache\",\n        method: \"PUT\",\n        headers: {\n          \"Content-Type\": \"application/json\"\n        },\n        body: JSON.stringify(bodyData)\n      }\n    }\n    else if (requestType === \"download\") {\n      request_options = {\n        cache: \"no-cache\",\n        method: \"GET\",\n        withCredentials: true,\n      }\n    }\n    else {\n      console.error('Unknown method');\n    }\n\n    // console.log('request_options: ', request_options);\n\n    var response = await fetch(url, request_options);\n    var data = await response.json();\n    return data;\n  }\n});\n\n/**\n * run it on domReady\n */\ndomReady(function () {\n  app.init();\n\n  if ( process.env.MODE === 'server' ) {\n    console.log('connecting to database at', process.env.DB_SERVER + \":\" + process.env.DB_SERVER_PORT);\n    app.me.isLockedDown = true;\n    app.me.connectToServer(process.env.DB_SERVER + \":\" + process.env.DB_SERVER_PORT);\n    app.me.socket.emit('getDatasets');\n  }\n});\n\n"],"mappings":";;;;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAHA;AAOA;AACA;AAAA;AACA;AAEA;AACA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AACA;AAAA;;;;AAIA;AAEA;AAAA;AAAA;AAAA;AACA;AACA;;;;AAIA;AACA;AAAA;;;AAGA;AACA;AACA;AACA;AACA;AAFA;AAMA;AACA;AACA;AAAA;AACA;AACA;AACA;AAHA;AAKA;AACA;AAAA;;;;;;;AAOA;AAEA;AACA;AAEA;AACA;AACA;AADA;AAGA;AACA;AAAA;;;;AAIA;AACA;AACA;AAEA;AACA;AACA;AAAA;;;;AAIA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;;;;AAIA;AACA;AACA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;;;AAGA;AAEA;AACA;AACA;AACA;AAAA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AADA;AAFA;AAOA;AACA;AACA;AACA;AACA;AAFA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AADA;AARA;AAcA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;;;;AAIA;AACA;AACA;AAAA;AAQA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;;;;AAIA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AAAA;;;;AAIA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAAA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AALA;AAOA;AACA;AAAA;AAAA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AAEA;AACA;AAAA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AAHA;AACA;AAKA;AACA;AACA;AACA;AAFA;AACA;AAGA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AAHA;AACA;AAKA;AACA;AACA;AACA;AAFA;AAIA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AAPA;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AAEA;AADA;AAGA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AANA;AAQA;AAEA;AACA;AACA;AACA;AAHA;AAKA;AAEA;AACA;AACA;AAFA;AAIA;AAEA;AACA;AACA;AACA;AACA;AADA;AAGA;AANA;AAQA;AAEA;AACA;AACA;AACA;AAHA;AAKA;AAEA;AACA;AACA;AACA;AA3EA;AAAA;AACA;AADA;AA6EA;AA7EA;AAAA;AACA;AADA;AA8EA;AA9EA;AACA;AADA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AADA;AAAA;AAAA;AACA;AADA;AAAA;AA/rBA;AAkxBA;;;;AAGA;AACA;AACA;AACA,eAKA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///9218\n")},"96da":function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar CategorialRuleView = __webpack_require__(/*! ./categorial-rule */ \"c783\");\n\nmodule.exports = View.extend({\n  template: templates.configureFacet.facetTransformCategorial,\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.renderCollection(this.model.rules, CategorialRuleView, this.queryByHook('categorial-rules-table'));\n    return this;\n  },\n  events: {\n    'click [data-hook~=categorial-addone-button]': function clickDataHookCategorialAddoneButton() {\n      this.model.rules.add({});\n    },\n    'click [data-hook~=categorial-removeall-button]': function clickDataHookCategorialRemoveallButton() {\n      this.model.reset();\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOTZkYS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQvZmFjZXQtdHJhbnNmb3JtLWNhdGVnb3JpYWwuanM/ZmJlMyJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgVmlldyA9IHJlcXVpcmUoJ2FtcGVyc2FuZC12aWV3Jyk7XG52YXIgdGVtcGxhdGVzID0gcmVxdWlyZSgnLi4vLi4vdGVtcGxhdGVzJyk7XG5cbnZhciBDYXRlZ29yaWFsUnVsZVZpZXcgPSByZXF1aXJlKCcuL2NhdGVnb3JpYWwtcnVsZScpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFZpZXcuZXh0ZW5kKHtcbiAgdGVtcGxhdGU6IHRlbXBsYXRlcy5jb25maWd1cmVGYWNldC5mYWNldFRyYW5zZm9ybUNhdGVnb3JpYWwsXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVuZGVyV2l0aFRlbXBsYXRlKHRoaXMpO1xuICAgIHRoaXMucmVuZGVyQ29sbGVjdGlvbih0aGlzLm1vZGVsLnJ1bGVzLCBDYXRlZ29yaWFsUnVsZVZpZXcsIHRoaXMucXVlcnlCeUhvb2soJ2NhdGVnb3JpYWwtcnVsZXMtdGFibGUnKSk7XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfSxcbiAgZXZlbnRzOiB7XG4gICAgJ2NsaWNrIFtkYXRhLWhvb2t+PWNhdGVnb3JpYWwtYWRkb25lLWJ1dHRvbl0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLnJ1bGVzLmFkZCh7fSk7XG4gICAgfSxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349Y2F0ZWdvcmlhbC1yZW1vdmVhbGwtYnV0dG9uXSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMubW9kZWwucmVzZXQoKTtcbiAgICB9XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTkE7QUFSQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///96da\n")},"9ae5":function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar TimePartsSelect = __webpack_require__(/*! ./time-parts-select */ \"c678\");\n\nvar TimeZonesSelect = __webpack_require__(/*! ./time-zones-select */ \"f3d5\");\n\nvar DurationUnitsSelect = __webpack_require__(/*! ./duration-units-select */ \"4916\");\n\nmodule.exports = View.extend({\n  template: templates.configureFacet.facetTransformDatetime,\n  bindings: {\n    'model.transformedZone': {\n      type: 'value',\n      hook: 'transform-time-zone-input'\n    },\n    'model.transformedReference': {\n      type: 'value',\n      hook: 'transform-time-reference-input'\n    }\n  },\n  events: {\n    'change [data-hook~=transform-time-zone-input]': function changeDataHookTransformTimeZoneInput() {\n      this.model.zone = this.queryByHook('transform-time-zone-input').value;\n    },\n    'change [data-hook~=transform-time-format-input]': function changeDataHookTransformTimeFormatInput() {\n      this.model.format = this.queryByHook('transform-time-format-input').value;\n    },\n    'change [data-hook~=transform-time-transformedzone-input]': function changeDataHookTransformTimeTransformedzoneInput() {\n      this.model.transformedZone = this.queryByHook('transform-time-transformedzone-input').value;\n    },\n    'change [data-hook~=transform-time-transformedformat-input]': function changeDataHookTransformTimeTransformedformatInput() {\n      this.model.transformedFormat = this.queryByHook('transform-time-transformedformat-input').value;\n    },\n    'change [data-hook~=transform-time-transformedreference-input]': function changeDataHookTransformTimeTransformedreferenceInput() {\n      this.model.transformedReference = this.queryByHook('transform-time-transformedreference-input').value;\n    },\n    'change [data-hook~=transform-time-transformedunits-input]': function changeDataHookTransformTimeTransformedunitsInput() {\n      this.model.transformedReference = this.queryByHook('transform-time-transformedunits-input').value;\n    }\n  },\n  subviews: {\n    timeParts: {\n      hook: 'time-parts',\n      prepareView: function prepareView(el) {\n        return new TimePartsSelect({\n          el: el,\n          model: this.model\n        });\n      }\n    },\n    timeZones: {\n      hook: 'time-zones',\n      prepareView: function prepareView(el) {\n        return new TimeZonesSelect({\n          el: el,\n          field: 'zone',\n          model: this.model\n        });\n      }\n    },\n    transformedTimeZones: {\n      hook: 'transformed-time-zones',\n      prepareView: function prepareView(el) {\n        return new TimeZonesSelect({\n          el: el,\n          field: 'transformedZone',\n          model: this.model\n        });\n      }\n    },\n    transformedTimeUnits: {\n      hook: 'transformed-time-units',\n      constructor: DurationUnitsSelect\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOWFlNS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQvZmFjZXQtdHJhbnNmb3JtLWRhdGV0aW1lLmpzPzA4NjAiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xudmFyIFRpbWVQYXJ0c1NlbGVjdCA9IHJlcXVpcmUoJy4vdGltZS1wYXJ0cy1zZWxlY3QnKTtcbnZhciBUaW1lWm9uZXNTZWxlY3QgPSByZXF1aXJlKCcuL3RpbWUtem9uZXMtc2VsZWN0Jyk7XG52YXIgRHVyYXRpb25Vbml0c1NlbGVjdCA9IHJlcXVpcmUoJy4vZHVyYXRpb24tdW5pdHMtc2VsZWN0Jyk7XG5cbm1vZHVsZS5leHBvcnRzID0gVmlldy5leHRlbmQoe1xuICB0ZW1wbGF0ZTogdGVtcGxhdGVzLmNvbmZpZ3VyZUZhY2V0LmZhY2V0VHJhbnNmb3JtRGF0ZXRpbWUsXG4gIGJpbmRpbmdzOiB7XG4gICAgJ21vZGVsLnRyYW5zZm9ybWVkWm9uZSc6IHtcbiAgICAgIHR5cGU6ICd2YWx1ZScsXG4gICAgICBob29rOiAndHJhbnNmb3JtLXRpbWUtem9uZS1pbnB1dCdcbiAgICB9LFxuICAgICdtb2RlbC50cmFuc2Zvcm1lZFJlZmVyZW5jZSc6IHtcbiAgICAgIHR5cGU6ICd2YWx1ZScsXG4gICAgICBob29rOiAndHJhbnNmb3JtLXRpbWUtcmVmZXJlbmNlLWlucHV0J1xuICAgIH1cbiAgfSxcbiAgZXZlbnRzOiB7XG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj10cmFuc2Zvcm0tdGltZS16b25lLWlucHV0XSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMubW9kZWwuem9uZSA9IHRoaXMucXVlcnlCeUhvb2soJ3RyYW5zZm9ybS10aW1lLXpvbmUtaW5wdXQnKS52YWx1ZTtcbiAgICB9LFxuICAgICdjaGFuZ2UgW2RhdGEtaG9va349dHJhbnNmb3JtLXRpbWUtZm9ybWF0LWlucHV0XSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMubW9kZWwuZm9ybWF0ID0gdGhpcy5xdWVyeUJ5SG9vaygndHJhbnNmb3JtLXRpbWUtZm9ybWF0LWlucHV0JykudmFsdWU7XG4gICAgfSxcbiAgICAnY2hhbmdlIFtkYXRhLWhvb2t+PXRyYW5zZm9ybS10aW1lLXRyYW5zZm9ybWVkem9uZS1pbnB1dF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLnRyYW5zZm9ybWVkWm9uZSA9IHRoaXMucXVlcnlCeUhvb2soJ3RyYW5zZm9ybS10aW1lLXRyYW5zZm9ybWVkem9uZS1pbnB1dCcpLnZhbHVlO1xuICAgIH0sXG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj10cmFuc2Zvcm0tdGltZS10cmFuc2Zvcm1lZGZvcm1hdC1pbnB1dF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLnRyYW5zZm9ybWVkRm9ybWF0ID0gdGhpcy5xdWVyeUJ5SG9vaygndHJhbnNmb3JtLXRpbWUtdHJhbnNmb3JtZWRmb3JtYXQtaW5wdXQnKS52YWx1ZTtcbiAgICB9LFxuICAgICdjaGFuZ2UgW2RhdGEtaG9va349dHJhbnNmb3JtLXRpbWUtdHJhbnNmb3JtZWRyZWZlcmVuY2UtaW5wdXRdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5tb2RlbC50cmFuc2Zvcm1lZFJlZmVyZW5jZSA9IHRoaXMucXVlcnlCeUhvb2soJ3RyYW5zZm9ybS10aW1lLXRyYW5zZm9ybWVkcmVmZXJlbmNlLWlucHV0JykudmFsdWU7XG4gICAgfSxcbiAgICAnY2hhbmdlIFtkYXRhLWhvb2t+PXRyYW5zZm9ybS10aW1lLXRyYW5zZm9ybWVkdW5pdHMtaW5wdXRdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5tb2RlbC50cmFuc2Zvcm1lZFJlZmVyZW5jZSA9IHRoaXMucXVlcnlCeUhvb2soJ3RyYW5zZm9ybS10aW1lLXRyYW5zZm9ybWVkdW5pdHMtaW5wdXQnKS52YWx1ZTtcbiAgICB9XG4gIH0sXG4gIHN1YnZpZXdzOiB7XG4gICAgdGltZVBhcnRzOiB7XG4gICAgICBob29rOiAndGltZS1wYXJ0cycsXG4gICAgICBwcmVwYXJlVmlldzogZnVuY3Rpb24gKGVsKSB7XG4gICAgICAgIHJldHVybiBuZXcgVGltZVBhcnRzU2VsZWN0KHtcbiAgICAgICAgICBlbDogZWwsXG4gICAgICAgICAgbW9kZWw6IHRoaXMubW9kZWxcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgICB0aW1lWm9uZXM6IHtcbiAgICAgIGhvb2s6ICd0aW1lLXpvbmVzJyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBUaW1lWm9uZXNTZWxlY3Qoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBmaWVsZDogJ3pvbmUnLFxuICAgICAgICAgIG1vZGVsOiB0aGlzLm1vZGVsXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH0sXG4gICAgdHJhbnNmb3JtZWRUaW1lWm9uZXM6IHtcbiAgICAgIGhvb2s6ICd0cmFuc2Zvcm1lZC10aW1lLXpvbmVzJyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBUaW1lWm9uZXNTZWxlY3Qoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBmaWVsZDogJ3RyYW5zZm9ybWVkWm9uZScsXG4gICAgICAgICAgbW9kZWw6IHRoaXMubW9kZWxcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgICB0cmFuc2Zvcm1lZFRpbWVVbml0czoge1xuICAgICAgaG9vazogJ3RyYW5zZm9ybWVkLXRpbWUtdW5pdHMnLFxuICAgICAgY29uc3RydWN0b3I6IER1cmF0aW9uVW5pdHNTZWxlY3RcbiAgICB9XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBRkE7QUFMQTtBQVVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBbEJBO0FBb0JBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQVBBO0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUtBO0FBUkE7QUFVQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBS0E7QUFSQTtBQVVBO0FBQ0E7QUFDQTtBQUZBO0FBOUJBO0FBaENBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///9ae5\n")},"9cb1":function(module,exports,__webpack_require__){eval("/**\n * @classdesc line chart class\n * @class LineChart\n * @augments BaseChart\n */\nvar BaseChart = __webpack_require__(/*! ./base-chart */ \"6339\");\n\nvar moment = __webpack_require__(/*! moment-timezone */ \"6c9d\");\n\nmodule.exports = BaseChart.extend({\n  initialize: function initialize() {\n    this.slots.reset([{\n      description: 'X axis',\n      type: 'partition',\n      rank: 1,\n      required: true,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Group by',\n      type: 'partition',\n      rank: 2,\n      required: false,\n      supportedFacets: ['categorial', 'datetime', 'duration', 'continuous', 'text']\n    }, {\n      description: 'Y axis',\n      type: 'aggregate',\n      rank: 1,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }, {\n      description: 'X error',\n      type: 'aggregate',\n      rank: 2,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }, {\n      description: 'Y error',\n      type: 'aggregate',\n      rank: 3,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }, {\n      description: 'Second Y axis',\n      type: 'aggregate',\n      rank: 4,\n      required: false,\n      supportedFacets: ['continuous', 'duration']\n    }]);\n  },\n  chartjsConfig: function chartjsConfig() {\n    return {\n      type: 'lineError',\n      data: {\n        datasets: [],\n        labels: []\n      },\n      options: {\n        title: {\n          display: true,\n          position: 'top'\n        },\n        scales: {\n          xAxes: [{\n            type: 'linear',\n            position: 'bottom',\n            scaleLabel: {\n              display: true\n            },\n            time: {\n              parser: function parser(label) {\n                return moment(label, moment.ISO_8601);\n              }\n            }\n          }],\n          yAxes: [{\n            type: 'linear',\n            display: true,\n            position: 'left',\n            id: 'first-scale'\n          }, {\n            type: 'linear',\n            display: false,\n            position: 'right',\n            id: 'second-scale'\n          }, {\n            type: 'linear',\n            display: false,\n            position: 'right',\n            id: 'selection-scale',\n            ticks: {\n              min: 0,\n              max: 1\n            }\n          }]\n        },\n        tooltips: {}\n      }\n    };\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiOWNiMS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9saW5lY2hhcnQuanM/ZGM2MSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBjbGFzc2Rlc2MgbGluZSBjaGFydCBjbGFzc1xuICogQGNsYXNzIExpbmVDaGFydFxuICogQGF1Z21lbnRzIEJhc2VDaGFydFxuICovXG52YXIgQmFzZUNoYXJ0ID0gcmVxdWlyZSgnLi9iYXNlLWNoYXJ0Jyk7XG52YXIgbW9tZW50ID0gcmVxdWlyZSgnbW9tZW50LXRpbWV6b25lJyk7XG5cbm1vZHVsZS5leHBvcnRzID0gQmFzZUNoYXJ0LmV4dGVuZCh7XG4gIGluaXRpYWxpemU6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnNsb3RzLnJlc2V0KFtcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdYIGF4aXMnLFxuICAgICAgICB0eXBlOiAncGFydGl0aW9uJyxcbiAgICAgICAgcmFuazogMSxcbiAgICAgICAgcmVxdWlyZWQ6IHRydWUsXG4gICAgICAgIHN1cHBvcnRlZEZhY2V0czogWydjYXRlZ29yaWFsJywgJ2RhdGV0aW1lJywgJ2R1cmF0aW9uJywgJ2NvbnRpbnVvdXMnLCAndGV4dCddXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICBkZXNjcmlwdGlvbjogJ0dyb3VwIGJ5JyxcbiAgICAgICAgdHlwZTogJ3BhcnRpdGlvbicsXG4gICAgICAgIHJhbms6IDIsXG4gICAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NhdGVnb3JpYWwnLCAnZGF0ZXRpbWUnLCAnZHVyYXRpb24nLCAnY29udGludW91cycsICd0ZXh0J11cbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnWSBheGlzJyxcbiAgICAgICAgdHlwZTogJ2FnZ3JlZ2F0ZScsXG4gICAgICAgIHJhbms6IDEsXG4gICAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NvbnRpbnVvdXMnLCAnZHVyYXRpb24nXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdYIGVycm9yJyxcbiAgICAgICAgdHlwZTogJ2FnZ3JlZ2F0ZScsXG4gICAgICAgIHJhbms6IDIsXG4gICAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NvbnRpbnVvdXMnLCAnZHVyYXRpb24nXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdZIGVycm9yJyxcbiAgICAgICAgdHlwZTogJ2FnZ3JlZ2F0ZScsXG4gICAgICAgIHJhbms6IDMsXG4gICAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NvbnRpbnVvdXMnLCAnZHVyYXRpb24nXVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdTZWNvbmQgWSBheGlzJyxcbiAgICAgICAgdHlwZTogJ2FnZ3JlZ2F0ZScsXG4gICAgICAgIHJhbms6IDQsXG4gICAgICAgIHJlcXVpcmVkOiBmYWxzZSxcbiAgICAgICAgc3VwcG9ydGVkRmFjZXRzOiBbJ2NvbnRpbnVvdXMnLCAnZHVyYXRpb24nXVxuICAgICAgfVxuICAgIF0pO1xuICB9LFxuICBjaGFydGpzQ29uZmlnOiBmdW5jdGlvbiAoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHR5cGU6ICdsaW5lRXJyb3InLFxuICAgICAgZGF0YToge1xuICAgICAgICBkYXRhc2V0czogW10sXG4gICAgICAgIGxhYmVsczogW11cbiAgICAgIH0sXG4gICAgICBvcHRpb25zOiB7XG4gICAgICAgIHRpdGxlOiB7XG4gICAgICAgICAgZGlzcGxheTogdHJ1ZSxcbiAgICAgICAgICBwb3NpdGlvbjogJ3RvcCdcbiAgICAgICAgfSxcbiAgICAgICAgc2NhbGVzOiB7XG4gICAgICAgICAgeEF4ZXM6IFt7XG4gICAgICAgICAgICB0eXBlOiAnbGluZWFyJyxcbiAgICAgICAgICAgIHBvc2l0aW9uOiAnYm90dG9tJyxcbiAgICAgICAgICAgIHNjYWxlTGFiZWw6IHtcbiAgICAgICAgICAgICAgZGlzcGxheTogdHJ1ZVxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHRpbWU6IHtcbiAgICAgICAgICAgICAgcGFyc2VyOiBmdW5jdGlvbiAobGFiZWwpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gbW9tZW50KGxhYmVsLCBtb21lbnQuSVNPXzg2MDEpO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfV0sXG4gICAgICAgICAgeUF4ZXM6IFtcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgdHlwZTogJ2xpbmVhcicsXG4gICAgICAgICAgICAgIGRpc3BsYXk6IHRydWUsXG4gICAgICAgICAgICAgIHBvc2l0aW9uOiAnbGVmdCcsXG4gICAgICAgICAgICAgIGlkOiAnZmlyc3Qtc2NhbGUnXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICB0eXBlOiAnbGluZWFyJyxcbiAgICAgICAgICAgICAgZGlzcGxheTogZmFsc2UsXG4gICAgICAgICAgICAgIHBvc2l0aW9uOiAncmlnaHQnLFxuICAgICAgICAgICAgICBpZDogJ3NlY29uZC1zY2FsZSdcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIHR5cGU6ICdsaW5lYXInLFxuICAgICAgICAgICAgICBkaXNwbGF5OiBmYWxzZSxcbiAgICAgICAgICAgICAgcG9zaXRpb246ICdyaWdodCcsXG4gICAgICAgICAgICAgIGlkOiAnc2VsZWN0aW9uLXNjYWxlJyxcbiAgICAgICAgICAgICAgdGlja3M6IHtcbiAgICAgICAgICAgICAgICBtaW46IDAsXG4gICAgICAgICAgICAgICAgbWF4OiAxXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICBdXG4gICAgICAgIH0sXG4gICAgICAgIHRvb2x0aXBzOiB7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9O1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0FBS0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQU5BO0FBWUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUpBO0FBT0E7QUFDQTtBQUNBO0FBQ0E7QUFKQTtBQU9BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFMQTtBQTFCQTtBQXNDQTtBQTNDQTtBQU5BO0FBcURBO0FBckdBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///9cb1\n")},"9d44":function(module,exports,__webpack_require__){eval("var app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar BaseWidget = __webpack_require__(/*! ./base-widget */ \"26ef\");\n\nvar Chart = __webpack_require__(/*! chart.js */ \"70b5\");\n\nvar colors = __webpack_require__(/*! ../../colors */ \"eb63\");\n\nvar misval = Spot.util.misval;\n\nvar util = __webpack_require__(/*! ./util */ \"2b41\"); // used for pie, bar, horizontalbar, and radar charts\n// modify the horizontalbarchart to have the group name printed on the bar\n\n\nChart.pluginService.register({\n  afterDatasetsDraw: function afterDatasetsDraw(chartInstance) {\n    var chartType = chartInstance.config.type;\n\n    if (chartType === 'horizontalBarError') {\n      var scale = chartInstance.scales['y-axis-0'];\n      scale.draw(scale);\n    }\n  }\n});\n\nfunction defaultErrorDir(model) {\n  var t = model.getType();\n\n  if (t === 'barchart') {\n    return 'vertical';\n  } else if (t === 'horizontalbarchart') {\n    return 'horizontal';\n  } else {\n    // pie radar\n    return 'none';\n  }\n}\n\nfunction acceptTimeAxis(model) {\n  var t = model.getType();\n  return t === 'barchart';\n}\n\nfunction hasPerItemColor(model) {\n  // data  Array\n  // color depending on plot type:\n  //           Array<Color>: barchart, piechart\n  //           Color:        radarchart\n  var t = model.getType();\n  return t === 'barchart' || t === 'horizontalbarchart' || t === 'piechart';\n} // true: color items by the index in the data array; for cateogrial facets\n// false:  color items by the index of their subgroup\n\n\nfunction colorByIndex(model) {\n  var t = model.getType();\n  return t === 'piechart';\n} // Called by Chartjs, this -> chart instance\n\n\nfunction onClick(ev, elements) {\n  if (elements.length > 0) {\n    var filter = this._Ampersandview.model.filter;\n    var partition = filter.partitions.get(1, 'rank');\n    partition.updateSelection(partition.groups.models[elements[0]._index]);\n    filter.updateDataFilter();\n    app.me.dataview.getData();\n  }\n}\n\nfunction _deinitChart(view) {\n  if (view._chartjs) {\n    view._chartjs.destroy();\n\n    delete view._chartjs;\n  }\n\n  delete view._config;\n  var canvas = view.queryByHook('canvas');\n\n  if (canvas) {\n    canvas.parentNode.removeChild(canvas);\n  }\n\n  view.isInitialized = false;\n}\n\nfunction _initChart(view) {\n  // Configure plot\n  view._config = view.model.chartjsConfig();\n  var options = view._config.options;\n  var partition = view.model.filter.partitions.get(1, 'rank'); // axis types\n\n  if (acceptTimeAxis(view.model)) {\n    if (partition.isDatetime) {\n      options.scales.xAxes[0].type = 'time';\n    } else if (partition.isDuration) {\n      options.scales.xAxes[0].type = 'spot-duration';\n    } else if (partition.isCategorial) {\n      options.scales.xAxes[0].type = 'category';\n    }\n  } // axis labels and title\n\n\n  if (view.model.getType() === 'barchart' || view.model.getType() === 'horizontalbarchart') {\n    options.scales.xAxes[0].scaleLabel.display = partition.showLabel;\n    options.scales.xAxes[0].scaleLabel.labelString = partition.label;\n  }\n\n  options.title.text = view.model.getTitle(); // mouse selection callbacks\n\n  if (view.model.getType() !== 'radarchart') {\n    options.onClick = onClick;\n  } // force a square full size plot\n\n\n  var width = view.el.offsetWidth;\n  var height = view.el.offsetHeight;\n  var canvas = document.createElement('canvas');\n  canvas.setAttribute('data-hook', 'canvas');\n  view.el.appendChild(canvas);\n  var ctx = canvas.getContext('2d');\n  ctx.canvas.width = width;\n  ctx.canvas.height = height; // Create Chartjs object\n\n  view._chartjs = new Chart(ctx, view._config); // In callbacks on the chart we will need the view, so store a reference\n\n  view._chartjs._Ampersandview = view;\n  view.isInitialized = true;\n}\n\nfunction _update(view) {\n  if (!view.isInitialized) {\n    console.warn('Cannot update chart, not initialized', view);\n    return;\n  }\n\n  var model = view.model;\n  var filter = view.model.filter;\n  var partitionA = filter.partitions.get(1, 'rank');\n  var partitionB = filter.partitions.get(2, 'rank');\n  var chartData = view._config.data;\n  util.resizeChartjsData(chartData, partitionA, partitionB, {\n    perItem: hasPerItemColor(model)\n  }); // update legends and tooltips:\n\n  if (model.getType() === 'piechart') {\n    view._config.options.legend.display = partitionA.showLegend;\n    view._config.options.tooltips.mode = 'single';\n  } else {\n    if (partitionB && partitionB.showLegend) {\n      view._config.options.legend.display = true;\n    } else {\n      view._config.options.legend.display = false;\n    }\n\n    if (partitionB && partitionB.groups && partitionB.groups.length > 1) {\n      view._config.options.tooltips.mode = 'label';\n    } else {\n      view._config.options.tooltips.mode = 'single';\n    }\n  }\n\n  var aggregate;\n  var valueFn;\n  aggregate = filter.aggregates.get(1, 'rank');\n\n  if (aggregate) {\n    valueFn = function valueFn(group) {\n      if (group.aa !== misval) {\n        return parseFloat(group.aa) || 0;\n      }\n\n      return 0;\n    };\n  } else {\n    valueFn = function valueFn(group) {\n      if (group.count !== misval) {\n        return group.count;\n      }\n\n      return 0;\n    };\n  }\n\n  var errorFn;\n  aggregate = filter.aggregates.get(2, 'rank');\n\n  if (aggregate) {\n    errorFn = function errorFn(group) {\n      if (group.bb !== misval) {\n        return parseFloat(group.bb) || 0;\n      }\n\n      return 0;\n    }; // use preset errorDir\n\n\n    view._config.options.errorDir = defaultErrorDir(model);\n  } else {\n    errorFn = function errorFn(group) {\n      return null;\n    };\n\n    view._config.options.errorDir = 'none';\n  }\n\n  var filterFn = partitionA.filterFunction(); // add datapoints\n\n  filter.data.forEach(function (group) {\n    var i = util.partitionValueToIndex(partitionA, group.a);\n    var j = util.partitionValueToIndex(partitionB, group.b); // only plot if both values are well defined\n\n    if (i >= 0 && j >= 0) {\n      // data value\n      chartData.datasets[j].data[i] = valueFn(group);\n      chartData.datasets[j].error[i] = errorFn(group); // data color\n\n      if (hasPerItemColor(model)) {\n        if (filterFn(partitionA.groups.models[i].value)) {\n          if (colorByIndex(model)) {\n            chartData.datasets[j].backgroundColor[i] = colors.getColor(i).css();\n          } else {\n            chartData.datasets[j].backgroundColor[i] = colors.getColor(j).css();\n          }\n        } else {\n          chartData.datasets[j].backgroundColor[i] = colors.unselectedColor.css();\n        }\n      }\n    }\n  }); // Hand-off to ChartJS for plotting\n\n  view._chartjs.update();\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner mdl-card__media\"></div>',\n  update: function update() {\n    _update(this);\n  },\n  initChart: function initChart() {\n    _initChart(this);\n  },\n  deinitChart: function deinitChart() {\n    _deinitChart(this);\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"9d44.js","sources":["webpack:///./src/widgets/views/chartjs.js?21b1"],"sourcesContent":["var app = require('ampersand-app');\nvar Spot = require('spot-framework');\nvar BaseWidget = require('./base-widget');\nvar Chart = require('chart.js');\nvar colors = require('../../colors');\nvar misval = Spot.util.misval;\nvar util = require('./util');\n\n// used for pie, bar, horizontalbar, and radar charts\n\n// modify the horizontalbarchart to have the group name printed on the bar\nChart.pluginService.register({\n  afterDatasetsDraw: function (chartInstance) {\n    var chartType = chartInstance.config.type;\n\n    if (chartType === 'horizontalBarError') {\n      var scale = chartInstance.scales['y-axis-0'];\n      scale.draw(scale);\n    }\n  }\n});\n\nfunction defaultErrorDir (model) {\n  var t = model.getType();\n  if (t === 'barchart') {\n    return 'vertical';\n  } else if (t === 'horizontalbarchart') {\n    return 'horizontal';\n  } else {\n    // pie radar\n    return 'none';\n  }\n}\n\nfunction acceptTimeAxis (model) {\n  var t = model.getType();\n  return (t === 'barchart');\n}\n\nfunction hasPerItemColor (model) {\n  // data  Array\n  // color depending on plot type:\n  //           Array<Color>: barchart, piechart\n  //           Color:        radarchart\n  var t = model.getType();\n  return (t === 'barchart' || t === 'horizontalbarchart' || t === 'piechart');\n}\n\n// true: color items by the index in the data array; for cateogrial facets\n// false:  color items by the index of their subgroup\nfunction colorByIndex (model) {\n  var t = model.getType();\n  return (t === 'piechart');\n}\n\n// Called by Chartjs, this -> chart instance\nfunction onClick (ev, elements) {\n  if (elements.length > 0) {\n    var filter = this._Ampersandview.model.filter;\n\n    var partition = filter.partitions.get(1, 'rank');\n    partition.updateSelection(partition.groups.models[elements[0]._index]);\n\n    filter.updateDataFilter();\n    app.me.dataview.getData();\n  }\n}\n\nfunction deinitChart (view) {\n  if (view._chartjs) {\n    view._chartjs.destroy();\n    delete view._chartjs;\n  }\n  delete view._config;\n\n  var canvas = view.queryByHook('canvas');\n  if (canvas) {\n    canvas.parentNode.removeChild(canvas);\n  }\n  view.isInitialized = false;\n}\n\nfunction initChart (view) {\n  // Configure plot\n  view._config = view.model.chartjsConfig();\n  var options = view._config.options;\n\n  var partition = view.model.filter.partitions.get(1, 'rank');\n\n  // axis types\n  if (acceptTimeAxis(view.model)) {\n    if (partition.isDatetime) {\n      options.scales.xAxes[0].type = 'time';\n    } else if (partition.isDuration) {\n      options.scales.xAxes[0].type = 'spot-duration';\n    } else if (partition.isCategorial) {\n      options.scales.xAxes[0].type = 'category';\n    }\n  }\n\n  // axis labels and title\n  if (view.model.getType() === 'barchart' || view.model.getType() === 'horizontalbarchart') {\n    options.scales.xAxes[0].scaleLabel.display = partition.showLabel;\n    options.scales.xAxes[0].scaleLabel.labelString = partition.label;\n  }\n  options.title.text = view.model.getTitle();\n\n  // mouse selection callbacks\n  if (view.model.getType() !== 'radarchart') {\n    options.onClick = onClick;\n  }\n\n  // force a square full size plot\n  var width = view.el.offsetWidth;\n  var height = view.el.offsetHeight;\n\n  var canvas = document.createElement('canvas');\n  canvas.setAttribute('data-hook', 'canvas');\n  view.el.appendChild(canvas);\n\n  var ctx = canvas.getContext('2d');\n  ctx.canvas.width = width;\n  ctx.canvas.height = height;\n\n  // Create Chartjs object\n  view._chartjs = new Chart(ctx, view._config);\n\n  // In callbacks on the chart we will need the view, so store a reference\n  view._chartjs._Ampersandview = view;\n\n  view.isInitialized = true;\n}\n\nfunction update (view) {\n  if (!view.isInitialized) {\n    console.warn('Cannot update chart, not initialized', view);\n    return;\n  }\n\n  var model = view.model;\n  var filter = view.model.filter;\n  var partitionA = filter.partitions.get(1, 'rank');\n  var partitionB = filter.partitions.get(2, 'rank');\n\n  var chartData = view._config.data;\n\n  util.resizeChartjsData(chartData, partitionA, partitionB, { perItem: hasPerItemColor(model) });\n\n  // update legends and tooltips:\n  if (model.getType() === 'piechart') {\n    view._config.options.legend.display = partitionA.showLegend;\n    view._config.options.tooltips.mode = 'single';\n  } else {\n    if (partitionB && partitionB.showLegend) {\n      view._config.options.legend.display = true;\n    } else {\n      view._config.options.legend.display = false;\n    }\n    if (partitionB && partitionB.groups && partitionB.groups.length > 1) {\n      view._config.options.tooltips.mode = 'label';\n    } else {\n      view._config.options.tooltips.mode = 'single';\n    }\n  }\n\n  var aggregate;\n\n  var valueFn;\n  aggregate = filter.aggregates.get(1, 'rank');\n  if (aggregate) {\n    valueFn = function (group) {\n      if (group.aa !== misval) {\n        return parseFloat(group.aa) || 0;\n      }\n      return 0;\n    };\n  } else {\n    valueFn = function (group) {\n      if (group.count !== misval) {\n        return group.count;\n      }\n      return 0;\n    };\n  }\n\n  var errorFn;\n  aggregate = filter.aggregates.get(2, 'rank');\n  if (aggregate) {\n    errorFn = function (group) {\n      if (group.bb !== misval) {\n        return parseFloat(group.bb) || 0;\n      }\n      return 0;\n    };\n    // use preset errorDir\n    view._config.options.errorDir = defaultErrorDir(model);\n  } else {\n    errorFn = function (group) { return null; };\n    view._config.options.errorDir = 'none';\n  }\n\n  var filterFn = partitionA.filterFunction();\n\n  // add datapoints\n  filter.data.forEach(function (group) {\n    var i = util.partitionValueToIndex(partitionA, group.a);\n    var j = util.partitionValueToIndex(partitionB, group.b);\n\n    // only plot if both values are well defined\n    if (i >= 0 && j >= 0) {\n      // data value\n      chartData.datasets[j].data[i] = valueFn(group);\n      chartData.datasets[j].error[i] = errorFn(group);\n\n      // data color\n      if (hasPerItemColor(model)) {\n        if (filterFn(partitionA.groups.models[i].value)) {\n          if (colorByIndex(model)) {\n            chartData.datasets[j].backgroundColor[i] = colors.getColor(i).css();\n          } else {\n            chartData.datasets[j].backgroundColor[i] = colors.getColor(j).css();\n          }\n        } else {\n          chartData.datasets[j].backgroundColor[i] = colors.unselectedColor.css();\n        }\n      }\n    }\n  });\n\n  // Hand-off to ChartJS for plotting\n  view._chartjs.update();\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner mdl-card__media\"></div>',\n\n  update: function () {\n    update(this);\n  },\n\n  initChart: function () {\n    initChart(this);\n  },\n\n  deinitChart: function () {\n    deinitChart(this);\n  }\n});\n\n"],"mappings":"AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AAIA;AACA;AACA;AADA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AARA;AACA;AAUA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AADA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAbA","sourceRoot":""}\n//# sourceURL=webpack-internal:///9d44\n")},a6e8:function(module,exports,__webpack_require__){eval("var Collection = __webpack_require__(/*! ampersand-collection */ \"7bd3\");\n\nvar AmpersandModel = __webpack_require__(/*! ampersand-model */ \"3bfc\");\n\nvar Chart = __webpack_require__(/*! chart.js */ \"70b5\"); // extend plot with errorbars\n\n\nvar extendWithErrorBar = __webpack_require__(/*! ./chartjs-errorbars */ \"ee83\");\n\nextendWithErrorBar(Chart, 'line', 'lineError');\nextendWithErrorBar(Chart, 'bubble', 'bubbleError');\nextendWithErrorBar(Chart, 'bar', 'barError');\nextendWithErrorBar(Chart, 'horizontalBar', 'horizontalBarError'); // extend plots with a duration scale type\n\nvar extendWithDurationScale = __webpack_require__(/*! ./chartjs-duration-scale */ \"d11f\");\n\nextendWithDurationScale(Chart); // replace the default linear scale with a smarter formatter\n\nvar SciLinearFormatter = __webpack_require__(/*! ./chartjs-scilinear-formatter */ \"de33\");\n\nChart.scaleService.updateScaleDefaults('linear', {\n  ticks: {\n    callback: SciLinearFormatter\n  }\n});\nvar widgetEntry = AmpersandModel.extend({\n  props: {\n    modelType: {\n      type: 'string',\n      required: true\n    },\n    newView: {\n      type: 'any',\n      required: false\n    }\n  }\n});\nvar WidgetCollection = Collection.extend({\n  model: widgetEntry,\n  mainIndex: 'modelType'\n});\n/**\n * A factory producing the Ampersand views corresponding to the different chart types.\n * @module widgets/view-factory\n */\n\nmodule.exports.widgets = new WidgetCollection([{\n  modelType: 'piechart',\n  newView: __webpack_require__(/*! ./views/chartjs */ \"9d44\")\n}, {\n  modelType: 'barchart',\n  newView: __webpack_require__(/*! ./views/chartjs */ \"9d44\")\n}, {\n  modelType: 'horizontalbarchart',\n  newView: __webpack_require__(/*! ./views/chartjs */ \"9d44\")\n}, {\n  modelType: 'linechart',\n  newView: __webpack_require__(/*! ./views/chartjs1d */ \"e9bd\")\n}, {\n  modelType: 'radarchart',\n  newView: __webpack_require__(/*! ./views/chartjs */ \"9d44\")\n}, {\n  modelType: 'bubbleplot',\n  newView: __webpack_require__(/*! ./views/chartjs2d */ \"fdc1\")\n}, {\n  modelType: 'scatterchart',\n  newView: __webpack_require__(/*! ./views/scatter */ \"035a\")\n}, {\n  modelType: 'networkchart',\n  newView: __webpack_require__(/*! ./views/sigma */ \"af18\") // Register new widgets here\n\n}]);\n/**\n * Create a new Ampersand view for a widget\n * @param {Object} options - passed on to the view constructor, see https://github.com/AmpersandJS/ampersand-view#constructor-new-ampersandviewoptions\n * @param {Object} options.model - The widget\n * @returns {View} view - An Ampersand view\n */\n\nmodule.exports.newView = function newView(options) {\n  var entry = module.exports.widgets.get(options.model.modelType);\n  var constructor = entry.newView;\n  return new constructor(options);\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYTZlOC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL3ZpZXctZmFjdG9yeS5qcz8xZTBkIl0sInNvdXJjZXNDb250ZW50IjpbInZhciBDb2xsZWN0aW9uID0gcmVxdWlyZSgnYW1wZXJzYW5kLWNvbGxlY3Rpb24nKTtcbnZhciBBbXBlcnNhbmRNb2RlbCA9IHJlcXVpcmUoJ2FtcGVyc2FuZC1tb2RlbCcpO1xuXG52YXIgQ2hhcnQgPSByZXF1aXJlKCdjaGFydC5qcycpO1xuXG4vLyBleHRlbmQgcGxvdCB3aXRoIGVycm9yYmFyc1xudmFyIGV4dGVuZFdpdGhFcnJvckJhciA9IHJlcXVpcmUoJy4vY2hhcnRqcy1lcnJvcmJhcnMnKTtcbmV4dGVuZFdpdGhFcnJvckJhcihDaGFydCwgJ2xpbmUnLCAnbGluZUVycm9yJyk7XG5leHRlbmRXaXRoRXJyb3JCYXIoQ2hhcnQsICdidWJibGUnLCAnYnViYmxlRXJyb3InKTtcbmV4dGVuZFdpdGhFcnJvckJhcihDaGFydCwgJ2JhcicsICdiYXJFcnJvcicpO1xuZXh0ZW5kV2l0aEVycm9yQmFyKENoYXJ0LCAnaG9yaXpvbnRhbEJhcicsICdob3Jpem9udGFsQmFyRXJyb3InKTtcblxuLy8gZXh0ZW5kIHBsb3RzIHdpdGggYSBkdXJhdGlvbiBzY2FsZSB0eXBlXG52YXIgZXh0ZW5kV2l0aER1cmF0aW9uU2NhbGUgPSByZXF1aXJlKCcuL2NoYXJ0anMtZHVyYXRpb24tc2NhbGUnKTtcbmV4dGVuZFdpdGhEdXJhdGlvblNjYWxlKENoYXJ0KTtcblxuLy8gcmVwbGFjZSB0aGUgZGVmYXVsdCBsaW5lYXIgc2NhbGUgd2l0aCBhIHNtYXJ0ZXIgZm9ybWF0dGVyXG52YXIgU2NpTGluZWFyRm9ybWF0dGVyID0gcmVxdWlyZSgnLi9jaGFydGpzLXNjaWxpbmVhci1mb3JtYXR0ZXInKTtcbkNoYXJ0LnNjYWxlU2VydmljZS51cGRhdGVTY2FsZURlZmF1bHRzKCdsaW5lYXInLCB7IHRpY2tzOiB7IGNhbGxiYWNrOiBTY2lMaW5lYXJGb3JtYXR0ZXIgfSB9KTtcblxudmFyIHdpZGdldEVudHJ5ID0gQW1wZXJzYW5kTW9kZWwuZXh0ZW5kKHtcbiAgcHJvcHM6IHtcbiAgICBtb2RlbFR5cGU6IHt0eXBlOiAnc3RyaW5nJywgcmVxdWlyZWQ6IHRydWV9LFxuICAgIG5ld1ZpZXc6IHt0eXBlOiAnYW55JywgcmVxdWlyZWQ6IGZhbHNlfVxuICB9XG59KTtcblxudmFyIFdpZGdldENvbGxlY3Rpb24gPSBDb2xsZWN0aW9uLmV4dGVuZCh7XG4gIG1vZGVsOiB3aWRnZXRFbnRyeSxcbiAgbWFpbkluZGV4OiAnbW9kZWxUeXBlJ1xufSk7XG5cbi8qKlxuICogQSBmYWN0b3J5IHByb2R1Y2luZyB0aGUgQW1wZXJzYW5kIHZpZXdzIGNvcnJlc3BvbmRpbmcgdG8gdGhlIGRpZmZlcmVudCBjaGFydCB0eXBlcy5cbiAqIEBtb2R1bGUgd2lkZ2V0cy92aWV3LWZhY3RvcnlcbiAqL1xubW9kdWxlLmV4cG9ydHMud2lkZ2V0cyA9IG5ldyBXaWRnZXRDb2xsZWN0aW9uKFtcbiAge1xuICAgIG1vZGVsVHlwZTogJ3BpZWNoYXJ0JyxcbiAgICBuZXdWaWV3OiByZXF1aXJlKCcuL3ZpZXdzL2NoYXJ0anMnKVxuICB9LFxuICB7XG4gICAgbW9kZWxUeXBlOiAnYmFyY2hhcnQnLFxuICAgIG5ld1ZpZXc6IHJlcXVpcmUoJy4vdmlld3MvY2hhcnRqcycpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdob3Jpem9udGFsYmFyY2hhcnQnLFxuICAgIG5ld1ZpZXc6IHJlcXVpcmUoJy4vdmlld3MvY2hhcnRqcycpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdsaW5lY2hhcnQnLFxuICAgIG5ld1ZpZXc6IHJlcXVpcmUoJy4vdmlld3MvY2hhcnRqczFkJylcbiAgfSxcbiAge1xuICAgIG1vZGVsVHlwZTogJ3JhZGFyY2hhcnQnLFxuICAgIG5ld1ZpZXc6IHJlcXVpcmUoJy4vdmlld3MvY2hhcnRqcycpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdidWJibGVwbG90JyxcbiAgICBuZXdWaWV3OiByZXF1aXJlKCcuL3ZpZXdzL2NoYXJ0anMyZCcpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdzY2F0dGVyY2hhcnQnLFxuICAgIG5ld1ZpZXc6IHJlcXVpcmUoJy4vdmlld3Mvc2NhdHRlcicpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICduZXR3b3JrY2hhcnQnLFxuICAgIG5ld1ZpZXc6IHJlcXVpcmUoJy4vdmlld3Mvc2lnbWEnKVxuICB9XG4gIC8vIFJlZ2lzdGVyIG5ldyB3aWRnZXRzIGhlcmVcbl0pO1xuXG4vKipcbiAqIENyZWF0ZSBhIG5ldyBBbXBlcnNhbmQgdmlldyBmb3IgYSB3aWRnZXRcbiAqIEBwYXJhbSB7T2JqZWN0fSBvcHRpb25zIC0gcGFzc2VkIG9uIHRvIHRoZSB2aWV3IGNvbnN0cnVjdG9yLCBzZWUgaHR0cHM6Ly9naXRodWIuY29tL0FtcGVyc2FuZEpTL2FtcGVyc2FuZC12aWV3I2NvbnN0cnVjdG9yLW5ldy1hbXBlcnNhbmR2aWV3b3B0aW9uc1xuICogQHBhcmFtIHtPYmplY3R9IG9wdGlvbnMubW9kZWwgLSBUaGUgd2lkZ2V0XG4gKiBAcmV0dXJucyB7Vmlld30gdmlldyAtIEFuIEFtcGVyc2FuZCB2aWV3XG4gKi9cbm1vZHVsZS5leHBvcnRzLm5ld1ZpZXcgPSBmdW5jdGlvbiBuZXdWaWV3IChvcHRpb25zKSB7XG4gIHZhciBlbnRyeSA9IG1vZHVsZS5leHBvcnRzLndpZGdldHMuZ2V0KG9wdGlvbnMubW9kZWwubW9kZWxUeXBlKTtcbiAgdmFyIGNvbnN0cnVjdG9yID0gZW50cnkubmV3VmlldztcbiAgcmV0dXJuIG5ldyBjb25zdHJ1Y3RvcihvcHRpb25zKTtcbn07XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQUE7QUFDQTtBQUVBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFGQTtBQURBO0FBT0E7QUFDQTtBQUNBO0FBRkE7QUFLQTs7Ozs7QUFJQTtBQUVBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFDQTtBQUhBO0FBT0E7Ozs7Ozs7QUFNQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///a6e8\n")},aa00:function(module,exports,__webpack_require__){eval("var app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar Router = __webpack_require__(/*! ampersand-router */ \"e57e\");\n\nvar HomePage = __webpack_require__(/*! ./pages/home */ \"8ab4\");\n\nvar DatasetsPage = __webpack_require__(/*! ./pages/datasets */ \"7bdf\");\n\nvar ConfigureDatasetPage = __webpack_require__(/*! ./pages/configure-dataset */ \"4b1e\");\n\nvar ConfigureFacetPage = __webpack_require__(/*! ./pages/configure-facet */ \"6668\");\n\nvar ConfigurePartitionPage = __webpack_require__(/*! ./pages/configure-partition */ \"d38c\");\n\nvar AnalyzePage = __webpack_require__(/*! ./pages/analyze */ \"22e9\");\n/**\n * [exports description]\n * @module router\n */\n\n\nmodule.exports = Router.extend({\n  routes: {\n    '': 'home',\n    'home': 'home',\n    'datasets': 'datasets',\n    'analyze': 'analyze',\n    'dataset/:id': 'configureDataset',\n    'facet/:id': 'configureFacet',\n    'partition/:id': 'configurePartition',\n    'session=(*url)': 'getSession',\n    '(*path)': 'catchAll'\n  },\n  // ------- ROUTE HANDLERS ---------\n  home: function home() {\n    app.trigger('page', new HomePage({\n      model: app.me\n    }));\n  },\n  datasets: function datasets() {\n    app.trigger('page', new DatasetsPage({\n      model: app.me\n    }));\n  },\n  analyze: function analyze() {\n    app.trigger('page', new AnalyzePage({\n      model: app.me.dataview,\n      collection: app.me.dataview.filters\n    }));\n  },\n  share: function share() {\n    app.trigger('page', new SharePage({\n      model: app.me\n    }));\n  },\n  configureDataset: function configureDataset(id) {\n    var dataset = app.me.datasets.get(id);\n\n    if (dataset) {\n      app.trigger('page', new ConfigureDatasetPage({\n        model: dataset,\n        collection: dataset.facets\n      }));\n    } else {\n      this.home();\n    }\n  },\n  configureFacet: function configureFacet(id) {\n    var dataset = null;\n    var facet = null; // look for facet in app.me.datasets\n\n    app.me.datasets.forEach(function (d) {\n      facet = d.facets.get(id);\n\n      if (facet) {\n        dataset = d;\n      }\n    }); // look for facet in app.me.dataview\n\n    facet = app.me.dataview.facets.get(id);\n\n    if (facet) {\n      dataset = app.me.dataview;\n    }\n\n    if (dataset) {\n      facet = dataset.facets.get(id);\n      app.trigger('page', new ConfigureFacetPage({\n        dataset: dataset,\n        model: facet\n      }));\n    } else {\n      this.home();\n      console.error('Facet not found');\n    }\n  },\n  configurePartition: function configurePartition(id) {\n    // Search over all filters and partitions in this dataset to find the right partition\n    // Not very pretty, but the number of filters and filters per partition are small\n    var partitionToEdit;\n    var found = false;\n    app.me.dataview.filters.forEach(function (filter) {\n      filter.partitions.forEach(function (partition) {\n        if (partition.getId() === id) {\n          found = true;\n          partitionToEdit = partition;\n        }\n      });\n    });\n\n    if (found) {\n      app.trigger('page', new ConfigurePartitionPage({\n        model: partitionToEdit\n      }));\n    } else {\n      this.home();\n    }\n  },\n  getSession: function getSession(url) {\n    console.log('router.js: Getting a remote session from:', url);\n    app.importRemoteSession(url);\n  },\n  catchAll: function catchAll() {\n    this.redirectTo('');\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWEwMC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9yb3V0ZXIuanM/NDFjYiJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgYXBwID0gcmVxdWlyZSgnYW1wZXJzYW5kLWFwcCcpO1xudmFyIFJvdXRlciA9IHJlcXVpcmUoJ2FtcGVyc2FuZC1yb3V0ZXInKTtcbnZhciBIb21lUGFnZSA9IHJlcXVpcmUoJy4vcGFnZXMvaG9tZScpO1xudmFyIERhdGFzZXRzUGFnZSA9IHJlcXVpcmUoJy4vcGFnZXMvZGF0YXNldHMnKTtcbnZhciBDb25maWd1cmVEYXRhc2V0UGFnZSA9IHJlcXVpcmUoJy4vcGFnZXMvY29uZmlndXJlLWRhdGFzZXQnKTtcbnZhciBDb25maWd1cmVGYWNldFBhZ2UgPSByZXF1aXJlKCcuL3BhZ2VzL2NvbmZpZ3VyZS1mYWNldCcpO1xudmFyIENvbmZpZ3VyZVBhcnRpdGlvblBhZ2UgPSByZXF1aXJlKCcuL3BhZ2VzL2NvbmZpZ3VyZS1wYXJ0aXRpb24nKTtcbnZhciBBbmFseXplUGFnZSA9IHJlcXVpcmUoJy4vcGFnZXMvYW5hbHl6ZScpO1xuXG4vKipcbiAqIFtleHBvcnRzIGRlc2NyaXB0aW9uXVxuICogQG1vZHVsZSByb3V0ZXJcbiAqL1xubW9kdWxlLmV4cG9ydHMgPSBSb3V0ZXIuZXh0ZW5kKHtcbiAgcm91dGVzOiB7XG4gICAgJyc6ICdob21lJyxcbiAgICAnaG9tZSc6ICdob21lJyxcbiAgICAnZGF0YXNldHMnOiAnZGF0YXNldHMnLFxuICAgICdhbmFseXplJzogJ2FuYWx5emUnLFxuXG4gICAgJ2RhdGFzZXQvOmlkJzogJ2NvbmZpZ3VyZURhdGFzZXQnLFxuICAgICdmYWNldC86aWQnOiAnY29uZmlndXJlRmFjZXQnLFxuICAgICdwYXJ0aXRpb24vOmlkJzogJ2NvbmZpZ3VyZVBhcnRpdGlvbicsXG4gICAgJ3Nlc3Npb249KCp1cmwpJzogJ2dldFNlc3Npb24nLFxuICAgICcoKnBhdGgpJzogJ2NhdGNoQWxsJ1xuICB9LFxuXG4gIC8vIC0tLS0tLS0gUk9VVEUgSEFORExFUlMgLS0tLS0tLS0tXG4gIGhvbWU6IGZ1bmN0aW9uICgpIHtcbiAgICBhcHAudHJpZ2dlcigncGFnZScsIG5ldyBIb21lUGFnZSh7XG4gICAgICBtb2RlbDogYXBwLm1lXG4gICAgfSkpO1xuICB9LFxuXG4gIGRhdGFzZXRzOiBmdW5jdGlvbiAoKSB7XG4gICAgYXBwLnRyaWdnZXIoJ3BhZ2UnLCBuZXcgRGF0YXNldHNQYWdlKHtcbiAgICAgIG1vZGVsOiBhcHAubWVcbiAgICB9KSk7XG4gIH0sXG5cbiAgYW5hbHl6ZTogZnVuY3Rpb24gKCkge1xuICAgIGFwcC50cmlnZ2VyKCdwYWdlJywgbmV3IEFuYWx5emVQYWdlKHtcbiAgICAgIG1vZGVsOiBhcHAubWUuZGF0YXZpZXcsXG4gICAgICBjb2xsZWN0aW9uOiBhcHAubWUuZGF0YXZpZXcuZmlsdGVyc1xuICAgIH0pKTtcbiAgfSxcblxuICBzaGFyZTogZnVuY3Rpb24gKCkge1xuICAgIGFwcC50cmlnZ2VyKCdwYWdlJywgbmV3IFNoYXJlUGFnZSh7XG4gICAgICBtb2RlbDogYXBwLm1lXG4gICAgfSkpO1xuICB9LFxuXG4gIGNvbmZpZ3VyZURhdGFzZXQ6IGZ1bmN0aW9uIChpZCkge1xuICAgIHZhciBkYXRhc2V0ID0gYXBwLm1lLmRhdGFzZXRzLmdldChpZCk7XG4gICAgaWYgKGRhdGFzZXQpIHtcbiAgICAgIGFwcC50cmlnZ2VyKCdwYWdlJywgbmV3IENvbmZpZ3VyZURhdGFzZXRQYWdlKHtcbiAgICAgICAgbW9kZWw6IGRhdGFzZXQsXG4gICAgICAgIGNvbGxlY3Rpb246IGRhdGFzZXQuZmFjZXRzXG4gICAgICB9KSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuaG9tZSgpO1xuICAgIH1cbiAgfSxcblxuICBjb25maWd1cmVGYWNldDogZnVuY3Rpb24gKGlkKSB7XG4gICAgdmFyIGRhdGFzZXQgPSBudWxsO1xuICAgIHZhciBmYWNldCA9IG51bGw7XG5cbiAgICAvLyBsb29rIGZvciBmYWNldCBpbiBhcHAubWUuZGF0YXNldHNcbiAgICBhcHAubWUuZGF0YXNldHMuZm9yRWFjaChmdW5jdGlvbiAoZCkge1xuICAgICAgZmFjZXQgPSBkLmZhY2V0cy5nZXQoaWQpO1xuICAgICAgaWYgKGZhY2V0KSB7XG4gICAgICAgIGRhdGFzZXQgPSBkO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgLy8gbG9vayBmb3IgZmFjZXQgaW4gYXBwLm1lLmRhdGF2aWV3XG4gICAgZmFjZXQgPSBhcHAubWUuZGF0YXZpZXcuZmFjZXRzLmdldChpZCk7XG4gICAgaWYgKGZhY2V0KSB7XG4gICAgICBkYXRhc2V0ID0gYXBwLm1lLmRhdGF2aWV3O1xuICAgIH1cblxuICAgIGlmIChkYXRhc2V0KSB7XG4gICAgICBmYWNldCA9IGRhdGFzZXQuZmFjZXRzLmdldChpZCk7XG4gICAgICBhcHAudHJpZ2dlcigncGFnZScsIG5ldyBDb25maWd1cmVGYWNldFBhZ2Uoe1xuICAgICAgICBkYXRhc2V0OiBkYXRhc2V0LFxuICAgICAgICBtb2RlbDogZmFjZXRcbiAgICAgIH0pKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5ob21lKCk7XG4gICAgICBjb25zb2xlLmVycm9yKCdGYWNldCBub3QgZm91bmQnKTtcbiAgICB9XG4gIH0sXG5cbiAgY29uZmlndXJlUGFydGl0aW9uOiBmdW5jdGlvbiAoaWQpIHtcbiAgICAvLyBTZWFyY2ggb3ZlciBhbGwgZmlsdGVycyBhbmQgcGFydGl0aW9ucyBpbiB0aGlzIGRhdGFzZXQgdG8gZmluZCB0aGUgcmlnaHQgcGFydGl0aW9uXG4gICAgLy8gTm90IHZlcnkgcHJldHR5LCBidXQgdGhlIG51bWJlciBvZiBmaWx0ZXJzIGFuZCBmaWx0ZXJzIHBlciBwYXJ0aXRpb24gYXJlIHNtYWxsXG4gICAgdmFyIHBhcnRpdGlvblRvRWRpdDtcbiAgICB2YXIgZm91bmQgPSBmYWxzZTtcbiAgICBhcHAubWUuZGF0YXZpZXcuZmlsdGVycy5mb3JFYWNoKGZ1bmN0aW9uIChmaWx0ZXIpIHtcbiAgICAgIGZpbHRlci5wYXJ0aXRpb25zLmZvckVhY2goZnVuY3Rpb24gKHBhcnRpdGlvbikge1xuICAgICAgICBpZiAocGFydGl0aW9uLmdldElkKCkgPT09IGlkKSB7XG4gICAgICAgICAgZm91bmQgPSB0cnVlO1xuICAgICAgICAgIHBhcnRpdGlvblRvRWRpdCA9IHBhcnRpdGlvbjtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfSk7XG5cbiAgICBpZiAoZm91bmQpIHtcbiAgICAgIGFwcC50cmlnZ2VyKCdwYWdlJywgbmV3IENvbmZpZ3VyZVBhcnRpdGlvblBhZ2UoeyBtb2RlbDogcGFydGl0aW9uVG9FZGl0IH0pKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5ob21lKCk7XG4gICAgfVxuICB9LFxuICBnZXRTZXNzaW9uOiBmdW5jdGlvbiAodXJsKSB7XG4gICAgY29uc29sZS5sb2coJ3JvdXRlci5qczogR2V0dGluZyBhIHJlbW90ZSBzZXNzaW9uIGZyb206JywgdXJsKTtcbiAgICBhcHAuaW1wb3J0UmVtb3RlU2Vzc2lvbih1cmwpO1xuICB9LFxuICBjYXRjaEFsbDogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVkaXJlY3RUbygnJyk7XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFFQTs7Ozs7O0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQVZBO0FBYUE7QUFDQTtBQUNBO0FBQ0E7QUFEQTtBQUdBO0FBRUE7QUFDQTtBQUNBO0FBREE7QUFHQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUVBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFFQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQTVHQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///aa00\n")},aea4:function(module,exports,__webpack_require__){eval("/**\n * A slot defines how a variable can be added to a plot\n *\n * @class Slot\n */\nvar AmpersandModel = __webpack_require__(/*! ampersand-model */ \"3bfc\");\n\nfunction labelForPartition(facet) {\n  // use: \"label [units]\" or \"label\"\n  if (facet.units.length > 0) {\n    return facet.name + ' [' + facet.units + ']';\n  } else {\n    return facet.name;\n  }\n}\n\nmodule.exports = AmpersandModel.extend({\n  props: {\n    /**\n     * Description of this slot, to be shown in the UI\n     */\n    description: {\n      type: 'string',\n      required: 'true'\n    },\n\n    /**\n     * Type of slot:\n     * 1. partition: partitions the data along this variable\n     * 2. aggregate: this variable is used to style the plot: bar height, color, etc.\n     */\n    type: {\n      type: 'string',\n      required: true,\n      default: 'partition',\n      values: ['partition', 'aggregate']\n    },\n\n    /**\n     * Supported facet types. A subset of: [constant, categorial, datetime, duration, text]\n     */\n    supportedFacets: {\n      type: 'array',\n      required: true,\n      default: function _default() {\n        return [];\n      }\n    },\n    rank: 'number',\n    required: 'boolean',\n    isFilled: 'boolean'\n  },\n\n  /**\n   * Remove facet from the slot\n   * @returns {boolean} succes True if something was removed\n   */\n  emptySlot: function emptySlot() {\n    var filter = this.collection.parent.filter;\n\n    if (!filter || !this.isFilled) {\n      return false;\n    }\n\n    filter.releaseDataFilter();\n\n    if (this.type === 'partition') {\n      var partition = filter.partitions.get(this.rank, 'rank');\n      filter.partitions.remove(partition);\n    } else if (this.type === 'aggregate') {\n      var aggregate = filter.aggregates.get(this.rank, 'rank');\n      filter.aggregates.remove(aggregate);\n    }\n\n    this.isFilled = false;\n    return true;\n  },\n\n  /**\n   * Try to fill the slot with the provided facet\n   * returns true on success, false on failure\n   * The tryFillSlot caller is responsible to do a app.trigger('refresh')\n   *\n   * @param {Facet} facet\n   * @param {string} operation Optional. Requested operation for aggregates\n   * @returns {boolean} success\n   */\n  tryFillSlot: function tryFillSlot(facet, operation) {\n    var filter = this.collection.parent.filter;\n\n    if (!filter || this.isFilled) {\n      return false;\n    } // check if this slot accepts this type of facet\n\n\n    if (this.supportedFacets.indexOf(facet.type) === -1) {\n      return false;\n    } // Release this filter, and add relevant partition or aggregate\n\n\n    filter.releaseDataFilter();\n\n    if (this.type === 'partition') {\n      var partition = filter.partitions.add({\n        facetName: facet.name,\n        label: labelForPartition(facet),\n        showLabel: this.rank !== 1 || !facet.isCategorial,\n        rank: this.rank\n      });\n      partition.reset();\n    } else if (this.type === 'aggregate') {\n      filter.aggregates.add({\n        facetName: facet.name,\n        label: facet.name,\n        rank: this.rank,\n        operation: operation || 'avg'\n      });\n    } else {\n      console.error('Illegal slot');\n      return false;\n    }\n\n    this.isFilled = true;\n    return true;\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWVhNC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9zbG90LmpzPzdjNmEiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBBIHNsb3QgZGVmaW5lcyBob3cgYSB2YXJpYWJsZSBjYW4gYmUgYWRkZWQgdG8gYSBwbG90XG4gKlxuICogQGNsYXNzIFNsb3RcbiAqL1xudmFyIEFtcGVyc2FuZE1vZGVsID0gcmVxdWlyZSgnYW1wZXJzYW5kLW1vZGVsJyk7XG5cbmZ1bmN0aW9uIGxhYmVsRm9yUGFydGl0aW9uIChmYWNldCkge1xuICAvLyB1c2U6IFwibGFiZWwgW3VuaXRzXVwiIG9yIFwibGFiZWxcIlxuICBpZiAoZmFjZXQudW5pdHMubGVuZ3RoID4gMCkge1xuICAgIHJldHVybiBmYWNldC5uYW1lICsgJyBbJyArIGZhY2V0LnVuaXRzICsgJ10nO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiBmYWNldC5uYW1lO1xuICB9XG59XG5cbm1vZHVsZS5leHBvcnRzID0gQW1wZXJzYW5kTW9kZWwuZXh0ZW5kKHtcbiAgcHJvcHM6IHtcbiAgICAvKipcbiAgICAgKiBEZXNjcmlwdGlvbiBvZiB0aGlzIHNsb3QsIHRvIGJlIHNob3duIGluIHRoZSBVSVxuICAgICAqL1xuICAgIGRlc2NyaXB0aW9uOiB7XG4gICAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICAgIHJlcXVpcmVkOiAndHJ1ZSdcbiAgICB9LFxuICAgIC8qKlxuICAgICAqIFR5cGUgb2Ygc2xvdDpcbiAgICAgKiAxLiBwYXJ0aXRpb246IHBhcnRpdGlvbnMgdGhlIGRhdGEgYWxvbmcgdGhpcyB2YXJpYWJsZVxuICAgICAqIDIuIGFnZ3JlZ2F0ZTogdGhpcyB2YXJpYWJsZSBpcyB1c2VkIHRvIHN0eWxlIHRoZSBwbG90OiBiYXIgaGVpZ2h0LCBjb2xvciwgZXRjLlxuICAgICAqL1xuICAgIHR5cGU6IHtcbiAgICAgIHR5cGU6ICdzdHJpbmcnLFxuICAgICAgcmVxdWlyZWQ6IHRydWUsXG4gICAgICBkZWZhdWx0OiAncGFydGl0aW9uJyxcbiAgICAgIHZhbHVlczogWydwYXJ0aXRpb24nLCAnYWdncmVnYXRlJ11cbiAgICB9LFxuICAgIC8qKlxuICAgICAqIFN1cHBvcnRlZCBmYWNldCB0eXBlcy4gQSBzdWJzZXQgb2Y6IFtjb25zdGFudCwgY2F0ZWdvcmlhbCwgZGF0ZXRpbWUsIGR1cmF0aW9uLCB0ZXh0XVxuICAgICAqL1xuICAgIHN1cHBvcnRlZEZhY2V0czoge1xuICAgICAgdHlwZTogJ2FycmF5JyxcbiAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgZGVmYXVsdDogZnVuY3Rpb24gKCkge1xuICAgICAgICByZXR1cm4gW107XG4gICAgICB9XG4gICAgfSxcbiAgICByYW5rOiAnbnVtYmVyJyxcbiAgICByZXF1aXJlZDogJ2Jvb2xlYW4nLFxuICAgIGlzRmlsbGVkOiAnYm9vbGVhbidcbiAgfSxcbiAgLyoqXG4gICAqIFJlbW92ZSBmYWNldCBmcm9tIHRoZSBzbG90XG4gICAqIEByZXR1cm5zIHtib29sZWFufSBzdWNjZXMgVHJ1ZSBpZiBzb21ldGhpbmcgd2FzIHJlbW92ZWRcbiAgICovXG4gIGVtcHR5U2xvdDogZnVuY3Rpb24gKCkge1xuICAgIHZhciBmaWx0ZXIgPSB0aGlzLmNvbGxlY3Rpb24ucGFyZW50LmZpbHRlcjtcbiAgICBpZiAoIWZpbHRlciB8fCAhdGhpcy5pc0ZpbGxlZCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIGZpbHRlci5yZWxlYXNlRGF0YUZpbHRlcigpO1xuICAgIGlmICh0aGlzLnR5cGUgPT09ICdwYXJ0aXRpb24nKSB7XG4gICAgICB2YXIgcGFydGl0aW9uID0gZmlsdGVyLnBhcnRpdGlvbnMuZ2V0KHRoaXMucmFuaywgJ3JhbmsnKTtcbiAgICAgIGZpbHRlci5wYXJ0aXRpb25zLnJlbW92ZShwYXJ0aXRpb24pO1xuICAgIH0gZWxzZSBpZiAodGhpcy50eXBlID09PSAnYWdncmVnYXRlJykge1xuICAgICAgdmFyIGFnZ3JlZ2F0ZSA9IGZpbHRlci5hZ2dyZWdhdGVzLmdldCh0aGlzLnJhbmssICdyYW5rJyk7XG4gICAgICBmaWx0ZXIuYWdncmVnYXRlcy5yZW1vdmUoYWdncmVnYXRlKTtcbiAgICB9XG4gICAgdGhpcy5pc0ZpbGxlZCA9IGZhbHNlO1xuICAgIHJldHVybiB0cnVlO1xuICB9LFxuICAvKipcbiAgICogVHJ5IHRvIGZpbGwgdGhlIHNsb3Qgd2l0aCB0aGUgcHJvdmlkZWQgZmFjZXRcbiAgICogcmV0dXJucyB0cnVlIG9uIHN1Y2Nlc3MsIGZhbHNlIG9uIGZhaWx1cmVcbiAgICogVGhlIHRyeUZpbGxTbG90IGNhbGxlciBpcyByZXNwb25zaWJsZSB0byBkbyBhIGFwcC50cmlnZ2VyKCdyZWZyZXNoJylcbiAgICpcbiAgICogQHBhcmFtIHtGYWNldH0gZmFjZXRcbiAgICogQHBhcmFtIHtzdHJpbmd9IG9wZXJhdGlvbiBPcHRpb25hbC4gUmVxdWVzdGVkIG9wZXJhdGlvbiBmb3IgYWdncmVnYXRlc1xuICAgKiBAcmV0dXJucyB7Ym9vbGVhbn0gc3VjY2Vzc1xuICAgKi9cbiAgdHJ5RmlsbFNsb3Q6IGZ1bmN0aW9uIChmYWNldCwgb3BlcmF0aW9uKSB7XG4gICAgdmFyIGZpbHRlciA9IHRoaXMuY29sbGVjdGlvbi5wYXJlbnQuZmlsdGVyO1xuICAgIGlmICghZmlsdGVyIHx8IHRoaXMuaXNGaWxsZWQpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICAvLyBjaGVjayBpZiB0aGlzIHNsb3QgYWNjZXB0cyB0aGlzIHR5cGUgb2YgZmFjZXRcbiAgICBpZiAodGhpcy5zdXBwb3J0ZWRGYWNldHMuaW5kZXhPZihmYWNldC50eXBlKSA9PT0gLTEpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICAvLyBSZWxlYXNlIHRoaXMgZmlsdGVyLCBhbmQgYWRkIHJlbGV2YW50IHBhcnRpdGlvbiBvciBhZ2dyZWdhdGVcbiAgICBmaWx0ZXIucmVsZWFzZURhdGFGaWx0ZXIoKTtcblxuICAgIGlmICh0aGlzLnR5cGUgPT09ICdwYXJ0aXRpb24nKSB7XG4gICAgICB2YXIgcGFydGl0aW9uID0gZmlsdGVyLnBhcnRpdGlvbnMuYWRkKHtcbiAgICAgICAgZmFjZXROYW1lOiBmYWNldC5uYW1lLFxuICAgICAgICBsYWJlbDogbGFiZWxGb3JQYXJ0aXRpb24oZmFjZXQpLFxuICAgICAgICBzaG93TGFiZWw6ICh0aGlzLnJhbmsgIT09IDEpIHx8ICFmYWNldC5pc0NhdGVnb3JpYWwsXG4gICAgICAgIHJhbms6IHRoaXMucmFua1xuICAgICAgfSk7XG4gICAgICBwYXJ0aXRpb24ucmVzZXQoKTtcbiAgICB9IGVsc2UgaWYgKHRoaXMudHlwZSA9PT0gJ2FnZ3JlZ2F0ZScpIHtcbiAgICAgIGZpbHRlci5hZ2dyZWdhdGVzLmFkZCh7XG4gICAgICAgIGZhY2V0TmFtZTogZmFjZXQubmFtZSxcbiAgICAgICAgbGFiZWw6IGZhY2V0Lm5hbWUsXG4gICAgICAgIHJhbms6IHRoaXMucmFuayxcbiAgICAgICAgb3BlcmF0aW9uOiBvcGVyYXRpb24gfHwgJ2F2ZydcbiAgICAgIH0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zb2xlLmVycm9yKCdJbGxlZ2FsIHNsb3QnKTtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICB0aGlzLmlzRmlsbGVkID0gdHJ1ZTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBOzs7OztBQUtBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUZBO0FBQ0E7QUFHQTs7Ozs7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSkE7QUFDQTtBQUtBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFMQTtBQU9BO0FBQ0E7QUFDQTtBQS9CQTtBQUNBO0FBZ0NBOzs7O0FBSUE7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7Ozs7Ozs7OztBQVNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUpBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFKQTtBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFwR0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///aea4\n")},af18:function(module,exports,__webpack_require__){eval("/*** IMPORTS FROM imports-loader ***/\n(function() {\n\nvar Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar BaseWidget = __webpack_require__(/*! ./base-widget */ \"26ef\");\n\nvar colors = __webpack_require__(/*! ../../colors */ \"eb63\");\n\nvar misval = Spot.util.misval; // NOTE: sigma and sigma plugins do not work properly with require()\n// workaround via browserify-shim (configured in package.json)\n\nvar Sigma = __webpack_require__(/*! sigmajs */ \"2f77\");\n\n__webpack_require__(/*! sigmajsLayoutForceAtlas2 */ \"48ba\");\n\n__webpack_require__(/*! sigmajsRenderersParallelEdges */ \"f2d8\");\n\nfunction _deinitChart(view) {\n  if (view._sigma) {\n    view._sigma.killForceAtlas2();\n\n    view._sigma.kill();\n\n    delete view._sigma;\n  }\n\n  delete view._config;\n  view.isInitialized = false;\n}\n\nfunction _initChart(view) {\n  // Configure plot\n  view._config = view.model.sigmaConfig(); // Get a new sigma plot\n\n  view._sigma = new Sigma({\n    renderers: [{\n      container: view.el,\n      type: 'canvas'\n    }],\n    settings: view._config\n  }); // In callbacks on the chart we will need the view, so store a reference\n\n  view._sigma._Ampersandview = view; // cache for nodes and their positions\n\n  view._nodes = {}; // number of nodes on screen\n\n  view._nnodes = 0;\n  view.isInitialized = true;\n} // test if node exits, and add it if not\n\n\nfunction testNode(view, label) {\n  var alpha;\n  var x;\n  var y;\n\n  if (!view._sigma.graph.nodes(label)) {\n    // try to get previous postion, or generate new one\n    if (view._nodes.hasOwnProperty(label)) {\n      x = view._nodes[label].x;\n      y = view._nodes[label].y;\n    } else {\n      // place all new nodes on a circle\n      alpha = view._nnodes * 2.0 * 3.1415297 / 5.333333;\n      x = 10.0 * Math.cos(alpha);\n      y = 10.0 * Math.sin(alpha);\n    }\n\n    view._sigma.graph.addNode({\n      id: label,\n      label: label,\n      size: 1,\n      color: '#666',\n      x: x,\n      y: y\n    });\n\n    view._nnodes++;\n  }\n}\n\nfunction drawGraph(view) {\n  var filter = view.model.filter;\n  var edgeToCount = {};\n  var count;\n  var type;\n  var edgePartition = view.model.filter.partitions.get(3, 'rank');\n\n  if (edgePartition) {\n    type = 'curve';\n    edgePartition.groups.forEach(function (group, n) {\n      edgeToCount[group.value] = n;\n    });\n  } else {\n    count = 0;\n    type = 'line';\n  } // draw new ones\n\n\n  filter.data.forEach(function (group, id) {\n    if (group.count !== 0 && group.a !== misval && group.b !== misval) {\n      testNode(view, group.a);\n      testNode(view, group.b);\n\n      if (edgePartition) {\n        if (edgeToCount.hasOwnProperty(group.c)) {\n          count = edgeToCount[group.c];\n        } else {\n          return;\n        }\n      } // add edge\n\n\n      view._sigma.graph.addEdge({\n        color: colors.getColor(count).css(),\n        id: 'e' + id,\n        source: group.a,\n        target: group.b,\n        count: count,\n        type: type\n      });\n    }\n  });\n}\n\nfunction _update(view) {\n  if (!view.isInitialized) {\n    return;\n  } // remove graph, but cache the node positions\n\n\n  view._sigma.killForceAtlas2();\n\n  view._nodes = {};\n  view._nnodes = 0;\n\n  view._sigma.graph.nodes().forEach(function (node) {\n    view._nodes[node.id] = node;\n  });\n\n  view._sigma.graph.clear(); // redraw graph\n\n\n  drawGraph(view);\n\n  view._sigma.refresh();\n\n  view._sigma.startForceAtlas2({\n    worker: true,\n    adjustSizes: true,\n    barnesHutOptimize: true,\n    edgeWeightInfluence: 1,\n    slowDown: 10,\n    gravity: 1\n  });\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner sigmajs mdl-card__media\"></div>',\n  update: function update() {\n    _update(this);\n  },\n  initChart: function initChart() {\n    _initChart(this);\n  },\n  deinitChart: function deinitChart() {\n    _deinitChart(this);\n  }\n});\n}.call(window));//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWYxOC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL3ZpZXdzL3NpZ21hLmpzPzc1MzgiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFNwb3QgPSByZXF1aXJlKCdzcG90LWZyYW1ld29yaycpO1xudmFyIEJhc2VXaWRnZXQgPSByZXF1aXJlKCcuL2Jhc2Utd2lkZ2V0Jyk7XG52YXIgY29sb3JzID0gcmVxdWlyZSgnLi4vLi4vY29sb3JzJyk7XG52YXIgbWlzdmFsID0gU3BvdC51dGlsLm1pc3ZhbDtcblxuLy8gTk9URTogc2lnbWEgYW5kIHNpZ21hIHBsdWdpbnMgZG8gbm90IHdvcmsgcHJvcGVybHkgd2l0aCByZXF1aXJlKClcbi8vIHdvcmthcm91bmQgdmlhIGJyb3dzZXJpZnktc2hpbSAoY29uZmlndXJlZCBpbiBwYWNrYWdlLmpzb24pXG52YXIgU2lnbWEgPSByZXF1aXJlKCdzaWdtYWpzJyk7XG5yZXF1aXJlKCdzaWdtYWpzTGF5b3V0Rm9yY2VBdGxhczInKTtcbnJlcXVpcmUoJ3NpZ21hanNSZW5kZXJlcnNQYXJhbGxlbEVkZ2VzJyk7XG5cbmZ1bmN0aW9uIGRlaW5pdENoYXJ0ICh2aWV3KSB7XG4gIGlmICh2aWV3Ll9zaWdtYSkge1xuICAgIHZpZXcuX3NpZ21hLmtpbGxGb3JjZUF0bGFzMigpO1xuICAgIHZpZXcuX3NpZ21hLmtpbGwoKTtcbiAgICBkZWxldGUgdmlldy5fc2lnbWE7XG4gIH1cbiAgZGVsZXRlIHZpZXcuX2NvbmZpZztcbiAgdmlldy5pc0luaXRpYWxpemVkID0gZmFsc2U7XG59XG5cbmZ1bmN0aW9uIGluaXRDaGFydCAodmlldykge1xuICAvLyBDb25maWd1cmUgcGxvdFxuICB2aWV3Ll9jb25maWcgPSB2aWV3Lm1vZGVsLnNpZ21hQ29uZmlnKCk7XG5cbiAgLy8gR2V0IGEgbmV3IHNpZ21hIHBsb3RcbiAgdmlldy5fc2lnbWEgPSBuZXcgU2lnbWEoe1xuICAgIHJlbmRlcmVyczogW3tcbiAgICAgIGNvbnRhaW5lcjogdmlldy5lbCxcbiAgICAgIHR5cGU6ICdjYW52YXMnXG4gICAgfV0sXG4gICAgc2V0dGluZ3M6IHZpZXcuX2NvbmZpZ1xuICB9KTtcblxuICAvLyBJbiBjYWxsYmFja3Mgb24gdGhlIGNoYXJ0IHdlIHdpbGwgbmVlZCB0aGUgdmlldywgc28gc3RvcmUgYSByZWZlcmVuY2VcbiAgdmlldy5fc2lnbWEuX0FtcGVyc2FuZHZpZXcgPSB2aWV3O1xuXG4gIC8vIGNhY2hlIGZvciBub2RlcyBhbmQgdGhlaXIgcG9zaXRpb25zXG4gIHZpZXcuX25vZGVzID0ge307XG5cbiAgLy8gbnVtYmVyIG9mIG5vZGVzIG9uIHNjcmVlblxuICB2aWV3Ll9ubm9kZXMgPSAwO1xuXG4gIHZpZXcuaXNJbml0aWFsaXplZCA9IHRydWU7XG59XG5cbi8vIHRlc3QgaWYgbm9kZSBleGl0cywgYW5kIGFkZCBpdCBpZiBub3RcbmZ1bmN0aW9uIHRlc3ROb2RlICh2aWV3LCBsYWJlbCkge1xuICB2YXIgYWxwaGE7XG4gIHZhciB4O1xuICB2YXIgeTtcblxuICBpZiAoIXZpZXcuX3NpZ21hLmdyYXBoLm5vZGVzKGxhYmVsKSkge1xuICAgIC8vIHRyeSB0byBnZXQgcHJldmlvdXMgcG9zdGlvbiwgb3IgZ2VuZXJhdGUgbmV3IG9uZVxuICAgIGlmICh2aWV3Ll9ub2Rlcy5oYXNPd25Qcm9wZXJ0eShsYWJlbCkpIHtcbiAgICAgIHggPSB2aWV3Ll9ub2Rlc1tsYWJlbF0ueDtcbiAgICAgIHkgPSB2aWV3Ll9ub2Rlc1tsYWJlbF0ueTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gcGxhY2UgYWxsIG5ldyBub2RlcyBvbiBhIGNpcmNsZVxuICAgICAgYWxwaGEgPSB2aWV3Ll9ubm9kZXMgKiAyLjAgKiAzLjE0MTUyOTcgLyA1LjMzMzMzMztcbiAgICAgIHggPSAxMC4wICogTWF0aC5jb3MoYWxwaGEpO1xuICAgICAgeSA9IDEwLjAgKiBNYXRoLnNpbihhbHBoYSk7XG4gICAgfVxuXG4gICAgdmlldy5fc2lnbWEuZ3JhcGguYWRkTm9kZSh7XG4gICAgICBpZDogbGFiZWwsXG4gICAgICBsYWJlbDogbGFiZWwsXG4gICAgICBzaXplOiAxLFxuICAgICAgY29sb3I6ICcjNjY2JyxcbiAgICAgIHg6IHgsXG4gICAgICB5OiB5XG4gICAgfSk7XG4gICAgdmlldy5fbm5vZGVzKys7XG4gIH1cbn1cblxuZnVuY3Rpb24gZHJhd0dyYXBoICh2aWV3KSB7XG4gIHZhciBmaWx0ZXIgPSB2aWV3Lm1vZGVsLmZpbHRlcjtcbiAgdmFyIGVkZ2VUb0NvdW50ID0ge307XG4gIHZhciBjb3VudDtcbiAgdmFyIHR5cGU7XG5cbiAgdmFyIGVkZ2VQYXJ0aXRpb24gPSB2aWV3Lm1vZGVsLmZpbHRlci5wYXJ0aXRpb25zLmdldCgzLCAncmFuaycpO1xuICBpZiAoZWRnZVBhcnRpdGlvbikge1xuICAgIHR5cGUgPSAnY3VydmUnO1xuICAgIGVkZ2VQYXJ0aXRpb24uZ3JvdXBzLmZvckVhY2goZnVuY3Rpb24gKGdyb3VwLCBuKSB7XG4gICAgICBlZGdlVG9Db3VudFtncm91cC52YWx1ZV0gPSBuO1xuICAgIH0pO1xuICB9IGVsc2Uge1xuICAgIGNvdW50ID0gMDtcbiAgICB0eXBlID0gJ2xpbmUnO1xuICB9XG5cbiAgLy8gZHJhdyBuZXcgb25lc1xuICBmaWx0ZXIuZGF0YS5mb3JFYWNoKGZ1bmN0aW9uIChncm91cCwgaWQpIHtcbiAgICBpZiAoZ3JvdXAuY291bnQgIT09IDAgJiYgZ3JvdXAuYSAhPT0gbWlzdmFsICYmIGdyb3VwLmIgIT09IG1pc3ZhbCkge1xuICAgICAgdGVzdE5vZGUodmlldywgZ3JvdXAuYSk7XG4gICAgICB0ZXN0Tm9kZSh2aWV3LCBncm91cC5iKTtcblxuICAgICAgaWYgKGVkZ2VQYXJ0aXRpb24pIHtcbiAgICAgICAgaWYgKGVkZ2VUb0NvdW50Lmhhc093blByb3BlcnR5KGdyb3VwLmMpKSB7XG4gICAgICAgICAgY291bnQgPSBlZGdlVG9Db3VudFtncm91cC5jXTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgLy8gYWRkIGVkZ2VcbiAgICAgIHZpZXcuX3NpZ21hLmdyYXBoLmFkZEVkZ2Uoe1xuICAgICAgICBjb2xvcjogY29sb3JzLmdldENvbG9yKGNvdW50KS5jc3MoKSxcbiAgICAgICAgaWQ6ICdlJyArIGlkLFxuICAgICAgICBzb3VyY2U6IGdyb3VwLmEsXG4gICAgICAgIHRhcmdldDogZ3JvdXAuYixcbiAgICAgICAgY291bnQ6IGNvdW50LFxuICAgICAgICB0eXBlOiB0eXBlXG4gICAgICB9KTtcbiAgICB9XG4gIH0pO1xufVxuXG5mdW5jdGlvbiB1cGRhdGUgKHZpZXcpIHtcbiAgaWYgKCF2aWV3LmlzSW5pdGlhbGl6ZWQpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyByZW1vdmUgZ3JhcGgsIGJ1dCBjYWNoZSB0aGUgbm9kZSBwb3NpdGlvbnNcbiAgdmlldy5fc2lnbWEua2lsbEZvcmNlQXRsYXMyKCk7XG4gIHZpZXcuX25vZGVzID0ge307XG4gIHZpZXcuX25ub2RlcyA9IDA7XG4gIHZpZXcuX3NpZ21hLmdyYXBoLm5vZGVzKCkuZm9yRWFjaChmdW5jdGlvbiAobm9kZSkge1xuICAgIHZpZXcuX25vZGVzW25vZGUuaWRdID0gbm9kZTtcbiAgfSk7XG4gIHZpZXcuX3NpZ21hLmdyYXBoLmNsZWFyKCk7XG5cbiAgLy8gcmVkcmF3IGdyYXBoXG4gIGRyYXdHcmFwaCh2aWV3KTtcbiAgdmlldy5fc2lnbWEucmVmcmVzaCgpO1xuXG4gIHZpZXcuX3NpZ21hLnN0YXJ0Rm9yY2VBdGxhczIoe1xuICAgIHdvcmtlcjogdHJ1ZSxcbiAgICBhZGp1c3RTaXplczogdHJ1ZSxcbiAgICBiYXJuZXNIdXRPcHRpbWl6ZTogdHJ1ZSxcbiAgICBlZGdlV2VpZ2h0SW5mbHVlbmNlOiAxLFxuICAgIHNsb3dEb3duOiAxMCxcbiAgICBncmF2aXR5OiAxXG4gIH0pO1xufVxuXG5tb2R1bGUuZXhwb3J0cyA9IEJhc2VXaWRnZXQuZXh0ZW5kKHtcbiAgdGVtcGxhdGU6ICc8ZGl2IGNsYXNzPVwid2lkZ2V0SW5uZXIgc2lnbWFqcyBtZGwtY2FyZF9fbWVkaWFcIj48L2Rpdj4nLFxuXG4gIHVwZGF0ZTogZnVuY3Rpb24gKCkge1xuICAgIHVwZGF0ZSh0aGlzKTtcbiAgfSxcblxuICBpbml0Q2hhcnQ6IGZ1bmN0aW9uICgpIHtcbiAgICBpbml0Q2hhcnQodGhpcyk7XG4gIH0sXG5cbiAgZGVpbml0Q2hhcnQ6IGZ1bmN0aW9uICgpIHtcbiAgICBkZWluaXRDaGFydCh0aGlzKTtcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiI7OztBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBR0E7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFMQTtBQUNBO0FBUUE7QUFDQTtBQUVBO0FBQ0E7QUFFQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTkE7QUFDQTtBQU9BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBTkE7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFOQTtBQVFBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBYkE7QSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///af18\n")},b24e:function(module,exports,__webpack_require__){eval("function _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nvar Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar misval = Spot.util.misval;\n\nfunction addRawValue(string, raw) {\n  if (typeof string !== 'string' || string.length === 0) {\n    string = '';\n  } else {\n    string = string + ', ';\n  }\n\n  if (typeof raw === 'string') {\n    string = string + '\"' + raw + '\"';\n  } else if (typeof raw === 'number') {\n    string = string + raw;\n  } else {\n    console.warn('Cannot add raw value', raw, 'of type', _typeof(raw));\n  }\n\n  return string;\n}\n\nmodule.exports = View.extend({\n  template: templates.configureFacet.facetDefine,\n  derived: {\n    showMinMax: {\n      deps: ['model.type'],\n      fn: function fn() {\n        return this.model.type === 'datetime' || this.model.type === 'duration' || this.model.type === 'continuous';\n      }\n    }\n  },\n  bindings: {\n    'showMinMax': [{\n      type: 'toggle',\n      hook: 'define-minimum-div'\n    }, {\n      type: 'toggle',\n      hook: 'define-maximum-div'\n    }],\n    'model.name': {\n      type: 'value',\n      hook: 'define-name-input'\n    },\n    'model.units': {\n      type: 'value',\n      hook: 'define-units-input'\n    },\n    'model.description': {\n      type: 'value',\n      hook: 'define-description-input'\n    },\n    'model.isContinuous': {\n      type: 'booleanAttribute',\n      hook: 'define-type-continuous',\n      name: 'checked'\n    },\n    'model.isCategorial': {\n      type: 'booleanAttribute',\n      hook: 'define-type-categorial',\n      name: 'checked'\n    },\n    'model.isDatetime': {\n      type: 'booleanAttribute',\n      hook: 'define-type-datetime',\n      name: 'checked'\n    },\n    'model.isDuration': {\n      type: 'booleanAttribute',\n      hook: 'define-type-duration',\n      name: 'checked'\n    },\n    'model.isText': {\n      type: 'booleanAttribute',\n      hook: 'define-type-text',\n      name: 'checked'\n    },\n    'model.accessor': {\n      type: 'value',\n      hook: 'define-accessor-input'\n    },\n    'model.misvalAsText': {\n      type: 'value',\n      hook: 'define-missing-input'\n    },\n    'model.minvalAsText': {\n      type: 'value',\n      hook: 'define-minimum-input'\n    },\n    'model.maxvalAsText': {\n      type: 'value',\n      hook: 'define-maximum-input'\n    }\n  },\n  events: {\n    'change [data-hook~=define-name-input]': function changeDataHookDefineNameInput() {\n      this.model.name = this.queryByHook('define-name-input').value;\n    },\n    'change [data-hook~=define-units-input]': function changeDataHookDefineUnitsInput() {\n      this.model.units = this.queryByHook('define-units-input').value;\n    },\n    'change [data-hook~=define-description-input]': function changeDataHookDefineDescriptionInput() {\n      this.model.description = this.queryByHook('define-description-input').value;\n    },\n    'click [data-hook~=define-type-continuous]': function clickDataHookDefineTypeContinuous() {\n      this.model.type = 'continuous';\n    },\n    'click [data-hook~=define-type-categorial]': function clickDataHookDefineTypeCategorial() {\n      this.model.type = 'categorial';\n    },\n    'click [data-hook~=define-type-datetime]': function clickDataHookDefineTypeDatetime() {\n      this.model.type = 'datetime';\n    },\n    'click [data-hook~=define-type-duration]': function clickDataHookDefineTypeDuration() {\n      this.model.type = 'duration';\n    },\n    'click [data-hook~=define-type-text]': function clickDataHookDefineTypeText() {\n      this.model.type = 'text';\n    },\n    'click [data-hook~=button-minval-missing]': function clickDataHookButtonMinvalMissing() {\n      if (this.model.minval === misval) {\n        return;\n      }\n\n      if (this.model.hasOwnProperty('rawMinval')) {\n        this.model.misvalAsText = addRawValue(this.model.misvalAsText, this.model.rawMinval);\n      } else {\n        this.model.misvalAsText += ', ' + this.model.minvalAsText;\n      }\n\n      this.model.minvalAsText = 'scanning';\n      this.model.setMinMax();\n      this.queryByHook('define-maximum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('define-minimum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('define-missing-input').dispatchEvent(new window.Event('input'));\n    },\n    'click [data-hook~=button-maxval-missing]': function clickDataHookButtonMaxvalMissing() {\n      if (this.model.maxval === misval) {\n        return;\n      }\n\n      if (this.model.hasOwnProperty('rawMaxval')) {\n        this.model.misvalAsText = addRawValue(this.model.misvalAsText, this.model.rawMaxval);\n      } else {\n        this.model.misvalAsText += ', ' + this.model.maxvalAsText;\n      }\n\n      this.model.maxvalAsText = 'scanning';\n      this.model.setMinMax();\n      this.queryByHook('define-maximum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('define-minimum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('define-missing-input').dispatchEvent(new window.Event('input'));\n    },\n    'click [data-hook~=define-rescan-button]': function clickDataHookDefineRescanButton() {\n      if (this.model.isContinuous || this.model.isDatetime || this.model.isDuration) {\n        this.model.minvalAsText = 'scanning';\n        this.model.maxvalAsText = 'scanning';\n        this.model.setMinMax();\n        this.queryByHook('define-minimum-input').dispatchEvent(new window.Event('input'));\n        this.queryByHook('define-maximum-input').dispatchEvent(new window.Event('input'));\n      } else if (this.model.isCategorial) {\n        this.model.setCategories();\n      }\n    },\n    'change [data-hook~=define-accessor-input]': function changeDataHookDefineAccessorInput() {\n      this.model.accessor = this.queryByHook('define-accessor-input').value;\n    },\n    'change [data-hook~=define-missing-input]': function changeDataHookDefineMissingInput() {\n      this.model.misvalAsText = this.queryByHook('define-missing-input').value;\n    },\n    'change [data-hook~=define-minimum-input]': function changeDataHookDefineMinimumInput() {\n      this.model.minvalAsText = this.queryByHook('define-minimum-input').value;\n    },\n    'change [data-hook~=define-maximum-input]': function changeDataHookDefineMaximumInput() {\n      this.model.maxvalAsText = this.queryByHook('define-maximum-input').value;\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"b24e.js","sources":["webpack:///./src/pages/configure-facet/facet-define.js?d51c"],"sourcesContent":["var Spot = require('spot-framework');\nvar View = require('ampersand-view');\nvar templates = require('../../templates');\nvar misval = Spot.util.misval;\n\nfunction addRawValue (string, raw) {\n  if (typeof string !== 'string' || string.length === 0) {\n    string = '';\n  } else {\n    string = string + ', ';\n  }\n\n  if (typeof raw === 'string') {\n    string = string + '\"' + raw + '\"';\n  } else if (typeof raw === 'number') {\n    string = string + raw;\n  } else {\n    console.warn('Cannot add raw value', raw, 'of type', typeof raw);\n  }\n  return string;\n}\n\nmodule.exports = View.extend({\n  template: templates.configureFacet.facetDefine,\n  derived: {\n    showMinMax: {\n      deps: ['model.type'],\n      fn: function () {\n        return this.model.type === 'datetime' || this.model.type === 'duration' || this.model.type === 'continuous';\n      }\n    }\n  },\n  bindings: {\n    'showMinMax': [\n      {\n        type: 'toggle',\n        hook: 'define-minimum-div'\n      },\n      {\n        type: 'toggle',\n        hook: 'define-maximum-div'\n      }\n    ],\n    'model.name': {\n      type: 'value',\n      hook: 'define-name-input'\n    },\n    'model.units': {\n      type: 'value',\n      hook: 'define-units-input'\n    },\n    'model.description': {\n      type: 'value',\n      hook: 'define-description-input'\n    },\n\n    'model.isContinuous': {\n      type: 'booleanAttribute',\n      hook: 'define-type-continuous',\n      name: 'checked'\n    },\n    'model.isCategorial': {\n      type: 'booleanAttribute',\n      hook: 'define-type-categorial',\n      name: 'checked'\n    },\n    'model.isDatetime': {\n      type: 'booleanAttribute',\n      hook: 'define-type-datetime',\n      name: 'checked'\n    },\n    'model.isDuration': {\n      type: 'booleanAttribute',\n      hook: 'define-type-duration',\n      name: 'checked'\n    },\n    'model.isText': {\n      type: 'booleanAttribute',\n      hook: 'define-type-text',\n      name: 'checked'\n    },\n\n    'model.accessor': {\n      type: 'value',\n      hook: 'define-accessor-input'\n    },\n    'model.misvalAsText': {\n      type: 'value',\n      hook: 'define-missing-input'\n    },\n    'model.minvalAsText': {\n      type: 'value',\n      hook: 'define-minimum-input'\n    },\n    'model.maxvalAsText': {\n      type: 'value',\n      hook: 'define-maximum-input'\n    }\n  },\n  events: {\n    'change [data-hook~=define-name-input]': function () {\n      this.model.name = this.queryByHook('define-name-input').value;\n    },\n    'change [data-hook~=define-units-input]': function () {\n      this.model.units = this.queryByHook('define-units-input').value;\n    },\n    'change [data-hook~=define-description-input]': function () {\n      this.model.description = this.queryByHook('define-description-input').value;\n    },\n\n    'click [data-hook~=define-type-continuous]': function () {\n      this.model.type = 'continuous';\n    },\n    'click [data-hook~=define-type-categorial]': function () {\n      this.model.type = 'categorial';\n    },\n    'click [data-hook~=define-type-datetime]': function () {\n      this.model.type = 'datetime';\n    },\n    'click [data-hook~=define-type-duration]': function () {\n      this.model.type = 'duration';\n    },\n    'click [data-hook~=define-type-text]': function () {\n      this.model.type = 'text';\n    },\n    'click [data-hook~=button-minval-missing]': function () {\n      if (this.model.minval === misval) {\n        return;\n      }\n      if (this.model.hasOwnProperty('rawMinval')) {\n        this.model.misvalAsText = addRawValue(this.model.misvalAsText, this.model.rawMinval);\n      } else {\n        this.model.misvalAsText += ', ' + this.model.minvalAsText;\n      }\n      this.model.minvalAsText = 'scanning';\n      this.model.setMinMax();\n      this.queryByHook('define-maximum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('define-minimum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('define-missing-input').dispatchEvent(new window.Event('input'));\n    },\n    'click [data-hook~=button-maxval-missing]': function () {\n      if (this.model.maxval === misval) {\n        return;\n      }\n      if (this.model.hasOwnProperty('rawMaxval')) {\n        this.model.misvalAsText = addRawValue(this.model.misvalAsText, this.model.rawMaxval);\n      } else {\n        this.model.misvalAsText += ', ' + this.model.maxvalAsText;\n      }\n      this.model.maxvalAsText = 'scanning';\n      this.model.setMinMax();\n      this.queryByHook('define-maximum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('define-minimum-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('define-missing-input').dispatchEvent(new window.Event('input'));\n    },\n    'click [data-hook~=define-rescan-button]': function () {\n      if (this.model.isContinuous || this.model.isDatetime || this.model.isDuration) {\n        this.model.minvalAsText = 'scanning';\n        this.model.maxvalAsText = 'scanning';\n        this.model.setMinMax();\n        this.queryByHook('define-minimum-input').dispatchEvent(new window.Event('input'));\n        this.queryByHook('define-maximum-input').dispatchEvent(new window.Event('input'));\n      } else if (this.model.isCategorial) {\n        this.model.setCategories();\n      }\n    },\n\n    'change [data-hook~=define-accessor-input]': function () {\n      this.model.accessor = this.queryByHook('define-accessor-input').value;\n    },\n    'change [data-hook~=define-missing-input]': function () {\n      this.model.misvalAsText = this.queryByHook('define-missing-input').value;\n    },\n    'change [data-hook~=define-minimum-input]': function () {\n      this.model.minvalAsText = this.queryByHook('define-minimum-input').value;\n    },\n    'change [data-hook~=define-maximum-input]': function () {\n      this.model.maxvalAsText = this.queryByHook('define-maximum-input').value;\n    }\n  }\n});\n"],"mappings":";;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAJA;AADA;AAQA;AACA;AAEA;AACA;AAFA;AAKA;AACA;AAFA;AAKA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAKA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AAHA;AAMA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AA9DA;AAmEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA/EA;AA7EA","sourceRoot":""}\n//# sourceURL=webpack-internal:///b24e\n")},b322:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar moment = __webpack_require__(/*! moment-timezone */ \"6c9d\");\n\nmodule.exports = View.extend({\n  template: templates.configurePartition.partitionDuration,\n  derived: {\n    minvalAsText: {\n      deps: ['model.minval', 'model.isDuration'],\n      fn: function fn() {\n        if (this.model.isDuration) {\n          return this.model.minval.toISOString();\n        } else {\n          return 'not a date';\n        }\n      }\n    },\n    maxvalAsText: {\n      deps: ['model.maxval', 'model.isDuration'],\n      fn: function fn() {\n        if (this.model.isDuration) {\n          return this.model.maxval.toISOString();\n        } else {\n          return 'not a date';\n        }\n      }\n    }\n  },\n  bindings: {\n    'model.isDuration': {\n      type: 'toggle',\n      hook: 'group-duration-panel'\n    },\n    'minvalAsText': {\n      type: 'value',\n      hook: 'group-startduration-input'\n    },\n    'maxvalAsText': {\n      type: 'value',\n      hook: 'group-endduration-input'\n    }\n  },\n  events: {\n    'click [data-hook~=group-durationrange-button]': function clickDataHookGroupDurationrangeButton() {\n      var partition = this.model;\n      partition.reset();\n      this.queryByHook('group-startduration-input').dispatchEvent(new window.Event('input'));\n      this.queryByHook('group-endduration-input').dispatchEvent(new window.Event('input'));\n      this.parent.resetFilter = true;\n    },\n    'change [data-hook~=group-startduration-input]': function changeDataHookGroupStartdurationInput() {\n      var d = moment.duration(this.queryByHook('group-startduration-input').value);\n\n      if (moment.isDuration(d)) {\n        this.model.minval = d;\n      }\n\n      this.parent.resetFilter = true;\n    },\n    'change [data-hook~=group-endduration-input]': function changeDataHookGroupEnddurationInput() {\n      var d = moment.duration(this.queryByHook('group-endduration-input').value);\n\n      if (moment.isDuration(d)) {\n        this.model.maxval = d;\n      }\n\n      this.parent.resetFilter = true;\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYjMyMi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtcGFydGl0aW9uL3BhcnRpdGlvbi1kdXJhdGlvbi5qcz9jZjk0Il0sInNvdXJjZXNDb250ZW50IjpbInZhciBWaWV3ID0gcmVxdWlyZSgnYW1wZXJzYW5kLXZpZXcnKTtcbnZhciB0ZW1wbGF0ZXMgPSByZXF1aXJlKCcuLi8uLi90ZW1wbGF0ZXMnKTtcbnZhciBtb21lbnQgPSByZXF1aXJlKCdtb21lbnQtdGltZXpvbmUnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuY29uZmlndXJlUGFydGl0aW9uLnBhcnRpdGlvbkR1cmF0aW9uLFxuICBkZXJpdmVkOiB7XG4gICAgbWludmFsQXNUZXh0OiB7XG4gICAgICBkZXBzOiBbJ21vZGVsLm1pbnZhbCcsICdtb2RlbC5pc0R1cmF0aW9uJ10sXG4gICAgICBmbjogZnVuY3Rpb24gKCkge1xuICAgICAgICBpZiAodGhpcy5tb2RlbC5pc0R1cmF0aW9uKSB7XG4gICAgICAgICAgcmV0dXJuIHRoaXMubW9kZWwubWludmFsLnRvSVNPU3RyaW5nKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcmV0dXJuICdub3QgYSBkYXRlJztcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sXG4gICAgbWF4dmFsQXNUZXh0OiB7XG4gICAgICBkZXBzOiBbJ21vZGVsLm1heHZhbCcsICdtb2RlbC5pc0R1cmF0aW9uJ10sXG4gICAgICBmbjogZnVuY3Rpb24gKCkge1xuICAgICAgICBpZiAodGhpcy5tb2RlbC5pc0R1cmF0aW9uKSB7XG4gICAgICAgICAgcmV0dXJuIHRoaXMubW9kZWwubWF4dmFsLnRvSVNPU3RyaW5nKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcmV0dXJuICdub3QgYSBkYXRlJztcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfSxcbiAgYmluZGluZ3M6IHtcbiAgICAnbW9kZWwuaXNEdXJhdGlvbic6IHtcbiAgICAgIHR5cGU6ICd0b2dnbGUnLFxuICAgICAgaG9vazogJ2dyb3VwLWR1cmF0aW9uLXBhbmVsJ1xuICAgIH0sXG5cbiAgICAnbWludmFsQXNUZXh0Jzoge1xuICAgICAgdHlwZTogJ3ZhbHVlJyxcbiAgICAgIGhvb2s6ICdncm91cC1zdGFydGR1cmF0aW9uLWlucHV0J1xuICAgIH0sXG4gICAgJ21heHZhbEFzVGV4dCc6IHtcbiAgICAgIHR5cGU6ICd2YWx1ZScsXG4gICAgICBob29rOiAnZ3JvdXAtZW5kZHVyYXRpb24taW5wdXQnXG4gICAgfVxuXG4gIH0sXG4gIGV2ZW50czoge1xuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1kdXJhdGlvbnJhbmdlLWJ1dHRvbl0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB2YXIgcGFydGl0aW9uID0gdGhpcy5tb2RlbDtcbiAgICAgIHBhcnRpdGlvbi5yZXNldCgpO1xuXG4gICAgICB0aGlzLnF1ZXJ5QnlIb29rKCdncm91cC1zdGFydGR1cmF0aW9uLWlucHV0JykuZGlzcGF0Y2hFdmVudChuZXcgd2luZG93LkV2ZW50KCdpbnB1dCcpKTtcbiAgICAgIHRoaXMucXVlcnlCeUhvb2soJ2dyb3VwLWVuZGR1cmF0aW9uLWlucHV0JykuZGlzcGF0Y2hFdmVudChuZXcgd2luZG93LkV2ZW50KCdpbnB1dCcpKTtcbiAgICAgIHRoaXMucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9LFxuICAgICdjaGFuZ2UgW2RhdGEtaG9va349Z3JvdXAtc3RhcnRkdXJhdGlvbi1pbnB1dF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB2YXIgZCA9IG1vbWVudC5kdXJhdGlvbih0aGlzLnF1ZXJ5QnlIb29rKCdncm91cC1zdGFydGR1cmF0aW9uLWlucHV0JykudmFsdWUpO1xuICAgICAgaWYgKG1vbWVudC5pc0R1cmF0aW9uKGQpKSB7XG4gICAgICAgIHRoaXMubW9kZWwubWludmFsID0gZDtcbiAgICAgIH1cbiAgICAgIHRoaXMucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9LFxuICAgICdjaGFuZ2UgW2RhdGEtaG9va349Z3JvdXAtZW5kZHVyYXRpb24taW5wdXRdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdmFyIGQgPSBtb21lbnQuZHVyYXRpb24odGhpcy5xdWVyeUJ5SG9vaygnZ3JvdXAtZW5kZHVyYXRpb24taW5wdXQnKS52YWx1ZSk7XG4gICAgICBpZiAobW9tZW50LmlzRHVyYXRpb24oZCkpIHtcbiAgICAgICAgdGhpcy5tb2RlbC5tYXh2YWwgPSBkO1xuICAgICAgfVxuICAgICAgdGhpcy5wYXJlbnQucmVzZXRGaWx0ZXIgPSB0cnVlO1xuICAgIH1cbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQVJBO0FBVUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBUkE7QUFYQTtBQXNCQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBS0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFGQTtBQVZBO0FBZ0JBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUF0QkE7QUF4Q0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///b322\n")},b43e:function(module,exports){eval('module.exports = {\n  steps: function steps() {\n    return [// {\n      //     element: document.getElementById(\'saveSessionButton\'),\n      //     position: "bottom",\n      //     intro: "Ok, wasn\'t that fun?",\n      // }\n    ];\n  },\n  hints: function hints() {\n    return [{\n      element: document.getElementById(\'saveSessionButton\'),\n      hintPosition: "bottom",\n      hint: "This buttons saves the current session."\n    }, {\n      element: document.getElementById(\'resetFiltersButton\'),\n      hintPosition: "bottom",\n      hint: "This buttons resets all the filters."\n    }];\n  }\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYjQzZS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9oZWxwL2FuYWx5emUuanM/ZDhhMSJdLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IHtcbiAgICBzdGVwczogZnVuY3Rpb24oKSB7XG4gICAgICAgIHJldHVybiBbXG4gICAgICAgICAgICAvLyB7XG4gICAgICAgICAgICAvLyAgICAgZWxlbWVudDogZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ3NhdmVTZXNzaW9uQnV0dG9uJyksXG4gICAgICAgICAgICAvLyAgICAgcG9zaXRpb246IFwiYm90dG9tXCIsXG4gICAgICAgICAgICAvLyAgICAgaW50cm86IFwiT2ssIHdhc24ndCB0aGF0IGZ1bj9cIixcbiAgICAgICAgICAgIC8vIH1cbiAgICAgICAgXTtcbiAgICB9LFxuICAgIGhpbnRzOiBmdW5jdGlvbigpIHtcbiAgICAgICAgcmV0dXJuIFtcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBlbGVtZW50OiBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnc2F2ZVNlc3Npb25CdXR0b24nKSxcbiAgICAgICAgICAgICAgICBoaW50UG9zaXRpb246IFwiYm90dG9tXCIsXG4gICAgICAgICAgICAgICAgaGludDogXCJUaGlzIGJ1dHRvbnMgc2F2ZXMgdGhlIGN1cnJlbnQgc2Vzc2lvbi5cIlxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBlbGVtZW50OiBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgncmVzZXRGaWx0ZXJzQnV0dG9uJyksXG4gICAgICAgICAgICAgICAgaGludFBvc2l0aW9uOiBcImJvdHRvbVwiLFxuICAgICAgICAgICAgICAgIGhpbnQ6IFwiVGhpcyBidXR0b25zIHJlc2V0cyBhbGwgdGhlIGZpbHRlcnMuXCJcbiAgICAgICAgICAgIH1cbiAgICAgICAgXTtcbiAgICB9ICAgIFxufTsiXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBTEE7QUFPQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFIQTtBQU1BO0FBQ0E7QUFDQTtBQUhBO0FBTUE7QUF2QkEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///b43e\n')},b966:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\"); // var key = require('keymaster')\n\n\nmodule.exports = View.extend({\n  // register keyboard handlers\n  registerKeyboardShortcuts: function registerKeyboardShortcuts() {\n    /*\n    var self = this\n    _.each(this.keyboardShortcuts, function (value, k) {\n        // register key handler scoped to this page\n        key(k, self.cid, _.bind(self[value], self))\n    })\n    key.setScope(this.cid)\n    */\n  },\n  unregisterKeyboardShortcuts: function unregisterKeyboardShortcuts() {// key.deleteScope(this.cid)\n  },\n  props: {\n    pageName: 'string'\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYjk2Ni5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9iYXNlLmpzP2U0NWUiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xuLy8gdmFyIGtleSA9IHJlcXVpcmUoJ2tleW1hc3RlcicpXG5cbm1vZHVsZS5leHBvcnRzID0gVmlldy5leHRlbmQoe1xuICAvLyByZWdpc3RlciBrZXlib2FyZCBoYW5kbGVyc1xuICByZWdpc3RlcktleWJvYXJkU2hvcnRjdXRzOiBmdW5jdGlvbiAoKSB7XG4gICAgLypcbiAgICB2YXIgc2VsZiA9IHRoaXNcbiAgICBfLmVhY2godGhpcy5rZXlib2FyZFNob3J0Y3V0cywgZnVuY3Rpb24gKHZhbHVlLCBrKSB7XG4gICAgICAgIC8vIHJlZ2lzdGVyIGtleSBoYW5kbGVyIHNjb3BlZCB0byB0aGlzIHBhZ2VcbiAgICAgICAga2V5KGssIHNlbGYuY2lkLCBfLmJpbmQoc2VsZlt2YWx1ZV0sIHNlbGYpKVxuICAgIH0pXG4gICAga2V5LnNldFNjb3BlKHRoaXMuY2lkKVxuICAgICovXG4gIH0sXG4gIHVucmVnaXN0ZXJLZXlib2FyZFNob3J0Y3V0czogZnVuY3Rpb24gKCkge1xuICAgIC8vIGtleS5kZWxldGVTY29wZSh0aGlzLmNpZClcbiAgfSxcbiAgcHJvcHM6IHtcbiAgICBwYWdlTmFtZTogJ3N0cmluZydcbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7Ozs7OztBQVFBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFEQTtBQWZBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///b966\n")},bdff:function(module,exports,__webpack_require__){eval("var AmpersandModel = __webpack_require__(/*! ampersand-model */ \"3bfc\");\n\nmodule.exports = AmpersandModel.extend({\n  props: {\n    id: 'string',\n    date: 'string',\n    name: 'string'\n  },\n  session: {\n    isActive: ['boolean', true, false]\n  },\n  derived: {// fullName: {\n    //     deps: ['date', 'name'],\n    //     fn: function () {\n    //         return this.firstName + ' ' + this.lastName;\n    //     }\n    // }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmRmZi5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9kYXRhc2V0cy9zZXNzaW9uLW1vZGVsLmpzPzcwZWYiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIEFtcGVyc2FuZE1vZGVsID0gcmVxdWlyZSgnYW1wZXJzYW5kLW1vZGVsJyk7XG5cbm1vZHVsZS5leHBvcnRzID0gQW1wZXJzYW5kTW9kZWwuZXh0ZW5kKHtcbiAgICBwcm9wczoge1xuICAgICAgICBpZDogJ3N0cmluZycsXG4gICAgICAgIGRhdGU6ICdzdHJpbmcnLFxuICAgICAgICBuYW1lOiAnc3RyaW5nJ1xuICAgIH0sXG4gICAgc2Vzc2lvbjoge1xuICAgICAgICBpc0FjdGl2ZTogWydib29sZWFuJywgdHJ1ZSwgZmFsc2VdLFxuICAgIH0sXG4gICAgZGVyaXZlZDoge1xuICAgICAgICAvLyBmdWxsTmFtZToge1xuICAgICAgICAvLyAgICAgZGVwczogWydkYXRlJywgJ25hbWUnXSxcbiAgICAgICAgLy8gICAgIGZuOiBmdW5jdGlvbiAoKSB7XG4gICAgICAgIC8vICAgICAgICAgcmV0dXJuIHRoaXMuZmlyc3ROYW1lICsgJyAnICsgdGhpcy5sYXN0TmFtZTtcbiAgICAgICAgLy8gICAgIH1cbiAgICAgICAgLy8gfVxuICAgIH1cbn0pOyJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFIQTtBQUtBO0FBQ0E7QUFEQTtBQUdBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQU5BO0FBVEEiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///bdff\n")},c678:function(module,exports,__webpack_require__){eval("var Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar timeUtil = Spot.util.time; // this.model should be a DatetimeTransform\n\nvar TimePartView = View.extend({\n  template: '<option data-hook=\"option\"> </option>',\n  render: function render() {\n    this.renderWithTemplate(this);\n  },\n  bindings: {\n    'model.description': [{\n      hook: 'option',\n      type: 'text'\n    }, {\n      hook: 'option',\n      type: 'attribute',\n      name: 'value'\n    }]\n  }\n});\nmodule.exports = View.extend({\n  template: '<select data-hook=\"options\"> </select>',\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.renderCollection(timeUtil.timeParts, TimePartView, this.queryByHook('options'));\n    var value = this.model.transformedFormat;\n    this.queryByHook('options').value = value;\n  },\n  events: {\n    'change [data-hook=\"options\"]': 'changeTimePart'\n  },\n  changeTimePart: function changeTimePart() {\n    var value = this.queryByHook('options').value;\n    this.model.transformedFormat = value;\n\n    if (this.parent.parent.resetFilter === false) {\n      this.parent.parent.resetFilter = true;\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzY3OC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQvdGltZS1wYXJ0cy1zZWxlY3QuanM/ZDlhZCJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgU3BvdCA9IHJlcXVpcmUoJ3Nwb3QtZnJhbWV3b3JrJyk7XG52YXIgVmlldyA9IHJlcXVpcmUoJ2FtcGVyc2FuZC12aWV3Jyk7XG52YXIgdGltZVV0aWwgPSBTcG90LnV0aWwudGltZTtcblxuLy8gdGhpcy5tb2RlbCBzaG91bGQgYmUgYSBEYXRldGltZVRyYW5zZm9ybVxuXG52YXIgVGltZVBhcnRWaWV3ID0gVmlldy5leHRlbmQoe1xuICB0ZW1wbGF0ZTogJzxvcHRpb24gZGF0YS1ob29rPVwib3B0aW9uXCI+IDwvb3B0aW9uPicsXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVuZGVyV2l0aFRlbXBsYXRlKHRoaXMpO1xuICB9LFxuICBiaW5kaW5nczoge1xuICAgICdtb2RlbC5kZXNjcmlwdGlvbic6IFtcbiAgICAgIHtcbiAgICAgICAgaG9vazogJ29wdGlvbicsXG4gICAgICAgIHR5cGU6ICd0ZXh0J1xuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgaG9vazogJ29wdGlvbicsXG4gICAgICAgIHR5cGU6ICdhdHRyaWJ1dGUnLFxuICAgICAgICBuYW1lOiAndmFsdWUnXG4gICAgICB9XG4gICAgXVxuICB9XG59KTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiAnPHNlbGVjdCBkYXRhLWhvb2s9XCJvcHRpb25zXCI+IDwvc2VsZWN0PicsXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVuZGVyV2l0aFRlbXBsYXRlKHRoaXMpO1xuICAgIHRoaXMucmVuZGVyQ29sbGVjdGlvbih0aW1lVXRpbC50aW1lUGFydHMsIFRpbWVQYXJ0VmlldywgdGhpcy5xdWVyeUJ5SG9vaygnb3B0aW9ucycpKTtcblxuICAgIHZhciB2YWx1ZSA9IHRoaXMubW9kZWwudHJhbnNmb3JtZWRGb3JtYXQ7XG4gICAgdGhpcy5xdWVyeUJ5SG9vaygnb3B0aW9ucycpLnZhbHVlID0gdmFsdWU7XG4gIH0sXG4gIGV2ZW50czoge1xuICAgICdjaGFuZ2UgW2RhdGEtaG9vaz1cIm9wdGlvbnNcIl0nOiAnY2hhbmdlVGltZVBhcnQnXG4gIH0sXG4gIGNoYW5nZVRpbWVQYXJ0OiBmdW5jdGlvbiAoKSB7XG4gICAgdmFyIHZhbHVlID0gdGhpcy5xdWVyeUJ5SG9vaygnb3B0aW9ucycpLnZhbHVlO1xuICAgIHRoaXMubW9kZWwudHJhbnNmb3JtZWRGb3JtYXQgPSB2YWx1ZTtcbiAgICBpZiAodGhpcy5wYXJlbnQucGFyZW50LnJlc2V0RmlsdGVyID09PSBmYWxzZSkge1xuICAgICAgdGhpcy5wYXJlbnQucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFGQTtBQUtBO0FBQ0E7QUFDQTtBQUhBO0FBTkE7QUFMQTtBQW9CQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQWxCQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///c678\n")},c783:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nmodule.exports = View.extend({\n  template: templates.configureFacet.categorialRule,\n  bindings: {\n    'model.expression': {\n      type: 'value',\n      hook: 'category-expression-input'\n    },\n    'model.count': {\n      type: 'text',\n      hook: 'category-value-count'\n    },\n    'model.group': {\n      type: 'value',\n      hook: 'category-group-input'\n    }\n  },\n  events: {\n    'click [data-hook~=category-remove]': function clickDataHookCategoryRemove() {\n      this.collection.remove(this.model);\n    },\n    'change [data-hook~=category-expression-input]': function changeDataHookCategoryExpressionInput() {\n      this.model.expression = this.queryByHook('category-expression-input').value;\n    },\n    'change [data-hook~=category-group-input]': function changeDataHookCategoryGroupInput() {\n      this.model.group = this.queryByHook('category-group-input').value;\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzc4My5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQvY2F0ZWdvcmlhbC1ydWxlLmpzPzdjMWYiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFZpZXcuZXh0ZW5kKHtcbiAgdGVtcGxhdGU6IHRlbXBsYXRlcy5jb25maWd1cmVGYWNldC5jYXRlZ29yaWFsUnVsZSxcbiAgYmluZGluZ3M6IHtcbiAgICAnbW9kZWwuZXhwcmVzc2lvbic6IHtcbiAgICAgIHR5cGU6ICd2YWx1ZScsXG4gICAgICBob29rOiAnY2F0ZWdvcnktZXhwcmVzc2lvbi1pbnB1dCdcbiAgICB9LFxuICAgICdtb2RlbC5jb3VudCc6IHtcbiAgICAgIHR5cGU6ICd0ZXh0JyxcbiAgICAgIGhvb2s6ICdjYXRlZ29yeS12YWx1ZS1jb3VudCdcbiAgICB9LFxuICAgICdtb2RlbC5ncm91cCc6IHtcbiAgICAgIHR5cGU6ICd2YWx1ZScsXG4gICAgICBob29rOiAnY2F0ZWdvcnktZ3JvdXAtaW5wdXQnXG4gICAgfVxuICB9LFxuICBldmVudHM6IHtcbiAgICAnY2xpY2sgW2RhdGEtaG9va349Y2F0ZWdvcnktcmVtb3ZlXSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMuY29sbGVjdGlvbi5yZW1vdmUodGhpcy5tb2RlbCk7XG4gICAgfSxcbiAgICAnY2hhbmdlIFtkYXRhLWhvb2t+PWNhdGVnb3J5LWV4cHJlc3Npb24taW5wdXRdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5tb2RlbC5leHByZXNzaW9uID0gdGhpcy5xdWVyeUJ5SG9vaygnY2F0ZWdvcnktZXhwcmVzc2lvbi1pbnB1dCcpLnZhbHVlO1xuICAgIH0sXG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj1jYXRlZ29yeS1ncm91cC1pbnB1dF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLmdyb3VwID0gdGhpcy5xdWVyeUJ5SG9vaygnY2F0ZWdvcnktZ3JvdXAtaW5wdXQnKS52YWx1ZTtcbiAgICB9XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUZBO0FBSUE7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQUNBO0FBQ0E7QUFGQTtBQVRBO0FBY0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFUQTtBQWhCQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///c783\n")},d11f:function(module,exports,__webpack_require__){"use strict";eval("/* global window: false */\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nvar moment = __webpack_require__(/*! moment-timezone */ \"6c9d\");\n\nfunction prettyPrintDuration(tick) {\n  var parts = [];\n  var count;\n  var remainder = moment.duration(tick);\n  count = Math.floor(remainder.asYears());\n\n  if (count) {\n    if (count === 1) {\n      parts.push('1 year');\n    } else {\n      parts.push(count.toString() + ' years');\n    }\n  }\n\n  remainder.subtract(count, 'years');\n  count = Math.floor(remainder.asMonths());\n\n  if (count) {\n    if (count === 1) {\n      parts.push('1 month');\n    } else {\n      parts.push(count.toString() + ' months');\n    }\n  }\n\n  remainder.subtract(count, 'months');\n  count = Math.floor(remainder.asWeeks());\n\n  if (count) {\n    if (count === 1) {\n      parts.push('1 week');\n    } else {\n      parts.push(count.toString() + ' weeks');\n    }\n  }\n\n  remainder.subtract(count, 'weeks');\n  count = Math.floor(remainder.asDays());\n\n  if (count) {\n    if (count === 1) {\n      parts.push('1 day');\n    } else {\n      parts.push(count.toString() + ' days');\n    }\n  }\n\n  remainder.subtract(count, 'days');\n  count = Math.floor(remainder.asHours());\n\n  if (count) {\n    if (count === 1) {\n      parts.push('1 hour');\n    } else {\n      parts.push(count.toString() + ' hours');\n    }\n  }\n\n  remainder.subtract(count, 'hours');\n  count = Math.floor(remainder.asMinutes());\n\n  if (count) {\n    if (count === 1) {\n      parts.push('1 minute');\n    } else {\n      parts.push(count.toString() + ' minutes');\n    }\n  }\n\n  remainder.subtract(count, 'minutes');\n  count = Math.floor(remainder.asSeconds());\n\n  if (count) {\n    if (count === 1) {\n      parts.push('1 second');\n    } else {\n      parts.push(count.toString() + ' seconds');\n    }\n  }\n\n  remainder.subtract(count, 'seconds');\n  count = Math.floor(remainder.asMilliseconds());\n\n  if (count) {\n    if (count === 1) {\n      parts.push('1 millisecond');\n    } else {\n      parts.push(count.toString() + ' milliseconds');\n    }\n  }\n\n  return parts.join(' ');\n}\n\nvar time = {\n  units: [{\n    name: 'millisecond',\n    steps: [1, 2, 5, 10, 20, 50, 100, 250, 500]\n  }, {\n    name: 'second',\n    steps: [1, 2, 5, 10, 30]\n  }, {\n    name: 'minute',\n    steps: [1, 2, 5, 10, 30]\n  }, {\n    name: 'hour',\n    steps: [1, 2, 3, 6, 12]\n  }, {\n    name: 'day',\n    steps: [1, 2, 5]\n  }, {\n    name: 'week',\n    maxStep: 4\n  }, {\n    name: 'month',\n    maxStep: 3 //  }, {\n    //    name: 'quarter',\n    //    maxStep: 4\n\n  }, {\n    name: 'year',\n    maxStep: false\n  }]\n};\nvar defaultConfig = {};\n\nmodule.exports = function (Chart, moment) {\n  var helpers = Chart.helpers;\n  moment = moment || __webpack_require__(/*! moment */ \"da01\");\n  var DurationScale = Chart.Scale.extend({\n    getLabelMoment: function getLabelMoment(datasetIndex, index) {\n      if (datasetIndex === null || index === null) {\n        return null;\n      }\n\n      if (typeof this.labelMoments[datasetIndex] !== 'undefined') {\n        return this.labelMoments[datasetIndex][index];\n      }\n\n      return null;\n    },\n    getLabelDiff: function getLabelDiff(datasetIndex, index) {\n      var me = this;\n\n      if (datasetIndex === null || index === null) {\n        return null;\n      }\n\n      if (me.labelDiffs === undefined) {\n        me.buildLabelDiffs();\n      }\n\n      if (typeof me.labelDiffs[datasetIndex] !== 'undefined') {\n        return me.labelDiffs[datasetIndex][index];\n      }\n\n      return null;\n    },\n    getMomentStartOf: function getMomentStartOf(tick) {\n      var me = this;\n      return moment.duration(Math.floor(tick.as(me.tickUnit)), me.tickUnit);\n    },\n    determineDataLimits: function determineDataLimits() {\n      var me = this;\n      me.labelMoments = []; // Get min max from labels\n\n      var scaleLabelMoments = [];\n\n      if (me.chart.data.labels && me.chart.data.labels.length > 0) {\n        me.firstTick = null;\n        me.lastTick = null;\n        helpers.each(me.chart.data.labels, function (label) {\n          var labelMoment = me.parseDuration(label);\n          scaleLabelMoments.push(labelMoment);\n\n          if (me.firstTick === null || me.firstTick > labelMoment) {\n            me.firstTick = labelMoment;\n          }\n\n          if (me.lastTick === null || me.lastTick < labelMoment) {\n            me.lastTick = labelMoment;\n          }\n        }, me);\n      } else {\n        me.firstTick = moment.duration('PT1S');\n        me.lastTick = moment.duration('PT10S');\n      } // Adjust min max from datasets, and build the labelMoments[dataset][point] array\n\n\n      helpers.each(me.chart.data.datasets, function (dataset, datasetIndex) {\n        var momentsForDataset = [];\n        var datasetVisible = me.chart.isDatasetVisible(datasetIndex);\n\n        if (_typeof(dataset.data[0]) === 'object' && dataset.data[0] !== null) {\n          helpers.each(dataset.data, function (value) {\n            var labelMoment;\n\n            if (me.isHorizontal()) {\n              labelMoment = me.parseDuration(value.x);\n            } else {\n              labelMoment = me.parseDuration(value.y);\n            }\n\n            momentsForDataset.push(labelMoment);\n\n            if (datasetVisible) {\n              // May have gone outside the scale ranges, make sure we keep the first and last ticks updated\n              me.firstTick = me.firstTick > labelMoment ? labelMoment : me.firstTick;\n              me.lastTick = me.lastTick < labelMoment ? labelMoment : me.lastTick;\n            }\n          }, me);\n        } else {\n          // We have no labels. Use the ones from the scale\n          momentsForDataset = scaleLabelMoments;\n        }\n\n        me.labelMoments.push(momentsForDataset);\n      }, me); // We will modify these, so clone for later\n\n      me.firstTick = moment.duration(me.firstTick);\n      me.lastTick = moment.duration(me.lastTick);\n    },\n    buildLabelDiffs: function buildLabelDiffs() {\n      var me = this;\n      me.labelDiffs = [];\n      var scaleLabelDiffs = []; // Parse common labels once\n\n      if (me.chart.data.labels && me.chart.data.labels.length > 0) {\n        helpers.each(me.chart.data.labels, function (label) {\n          var labelMoment = me.parseDuration(label);\n\n          if (moment.isDuration(labelMoment)) {\n            scaleLabelDiffs.push(moment.duration(labelMoment).subtract(me.firstTick).as(me.tickUnit));\n          }\n        }, me);\n      }\n\n      helpers.each(me.chart.data.datasets, function (dataset) {\n        var diffsForDataset = [];\n\n        if (_typeof(dataset.data[0]) === 'object' && dataset.data[0] !== null) {\n          helpers.each(dataset.data, function (value) {\n            var labelMoment;\n\n            if (me.isHorizontal()) {\n              labelMoment = me.parseDuration(value.x);\n            } else {\n              labelMoment = me.parseDuration(value.y);\n            }\n\n            if (moment.isDuration(labelMoment)) {\n              diffsForDataset.push(moment.duration(labelMoment).subtract(me.firstTick).as(me.tickUnit));\n            }\n          }, me);\n        } else {\n          // We have no labels. Use common ones\n          diffsForDataset = scaleLabelDiffs;\n        }\n\n        me.labelDiffs.push(diffsForDataset);\n      }, me);\n    },\n    buildTicks: function buildTicks() {\n      var me = this;\n      me.ctx.save();\n      var tickFontSize = helpers.getValueOrDefault(me.options.ticks.fontSize, Chart.defaults.global.defaultFontSize);\n      var tickFontStyle = helpers.getValueOrDefault(me.options.ticks.fontStyle, Chart.defaults.global.defaultFontStyle);\n      var tickFontFamily = helpers.getValueOrDefault(me.options.ticks.fontFamily, Chart.defaults.global.defaultFontFamily);\n      var tickLabelFont = helpers.fontString(tickFontSize, tickFontStyle, tickFontFamily);\n      me.ctx.font = tickLabelFont;\n      me.ticks = [];\n      me.unitScale = 1; // How much we scale the unit by, ie 2 means 2x unit per step\n\n      me.scaleSizeInUnits = 0; // How large the scale is in the base unit (seconds, minutes, etc)\n      // Determine the smallest needed unit of the time\n\n      var innerWidth = me.isHorizontal() ? me.width - (me.paddingLeft + me.paddingRight) : me.height - (me.paddingTop + me.paddingBottom); // Crude approximation of what the label length might be\n\n      var tempFirstLabel = me.tickFormatFunction(me.firstTick, 0, []);\n      var tickLabelWidth = me.ctx.measureText(tempFirstLabel).width;\n      var cosRotation = Math.cos(helpers.toRadians(me.options.ticks.maxRotation));\n      var sinRotation = Math.sin(helpers.toRadians(me.options.ticks.maxRotation));\n      tickLabelWidth = tickLabelWidth * cosRotation + tickFontSize * sinRotation;\n      var labelCapacity = innerWidth / tickLabelWidth; // Start as small as possible\n\n      me.tickUnit = 'millisecond';\n      me.scaleSizeInUnits = moment.duration(me.lastTick).subtract(me.firstTick).as(me.tickUnit);\n      var unitDefinitionIndex = 0;\n      var unitDefinition = time.units[unitDefinitionIndex]; // While we aren't ideal and we don't have units left\n\n      while (unitDefinitionIndex < time.units.length) {\n        // Can we scale this unit. If `false` we can scale infinitely\n        me.unitScale = 1;\n\n        if (helpers.isArray(unitDefinition.steps) && Math.ceil(me.scaleSizeInUnits / labelCapacity) < helpers.max(unitDefinition.steps)) {\n          // Use one of the predefined steps\n          for (var idx = 0; idx < unitDefinition.steps.length; ++idx) {\n            if (unitDefinition.steps[idx] >= Math.ceil(me.scaleSizeInUnits / labelCapacity)) {\n              me.unitScale = helpers.getValueOrDefault(me.options.time.unitStepSize, unitDefinition.steps[idx]);\n              break;\n            }\n          }\n\n          break;\n        } else if (unitDefinition.maxStep === false || Math.ceil(me.scaleSizeInUnits / labelCapacity) < unitDefinition.maxStep) {\n          // We have a max step. Scale this unit\n          me.unitScale = helpers.getValueOrDefault(me.options.time.unitStepSize, Math.ceil(me.scaleSizeInUnits / labelCapacity));\n          break;\n        } else {\n          // Move to the next unit up\n          ++unitDefinitionIndex;\n          unitDefinition = time.units[unitDefinitionIndex];\n          me.tickUnit = unitDefinition.name;\n          var leadingUnitBuffer = moment.duration(me.firstTick).subtract(me.getMomentStartOf(me.firstTick)).as(me.tickUnit);\n          var trailingUnitBuffer = me.getMomentStartOf(moment.duration(me.lastTick).add(1, me.tickUnit)).subtract(me.lastTick).as(me.tickUnit);\n          me.scaleSizeInUnits = moment.duration(me.lastTick).subtract(me.firstTick).as(me.tickUnit) + leadingUnitBuffer + trailingUnitBuffer;\n        }\n      } // Round the first tick\n\n\n      var roundedStart = me.getMomentStartOf(me.firstTick); // Round the last tick\n\n      var roundedEnd = me.getMomentStartOf(me.lastTick);\n      var delta = moment.duration(roundedEnd).subtract(me.lastTick).as(me.tickUnit);\n\n      if (delta < 0) {\n        // Do not use end of because we need me to be in the next time unit\n        me.lastTick = roundedEnd.add(1, me.tickUnit);\n      } else if (delta >= 0) {\n        me.lastTick = roundedEnd;\n      }\n\n      me.scaleSizeInUnits = moment.duration(me.lastTick).subtract(me.firstTick).as(me.tickUnit);\n      me.ticks.push(moment.duration(me.firstTick)); // For every unit in between the first and last moment, create a moment and add it to the ticks tick\n\n      for (var i = 1; i <= me.scaleSizeInUnits; ++i) {\n        var newTick = moment.duration(roundedStart).add(i, me.tickUnit);\n\n        if (i % me.unitScale === 0) {\n          me.ticks.push(newTick);\n        }\n      }\n\n      me.ctx.restore(); // Invalidate label diffs cache\n\n      me.labelDiffs = undefined;\n    },\n    // Get tooltip label\n    getLabelForIndex: function getLabelForIndex(index, datasetIndex) {\n      var me = this;\n      var label = me.chart.data.labels && index < me.chart.data.labels.length ? me.chart.data.labels[index] : '';\n\n      if (_typeof(me.chart.data.datasets[datasetIndex].data[0]) === 'object') {\n        if (me.isHorizontal()) {\n          label = me.chart.data.datasets[datasetIndex].data[index].x;\n        } else {\n          label = me.chart.data.datasets[datasetIndex].data[index].y;\n        }\n      }\n\n      return prettyPrintDuration(me.parseDuration(label));\n    },\n    // Function to format an individual tick mark\n    tickFormatFunction: function tickFormatFunction(tick, index, ticks) {\n      return tick.toISOString();\n    },\n    convertTicksToLabels: function convertTicksToLabels() {\n      var me = this;\n      me.tickMoments = me.ticks;\n      me.ticks = me.ticks.map(me.tickFormatFunction, me);\n    },\n    getPixelForValue: function getPixelForValue(value, index, datasetIndex) {\n      var me = this;\n      var offset = null;\n\n      if (index !== undefined && datasetIndex !== undefined) {\n        offset = me.getLabelDiff(datasetIndex, index);\n      }\n\n      if (offset === null) {\n        if (!value || !moment.isDuration(value)) {\n          // not already a moment object\n          value = me.parseDuration(value);\n        }\n\n        if (value && moment.isDuration(value)) {\n          offset = moment.duration(value).subtract(me.firstTick).as(me.tickUnit);\n        }\n      }\n\n      if (offset !== null) {\n        var decimal = offset !== 0 ? offset / me.scaleSizeInUnits : offset;\n\n        if (me.isHorizontal()) {\n          var innerWidth = me.width - (me.paddingLeft + me.paddingRight);\n          var valueOffset = innerWidth * decimal + me.paddingLeft;\n          return me.left + Math.round(valueOffset);\n        }\n\n        var innerHeight = me.height - (me.paddingTop + me.paddingBottom);\n        var heightOffset = innerHeight * decimal + me.paddingTop;\n        return me.top + Math.round(heightOffset);\n      }\n    },\n    getPixelForTick: function getPixelForTick(index) {\n      return this.getPixelForValue(this.tickMoments[index], null, null);\n    },\n    getValueForPixel: function getValueForPixel(pixel) {\n      var me = this;\n      var innerDimension = me.isHorizontal() ? me.width - (me.paddingLeft + me.paddingRight) : me.height - (me.paddingTop + me.paddingBottom);\n      var offset = (pixel - (me.isHorizontal() ? me.left + me.paddingLeft : me.top + me.paddingTop)) / innerDimension;\n      offset *= me.scaleSizeInUnits;\n      return moment.duration(me.firstTick).add(moment.duration(offset, me.tickUnit).asSeconds(), 'seconds');\n    },\n    parseDuration: function parseDuration(label) {\n      return moment.duration(label);\n    }\n  });\n  Chart.scaleService.registerScaleType('spot-duration', DurationScale, defaultConfig);\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"d11f.js","sources":["webpack:///./src/widgets/chartjs-duration-scale.js?1f9e"],"sourcesContent":["/* global window: false */\n'use strict';\nvar moment = require('moment-timezone');\n\nfunction prettyPrintDuration (tick) {\n  var parts = [];\n  var count;\n  var remainder = moment.duration(tick);\n\n  count = Math.floor(remainder.asYears());\n  if (count) { if (count === 1) { parts.push('1 year'); } else { parts.push(count.toString() + ' years'); } }\n  remainder.subtract(count, 'years');\n\n  count = Math.floor(remainder.asMonths());\n  if (count) { if (count === 1) { parts.push('1 month'); } else { parts.push(count.toString() + ' months'); } }\n  remainder.subtract(count, 'months');\n\n  count = Math.floor(remainder.asWeeks());\n  if (count) { if (count === 1) { parts.push('1 week'); } else { parts.push(count.toString() + ' weeks'); } }\n  remainder.subtract(count, 'weeks');\n\n  count = Math.floor(remainder.asDays());\n  if (count) { if (count === 1) { parts.push('1 day'); } else { parts.push(count.toString() + ' days'); } }\n  remainder.subtract(count, 'days');\n\n  count = Math.floor(remainder.asHours());\n  if (count) { if (count === 1) { parts.push('1 hour'); } else { parts.push(count.toString() + ' hours'); } }\n  remainder.subtract(count, 'hours');\n\n  count = Math.floor(remainder.asMinutes());\n  if (count) { if (count === 1) { parts.push('1 minute'); } else { parts.push(count.toString() + ' minutes'); } }\n  remainder.subtract(count, 'minutes');\n\n  count = Math.floor(remainder.asSeconds());\n  if (count) { if (count === 1) { parts.push('1 second'); } else { parts.push(count.toString() + ' seconds'); } }\n  remainder.subtract(count, 'seconds');\n\n  count = Math.floor(remainder.asMilliseconds());\n  if (count) { if (count === 1) { parts.push('1 millisecond'); } else { parts.push(count.toString() + ' milliseconds'); } }\n  return parts.join(' ');\n}\n\nvar time = {\n  units: [{\n    name: 'millisecond',\n    steps: [1, 2, 5, 10, 20, 50, 100, 250, 500]\n  }, {\n    name: 'second',\n    steps: [1, 2, 5, 10, 30]\n  }, {\n    name: 'minute',\n    steps: [1, 2, 5, 10, 30]\n  }, {\n    name: 'hour',\n    steps: [1, 2, 3, 6, 12]\n  }, {\n    name: 'day',\n    steps: [1, 2, 5]\n  }, {\n    name: 'week',\n    maxStep: 4\n  }, {\n    name: 'month',\n    maxStep: 3\n//  }, {\n//    name: 'quarter',\n//    maxStep: 4\n  }, {\n    name: 'year',\n    maxStep: false\n  }]\n};\n\nvar defaultConfig = {\n};\n\nmodule.exports = function (Chart, moment) {\n  var helpers = Chart.helpers;\n  moment = moment || require('moment');\n\n  var DurationScale = Chart.Scale.extend({\n    getLabelMoment: function (datasetIndex, index) {\n      if (datasetIndex === null || index === null) {\n        return null;\n      }\n\n      if (typeof this.labelMoments[datasetIndex] !== 'undefined') {\n        return this.labelMoments[datasetIndex][index];\n      }\n\n      return null;\n    },\n    getLabelDiff: function (datasetIndex, index) {\n      var me = this;\n      if (datasetIndex === null || index === null) {\n        return null;\n      }\n\n      if (me.labelDiffs === undefined) {\n        me.buildLabelDiffs();\n      }\n\n      if (typeof me.labelDiffs[datasetIndex] !== 'undefined') {\n        return me.labelDiffs[datasetIndex][index];\n      }\n\n      return null;\n    },\n    getMomentStartOf: function (tick) {\n      var me = this;\n      return moment.duration(Math.floor(tick.as(me.tickUnit)), me.tickUnit);\n    },\n    determineDataLimits: function () {\n      var me = this;\n      me.labelMoments = [];\n\n      // Get min max from labels\n      var scaleLabelMoments = [];\n      if (me.chart.data.labels && me.chart.data.labels.length > 0) {\n        me.firstTick = null;\n        me.lastTick = null;\n\n        helpers.each(me.chart.data.labels, function (label) {\n          var labelMoment = me.parseDuration(label);\n\n          scaleLabelMoments.push(labelMoment);\n\n          if (me.firstTick === null || me.firstTick > labelMoment) {\n            me.firstTick = labelMoment;\n          }\n          if (me.lastTick === null || me.lastTick < labelMoment) {\n            me.lastTick = labelMoment;\n          }\n        }, me);\n      } else {\n        me.firstTick = moment.duration('PT1S');\n        me.lastTick = moment.duration('PT10S');\n      }\n\n      // Adjust min max from datasets, and build the labelMoments[dataset][point] array\n      helpers.each(me.chart.data.datasets, function (dataset, datasetIndex) {\n        var momentsForDataset = [];\n        var datasetVisible = me.chart.isDatasetVisible(datasetIndex);\n\n        if (typeof dataset.data[0] === 'object' && dataset.data[0] !== null) {\n          helpers.each(dataset.data, function (value) {\n            var labelMoment;\n            if (me.isHorizontal()) {\n              labelMoment = me.parseDuration(value.x);\n            } else {\n              labelMoment = me.parseDuration(value.y);\n            }\n            momentsForDataset.push(labelMoment);\n\n            if (datasetVisible) {\n              // May have gone outside the scale ranges, make sure we keep the first and last ticks updated\n              me.firstTick = me.firstTick > labelMoment ? labelMoment : me.firstTick;\n              me.lastTick = me.lastTick < labelMoment ? labelMoment : me.lastTick;\n            }\n          }, me);\n        } else {\n          // We have no labels. Use the ones from the scale\n          momentsForDataset = scaleLabelMoments;\n        }\n\n        me.labelMoments.push(momentsForDataset);\n      }, me);\n\n      // We will modify these, so clone for later\n      me.firstTick = moment.duration(me.firstTick);\n      me.lastTick = moment.duration(me.lastTick);\n    },\n    buildLabelDiffs: function () {\n      var me = this;\n      me.labelDiffs = [];\n      var scaleLabelDiffs = [];\n      // Parse common labels once\n      if (me.chart.data.labels && me.chart.data.labels.length > 0) {\n        helpers.each(me.chart.data.labels, function (label) {\n          var labelMoment = me.parseDuration(label);\n\n          if (moment.isDuration(labelMoment)) {\n            scaleLabelDiffs.push(moment.duration(labelMoment).subtract(me.firstTick).as(me.tickUnit));\n          }\n        }, me);\n      }\n\n      helpers.each(me.chart.data.datasets, function (dataset) {\n        var diffsForDataset = [];\n\n        if (typeof dataset.data[0] === 'object' && dataset.data[0] !== null) {\n          helpers.each(dataset.data, function (value) {\n            var labelMoment;\n            if (me.isHorizontal()) {\n              labelMoment = me.parseDuration(value.x);\n            } else {\n              labelMoment = me.parseDuration(value.y);\n            }\n\n            if (moment.isDuration(labelMoment)) {\n              diffsForDataset.push(moment.duration(labelMoment).subtract(me.firstTick).as(me.tickUnit));\n            }\n          }, me);\n        } else {\n          // We have no labels. Use common ones\n          diffsForDataset = scaleLabelDiffs;\n        }\n        me.labelDiffs.push(diffsForDataset);\n      }, me);\n    },\n    buildTicks: function () {\n      var me = this;\n\n      me.ctx.save();\n      var tickFontSize = helpers.getValueOrDefault(me.options.ticks.fontSize, Chart.defaults.global.defaultFontSize);\n      var tickFontStyle = helpers.getValueOrDefault(me.options.ticks.fontStyle, Chart.defaults.global.defaultFontStyle);\n      var tickFontFamily = helpers.getValueOrDefault(me.options.ticks.fontFamily, Chart.defaults.global.defaultFontFamily);\n      var tickLabelFont = helpers.fontString(tickFontSize, tickFontStyle, tickFontFamily);\n      me.ctx.font = tickLabelFont;\n\n      me.ticks = [];\n      me.unitScale = 1; // How much we scale the unit by, ie 2 means 2x unit per step\n      me.scaleSizeInUnits = 0; // How large the scale is in the base unit (seconds, minutes, etc)\n\n      // Determine the smallest needed unit of the time\n      var innerWidth = me.isHorizontal() ? me.width - (me.paddingLeft + me.paddingRight) : me.height - (me.paddingTop + me.paddingBottom);\n\n      // Crude approximation of what the label length might be\n      var tempFirstLabel = me.tickFormatFunction(me.firstTick, 0, []);\n      var tickLabelWidth = me.ctx.measureText(tempFirstLabel).width;\n      var cosRotation = Math.cos(helpers.toRadians(me.options.ticks.maxRotation));\n      var sinRotation = Math.sin(helpers.toRadians(me.options.ticks.maxRotation));\n      tickLabelWidth = (tickLabelWidth * cosRotation) + (tickFontSize * sinRotation);\n      var labelCapacity = innerWidth / (tickLabelWidth);\n\n      // Start as small as possible\n      me.tickUnit = 'millisecond';\n      me.scaleSizeInUnits = moment.duration(me.lastTick).subtract(me.firstTick).as(me.tickUnit);\n\n      var unitDefinitionIndex = 0;\n      var unitDefinition = time.units[unitDefinitionIndex];\n\n      // While we aren't ideal and we don't have units left\n      while (unitDefinitionIndex < time.units.length) {\n        // Can we scale this unit. If `false` we can scale infinitely\n        me.unitScale = 1;\n\n        if (helpers.isArray(unitDefinition.steps) && Math.ceil(me.scaleSizeInUnits / labelCapacity) < helpers.max(unitDefinition.steps)) {\n          // Use one of the predefined steps\n          for (var idx = 0; idx < unitDefinition.steps.length; ++idx) {\n            if (unitDefinition.steps[idx] >= Math.ceil(me.scaleSizeInUnits / labelCapacity)) {\n              me.unitScale = helpers.getValueOrDefault(me.options.time.unitStepSize, unitDefinition.steps[idx]);\n              break;\n            }\n          }\n\n          break;\n        } else if ((unitDefinition.maxStep === false) || (Math.ceil(me.scaleSizeInUnits / labelCapacity) < unitDefinition.maxStep)) {\n          // We have a max step. Scale this unit\n          me.unitScale = helpers.getValueOrDefault(me.options.time.unitStepSize, Math.ceil(me.scaleSizeInUnits / labelCapacity));\n          break;\n        } else {\n          // Move to the next unit up\n          ++unitDefinitionIndex;\n          unitDefinition = time.units[unitDefinitionIndex];\n\n          me.tickUnit = unitDefinition.name;\n          var leadingUnitBuffer = moment.duration(me.firstTick).subtract(me.getMomentStartOf(me.firstTick)).as(me.tickUnit);\n          var trailingUnitBuffer = me.getMomentStartOf(moment.duration(me.lastTick).add(1, me.tickUnit)).subtract(me.lastTick).as(me.tickUnit);\n          me.scaleSizeInUnits = moment.duration(me.lastTick).subtract(me.firstTick).as(me.tickUnit) + leadingUnitBuffer + trailingUnitBuffer;\n        }\n      }\n\n      // Round the first tick\n      var roundedStart = me.getMomentStartOf(me.firstTick);\n\n      // Round the last tick\n      var roundedEnd = me.getMomentStartOf(me.lastTick);\n      var delta = moment.duration(roundedEnd).subtract(me.lastTick).as(me.tickUnit);\n      if (delta < 0) {\n        // Do not use end of because we need me to be in the next time unit\n        me.lastTick = roundedEnd.add(1, me.tickUnit);\n      } else if (delta >= 0) {\n        me.lastTick = roundedEnd;\n      }\n\n      me.scaleSizeInUnits = moment.duration(me.lastTick).subtract(me.firstTick).as(me.tickUnit);\n\n      me.ticks.push(moment.duration(me.firstTick));\n\n      // For every unit in between the first and last moment, create a moment and add it to the ticks tick\n      for (var i = 1; i <= me.scaleSizeInUnits; ++i) {\n        var newTick = moment.duration(roundedStart).add(i, me.tickUnit);\n\n        if (i % me.unitScale === 0) {\n          me.ticks.push(newTick);\n        }\n      }\n\n      me.ctx.restore();\n\n      // Invalidate label diffs cache\n      me.labelDiffs = undefined;\n    },\n    // Get tooltip label\n    getLabelForIndex: function (index, datasetIndex) {\n      var me = this;\n      var label = me.chart.data.labels && index < me.chart.data.labels.length ? me.chart.data.labels[index] : '';\n\n      if (typeof me.chart.data.datasets[datasetIndex].data[0] === 'object') {\n        if (me.isHorizontal()) {\n          label = me.chart.data.datasets[datasetIndex].data[index].x;\n        } else {\n          label = me.chart.data.datasets[datasetIndex].data[index].y;\n        }\n      }\n\n      return prettyPrintDuration(me.parseDuration(label));\n    },\n    // Function to format an individual tick mark\n    tickFormatFunction: function (tick, index, ticks) {\n      return tick.toISOString();\n    },\n    convertTicksToLabels: function () {\n      var me = this;\n      me.tickMoments = me.ticks;\n      me.ticks = me.ticks.map(me.tickFormatFunction, me);\n    },\n    getPixelForValue: function (value, index, datasetIndex) {\n      var me = this;\n      var offset = null;\n      if (index !== undefined && datasetIndex !== undefined) {\n        offset = me.getLabelDiff(datasetIndex, index);\n      }\n\n      if (offset === null) {\n        if (!value || !moment.isDuration(value)) {\n          // not already a moment object\n          value = me.parseDuration(value);\n        }\n        if (value && moment.isDuration(value)) {\n          offset = moment.duration(value).subtract(me.firstTick).as(me.tickUnit);\n        }\n      }\n\n      if (offset !== null) {\n        var decimal = offset !== 0 ? offset / me.scaleSizeInUnits : offset;\n\n        if (me.isHorizontal()) {\n          var innerWidth = me.width - (me.paddingLeft + me.paddingRight);\n          var valueOffset = (innerWidth * decimal) + me.paddingLeft;\n\n          return me.left + Math.round(valueOffset);\n        }\n        var innerHeight = me.height - (me.paddingTop + me.paddingBottom);\n        var heightOffset = (innerHeight * decimal) + me.paddingTop;\n\n        return me.top + Math.round(heightOffset);\n      }\n    },\n    getPixelForTick: function (index) {\n      return this.getPixelForValue(this.tickMoments[index], null, null);\n    },\n    getValueForPixel: function (pixel) {\n      var me = this;\n      var innerDimension = me.isHorizontal() ? me.width - (me.paddingLeft + me.paddingRight) : me.height - (me.paddingTop + me.paddingBottom);\n      var offset = (pixel - (me.isHorizontal() ? me.left + me.paddingLeft : me.top + me.paddingTop)) / innerDimension;\n      offset *= me.scaleSizeInUnits;\n      return moment.duration(me.firstTick).add(moment.duration(offset, me.tickUnit).asSeconds(), 'seconds');\n    },\n    parseDuration: function (label) {\n      return moment.duration(label);\n    }\n  });\n  Chart.scaleService.registerScaleType('spot-duration', DurationScale, defaultConfig);\n};\n"],"mappings":"AAAA;AACA;AACA;;;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AAFA;AAIA;AACA;AAFA;AAIA;AACA;AAFA;AAIA;AACA;AAFA;AAIA;AACA;AAFA;AAIA;AACA;AAEA;AACA;AACA;AANA;AAOA;AACA;AAFA;AAzBA;AA+BA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AAEA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AApSA;AAsSA;AACA","sourceRoot":""}\n//# sourceURL=webpack-internal:///d11f\n")},d38c:function(module,exports,__webpack_require__){eval("var app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar PageView = __webpack_require__(/*! ./base */ \"b966\");\n\nvar templates = __webpack_require__(/*! ../templates */ \"4324\");\n\nvar PartitionContinuousView = __webpack_require__(/*! ./configure-partition/partition-continuous */ \"6d22\");\n\nvar PartitionCategorialView = __webpack_require__(/*! ./configure-partition/partition-categorial */ \"de24\");\n\nvar PartitionDatetimeView = __webpack_require__(/*! ./configure-partition/partition-datetime */ \"0d07\");\n\nvar PartitionDurationView = __webpack_require__(/*! ./configure-partition/partition-duration */ \"b322\");\n\nvar PartitionTextView = __webpack_require__(/*! ./configure-partition/partition-text */ \"faa4\");\n\nmodule.exports = PageView.extend({\n  initialize: function initialize() {\n    this.pageName = 'configurePartition';\n    this.once('remove', function () {\n      if (this.resetFilter) {\n        var filter = this.model.collection.parent;\n        filter.releaseDataFilter();\n        filter.initDataFilter();\n        filter.updateDataFilter(); // this filter needs new data\n\n        app.me.dataview.getData();\n      }\n    }, this);\n  },\n  template: templates.configurePartition.page,\n  bindings: {\n    'model.label': {\n      type: 'value',\n      hook: 'partition-title-input'\n    },\n    'model.showLabel': {\n      type: 'booleanAttribute',\n      hook: 'show-label',\n      name: 'checked'\n    },\n    'model.showLegend': {\n      type: 'booleanAttribute',\n      hook: 'show-legend',\n      name: 'checked'\n    }\n  },\n  session: {\n    resetFilter: ['boolean', true, false]\n  },\n  events: {\n    'change [data-hook~=partition-title-input]': function changeDataHookPartitionTitleInput() {\n      this.model.label = this.queryByHook('partition-title-input').value;\n    },\n    'change [data-hook~=show-label]': function changeDataHookShowLabel() {\n      this.model.showLabel = !this.model.showLabel;\n    },\n    'change [data-hook~=show-legend]': function changeDataHookShowLegend() {\n      this.model.showLegend = !this.model.showLegend;\n    }\n  },\n  subviews: {\n    groupContinuous: {\n      hook: 'partition-continuous',\n      prepareView: function prepareView(el) {\n        return new PartitionContinuousView({\n          el: el,\n          model: this.model\n        });\n      }\n    },\n    groupCategorial: {\n      hook: 'partition-categorial',\n      prepareView: function prepareView(el) {\n        return new PartitionCategorialView({\n          el: el,\n          model: this.model\n        });\n      }\n    },\n    groupDatetime: {\n      hook: 'partition-datetime',\n      prepareView: function prepareView(el) {\n        return new PartitionDatetimeView({\n          el: el,\n          model: this.model\n        });\n      }\n    },\n    groupDuration: {\n      hook: 'partition-duration',\n      prepareView: function prepareView(el) {\n        return new PartitionDurationView({\n          el: el,\n          model: this.model\n        });\n      }\n    },\n    groupText: {\n      hook: 'partition-text',\n      prepareView: function prepareView(el) {\n        return new PartitionTextView({\n          el: el,\n          model: this.model\n        });\n      }\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZDM4Yy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtcGFydGl0aW9uLmpzPzkzOTkiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIGFwcCA9IHJlcXVpcmUoJ2FtcGVyc2FuZC1hcHAnKTtcbnZhciBQYWdlVmlldyA9IHJlcXVpcmUoJy4vYmFzZScpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uL3RlbXBsYXRlcycpO1xuXG52YXIgUGFydGl0aW9uQ29udGludW91c1ZpZXcgPSByZXF1aXJlKCcuL2NvbmZpZ3VyZS1wYXJ0aXRpb24vcGFydGl0aW9uLWNvbnRpbnVvdXMnKTtcbnZhciBQYXJ0aXRpb25DYXRlZ29yaWFsVmlldyA9IHJlcXVpcmUoJy4vY29uZmlndXJlLXBhcnRpdGlvbi9wYXJ0aXRpb24tY2F0ZWdvcmlhbCcpO1xudmFyIFBhcnRpdGlvbkRhdGV0aW1lVmlldyA9IHJlcXVpcmUoJy4vY29uZmlndXJlLXBhcnRpdGlvbi9wYXJ0aXRpb24tZGF0ZXRpbWUnKTtcbnZhciBQYXJ0aXRpb25EdXJhdGlvblZpZXcgPSByZXF1aXJlKCcuL2NvbmZpZ3VyZS1wYXJ0aXRpb24vcGFydGl0aW9uLWR1cmF0aW9uJyk7XG52YXIgUGFydGl0aW9uVGV4dFZpZXcgPSByZXF1aXJlKCcuL2NvbmZpZ3VyZS1wYXJ0aXRpb24vcGFydGl0aW9uLXRleHQnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBQYWdlVmlldy5leHRlbmQoe1xuICBpbml0aWFsaXplOiBmdW5jdGlvbiAoKSB7XG4gICAgdGhpcy5wYWdlTmFtZSA9ICdjb25maWd1cmVQYXJ0aXRpb24nO1xuXG4gICAgdGhpcy5vbmNlKCdyZW1vdmUnLCBmdW5jdGlvbiAoKSB7XG4gICAgICBpZiAodGhpcy5yZXNldEZpbHRlcikge1xuICAgICAgICB2YXIgZmlsdGVyID0gdGhpcy5tb2RlbC5jb2xsZWN0aW9uLnBhcmVudDtcbiAgICAgICAgZmlsdGVyLnJlbGVhc2VEYXRhRmlsdGVyKCk7XG5cbiAgICAgICAgZmlsdGVyLmluaXREYXRhRmlsdGVyKCk7XG4gICAgICAgIGZpbHRlci51cGRhdGVEYXRhRmlsdGVyKCk7XG5cbiAgICAgICAgLy8gdGhpcyBmaWx0ZXIgbmVlZHMgbmV3IGRhdGFcbiAgICAgICAgYXBwLm1lLmRhdGF2aWV3LmdldERhdGEoKTtcbiAgICAgIH1cbiAgICB9LCB0aGlzKTtcbiAgfSxcbiAgdGVtcGxhdGU6IHRlbXBsYXRlcy5jb25maWd1cmVQYXJ0aXRpb24ucGFnZSxcbiAgYmluZGluZ3M6IHtcbiAgICAnbW9kZWwubGFiZWwnOiB7XG4gICAgICB0eXBlOiAndmFsdWUnLFxuICAgICAgaG9vazogJ3BhcnRpdGlvbi10aXRsZS1pbnB1dCdcbiAgICB9LFxuICAgICdtb2RlbC5zaG93TGFiZWwnOiB7XG4gICAgICB0eXBlOiAnYm9vbGVhbkF0dHJpYnV0ZScsXG4gICAgICBob29rOiAnc2hvdy1sYWJlbCcsXG4gICAgICBuYW1lOiAnY2hlY2tlZCdcbiAgICB9LFxuICAgICdtb2RlbC5zaG93TGVnZW5kJzoge1xuICAgICAgdHlwZTogJ2Jvb2xlYW5BdHRyaWJ1dGUnLFxuICAgICAgaG9vazogJ3Nob3ctbGVnZW5kJyxcbiAgICAgIG5hbWU6ICdjaGVja2VkJ1xuICAgIH1cbiAgfSxcbiAgc2Vzc2lvbjoge1xuICAgIHJlc2V0RmlsdGVyOiBbJ2Jvb2xlYW4nLCB0cnVlLCBmYWxzZV1cbiAgfSxcbiAgZXZlbnRzOiB7XG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj1wYXJ0aXRpb24tdGl0bGUtaW5wdXRdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5tb2RlbC5sYWJlbCA9IHRoaXMucXVlcnlCeUhvb2soJ3BhcnRpdGlvbi10aXRsZS1pbnB1dCcpLnZhbHVlO1xuICAgIH0sXG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj1zaG93LWxhYmVsXSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMubW9kZWwuc2hvd0xhYmVsID0gIXRoaXMubW9kZWwuc2hvd0xhYmVsO1xuICAgIH0sXG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rfj1zaG93LWxlZ2VuZF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLnNob3dMZWdlbmQgPSAhdGhpcy5tb2RlbC5zaG93TGVnZW5kO1xuICAgIH1cbiAgfSxcbiAgc3Vidmlld3M6IHtcbiAgICBncm91cENvbnRpbnVvdXM6IHtcbiAgICAgIGhvb2s6ICdwYXJ0aXRpb24tY29udGludW91cycsXG4gICAgICBwcmVwYXJlVmlldzogZnVuY3Rpb24gKGVsKSB7XG4gICAgICAgIHJldHVybiBuZXcgUGFydGl0aW9uQ29udGludW91c1ZpZXcoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBtb2RlbDogdGhpcy5tb2RlbFxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9LFxuICAgIGdyb3VwQ2F0ZWdvcmlhbDoge1xuICAgICAgaG9vazogJ3BhcnRpdGlvbi1jYXRlZ29yaWFsJyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBQYXJ0aXRpb25DYXRlZ29yaWFsVmlldyh7XG4gICAgICAgICAgZWw6IGVsLFxuICAgICAgICAgIG1vZGVsOiB0aGlzLm1vZGVsXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH0sXG4gICAgZ3JvdXBEYXRldGltZToge1xuICAgICAgaG9vazogJ3BhcnRpdGlvbi1kYXRldGltZScsXG4gICAgICBwcmVwYXJlVmlldzogZnVuY3Rpb24gKGVsKSB7XG4gICAgICAgIHJldHVybiBuZXcgUGFydGl0aW9uRGF0ZXRpbWVWaWV3KHtcbiAgICAgICAgICBlbDogZWwsXG4gICAgICAgICAgbW9kZWw6IHRoaXMubW9kZWxcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgICBncm91cER1cmF0aW9uOiB7XG4gICAgICBob29rOiAncGFydGl0aW9uLWR1cmF0aW9uJyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBQYXJ0aXRpb25EdXJhdGlvblZpZXcoe1xuICAgICAgICAgIGVsOiBlbCxcbiAgICAgICAgICBtb2RlbDogdGhpcy5tb2RlbFxuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9LFxuICAgIGdyb3VwVGV4dDoge1xuICAgICAgaG9vazogJ3BhcnRpdGlvbi10ZXh0JyxcbiAgICAgIHByZXBhcmVWaWV3OiBmdW5jdGlvbiAoZWwpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBQYXJ0aXRpb25UZXh0Vmlldyh7XG4gICAgICAgICAgZWw6IGVsLFxuICAgICAgICAgIG1vZGVsOiB0aGlzLm1vZGVsXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH1cbiAgfVxufSk7XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBVkE7QUFnQkE7QUFDQTtBQURBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFUQTtBQVdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQVBBO0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQVBBO0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQVBBO0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQVBBO0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFJQTtBQVBBO0FBckNBO0FBaERBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///d38c\n")},de24:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar GroupView = __webpack_require__(/*! ./group */ \"0b9a\");\n\nmodule.exports = View.extend({\n  template: templates.configurePartition.partitionCategorial,\n  bindings: {\n    'model.isCategorial': {\n      type: 'toggle',\n      hook: 'group-categorial-panel'\n    }\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.renderCollection(this.model.groups, GroupView, this.queryByHook('groups-table'));\n    return this;\n  },\n  events: {\n    'click [data-hook~=group-order-count]': function clickDataHookGroupOrderCount() {\n      this.model.ordering = 'count';\n      this.parent.resetFilter = true;\n    },\n    'click [data-hook~=group-order-abc]': function clickDataHookGroupOrderAbc() {\n      this.model.ordering = 'value';\n      this.parent.resetFilter = true;\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGUyNC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtcGFydGl0aW9uL3BhcnRpdGlvbi1jYXRlZ29yaWFsLmpzPzJhZTQiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xudmFyIEdyb3VwVmlldyA9IHJlcXVpcmUoJy4vZ3JvdXAnKTtcblxubW9kdWxlLmV4cG9ydHMgPSBWaWV3LmV4dGVuZCh7XG4gIHRlbXBsYXRlOiB0ZW1wbGF0ZXMuY29uZmlndXJlUGFydGl0aW9uLnBhcnRpdGlvbkNhdGVnb3JpYWwsXG4gIGJpbmRpbmdzOiB7XG4gICAgJ21vZGVsLmlzQ2F0ZWdvcmlhbCc6IHtcbiAgICAgIHR5cGU6ICd0b2dnbGUnLFxuICAgICAgaG9vazogJ2dyb3VwLWNhdGVnb3JpYWwtcGFuZWwnXG4gICAgfVxuICB9LFxuICByZW5kZXI6IGZ1bmN0aW9uICgpIHtcbiAgICB0aGlzLnJlbmRlcldpdGhUZW1wbGF0ZSh0aGlzKTtcbiAgICB0aGlzLnJlbmRlckNvbGxlY3Rpb24odGhpcy5tb2RlbC5ncm91cHMsIEdyb3VwVmlldywgdGhpcy5xdWVyeUJ5SG9vaygnZ3JvdXBzLXRhYmxlJykpO1xuXG4gICAgcmV0dXJuIHRoaXM7XG4gIH0sXG4gIGV2ZW50czoge1xuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1vcmRlci1jb3VudF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLm9yZGVyaW5nID0gJ2NvdW50JztcbiAgICAgIHRoaXMucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9LFxuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1vcmRlci1hYmNdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5tb2RlbC5vcmRlcmluZyA9ICd2YWx1ZSc7XG4gICAgICB0aGlzLnBhcmVudC5yZXNldEZpbHRlciA9IHRydWU7XG4gICAgfVxuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRkE7QUFEQTtBQU1BO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFSQTtBQWRBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///de24\n")},de33:function(module,exports){eval("/**\n * Formatter for tick labels on a linear axis in chartjs\n *\n * Override the default behavious such that it:\n *  * switches to scientific notation for large numbers with a lot of 'trailing zeros': 1e25\n *  * only prints the trailing (least significant) digits when zoomin in: 100000000000.1 prints as '..000.1'\n *\n * see issue #142\n */\nmodule.exports = function (tickValue, index, ticks) {\n  // Find the proper tick spacing\n  // if we have lots of ticks, don't use the ones\n  var delta = Math.abs(ticks.length > 3 ? ticks[2] - ticks[1] : ticks[1] - ticks[0]);\n\n  if (tickValue === 0) {\n    return '0';\n  } // Find the order of magnitude of the least significant digit\n\n\n  var leastSignificantOOM = Math.floor(Math.log10(delta)); // Find the order magnitude of the most significant digit\n\n  var logTicks = [];\n  ticks.forEach(function (value, i) {\n    if (value !== 0) {\n      logTicks.push(Math.log10(Math.abs(value)));\n    }\n  });\n  var mostSignificantOOM = Math.floor(Math.max.apply(Math, logTicks)); // We can chose between 3 different notations for '12.34':\n  //   fixed precision:     12.34\n  //   scientific notation: 1.234e1\n  //   and truncated         ..34\n  // find how long each notation would be, and chose the optimal one\n  // when using scientific notation (1,2303e2), how many digits would it take?\n\n  var totalNumberOfDigits = mostSignificantOOM + 1 - leastSignificantOOM; // when using fixed notation (123.03), how many digits would it take?\n\n  var fixedNotationDitigts = 1 + Math.max(0, mostSignificantOOM) + // digits before '.'\n  Math.max(0, Math.abs(leastSignificantOOM)); // digits after '.'\n  // when truncating the string to the last 5 digits, it is of course 5 digits\n\n  var tickString = '';\n\n  if (fixedNotationDitigts < 9) {\n    var numDecimal = Math.max(Math.min(-1 * leastSignificantOOM, 20), 0); // toFixed has a max of 20 decimal places\n\n    tickString = tickValue.toFixed(numDecimal);\n  } else if (totalNumberOfDigits < 9) {\n    tickString = tickValue.toExponential(totalNumberOfDigits - 1);\n  } else {\n    tickString = tickValue.toFixed(Math.max(0, -1 * leastSignificantOOM));\n    tickString = '..' + tickString.substring(tickString.length - 5, tickString.length);\n  }\n\n  return tickString;\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGUzMy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL2NoYXJ0anMtc2NpbGluZWFyLWZvcm1hdHRlci5qcz9hZjZhIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRm9ybWF0dGVyIGZvciB0aWNrIGxhYmVscyBvbiBhIGxpbmVhciBheGlzIGluIGNoYXJ0anNcbiAqXG4gKiBPdmVycmlkZSB0aGUgZGVmYXVsdCBiZWhhdmlvdXMgc3VjaCB0aGF0IGl0OlxuICogICogc3dpdGNoZXMgdG8gc2NpZW50aWZpYyBub3RhdGlvbiBmb3IgbGFyZ2UgbnVtYmVycyB3aXRoIGEgbG90IG9mICd0cmFpbGluZyB6ZXJvcyc6IDFlMjVcbiAqICAqIG9ubHkgcHJpbnRzIHRoZSB0cmFpbGluZyAobGVhc3Qgc2lnbmlmaWNhbnQpIGRpZ2l0cyB3aGVuIHpvb21pbiBpbjogMTAwMDAwMDAwMDAwLjEgcHJpbnRzIGFzICcuLjAwMC4xJ1xuICpcbiAqIHNlZSBpc3N1ZSAjMTQyXG4gKi9cbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb24gKHRpY2tWYWx1ZSwgaW5kZXgsIHRpY2tzKSB7XG4gIC8vIEZpbmQgdGhlIHByb3BlciB0aWNrIHNwYWNpbmdcbiAgLy8gaWYgd2UgaGF2ZSBsb3RzIG9mIHRpY2tzLCBkb24ndCB1c2UgdGhlIG9uZXNcbiAgdmFyIGRlbHRhID0gTWF0aC5hYnModGlja3MubGVuZ3RoID4gMyA/IHRpY2tzWzJdIC0gdGlja3NbMV0gOiB0aWNrc1sxXSAtIHRpY2tzWzBdKTtcblxuICBpZiAodGlja1ZhbHVlID09PSAwKSB7XG4gICAgcmV0dXJuICcwJztcbiAgfVxuXG4gIC8vIEZpbmQgdGhlIG9yZGVyIG9mIG1hZ25pdHVkZSBvZiB0aGUgbGVhc3Qgc2lnbmlmaWNhbnQgZGlnaXRcbiAgdmFyIGxlYXN0U2lnbmlmaWNhbnRPT00gPSBNYXRoLmZsb29yKE1hdGgubG9nMTAoZGVsdGEpKTtcblxuICAvLyBGaW5kIHRoZSBvcmRlciBtYWduaXR1ZGUgb2YgdGhlIG1vc3Qgc2lnbmlmaWNhbnQgZGlnaXRcbiAgdmFyIGxvZ1RpY2tzID0gW107XG4gIHRpY2tzLmZvckVhY2goZnVuY3Rpb24gKHZhbHVlLCBpKSB7XG4gICAgaWYgKHZhbHVlICE9PSAwKSB7XG4gICAgICBsb2dUaWNrcy5wdXNoKE1hdGgubG9nMTAoTWF0aC5hYnModmFsdWUpKSk7XG4gICAgfVxuICB9KTtcbiAgdmFyIG1vc3RTaWduaWZpY2FudE9PTSA9IE1hdGguZmxvb3IoTWF0aC5tYXguYXBwbHkoTWF0aCwgbG9nVGlja3MpKTtcblxuICAvLyBXZSBjYW4gY2hvc2UgYmV0d2VlbiAzIGRpZmZlcmVudCBub3RhdGlvbnMgZm9yICcxMi4zNCc6XG4gIC8vICAgZml4ZWQgcHJlY2lzaW9uOiAgICAgMTIuMzRcbiAgLy8gICBzY2llbnRpZmljIG5vdGF0aW9uOiAxLjIzNGUxXG4gIC8vICAgYW5kIHRydW5jYXRlZCAgICAgICAgIC4uMzRcbiAgLy8gZmluZCBob3cgbG9uZyBlYWNoIG5vdGF0aW9uIHdvdWxkIGJlLCBhbmQgY2hvc2UgdGhlIG9wdGltYWwgb25lXG5cbiAgLy8gd2hlbiB1c2luZyBzY2llbnRpZmljIG5vdGF0aW9uICgxLDIzMDNlMiksIGhvdyBtYW55IGRpZ2l0cyB3b3VsZCBpdCB0YWtlP1xuICB2YXIgdG90YWxOdW1iZXJPZkRpZ2l0cyA9IG1vc3RTaWduaWZpY2FudE9PTSArIDEgLSBsZWFzdFNpZ25pZmljYW50T09NO1xuXG4gIC8vIHdoZW4gdXNpbmcgZml4ZWQgbm90YXRpb24gKDEyMy4wMyksIGhvdyBtYW55IGRpZ2l0cyB3b3VsZCBpdCB0YWtlP1xuICB2YXIgZml4ZWROb3RhdGlvbkRpdGlndHMgPSAxICtcbiAgICBNYXRoLm1heCgwLCBtb3N0U2lnbmlmaWNhbnRPT00pICsgICAgICAgICAgIC8vIGRpZ2l0cyBiZWZvcmUgJy4nXG4gICAgTWF0aC5tYXgoMCwgTWF0aC5hYnMobGVhc3RTaWduaWZpY2FudE9PTSkpOyAvLyBkaWdpdHMgYWZ0ZXIgJy4nXG5cbiAgLy8gd2hlbiB0cnVuY2F0aW5nIHRoZSBzdHJpbmcgdG8gdGhlIGxhc3QgNSBkaWdpdHMsIGl0IGlzIG9mIGNvdXJzZSA1IGRpZ2l0c1xuXG4gIHZhciB0aWNrU3RyaW5nID0gJyc7XG4gIGlmIChmaXhlZE5vdGF0aW9uRGl0aWd0cyA8IDkpIHtcbiAgICB2YXIgbnVtRGVjaW1hbCA9IE1hdGgubWF4KE1hdGgubWluKC0xICogbGVhc3RTaWduaWZpY2FudE9PTSwgMjApLCAwKTsgLy8gdG9GaXhlZCBoYXMgYSBtYXggb2YgMjAgZGVjaW1hbCBwbGFjZXNcbiAgICB0aWNrU3RyaW5nID0gdGlja1ZhbHVlLnRvRml4ZWQobnVtRGVjaW1hbCk7XG4gIH0gZWxzZSBpZiAodG90YWxOdW1iZXJPZkRpZ2l0cyA8IDkpIHtcbiAgICB0aWNrU3RyaW5nID0gdGlja1ZhbHVlLnRvRXhwb25lbnRpYWwodG90YWxOdW1iZXJPZkRpZ2l0cyAtIDEpO1xuICB9IGVsc2Uge1xuICAgIHRpY2tTdHJpbmcgPSB0aWNrVmFsdWUudG9GaXhlZChNYXRoLm1heCgwLCAtMSAqIGxlYXN0U2lnbmlmaWNhbnRPT00pKTtcbiAgICB0aWNrU3RyaW5nID0gJy4uJyArIHRpY2tTdHJpbmcuc3Vic3RyaW5nKHRpY2tTdHJpbmcubGVuZ3RoIC0gNSwgdGlja1N0cmluZy5sZW5ndGgpO1xuICB9XG5cbiAgcmV0dXJuIHRpY2tTdHJpbmc7XG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7O0FBU0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFBQTtBQUNBO0FBRUE7QUFFQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///de33\n")},de8e:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nvar sortablejs = __webpack_require__(/*! sortablejs */ \"4776\");\n\nvar app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar startDnd = function startDnd(type) {\n  if (this.model.isFilled) {\n    // do nothing if the slot is already filled\n    this.dndClass = '';\n  } else {\n    if (this.model.supportedFacets.indexOf(type) > -1) {\n      // highlight the drop zone\n      this.dndClass = 'slot-start-dnd-accept';\n    } else {\n      // gray out the drop zone\n      this.dndClass = 'slot-start-dnd-reject';\n    }\n  }\n};\n\nvar stopDnd = function stopDnd() {\n  this.dndClass = '';\n};\n\nmodule.exports = View.extend({\n  template: templates.analyze.slot,\n  props: {\n    dndClass: 'string',\n    // CSS class to add when a facet dnd is in progress\n    updateCounter: {\n      type: 'number',\n      default: 0,\n      required: true\n    }\n  },\n  derived: {\n    requiredText: {\n      deps: ['model.required', 'model.isFilled'],\n      fn: function fn() {\n        if (this.model.isFilled) {\n          return 'click to configure';\n        } else {\n          if (this.model.required) {\n            return 'required';\n          } else {\n            return 'optional';\n          }\n        }\n      }\n    },\n    chipText: {\n      deps: ['model.isFilled', 'updateCounter'],\n      cache: false,\n      fn: function fn() {\n        var filter = this.collection.parent.filter; // stop accepting DND\n\n        if (this._sortable) {\n          this._sortable.option('disabled', true);\n        }\n\n        if (filter) {\n          if (this.model.type === 'partition') {\n            var partition = filter.partitions.get(this.model.rank, 'rank');\n\n            if (partition) {\n              return partition.facetName;\n            }\n          } else if (this.model.type === 'aggregate') {\n            var aggregate = filter.aggregates.get(this.model.rank, 'rank');\n\n            if (aggregate) {\n              return aggregate.operation + ' ' + aggregate.label;\n            }\n          } else {\n            console.error('Illegal slot');\n          }\n        } // this slots should accept DND\n\n\n        if (this._sortable) {\n          this._sortable.option('disabled', false);\n        }\n\n        return '';\n      }\n    }\n  },\n  initialize: function initialize() {\n    var filter = this.collection.parent.filter;\n    this.model.isFilled = false;\n\n    if (filter) {\n      if (this.model.type === 'partition') {\n        var partition = filter.partitions.get(this.model.rank, 'rank');\n\n        if (partition) {\n          this.model.isFilled = true;\n        }\n      } else if (this.model.type === 'aggregate') {\n        var aggregate = filter.aggregates.get(this.model.rank, 'rank');\n\n        if (aggregate) {\n          this.model.isFilled = true;\n        }\n      } else {\n        console.error('Illegal slot');\n      }\n    } // add remove classes 'dndAccept' and 'dndRefuse' on drag-and-drop\n\n\n    app.on('dragStart', startDnd, this);\n    app.on('dragEnd', stopDnd, this);\n    this.on('remove', function () {\n      app.off('dragStart', startDnd);\n      app.off('dragEnd', stopDnd);\n    }, this);\n  },\n  bindings: {\n    'dndClass': {\n      type: 'class',\n      hook: 'drop-zone'\n    },\n    'model.description': {\n      type: 'text',\n      hook: 'description'\n    },\n    'requiredText': {\n      type: 'text',\n      hook: 'required'\n    },\n    'chipText': {\n      type: 'text',\n      hook: 'drop-zone'\n    },\n    'model.isFilled': {\n      type: 'toggle',\n      hook: 'button-div'\n    }\n  },\n  events: {\n    'click .clickTarget': 'rotateSetting',\n    'click [data-hook~=\"delete\"]': 'emptySlot'\n  },\n  rotateSetting: function rotateSetting() {\n    var filter = this.collection.parent.filter;\n    filter.releaseDataFilter();\n\n    if (this.model.type === 'partition') {\n      var partition = filter.partitions.get(this.model.rank, 'rank');\n\n      if (!partition) {\n        return;\n      }\n\n      app.navigate('partition/' + partition.getId());\n    } else if (this.model.type === 'aggregate') {\n      var values = ['count', 'avg', 'sum', 'stddev', 'min', 'max'];\n      var aggregate = filter.aggregates.get(this.model.rank, 'rank');\n\n      if (!aggregate) {\n        return;\n      }\n\n      var i = values.indexOf(aggregate.operation) + 1;\n\n      if (i >= values.length) {\n        i = 0;\n      }\n\n      if (app.me.sessionType === 'client' && values[i] === 'min' | values[i] === 'max') {\n        // crossfilter does not support min/max\n        i = 0;\n      }\n\n      aggregate.operation = values[i];\n      app.trigger('refresh'); // force a redraw of the text\n\n      this.updateCounter += 1;\n    }\n  },\n  emptySlot: function emptySlot() {\n    if (this.model.emptySlot()) {\n      app.trigger('refresh'); // force a redraw of the chipText\n\n      this.updateCounter += 1;\n    }\n  },\n  tryFillSlot: function tryFillSlot(facet) {\n    if (this.model.tryFillSlot(facet)) {\n      // Hack-ish feature:\n      //  * for bubble plots, add a facet dropped as 'X axis' also as 'Point size'\n      //  * for 3d scatter plots, add a facet dropped as 'X axis' also as 'Color by'\n      var chartType = this.model.collection.parent.filter.chartType;\n\n      if (chartType === 'bubbleplot') {\n        if (this.model.description === 'X axis') {\n          this.model.collection.get('Point size', 'description').tryFillSlot(facet, 'count');\n        }\n      } else if (chartType === 'scatterchart') {\n        if (this.model.description === 'X axis') {\n          this.model.collection.get('Color by', 'description').tryFillSlot(facet, 'count');\n        }\n      }\n\n      app.trigger('refresh'); // force a redraw of the chipText\n\n      this.updateCounter += 1;\n    }\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n    var me = this;\n    this._sortable = sortablejs.create(this.queryByHook('drop-zone'), {\n      draggable: '.mdl-chip',\n      disabled: me.model.isFilled,\n      group: {\n        name: 'facets',\n        pull: false,\n        put: true\n      },\n      onAdd: function onAdd(evt) {\n        // get the dropped facet\n        // because the ampersand view collection takes care of rendering a\n        // prettier one\n        var item = evt.item;\n        var facetId = item.getAttribute('data-id');\n        item.remove();\n        var facet = app.me.dataview.facets.get(facetId);\n\n        if (!facet) {\n          console.error('Cannot find facet');\n          return;\n        }\n\n        me.tryFillSlot(facet);\n      }\n    });\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"de8e.js","sources":["webpack:///./src/pages/analyze/slot.js?f3f2"],"sourcesContent":["var View = require('ampersand-view');\nvar templates = require('../../templates');\nvar sortablejs = require('sortablejs');\nvar app = require('ampersand-app');\n\nvar startDnd = function (type) {\n  if (this.model.isFilled) {\n    // do nothing if the slot is already filled\n    this.dndClass = '';\n  } else {\n    if (this.model.supportedFacets.indexOf(type) > -1) {\n      // highlight the drop zone\n      this.dndClass = 'slot-start-dnd-accept';\n    } else {\n      // gray out the drop zone\n      this.dndClass = 'slot-start-dnd-reject';\n    }\n  }\n};\n\nvar stopDnd = function () {\n  this.dndClass = '';\n};\n\nmodule.exports = View.extend({\n  template: templates.analyze.slot,\n  props: {\n    dndClass: 'string', // CSS class to add when a facet dnd is in progress\n    updateCounter: {\n      type: 'number',\n      default: 0,\n      required: true\n    }\n  },\n  derived: {\n    requiredText: {\n      deps: ['model.required', 'model.isFilled'],\n      fn: function () {\n        if (this.model.isFilled) {\n          return 'click to configure';\n        } else {\n          if (this.model.required) {\n            return 'required';\n          } else {\n            return 'optional';\n          }\n        }\n      }\n    },\n    chipText: {\n      deps: ['model.isFilled', 'updateCounter'],\n      cache: false,\n      fn: function () {\n        var filter = this.collection.parent.filter;\n\n        // stop accepting DND\n        if (this._sortable) {\n          this._sortable.option('disabled', true);\n        }\n\n        if (filter) {\n          if (this.model.type === 'partition') {\n            var partition = filter.partitions.get(this.model.rank, 'rank');\n            if (partition) {\n              return partition.facetName;\n            }\n          } else if (this.model.type === 'aggregate') {\n            var aggregate = filter.aggregates.get(this.model.rank, 'rank');\n            if (aggregate) {\n              return aggregate.operation + ' ' + aggregate.label;\n            }\n          } else {\n            console.error('Illegal slot');\n          }\n        }\n\n        // this slots should accept DND\n        if (this._sortable) {\n          this._sortable.option('disabled', false);\n        }\n        return '';\n      }\n    }\n  },\n  initialize: function () {\n    var filter = this.collection.parent.filter;\n    this.model.isFilled = false;\n\n    if (filter) {\n      if (this.model.type === 'partition') {\n        var partition = filter.partitions.get(this.model.rank, 'rank');\n        if (partition) {\n          this.model.isFilled = true;\n        }\n      } else if (this.model.type === 'aggregate') {\n        var aggregate = filter.aggregates.get(this.model.rank, 'rank');\n        if (aggregate) {\n          this.model.isFilled = true;\n        }\n      } else {\n        console.error('Illegal slot');\n      }\n    }\n\n    // add remove classes 'dndAccept' and 'dndRefuse' on drag-and-drop\n    app.on('dragStart', startDnd, this);\n    app.on('dragEnd', stopDnd, this);\n    this.on('remove', function () {\n      app.off('dragStart', startDnd);\n      app.off('dragEnd', stopDnd);\n    }, this);\n  },\n  bindings: {\n    'dndClass': {\n      type: 'class',\n      hook: 'drop-zone'\n    },\n    'model.description': {\n      type: 'text',\n      hook: 'description'\n    },\n    'requiredText': {\n      type: 'text',\n      hook: 'required'\n    },\n    'chipText': {\n      type: 'text',\n      hook: 'drop-zone'\n    },\n    'model.isFilled': {\n      type: 'toggle',\n      hook: 'button-div'\n    }\n  },\n  events: {\n    'click .clickTarget': 'rotateSetting',\n    'click [data-hook~=\"delete\"]': 'emptySlot'\n  },\n  rotateSetting: function () {\n    var filter = this.collection.parent.filter;\n    filter.releaseDataFilter();\n\n    if (this.model.type === 'partition') {\n      var partition = filter.partitions.get(this.model.rank, 'rank');\n      if (!partition) {\n        return;\n      }\n\n      app.navigate('partition/' + partition.getId());\n    } else if (this.model.type === 'aggregate') {\n      var values = ['count', 'avg', 'sum', 'stddev', 'min', 'max'];\n      var aggregate = filter.aggregates.get(this.model.rank, 'rank');\n      if (!aggregate) {\n        return;\n      }\n\n      var i = values.indexOf(aggregate.operation) + 1;\n      if (i >= values.length) {\n        i = 0;\n      }\n\n      if (app.me.sessionType === 'client' && values[i] === 'min' | values[i] === 'max') {\n        // crossfilter does not support min/max\n        i = 0;\n      }\n\n      aggregate.operation = values[i];\n\n      app.trigger('refresh');\n\n      // force a redraw of the text\n      this.updateCounter += 1;\n    }\n  },\n  emptySlot: function () {\n    if (this.model.emptySlot()) {\n      app.trigger('refresh');\n\n      // force a redraw of the chipText\n      this.updateCounter += 1;\n    }\n  },\n  tryFillSlot: function (facet) {\n    if (this.model.tryFillSlot(facet)) {\n      // Hack-ish feature:\n      //  * for bubble plots, add a facet dropped as 'X axis' also as 'Point size'\n      //  * for 3d scatter plots, add a facet dropped as 'X axis' also as 'Color by'\n      var chartType = this.model.collection.parent.filter.chartType;\n      if (chartType === 'bubbleplot') {\n        if (this.model.description === 'X axis') {\n          this.model.collection.get('Point size', 'description').tryFillSlot(facet, 'count');\n        }\n      } else if (chartType === 'scatterchart') {\n        if (this.model.description === 'X axis') {\n          this.model.collection.get('Color by', 'description').tryFillSlot(facet, 'count');\n        }\n      }\n\n      app.trigger('refresh');\n\n      // force a redraw of the chipText\n      this.updateCounter += 1;\n    }\n  },\n  render: function () {\n    this.renderWithTemplate(this);\n\n    var me = this;\n    this._sortable = sortablejs.create(this.queryByHook('drop-zone'), {\n      draggable: '.mdl-chip',\n      disabled: me.model.isFilled,\n      group: {\n        name: 'facets',\n        pull: false,\n        put: true\n      },\n      onAdd: function (evt) {\n        // get the dropped facet\n        // because the ampersand view collection takes care of rendering a\n        // prettier one\n        var item = evt.item;\n        var facetId = item.getAttribute('data-id');\n        item.remove();\n\n        var facet = app.me.dataview.facets.get(facetId);\n        if (!facet) {\n          console.error('Cannot find facet');\n          return;\n        }\n        me.tryFillSlot(facet);\n      }\n    });\n  }\n});\n"],"mappings":"AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAHA;AAFA;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAZA;AAcA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAhCA;AAfA;AAkDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAFA;AAjBA;AAsBA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AAtBA;AAwBA;AAhNA","sourceRoot":""}\n//# sourceURL=webpack-internal:///de8e\n")},e96a:function(module,exports,__webpack_require__){eval('var Collection = __webpack_require__(/*! ampersand-collection */ "7bd3");\n\nvar Slot = __webpack_require__(/*! ./slot */ "aea4");\n\nmodule.exports = Collection.extend({\n  model: Slot,\n  indexes: [\'description\']\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZTk2YS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL21vZGVscy9zbG90cy5qcz9jYmU1Il0sInNvdXJjZXNDb250ZW50IjpbInZhciBDb2xsZWN0aW9uID0gcmVxdWlyZSgnYW1wZXJzYW5kLWNvbGxlY3Rpb24nKTtcbnZhciBTbG90ID0gcmVxdWlyZSgnLi9zbG90Jyk7XG5cbm1vZHVsZS5leHBvcnRzID0gQ29sbGVjdGlvbi5leHRlbmQoe1xuICBtb2RlbDogU2xvdCxcbiAgaW5kZXhlczogWydkZXNjcmlwdGlvbiddXG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///e96a\n')},e9bd:function(module,exports,__webpack_require__){eval("var app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar BaseWidget = __webpack_require__(/*! ./base-widget */ \"26ef\");\n\nvar Chart = __webpack_require__(/*! chart.js */ \"70b5\");\n\nvar colors = __webpack_require__(/*! ../../colors */ \"eb63\");\n\nvar misval = Spot.util.misval;\n\nvar util = __webpack_require__(/*! ./util */ \"2b41\"); // Called by Chartjs, this -> chart instance\n\n\nfunction onClick(ev, elements) {\n  var model = this._Ampersandview.model;\n  var partition = model.filter.partitions.get(1, 'rank');\n\n  if (elements.length > 0) {\n    partition.updateSelection(partition.groups.models[elements[0]._index]);\n    model.filter.updateDataFilter();\n    app.me.dataview.getData();\n  }\n}\n\nfunction _deinitChart(view) {\n  if (view._chartjs) {\n    view._chartjs.destroy();\n\n    delete view._chartjs;\n  }\n\n  delete view._config;\n  var canvas = view.queryByHook('canvas');\n\n  if (canvas) {\n    view.el.removeChild(canvas);\n  }\n\n  view.isInitialized = false;\n}\n\nfunction _initChart(view) {\n  // Configure plot\n  view._config = view.model.chartjsConfig();\n  var options = view._config.options; // axis types\n\n  var partitionA = view.model.filter.partitions.get(1, 'rank');\n\n  if (partitionA.isDatetime) {\n    options.scales.xAxes[0].type = 'time';\n  } else if (partitionA.isDuration) {\n    options.scales.xAxes[0].type = 'spot-duration';\n  }\n\n  options.scales.xAxes[0].scaleLabel = {\n    display: partitionA.showLabel,\n    labelString: partitionA.label\n  }; // title\n\n  options.title.text = view.model.getTitle(); // mouse interaction\n\n  options.onClick = onClick; // force a square full size plot\n\n  var width = view.el.offsetWidth;\n  var height = view.el.offsetHeight;\n  var canvas = document.createElement('canvas');\n  canvas.setAttribute('data-hook', 'canvas');\n  view.el.appendChild(canvas);\n  var ctx = canvas.getContext('2d');\n  ctx.canvas.width = width;\n  ctx.canvas.height = height;\n  var aggregateD = view.model.filter.aggregates.get(4, 'rank');\n\n  if (aggregateD) {\n    // show secondary y Axis on the right when we have a second y variable\n    view._config.options.scales.yAxes[1].display = true;\n  } // Create Chartjs object\n\n\n  view._chartjs = new Chart(ctx, view._config); // In callbacks on the chart we will need the view, so store a reference\n\n  view._chartjs._Ampersandview = view;\n  view.isInitialized = true;\n}\n\nfunction _update(view) {\n  if (!view.isInitialized) {\n    return;\n  }\n\n  var filter = view.model.filter;\n  var partitionA = filter.partitions.get(1, 'rank');\n  var partitionB = filter.partitions.get(2, 'rank');\n  var chartData = view._config.data;\n  var datasetCount; // update legends and tooltips\n\n  if (partitionB && partitionB.groups && partitionB.groups.length > 1) {\n    // we have sub-grouping\n    view._config.options.legend.display = partitionB.showLegend;\n    view._config.options.tooltips.mode = 'label';\n    datasetCount = partitionB.groups.length;\n  } else {\n    view._config.options.legend.display = false;\n    view._config.options.tooltips.mode = 'single';\n    datasetCount = 1;\n  }\n\n  var aggregate;\n  aggregate = filter.aggregates.get(1, 'rank');\n  var valueFn;\n\n  if (aggregate) {\n    valueFn = function valueFn(group) {\n      if (group.count !== misval && group.aa !== misval) {\n        return parseFloat(group.aa) || null;\n      }\n\n      return null;\n    };\n  } else {\n    valueFn = function valueFn(group) {\n      if (group.count !== misval && group.count !== 0) {\n        return parseInt(group.count);\n      }\n\n      return null;\n    };\n  }\n\n  view._config.options.errorDir = 'both';\n  aggregate = filter.aggregates.get(2, 'rank');\n  var errorXFn;\n\n  if (aggregate) {\n    errorXFn = function errorXFn(group) {\n      if (group.bb !== misval) {\n        return parseFloat(group.bb) || 0;\n      }\n\n      return 0;\n    };\n  } else {\n    errorXFn = function errorXFn(group) {\n      return null;\n    };\n\n    view._config.options.errorDir = 'vertical';\n  }\n\n  aggregate = filter.aggregates.get(3, 'rank');\n  var errorYFn;\n\n  if (aggregate) {\n    errorYFn = function errorYFn(group) {\n      if (group.cc !== misval) {\n        return parseFloat(group.cc) || 0;\n      }\n\n      return 0;\n    };\n  } else {\n    errorYFn = function errorYFn(group) {\n      return null;\n    };\n\n    if (view._config.options.errorDir === 'vertical') {\n      view._config.options.errorDir === 'none';\n    }\n\n    if (view._config.options.errorDir === 'both') {\n      view._config.options.errorDir === 'horizontal';\n    }\n  }\n\n  aggregate = filter.aggregates.get(4, 'rank');\n  var secondYFn = false;\n  var secondYOffset = datasetCount;\n\n  if (aggregate) {\n    // double the number of datasets for the second y value\n    secondYOffset = datasetCount;\n    datasetCount = 2 * datasetCount;\n\n    secondYFn = function secondYFn(group) {\n      if (group.dd !== misval) {\n        return parseFloat(group.dd) || null;\n      }\n\n      return null;\n    };\n  }\n\n  util.resizeChartjsData(chartData, partitionA, partitionB, {\n    multiDimensional: true,\n    doubleDatasets: secondYFn\n  }); // add datapoints\n\n  filter.data.forEach(function (group) {\n    var i = util.partitionValueToIndex(partitionA, group.a);\n    var j = util.partitionValueToIndex(partitionB, group.b);\n\n    if (i >= 0 && j >= 0) {\n      chartData.datasets[j].data[i].x = group.a;\n      chartData.datasets[j].data[i].y = valueFn(group);\n      chartData.datasets[j].error[i].x = errorXFn(group);\n      chartData.datasets[j].error[i].y = errorYFn(group);\n      chartData.datasets[j].yAxisID = 'first-scale';\n\n      if (secondYFn) {\n        chartData.datasets[secondYOffset + j].data[i].x = group.a;\n        chartData.datasets[secondYOffset + j].data[i].y = secondYFn(group);\n        chartData.datasets[secondYOffset + j].error[i].x = null;\n        chartData.datasets[secondYOffset + j].error[i].y = null;\n        chartData.datasets[secondYOffset + j].yAxisID = 'second-scale';\n      }\n    }\n  }); // Add an extra dataset to highlight selected area\n\n  var selectionId = datasetCount;\n  chartData.datasets[selectionId] = chartData.datasets[selectionId] || {\n    data: [{\n      x: null,\n      y: 1\n    }, {\n      x: null,\n      y: 1\n    }],\n    error: [{\n      x: null,\n      y: null\n    }, {\n      x: null,\n      y: null\n    }],\n    yAxisID: 'selection-scale',\n    label: 'selection',\n    backgroundColor: colors.getColor(1).css(),\n    borderColor: colors.getColor(1).css(),\n    fill: true,\n    lineTension: 0,\n    pointRadius: 0\n  };\n\n  if (partitionA.selected && partitionA.selected.length > 0) {\n    chartData.datasets[selectionId].data[0].x = partitionA.selected[0];\n    chartData.datasets[selectionId].data[1].x = partitionA.selected[1];\n  } else {\n    chartData.datasets[selectionId].data[0].x = null;\n    chartData.datasets[selectionId].data[1].x = null;\n  } // Hand-off to ChartJS for plotting\n\n\n  view._chartjs.update();\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner mdl-card__media\"></div>',\n  update: function update() {\n    _update(this);\n  },\n  initChart: function initChart() {\n    _initChart(this);\n  },\n  deinitChart: function deinitChart() {\n    _deinitChart(this);\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"e9bd.js","sources":["webpack:///./src/widgets/views/chartjs1d.js?27c1"],"sourcesContent":["var app = require('ampersand-app');\nvar Spot = require('spot-framework');\nvar BaseWidget = require('./base-widget');\nvar Chart = require('chart.js');\nvar colors = require('../../colors');\nvar misval = Spot.util.misval;\nvar util = require('./util');\n\n// Called by Chartjs, this -> chart instance\nfunction onClick (ev, elements) {\n  var model = this._Ampersandview.model;\n  var partition = model.filter.partitions.get(1, 'rank');\n\n  if (elements.length > 0) {\n    partition.updateSelection(partition.groups.models[elements[0]._index]);\n    model.filter.updateDataFilter();\n    app.me.dataview.getData();\n  }\n}\n\nfunction deinitChart (view) {\n  if (view._chartjs) {\n    view._chartjs.destroy();\n    delete view._chartjs;\n  }\n  delete view._config;\n\n  var canvas = view.queryByHook('canvas');\n  if (canvas) {\n    view.el.removeChild(canvas);\n  }\n  view.isInitialized = false;\n}\n\nfunction initChart (view) {\n  // Configure plot\n  view._config = view.model.chartjsConfig();\n  var options = view._config.options;\n\n  // axis types\n  var partitionA = view.model.filter.partitions.get(1, 'rank');\n  if (partitionA.isDatetime) {\n    options.scales.xAxes[0].type = 'time';\n  } else if (partitionA.isDuration) {\n    options.scales.xAxes[0].type = 'spot-duration';\n  }\n  options.scales.xAxes[0].scaleLabel = {\n    display: partitionA.showLabel,\n    labelString: partitionA.label\n  };\n\n  // title\n  options.title.text = view.model.getTitle();\n\n  // mouse interaction\n  options.onClick = onClick;\n\n  // force a square full size plot\n  var width = view.el.offsetWidth;\n  var height = view.el.offsetHeight;\n\n  var canvas = document.createElement('canvas');\n  canvas.setAttribute('data-hook', 'canvas');\n  view.el.appendChild(canvas);\n\n  var ctx = canvas.getContext('2d');\n  ctx.canvas.width = width;\n  ctx.canvas.height = height;\n\n  var aggregateD = view.model.filter.aggregates.get(4, 'rank');\n  if (aggregateD) {\n    // show secondary y Axis on the right when we have a second y variable\n    view._config.options.scales.yAxes[1].display = true;\n  }\n\n  // Create Chartjs object\n  view._chartjs = new Chart(ctx, view._config);\n\n  // In callbacks on the chart we will need the view, so store a reference\n  view._chartjs._Ampersandview = view;\n  view.isInitialized = true;\n}\n\nfunction update (view) {\n  if (!view.isInitialized) {\n    return;\n  }\n\n  var filter = view.model.filter;\n  var partitionA = filter.partitions.get(1, 'rank');\n  var partitionB = filter.partitions.get(2, 'rank');\n\n  var chartData = view._config.data;\n  var datasetCount;\n\n  // update legends and tooltips\n  if (partitionB && partitionB.groups && partitionB.groups.length > 1) {\n    // we have sub-grouping\n    view._config.options.legend.display = partitionB.showLegend;\n    view._config.options.tooltips.mode = 'label';\n    datasetCount = partitionB.groups.length;\n  } else {\n    view._config.options.legend.display = false;\n    view._config.options.tooltips.mode = 'single';\n    datasetCount = 1;\n  }\n\n  var aggregate;\n\n  aggregate = filter.aggregates.get(1, 'rank');\n  var valueFn;\n  if (aggregate) {\n    valueFn = function (group) {\n      if (group.count !== misval && group.aa !== misval) {\n        return parseFloat(group.aa) || null;\n      }\n      return null;\n    };\n  } else {\n    valueFn = function (group) {\n      if (group.count !== misval && group.count !== 0) {\n        return parseInt(group.count);\n      }\n      return null;\n    };\n  }\n\n  view._config.options.errorDir = 'both';\n  aggregate = filter.aggregates.get(2, 'rank');\n  var errorXFn;\n  if (aggregate) {\n    errorXFn = function (group) {\n      if (group.bb !== misval) {\n        return parseFloat(group.bb) || 0;\n      }\n      return 0;\n    };\n  } else {\n    errorXFn = function (group) { return null; };\n    view._config.options.errorDir = 'vertical';\n  }\n\n  aggregate = filter.aggregates.get(3, 'rank');\n  var errorYFn;\n  if (aggregate) {\n    errorYFn = function (group) {\n      if (group.cc !== misval) {\n        return parseFloat(group.cc) || 0;\n      }\n      return 0;\n    };\n  } else {\n    errorYFn = function (group) { return null; };\n    if (view._config.options.errorDir === 'vertical') {\n      view._config.options.errorDir === 'none';\n    }\n    if (view._config.options.errorDir === 'both') {\n      view._config.options.errorDir === 'horizontal';\n    }\n  }\n\n  aggregate = filter.aggregates.get(4, 'rank');\n  var secondYFn = false;\n  var secondYOffset = datasetCount;\n  if (aggregate) {\n    // double the number of datasets for the second y value\n    secondYOffset = datasetCount;\n    datasetCount = 2 * datasetCount;\n    secondYFn = function (group) {\n      if (group.dd !== misval) {\n        return parseFloat(group.dd) || null;\n      }\n      return null;\n    };\n  }\n\n  util.resizeChartjsData(chartData, partitionA, partitionB, {\n    multiDimensional: true,\n    doubleDatasets: secondYFn\n  });\n\n  // add datapoints\n  filter.data.forEach(function (group) {\n    var i = util.partitionValueToIndex(partitionA, group.a);\n    var j = util.partitionValueToIndex(partitionB, group.b);\n\n    if (i >= 0 && j >= 0) {\n      chartData.datasets[j].data[i].x = group.a;\n      chartData.datasets[j].data[i].y = valueFn(group);\n      chartData.datasets[j].error[i].x = errorXFn(group);\n      chartData.datasets[j].error[i].y = errorYFn(group);\n      chartData.datasets[j].yAxisID = 'first-scale';\n\n      if (secondYFn) {\n        chartData.datasets[secondYOffset + j].data[i].x = group.a;\n        chartData.datasets[secondYOffset + j].data[i].y = secondYFn(group);\n        chartData.datasets[secondYOffset + j].error[i].x = null;\n        chartData.datasets[secondYOffset + j].error[i].y = null;\n        chartData.datasets[secondYOffset + j].yAxisID = 'second-scale';\n      }\n    }\n  });\n\n  // Add an extra dataset to highlight selected area\n  var selectionId = datasetCount;\n  chartData.datasets[selectionId] = chartData.datasets[selectionId] || {\n    data: [ {x: null, y: 1}, {x: null, y: 1} ],\n    error: [ {x: null, y: null}, {x: null, y: null} ],\n    yAxisID: 'selection-scale',\n    label: 'selection',\n    backgroundColor: colors.getColor(1).css(),\n    borderColor: colors.getColor(1).css(),\n    fill: true,\n    lineTension: 0,\n    pointRadius: 0\n  };\n\n  if (partitionA.selected && partitionA.selected.length > 0) {\n    chartData.datasets[selectionId].data[0].x = partitionA.selected[0];\n    chartData.datasets[selectionId].data[1].x = partitionA.selected[1];\n  } else {\n    chartData.datasets[selectionId].data[0].x = null;\n    chartData.datasets[selectionId].data[1].x = null;\n  }\n\n  // Hand-off to ChartJS for plotting\n  view._chartjs.update();\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner mdl-card__media\"></div>',\n\n  update: function () {\n    update(this);\n  },\n\n  initChart: function () {\n    initChart(this);\n  },\n\n  deinitChart: function () {\n    deinitChart(this);\n  }\n});\n"],"mappings":"AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAFA;AACA;AAKA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAFA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AATA;AACA;AAWA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAbA","sourceRoot":""}\n//# sourceURL=webpack-internal:///e9bd\n")},eb63:function(module,exports,__webpack_require__){eval("/**\n *\n * Color handling\n *\n * All colors are a chroma.js color. See http://gka.github.io/chroma.js/\n * @module colors\n */\nvar chroma = __webpack_require__(/*! chroma-js */ \"9b81\");\n\nvar colors = ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f']; // alternative color scheme, needs some tuning:\n// var colors = ['#cccccc', '#c2e06c', '#00168c', '#997100', '#eabd00', '#ff4889', '#f497ff', '#0db700', '#d26bb8', '#a8e74b', '#a83375', '#ff6a2b', '#8690ff', '#ff4b50', '#fb78ff', '#00a349', '#c6008f', '#4ef168', '#ff25a2', '#be6300', '#b667ff', '#ff9451', '#e113d2', '#cc0013', '#ff66e0'];\n\nvar scale = chroma.scale('Spectral');\nmodule.exports = {\n  /**\n   * Get i-th color\n   * @param {number} color number\n   * @returns {Object} color\n   */\n  getColor: function getColor(i) {\n    i = parseInt(i);\n\n    if (i < 0 || i >= colors.length) {\n      // pick a color from the scale defined above\n      return scale((i - colors.length) * (211 / 971) % 1);\n    } else {\n      return chroma(colors[i]);\n    }\n  },\n\n  /**\n   * Colorscale from 0 to 1\n   * @param  {number} f [description]\n   * @return {number}   [description]\n   */\n  getColorFloat: function getColorFloat(f) {\n    return scale(f);\n  },\n\n  /**\n   * Color for unselected groups\n   * @type {any}\n   */\n  unselectedColor: chroma('#aaaaaa')\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWI2My5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9jb2xvcnMuanM/MWI5MiJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqXG4gKiBDb2xvciBoYW5kbGluZ1xuICpcbiAqIEFsbCBjb2xvcnMgYXJlIGEgY2hyb21hLmpzIGNvbG9yLiBTZWUgaHR0cDovL2drYS5naXRodWIuaW8vY2hyb21hLmpzL1xuICogQG1vZHVsZSBjb2xvcnNcbiAqL1xudmFyIGNocm9tYSA9IHJlcXVpcmUoJ2Nocm9tYS1qcycpO1xuXG52YXIgY29sb3JzID0gWycjOGRkM2M3JywgJyNmZmZmYjMnLCAnI2JlYmFkYScsICcjZmI4MDcyJywgJyM4MGIxZDMnLCAnI2ZkYjQ2MicsICcjYjNkZTY5JywgJyNmY2NkZTUnLCAnI2Q5ZDlkOScsICcjYmM4MGJkJywgJyNjY2ViYzUnLCAnI2ZmZWQ2ZiddO1xuLy8gYWx0ZXJuYXRpdmUgY29sb3Igc2NoZW1lLCBuZWVkcyBzb21lIHR1bmluZzpcbi8vIHZhciBjb2xvcnMgPSBbJyNjY2NjY2MnLCAnI2MyZTA2YycsICcjMDAxNjhjJywgJyM5OTcxMDAnLCAnI2VhYmQwMCcsICcjZmY0ODg5JywgJyNmNDk3ZmYnLCAnIzBkYjcwMCcsICcjZDI2YmI4JywgJyNhOGU3NGInLCAnI2E4MzM3NScsICcjZmY2YTJiJywgJyM4NjkwZmYnLCAnI2ZmNGI1MCcsICcjZmI3OGZmJywgJyMwMGEzNDknLCAnI2M2MDA4ZicsICcjNGVmMTY4JywgJyNmZjI1YTInLCAnI2JlNjMwMCcsICcjYjY2N2ZmJywgJyNmZjk0NTEnLCAnI2UxMTNkMicsICcjY2MwMDEzJywgJyNmZjY2ZTAnXTtcbnZhciBzY2FsZSA9IGNocm9tYS5zY2FsZSgnU3BlY3RyYWwnKTtcblxubW9kdWxlLmV4cG9ydHMgPSB7XG4gIC8qKlxuICAgKiBHZXQgaS10aCBjb2xvclxuICAgKiBAcGFyYW0ge251bWJlcn0gY29sb3IgbnVtYmVyXG4gICAqIEByZXR1cm5zIHtPYmplY3R9IGNvbG9yXG4gICAqL1xuICBnZXRDb2xvcjogZnVuY3Rpb24gZ2V0Q29sb3IgKGkpIHtcbiAgICBpID0gcGFyc2VJbnQoaSk7XG4gICAgaWYgKGkgPCAwIHx8IGkgPj0gY29sb3JzLmxlbmd0aCkge1xuICAgICAgLy8gcGljayBhIGNvbG9yIGZyb20gdGhlIHNjYWxlIGRlZmluZWQgYWJvdmVcbiAgICAgIHJldHVybiBzY2FsZSgoKGkgLSBjb2xvcnMubGVuZ3RoKSAqICgyMTEgLyA5NzEpKSAlIDEpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gY2hyb21hKGNvbG9yc1tpXSk7XG4gICAgfVxuICB9LFxuICAvKipcbiAgICogQ29sb3JzY2FsZSBmcm9tIDAgdG8gMVxuICAgKiBAcGFyYW0gIHtudW1iZXJ9IGYgW2Rlc2NyaXB0aW9uXVxuICAgKiBAcmV0dXJuIHtudW1iZXJ9ICAgW2Rlc2NyaXB0aW9uXVxuICAgKi9cbiAgZ2V0Q29sb3JGbG9hdDogZnVuY3Rpb24gKGYpIHtcbiAgICByZXR1cm4gc2NhbGUoZik7XG4gIH0sXG4gIC8qKlxuICAgKiBDb2xvciBmb3IgdW5zZWxlY3RlZCBncm91cHNcbiAgICogQHR5cGUge2FueX1cbiAgICovXG4gIHVuc2VsZWN0ZWRDb2xvcjogY2hyb21hKCcjYWFhYWFhJylcbn07XG4iXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0FBT0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUFBO0FBRUE7QUFDQTs7Ozs7QUFLQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7Ozs7O0FBS0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTs7OztBQUlBO0FBM0JBIiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///eb63\n")},ee83:function(module,exports,__webpack_require__){"use strict";eval("// Code adapted from: https://github.com/CAYdenberg/Chart.js-ErrorBars.git\n// Original license: MIT\n// Original copyright: Copyright (c) 2013-2016 Nick Downie\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nmodule.exports = function (Chart, chartType, newType) {\n  var helpers = Chart.helpers; // ErrorBar element\n\n  Chart.elements.ErrorBar = Chart.elements.ErrorBar || Chart.Element.extend({\n    draw: function draw() {\n      var ctx = this._chart.ctx;\n      var vm = this._view;\n\n      if (vm.direction === 'none') {\n        return;\n      }\n\n      var halfWidth = vm.capWidth / 2;\n      var halfHeight = vm.capHeight / 2;\n      var top = vm.yTop;\n      var bottom = vm.yBottom;\n      var left = vm.xLeft;\n      var right = vm.xRight;\n      ctx.strokeStyle = vm.strokeColor;\n      ctx.lineWidth = vm.strokeWidth; // draw vertical error bar\n\n      if (vm.direction === 'vertical' || vm.direction === 'both') {\n        ctx.beginPath();\n        ctx.moveTo(vm.x, top);\n        ctx.lineTo(vm.x, bottom);\n        ctx.stroke();\n        ctx.beginPath();\n        ctx.moveTo(vm.x - halfWidth, top);\n        ctx.lineTo(vm.x + halfWidth, top);\n        ctx.stroke();\n        ctx.beginPath();\n        ctx.moveTo(vm.x - halfWidth, bottom);\n        ctx.lineTo(vm.x + halfWidth, bottom);\n        ctx.stroke();\n      } // draw horizontal error bar\n\n\n      if (vm.direction === 'horizontal' || vm.direction === 'both') {\n        ctx.beginPath();\n        ctx.moveTo(left, vm.y);\n        ctx.lineTo(right, vm.y);\n        ctx.stroke();\n        ctx.beginPath();\n        ctx.moveTo(left, vm.y - halfHeight);\n        ctx.lineTo(left, vm.y + halfHeight);\n        ctx.stroke();\n        ctx.beginPath();\n        ctx.moveTo(right, vm.y - halfHeight);\n        ctx.lineTo(right, vm.y + halfHeight);\n        ctx.stroke();\n      }\n    }\n  });\n  /**\n   * Default config for errorbars:\n   * errorDir: none, horizontal, vertical, both\n   * errorStrokeWidth\n   * errorCapWidth\n   * errorCapHeight\n   * errorColor\n   */\n\n  Chart.defaults[newType] = helpers.extend(Chart.defaults[chartType], {\n    errorDir: 'vertical',\n    errorStrokeWidth: 1,\n    errorCapWidth: 2.5,\n    errorCapHeight: 0.25,\n    errorColor: 'rgba(0,0,0,1)'\n  }); // Extend chart type with error bar\n\n  Chart.controllers[newType] = Chart.controllers[chartType].extend({\n    initialize: function initialize(chart, datasetIndex) {\n      // call Super\n      Chart.controllers[chartType].prototype.initialize.call(this, chart, datasetIndex);\n      var options = chart.chart.config.options;\n      options.errorDir = options.errorDir || Chart.defaults[newType].errorDir;\n      options.errorCapWidth = options.errorCapWidth || Chart.defaults[newType].errorCapWidth;\n      options.errorCapHeight = options.errorCapHeight || Chart.defaults[newType].errorCapHeight;\n      options.errorStrokeColor = options.errorColor || Chart.defaults[newType].errorColor;\n      options.errorStrokeWidth = options.errorStrokeWidth || Chart.defaults[newType].errorStrokeWidth;\n    },\n    addElements: function addElements() {\n      // call Super\n      Chart.controllers[chartType].prototype.addElements.call(this);\n      var meta = this.getMeta();\n      var error = this.getDataset().error || [];\n      var metaError = meta.error || [];\n      var i, ilen;\n\n      for (i = 0, ilen = error.length; i < ilen; i++) {\n        metaError[i] = metaError[i] || new Chart.elements.ErrorBar({\n          _chart: this.chart.chart,\n          _datasetIndex: this.index,\n          _index: i\n        });\n      }\n\n      meta.error = metaError;\n    },\n    addElementAndReset: function addElementAndReset(index) {\n      // call Super\n      Chart.controllers[chartType].prototype.addElementAndReset.call(this, index);\n      var meta = this.getMeta();\n      var metaError = meta.error;\n      var metaData = meta.data;\n      metaError[index] = metaError[index] || new Chart.elements.ErrorBar({\n        _chart: this.chart.chart,\n        _datasetIndex: this.index,\n        _index: index,\n        x: 0,\n        y: 0\n      });\n      this.updateErrorBar(metaError[index], metaData[index], index, true);\n    },\n    update: function update(reset) {\n      // call Super\n      Chart.controllers[chartType].prototype.update.call(this, reset);\n      var meta = this.getMeta();\n      var metaData = meta.data;\n      var metaError = meta.error; // make sure we don't have more error bars than points\n\n      var cut = metaError.length - metaData.length;\n\n      if (cut > 0) {\n        metaError.splice(metaData.length, cut);\n      }\n\n      metaError.forEach(function (errorBar, index) {\n        this.updateErrorBar(errorBar, metaData[index], index, reset);\n      }, this);\n    },\n    updateErrorBar: function updateErrorBar(errorBar, element, index, reset) {\n      var dataset = this.getDataset();\n      var meta = this.getMeta();\n      var xScale = this.getScaleForId(meta.xAxisID);\n      var yScale = this.getScaleForId(meta.yAxisID);\n      var options = this.chart.chart.config.options;\n      var px = element._model.x;\n      var py = element._model.y;\n      var x = xScale.getValueForPixel(px);\n      var y = yScale.getValueForPixel(py);\n      var errorX;\n      var errorY;\n\n      if (_typeof(dataset.error[index]) === 'object' && dataset.error[index] != null) {\n        errorX = dataset.error[index].x;\n        errorY = dataset.error[index].y;\n      } else {\n        errorX = dataset.error[index];\n        errorY = dataset.error[index];\n      } // Utility\n\n\n      errorBar._chart = this.chart.chart;\n      errorBar._xScale = xScale;\n      errorBar._yScale = yScale;\n      errorBar._datasetIndex = this.index;\n      errorBar._index = index;\n      errorBar._model = {\n        // Position\n        x: px,\n        y: py,\n        yTop: yScale.getPixelForValue(y + errorY, index, this.index, this.chart.isCombo),\n        yBottom: yScale.getPixelForValue(y - errorY, index, this.index, this.chart.isCombo),\n        xLeft: xScale.getPixelForValue(x - errorX, index, this.index, this.chart.isCombo),\n        xRight: xScale.getPixelForValue(x + errorX, index, this.index, this.chart.isCombo),\n        // Appearance\n        capWidth: element._model.width * options.errorCapWidth || options.errorCapWidth,\n        capHeight: element._model.height * options.errorCapHeight || options.errorCapHeight,\n        direction: options.errorDir,\n        strokeColor: options.errorStrokeColor,\n        strokeWidth: options.errorStrokeWidth\n      };\n      errorBar.pivot();\n    },\n    draw: function draw(ease) {\n      var easingDecimal = ease || 1; // call Super\n\n      Chart.controllers[chartType].prototype.draw.call(this, ease);\n      this.getMeta().error.forEach(function (errorBar, index) {\n        // Chech for valid errror bar sizes:\n        // 2-d datastructure: check error.x and error.y\n        // 1-d datastructure: check error\n        var e = this.getDataset().error[index];\n\n        if (e !== null && _typeof(e) === 'object') {\n          if (e.x !== null && e.x !== undefined && !isNaN(e.x) || e.y !== null && e.y !== undefined && !isNaN(e.y)) {\n            errorBar.transition(easingDecimal).draw();\n          }\n        } else if (e !== null && e !== undefined && !isNaN(e) && e !== 0) {\n          errorBar.transition(easingDecimal).draw();\n        }\n      }, this);\n    }\n  });\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ee83.js","sources":["webpack:///./src/widgets/chartjs-errorbars.js?6f9c"],"sourcesContent":["// Code adapted from: https://github.com/CAYdenberg/Chart.js-ErrorBars.git\n// Original license: MIT\n// Original copyright: Copyright (c) 2013-2016 Nick Downie\n'use strict';\n\nmodule.exports = function (Chart, chartType, newType) {\n  var helpers = Chart.helpers;\n\n  // ErrorBar element\n  Chart.elements.ErrorBar = Chart.elements.ErrorBar || Chart.Element.extend({\n    draw: function () {\n      var ctx = this._chart.ctx;\n      var vm = this._view;\n\n      if (vm.direction === 'none') {\n        return;\n      }\n\n      var halfWidth = vm.capWidth / 2;\n      var halfHeight = vm.capHeight / 2;\n\n      var top = vm.yTop;\n      var bottom = vm.yBottom;\n      var left = vm.xLeft;\n      var right = vm.xRight;\n\n      ctx.strokeStyle = vm.strokeColor;\n      ctx.lineWidth = vm.strokeWidth;\n\n      // draw vertical error bar\n      if (vm.direction === 'vertical' || vm.direction === 'both') {\n        ctx.beginPath();\n        ctx.moveTo(vm.x, top);\n        ctx.lineTo(vm.x, bottom);\n        ctx.stroke();\n\n        ctx.beginPath();\n        ctx.moveTo(vm.x - halfWidth, top);\n        ctx.lineTo(vm.x + halfWidth, top);\n        ctx.stroke();\n\n        ctx.beginPath();\n        ctx.moveTo(vm.x - halfWidth, bottom);\n        ctx.lineTo(vm.x + halfWidth, bottom);\n        ctx.stroke();\n      }\n\n      // draw horizontal error bar\n      if (vm.direction === 'horizontal' || vm.direction === 'both') {\n        ctx.beginPath();\n        ctx.moveTo(left, vm.y);\n        ctx.lineTo(right, vm.y);\n        ctx.stroke();\n\n        ctx.beginPath();\n        ctx.moveTo(left, vm.y - halfHeight);\n        ctx.lineTo(left, vm.y + halfHeight);\n        ctx.stroke();\n\n        ctx.beginPath();\n        ctx.moveTo(right, vm.y - halfHeight);\n        ctx.lineTo(right, vm.y + halfHeight);\n        ctx.stroke();\n      }\n    }\n  });\n\n  /**\n   * Default config for errorbars:\n   * errorDir: none, horizontal, vertical, both\n   * errorStrokeWidth\n   * errorCapWidth\n   * errorCapHeight\n   * errorColor\n   */\n  Chart.defaults[newType] = helpers.extend(Chart.defaults[chartType], {\n    errorDir: 'vertical',\n    errorStrokeWidth: 1,\n    errorCapWidth: 2.5,\n    errorCapHeight: 0.25,\n    errorColor: 'rgba(0,0,0,1)'\n  });\n\n  // Extend chart type with error bar\n  Chart.controllers[newType] = Chart.controllers[chartType].extend({\n    initialize: function (chart, datasetIndex) {\n      // call Super\n      Chart.controllers[chartType].prototype.initialize.call(this, chart, datasetIndex);\n\n      var options = chart.chart.config.options;\n      options.errorDir = options.errorDir || Chart.defaults[newType].errorDir;\n      options.errorCapWidth = options.errorCapWidth || Chart.defaults[newType].errorCapWidth;\n      options.errorCapHeight = options.errorCapHeight || Chart.defaults[newType].errorCapHeight;\n      options.errorStrokeColor = options.errorColor || Chart.defaults[newType].errorColor;\n      options.errorStrokeWidth = options.errorStrokeWidth || Chart.defaults[newType].errorStrokeWidth;\n    },\n\n    addElements: function () {\n      // call Super\n      Chart.controllers[chartType].prototype.addElements.call(this);\n\n      var meta = this.getMeta();\n      var error = this.getDataset().error || [];\n      var metaError = meta.error || [];\n      var i, ilen;\n\n      for (i = 0, ilen = error.length; i < ilen; i++) {\n        metaError[i] = metaError[i] || new Chart.elements.ErrorBar({\n          _chart: this.chart.chart,\n          _datasetIndex: this.index,\n          _index: i\n        });\n      }\n      meta.error = metaError;\n    },\n\n    addElementAndReset: function (index) {\n      // call Super\n      Chart.controllers[chartType].prototype.addElementAndReset.call(this, index);\n\n      var meta = this.getMeta();\n      var metaError = meta.error;\n      var metaData = meta.data;\n\n      metaError[index] = metaError[index] || new Chart.elements.ErrorBar({\n        _chart: this.chart.chart,\n        _datasetIndex: this.index,\n        _index: index,\n        x: 0,\n        y: 0\n      });\n      this.updateErrorBar(metaError[index], metaData[index], index, true);\n    },\n\n    update: function update (reset) {\n      // call Super\n      Chart.controllers[chartType].prototype.update.call(this, reset);\n\n      var meta = this.getMeta();\n      var metaData = meta.data;\n      var metaError = meta.error;\n\n      // make sure we don't have more error bars than points\n      var cut = metaError.length - metaData.length;\n      if (cut > 0) {\n        metaError.splice(metaData.length, cut);\n      }\n\n      metaError.forEach(function (errorBar, index) {\n        this.updateErrorBar(errorBar, metaData[index], index, reset);\n      }, this);\n    },\n\n    updateErrorBar: function updateErrorBar (errorBar, element, index, reset) {\n      var dataset = this.getDataset();\n      var meta = this.getMeta();\n      var xScale = this.getScaleForId(meta.xAxisID);\n      var yScale = this.getScaleForId(meta.yAxisID);\n\n      var options = this.chart.chart.config.options;\n\n      var px = element._model.x;\n      var py = element._model.y;\n\n      var x = xScale.getValueForPixel(px);\n      var y = yScale.getValueForPixel(py);\n\n      var errorX;\n      var errorY;\n      if (typeof dataset.error[index] === 'object' && dataset.error[index] != null) {\n        errorX = dataset.error[index].x;\n        errorY = dataset.error[index].y;\n      } else {\n        errorX = dataset.error[index];\n        errorY = dataset.error[index];\n      }\n\n      // Utility\n      errorBar._chart = this.chart.chart;\n      errorBar._xScale = xScale;\n      errorBar._yScale = yScale;\n      errorBar._datasetIndex = this.index;\n      errorBar._index = index;\n\n      errorBar._model = {\n        // Position\n        x: px,\n        y: py,\n        yTop: yScale.getPixelForValue(y + errorY, index, this.index, this.chart.isCombo),\n        yBottom: yScale.getPixelForValue(y - errorY, index, this.index, this.chart.isCombo),\n        xLeft: xScale.getPixelForValue(x - errorX, index, this.index, this.chart.isCombo),\n        xRight: xScale.getPixelForValue(x + errorX, index, this.index, this.chart.isCombo),\n\n        // Appearance\n        capWidth: element._model.width * options.errorCapWidth || options.errorCapWidth,\n        capHeight: element._model.height * options.errorCapHeight || options.errorCapHeight,\n        direction: options.errorDir,\n        strokeColor: options.errorStrokeColor,\n        strokeWidth: options.errorStrokeWidth\n      };\n\n      errorBar.pivot();\n    },\n\n    draw: function (ease) {\n      var easingDecimal = ease || 1;\n\n      // call Super\n      Chart.controllers[chartType].prototype.draw.call(this, ease);\n\n      this.getMeta().error.forEach(function (errorBar, index) {\n        // Chech for valid errror bar sizes:\n        // 2-d datastructure: check error.x and error.y\n        // 1-d datastructure: check error\n        var e = this.getDataset().error[index];\n\n        if (e !== null && typeof e === 'object') {\n          if ((e.x !== null && e.x !== undefined && !isNaN(e.x)) || (e.y !== null && e.y !== undefined && !isNaN(e.y))) {\n            errorBar.transition(easingDecimal).draw();\n          }\n        } else if (e !== null && e !== undefined && !isNaN(e) && e !== 0) {\n          errorBar.transition(easingDecimal).draw();\n        }\n      }, this);\n    }\n  });\n};\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;;;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAvDA;AA0DA;;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AALA;AACA;AAQA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAHA;AAKA;AACA;AAAA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AALA;AAOA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAdA;AAiBA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA5IA;AA8IA","sourceRoot":""}\n//# sourceURL=webpack-internal:///ee83\n")},f2bc:function(module,exports,__webpack_require__){eval("var Collection = __webpack_require__(/*! ampersand-collection */ \"7bd3\");\n\nvar AmpersandModel = __webpack_require__(/*! ampersand-model */ \"3bfc\");\n\nvar widgetEntry = AmpersandModel.extend({\n  props: {\n    modelType: {\n      type: 'string',\n      required: true\n    },\n    newModel: {\n      type: 'any',\n      required: true\n    }\n  }\n});\nvar WidgetCollection = Collection.extend({\n  model: widgetEntry,\n  mainIndex: 'modelType'\n});\n/**\n * A collection of Ampersand widget containing all available chart types\n * @module widgets/widget-factory\n */\n\nmodule.exports.widgets = new WidgetCollection([{\n  modelType: 'piechart',\n  newModel: __webpack_require__(/*! ./models/piechart */ \"2413\")\n}, {\n  modelType: 'horizontalbarchart',\n  newModel: __webpack_require__(/*! ./models/horizontalbarchart */ \"1c81\")\n}, {\n  modelType: 'barchart',\n  newModel: __webpack_require__(/*! ./models/barchart */ \"6535\")\n}, {\n  modelType: 'linechart',\n  newModel: __webpack_require__(/*! ./models/linechart */ \"9cb1\")\n}, {\n  modelType: 'radarchart',\n  newModel: __webpack_require__(/*! ./models/radarchart */ \"0b9d\")\n}, {\n  modelType: 'bubbleplot',\n  newModel: __webpack_require__(/*! ./models/bubbleplot */ \"71a3\")\n}, {\n  modelType: 'scatterchart',\n  newModel: __webpack_require__(/*! ./models/scatter */ \"37f6\")\n}, {\n  modelType: 'networkchart',\n  newModel: __webpack_require__(/*! ./models/sigma */ \"8f0f\") // Register new widgets here\n\n}]);\n/**\n * Create a new Ampersand model for a widget\n * @param {Object} attrs - Used for initialization of model properties, passed on to the model constructor.\n * @param {Object} options - passed on to the model constructor, see https://github.com/AmpersandJS/ampersand-model#constructorinitialize-new-extendedampersandmodelattrs-options\n * @returns {Model} widget - An Ampersand model representing the widget\n */\n\nmodule.exports.newModel = function newModel(attrs, options) {\n  var model;\n  var entry = module.exports.widgets.get(attrs.modelType);\n  var constructor = entry.newModel;\n  model = new constructor(attrs, options);\n  model.modelType = attrs.modelType;\n  return model;\n};//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZjJiYy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy93aWRnZXRzL3dpZGdldC1mYWN0b3J5LmpzP2Y0M2EiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIENvbGxlY3Rpb24gPSByZXF1aXJlKCdhbXBlcnNhbmQtY29sbGVjdGlvbicpO1xudmFyIEFtcGVyc2FuZE1vZGVsID0gcmVxdWlyZSgnYW1wZXJzYW5kLW1vZGVsJyk7XG5cbnZhciB3aWRnZXRFbnRyeSA9IEFtcGVyc2FuZE1vZGVsLmV4dGVuZCh7XG4gIHByb3BzOiB7XG4gICAgbW9kZWxUeXBlOiB7dHlwZTogJ3N0cmluZycsIHJlcXVpcmVkOiB0cnVlfSxcbiAgICBuZXdNb2RlbDoge3R5cGU6ICdhbnknLCByZXF1aXJlZDogdHJ1ZX1cbiAgfVxufSk7XG5cbnZhciBXaWRnZXRDb2xsZWN0aW9uID0gQ29sbGVjdGlvbi5leHRlbmQoe1xuICBtb2RlbDogd2lkZ2V0RW50cnksXG4gIG1haW5JbmRleDogJ21vZGVsVHlwZSdcbn0pO1xuXG4vKipcbiAqIEEgY29sbGVjdGlvbiBvZiBBbXBlcnNhbmQgd2lkZ2V0IGNvbnRhaW5pbmcgYWxsIGF2YWlsYWJsZSBjaGFydCB0eXBlc1xuICogQG1vZHVsZSB3aWRnZXRzL3dpZGdldC1mYWN0b3J5XG4gKi9cbm1vZHVsZS5leHBvcnRzLndpZGdldHMgPSBuZXcgV2lkZ2V0Q29sbGVjdGlvbihbXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdwaWVjaGFydCcsXG4gICAgbmV3TW9kZWw6IHJlcXVpcmUoJy4vbW9kZWxzL3BpZWNoYXJ0JylcbiAgfSxcbiAge1xuICAgIG1vZGVsVHlwZTogJ2hvcml6b250YWxiYXJjaGFydCcsXG4gICAgbmV3TW9kZWw6IHJlcXVpcmUoJy4vbW9kZWxzL2hvcml6b250YWxiYXJjaGFydCcpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdiYXJjaGFydCcsXG4gICAgbmV3TW9kZWw6IHJlcXVpcmUoJy4vbW9kZWxzL2JhcmNoYXJ0JylcbiAgfSxcbiAge1xuICAgIG1vZGVsVHlwZTogJ2xpbmVjaGFydCcsXG4gICAgbmV3TW9kZWw6IHJlcXVpcmUoJy4vbW9kZWxzL2xpbmVjaGFydCcpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdyYWRhcmNoYXJ0JyxcbiAgICBuZXdNb2RlbDogcmVxdWlyZSgnLi9tb2RlbHMvcmFkYXJjaGFydCcpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdidWJibGVwbG90JyxcbiAgICBuZXdNb2RlbDogcmVxdWlyZSgnLi9tb2RlbHMvYnViYmxlcGxvdCcpXG4gIH0sXG4gIHtcbiAgICBtb2RlbFR5cGU6ICdzY2F0dGVyY2hhcnQnLFxuICAgIG5ld01vZGVsOiByZXF1aXJlKCcuL21vZGVscy9zY2F0dGVyJylcbiAgfSxcbiAge1xuICAgIG1vZGVsVHlwZTogJ25ldHdvcmtjaGFydCcsXG4gICAgbmV3TW9kZWw6IHJlcXVpcmUoJy4vbW9kZWxzL3NpZ21hJylcbiAgfVxuICAvLyBSZWdpc3RlciBuZXcgd2lkZ2V0cyBoZXJlXG5dKTtcblxuLyoqXG4gKiBDcmVhdGUgYSBuZXcgQW1wZXJzYW5kIG1vZGVsIGZvciBhIHdpZGdldFxuICogQHBhcmFtIHtPYmplY3R9IGF0dHJzIC0gVXNlZCBmb3IgaW5pdGlhbGl6YXRpb24gb2YgbW9kZWwgcHJvcGVydGllcywgcGFzc2VkIG9uIHRvIHRoZSBtb2RlbCBjb25zdHJ1Y3Rvci5cbiAqIEBwYXJhbSB7T2JqZWN0fSBvcHRpb25zIC0gcGFzc2VkIG9uIHRvIHRoZSBtb2RlbCBjb25zdHJ1Y3Rvciwgc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9BbXBlcnNhbmRKUy9hbXBlcnNhbmQtbW9kZWwjY29uc3RydWN0b3Jpbml0aWFsaXplLW5ldy1leHRlbmRlZGFtcGVyc2FuZG1vZGVsYXR0cnMtb3B0aW9uc1xuICogQHJldHVybnMge01vZGVsfSB3aWRnZXQgLSBBbiBBbXBlcnNhbmQgbW9kZWwgcmVwcmVzZW50aW5nIHRoZSB3aWRnZXRcbiAqL1xubW9kdWxlLmV4cG9ydHMubmV3TW9kZWwgPSBmdW5jdGlvbiBuZXdNb2RlbCAoYXR0cnMsIG9wdGlvbnMpIHtcbiAgdmFyIG1vZGVsO1xuICB2YXIgZW50cnkgPSBtb2R1bGUuZXhwb3J0cy53aWRnZXRzLmdldChhdHRycy5tb2RlbFR5cGUpO1xuICB2YXIgY29uc3RydWN0b3IgPSBlbnRyeS5uZXdNb2RlbDtcbiAgbW9kZWwgPSBuZXcgY29uc3RydWN0b3IoYXR0cnMsIG9wdGlvbnMpO1xuICBtb2RlbC5tb2RlbFR5cGUgPSBhdHRycy5tb2RlbFR5cGU7XG5cbiAgcmV0dXJuIG1vZGVsO1xufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUZBO0FBREE7QUFPQTtBQUNBO0FBQ0E7QUFGQTtBQUtBOzs7OztBQUlBO0FBRUE7QUFDQTtBQUZBO0FBS0E7QUFDQTtBQUZBO0FBS0E7QUFDQTtBQUZBO0FBS0E7QUFDQTtBQUZBO0FBS0E7QUFDQTtBQUZBO0FBS0E7QUFDQTtBQUZBO0FBS0E7QUFDQTtBQUZBO0FBS0E7QUFDQTtBQUNBO0FBSEE7QUFPQTs7Ozs7OztBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0EiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///f2bc\n")},f3d5:function(module,exports,__webpack_require__){eval("var Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar timeUtil = Spot.util.time;\n\nvar View = __webpack_require__(/*! ampersand-view */ \"2883\"); // this.model should be a DatetimeTransform or DurationTransform\n\n\nvar TimeZoneView = View.extend({\n  template: '<option data-hook=\"option\"> </option>',\n  render: function render() {\n    this.renderWithTemplate(this);\n  },\n  bindings: {\n    'model.description': {\n      hook: 'option',\n      type: 'text'\n    },\n    'model.format': {\n      hook: 'option',\n      type: 'attribute',\n      name: 'value'\n    }\n  }\n});\nmodule.exports = View.extend({\n  template: '<select data-hook=\"options\"> </select>',\n  initialize: function initialize(options) {\n    this.field = options.field;\n  },\n  render: function render() {\n    this.renderWithTemplate(this);\n    this.renderCollection(timeUtil.timeZones, TimeZoneView, this.queryByHook('options'));\n    var value = this.model[this.field];\n    this.queryByHook('options').value = value;\n  },\n  events: {\n    'change [data-hook=\"options\"]': 'changeTimeZone'\n  },\n  changeTimeZone: function changeTimeZone() {\n    var value = this.queryByHook('options').value;\n    this.model[this.field] = value;\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZjNkNS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQvdGltZS16b25lcy1zZWxlY3QuanM/ZDY4YiJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgU3BvdCA9IHJlcXVpcmUoJ3Nwb3QtZnJhbWV3b3JrJyk7XG52YXIgdGltZVV0aWwgPSBTcG90LnV0aWwudGltZTtcbnZhciBWaWV3ID0gcmVxdWlyZSgnYW1wZXJzYW5kLXZpZXcnKTtcblxuLy8gdGhpcy5tb2RlbCBzaG91bGQgYmUgYSBEYXRldGltZVRyYW5zZm9ybSBvciBEdXJhdGlvblRyYW5zZm9ybVxuXG52YXIgVGltZVpvbmVWaWV3ID0gVmlldy5leHRlbmQoe1xuICB0ZW1wbGF0ZTogJzxvcHRpb24gZGF0YS1ob29rPVwib3B0aW9uXCI+IDwvb3B0aW9uPicsXG4gIHJlbmRlcjogZnVuY3Rpb24gKCkge1xuICAgIHRoaXMucmVuZGVyV2l0aFRlbXBsYXRlKHRoaXMpO1xuICB9LFxuICBiaW5kaW5nczoge1xuICAgICdtb2RlbC5kZXNjcmlwdGlvbic6IHtcbiAgICAgIGhvb2s6ICdvcHRpb24nLFxuICAgICAgdHlwZTogJ3RleHQnXG4gICAgfSxcbiAgICAnbW9kZWwuZm9ybWF0Jzoge1xuICAgICAgaG9vazogJ29wdGlvbicsXG4gICAgICB0eXBlOiAnYXR0cmlidXRlJyxcbiAgICAgIG5hbWU6ICd2YWx1ZSdcbiAgICB9XG4gIH1cbn0pO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFZpZXcuZXh0ZW5kKHtcbiAgdGVtcGxhdGU6ICc8c2VsZWN0IGRhdGEtaG9vaz1cIm9wdGlvbnNcIj4gPC9zZWxlY3Q+JyxcbiAgaW5pdGlhbGl6ZTogZnVuY3Rpb24gKG9wdGlvbnMpIHtcbiAgICB0aGlzLmZpZWxkID0gb3B0aW9ucy5maWVsZDtcbiAgfSxcbiAgcmVuZGVyOiBmdW5jdGlvbiAoKSB7XG4gICAgdGhpcy5yZW5kZXJXaXRoVGVtcGxhdGUodGhpcyk7XG4gICAgdGhpcy5yZW5kZXJDb2xsZWN0aW9uKHRpbWVVdGlsLnRpbWVab25lcywgVGltZVpvbmVWaWV3LCB0aGlzLnF1ZXJ5QnlIb29rKCdvcHRpb25zJykpO1xuXG4gICAgdmFyIHZhbHVlID0gdGhpcy5tb2RlbFt0aGlzLmZpZWxkXTtcbiAgICB0aGlzLnF1ZXJ5QnlIb29rKCdvcHRpb25zJykudmFsdWUgPSB2YWx1ZTtcbiAgfSxcbiAgZXZlbnRzOiB7XG4gICAgJ2NoYW5nZSBbZGF0YS1ob29rPVwib3B0aW9uc1wiXSc6ICdjaGFuZ2VUaW1lWm9uZSdcbiAgfSxcbiAgY2hhbmdlVGltZVpvbmU6IGZ1bmN0aW9uICgpIHtcbiAgICB2YXIgdmFsdWUgPSB0aGlzLnF1ZXJ5QnlIb29rKCdvcHRpb25zJykudmFsdWU7XG4gICAgdGhpcy5tb2RlbFt0aGlzLmZpZWxkXSA9IHZhbHVlO1xuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFMQTtBQUxBO0FBa0JBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBREE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQWxCQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///f3d5\n")},f77a:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nmodule.exports = View.extend({\n  template: templates.configureFacet.facetTransformContinuous,\n  bindings: {\n    'model.isNone': {\n      type: 'booleanAttribute',\n      hook: 'define-transform-none',\n      name: 'checked'\n    },\n    'model.isPercentiles': {\n      type: 'booleanAttribute',\n      hook: 'define-transform-percentiles',\n      name: 'checked'\n    }\n  },\n  events: {\n    'click [data-hook~=define-transform-percentiles]': function clickDataHookDefineTransformPercentiles() {\n      this.model.clear();\n      this.model.setPercentiles();\n    },\n    'click [data-hook~=define-transform-none]': function clickDataHookDefineTransformNone() {\n      this.model.clear();\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZjc3YS5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtZmFjZXQvZmFjZXQtdHJhbnNmb3JtLWNvbnRpbnVvdXMuanM/NDgyNCJdLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgVmlldyA9IHJlcXVpcmUoJ2FtcGVyc2FuZC12aWV3Jyk7XG52YXIgdGVtcGxhdGVzID0gcmVxdWlyZSgnLi4vLi4vdGVtcGxhdGVzJyk7XG5cbm1vZHVsZS5leHBvcnRzID0gVmlldy5leHRlbmQoe1xuICB0ZW1wbGF0ZTogdGVtcGxhdGVzLmNvbmZpZ3VyZUZhY2V0LmZhY2V0VHJhbnNmb3JtQ29udGludW91cyxcbiAgYmluZGluZ3M6IHtcbiAgICAnbW9kZWwuaXNOb25lJzoge1xuICAgICAgdHlwZTogJ2Jvb2xlYW5BdHRyaWJ1dGUnLFxuICAgICAgaG9vazogJ2RlZmluZS10cmFuc2Zvcm0tbm9uZScsXG4gICAgICBuYW1lOiAnY2hlY2tlZCdcbiAgICB9LFxuICAgICdtb2RlbC5pc1BlcmNlbnRpbGVzJzoge1xuICAgICAgdHlwZTogJ2Jvb2xlYW5BdHRyaWJ1dGUnLFxuICAgICAgaG9vazogJ2RlZmluZS10cmFuc2Zvcm0tcGVyY2VudGlsZXMnLFxuICAgICAgbmFtZTogJ2NoZWNrZWQnXG4gICAgfVxuICB9LFxuICBldmVudHM6IHtcbiAgICAnY2xpY2sgW2RhdGEtaG9va349ZGVmaW5lLXRyYW5zZm9ybS1wZXJjZW50aWxlc10nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLmNsZWFyKCk7XG4gICAgICB0aGlzLm1vZGVsLnNldFBlcmNlbnRpbGVzKCk7XG4gICAgfSxcbiAgICAnY2xpY2sgW2RhdGEtaG9va349ZGVmaW5lLXRyYW5zZm9ybS1ub25lXSc6IGZ1bmN0aW9uICgpIHtcbiAgICAgIHRoaXMubW9kZWwuY2xlYXIoKTtcbiAgICB9XG4gIH1cbn0pO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSEE7QUFLQTtBQUNBO0FBQ0E7QUFDQTtBQUhBO0FBTkE7QUFZQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBUEE7QUFkQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///f77a\n")},faa4:function(module,exports,__webpack_require__){eval("var View = __webpack_require__(/*! ampersand-view */ \"2883\");\n\nvar templates = __webpack_require__(/*! ../../templates */ \"4324\");\n\nmodule.exports = View.extend({\n  template: templates.configurePartition.partitionText,\n  bindings: {\n    'model.isText': {\n      type: 'toggle',\n      hook: 'group-text-panel'\n    }\n  },\n  events: {\n    'click [data-hook~=group-order-count]': function clickDataHookGroupOrderCount() {\n      this.model.ordering = 'count';\n      this.parent.resetFilter = true;\n    },\n    'click [data-hook~=group-order-abc]': function clickDataHookGroupOrderAbc() {\n      this.model.ordering = 'value';\n      this.parent.resetFilter = true;\n    }\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFhNC5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9wYWdlcy9jb25maWd1cmUtcGFydGl0aW9uL3BhcnRpdGlvbi10ZXh0LmpzPzdhOGYiXSwic291cmNlc0NvbnRlbnQiOlsidmFyIFZpZXcgPSByZXF1aXJlKCdhbXBlcnNhbmQtdmlldycpO1xudmFyIHRlbXBsYXRlcyA9IHJlcXVpcmUoJy4uLy4uL3RlbXBsYXRlcycpO1xuXG5tb2R1bGUuZXhwb3J0cyA9IFZpZXcuZXh0ZW5kKHtcbiAgdGVtcGxhdGU6IHRlbXBsYXRlcy5jb25maWd1cmVQYXJ0aXRpb24ucGFydGl0aW9uVGV4dCxcbiAgYmluZGluZ3M6IHtcbiAgICAnbW9kZWwuaXNUZXh0Jzoge1xuICAgICAgdHlwZTogJ3RvZ2dsZScsXG4gICAgICBob29rOiAnZ3JvdXAtdGV4dC1wYW5lbCdcbiAgICB9XG4gIH0sXG4gIGV2ZW50czoge1xuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1vcmRlci1jb3VudF0nOiBmdW5jdGlvbiAoKSB7XG4gICAgICB0aGlzLm1vZGVsLm9yZGVyaW5nID0gJ2NvdW50JztcbiAgICAgIHRoaXMucGFyZW50LnJlc2V0RmlsdGVyID0gdHJ1ZTtcbiAgICB9LFxuICAgICdjbGljayBbZGF0YS1ob29rfj1ncm91cC1vcmRlci1hYmNdJzogZnVuY3Rpb24gKCkge1xuICAgICAgdGhpcy5tb2RlbC5vcmRlcmluZyA9ICd2YWx1ZSc7XG4gICAgICB0aGlzLnBhcmVudC5yZXNldEZpbHRlciA9IHRydWU7XG4gICAgfVxuICB9XG59KTtcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFGQTtBQURBO0FBTUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBUkE7QUFSQSIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///faa4\n")},fdc1:function(module,exports,__webpack_require__){eval("var app = __webpack_require__(/*! ampersand-app */ \"fcbc\");\n\nvar Spot = __webpack_require__(/*! spot-framework */ \"3b07\");\n\nvar BaseWidget = __webpack_require__(/*! ./base-widget */ \"26ef\");\n\nvar Chart = __webpack_require__(/*! chart.js */ \"70b5\");\n\nvar colors = __webpack_require__(/*! ../../colors */ \"eb63\");\n\nvar misval = Spot.util.misval;\n\nvar util = __webpack_require__(/*! ./util */ \"2b41\");\n\nvar BUBBLE_ALPHA = 0.5;\nvar MAX_BUBBLE_SIZE = 50; // in pixels\n\nvar MIN_BUBBLE_SIZE = 5; // in pixels\n\nfunction normalizeGroup(data, key) {\n  var norm;\n  var min = Number.MAX_VALUE;\n  var max = -min;\n  data.forEach(function (group) {\n    if (group.count !== 0) {\n      var val = parseFloat(group[key]) || 0;\n\n      if (val !== misval) {\n        min = min <= val ? min : val;\n        max = max >= val ? max : val;\n      }\n    }\n  });\n\n  if (min === Number.MAX_VALUE) {\n    // no data, no normalization\n    norm = function norm(v) {\n      return 1;\n    };\n  } else if (min < 0 && max > 0) {\n    // bubble radius should always be positive,\n    // so take abs, and normalize by largest of |min| and max\n    min = Math.abs(min);\n    max = max < min ? min : max;\n\n    norm = function norm(v) {\n      return Math.abs(v) / max;\n    };\n  } else if (max > 0 && min >= 0 || max <= 0 && min < 0) {\n    // linear map v from [min, max] to [0,1]\n    norm = function norm(v) {\n      return (v - min) / (max - min);\n    };\n  } else {\n    // not sure if ever reached\n    norm = function norm(v) {\n      return 1;\n    };\n  }\n\n  return norm;\n}\n\nfunction _deinitChart(view) {\n  if (view._chartjs) {\n    view._chartjs.destroy();\n\n    delete view._chartjs;\n  }\n\n  delete view._config;\n  var canvas = view.queryByHook('canvas');\n\n  if (canvas) {\n    view.el.removeChild(canvas);\n  }\n\n  view.isInitialized = false;\n}\n\nfunction _initChart(view) {\n  // Configure plot\n  view._config = view.model.chartjsConfig();\n  var options = view._config.options;\n  var filter = view.model.filter;\n  var partition;\n  var canSelect = true; // configure x-axis\n\n  partition = filter.partitions.get(1, 'rank');\n\n  if (partition.isDatetime) {\n    options.scales.xAxes[0].type = 'time';\n  } else if (partition.isDuration) {\n    options.scales.xAxes[0].type = 'spot-duration';\n  } else if (partition.isContinuous) {\n    if (partition.groupLog) {\n      options.scales.xAxes[0].type = 'logarithmic';\n    } else {\n      options.scales.xAxes[0].type = 'linear';\n    }\n  } else {\n    canSelect = false;\n  }\n\n  options.scales.xAxes[0].scaleLabel = {\n    display: partition.showLabel,\n    labelString: partition.label\n  }; // configure y-axis\n\n  partition = filter.partitions.get(2, 'rank');\n\n  if (partition.isDatetime) {\n    options.scales.yAxes[0].type = 'time';\n  } else if (partition.isDuration) {\n    options.scales.yAxes[0].type = 'spot-duration';\n  } else if (partition.isContinuous) {\n    if (partition.groupLog) {\n      options.scales.yAxes[0].type = 'logarithmic';\n    } else {\n      options.scales.yAxes[0].type = 'linear';\n    }\n  } else {\n    canSelect = false;\n  }\n\n  options.scales.yAxes[0].scaleLabel = {\n    display: partition.showLabel,\n    labelString: partition.label\n  }; // title\n\n  options.title.text = view.model.getTitle(); // user interaction\n\n  if (canSelect) {\n    options.onClick = function (ev, elements) {\n      var partitionA = filter.partitions.get(1, 'rank');\n      var partitionB = filter.partitions.get(2, 'rank');\n\n      if (elements && elements[0]) {\n        // get the clicked-on bubble\n        var index = elements[0]._index;\n        var point = view._config.data.datasets[0].data[index]; // update selection on x-axis\n\n        var groupx = partitionA.groups.models[point.i];\n        partitionA.updateSelection(groupx); // update selection on y-axis\n\n        var groupy = partitionB.groups.models[point.j];\n        partitionB.updateSelection(groupy);\n        view.model.filter.updateDataFilter();\n        app.me.dataview.getData();\n      }\n    };\n  } // force a square full size plot\n\n\n  var width = view.el.offsetWidth;\n  var height = view.el.offsetHeight;\n  var canvas = document.createElement('canvas');\n  canvas.setAttribute('data-hook', 'canvas');\n  view.el.appendChild(canvas);\n  var ctx = canvas.getContext('2d');\n  ctx.canvas.width = width;\n  ctx.canvas.height = height; // Create Chartjs object\n\n  view._chartjs = new Chart(ctx, view._config); // In callbacks on the chart we will need the view, so store a reference\n\n  view._chartjs._Ampersandview = view;\n  view.isInitialized = true;\n}\n\nfunction _update(view) {\n  if (!view.isInitialized) {\n    return;\n  } // Add our data to the plot\n\n\n  updateBubbles(view); // Hand over to Chartjs for actual plotting\n\n  view._chartjs.update();\n}\n\nfunction updateBubbles(view) {\n  var filter = view.model.filter;\n  var chartData = view._config.data;\n  var partitionA = filter.partitions.get(1, 'rank');\n  var partitionB = filter.partitions.get(2, 'rank');\n  chartData.datasets = chartData.datasets || [];\n  chartData.datasets[0] = chartData.datasets[0] || {\n    data: [],\n    error: [],\n    backgroundColor: []\n  }; // find facet names for tooltips\n\n  chartData.datasets[0].spotAxes = {\n    x: partitionA.label,\n    y: partitionB.label\n  };\n  var aggregate;\n  var bubbleColorFn; // normalization function for bubble color\n\n  var bubbleRadiusFn; // normalization function for bubble radius\n\n  var errorXFn;\n  var errorYFn;\n  aggregate = filter.aggregates.get(1, 'rank');\n\n  if (aggregate) {\n    bubbleColorFn = normalizeGroup(filter.data, 'aa');\n    chartData.datasets[0].spotAxes.c = aggregate.operation + ' ' + aggregate.label;\n  }\n\n  aggregate = filter.aggregates.get(2, 'rank');\n\n  if (aggregate) {\n    bubbleRadiusFn = normalizeGroup(filter.data, 'bb');\n    chartData.datasets[0].spotAxes.r = aggregate.operation + ' ' + aggregate.label;\n  }\n\n  view._config.options.errorDir = 'both';\n  aggregate = filter.aggregates.get(3, 'rank');\n\n  if (aggregate) {\n    errorXFn = function errorXFn(group) {\n      return group['cc'];\n    };\n  } else {\n    errorXFn = function errorXFn(group) {\n      return null;\n    };\n\n    view._config.options.errorDir = 'vertical';\n  }\n\n  aggregate = filter.aggregates.get(4, 'rank');\n\n  if (aggregate) {\n    errorYFn = function errorYFn(group) {\n      return group['dd'];\n    };\n  } else {\n    errorYFn = function errorYFn(group) {\n      return null;\n    };\n\n    if (view._config.options.errorDir === 'vertical') {\n      view._config.options.errorDir === 'none';\n    }\n\n    if (view._config.options.errorDir === 'both') {\n      view._config.options.errorDir === 'horizontal';\n    }\n  } // add data\n\n\n  var val;\n  var d = 0;\n  filter.data.forEach(function (group) {\n    var i = util.partitionValueToIndex(partitionA, group.a);\n    var j = util.partitionValueToIndex(partitionB, group.b);\n\n    if (i >= 0 && j >= 0 && group.aa !== misval && group.bb !== misval && group.count !== 0) {\n      // initialize if necessary\n      chartData.datasets[0].data[d] = chartData.datasets[0].data[d] || {};\n      chartData.datasets[0].error[d] = chartData.datasets[0].error[d] || {}; // update position\n\n      if (partitionA.isDatetime || partitionA.isDuration || partitionA.isContinuous) {\n        chartData.datasets[0].data[d].x = partitionA.groups.models[i].value;\n      } else {\n        chartData.datasets[0].data[d].x = i;\n      }\n\n      if (partitionB.isDatetime || partitionB.isDuration || partitionB.isContinuous) {\n        chartData.datasets[0].data[d].y = partitionB.groups.models[j].value;\n      } else {\n        chartData.datasets[0].data[d].y = j;\n      } // update error\n\n\n      chartData.datasets[0].error[d].x = errorXFn(group);\n      chartData.datasets[0].error[d].y = errorYFn(group); // update color\n\n      val = parseFloat(group.aa) || 0;\n\n      if (bubbleColorFn) {\n        chartData.datasets[0].backgroundColor[d] = colors.getColorFloat(bubbleColorFn(val)).alpha(BUBBLE_ALPHA).css();\n      } else {\n        chartData.datasets[0].backgroundColor[d] = colors.getColor(0).alpha(BUBBLE_ALPHA).css();\n      } // update radius\n\n\n      val = parseFloat(group.bb) || 0;\n\n      if (bubbleRadiusFn) {\n        chartData.datasets[0].data[d].r = Math.round(MIN_BUBBLE_SIZE + Math.sqrt(bubbleRadiusFn(val)) * (MAX_BUBBLE_SIZE - MIN_BUBBLE_SIZE));\n      } else {\n        chartData.datasets[0].data[d].r = MIN_BUBBLE_SIZE; // NOTE: in pixels\n      } // store group indexes for onClick callback\n\n\n      chartData.datasets[0].data[d].i = i;\n      chartData.datasets[0].data[d].j = j;\n      chartData.datasets[0].data[d].a = group.a;\n      chartData.datasets[0].data[d].b = group.b;\n      chartData.datasets[0].data[d].aa = group.aa;\n      chartData.datasets[0].data[d].bb = group.bb;\n      chartData.datasets[0].data[d].count = group.count;\n      d++;\n    }\n  }); // remove remaining (unused) points\n\n  var cut = chartData.datasets[0].data.length - d;\n\n  if (cut > 0) {\n    chartData.datasets[0].data.splice(d, cut);\n    chartData.datasets[0].error.splice(d, cut);\n    chartData.datasets[0].backgroundColor.splice(d, cut);\n  } // highlight selected area\n\n\n  if ((partitionA.isDatetime || partitionA.isDuration || partitionA.isContinuous) && (partitionB.isDatetime || partitionB.isDuration || partitionB.isContinuous)) {\n    if (partitionA.selected && partitionA.selected.length > 0) {\n      chartData.datasets[1] = chartData.datasets[1] || {\n        type: 'line',\n        lineTension: 0\n      };\n      chartData.datasets[1].data = [{\n        x: partitionA.selected[0],\n        y: partitionB.selected[0],\n        r: 1\n      }, {\n        x: partitionA.selected[0],\n        y: partitionB.selected[1],\n        r: 1\n      }, {\n        x: partitionA.selected[1],\n        y: partitionB.selected[1],\n        r: 1\n      }, {\n        x: partitionA.selected[1],\n        y: partitionB.selected[0],\n        r: 1\n      }, {\n        x: partitionA.selected[0],\n        y: partitionB.selected[0],\n        r: 1\n      }];\n      chartData.datasets[1].error = [null, null, null, null];\n      chartData.datasets[1].backgroundColor = colors.getColor(1).alpha(BUBBLE_ALPHA).css();\n    } else {\n      chartData.datasets.splice(1, 1);\n    }\n  }\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner mdl-card__media\"></div>',\n  update: function update() {\n    _update(this);\n  },\n  initChart: function initChart() {\n    _initChart(this);\n  },\n  deinitChart: function deinitChart() {\n    _deinitChart(this);\n  }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"fdc1.js","sources":["webpack:///./src/widgets/views/chartjs2d.js?908e"],"sourcesContent":["var app = require('ampersand-app');\nvar Spot = require('spot-framework');\nvar BaseWidget = require('./base-widget');\nvar Chart = require('chart.js');\nvar colors = require('../../colors');\nvar misval = Spot.util.misval;\nvar util = require('./util');\n\nvar BUBBLE_ALPHA = 0.5;\nvar MAX_BUBBLE_SIZE = 50; // in pixels\nvar MIN_BUBBLE_SIZE = 5; // in pixels\n\nfunction normalizeGroup (data, key) {\n  var norm;\n  var min = Number.MAX_VALUE;\n  var max = -min;\n  data.forEach(function (group) {\n    if (group.count !== 0) {\n      var val = parseFloat(group[key]) || 0;\n      if (val !== misval) {\n        min = min <= val ? min : val;\n        max = max >= val ? max : val;\n      }\n    }\n  });\n\n  if (min === Number.MAX_VALUE) {\n    // no data, no normalization\n    norm = function (v) { return 1; };\n  } else if (min < 0 && max > 0) {\n    // bubble radius should always be positive,\n    // so take abs, and normalize by largest of |min| and max\n    min = Math.abs(min);\n    max = max < min ? min : max;\n    norm = function (v) {\n      return Math.abs(v) / max;\n    };\n  } else if ((max > 0 && min >= 0) || (max <= 0 && min < 0)) {\n    // linear map v from [min, max] to [0,1]\n    norm = function (v) {\n      return (v - min) / (max - min);\n    };\n  } else {\n    // not sure if ever reached\n    norm = function (v) { return 1; };\n  }\n  return norm;\n}\n\nfunction deinitChart (view) {\n  if (view._chartjs) {\n    view._chartjs.destroy();\n    delete view._chartjs;\n  }\n  delete view._config;\n\n  var canvas = view.queryByHook('canvas');\n  if (canvas) {\n    view.el.removeChild(canvas);\n  }\n  view.isInitialized = false;\n}\n\nfunction initChart (view) {\n  // Configure plot\n  view._config = view.model.chartjsConfig();\n  var options = view._config.options;\n\n  var filter = view.model.filter;\n  var partition;\n\n  var canSelect = true;\n\n  // configure x-axis\n  partition = filter.partitions.get(1, 'rank');\n\n  if (partition.isDatetime) {\n    options.scales.xAxes[0].type = 'time';\n  } else if (partition.isDuration) {\n    options.scales.xAxes[0].type = 'spot-duration';\n  } else if (partition.isContinuous) {\n    if (partition.groupLog) {\n      options.scales.xAxes[0].type = 'logarithmic';\n    } else {\n      options.scales.xAxes[0].type = 'linear';\n    }\n  } else {\n    canSelect = false;\n  }\n  options.scales.xAxes[0].scaleLabel = {\n    display: partition.showLabel,\n    labelString: partition.label\n  };\n\n  // configure y-axis\n  partition = filter.partitions.get(2, 'rank');\n\n  if (partition.isDatetime) {\n    options.scales.yAxes[0].type = 'time';\n  } else if (partition.isDuration) {\n    options.scales.yAxes[0].type = 'spot-duration';\n  } else if (partition.isContinuous) {\n    if (partition.groupLog) {\n      options.scales.yAxes[0].type = 'logarithmic';\n    } else {\n      options.scales.yAxes[0].type = 'linear';\n    }\n  } else {\n    canSelect = false;\n  }\n  options.scales.yAxes[0].scaleLabel = {\n    display: partition.showLabel,\n    labelString: partition.label\n  };\n\n  // title\n  options.title.text = view.model.getTitle();\n\n  // user interaction\n  if (canSelect) {\n    options.onClick = function (ev, elements) {\n      var partitionA = filter.partitions.get(1, 'rank');\n      var partitionB = filter.partitions.get(2, 'rank');\n\n      if (elements && elements[0]) {\n        // get the clicked-on bubble\n        var index = elements[0]._index;\n        var point = view._config.data.datasets[0].data[index];\n\n        // update selection on x-axis\n        var groupx = partitionA.groups.models[point.i];\n        partitionA.updateSelection(groupx);\n\n        // update selection on y-axis\n        var groupy = partitionB.groups.models[point.j];\n        partitionB.updateSelection(groupy);\n\n        view.model.filter.updateDataFilter();\n        app.me.dataview.getData();\n      }\n    };\n  }\n\n  // force a square full size plot\n  var width = view.el.offsetWidth;\n  var height = view.el.offsetHeight;\n\n  var canvas = document.createElement('canvas');\n  canvas.setAttribute('data-hook', 'canvas');\n  view.el.appendChild(canvas);\n\n  var ctx = canvas.getContext('2d');\n  ctx.canvas.width = width;\n  ctx.canvas.height = height;\n\n  // Create Chartjs object\n  view._chartjs = new Chart(ctx, view._config);\n\n  // In callbacks on the chart we will need the view, so store a reference\n  view._chartjs._Ampersandview = view;\n\n  view.isInitialized = true;\n}\n\nfunction update (view) {\n  if (!view.isInitialized) {\n    return;\n  }\n\n  // Add our data to the plot\n  updateBubbles(view);\n\n  // Hand over to Chartjs for actual plotting\n  view._chartjs.update();\n}\n\nfunction updateBubbles (view) {\n  var filter = view.model.filter;\n  var chartData = view._config.data;\n\n  var partitionA = filter.partitions.get(1, 'rank');\n  var partitionB = filter.partitions.get(2, 'rank');\n\n  chartData.datasets = chartData.datasets || [];\n  chartData.datasets[0] = chartData.datasets[0] || { data: [], error: [], backgroundColor: [] };\n\n  // find facet names for tooltips\n  chartData.datasets[0].spotAxes = {\n    x: partitionA.label,\n    y: partitionB.label\n  };\n\n  var aggregate;\n  var bubbleColorFn; // normalization function for bubble color\n  var bubbleRadiusFn; // normalization function for bubble radius\n  var errorXFn;\n  var errorYFn;\n\n  aggregate = filter.aggregates.get(1, 'rank');\n  if (aggregate) {\n    bubbleColorFn = normalizeGroup(filter.data, 'aa');\n    chartData.datasets[0].spotAxes.c = aggregate.operation + ' ' + aggregate.label;\n  }\n\n  aggregate = filter.aggregates.get(2, 'rank');\n  if (aggregate) {\n    bubbleRadiusFn = normalizeGroup(filter.data, 'bb');\n    chartData.datasets[0].spotAxes.r = aggregate.operation + ' ' + aggregate.label;\n  }\n\n  view._config.options.errorDir = 'both';\n  aggregate = filter.aggregates.get(3, 'rank');\n  if (aggregate) {\n    errorXFn = function (group) { return group['cc']; };\n  } else {\n    errorXFn = function (group) { return null; };\n    view._config.options.errorDir = 'vertical';\n  }\n\n  aggregate = filter.aggregates.get(4, 'rank');\n  if (aggregate) {\n    errorYFn = function (group) { return group['dd']; };\n  } else {\n    errorYFn = function (group) { return null; };\n    if (view._config.options.errorDir === 'vertical') {\n      view._config.options.errorDir === 'none';\n    }\n    if (view._config.options.errorDir === 'both') {\n      view._config.options.errorDir === 'horizontal';\n    }\n  }\n\n  // add data\n  var val;\n  var d = 0;\n  filter.data.forEach(function (group) {\n    var i = util.partitionValueToIndex(partitionA, group.a);\n    var j = util.partitionValueToIndex(partitionB, group.b);\n\n    if (i >= 0 && j >= 0 && group.aa !== misval && group.bb !== misval && group.count !== 0) {\n      // initialize if necessary\n      chartData.datasets[0].data[d] = chartData.datasets[0].data[d] || {};\n      chartData.datasets[0].error[d] = chartData.datasets[0].error[d] || {};\n\n      // update position\n      if (partitionA.isDatetime || partitionA.isDuration || partitionA.isContinuous) {\n        chartData.datasets[0].data[d].x = partitionA.groups.models[i].value;\n      } else {\n        chartData.datasets[0].data[d].x = i;\n      }\n\n      if (partitionB.isDatetime || partitionB.isDuration || partitionB.isContinuous) {\n        chartData.datasets[0].data[d].y = partitionB.groups.models[j].value;\n      } else {\n        chartData.datasets[0].data[d].y = j;\n      }\n\n      // update error\n      chartData.datasets[0].error[d].x = errorXFn(group);\n      chartData.datasets[0].error[d].y = errorYFn(group);\n\n      // update color\n      val = parseFloat(group.aa) || 0;\n      if (bubbleColorFn) {\n        chartData.datasets[0].backgroundColor[d] = colors.getColorFloat(bubbleColorFn(val)).alpha(BUBBLE_ALPHA).css();\n      } else {\n        chartData.datasets[0].backgroundColor[d] = colors.getColor(0).alpha(BUBBLE_ALPHA).css();\n      }\n\n      // update radius\n      val = parseFloat(group.bb) || 0;\n      if (bubbleRadiusFn) {\n        chartData.datasets[0].data[d].r = Math.round(MIN_BUBBLE_SIZE + Math.sqrt(bubbleRadiusFn(val)) * (MAX_BUBBLE_SIZE - MIN_BUBBLE_SIZE));\n      } else {\n        chartData.datasets[0].data[d].r = MIN_BUBBLE_SIZE; // NOTE: in pixels\n      }\n\n      // store group indexes for onClick callback\n      chartData.datasets[0].data[d].i = i;\n      chartData.datasets[0].data[d].j = j;\n      chartData.datasets[0].data[d].a = group.a;\n      chartData.datasets[0].data[d].b = group.b;\n      chartData.datasets[0].data[d].aa = group.aa;\n      chartData.datasets[0].data[d].bb = group.bb;\n      chartData.datasets[0].data[d].count = group.count;\n      d++;\n    }\n  });\n\n  // remove remaining (unused) points\n  var cut = chartData.datasets[0].data.length - d;\n  if (cut > 0) {\n    chartData.datasets[0].data.splice(d, cut);\n    chartData.datasets[0].error.splice(d, cut);\n    chartData.datasets[0].backgroundColor.splice(d, cut);\n  }\n\n  // highlight selected area\n  if (\n    (partitionA.isDatetime || partitionA.isDuration || partitionA.isContinuous) &&\n    (partitionB.isDatetime || partitionB.isDuration || partitionB.isContinuous)) {\n    if (partitionA.selected && partitionA.selected.length > 0) {\n      chartData.datasets[1] = chartData.datasets[1] || {\n        type: 'line',\n        lineTension: 0\n      };\n      chartData.datasets[1].data = [\n        { x: partitionA.selected[0], y: partitionB.selected[0], r: 1 },\n        { x: partitionA.selected[0], y: partitionB.selected[1], r: 1 },\n        { x: partitionA.selected[1], y: partitionB.selected[1], r: 1 },\n        { x: partitionA.selected[1], y: partitionB.selected[0], r: 1 },\n        { x: partitionA.selected[0], y: partitionB.selected[0], r: 1 }\n      ];\n      chartData.datasets[1].error = [null, null, null, null];\n      chartData.datasets[1].backgroundColor = colors.getColor(1).alpha(BUBBLE_ALPHA).css();\n    } else {\n      chartData.datasets.splice(1, 1);\n    }\n  }\n}\n\nmodule.exports = BaseWidget.extend({\n  template: '<div class=\"widgetInner mdl-card__media\"></div>',\n\n  update: function () {\n    update(this);\n  },\n\n  initChart: function () {\n    initChart(this);\n  },\n\n  deinitChart: function () {\n    deinitChart(this);\n  }\n});\n"],"mappings":"AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AAEA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAFA;AACA;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAFA;AACA;AAKA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AAFA;AAKA;AACA;AACA;AAAA;AACA;AAAA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AAAA;AAAA;AACA;AACA;AAAA;AAAA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AAFA;AAIA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAbA","sourceRoot":""}\n//# sourceURL=webpack-internal:///fdc1\n")}},[[0,"runtime","npm.core-js","npm.lodash","npm.spot-framework","npm.chart.js","npm.readable-stream","npm.es-abstract","npm.qs","npm.string.prototype.trim","npm.webpack","npm.sigma","npm.moment-timezone","npm.object-keys","npm.ampersand-events","npm.ampersand-router","npm.ampersand-sync","npm.babel-polyfill","npm.closest","npm.color-convert","npm.es-to-primitive","npm.function-bind","npm.has-binary","npm.node-libs-browser","npm.util","npm.after","npm.ampersand-app","npm.ampersand-class-extend","npm.ampersand-collection-view","npm.ampersand-collection","npm.ampersand-dom-bindings","npm.ampersand-dom","npm.ampersand-model","npm.ampersand-state","npm.ampersand-view-switcher","npm.ampersand-view","npm.array-next","npm.backo2","npm.base64-arraybuffer","npm.base64-js","npm.buffer","npm.chartjs-color-string","npm.chartjs-color","npm.chroma-js","npm.color-name","npm.component-bind","npm.component-emitter","npm.component-event","npm.component-inherit","npm.core-util-is","npm.csv-generate","npm.csv-parse","npm.csv-stringify","npm.csv","npm.define-properties","npm.delegate-events","npm.dialog-polyfill","npm.domify","npm.domready","npm.events-mixin","npm.events","npm.file-saver","npm.for-each","npm.global","npm.gridster","npm.has-cors","npm.has","npm.ieee754","npm.indexof","npm.inherits","npm.intro.js","npm.is-callable","npm.is-function","npm.isarray","npm.jquery","npm.json3","npm.key-tree-store","npm.local-links","npm.lodash.get","npm.matches-selector","npm.material-design-lite","npm.media-type","npm.moment","npm.parse-headers","npm.parsejson","npm.parseqs","npm.parseuri","npm.process-nextick-args","npm.process","npm.safe-buffer","npm.setimmediate","npm.sortablejs","npm.stream-browserify","npm.stream-transform","npm.timers-browserify","npm.to-array","npm.util-deprecate","npm.vis","npm.wtf-8","npm.xhr","npm.xtend","npm.yeast"]]]);