OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 cr.define('print_preview', function() { |
| 6 'use strict'; |
| 7 |
| 8 /** |
| 9 * An immutable ordered set of page numbers. |
| 10 * @param {!Array.<number>} pageNumberList A list of page numbers to include |
| 11 * in the set. |
| 12 * @constructor |
| 13 */ |
| 14 function PageNumberSet(pageNumberList) { |
| 15 /** |
| 16 * Internal data store for the page number set. |
| 17 * @type {!Array.<number>} |
| 18 * @private |
| 19 */ |
| 20 this.pageNumberSet_ = pageListToPageSet(pageNumberList); |
| 21 }; |
| 22 |
| 23 /** |
| 24 * @param {string} pageRangeStr String form of a page range. I.e. '2,3,4-5'. |
| 25 * If string is empty, all page numbers will be in the page number set. |
| 26 * @param {number} totalPageCount Total number of pages in the original |
| 27 * document. |
| 28 * @return {print_preview.PageNumberSet} Page number set parsed from the |
| 29 * given page range string and total page count. Null returned if |
| 30 * the given page range string is invalid. |
| 31 */ |
| 32 PageNumberSet.parse = function(pageRangeStr, totalPageCount) { |
| 33 if (pageRangeStr == '') { |
| 34 var pageNumberList = []; |
| 35 for (var i = 0; i < totalPageCount; i++) { |
| 36 pageNumberList.push(i + 1); |
| 37 } |
| 38 return new PageNumberSet(pageNumberList); |
| 39 } else { |
| 40 return isPageRangeTextValid(pageRangeStr, totalPageCount) ? |
| 41 new PageNumberSet( |
| 42 pageRangeTextToPageList(pageRangeStr, totalPageCount)) : null; |
| 43 } |
| 44 }; |
| 45 |
| 46 PageNumberSet.prototype = { |
| 47 /** @return {number} The number of page numbers in the set. */ |
| 48 get size() { |
| 49 return this.pageNumberSet_.length; |
| 50 }, |
| 51 |
| 52 /** |
| 53 * @param {number} index 0-based index of the page number to get. |
| 54 * @return {number} Page number at the given index. |
| 55 */ |
| 56 getPageNumberAt: function(index) { |
| 57 return this.pageNumberSet_[index]; |
| 58 }, |
| 59 |
| 60 /** |
| 61 * @param {number} 1-based page number to check for. |
| 62 * @return {boolean} Whether the given page number is in the page range. |
| 63 */ |
| 64 hasPageNumber: function(pageNumber) { |
| 65 return arrayContains(this.pageNumberSet_, pageNumber); |
| 66 }, |
| 67 |
| 68 /** |
| 69 * @param {number} 1-based number of the page to get index of. |
| 70 * @return {number} 0-based index of the given page number with respect to |
| 71 * all of the pages in the page range. |
| 72 */ |
| 73 getPageNumberIndex: function(pageNumber) { |
| 74 return this.pageNumberSet_.indexOf(pageNumber); |
| 75 }, |
| 76 |
| 77 /** |
| 78 * @return {!Array.<object.<{from: number, to: number}>>} A list of page |
| 79 * ranges suitable for use in the native layer. |
| 80 */ |
| 81 getPageRanges: function() { |
| 82 return pageSetToPageRanges(this.pageNumberSet_); |
| 83 }, |
| 84 |
| 85 /** @return {!Array.<number>} Array representation of the set. */ |
| 86 asArray: function() { |
| 87 return this.pageNumberSet_.slice(0); |
| 88 }, |
| 89 |
| 90 /** |
| 91 * @param {print_preview.PageNumberSet} other Page number set to compare |
| 92 * against. |
| 93 * @return {boolean} Whether another page number set is equal to this one. |
| 94 */ |
| 95 equals: function(other) { |
| 96 return other == null ? |
| 97 false : areArraysEqual(this.pageNumberSet_, other.pageNumberSet_); |
| 98 } |
| 99 }; |
| 100 |
| 101 // Export |
| 102 return { |
| 103 PageNumberSet: PageNumberSet |
| 104 }; |
| 105 }); |
OLD | NEW |