@taiga-ui/legacy 4.9.0 → 4.11.0

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 (136) hide show
  1. package/classes/control.d.ts +1 -1
  2. package/components/combo-box/combo-box.component.d.ts +2 -1
  3. package/components/input-phone/input-phone.component.d.ts +2 -1
  4. package/components/input-phone-international/input-phone-international.component.d.ts +2 -1
  5. package/components/input-tag/input-tag.component.d.ts +2 -1
  6. package/components/input-time/input-time.component.d.ts +2 -1
  7. package/components/multi-select/multi-select.component.d.ts +6 -1
  8. package/components/select/select.component.d.ts +2 -1
  9. package/esm2022/classes/control.mjs +5 -5
  10. package/esm2022/components/arrow/arrow.component.mjs +3 -4
  11. package/esm2022/components/color-selector/color-edit/color-edit.component.mjs +3 -5
  12. package/esm2022/components/color-selector/color-picker/color-picker.component.mjs +3 -5
  13. package/esm2022/components/color-selector/color-selector.component.mjs +3 -5
  14. package/esm2022/components/color-selector/flat-picker/flat-picker.component.mjs +3 -5
  15. package/esm2022/components/color-selector/linear-multi-picker/linear-multi-picker.component.mjs +2 -3
  16. package/esm2022/components/color-selector/linear-picker/linear-picker.component.mjs +3 -5
  17. package/esm2022/components/color-selector/palette/palette.component.mjs +3 -5
  18. package/esm2022/components/combo-box/combo-box.component.mjs +11 -13
  19. package/esm2022/components/input/input.component.mjs +6 -8
  20. package/esm2022/components/input-color/input-color.component.mjs +3 -4
  21. package/esm2022/components/input-copy/input-copy.component.mjs +4 -5
  22. package/esm2022/components/input-date/input-date.component.mjs +4 -5
  23. package/esm2022/components/input-date-multi/input-date-multi.component.mjs +4 -5
  24. package/esm2022/components/input-date-range/input-date-range.component.mjs +4 -5
  25. package/esm2022/components/input-date-time/input-date-time.component.mjs +4 -5
  26. package/esm2022/components/input-date-time/input-date-time.directive.mjs +2 -2
  27. package/esm2022/components/input-month/input-month.component.mjs +4 -5
  28. package/esm2022/components/input-month-range/input-month-range.component.mjs +4 -5
  29. package/esm2022/components/input-number/input-number.component.mjs +4 -5
  30. package/esm2022/components/input-password/input-password.component.mjs +4 -5
  31. package/esm2022/components/input-phone/input-phone.component.mjs +10 -12
  32. package/esm2022/components/input-phone-international/input-phone-international.component.mjs +11 -12
  33. package/esm2022/components/input-range/input-range.component.mjs +4 -5
  34. package/esm2022/components/input-slider/input-slider.component.mjs +4 -5
  35. package/esm2022/components/input-tag/input-tag.component.mjs +22 -20
  36. package/esm2022/components/input-time/input-time.component.mjs +14 -15
  37. package/esm2022/components/input-time/native-time/native-time.component.mjs +2 -3
  38. package/esm2022/components/input-year/input-year.component.mjs +4 -5
  39. package/esm2022/components/multi-select/multi-select-group/multi-select-group.component.mjs +2 -3
  40. package/esm2022/components/multi-select/multi-select.component.mjs +42 -15
  41. package/esm2022/components/multi-select/native-multi-select/native-multi-select-group.component.mjs +2 -3
  42. package/esm2022/components/multi-select/native-multi-select/native-multi-select.component.mjs +2 -3
  43. package/esm2022/components/multi-select-option/multi-select-option.component.mjs +3 -5
  44. package/esm2022/components/primitive-textfield/primitive-textfield.component.mjs +4 -5
  45. package/esm2022/components/primitive-textfield/textfield/textfield.component.mjs +2 -3
  46. package/esm2022/components/primitive-textfield/value-decoration/value-decoration.component.mjs +2 -3
  47. package/esm2022/components/select/native-select/native-select-group.component.mjs +2 -3
  48. package/esm2022/components/select/native-select/native-select.component.mjs +2 -3
  49. package/esm2022/components/select/select.component.mjs +11 -13
  50. package/esm2022/components/select-option/select-option.component.mjs +3 -5
  51. package/esm2022/components/sheet/components/sheet/sheet.component.mjs +2 -3
  52. package/esm2022/components/sheet/components/sheet-bar/sheet-bar.component.mjs +3 -5
  53. package/esm2022/components/sheet/components/sheet-heading/sheet-heading.component.mjs +3 -5
  54. package/esm2022/components/sheet/components/sheets-host/sheets-host.component.mjs +3 -5
  55. package/esm2022/components/svg/svg.component.mjs +3 -5
  56. package/esm2022/components/table-bar/table-bar.component.mjs +2 -3
  57. package/esm2022/components/table-bar/table-bars-host.component.mjs +3 -5
  58. package/esm2022/components/tag/tag.component.mjs +4 -5
  59. package/esm2022/components/textarea/textarea.component.mjs +4 -5
  60. package/esm2022/components/tooltip/tooltip.component.mjs +3 -4
  61. package/esm2022/tokens/is-apple.mjs +3 -3
  62. package/esm2022/utils/is-apple.mjs +3 -6
  63. package/fesm2022/taiga-ui-legacy-classes.mjs +4 -4
  64. package/fesm2022/taiga-ui-legacy-classes.mjs.map +1 -1
  65. package/fesm2022/taiga-ui-legacy-components-arrow.mjs +2 -3
  66. package/fesm2022/taiga-ui-legacy-components-arrow.mjs.map +1 -1
  67. package/fesm2022/taiga-ui-legacy-components-color-selector.mjs +13 -26
  68. package/fesm2022/taiga-ui-legacy-components-color-selector.mjs.map +1 -1
  69. package/fesm2022/taiga-ui-legacy-components-combo-box.mjs +13 -15
  70. package/fesm2022/taiga-ui-legacy-components-combo-box.mjs.map +1 -1
  71. package/fesm2022/taiga-ui-legacy-components-input-color.mjs +2 -3
  72. package/fesm2022/taiga-ui-legacy-components-input-color.mjs.map +1 -1
  73. package/fesm2022/taiga-ui-legacy-components-input-copy.mjs +3 -4
  74. package/fesm2022/taiga-ui-legacy-components-input-copy.mjs.map +1 -1
  75. package/fesm2022/taiga-ui-legacy-components-input-date-multi.mjs +3 -4
  76. package/fesm2022/taiga-ui-legacy-components-input-date-multi.mjs.map +1 -1
  77. package/fesm2022/taiga-ui-legacy-components-input-date-range.mjs +3 -4
  78. package/fesm2022/taiga-ui-legacy-components-input-date-range.mjs.map +1 -1
  79. package/fesm2022/taiga-ui-legacy-components-input-date-time.mjs +4 -5
  80. package/fesm2022/taiga-ui-legacy-components-input-date-time.mjs.map +1 -1
  81. package/fesm2022/taiga-ui-legacy-components-input-date.mjs +3 -4
  82. package/fesm2022/taiga-ui-legacy-components-input-date.mjs.map +1 -1
  83. package/fesm2022/taiga-ui-legacy-components-input-month-range.mjs +3 -4
  84. package/fesm2022/taiga-ui-legacy-components-input-month-range.mjs.map +1 -1
  85. package/fesm2022/taiga-ui-legacy-components-input-month.mjs +3 -4
  86. package/fesm2022/taiga-ui-legacy-components-input-month.mjs.map +1 -1
  87. package/fesm2022/taiga-ui-legacy-components-input-number.mjs +3 -4
  88. package/fesm2022/taiga-ui-legacy-components-input-number.mjs.map +1 -1
  89. package/fesm2022/taiga-ui-legacy-components-input-password.mjs +3 -4
  90. package/fesm2022/taiga-ui-legacy-components-input-password.mjs.map +1 -1
  91. package/fesm2022/taiga-ui-legacy-components-input-phone-international.mjs +10 -11
  92. package/fesm2022/taiga-ui-legacy-components-input-phone-international.mjs.map +1 -1
  93. package/fesm2022/taiga-ui-legacy-components-input-phone.mjs +12 -14
  94. package/fesm2022/taiga-ui-legacy-components-input-phone.mjs.map +1 -1
  95. package/fesm2022/taiga-ui-legacy-components-input-range.mjs +3 -4
  96. package/fesm2022/taiga-ui-legacy-components-input-range.mjs.map +1 -1
  97. package/fesm2022/taiga-ui-legacy-components-input-slider.mjs +3 -4
  98. package/fesm2022/taiga-ui-legacy-components-input-slider.mjs.map +1 -1
  99. package/fesm2022/taiga-ui-legacy-components-input-tag.mjs +23 -21
  100. package/fesm2022/taiga-ui-legacy-components-input-tag.mjs.map +1 -1
  101. package/fesm2022/taiga-ui-legacy-components-input-time.mjs +18 -21
  102. package/fesm2022/taiga-ui-legacy-components-input-time.mjs.map +1 -1
  103. package/fesm2022/taiga-ui-legacy-components-input-year.mjs +3 -4
  104. package/fesm2022/taiga-ui-legacy-components-input-year.mjs.map +1 -1
  105. package/fesm2022/taiga-ui-legacy-components-input.mjs +5 -7
  106. package/fesm2022/taiga-ui-legacy-components-input.mjs.map +1 -1
  107. package/fesm2022/taiga-ui-legacy-components-multi-select-option.mjs +2 -4
  108. package/fesm2022/taiga-ui-legacy-components-multi-select-option.mjs.map +1 -1
  109. package/fesm2022/taiga-ui-legacy-components-multi-select.mjs +51 -27
  110. package/fesm2022/taiga-ui-legacy-components-multi-select.mjs.map +1 -1
  111. package/fesm2022/taiga-ui-legacy-components-primitive-textfield.mjs +5 -8
  112. package/fesm2022/taiga-ui-legacy-components-primitive-textfield.mjs.map +1 -1
  113. package/fesm2022/taiga-ui-legacy-components-select-option.mjs +2 -4
  114. package/fesm2022/taiga-ui-legacy-components-select-option.mjs.map +1 -1
  115. package/fesm2022/taiga-ui-legacy-components-select.mjs +10 -14
  116. package/fesm2022/taiga-ui-legacy-components-select.mjs.map +1 -1
  117. package/fesm2022/taiga-ui-legacy-components-sheet.mjs +7 -14
  118. package/fesm2022/taiga-ui-legacy-components-sheet.mjs.map +1 -1
  119. package/fesm2022/taiga-ui-legacy-components-svg.mjs +2 -4
  120. package/fesm2022/taiga-ui-legacy-components-svg.mjs.map +1 -1
  121. package/fesm2022/taiga-ui-legacy-components-table-bar.mjs +3 -6
  122. package/fesm2022/taiga-ui-legacy-components-table-bar.mjs.map +1 -1
  123. package/fesm2022/taiga-ui-legacy-components-tag.mjs +3 -4
  124. package/fesm2022/taiga-ui-legacy-components-tag.mjs.map +1 -1
  125. package/fesm2022/taiga-ui-legacy-components-textarea.mjs +3 -4
  126. package/fesm2022/taiga-ui-legacy-components-textarea.mjs.map +1 -1
  127. package/fesm2022/taiga-ui-legacy-components-tooltip.mjs +2 -3
  128. package/fesm2022/taiga-ui-legacy-components-tooltip.mjs.map +1 -1
  129. package/fesm2022/taiga-ui-legacy-tokens.mjs +2 -2
  130. package/fesm2022/taiga-ui-legacy-tokens.mjs.map +1 -1
  131. package/fesm2022/taiga-ui-legacy-utils.mjs +2 -5
  132. package/fesm2022/taiga-ui-legacy-utils.mjs.map +1 -1
  133. package/package.json +25 -25
  134. package/styles/mixins/textfield.less +5 -1
  135. package/utils/icons-path-factory.d.ts +1 -1
  136. package/utils/is-apple.d.ts +2 -1
@@ -56,4 +56,4 @@ export declare abstract class AbstractTuiControl<T> extends AbstractTuiInteracti
56
56
  static ɵfac: i0.ɵɵFactoryDeclaration<AbstractTuiControl<any>, never>;
57
57
  static ɵdir: i0.ɵɵDirectiveDeclaration<AbstractTuiControl<any>, never, never, { "readOnly": { "alias": "readOnly"; "required": false; }; "pseudoInvalid": { "alias": "pseudoInvalid"; "required": false; }; }, {}, never, never, false, never>;
58
58
  }
59
- export declare function tuiAsControl<T>(control: Type<AbstractTuiControl<T>>): Provider;
59
+ export declare function tuiAsControl<T>(control: Type<AbstractTuiControl<T>>): Provider[];
@@ -8,6 +8,7 @@ import { AbstractTuiNullableControl } from '@taiga-ui/legacy/classes';
8
8
  import type { TuiFocusableElementAccessor } from '@taiga-ui/legacy/tokens';
9
9
  import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
10
10
  import * as i0 from "@angular/core";
11
+ import * as i1 from "@taiga-ui/core/directives/dropdown";
11
12
  export declare class TuiComboBoxComponent<T> extends AbstractTuiNullableControl<T> implements TuiFocusableElementAccessor, TuiDataListHost<T> {
12
13
  private readonly accessor?;
13
14
  private readonly dropdown?;
@@ -43,5 +44,5 @@ export declare class TuiComboBoxComponent<T> extends AbstractTuiNullableControl<
43
44
  private setNativeValue;
44
45
  private focusInput;
45
46
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiComboBoxComponent<any>, never>;
46
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiComboBoxComponent<any>, "tui-combo-box", never, { "stringify": { "alias": "stringify"; "required": false; }; "strictMatcher": { "alias": "strictMatcher"; "required": false; }; "identityMatcher": { "alias": "identityMatcher"; "required": false; }; "valueContent": { "alias": "valueContent"; "required": false; }; "strict": { "alias": "strict"; "required": false; }; "search": { "alias": "search"; "required": false; }; }, { "searchChange": "searchChange"; }, ["accessor", "datalist"], ["*", "input"], false, never>;
47
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiComboBoxComponent<any>, "tui-combo-box", never, { "stringify": { "alias": "stringify"; "required": false; }; "strictMatcher": { "alias": "strictMatcher"; "required": false; }; "identityMatcher": { "alias": "identityMatcher"; "required": false; }; "valueContent": { "alias": "valueContent"; "required": false; }; "strict": { "alias": "strict"; "required": false; }; "search": { "alias": "search"; "required": false; }; }, { "searchChange": "searchChange"; }, ["accessor", "datalist"], ["*", "input"], false, [{ directive: typeof i1.TuiDropdownFixed; inputs: {}; outputs: {}; }]>;
47
48
  }
@@ -7,6 +7,7 @@ import type { TuiSizeL, TuiSizeS } from '@taiga-ui/core/types';
7
7
  import { AbstractTuiControl } from '@taiga-ui/legacy/classes';
8
8
  import type { TuiFocusableElementAccessor } from '@taiga-ui/legacy/tokens';
9
9
  import * as i0 from "@angular/core";
