@sebgroup/green-angular 4.6.2 → 4.6.4

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 (101) hide show
  1. package/esm2022/src/v-angular/base-control-value-accessor/base-control-value-accessor.component.mjs +9 -9
  2. package/esm2022/src/v-angular/button/button.component.mjs +5 -5
  3. package/esm2022/src/v-angular/character-countdown/character-countdown.directive.mjs +5 -5
  4. package/esm2022/src/v-angular/core/core.globals.mjs +3 -3
  5. package/esm2022/src/v-angular/dropdown/dropdown-list/dropdown-list.component.mjs +4 -4
  6. package/esm2022/src/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.mjs +5 -5
  7. package/esm2022/src/v-angular/dropdown/typeahead/typeahead.directive.mjs +7 -7
  8. package/esm2022/src/v-angular/info-circle/info-circle.component.mjs +4 -4
  9. package/esm2022/src/v-angular/input/input.component.mjs +7 -7
  10. package/esm2022/src/v-angular/input-mask/input-mask-format.pipe.mjs +5 -4
  11. package/esm2022/src/v-angular/input-mask/input-mask.directive.mjs +8 -8
  12. package/esm2022/src/v-angular/modal/dialog/dialog.component.mjs +16 -16
  13. package/esm2022/src/v-angular/modal/fold-out/fold-out.component.mjs +2 -2
  14. package/esm2022/src/v-angular/modal/fold-out/fold-out.directive.mjs +3 -3
  15. package/esm2022/src/v-angular/modal/modal.globals.mjs +3 -3
  16. package/esm2022/src/v-angular/modal/slide-out/slide-out.component.mjs +15 -15
  17. package/esm2022/src/v-angular/textarea/textarea.component.mjs +4 -3
  18. package/esm2022/src/v-angular/textarea/textarea.module.mjs +5 -4
  19. package/esm2022/src/v-angular/tooltip/tooltip.directive.mjs +13 -13
  20. package/esm2022/v-angular/base-control-value-accessor/base-control-value-accessor.component.mjs +9 -9
  21. package/esm2022/v-angular/button/button.component.mjs +5 -5
  22. package/esm2022/v-angular/character-countdown/character-countdown.directive.mjs +51 -0
  23. package/esm2022/v-angular/character-countdown/character-countdown.module.mjs +18 -0
  24. package/esm2022/v-angular/character-countdown/index.mjs +3 -0
  25. package/esm2022/v-angular/dropdown/dropdown-list/dropdown-list.component.mjs +4 -4
  26. package/esm2022/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.mjs +5 -5
  27. package/esm2022/v-angular/dropdown/typeahead/typeahead.directive.mjs +7 -7
  28. package/esm2022/v-angular/index.mjs +2 -1
  29. package/esm2022/v-angular/info-circle/info-circle.component.mjs +4 -4
  30. package/esm2022/v-angular/input/input.component.mjs +7 -7
  31. package/esm2022/v-angular/input-mask/input-mask-format.pipe.mjs +5 -4
  32. package/esm2022/v-angular/input-mask/input-mask.directive.mjs +8 -8
  33. package/esm2022/v-angular/modal/dialog/dialog.component.mjs +16 -16
  34. package/esm2022/v-angular/modal/fold-out/fold-out.component.mjs +2 -2
  35. package/esm2022/v-angular/modal/fold-out/fold-out.directive.mjs +3 -3
  36. package/esm2022/v-angular/modal/modal.globals.mjs +3 -3
  37. package/esm2022/v-angular/modal/slide-out/slide-out.component.mjs +15 -15
  38. package/esm2022/v-angular/textarea/textarea.component.mjs +4 -3
  39. package/esm2022/v-angular/textarea/textarea.module.mjs +5 -4
  40. package/esm2022/v-angular/tooltip/tooltip.directive.mjs +13 -13
  41. package/esm2022/v-angular/v-angular.module.mjs +5 -1
  42. package/fesm2022/sebgroup-green-angular-src-v-angular-base-control-value-accessor.mjs +8 -8
  43. package/fesm2022/sebgroup-green-angular-src-v-angular-base-control-value-accessor.mjs.map +1 -1
  44. package/fesm2022/sebgroup-green-angular-src-v-angular-button.mjs +4 -4
  45. package/fesm2022/sebgroup-green-angular-src-v-angular-button.mjs.map +1 -1
  46. package/fesm2022/sebgroup-green-angular-src-v-angular-character-countdown.mjs +4 -4
  47. package/fesm2022/sebgroup-green-angular-src-v-angular-character-countdown.mjs.map +1 -1
  48. package/fesm2022/sebgroup-green-angular-src-v-angular-core.mjs +2 -2
  49. package/fesm2022/sebgroup-green-angular-src-v-angular-core.mjs.map +1 -1
  50. package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs +13 -13
  51. package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs.map +1 -1
  52. package/fesm2022/sebgroup-green-angular-src-v-angular-info-circle.mjs +3 -3
  53. package/fesm2022/sebgroup-green-angular-src-v-angular-info-circle.mjs.map +1 -1
  54. package/fesm2022/sebgroup-green-angular-src-v-angular-input-mask.mjs +11 -10
  55. package/fesm2022/sebgroup-green-angular-src-v-angular-input-mask.mjs.map +1 -1
  56. package/fesm2022/sebgroup-green-angular-src-v-angular-input.mjs +6 -6
  57. package/fesm2022/sebgroup-green-angular-src-v-angular-input.mjs.map +1 -1
  58. package/fesm2022/sebgroup-green-angular-src-v-angular-modal.mjs +34 -34
  59. package/fesm2022/sebgroup-green-angular-src-v-angular-modal.mjs.map +1 -1
  60. package/fesm2022/sebgroup-green-angular-src-v-angular-textarea.mjs +7 -5
  61. package/fesm2022/sebgroup-green-angular-src-v-angular-textarea.mjs.map +1 -1
  62. package/fesm2022/sebgroup-green-angular-src-v-angular-tooltip.mjs +12 -12
  63. package/fesm2022/sebgroup-green-angular-src-v-angular-tooltip.mjs.map +1 -1
  64. package/fesm2022/sebgroup-green-angular-v-angular.mjs +164 -97
  65. package/fesm2022/sebgroup-green-angular-v-angular.mjs.map +1 -1
  66. package/package.json +2 -2
  67. package/src/v-angular/base-control-value-accessor/base-control-value-accessor.component.d.ts +3 -3
  68. package/src/v-angular/button/button.component.d.ts +2 -2
  69. package/src/v-angular/character-countdown/character-countdown.directive.d.ts +1 -1
  70. package/src/v-angular/core/core.globals.d.ts +1 -1
  71. package/src/v-angular/dropdown/typeahead/typeahead.directive.d.ts +2 -2
  72. package/src/v-angular/info-circle/info-circle.component.d.ts +1 -1
  73. package/src/v-angular/input/input.component.d.ts +3 -3
  74. package/src/v-angular/input-mask/input-mask-format.pipe.d.ts +1 -1
  75. package/src/v-angular/input-mask/input-mask.directive.d.ts +2 -2
  76. package/src/v-angular/modal/dialog/dialog.component.d.ts +5 -5
  77. package/src/v-angular/modal/fold-out/fold-out.component.d.ts +1 -1
  78. package/src/v-angular/modal/fold-out/fold-out.directive.d.ts +1 -1
  79. package/src/v-angular/modal/modal.globals.d.ts +1 -1
  80. package/src/v-angular/modal/slide-out/slide-out.component.d.ts +6 -6
  81. package/src/v-angular/textarea/textarea.module.d.ts +2 -1
  82. package/src/v-angular/tooltip/tooltip.directive.d.ts +4 -4
  83. package/v-angular/base-control-value-accessor/base-control-value-accessor.component.d.ts +3 -3
  84. package/v-angular/button/button.component.d.ts +2 -2
  85. package/v-angular/character-countdown/character-countdown.directive.d.ts +17 -0
  86. package/v-angular/character-countdown/character-countdown.module.d.ts +8 -0
  87. package/v-angular/character-countdown/index.d.ts +2 -0
  88. package/v-angular/dropdown/typeahead/typeahead.directive.d.ts +2 -2
  89. package/v-angular/index.d.ts +1 -0
  90. package/v-angular/info-circle/info-circle.component.d.ts +1 -1
  91. package/v-angular/input/input.component.d.ts +3 -3
  92. package/v-angular/input-mask/input-mask-format.pipe.d.ts +1 -1
  93. package/v-angular/input-mask/input-mask.directive.d.ts +2 -2
  94. package/v-angular/modal/dialog/dialog.component.d.ts +5 -5
  95. package/v-angular/modal/fold-out/fold-out.component.d.ts +1 -1
  96. package/v-angular/modal/fold-out/fold-out.directive.d.ts +1 -1
  97. package/v-angular/modal/modal.globals.d.ts +1 -1
  98. package/v-angular/modal/slide-out/slide-out.component.d.ts +6 -6
  99. package/v-angular/textarea/textarea.module.d.ts +2 -1
  100. package/v-angular/tooltip/tooltip.directive.d.ts +4 -4
  101. package/v-angular/v-angular.module.d.ts +13 -12
@@ -73,7 +73,7 @@ export class NgvBaseControlValueAccessorComponent {
73
73
  this.cdr = cdr;
74
74
  /* ATTRIBUTES */
75
75
  /** Id of the host element and is accessible by the children, automatically generated if not provided. */
76
- this.id = window.ngv?.nextId();
76
+ this.id = window.nggv?.nextId();
77
77
  /** If set to true, the browser will try to automatically set focus to the child input element. */
78
78
  this.autofocus = false;
79
79
  this._locked = undefined;
@@ -86,9 +86,9 @@ export class NgvBaseControlValueAccessorComponent {
86
86
  this._disabled = undefined;
87
87
  /* TRIGGERS */
88
88
  /** Emits focus events triggered by the child elements. */
89
- this.ngvFocus = new EventEmitter();
89
+ this.nggvFocus = new EventEmitter();
90
90
  /** Emits focus events triggered by the child elements. */
91
- this.ngvBlur = new EventEmitter();
91
+ this.nggvBlur = new EventEmitter();
92
92
  /* VALUE HANDLERS */
93
93
  this._state = null;
94
94
  /** @internal */
@@ -145,7 +145,7 @@ export class NgvBaseControlValueAccessorComponent {
145
145
  ? event.stopPropagation()
146
146
  : (event.cancelBubble = true);
147
147
  this.focused = true;
148
- this.ngvFocus.emit(event);
148
+ this.nggvFocus.emit(event);
149
149
  }
150
150
  /** @internal */
151
151
  onBlur(event) {
@@ -154,7 +154,7 @@ export class NgvBaseControlValueAccessorComponent {
154
154
  : (event.cancelBubble = true);
155
155
  this.onTouched();
156
156
  this.focused = false;
157
- this.ngvBlur.emit(event);
157
+ this.nggvBlur.emit(event);
158
158
  }
159
159
  /** Sets the focus on the actual input element. */
160
160
  setFocus() {
@@ -217,7 +217,7 @@ export class NgvBaseControlValueAccessorComponent {
217
217
  return { code, params: errors[code] };
218
218
  }
219
219
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: TRANSLOCO_SCOPE, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
220
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvBaseControlValueAccessorComponent, selector: "ng-component", inputs: { id: "id", name: "name", label: "label", role: "role", value: "value", error: "error", description: "description", autofocus: "autofocus", defaultValue: "defaultValue", reset: "reset", optional: "optional", locked: "locked", displayDisabledAsLocked: "displayDisabledAsLocked", required: "required", invalid: "invalid", valid: "valid", focused: "focused", disabled: "disabled" }, outputs: { ngvFocus: "ngvFocus", ngvBlur: "ngvBlur" }, host: { properties: { "attr.id": "this.id" } }, queries: [{ propertyName: "labelContentTpl", first: true, predicate: ["labelTpl"], descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["input"], descendants: true, read: ElementRef }], ngImport: i0, template: '', isInline: true }); }
220
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvBaseControlValueAccessorComponent, selector: "ng-component", inputs: { id: "id", name: "name", label: "label", role: "role", value: "value", error: "error", description: "description", autofocus: "autofocus", defaultValue: "defaultValue", reset: "reset", optional: "optional", locked: "locked", displayDisabledAsLocked: "displayDisabledAsLocked", required: "required", invalid: "invalid", valid: "valid", focused: "focused", disabled: "disabled" }, outputs: { nggvFocus: "nggvFocus", nggvBlur: "nggvBlur" }, host: { properties: { "attr.id": "this.id" } }, queries: [{ propertyName: "labelContentTpl", first: true, predicate: ["labelTpl"], descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["input"], descendants: true, read: ElementRef }], ngImport: i0, template: '', isInline: true }); }
221
221
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorComponent }); }
222
222
  }
223
223
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorComponent, decorators: [{
@@ -279,9 +279,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
279
279
  type: Input
280
280
  }], disabled: [{
281
281
  type: Input
282
- }], ngvFocus: [{
282
+ }], nggvFocus: [{
283
283
  type: Output
284
- }], ngvBlur: [{
284
+ }], nggvBlur: [{
285
285
  type: Output
286
286
  }] } });
