@snabcentr/client-ui 0.14.3 → 0.15.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (79) hide show
  1. package/accordion/sc-accordion.component.d.ts +9 -0
  2. package/auth/index.d.ts +0 -1
  3. package/catalog/input-quantity/sc-input-quantity.component.d.ts +3 -0
  4. package/contacts/add-contact-dialog/sc-add-contact-dialog.component.d.ts +44 -0
  5. package/contacts/contacts-accordion/sc-contacts-accordion.component.d.ts +3 -3
  6. package/contacts/index.d.ts +2 -2
  7. package/contacts/new-contact-form/sc-new-contact-form.component.d.ts +23 -0
  8. package/contacts/sc-contacts.module.d.ts +3 -3
  9. package/{contacts → contragents}/add-contragent-bank-account-dialog/sc-add-contragent-bank-account-dialog.component.d.ts +1 -1
  10. package/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.d.ts +147 -0
  11. package/contragents/contragents-accordion/contragents-accordion-item/sc-contragents-accordion-item.component.d.ts +24 -6
  12. package/contragents/contragents-accordion/sc-contragents-accordion.component.d.ts +19 -8
  13. package/contragents/index.d.ts +4 -0
  14. package/contragents/new-contragent-form/sc-new-contragent-form.component.d.ts +100 -0
  15. package/contragents/sc-contragents.module.d.ts +15 -6
  16. package/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.d.ts +53 -0
  17. package/delivery-address/delivery-address-accordion/delivery-address-accordion-item/sc-delivery-address-accordion-item.component.d.ts +23 -5
  18. package/delivery-address/delivery-address-accordion/sc-delivery-address-accordion.component.d.ts +17 -2
  19. package/delivery-address/index.d.ts +1 -0
  20. package/delivery-address/sc-delivery-address.module.d.ts +10 -6
  21. package/directives/carousel-item-hidden/sc-carousel-item-hidden.directive.d.ts +24 -0
  22. package/directives/carousel-item-hidden/sc-carousel-item-hidden.module.d.ts +11 -0
  23. package/directives/index.d.ts +2 -0
  24. package/esm2020/accordion/sc-accordion.component.mjs +14 -4
  25. package/esm2020/auth/index.mjs +1 -2
  26. package/esm2020/cart/cart-item-mobile/sc-cart-item-mobile.component.mjs +3 -3
  27. package/esm2020/catalog/input-quantity/sc-input-quantity.component.mjs +6 -1
  28. package/esm2020/contacts/add-contact-dialog/sc-add-contact-dialog.component.mjs +71 -0
  29. package/esm2020/contacts/contacts-accordion/sc-contacts-accordion.component.mjs +6 -6
  30. package/esm2020/contacts/index.mjs +3 -3
  31. package/esm2020/contacts/new-contact-form/sc-new-contact-form.component.mjs +28 -0
  32. package/esm2020/contacts/sc-contacts.module.mjs +7 -7
  33. package/esm2020/contragents/add-contragent-bank-account-dialog/sc-add-contragent-bank-account-dialog.component.mjs +71 -0
  34. package/esm2020/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.mjs +249 -0
  35. package/esm2020/contragents/contragents-accordion/contragents-accordion-item/sc-contragents-accordion-item.component.mjs +32 -11
  36. package/esm2020/contragents/contragents-accordion/sc-contragents-accordion.component.mjs +24 -12
  37. package/esm2020/contragents/index.mjs +5 -1
  38. package/esm2020/contragents/new-contragent-bank-account-form/sc-new-contragent-bank-account-form.component.mjs +61 -0
  39. package/esm2020/contragents/new-contragent-form/sc-new-contragent-form.component.mjs +183 -0
  40. package/esm2020/contragents/sc-contragents.module.mjs +84 -7
  41. package/esm2020/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.mjs +79 -0
  42. package/esm2020/delivery-address/delivery-address-accordion/delivery-address-accordion-item/sc-delivery-address-accordion-item.component.mjs +28 -8
  43. package/esm2020/delivery-address/delivery-address-accordion/sc-delivery-address-accordion.component.mjs +21 -3
  44. package/esm2020/delivery-address/index.mjs +2 -1
  45. package/esm2020/delivery-address/sc-delivery-address.module.mjs +58 -7
  46. package/esm2020/directives/carousel-item-hidden/sc-carousel-item-hidden.directive.mjs +40 -0
  47. package/esm2020/directives/carousel-item-hidden/sc-carousel-item-hidden.module.mjs +21 -0
  48. package/esm2020/directives/index.mjs +3 -0
  49. package/esm2020/form-fields/index.mjs +4 -0
  50. package/esm2020/masks/index.mjs +5 -1
  51. package/esm2020/masks/sc-inn-mask.mjs +13 -0
  52. package/esm2020/masks/sc-kpp-mask.mjs +7 -0
  53. package/esm2020/masks/sc-okpo-mask.mjs +13 -0
  54. package/esm2020/masks/sc-phone-verification-code-mask.mjs +7 -0
  55. package/esm2020/profile/sc-profile-accordions-content/sc-profile-accordions-content.component.mjs +67 -8
  56. package/esm2020/profile/sc-profile.module.mjs +8 -4
  57. package/esm2020/public-api.mjs +3 -1
  58. package/esm2020/user/reset-user-password/sc-reset-user-password.component.mjs +24 -18
  59. package/esm2020/verification/verification-phone-check-form/sc-verification-phone-check-form.component.mjs +3 -3
  60. package/fesm2015/snabcentr-client-ui.mjs +1177 -265
  61. package/fesm2015/snabcentr-client-ui.mjs.map +1 -1
  62. package/fesm2020/snabcentr-client-ui.mjs +1156 -263
  63. package/fesm2020/snabcentr-client-ui.mjs.map +1 -1
  64. package/form-fields/index.d.ts +3 -0
  65. package/masks/index.d.ts +4 -0
  66. package/masks/sc-inn-mask.d.ts +9 -0
  67. package/masks/sc-kpp-mask.d.ts +5 -0
  68. package/masks/sc-okpo-mask.d.ts +9 -0
  69. package/{auth/constants/phone-approve-code-mask.d.ts → masks/sc-phone-verification-code-mask.d.ts} +1 -1
  70. package/package.json +2 -2
  71. package/profile/sc-profile-accordions-content/sc-profile-accordions-content.component.d.ts +50 -4
  72. package/profile/sc-profile.module.d.ts +2 -1
  73. package/public-api.d.ts +2 -0
  74. package/styles/tailwind/tailwind.scss +62 -36
  75. package/user/reset-user-password/sc-reset-user-password.component.d.ts +11 -3
  76. package/esm2020/auth/constants/phone-approve-code-mask.mjs +0 -7
  77. package/esm2020/contacts/add-contragent-bank-account-dialog/sc-add-contragent-bank-account-dialog.component.mjs +0 -72
  78. package/esm2020/contacts/new-contragent-bank-account-form/sc-new-contragent-bank-account-form.component.mjs +0 -61
  79. /package/{contacts → contragents}/new-contragent-bank-account-form/sc-new-contragent-bank-account-form.component.d.ts +0 -0
