/* Copyright 2017 Mozilla Foundation * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.PDFSidebarResizer = undefined; 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; }; }(); var _ui_utils = require('./ui_utils'); function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var SIDEBAR_WIDTH_VAR = '--sidebar-width'; var SIDEBAR_MIN_WIDTH = 200; var SIDEBAR_RESIZING_CLASS = 'sidebarResizing'; var PDFSidebarResizer = function () { function PDFSidebarResizer(options, eventBus) { var _this = this; var l10n = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _ui_utils.NullL10n; _classCallCheck(this, PDFSidebarResizer); this.enabled = false; this.isRTL = false; this.sidebarOpen = false; this.doc = document.documentElement; this._width = null; this._outerContainerWidth = null; this._boundEvents = Object.create(null); this.outerContainer = options.outerContainer; this.resizer = options.resizer; this.eventBus = eventBus; this.l10n = l10n; if (typeof CSS === 'undefined' || typeof CSS.supports !== 'function' || !CSS.supports(SIDEBAR_WIDTH_VAR, 'calc(-1 * ' + SIDEBAR_MIN_WIDTH + 'px)')) { console.warn('PDFSidebarResizer: ' + 'The browser does not support resizing of the sidebar.'); return; } this.enabled = true; this.resizer.classList.remove('hidden'); this.l10n.getDirection().then(function (dir) { _this.isRTL = dir === 'rtl'; }); this._addEventListeners(); } _createClass(PDFSidebarResizer, [{ key: '_updateWidth', value: function _updateWidth() { var width = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; if (!this.enabled) { return false; } var maxWidth = Math.floor(this.outerContainerWidth / 2); if (width > maxWidth) { width = maxWidth; } if (width < SIDEBAR_MIN_WIDTH) { width = SIDEBAR_MIN_WIDTH; } if (width === this._width) { return false; } this._width = width; this.doc.style.setProperty(SIDEBAR_WIDTH_VAR, width + 'px'); return true; } }, { key: '_mouseMove', value: function _mouseMove(evt) { var width = evt.clientX; if (this.isRTL) { width = this.outerContainerWidth - width; } this._updateWidth(width); } }, { key: '_mouseUp', value: function _mouseUp(evt) { this.outerContainer.classList.remove(SIDEBAR_RESIZING_CLASS); this.eventBus.dispatch('resize', { source: this }); var _boundEvents = this._boundEvents; window.removeEventListener('mousemove', _boundEvents.mouseMove); window.removeEventListener('mouseup', _boundEvents.mouseUp); } }, { key: '_addEventListeners', value: function _addEventListeners() { var _this2 = this; if (!this.enabled) { return; } var _boundEvents = this._boundEvents; _boundEvents.mouseMove = this._mouseMove.bind(this); _boundEvents.mouseUp = this._mouseUp.bind(this); this.resizer.addEventListener('mousedown', function (evt) { if (evt.button !== 0) { return; } _this2.outerContainer.classList.add(SIDEBAR_RESIZING_CLASS); window.addEventListener('mousemove', _boundEvents.mouseMove); window.addEventListener('mouseup', _boundEvents.mouseUp); }); this.eventBus.on('sidebarviewchanged', function (evt) { _this2.sidebarOpen = !!(evt && evt.view); }); this.eventBus.on('resize', function (evt) { if (evt && evt.source === window) { _this2._outerContainerWidth = null; if (_this2._width) { if (_this2.sidebarOpen) { _this2.outerContainer.classList.add(SIDEBAR_RESIZING_CLASS); var updated = _this2._updateWidth(_this2._width); Promise.resolve().then(function () { _this2.outerContainer.classList.remove(SIDEBAR_RESIZING_CLASS); if (updated) { _this2.eventBus.dispatch('resize', { source: _this2 }); } }); } else { _this2._updateWidth(_this2._width); } } } }); } }, { key: 'outerContainerWidth', get: function get() { if (!this._outerContainerWidth) { this._outerContainerWidth = this.outerContainer.clientWidth; } return this._outerContainerWidth; } }]); return PDFSidebarResizer; }(); exports.PDFSidebarResizer = PDFSidebarResizer;