@kirbydesign/designsystem 4.0.1 → 4.0.2

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 (57) hide show
  1. package/bundles/kirbydesign-designsystem-testing-base.umd.js +44 -15
  2. package/bundles/kirbydesign-designsystem-testing-base.umd.js.map +1 -1
  3. package/bundles/kirbydesign-designsystem-testing-base.umd.min.js +1 -1
  4. package/bundles/kirbydesign-designsystem-testing-base.umd.min.js.map +1 -1
  5. package/bundles/kirbydesign-designsystem.umd.js +274 -63
  6. package/bundles/kirbydesign-designsystem.umd.js.map +1 -1
  7. package/bundles/kirbydesign-designsystem.umd.min.js +1 -1
  8. package/bundles/kirbydesign-designsystem.umd.min.js.map +1 -1
  9. package/esm2015/kirbydesign-designsystem.js +18 -16
  10. package/esm2015/kirbydesign-designsystem.metadata.json +1 -1
  11. package/esm2015/lib/components/card/card.component.js +1 -1
  12. package/esm2015/lib/components/card/card.component.metadata.json +1 -1
  13. package/esm2015/lib/components/dropdown/dropdown.component.js +53 -59
  14. package/esm2015/lib/components/dropdown/dropdown.component.metadata.json +1 -1
  15. package/esm2015/lib/components/dropdown/dropdown.types.js +12 -0
  16. package/esm2015/lib/components/dropdown/dropdown.types.metadata.json +1 -0
  17. package/esm2015/lib/components/dropdown/keyboard-handler.service.js +43 -0
  18. package/esm2015/lib/components/dropdown/keyboard-handler.service.metadata.json +1 -0
  19. package/esm2015/lib/components/index.js +3 -2
  20. package/esm2015/lib/components/index.metadata.json +1 -1
  21. package/esm2015/lib/components/item/item.component.js +1 -1
  22. package/esm2015/lib/components/item/item.component.metadata.json +1 -1
  23. package/esm2015/lib/components/popover/popover.component.js +156 -0
  24. package/esm2015/lib/components/popover/popover.component.metadata.json +1 -0
  25. package/esm2015/lib/helpers/design-token-helper.js +4 -1
  26. package/esm2015/lib/helpers/design-token-helper.metadata.json +1 -1
  27. package/esm2015/lib/helpers/design-token-helper.styles.js +2 -1
  28. package/esm2015/lib/helpers/design-token-helper.styles.metadata.json +1 -1
  29. package/esm2015/lib/kirby.module.js +3 -1
  30. package/esm2015/lib/kirby.module.metadata.json +1 -1
  31. package/esm2015/testing-base/kirbydesign-designsystem-testing-base.js +17 -16
  32. package/esm2015/testing-base/kirbydesign-designsystem-testing-base.metadata.json +1 -1
  33. package/esm2015/testing-base/lib/components/mock.dropdown.component.js +2 -1
  34. package/esm2015/testing-base/lib/components/mock.dropdown.component.metadata.json +1 -1
  35. package/esm2015/testing-base/lib/components/mock.popover.component.js +27 -0
  36. package/esm2015/testing-base/lib/components/mock.popover.component.metadata.json +1 -0
  37. package/esm2015/testing-base/lib/mock-components.js +3 -1
  38. package/esm2015/testing-base/lib/mock-components.metadata.json +1 -1
  39. package/fesm2015/kirbydesign-designsystem-testing-base.js +29 -2
  40. package/fesm2015/kirbydesign-designsystem-testing-base.js.map +1 -1
  41. package/fesm2015/kirbydesign-designsystem.js +251 -49
  42. package/fesm2015/kirbydesign-designsystem.js.map +1 -1
  43. package/kirbydesign-designsystem.d.ts +17 -15
  44. package/kirbydesign-designsystem.metadata.json +1 -1
  45. package/lib/components/dropdown/dropdown.component.d.ts +13 -14
  46. package/lib/components/dropdown/dropdown.types.d.ts +9 -0
  47. package/lib/components/dropdown/keyboard-handler.service.d.ts +3 -0
  48. package/lib/components/index.d.ts +2 -1
  49. package/lib/components/popover/popover.component.d.ts +34 -0
  50. package/lib/helpers/design-token-helper.d.ts +1 -0
  51. package/lib/helpers/design-token-helper.styles.d.ts +1 -0
  52. package/package.json +1 -1
  53. package/scss/base/_variables.scss +1 -0
  54. package/testing-base/kirbydesign-designsystem-testing-base.d.ts +16 -15
  55. package/testing-base/kirbydesign-designsystem-testing-base.metadata.json +1 -1
  56. package/testing-base/lib/components/mock.dropdown.component.d.ts +1 -0
  57. package/testing-base/lib/components/mock.popover.component.d.ts +7 -0
@@ -1,29 +1,18 @@
1
- import { ChangeDetectorRef, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, forwardRef, HostBinding, HostListener, Input, Output, QueryList, Renderer2, TemplateRef, ViewChild, ViewChildren, } from '@angular/core';
1
+ import { ChangeDetectorRef, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, forwardRef, HostBinding, HostListener, Input, Output, QueryList, Renderer2, RendererStyleFlags2, TemplateRef, ViewChild, ViewChildren, } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { ButtonComponent } from '../button/button.component';
3
4
  import { CardComponent } from '../card/card.component';
4
5
  import { ItemComponent } from '../item/item.component';
5
6
  import { ListItemTemplateDirective } from '../list/list.directive';
