highmark-cli 0.0.138 → 0.0.140

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/bin/action/publish.js +2 -0
  2. package/bin/constants.js +6 -2
  3. package/bin/handler/liveReload.js +18 -0
  4. package/bin/importer.js +7 -4
  5. package/bin/operation/copyCheckmark.js +32 -0
  6. package/bin/operation/copyClient.js +5 -5
  7. package/bin/operation/markdownHTML.js +31 -9
  8. package/bin/operation/markdownStylesCSS.js +17 -10
  9. package/bin/operation/server.js +7 -10
  10. package/bin/router/static.js +17 -0
  11. package/checkmark.svg +12 -0
  12. package/client.js +6126 -1527
  13. package/css/loading.css +32 -32
  14. package/lib/client.js +48 -6
  15. package/lib/constants.js +28 -12
  16. package/lib/createMethods.js +64 -0
  17. package/lib/customEventTypes.js +9 -1
  18. package/lib/eventTypes.js +5 -1
  19. package/lib/localStorage.js +56 -0
  20. package/lib/mixins/fullsrean.js +63 -0
  21. package/lib/mixins/touch.js +101 -32
  22. package/lib/selectors.js +5 -9
  23. package/lib/state.js +133 -0
  24. package/lib/styles.js +78 -0
  25. package/lib/utilities/element.js +11 -11
  26. package/lib/utilities/fullScreen.js +16 -0
  27. package/lib/utilities/orientation.js +39 -0
  28. package/lib/view/button/closeMenu.js +121 -0
  29. package/lib/view/button/fullScreen.js +121 -0
  30. package/lib/view/button/zoomMenuIn.js +121 -0
  31. package/lib/view/button/zoomMenuOut.js +121 -0
  32. package/lib/view/button.js +160 -0
  33. package/lib/view/checkbox.js +193 -0
  34. package/lib/view/div/buttons.js +215 -0
  35. package/lib/view/div/checkbox/invertColours.js +151 -0
  36. package/lib/view/div/checkbox/restoreNativeGestures.js +147 -0
  37. package/lib/view/div/checkbox.js +220 -0
  38. package/lib/view/div/checkboxes.js +211 -0
  39. package/lib/view/div/menu.js +122 -28
  40. package/lib/view/div/overlay.js +639 -0
  41. package/lib/view/div/preloader.js +204 -0
  42. package/lib/view/{div/leaf.js → div.js} +21 -32
  43. package/lib/view/element.js +164 -0
  44. package/lib/view/span.js +182 -0
  45. package/lib/view/svg/closeMenu.js +138 -0
  46. package/lib/view/svg/fullScreen.js +138 -0
  47. package/lib/view/svg/zoomMenuIn.js +146 -0
  48. package/lib/view/svg/zoomMenuOut.js +141 -0
  49. package/lib/view/svg.js +184 -0
  50. package/lib/view.js +23 -396
  51. package/package.json +3 -2
  52. package/src/client.js +34 -8
  53. package/src/constants.js +7 -3
  54. package/src/createMethods.js +66 -0
  55. package/src/customEventTypes.js +2 -0
  56. package/src/eventTypes.js +1 -0
  57. package/src/localStorage.js +48 -0
  58. package/src/mixins/fullsrean.js +75 -0
  59. package/src/mixins/touch.js +98 -39
  60. package/src/selectors.js +1 -2
  61. package/src/state.js +130 -0
  62. package/src/styles.js +18 -0
  63. package/src/utilities/element.js +18 -15
  64. package/src/utilities/fullScreen.js +8 -0
  65. package/src/utilities/orientation.js +34 -0
  66. package/src/view/button/closeMenu.js +16 -0
  67. package/src/view/button/fullScreen.js +16 -0
  68. package/src/view/button/zoomMenuIn.js +16 -0
  69. package/src/view/button/zoomMenuOut.js +16 -0
  70. package/src/view/button.js +38 -0
  71. package/src/view/checkbox.js +68 -0
  72. package/src/view/div/buttons.js +39 -0
  73. package/src/view/div/checkbox/invertColours.js +33 -0
  74. package/src/view/div/checkbox/restoreNativeGestures.js +29 -0
  75. package/src/view/div/checkbox.js +45 -0
  76. package/src/view/div/checkboxes.js +36 -0
  77. package/src/view/div/menu.js +83 -26
  78. package/src/view/div/overlay.js +547 -0
  79. package/src/view/div/preloader.js +25 -0
  80. package/src/view/{div/leaf.js → div.js} +13 -21
  81. package/src/view/element.js +16 -0
  82. package/src/view/span.js +22 -0
  83. package/src/view/svg/closeMenu.js +19 -0
  84. package/src/view/svg/fullScreen.js +19 -0
  85. package/src/view/svg/zoomMenuIn.js +20 -0
  86. package/src/view/svg/zoomMenuOut.js +19 -0
  87. package/src/view/svg.js +24 -0
  88. package/src/view.js +20 -482
  89. package/lib/style.js +0 -13
  90. package/lib/utilities/tree.js +0 -55
  91. package/src/style.js +0 -3
  92. package/src/utilities/tree.js +0 -29
package/lib/view.js CHANGED
@@ -9,15 +9,10 @@ Object.defineProperty(exports, "default", {
9
9
  }
10
10
  });
11
11
  var _easywithstyle = /*#__PURE__*/ _interop_require_default(require("easy-with-style"));
12
- var _necessary = require("necessary");
13
- var _easy = require("easy");
14
- var _leaf = /*#__PURE__*/ _interop_require_default(require("./view/div/leaf"));
12
+ var _element = /*#__PURE__*/ _interop_require_default(require("./view/element"));
15
13
  var _menu = /*#__PURE__*/ _interop_require_default(require("./view/div/menu"));
