@sebgroup/green-angular 4.6.1 → 4.6.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (133) hide show
  1. package/esm2022/src/v-angular/dropdown/typeahead/index.mjs +4 -1
  2. package/esm2022/src/v-angular/dropdown/typeahead/typeahead.directive.mjs +177 -0
  3. package/esm2022/v-angular/base-control-value-accessor/base-control-value-accessor.component.mjs +287 -0
  4. package/esm2022/v-angular/base-control-value-accessor/base-control-value-accessor.module.mjs +17 -0
  5. package/esm2022/v-angular/base-control-value-accessor/index.mjs +3 -0
  6. package/esm2022/v-angular/breadcrumbs/breadcrumbs.component.mjs +25 -0
  7. package/esm2022/v-angular/breadcrumbs/breadcrumbs.module.mjs +20 -0
  8. package/esm2022/v-angular/breadcrumbs/index.mjs +3 -0
  9. package/esm2022/v-angular/button/button.component.mjs +108 -0
  10. package/esm2022/v-angular/button/button.module.mjs +20 -0
  11. package/esm2022/v-angular/button/index.mjs +3 -0
  12. package/esm2022/v-angular/card/card.component.mjs +11 -0
  13. package/esm2022/v-angular/card/card.module.mjs +18 -0
  14. package/esm2022/v-angular/card/index.mjs +3 -0
  15. package/esm2022/v-angular/checkbox/checkbox.component.mjs +72 -0
  16. package/esm2022/v-angular/checkbox/checkbox.module.mjs +19 -0
  17. package/esm2022/v-angular/checkbox/index.mjs +3 -0
  18. package/esm2022/v-angular/dropdown/dropdown-list/dropdown-list.component.mjs +256 -0
  19. package/esm2022/v-angular/dropdown/dropdown-list/index.mjs +2 -0
  20. package/esm2022/v-angular/dropdown/dropdown.component.mjs +239 -0
  21. package/esm2022/v-angular/dropdown/dropdown.module.mjs +22 -0
  22. package/esm2022/v-angular/dropdown/index.mjs +6 -0
  23. package/esm2022/v-angular/dropdown/typeahead/index.mjs +6 -0
  24. package/esm2022/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.mjs +98 -0
  25. package/esm2022/v-angular/dropdown/typeahead/typeahead-highlight/typeahead-highlight.component.mjs +85 -0
  26. package/esm2022/v-angular/dropdown/typeahead/typeahead-input/typeahead-input.component.mjs +132 -0
  27. package/esm2022/v-angular/dropdown/typeahead/typeahead.directive.mjs +177 -0
  28. package/esm2022/v-angular/dropdown/typeahead/typeahead.module.mjs +33 -0
  29. package/esm2022/v-angular/i18n/i18n.json +12 -0
  30. package/esm2022/v-angular/i18n/i18n.module.mjs +83 -0
  31. package/esm2022/v-angular/i18n/i18n.test.module.mjs +89 -0
  32. package/esm2022/v-angular/i18n/index.mjs +3 -0
  33. package/esm2022/v-angular/index.mjs +17 -0
  34. package/esm2022/v-angular/info-circle/index.mjs +3 -0
  35. package/esm2022/v-angular/info-circle/info-circle.component.mjs +28 -0
  36. package/esm2022/v-angular/info-circle/info-circle.module.mjs +21 -0
  37. package/esm2022/v-angular/input/index.mjs +3 -0
  38. package/esm2022/v-angular/input/input.component.mjs +221 -0
  39. package/esm2022/v-angular/input/input.module.mjs +32 -0
  40. package/esm2022/v-angular/input-mask/config.mjs +9 -0
  41. package/esm2022/v-angular/input-mask/constants.mjs +2 -0
  42. package/esm2022/v-angular/input-mask/index.mjs +6 -0
  43. package/esm2022/v-angular/input-mask/input-mask-format.pipe.mjs +20 -0
  44. package/esm2022/v-angular/input-mask/input-mask.directive.mjs +165 -0
  45. package/esm2022/v-angular/input-mask/input-mask.module.mjs +35 -0
  46. package/esm2022/v-angular/input-mask/input-mask.types.mjs +2 -0
  47. package/esm2022/v-angular/modal/dialog/dialog.component.mjs +190 -0
  48. package/esm2022/v-angular/modal/fold-out/fold-out.component.mjs +56 -0
  49. package/esm2022/v-angular/modal/fold-out/fold-out.directive.mjs +19 -0
  50. package/esm2022/v-angular/modal/index.mjs +6 -0
  51. package/esm2022/v-angular/modal/modal.globals.mjs +20 -0
  52. package/esm2022/v-angular/modal/modal.module.mjs +40 -0
  53. package/esm2022/v-angular/modal/modal.types.mjs +2 -0
  54. package/esm2022/v-angular/modal/slide-out/slide-out.component.mjs +229 -0
  55. package/esm2022/v-angular/radio/index.mjs +3 -0
  56. package/esm2022/v-angular/radio/radio.component.mjs +130 -0
  57. package/esm2022/v-angular/radio/radio.module.mjs +20 -0
  58. package/esm2022/v-angular/sebgroup-green-angular-v-angular.mjs +5 -0
  59. package/esm2022/v-angular/textarea/index.mjs +3 -0
  60. package/esm2022/v-angular/textarea/textarea.component.mjs +101 -0
  61. package/esm2022/v-angular/textarea/textarea.module.mjs +18 -0
  62. package/esm2022/v-angular/tooltip/index.mjs +3 -0
  63. package/esm2022/v-angular/tooltip/tooltip.directive.mjs +273 -0
  64. package/esm2022/v-angular/tooltip/tooltip.module.mjs +18 -0
  65. package/esm2022/v-angular/v-angular.module.mjs +76 -0
  66. package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs +172 -3
  67. package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs.map +1 -1
  68. package/fesm2022/sebgroup-green-angular-v-angular.mjs +3341 -0
  69. package/fesm2022/sebgroup-green-angular-v-angular.mjs.map +1 -0
  70. package/package.json +8 -2
  71. package/src/v-angular/dropdown/typeahead/index.d.ts +3 -0
  72. package/src/v-angular/dropdown/typeahead/typeahead.directive.d.ts +76 -0
  73. package/v-angular/base-control-value-accessor/base-control-value-accessor.component.d.ts +124 -0
  74. package/v-angular/base-control-value-accessor/base-control-value-accessor.module.d.ts +7 -0
  75. package/v-angular/base-control-value-accessor/index.d.ts +2 -0
  76. package/v-angular/breadcrumbs/breadcrumbs.component.d.ts +18 -0
  77. package/v-angular/breadcrumbs/breadcrumbs.module.d.ts +10 -0
  78. package/v-angular/breadcrumbs/index.d.ts +2 -0
  79. package/v-angular/button/button.component.d.ts +62 -0
  80. package/v-angular/button/button.module.d.ts +10 -0
  81. package/v-angular/button/index.d.ts +2 -0
  82. package/v-angular/card/card.component.d.ts +5 -0
  83. package/v-angular/card/card.module.d.ts +8 -0
  84. package/v-angular/card/index.d.ts +2 -0
  85. package/v-angular/checkbox/checkbox.component.d.ts +27 -0
  86. package/v-angular/checkbox/checkbox.module.d.ts +9 -0
  87. package/v-angular/checkbox/index.d.ts +2 -0
  88. package/v-angular/dropdown/dropdown-list/dropdown-list.component.d.ts +89 -0
  89. package/v-angular/dropdown/dropdown-list/index.d.ts +1 -0
  90. package/v-angular/dropdown/dropdown.component.d.ts +99 -0
  91. package/v-angular/dropdown/dropdown.module.d.ts +12 -0
  92. package/v-angular/dropdown/index.d.ts +5 -0
  93. package/v-angular/dropdown/typeahead/index.d.ts +5 -0
  94. package/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.d.ts +34 -0
  95. package/v-angular/dropdown/typeahead/typeahead-highlight/typeahead-highlight.component.d.ts +34 -0
  96. package/v-angular/dropdown/typeahead/typeahead-input/typeahead-input.component.d.ts +59 -0
  97. package/v-angular/dropdown/typeahead/typeahead.directive.d.ts +76 -0
  98. package/v-angular/dropdown/typeahead/typeahead.module.d.ts +11 -0
  99. package/v-angular/i18n/i18n.module.d.ts +15 -0
  100. package/v-angular/i18n/i18n.test.module.d.ts +27 -0
  101. package/v-angular/i18n/index.d.ts +2 -0
  102. package/v-angular/index.d.ts +16 -0
  103. package/v-angular/info-circle/index.d.ts +2 -0
  104. package/v-angular/info-circle/info-circle.component.d.ts +16 -0
  105. package/v-angular/info-circle/info-circle.module.d.ts +10 -0
  106. package/v-angular/input/index.d.ts +2 -0
  107. package/v-angular/input/input.component.d.ts +90 -0
  108. package/v-angular/input/input.module.d.ts +11 -0
  109. package/v-angular/input-mask/config.d.ts +6 -0
  110. package/v-angular/input-mask/constants.d.ts +2 -0
  111. package/v-angular/input-mask/index.d.ts +5 -0
  112. package/v-angular/input-mask/input-mask-format.pipe.d.ts +8 -0
  113. package/v-angular/input-mask/input-mask.directive.d.ts +39 -0
  114. package/v-angular/input-mask/input-mask.module.d.ts +11 -0
  115. package/v-angular/input-mask/input-mask.types.d.ts +20 -0
  116. package/v-angular/modal/dialog/dialog.component.d.ts +55 -0
  117. package/v-angular/modal/fold-out/fold-out.component.d.ts +24 -0
  118. package/v-angular/modal/fold-out/fold-out.directive.d.ts +6 -0
  119. package/v-angular/modal/index.d.ts +5 -0
  120. package/v-angular/modal/modal.globals.d.ts +13 -0
  121. package/v-angular/modal/modal.module.d.ts +13 -0
  122. package/v-angular/modal/modal.types.d.ts +5 -0
  123. package/v-angular/modal/slide-out/slide-out.component.d.ts +76 -0
  124. package/v-angular/radio/index.d.ts +2 -0
  125. package/v-angular/radio/radio.component.d.ts +48 -0
  126. package/v-angular/radio/radio.module.d.ts +9 -0
  127. package/v-angular/textarea/index.d.ts +2 -0
  128. package/v-angular/textarea/textarea.component.d.ts +44 -0
  129. package/v-angular/textarea/textarea.module.d.ts +8 -0
  130. package/v-angular/tooltip/index.d.ts +2 -0
  131. package/v-angular/tooltip/tooltip.directive.d.ts +106 -0
  132. package/v-angular/tooltip/tooltip.module.d.ts +8 -0
  133. package/v-angular/v-angular.module.d.ts +22 -0
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ViZ3JvdXAtZ3JlZW4tYW5ndWxhci12LWFuZ3VsYXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci9zZWJncm91cC1ncmVlbi1hbmd1bGFyLXYtYW5ndWxhci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -0,0 +1,3 @@
1
+ export * from './textarea.component';
2
+ export * from './textarea.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci90ZXh0YXJlYS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFBO0FBQ3BDLGNBQWMsbUJBQW1CLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RleHRhcmVhLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vdGV4dGFyZWEubW9kdWxlJ1xuIl19
@@ -0,0 +1,101 @@
1
+ import { ChangeDetectorRef, Component, HostBinding, Inject, Input, Optional, Self, } from '@angular/core';
2
+ import { NgControl } from '@angular/forms';
3
+ import { TRANSLOCO_SCOPE } from '@ngneat/transloco';
4
+ import { NgvBaseControlValueAccessorComponent } from '@sebgroup/green-angular/src/v-angular/base-control-value-accessor';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/forms";
7
+ import * as i2 from "@angular/common";
8
+ /** Textarea fields allow users to add and edit longer or multiple line text. */
9
+ export class NgvTextareaComponent extends NgvBaseControlValueAccessorComponent {
10
+ /** Minimum length (number of characters) of value. */
11
+ set minLength(length) {
12
+ this._minlength = length;
13
+ this.cdr.detectChanges();
14
+ }
15
+ get minlength() {
16
+ return this._minlength;
17
+ }
18
+ /**
19
+ * Minimum length (number of characters) of value.
20
+ * @deprecated minlength triggers angular-template-validation. Use @Input() minLength instead.
21
+ */
22
+ set minlength(length) {
23
+ this._minlength = length;
24
+ this.cdr.detectChanges();
25
+ }
26
+ /** Maximum length (number of characters) of value. */
27
+ set maxLength(length) {
28
+ this._maxlength = length;
29
+ this.cdr.detectChanges();
30
+ }
31
+ get maxlength() {
32
+ return this._maxlength;
33
+ }
34
+ /**
35
+ * Maximum length (number of characters) of value.
36
+ * @deprecated maxlength triggers angular-template-validation. Use @Input() maxLength instead.
37
+ */
38
+ set maxlength(length) {
39
+ this._maxlength = length;
40
+ this.cdr.detectChanges();
41
+ }
42
+ /** Returns if maxlength is used */
43
+ get hasMaxLength() {
44
+ return !!this.maxlength && this.maxlength !== Number.MAX_SAFE_INTEGER;
45
+ }
46
+ constructor(ngControl, translocoScope, cdr) {
47
+ super(ngControl, translocoScope, cdr);
48
+ this.ngControl = ngControl;
49
+ this.translocoScope = translocoScope;
50
+ this.cdr = cdr;
51
+ /** Special property used for selecting DOM elements during automated UI testing. */
52
+ this.thook = 'textarea';
53
+ /** If set to true, the value will not be editable. */
54
+ this.readonly = false;
55
+ this._maxlength = Number.MAX_SAFE_INTEGER;
56
+ this._minlength = 0;
57
+ }
58
+ /** @internal */
59
+ onInput(event) {
60
+ event.stopPropagation();
61
+ if (this.disabled)
62
+ return;
63
+ this.state = event.target.value;
64
+ this.onChange(this.state);
65
+ }
66
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTextareaComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: TRANSLOCO_SCOPE, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
67
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvTextareaComponent, selector: "nggv-textarea", inputs: { thook: "thook", placeholder: "placeholder", readonly: "readonly", minLength: "minLength", minlength: "minlength", maxLength: "maxLength", maxlength: "maxlength", rows: "rows" }, host: { properties: { "attr.data-thook": "this.thook" } }, usesInheritance: true, ngImport: i0, template: "<!-- LABEL -->\n<label\n [id]=\"id + '-label'\"\n class=\"sdv-field-label hide-if-empty\"\n [attr.for]=\"id + '-textarea'\"\n *transloco=\"let t; read: scope\"\n>\n <ng-template\n *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n ></ng-template>\n <ng-template #basicLabelContentTpl>\n <!-- to trigger css:empty if no label was added -->\n <ng-container *ngIf=\"label\">\n {{ label }}\n <span\n *ngIf=\"optional === true || (required !== true && optional !== false)\"\n class=\"sdv-field-label--optional\"\n >\n ({{ t('label.optional') }})\n </span>\n </ng-container>\n </ng-template>\n</label>\n\n<!-- DESCRIPTION -->\n<div class=\"sdv-field-label--small description\">{{ description }}</div>\n\n<!-- LOCKED INPUT -->\n<ng-container *ngIf=\"locked\">\n <div\n [id]=\"id + '-textarea'\"\n class=\"nggv-field--locked\"\n [attr.name]=\"name\"\n [attr.value]=\"state\"\n [attr.role]=\"role\"\n >\n <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n <ng-container *ngIf=\"state\">\n {{ state }}\n </ng-container>\n </div>\n</ng-container>\n\n<!-- INPUT FIELD -->\n<ng-container *ngIf=\"!locked\">\n <textarea\n #input\n [id]=\"id + '-textarea'\"\n class=\"sdv-field\"\n [ngClass]=\"{ 'no-resize': !!rows }\"\n [class.nggv-field--error]=\"invalid\"\n [attr.name]=\"name\"\n [attr.required]=\"required\"\n [disabled]=\"disabled\"\n [autofocus]=\"autofocus\"\n [readOnly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [attr.role]=\"role\"\n [attr.rows]=\"rows\"\n [attr.placeholder]=\"placeholder\"\n [attr.aria-label]=\"description\"\n [value]=\"state\"\n (input)=\"onInput($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n ></textarea>\n\n <!-- ERRORS -->\n <div class=\"error-wrapper\" *transloco=\"let t; read: scope\">\n <label\n class=\"sdv-field-notice sdv-field-notice--error\"\n [attr.for]=\"id + '-textarea'\"\n *ngIf=\"invalid && (error || ngControl?.invalid)\"\n >\n <span *ngIf=\"error; else errorsRef\">{{ error }}</span>\n <ng-template #errorsRef>\n <span *ngIf=\"firstError as error\">\n {{ t('error.field' + error?.code, error?.params) }}\n </span>\n </ng-template>\n </label>\n\n <ng-container *ngIf=\"hasMaxLength\">\n <label\n *ngvCharacterCountdown=\"\n maxlength;\n currentLength: (inputRef?.nativeElement?.value ?? '').length;\n charactersLeft as charactersLeft\n \"\n class=\"sdv-field-notice\"\n style=\"text-align: right\"\n >\n {{ charactersLeft }} {{ t('label.maxlength') }}\n </label>\n </ng-container>\n </div>\n\n <!-- CHILDREN -->\n <ng-content></ng-content>\n</ng-container>\n", styles: [":host textarea{padding:.75rem 1rem;border-radius:var(--sg-border-radius);border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--sg-border-color);align-items:center;background-color:var(--sg-form-control-bg);color:var(--text-primary-color);display:flex;justify-content:center;resize:vertical}:host textarea:focus:not(:focus-visible){box-shadow:none;outline:0}:host textarea:focus,:host textarea:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}@media screen and (-ms-high-contrast: active){:host textarea{border:2px solid currentcolor}}:host textarea:hover{background-color:var(--gds-ref-pallet-base100)}:host textarea:disabled,:host textarea.disabled,:host textarea[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 textarea:disabled::placeholder,:host textarea.disabled::placeholder,:host textarea[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host label:not(.sdv-field-notice){margin-bottom:.5rem}:host label:not(.sdv-field-notice):is(label){margin-bottom:0}:host label:not(.sdv-field-notice).form-control{width:-moz-fit-content;width:fit-content}@supports (-moz-appearance: none){:host label:not(.sdv-field-notice).form-control:focus:not(:focus-visible){box-shadow:none;outline:0}:host label:not(.sdv-field-notice).form-control:focus,:host label:not(.sdv-field-notice).form-control:focus-within{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}}:host label:not(.sdv-field-notice):not(.form-control){font-weight:500;width:100%;line-height:1.25rem}:host label:not(.sdv-field-notice)+input,:host label:not(.sdv-field-notice)+textarea,fieldset :host label:not(.sdv-field-notice)+div,:host label:not(.sdv-field-notice)+button,:host label:not(.sdv-field-notice)+.group-stepper,:host label:not(.sdv-field-notice)+.stepper-wrapper,:host label:not(.sdv-field-notice)+.group{margin-top:.5rem}:host label:not(.sdv-field-notice)+.form-info{margin-bottom:.5rem}:host label:is(.sdv-field-label){margin-bottom:.5rem}:host .hide-if-empty:empty{display:none}:host .unset-state{padding-left:.5rem}:host .sdv-field-label--optional{font-weight:400}:host textarea{width:100%;max-width:100%}:host .description{margin-bottom:.5rem}:host .error-wrapper{margin-top:.5rem}:host .no-resize{resize:none}:host .no-resize::-webkit-scrollbar{-webkit-appearance:none}:host .no-resize::-webkit-scrollbar-thumb{border-radius:.5rem}\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"] }] }); }
68
+ }
69
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTextareaComponent, decorators: [{
70
+ type: Component,
71
+ args: [{ selector: 'nggv-textarea', template: "<!-- LABEL -->\n<label\n [id]=\"id + '-label'\"\n class=\"sdv-field-label hide-if-empty\"\n [attr.for]=\"id + '-textarea'\"\n *transloco=\"let t; read: scope\"\n>\n <ng-template\n *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n ></ng-template>\n <ng-template #basicLabelContentTpl>\n <!-- to trigger css:empty if no label was added -->\n <ng-container *ngIf=\"label\">\n {{ label }}\n <span\n *ngIf=\"optional === true || (required !== true && optional !== false)\"\n class=\"sdv-field-label--optional\"\n >\n ({{ t('label.optional') }})\n </span>\n </ng-container>\n </ng-template>\n</label>\n\n<!-- DESCRIPTION -->\n<div class=\"sdv-field-label--small description\">{{ description }}</div>\n\n<!-- LOCKED INPUT -->\n<ng-container *ngIf=\"locked\">\n <div\n [id]=\"id + '-textarea'\"\n class=\"nggv-field--locked\"\n [attr.name]=\"name\"\n [attr.value]=\"state\"\n [attr.role]=\"role\"\n >\n <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n <ng-container *ngIf=\"state\">\n {{ state }}\n </ng-container>\n </div>\n</ng-container>\n\n<!-- INPUT FIELD -->\n<ng-container *ngIf=\"!locked\">\n <textarea\n #input\n [id]=\"id + '-textarea'\"\n class=\"sdv-field\"\n [ngClass]=\"{ 'no-resize': !!rows }\"\n [class.nggv-field--error]=\"invalid\"\n [attr.name]=\"name\"\n [attr.required]=\"required\"\n [disabled]=\"disabled\"\n [autofocus]=\"autofocus\"\n [readOnly]=\"readonly\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [attr.role]=\"role\"\n [attr.rows]=\"rows\"\n [attr.placeholder]=\"placeholder\"\n [attr.aria-label]=\"description\"\n [value]=\"state\"\n (input)=\"onInput($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n ></textarea>\n\n <!-- ERRORS -->\n <div class=\"error-wrapper\" *transloco=\"let t; read: scope\">\n <label\n class=\"sdv-field-notice sdv-field-notice--error\"\n [attr.for]=\"id + '-textarea'\"\n *ngIf=\"invalid && (error || ngControl?.invalid)\"\n >\n <span *ngIf=\"error; else errorsRef\">{{ error }}</span>\n <ng-template #errorsRef>\n <span *ngIf=\"firstError as error\">\n {{ t('error.field' + error?.code, error?.params) }}\n </span>\n </ng-template>\n </label>\n\n <ng-container *ngIf=\"hasMaxLength\">\n <label\n *ngvCharacterCountdown=\"\n maxlength;\n currentLength: (inputRef?.nativeElement?.value ?? '').length;\n charactersLeft as charactersLeft\n \"\n class=\"sdv-field-notice\"\n style=\"text-align: right\"\n >\n {{ charactersLeft }} {{ t('label.maxlength') }}\n </label>\n </ng-container>\n </div>\n\n <!-- CHILDREN -->\n <ng-content></ng-content>\n</ng-container>\n", styles: [":host textarea{padding:.75rem 1rem;border-radius:var(--sg-border-radius);border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--sg-border-color);align-items:center;background-color:var(--sg-form-control-bg);color:var(--text-primary-color);display:flex;justify-content:center;resize:vertical}:host textarea:focus:not(:focus-visible){box-shadow:none;outline:0}:host textarea:focus,:host textarea:focus-visible{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}@media screen and (-ms-high-contrast: active){:host textarea{border:2px solid currentcolor}}:host textarea:hover{background-color:var(--gds-ref-pallet-base100)}:host textarea:disabled,:host textarea.disabled,:host textarea[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 textarea:disabled::placeholder,:host textarea.disabled::placeholder,:host textarea[aria-disabled=true]::placeholder{color:var(--text-disabled-color)}:host label:not(.sdv-field-notice){margin-bottom:.5rem}:host label:not(.sdv-field-notice):is(label){margin-bottom:0}:host label:not(.sdv-field-notice).form-control{width:-moz-fit-content;width:fit-content}@supports (-moz-appearance: none){:host label:not(.sdv-field-notice).form-control:focus:not(:focus-visible){box-shadow:none;outline:0}:host label:not(.sdv-field-notice).form-control:focus,:host label:not(.sdv-field-notice).form-control:focus-within{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}}:host label:not(.sdv-field-notice):not(.form-control){font-weight:500;width:100%;line-height:1.25rem}:host label:not(.sdv-field-notice)+input,:host label:not(.sdv-field-notice)+textarea,fieldset :host label:not(.sdv-field-notice)+div,:host label:not(.sdv-field-notice)+button,:host label:not(.sdv-field-notice)+.group-stepper,:host label:not(.sdv-field-notice)+.stepper-wrapper,:host label:not(.sdv-field-notice)+.group{margin-top:.5rem}:host label:not(.sdv-field-notice)+.form-info{margin-bottom:.5rem}:host label:is(.sdv-field-label){margin-bottom:.5rem}:host .hide-if-empty:empty{display:none}:host .unset-state{padding-left:.5rem}:host .sdv-field-label--optional{font-weight:400}:host textarea{width:100%;max-width:100%}:host .description{margin-bottom:.5rem}:host .error-wrapper{margin-top:.5rem}:host .no-resize{resize:none}:host .no-resize::-webkit-scrollbar{-webkit-appearance:none}:host .no-resize::-webkit-scrollbar-thumb{border-radius:.5rem}\n"] }]
72
+ }], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
73
+ type: Self
74
+ }, {
75
+ type: Optional
76
+ }] }, { type: undefined, decorators: [{
77
+ type: Optional
78
+ }, {
79
+ type: Inject,
80
+ args: [TRANSLOCO_SCOPE]
81
+ }] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { thook: [{
82
+ type: HostBinding,
83
+ args: ['attr.data-thook']
84
+ }, {
85
+ type: Input
86
+ }], placeholder: [{
87
+ type: Input
88
+ }], readonly: [{
89
+ type: Input
90
+ }], minLength: [{
91
+ type: Input
92
+ }], minlength: [{
93
+ type: Input
94
+ }], maxLength: [{
95
+ type: Input
96
+ }], maxlength: [{
97
+ type: Input
98
+ }], rows: [{
99
+ type: Input
100
+ }] } });
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/v-angular/textarea/textarea.component.ts","../../../../../../libs/angular/src/v-angular/textarea/textarea.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,WAAW,EACX,MAAM,EACN,KAAK,EACL,QAAQ,EACR,IAAI,GACL,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAE1C,OAAO,EAAE,eAAe,EAAkB,MAAM,mBAAmB,CAAA;AAEnE,OAAO,EAAE,oCAAoC,EAAE,MAAM,mEAAmE,CAAA;;;;AAExH,gFAAgF;AAMhF,MAAM,OAAO,oBAAqB,SAAQ,oCAAoC;IAO5E,sDAAsD;IACtD,IAAa,SAAS,CAAC,MAAc;QACnC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAA;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAA;IAC1B,CAAC;IACD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAA;IACxB,CAAC;IAED;;;OAGG;IACH,IAAa,SAAS,CAAC,MAAc;QACnC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAA;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAA;IAC1B,CAAC;IACD,sDAAsD;IACtD,IAAa,SAAS,CAAC,MAAc;QACnC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAA;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAA;IAC1B,CAAC;IACD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAA;IACxB,CAAC;IACD;;;OAGG;IACH,IAAa,SAAS,CAAC,MAAc;QACnC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAA;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAA;IAC1B,CAAC;IAED,mCAAmC;IACnC,IAAI,YAAY;QACd,OAAO,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,CAAC,gBAAgB,CAAA;IACvE,CAAC;IASD,YAC6B,SAAoB,EAGrC,cAA8B,EAC9B,GAAsB;QAEhC,KAAK,CAAC,SAAS,EAAE,cAAc,EAAE,GAAG,CAAC,CAAA;QANV,cAAS,GAAT,SAAS,CAAW;QAGrC,mBAAc,GAAd,cAAc,CAAgB;QAC9B,QAAG,GAAH,GAAG,CAAmB;QAzDlC,oFAAoF;QAC3C,UAAK,GAAG,UAAU,CAAA;QAG3D,sDAAsD;QAC7C,aAAQ,GAAG,KAAK,CAAA;QAwCjB,eAAU,GAAG,MAAM,CAAC,gBAAgB,CAAA;QAEpC,eAAU,GAAG,CAAC,CAAA;IAatB,CAAC;IAED,gBAAgB;IAChB,OAAO,CAAC,KAAY;QAClB,KAAK,CAAC,eAAe,EAAE,CAAA;QACvB,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAM;QACzB,IAAI,CAAC,KAAK,GAAI,KAAK,CAAC,MAA8B,CAAC,KAAK,CAAA;QACxD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC3B,CAAC;+GArEU,oBAAoB,uEAwDrB,eAAe;mGAxDd,oBAAoB,mUCrBjC,m0FAqGA;;4FDhFa,oBAAoB;kBALhC,SAAS;+BACE,eAAe;;0BA0DtB,IAAI;;0BAAI,QAAQ;;0BAChB,QAAQ;;0BACR,MAAM;2BAAC,eAAe;4EAtDgB,KAAK;sBAA7C,WAAW;uBAAC,iBAAiB;;sBAAG,KAAK;gBAE7B,WAAW;sBAAnB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEO,SAAS;sBAArB,KAAK;gBAYO,SAAS;sBAArB,KAAK;gBAKO,SAAS;sBAArB,KAAK;gBAWO,SAAS;sBAArB,KAAK;gBAeG,IAAI;sBAAZ,KAAK","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  HostBinding,\n  Inject,\n  Input,\n  Optional,\n  Self,\n} from '@angular/core'\nimport { NgControl } from '@angular/forms'\n\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@ngneat/transloco'\n\nimport { NgvBaseControlValueAccessorComponent } from '@sebgroup/green-angular/src/v-angular/base-control-value-accessor'\n\n/** Textarea fields allow users to add and edit longer or multiple line text. */\n@Component({\n  selector: 'nggv-textarea',\n  templateUrl: './textarea.component.html',\n  styleUrls: ['./textarea.component.scss'],\n})\nexport class NgvTextareaComponent extends NgvBaseControlValueAccessorComponent {\n  /** Special property used for selecting DOM elements during automated UI testing. */\n  @HostBinding('attr.data-thook') @Input() thook = 'textarea'\n  /** Text shown before input has a written value. */\n  @Input() placeholder?: string\n  /** If set to true, the value will not be editable. */\n  @Input() readonly = false\n  /** Minimum length (number of characters) of value. */\n  @Input() set minLength(length: number) {\n    this._minlength = length\n    this.cdr.detectChanges()\n  }\n  get minlength(): number {\n    return this._minlength\n  }\n\n  /**\n   * Minimum length (number of characters) of value.\n   * @deprecated minlength triggers angular-template-validation. Use @Input() minLength instead.\n   */\n  @Input() set minlength(length: number) {\n    this._minlength = length\n    this.cdr.detectChanges()\n  }\n  /** Maximum length (number of characters) of value. */\n  @Input() set maxLength(length: number) {\n    this._maxlength = length\n    this.cdr.detectChanges()\n  }\n  get maxlength(): number {\n    return this._maxlength\n  }\n  /**\n   * Maximum length (number of characters) of value.\n   * @deprecated maxlength triggers angular-template-validation. Use @Input() maxLength instead.\n   */\n  @Input() set maxlength(length: number) {\n    this._maxlength = length\n    this.cdr.detectChanges()\n  }\n\n  /** Returns if maxlength is used */\n  get hasMaxLength(): boolean {\n    return !!this.maxlength && this.maxlength !== Number.MAX_SAFE_INTEGER\n  }\n\n  private _maxlength = Number.MAX_SAFE_INTEGER\n\n  private _minlength = 0\n\n  /** Sets the height of the textarea and disables resize. A scrollbar will appear if necessary. */\n  @Input() rows?: number\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  onInput(event: Event) {\n    event.stopPropagation()\n    if (this.disabled) return\n    this.state = (event.target as HTMLTextAreaElement).value\n    this.onChange(this.state)\n  }\n}\n","<!-- LABEL -->\n<label\n  [id]=\"id + '-label'\"\n  class=\"sdv-field-label hide-if-empty\"\n  [attr.for]=\"id + '-textarea'\"\n  *transloco=\"let t; read: scope\"\n>\n  <ng-template\n    *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n  ></ng-template>\n  <ng-template #basicLabelContentTpl>\n    <!-- to trigger css:empty if no label was added -->\n    <ng-container *ngIf=\"label\">\n      {{ label }}\n      <span\n        *ngIf=\"optional === true || (required !== true && optional !== false)\"\n        class=\"sdv-field-label--optional\"\n      >\n        ({{ t('label.optional') }})\n      </span>\n    </ng-container>\n  </ng-template>\n</label>\n\n<!-- DESCRIPTION -->\n<div class=\"sdv-field-label--small description\">{{ description }}</div>\n\n<!-- LOCKED INPUT -->\n<ng-container *ngIf=\"locked\">\n  <div\n    [id]=\"id + '-textarea'\"\n    class=\"nggv-field--locked\"\n    [attr.name]=\"name\"\n    [attr.value]=\"state\"\n    [attr.role]=\"role\"\n  >\n    <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n    <ng-container *ngIf=\"state\">\n      {{ state }}\n    </ng-container>\n  </div>\n</ng-container>\n\n<!-- INPUT FIELD -->\n<ng-container *ngIf=\"!locked\">\n  <textarea\n    #input\n    [id]=\"id + '-textarea'\"\n    class=\"sdv-field\"\n    [ngClass]=\"{ 'no-resize': !!rows }\"\n    [class.nggv-field--error]=\"invalid\"\n    [attr.name]=\"name\"\n    [attr.required]=\"required\"\n    [disabled]=\"disabled\"\n    [autofocus]=\"autofocus\"\n    [readOnly]=\"readonly\"\n    [attr.maxlength]=\"maxlength\"\n    [attr.minlength]=\"minlength\"\n    [attr.role]=\"role\"\n    [attr.rows]=\"rows\"\n    [attr.placeholder]=\"placeholder\"\n    [attr.aria-label]=\"description\"\n    [value]=\"state\"\n    (input)=\"onInput($event)\"\n    (focus)=\"onFocus($event)\"\n    (blur)=\"onBlur($event)\"\n  ></textarea>\n\n  <!-- ERRORS -->\n  <div class=\"error-wrapper\" *transloco=\"let t; read: scope\">\n    <label\n      class=\"sdv-field-notice sdv-field-notice--error\"\n      [attr.for]=\"id + '-textarea'\"\n      *ngIf=\"invalid && (error || ngControl?.invalid)\"\n    >\n      <span *ngIf=\"error; else errorsRef\">{{ error }}</span>\n      <ng-template #errorsRef>\n        <span *ngIf=\"firstError as error\">\n          {{ t('error.field' + error?.code, error?.params) }}\n        </span>\n      </ng-template>\n    </label>\n\n    <ng-container *ngIf=\"hasMaxLength\">\n      <label\n        *ngvCharacterCountdown=\"\n          maxlength;\n          currentLength: (inputRef?.nativeElement?.value ?? '').length;\n          charactersLeft as charactersLeft\n        \"\n        class=\"sdv-field-notice\"\n        style=\"text-align: right\"\n      >\n        {{ charactersLeft }} {{ t('label.maxlength') }}\n      </label>\n    </ng-container>\n  </div>\n\n  <!-- CHILDREN -->\n  <ng-content></ng-content>\n</ng-container>\n"]}
@@ -0,0 +1,18 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { NgvTextareaComponent } from './textarea.component';
4
+ import * as i0 from "@angular/core";
5
+ export class NgvTextareaModule {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTextareaModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NgvTextareaModule, declarations: [NgvTextareaComponent], imports: [CommonModule], exports: [NgvTextareaComponent] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTextareaModule, imports: [CommonModule] }); }
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTextareaModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ declarations: [NgvTextareaComponent],
14
+ imports: [CommonModule],
15
+ exports: [NgvTextareaComponent],
16
+ }]
17
+ }] });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGFyZWEubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy92LWFuZ3VsYXIvdGV4dGFyZWEvdGV4dGFyZWEubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBRTlDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNCQUFzQixDQUFBOztBQU8zRCxNQUFNLE9BQU8saUJBQWlCOytHQUFqQixpQkFBaUI7Z0hBQWpCLGlCQUFpQixpQkFKYixvQkFBb0IsYUFDekIsWUFBWSxhQUNaLG9CQUFvQjtnSEFFbkIsaUJBQWlCLFlBSGxCLFlBQVk7OzRGQUdYLGlCQUFpQjtrQkFMN0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztpQkFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5cbmltcG9ydCB7IE5ndlRleHRhcmVhQ29tcG9uZW50IH0gZnJvbSAnLi90ZXh0YXJlYS5jb21wb25lbnQnXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW05ndlRleHRhcmVhQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtOZ3ZUZXh0YXJlYUNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIE5ndlRleHRhcmVhTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './tooltip.directive';
2
+ export * from './tooltip.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci90b29sdGlwL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUJBQXFCLENBQUE7QUFDbkMsY0FBYyxrQkFBa0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdG9vbHRpcC5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL3Rvb2x0aXAubW9kdWxlJ1xuIl19
@@ -0,0 +1,273 @@
1
+ import { Directive, ElementRef, EventEmitter, HostListener, Input, Output, Renderer2, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ * A tooltip is a text label that acts as a helper to a specific item.
5
+ * Recommended to use value `top` or `bottom` with `placement` for responsive design.
6
+ * Dynamic resizing and tooltip position are a work in progress.
7
+ * https://designlibrary.sebgroup.com/components/component-tooltip
8
+ */
9
+ export class NgvTooltipDirective {
10
+ /** @internal Check if changes should trigger a re-render */
11
+ static shouldUpdate(change) {
12
+ return (change &&
13
+ !change.firstChange &&
14
+ change.previousValue !== change.currentValue);
15
+ }
16
+ constructor(anchorElementRef, renderer) {
17
+ this.anchorElementRef = anchorElementRef;
18
+ this.renderer = renderer;
19
+ /** Special property used for selecting DOM elements during automated UI testing. */
20
+ this.thook = 'tooltip';
21
+ /** The side of the anchor which the tooltip will be rendered.
22
+ * Recommended `top` and `bottom` for responsive designs as these are more stable.
23
+ */
24
+ this.placement = 'top';
25
+ /** Initial state and subsequent updates on wether the tooltip is visible. */
26
+ this.shown = false;
27
+ /** How far off from the text the tooltip will be rendered. */
28
+ this.offset = 10;
29
+ /** How frequently the tooltip will be re-rendered when the page size changes. */
30
+ this.resizeThrottle = 50;
31
+ /** Numeric max-width for tooltip. */
32
+ this.maxWidth = 343;
33
+ /** Emits a show event triggered changing visibility state of the tooltip. */
34
+ this.ngvShow = new EventEmitter();
35
+ /** Emits a hide event triggered changing visibility state of the tooltip. */
36
+ this.ngvHide = new EventEmitter();
37
+ /** @internal */
38
+ this.timeout = 0;
39
+ this.anchorElement = this.anchorElementRef.nativeElement;
40
+ this.parentElement = document.body;
41
+ }
42
+ ngAfterViewInit() {
43
+ // Set a timeout to allow view to fully render before creating tooltip.
44
+ setTimeout(() => (this.shown ? this.show(true) : this.hide(true)));
45
+ }
46
+ ngOnChanges(changes) {
47
+ if (NgvTooltipDirective.shouldUpdate(changes.ngvTooltip) ||
48
+ NgvTooltipDirective.shouldUpdate(changes.placement) ||
49
+ NgvTooltipDirective.shouldUpdate(changes.thook)) {
50
+ this.shown ? this.show(true) : this.hide(true);
51
+ }
52
+ if (NgvTooltipDirective.shouldUpdate(changes.shown)) {
53
+ this.shown ? this.show() : this.hide();
54
+ }
55
+ if (NgvTooltipDirective.shouldUpdate(changes.offset)) {
56
+ this.updatePosition();
57
+ }
58
+ }
59
+ ngOnDestroy() {
60
+ this.hide(true);
61
+ }
62
+ /** @internal */
63
+ onMouseEnter() {
64
+ this.show();
65
+ }
66
+ /** @internal */
67
+ onMouseLeave() {
68
+ this.hide();
69
+ }
70
+ /** @internal */
71
+ resize() {
72
+ if (this.timeout)
73
+ return;
74
+ this.timeout = window.setTimeout(() => {
75
+ this.timeout = 0;
76
+ this.updatePosition();
77
+ }, this.resizeThrottle);
78
+ }
79
+ /**
80
+ * Sets the visibility state of the tooltip to true and creates a new tooltip if it doesn't exist or `recreate` is set.
81
+ * @param recreate if set to true, destroy any existing tooltip and create a new one.
82
+ */
83
+ show(recreate = false) {
84
+ // Require tooltip text to create
85
+ if (!this.ngvTooltip || this.ngvTooltip.length === 0)
86
+ return;
87
+ if (recreate || !this.tooltipElement) {
88
+ this.hide(true);
89
+ this.create(this.ngvTooltip);
90
+ }
91
+ else {
92
+ this.renderer.appendChild(this.parentElement, this.tooltipElement);
93
+ }
94
+ this.updatePosition();
95
+ this.shown = true;
96
+ this.ngvShow.emit(this.tooltipElement);
97
+ }
98
+ /**
99
+ * Sets the visibility state of the tooltip to false and destroys an existing tooltip if `destroy` is set.
100
+ * @param destroy if set to true, destroy any existing tooltip.
101
+ */
102
+ hide(destroy = false) {
103
+ if (!this.tooltipElement)
104
+ return;
105
+ if (this.parentElement.contains(this.tooltipElement))
106
+ this.renderer.removeChild(this.parentElement, this.tooltipElement);
107
+ if (destroy)
108
+ this.destroy();
109
+ this.shown = false;
110
+ this.ngvHide.emit(this.tooltipElement);
111
+ }
112
+ /**
113
+ * @internal
114
+ * Creates a new tooltip with the set placement and a given text as its body.
115
+ * @param text the string to be displayed in the tooltip body.
116
+ */
117
+ create(text) {
118
+ this.tooltipElement = this.renderer.createElement('div');
119
+ this.renderer.addClass(this.tooltipElement, 'gds-tooltip');
120
+ this.renderer.setAttribute(this.tooltipElement, 'data-thook', this.thook);
121
+ this.renderer.setStyle(this.tooltipElement, 'position', 'absolute');
122
+ this.renderer.setStyle(this.tooltipElement, 'z-index', '1040');
123
+ this.renderer.setStyle(this.tooltipElement, 'border-radius', '.25rem');
124
+ this.renderer.setStyle(this.tooltipElement, 'padding', '.5rem 1rem');
125
+ const relativeMaxWidth = this.pxToRem(this.maxWidth);
126
+ this.renderer.setStyle(this.tooltipElement, 'max-width', relativeMaxWidth);
127
+ this.renderer.appendChild(this.tooltipElement, this.renderer.createText(text));
128
+ // add tooltip to DOM
129
+ this.renderer.appendChild(this.parentElement, this.tooltipElement);
130
+ this.arrowElement = this.renderer.createElement('div');
131
+ this.renderer.addClass(this.arrowElement, `gds-tooltip__arrow-${this.placement}`);
132
+ // add arrow to tooltip element
133
+ this.renderer.appendChild(this.tooltipElement, this.arrowElement);
134
+ }
135
+ /**
136
+ * @internal
137
+ * Destroys the current tooltip by un-setting variables, should only be used after detaching elements from the DOM.
138
+ */
139
+ destroy() {
140
+ this.tooltipElement = undefined;
141
+ this.arrowElement = undefined;
142
+ }
143
+ /**
144
+ * @internal
145
+ * Recalculates the position of the tooltip.
146
+ */
147
+ updatePosition() {
148
+ if (!this.tooltipElement || !this.arrowElement)
149
+ return;
150
+ const scrollPos = window.pageYOffset ||
151
+ document.documentElement.scrollTop ||
152
+ this.parentElement.scrollTop ||
153
+ 0;
154
+ const anchorRect = this.anchorElement.getBoundingClientRect();
155
+ const tooltipRect = this.tooltipElement.getBoundingClientRect();
156
+ const arrowRect = this.arrowElement.getBoundingClientRect();
157
+ switch (this.placement) {
158
+ case 'top':
159
+ this.alignVertical(true, scrollPos, anchorRect, tooltipRect.width, tooltipRect.height, arrowRect.width);
160
+ break;
161
+ case 'bottom':
162
+ this.alignVertical(false, scrollPos, anchorRect, tooltipRect.width, tooltipRect.height, arrowRect.width);
163
+ break;
164
+ case 'left':
165
+ this.alignHorizontal(true, scrollPos, anchorRect, tooltipRect.height);
166
+ break;
167
+ case 'right':
168
+ this.alignHorizontal(false, scrollPos, anchorRect, tooltipRect.height);
169
+ break;
170
+ default:
171
+ return;
172
+ }
173
+ }
174
+ /**
175
+ * @internal
176
+ * Calculates and set the position of the tooltip when the placement is `top` or `bottom`.
177
+ */
178
+ alignVertical(above, scrollPos, anchor, tooltipWidth, tooltipHeight, arrowWidth) {
179
+ const width = this.parentElement.clientWidth;
180
+ const anchorMidX = anchor.left + anchor.width / 2;
181
+ const tooltip = {};
182
+ const arrow = {};
183
+ if (above)
184
+ tooltip.top = anchor.top - tooltipHeight - this.offset + scrollPos;
185
+ else
186
+ tooltip.top = anchor.bottom + this.offset + scrollPos;
187
+ if (anchorMidX < width / 2) {
188
+ tooltip.left = Math.max(0, anchorMidX - tooltipWidth / 2);
189
+ arrow.left = anchorMidX - tooltip.left;
190
+ }
191
+ else {
192
+ tooltip.right = Math.max(0, width - (anchorMidX + tooltipWidth / 2));
193
+ arrow.right = width - anchorMidX - tooltip.right - arrowWidth;
194
+ }
195
+ this.setStyle(tooltip, arrow);
196
+ }
197
+ /**
198
+ * @internal
199
+ * Calculates and set the position of the tooltip when the placement is `left` or `right`.
200
+ */
201
+ alignHorizontal(before, scrollPos, anchor, tooltipHeight) {
202
+ const width = this.parentElement.clientWidth;
203
+ const top = anchor.top + (anchor.height - tooltipHeight) / 2 + scrollPos;
204
+ const tooltip = { top };
205
+ const arrow = { top: tooltipHeight / 2 };
206
+ if (before)
207
+ tooltip.right = width - anchor.left + this.offset;
208
+ else
209
+ tooltip.left = anchor.right + this.offset;
210
+ this.setStyle(tooltip, arrow);
211
+ }
212
+ /**
213
+ * @internal
214
+ * Updates the CSS properties for the tooltip position.
215
+ */
216
+ setStyle(tooltip, arrow) {
217
+ // Tooltip
218
+ Object.entries(tooltip).forEach(([prop, value]) => {
219
+ const position = this.pxToRem(value);
220
+ this.renderer.setStyle(this.tooltipElement, prop, position);
221
+ });
222
+ // Arrow
223
+ Object.entries(arrow).forEach(([prop, value]) => {
224
+ const position = this.pxToRem(value);
225
+ this.renderer.setStyle(this.arrowElement, prop, position);
226
+ });
227
+ }
228
+ pxToRem(value) {
229
+ const fontSizePx = window
230
+ ?.getComputedStyle(this.parentElement)
231
+ ?.getPropertyValue('font-size');
232
+ const fontSizeNumberMatch = fontSizePx?.match(/\d{1,}/);
233
+ const fontSize = fontSizeNumberMatch ? +fontSizeNumberMatch[0] : 16;
234
+ const remValue = value / fontSize;
235
+ return `${remValue}rem`;
236
+ }
237
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
238
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: NgvTooltipDirective, selector: "[ngvTooltip]", inputs: { ngvTooltip: "ngvTooltip", thook: "thook", placement: "placement", shown: "shown", offset: "offset", resizeThrottle: "resizeThrottle", maxWidth: "maxWidth" }, outputs: { ngvShow: "ngvShow", ngvHide: "ngvHide" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "window:resize": "resize()" } }, usesOnChanges: true, ngImport: i0 }); }
239
+ }
240
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTooltipDirective, decorators: [{
241
+ type: Directive,
242
+ args: [{
243
+ selector: '[ngvTooltip]',
244
+ }]
245
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { ngvTooltip: [{
246
+ type: Input
247
+ }], thook: [{
248
+ type: Input
249
+ }], placement: [{
250
+ type: Input
251
+ }], shown: [{
252
+ type: Input
253
+ }], offset: [{
254
+ type: Input
255
+ }], resizeThrottle: [{
256
+ type: Input
257
+ }], maxWidth: [{
258
+ type: Input
259
+ }], ngvShow: [{
260
+ type: Output
261
+ }], ngvHide: [{
262
+ type: Output
263
+ }], onMouseEnter: [{
264
+ type: HostListener,
265
+ args: ['mouseenter']
266
+ }], onMouseLeave: [{
267
+ type: HostListener,
268
+ args: ['mouseleave']
269
+ }], resize: [{
270
+ type: HostListener,
271
+ args: ['window:resize']
272
+ }] } });
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/v-angular/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  Renderer2,\n  SimpleChange,\n  SimpleChanges,\n} from '@angular/core'\n\nexport type Placement = 'top' | 'right' | 'bottom' | 'left'\n\ntype Position = {\n  top?: number\n  right?: number\n  bottom?: number\n  left?: number\n}\n\n/**\n * A tooltip is a text label that acts as a helper to a specific item.\n * Recommended to use value `top` or `bottom` with `placement` for responsive design.\n * Dynamic resizing and tooltip position are a work in progress.\n * https://designlibrary.sebgroup.com/components/component-tooltip\n */\n@Directive({\n  selector: '[ngvTooltip]',\n})\nexport class NgvTooltipDirective\n  implements AfterViewInit, OnChanges, OnDestroy\n{\n  /** The text that will be shown in the tooltip. */\n  @Input() ngvTooltip?: string\n  /** Special property used for selecting DOM elements during automated UI testing. */\n  @Input() thook = 'tooltip'\n  /** The side of the anchor which the tooltip will be rendered.\n   * Recommended `top` and `bottom` for responsive designs as these are more stable.\n   */\n  @Input() placement: Placement = 'top'\n  /** Initial state and subsequent updates on wether the tooltip is visible. */\n  @Input() shown = false\n  /** How far off from the text the tooltip will be rendered. */\n  @Input() offset = 10\n  /** How frequently the tooltip will be re-rendered when the page size changes. */\n  @Input() resizeThrottle = 50\n  /** Numeric max-width for tooltip. */\n  @Input() maxWidth = 343\n\n  /** Emits a show event triggered changing visibility state of the tooltip. */\n  @Output() ngvShow = new EventEmitter<HTMLElement>()\n  /** Emits a hide event triggered changing visibility state of the tooltip. */\n  @Output() ngvHide = new EventEmitter<HTMLElement>()\n\n  /** @internal */\n  protected timeout = 0\n\n  /** @internal */\n  protected parentElement: HTMLElement\n\n  /** @internal */\n  protected anchorElement: HTMLElement\n\n  /** @internal */\n  protected tooltipElement: HTMLElement | undefined\n\n  /** @internal */\n  protected arrowElement: HTMLElement | undefined\n\n  /** @internal Check if changes should trigger a re-render */\n  static shouldUpdate(change: SimpleChange) {\n    return (\n      change &&\n      !change.firstChange &&\n      change.previousValue !== change.currentValue\n    )\n  }\n\n  constructor(\n    private anchorElementRef: ElementRef,\n    private renderer: Renderer2,\n  ) {\n    this.anchorElement = this.anchorElementRef.nativeElement\n    this.parentElement = document.body\n  }\n\n  ngAfterViewInit() {\n    // Set a timeout to allow view to fully render before creating tooltip.\n    setTimeout(() => (this.shown ? this.show(true) : this.hide(true)))\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (\n      NgvTooltipDirective.shouldUpdate(changes.ngvTooltip) ||\n      NgvTooltipDirective.shouldUpdate(changes.placement) ||\n      NgvTooltipDirective.shouldUpdate(changes.thook)\n    ) {\n      this.shown ? this.show(true) : this.hide(true)\n    }\n\n    if (NgvTooltipDirective.shouldUpdate(changes.shown)) {\n      this.shown ? this.show() : this.hide()\n    }\n\n    if (NgvTooltipDirective.shouldUpdate(changes.offset)) {\n      this.updatePosition()\n    }\n  }\n\n  ngOnDestroy() {\n    this.hide(true)\n  }\n\n  /** @internal */\n  @HostListener('mouseenter')\n  onMouseEnter() {\n    this.show()\n  }\n\n  /** @internal */\n  @HostListener('mouseleave')\n  onMouseLeave() {\n    this.hide()\n  }\n\n  /** @internal */\n  @HostListener('window:resize')\n  resize() {\n    if (this.timeout) return\n    this.timeout = window.setTimeout(() => {\n      this.timeout = 0\n      this.updatePosition()\n    }, this.resizeThrottle)\n  }\n\n  /**\n   * Sets the visibility state of the tooltip to true and creates a new tooltip if it doesn't exist or `recreate` is set.\n   * @param recreate if set to true, destroy any existing tooltip and create a new one.\n   */\n  show(recreate = false) {\n    // Require tooltip text to create\n    if (!this.ngvTooltip || this.ngvTooltip.length === 0) return\n\n    if (recreate || !this.tooltipElement) {\n      this.hide(true)\n      this.create(this.ngvTooltip)\n    } else {\n      this.renderer.appendChild(this.parentElement, this.tooltipElement)\n    }\n\n    this.updatePosition()\n    this.shown = true\n    this.ngvShow.emit(this.tooltipElement)\n  }\n\n  /**\n   * Sets the visibility state of the tooltip to false and destroys an existing tooltip if `destroy` is set.\n   * @param destroy if set to true, destroy any existing tooltip.\n   */\n  hide(destroy = false) {\n    if (!this.tooltipElement) return\n    if (this.parentElement.contains(this.tooltipElement))\n      this.renderer.removeChild(this.parentElement, this.tooltipElement)\n    if (destroy) this.destroy()\n    this.shown = false\n    this.ngvHide.emit(this.tooltipElement)\n  }\n\n  /**\n   * @internal\n   * Creates a new tooltip with the set placement and a given text as its body.\n   * @param text the string to be displayed in the tooltip body.\n   */\n  create(text: string) {\n    this.tooltipElement = this.renderer.createElement('div')\n    this.renderer.addClass(this.tooltipElement, 'gds-tooltip')\n    this.renderer.setAttribute(this.tooltipElement, 'data-thook', this.thook)\n    this.renderer.setStyle(this.tooltipElement, 'position', 'absolute')\n    this.renderer.setStyle(this.tooltipElement, 'z-index', '1040')\n    this.renderer.setStyle(this.tooltipElement, 'border-radius', '.25rem')\n    this.renderer.setStyle(this.tooltipElement, 'padding', '.5rem 1rem')\n    const relativeMaxWidth = this.pxToRem(this.maxWidth)\n    this.renderer.setStyle(this.tooltipElement, 'max-width', relativeMaxWidth)\n    this.renderer.appendChild(\n      this.tooltipElement,\n      this.renderer.createText(text),\n    )\n\n    // add tooltip to DOM\n    this.renderer.appendChild(this.parentElement, this.tooltipElement)\n\n    this.arrowElement = this.renderer.createElement('div')\n    this.renderer.addClass(\n      this.arrowElement,\n      `gds-tooltip__arrow-${this.placement}`,\n    )\n\n    // add arrow to tooltip element\n    this.renderer.appendChild(this.tooltipElement, this.arrowElement)\n  }\n\n  /**\n   * @internal\n   * Destroys the current tooltip by un-setting variables, should only be used after detaching elements from the DOM.\n   */\n  destroy() {\n    this.tooltipElement = undefined\n    this.arrowElement = undefined\n  }\n\n  /**\n   * @internal\n   * Recalculates the position of the tooltip.\n   */\n  updatePosition() {\n    if (!this.tooltipElement || !this.arrowElement) return\n    const scrollPos =\n      window.pageYOffset ||\n      document.documentElement.scrollTop ||\n      this.parentElement.scrollTop ||\n      0\n    const anchorRect = this.anchorElement.getBoundingClientRect()\n    const tooltipRect = this.tooltipElement.getBoundingClientRect()\n    const arrowRect = this.arrowElement.getBoundingClientRect()\n\n    switch (this.placement) {\n      case 'top':\n        this.alignVertical(\n          true,\n          scrollPos,\n          anchorRect,\n          tooltipRect.width,\n          tooltipRect.height,\n          arrowRect.width,\n        )\n        break\n\n      case 'bottom':\n        this.alignVertical(\n          false,\n          scrollPos,\n          anchorRect,\n          tooltipRect.width,\n          tooltipRect.height,\n          arrowRect.width,\n        )\n        break\n\n      case 'left':\n        this.alignHorizontal(true, scrollPos, anchorRect, tooltipRect.height)\n        break\n\n      case 'right':\n        this.alignHorizontal(false, scrollPos, anchorRect, tooltipRect.height)\n        break\n\n      default:\n        return\n    }\n  }\n\n  /**\n   * @internal\n   * Calculates and set the position of the tooltip when the placement is `top` or `bottom`.\n   */\n  alignVertical(\n    above: boolean,\n    scrollPos: number,\n    anchor: DOMRect,\n    tooltipWidth: number,\n    tooltipHeight: number,\n    arrowWidth: number,\n  ) {\n    const width = this.parentElement.clientWidth\n    const anchorMidX = anchor.left + anchor.width / 2\n    const tooltip: Position = {}\n    const arrow: Position = {}\n\n    if (above)\n      tooltip.top = anchor.top - tooltipHeight - this.offset + scrollPos\n    else tooltip.top = anchor.bottom + this.offset + scrollPos\n\n    if (anchorMidX < width / 2) {\n      tooltip.left = Math.max(0, anchorMidX - tooltipWidth / 2)\n      arrow.left = anchorMidX - tooltip.left\n    } else {\n      tooltip.right = Math.max(0, width - (anchorMidX + tooltipWidth / 2))\n      arrow.right = width - anchorMidX - tooltip.right - arrowWidth\n    }\n\n    this.setStyle(tooltip, arrow)\n  }\n\n  /**\n   * @internal\n   * Calculates and set the position of the tooltip when the placement is `left` or `right`.\n   */\n  alignHorizontal(\n    before: boolean,\n    scrollPos: number,\n    anchor: DOMRect,\n    tooltipHeight: number,\n  ) {\n    const width = this.parentElement.clientWidth\n    const top = anchor.top + (anchor.height - tooltipHeight) / 2 + scrollPos\n    const tooltip: Position = { top }\n    const arrow: Position = { top: tooltipHeight / 2 }\n\n    if (before) tooltip.right = width - anchor.left + this.offset\n    else tooltip.left = anchor.right + this.offset\n\n    this.setStyle(tooltip, arrow)\n  }\n\n  /**\n   * @internal\n   * Updates the CSS properties for the tooltip position.\n   */\n  setStyle(tooltip: Position, arrow: Position) {\n    // Tooltip\n    Object.entries(tooltip).forEach(([prop, value]) => {\n      const position = this.pxToRem(value)\n      this.renderer.setStyle(this.tooltipElement, prop, position)\n    })\n\n    // Arrow\n    Object.entries(arrow).forEach(([prop, value]) => {\n      const position = this.pxToRem(value)\n      this.renderer.setStyle(this.arrowElement, prop, position)\n    })\n  }\n\n  private pxToRem(value: number): string {\n    const fontSizePx = window\n      ?.getComputedStyle(this.parentElement)\n      ?.getPropertyValue('font-size')\n    const fontSizeNumberMatch = fontSizePx?.match(/\\d{1,}/)\n    const fontSize = fontSizeNumberMatch ? +fontSizeNumberMatch[0] : 16\n    const remValue = value / fontSize\n    return `${remValue}rem`\n  }\n}\n"]}
@@ -0,0 +1,18 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { NgvI18nModule } from '@sebgroup/green-angular/src/v-angular/i18n';
3
+ import { NgvTooltipDirective } from './tooltip.directive';
4
+ import * as i0 from "@angular/core";
5
+ export class NgvTooltipModule {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTooltipModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NgvTooltipModule, declarations: [NgvTooltipDirective], imports: [NgvI18nModule], exports: [NgvTooltipDirective] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTooltipModule, imports: [NgvI18nModule] }); }
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTooltipModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ declarations: [NgvTooltipDirective],
14
+ exports: [NgvTooltipDirective],
15
+ imports: [NgvI18nModule],
16
+ }]
17
+ }] });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci90b29sdGlwL3Rvb2x0aXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDRDQUE0QyxDQUFBO0FBQzFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFCQUFxQixDQUFBOztBQU96RCxNQUFNLE9BQU8sZ0JBQWdCOytHQUFoQixnQkFBZ0I7Z0hBQWhCLGdCQUFnQixpQkFKWixtQkFBbUIsYUFFeEIsYUFBYSxhQURiLG1CQUFtQjtnSEFHbEIsZ0JBQWdCLFlBRmpCLGFBQWE7OzRGQUVaLGdCQUFnQjtrQkFMNUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztvQkFDbkMsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQzlCLE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQztpQkFDekIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBOZ3ZJMThuTW9kdWxlIH0gZnJvbSAnQHNlYmdyb3VwL2dyZWVuLWFuZ3VsYXIvc3JjL3YtYW5ndWxhci9pMThuJ1xuaW1wb3J0IHsgTmd2VG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4vdG9vbHRpcC5kaXJlY3RpdmUnXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW05ndlRvb2x0aXBEaXJlY3RpdmVdLFxuICBleHBvcnRzOiBbTmd2VG9vbHRpcERpcmVjdGl2ZV0sXG4gIGltcG9ydHM6IFtOZ3ZJMThuTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd2VG9vbHRpcE1vZHVsZSB7fVxuIl19
@@ -0,0 +1,76 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { NgvBaseControlValueAccessorModule } from './base-control-value-accessor';
4
+ import { NgvBreadcrumbsModule } from './breadcrumbs';
5
+ import { NgvButtonModule } from './button';
6
+ import { NgvCardModule } from './card';
7
+ import { NgvCheckboxModule } from './checkbox';
8
+ import { NgvDropdownModule } from './dropdown';
9
+ import { NgvI18nModule } from './i18n';
10
+ import { NgvInfoCircleModule } from './info-circle';
11
+ import { NgvInputModule } from './input';
12
+ import { NgvInputMaskModule } from './input-mask';
13
+ import { NgvModalModule } from './modal';
14
+ import { NgvRadioModule } from './radio';
15
+ import { NgvTextareaModule } from './textarea';
16
+ import { NgvTooltipModule } from './tooltip';
17
+ import { NgvTypeaheadModule } from './dropdown/typeahead/typeahead.module';
18
+ import * as i0 from "@angular/core";
19
+ export class NggvModule {
20
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggvModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
21
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NggvModule, imports: [CommonModule], exports: [NgvBaseControlValueAccessorModule,
22
+ NgvBreadcrumbsModule,
23
+ NgvButtonModule,
24
+ NgvCardModule,
25
+ NgvCheckboxModule,
26
+ NgvDropdownModule,
27
+ NgvI18nModule,
28
+ NgvInfoCircleModule,
29
+ NgvInputModule,
30
+ NgvInputMaskModule,
31
+ NgvModalModule,
32
+ NgvRadioModule,
33
+ NgvTextareaModule,
34
+ NgvTooltipModule,
35
+ NgvTypeaheadModule] }); }
36
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggvModule, imports: [CommonModule, NgvBaseControlValueAccessorModule,
37
+ NgvBreadcrumbsModule,
38
+ NgvButtonModule,
39
+ NgvCardModule,
40
+ NgvCheckboxModule,
41
+ NgvDropdownModule,
42
+ NgvI18nModule,
43
+ NgvInfoCircleModule,
44
+ NgvInputModule,
45
+ NgvInputMaskModule,
46
+ NgvModalModule,
47
+ NgvRadioModule,
48
+ NgvTextareaModule,
49
+ NgvTooltipModule,
50
+ NgvTypeaheadModule] }); }
51
+ }
52
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NggvModule, decorators: [{
53
+ type: NgModule,
54
+ args: [{
55
+ declarations: [],
56
+ imports: [CommonModule],
57
+ exports: [
58
+ NgvBaseControlValueAccessorModule,
59
+ NgvBreadcrumbsModule,
60
+ NgvButtonModule,
61
+ NgvCardModule,
62
+ NgvCheckboxModule,
63
+ NgvDropdownModule,
64
+ NgvI18nModule,
65
+ NgvInfoCircleModule,
66
+ NgvInputModule,
67
+ NgvInputMaskModule,
68
+ NgvModalModule,
69
+ NgvRadioModule,
70
+ NgvTextareaModule,
71
+ NgvTooltipModule,
72
+ NgvTypeaheadModule,
73
+ ],
74
+ }]
75
+ }] });
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidi1hbmd1bGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvdi1hbmd1bGFyL3YtYW5ndWxhci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sK0JBQStCLENBQUE7QUFDakYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3BELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxVQUFVLENBQUE7QUFDMUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFFBQVEsQ0FBQTtBQUN0QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxZQUFZLENBQUE7QUFDOUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sWUFBWSxDQUFBO0FBQzlDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxRQUFRLENBQUE7QUFDdEMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ25ELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxTQUFTLENBQUE7QUFDeEMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFBO0FBQ2pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxTQUFTLENBQUE7QUFDeEMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLFNBQVMsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxZQUFZLENBQUE7QUFDOUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sV0FBVyxDQUFBO0FBQzVDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFBOztBQXVCMUUsTUFBTSxPQUFPLFVBQVU7K0dBQVYsVUFBVTtnSEFBVixVQUFVLFlBbkJYLFlBQVksYUFFcEIsaUNBQWlDO1lBQ2pDLG9CQUFvQjtZQUNwQixlQUFlO1lBQ2YsYUFBYTtZQUNiLGlCQUFpQjtZQUNqQixpQkFBaUI7WUFDakIsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2Qsa0JBQWtCO1lBQ2xCLGNBQWM7WUFDZCxjQUFjO1lBQ2QsaUJBQWlCO1lBQ2pCLGdCQUFnQjtZQUNoQixrQkFBa0I7Z0hBR1QsVUFBVSxZQW5CWCxZQUFZLEVBRXBCLGlDQUFpQztZQUNqQyxvQkFBb0I7WUFDcEIsZUFBZTtZQUNmLGFBQWE7WUFDYixpQkFBaUI7WUFDakIsaUJBQWlCO1lBQ2pCLGFBQWE7WUFDYixtQkFBbUI7WUFDbkIsY0FBYztZQUNkLGtCQUFrQjtZQUNsQixjQUFjO1lBQ2QsY0FBYztZQUNkLGlCQUFpQjtZQUNqQixnQkFBZ0I7WUFDaEIsa0JBQWtCOzs0RkFHVCxVQUFVO2tCQXJCdEIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUU7d0JBQ1AsaUNBQWlDO3dCQUNqQyxvQkFBb0I7d0JBQ3BCLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixpQkFBaUI7d0JBQ2pCLGlCQUFpQjt3QkFDakIsYUFBYTt3QkFDYixtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2Qsa0JBQWtCO3dCQUNsQixjQUFjO3dCQUNkLGNBQWM7d0JBQ2QsaUJBQWlCO3dCQUNqQixnQkFBZ0I7d0JBQ2hCLGtCQUFrQjtxQkFDbkI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBOZ3ZCYXNlQ29udHJvbFZhbHVlQWNjZXNzb3JNb2R1bGUgfSBmcm9tICcuL2Jhc2UtY29udHJvbC12YWx1ZS1hY2Nlc3NvcidcbmltcG9ydCB7IE5ndkJyZWFkY3J1bWJzTW9kdWxlIH0gZnJvbSAnLi9icmVhZGNydW1icydcbmltcG9ydCB7IE5ndkJ1dHRvbk1vZHVsZSB9IGZyb20gJy4vYnV0dG9uJ1xuaW1wb3J0IHsgTmd2Q2FyZE1vZHVsZSB9IGZyb20gJy4vY2FyZCdcbmltcG9ydCB7IE5ndkNoZWNrYm94TW9kdWxlIH0gZnJvbSAnLi9jaGVja2JveCdcbmltcG9ydCB7IE5ndkRyb3Bkb3duTW9kdWxlIH0gZnJvbSAnLi9kcm9wZG93bidcbmltcG9ydCB7IE5ndkkxOG5Nb2R1bGUgfSBmcm9tICcuL2kxOG4nXG5pbXBvcnQgeyBOZ3ZJbmZvQ2lyY2xlTW9kdWxlIH0gZnJvbSAnLi9pbmZvLWNpcmNsZSdcbmltcG9ydCB7IE5ndklucHV0TW9kdWxlIH0gZnJvbSAnLi9pbnB1dCdcbmltcG9ydCB7IE5ndklucHV0TWFza01vZHVsZSB9IGZyb20gJy4vaW5wdXQtbWFzaydcbmltcG9ydCB7IE5ndk1vZGFsTW9kdWxlIH0gZnJvbSAnLi9tb2RhbCdcbmltcG9ydCB7IE5ndlJhZGlvTW9kdWxlIH0gZnJvbSAnLi9yYWRpbydcbmltcG9ydCB7IE5ndlRleHRhcmVhTW9kdWxlIH0gZnJvbSAnLi90ZXh0YXJlYSdcbmltcG9ydCB7IE5ndlRvb2x0aXBNb2R1bGUgfSBmcm9tICcuL3Rvb2x0aXAnXG5pbXBvcnQgeyBOZ3ZUeXBlYWhlYWRNb2R1bGUgfSBmcm9tICcuL2Ryb3Bkb3duL3R5cGVhaGVhZC90eXBlYWhlYWQubW9kdWxlJ1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogW1xuICAgIE5ndkJhc2VDb250cm9sVmFsdWVBY2Nlc3Nvck1vZHVsZSxcbiAgICBOZ3ZCcmVhZGNydW1ic01vZHVsZSxcbiAgICBOZ3ZCdXR0b25Nb2R1bGUsXG4gICAgTmd2Q2FyZE1vZHVsZSxcbiAgICBOZ3ZDaGVja2JveE1vZHVsZSxcbiAgICBOZ3ZEcm9wZG93bk1vZHVsZSxcbiAgICBOZ3ZJMThuTW9kdWxlLFxuICAgIE5ndkluZm9DaXJjbGVNb2R1bGUsXG4gICAgTmd2SW5wdXRNb2R1bGUsXG4gICAgTmd2SW5wdXRNYXNrTW9kdWxlLFxuICAgIE5ndk1vZGFsTW9kdWxlLFxuICAgIE5ndlJhZGlvTW9kdWxlLFxuICAgIE5ndlRleHRhcmVhTW9kdWxlLFxuICAgIE5ndlRvb2x0aXBNb2R1bGUsXG4gICAgTmd2VHlwZWFoZWFkTW9kdWxlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ2d2TW9kdWxlIHt9XG4iXX0=