tnx-shared 5.2.24 → 5.2.25

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 (102) hide show
  1. package/classes/public-function.d.ts +70 -17
  2. package/classes/public-function.d.ts.map +1 -1
  3. package/esm2020/classes/public-function.mjs +2 -72
  4. package/esm2020/components/add-news/add-news.component.mjs +3 -3
  5. package/esm2020/components/autocomplete-datasource/autocomplete-datasource.component.mjs +1 -1
  6. package/esm2020/components/autocomplete-picker/autocomplete-picker.component.mjs +1 -1
  7. package/esm2020/components/avatar-uploader/avatar-uploader.component.mjs +1 -1
  8. package/esm2020/components/chat/chat-box/chat-box.component.mjs +1 -1
  9. package/esm2020/components/chat/chat-send-message-box/chat-send-message-box.component.mjs +1 -1
  10. package/esm2020/components/check-box-list/check-box-list.component.mjs +1 -1
  11. package/esm2020/components/cocautochuc/cocautochuc-picker/cocautochuc-picker.component.mjs +1 -1
  12. package/esm2020/components/common-app-component/app-topbar-v1/app-topbar-v1.component.mjs +1 -1
  13. package/esm2020/components/common-app-component/app-topbar-v2/app-topbar-v2.component.mjs +1 -1
  14. package/esm2020/components/common-app-component/app.menu.component.mjs +2 -2
  15. package/esm2020/components/common-app-component/app.topbar.component.mjs +1 -1
  16. package/esm2020/components/common-app-component/common-app-component.mjs +1 -1
  17. package/esm2020/components/common-app-component/default-setting-form/default-data-settings.component.mjs +1 -1
  18. package/esm2020/components/crud/advance-search/advance-search.component.mjs +1 -1
  19. package/esm2020/components/crud/crud-form/crud-form.component.mjs +1 -1
  20. package/esm2020/components/crud/crud-list/crud-list.component.mjs +1 -1
  21. package/esm2020/components/crud/table-detail-form/table-detail-form.component.mjs +1 -1
  22. package/esm2020/components/crud/tree-table/tree-table.component.mjs +1 -1
  23. package/esm2020/components/datetime-picker/datetime-picker.component.mjs +1 -1
  24. package/esm2020/components/dropdown/dropdown-setting-form/dropdown-setting-form.component.mjs +1 -1
  25. package/esm2020/components/dropdown/dropdown.component.mjs +4 -4
  26. package/esm2020/components/dropdown/quick-add-form/quick-add-form.component.mjs +1 -1
  27. package/esm2020/components/entity-permission/entity-permission.component.mjs +1 -1
  28. package/esm2020/components/entity-picker/entity-picker-dialog/components/entity-picker-data/entity-picker-data.component.mjs +1 -1
  29. package/esm2020/components/entity-picker/entity-picker-dialog/components/entity-picker-selected/entity-picker-selected.component.mjs +1 -1
  30. package/esm2020/components/entity-picker/entity-picker-dialog/components/entity-picker-tree-data/entity-picker-tree-data.component.mjs +1 -1
  31. package/esm2020/components/entity-picker/entity-picker-dialog/components/entity-picker-tree-selected/entity-picker-tree-selected.component.mjs +1 -1
  32. package/esm2020/components/entity-picker/entity-picker-dialog/entity-picker-dialog.component.mjs +1 -1
  33. package/esm2020/components/entity-picker/entity-picker.component.mjs +1 -1
  34. package/esm2020/components/file-explorer/file-explorer.component.mjs +1 -1
  35. package/esm2020/components/file-explorer/file-form/file-form.component.mjs +1 -1
  36. package/esm2020/components/file-explorer/file-ky-so-sim/file-ky-so-sim.component.mjs +1 -1
  37. package/esm2020/components/file-explorer/file-manager/file-manager.component.mjs +1 -1
  38. package/esm2020/components/file-explorer/file-picker-dialog/file-picker-dialog.component.mjs +1 -1
  39. package/esm2020/components/file-explorer/file-tai-lieu/file-tai-lieu.component.mjs +1 -1
  40. package/esm2020/components/file-explorer/file-version-list/file-version-list.component.mjs +1 -1
  41. package/esm2020/components/file-explorer/file-viewer/file-viewer.component.mjs +1 -1
  42. package/esm2020/components/file-explorer/folder-form/folder-form.component.mjs +1 -1
  43. package/esm2020/components/file-explorer/ky-so-sim-danh-sach-chu-ky/ky-so-sim-danh-sach-chu-ky.component.mjs +1 -1
  44. package/esm2020/components/file-explorer/signature-detail/signature-detail.component.mjs +1 -1
  45. package/esm2020/components/file-upload/file-upload.component.mjs +1 -1
  46. package/esm2020/components/image-uploader/image-uploader.component.mjs +1 -1
  47. package/esm2020/components/paging-next-back-only/paging-next-back-only.component.mjs +1 -1
  48. package/esm2020/components/permission-utils/permission-utils.component.mjs +1 -1
  49. package/esm2020/components/qr-code-generator/qr-code-generator.component.mjs +1 -1
  50. package/esm2020/components/query-builders/query-builder/query-builder.component.mjs +1 -1
  51. package/esm2020/components/query-builders/query-builder-group/query-builder-group.component.mjs +2 -2
  52. package/esm2020/components/query-builders/query-builder-rule/query-builder-rule.component.mjs +3 -3
  53. package/esm2020/components/radio-button-list/radio-button-list.component.mjs +1 -1
  54. package/esm2020/components/report-queue/report-queue.component.mjs +1 -1
  55. package/esm2020/components/service-file-upload/service-file-upload.component.mjs +1 -1
  56. package/esm2020/components/settings/settings-row/settings-row.component.mjs +1 -1
  57. package/esm2020/components/settings/settings-workflow/settings-workflow.component.mjs +1 -1
  58. package/esm2020/components/settings/settings.component.mjs +1 -1
  59. package/esm2020/components/share-link-by-permission/share-link-by-permission.component.mjs +1 -1
  60. package/esm2020/components/statemachines/state/state.component.mjs +1 -1
  61. package/esm2020/components/statemachines/state-metadata/state-metadata.component.mjs +1 -1
  62. package/esm2020/components/statemachines/statemachines-connection-metadata/statemachines-connection-metadata.component.mjs +1 -1
  63. package/esm2020/components/statemachines/statemachines-designer/statemachines-designer.component.mjs +1 -1
  64. package/esm2020/components/tn-app-help/helper-current-page/helper-current-page.component.mjs +1 -1
  65. package/esm2020/components/tn-app-help/tn-app-help.component.mjs +1 -1
  66. package/esm2020/components/tn-app-notification/tn-app-notification.component.mjs +1 -1
  67. package/esm2020/components/tn-checkbox/tn-checkbox.component.mjs +1 -1
  68. package/esm2020/components/tn-color-picker/tn-color-picker.component.mjs +1 -1
  69. package/esm2020/components/tn-dialog/tn-dialog.component.mjs +1 -1
  70. package/esm2020/components/tn-tabview/tn-tabview.component.mjs +1 -1
  71. package/esm2020/components/tn-template/tn-template.component.mjs +1 -1
  72. package/esm2020/components/tn-tinymce/tn-tinymce.component.mjs +1 -1
  73. package/esm2020/components/tn-tree/tn-tree.component.mjs +1 -1
  74. package/esm2020/components/user-picker/user-picker-box/user-picker-box.component.mjs +1 -1
  75. package/esm2020/components/user-picker/user-picker.component.mjs +1 -1
  76. package/esm2020/components/usmart/chuoi-phan-tiet/chuoi-phan-tiet.component.mjs +1 -1
  77. package/esm2020/components/vanban-picker/vanban-den-picker/vanban-den-picker.component.mjs +2 -2
  78. package/esm2020/components/vanban-picker/vanban-di-picker/vanban-di-picker.component.mjs +2 -2
  79. package/esm2020/components/vanban-picker/vanban-picker-dialog/vanban-picker-dialog.component.mjs +1 -1
  80. package/esm2020/components/vanban-picker/vanban-picker.component.mjs +1 -1
  81. package/esm2020/components/workflow/cho-y-kien-form/cho-y-kien-form.component.mjs +1 -1
  82. package/esm2020/components/workflow/permission-sharing/permission-sharing.component.mjs +1 -1
  83. package/esm2020/components/workflow/process-workflow-form/process-workflow-form.component.mjs +1 -1
  84. package/esm2020/components/workflow/start-workflow/start-workflow.component.mjs +1 -1
  85. package/esm2020/components/workflow/workflow-history-new/workflow-history-new.component.mjs +1 -1
  86. package/esm2020/components/workflow/workflow-permission-form/workflow-permission-form.component.mjs +1 -1
  87. package/esm2020/components/workflow/workflow-picker/workflow-picker.component.mjs +1 -1
  88. package/esm2020/components/workflow/workflow-setting-new/workflow-setting-new.component.mjs +1 -1
  89. package/esm2020/congviec/congviec/congviec-dinhkem/congviec-dinhkem.component.mjs +1 -1
  90. package/esm2020/congviec/congviec/congviec-form/congviec-form.component.mjs +1 -1
  91. package/esm2020/congviec/congviec/congviec.component.mjs +2 -2
  92. package/esm2020/congviec/dm-linhvuc-congviec/dm-linhvuc-congviec-form/dm-linhvuc-congviec-form.component.mjs +1 -1
  93. package/esm2020/congviec/dm-loai-congviec/dm-loai-congviec-form/dm-loai-congviec-form.component.mjs +1 -1
  94. package/esm2020/congviec/dm-priority/dm-priority-form/dm-priority-form.component.mjs +1 -1
  95. package/esm2020/tnx-shared.module.mjs +1 -1
  96. package/fesm2015/tnx-shared.mjs +104 -171
  97. package/fesm2015/tnx-shared.mjs.map +1 -1
  98. package/fesm2020/tnx-shared.mjs +104 -171
  99. package/fesm2020/tnx-shared.mjs.map +1 -1
  100. package/package.json +3 -3
  101. package/tnx-shared.module.d.ts +2 -1
  102. package/tnx-shared.module.d.ts.map +1 -1
