@dso-toolkit/core 34.1.0 → 35.0.0

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 (116) hide show
  1. package/dist/cjs/dso-autosuggest.cjs.entry.js +5 -1
  2. package/dist/cjs/dso-header.cjs.entry.js +1 -1
  3. package/dist/cjs/dso-image-overlay.cjs.entry.js +62 -0
  4. package/dist/cjs/dso-info_2.cjs.entry.js +4 -1
  5. package/dist/cjs/dso-map-base-layers.cjs.entry.js +14 -1
  6. package/dist/cjs/dso-map-overlays.cjs.entry.js +14 -1
  7. package/dist/cjs/dso-ozon-content.cjs.entry.js +281 -423
  8. package/dist/cjs/dso-toolkit.cjs.js +1 -1
  9. package/dist/cjs/dso-viewer-grid.cjs.entry.js +57 -726
  10. package/dist/cjs/focus-trap.esm-8d3e3fb6.js +712 -0
  11. package/dist/cjs/loader.cjs.js +1 -1
  12. package/dist/collection/collection-manifest.json +3 -2
  13. package/dist/collection/components/autosuggest/autosuggest.js +6 -2
  14. package/dist/collection/components/header/header.css +21 -13
  15. package/dist/collection/components/highlight-box/highlight-box.template.js +4 -1
  16. package/dist/collection/components/image-overlay/image-overlay.css +263 -0
  17. package/dist/collection/components/image-overlay/image-overlay.js +72 -0
  18. package/dist/collection/components/image-overlay/image-overlay.template.js +7 -0
  19. package/dist/collection/components/info/info.css +20 -0
  20. package/dist/collection/components/map-base-layers/map-base-layers.js +16 -1
  21. package/dist/collection/components/map-overlays/map-overlays.js +16 -1
  22. package/dist/collection/components/ozon-content/nodes/al.node.js +13 -0
  23. package/dist/collection/components/ozon-content/nodes/document.node.js +9 -0
  24. package/dist/collection/components/ozon-content/nodes/ext-ref.node.js +15 -0
  25. package/dist/collection/components/ozon-content/nodes/fallback.node.js +10 -0
  26. package/dist/collection/components/ozon-content/nodes/illustratie.node.js +13 -0
  27. package/dist/collection/components/ozon-content/nodes/inhoud.node.js +14 -0
  28. package/dist/collection/components/ozon-content/nodes/inline.nodes.js +21 -0
  29. package/dist/collection/components/ozon-content/nodes/int-ref.node.js +26 -0
  30. package/dist/collection/components/ozon-content/nodes/noot.node.js +27 -0
  31. package/dist/collection/components/ozon-content/nodes/table.node/colspec/colspec-mapper.js +39 -0
  32. package/dist/collection/components/ozon-content/nodes/table.node/colspec/colspec.interface.js +2 -0
  33. package/dist/collection/components/ozon-content/nodes/table.node/index.js +1 -0
  34. package/dist/collection/components/ozon-content/nodes/table.node/table-cell.js +25 -0
  35. package/dist/collection/components/ozon-content/nodes/table.node/table-colgroup.js +4 -0
  36. package/dist/collection/components/ozon-content/nodes/table.node/table-rows.js +5 -0
  37. package/dist/collection/components/ozon-content/nodes/table.node/table.node.js +32 -0
  38. package/dist/collection/components/ozon-content/nodes/text.node.js +9 -0
  39. package/dist/collection/components/ozon-content/ozon-content-context.interface.js +1 -0
  40. package/dist/collection/components/ozon-content/ozon-content-mapper.js +76 -0
  41. package/dist/collection/components/ozon-content/ozon-content-node-context.interface.js +1 -0
  42. package/dist/collection/components/ozon-content/ozon-content-node-state.interface.js +1 -0
  43. package/dist/collection/components/ozon-content/ozon-content-node.interface.js +1 -0
  44. package/dist/collection/components/ozon-content/ozon-content.css +15 -7
  45. package/dist/collection/components/ozon-content/ozon-content.js +21 -33
  46. package/dist/collection/components/selectable/selectable.js +25 -1
  47. package/dist/collection/components/viewer-grid/viewer-grid-filterpanel-buttons.js +7 -0
  48. package/dist/collection/components/viewer-grid/viewer-grid.css +351 -3
  49. package/dist/collection/components/viewer-grid/viewer-grid.js +109 -19
  50. package/dist/collection/components/viewer-grid/viewer-grid.template.js +7 -3
  51. package/dist/custom-elements/index.d.ts +6 -0
  52. package/dist/custom-elements/index.js +3088 -3103
  53. package/dist/dso-toolkit/dso-toolkit.css +1 -1
  54. package/dist/dso-toolkit/dso-toolkit.esm.js +1 -1
  55. package/dist/dso-toolkit/p-225bbb28.entry.js +1 -0
  56. package/dist/dso-toolkit/p-3c4dbd89.entry.js +1 -0
  57. package/dist/dso-toolkit/p-44905fb1.js +5 -0
  58. package/dist/dso-toolkit/p-50b63cf4.entry.js +1 -0
  59. package/dist/dso-toolkit/p-8b6e3abc.entry.js +1 -0
  60. package/dist/dso-toolkit/p-ad540748.entry.js +1 -0
  61. package/dist/dso-toolkit/p-c6f467b3.entry.js +1 -0
  62. package/dist/dso-toolkit/p-f193c258.entry.js +1 -0
  63. package/dist/esm/dso-autosuggest.entry.js +5 -1
  64. package/dist/esm/dso-header.entry.js +1 -1
  65. package/dist/esm/dso-image-overlay.entry.js +58 -0
  66. package/dist/esm/dso-info_2.entry.js +4 -1
  67. package/dist/esm/dso-map-base-layers.entry.js +14 -1
  68. package/dist/esm/dso-map-overlays.entry.js +14 -1
  69. package/dist/esm/dso-ozon-content.entry.js +282 -424
  70. package/dist/esm/dso-toolkit.js +1 -1
  71. package/dist/esm/dso-viewer-grid.entry.js +58 -727
  72. package/dist/esm/focus-trap.esm-299989f2.js +710 -0
  73. package/dist/esm/loader.js +1 -1
  74. package/dist/types/components/autosuggest/autosuggest.d.ts +15 -1
  75. package/dist/types/components/image-overlay/image-overlay.d.ts +15 -0
  76. package/dist/types/components/image-overlay/image-overlay.template.d.ts +2 -0
  77. package/dist/types/components/map-base-layers/map-base-layers.d.ts +7 -2
  78. package/dist/types/components/map-overlays/map-overlays.d.ts +7 -2
  79. package/dist/types/components/ozon-content/nodes/al.node.d.ts +6 -0
  80. package/dist/types/components/ozon-content/nodes/document.node.d.ts +6 -0
  81. package/dist/types/components/ozon-content/nodes/ext-ref.node.d.ts +6 -0
  82. package/dist/types/components/ozon-content/nodes/fallback.node.d.ts +6 -0
  83. package/dist/types/components/ozon-content/nodes/illustratie.node.d.ts +5 -0
  84. package/dist/types/components/ozon-content/nodes/inhoud.node.d.ts +6 -0
  85. package/dist/types/components/ozon-content/nodes/inline.nodes.d.ts +6 -0
  86. package/dist/types/components/ozon-content/nodes/int-ref.node.d.ts +6 -0
  87. package/dist/types/components/ozon-content/nodes/noot.node.d.ts +8 -0
  88. package/dist/types/components/ozon-content/nodes/table.node/colspec/colspec-mapper.d.ts +2 -0
  89. package/dist/types/components/ozon-content/nodes/table.node/colspec/colspec.interface.d.ts +10 -0
  90. package/dist/types/components/ozon-content/nodes/table.node/index.d.ts +1 -0
  91. package/dist/types/components/ozon-content/nodes/table.node/table-cell.d.ts +8 -0
  92. package/dist/types/components/ozon-content/nodes/table.node/table-colgroup.d.ts +5 -0
  93. package/dist/types/components/ozon-content/nodes/table.node/table-rows.d.ts +8 -0
  94. package/dist/types/components/ozon-content/nodes/table.node/table.node.d.ts +7 -0
  95. package/dist/types/components/ozon-content/nodes/text.node.d.ts +5 -0
  96. package/dist/types/components/ozon-content/ozon-content-context.interface.d.ts +8 -0
  97. package/dist/types/components/ozon-content/ozon-content-mapper.d.ts +12 -0
  98. package/dist/types/components/ozon-content/ozon-content-node-context.interface.d.ts +8 -0
  99. package/dist/types/components/ozon-content/ozon-content-node-state.interface.d.ts +3 -0
  100. package/dist/types/components/ozon-content/ozon-content-node.interface.d.ts +8 -0
  101. package/dist/types/components/ozon-content/ozon-content.d.ts +8 -10
  102. package/dist/types/components/ozon-content/ozon-content.interfaces.d.ts +2 -2
  103. package/dist/types/components/selectable/selectable.d.ts +1 -0
  104. package/dist/types/components/viewer-grid/viewer-grid-filterpanel-buttons.d.ts +6 -0
  105. package/dist/types/components/viewer-grid/viewer-grid.d.ts +14 -3
  106. package/dist/types/components/viewer-grid/viewer-grid.template.d.ts +1 -1
  107. package/dist/types/components.d.ts +25 -6
  108. package/package.json +2 -2
  109. package/dist/collection/components/ozon-content/ozon-content.transformer.js +0 -105
  110. package/dist/dso-toolkit/p-06de0fa1.entry.js +0 -1
  111. package/dist/dso-toolkit/p-17f073d1.entry.js +0 -1
  112. package/dist/dso-toolkit/p-20856f91.entry.js +0 -1
  113. package/dist/dso-toolkit/p-7b006b11.entry.js +0 -1
  114. package/dist/dso-toolkit/p-aadc4f8e.entry.js +0 -1
  115. package/dist/dso-toolkit/p-b69134ed.entry.js +0 -5
  116. package/dist/types/components/ozon-content/ozon-content.transformer.d.ts +0 -15
