| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 | 
							- /* 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) {
 
-         _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;
 
 
  |