@snabcentr/client-ui 3.48.1 → 3.49.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (81) hide show
  1. package/auth/sc-auth.module.d.ts +8 -8
  2. package/banner/sc-banner.module.d.ts +2 -3
  3. package/catalog/price-card-inline/sc-price-card-inline.component.d.ts +1 -1
  4. package/catalog/sc-catalog.module.d.ts +1 -1
  5. package/contacts/sc-contacts.module.d.ts +12 -13
  6. package/contacts/tokens/sc-manager-qr-handler.token.d.ts +1 -1
  7. package/contragents/sc-contragents.module.d.ts +8 -9
  8. package/delivery-address/sc-delivery-address.module.d.ts +11 -12
  9. package/error-handler/consts/error-change-handler.providers.d.ts +2 -1
  10. package/esm2022/auth/sc-auth.module.mjs +2 -4
  11. package/esm2022/auth/sc-sign-in-form/sc-sign-in-form-by-phone/sc-sign-in-form-by-phone.component.mjs +5 -6
  12. package/esm2022/auth/sc-simple-sign-up-form/sc-simple-sign-up-form.component.mjs +2 -1
  13. package/esm2022/auth/sign-up-form/sc-sign-up-form.component.mjs +10 -10
  14. package/esm2022/banner/sc-banner.component.mjs +4 -5
  15. package/esm2022/banner/sc-banner.module.mjs +3 -4
  16. package/esm2022/cart/add-or-editing-cart-item-dialog/add-or-editing-cart-item-form/sc-add-or-editing-cart-item-form.component.mjs +2 -2
  17. package/esm2022/cart/cart-item/sc-cart-item.component.mjs +3 -3
  18. package/esm2022/catalog/catalog-filters/sc-catalog-filters.component.mjs +2 -3
  19. package/esm2022/catalog/price-history/sc-price-history.component.mjs +7 -7
  20. package/esm2022/catalog/price-warehouse-stock/sc-price-warehouse-stock.component.mjs +3 -4
  21. package/esm2022/catalog/sc-catalog.module.mjs +2 -4
  22. package/esm2022/contacts/contacts-accordion/sc-contacts-accordion.component.mjs +6 -7
  23. package/esm2022/contacts/sc-contacts.module.mjs +1 -4
  24. package/esm2022/contacts/tokens/sc-manager-qr-handler.token.mjs +17 -16
  25. package/esm2022/contacts/tokens/sc-show-help-notification-in-phone-input.token.mjs +6 -4
  26. package/esm2022/contragents/contragents-accordion/contragents-accordion-item/sc-contragents-accordion-item.component.mjs +4 -5
  27. package/esm2022/contragents/contragents-accordion/sc-contragents-accordion.component.mjs +4 -5
  28. package/esm2022/contragents/sc-contragents.module.mjs +1 -4
  29. package/esm2022/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.mjs +2 -4
  30. package/esm2022/delivery-address/delivery-address-accordion/sc-delivery-address-accordion.component.mjs +6 -7
  31. package/esm2022/delivery-address/sc-delivery-address.module.mjs +1 -4
  32. package/esm2022/directives/abstract-price-card/abstract-sc-price-card.directive.mjs +2 -2
  33. package/esm2022/error-handler/consts/error-change-handler.providers.mjs +5 -3
  34. package/esm2022/feedback/feedback-form/sc-feedback-form.component.mjs +2 -2
  35. package/esm2022/form-fields/addresses-selection-field/sc-addresses-selection-field.component.mjs +6 -7
  36. package/esm2022/form-fields/form-fields.module.mjs +1 -4
  37. package/esm2022/form-fields/suggestion-field/sc-suggestion-field.component.mjs +6 -7
  38. package/esm2022/news/news-card/sc-news-card.component.mjs +1 -1
  39. package/esm2022/pages/frequently-asked-questions/sc-page-size-options.mjs +5 -3
  40. package/esm2022/profile/sc-profile-accordions-content/sc-profile-accordions-content.component.mjs +10 -11
  41. package/esm2022/profile/sc-profile.module.mjs +1 -4
  42. package/esm2022/providers/index.mjs +1 -2
  43. package/esm2022/providers/sc-allow-select-terminated.mjs +5 -3
  44. package/esm2022/providers/sc-banner-duration.mjs +5 -3
  45. package/esm2022/providers/sc-country-ids.mjs +5 -3
  46. package/esm2022/providers/sc-date-formatter.mjs +10 -7
  47. package/esm2022/providers/sc-help-notification-close.mjs +5 -3
  48. package/esm2022/providers/sc-help-notification-limit.mjs +5 -3
  49. package/esm2022/providers/sc-max-files-in-form-input.mjs +5 -3
  50. package/esm2022/providers/sc-notify-when-in-stock-required-fields.mjs +5 -3
  51. package/esm2022/providers/sc-page-size-options.mjs +5 -3
  52. package/esm2022/providers/sc-user-providers.mjs +17 -12
  53. package/esm2022/providers/sc-verification-code-timeout.mjs +5 -3
  54. package/esm2022/public-api.mjs +1 -5
  55. package/esm2022/samples/sc-sample.module.mjs +2 -4
  56. package/esm2022/user/reset-user-password/sc-reset-user-password.component.mjs +4 -5
  57. package/esm2022/user/sc-user.module.mjs +1 -4
  58. package/esm2022/user/update-user-info-dialog/sc-update-user-info-dialog.component.mjs +11 -12
  59. package/esm2022/user/user-phone-approve-dialog/sc-user-phone-approve-dialog.component.mjs +7 -8
  60. package/esm2022/verification/sc-verification.module.mjs +2 -4
  61. package/esm2022/verification/verification-phone-check-form/sc-verification-phone-check-form.component.mjs +6 -6
  62. package/fesm2022/snabcentr-client-ui.mjs +285 -497
  63. package/fesm2022/snabcentr-client-ui.mjs.map +1 -1
  64. package/form-fields/form-fields.module.d.ts +4 -5
  65. package/news/news-card/sc-news-card.component.d.ts +2 -2
  66. package/package.json +7 -8
  67. package/profile/sc-profile.module.d.ts +8 -9
  68. package/providers/index.d.ts +0 -1
  69. package/public-api.d.ts +0 -1
  70. package/samples/sc-sample.module.d.ts +1 -1
  71. package/styles/tailwind/tailwind.scss +1 -1
  72. package/user/sc-user.module.d.ts +7 -8
  73. package/verification/sc-verification.module.d.ts +7 -7
  74. package/esm2022/providers/sc-category.providers.mjs +0 -43
  75. package/esm2022/schemas/breadcrumb-list.interface.mjs +0 -2
  76. package/esm2022/schemas/index.mjs +0 -3
  77. package/esm2022/schemas/sc-json-ld-category/sc-json-ld-category.component.mjs +0 -192
  78. package/providers/sc-category.providers.d.ts +0 -11
  79. package/schemas/breadcrumb-list.interface.d.ts +0 -38
  80. package/schemas/index.d.ts +0 -2
  81. package/schemas/sc-json-ld-category/sc-json-ld-category.component.d.ts +0 -63
@@ -11,10 +11,9 @@ import * as i2 from "@angular/common";
11
11
  import * as i3 from "@angular/forms";
12
12
  import * as i4 from "@taiga-ui/legacy/components/primitive-textfield";
13
13
  import * as i5 from "@taiga-ui/core";
14
- import * as i6 from "@taiga-ui/cdk";
15
- import * as i7 from "@taiga-ui/core/components/data-list";
16
- import * as i8 from "@taiga-ui/legacy";
17
- import * as i9 from "@taiga-ui/kit";
14
+ import * as i6 from "@taiga-ui/core/components/data-list";
15
+ import * as i7 from "@taiga-ui/legacy";
16
+ import * as i8 from "@taiga-ui/kit";
18
17
  /**
19
18
  * Компонент поля ввода страны/региона/города.
20
19
  */
@@ -143,15 +142,15 @@ export class ScAddressesSelectionFieldComponent {
143
142
  }
144
143
  }