@@ -1,3 +1,103 @@
1
+ button {
2
+ -webkit-appearance: button;
3
+ color: inherit;
4
+ cursor: pointer;
5
+ font: inherit;
6
+ font-family: inherit;
7
+ font-size: inherit;
8
+ line-height: inherit;
9
+ margin: 0;
10
+ overflow: visible;
11
+ text-transform: none;
12
+ }
13
+ button[disabled] {
14
+ cursor: default;
15
+ }
16
+ button::-moz-focus-inner {
17
+ border: 0;
18
+ padding: 0;
19
+ }
20
+
21
+ h1,
22
+ .h1,
23
+ h2,
24
+ .h2,
25
+ h3,
26
+ .h3 {
27
+ margin-bottom: 16px;
28
+ margin-top: 24px;
29
+ }
30
+
31
+ h1,
32
+ .h1 {
33
+ line-height: 1.25;
34
+ }
35
+
36
+ h1 {
37
+ color: #275937;
38
+ font-size: 2rem;
39
+ font-weight: 700;
40
+ }
41
+
42
+ h2,
43
+ .h2 {
44
+ line-height: 1.33;
45
+ }
46
+
47
+ h2 {
48
+ color: #275937;
49
+ font-size: 1.5rem;
50
+ font-weight: 700;
51
+ }
52
+
53
+ h3,
54
+ .h3 {
55
+ line-height: 1.2;
56
+ }
57
+
58
+ h3 {
59
+ color: #275937;
60
+ font-size: 1.25rem;
61
+ font-weight: 600;
62
+ }
63
+
64
+ h4,
65
+ .h4,
66
+ h5,
67
+ .h5,
68
+ h6,
69
+ .h6 {
70
+ margin-bottom: 16px;
71
+ margin-top: 12px;
72
+ }
73
+
74
+ h4,
75
+ .h4 {
76
+ line-height: 1.5;
77
+ }
78
+
79
+ h4 {
80
+ color: #275937;
81
+ font-size: 1rem;
82
+ font-weight: 600;
83
+ }
84
+
85
+ h5,
86
+ .h5 {
87
+ line-height: 1.5;
88
+ }
89
+
90
+ h5 {
91
+ color: #191919;
92
+ font-size: 1rem;
93
+ font-weight: 600;
94
+ }
95
+
96
+ h6,
97
+ .h6 {
98
+ line-height: 1.5;
99
+ }
100
+
1
101
  *,
