monkey-style-guide-v2 0.0.4 → 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 (169) 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 +14 -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/index.mjs +3 -0
  63. package/esm2022/lib/components/monkey-tooltip/monkey-tooltip.directive.mjs +175 -0
  64. package/esm2022/lib/components/monkey-tooltip/tooltip/index.mjs +2 -0
  65. package/esm2022/lib/components/monkey-tooltip/tooltip/tooltip.component.mjs +53 -0
  66. package/esm2022/lib/directives/error.mjs +18 -0
  67. package/esm2022/lib/directives/helper.mjs +18 -0
  68. package/esm2022/lib/directives/index.mjs +8 -0
  69. package/esm2022/lib/directives/info.mjs +18 -0
  70. package/esm2022/lib/directives/label.mjs +18 -0
  71. package/esm2022/lib/directives/module.mjs +26 -0
  72. package/esm2022/lib/directives/prefix.mjs +18 -0
  73. package/esm2022/lib/directives/suffix.mjs +43 -0
  74. package/esm2022/lib/interfaces/alert.mjs +2 -0
  75. package/esm2022/lib/interfaces/breadcrumb.mjs +2 -0
  76. package/esm2022/lib/interfaces/button.mjs +2 -0
  77. package/esm2022/lib/interfaces/index.mjs +7 -0
  78. package/esm2022/lib/interfaces/sizes.mjs +2 -0
  79. package/esm2022/lib/interfaces/table.mjs +2 -0
  80. package/esm2022/lib/interfaces/toast.mjs +10 -0
  81. package/esm2022/lib/services/index.mjs +4 -0
  82. package/esm2022/lib/services/monkey-destroy.service.mjs +15 -0
  83. package/esm2022/lib/services/monkey-icons.service.mjs +45 -0
  84. package/esm2022/lib/services/monkey-toast.service.mjs +72 -0
  85. package/esm2022/public-api.mjs +6 -3
  86. package/esm2022/utils/id-generator.mjs +20 -0
  87. package/esm2022/utils/index.mjs +4 -0
  88. package/esm2022/utils/tests-utils.mjs +4 -0
  89. package/esm2022/utils/utils.mjs +10 -0
  90. package/fesm2022/monkey-style-guide-v2.mjs +3049 -121
  91. package/fesm2022/monkey-style-guide-v2.mjs.map +1 -1
  92. package/lib/components/index.d.ts +13 -0
  93. package/lib/components/monkey-accordion/index.d.ts +1 -0
  94. package/lib/components/monkey-accordion/monkey-accordion.component.d.ts +22 -0
  95. package/lib/components/monkey-alert/index.d.ts +1 -0
  96. package/lib/components/monkey-alert/monkey-alert.component.d.ts +23 -0
  97. package/lib/components/monkey-breadcrumb/index.d.ts +1 -0
  98. package/lib/components/monkey-breadcrumb/monkey-breadcrumb.component.d.ts +18 -0
  99. package/lib/components/monkey-button/monkey-button.component.d.ts +11 -4
  100. package/lib/components/monkey-checkbox/index.d.ts +1 -0
  101. package/lib/components/monkey-checkbox/monkey-checkbox.component.d.ts +50 -0
  102. package/lib/components/monkey-divider/index.d.ts +1 -0
  103. package/lib/components/monkey-divider/monkey-divider.component.d.ts +20 -0
  104. package/lib/components/monkey-form-field/form-field-control.d.ts +18 -0
  105. package/lib/components/monkey-form-field/form-field.d.ts +74 -0
  106. package/lib/components/monkey-form-field/index.d.ts +4 -0
  107. package/lib/components/monkey-form-field/module.d.ts +7 -0
  108. package/lib/components/monkey-form-field/utils.d.ts +6 -0
  109. package/lib/components/monkey-icon/monkey-icon.component.d.ts +6 -1
  110. package/lib/components/monkey-icon-button/monkey-icon-button.component.d.ts +6 -1
  111. package/lib/components/monkey-input/index.d.ts +4 -0
  112. package/lib/components/monkey-input/monkey-input-currency.directive.d.ts +57 -0
  113. package/lib/components/monkey-input/monkey-input.directive.d.ts +46 -0
  114. package/lib/components/monkey-input/monkey-input.module.d.ts +8 -0
  115. package/lib/components/monkey-input/validators.d.ts +1 -0
  116. package/lib/components/monkey-option/index.d.ts +1 -0
  117. package/lib/components/monkey-option/monkey-option.component.d.ts +22 -0
  118. package/lib/components/monkey-security-level/monkey-security-level.component.d.ts +7 -2
  119. package/lib/components/monkey-select/index.d.ts +1 -0
  120. package/lib/components/monkey-select/monkey-select.component.d.ts +74 -0
  121. package/lib/components/monkey-status/monkey-status.component.d.ts +8 -3
  122. package/lib/components/monkey-table/components/pagination-action/pagination-action.d.ts +17 -0
  123. package/lib/components/monkey-table/components/pagination-label/pagination-label.d.ts +10 -0
  124. package/lib/components/monkey-table/components/pagination-size/pagination-size.d.ts +15 -0
  125. package/lib/components/monkey-table/directives/column-checked.d.ts +32 -0
  126. package/lib/components/monkey-table/directives/column-expansible.d.ts +25 -0
  127. package/lib/components/monkey-table/directives/column-sortable.d.ts +24 -0
  128. package/lib/components/monkey-table/directives/column-stick.d.ts +6 -0
  129. package/lib/components/monkey-table/index.d.ts +9 -0
  130. package/lib/components/monkey-table/table.d.ts +32 -0
  131. package/lib/components/monkey-table/table.module.d.ts +15 -0
  132. package/lib/components/monkey-toast/index.d.ts +1 -0
  133. package/lib/components/monkey-toast/monkey-toast.component.d.ts +26 -0
  134. package/lib/components/monkey-toggle/monkey-toggle.component.d.ts +6 -1
  135. package/lib/components/monkey-toggle-line/index.d.ts +2 -0
  136. package/lib/components/monkey-toggle-line/monkey-toggle-line-button/index.d.ts +1 -0
  137. package/lib/components/monkey-toggle-line/monkey-toggle-line-button/monkey-toggle-line-button.component.d.ts +16 -0
  138. package/lib/components/monkey-toggle-line/monkey-toggle-line.component.d.ts +24 -0
  139. package/lib/components/monkey-tooltip/index.d.ts +2 -0
  140. package/lib/components/monkey-tooltip/monkey-tooltip.directive.d.ts +30 -0
  141. package/lib/components/monkey-tooltip/tooltip/index.d.ts +1 -0
  142. package/lib/components/monkey-tooltip/tooltip/tooltip.component.d.ts +19 -0
  143. package/lib/directives/error.d.ts +5 -0
  144. package/lib/directives/helper.d.ts +5 -0
  145. package/lib/directives/index.d.ts +7 -0
  146. package/lib/directives/info.d.ts +5 -0
  147. package/lib/directives/label.d.ts +5 -0
  148. package/lib/directives/module.d.ts +12 -0
  149. package/lib/directives/prefix.d.ts +5 -0
  150. package/lib/directives/suffix.d.ts +9 -0
  151. package/lib/interfaces/alert.d.ts +1 -0
  152. package/lib/interfaces/breadcrumb.d.ts +5 -0
  153. package/lib/interfaces/button.d.ts +1 -0
  154. package/lib/interfaces/index.d.ts +6 -0
  155. package/lib/interfaces/sizes.d.ts +1 -0
  156. package/lib/interfaces/table.d.ts +4 -0
  157. package/lib/interfaces/toast.d.ts +22 -0
  158. package/lib/services/index.d.ts +3 -0
  159. package/lib/services/monkey-destroy.service.d.ts +8 -0
  160. package/lib/services/monkey-icons.service.d.ts +14 -0
  161. package/lib/services/monkey-toast.service.d.ts +13 -0
  162. package/monkey-style-guide-v2-0.0.6.tgz +0 -0
  163. package/package.json +10 -3
  164. package/public-api.d.ts +5 -2
  165. package/utils/id-generator.d.ts +6 -0
  166. package/utils/index.d.ts +3 -0
  167. package/utils/tests-utils.d.ts +1 -0
  168. package/utils/utils.d.ts +1 -0
  169. package/monkey-style-guide-v2-0.0.4.tgz +0 -0
