OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 'use strict'; | 5 'use strict'; |
6 | 6 |
7 /** | 7 /** |
8 * Creates a new OpenPDFParamsParser. This parses the open pdf parameters | 8 * Creates a new OpenPDFParamsParser. This parses the open pdf parameters |
9 * passed in the url to set initial viewport settings for opening the pdf. | 9 * passed in the url to set initial viewport settings for opening the pdf. |
10 * @param {string} url to be parsed. | 10 * @param {string} url to be parsed. |
11 */ | 11 */ |
12 function OpenPDFParamsParser(url) { | 12 function OpenPDFParamsParser(url) { |
13 this.url_ = url; | |
14 this.urlParams = {}; | 13 this.urlParams = {}; |
15 this.parseOpenPDFParams_(); | 14 // This will have name of all the nameddest from the loaded PDF. |
raymes
2015/01/14 00:19:00
nit: // A dictionary of all the named destinations
Deepak
2015/01/14 06:29:01
Done.
| |
15 this.namedDestinations = {}; | |
16 } | 16 } |
17 | 17 |
18 OpenPDFParamsParser.prototype = { | 18 OpenPDFParamsParser.prototype = { |
19 /** | 19 /** |
20 * @private | 20 * @private |
21 * Parse zoom parameter of open PDF parameters. If this | 21 * Parse zoom parameter of open PDF parameters. If this |
22 * parameter is passed while opening PDF then PDF should be opened | 22 * parameter is passed while opening PDF then PDF should be opened |
23 * at the specified zoom level. | 23 * at the specified zoom level. |
24 * @param {number} zoom value. | 24 * @param {number} zoom value. |
25 */ | 25 */ |
(...skipping 15 matching lines...) Expand all Loading... | |
41 | 41 |
42 // Handle #zoom=scale,left,top. | 42 // Handle #zoom=scale,left,top. |
43 var position = {x: parseFloat(paramValueSplit[1]), | 43 var position = {x: parseFloat(paramValueSplit[1]), |
44 y: parseFloat(paramValueSplit[2])}; | 44 y: parseFloat(paramValueSplit[2])}; |
45 this.urlParams['position'] = position; | 45 this.urlParams['position'] = position; |
46 this.urlParams['zoom'] = zoomFactor; | 46 this.urlParams['zoom'] = zoomFactor; |
47 }, | 47 }, |
48 | 48 |
49 /** | 49 /** |
50 * @private | 50 * @private |
51 * Parse open PDF parameters. These parameters are mentioned in the url | 51 * Parse PDF url parameters. These parameters are mentioned in the url |
52 * and specify actions to be performed when opening pdf files. | 52 * and specify actions to be performed when opening pdf files. |
53 * See http://www.adobe.com/content/dam/Adobe/en/devnet/acrobat/ | 53 * See http://www.adobe.com/content/dam/Adobe/en/devnet/acrobat/ |
54 * pdfs/pdf_open_parameters.pdf for details. | 54 * pdfs/pdf_open_parameters.pdf for details. |
55 * @param {string} inputUrl that need to be parsed. | |
56 * @return {Object} urlParams data that have the PDF url parameter info. | |
55 */ | 57 */ |
56 parseOpenPDFParams_: function() { | 58 getURLPDFParams: function(inputUrl) { |
57 var originalUrl = this.url_; | 59 var originalUrl = inputUrl; |
58 var paramIndex = originalUrl.search('#'); | 60 var paramIndex = originalUrl.search('#'); |
59 if (paramIndex == -1) | 61 if (paramIndex == -1) |
60 return; | 62 return; |
61 | |
62 var paramTokens = originalUrl.substring(paramIndex + 1).split('&'); | 63 var paramTokens = originalUrl.substring(paramIndex + 1).split('&'); |
63 var paramsDictionary = {}; | 64 var paramsDictionary = {}; |
64 for (var i = 0; i < paramTokens.length; ++i) { | 65 for (var i = 0; i < paramTokens.length; ++i) { |
65 var keyValueSplit = paramTokens[i].split('='); | 66 var keyValueSplit = paramTokens[i].split('='); |
66 if (keyValueSplit.length != 2) | 67 if (keyValueSplit.length != 2) |
67 continue; | 68 continue; |
68 paramsDictionary[keyValueSplit[0]] = keyValueSplit[1]; | 69 paramsDictionary[keyValueSplit[0]] = keyValueSplit[1]; |
69 } | 70 } |
71 if ('zoom' in paramsDictionary) | |
72 this.parseZoomParam_(paramsDictionary['zoom']); | |
73 return this.urlParams; | |
74 }, | |
70 | 75 |
71 if ('page' in paramsDictionary) { | 76 /** |
72 // |pageNumber| is 1-based, but goToPage() take a zero-based page number. | 77 * @private |
73 var pageNumber = parseInt(paramsDictionary['page']); | 78 * Helper function to give the page number after parsing url based on page, |
74 if (!isNaN(pageNumber)) | 79 * nameddest and nameddest with some value. These parameters are mentioned in |
75 this.urlParams['page'] = pageNumber - 1; | 80 * the url and specify actions to be performed when opening pdf files. |
81 * See http://www.adobe.com/content/dam/Adobe/en/devnet/acrobat/ | |
82 * pdfs/pdf_open_parameters.pdf for details. | |
83 * @param {string} inputUrl that need to be parsed to get pageNumber. | |
84 * @return {number} page number info for scrolling PDF file. | |
85 */ | |
86 getInitalPage: function(inputUrl) { | |
87 var originalUrl = inputUrl; | |
88 var finalPageNumber = -1; | |
89 var paramIndex = originalUrl.search('#'); | |
90 if (paramIndex == -1) | |
91 return finalPageNumber; | |
92 | |
93 var paramTokens = originalUrl.substring(paramIndex + 1).split('&'); | |
94 if ((paramTokens.length == 1) && (paramTokens[0].search('=') == -1)) { | |
95 return this.namedDestinations[paramTokens[0]]; | |
76 } | 96 } |
77 | 97 |
78 if ('zoom' in paramsDictionary) | 98 for (var i = 0; i < paramTokens.length; ++i) { |
79 this.parseZoomParam_(paramsDictionary['zoom']); | 99 var keyValueSplit = paramTokens[i].split('='); |
80 } | 100 if (keyValueSplit.length != 2) |
101 continue; | |
102 if (keyValueSplit[0] == 'page') { | |
103 var pageNumber = parseInt(keyValueSplit[1]); | |
104 if (!isNaN(pageNumber) && pageNumber > 0) | |
105 finalPageNumber = pageNumber - 1; | |
106 continue; | |
107 } | |
108 if (keyValueSplit[0] == 'nameddest') { | |
109 var pageNumber = this.namedDestinations[keyValueSplit[1]]; | |
110 if (!isNaN(pageNumber) && pageNumber >= 0) | |
111 finalPageNumber = pageNumber; | |
112 continue; | |
113 } | |
114 } | |
115 return finalPageNumber; | |
116 }, | |
raymes
2015/01/14 00:19:00
I don't think we need to add a new function to par
Deepak
2015/01/14 06:29:01
I understood your meaning, I am removing getInitia
| |
81 }; | 117 }; |
OLD | NEW |