10
+ import * as i1 from "@taiga-ui/core/directives/dropdown";
10
11
  export declare class TuiInputPhoneComponent extends AbstractTuiControl<string> implements TuiFocusableElementAccessor, TuiDataListHost<string> {
11
12
  private readonly dropdown?;
12
13
  private readonly textfield?;
@@ -44,5 +45,5 @@ export declare class TuiInputPhoneComponent extends AbstractTuiControl<string> i
44
45
  private updateSearch;
45
46
  private updateValueWithNewCountryCode;
46
47
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputPhoneComponent, never>;
47
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputPhoneComponent, "tui-input-phone", never, { "phoneMaskAfterCountryCode": { "alias": "phoneMaskAfterCountryCode"; "required": false; }; "allowText": { "alias": "allowText"; "required": false; }; "search": { "alias": "search"; "required": false; }; "countryCodeSetter": { "alias": "countryCode"; "required": false; }; }, { "searchChange": "searchChange"; }, ["datalist"], ["*", "input"], false, never>;
48
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputPhoneComponent, "tui-input-phone", never, { "phoneMaskAfterCountryCode": { "alias": "phoneMaskAfterCountryCode"; "required": false; }; "allowText": { "alias": "allowText"; "required": false; }; "search": { "alias": "search"; "required": false; }; "countryCodeSetter": { "alias": "countryCode"; "required": false; }; }, { "searchChange": "searchChange"; }, ["datalist"], ["*", "input"], false, [{ directive: typeof i1.TuiDropdownFixed; inputs: {}; outputs: {}; }]>;
48
49
  }
@@ -6,6 +6,7 @@ import { AbstractTuiControl } from '@taiga-ui/legacy/classes';
6
6
  import type { TuiFocusableElementAccessor } from '@taiga-ui/legacy/tokens';
7
7
  import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
8
8
  import * as i0 from "@angular/core";
9
+ import * as i1 from "@taiga-ui/core/directives/dropdown";
9
10
  /**
10
11
  * @deprecated: drop in v5.0 use {@link TuiInputPhoneInternational}
11
12
  * https://taiga-ui.dev/components/input-phone-international
@@ -38,5 +39,5 @@ export declare class TuiInputPhoneInternationalComponent extends AbstractTuiCont
38
39
  private close;
39
40
  private updateCountryIsoCode;
40
41
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputPhoneInternationalComponent, never>;
41
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputPhoneInternationalComponent, "tui-input-phone-international", never, { "countries": { "alias": "countries"; "required": false; }; "isoCode": { "alias": "countryIsoCode"; "required": false; }; }, { "countryIsoCodeChange": "countryIsoCodeChange"; }, never, ["*"], true, never>;
42
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputPhoneInternationalComponent, "tui-input-phone-international", never, { "countries": { "alias": "countries"; "required": false; }; "isoCode": { "alias": "countryIsoCode"; "required": false; }; }, { "countryIsoCodeChange": "countryIsoCodeChange"; }, never, ["*"], true, [{ directive: typeof i1.TuiDropdownFixed; inputs: {}; outputs: {}; }]>;
42
43
  }
@@ -10,6 +10,7 @@ import type { TuiFocusableElementAccessor } from '@taiga-ui/legacy/tokens';
10
10
  import type { TuiStatus } from '@taiga-ui/legacy/utils';
11
11
  import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
12
12
  import * as i0 from "@angular/core";
13
+ import * as i1 from "@taiga-ui/core/directives/dropdown";
13
14
  export declare class TuiInputTagComponent extends AbstractTuiMultipleControl<string> implements TuiFocusableElementAccessor, TuiDataListHost<string> {
14
15
  private readonly dropdown?;
15
16
  private readonly focusableElement?;
@@ -93,5 +94,5 @@ export declare class TuiInputTagComponent extends AbstractTuiMultipleControl<str
93
94
  private focusInput;
94
95
  private clippedValue;
95
96
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputTagComponent, never>;
96
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputTagComponent, "tui-input-tag", never, { "separator": { "alias": "separator"; "required": false; }; "search": { "alias": "search"; "required": false; }; "editable": { "alias": "editable"; "required": false; }; "tagValidator": { "alias": "tagValidator"; "required": false; }; "rows": { "alias": "rows"; "required": false; }; "inputHidden": { "alias": "inputHidden"; "required": false; }; "uniqueTags": { "alias": "uniqueTags"; "required": false; }; "autoColor": { "alias": "autoColor"; "required": false; }; "maxLength": { "alias": "maxLength"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "removable": { "alias": "removable"; "required": false; }; "pseudoOpen": { "alias": "pseudoOpen"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "pseudoFocusedSetter": { "alias": "pseudoFocused"; "required": false; }; }, { "searchChange": "searchChange"; }, ["datalist", "valueContent"], ["*", "tuiContent", "select"], false, never>;
97
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputTagComponent, "tui-input-tag", never, { "separator": { "alias": "separator"; "required": false; }; "search": { "alias": "search"; "required": false; }; "editable": { "alias": "editable"; "required": false; }; "tagValidator": { "alias": "tagValidator"; "required": false; }; "rows": { "alias": "rows"; "required": false; }; "inputHidden": { "alias": "inputHidden"; "required": false; }; "uniqueTags": { "alias": "uniqueTags"; "required": false; }; "autoColor": { "alias": "autoColor"; "required": false; }; "maxLength": { "alias": "maxLength"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "removable": { "alias": "removable"; "required": false; }; "pseudoOpen": { "alias": "pseudoOpen"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "pseudoFocusedSetter": { "alias": "pseudoFocused"; "required": false; }; }, { "searchChange": "searchChange"; }, ["datalist", "valueContent"], ["*", "tuiContent", "select"], false, [{ directive: typeof i1.TuiDropdownFixed; inputs: {}; outputs: {}; }]>;
97
98
  }
@@ -10,6 +10,7 @@ import type { TuiFocusableElementAccessor } from '@taiga-ui/legacy/tokens';
10
10
  import type { Observable } from 'rxjs';
11
11
  import type { TuiInputTimeOptions } from './input-time.options';
12
12
  import * as i0 from "@angular/core";
13
+ import * as i1 from "@taiga-ui/core/directives/dropdown";
13
14
  export declare class TuiInputTimeComponent extends AbstractTuiNullableControl<TuiTime> implements TuiFocusableElementAccessor, TuiDataListHost<TuiTime> {
14
15
  private readonly textfield?;
15
16
  private readonly timeTexts$;
@@ -60,5 +61,5 @@ export declare class TuiInputTimeComponent extends AbstractTuiNullableControl<Tu
60
61
  private shiftTime;
61
62
  private focusInput;
62
63
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiInputTimeComponent, never>;
63
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputTimeComponent, "tui-input-time", never, { "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "items": { "alias": "items"; "required": false; }; "itemSize": { "alias": "itemSize"; "required": false; }; "strict": { "alias": "strict"; "required": false; }; "mode": { "alias": "mode"; "required": false; }; }, {}, never, ["*"], false, never>;
64
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiInputTimeComponent, "tui-input-time", never, { "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "items": { "alias": "items"; "required": false; }; "itemSize": { "alias": "itemSize"; "required": false; }; "strict": { "alias": "strict"; "required": false; }; "mode": { "alias": "mode"; "required": false; }; }, {}, never, ["*"], false, [{ directive: typeof i1.TuiDropdownFixed; inputs: {}; outputs: {}; }]>;
64
65
  }
@@ -10,6 +10,7 @@ import type { TuiFocusableElementAccessor } from '@taiga-ui/legacy/tokens';
10
10
  import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
11
11
  import type { TuiMultiSelectOptions } from './multi-select.options';
12
12
  import * as i0 from "@angular/core";
13
+ import * as i1 from "@taiga-ui/core/directives/dropdown";
13
14
  export declare class TuiMultiSelectComponent<T> extends AbstractTuiMultipleControl<T> implements TuiFocusableElementAccessor, TuiDataListHost<T> {
14
15
  private readonly accessor?;
15
16
  private readonly nativeSelect?;
@@ -18,6 +19,7 @@ export declare class TuiMultiSelectComponent<T> extends AbstractTuiMultipleContr
18
19
  private readonly arrowMode;
19
20
  private readonly itemsHandlers;
20
21
  private readonly options;
22
+ private readonly inputTagOptions;
21
23
  protected readonly datalist: PolymorpheusContent<TuiContext<TuiActiveZone>>;
22
24
  protected open: boolean;
23
25
  protected readonly controller: import("@taiga-ui/legacy/directives").TuiTextfieldController;
@@ -57,10 +59,13 @@ export declare class TuiMultiSelectComponent<T> extends AbstractTuiMultipleContr
57
59
  ], TuiBooleanHandler<TuiStringifiableItem<T> | string>>;
58
60
  protected onSpace(event: Event): void;
59
61
  protected onEnter(event: Event): void;
62
+ protected onKeyDown(event: KeyboardEvent): void;
63
+ protected onPaste(event: Event): void;
60
64
  protected onClick({ nativeFocusableElement }: TuiInputTagComponent): void;
61
65
  protected onInput(value: ReadonlyArray<TuiStringifiableItem<T>>): void;
62
66
  protected onActiveZone(active: boolean): void;
67
+ private filterValue;
63
68
  private updateSearch;
64
69
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiMultiSelectComponent<any>, never>;
65
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiMultiSelectComponent<any>, "tui-multi-select", never, { "stringify": { "alias": "stringify"; "required": false; }; "identityMatcher": { "alias": "identityMatcher"; "required": false; }; "search": { "alias": "search"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "editable": { "alias": "editable"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "valueContent": { "alias": "valueContent"; "required": false; }; "tagValidator": { "alias": "tagValidator"; "required": false; }; "rows": { "alias": "rows"; "required": false; }; "autoColor": { "alias": "autoColor"; "required": false; }; }, { "searchChange": "searchChange"; }, ["accessor", "nativeSelect", "datalist"], ["*", "select"], false, never>;
70
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiMultiSelectComponent<any>, "tui-multi-select", never, { "stringify": { "alias": "stringify"; "required": false; }; "identityMatcher": { "alias": "identityMatcher"; "required": false; }; "search": { "alias": "search"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "editable": { "alias": "editable"; "required": false; }; "disabledItemHandler": { "alias": "disabledItemHandler"; "required": false; }; "valueContent": { "alias": "valueContent"; "required": false; }; "tagValidator": { "alias": "tagValidator"; "required": false; }; "rows": { "alias": "rows"; "required": false; }; "autoColor": { "alias": "autoColor"; "required": false; }; }, { "searchChange": "searchChange"; }, ["accessor", "nativeSelect", "datalist"], ["*", "select"], false, [{ directive: typeof i1.TuiDropdownFixed; inputs: {}; outputs: {}; }]>;
66
71
  }
@@ -8,6 +8,7 @@ import type { TuiFocusableElementAccessor } from '@taiga-ui/legacy/tokens';
8
8
  import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
9
9
  import type { TuiSelectOptions } from './select.options';
10
10
  import * as i0 from "@angular/core";
11
+ import * as i1 from "@taiga-ui/core/directives/dropdown";
11
12
  export declare class TuiSelectComponent<T> extends AbstractTuiNullableControl<T> implements TuiFocusableElementAccessor, TuiDataListHost<T> {
12
13
  private readonly textfield?;
13
14
  private readonly dropdown?;
@@ -36,5 +37,5 @@ export declare class TuiSelectComponent<T> extends AbstractTuiNullableControl<T>
36
37
  protected onKeyDownDelete(): void;
37
38
  private focusInput;
38
39
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiSelectComponent<any>, never>;
39
- static ɵcmp: i0.ɵɵComponentDeclaration<TuiSelectComponent<any>, "tui-select", never, { "stringify": { "alias": "stringify"; "required": false; }; "identityMatcher": { "alias": "identityMatcher"; "required": false; }; "valueContent": { "alias": "valueContent"; "required": false; }; }, {}, ["nativeSelect", "datalist"], ["*", "input", "select"], false, never>;
40
+ static ɵcmp: i0.ɵɵComponentDeclaration<TuiSelectComponent<any>, "tui-select", never, { "stringify": { "alias": "stringify"; "required": false; }; "identityMatcher": { "alias": "identityMatcher"; "required": false; }; "valueContent": { "alias": "valueContent"; "required": false; }; }, {}, ["nativeSelect", "datalist"], ["*", "input", "select"], false, [{ directive: typeof i1.TuiDropdownFixed; inputs: {}; outputs: {}; }]>;
40
41
  }
@@ -2,10 +2,10 @@
2
2
  import { ChangeDetectorRef, DestroyRef, Directive, inject, Input } from '@angular/core';
3
3
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
4
  import { NgControl, NgModel } from '@angular/forms';
5
- import { TuiValueTransformer } from '@taiga-ui/cdk/classes';
5
+ import { TuiControl, TuiValueTransformer } from '@taiga-ui/cdk/classes';
6
6
  import { EMPTY_FUNCTION } from '@taiga-ui/cdk/constants';
7
7
  import { tuiIsPresent, tuiProvide } from '@taiga-ui/cdk/utils/miscellaneous';
8
- import { delay, distinctUntilChanged, filter, map, merge, startWith, Subject, switchMap, } from 'rxjs';
8
+ import { delay, distinctUntilChanged, EMPTY, filter, map, merge, startWith, Subject, switchMap, } from 'rxjs';
9
9
  import { AbstractTuiInteractive } from './interactive';
10
10
  import * as i0 from "@angular/core";
11
11
  /**
@@ -73,7 +73,7 @@ class AbstractTuiControl extends AbstractTuiInteractive {
73
73
  }
74
74
  ngOnInit() {
75
75
  this.refresh$
76
- .pipe(delay(0), startWith(null), map(() => this.ngControl?.control), filter(tuiIsPresent), distinctUntilChanged(), switchMap((control) => merge(control.valueChanges, control.statusChanges)), takeUntilDestroyed(this.destroyRef))
76
+ .pipe(delay(0), startWith(null), map(() => this.ngControl?.control), filter(tuiIsPresent), distinctUntilChanged(), switchMap((control) => merge(control.valueChanges, control.statusChanges, control.events || EMPTY)), takeUntilDestroyed(this.destroyRef))
77
77
  .subscribe(() => {
78
78
  this.refreshLocalValue(this.safeCurrentValue);
79
79
  });
@@ -172,6 +172,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
172
172
  type: Input
173
173
  }] } });
174
174
  export function tuiAsControl(control) {
175
- return tuiProvide(AbstractTuiControl, control);
175
+ return [tuiProvide(AbstractTuiControl, control), tuiProvide(TuiControl, control)];
176
176
  }
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.js","sourceRoot":"","sources":["../../../../projects/legacy/classes/control.ts"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"@taiga-ui/tsconfig/ng-dev-mode\" />\nimport type {OnInit, Provider, Type} from '@angular/core';\nimport {ChangeDetectorRef, DestroyRef, Directive, inject, Input} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport type {AbstractControl, ControlValueAccessor} from '@angular/forms';\nimport {NgControl, NgModel} from '@angular/forms';\nimport {TuiValueTransformer} from '@taiga-ui/cdk/classes';\nimport {EMPTY_FUNCTION} from '@taiga-ui/cdk/constants';\nimport {tuiIsPresent, tuiProvide} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {\n    delay,\n    distinctUntilChanged,\n    filter,\n    map,\n    merge,\n    startWith,\n    Subject,\n    switchMap,\n} from 'rxjs';\n\nimport {AbstractTuiInteractive} from './interactive';\n\n/**\n * @deprecated: drop in v5.0\n * Basic ControlValueAccessor class to build form components upon\n */\n@Directive({\n    standalone: false,\n    host: {\n        '[class._readonly]': 'readOnly',\n        '[class._invalid]': 'computedInvalid',\n    },\n})\nexport abstract class AbstractTuiControl<T>\n    extends AbstractTuiInteractive\n    implements OnInit, ControlValueAccessor\n{\n    private readonly ngControl = inject(NgControl, {optional: true});\n    private previousInternalValue?: T | null;\n    private readonly refresh$ = new Subject<void>();\n\n    protected onTouched = EMPTY_FUNCTION;\n    protected onChange = EMPTY_FUNCTION;\n    protected readonly fallbackValue = this.getFallbackValue();\n    protected destroyRef = inject(DestroyRef);\n    protected readonly cdr = inject(ChangeDetectorRef);\n    protected readonly valueTransformer = inject<TuiValueTransformer<T>>(\n        TuiValueTransformer,\n        {optional: true},\n    );\n\n    @Input()\n    public readOnly = false;\n\n    @Input()\n    public pseudoInvalid: boolean | null = null;\n\n    constructor() {\n        super();\n\n        if (ngDevMode && this.ngControl === null) {\n            console.assert(\n                false,\n                `NgControl not injected in ${this.constructor.name}!\\n`,\n                'Use [(ngModel)] or [formControl] or formControlName for correct work.',\n            );\n        }\n\n        if (this.ngControl) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    protected abstract getFallbackValue(): T;\n\n    public get computedInvalid(): boolean {\n        return (\n            this.interactive &&\n            (this.pseudoInvalid !== null\n                ? this.pseudoInvalid\n                : this.touched && this.invalid)\n        );\n    }\n\n    public get value(): T {\n        return this.previousInternalValue ?? this.fallbackValue;\n    }\n\n    public set value(value: T) {\n        this.updateValue(value);\n    }\n\n    public get safeCurrentValue(): T {\n        return this.rawValue ?? this.fallbackValue;\n    }\n\n    public get invalid(): boolean {\n        return this.safeNgControlData<boolean>(({invalid}) => invalid, false);\n    }\n\n    public get valid(): boolean {\n        return this.safeNgControlData<boolean>(({valid}) => valid, false);\n    }\n\n    public get touched(): boolean {\n        return this.safeNgControlData<boolean>(({touched}) => touched, false);\n    }\n\n    public get disabled(): boolean {\n        return this.safeNgControlData<boolean>(({disabled}) => disabled, false);\n    }\n\n    public get interactive(): boolean {\n        return !this.readOnly && !this.computedDisabled;\n    }\n\n    public get control(): AbstractControl | null {\n        return this.safeNgControlData<AbstractControl | null>(\n            ({control}) => control,\n            null,\n        );\n    }\n\n    public get computedName(): string | null {\n        return this.controlName?.toString() ?? null;\n    }\n\n    public get controlName(): string | null {\n        return this.ngControl?.name?.toString() ?? null;\n    }\n\n    public ngOnInit(): void {\n        this.refresh$\n            .pipe(\n                delay(0),\n                startWith(null),\n                map(() => this.ngControl?.control),\n                filter(tuiIsPresent),\n                distinctUntilChanged(),\n                switchMap((control) =>\n                    merge(control.valueChanges, control.statusChanges),\n                ),\n                takeUntilDestroyed(this.destroyRef),\n            )\n            .subscribe(() => {\n                this.refreshLocalValue(this.safeCurrentValue);\n            });\n    }\n\n    public checkControlUpdate(): void {\n        this.cdr.markForCheck();\n    }\n\n    public registerOnChange(onChange: (value: unknown) => void): void {\n        this.onChange = (componentValue: T) => {\n            onChange(this.toControlValue(componentValue));\n        };\n\n        this.refresh$.next();\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this.onTouched = onTouched;\n    }\n\n    public setDisabledState(): void {\n        this.checkControlUpdate();\n    }\n\n    public writeValue(value: T | null): void {\n        const controlValue =\n            this.ngControl instanceof NgModel && this.previousInternalValue === undefined\n                ? this.ngControl.model\n                : value;\n\n        this.refreshLocalValue(this.fromControlValue(controlValue));\n    }\n\n    protected override updateFocused(focused: boolean): void {\n        if (!focused) {\n            this.controlMarkAsTouched();\n        }\n\n        super.updateFocused(focused);\n    }\n\n    /**\n     * @deprecated use `value` setter\n     */\n    protected updateValue(value: T): void {\n        if (this.disabled || this.valueIdenticalComparator(this.value, value)) {\n            return;\n        }\n\n        this.previousInternalValue = value;\n        this.controlSetValue(value);\n    }\n\n    protected valueIdenticalComparator(oldValue: T, newValue: T): boolean {\n        return oldValue === newValue;\n    }\n\n    private get rawValue(): T | undefined {\n        const {ngControl} = this;\n\n        if (ngControl === null) {\n            return undefined;\n        }\n\n        const controlValue =\n            ngControl instanceof NgModel && this.previousInternalValue === undefined\n                ? ngControl.viewModel\n                : ngControl.value;\n\n        return this.fromControlValue(controlValue);\n    }\n\n    private safeNgControlData<T>(\n        extractor: (ngControl: NgControl) => T | null | undefined,\n        defaultFieldValue: T,\n    ): T {\n        return (this.ngControl && extractor(this.ngControl)) ?? defaultFieldValue;\n    }\n\n    private controlMarkAsTouched(): void {\n        this.onTouched();\n        this.checkControlUpdate();\n    }\n\n    private controlSetValue(value: T): void {\n        this.onChange(value);\n        this.checkControlUpdate();\n    }\n\n    private refreshLocalValue(value: T | null): void {\n        this.previousInternalValue = value;\n        this.checkControlUpdate();\n    }\n\n    private fromControlValue(controlValue: unknown): T {\n        return this.valueTransformer\n            ? this.valueTransformer.fromControlValue(controlValue)\n            : (controlValue as T);\n    }\n\n    private toControlValue(componentValue: T): unknown {\n        return this.valueTransformer\n            ? this.valueTransformer.toControlValue(componentValue)\n            : componentValue;\n    }\n}\n\nexport function tuiAsControl<T>(control: Type<AbstractTuiControl<T>>): Provider {\n    return tuiProvide(AbstractTuiControl, control);\n}\n"]}
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.js","sourceRoot":"","sources":["../../../../projects/legacy/classes/control.ts"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"@taiga-ui/tsconfig/ng-dev-mode\" />\nimport type {OnInit, Provider, Type} from '@angular/core';\nimport {ChangeDetectorRef, DestroyRef, Directive, inject, Input} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport type {AbstractControl, ControlValueAccessor} from '@angular/forms';\nimport {NgControl, NgModel} from '@angular/forms';\nimport {TuiControl, TuiValueTransformer} from '@taiga-ui/cdk/classes';\nimport {EMPTY_FUNCTION} from '@taiga-ui/cdk/constants';\nimport {tuiIsPresent, tuiProvide} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {\n    delay,\n    distinctUntilChanged,\n    EMPTY,\n    filter,\n    map,\n    merge,\n    startWith,\n    Subject,\n    switchMap,\n} from 'rxjs';\n\nimport {AbstractTuiInteractive} from './interactive';\n\n/**\n * @deprecated: drop in v5.0\n * Basic ControlValueAccessor class to build form components upon\n */\n@Directive({\n    standalone: false,\n    host: {\n        '[class._readonly]': 'readOnly',\n        '[class._invalid]': 'computedInvalid',\n    },\n})\nexport abstract class AbstractTuiControl<T>\n    extends AbstractTuiInteractive\n    implements OnInit, ControlValueAccessor\n{\n    private readonly ngControl = inject(NgControl, {optional: true});\n    private previousInternalValue?: T | null;\n    private readonly refresh$ = new Subject<void>();\n\n    protected onTouched = EMPTY_FUNCTION;\n    protected onChange = EMPTY_FUNCTION;\n    protected readonly fallbackValue = this.getFallbackValue();\n    protected destroyRef = inject(DestroyRef);\n    protected readonly cdr = inject(ChangeDetectorRef);\n    protected readonly valueTransformer = inject<TuiValueTransformer<T>>(\n        TuiValueTransformer,\n        {optional: true},\n    );\n\n    @Input()\n    public readOnly = false;\n\n    @Input()\n    public pseudoInvalid: boolean | null = null;\n\n    constructor() {\n        super();\n\n        if (ngDevMode && this.ngControl === null) {\n            console.assert(\n                false,\n                `NgControl not injected in ${this.constructor.name}!\\n`,\n                'Use [(ngModel)] or [formControl] or formControlName for correct work.',\n            );\n        }\n\n        if (this.ngControl) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    protected abstract getFallbackValue(): T;\n\n    public get computedInvalid(): boolean {\n        return (\n            this.interactive &&\n            (this.pseudoInvalid !== null\n                ? this.pseudoInvalid\n                : this.touched && this.invalid)\n        );\n    }\n\n    public get value(): T {\n        return this.previousInternalValue ?? this.fallbackValue;\n    }\n\n    public set value(value: T) {\n        this.updateValue(value);\n    }\n\n    public get safeCurrentValue(): T {\n        return this.rawValue ?? this.fallbackValue;\n    }\n\n    public get invalid(): boolean {\n        return this.safeNgControlData<boolean>(({invalid}) => invalid, false);\n    }\n\n    public get valid(): boolean {\n        return this.safeNgControlData<boolean>(({valid}) => valid, false);\n    }\n\n    public get touched(): boolean {\n        return this.safeNgControlData<boolean>(({touched}) => touched, false);\n    }\n\n    public get disabled(): boolean {\n        return this.safeNgControlData<boolean>(({disabled}) => disabled, false);\n    }\n\n    public get interactive(): boolean {\n        return !this.readOnly && !this.computedDisabled;\n    }\n\n    public get control(): AbstractControl | null {\n        return this.safeNgControlData<AbstractControl | null>(\n            ({control}) => control,\n            null,\n        );\n    }\n\n    public get computedName(): string | null {\n        return this.controlName?.toString() ?? null;\n    }\n\n    public get controlName(): string | null {\n        return this.ngControl?.name?.toString() ?? null;\n    }\n\n    public ngOnInit(): void {\n        this.refresh$\n            .pipe(\n                delay(0),\n                startWith(null),\n                map(() => this.ngControl?.control),\n                filter(tuiIsPresent),\n                distinctUntilChanged(),\n                switchMap((control) =>\n                    merge(\n                        control.valueChanges,\n                        control.statusChanges,\n                        (control as any).events || EMPTY,\n                    ),\n                ),\n                takeUntilDestroyed(this.destroyRef),\n            )\n            .subscribe(() => {\n                this.refreshLocalValue(this.safeCurrentValue);\n            });\n    }\n\n    public checkControlUpdate(): void {\n        this.cdr.markForCheck();\n    }\n\n    public registerOnChange(onChange: (value: unknown) => void): void {\n        this.onChange = (componentValue: T) => {\n            onChange(this.toControlValue(componentValue));\n        };\n\n        this.refresh$.next();\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this.onTouched = onTouched;\n    }\n\n    public setDisabledState(): void {\n        this.checkControlUpdate();\n    }\n\n    public writeValue(value: T | null): void {\n        const controlValue =\n            this.ngControl instanceof NgModel && this.previousInternalValue === undefined\n                ? this.ngControl.model\n                : value;\n\n        this.refreshLocalValue(this.fromControlValue(controlValue));\n    }\n\n    protected override updateFocused(focused: boolean): void {\n        if (!focused) {\n            this.controlMarkAsTouched();\n        }\n\n        super.updateFocused(focused);\n    }\n\n    /**\n     * @deprecated use `value` setter\n     */\n    protected updateValue(value: T): void {\n        if (this.disabled || this.valueIdenticalComparator(this.value, value)) {\n            return;\n        }\n\n        this.previousInternalValue = value;\n        this.controlSetValue(value);\n    }\n\n    protected valueIdenticalComparator(oldValue: T, newValue: T): boolean {\n        return oldValue === newValue;\n    }\n\n    private get rawValue(): T | undefined {\n        const {ngControl} = this;\n\n        if (ngControl === null) {\n            return undefined;\n        }\n\n        const controlValue =\n            ngControl instanceof NgModel && this.previousInternalValue === undefined\n                ? ngControl.viewModel\n                : ngControl.value;\n\n        return this.fromControlValue(controlValue);\n    }\n\n    private safeNgControlData<T>(\n        extractor: (ngControl: NgControl) => T | null | undefined,\n        defaultFieldValue: T,\n    ): T {\n        return (this.ngControl && extractor(this.ngControl)) ?? defaultFieldValue;\n    }\n\n    private controlMarkAsTouched(): void {\n        this.onTouched();\n        this.checkControlUpdate();\n    }\n\n    private controlSetValue(value: T): void {\n        this.onChange(value);\n        this.checkControlUpdate();\n    }\n\n    private refreshLocalValue(value: T | null): void {\n        this.previousInternalValue = value;\n        this.checkControlUpdate();\n    }\n\n    private fromControlValue(controlValue: unknown): T {\n        return this.valueTransformer\n            ? this.valueTransformer.fromControlValue(controlValue)\n            : (controlValue as T);\n    }\n\n    private toControlValue(componentValue: T): unknown {\n        return this.valueTransformer\n            ? this.valueTransformer.toControlValue(componentValue)\n            : componentValue;\n    }\n}\n\nexport function tuiAsControl<T>(control: Type<AbstractTuiControl<T>>): Provider[] {\n    return [tuiProvide(AbstractTuiControl, control), tuiProvide(TuiControl, control)];\n}\n"]}
@@ -28,16 +28,15 @@ class TuiArrowComponent {
28
28
  return !this.small ? this.options.iconLarge : this.options.iconSmall;
29
29
  }
