monkey-style-guide-v2 0.0.5 → 0.0.6

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 (164) hide show
  1. package/assets/scss/directives/_index.scss +7 -0
  2. package/assets/scss/directives/_styles.scss +100 -0
  3. package/assets/scss/input/_index.scss +7 -0
  4. package/assets/scss/input/_styles.scss +43 -0
  5. package/assets/scss/partials/_index.scss +7 -0
  6. package/assets/scss/partials/_style-reset.scss +189 -0
  7. package/assets/scss/partials/_variables.scss +178 -0
  8. package/assets/scss/table/_index.scss +7 -0
  9. package/assets/scss/table/_styles.scss +45 -0
  10. package/assets/scss/theme.scss +11 -0
  11. package/assets/scss/typography/_function.scss +23 -0
  12. package/assets/scss/typography/_index.scss +9 -0
  13. package/assets/scss/typography/_mixins.scss +111 -0
  14. package/assets/scss/typography/_styles.scss +173 -0
  15. package/esm2022/lib/components/index.mjs +13 -1
  16. package/esm2022/lib/components/monkey-accordion/index.mjs +2 -0
  17. package/esm2022/lib/components/monkey-accordion/monkey-accordion.component.mjs +102 -0
  18. package/esm2022/lib/components/monkey-alert/index.mjs +2 -0
  19. package/esm2022/lib/components/monkey-alert/monkey-alert.component.mjs +50 -0
  20. package/esm2022/lib/components/monkey-breadcrumb/index.mjs +2 -0
  21. package/esm2022/lib/components/monkey-breadcrumb/monkey-breadcrumb.component.mjs +56 -0
  22. package/esm2022/lib/components/monkey-button/monkey-button.component.mjs +27 -12
  23. package/esm2022/lib/components/monkey-checkbox/index.mjs +2 -0
  24. package/esm2022/lib/components/monkey-checkbox/monkey-checkbox.component.mjs +216 -0
  25. package/esm2022/lib/components/monkey-divider/index.mjs +2 -0
  26. package/esm2022/lib/components/monkey-divider/monkey-divider.component.mjs +44 -0
  27. package/esm2022/lib/components/monkey-form-field/form-field-control.mjs +15 -0
  28. package/esm2022/lib/components/monkey-form-field/form-field.mjs +250 -0
  29. package/esm2022/lib/components/monkey-form-field/index.mjs +5 -0
  30. package/esm2022/lib/components/monkey-form-field/module.mjs +21 -0
  31. package/esm2022/lib/components/monkey-form-field/utils.mjs +16 -0
  32. package/esm2022/lib/components/monkey-icon/monkey-icon.component.mjs +31 -15
  33. package/esm2022/lib/components/monkey-icon-button/monkey-icon-button.component.mjs +25 -9
  34. package/esm2022/lib/components/monkey-input/index.mjs +5 -0
  35. package/esm2022/lib/components/monkey-input/monkey-input-currency.directive.mjs +187 -0
  36. package/esm2022/lib/components/monkey-input/monkey-input.directive.mjs +166 -0
  37. package/esm2022/lib/components/monkey-input/monkey-input.module.mjs +24 -0
  38. package/esm2022/lib/components/monkey-input/validators.mjs +17 -0
  39. package/esm2022/lib/components/monkey-option/index.mjs +2 -0
  40. package/esm2022/lib/components/monkey-option/monkey-option.component.mjs +54 -0
  41. package/esm2022/lib/components/monkey-security-level/monkey-security-level.component.mjs +30 -14
  42. package/esm2022/lib/components/monkey-select/index.mjs +2 -0
  43. package/esm2022/lib/components/monkey-select/monkey-select.component.mjs +352 -0
  44. package/esm2022/lib/components/monkey-status/monkey-status.component.mjs +28 -12
  45. package/esm2022/lib/components/monkey-table/components/pagination-action/pagination-action.mjs +53 -0
  46. package/esm2022/lib/components/monkey-table/components/pagination-label/pagination-label.mjs +34 -0
  47. package/esm2022/lib/components/monkey-table/components/pagination-size/pagination-size.mjs +57 -0
  48. package/esm2022/lib/components/monkey-table/directives/column-checked.mjs +109 -0
  49. package/esm2022/lib/components/monkey-table/directives/column-expansible.mjs +134 -0
  50. package/esm2022/lib/components/monkey-table/directives/column-sortable.mjs +97 -0
  51. package/esm2022/lib/components/monkey-table/directives/column-stick.mjs +28 -0
  52. package/esm2022/lib/components/monkey-table/index.mjs +10 -0
  53. package/esm2022/lib/components/monkey-table/table.mjs +132 -0
  54. package/esm2022/lib/components/monkey-table/table.module.mjs +60 -0
  55. package/esm2022/lib/components/monkey-toast/index.mjs +2 -0
  56. package/esm2022/lib/components/monkey-toast/monkey-toast.component.mjs +74 -0
  57. package/esm2022/lib/components/monkey-toggle/monkey-toggle.component.mjs +28 -14
  58. package/esm2022/lib/components/monkey-toggle-line/index.mjs +3 -0
  59. package/esm2022/lib/components/monkey-toggle-line/monkey-toggle-line-button/index.mjs +2 -0
  60. package/esm2022/lib/components/monkey-toggle-line/monkey-toggle-line-button/monkey-toggle-line-button.component.mjs +24 -0
  61. package/esm2022/lib/components/monkey-toggle-line/monkey-toggle-line.component.mjs +85 -0
  62. package/esm2022/lib/components/monkey-tooltip/monkey-tooltip.directive.mjs +4 -4
  63. package/esm2022/lib/components/monkey-tooltip/tooltip/tooltip.component.mjs +20 -7
  64. package/esm2022/lib/directives/error.mjs +18 -0
  65. package/esm2022/lib/directives/helper.mjs +18 -0
  66. package/esm2022/lib/directives/index.mjs +8 -0
  67. package/esm2022/lib/directives/info.mjs +18 -0
  68. package/esm2022/lib/directives/label.mjs +18 -0
  69. package/esm2022/lib/directives/module.mjs +26 -0
  70. package/esm2022/lib/directives/prefix.mjs +18 -0
  71. package/esm2022/lib/directives/suffix.mjs +43 -0
  72. package/esm2022/lib/interfaces/alert.mjs +2 -0
  73. package/esm2022/lib/interfaces/breadcrumb.mjs +2 -0
  74. package/esm2022/lib/interfaces/button.mjs +2 -0
  75. package/esm2022/lib/interfaces/index.mjs +7 -0
  76. package/esm2022/lib/interfaces/sizes.mjs +2 -0
  77. package/esm2022/lib/interfaces/table.mjs +2 -0
  78. package/esm2022/lib/interfaces/toast.mjs +10 -0
  79. package/esm2022/lib/services/index.mjs +4 -0
  80. package/esm2022/lib/services/monkey-destroy.service.mjs +15 -0
  81. package/esm2022/lib/services/monkey-icons.service.mjs +45 -0
  82. package/esm2022/lib/services/monkey-toast.service.mjs +72 -0
  83. package/esm2022/public-api.mjs +6 -3
  84. package/esm2022/utils/id-generator.mjs +20 -0
  85. package/esm2022/utils/index.mjs +4 -0
  86. package/esm2022/utils/tests-utils.mjs +4 -0
  87. package/esm2022/utils/utils.mjs +10 -0
  88. package/fesm2022/monkey-style-guide-v2.mjs +2849 -129
  89. package/fesm2022/monkey-style-guide-v2.mjs.map +1 -1
  90. package/lib/components/index.d.ts +12 -0
  91. package/lib/components/monkey-accordion/index.d.ts +1 -0
  92. package/lib/components/monkey-accordion/monkey-accordion.component.d.ts +22 -0
  93. package/lib/components/monkey-alert/index.d.ts +1 -0
  94. package/lib/components/monkey-alert/monkey-alert.component.d.ts +23 -0
  95. package/lib/components/monkey-breadcrumb/index.d.ts +1 -0
  96. package/lib/components/monkey-breadcrumb/monkey-breadcrumb.component.d.ts +18 -0
  97. package/lib/components/monkey-button/monkey-button.component.d.ts +11 -4
  98. package/lib/components/monkey-checkbox/index.d.ts +1 -0
  99. package/lib/components/monkey-checkbox/monkey-checkbox.component.d.ts +50 -0
  100. package/lib/components/monkey-divider/index.d.ts +1 -0
  101. package/lib/components/monkey-divider/monkey-divider.component.d.ts +20 -0
  102. package/lib/components/monkey-form-field/form-field-control.d.ts +18 -0
  103. package/lib/components/monkey-form-field/form-field.d.ts +74 -0
  104. package/lib/components/monkey-form-field/index.d.ts +4 -0
  105. package/lib/components/monkey-form-field/module.d.ts +7 -0
  106. package/lib/components/monkey-form-field/utils.d.ts +6 -0
  107. package/lib/components/monkey-icon/monkey-icon.component.d.ts +6 -1
  108. package/lib/components/monkey-icon-button/monkey-icon-button.component.d.ts +6 -1
  109. package/lib/components/monkey-input/index.d.ts +4 -0
  110. package/lib/components/monkey-input/monkey-input-currency.directive.d.ts +57 -0
  111. package/lib/components/monkey-input/monkey-input.directive.d.ts +46 -0
  112. package/lib/components/monkey-input/monkey-input.module.d.ts +8 -0
  113. package/lib/components/monkey-input/validators.d.ts +1 -0
  114. package/lib/components/monkey-option/index.d.ts +1 -0
  115. package/lib/components/monkey-option/monkey-option.component.d.ts +22 -0
  116. package/lib/components/monkey-security-level/monkey-security-level.component.d.ts +7 -2
  117. package/lib/components/monkey-select/index.d.ts +1 -0
  118. package/lib/components/monkey-select/monkey-select.component.d.ts +74 -0
  119. package/lib/components/monkey-status/monkey-status.component.d.ts +8 -3
  120. package/lib/components/monkey-table/components/pagination-action/pagination-action.d.ts +17 -0
  121. package/lib/components/monkey-table/components/pagination-label/pagination-label.d.ts +10 -0
  122. package/lib/components/monkey-table/components/pagination-size/pagination-size.d.ts +15 -0
  123. package/lib/components/monkey-table/directives/column-checked.d.ts +32 -0
  124. package/lib/components/monkey-table/directives/column-expansible.d.ts +25 -0
  125. package/lib/components/monkey-table/directives/column-sortable.d.ts +24 -0
  126. package/lib/components/monkey-table/directives/column-stick.d.ts +6 -0
  127. package/lib/components/monkey-table/index.d.ts +9 -0
  128. package/lib/components/monkey-table/table.d.ts +32 -0
  129. package/lib/components/monkey-table/table.module.d.ts +15 -0
  130. package/lib/components/monkey-toast/index.d.ts +1 -0
  131. package/lib/components/monkey-toast/monkey-toast.component.d.ts +26 -0
  132. package/lib/components/monkey-toggle/monkey-toggle.component.d.ts +6 -1
  133. package/lib/components/monkey-toggle-line/index.d.ts +2 -0
  134. package/lib/components/monkey-toggle-line/monkey-toggle-line-button/index.d.ts +1 -0
  135. package/lib/components/monkey-toggle-line/monkey-toggle-line-button/monkey-toggle-line-button.component.d.ts +16 -0
  136. package/lib/components/monkey-toggle-line/monkey-toggle-line.component.d.ts +24 -0
  137. package/lib/components/monkey-tooltip/tooltip/tooltip.component.d.ts +5 -1
  138. package/lib/directives/error.d.ts +5 -0
  139. package/lib/directives/helper.d.ts +5 -0
  140. package/lib/directives/index.d.ts +7 -0
  141. package/lib/directives/info.d.ts +5 -0
  142. package/lib/directives/label.d.ts +5 -0
  143. package/lib/directives/module.d.ts +12 -0
  144. package/lib/directives/prefix.d.ts +5 -0
  145. package/lib/directives/suffix.d.ts +9 -0
  146. package/lib/interfaces/alert.d.ts +1 -0
  147. package/lib/interfaces/breadcrumb.d.ts +5 -0
  148. package/lib/interfaces/button.d.ts +1 -0
  149. package/lib/interfaces/index.d.ts +6 -0
  150. package/lib/interfaces/sizes.d.ts +1 -0
  151. package/lib/interfaces/table.d.ts +4 -0
  152. package/lib/interfaces/toast.d.ts +22 -0
  153. package/lib/services/index.d.ts +3 -0
  154. package/lib/services/monkey-destroy.service.d.ts +8 -0
  155. package/lib/services/monkey-icons.service.d.ts +14 -0
  156. package/lib/services/monkey-toast.service.d.ts +13 -0
  157. package/monkey-style-guide-v2-0.0.6.tgz +0 -0
  158. package/package.json +10 -3
  159. package/public-api.d.ts +5 -2
  160. package/utils/id-generator.d.ts +6 -0
  161. package/utils/index.d.ts +3 -0
  162. package/utils/tests-utils.d.ts +1 -0
  163. package/utils/utils.d.ts +1 -0
  164. package/monkey-style-guide-v2-0.0.5.tgz +0 -0