@@ -0,0 +1,249 @@
1
+ import { __decorate } from "tslib";
2
+ import { Component, ChangeDetectionStrategy, Optional, Inject } from '@angular/core';
3
+ import { FormControl, FormGroup, Validators } from '@angular/forms';
4
+ import { UntilDestroy } from '@ngneat/until-destroy';
5
+ import { ScOpfList } from '@snabcentr/client-core';
6
+ import { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';
7
+ import { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';
8
+ import { map, Subject, catchError, filter, of, share, startWith, switchMap, tap } from 'rxjs';
9
+ import { scBicValidator, scCorrespondentAccountValidator } from '../../validators';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@snabcentr/client-core";
12
+ import * as i2 from "@angular/forms";
13
+ import * as i3 from "@angular/common";
14
+ import * as i4 from "@taiga-ui/core";
15
+ import * as i5 from "../../contacts/new-contact-form/sc-new-contact-form.component";
16
+ import * as i6 from "@taiga-ui/kit";
17
+ import * as i7 from "@taiga-ui/cdk";
18
+ import * as i8 from "../../directives/carousel-item-hidden/sc-carousel-item-hidden.directive";
19
+ import * as i9 from "../new-contragent-bank-account-form/sc-new-contragent-bank-account-form.component";
20
+ import * as i10 from "../new-contragent-form/sc-new-contragent-form.component";
21
+ /**
22
+ * Компотен добавления контрагента.
23
+ */
24
+ let ScAddContragentDialogComponent = class ScAddContragentDialogComponent {
25
+ /**
26
+ * Инициализирует экземпляр класса {@link ScAddContragentDialogComponent}.
27
+ *
28
+ * @param referencesService Сервис справочников.
29
+ * @param contragentService Сервис работы с контрагентами.
30
+ * @param convertersService Сервис конвертации данных.
31
+ * @param context Контекст диалогового окна, в котором открыт компонент.
32
+ */
33
+ constructor(referencesService, contragentService, convertersService, locationsService, context) {
34
+ this.referencesService = referencesService;
35
+ this.contragentService = contragentService;
36
+ this.convertersService = convertersService;
37
+ this.locationsService = locationsService;
38
+ this.context = context;
39
+ /**
40
+ * Перечисление организационно-правовых форм.
41
+ */
42
+ this.opfListEnum = ScOpfList;
43
+ /**
44
+ * Расположение баннера.
45
+ */
46
+ this.stepIndex = 0;
47
+ /**
48
+ * Родительская `FormGroup`.
49
+ */
50
+ this.form = new FormGroup({
51
+ contragent: new FormGroup({})
52
+ });
53
+ /**
54
+ * {@link Subject} события отправки формы.
55
+ */
56
+ this.onSubmit = new Subject();
57
+ /**
58
+ * {@link Observable} запроса добавления контрагента.
59
+ */
60
+ this.request$ = this.onSubmit.pipe(map(() => this.form.value.contragent), filter((value) => this.form.valid), switchMap((value) => {
61
+ return this.contragentService.createContragent$(this.convertersService.removeNullRecursive(value)).pipe(tap((contragent) => this.context?.completeWith(contragent)), catchError((error) => {
62
+ tuiMarkControlAsTouchedAndValidate(this.form);
63
+ const errorResponse = error.error;
64
+ for (const key in errorResponse.errors) {
65
+ this.form.controls.contragent.get(key)?.setErrors({ serverResponse: errorResponse.errors[`${key}`] });
66
+ }
67
+ if (!errorResponse.errors && errorResponse.message) {
68
+ this.form.setErrors({ serverResponse: [errorResponse.message] });
69
+ }
70
+ return of({});
71
+ }), startWith(null));
72
+ }), share());
73
+ /**
74
+ * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.
75
+ */
76
+ this.loading$ = this.request$.pipe(map(tuiIsFalsy));
77
+ }
78
+ /**
79
+ * Текущий выбранный ОПФ.
80
+ */
81
+ get selectOpf() {
82
+ return this.opfListEnum[this.form.controls.contragent.controls['opf'].value];
83
+ }
84
+ /**
85
+ * Список групп полей банковских реквизитов.
86
+ */
87
+ get bankAccounts() {
88
+ return this.form.controls.contragent.get('bankAccounts');
89
+ }
90
+ /**
91
+ * Список групп полей контактных лиц.
92
+ */
93
+ get contacts() {
94
+ return this.form.controls.contragent.get('contacts');
95
+ }
96
+ /**
97
+ * Выполняет навигацию по форме создания контрагента.
98
+ *
99
+ * @param delta Значение, на которое необходимо выполнить навигацию.
100
+ */
101
+ navigate(delta) {
102
+ this.stepIndex = (this.stepIndex + delta) % 3;
103
+ }
104
+ /**
105
+ * Проверяет, может ли пользователь перейти к следующему шагу создания контрагента.
106
+ *
107
+ * @returns Выводит значение `boolean` на основании {@link stepIndex}.
108
+ */
109
+ canNextStep() {
110
+ switch (this.stepIndex) {
111
+ case 0:
112
+ for (const key in this.form.controls.contragent.controls) {
113
+ if (Object.prototype.hasOwnProperty.call(this.form.controls.contragent.controls, key) && !Array.isArray(this.form.controls.contragent.controls[key].value)) {
114
+ if (this.form.controls.contragent.controls[key].invalid) {
115
+ return false;
116
+ }
117
+ }
118
+ }
119
+ return true;
120
+ case 1:
121
+ return this.form.controls.contragent.controls['contacts'].valid;
122
+ case 2:
123
+ return this.form.controls.contragent.controls['bankAccounts'].valid;
124
+ default:
125
+ return true;
126
+ }
127
+ }
128
+ /**
129
+ * Возвращает {@link Observable} списка направлений продаж.
130
+ */
131
+ getSalesDirections$() {
132
+ return this.referencesService.directions$;
133
+ }
134
+ /**
135
+ * Возвращает {@link Observable} списка направлений продаж.
136
+ */
137
+ getDirectionById$(directionId) {
138
+ return this.referencesService.getDirectionById$(directionId);
139
+ }
140
+ /**
141
+ * Возвращает {@link Observable} список организационно-правовых форм.
142
+ */
143
+ getOpf$() {
144
+ return this.referencesService.opf$;
145
+ }
146
+ /**
147
+ * Возвращает {@link Observable} организационно-правовой формы, соответствующий символьному обозначению (slug) на входе.
148
+ *
149
+ * @param slug Символьное обозначение (slug).
150
+ */
151
+ getOpfBySlug$(slug) {
152
+ return this.referencesService.getOpfBySlug$(slug);
153
+ }
154
+ /**
155
+ * Возвращает {@link Observable} списка валют.
156
+ */
157
+ getCurrencies$() {
158
+ return this.referencesService.currencies$;
159
+ }
160
+ /**
161
+ * Возвращает {@link Observable} валюты, соответствующий идентификатору на входе.
162
+ *
163
+ * @param currencyId — Идентификатор валюты.
164
+ */
165
+ getCurrencyById$(currencyId) {
166
+ return this.referencesService.getCurrencyById$(currencyId);
167
+ }
168
+ /**
169
+ * Возвращает {@link Observable} списка стран.
170
+ */
171
+ getCountries$() {
172
+ return this.locationsService.getCountries$();
173
+ }
174
+ /**
175
+ * Возвращает {@link Observable} страны, соответствующий идентификатору на входе.
176
+ *
177
+ * @param countryId — Идентификатор страны.
178
+ */
179
+ getCountriesById$(countryId) {
180
+ return this.locationsService.getCountries$().pipe(map((countries) => countries.find((country) => country.id === countryId)));
181
+ }
182
+ /**
183
+ * Создаёт группу полей банковских реквизитов.
184
+ */
185
+ createBankAccountGroup() {
186
+ return new FormGroup({
187
+ bankName: new FormControl(null, Validators.required),
188
+ bic: new FormControl(null, [Validators.required, Validators.minLength(9), scBicValidator]),
189
+ accountNumber: new FormControl(null, [Validators.required, Validators.minLength(20)]),
190
+ correspondentAccount: new FormControl(null, [Validators.required, Validators.minLength(20), scCorrespondentAccountValidator]),
191
+ currencyId: new FormControl(null, Validators.required)
192
+ });
193
+ }
194
+ /**
195
+ * Добавляет Банковские реквизиты.
196
+ */
197
+ addBankAccountGroup() {
198
+ this.bankAccounts.push(this.createBankAccountGroup());
199
+ }
200
+ /**
201
+ * Удаляет банковские реквизиты.
202
+ *
203
+ * @param index Индекс банковских реквизитов.
204
+ */
205
+ removeBankAccountGroup(index) {
206
+ this.bankAccounts.removeAt(index);
207
+ }
208
+ /**
209
+ * Создаёт группу полей контактного лица.
210
+ */
211
+ createContactGroup() {
212
+ return new FormGroup({
213
+ name: new FormControl(null, Validators.required),
214
+ phone: new FormControl(null, [Validators.required, Validators.minLength(12)]),
215
+ email: new FormControl(null, Validators.email),
216
+ position: new FormControl(null)
217
+ });
218
+ }
219
+ /**
220
+ * Добавляет контактное лицо контрагента.
221
+ */
222
+ addContactGroup() {
223
+ this.contacts.push(this.createContactGroup());
224
+ }
225
+ /**
226
+ * Удаляет контактное лицо контрагента.
227
+ *
228
+ * @param index Индекс контактного лица.
229
+ */
230
+ removeContactGroup(index) {
231
+ this.contacts.removeAt(index);
232
+ }
233
+ };
234
+ ScAddContragentDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddContragentDialogComponent, deps: [{ token: i1.ScReferencesService }, { token: i1.ScContragentService }, { token: i1.ScConvertersService }, { token: i1.ScLocationsService }, { token: POLYMORPHEUS_CONTEXT, optional: true }], target: i0.ɵɵFactoryTarget.Component });
235
+ ScAddContragentDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScAddContragentDialogComponent, selector: "sc-add-contragent-dialog", ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-4\">\n <tui-elastic-container>\n <tui-carousel [(index)]=\"stepIndex\" [draggable]=\"false\">\n <sc-new-contragent-form *tuiItem scCarouselItemHidden [index]=\"0\"></sc-new-contragent-form>\n\n <div *tuiItem scCarouselItemHidden [index]=\"1\">\n <div *ngIf=\"contacts\" class=\"flex flex-col gap-5 pb-1\">\n <p class=\"font-bold text-lg\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442\u044B</p>\n <div *ngFor=\"let contact of contacts.controls; let index = index, let count = count, let last = last\" class=\"flex flex-col gap-3\">\n <div class=\"flex justify-between items-center h-10\">\n <p class=\"font-bold\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442\u043D\u043E\u0435 \u043B\u0438\u0446\u043E \u2116{{ index + 1 }}:</p>\n <button *ngIf=\"count - 1\" tuiIconButton appearance=\"secondary\" (click)=\"removeContactGroup(index)\" icon=\"tuiIconTrash2Large\"></button>\n </div>\n <sc-new-contact-form [form]=\"contact\"></sc-new-contact-form>\n <hr *ngIf=\"!last\" class=\"w-full h-px bg-tui-base-04\" />\n </div>\n <button tuiButton icon=\"tuiIconPlusLarge\" [appearance]=\"'secondary'\" (click)=\"addContactGroup()\" type=\"button\">\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u043A\u043E\u043D\u0442\u0430\u043A\u0442</button>\n </div>\n </div>\n\n <div *tuiItem scCarouselItemHidden [index]=\"2\">\n <div *ngIf=\"bankAccounts\" class=\"flex flex-col gap-5 pb-1\">\n <p class=\"font-bold text-lg\">\u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B</p>\n <div *ngFor=\"let bankAccount of bankAccounts.controls; let index = index, let count = count, let last = last\" class=\"flex flex-col gap-3\">\n <div class=\"flex justify-between items-center h-12\">\n <p class=\"font-bold\">\u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B \u2116{{ index + 1 }}:</p>\n <button *ngIf=\"count - 1\" tuiIconButton appearance=\"secondary\" (click)=\"removeBankAccountGroup(index)\" icon=\"tuiIconTrash2Large\"></button>\n </div>\n <sc-new-contragent-bank-account-form [form]=\"bankAccount\"></sc-new-contragent-bank-account-form>\n <hr *ngIf=\"!last\" class=\"w-full h-px bg-tui-base-04\" />\n </div>\n <button tuiButton icon=\"tuiIconPlusLarge\" [appearance]=\"'secondary'\" (click)=\"addBankAccountGroup()\" type=\"button\">\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B</button>\n </div>\n </div>\n </tui-carousel>\n </tui-elastic-container>\n <div class=\"flex gap-2 justify-center\">\n <button *ngIf=\"stepIndex > 0\" tuiButton appearance=\"secondary\" type=\"button\" (click)=\"stepIndex = (stepIndex - 1) % 3;\">\u041D\u0430\u0437\u0430\u0434</button>\n <button\n *ngIf=\"stepIndex === 2 || stepIndex === 1 && !form.controls.contragent.controls['bankAccounts']; else nextIndexBtn\"\n tuiButton\n [disabled]=\"form.invalid\"\n [showLoader]=\"!!(loading$ | async)\"\n type=\"submit\"\n class=\"self-center\"\n >\n \u0421\u043E\u0437\u0434\u0430\u0442\u044C\n </button>\n <ng-template #nextIndexBtn>\n <button tuiButton [disabled]=\"!canNextStep()\" type=\"button\" (click)=\"stepIndex = (stepIndex + 1) % 3;\">\u0414\u0430\u043B\u0435\u0435</button>\n </ng-template>\n </div>\n</form>\n", styles: ["tui-carousel{--tui-carousel-padding: .5rem}\n"], dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "component", type: i5.ScNewContactFormComponent, selector: "sc-new-contact-form", inputs: ["form"] }, { kind: "component", type: i6.TuiElasticContainerComponent, selector: "tui-elastic-container" }, { kind: "component", type: i6.TuiCarouselComponent, selector: "tui-carousel", inputs: ["draggable", "itemsCount", "index"], outputs: ["indexChange"] }, { kind: "directive", type: i6.TuiCarouselDirective, selector: "tui-carousel", inputs: ["duration", "index"] }, { kind: "directive", type: i7.TuiItemDirective, selector: "[tuiItem]" }, { kind: "directive", type: i8.ScCarouselItemHiddenDirective, selector: "[tuiItem], [scCarouselItemHidden]", inputs: ["index"] }, { kind: "component", type: i9.ScNewContragentBankAccountsFormComponent, selector: "sc-new-contragent-bank-account-form", inputs: ["form"] }, { kind: "component", type: i10.ScNewContragentFormComponent, selector: "sc-new-contragent-form" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
236
+ ScAddContragentDialogComponent = __decorate([
237
+ UntilDestroy({ checkProperties: true })
238
+ ], ScAddContragentDialogComponent);
239
+ export { ScAddContragentDialogComponent };
240
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddContragentDialogComponent, decorators: [{
241
+ type: Component,
242
+ args: [{ selector: 'sc-add-contragent-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-4\">\n <tui-elastic-container>\n <tui-carousel [(index)]=\"stepIndex\" [draggable]=\"false\">\n <sc-new-contragent-form *tuiItem scCarouselItemHidden [index]=\"0\"></sc-new-contragent-form>\n\n <div *tuiItem scCarouselItemHidden [index]=\"1\">\n <div *ngIf=\"contacts\" class=\"flex flex-col gap-5 pb-1\">\n <p class=\"font-bold text-lg\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442\u044B</p>\n <div *ngFor=\"let contact of contacts.controls; let index = index, let count = count, let last = last\" class=\"flex flex-col gap-3\">\n <div class=\"flex justify-between items-center h-10\">\n <p class=\"font-bold\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442\u043D\u043E\u0435 \u043B\u0438\u0446\u043E \u2116{{ index + 1 }}:</p>\n <button *ngIf=\"count - 1\" tuiIconButton appearance=\"secondary\" (click)=\"removeContactGroup(index)\" icon=\"tuiIconTrash2Large\"></button>\n </div>\n <sc-new-contact-form [form]=\"contact\"></sc-new-contact-form>\n <hr *ngIf=\"!last\" class=\"w-full h-px bg-tui-base-04\" />\n </div>\n <button tuiButton icon=\"tuiIconPlusLarge\" [appearance]=\"'secondary'\" (click)=\"addContactGroup()\" type=\"button\">\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u043A\u043E\u043D\u0442\u0430\u043A\u0442</button>\n </div>\n </div>\n\n <div *tuiItem scCarouselItemHidden [index]=\"2\">\n <div *ngIf=\"bankAccounts\" class=\"flex flex-col gap-5 pb-1\">\n <p class=\"font-bold text-lg\">\u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B</p>\n <div *ngFor=\"let bankAccount of bankAccounts.controls; let index = index, let count = count, let last = last\" class=\"flex flex-col gap-3\">\n <div class=\"flex justify-between items-center h-12\">\n <p class=\"font-bold\">\u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B \u2116{{ index + 1 }}:</p>\n <button *ngIf=\"count - 1\" tuiIconButton appearance=\"secondary\" (click)=\"removeBankAccountGroup(index)\" icon=\"tuiIconTrash2Large\"></button>\n </div>\n <sc-new-contragent-bank-account-form [form]=\"bankAccount\"></sc-new-contragent-bank-account-form>\n <hr *ngIf=\"!last\" class=\"w-full h-px bg-tui-base-04\" />\n </div>\n <button tuiButton icon=\"tuiIconPlusLarge\" [appearance]=\"'secondary'\" (click)=\"addBankAccountGroup()\" type=\"button\">\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B</button>\n </div>\n </div>\n </tui-carousel>\n </tui-elastic-container>\n <div class=\"flex gap-2 justify-center\">\n <button *ngIf=\"stepIndex > 0\" tuiButton appearance=\"secondary\" type=\"button\" (click)=\"stepIndex = (stepIndex - 1) % 3;\">\u041D\u0430\u0437\u0430\u0434</button>\n <button\n *ngIf=\"stepIndex === 2 || stepIndex === 1 && !form.controls.contragent.controls['bankAccounts']; else nextIndexBtn\"\n tuiButton\n [disabled]=\"form.invalid\"\n [showLoader]=\"!!(loading$ | async)\"\n type=\"submit\"\n class=\"self-center\"\n >\n \u0421\u043E\u0437\u0434\u0430\u0442\u044C\n </button>\n <ng-template #nextIndexBtn>\n <button tuiButton [disabled]=\"!canNextStep()\" type=\"button\" (click)=\"stepIndex = (stepIndex + 1) % 3;\">\u0414\u0430\u043B\u0435\u0435</button>\n </ng-template>\n </div>\n</form>\n", styles: ["tui-carousel{--tui-carousel-padding: .5rem}\n"] }]
243
+ }], ctorParameters: function () { return [{ type: i1.ScReferencesService }, { type: i1.ScContragentService }, { type: i1.ScConvertersService }, { type: i1.ScLocationsService }, { type: undefined, decorators: [{
244
+ type: Optional
245
+ }, {
246
+ type: Inject,
247
+ args: [POLYMORPHEUS_CONTEXT]
248
+ }] }]; } });
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contragent-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.ts","../../../../../projects/client-ui/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from '@angular/common/http';\nimport { Component, ChangeDetectionStrategy, Optional, Inject } from '@angular/core';\nimport { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { UntilDestroy } from '@ngneat/until-destroy';\nimport {\n    ScOpfList,\n    ScReferencesService,\n    ScContragentService,\n    ScConvertersService,\n    ScLocationsService,\n    ScContragentOnDataCreate,\n    ScISalesDirection,\n    ScIReferencesTypes,\n    ScICurrency,\n    ScICountry,\n    ScIBankAccount,\n    ScContragent\n} from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';\nimport { Observable, map, Subject, catchError, filter, of, share, startWith, switchMap, tap } from 'rxjs';\nimport { ApiErrorResponse } from '../../auth';\nimport { scBicValidator, scCorrespondentAccountValidator } from '../../validators';\n\n/**\n * Компотен добавления контрагента.\n */\n@Component({\n    selector: 'sc-add-contragent-dialog',\n    templateUrl: './sc-add-contragent-dialog.component.html',\n    styleUrls: ['./sc-add-contragent-dialog.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\n@UntilDestroy({ checkProperties: true })\nexport class ScAddContragentDialogComponent {\n    /**\n     * Перечисление организационно-правовых форм.\n     */\n    public readonly opfListEnum: typeof ScOpfList = ScOpfList;\n\n    /**\n     * Расположение баннера.\n     */\n    public stepIndex = 0;\n\n    /**\n     * Родительская `FormGroup`.\n     */\n    public form = new FormGroup({\n        contragent: new FormGroup<any>({})\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса добавления контрагента.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value.contragent as ScContragentOnDataCreate),\n        filter((value): value is ScContragentOnDataCreate => this.form.valid),\n        switchMap((value) => {\n            return this.contragentService.createContragent$(this.convertersService.removeNullRecursive(value)).pipe(\n                tap((contragent) => this.context?.completeWith(contragent)),\n                catchError((error: HttpErrorResponse) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    for (const key in errorResponse.errors) {\n                        this.form.controls.contragent.get(key)?.setErrors({ serverResponse: errorResponse.errors[`${key}`] });\n                    }\n\n                    if (!errorResponse.errors && errorResponse.message) {\n                        this.form.setErrors({ serverResponse: [errorResponse.message] });\n                    }\n\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Текущий выбранный ОПФ.\n     */\n    public get selectOpf(): ScOpfList {\n        return this.opfListEnum[this.form.controls.contragent.controls['opf'].value as keyof typeof ScOpfList];\n    }\n\n    /**\n     * Список групп полей банковских реквизитов.\n     */\n    public get bankAccounts(): FormArray<ReturnType<ScAddContragentDialogComponent['createBankAccountGroup']>> {\n        return this.form.controls.contragent.get('bankAccounts') as FormArray<ReturnType<ScAddContragentDialogComponent['createBankAccountGroup']>>;\n    }\n\n    /**\n     * Список групп полей контактных лиц.\n     */\n    public get contacts(): FormArray<ReturnType<ScAddContragentDialogComponent['createContactGroup']>> {\n        return this.form.controls.contragent.get('contacts') as FormArray<ReturnType<ScAddContragentDialogComponent['createContactGroup']>>;\n    }\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContragentDialogComponent}.\n     *\n     * @param referencesService Сервис справочников.\n     * @param contragentService Сервис работы с контрагентами.\n     * @param convertersService Сервис конвертации данных.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly referencesService: ScReferencesService,\n        private readonly contragentService: ScContragentService,\n        private readonly convertersService: ScConvertersService,\n        private readonly locationsService: ScLocationsService,\n        @Optional()\n        @Inject(POLYMORPHEUS_CONTEXT)\n        private readonly context: TuiDialogContext<ScContragent, void>\n    ) {}\n\n    /**\n     * Выполняет навигацию по форме создания контрагента.\n     *\n     * @param delta Значение, на которое необходимо выполнить навигацию.\n     */\n    public navigate(delta: number): void {\n        this.stepIndex = (this.stepIndex + delta) % 3;\n    }\n\n    /**\n     * Проверяет, может ли пользователь перейти к следующему шагу создания контрагента.\n     *\n     * @returns Выводит значение `boolean` на основании {@link stepIndex}.\n     */\n    public canNextStep(): boolean {\n        switch (this.stepIndex) {\n            case 0:\n                for (const key in this.form.controls.contragent.controls) {\n                    if (Object.prototype.hasOwnProperty.call(this.form.controls.contragent.controls, key) && !Array.isArray(this.form.controls.contragent.controls[key].value)) {\n                        if (this.form.controls.contragent.controls[key].invalid) {\n                            return false;\n                        }\n                    }\n                }\n\n                return true;\n            case 1:\n                return this.form.controls.contragent.controls['contacts'].valid;\n            case 2:\n                return this.form.controls.contragent.controls['bankAccounts'].valid;\n            default:\n                return true;\n        }\n    }\n\n    /**\n     * Возвращает {@link Observable} списка направлений продаж.\n     */\n    public getSalesDirections$(): Observable<ScISalesDirection[]> {\n        return this.referencesService.directions$;\n    }\n\n    /**\n     * Возвращает {@link Observable} списка направлений продаж.\n     */\n    public getDirectionById$(directionId: number): Observable<ScISalesDirection | undefined> {\n        return this.referencesService.getDirectionById$(directionId);\n    }\n\n    /**\n     * Возвращает {@link Observable} список организационно-правовых форм.\n     */\n    public getOpf$(): Observable<ScIReferencesTypes<ScOpfList, typeof ScOpfList>[]> {\n        return this.referencesService.opf$;\n    }\n\n    /**\n     * Возвращает {@link Observable} организационно-правовой формы, соответствующий символьному обозначению (slug) на входе.\n     *\n     * @param slug Символьное обозначение (slug).\n     */\n    public getOpfBySlug$(slug: keyof typeof ScOpfList): Observable<ScIReferencesTypes<ScOpfList, typeof ScOpfList> | undefined> {\n        return this.referencesService.getOpfBySlug$(slug);\n    }\n\n    /**\n     * Возвращает {@link Observable} списка валют.\n     */\n    public getCurrencies$(): Observable<ScICurrency[]> {\n        return this.referencesService.currencies$;\n    }\n\n    /**\n     * Возвращает {@link Observable} валюты, соответствующий идентификатору на входе.\n     *\n     * @param currencyId — Идентификатор валюты.\n     */\n    public getCurrencyById$(currencyId: number): Observable<ScICurrency | undefined> {\n        return this.referencesService.getCurrencyById$(currencyId);\n    }\n\n    /**\n     * Возвращает {@link Observable} списка стран.\n     */\n    public getCountries$(): Observable<ScICountry[]> {\n        return this.locationsService.getCountries$();\n    }\n\n    /**\n     * Возвращает {@link Observable} страны, соответствующий идентификатору на входе.\n     *\n     * @param countryId — Идентификатор страны.\n     */\n    public getCountriesById$(countryId: number): Observable<ScICountry | undefined> {\n        return this.locationsService.getCountries$().pipe(map((countries) => countries.find((country) => country.id === countryId)));\n    }\n\n    /**\n     * Создаёт группу полей банковских реквизитов.\n     */\n    private createBankAccountGroup(): FormGroup<{\n        bankName: FormControl<string | null>;\n        bic: FormControl<string | null>;\n        accountNumber: FormControl<string | null>;\n        correspondentAccount: FormControl<string | null>;\n        currencyId: FormControl<number | null>;\n    }> {\n        return new FormGroup({\n            bankName: new FormControl<string | null>(null, Validators.required),\n            bic: new FormControl<string | null>(null, [Validators.required, Validators.minLength(9), scBicValidator]),\n            accountNumber: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20)]),\n            correspondentAccount: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20), scCorrespondentAccountValidator]),\n            currencyId: new FormControl<number | null>(null, Validators.required)\n        });\n    }\n\n    /**\n     * Добавляет Банковские реквизиты.\n     */\n    public addBankAccountGroup(): void {\n        this.bankAccounts.push(this.createBankAccountGroup());\n    }\n\n    /**\n     * Удаляет банковские реквизиты.\n     *\n     * @param index Индекс банковских реквизитов.\n     */\n    public removeBankAccountGroup(index: number): void {\n        this.bankAccounts.removeAt(index);\n    }\n\n    /**\n     * Создаёт группу полей контактного лица.\n     */\n    public createContactGroup(): FormGroup<{\n        name: FormControl<string | null>;\n        phone: FormControl<string | null>;\n        email: FormControl<string | null>;\n        position: FormControl<string | null>;\n    }> {\n        return new FormGroup({\n            name: new FormControl<string | null>(null, Validators.required),\n            phone: new FormControl<string | null>(null, [Validators.required, Validators.minLength(12)]),\n            email: new FormControl<string | null>(null, Validators.email),\n            position: new FormControl<string | null>(null)\n        });\n    }\n\n    /**\n     * Добавляет контактное лицо контрагента.\n     */\n    public addContactGroup(): void {\n        this.contacts.push(this.createContactGroup());\n    }\n\n    /**\n     * Удаляет контактное лицо контрагента.\n     *\n     * @param index Индекс контактного лица.\n     */\n    public removeContactGroup(index: number): void {\n        this.contacts.removeAt(index);\n    }\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-4\">\n    <tui-elastic-container>\n        <tui-carousel [(index)]=\"stepIndex\" [draggable]=\"false\">\n            <sc-new-contragent-form *tuiItem scCarouselItemHidden [index]=\"0\"></sc-new-contragent-form>\n\n            <div *tuiItem scCarouselItemHidden [index]=\"1\">\n                <div *ngIf=\"contacts\" class=\"flex flex-col gap-5 pb-1\">\n                    <p class=\"font-bold text-lg\">Контакты</p>\n                    <div *ngFor=\"let contact of contacts.controls; let index = index, let count = count, let last = last\" class=\"flex flex-col gap-3\">\n                        <div class=\"flex justify-between items-center h-10\">\n                            <p class=\"font-bold\">Контактное лицо №{{ index + 1 }}:</p>\n                            <button *ngIf=\"count - 1\" tuiIconButton appearance=\"secondary\" (click)=\"removeContactGroup(index)\" icon=\"tuiIconTrash2Large\"></button>\n                        </div>\n                        <sc-new-contact-form [form]=\"contact\"></sc-new-contact-form>\n                        <hr *ngIf=\"!last\" class=\"w-full h-px bg-tui-base-04\" />\n                    </div>\n                    <button tuiButton icon=\"tuiIconPlusLarge\" [appearance]=\"'secondary'\" (click)=\"addContactGroup()\" type=\"button\">Добавить контакт</button>\n                </div>\n            </div>\n\n            <div *tuiItem scCarouselItemHidden [index]=\"2\">\n                <div *ngIf=\"bankAccounts\" class=\"flex flex-col gap-5 pb-1\">\n                    <p class=\"font-bold text-lg\">Банковские реквизиты</p>\n                    <div *ngFor=\"let bankAccount of bankAccounts.controls; let index = index, let count = count, let last = last\" class=\"flex flex-col gap-3\">\n                        <div class=\"flex justify-between items-center h-12\">\n                            <p class=\"font-bold\">Банковские реквизиты №{{ index + 1 }}:</p>\n                            <button *ngIf=\"count - 1\" tuiIconButton appearance=\"secondary\" (click)=\"removeBankAccountGroup(index)\" icon=\"tuiIconTrash2Large\"></button>\n                        </div>\n                        <sc-new-contragent-bank-account-form [form]=\"bankAccount\"></sc-new-contragent-bank-account-form>\n                        <hr *ngIf=\"!last\" class=\"w-full h-px bg-tui-base-04\" />\n                    </div>\n                    <button tuiButton icon=\"tuiIconPlusLarge\" [appearance]=\"'secondary'\" (click)=\"addBankAccountGroup()\" type=\"button\">Добавить банковские реквизиты</button>\n                </div>\n            </div>\n        </tui-carousel>\n    </tui-elastic-container>\n    <div class=\"flex gap-2 justify-center\">\n        <button *ngIf=\"stepIndex > 0\" tuiButton appearance=\"secondary\" type=\"button\" (click)=\"stepIndex = (stepIndex - 1) % 3;\">Назад</button>\n        <button\n            *ngIf=\"stepIndex === 2 || stepIndex === 1 && !form.controls.contragent.controls['bankAccounts']; else nextIndexBtn\"\n            tuiButton\n            [disabled]=\"form.invalid\"\n            [showLoader]=\"!!(loading$ | async)\"\n            type=\"submit\"\n            class=\"self-center\"\n        >\n            Создать\n        </button>\n        <ng-template #nextIndexBtn>\n            <button tuiButton [disabled]=\"!canNextStep()\" type=\"button\" (click)=\"stepIndex = (stepIndex + 1) % 3;\">Далее</button>\n        </ng-template>\n    </div>\n</form>\n"]}
@@ -18,37 +18,58 @@ export class ScContragentsAccordionItemComponent {
18
18
  */
19
19
  constructor(contragentService) {
20
20
  this.contragentService = contragentService;
21
+ /**
22
+ * Событие нажатия на кнопку удаления контрагента.
23
+ */
24
+ this.deleteContragentClick = new EventEmitter();
21
25
  /**
22
26
  * Событие нажатия на кнопку добавления банковского счёта контрагенту.
23
27
  */
24
- this.addBankAccountsClick = new EventEmitter();
28
+ this.addContragentBankAccountClick = new EventEmitter();
25
29
  /**
26
- * Событие нажатия на кнопку редактирования банковского счёта контрагента.
30
+ * Событие нажатия на кнопку удаления банковского счёта контрагента.
27
31
  */
28
- this.editBankAccountsContragentClick = new EventEmitter();
32
+ this.deleteContragentBankAccountClick = new EventEmitter();
29
33
  /**
30
- * Событие нажатия на кнопку редактирования контрагента.
34
+ * Событие нажатия на кнопку добавления контактного лица контрагенту.
31
35
  */
32
- this.editContragentClick = new EventEmitter();
36
+ this.addContragentContactClick = new EventEmitter();
37
+ /**
38
+ * Событие нажатия на кнопку удаления контактного лица у контрагента.
39
+ */
40
+ this.deleteContragentContactClick = new EventEmitter();
33
41
  }
34
42
  /** @inheritDoc */
35
43
  ngOnInit() {
36
44
  this.bankAccounts$ = this.contragentService.getContragentBankAccounts$(this.contragent.id);
37
45
  this.contacts$ = this.contragentService.getContragentContacts$(this.contragent.id);
38
46
  }
47
+ /**
48
+ * Обработчик нажатия на кнопку удаления контактного лица у контрагента.
49
+ *
50
+ * @param contact Контактное лицо.
51
+ * @param contragent Контрагент.
52
+ */
53
+ onDeleteContragentContactClick(contact, contragent) {
54
+ this.deleteContragentContactClick.emit({ contact: contact, contragent: contragent });
55
+ }
39
56
  }