16
- var _touch = /*#__PURE__*/ _interop_require_default(require("./mixins/touch"));
17
- var _tree = require("./utilities/tree");
18
- var _element = require("./utilities/element");
19
- var _selectors = require("./selectors");
20
- var _constants = require("./constants");
14
+ var _overlay = /*#__PURE__*/ _interop_require_default(require("./view/div/overlay"));
15
+ var _preloader = /*#__PURE__*/ _interop_require_default(require("./view/div/preloader"));
21
16
  function _assert_this_initialized(self) {
22
17
  if (self === void 0) {
23
18
  throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
@@ -179,426 +174,58 @@ function _create_super(Derived) {
179
174
  }
180
175
  function _templateObject() {
181
176
  var data = _tagged_template_literal([
182
- "\n\n width: 100%;\n height: 100%;\n overflow: hidden;\n touch-action: none;\n \n .native-gestures {\n touch-action: auto;\n }\n \n"
177
+ "\n\n width: 100%;\n height: 100%;\n align-items: stretch;\n flex-direction: column;\n \n"
183
178
  ]);
184
179
  _templateObject = function _templateObject() {
185
180
  return data;
186
181
  };
187
182
  return data;
188
183
  }
189
- var ENTER_KEY_CODE = _necessary.keyCodes.ENTER_KEY_CODE, ESCAPE_KEY_CODE = _necessary.keyCodes.ESCAPE_KEY_CODE, BACKSPACE_KEY_CODE = _necessary.keyCodes.BACKSPACE_KEY_CODE, ARROW_UP_KEY_CODE = _necessary.keyCodes.ARROW_UP_KEY_CODE, ARROW_DOWN_KEY_CODE = _necessary.keyCodes.ARROW_DOWN_KEY_CODE, ARROW_LEFT_KEY_CODE = _necessary.keyCodes.ARROW_LEFT_KEY_CODE, ARROW_RIGHT_KEY_CODE = _necessary.keyCodes.ARROW_RIGHT_KEY_CODE;
190
184
  var View = /*#__PURE__*/ function(Element) {
191
185
  _inherits(View, Element);
192
186
  var _super = _create_super(View);
193
187
  function View() {
194
188
  _class_call_check(this, View);
195
- var _this;
196
- _this = _super.apply(this, arguments);
197
- _define_property(_assert_this_initialized(_this), "doubleTapCustomHandler", function(event, element) {
198
- _this.enableNativeGestures();
199
- });
200
- _define_property(_assert_this_initialized(_this), "pinchStartCustomHandler", function(event, element) {
201
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
202
- if (nativeGesturesEnabled) {
203
- return;
204
- }
205
- var zoom = _this.getZoom(), startZoom = zoom; ///
206
- _this.setStartZoom(startZoom);
207
- });
208
- _define_property(_assert_this_initialized(_this), "pinchMoveCustomHandler", function(event, element, ratio) {
209
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
210
- if (nativeGesturesEnabled) {
211
- return;
212
- }
213
- var startZoom = _this.getStartZoom(), zoom = startZoom * Math.sqrt(ratio);
214
- _this.setZoom(zoom);
215
- _this.zoom(zoom);
216
- });
217
- _define_property(_assert_this_initialized(_this), "swipeRightCustomHandler", function(event, element) {
218
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
219
- if (nativeGesturesEnabled) {
220
- return;
221
- }
222
- _this.showLeftLeafDiv();
223
- });
224
- _define_property(_assert_this_initialized(_this), "swipeLeftCustomHandler", function(event, element) {
225
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
226
- if (nativeGesturesEnabled) {
227
- return;
228
- }
229
- _this.showRightLeftDiv();
230
- });
231
- _define_property(_assert_this_initialized(_this), "swipeDownCustomHandler", function(event, element, top, left, speed) {
232
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
233
- if (nativeGesturesEnabled) {
234
- return;
235
- }
236
- var direction = _constants.DOWN_DIRECTION;
237
- _this.scroll(speed, direction);
238
- });
239
- _define_property(_assert_this_initialized(_this), "swipeUpCustomHandler", function(event, element, top, left, speed) {
240
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
241
- if (nativeGesturesEnabled) {
242
- return;
243
- }
244
- var height = _this.getHeight(), bottom = height - top;
245
- if (bottom < _constants.MENU_DIV_SWIPE_BOTTOM) {
246
- _this.showMenuDiv();
247
- return;
248
- }
249
- var direction = _constants.UP_DIRECTION;
250
- _this.scroll(speed, direction);
251
- });
252
- _define_property(_assert_this_initialized(_this), "dragStartCustomHandler", function(event, element) {
253
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
254
- if (nativeGesturesEnabled) {
255
- return;
256
- }
257
- var scrollTop = _this.getScrollTop(), startScrollTop = scrollTop; ///
258
- _this.setStartScrollTop(startScrollTop);
259
- });
260
- _define_property(_assert_this_initialized(_this), "dragDownCustomHandler", function(event, element, top, left) {
261
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
262
- if (nativeGesturesEnabled) {
263
- return;
264
- }
265
- var startScrollTop = _this.getStartScrollTop(), scrollTop = startScrollTop - top;
266
- _this.setScrollTop(scrollTop);
267
- });
268
- _define_property(_assert_this_initialized(_this), "dragUpCustomHandler", function(event, element, top, left) {
269
- var nativeGesturesEnabled = _this.areNativeGesturesEnabled();
270
- if (nativeGesturesEnabled) {
271
- return;
272
- }
273
- var startScrollTop = _this.getStartScrollTop(), scrollTop = startScrollTop - top;
274
- _this.setScrollTop(scrollTop);
275
- });
276
- _define_property(_assert_this_initialized(_this), "tapCustomHandler", function(event, element) {
277
- alert("view tap...");
278
- _this.disableNativeGestures();
279
- });
280
- _define_property(_assert_this_initialized(_this), "keyDownHandler", function(event, element) {
281
- var keyCode = event.keyCode;
282
- switch(keyCode){
283
- case ENTER_KEY_CODE:
284
- case ARROW_RIGHT_KEY_CODE:
285
- {
286
- _this.showRightLeftDiv();
287
- break;
288
- }
289
- case BACKSPACE_KEY_CODE:
290
- case ARROW_LEFT_KEY_CODE:
291
- {
292
- _this.showLeftLeafDiv();
293
- break;
294
- }
295
- case ESCAPE_KEY_CODE:
296
- {
297
- break;
298
- }
299
- case ARROW_UP_KEY_CODE:
300
- {
301
- _this.showFirstLeftDiv();
302
- break;
303
- }
304
- case ARROW_DOWN_KEY_CODE:
305
- {
306
- _this.showLastLeafDiv();
307
- break;
308
- }
309
- }
310
- });
311
- return _this;
189
+ return _super.apply(this, arguments);
312
190
  }
313
191
  _create_class(View, [
314
192
  {
315
- key: "zoomOut",
316
- value: function zoomOut() {
317
- var zoom = this.getZoom();
318
- zoom /= _constants.ZOOM_RATIO;
319
- this.setZoom(zoom);
320
- this.zoom(zoom);
321
- }
322
- },
323
- {
324
- key: "zoomIn",
325
- value: function zoomIn() {
326
- var zoom = this.getZoom();
327
- zoom *= _constants.ZOOM_RATIO;
328
- this.setZoom(zoom);
329
- this.zoom(zoom);
330
- }
331
- },
332
- {
333
- key: "zoom",
334
- value: function zoom(zoom) {
335
- var displayedLeafDiv = this.findDisplayedLeafDiv();
336
- displayedLeafDiv.zoom(zoom);
337
- }
338
- },
339
- {
340
- key: "scroll",
341
- value: function scroll(speed, direction) {
342
- var _this = this;
343
- var scrollTop = this.getScrollTop();
344
- scrollTop += speed * _constants.SCROLL_DELAY;
345
- this.setScrollTop(scrollTop);
346
- var interval = this.getInterval();
347
- if (interval !== null) {
348
- clearInterval(interval);
349
- }
350
- interval = setInterval(function() {
351
- speed = speed - direction * _constants.DECELERATION;
352
- if (speed * direction < 0) {
353
- clearInterval(interval);
354
- interval = null;
355
- _this.setInterval(interval);
356
- }
357
- var scrollTop = _this.getScrollTop();
358
- scrollTop += speed * _constants.SCROLL_DELAY;
359
- _this.setScrollTop(scrollTop);
360
- }, _constants.SCROLL_DELAY);
361
- this.setInterval(interval);
362
- }
363
- },
364
- {
365
- key: "showFirstLeftDiv",
366
- value: function showFirstLeftDiv() {
367
- var displayedLeafDiv = this.findDisplayedLeafDiv(), leafDivs = this.getLeafDivs(), index = leafDivs.indexOf(displayedLeafDiv), nextIndex = 0, previousIndex = index; ///
368
- this.showNextLeafDiv(nextIndex, previousIndex);
369
- }
370
- },
371
- {
372
- key: "showLeftLeafDiv",
373
- value: function showLeftLeafDiv() {
374
- var displayedLeafDiv = this.findDisplayedLeafDiv(), leafDivs = this.getLeafDivs(), index = leafDivs.indexOf(displayedLeafDiv), nextIndex = index - 1, previousIndex = index; ///
375
- this.showNextLeafDiv(nextIndex, previousIndex);
376
- }
377
- },
378
- {
379
- key: "showRightLeftDiv",
380
- value: function showRightLeftDiv() {
381
- var displayedLeafDiv = this.findDisplayedLeafDiv(), leafDivs = this.getLeafDivs(), index = leafDivs.indexOf(displayedLeafDiv), nextIndex = index + 1, previousIndex = index; ///
382
- this.showNextLeafDiv(nextIndex, previousIndex);
383
- }
384
- },
385
- {
386
- key: "showLastLeafDiv",
387
- value: function showLastLeafDiv() {
388
- var displayedLeafDiv = this.findDisplayedLeafDiv(), leafDivs = this.getLeafDivs(), index = leafDivs.indexOf(displayedLeafDiv), leafDivsLength = leafDivs.length, nextIndex = leafDivsLength - 1, previousIndex = index; ///
389
- this.showNextLeafDiv(nextIndex, previousIndex);
390
- }
391
- },
392
- {
393
- key: "showNextLeafDiv",
394
- value: function showNextLeafDiv(nextIndex, previousIndex) {
395
- var leafDivs = this.getLeafDivs(), leafDivsLength = leafDivs.length, previousLeafDiv = leafDivs[previousIndex];
396
- if (nextIndex === -1 || nextIndex === previousIndex || nextIndex === leafDivsLength) {
397
- return;
398
- }
399
- previousLeafDiv.hide();
400
- var nextLeafDiv = leafDivs[nextIndex], zoom = this.getZoom();
401
- nextLeafDiv.zoom(zoom);
402
- setTimeout(function() {
403
- var scrollTop = 0;
404
- nextLeafDiv.setScrollTop(scrollTop);
405
- nextLeafDiv.show();
406
- }, _constants.SHOW_DELAY);
407
- }
408
- },
409
- {
410
- key: "enableNativeGestures",
411
- value: function enableNativeGestures() {
412
- this.addClass("native-gestures");
413
- }
414
- },
415
- {
416
- key: "disableNativeGestures",
417
- value: function disableNativeGestures() {
418
- this.removeClass("native-gestures");
419
- }
420
- },
421
- {
422
- key: "forEachLeafDiv",
423
- value: function forEachLeafDiv(callback) {
424
- var leafDivs = this.getLeafDivs();
425
- leafDivs.forEach(callback);
426
- }
427
- },
428
- {
429
- key: "findDisplayedLeafDiv",
430
- value: function findDisplayedLeafDiv() {
431
- var leafDivs = this.getLeafDivs(), displayedLeafDiv = leafDivs.find(function(leafDiv) {
432
- var displayed = leafDiv.isDisplayed();
433
- if (displayed) {
434
- return true;
435
- }
436
- });
437
- return displayedLeafDiv;
438
- }
439
- },
440
- {
441
- key: "retrieveLeafDivs",
442
- value: function retrieveLeafDivs() {
443
- var viewChildDivDOMElementNodeList = document.querySelectorAll(_selectors.VIEW_CHILD_DIVS_SELECTOR), viewChildDivDOMElements = (0, _tree.leafNodesFromNodeList)(viewChildDivDOMElementNodeList), leafDivs = (0, _element.elementsFromDOMElements)(viewChildDivDOMElements, _leaf.default);
444
- return leafDivs;
445
- }
446
- },
447
- {
448
- key: "getZoom",
449
- value: function getZoom() {
450
- var zoom = this.getState().zoom;
451
- return zoom;
452
- }
453
- },
454
- {
455
- key: "setZoom",
456
- value: function setZoom(zoom) {
457
- this.updateState({
458
- zoom: zoom
459
- });
460
- }
461
- },
462
- {
463
- key: "getLeafDivs",
464
- value: function getLeafDivs() {
465
- var leafDivs = this.getState().leafDivs;
466
- return leafDivs;
467
- }
468
- },
469
- {
470
- key: "setLeftDivs",
471
- value: function setLeftDivs(leafDivs) {
472
- this.updateState({
473
- leafDivs: leafDivs
474
- });
475
- }
476
- },
477
- {
478
- key: "getInterval",
479
- value: function getInterval() {
480
- var interval = this.getState().interval;
481
- return interval;
482
- }
483
- },
484
- {
485
- key: "setInterval",
486
- value: function setInterval1(interval) {
487
- this.updateState({
488
- interval: interval
489
- });
490
- }
491
- },
492
- {
493
- key: "getStartZoom",
494
- value: function getStartZoom() {
495
- var startZoom = this.getState().startZoom;
496
- return startZoom;
497
- }
498
- },
499
- {
500
- key: "setStartZoom",
501
- value: function setStartZoom(startZoom) {
502
- this.updateState({
503
- startZoom: startZoom
504
- });
505
- }
506
- },
507
- {
508
- key: "getStartScrollTop",
509
- value: function getStartScrollTop() {
510
- var startScrollTop = this.getState().startScrollTop;
511
- return startScrollTop;
512
- }
513
- },
514
- {
515
- key: "setStartScrollTop",
516
- value: function setStartScrollTop(startScrollTop) {
517
- this.updateState({
518
- startScrollTop: startScrollTop
519
- });
520
- }
521
- },
522
- {
523
- key: "areNativeGesturesEnabled",
524
- value: function areNativeGesturesEnabled() {
525
- var nativeGesturesEnabled = this.hasClass("native-gestures");
526
- return nativeGesturesEnabled;
527
- }
528
- },
529
- {
530
- key: "setInitialState",
531
- value: function setInitialState() {
532
- var zoom = 1, leafDivs = this.retrieveLeafDivs(), interval = null, startZoom = null, startScrollTop = null;
533
- this.setState({
534
- zoom: zoom,
535
- leafDivs: leafDivs,
536
- interval: interval,
537
- startZoom: startZoom,
538
- startScrollTop: startScrollTop
539
- });
540
- }
541
- },
542
- {
543
- key: "didMount",
544
- value: function didMount() {
545
- this.enableTouch();
546
- this.onCustomTap(this.tapCustomHandler);
547
- this.onCustomDragUp(this.dragUpCustomHandler);
548
- this.onCustomDragDown(this.dragDownCustomHandler);
549
- this.onCustomDragStart(this.dragStartCustomHandler);
550
- this.onCustomSwipeUp(this.swipeUpCustomHandler);
551
- this.onCustomSwipeDown(this.swipeDownCustomHandler);
552
- this.onCustomSwipeLeft(this.swipeLeftCustomHandler);
553
- this.onCustomSwipeRight(this.swipeRightCustomHandler);
554
- this.onCustomPinchMove(this.pinchMoveCustomHandler);
555
- this.onCustomPinchStart(this.pinchStartCustomHandler);
556
- this.onCustomDoubleTap(this.doubleTapCustomHandler);
557
- _easy.window.onKeyDown(this.keyDownHandler);
558
- }
559
- },
560
- {
561
- key: "willUnmount",
562
- value: function willUnmount() {
563
- this.offCustomTap(this.tapCustomHandler);
564
- this.offCustomDragUp(this.dragUpCustomHandler);
565
- this.offCustomDragDown(this.dragDownCustomHandler);
566
- this.offCustomDragStart(this.dragStartCustomHandler);
567
- this.offCustomSwipeUp(this.swipeUpCustomHandler);
568
- this.offCustomSwipeDown(this.swipeDownCustomHandler);
569
- this.offCustomSwipeLeft(this.swipeLeftCustomHandler);
570
- this.offCustomSwipeRight(this.swipeRightCustomHandler);
571
- this.offCustomPinchMove(this.pinchMoveCustomHandler);
572
- this.offCustomPinchStart(this.pinchStartCustomHandler);
573
- this.offCustomDoubleTap(this.doubleTapCustomHandler);
574
- this.disableTouch();
575
- _easy.window.offKeyDown(this.keyDownHandler);
193
+ key: "updateZoom",
194
+ value: function updateZoom() {
195
+ this.updateMenuDivZoom();
196
+ this.updateOverlayDivZoom();
576
197
  }
577
198
  },
578
199
  {
579
200
  key: "childElements",
580
201
  value: function childElements() {
581
- return /*#__PURE__*/ React.createElement(_menu.default, null);
202
+ var divDOMElements = this.properties.divDOMElements;
203
+ return [
204
+ /*#__PURE__*/ React.createElement(_preloader.default, null),
205
+ /*#__PURE__*/ React.createElement(_overlay.default, {
206
+ divDOMElements: divDOMElements
207
+ }),
208
+ /*#__PURE__*/ React.createElement(_menu.default, null)
209
+ ];
582
210
  }
583
211
  },
584
212
  {
585
213
  key: "initialise",
586
214
  value: function initialise() {
587
215
  this.assignContext();
588
- this.setInitialState();
589
- this.forEachLeafDiv(function(leafDiv, index) {
590
- index === 0 ? leafDiv.show() : leafDiv.hide();
591
- });
216
+ this.show();
592
217
  }
593
218
  }
594
219
  ]);
595
220
  return View;
596
- }(_wrap_native_super(_easy.Element));
221
+ }(_wrap_native_super(_element.default));
597
222
  _define_property(View, "tagName", "div");
223
+ _define_property(View, "ignoredProperties", [
224
+ "divDOMElements"
225
+ ]);
598
226
  _define_property(View, "defaultProperties", {
599
227
  className: "view"
600
228
  });
601
- Object.assign(View.prototype, _touch.default);
602
229
  var _default = (0, _easywithstyle.default)(View)(_templateObject());
603
230
 
604
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/view.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";\n\nimport { keyCodes } from \"necessary\";\nimport { Element, window } from \"easy\";\n\nimport LeafDiv from \"./view/div/leaf\";\nimport MenuDiv from \"./view/div/menu\";\nimport touchMixins from \"./mixins/touch\";\n\nimport { leafNodesFromNodeList } from \"./utilities/tree\";\nimport { elementsFromDOMElements } from \"./utilities/element\";\nimport { VIEW_CHILD_DIVS_SELECTOR } from \"./selectors\";\nimport { SHOW_DELAY, ZOOM_RATIO, SCROLL_DELAY, UP_DIRECTION, DECELERATION, DOWN_DIRECTION, MENU_DIV_SWIPE_BOTTOM } from \"./constants\";\n\nconst { ENTER_KEY_CODE,\n        ESCAPE_KEY_CODE,\n        BACKSPACE_KEY_CODE,\n        ARROW_UP_KEY_CODE,\n        ARROW_DOWN_KEY_CODE,\n        ARROW_LEFT_KEY_CODE,\n        ARROW_RIGHT_KEY_CODE } = keyCodes;\n\nclass View extends Element {\n  doubleTapCustomHandler = (event, element) => {\n    this.enableNativeGestures();\n  }\n\n  pinchStartCustomHandler = (event, element) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    const zoom = this.getZoom(),\n          startZoom = zoom; ///\n\n    this.setStartZoom(startZoom);\n  }\n\n  pinchMoveCustomHandler = (event, element, ratio) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    const startZoom = this.getStartZoom(),\n          zoom = startZoom * Math.sqrt(ratio);\n\n    this.setZoom(zoom);\n\n    this.zoom(zoom);\n  }\n\n  swipeRightCustomHandler = (event, element) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    this.showLeftLeafDiv();\n  }\n\n  swipeLeftCustomHandler = (event, element) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    this.showRightLeftDiv();\n  }\n\n  swipeDownCustomHandler = (event, element, top, left, speed) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    const direction = DOWN_DIRECTION;\n\n    this.scroll(speed, direction);\n  }\n\n  swipeUpCustomHandler = (event, element, top, left, speed) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    const height = this.getHeight(),\n          bottom = height - top;\n\n    if (bottom < MENU_DIV_SWIPE_BOTTOM) {\n      this.showMenuDiv();\n\n      return;\n    }\n\n    const direction = UP_DIRECTION;\n\n    this.scroll(speed, direction);\n  }\n\n  dragStartCustomHandler = (event, element) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    const scrollTop = this.getScrollTop(),\n          startScrollTop = scrollTop; ///\n\n    this.setStartScrollTop(startScrollTop);\n  }\n\n  dragDownCustomHandler = (event, element, top, left) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    const startScrollTop = this.getStartScrollTop(),\n          scrollTop = startScrollTop - top;\n\n    this.setScrollTop(scrollTop);\n  }\n\n  dragUpCustomHandler = (event, element, top, left) => {\n    const nativeGesturesEnabled = this.areNativeGesturesEnabled();\n\n    if (nativeGesturesEnabled) {\n      return;\n    }\n\n    const startScrollTop = this.getStartScrollTop(),\n          scrollTop = startScrollTop - top;\n\n    this.setScrollTop(scrollTop);\n  }\n\n  tapCustomHandler = (event, element) => {\n\n    alert(\"view tap...\")\n\n    this.disableNativeGestures();\n  }\n\n  keyDownHandler = (event, element) => {\n    const { keyCode } = event;\n\n    switch (keyCode) {\n      case ENTER_KEY_CODE:\n      case ARROW_RIGHT_KEY_CODE: {\n        this.showRightLeftDiv();\n\n        break;\n      }\n\n      case BACKSPACE_KEY_CODE:\n      case ARROW_LEFT_KEY_CODE: {\n        this.showLeftLeafDiv();\n\n        break;\n      }\n\n      case ESCAPE_KEY_CODE: {\n        ///\n\n        break;\n      }\n\n      case ARROW_UP_KEY_CODE: {\n        this.showFirstLeftDiv();\n\n        break;\n      }\n\n      case ARROW_DOWN_KEY_CODE: {\n        this.showLastLeafDiv();\n\n        break;\n      }\n    }\n  }\n\n  zoomOut() {\n    let zoom = this.getZoom();\n\n    zoom /= ZOOM_RATIO;\n\n    this.setZoom(zoom);\n\n    this.zoom(zoom);\n  }\n\n  zoomIn() {\n    let zoom = this.getZoom();\n\n    zoom *= ZOOM_RATIO;\n\n    this.setZoom(zoom);\n\n    this.zoom(zoom);\n  }\n\n  zoom(zoom) {\n    const displayedLeafDiv = this.findDisplayedLeafDiv();\n\n    displayedLeafDiv.zoom(zoom);\n  }\n\n  scroll(speed, direction) {\n    let scrollTop = this.getScrollTop();\n\n    scrollTop += speed * SCROLL_DELAY;\n\n    this.setScrollTop(scrollTop);\n\n    let interval = this.getInterval();\n\n    if (interval !== null) {\n      clearInterval(interval);\n    }\n\n    interval = setInterval(() => {\n      speed = speed - direction * DECELERATION;\n\n      if ((speed * direction) < 0) {\n        clearInterval(interval);\n\n        interval = null;\n\n        this.setInterval(interval);\n      }\n\n      let scrollTop = this.getScrollTop();\n\n      scrollTop += speed * SCROLL_DELAY;\n\n      this.setScrollTop(scrollTop);\n    }, SCROLL_DELAY);\n\n    this.setInterval(interval);\n  }\n\n  showFirstLeftDiv() {\n    const displayedLeafDiv = this.findDisplayedLeafDiv(),\n          leafDivs = this.getLeafDivs(),\n          index = leafDivs.indexOf(displayedLeafDiv),\n          nextIndex = 0,\n          previousIndex = index;  ///\n\n    this.showNextLeafDiv(nextIndex, previousIndex);\n  }\n\n  showLeftLeafDiv() {\n    const displayedLeafDiv = this.findDisplayedLeafDiv(),\n          leafDivs = this.getLeafDivs(),\n          index = leafDivs.indexOf(displayedLeafDiv),\n          nextIndex = index - 1,\n          previousIndex = index;  ///\n\n    this.showNextLeafDiv(nextIndex, previousIndex);\n  }\n\n  showRightLeftDiv() {\n    const displayedLeafDiv = this.findDisplayedLeafDiv(),\n          leafDivs = this.getLeafDivs(),\n          index = leafDivs.indexOf(displayedLeafDiv),\n          nextIndex = index + 1,\n          previousIndex = index;  ///\n\n    this.showNextLeafDiv(nextIndex, previousIndex);\n  }\n\n  showLastLeafDiv() {\n    const displayedLeafDiv = this.findDisplayedLeafDiv(),\n          leafDivs = this.getLeafDivs(),\n          index = leafDivs.indexOf(displayedLeafDiv),\n          leafDivsLength = leafDivs.length,\n          nextIndex = leafDivsLength - 1,\n          previousIndex = index;  ///\n\n    this.showNextLeafDiv(nextIndex, previousIndex);\n  }\n\n  showNextLeafDiv(nextIndex, previousIndex) {\n    const leafDivs = this.getLeafDivs(),\n          leafDivsLength = leafDivs.length,\n          previousLeafDiv = leafDivs[previousIndex];\n\n    if ((nextIndex === -1) || (nextIndex === previousIndex) || (nextIndex === leafDivsLength)) {\n      return;\n    }\n\n    previousLeafDiv.hide();\n\n    const nextLeafDiv = leafDivs[nextIndex],\n          zoom = this.getZoom();\n\n    nextLeafDiv.zoom(zoom);\n\n    setTimeout(() => {\n      const scrollTop = 0;\n\n      nextLeafDiv.setScrollTop(scrollTop);\n\n      nextLeafDiv.show();\n    }, SHOW_DELAY);\n  }\n\n  enableNativeGestures() {\n    this.addClass(\"native-gestures\");\n  }\n\n  disableNativeGestures() {\n    this.removeClass(\"native-gestures\");\n  }\n\n  forEachLeafDiv(callback) {\n    const leafDivs = this.getLeafDivs();\n\n    leafDivs.forEach(callback);\n  }\n\n  findDisplayedLeafDiv() {\n    const leafDivs = this.getLeafDivs(),\n          displayedLeafDiv = leafDivs.find((leafDiv) => {\n            const displayed = leafDiv.isDisplayed();\n\n            if (displayed) {\n              return true;\n            }\n          });\n\n    return displayedLeafDiv;\n  }\n\n  retrieveLeafDivs() {\n    const viewChildDivDOMElementNodeList = document.querySelectorAll(VIEW_CHILD_DIVS_SELECTOR),\n          viewChildDivDOMElements = leafNodesFromNodeList(viewChildDivDOMElementNodeList),  ///\n          leafDivs = elementsFromDOMElements(viewChildDivDOMElements, LeafDiv);\n\n    return leafDivs;\n  }\n\n  getZoom() {\n    const { zoom } = this.getState();\n\n    return zoom;\n  }\n\n  setZoom(zoom) {\n    this.updateState({\n      zoom\n    });\n  }\n\n  getLeafDivs() {\n    const { leafDivs } = this.getState();\n\n    return leafDivs;\n  }\n\n  setLeftDivs(leafDivs) {\n    this.updateState({\n      leafDivs\n    });\n  }\n\n  getInterval() {\n    const { interval } = this.getState();\n\n    return interval;\n  }\n\n  setInterval(interval) {\n    this.updateState({\n      interval\n    });\n  }\n\n  getStartZoom() {\n    const { startZoom } = this.getState();\n\n    return startZoom;\n  }\n\n  setStartZoom(startZoom) {\n    this.updateState({\n      startZoom\n    });\n  }\n\n  getStartScrollTop() {\n    const { startScrollTop } = this.getState();\n\n    return startScrollTop;\n  }\n\n  setStartScrollTop(startScrollTop) {\n    this.updateState({\n      startScrollTop\n    });\n  }\n\n  areNativeGesturesEnabled() {\n    const nativeGesturesEnabled = this.hasClass(\"native-gestures\");\n\n    return nativeGesturesEnabled;\n  }\n\n  setInitialState() {\n    const zoom = 1,\n          leafDivs = this.retrieveLeafDivs(),\n          interval = null,\n          startZoom = null,\n          startScrollTop = null;\n\n    this.setState({\n      zoom,\n      leafDivs,\n      interval,\n      startZoom,\n      startScrollTop\n    });\n  }\n\n  didMount() {\n    this.enableTouch();\n\n    this.onCustomTap(this.tapCustomHandler);\n    this.onCustomDragUp(this.dragUpCustomHandler);\n    this.onCustomDragDown(this.dragDownCustomHandler);\n    this.onCustomDragStart(this.dragStartCustomHandler);\n    this.onCustomSwipeUp(this.swipeUpCustomHandler);\n    this.onCustomSwipeDown(this.swipeDownCustomHandler);\n    this.onCustomSwipeLeft(this.swipeLeftCustomHandler);\n    this.onCustomSwipeRight(this.swipeRightCustomHandler);\n    this.onCustomPinchMove(this.pinchMoveCustomHandler);\n    this.onCustomPinchStart(this.pinchStartCustomHandler);\n    this.onCustomDoubleTap(this.doubleTapCustomHandler);\n\n    window.onKeyDown(this.keyDownHandler);\n  }\n\n  willUnmount() {\n    this.offCustomTap(this.tapCustomHandler);\n    this.offCustomDragUp(this.dragUpCustomHandler);\n    this.offCustomDragDown(this.dragDownCustomHandler);\n    this.offCustomDragStart(this.dragStartCustomHandler);\n    this.offCustomSwipeUp(this.swipeUpCustomHandler);\n    this.offCustomSwipeDown(this.swipeDownCustomHandler);\n    this.offCustomSwipeLeft(this.swipeLeftCustomHandler);\n    this.offCustomSwipeRight(this.swipeRightCustomHandler);\n    this.offCustomPinchMove(this.pinchMoveCustomHandler);\n    this.offCustomPinchStart(this.pinchStartCustomHandler);\n    this.offCustomDoubleTap(this.doubleTapCustomHandler);\n\n    this.disableTouch();\n\n    window.offKeyDown(this.keyDownHandler);\n  }\n\n  childElements() {\n    return (\n\n      <MenuDiv/>\n\n    );\n  }\n\n  initialise() {\n    this.assignContext();\n\n    this.setInitialState();\n\n    this.forEachLeafDiv((leafDiv, index) => {\n      (index === 0) ?\n        leafDiv.show() :\n          leafDiv.hide();\n    });\n  }\n\n  static tagName = \"div\";\n\n  static defaultProperties = {\n    className: \"view\"\n  };\n}\n\nObject.assign(View.prototype, touchMixins);\n\nexport default withStyle(View)`\n\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  touch-action: none;\n  \n  .native-gestures {\n    touch-action: auto;\n  }\n    \n`;\n"],"names":["ENTER_KEY_CODE","keyCodes","ESCAPE_KEY_CODE","BACKSPACE_KEY_CODE","ARROW_UP_KEY_CODE","ARROW_DOWN_KEY_CODE","ARROW_LEFT_KEY_CODE","ARROW_RIGHT_KEY_CODE","View","doubleTapCustomHandler","event","element","enableNativeGestures","pinchStartCustomHandler","nativeGesturesEnabled","areNativeGesturesEnabled","zoom","getZoom","startZoom","setStartZoom","pinchMoveCustomHandler","ratio","getStartZoom","Math","sqrt","setZoom","swipeRightCustomHandler","showLeftLeafDiv","swipeLeftCustomHandler","showRightLeftDiv","swipeDownCustomHandler","top","left","speed","direction","DOWN_DIRECTION","scroll","swipeUpCustomHandler","height","getHeight","bottom","MENU_DIV_SWIPE_BOTTOM","showMenuDiv","UP_DIRECTION","dragStartCustomHandler","scrollTop","getScrollTop","startScrollTop","setStartScrollTop","dragDownCustomHandler","getStartScrollTop","setScrollTop","dragUpCustomHandler","tapCustomHandler","alert","disableNativeGestures","keyDownHandler","keyCode","showFirstLeftDiv","showLastLeafDiv","zoomOut","ZOOM_RATIO","zoomIn","displayedLeafDiv","findDisplayedLeafDiv","SCROLL_DELAY","interval","getInterval","clearInterval","setInterval","DECELERATION","leafDivs","getLeafDivs","index","indexOf","nextIndex","previousIndex","showNextLeafDiv","leafDivsLength","length","previousLeafDiv","hide","nextLeafDiv","setTimeout","show","SHOW_DELAY","addClass","removeClass","forEachLeafDiv","callback","forEach","find","leafDiv","displayed","isDisplayed","retrieveLeafDivs","viewChildDivDOMElementNodeList","document","querySelectorAll","VIEW_CHILD_DIVS_SELECTOR","viewChildDivDOMElements","leafNodesFromNodeList","elementsFromDOMElements","LeafDiv","getState","updateState","setLeftDivs","hasClass","setInitialState","setState","didMount","enableTouch","onCustomTap","onCustomDragUp","onCustomDragDown","onCustomDragStart","onCustomSwipeUp","onCustomSwipeDown","onCustomSwipeLeft","onCustomSwipeRight","onCustomPinchMove","onCustomPinchStart","onCustomDoubleTap","window","onKeyDown","willUnmount","offCustomTap","offCustomDragUp","offCustomDragDown","offCustomDragStart","offCustomSwipeUp","offCustomSwipeDown","offCustomSwipeLeft","offCustomSwipeRight","offCustomPinchMove","offCustomPinchStart","offCustomDoubleTap","disableTouch","offKeyDown","childElements","MenuDiv","initialise","assignContext","Element","tagName","defaultProperties","className","Object","assign","prototype","touchMixins","withStyle"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
231
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy92aWV3LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5pbXBvcnQgd2l0aFN0eWxlIGZyb20gXCJlYXN5LXdpdGgtc3R5bGVcIjsgIC8vL1xuXG5pbXBvcnQgRWxlbWVudCBmcm9tIFwiLi92aWV3L2VsZW1lbnRcIjtcbmltcG9ydCBNZW51RGl2IGZyb20gXCIuL3ZpZXcvZGl2L21lbnVcIjtcbmltcG9ydCBPdmVybGF5RGl2IGZyb20gXCIuL3ZpZXcvZGl2L292ZXJsYXlcIjtcbmltcG9ydCBQcmVsb2FkZXJEaXYgZnJvbSBcIi4vdmlldy9kaXYvcHJlbG9hZGVyXCI7XG5cbmNsYXNzIFZpZXcgZXh0ZW5kcyBFbGVtZW50IHtcbiAgdXBkYXRlWm9vbSgpIHtcbiAgICB0aGlzLnVwZGF0ZU1lbnVEaXZab29tKCk7XG4gICAgdGhpcy51cGRhdGVPdmVybGF5RGl2Wm9vbSgpO1xuICB9XG5cbiAgY2hpbGRFbGVtZW50cygpIHtcbiAgICBjb25zdCB7IGRpdkRPTUVsZW1lbnRzIH0gPSB0aGlzLnByb3BlcnRpZXM7XG5cbiAgICByZXR1cm4gKFtcblxuICAgICAgPFByZWxvYWRlckRpdi8+LFxuICAgICAgPE92ZXJsYXlEaXYgZGl2RE9NRWxlbWVudHM9e2RpdkRPTUVsZW1lbnRzfSAvPixcbiAgICAgIDxNZW51RGl2Lz5cblxuICAgIF0pO1xuICB9XG5cbiAgaW5pdGlhbGlzZSgpIHtcbiAgICB0aGlzLmFzc2lnbkNvbnRleHQoKTtcblxuICAgIHRoaXMuc2hvdygpO1xuICB9XG5cbiAgc3RhdGljIHRhZ05hbWUgPSBcImRpdlwiO1xuXG4gIHN0YXRpYyBpZ25vcmVkUHJvcGVydGllcyA9IFtcbiAgICBcImRpdkRPTUVsZW1lbnRzXCJcbiAgXTtcblxuICBzdGF0aWMgZGVmYXVsdFByb3BlcnRpZXMgPSB7XG4gICAgY2xhc3NOYW1lOiBcInZpZXdcIlxuICB9O1xufVxuXG5leHBvcnQgZGVmYXVsdCB3aXRoU3R5bGUoVmlldylgXG5cbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbiAgYWxpZ24taXRlbXM6IHN0cmV0Y2g7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gICAgXG5gO1xuIl0sIm5hbWVzIjpbIlZpZXciLCJ1cGRhdGVab29tIiwidXBkYXRlTWVudURpdlpvb20iLCJ1cGRhdGVPdmVybGF5RGl2Wm9vbSIsImNoaWxkRWxlbWVudHMiLCJkaXZET01FbGVtZW50cyIsInByb3BlcnRpZXMiLCJQcmVsb2FkZXJEaXYiLCJPdmVybGF5RGl2IiwiTWVudURpdiIsImluaXRpYWxpc2UiLCJhc3NpZ25Db250ZXh0Iiwic2hvdyIsIkVsZW1lbnQiLCJ0YWdOYW1lIiwiaWdub3JlZFByb3BlcnRpZXMiLCJkZWZhdWx0UHJvcGVydGllcyIsImNsYXNzTmFtZSIsIndpdGhTdHlsZSJdLCJyYW5nZU1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7IiwibWFwcGluZ3MiOiJBQUFBOzs7OytCQTRDQTs7O2VBQUE7OztvRUExQ3NCOzhEQUVGOzJEQUNBOzhEQUNHO2dFQUNFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRXpCLElBQUEsQUFBTUEscUJBQUQsQUFBTDtjQUFNQTsrQkFBQUE7YUFBQUE7Z0NBQUFBOzs7a0JBQUFBOztZQUNKQyxLQUFBQTttQkFBQUEsU0FBQUE7Z0JBQ0UsSUFBSSxDQUFDQyxpQkFBaUI7Z0JBQ3RCLElBQUksQ0FBQ0Msb0JBQW9CO1lBQzNCOzs7WUFFQUMsS0FBQUE7bUJBQUFBLFNBQUFBO2dCQUNFLElBQU0sQUFBRUMsaUJBQW1CLElBQUksQ0FBQ0MsVUFBVSxDQUFsQ0Q7Z0JBRVIsT0FBUTtrQ0FFTixvQkFBQ0Usa0JBQVk7a0NBQ2Isb0JBQUNDLGdCQUFVO3dCQUFDSCxnQkFBZ0JBOztrQ0FDNUIsb0JBQUNJLGFBQU87aUJBRVQ7WUFDSDs7O1lBRUFDLEtBQUFBO21CQUFBQSxTQUFBQTtnQkFDRSxJQUFJLENBQUNDLGFBQWE7Z0JBRWxCLElBQUksQ0FBQ0MsSUFBSTtZQUNYOzs7V0F0QklaO3FCQUFhYSxnQkFBTztBQXdCeEIsaUJBeEJJYixNQXdCR2MsV0FBVTtBQUVqQixpQkExQklkLE1BMEJHZSxxQkFBb0I7SUFDekI7Q0FDRDtBQUVELGlCQTlCSWYsTUE4QkdnQixxQkFBb0I7SUFDekJDLFdBQVc7QUFDYjtJQUdGLFdBQWVDLElBQUFBLHNCQUFTLEVBQUNsQiJ9
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "highmark-cli",
3
3
  "author": "James Smith",
4
- "version": "0.0.138",
4
+ "version": "0.0.140",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/highmark-cli",
7
7
  "description": "Extensible, styleable Markdown.",
@@ -13,7 +13,7 @@
13
13
  "argumentative": "^2.0.28",
14
14
  "express": "^4.19.2",
15
15
  "highmark-fonts": "^1.0.36",
16
- "highmark-markdown": "^0.0.224",
16
+ "highmark-markdown": "^0.0.229",
17
17
  "lively-cli": "^2.0.59",
18
18
  "necessary": "^13.6.1",
19
19
  "occam-entities": "^1.0.90"
@@ -25,6 +25,7 @@
25
25
  "easy-with-style": "^3.0.349",
26
26
  "esbuild": "^0.9.2",
27
27
  "juxtapose": "^4.0.81",
28
+ "sufficient": "^2.0.55",
28
29
  "watchful-cli": "^1.7.44"
29
30
  },
30
31
  "scripts": {
package/src/client.js CHANGED
@@ -4,23 +4,49 @@ import "juxtapose";
4
4
 
5
5
  import withStyle from "easy-with-style"; ///
6
6
 
7
+ import { controller } from "sufficient";
7
8
  import { Body, Element } from "easy";
8
9
 
9
10
  import View from "./view";
11
+ import createMethods from "./createMethods";
10
12
 
11
- import { elementFromDOMElement } from "./utilities/element";
12
- import { LOADING_DIV_SELECTOR, VIEW_DIV_SELECTOR } from "./selectors";
13
+ import { setOrientation } from "./state";
14
+ import { DIVS_SELECTOR, LOADING_DIV_SELECTOR } from "./selectors";
15
+ import { getOrientation, onOrientationChange } from "./utilities/orientation";
13
16
 
14
17
  const { renderStyles } = withStyle;
15
18
 
16
19
  renderStyles();
17
20
 
18
- const viewDOMElement = document.querySelector(VIEW_DIV_SELECTOR),
19
- body = new Body(),
20
- view = elementFromDOMElement(viewDOMElement, View); ///
21
+ const divDOMElements = [ ...document.querySelectorAll(DIVS_SELECTOR) ]; ///
21
22
 
22
- body.mount(view);
23
+ divDOMElements.forEach((divDOMElement) => {
24
+ divDOMElement.remove();
25
+ });
23
26
 
24
- const loadingDiv = new Element(LOADING_DIV_SELECTOR);
27
+ const scheduler = null,
28
+ model = null,
29
+ view =
25
30
 
26
- loadingDiv.hide();
31
+ <View divDOMElements={divDOMElements} />
32
+
33
+ ;
34
+
35
+ controller.assignMethods(createMethods, scheduler, model, view);
36
+
37
+ const body = new Body(),
38
+ loadingDiv = new Element(LOADING_DIV_SELECTOR);
39
+
40
+ onOrientationChange((orientation) => {
41
+ setOrientation(orientation);
42
+
43
+ view.updateZoom();
44
+ });
45
+
46
+ getOrientation((orientation) => {
47
+ setOrientation(orientation);
48
+
49
+ body.mount(view);
50
+
51
+ loadingDiv.hide();
52
+ });
package/src/constants.js CHANGED
@@ -2,16 +2,20 @@
2
2
 
3
3
  export const { PI } = Math;
4
4
 
5
+ export const GRID = "grid";
6
+ export const STATE_KEY = "state";
5
7
  export const TAP_DELAY = 250;
6
8
  export const ZOOM_RATIO = 1.1;
7
- export const SHOW_DELAY = 0;
8
9
  export const PI_OVER_TWO = PI / 2;
9
10
  export const SCROLL_DELAY = 10;
10
11
  export const DECELERATION = 0.0333333;
11
- export const SINGLE_SPACE = " ";
12
12
  export const UP_DIRECTION = +1;
13
13
  export const DOWN_DIRECTION = -1;
14
14
  export const MAXIMUM_SPREAD = PI / 4;
15
15
  export const MAXIMUM_TAP_TIME = 125;
16
+ export const BACKGROUND_COLOUR = "background-color"; ///
16
17
  export const MINIMUM_SWIPE_SPEED = 1;
17
- export const MENU_DIV_SWIPE_BOTTOM = 100;
18
+ export const PORTRAIT_ORIENTATION = "portrait";
19
+ export const LANDSCAPE_ORIENTATION = "landscape";
20
+ export const OPEN_MENU_TAP_AREA_HEIGHT = 256;
21
+ export const ORIENTATION_PORTRAIT_QUERY = "(orientation: portrait)";