@@ -0,0 +1,352 @@
1
+ /** ************************
2
+ * Copyright Monkey Exchange. All Rights Reserved
3
+ * This style guide was developed by Monkey Exchange Team
4
+ * MIT Licence
5
+ ************************* */
6
+ import { animate, state, style, transition, trigger } from '@angular/animations';
7
+ import { TemplatePortal } from '@angular/cdk/portal';
8
+ import { booleanAttribute, ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, inject, Input, Optional, Output, ViewChild, ViewEncapsulation } from '@angular/core';
9
+ import { FormsModule, NgControl, ReactiveFormsModule, Validators } from '@angular/forms';
10
+ import { Subject, takeUntil } from 'rxjs';
11
+ import { IdGenerator } from '../../../utils/id-generator';
12
+ import { MonkeyDestroyService } from '../../services/monkey-destroy.service';
13
+ import { MonkeyIconsService } from '../../services/monkey-icons.service';
14
+ import { MonkeyFormFieldControl } from '../monkey-form-field/form-field-control';
15
+ import { MonkeyOptionComponent } from '../monkey-option/monkey-option.component';
16
+ import * as i0 from "@angular/core";
17
+ import * as i1 from "@angular/cdk/overlay";
18
+ import * as i2 from "../monkey-form-field/form-field";
19
+ export class MonkeySelectComponent {
20
+ get disabled() {
21
+ if (this.ngControl && this.ngControl.disabled !== null) {
22
+ return this.ngControl.disabled;
23
+ }
24
+ return this._disabled;
25
+ }
26
+ set disabled(value) {
27
+ this._disabled = value;
28
+ if (this.focused) {
29
+ this.focused = false;
30
+ this.stateChanges.next();
31
+ }
32
+ }
33
+ get required() {
34
+ return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;
35
+ }
36
+ set required(value) {
37
+ this._required = value;
38
+ this.stateChanges.next();
39
+ }
40
+ set value(value) {
41
+ if (this._value !== value) {
42
+ this._value = value;
43
+ this._onChange(value);
44
+ }
45
+ }
46
+ get value() {
47
+ return this._value;
48
+ }
49
+ constructor(overlay, changeDetectorRef, viewContainerRef, formField) {
50
+ this.overlay = overlay;
51
+ this.changeDetectorRef = changeDetectorRef;
52
+ this.viewContainerRef = viewContainerRef;
53
+ this.formField = formField;
54
+ this.tabIndex = 0;
55
+ this.onChange = new EventEmitter();
56
+ this.placeholder = '';
57
+ this.loading = false;
58
+ this._value = null;
59
+ this.labelSelected = '';
60
+ this.overlayRef = null;
61
+ this.isOpen = false;
62
+ this._destroyed = inject(MonkeyDestroyService);
63
+ this.iconArrowDown = inject(MonkeyIconsService).arrowDown;
64
+ this.idGenerator = inject(IdGenerator);
65
+ this.ngControl = inject(NgControl, { self: true, optional: true });
66
+ this._elementRef = inject(ElementRef);
67
+ this.currency = false;
68
+ this.focused = false;
69
+ this._disabled = false;
70
+ this.id = this.idGenerator.getId('monkey-select-');
71
+ this.percent = false;
72
+ this.stateChanges = new Subject();
73
+ this.type = '';
74
+ this.onAnimationEnd = (event) => {
75
+ if (event.toState === 'closed') {
76
+ this.closeOverlay();
77
+ }
78
+ };
79
+ this._onChange = () => { };
80
+ this._onTouched = () => { };
81
+ if (this.ngControl) {
82
+ this.ngControl.valueAccessor = this;
83
+ }
84
+ }
85
+ changeControl() {
86
+ if (this.formField?.control) {
87
+ this.formField.control.loading = this.loading;
88
+ }
89
+ }
90
+ changeSelected() {
91
+ setTimeout(() => {
92
+ if (this.options) {
93
+ this.options.forEach((opt) => {
94
+ opt.selected = opt.value === this.value;
95
+ });
96
+ this.updateSelectedLabel();
97
+ }
98
+ this.changeDetectorRef.markForCheck();
99
+ });
100
+ }
101
+ initializeOptions() {
102
+ this.options.forEach((option) => {
103
+ if (!option.action) {
104
+ option.action = this.selectOption.bind(this, option);
105
+ }
106
+ });
107
+ }
108
+ ngAfterContentInit() {
109
+ this.initializeOptions();
110
+ this.options.changes.subscribe((resp) => {
111
+ this.updateSelectedLabel();
112
+ this.initializeOptions();
113
+ this.changeSelected();
114
+ });
115
+ }
116
+ ngOnDestroy() {
117
+ if (this.overlayRef) {
118
+ this.overlayRef.dispose();
119
+ }
120
+ }
121
+ toggleDropdown() {
122
+ if (!this.disabled) {
123
+ if (this.isOpen) {
124
+ this.closeDropdown();
125
+ this._onTouched();
126
+ }
127
+ else {
128
+ this.openDropdown();
129
+ }
130
+ }
131
+ }
132
+ openDropdown() {
133
+ if (this.options?.length) {
134
+ this.formField.control.disableToBeDirty = true;
135
+ this.isOpen = true;
136
+ this.createOverlay();
137
+ }
138
+ }
139
+ closeDropdown() {
140
+ this.changeDetectorRef.markForCheck();
141
+ this.isOpen = false;
142
+ this.focused = false;
143
+ this.formField.control.disableToBeDirty = false;
144
+ }
145
+ closeOverlay() {
146
+ if (this.overlayRef) {
147
+ this.overlayRef.dispose();
148
+ this.overlayRef = null;
149
+ }
150
+ }
151
+ createOverlay() {
152
+ if (this.overlayRef) {
153
+ return;
154
+ }
155
+ const offset = 4;
156
+ const positions = [
157
+ {
158
+ originX: 'start',
159
+ originY: 'bottom',
160
+ overlayX: 'start',
161
+ overlayY: 'top',
162
+ offsetY: offset
163
+ },
164
+ {
165
+ originX: 'start',
166
+ originY: 'top',
167
+ overlayX: 'start',
168
+ overlayY: 'bottom',
169
+ offsetY: -offset
170
+ }
171
+ ];
172
+ let anchor = this.trigger;
173
+ let width = anchor.nativeElement.offsetWidth;
174
+ if (this.formField?.elementRef) {
175
+ const el = this.formField?.elementRef.nativeElement.querySelector('.mecx-form-field-body');
176
+ anchor = el;
177
+ width = el.offsetWidth;
178
+ }
179
+ const positionStrategy = this.overlay
180
+ .position()
181
+ .flexibleConnectedTo(anchor)
182
+ .withPositions(positions)
183
+ .withPush(true);
184
+ this.overlayRef = this.overlay.create({
185
+ positionStrategy,
186
+ scrollStrategy: this.overlay.scrollStrategies.block(),
187
+ width,
188
+ hasBackdrop: true,
189
+ backdropClass: 'no-class'
190
+ });
191
+ const portal = new TemplatePortal(this.overlayTemplate, this.viewContainerRef);
192
+ this.overlayRef.attach(portal);
193
+ this.overlayRef
194
+ .backdropClick()
195
+ .pipe(takeUntil(this._destroyed))
196
+ .subscribe(() => {
197
+ return this.closeDropdown();
198
+ });
199
+ }
200
+ selectOption(option) {
201
+ if (!option.disabled && !this.disabled) {
202
+ this.value = option.value;
203
+ this.updateSelectedLabel();
204
+ this.closeDropdown();
205
+ this._onChange(this.value);
206
+ this.onChange.emit(this.value);
207
+ this.options.forEach((opt) => {
208
+ opt.selected = opt.value === this.value;
209
+ });
210
+ }
211
+ }
212
+ updateSelectedLabel() {
213
+ const selectedOption = this.options.find((opt) => {
214
+ return opt.value === this.value;
215
+ });
216
+ this.labelSelected = selectedOption ? selectedOption.displayContent : '';
217
+ }
218
+ writeValue(value) {
219
+ this.value = value;
220
+ this.changeSelected();
221
+ }
222
+ onContainerClick(event) {
223
+ if (this.disabled)
224
+ return;
225
+ this.openDropdown();
226
+ this._elementRef.nativeElement.focus();
227
+ }
228
+ _onFocus() {
229
+ if (!this.disabled) {
230
+ this.focused = true;
231
+ this._onTouched();
232
+ this.stateChanges.next();
233
+ }
234
+ }
235
+ _onBlur() {
236
+ this.focused = false;
237
+ this.stateChanges.next();
238
+ }
239
+ registerOnChange(fn) {
240
+ this._onChange = fn;
241
+ }
242
+ registerOnTouched(fn) {
243
+ this._onTouched = fn;
244
+ }
245
+ setDisabledState(isDisabled) {
246
+ this.disabled = isDisabled;
247
+ }
248
+ ngOnChanges(changes) {
249
+ let hasChanges = false;
250
+ // eslint-disable-next-line dot-notation
251
+ const changesLoading = changes?.['loading'];
252
+ if (changesLoading?.currentValue !== changesLoading?.previousValue) {
253
+ hasChanges = true;
254
+ this.changeControl();
255
+ }
256
+ if (hasChanges) {
257
+ this.stateChanges.next();
258
+ }
259
+ }
260
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeySelectComponent, deps: [{ token: i1.Overlay }, { token: i0.ChangeDetectorRef }, { token: i0.ViewContainerRef }, { token: i2.MonkeyFormFieldComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
261
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MonkeySelectComponent, isStandalone: true, selector: "monkey-select", inputs: { tabIndex: "tabIndex", placeholder: "placeholder", loading: ["loading", "loading", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute], required: ["required", "required", booleanAttribute], value: "value" }, outputs: { onChange: "onChange" }, host: { attributes: { "data-testid": "monkey-select" }, listeners: { "focus": "_onFocus()", "blur": "_onBlur()" }, properties: { "class.mecx-select-disabled": "_disabled", "class.mecx-select-focused": "focused", "attr.id": "id", "attr.tabindex": "disabled ? -1 : tabIndex" }, classAttribute: "mecx-select" }, providers: [
262
+ // eslint-disable-next-line no-use-before-define
263
+ { provide: MonkeyFormFieldControl, useExisting: MonkeySelectComponent },
264
+ MonkeyDestroyService
265
+ ], queries: [{ propertyName: "options", predicate: MonkeyOptionComponent }], viewQueries: [{ propertyName: "overlayTemplate", first: true, predicate: ["overlayTemplate"], descendants: true }, { propertyName: "overlayEl", first: true, predicate: ["overlay"], descendants: true }, { propertyName: "trigger", first: true, predicate: ["trigger"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"mecx-select-trigger\"\n [class.open]=\"isOpen\"\n (click)=\"toggleDropdown()\"\n role=\"combobox\"\n [attr.aria-expanded]=\"isOpen\"\n #trigger\n>\n <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n <span>{{ labelSelected || placeholder }}</span>\n </div>\n\n @if (!loading) {\n <div class=\"mecx-select-icon\" [innerHTML]=\"iconArrowDown\"></div>\n }\n</div>\n\n<ng-template #overlayTemplate>\n <div\n class=\"mecx-select-overlay\"\n #overlay\n [@animation]=\"isOpen ? 'open' : 'closed'\"\n (@animation.done)=\"onAnimationEnd($event)\"\n >\n <ng-content />\n </div>\n</ng-template>\n", styles: ["monkey-select{display:inline-flex;width:100%;min-width:0;position:relative}monkey-select:focus-visible,monkey-select:focus{outline:none}.mecx-select-trigger{width:100%;display:inline-flex;align-items:center;cursor:pointer;gap:8px;box-sizing:border-box}.mecx-select-trigger .mecx-select-value{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--mecx-color-gray-500);font-size:14px;line-height:24px;letter-spacing:.42px}.mecx-select-trigger .mecx-select-value.has-value{color:var(--mecx-color-gray-900)}.mecx-select-trigger .mecx-select-icon{display:flex;transition:all .2s ease-in-out}.mecx-select-trigger .mecx-select-icon svg *{stroke:var(--mecx-color-theme-main)}.mecx-select-disabled .mecx-select-trigger{background-color:var(--mecx-color-gray-50);border-color:var(--mecx-color-gray-50);cursor:default}.mecx-select-disabled .mecx-select-trigger .mecx-select-value{color:var(--mecx-color-gray-400)}.mecx-select-disabled .mecx-select-trigger .mecx-select-icon svg *{stroke:var(--mecx-color-gray-400)}.mecx-select-trigger.open .mecx-select-icon{transform:rotate(180deg)}.mecx-select-overlay{width:100%;background:#fff;border:2px solid var(--mecx-color-gray-400);overflow:hidden auto;border-radius:8px;box-shadow:0 16px 32px #d6d6d694;max-height:360px}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: FormsModule }], animations: [
266
+ trigger('animation', [
267
+ transition(':enter', [
268
+ style({
269
+ opacity: 0,
270
+ transform: 'scaleY(.9)'
271
+ }),
272
+ animate('100ms ease-in-out', style({
273
+ opacity: 1,
274
+ transform: 'scaleY(1)'
275
+ }))
276
+ ]),
277
+ state('closed', style({
278
+ transform: 'scaleY(.9)',
279
+ opacity: 0
280
+ })),
281
+ transition('closed <=> open', animate('200ms ease-in-out'))
282
+ ])
283
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
284
+ }
285
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeySelectComponent, decorators: [{
286
+ type: Component,
287
+ args: [{ selector: 'monkey-select', standalone: true, imports: [ReactiveFormsModule, FormsModule], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
288
+ // eslint-disable-next-line no-use-before-define
289
+ { provide: MonkeyFormFieldControl, useExisting: MonkeySelectComponent },
290
+ MonkeyDestroyService
291
+ ], animations: [
292
+ trigger('animation', [
293
+ transition(':enter', [
294
+ style({
295
+ opacity: 0,
296
+ transform: 'scaleY(.9)'
297
+ }),
298
+ animate('100ms ease-in-out', style({
299
+ opacity: 1,
300
+ transform: 'scaleY(1)'
301
+ }))
302
+ ]),
303
+ state('closed', style({
304
+ transform: 'scaleY(.9)',
305
+ opacity: 0
306
+ })),
307
+ transition('closed <=> open', animate('200ms ease-in-out'))
308
+ ])
309
+ ], host: {
310
+ 'data-testid': 'monkey-select',
311
+ class: 'mecx-select',
312
+ '[class.mecx-select-disabled]': '_disabled',
313
+ '[class.mecx-select-focused]': 'focused',
314
+ '[attr.id]': 'id',
315
+ '[attr.tabindex]': 'disabled ? -1 : tabIndex',
316
+ '(focus)': '_onFocus()',
317
+ '(blur)': '_onBlur()'
318
+ }, template: "<div\n class=\"mecx-select-trigger\"\n [class.open]=\"isOpen\"\n (click)=\"toggleDropdown()\"\n role=\"combobox\"\n [attr.aria-expanded]=\"isOpen\"\n #trigger\n>\n <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n <span>{{ labelSelected || placeholder }}</span>\n </div>\n\n @if (!loading) {\n <div class=\"mecx-select-icon\" [innerHTML]=\"iconArrowDown\"></div>\n }\n</div>\n\n<ng-template #overlayTemplate>\n <div\n class=\"mecx-select-overlay\"\n #overlay\n [@animation]=\"isOpen ? 'open' : 'closed'\"\n (@animation.done)=\"onAnimationEnd($event)\"\n >\n <ng-content />\n </div>\n</ng-template>\n", styles: ["monkey-select{display:inline-flex;width:100%;min-width:0;position:relative}monkey-select:focus-visible,monkey-select:focus{outline:none}.mecx-select-trigger{width:100%;display:inline-flex;align-items:center;cursor:pointer;gap:8px;box-sizing:border-box}.mecx-select-trigger .mecx-select-value{flex-grow:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--mecx-color-gray-500);font-size:14px;line-height:24px;letter-spacing:.42px}.mecx-select-trigger .mecx-select-value.has-value{color:var(--mecx-color-gray-900)}.mecx-select-trigger .mecx-select-icon{display:flex;transition:all .2s ease-in-out}.mecx-select-trigger .mecx-select-icon svg *{stroke:var(--mecx-color-theme-main)}.mecx-select-disabled .mecx-select-trigger{background-color:var(--mecx-color-gray-50);border-color:var(--mecx-color-gray-50);cursor:default}.mecx-select-disabled .mecx-select-trigger .mecx-select-value{color:var(--mecx-color-gray-400)}.mecx-select-disabled .mecx-select-trigger .mecx-select-icon svg *{stroke:var(--mecx-color-gray-400)}.mecx-select-trigger.open .mecx-select-icon{transform:rotate(180deg)}.mecx-select-overlay{width:100%;background:#fff;border:2px solid var(--mecx-color-gray-400);overflow:hidden auto;border-radius:8px;box-shadow:0 16px 32px #d6d6d694;max-height:360px}\n"] }]
319
+ }], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.ChangeDetectorRef }, { type: i0.ViewContainerRef }, { type: i2.MonkeyFormFieldComponent, decorators: [{
320
+ type: Optional
321
+ }] }], propDecorators: { overlayTemplate: [{
322
+ type: ViewChild,
323
+ args: ['overlayTemplate']
324
+ }], overlayEl: [{
325
+ type: ViewChild,
326
+ args: ['overlay']
327
+ }], trigger: [{
328
+ type: ViewChild,
329
+ args: ['trigger']
330
+ }], options: [{
331
+ type: ContentChildren,
332
+ args: [MonkeyOptionComponent]
333
+ }], tabIndex: [{
334
+ type: Input
335
+ }], onChange: [{
336
+ type: Output
337
+ }], placeholder: [{
338
+ type: Input,
339
+ args: [{ required: true }]
340
+ }], loading: [{
341
+ type: Input,
342
+ args: [{ transform: booleanAttribute }]
343
+ }], disabled: [{
344
+ type: Input,
345
+ args: [{ transform: booleanAttribute }]
346
+ }], required: [{
347
+ type: Input,
348
+ args: [{ transform: booleanAttribute }]
349
+ }], value: [{
350
+ type: Input
351
+ }] } });
352
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monkey-select.component.js","sourceRoot":"","sources":["../../../../../../projects/monkey-style-guide-v2/src/lib/components/monkey-select/monkey-select.component.ts","../../../../../../projects/monkey-style-guide-v2/src/lib/components/monkey-select/monkey-select.component.html"],"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 { animate, state, style, transition, trigger } from '@angular/animations';\nimport { ConnectedPosition, Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport {\n  AfterContentInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NgControl,\n  ReactiveFormsModule,\n  Validators\n} from '@angular/forms';\nimport { Subject, takeUntil } from 'rxjs';\nimport { IdGenerator } from '../../../utils/id-generator';\nimport { MonkeyDestroyService } from '../../services/monkey-destroy.service';\nimport { MonkeyIconsService } from '../../services/monkey-icons.service';\nimport { MonkeyFormFieldComponent } from '../monkey-form-field/form-field';\nimport { MonkeyFormFieldControl } from '../monkey-form-field/form-field-control';\nimport { MonkeyOptionComponent } from '../monkey-option/monkey-option.component';\n\n@Component({\n  selector: 'monkey-select',\n  standalone: true,\n  imports: [ReactiveFormsModule, FormsModule],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: 'monkey-select.component.html',\n  styleUrls: ['./monkey-select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    // eslint-disable-next-line no-use-before-define\n    { provide: MonkeyFormFieldControl, useExisting: MonkeySelectComponent },\n    MonkeyDestroyService\n  ],\n  animations: [\n    trigger('animation', [\n      transition(':enter', [\n        style({\n          opacity: 0,\n          transform: 'scaleY(.9)'\n        }),\n        animate(\n          '100ms ease-in-out',\n          style({\n            opacity: 1,\n            transform: 'scaleY(1)'\n          })\n        )\n      ]),\n      state(\n        'closed',\n        style({\n          transform: 'scaleY(.9)',\n          opacity: 0\n        })\n      ),\n      transition('closed <=> open', animate('200ms ease-in-out'))\n    ])\n  ],\n  host: {\n    'data-testid': 'monkey-select',\n    class: 'mecx-select',\n    '[class.mecx-select-disabled]': '_disabled',\n    '[class.mecx-select-focused]': 'focused',\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'disabled ? -1 : tabIndex',\n    '(focus)': '_onFocus()',\n    '(blur)': '_onBlur()'\n  }\n})\nexport class MonkeySelectComponent\n  implements MonkeyFormFieldControl, ControlValueAccessor, AfterContentInit, OnDestroy, OnChanges\n{\n  @ViewChild('overlayTemplate') overlayTemplate!: TemplateRef<any>;\n\n  @ViewChild('overlay') overlayEl!: ElementRef;\n\n  @ViewChild('trigger') trigger!: ElementRef;\n\n  @ContentChildren(MonkeyOptionComponent) options!: QueryList<MonkeyOptionComponent>;\n\n  @Input() tabIndex = 0;\n\n  @Output() onChange = new EventEmitter();\n\n  @Input({ required: true }) placeholder = '';\n\n  @Input({ transform: booleanAttribute })\n  loading = false;\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({ transform: booleanAttribute })\n  get required(): boolean {\n    return this._required ?? this.ngControl?.control?.hasValidator(Validators.required) ?? false;\n  }\n\n  set required(value: boolean) {\n    this._required = value;\n    this.stateChanges.next();\n  }\n\n  private _required: boolean | undefined;\n\n  @Input()\n  set value(value: any) {\n    if (this._value !== value) {\n      this._value = value;\n      this._onChange(value);\n    }\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  _value = null;\n\n  labelSelected = '';\n\n  private overlayRef: OverlayRef | null = null;\n\n  isOpen = false;\n\n  private _destroyed = inject(MonkeyDestroyService);\n\n  readonly iconArrowDown = inject(MonkeyIconsService).arrowDown;\n\n  private readonly idGenerator = inject(IdGenerator);\n\n  ngControl: NgControl | null = inject(NgControl, { self: true, optional: true })!;\n\n  protected _elementRef =\n    inject<ElementRef<HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement>>(ElementRef);\n\n  readonly currency: boolean = false;\n\n  focused: boolean = false;\n\n  _disabled: boolean = false;\n\n  readonly id: string = this.idGenerator.getId('monkey-select-');\n\n  readonly percent: boolean = false;\n\n  readonly stateChanges = new Subject<void>();\n\n  readonly type: string = '';\n\n  constructor(\n    private overlay: Overlay,\n    private changeDetectorRef: ChangeDetectorRef,\n    private viewContainerRef: ViewContainerRef,\n    @Optional() private formField: MonkeyFormFieldComponent\n  ) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  private changeControl() {\n    if (this.formField?.control) {\n      this.formField.control.loading = this.loading;\n    }\n  }\n\n  private changeSelected() {\n    setTimeout(() => {\n      if (this.options) {\n        this.options.forEach((opt) => {\n          opt.selected = opt.value === this.value;\n        });\n        this.updateSelectedLabel();\n      }\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n\n  private initializeOptions() {\n    this.options.forEach((option) => {\n      if (!option.action) {\n        option.action = this.selectOption.bind(this, option);\n      }\n    });\n  }\n\n  ngAfterContentInit() {\n    this.initializeOptions();\n    this.options.changes.subscribe((resp) => {\n      this.updateSelectedLabel();\n      this.initializeOptions();\n      this.changeSelected();\n    });\n  }\n\n  ngOnDestroy() {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n    }\n  }\n\n  toggleDropdown(): void {\n    if (!this.disabled) {\n      if (this.isOpen) {\n        this.closeDropdown();\n        this._onTouched();\n      } else {\n        this.openDropdown();\n      }\n    }\n  }\n\n  private openDropdown(): void {\n    if (this.options?.length) {\n      this.formField.control.disableToBeDirty = true;\n      this.isOpen = true;\n      this.createOverlay();\n    }\n  }\n\n  private closeDropdown() {\n    this.changeDetectorRef.markForCheck();\n    this.isOpen = false;\n    this.focused = false;\n    this.formField.control.disableToBeDirty = false;\n  }\n\n  private closeOverlay(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n      this.overlayRef = null;\n    }\n  }\n\n  onAnimationEnd = (event: any) => {\n    if (event.toState === 'closed') {\n      this.closeOverlay();\n    }\n  };\n\n  private createOverlay(): void {\n    if (this.overlayRef) {\n      return;\n    }\n\n    const offset = 4;\n    const positions: ConnectedPosition[] = [\n      {\n        originX: 'start',\n        originY: 'bottom',\n        overlayX: 'start',\n        overlayY: 'top',\n        offsetY: offset\n      },\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'bottom',\n        offsetY: -offset\n      }\n    ];\n\n    let anchor = this.trigger;\n    let width = anchor.nativeElement.offsetWidth;\n\n    if (this.formField?.elementRef) {\n      const el = this.formField?.elementRef.nativeElement.querySelector('.mecx-form-field-body');\n      anchor = el;\n      width = el.offsetWidth;\n    }\n\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(anchor)\n      .withPositions(positions)\n      .withPush(true);\n\n    this.overlayRef = this.overlay.create({\n      positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n      width,\n      hasBackdrop: true,\n      backdropClass: 'no-class'\n    });\n\n    const portal = new TemplatePortal(this.overlayTemplate, this.viewContainerRef);\n\n    this.overlayRef.attach(portal);\n\n    this.overlayRef\n      .backdropClick()\n      .pipe(takeUntil(this._destroyed))\n      .subscribe(() => {\n        return this.closeDropdown();\n      });\n  }\n\n  selectOption(option: MonkeyOptionComponent): void {\n    if (!option.disabled && !this.disabled) {\n      this.value = option.value;\n      this.updateSelectedLabel();\n      this.closeDropdown();\n      this._onChange(this.value);\n      this.onChange.emit(this.value);\n\n      this.options.forEach((opt) => {\n        opt.selected = opt.value === this.value;\n      });\n    }\n  }\n\n  private updateSelectedLabel(): void {\n    const selectedOption = this.options.find((opt) => {\n      return opt.value === this.value;\n    });\n    this.labelSelected = selectedOption ? selectedOption.displayContent : '';\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.changeSelected();\n  }\n\n  onContainerClick(event: MouseEvent): void {\n    if (this.disabled) return;\n\n    this.openDropdown();\n    this._elementRef.nativeElement.focus();\n  }\n\n  _onFocus() {\n    if (!this.disabled) {\n      this.focused = true;\n      this._onTouched();\n      this.stateChanges.next();\n    }\n  }\n\n  _onBlur() {\n    this.focused = false;\n    this.stateChanges.next();\n  }\n\n  _onChange: any = () => {};\n\n  _onTouched: any = () => {};\n\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    let hasChanges = false;\n    // eslint-disable-next-line dot-notation\n    const changesLoading = changes?.['loading'];\n    if (changesLoading?.currentValue !== changesLoading?.previousValue) {\n      hasChanges = true;\n      this.changeControl();\n    }\n\n    if (hasChanges) {\n      this.stateChanges.next();\n    }\n  }\n}\n","<div\n  class=\"mecx-select-trigger\"\n  [class.open]=\"isOpen\"\n  (click)=\"toggleDropdown()\"\n  role=\"combobox\"\n  [attr.aria-expanded]=\"isOpen\"\n  #trigger\n>\n  <div class=\"mecx-select-value\" [class.has-value]=\"value\">\n    <span>{{ labelSelected || placeholder }}</span>\n  </div>\n\n  @if (!loading) {\n    <div class=\"mecx-select-icon\" [innerHTML]=\"iconArrowDown\"></div>\n  }\n</div>\n\n<ng-template #overlayTemplate>\n  <div\n    class=\"mecx-select-overlay\"\n    #overlay\n    [@animation]=\"isOpen ? 'open' : 'closed'\"\n    (@animation.done)=\"onAnimationEnd($event)\"\n  >\n    <ng-content />\n  </div>\n</ng-template>\n"]}
@@ -1,29 +1,45 @@
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 } 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 MonkeyStatusComponent {
12
+ get class() {
13
+ return `${this.type()} ${this.size()}`;
14
+ }
15
+ get id() {
16
+ return this._id;
17
+ }
18
+ set id(value) {
19
+ this._id = value || this._uid;
20
+ }
11
21
  constructor() {
12
22
  this.type = input.required();
13
23
  this.size = input('md');
14
24
  this.label = input();
25
+ this._uid = inject(IdGenerator).getId('monkey-status-');
26
+ // eslint-disable-next-line no-self-assign
27
+ this.id = this.id;
15
28
  }
16
- get class() {
17
- return `${this.type()} ${this.size()}`;
18
- }
19
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: MonkeyStatusComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
20
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.2", type: MonkeyStatusComponent, isStandalone: true, selector: "monkey-status", inputs: { type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: true, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.class" } }, ngImport: i0, template: "<div class=\"status\"></div>\n<span *ngIf=\"label() as lb\">\n {{ lb }}\n</span>\n", styles: [":host{display:flex;align-items:center;gap:8px}:host span{color:#545a63;font-style:normal;font-weight:400;line-height:24px}:host .status{width:8px;height:8px;border-radius:50%;flex-shrink:0}:host.sm span{font-size:14px;letter-spacing:.42px}:host.sm .status{height:8px;width:8px}:host.md span{font-size:16px;letter-spacing:.48px}:host.md .status{height:12px;width:12px}:host.lg span{font-size:18px;letter-spacing:.52px}:host.lg .status{height:16px;width:16px}:host.default .status{background-color:#d3d6da}:host.success .status{background-color:#00875a}:host.warning .status{background-color:#efa30e}:host.error .status{background-color:#db0505}:host.question .status{background-color:#8d38fa}:host.info .status{background-color:#003687}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyStatusComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: MonkeyStatusComponent, isStandalone: true, selector: "monkey-status", inputs: { type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: true, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: false, isRequired: false, transformFunction: null } }, host: { attributes: { "data-testid": "monkey-status" }, properties: { "attr.id": "id", "id": "id", "class": "this.class" } }, ngImport: i0, template: "<div class=\"status\"></div>\n<span *ngIf=\"label() as lb\">\n {{ lb }}\n</span>\n", styles: [":host{display:flex;align-items:center;gap:8px}:host span{color:#545a63;font-style:normal;font-weight:400;line-height:24px}:host .status{width:8px;height:8px;border-radius:50%;flex-shrink:0}:host.sm span{font-size:14px;letter-spacing:.42px}:host.sm .status{height:8px;width:8px}:host.md span{font-size:16px;letter-spacing:.48px}:host.md .status{height:12px;width:12px}:host.lg span{font-size:18px;letter-spacing:.52px}:host.lg .status{height:16px;width:16px}:host.default .status{background-color:#d3d6da}:host.success .status{background-color:#00875a}:host.warning .status{background-color:#efa30e}:host.error .status{background-color:#db0505}:host.question .status{background-color:#8d38fa}:host.info .status{background-color:#003687}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
21
31
  }
22
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: MonkeyStatusComponent, decorators: [{
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyStatusComponent, decorators: [{
23
33
  type: Component,
24
- args: [{ selector: 'monkey-status', standalone: true, imports: [CommonModule], template: "<div class=\"status\"></div>\n<span *ngIf=\"label() as lb\">\n {{ lb }}\n</span>\n", styles: [":host{display:flex;align-items:center;gap:8px}:host span{color:#545a63;font-style:normal;font-weight:400;line-height:24px}:host .status{width:8px;height:8px;border-radius:50%;flex-shrink:0}:host.sm span{font-size:14px;letter-spacing:.42px}:host.sm .status{height:8px;width:8px}:host.md span{font-size:16px;letter-spacing:.48px}:host.md .status{height:12px;width:12px}:host.lg span{font-size:18px;letter-spacing:.52px}:host.lg .status{height:16px;width:16px}:host.default .status{background-color:#d3d6da}:host.success .status{background-color:#00875a}:host.warning .status{background-color:#efa30e}:host.error .status{background-color:#db0505}:host.question .status{background-color:#8d38fa}:host.info .status{background-color:#003687}\n"] }]
25
- }], propDecorators: { class: [{
34
+ args: [{ selector: 'monkey-status', standalone: true, imports: [CommonModule], host: {
35
+ 'data-testid': 'monkey-status',
36
+ '[attr.id]': 'id',
37
+ '[id]': 'id'
38
+ }, template: "<div class=\"status\"></div>\n<span *ngIf=\"label() as lb\">\n {{ lb }}\n</span>\n", styles: [":host{display:flex;align-items:center;gap:8px}:host span{color:#545a63;font-style:normal;font-weight:400;line-height:24px}:host .status{width:8px;height:8px;border-radius:50%;flex-shrink:0}:host.sm span{font-size:14px;letter-spacing:.42px}:host.sm .status{height:8px;width:8px}:host.md span{font-size:16px;letter-spacing:.48px}:host.md .status{height:12px;width:12px}:host.lg span{font-size:18px;letter-spacing:.52px}:host.lg .status{height:16px;width:16px}:host.default .status{background-color:#d3d6da}:host.success .status{background-color:#00875a}:host.warning .status{background-color:#efa30e}:host.error .status{background-color:#db0505}:host.question .status{background-color:#8d38fa}:host.info .status{background-color:#003687}\n"] }]
39
+ }], ctorParameters: () => [], propDecorators: { class: [{
26
40
  type: HostBinding,
27
41
  args: ['class']
42
+ }], id: [{
43
+ type: Input
28
44
  }] } });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5LXN0YXR1cy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1zdGF0dXMvbW9ua2V5LXN0YXR1cy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1zdGF0dXMvbW9ua2V5LXN0YXR1cy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs0QkFJNEI7QUFDNUIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBWTlELE1BQU0sT0FBTyxxQkFBcUI7SUFQbEM7UUFRRSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ2hDLFNBQUksR0FBRyxLQUFLLENBQU8sSUFBSSxDQUFDLENBQUM7UUFDekIsVUFBSyxHQUFHLEtBQUssRUFBVSxDQUFDO0tBTXpCO0lBSkMsSUFDVyxLQUFLO1FBQ2QsT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQztJQUN6QyxDQUFDOzhHQVJVLHFCQUFxQjtrR0FBckIscUJBQXFCLHVlQ2xCbEMscUZBSUEsMHhCRFVZLFlBQVk7OzJGQUlYLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDRSxlQUFlLGNBQ2IsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDOzhCQVVaLEtBQUs7c0JBRGYsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiLyoqKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBDb3B5cmlnaHQgTW9ua2V5IEV4Y2hhbmdlLiBBbGwgUmlnaHRzIFJlc2VydmVkXG4gKiBUaGlzIHN0eWxlIGd1aWRlIHdhcyBkZXZlbG9wZWQgYnkgTW9ua2V5IEV4Y2hhbmdlIFRlYW1cbiAqIE1JVCBMaWNlbmNlXG4gKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0QmluZGluZywgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxudHlwZSBTdGF0dXMgPSAnZGVmYXVsdCcgfCAnc3VjY2VzcycgfCAnd2FybmluZycgfCAnZXJyb3InIHwgJ3F1ZXN0aW9uJyB8ICdpbmZvJztcbnR5cGUgU2l6ZSA9ICdtZCcgfCAnc20nIHwgJ2xnJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbW9ua2V5LXN0YXR1cycsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vbW9ua2V5LXN0YXR1cy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9tb25rZXktc3RhdHVzLmNvbXBvbmVudC5zY3NzJ1xufSlcbmV4cG9ydCBjbGFzcyBNb25rZXlTdGF0dXNDb21wb25lbnQge1xuICB0eXBlID0gaW5wdXQucmVxdWlyZWQ8U3RhdHVzPigpO1xuICBzaXplID0gaW5wdXQ8U2l6ZT4oJ21kJyk7XG4gIGxhYmVsID0gaW5wdXQ8c3RyaW5nPigpO1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBwdWJsaWMgZ2V0IGNsYXNzKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke3RoaXMudHlwZSgpfSAke3RoaXMuc2l6ZSgpfWA7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJzdGF0dXNcIj48L2Rpdj5cbjxzcGFuICpuZ0lmPVwibGFiZWwoKSBhcyBsYlwiPlxuICB7eyBsYiB9fVxuPC9zcGFuPlxuIl19
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9ua2V5LXN0YXR1cy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1zdGF0dXMvbW9ua2V5LXN0YXR1cy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS1zdGF0dXMvbW9ua2V5LXN0YXR1cy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs2QkFJNkI7QUFDN0IsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBaUI3QyxNQUFNLE9BQU8scUJBQXFCO0lBT2hDLElBQ1csS0FBSztRQUNkLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxFQUFFLENBQUM7SUFDekMsQ0FBQztJQU1ELElBQ0ksRUFBRTtRQUNKLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQztJQUNsQixDQUFDO0lBRUQsSUFBSSxFQUFFLENBQUMsS0FBYTtRQUNsQixJQUFJLENBQUMsR0FBRyxHQUFHLEtBQUssSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ2hDLENBQUM7SUFFRDtRQXhCQSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBRWhDLFNBQUksR0FBRyxLQUFLLENBQWEsSUFBSSxDQUFDLENBQUM7UUFFL0IsVUFBSyxHQUFHLEtBQUssRUFBVSxDQUFDO1FBT2QsU0FBSSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxLQUFLLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQWMzRCwwQ0FBMEM7UUFDMUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDO0lBQ3BCLENBQUM7K0dBNUJVLHFCQUFxQjttR0FBckIscUJBQXFCLG9xQkN4QmxDLHFGQUlBLDB4QkRXWSxZQUFZOzs0RkFTWCxxQkFBcUI7a0JBWmpDLFNBQVM7K0JBQ0UsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxRQUdqQjt3QkFDSixhQUFhLEVBQUUsZUFBZTt3QkFDOUIsV0FBVyxFQUFFLElBQUk7d0JBQ2pCLE1BQU0sRUFBRSxJQUFJO3FCQUNiO3dEQVVVLEtBQUs7c0JBRGYsV0FBVzt1QkFBQyxPQUFPO2dCQVVoQixFQUFFO3NCQURMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBDb3B5cmlnaHQgTW9ua2V5IEV4Y2hhbmdlLiBBbGwgUmlnaHRzIFJlc2VydmVkXG4gKiBUaGlzIHN0eWxlIGd1aWRlIHdhcyBkZXZlbG9wZWQgYnkgTW9ua2V5IEV4Y2hhbmdlIFRlYW1cbiAqIE1JVCBMaWNlbmNlXG4gKioqKioqKioqKioqKioqKioqKioqKioqKiAqL1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIGluamVjdCwgSW5wdXQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJZEdlbmVyYXRvciB9IGZyb20gJy4uLy4uLy4uL3V0aWxzJztcbmltcG9ydCB7IE1vbmtleVNpemUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxudHlwZSBTdGF0dXMgPSAnZGVmYXVsdCcgfCAnc3VjY2VzcycgfCAnd2FybmluZycgfCAnZXJyb3InIHwgJ3F1ZXN0aW9uJyB8ICdpbmZvJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbW9ua2V5LXN0YXR1cycsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vbW9ua2V5LXN0YXR1cy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9tb25rZXktc3RhdHVzLmNvbXBvbmVudC5zY3NzJyxcbiAgaG9zdDoge1xuICAgICdkYXRhLXRlc3RpZCc6ICdtb25rZXktc3RhdHVzJyxcbiAgICAnW2F0dHIuaWRdJzogJ2lkJyxcbiAgICAnW2lkXSc6ICdpZCdcbiAgfVxufSlcbmV4cG9ydCBjbGFzcyBNb25rZXlTdGF0dXNDb21wb25lbnQge1xuICB0eXBlID0gaW5wdXQucmVxdWlyZWQ8U3RhdHVzPigpO1xuXG4gIHNpemUgPSBpbnB1dDxNb25rZXlTaXplPignbWQnKTtcblxuICBsYWJlbCA9IGlucHV0PHN0cmluZz4oKTtcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcbiAgcHVibGljIGdldCBjbGFzcygpOiBzdHJpbmcge1xuICAgIHJldHVybiBgJHt0aGlzLnR5cGUoKX0gJHt0aGlzLnNpemUoKX1gO1xuICB9XG5cbiAgcHJvdGVjdGVkIF91aWQgPSBpbmplY3QoSWRHZW5lcmF0b3IpLmdldElkKCdtb25rZXktc3RhdHVzLScpO1xuXG4gIHByb3RlY3RlZCBfaWQhOiBzdHJpbmc7XG5cbiAgQElucHV0KClcbiAgZ2V0IGlkKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX2lkO1xuICB9XG5cbiAgc2V0IGlkKHZhbHVlOiBzdHJpbmcpIHtcbiAgICB0aGlzLl9pZCA9IHZhbHVlIHx8IHRoaXMuX3VpZDtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1zZWxmLWFzc2lnblxuICAgIHRoaXMuaWQgPSB0aGlzLmlkO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwic3RhdHVzXCI+PC9kaXY+XG48c3BhbiAqbmdJZj1cImxhYmVsKCkgYXMgbGJcIj5cbiAge3sgbGIgfX1cbjwvc3Bhbj5cbiJdfQ==
@@ -0,0 +1,53 @@
1
+ /** ************************
2
+ * Copyright Monkey Exchange. All Rights Reserved
3
+ * This style guide was developed by Monkey Exchange Team
4
+ * MIT Licence
5
+ ************************* */
6
+ import { CommonModule } from '@angular/common';
7
+ import { Component, EventEmitter, inject, Input, Output, ViewEncapsulation } from '@angular/core';
8
+ import { IdGenerator } from '../../../../../utils';
9
+ import { MonkeyButtonComponent } from '../../../monkey-button';
10
+ import * as i0 from "@angular/core";
11
+ export class MonkeyPaginationActionComponent {
12
+ get id() {
13
+ return this._id;
14
+ }
15
+ set id(value) {
16
+ this._id = value || this._uid;
17
+ }
18
+ constructor() {
19
+ this.next = false;
20
+ this.prev = false;
21
+ this.onAction = new EventEmitter();
22
+ this._uid = inject(IdGenerator).getId('monkey-pagination-action-');
23
+ // eslint-disable-next-line no-self-assign
24
+ this.id = this.id;
25
+ }
26
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyPaginationActionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
27
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MonkeyPaginationActionComponent, isStandalone: true, selector: "monkey-pagination-action", inputs: { disabled: "disabled", first: "first", last: "last", next: "next", prev: "prev", id: "id" }, outputs: { onAction: "onAction" }, host: { attributes: { "data-testid": "monkey-pagination-action" }, properties: { "attr.id": "id", "id": "id" } }, exportAs: ["monkeyPaginationAction"], ngImport: i0, template: "<monkey-button\n type=\"secondary\"\n size=\"sm\"\n (click)=\"onAction.next('prev')\"\n [disabled]=\"disabled || !prev\"\n>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M11.670 8.630 C 9.335 10.964,8.550 11.772,8.523 11.870 C 8.501 11.947,8.501 12.053,8.523 12.130 C 8.574 12.316,14.682 18.423,14.870 18.477 C 15.231 18.581,15.581 18.231,15.477 17.869 C 15.450 17.774,14.687 16.987,12.570 14.870 L 9.700 12.000 12.570 9.130 C 14.687 7.013,15.450 6.226,15.477 6.131 C 15.528 5.951,15.464 5.747,15.316 5.623 C 15.219 5.541,15.151 5.520,14.988 5.520 L 14.781 5.520 11.670 8.630 \"\n stroke=\"none\"\n fill-rule=\"evenodd\"\n fill=\"black\"\n ></path>\n </svg>\n</monkey-button>\n\n<monkey-button\n type=\"secondary\"\n size=\"sm\"\n (click)=\"onAction.next('next')\"\n [disabled]=\"disabled || !next\"\n>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M8.751 5.583 C 8.552 5.691,8.459 6.004,8.564 6.213 C 8.588 6.261,9.889 7.583,11.454 9.150 L 14.300 12.000 11.454 14.850 C 9.889 16.418,8.588 17.739,8.564 17.787 C 8.357 18.197,8.823 18.640,9.232 18.423 C 9.363 18.353,15.373 12.337,15.436 12.213 C 15.497 12.092,15.491 11.897,15.423 11.768 C 15.353 11.637,9.337 5.627,9.213 5.564 C 9.092 5.503,8.881 5.512,8.751 5.583 \"\n stroke=\"none\"\n fill-rule=\"evenodd\"\n fill=\"black\"\n ></path>\n </svg>\n</monkey-button>\n", styles: ["monkey-pagination-action{display:flex;align-items:center;gap:8px}monkey-pagination-action monkey-button .mecx-button .content{padding:unset}monkey-pagination-action monkey-button .mecx-button .content span{display:flex;height:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: MonkeyButtonComponent, selector: "monkey-button", inputs: ["disabled", "size", "type", "id"] }], encapsulation: i0.ViewEncapsulation.None }); }
28
+ }
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyPaginationActionComponent, decorators: [{
30
+ type: Component,
31
+ args: [{ standalone: true, imports: [CommonModule, MonkeyButtonComponent], encapsulation: ViewEncapsulation.None, selector: 'monkey-pagination-action', exportAs: 'monkeyPaginationAction', host: {
32
+ 'data-testid': 'monkey-pagination-action',
33
+ '[attr.id]': 'id',
34
+ '[id]': 'id'
35
+ }, template: "<monkey-button\n type=\"secondary\"\n size=\"sm\"\n (click)=\"onAction.next('prev')\"\n [disabled]=\"disabled || !prev\"\n>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M11.670 8.630 C 9.335 10.964,8.550 11.772,8.523 11.870 C 8.501 11.947,8.501 12.053,8.523 12.130 C 8.574 12.316,14.682 18.423,14.870 18.477 C 15.231 18.581,15.581 18.231,15.477 17.869 C 15.450 17.774,14.687 16.987,12.570 14.870 L 9.700 12.000 12.570 9.130 C 14.687 7.013,15.450 6.226,15.477 6.131 C 15.528 5.951,15.464 5.747,15.316 5.623 C 15.219 5.541,15.151 5.520,14.988 5.520 L 14.781 5.520 11.670 8.630 \"\n stroke=\"none\"\n fill-rule=\"evenodd\"\n fill=\"black\"\n ></path>\n </svg>\n</monkey-button>\n\n<monkey-button\n type=\"secondary\"\n size=\"sm\"\n (click)=\"onAction.next('next')\"\n [disabled]=\"disabled || !next\"\n>\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M8.751 5.583 C 8.552 5.691,8.459 6.004,8.564 6.213 C 8.588 6.261,9.889 7.583,11.454 9.150 L 14.300 12.000 11.454 14.850 C 9.889 16.418,8.588 17.739,8.564 17.787 C 8.357 18.197,8.823 18.640,9.232 18.423 C 9.363 18.353,15.373 12.337,15.436 12.213 C 15.497 12.092,15.491 11.897,15.423 11.768 C 15.353 11.637,9.337 5.627,9.213 5.564 C 9.092 5.503,8.881 5.512,8.751 5.583 \"\n stroke=\"none\"\n fill-rule=\"evenodd\"\n fill=\"black\"\n ></path>\n </svg>\n</monkey-button>\n", styles: ["monkey-pagination-action{display:flex;align-items:center;gap:8px}monkey-pagination-action monkey-button .mecx-button .content{padding:unset}monkey-pagination-action monkey-button .mecx-button .content span{display:flex;height:100%}\n"] }]
36
+ }], ctorParameters: () => [], propDecorators: { disabled: [{
37
+ type: Input
38
+ }], first: [{
39
+ type: Input
40
+ }], last: [{
41
+ type: Input
42
+ }], next: [{
43
+ type: Input,
44
+ args: [{ required: true }]
45
+ }], prev: [{
46
+ type: Input,
47
+ args: [{ required: true }]
48
+ }], onAction: [{
49
+ type: Output
50
+ }], id: [{
51
+ type: Input
52
+ }] } });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi1hY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktc3R5bGUtZ3VpZGUtdjIvc3JjL2xpYi9jb21wb25lbnRzL21vbmtleS10YWJsZS9jb21wb25lbnRzL3BhZ2luYXRpb24tYWN0aW9uL3BhZ2luYXRpb24tYWN0aW9uLnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LXN0eWxlLWd1aWRlLXYyL3NyYy9saWIvY29tcG9uZW50cy9tb25rZXktdGFibGUvY29tcG9uZW50cy9wYWdpbmF0aW9uLWFjdGlvbi9wYWdpbmF0aW9uLWFjdGlvbi5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OzZCQUk2QjtBQUU3QixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEcsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQWdCL0QsTUFBTSxPQUFPLCtCQUErQjtJQWlCMUMsSUFDSSxFQUFFO1FBQ0osT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQ2xCLENBQUM7SUFFRCxJQUFJLEVBQUUsQ0FBQyxLQUFhO1FBQ2xCLElBQUksQ0FBQyxHQUFHLEdBQUcsS0FBSyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDaEMsQ0FBQztJQUVEO1FBbkIyQixTQUFJLEdBQVksS0FBSyxDQUFDO1FBRXRCLFNBQUksR0FBWSxLQUFLLENBQUM7UUFFdkMsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFFOUIsU0FBSSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxLQUFLLENBQUMsMkJBQTJCLENBQUMsQ0FBQztRQWN0RSwwQ0FBMEM7UUFDMUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDO0lBQ3BCLENBQUM7K0dBN0JVLCtCQUErQjttR0FBL0IsK0JBQStCLHFYQ3pCNUMsKy9DQStCQSxrU0RsQlksWUFBWSwrQkFBRSxxQkFBcUI7OzRGQVlsQywrQkFBK0I7a0JBZDNDLFNBQVM7aUNBQ0ksSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLHFCQUFxQixDQUFDLGlCQUMvQixpQkFBaUIsQ0FBQyxJQUFJLFlBQzNCLDBCQUEwQixZQUMxQix3QkFBd0IsUUFHNUI7d0JBQ0osYUFBYSxFQUFFLDBCQUEwQjt3QkFDekMsV0FBVyxFQUFFLElBQUk7d0JBQ2pCLE1BQU0sRUFBRSxJQUFJO3FCQUNiO3dEQUdRLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUVHLElBQUk7c0JBQVosS0FBSztnQkFFcUIsSUFBSTtzQkFBOUIsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUU7Z0JBRUUsSUFBSTtzQkFBOUIsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUU7Z0JBRWYsUUFBUTtzQkFBakIsTUFBTTtnQkFPSCxFQUFFO3NCQURMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBDb3B5cmlnaHQgTW9ua2V5IEV4Y2hhbmdlLiBBbGwgUmlnaHRzIFJlc2VydmVkXG4gKiBUaGlzIHN0eWxlIGd1aWRlIHdhcyBkZXZlbG9wZWQgYnkgTW9ua2V5IEV4Y2hhbmdlIFRlYW1cbiAqIE1JVCBMaWNlbmNlXG4gKioqKioqKioqKioqKioqKioqKioqKioqKiAqL1xuXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIGluamVjdCwgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElkR2VuZXJhdG9yIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vdXRpbHMnO1xuaW1wb3J0IHsgTW9ua2V5QnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vbW9ua2V5LWJ1dHRvbic7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBNb25rZXlCdXR0b25Db21wb25lbnRdLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBzZWxlY3RvcjogJ21vbmtleS1wYWdpbmF0aW9uLWFjdGlvbicsXG4gIGV4cG9ydEFzOiAnbW9ua2V5UGFnaW5hdGlvbkFjdGlvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9wYWdpbmF0aW9uLWFjdGlvbi5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL3BhZ2luYXRpb24tYWN0aW9uLnNjc3MnLFxuICBob3N0OiB7XG4gICAgJ2RhdGEtdGVzdGlkJzogJ21vbmtleS1wYWdpbmF0aW9uLWFjdGlvbicsXG4gICAgJ1thdHRyLmlkXSc6ICdpZCcsXG4gICAgJ1tpZF0nOiAnaWQnXG4gIH1cbn0pXG5leHBvcnQgY2xhc3MgTW9ua2V5UGFnaW5hdGlvbkFjdGlvbkNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGRpc2FibGVkITogYm9vbGVhbjtcblxuICBASW5wdXQoKSBmaXJzdCE6IGJvb2xlYW47XG5cbiAgQElucHV0KCkgbGFzdCE6IGJvb2xlYW47XG5cbiAgQElucHV0KHsgcmVxdWlyZWQ6IHRydWUgfSkgbmV4dDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIHByZXY6IGJvb2xlYW4gPSBmYWxzZTtcblxuICBAT3V0cHV0KCkgb25BY3Rpb24gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgcHJvdGVjdGVkIF91aWQgPSBpbmplY3QoSWRHZW5lcmF0b3IpLmdldElkKCdtb25rZXktcGFnaW5hdGlvbi1hY3Rpb24tJyk7XG5cbiAgcHJvdGVjdGVkIF9pZCE6IHN0cmluZztcblxuICBASW5wdXQoKVxuICBnZXQgaWQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5faWQ7XG4gIH1cblxuICBzZXQgaWQodmFsdWU6IHN0cmluZykge1xuICAgIHRoaXMuX2lkID0gdmFsdWUgfHwgdGhpcy5fdWlkO1xuICB9XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXNlbGYtYXNzaWduXG4gICAgdGhpcy5pZCA9IHRoaXMuaWQ7XG4gIH1cbn1cbiIsIjxtb25rZXktYnV0dG9uXG4gIHR5cGU9XCJzZWNvbmRhcnlcIlxuICBzaXplPVwic21cIlxuICAoY2xpY2spPVwib25BY3Rpb24ubmV4dCgncHJldicpXCJcbiAgW2Rpc2FibGVkXT1cImRpc2FibGVkIHx8ICFwcmV2XCJcbj5cbiAgPHN2ZyB3aWR0aD1cIjI0XCIgaGVpZ2h0PVwiMjRcIiB2aWV3Qm94PVwiMCAwIDI0IDI0XCIgZmlsbD1cIm5vbmVcIiB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCI+XG4gICAgPHBhdGhcbiAgICAgIGQ9XCJNMTEuNjcwIDguNjMwIEMgOS4zMzUgMTAuOTY0LDguNTUwIDExLjc3Miw4LjUyMyAxMS44NzAgQyA4LjUwMSAxMS45NDcsOC41MDEgMTIuMDUzLDguNTIzIDEyLjEzMCBDIDguNTc0IDEyLjMxNiwxNC42ODIgMTguNDIzLDE0Ljg3MCAxOC40NzcgQyAxNS4yMzEgMTguNTgxLDE1LjU4MSAxOC4yMzEsMTUuNDc3IDE3Ljg2OSBDIDE1LjQ1MCAxNy43NzQsMTQuNjg3IDE2Ljk4NywxMi41NzAgMTQuODcwIEwgOS43MDAgMTIuMDAwIDEyLjU3MCA5LjEzMCBDIDE0LjY4NyA3LjAxMywxNS40NTAgNi4yMjYsMTUuNDc3IDYuMTMxIEMgMTUuNTI4IDUuOTUxLDE1LjQ2NCA1Ljc0NywxNS4zMTYgNS42MjMgQyAxNS4yMTkgNS41NDEsMTUuMTUxIDUuNTIwLDE0Ljk4OCA1LjUyMCBMIDE0Ljc4MSA1LjUyMCAxMS42NzAgOC42MzAgXCJcbiAgICAgIHN0cm9rZT1cIm5vbmVcIlxuICAgICAgZmlsbC1ydWxlPVwiZXZlbm9kZFwiXG4gICAgICBmaWxsPVwiYmxhY2tcIlxuICAgID48L3BhdGg+XG4gIDwvc3ZnPlxuPC9tb25rZXktYnV0dG9uPlxuXG48bW9ua2V5LWJ1dHRvblxuICB0eXBlPVwic2Vjb25kYXJ5XCJcbiAgc2l6ZT1cInNtXCJcbiAgKGNsaWNrKT1cIm9uQWN0aW9uLm5leHQoJ25leHQnKVwiXG4gIFtkaXNhYmxlZF09XCJkaXNhYmxlZCB8fCAhbmV4dFwiXG4+XG4gIDxzdmcgd2lkdGg9XCIyNFwiIGhlaWdodD1cIjI0XCIgdmlld0JveD1cIjAgMCAyNCAyNFwiIGZpbGw9XCJub25lXCIgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiPlxuICAgIDxwYXRoXG4gICAgICBkPVwiTTguNzUxIDUuNTgzIEMgOC41NTIgNS42OTEsOC40NTkgNi4wMDQsOC41NjQgNi4yMTMgQyA4LjU4OCA2LjI2MSw5Ljg4OSA3LjU4MywxMS40NTQgOS4xNTAgTCAxNC4zMDAgMTIuMDAwIDExLjQ1NCAxNC44NTAgQyA5Ljg4OSAxNi40MTgsOC41ODggMTcuNzM5LDguNTY0IDE3Ljc4NyBDIDguMzU3IDE4LjE5Nyw4LjgyMyAxOC42NDAsOS4yMzIgMTguNDIzIEMgOS4zNjMgMTguMzUzLDE1LjM3MyAxMi4zMzcsMTUuNDM2IDEyLjIxMyBDIDE1LjQ5NyAxMi4wOTIsMTUuNDkxIDExLjg5NywxNS40MjMgMTEuNzY4IEMgMTUuMzUzIDExLjYzNyw5LjMzNyA1LjYyNyw5LjIxMyA1LjU2NCBDIDkuMDkyIDUuNTAzLDguODgxIDUuNTEyLDguNzUxIDUuNTgzIFwiXG4gICAgICBzdHJva2U9XCJub25lXCJcbiAgICAgIGZpbGwtcnVsZT1cImV2ZW5vZGRcIlxuICAgICAgZmlsbD1cImJsYWNrXCJcbiAgICA+PC9wYXRoPlxuICA8L3N2Zz5cbjwvbW9ua2V5LWJ1dHRvbj5cbiJdfQ==
@@ -0,0 +1,34 @@
1
+ /** ************************
2
+ * Copyright Monkey Exchange. All Rights Reserved
3
+ * This style guide was developed by Monkey Exchange Team
4
+ * MIT Licence
5
+ ************************* */
6
+ import { Component, inject, Input, ViewEncapsulation } from '@angular/core';
7
+ import { IdGenerator } from '../../../../../utils';
8
+ import * as i0 from "@angular/core";
9
+ export class MonkeyPaginationLabelComponent {
10
+ get id() {
11
+ return this._id;
12
+ }
13
+ set id(value) {
14
+ this._id = value || this._uid;
15
+ }
16
+ constructor() {
17
+ this._uid = inject(IdGenerator).getId('monkey-pagination-label-');
18
+ // eslint-disable-next-line no-self-assign
19
+ this.id = this.id;
20
+ }
21
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyPaginationLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
22
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MonkeyPaginationLabelComponent, isStandalone: true, selector: "monkey-pagination-label", inputs: { id: "id" }, host: { attributes: { "data-testid": "monkey-pagination-label" }, properties: { "attr.id": "id", "id": "id" } }, exportAs: ["monkeyPaginationLabel"], ngImport: i0, template: "<ng-content></ng-content>\n", styles: ["monkey-pagination-label{font-size:12px}\n"], encapsulation: i0.ViewEncapsulation.None }); }
23
+ }
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MonkeyPaginationLabelComponent, decorators: [{
25
+ type: Component,
26
+ args: [{ standalone: true, encapsulation: ViewEncapsulation.None, selector: 'monkey-pagination-label', exportAs: 'monkeyPaginationLabel', host: {
27
+ 'data-testid': 'monkey-pagination-label',
28
+ '[attr.id]': 'id',
29
+ '[id]': 'id'
30
+ }, template: "<ng-content></ng-content>\n", styles: ["monkey-pagination-label{font-size:12px}\n"] }]
31
+ }], ctorParameters: () => [], propDecorators: { id: [{
32
+ type: Input
33
+ }] } });
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnaW5hdGlvbi1sYWJlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1zdHlsZS1ndWlkZS12Mi9zcmMvbGliL2NvbXBvbmVudHMvbW9ua2V5LXRhYmxlL2NvbXBvbmVudHMvcGFnaW5hdGlvbi1sYWJlbC9wYWdpbmF0aW9uLWxhYmVsLnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LXN0eWxlLWd1aWRlLXYyL3NyYy9saWIvY29tcG9uZW50cy9tb25rZXktdGFibGUvY29tcG9uZW50cy9wYWdpbmF0aW9uLWxhYmVsL3BhZ2luYXRpb24tbGFiZWwuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs2QkFJNkI7QUFFN0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFlbkQsTUFBTSxPQUFPLDhCQUE4QjtJQUt6QyxJQUNJLEVBQUU7UUFDSixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUM7SUFDbEIsQ0FBQztJQUVELElBQUksRUFBRSxDQUFDLEtBQWE7UUFDbEIsSUFBSSxDQUFDLEdBQUcsR0FBRyxLQUFLLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQztJQUNoQyxDQUFDO0lBRUQ7UUFiVSxTQUFJLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO1FBY3JFLDBDQUEwQztRQUMxQyxJQUFJLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDcEIsQ0FBQzsrR0FqQlUsOEJBQThCO21HQUE5Qiw4QkFBOEIsK1BDdEIzQyw2QkFDQTs7NEZEcUJhLDhCQUE4QjtrQkFiMUMsU0FBUztpQ0FDSSxJQUFJLGlCQUNELGlCQUFpQixDQUFDLElBQUksWUFDM0IseUJBQXlCLFlBQ3pCLHVCQUF1QixRQUczQjt3QkFDSixhQUFhLEVBQUUseUJBQXlCO3dCQUN4QyxXQUFXLEVBQUUsSUFBSTt3QkFDakIsTUFBTSxFQUFFLElBQUk7cUJBQ2I7d0RBUUcsRUFBRTtzQkFETCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLyoqICoqKioqKioqKioqKioqKioqKioqKioqKlxuICogQ29weXJpZ2h0IE1vbmtleSBFeGNoYW5nZS4gQWxsIFJpZ2h0cyBSZXNlcnZlZFxuICogVGhpcyBzdHlsZSBndWlkZSB3YXMgZGV2ZWxvcGVkIGJ5IE1vbmtleSBFeGNoYW5nZSBUZWFtXG4gKiBNSVQgTGljZW5jZVxuICoqKioqKioqKioqKioqKioqKioqKioqKiogKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWRHZW5lcmF0b3IgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi91dGlscyc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBzZWxlY3RvcjogJ21vbmtleS1wYWdpbmF0aW9uLWxhYmVsJyxcbiAgZXhwb3J0QXM6ICdtb25rZXlQYWdpbmF0aW9uTGFiZWwnLFxuICB0ZW1wbGF0ZVVybDogJy4vcGFnaW5hdGlvbi1sYWJlbC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL3BhZ2luYXRpb24tbGFiZWwuc2NzcycsXG4gIGhvc3Q6IHtcbiAgICAnZGF0YS10ZXN0aWQnOiAnbW9ua2V5LXBhZ2luYXRpb24tbGFiZWwnLFxuICAgICdbYXR0ci5pZF0nOiAnaWQnLFxuICAgICdbaWRdJzogJ2lkJ1xuICB9XG59KVxuZXhwb3J0IGNsYXNzIE1vbmtleVBhZ2luYXRpb25MYWJlbENvbXBvbmVudCB7XG4gIHByb3RlY3RlZCBfdWlkID0gaW5qZWN0KElkR2VuZXJhdG9yKS5nZXRJZCgnbW9ua2V5LXBhZ2luYXRpb24tbGFiZWwtJyk7XG5cbiAgcHJvdGVjdGVkIF9pZCE6IHN0cmluZztcblxuICBASW5wdXQoKVxuICBnZXQgaWQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5faWQ7XG4gIH1cblxuICBzZXQgaWQodmFsdWU6IHN0cmluZykge1xuICAgIHRoaXMuX2lkID0gdmFsdWUgfHwgdGhpcy5fdWlkO1xuICB9XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXNlbGYtYXNzaWduXG4gICAgdGhpcy5pZCA9IHRoaXMuaWQ7XG4gIH1cbn1cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==