287
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-control-value-accessor.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/v-angular/base-control-value-accessor/base-control-value-accessor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  ContentChild,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Injectable,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NgControl,\n  ValidationErrors,\n  Validator,\n  Validators,\n} from '@angular/forms'\n\nimport { Observable, Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@ngneat/transloco'\n\n@Injectable() // Workaround for Compodoc https://github.com/compodoc/compodoc/issues/984\n@Component({ template: '' }) // Required with Angular ivy compiler\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport class NgvBaseControlValueAccessorComponent\n  implements AfterViewInit, OnInit, OnDestroy, ControlValueAccessor, Validator\n{\n  /** Custom template for displaying the content of the label.\n   * Specified by nesting an `<ng-template #labelTpl>Custom Label</ng-template>`.\n   */\n  @ContentChild('labelTpl', { read: TemplateRef })\n  labelContentTpl?: TemplateRef<undefined>\n\n  /** Reference to the native child input element. */\n  @ViewChild('input', { read: ElementRef }) inputRef?: ElementRef\n\n  /* ATTRIBUTES */\n\n  /** Id of the host element and is accessible by the children, automatically generated if not provided. */\n  @HostBinding('attr.id') @Input() id = (window as any).ngv?.nextId()\n  /** Name of the child input element. */\n  @Input() name?: string\n  /**\n   * Label of the child input element using the default template.\n   * Can be overwritten by specifying an `<ng-template #labelTpl>Custom Label</ng-template>`.\n   */\n  @Input() label?: string\n  /** Role of the child input element. https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles */\n  @Input() role?: string\n  /** Value of the child input element. Mostly used in conjunction with radio and checkboxes. */\n  @Input() value: any\n  /** An error string to be shown under invalid inputs. Overwrites any form errors. */\n  @Input() error?: string\n  /** Description of the child input element. Both visibly and as `aria-label`. */\n  @Input() description?: string\n  /** If set to true, the browser will try to automatically set focus to the child input element. */\n  @Input() autofocus = false\n  /** Deafult value of the child input element. Used when resetting child element. */\n  @Input() defaultValue?: any\n  /** If passed, the component will listen for updates and will reset its value. */\n  @Input() reset?: Observable<any>\n  /** Adds (Optional) to input label. */\n  @Input() optional?: boolean | null | undefined\n\n  private _locked: boolean | null | undefined = undefined\n  /** Hides the input borders and displays current value as a text. */\n  @Input() set locked(value: boolean | null | undefined) {\n    this._locked = value\n    this.cdr.detectChanges()\n  }\n  get locked(): boolean | null | undefined {\n    return this._locked\n  }\n  /** If set to true, using a controls disabled state will display input as locked. */\n  @Input() displayDisabledAsLocked?: boolean | null | undefined\n\n  /* STATES */\n\n  private _required: boolean | null | undefined = undefined\n  /** Override the required flag of the component. */\n  @Input() set required(value: boolean | null | undefined) {\n    this._required = value\n  }\n  /** Child input element is considered required and changes default label template accordingly. */\n  get required(): boolean | null | undefined {\n    // if required is set => return required\n    if (this._required !== undefined) return this._required\n\n    // if required can be determined from the control => return control.required\n    if (this.ngControl?.control?.validator) {\n      const validator = this.ngControl?.control?.validator(\n        {} as AbstractControl,\n      )\n      // returns true for any error that starts with required\n      return Object.keys(validator ?? {}).some((key) =>\n        key.startsWith('required'),\n      )\n    }\n\n    return\n  }\n\n  private _invalid: boolean | undefined = undefined\n  /** Override the invalid state of the component. */\n  @Input() set invalid(value: boolean) {\n    this._invalid = value\n  }\n  /** The component has the invalid state, usually decorating the elements red and shows the first error. */\n  get invalid(): boolean {\n    if (this._invalid === true || this._invalid === false) return this._invalid\n    return (\n      !!this.ngControl?.control?.invalid && this.ngControl?.control?.touched\n    )\n  }\n\n  private _valid: boolean | undefined = undefined\n  /** Override the valid state of the component. */\n  @Input() set valid(value: boolean) {\n    this._valid = value\n  }\n  /** The component has the valid state, usually decorating the elements green. */\n  get valid(): boolean {\n    if (this._valid === true || this._valid === false) return this._valid\n    return !!this.ngControl?.control?.valid && this.ngControl?.control?.touched\n  }\n\n  /** The component has the focused state, updated by the child input element's focus state. */\n  @Input() focused = false\n\n  private _disabled: boolean | undefined = undefined\n  /** Override the disabled state of the component. */\n  @Input() set disabled(value: boolean) {\n    this._disabled = value\n  }\n  /** The component has the disabled state, usually muting the colors and removes interaction. */\n  get disabled(): boolean {\n    if (this._disabled === true || this._disabled === false)\n      return this._disabled\n    return !!this.ngControl?.control?.disabled\n  }\n\n  /* TRIGGERS */\n\n  /** Emits focus events triggered by the child elements. */\n  @Output() readonly ngvFocus = new EventEmitter()\n  /** Emits focus events triggered by the child elements. */\n  @Output() readonly ngvBlur = new EventEmitter()\n\n  /* VALUE HANDLERS */\n\n  private _state: any = null\n  /** @internal */\n  protected onChange = (_: any) => {\n    // do nothing\n  }\n  /** @internal */\n  protected onTouched = () => {\n    // do nothing\n  }\n  /** @internal */\n  protected onValidatorChange: () => void = () => null\n\n  /* OTHER VARIABLES */\n  scope: string | undefined\n\n  /* LIFE CYCLE VARIABLES */\n\n  private _onDestroy$ = new Subject<boolean>()\n\n  /**\n   * Creates a new BaseControlValueAccessorComponent.\n   * @param ngControl optional FormControl provided when component is used in a form, through dependency injection.\n   * @param translocoScope optional TranslocoScope provided if component is used within a scope.\n   */\n  constructor(\n    @Self() @Optional() public ngControl: NgControl,\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n    protected cdr: ChangeDetectorRef,\n  ) {\n    if (this.ngControl) {\n      // Note: we provide the value accessor through here, instead of\n      // the `providers` to avoid running into a circular import.\n      this.ngControl.valueAccessor = this\n    }\n\n    if (this.translocoScope) this.scope = this.translocoScope.toString()\n  }\n\n  // eslint-disable-next-line @angular-eslint/contextual-lifecycle\n  ngOnInit(): void {\n    if (this.ngControl && this.ngControl.control) {\n      this.ngControl.control.setValidators(\n        Validators.compose([this.ngControl.control.validator, this.validate]),\n      )\n    }\n\n    // if reset observable has been passed, subscribe after updates\n    this.reset?.pipe(takeUntil(this._onDestroy$)).subscribe({\n      next: () => {\n        // reset value of controller\n        this.state = this.defaultValue\n        this.onChange(this.state)\n        this.cdr.detectChanges()\n      },\n    })\n  }\n\n  // eslint-disable-next-line @angular-eslint/contextual-lifecycle\n  ngAfterViewInit(): void {\n    // if default value is set, then don't alter it. Otherwise, use\n    // current value of controller after initiation as default value\n    this.defaultValue = this.defaultValue ?? this.ngControl?.value\n  }\n\n  ngOnDestroy(): void {\n    this._onDestroy$.next(true)\n    this._onDestroy$.complete()\n  }\n\n  detectChanges(): void {\n    this.cdr.detectChanges()\n  }\n\n  /** @internal */\n  onFocus(event: Event) {\n    event.stopPropagation\n      ? event.stopPropagation()\n      : (event.cancelBubble = true)\n    this.focused = true\n    this.ngvFocus.emit(event)\n  }\n\n  /** @internal */\n  onBlur(event: Event) {\n    event.stopPropagation\n      ? event.stopPropagation()\n      : (event.cancelBubble = true)\n    this.onTouched()\n    this.focused = false\n    this.ngvBlur.emit(event)\n  }\n\n  /** Sets the focus on the actual input element. */\n  setFocus() {\n    if (this.inputRef) this.inputRef.nativeElement.focus()\n  }\n\n  // ----------------------------------------------------------------------------\n  // CONTROL VALUE ACCESSOR\n  // ----------------------------------------------------------------------------\n\n  /** Internal state/value that the native input element has.  */\n  get state() {\n    return this._state\n  }\n\n  /** Internal state/value that the native input element has.  */\n  set state(value) {\n    if (typeof value === 'undefined') value = null\n    this._state = value\n  }\n\n  /** Writes a new value to the child input element. */\n  writeValue(value: any): void {\n    this.state = value\n  }\n\n  /** Registers a callback function that is called when the child input element's value changes. */\n  registerOnChange(fn: (_: any) => object): void {\n    this.onChange = fn\n  }\n\n  /** Registers a callback function that is called when the child input element triggers on blur. */\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn\n  }\n\n  /** Function that is called by the forms API when the control status changes to or from 'DISABLED'. */\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled\n\n    // if displayDisabledAsLocked is enabled - update locked state based on disabled state\n    if (this.displayDisabledAsLocked) {\n      this.locked = isDisabled\n    }\n  }\n\n  // ----------------------------------------------------------------------------\n  // VALIDATORS\n  // ----------------------------------------------------------------------------\n\n  /** Method that performs synchronous validation against the provided control. Used for internal validation. */\n  validate(_control: AbstractControl): { [name: string]: any } | null {\n    return null\n  }\n\n  /** Registers a callback function to call when the validator inputs change. */\n  registerOnValidatorChange(fn: () => void): void {\n    this.onValidatorChange = fn\n  }\n\n  // ----------------------------------------------------------------------------\n  // HELPERS\n  // ----------------------------------------------------------------------------\n\n  /** Returns the first entry in an error object. */\n  get firstError(): { code: string; params: any } | null {\n    const errors: ValidationErrors | null = this.ngControl.errors\n    if (!errors) return null\n    const code: string = Object.keys(errors)[0]\n    return { code, params: errors[code] }\n  }\n}\n"]}
287
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-control-value-accessor.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/v-angular/base-control-value-accessor/base-control-value-accessor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  ContentChild,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Injectable,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NgControl,\n  ValidationErrors,\n  Validator,\n  Validators,\n} from '@angular/forms'\n\nimport { Observable, Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@ngneat/transloco'\n\n@Injectable() // Workaround for Compodoc https://github.com/compodoc/compodoc/issues/984\n@Component({ template: '' }) // Required with Angular ivy compiler\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport class NgvBaseControlValueAccessorComponent\n  implements AfterViewInit, OnInit, OnDestroy, ControlValueAccessor, Validator\n{\n  /** Custom template for displaying the content of the label.\n   * Specified by nesting an `<ng-template #labelTpl>Custom Label</ng-template>`.\n   */\n  @ContentChild('labelTpl', { read: TemplateRef })\n  labelContentTpl?: TemplateRef<undefined>\n\n  /** Reference to the native child input element. */\n  @ViewChild('input', { read: ElementRef }) inputRef?: ElementRef\n\n  /* ATTRIBUTES */\n\n  /** Id of the host element and is accessible by the children, automatically generated if not provided. */\n  @HostBinding('attr.id') @Input() id = (window as any).nggv?.nextId()\n  /** Name of the child input element. */\n  @Input() name?: string\n  /**\n   * Label of the child input element using the default template.\n   * Can be overwritten by specifying an `<ng-template #labelTpl>Custom Label</ng-template>`.\n   */\n  @Input() label?: string\n  /** Role of the child input element. https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles */\n  @Input() role?: string\n  /** Value of the child input element. Mostly used in conjunction with radio and checkboxes. */\n  @Input() value: any\n  /** An error string to be shown under invalid inputs. Overwrites any form errors. */\n  @Input() error?: string\n  /** Description of the child input element. Both visibly and as `aria-label`. */\n  @Input() description?: string\n  /** If set to true, the browser will try to automatically set focus to the child input element. */\n  @Input() autofocus = false\n  /** Deafult value of the child input element. Used when resetting child element. */\n  @Input() defaultValue?: any\n  /** If passed, the component will listen for updates and will reset its value. */\n  @Input() reset?: Observable<any>\n  /** Adds (Optional) to input label. */\n  @Input() optional?: boolean | null | undefined\n\n  private _locked: boolean | null | undefined = undefined\n  /** Hides the input borders and displays current value as a text. */\n  @Input() set locked(value: boolean | null | undefined) {\n    this._locked = value\n    this.cdr.detectChanges()\n  }\n  get locked(): boolean | null | undefined {\n    return this._locked\n  }\n  /** If set to true, using a controls disabled state will display input as locked. */\n  @Input() displayDisabledAsLocked?: boolean | null | undefined\n\n  /* STATES */\n\n  private _required: boolean | null | undefined = undefined\n  /** Override the required flag of the component. */\n  @Input() set required(value: boolean | null | undefined) {\n    this._required = value\n  }\n  /** Child input element is considered required and changes default label template accordingly. */\n  get required(): boolean | null | undefined {\n    // if required is set => return required\n    if (this._required !== undefined) return this._required\n\n    // if required can be determined from the control => return control.required\n    if (this.ngControl?.control?.validator) {\n      const validator = this.ngControl?.control?.validator(\n        {} as AbstractControl,\n      )\n      // returns true for any error that starts with required\n      return Object.keys(validator ?? {}).some((key) =>\n        key.startsWith('required'),\n      )\n    }\n\n    return\n  }\n\n  private _invalid: boolean | undefined = undefined\n  /** Override the invalid state of the component. */\n  @Input() set invalid(value: boolean) {\n    this._invalid = value\n  }\n  /** The component has the invalid state, usually decorating the elements red and shows the first error. */\n  get invalid(): boolean {\n    if (this._invalid === true || this._invalid === false) return this._invalid\n    return (\n      !!this.ngControl?.control?.invalid && this.ngControl?.control?.touched\n    )\n  }\n\n  private _valid: boolean | undefined = undefined\n  /** Override the valid state of the component. */\n  @Input() set valid(value: boolean) {\n    this._valid = value\n  }\n  /** The component has the valid state, usually decorating the elements green. */\n  get valid(): boolean {\n    if (this._valid === true || this._valid === false) return this._valid\n    return !!this.ngControl?.control?.valid && this.ngControl?.control?.touched\n  }\n\n  /** The component has the focused state, updated by the child input element's focus state. */\n  @Input() focused = false\n\n  private _disabled: boolean | undefined = undefined\n  /** Override the disabled state of the component. */\n  @Input() set disabled(value: boolean) {\n    this._disabled = value\n  }\n  /** The component has the disabled state, usually muting the colors and removes interaction. */\n  get disabled(): boolean {\n    if (this._disabled === true || this._disabled === false)\n      return this._disabled\n    return !!this.ngControl?.control?.disabled\n  }\n\n  /* TRIGGERS */\n\n  /** Emits focus events triggered by the child elements. */\n  @Output() readonly nggvFocus = new EventEmitter()\n  /** Emits focus events triggered by the child elements. */\n  @Output() readonly nggvBlur = new EventEmitter()\n\n  /* VALUE HANDLERS */\n\n  private _state: any = null\n  /** @internal */\n  protected onChange = (_: any) => {\n    // do nothing\n  }\n  /** @internal */\n  protected onTouched = () => {\n    // do nothing\n  }\n  /** @internal */\n  protected onValidatorChange: () => void = () => null\n\n  /* OTHER VARIABLES */\n  scope: string | undefined\n\n  /* LIFE CYCLE VARIABLES */\n\n  private _onDestroy$ = new Subject<boolean>()\n\n  /**\n   * Creates a new BaseControlValueAccessorComponent.\n   * @param ngControl optional FormControl provided when component is used in a form, through dependency injection.\n   * @param translocoScope optional TranslocoScope provided if component is used within a scope.\n   */\n  constructor(\n    @Self() @Optional() public ngControl: NgControl,\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n    protected cdr: ChangeDetectorRef,\n  ) {\n    if (this.ngControl) {\n      // Note: we provide the value accessor through here, instead of\n      // the `providers` to avoid running into a circular import.\n      this.ngControl.valueAccessor = this\n    }\n\n    if (this.translocoScope) this.scope = this.translocoScope.toString()\n  }\n\n  // eslint-disable-next-line @angular-eslint/contextual-lifecycle\n  ngOnInit(): void {\n    if (this.ngControl && this.ngControl.control) {\n      this.ngControl.control.setValidators(\n        Validators.compose([this.ngControl.control.validator, this.validate]),\n      )\n    }\n\n    // if reset observable has been passed, subscribe after updates\n    this.reset?.pipe(takeUntil(this._onDestroy$)).subscribe({\n      next: () => {\n        // reset value of controller\n        this.state = this.defaultValue\n        this.onChange(this.state)\n        this.cdr.detectChanges()\n      },\n    })\n  }\n\n  // eslint-disable-next-line @angular-eslint/contextual-lifecycle\n  ngAfterViewInit(): void {\n    // if default value is set, then don't alter it. Otherwise, use\n    // current value of controller after initiation as default value\n    this.defaultValue = this.defaultValue ?? this.ngControl?.value\n  }\n\n  ngOnDestroy(): void {\n    this._onDestroy$.next(true)\n    this._onDestroy$.complete()\n  }\n\n  detectChanges(): void {\n    this.cdr.detectChanges()\n  }\n\n  /** @internal */\n  onFocus(event: Event) {\n    event.stopPropagation\n      ? event.stopPropagation()\n      : (event.cancelBubble = true)\n    this.focused = true\n    this.nggvFocus.emit(event)\n  }\n\n  /** @internal */\n  onBlur(event: Event) {\n    event.stopPropagation\n      ? event.stopPropagation()\n      : (event.cancelBubble = true)\n    this.onTouched()\n    this.focused = false\n    this.nggvBlur.emit(event)\n  }\n\n  /** Sets the focus on the actual input element. */\n  setFocus() {\n    if (this.inputRef) this.inputRef.nativeElement.focus()\n  }\n\n  // ----------------------------------------------------------------------------\n  // CONTROL VALUE ACCESSOR\n  // ----------------------------------------------------------------------------\n\n  /** Internal state/value that the native input element has.  */\n  get state() {\n    return this._state\n  }\n\n  /** Internal state/value that the native input element has.  */\n  set state(value) {\n    if (typeof value === 'undefined') value = null\n    this._state = value\n  }\n\n  /** Writes a new value to the child input element. */\n  writeValue(value: any): void {\n    this.state = value\n  }\n\n  /** Registers a callback function that is called when the child input element's value changes. */\n  registerOnChange(fn: (_: any) => object): void {\n    this.onChange = fn\n  }\n\n  /** Registers a callback function that is called when the child input element triggers on blur. */\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn\n  }\n\n  /** Function that is called by the forms API when the control status changes to or from 'DISABLED'. */\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled\n\n    // if displayDisabledAsLocked is enabled - update locked state based on disabled state\n    if (this.displayDisabledAsLocked) {\n      this.locked = isDisabled\n    }\n  }\n\n  // ----------------------------------------------------------------------------\n  // VALIDATORS\n  // ----------------------------------------------------------------------------\n\n  /** Method that performs synchronous validation against the provided control. Used for internal validation. */\n  validate(_control: AbstractControl): { [name: string]: any } | null {\n    return null\n  }\n\n  /** Registers a callback function to call when the validator inputs change. */\n  registerOnValidatorChange(fn: () => void): void {\n    this.onValidatorChange = fn\n  }\n\n  // ----------------------------------------------------------------------------\n  // HELPERS\n  // ----------------------------------------------------------------------------\n\n  /** Returns the first entry in an error object. */\n  get firstError(): { code: string; params: any } | null {\n    const errors: ValidationErrors | null = this.ngControl.errors\n    if (!errors) return null\n    const code: string = Object.keys(errors)[0]\n    return { code, params: errors[code] }\n  }\n}\n"]}
@@ -43,7 +43,7 @@ export class NgvButtonComponent extends NgvBaseControlValueAccessorComponent {
43
43
  /** Emits click events triggered by the button or link.
44
44
  * Use instead of click to avoid triggering events on disabled buttons and links.
45
45
  */
46
- this.ngvClick = new EventEmitter();
46
+ this.nggvClick = new EventEmitter();
47
47
  }
48
48
  /** @internal */
49
49
  static buttonStyleClasses(type, small) {
@@ -72,10 +72,10 @@ export class NgvButtonComponent extends NgvBaseControlValueAccessorComponent {
72
72
  onClick(event) {
73
73
  if (this.disabled)
74
74
  return;
75
- this.ngvClick.emit(event);
75
+ this.nggvClick.emit(event);
76
76
  }
77
77
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvButtonComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: TRANSLOCO_SCOPE, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
78
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvButtonComponent, selector: "nggv-button", inputs: { thook: "thook", type: "type", buttonStyle: "buttonStyle", small: "small", href: "href" }, outputs: { ngvClick: "ngvClick" }, host: { properties: { "attr.data-thook": "this.thook" } }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<button\n #input\n [ngClass]=\"buttonClasses\"\n [id]=\"id + '-button'\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n [type]=\"type\"\n [autofocus]=\"autofocus\"\n [disabled]=\"disabled\"\n [attr.aria-label]=\"description\"\n (click)=\"onClick($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n *ngIf=\"type !== 'link'\"\n>\n <ng-container *ngTemplateOutlet=\"contentRef\"></ng-container>\n</button>\n\n<a\n #input\n [ngClass]=\"buttonClasses\"\n role=\"button\"\n [id]=\"id + '-link'\"\n [routerLink]=\"href\"\n [external]=\"external\"\n [attr.aria-label]=\"description\"\n (click)=\"onClick($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n *ngIf=\"type === 'link'\"\n>\n <ng-container *ngTemplateOutlet=\"contentRef\"></ng-container>\n</a>\n\n<ng-template #contentRef>\n <ng-content></ng-content>\n</ng-template>\n", styles: [":host button,:host a{background-color:transparent;border:0;cursor:pointer;font-family:inherit;padding:0;padding:.75rem 1rem;border-radius:var(--sg-border-radius);border:solid var(--sg-border-width) var(--sg-border-color);font-weight:500;min-height:2.75rem;align-items:center;display:inline-flex;justify-content:center}:host button:focus:not(:focus-visible),:host a:focus:not(:focus-visible){box-shadow:none;outline:0}:host button:focus,:host button:focus-visible,:host a:focus,:host a:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}@media (max-width: 35.98em){:host button,:host a{min-width:100%}}@media screen and (-ms-high-contrast: active){:host button,:host a{border:2px solid currentcolor}}:host button.small,:host a.small{min-height:2rem;padding:.4375rem .75rem;line-height:1rem}:host button.large,:host a.large{min-height:4rem;padding:1rem 1.5rem;font-size:1.5rem;line-height:2rem}:host .primary{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;background:#007ac7;border-color:#007ac7;color:#fff;--color: #fff}:host .primary:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#199be3;color:#fff;--background: #199be3;--color: rgb(255, 255, 255);border-color:#199be3}:host .primary[aria-selected=true],:host .primary:active,:host .primary.active,:host .primary.active:hover,:host .primary:active:hover{background-color:#007ac7;color:#fff;--background: rgb(0, 122, 199);--color: rgb(255, 255, 255);border-color:#007ac7}:host .primary:focus-visible{background-color:#199be3;color:#fff;--background: #199be3;--color: rgb(255, 255, 255);border-color:#199be3!important}:host .primary:disabled,:host .primary.disabled,:host .primary[aria-disabled=true]{background:var(--form-control-primary-bg-disabled)!important;color:var(--text-primary-disabled-color)!important;border-color:var(--border-primary-disabled-color)!important;cursor:not-allowed}:host .primary:disabled::placeholder,:host .primary.disabled::placeholder,:host .primary[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .secondary{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;background:transparent;border-color:#007ac7;color:#007ac7;--color: rgb(0, 122, 199)}:host .secondary:focus:not(:focus-visible){box-shadow:none;outline:0}:host .secondary:focus,:host .secondary:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}:host .secondary:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#199be3;color:#fff;--background: #199be3;--color: rgb(255, 255, 255);border-color:#199be3}:host .secondary[aria-selected=true],:host .secondary:active,:host .secondary.active,:host .secondary.active:hover,:host .secondary:active:hover{background-color:#007ac7;color:#fff;--background: rgb(0, 122, 199);--color: rgb(255, 255, 255);border-color:#007ac7}:host .secondary:disabled,:host .secondary.disabled,:host .secondary[aria-disabled=true]{background:var(--sg-form-control-bg-disabled)!important;color:var(--text-disabled-color)!important;border-color:var(--border-disabled-color)!important;cursor:not-allowed}:host .secondary:disabled::placeholder,:host .secondary.disabled::placeholder,:host .secondary[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .tertiary{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;background:transparent;border-color:transparent;color:#007ac7;--color: rgb(0, 122, 199)}:host .tertiary:focus:not(:focus-visible){box-shadow:none;outline:0}:host .tertiary:focus,:host .tertiary:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}:host .tertiary:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#199be3;color:#fff;--background: #199be3;--color: rgb(255, 255, 255);border-color:#199be3}:host .tertiary[aria-selected=true],:host .tertiary:active,:host .tertiary.active,:host .tertiary.active:hover,:host .tertiary:active:hover{background-color:#007ac7;color:#fff;--background: rgb(0, 122, 199);--color: rgb(255, 255, 255);border-color:#007ac7}:host .tertiary:disabled,:host .tertiary.disabled,:host .tertiary[aria-disabled=true]{background:var(--sg-form-control-bg-disabled)!important;color:var(--text-disabled-color)!important;border-color:var(--border-disabled-color)!important;cursor:not-allowed}:host .tertiary:disabled::placeholder,:host .tertiary.disabled::placeholder,:host .tertiary[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .ghost-light{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;border-color:#fff;color:#fff;--color: rgb(255, 255, 255)}:host .ghost-light:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#fff;color:#000;--background: rgb(255, 255, 255);--color: black;border-color:#fff}:host .ghost-light[aria-selected=true],:host .ghost-light:active,:host .ghost-light.active,:host .ghost-light.active:hover,:host .ghost-light:active:hover{background-color:#fff;color:#000;--background: rgb(255, 255, 255);--color: black;border-color:#fff}:host .ghost-light[aria-selected]:hover,:host .ghost-light.active:hover,:host .ghost-light:active:hover{opacity:.9}:host .ghost-light:focus-visible{background-color:#fff;color:#000;--background: rgb(255, 255, 255);--color: black;border-color:#fff!important}:host .ghost-light:disabled,:host .ghost-light.disabled,:host .ghost-light[aria-disabled=true]{color:var(--text-disabled-color)!important;border-color:var(--border-disabled-color)!important;cursor:not-allowed}:host .ghost-light:disabled::placeholder,:host .ghost-light.disabled::placeholder,:host .ghost-light[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .ghost{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;border-color:#333;color:#333;--color: rgb(51, 51, 51)}:host .ghost:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#333;color:#fff;--background: rgb(51, 51, 51);--color: rgb(255, 255, 255);border-color:#333}:host .ghost[aria-selected=true],:host .ghost:active,:host .ghost.active,:host .ghost.active:hover,:host .ghost:active:hover{background-color:#333;color:#fff;--background: rgb(51, 51, 51);--color: rgb(255, 255, 255);border-color:#333}:host .ghost[aria-selected]:hover,:host .ghost.active:hover,:host .ghost:active:hover{opacity:.9}:host .ghost:focus-visible{background-color:#333;color:#fff;--background: rgb(51, 51, 51);--color: rgb(255, 255, 255);border-color:#333!important}:host .ghost:disabled,:host .ghost.disabled,:host .ghost[aria-disabled=true]{color:var(--text-disabled-color)!important;border-color:var(--border-disabled-color)!important;cursor:not-allowed}:host .ghost:disabled::placeholder,:host .ghost.disabled::placeholder,:host .ghost[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .danger.primary{background:#bb000c;border-color:#bb000c;color:#fff;--color: #fff;transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s}:host .danger.primary:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#d81a1a;color:#fff;--background: rgb(216, 26, 26);--color: rgb(255, 255, 255);border-color:#d81a1a}:host .danger.primary[aria-selected=true],:host .danger.primary:active,:host .danger.primary.active,:host .danger.primary.active:hover,:host .danger.primary:active:hover{background-color:#bb000c;color:#fff;--background: rgb(187, 0, 12);--color: rgb(255, 255, 255);border-color:#bb000c}:host .danger.primary[aria-selected]:hover,:host .danger.primary.active:hover,:host .danger.primary:active:hover{opacity:.9}:host .danger.primary:focus:not(:focus-visible){box-shadow:none;outline:0}:host .danger.primary:focus,:host .danger.primary:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}:host .danger.primary:disabled,:host .danger.primary.disabled,:host .danger.primary[aria-disabled=true]{background:var(--form-control-primary-bg-disabled)!important;color:var(--text-primary-disabled-color)!important;border-color:var(--border-primary-disabled-color)!important;cursor:not-allowed}:host .danger.primary:disabled::placeholder,:host .danger.primary.disabled::placeholder,:host .danger.primary[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .danger:not(.primary){color:#bb000c;--color: rgb(187, 0, 12);border-color:transparent;transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s}:host .danger:not(.primary):not(:disabled,.disabled,[aria-disabled]):hover{background-color:#d81a1a;color:#fff;--background: rgb(216, 26, 26);--color: rgb(255, 255, 255);border-color:#d81a1a}:host .danger:not(.primary)[aria-selected=true],:host .danger:not(.primary):active,:host .danger:not(.primary).active,:host .danger:not(.primary).active:hover,:host .danger:not(.primary):active:hover{background-color:#bb000c;color:#fff;--background: rgb(187, 0, 12);--color: rgb(255, 255, 255);border-color:#bb000c}:host .danger:not(.primary)[aria-selected]:hover,:host .danger:not(.primary).active:hover,:host .danger:not(.primary):active:hover{opacity:.9}:host .danger:not(.primary):focus:not(:focus-visible){box-shadow:none;outline:0}:host .danger:not(.primary):focus,:host .danger:not(.primary):focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgvExternalLinkDirective, selector: "a[routerLink]", inputs: ["external"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
78
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvButtonComponent, selector: "nggv-button", inputs: { thook: "thook", type: "type", buttonStyle: "buttonStyle", small: "small", href: "href" }, outputs: { nggvClick: "nggvClick" }, host: { properties: { "attr.data-thook": "this.thook" } }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<button\n #input\n [ngClass]=\"buttonClasses\"\n [id]=\"id + '-button'\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n [type]=\"type\"\n [autofocus]=\"autofocus\"\n [disabled]=\"disabled\"\n [attr.aria-label]=\"description\"\n (click)=\"onClick($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n *ngIf=\"type !== 'link'\"\n>\n <ng-container *ngTemplateOutlet=\"contentRef\"></ng-container>\n</button>\n\n<a\n #input\n [ngClass]=\"buttonClasses\"\n role=\"button\"\n [id]=\"id + '-link'\"\n [routerLink]=\"href\"\n [external]=\"external\"\n [attr.aria-label]=\"description\"\n (click)=\"onClick($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n *ngIf=\"type === 'link'\"\n>\n <ng-container *ngTemplateOutlet=\"contentRef\"></ng-container>\n</a>\n\n<ng-template #contentRef>\n <ng-content></ng-content>\n</ng-template>\n", styles: [":host button,:host a{background-color:transparent;border:0;cursor:pointer;font-family:inherit;padding:0;padding:.75rem 1rem;border-radius:var(--sg-border-radius);border:solid var(--sg-border-width) var(--sg-border-color);font-weight:500;min-height:2.75rem;align-items:center;display:inline-flex;justify-content:center}:host button:focus:not(:focus-visible),:host a:focus:not(:focus-visible){box-shadow:none;outline:0}:host button:focus,:host button:focus-visible,:host a:focus,:host a:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}@media (max-width: 35.98em){:host button,:host a{min-width:100%}}@media screen and (-ms-high-contrast: active){:host button,:host a{border:2px solid currentcolor}}:host button.small,:host a.small{min-height:2rem;padding:.4375rem .75rem;line-height:1rem}:host button.large,:host a.large{min-height:4rem;padding:1rem 1.5rem;font-size:1.5rem;line-height:2rem}:host .primary{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;background:#007ac7;border-color:#007ac7;color:#fff;--color: #fff}:host .primary:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#199be3;color:#fff;--background: #199be3;--color: rgb(255, 255, 255);border-color:#199be3}:host .primary[aria-selected=true],:host .primary:active,:host .primary.active,:host .primary.active:hover,:host .primary:active:hover{background-color:#007ac7;color:#fff;--background: rgb(0, 122, 199);--color: rgb(255, 255, 255);border-color:#007ac7}:host .primary:focus-visible{background-color:#199be3;color:#fff;--background: #199be3;--color: rgb(255, 255, 255);border-color:#199be3!important}:host .primary:disabled,:host .primary.disabled,:host .primary[aria-disabled=true]{background:var(--form-control-primary-bg-disabled)!important;color:var(--text-primary-disabled-color)!important;border-color:var(--border-primary-disabled-color)!important;cursor:not-allowed}:host .primary:disabled::placeholder,:host .primary.disabled::placeholder,:host .primary[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .secondary{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;background:transparent;border-color:#007ac7;color:#007ac7;--color: rgb(0, 122, 199)}:host .secondary:focus:not(:focus-visible){box-shadow:none;outline:0}:host .secondary:focus,:host .secondary:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}:host .secondary:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#199be3;color:#fff;--background: #199be3;--color: rgb(255, 255, 255);border-color:#199be3}:host .secondary[aria-selected=true],:host .secondary:active,:host .secondary.active,:host .secondary.active:hover,:host .secondary:active:hover{background-color:#007ac7;color:#fff;--background: rgb(0, 122, 199);--color: rgb(255, 255, 255);border-color:#007ac7}:host .secondary:disabled,:host .secondary.disabled,:host .secondary[aria-disabled=true]{background:var(--sg-form-control-bg-disabled)!important;color:var(--text-disabled-color)!important;border-color:var(--border-disabled-color)!important;cursor:not-allowed}:host .secondary:disabled::placeholder,:host .secondary.disabled::placeholder,:host .secondary[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .tertiary{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;background:transparent;border-color:transparent;color:#007ac7;--color: rgb(0, 122, 199)}:host .tertiary:focus:not(:focus-visible){box-shadow:none;outline:0}:host .tertiary:focus,:host .tertiary:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}:host .tertiary:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#199be3;color:#fff;--background: #199be3;--color: rgb(255, 255, 255);border-color:#199be3}:host .tertiary[aria-selected=true],:host .tertiary:active,:host .tertiary.active,:host .tertiary.active:hover,:host .tertiary:active:hover{background-color:#007ac7;color:#fff;--background: rgb(0, 122, 199);--color: rgb(255, 255, 255);border-color:#007ac7}:host .tertiary:disabled,:host .tertiary.disabled,:host .tertiary[aria-disabled=true]{background:var(--sg-form-control-bg-disabled)!important;color:var(--text-disabled-color)!important;border-color:var(--border-disabled-color)!important;cursor:not-allowed}:host .tertiary:disabled::placeholder,:host .tertiary.disabled::placeholder,:host .tertiary[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .ghost-light{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;border-color:#fff;color:#fff;--color: rgb(255, 255, 255)}:host .ghost-light:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#fff;color:#000;--background: rgb(255, 255, 255);--color: black;border-color:#fff}:host .ghost-light[aria-selected=true],:host .ghost-light:active,:host .ghost-light.active,:host .ghost-light.active:hover,:host .ghost-light:active:hover{background-color:#fff;color:#000;--background: rgb(255, 255, 255);--color: black;border-color:#fff}:host .ghost-light[aria-selected]:hover,:host .ghost-light.active:hover,:host .ghost-light:active:hover{opacity:.9}:host .ghost-light:focus-visible{background-color:#fff;color:#000;--background: rgb(255, 255, 255);--color: black;border-color:#fff!important}:host .ghost-light:disabled,:host .ghost-light.disabled,:host .ghost-light[aria-disabled=true]{color:var(--text-disabled-color)!important;border-color:var(--border-disabled-color)!important;cursor:not-allowed}:host .ghost-light:disabled::placeholder,:host .ghost-light.disabled::placeholder,:host .ghost-light[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .ghost{transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s;border-color:#333;color:#333;--color: rgb(51, 51, 51)}:host .ghost:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#333;color:#fff;--background: rgb(51, 51, 51);--color: rgb(255, 255, 255);border-color:#333}:host .ghost[aria-selected=true],:host .ghost:active,:host .ghost.active,:host .ghost.active:hover,:host .ghost:active:hover{background-color:#333;color:#fff;--background: rgb(51, 51, 51);--color: rgb(255, 255, 255);border-color:#333}:host .ghost[aria-selected]:hover,:host .ghost.active:hover,:host .ghost:active:hover{opacity:.9}:host .ghost:focus-visible{background-color:#333;color:#fff;--background: rgb(51, 51, 51);--color: rgb(255, 255, 255);border-color:#333!important}:host .ghost:disabled,:host .ghost.disabled,:host .ghost[aria-disabled=true]{color:var(--text-disabled-color)!important;border-color:var(--border-disabled-color)!important;cursor:not-allowed}:host .ghost:disabled::placeholder,:host .ghost.disabled::placeholder,:host .ghost[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .danger.primary{background:#bb000c;border-color:#bb000c;color:#fff;--color: #fff;transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s}:host .danger.primary:not(:disabled,.disabled,[aria-disabled]):hover{background-color:#d81a1a;color:#fff;--background: rgb(216, 26, 26);--color: rgb(255, 255, 255);border-color:#d81a1a}:host .danger.primary[aria-selected=true],:host .danger.primary:active,:host .danger.primary.active,:host .danger.primary.active:hover,:host .danger.primary:active:hover{background-color:#bb000c;color:#fff;--background: rgb(187, 0, 12);--color: rgb(255, 255, 255);border-color:#bb000c}:host .danger.primary[aria-selected]:hover,:host .danger.primary.active:hover,:host .danger.primary:active:hover{opacity:.9}:host .danger.primary:focus:not(:focus-visible){box-shadow:none;outline:0}:host .danger.primary:focus,:host .danger.primary:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}:host .danger.primary:disabled,:host .danger.primary.disabled,:host .danger.primary[aria-disabled=true]{background:var(--form-control-primary-bg-disabled)!important;color:var(--text-primary-disabled-color)!important;border-color:var(--border-primary-disabled-color)!important;cursor:not-allowed}:host .danger.primary:disabled::placeholder,:host .danger.primary.disabled::placeholder,:host .danger.primary[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host .danger:not(.primary){color:#bb000c;--color: rgb(187, 0, 12);border-color:transparent;transition:all .3s cubic-bezier(.23,1,.32,1),outline-offset 0s,outline-width 0s}:host .danger:not(.primary):not(:disabled,.disabled,[aria-disabled]):hover{background-color:#d81a1a;color:#fff;--background: rgb(216, 26, 26);--color: rgb(255, 255, 255);border-color:#d81a1a}:host .danger:not(.primary)[aria-selected=true],:host .danger:not(.primary):active,:host .danger:not(.primary).active,:host .danger:not(.primary).active:hover,:host .danger:not(.primary):active:hover{background-color:#bb000c;color:#fff;--background: rgb(187, 0, 12);--color: rgb(255, 255, 255);border-color:#bb000c}:host .danger:not(.primary)[aria-selected]:hover,:host .danger:not(.primary).active:hover,:host .danger:not(.primary):active:hover{opacity:.9}:host .danger:not(.primary):focus:not(:focus-visible){box-shadow:none;outline:0}:host .danger:not(.primary):focus,:host .danger:not(.primary):focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgvExternalLinkDirective, selector: "a[routerLink]", inputs: ["external"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
79
79
  }
80
80
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvButtonComponent, decorators: [{
81
81
  type: Component,
@@ -102,7 +102,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
102
102
  type: Input
103
103
  }], href: [{
104
104
  type: Input
105
- }], ngvClick: [{
105
+ }], nggvClick: [{
106
106
  type: Output
107
107
  }] } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/v-angular/button/button.component.ts","../../../../../../../libs/angular/src/v-angular/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  InjectionToken,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n} from '@angular/core'\nimport { NgControl } from '@angular/forms'\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@ngneat/transloco'\nimport { NgvBaseControlValueAccessorComponent } from '@sebgroup/green-angular/src/v-angular/base-control-value-accessor'\n\nexport type ButtonTypes = 'button' | 'submit' | 'reset' | 'link'\n\nexport enum ButtonStyle {\n  Primary,\n  Secondary,\n  Alternative,\n  Delete,\n  DeleteConfirm,\n  Ghost,\n  GhostDark,\n  Link,\n}\n\n/**\n * Buttons allow users to take action with a single tap.\n * https://designlibrary.sebgroup.com/components/component-button\n */\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'nggv-button',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss'],\n})\nexport class NgvButtonComponent\n  extends NgvBaseControlValueAccessorComponent\n  implements OnInit, OnChanges\n{\n  /** Special property used for selecting DOM elements during automated UI testing. */\n  @HostBinding('attr.data-thook') @Input() thook = 'button'\n  /** Type of button to one of button|submit|reset|link, where link creates an anchor tag. */\n  @Input() type: ButtonTypes = 'button'\n  /** Style of the button to one of Primary|Secondary|Alternative|Delete|DeleteConfirm|Ghost|GhostDark|Link. */\n  @Input() buttonStyle: ButtonStyle =\n    this.type === 'link' ? ButtonStyle.Link : ButtonStyle.Primary\n  /** Size of the button to be smaller. */\n  @Input() small = false\n  /** Where the button should link to if {@link ButtonTypes} is set to link. */\n  @Input() href?: string\n\n  /** @internal Determines if the the href property should use internal routing. */\n  external = false\n  /** @internal The classes determined by the buttonStyle and small properties. */\n  buttonClasses: { [className: string]: boolean } = {}\n\n  /** Emits click events triggered by the button or link.\n   * Use instead of click to avoid triggering events on disabled buttons and links.\n   */\n  @Output() ngvClick = new EventEmitter()\n\n  constructor(\n    @Self() @Optional() public ngControl: NgControl,\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n    protected cdr: ChangeDetectorRef,\n  ) {\n    super(ngControl, translocoScope, cdr)\n  }\n\n  /** @internal */\n  static buttonStyleClasses(type: ButtonStyle, small: boolean) {\n    return {\n      small: small,\n      primary: type === ButtonStyle.Primary || type === ButtonStyle.Delete,\n      secondary: type === ButtonStyle.Secondary,\n      tertiary: type === ButtonStyle.Alternative || type === ButtonStyle.Link,\n      danger: type === ButtonStyle.Delete || type === ButtonStyle.DeleteConfirm,\n      ghost: type === ButtonStyle.GhostDark,\n      'ghost-light': type === ButtonStyle.Ghost,\n    }\n  }\n\n  ngOnInit() {\n    super.ngOnInit()\n    if (this.href) this.external = /^\\w+:\\/\\/.+$/.test(this.href)\n    this.buttonClasses = NgvButtonComponent.buttonStyleClasses(\n      this.buttonStyle,\n      this.small,\n    )\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.buttonStyle || changes.small) {\n      this.buttonClasses = NgvButtonComponent.buttonStyleClasses(\n        this.buttonStyle,\n        this.small,\n      )\n    }\n  }\n\n  /** @internal */\n  onClick(event: Event) {\n    if (this.disabled) return\n    this.ngvClick.emit(event)\n  }\n}\n","<button\n  #input\n  [ngClass]=\"buttonClasses\"\n  [id]=\"id + '-button'\"\n  [attr.name]=\"name\"\n  [attr.value]=\"value\"\n  [type]=\"type\"\n  [autofocus]=\"autofocus\"\n  [disabled]=\"disabled\"\n  [attr.aria-label]=\"description\"\n  (click)=\"onClick($event)\"\n  (focus)=\"onFocus($event)\"\n  (blur)=\"onBlur($event)\"\n  *ngIf=\"type !== 'link'\"\n>\n  <ng-container *ngTemplateOutlet=\"contentRef\"></ng-container>\n</button>\n\n<a\n  #input\n  [ngClass]=\"buttonClasses\"\n  role=\"button\"\n  [id]=\"id + '-link'\"\n  [routerLink]=\"href\"\n  [external]=\"external\"\n  [attr.aria-label]=\"description\"\n  (click)=\"onClick($event)\"\n  (focus)=\"onFocus($event)\"\n  (blur)=\"onBlur($event)\"\n  *ngIf=\"type === 'link'\"\n>\n  <ng-container *ngTemplateOutlet=\"contentRef\"></ng-container>\n</a>\n\n<ng-template #contentRef>\n  <ng-content></ng-content>\n</ng-template>\n"]}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/v-angular/button/button.component.ts","../../../../../../../libs/angular/src/v-angular/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  InjectionToken,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n} from '@angular/core'\nimport { NgControl } from '@angular/forms'\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@ngneat/transloco'\nimport { NgvBaseControlValueAccessorComponent } from '@sebgroup/green-angular/src/v-angular/base-control-value-accessor'\n\nexport type ButtonTypes = 'button' | 'submit' | 'reset' | 'link'\n\nexport enum ButtonStyle {\n  Primary,\n  Secondary,\n  Alternative,\n  Delete,\n  DeleteConfirm,\n  Ghost,\n  GhostDark,\n  Link,\n}\n\n/**\n * Buttons allow users to take action with a single tap.\n * https://designlibrary.sebgroup.com/components/component-button\n */\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'nggv-button',\n  templateUrl: './button.component.html',\n  styleUrls: ['./button.component.scss'],\n})\nexport class NgvButtonComponent\n  extends NgvBaseControlValueAccessorComponent\n  implements OnInit, OnChanges\n{\n  /** Special property used for selecting DOM elements during automated UI testing. */\n  @HostBinding('attr.data-thook') @Input() thook = 'button'\n  /** Type of button to one of button|submit|reset|link, where link creates an anchor tag. */\n  @Input() type: ButtonTypes = 'button'\n  /** Style of the button to one of Primary|Secondary|Alternative|Delete|DeleteConfirm|Ghost|GhostDark|Link. */\n  @Input() buttonStyle: ButtonStyle =\n    this.type === 'link' ? ButtonStyle.Link : ButtonStyle.Primary\n  /** Size of the button to be smaller. */\n  @Input() small = false\n  /** Where the button should link to if {@link ButtonTypes} is set to link. */\n  @Input() href?: string\n\n  /** @internal Determines if the the href property should use internal routing. */\n  external = false\n  /** @internal The classes determined by the buttonStyle and small properties. */\n  buttonClasses: { [className: string]: boolean } = {}\n\n  /** Emits click events triggered by the button or link.\n   * Use instead of click to avoid triggering events on disabled buttons and links.\n   */\n  @Output() nggvClick = new EventEmitter()\n\n  constructor(\n    @Self() @Optional() public ngControl: NgControl,\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n    protected cdr: ChangeDetectorRef,\n  ) {\n    super(ngControl, translocoScope, cdr)\n  }\n\n  /** @internal */\n  static buttonStyleClasses(type: ButtonStyle, small: boolean) {\n    return {\n      small: small,\n      primary: type === ButtonStyle.Primary || type === ButtonStyle.Delete,\n      secondary: type === ButtonStyle.Secondary,\n      tertiary: type === ButtonStyle.Alternative || type === ButtonStyle.Link,\n      danger: type === ButtonStyle.Delete || type === ButtonStyle.DeleteConfirm,\n      ghost: type === ButtonStyle.GhostDark,\n      'ghost-light': type === ButtonStyle.Ghost,\n    }\n  }\n\n  ngOnInit() {\n    super.ngOnInit()\n    if (this.href) this.external = /^\\w+:\\/\\/.+$/.test(this.href)\n    this.buttonClasses = NgvButtonComponent.buttonStyleClasses(\n      this.buttonStyle,\n      this.small,\n    )\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.buttonStyle || changes.small) {\n      this.buttonClasses = NgvButtonComponent.buttonStyleClasses(\n        this.buttonStyle,\n        this.small,\n      )\n    }\n  }\n\n  /** @internal */\n  onClick(event: Event) {\n    if (this.disabled) return\n    this.nggvClick.emit(event)\n  }\n}\n","<button\n  #input\n  [ngClass]=\"buttonClasses\"\n  [id]=\"id + '-button'\"\n  [attr.name]=\"name\"\n  [attr.value]=\"value\"\n  [type]=\"type\"\n  [autofocus]=\"autofocus\"\n  [disabled]=\"disabled\"\n  [attr.aria-label]=\"description\"\n  (click)=\"onClick($event)\"\n  (focus)=\"onFocus($event)\"\n  (blur)=\"onBlur($event)\"\n  *ngIf=\"type !== 'link'\"\n>\n  <ng-container *ngTemplateOutlet=\"contentRef\"></ng-container>\n</button>\n\n<a\n  #input\n  [ngClass]=\"buttonClasses\"\n  role=\"button\"\n  [id]=\"id + '-link'\"\n  [routerLink]=\"href\"\n  [external]=\"external\"\n  [attr.aria-label]=\"description\"\n  (click)=\"onClick($event)\"\n  (focus)=\"onFocus($event)\"\n  (blur)=\"onBlur($event)\"\n  *ngIf=\"type === 'link'\"\n>\n  <ng-container *ngTemplateOutlet=\"contentRef\"></ng-container>\n</a>\n\n<ng-template #contentRef>\n  <ng-content></ng-content>\n</ng-template>\n"]}