30
30
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiArrowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
31
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiArrowComponent, isStandalone: true, selector: "tui-arrow", host: { attributes: { "ngSkipHydration": "true" }, properties: { "class._rotated": "rotated", "class._small": "small" } }, ngImport: i0, template: "<tui-icon\n *polymorpheusOutlet=\"arrowIcon as src\"\n [icon]=\"src\"\n/>\n<ng-container *ngIf=\"directive?.tuiDropdownOpenChange | async\" />\n", styles: [":host{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:block;cursor:pointer;pointer-events:none}:host._rotated{transform:rotate(180deg)}tui-icon{border:.25rem solid transparent}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
31
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiArrowComponent, isStandalone: true, selector: "tui-arrow", host: { properties: { "class._rotated": "rotated", "class._small": "small" } }, ngImport: i0, template: "<tui-icon\n *polymorpheusOutlet=\"arrowIcon as src\"\n [icon]=\"src\"\n/>\n<ng-container *ngIf=\"directive?.tuiDropdownOpenChange | async\" />\n", styles: [":host{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:block;cursor:pointer;pointer-events:none}:host._rotated{transform:rotate(180deg)}tui-icon{border-width:.25rem}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
32
32
  }
33
33
  export { TuiArrowComponent };
34
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiArrowComponent, decorators: [{
35
35
  type: Component,
36
36
  args: [{ standalone: true, selector: 'tui-arrow', imports: [AsyncPipe, NgIf, PolymorpheusOutlet, PolymorpheusTemplate, TuiIcon], changeDetection: ChangeDetectionStrategy.OnPush, host: {
37
- ngSkipHydration: 'true',
38
37
  '[class._rotated]': 'rotated',
39
38
  '[class._small]': 'small',
40
- }, template: "<tui-icon\n *polymorpheusOutlet=\"arrowIcon as src\"\n [icon]=\"src\"\n/>\n<ng-container *ngIf=\"directive?.tuiDropdownOpenChange | async\" />\n", styles: [":host{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:block;cursor:pointer;pointer-events:none}:host._rotated{transform:rotate(180deg)}tui-icon{border:.25rem solid transparent}\n"] }]
39
+ }, template: "<tui-icon\n *polymorpheusOutlet=\"arrowIcon as src\"\n [icon]=\"src\"\n/>\n<ng-container *ngIf=\"directive?.tuiDropdownOpenChange | async\" />\n", styles: [":host{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:block;cursor:pointer;pointer-events:none}:host._rotated{transform:rotate(180deg)}tui-icon{border-width:.25rem}\n"] }]
41
40
  }] });