@@ -0,0 +1,187 @@
1
+ /** ************************
2
+ * Copyright Monkey Exchange. All Rights Reserved
3
+ * This style guide was developed by Monkey Exchange Team
4
+ * MIT Licence
5
+ ************************* */
6
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
7
+ import { booleanAttribute, ChangeDetectorRef, DEFAULT_CURRENCY_CODE, Directive, ElementRef, inject, Input, LOCALE_ID } from '@angular/core';
8
+ import { NgControl, Validators } from '@angular/forms';
9
+ import { Subject, takeUntil } from 'rxjs';
10
+ import { IdGenerator } from '../../../utils';
11
+ import { MonkeyDestroyService } from '../../services';
12
+ import { MonkeyFormFieldControl } from '../monkey-form-field';
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "@angular/common";
15
+ export class MonkeyInputCurrencyDirective {
16
+ get disabled() {
17
+ if (this.ngControl && this.ngControl.disabled !== null) {
18
+ return this.ngControl.disabled;
19
+ }
20
+ return this._disabled;
21
+ }
22
+ set disabled(value) {
23
+ this._disabled = value;
24
+ if (this.focused) {
25
+ this.focused = false;
26
+ this.stateChanges.next();
27
+ }
28
+ }
29
+ get id() {
30
+ return this._id;
31
+ }
32
+ set id(value) {
33
+ this._id = value || this._uid;
34
+ }
35
+ get required() {
36
+ return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;
37
+ }
38
+ set required(value) {
39
+ this._required = coerceBooleanProperty(value);
40
+ }
41
+ get type() {
42
+ return this._type;
43
+ }
44
+ set type(value) {
45
+ this._type = value;
46
+ }
47
+ get currency() {
48
+ return true;
49
+ }
50
+ get percent() {
51
+ return false;
52
+ }
53
+ constructor(el, renderer, currencyPipe) {
54
+ this.el = el;
55
+ this.renderer = renderer;
56
+ this.currencyPipe = currencyPipe;
57
+ this._elementRef = inject(ElementRef);
58
+ this._uid = inject(IdGenerator).getId('monkey-input-currency-');
59
+ this.stateChanges = new Subject();
60
+ this._disabled = false;
61
+ this._type = 'text';
62
+ this._changeDetectorRef = inject(ChangeDetectorRef);
63
+ this._currencyCode = inject(DEFAULT_CURRENCY_CODE);
64
+ this._localeId = inject(LOCALE_ID);
65
+ this._destroyed = new Subject();
66
+ this._rawValue = 0;
67
+ this.ngControl = inject(NgControl, { self: true, optional: true });
68
+ this.focused = false;
69
+ // eslint-disable-next-line no-self-assign
70
+ this.id = this.id;
71
+ }
72
+ markAsUntouched() {
73
+ this.ngControl?.control?.markAsUntouched();
74
+ }
75
+ focus(options) {
76
+ this._elementRef.nativeElement.focus(options);
77
+ this.markAsUntouched();
78
+ }
79
+ formatValue(value) {
80
+ return this.currencyPipe.transform(value, this._currencyCode || 'BRL', '', '1.2-2', this._localeId || 'pt-BR');
81
+ }
82
+ handleControlValue() {
83
+ const value = this.ngControl?.control?.value;
84
+ if (this._rawValue !== value) {
85
+ this._rawValue = value;
86
+ let handled = value;
87
+ const decimal = `${value}`.split('.')[1];
88
+ if (`${decimal}`.length >= 2) {
89
+ handled = `${value}`.replace(/[^0-9]/g, '');
90
+ handled = `${Number(handled) / 100}`;
91
+ }
92
+ this.ngControl?.control?.setValue(Number(handled), { emitEvent: false, onlySelf: true });
93
+ const formattedValue = this.formatValue(handled);
94
+ this.renderer.setProperty(this.el.nativeElement, 'value', formattedValue);
95
+ this._changeDetectorRef.markForCheck();
96
+ }
97
+ }
98
+ ngOnInit() {
99
+ this.handleControlValue();
100
+ this._valueChanges?.unsubscribe();
101
+ this._valueChanges = this.ngControl?.control?.valueChanges
102
+ .pipe(takeUntil(this._destroyed))
103
+ .subscribe(() => {
104
+ this.handleControlValue();
105
+ });
106
+ }
107
+ ngOnDestroy() {
108
+ this.stateChanges.complete();
109
+ this._valueChanges?.unsubscribe();
110
+ }
111
+ ngOnChanges({ disabled }) {
112
+ if (!disabled) {
113
+ this.stateChanges.next();
114
+ }
115
+ }
116
+ onContainerClick() {
117
+ if (!this.focused) {
118
+ this.focus();
119
+ }
120
+ }
121
+ focusChanged(isFocused) {
122
+ if (isFocused === this.focused) {
123
+ return;
124
+ }
125
+ if (isFocused && this.disabled) {
126
+ const element = this._elementRef.nativeElement;
127
+ element.setSelectionRange(0, 0);
128
+ }
129
+ this.markAsUntouched();
130
+ this.focused = isFocused;
131
+ this.stateChanges.next();
132
+ }
133
+ focusOutChanged() {
134
+ this.ngControl?.control?.markAsTouched();
135
+ }
136
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyInputCurrencyDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.CurrencyPipe }], target: i0.ɵɵFactoryTarget.Directive }); }
137
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.13", type: MonkeyInputCurrencyDirective, selector: "input[monkey-input-currency]", inputs: { name: "name", disabled: ["disabled", "disabled", booleanAttribute], id: "id", required: "required", type: "type" }, host: { listeners: { "focus": "focusChanged(true)", "focusout": "focusOutChanged()", "blur": "focusChanged(false)" }, properties: { "class.mecx-input-disabled": "disabled", "id": "id", "disabled": "disabled", "required": "required", "attr.name": "name || null", "attr.disabled": "disabled || null", "attr.aria-invalid": "(empty && required) ? null : errorState", "attr.aria-required": "required", "attr.id": "id" }, classAttribute: "mecx-input" }, providers: [
138
+ {
139
+ provide: MonkeyFormFieldControl,
140
+ // eslint-disable-next-line no-use-before-define
141
+ useExisting: MonkeyInputCurrencyDirective
142
+ },
143
+ MonkeyDestroyService
144
+ ], exportAs: ["monkeyInput"], usesOnChanges: true, ngImport: i0 }); }
145
+ }
146
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyInputCurrencyDirective, decorators: [{
147
+ type: Directive,
148
+ args: [{
149
+ selector: 'input[monkey-input-currency]',
150
+ exportAs: 'monkeyInput',
151
+ host: {
152
+ class: 'mecx-input',
153
+ '[class.mecx-input-disabled]': 'disabled',
154
+ '[id]': 'id',
155
+ '[disabled]': 'disabled',
156
+ '[required]': 'required',
157
+ '[attr.name]': 'name || null',
158
+ '[attr.disabled]': 'disabled || null',
159
+ '[attr.aria-invalid]': '(empty && required) ? null : errorState',
160
+ '[attr.aria-required]': 'required',
161
+ '[attr.id]': 'id',
162
+ '(focus)': 'focusChanged(true)',
163
+ '(focusout)': 'focusOutChanged()',
164
+ '(blur)': 'focusChanged(false)'
165
+ },
166
+ providers: [
167
+ {
168
+ provide: MonkeyFormFieldControl,
169
+ // eslint-disable-next-line no-use-before-define
170
+ useExisting: MonkeyInputCurrencyDirective
171
+ },
172
+ MonkeyDestroyService
173
+ ]
174
+ }]
175
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.CurrencyPipe }], propDecorators: { name: [{
176
+ type: Input
177
+ }], disabled: [{
178
+ type: Input,
179
+ args: [{ transform: booleanAttribute }]
180
+ }], id: [{
181
+ type: Input
182
+ }], required: [{
183
+ type: Input
184
+ }], type: [{
185
+ type: Input
186
+ }] } });
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monkey-input-currency.directive.js","sourceRoot":"","sources":["../../../../../../projects/monkey-style-guide-v2/src/lib/components/monkey-input/monkey-input-currency.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/** ************************\n * Copyright Monkey Exchange. All Rights Reserved\n * This style guide was developed by Monkey Exchange Team\n * MIT Licence\n ************************* */\n\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { CurrencyPipe } from '@angular/common';\nimport {\n  booleanAttribute,\n  ChangeDetectorRef,\n  DEFAULT_CURRENCY_CODE,\n  Directive,\n  ElementRef,\n  inject,\n  Input,\n  LOCALE_ID,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  SimpleChanges\n} from '@angular/core';\nimport { NgControl, Validators } from '@angular/forms';\nimport { Subject, Subscription, takeUntil } from 'rxjs';\nimport { IdGenerator } from '../../../utils';\nimport { MonkeyDestroyService } from '../../services';\nimport { MonkeyFormFieldControl } from '../monkey-form-field';\n\n@Directive({\n  selector: 'input[monkey-input-currency]',\n  exportAs: 'monkeyInput',\n  host: {\n    class: 'mecx-input',\n    '[class.mecx-input-disabled]': 'disabled',\n    '[id]': 'id',\n    '[disabled]': 'disabled',\n    '[required]': 'required',\n    '[attr.name]': 'name || null',\n    '[attr.disabled]': 'disabled || null',\n    '[attr.aria-invalid]': '(empty && required) ? null : errorState',\n    '[attr.aria-required]': 'required',\n    '[attr.id]': 'id',\n    '(focus)': 'focusChanged(true)',\n    '(focusout)': 'focusOutChanged()',\n    '(blur)': 'focusChanged(false)'\n  },\n  providers: [\n    {\n      provide: MonkeyFormFieldControl,\n      // eslint-disable-next-line no-use-before-define\n      useExisting: MonkeyInputCurrencyDirective\n    },\n    MonkeyDestroyService\n  ]\n})\nexport class MonkeyInputCurrencyDirective\n  implements MonkeyFormFieldControl, OnChanges, OnInit, OnDestroy\n{\n  protected _elementRef =\n    inject<ElementRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>>(ElementRef);\n\n  protected _uid = inject(IdGenerator).getId('monkey-input-currency-');\n\n  protected _id!: string;\n\n  readonly stateChanges: Subject<void> = new Subject<void>();\n\n  @Input() name!: string;\n\n  @Input({ transform: booleanAttribute })\n  get disabled(): boolean {\n    if (this.ngControl && this.ngControl.disabled !== null) {\n      return this.ngControl.disabled;\n    }\n    return this._disabled;\n  }\n\n  set disabled(value: boolean) {\n    this._disabled = value;\n\n    if (this.focused) {\n      this.focused = false;\n      this.stateChanges.next();\n    }\n  }\n\n  @Input()\n  get id(): string {\n    return this._id;\n  }\n\n  set id(value: string) {\n    this._id = value || this._uid;\n  }\n\n  @Input()\n  get required(): boolean {\n    return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;\n  }\n\n  set required(value: BooleanInput) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  protected _required: boolean | undefined;\n\n  protected _disabled = false;\n\n  @Input()\n  get type(): string {\n    return this._type;\n  }\n\n  set type(value: string) {\n    this._type = value;\n  }\n\n  protected _type = 'text';\n\n  get currency(): boolean {\n    return true;\n  }\n\n  get percent(): boolean {\n    return false;\n  }\n\n  private readonly _changeDetectorRef = inject(ChangeDetectorRef);\n\n  private readonly _currencyCode = inject(DEFAULT_CURRENCY_CODE);\n\n  private readonly _localeId = inject(LOCALE_ID);\n\n  private _destroyed = new Subject<void>();\n\n  private _valueChanges: Subscription | undefined;\n\n  private _rawValue = 0;\n\n  ngControl = inject(NgControl, { self: true, optional: true });\n\n  focused: boolean = false;\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2,\n    private currencyPipe: CurrencyPipe\n  ) {\n    // eslint-disable-next-line no-self-assign\n    this.id = this.id;\n  }\n\n  private markAsUntouched() {\n    this.ngControl?.control?.markAsUntouched();\n  }\n\n  private focus(options?: FocusOptions): void {\n    this._elementRef.nativeElement.focus(options);\n    this.markAsUntouched();\n  }\n\n  private formatValue(value: string): string | null {\n    return this.currencyPipe.transform(\n      value,\n      this._currencyCode || 'BRL',\n      '',\n      '1.2-2',\n      this._localeId || 'pt-BR'\n    );\n  }\n\n  private handleControlValue() {\n    const value = this.ngControl?.control?.value;\n    if (this._rawValue !== value) {\n      this._rawValue = value;\n      let handled = value;\n      const decimal = `${value}`.split('.')[1];\n      if (`${decimal}`.length >= 2) {\n        handled = `${value}`.replace(/[^0-9]/g, '');\n        handled = `${Number(handled) / 100}`;\n      }\n\n      this.ngControl?.control?.setValue(Number(handled), { emitEvent: false, onlySelf: true });\n      const formattedValue = this.formatValue(handled);\n      this.renderer.setProperty(this.el.nativeElement, 'value', formattedValue);\n      this._changeDetectorRef.markForCheck();\n    }\n  }\n\n  ngOnInit(): void {\n    this.handleControlValue();\n    this._valueChanges?.unsubscribe();\n\n    this._valueChanges = this.ngControl?.control?.valueChanges\n      .pipe(takeUntil(this._destroyed))\n      .subscribe(() => {\n        this.handleControlValue();\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.stateChanges.complete();\n    this._valueChanges?.unsubscribe();\n  }\n\n  ngOnChanges({ disabled }: SimpleChanges): void {\n    if (!disabled) {\n      this.stateChanges.next();\n    }\n  }\n\n  onContainerClick() {\n    if (!this.focused) {\n      this.focus();\n    }\n  }\n\n  focusChanged(isFocused: boolean) {\n    if (isFocused === this.focused) {\n      return;\n    }\n\n    if (isFocused && this.disabled) {\n      const element = this._elementRef.nativeElement as HTMLInputElement;\n      element.setSelectionRange(0, 0);\n    }\n\n    this.markAsUntouched();\n    this.focused = isFocused;\n    this.stateChanges.next();\n  }\n\n  focusOutChanged() {\n    this.ngControl?.control?.markAsTouched();\n  }\n}\n"]}
@@ -0,0 +1,166 @@
1
+ /** ************************
2
+ * Copyright Monkey Exchange. All Rights Reserved
3
+ * This style guide was developed by Monkey Exchange Team
4
+ * MIT Licence
5
+ ************************* */
6
+ import { coerceBooleanProperty } from '@angular/cdk/coercion';
7
+ import { booleanAttribute, Directive, ElementRef, inject, Input } from '@angular/core';
8
+ import { NgControl, Validators } from '@angular/forms';
9
+ import { Subject } from 'rxjs';
10
+ import { IdGenerator } from '../../../utils';
11
+ import { MonkeyDestroyService } from '../../services';
12
+ import { MonkeyFormFieldControl } from '../monkey-form-field';
13
+ import { validateType } from './validators';
14
+ import * as i0 from "@angular/core";
15
+ export class MonkeyInputDirective {
16
+ get disabled() {
17
+ if (this.ngControl && this.ngControl.disabled !== null) {
18
+ return this.ngControl.disabled;
19
+ }
20
+ return this._disabled;
21
+ }
22
+ set disabled(value) {
23
+ this._disabled = value;
24
+ if (this.focused) {
25
+ this.focused = false;
26
+ this.stateChanges.next();
27
+ }
28
+ }
29
+ get id() {
30
+ return this._id;
31
+ }
32
+ set id(value) {
33
+ this._id = value || this._uid;
34
+ }
35
+ get required() {
36
+ return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;
37
+ }
38
+ set required(value) {
39
+ this._required = coerceBooleanProperty(value);
40
+ }
41
+ get type() {
42
+ return this._type;
43
+ }
44
+ set type(value) {
45
+ validateType(value);
46
+ this._type = value || 'text';
47
+ this._elementRef.nativeElement.type = this._type;
48
+ }
49
+ get currency() {
50
+ return false;
51
+ }
52
+ get percent() {
53
+ return this._percent;
54
+ }
55
+ set percent(value) {
56
+ this._percent = true;
57
+ }
58
+ constructor() {
59
+ this._elementRef = inject(ElementRef);
60
+ this._uid = inject(IdGenerator).getId('monkey-input-');
61
+ this.stateChanges = new Subject();
62
+ this._disabled = false;
63
+ this._type = 'text';
64
+ this._percent = false;
65
+ this.ngControl = inject(NgControl, { self: true, optional: true });
66
+ this.focused = false;
67
+ // eslint-disable-next-line no-self-assign
68
+ this.id = this.id;
69
+ }
70
+ markAsUntouched() {
71
+ this.ngControl?.control?.markAsUntouched();
72
+ }
73
+ focus(options) {
74
+ this._elementRef.nativeElement.focus(options);
75
+ this.markAsUntouched();
76
+ }
77
+ ngOnDestroy() {
78
+ this.stateChanges.complete();
79
+ }
80
+ ngOnChanges({ disabled }) {
81
+ if (!disabled) {
82
+ this.stateChanges.next();
83
+ }
84
+ }
85
+ onContainerClick() {
86
+ if (!this.focused) {
87
+ this.focus();
88
+ }
89
+ }
90
+ focusChanged(isFocused) {
91
+ if (isFocused === this.focused) {
92
+ return;
93
+ }
94
+ if (isFocused && this.disabled) {
95
+ const element = this._elementRef.nativeElement;
96
+ if (element.type === 'number') {
97
+ element.type = 'text';
98
+ element.setSelectionRange(0, 0);
99
+ element.type = 'number';
100
+ }
101
+ else {
102
+ element.setSelectionRange(0, 0);
103
+ }
104
+ }
105
+ this.markAsUntouched();
106
+ this.focused = isFocused;
107
+ this.stateChanges.next();
108
+ }
109
+ focusOutChanged() {
110
+ this.ngControl?.control?.markAsTouched();
111
+ }
112
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyInputDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
113
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.2.13", type: MonkeyInputDirective, selector: "input[monkey-input],textarea[monkey-input]", inputs: { name: "name", disabled: ["disabled", "disabled", booleanAttribute], id: "id", required: "required", type: "type", percent: "percent" }, host: { attributes: { "data-testid": "monkey-input" }, listeners: { "focus": "focusChanged(true)", "focusout": "focusOutChanged()", "blur": "focusChanged(false)" }, properties: { "class.mecx-input-disabled": "disabled", "id": "id", "disabled": "disabled", "required": "required", "attr.name": "name || null", "attr.disabled": "disabled || null", "attr.aria-invalid": "(empty && required) ? null : errorState", "attr.aria-required": "required", "attr.id": "id" }, classAttribute: "mecx-input" }, providers: [
114
+ {
115
+ provide: MonkeyFormFieldControl,
116
+ // eslint-disable-next-line no-use-before-define
117
+ useExisting: MonkeyInputDirective
118
+ },
119
+ MonkeyDestroyService
120
+ ], exportAs: ["monkeyInput"], usesOnChanges: true, ngImport: i0 }); }
121
+ }
122
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyInputDirective, decorators: [{
123
+ type: Directive,
124
+ args: [{
125
+ selector: 'input[monkey-input],textarea[monkey-input]',
126
+ exportAs: 'monkeyInput',
127
+ host: {
128
+ class: 'mecx-input',
129
+ 'data-testid': 'monkey-input',
130
+ '[class.mecx-input-disabled]': 'disabled',
131
+ '[id]': 'id',
132
+ '[disabled]': 'disabled',
133
+ '[required]': 'required',
134
+ '[attr.name]': 'name || null',
135
+ '[attr.disabled]': 'disabled || null',
136
+ '[attr.aria-invalid]': '(empty && required) ? null : errorState',
137
+ '[attr.aria-required]': 'required',
138
+ '[attr.id]': 'id',
139
+ '(focus)': 'focusChanged(true)',
140
+ '(focusout)': 'focusOutChanged()',
141
+ '(blur)': 'focusChanged(false)'
142
+ },
143
+ providers: [
144
+ {
145
+ provide: MonkeyFormFieldControl,
146
+ // eslint-disable-next-line no-use-before-define
147
+ useExisting: MonkeyInputDirective
148
+ },
149
+ MonkeyDestroyService
150
+ ]
151
+ }]
152
+ }], ctorParameters: () => [], propDecorators: { name: [{
153
+ type: Input
154
+ }], disabled: [{
155
+ type: Input,
156
+ args: [{ transform: booleanAttribute }]
157
+ }], id: [{
158
+ type: Input
159
+ }], required: [{
160
+ type: Input
161
+ }], type: [{
162
+ type: Input
163
+ }], percent: [{
164
+ type: Input
165
+ }] } });
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monkey-input.directive.js","sourceRoot":"","sources":["../../../../../../projects/monkey-style-guide-v2/src/lib/components/monkey-input/monkey-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/** ************************\n * Copyright Monkey Exchange. All Rights Reserved\n * This style guide was developed by Monkey Exchange Team\n * MIT Licence\n ************************* */\n\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  booleanAttribute,\n  Directive,\n  ElementRef,\n  inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges\n} from '@angular/core';\nimport { NgControl, Validators } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { IdGenerator } from '../../../utils';\nimport { MonkeyDestroyService } from '../../services';\nimport { MonkeyFormFieldControl } from '../monkey-form-field';\nimport { validateType } from './validators';\n\n@Directive({\n  selector: 'input[monkey-input],textarea[monkey-input]',\n  exportAs: 'monkeyInput',\n  host: {\n    class: 'mecx-input',\n    'data-testid': 'monkey-input',\n    '[class.mecx-input-disabled]': 'disabled',\n    '[id]': 'id',\n    '[disabled]': 'disabled',\n    '[required]': 'required',\n    '[attr.name]': 'name || null',\n    '[attr.disabled]': 'disabled || null',\n    '[attr.aria-invalid]': '(empty && required) ? null : errorState',\n    '[attr.aria-required]': 'required',\n    '[attr.id]': 'id',\n    '(focus)': 'focusChanged(true)',\n    '(focusout)': 'focusOutChanged()',\n    '(blur)': 'focusChanged(false)'\n  },\n  providers: [\n    {\n      provide: MonkeyFormFieldControl,\n      // eslint-disable-next-line no-use-before-define\n      useExisting: MonkeyInputDirective\n    },\n    MonkeyDestroyService\n  ]\n})\nexport class MonkeyInputDirective implements MonkeyFormFieldControl, OnChanges, OnDestroy {\n  protected _elementRef =\n    inject<ElementRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>>(ElementRef);\n\n  protected _uid = inject(IdGenerator).getId('monkey-input-');\n\n  protected _id!: string;\n\n  readonly stateChanges: Subject<void> = new Subject<void>();\n\n  @Input() name!: string;\n\n  @Input({ transform: booleanAttribute })\n  get disabled(): boolean {\n    if (this.ngControl && this.ngControl.disabled !== null) {\n      return this.ngControl.disabled;\n    }\n    return this._disabled;\n  }\n\n  set disabled(value: boolean) {\n    this._disabled = value;\n\n    if (this.focused) {\n      this.focused = false;\n      this.stateChanges.next();\n    }\n  }\n\n  @Input()\n  get id(): string {\n    return this._id;\n  }\n\n  set id(value: string) {\n    this._id = value || this._uid;\n  }\n\n  @Input()\n  get required(): boolean {\n    return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;\n  }\n\n  set required(value: BooleanInput) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  protected _required: boolean | undefined;\n\n  protected _disabled = false;\n\n  @Input()\n  get type(): string {\n    return this._type;\n  }\n\n  set type(value: string) {\n    validateType(value);\n    this._type = value || 'text';\n\n    (this._elementRef.nativeElement as HTMLInputElement).type = this._type;\n  }\n\n  protected _type = 'text';\n\n  get currency(): boolean {\n    return false;\n  }\n\n  @Input()\n  get percent(): boolean {\n    return this._percent;\n  }\n\n  set percent(value: '') {\n    this._percent = true;\n  }\n\n  protected _percent = false;\n\n  ngControl = inject(NgControl, { self: true, optional: true });\n\n  focused: boolean = false;\n\n  constructor() {\n    // eslint-disable-next-line no-self-assign\n    this.id = this.id;\n  }\n\n  private markAsUntouched() {\n    this.ngControl?.control?.markAsUntouched();\n  }\n\n  private focus(options?: FocusOptions): void {\n    this._elementRef.nativeElement.focus(options);\n    this.markAsUntouched();\n  }\n\n  ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  ngOnChanges({ disabled }: SimpleChanges): void {\n    if (!disabled) {\n      this.stateChanges.next();\n    }\n  }\n\n  onContainerClick() {\n    if (!this.focused) {\n      this.focus();\n    }\n  }\n\n  focusChanged(isFocused: boolean) {\n    if (isFocused === this.focused) {\n      return;\n    }\n\n    if (isFocused && this.disabled) {\n      const element = this._elementRef.nativeElement as HTMLInputElement;\n\n      if (element.type === 'number') {\n        element.type = 'text';\n        element.setSelectionRange(0, 0);\n        element.type = 'number';\n      } else {\n        element.setSelectionRange(0, 0);\n      }\n    }\n\n    this.markAsUntouched();\n    this.focused = isFocused;\n    this.stateChanges.next();\n  }\n\n  focusOutChanged() {\n    this.ngControl?.control?.markAsTouched();\n  }\n}\n"]}
@@ -0,0 +1,24 @@
1
+ /** ************************
2
+ * Copyright Monkey Exchange. All Rights Reserved
3
+ * This style guide was developed by Monkey Exchange Team
4
+ * MIT Licence
5
+ ************************* */
6
+ import { CurrencyPipe } from '@angular/common';
7
+ import { NgModule } from '@angular/core';
8
+ import { MonkeyInputCurrencyDirective } from './monkey-input-currency.directive';
9
+ import { MonkeyInputDirective } from './monkey-input.directive';
10
+ import * as i0 from "@angular/core";
11
+ export class MonkeyInputModule {
12
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
13
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MonkeyInputModule, declarations: [MonkeyInputDirective, MonkeyInputCurrencyDirective], exports: [MonkeyInputDirective, MonkeyInputCurrencyDirective] }); }
14
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyInputModule, providers: [CurrencyPipe] }); }
15
+ }
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyInputModule, decorators: [{
17
+ type: NgModule,
18
+ args: [{
19
+ providers: [CurrencyPipe],
20
+ declarations: [MonkeyInputDirective, MonkeyInputCurrencyDirective],
21
+ exports: [MonkeyInputDirective, MonkeyInputCurrencyDirective]
22
+ }]
23
+ }] });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5LWlucHV0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1zdHlsZS1ndWlkZS12Mi9zcmMvbGliL2NvbXBvbmVudHMvbW9ua2V5LWlucHV0L21vbmtleS1pbnB1dC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7NkJBSTZCO0FBRTdCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQU9oRSxNQUFNLE9BQU8saUJBQWlCOytHQUFqQixpQkFBaUI7Z0hBQWpCLGlCQUFpQixpQkFIYixvQkFBb0IsRUFBRSw0QkFBNEIsYUFDdkQsb0JBQW9CLEVBQUUsNEJBQTRCO2dIQUVqRCxpQkFBaUIsYUFKakIsQ0FBQyxZQUFZLENBQUM7OzRGQUlkLGlCQUFpQjtrQkFMN0IsUUFBUTttQkFBQztvQkFDUixTQUFTLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3pCLFlBQVksRUFBRSxDQUFDLG9CQUFvQixFQUFFLDRCQUE0QixDQUFDO29CQUNsRSxPQUFPLEVBQUUsQ0FBQyxvQkFBb0IsRUFBRSw0QkFBNEIsQ0FBQztpQkFDOUQiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBDb3B5cmlnaHQgTW9ua2V5IEV4Y2hhbmdlLiBBbGwgUmlnaHRzIFJlc2VydmVkXG4gKiBUaGlzIHN0eWxlIGd1aWRlIHdhcyBkZXZlbG9wZWQgYnkgTW9ua2V5IEV4Y2hhbmdlIFRlYW1cbiAqIE1JVCBMaWNlbmNlXG4gKioqKioqKioqKioqKioqKioqKioqKioqKiAqL1xuXG5pbXBvcnQgeyBDdXJyZW5jeVBpcGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1vbmtleUlucHV0Q3VycmVuY3lEaXJlY3RpdmUgfSBmcm9tICcuL21vbmtleS1pbnB1dC1jdXJyZW5jeS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgTW9ua2V5SW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL21vbmtleS1pbnB1dC5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICBwcm92aWRlcnM6IFtDdXJyZW5jeVBpcGVdLFxuICBkZWNsYXJhdGlvbnM6IFtNb25rZXlJbnB1dERpcmVjdGl2ZSwgTW9ua2V5SW5wdXRDdXJyZW5jeURpcmVjdGl2ZV0sXG4gIGV4cG9ydHM6IFtNb25rZXlJbnB1dERpcmVjdGl2ZSwgTW9ua2V5SW5wdXRDdXJyZW5jeURpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgTW9ua2V5SW5wdXRNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,17 @@
1
+ import { getSupportedInputTypes } from '@angular/cdk/platform';
2
+ const INPUT_INVALID_TYPES = [
3
+ 'button',
4
+ 'checkbox',
5
+ 'file',
6
+ 'image',
7
+ 'radio',
8
+ 'range',
9
+ 'reset',
10
+ 'submit'
11
+ ];
12
+ export function validateType(type) {
13
+ if (INPUT_INVALID_TYPES.indexOf(type) > -1 || !getSupportedInputTypes().has(type)) {
14
+ throw Error(`Input type "${type}" isn't supported.`);
15
+ }
16
+ }
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1zdHlsZS1ndWlkZS12Mi9zcmMvbGliL2NvbXBvbmVudHMvbW9ua2V5LWlucHV0L3ZhbGlkYXRvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFL0QsTUFBTSxtQkFBbUIsR0FBRztJQUMxQixRQUFRO0lBQ1IsVUFBVTtJQUNWLE1BQU07SUFDTixPQUFPO0lBQ1AsT0FBTztJQUNQLE9BQU87SUFDUCxPQUFPO0lBQ1AsUUFBUTtDQUNULENBQUM7QUFFRixNQUFNLFVBQVUsWUFBWSxDQUFDLElBQVk7SUFDdkMsSUFBSSxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ2xGLE1BQU0sS0FBSyxDQUFDLGVBQWUsSUFBSSxvQkFBb0IsQ0FBQyxDQUFDO0lBQ3ZELENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0U3VwcG9ydGVkSW5wdXRUeXBlcyB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wbGF0Zm9ybSc7XG5cbmNvbnN0IElOUFVUX0lOVkFMSURfVFlQRVMgPSBbXG4gICdidXR0b24nLFxuICAnY2hlY2tib3gnLFxuICAnZmlsZScsXG4gICdpbWFnZScsXG4gICdyYWRpbycsXG4gICdyYW5nZScsXG4gICdyZXNldCcsXG4gICdzdWJtaXQnXG5dO1xuXG5leHBvcnQgZnVuY3Rpb24gdmFsaWRhdGVUeXBlKHR5cGU6IHN0cmluZykge1xuICBpZiAoSU5QVVRfSU5WQUxJRF9UWVBFUy5pbmRleE9mKHR5cGUpID4gLTEgfHwgIWdldFN1cHBvcnRlZElucHV0VHlwZXMoKS5oYXModHlwZSkpIHtcbiAgICB0aHJvdyBFcnJvcihgSW5wdXQgdHlwZSBcIiR7dHlwZX1cIiBpc24ndCBzdXBwb3J0ZWQuYCk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export * from './monkey-option.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1vcHRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbW9ua2V5LW9wdGlvbi5jb21wb25lbnQnO1xuIl19
@@ -0,0 +1,54 @@
1
+ /** ************************
2
+ * Copyright Monkey Exchange. All Rights Reserved
3
+ * This style guide was developed by Monkey Exchange Team
4
+ * MIT Licence
5
+ ************************* */
6
+ import { booleanAttribute, ChangeDetectionStrategy, Component, HostListener, inject, Input, ViewChild, ViewEncapsulation } from '@angular/core';
7
+ import { IdGenerator } from '../../../utils';
8
+ import * as i0 from "@angular/core";
9
+ export class MonkeyOptionComponent {
10
+ constructor() {
11
+ this.idGenerator = inject(IdGenerator);
12
+ this.disabled = false;
13
+ this.selected = false;
14
+ this.tabIndex = 0;
15
+ this.id = this.idGenerator.getId('mecx-option-');
16
+ }
17
+ get displayContent() {
18
+ return (this._content?.nativeElement.textContent || '').trim();
19
+ }
20
+ onClick(event) {
21
+ if (this.disabled) {
22
+ event.stopPropagation();
23
+ event.preventDefault();
24
+ }
25
+ else {
26
+ this.action?.();
27
+ }
28
+ }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyOptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.13", type: MonkeyOptionComponent, isStandalone: true, selector: "monkey-option", inputs: { value: "value", disabled: ["disabled", "disabled", booleanAttribute] }, host: { attributes: { "data-testid": "monkey-option" }, listeners: { "click": "onClick($event)" }, properties: { "attr.id": "id", "class.mecx-option-disabled": "disabled", "class.mecx-option-selected": "selected", "attr.tabindex": "disabled ? -1 : tabIndex" }, classAttribute: "mecx-option" }, viewQueries: [{ propertyName: "_content", first: true, predicate: ["content"], descendants: true, static: true }], ngImport: i0, template: `<div #content><ng-content /></div>`, isInline: true, styles: ["monkey-option{display:flex;position:relative;cursor:pointer;padding:16px;line-height:16px;font-size:14px;color:var(--mecx-color-gray-900);transition:all .1s ease-in-out}monkey-option>div{display:flex;white-space:normal;word-break:break-all}monkey-option:hover{color:var(--mecx-color-gray-900);background-color:var(--mecx-color-gray-100)}monkey-option.mecx-option-disabled{color:var(--mecx-color-gray-400);background-color:#fff;cursor:default}monkey-option.mecx-option-selected{color:var(--mecx-color-theme-contrast-main);background-color:var(--mecx-color-theme-main)}.ng-animating monkey-option.mecx-option-selected{color:var(--mecx-color-gray-900);background-color:var(--mecx-color-gray-100)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
31
+ }
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyOptionComponent, decorators: [{
33
+ type: Component,
34
+ args: [{ selector: 'monkey-option', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: `<div #content><ng-content /></div>`, encapsulation: ViewEncapsulation.None, host: {
35
+ 'data-testid': 'monkey-option',
36
+ '[attr.id]': 'id',
37
+ class: 'mecx-option',
38
+ '[class.mecx-option-disabled]': 'disabled',
39
+ '[class.mecx-option-selected]': 'selected',
40
+ '[attr.tabindex]': 'disabled ? -1 : tabIndex'
41
+ }, styles: ["monkey-option{display:flex;position:relative;cursor:pointer;padding:16px;line-height:16px;font-size:14px;color:var(--mecx-color-gray-900);transition:all .1s ease-in-out}monkey-option>div{display:flex;white-space:normal;word-break:break-all}monkey-option:hover{color:var(--mecx-color-gray-900);background-color:var(--mecx-color-gray-100)}monkey-option.mecx-option-disabled{color:var(--mecx-color-gray-400);background-color:#fff;cursor:default}monkey-option.mecx-option-selected{color:var(--mecx-color-theme-contrast-main);background-color:var(--mecx-color-theme-main)}.ng-animating monkey-option.mecx-option-selected{color:var(--mecx-color-gray-900);background-color:var(--mecx-color-gray-100)}\n"] }]
42
+ }], propDecorators: { _content: [{
43
+ type: ViewChild,
44
+ args: ['content', { static: true }]
45
+ }], value: [{
46
+ type: Input
47
+ }], disabled: [{
48
+ type: Input,
49
+ args: [{ transform: booleanAttribute }]
50
+ }], onClick: [{
51
+ type: HostListener,
52
+ args: ['click', ['$event']]
53
+ }] } });
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5LW9wdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1vcHRpb24vbW9ua2V5LW9wdGlvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7NkJBSTZCO0FBRTdCLE9BQU8sRUFDTCxnQkFBZ0IsRUFDaEIsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFFVCxZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFDTCxTQUFTLEVBQ1QsaUJBQWlCLEVBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFrQjdDLE1BQU0sT0FBTyxxQkFBcUI7SUFoQmxDO1FBaUJtQixnQkFBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQU1YLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFNekQsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUVqQixhQUFRLEdBQUcsQ0FBQyxDQUFDO1FBSUosT0FBRSxHQUFXLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDO0tBVzlEO0lBckJDLElBQUksY0FBYztRQUNoQixPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxhQUFhLENBQUMsV0FBVyxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2pFLENBQUM7SUFXRCxPQUFPLENBQUMsS0FBaUI7UUFDdkIsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbEIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1lBQ3hCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN6QixDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDO1FBQ2xCLENBQUM7SUFDSCxDQUFDOytHQTdCVSxxQkFBcUI7bUdBQXJCLHFCQUFxQiw4R0FPWixnQkFBZ0Isc2JBbkIxQixvQ0FBb0M7OzRGQVluQyxxQkFBcUI7a0JBaEJqQyxTQUFTOytCQUNFLGVBQWUsY0FDYixJQUFJLG1CQUNDLHVCQUF1QixDQUFDLE1BQU0sWUFDckMsb0NBQW9DLGlCQUUvQixpQkFBaUIsQ0FBQyxJQUFJLFFBQy9CO3dCQUNKLGFBQWEsRUFBRSxlQUFlO3dCQUM5QixXQUFXLEVBQUUsSUFBSTt3QkFDakIsS0FBSyxFQUFFLGFBQWE7d0JBQ3BCLDhCQUE4QixFQUFFLFVBQVU7d0JBQzFDLDhCQUE4QixFQUFFLFVBQVU7d0JBQzFDLGlCQUFpQixFQUFFLDBCQUEwQjtxQkFDOUM7OEJBS3VDLFFBQVE7c0JBQS9DLFNBQVM7dUJBQUMsU0FBUyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRTtnQkFFN0IsS0FBSztzQkFBYixLQUFLO2dCQUVrQyxRQUFRO3NCQUEvQyxLQUFLO3VCQUFDLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFO2dCQWV0QyxPQUFPO3NCQUROLFlBQVk7dUJBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqICoqKioqKioqKioqKioqKioqKioqKioqKlxuICogQ29weXJpZ2h0IE1vbmtleSBFeGNoYW5nZS4gQWxsIFJpZ2h0cyBSZXNlcnZlZFxuICogVGhpcyBzdHlsZSBndWlkZSB3YXMgZGV2ZWxvcGVkIGJ5IE1vbmtleSBFeGNoYW5nZSBUZWFtXG4gKiBNSVQgTGljZW5jZVxuICoqKioqKioqKioqKioqKioqKioqKioqKiogKi9cblxuaW1wb3J0IHtcbiAgYm9vbGVhbkF0dHJpYnV0ZSxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgSG9zdExpc3RlbmVyLFxuICBpbmplY3QsXG4gIElucHV0LFxuICBWaWV3Q2hpbGQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWRHZW5lcmF0b3IgfSBmcm9tICcuLi8uLi8uLi91dGlscyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21vbmtleS1vcHRpb24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgdGVtcGxhdGU6IGA8ZGl2ICNjb250ZW50PjxuZy1jb250ZW50IC8+PC9kaXY+YCxcbiAgc3R5bGVVcmxzOiBbJy4vbW9ua2V5LW9wdGlvbi5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBob3N0OiB7XG4gICAgJ2RhdGEtdGVzdGlkJzogJ21vbmtleS1vcHRpb24nLFxuICAgICdbYXR0ci5pZF0nOiAnaWQnLFxuICAgIGNsYXNzOiAnbWVjeC1vcHRpb24nLFxuICAgICdbY2xhc3MubWVjeC1vcHRpb24tZGlzYWJsZWRdJzogJ2Rpc2FibGVkJyxcbiAgICAnW2NsYXNzLm1lY3gtb3B0aW9uLXNlbGVjdGVkXSc6ICdzZWxlY3RlZCcsXG4gICAgJ1thdHRyLnRhYmluZGV4XSc6ICdkaXNhYmxlZCA/IC0xIDogdGFiSW5kZXgnXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgTW9ua2V5T3B0aW9uQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSByZWFkb25seSBpZEdlbmVyYXRvciA9IGluamVjdChJZEdlbmVyYXRvcik7XG5cbiAgQFZpZXdDaGlsZCgnY29udGVudCcsIHsgc3RhdGljOiB0cnVlIH0pIF9jb250ZW50OiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PiB8IHVuZGVmaW5lZDtcblxuICBASW5wdXQoKSB2YWx1ZTogYW55O1xuXG4gIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KSBkaXNhYmxlZCA9IGZhbHNlO1xuXG4gIGdldCBkaXNwbGF5Q29udGVudCgpOiBzdHJpbmcge1xuICAgIHJldHVybiAodGhpcy5fY29udGVudD8ubmF0aXZlRWxlbWVudC50ZXh0Q29udGVudCB8fCAnJykudHJpbSgpO1xuICB9XG5cbiAgc2VsZWN0ZWQgPSBmYWxzZTtcblxuICB0YWJJbmRleCA9IDA7XG5cbiAgYWN0aW9uITogRnVuY3Rpb247XG5cbiAgcmVhZG9ubHkgaWQ6IHN0cmluZyA9IHRoaXMuaWRHZW5lcmF0b3IuZ2V0SWQoJ21lY3gtb3B0aW9uLScpO1xuXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJywgWyckZXZlbnQnXSlcbiAgb25DbGljayhldmVudDogTW91c2VFdmVudCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmRpc2FibGVkKSB7XG4gICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuYWN0aW9uPy4oKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -1,18 +1,14 @@
1
- /**************************
1
+ /** ************************
2
2
  * Copyright Monkey Exchange. All Rights Reserved
3
3
  * This style guide was developed by Monkey Exchange Team
4
4
  * MIT Licence
5
- **************************/
5
+ ************************* */
6
6
  import { CommonModule } from '@angular/common';