145
144
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScAddressesSelectionFieldComponent, deps: [{ token: FormGroupDirective, skipSelf: true }, { token: i1.ScLocationsService }], target: i0.ɵɵFactoryTarget.Component }); }
146
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.14", type: ScAddressesSelectionFieldComponent, selector: "sc-addresses-selection-field", inputs: { canSelectCountry: { classPropertyName: "canSelectCountry", publicName: "canSelectCountry", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { canSelectCountry: "canSelectCountryChange" }, ngImport: i0, template: "<label\n *ngIf=\"canSelectCountry()\"\n tuiLabel\n class=\"mb-2\"\n>\n \u0421\u0442\u0440\u0430\u043D\u0430\n <tui-combo-box\n *tuiLet=\"(countries$ | async) ?? [] as countries\"\n [formControl]=\"countryControl\"\n [stringify]=\"stringify\"\n >\n \u0421\u0442\u0440\u0430\u043D\u0430\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"countries | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"countryControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n</label>\n<div class=\"grid items-start gap-4 sm:grid-cols-2\">\n <label tuiLabel>\n \u0420\u0435\u0433\u0438\u043E\u043D\n <tui-combo-box\n *tuiLet=\"(regions$ | async) ?? [] as regions\"\n [formControl]=\"regionControl\"\n [stringify]=\"stringify\"\n >\n \u0420\u0435\u0433\u0438\u043E\u043D\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"regions | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"regionControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel>\n \u0413\u043E\u0440\u043E\u0434\n <tui-combo-box\n *tuiLet=\"(cities$ | async) ?? [] as cities\"\n [formControl]=\"cityControl\"\n [stringify]=\"stringify\"\n (ngModelChange)=\"onSelectedCity($event)\"\n >\n \u0413\u043E\u0440\u043E\u0434\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"cities | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"cityIdControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n <tui-error\n *ngIf=\"cityIdControl.untouched\"\n [formControl]=\"cityControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4.TuiTextfieldComponent, selector: "input[tuiTextfieldLegacy], textarea[tuiTextfieldLegacy]" }, { kind: "directive", type: i5.TuiLabel, selector: "label[tuiLabel]" }, { kind: "directive", type: i6.TuiLet, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i5.TuiError, selector: "tui-error", inputs: ["error"] }, { kind: "directive", type: i7.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { kind: "component", type: i8.TuiComboBoxComponent, selector: "tui-combo-box", inputs: ["stringify", "strictMatcher", "identityMatcher", "valueContent", "strict", "search"], outputs: ["searchChange"] }, { kind: "directive", type: i8.TuiComboBoxDirective, selector: "tui-combo-box" }, { kind: "component", type: i9.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]", inputs: ["items", "disabledItemHandler", "emptyContent", "size", "itemContent"], outputs: ["itemClick"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TuiFieldErrorPipe, name: "tuiFieldError" }, { kind: "pipe", type: i9.TuiFilterByInputPipe, name: "tuiFilterByInput" }, { kind: "pipe", type: i9.TuiStringifyContentPipe, name: "tuiStringifyContent" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
145
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.14", type: ScAddressesSelectionFieldComponent, selector: "sc-addresses-selection-field", inputs: { canSelectCountry: { classPropertyName: "canSelectCountry", publicName: "canSelectCountry", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { canSelectCountry: "canSelectCountryChange" }, ngImport: i0, template: "<label\n *ngIf=\"canSelectCountry()\"\n tuiLabel\n class=\"mb-2\"\n>\n \u0421\u0442\u0440\u0430\u043D\u0430\n @let countries = (countries$ | async) ?? [];\n <tui-combo-box\n [formControl]=\"countryControl\"\n [stringify]=\"stringify\"\n >\n \u0421\u0442\u0440\u0430\u043D\u0430\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"countries | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"countryControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n</label>\n<div class=\"grid items-start gap-4 sm:grid-cols-2\">\n <label tuiLabel>\n \u0420\u0435\u0433\u0438\u043E\u043D\n @let regions = (regions$ | async) ?? [];\n <tui-combo-box\n [formControl]=\"regionControl\"\n [stringify]=\"stringify\"\n >\n \u0420\u0435\u0433\u0438\u043E\u043D\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"regions | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"regionControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel>\n \u0413\u043E\u0440\u043E\u0434\n @let cities = (cities$ | async) ?? [];\n <tui-combo-box\n [formControl]=\"cityControl\"\n [stringify]=\"stringify\"\n (ngModelChange)=\"onSelectedCity($event)\"\n >\n \u0413\u043E\u0440\u043E\u0434\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"cities | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"cityIdControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n <tui-error\n *ngIf=\"cityIdControl.untouched\"\n [formControl]=\"cityControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4.TuiTextfieldComponent, selector: "input[tuiTextfieldLegacy], textarea[tuiTextfieldLegacy]" }, { kind: "directive", type: i5.TuiLabel, selector: "label[tuiLabel]" }, { kind: "component", type: i5.TuiError, selector: "tui-error", inputs: ["error"] }, { kind: "directive", type: i6.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { kind: "component", type: i7.TuiComboBoxComponent, selector: "tui-combo-box", inputs: ["stringify", "strictMatcher", "identityMatcher", "valueContent", "strict", "search"], outputs: ["searchChange"] }, { kind: "directive", type: i7.TuiComboBoxDirective, selector: "tui-combo-box" }, { kind: "component", type: i8.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]", inputs: ["items", "disabledItemHandler", "emptyContent", "size", "itemContent"], outputs: ["itemClick"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TuiFieldErrorPipe, name: "tuiFieldError" }, { kind: "pipe", type: i8.TuiFilterByInputPipe, name: "tuiFilterByInput" }, { kind: "pipe", type: i8.TuiStringifyContentPipe, name: "tuiStringifyContent" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
147
146
  }
148
147
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScAddressesSelectionFieldComponent, decorators: [{
149
148
  type: Component,
150
- args: [{ selector: 'sc-addresses-selection-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<label\n *ngIf=\"canSelectCountry()\"\n tuiLabel\n class=\"mb-2\"\n>\n \u0421\u0442\u0440\u0430\u043D\u0430\n <tui-combo-box\n *tuiLet=\"(countries$ | async) ?? [] as countries\"\n [formControl]=\"countryControl\"\n [stringify]=\"stringify\"\n >\n \u0421\u0442\u0440\u0430\u043D\u0430\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"countries | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"countryControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n</label>\n<div class=\"grid items-start gap-4 sm:grid-cols-2\">\n <label tuiLabel>\n \u0420\u0435\u0433\u0438\u043E\u043D\n <tui-combo-box\n *tuiLet=\"(regions$ | async) ?? [] as regions\"\n [formControl]=\"regionControl\"\n [stringify]=\"stringify\"\n >\n \u0420\u0435\u0433\u0438\u043E\u043D\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"regions | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"regionControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel>\n \u0413\u043E\u0440\u043E\u0434\n <tui-combo-box\n *tuiLet=\"(cities$ | async) ?? [] as cities\"\n [formControl]=\"cityControl\"\n [stringify]=\"stringify\"\n (ngModelChange)=\"onSelectedCity($event)\"\n >\n \u0413\u043E\u0440\u043E\u0434\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"cities | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"cityIdControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n <tui-error\n *ngIf=\"cityIdControl.untouched\"\n [formControl]=\"cityControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n</div>\n" }]
149
+ args: [{ selector: 'sc-addresses-selection-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<label\n *ngIf=\"canSelectCountry()\"\n tuiLabel\n class=\"mb-2\"\n>\n \u0421\u0442\u0440\u0430\u043D\u0430\n @let countries = (countries$ | async) ?? [];\n <tui-combo-box\n [formControl]=\"countryControl\"\n [stringify]=\"stringify\"\n >\n \u0421\u0442\u0440\u0430\u043D\u0430\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"countries | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"countryControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n</label>\n<div class=\"grid items-start gap-4 sm:grid-cols-2\">\n <label tuiLabel>\n \u0420\u0435\u0433\u0438\u043E\u043D\n @let regions = (regions$ | async) ?? [];\n <tui-combo-box\n [formControl]=\"regionControl\"\n [stringify]=\"stringify\"\n >\n \u0420\u0435\u0433\u0438\u043E\u043D\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"regions | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"regionControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel>\n \u0413\u043E\u0440\u043E\u0434\n @let cities = (cities$ | async) ?? [];\n <tui-combo-box\n [formControl]=\"cityControl\"\n [stringify]=\"stringify\"\n (ngModelChange)=\"onSelectedCity($event)\"\n >\n \u0413\u043E\u0440\u043E\u0434\n <input\n tuiTextfieldLegacy\n autocapitalize=\"off\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocomplete=\"new-password\"\n />\n <tui-data-list-wrapper\n *tuiDataList\n [itemContent]=\"stringify | tuiStringifyContent\"\n [items]=\"cities | tuiFilterByInput\"\n ></tui-data-list-wrapper>\n </tui-combo-box>\n <tui-error\n [formControl]=\"cityIdControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n <tui-error\n *ngIf=\"cityIdControl.untouched\"\n [formControl]=\"cityControl\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n</div>\n" }]
151
150
  }], ctorParameters: () => [{ type: i3.FormGroupDirective, decorators: [{
152
151
  type: SkipSelf
153
152
  }, {
154
153
  type: Inject,
155
154
  args: [FormGroupDirective]
156
155
  }] }, { type: i1.ScLocationsService }] });
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-addresses-selection-field.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/form-fields/addresses-selection-field/sc-addresses-selection-field.component.ts","../../../../../projects/client-ui/form-fields/addresses-selection-field/sc-addresses-selection-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-unused-expressions,class-methods-use-this,@typescript-eslint/unbound-method */\n\nimport { ChangeDetectionStrategy, Component, DestroyRef, effect, Inject, inject, model, OnInit, SkipSelf } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { FormControl, FormGroupDirective, Validators } from '@angular/forms';\nimport { ScICity, ScICityWithRegionAndCountry, ScICountry, ScIRegion, ScLocationsService } from '@snabcentr/client-core';\nimport { tuiControlValue, tuiIsPresent, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { combineLatest, debounceTime, filter, Observable, of, share, startWith, switchMap } from 'rxjs';\n\nimport { CURRENT_COUNTRY_ID } from '../../providers/sc-country-ids';\n\n/**\n * Компонент поля ввода страны/региона/города.\n */\n@Component({\n    selector: 'sc-addresses-selection-field',\n    templateUrl: './sc-addresses-selection-field.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddressesSelectionFieldComponent implements OnInit {\n    /**\n     * Флаг возможности выбора страны.\n     */\n    public readonly canSelectCountry = model<boolean>(false);\n\n    /**\n     * Идентификатор текущей страны системы.\n     */\n    private readonly russiaCountryId: number = inject(CURRENT_COUNTRY_ID);\n\n    /**\n     * FormControl для поля страны.\n     */\n    protected readonly countryControl: FormControl<ScICountry | null> = new FormControl<ScICountry | null>(null, Validators.required);\n\n    /**\n     * FormControl для поля региона.\n     */\n    protected readonly regionControl: FormControl<ScIRegion | null> = new FormControl<ScIRegion | null>(null, Validators.required);\n\n    /**\n     * FormControl для поля города.\n     */\n    protected cityControl: FormControl<ScICity | null> = new FormControl<ScICountry | null>(null, Validators.required);\n\n    /**\n     * {@link Observable} изменения списка стран.\n     */\n    protected countries$: Observable<ScICountry[] | null> = this.locationsService.getCountries$().pipe(share(), startWith(null));\n\n    /**\n     * {@link Observable} изменения списка регионов.\n     */\n    protected regions$: Observable<ScIRegion[] | null> = tuiControlValue<ScIRegion | null>(this.countryControl).pipe(\n        filter(tuiIsPresent),\n        switchMap((country: ScICountry) => this.locationsService.getRegions$(country.id).pipe(startWith(null))),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения списка городов.\n     */\n    protected cities$: Observable<ScICity[] | null> = combineLatest({\n        country: tuiControlValue<ScIRegion | null>(this.countryControl),\n        region: tuiControlValue<ScICity | null>(this.regionControl),\n    }).pipe(\n        debounceTime(0),\n        switchMap(({ country, region }: { country: ScIRegion | null; region: ScICity | null }) =>\n            country && region ? this.locationsService.getCities$(country.id, region.id).pipe(startWith(null)) : of([])\n        ),\n        share()\n    );\n\n    /**\n     * Ссылка для автоматического управления уничтожением зависимостей.\n     */\n    private destroyRef: DestroyRef = inject(DestroyRef);\n\n    /**\n     * Функция преобразования объекта сортировки в значение, отображаемое в поле ввода.\n     *\n     * @param item Выбранный объект выпадающего списка.\n     * @param item.name Название страны/региона/города, которое будет отображено в поле.\n     */\n    protected readonly stringify = (item: { name: string }): string => item.name;\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddressesSelectionFieldComponent}.\n     *\n     * @param formGroupDirective Директива c `FormGroup` из DOM.\n     * @param locationsService Сервис для получения списков стран, регионов, городов.\n     */\n    public constructor(\n        @SkipSelf() @Inject(FormGroupDirective) private readonly formGroupDirective: FormGroupDirective,\n        private readonly locationsService: ScLocationsService\n    ) {\n        effect(() => {\n            if (this.canSelectCountry()) {\n                this.countryControl.setValue(null);\n            } else {\n                this.countryControl.setValue({\n                    id: this.russiaCountryId,\n                    name: 'Россия',\n                });\n            }\n        });\n    }\n\n    /**\n     * `FormControl` поля идентификатора города.\n     */\n    public get cityIdControl(): FormControl<string | null> {\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        return this.formGroupDirective.form.get('cityId')! as FormControl<string | null>;\n    }\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        if (this.cityIdControl.valid) {\n            this.locationsService\n                .getCityById$(Number(this.cityIdControl.value))\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe((city: ScICityWithRegionAndCountry) => {\n                    this.canSelectCountry.set(city.region.country.id !== this.russiaCountryId);\n                    setTimeout(() => {\n                        this.countryControl.patchValue(city.region.country);\n                        this.regionControl.patchValue(city.region);\n                        this.cityControl.patchValue(city);\n                    });\n                });\n        }\n\n        this.countryControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((country) => {\n            this.regionControl.reset(null);\n            this.cityControl.reset(null);\n\n            if (country) {\n                this.regionControl.enable();\n            } else {\n                this.regionControl.disable();\n            }\n\n            this.cityControl.disable();\n        });\n\n        this.regionControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((region) => {\n            this.cityControl.reset(null);\n            this.cityIdControl.reset(null);\n\n            if (region) {\n                this.cityControl.enable();\n            } else {\n                this.cityControl.disable();\n            }\n        });\n    }\n\n    /**\n     * Заполнение полей банковских реквизитов на основе выбранной подсказки.\n     *\n     * @param city Идентификатор записи города.\n     */\n    protected onSelectedCity(city: ScICity | null): void {\n        // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n        if (this.cityIdControl) {\n            this.cityIdControl.setValue(city?.id.toString() ?? null);\n            tuiMarkControlAsTouchedAndValidate(this.cityIdControl);\n        }\n    }\n}\n","<label\n    *ngIf=\"canSelectCountry()\"\n    tuiLabel\n    class=\"mb-2\"\n>\n    Страна\n    <tui-combo-box\n        *tuiLet=\"(countries$ | async) ?? [] as countries\"\n        [formControl]=\"countryControl\"\n        [stringify]=\"stringify\"\n    >\n        Страна\n        <input\n            tuiTextfieldLegacy\n            autocapitalize=\"off\"\n            autocomplete=\"off\"\n            autocorrect=\"off\"\n            autocomplete=\"new-password\"\n        />\n        <tui-data-list-wrapper\n            *tuiDataList\n            [itemContent]=\"stringify | tuiStringifyContent\"\n            [items]=\"countries | tuiFilterByInput\"\n        ></tui-data-list-wrapper>\n    </tui-combo-box>\n    <tui-error\n        [formControl]=\"countryControl\"\n        [error]=\"[] | tuiFieldError | async\"\n    ></tui-error>\n</label>\n<div class=\"grid items-start gap-4 sm:grid-cols-2\">\n    <label tuiLabel>\n        Регион\n        <tui-combo-box\n            *tuiLet=\"(regions$ | async) ?? [] as regions\"\n            [formControl]=\"regionControl\"\n            [stringify]=\"stringify\"\n        >\n            Регион\n            <input\n                tuiTextfieldLegacy\n                autocapitalize=\"off\"\n                autocomplete=\"off\"\n                autocorrect=\"off\"\n                autocomplete=\"new-password\"\n            />\n            <tui-data-list-wrapper\n                *tuiDataList\n                [itemContent]=\"stringify | tuiStringifyContent\"\n                [items]=\"regions | tuiFilterByInput\"\n            ></tui-data-list-wrapper>\n        </tui-combo-box>\n        <tui-error\n            [formControl]=\"regionControl\"\n            [error]=\"[] | tuiFieldError | async\"\n        ></tui-error>\n    </label>\n    <label tuiLabel>\n        Город\n        <tui-combo-box\n            *tuiLet=\"(cities$ | async) ?? [] as cities\"\n            [formControl]=\"cityControl\"\n            [stringify]=\"stringify\"\n            (ngModelChange)=\"onSelectedCity($event)\"\n        >\n            Город\n            <input\n                tuiTextfieldLegacy\n                autocapitalize=\"off\"\n                autocomplete=\"off\"\n                autocorrect=\"off\"\n                autocomplete=\"new-password\"\n            />\n            <tui-data-list-wrapper\n                *tuiDataList\n                [itemContent]=\"stringify | tuiStringifyContent\"\n                [items]=\"cities | tuiFilterByInput\"\n            ></tui-data-list-wrapper>\n        </tui-combo-box>\n        <tui-error\n            [formControl]=\"cityIdControl\"\n            [error]=\"[] | tuiFieldError | async\"\n        ></tui-error>\n        <tui-error\n            *ngIf=\"cityIdControl.untouched\"\n            [formControl]=\"cityControl\"\n            [error]=\"[] | tuiFieldError | async\"\n        ></tui-error>\n    </label>\n</div>\n"]}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-addresses-selection-field.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/form-fields/addresses-selection-field/sc-addresses-selection-field.component.ts","../../../../../projects/client-ui/form-fields/addresses-selection-field/sc-addresses-selection-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-unused-expressions,class-methods-use-this,@typescript-eslint/unbound-method */\n\nimport { ChangeDetectionStrategy, Component, DestroyRef, effect, Inject, inject, model, OnInit, SkipSelf } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { FormControl, FormGroupDirective, Validators } from '@angular/forms';\nimport { ScICity, ScICityWithRegionAndCountry, ScICountry, ScIRegion, ScLocationsService } from '@snabcentr/client-core';\nimport { tuiControlValue, tuiIsPresent, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { combineLatest, debounceTime, filter, Observable, of, share, startWith, switchMap } from 'rxjs';\n\nimport { CURRENT_COUNTRY_ID } from '../../providers/sc-country-ids';\n\n/**\n * Компонент поля ввода страны/региона/города.\n */\n@Component({\n    selector: 'sc-addresses-selection-field',\n    templateUrl: './sc-addresses-selection-field.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddressesSelectionFieldComponent implements OnInit {\n    /**\n     * Флаг возможности выбора страны.\n     */\n    public readonly canSelectCountry = model<boolean>(false);\n\n    /**\n     * Идентификатор текущей страны системы.\n     */\n    private readonly russiaCountryId: number = inject(CURRENT_COUNTRY_ID);\n\n    /**\n     * FormControl для поля страны.\n     */\n    protected readonly countryControl: FormControl<ScICountry | null> = new FormControl<ScICountry | null>(null, Validators.required);\n\n    /**\n     * FormControl для поля региона.\n     */\n    protected readonly regionControl: FormControl<ScIRegion | null> = new FormControl<ScIRegion | null>(null, Validators.required);\n\n    /**\n     * FormControl для поля города.\n     */\n    protected cityControl: FormControl<ScICity | null> = new FormControl<ScICountry | null>(null, Validators.required);\n\n    /**\n     * {@link Observable} изменения списка стран.\n     */\n    protected countries$: Observable<ScICountry[] | null> = this.locationsService.getCountries$().pipe(share(), startWith(null));\n\n    /**\n     * {@link Observable} изменения списка регионов.\n     */\n    protected regions$: Observable<ScIRegion[] | null> = tuiControlValue<ScIRegion | null>(this.countryControl).pipe(\n        filter(tuiIsPresent),\n        switchMap((country: ScICountry) => this.locationsService.getRegions$(country.id).pipe(startWith(null))),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения списка городов.\n     */\n    protected cities$: Observable<ScICity[] | null> = combineLatest({\n        country: tuiControlValue<ScIRegion | null>(this.countryControl),\n        region: tuiControlValue<ScICity | null>(this.regionControl),\n    }).pipe(\n        debounceTime(0),\n        switchMap(({ country, region }: { country: ScIRegion | null; region: ScICity | null }) =>\n            country && region ? this.locationsService.getCities$(country.id, region.id).pipe(startWith(null)) : of([])\n        ),\n        share()\n    );\n\n    /**\n     * Ссылка для автоматического управления уничтожением зависимостей.\n     */\n    private destroyRef: DestroyRef = inject(DestroyRef);\n\n    /**\n     * Функция преобразования объекта сортировки в значение, отображаемое в поле ввода.\n     *\n     * @param item Выбранный объект выпадающего списка.\n     * @param item.name Название страны/региона/города, которое будет отображено в поле.\n     */\n    protected readonly stringify = (item: { name: string }): string => item.name;\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddressesSelectionFieldComponent}.\n     *\n     * @param formGroupDirective Директива c `FormGroup` из DOM.\n     * @param locationsService Сервис для получения списков стран, регионов, городов.\n     */\n    public constructor(\n        @SkipSelf() @Inject(FormGroupDirective) private readonly formGroupDirective: FormGroupDirective,\n        private readonly locationsService: ScLocationsService\n    ) {\n        effect(() => {\n            if (this.canSelectCountry()) {\n                this.countryControl.setValue(null);\n            } else {\n                this.countryControl.setValue({\n                    id: this.russiaCountryId,\n                    name: 'Россия',\n                });\n            }\n        });\n    }\n\n    /**\n     * `FormControl` поля идентификатора города.\n     */\n    public get cityIdControl(): FormControl<string | null> {\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        return this.formGroupDirective.form.get('cityId')! as FormControl<string | null>;\n    }\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        if (this.cityIdControl.valid) {\n            this.locationsService\n                .getCityById$(Number(this.cityIdControl.value))\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe((city: ScICityWithRegionAndCountry) => {\n                    this.canSelectCountry.set(city.region.country.id !== this.russiaCountryId);\n                    setTimeout(() => {\n                        this.countryControl.patchValue(city.region.country);\n                        this.regionControl.patchValue(city.region);\n                        this.cityControl.patchValue(city);\n                    });\n                });\n        }\n\n        this.countryControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((country) => {\n            this.regionControl.reset(null);\n            this.cityControl.reset(null);\n\n            if (country) {\n                this.regionControl.enable();\n            } else {\n                this.regionControl.disable();\n            }\n\n            this.cityControl.disable();\n        });\n\n        this.regionControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((region) => {\n            this.cityControl.reset(null);\n            this.cityIdControl.reset(null);\n\n            if (region) {\n                this.cityControl.enable();\n            } else {\n                this.cityControl.disable();\n            }\n        });\n    }\n\n    /**\n     * Заполнение полей банковских реквизитов на основе выбранной подсказки.\n     *\n     * @param city Идентификатор записи города.\n     */\n    protected onSelectedCity(city: ScICity | null): void {\n        // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n        if (this.cityIdControl) {\n            this.cityIdControl.setValue(city?.id.toString() ?? null);\n            tuiMarkControlAsTouchedAndValidate(this.cityIdControl);\n        }\n    }\n}\n","<label\n    *ngIf=\"canSelectCountry()\"\n    tuiLabel\n    class=\"mb-2\"\n>\n    Страна\n    @let countries = (countries$ | async) ?? [];\n    <tui-combo-box\n        [formControl]=\"countryControl\"\n        [stringify]=\"stringify\"\n    >\n        Страна\n        <input\n            tuiTextfieldLegacy\n            autocapitalize=\"off\"\n            autocomplete=\"off\"\n            autocorrect=\"off\"\n            autocomplete=\"new-password\"\n        />\n        <tui-data-list-wrapper\n            *tuiDataList\n            [itemContent]=\"stringify | tuiStringifyContent\"\n            [items]=\"countries | tuiFilterByInput\"\n        ></tui-data-list-wrapper>\n    </tui-combo-box>\n    <tui-error\n        [formControl]=\"countryControl\"\n        [error]=\"[] | tuiFieldError | async\"\n    ></tui-error>\n</label>\n<div class=\"grid items-start gap-4 sm:grid-cols-2\">\n    <label tuiLabel>\n        Регион\n        @let regions = (regions$ | async) ?? [];\n        <tui-combo-box\n            [formControl]=\"regionControl\"\n            [stringify]=\"stringify\"\n        >\n            Регион\n            <input\n                tuiTextfieldLegacy\n                autocapitalize=\"off\"\n                autocomplete=\"off\"\n                autocorrect=\"off\"\n                autocomplete=\"new-password\"\n            />\n            <tui-data-list-wrapper\n                *tuiDataList\n                [itemContent]=\"stringify | tuiStringifyContent\"\n                [items]=\"regions | tuiFilterByInput\"\n            ></tui-data-list-wrapper>\n        </tui-combo-box>\n        <tui-error\n            [formControl]=\"regionControl\"\n            [error]=\"[] | tuiFieldError | async\"\n        ></tui-error>\n    </label>\n    <label tuiLabel>\n        Город\n        @let cities = (cities$ | async) ?? [];\n        <tui-combo-box\n            [formControl]=\"cityControl\"\n            [stringify]=\"stringify\"\n            (ngModelChange)=\"onSelectedCity($event)\"\n        >\n            Город\n            <input\n                tuiTextfieldLegacy\n                autocapitalize=\"off\"\n                autocomplete=\"off\"\n                autocorrect=\"off\"\n                autocomplete=\"new-password\"\n            />\n            <tui-data-list-wrapper\n                *tuiDataList\n                [itemContent]=\"stringify | tuiStringifyContent\"\n                [items]=\"cities | tuiFilterByInput\"\n            ></tui-data-list-wrapper>\n        </tui-combo-box>\n        <tui-error\n            [formControl]=\"cityIdControl\"\n            [error]=\"[] | tuiFieldError | async\"\n        ></tui-error>\n        <tui-error\n            *ngIf=\"cityIdControl.untouched\"\n            [formControl]=\"cityControl\"\n            [error]=\"[] | tuiFieldError | async\"\n        ></tui-error>\n    </label>\n</div>\n"]}
@@ -2,7 +2,6 @@ import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
3
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  import { MaskitoDirective } from '@maskito/angular';
5
- import { TuiLet } from '@taiga-ui/cdk';
6
5
  import { TuiButton, TuiDataList, TuiError, TuiLabel, TuiLoader } from '@taiga-ui/core';
7
6
  import { TuiDataListWrapper, TuiFieldErrorPipe, TuiFilterByInputPipe, TuiStringifyContentPipe } from '@taiga-ui/kit';
8
7
  import { TuiComboBoxModule, TuiInputModule, TuiInputPhoneModule, TuiTextfieldControllerModule } from '@taiga-ui/legacy';
@@ -23,7 +22,6 @@ export class ScFormFieldsModule {
23
22
  TuiInputModule,
24
23
  TuiTextfieldControllerModule,
25
24
  TuiLabel,
26
- TuiLet,
27
25
  TuiFieldErrorPipe,
28
26
  TuiError, i1.TuiDataListComponent, i1.TuiDataListDirective, i1.TuiOption, i1.TuiOptionNew, i1.TuiOptionWithValue, i1.TuiOptGroup, TuiLoader,
29
27
  TuiComboBoxModule, i2.TuiDataListWrapperComponent, i2.TuiDataListGroupWrapperComponent, i3.TuiDataListDirective, TuiFilterByInputPipe,
@@ -50,7 +48,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
50
48
  TuiInputModule,
51
49
  TuiTextfieldControllerModule,
52
50
  TuiLabel,
53
- TuiLet,
54
51
  TuiFieldErrorPipe,
55
52
  TuiError,
56
53
  ...TuiDataList,
@@ -66,4 +63,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
66
63
  exports: [ScAddressesSelectionFieldComponent, ScSuggestionFieldComponent],
67
64
  }]
68
65
  }] });
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXVpL2Zvcm0tZmllbGRzL2Zvcm0tZmllbGRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDcEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxpQkFBaUIsRUFBRSxvQkFBb0IsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNySCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsY0FBYyxFQUFFLG1CQUFtQixFQUFFLDRCQUE0QixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFeEgsT0FBTyxFQUFFLGtDQUFrQyxFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDeEgsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sa0RBQWtELENBQUM7Ozs7O0FBRTlGOztHQUVHO0FBeUJILE1BQU0sT0FBTyxrQkFBa0I7K0dBQWxCLGtCQUFrQjtnSEFBbEIsa0JBQWtCLGlCQXZCWixrQ0FBa0MsRUFBRSwwQkFBMEIsYUFFekUsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsY0FBYztZQUNkLDRCQUE0QjtZQUM1QixRQUFRO1lBQ1IsTUFBTTtZQUNOLGlCQUFpQjtZQUNqQixRQUFRLDBIQUVSLFNBQVM7WUFDVCxpQkFBaUIsZ0dBRWpCLG9CQUFvQjtZQUNwQix1QkFBdUI7WUFDdkIsbUJBQW1CO1lBQ25CLFNBQVM7WUFDVCxnQkFBZ0IsYUFFVixrQ0FBa0MsRUFBRSwwQkFBMEI7Z0hBRS9ELGtCQUFrQixZQXJCdkIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsY0FBYztZQUNkLDRCQUE0QjtZQUk1QixRQUFRLHlDQUVSLFNBQVM7WUFDVCxpQkFBaUIsdUVBSWpCLG1CQUFtQjs7NEZBTWQsa0JBQWtCO2tCQXhCOUIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxrQ0FBa0MsRUFBRSwwQkFBMEIsQ0FBQztvQkFDOUUsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QsNEJBQTRCO3dCQUM1QixRQUFRO3dCQUNSLE1BQU07d0JBQ04saUJBQWlCO3dCQUNqQixRQUFRO3dCQUNSLEdBQUcsV0FBVzt3QkFDZCxTQUFTO3dCQUNULGlCQUFpQjt3QkFDakIsR0FBRyxrQkFBa0I7d0JBQ3JCLG9CQUFvQjt3QkFDcEIsdUJBQXVCO3dCQUN2QixtQkFBbUI7d0JBQ25CLFNBQVM7d0JBQ1QsZ0JBQWdCO3FCQUNuQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxrQ0FBa0MsRUFBRSwwQkFBMEIsQ0FBQztpQkFDNUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWFza2l0b0RpcmVjdGl2ZSB9IGZyb20gJ0BtYXNraXRvL2FuZ3VsYXInO1xuaW1wb3J0IHsgVHVpTGV0IH0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQgeyBUdWlCdXR0b24sIFR1aURhdGFMaXN0LCBUdWlFcnJvciwgVHVpTGFiZWwsIFR1aUxvYWRlciB9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcbmltcG9ydCB7IFR1aURhdGFMaXN0V3JhcHBlciwgVHVpRmllbGRFcnJvclBpcGUsIFR1aUZpbHRlckJ5SW5wdXRQaXBlLCBUdWlTdHJpbmdpZnlDb250ZW50UGlwZSB9IGZyb20gJ0B0YWlnYS11aS9raXQnO1xuaW1wb3J0IHsgVHVpQ29tYm9Cb3hNb2R1bGUsIFR1aUlucHV0TW9kdWxlLCBUdWlJbnB1dFBob25lTW9kdWxlLCBUdWlUZXh0ZmllbGRDb250cm9sbGVyTW9kdWxlIH0gZnJvbSAnQHRhaWdhLXVpL2xlZ2FjeSc7XG5cbmltcG9ydCB7IFNjQWRkcmVzc2VzU2VsZWN0aW9uRmllbGRDb21wb25lbnQgfSBmcm9tICcuL2FkZHJlc3Nlcy1zZWxlY3Rpb24tZmllbGQvc2MtYWRkcmVzc2VzLXNlbGVjdGlvbi1maWVsZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2NTdWdnZXN0aW9uRmllbGRDb21wb25lbnQgfSBmcm9tICcuL3N1Z2dlc3Rpb24tZmllbGQvc2Mtc3VnZ2VzdGlvbi1maWVsZC5jb21wb25lbnQnO1xuXG4vKipcbiAqINCc0L7QtNGD0LvRjCDQv9C+0LvQtdC5INCy0LLQvtC00LAuXG4gKi9cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbU2NBZGRyZXNzZXNTZWxlY3Rpb25GaWVsZENvbXBvbmVudCwgU2NTdWdnZXN0aW9uRmllbGRDb21wb25lbnRdLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBGb3Jtc01vZHVsZSxcbiAgICAgICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICAgICAgVHVpSW5wdXRNb2R1bGUsXG4gICAgICAgIFR1aVRleHRmaWVsZENvbnRyb2xsZXJNb2R1bGUsXG4gICAgICAgIFR1aUxhYmVsLFxuICAgICAgICBUdWlMZXQsXG4gICAgICAgIFR1aUZpZWxkRXJyb3JQaXBlLFxuICAgICAgICBUdWlFcnJvcixcbiAgICAgICAgLi4uVHVpRGF0YUxpc3QsXG4gICAgICAgIFR1aUxvYWRlcixcbiAgICAgICAgVHVpQ29tYm9Cb3hNb2R1bGUsXG4gICAgICAgIC4uLlR1aURhdGFMaXN0V3JhcHBlcixcbiAgICAgICAgVHVpRmlsdGVyQnlJbnB1dFBpcGUsXG4gICAgICAgIFR1aVN0cmluZ2lmeUNvbnRlbnRQaXBlLFxuICAgICAgICBUdWlJbnB1dFBob25lTW9kdWxlLFxuICAgICAgICBUdWlCdXR0b24sXG4gICAgICAgIE1hc2tpdG9EaXJlY3RpdmUsXG4gICAgXSxcbiAgICBleHBvcnRzOiBbU2NBZGRyZXNzZXNTZWxlY3Rpb25GaWVsZENvbXBvbmVudCwgU2NTdWdnZXN0aW9uRmllbGRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBTY0Zvcm1GaWVsZHNNb2R1bGUge31cbiJdfQ==
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXVpL2Zvcm0tZmllbGRzL2Zvcm0tZmllbGRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN2RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLEVBQUUsb0JBQW9CLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDckgsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGNBQWMsRUFBRSxtQkFBbUIsRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRXhILE9BQU8sRUFBRSxrQ0FBa0MsRUFBRSxNQUFNLG9FQUFvRSxDQUFDO0FBQ3hILE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGtEQUFrRCxDQUFDOzs7OztBQUU5Rjs7R0FFRztBQXdCSCxNQUFNLE9BQU8sa0JBQWtCOytHQUFsQixrQkFBa0I7Z0hBQWxCLGtCQUFrQixpQkF0Qlosa0NBQWtDLEVBQUUsMEJBQTBCLGFBRXpFLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGNBQWM7WUFDZCw0QkFBNEI7WUFDNUIsUUFBUTtZQUNSLGlCQUFpQjtZQUNqQixRQUFRLDBIQUVSLFNBQVM7WUFDVCxpQkFBaUIsZ0dBRWpCLG9CQUFvQjtZQUNwQix1QkFBdUI7WUFDdkIsbUJBQW1CO1lBQ25CLFNBQVM7WUFDVCxnQkFBZ0IsYUFFVixrQ0FBa0MsRUFBRSwwQkFBMEI7Z0hBRS9ELGtCQUFrQixZQXBCdkIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsY0FBYztZQUNkLDRCQUE0QjtZQUc1QixRQUFRLHlDQUVSLFNBQVM7WUFDVCxpQkFBaUIsdUVBSWpCLG1CQUFtQjs7NEZBTWQsa0JBQWtCO2tCQXZCOUIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxrQ0FBa0MsRUFBRSwwQkFBMEIsQ0FBQztvQkFDOUUsT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QsNEJBQTRCO3dCQUM1QixRQUFRO3dCQUNSLGlCQUFpQjt3QkFDakIsUUFBUTt3QkFDUixHQUFHLFdBQVc7d0JBQ2QsU0FBUzt3QkFDVCxpQkFBaUI7d0JBQ2pCLEdBQUcsa0JBQWtCO3dCQUNyQixvQkFBb0I7d0JBQ3BCLHVCQUF1Qjt3QkFDdkIsbUJBQW1CO3dCQUNuQixTQUFTO3dCQUNULGdCQUFnQjtxQkFDbkI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsa0NBQWtDLEVBQUUsMEJBQTBCLENBQUM7aUJBQzVFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE1hc2tpdG9EaXJlY3RpdmUgfSBmcm9tICdAbWFza2l0by9hbmd1bGFyJztcbmltcG9ydCB7IFR1aUJ1dHRvbiwgVHVpRGF0YUxpc3QsIFR1aUVycm9yLCBUdWlMYWJlbCwgVHVpTG9hZGVyIH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuaW1wb3J0IHsgVHVpRGF0YUxpc3RXcmFwcGVyLCBUdWlGaWVsZEVycm9yUGlwZSwgVHVpRmlsdGVyQnlJbnB1dFBpcGUsIFR1aVN0cmluZ2lmeUNvbnRlbnRQaXBlIH0gZnJvbSAnQHRhaWdhLXVpL2tpdCc7XG5pbXBvcnQgeyBUdWlDb21ib0JveE1vZHVsZSwgVHVpSW5wdXRNb2R1bGUsIFR1aUlucHV0UGhvbmVNb2R1bGUsIFR1aVRleHRmaWVsZENvbnRyb2xsZXJNb2R1bGUgfSBmcm9tICdAdGFpZ2EtdWkvbGVnYWN5JztcblxuaW1wb3J0IHsgU2NBZGRyZXNzZXNTZWxlY3Rpb25GaWVsZENvbXBvbmVudCB9IGZyb20gJy4vYWRkcmVzc2VzLXNlbGVjdGlvbi1maWVsZC9zYy1hZGRyZXNzZXMtc2VsZWN0aW9uLWZpZWxkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTY1N1Z2dlc3Rpb25GaWVsZENvbXBvbmVudCB9IGZyb20gJy4vc3VnZ2VzdGlvbi1maWVsZC9zYy1zdWdnZXN0aW9uLWZpZWxkLmNvbXBvbmVudCc7XG5cbi8qKlxuICog0JzQvtC00YPQu9GMINC/0L7Qu9C10Lkg0LLQstC+0LTQsC5cbiAqL1xuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtTY0FkZHJlc3Nlc1NlbGVjdGlvbkZpZWxkQ29tcG9uZW50LCBTY1N1Z2dlc3Rpb25GaWVsZENvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIEZvcm1zTW9kdWxlLFxuICAgICAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgICAgICBUdWlJbnB1dE1vZHVsZSxcbiAgICAgICAgVHVpVGV4dGZpZWxkQ29udHJvbGxlck1vZHVsZSxcbiAgICAgICAgVHVpTGFiZWwsXG4gICAgICAgIFR1aUZpZWxkRXJyb3JQaXBlLFxuICAgICAgICBUdWlFcnJvcixcbiAgICAgICAgLi4uVHVpRGF0YUxpc3QsXG4gICAgICAgIFR1aUxvYWRlcixcbiAgICAgICAgVHVpQ29tYm9Cb3hNb2R1bGUsXG4gICAgICAgIC4uLlR1aURhdGFMaXN0V3JhcHBlcixcbiAgICAgICAgVHVpRmlsdGVyQnlJbnB1dFBpcGUsXG4gICAgICAgIFR1aVN0cmluZ2lmeUNvbnRlbnRQaXBlLFxuICAgICAgICBUdWlJbnB1dFBob25lTW9kdWxlLFxuICAgICAgICBUdWlCdXR0b24sXG4gICAgICAgIE1hc2tpdG9EaXJlY3RpdmUsXG4gICAgXSxcbiAgICBleHBvcnRzOiBbU2NBZGRyZXNzZXNTZWxlY3Rpb25GaWVsZENvbXBvbmVudCwgU2NTdWdnZXN0aW9uRmllbGRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBTY0Zvcm1GaWVsZHNNb2R1bGUge31cbiJdfQ==
@@ -10,9 +10,8 @@ import { SC_ALLOW_SELECT_TERMINATED } from '../../providers/sc-allow-select-term
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "@snabcentr/client-core";
12
12
  import * as i2 from "@angular/common";
13
- import * as i3 from "@taiga-ui/cdk";
14
- import * as i4 from "@taiga-ui/core";
15
- import * as i5 from "@angular/forms";
13
+ import * as i3 from "@taiga-ui/core";
14
+ import * as i4 from "@angular/forms";
16
15
  /**
17
16
  * Компонент подсказок для поля ввода.
18
17
  */
@@ -154,15 +153,15 @@ export class ScSuggestionFieldComponent {
154
153
  */
155
154
  isOrgTerminated(suggestion) {
156
155
  // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
157
- return Boolean(suggestion.rawData?.['state']?.status === 'LIQUIDATED');
156
+ return suggestion.rawData?.['state']?.status === 'LIQUIDATED';
158
157
  }
159
158
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScSuggestionFieldComponent, deps: [{ token: NgControl, skipSelf: true }, { token: i1.ScSuggestionService }], target: i0.ɵɵFactoryTarget.Component }); }
160
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: ScSuggestionFieldComponent, selector: "sc-suggestion-field", inputs: { type: "type" }, outputs: { selectedClick: "selectedClick" }, ngImport: i0, template: "<tui-loader\n size=\"m\"\n [overlay]=\"true\"\n [showLoader]=\"!!(loading$ | async)\"\n>\n <tui-data-list *tuiLet=\"suggestions$ | async as options\">\n <button\n *ngFor=\"let option of options\"\n tuiOption\n (click)=\"onSelected(option)\"\n [disabled]=\"isDisabledSuggestion(option)\"\n class=\"flex-col !items-start\"\n >\n <ng-container *tuiLet=\"$any(option) as option\">\n <ng-container [ngSwitch]=\"type\">\n <ng-container *ngSwitchCase=\"suggestionType.fio\">\n <span class=\"text-tui-link\">{{ option.fio }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.organization\">\n <span class=\"text-tui-link\">\n {{ option.name }}\n <span class=\"ml-1 text-tui-text-02\">\u0438\u043D\u043D: {{ option.inn }}</span>\n <span\n *ngIf=\"isOrgTerminated(option)\"\n class=\"text-tui-negative\"\n >\n \u041B\u0438\u043A\u0432\u0438\u0434\u0438\u0440\u043E\u0432\u0430\u043D\u043E\n </span>\n </span>\n <span class=\"text-tui-text-02\">{{ option?.legalAddress }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.bank\">\n <span class=\"text-tui-link\">{{ option.name }}</span>\n <span class=\"text-tui-text-02\">{{ option.bic }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.email\">\n <span class=\"text-tui-link\">{{ option.email }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.address\">\n <span class=\"text-tui-link\">{{ option.addressString }}</span>\n </ng-container>\n </ng-container>\n </ng-container>\n </button>\n </tui-data-list>\n</tui-loader>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i3.TuiLet, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i4.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i4.TuiOption, selector: "button[tuiOption]:not([new]), a[tuiOption]:not([new]), label[tuiOption]:not([new])", inputs: ["disabled", "value"] }, { kind: "component", type: i4.TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
159
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: ScSuggestionFieldComponent, selector: "sc-suggestion-field", inputs: { type: "type" }, outputs: { selectedClick: "selectedClick" }, ngImport: i0, template: "<tui-loader\n size=\"m\"\n [overlay]=\"true\"\n [showLoader]=\"!!(loading$ | async)\"\n>\n <tui-data-list *tuiLet=\"suggestions$ | async as options\">\n <button\n *ngFor=\"let option of options\"\n tuiOption\n (click)=\"onSelected(option)\"\n [disabled]=\"isDisabledSuggestion(option)\"\n class=\"flex-col !items-start\"\n >\n <ng-container *tuiLet=\"$any(option) as option\">\n <ng-container [ngSwitch]=\"type\">\n <ng-container *ngSwitchCase=\"suggestionType.fio\">\n <span class=\"text-tui-link\">{{ option.fio }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.organization\">\n <span class=\"text-tui-link\">\n {{ option.name }}\n <span class=\"ml-1 text-tui-text-02\">\u0438\u043D\u043D: {{ option.inn }}</span>\n <span\n *ngIf=\"isOrgTerminated(option)\"\n class=\"text-tui-negative\"\n >\n \u041B\u0438\u043A\u0432\u0438\u0434\u0438\u0440\u043E\u0432\u0430\u043D\u043E\n </span>\n </span>\n <span class=\"text-tui-text-02\">{{ option?.legalAddress }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.bank\">\n <span class=\"text-tui-link\">{{ option.name }}</span>\n <span class=\"text-tui-text-02\">{{ option.bic }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.email\">\n <span class=\"text-tui-link\">{{ option.email }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.address\">\n <span class=\"text-tui-link\">{{ option.addressString }}</span>\n </ng-container>\n </ng-container>\n </ng-container>\n </button>\n </tui-data-list>\n</tui-loader>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i3.TuiOption, selector: "button[tuiOption]:not([new]), a[tuiOption]:not([new]), label[tuiOption]:not([new])", inputs: ["disabled", "value"] }, { kind: "component", type: i3.TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
161
160
  }