42
41
  export const TUI_ARROW = new PolymorpheusComponent(TuiArrowComponent);
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyb3cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvYXJyb3cvYXJyb3cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvYXJyb3cvYXJyb3cudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ2hELE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDbkUsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ2pFLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzVELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBRS9ELE9BQU8sRUFDSCxxQkFBcUIsRUFDckIsa0JBQWtCLEVBQ2xCLG9CQUFvQixHQUN2QixNQUFNLHdCQUF3QixDQUFDO0FBRWhDLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLGlCQUFpQixDQUFDOztBQUVsRDs7R0FFRztBQUNILE1BYWEsaUJBQWlCO0lBYjlCO1FBY3FCLFlBQU8sR0FBUSxNQUFNLENBQUMsa0JBQWtCLEVBQUUsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQztRQUM1RCxrQkFBYSxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzNDLFlBQU8sR0FBRyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUNsQyxjQUFTLEdBQUcsTUFBTSxDQUFDLGVBQWUsRUFBRSxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFDO0tBYTVFO0lBWEcsSUFBYyxPQUFPO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsRUFBRSxlQUFlLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxJQUFJLEtBQUssQ0FBQztJQUNqRixDQUFDO0lBRUQsSUFBYyxLQUFLO1FBQ2YsT0FBTyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxJQUFjLFNBQVM7UUFDbkIsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQztJQUN6RSxDQUFDOytHQWhCUSxpQkFBaUI7bUdBQWpCLGlCQUFpQixnTUNoQzlCLHdKQUtBLGlURGlCYyxTQUFTLDhDQUFFLElBQUksNkZBQUUsa0JBQWtCLDhIQUF3QixPQUFPOztTQVVuRSxpQkFBaUI7NEZBQWpCLGlCQUFpQjtrQkFiN0IsU0FBUztpQ0FDTSxJQUFJLFlBQ04sV0FBVyxXQUNaLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxrQkFBa0IsRUFBRSxvQkFBb0IsRUFBRSxPQUFPLENBQUMsbUJBRzVELHVCQUF1QixDQUFDLE1BQU0sUUFDekM7d0JBQ0YsZUFBZSxFQUFFLE1BQU07d0JBQ3ZCLGtCQUFrQixFQUFFLFNBQVM7d0JBQzdCLGdCQUFnQixFQUFFLE9BQU87cUJBQzVCOztBQXFCTCxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsSUFBSSxxQkFBcUIsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBc3luY1BpcGUsIE5nSWZ9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1R1aUljb259IGZyb20gJ0B0YWlnYS11aS9jb3JlL2NvbXBvbmVudHMvaWNvbic7XG5pbXBvcnQge1R1aURyb3Bkb3duT3Blbn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvZGlyZWN0aXZlcy9kcm9wZG93bic7XG5pbXBvcnQge3R1aVNpemVCaWdnZXJ9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3V0aWxzL21pc2NlbGxhbmVvdXMnO1xuaW1wb3J0IHtBYnN0cmFjdFR1aUNvbnRyb2x9IGZyb20gJ0B0YWlnYS11aS9sZWdhY3kvY2xhc3Nlcyc7XG5pbXBvcnQge1RVSV9URVhURklFTERfU0laRX0gZnJvbSAnQHRhaWdhLXVpL2xlZ2FjeS9kaXJlY3RpdmVzJztcbmltcG9ydCB0eXBlIHtQb2x5bW9ycGhldXNDb250ZW50fSBmcm9tICdAdGFpZ2EtdWkvcG9seW1vcnBoZXVzJztcbmltcG9ydCB7XG4gICAgUG9seW1vcnBoZXVzQ29tcG9uZW50LFxuICAgIFBvbHltb3JwaGV1c091dGxldCxcbiAgICBQb2x5bW9ycGhldXNUZW1wbGF0ZSxcbn0gZnJvbSAnQHRhaWdhLXVpL3BvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB7VFVJX0FSUk9XX09QVElPTlN9IGZyb20gJy4vYXJyb3cub3B0aW9ucyc7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQ6IGRyb3AgaW4gdjUuMCB1c2Uge0BsaW5rIFR1aUNoZXZyb259XG4gKi9cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICd0dWktYXJyb3cnLFxuICAgIGltcG9ydHM6IFtBc3luY1BpcGUsIE5nSWYsIFBvbHltb3JwaGV1c091dGxldCwgUG9seW1vcnBoZXVzVGVtcGxhdGUsIFR1aUljb25dLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9hcnJvdy50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9hcnJvdy5zdHlsZS5sZXNzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaG9zdDoge1xuICAgICAgICBuZ1NraXBIeWRyYXRpb246ICd0cnVlJyxcbiAgICAgICAgJ1tjbGFzcy5fcm90YXRlZF0nOiAncm90YXRlZCcsXG4gICAgICAgICdbY2xhc3MuX3NtYWxsXSc6ICdzbWFsbCcsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpQXJyb3dDb21wb25lbnQge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgY29udHJvbDogYW55ID0gaW5qZWN0KEFic3RyYWN0VHVpQ29udHJvbCwge29wdGlvbmFsOiB0cnVlfSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSB0ZXh0ZmllbGRTaXplID0gaW5qZWN0KFRVSV9URVhURklFTERfU0laRSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBvcHRpb25zID0gaW5qZWN0KFRVSV9BUlJPV19PUFRJT05TKTtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgZGlyZWN0aXZlID0gaW5qZWN0KFR1aURyb3Bkb3duT3Blbiwge29wdGlvbmFsOiB0cnVlfSk7XG5cbiAgICBwcm90ZWN0ZWQgZ2V0IHJvdGF0ZWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmRpcmVjdGl2ZT8udHVpRHJvcGRvd25PcGVuIHx8ICEhdGhpcy5jb250cm9sLnBzZXVkb09wZW4gfHwgZmFsc2U7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGdldCBzbWFsbCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuICF0dWlTaXplQmlnZ2VyKHRoaXMudGV4dGZpZWxkU2l6ZS5zaXplKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgZ2V0IGFycm93SWNvbigpOiBQb2x5bW9ycGhldXNDb250ZW50IHtcbiAgICAgICAgcmV0dXJuICF0aGlzLnNtYWxsID8gdGhpcy5vcHRpb25zLmljb25MYXJnZSA6IHRoaXMub3B0aW9ucy5pY29uU21hbGw7XG4gICAgfVxufVxuXG5leHBvcnQgY29uc3QgVFVJX0FSUk9XID0gbmV3IFBvbHltb3JwaGV1c0NvbXBvbmVudChUdWlBcnJvd0NvbXBvbmVudCk7XG4iLCI8dHVpLWljb25cbiAgICAqcG9seW1vcnBoZXVzT3V0bGV0PVwiYXJyb3dJY29uIGFzIHNyY1wiXG4gICAgW2ljb25dPVwic3JjXCJcbi8+XG48bmctY29udGFpbmVyICpuZ0lmPVwiZGlyZWN0aXZlPy50dWlEcm9wZG93bk9wZW5DaGFuZ2UgfCBhc3luY1wiIC8+XG4iXX0=
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyb3cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvYXJyb3cvYXJyb3cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvYXJyb3cvYXJyb3cudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ2hELE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDbkUsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ2pFLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQzVELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBRS9ELE9BQU8sRUFDSCxxQkFBcUIsRUFDckIsa0JBQWtCLEVBQ2xCLG9CQUFvQixHQUN2QixNQUFNLHdCQUF3QixDQUFDO0FBRWhDLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLGlCQUFpQixDQUFDOztBQUVsRDs7R0FFRztBQUNILE1BWWEsaUJBQWlCO0lBWjlCO1FBYXFCLFlBQU8sR0FBUSxNQUFNLENBQUMsa0JBQWtCLEVBQUUsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQztRQUM1RCxrQkFBYSxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzNDLFlBQU8sR0FBRyxNQUFNLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUNsQyxjQUFTLEdBQUcsTUFBTSxDQUFDLGVBQWUsRUFBRSxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFDO0tBYTVFO0lBWEcsSUFBYyxPQUFPO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsRUFBRSxlQUFlLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxJQUFJLEtBQUssQ0FBQztJQUNqRixDQUFDO0lBRUQsSUFBYyxLQUFLO1FBQ2YsT0FBTyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxJQUFjLFNBQVM7UUFDbkIsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQztJQUN6RSxDQUFDOytHQWhCUSxpQkFBaUI7bUdBQWpCLGlCQUFpQixxSkMvQjlCLHdKQUtBLHFTRGlCYyxTQUFTLDhDQUFFLElBQUksNkZBQUUsa0JBQWtCLDhIQUF3QixPQUFPOztTQVNuRSxpQkFBaUI7NEZBQWpCLGlCQUFpQjtrQkFaN0IsU0FBUztpQ0FDTSxJQUFJLFlBQ04sV0FBVyxXQUNaLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxrQkFBa0IsRUFBRSxvQkFBb0IsRUFBRSxPQUFPLENBQUMsbUJBRzVELHVCQUF1QixDQUFDLE1BQU0sUUFDekM7d0JBQ0Ysa0JBQWtCLEVBQUUsU0FBUzt3QkFDN0IsZ0JBQWdCLEVBQUUsT0FBTztxQkFDNUI7O0FBcUJMLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxJQUFJLHFCQUFxQixDQUFDLGlCQUFpQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0FzeW5jUGlwZSwgTmdJZn0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgaW5qZWN0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VHVpSWNvbn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9pY29uJztcbmltcG9ydCB7VHVpRHJvcGRvd25PcGVufSBmcm9tICdAdGFpZ2EtdWkvY29yZS9kaXJlY3RpdmVzL2Ryb3Bkb3duJztcbmltcG9ydCB7dHVpU2l6ZUJpZ2dlcn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5pbXBvcnQge0Fic3RyYWN0VHVpQ29udHJvbH0gZnJvbSAnQHRhaWdhLXVpL2xlZ2FjeS9jbGFzc2VzJztcbmltcG9ydCB7VFVJX1RFWFRGSUVMRF9TSVpFfSBmcm9tICdAdGFpZ2EtdWkvbGVnYWN5L2RpcmVjdGl2ZXMnO1xuaW1wb3J0IHR5cGUge1BvbHltb3JwaGV1c0NvbnRlbnR9IGZyb20gJ0B0YWlnYS11aS9wb2x5bW9ycGhldXMnO1xuaW1wb3J0IHtcbiAgICBQb2x5bW9ycGhldXNDb21wb25lbnQsXG4gICAgUG9seW1vcnBoZXVzT3V0bGV0LFxuICAgIFBvbHltb3JwaGV1c1RlbXBsYXRlLFxufSBmcm9tICdAdGFpZ2EtdWkvcG9seW1vcnBoZXVzJztcblxuaW1wb3J0IHtUVUlfQVJST1dfT1BUSU9OU30gZnJvbSAnLi9hcnJvdy5vcHRpb25zJztcblxuLyoqXG4gKiBAZGVwcmVjYXRlZDogZHJvcCBpbiB2NS4wIHVzZSB7QGxpbmsgVHVpQ2hldnJvbn1cbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ3R1aS1hcnJvdycsXG4gICAgaW1wb3J0czogW0FzeW5jUGlwZSwgTmdJZiwgUG9seW1vcnBoZXVzT3V0bGV0LCBQb2x5bW9ycGhldXNUZW1wbGF0ZSwgVHVpSWNvbl0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2Fycm93LnRlbXBsYXRlLmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2Fycm93LnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBob3N0OiB7XG4gICAgICAgICdbY2xhc3MuX3JvdGF0ZWRdJzogJ3JvdGF0ZWQnLFxuICAgICAgICAnW2NsYXNzLl9zbWFsbF0nOiAnc21hbGwnLFxuICAgIH0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aUFycm93Q29tcG9uZW50IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbnRyb2w6IGFueSA9IGluamVjdChBYnN0cmFjdFR1aUNvbnRyb2wsIHtvcHRpb25hbDogdHJ1ZX0pO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgdGV4dGZpZWxkU2l6ZSA9IGluamVjdChUVUlfVEVYVEZJRUxEX1NJWkUpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgb3B0aW9ucyA9IGluamVjdChUVUlfQVJST1dfT1BUSU9OUyk7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGRpcmVjdGl2ZSA9IGluamVjdChUdWlEcm9wZG93bk9wZW4sIHtvcHRpb25hbDogdHJ1ZX0pO1xuXG4gICAgcHJvdGVjdGVkIGdldCByb3RhdGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5kaXJlY3RpdmU/LnR1aURyb3Bkb3duT3BlbiB8fCAhIXRoaXMuY29udHJvbC5wc2V1ZG9PcGVuIHx8IGZhbHNlO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBnZXQgc21hbGwoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhdHVpU2l6ZUJpZ2dlcih0aGlzLnRleHRmaWVsZFNpemUuc2l6ZSk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGdldCBhcnJvd0ljb24oKTogUG9seW1vcnBoZXVzQ29udGVudCB7XG4gICAgICAgIHJldHVybiAhdGhpcy5zbWFsbCA/IHRoaXMub3B0aW9ucy5pY29uTGFyZ2UgOiB0aGlzLm9wdGlvbnMuaWNvblNtYWxsO1xuICAgIH1cbn1cblxuZXhwb3J0IGNvbnN0IFRVSV9BUlJPVyA9IG5ldyBQb2x5bW9ycGhldXNDb21wb25lbnQoVHVpQXJyb3dDb21wb25lbnQpO1xuIiwiPHR1aS1pY29uXG4gICAgKnBvbHltb3JwaGV1c091dGxldD1cImFycm93SWNvbiBhcyBzcmNcIlxuICAgIFtpY29uXT1cInNyY1wiXG4vPlxuPG5nLWNvbnRhaW5lciAqbmdJZj1cImRpcmVjdGl2ZT8udHVpRHJvcGRvd25PcGVuQ2hhbmdlIHwgYXN5bmNcIiAvPlxuIl19
@@ -45,17 +45,15 @@ class TuiColorEditComponent {
45
45
  this.colorChange.emit(color);
46
46
  }