7
- import { Component, HostBinding, input } from '@angular/core';
7
+ import { Component, HostBinding, inject, Input, input, ViewEncapsulation } from '@angular/core';
8
+ import { IdGenerator } from '../../../utils';
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "@angular/common";
10
11
  export class MonkeySecurityLevelComponent {
11
- constructor() {
12
- this.score = input.required();
13
- this.label = input();
14
- this.strengthLabel = input();
15
- }
16
12
  get class() {
17
13
  if (this.score() === 0) {
18
14
  return 'empty';
@@ -28,14 +24,34 @@ export class MonkeySecurityLevelComponent {
28
24
  }
29
25
  return 'very-strong';
30
26
  }
31
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MonkeySecurityLevelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
32
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.4", type: MonkeySecurityLevelComponent, isStandalone: true, selector: "monkey-security-level", inputs: { score: { classPropertyName: "score", publicName: "score", isSignal: true, isRequired: true, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, strengthLabel: { classPropertyName: "strengthLabel", publicName: "strengthLabel", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.class" } }, ngImport: i0, template: "<div class=\"body\">\n <div>\n <span data-testid=\"label\" *ngIf=\"label() as lb\">\n {{ lb }}\n </span>\n <span data-testid=\"str-label\" class=\"level-info\" *ngIf=\"strengthLabel() as strLabel\">\n {{ strLabel }}\n </span>\n </div>\n <div class=\"bar\"></div>\n</div>\n", styles: [":host{display:flex;align-items:center;gap:8px;width:100%}:host span{color:#545a63;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}:host .level-info{color:#1f2024;margin-left:24px;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}:host .body{display:flex;flex-direction:column;align-items:baseline;width:100%}:host .bar{height:4px;width:100%;max-width:426px;border-radius:8px;background:#d3d6da;position:relative;overflow:hidden}:host .bar:before{content:\"\";display:block;position:absolute;height:100%;left:0;top:0;transition:all 1s}:host.very-strong .bar:before{background:#00875a;width:100%}:host.strong .bar:before{background:#00875a;width:80%}:host.medium .bar:before{background:#efa30e;width:66%}:host.weak .bar:before{background:#db0505;width:33%}:host.empty .bar:before{background:#db0505;width:0%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
27
+ get id() {
28
+ return this._id;
29
+ }
30
+ set id(value) {
31
+ this._id = value || this._uid;
32
+ }
33
+ constructor() {
34
+ this.label = input();
35
+ this.score = input.required();
36
+ this.strengthLabel = input();
37
+ this._uid = inject(IdGenerator).getId('monkey-security-level-');
38
+ // eslint-disable-next-line no-self-assign
39
+ this.id = this.id;
40
+ }
41
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeySecurityLevelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: MonkeySecurityLevelComponent, isStandalone: true, selector: "monkey-security-level", inputs: { label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, score: { classPropertyName: "score", publicName: "score", isSignal: true, isRequired: true, transformFunction: null }, strengthLabel: { classPropertyName: "strengthLabel", publicName: "strengthLabel", isSignal: true, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: false, isRequired: false, transformFunction: null } }, host: { attributes: { "data-testid": "monkey-security-level" }, properties: { "attr.id": "id", "id": "id", "class": "this.class" } }, ngImport: i0, template: "<div class=\"body\">\n <div>\n <span data-testid=\"label\" *ngIf=\"label() as lb\">\n {{ lb }}\n </span>\n <span data-testid=\"str-label\" class=\"level-info\" *ngIf=\"strengthLabel() as strLabel\">\n {{ strLabel }}\n </span>\n </div>\n <div class=\"bar\"></div>\n</div>\n", styles: ["monkey-security-level{display:flex;align-items:center;gap:8px;width:100%}monkey-security-level span{color:#545a63;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .level-info{color:#1f2024;margin-left:24px;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .body{display:flex;flex-direction:column;align-items:baseline;width:100%}monkey-security-level .bar{height:4px;width:100%;max-width:426px;border-radius:8px;background:#d3d6da;position:relative;overflow:hidden}monkey-security-level .bar:before{content:\"\";display:block;position:absolute;height:100%;left:0;top:0;transition:all 1s}monkey-security-level.very-strong .bar:before{background:#00875a;width:100%}monkey-security-level.strong .bar:before{background:#00875a;width:80%}monkey-security-level.medium .bar:before{background:#efa30e;width:66%}monkey-security-level.weak .bar:before{background:#db0505;width:33%}monkey-security-level.empty .bar:before{background:#db0505;width:0%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
33
43
  }
34
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MonkeySecurityLevelComponent, decorators: [{
44
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeySecurityLevelComponent, decorators: [{
35
45
  type: Component,
36
- args: [{ selector: 'monkey-security-level', standalone: true, imports: [CommonModule], template: "<div class=\"body\">\n <div>\n <span data-testid=\"label\" *ngIf=\"label() as lb\">\n {{ lb }}\n </span>\n <span data-testid=\"str-label\" class=\"level-info\" *ngIf=\"strengthLabel() as strLabel\">\n {{ strLabel }}\n </span>\n </div>\n <div class=\"bar\"></div>\n</div>\n", styles: [":host{display:flex;align-items:center;gap:8px;width:100%}:host span{color:#545a63;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}:host .level-info{color:#1f2024;margin-left:24px;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}:host .body{display:flex;flex-direction:column;align-items:baseline;width:100%}:host .bar{height:4px;width:100%;max-width:426px;border-radius:8px;background:#d3d6da;position:relative;overflow:hidden}:host .bar:before{content:\"\";display:block;position:absolute;height:100%;left:0;top:0;transition:all 1s}:host.very-strong .bar:before{background:#00875a;width:100%}:host.strong .bar:before{background:#00875a;width:80%}:host.medium .bar:before{background:#efa30e;width:66%}:host.weak .bar:before{background:#db0505;width:33%}:host.empty .bar:before{background:#db0505;width:0%}\n"] }]
37
- }], propDecorators: { class: [{
46
+ args: [{ encapsulation: ViewEncapsulation.None, imports: [CommonModule], selector: 'monkey-security-level', standalone: true, host: {
47
+ 'data-testid': 'monkey-security-level',
48
+ '[attr.id]': 'id',
49
+ '[id]': 'id'
50
+ }, template: "<div class=\"body\">\n <div>\n <span data-testid=\"label\" *ngIf=\"label() as lb\">\n {{ lb }}\n </span>\n <span data-testid=\"str-label\" class=\"level-info\" *ngIf=\"strengthLabel() as strLabel\">\n {{ strLabel }}\n </span>\n </div>\n <div class=\"bar\"></div>\n</div>\n", styles: ["monkey-security-level{display:flex;align-items:center;gap:8px;width:100%}monkey-security-level span{color:#545a63;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .level-info{color:#1f2024;margin-left:24px;font-size:14px;font-style:normal;font-weight:400;line-height:24px;letter-spacing:.42px}monkey-security-level .body{display:flex;flex-direction:column;align-items:baseline;width:100%}monkey-security-level .bar{height:4px;width:100%;max-width:426px;border-radius:8px;background:#d3d6da;position:relative;overflow:hidden}monkey-security-level .bar:before{content:\"\";display:block;position:absolute;height:100%;left:0;top:0;transition:all 1s}monkey-security-level.very-strong .bar:before{background:#00875a;width:100%}monkey-security-level.strong .bar:before{background:#00875a;width:80%}monkey-security-level.medium .bar:before{background:#efa30e;width:66%}monkey-security-level.weak .bar:before{background:#db0505;width:33%}monkey-security-level.empty .bar:before{background:#db0505;width:0%}\n"] }]
51
+ }], ctorParameters: () => [], propDecorators: { class: [{
38
52
  type: HostBinding,
39
53
  args: ['class']
54
+ }], id: [{
55
+ type: Input
40
56
  }] } });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5LXNlY3VyaXR5LWxldmVsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1zdHlsZS1ndWlkZS12Mi9zcmMvbGliL2NvbXBvbmVudHMvbW9ua2V5LXNlY3VyaXR5LWxldmVsL21vbmtleS1zZWN1cml0eS1sZXZlbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1zZWN1cml0eS1sZXZlbC9tb25rZXktc2VjdXJpdHktbGV2ZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7NEJBSTRCO0FBQzVCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVM5RCxNQUFNLE9BQU8sNEJBQTRCO0lBUHpDO1FBUUUsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUNqQyxVQUFLLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDeEIsa0JBQWEsR0FBRyxLQUFLLEVBQVUsQ0FBQztLQWtCakM7SUFoQkMsSUFDVyxLQUFLO1FBQ2QsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdkIsT0FBTyxPQUFPLENBQUM7UUFDakIsQ0FBQztRQUNELElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxHQUFHLEdBQUcsRUFBRSxDQUFDO1lBQ3ZCLE9BQU8sTUFBTSxDQUFDO1FBQ2hCLENBQUM7UUFDRCxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxHQUFHLEdBQUcsRUFBRSxDQUFDO1lBQzlDLE9BQU8sUUFBUSxDQUFDO1FBQ2xCLENBQUM7UUFDRCxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDO1lBQy9DLE9BQU8sUUFBUSxDQUFDO1FBQ2xCLENBQUM7UUFDRCxPQUFPLGFBQWEsQ0FBQztJQUN2QixDQUFDOzhHQXBCVSw0QkFBNEI7a0dBQTVCLDRCQUE0Qiw2Z0JDZnpDLDJTQVdBLDY2QkRBWSxZQUFZOzsyRkFJWCw0QkFBNEI7a0JBUHhDLFNBQVM7K0JBQ0UsdUJBQXVCLGNBQ3JCLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQzs4QkFVWixLQUFLO3NCQURmLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbIi8qKioqKioqKioqKioqKioqKioqKioqKioqKlxuICogQ29weXJpZ2h0IE1vbmtleSBFeGNoYW5nZS4gQWxsIFJpZ2h0cyBSZXNlcnZlZFxuICogVGhpcyBzdHlsZSBndWlkZSB3YXMgZGV2ZWxvcGVkIGJ5IE1vbmtleSBFeGNoYW5nZSBUZWFtXG4gKiBNSVQgTGljZW5jZVxuICoqKioqKioqKioqKioqKioqKioqKioqKioqL1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21vbmtleS1zZWN1cml0eS1sZXZlbCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vbW9ua2V5LXNlY3VyaXR5LWxldmVsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL21vbmtleS1zZWN1cml0eS1sZXZlbC5jb21wb25lbnQuc2Nzcydcbn0pXG5leHBvcnQgY2xhc3MgTW9ua2V5U2VjdXJpdHlMZXZlbENvbXBvbmVudCB7XG4gIHNjb3JlID0gaW5wdXQucmVxdWlyZWQ8bnVtYmVyPigpO1xuICBsYWJlbCA9IGlucHV0PHN0cmluZz4oKTtcbiAgc3RyZW5ndGhMYWJlbCA9IGlucHV0PHN0cmluZz4oKTtcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgcHVibGljIGdldCBjbGFzcygpOiBzdHJpbmcge1xuICAgIGlmICh0aGlzLnNjb3JlKCkgPT09IDApIHtcbiAgICAgIHJldHVybiAnZW1wdHknO1xuICAgIH1cbiAgICBpZiAodGhpcy5zY29yZSgpIDwgMzAwKSB7XG4gICAgICByZXR1cm4gJ3dlYWsnO1xuICAgIH1cbiAgICBpZiAodGhpcy5zY29yZSgpID49IDMwMCAmJiB0aGlzLnNjb3JlKCkgPCA4MDApIHtcbiAgICAgIHJldHVybiAnbWVkaXVtJztcbiAgICB9XG4gICAgaWYgKHRoaXMuc2NvcmUoKSA+PSA4MDAgJiYgdGhpcy5zY29yZSgpIDwgMTAwMCkge1xuICAgICAgcmV0dXJuICdzdHJvbmcnO1xuICAgIH1cbiAgICByZXR1cm4gJ3Zlcnktc3Ryb25nJztcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImJvZHlcIj5cbiAgPGRpdj5cbiAgICA8c3BhbiBkYXRhLXRlc3RpZD1cImxhYmVsXCIgKm5nSWY9XCJsYWJlbCgpIGFzIGxiXCI+XG4gICAgICB7eyBsYiB9fVxuICAgIDwvc3Bhbj5cbiAgICA8c3BhbiBkYXRhLXRlc3RpZD1cInN0ci1sYWJlbFwiIGNsYXNzPVwibGV2ZWwtaW5mb1wiICpuZ0lmPVwic3RyZW5ndGhMYWJlbCgpIGFzIHN0ckxhYmVsXCI+XG4gICAgICB7eyBzdHJMYWJlbCB9fVxuICAgIDwvc3Bhbj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJiYXJcIj48L2Rpdj5cbjwvZGl2PlxuIl19
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5LXNlY3VyaXR5LWxldmVsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1zdHlsZS1ndWlkZS12Mi9zcmMvbGliL2NvbXBvbmVudHMvbW9ua2V5LXNlY3VyaXR5LWxldmVsL21vbmtleS1zZWN1cml0eS1sZXZlbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1zZWN1cml0eS1sZXZlbC9tb25rZXktc2VjdXJpdHktbGV2ZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7NkJBSTZCO0FBQzdCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNoRyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQWU3QyxNQUFNLE9BQU8sNEJBQTRCO0lBT3ZDLElBQ1csS0FBSztRQUNkLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQ3ZCLE9BQU8sT0FBTyxDQUFDO1FBQ2pCLENBQUM7UUFFRCxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsR0FBRyxHQUFHLEVBQUUsQ0FBQztZQUN2QixPQUFPLE1BQU0sQ0FBQztRQUNoQixDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksR0FBRyxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsR0FBRyxHQUFHLEVBQUUsQ0FBQztZQUM5QyxPQUFPLFFBQVEsQ0FBQztRQUNsQixDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksR0FBRyxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsR0FBRyxJQUFJLEVBQUUsQ0FBQztZQUMvQyxPQUFPLFFBQVEsQ0FBQztRQUNsQixDQUFDO1FBRUQsT0FBTyxhQUFhLENBQUM7SUFDdkIsQ0FBQztJQU1ELElBQ0ksRUFBRTtRQUNKLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQztJQUNsQixDQUFDO0lBRUQsSUFBSSxFQUFFLENBQUMsS0FBYTtRQUNsQixJQUFJLENBQUMsR0FBRyxHQUFHLEtBQUssSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ2hDLENBQUM7SUFFRDtRQXhDQSxVQUFLLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFFeEIsVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUVqQyxrQkFBYSxHQUFHLEtBQUssRUFBVSxDQUFDO1FBdUJ0QixTQUFJLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLEtBQUssQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1FBY25FLDBDQUEwQztRQUMxQyxJQUFJLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDcEIsQ0FBQzsrR0E1Q1UsNEJBQTRCO21HQUE1Qiw0QkFBNEIsa3RCQ3RCekMsMlNBV0EsNmxDREFZLFlBQVk7OzRGQVdYLDRCQUE0QjtrQkFieEMsU0FBUztvQ0FDTyxpQkFBaUIsQ0FBQyxJQUFJLFdBQzVCLENBQUMsWUFBWSxDQUFDLFlBQ2IsdUJBQXVCLGNBQ3JCLElBQUksUUFHVjt3QkFDSixhQUFhLEVBQUUsdUJBQXVCO3dCQUN0QyxXQUFXLEVBQUUsSUFBSTt3QkFDakIsTUFBTSxFQUFFLElBQUk7cUJBQ2I7d0RBVVUsS0FBSztzQkFEZixXQUFXO3VCQUFDLE9BQU87Z0JBMEJoQixFQUFFO3NCQURMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBDb3B5cmlnaHQgTW9ua2V5IEV4Y2hhbmdlLiBBbGwgUmlnaHRzIFJlc2VydmVkXG4gKiBUaGlzIHN0eWxlIGd1aWRlIHdhcyBkZXZlbG9wZWQgYnkgTW9ua2V5IEV4Y2hhbmdlIFRlYW1cbiAqIE1JVCBMaWNlbmNlXG4gKioqKioqKioqKioqKioqKioqKioqKioqKiAqL1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIGluamVjdCwgSW5wdXQsIGlucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWRHZW5lcmF0b3IgfSBmcm9tICcuLi8uLi8uLi91dGlscyc7XG5cbkBDb21wb25lbnQoe1xuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgc2VsZWN0b3I6ICdtb25rZXktc2VjdXJpdHktbGV2ZWwnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzdHlsZVVybDogJy4vbW9ua2V5LXNlY3VyaXR5LWxldmVsLmNvbXBvbmVudC5zY3NzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL21vbmtleS1zZWN1cml0eS1sZXZlbC5jb21wb25lbnQuaHRtbCcsXG4gIGhvc3Q6IHtcbiAgICAnZGF0YS10ZXN0aWQnOiAnbW9ua2V5LXNlY3VyaXR5LWxldmVsJyxcbiAgICAnW2F0dHIuaWRdJzogJ2lkJyxcbiAgICAnW2lkXSc6ICdpZCdcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBNb25rZXlTZWN1cml0eUxldmVsQ29tcG9uZW50IHtcbiAgbGFiZWwgPSBpbnB1dDxzdHJpbmc+KCk7XG5cbiAgc2NvcmUgPSBpbnB1dC5yZXF1aXJlZDxudW1iZXI+KCk7XG5cbiAgc3RyZW5ndGhMYWJlbCA9IGlucHV0PHN0cmluZz4oKTtcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgcHVibGljIGdldCBjbGFzcygpOiBzdHJpbmcge1xuICAgIGlmICh0aGlzLnNjb3JlKCkgPT09IDApIHtcbiAgICAgIHJldHVybiAnZW1wdHknO1xuICAgIH1cblxuICAgIGlmICh0aGlzLnNjb3JlKCkgPCAzMDApIHtcbiAgICAgIHJldHVybiAnd2Vhayc7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuc2NvcmUoKSA+PSAzMDAgJiYgdGhpcy5zY29yZSgpIDwgODAwKSB7XG4gICAgICByZXR1cm4gJ21lZGl1bSc7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuc2NvcmUoKSA+PSA4MDAgJiYgdGhpcy5zY29yZSgpIDwgMTAwMCkge1xuICAgICAgcmV0dXJuICdzdHJvbmcnO1xuICAgIH1cblxuICAgIHJldHVybiAndmVyeS1zdHJvbmcnO1xuICB9XG5cbiAgcHJvdGVjdGVkIF91aWQgPSBpbmplY3QoSWRHZW5lcmF0b3IpLmdldElkKCdtb25rZXktc2VjdXJpdHktbGV2ZWwtJyk7XG5cbiAgcHJvdGVjdGVkIF9pZCE6IHN0cmluZztcblxuICBASW5wdXQoKVxuICBnZXQgaWQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5faWQ7XG4gIH1cblxuICBzZXQgaWQodmFsdWU6IHN0cmluZykge1xuICAgIHRoaXMuX2lkID0gdmFsdWUgfHwgdGhpcy5fdWlkO1xuICB9XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXNlbGYtYXNzaWduXG4gICAgdGhpcy5pZCA9IHRoaXMuaWQ7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJib2R5XCI+XG4gIDxkaXY+XG4gICAgPHNwYW4gZGF0YS10ZXN0aWQ9XCJsYWJlbFwiICpuZ0lmPVwibGFiZWwoKSBhcyBsYlwiPlxuICAgICAge3sgbGIgfX1cbiAgICA8L3NwYW4+XG4gICAgPHNwYW4gZGF0YS10ZXN0aWQ9XCJzdHItbGFiZWxcIiBjbGFzcz1cImxldmVsLWluZm9cIiAqbmdJZj1cInN0cmVuZ3RoTGFiZWwoKSBhcyBzdHJMYWJlbFwiPlxuICAgICAge3sgc3RyTGFiZWwgfX1cbiAgICA8L3NwYW4+XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwiYmFyXCI+PC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export * from './monkey-select.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1zZWxlY3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbW9ua2V5LXNlbGVjdC5jb21wb25lbnQnO1xuIl19