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; | 13 // A dictionary of all the named destinations in the PDF. |
14 this.urlParams = {}; | 14 this.namedDestinations = {}; |
15 this.parseOpenPDFParams_(); | |
16 } | 15 } |
17 | 16 |
18 OpenPDFParamsParser.prototype = { | 17 OpenPDFParamsParser.prototype = { |
19 /** | 18 /** |
20 * @private | 19 * @private |
21 * Parse zoom parameter of open PDF parameters. If this | 20 * Parse zoom parameter of open PDF parameters. If this |
22 * parameter is passed while opening PDF then PDF should be opened | 21 * parameter is passed while opening PDF then PDF should be opened |
23 * at the specified zoom level. | 22 * at the specified zoom level. |
24 * @param {number} zoom value. | 23 * @param {number} zoom value. |
| 24 * @param {Object} viewportPosition to store zoom and position value. |
25 */ | 25 */ |
26 parseZoomParam_: function(paramValue) { | 26 parseZoomParam_: function(paramValue, viewportPosition) { |
27 var paramValueSplit = paramValue.split(','); | 27 var paramValueSplit = paramValue.split(','); |
28 if ((paramValueSplit.length != 1) && (paramValueSplit.length != 3)) | 28 if ((paramValueSplit.length != 1) && (paramValueSplit.length != 3)) |
29 return; | 29 return; |
30 | 30 |
31 // User scale of 100 means zoom value of 100% i.e. zoom factor of 1.0. | 31 // User scale of 100 means zoom value of 100% i.e. zoom factor of 1.0. |
32 var zoomFactor = parseFloat(paramValueSplit[0]) / 100; | 32 var zoomFactor = parseFloat(paramValueSplit[0]) / 100; |
33 if (isNaN(zoomFactor)) | 33 if (isNaN(zoomFactor)) |
34 return; | 34 return; |
35 | 35 |
36 // Handle #zoom=scale. | 36 // Handle #zoom=scale. |
37 if (paramValueSplit.length == 1) { | 37 if (paramValueSplit.length == 1) { |
38 this.urlParams['zoom'] = zoomFactor; | 38 viewportPosition['zoom'] = zoomFactor; |
39 return; | 39 return; |
40 } | 40 } |
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 viewportPosition['position'] = position; |
46 this.urlParams['zoom'] = zoomFactor; | 46 viewportPosition['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} url that needs to be parsed. |
| 56 * @return {Object} A dictionary containing the viewport which should be |
| 57 * displayed based on the URL. |
55 */ | 58 */ |
56 parseOpenPDFParams_: function() { | 59 getViewportFromUrlParams: function(url) { |
57 var originalUrl = this.url_; | 60 var viewportPosition = {}; |
58 var paramIndex = originalUrl.search('#'); | 61 var paramIndex = url.search('#'); |
59 if (paramIndex == -1) | 62 if (paramIndex == -1) |
60 return; | 63 return viewportPosition; |
61 | 64 |
62 var paramTokens = originalUrl.substring(paramIndex + 1).split('&'); | 65 var paramTokens = url.substring(paramIndex + 1).split('&'); |
| 66 if ((paramTokens.length == 1) && (paramTokens[0].search('=') == -1)) { |
| 67 // Handle the case of http://foo.com/bar#NAMEDDEST. This is not |
| 68 // explicitlymentioned except by example in the Adobe |
| 69 // "PDF Open Parameters" document. |
| 70 viewportPosition['page'] = this.namedDestinations[paramTokens[0]]; |
| 71 return viewportPosition; |
| 72 } |
| 73 |
63 var paramsDictionary = {}; | 74 var paramsDictionary = {}; |
64 for (var i = 0; i < paramTokens.length; ++i) { | 75 for (var i = 0; i < paramTokens.length; ++i) { |
65 var keyValueSplit = paramTokens[i].split('='); | 76 var keyValueSplit = paramTokens[i].split('='); |
66 if (keyValueSplit.length != 2) | 77 if (keyValueSplit.length != 2) |
67 continue; | 78 continue; |
68 paramsDictionary[keyValueSplit[0]] = keyValueSplit[1]; | 79 paramsDictionary[keyValueSplit[0]] = keyValueSplit[1]; |
69 } | 80 } |
70 | 81 |
| 82 if ('nameddest' in paramsDictionary) { |
| 83 var page = this.namedDestinations[paramsDictionary['nameddest']]; |
| 84 if (page != undefined) |
| 85 viewportPosition['page'] = page; |
| 86 } |
| 87 |
71 if ('page' in paramsDictionary) { | 88 if ('page' in paramsDictionary) { |
72 // |pageNumber| is 1-based, but goToPage() take a zero-based page number. | 89 // |pageNumber| is 1-based, but goToPage() take a zero-based page number. |
73 var pageNumber = parseInt(paramsDictionary['page']); | 90 var pageNumber = parseInt(paramsDictionary['page']); |
74 if (!isNaN(pageNumber)) | 91 if (!isNaN(pageNumber) && pageNumber > 0) |
75 this.urlParams['page'] = pageNumber - 1; | 92 viewportPosition['page'] = pageNumber - 1; |
76 } | 93 } |
77 | 94 |
78 if ('zoom' in paramsDictionary) | 95 if ('zoom' in paramsDictionary) |
79 this.parseZoomParam_(paramsDictionary['zoom']); | 96 this.parseZoomParam_(paramsDictionary['zoom'], viewportPosition); |
| 97 |
| 98 return viewportPosition; |
80 } | 99 } |
81 }; | 100 }; |
OLD | NEW |