@@ -1,25 +1,78 @@
1
+ import { DatePipe, DecimalPipe } from '@angular/common';
1
2
  import { HttpClient } from '@angular/common/http';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { BrowserModule } from '@angular/platform-browser';
5
+ import { TranslateService } from '@ngx-translate/core';
6
+ import { OAuthModule } from 'angular-oauth2-oidc';
7
+ import { ConfirmationService, MessageService } from 'tn-custom-primeng/api';
8
+ import { AccessDeniedComponent } from '../components/access-denied-component/access-denied.component';
9
+ import { CommonDashboardComponent } from '../components/common-dashboard/common-dashboard.component';
10
+ import { EntityPermissionService } from '../components/entity-permission/services.cs/entity-permission.service';
11
+ import { NotFoundComponent } from '../components/not-found/not-found.component';
12
+ import { SplashComponentComponent } from '../components/splash-component/splash-component.component';
13
+ import { UniversalLinkProcessorComponent } from '../components/universal-link-processor/universal-link-processor.component';
14
+ import { EntityWorkflowHistoryService } from '../components/workflow/services/entity-workflow-history.service';
15
+ import { EntityWorkflowSettingService } from '../components/workflow/services/entity-workflow-setting.service';
16
+ import { LogInterceptor } from '../intercepters/log.interceptor';
17
+ import { PermissionUtilsInterceptor } from '../intercepters/permission-utils.interceptor';
18
+ import { SendAccessTokenInterceptor } from '../intercepters/send-access-token.interceptor';
19
+ import { TraceInterceptor } from '../intercepters/trace.interceptor';
20
+ import { HtmlFormatPipe } from '../pipes/html-format.pipe';
21
+ import { MasterDataPipe } from '../pipes/masterData.pipe';
22
+ import { OrganizationFormatPipe } from '../pipes/organization-format.pipe';
23
+ import { OrganizationsFormatPipe } from '../pipes/organizations-format.pipe';
24
+ import { SafeHtmlPipe } from '../pipes/safe-html.pipe';
25
+ import { UserFormatPipe } from '../pipes/user-format.pipe';
26
+ import { UsersFormatPipe } from '../pipes/users-format.pipe';
27
+ import { NotifierService } from '../services/notifier.service';
2
28
  import { MultiTranslateHttpLoader } from './multi-translate-http-loader';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/platform-browser";
5
- import * as i2 from "@angular/forms";
6
- import * as i3 from "@angular/common/http";
7
- import * as i4 from "@angular/platform-browser/animations";
8
- import * as i5 from "@ngx-translate/core";
9
- import * as i6 from "ngx-mask";
10
- import * as i7 from "ngx-img-fallback";
11
29
  export declare class PublicFunction {
12
30
  static initRoute(routes: any[]): any[];
13
- static commonRoutes(): any[];
14
- static defaultRoutes(): any[];
31
+ static commonRoutes(): ({
32
+ path: string;
33
+ component: typeof SplashComponentComponent;
34
+ } | {
35
+ path: string;
36
+ component: typeof CommonDashboardComponent;
37
+ } | {
38
+ path: string;
39
+ component: typeof AccessDeniedComponent;
40
+ } | {
41
+ path: string;
42
+ component: typeof UniversalLinkProcessorComponent;
43
+ })[];
44
+ static defaultRoutes(): {
45
+ path: string;
46
+ component: typeof NotFoundComponent;
47
+ }[];
15
48
  static createTranslateLoader(http: HttpClient): MultiTranslateHttpLoader;
16
49
  static registerLocaleData(locale?: any, language?: any): void;
17
- static importRootModule(environment: any): any[];
18
- static useRootProvider(enviromment: any): any[];
19
- }
20
- export declare class CommonPublicModule {
21
- static ɵfac: i0.ɵɵFactoryDeclaration<CommonPublicModule, never>;
22
- static ɵmod: i0.ɵɵNgModuleDeclaration<CommonPublicModule, never, [typeof i1.BrowserModule, typeof i2.FormsModule, typeof i3.HttpClientModule, typeof i4.BrowserAnimationsModule, typeof i2.ReactiveFormsModule, typeof i5.TranslateModule, typeof i6.NgxMaskModule, typeof i7.ImgFallbackModule], [typeof i1.BrowserModule, typeof i2.FormsModule, typeof i3.HttpClientModule, typeof i4.BrowserAnimationsModule, typeof i2.ReactiveFormsModule, typeof i5.TranslateModule, typeof i6.NgxMaskModule, typeof i7.ImgFallbackModule]>;
23
- static ɵinj: i0.ɵɵInjectorDeclaration<CommonPublicModule>;
50
+ static importRootModule(environment: any): (typeof FormsModule | typeof BrowserModule | import("@angular/core").ModuleWithProviders<OAuthModule>)[];
51
+ static useRootProvider(enviromment: any): (typeof DecimalPipe | typeof DatePipe | typeof ConfirmationService | typeof MessageService | typeof TranslateService | typeof NotifierService | typeof EntityPermissionService | typeof EntityWorkflowHistoryService | typeof EntityWorkflowSettingService | typeof HtmlFormatPipe | typeof MasterDataPipe | typeof OrganizationFormatPipe | typeof OrganizationsFormatPipe | typeof SafeHtmlPipe | typeof UserFormatPipe | typeof UsersFormatPipe | {
52
+ provide: import("@angular/core").InjectionToken<string>;
53
+ useValue: string;
54
+ useClass?: undefined;
55
+ multi?: undefined;
56
+ } | {
57
+ provide: import("@angular/core").InjectionToken<import("@angular/common/http").HttpInterceptor[]>;
58
+ useClass: typeof SendAccessTokenInterceptor;
59
+ multi: boolean;
60
+ useValue?: undefined;
61
+ } | {
62
+ provide: import("@angular/core").InjectionToken<import("@angular/common/http").HttpInterceptor[]>;
63
+ useClass: typeof LogInterceptor;
64
+ multi: boolean;
65
+ useValue?: undefined;
66
+ } | {
67
+ provide: import("@angular/core").InjectionToken<import("@angular/common/http").HttpInterceptor[]>;
68
+ useClass: typeof PermissionUtilsInterceptor;
69
+ multi: boolean;
70
+ useValue?: undefined;
71
+ } | {
72
+ provide: import("@angular/core").InjectionToken<import("@angular/common/http").HttpInterceptor[]>;
73
+ useClass: typeof TraceInterceptor;
74
+ multi: boolean;
75
+ useValue?: undefined;
76
+ })[];
24
77
  }
25
78
  //# sourceMappingURL=public-function.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"public-function.d.ts","sourceRoot":"","sources":["../../../projects/shared/src/lib/classes/public-function.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAuC,MAAM,sBAAsB,CAAC;AAiCvF,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;;;;;;;;;AAEzE,qBAAa,cAAc;IAEvB,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,GAAG,EAAE,GAAG,GAAG,EAAE;IAQtC,MAAM,CAAC,YAAY,IAAI,GAAG,EAAE;IAqB5B,MAAM,CAAC,aAAa,IAAI,GAAG,EAAE;IAM7B,MAAM,CAAC,qBAAqB,CAAC,IAAI,EAAE,UAAU;IAS7C,MAAM,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAA,EAAE,QAAQ,CAAC,KAAA;IAW5C,MAAM,CAAC,gBAAgB,CAAC,WAAW,KAAA,GAAG,GAAG,EAAE;IAyB3C,MAAM,CAAC,eAAe,CAAC,WAAW,KAAA,GAAG,GAAG,EAAE;CAyC7C;AAED,qBA4Ba,kBAAkB;yCAAlB,kBAAkB;0CAAlB,kBAAkB;0CAAlB,kBAAkB;CAAI"}
