UNPKG

grommet

Version:

The most advanced UX framework for enterprise applications.

87 lines (76 loc) 3.04 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); exports.graphValue = graphValue; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } // (C) Copyright 2014-2016 Hewlett Packard Enterprise Development LP function graphValue(value, min, max, size) { var scale = size / (max - min); return Math.floor(scale * (value - min)); }; var pointSize = exports.pointSize = 12; var padding = exports.padding = pointSize / 2 + 2; var debounceDelay = exports.debounceDelay = 50; var trackSize = exports.trackSize = function () { function trackSize(props, onSize) { _classCallCheck(this, trackSize); this._onResize = this._onResize.bind(this); this._measure = this._measure.bind(this); this._width = props.width; this._height = props.height; this._size = { width: props.width || 0, height: props.height || 0 }; this._onSize = onSize; } _createClass(trackSize, [{ key: '_measure', value: function _measure() { if (this._element) { var rect = this._element.getBoundingClientRect(); this._size.width = this._width || Math.round(rect.width); this._size.height = this._height || Math.round(rect.height); this._onSize(this._size); } } }, { key: '_onResize', value: function _onResize() { // debounce clearTimeout(this._resizeTimer); // delay should be greater than Chart's delay this._resizeTimer = setTimeout(this._measure, debounceDelay + 10); } }, { key: 'size', value: function size() { return this._size; } }, { key: 'start', value: function start(element) { this._element = element; if (!this._width || !this._height) { window.addEventListener('resize', this._onResize); // delay just a bit to allow the browser to lay things out setTimeout(this._measure.bind(this), 3); } } }, { key: 'reset', value: function reset(props) { this._width = props.width; this._height = props.height; this._size.width = props.width || this._size.width; this._size.height = props.height || this._size.height; this._onSize(this._size); } }, { key: 'stop', value: function stop() { window.removeEventListener('resize', this._onResize); this._element = undefined; } }]); return trackSize; }();