@@ -34,18 +34,18 @@ export class CharacterCountdownDirective {
34
34
  this.context.charactersLeft = this.calculateCharactersLeft(this._maxlength, this._currentLength);
35
35
  }
36
36
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CharacterCountdownDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
37
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CharacterCountdownDirective, selector: "[ngvCharacterCountdown]", inputs: { maxlength: ["ngvCharacterCountdown", "maxlength"], currentLength: ["ngvCharacterCountdownCurrentLength", "currentLength"] }, ngImport: i0 }); }
37
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CharacterCountdownDirective, selector: "[nggvCharacterCountdown]", inputs: { maxlength: ["nggvCharacterCountdown", "maxlength"], currentLength: ["nggvCharacterCountdownCurrentLength", "currentLength"] }, ngImport: i0 }); }
38
38
  }
39
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CharacterCountdownDirective, decorators: [{
40
40
  type: Directive,
41
41
  args: [{
42
- selector: '[ngvCharacterCountdown]',
42
+ selector: '[nggvCharacterCountdown]',
43
43
  }]
44
44
  }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }]; }, propDecorators: { maxlength: [{
45
45
  type: Input,
46
- args: ['ngvCharacterCountdown']
46
+ args: ['nggvCharacterCountdown']
47
47
  }], currentLength: [{
48
48
  type: Input,
49
- args: ['ngvCharacterCountdownCurrentLength']
49
+ args: ['nggvCharacterCountdownCurrentLength']
50
50
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcmFjdGVyLWNvdW50ZG93bi5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci9jaGFyYWN0ZXItY291bnRkb3duL2NoYXJhY3Rlci1jb3VudGRvd24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQTs7QUFLL0UsTUFBTSxPQUFPLDJCQUEyQjtJQUN0QyxJQUNJLFNBQVMsQ0FBQyxLQUF5QjtRQUNyQyxJQUFJLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ25DLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFBO1lBQ3ZCLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQTtZQUNwQixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRTtnQkFDdkIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO2dCQUN4RSxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQTthQUMxQjtTQUNGO2FBQU07WUFDTCxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUU7Z0JBQ3RCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtnQkFDN0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUE7YUFDM0I7U0FDRjtJQUNILENBQUM7SUFFRCxJQUNJLGFBQWEsQ0FBQyxLQUFhO1FBQzdCLElBQUksQ0FBQyxjQUFjLEdBQUcsS0FBSyxJQUFJLENBQUMsQ0FBQTtRQUNoQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUE7SUFDdEIsQ0FBQztJQU9ELFlBQ21CLGdCQUFrQyxFQUNsQyxXQUE2QjtRQUQ3QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQ2xDLGdCQUFXLEdBQVgsV0FBVyxDQUFrQjtRQVB4QyxlQUFVLEdBQVcsTUFBTSxDQUFDLGdCQUFnQixDQUFBO1FBQzVDLG1CQUFjLEdBQUcsQ0FBQyxDQUFBO1FBQ2xCLGtCQUFhLEdBQUcsS0FBSyxDQUFBO1FBQ3JCLFlBQU8sR0FBRyxFQUFFLGNBQWMsRUFBRSxDQUFDLEVBQUUsQ0FBQTtRQWN2Qyw0QkFBdUIsR0FBRyxDQUFDLEdBQVcsRUFBRSxPQUFlLEVBQVUsRUFBRSxDQUNqRSxHQUFHLEdBQUcsT0FBTyxDQUFBO0lBVlosQ0FBQztJQUVKLGFBQWE7UUFDWCxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsdUJBQXVCLENBQ3hELElBQUksQ0FBQyxVQUFVLEVBQ2YsSUFBSSxDQUFDLGNBQWMsQ0FDcEIsQ0FBQTtJQUNILENBQUM7K0dBdkNVLDJCQUEyQjttR0FBM0IsMkJBQTJCOzs0RkFBM0IsMkJBQTJCO2tCQUh2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx5QkFBeUI7aUJBQ3BDO2lJQUdLLFNBQVM7c0JBRFosS0FBSzt1QkFBQyx1QkFBdUI7Z0JBa0IxQixhQUFhO3NCQURoQixLQUFLO3VCQUFDLG9DQUFvQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQsIFRlbXBsYXRlUmVmLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW25ndkNoYXJhY3RlckNvdW50ZG93bl0nLFxufSlcbmV4cG9ydCBjbGFzcyBDaGFyYWN0ZXJDb3VudGRvd25EaXJlY3RpdmUge1xuICBASW5wdXQoJ25ndkNoYXJhY3RlckNvdW50ZG93bicpXG4gIHNldCBtYXhsZW5ndGgodmFsdWU6IG51bWJlciB8IHVuZGVmaW5lZCkge1xuICAgIGlmICghIXZhbHVlICYmICFOdW1iZXIuaXNOYU4odmFsdWUpKSB7XG4gICAgICB0aGlzLl9tYXhsZW5ndGggPSB2YWx1ZVxuICAgICAgdGhpcy51cGRhdGVDb250ZXh0KClcbiAgICAgIGlmICghdGhpcy5pc1ZpZXdDcmVhdGVkKSB7XG4gICAgICAgIHRoaXMudmlld0NvbnRhaW5lclJlZi5jcmVhdGVFbWJlZGRlZFZpZXcodGhpcy50ZW1wbGF0ZVJlZiwgdGhpcy5jb250ZXh0KVxuICAgICAgICB0aGlzLmlzVmlld0NyZWF0ZWQgPSB0cnVlXG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGlmICh0aGlzLmlzVmlld0NyZWF0ZWQpIHtcbiAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNsZWFyKClcbiAgICAgICAgdGhpcy5pc1ZpZXdDcmVhdGVkID0gZmFsc2VcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBASW5wdXQoJ25ndkNoYXJhY3RlckNvdW50ZG93bkN1cnJlbnRMZW5ndGgnKVxuICBzZXQgY3VycmVudExlbmd0aCh2YWx1ZTogbnVtYmVyKSB7XG4gICAgdGhpcy5fY3VycmVudExlbmd0aCA9IHZhbHVlID8/IDBcbiAgICB0aGlzLnVwZGF0ZUNvbnRleHQoKVxuICB9XG5cbiAgcHJpdmF0ZSBfbWF4bGVuZ3RoOiBudW1iZXIgPSBOdW1iZXIuTUFYX1NBRkVfSU5URUdFUlxuICBwcml2YXRlIF9jdXJyZW50TGVuZ3RoID0gMFxuICBwcml2YXRlIGlzVmlld0NyZWF0ZWQgPSBmYWxzZVxuICBwcml2YXRlIGNvbnRleHQgPSB7IGNoYXJhY3RlcnNMZWZ0OiAwIH1cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYsXG4gICAgcHJpdmF0ZSByZWFkb25seSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgKSB7fVxuXG4gIHVwZGF0ZUNvbnRleHQoKSB7XG4gICAgdGhpcy5jb250ZXh0LmNoYXJhY3RlcnNMZWZ0ID0gdGhpcy5jYWxjdWxhdGVDaGFyYWN0ZXJzTGVmdChcbiAgICAgIHRoaXMuX21heGxlbmd0aCxcbiAgICAgIHRoaXMuX2N1cnJlbnRMZW5ndGgsXG4gICAgKVxuICB9XG5cbiAgY2FsY3VsYXRlQ2hhcmFjdGVyc0xlZnQgPSAobWF4OiBudW1iZXIsIGN1cnJlbnQ6IG51bWJlcik6IG51bWJlciA9PlxuICAgIG1heCAtIGN1cnJlbnRcbn1cbiJdfQ==
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcmFjdGVyLWNvdW50ZG93bi5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci9jaGFyYWN0ZXItY291bnRkb3duL2NoYXJhY3Rlci1jb3VudGRvd24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQTs7QUFLL0UsTUFBTSxPQUFPLDJCQUEyQjtJQUN0QyxJQUNJLFNBQVMsQ0FBQyxLQUF5QjtRQUNyQyxJQUFJLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ25DLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFBO1lBQ3ZCLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQTtZQUNwQixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRTtnQkFDdkIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO2dCQUN4RSxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQTthQUMxQjtTQUNGO2FBQU07WUFDTCxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUU7Z0JBQ3RCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtnQkFDN0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUE7YUFDM0I7U0FDRjtJQUNILENBQUM7SUFFRCxJQUNJLGFBQWEsQ0FBQyxLQUFhO1FBQzdCLElBQUksQ0FBQyxjQUFjLEdBQUcsS0FBSyxJQUFJLENBQUMsQ0FBQTtRQUNoQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUE7SUFDdEIsQ0FBQztJQU9ELFlBQ21CLGdCQUFrQyxFQUNsQyxXQUE2QjtRQUQ3QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQ2xDLGdCQUFXLEdBQVgsV0FBVyxDQUFrQjtRQVB4QyxlQUFVLEdBQVcsTUFBTSxDQUFDLGdCQUFnQixDQUFBO1FBQzVDLG1CQUFjLEdBQUcsQ0FBQyxDQUFBO1FBQ2xCLGtCQUFhLEdBQUcsS0FBSyxDQUFBO1FBQ3JCLFlBQU8sR0FBRyxFQUFFLGNBQWMsRUFBRSxDQUFDLEVBQUUsQ0FBQTtRQWN2Qyw0QkFBdUIsR0FBRyxDQUFDLEdBQVcsRUFBRSxPQUFlLEVBQVUsRUFBRSxDQUNqRSxHQUFHLEdBQUcsT0FBTyxDQUFBO0lBVlosQ0FBQztJQUVKLGFBQWE7UUFDWCxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsdUJBQXVCLENBQ3hELElBQUksQ0FBQyxVQUFVLEVBQ2YsSUFBSSxDQUFDLGNBQWMsQ0FDcEIsQ0FBQTtJQUNILENBQUM7K0dBdkNVLDJCQUEyQjttR0FBM0IsMkJBQTJCOzs0RkFBM0IsMkJBQTJCO2tCQUh2QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSwwQkFBMEI7aUJBQ3JDO2lJQUdLLFNBQVM7c0JBRFosS0FBSzt1QkFBQyx3QkFBd0I7Z0JBa0IzQixhQUFhO3NCQURoQixLQUFLO3VCQUFDLHFDQUFxQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQsIFRlbXBsYXRlUmVmLCBWaWV3Q29udGFpbmVyUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW25nZ3ZDaGFyYWN0ZXJDb3VudGRvd25dJyxcbn0pXG5leHBvcnQgY2xhc3MgQ2hhcmFjdGVyQ291bnRkb3duRGlyZWN0aXZlIHtcbiAgQElucHV0KCduZ2d2Q2hhcmFjdGVyQ291bnRkb3duJylcbiAgc2V0IG1heGxlbmd0aCh2YWx1ZTogbnVtYmVyIHwgdW5kZWZpbmVkKSB7XG4gICAgaWYgKCEhdmFsdWUgJiYgIU51bWJlci5pc05hTih2YWx1ZSkpIHtcbiAgICAgIHRoaXMuX21heGxlbmd0aCA9IHZhbHVlXG4gICAgICB0aGlzLnVwZGF0ZUNvbnRleHQoKVxuICAgICAgaWYgKCF0aGlzLmlzVmlld0NyZWF0ZWQpIHtcbiAgICAgICAgdGhpcy52aWV3Q29udGFpbmVyUmVmLmNyZWF0ZUVtYmVkZGVkVmlldyh0aGlzLnRlbXBsYXRlUmVmLCB0aGlzLmNvbnRleHQpXG4gICAgICAgIHRoaXMuaXNWaWV3Q3JlYXRlZCA9IHRydWVcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKHRoaXMuaXNWaWV3Q3JlYXRlZCkge1xuICAgICAgICB0aGlzLnZpZXdDb250YWluZXJSZWYuY2xlYXIoKVxuICAgICAgICB0aGlzLmlzVmlld0NyZWF0ZWQgPSBmYWxzZVxuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIEBJbnB1dCgnbmdndkNoYXJhY3RlckNvdW50ZG93bkN1cnJlbnRMZW5ndGgnKVxuICBzZXQgY3VycmVudExlbmd0aCh2YWx1ZTogbnVtYmVyKSB7XG4gICAgdGhpcy5fY3VycmVudExlbmd0aCA9IHZhbHVlID8/IDBcbiAgICB0aGlzLnVwZGF0ZUNvbnRleHQoKVxuICB9XG5cbiAgcHJpdmF0ZSBfbWF4bGVuZ3RoOiBudW1iZXIgPSBOdW1iZXIuTUFYX1NBRkVfSU5URUdFUlxuICBwcml2YXRlIF9jdXJyZW50TGVuZ3RoID0gMFxuICBwcml2YXRlIGlzVmlld0NyZWF0ZWQgPSBmYWxzZVxuICBwcml2YXRlIGNvbnRleHQgPSB7IGNoYXJhY3RlcnNMZWZ0OiAwIH1cblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYsXG4gICAgcHJpdmF0ZSByZWFkb25seSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgKSB7fVxuXG4gIHVwZGF0ZUNvbnRleHQoKSB7XG4gICAgdGhpcy5jb250ZXh0LmNoYXJhY3RlcnNMZWZ0ID0gdGhpcy5jYWxjdWxhdGVDaGFyYWN0ZXJzTGVmdChcbiAgICAgIHRoaXMuX21heGxlbmd0aCxcbiAgICAgIHRoaXMuX2N1cnJlbnRMZW5ndGgsXG4gICAgKVxuICB9XG5cbiAgY2FsY3VsYXRlQ2hhcmFjdGVyc0xlZnQgPSAobWF4OiBudW1iZXIsIGN1cnJlbnQ6IG51bWJlcik6IG51bWJlciA9PlxuICAgIG1heCAtIGN1cnJlbnRcbn1cbiJdfQ==
@@ -1,8 +1,8 @@
1
1
  ;
2
2
  (() => {
3
3
  // Make sure there is an incremental ID each component can use
4
- if (typeof window !== 'undefined' && !window.ngv) {
5
- window.ngv = {
4
+ if (typeof window !== 'undefined' && !window.nggv) {
5
+ window.nggv = {
6
6
  ids: { default: -1 },
7
7
  nextId(namespace = 'default') {
8
8
  let id = this.ids[namespace] || 0;
@@ -17,4 +17,4 @@
17
17
  }
18
18
  })();
19
19
  export {};
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS5nbG9iYWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy92LWFuZ3VsYXIvY29yZS9jb3JlLmdsb2JhbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0EsQ0FBQztBQUFBLENBQUMsR0FBRyxFQUFFO0lBQ0wsOERBQThEO0lBQzlELElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBRTtRQUNoRCxNQUFNLENBQUMsR0FBRyxHQUFHO1lBQ1gsR0FBRyxFQUFFLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxFQUFFO1lBQ3BCLE1BQU0sQ0FBQyxTQUFTLEdBQUcsU0FBUztnQkFDMUIsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUE7Z0JBQ2pDLElBQUksT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxLQUFLLFFBQVE7b0JBQUUsRUFBRSxFQUFFLENBQUE7Z0JBQ2pELElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFBO2dCQUN4QixPQUFPLFNBQVMsS0FBSyxTQUFTO29CQUM1QixDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUU7b0JBQ2QsQ0FBQyxDQUFDLFFBQVEsU0FBUyxJQUFJLEVBQUUsRUFBRSxDQUFBO1lBQy9CLENBQUM7U0FDRixDQUFBO0tBQ0Y7QUFDSCxDQUFDLENBQUMsRUFBRSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gV2UgbXVzdCBmb3JjZSB0c2MgdG8gaW50ZXJwcmV0IHRoaXMgZmlsZSBhcyBhIG1vZHVsZSwgcmVzb2x2ZXNcbi8vIFwiQXVnbWVudGF0aW9ucyBmb3IgdGhlIGdsb2JhbCBzY29wZSBjYW4gb25seSBiZSBkaXJlY3RseSBuZXN0ZWQgaW4gZXh0ZXJuYWwgbW9kdWxlcyBvciBhbWJpZW50IG1vZHVsZSBkZWNsYXJhdGlvbnMuXCJcbmV4cG9ydCB7fVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBXaW5kb3cge1xuICAgIC8qKiBDb3VudGVyIGZvciB1bmlxdWUgaWRlbnRpZmllcnMgKi9cbiAgICBuZ3Y6IHtcbiAgICAgIGlkczogeyBbbmFtZXNwYWNlOiBzdHJpbmddOiBudW1iZXI7IGRlZmF1bHQ6IG51bWJlciB9XG4gICAgICBuZXh0SWQ6IChuYW1lc3BhY2U/OiBzdHJpbmcpID0+IHN0cmluZ1xuICAgIH1cbiAgfVxufVxuXG47KCgpID0+IHtcbiAgLy8gTWFrZSBzdXJlIHRoZXJlIGlzIGFuIGluY3JlbWVudGFsIElEIGVhY2ggY29tcG9uZW50IGNhbiB1c2VcbiAgaWYgKHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmICF3aW5kb3cubmd2KSB7XG4gICAgd2luZG93Lm5ndiA9IHtcbiAgICAgIGlkczogeyBkZWZhdWx0OiAtMSB9LFxuICAgICAgbmV4dElkKG5hbWVzcGFjZSA9ICdkZWZhdWx0Jyk6IHN0cmluZyB7XG4gICAgICAgIGxldCBpZCA9IHRoaXMuaWRzW25hbWVzcGFjZV0gfHwgMFxuICAgICAgICBpZiAodHlwZW9mIHRoaXMuaWRzW25hbWVzcGFjZV0gPT09ICdudW1iZXInKSBpZCsrXG4gICAgICAgIHRoaXMuaWRzW25hbWVzcGFjZV0gPSBpZFxuICAgICAgICByZXR1cm4gbmFtZXNwYWNlID09PSAnZGVmYXVsdCdcbiAgICAgICAgICA/IGBuZ2d2LSR7aWR9YFxuICAgICAgICAgIDogYG5nZ3YtJHtuYW1lc3BhY2V9LSR7aWR9YFxuICAgICAgfSxcbiAgICB9XG4gIH1cbn0pKClcbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS5nbG9iYWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy92LWFuZ3VsYXIvY29yZS9jb3JlLmdsb2JhbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0EsQ0FBQztBQUFBLENBQUMsR0FBRyxFQUFFO0lBQ0wsOERBQThEO0lBQzlELElBQUksT0FBTyxNQUFNLEtBQUssV0FBVyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRTtRQUNqRCxNQUFNLENBQUMsSUFBSSxHQUFHO1lBQ1osR0FBRyxFQUFFLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQyxFQUFFO1lBQ3BCLE1BQU0sQ0FBQyxTQUFTLEdBQUcsU0FBUztnQkFDMUIsSUFBSSxFQUFFLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUE7Z0JBQ2pDLElBQUksT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxLQUFLLFFBQVE7b0JBQUUsRUFBRSxFQUFFLENBQUE7Z0JBQ2pELElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFBO2dCQUN4QixPQUFPLFNBQVMsS0FBSyxTQUFTO29CQUM1QixDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUU7b0JBQ2QsQ0FBQyxDQUFDLFFBQVEsU0FBUyxJQUFJLEVBQUUsRUFBRSxDQUFBO1lBQy9CLENBQUM7U0FDRixDQUFBO0tBQ0Y7QUFDSCxDQUFDLENBQUMsRUFBRSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gV2UgbXVzdCBmb3JjZSB0c2MgdG8gaW50ZXJwcmV0IHRoaXMgZmlsZSBhcyBhIG1vZHVsZSwgcmVzb2x2ZXNcbi8vIFwiQXVnbWVudGF0aW9ucyBmb3IgdGhlIGdsb2JhbCBzY29wZSBjYW4gb25seSBiZSBkaXJlY3RseSBuZXN0ZWQgaW4gZXh0ZXJuYWwgbW9kdWxlcyBvciBhbWJpZW50IG1vZHVsZSBkZWNsYXJhdGlvbnMuXCJcbmV4cG9ydCB7fVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBXaW5kb3cge1xuICAgIC8qKiBDb3VudGVyIGZvciB1bmlxdWUgaWRlbnRpZmllcnMgKi9cbiAgICBuZ2d2OiB7XG4gICAgICBpZHM6IHsgW25hbWVzcGFjZTogc3RyaW5nXTogbnVtYmVyOyBkZWZhdWx0OiBudW1iZXIgfVxuICAgICAgbmV4dElkOiAobmFtZXNwYWNlPzogc3RyaW5nKSA9PiBzdHJpbmdcbiAgICB9XG4gIH1cbn1cblxuOygoKSA9PiB7XG4gIC8vIE1ha2Ugc3VyZSB0aGVyZSBpcyBhbiBpbmNyZW1lbnRhbCBJRCBlYWNoIGNvbXBvbmVudCBjYW4gdXNlXG4gIGlmICh0eXBlb2Ygd2luZG93ICE9PSAndW5kZWZpbmVkJyAmJiAhd2luZG93Lm5nZ3YpIHtcbiAgICB3aW5kb3cubmdndiA9IHtcbiAgICAgIGlkczogeyBkZWZhdWx0OiAtMSB9LFxuICAgICAgbmV4dElkKG5hbWVzcGFjZSA9ICdkZWZhdWx0Jyk6IHN0cmluZyB7XG4gICAgICAgIGxldCBpZCA9IHRoaXMuaWRzW25hbWVzcGFjZV0gfHwgMFxuICAgICAgICBpZiAodHlwZW9mIHRoaXMuaWRzW25hbWVzcGFjZV0gPT09ICdudW1iZXInKSBpZCsrXG4gICAgICAgIHRoaXMuaWRzW25hbWVzcGFjZV0gPSBpZFxuICAgICAgICByZXR1cm4gbmFtZXNwYWNlID09PSAnZGVmYXVsdCdcbiAgICAgICAgICA/IGBuZ2d2LSR7aWR9YFxuICAgICAgICAgIDogYG5nZ3YtJHtuYW1lc3BhY2V9LSR7aWR9YFxuICAgICAgfSxcbiAgICB9XG4gIH1cbn0pKClcbiJdfQ==
@@ -20,7 +20,7 @@ export class NgvDropdownListComponent {
20
20
  /** The additional amount to show when option is scrolled into view. */
21
21
  this.scrollOffset = 24;
22
22
  /** Id of the host element and is accessible by the children, automatically generated if not provided. */
23
- this.id = window.ngv?.nextId();
23
+ this.id = window.nggv?.nextId();
24
24
  /** Special property used for selecting DOM elements during automated UI testing. */
25
25
  this.thook = 'dropdown';
26
26
  this.selectedValueChanged = new EventEmitter();
@@ -207,11 +207,11 @@ export class NgvDropdownListComponent {
207
207
  }
208
208
  }
209
209
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvDropdownListComponent, deps: [{ token: TRANSLOCO_SCOPE, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
210
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvDropdownListComponent, selector: "nggv-dropdown-list", inputs: { expanded: "expanded", state: "state", scrollOffset: "scrollOffset", optionContentTpl: "optionContentTpl", id: "id", thook: "thook", options: "options", textToHighlight: "textToHighlight" }, outputs: { selectedValueChanged: "selectedValueChanged", closed: "closed" }, host: { listeners: { "document:keydown": "onKeyDown($event)", "document:keyup": "onKeyUp($event)" }, properties: { "attr.id": "this.id", "attr.data-thook": "this.thook" } }, viewQueries: [{ propertyName: "optionRefs", predicate: ["optionRefs"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *transloco=\"let t; read: scope\">\n <ul\n class=\"gds-dropdown__options card options gds-reset\"\n [class.gds-dropdown__options-expanded]=\"expanded\"\n role=\"listbox\"\n tabindex=\"-1\"\n [attr.data-thook]=\"thook + '-options'\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.aria-activedescendant]=\"\n state ? id + '-option-' + state?.key : undefined\n \"\n >\n <ng-container *ngFor=\"let item of options\">\n <!-- OPTION -->\n <ng-container *ngIf=\"!isGroup(item)\">\n <ng-template\n *ngTemplateOutlet=\"listItemTemplate; context: { $implicit: item }\"\n ></ng-template>\n </ng-container>\n\n <!-- OPTION GROUP -->\n <li\n class=\"gds-dropdown__options__label group\"\n [attr.data-thook]=\"thook + '-option-group'\"\n *ngIf=\"isGroup(item)\"\n >\n <div class=\"sdv-list__label\">{{ t(item.label) }}</div>\n <ul [attr.aria-disabled]=\"item.disabled\">\n <ng-container *ngFor=\"let option of castGroup(item).options\">\n <ng-template\n *ngTemplateOutlet=\"\n listItemTemplate;\n context: { $implicit: option }\n \"\n ></ng-template>\n </ng-container>\n </ul>\n </li>\n </ng-container>\n </ul>\n\n <!-- TEMPLATE -->\n <ng-template #listItemTemplate let-option>\n <li\n #optionRefs\n *ngIf=\"!optionContentTpl\"\n tabindex=\"-1\"\n [id]=\"id + '-option-' + option.key\"\n class=\"gds-dropdown__options__label option\"\n role=\"option\"\n #liElem\n [attr.data-thook]=\"thook + '-option-' + option.key\"\n [attr.aria-disabled]=\"option.disabled\"\n [attr.aria-selected]=\"\n option.key === selectedValue?.key && !!selectedValue?.key\n \"\n [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n [ngvTooltip]=\"isOverflow(liElem) ? t(option.label) : undefined\"\n (click)=\"updateState(option, $event)\"\n >\n <ng-template\n *ngTemplateOutlet=\"\n basicOptionContentTpl;\n context: { $implicit: option }\n \"\n >\n </ng-template>\n </li>\n <!-- Checking overflow on custom templates do not work skip adding ngvToolTip if custom template is provided -->\n <li\n #optionRefs\n *ngIf=\"!!optionContentTpl\"\n tabindex=\"-1\"\n [id]=\"id + '-option-' + option.key\"\n class=\"gds-dropdown__options__label option\"\n role=\"option\"\n #liElem\n [attr.data-thook]=\"thook + '-option-' + option.key\"\n [attr.aria-disabled]=\"option.disabled\"\n [attr.aria-selected]=\"\n option.key === selectedValue?.key && !!selectedValue?.key\n \"\n [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n (click)=\"updateState(option, $event)\"\n >\n <ng-template\n *ngTemplateOutlet=\"optionContentTpl; context: { $implicit: option }\"\n >\n </ng-template>\n </li>\n </ng-template>\n\n <ng-template #basicOptionContentTpl let-option>\n <nggv-typeahead-highlight\n *ngIf=\"!!textToHighlight\"\n [textToHighlight]=\"textToHighlight\"\n [textContent]=\"t(option.label)\"\n >\n </nggv-typeahead-highlight>\n <ng-container *ngIf=\"!textToHighlight\">\n {{ t(option.label) }}\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [":host{position:absolute;bottom:0;transform:translateY(calc(100% + .5rem));--z-index: var(--sg-z-index-dropdown)}:host .hidden{visibility:hidden;display:none}:host ul[role=menu] [role=menuitem]{padding:.75rem;cursor:pointer}:host ul[role=menu] [role=menuitem]:hover,:host ul[role=menu] [role=menuitem]:focus-visible{background-color:var(--gds-ref-pallet-base200)}:host ul[role=menu] [role=menuitem]:active{background-color:var(--gds-ref-pallet-base300)}:host ul[role=menu] [role=menuitem]:focus{outline-color:#000;outline-offset:-.25rem}:host ul[role=listbox]{--z-index: var(--sg-z-index-popover);background-color:var(--sg-popover-background);flex-direction:column;justify-content:flex-end;inset:auto;z-index:var(--z-index);box-shadow:var(--sg-popover-box-shadow);color:var(--text-primary-color);padding:0;border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--text-primary-color);--sg-border-color: var(--text-primary-color);border-radius:var(--sg-border-radius)}:host ul[role=listbox] [role=option]{padding:.75rem 1rem;line-height:1.25;cursor:pointer}:host ul[role=listbox] [role=option]:hover,:host ul[role=listbox] [role=option]:focus-visible{background-color:var(--grey-400)}:host ul[role=listbox] [role=option]:active{background-color:var(--grey-400)}:host ul[role=listbox] [role=option]:focus{outline-color:#000;outline-offset:-.25rem}:host ul[role=listbox] [role=option].active.sg-highlighted,:host ul[role=listbox] [role=option][aria-selected=true]{background:var(--grey-1000);color:#fff}:host .sg-fieldset-container{overflow-y:auto}:host .sg-fieldset-container fieldset[role=listbox][aria-multiselectable=true] [role=option]{display:flex;width:100%}:host .sg-fieldset-container fieldset[role=listbox][aria-multiselectable=true] [role=option].active.sg-highlighted input[type=checkbox]~i{border-color:#007ac7!important;box-shadow:0 0 .25em .0625em #41b0ee;outline-color:transparent;outline-style:solid}:host .gds-dropdown__options{padding-left:0;margin-bottom:0;margin-top:0;display:flex;flex-direction:column;list-style:none;display:none}:host .gds-dropdown__options>li{padding-bottom:.5rem;padding-top:.5rem;border:0;display:block;position:relative}:host .gds-dropdown__options>li:before{font-weight:500;display:inline-block;left:0;position:absolute;text-align:center}:host .gds-dropdown__options-expanded{display:block}:host .gds-dropdown__options__label:hover,:host .gds-dropdown__options__label:focus-visible{background-color:var(--grey-400)}:host .gds-dropdown__options__label:active{background-color:var(--grey-500)}:host .gds-dropdown__options__label:focus-visible{outline-color:#000;outline-offset:-.25rem}:host .gds-dropdown__options__label[aria-hidden=true]{display:none}:host .gds-dropdown__options__label[highlighted]{color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.NgvTypeaheadHighlightComponent, selector: "nggv-typeahead-highlight", inputs: ["textContent", "textToHighlight"] }, { kind: "directive", type: i3.NgvTooltipDirective, selector: "[ngvTooltip]", inputs: ["ngvTooltip", "thook", "placement", "shown", "offset", "resizeThrottle", "maxWidth"], outputs: ["ngvShow", "ngvHide"] }, { kind: "directive", type: i4.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoLang", "translocoLoadingTpl"] }] }); }
210
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvDropdownListComponent, selector: "nggv-dropdown-list", inputs: { expanded: "expanded", state: "state", scrollOffset: "scrollOffset", optionContentTpl: "optionContentTpl", id: "id", thook: "thook", options: "options", textToHighlight: "textToHighlight" }, outputs: { selectedValueChanged: "selectedValueChanged", closed: "closed" }, host: { listeners: { "document:keydown": "onKeyDown($event)", "document:keyup": "onKeyUp($event)" }, properties: { "attr.id": "this.id", "attr.data-thook": "this.thook" } }, viewQueries: [{ propertyName: "optionRefs", predicate: ["optionRefs"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *transloco=\"let t; read: scope\">\n <ul\n class=\"gds-dropdown__options card options gds-reset\"\n [class.gds-dropdown__options-expanded]=\"expanded\"\n role=\"listbox\"\n tabindex=\"-1\"\n [attr.data-thook]=\"thook + '-options'\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.aria-activedescendant]=\"\n state ? id + '-option-' + state?.key : undefined\n \"\n >\n <ng-container *ngFor=\"let item of options\">\n <!-- OPTION -->\n <ng-container *ngIf=\"!isGroup(item)\">\n <ng-template\n *ngTemplateOutlet=\"listItemTemplate; context: { $implicit: item }\"\n ></ng-template>\n </ng-container>\n\n <!-- OPTION GROUP -->\n <li\n class=\"gds-dropdown__options__label group\"\n [attr.data-thook]=\"thook + '-option-group'\"\n *ngIf=\"isGroup(item)\"\n >\n <div class=\"sdv-list__label\">{{ t(item.label) }}</div>\n <ul [attr.aria-disabled]=\"item.disabled\">\n <ng-container *ngFor=\"let option of castGroup(item).options\">\n <ng-template\n *ngTemplateOutlet=\"\n listItemTemplate;\n context: { $implicit: option }\n \"\n ></ng-template>\n </ng-container>\n </ul>\n </li>\n </ng-container>\n </ul>\n\n <!-- TEMPLATE -->\n <ng-template #listItemTemplate let-option>\n <li\n #optionRefs\n *ngIf=\"!optionContentTpl\"\n tabindex=\"-1\"\n [id]=\"id + '-option-' + option.key\"\n class=\"gds-dropdown__options__label option\"\n role=\"option\"\n #liElem\n [attr.data-thook]=\"thook + '-option-' + option.key\"\n [attr.aria-disabled]=\"option.disabled\"\n [attr.aria-selected]=\"\n option.key === selectedValue?.key && !!selectedValue?.key\n \"\n [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n [nggvTooltip]=\"isOverflow(liElem) ? t(option.label) : undefined\"\n (click)=\"updateState(option, $event)\"\n >\n <ng-template\n *ngTemplateOutlet=\"\n basicOptionContentTpl;\n context: { $implicit: option }\n \"\n >\n </ng-template>\n </li>\n <!-- Checking overflow on custom templates do not work skip adding nggvToolTip if custom template is provided -->\n <li\n #optionRefs\n *ngIf=\"!!optionContentTpl\"\n tabindex=\"-1\"\n [id]=\"id + '-option-' + option.key\"\n class=\"gds-dropdown__options__label option\"\n role=\"option\"\n #liElem\n [attr.data-thook]=\"thook + '-option-' + option.key\"\n [attr.aria-disabled]=\"option.disabled\"\n [attr.aria-selected]=\"\n option.key === selectedValue?.key && !!selectedValue?.key\n \"\n [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n (click)=\"updateState(option, $event)\"\n >\n <ng-template\n *ngTemplateOutlet=\"optionContentTpl; context: { $implicit: option }\"\n >\n </ng-template>\n </li>\n </ng-template>\n\n <ng-template #basicOptionContentTpl let-option>\n <nggv-typeahead-highlight\n *ngIf=\"!!textToHighlight\"\n [textToHighlight]=\"textToHighlight\"\n [textContent]=\"t(option.label)\"\n >\n </nggv-typeahead-highlight>\n <ng-container *ngIf=\"!textToHighlight\">\n {{ t(option.label) }}\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [":host{position:absolute;bottom:0;transform:translateY(calc(100% + .5rem));--z-index: var(--sg-z-index-dropdown)}:host .hidden{visibility:hidden;display:none}:host ul[role=menu] [role=menuitem]{padding:.75rem;cursor:pointer}:host ul[role=menu] [role=menuitem]:hover,:host ul[role=menu] [role=menuitem]:focus-visible{background-color:var(--gds-ref-pallet-base200)}:host ul[role=menu] [role=menuitem]:active{background-color:var(--gds-ref-pallet-base300)}:host ul[role=menu] [role=menuitem]:focus{outline-color:#000;outline-offset:-.25rem}:host ul[role=listbox]{--z-index: var(--sg-z-index-popover);background-color:var(--sg-popover-background);flex-direction:column;justify-content:flex-end;inset:auto;z-index:var(--z-index);box-shadow:var(--sg-popover-box-shadow);color:var(--text-primary-color);padding:0;border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--text-primary-color);--sg-border-color: var(--text-primary-color);border-radius:var(--sg-border-radius)}:host ul[role=listbox] [role=option]{padding:.75rem 1rem;line-height:1.25;cursor:pointer}:host ul[role=listbox] [role=option]:hover,:host ul[role=listbox] [role=option]:focus-visible{background-color:var(--grey-400)}:host ul[role=listbox] [role=option]:active{background-color:var(--grey-400)}:host ul[role=listbox] [role=option]:focus{outline-color:#000;outline-offset:-.25rem}:host ul[role=listbox] [role=option].active.sg-highlighted,:host ul[role=listbox] [role=option][aria-selected=true]{background:var(--grey-1000);color:#fff}:host .sg-fieldset-container{overflow-y:auto}:host .sg-fieldset-container fieldset[role=listbox][aria-multiselectable=true] [role=option]{display:flex;width:100%}:host .sg-fieldset-container fieldset[role=listbox][aria-multiselectable=true] [role=option].active.sg-highlighted input[type=checkbox]~i{border-color:#007ac7!important;box-shadow:0 0 .25em .0625em #41b0ee;outline-color:transparent;outline-style:solid}:host .gds-dropdown__options{padding-left:0;margin-bottom:0;margin-top:0;display:flex;flex-direction:column;list-style:none;display:none}:host .gds-dropdown__options>li{padding-bottom:.5rem;padding-top:.5rem;border:0;display:block;position:relative}:host .gds-dropdown__options>li:before{font-weight:500;display:inline-block;left:0;position:absolute;text-align:center}:host .gds-dropdown__options-expanded{display:block}:host .gds-dropdown__options__label:hover,:host .gds-dropdown__options__label:focus-visible{background-color:var(--grey-400)}:host .gds-dropdown__options__label:active{background-color:var(--grey-500)}:host .gds-dropdown__options__label:focus-visible{outline-color:#000;outline-offset:-.25rem}:host .gds-dropdown__options__label[aria-hidden=true]{display:none}:host .gds-dropdown__options__label[highlighted]{color:#fff}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.NgvTypeaheadHighlightComponent, selector: "nggv-typeahead-highlight", inputs: ["textContent", "textToHighlight"] }, { kind: "directive", type: i3.NgvTooltipDirective, selector: "[nggvTooltip]", inputs: ["nggvTooltip", "thook", "placement", "shown", "offset", "resizeThrottle", "maxWidth"], outputs: ["nggvShow", "nggvHide"] }, { kind: "directive", type: i4.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoLang", "translocoLoadingTpl"] }] }); }
211
211
  }
212
212
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvDropdownListComponent, decorators: [{
213
213
  type: Component,
214
- args: [{ selector: 'nggv-dropdown-list', template: "<ng-container *transloco=\"let t; read: scope\">\n <ul\n class=\"gds-dropdown__options card options gds-reset\"\n [class.gds-dropdown__options-expanded]=\"expanded\"\n role=\"listbox\"\n tabindex=\"-1\"\n [attr.data-thook]=\"thook + '-options'\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.aria-activedescendant]=\"\n state ? id + '-option-' + state?.key : undefined\n \"\n >\n <ng-container *ngFor=\"let item of options\">\n <!-- OPTION -->\n <ng-container *ngIf=\"!isGroup(item)\">\n <ng-template\n *ngTemplateOutlet=\"listItemTemplate; context: { $implicit: item }\"\n ></ng-template>\n </ng-container>\n\n <!-- OPTION GROUP -->\n <li\n class=\"gds-dropdown__options__label group\"\n [attr.data-thook]=\"thook + '-option-group'\"\n *ngIf=\"isGroup(item)\"\n >\n <div class=\"sdv-list__label\">{{ t(item.label) }}</div>\n <ul [attr.aria-disabled]=\"item.disabled\">\n <ng-container *ngFor=\"let option of castGroup(item).options\">\n <ng-template\n *ngTemplateOutlet=\"\n listItemTemplate;\n context: { $implicit: option }\n \"\n ></ng-template>\n </ng-container>\n </ul>\n </li>\n </ng-container>\n </ul>\n\n <!-- TEMPLATE -->\n <ng-template #listItemTemplate let-option>\n <li\n #optionRefs\n *ngIf=\"!optionContentTpl\"\n tabindex=\"-1\"\n [id]=\"id + '-option-' + option.key\"\n class=\"gds-dropdown__options__label option\"\n role=\"option\"\n #liElem\n [attr.data-thook]=\"thook + '-option-' + option.key\"\n [attr.aria-disabled]=\"option.disabled\"\n [attr.aria-selected]=\"\n option.key === selectedValue?.key && !!selectedValue?.key\n \"\n [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n [ngvTooltip]=\"isOverflow(liElem) ? t(option.label) : undefined\"\n (click)=\"updateState(option, $event)\"\n >\n <ng-template\n *ngTemplateOutlet=\"\n basicOptionContentTpl;\n context: { $implicit: option }\n \"\n >\n </ng-template>\n </li>\n <!-- Checking overflow on custom templates do not work skip adding ngvToolTip if custom template is provided -->\n <li\n #optionRefs\n *ngIf=\"!!optionContentTpl\"\n tabindex=\"-1\"\n [id]=\"id + '-option-' + option.key\"\n class=\"gds-dropdown__options__label option\"\n role=\"option\"\n #liElem\n [attr.data-thook]=\"thook + '-option-' + option.key\"\n [attr.aria-disabled]=\"option.disabled\"\n [attr.aria-selected]=\"\n option.key === selectedValue?.key && !!selectedValue?.key\n \"\n [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n (click)=\"updateState(option, $event)\"\n >\n <ng-template\n *ngTemplateOutlet=\"optionContentTpl; context: { $implicit: option }\"\n >\n </ng-template>\n </li>\n </ng-template>\n\n <ng-template #basicOptionContentTpl let-option>\n <nggv-typeahead-highlight\n *ngIf=\"!!textToHighlight\"\n [textToHighlight]=\"textToHighlight\"\n [textContent]=\"t(option.label)\"\n >\n </nggv-typeahead-highlight>\n <ng-container *ngIf=\"!textToHighlight\">\n {{ t(option.label) }}\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [":host{position:absolute;bottom:0;transform:translateY(calc(100% + .5rem));--z-index: var(--sg-z-index-dropdown)}:host .hidden{visibility:hidden;display:none}:host ul[role=menu] [role=menuitem]{padding:.75rem;cursor:pointer}:host ul[role=menu] [role=menuitem]:hover,:host ul[role=menu] [role=menuitem]:focus-visible{background-color:var(--gds-ref-pallet-base200)}:host ul[role=menu] [role=menuitem]:active{background-color:var(--gds-ref-pallet-base300)}:host ul[role=menu] [role=menuitem]:focus{outline-color:#000;outline-offset:-.25rem}:host ul[role=listbox]{--z-index: var(--sg-z-index-popover);background-color:var(--sg-popover-background);flex-direction:column;justify-content:flex-end;inset:auto;z-index:var(--z-index);box-shadow:var(--sg-popover-box-shadow);color:var(--text-primary-color);padding:0;border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--text-primary-color);--sg-border-color: var(--text-primary-color);border-radius:var(--sg-border-radius)}:host ul[role=listbox] [role=option]{padding:.75rem 1rem;line-height:1.25;cursor:pointer}:host ul[role=listbox] [role=option]:hover,:host ul[role=listbox] [role=option]:focus-visible{background-color:var(--grey-400)}:host ul[role=listbox] [role=option]:active{background-color:var(--grey-400)}:host ul[role=listbox] [role=option]:focus{outline-color:#000;outline-offset:-.25rem}:host ul[role=listbox] [role=option].active.sg-highlighted,:host ul[role=listbox] [role=option][aria-selected=true]{background:var(--grey-1000);color:#fff}:host .sg-fieldset-container{overflow-y:auto}:host .sg-fieldset-container fieldset[role=listbox][aria-multiselectable=true] [role=option]{display:flex;width:100%}:host .sg-fieldset-container fieldset[role=listbox][aria-multiselectable=true] [role=option].active.sg-highlighted input[type=checkbox]~i{border-color:#007ac7!important;box-shadow:0 0 .25em .0625em #41b0ee;outline-color:transparent;outline-style:solid}:host .gds-dropdown__options{padding-left:0;margin-bottom:0;margin-top:0;display:flex;flex-direction:column;list-style:none;display:none}:host .gds-dropdown__options>li{padding-bottom:.5rem;padding-top:.5rem;border:0;display:block;position:relative}:host .gds-dropdown__options>li:before{font-weight:500;display:inline-block;left:0;position:absolute;text-align:center}:host .gds-dropdown__options-expanded{display:block}:host .gds-dropdown__options__label:hover,:host .gds-dropdown__options__label:focus-visible{background-color:var(--grey-400)}:host .gds-dropdown__options__label:active{background-color:var(--grey-500)}:host .gds-dropdown__options__label:focus-visible{outline-color:#000;outline-offset:-.25rem}:host .gds-dropdown__options__label[aria-hidden=true]{display:none}:host .gds-dropdown__options__label[highlighted]{color:#fff}\n"] }]
214
+ args: [{ selector: 'nggv-dropdown-list', template: "<ng-container *transloco=\"let t; read: scope\">\n <ul\n class=\"gds-dropdown__options card options gds-reset\"\n [class.gds-dropdown__options-expanded]=\"expanded\"\n role=\"listbox\"\n tabindex=\"-1\"\n [attr.data-thook]=\"thook + '-options'\"\n [attr.aria-labelledby]=\"id + '-label'\"\n [attr.aria-activedescendant]=\"\n state ? id + '-option-' + state?.key : undefined\n \"\n >\n <ng-container *ngFor=\"let item of options\">\n <!-- OPTION -->\n <ng-container *ngIf=\"!isGroup(item)\">\n <ng-template\n *ngTemplateOutlet=\"listItemTemplate; context: { $implicit: item }\"\n ></ng-template>\n </ng-container>\n\n <!-- OPTION GROUP -->\n <li\n class=\"gds-dropdown__options__label group\"\n [attr.data-thook]=\"thook + '-option-group'\"\n *ngIf=\"isGroup(item)\"\n >\n <div class=\"sdv-list__label\">{{ t(item.label) }}</div>\n <ul [attr.aria-disabled]=\"item.disabled\">\n <ng-container *ngFor=\"let option of castGroup(item).options\">\n <ng-template\n *ngTemplateOutlet=\"\n listItemTemplate;\n context: { $implicit: option }\n \"\n ></ng-template>\n </ng-container>\n </ul>\n </li>\n </ng-container>\n </ul>\n\n <!-- TEMPLATE -->\n <ng-template #listItemTemplate let-option>\n <li\n #optionRefs\n *ngIf=\"!optionContentTpl\"\n tabindex=\"-1\"\n [id]=\"id + '-option-' + option.key\"\n class=\"gds-dropdown__options__label option\"\n role=\"option\"\n #liElem\n [attr.data-thook]=\"thook + '-option-' + option.key\"\n [attr.aria-disabled]=\"option.disabled\"\n [attr.aria-selected]=\"\n option.key === selectedValue?.key && !!selectedValue?.key\n \"\n [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n [nggvTooltip]=\"isOverflow(liElem) ? t(option.label) : undefined\"\n (click)=\"updateState(option, $event)\"\n >\n <ng-template\n *ngTemplateOutlet=\"\n basicOptionContentTpl;\n context: { $implicit: option }\n \"\n >\n </ng-template>\n </li>\n <!-- Checking overflow on custom templates do not work skip adding nggvToolTip if custom template is provided -->\n <li\n #optionRefs\n *ngIf=\"!!optionContentTpl\"\n tabindex=\"-1\"\n [id]=\"id + '-option-' + option.key\"\n class=\"gds-dropdown__options__label option\"\n role=\"option\"\n #liElem\n [attr.data-thook]=\"thook + '-option-' + option.key\"\n [attr.aria-disabled]=\"option.disabled\"\n [attr.aria-selected]=\"\n option.key === selectedValue?.key && !!selectedValue?.key\n \"\n [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n (click)=\"updateState(option, $event)\"\n >\n <ng-template\n *ngTemplateOutlet=\"optionContentTpl; context: { $implicit: option }\"\n >\n </ng-template>\n </li>\n </ng-template>\n\n <ng-template #basicOptionContentTpl let-option>\n <nggv-typeahead-highlight\n *ngIf=\"!!textToHighlight\"\n [textToHighlight]=\"textToHighlight\"\n [textContent]=\"t(option.label)\"\n >\n </nggv-typeahead-highlight>\n <ng-container *ngIf=\"!textToHighlight\">\n {{ t(option.label) }}\n </ng-container>\n </ng-template>\n</ng-container>\n", styles: [":host{position:absolute;bottom:0;transform:translateY(calc(100% + .5rem));--z-index: var(--sg-z-index-dropdown)}:host .hidden{visibility:hidden;display:none}:host ul[role=menu] [role=menuitem]{padding:.75rem;cursor:pointer}:host ul[role=menu] [role=menuitem]:hover,:host ul[role=menu] [role=menuitem]:focus-visible{background-color:var(--gds-ref-pallet-base200)}:host ul[role=menu] [role=menuitem]:active{background-color:var(--gds-ref-pallet-base300)}:host ul[role=menu] [role=menuitem]:focus{outline-color:#000;outline-offset:-.25rem}:host ul[role=listbox]{--z-index: var(--sg-z-index-popover);background-color:var(--sg-popover-background);flex-direction:column;justify-content:flex-end;inset:auto;z-index:var(--z-index);box-shadow:var(--sg-popover-box-shadow);color:var(--text-primary-color);padding:0;border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--text-primary-color);--sg-border-color: var(--text-primary-color);border-radius:var(--sg-border-radius)}:host ul[role=listbox] [role=option]{padding:.75rem 1rem;line-height:1.25;cursor:pointer}:host ul[role=listbox] [role=option]:hover,:host ul[role=listbox] [role=option]:focus-visible{background-color:var(--grey-400)}:host ul[role=listbox] [role=option]:active{background-color:var(--grey-400)}:host ul[role=listbox] [role=option]:focus{outline-color:#000;outline-offset:-.25rem}:host ul[role=listbox] [role=option].active.sg-highlighted,:host ul[role=listbox] [role=option][aria-selected=true]{background:var(--grey-1000);color:#fff}:host .sg-fieldset-container{overflow-y:auto}:host .sg-fieldset-container fieldset[role=listbox][aria-multiselectable=true] [role=option]{display:flex;width:100%}:host .sg-fieldset-container fieldset[role=listbox][aria-multiselectable=true] [role=option].active.sg-highlighted input[type=checkbox]~i{border-color:#007ac7!important;box-shadow:0 0 .25em .0625em #41b0ee;outline-color:transparent;outline-style:solid}:host .gds-dropdown__options{padding-left:0;margin-bottom:0;margin-top:0;display:flex;flex-direction:column;list-style:none;display:none}:host .gds-dropdown__options>li{padding-bottom:.5rem;padding-top:.5rem;border:0;display:block;position:relative}:host .gds-dropdown__options>li:before{font-weight:500;display:inline-block;left:0;position:absolute;text-align:center}:host .gds-dropdown__options-expanded{display:block}:host .gds-dropdown__options__label:hover,:host .gds-dropdown__options__label:focus-visible{background-color:var(--grey-400)}:host .gds-dropdown__options__label:active{background-color:var(--grey-500)}:host .gds-dropdown__options__label:focus-visible{outline-color:#000;outline-offset:-.25rem}:host .gds-dropdown__options__label[aria-hidden=true]{display:none}:host .gds-dropdown__options__label[highlighted]{color:#fff}\n"] }]
215
215
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
216
216
  type: Optional
217
217
  }, {
@@ -253,4 +253,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
253
253
  type: HostListener,
254
254
  args: ['document:keyup', ['$event']]
255
255
  }] } });
256
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-list.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular/src/v-angular/dropdown/dropdown-list/dropdown-list.component.ts","../../../../../../../../libs/angular/src/v-angular/dropdown/dropdown-list/dropdown-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChildren,\n} from '@angular/core'\n\nimport { Subject, Subscription } from 'rxjs'\nimport scrollIntoView from 'scroll-into-view-if-needed'\n\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@ngneat/transloco'\n\nimport {\n  DropdownUtils,\n  Option,\n  OptionBase,\n} from '@sebgroup/green-angular/src/v-angular/core'\n\n@Component({\n  selector: 'nggv-dropdown-list',\n  templateUrl: './dropdown-list.component.html',\n  styleUrls: ['./dropdown-list.component.scss'],\n})\nexport class NgvDropdownListComponent implements OnInit, OnChanges {\n  @Input() set expanded(state: boolean) {\n    this.setExpanded(state)\n  }\n  get expanded(): boolean {\n    return this._expanded\n  }\n  @Input() state: any\n\n  /** The additional amount to show when option is scrolled into view. */\n  @Input() scrollOffset = 24\n\n  @Input() optionContentTpl: TemplateRef<OptionBase<any>> | undefined\n\n  /** @internal List of references to the option elements. */\n  @ViewChildren('optionRefs') optionRefs:\n    | QueryList<ElementRef<HTMLLIElement>>\n    | undefined\n\n  /** Id of the host element and is accessible by the children, automatically generated if not provided. */\n  @HostBinding('attr.id') @Input() id = (window as any).ngv?.nextId()\n\n  /** Special property used for selecting DOM elements during automated UI testing. */\n  @HostBinding('attr.data-thook') @Input() thook = 'dropdown'\n\n  @Input() options!: any[]\n\n  @Input() textToHighlight?: string\n\n  @Output() selectedValueChanged = new EventEmitter<any>()\n\n  @Output() closed = new EventEmitter<void>()\n\n  /** The current active option based on numeric index. */\n  public activeIndex = -1\n\n  scope: string | undefined\n\n  private dropdownUtils: DropdownUtils<string | null, string, any> =\n    new DropdownUtils<string | null, string, any>()\n  private _expanded = false\n  private closed$ = new Subject<boolean>()\n  public selectedValue?: Option<string, any>\n\n  /** Subscribe if dropdown expanded to listen to click outside to close dropdown. */\n  protected onClickSubscription: Subscription | undefined\n\n  constructor(\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n  ) {\n    if (this.translocoScope) this.scope = this.translocoScope.toString()\n  }\n\n  ngOnInit(): void {\n    if (this.state)\n      this.activeIndex = this.options.findIndex(\n        (option) => option.key === this.state.key,\n      )\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!!changes.state && !changes.state.firstChange)\n      this.selectedValue = changes.state.currentValue\n    if (!!changes.options?.currentValue?.length && this.expanded)\n      this.refreshSelectedOption()\n  }\n\n  /**\n   * Returns true if argument is an {@link OptionGroup}.\n   * @param option the object to check.\n   */\n  isGroup(option: any): boolean {\n    return 'options' in option\n  }\n\n  /** @internal */\n  updateState(option: any, event: Event) {\n    if (option.disabled) return\n\n    this.selectedValue = option\n    this.state = option\n    this.selectedValueChanged.emit(option)\n    this.setExpanded(false)\n    event.stopPropagation()\n  }\n\n  /**\n   * @internal\n   */\n  setExpanded(expanded = true) {\n    // update expanded state\n    this._expanded = expanded\n\n    if (expanded) this.refreshSelectedOption()\n    else {\n      this.closed$.next(true)\n      this.onClickSubscription?.unsubscribe()\n    }\n  }\n\n  /**\n   * @internal\n   */\n  refreshSelectedOption() {\n    const options = this.dropdownUtils.flattenOptions(\n      this.options,\n      !this.optionContentTpl,\n    )\n    this.activeIndex = this.getActiveIndex()\n    this.state = options[this.activeIndex]\n    this.scrollToResult(this.state)\n  }\n\n  /**\n   * @internal\n   * @returns The active index (number) if option is found, -1 otherwise.\n   * - If a selectedValue exists that's not nullish and that options is found, return that index\n   * - Else, return first non nullish index\n   * - If none of the above criterias are met, -1 are returned\n   */\n  getActiveIndex(): number {\n    if (!!this.selectedValue && this.selectedValue?.key != null) {\n      const selectedIndex = this.dropdownUtils\n        .flattenOptions(this.options, !this.optionContentTpl)\n        .findIndex(\n          (option) =>\n            option.key != null && option.key === this.selectedValue?.key,\n        )\n      if (selectedIndex > -1) return selectedIndex\n    }\n    return this.dropdownUtils\n      .flattenOptions(this.options, !this.optionContentTpl)\n      .findIndex((option) => option.key != null)\n  }\n\n  /**\n   * @internal\n   * evaluates wether the HTML element overflows\n   * @param elem The HTMLElement to evaluate\n   * */\n  isOverflow(elem: HTMLElement) {\n    return elem.offsetWidth < elem.scrollWidth\n  }\n\n  /**\n   * Typecast anything to an {@link OptionGroup}.\n   * @param group the object to typecast.\n   */\n  castGroup(group: any): any {\n    return group\n  }\n\n  /**\n   * @internal\n   * Disables default events.\n   * @param event fired containing which key was pressed.\n   */\n  @HostListener('document:keydown', ['$event'])\n  onKeyDown(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'Enter': //  Disable form submission\n      case 'ArrowUp': // Disable scrolling up\n      case 'ArrowDown': // Disable scrolling down\n        event.preventDefault()\n        event.stopPropagation()\n        return false\n    }\n    return true\n  }\n\n  /**\n   * @internal\n   * Enter toggles the dropdown, home, end, and, arrows change the index.\n   * @param event fired containing which key was released.\n   */\n  @HostListener('document:keyup', ['$event'])\n  onKeyUp(event: KeyboardEvent) {\n    if (!this.expanded) return\n    const options = this.dropdownUtils.flattenOptions(\n      this.options,\n      !this.optionContentTpl,\n    )\n    let option\n\n    switch (event.key) {\n      case 'Escape':\n        this.setExpanded(false)\n        this.closed.emit()\n        break\n      case 'Enter': // Select the currently chosen value\n        option = options[this.activeIndex]\n        this.updateState(option, event)\n        break\n\n      case 'Home': // Move to the first option\n        this.activeIndex = 0\n\n        option = options[this.activeIndex]\n        this.state = option\n        this.scrollToResult(option)\n        break\n\n      case 'ArrowUp': // Move up one step to the previous option\n        if (this.activeIndex > 0) this.activeIndex--\n        else if (this.activeIndex === 0) this.activeIndex = options.length - 1\n\n        option = options[this.activeIndex]\n        this.state = option\n        this.scrollToResult(option)\n        break\n\n      case 'ArrowDown': // Move down one step to the next option\n        if (options.length > this.activeIndex + 1) this.activeIndex++\n        else if (this.activeIndex === options.length - 1) this.activeIndex = 0\n\n        option = options[this.activeIndex]\n        this.state = option\n        this.scrollToResult(option)\n        break\n\n      case 'End': // Move to the last options\n        this.activeIndex = options.length - 1\n\n        option = options[this.activeIndex]\n        this.state = option\n        this.scrollToResult(option)\n        break\n    }\n  }\n\n  /**\n   * Scrolls focused result into view with a specified offset.\n   * @param key the result index which to scroll to.\n   */\n  scrollToResult(option: any) {\n    if (!this.optionRefs || !option) return\n    const optionRef = this.optionRefs.find(\n      (li) => li.nativeElement.id === this.id + '-option-' + option.key,\n    )\n    const offset = this.scrollOffset\n    if (optionRef) {\n      let delta = window.scrollY || document.documentElement.scrollTop\n\n      // The list seems not to be visible at the time of scrolling, but this setTimeout \"hack\" makes it work...\n      setTimeout(() => {\n        scrollIntoView(optionRef.nativeElement, {\n          scrollMode: 'if-needed',\n          block: 'nearest',\n        })\n\n        delta -= window.scrollY || document.documentElement.scrollTop\n        if (delta) window.scrollBy(0, delta > 0 ? -offset : offset)\n      }, 0)\n    }\n  }\n}\n","<ng-container *transloco=\"let t; read: scope\">\n  <ul\n    class=\"gds-dropdown__options card options gds-reset\"\n    [class.gds-dropdown__options-expanded]=\"expanded\"\n    role=\"listbox\"\n    tabindex=\"-1\"\n    [attr.data-thook]=\"thook + '-options'\"\n    [attr.aria-labelledby]=\"id + '-label'\"\n    [attr.aria-activedescendant]=\"\n      state ? id + '-option-' + state?.key : undefined\n    \"\n  >\n    <ng-container *ngFor=\"let item of options\">\n      <!-- OPTION -->\n      <ng-container *ngIf=\"!isGroup(item)\">\n        <ng-template\n          *ngTemplateOutlet=\"listItemTemplate; context: { $implicit: item }\"\n        ></ng-template>\n      </ng-container>\n\n      <!-- OPTION GROUP -->\n      <li\n        class=\"gds-dropdown__options__label group\"\n        [attr.data-thook]=\"thook + '-option-group'\"\n        *ngIf=\"isGroup(item)\"\n      >\n        <div class=\"sdv-list__label\">{{ t(item.label) }}</div>\n        <ul [attr.aria-disabled]=\"item.disabled\">\n          <ng-container *ngFor=\"let option of castGroup(item).options\">\n            <ng-template\n              *ngTemplateOutlet=\"\n                listItemTemplate;\n                context: { $implicit: option }\n              \"\n            ></ng-template>\n          </ng-container>\n        </ul>\n      </li>\n    </ng-container>\n  </ul>\n\n  <!-- TEMPLATE -->\n  <ng-template #listItemTemplate let-option>\n    <li\n      #optionRefs\n      *ngIf=\"!optionContentTpl\"\n      tabindex=\"-1\"\n      [id]=\"id + '-option-' + option.key\"\n      class=\"gds-dropdown__options__label option\"\n      role=\"option\"\n      #liElem\n      [attr.data-thook]=\"thook + '-option-' + option.key\"\n      [attr.aria-disabled]=\"option.disabled\"\n      [attr.aria-selected]=\"\n        option.key === selectedValue?.key && !!selectedValue?.key\n      \"\n      [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n      [ngvTooltip]=\"isOverflow(liElem) ? t(option.label) : undefined\"\n      (click)=\"updateState(option, $event)\"\n    >\n      <ng-template\n        *ngTemplateOutlet=\"\n          basicOptionContentTpl;\n          context: { $implicit: option }\n        \"\n      >\n      </ng-template>\n    </li>\n    <!-- Checking overflow on custom templates do not work skip adding ngvToolTip if custom template is provided -->\n    <li\n      #optionRefs\n      *ngIf=\"!!optionContentTpl\"\n      tabindex=\"-1\"\n      [id]=\"id + '-option-' + option.key\"\n      class=\"gds-dropdown__options__label option\"\n      role=\"option\"\n      #liElem\n      [attr.data-thook]=\"thook + '-option-' + option.key\"\n      [attr.aria-disabled]=\"option.disabled\"\n      [attr.aria-selected]=\"\n        option.key === selectedValue?.key && !!selectedValue?.key\n      \"\n      [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n      (click)=\"updateState(option, $event)\"\n    >\n      <ng-template\n        *ngTemplateOutlet=\"optionContentTpl; context: { $implicit: option }\"\n      >\n      </ng-template>\n    </li>\n  </ng-template>\n\n  <ng-template #basicOptionContentTpl let-option>\n    <nggv-typeahead-highlight\n      *ngIf=\"!!textToHighlight\"\n      [textToHighlight]=\"textToHighlight\"\n      [textContent]=\"t(option.label)\"\n    >\n    </nggv-typeahead-highlight>\n    <ng-container *ngIf=\"!textToHighlight\">\n      {{ t(option.label) }}\n    </ng-container>\n  </ng-template>\n</ng-container>\n"]}
256
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-list.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular/src/v-angular/dropdown/dropdown-list/dropdown-list.component.ts","../../../../../../../../libs/angular/src/v-angular/dropdown/dropdown-list/dropdown-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChildren,\n} from '@angular/core'\n\nimport { Subject, Subscription } from 'rxjs'\nimport scrollIntoView from 'scroll-into-view-if-needed'\n\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@ngneat/transloco'\n\nimport {\n  DropdownUtils,\n  Option,\n  OptionBase,\n} from '@sebgroup/green-angular/src/v-angular/core'\n\n@Component({\n  selector: 'nggv-dropdown-list',\n  templateUrl: './dropdown-list.component.html',\n  styleUrls: ['./dropdown-list.component.scss'],\n})\nexport class NgvDropdownListComponent implements OnInit, OnChanges {\n  @Input() set expanded(state: boolean) {\n    this.setExpanded(state)\n  }\n  get expanded(): boolean {\n    return this._expanded\n  }\n  @Input() state: any\n\n  /** The additional amount to show when option is scrolled into view. */\n  @Input() scrollOffset = 24\n\n  @Input() optionContentTpl: TemplateRef<OptionBase<any>> | undefined\n\n  /** @internal List of references to the option elements. */\n  @ViewChildren('optionRefs') optionRefs:\n    | QueryList<ElementRef<HTMLLIElement>>\n    | undefined\n\n  /** Id of the host element and is accessible by the children, automatically generated if not provided. */\n  @HostBinding('attr.id') @Input() id = (window as any).nggv?.nextId()\n\n  /** Special property used for selecting DOM elements during automated UI testing. */\n  @HostBinding('attr.data-thook') @Input() thook = 'dropdown'\n\n  @Input() options!: any[]\n\n  @Input() textToHighlight?: string\n\n  @Output() selectedValueChanged = new EventEmitter<any>()\n\n  @Output() closed = new EventEmitter<void>()\n\n  /** The current active option based on numeric index. */\n  public activeIndex = -1\n\n  scope: string | undefined\n\n  private dropdownUtils: DropdownUtils<string | null, string, any> =\n    new DropdownUtils<string | null, string, any>()\n  private _expanded = false\n  private closed$ = new Subject<boolean>()\n  public selectedValue?: Option<string, any>\n\n  /** Subscribe if dropdown expanded to listen to click outside to close dropdown. */\n  protected onClickSubscription: Subscription | undefined\n\n  constructor(\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n  ) {\n    if (this.translocoScope) this.scope = this.translocoScope.toString()\n  }\n\n  ngOnInit(): void {\n    if (this.state)\n      this.activeIndex = this.options.findIndex(\n        (option) => option.key === this.state.key,\n      )\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (!!changes.state && !changes.state.firstChange)\n      this.selectedValue = changes.state.currentValue\n    if (!!changes.options?.currentValue?.length && this.expanded)\n      this.refreshSelectedOption()\n  }\n\n  /**\n   * Returns true if argument is an {@link OptionGroup}.\n   * @param option the object to check.\n   */\n  isGroup(option: any): boolean {\n    return 'options' in option\n  }\n\n  /** @internal */\n  updateState(option: any, event: Event) {\n    if (option.disabled) return\n\n    this.selectedValue = option\n    this.state = option\n    this.selectedValueChanged.emit(option)\n    this.setExpanded(false)\n    event.stopPropagation()\n  }\n\n  /**\n   * @internal\n   */\n  setExpanded(expanded = true) {\n    // update expanded state\n    this._expanded = expanded\n\n    if (expanded) this.refreshSelectedOption()\n    else {\n      this.closed$.next(true)\n      this.onClickSubscription?.unsubscribe()\n    }\n  }\n\n  /**\n   * @internal\n   */\n  refreshSelectedOption() {\n    const options = this.dropdownUtils.flattenOptions(\n      this.options,\n      !this.optionContentTpl,\n    )\n    this.activeIndex = this.getActiveIndex()\n    this.state = options[this.activeIndex]\n    this.scrollToResult(this.state)\n  }\n\n  /**\n   * @internal\n   * @returns The active index (number) if option is found, -1 otherwise.\n   * - If a selectedValue exists that's not nullish and that options is found, return that index\n   * - Else, return first non nullish index\n   * - If none of the above criterias are met, -1 are returned\n   */\n  getActiveIndex(): number {\n    if (!!this.selectedValue && this.selectedValue?.key != null) {\n      const selectedIndex = this.dropdownUtils\n        .flattenOptions(this.options, !this.optionContentTpl)\n        .findIndex(\n          (option) =>\n            option.key != null && option.key === this.selectedValue?.key,\n        )\n      if (selectedIndex > -1) return selectedIndex\n    }\n    return this.dropdownUtils\n      .flattenOptions(this.options, !this.optionContentTpl)\n      .findIndex((option) => option.key != null)\n  }\n\n  /**\n   * @internal\n   * evaluates wether the HTML element overflows\n   * @param elem The HTMLElement to evaluate\n   * */\n  isOverflow(elem: HTMLElement) {\n    return elem.offsetWidth < elem.scrollWidth\n  }\n\n  /**\n   * Typecast anything to an {@link OptionGroup}.\n   * @param group the object to typecast.\n   */\n  castGroup(group: any): any {\n    return group\n  }\n\n  /**\n   * @internal\n   * Disables default events.\n   * @param event fired containing which key was pressed.\n   */\n  @HostListener('document:keydown', ['$event'])\n  onKeyDown(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'Enter': //  Disable form submission\n      case 'ArrowUp': // Disable scrolling up\n      case 'ArrowDown': // Disable scrolling down\n        event.preventDefault()\n        event.stopPropagation()\n        return false\n    }\n    return true\n  }\n\n  /**\n   * @internal\n   * Enter toggles the dropdown, home, end, and, arrows change the index.\n   * @param event fired containing which key was released.\n   */\n  @HostListener('document:keyup', ['$event'])\n  onKeyUp(event: KeyboardEvent) {\n    if (!this.expanded) return\n    const options = this.dropdownUtils.flattenOptions(\n      this.options,\n      !this.optionContentTpl,\n    )\n    let option\n\n    switch (event.key) {\n      case 'Escape':\n        this.setExpanded(false)\n        this.closed.emit()\n        break\n      case 'Enter': // Select the currently chosen value\n        option = options[this.activeIndex]\n        this.updateState(option, event)\n        break\n\n      case 'Home': // Move to the first option\n        this.activeIndex = 0\n\n        option = options[this.activeIndex]\n        this.state = option\n        this.scrollToResult(option)\n        break\n\n      case 'ArrowUp': // Move up one step to the previous option\n        if (this.activeIndex > 0) this.activeIndex--\n        else if (this.activeIndex === 0) this.activeIndex = options.length - 1\n\n        option = options[this.activeIndex]\n        this.state = option\n        this.scrollToResult(option)\n        break\n\n      case 'ArrowDown': // Move down one step to the next option\n        if (options.length > this.activeIndex + 1) this.activeIndex++\n        else if (this.activeIndex === options.length - 1) this.activeIndex = 0\n\n        option = options[this.activeIndex]\n        this.state = option\n        this.scrollToResult(option)\n        break\n\n      case 'End': // Move to the last options\n        this.activeIndex = options.length - 1\n\n        option = options[this.activeIndex]\n        this.state = option\n        this.scrollToResult(option)\n        break\n    }\n  }\n\n  /**\n   * Scrolls focused result into view with a specified offset.\n   * @param key the result index which to scroll to.\n   */\n  scrollToResult(option: any) {\n    if (!this.optionRefs || !option) return\n    const optionRef = this.optionRefs.find(\n      (li) => li.nativeElement.id === this.id + '-option-' + option.key,\n    )\n    const offset = this.scrollOffset\n    if (optionRef) {\n      let delta = window.scrollY || document.documentElement.scrollTop\n\n      // The list seems not to be visible at the time of scrolling, but this setTimeout \"hack\" makes it work...\n      setTimeout(() => {\n        scrollIntoView(optionRef.nativeElement, {\n          scrollMode: 'if-needed',\n          block: 'nearest',\n        })\n\n        delta -= window.scrollY || document.documentElement.scrollTop\n        if (delta) window.scrollBy(0, delta > 0 ? -offset : offset)\n      }, 0)\n    }\n  }\n}\n","<ng-container *transloco=\"let t; read: scope\">\n  <ul\n    class=\"gds-dropdown__options card options gds-reset\"\n    [class.gds-dropdown__options-expanded]=\"expanded\"\n    role=\"listbox\"\n    tabindex=\"-1\"\n    [attr.data-thook]=\"thook + '-options'\"\n    [attr.aria-labelledby]=\"id + '-label'\"\n    [attr.aria-activedescendant]=\"\n      state ? id + '-option-' + state?.key : undefined\n    \"\n  >\n    <ng-container *ngFor=\"let item of options\">\n      <!-- OPTION -->\n      <ng-container *ngIf=\"!isGroup(item)\">\n        <ng-template\n          *ngTemplateOutlet=\"listItemTemplate; context: { $implicit: item }\"\n        ></ng-template>\n      </ng-container>\n\n      <!-- OPTION GROUP -->\n      <li\n        class=\"gds-dropdown__options__label group\"\n        [attr.data-thook]=\"thook + '-option-group'\"\n        *ngIf=\"isGroup(item)\"\n      >\n        <div class=\"sdv-list__label\">{{ t(item.label) }}</div>\n        <ul [attr.aria-disabled]=\"item.disabled\">\n          <ng-container *ngFor=\"let option of castGroup(item).options\">\n            <ng-template\n              *ngTemplateOutlet=\"\n                listItemTemplate;\n                context: { $implicit: option }\n              \"\n            ></ng-template>\n          </ng-container>\n        </ul>\n      </li>\n    </ng-container>\n  </ul>\n\n  <!-- TEMPLATE -->\n  <ng-template #listItemTemplate let-option>\n    <li\n      #optionRefs\n      *ngIf=\"!optionContentTpl\"\n      tabindex=\"-1\"\n      [id]=\"id + '-option-' + option.key\"\n      class=\"gds-dropdown__options__label option\"\n      role=\"option\"\n      #liElem\n      [attr.data-thook]=\"thook + '-option-' + option.key\"\n      [attr.aria-disabled]=\"option.disabled\"\n      [attr.aria-selected]=\"\n        option.key === selectedValue?.key && !!selectedValue?.key\n      \"\n      [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n      [nggvTooltip]=\"isOverflow(liElem) ? t(option.label) : undefined\"\n      (click)=\"updateState(option, $event)\"\n    >\n      <ng-template\n        *ngTemplateOutlet=\"\n          basicOptionContentTpl;\n          context: { $implicit: option }\n        \"\n      >\n      </ng-template>\n    </li>\n    <!-- Checking overflow on custom templates do not work skip adding nggvToolTip if custom template is provided -->\n    <li\n      #optionRefs\n      *ngIf=\"!!optionContentTpl\"\n      tabindex=\"-1\"\n      [id]=\"id + '-option-' + option.key\"\n      class=\"gds-dropdown__options__label option\"\n      role=\"option\"\n      #liElem\n      [attr.data-thook]=\"thook + '-option-' + option.key\"\n      [attr.aria-disabled]=\"option.disabled\"\n      [attr.aria-selected]=\"\n        option.key === selectedValue?.key && !!selectedValue?.key\n      \"\n      [attr.aria-focus]=\"option.key === state?.key && !option.disabled\"\n      (click)=\"updateState(option, $event)\"\n    >\n      <ng-template\n        *ngTemplateOutlet=\"optionContentTpl; context: { $implicit: option }\"\n      >\n      </ng-template>\n    </li>\n  </ng-template>\n\n  <ng-template #basicOptionContentTpl let-option>\n    <nggv-typeahead-highlight\n      *ngIf=\"!!textToHighlight\"\n      [textToHighlight]=\"textToHighlight\"\n      [textContent]=\"t(option.label)\"\n    >\n    </nggv-typeahead-highlight>\n    <ng-container *ngIf=\"!textToHighlight\">\n      {{ t(option.label) }}\n    </ng-container>\n  </ng-template>\n</ng-container>\n"]}