47
47
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiColorEditComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
48
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiColorEditComponent, selector: "tui-color-edit", inputs: { color: "color" }, outputs: { colorChange: "colorChange" }, host: { attributes: { "ngSkipHydration": "true" } }, ngImport: i0, template: "<tui-select\n tuiDropdownAlign=\"left\"\n tuiDropdownLimitWidth=\"min\"\n tuiTextfieldSize=\"m\"\n class=\"t-select\"\n [ngModelOptions]=\"{standalone: true}\"\n [style.flex]=\"'0 0 auto'\"\n [tuiTextfieldLabelOutside]=\"true\"\n [(ngModel)]=\"mode\"\n>\n <tui-data-list\n *tuiDataList\n size=\"s\"\n >\n <button\n *ngFor=\"let item of modes\"\n tuiOption\n type=\"button\"\n [value]=\"item\"\n >\n {{ item }}\n </button>\n </tui-data-list>\n</tui-select>\n<tui-primitive-textfield\n *ngIf=\"isHex; else rgb\"\n tuiTextfieldSize=\"m\"\n [maskito]=\"hexMask\"\n [tuiTextfieldLabelOutside]=\"true\"\n [value]=\"hex\"\n (valueChange)=\"onHexChange($event)\"\n/>\n<ng-template #rgb>\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[0]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange($event, color[1], color[2], color[3])\"\n />\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[1]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], $event, color[2], color[3])\"\n />\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[2]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], color[1], $event, color[3])\"\n />\n</ng-template>\n<tui-input-number\n tuiTextfieldPostfix=\"%\"\n tuiTextfieldSize=\"m\"\n class=\"t-opacity\"\n [max]=\"100\"\n [min]=\"0\"\n [ngModel]=\"opacity\"\n [ngModelOptions]=\"{standalone: true}\"\n [style.flex]=\"'0 0 auto'\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], color[1], color[2], $event / 100)\"\n/>\n", styles: [":host{display:flex}.t-select{inline-size:5.875rem}.t-opacity{inline-size:4.275rem}.t-rgb,.t-opacity{text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { kind: "component", type: i4.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "iconCleaner", "readOnly", "invalid", "disabled", "value"], outputs: ["valueChange"] }, { kind: "directive", type: i4.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { kind: "directive", type: i5.TuiTextfieldLabelOutsideDirective, selector: "[tuiTextfieldLabelOutside]", inputs: ["tuiTextfieldLabelOutside"] }, { kind: "directive", type: i5.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { kind: "directive", type: i5.TuiTextfieldPostfixDirective, selector: "[tuiTextfieldPostfix]", inputs: ["tuiTextfieldPostfix"] }, { kind: "component", type: i6.TuiInputNumberComponent, selector: "tui-input-number", inputs: ["min", "max", "step"] }, { kind: "directive", type: i6.TuiInputNumberDirective, selector: "tui-input-number" }, { kind: "component", type: i7.TuiSelectComponent, selector: "tui-select", inputs: ["stringify", "identityMatcher", "valueContent"] }, { kind: "directive", type: i7.TuiSelectDirective, selector: "tui-select" }, { kind: "directive", type: i8.TuiDropdownOptionsDirective, selector: "[tuiDropdownAlign], [tuiDropdownAppearance], [tuiDropdownDirection], [tuiDropdownLimitWidth], [tuiDropdownMinHeight], [tuiDropdownMaxHeight], [tuiDropdownOffset]", inputs: ["tuiDropdownAlign", "tuiDropdownAppearance", "tuiDropdownDirection", "tuiDropdownLimitWidth", "tuiDropdownMinHeight", "tuiDropdownMaxHeight", "tuiDropdownOffset"] }, { kind: "component", type: i9.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "directive", type: i9.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { kind: "component", type: i9.TuiOption, selector: "button[tuiOption], a[tuiOption], label[tuiOption]", inputs: ["disabled", "value"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
48
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiColorEditComponent, selector: "tui-color-edit", inputs: { color: "color" }, outputs: { colorChange: "colorChange" }, ngImport: i0, template: "<tui-select\n tuiDropdownAlign=\"left\"\n tuiDropdownLimitWidth=\"min\"\n tuiTextfieldSize=\"m\"\n class=\"t-select\"\n [ngModelOptions]=\"{standalone: true}\"\n [style.flex]=\"'0 0 auto'\"\n [tuiTextfieldLabelOutside]=\"true\"\n [(ngModel)]=\"mode\"\n>\n <tui-data-list\n *tuiDataList\n size=\"s\"\n >\n <button\n *ngFor=\"let item of modes\"\n tuiOption\n type=\"button\"\n [value]=\"item\"\n >\n {{ item }}\n </button>\n </tui-data-list>\n</tui-select>\n<tui-primitive-textfield\n *ngIf=\"isHex; else rgb\"\n tuiTextfieldSize=\"m\"\n [maskito]=\"hexMask\"\n [tuiTextfieldLabelOutside]=\"true\"\n [value]=\"hex\"\n (valueChange)=\"onHexChange($event)\"\n/>\n<ng-template #rgb>\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[0]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange($event, color[1], color[2], color[3])\"\n />\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[1]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], $event, color[2], color[3])\"\n />\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[2]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], color[1], $event, color[3])\"\n />\n</ng-template>\n<tui-input-number\n tuiTextfieldPostfix=\"%\"\n tuiTextfieldSize=\"m\"\n class=\"t-opacity\"\n [max]=\"100\"\n [min]=\"0\"\n [ngModel]=\"opacity\"\n [ngModelOptions]=\"{standalone: true}\"\n [style.flex]=\"'0 0 auto'\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], color[1], color[2], $event / 100)\"\n/>\n", styles: [":host{display:flex}.t-select{inline-size:5.875rem}.t-opacity{inline-size:4.275rem}.t-rgb,.t-opacity{text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { kind: "component", type: i4.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "iconCleaner", "readOnly", "invalid", "disabled", "value"], outputs: ["valueChange"] }, { kind: "directive", type: i4.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { kind: "directive", type: i5.TuiTextfieldLabelOutsideDirective, selector: "[tuiTextfieldLabelOutside]", inputs: ["tuiTextfieldLabelOutside"] }, { kind: "directive", type: i5.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { kind: "directive", type: i5.TuiTextfieldPostfixDirective, selector: "[tuiTextfieldPostfix]", inputs: ["tuiTextfieldPostfix"] }, { kind: "component", type: i6.TuiInputNumberComponent, selector: "tui-input-number", inputs: ["min", "max", "step"] }, { kind: "directive", type: i6.TuiInputNumberDirective, selector: "tui-input-number" }, { kind: "component", type: i7.TuiSelectComponent, selector: "tui-select", inputs: ["stringify", "identityMatcher", "valueContent"] }, { kind: "directive", type: i7.TuiSelectDirective, selector: "tui-select" }, { kind: "directive", type: i8.TuiDropdownOptionsDirective, selector: "[tuiDropdownAlign], [tuiDropdownAppearance], [tuiDropdownDirection], [tuiDropdownLimitWidth], [tuiDropdownMinHeight], [tuiDropdownMaxHeight], [tuiDropdownOffset]", inputs: ["tuiDropdownAlign", "tuiDropdownAppearance", "tuiDropdownDirection", "tuiDropdownLimitWidth", "tuiDropdownMinHeight", "tuiDropdownMaxHeight", "tuiDropdownOffset"] }, { kind: "component", type: i9.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "directive", type: i9.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { kind: "component", type: i9.TuiOption, selector: "button[tuiOption], a[tuiOption], label[tuiOption]", inputs: ["disabled", "value"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
49
49
  }
50
50
  export { TuiColorEditComponent };
51
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiColorEditComponent, decorators: [{
52
52
  type: Component,
53
- args: [{ standalone: false, selector: 'tui-color-edit', changeDetection: ChangeDetectionStrategy.OnPush, host: {
54
- ngSkipHydration: 'true',
55
- }, template: "<tui-select\n tuiDropdownAlign=\"left\"\n tuiDropdownLimitWidth=\"min\"\n tuiTextfieldSize=\"m\"\n class=\"t-select\"\n [ngModelOptions]=\"{standalone: true}\"\n [style.flex]=\"'0 0 auto'\"\n [tuiTextfieldLabelOutside]=\"true\"\n [(ngModel)]=\"mode\"\n>\n <tui-data-list\n *tuiDataList\n size=\"s\"\n >\n <button\n *ngFor=\"let item of modes\"\n tuiOption\n type=\"button\"\n [value]=\"item\"\n >\n {{ item }}\n </button>\n </tui-data-list>\n</tui-select>\n<tui-primitive-textfield\n *ngIf=\"isHex; else rgb\"\n tuiTextfieldSize=\"m\"\n [maskito]=\"hexMask\"\n [tuiTextfieldLabelOutside]=\"true\"\n [value]=\"hex\"\n (valueChange)=\"onHexChange($event)\"\n/>\n<ng-template #rgb>\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[0]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange($event, color[1], color[2], color[3])\"\n />\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[1]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], $event, color[2], color[3])\"\n />\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[2]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], color[1], $event, color[3])\"\n />\n</ng-template>\n<tui-input-number\n tuiTextfieldPostfix=\"%\"\n tuiTextfieldSize=\"m\"\n class=\"t-opacity\"\n [max]=\"100\"\n [min]=\"0\"\n [ngModel]=\"opacity\"\n [ngModelOptions]=\"{standalone: true}\"\n [style.flex]=\"'0 0 auto'\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], color[1], color[2], $event / 100)\"\n/>\n", styles: [":host{display:flex}.t-select{inline-size:5.875rem}.t-opacity{inline-size:4.275rem}.t-rgb,.t-opacity{text-align:center}\n"] }]
53
+ args: [{ standalone: false, selector: 'tui-color-edit', changeDetection: ChangeDetectionStrategy.OnPush, template: "<tui-select\n tuiDropdownAlign=\"left\"\n tuiDropdownLimitWidth=\"min\"\n tuiTextfieldSize=\"m\"\n class=\"t-select\"\n [ngModelOptions]=\"{standalone: true}\"\n [style.flex]=\"'0 0 auto'\"\n [tuiTextfieldLabelOutside]=\"true\"\n [(ngModel)]=\"mode\"\n>\n <tui-data-list\n *tuiDataList\n size=\"s\"\n >\n <button\n *ngFor=\"let item of modes\"\n tuiOption\n type=\"button\"\n [value]=\"item\"\n >\n {{ item }}\n </button>\n </tui-data-list>\n</tui-select>\n<tui-primitive-textfield\n *ngIf=\"isHex; else rgb\"\n tuiTextfieldSize=\"m\"\n [maskito]=\"hexMask\"\n [tuiTextfieldLabelOutside]=\"true\"\n [value]=\"hex\"\n (valueChange)=\"onHexChange($event)\"\n/>\n<ng-template #rgb>\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[0]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange($event, color[1], color[2], color[3])\"\n />\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[1]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], $event, color[2], color[3])\"\n />\n <tui-input-number\n tuiTextfieldSize=\"m\"\n class=\"t-rgb\"\n [max]=\"255\"\n [min]=\"0\"\n [ngModel]=\"color[2]\"\n [ngModelOptions]=\"{standalone: true}\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], color[1], $event, color[3])\"\n />\n</ng-template>\n<tui-input-number\n tuiTextfieldPostfix=\"%\"\n tuiTextfieldSize=\"m\"\n class=\"t-opacity\"\n [max]=\"100\"\n [min]=\"0\"\n [ngModel]=\"opacity\"\n [ngModelOptions]=\"{standalone: true}\"\n [style.flex]=\"'0 0 auto'\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onRgbChange(color[0], color[1], color[2], $event / 100)\"\n/>\n", styles: [":host{display:flex}.t-select{inline-size:5.875rem}.t-opacity{inline-size:4.275rem}.t-rgb,.t-opacity{text-align:center}\n"] }]
56
54
  }], propDecorators: { color: [{
57
55
  type: Input
58
56
  }], colorChange: [{
59
57
  type: Output
60
58
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItZWRpdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sZWdhY3kvY29tcG9uZW50cy9jb2xvci1zZWxlY3Rvci9jb2xvci1lZGl0L2NvbG9yLWVkaXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvY29sb3Itc2VsZWN0b3IvY29sb3ItZWRpdC9jb2xvci1lZGl0LnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFDLFdBQVcsRUFBRSxXQUFXLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQzs7Ozs7Ozs7Ozs7QUFFbkUsTUFBTSxlQUFlLEdBQUcsQ0FBQyxDQUFDO0FBRTFCLE1BVWEscUJBQXFCO0lBVmxDO1FBWVcsVUFBSyxHQUFxQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBRzlDLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQW9DLENBQUM7UUFFbkUsWUFBTyxHQUFtQjtZQUN0QyxJQUFJLEVBQUUsSUFBSSxNQUFNLENBQUMsZUFBZSxlQUFlLElBQUksRUFBRSxJQUFJLENBQUM7U0FDN0QsQ0FBQztRQUVjLFVBQUssR0FBRyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztRQUVoQyxTQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztLQWdDL0I7SUE5QkcsSUFBVyxLQUFLO1FBQ1osT0FBTyxJQUFJLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVELElBQVcsR0FBRztRQUNWLE9BQU8sV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNyRixDQUFDO0lBRUQsSUFBVyxPQUFPO1FBQ2QsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVNLFdBQVcsQ0FBQyxHQUFXO1FBQzFCLElBQUksR0FBRyxDQUFDLE1BQU0sS0FBSyxlQUFlLEVBQUU7WUFDaEMsT0FBTztTQUNWO1FBRUQsTUFBTSxHQUFHLEdBQUcsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRTdCLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRU0sV0FBVyxDQUFDLEdBQUcsSUFBc0M7UUFDeEQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRU8sV0FBVyxDQUFDLEtBQXVDO1FBQ3ZELElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pDLENBQUM7K0dBNUNRLHFCQUFxQjttR0FBckIscUJBQXFCLGdMQ3RCbEMsNHFFQTRFQTs7U0R0RGEscUJBQXFCOzRGQUFyQixxQkFBcUI7a0JBVmpDLFNBQVM7aUNBQ00sS0FBSyxZQUNQLGdCQUFnQixtQkFHVCx1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNGLGVBQWUsRUFBRSxNQUFNO3FCQUMxQjs4QkFJTSxLQUFLO3NCQURYLEtBQUs7Z0JBSVUsV0FBVztzQkFEMUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBJbnB1dCxcbiAgICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUge01hc2tpdG9PcHRpb25zfSBmcm9tICdAbWFza2l0by9jb3JlJztcbmltcG9ydCB7dHVpSGV4VG9SZ2IsIHR1aVJnYlRvSGV4fSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL2NvbG9yJztcblxuY29uc3QgSEVYX01PREVfTEVOR1RIID0gNjtcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogZmFsc2UsXG4gICAgc2VsZWN0b3I6ICd0dWktY29sb3ItZWRpdCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NvbG9yLWVkaXQudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vY29sb3ItZWRpdC5zdHlsZS5sZXNzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaG9zdDoge1xuICAgICAgICBuZ1NraXBIeWRyYXRpb246ICd0cnVlJyxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBUdWlDb2xvckVkaXRDb21wb25lbnQge1xuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGNvbG9yOiBbbnVtYmVyLCBudW1iZXIsIG51bWJlciwgbnVtYmVyXSA9IFswLCAwLCAwLCAxXTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyByZWFkb25seSBjb2xvckNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8W251bWJlciwgbnVtYmVyLCBudW1iZXIsIG51bWJlcl0+KCk7XG5cbiAgICBwdWJsaWMgcmVhZG9ubHkgaGV4TWFzazogTWFza2l0b09wdGlvbnMgPSB7XG4gICAgICAgIG1hc2s6IG5ldyBSZWdFeHAoYF5bQS1GXFxcXGRdezAsJHtIRVhfTU9ERV9MRU5HVEh9fSRgLCAnZ2knKSxcbiAgICB9O1xuXG4gICAgcHVibGljIHJlYWRvbmx5IG1vZGVzID0gWydIRVgnLCAnUkdCJ107XG5cbiAgICBwdWJsaWMgbW9kZSA9IHRoaXMubW9kZXNbMF07XG5cbiAgICBwdWJsaWMgZ2V0IGlzSGV4KCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5tb2RlID09PSB0aGlzLm1vZGVzWzBdO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgaGV4KCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiB0dWlSZ2JUb0hleCh0aGlzLmNvbG9yWzBdLCB0aGlzLmNvbG9yWzFdLCB0aGlzLmNvbG9yWzJdKS5yZXBsYWNlKCcjJywgJycpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgb3BhY2l0eSgpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gTWF0aC5yb3VuZCh0aGlzLmNvbG9yWzNdICogMTAwKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb25IZXhDaGFuZ2UoaGV4OiBzdHJpbmcpOiB2b2lkIHtcbiAgICAgICAgaWYgKGhleC5sZW5ndGggIT09IEhFWF9NT0RFX0xFTkdUSCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcmdiID0gdHVpSGV4VG9SZ2IoaGV4KTtcblxuICAgICAgICB0aGlzLnVwZGF0ZUNvbG9yKFtyZ2JbMF0sIHJnYlsxXSwgcmdiWzJdLCB0aGlzLmNvbG9yWzNdXSk7XG4gICAgfVxuXG4gICAgcHVibGljIG9uUmdiQ2hhbmdlKC4uLnJnYmE6IFtudW1iZXIsIG51bWJlciwgbnVtYmVyLCBudW1iZXJdKTogdm9pZCB7XG4gICAgICAgIHRoaXMudXBkYXRlQ29sb3IocmdiYSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSB1cGRhdGVDb2xvcihjb2xvcjogW251bWJlciwgbnVtYmVyLCBudW1iZXIsIG51bWJlcl0pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jb2xvciA9IGNvbG9yO1xuICAgICAgICB0aGlzLmNvbG9yQ2hhbmdlLmVtaXQoY29sb3IpO1xuICAgIH1cbn1cbiIsIjx0dWktc2VsZWN0XG4gICAgdHVpRHJvcGRvd25BbGlnbj1cImxlZnRcIlxuICAgIHR1aURyb3Bkb3duTGltaXRXaWR0aD1cIm1pblwiXG4gICAgdHVpVGV4dGZpZWxkU2l6ZT1cIm1cIlxuICAgIGNsYXNzPVwidC1zZWxlY3RcIlxuICAgIFtuZ01vZGVsT3B0aW9uc109XCJ7c3RhbmRhbG9uZTogdHJ1ZX1cIlxuICAgIFtzdHlsZS5mbGV4XT1cIicwIDAgYXV0bydcIlxuICAgIFt0dWlUZXh0ZmllbGRMYWJlbE91dHNpZGVdPVwidHJ1ZVwiXG4gICAgWyhuZ01vZGVsKV09XCJtb2RlXCJcbj5cbiAgICA8dHVpLWRhdGEtbGlzdFxuICAgICAgICAqdHVpRGF0YUxpc3RcbiAgICAgICAgc2l6ZT1cInNcIlxuICAgID5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgbW9kZXNcIlxuICAgICAgICAgICAgdHVpT3B0aW9uXG4gICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgIFt2YWx1ZV09XCJpdGVtXCJcbiAgICAgICAgPlxuICAgICAgICAgICAge3sgaXRlbSB9fVxuICAgICAgICA8L2J1dHRvbj5cbiAgICA8L3R1aS1kYXRhLWxpc3Q+XG48L3R1aS1zZWxlY3Q+XG48dHVpLXByaW1pdGl2ZS10ZXh0ZmllbGRcbiAgICAqbmdJZj1cImlzSGV4OyBlbHNlIHJnYlwiXG4gICAgdHVpVGV4dGZpZWxkU2l6ZT1cIm1cIlxuICAgIFttYXNraXRvXT1cImhleE1hc2tcIlxuICAgIFt0dWlUZXh0ZmllbGRMYWJlbE91dHNpZGVdPVwidHJ1ZVwiXG4gICAgW3ZhbHVlXT1cImhleFwiXG4gICAgKHZhbHVlQ2hhbmdlKT1cIm9uSGV4Q2hhbmdlKCRldmVudClcIlxuLz5cbjxuZy10ZW1wbGF0ZSAjcmdiPlxuICAgIDx0dWktaW5wdXQtbnVtYmVyXG4gICAgICAgIHR1aVRleHRmaWVsZFNpemU9XCJtXCJcbiAgICAgICAgY2xhc3M9XCJ0LXJnYlwiXG4gICAgICAgIFttYXhdPVwiMjU1XCJcbiAgICAgICAgW21pbl09XCIwXCJcbiAgICAgICAgW25nTW9kZWxdPVwiY29sb3JbMF1cIlxuICAgICAgICBbbmdNb2RlbE9wdGlvbnNdPVwie3N0YW5kYWxvbmU6IHRydWV9XCJcbiAgICAgICAgW3R1aVRleHRmaWVsZExhYmVsT3V0c2lkZV09XCJ0cnVlXCJcbiAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwib25SZ2JDaGFuZ2UoJGV2ZW50LCBjb2xvclsxXSwgY29sb3JbMl0sIGNvbG9yWzNdKVwiXG4gICAgLz5cbiAgICA8dHVpLWlucHV0LW51bWJlclxuICAgICAgICB0dWlUZXh0ZmllbGRTaXplPVwibVwiXG4gICAgICAgIGNsYXNzPVwidC1yZ2JcIlxuICAgICAgICBbbWF4XT1cIjI1NVwiXG4gICAgICAgIFttaW5dPVwiMFwiXG4gICAgICAgIFtuZ01vZGVsXT1cImNvbG9yWzFdXCJcbiAgICAgICAgW25nTW9kZWxPcHRpb25zXT1cIntzdGFuZGFsb25lOiB0cnVlfVwiXG4gICAgICAgIFt0dWlUZXh0ZmllbGRMYWJlbE91dHNpZGVdPVwidHJ1ZVwiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cIm9uUmdiQ2hhbmdlKGNvbG9yWzBdLCAkZXZlbnQsIGNvbG9yWzJdLCBjb2xvclszXSlcIlxuICAgIC8+XG4gICAgPHR1aS1pbnB1dC1udW1iZXJcbiAgICAgICAgdHVpVGV4dGZpZWxkU2l6ZT1cIm1cIlxuICAgICAgICBjbGFzcz1cInQtcmdiXCJcbiAgICAgICAgW21heF09XCIyNTVcIlxuICAgICAgICBbbWluXT1cIjBcIlxuICAgICAgICBbbmdNb2RlbF09XCJjb2xvclsyXVwiXG4gICAgICAgIFtuZ01vZGVsT3B0aW9uc109XCJ7c3RhbmRhbG9uZTogdHJ1ZX1cIlxuICAgICAgICBbdHVpVGV4dGZpZWxkTGFiZWxPdXRzaWRlXT1cInRydWVcIlxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJvblJnYkNoYW5nZShjb2xvclswXSwgY29sb3JbMV0sICRldmVudCwgY29sb3JbM10pXCJcbiAgICAvPlxuPC9uZy10ZW1wbGF0ZT5cbjx0dWktaW5wdXQtbnVtYmVyXG4gICAgdHVpVGV4dGZpZWxkUG9zdGZpeD1cIiVcIlxuICAgIHR1aVRleHRmaWVsZFNpemU9XCJtXCJcbiAgICBjbGFzcz1cInQtb3BhY2l0eVwiXG4gICAgW21heF09XCIxMDBcIlxuICAgIFttaW5dPVwiMFwiXG4gICAgW25nTW9kZWxdPVwib3BhY2l0eVwiXG4gICAgW25nTW9kZWxPcHRpb25zXT1cIntzdGFuZGFsb25lOiB0cnVlfVwiXG4gICAgW3N0eWxlLmZsZXhdPVwiJzAgMCBhdXRvJ1wiXG4gICAgW3R1aVRleHRmaWVsZExhYmVsT3V0c2lkZV09XCJ0cnVlXCJcbiAgICAobmdNb2RlbENoYW5nZSk9XCJvblJnYkNoYW5nZShjb2xvclswXSwgY29sb3JbMV0sIGNvbG9yWzJdLCAkZXZlbnQgLyAxMDApXCJcbi8+XG4iXX0=
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItZWRpdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sZWdhY3kvY29tcG9uZW50cy9jb2xvci1zZWxlY3Rvci9jb2xvci1lZGl0L2NvbG9yLWVkaXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvY29sb3Itc2VsZWN0b3IvY29sb3ItZWRpdC9jb2xvci1lZGl0LnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFDLFdBQVcsRUFBRSxXQUFXLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQzs7Ozs7Ozs7Ozs7QUFFbkUsTUFBTSxlQUFlLEdBQUcsQ0FBQyxDQUFDO0FBRTFCLE1BT2EscUJBQXFCO0lBUGxDO1FBU1csVUFBSyxHQUFxQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBRzlDLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQW9DLENBQUM7UUFFbkUsWUFBTyxHQUFtQjtZQUN0QyxJQUFJLEVBQUUsSUFBSSxNQUFNLENBQUMsZUFBZSxlQUFlLElBQUksRUFBRSxJQUFJLENBQUM7U0FDN0QsQ0FBQztRQUVjLFVBQUssR0FBRyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztRQUVoQyxTQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztLQWdDL0I7SUE5QkcsSUFBVyxLQUFLO1FBQ1osT0FBTyxJQUFJLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVELElBQVcsR0FBRztRQUNWLE9BQU8sV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNyRixDQUFDO0lBRUQsSUFBVyxPQUFPO1FBQ2QsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVNLFdBQVcsQ0FBQyxHQUFXO1FBQzFCLElBQUksR0FBRyxDQUFDLE1BQU0sS0FBSyxlQUFlLEVBQUU7WUFDaEMsT0FBTztTQUNWO1FBRUQsTUFBTSxHQUFHLEdBQUcsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRTdCLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRU0sV0FBVyxDQUFDLEdBQUcsSUFBc0M7UUFDeEQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRU8sV0FBVyxDQUFDLEtBQXVDO1FBQ3ZELElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pDLENBQUM7K0dBNUNRLHFCQUFxQjttR0FBckIscUJBQXFCLDJIQ25CbEMsNHFFQTRFQTs7U0R6RGEscUJBQXFCOzRGQUFyQixxQkFBcUI7a0JBUGpDLFNBQVM7aUNBQ00sS0FBSyxZQUNQLGdCQUFnQixtQkFHVCx1QkFBdUIsQ0FBQyxNQUFNOzhCQUl4QyxLQUFLO3NCQURYLEtBQUs7Z0JBSVUsV0FBVztzQkFEMUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBJbnB1dCxcbiAgICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUge01hc2tpdG9PcHRpb25zfSBmcm9tICdAbWFza2l0by9jb3JlJztcbmltcG9ydCB7dHVpSGV4VG9SZ2IsIHR1aVJnYlRvSGV4fSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL2NvbG9yJztcblxuY29uc3QgSEVYX01PREVfTEVOR1RIID0gNjtcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogZmFsc2UsXG4gICAgc2VsZWN0b3I6ICd0dWktY29sb3ItZWRpdCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NvbG9yLWVkaXQudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vY29sb3ItZWRpdC5zdHlsZS5sZXNzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFR1aUNvbG9yRWRpdENvbXBvbmVudCB7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgY29sb3I6IFtudW1iZXIsIG51bWJlciwgbnVtYmVyLCBudW1iZXJdID0gWzAsIDAsIDAsIDFdO1xuXG4gICAgQE91dHB1dCgpXG4gICAgcHVibGljIHJlYWRvbmx5IGNvbG9yQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxbbnVtYmVyLCBudW1iZXIsIG51bWJlciwgbnVtYmVyXT4oKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBoZXhNYXNrOiBNYXNraXRvT3B0aW9ucyA9IHtcbiAgICAgICAgbWFzazogbmV3IFJlZ0V4cChgXltBLUZcXFxcZF17MCwke0hFWF9NT0RFX0xFTkdUSH19JGAsICdnaScpLFxuICAgIH07XG5cbiAgICBwdWJsaWMgcmVhZG9ubHkgbW9kZXMgPSBbJ0hFWCcsICdSR0InXTtcblxuICAgIHB1YmxpYyBtb2RlID0gdGhpcy5tb2Rlc1swXTtcblxuICAgIHB1YmxpYyBnZXQgaXNIZXgoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLm1vZGUgPT09IHRoaXMubW9kZXNbMF07XG4gICAgfVxuXG4gICAgcHVibGljIGdldCBoZXgoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIHR1aVJnYlRvSGV4KHRoaXMuY29sb3JbMF0sIHRoaXMuY29sb3JbMV0sIHRoaXMuY29sb3JbMl0pLnJlcGxhY2UoJyMnLCAnJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldCBvcGFjaXR5KCk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiBNYXRoLnJvdW5kKHRoaXMuY29sb3JbM10gKiAxMDApO1xuICAgIH1cblxuICAgIHB1YmxpYyBvbkhleENoYW5nZShoZXg6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICBpZiAoaGV4Lmxlbmd0aCAhPT0gSEVYX01PREVfTEVOR1RIKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCByZ2IgPSB0dWlIZXhUb1JnYihoZXgpO1xuXG4gICAgICAgIHRoaXMudXBkYXRlQ29sb3IoW3JnYlswXSwgcmdiWzFdLCByZ2JbMl0sIHRoaXMuY29sb3JbM11dKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb25SZ2JDaGFuZ2UoLi4ucmdiYTogW251bWJlciwgbnVtYmVyLCBudW1iZXIsIG51bWJlcl0pOiB2b2lkIHtcbiAgICAgICAgdGhpcy51cGRhdGVDb2xvcihyZ2JhKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIHVwZGF0ZUNvbG9yKGNvbG9yOiBbbnVtYmVyLCBudW1iZXIsIG51bWJlciwgbnVtYmVyXSk6IHZvaWQge1xuICAgICAgICB0aGlzLmNvbG9yID0gY29sb3I7XG4gICAgICAgIHRoaXMuY29sb3JDaGFuZ2UuZW1pdChjb2xvcik7XG4gICAgfVxufVxuIiwiPHR1aS1zZWxlY3RcbiAgICB0dWlEcm9wZG93bkFsaWduPVwibGVmdFwiXG4gICAgdHVpRHJvcGRvd25MaW1pdFdpZHRoPVwibWluXCJcbiAgICB0dWlUZXh0ZmllbGRTaXplPVwibVwiXG4gICAgY2xhc3M9XCJ0LXNlbGVjdFwiXG4gICAgW25nTW9kZWxPcHRpb25zXT1cIntzdGFuZGFsb25lOiB0cnVlfVwiXG4gICAgW3N0eWxlLmZsZXhdPVwiJzAgMCBhdXRvJ1wiXG4gICAgW3R1aVRleHRmaWVsZExhYmVsT3V0c2lkZV09XCJ0cnVlXCJcbiAgICBbKG5nTW9kZWwpXT1cIm1vZGVcIlxuPlxuICAgIDx0dWktZGF0YS1saXN0XG4gICAgICAgICp0dWlEYXRhTGlzdFxuICAgICAgICBzaXplPVwic1wiXG4gICAgPlxuICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiBtb2Rlc1wiXG4gICAgICAgICAgICB0dWlPcHRpb25cbiAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgW3ZhbHVlXT1cIml0ZW1cIlxuICAgICAgICA+XG4gICAgICAgICAgICB7eyBpdGVtIH19XG4gICAgICAgIDwvYnV0dG9uPlxuICAgIDwvdHVpLWRhdGEtbGlzdD5cbjwvdHVpLXNlbGVjdD5cbjx0dWktcHJpbWl0aXZlLXRleHRmaWVsZFxuICAgICpuZ0lmPVwiaXNIZXg7IGVsc2UgcmdiXCJcbiAgICB0dWlUZXh0ZmllbGRTaXplPVwibVwiXG4gICAgW21hc2tpdG9dPVwiaGV4TWFza1wiXG4gICAgW3R1aVRleHRmaWVsZExhYmVsT3V0c2lkZV09XCJ0cnVlXCJcbiAgICBbdmFsdWVdPVwiaGV4XCJcbiAgICAodmFsdWVDaGFuZ2UpPVwib25IZXhDaGFuZ2UoJGV2ZW50KVwiXG4vPlxuPG5nLXRlbXBsYXRlICNyZ2I+XG4gICAgPHR1aS1pbnB1dC1udW1iZXJcbiAgICAgICAgdHVpVGV4dGZpZWxkU2l6ZT1cIm1cIlxuICAgICAgICBjbGFzcz1cInQtcmdiXCJcbiAgICAgICAgW21heF09XCIyNTVcIlxuICAgICAgICBbbWluXT1cIjBcIlxuICAgICAgICBbbmdNb2RlbF09XCJjb2xvclswXVwiXG4gICAgICAgIFtuZ01vZGVsT3B0aW9uc109XCJ7c3RhbmRhbG9uZTogdHJ1ZX1cIlxuICAgICAgICBbdHVpVGV4dGZpZWxkTGFiZWxPdXRzaWRlXT1cInRydWVcIlxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJvblJnYkNoYW5nZSgkZXZlbnQsIGNvbG9yWzFdLCBjb2xvclsyXSwgY29sb3JbM10pXCJcbiAgICAvPlxuICAgIDx0dWktaW5wdXQtbnVtYmVyXG4gICAgICAgIHR1aVRleHRmaWVsZFNpemU9XCJtXCJcbiAgICAgICAgY2xhc3M9XCJ0LXJnYlwiXG4gICAgICAgIFttYXhdPVwiMjU1XCJcbiAgICAgICAgW21pbl09XCIwXCJcbiAgICAgICAgW25nTW9kZWxdPVwiY29sb3JbMV1cIlxuICAgICAgICBbbmdNb2RlbE9wdGlvbnNdPVwie3N0YW5kYWxvbmU6IHRydWV9XCJcbiAgICAgICAgW3R1aVRleHRmaWVsZExhYmVsT3V0c2lkZV09XCJ0cnVlXCJcbiAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwib25SZ2JDaGFuZ2UoY29sb3JbMF0sICRldmVudCwgY29sb3JbMl0sIGNvbG9yWzNdKVwiXG4gICAgLz5cbiAgICA8dHVpLWlucHV0LW51bWJlclxuICAgICAgICB0dWlUZXh0ZmllbGRTaXplPVwibVwiXG4gICAgICAgIGNsYXNzPVwidC1yZ2JcIlxuICAgICAgICBbbWF4XT1cIjI1NVwiXG4gICAgICAgIFttaW5dPVwiMFwiXG4gICAgICAgIFtuZ01vZGVsXT1cImNvbG9yWzJdXCJcbiAgICAgICAgW25nTW9kZWxPcHRpb25zXT1cIntzdGFuZGFsb25lOiB0cnVlfVwiXG4gICAgICAgIFt0dWlUZXh0ZmllbGRMYWJlbE91dHNpZGVdPVwidHJ1ZVwiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cIm9uUmdiQ2hhbmdlKGNvbG9yWzBdLCBjb2xvclsxXSwgJGV2ZW50LCBjb2xvclszXSlcIlxuICAgIC8+XG48L25nLXRlbXBsYXRlPlxuPHR1aS1pbnB1dC1udW1iZXJcbiAgICB0dWlUZXh0ZmllbGRQb3N0Zml4PVwiJVwiXG4gICAgdHVpVGV4dGZpZWxkU2l6ZT1cIm1cIlxuICAgIGNsYXNzPVwidC1vcGFjaXR5XCJcbiAgICBbbWF4XT1cIjEwMFwiXG4gICAgW21pbl09XCIwXCJcbiAgICBbbmdNb2RlbF09XCJvcGFjaXR5XCJcbiAgICBbbmdNb2RlbE9wdGlvbnNdPVwie3N0YW5kYWxvbmU6IHRydWV9XCJcbiAgICBbc3R5bGUuZmxleF09XCInMCAwIGF1dG8nXCJcbiAgICBbdHVpVGV4dGZpZWxkTGFiZWxPdXRzaWRlXT1cInRydWVcIlxuICAgIChuZ01vZGVsQ2hhbmdlKT1cIm9uUmdiQ2hhbmdlKGNvbG9yWzBdLCBjb2xvclsxXSwgY29sb3JbMl0sICRldmVudCAvIDEwMClcIlxuLz5cbiJdfQ==
@@ -53,7 +53,7 @@ class TuiColorPickerComponent {
53
53
  this.colorChange.emit([...this.currentColor, this.opacity]);
54
54
  }
55
55
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiColorPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
56
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiColorPickerComponent, selector: "tui-color-picker", inputs: { color: "color" }, outputs: { colorChange: "colorChange" }, host: { attributes: { "ngSkipHydration": "true" } }, ngImport: i0, template: "<tui-flat-picker\n class=\"t-flat\"\n [style.backgroundColor]=\"base\"\n [value]=\"point\"\n (valueChange)=\"onPointChange($event)\"\n/>\n<div class=\"t-wrapper t-wrapper_hue\">\n <tui-linear-picker\n class=\"t-hue\"\n [value]=\"hue\"\n (valueChange)=\"onHueChange($event)\"\n />\n</div>\n<div\n class=\"t-wrapper t-wrapper_opacity\"\n [style.background]=\"gradient\"\n>\n <tui-linear-picker\n class=\"t-opacity\"\n [value]=\"opacity\"\n (valueChange)=\"onOpacityChange($event)\"\n />\n</div>\n", styles: [":host{position:relative;display:block;isolation:isolate}.t-flat{block-size:14rem;background:linear-gradient(#0000,#000),linear-gradient(to right,#fff,#fff0);margin-bottom:.25rem;overflow:hidden}.t-wrapper{position:relative;margin:1rem 1.25rem;border-radius:.5rem}.t-wrapper:after{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";box-shadow:inset 0 0 0 1px #00000014;pointer-events:none;border-radius:inherit}.t-wrapper_hue{background:red}.t-wrapper_opacity:before{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";z-index:-1;background-image:linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03)),linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03));background-size:.375rem .375rem;background-position:0 0,.1875rem .1875rem;border-radius:inherit}.t-hue{background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);border-radius:inherit;margin:0 .5rem}.t-opacity{border-radius:inherit;margin:0 .5rem}\n"], dependencies: [{ kind: "component", type: i1.TuiFlatPickerComponent, selector: "tui-flat-picker", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: i2.TuiLinearPickerComponent, selector: "tui-linear-picker", inputs: ["value"], outputs: ["valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
56
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiColorPickerComponent, selector: "tui-color-picker", inputs: { color: "color" }, outputs: { colorChange: "colorChange" }, ngImport: i0, template: "<tui-flat-picker\n class=\"t-flat\"\n [style.backgroundColor]=\"base\"\n [value]=\"point\"\n (valueChange)=\"onPointChange($event)\"\n/>\n<div class=\"t-wrapper t-wrapper_hue\">\n <tui-linear-picker\n class=\"t-hue\"\n [value]=\"hue\"\n (valueChange)=\"onHueChange($event)\"\n />\n</div>\n<div\n class=\"t-wrapper t-wrapper_opacity\"\n [style.background]=\"gradient\"\n>\n <tui-linear-picker\n class=\"t-opacity\"\n [value]=\"opacity\"\n (valueChange)=\"onOpacityChange($event)\"\n />\n</div>\n", styles: [":host{position:relative;display:block;isolation:isolate}.t-flat{block-size:14rem;background:linear-gradient(#0000,#000),linear-gradient(to right,#fff,#fff0);margin-bottom:.25rem;overflow:hidden}.t-wrapper{position:relative;margin:1rem 1.25rem;border-radius:.5rem}.t-wrapper:after{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";box-shadow:inset 0 0 0 1px #00000014;pointer-events:none;border-radius:inherit}.t-wrapper_hue{background:red}.t-wrapper_opacity:before{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";z-index:-1;background-image:linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03)),linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03));background-size:.375rem .375rem;background-position:0 0,.1875rem .1875rem;border-radius:inherit}.t-hue{background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);border-radius:inherit;margin:0 .5rem}.t-opacity{border-radius:inherit;margin:0 .5rem}\n"], dependencies: [{ kind: "component", type: i1.TuiFlatPickerComponent, selector: "tui-flat-picker", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: i2.TuiLinearPickerComponent, selector: "tui-linear-picker", inputs: ["value"], outputs: ["valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
57
57
  }
58
58
  __decorate([
59
59
  tuiPure
@@ -61,12 +61,10 @@ __decorate([
61
61
  export { TuiColorPickerComponent };
62
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiColorPickerComponent, decorators: [{
63
63
  type: Component,
64
- args: [{ standalone: false, selector: 'tui-color-picker', changeDetection: ChangeDetectionStrategy.OnPush, host: {
65
- ngSkipHydration: 'true',
66
- }, template: "<tui-flat-picker\n class=\"t-flat\"\n [style.backgroundColor]=\"base\"\n [value]=\"point\"\n (valueChange)=\"onPointChange($event)\"\n/>\n<div class=\"t-wrapper t-wrapper_hue\">\n <tui-linear-picker\n class=\"t-hue\"\n [value]=\"hue\"\n (valueChange)=\"onHueChange($event)\"\n />\n</div>\n<div\n class=\"t-wrapper t-wrapper_opacity\"\n [style.background]=\"gradient\"\n>\n <tui-linear-picker\n class=\"t-opacity\"\n [value]=\"opacity\"\n (valueChange)=\"onOpacityChange($event)\"\n />\n</div>\n", styles: [":host{position:relative;display:block;isolation:isolate}.t-flat{block-size:14rem;background:linear-gradient(#0000,#000),linear-gradient(to right,#fff,#fff0);margin-bottom:.25rem;overflow:hidden}.t-wrapper{position:relative;margin:1rem 1.25rem;border-radius:.5rem}.t-wrapper:after{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";box-shadow:inset 0 0 0 1px #00000014;pointer-events:none;border-radius:inherit}.t-wrapper_hue{background:red}.t-wrapper_opacity:before{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";z-index:-1;background-image:linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03)),linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03));background-size:.375rem .375rem;background-position:0 0,.1875rem .1875rem;border-radius:inherit}.t-hue{background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);border-radius:inherit;margin:0 .5rem}.t-opacity{border-radius:inherit;margin:0 .5rem}\n"] }]
64
+ args: [{ standalone: false, selector: 'tui-color-picker', changeDetection: ChangeDetectionStrategy.OnPush, template: "<tui-flat-picker\n class=\"t-flat\"\n [style.backgroundColor]=\"base\"\n [value]=\"point\"\n (valueChange)=\"onPointChange($event)\"\n/>\n<div class=\"t-wrapper t-wrapper_hue\">\n <tui-linear-picker\n class=\"t-hue\"\n [value]=\"hue\"\n (valueChange)=\"onHueChange($event)\"\n />\n</div>\n<div\n class=\"t-wrapper t-wrapper_opacity\"\n [style.background]=\"gradient\"\n>\n <tui-linear-picker\n class=\"t-opacity\"\n [value]=\"opacity\"\n (valueChange)=\"onOpacityChange($event)\"\n />\n</div>\n", styles: [":host{position:relative;display:block;isolation:isolate}.t-flat{block-size:14rem;background:linear-gradient(#0000,#000),linear-gradient(to right,#fff,#fff0);margin-bottom:.25rem;overflow:hidden}.t-wrapper{position:relative;margin:1rem 1.25rem;border-radius:.5rem}.t-wrapper:after{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";box-shadow:inset 0 0 0 1px #00000014;pointer-events:none;border-radius:inherit}.t-wrapper_hue{background:red}.t-wrapper_opacity:before{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;content:\"\";z-index:-1;background-image:linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03)),linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03));background-size:.375rem .375rem;background-position:0 0,.1875rem .1875rem;border-radius:inherit}.t-hue{background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);border-radius:inherit;margin:0 .5rem}.t-opacity{border-radius:inherit;margin:0 .5rem}\n"] }]
67
65
  }], propDecorators: { colorChange: [{
68
66
  type: Output
69
67
  }], color: [{
70
68
  type: Input
71
69
  }], getCurrentColor: [] } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItcGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xlZ2FjeS9jb21wb25lbnRzL2NvbG9yLXNlbGVjdG9yL2NvbG9yLXBpY2tlci9jb2xvci1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvY29sb3Itc2VsZWN0b3IvY29sb3ItcGlja2VyL2NvbG9yLXBpY2tlci50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFDTCxNQUFNLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxXQUFXLEVBQUUsV0FBVyxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDbkUsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQ2xELE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQzs7OztBQUcxRCxNQVVhLHVCQUF1QjtJQVZwQztRQVdxQixjQUFTLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRXhDLFVBQUssR0FBYSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUN6QixRQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ1IsWUFBTyxHQUFHLENBQUMsQ0FBQztRQUdOLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBRTNDLENBQUM7S0E0RFA7SUExREcsSUFDVyxLQUFLLENBQUMsS0FBeUQ7UUFDdEUsSUFDSSxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLElBQUksS0FBSyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDL0QsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxPQUFPLEVBQzNCO1lBQ0UsT0FBTztTQUNWO1FBRUQsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFNUQsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEIsSUFBSSxDQUFDLEdBQUcsR0FBRyxDQUFDLEdBQUcsR0FBRyxDQUFDO1FBQ25CLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQsSUFBVyxZQUFZO1FBQ25CLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRUQsSUFBVyxJQUFJO1FBQ1gsT0FBTyxPQUFPLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsRUFBRSxDQUFDLEVBQUUsR0FBRyxDQUFDLEdBQUcsQ0FBQztJQUN6RCxDQUFDO0lBRUQsSUFBVyxRQUFRO1FBQ2YsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLHdCQUF3QixDQUMxQyxrQ0FBa0MsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQ3BELEdBQUcsQ0FDTixhQUFhLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQ2hELENBQUM7SUFDTixDQUFDO0lBRU0sYUFBYSxDQUFDLEtBQWU7UUFDaEMsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFTSxXQUFXLENBQUMsR0FBVztRQUMxQixJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztRQUNmLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRU0sZUFBZSxDQUFDLE9BQWU7UUFDbEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxRQUFRLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3BDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBR08sZUFBZSxDQUNuQixHQUFXLEVBQ1gsS0FBZTtRQUVmLE9BQU8sV0FBVyxDQUFDLEdBQUcsR0FBRyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7SUFFTyxXQUFXO1FBQ2YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDaEUsQ0FBQzsrR0FyRVEsdUJBQXVCO21HQUF2Qix1QkFBdUIsa0xDekJwQyx3akJBdUJBOztBRDhEWTtJQURQLE9BQU87OERBTVA7U0FqRVEsdUJBQXVCOzRGQUF2Qix1QkFBdUI7a0JBVm5DLFNBQVM7aUNBQ00sS0FBSyxZQUNQLGtCQUFrQixtQkFHWCx1QkFBdUIsQ0FBQyxNQUFNLFFBQ3pDO3dCQUNGLGVBQWUsRUFBRSxNQUFNO3FCQUMxQjs4QkFVZSxXQUFXO3NCQUQxQixNQUFNO2dCQU1JLEtBQUs7c0JBRGYsS0FBSztnQkFnREUsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBpbmplY3QsXG4gICAgSW5wdXQsXG4gICAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHtTYWZlU3R5bGV9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHtEb21TYW5pdGl6ZXJ9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHt0dWlIc3ZUb1JnYiwgdHVpUmdiVG9Ic3Z9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvY29sb3InO1xuaW1wb3J0IHt0dWlSb3VuZH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9tYXRoJztcbmltcG9ydCB7dHVpUHVyZX0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9taXNjZWxsYW5lb3VzJztcbmltcG9ydCB0eXBlIHtUdWlQb2ludH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiBmYWxzZSxcbiAgICBzZWxlY3RvcjogJ3R1aS1jb2xvci1waWNrZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9jb2xvci1waWNrZXIudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vY29sb3ItcGlja2VyLnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBob3N0OiB7XG4gICAgICAgIG5nU2tpcEh5ZHJhdGlvbjogJ3RydWUnLFxuICAgIH0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aUNvbG9yUGlja2VyQ29tcG9uZW50IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHNhbml0aXplciA9IGluamVjdChEb21TYW5pdGl6ZXIpO1xuXG4gICAgcHJvdGVjdGVkIHBvaW50OiBUdWlQb2ludCA9IFswLCAxXTtcbiAgICBwcm90ZWN0ZWQgaHVlID0gMDtcbiAgICBwcm90ZWN0ZWQgb3BhY2l0eSA9IDE7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgcmVhZG9ubHkgY29sb3JDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPFxuICAgICAgICBbaDogbnVtYmVyLCBzOiBudW1iZXIsIHY6IG51bWJlciwgb3BhY2l0eTogbnVtYmVyXVxuICAgID4oKTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNldCBjb2xvcihjb2xvcjogW2g6IG51bWJlciwgczogbnVtYmVyLCB2OiBudW1iZXIsIG9wYWNpdHk6IG51bWJlcl0pIHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICAgdGhpcy5jdXJyZW50Q29sb3IuZXZlcnkoKGl0ZW0sIGluZGV4KSA9PiBpdGVtID09PSBjb2xvcltpbmRleF0pICYmXG4gICAgICAgICAgICBjb2xvclszXSA9PT0gdGhpcy5vcGFjaXR5XG4gICAgICAgICkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgW2gsIHMsIHZdID0gdHVpUmdiVG9Ic3YoY29sb3JbMF0sIGNvbG9yWzFdLCBjb2xvclsyXSk7XG5cbiAgICAgICAgdGhpcy5vcGFjaXR5ID0gY29sb3JbM107XG4gICAgICAgIHRoaXMuaHVlID0gaCAvIDM2MDtcbiAgICAgICAgdGhpcy5wb2ludCA9IFtzLCAxIC0gdiAvIDI1NV07XG4gICAgfVxuXG4gICAgcHVibGljIGdldCBjdXJyZW50Q29sb3IoKTogW2g6IG51bWJlciwgczogbnVtYmVyLCB2OiBudW1iZXJdIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZ2V0Q3VycmVudENvbG9yKHRoaXMuaHVlLCB0aGlzLnBvaW50KTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGJhc2UoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIGByZ2IoJHt0dWlIc3ZUb1JnYih0aGlzLmh1ZSAqIDM2MCwgMSwgMjU1KX0pYDtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGdyYWRpZW50KCk6IFNhZmVTdHlsZSB7XG4gICAgICAgIHJldHVybiB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0U3R5bGUoXG4gICAgICAgICAgICBgbGluZWFyLWdyYWRpZW50KHRvIHJpZ2h0LCByZ2JhKCR7dGhpcy5jdXJyZW50Q29sb3Iuam9pbihcbiAgICAgICAgICAgICAgICAnLCcsXG4gICAgICAgICAgICApfSwgMCksIHJnYigke3RoaXMuY3VycmVudENvbG9yLmpvaW4oJywnKX0pKWAsXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgcHVibGljIG9uUG9pbnRDaGFuZ2UocG9pbnQ6IFR1aVBvaW50KTogdm9pZCB7XG4gICAgICAgIHRoaXMucG9pbnQgPSBwb2ludDtcbiAgICAgICAgdGhpcy51cGRhdGVDb2xvcigpO1xuICAgIH1cblxuICAgIHB1YmxpYyBvbkh1ZUNoYW5nZShodWU6IG51bWJlcik6IHZvaWQge1xuICAgICAgICB0aGlzLmh1ZSA9IGh1ZTtcbiAgICAgICAgdGhpcy51cGRhdGVDb2xvcigpO1xuICAgIH1cblxuICAgIHB1YmxpYyBvbk9wYWNpdHlDaGFuZ2Uob3BhY2l0eTogbnVtYmVyKTogdm9pZCB7XG4gICAgICAgIHRoaXMub3BhY2l0eSA9IHR1aVJvdW5kKG9wYWNpdHksIDIpO1xuICAgICAgICB0aGlzLnVwZGF0ZUNvbG9yKCk7XG4gICAgfVxuXG4gICAgQHR1aVB1cmVcbiAgICBwcml2YXRlIGdldEN1cnJlbnRDb2xvcihcbiAgICAgICAgaHVlOiBudW1iZXIsXG4gICAgICAgIHBvaW50OiBUdWlQb2ludCxcbiAgICApOiBbaDogbnVtYmVyLCBzOiBudW1iZXIsIHY6IG51bWJlcl0ge1xuICAgICAgICByZXR1cm4gdHVpSHN2VG9SZ2IoaHVlICogMzYwLCBwb2ludFswXSwgKDEgLSBwb2ludFsxXSkgKiAyNTUpO1xuICAgIH1cblxuICAgIHByaXZhdGUgdXBkYXRlQ29sb3IoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY29sb3JDaGFuZ2UuZW1pdChbLi4udGhpcy5jdXJyZW50Q29sb3IsIHRoaXMub3BhY2l0eV0pO1xuICAgIH1cbn1cbiIsIjx0dWktZmxhdC1waWNrZXJcbiAgICBjbGFzcz1cInQtZmxhdFwiXG4gICAgW3N0eWxlLmJhY2tncm91bmRDb2xvcl09XCJiYXNlXCJcbiAgICBbdmFsdWVdPVwicG9pbnRcIlxuICAgICh2YWx1ZUNoYW5nZSk9XCJvblBvaW50Q2hhbmdlKCRldmVudClcIlxuLz5cbjxkaXYgY2xhc3M9XCJ0LXdyYXBwZXIgdC13cmFwcGVyX2h1ZVwiPlxuICAgIDx0dWktbGluZWFyLXBpY2tlclxuICAgICAgICBjbGFzcz1cInQtaHVlXCJcbiAgICAgICAgW3ZhbHVlXT1cImh1ZVwiXG4gICAgICAgICh2YWx1ZUNoYW5nZSk9XCJvbkh1ZUNoYW5nZSgkZXZlbnQpXCJcbiAgICAvPlxuPC9kaXY+XG48ZGl2XG4gICAgY2xhc3M9XCJ0LXdyYXBwZXIgdC13cmFwcGVyX29wYWNpdHlcIlxuICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cImdyYWRpZW50XCJcbj5cbiAgICA8dHVpLWxpbmVhci1waWNrZXJcbiAgICAgICAgY2xhc3M9XCJ0LW9wYWNpdHlcIlxuICAgICAgICBbdmFsdWVdPVwib3BhY2l0eVwiXG4gICAgICAgICh2YWx1ZUNoYW5nZSk9XCJvbk9wYWNpdHlDaGFuZ2UoJGV2ZW50KVwiXG4gICAgLz5cbjwvZGl2PlxuIl19
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItcGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xlZ2FjeS9jb21wb25lbnRzL2NvbG9yLXNlbGVjdG9yL2NvbG9yLXBpY2tlci9jb2xvci1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvY29sb3Itc2VsZWN0b3IvY29sb3ItcGlja2VyL2NvbG9yLXBpY2tlci50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFDTCxNQUFNLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxXQUFXLEVBQUUsV0FBVyxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDbkUsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQ2xELE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQzs7OztBQUcxRCxNQU9hLHVCQUF1QjtJQVBwQztRQVFxQixjQUFTLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBRXhDLFVBQUssR0FBYSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUN6QixRQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQ1IsWUFBTyxHQUFHLENBQUMsQ0FBQztRQUdOLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBRTNDLENBQUM7S0E0RFA7SUExREcsSUFDVyxLQUFLLENBQUMsS0FBeUQ7UUFDdEUsSUFDSSxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLElBQUksS0FBSyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDL0QsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxPQUFPLEVBQzNCO1lBQ0UsT0FBTztTQUNWO1FBRUQsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFNUQsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEIsSUFBSSxDQUFDLEdBQUcsR0FBRyxDQUFDLEdBQUcsR0FBRyxDQUFDO1FBQ25CLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQsSUFBVyxZQUFZO1FBQ25CLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRUQsSUFBVyxJQUFJO1FBQ1gsT0FBTyxPQUFPLFdBQVcsQ0FBQyxJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsRUFBRSxDQUFDLEVBQUUsR0FBRyxDQUFDLEdBQUcsQ0FBQztJQUN6RCxDQUFDO0lBRUQsSUFBVyxRQUFRO1FBQ2YsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLHdCQUF3QixDQUMxQyxrQ0FBa0MsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQ3BELEdBQUcsQ0FDTixhQUFhLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQ2hELENBQUM7SUFDTixDQUFDO0lBRU0sYUFBYSxDQUFDLEtBQWU7UUFDaEMsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFTSxXQUFXLENBQUMsR0FBVztRQUMxQixJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztRQUNmLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRU0sZUFBZSxDQUFDLE9BQWU7UUFDbEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxRQUFRLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3BDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBR08sZUFBZSxDQUNuQixHQUFXLEVBQ1gsS0FBZTtRQUVmLE9BQU8sV0FBVyxDQUFDLEdBQUcsR0FBRyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDO0lBQ2xFLENBQUM7SUFFTyxXQUFXO1FBQ2YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDaEUsQ0FBQzsrR0FyRVEsdUJBQXVCO21HQUF2Qix1QkFBdUIsNkhDdEJwQyx3akJBdUJBOztBRDJEWTtJQURQLE9BQU87OERBTVA7U0FqRVEsdUJBQXVCOzRGQUF2Qix1QkFBdUI7a0JBUG5DLFNBQVM7aUNBQ00sS0FBSyxZQUNQLGtCQUFrQixtQkFHWCx1QkFBdUIsQ0FBQyxNQUFNOzhCQVUvQixXQUFXO3NCQUQxQixNQUFNO2dCQU1JLEtBQUs7c0JBRGYsS0FBSztnQkFnREUsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBpbmplY3QsXG4gICAgSW5wdXQsXG4gICAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHtTYWZlU3R5bGV9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHtEb21TYW5pdGl6ZXJ9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHt0dWlIc3ZUb1JnYiwgdHVpUmdiVG9Ic3Z9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvY29sb3InO1xuaW1wb3J0IHt0dWlSb3VuZH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9tYXRoJztcbmltcG9ydCB7dHVpUHVyZX0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9taXNjZWxsYW5lb3VzJztcbmltcG9ydCB0eXBlIHtUdWlQb2ludH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiBmYWxzZSxcbiAgICBzZWxlY3RvcjogJ3R1aS1jb2xvci1waWNrZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9jb2xvci1waWNrZXIudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vY29sb3ItcGlja2VyLnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpQ29sb3JQaWNrZXJDb21wb25lbnQge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgc2FuaXRpemVyID0gaW5qZWN0KERvbVNhbml0aXplcik7XG5cbiAgICBwcm90ZWN0ZWQgcG9pbnQ6IFR1aVBvaW50ID0gWzAsIDFdO1xuICAgIHByb3RlY3RlZCBodWUgPSAwO1xuICAgIHByb3RlY3RlZCBvcGFjaXR5ID0gMTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyByZWFkb25seSBjb2xvckNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8XG4gICAgICAgIFtoOiBudW1iZXIsIHM6IG51bWJlciwgdjogbnVtYmVyLCBvcGFjaXR5OiBudW1iZXJdXG4gICAgPigpO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgc2V0IGNvbG9yKGNvbG9yOiBbaDogbnVtYmVyLCBzOiBudW1iZXIsIHY6IG51bWJlciwgb3BhY2l0eTogbnVtYmVyXSkge1xuICAgICAgICBpZiAoXG4gICAgICAgICAgICB0aGlzLmN1cnJlbnRDb2xvci5ldmVyeSgoaXRlbSwgaW5kZXgpID0+IGl0ZW0gPT09IGNvbG9yW2luZGV4XSkgJiZcbiAgICAgICAgICAgIGNvbG9yWzNdID09PSB0aGlzLm9wYWNpdHlcbiAgICAgICAgKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBbaCwgcywgdl0gPSB0dWlSZ2JUb0hzdihjb2xvclswXSwgY29sb3JbMV0sIGNvbG9yWzJdKTtcblxuICAgICAgICB0aGlzLm9wYWNpdHkgPSBjb2xvclszXTtcbiAgICAgICAgdGhpcy5odWUgPSBoIC8gMzYwO1xuICAgICAgICB0aGlzLnBvaW50ID0gW3MsIDEgLSB2IC8gMjU1XTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGN1cnJlbnRDb2xvcigpOiBbaDogbnVtYmVyLCBzOiBudW1iZXIsIHY6IG51bWJlcl0ge1xuICAgICAgICByZXR1cm4gdGhpcy5nZXRDdXJyZW50Q29sb3IodGhpcy5odWUsIHRoaXMucG9pbnQpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgYmFzZSgpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gYHJnYigke3R1aUhzdlRvUmdiKHRoaXMuaHVlICogMzYwLCAxLCAyNTUpfSlgO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgZ3JhZGllbnQoKTogU2FmZVN0eWxlIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RTdHlsZShcbiAgICAgICAgICAgIGBsaW5lYXItZ3JhZGllbnQodG8gcmlnaHQsIHJnYmEoJHt0aGlzLmN1cnJlbnRDb2xvci5qb2luKFxuICAgICAgICAgICAgICAgICcsJyxcbiAgICAgICAgICAgICl9LCAwKSwgcmdiKCR7dGhpcy5jdXJyZW50Q29sb3Iuam9pbignLCcpfSkpYCxcbiAgICAgICAgKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb25Qb2ludENoYW5nZShwb2ludDogVHVpUG9pbnQpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5wb2ludCA9IHBvaW50O1xuICAgICAgICB0aGlzLnVwZGF0ZUNvbG9yKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG9uSHVlQ2hhbmdlKGh1ZTogbnVtYmVyKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaHVlID0gaHVlO1xuICAgICAgICB0aGlzLnVwZGF0ZUNvbG9yKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG9uT3BhY2l0eUNoYW5nZShvcGFjaXR5OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5vcGFjaXR5ID0gdHVpUm91bmQob3BhY2l0eSwgMik7XG4gICAgICAgIHRoaXMudXBkYXRlQ29sb3IoKTtcbiAgICB9XG5cbiAgICBAdHVpUHVyZVxuICAgIHByaXZhdGUgZ2V0Q3VycmVudENvbG9yKFxuICAgICAgICBodWU6IG51bWJlcixcbiAgICAgICAgcG9pbnQ6IFR1aVBvaW50LFxuICAgICk6IFtoOiBudW1iZXIsIHM6IG51bWJlciwgdjogbnVtYmVyXSB7XG4gICAgICAgIHJldHVybiB0dWlIc3ZUb1JnYihodWUgKiAzNjAsIHBvaW50WzBdLCAoMSAtIHBvaW50WzFdKSAqIDI1NSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSB1cGRhdGVDb2xvcigpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jb2xvckNoYW5nZS5lbWl0KFsuLi50aGlzLmN1cnJlbnRDb2xvciwgdGhpcy5vcGFjaXR5XSk7XG4gICAgfVxufVxuIiwiPHR1aS1mbGF0LXBpY2tlclxuICAgIGNsYXNzPVwidC1mbGF0XCJcbiAgICBbc3R5bGUuYmFja2dyb3VuZENvbG9yXT1cImJhc2VcIlxuICAgIFt2YWx1ZV09XCJwb2ludFwiXG4gICAgKHZhbHVlQ2hhbmdlKT1cIm9uUG9pbnRDaGFuZ2UoJGV2ZW50KVwiXG4vPlxuPGRpdiBjbGFzcz1cInQtd3JhcHBlciB0LXdyYXBwZXJfaHVlXCI+XG4gICAgPHR1aS1saW5lYXItcGlja2VyXG4gICAgICAgIGNsYXNzPVwidC1odWVcIlxuICAgICAgICBbdmFsdWVdPVwiaHVlXCJcbiAgICAgICAgKHZhbHVlQ2hhbmdlKT1cIm9uSHVlQ2hhbmdlKCRldmVudClcIlxuICAgIC8+XG48L2Rpdj5cbjxkaXZcbiAgICBjbGFzcz1cInQtd3JhcHBlciB0LXdyYXBwZXJfb3BhY2l0eVwiXG4gICAgW3N0eWxlLmJhY2tncm91bmRdPVwiZ3JhZGllbnRcIlxuPlxuICAgIDx0dWktbGluZWFyLXBpY2tlclxuICAgICAgICBjbGFzcz1cInQtb3BhY2l0eVwiXG4gICAgICAgIFt2YWx1ZV09XCJvcGFjaXR5XCJcbiAgICAgICAgKHZhbHVlQ2hhbmdlKT1cIm9uT3BhY2l0eUNoYW5nZSgkZXZlbnQpXCJcbiAgICAvPlxuPC9kaXY+XG4iXX0=