162
161
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScSuggestionFieldComponent, decorators: [{
163
162
  type: Component,
164
163
  args: [{ selector: 'sc-suggestion-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<tui-loader\n size=\"m\"\n [overlay]=\"true\"\n [showLoader]=\"!!(loading$ | async)\"\n>\n <tui-data-list *tuiLet=\"suggestions$ | async as options\">\n <button\n *ngFor=\"let option of options\"\n tuiOption\n (click)=\"onSelected(option)\"\n [disabled]=\"isDisabledSuggestion(option)\"\n class=\"flex-col !items-start\"\n >\n <ng-container *tuiLet=\"$any(option) as option\">\n <ng-container [ngSwitch]=\"type\">\n <ng-container *ngSwitchCase=\"suggestionType.fio\">\n <span class=\"text-tui-link\">{{ option.fio }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.organization\">\n <span class=\"text-tui-link\">\n {{ option.name }}\n <span class=\"ml-1 text-tui-text-02\">\u0438\u043D\u043D: {{ option.inn }}</span>\n <span\n *ngIf=\"isOrgTerminated(option)\"\n class=\"text-tui-negative\"\n >\n \u041B\u0438\u043A\u0432\u0438\u0434\u0438\u0440\u043E\u0432\u0430\u043D\u043E\n </span>\n </span>\n <span class=\"text-tui-text-02\">{{ option?.legalAddress }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.bank\">\n <span class=\"text-tui-link\">{{ option.name }}</span>\n <span class=\"text-tui-text-02\">{{ option.bic }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.email\">\n <span class=\"text-tui-link\">{{ option.email }}</span>\n </ng-container>\n <ng-container *ngSwitchCase=\"suggestionType.address\">\n <span class=\"text-tui-link\">{{ option.addressString }}</span>\n </ng-container>\n </ng-container>\n </ng-container>\n </button>\n </tui-data-list>\n</tui-loader>\n" }]
165
- }], ctorParameters: () => [{ type: i5.NgControl, decorators: [{
164
+ }], ctorParameters: () => [{ type: i4.NgControl, decorators: [{
166
165
  type: SkipSelf
167
166
  }, {
168
167
  type: Inject,
@@ -172,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
172
171
  }], selectedClick: [{
173
172
  type: Output
174
173
  }] } });
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-suggestion-field.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/form-fields/suggestion-field/sc-suggestion-field.component.ts","../../../../../projects/client-ui/form-fields/suggestion-field/sc-suggestion-field.component.html"],"names":[],"mappings":"AAAA,2CAA2C;AAE3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAClI,OAAO,EAAa,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,yBAAyB,EAA6B,iBAAiB,EAAqC,MAAM,wBAAwB,CAAC;AACpJ,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,YAAY,EAAE,kCAAkC,EAAE,MAAM,eAAe,CAAC;AAC9G,OAAO,EAAE,kBAAkB,EAAmB,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,EAAc,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAGtH,OAAO,EAAE,0BAA0B,EAAE,MAAM,4CAA4C,CAAC;;;;;;;AAExF;;GAEG;AAMH,MAAM,OAAO,0BAA0B;IA6CnC;;;;;OAKG;IACH,YAGoB,OAAkB,EACjB,iBAAsC;QADvC,YAAO,GAAP,OAAO,CAAW;QACjB,sBAAiB,GAAjB,iBAAiB,CAAqB;QAtD3D;;WAEG;QAEI,SAAI,GAAsB,iBAAiB,CAAC,GAAG,CAAC;QAEvD;;WAEG;QAEI,kBAAa,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAYpF;;WAEG;QACa,mBAAc,GAA6B,iBAAiB,CAAC;QAE7E;;WAEG;QACc,SAAI,GAAoC,MAAM,CAA2B,kBAAkB,EAAE;YAC1G,QAAQ,EAAE,IAAI;SACjB,CAAC,CAAC;QAEH;;WAEG;QACc,wBAAmB,GAAW,MAAM,CAAC,yBAAyB,CAAC,CAAC;QAEjF;;WAEG;QACc,0BAAqB,GAAY,MAAM,CAAC,0BAA0B,CAAC,CAAC;IAalF,CAAC;IAEJ,kBAAkB;IACX,QAAQ;QACX,MAAM,QAAQ,GAAG,eAAe,CAAgB,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAC9D,YAAY,CAAC,GAAG,CAAC,EACjB,MAAM,CAAC,YAAY,CAAC,EACpB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,EAC1B,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,mBAAmB,CAAC,EACzD,SAAS,CAAC,CAAC,IAAY,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAe,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAChH,UAAU,CAAC,CAAC,KAAc,EAAE,EAAE;YAC1B,IAAI,KAAK,YAAY,iBAAiB,EAAE,CAAC;gBACrC,MAAM,aAAa,GAAG,KAAK,CAAC,KAAyB,CAAC;gBAEtD,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;oBACvB,kCAAkC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;oBAEzD,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC;wBAC3B,cAAc,EAAE,CAAC,aAAa,CAAC,OAAO,IAAI,kFAAkF,CAAC;qBAChI,CAAC,CAAC;gBACP,CAAC;YACL,CAAC;YAED,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACpC,CAAC,CAAC,EACF,KAAK,EAAE,CACV,CAAC;QAEF,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;QACzE,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;IACnD,CAAC;IAED;;;;OAIG;IACI,UAAU,CAAC,UAAwB;QACtC,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;YAChB,KAAK,iBAAiB,CAAC,GAAG;gBACtB,IAAI,KAAK,IAAI,UAAU,EAAE,CAAC;oBACtB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC3E,CAAC;gBACD,MAAM;YACV,KAAK,iBAAiB,CAAC,OAAO;gBAC1B,IAAI,eAAe,IAAI,UAAU,EAAE,CAAC;oBAChC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,UAAU,CAAC,aAAa,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBACrF,CAAC;gBACD,MAAM;YACV,KAAK,iBAAiB,CAAC,IAAI;gBACvB,IAAI,KAAK,IAAI,UAAU,IAAI,KAAK,IAAI,UAAU,EAAE,CAAC;oBAC7C,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,MAAoB,CAAA,CAAC,UAAU,CAClD;wBACI,QAAQ,EAAE,UAAU,CAAC,IAAI;wBACzB,GAAG,EAAE,UAAU,CAAC,GAAG;wBACnB,oBAAoB,EAAE,UAAU,CAAC,oBAAoB;qBACxD,EACD,EAAE,SAAS,EAAE,KAAK,EAAE,CACvB,CAAC;gBACN,CAAC;gBACD,MAAM;YACV,KAAK,iBAAiB,CAAC,YAAY;gBAC/B,IAAI,KAAK,IAAI,UAAU,IAAI,CAAC,CAAC,KAAK,IAAI,UAAU,CAAC,EAAE,CAAC;oBAChD,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,MAAoB,CAAA,CAAC,UAAU,CAClD;wBACI,IAAI,EAAE,UAAU,CAAC,IAAI;wBACrB,GAAG,EAAE,UAAU,CAAC,GAAG;wBACnB,GAAG,EAAE,UAAU,CAAC,GAAG;wBACnB,IAAI,EAAE,UAAU,CAAC,IAAI;wBACrB,YAAY,EAAE,UAAU,CAAC,YAAY;wBACrC,gBAAgB,EAAE,UAAU,CAAC,gBAAgB;wBAC7C,YAAY,EAAE,UAAU,CAAC,YAAY;wBACrC,aAAa,EAAE,UAAU,CAAC,aAAa;wBACvC,aAAa,EAAE,UAAU,CAAC,aAAa;qBAC1C,EACD,EAAE,SAAS,EAAE,KAAK,EAAE,CACvB,CAAC;gBACN,CAAC;gBACD,MAAM;YACV,KAAK,iBAAiB,CAAC,KAAK;gBACxB,IAAI,OAAO,IAAI,UAAU,EAAE,CAAC;oBACxB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,UAAU,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC7E,CAAC;gBACD,MAAM;YACV;gBACI,MAAM;QACd,CAAC;QAED,IAAI,IAAI,CAAC,IAAI,EAAE,YAAY,EAAE,CAAC;YAC1B,+HAA+H;YAC/H,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACI,oBAAoB,CAAC,UAAwB;QAChD,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;YAChB,KAAK,iBAAiB,CAAC,GAAG,CAAC;YAC3B,KAAK,iBAAiB,CAAC,OAAO,CAAC;YAC/B,KAAK,iBAAiB,CAAC,IAAI,CAAC;YAC5B,KAAK,iBAAiB,CAAC,KAAK;gBACxB,OAAO,KAAK,CAAC;YACjB,KAAK,iBAAiB,CAAC,YAAY;gBAC/B,IAAI,KAAK,IAAI,UAAU,IAAI,CAAC,CAAC,KAAK,IAAI,UAAU,CAAC,EAAE,CAAC;oBAChD,OAAO,CAAC,IAAI,CAAC,qBAAqB,IAAI,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;gBAC3E,CAAC;gBACD,MAAM;YACV;gBACI,OAAO,KAAK,CAAC;QACrB,CAAC;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAED;;;;OAIG;IACI,eAAe,CAAC,UAAqC;QACxD,sEAAsE;QACtE,OAAO,OAAO,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,EAAE,MAAM,KAAK,YAAY,CAAC,CAAC;IAC3E,CAAC;+GAvLQ,0BAA0B,kBAqDvB,SAAS;mGArDZ,0BAA0B,kICrBvC,6vEA8CA;;4FDzBa,0BAA0B;kBALtC,SAAS;+BACI,qBAAqB,mBAEd,uBAAuB,CAAC,MAAM;;0BAsD1C,QAAQ;;0BACR,MAAM;2BAAC,SAAS;2EAhDd,IAAI;sBADV,KAAK;gBAOC,aAAa;sBADnB,MAAM","sourcesContent":["/* eslint-disable class-methods-use-this */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, EventEmitter, Inject, inject, Input, OnInit, Output, SkipSelf } from '@angular/core';\nimport { FormGroup, NgControl } from '@angular/forms';\nimport { SC_MIN_LENGTH_SEARCH_TERM, ScISuggestionOrganization, ScISuggestionType, ScSuggestion, ScSuggestionService } from '@snabcentr/client-core';\nimport { tuiControlValue, tuiIsFalsy, tuiIsPresent, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TUI_DATA_LIST_HOST, TuiDataListHost } from '@taiga-ui/core';\nimport { catchError, debounceTime, filter, map, Observable, of, share, startWith, switchMap, throwError } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { SC_ALLOW_SELECT_TERMINATED } from '../../providers/sc-allow-select-terminated';\n\n/**\n * Компонент подсказок для поля ввода.\n */\n@Component({\n    selector: 'sc-suggestion-field',\n    templateUrl: './sc-suggestion-field.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSuggestionFieldComponent implements OnInit {\n    /**\n     * Тип подсказок.\n     */\n    @Input()\n    public type: ScISuggestionType = ScISuggestionType.fio;\n\n    /**\n     * Событие выбора результата подсказки.\n     */\n    @Output()\n    public selectedClick: EventEmitter<ScSuggestion> = new EventEmitter<ScSuggestion>();\n\n    /**\n     * {@link Observable} подсказок.\n     */\n    public suggestions$?: Observable<ScSuggestion[] | null>;\n\n    /**\n     * {@link Observable} состояние запроса подсказок.\n     */\n    public loading$?: Observable<boolean>;\n\n    /**\n     * Перечисление типов подсказок.\n     */\n    public readonly suggestionType: typeof ScISuggestionType = ScISuggestionType;\n\n    /**\n     * Компонент обёртка выпадающего списка.\n     */\n    private readonly host: TuiDataListHost<unknown> | null = inject<TuiDataListHost<unknown>>(TUI_DATA_LIST_HOST, {\n        optional: true,\n    });\n\n    /**\n     * Минимальная длина поискового запроса для получения данных.\n     */\n    private readonly minLengthSearchTerm: number = inject(SC_MIN_LENGTH_SEARCH_TERM);\n\n    /**\n     * Признак, что разрешено выбирать записи ликвидированных организаций.\n     */\n    private readonly allowSelectTerminated: boolean = inject(SC_ALLOW_SELECT_TERMINATED);\n\n    /**\n     * Инициализирует экземпляр класса {@link ScSuggestionFieldComponent}.\n     *\n     * @param control Контрол поля ввода.\n     * @param suggestionService Сервис работы с API подсказок.\n     */\n    public constructor(\n        @SkipSelf()\n        @Inject(NgControl)\n        public readonly control: NgControl,\n        private readonly suggestionService: ScSuggestionService\n    ) {}\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        const request$ = tuiControlValue<string | null>(this.control).pipe(\n            debounceTime(500),\n            filter(tuiIsPresent),\n            map((term) => term.trim()),\n            filter((term) => term.length >= this.minLengthSearchTerm),\n            switchMap((term: string) => this.suggestionService.getData<ScSuggestion>(term, this.type).pipe(startWith(null))),\n            catchError((error: unknown) => {\n                if (error instanceof HttpErrorResponse) {\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    if (this.control.control) {\n                        tuiMarkControlAsTouchedAndValidate(this.control.control);\n\n                        this.control.control.setErrors({\n                            serverResponse: [errorResponse.message || 'Ошибка сервера: пожалуйста, перезагрузите страницу и/или выполните запрос позже.'],\n                        });\n                    }\n                }\n\n                return throwError(() => of([]));\n            }),\n            share()\n        );\n\n        this.suggestions$ = request$.pipe(filter(tuiIsPresent), startWith(null));\n        this.loading$ = request$.pipe(map(tuiIsFalsy));\n    }\n\n    /**\n     * Заполнение полей основе выбранной подсказки.\n     *\n     * @param suggestion Объект подсказки.\n     */\n    public onSelected(suggestion: ScSuggestion): void {\n        switch (this.type) {\n            case ScISuggestionType.fio:\n                if ('fio' in suggestion) {\n                    this.control.control?.patchValue(suggestion.fio, { emitEvent: false });\n                }\n                break;\n            case ScISuggestionType.address:\n                if ('addressString' in suggestion) {\n                    this.control.control?.patchValue(suggestion.addressString, { emitEvent: false });\n                }\n                break;\n            case ScISuggestionType.bank:\n                if ('inn' in suggestion && 'bic' in suggestion) {\n                    (this.control.control?.parent as FormGroup).patchValue(\n                        {\n                            bankName: suggestion.name,\n                            bic: suggestion.bic,\n                            correspondentAccount: suggestion.correspondentAccount,\n                        },\n                        { emitEvent: false }\n                    );\n                }\n                break;\n            case ScISuggestionType.organization:\n                if ('inn' in suggestion && !('bic' in suggestion)) {\n                    (this.control.control?.parent as FormGroup).patchValue(\n                        {\n                            name: suggestion.name,\n                            inn: suggestion.inn,\n                            kpp: suggestion.kpp,\n                            okpo: suggestion.okpo,\n                            directorName: suggestion.directorName,\n                            directorPosition: suggestion.directorPosition,\n                            legalAddress: suggestion.legalAddress,\n                            postalAddress: suggestion.postalAddress,\n                            actualAddress: suggestion.actualAddress,\n                        },\n                        { emitEvent: false }\n                    );\n                }\n                break;\n            case ScISuggestionType.email:\n                if ('email' in suggestion) {\n                    this.control.control?.patchValue(suggestion.email, { emitEvent: false });\n                }\n                break;\n            default:\n                break;\n        }\n\n        if (this.host?.handleOption) {\n            // Дёргаем внутренний обработчик выбора элемента выпадающего списка для решения проблемы закрытия выпадающего списка подсказки.\n            this.host.handleOption(this.control.value);\n        }\n        this.selectedClick.emit(suggestion);\n    }\n\n    /**\n     * Возвращает признак, что элемент выпадающего списка подсказок отключён.\n     *\n     * @param suggestion Объект подсказки.\n     */\n    public isDisabledSuggestion(suggestion: ScSuggestion): boolean {\n        switch (this.type) {\n            case ScISuggestionType.fio:\n            case ScISuggestionType.address:\n            case ScISuggestionType.bank:\n            case ScISuggestionType.email:\n                return false;\n            case ScISuggestionType.organization:\n                if ('inn' in suggestion && !('bic' in suggestion)) {\n                    return !this.allowSelectTerminated && this.isOrgTerminated(suggestion);\n                }\n                break;\n            default:\n                return false;\n        }\n\n        return false;\n    }\n\n    /**\n     * Проверяет прекращена ли деятельность указанной организации.\n     *\n     * @param suggestion Объект подсказки по организации.\n     */\n    public isOrgTerminated(suggestion: ScISuggestionOrganization): boolean {\n        // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n        return Boolean(suggestion.rawData?.['state']?.status === 'LIQUIDATED');\n    }\n}\n","<tui-loader\n    size=\"m\"\n    [overlay]=\"true\"\n    [showLoader]=\"!!(loading$ | async)\"\n>\n    <tui-data-list *tuiLet=\"suggestions$ | async as options\">\n        <button\n            *ngFor=\"let option of options\"\n            tuiOption\n            (click)=\"onSelected(option)\"\n            [disabled]=\"isDisabledSuggestion(option)\"\n            class=\"flex-col !items-start\"\n        >\n            <ng-container *tuiLet=\"$any(option) as option\">\n                <ng-container [ngSwitch]=\"type\">\n                    <ng-container *ngSwitchCase=\"suggestionType.fio\">\n                        <span class=\"text-tui-link\">{{ option.fio }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.organization\">\n                        <span class=\"text-tui-link\">\n                            {{ option.name }}\n                            <span class=\"ml-1 text-tui-text-02\">инн: {{ option.inn }}</span>\n                            <span\n                                *ngIf=\"isOrgTerminated(option)\"\n                                class=\"text-tui-negative\"\n                            >\n                                Ликвидировано\n                            </span>\n                        </span>\n                        <span class=\"text-tui-text-02\">{{ option?.legalAddress }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.bank\">\n                        <span class=\"text-tui-link\">{{ option.name }}</span>\n                        <span class=\"text-tui-text-02\">{{ option.bic }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.email\">\n                        <span class=\"text-tui-link\">{{ option.email }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.address\">\n                        <span class=\"text-tui-link\">{{ option.addressString }}</span>\n                    </ng-container>\n                </ng-container>\n            </ng-container>\n        </button>\n    </tui-data-list>\n</tui-loader>\n"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-suggestion-field.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/form-fields/suggestion-field/sc-suggestion-field.component.ts","../../../../../projects/client-ui/form-fields/suggestion-field/sc-suggestion-field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, EventEmitter, Inject, inject, Input, OnInit, Output, SkipSelf } from '@angular/core';\nimport { FormGroup, NgControl } from '@angular/forms';\nimport { SC_MIN_LENGTH_SEARCH_TERM, ScISuggestionOrganization, ScISuggestionType, ScSuggestion, ScSuggestionService } from '@snabcentr/client-core';\nimport { tuiControlValue, tuiIsFalsy, tuiIsPresent, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TUI_DATA_LIST_HOST, TuiDataListHost } from '@taiga-ui/core';\nimport { catchError, debounceTime, filter, map, Observable, of, share, startWith, switchMap, throwError } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { SC_ALLOW_SELECT_TERMINATED } from '../../providers/sc-allow-select-terminated';\n\n/**\n * Компонент подсказок для поля ввода.\n */\n@Component({\n    selector: 'sc-suggestion-field',\n    templateUrl: './sc-suggestion-field.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSuggestionFieldComponent implements OnInit {\n    /**\n     * Тип подсказок.\n     */\n    @Input()\n    public type: ScISuggestionType = ScISuggestionType.fio;\n\n    /**\n     * Событие выбора результата подсказки.\n     */\n    @Output()\n    public selectedClick: EventEmitter<ScSuggestion> = new EventEmitter<ScSuggestion>();\n\n    /**\n     * {@link Observable} подсказок.\n     */\n    public suggestions$?: Observable<ScSuggestion[] | null>;\n\n    /**\n     * {@link Observable} состояние запроса подсказок.\n     */\n    public loading$?: Observable<boolean>;\n\n    /**\n     * Перечисление типов подсказок.\n     */\n    public readonly suggestionType: typeof ScISuggestionType = ScISuggestionType;\n\n    /**\n     * Компонент обёртка выпадающего списка.\n     */\n    private readonly host: TuiDataListHost<unknown> | null = inject<TuiDataListHost<unknown>>(TUI_DATA_LIST_HOST, {\n        optional: true,\n    });\n\n    /**\n     * Минимальная длина поискового запроса для получения данных.\n     */\n    private readonly minLengthSearchTerm: number = inject(SC_MIN_LENGTH_SEARCH_TERM);\n\n    /**\n     * Признак, что разрешено выбирать записи ликвидированных организаций.\n     */\n    private readonly allowSelectTerminated: boolean = inject(SC_ALLOW_SELECT_TERMINATED);\n\n    /**\n     * Инициализирует экземпляр класса {@link ScSuggestionFieldComponent}.\n     *\n     * @param control Контрол поля ввода.\n     * @param suggestionService Сервис работы с API подсказок.\n     */\n    public constructor(\n        @SkipSelf()\n        @Inject(NgControl)\n        public readonly control: NgControl,\n        private readonly suggestionService: ScSuggestionService\n    ) {}\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        const request$ = tuiControlValue<string | null>(this.control).pipe(\n            debounceTime(500),\n            filter(tuiIsPresent),\n            map((term) => term.trim()),\n            filter((term) => term.length >= this.minLengthSearchTerm),\n            switchMap((term: string) => this.suggestionService.getData<ScSuggestion>(term, this.type).pipe(startWith(null))),\n            catchError((error: unknown) => {\n                if (error instanceof HttpErrorResponse) {\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    if (this.control.control) {\n                        tuiMarkControlAsTouchedAndValidate(this.control.control);\n\n                        this.control.control.setErrors({\n                            serverResponse: [errorResponse.message || 'Ошибка сервера: пожалуйста, перезагрузите страницу и/или выполните запрос позже.'],\n                        });\n                    }\n                }\n\n                return throwError(() => of([]));\n            }),\n            share()\n        );\n\n        this.suggestions$ = request$.pipe(filter(tuiIsPresent), startWith(null));\n        this.loading$ = request$.pipe(map(tuiIsFalsy));\n    }\n\n    /**\n     * Заполнение полей основе выбранной подсказки.\n     *\n     * @param suggestion Объект подсказки.\n     */\n    public onSelected(suggestion: ScSuggestion): void {\n        switch (this.type) {\n            case ScISuggestionType.fio:\n                if ('fio' in suggestion) {\n                    this.control.control?.patchValue(suggestion.fio, { emitEvent: false });\n                }\n                break;\n            case ScISuggestionType.address:\n                if ('addressString' in suggestion) {\n                    this.control.control?.patchValue(suggestion.addressString, { emitEvent: false });\n                }\n                break;\n            case ScISuggestionType.bank:\n                if ('inn' in suggestion && 'bic' in suggestion) {\n                    (this.control.control?.parent as FormGroup).patchValue(\n                        {\n                            bankName: suggestion.name,\n                            bic: suggestion.bic,\n                            correspondentAccount: suggestion.correspondentAccount,\n                        },\n                        { emitEvent: false }\n                    );\n                }\n                break;\n            case ScISuggestionType.organization:\n                if ('inn' in suggestion && !('bic' in suggestion)) {\n                    (this.control.control?.parent as FormGroup).patchValue(\n                        {\n                            name: suggestion.name,\n                            inn: suggestion.inn,\n                            kpp: suggestion.kpp,\n                            okpo: suggestion.okpo,\n                            directorName: suggestion.directorName,\n                            directorPosition: suggestion.directorPosition,\n                            legalAddress: suggestion.legalAddress,\n                            postalAddress: suggestion.postalAddress,\n                            actualAddress: suggestion.actualAddress,\n                        },\n                        { emitEvent: false }\n                    );\n                }\n                break;\n            case ScISuggestionType.email:\n                if ('email' in suggestion) {\n                    this.control.control?.patchValue(suggestion.email, { emitEvent: false });\n                }\n                break;\n            default:\n                break;\n        }\n\n        if (this.host?.handleOption) {\n            // Дёргаем внутренний обработчик выбора элемента выпадающего списка для решения проблемы закрытия выпадающего списка подсказки.\n            this.host.handleOption(this.control.value);\n        }\n        this.selectedClick.emit(suggestion);\n    }\n\n    /**\n     * Возвращает признак, что элемент выпадающего списка подсказок отключён.\n     *\n     * @param suggestion Объект подсказки.\n     */\n    public isDisabledSuggestion(suggestion: ScSuggestion): boolean {\n        switch (this.type) {\n            case ScISuggestionType.fio:\n            case ScISuggestionType.address:\n            case ScISuggestionType.bank:\n            case ScISuggestionType.email:\n                return false;\n            case ScISuggestionType.organization:\n                if ('inn' in suggestion && !('bic' in suggestion)) {\n                    return !this.allowSelectTerminated && this.isOrgTerminated(suggestion);\n                }\n                break;\n            default:\n                return false;\n        }\n\n        return false;\n    }\n\n    /**\n     * Проверяет прекращена ли деятельность указанной организации.\n     *\n     * @param suggestion Объект подсказки по организации.\n     */\n    public isOrgTerminated(suggestion: ScISuggestionOrganization): boolean {\n        // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n        return suggestion.rawData?.['state']?.status === 'LIQUIDATED';\n    }\n}\n","<tui-loader\n    size=\"m\"\n    [overlay]=\"true\"\n    [showLoader]=\"!!(loading$ | async)\"\n>\n    <tui-data-list *tuiLet=\"suggestions$ | async as options\">\n        <button\n            *ngFor=\"let option of options\"\n            tuiOption\n            (click)=\"onSelected(option)\"\n            [disabled]=\"isDisabledSuggestion(option)\"\n            class=\"flex-col !items-start\"\n        >\n            <ng-container *tuiLet=\"$any(option) as option\">\n                <ng-container [ngSwitch]=\"type\">\n                    <ng-container *ngSwitchCase=\"suggestionType.fio\">\n                        <span class=\"text-tui-link\">{{ option.fio }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.organization\">\n                        <span class=\"text-tui-link\">\n                            {{ option.name }}\n                            <span class=\"ml-1 text-tui-text-02\">инн: {{ option.inn }}</span>\n                            <span\n                                *ngIf=\"isOrgTerminated(option)\"\n                                class=\"text-tui-negative\"\n                            >\n                                Ликвидировано\n                            </span>\n                        </span>\n                        <span class=\"text-tui-text-02\">{{ option?.legalAddress }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.bank\">\n                        <span class=\"text-tui-link\">{{ option.name }}</span>\n                        <span class=\"text-tui-text-02\">{{ option.bic }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.email\">\n                        <span class=\"text-tui-link\">{{ option.email }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.address\">\n                        <span class=\"text-tui-link\">{{ option.addressString }}</span>\n                    </ng-container>\n                </ng-container>\n            </ng-container>\n        </button>\n    </tui-data-list>\n</tui-loader>\n"]}
@@ -31,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
31
31
  '[class.is_mobile]': 'isMobile',
32
32
  }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<a\n [routerLink]=\"href()\"\n class=\"black-link relative flex h-full cursor-pointer flex-col gap-2 overflow-hidden rounded-xl bg-white px-2 pb-4 pt-2 shadow-sc\"\n>\n <div class=\"w-full grow overflow-hidden rounded-xl bg-tui-base-02 bg-cover bg-center bg-no-repeat\">\n <picture>\n @if (news().imageWebp) {\n <source\n type=\"image/webp\"\n [srcset]=\"news().imageWebp | scMediaImageTransformer\"\n />\n }\n <img\n [src]=\"news().image | scMediaImageTransformer: true\"\n [alt]=\"news().subject\"\n class=\"size-full object-cover\"\n />\n </picture>\n </div>\n <div class=\"flex w-full shrink-0 flex-col justify-between gap-2 overflow-hidden bg-white align-baseline\">\n <p class=\"text-sm font-medium text-tui-text-02\">{{ news().createdAt | scFormatDate }}</p>\n\n <div class=\"line-clamp-3 font-extrabold\">{{ news().subject }}</div>\n </div>\n</a>\n", styles: [":host{display:block;height:20.5rem}:host.is_mobile{height:17rem}\n"] }]
33
33
  }] });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtbmV3cy1jYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NsaWVudC11aS9uZXdzL25ld3MtY2FyZC9zYy1uZXdzLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXVpL25ld3MvbmV3cy1jYXJkL3NjLW5ld3MtY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFFL0YsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFFOUM7O0dBRUc7QUFVSCxNQUFNLE9BQU8sbUJBQW1CO0lBVGhDO1FBVUk7O1dBRUc7UUFDSSxTQUFJLEdBQTRCLEtBQUssQ0FBQyxRQUFRLEVBQWMsQ0FBQztRQUVwRTs7V0FFRztRQUNJLFNBQUksR0FBK0IsS0FBSyxDQUFDLFFBQVEsRUFBaUIsQ0FBQztRQUUxRTs7V0FFRztRQUNhLGFBQVEsR0FBWSxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7S0FDN0Q7K0dBZlksbUJBQW1CO21HQUFuQixtQkFBbUIsaVdDaEJoQyxxaUNBeUJBOzs0RkRUYSxtQkFBbUI7a0JBVC9CLFNBQVM7K0JBQ0ksY0FBYyxRQUdsQjt3QkFDRixtQkFBbUIsRUFBRSxVQUFVO3FCQUNsQyxtQkFDZ0IsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgaW5wdXQsIElucHV0U2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTY05ld3NUaWxlIH0gZnJvbSAnQHNuYWJjZW50ci9jbGllbnQtY29yZSc7XG5pbXBvcnQgeyBUVUlfSVNfTU9CSUxFIH0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5cbi8qKlxuICog0JrQvtC80L/QvtC90LXQvdGCINC60LDRgNGC0L7Rh9C60Lgg0L3QvtCy0L7RgdGC0LguXG4gKi9cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnc2MtbmV3cy1jYXJkJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vc2MtbmV3cy1jYXJkLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zYy1uZXdzLWNhcmQuY29tcG9uZW50LnNjc3MnXSxcbiAgICBob3N0OiB7XG4gICAgICAgICdbY2xhc3MuaXNfbW9iaWxlXSc6ICdpc01vYmlsZScsXG4gICAgfSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgU2NOZXdzQ2FyZENvbXBvbmVudCB7XG4gICAgLyoqXG4gICAgICog0JTQsNC90L3Ri9C1INC+INC90L7QstC+0YHRgtC4LlxuICAgICAqL1xuICAgIHB1YmxpYyBuZXdzOiBJbnB1dFNpZ25hbDxTY05ld3NUaWxlPiA9IGlucHV0LnJlcXVpcmVkPFNjTmV3c1RpbGU+KCk7XG5cbiAgICAvKipcbiAgICAgKiDQodGB0YvQu9C60LAg0L3QsCDRgdGC0YDQsNC90LjRhtGDINC90L7QstC+0YHRgtC4LiDQmNGB0L/QvtC70YzQt9GD0LXRgtGB0Y8g0LjQvNC10L3QvdC+IGBocmVmYCwg0YLQsNC6INC60LDQuiDQvtGB0YLQsNC90L7QstC40YLRjCDRgdC+0LHRi9GC0LjQtSDQutC70LjQutCwINC00LvRjyBgcm91dGVyTGlua2Ag0L3QtSDQstGL0YjQu9C+LlxuICAgICAqL1xuICAgIHB1YmxpYyBocmVmOiBJbnB1dFNpZ25hbDxzdHJpbmcgfCBudWxsPiA9IGlucHV0LnJlcXVpcmVkPHN0cmluZyB8IG51bGw+KCk7XG5cbiAgICAvKipcbiAgICAgKiDQn9GA0LjQt9C90LDQuiDRgtC+0LPQviwg0YfRgtC+INGN0YLQvtGCINC60L7QvNC/0L7QvdC10L3RgiDQvtGC0L7QsdGA0LDQttCw0LXRgtGB0Y8g0L3QsCDQvNC+0LHQuNC70YzQvdC+0Lwg0YPRgdGC0YDQvtC50YHRgtCy0LUuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGlzTW9iaWxlOiBib29sZWFuID0gaW5qZWN0KFRVSV9JU19NT0JJTEUpO1xufVxuIiwiPGFcbiAgICBbcm91dGVyTGlua109XCJocmVmKClcIlxuICAgIGNsYXNzPVwiYmxhY2stbGluayByZWxhdGl2ZSBmbGV4IGgtZnVsbCBjdXJzb3ItcG9pbnRlciBmbGV4LWNvbCBnYXAtMiBvdmVyZmxvdy1oaWRkZW4gcm91bmRlZC14bCBiZy13aGl0ZSBweC0yIHBiLTQgcHQtMiBzaGFkb3ctc2NcIlxuPlxuICAgIDxkaXYgY2xhc3M9XCJ3LWZ1bGwgZ3JvdyBvdmVyZmxvdy1oaWRkZW4gcm91bmRlZC14bCBiZy10dWktYmFzZS0wMiBiZy1jb3ZlciBiZy1jZW50ZXIgYmctbm8tcmVwZWF0XCI+XG4gICAgICAgIDxwaWN0dXJlPlxuICAgICAgICAgICAgQGlmIChuZXdzKCkuaW1hZ2VXZWJwKSB7XG4gICAgICAgICAgICAgICAgPHNvdXJjZVxuICAgICAgICAgICAgICAgICAgICB0eXBlPVwiaW1hZ2Uvd2VicFwiXG4gICAgICAgICAgICAgICAgICAgIFtzcmNzZXRdPVwibmV3cygpLmltYWdlV2VicCB8IHNjTWVkaWFJbWFnZVRyYW5zZm9ybWVyXCJcbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgPGltZ1xuICAgICAgICAgICAgICAgIFtzcmNdPVwibmV3cygpLmltYWdlIHwgc2NNZWRpYUltYWdlVHJhbnNmb3JtZXI6IHRydWVcIlxuICAgICAgICAgICAgICAgIFthbHRdPVwibmV3cygpLnN1YmplY3RcIlxuICAgICAgICAgICAgICAgIGNsYXNzPVwic2l6ZS1mdWxsIG9iamVjdC1jb3ZlclwiXG4gICAgICAgICAgICAvPlxuICAgICAgICA8L3BpY3R1cmU+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImZsZXggdy1mdWxsIHNocmluay0wIGZsZXgtY29sIGp1c3RpZnktYmV0d2VlbiBnYXAtMiBvdmVyZmxvdy1oaWRkZW4gYmctd2hpdGUgYWxpZ24tYmFzZWxpbmVcIj5cbiAgICAgICAgPHAgY2xhc3M9XCJ0ZXh0LXNtIGZvbnQtbWVkaXVtIHRleHQtdHVpLXRleHQtMDJcIj57eyBuZXdzKCkuY3JlYXRlZEF0IHwgc2NGb3JtYXREYXRlIH19PC9wPlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJsaW5lLWNsYW1wLTMgZm9udC1leHRyYWJvbGRcIj57eyBuZXdzKCkuc3ViamVjdCB9fTwvZGl2PlxuICAgIDwvZGl2PlxuPC9hPlxuIl19
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtbmV3cy1jYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NsaWVudC11aS9uZXdzL25ld3MtY2FyZC9zYy1uZXdzLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xpZW50LXVpL25ld3MvbmV3cy1jYXJkL3NjLW5ld3MtY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFFL0YsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFFOUM7O0dBRUc7QUFVSCxNQUFNLE9BQU8sbUJBQW1CO0lBVGhDO1FBVUk7O1dBRUc7UUFDSSxTQUFJLEdBQTZCLEtBQUssQ0FBQyxRQUFRLEVBQWUsQ0FBQztRQUV0RTs7V0FFRztRQUNJLFNBQUksR0FBK0IsS0FBSyxDQUFDLFFBQVEsRUFBaUIsQ0FBQztRQUUxRTs7V0FFRztRQUNhLGFBQVEsR0FBWSxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7S0FDN0Q7K0dBZlksbUJBQW1CO21HQUFuQixtQkFBbUIsaVdDaEJoQyxxaUNBeUJBOzs0RkRUYSxtQkFBbUI7a0JBVC9CLFNBQVM7K0JBQ0ksY0FBYyxRQUdsQjt3QkFDRixtQkFBbUIsRUFBRSxVQUFVO3FCQUNsQyxtQkFDZ0IsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgaW5wdXQsIElucHV0U2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTY0lOZXdzVGlsZSB9IGZyb20gJ0BzbmFiY2VudHIvY2xpZW50LWNvcmUnO1xuaW1wb3J0IHsgVFVJX0lTX01PQklMRSB9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuXG4vKipcbiAqINCa0L7QvNC/0L7QvdC10L3RgiDQutCw0YDRgtC+0YfQutC4INC90L7QstC+0YHRgtC4LlxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3NjLW5ld3MtY2FyZCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NjLW5ld3MtY2FyZC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vc2MtbmV3cy1jYXJkLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgaG9zdDoge1xuICAgICAgICAnW2NsYXNzLmlzX21vYmlsZV0nOiAnaXNNb2JpbGUnLFxuICAgIH0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFNjTmV3c0NhcmRDb21wb25lbnQge1xuICAgIC8qKlxuICAgICAqINCU0LDQvdC90YvQtSDQviDQvdC+0LLQvtGB0YLQuC5cbiAgICAgKi9cbiAgICBwdWJsaWMgbmV3czogSW5wdXRTaWduYWw8U2NJTmV3c1RpbGU+ID0gaW5wdXQucmVxdWlyZWQ8U2NJTmV3c1RpbGU+KCk7XG5cbiAgICAvKipcbiAgICAgKiDQodGB0YvQu9C60LAg0L3QsCDRgdGC0YDQsNC90LjRhtGDINC90L7QstC+0YHRgtC4LiDQmNGB0L/QvtC70YzQt9GD0LXRgtGB0Y8g0LjQvNC10L3QvdC+IGBocmVmYCwg0YLQsNC6INC60LDQuiDQvtGB0YLQsNC90L7QstC40YLRjCDRgdC+0LHRi9GC0LjQtSDQutC70LjQutCwINC00LvRjyBgcm91dGVyTGlua2Ag0L3QtSDQstGL0YjQu9C+LlxuICAgICAqL1xuICAgIHB1YmxpYyBocmVmOiBJbnB1dFNpZ25hbDxzdHJpbmcgfCBudWxsPiA9IGlucHV0LnJlcXVpcmVkPHN0cmluZyB8IG51bGw+KCk7XG5cbiAgICAvKipcbiAgICAgKiDQn9GA0LjQt9C90LDQuiDRgtC+0LPQviwg0YfRgtC+INGN0YLQvtGCINC60L7QvNC/0L7QvdC10L3RgiDQvtGC0L7QsdGA0LDQttCw0LXRgtGB0Y8g0L3QsCDQvNC+0LHQuNC70YzQvdC+0Lwg0YPRgdGC0YDQvtC50YHRgtCy0LUuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGlzTW9iaWxlOiBib29sZWFuID0gaW5qZWN0KFRVSV9JU19NT0JJTEUpO1xufVxuIiwiPGFcbiAgICBbcm91dGVyTGlua109XCJocmVmKClcIlxuICAgIGNsYXNzPVwiYmxhY2stbGluayByZWxhdGl2ZSBmbGV4IGgtZnVsbCBjdXJzb3ItcG9pbnRlciBmbGV4LWNvbCBnYXAtMiBvdmVyZmxvdy1oaWRkZW4gcm91bmRlZC14bCBiZy13aGl0ZSBweC0yIHBiLTQgcHQtMiBzaGFkb3ctc2NcIlxuPlxuICAgIDxkaXYgY2xhc3M9XCJ3LWZ1bGwgZ3JvdyBvdmVyZmxvdy1oaWRkZW4gcm91bmRlZC14bCBiZy10dWktYmFzZS0wMiBiZy1jb3ZlciBiZy1jZW50ZXIgYmctbm8tcmVwZWF0XCI+XG4gICAgICAgIDxwaWN0dXJlPlxuICAgICAgICAgICAgQGlmIChuZXdzKCkuaW1hZ2VXZWJwKSB7XG4gICAgICAgICAgICAgICAgPHNvdXJjZVxuICAgICAgICAgICAgICAgICAgICB0eXBlPVwiaW1hZ2Uvd2VicFwiXG4gICAgICAgICAgICAgICAgICAgIFtzcmNzZXRdPVwibmV3cygpLmltYWdlV2VicCB8IHNjTWVkaWFJbWFnZVRyYW5zZm9ybWVyXCJcbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgPGltZ1xuICAgICAgICAgICAgICAgIFtzcmNdPVwibmV3cygpLmltYWdlIHwgc2NNZWRpYUltYWdlVHJhbnNmb3JtZXI6IHRydWVcIlxuICAgICAgICAgICAgICAgIFthbHRdPVwibmV3cygpLnN1YmplY3RcIlxuICAgICAgICAgICAgICAgIGNsYXNzPVwic2l6ZS1mdWxsIG9iamVjdC1jb3ZlclwiXG4gICAgICAgICAgICAvPlxuICAgICAgICA8L3BpY3R1cmU+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImZsZXggdy1mdWxsIHNocmluay0wIGZsZXgtY29sIGp1c3RpZnktYmV0d2VlbiBnYXAtMiBvdmVyZmxvdy1oaWRkZW4gYmctd2hpdGUgYWxpZ24tYmFzZWxpbmVcIj5cbiAgICAgICAgPHAgY2xhc3M9XCJ0ZXh0LXNtIGZvbnQtbWVkaXVtIHRleHQtdHVpLXRleHQtMDJcIj57eyBuZXdzKCkuY3JlYXRlZEF0IHwgc2NGb3JtYXREYXRlIH19PC9wPlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJsaW5lLWNsYW1wLTMgZm9udC1leHRyYWJvbGRcIj57eyBuZXdzKCkuc3ViamVjdCB9fTwvZGl2PlxuICAgIDwvZGl2PlxuPC9hPlxuIl19
@@ -1,6 +1,8 @@
1
- import { tuiCreateToken } from '@taiga-ui/cdk';
1
+ import { InjectionToken } from '@angular/core';
2
2
  /**
3
3
  * Токен перечисления размеров страниц пагинации.
4
4
  */