1
+ {"version":3,"file":"public-function.d.ts","sourceRoot":"","sources":["../../../projects/shared/src/lib/classes/public-function.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAsB,MAAM,iBAAiB,CAAC;AAC5E,OAAO,EAAE,UAAU,EAAuC,MAAM,sBAAsB,CAAC;AAGvF,OAAO,EAAE,WAAW,EAAuB,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAE1D,OAAO,EAAoC,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACzF,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlD,OAAO,EAAE,mBAAmB,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,+DAA+D,CAAC;AACtG,OAAO,EAAE,wBAAwB,EAAE,MAAM,2DAA2D,CAAC;AACrG,OAAO,EAAE,uBAAuB,EAAE,MAAM,uEAAuE,CAAC;AAChH,OAAO,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AAChF,OAAO,EAAE,wBAAwB,EAAE,MAAM,2DAA2D,CAAC;AACrG,OAAO,EAAE,+BAA+B,EAAE,MAAM,2EAA2E,CAAC;AAC5H,OAAO,EAAE,4BAA4B,EAAE,MAAM,iEAAiE,CAAC;AAC/G,OAAO,EAAE,4BAA4B,EAAE,MAAM,iEAAiE,CAAC;AAC/G,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,0BAA0B,EAAE,MAAM,8CAA8C,CAAC;AAC1F,OAAO,EAAE,0BAA0B,EAAE,MAAM,+CAA+C,CAAC;AAC3F,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,mCAAmC,CAAC;AAC3E,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAG/D,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAGzE,qBAAa,cAAc;IAEvB,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,GAAG,EAAE;IAQ9B,MAAM,CAAC,YAAY;;;;;;;;;;;;;IAqBnB,MAAM,CAAC,aAAa;;;;IAMpB,MAAM,CAAC,qBAAqB,CAAC,IAAI,EAAE,UAAU;IAS7C,MAAM,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAA,EAAE,QAAQ,CAAC,KAAA;IAW5C,MAAM,CAAC,gBAAgB,CAAC,WAAW,KAAA;IAyBnC,MAAM,CAAC,eAAe,CAAC,WAAW,KAAA;;;;;;;;;;;;;;;;;;;;;;;;;;CA2CrC"}
@@ -1,7 +1,7 @@
1
1
  import { DatePipe, DecimalPipe, registerLocaleData } from '@angular/common';
2
2
  import { HttpClient, HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
3
3
  import localeVi from '@angular/common/locales/vi';
4
- import { LOCALE_ID, NgModule } from '@angular/core';
4
+ import { LOCALE_ID } from '@angular/core';
5
5
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
6
6
  import { BrowserModule } from '@angular/platform-browser';
7
7
  import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
@@ -33,9 +33,6 @@ import { NotifierService } from '../services/notifier.service';
33
33
  // TODO: Upgrade sau
34
34
  // import { BrowserFavicons, BROWSER_FAVICONS_CONFIG, Favicons } from './favicon';
35
35
  import { MultiTranslateHttpLoader } from './multi-translate-http-loader';
36
- import * as i0 from "@angular/core";
37
- import * as i1 from "@ngx-translate/core";
38
- import * as i2 from "ngx-mask";
39
36
  export class PublicFunction {
40
37
  static initRoute(routes) {
41
38
  return [
@@ -150,71 +147,4 @@ export class PublicFunction {
150
147
  ];
151
148
  }
152
149
  }
153
- export class CommonPublicModule {
154
- }
155
- CommonPublicModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: CommonPublicModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
156
- CommonPublicModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.0", ngImport: i0, type: CommonPublicModule, imports: [BrowserModule,
157
- FormsModule,
158
- HttpClientModule,
159
- BrowserAnimationsModule,
160
- ReactiveFormsModule, i1.TranslateModule, i2.NgxMaskModule, ImgFallbackModule], exports: [BrowserModule,
161
- FormsModule,
162
- HttpClientModule,
163
- BrowserAnimationsModule,
164
- ReactiveFormsModule,
165
- TranslateModule,
166
- NgxMaskModule,
167
- ImgFallbackModule] });
168
- CommonPublicModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: CommonPublicModule, imports: [BrowserModule,
169
- FormsModule,
170
- HttpClientModule,
171
- BrowserAnimationsModule,
172
- ReactiveFormsModule,
173
- TranslateModule.forRoot({
174
- loader: {
175
- provide: TranslateLoader,
176
- useFactory: PublicFunction.createTranslateLoader,
177
- deps: [HttpClient],
178
- },
179
- }),
180
- NgxMaskModule.forRoot(),
181
- ImgFallbackModule, BrowserModule,
182
- FormsModule,
183
- HttpClientModule,
184
- BrowserAnimationsModule,
185
- ReactiveFormsModule,
186
- TranslateModule,
187
- NgxMaskModule,
188
- ImgFallbackModule] });
189
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: CommonPublicModule, decorators: [{
190
- type: NgModule,
191
- args: [{
192
- imports: [
193
- BrowserModule,
194
- FormsModule,
195
- HttpClientModule,
196
- BrowserAnimationsModule,
197
- ReactiveFormsModule,
198
- TranslateModule.forRoot({
199
- loader: {
200
- provide: TranslateLoader,
201
- useFactory: PublicFunction.createTranslateLoader,
202
- deps: [HttpClient],
203
- },
204
- }),
205
- NgxMaskModule.forRoot(),
206
- ImgFallbackModule,
207
- ],
208
- exports: [
209
- BrowserModule,
210
- FormsModule,
211
- HttpClientModule,
212
- BrowserAnimationsModule,
213
- ReactiveFormsModule,
214
- TranslateModule,
215
- NgxMaskModule,
216
- ImgFallbackModule,
217
- ]
218
- }]
219
- }] });
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-function.js","sourceRoot":"","sources":["../../../../projects/shared/src/lib/classes/public-function.ts"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe, registerLocaleData } from '@angular/common';\r\nimport { HttpClient, HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';\r\nimport localeVi from '@angular/common/locales/vi';\r\nimport { LOCALE_ID, NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { BrowserModule } from '@angular/platform-browser';\r\nimport { BrowserAnimationsModule } from '@angular/platform-browser/animations';\r\nimport { TranslateLoader, TranslateModule, TranslateService } from '@ngx-translate/core';\r\nimport { OAuthModule } from 'angular-oauth2-oidc';\r\nimport { ImgFallbackModule } from 'ngx-img-fallback';\r\nimport { NgxMaskModule } from 'ngx-mask';\r\nimport { ConfirmationService, MessageService } from 'tn-custom-primeng/api';\r\nimport { AccessDeniedComponent } from '../components/access-denied-component/access-denied.component';\r\nimport { CommonDashboardComponent } from '../components/common-dashboard/common-dashboard.component';\r\nimport { EntityPermissionService } from '../components/entity-permission/services.cs/entity-permission.service';\r\nimport { NotFoundComponent } from '../components/not-found/not-found.component';\r\nimport { SplashComponentComponent } from '../components/splash-component/splash-component.component';\r\nimport { UniversalLinkProcessorComponent } from '../components/universal-link-processor/universal-link-processor.component';\r\nimport { EntityWorkflowHistoryService } from '../components/workflow/services/entity-workflow-history.service';\r\nimport { EntityWorkflowSettingService } from '../components/workflow/services/entity-workflow-setting.service';\r\nimport { LogInterceptor } from '../intercepters/log.interceptor';\r\nimport { PermissionUtilsInterceptor } from '../intercepters/permission-utils.interceptor';\r\nimport { SendAccessTokenInterceptor } from '../intercepters/send-access-token.interceptor';\r\nimport { TraceInterceptor } from '../intercepters/trace.interceptor';\r\nimport { HtmlFormatPipe } from '../pipes/html-format.pipe';\r\nimport { MasterDataPipe } from '../pipes/masterData.pipe';\r\nimport { OrganizationFormatPipe } from '../pipes/organization-format.pipe';\r\nimport { OrganizationsFormatPipe } from '../pipes/organizations-format.pipe';\r\nimport { SafeHtmlPipe } from '../pipes/safe-html.pipe';\r\nimport { UserFormatPipe } from '../pipes/user-format.pipe';\r\nimport { UsersFormatPipe } from '../pipes/users-format.pipe';\r\nimport { NotifierService } from '../services/notifier.service';\r\n// TODO: Upgrade sau\r\n// import { BrowserFavicons, BROWSER_FAVICONS_CONFIG, Favicons } from './favicon';\r\nimport { MultiTranslateHttpLoader } from './multi-translate-http-loader';\r\n\r\nexport class PublicFunction {\r\n\r\n    static initRoute(routes: any[]): any[] {\r\n        return [\r\n            ...PublicFunction.commonRoutes(),\r\n            ...routes,\r\n            ...PublicFunction.defaultRoutes(),\r\n        ];\r\n    }\r\n\r\n    static commonRoutes(): any[] {\r\n        return [\r\n            {\r\n                path: '',\r\n                component: SplashComponentComponent,\r\n            },\r\n            {\r\n                path: 'dashboard',\r\n                component: CommonDashboardComponent,\r\n            },\r\n            {\r\n                path: 'access-denied',\r\n                component: AccessDeniedComponent,\r\n            },\r\n            {\r\n                path: 'universal-link',\r\n                component: UniversalLinkProcessorComponent,\r\n            },\r\n        ];\r\n    }\r\n\r\n    static defaultRoutes(): any[] {\r\n        return [\r\n            { path: '**', component: NotFoundComponent },\r\n        ];\r\n    }\r\n\r\n    static createTranslateLoader(http: HttpClient) {\r\n        return new MultiTranslateHttpLoader(http,\r\n            [\r\n                { prefix: 'assets/i18n/', suffix: '.json' },\r\n                { prefix: 'assets/i18n/shared/', suffix: '.json' },\r\n            ],\r\n        );\r\n    }\r\n\r\n    static registerLocaleData(locale?, language?) {\r\n        if (!locale) {\r\n            locale = localeVi;\r\n        }\r\n        if (!language) {\r\n            language = 'vi';\r\n        }\r\n\r\n        registerLocaleData(locale, language);\r\n    }\r\n\r\n    static importRootModule(environment): any[] {\r\n        return [\r\n            BrowserModule,\r\n            FormsModule,\r\n            HttpClientModule,\r\n            BrowserAnimationsModule,\r\n            ReactiveFormsModule,\r\n            TranslateModule.forRoot({\r\n                loader: {\r\n                    provide: TranslateLoader,\r\n                    useFactory: PublicFunction.createTranslateLoader,\r\n                    deps: [HttpClient],\r\n                },\r\n            }),\r\n            NgxMaskModule.forRoot(),\r\n            OAuthModule.forRoot({\r\n                resourceServer: {\r\n                    allowedUrls: [environment.appMetadata.appGateway],\r\n                    sendAccessToken: false,\r\n                },\r\n            }),\r\n            ImgFallbackModule,\r\n        ];\r\n    }\r\n\r\n    static useRootProvider(enviromment): any[] {\r\n        return [\r\n            { provide: LOCALE_ID, useValue: 'vi-VN' },\r\n            {\r\n                provide: HTTP_INTERCEPTORS,\r\n                useClass: SendAccessTokenInterceptor,\r\n                multi: true,\r\n            },\r\n            {\r\n                provide: HTTP_INTERCEPTORS,\r\n                useClass: LogInterceptor,\r\n                multi: true,\r\n            },\r\n            {\r\n                provide: HTTP_INTERCEPTORS,\r\n                useClass: PermissionUtilsInterceptor,\r\n                multi: true,\r\n            },\r\n            {\r\n                provide: HTTP_INTERCEPTORS,\r\n                useClass: TraceInterceptor,\r\n                multi: true,\r\n            },\r\n            MessageService,\r\n            ConfirmationService,\r\n            DatePipe,\r\n            UserFormatPipe,\r\n            UsersFormatPipe,\r\n            HtmlFormatPipe,\r\n            SafeHtmlPipe,\r\n            OrganizationFormatPipe,\r\n            OrganizationsFormatPipe,\r\n            MasterDataPipe,\r\n            NotifierService,\r\n            DecimalPipe,\r\n            TranslateService,\r\n            EntityWorkflowSettingService,\r\n            EntityWorkflowHistoryService,\r\n            EntityPermissionService,\r\n        ];\r\n    }\r\n}\r\n\r\n@NgModule({\r\n    imports: [\r\n        BrowserModule,\r\n        FormsModule,\r\n        HttpClientModule,\r\n        BrowserAnimationsModule,\r\n        ReactiveFormsModule,\r\n        TranslateModule.forRoot({\r\n            loader: {\r\n                provide: TranslateLoader,\r\n                useFactory: PublicFunction.createTranslateLoader,\r\n                deps: [HttpClient],\r\n            },\r\n        }),\r\n        NgxMaskModule.forRoot(),\r\n        ImgFallbackModule,\r\n    ],\r\n    exports: [\r\n        BrowserModule,\r\n        FormsModule,\r\n        HttpClientModule,\r\n        BrowserAnimationsModule,\r\n        ReactiveFormsModule,\r\n        TranslateModule,\r\n        NgxMaskModule,\r\n        ImgFallbackModule,\r\n    ]\r\n})\r\nexport class CommonPublicModule { }"]}
150
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-function.js","sourceRoot":"","sources":["../../../../projects/shared/src/lib/classes/public-function.ts"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, DecimalPipe, registerLocaleData } from '@angular/common';\r\nimport { HttpClient, HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';\r\nimport localeVi from '@angular/common/locales/vi';\r\nimport { LOCALE_ID } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { BrowserModule } from '@angular/platform-browser';\r\nimport { BrowserAnimationsModule } from '@angular/platform-browser/animations';\r\nimport { TranslateLoader, TranslateModule, TranslateService } from '@ngx-translate/core';\r\nimport { OAuthModule } from 'angular-oauth2-oidc';\r\nimport { ImgFallbackModule } from 'ngx-img-fallback';\r\nimport { NgxMaskModule } from 'ngx-mask';\r\nimport { ConfirmationService, MessageService } from 'tn-custom-primeng/api';\r\nimport { AccessDeniedComponent } from '../components/access-denied-component/access-denied.component';\r\nimport { CommonDashboardComponent } from '../components/common-dashboard/common-dashboard.component';\r\nimport { EntityPermissionService } from '../components/entity-permission/services.cs/entity-permission.service';\r\nimport { NotFoundComponent } from '../components/not-found/not-found.component';\r\nimport { SplashComponentComponent } from '../components/splash-component/splash-component.component';\r\nimport { UniversalLinkProcessorComponent } from '../components/universal-link-processor/universal-link-processor.component';\r\nimport { EntityWorkflowHistoryService } from '../components/workflow/services/entity-workflow-history.service';\r\nimport { EntityWorkflowSettingService } from '../components/workflow/services/entity-workflow-setting.service';\r\nimport { LogInterceptor } from '../intercepters/log.interceptor';\r\nimport { PermissionUtilsInterceptor } from '../intercepters/permission-utils.interceptor';\r\nimport { SendAccessTokenInterceptor } from '../intercepters/send-access-token.interceptor';\r\nimport { TraceInterceptor } from '../intercepters/trace.interceptor';\r\nimport { HtmlFormatPipe } from '../pipes/html-format.pipe';\r\nimport { MasterDataPipe } from '../pipes/masterData.pipe';\r\nimport { OrganizationFormatPipe } from '../pipes/organization-format.pipe';\r\nimport { OrganizationsFormatPipe } from '../pipes/organizations-format.pipe';\r\nimport { SafeHtmlPipe } from '../pipes/safe-html.pipe';\r\nimport { UserFormatPipe } from '../pipes/user-format.pipe';\r\nimport { UsersFormatPipe } from '../pipes/users-format.pipe';\r\nimport { NotifierService } from '../services/notifier.service';\r\n// TODO: Upgrade sau\r\n// import { BrowserFavicons, BROWSER_FAVICONS_CONFIG, Favicons } from './favicon';\r\nimport { MultiTranslateHttpLoader } from './multi-translate-http-loader';\r\n\r\n\r\nexport class PublicFunction {\r\n\r\n    static initRoute(routes: any[]) {\r\n        return [\r\n            ...PublicFunction.commonRoutes(),\r\n            ...routes,\r\n            ...PublicFunction.defaultRoutes(),\r\n        ];\r\n    }\r\n\r\n    static commonRoutes() {\r\n        return [\r\n            {\r\n                path: '',\r\n                component: SplashComponentComponent,\r\n            },\r\n            {\r\n                path: 'dashboard',\r\n                component: CommonDashboardComponent,\r\n            },\r\n            {\r\n                path: 'access-denied',\r\n                component: AccessDeniedComponent,\r\n            },\r\n            {\r\n                path: 'universal-link',\r\n                component: UniversalLinkProcessorComponent,\r\n            },\r\n        ];\r\n    }\r\n\r\n    static defaultRoutes() {\r\n        return [\r\n            { path: '**', component: NotFoundComponent },\r\n        ];\r\n    }\r\n\r\n    static createTranslateLoader(http: HttpClient) {\r\n        return new MultiTranslateHttpLoader(http,\r\n            [\r\n                { prefix: 'assets/i18n/', suffix: '.json' },\r\n                { prefix: 'assets/i18n/shared/', suffix: '.json' },\r\n            ],\r\n        );\r\n    }\r\n\r\n    static registerLocaleData(locale?, language?) {\r\n        if (!locale) {\r\n            locale = localeVi;\r\n        }\r\n        if (!language) {\r\n            language = 'vi';\r\n        }\r\n\r\n        registerLocaleData(locale, language);\r\n    }\r\n\r\n    static importRootModule(environment) {\r\n        return [\r\n            BrowserModule,\r\n            FormsModule,\r\n            HttpClientModule,\r\n            BrowserAnimationsModule,\r\n            ReactiveFormsModule,\r\n            TranslateModule.forRoot({\r\n                loader: {\r\n                    provide: TranslateLoader,\r\n                    useFactory: PublicFunction.createTranslateLoader,\r\n                    deps: [HttpClient],\r\n                },\r\n            }),\r\n            NgxMaskModule.forRoot(),\r\n            OAuthModule.forRoot({\r\n                resourceServer: {\r\n                    allowedUrls: [environment.appMetadata.appGateway],\r\n                    sendAccessToken: false,\r\n                },\r\n            }),\r\n            ImgFallbackModule,\r\n        ];\r\n    }\r\n\r\n    static useRootProvider(enviromment) {\r\n        return [\r\n            { provide: LOCALE_ID, useValue: 'vi-VN' },\r\n            {\r\n                provide: HTTP_INTERCEPTORS,\r\n                useClass: SendAccessTokenInterceptor,\r\n                multi: true,\r\n            },\r\n            {\r\n                provide: HTTP_INTERCEPTORS,\r\n                useClass: LogInterceptor,\r\n                multi: true,\r\n            },\r\n            {\r\n                provide: HTTP_INTERCEPTORS,\r\n                useClass: PermissionUtilsInterceptor,\r\n                multi: true,\r\n            },\r\n            {\r\n                provide: HTTP_INTERCEPTORS,\r\n                useClass: TraceInterceptor,\r\n                multi: true,\r\n            },\r\n            MessageService,\r\n            ConfirmationService,\r\n            DatePipe,\r\n            UserFormatPipe,\r\n            UsersFormatPipe,\r\n            HtmlFormatPipe,\r\n            SafeHtmlPipe,\r\n            OrganizationFormatPipe,\r\n            OrganizationsFormatPipe,\r\n            MasterDataPipe,\r\n            NotifierService,\r\n            DecimalPipe,\r\n            TranslateService,\r\n            EntityWorkflowSettingService,\r\n            EntityWorkflowHistoryService,\r\n            EntityPermissionService,\r\n        ];\r\n    }\r\n\r\n\r\n}\r\n"]}
@@ -10,8 +10,8 @@ import * as i0 from "@angular/core";
10
10
  import * as i1 from "../../services/article.service";
