You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
221 lines
7.1 KiB
221 lines
7.1 KiB
/* Copyright 2012 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. |
|
*/ |
|
|
|
import { mozL10n, SCROLLBAR_PADDING } from './ui_utils'; |
|
|
|
/** |
|
* @typedef {Object} SecondaryToolbarOptions |
|
* @property {HTMLDivElement} toolbar - Container for the secondary toolbar. |
|
* @property {HTMLButtonElement} toggleButton - Button to toggle the visibility |
|
* of the secondary toolbar. |
|
* @property {HTMLDivElement} toolbarButtonContainer - Container where all the |
|
* toolbar buttons are placed. The maximum height of the toolbar is controlled |
|
* dynamically by adjusting the 'max-height' CSS property of this DOM element. |
|
* @property {HTMLButtonElement} presentationModeButton - Button for entering |
|
* presentation mode. |
|
* @property {HTMLButtonElement} openFileButton - Button to open a file. |
|
* @property {HTMLButtonElement} printButton - Button to print the document. |
|
* @property {HTMLButtonElement} downloadButton - Button to download the |
|
* document. |
|
* @property {HTMLLinkElement} viewBookmarkButton - Button to obtain a bookmark |
|
* link to the current location in the document. |
|
* @property {HTMLButtonElement} firstPageButton - Button to go to the first |
|
* page in the document. |
|
* @property {HTMLButtonElement} lastPageButton - Button to go to the last page |
|
* in the document. |
|
* @property {HTMLButtonElement} pageRotateCwButton - Button to rotate the pages |
|
* clockwise. |
|
* @property {HTMLButtonElement} pageRotateCcwButton - Button to rotate the |
|
* pages counterclockwise. |
|
* @property {HTMLButtonElement} toggleHandToolButton - Button to toggle the |
|
* hand tool. |
|
* @property {HTMLButtonElement} documentPropertiesButton - Button for opening |
|
* the document properties dialog. |
|
*/ |
|
|
|
class SecondaryToolbar { |
|
/** |
|
* @param {SecondaryToolbarOptions} options |
|
* @param {HTMLDivElement} mainContainer |
|
* @param {EventBus} eventBus |
|
*/ |
|
constructor(options, mainContainer, eventBus) { |
|
this.toolbar = options.toolbar; |
|
this.toggleButton = options.toggleButton; |
|
this.toolbarButtonContainer = options.toolbarButtonContainer; |
|
this.buttons = [ |
|
{ element: options.presentationModeButton, eventName: 'presentationmode', |
|
close: true }, |
|
{ element: options.openFileButton, eventName: 'openfile', close: true }, |
|
{ element: options.printButton, eventName: 'print', close: true }, |
|
{ element: options.downloadButton, eventName: 'download', close: true }, |
|
{ element: options.viewBookmarkButton, eventName: null, close: true }, |
|
{ element: options.firstPageButton, eventName: 'firstpage', close: true }, |
|
{ element: options.lastPageButton, eventName: 'lastpage', close: true }, |
|
{ element: options.pageRotateCwButton, eventName: 'rotatecw', |
|
close: false }, |
|
{ element: options.pageRotateCcwButton, eventName: 'rotateccw', |
|
close: false }, |
|
{ element: options.toggleHandToolButton, eventName: 'togglehandtool', |
|
close: true }, |
|
{ element: options.documentPropertiesButton, |
|
eventName: 'documentproperties', close: true } |
|
]; |
|
this.items = { |
|
firstPage: options.firstPageButton, |
|
lastPage: options.lastPageButton, |
|
pageRotateCw: options.pageRotateCwButton, |
|
pageRotateCcw: options.pageRotateCcwButton, |
|
}; |
|
|
|
this.mainContainer = mainContainer; |
|
this.eventBus = eventBus; |
|
|
|
this.opened = false; |
|
this.containerHeight = null; |
|
this.previousContainerHeight = null; |
|
|
|
this.reset(); |
|
|
|
// Bind the event listeners for click and hand tool actions. |
|
this._bindClickListeners(); |
|
this._bindHandToolListener(options.toggleHandToolButton); |
|
|
|
// Bind the event listener for adjusting the 'max-height' of the toolbar. |
|
this.eventBus.on('resize', this._setMaxHeight.bind(this)); |
|
} |
|
|
|
/** |
|
* @return {boolean} |
|
*/ |
|
get isOpen() { |
|
return this.opened; |
|
} |
|
|
|
setPageNumber(pageNumber) { |
|
this.pageNumber = pageNumber; |
|
this._updateUIState(); |
|
} |
|
|
|
setPagesCount(pagesCount) { |
|
this.pagesCount = pagesCount; |
|
this._updateUIState(); |
|
} |
|
|
|
reset() { |
|
this.pageNumber = 0; |
|
this.pagesCount = 0; |
|
this._updateUIState(); |
|
} |
|
|
|
_updateUIState() { |
|
this.items.firstPage.disabled = (this.pageNumber <= 1); |
|
this.items.lastPage.disabled = (this.pageNumber >= this.pagesCount); |
|
this.items.pageRotateCw.disabled = this.pagesCount === 0; |
|
this.items.pageRotateCcw.disabled = this.pagesCount === 0; |
|
} |
|
|
|
_bindClickListeners() { |
|
// Button to toggle the visibility of the secondary toolbar. |
|
this.toggleButton.addEventListener('click', this.toggle.bind(this)); |
|
|
|
// All items within the secondary toolbar. |
|
for (let button in this.buttons) { |
|
let { element, eventName, close, } = this.buttons[button]; |
|
|
|
element.addEventListener('click', (evt) => { |
|
if (eventName !== null) { |
|
this.eventBus.dispatch(eventName, { source: this, }); |
|
} |
|
if (close) { |
|
this.close(); |
|
} |
|
}); |
|
} |
|
} |
|
|
|
_bindHandToolListener(toggleHandToolButton) { |
|
let isHandToolActive = false; |
|
|
|
this.eventBus.on('handtoolchanged', function(evt) { |
|
if (isHandToolActive === evt.isActive) { |
|
return; |
|
} |
|
isHandToolActive = evt.isActive; |
|
|
|
if (isHandToolActive) { |
|
toggleHandToolButton.title = |
|
mozL10n.get('hand_tool_disable.title', null, 'Disable hand tool'); |
|
toggleHandToolButton.firstElementChild.textContent = |
|
mozL10n.get('hand_tool_disable_label', null, 'Disable hand tool'); |
|
} else { |
|
toggleHandToolButton.title = |
|
mozL10n.get('hand_tool_enable.title', null, 'Enable hand tool'); |
|
toggleHandToolButton.firstElementChild.textContent = |
|
mozL10n.get('hand_tool_enable_label', null, 'Enable hand tool'); |
|
} |
|
}); |
|
} |
|
|
|
open() { |
|
if (this.opened) { |
|
return; |
|
} |
|
this.opened = true; |
|
this._setMaxHeight(); |
|
|
|
this.toggleButton.classList.add('toggled'); |
|
this.toolbar.classList.remove('hidden'); |
|
} |
|
|
|
close() { |
|
if (!this.opened) { |
|
return; |
|
} |
|
this.opened = false; |
|
this.toolbar.classList.add('hidden'); |
|
this.toggleButton.classList.remove('toggled'); |
|
} |
|
|
|
toggle() { |
|
if (this.opened) { |
|
this.close(); |
|
} else { |
|
this.open(); |
|
} |
|
} |
|
|
|
/** |
|
* @private |
|
*/ |
|
_setMaxHeight() { |
|
if (!this.opened) { |
|
return; // Only adjust the 'max-height' if the toolbar is visible. |
|
} |
|
this.containerHeight = this.mainContainer.clientHeight; |
|
|
|
if (this.containerHeight === this.previousContainerHeight) { |
|
return; |
|
} |
|
this.toolbarButtonContainer.setAttribute('style', |
|
'max-height: ' + (this.containerHeight - SCROLLBAR_PADDING) + 'px;'); |
|
|
|
this.previousContainerHeight = this.containerHeight; |
|
} |
|
} |
|
|
|
export { |
|
SecondaryToolbar, |
|
};
|
|
|