5
- export const SC_PAGE_SIZE_OPTIONS = tuiCreateToken([5]);
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtcGFnZS1zaXplLW9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbGllbnQtdWkvcGFnZXMvZnJlcXVlbnRseS1hc2tlZC1xdWVzdGlvbnMvc2MtcGFnZS1zaXplLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQzs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUE2QixjQUFjLENBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHR1aUNyZWF0ZVRva2VuIH0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5cbi8qKlxuICog0KLQvtC60LXQvSDQv9C10YDQtdGH0LjRgdC70LXQvdC40Y8g0YDQsNC30LzQtdGA0L7QsiDRgdGC0YDQsNC90LjRhiDQv9Cw0LPQuNC90LDRhtC40LguXG4gKi9cbmV4cG9ydCBjb25zdCBTQ19QQUdFX1NJWkVfT1BUSU9OUzogSW5qZWN0aW9uVG9rZW48bnVtYmVyW10+ID0gdHVpQ3JlYXRlVG9rZW48bnVtYmVyW10+KFs1XSk7XG4iXX0=
5
+ export const SC_PAGE_SIZE_OPTIONS = new InjectionToken('SC_PAGE_SIZE_OPTIONS', {
6
+ factory: () => [5],
7
+ });
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtcGFnZS1zaXplLW9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbGllbnQtdWkvcGFnZXMvZnJlcXVlbnRseS1hc2tlZC1xdWVzdGlvbnMvc2MtcGFnZS1zaXplLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQzs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLElBQUksY0FBYyxDQUFXLHNCQUFzQixFQUFFO0lBQ3JGLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztDQUNyQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqINCi0L7QutC10L0g0L/QtdGA0LXRh9C40YHQu9C10L3QuNGPINGA0LDQt9C80LXRgNC+0LIg0YHRgtGA0LDQvdC40YYg0L/QsNCz0LjQvdCw0YbQuNC4LlxuICovXG5leHBvcnQgY29uc3QgU0NfUEFHRV9TSVpFX09QVElPTlMgPSBuZXcgSW5qZWN0aW9uVG9rZW48bnVtYmVyW10+KCdTQ19QQUdFX1NJWkVfT1BUSU9OUycsIHtcbiAgICBmYWN0b3J5OiAoKSA9PiBbNV0sXG59KTtcbiJdfQ==