11
11
  import * as i2 from "../../services/newscategory.service";
12
12
  import * as i3 from "tn-custom-primeng/button";
13
- import * as i4 from "tn-custom-primeng/dropdown";
14
- import * as i5 from "tn-custom-primeng/tooltip";
13
+ import * as i4 from "tn-custom-primeng/tooltip";
14
+ import * as i5 from "tn-custom-primeng/dropdown";
15
15
  import * as i6 from "@angular/forms";
16
16
  import * as i7 from "../crud/crud-list/crud-list.component";
17
17
  import * as i8 from "@ngx-translate/core";
@@ -177,7 +177,7 @@ export class AddNewsComponent extends DataListBase {
177
177
  }
178
178
  }
179
179
  AddNewsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: AddNewsComponent, deps: [{ token: i0.Injector }, { token: i1.ArticleService }, { token: i2.NewsCategoryService }], target: i0.ɵɵFactoryTarget.Component });
180
- AddNewsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: AddNewsComponent, selector: "add-news", inputs: { isShow: "isShow", languageCode: "languageCode" }, outputs: { showChange: "showChange" }, providers: [ComponentContextService], viewQueries: [{ propertyName: "contextMenu", first: true, predicate: ContextMenu, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"custom-list\">\r\n <crud-list #crudList [model]=\"model\" [setting]=\"setting\" [dataSource]=\"model.dataSource\"\r\n (onReload)=\"_triggerProcessData($event)\" (onAdd)=\"_add($event)\" (onEdit)=\"_edit($event)\"\r\n (onView)=\"_view($event)\" (onDelete)=\"_delete($event)\" (onDeleteMultiple)=\"_deleteMultiple($event)\"\r\n (onReloaded)=\"_unmarkLoading()\" [hiddenAdd]=\"true\" [hiddenDelete]=\"true\">\r\n <ng-template #toolbar>\r\n <div class=\"ui-g p-grid\">\r\n <div class=\" p-g-12 p-md-3\">\r\n <button (click)=\"addMultiple($event)\" pButton type=\"button\"\r\n label=\"Th\u00EAm ({{model.selectedItems.length}})\" icon=\"pi pi-plus\" iconPos=\"left\"\r\n class=\"p-button-rounded p-button-text p-button-info\"></button>\r\n </div>\r\n <div class=\" p-g-12 p-md-3 p-offset-6\">\r\n <p-dropdown [placeholder]=\"'Ch\u1ECDn lo\u1EA1i tin'\" [options]=\"optionArr\" [(ngModel)]=\"articleType\"\r\n (onChange)=\"onSelect($event)\">\r\n </p-dropdown>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template #function let-rowData=\"rowData\" let-crudList=\"crudList\">\r\n <button (click)=\"addRow(rowData)\" icon=\"pi pi-plus\" pTooltip=\"{{'Th\u00EAm' | translate}}\" tooltipPosition=\"top\"\r\n pButton type=\"button\" label=\"Th\u00EAm\"\r\n class=\"p-button-rounded p-button-text p-button-primary link-or-action\"></button>\r\n </ng-template>\r\n </crud-list>\r\n</div>\r\n", styles: ["::ng-deep .custom-list .custom-card{min-height:calc(100vh - 328px)}::ng-deep .custom-list .p-dropdown.p-component{width:100%}\n"], dependencies: [{ kind: "directive", type: i3.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "label", "icon"] }, { kind: "component", type: i4.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "resetFilterOnHide", "dropdownIcon", "autoDisplayFirst", "emptyFilterMessage", "maxItemDisplay", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "autofocusFilter", "autofocusSelectedItem", "delayFilter", "disabled", "options", "filterValue", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "group", "showClear", "virtualScroll", "itemSize", "ariaFilterLabel", "ariaLabelledBy", "maxlength", "tooltipStyleClass", "modifyOptionsWhenFilter"], outputs: ["onChange", "onFocus", "onBlur", "onClick", "onShow", "onHide"] }, { kind: "directive", type: i5.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "tooltipZIndex", "escape", "tooltipDisabled", "pTooltip", "positionStyle", "tooltipStyleClass", "showDelay", "hideDelay", "life"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.CrudListComponent, selector: "crud-list" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] });
180
+ AddNewsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: AddNewsComponent, selector: "add-news", inputs: { isShow: "isShow", languageCode: "languageCode" }, outputs: { showChange: "showChange" }, providers: [ComponentContextService], viewQueries: [{ propertyName: "contextMenu", first: true, predicate: ContextMenu, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"custom-list\">\r\n <crud-list #crudList [model]=\"model\" [setting]=\"setting\" [dataSource]=\"model.dataSource\"\r\n (onReload)=\"_triggerProcessData($event)\" (onAdd)=\"_add($event)\" (onEdit)=\"_edit($event)\"\r\n (onView)=\"_view($event)\" (onDelete)=\"_delete($event)\" (onDeleteMultiple)=\"_deleteMultiple($event)\"\r\n (onReloaded)=\"_unmarkLoading()\" [hiddenAdd]=\"true\" [hiddenDelete]=\"true\">\r\n <ng-template #toolbar>\r\n <div class=\"ui-g p-grid\">\r\n <div class=\" p-g-12 p-md-3\">\r\n <button (click)=\"addMultiple($event)\" pButton type=\"button\"\r\n label=\"Th\u00EAm ({{model.selectedItems.length}})\" icon=\"pi pi-plus\" iconPos=\"left\"\r\n class=\"p-button-rounded p-button-text p-button-info\"></button>\r\n </div>\r\n <div class=\" p-g-12 p-md-3 p-offset-6\">\r\n <p-dropdown [placeholder]=\"'Ch\u1ECDn lo\u1EA1i tin'\" [options]=\"optionArr\" [(ngModel)]=\"articleType\"\r\n (onChange)=\"onSelect($event)\">\r\n </p-dropdown>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template #function let-rowData=\"rowData\" let-crudList=\"crudList\">\r\n <button (click)=\"addRow(rowData)\" icon=\"pi pi-plus\" pTooltip=\"{{'Th\u00EAm' | translate}}\" tooltipPosition=\"top\"\r\n pButton type=\"button\" label=\"Th\u00EAm\"\r\n class=\"p-button-rounded p-button-text p-button-primary link-or-action\"></button>\r\n </ng-template>\r\n </crud-list>\r\n</div>\r\n", styles: ["::ng-deep .custom-list .custom-card{min-height:calc(100vh - 328px)}::ng-deep .custom-list .p-dropdown.p-component{width:100%}\n"], dependencies: [{ kind: "directive", type: i3.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i4.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i5.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "maxItemDisplay", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "autofocusSelectedItem", "modifyOptionsWhenFilter", "delayFilter", "disabled", "itemSize", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i7.CrudListComponent, selector: "crud-list" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] });
181
181
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: AddNewsComponent, decorators: [{
182
182
  type: Component,
183
183
  args: [{ selector: 'add-news', providers: [ComponentContextService], template: "<div class=\"custom-list\">\r\n <crud-list #crudList [model]=\"model\" [setting]=\"setting\" [dataSource]=\"model.dataSource\"\r\n (onReload)=\"_triggerProcessData($event)\" (onAdd)=\"_add($event)\" (onEdit)=\"_edit($event)\"\r\n (onView)=\"_view($event)\" (onDelete)=\"_delete($event)\" (onDeleteMultiple)=\"_deleteMultiple($event)\"\r\n (onReloaded)=\"_unmarkLoading()\" [hiddenAdd]=\"true\" [hiddenDelete]=\"true\">\r\n <ng-template #toolbar>\r\n <div class=\"ui-g p-grid\">\r\n <div class=\" p-g-12 p-md-3\">\r\n <button (click)=\"addMultiple($event)\" pButton type=\"button\"\r\n label=\"Th\u00EAm ({{model.selectedItems.length}})\" icon=\"pi pi-plus\" iconPos=\"left\"\r\n class=\"p-button-rounded p-button-text p-button-info\"></button>\r\n </div>\r\n <div class=\" p-g-12 p-md-3 p-offset-6\">\r\n <p-dropdown [placeholder]=\"'Ch\u1ECDn lo\u1EA1i tin'\" [options]=\"optionArr\" [(ngModel)]=\"articleType\"\r\n (onChange)=\"onSelect($event)\">\r\n </p-dropdown>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template #function let-rowData=\"rowData\" let-crudList=\"crudList\">\r\n <button (click)=\"addRow(rowData)\" icon=\"pi pi-plus\" pTooltip=\"{{'Th\u00EAm' | translate}}\" tooltipPosition=\"top\"\r\n pButton type=\"button\" label=\"Th\u00EAm\"\r\n class=\"p-button-rounded p-button-text p-button-primary link-or-action\"></button>\r\n </ng-template>\r\n </crud-list>\r\n</div>\r\n", styles: ["::ng-deep .custom-list .custom-card{min-height:calc(100vh - 328px)}::ng-deep .custom-list .p-dropdown.p-component{width:100%}\n"] }]
@@ -100,7 +100,7 @@ AutocompleteDatasourceComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion:
100
100
  useExisting: forwardRef(() => AutocompleteDatasourceComponent),
101
101
  multi: true
102
102
  }
103
- ], ngImport: i0, template: "<p-autoComplete [styleClass]=\"'tn-autocomplete'\" [disabled]=\"control.disabled\" [size]=\"300\" [dropdown]=\"true\"\r\n [suggestions]=\"lstDataSuggest\" [placeholder]=\"control.placeholder\" [showTransitionOptions]=\"showTransitionOptions\"\r\n [hideTransitionOptions]=\"hideTransitionOptions\" [multiple]=\"control.multiple\" [minLength]=\"control.minLengthFilter\"\r\n [appendTo]=\"control.appendTo\" [(ngModel)]=\"selectedValue\" (onSelect)=\"handleSelect($event)\"\r\n (onUnselect)=\"handleUnSelect($event)\" (onBlur)=\"handleBlur($event)\" (onFocus)=\"handleFocus($event)\"\r\n (onDropdownClick)=\"handleACDropdownClick($event)\" (completeMethod)=\"filterData($event)\"\r\n (onKeyUp)=\"handleKeyUp($event)\">\r\n</p-autoComplete>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "type", "autoZIndex", "baseZIndex", "dropdownIcon", "unique", "completeOnFocus", "scrollHeight", "dropdownMode", "showTransitionOptions", "hideTransitionOptions", "autocomplete", "suggestions", "disabled", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "ariaLabel", "ariaLabelledBy", "field", "dropdown", "multiple", "tabindex", "dataKey", "emptyMessage", "autofocus"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide"] }] });
103
+ ], ngImport: i0, template: "<p-autoComplete [styleClass]=\"'tn-autocomplete'\" [disabled]=\"control.disabled\" [size]=\"300\" [dropdown]=\"true\"\r\n [suggestions]=\"lstDataSuggest\" [placeholder]=\"control.placeholder\" [showTransitionOptions]=\"showTransitionOptions\"\r\n [hideTransitionOptions]=\"hideTransitionOptions\" [multiple]=\"control.multiple\" [minLength]=\"control.minLengthFilter\"\r\n [appendTo]=\"control.appendTo\" [(ngModel)]=\"selectedValue\" (onSelect)=\"handleSelect($event)\"\r\n (onUnselect)=\"handleUnSelect($event)\" (onBlur)=\"handleBlur($event)\" (onFocus)=\"handleFocus($event)\"\r\n (onDropdownClick)=\"handleACDropdownClick($event)\" (completeMethod)=\"filterData($event)\"\r\n (onKeyUp)=\"handleKeyUp($event)\">\r\n</p-autoComplete>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "disabled", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "type", "autoZIndex", "baseZIndex", "ariaLabel", "dropdownAriaLabel", "ariaLabelledBy", "dropdownIcon", "unique", "group", "completeOnFocus", "showClear", "field", "dropdown", "showEmptyMessage", "dropdownMode", "multiple", "tabindex", "dataKey", "emptyMessage", "showTransitionOptions", "hideTransitionOptions", "autofocus", "autocomplete", "optionGroupChildren", "optionGroupLabel", "itemSize", "suggestions"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide", "onLazyLoad"] }] });
104
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: AutocompleteDatasourceComponent, decorators: [{
105
105
  type: Component,
106
106
  args: [{ selector: 'app-autocomplete-datasource', providers: [
@@ -530,7 +530,7 @@ AutoCompletePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.
530
530
  },
531
531
  ComponentContextService,
532
532
  EntityMetadataService
533
- ], viewQueries: [{ propertyName: "entityPickerBoxComponent", first: true, predicate: ["entityPickerBox"], descendants: true, static: true }, { propertyName: "autoComplete", first: true, predicate: ["autoComplete"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"p-inputgroup autocomplete-picker\" *ngIf=\"control\" [class.has-value]=\"hasValue\"\r\n [class.multiple]=\"control.multiple\" [class.disabled]=\"control.disabled\">\r\n <div style=\"width: calc(100% - 28px)\" [pTooltip]=\"tooltip\" tooltipPosition=\"top\">\r\n <p-autoComplete #autoComplete emptyMessage=\"Kh\u00F4ng c\u00F3 k\u1EBFt qu\u1EA3 n\u00E0o\" [ngClass]=\"'custom-autocomplete'\"\r\n [disabled]=\"disabled\" [placeholder]=\"control.placeholder\" [appendTo]=\"control.appendTo\"\r\n [suggestions]=\"results\" field=\"label\" [styleClass]=\"control.validators && control.required ? 'rq' : ''\"\r\n [multiple]=\"control.multiple\" [minLength]=\"2\" [(ngModel)]=\"selectedValueObject\"\r\n (onFocus)=\"handleFocus($event)\" (onBlur)=\"handleBlur($event)\" (completeMethod)=\"search($event)\"\r\n (onKeyUp)=\"handleKeyUp($event)\" (onSelect)=\"handleSelect($event)\" (onUnselect)=\"handleUnSelect($event)\">\r\n </p-autoComplete>\r\n </div>\r\n <span *ngIf=\"!control.multiple && !disabled && hasValue\" class=\"icon-clear\" (click)=\"clearValue()\"><i\r\n class=\"fas fa-times\"></i></span>\r\n <button class=\"custom-autocomplete-button\" [disabled]=\"disabled\" tabindex=\"-1\" (click)=\"showPickForm()\" pButton\r\n [pTooltip]=\"control.title\" icon=\"fas fa-external-link-alt\" type=\"button\"></button>\r\n</div>\r\n<tn-dialog #dialog *ngIf=\"showFormPicker\" styleClass=\"entity-picker-box-dialog no-padding\" [useDefaultScrollBar]=\"true\"\r\n [header]=\"control.title | translate\" [popupSize]=\"popupSize\" (onHide)=\"handleHide($event)\">\r\n <entity-picker-box #entityPickerBox [currentNode]=\"currentNode\" [control]=\"control\" [parentSetting]=\"setting\"\r\n [advanceData]=\"advanceData\" [readOnlyValues]=\"readOnlyValues\" [selectedValue]=\"selectedValue\"\r\n (onContentLeftInit)=\"handleContentLeftInit($event)\" (onContentRightInit)=\"handleContentRightInit($event)\"\r\n (onChanged)=\"handleChangeEntity($event)\" (onSelect)=\"handleSelectEntity($event)\"\r\n (onUnSelect)=\"handleUnSelectEntity($event)\" (onDone)=\"handleHide($event)\"\r\n (onRowSelect)=\"handleRowSelect($event)\">\r\n </entity-picker-box>\r\n <ng-template #footer>\r\n <button type=\" button\" pButton class=\"p-button-text\" (click)=\"onClickSubmitButton($event, entityPickerBox)\"\r\n [label]=\"'Ho\u00E0n th\u00E0nh' | translate\" icon=\"pi pi-check\"></button>\r\n </ng-template>\r\n</tn-dialog>", styles: [".autocomplete-picker{position:relative}.autocomplete-picker .icon-clear{position:absolute;right:36px;top:50%;transform:translateY(-50%);font-size:11px;color:#555;padding:3px;cursor:pointer}::ng-deep .autocomplete-picker.has-value:not(.multiple):not(.disabled) p-autocomplete .p-inputtext{padding-right:34px}::ng-deep .autocomplete-picker .p-autocomplete.p-autocomplete-multiple .p-autocomplete-multiple-container .p-autocomplete-input-token{padding:.143rem 0}::ng-deep .autocomplete-picker .p-autocomplete .p-autocomplete-multiple-container,::ng-deep .autocomplete-picker .p-autocomplete .p-autocomplete-input{border-radius:4px 0 0 4px}@media (max-width: 640px){::ng-deep autocomplete-picker .p-autocomplete.p-autocomplete-multiple .p-autocomplete-multiple-container .p-autocomplete-input-token{padding:0 0 3px}::ng-deep autocomplete-picker .p-autocomplete-input-token>input{height:21.5px!important}}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "label", "icon"] }, { kind: "directive", type: i4.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "tooltipZIndex", "escape", "tooltipDisabled", "pTooltip", "positionStyle", "tooltipStyleClass", "showDelay", "hideDelay", "life"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "type", "autoZIndex", "baseZIndex", "dropdownIcon", "unique", "completeOnFocus", "scrollHeight", "dropdownMode", "showTransitionOptions", "hideTransitionOptions", "autocomplete", "suggestions", "disabled", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "ariaLabel", "ariaLabelledBy", "field", "dropdown", "multiple", "tabindex", "dataKey", "emptyMessage", "autofocus"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide"] }, { kind: "component", type: i7.EntityPickerBoxComponent, selector: "entity-picker-box", inputs: ["parentSetting", "advanceData", "control", "width", "height", "readOnlyValues", "selectedValue", "currentNode"], outputs: ["onContentLeftInit", "onContentRightInit", "onRowSelect", "onChanged", "onSelect", "onUnSelect", "onDone"] }, { kind: "component", type: i8.TnDialogComponent, selector: "tn-dialog", inputs: ["maskClass", "styleClass", "scrollBarStyleClass", "useDefaultScrollBar", "visible", "disabledButton", "modal", "header", "popupSize", "closeOnEscape", "showFooter", "positionTop", "minY", "hiddenSave", "maximizable"], outputs: ["onSave", "onCancel", "onShow", "onHide"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
533
+ ], viewQueries: [{ propertyName: "entityPickerBoxComponent", first: true, predicate: ["entityPickerBox"], descendants: true, static: true }, { propertyName: "autoComplete", first: true, predicate: ["autoComplete"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"p-inputgroup autocomplete-picker\" *ngIf=\"control\" [class.has-value]=\"hasValue\"\r\n [class.multiple]=\"control.multiple\" [class.disabled]=\"control.disabled\">\r\n <div style=\"width: calc(100% - 28px)\" [pTooltip]=\"tooltip\" tooltipPosition=\"top\">\r\n <p-autoComplete #autoComplete emptyMessage=\"Kh\u00F4ng c\u00F3 k\u1EBFt qu\u1EA3 n\u00E0o\" [ngClass]=\"'custom-autocomplete'\"\r\n [disabled]=\"disabled\" [placeholder]=\"control.placeholder\" [appendTo]=\"control.appendTo\"\r\n [suggestions]=\"results\" field=\"label\" [styleClass]=\"control.validators && control.required ? 'rq' : ''\"\r\n [multiple]=\"control.multiple\" [minLength]=\"2\" [(ngModel)]=\"selectedValueObject\"\r\n (onFocus)=\"handleFocus($event)\" (onBlur)=\"handleBlur($event)\" (completeMethod)=\"search($event)\"\r\n (onKeyUp)=\"handleKeyUp($event)\" (onSelect)=\"handleSelect($event)\" (onUnselect)=\"handleUnSelect($event)\">\r\n </p-autoComplete>\r\n </div>\r\n <span *ngIf=\"!control.multiple && !disabled && hasValue\" class=\"icon-clear\" (click)=\"clearValue()\"><i\r\n class=\"fas fa-times\"></i></span>\r\n <button class=\"custom-autocomplete-button\" [disabled]=\"disabled\" tabindex=\"-1\" (click)=\"showPickForm()\" pButton\r\n [pTooltip]=\"control.title\" icon=\"fas fa-external-link-alt\" type=\"button\"></button>\r\n</div>\r\n<tn-dialog #dialog *ngIf=\"showFormPicker\" styleClass=\"entity-picker-box-dialog no-padding\" [useDefaultScrollBar]=\"true\"\r\n [header]=\"control.title | translate\" [popupSize]=\"popupSize\" (onHide)=\"handleHide($event)\">\r\n <entity-picker-box #entityPickerBox [currentNode]=\"currentNode\" [control]=\"control\" [parentSetting]=\"setting\"\r\n [advanceData]=\"advanceData\" [readOnlyValues]=\"readOnlyValues\" [selectedValue]=\"selectedValue\"\r\n (onContentLeftInit)=\"handleContentLeftInit($event)\" (onContentRightInit)=\"handleContentRightInit($event)\"\r\n (onChanged)=\"handleChangeEntity($event)\" (onSelect)=\"handleSelectEntity($event)\"\r\n (onUnSelect)=\"handleUnSelectEntity($event)\" (onDone)=\"handleHide($event)\"\r\n (onRowSelect)=\"handleRowSelect($event)\">\r\n </entity-picker-box>\r\n <ng-template #footer>\r\n <button type=\" button\" pButton class=\"p-button-text\" (click)=\"onClickSubmitButton($event, entityPickerBox)\"\r\n [label]=\"'Ho\u00E0n th\u00E0nh' | translate\" icon=\"pi pi-check\"></button>\r\n </ng-template>\r\n</tn-dialog>", styles: [".autocomplete-picker{position:relative}.autocomplete-picker .icon-clear{position:absolute;right:36px;top:50%;transform:translateY(-50%);font-size:11px;color:#555;padding:3px;cursor:pointer}::ng-deep .autocomplete-picker.has-value:not(.multiple):not(.disabled) p-autocomplete .p-inputtext{padding-right:34px}::ng-deep .autocomplete-picker .p-autocomplete.p-autocomplete-multiple .p-autocomplete-multiple-container .p-autocomplete-input-token{padding:.143rem 0}::ng-deep .autocomplete-picker .p-autocomplete .p-autocomplete-multiple-container,::ng-deep .autocomplete-picker .p-autocomplete .p-autocomplete-input{border-radius:4px 0 0 4px}@media (max-width: 640px){::ng-deep autocomplete-picker .p-autocomplete.p-autocomplete-multiple .p-autocomplete-multiple-container .p-autocomplete-input-token{padding:0 0 3px}::ng-deep autocomplete-picker .p-autocomplete-input-token>input{height:21.5px!important}}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i4.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "disabled", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "type", "autoZIndex", "baseZIndex", "ariaLabel", "dropdownAriaLabel", "ariaLabelledBy", "dropdownIcon", "unique", "group", "completeOnFocus", "showClear", "field", "dropdown", "showEmptyMessage", "dropdownMode", "multiple", "tabindex", "dataKey", "emptyMessage", "showTransitionOptions", "hideTransitionOptions", "autofocus", "autocomplete", "optionGroupChildren", "optionGroupLabel", "itemSize", "suggestions"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide", "onLazyLoad"] }, { kind: "component", type: i7.EntityPickerBoxComponent, selector: "entity-picker-box", inputs: ["parentSetting", "advanceData", "control", "width", "height", "readOnlyValues", "selectedValue", "currentNode"], outputs: ["onContentLeftInit", "onContentRightInit", "onRowSelect", "onChanged", "onSelect", "onUnSelect", "onDone"] }, { kind: "component", type: i8.TnDialogComponent, selector: "tn-dialog", inputs: ["maskClass", "styleClass", "scrollBarStyleClass", "useDefaultScrollBar", "visible", "disabledButton", "modal", "header", "popupSize", "closeOnEscape", "showFooter", "positionTop", "minY", "hiddenSave", "maximizable"], outputs: ["onSave", "onCancel", "onShow", "onHide"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
534
534
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: AutoCompletePickerComponent, decorators: [{
535
535
  type: Component,
536
536
  args: [{ selector: 'autocomplete-picker', providers: [
@@ -204,7 +204,7 @@ AvatarUploaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0"
204
204
  useExisting: forwardRef(() => AvatarUploaderComponent),
205
205
  multi: true
206
206
  }
207
- ], viewQueries: [{ propertyName: "fileControl", first: true, predicate: FileUpload, descendants: true }], ngImport: i0, template: "<!-- Todo: code lom, refactory lai sau -->\r\n<div *ngIf=\"!fileIdUploaded\">\r\n <div class=\"tn-thumbnail\">\r\n <img src=\"{{defaultNoImageUrl}}\" width=\"100%\" height=\"100%\" />\r\n\r\n <div class=\"tn-btn-thumbnail text-center\" *ngIf=\"!disabled && !showNoti\" (click)=\"onSelectThumbnailClick()\">\r\n <span class=\"text-center\"><i class=\"fas fa-cloud-upload-alt\"\r\n style=\"margin-right: 5px\"></i>{{chooseLabel}}</span>\r\n </div>\r\n\r\n <div *ngIf=\"showNoti\" class=\"tn-btn-thumbnail noti-container\">\r\n <i class=\"loader-icon pi pi-spin pi-spinner\"></i>\r\n {{notification}}\r\n </div>\r\n\r\n </div>\r\n <div *ngIf=\"!disabled\" style=\"display:none;\">\r\n <p-fileUpload #fileControl (onBeforeUpload)=\"onBeforeUpload($event)\" [multiple]=\"false\" accept=\"image/*\"\r\n [chooseLabel]=\"chooseLabel\" (onUpload)=\"onUploadEvent($event)\" mode=\"basic\" name=\"file\" [url]=\"apiUploadUrl\"\r\n maxFileSize=\"10000000\" auto=\"true\"></p-fileUpload>\r\n </div>\r\n</div>\r\n<div *ngIf=\"fileIdUploaded != null\">\r\n <div class=\"tn-thumbnail\">\r\n <img (error)=\"onError($event)\" [src]=\"getImageUrl()\" width=\"100%\" height=\"100%\" />\r\n <div *ngIf=\"!disabled && !showNoti\" class=\"tn-btn-thumbnail text-center\" (click)=\"deleteAvatar()\">\r\n <a class=\"text-center text-danger\">\r\n <i class=\"pi pi-trash btn-delete\"></i>\r\n X\u00F3a</a>\r\n </div>\r\n <div *ngIf=\"showNoti\" class=\"tn-btn-thumbnail noti-container\">\r\n <i class=\"loader-icon pi pi-spin pi-spinner\"></i>\r\n {{notification}}\r\n </div>\r\n </div>\r\n</div>", styles: [".tn-thumbnail{width:100%;height:100%;position:relative;border:1px solid #eee}.tn-btn-thumbnail{display:inline-block;position:absolute;bottom:0;height:30px;width:100%;opacity:.5;background:#000;left:0;cursor:pointer;border:1px solid #eee}.tn-btn-thumbnail span{line-height:30px;color:#fff}.tn-btn-thumbnail .btn-delete{margin-right:5px}.text-center{text-align:center;vertical-align:middle;vertical-align:-webkit-baseline-middle}.text-danger{color:red}.noti-container{display:flex;justify-content:center;align-items:center;font-size:12px;font-weight:400;color:#fff}.noti-container .loader-icon{margin-right:5px;font-size:13px}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.FileUpload, selector: "p-fileUpload", inputs: ["method", "invalidFileSizeMessageSummary", "invalidFileSizeMessageDetail", "invalidFileTypeMessageSummary", "invalidFileTypeMessageDetail", "invalidFileLimitMessageDetail", "invalidFileLimitMessageSummary", "previewWidth", "chooseIcon", "uploadIcon", "cancelIcon", "showUploadButton", "showCancelButton", "mode", "files", "name", "url", "multiple", "accept", "disabled", "auto", "withCredentials", "maxFileSize", "style", "styleClass", "chooseLabel", "uploadLabel", "cancelLabel", "headers", "customUpload", "fileLimit"], outputs: ["onBeforeUpload", "onSend", "onUpload", "onError", "onClear", "onRemove", "onSelect", "onProgress", "uploadHandler"] }] });
207
+ ], viewQueries: [{ propertyName: "fileControl", first: true, predicate: FileUpload, descendants: true }], ngImport: i0, template: "<!-- Todo: code lom, refactory lai sau -->\r\n<div *ngIf=\"!fileIdUploaded\">\r\n <div class=\"tn-thumbnail\">\r\n <img src=\"{{defaultNoImageUrl}}\" width=\"100%\" height=\"100%\" />\r\n\r\n <div class=\"tn-btn-thumbnail text-center\" *ngIf=\"!disabled && !showNoti\" (click)=\"onSelectThumbnailClick()\">\r\n <span class=\"text-center\"><i class=\"fas fa-cloud-upload-alt\"\r\n style=\"margin-right: 5px\"></i>{{chooseLabel}}</span>\r\n </div>\r\n\r\n <div *ngIf=\"showNoti\" class=\"tn-btn-thumbnail noti-container\">\r\n <i class=\"loader-icon pi pi-spin pi-spinner\"></i>\r\n {{notification}}\r\n </div>\r\n\r\n </div>\r\n <div *ngIf=\"!disabled\" style=\"display:none;\">\r\n <p-fileUpload #fileControl (onBeforeUpload)=\"onBeforeUpload($event)\" [multiple]=\"false\" accept=\"image/*\"\r\n [chooseLabel]=\"chooseLabel\" (onUpload)=\"onUploadEvent($event)\" mode=\"basic\" name=\"file\" [url]=\"apiUploadUrl\"\r\n maxFileSize=\"10000000\" auto=\"true\"></p-fileUpload>\r\n </div>\r\n</div>\r\n<div *ngIf=\"fileIdUploaded != null\">\r\n <div class=\"tn-thumbnail\">\r\n <img (error)=\"onError($event)\" [src]=\"getImageUrl()\" width=\"100%\" height=\"100%\" />\r\n <div *ngIf=\"!disabled && !showNoti\" class=\"tn-btn-thumbnail text-center\" (click)=\"deleteAvatar()\">\r\n <a class=\"text-center text-danger\">\r\n <i class=\"pi pi-trash btn-delete\"></i>\r\n X\u00F3a</a>\r\n </div>\r\n <div *ngIf=\"showNoti\" class=\"tn-btn-thumbnail noti-container\">\r\n <i class=\"loader-icon pi pi-spin pi-spinner\"></i>\r\n {{notification}}\r\n </div>\r\n </div>\r\n</div>", styles: [".tn-thumbnail{width:100%;height:100%;position:relative;border:1px solid #eee}.tn-btn-thumbnail{display:inline-block;position:absolute;bottom:0;height:30px;width:100%;opacity:.5;background:#000;left:0;cursor:pointer;border:1px solid #eee}.tn-btn-thumbnail span{line-height:30px;color:#fff}.tn-btn-thumbnail .btn-delete{margin-right:5px}.text-center{text-align:center;vertical-align:middle;vertical-align:-webkit-baseline-middle}.text-danger{color:red}.noti-container{display:flex;justify-content:center;align-items:center;font-size:12px;font-weight:400;color:#fff}.noti-container .loader-icon{margin-right:5px;font-size:13px}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.FileUpload, selector: "p-fileUpload", inputs: ["name", "url", "method", "multiple", "accept", "disabled", "auto", "withCredentials", "maxFileSize", "invalidFileSizeMessageSummary", "invalidFileSizeMessageDetail", "invalidFileTypeMessageSummary", "invalidFileTypeMessageDetail", "invalidFileLimitMessageDetail", "invalidFileLimitMessageSummary", "style", "styleClass", "previewWidth", "chooseLabel", "uploadLabel", "cancelLabel", "chooseIcon", "uploadIcon", "cancelIcon", "showUploadButton", "showCancelButton", "mode", "headers", "customUpload", "fileLimit", "files"], outputs: ["onBeforeUpload", "onSend", "onUpload", "onError", "onClear", "onRemove", "onSelect", "onProgress", "uploadHandler"] }] });
208
208
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: AvatarUploaderComponent, decorators: [{
209
209
  type: Component,
210
210
  args: [{ selector: 'app-avatar-uploader', providers: [