2
102
  *::after,
3
103
  *::before {
@@ -373,14 +473,262 @@
373
473
  overflow: hidden;
374
474
  }
375
475
 
476
+ #filterpanel,
376
477
  .overlay {
377
478
  background-color: #fff;
378
- box-shadow: -2px 0 5px #666;
379
479
  height: 100%;
380
480
  overflow-y: auto;
381
- padding: 40px 16px 8px;
382
481
  position: absolute;
482
+ z-index: 2;
483
+ }
484
+
485
+ #filterpanel {
486
+ box-shadow: 2px 0 5px #666;
487
+ padding: 40px 16px 8px;
488
+ left: 0;
489
+ max-width: 896px;
490
+ width: calc(100vw - 40px);
491
+ }
492
+ @media screen and (max-width: 768px) {
493
+ #filterpanel {
494
+ width: 100vw;
495
+ }
496
+ #filterpanel::before {
497
+ display: none !important;
498
+ }
499
+ }
500
+ #filterpanel::before {
501
+ content: "";
502
+ display: block;
503
+ position: fixed;
504
+ top: 0;
505
+ bottom: 0;
506
+ right: 0;
507
+ left: 896px;
508
+ background-color: rgba(0, 0, 0, 0.5);
509
+ }
510
+ @media screen and (max-width: 936px) {
511
+ #filterpanel::before {
512
+ left: auto;
513
+ width: 40px;
514
+ }
515
+ }
516
+
517
+ .overlay {
518
+ box-shadow: -2px 0 5px #666;
519
+ padding: 40px 16px 8px;
383
520
  right: 0;
384
521
  width: 624px;
385
- z-index: 2;
522
+ }
523
+ @media screen and (max-width: 624px) {
524
+ .overlay {
525
+ width: 100vw;
526
+ }
527
+ }
528
+ .overlay::before {
529
+ content: "";
530
+ display: block;
531
+ position: fixed;
532
+ top: 0;
533
+ bottom: 0;
534
+ left: 0;
535
+ right: 624px;
536
+ background-color: rgba(0, 0, 0, 0.5);
537
+ }
538
+
539
+ .filterpanel-buttons {
540
+ text-align: right;
541
+ }
542
+ .filterpanel-buttons .cancel-button {
543
+ display: inline-block;
544
+ font-size: 1em;
545
+ font-weight: 500;
546
+ margin-bottom: 0;
547
+ text-decoration: none;
548
+ touch-action: manipulation;
549
+ text-align: left;
550
+ user-select: none;
551
+ vertical-align: middle;
552
+ background-color: #fff;
553
+ border-color: #39870c;
554
+ color: #39870c;
555
+ border-width: 1px;
556
+ border-style: solid;
557
+ border-radius: 4px;
558
+ line-height: 1.5;
559
+ min-width: 56px;
560
+ padding: 11px 15px;
561
+ line-height: 16px;
562
+ }
563
+ .filterpanel-buttons .cancel-button:focus, .filterpanel-buttons .cancel-button:focus-visible {
564
+ outline-offset: 2px;
565
+ }
566
+ .filterpanel-buttons .cancel-button:active {
567
+ outline: 0;
568
+ }
569
+ .filterpanel-buttons .cancel-button.extern::after, .filterpanel-buttons .cancel-button.download::after {
570
+ content: "";
571
+ display: inline-block;
572
+ height: 1.5em;
573
+ margin-left: 8px;
574
+ vertical-align: top;
575
+ width: 1.5em;
576
+ }
577
+ .filterpanel-buttons .cancel-button:hover {
578
+ background-color: #39870c;
579
+ border-color: #39870c;
580
+ color: #fff;
581
+ }
582
+ .filterpanel-buttons .cancel-button:active {
583
+ background-color: #275937;
584
+ border-color: #275937;
585
+ color: #fff;
586
+ }
587
+ .filterpanel-buttons .cancel-button[disabled], .filterpanel-buttons .cancel-button[disabled]:hover {
588
+ background-color: #fff;
589
+ border-color: #afcf9d;
590
+ color: #afcf9d;
591
+ }
592
+ .filterpanel-buttons .cancel-button.btn-sm {
593
+ line-height: 16px;
594
+ }
595
+ .filterpanel-buttons .cancel-button.btn-sm dso-icon,
596
+ .filterpanel-buttons .cancel-button.btn-sm svg.di, .filterpanel-buttons .cancel-button.btn-sm.extern::after, .filterpanel-buttons .cancel-button.btn-sm.download::after {
597
+ margin-bottom: -4px;
598
+ margin-top: -4px;
599
+ }
600
+ .filterpanel-buttons .cancel-button.download::after {
601
+ background: var(--dso-icon, var(--di-download)) no-repeat;
602
+ background-position: center;
603
+ background-size: cover;
604
+ height: 1.5em;
605
+ vertical-align: top;
606
+ width: 1.5em;
607
+ }
608
+ .filterpanel-buttons .cancel-button.download:hover::after {
609
+ --dso-icon: var(--di-download-wit);
610
+ }
611
+ .filterpanel-buttons .cancel-button.download[disabled]::after {
612
+ --dso-icon: var(--di-download-grasgroen-40);
613
+ }
614
+ .filterpanel-buttons .cancel-button.extern::after {
615
+ background: var(--dso-icon, var(--di-external-link)) no-repeat;
616
+ background-position: center;
617
+ background-size: cover;
618
+ height: 1.5em;
619
+ vertical-align: top;
620
+ width: 1.5em;
621
+ }
622
+ .filterpanel-buttons .cancel-button.extern:hover::after {
623
+ --dso-icon: var(--di-external-link-wit);
624
+ }
625
+ .filterpanel-buttons .cancel-button.extern[disabled]::after {
626
+ --dso-icon: var(--di-external-link-grasgroen-40);
627
+ }
628
+ .filterpanel-buttons .cancel-button dso-icon,
629
+ .filterpanel-buttons .cancel-button svg.di {
630
+ margin-left: -8px;
631
+ margin-right: 8px;
632
+ }
633
+ .filterpanel-buttons .cancel-button span + dso-icon,
634
+ .filterpanel-buttons .cancel-button span + svg.di {
635
+ margin-left: 8px;
636
+ margin-right: -8px;
637
+ }
638
+ .filterpanel-buttons .cancel-button dso-icon,
639
+ .filterpanel-buttons .cancel-button svg.di, .filterpanel-buttons .cancel-button.extern::after, .filterpanel-buttons .cancel-button.download::after {
640
+ margin-bottom: -4px;
641
+ margin-top: -4px;
642
+ }
643
+ .filterpanel-buttons .apply-button {
644
+ display: inline-block;
645
+ font-size: 1em;
646
+ font-weight: 500;
647
+ margin-bottom: 0;
648
+ text-decoration: none;
649
+ touch-action: manipulation;
650
+ text-align: left;
651
+ user-select: none;
652
+ vertical-align: middle;
653
+ background-color: #39870c;
654
+ border-color: #39870c;
655
+ color: #fff;
656
+ border-width: 1px;
657
+ border-style: solid;
658
+ border-radius: 4px;
659
+ line-height: 1.5;
660
+ min-width: 56px;
661
+ padding: 11px 15px;
662
+ line-height: 16px;
663
+ }
664
+ .filterpanel-buttons .apply-button:focus, .filterpanel-buttons .apply-button:focus-visible {
665
+ outline-offset: 2px;
666
+ }
667
+ .filterpanel-buttons .apply-button:active {
668
+ outline: 0;
669
+ }
670
+ .filterpanel-buttons .apply-button.extern::after, .filterpanel-buttons .apply-button.download::after {
671
+ content: "";
672
+ display: inline-block;
673
+ height: 1.5em;
674
+ margin-left: 8px;
675
+ vertical-align: top;
676
+ width: 1.5em;
677
+ }
678
+ .filterpanel-buttons .apply-button:hover {
679
+ background-color: #275937;
680
+ border-color: #275937;
681
+ color: #fff;
682
+ }
683
+ .filterpanel-buttons .apply-button:active {
684
+ background-color: #15301e;
685
+ border-color: #15301e;
686
+ color: #fff;
687
+ }
688
+ .filterpanel-buttons .apply-button[disabled], .filterpanel-buttons .apply-button[disabled]:hover {
689
+ background-color: #afcf9d;
690
+ border-color: #afcf9d;
691
+ color: #fff;
692
+ }
693
+ .filterpanel-buttons .apply-button.btn-sm {
694
+ line-height: 16px;
695
+ }
696
+ .filterpanel-buttons .apply-button.btn-sm dso-icon,
697
+ .filterpanel-buttons .apply-button.btn-sm svg.di, .filterpanel-buttons .apply-button.btn-sm.extern::after, .filterpanel-buttons .apply-button.btn-sm.download::after {
698
+ margin-bottom: -4px;
699
+ margin-top: -4px;
700
+ }
701
+ .filterpanel-buttons .apply-button.download::after {
702
+ background: var(--dso-icon, var(--di-download-wit)) no-repeat;
703
+ background-position: center;
704
+ background-size: cover;
705
+ height: 1.5em;
706
+ vertical-align: top;
707
+ width: 1.5em;
708
+ }
709
+ .filterpanel-buttons .apply-button.extern::after {
710
+ background: var(--dso-icon, var(--di-external-link-wit)) no-repeat;
711
+ background-position: center;
712
+ background-size: cover;
713
+ height: 1.5em;
714
+ vertical-align: top;
715
+ width: 1.5em;
716
+ }
717
+ .filterpanel-buttons .apply-button dso-icon,
718
+ .filterpanel-buttons .apply-button svg.di {
719
+ margin-left: -8px;
720
+ margin-right: 8px;
721
+ }
722
+ .filterpanel-buttons .apply-button span + dso-icon,
723
+ .filterpanel-buttons .apply-button span + svg.di {
724
+ margin-left: 8px;
725
+ margin-right: -8px;
726
+ }
727
+ .filterpanel-buttons .apply-button dso-icon,
728
+ .filterpanel-buttons .apply-button svg.di, .filterpanel-buttons .apply-button.extern::after, .filterpanel-buttons .apply-button.download::after {
729
+ margin-bottom: -4px;
730
+ margin-top: -4px;
731
+ }
732
+ .filterpanel-buttons .cancel-button + .apply-button {
733
+ margin-left: 16px;
386
734
  }
