annotate rhodecode/public/js/yui/history/history.js @ 1073:289ff43cc190 beta

update YUI dev libs to latest version
author Marcin Kuzminski <marcin@python-works.com>
date Sun, 20 Feb 2011 20:58:07 +0100
parents 1e757ac98988
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
1 /*
1073
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
2 Copyright (c) 2010, Yahoo! Inc. All rights reserved.
0
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
3 Code licensed under the BSD License:
1073
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
4 http://developer.yahoo.com/yui/license.html
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
5 version: 2.8.2r1
0
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
6 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
7 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
8 * The Browser History Manager provides the ability to use the back/forward
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
9 * navigation buttons in a DHTML application. It also allows a DHTML
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
10 * application to be bookmarked in a specific state.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
11 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
12 * This library requires the following static markup:
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
13 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
14 * &lt;iframe id="yui-history-iframe" src="path-to-real-asset-in-same-domain"&gt;&lt;/iframe&gt;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
15 * &lt;input id="yui-history-field" type="hidden"&gt;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
16 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
17 * @module history
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
18 * @requires yahoo,event
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
19 * @namespace YAHOO.util
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
20 * @title Browser History Manager
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
21 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
22
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
23 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
24 * The History class provides the ability to use the back/forward navigation
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
25 * buttons in a DHTML application. It also allows a DHTML application to
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
26 * be bookmarked in a specific state.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
27 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
28 * @class History
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
29 * @constructor
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
30 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
31 YAHOO.util.History = (function () {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
32
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
33 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
34 * Our hidden IFrame used to store the browsing history.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
35 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
36 * @property _histFrame
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
37 * @type HTMLIFrameElement
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
38 * @default null
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
39 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
40 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
41 var _histFrame = null;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
42
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
43 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
44 * INPUT field (with type="hidden" or type="text") or TEXTAREA.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
45 * This field keeps the value of the initial state, current state
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
46 * the list of all states across pages within a single browser session.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
47 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
48 * @property _stateField
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
49 * @type HTMLInputElement|HTMLTextAreaElement
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
50 * @default null
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
51 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
52 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
53 var _stateField = null;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
54
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
55 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
56 * Flag used to tell whether YAHOO.util.History.initialize has been called.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
57 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
58 * @property _initialized
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
59 * @type boolean
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
60 * @default false
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
61 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
62 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
63 var _initialized = false;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
64
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
65 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
66 * List of registered modules.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
67 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
68 * @property _modules
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
69 * @type array
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
70 * @default []
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
71 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
72 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
73 var _modules = [];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
74
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
75 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
76 * List of fully qualified states. This is used only by Safari.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
77 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
78 * @property _fqstates
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
79 * @type array
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
80 * @default []
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
81 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
82 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
83 var _fqstates = [];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
84
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
85 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
86 * location.hash is a bit buggy on Opera. I have seen instances where
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
87 * navigating the history using the back/forward buttons, and hence
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
88 * changing the URL, would not change location.hash. That's ok, the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
89 * implementation of an equivalent is trivial.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
90 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
91 * @method _getHash
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
92 * @return {string} The hash portion of the document's location
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
93 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
94 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
95 function _getHash() {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
96 var i, href;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
97 href = top.location.href;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
98 i = href.indexOf("#");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
99 return i >= 0 ? href.substr(i + 1) : null;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
100 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
101
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
102 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
103 * Stores all the registered modules' initial state and current state.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
104 * On Safari, we also store all the fully qualified states visited by
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
105 * the application within a single browser session. The storage takes
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
106 * place in the form field specified during initialization.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
107 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
108 * @method _storeStates
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
109 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
110 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
111 function _storeStates() {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
112
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
113 var moduleName, moduleObj, initialStates = [], currentStates = [];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
114
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
115 for (moduleName in _modules) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
116 if (YAHOO.lang.hasOwnProperty(_modules, moduleName)) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
117 moduleObj = _modules[moduleName];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
118 initialStates.push(moduleName + "=" + moduleObj.initialState);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
119 currentStates.push(moduleName + "=" + moduleObj.currentState);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
120 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
121 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
122
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
123 _stateField.value = initialStates.join("&") + "|" + currentStates.join("&");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
124
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
125 if (YAHOO.env.ua.webkit) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
126 _stateField.value += "|" + _fqstates.join(",");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
127 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
128 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
129
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
130 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
131 * Sets the new currentState attribute of all modules depending on the new
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
132 * fully qualified state. Also notifies the modules which current state has
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
133 * changed.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
134 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
135 * @method _handleFQStateChange
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
136 * @param {string} fqstate Fully qualified state
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
137 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
138 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
139 function _handleFQStateChange(fqstate) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
140
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
141 var i, len, moduleName, moduleObj, modules, states, tokens, currentState;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
142
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
143 if (!fqstate) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
144 // Notifies all modules
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
145 for (moduleName in _modules) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
146 if (YAHOO.lang.hasOwnProperty(_modules, moduleName)) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
147 moduleObj = _modules[moduleName];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
148 moduleObj.currentState = moduleObj.initialState;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
149 moduleObj.onStateChange(unescape(moduleObj.currentState));
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
150 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
151 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
152 return;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
153 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
154
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
155 modules = [];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
156 states = fqstate.split("&");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
157 for (i = 0, len = states.length; i < len; i++) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
158 tokens = states[i].split("=");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
159 if (tokens.length === 2) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
160 moduleName = tokens[0];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
161 currentState = tokens[1];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
162 modules[moduleName] = currentState;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
163 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
164 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
165
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
166 for (moduleName in _modules) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
167 if (YAHOO.lang.hasOwnProperty(_modules, moduleName)) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
168 moduleObj = _modules[moduleName];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
169 currentState = modules[moduleName];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
170 if (!currentState || moduleObj.currentState !== currentState) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
171 moduleObj.currentState = currentState || moduleObj.initialState;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
172 moduleObj.onStateChange(unescape(moduleObj.currentState));
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
173 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
174 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
175 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
176 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
177
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
178 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
179 * Update the IFrame with our new state.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
180 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
181 * @method _updateIFrame
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
182 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
183 * @return {boolean} true if successful. false otherwise.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
184 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
185 function _updateIFrame (fqstate) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
186
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
187 var html, doc;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
188
1073
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
189 html = '<html><body><div id="state">' +
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
190 fqstate.replace(/&/g,'&amp;').
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
191 replace(/</g,'&lt;').
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
192 replace(/>/g,'&gt;').
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
193 replace(/"/g,'&quot;') +
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
194 '</div></body></html>';
0
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
195
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
196 try {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
197 doc = _histFrame.contentWindow.document;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
198 doc.open();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
199 doc.write(html);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
200 doc.close();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
201 return true;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
202 } catch (e) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
203 return false;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
204 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
205 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
206
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
207 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
208 * Periodically checks whether our internal IFrame is ready to be used.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
209 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
210 * @method _checkIframeLoaded
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
211 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
212 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
213 function _checkIframeLoaded() {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
214
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
215 var doc, elem, fqstate, hash;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
216
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
217 if (!_histFrame.contentWindow || !_histFrame.contentWindow.document) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
218 // Check again in 10 msec...
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
219 setTimeout(_checkIframeLoaded, 10);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
220 return;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
221 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
222
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
223 // Start the thread that will have the responsibility to
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
224 // periodically check whether a navigate operation has been
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
225 // requested on the main window. This will happen when
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
226 // YAHOO.util.History.navigate has been called or after
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
227 // the user has hit the back/forward button.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
228
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
229 doc = _histFrame.contentWindow.document;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
230 elem = doc.getElementById("state");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
231 // We must use innerText, and not innerHTML because our string contains
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
232 // the "&" character (which would end up being escaped as "&amp;") and
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
233 // the string comparison would fail...
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
234 fqstate = elem ? elem.innerText : null;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
235
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
236 hash = _getHash();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
237
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
238 setInterval(function () {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
239
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
240 var newfqstate, states, moduleName, moduleObj, newHash, historyLength;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
241
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
242 doc = _histFrame.contentWindow.document;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
243 elem = doc.getElementById("state");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
244 // See my comment above about using innerText instead of innerHTML...
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
245 newfqstate = elem ? elem.innerText : null;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
246
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
247 newHash = _getHash();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
248
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
249 if (newfqstate !== fqstate) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
250
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
251 fqstate = newfqstate;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
252 _handleFQStateChange(fqstate);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
253
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
254 if (!fqstate) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
255 states = [];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
256 for (moduleName in _modules) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
257 if (YAHOO.lang.hasOwnProperty(_modules, moduleName)) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
258 moduleObj = _modules[moduleName];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
259 states.push(moduleName + "=" + moduleObj.initialState);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
260 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
261 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
262 newHash = states.join("&");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
263 } else {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
264 newHash = fqstate;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
265 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
266
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
267 // Allow the state to be bookmarked by setting the top window's
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
268 // URL fragment identifier. Note that here, we are on IE, and
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
269 // IE does not touch the browser history when setting the hash
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
270 // (unlike all the other browsers). I used to write:
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
271 // top.location.replace( "#" + hash );
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
272 // but this had a side effect when the page was not the top frame.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
273 top.location.hash = newHash;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
274 hash = newHash;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
275
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
276 _storeStates();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
277
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
278 } else if (newHash !== hash) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
279
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
280 // The hash has changed. The user might have clicked on a link,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
281 // or modified the URL directly, or opened the same application
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
282 // bookmarked in a specific state using a bookmark. However, we
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
283 // know the hash change was not caused by a hit on the back or
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
284 // forward buttons, or by a call to navigate() (because it would
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
285 // have been handled above) We must handle these cases, which is
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
286 // why we also need to keep track of hash changes on IE!
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
287
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
288 // Note that IE6 has some major issues with this kind of user
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
289 // interaction (the history stack gets completely messed up)
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
290 // but it seems to work fine on IE7.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
291
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
292 hash = newHash;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
293
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
294 // Now, store a new history entry. The following will cause the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
295 // code above to execute, doing all the dirty work for us...
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
296 _updateIFrame(newHash);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
297 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
298
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
299 }, 50);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
300
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
301 _initialized = true;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
302 YAHOO.util.History.onLoadEvent.fire();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
303 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
304
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
305 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
306 * Finish up the initialization of the Browser History Manager.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
307 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
308 * @method _initialize
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
309 * @private
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
310 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
311 function _initialize() {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
312
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
313 var i, len, parts, tokens, moduleName, moduleObj, initialStates, initialState, currentStates, currentState, counter, hash;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
314
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
315 // Decode the content of our storage field...
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
316 parts = _stateField.value.split("|");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
317
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
318 if (parts.length > 1) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
319
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
320 initialStates = parts[0].split("&");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
321 for (i = 0, len = initialStates.length; i < len; i++) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
322 tokens = initialStates[i].split("=");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
323 if (tokens.length === 2) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
324 moduleName = tokens[0];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
325 initialState = tokens[1];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
326 moduleObj = _modules[moduleName];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
327 if (moduleObj) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
328 moduleObj.initialState = initialState;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
329 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
330 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
331 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
332
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
333 currentStates = parts[1].split("&");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
334 for (i = 0, len = currentStates.length; i < len; i++) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
335 tokens = currentStates[i].split("=");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
336 if (tokens.length >= 2) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
337 moduleName = tokens[0];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
338 currentState = tokens[1];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
339 moduleObj = _modules[moduleName];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
340 if (moduleObj) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
341 moduleObj.currentState = currentState;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
342 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
343 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
344 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
345 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
346
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
347 if (parts.length > 2) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
348 _fqstates = parts[2].split(",");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
349 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
350
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
351 if (YAHOO.env.ua.ie) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
352
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
353 if (typeof document.documentMode === "undefined" || document.documentMode < 8) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
354
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
355 // IE < 8 or IE8 in quirks mode or IE7 standards mode
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
356 _checkIframeLoaded();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
357
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
358 } else {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
359
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
360 // IE8 in IE8 standards mode
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
361 YAHOO.util.Event.on(top, "hashchange",
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
362 function () {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
363 var hash = _getHash();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
364 _handleFQStateChange(hash);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
365 _storeStates();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
366 });
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
367
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
368 _initialized = true;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
369 YAHOO.util.History.onLoadEvent.fire();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
370
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
371 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
372
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
373 } else {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
374
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
375 // Start the thread that will have the responsibility to
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
376 // periodically check whether a navigate operation has been
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
377 // requested on the main window. This will happen when
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
378 // YAHOO.util.History.navigate has been called or after
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
379 // the user has hit the back/forward button.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
380
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
381 // On Safari 1.x and 2.0, the only way to catch a back/forward
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
382 // operation is to watch history.length... We basically exploit
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
383 // what I consider to be a bug (history.length is not supposed
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
384 // to change when going back/forward in the history...) This is
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
385 // why, in the following thread, we first compare the hash,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
386 // because the hash thing will be fixed in the next major
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
387 // version of Safari. So even if they fix the history.length
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
388 // bug, all this will still work!
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
389 counter = history.length;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
390
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
391 // On Gecko and Opera, we just need to watch the hash...
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
392 hash = _getHash();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
393
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
394 setInterval(function () {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
395
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
396 var state, newHash, newCounter;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
397
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
398 newHash = _getHash();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
399 newCounter = history.length;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
400 if (newHash !== hash) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
401 hash = newHash;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
402 counter = newCounter;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
403 _handleFQStateChange(hash);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
404 _storeStates();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
405 } else if (newCounter !== counter && YAHOO.env.ua.webkit) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
406 hash = newHash;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
407 counter = newCounter;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
408 state = _fqstates[counter - 1];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
409 _handleFQStateChange(state);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
410 _storeStates();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
411 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
412
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
413 }, 50);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
414
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
415 _initialized = true;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
416 YAHOO.util.History.onLoadEvent.fire();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
417 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
418 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
419
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
420 return {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
421
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
422 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
423 * Fired when the Browser History Manager is ready. If you subscribe to
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
424 * this event after the Browser History Manager has been initialized,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
425 * it will not fire. Therefore, it is recommended to use the onReady
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
426 * method instead.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
427 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
428 * @event onLoadEvent
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
429 * @see onReady
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
430 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
431 onLoadEvent: new YAHOO.util.CustomEvent("onLoad"),
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
432
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
433 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
434 * Executes the supplied callback when the Browser History Manager is
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
435 * ready. This will execute immediately if called after the Browser
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
436 * History Manager onLoad event has fired.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
437 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
438 * @method onReady
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
439 * @param {function} fn what to execute when the Browser History Manager is ready.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
440 * @param {object} obj an optional object to be passed back as a parameter to fn.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
441 * @param {boolean|object} overrideContext If true, the obj passed in becomes fn's execution scope.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
442 * @see onLoadEvent
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
443 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
444 onReady: function (fn, obj, overrideContext) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
445
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
446 if (_initialized) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
447
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
448 setTimeout(function () {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
449 var ctx = window;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
450 if (overrideContext) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
451 if (overrideContext === true) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
452 ctx = obj;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
453 } else {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
454 ctx = overrideContext;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
455 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
456 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
457 fn.call(ctx, "onLoad", [], obj);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
458 }, 0);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
459
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
460 } else {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
461
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
462 YAHOO.util.History.onLoadEvent.subscribe(fn, obj, overrideContext);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
463
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
464 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
465 },
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
466
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
467 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
468 * Registers a new module.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
469 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
470 * @method register
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
471 * @param {string} module Non-empty string uniquely identifying the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
472 * module you wish to register.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
473 * @param {string} initialState The initial state of the specified
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
474 * module corresponding to its earliest history entry.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
475 * @param {function} onStateChange Callback called when the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
476 * state of the specified module has changed.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
477 * @param {object} obj An arbitrary object that will be passed as a
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
478 * parameter to the handler.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
479 * @param {boolean} overrideContext If true, the obj passed in becomes the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
480 * execution scope of the listener.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
481 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
482 register: function (module, initialState, onStateChange, obj, overrideContext) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
483
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
484 var scope, wrappedFn;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
485
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
486 if (typeof module !== "string" || YAHOO.lang.trim(module) === "" ||
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
487 typeof initialState !== "string" ||
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
488 typeof onStateChange !== "function") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
489 throw new Error("Missing or invalid argument");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
490 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
491
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
492 if (_modules[module]) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
493 // Here, we used to throw an exception. However, users have
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
494 // complained about this behavior, so we now just return.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
495 return;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
496 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
497
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
498 // Note: A module CANNOT be registered after calling
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
499 // YAHOO.util.History.initialize. Indeed, we set the initial state
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
500 // of each registered module in YAHOO.util.History.initialize.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
501 // If you could register a module after initializing the Browser
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
502 // History Manager, you would not read the correct state using
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
503 // YAHOO.util.History.getCurrentState when coming back to the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
504 // page using the back button.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
505 if (_initialized) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
506 throw new Error("All modules must be registered before calling YAHOO.util.History.initialize");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
507 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
508
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
509 // Make sure the strings passed in do not contain our separators "," and "|"
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
510 module = escape(module);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
511 initialState = escape(initialState);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
512
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
513 // If the user chooses to override the scope, we use the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
514 // custom object passed in as the execution scope.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
515 scope = null;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
516 if (overrideContext === true) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
517 scope = obj;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
518 } else {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
519 scope = overrideContext;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
520 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
521
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
522 wrappedFn = function (state) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
523 return onStateChange.call(scope, state, obj);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
524 };
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
525
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
526 _modules[module] = {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
527 name: module,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
528 initialState: initialState,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
529 currentState: initialState,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
530 onStateChange: wrappedFn
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
531 };
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
532 },
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
533
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
534 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
535 * Initializes the Browser History Manager. Call this method
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
536 * from a script block located right after the opening body tag.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
537 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
538 * @method initialize
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
539 * @param {string|HTML Element} stateField <input type="hidden"> used
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
540 * to store application states. Must be in the static markup.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
541 * @param {string|HTML Element} histFrame IFrame used to store
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
542 * the history (only required on Internet Explorer)
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
543 * @public
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
544 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
545 initialize: function (stateField, histFrame) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
546
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
547 if (_initialized) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
548 // The browser history manager has already been initialized.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
549 return;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
550 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
551
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
552 if (YAHOO.env.ua.opera && typeof history.navigationMode !== "undefined") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
553 // Disable Opera's fast back/forward navigation mode and puts
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
554 // it in compatible mode. This makes anchor-based history
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
555 // navigation work after the page has been navigated away
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
556 // from and re-activated, at the cost of slowing down
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
557 // back/forward navigation to and from that page.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
558 history.navigationMode = "compatible";
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
559 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
560
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
561 if (typeof stateField === "string") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
562 stateField = document.getElementById(stateField);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
563 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
564
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
565 if (!stateField ||
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
566 stateField.tagName.toUpperCase() !== "TEXTAREA" &&
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
567 (stateField.tagName.toUpperCase() !== "INPUT" ||
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
568 stateField.type !== "hidden" &&
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
569 stateField.type !== "text")) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
570 throw new Error("Missing or invalid argument");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
571 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
572
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
573 _stateField = stateField;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
574
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
575 // IE < 8 or IE8 in quirks mode or IE7 standards mode
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
576 if (YAHOO.env.ua.ie && (typeof document.documentMode === "undefined" || document.documentMode < 8)) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
577
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
578 if (typeof histFrame === "string") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
579 histFrame = document.getElementById(histFrame);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
580 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
581
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
582 if (!histFrame || histFrame.tagName.toUpperCase() !== "IFRAME") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
583 throw new Error("Missing or invalid argument");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
584 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
585
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
586 _histFrame = histFrame;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
587 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
588
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
589 // Note that the event utility MUST be included inline in the page.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
590 // If it gets loaded later (which you may want to do to improve the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
591 // loading speed of your site), the onDOMReady event never fires,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
592 // and the history library never gets fully initialized.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
593 YAHOO.util.Event.onDOMReady(_initialize);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
594 },
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
595
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
596 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
597 * Call this method when you want to store a new entry in the browser's history.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
598 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
599 * @method navigate
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
600 * @param {string} module Non-empty string representing your module.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
601 * @param {string} state String representing the new state of the specified module.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
602 * @return {boolean} Indicates whether the new state was successfully added to the history.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
603 * @public
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
604 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
605 navigate: function (module, state) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
606
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
607 var states;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
608
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
609 if (typeof module !== "string" || typeof state !== "string") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
610 throw new Error("Missing or invalid argument");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
611 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
612
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
613 states = {};
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
614 states[module] = state;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
615
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
616 return YAHOO.util.History.multiNavigate(states);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
617 },
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
618
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
619 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
620 * Call this method when you want to store a new entry in the browser's history.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
621 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
622 * @method multiNavigate
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
623 * @param {object} states Associative array of module-state pairs to set simultaneously.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
624 * @return {boolean} Indicates whether the new state was successfully added to the history.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
625 * @public
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
626 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
627 multiNavigate: function (states) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
628
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
629 var currentStates, moduleName, moduleObj, currentState, fqstate;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
630
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
631 if (typeof states !== "object") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
632 throw new Error("Missing or invalid argument");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
633 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
634
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
635 if (!_initialized) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
636 throw new Error("The Browser History Manager is not initialized");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
637 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
638
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
639 for (moduleName in states) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
640 if (!_modules[moduleName]) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
641 throw new Error("The following module has not been registered: " + moduleName);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
642 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
643 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
644
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
645 // Generate our new full state string mod1=xxx&mod2=yyy
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
646 currentStates = [];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
647
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
648 for (moduleName in _modules) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
649 if (YAHOO.lang.hasOwnProperty(_modules, moduleName)) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
650 moduleObj = _modules[moduleName];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
651 if (YAHOO.lang.hasOwnProperty(states, moduleName)) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
652 currentState = states[unescape(moduleName)];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
653 } else {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
654 currentState = unescape(moduleObj.currentState);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
655 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
656
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
657 // Make sure the strings passed in do not contain our separators "," and "|"
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
658 moduleName = escape(moduleName);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
659 currentState = escape(currentState);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
660
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
661 currentStates.push(moduleName + "=" + currentState);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
662 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
663 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
664
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
665 fqstate = currentStates.join("&");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
666
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
667 if (YAHOO.env.ua.ie && (typeof document.documentMode === "undefined" || document.documentMode < 8)) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
668
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
669 return _updateIFrame(fqstate);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
670
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
671 } else {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
672
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
673 // Known bug: On Safari 1.x and 2.0, if you have tab browsing
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
674 // enabled, Safari will show an endless loading icon in the
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
675 // tab. This has apparently been fixed in recent WebKit builds.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
676 // One work around found by Dav Glass is to submit a form that
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
677 // points to the same document. This indeed works on Safari 1.x
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
678 // and 2.0 but creates bigger problems on WebKit. So for now,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
679 // we'll consider this an acceptable bug, and hope that Apple
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
680 // comes out with their next version of Safari very soon.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
681 top.location.hash = fqstate;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
682 if (YAHOO.env.ua.webkit) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
683 // The following two lines are only useful for Safari 1.x
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
684 // and 2.0. Recent nightly builds of WebKit do not require
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
685 // that, but unfortunately, it is not easy to differentiate
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
686 // between the two. Once Safari 2.0 departs the A-grade
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
687 // list, we can remove the following two lines...
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
688 _fqstates[history.length] = fqstate;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
689 _storeStates();
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
690 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
691
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
692 return true;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
693
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
694 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
695 },
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
696
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
697 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
698 * Returns the current state of the specified module.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
699 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
700 * @method getCurrentState
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
701 * @param {string} module Non-empty string representing your module.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
702 * @return {string} The current state of the specified module.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
703 * @public
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
704 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
705 getCurrentState: function (module) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
706
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
707 var moduleObj;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
708
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
709 if (typeof module !== "string") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
710 throw new Error("Missing or invalid argument");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
711 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
712
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
713 if (!_initialized) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
714 throw new Error("The Browser History Manager is not initialized");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
715 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
716
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
717 moduleObj = _modules[module];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
718 if (!moduleObj) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
719 throw new Error("No such registered module: " + module);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
720 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
721
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
722 return unescape(moduleObj.currentState);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
723 },
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
724
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
725 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
726 * Returns the state of a module according to the URL fragment
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
727 * identifier. This method is useful to initialize your modules
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
728 * if your application was bookmarked from a particular state.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
729 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
730 * @method getBookmarkedState
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
731 * @param {string} module Non-empty string representing your module.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
732 * @return {string} The bookmarked state of the specified module.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
733 * @public
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
734 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
735 getBookmarkedState: function (module) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
736
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
737 var i, len, idx, hash, states, tokens, moduleName;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
738
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
739 if (typeof module !== "string") {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
740 throw new Error("Missing or invalid argument");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
741 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
742
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
743 // Use location.href instead of location.hash which is already
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
744 // URL-decoded, which creates problems if the state value
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
745 // contained special characters...
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
746 idx = top.location.href.indexOf("#");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
747 if (idx >= 0) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
748 hash = top.location.href.substr(idx + 1);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
749 states = hash.split("&");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
750 for (i = 0, len = states.length; i < len; i++) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
751 tokens = states[i].split("=");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
752 if (tokens.length === 2) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
753 moduleName = tokens[0];
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
754 if (moduleName === module) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
755 return unescape(tokens[1]);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
756 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
757 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
758 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
759 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
760
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
761 return null;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
762 },
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
763
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
764 /**
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
765 * Returns the value of the specified query string parameter.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
766 * This method is not used internally by the Browser History Manager.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
767 * However, it is provided here as a helper since many applications
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
768 * using the Browser History Manager will want to read the value of
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
769 * url parameters to initialize themselves.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
770 *
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
771 * @method getQueryStringParameter
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
772 * @param {string} paramName Name of the parameter we want to look up.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
773 * @param {string} queryString Optional URL to look at. If not specified,
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
774 * this method uses the URL in the address bar.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
775 * @return {string} The value of the specified parameter, or null.
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
776 * @public
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
777 */
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
778 getQueryStringParameter: function (paramName, url) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
779
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
780 var i, len, idx, queryString, params, tokens;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
781
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
782 url = url || top.location.href;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
783
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
784 idx = url.indexOf("?");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
785 queryString = idx >= 0 ? url.substr(idx + 1) : url;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
786
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
787 // Remove the hash if any
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
788 idx = queryString.lastIndexOf("#");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
789 queryString = idx >= 0 ? queryString.substr(0, idx) : queryString;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
790
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
791 params = queryString.split("&");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
792
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
793 for (i = 0, len = params.length; i < len; i++) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
794 tokens = params[i].split("=");
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
795 if (tokens.length >= 2) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
796 if (tokens[0] === paramName) {
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
797 return unescape(tokens[1]);
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
798 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
799 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
800 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
801
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
802 return null;
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
803 }
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
804
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
805 };
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
806
564e40829f80 initial commit.
Marcin Kuzminski
parents:
diff changeset
807 })();
1073
289ff43cc190 update YUI dev libs to latest version
Marcin Kuzminski <marcin@python-works.com>
parents: 547
diff changeset
808 YAHOO.register("history", YAHOO.util.History, {version: "2.8.2r1", build: "7"});