40
57
  ScContragentsAccordionItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionItemComponent, deps: [{ token: i1.ScContragentService }], target: i0.ɵɵFactoryTarget.Component });
41
- ScContragentsAccordionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScContragentsAccordionItemComponent, selector: "sc-contragents-accordion-item", inputs: { contragent: "contragent" }, outputs: { addBankAccountsClick: "addBankAccountsClick", editBankAccountsContragentClick: "editBankAccountsContragentClick", editContragentClick: "editContragentClick" }, ngImport: i0, template: "<sc-accordion [showAddButton]=\"false\">\n {{ contragent.name }}\n <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n\n <ng-template scAccordionContent>\n <div class=\"flex flex-col gap-2\">\n <div class=\"flex gap-2\">\n <div class=\"flex flex-col gap-2 grow\">\n {{ contragent.name }}\n <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n <span *ngIf=\"$any(contragent).kpp as kpp\">\u041A\u041F\u041F: {{ kpp }}</span>\n </div>\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconEdit3Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); editContragentClick.emit()\"\n ></button>\n </div>\n\n <sc-accordion (addButtonClick)=\"addBankAccountsClick.emit(contragent.id)\">\n \u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n <ng-template scAccordionContent>\n <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n <div class=\"flex flex-col gap-2\">\n <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n <div class=\"flex flex-col gap-2 grow\">\n <span>\u0411\u0430\u043D\u043A: {{ bankAccount.bankName }}</span>\n <span>\u0411\u0418\u041A: {{ bankAccount.bic }}</span>\n <span>\u0420/\u0441\u0447\u0451\u0442: {{ bankAccount.accountNumber }}</span>\n <span>\u041A\u043E\u0440/\u0441\u0447\u0451\u0442: {{ bankAccount.correspondentAccount }}</span>\n <span>\u0412\u0430\u043B\u044E\u0442\u0430: {{ bankAccount.currency.name }}</span>\n </div>\n <div class=\"flex flex-col md:flex-row gap-4\">\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconEdit3Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation();\"\n ></button>\n\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconTrash2Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation();\"\n ></button>\n </div>\n </div>\n </ng-container>\n\n <ng-template #bankAccountsNotExist>\n <tui-notification size=\"l\">\n <div class=\"flex flex-wrap gap-2 font-medium\">\n \u0423 \u043A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u0430 <span class=\"font-bold\">{{ contragent.name }}</span> \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B.\n <button tuiButton size=\"s\" icon=\"tuiIconPlusLarge\" (click)=\"addBankAccountsClick.emit(contragent.id)\">\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C</button>\n </div>\n </tui-notification>\n </ng-template>\n </div>\n </tui-loader>\n </ng-template>\n </sc-accordion>\n <sc-contacts-accordion *ngIf=\"contacts$\" [contacts$]=\"contacts$\"></sc-contacts-accordion>\n </div>\n </ng-template>\n</sc-accordion>\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: "component", type: i3.ScAccordionComponent, selector: "sc-accordion", inputs: ["showAddButton", "showDeleteButton", "showArrow", "open", "size"], outputs: ["addButtonClick", "deleteButtonClick"] }, { kind: "directive", type: i4.ScAccordionContentDirective, selector: "ng-template[scAccordionContent]" }, { kind: "component", type: i5.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "directive", type: i5.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { kind: "component", type: i5.TuiLoaderComponent, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "directive", type: i6.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i5.TuiNotificationComponent, selector: "tui-notification", inputs: ["hasIcon", "icon", "status", "size", "hideClose"], outputs: ["close"] }, { kind: "component", type: i7.ScContactsAccordionComponent, selector: "sc-contacts-accordion", inputs: ["contacts$"], outputs: ["addContactClick", "editContactClick"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
58
+ ScContragentsAccordionItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScContragentsAccordionItemComponent, selector: "sc-contragents-accordion-item", inputs: { contragent: "contragent" }, outputs: { deleteContragentClick: "deleteContragentClick", addContragentBankAccountClick: "addContragentBankAccountClick", deleteContragentBankAccountClick: "deleteContragentBankAccountClick", addContragentContactClick: "addContragentContactClick", deleteContragentContactClick: "deleteContragentContactClick" }, ngImport: i0, template: "<sc-accordion [showAddButton]=\"false\">\n {{ contragent.name }}\n <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n\n <ng-template scAccordionContent>\n <div class=\"flex flex-col gap-2\">\n <div class=\"flex gap-2\">\n <div class=\"flex flex-col gap-2 grow\">\n {{ contragent.name }}\n <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n <span *ngIf=\"$any(contragent).kpp as kpp\">\u041A\u041F\u041F: {{ kpp }}</span>\n </div>\n <!-- \u0424\u0443\u043D\u043A\u0446\u0438\u043E\u043D\u0430\u043B \u0443\u0434\u0430\u043B\u0435\u043D\u0438\u044F \u0438 \u0440\u0435\u0434\u0430\u043A\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u044F \u0432\u0440\u0435\u043C\u0435\u043D\u043D\u043E \u043D\u0435 \u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D \u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u0435\u043B\u044E. -->\n <!-- <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconEdit3Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); editContragentClick.emit(contragent.id)\"\n ></button>\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconTrash2Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); deleteContragentClick.emit(contragent)\"\n ></button> -->\n </div>\n\n <sc-accordion (addButtonClick)=\"addContragentBankAccountClick.emit(contragent)\">\n \u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n <ng-template scAccordionContent>\n <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n <div class=\"flex flex-col gap-2\">\n <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n <div class=\"flex flex-col gap-2 grow\">\n <span>\u0411\u0430\u043D\u043A: {{ bankAccount.bankName }}</span>\n <span>\u0411\u0418\u041A: {{ bankAccount.bic }}</span>\n <span>\u0420/\u0441\u0447\u0451\u0442: {{ bankAccount.accountNumber }}</span>\n <span>\u041A\u043E\u0440/\u0441\u0447\u0451\u0442: {{ bankAccount.correspondentAccount }}</span>\n <span>\u0412\u0430\u043B\u044E\u0442\u0430: {{ bankAccount.currency.name }}</span>\n </div>\n <!-- <div class=\"flex flex-col md:flex-row gap-4\">\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconEdit3Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); editBankAccountsContragentClick.emit(bankAccount.id)\"\n ></button>\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconTrash2Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); deleteContragentBankAccountClick.emit(bankAccount)\"\n ></button>\n </div> -->\n </div>\n </ng-container>\n\n <ng-template #bankAccountsNotExist>\n <tui-notification size=\"l\">\n <div class=\"flex flex-wrap gap-2 font-medium\">\n \u0423 \u043A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u0430 <span class=\"font-bold\">{{ contragent.name }}</span> \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B.\n </div>\n </tui-notification>\n </ng-template>\n </div>\n </tui-loader>\n </ng-template>\n </sc-accordion>\n <sc-contacts-accordion\n *ngIf=\"contacts$\"\n [contacts$]=\"contacts$\"\n (addContactClick)=\"addContragentContactClick.emit(contragent)\"\n (deleteButtonClick)=\"onDeleteContragentContactClick($event, contragent)\"\n ></sc-contacts-accordion>\n </div>\n </ng-template>\n</sc-accordion>\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: "component", type: i3.ScAccordionComponent, selector: "sc-accordion", inputs: ["showAddButton", "showDeleteButton", "showArrow", "open", "size"], outputs: ["addButtonClick", "deleteButtonClick"] }, { kind: "directive", type: i4.ScAccordionContentDirective, selector: "ng-template[scAccordionContent]" }, { kind: "component", type: i5.TuiLoaderComponent, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { kind: "directive", type: i6.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i5.TuiNotificationComponent, selector: "tui-notification", inputs: ["hasIcon", "icon", "status", "size", "hideClose"], outputs: ["close"] }, { kind: "component", type: i7.ScContactsAccordionComponent, selector: "sc-contacts-accordion", inputs: ["contacts$"], outputs: ["addContactClick", "deleteButtonClick"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
42
59
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScContragentsAccordionItemComponent, decorators: [{
43
60
  type: Component,
44
- args: [{ selector: 'sc-contragents-accordion-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sc-accordion [showAddButton]=\"false\">\n {{ contragent.name }}\n <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n\n <ng-template scAccordionContent>\n <div class=\"flex flex-col gap-2\">\n <div class=\"flex gap-2\">\n <div class=\"flex flex-col gap-2 grow\">\n {{ contragent.name }}\n <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n <span *ngIf=\"$any(contragent).kpp as kpp\">\u041A\u041F\u041F: {{ kpp }}</span>\n </div>\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconEdit3Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); editContragentClick.emit()\"\n ></button>\n </div>\n\n <sc-accordion (addButtonClick)=\"addBankAccountsClick.emit(contragent.id)\">\n \u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n <ng-template scAccordionContent>\n <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n <div class=\"flex flex-col gap-2\">\n <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n <div class=\"flex flex-col gap-2 grow\">\n <span>\u0411\u0430\u043D\u043A: {{ bankAccount.bankName }}</span>\n <span>\u0411\u0418\u041A: {{ bankAccount.bic }}</span>\n <span>\u0420/\u0441\u0447\u0451\u0442: {{ bankAccount.accountNumber }}</span>\n <span>\u041A\u043E\u0440/\u0441\u0447\u0451\u0442: {{ bankAccount.correspondentAccount }}</span>\n <span>\u0412\u0430\u043B\u044E\u0442\u0430: {{ bankAccount.currency.name }}</span>\n </div>\n <div class=\"flex flex-col md:flex-row gap-4\">\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconEdit3Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation();\"\n ></button>\n\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconTrash2Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation();\"\n ></button>\n </div>\n </div>\n </ng-container>\n\n <ng-template #bankAccountsNotExist>\n <tui-notification size=\"l\">\n <div class=\"flex flex-wrap gap-2 font-medium\">\n \u0423 \u043A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u0430 <span class=\"font-bold\">{{ contragent.name }}</span> \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B.\n <button tuiButton size=\"s\" icon=\"tuiIconPlusLarge\" (click)=\"addBankAccountsClick.emit(contragent.id)\">\u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C</button>\n </div>\n </tui-notification>\n </ng-template>\n </div>\n </tui-loader>\n </ng-template>\n </sc-accordion>\n <sc-contacts-accordion *ngIf=\"contacts$\" [contacts$]=\"contacts$\"></sc-contacts-accordion>\n </div>\n </ng-template>\n</sc-accordion>\n" }]
61
+ args: [{ selector: 'sc-contragents-accordion-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<sc-accordion [showAddButton]=\"false\">\n {{ contragent.name }}\n <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n\n <ng-template scAccordionContent>\n <div class=\"flex flex-col gap-2\">\n <div class=\"flex gap-2\">\n <div class=\"flex flex-col gap-2 grow\">\n {{ contragent.name }}\n <span *ngIf=\"$any(contragent).inn as inn\">\u0418\u041D\u041D: {{ inn }}</span>\n <span *ngIf=\"$any(contragent).kpp as kpp\">\u041A\u041F\u041F: {{ kpp }}</span>\n </div>\n <!-- \u0424\u0443\u043D\u043A\u0446\u0438\u043E\u043D\u0430\u043B \u0443\u0434\u0430\u043B\u0435\u043D\u0438\u044F \u0438 \u0440\u0435\u0434\u0430\u043A\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u044F \u0432\u0440\u0435\u043C\u0435\u043D\u043D\u043E \u043D\u0435 \u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D \u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u0435\u043B\u044E. -->\n <!-- <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconEdit3Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); editContragentClick.emit(contragent.id)\"\n ></button>\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconTrash2Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); deleteContragentClick.emit(contragent)\"\n ></button> -->\n </div>\n\n <sc-accordion (addButtonClick)=\"addContragentBankAccountClick.emit(contragent)\">\n \u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n <ng-template scAccordionContent>\n <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n <div class=\"flex flex-col gap-2\">\n <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n <div class=\"flex flex-col gap-2 grow\">\n <span>\u0411\u0430\u043D\u043A: {{ bankAccount.bankName }}</span>\n <span>\u0411\u0418\u041A: {{ bankAccount.bic }}</span>\n <span>\u0420/\u0441\u0447\u0451\u0442: {{ bankAccount.accountNumber }}</span>\n <span>\u041A\u043E\u0440/\u0441\u0447\u0451\u0442: {{ bankAccount.correspondentAccount }}</span>\n <span>\u0412\u0430\u043B\u044E\u0442\u0430: {{ bankAccount.currency.name }}</span>\n </div>\n <!-- <div class=\"flex flex-col md:flex-row gap-4\">\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconEdit3Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); editBankAccountsContragentClick.emit(bankAccount.id)\"\n ></button>\n <button\n tuiIconButton\n size=\"m\"\n type=\"button\"\n icon=\"tuiIconTrash2Large\"\n tuiMode=\"onLight\"\n appearance=\"flat\"\n (click)=\"$event.stopPropagation(); deleteContragentBankAccountClick.emit(bankAccount)\"\n ></button>\n </div> -->\n </div>\n </ng-container>\n\n <ng-template #bankAccountsNotExist>\n <tui-notification size=\"l\">\n <div class=\"flex flex-wrap gap-2 font-medium\">\n \u0423 \u043A\u043E\u043D\u0442\u0440\u0430\u0433\u0435\u043D\u0442\u0430 <span class=\"font-bold\">{{ contragent.name }}</span> \u043D\u0435 \u0443\u043A\u0430\u0437\u0430\u043D\u044B \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B.\n </div>\n </tui-notification>\n </ng-template>\n </div>\n </tui-loader>\n </ng-template>\n </sc-accordion>\n <sc-contacts-accordion\n *ngIf=\"contacts$\"\n [contacts$]=\"contacts$\"\n (addContactClick)=\"addContragentContactClick.emit(contragent)\"\n (deleteButtonClick)=\"onDeleteContragentContactClick($event, contragent)\"\n ></sc-contacts-accordion>\n </div>\n </ng-template>\n</sc-accordion>\n" }]
45
62
  }], ctorParameters: function () { return [{ type: i1.ScContragentService }]; }, propDecorators: { contragent: [{
46
63
  type: Input
47
- }], addBankAccountsClick: [{
64
+ }], deleteContragentClick: [{
65
+ type: Output
66
+ }], addContragentBankAccountClick: [{
67
+ type: Output
68
+ }], deleteContragentBankAccountClick: [{
48
69
  type: Output
49
- }], editBankAccountsContragentClick: [{
70
+ }], addContragentContactClick: [{
50
71
  type: Output
51
- }], editContragentClick: [{
72
+ }], deleteContragentContactClick: [{
52
73
  type: Output
53
74
  }] } });
54
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-contragents-accordion-item.component.js","sourceRoot":"","sources":["../../../../../../projects/client-ui/contragents/contragents-accordion/contragents-accordion-item/sc-contragents-accordion-item.component.ts","../../../../../../projects/client-ui/contragents/contragents-accordion/contragents-accordion-item/sc-contragents-accordion-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;;;;;;;;;AAIxG;;GAEG;AAMH,MAAM,OAAO,mCAAmC;IAmC5C;;;;OAIG;IACH,YAAoC,iBAAsC;QAAtC,sBAAiB,GAAjB,iBAAiB,CAAqB;QAjC1E;;WAEG;QAEI,yBAAoB,GAAyB,IAAI,YAAY,EAAU,CAAC;QAE/E;;WAEG;QAEI,oCAA+B,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAEtF;;WAEG;QAEI,wBAAmB,GAAuB,IAAI,YAAY,EAAQ,CAAC;IAiBG,CAAC;IAE9E,kBAAkB;IACX,QAAQ;QACX,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,0BAA0B,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QAC3F,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IACvF,CAAC;;gIA9CQ,mCAAmC;oHAAnC,mCAAmC,sRCZhD,62JA6EA;2FDjEa,mCAAmC;kBAL/C,SAAS;+BACI,+BAA+B,mBAExB,uBAAuB,CAAC,MAAM;0GAOxC,UAAU;sBADhB,KAAK;gBAOC,oBAAoB;sBAD1B,MAAM;gBAOA,+BAA+B;sBADrC,MAAM;gBAOA,mBAAmB;sBADzB,MAAM","sourcesContent":["import { Component, ChangeDetectionStrategy, Output, EventEmitter, Input, OnInit } from '@angular/core';\nimport { ScContragent, ScContragentService, ScIBankAccount, ScIContact } from '@snabcentr/client-core';\nimport { Observable } from 'rxjs';\n\n/**\n * Компонент контрагента пользователя.\n */\n@Component({\n    selector: 'sc-contragents-accordion-item',\n    templateUrl: './sc-contragents-accordion-item.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ScContragentsAccordionItemComponent implements OnInit {\n    /**\n     * Контрагент пользователя.\n     */\n    @Input()\n    public contragent: ScContragent;\n\n    /**\n     * Событие нажатия на кнопку добавления банковского счёта контрагенту.\n     */\n    @Output()\n    public addBankAccountsClick: EventEmitter<number> = new EventEmitter<number>();\n\n    /**\n     * Событие нажатия на кнопку редактирования банковского счёта контрагента.\n     */\n    @Output()\n    public editBankAccountsContragentClick: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Событие нажатия на кнопку редактирования контрагента.\n     */\n    @Output()\n    public editContragentClick: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Список банковских счетов контрагента.\n     */\n    public bankAccounts$?: Observable<ScIBankAccount[] | null>;\n\n    /**\n     * Список банковских счетов контрагента.\n     */\n    public contacts$?: Observable<ScIContact[] | null>;\n\n    /**\n     * Инициализирует экземпляр класса {@link ScContragentsAccordionItemComponent}.\n     *\n     * @param contragentService Сервис работы с контрагентами.\n     */\n    public constructor(private readonly contragentService: ScContragentService) {}\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.bankAccounts$ = this.contragentService.getContragentBankAccounts$(this.contragent.id);\n        this.contacts$ = this.contragentService.getContragentContacts$(this.contragent.id);\n    }\n}\n","<sc-accordion [showAddButton]=\"false\">\n    {{ contragent.name }}\n    <span *ngIf=\"$any(contragent).inn as inn\">ИНН: {{ inn }}</span>\n\n    <ng-template scAccordionContent>\n        <div class=\"flex flex-col gap-2\">\n            <div class=\"flex gap-2\">\n                <div class=\"flex flex-col gap-2 grow\">\n                    {{ contragent.name }}\n                    <span *ngIf=\"$any(contragent).inn as inn\">ИНН: {{ inn }}</span>\n                    <span *ngIf=\"$any(contragent).kpp as kpp\">КПП: {{ kpp }}</span>\n                </div>\n                <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconEdit3Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); editContragentClick.emit()\"\n                ></button>\n            </div>\n\n            <sc-accordion (addButtonClick)=\"addBankAccountsClick.emit(contragent.id)\">\n                Банковские реквизиты\n                <ng-template scAccordionContent>\n                    <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n                        <div class=\"flex flex-col gap-2\">\n                            <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n                                <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n                                    <div class=\"flex flex-col gap-2 grow\">\n                                        <span>Банк: {{ bankAccount.bankName }}</span>\n                                        <span>БИК: {{ bankAccount.bic }}</span>\n                                        <span>Р/счёт: {{ bankAccount.accountNumber }}</span>\n                                        <span>Кор/счёт: {{ bankAccount.correspondentAccount }}</span>\n                                        <span>Валюта: {{ bankAccount.currency.name }}</span>\n                                    </div>\n                                    <div class=\"flex flex-col md:flex-row gap-4\">\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconEdit3Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation();\"\n                                        ></button>\n\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconTrash2Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation();\"\n                                        ></button>\n                                    </div>\n                                </div>\n                            </ng-container>\n\n                            <ng-template #bankAccountsNotExist>\n                                <tui-notification size=\"l\">\n                                    <div class=\"flex flex-wrap gap-2 font-medium\">\n                                        У контрагента <span class=\"font-bold\">{{ contragent.name }}</span> не указаны банковские реквизиты.\n                                        <button tuiButton size=\"s\" icon=\"tuiIconPlusLarge\" (click)=\"addBankAccountsClick.emit(contragent.id)\">Добавить</button>\n                                    </div>\n                                </tui-notification>\n                            </ng-template>\n                        </div>\n                    </tui-loader>\n                </ng-template>\n            </sc-accordion>\n            <sc-contacts-accordion *ngIf=\"contacts$\" [contacts$]=\"contacts$\"></sc-contacts-accordion>\n        </div>\n    </ng-template>\n</sc-accordion>\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-contragents-accordion-item.component.js","sourceRoot":"","sources":["../../../../../../projects/client-ui/contragents/contragents-accordion/contragents-accordion-item/sc-contragents-accordion-item.component.ts","../../../../../../projects/client-ui/contragents/contragents-accordion/contragents-accordion-item/sc-contragents-accordion-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;;;;;;;;;AAIxG;;GAEG;AAMH,MAAM,OAAO,mCAAmC;IA+C5C;;;;OAIG;IACH,YAAoC,iBAAsC;QAAtC,sBAAiB,GAAjB,iBAAiB,CAAqB;QA7C1E;;WAEG;QAEI,0BAAqB,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAE5F;;WAEG;QAEI,kCAA6B,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAEpG;;WAEG;QAEI,qCAAgC,GAAiC,IAAI,YAAY,EAAkB,CAAC;QAE3G;;WAEG;QAEI,8BAAyB,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAEhG;;WAEG;QAEI,iCAA4B,GAAoE,IAAI,YAAY,EAAqD,CAAC;IAiBhG,CAAC;IAE9E,kBAAkB;IACX,QAAQ;QACX,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,0BAA0B,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;QAC3F,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IACvF,CAAC;IAED;;;;;OAKG;IACI,8BAA8B,CAAC,OAAmB,EAAE,UAAwB;QAC/E,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC,CAAC;IACzF,CAAC;;gIApEQ,mCAAmC;oHAAnC,mCAAmC,oaCZhD,syLA0FA;2FD9Ea,mCAAmC;kBAL/C,SAAS;+BACI,+BAA+B,mBAExB,uBAAuB,CAAC,MAAM;0GAOxC,UAAU;sBADhB,KAAK;gBAOC,qBAAqB;sBAD3B,MAAM;gBAOA,6BAA6B;sBADnC,MAAM;gBAOA,gCAAgC;sBADtC,MAAM;gBAOA,yBAAyB;sBAD/B,MAAM;gBAOA,4BAA4B;sBADlC,MAAM","sourcesContent":["import { Component, ChangeDetectionStrategy, Output, EventEmitter, Input, OnInit } from '@angular/core';\nimport { ScContragent, ScContragentService, ScIBankAccount, ScIContact } from '@snabcentr/client-core';\nimport { Observable } from 'rxjs';\n\n/**\n * Компонент контрагента пользователя.\n */\n@Component({\n    selector: 'sc-contragents-accordion-item',\n    templateUrl: './sc-contragents-accordion-item.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ScContragentsAccordionItemComponent implements OnInit {\n    /**\n     * Контрагент пользователя.\n     */\n    @Input()\n    public contragent: ScContragent;\n\n    /**\n     * Событие нажатия на кнопку удаления контрагента.\n     */\n    @Output()\n    public deleteContragentClick: EventEmitter<ScContragent> = new EventEmitter<ScContragent>();\n\n    /**\n     * Событие нажатия на кнопку добавления банковского счёта контрагенту.\n     */\n    @Output()\n    public addContragentBankAccountClick: EventEmitter<ScContragent> = new EventEmitter<ScContragent>();\n\n    /**\n     * Событие нажатия на кнопку удаления банковского счёта контрагента.\n     */\n    @Output()\n    public deleteContragentBankAccountClick: EventEmitter<ScIBankAccount> = new EventEmitter<ScIBankAccount>();\n\n    /**\n     * Событие нажатия на кнопку добавления контактного лица контрагенту.\n     */\n    @Output()\n    public addContragentContactClick: EventEmitter<ScContragent> = new EventEmitter<ScContragent>();\n\n    /**\n     * Событие нажатия на кнопку удаления контактного лица у контрагента.\n     */\n    @Output()\n    public deleteContragentContactClick: EventEmitter<{ contact: ScIContact; contragent: ScContragent }> = new EventEmitter<{ contact: ScIContact; contragent: ScContragent }>();\n\n    /**\n     * Список банковских счетов контрагента.\n     */\n    public bankAccounts$?: Observable<ScIBankAccount[] | null>;\n\n    /**\n     * Список банковских счетов контрагента.\n     */\n    public contacts$?: Observable<ScIContact[] | null>;\n\n    /**\n     * Инициализирует экземпляр класса {@link ScContragentsAccordionItemComponent}.\n     *\n     * @param contragentService Сервис работы с контрагентами.\n     */\n    public constructor(private readonly contragentService: ScContragentService) {}\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.bankAccounts$ = this.contragentService.getContragentBankAccounts$(this.contragent.id);\n        this.contacts$ = this.contragentService.getContragentContacts$(this.contragent.id);\n    }\n\n    /**\n     * Обработчик нажатия на кнопку удаления контактного лица у контрагента.\n     *\n     * @param contact Контактное лицо.\n     * @param contragent Контрагент.\n     */\n    public onDeleteContragentContactClick(contact: ScIContact, contragent: ScContragent): void {\n        this.deleteContragentContactClick.emit({ contact: contact, contragent: contragent });\n    }\n}\n","<sc-accordion [showAddButton]=\"false\">\n    {{ contragent.name }}\n    <span *ngIf=\"$any(contragent).inn as inn\">ИНН: {{ inn }}</span>\n\n    <ng-template scAccordionContent>\n        <div class=\"flex flex-col gap-2\">\n            <div class=\"flex gap-2\">\n                <div class=\"flex flex-col gap-2 grow\">\n                    {{ contragent.name }}\n                    <span *ngIf=\"$any(contragent).inn as inn\">ИНН: {{ inn }}</span>\n                    <span *ngIf=\"$any(contragent).kpp as kpp\">КПП: {{ kpp }}</span>\n                </div>\n                <!-- Функционал удаления и редактирования временно не доступен пользователю. -->\n                <!-- <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconEdit3Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); editContragentClick.emit(contragent.id)\"\n                ></button>\n                <button\n                    tuiIconButton\n                    size=\"m\"\n                    type=\"button\"\n                    icon=\"tuiIconTrash2Large\"\n                    tuiMode=\"onLight\"\n                    appearance=\"flat\"\n                    (click)=\"$event.stopPropagation(); deleteContragentClick.emit(contragent)\"\n                ></button> -->\n            </div>\n\n            <sc-accordion (addButtonClick)=\"addContragentBankAccountClick.emit(contragent)\">\n                Банковские реквизиты\n                <ng-template scAccordionContent>\n                    <tui-loader *tuiLet=\"bankAccounts$ | async as bankAccounts\" [overlay]=\"true\" [showLoader]=\"bankAccounts === null\">\n                        <div class=\"flex flex-col gap-2\">\n                            <ng-container *ngIf=\"!bankAccounts || bankAccounts.length; else bankAccountsNotExist\">\n                                <div *ngFor=\"let bankAccount of bankAccounts\" class=\"flex gap-2 border-b border-tui-base-03\">\n                                    <div class=\"flex flex-col gap-2 grow\">\n                                        <span>Банк: {{ bankAccount.bankName }}</span>\n                                        <span>БИК: {{ bankAccount.bic }}</span>\n                                        <span>Р/счёт: {{ bankAccount.accountNumber }}</span>\n                                        <span>Кор/счёт: {{ bankAccount.correspondentAccount }}</span>\n                                        <span>Валюта: {{ bankAccount.currency.name }}</span>\n                                    </div>\n                                    <!-- <div class=\"flex flex-col md:flex-row gap-4\">\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconEdit3Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); editBankAccountsContragentClick.emit(bankAccount.id)\"\n                                        ></button>\n                                        <button\n                                            tuiIconButton\n                                            size=\"m\"\n                                            type=\"button\"\n                                            icon=\"tuiIconTrash2Large\"\n                                            tuiMode=\"onLight\"\n                                            appearance=\"flat\"\n                                            (click)=\"$event.stopPropagation(); deleteContragentBankAccountClick.emit(bankAccount)\"\n                                        ></button>\n                                    </div> -->\n                                </div>\n                            </ng-container>\n\n                            <ng-template #bankAccountsNotExist>\n                                <tui-notification size=\"l\">\n                                    <div class=\"flex flex-wrap gap-2 font-medium\">\n                                        У контрагента <span class=\"font-bold\">{{ contragent.name }}</span> не указаны банковские реквизиты.\n                                    </div>\n                                </tui-notification>\n                            </ng-template>\n                        </div>\n                    </tui-loader>\n                </ng-template>\n            </sc-accordion>\n            <sc-contacts-accordion\n                *ngIf=\"contacts$\"\n                [contacts$]=\"contacts$\"\n                (addContactClick)=\"addContragentContactClick.emit(contragent)\"\n                (deleteButtonClick)=\"onDeleteContragentContactClick($event, contragent)\"\n            ></sc-contacts-accordion>\n        </div>\n    </ng-template>\n</sc-accordion>\n"]}