@@ -1,9 +1,13 @@
1
1
  import { h, Component, Prop, State, Host, Element, Event, } from "@stencil/core";
2
- import * as focusTrap from "focus-trap";
2
+ import { createFocusTrap } from "focus-trap";
3
+ import { ViewerGridFilterpanelButtons } from './viewer-grid-filterpanel-buttons';
3
4
  export class ViewerGrid {
4
5
  constructor() {
6
+ this.filterpanelOpen = false;
5
7
  this.overlayOpen = false;
6
8
  this.mainSize = "large";
9
+ this.filterpanelSlot = null;
10
+ this.overlaySlot = null;
7
11
  this.shrinkMain = () => {
8
12
  this.mainSize = this.mainSize == "large" ? "medium" : "small";
9
13
  };
@@ -18,40 +22,65 @@ export class ViewerGrid {
18
22
  };
19
23
  }
20
24
  updateFocusTrap() {
21
- if (!this.trap) {
25
+ var _a, _b;
26
+ if (this.filterpanelOpen && this.overlayOpen) {
22
27
  return;
23
28
  }
24
- if (this.overlayOpen) {
25
- this.trap.activate();
26
- this.host.addEventListener("keydown", this.keyDownListener);
29
+ if (this.filterpanelFocustrap) {
30
+ if (this.filterpanelOpen && !((_a = this.filterpanel) === null || _a === void 0 ? void 0 : _a.hidden)) {
31
+ this.filterpanelFocustrap.activate();
32
+ this.host.addEventListener("keydown", this.keyDownListener);
33
+ }
34
+ else {
35
+ this.filterpanelFocustrap.deactivate();
36
+ this.host.removeEventListener("keydown", this.keyDownListener);
37
+ }
27
38
  }
28
- else {
29
- this.trap.deactivate();
30
- this.host.removeEventListener("keydown", this.keyDownListener);
39
+ if (this.overlayFocustrap) {
40
+ if (this.overlayOpen && !((_b = this.overlay) === null || _b === void 0 ? void 0 : _b.hidden)) {
41
+ this.overlayFocustrap.activate();
42
+ this.host.addEventListener("keydown", this.keyDownListener);
43
+ }
44
+ else {
45
+ this.overlayFocustrap.deactivate();
46
+ this.host.removeEventListener("keydown", this.keyDownListener);
47
+ }
31
48
  }
32
49
  }
33
50
  connectedCallback() {
34
- this.overlaySlot = this.host.querySelector("div[slot = 'overlay']");
51
+ this.filterpanelSlot = this.host.querySelector("div[slot='filterpanel']");
52
+ this.overlaySlot = this.host.querySelector("div[slot='overlay']");
35
53
  }
36
54
  componentDidLoad() {
37
- if (!this.overlay || !this.overlaySlot) {
38
- return;
55
+ if (this.filterpanel && this.filterpanelSlot) {
56
+ this.filterpanelFocustrap = createFocusTrap([this.filterpanel, this.filterpanelSlot], {
57
+ escapeDeactivates: false,
58
+ allowOutsideClick: true,
59
+ });
60
+ }
61
+ if (this.overlay && this.overlaySlot) {
62
+ this.overlayFocustrap = createFocusTrap([this.overlay, this.overlaySlot], {
63
+ escapeDeactivates: false,
64
+ allowOutsideClick: true,
65
+ });
39
66
  }
40
- this.trap = focusTrap.createFocusTrap([this.overlay, this.overlaySlot], {
41
- escapeDeactivates: false,
42
- allowOutsideClick: true,
43
- });
44
67
  this.updateFocusTrap();
45
68
  }
46
69
  componentDidUpdate() {
47
70
  this.updateFocusTrap();
48
71
  }
49
72
  disconnectedCallback() {
50
- if (this.trap) {
51
- this.trap.deactivate();
52
- }
73
+ var _a, _b;
74
+ (_a = this.overlayFocustrap) === null || _a === void 0 ? void 0 : _a.deactivate();
75
+ (_b = this.filterpanelFocustrap) === null || _b === void 0 ? void 0 : _b.deactivate();
53
76
  this.host.removeEventListener("keydown", this.keyDownListener);
54
77
  }
78
+ handleFilterpanelApply(mouseEvent) {
79
+ this.filterpanelApply.emit({ originalEvent: mouseEvent });
80
+ }
81
+ handleFilterpanelCancel(mouseEvent) {
82
+ this.filterpanelCancel.emit({ originalEvent: mouseEvent });
83
+ }
55
84
  render() {
56
85
  return (h(Host, Object.assign({}, { [this.mainSize]: true }),
57
86
  h("div", { class: "dso-map-panel" },
@@ -62,6 +91,11 @@ export class ViewerGrid {
62
91
  h("dso-icon", { icon: "chevron-right" }))),
63
92
  h("div", { class: "main" },
64
93
  h("slot", { name: "main" }))),
94
+ h("div", { id: "filterpanel", hidden: !this.filterpanelOpen || !this.filterpanelSlot, ref: (element) => this.filterpanel = element },
95
+ h("h2", null, "Uw keuzes"),
96
+ h(ViewerGridFilterpanelButtons, { onApply: e => this.handleFilterpanelApply(e), onCancel: e => this.handleFilterpanelCancel(e) }),
97
+ h("slot", { name: "filterpanel" }),
98
+ h(ViewerGridFilterpanelButtons, { onApply: e => this.handleFilterpanelApply(e), onCancel: e => this.handleFilterpanelCancel(e) })),
65
99
  h("div", { class: "map" },
66
100
  h("slot", { name: "map" })),
67
101
  h("div", { class: "overlay", hidden: !this.overlayOpen || !this.overlaySlot, ref: (element) => (this.overlay = element) },
@@ -79,6 +113,24 @@ export class ViewerGrid {
79
113
  "$": ["viewer-grid.css"]
80
114
  }; }
81
115
  static get properties() { return {
116
+ "filterpanelOpen": {
117
+ "type": "boolean",
118
+ "mutable": false,
119
+ "complexType": {
120
+ "original": "boolean",
121
+ "resolved": "boolean",
122
+ "references": {}
123
+ },
124
+ "required": false,
125
+ "optional": false,
126
+ "docs": {
127
+ "tags": [],
128
+ "text": ""
129
+ },
130
+ "attribute": "filterpanel-open",
131
+ "reflect": true,
132
+ "defaultValue": "false"
133
+ },
82
134
  "overlayOpen": {
83
135
  "type": "boolean",
84
136
  "mutable": false,
@@ -94,7 +146,7 @@ export class ViewerGrid {
94
146
  "text": ""
95
147
  },
96
148
  "attribute": "overlay-open",
97
- "reflect": false,
149
+ "reflect": true,
98
150
  "defaultValue": "false"
99
151
  }
100
152
  }; }
@@ -123,6 +175,44 @@ export class ViewerGrid {
123
175
  }
124
176
  }
125
177
  }
178
+ }, {
179
+ "method": "filterpanelCancel",
180
+ "name": "filterpanelCancel",
181
+ "bubbles": true,
182
+ "cancelable": true,
183
+ "composed": true,
184
+ "docs": {
185
+ "tags": [],
186
+ "text": ""
187
+ },
188
+ "complexType": {
189
+ "original": "FilterpanelEvent",
190
+ "resolved": "FilterpanelEvent",
191
+ "references": {
192
+ "FilterpanelEvent": {
193
+ "location": "local"
194
+ }
195
+ }
196
+ }
197
+ }, {
198
+ "method": "filterpanelApply",
199
+ "name": "filterpanelApply",
200
+ "bubbles": true,
201
+ "cancelable": true,
202
+ "composed": true,
203
+ "docs": {
204
+ "tags": [],
205
+ "text": ""
206
+ },
207
+ "complexType": {
208
+ "original": "FilterpanelEvent",
209
+ "resolved": "FilterpanelEvent",
210
+ "references": {
211
+ "FilterpanelEvent": {
212
+ "location": "local"
213
+ }
214
+ }
215
+ }
126
216
  }]; }
127
217
  static get elementRef() { return "host"; }
128
218
  }
@@ -1,9 +1,9 @@
1
1
  import { html } from "lit-html";
2
- export function viewerGridTemplate({ main, map, overlay, noOverlay, overlayOpen, closeOverlay, }) {
2
+ export function viewerGridTemplate({ filterpanel, main, map, overlay, noOverlay, filterpanelOpen, overlayOpen, filterpanelApply, filterpanelCancel, closeOverlay, }) {
3
3
  return noOverlay
4
4
  ? html `
5
5
  <dso-viewer-grid
6
- overlay-open=${overlayOpen}
6
+ ?overlay-open=${overlayOpen}
7
7
  @closeOverlay=${closeOverlay}
8
8
  >
9
9
  <div slot="main">${main}</div>
@@ -12,9 +12,13 @@ export function viewerGridTemplate({ main, map, overlay, noOverlay, overlayOpen,
12
12
  `
13
13
  : html `
14
14
  <dso-viewer-grid
15
- overlay-open=${overlayOpen}
15
+ ?filterpanel-open=${filterpanelOpen}
16
+ ?overlay-open=${overlayOpen}
16
17
  @closeOverlay=${closeOverlay}
18
+ @filterpanelApply=${filterpanelApply}
19
+ @filterpanelCancel=${filterpanelCancel}
17
20
  >
21
+ <div slot="filterpanel">${filterpanel}</div>
18
22
  <div slot="main">${main}</div>
19
23
  <div slot="map">${map}</div>
20
24
  <div slot="overlay">${overlay}</div>
@@ -68,6 +68,12 @@ export const DsoIcon: {
68
68
  new (): DsoIcon;
69
69
  };
70
70
 
71
+ interface DsoImageOverlay extends Components.DsoImageOverlay, HTMLElement {}
72
+ export const DsoImageOverlay: {
73
+ prototype: DsoImageOverlay;
74
+ new (): DsoImageOverlay;
75
+ };
76
+
71
77
  interface DsoInfo extends Components.DsoInfo, HTMLElement {}
72
78
  export const DsoInfo: {
73
79
  prototype: DsoInfo;