UNPKG

70 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3var tslib_1 = require("tslib");
4var lodash_1 = require("lodash");
5var persist_1 = require("./persist");
6var actions_1 = require("./actions");
7function orderedPages(instances) {
8 return instances.pageOrder.map(function (path) { return instances.pages[path]; });
9}
10function cloneInstances(oldInstances) {
11 return {
12 pageOrder: oldInstances.pageOrder.slice(),
13 pages: tslib_1.__assign({}, oldInstances.pages),
14 };
15}
16function openPage(instances, options, pages) {
17 var newInstances = cloneInstances(instances);
18 var insertAfterMutex = options.insertAfterMutex, occurrence = tslib_1.__rest(options, ["insertAfterMutex"]);
19 var insertAfterIndex = insertAfterMutex ? newInstances.pageOrder.indexOf(insertAfterMutex) : -1;
20 if (occurrence.parent) {
21 if (occurrence.parent === occurrence.mutex) {
22 throw new Error(occurrence.mutex + " cannot be child of itself.");
23 }
24 if (!instances.pages[occurrence.parent]) {
25 throw new Error("Parent of " + occurrence.mutex + " is invalid.");
26 }
27 if (insertAfterIndex !== -1 &&
28 insertAfterIndex < instances.pageOrder.indexOf(occurrence.parent)) {
29 throw new Error("Cannot open " + occurrence.mutex + ". Cannot be inserted before the parent.");
30 }
31 if (instances.pages[occurrence.parent].parent) {
32 throw new Error("Cannot open " + occurrence.mutex + ". Nesting more than one level is forbidden.");
33 }
34 }
35 var newPage = pages.buildInstance(occurrence);
36 if (insertAfterIndex !== -1) {
37 newInstances.pageOrder.splice(insertAfterIndex + 1, 0, occurrence.mutex);
38 }
39 else {
40 newInstances.pageOrder.push(occurrence.mutex);
41 }
42 newInstances.pages[occurrence.mutex] = newPage;
43 return newInstances;
44}
45function closePage(instances, toRemoveMutex) {
46 var newPages = orderedPages(instances).filter(function (page) {
47 if (page.mutex === toRemoveMutex) {
48 return false;
49 }
50 return page.parent !== toRemoveMutex;
51 });
52 return {
53 pageOrder: newPages.map(function (page) { return page.mutex; }),
54 pages: lodash_1.keyBy(newPages, function (page) { return page.mutex; }),
55 };
56}
57function findClosePageTarget(instances, toRemoveMutex, override) {
58 if (instances.pageOrder.length < 2) {
59 return;
60 }
61 if (override && override !== toRemoveMutex && instances.pages[override]) {
62 return override;
63 }
64 var toRemove = instances.pages[toRemoveMutex];
65 if (!toRemove.parent) {
66 var roots = orderedPages(instances).filter(function (page) { return !page.parent; }).map(function (page) { return page.mutex; });
67 var toRemoveRootIndex = roots.indexOf(toRemoveMutex);
68 return toRemoveRootIndex === 0 ? roots[1] : roots[toRemoveRootIndex - 1];
69 }
70 var parentChildren = orderedPages(instances)
71 .filter(function (page) { return page.parent === toRemove.parent; })
72 .map(function (page) { return page.mutex; });
73 if (parentChildren.length === 1) {
74 return toRemove.parent;
75 }
76 var toRemoveIndex = parentChildren.indexOf(toRemoveMutex);
77 return toRemoveIndex === 0 ? parentChildren[1] : parentChildren[toRemoveIndex - 1];
78}
79function replacePage(instances, options, pages) {
80 var toRemoveMutex = options.toRemoveMutex, occurrence = tslib_1.__rest(options, ["toRemoveMutex"]);
81 var toInsertIndex = instances.pageOrder.indexOf(toRemoveMutex);
82 if (toInsertIndex === -1) {
83 return openPage(instances, occurrence, pages);
84 }
85 if (occurrence.parent !== instances.pages[toRemoveMutex].parent) {
86 throw new Error("Cannot open " + occurrence.mutex + ". " +
87 'The new page and the page to be removed must have the same parent.');
88 }
89 var newPage = pages.buildInstance(occurrence);
90 var newInstances = closePage(instances, toRemoveMutex);
91 newInstances.pageOrder.splice(toInsertIndex, 0, occurrence.mutex);
92 newInstances.pages[occurrence.mutex] = newPage;
93 return newInstances;
94}
95function cloneActiveChildren(instances, currentActives) {
96 var newActives = {};
97 var roots = orderedPages(instances).filter(function (page) { return !page.parent; }).map(function (page) { return page.mutex; });
98 for (var _i = 0, roots_1 = roots; _i < roots_1.length; _i++) {
99 var root = roots_1[_i];
100 if (currentActives[root] && instances.pages[currentActives[root]]) {
101 newActives[root] = currentActives[root];
102 }
103 }
104 return newActives;
105}
106function updateActiveChildren(instances, actives, target) {
107 var newActives = cloneActiveChildren(instances, actives);
108 if (!target) {
109 return newActives;
110 }
111 var targetPage = instances.pages[target];
112 // target is root
113 if (targetPage && !targetPage.parent) {
114 if (!newActives[target]) {
115 return newActives;
116 }
117 delete newActives[target];
118 return newActives;
119 }
120 var root = targetPage && targetPage.parent;
121 if (!root) {
122 return newActives;
123 }
124 return tslib_1.__assign({}, newActives, (_a = {}, _a[root] = target, _a));
125 var _a;
126}
127function getTransitionTarget(instances, actives, currentActive, desiredTarget) {
128 var desiredTargetPage = instances.pages[desiredTarget];
129 var currentPage = currentActive && instances.pages[currentActive];
130 // non-root
131 if (desiredTargetPage && desiredTargetPage.parent) {
132 return desiredTarget;
133 }
134 // transiting to own root
135 if (currentPage && desiredTarget === currentPage.parent) {
136 return desiredTarget;
137 }
138 if (actives[desiredTarget] && instances.pages[actives[desiredTarget]]) {
139 return actives[desiredTarget];
140 }
141 return desiredTarget;
142}
143var Navigator = /** @class */ (function () {
144 function Navigator(pages) {
145 this.instances = { pageOrder: [], pages: {} };
146 this.activeChildren = {};
147 this.pages = pages;
148 }
149 Object.defineProperty(Navigator.prototype, "all", {
150 get: function () {
151 return orderedPages(this.instances);
152 },
153 enumerable: true,
154 configurable: true
155 });
156 Object.defineProperty(Navigator.prototype, "roots", {
157 get: function () {
158 return this.all.filter(function (page) { return !page.parent; });
159 },
160 enumerable: true,
161 configurable: true
162 });
163 Object.defineProperty(Navigator.prototype, "active", {
164 get: function () {
165 if (!this.activePageMutex) {
166 return;
167 }
168 return this.instances.pages[this.activePageMutex];
169 },
170 enumerable: true,
171 configurable: true
172 });
173 Object.defineProperty(Navigator.prototype, "activeMutex", {
174 get: function () {
175 return this.activePageMutex;
176 },
177 enumerable: true,
178 configurable: true
179 });
180 Object.defineProperty(Navigator.prototype, "activeRootMutex", {
181 get: function () {
182 if (!this.activePageMutex || !this.instances.pages[this.activePageMutex]) {
183 return;
184 }
185 if (this.instances.pages[this.activePageMutex].parent) {
186 return this.instances.pages[this.activePageMutex].parent;
187 }
188 return this.activePageMutex;
189 },
190 enumerable: true,
191 configurable: true
192 });
193 Object.defineProperty(Navigator.prototype, "activeRoot", {
194 get: function () {
195 var mutex = this.activeRootMutex;
196 if (!mutex) {
197 return;
198 }
199 return this.instances.pages[mutex];
200 },
201 enumerable: true,
202 configurable: true
203 });
204 Object.defineProperty(Navigator.prototype, "activeRootIndex", {
205 get: function () {
206 if (!this.activePageMutex || !this.instances.pages[this.activePageMutex]) {
207 return -1;
208 }
209 var parentMutex = this.instances.pages[this.activePageMutex].parent;
210 if (!parentMutex) {
211 return this.roots.map(function (page) { return page.mutex; }).indexOf(this.activePageMutex);
212 }
213 return this.roots.map(function (page) { return page.mutex; }).indexOf(parentMutex);
214 },
215 enumerable: true,
216 configurable: true
217 });
218 Object.defineProperty(Navigator.prototype, "indexAsChildOfActiveRoot", {
219 get: function () {
220 if (!this.activePageMutex || !this.instances.pages[this.activePageMutex]) {
221 return -1;
222 }
223 var parentMutex = this.instances.pages[this.activePageMutex].parent;
224 if (!parentMutex) {
225 return -1;
226 }
227 return this.childrenOf(parentMutex).map(function (page) { return page.mutex; }).indexOf(this.activePageMutex);
228 },
229 enumerable: true,
230 configurable: true
231 });
232 Navigator.prototype.hasChildren = function (mutex) {
233 return this.all.some(function (page) { return page.parent === mutex; });
234 };
235 Navigator.prototype.childrenOf = function (mutex) {
236 return this.all.filter(function (page) { return page.parent === mutex; });
237 };
238 Navigator.prototype.pageFromMutex = function (mutex) {
239 return typeof mutex === 'string' ? this.instances.pages[mutex] : undefined;
240 };
241 Navigator.prototype.getActiveChild = function (mutex) {
242 return mutex ? this.activeChildren[mutex] : undefined;
243 };
244 Navigator.prototype.persistInstances = function (instances) {
245 var toSave = [];
246 for (var _i = 0, _a = orderedPages(instances); _i < _a.length; _i++) {
247 var instance = _a[_i];
248 if (instance.page.persistent !== false) {
249 if (instance.parent) {
250 if (instances.pages[instance.parent].page.persistent !== false) {
251 toSave.push(instance.occurrence);
252 }
253 }
254 else {
255 toSave.push(instance.occurrence);
256 }
257 }
258 }
259 persist_1.save(toSave);
260 };
261 Navigator.prototype.persistActivePage = function (instances, mutex) {
262 if (!mutex) {
263 persist_1.saveActivePage(undefined);
264 return;
265 }
266 if (instances.pages[mutex].page.persistent !== false) {
267 var parentMutex = instances.pages[mutex].parent;
268 if (parentMutex) {
269 var parent_1 = instances.pages[parentMutex];
270 if (parent_1.page.persistent !== false) {
271 persist_1.saveActivePage(mutex);
272 }
273 }
274 else {
275 persist_1.saveActivePage(mutex);
276 }
277 }
278 };
279 Navigator.prototype.reduce = function (action) {
280 if (actions_1.NAVIGATION_TRANSIT_TO_PAGE.is(actions_1.__NAVIGATION_IDENTIFIER__, action)) {
281 if (action.payload === this.activePageMutex) {
282 return this;
283 }
284 if (!action.payload) {
285 this.persistActivePage(this.instances, undefined);
286 var newNavWithoutActive = new Navigator(this.pages);
287 newNavWithoutActive.instances = this.instances;
288 newNavWithoutActive.activeChildren = this.activeChildren;
289 return newNavWithoutActive;
290 }
291 if (!this.instances.pages[action.payload]) {
292 return this;
293 }
294 var transitionTarget = getTransitionTarget(this.instances, this.activeChildren, this.activePageMutex, action.payload);
295 this.persistActivePage(this.instances, transitionTarget);
296 var newNav = new Navigator(this.pages);
297 newNav.instances = this.instances;
298 newNav.activePageMutex = transitionTarget;
299 newNav.activeChildren
300 = updateActiveChildren(this.instances, this.activeChildren, transitionTarget);
301 return newNav;
302 }
303 if (actions_1.NAVIGATION_OPEN_PAGE.is(actions_1.__NAVIGATION_IDENTIFIER__, action)) {
304 if (!action.payload || action.payload.mutex === this.activePageMutex) {
305 return this;
306 }
307 var _a = action.payload, mutex = _a.mutex, path = _a.path;
308 if (this.instances.pages[mutex]) {
309 this.persistActivePage(this.instances, mutex);
310 var newNav = new Navigator(this.pages);
311 newNav.instances = this.instances;
312 newNav.activePageMutex = mutex;
313 newNav.activeChildren = updateActiveChildren(this.instances, this.activeChildren, mutex);
314 return newNav;
315 }
316 if (this.pages.hasPage(path)) {
317 var newInstances = openPage(this.instances, action.payload, this.pages);
318 this.persistInstances(newInstances);
319 this.persistActivePage(newInstances, mutex);
320 var newNav = new Navigator(this.pages);
321 newNav.instances = newInstances;
322 newNav.activePageMutex = mutex;
323 newNav.activeChildren = updateActiveChildren(newInstances, this.activeChildren, mutex);
324 return newNav;
325 }
326 return this;
327 }
328 if (actions_1.NAVIGATION_REPLACE_PAGE.is(actions_1.__NAVIGATION_IDENTIFIER__, action)) {
329 if (!action.payload) {
330 return this;
331 }
332 var _b = action.payload, mutex = _b.mutex, path = _b.path;
333 if (this.instances.pages[mutex]) {
334 this.persistActivePage(this.instances, mutex);
335 var newNav = new Navigator(this.pages);
336 newNav.instances = this.instances;
337 newNav.activePageMutex = mutex;
338 newNav.activeChildren = updateActiveChildren(this.instances, this.activeChildren, mutex);
339 return newNav;
340 }
341 if (this.pages.hasPage(path)) {
342 var newInstances = replacePage(this.instances, action.payload, this.pages);
343 this.persistInstances(newInstances);
344 this.persistActivePage(newInstances, mutex);
345 var newNav = new Navigator(this.pages);
346 newNav.instances = newInstances;
347 newNav.activePageMutex = mutex;
348 newNav.activeChildren = updateActiveChildren(newInstances, this.activeChildren, mutex);
349 return newNav;
350 }
351 return this;
352 }
353 if (actions_1.NAVIGATION_CLOSE_PAGE.is(actions_1.__NAVIGATION_IDENTIFIER__, action)) {
354 if (!action.payload) {
355 return this;
356 }
357 var _c = action.payload, mutex = _c.mutex, goto = _c.goto;
358 if (!this.instances.pages[mutex]) {
359 return this;
360 }
361 var newNav = new Navigator(this.pages);
362 newNav.activePageMutex = this.activePageMutex;
363 var newInstances = closePage(this.instances, mutex);
364 var isParentOfActive = this.activePageMutex &&
365 this.instances.pages[this.activePageMutex].parent === mutex;
366 if (this.activePageMutex === mutex || isParentOfActive) {
367 var targetMutex = findClosePageTarget(this.instances, isParentOfActive ? this.instances.pages[this.activePageMutex].parent : mutex, goto);
368 var transitionTarget = targetMutex && getTransitionTarget(newInstances, this.activeChildren, this.activePageMutex, targetMutex);
369 this.persistActivePage(this.instances, undefined);
370 this.persistActivePage(this.instances, transitionTarget);
371 newNav.activePageMutex = transitionTarget;
372 }
373 this.persistInstances(newInstances);
374 newNav.instances = newInstances;
375 newNav.activeChildren
376 = updateActiveChildren(newInstances, this.activeChildren, newNav.activePageMutex);
377 return newNav;
378 }
379 if (actions_1.NAVIGATION_LOAD_PAGES.is(actions_1.__NAVIGATION_IDENTIFIER__, action)) {
380 var occurrence = persist_1.load();
381 var loadedActivePageMutex = persist_1.loadActivePage();
382 var instances = undefined;
383 var activePageMutex = undefined;
384 if (occurrence && occurrence.length > 0) {
385 instances = { pageOrder: [], pages: {} };
386 for (var _i = 0, occurrence_1 = occurrence; _i < occurrence_1.length; _i++) {
387 var instanceData = occurrence_1[_i];
388 if (this.pages.hasPage(instanceData.path)) {
389 var pageInstance = this.pages.buildInstance(instanceData);
390 if (pageInstance.mutex === loadedActivePageMutex) {
391 activePageMutex = loadedActivePageMutex;
392 }
393 instances.pageOrder.push(pageInstance.mutex);
394 instances.pages[pageInstance.mutex] = pageInstance;
395 }
396 }
397 }
398 if (instances && instances.pageOrder.length > 0) {
399 var newNav = new Navigator(this.pages);
400 newNav.instances = instances;
401 newNav.activePageMutex = activePageMutex;
402 newNav.activeChildren
403 = updateActiveChildren(instances, this.activeChildren, activePageMutex);
404 return newNav;
405 }
406 return this;
407 }
408 if (actions_1.NAVIGATION_CLEAR_PAGES.is(actions_1.__NAVIGATION_IDENTIFIER__, action)) {
409 persist_1.clear();
410 return new Navigator(this.pages);
411 }
412 var nextInstances = { pageOrder: this.instances.pageOrder, pages: {} };
413 var modified = false;
414 for (var _d = 0, _e = orderedPages(this.instances); _d < _e.length; _d++) {
415 var instance = _e[_d];
416 var newInstance = instance.reduce(action);
417 if (newInstance !== instance) {
418 modified = true;
419 }
420 nextInstances.pages[instance.mutex] = newInstance;
421 }
422 if (modified) {
423 var newNav = new Navigator(this.pages);
424 newNav.activePageMutex = this.activePageMutex;
425 newNav.instances = nextInstances;
426 newNav.activeChildren = this.activeChildren;
427 return newNav;
428 }
429 return this;
430 };
431 Navigator.prototype.transit = function (dispatch, mutex) {
432 dispatch(actions_1.NAVIGATION_TRANSIT_TO_PAGE.create.unicast(actions_1.__NAVIGATION_IDENTIFIER__, mutex));
433 };
434 Navigator.prototype.open = function (dispatch, occurrence) {
435 dispatch(actions_1.NAVIGATION_OPEN_PAGE.create.unicast(actions_1.__NAVIGATION_IDENTIFIER__, occurrence));
436 };
437 Navigator.prototype.replace = function (dispatch, toRemoveMutex, occurrence) {
438 dispatch(actions_1.NAVIGATION_REPLACE_PAGE.create.unicast(actions_1.__NAVIGATION_IDENTIFIER__, tslib_1.__assign({ toRemoveMutex: toRemoveMutex }, occurrence)));
439 };
440 Navigator.prototype.close = function (dispatch, mutex, goto) {
441 dispatch(actions_1.NAVIGATION_CLOSE_PAGE.create.unicast(actions_1.__NAVIGATION_IDENTIFIER__, { mutex: mutex, goto: goto }));
442 };
443 Navigator.prototype.load = function (dispatch) {
444 dispatch(actions_1.NAVIGATION_LOAD_PAGES.create.unicast(actions_1.__NAVIGATION_IDENTIFIER__));
445 };
446 Navigator.prototype.clear = function (dispatch) {
447 dispatch(actions_1.NAVIGATION_CLEAR_PAGES.create.unicast(actions_1.__NAVIGATION_IDENTIFIER__));
448 };
449 return Navigator;
450}());
451exports.Navigator = Navigator;
452//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigator.js","sourceRoot":"","sources":["../src/navigator.ts"],"names":[],"mappings":"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","sourcesContent":["import { Reducible, Action, Dispatch } from 'reducible-node';\r\nimport { keyBy } from 'lodash';\r\nimport { PageInstance } from './pageInstance';\r\nimport { Pages, PageOccurrence } from './pages';\r\nimport { load, clear, loadActivePage, save, saveActivePage } from './persist';\r\nimport {\r\n  __NAVIGATION_IDENTIFIER__,\r\n  NAVIGATION_TRANSIT_TO_PAGE,\r\n  NAVIGATION_OPEN_PAGE,\r\n  NAVIGATION_REPLACE_PAGE,\r\n  NAVIGATION_CLOSE_PAGE,\r\n  NAVIGATION_LOAD_PAGES,\r\n  NAVIGATION_CLEAR_PAGES,\r\n} from './actions';\r\n\r\nexport interface PageReplaceOptions extends PageOccurrence<any> {\r\n  toRemoveMutex: string;\r\n}\r\n\r\nexport interface PageOpenOptions extends PageOccurrence<any> {\r\n  insertAfterMutex?: string;\r\n}\r\n\r\nexport interface PageCloseOptions {\r\n  mutex: string;\r\n  goto?: string;\r\n}\r\n\r\ninterface InstanceMap {\r\n  [prop: string]: PageInstance<any, any>;\r\n}\r\n\r\ninterface Instances {\r\n  pageOrder: string[];\r\n  pages: InstanceMap;\r\n}\r\n\r\ninterface ActiveChildren {\r\n  [root: string]: string;\r\n}\r\n\r\nfunction orderedPages(instances: Instances): PageInstance<any, any>[] {\r\n  return instances.pageOrder.map(path => instances.pages[path]);\r\n}\r\n\r\nfunction cloneInstances(oldInstances: Instances): Instances {\r\n  return {\r\n    pageOrder: [...oldInstances.pageOrder],\r\n    pages: { ...oldInstances.pages },\r\n  };\r\n}\r\n\r\nfunction openPage(instances: Instances, options: PageOpenOptions, pages: Pages): Instances {\r\n  const newInstances = cloneInstances(instances);\r\n  const { insertAfterMutex, ...occurrence } = options;\r\n  const insertAfterIndex = insertAfterMutex ? newInstances.pageOrder.indexOf(insertAfterMutex) : -1;\r\n\r\n  if (occurrence.parent) {\r\n    if (occurrence.parent === occurrence.mutex) {\r\n      throw new Error(`${occurrence.mutex} cannot be child of itself.`);\r\n    }\r\n\r\n    if (!instances.pages[occurrence.parent]) {\r\n      throw new Error(`Parent of ${occurrence.mutex} is invalid.`);\r\n    }\r\n\r\n    if (\r\n      insertAfterIndex !== -1 &&\r\n      insertAfterIndex < instances.pageOrder.indexOf(occurrence.parent)\r\n    ) {\r\n      throw new Error(\r\n        `Cannot open ${occurrence.mutex}. Cannot be inserted before the parent.`,\r\n      );\r\n    }\r\n\r\n    if (instances.pages[occurrence.parent].parent) {\r\n      throw new Error(\r\n        `Cannot open ${occurrence.mutex}. Nesting more than one level is forbidden.`,\r\n      );\r\n    }\r\n  }\r\n\r\n  const newPage = pages.buildInstance(occurrence);\r\n\r\n  if (insertAfterIndex !== -1) {\r\n    newInstances.pageOrder.splice(insertAfterIndex + 1, 0, occurrence.mutex);\r\n  } else {\r\n    newInstances.pageOrder.push(occurrence.mutex);\r\n  }\r\n\r\n  newInstances.pages[occurrence.mutex] = newPage;\r\n\r\n  return newInstances;\r\n}\r\n\r\nfunction closePage(instances: Instances, toRemoveMutex: string): Instances {\r\n  const newPages = orderedPages(instances).filter(page => {\r\n    if (page.mutex === toRemoveMutex) {\r\n      return false;\r\n    }\r\n\r\n    return page.parent !== toRemoveMutex;\r\n  });\r\n\r\n  return {\r\n    pageOrder: newPages.map(page => page.mutex),\r\n    pages: keyBy(newPages, page => page.mutex),\r\n  };\r\n}\r\n\r\nfunction findClosePageTarget(\r\n  instances: Instances,\r\n  toRemoveMutex: string,\r\n  override?: string,\r\n): string | undefined {\r\n  if (instances.pageOrder.length < 2) {\r\n    return;\r\n  }\r\n\r\n  if (override && override !== toRemoveMutex && instances.pages[override]) {\r\n    return override;\r\n  }\r\n\r\n  const toRemove = instances.pages[toRemoveMutex];\r\n\r\n  if (!toRemove.parent) {\r\n    const roots = orderedPages(instances).filter(page => !page.parent).map(page => page.mutex);\r\n    const toRemoveRootIndex = roots.indexOf(toRemoveMutex);\r\n    return toRemoveRootIndex === 0 ? roots[1] : roots[toRemoveRootIndex - 1];\r\n  }\r\n\r\n  const parentChildren = orderedPages(instances)\r\n    .filter(page => page.parent === toRemove.parent)\r\n    .map(page => page.mutex);\r\n\r\n  if (parentChildren.length === 1) {\r\n    return toRemove.parent;\r\n  }\r\n\r\n  const toRemoveIndex = parentChildren.indexOf(toRemoveMutex);\r\n  return toRemoveIndex === 0 ? parentChildren[1] : parentChildren[toRemoveIndex - 1];\r\n}\r\n\r\nfunction replacePage(instances: Instances, options: PageReplaceOptions, pages: Pages): Instances {\r\n  const { toRemoveMutex, ...occurrence } = options;\r\n  const toInsertIndex = instances.pageOrder.indexOf(toRemoveMutex);\r\n\r\n  if (toInsertIndex === -1) {\r\n    return openPage(instances, occurrence, pages);\r\n  }\r\n\r\n  if (occurrence.parent !== instances.pages[toRemoveMutex].parent) {\r\n    throw new Error(\r\n      `Cannot open ${occurrence.mutex}. ` +\r\n      'The new page and the page to be removed must have the same parent.',\r\n    );\r\n  }\r\n\r\n  const newPage = pages.buildInstance(occurrence);\r\n  const newInstances = closePage(instances, toRemoveMutex);\r\n\r\n  newInstances.pageOrder.splice(toInsertIndex, 0, occurrence.mutex);\r\n  newInstances.pages[occurrence.mutex] = newPage;\r\n\r\n  return newInstances;\r\n}\r\n\r\nfunction cloneActiveChildren(instances: Instances, currentActives: ActiveChildren): ActiveChildren {\r\n  const newActives: ActiveChildren = {};\r\n  const roots = orderedPages(instances).filter(page => !page.parent).map(page => page.mutex);\r\n\r\n  for (const root of roots) {\r\n    if (currentActives[root] && instances.pages[currentActives[root]]) {\r\n      newActives[root] = currentActives[root];\r\n    }\r\n  }\r\n\r\n  return newActives;\r\n}\r\n\r\nfunction updateActiveChildren(\r\n  instances: Instances,\r\n  actives: ActiveChildren,\r\n  target?: string,\r\n): ActiveChildren {\r\n  const newActives = cloneActiveChildren(instances, actives);\r\n\r\n  if (!target) {\r\n    return newActives;\r\n  }\r\n\r\n  const targetPage = instances.pages[target];\r\n\r\n  // target is root\r\n  if (targetPage && !targetPage.parent) {\r\n    if (!newActives[target]) {\r\n      return newActives;\r\n    }\r\n    delete newActives[target];\r\n    return newActives;\r\n  }\r\n\r\n  const root = targetPage && targetPage.parent;\r\n\r\n  if (!root) {\r\n    return newActives;\r\n  }\r\n\r\n  return { ...newActives, [root]: target };\r\n}\r\n\r\nfunction getTransitionTarget(\r\n  instances: Instances,\r\n  actives: ActiveChildren,\r\n  currentActive: string | undefined,\r\n  desiredTarget: string,\r\n): string {\r\n  const desiredTargetPage = instances.pages[desiredTarget];\r\n  const currentPage = currentActive && instances.pages[currentActive];\r\n\r\n  // non-root\r\n  if (desiredTargetPage && desiredTargetPage.parent) {\r\n    return desiredTarget;\r\n  }\r\n\r\n  // transiting to own root\r\n  if (currentPage && desiredTarget === currentPage.parent) {\r\n    return desiredTarget;\r\n  }\r\n\r\n  if (actives[desiredTarget] && instances.pages[actives[desiredTarget]]) {\r\n    return actives[desiredTarget];\r\n  }\r\n\r\n  return desiredTarget;\r\n}\r\n\r\nexport class Navigator implements Reducible<Navigator> {\r\n  private pages: Pages;\r\n  private instances: Instances = { pageOrder: [], pages: {} };\r\n  private activePageMutex: string | undefined;\r\n  private activeChildren: ActiveChildren = {};\r\n\r\n  constructor(pages: Pages) {\r\n    this.pages = pages;\r\n  }\r\n\r\n  public get all(): PageInstance<any, any>[] {\r\n    return orderedPages(this.instances);\r\n  }\r\n\r\n  public get roots(): PageInstance<any, any>[] {\r\n    return this.all.filter(page => !page.parent);\r\n  }\r\n\r\n  public get active(): PageInstance<any, any> | undefined {\r\n    if (!this.activePageMutex) {\r\n      return;\r\n    }\r\n    return this.instances.pages[this.activePageMutex];\r\n  }\r\n\r\n  public get activeMutex(): string | undefined {\r\n    return this.activePageMutex;\r\n  }\r\n\r\n  public get activeRootMutex(): string | undefined {\r\n    if (!this.activePageMutex || !this.instances.pages[this.activePageMutex]) {\r\n      return;\r\n    }\r\n\r\n    if (this.instances.pages[this.activePageMutex].parent) {\r\n      return this.instances.pages[this.activePageMutex].parent;\r\n    }\r\n\r\n    return this.activePageMutex;\r\n  }\r\n\r\n  public get activeRoot(): PageInstance<any, any> | undefined {\r\n    const mutex = this.activeRootMutex;\r\n    if (!mutex) {\r\n      return;\r\n    }\r\n\r\n    return this.instances.pages[mutex];\r\n  }\r\n\r\n  public get activeRootIndex(): number {\r\n    if (!this.activePageMutex || !this.instances.pages[this.activePageMutex]) {\r\n      return -1;\r\n    }\r\n\r\n    const parentMutex = this.instances.pages[this.activePageMutex].parent;\r\n\r\n    if (!parentMutex) {\r\n      return this.roots.map(page => page.mutex).indexOf(this.activePageMutex);\r\n    }\r\n\r\n    return this.roots.map(page => page.mutex).indexOf(parentMutex);\r\n  }\r\n\r\n  public get indexAsChildOfActiveRoot(): number {\r\n    if (!this.activePageMutex || !this.instances.pages[this.activePageMutex]) {\r\n      return -1;\r\n    }\r\n\r\n    const parentMutex = this.instances.pages[this.activePageMutex].parent;\r\n\r\n    if (!parentMutex) {\r\n      return -1;\r\n    }\r\n\r\n    return this.childrenOf(parentMutex).map(page => page.mutex).indexOf(this.activePageMutex);\r\n  }\r\n\r\n  public hasChildren(mutex: string): boolean {\r\n    return this.all.some(page => page.parent === mutex);\r\n  }\r\n\r\n  public childrenOf(mutex: string): PageInstance<any, any>[] {\r\n    return this.all.filter(page => page.parent === mutex);\r\n  }\r\n\r\n  public pageFromMutex(mutex: string | undefined): PageInstance<any, any> | undefined {\r\n    return typeof mutex === 'string' ? this.instances.pages[mutex] : undefined;\r\n  }\r\n\r\n  public getActiveChild(mutex: string | undefined): string | undefined {\r\n    return mutex ? this.activeChildren[mutex] : undefined;\r\n  }\r\n\r\n  private persistInstances(instances: Instances): void {\r\n    const toSave: PageOccurrence<any>[] = [];\r\n\r\n    for (const instance of orderedPages(instances)) {\r\n      if (instance.page.persistent !== false) {\r\n        if (instance.parent) {\r\n          if (instances.pages[instance.parent].page.persistent !== false) {\r\n            toSave.push(instance.occurrence);\r\n          }\r\n        } else {\r\n          toSave.push(instance.occurrence);\r\n        }\r\n      }\r\n    }\r\n\r\n    save(toSave);\r\n  }\r\n\r\n  private persistActivePage(instances: Instances, mutex: string | undefined): void {\r\n    if (!mutex) {\r\n      saveActivePage(undefined);\r\n      return;\r\n    }\r\n\r\n    if (instances.pages[mutex].page.persistent !== false) {\r\n      const parentMutex = instances.pages[mutex].parent;\r\n\r\n      if (parentMutex) {\r\n        const parent = instances.pages[parentMutex];\r\n\r\n        if (parent.page.persistent !== false) {\r\n          saveActivePage(mutex);\r\n        }\r\n      } else {\r\n        saveActivePage(mutex);\r\n      }\r\n    }\r\n  }\r\n\r\n  public reduce(action: Action<any>): this {\r\n    if (NAVIGATION_TRANSIT_TO_PAGE.is(__NAVIGATION_IDENTIFIER__, action)) {\r\n      if (action.payload === this.activePageMutex) {\r\n        return this;\r\n      }\r\n\r\n      if (!action.payload) {\r\n        this.persistActivePage(this.instances, undefined);\r\n        const newNavWithoutActive = <this>new Navigator(this.pages);\r\n        newNavWithoutActive.instances = this.instances;\r\n        newNavWithoutActive.activeChildren = this.activeChildren;\r\n        return newNavWithoutActive;\r\n      }\r\n\r\n      if (!this.instances.pages[action.payload]) {\r\n        return this;\r\n      }\r\n\r\n      const transitionTarget = getTransitionTarget(\r\n        this.instances,\r\n        this.activeChildren,\r\n        this.activePageMutex,\r\n        action.payload,\r\n      );\r\n\r\n      this.persistActivePage(this.instances, transitionTarget);\r\n\r\n      const newNav = <this>new Navigator(this.pages);\r\n      newNav.instances = this.instances;\r\n      newNav.activePageMutex = transitionTarget;\r\n      newNav.activeChildren\r\n        = updateActiveChildren(this.instances, this.activeChildren, transitionTarget);\r\n      return newNav;\r\n    }\r\n\r\n    if (NAVIGATION_OPEN_PAGE.is(__NAVIGATION_IDENTIFIER__, action)) {\r\n      if (!action.payload || action.payload.mutex === this.activePageMutex) {\r\n        return this;\r\n      }\r\n\r\n      const { mutex, path } = action.payload;\r\n\r\n      if (this.instances.pages[mutex]) {\r\n\r\n        this.persistActivePage(this.instances, mutex);\r\n\r\n        const newNav = <this>new Navigator(this.pages);\r\n        newNav.instances = this.instances;\r\n        newNav.activePageMutex = mutex;\r\n        newNav.activeChildren = updateActiveChildren(this.instances, this.activeChildren, mutex);\r\n        return newNav;\r\n      }\r\n\r\n      if (this.pages.hasPage(path)) {\r\n        const newInstances = openPage(this.instances, action.payload, this.pages);\r\n\r\n        this.persistInstances(newInstances);\r\n        this.persistActivePage(newInstances, mutex);\r\n\r\n        const newNav = <this>new Navigator(this.pages);\r\n        newNav.instances = newInstances;\r\n        newNav.activePageMutex = mutex;\r\n        newNav.activeChildren = updateActiveChildren(newInstances, this.activeChildren, mutex);\r\n        return newNav;\r\n      }\r\n      return this;\r\n    }\r\n\r\n    if (NAVIGATION_REPLACE_PAGE.is(__NAVIGATION_IDENTIFIER__, action)) {\r\n      if (!action.payload) {\r\n        return this;\r\n      }\r\n\r\n      const { mutex, path } = action.payload;\r\n\r\n      if (this.instances.pages[mutex]) {\r\n\r\n        this.persistActivePage(this.instances, mutex);\r\n\r\n        const newNav = <this>new Navigator(this.pages);\r\n        newNav.instances = this.instances;\r\n        newNav.activePageMutex = mutex;\r\n        newNav.activeChildren = updateActiveChildren(this.instances, this.activeChildren, mutex);\r\n        return newNav;\r\n      }\r\n\r\n      if (this.pages.hasPage(path)) {\r\n        const newInstances = replacePage(this.instances, action.payload, this.pages);\r\n\r\n        this.persistInstances(newInstances);\r\n        this.persistActivePage(newInstances, mutex);\r\n\r\n        const newNav = <this>new Navigator(this.pages);\r\n        newNav.instances = newInstances;\r\n        newNav.activePageMutex = mutex;\r\n        newNav.activeChildren = updateActiveChildren(newInstances, this.activeChildren, mutex);\r\n        return newNav;\r\n      }\r\n      return this;\r\n    }\r\n\r\n    if (NAVIGATION_CLOSE_PAGE.is(__NAVIGATION_IDENTIFIER__, action)) {\r\n      if (!action.payload) {\r\n        return this;\r\n      }\r\n\r\n      const { mutex, goto } = action.payload;\r\n\r\n      if (!this.instances.pages[mutex]) {\r\n        return this;\r\n      }\r\n\r\n      const newNav = <this>new Navigator(this.pages);\r\n      newNav.activePageMutex = this.activePageMutex;\r\n      const newInstances = closePage(this.instances, mutex);\r\n\r\n      const isParentOfActive = this.activePageMutex &&\r\n        this.instances.pages[this.activePageMutex].parent === mutex;\r\n\r\n      if (this.activePageMutex === mutex || isParentOfActive) {\r\n        const targetMutex = findClosePageTarget(\r\n          this.instances,\r\n          isParentOfActive ? this.instances.pages[this.activePageMutex!].parent! : mutex,\r\n          goto,\r\n        );\r\n\r\n        const transitionTarget = targetMutex && getTransitionTarget(\r\n          newInstances,\r\n          this.activeChildren,\r\n          this.activePageMutex,\r\n          targetMutex,\r\n        );\r\n\r\n        this.persistActivePage(this.instances, undefined);\r\n        this.persistActivePage(this.instances, transitionTarget);\r\n\r\n        newNav.activePageMutex = transitionTarget;\r\n      }\r\n\r\n      this.persistInstances(newInstances);\r\n\r\n      newNav.instances = newInstances;\r\n      newNav.activeChildren\r\n        = updateActiveChildren(newInstances, this.activeChildren, newNav.activePageMutex);\r\n      return newNav;\r\n    }\r\n\r\n    if (NAVIGATION_LOAD_PAGES.is(__NAVIGATION_IDENTIFIER__, action)) {\r\n\r\n      const occurrence = load();\r\n      const loadedActivePageMutex = loadActivePage();\r\n\r\n      let instances: Instances | undefined = undefined;\r\n      let activePageMutex: string | undefined = undefined;\r\n\r\n      if (occurrence && occurrence.length > 0) {\r\n        instances = { pageOrder: [], pages: {} };\r\n\r\n        for (const instanceData of occurrence) {\r\n          if (this.pages.hasPage(instanceData.path)) {\r\n            const pageInstance = this.pages.buildInstance(instanceData);\r\n\r\n            if (pageInstance.mutex === loadedActivePageMutex) {\r\n              activePageMutex = loadedActivePageMutex;\r\n            }\r\n\r\n            instances.pageOrder.push(pageInstance.mutex);\r\n            instances.pages[pageInstance.mutex] = pageInstance;\r\n          }\r\n        }\r\n      }\r\n\r\n      if (instances && instances.pageOrder.length > 0) {\r\n        const newNav = <this>new Navigator(this.pages);\r\n        newNav.instances = instances;\r\n        newNav.activePageMutex = activePageMutex;\r\n        newNav.activeChildren\r\n          = updateActiveChildren(instances, this.activeChildren, activePageMutex);\r\n        return newNav;\r\n      }\r\n      return this;\r\n    }\r\n\r\n    if (NAVIGATION_CLEAR_PAGES.is(__NAVIGATION_IDENTIFIER__, action)) {\r\n      clear();\r\n      return <this>new Navigator(this.pages);\r\n    }\r\n\r\n    const nextInstances: Instances = { pageOrder: this.instances.pageOrder, pages: {} };\r\n    let modified = false;\r\n\r\n    for (const instance of orderedPages(this.instances)) {\r\n      const newInstance = instance.reduce(action);\r\n      if (newInstance !== instance) {\r\n        modified = true;\r\n      }\r\n      nextInstances.pages[instance.mutex] = newInstance;\r\n    }\r\n\r\n    if (modified) {\r\n      const newNav = <this>new Navigator(this.pages);\r\n      newNav.activePageMutex = this.activePageMutex;\r\n      newNav.instances = nextInstances;\r\n      newNav.activeChildren = this.activeChildren;\r\n      return newNav;\r\n    }\r\n    return this;\r\n  }\r\n\r\n  public transit(dispatch: Dispatch, mutex: string | undefined) {\r\n    dispatch(NAVIGATION_TRANSIT_TO_PAGE.create.unicast(__NAVIGATION_IDENTIFIER__, mutex));\r\n  }\r\n\r\n  public open(dispatch: Dispatch, occurrence: PageOpenOptions) {\r\n    dispatch(NAVIGATION_OPEN_PAGE.create.unicast(__NAVIGATION_IDENTIFIER__, occurrence));\r\n  }\r\n\r\n  public replace(\r\n    dispatch: Dispatch,\r\n    toRemoveMutex: string,\r\n    occurrence: PageOccurrence<any>,\r\n  ) {\r\n    dispatch(NAVIGATION_REPLACE_PAGE.create.unicast(\r\n      __NAVIGATION_IDENTIFIER__,\r\n      { toRemoveMutex, ...occurrence },\r\n    ));\r\n  }\r\n\r\n  public close(dispatch: Dispatch, mutex: string, goto?: string) {\r\n    dispatch(NAVIGATION_CLOSE_PAGE.create.unicast(__NAVIGATION_IDENTIFIER__, { mutex, goto }));\r\n  }\r\n\r\n  public load(dispatch: Dispatch) {\r\n    dispatch(NAVIGATION_LOAD_PAGES.create.unicast(__NAVIGATION_IDENTIFIER__));\r\n  }\r\n\r\n  public clear(dispatch: Dispatch) {\r\n    dispatch(NAVIGATION_CLEAR_PAGES.create.unicast(__NAVIGATION_IDENTIFIER__));\r\n  }\r\n}\r\n"]}
\No newline at end of file