6
- export var OpenState;
7
- (function (OpenState) {
8
- OpenState[OpenState["closed"] = 0] = "closed";
9
- OpenState[OpenState["opening"] = 1] = "opening";
10
- OpenState[OpenState["open"] = 2] = "open";
11
- })(OpenState || (OpenState = {}));
12
- export var HorizontalDirection;
13
- (function (HorizontalDirection) {
14
- HorizontalDirection["right"] = "right";
15
- HorizontalDirection["left"] = "left";
16
- })(HorizontalDirection || (HorizontalDirection = {}));
17
- var VerticalDirection;
18
- (function (VerticalDirection) {
19
- VerticalDirection[VerticalDirection["up"] = 0] = "up";
20
- VerticalDirection[VerticalDirection["down"] = 1] = "down";
21
- })(VerticalDirection || (VerticalDirection = {}));
7
+ import { HorizontalDirection, PopoverComponent } from '../popover/popover.component';
8
+ import { OpenState, VerticalDirection } from './dropdown.types';
9
+ import { KeyboardHandlerService } from './keyboard-handler.service';
22
10
  export class DropdownComponent {
23
- constructor(renderer, elementRef, changeDetectorRef) {
11
+ constructor(renderer, elementRef, changeDetectorRef, keyboardHandlerService) {
24
12
  this.renderer = renderer;
25
13
  this.elementRef = elementRef;
26
14
  this.changeDetectorRef = changeDetectorRef;
15
+ this.keyboardHandlerService = keyboardHandlerService;
27
16
  this.state = OpenState.closed;
28
17
  this.hasConfiguredSlottedItems = false;
29
18
  this.horizontalDirection = HorizontalDirection.right;
@@ -37,6 +26,7 @@ export class DropdownComponent {
37
26
  this.disabled = false;
38
27
  this.size = 'md';
39
28
  this.tabindex = 0;
29
+ this.usePopover = false;
40
30
  /**
41
31
  * Emitted when an item is selected (tap on mobile, click/keypress on web)
42
32
  */
@@ -129,10 +119,25 @@ export class DropdownComponent {
129
119
  this.hasConfiguredSlottedItems = true;
130
120
  }
131
121
  }
122
+ /* Utility that makes it easier to set styles on card element
123
+ when using popover*/
124
+ setPopoverCardStyle(style, value) {
125
+ if (!this.usePopover)
126
+ return;
127
+ this.renderer.setStyle(this.cardElement.nativeElement, style, value, RendererStyleFlags2.DashCase);
128
+ }
132
129
  ngAfterViewInit() {
130
+ if (this.usePopover && this.expand === 'block') {
131
+ const { width } = this.elementRef.nativeElement.getBoundingClientRect();
132
+ this.setPopoverCardStyle('--kirby-card-width', `${width}px`);
133
+ this.setPopoverCardStyle('max-width', 'initial');
134
+ this.setPopoverCardStyle('min-width', 'initial');
135
+ }
133
136
  this.initializeAlignment();
134
137
  }
135
138
  initializeAlignment() {
139
+ if (this.usePopover)
140
+ return;
136
141
  if (!this.intersectionObserverRef) {
137
142
  const options = {
138
143
  rootMargin: '0px',
@@ -199,13 +204,16 @@ export class DropdownComponent {
199
204
  }
200
205
  }
201
206
  showDropdown() {
207
+ var _a;
202
208
  if (this.state === OpenState.opening) {
203
209
  this.state = OpenState.open;
210
+ (_a = this.popover) === null || _a === void 0 ? void 0 : _a.show();
204
211
  this.scrollItemIntoView(this.selectedIndex);
205
212
  this.changeDetectorRef.markForCheck();
206
213
  }
207
214
  }
208
215
  close() {
216
+ var _a;
209
217
  if (this.disabled) {
210
218
  return;
211
219
  }
@@ -213,6 +221,7 @@ export class DropdownComponent {
213
221
  this.state = OpenState.closed;
214
222
  // Reset vertical direction to default
215
223
  this.verticalDirection = VerticalDirection.down;
224
+ (_a = this.popover) === null || _a === void 0 ? void 0 : _a.hide();
216
225
  }
217
226
  }
218
227
  onItemSelect(index) {
@@ -313,12 +322,17 @@ export class DropdownComponent {
313
322
  this.elementRef.nativeElement.blur();
314
323
  }
315
324
  }
316
- _onBlur() {
317
- if (this.disabled) {
325
+ _onPopoverWillHide() {
326
+ this.state = OpenState.closed;
327
+ this.elementRef.nativeElement.focus();
328
+ }
329
+ _onBlur(event) {
330
+ if (this.disabled)
318
331
  return;
319
- }
320
332
  if (this.isOpen) {
321
- this.close();
333
+ if (!this.cardElement.nativeElement.contains(event === null || event === void 0 ? void 0 : event.relatedTarget)) {
334
+ this.close();
335
+ }
322
336
  }
323
337
  this._onTouched();
324
338
  }
@@ -335,50 +349,26 @@ export class DropdownComponent {
335
349
  this.toggle();
336
350
  }
337
351
  _onArrowKeys(event) {
338
- if (this.disabled) {
352
+ if (this.disabled)
339
353
  return;
340
- }
354
+ // Mirror default HTML5 select behaviour - prevent left/right arrows when open:
341
355
  if (this.isOpen && (event.key === 'ArrowLeft' || event.key === 'ArrowRight')) {
342
- // Mirror default HTML5 select behaviour - prevent left/right arrows when open:
343
356
  return;
344
357
  }
345
- event.preventDefault();
346
- let newIndex = -1;
347
- if (event.key === 'ArrowUp' || event.key === 'ArrowLeft') {
348
- // Select previous item:
349
- newIndex = this.selectedIndex - 1;
350
- }
351
- if (event.key === 'ArrowDown' || event.key === 'ArrowRight') {
352
- if (this.selectedIndex === undefined) {
353
- // None selected, select first item:
354
- newIndex = 0;
355
- }
356
- else if (this.selectedIndex < this.items.length - 1) {
357
- // Select next item:
358
- newIndex = this.selectedIndex + 1;
359
- }
360
- }
358
+ const newIndex = this.keyboardHandlerService.handle(event, this.items, this.selectedIndex);
361
359
  if (newIndex > -1) {
362
360
  this.selectItem(newIndex);
363
361
  }
362
+ return false;
364
363
  }
365
364
  _onHomeEndKeys(event) {
366
- event.preventDefault();
367
- if (this.disabled) {
365
+ if (this.disabled)
368
366
  return;
369
- }
370
- let newIndex = -1;
371
- if (event.key === 'Home') {
372
- // Select first item:
373
- newIndex = 0;
374
- }
375
- if (event.key === 'End') {
376
- // Select last item:
377
- newIndex = this.items.length - 1;
378
- }
367
+ const newIndex = this.keyboardHandlerService.handle(event, this.items, this.selectedIndex);
379
368
  if (newIndex > -1) {
380
369
  this.selectItem(newIndex);
381
370
  }
371
+ return false;
382
372
  }
383
373
  ngOnDestroy() {
384
374
  let unlisten;
@@ -394,7 +384,7 @@ DropdownComponent.OPEN_DELAY_IN_MS = 100;
394
384
  DropdownComponent.decorators = [
395
385
  { type: Component, args: [{
396
386
  selector: 'kirby-dropdown',
397
- template: "<button\n kirby-button\n [size]=\"size\"\n [attentionLevel]=\"isOpen ? attentionLevelOpen : attentionLevel\"\n tabindex=\"-1\"\n (click)=\"onToggle($event)\"\n (mousedown)=\"onButtonMouseEvent($event)\"\n [disabled]=\"disabled\"\n>\n <span class=\"text\">{{ selectedText || placeholder }}</span>\n <kirby-icon [name]=\"isOpen ? 'arrow-up' : 'arrow-down'\"></kirby-icon>\n</button>\n<kirby-card>\n <ng-container *ngFor=\"let item of items; let i = index\">\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate || defaultItemTemplate;\n context: { $implicit: item, selected: i === selectedIndex, index: i }\n \"\n ></ng-container>\n </ng-container>\n</kirby-card>\n\n<ng-template #defaultItemTemplate let-item let-selected=\"selected\" let-index=\"index\">\n <kirby-item [selectable]=\"true\" [selected]=\"selected\" (click)=\"onItemSelect(index)\" role=\"option\">\n <h3>{{ getTextFromItem(item) }}</h3>\n <kirby-icon *ngIf=\"selected\" name=\"checkmark-selected\" slot=\"end\"></kirby-icon>\n </kirby-item>\n</ng-template>\n",
387
+ template: "<button\n kirby-button\n [size]=\"size\"\n [attentionLevel]=\"isOpen ? attentionLevelOpen : attentionLevel\"\n tabindex=\"-1\"\n (click)=\"onToggle($event)\"\n (mousedown)=\"onButtonMouseEvent($event)\"\n [disabled]=\"disabled\"\n>\n <span class=\"text\">{{ selectedText || placeholder }}</span>\n <kirby-icon [name]=\"isOpen ? 'arrow-up' : 'arrow-down'\"></kirby-icon>\n</button>\n\n<ng-container *ngTemplateOutlet=\"usePopover ? popoverTemplate : itemWrapperTemplate\"></ng-container>\n\n<ng-template #popoverTemplate>\n <kirby-popover [target]=\"buttonElement\" [popout]=\"popout\" (willHide)=\"_onPopoverWillHide()\">\n <ng-container *ngTemplateOutlet=\"itemWrapperTemplate\"></ng-container>\n </kirby-popover>\n</ng-template>\n\n<ng-template #itemWrapperTemplate>\n <kirby-card>\n <ng-container *ngFor=\"let item of items; let i = index\">\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate || defaultItemTemplate;\n context: { $implicit: item, selected: i === selectedIndex, index: i }\n \"\n ></ng-container>\n </ng-container>\n </kirby-card>\n</ng-template>\n\n<ng-template #defaultItemTemplate let-item let-selected=\"selected\" let-index=\"index\">\n <kirby-item [selectable]=\"true\" [selected]=\"selected\" (click)=\"onItemSelect(index)\" role=\"option\">\n <!-- Tabindex fixes issue with popover dropdown not working in safari -->\n <h3 tabindex=\"0\">{{ getTextFromItem(item) }}</h3>\n <kirby-icon *ngIf=\"selected\" name=\"checkmark-selected\" slot=\"end\"></kirby-icon>\n </kirby-item>\n</ng-template>\n",
398
388
  providers: [
399
389
  {
400
390
  provide: NG_VALUE_ACCESSOR,
@@ -402,14 +392,15 @@ DropdownComponent.decorators = [
402
392
  multi: true,
403
393
  },
404
394
  ],
405
- styles: [":host{--kirby_internal_min-screen-width:320px;display:inline-block;position:relative;max-width:calc(100vw - 32px);outline:none}@media (min-width:321px){:host{--kirby_internal_min-screen-width:375px}}:host.expand{display:block}:host:not(.expand) kirby-card{min-width:calc(var(--kirby_internal_min-screen-width) - 32px);max-width:calc(100vw - 32px)}@media (hover:hover){:host:focus>button,:host:focus>button.attention-level3{border-color:#4d90fe}}:host.error>button,:host.ng-touched.ng-invalid>button{border-color:var(--kirby-danger)}:host>button{position:relative;margin:0;outline:none;width:100%;transition:box-shadow .2s,border-color .2s}:host>button.attention-level2{border:1px solid transparent}:host>button .text{overflow:hidden;text-overflow:ellipsis}kirby-card{display:none;opacity:0;position:absolute;width:100%;max-height:352px;margin-top:4px;overflow-y:auto;box-shadow:0 20px 30px -15px rgba(28,28,28,.3),0 0 5px 0 rgba(28,28,28,.08);z-index:800}:host(.is-opening) kirby-card{display:block}:host(.is-open)>button{box-shadow:0 20px 30px -15px rgba(28,28,28,.3),0 0 5px 0 rgba(28,28,28,.08)}:host(.is-open) kirby-card{display:block;opacity:1}:host(.popout-left) kirby-card{right:0}:host(.popout-up) kirby-card{top:0;margin-top:-4px;transform:translateY(-100%)}:host(.popout-up).is-open>button{z-index:801}:host-context(kirby-calendar)>button{border-color:transparent;font-weight:700;font-size:medium}:host-context(kirby-calendar).is-open>button{box-shadow:none}"]
395
+ styles: [":host{display:inline-block;position:relative;max-width:calc(100vw - 32px);outline:none}:host.expand{display:block}:host.expand kirby-card{width:100%;min-width:0;max-width:none}@media (hover:hover){:host:focus>button,:host:focus>button.attention-level3{border-color:#4d90fe}}:host.error>button,:host.ng-touched.ng-invalid>button{border-color:var(--kirby-danger)}:host>button{position:relative;margin:0;outline:none;width:100%;transition:box-shadow .2s,border-color .2s}:host>button.attention-level2{border:1px solid transparent}:host>button .text{overflow:hidden;text-overflow:ellipsis}kirby-popover{--max-height:352px}kirby-card{max-height:352px;margin-top:4px;margin-bottom:4px;overflow-y:auto;box-shadow:0 20px 30px -15px rgba(28,28,28,.3),0 0 5px 0 rgba(28,28,28,.08);min-width:288px;max-width:calc(100vw - 32px)}@media (min-width:321px){kirby-card{min-width:343px}}:host(:not(.with-popover)) kirby-card{display:none;opacity:0;position:absolute;z-index:800}:host(:not(.with-popover)).is-opening kirby-card{display:block}:host(:not(.with-popover)).is-open kirby-card{display:block;opacity:1}:host(:not(.with-popover)).popout-left kirby-card{right:0}:host(:not(.with-popover)).popout-up kirby-card{top:0;margin-top:-4px;transform:translateY(-100%)}:host(:not(.with-popover)).popout-up.is-open>button{z-index:801}:host(.is-open)>button{box-shadow:0 20px 30px -15px rgba(28,28,28,.3),0 0 5px 0 rgba(28,28,28,.08)}:host-context(kirby-calendar)>button{border-color:transparent;font-weight:700;font-size:medium}:host-context(kirby-calendar).is-open>button{box-shadow:none}"]
406
396
  },] }
407
397
  ];
408
398
  /** @nocollapse */
409
399
  DropdownComponent.ctorParameters = () => [
410
400
  { type: Renderer2 },
411
401
  { type: ElementRef },
412
- { type: ChangeDetectorRef }
402
+ { type: ChangeDetectorRef },
403
+ { type: KeyboardHandlerService }
413
404
  ];
414
405
  DropdownComponent.propDecorators = {
415
406
  items: [{ type: Input }],
@@ -424,6 +415,7 @@ DropdownComponent.propDecorators = {
424
415
  hasError: [{ type: HostBinding, args: ['class.error',] }, { type: Input }],
425
416
  size: [{ type: Input }],
426
417
  tabindex: [{ type: Input }],
418
+ usePopover: [{ type: HostBinding, args: ['class.with-popover',] }, { type: Input }],
427
419
  _tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }],
428
420
  _noBlurOnScroll: [{ type: HostBinding, args: ['attr.no-blur',] }],
429
421
  change: [{ type: Output }],
@@ -435,16 +427,18 @@ DropdownComponent.propDecorators = {
435
427
  _popoutUp: [{ type: HostBinding, args: ['class.popout-up',] }],
436
428
  itemTemplate: [{ type: ContentChild, args: [ListItemTemplateDirective, { static: true, read: TemplateRef },] }],
437
429
  slottedItems: [{ type: ContentChildren, args: [ListItemTemplateDirective, { read: ElementRef },] }],
438
- cardElement: [{ type: ViewChild, args: [CardComponent, { static: true, read: ElementRef },] }],
430
+ cardElement: [{ type: ViewChild, args: [CardComponent, { read: ElementRef },] }],
431
+ popover: [{ type: ViewChild, args: [PopoverComponent,] }],
432
+ buttonElement: [{ type: ViewChild, args: [ButtonComponent, { static: true, read: ElementRef },] }],
439
433
  kirbyItemsDefault: [{ type: ViewChildren, args: [ItemComponent, { read: ElementRef },] }],
440
434
  kirbyItemsSlotted: [{ type: ContentChildren, args: [ItemComponent, { read: ElementRef },] }],
441
435
  _onTab: [{ type: HostListener, args: ['keydown.tab', ['$event'],] }],
442
436
  _onMouseDown: [{ type: HostListener, args: ['mousedown', ['$event'],] }],
443
437
  _onFocus: [{ type: HostListener, args: ['focus',] }],
444
- _onBlur: [{ type: HostListener, args: ['keydown.enter',] }, { type: HostListener, args: ['keydown.escape',] }, { type: HostListener, args: ['blur',] }],
438
+ _onBlur: [{ type: HostListener, args: ['keydown.enter',] }, { type: HostListener, args: ['keydown.escape',] }, { type: HostListener, args: ['blur', ['$event'],] }],
445
439
  _onSpace: [{ type: HostListener, args: ['keydown.space', ['$event'],] }],
446
440
  _onEnter: [{ type: HostListener, args: ['keydown.enter', ['$event'],] }],
447
441
  _onArrowKeys: [{ type: HostListener, args: ['keydown.arrowup', ['$event'],] }, { type: HostListener, args: ['keydown.arrowdown', ['$event'],] }, { type: HostListener, args: ['keydown.arrowleft', ['$event'],] }, { type: HostListener, args: ['keydown.arrowright', ['$event'],] }],
448
442
  _onHomeEndKeys: [{ type: HostListener, args: ['keydown.home', ['$event'],] }, { type: HostListener, args: ['keydown.end', ['$event'],] }]
449
443
  };
450
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../libs/designsystem/src/lib/components/dropdown/dropdown.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,eAAe,EACf,UAAU,EACV,YAAY,EACZ,UAAU,EACV,WAAW,EACX,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,SAAS,EACT,SAAS,EACT,WAAW,EACX,SAAS,EACT,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,yBAAyB,EAAE,MAAM,wBAAwB,CAAC;AAEnE,MAAM,CAAN,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,6CAAM,CAAA;IACN,+CAAO,CAAA;IACP,yCAAI,CAAA;AACN,CAAC,EAJW,SAAS,KAAT,SAAS,QAIpB;AAED,MAAM,CAAN,IAAY,mBAGX;AAHD,WAAY,mBAAmB;IAC7B,sCAAe,CAAA;IACf,oCAAa,CAAA;AACf,CAAC,EAHW,mBAAmB,KAAnB,mBAAmB,QAG9B;AAED,IAAK,iBAGJ;AAHD,WAAK,iBAAiB;IACpB,qDAAE,CAAA;IACF,yDAAI,CAAA;AACN,CAAC,EAHI,iBAAiB,KAAjB,iBAAiB,QAGrB;AAcD,MAAM,OAAO,iBAAiB;IAyI5B,YACU,QAAmB,EACnB,UAAmC,EACnC,iBAAoC;QAFpC,aAAQ,GAAR,QAAQ,CAAW;QACnB,eAAU,GAAV,UAAU,CAAyB;QACnC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAzItC,UAAK,GAAG,SAAS,CAAC,MAAM,CAAC;QACzB,8BAAyB,GAAG,KAAK,CAAC;QAClC,wBAAmB,GAAG,mBAAmB,CAAC,KAAK,CAAC;QAChD,sBAAiB,GAAG,iBAAiB,CAAC,IAAI,CAAC;QAE3C,WAAM,GAAqB,EAAE,CAAC;QAU9B,mBAAc,GAAW,CAAC,CAAC,CAAC;QAapC,qBAAgB,GAAG,MAAM,CAAC;QAG1B,gBAAW,GAAG,gBAAgB,CAAC;QAW/B,mBAAc,GAA0B,GAAG,CAAC;QACnC,uBAAkB,GAAG,GAAG,CAAC;QAMlC,aAAQ,GAAG,KAAK,CAAC;QAYjB,SAAI,GAAgB,IAAI,CAAC;QAGzB,aAAQ,GAAG,CAAC,CAAC;QAab;;WAEG;QACO,WAAM,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAExE,WAAM,GAAiB,IAAI,CAAC;QAepC,UAAK,GAAG,SAAS,CAAC;QAiCV,sBAAiB,GAAmB,EAAE,CAAC;QAgJvC,cAAS,GAAyB,GAAG,EAAE,GAAE,CAAC,CAAC;QAC3C,eAAU,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;IAzI3B,CAAC;IApIJ,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAa,KAAK,CAAC,KAAuB;QACxC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;IACvD,CAAC;IAGD,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED,IAAa,aAAa,CAAC,KAAa;QACtC,IAAI,IAAI,CAAC,cAAc,IAAI,KAAK,EAAE;YAChC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC5B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC;SACtD;IACH,CAAC;IAQD,IAAa,MAAM,CAAC,SAA8B;QAChD,IAAI,CAAC,mBAAmB,GAAG,SAAS,IAAI,mBAAmB,CAAC,KAAK,CAAC;IACpE,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IAYD,IACI,WAAW;QACb,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3C,CAAC;IAYD,IACI,SAAS;QACX,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;IAC5C,CAAC;IAED,+BAA+B;IAC/B,IACI,eAAe;QACjB,OAAO,IAAI,CAAC;IACd,CAAC;IAQD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;IAED,IACI,aAAa;QACf,OAAO,IAAI,CAAC,MAAM,KAAK,OAAO,CAAC;IACjC,CAAC;IAKD,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC,OAAO,CAAC;IAC1C,CAAC;IAED,IACI,MAAM;QACR,OAAO,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC,IAAI,CAAC;IACvC,CAAC;IAED,IACI,WAAW;QACb,OAAO,IAAI,CAAC,mBAAmB,KAAK,mBAAmB,CAAC,IAAI,CAAC;IAC/D,CAAC;IAED,IACI,SAAS;QACX,OAAO,IAAI,CAAC,iBAAiB,KAAK,iBAAiB,CAAC,EAAE,CAAC;IACzD,CAAC;IAuBD,QAAQ,CAAC,KAAY;QACnB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACvC;QACD,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QACD,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IAC3C,CAAC;IAED,kBAAkB,CAAC,KAAY;QAC7B,wBAAwB;QACxB,KAAK,CAAC,cAAc,EAAE,CAAC;IACzB,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,IAAI,CAAC,yBAAyB,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE;YACpE,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,KAAK,EAAE,EAAE;gBAClD,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,SAAS,CAAC,aAAa,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;gBACtE,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,aAAa,EAAE,OAAO,EAAE,GAAG,EAAE;oBAC3E,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;gBAC3B,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACxC,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;SACvC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,IAAI,CAAC,uBAAuB,EAAE;YACjC,MAAM,OAAO,GAAG;gBACd,UAAU,EAAE,KAAK;aAClB,CAAC;YACF,MAAM,QAAQ,GAAiC,CAAC,OAAO,EAAE,EAAE;gBACzD,qCAAqC;gBACrC,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC,OAAO,EAAE;oBACpC,OAAO;iBACR;gBAED,6CAA6C;gBAC7C,YAAY,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;gBACzC,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;gBACzB,MAAM,SAAS,GAAG,KAAK,CAAC,kBAAkB,CAAC,KAAK,GAAG,CAAC,CAAC;gBACrD,IAAI,SAAS,IAAI,KAAK,CAAC,iBAAiB,GAAG,CAAC,EAAE;oBAC5C,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;oBACnC,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;iBAClC;gBACD,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;YACzC,CAAC,CAAC;YACF,IAAI,CAAC,uBAAuB,GAAG,IAAI,oBAAoB,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YAC3E,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;SACtE;IACH,CAAC;IAEO,sBAAsB,CAAC,KAAK;QAClC,mJAAmJ;QACnJ,6EAA6E;QAC7E,IAAI,IAAI,CAAC,mBAAmB,KAAK,mBAAmB,CAAC,KAAK,EAAE;YAC1D,IAAI,KAAK,CAAC,kBAAkB,CAAC,KAAK,GAAG,KAAK,CAAC,UAAU,CAAC,KAAK,EAAE;gBAC3D,IAAI,CAAC,mBAAmB,GAAG,mBAAmB,CAAC,IAAI,CAAC;aACrD;SACF;aAAM;YACL,IAAI,KAAK,CAAC,kBAAkB,CAAC,IAAI,GAAG,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE;gBACzD,IAAI,CAAC,mBAAmB,GAAG,mBAAmB,CAAC,KAAK,CAAC;aACtD;SACF;IACH,CAAC;IAEO,oBAAoB,CAAC,KAAK;QAChC,IAAI,KAAK,CAAC,kBAAkB,CAAC,GAAG,GAAG,CAAC,EAAE;YACpC,mEAAmE;YACnE,kBAAkB;YAClB,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,IAAI,CAAC;SACjD;QACD,IAAI,KAAK,CAAC,kBAAkB,CAAC,MAAM,GAAG,KAAK,CAAC,UAAU,CAAC,MAAM,EAAE;YAC7D,yGAAyG;YACzG,MAAM,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;YACrF,MAAM,OAAO,GAAG,CAAC,CAAC,CAAC,qBAAqB;YACxC,8CAA8C;YAC9C,IAAI,kBAAkB,GAAG,KAAK,CAAC,MAAM,CAAC,YAAY,GAAG,OAAO,EAAE;gBAC5D,gBAAgB;gBAChB,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,EAAE,CAAC;aAC/C;SACF;IACH,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QACD,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC,OAAO,CAAC;YAC/B,6FAA6F;YAC7F,IAAI,CAAC,qBAAqB,GAAG,UAAU,CACrC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EACzB,iBAAiB,CAAC,gBAAgB,CACnC,CAAC;SACH;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC,OAAO,EAAE;YACpC,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC;YAC5B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAC5C,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;SACvC;IACH,CAAC;IAED,KAAK;QACH,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QACD,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC,MAAM,CAAC;YAC9B,sCAAsC;YACtC,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,IAAI,CAAC;SACjD;IACH,CAAC;IAED,YAAY,CAAC,KAAa;QACxB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAKD;;;;;OAKG;IACH,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACH,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED;;;;;;OAMG;IACH,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAED;;;;;OAKG;IACH,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAEO,UAAU,CAAC,KAAa;QAC9B,IAAI,KAAK,IAAI,IAAI,CAAC,aAAa,EAAE;YAC/B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3B,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;SAChC;IACH,CAAC;IAEO,kBAAkB,CAAC,KAAmB;QAC5C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC;IAED,eAAe,CAAC,IAAkB;QAChC,IAAI,CAAC,IAAI,EAAE;YACT,OAAO,IAAI,CAAC;SACb;QACD,OAAO,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACvE,CAAC;IAED,kBAAkB,CAAC,KAAa;QAC9B,MAAM,UAAU,GACd,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM;YACrD,CAAC,CAAC,IAAI,CAAC,iBAAiB;YACxB,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC;QAC7B,IAAI,UAAU,IAAI,UAAU,CAAC,MAAM,EAAE;YACnC,MAAM,iBAAiB,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;YACtD,IAAI,iBAAiB,IAAI,iBAAiB,CAAC,aAAa,EAAE;gBACxD,MAAM,WAAW,GAAG,iBAAiB,CAAC,aAAa,CAAC;gBACpD,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;gBACvD,MAAM,OAAO,GAAG,WAAW,CAAC,SAAS,CAAC;gBACtC,MAAM,UAAU,GAAG,WAAW,CAAC,SAAS,GAAG,WAAW,CAAC,YAAY,CAAC;gBACpE,MAAM,mBAAmB,GAAG,eAAe,CAAC,SAAS,CAAC;gBACtD,MAAM,sBAAsB,GAAG,eAAe,CAAC,YAAY,GAAG,eAAe,CAAC,SAAS,CAAC;gBACxF,IAAI,OAAO,GAAG,mBAAmB,EAAE;oBACjC,eAAe,CAAC,SAAS,GAAG,OAAO,CAAC;iBACrC;qBAAM,IAAI,UAAU,GAAG,sBAAsB,EAAE;oBAC9C,eAAe,CAAC,SAAS,GAAG,UAAU,GAAG,eAAe,CAAC,YAAY,CAAC;iBACvE;aACF;SACF;IACH,CAAC;IAGD,MAAM,CAAC,KAAoB;QACzB,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;IACH,CAAC;IAGD,YAAY,CAAC,KAAiB;QAC5B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,wBAAwB,EAAE,CAAC;SAClC;IACH,CAAC;IAGD,QAAQ;QACN,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;SACtC;IACH,CAAC;IAKD,OAAO;QACL,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QACD,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAGD,QAAQ,CAAC,KAAoB;QAC3B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,IAAI,EAAE,CAAC;SACb;IACH,CAAC;IAGD,QAAQ,CAAC,KAAoB;QAC3B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAMD,YAAY,CAAC,KAAoB;QAC/B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QACD,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,KAAK,WAAW,IAAI,KAAK,CAAC,GAAG,KAAK,YAAY,CAAC,EAAE;YAC5E,+EAA+E;YAC/E,OAAO;SACR;QACD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,QAAQ,GAAG,CAAC,CAAC,CAAC;QAClB,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE;YACxD,wBAAwB;YACxB,QAAQ,GAAG,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;SACnC;QACD,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,IAAI,KAAK,CAAC,GAAG,KAAK,YAAY,EAAE;YAC3D,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,EAAE;gBACpC,oCAAoC;gBACpC,QAAQ,GAAG,CAAC,CAAC;aACd;iBAAM,IAAI,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;gBACrD,oBAAoB;gBACpB,QAAQ,GAAG,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;aACnC;SACF;QACD,IAAI,QAAQ,GAAG,CAAC,CAAC,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAC3B;IACH,CAAC;IAID,cAAc,CAAC,KAAoB;QACjC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QACD,IAAI,QAAQ,GAAG,CAAC,CAAC,CAAC;QAClB,IAAI,KAAK,CAAC,GAAG,KAAK,MAAM,EAAE;YACxB,qBAAqB;YACrB,QAAQ,GAAG,CAAC,CAAC;SACd;QACD,IAAI,KAAK,CAAC,GAAG,KAAK,KAAK,EAAE;YACvB,oBAAoB;YACpB,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;SAClC;QACD,IAAI,QAAQ,GAAG,CAAC,CAAC,EAAE;YACjB,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SAC3B;IACH,CAAC;IAED,WAAW;QACT,IAAI,QAAoB,CAAC;QACzB,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE,CAAC,KAAK,SAAS,EAAE;YAC9D,QAAQ,EAAE,CAAC;SACZ;QACD,IAAI,IAAI,CAAC,uBAAuB,EAAE;YAChC,IAAI,CAAC,uBAAuB,CAAC,UAAU,EAAE,CAAC;SAC3C;IACH,CAAC;;AA5de,kCAAgB,GAAG,GAAG,CAAC;;YAdxC,SAAS,SAAC;gBACT,QAAQ,EAAE,gBAAgB;gBAC1B,8jCAAwC;gBAExC,SAAS,EAAE;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;wBAChD,KAAK,EAAE,IAAI;qBACZ;iBACF;;aACF;;;;YAtCC,SAAS;YATT,UAAU;YAJV,iBAAiB;;;oBAiEhB,KAAK;4BAUL,KAAK;+BAOL,KAAK;0BAGL,KAAK;qBAGL,KAAK;6BAQL,KAAK;qBAIL,KAAK;uBAGL,KAAK;0BAGL,WAAW,SAAC,eAAe;uBAK3B,WAAW,SAAC,aAAa,cACzB,KAAK;mBAGL,KAAK;uBAGL,KAAK;wBAGL,WAAW,SAAC,eAAe;8BAM3B,WAAW,SAAC,cAAc;qBAQ1B,MAAM;4BAWN,WAAW,SAAC,cAAc;oBAK1B,WAAW,SAAC,WAAW;yBAGvB,WAAW,SAAC,kBAAkB;qBAK9B,WAAW,SAAC,eAAe;0BAK3B,WAAW,SAAC,mBAAmB;wBAK/B,WAAW,SAAC,iBAAiB;2BAK7B,YAAY,SAAC,yBAAyB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,WAAW,EAAE;2BAE3E,eAAe,SAAC,yBAAyB,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;0BAE/D,SAAS,SAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE;gCAE3D,YAAY,SAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gCAEhD,eAAe,SAAC,aAAa,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;qBA2OnD,YAAY,SAAC,aAAa,EAAE,CAAC,QAAQ,CAAC;2BAQtC,YAAY,SAAC,WAAW,EAAE,CAAC,QAAQ,CAAC;uBAQpC,YAAY,SAAC,OAAO;sBAOpB,YAAY,SAAC,eAAe,cAC5B,YAAY,SAAC,gBAAgB,cAC7B,YAAY,SAAC,MAAM;uBAWnB,YAAY,SAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;uBASxC,YAAY,SAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;2BAOxC,YAAY,SAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,cAC1C,YAAY,SAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC,cAC5C,YAAY,SAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC,cAC5C,YAAY,SAAC,oBAAoB,EAAE,CAAC,QAAQ,CAAC;6BA6B7C,YAAY,SAAC,cAAc,EAAE,CAAC,QAAQ,CAAC,cACvC,YAAY,SAAC,aAAa,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n  AfterContentChecked,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { CardComponent } from '../card/card.component';\nimport { ItemComponent } from '../item/item.component';\nimport { ListItemTemplateDirective } from '../list/list.directive';\n\nexport enum OpenState {\n  closed,\n  opening,\n  open,\n}\n\nexport enum HorizontalDirection {\n  right = 'right',\n  left = 'left',\n}\n\nenum VerticalDirection {\n  up,\n  down,\n}\n\n@Component({\n  selector: 'kirby-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DropdownComponent),\n      multi: true,\n    },\n  ],\n})\nexport class DropdownComponent\n  implements AfterContentChecked, AfterViewInit, OnDestroy, ControlValueAccessor {\n  static readonly OPEN_DELAY_IN_MS = 100;\n  private state = OpenState.closed;\n  private hasConfiguredSlottedItems = false;\n  private horizontalDirection = HorizontalDirection.right;\n  private verticalDirection = VerticalDirection.down;\n\n  private _items: string[] | any[] = [];\n  get items(): string[] | any[] {\n    return this._items;\n  }\n\n  @Input() set items(value: string[] | any[]) {\n    this._items = value;\n    this._value = this.items[this.selectedIndex] || null;\n  }\n\n  private _selectedIndex: number = -1;\n  get selectedIndex(): number {\n    return this._selectedIndex;\n  }\n\n  @Input() set selectedIndex(value: number) {\n    if (this._selectedIndex != value) {\n      this._selectedIndex = value;\n      this._value = this.items[this.selectedIndex] || null;\n    }\n  }\n\n  @Input()\n  itemTextProperty = 'text';\n\n  @Input()\n  placeholder = 'Please select:';\n\n  @Input() set popout(direction: HorizontalDirection) {\n    this.horizontalDirection = direction || HorizontalDirection.right;\n  }\n\n  get popout() {\n    return this.horizontalDirection;\n  }\n\n  @Input()\n  attentionLevel: '1' | '2' | '3' | '4' = '3';\n  readonly attentionLevelOpen = '2';\n\n  @Input()\n  expand?: 'block';\n\n  @Input()\n  disabled = false;\n\n  @HostBinding('attr.disabled')\n  get _isDisabled() {\n    return this.disabled ? 'disabled' : null;\n  }\n\n  @HostBinding('class.error')\n  @Input()\n  hasError: boolean;\n\n  @Input()\n  size: 'sm' | 'md' = 'md';\n\n  @Input()\n  tabindex = 0;\n\n  @HostBinding('attr.tabindex')\n  get _tabindex() {\n    return this.disabled ? -1 : this.tabindex;\n  }\n\n  // Prevent Ionic blur on scroll\n  @HostBinding('attr.no-blur')\n  get _noBlurOnScroll() {\n    return true;\n  }\n\n  /**\n   * Emitted when an item is selected (tap on mobile, click/keypress on web)\n   */\n  @Output() change: EventEmitter<string | any> = new EventEmitter<string | any>();\n\n  private _value: string | any = null;\n  get value(): string | any {\n    return this._value;\n  }\n\n  get selectedText(): string {\n    return this.getTextFromItem(this.value);\n  }\n\n  @HostBinding('class.expand')\n  get _isBlockLevel() {\n    return this.expand === 'block';\n  }\n\n  @HostBinding('attr.role')\n  _role = 'listbox';\n\n  @HostBinding('class.is-opening')\n  get _isOpening(): boolean {\n    return this.state === OpenState.opening;\n  }\n\n  @HostBinding('class.is-open')\n  get isOpen(): boolean {\n    return this.state === OpenState.open;\n  }\n\n  @HostBinding('class.popout-left')\n  get _popoutLeft() {\n    return this.horizontalDirection === HorizontalDirection.left;\n  }\n\n  @HostBinding('class.popout-up')\n  get _popoutUp() {\n    return this.verticalDirection === VerticalDirection.up;\n  }\n\n  @ContentChild(ListItemTemplateDirective, { static: true, read: TemplateRef })\n  itemTemplate: TemplateRef<any>;\n  @ContentChildren(ListItemTemplateDirective, { read: ElementRef })\n  slottedItems: QueryList<ElementRef<HTMLElement>>;\n  @ViewChild(CardComponent, { static: true, read: ElementRef })\n  cardElement: ElementRef<HTMLElement>;\n  @ViewChildren(ItemComponent, { read: ElementRef })\n  kirbyItemsDefault: QueryList<ElementRef<HTMLElement>>;\n  @ContentChildren(ItemComponent, { read: ElementRef })\n  kirbyItemsSlotted: QueryList<ElementRef<HTMLElement>>;\n\n  private itemClickUnlisten: (() => void)[] = [];\n  private intersectionObserverRef: IntersectionObserver;\n  private showDropdownTimeoutId;\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>,\n    private changeDetectorRef: ChangeDetectorRef\n  ) {}\n\n  onToggle(event: Event) {\n    event.stopPropagation();\n    if (!this.isOpen) {\n      this.elementRef.nativeElement.focus();\n    }\n    this.toggle();\n  }\n\n  toggle() {\n    if (this.disabled) {\n      return;\n    }\n    this.isOpen ? this.close() : this.open();\n  }\n\n  onButtonMouseEvent(event: Event) {\n    // Prevent button focus;\n    event.preventDefault();\n  }\n\n  ngAfterContentChecked() {\n    if (!this.hasConfiguredSlottedItems && this.kirbyItemsSlotted.length) {\n      this.kirbyItemsSlotted.forEach((kirbyItem, index) => {\n        this.renderer.setAttribute(kirbyItem.nativeElement, 'role', 'option');\n        const unlisten = this.renderer.listen(kirbyItem.nativeElement, 'click', () => {\n          this.onItemSelect(index);\n        });\n        this.itemClickUnlisten.push(unlisten);\n      });\n      this.hasConfiguredSlottedItems = true;\n    }\n  }\n\n  ngAfterViewInit() {\n    this.initializeAlignment();\n  }\n\n  private initializeAlignment() {\n    if (!this.intersectionObserverRef) {\n      const options = {\n        rootMargin: '0px',\n      };\n      const callback: IntersectionObserverCallback = (entries) => {\n        // Only apply alignment when opening:\n        if (this.state !== OpenState.opening) {\n          return;\n        }\n\n        // Cancel any pending timer to show dropdown:\n        clearTimeout(this.showDropdownTimeoutId);\n        const entry = entries[0];\n        const isVisible = entry.boundingClientRect.width > 0;\n        if (isVisible && entry.intersectionRatio < 1) {\n          this.setHorizontalDirection(entry);\n          this.setVerticalDirection(entry);\n        }\n        this.showDropdown();\n        this.changeDetectorRef.detectChanges();\n      };\n      this.intersectionObserverRef = new IntersectionObserver(callback, options);\n      this.intersectionObserverRef.observe(this.cardElement.nativeElement);\n    }\n  }\n\n  private setHorizontalDirection(entry) {\n    // If popout direction is set to right, and the entry is cut off to the right by ${entry.boundingClientRect.right - entry.intersectionRect.right}px\n    // it is set to popout left instead, and vice versa for popout direction left\n    if (this.horizontalDirection === HorizontalDirection.right) {\n      if (entry.boundingClientRect.right > entry.rootBounds.right) {\n        this.horizontalDirection = HorizontalDirection.left;\n      }\n    } else {\n      if (entry.boundingClientRect.left < entry.rootBounds.left) {\n        this.horizontalDirection = HorizontalDirection.right;\n      }\n    }\n  }\n\n  private setVerticalDirection(entry) {\n    if (entry.boundingClientRect.top < 0) {\n      // entry is cut off at the top by ${entry.boundingClientRect.top}px\n      // open downwards:\n      this.verticalDirection = VerticalDirection.down;\n    }\n    if (entry.boundingClientRect.bottom > entry.rootBounds.bottom) {\n      // entry is cut off at the bottom by ${entry.boundingClientRect.bottom - entry.intersectionRect.bottom}px\n      const containerOffsetTop = this.elementRef.nativeElement.getBoundingClientRect().top;\n      const SPACING = 5; //TODO: Get from SCSS\n      // Check if the card can fit on top of button:\n      if (containerOffsetTop > entry.target.clientHeight + SPACING) {\n        // open upwards:\n        this.verticalDirection = VerticalDirection.up;\n      }\n    }\n  }\n\n  open() {\n    if (this.disabled) {\n      return;\n    }\n    if (!this.isOpen) {\n      this.state = OpenState.opening;\n      // ensures that the dropdown is opened in case the IntersectionObserverCallback isn't invoked\n      this.showDropdownTimeoutId = setTimeout(\n        () => this.showDropdown(),\n        DropdownComponent.OPEN_DELAY_IN_MS\n      );\n    }\n  }\n\n  private showDropdown() {\n    if (this.state === OpenState.opening) {\n      this.state = OpenState.open;\n      this.scrollItemIntoView(this.selectedIndex);\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n\n  close() {\n    if (this.disabled) {\n      return;\n    }\n    if (this.isOpen) {\n      this.state = OpenState.closed;\n      // Reset vertical direction to default\n      this.verticalDirection = VerticalDirection.down;\n    }\n  }\n\n  onItemSelect(index: number) {\n    this.selectItem(index);\n    this.close();\n  }\n\n  private _onChange: (value: any) => void = () => {};\n  private _onTouched = () => {};\n\n  /**\n   * Sets the select's value. Part of the ControlValueAccessor interface\n   * required to integrate with Angular's core forms API.\n   *\n   * @param value New value to be written to the model.\n   */\n  writeValue(value: any): void {\n    this._selectItemByValue(value);\n  }\n\n  /**\n   * Saves a callback function to be invoked when the select's value\n   * changes from user input. Part of the ControlValueAccessor interface\n   * required to integrate with Angular's core forms API.\n   *\n   * @param fn Callback to be triggered when the value changes.\n   */\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  /**\n   * Saves a callback function to be invoked when the select is blurred\n   * by the user. Part of the ControlValueAccessor interface required\n   * to integrate with Angular's core forms API.\n   *\n   * @param fn Callback to be triggered when the component has been touched.\n   */\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  /**\n   * Disables the select. Part of the ControlValueAccessor interface required\n   * to integrate with Angular's core forms API.\n   *\n   * @param isDisabled Sets whether the component is disabled.\n   */\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  private selectItem(index: number) {\n    if (index != this.selectedIndex) {\n      this.selectedIndex = index;\n      this.change.emit(this.value);\n      this._onChange(this.value);\n      this.scrollItemIntoView(index);\n    }\n  }\n\n  private _selectItemByValue(value: string | any) {\n    this.selectedIndex = this.items.indexOf(value);\n  }\n\n  getTextFromItem(item: string | any) {\n    if (!item) {\n      return null;\n    }\n    return typeof item === 'string' ? item : item[this.itemTextProperty];\n  }\n\n  scrollItemIntoView(index: number) {\n    const kirbyItems =\n      this.kirbyItemsSlotted && this.kirbyItemsSlotted.length\n        ? this.kirbyItemsSlotted\n        : this.kirbyItemsDefault;\n    if (kirbyItems && kirbyItems.length) {\n      const selectedKirbyItem = kirbyItems.toArray()[index];\n      if (selectedKirbyItem && selectedKirbyItem.nativeElement) {\n        const itemElement = selectedKirbyItem.nativeElement;\n        const scrollContainer = this.cardElement.nativeElement;\n        const itemTop = itemElement.offsetTop;\n        const itemBottom = itemElement.offsetTop + itemElement.offsetHeight;\n        const containerVisibleTop = scrollContainer.scrollTop;\n        const containerVisibleBottom = scrollContainer.clientHeight + scrollContainer.scrollTop;\n        if (itemTop < containerVisibleTop) {\n          scrollContainer.scrollTop = itemTop;\n        } else if (itemBottom > containerVisibleBottom) {\n          scrollContainer.scrollTop = itemBottom - scrollContainer.clientHeight;\n        }\n      }\n    }\n  }\n\n  @HostListener('keydown.tab', ['$event'])\n  _onTab(event: KeyboardEvent) {\n    if (this.isOpen) {\n      event.preventDefault();\n      this.close();\n    }\n  }\n\n  @HostListener('mousedown', ['$event'])\n  _onMouseDown(event: MouseEvent) {\n    if (this.disabled) {\n      event.preventDefault();\n      event.stopImmediatePropagation();\n    }\n  }\n\n  @HostListener('focus')\n  _onFocus() {\n    if (this.disabled) {\n      this.elementRef.nativeElement.blur();\n    }\n  }\n\n  @HostListener('keydown.enter')\n  @HostListener('keydown.escape')\n  @HostListener('blur')\n  _onBlur() {\n    if (this.disabled) {\n      return;\n    }\n    if (this.isOpen) {\n      this.close();\n    }\n    this._onTouched();\n  }\n\n  @HostListener('keydown.space', ['$event'])\n  _onSpace(event: KeyboardEvent) {\n    event.preventDefault();\n    event.stopPropagation();\n    if (!this.isOpen) {\n      this.open();\n    }\n  }\n\n  @HostListener('keydown.enter', ['$event'])\n  _onEnter(event: KeyboardEvent) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.toggle();\n  }\n\n  @HostListener('keydown.arrowup', ['$event'])\n  @HostListener('keydown.arrowdown', ['$event'])\n  @HostListener('keydown.arrowleft', ['$event'])\n  @HostListener('keydown.arrowright', ['$event'])\n  _onArrowKeys(event: KeyboardEvent) {\n    if (this.disabled) {\n      return;\n    }\n    if (this.isOpen && (event.key === 'ArrowLeft' || event.key === 'ArrowRight')) {\n      // Mirror default HTML5 select behaviour - prevent left/right arrows when open:\n      return;\n    }\n    event.preventDefault();\n    let newIndex = -1;\n    if (event.key === 'ArrowUp' || event.key === 'ArrowLeft') {\n      // Select previous item:\n      newIndex = this.selectedIndex - 1;\n    }\n    if (event.key === 'ArrowDown' || event.key === 'ArrowRight') {\n      if (this.selectedIndex === undefined) {\n        // None selected, select first item:\n        newIndex = 0;\n      } else if (this.selectedIndex < this.items.length - 1) {\n        // Select next item:\n        newIndex = this.selectedIndex + 1;\n      }\n    }\n    if (newIndex > -1) {\n      this.selectItem(newIndex);\n    }\n  }\n\n  @HostListener('keydown.home', ['$event'])\n  @HostListener('keydown.end', ['$event'])\n  _onHomeEndKeys(event: KeyboardEvent) {\n    event.preventDefault();\n    if (this.disabled) {\n      return;\n    }\n    let newIndex = -1;\n    if (event.key === 'Home') {\n      // Select first item:\n      newIndex = 0;\n    }\n    if (event.key === 'End') {\n      // Select last item:\n      newIndex = this.items.length - 1;\n    }\n    if (newIndex > -1) {\n      this.selectItem(newIndex);\n    }\n  }\n\n  ngOnDestroy(): void {\n    let unlisten: () => void;\n    while ((unlisten = this.itemClickUnlisten.pop()) !== undefined) {\n      unlisten();\n    }\n    if (this.intersectionObserverRef) {\n      this.intersectionObserverRef.disconnect();\n    }\n  }\n}\n"]}
444
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../libs/designsystem/src/lib/components/dropdown/dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  Renderer2,\n  RendererStyleFlags2,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { ButtonComponent } from '../button/button.component';\nimport { CardComponent } from '../card/card.component';\nimport { ItemComponent } from '../item/item.component';\nimport { ListItemTemplateDirective } from '../list/list.directive';\nimport { HorizontalDirection, PopoverComponent } from '../popover/popover.component';\n\nimport { OpenState, VerticalDirection } from './dropdown.types';\nimport { KeyboardHandlerService } from './keyboard-handler.service';\n\n@Component({\n  selector: 'kirby-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DropdownComponent),\n      multi: true,\n    },\n  ],\n})\nexport class DropdownComponent\n  implements AfterContentChecked, AfterViewInit, OnDestroy, ControlValueAccessor {\n  static readonly OPEN_DELAY_IN_MS = 100;\n  private state = OpenState.closed;\n  private hasConfiguredSlottedItems = false;\n  private horizontalDirection = HorizontalDirection.right;\n  private verticalDirection = VerticalDirection.down;\n\n  private _items: string[] | any[] = [];\n  get items(): string[] | any[] {\n    return this._items;\n  }\n\n  @Input() set items(value: string[] | any[]) {\n    this._items = value;\n    this._value = this.items[this.selectedIndex] || null;\n  }\n\n  private _selectedIndex: number = -1;\n  get selectedIndex(): number {\n    return this._selectedIndex;\n  }\n\n  @Input() set selectedIndex(value: number) {\n    if (this._selectedIndex != value) {\n      this._selectedIndex = value;\n      this._value = this.items[this.selectedIndex] || null;\n    }\n  }\n\n  @Input()\n  itemTextProperty = 'text';\n\n  @Input()\n  placeholder = 'Please select:';\n\n  @Input() set popout(direction: HorizontalDirection) {\n    this.horizontalDirection = direction || HorizontalDirection.right;\n  }\n\n  get popout() {\n    return this.horizontalDirection;\n  }\n\n  @Input()\n  attentionLevel: '1' | '2' | '3' | '4' = '3';\n  readonly attentionLevelOpen = '2';\n\n  @Input()\n  expand?: 'block';\n\n  @Input()\n  disabled = false;\n\n  @HostBinding('attr.disabled')\n  get _isDisabled() {\n    return this.disabled ? 'disabled' : null;\n  }\n\n  @HostBinding('class.error')\n  @Input()\n  hasError: boolean;\n\n  @Input()\n  size: 'sm' | 'md' = 'md';\n\n  @Input()\n  tabindex = 0;\n\n  @HostBinding('class.with-popover')\n  @Input()\n  usePopover = false;\n\n  @HostBinding('attr.tabindex')\n  get _tabindex() {\n    return this.disabled ? -1 : this.tabindex;\n  }\n\n  // Prevent Ionic blur on scroll\n  @HostBinding('attr.no-blur')\n  get _noBlurOnScroll() {\n    return true;\n  }\n\n  /**\n   * Emitted when an item is selected (tap on mobile, click/keypress on web)\n   */\n  @Output() change: EventEmitter<string | any> = new EventEmitter<string | any>();\n\n  private _value: string | any = null;\n  get value(): string | any {\n    return this._value;\n  }\n\n  get selectedText(): string {\n    return this.getTextFromItem(this.value);\n  }\n\n  @HostBinding('class.expand')\n  get _isBlockLevel() {\n    return this.expand === 'block';\n  }\n\n  @HostBinding('attr.role')\n  _role = 'listbox';\n\n  @HostBinding('class.is-opening')\n  get _isOpening(): boolean {\n    return this.state === OpenState.opening;\n  }\n\n  @HostBinding('class.is-open')\n  get isOpen(): boolean {\n    return this.state === OpenState.open;\n  }\n\n  @HostBinding('class.popout-left')\n  get _popoutLeft() {\n    return this.horizontalDirection === HorizontalDirection.left;\n  }\n\n  @HostBinding('class.popout-up')\n  get _popoutUp() {\n    return this.verticalDirection === VerticalDirection.up;\n  }\n\n  @ContentChild(ListItemTemplateDirective, { static: true, read: TemplateRef })\n  itemTemplate: TemplateRef<any>;\n  @ContentChildren(ListItemTemplateDirective, { read: ElementRef })\n  slottedItems: QueryList<ElementRef<HTMLElement>>;\n  @ViewChild(CardComponent, { read: ElementRef })\n  cardElement: ElementRef<HTMLElement>;\n  @ViewChild(PopoverComponent)\n  popover?: PopoverComponent;\n  @ViewChild(ButtonComponent, { static: true, read: ElementRef })\n  buttonElement: ElementRef<HTMLElement>;\n  @ViewChildren(ItemComponent, { read: ElementRef })\n  kirbyItemsDefault: QueryList<ElementRef<HTMLElement>>;\n  @ContentChildren(ItemComponent, { read: ElementRef })\n  kirbyItemsSlotted: QueryList<ElementRef<HTMLElement>>;\n\n  private itemClickUnlisten: (() => void)[] = [];\n  private intersectionObserverRef: IntersectionObserver;\n  private showDropdownTimeoutId: ReturnType<typeof setTimeout>;\n\n  constructor(\n    private renderer: Renderer2,\n    private elementRef: ElementRef<HTMLElement>,\n    private changeDetectorRef: ChangeDetectorRef,\n    private keyboardHandlerService: KeyboardHandlerService\n  ) {}\n\n  onToggle(event: MouseEvent) {\n    event.stopPropagation();\n    if (!this.isOpen) {\n      this.elementRef.nativeElement.focus();\n    }\n    this.toggle();\n  }\n\n  toggle() {\n    if (this.disabled) {\n      return;\n    }\n    this.isOpen ? this.close() : this.open();\n  }\n\n  onButtonMouseEvent(event: Event) {\n    // Prevent button focus;\n    event.preventDefault();\n  }\n\n  ngAfterContentChecked() {\n    if (!this.hasConfiguredSlottedItems && this.kirbyItemsSlotted.length) {\n      this.kirbyItemsSlotted.forEach((kirbyItem, index) => {\n        this.renderer.setAttribute(kirbyItem.nativeElement, 'role', 'option');\n        const unlisten = this.renderer.listen(kirbyItem.nativeElement, 'click', () => {\n          this.onItemSelect(index);\n        });\n        this.itemClickUnlisten.push(unlisten);\n      });\n      this.hasConfiguredSlottedItems = true;\n    }\n  }\n\n  /* Utility that makes it easier to set styles on card element \n  when using popover*/\n  private setPopoverCardStyle(style: string, value: string) {\n    if (!this.usePopover) return;\n\n    this.renderer.setStyle(\n      this.cardElement.nativeElement,\n      style,\n      value,\n      RendererStyleFlags2.DashCase\n    );\n  }\n\n  ngAfterViewInit() {\n    if (this.usePopover && this.expand === 'block') {\n      const { width } = this.elementRef.nativeElement.getBoundingClientRect();\n      this.setPopoverCardStyle('--kirby-card-width', `${width}px`);\n      this.setPopoverCardStyle('max-width', 'initial');\n      this.setPopoverCardStyle('min-width', 'initial');\n    }\n    this.initializeAlignment();\n  }\n\n  private initializeAlignment() {\n    if (this.usePopover) return;\n    if (!this.intersectionObserverRef) {\n      const options = {\n        rootMargin: '0px',\n      };\n      const callback: IntersectionObserverCallback = (entries) => {\n        // Only apply alignment when opening:\n        if (this.state !== OpenState.opening) {\n          return;\n        }\n\n        // Cancel any pending timer to show dropdown:\n        clearTimeout(this.showDropdownTimeoutId);\n        const entry = entries[0];\n        const isVisible = entry.boundingClientRect.width > 0;\n        if (isVisible && entry.intersectionRatio < 1) {\n          this.setHorizontalDirection(entry);\n          this.setVerticalDirection(entry);\n        }\n        this.showDropdown();\n        this.changeDetectorRef.detectChanges();\n      };\n      this.intersectionObserverRef = new IntersectionObserver(callback, options);\n      this.intersectionObserverRef.observe(this.cardElement.nativeElement);\n    }\n  }\n\n  private setHorizontalDirection(entry: IntersectionObserverEntry) {\n    // If popout direction is set to right, and the entry is cut off to the right by ${entry.boundingClientRect.right - entry.intersectionRect.right}px\n    // it is set to popout left instead, and vice versa for popout direction left\n    if (this.horizontalDirection === HorizontalDirection.right) {\n      if (entry.boundingClientRect.right > entry.rootBounds.right) {\n        this.horizontalDirection = HorizontalDirection.left;\n      }\n    } else {\n      if (entry.boundingClientRect.left < entry.rootBounds.left) {\n        this.horizontalDirection = HorizontalDirection.right;\n      }\n    }\n  }\n\n  private setVerticalDirection(entry: IntersectionObserverEntry) {\n    if (entry.boundingClientRect.top < 0) {\n      // entry is cut off at the top by ${entry.boundingClientRect.top}px\n      // open downwards:\n      this.verticalDirection = VerticalDirection.down;\n    }\n    if (entry.boundingClientRect.bottom > entry.rootBounds.bottom) {\n      // entry is cut off at the bottom by ${entry.boundingClientRect.bottom - entry.intersectionRect.bottom}px\n      const containerOffsetTop = this.elementRef.nativeElement.getBoundingClientRect().top;\n      const SPACING = 5; //TODO: Get from SCSS\n      // Check if the card can fit on top of button:\n      if (containerOffsetTop > entry.target.clientHeight + SPACING) {\n        // open upwards:\n        this.verticalDirection = VerticalDirection.up;\n      }\n    }\n  }\n\n  open() {\n    if (this.disabled) {\n      return;\n    }\n    if (!this.isOpen) {\n      this.state = OpenState.opening;\n      // ensures that the dropdown is opened in case the IntersectionObserverCallback isn't invoked\n      this.showDropdownTimeoutId = setTimeout(\n        () => this.showDropdown(),\n        DropdownComponent.OPEN_DELAY_IN_MS\n      );\n    }\n  }\n\n  private showDropdown() {\n    if (this.state === OpenState.opening) {\n      this.state = OpenState.open;\n      this.popover?.show();\n      this.scrollItemIntoView(this.selectedIndex);\n      this.changeDetectorRef.markForCheck();\n    }\n  }\n\n  close() {\n    if (this.disabled) {\n      return;\n    }\n    if (this.isOpen) {\n      this.state = OpenState.closed;\n      // Reset vertical direction to default\n      this.verticalDirection = VerticalDirection.down;\n      this.popover?.hide();\n    }\n  }\n\n  onItemSelect(index: number) {\n    this.selectItem(index);\n    this.close();\n  }\n\n  private _onChange: (value: any) => void = () => {};\n  private _onTouched = () => {};\n\n  /**\n   * Sets the select's value. Part of the ControlValueAccessor interface\n   * required to integrate with Angular's core forms API.\n   *\n   * @param value New value to be written to the model.\n   */\n  writeValue(value: any): void {\n    this._selectItemByValue(value);\n  }\n\n  /**\n   * Saves a callback function to be invoked when the select's value\n   * changes from user input. Part of the ControlValueAccessor interface\n   * required to integrate with Angular's core forms API.\n   *\n   * @param fn Callback to be triggered when the value changes.\n   */\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  /**\n   * Saves a callback function to be invoked when the select is blurred\n   * by the user. Part of the ControlValueAccessor interface required\n   * to integrate with Angular's core forms API.\n   *\n   * @param fn Callback to be triggered when the component has been touched.\n   */\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  /**\n   * Disables the select. Part of the ControlValueAccessor interface required\n   * to integrate with Angular's core forms API.\n   *\n   * @param isDisabled Sets whether the component is disabled.\n   */\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  private selectItem(index: number) {\n    if (index != this.selectedIndex) {\n      this.selectedIndex = index;\n      this.change.emit(this.value);\n      this._onChange(this.value);\n      this.scrollItemIntoView(index);\n    }\n  }\n\n  private _selectItemByValue(value: string | any) {\n    this.selectedIndex = this.items.indexOf(value);\n  }\n\n  getTextFromItem(item: string | any) {\n    if (!item) {\n      return null;\n    }\n    return typeof item === 'string' ? item : item[this.itemTextProperty];\n  }\n\n  scrollItemIntoView(index: number) {\n    const kirbyItems =\n      this.kirbyItemsSlotted && this.kirbyItemsSlotted.length\n        ? this.kirbyItemsSlotted\n        : this.kirbyItemsDefault;\n    if (kirbyItems && kirbyItems.length) {\n      const selectedKirbyItem = kirbyItems.toArray()[index];\n      if (selectedKirbyItem && selectedKirbyItem.nativeElement) {\n        const itemElement = selectedKirbyItem.nativeElement;\n        const scrollContainer = this.cardElement.nativeElement;\n        const itemTop = itemElement.offsetTop;\n        const itemBottom = itemElement.offsetTop + itemElement.offsetHeight;\n        const containerVisibleTop = scrollContainer.scrollTop;\n        const containerVisibleBottom = scrollContainer.clientHeight + scrollContainer.scrollTop;\n        if (itemTop < containerVisibleTop) {\n          scrollContainer.scrollTop = itemTop;\n        } else if (itemBottom > containerVisibleBottom) {\n          scrollContainer.scrollTop = itemBottom - scrollContainer.clientHeight;\n        }\n      }\n    }\n  }\n\n  @HostListener('keydown.tab', ['$event'])\n  _onTab(event: KeyboardEvent) {\n    if (this.isOpen) {\n      event.preventDefault();\n      this.close();\n    }\n  }\n\n  @HostListener('mousedown', ['$event'])\n  _onMouseDown(event: MouseEvent) {\n    if (this.disabled) {\n      event.preventDefault();\n      event.stopImmediatePropagation();\n    }\n  }\n\n  @HostListener('focus')\n  _onFocus() {\n    if (this.disabled) {\n      this.elementRef.nativeElement.blur();\n    }\n  }\n\n  _onPopoverWillHide() {\n    this.state = OpenState.closed;\n    this.elementRef.nativeElement.focus();\n  }\n\n  @HostListener('keydown.enter')\n  @HostListener('keydown.escape')\n  @HostListener('blur', ['$event'])\n  _onBlur(event?: FocusEvent) {\n    if (this.disabled) return;\n    if (this.isOpen) {\n      if (!this.cardElement.nativeElement.contains(event?.relatedTarget as HTMLElement)) {\n        this.close();\n      }\n    }\n    this._onTouched();\n  }\n\n  @HostListener('keydown.space', ['$event'])\n  _onSpace(event: KeyboardEvent) {\n    event.preventDefault();\n    event.stopPropagation();\n    if (!this.isOpen) {\n      this.open();\n    }\n  }\n\n  @HostListener('keydown.enter', ['$event'])\n  _onEnter(event: KeyboardEvent) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.toggle();\n  }\n\n  @HostListener('keydown.arrowup', ['$event'])\n  @HostListener('keydown.arrowdown', ['$event'])\n  @HostListener('keydown.arrowleft', ['$event'])\n  @HostListener('keydown.arrowright', ['$event'])\n  _onArrowKeys(event: KeyboardEvent) {\n    if (this.disabled) return;\n    // Mirror default HTML5 select behaviour - prevent left/right arrows when open:\n    if (this.isOpen && (event.key === 'ArrowLeft' || event.key === 'ArrowRight')) {\n      return;\n    }\n    const newIndex = this.keyboardHandlerService.handle(event, this.items, this.selectedIndex);\n    if (newIndex > -1) {\n      this.selectItem(newIndex);\n    }\n    return false;\n  }\n\n  @HostListener('keydown.home', ['$event'])\n  @HostListener('keydown.end', ['$event'])\n  _onHomeEndKeys(event: KeyboardEvent) {\n    if (this.disabled) return;\n    const newIndex = this.keyboardHandlerService.handle(event, this.items, this.selectedIndex);\n    if (newIndex > -1) {\n      this.selectItem(newIndex);\n    }\n    return false;\n  }\n\n  ngOnDestroy(): void {\n    let unlisten: () => void;\n    while ((unlisten = this.itemClickUnlisten.pop()) !== undefined) {\n      unlisten();\n    }\n    if (this.intersectionObserverRef) {\n      this.intersectionObserverRef.disconnect();\n    }\n  }\n}\n"]}
@@ -1 +1 @@
1
- [{"__symbolic":"module","version":4,"metadata":{"OpenState":{"closed":0,"opening":1,"open":2},"HorizontalDirection":{"right":"right","left":"left"},"DropdownComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":43,"character":1},"arguments":[{"selector":"kirby-dropdown","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":49,"character":15},"useExisting":{"__symbolic":"reference","name":"DropdownComponent"},"multi":true}],"template":"<button\n kirby-button\n [size]=\"size\"\n [attentionLevel]=\"isOpen ? attentionLevelOpen : attentionLevel\"\n tabindex=\"-1\"\n (click)=\"onToggle($event)\"\n (mousedown)=\"onButtonMouseEvent($event)\"\n [disabled]=\"disabled\"\n>\n <span class=\"text\">{{ selectedText || placeholder }}</span>\n <kirby-icon [name]=\"isOpen ? 'arrow-up' : 'arrow-down'\"></kirby-icon>\n</button>\n<kirby-card>\n <ng-container *ngFor=\"let item of items; let i = index\">\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate || defaultItemTemplate;\n context: { $implicit: item, selected: i === selectedIndex, index: i }\n \"\n ></ng-container>\n </ng-container>\n</kirby-card>\n\n<ng-template #defaultItemTemplate let-item let-selected=\"selected\" let-index=\"index\">\n <kirby-item [selectable]=\"true\" [selected]=\"selected\" (click)=\"onItemSelect(index)\" role=\"option\">\n <h3>{{ getTextFromItem(item) }}</h3>\n <kirby-icon *ngIf=\"selected\" name=\"checkmark-selected\" slot=\"end\"></kirby-icon>\n </kirby-item>\n</ng-template>\n","styles":[":host{--kirby_internal_min-screen-width:320px;display:inline-block;position:relative;max-width:calc(100vw - 32px);outline:none}@media (min-width:321px){:host{--kirby_internal_min-screen-width:375px}}:host.expand{display:block}:host:not(.expand) kirby-card{min-width:calc(var(--kirby_internal_min-screen-width) - 32px);max-width:calc(100vw - 32px)}@media (hover:hover){:host:focus>button,:host:focus>button.attention-level3{border-color:#4d90fe}}:host.error>button,:host.ng-touched.ng-invalid>button{border-color:var(--kirby-danger)}:host>button{position:relative;margin:0;outline:none;width:100%;transition:box-shadow .2s,border-color .2s}:host>button.attention-level2{border:1px solid transparent}:host>button .text{overflow:hidden;text-overflow:ellipsis}kirby-card{display:none;opacity:0;position:absolute;width:100%;max-height:352px;margin-top:4px;overflow-y:auto;box-shadow:0 20px 30px -15px rgba(28,28,28,.3),0 0 5px 0 rgba(28,28,28,.08);z-index:800}:host(.is-opening) kirby-card{display:block}:host(.is-open)>button{box-shadow:0 20px 30px -15px rgba(28,28,28,.3),0 0 5px 0 rgba(28,28,28,.08)}:host(.is-open) kirby-card{display:block;opacity:1}:host(.popout-left) kirby-card{right:0}:host(.popout-up) kirby-card{top:0;margin-top:-4px;transform:translateY(-100%)}:host(.popout-up).is-open>button{z-index:801}:host-context(kirby-calendar)>button{border-color:transparent;font-weight:700;font-size:medium}:host-context(kirby-calendar).is-open>button{box-shadow:none}"]}]}],"members":{"items":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"itemTextProperty":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":85,"character":3}}]}],"placeholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":88,"character":3}}]}],"popout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":91,"character":3}}]}],"attentionLevel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":99,"character":3}}]}],"expand":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":103,"character":3}}]}],"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":106,"character":3}}]}],"_isDisabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":109,"character":3},"arguments":["attr.disabled"]}]}],"hasError":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":114,"character":3},"arguments":["class.error"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":115,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":118,"character":3}}]}],"tabindex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":121,"character":3}}]}],"_tabindex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":124,"character":3},"arguments":["attr.tabindex"]}]}],"_noBlurOnScroll":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":130,"character":3},"arguments":["attr.no-blur"]}]}],"change":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":138,"character":3}}]}],"_isBlockLevel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":149,"character":3},"arguments":["class.expand"]}]}],"_role":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":154,"character":3},"arguments":["attr.role"]}]}],"_isOpening":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":157,"character":3},"arguments":["class.is-opening"]}]}],"isOpen":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":162,"character":3},"arguments":["class.is-open"]}]}],"_popoutLeft":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":167,"character":3},"arguments":["class.popout-left"]}]}],"_popoutUp":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":172,"character":3},"arguments":["class.popout-up"]}]}],"itemTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChild","line":177,"character":3},"arguments":[{"__symbolic":"reference","module":"../list/list.directive","name":"ListItemTemplateDirective","line":177,"character":16},{"static":true,"read":{"__symbolic":"reference","module":"@angular/core","name":"TemplateRef","line":177,"character":65}}]}]}],"slottedItems":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":179,"character":3},"arguments":[{"__symbolic":"reference","module":"../list/list.directive","name":"ListItemTemplateDirective","line":179,"character":19},{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":179,"character":54}}]}]}],"cardElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":181,"character":3},"arguments":[{"__symbolic":"reference","module":"../card/card.component","name":"CardComponent","line":181,"character":13},{"static":true,"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":181,"character":50}}]}]}],"kirbyItemsDefault":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":183,"character":3},"arguments":[{"__symbolic":"reference","module":"../item/item.component","name":"ItemComponent","line":183,"character":16},{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":183,"character":39}}]}]}],"kirbyItemsSlotted":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":185,"character":3},"arguments":[{"__symbolic":"reference","module":"../item/item.component","name":"ItemComponent","line":185,"character":19},{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":185,"character":42}}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":193,"character":22},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":194,"character":24,"arguments":[{"__symbolic":"error","message":"Could not resolve type","line":194,"character":35,"context":{"typeName":"HTMLElement"}}]},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":195,"character":31}]}],"onToggle":[{"__symbolic":"method"}],"toggle":[{"__symbolic":"method"}],"onButtonMouseEvent":[{"__symbolic":"method"}],"ngAfterContentChecked":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"initializeAlignment":[{"__symbolic":"method"}],"setHorizontalDirection":[{"__symbolic":"method"}],"setVerticalDirection":[{"__symbolic":"method"}],"open":[{"__symbolic":"method"}],"showDropdown":[{"__symbolic":"method"}],"close":[{"__symbolic":"method"}],"onItemSelect":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}],"selectItem":[{"__symbolic":"method"}],"_selectItemByValue":[{"__symbolic":"method"}],"getTextFromItem":[{"__symbolic":"method"}],"scrollItemIntoView":[{"__symbolic":"method"}],"_onTab":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":420,"character":3},"arguments":["keydown.tab",["$event"]]}]}],"_onMouseDown":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":428,"character":3},"arguments":["mousedown",["$event"]]}]}],"_onFocus":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":436,"character":3},"arguments":["focus"]}]}],"_onBlur":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":443,"character":3},"arguments":["keydown.enter"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":444,"character":3},"arguments":["keydown.escape"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":445,"character":3},"arguments":["blur"]}]}],"_onSpace":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":456,"character":3},"arguments":["keydown.space",["$event"]]}]}],"_onEnter":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":465,"character":3},"arguments":["keydown.enter",["$event"]]}]}],"_onArrowKeys":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":472,"character":3},"arguments":["keydown.arrowup",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":473,"character":3},"arguments":["keydown.arrowdown",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":474,"character":3},"arguments":["keydown.arrowleft",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":475,"character":3},"arguments":["keydown.arrowright",["$event"]]}]}],"_onHomeEndKeys":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":504,"character":3},"arguments":["keydown.home",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":505,"character":3},"arguments":["keydown.end",["$event"]]}]}],"ngOnDestroy":[{"__symbolic":"method"}]},"statics":{"OPEN_DELAY_IN_MS":100}}}}]
1
+ [{"__symbolic":"module","version":4,"metadata":{"DropdownComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":33,"character":1},"arguments":[{"selector":"kirby-dropdown","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":39,"character":15},"useExisting":{"__symbolic":"reference","name":"DropdownComponent"},"multi":true}],"template":"<button\n kirby-button\n [size]=\"size\"\n [attentionLevel]=\"isOpen ? attentionLevelOpen : attentionLevel\"\n tabindex=\"-1\"\n (click)=\"onToggle($event)\"\n (mousedown)=\"onButtonMouseEvent($event)\"\n [disabled]=\"disabled\"\n>\n <span class=\"text\">{{ selectedText || placeholder }}</span>\n <kirby-icon [name]=\"isOpen ? 'arrow-up' : 'arrow-down'\"></kirby-icon>\n</button>\n\n<ng-container *ngTemplateOutlet=\"usePopover ? popoverTemplate : itemWrapperTemplate\"></ng-container>\n\n<ng-template #popoverTemplate>\n <kirby-popover [target]=\"buttonElement\" [popout]=\"popout\" (willHide)=\"_onPopoverWillHide()\">\n <ng-container *ngTemplateOutlet=\"itemWrapperTemplate\"></ng-container>\n </kirby-popover>\n</ng-template>\n\n<ng-template #itemWrapperTemplate>\n <kirby-card>\n <ng-container *ngFor=\"let item of items; let i = index\">\n <ng-container\n *ngTemplateOutlet=\"\n itemTemplate || defaultItemTemplate;\n context: { $implicit: item, selected: i === selectedIndex, index: i }\n \"\n ></ng-container>\n </ng-container>\n </kirby-card>\n</ng-template>\n\n<ng-template #defaultItemTemplate let-item let-selected=\"selected\" let-index=\"index\">\n <kirby-item [selectable]=\"true\" [selected]=\"selected\" (click)=\"onItemSelect(index)\" role=\"option\">\n <!-- Tabindex fixes issue with popover dropdown not working in safari -->\n <h3 tabindex=\"0\">{{ getTextFromItem(item) }}</h3>\n <kirby-icon *ngIf=\"selected\" name=\"checkmark-selected\" slot=\"end\"></kirby-icon>\n </kirby-item>\n</ng-template>\n","styles":[":host{display:inline-block;position:relative;max-width:calc(100vw - 32px);outline:none}:host.expand{display:block}:host.expand kirby-card{width:100%;min-width:0;max-width:none}@media (hover:hover){:host:focus>button,:host:focus>button.attention-level3{border-color:#4d90fe}}:host.error>button,:host.ng-touched.ng-invalid>button{border-color:var(--kirby-danger)}:host>button{position:relative;margin:0;outline:none;width:100%;transition:box-shadow .2s,border-color .2s}:host>button.attention-level2{border:1px solid transparent}:host>button .text{overflow:hidden;text-overflow:ellipsis}kirby-popover{--max-height:352px}kirby-card{max-height:352px;margin-top:4px;margin-bottom:4px;overflow-y:auto;box-shadow:0 20px 30px -15px rgba(28,28,28,.3),0 0 5px 0 rgba(28,28,28,.08);min-width:288px;max-width:calc(100vw - 32px)}@media (min-width:321px){kirby-card{min-width:343px}}:host(:not(.with-popover)) kirby-card{display:none;opacity:0;position:absolute;z-index:800}:host(:not(.with-popover)).is-opening kirby-card{display:block}:host(:not(.with-popover)).is-open kirby-card{display:block;opacity:1}:host(:not(.with-popover)).popout-left kirby-card{right:0}:host(:not(.with-popover)).popout-up kirby-card{top:0;margin-top:-4px;transform:translateY(-100%)}:host(:not(.with-popover)).popout-up.is-open>button{z-index:801}:host(.is-open)>button{box-shadow:0 20px 30px -15px rgba(28,28,28,.3),0 0 5px 0 rgba(28,28,28,.08)}:host-context(kirby-calendar)>button{border-color:transparent;font-weight:700;font-size:medium}:host-context(kirby-calendar).is-open>button{box-shadow:none}"]}]}],"members":{"items":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":58,"character":3}}]}],"selectedIndex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":68,"character":3}}]}],"itemTextProperty":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":75,"character":3}}]}],"placeholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":78,"character":3}}]}],"popout":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":81,"character":3}}]}],"attentionLevel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":89,"character":3}}]}],"expand":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":93,"character":3}}]}],"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":96,"character":3}}]}],"_isDisabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":99,"character":3},"arguments":["attr.disabled"]}]}],"hasError":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":104,"character":3},"arguments":["class.error"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":105,"character":3}}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":108,"character":3}}]}],"tabindex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":111,"character":3}}]}],"usePopover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":114,"character":3},"arguments":["class.with-popover"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":115,"character":3}}]}],"_tabindex":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":118,"character":3},"arguments":["attr.tabindex"]}]}],"_noBlurOnScroll":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":124,"character":3},"arguments":["attr.no-blur"]}]}],"change":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":132,"character":3}}]}],"_isBlockLevel":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":143,"character":3},"arguments":["class.expand"]}]}],"_role":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":148,"character":3},"arguments":["attr.role"]}]}],"_isOpening":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":151,"character":3},"arguments":["class.is-opening"]}]}],"isOpen":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":156,"character":3},"arguments":["class.is-open"]}]}],"_popoutLeft":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":161,"character":3},"arguments":["class.popout-left"]}]}],"_popoutUp":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostBinding","line":166,"character":3},"arguments":["class.popout-up"]}]}],"itemTemplate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChild","line":171,"character":3},"arguments":[{"__symbolic":"reference","module":"../list/list.directive","name":"ListItemTemplateDirective","line":171,"character":16},{"static":true,"read":{"__symbolic":"reference","module":"@angular/core","name":"TemplateRef","line":171,"character":65}}]}]}],"slottedItems":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":173,"character":3},"arguments":[{"__symbolic":"reference","module":"../list/list.directive","name":"ListItemTemplateDirective","line":173,"character":19},{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":173,"character":54}}]}]}],"cardElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":175,"character":3},"arguments":[{"__symbolic":"reference","module":"../card/card.component","name":"CardComponent","line":175,"character":13},{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":175,"character":36}}]}]}],"popover":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":177,"character":3},"arguments":[{"__symbolic":"reference","module":"../popover/popover.component","name":"PopoverComponent","line":177,"character":13}]}]}],"buttonElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":179,"character":3},"arguments":[{"__symbolic":"reference","module":"../button/button.component","name":"ButtonComponent","line":179,"character":13},{"static":true,"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":179,"character":52}}]}]}],"kirbyItemsDefault":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChildren","line":181,"character":3},"arguments":[{"__symbolic":"reference","module":"../item/item.component","name":"ItemComponent","line":181,"character":16},{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":181,"character":39}}]}]}],"kirbyItemsSlotted":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ContentChildren","line":183,"character":3},"arguments":[{"__symbolic":"reference","module":"../item/item.component","name":"ItemComponent","line":183,"character":19},{"read":{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":183,"character":42}}]}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":191,"character":22},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":192,"character":24,"arguments":[{"__symbolic":"error","message":"Could not resolve type","line":192,"character":35,"context":{"typeName":"HTMLElement"}}]},{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectorRef","line":193,"character":31},{"__symbolic":"reference","module":"./keyboard-handler.service","name":"KeyboardHandlerService","line":194,"character":36}]}],"onToggle":[{"__symbolic":"method"}],"toggle":[{"__symbolic":"method"}],"onButtonMouseEvent":[{"__symbolic":"method"}],"ngAfterContentChecked":[{"__symbolic":"method"}],"setPopoverCardStyle":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"initializeAlignment":[{"__symbolic":"method"}],"setHorizontalDirection":[{"__symbolic":"method"}],"setVerticalDirection":[{"__symbolic":"method"}],"open":[{"__symbolic":"method"}],"showDropdown":[{"__symbolic":"method"}],"close":[{"__symbolic":"method"}],"onItemSelect":[{"__symbolic":"method"}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}],"selectItem":[{"__symbolic":"method"}],"_selectItemByValue":[{"__symbolic":"method"}],"getTextFromItem":[{"__symbolic":"method"}],"scrollItemIntoView":[{"__symbolic":"method"}],"_onTab":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":441,"character":3},"arguments":["keydown.tab",["$event"]]}]}],"_onMouseDown":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":449,"character":3},"arguments":["mousedown",["$event"]]}]}],"_onFocus":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":457,"character":3},"arguments":["focus"]}]}],"_onPopoverWillHide":[{"__symbolic":"method"}],"_onBlur":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":469,"character":3},"arguments":["keydown.enter"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":470,"character":3},"arguments":["keydown.escape"]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":471,"character":3},"arguments":["blur",["$event"]]}]}],"_onSpace":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":482,"character":3},"arguments":["keydown.space",["$event"]]}]}],"_onEnter":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":491,"character":3},"arguments":["keydown.enter",["$event"]]}]}],"_onArrowKeys":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":498,"character":3},"arguments":["keydown.arrowup",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":499,"character":3},"arguments":["keydown.arrowdown",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":500,"character":3},"arguments":["keydown.arrowleft",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":501,"character":3},"arguments":["keydown.arrowright",["$event"]]}]}],"_onHomeEndKeys":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":515,"character":3},"arguments":["keydown.home",["$event"]]},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":516,"character":3},"arguments":["keydown.end",["$event"]]}]}],"ngOnDestroy":[{"__symbolic":"method"}]},"statics":{"OPEN_DELAY_IN_MS":100}}}}]
@@ -0,0 +1,12 @@
1
+ export var OpenState;
2
+ (function (OpenState) {
3
+ OpenState[OpenState["closed"] = 0] = "closed";
4
+ OpenState[OpenState["opening"] = 1] = "opening";
5
+ OpenState[OpenState["open"] = 2] = "open";
6
+ })(OpenState || (OpenState = {}));
7
+ export var VerticalDirection;
8
+ (function (VerticalDirection) {
9
+ VerticalDirection[VerticalDirection["up"] = 0] = "up";
10
+ VerticalDirection[VerticalDirection["down"] = 1] = "down";
11
+ })(VerticalDirection || (VerticalDirection = {}));
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24udHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Rlc2lnbnN5c3RlbS9zcmMvbGliL2NvbXBvbmVudHMvZHJvcGRvd24vZHJvcGRvd24udHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksU0FJWDtBQUpELFdBQVksU0FBUztJQUNuQiw2Q0FBTSxDQUFBO0lBQ04sK0NBQU8sQ0FBQTtJQUNQLHlDQUFJLENBQUE7QUFDTixDQUFDLEVBSlcsU0FBUyxLQUFULFNBQVMsUUFJcEI7QUFFRCxNQUFNLENBQU4sSUFBWSxpQkFHWDtBQUhELFdBQVksaUJBQWlCO0lBQzNCLHFEQUFFLENBQUE7SUFDRix5REFBSSxDQUFBO0FBQ04sQ0FBQyxFQUhXLGlCQUFpQixLQUFqQixpQkFBaUIsUUFHNUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBPcGVuU3RhdGUge1xuICBjbG9zZWQsXG4gIG9wZW5pbmcsXG4gIG9wZW4sXG59XG5cbmV4cG9ydCBlbnVtIFZlcnRpY2FsRGlyZWN0aW9uIHtcbiAgdXAsXG4gIGRvd24sXG59XG4iXX0=
@@ -0,0 +1 @@
1
+ [{"__symbolic":"module","version":4,"metadata":{"OpenState":{"closed":0,"opening":1,"open":2},"VerticalDirection":{"up":0,"down":1}}}]
@@ -0,0 +1,43 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class KeyboardHandlerService {
4
+ handle(event, items, selectedIndex) {
5
+ let newIndex = -1;
6
+ switch (event.key) {
7
+ case 'ArrowUp':
8
+ case 'ArrowLeft':
9
+ // Select previous item:
10
+ newIndex = selectedIndex - 1;
11
+ break;
12
+ case 'ArrowDown':
13
+ case 'ArrowRight':
14
+ if (selectedIndex === undefined) {
15
+ // None selected, select first item:
16
+ newIndex = 0;
17
+ }
18
+ else if (selectedIndex < items.length - 1) {
19
+ // Select next item:
20
+ newIndex = selectedIndex + 1;
21
+ }
22
+ break;
23
+ case 'Home':
24
+ // Select first item:
25
+ newIndex = 0;
26
+ break;
27
+ case 'End':
28
+ // Select last item:
29
+ newIndex = items.length - 1;
30
+ break;
31
+ default:
32
+ break;
33
+ }
34
+ return newIndex;
35
+ }
36
+ }
37
+ /** @nocollapse */ KeyboardHandlerService.ɵprov = i0.ɵɵdefineInjectable({ factory: function KeyboardHandlerService_Factory() { return new KeyboardHandlerService(); }, token: KeyboardHandlerService, providedIn: "root" });
38
+ KeyboardHandlerService.decorators = [
39
+ { type: Injectable, args: [{
40
+ providedIn: 'root',
41
+ },] }
42
+ ];
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Ym9hcmQtaGFuZGxlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ25zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2Ryb3Bkb3duL2tleWJvYXJkLWhhbmRsZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLE1BQU0sQ0FBQyxLQUFvQixFQUFFLEtBQXVCLEVBQUUsYUFBcUI7UUFDekUsSUFBSSxRQUFRLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDbEIsUUFBUSxLQUFLLENBQUMsR0FBRyxFQUFFO1lBQ2pCLEtBQUssU0FBUyxDQUFDO1lBQ2YsS0FBSyxXQUFXO2dCQUNkLHdCQUF3QjtnQkFDeEIsUUFBUSxHQUFHLGFBQWEsR0FBRyxDQUFDLENBQUM7Z0JBQzdCLE1BQU07WUFDUixLQUFLLFdBQVcsQ0FBQztZQUNqQixLQUFLLFlBQVk7Z0JBQ2YsSUFBSSxhQUFhLEtBQUssU0FBUyxFQUFFO29CQUMvQixvQ0FBb0M7b0JBQ3BDLFFBQVEsR0FBRyxDQUFDLENBQUM7aUJBQ2Q7cUJBQU0sSUFBSSxhQUFhLEdBQUcsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7b0JBQzNDLG9CQUFvQjtvQkFDcEIsUUFBUSxHQUFHLGFBQWEsR0FBRyxDQUFDLENBQUM7aUJBQzlCO2dCQUNELE1BQU07WUFDUixLQUFLLE1BQU07Z0JBQ1QscUJBQXFCO2dCQUNyQixRQUFRLEdBQUcsQ0FBQyxDQUFDO2dCQUNiLE1BQU07WUFDUixLQUFLLEtBQUs7Z0JBQ1Isb0JBQW9CO2dCQUNwQixRQUFRLEdBQUcsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7Z0JBQzVCLE1BQU07WUFDUjtnQkFDRSxNQUFNO1NBQ1Q7UUFDRCxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDOzs7O1lBbENGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEtleWJvYXJkSGFuZGxlclNlcnZpY2Uge1xuICBoYW5kbGUoZXZlbnQ6IEtleWJvYXJkRXZlbnQsIGl0ZW1zOiBhbnlbXSB8IHN0cmluZ1tdLCBzZWxlY3RlZEluZGV4OiBudW1iZXIpIHtcbiAgICBsZXQgbmV3SW5kZXggPSAtMTtcbiAgICBzd2l0Y2ggKGV2ZW50LmtleSkge1xuICAgICAgY2FzZSAnQXJyb3dVcCc6XG4gICAgICBjYXNlICdBcnJvd0xlZnQnOlxuICAgICAgICAvLyBTZWxlY3QgcHJldmlvdXMgaXRlbTpcbiAgICAgICAgbmV3SW5kZXggPSBzZWxlY3RlZEluZGV4IC0gMTtcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlICdBcnJvd0Rvd24nOlxuICAgICAgY2FzZSAnQXJyb3dSaWdodCc6XG4gICAgICAgIGlmIChzZWxlY3RlZEluZGV4ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAvLyBOb25lIHNlbGVjdGVkLCBzZWxlY3QgZmlyc3QgaXRlbTpcbiAgICAgICAgICBuZXdJbmRleCA9IDA7XG4gICAgICAgIH0gZWxzZSBpZiAoc2VsZWN0ZWRJbmRleCA8IGl0ZW1zLmxlbmd0aCAtIDEpIHtcbiAgICAgICAgICAvLyBTZWxlY3QgbmV4dCBpdGVtOlxuICAgICAgICAgIG5ld0luZGV4ID0gc2VsZWN0ZWRJbmRleCArIDE7XG4gICAgICAgIH1cbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlICdIb21lJzpcbiAgICAgICAgLy8gU2VsZWN0IGZpcnN0IGl0ZW06XG4gICAgICAgIG5ld0luZGV4ID0gMDtcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlICdFbmQnOlxuICAgICAgICAvLyBTZWxlY3QgbGFzdCBpdGVtOlxuICAgICAgICBuZXdJbmRleCA9IGl0ZW1zLmxlbmd0aCAtIDE7XG4gICAgICAgIGJyZWFrO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgYnJlYWs7XG4gICAgfVxuICAgIHJldHVybiBuZXdJbmRleDtcbiAgfVxufVxuIl19
@@ -0,0 +1 @@
1
+ [{"__symbolic":"module","version":4,"metadata":{"KeyboardHandlerService":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Injectable","line":2,"character":1},"arguments":[{"providedIn":"root"}]}],"members":{"handle":[{"__symbolic":"method"}]},"statics":{"ɵprov":{}}}}}]