barsa-develop-components 2.2.2 → 2.2.4

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 (75) hide show
  1. package/esm2022/barsa-develop-components.mjs +5 -0
  2. package/esm2022/lib/accept-reject/accept-reject.component.mjs +68 -0
  3. package/esm2022/lib/avatar/avatar.component.mjs +29 -0
  4. package/esm2022/lib/barcode-format-pipe.mjs +25 -0
  5. package/esm2022/lib/barcode-reader/barcode-reader.component.mjs +62 -0
  6. package/esm2022/lib/barcode-reader-dialog/barcode-reader-dialog.component.mjs +82 -0
  7. package/esm2022/lib/barcode-reader-video/barcode-reader-video.component.mjs +66 -0
  8. package/esm2022/lib/barcode.service.mjs +330 -0
  9. package/esm2022/lib/barsa-develop-components.module.mjs +292 -0
  10. package/esm2022/lib/barsa-document-list-item/barsa-document-list-item.component.mjs +104 -0
  11. package/esm2022/lib/barsa-documents/barsa-documents.component.mjs +159 -0
  12. package/esm2022/lib/barsa-geographic-location/barsa-geographic-location.component.mjs +173 -0
  13. package/esm2022/lib/card-content-image-and-title/card-content-image-and-title.component.mjs +50 -0
  14. package/esm2022/lib/card-content-line-chart/card-content-line-chart.component.mjs +36 -0
  15. package/esm2022/lib/card-header-big-image-title-and-subtitle/card-header-big-image-title-and-subtitle.component.mjs +19 -0
  16. package/esm2022/lib/card-header-kpi/card-header-kpi.component.mjs +40 -0
  17. package/esm2022/lib/card-header-logo-title-subtitle/card-header-logo-title-subtitle.component.mjs +45 -0
  18. package/esm2022/lib/checkbox-button/checkbox-button.component.mjs +23 -0
  19. package/esm2022/lib/column-chip/column-chip.component.mjs +44 -0
  20. package/esm2022/lib/column-form-viewer/column-form-viewer.component.mjs +88 -0
  21. package/esm2022/lib/column-progressbar/column-progressbar.component.mjs +87 -0
  22. package/esm2022/lib/enum-info-micro-proccess-flow/enum-info-micro-proccess-flow.component.mjs +18 -0
  23. package/esm2022/lib/footer/footer.component.mjs +43 -0
  24. package/esm2022/lib/form-card/form-card.component.mjs +17 -0
  25. package/esm2022/lib/form-chart-content/form-chart-content.component.mjs +36 -0
  26. package/esm2022/lib/form-content-quick-view/form-content-quick-view.component.mjs +102 -0
  27. package/esm2022/lib/form-report-view/form-report-view.component.mjs +25 -0
  28. package/esm2022/lib/form-report-view-item/form-report-view-item.component.mjs +45 -0
  29. package/esm2022/lib/g4b-details/g4b-details.component.mjs +28 -0
  30. package/esm2022/lib/g4b-estelam/g4b-estelam.component.mjs +30 -0
  31. package/esm2022/lib/geographic-location/geographic-location.component.mjs +88 -0
  32. package/esm2022/lib/login-form/login-form.component.mjs +55 -0
  33. package/esm2022/lib/login-social-conncetions/login-social-conncetions.component.mjs +30 -0
  34. package/esm2022/lib/master-detail-card-form/master-detail-card-form.component.mjs +17 -0
  35. package/esm2022/lib/media-file-uploader/media-file-uploader.component.mjs +238 -0
  36. package/esm2022/lib/micro-proccess-flow/micro-proccess-flow.component.mjs +52 -0
  37. package/esm2022/lib/micro-process-flow-view/micro-process-flow-view.component.mjs +24 -0
  38. package/esm2022/lib/mo-info-micro-proccess-flow/mo-info-micro-proccess-flow.component.mjs +23 -0
  39. package/esm2022/lib/models/document-item.mjs +2 -0
  40. package/esm2022/lib/models/documents-setting.mjs +2 -0
  41. package/esm2022/lib/models/form-report-view-setting.mjs +2 -0
  42. package/esm2022/lib/models/index.mjs +8 -0
  43. package/esm2022/lib/models/micro-process-flow-view-setting.mjs +2 -0
  44. package/esm2022/lib/models/person.mjs +2 -0
  45. package/esm2022/lib/models/service-desk-view-of-services-setting.mjs +2 -0
  46. package/esm2022/lib/models/tab-process-view-setting.mjs +2 -0
  47. package/esm2022/lib/pipes/datasource-to-flow-item.mjs +23 -0
  48. package/esm2022/lib/pipes/index.mjs +3 -0
  49. package/esm2022/lib/pipes/mo-list-to-flow-item.pipe.mjs +23 -0
  50. package/esm2022/lib/query-string-form-observable/query-string-form-observable.component.mjs +37 -0
  51. package/esm2022/lib/query-string-observable/query-string-observable.component.mjs +22 -0
  52. package/esm2022/lib/report-button-view/report-button-view.component.mjs +37 -0
  53. package/esm2022/lib/report-line-chart-view/report-line-chart-view.component.mjs +12 -0
  54. package/esm2022/lib/report-tab-view/report-tab-view.component.mjs +27 -0
  55. package/esm2022/lib/resend-verification-code/resend-verification-code.component.mjs +62 -0
  56. package/esm2022/lib/service-desk-card-content-mojavezhay-akhz-shode/service-desk-card-content-mojavezhay-akhz-shode.component.mjs +28 -0
  57. package/esm2022/lib/service-desk-form-layout-content-mojavez/service-desk-form-layout-content-mojavez.component.mjs +110 -0
  58. package/esm2022/lib/service-desk-header/service-desk-header.component.mjs +238 -0
  59. package/esm2022/lib/service-desk-servcie-detail/service-desk-servcie-detail.component.mjs +142 -0
  60. package/esm2022/lib/service-desk-view-of-services/service-desk-view-of-services.component.mjs +37 -0
  61. package/esm2022/lib/setting-form/setting-form.component.mjs +64 -0
  62. package/esm2022/lib/subform-in-row-report/subform-in-row-report.component.mjs +73 -0
  63. package/esm2022/lib/tab-process-view/tab-process-view.component.mjs +48 -0
  64. package/esm2022/lib/table-view-vertical-columns/table-view-vertical-columns.component.mjs +16 -0
  65. package/esm2022/lib/timer-count-down/timer-count-down.component.mjs +104 -0
  66. package/esm2022/lib/token-report-view/token-report-view.component.mjs +27 -0
  67. package/esm2022/lib/ui-enum-segmented-button/ui-enum-segmented-button.component.mjs +25 -0
  68. package/esm2022/lib/ui-num-rate/ui-num-rate.component.mjs +29 -0
  69. package/esm2022/lib/ui-person/ui-person.component.mjs +160 -0
  70. package/esm2022/lib/ui-person/ui-person.pipe.mjs +41 -0
  71. package/esm2022/lib/ui-pictures-carousel/ui-pictures-carousel.component.mjs +17 -0
  72. package/esm2022/lib/ui-text-field-search/ui-text-field-search.component.mjs +42 -0
  73. package/esm2022/lib/ulv-context-menu-item-show-file-content/ulv-context-menu-item-show-file-content.component.mjs +69 -0
  74. package/esm2022/public-api.mjs +64 -0
  75. package/package.json +3 -1
@@ -0,0 +1,292 @@
1
+ import { CUSTOM_ELEMENTS_SCHEMA, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
+ import { FundamentalNgxCoreModule } from '@fundamental-ngx/core';
5
+ import { BarsaNovinRayCoreModule, BaseModule } from 'barsa-novin-ray-core';
6
+ import { BarsaSapUiModule } from 'barsa-sap-ui';
7
+ import { BarsaTilesModule } from 'barsa-tiles';
8
+ import { BarsaEchartsModule } from 'barsa-echarts';
9
+ import { LoginFormComponent } from './login-form/login-form.component';
10
+ import { LoginSocialConncetionsComponent } from './login-social-conncetions/login-social-conncetions.component';
11
+ import { UiPersonComponent } from './ui-person/ui-person.component';
12
+ import { UiPersonPipe } from './ui-person/ui-person.pipe';
13
+ import { BarcodeReaderComponent } from './barcode-reader/barcode-reader.component';
14
+ import { BarcodeReaderDialogComponent } from './barcode-reader-dialog/barcode-reader-dialog.component';
15
+ import { BarcodeReaderVideoComponent } from './barcode-reader-video/barcode-reader-video.component';
16
+ import { UserMediaBaseService, WebBarcodeService } from './barcode.service';
17
+ import { SettingFormComponent } from './setting-form/setting-form.component';
18
+ import { MicroProcessFlowViewComponent } from './micro-process-flow-view/micro-process-flow-view.component';
19
+ import { UiEnumSegmentedButtonComponent } from './ui-enum-segmented-button/ui-enum-segmented-button.component';
20
+ import { TabProcessViewComponent } from './tab-process-view/tab-process-view.component';
21
+ import { UiTextFieldSearchComponent } from './ui-text-field-search/ui-text-field-search.component';
22
+ import { BarcodeFormatPipe } from './barcode-format-pipe';
23
+ import { ServiceDeskHeaderComponent } from './service-desk-header/service-desk-header.component';
24
+ import { CardContentImageAndTitleComponent } from './card-content-image-and-title/card-content-image-and-title.component';
25
+ import { CardHeaderLogoTitleSubtitleComponent } from './card-header-logo-title-subtitle/card-header-logo-title-subtitle.component';
26
+ import { FormContentQuickViewComponent } from './form-content-quick-view/form-content-quick-view.component';
27
+ import { ServiceDeskServcieDetailComponent } from './service-desk-servcie-detail/service-desk-servcie-detail.component';
28
+ import { ServiceDeskViewOfServicesComponent } from './service-desk-view-of-services/service-desk-view-of-services.component';
29
+ import { ServiceDeskCardContentMojavezhayAkhzShodeComponent } from './service-desk-card-content-mojavezhay-akhz-shode/service-desk-card-content-mojavezhay-akhz-shode.component';
30
+ import { CardHeaderBigImageTitleAndSubtitleComponent } from './card-header-big-image-title-and-subtitle/card-header-big-image-title-and-subtitle.component';
31
+ import { ServiceDeskFormLayoutContentMojavezComponent } from './service-desk-form-layout-content-mojavez/service-desk-form-layout-content-mojavez.component';
32
+ import { UlvContextMenuItemShowFileContentComponent } from './ulv-context-menu-item-show-file-content/ulv-context-menu-item-show-file-content.component';
33
+ import { ResendVerificationCodeComponent } from './resend-verification-code/resend-verification-code.component';
34
+ import { CheckboxButtonComponent } from './checkbox-button/checkbox-button.component';
35
+ import { ReportTabViewComponent } from './report-tab-view/report-tab-view.component';
36
+ import { ReportLineChartViewComponent } from './report-line-chart-view/report-line-chart-view.component';
37
+ import { CardHeaderKpiComponent } from './card-header-kpi/card-header-kpi.component';
38
+ import { CardContentLineChartComponent } from './card-content-line-chart/card-content-line-chart.component';
39
+ import { FormChartContentComponent } from './form-chart-content/form-chart-content.component';
40
+ import { TableViewVerticalColumnsComponent } from './table-view-vertical-columns/table-view-vertical-columns.component';
41
+ import { QueryStringObservableComponent } from './query-string-observable/query-string-observable.component';
42
+ import { QueryStringFormObservableComponent } from './query-string-form-observable/query-string-form-observable.component';
43
+ import { G4bDetailsComponent } from './g4b-details/g4b-details.component';
44
+ import { AvatarComponent } from './avatar/avatar.component';
45
+ import { G4bEstelamComponent } from './g4b-estelam/g4b-estelam.component';
46
+ import { TimerCountDownComponent } from './timer-count-down/timer-count-down.component';
47
+ import { MoInfoMicroProccessFlowComponent } from './mo-info-micro-proccess-flow/mo-info-micro-proccess-flow.component';
48
+ import { MicroProccessFlowComponent } from './micro-proccess-flow/micro-proccess-flow.component';
49
+ import { EnumInfoMicroProccessFlowComponent } from './enum-info-micro-proccess-flow/enum-info-micro-proccess-flow.component';
50
+ import { DataSourceToFlowItemPipe, MoListToFlowItemPipe } from './pipes';
51
+ import { UiPicturesCarouselComponent } from './ui-pictures-carousel/ui-pictures-carousel.component';
52
+ import { UiNumRateComponent } from './ui-num-rate/ui-num-rate.component';
53
+ import { MediaFileUploaderComponent } from './media-file-uploader/media-file-uploader.component';
54
+ import { SubformInRowReportComponent } from './subform-in-row-report/subform-in-row-report.component';
55
+ import { MasterDetailCardFormComponent } from './master-detail-card-form/master-detail-card-form.component';
56
+ import { ReportButtonViewComponent } from './report-button-view/report-button-view.component';
57
+ import { BarsaDocumentsComponent } from './barsa-documents/barsa-documents.component';
58
+ import { BarsaDocumentListItemComponent } from './barsa-document-list-item/barsa-document-list-item.component';
59
+ import { AcceptRejectComponent } from './accept-reject/accept-reject.component';
60
+ import { FooterComponent } from './footer/footer.component';
61
+ import { GeographicLocationComponent } from './geographic-location/geographic-location.component';
62
+ import { BarsaGeographicLocationComponent } from './barsa-geographic-location/barsa-geographic-location.component';
63
+ import { TokenReportViewComponent } from './token-report-view/token-report-view.component';
64
+ import { ColumnFormViewerComponent } from './column-form-viewer/column-form-viewer.component';
65
+ import { PlatformInputGroupModule } from '@fundamental-ngx/platform';
66
+ import { FormReportViewComponent } from './form-report-view/form-report-view.component';
67
+ import { FormReportViewItemComponent } from './form-report-view-item/form-report-view-item.component';
68
+ import { FormCardComponent } from './form-card/form-card.component';
69
+ import { ColumnProgressbarComponent } from './column-progressbar/column-progressbar.component';
70
+ import { ColumnChipComponent } from '../public-api';
71
+ import * as i0 from "@angular/core";
72
+ import * as i1 from "barsa-novin-ray-core";
73
+ const components = [
74
+ LoginFormComponent,
75
+ LoginSocialConncetionsComponent,
76
+ UiPersonComponent,
77
+ BarcodeReaderComponent,
78
+ BarcodeReaderDialogComponent,
79
+ BarcodeReaderVideoComponent,
80
+ SettingFormComponent,
81
+ MicroProcessFlowViewComponent,
82
+ UiEnumSegmentedButtonComponent,
83
+ TabProcessViewComponent,
84
+ UiTextFieldSearchComponent,
85
+ ServiceDeskHeaderComponent,
86
+ CardContentImageAndTitleComponent,
87
+ CardHeaderLogoTitleSubtitleComponent,
88
+ FormContentQuickViewComponent,
89
+ ServiceDeskServcieDetailComponent,
90
+ ServiceDeskViewOfServicesComponent,
91
+ ServiceDeskCardContentMojavezhayAkhzShodeComponent,
92
+ CardHeaderBigImageTitleAndSubtitleComponent,
93
+ ServiceDeskFormLayoutContentMojavezComponent,
94
+ UlvContextMenuItemShowFileContentComponent,
95
+ ResendVerificationCodeComponent,
96
+ CheckboxButtonComponent,
97
+ ReportTabViewComponent,
98
+ ReportLineChartViewComponent,
99
+ CardHeaderKpiComponent,
100
+ CardContentLineChartComponent,
101
+ FormChartContentComponent,
102
+ TableViewVerticalColumnsComponent,
103
+ QueryStringObservableComponent,
104
+ QueryStringFormObservableComponent,
105
+ G4bDetailsComponent,
106
+ AvatarComponent,
107
+ G4bEstelamComponent,
108
+ TimerCountDownComponent,
109
+ MoInfoMicroProccessFlowComponent,
110
+ MicroProccessFlowComponent,
111
+ EnumInfoMicroProccessFlowComponent,
112
+ UiPicturesCarouselComponent,
113
+ UiNumRateComponent,
114
+ MediaFileUploaderComponent,
115
+ SubformInRowReportComponent,
116
+ MasterDetailCardFormComponent,
117
+ ReportButtonViewComponent,
118
+ BarsaDocumentsComponent,
119
+ BarsaDocumentListItemComponent,
120
+ AcceptRejectComponent,
121
+ FooterComponent,
122
+ GeographicLocationComponent,
123
+ BarsaGeographicLocationComponent,
124
+ TokenReportViewComponent,
125
+ ColumnFormViewerComponent,
126
+ FormReportViewComponent,
127
+ FormReportViewItemComponent,
128
+ FormCardComponent,
129
+ ColumnProgressbarComponent,
130
+ ColumnChipComponent
131
+ ];
132
+ const pipes = [UiPersonPipe, BarcodeFormatPipe, MoListToFlowItemPipe, DataSourceToFlowItemPipe];
133
+ export class BarsaDevelopComponentsModule extends BaseModule {
134
+ constructor(dcm, cfr) {
135
+ super(dcm, cfr, 'BarsaDevelopComponentsModule');
136
+ this.dcm = dcm;
137
+ this.cfr = cfr;
138
+ this.dynamicComponents = [...components];
139
+ }
140
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaDevelopComponentsModule, deps: [{ token: i1.DynamicComponentService }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.NgModule }); }
141
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: BarsaDevelopComponentsModule, declarations: [LoginFormComponent,
142
+ LoginSocialConncetionsComponent,
143
+ UiPersonComponent,
144
+ BarcodeReaderComponent,
145
+ BarcodeReaderDialogComponent,
146
+ BarcodeReaderVideoComponent,
147
+ SettingFormComponent,
148
+ MicroProcessFlowViewComponent,
149
+ UiEnumSegmentedButtonComponent,
150
+ TabProcessViewComponent,
151
+ UiTextFieldSearchComponent,
152
+ ServiceDeskHeaderComponent,
153
+ CardContentImageAndTitleComponent,
154
+ CardHeaderLogoTitleSubtitleComponent,
155
+ FormContentQuickViewComponent,
156
+ ServiceDeskServcieDetailComponent,
157
+ ServiceDeskViewOfServicesComponent,
158
+ ServiceDeskCardContentMojavezhayAkhzShodeComponent,
159
+ CardHeaderBigImageTitleAndSubtitleComponent,
160
+ ServiceDeskFormLayoutContentMojavezComponent,
161
+ UlvContextMenuItemShowFileContentComponent,
162
+ ResendVerificationCodeComponent,
163
+ CheckboxButtonComponent,
164
+ ReportTabViewComponent,
165
+ ReportLineChartViewComponent,
166
+ CardHeaderKpiComponent,
167
+ CardContentLineChartComponent,
168
+ FormChartContentComponent,
169
+ TableViewVerticalColumnsComponent,
170
+ QueryStringObservableComponent,
171
+ QueryStringFormObservableComponent,
172
+ G4bDetailsComponent,
173
+ AvatarComponent,
174
+ G4bEstelamComponent,
175
+ TimerCountDownComponent,
176
+ MoInfoMicroProccessFlowComponent,
177
+ MicroProccessFlowComponent,
178
+ EnumInfoMicroProccessFlowComponent,
179
+ UiPicturesCarouselComponent,
180
+ UiNumRateComponent,
181
+ MediaFileUploaderComponent,
182
+ SubformInRowReportComponent,
183
+ MasterDetailCardFormComponent,
184
+ ReportButtonViewComponent,
185
+ BarsaDocumentsComponent,
186
+ BarsaDocumentListItemComponent,
187
+ AcceptRejectComponent,
188
+ FooterComponent,
189
+ GeographicLocationComponent,
190
+ BarsaGeographicLocationComponent,
191
+ TokenReportViewComponent,
192
+ ColumnFormViewerComponent,
193
+ FormReportViewComponent,
194
+ FormReportViewItemComponent,
195
+ FormCardComponent,
196
+ ColumnProgressbarComponent,
197
+ ColumnChipComponent, UiPersonPipe, BarcodeFormatPipe, MoListToFlowItemPipe, DataSourceToFlowItemPipe], imports: [CommonModule,
198
+ BarsaNovinRayCoreModule,
199
+ ReactiveFormsModule,
200
+ BarsaSapUiModule,
201
+ BarsaEchartsModule,
202
+ BarsaTilesModule,
203
+ FundamentalNgxCoreModule,
204
+ PlatformInputGroupModule,
205
+ FormsModule], exports: [LoginFormComponent,
206
+ LoginSocialConncetionsComponent,
207
+ UiPersonComponent,
208
+ BarcodeReaderComponent,
209
+ BarcodeReaderDialogComponent,
210
+ BarcodeReaderVideoComponent,
211
+ SettingFormComponent,
212
+ MicroProcessFlowViewComponent,
213
+ UiEnumSegmentedButtonComponent,
214
+ TabProcessViewComponent,
215
+ UiTextFieldSearchComponent,
216
+ ServiceDeskHeaderComponent,
217
+ CardContentImageAndTitleComponent,
218
+ CardHeaderLogoTitleSubtitleComponent,
219
+ FormContentQuickViewComponent,
220
+ ServiceDeskServcieDetailComponent,
221
+ ServiceDeskViewOfServicesComponent,
222
+ ServiceDeskCardContentMojavezhayAkhzShodeComponent,
223
+ CardHeaderBigImageTitleAndSubtitleComponent,
224
+ ServiceDeskFormLayoutContentMojavezComponent,
225
+ UlvContextMenuItemShowFileContentComponent,
226
+ ResendVerificationCodeComponent,
227
+ CheckboxButtonComponent,
228
+ ReportTabViewComponent,
229
+ ReportLineChartViewComponent,
230
+ CardHeaderKpiComponent,
231
+ CardContentLineChartComponent,
232
+ FormChartContentComponent,
233
+ TableViewVerticalColumnsComponent,
234
+ QueryStringObservableComponent,
235
+ QueryStringFormObservableComponent,
236
+ G4bDetailsComponent,
237
+ AvatarComponent,
238
+ G4bEstelamComponent,
239
+ TimerCountDownComponent,
240
+ MoInfoMicroProccessFlowComponent,
241
+ MicroProccessFlowComponent,
242
+ EnumInfoMicroProccessFlowComponent,
243
+ UiPicturesCarouselComponent,
244
+ UiNumRateComponent,
245
+ MediaFileUploaderComponent,
246
+ SubformInRowReportComponent,
247
+ MasterDetailCardFormComponent,
248
+ ReportButtonViewComponent,
249
+ BarsaDocumentsComponent,
250
+ BarsaDocumentListItemComponent,
251
+ AcceptRejectComponent,
252
+ FooterComponent,
253
+ GeographicLocationComponent,
254
+ BarsaGeographicLocationComponent,
255
+ TokenReportViewComponent,
256
+ ColumnFormViewerComponent,
257
+ FormReportViewComponent,
258
+ FormReportViewItemComponent,
259
+ FormCardComponent,
260
+ ColumnProgressbarComponent,
261
+ ColumnChipComponent] }); }
262
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaDevelopComponentsModule, providers: [UserMediaBaseService, WebBarcodeService], imports: [CommonModule,
263
+ BarsaNovinRayCoreModule,
264
+ ReactiveFormsModule,
265
+ BarsaSapUiModule,
266
+ BarsaEchartsModule,
267
+ BarsaTilesModule,
268
+ FundamentalNgxCoreModule,
269
+ PlatformInputGroupModule,
270
+ FormsModule] }); }
271
+ }
272
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaDevelopComponentsModule, decorators: [{
273
+ type: NgModule,
274
+ args: [{
275
+ declarations: [...components, ...pipes],
276
+ schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],
277
+ imports: [
278
+ CommonModule,
279
+ BarsaNovinRayCoreModule,
280
+ ReactiveFormsModule,
281
+ BarsaSapUiModule,
282
+ BarsaEchartsModule,
283
+ BarsaTilesModule,
284
+ FundamentalNgxCoreModule,
285
+ PlatformInputGroupModule,
286
+ FormsModule
287
+ ],
288
+ providers: [UserMediaBaseService, WebBarcodeService],
289
+ exports: [...components]
290
+ }]
291
+ }], ctorParameters: () => [{ type: i1.DynamicComponentService }, { type: i0.ComponentFactoryResolver }] });
292
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-develop-components.module.js","sourceRoot":"","sources":["../../../../projects/barsa-develop-components/src/lib/barsa-develop-components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, CUSTOM_ELEMENTS_SCHEMA, NgModule, NO_ERRORS_SCHEMA } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { FundamentalNgxCoreModule } from '@fundamental-ngx/core';\r\n\r\nimport { BarsaNovinRayCoreModule, BaseModule, DynamicComponentService } from 'barsa-novin-ray-core';\r\nimport { BarsaSapUiModule } from 'barsa-sap-ui';\r\nimport { BarsaTilesModule } from 'barsa-tiles';\r\nimport { BarsaEchartsModule } from 'barsa-echarts';\r\n\r\nimport { LoginFormComponent } from './login-form/login-form.component';\r\nimport { LoginSocialConncetionsComponent } from './login-social-conncetions/login-social-conncetions.component';\r\nimport { UiPersonComponent } from './ui-person/ui-person.component';\r\nimport { UiPersonPipe } from './ui-person/ui-person.pipe';\r\nimport { BarcodeReaderComponent } from './barcode-reader/barcode-reader.component';\r\nimport { BarcodeReaderDialogComponent } from './barcode-reader-dialog/barcode-reader-dialog.component';\r\nimport { BarcodeReaderVideoComponent } from './barcode-reader-video/barcode-reader-video.component';\r\nimport { UserMediaBaseService, WebBarcodeService } from './barcode.service';\r\nimport { SettingFormComponent } from './setting-form/setting-form.component';\r\nimport { MicroProcessFlowViewComponent } from './micro-process-flow-view/micro-process-flow-view.component';\r\nimport { UiEnumSegmentedButtonComponent } from './ui-enum-segmented-button/ui-enum-segmented-button.component';\r\nimport { TabProcessViewComponent } from './tab-process-view/tab-process-view.component';\r\nimport { UiTextFieldSearchComponent } from './ui-text-field-search/ui-text-field-search.component';\r\nimport { BarcodeFormatPipe } from './barcode-format-pipe';\r\nimport { ServiceDeskHeaderComponent } from './service-desk-header/service-desk-header.component';\r\nimport { CardContentImageAndTitleComponent } from './card-content-image-and-title/card-content-image-and-title.component';\r\nimport { CardHeaderLogoTitleSubtitleComponent } from './card-header-logo-title-subtitle/card-header-logo-title-subtitle.component';\r\nimport { FormContentQuickViewComponent } from './form-content-quick-view/form-content-quick-view.component';\r\nimport { ServiceDeskServcieDetailComponent } from './service-desk-servcie-detail/service-desk-servcie-detail.component';\r\nimport { ServiceDeskViewOfServicesComponent } from './service-desk-view-of-services/service-desk-view-of-services.component';\r\nimport { ServiceDeskCardContentMojavezhayAkhzShodeComponent } from './service-desk-card-content-mojavezhay-akhz-shode/service-desk-card-content-mojavezhay-akhz-shode.component';\r\nimport { CardHeaderBigImageTitleAndSubtitleComponent } from './card-header-big-image-title-and-subtitle/card-header-big-image-title-and-subtitle.component';\r\nimport { ServiceDeskFormLayoutContentMojavezComponent } from './service-desk-form-layout-content-mojavez/service-desk-form-layout-content-mojavez.component';\r\nimport { UlvContextMenuItemShowFileContentComponent } from './ulv-context-menu-item-show-file-content/ulv-context-menu-item-show-file-content.component';\r\nimport { ResendVerificationCodeComponent } from './resend-verification-code/resend-verification-code.component';\r\nimport { CheckboxButtonComponent } from './checkbox-button/checkbox-button.component';\r\nimport { ReportTabViewComponent } from './report-tab-view/report-tab-view.component';\r\nimport { ReportLineChartViewComponent } from './report-line-chart-view/report-line-chart-view.component';\r\nimport { CardHeaderKpiComponent } from './card-header-kpi/card-header-kpi.component';\r\nimport { CardContentLineChartComponent } from './card-content-line-chart/card-content-line-chart.component';\r\nimport { FormChartContentComponent } from './form-chart-content/form-chart-content.component';\r\nimport { TableViewVerticalColumnsComponent } from './table-view-vertical-columns/table-view-vertical-columns.component';\r\nimport { QueryStringObservableComponent } from './query-string-observable/query-string-observable.component';\r\nimport { QueryStringFormObservableComponent } from './query-string-form-observable/query-string-form-observable.component';\r\nimport { G4bDetailsComponent } from './g4b-details/g4b-details.component';\r\nimport { AvatarComponent } from './avatar/avatar.component';\r\nimport { G4bEstelamComponent } from './g4b-estelam/g4b-estelam.component';\r\nimport { TimerCountDownComponent } from './timer-count-down/timer-count-down.component';\r\nimport { MoInfoMicroProccessFlowComponent } from './mo-info-micro-proccess-flow/mo-info-micro-proccess-flow.component';\r\nimport { MicroProccessFlowComponent } from './micro-proccess-flow/micro-proccess-flow.component';\r\nimport { EnumInfoMicroProccessFlowComponent } from './enum-info-micro-proccess-flow/enum-info-micro-proccess-flow.component';\r\n\r\nimport { DataSourceToFlowItemPipe, MoListToFlowItemPipe } from './pipes';\r\nimport { UiPicturesCarouselComponent } from './ui-pictures-carousel/ui-pictures-carousel.component';\r\nimport { UiNumRateComponent } from './ui-num-rate/ui-num-rate.component';\r\nimport { MediaFileUploaderComponent } from './media-file-uploader/media-file-uploader.component';\r\nimport { SubformInRowReportComponent } from './subform-in-row-report/subform-in-row-report.component';\r\nimport { MasterDetailCardFormComponent } from './master-detail-card-form/master-detail-card-form.component';\r\nimport { ReportButtonViewComponent } from './report-button-view/report-button-view.component';\r\nimport { BarsaDocumentsComponent } from './barsa-documents/barsa-documents.component';\r\nimport { BarsaDocumentListItemComponent } from './barsa-document-list-item/barsa-document-list-item.component';\r\nimport { AcceptRejectComponent } from './accept-reject/accept-reject.component';\r\nimport { FooterComponent } from './footer/footer.component';\r\nimport { GeographicLocationComponent } from './geographic-location/geographic-location.component';\r\nimport { BarsaGeographicLocationComponent } from './barsa-geographic-location/barsa-geographic-location.component';\r\nimport { TokenReportViewComponent } from './token-report-view/token-report-view.component';\r\nimport { ColumnFormViewerComponent } from './column-form-viewer/column-form-viewer.component';\r\nimport { PlatformInputGroupModule } from '@fundamental-ngx/platform';\r\nimport { FormReportViewComponent } from './form-report-view/form-report-view.component';\r\nimport { FormReportViewItemComponent } from './form-report-view-item/form-report-view-item.component';\r\nimport { FormCardComponent } from './form-card/form-card.component';\r\nimport { ColumnProgressbarComponent } from './column-progressbar/column-progressbar.component';\r\nimport { ColumnChipComponent } from '../public-api';\r\n\r\nconst components = [\r\n    LoginFormComponent,\r\n    LoginSocialConncetionsComponent,\r\n    UiPersonComponent,\r\n    BarcodeReaderComponent,\r\n    BarcodeReaderDialogComponent,\r\n    BarcodeReaderVideoComponent,\r\n    SettingFormComponent,\r\n    MicroProcessFlowViewComponent,\r\n    UiEnumSegmentedButtonComponent,\r\n    TabProcessViewComponent,\r\n    UiTextFieldSearchComponent,\r\n    ServiceDeskHeaderComponent,\r\n    CardContentImageAndTitleComponent,\r\n    CardHeaderLogoTitleSubtitleComponent,\r\n    FormContentQuickViewComponent,\r\n    ServiceDeskServcieDetailComponent,\r\n    ServiceDeskViewOfServicesComponent,\r\n    ServiceDeskCardContentMojavezhayAkhzShodeComponent,\r\n    CardHeaderBigImageTitleAndSubtitleComponent,\r\n    ServiceDeskFormLayoutContentMojavezComponent,\r\n    UlvContextMenuItemShowFileContentComponent,\r\n    ResendVerificationCodeComponent,\r\n    CheckboxButtonComponent,\r\n    ReportTabViewComponent,\r\n    ReportLineChartViewComponent,\r\n    CardHeaderKpiComponent,\r\n    CardContentLineChartComponent,\r\n    FormChartContentComponent,\r\n    TableViewVerticalColumnsComponent,\r\n    QueryStringObservableComponent,\r\n    QueryStringFormObservableComponent,\r\n    G4bDetailsComponent,\r\n    AvatarComponent,\r\n    G4bEstelamComponent,\r\n    TimerCountDownComponent,\r\n    MoInfoMicroProccessFlowComponent,\r\n    MicroProccessFlowComponent,\r\n    EnumInfoMicroProccessFlowComponent,\r\n    UiPicturesCarouselComponent,\r\n    UiNumRateComponent,\r\n    MediaFileUploaderComponent,\r\n    SubformInRowReportComponent,\r\n    MasterDetailCardFormComponent,\r\n    ReportButtonViewComponent,\r\n    BarsaDocumentsComponent,\r\n    BarsaDocumentListItemComponent,\r\n    AcceptRejectComponent,\r\n    FooterComponent,\r\n    GeographicLocationComponent,\r\n    BarsaGeographicLocationComponent,\r\n    TokenReportViewComponent,\r\n    ColumnFormViewerComponent,\r\n    FormReportViewComponent,\r\n    FormReportViewItemComponent,\r\n    FormCardComponent,\r\n    ColumnProgressbarComponent,\r\n    ColumnChipComponent\r\n];\r\nconst pipes = [UiPersonPipe, BarcodeFormatPipe, MoListToFlowItemPipe, DataSourceToFlowItemPipe];\r\n@NgModule({\r\n    declarations: [...components, ...pipes],\r\n    schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],\r\n    imports: [\r\n        CommonModule,\r\n        BarsaNovinRayCoreModule,\r\n        ReactiveFormsModule,\r\n        BarsaSapUiModule,\r\n        BarsaEchartsModule,\r\n        BarsaTilesModule,\r\n        FundamentalNgxCoreModule,\r\n        PlatformInputGroupModule,\r\n        FormsModule\r\n    ],\r\n    providers: [UserMediaBaseService, WebBarcodeService],\r\n    exports: [...components]\r\n})\r\nexport class BarsaDevelopComponentsModule extends BaseModule {\r\n    protected dynamicComponents = [...components];\r\n    constructor(protected dcm: DynamicComponentService, protected cfr: ComponentFactoryResolver) {\r\n        super(dcm, cfr, 'BarsaDevelopComponentsModule');\r\n    }\r\n}\r\n"]}
@@ -0,0 +1,104 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { AudioMimeType, BaseComponent, ImageMimeType, PreventDefaulEvent, VideoMimeType, AllFilesMimeType, isImage, getIcon } from 'barsa-novin-ray-core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "barsa-novin-ray-core";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "barsa-sap-ui";
7
+ import * as i4 from "@fundamental-ngx/core/action-sheet";
8
+ import * as i5 from "@fundamental-ngx/core/avatar";
9
+ import * as i6 from "@fundamental-ngx/core/button";
10
+ import * as i7 from "@fundamental-ngx/core/file-uploader";
11
+ import * as i8 from "@fundamental-ngx/core/form";
12
+ import * as i9 from "@fundamental-ngx/core/inline-help";
13
+ import * as i10 from "@fundamental-ngx/core/object-status";
14
+ import * as i11 from "@fundamental-ngx/core/table";
15
+ import * as i12 from "@fundamental-ngx/core/toolbar";
16
+ export class BarsaDocumentListItemComponent extends BaseComponent {
17
+ constructor(_cdr, _picFieldSrc) {
18
+ super();
19
+ this._cdr = _cdr;
20
+ this._picFieldSrc = _picFieldSrc;
21
+ this.statusChanged = new EventEmitter();
22
+ this.rejectTextChange = new EventEmitter();
23
+ this.fileSelectionChange = new EventEmitter();
24
+ this.removeFile = new EventEmitter();
25
+ this.fullscreen = new EventEmitter();
26
+ this.download = new EventEmitter();
27
+ this.downloadAll = new EventEmitter();
28
+ this.hasFiles = false;
29
+ }
30
+ ngOnInit() {
31
+ super.ngOnInit();
32
+ const documentItem = this.documentItem;
33
+ documentItem.$ValidExtensions = `
34
+ ${documentItem.SupportImage ? ImageMimeType : ''},
35
+ ${documentItem.SupportAudio ? AudioMimeType : ''},
36
+ ${documentItem.SupportVideo ? VideoMimeType : ''},
37
+ ${documentItem.SupportFile ? AllFilesMimeType : ''}
38
+ `;
39
+ }
40
+ ngOnChanges(changes) {
41
+ super.ngOnChanges(changes);
42
+ const { files } = changes;
43
+ files && Array.isArray(files.currentValue) && this._setFirstImage(files.currentValue);
44
+ this._detectChanges();
45
+ }
46
+ onReject(e) {
47
+ this.statusChanged.emit({ value: e, rejectedText: e === 2 ? '' : this.rejectedReason });
48
+ }
49
+ onRejectedTextChange(e) {
50
+ this.rejectTextChange.emit(e.target.value);
51
+ }
52
+ onPreventClick(e) {
53
+ PreventDefaulEvent(e);
54
+ }
55
+ onFileSelection(files) {
56
+ this.fileSelectionChange.emit(files);
57
+ }
58
+ _setFirstImage(files) {
59
+ files.length &&
60
+ (this.firstImageUrl = isImage(files[0].Type)
61
+ ? this._picFieldSrc.transform(files[0].Id, 'ID', null, '', 120, 120)
62
+ : getIcon(files[0].Type));
63
+ }
64
+ _detectChanges() {
65
+ this._cdr.detectChanges();
66
+ }
67
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaDocumentListItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.PictureFieldSourcePipe }], target: i0.ɵɵFactoryTarget.Component }); }
68
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: BarsaDocumentListItemComponent, selector: "bdc-barsa-document-list-item", inputs: { documentItem: "documentItem", deviceSize: "deviceSize", files: "files", accepted: "accepted", rejectedReason: "rejectedReason", readonly: "readonly", status: "status", uploadingState: "uploadingState" }, outputs: { statusChanged: "statusChanged", rejectTextChange: "rejectTextChange", fileSelectionChange: "fileSelectionChange", removeFile: "removeFile", fullscreen: "fullscreen", download: "download", downloadAll: "downloadAll" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- <li fd-list-item style=\"padding: 0.5rem 1rem\">\r\n<span fd-list-thumbnail>\r\n <fd-icon *ngIf=\"documentItem.FontIcon\" [glyph]=\"documentItem.FontIcon\"></fd-icon>\r\n <fd-avatar\r\n *ngIf=\"documentItem.Avatar\"\r\n size=\"s\"\r\n [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:''\"\r\n [clickable]=\"true\"\r\n ></fd-avatar\r\n ></span>\r\n\r\n <div fd-list-content>\r\n <div fd-list-title>\r\n <div style=\"display: flex; column-gap: 3px\">\r\n <strong\r\n >{{ documentItem.Title }}\r\n <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\r\n >*({{ '\u0627\u062C\u0628\u0627\u0631\u06CC' | bbbTranslate }})\r\n </span>\r\n </strong>\r\n <div\r\n *ngIf=\"documentItem.$Accepted === false || documentItem.$Accepted === true\"\r\n style=\"display: flex; column-gap: 3px; flex-wrap: wrap; align-items: center\"\r\n >\r\n <span\r\n fd-object-status\r\n [status]=\"accepted ? 'positive' : 'negative'\"\r\n [label]=\"accepted ? acceptedText : rejectedText\"\r\n [clickable]=\"true\"\r\n [inverted]=\"true\"\r\n [aria-label]=\"accepted ? acceptedText : rejectedText\"\r\n ></span>\r\n <fd-popover title=\"Rejected document\" *ngIf=\"rejectedReason && !accepted\">\r\n <fd-popover-control>\r\n <span\r\n fd-object-status\r\n status=\"negative\"\r\n glyph=\"question-mark\"\r\n glyphAriaLabel=\"Negative\"\r\n title=\"Rejected document\"\r\n ></span>\r\n </fd-popover-control>\r\n <fd-popover-body>\r\n <fd-message-strip type=\"error\" [dismissible]=\"false\">\r\n {{ rejectedReason }}\r\n </fd-message-strip>\r\n </fd-popover-body>\r\n </fd-popover>\r\n </div>\r\n </div>\r\n </div>\r\n <div fd-list-byline [twoCol]=\"true\" [class.smallSize]=\"deviceSize === 's'\">\r\n <div fd-list-byline-left>\r\n <div style=\"display: flex; flex-direction: column; row-gap: 5px; flex-wrap: wrap\">\r\n <span>\r\n {{ documentItem.Description }}\r\n </span>\r\n <div style=\"display: flex; flex-wrap: wrap; column-gap: 3px; align-items: center\">\r\n <ng-container *ngIf=\"hasFiles\">\r\n <button fd-button [fdType]=\"'transparent'\" glyph=\"show\" (click)=\"onFullscreen()\"></button>\r\n <ng-container *ngFor=\"let file of files\">\r\n <fd-token\r\n [readOnly]=\"readonly\"\r\n *ngIf=\"!file.IsDeleted\"\r\n (onCloseClick)=\"onRemoveFile(file)\"\r\n >{{ file.FileName }}</fd-token\r\n >\r\n </ng-container>\r\n </ng-container>\r\n <button\r\n fd-button\r\n *ngIf=\"documentItem.MaxFileCount && !readonly\"\r\n glyph=\"attachment\"\r\n [label]=\"'AttachFile' | bbbTranslate\"\r\n (click)=\"!readonly && uploader.open()\"\r\n ></button>\r\n <fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n fd-toolbar-item\r\n [id]=\"documentItem.ItemKey\"\r\n [name]=\"'pictures_' + documentItem.ItemKey\"\r\n [accept]=\"documentItem.$ValidExtensions\"\r\n [fileLimit]=\"documentItem.MaxFileCount\"\r\n [multiple]=\"documentItem.MaxFileCount > 0\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n ></fd-file-uploader>\r\n </div>\r\n </div>\r\n </div>\r\n <div fd-list-byline-right *ngIf=\"documentItem.CanAccept\">\r\n <bdc-accept-reject\r\n [rejectedReason]=\"rejectedReason\"\r\n [positiveText]=\"acceptedText\"\r\n [negativeText]=\"rejectedText\"\r\n [deviceSize]=\"deviceSize\"\r\n [readonly]=\"readonly\"\r\n ></bdc-accept-reject>\r\n </div>\r\n </div>\r\n </div>\r\n </li> -->\r\n\r\n<tr fd-table-row>\r\n <td fd-table-cell>\r\n @if (documentItem.Avatar && !files.length) {\r\n <fd-avatar\r\n size=\"s\"\r\n [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:'':64:64\"\r\n [clickable]=\"true\"\r\n [transparent]=\"true\"\r\n ></fd-avatar>\r\n } @else { @if (files.length) {\r\n <fd-avatar [transparent]=\"true\" size=\"s\" [image]=\"firstImageUrl\" [clickable]=\"true\"></fd-avatar>\r\n } @if (!files.length) {\r\n <fd-avatar [transparent]=\"true\" size=\"s\" [glyph]=\"documentItem.FontIcon\" [clickable]=\"true\"></fd-avatar>\r\n } }\r\n </td>\r\n <td fd-table-cell style=\"min-width: 140px\">\r\n <p fd-table-text>\r\n <strong\r\n >{{ documentItem.Title }}\r\n @if (documentItem.IsRequired) {\r\n <span fd-object-status status=\"negative\">*({{ '\u0627\u062C\u0628\u0627\u0631\u06CC' | bbbTranslate }}) </span>\r\n }\r\n </strong>\r\n </p>\r\n <div>\r\n <span>\r\n {{ documentItem.Description }}\r\n </span>\r\n </div>\r\n </td>\r\n\r\n <td fd-table-cell>\r\n <ng-container>\r\n <!-- <ul fd-list>\r\n <li fd-list-item *ngFor=\"let file of files; let ind = index\">\r\n <span fd-list-title>\r\n {{ file.FileName }}\r\n </span>\r\n <span fd-list-secondary>\r\n <button ariaLabel=\"Remove\" title=\"Remove\" fd-button glyph=\"delete\" ></button>\r\n </span>\r\n </li>\r\n </ul> -->\r\n <div style=\"display: flex; align-items: flex-start; column-gap: 3px; row-gap: 3px; flex-direction: column\">\r\n @for (file of files; track file) {\r\n <!-- <span><fd-icon glyph=\"attachment\"></fd-icon><a fd-link>{{file.FileName}}</a></span> -->\r\n @if (!file.IsDeleted) {\r\n <bsu-file-viewer-popover\r\n [file]=\"file\"\r\n [deviceSize]=\"deviceSize\"\r\n [canDownload]=\"true\"\r\n (remove)=\"removeFile.emit(file)\"\r\n ></bsu-file-viewer-popover>\r\n } }\r\n <!-- <button\r\n fd-button\r\n *ngIf=\"+documentItem.MaxFileCount && !readonly\"\r\n glyph=\"add\"\r\n (click)=\"!readonly && uploader.open()\"\r\n ></button> -->\r\n </div>\r\n <!-- <p *ngFor=\"let file of files\" fd-table-text>\r\n <fd-action-sheet >\r\n <fd-action-sheet-control>\r\n <button\r\n fd-button\r\n glyph=\"settings\"\r\n title=\"Open Action Sheet Mobile\"\r\n id=\"fd-action-sheet-mobile-control\"\r\n aria-haspopup=\"menu\"\r\n [label]=\"file.FileName ||''\"\r\n aria-controls=\"fd-action-sheet-mobile-body\"\r\n ></button>\r\n </fd-action-sheet-control>\r\n\r\n <fd-action-sheet-body\r\n actionSheetBodyId=\"fd-action-sheet-mobile-body\"\r\n ariaLabelledBy=\"fd-action-sheet-mobile-control\"\r\n >\r\n <li fd-action-sheet-item label=\"Search\" glyph=\"search\"></li>\r\n <li fd-action-sheet-item label=\"Download\" glyph=\"download\" ></li>\r\n <li fd-action-sheet-item label=\"Accept\" glyph=\"accept\" ></li>\r\n <li fd-action-sheet-item label=\"Reject\" glyph=\"cancel\" ></li>\r\n <li fd-action-sheet-item label=\"Decide Later\" [isCloseButton]=\"true\"></li>\r\n <li fd-action-sheet-item label=\"Cancel\" [negative]=\"true\" [isCloseButton]=\"true\"></li>\r\n </fd-action-sheet-body>\r\n </fd-action-sheet>\r\n </p> -->\r\n </ng-container>\r\n </td>\r\n <td fd-table-cell>\r\n <div class=\"status\" style=\"position: relative\">\r\n @if (+documentItem.MaxFileCount && !readonly) {\r\n <button\r\n fd-button\r\n glyph=\"attachment\"\r\n [label]=\"'AttachFile' | bbbTranslate\"\r\n [disabled]=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\r\n (click)=\"!readonly && uploader.open()\"\r\n >\r\n @if (uploadingState?.key === documentItem.Title && uploadingState?.uploading) {\r\n <bsu-mask [marginTop]=\"'3px'\"></bsu-mask>\r\n }\r\n </button>\r\n }\r\n <button\r\n fd-button\r\n glyph=\"show\"\r\n fullscreenFiles\r\n [files]=\"files\"\r\n [title]=\"documentItem.Title\"\r\n [fd-inline-help]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\r\n [aria-describedby]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\r\n [ariaLabel]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\r\n fullscreenFiles\r\n [disabled]=\"!files.length\"\r\n [files]=\"files\"\r\n ></button>\r\n <button\r\n fd-button\r\n glyph=\"download\"\r\n [fd-inline-help]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\r\n [aria-describedby]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\r\n [ariaLabel]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\r\n downloadFiles\r\n [disabled]=\"!files.length\"\r\n [files]=\"files\"\r\n (click)=\"downloadAll.emit()\"\r\n ></button>\r\n </div>\r\n </td>\r\n <td fd-table-cell>\r\n <fd-action-sheet #actionSheet>\r\n <fd-action-sheet-control>\r\n <ng-container *ngTemplateOutlet=\"statusTpl\"></ng-container>\r\n </fd-action-sheet-control>\r\n <fd-action-sheet-body>\r\n <li\r\n fd-action-sheet-item\r\n [label]=\"'Accept' | bbbTranslate\"\r\n glyph=\"accept\"\r\n (click)=\"actionSheet.close(); onReject(2)\"\r\n ></li>\r\n <li\r\n fd-action-sheet-item\r\n [label]=\"'Reject' | bbbTranslate\"\r\n glyph=\"cancel\"\r\n (click)=\"actionSheet.close(); onReject(3)\"\r\n ></li>\r\n </fd-action-sheet-body>\r\n </fd-action-sheet>\r\n\r\n @if (status === 3) {\r\n <p fd-table-text maxWidth=\"400px\">\r\n @if (readonly && rejectedReason) {\r\n <span> {{ rejectedReason | bbbTranslate }} </span>\r\n } @if (!readonly) {\r\n <input\r\n fd-form-control\r\n [value]=\"rejectedReason | bbbTranslate\"\r\n [placeholder]=\"'\u062F\u0644\u0627\u06CC\u0644 \u0631\u062F \u0645\u062F\u0631\u06A9' | bbbTranslate\"\r\n />\r\n }\r\n </p>\r\n }\r\n </td>\r\n</tr>\r\n\r\n<fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n fd-toolbar-item\r\n [id]=\"documentItem.ItemKey\"\r\n [name]=\"'pictures_' + documentItem.ItemKey\"\r\n [accept]=\"documentItem.$ValidExtensions\"\r\n [fileLimit]=\"documentItem.MaxFileCount\"\r\n [multiple]=\"documentItem.MaxFileCount > 0\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<ng-template #statusTpl>\r\n <div class=\"status\">\r\n <button fd-button fdType=\"transparent\">\r\n @if (status === 1) {\r\n <span\r\n fd-object-status\r\n [label]=\"'[\u067E\u06CC\u0648\u0633\u062A \u0645\u062F\u0627\u0631\u06A9]' | bbbTranslate\"\r\n [aria-label]=\"'[\u067E\u06CC\u0648\u0633\u062A \u0645\u062F\u0627\u0631\u06A9]' | bbbTranslate\"\r\n ></span>\r\n } @if (status === 2) {\r\n <span\r\n fd-object-status\r\n glyph=\"message-success\"\r\n status=\"positive\"\r\n [label]=\"'Accepted' | bbbTranslate\"\r\n [label]=\"'Accepted' | bbbTranslate\"\r\n ></span>\r\n } @if (status === 3) {\r\n <span\r\n fd-object-status\r\n glyph=\"cancel\"\r\n status=\"negative\"\r\n [label]=\"'Rejected' | bbbTranslate\"\r\n [aria-label]=\"'Rejected' | bbbTranslate\"\r\n ></span>\r\n }\r\n </button>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:contents}::ng-deep .fd-list--byline .fd-list__byline-left,::ng-deep .fd-list--byline .fd-list__byline-right{line-height:1.1rem!important}.fd-list__byline.smallSize{flex-direction:column;row-gap:5px}.fd-list__byline.smallSize div{width:100%}td{white-space:nowrap;padding:.5rem}fd-avatar ::ng-deep i{font-size:2.3rem!important}.status{display:flex;align-items:center;column-gap:3px;row-gap:3px}.status span.fd-object-status{font-size:var(--sapFontSize)!important;font-weight:700!important}.status span.fd-object-status ::ng-deep fd-icon{font-size:var(--sapFontSize);font-weight:700}\n"], dependencies: [{ kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }, { kind: "component", type: i3.FileViewerPopoverComponent, selector: "bsu-file-viewer-popover", inputs: ["files", "file", "deviceSize", "canDownload", "disableRemove", "fdType"], outputs: ["remove"] }, { kind: "directive", type: i3.FullscreenFilesDirective, selector: "[fullscreenFiles]", inputs: ["files", "title", "deviceSize", "isImageGallery", "component"] }, { kind: "directive", type: i3.DownloadFilesDirective, selector: "[downloadFiles]", inputs: ["files"] }, { kind: "component", type: i4.ActionSheetComponent, selector: "fd-action-sheet", inputs: ["mobile", "placement", "noArrow", "isOpen", "keyboardSupport", "triggers"], outputs: ["focusEscapeList", "isOpenChange"] }, { kind: "component", type: i4.ActionSheetControlComponent, selector: "fd-action-sheet-control", outputs: ["clicked"] }, { kind: "component", type: i4.ActionSheetItemComponent, selector: "[fd-action-sheet-item]", inputs: ["label", "glyph", "glyphFont", "negative", "isCloseButton", "disabled"], outputs: ["keyDown"] }, { kind: "component", type: i4.ActionSheetBodyComponent, selector: "fd-action-sheet-body", inputs: ["actionSheetBodyId", "mobile", "ariaLabel", "ariaLabelledby"] }, { kind: "component", type: i5.AvatarComponent, selector: "fd-avatar", inputs: ["class", "id", "ariaLabel", "ariaLabelledby", "label", "size", "font", "glyph", "zoomGlyph", "circle", "transparent", "contain", "placeholder", "tile", "border", "colorAccent", "colorIndication", "random", "clickable", "valueState", "image", "alterIcon", "backupImage"], outputs: ["avatarClicked", "zoomGlyphClicked"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i7.FileUploaderComponent, selector: "fd-file-uploader", inputs: ["disabled", "required", "multiple", "accept", "dragndrop", "maxFileSize", "minFileSize", "id", "ariaLabel", "ariaLabelledBy", "placeholder", "buttonLabel", "buttonAriaLabel", "state", "fileLimit", "inputHidden", "width"], outputs: ["selectedFilesChanged", "selectedInvalidFiles", "onDragEnter", "onDragLeave"] }, { kind: "component", type: i8.FormControlComponent, selector: "input[fd-form-control], textarea[fd-form-control]", inputs: ["state", "type", "class", "ariaLabel", "ariaLabelledBy"] }, { kind: "directive", type: i9.InlineHelpDirective, selector: "[fd-inline-help]:not([fd-inline-help-template]), [fd-inline-help-template]:not([fd-inline-help])", inputs: ["triggers", "noArrow", "closeOnEscapeKey", "closeOnOutsideClick", "fd-inline-help"] }, { kind: "component", type: i10.ObjectStatusComponent, selector: "[fd-object-status]", inputs: ["class", "status", "glyph", "glyphFont", "label", "glyphAriaLabel", "indicationColor", "clickable", "inverted", "large", "secondaryIndication", "textTemplate"] }, { kind: "directive", type: i11.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i11.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "hoverable", "fitContent", "noPadding", "noData", "nonInteractive", "key"] }, { kind: "directive", type: i11.TableTextDirective, selector: "[fdTableText], [fd-table-text]", inputs: ["fdTableTextClass", "noWrap", "title", "maxWidth"] }, { kind: "directive", type: i12.ToolbarItemDirective, selector: "[fd-toolbar-item], [fdOverflowGroup], [fdOverflowPriority]", inputs: ["fdOverflowPriority", "fdOverflowGroup"] }, { kind: "pipe", type: i1.PictureFieldSourcePipe, name: "picFieldSrc" }, { kind: "pipe", type: i1.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
69
+ }
70
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BarsaDocumentListItemComponent, decorators: [{
71
+ type: Component,
72
+ args: [{ selector: 'bdc-barsa-document-list-item', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<!-- <li fd-list-item style=\"padding: 0.5rem 1rem\">\r\n<span fd-list-thumbnail>\r\n <fd-icon *ngIf=\"documentItem.FontIcon\" [glyph]=\"documentItem.FontIcon\"></fd-icon>\r\n <fd-avatar\r\n *ngIf=\"documentItem.Avatar\"\r\n size=\"s\"\r\n [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:''\"\r\n [clickable]=\"true\"\r\n ></fd-avatar\r\n ></span>\r\n\r\n <div fd-list-content>\r\n <div fd-list-title>\r\n <div style=\"display: flex; column-gap: 3px\">\r\n <strong\r\n >{{ documentItem.Title }}\r\n <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\r\n >*({{ '\u0627\u062C\u0628\u0627\u0631\u06CC' | bbbTranslate }})\r\n </span>\r\n </strong>\r\n <div\r\n *ngIf=\"documentItem.$Accepted === false || documentItem.$Accepted === true\"\r\n style=\"display: flex; column-gap: 3px; flex-wrap: wrap; align-items: center\"\r\n >\r\n <span\r\n fd-object-status\r\n [status]=\"accepted ? 'positive' : 'negative'\"\r\n [label]=\"accepted ? acceptedText : rejectedText\"\r\n [clickable]=\"true\"\r\n [inverted]=\"true\"\r\n [aria-label]=\"accepted ? acceptedText : rejectedText\"\r\n ></span>\r\n <fd-popover title=\"Rejected document\" *ngIf=\"rejectedReason && !accepted\">\r\n <fd-popover-control>\r\n <span\r\n fd-object-status\r\n status=\"negative\"\r\n glyph=\"question-mark\"\r\n glyphAriaLabel=\"Negative\"\r\n title=\"Rejected document\"\r\n ></span>\r\n </fd-popover-control>\r\n <fd-popover-body>\r\n <fd-message-strip type=\"error\" [dismissible]=\"false\">\r\n {{ rejectedReason }}\r\n </fd-message-strip>\r\n </fd-popover-body>\r\n </fd-popover>\r\n </div>\r\n </div>\r\n </div>\r\n <div fd-list-byline [twoCol]=\"true\" [class.smallSize]=\"deviceSize === 's'\">\r\n <div fd-list-byline-left>\r\n <div style=\"display: flex; flex-direction: column; row-gap: 5px; flex-wrap: wrap\">\r\n <span>\r\n {{ documentItem.Description }}\r\n </span>\r\n <div style=\"display: flex; flex-wrap: wrap; column-gap: 3px; align-items: center\">\r\n <ng-container *ngIf=\"hasFiles\">\r\n <button fd-button [fdType]=\"'transparent'\" glyph=\"show\" (click)=\"onFullscreen()\"></button>\r\n <ng-container *ngFor=\"let file of files\">\r\n <fd-token\r\n [readOnly]=\"readonly\"\r\n *ngIf=\"!file.IsDeleted\"\r\n (onCloseClick)=\"onRemoveFile(file)\"\r\n >{{ file.FileName }}</fd-token\r\n >\r\n </ng-container>\r\n </ng-container>\r\n <button\r\n fd-button\r\n *ngIf=\"documentItem.MaxFileCount && !readonly\"\r\n glyph=\"attachment\"\r\n [label]=\"'AttachFile' | bbbTranslate\"\r\n (click)=\"!readonly && uploader.open()\"\r\n ></button>\r\n <fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n fd-toolbar-item\r\n [id]=\"documentItem.ItemKey\"\r\n [name]=\"'pictures_' + documentItem.ItemKey\"\r\n [accept]=\"documentItem.$ValidExtensions\"\r\n [fileLimit]=\"documentItem.MaxFileCount\"\r\n [multiple]=\"documentItem.MaxFileCount > 0\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n ></fd-file-uploader>\r\n </div>\r\n </div>\r\n </div>\r\n <div fd-list-byline-right *ngIf=\"documentItem.CanAccept\">\r\n <bdc-accept-reject\r\n [rejectedReason]=\"rejectedReason\"\r\n [positiveText]=\"acceptedText\"\r\n [negativeText]=\"rejectedText\"\r\n [deviceSize]=\"deviceSize\"\r\n [readonly]=\"readonly\"\r\n ></bdc-accept-reject>\r\n </div>\r\n </div>\r\n </div>\r\n </li> -->\r\n\r\n<tr fd-table-row>\r\n <td fd-table-cell>\r\n @if (documentItem.Avatar && !files.length) {\r\n <fd-avatar\r\n size=\"s\"\r\n [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:'':64:64\"\r\n [clickable]=\"true\"\r\n [transparent]=\"true\"\r\n ></fd-avatar>\r\n } @else { @if (files.length) {\r\n <fd-avatar [transparent]=\"true\" size=\"s\" [image]=\"firstImageUrl\" [clickable]=\"true\"></fd-avatar>\r\n } @if (!files.length) {\r\n <fd-avatar [transparent]=\"true\" size=\"s\" [glyph]=\"documentItem.FontIcon\" [clickable]=\"true\"></fd-avatar>\r\n } }\r\n </td>\r\n <td fd-table-cell style=\"min-width: 140px\">\r\n <p fd-table-text>\r\n <strong\r\n >{{ documentItem.Title }}\r\n @if (documentItem.IsRequired) {\r\n <span fd-object-status status=\"negative\">*({{ '\u0627\u062C\u0628\u0627\u0631\u06CC' | bbbTranslate }}) </span>\r\n }\r\n </strong>\r\n </p>\r\n <div>\r\n <span>\r\n {{ documentItem.Description }}\r\n </span>\r\n </div>\r\n </td>\r\n\r\n <td fd-table-cell>\r\n <ng-container>\r\n <!-- <ul fd-list>\r\n <li fd-list-item *ngFor=\"let file of files; let ind = index\">\r\n <span fd-list-title>\r\n {{ file.FileName }}\r\n </span>\r\n <span fd-list-secondary>\r\n <button ariaLabel=\"Remove\" title=\"Remove\" fd-button glyph=\"delete\" ></button>\r\n </span>\r\n </li>\r\n </ul> -->\r\n <div style=\"display: flex; align-items: flex-start; column-gap: 3px; row-gap: 3px; flex-direction: column\">\r\n @for (file of files; track file) {\r\n <!-- <span><fd-icon glyph=\"attachment\"></fd-icon><a fd-link>{{file.FileName}}</a></span> -->\r\n @if (!file.IsDeleted) {\r\n <bsu-file-viewer-popover\r\n [file]=\"file\"\r\n [deviceSize]=\"deviceSize\"\r\n [canDownload]=\"true\"\r\n (remove)=\"removeFile.emit(file)\"\r\n ></bsu-file-viewer-popover>\r\n } }\r\n <!-- <button\r\n fd-button\r\n *ngIf=\"+documentItem.MaxFileCount && !readonly\"\r\n glyph=\"add\"\r\n (click)=\"!readonly && uploader.open()\"\r\n ></button> -->\r\n </div>\r\n <!-- <p *ngFor=\"let file of files\" fd-table-text>\r\n <fd-action-sheet >\r\n <fd-action-sheet-control>\r\n <button\r\n fd-button\r\n glyph=\"settings\"\r\n title=\"Open Action Sheet Mobile\"\r\n id=\"fd-action-sheet-mobile-control\"\r\n aria-haspopup=\"menu\"\r\n [label]=\"file.FileName ||''\"\r\n aria-controls=\"fd-action-sheet-mobile-body\"\r\n ></button>\r\n </fd-action-sheet-control>\r\n\r\n <fd-action-sheet-body\r\n actionSheetBodyId=\"fd-action-sheet-mobile-body\"\r\n ariaLabelledBy=\"fd-action-sheet-mobile-control\"\r\n >\r\n <li fd-action-sheet-item label=\"Search\" glyph=\"search\"></li>\r\n <li fd-action-sheet-item label=\"Download\" glyph=\"download\" ></li>\r\n <li fd-action-sheet-item label=\"Accept\" glyph=\"accept\" ></li>\r\n <li fd-action-sheet-item label=\"Reject\" glyph=\"cancel\" ></li>\r\n <li fd-action-sheet-item label=\"Decide Later\" [isCloseButton]=\"true\"></li>\r\n <li fd-action-sheet-item label=\"Cancel\" [negative]=\"true\" [isCloseButton]=\"true\"></li>\r\n </fd-action-sheet-body>\r\n </fd-action-sheet>\r\n </p> -->\r\n </ng-container>\r\n </td>\r\n <td fd-table-cell>\r\n <div class=\"status\" style=\"position: relative\">\r\n @if (+documentItem.MaxFileCount && !readonly) {\r\n <button\r\n fd-button\r\n glyph=\"attachment\"\r\n [label]=\"'AttachFile' | bbbTranslate\"\r\n [disabled]=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\r\n (click)=\"!readonly && uploader.open()\"\r\n >\r\n @if (uploadingState?.key === documentItem.Title && uploadingState?.uploading) {\r\n <bsu-mask [marginTop]=\"'3px'\"></bsu-mask>\r\n }\r\n </button>\r\n }\r\n <button\r\n fd-button\r\n glyph=\"show\"\r\n fullscreenFiles\r\n [files]=\"files\"\r\n [title]=\"documentItem.Title\"\r\n [fd-inline-help]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\r\n [aria-describedby]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\r\n [ariaLabel]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\r\n fullscreenFiles\r\n [disabled]=\"!files.length\"\r\n [files]=\"files\"\r\n ></button>\r\n <button\r\n fd-button\r\n glyph=\"download\"\r\n [fd-inline-help]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\r\n [aria-describedby]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\r\n [ariaLabel]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\r\n downloadFiles\r\n [disabled]=\"!files.length\"\r\n [files]=\"files\"\r\n (click)=\"downloadAll.emit()\"\r\n ></button>\r\n </div>\r\n </td>\r\n <td fd-table-cell>\r\n <fd-action-sheet #actionSheet>\r\n <fd-action-sheet-control>\r\n <ng-container *ngTemplateOutlet=\"statusTpl\"></ng-container>\r\n </fd-action-sheet-control>\r\n <fd-action-sheet-body>\r\n <li\r\n fd-action-sheet-item\r\n [label]=\"'Accept' | bbbTranslate\"\r\n glyph=\"accept\"\r\n (click)=\"actionSheet.close(); onReject(2)\"\r\n ></li>\r\n <li\r\n fd-action-sheet-item\r\n [label]=\"'Reject' | bbbTranslate\"\r\n glyph=\"cancel\"\r\n (click)=\"actionSheet.close(); onReject(3)\"\r\n ></li>\r\n </fd-action-sheet-body>\r\n </fd-action-sheet>\r\n\r\n @if (status === 3) {\r\n <p fd-table-text maxWidth=\"400px\">\r\n @if (readonly && rejectedReason) {\r\n <span> {{ rejectedReason | bbbTranslate }} </span>\r\n } @if (!readonly) {\r\n <input\r\n fd-form-control\r\n [value]=\"rejectedReason | bbbTranslate\"\r\n [placeholder]=\"'\u062F\u0644\u0627\u06CC\u0644 \u0631\u062F \u0645\u062F\u0631\u06A9' | bbbTranslate\"\r\n />\r\n }\r\n </p>\r\n }\r\n </td>\r\n</tr>\r\n\r\n<fd-file-uploader\r\n #uploader\r\n [style.display]=\"'none'\"\r\n fd-toolbar-item\r\n [id]=\"documentItem.ItemKey\"\r\n [name]=\"'pictures_' + documentItem.ItemKey\"\r\n [accept]=\"documentItem.$ValidExtensions\"\r\n [fileLimit]=\"documentItem.MaxFileCount\"\r\n [multiple]=\"documentItem.MaxFileCount > 0\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<ng-template #statusTpl>\r\n <div class=\"status\">\r\n <button fd-button fdType=\"transparent\">\r\n @if (status === 1) {\r\n <span\r\n fd-object-status\r\n [label]=\"'[\u067E\u06CC\u0648\u0633\u062A \u0645\u062F\u0627\u0631\u06A9]' | bbbTranslate\"\r\n [aria-label]=\"'[\u067E\u06CC\u0648\u0633\u062A \u0645\u062F\u0627\u0631\u06A9]' | bbbTranslate\"\r\n ></span>\r\n } @if (status === 2) {\r\n <span\r\n fd-object-status\r\n glyph=\"message-success\"\r\n status=\"positive\"\r\n [label]=\"'Accepted' | bbbTranslate\"\r\n [label]=\"'Accepted' | bbbTranslate\"\r\n ></span>\r\n } @if (status === 3) {\r\n <span\r\n fd-object-status\r\n glyph=\"cancel\"\r\n status=\"negative\"\r\n [label]=\"'Rejected' | bbbTranslate\"\r\n [aria-label]=\"'Rejected' | bbbTranslate\"\r\n ></span>\r\n }\r\n </button>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:contents}::ng-deep .fd-list--byline .fd-list__byline-left,::ng-deep .fd-list--byline .fd-list__byline-right{line-height:1.1rem!important}.fd-list__byline.smallSize{flex-direction:column;row-gap:5px}.fd-list__byline.smallSize div{width:100%}td{white-space:nowrap;padding:.5rem}fd-avatar ::ng-deep i{font-size:2.3rem!important}.status{display:flex;align-items:center;column-gap:3px;row-gap:3px}.status span.fd-object-status{font-size:var(--sapFontSize)!important;font-weight:700!important}.status span.fd-object-status ::ng-deep fd-icon{font-size:var(--sapFontSize);font-weight:700}\n"] }]
73
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.PictureFieldSourcePipe }], propDecorators: { documentItem: [{
74
+ type: Input
75
+ }], deviceSize: [{
76
+ type: Input
77
+ }], files: [{
78
+ type: Input
79
+ }], accepted: [{
80
+ type: Input
81
+ }], rejectedReason: [{
82
+ type: Input
83
+ }], readonly: [{
84
+ type: Input
85
+ }], status: [{
86
+ type: Input
87
+ }], uploadingState: [{
88
+ type: Input
89
+ }], statusChanged: [{
90
+ type: Output
91
+ }], rejectTextChange: [{
92
+ type: Output
93
+ }], fileSelectionChange: [{
94
+ type: Output
95
+ }], removeFile: [{
96
+ type: Output
97
+ }], fullscreen: [{
98
+ type: Output
99
+ }], download: [{
100
+ type: Output
101
+ }], downloadAll: [{
102
+ type: Output
103
+ }] } });
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-document-list-item.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/barsa-document-list-item/barsa-document-list-item.component.ts","../../../../../projects/barsa-develop-components/src/lib/barsa-document-list-item/barsa-document-list-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    Output,\r\n    SimpleChanges\r\n} from '@angular/core';\r\nimport {\r\n    AbbrevationDeviceSize,\r\n    AudioMimeType,\r\n    BaseComponent,\r\n    FileAttachmentInfo,\r\n    ImageMimeType,\r\n    PreventDefaulEvent,\r\n    VideoMimeType,\r\n    AllFilesMimeType,\r\n    PictureFieldSourcePipe,\r\n    isImage,\r\n    getIcon,\r\n    IUploadingState\r\n} from 'barsa-novin-ray-core';\r\nimport { DocumentItem } from '../models';\r\n\r\n@Component({\r\n    selector: 'bdc-barsa-document-list-item',\r\n    templateUrl: './barsa-document-list-item.component.html',\r\n    styleUrls: ['./barsa-document-list-item.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class BarsaDocumentListItemComponent extends BaseComponent implements OnChanges {\r\n    @Input() documentItem: DocumentItem;\r\n\r\n    @Input() deviceSize: AbbrevationDeviceSize;\r\n    @Input() files: FileAttachmentInfo[];\r\n    @Input() accepted: boolean;\r\n    @Input() rejectedReason: string;\r\n    @Input() readonly: boolean;\r\n    @Input() status: number;\r\n    @Input() uploadingState: IUploadingState;\r\n\r\n    @Output() statusChanged = new EventEmitter<{ value: number; rejectedText: string }>();\r\n    @Output() rejectTextChange = new EventEmitter<string>();\r\n    @Output() fileSelectionChange = new EventEmitter<File[]>();\r\n    @Output() removeFile = new EventEmitter<FileAttachmentInfo>();\r\n    @Output() fullscreen = new EventEmitter<null | FileAttachmentInfo>();\r\n    @Output() download = new EventEmitter<FileAttachmentInfo>();\r\n    @Output() downloadAll = new EventEmitter<void>();\r\n\r\n    hasFiles = false;\r\n    firstImageUrl: any;\r\n    constructor(private _cdr: ChangeDetectorRef, private _picFieldSrc: PictureFieldSourcePipe) {\r\n        super();\r\n    }\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        const documentItem = this.documentItem;\r\n        documentItem.$ValidExtensions = `            \r\n        ${documentItem.SupportImage ? ImageMimeType : ''},\r\n        ${documentItem.SupportAudio ? AudioMimeType : ''},\r\n        ${documentItem.SupportVideo ? VideoMimeType : ''},\r\n        ${documentItem.SupportFile ? AllFilesMimeType : ''}\r\n        `;\r\n    }\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        const { files } = changes;\r\n        files && Array.isArray(files.currentValue) && this._setFirstImage(files.currentValue);\r\n        this._detectChanges();\r\n    }\r\n    onReject(e: number): void {\r\n        this.statusChanged.emit({ value: e, rejectedText: e === 2 ? '' : this.rejectedReason });\r\n    }\r\n    onRejectedTextChange(e): void {\r\n        this.rejectTextChange.emit(e.target.value);\r\n    }\r\n    onPreventClick(e): void {\r\n        PreventDefaulEvent(e);\r\n    }\r\n    onFileSelection(files: File[]): void {\r\n        this.fileSelectionChange.emit(files);\r\n    }\r\n\r\n    protected _setFirstImage(files: FileAttachmentInfo[]): void {\r\n        files.length &&\r\n            (this.firstImageUrl = isImage(files[0].Type)\r\n                ? this._picFieldSrc.transform(files[0].Id, 'ID', null, '', 120, 120)\r\n                : getIcon(files[0].Type));\r\n    }\r\n    protected _detectChanges(): void {\r\n        this._cdr.detectChanges();\r\n    }\r\n}\r\n","<!-- <li fd-list-item style=\"padding: 0.5rem 1rem\">\r\n<span fd-list-thumbnail>\r\n  <fd-icon *ngIf=\"documentItem.FontIcon\" [glyph]=\"documentItem.FontIcon\"></fd-icon>\r\n  <fd-avatar\r\n    *ngIf=\"documentItem.Avatar\"\r\n    size=\"s\"\r\n    [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:''\"\r\n    [clickable]=\"true\"\r\n    ></fd-avatar\r\n  ></span>\r\n\r\n  <div fd-list-content>\r\n    <div fd-list-title>\r\n      <div style=\"display: flex; column-gap: 3px\">\r\n        <strong\r\n          >{{ documentItem.Title }}\r\n          <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\r\n            >*({{ 'اجباری' | bbbTranslate }})\r\n          </span>\r\n        </strong>\r\n        <div\r\n          *ngIf=\"documentItem.$Accepted === false || documentItem.$Accepted === true\"\r\n          style=\"display: flex; column-gap: 3px; flex-wrap: wrap; align-items: center\"\r\n          >\r\n          <span\r\n            fd-object-status\r\n            [status]=\"accepted ? 'positive' : 'negative'\"\r\n            [label]=\"accepted ? acceptedText : rejectedText\"\r\n            [clickable]=\"true\"\r\n            [inverted]=\"true\"\r\n            [aria-label]=\"accepted ? acceptedText : rejectedText\"\r\n          ></span>\r\n          <fd-popover title=\"Rejected document\" *ngIf=\"rejectedReason && !accepted\">\r\n            <fd-popover-control>\r\n              <span\r\n                fd-object-status\r\n                status=\"negative\"\r\n                glyph=\"question-mark\"\r\n                glyphAriaLabel=\"Negative\"\r\n                title=\"Rejected document\"\r\n              ></span>\r\n            </fd-popover-control>\r\n            <fd-popover-body>\r\n              <fd-message-strip type=\"error\" [dismissible]=\"false\">\r\n                {{ rejectedReason }}\r\n              </fd-message-strip>\r\n            </fd-popover-body>\r\n          </fd-popover>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div fd-list-byline [twoCol]=\"true\" [class.smallSize]=\"deviceSize === 's'\">\r\n      <div fd-list-byline-left>\r\n        <div style=\"display: flex; flex-direction: column; row-gap: 5px; flex-wrap: wrap\">\r\n          <span>\r\n            {{ documentItem.Description }}\r\n          </span>\r\n          <div style=\"display: flex; flex-wrap: wrap; column-gap: 3px; align-items: center\">\r\n            <ng-container *ngIf=\"hasFiles\">\r\n              <button fd-button [fdType]=\"'transparent'\" glyph=\"show\" (click)=\"onFullscreen()\"></button>\r\n              <ng-container *ngFor=\"let file of files\">\r\n                <fd-token\r\n                  [readOnly]=\"readonly\"\r\n                  *ngIf=\"!file.IsDeleted\"\r\n                  (onCloseClick)=\"onRemoveFile(file)\"\r\n                  >{{ file.FileName }}</fd-token\r\n                  >\r\n                </ng-container>\r\n              </ng-container>\r\n              <button\r\n                fd-button\r\n                *ngIf=\"documentItem.MaxFileCount && !readonly\"\r\n                glyph=\"attachment\"\r\n                [label]=\"'AttachFile' | bbbTranslate\"\r\n                (click)=\"!readonly && uploader.open()\"\r\n              ></button>\r\n              <fd-file-uploader\r\n                #uploader\r\n                [style.display]=\"'none'\"\r\n                fd-toolbar-item\r\n                [id]=\"documentItem.ItemKey\"\r\n                [name]=\"'pictures_' + documentItem.ItemKey\"\r\n                [accept]=\"documentItem.$ValidExtensions\"\r\n                [fileLimit]=\"documentItem.MaxFileCount\"\r\n                [multiple]=\"documentItem.MaxFileCount > 0\"\r\n                (selectedFilesChanged)=\"onFileSelection($event)\"\r\n              ></fd-file-uploader>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div fd-list-byline-right *ngIf=\"documentItem.CanAccept\">\r\n          <bdc-accept-reject\r\n            [rejectedReason]=\"rejectedReason\"\r\n            [positiveText]=\"acceptedText\"\r\n            [negativeText]=\"rejectedText\"\r\n            [deviceSize]=\"deviceSize\"\r\n            [readonly]=\"readonly\"\r\n          ></bdc-accept-reject>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </li> -->\r\n\r\n<tr fd-table-row>\r\n    <td fd-table-cell>\r\n        @if (documentItem.Avatar && !files.length) {\r\n        <fd-avatar\r\n            size=\"s\"\r\n            [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:'':64:64\"\r\n            [clickable]=\"true\"\r\n            [transparent]=\"true\"\r\n        ></fd-avatar>\r\n        } @else { @if (files.length) {\r\n        <fd-avatar [transparent]=\"true\" size=\"s\" [image]=\"firstImageUrl\" [clickable]=\"true\"></fd-avatar>\r\n        } @if (!files.length) {\r\n        <fd-avatar [transparent]=\"true\" size=\"s\" [glyph]=\"documentItem.FontIcon\" [clickable]=\"true\"></fd-avatar>\r\n        } }\r\n    </td>\r\n    <td fd-table-cell style=\"min-width: 140px\">\r\n        <p fd-table-text>\r\n            <strong\r\n                >{{ documentItem.Title }}\r\n                @if (documentItem.IsRequired) {\r\n                <span fd-object-status status=\"negative\">*({{ 'اجباری' | bbbTranslate }}) </span>\r\n                }\r\n            </strong>\r\n        </p>\r\n        <div>\r\n            <span>\r\n                {{ documentItem.Description }}\r\n            </span>\r\n        </div>\r\n    </td>\r\n\r\n    <td fd-table-cell>\r\n        <ng-container>\r\n            <!-- <ul fd-list>\r\n        <li fd-list-item *ngFor=\"let file of files; let ind = index\">\r\n          <span fd-list-title>\r\n            {{ file.FileName }}\r\n          </span>\r\n          <span fd-list-secondary>\r\n            <button ariaLabel=\"Remove\" title=\"Remove\" fd-button glyph=\"delete\" ></button>\r\n          </span>\r\n        </li>\r\n      </ul> -->\r\n            <div style=\"display: flex; align-items: flex-start; column-gap: 3px; row-gap: 3px; flex-direction: column\">\r\n                @for (file of files; track file) {\r\n                <!-- <span><fd-icon glyph=\"attachment\"></fd-icon><a fd-link>{{file.FileName}}</a></span> -->\r\n                @if (!file.IsDeleted) {\r\n                <bsu-file-viewer-popover\r\n                    [file]=\"file\"\r\n                    [deviceSize]=\"deviceSize\"\r\n                    [canDownload]=\"true\"\r\n                    (remove)=\"removeFile.emit(file)\"\r\n                ></bsu-file-viewer-popover>\r\n                } }\r\n                <!-- <button\r\n        fd-button\r\n        *ngIf=\"+documentItem.MaxFileCount && !readonly\"\r\n        glyph=\"add\"\r\n        (click)=\"!readonly && uploader.open()\"\r\n      ></button> -->\r\n            </div>\r\n            <!-- <p *ngFor=\"let file of files\" fd-table-text>\r\n    <fd-action-sheet  >\r\n      <fd-action-sheet-control>\r\n        <button\r\n          fd-button\r\n          glyph=\"settings\"\r\n          title=\"Open Action Sheet Mobile\"\r\n          id=\"fd-action-sheet-mobile-control\"\r\n          aria-haspopup=\"menu\"\r\n          [label]=\"file.FileName ||''\"\r\n          aria-controls=\"fd-action-sheet-mobile-body\"\r\n        ></button>\r\n      </fd-action-sheet-control>\r\n\r\n      <fd-action-sheet-body\r\n        actionSheetBodyId=\"fd-action-sheet-mobile-body\"\r\n        ariaLabelledBy=\"fd-action-sheet-mobile-control\"\r\n        >\r\n        <li fd-action-sheet-item label=\"Search\" glyph=\"search\"></li>\r\n        <li fd-action-sheet-item label=\"Download\" glyph=\"download\" ></li>\r\n        <li fd-action-sheet-item label=\"Accept\" glyph=\"accept\" ></li>\r\n        <li fd-action-sheet-item label=\"Reject\" glyph=\"cancel\" ></li>\r\n        <li fd-action-sheet-item label=\"Decide Later\" [isCloseButton]=\"true\"></li>\r\n        <li fd-action-sheet-item label=\"Cancel\" [negative]=\"true\" [isCloseButton]=\"true\"></li>\r\n      </fd-action-sheet-body>\r\n    </fd-action-sheet>\r\n  </p> -->\r\n        </ng-container>\r\n    </td>\r\n    <td fd-table-cell>\r\n        <div class=\"status\" style=\"position: relative\">\r\n            @if (+documentItem.MaxFileCount && !readonly) {\r\n            <button\r\n                fd-button\r\n                glyph=\"attachment\"\r\n                [label]=\"'AttachFile' | bbbTranslate\"\r\n                [disabled]=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\r\n                (click)=\"!readonly && uploader.open()\"\r\n            >\r\n                @if (uploadingState?.key === documentItem.Title && uploadingState?.uploading) {\r\n                <bsu-mask [marginTop]=\"'3px'\"></bsu-mask>\r\n                }\r\n            </button>\r\n            }\r\n            <button\r\n                fd-button\r\n                glyph=\"show\"\r\n                fullscreenFiles\r\n                [files]=\"files\"\r\n                [title]=\"documentItem.Title\"\r\n                [fd-inline-help]=\"'مشاهده همه' | bbbTranslate\"\r\n                [aria-describedby]=\"'مشاهده همه' | bbbTranslate\"\r\n                [ariaLabel]=\"'مشاهده همه' | bbbTranslate\"\r\n                fullscreenFiles\r\n                [disabled]=\"!files.length\"\r\n                [files]=\"files\"\r\n            ></button>\r\n            <button\r\n                fd-button\r\n                glyph=\"download\"\r\n                [fd-inline-help]=\"'دانلود همه' | bbbTranslate\"\r\n                [aria-describedby]=\"'دانلود همه' | bbbTranslate\"\r\n                [ariaLabel]=\"'دانلود همه' | bbbTranslate\"\r\n                downloadFiles\r\n                [disabled]=\"!files.length\"\r\n                [files]=\"files\"\r\n                (click)=\"downloadAll.emit()\"\r\n            ></button>\r\n        </div>\r\n    </td>\r\n    <td fd-table-cell>\r\n        <fd-action-sheet #actionSheet>\r\n            <fd-action-sheet-control>\r\n                <ng-container *ngTemplateOutlet=\"statusTpl\"></ng-container>\r\n            </fd-action-sheet-control>\r\n            <fd-action-sheet-body>\r\n                <li\r\n                    fd-action-sheet-item\r\n                    [label]=\"'Accept' | bbbTranslate\"\r\n                    glyph=\"accept\"\r\n                    (click)=\"actionSheet.close(); onReject(2)\"\r\n                ></li>\r\n                <li\r\n                    fd-action-sheet-item\r\n                    [label]=\"'Reject' | bbbTranslate\"\r\n                    glyph=\"cancel\"\r\n                    (click)=\"actionSheet.close(); onReject(3)\"\r\n                ></li>\r\n            </fd-action-sheet-body>\r\n        </fd-action-sheet>\r\n\r\n        @if (status === 3) {\r\n        <p fd-table-text maxWidth=\"400px\">\r\n            @if (readonly && rejectedReason) {\r\n            <span> {{ rejectedReason | bbbTranslate }} </span>\r\n            } @if (!readonly) {\r\n            <input\r\n                fd-form-control\r\n                [value]=\"rejectedReason | bbbTranslate\"\r\n                [placeholder]=\"'دلایل رد مدرک' | bbbTranslate\"\r\n            />\r\n            }\r\n        </p>\r\n        }\r\n    </td>\r\n</tr>\r\n\r\n<fd-file-uploader\r\n    #uploader\r\n    [style.display]=\"'none'\"\r\n    fd-toolbar-item\r\n    [id]=\"documentItem.ItemKey\"\r\n    [name]=\"'pictures_' + documentItem.ItemKey\"\r\n    [accept]=\"documentItem.$ValidExtensions\"\r\n    [fileLimit]=\"documentItem.MaxFileCount\"\r\n    [multiple]=\"documentItem.MaxFileCount > 0\"\r\n    (selectedFilesChanged)=\"onFileSelection($event)\"\r\n></fd-file-uploader>\r\n<ng-template #statusTpl>\r\n    <div class=\"status\">\r\n        <button fd-button fdType=\"transparent\">\r\n            @if (status === 1) {\r\n            <span\r\n                fd-object-status\r\n                [label]=\"'[پیوست مدارک]' | bbbTranslate\"\r\n                [aria-label]=\"'[پیوست مدارک]' | bbbTranslate\"\r\n            ></span>\r\n            } @if (status === 2) {\r\n            <span\r\n                fd-object-status\r\n                glyph=\"message-success\"\r\n                status=\"positive\"\r\n                [label]=\"'Accepted' | bbbTranslate\"\r\n                [label]=\"'Accepted' | bbbTranslate\"\r\n            ></span>\r\n            } @if (status === 3) {\r\n            <span\r\n                fd-object-status\r\n                glyph=\"cancel\"\r\n                status=\"negative\"\r\n                [label]=\"'Rejected' | bbbTranslate\"\r\n                [aria-label]=\"'Rejected' | bbbTranslate\"\r\n            ></span>\r\n            }\r\n        </button>\r\n    </div>\r\n</ng-template>\r\n"]}