ets-fe-ng-sdk 17.0.428 → 17.0.430

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.
@@ -15,7 +15,8 @@ export declare class FindItemComponent<TQuery extends IObjectLiteral = any, TRow
15
15
  readonly autoFormatSchema: import("@angular/core").InputSignal<boolean>;
16
16
  readonly autoOrder: import("@angular/core").InputSignal<boolean>;
17
17
  readonly centerCells: import("@angular/core").InputSignal<boolean>;
18
- readonly displayedColumns: import("@angular/core").InputSignal<TableCol<any>[]>;
18
+ readonly _displayedColumns: import("@angular/core").InputSignal<TableCol<TRow>[]>;
19
+ readonly displayedColumns: import("@angular/core").Signal<TableCol<TRow>[]>;
19
20
  /**
20
21
  * Row grid configuration
21
22
  */
@@ -114,7 +115,7 @@ export declare class FindItemComponent<TQuery extends IObjectLiteral = any, TRow
114
115
  readonly isAnySelected: import("@angular/core").Signal<boolean>;
115
116
  protected setSelection(): void;
116
117
  static ɵfac: i0.ɵɵFactoryDeclaration<FindItemComponent<any, any>, never>;
117
- static ɵcmp: i0.ɵɵComponentDeclaration<FindItemComponent<any, any>, "app-find-item,find-item", never, { "autoFormatSchema": { "alias": "autoFormatSchema"; "required": false; "isSignal": true; }; "autoOrder": { "alias": "autoOrder"; "required": false; "isSignal": true; }; "centerCells": { "alias": "centerCells"; "required": false; "isSignal": true; }; "displayedColumns": { "alias": "displayedColumns"; "required": false; "isSignal": true; }; "gridClass": { "alias": "gridClass"; "required": false; "isSignal": true; }; "hideForm": { "alias": "hideForm"; "required": false; "isSignal": true; }; "expandedRowTemplate": { "alias": "expandedRowTemplate"; "required": false; "isSignal": true; }; "isTablePaginated": { "alias": "isTablePaginated"; "required": false; "isSignal": true; }; "isExpandable": { "alias": "isExpandable"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "nowrap": { "alias": "nowrap"; "required": false; "isSignal": true; }; "options": { "alias": "rowOptions"; "required": false; "isSignal": true; }; "orderDirection": { "alias": "orderDirection"; "required": false; "isSignal": true; }; "orderField": { "alias": "orderField"; "required": false; "isSignal": true; }; "pageSize": { "alias": "pageSize"; "required": false; "isSignal": true; }; "searchFunction": { "alias": "searchFunction"; "required": false; "isSignal": true; }; "showData": { "alias": "showData"; "required": false; "isSignal": true; }; "searchIfNoQuery": { "alias": "searchIfNoQuery"; "required": false; "isSignal": true; }; "showExport": { "alias": "showExport"; "required": false; "isSignal": true; }; "showFilter": { "alias": "showFilter"; "required": false; "isSignal": true; }; "showRefreshBtn": { "alias": "showRefreshBtn"; "required": false; "isSignal": true; }; "startSectionTemplate": { "alias": "startSectionTemplate"; "required": false; "isSignal": true; }; "showSearchBtn": { "alias": "showSearchBtn"; "required": false; "isSignal": true; }; "showClearBtn": { "alias": "showClearBtn"; "required": false; "isSignal": true; }; "showValidationMsg": { "alias": "showValidationMsg"; "required": false; "isSignal": true; }; "createBtnRoute": { "alias": "createBtnRoute"; "required": false; "isSignal": true; }; "showAdditionalColumns": { "alias": "showAdditionalColumns"; "required": false; "isSignal": true; }; "smallerFonts": { "alias": "smallerFonts"; "required": false; "isSignal": true; }; "useSelection": { "alias": "useSelection"; "required": false; "isSignal": true; }; "createButton": { "alias": "createButton"; "required": false; "isSignal": true; }; "_formSchema": { "alias": "formSchema"; "required": false; }; "searchObservableFunc": { "alias": "searchObservableFunc"; "required": false; "isSignal": true; }; }, { "_rowClick": "rowClick"; "clickedCreate": "clickedCreate"; }, never, ["[tablePanel]"], true, never>;
118
+ static ɵcmp: i0.ɵɵComponentDeclaration<FindItemComponent<any, any>, "app-find-item,find-item", never, { "autoFormatSchema": { "alias": "autoFormatSchema"; "required": false; "isSignal": true; }; "autoOrder": { "alias": "autoOrder"; "required": false; "isSignal": true; }; "centerCells": { "alias": "centerCells"; "required": false; "isSignal": true; }; "_displayedColumns": { "alias": "displayedColumns"; "required": false; "isSignal": true; }; "gridClass": { "alias": "gridClass"; "required": false; "isSignal": true; }; "hideForm": { "alias": "hideForm"; "required": false; "isSignal": true; }; "expandedRowTemplate": { "alias": "expandedRowTemplate"; "required": false; "isSignal": true; }; "isTablePaginated": { "alias": "isTablePaginated"; "required": false; "isSignal": true; }; "isExpandable": { "alias": "isExpandable"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "nowrap": { "alias": "nowrap"; "required": false; "isSignal": true; }; "options": { "alias": "rowOptions"; "required": false; "isSignal": true; }; "orderDirection": { "alias": "orderDirection"; "required": false; "isSignal": true; }; "orderField": { "alias": "orderField"; "required": false; "isSignal": true; }; "pageSize": { "alias": "pageSize"; "required": false; "isSignal": true; }; "searchFunction": { "alias": "searchFunction"; "required": false; "isSignal": true; }; "showData": { "alias": "showData"; "required": false; "isSignal": true; }; "searchIfNoQuery": { "alias": "searchIfNoQuery"; "required": false; "isSignal": true; }; "showExport": { "alias": "showExport"; "required": false; "isSignal": true; }; "showFilter": { "alias": "showFilter"; "required": false; "isSignal": true; }; "showRefreshBtn": { "alias": "showRefreshBtn"; "required": false; "isSignal": true; }; "startSectionTemplate": { "alias": "startSectionTemplate"; "required": false; "isSignal": true; }; "showSearchBtn": { "alias": "showSearchBtn"; "required": false; "isSignal": true; }; "showClearBtn": { "alias": "showClearBtn"; "required": false; "isSignal": true; }; "showValidationMsg": { "alias": "showValidationMsg"; "required": false; "isSignal": true; }; "createBtnRoute": { "alias": "createBtnRoute"; "required": false; "isSignal": true; }; "showAdditionalColumns": { "alias": "showAdditionalColumns"; "required": false; "isSignal": true; }; "smallerFonts": { "alias": "smallerFonts"; "required": false; "isSignal": true; }; "useSelection": { "alias": "useSelection"; "required": false; "isSignal": true; }; "createButton": { "alias": "createButton"; "required": false; "isSignal": true; }; "_formSchema": { "alias": "formSchema"; "required": false; }; "searchObservableFunc": { "alias": "searchObservableFunc"; "required": false; "isSignal": true; }; }, { "_rowClick": "rowClick"; "clickedCreate": "clickedCreate"; }, never, ["[tablePanel]"], true, never>;
118
119
  }
119
120
  export interface ISearchFormSchema<TQuery extends IObjectLiteral = any, TRow extends IObjectLiteral = any> extends IBaseFormSchema<TQuery, FindItemComponent<TQuery, TRow>, {
120
121
  [K in keyof TQuery]: AbstractControl<any, any>;
@@ -41,7 +41,7 @@ export declare class ApiService {
41
41
  get: <T = any>(route: string, parameters?: {
42
42
  [field: string]: string | number | boolean;
43
43
  }, extras?: IExtras) => Observable<T>;
44
- getCodes: <T extends ICodeTitle<string> | ICodeDescription = ICodeTitle<string> & ICodeDescription>(route: string) => Observable<T[]>;
44
+ getCodes: <T extends ICodeDescription | ICodeTitle<string> = ICodeTitle<string> & ICodeDescription>(route: string) => Observable<T[]>;
45
45
  getText: <T = string>(route: string, parameters?: {
46
46
  [field: string]: string | number | boolean;
47
47
  }, extras?: IExtras) => Observable<T>;
@@ -84,7 +84,7 @@ export declare class FormGeneratedValueComponent<TFormGroup extends {
84
84
  showValidationMsg?: boolean;
85
85
  dontFormatAsInput?: boolean;
86
86
  showRequiredTag?: boolean;
87
- tableFormatter?: (val: any) => string | import("rxjs").Observable<string> | Promise<string>;
87
+ tableFormatter?: (val: any) => string | Promise<string> | import("rxjs").Observable<string>;
88
88
  icon?: import("ets-fe-ng-sdk").IconType;
89
89
  verbose?: boolean;
90
90
  }[]>;
@@ -5,19 +5,26 @@ import { Observable, Subscription } from 'rxjs';
5
5
  import { UtilityService } from '../../../Services/utility.service';
6
6
  import { IObjectLiteral, InputType } from '../../models/index.model';
7
7
  import { IconType } from '../btn/btn.model';
8
+ import { TableService } from '../table-plain/table-plain.service';
8
9
  export declare abstract class BaseFormGenerator<TFormGroup extends IObjectLiteral, TBaseFormSchema extends {
9
10
  field?: any;
11
+ label?: string;
10
12
  } = any> {
11
- formSchemaMap: import("@angular/core").WritableSignal<{
13
+ readonly tableService: TableService;
14
+ protected _formSchemaMap: import("@angular/core").WritableSignal<{
15
+ [field: string]: TBaseFormSchema;
16
+ }>;
17
+ protected formSchemaMap: import("@angular/core").Signal<{
12
18
  [field: string]: TBaseFormSchema;
13
19
  }>;
14
- formSchema: import("@angular/core").Signal<TBaseFormSchema[]>;
20
+ readonly formSchema: import("@angular/core").Signal<TBaseFormSchema[]>;
15
21
  subs: {
16
22
  [fieldName: string]: Subscription;
17
23
  };
18
24
  utilityService: UtilityService<any>;
19
25
  destroyRef: DestroyRef;
20
26
  cdr: ChangeDetectorRef;
27
+ readonly useCustomLabels: import("@angular/core").ModelSignal<boolean>;
21
28
  constructor();
22
29
  onDestroy(): void;
23
30
  protected _setFormSchemas(schemas: TBaseFormSchema[]): void;
@@ -18,7 +18,7 @@ export declare class ResizeGridPipe implements PipeTransform {
18
18
  static ɵpipe: i0.ɵɵPipeDeclaration<ResizeGridPipe, "resizeGrid", true>;
19
19
  }
20
20
  export declare class IndexCompLayoutComponent {
21
- readonly grid: InputSignal<4 | 2 | 3 | 1 | 6 | 5 | "auto">;
21
+ readonly grid: InputSignal<6 | 4 | 1 | 3 | 2 | "auto" | 5>;
22
22
  readonly showButtons: InputSignal<boolean>;
23
23
  readonly hideClone: InputSignal<boolean>;
24
24
  readonly hideShow: InputSignal<boolean>;
@@ -22,7 +22,7 @@ export declare class PageTemplateComponent<ModelData = any, TEnvironment extends
22
22
  readonly isClone: import("@angular/core").Signal<boolean>;
23
23
  readonly isEdit: import("@angular/core").Signal<boolean>;
24
24
  readonly isShow: import("@angular/core").Signal<boolean>;
25
- get infoFunc(): (text: string, status?: 0 | 2 | 1, heading?: string, btns?: import("ets-fe-ng-sdk").IInfoDialogBtn[], disableClose?: boolean) => Promise<boolean>;
25
+ get infoFunc(): (text: string, status?: 0 | 1 | 2, heading?: string, btns?: import("ets-fe-ng-sdk").IInfoDialogBtn[], disableClose?: boolean) => Promise<boolean>;
26
26
  route: ActivatedRoute;
27
27
  uS: UtilityService<any>;
28
28
  router: Router;
@@ -44,7 +44,8 @@ export declare abstract class TableBaseComponent<TItem extends IObjectLiteral> {
44
44
  field?: keyof TItem;
45
45
  label?: string;
46
46
  }[]>;
47
- readonly displayedColumns: import("@angular/core").InputSignal<TableCol<TItem>[]>;
47
+ readonly _displayedColumns: import("@angular/core").InputSignal<TableCol<TItem>[]>;
48
+ readonly displayedColumns: Signal<TableCol<TItem>[]>;
48
49
  readonly overrideDisplayedColumns: WritableSignal<TableCol<TItem>[]>;
49
50
  readonly displayedColumnsNoAC: Signal<TableCol<TItem>[]>;
50
51
  readonly displayedColumnsMap: Signal<{
@@ -77,6 +78,7 @@ export declare abstract class TableBaseComponent<TItem extends IObjectLiteral> {
77
78
  };
78
79
  uS: UtilityService<any>;
79
80
  tS: TableService;
81
+ readonly useCustomLabels: import("@angular/core").ModelSignal<boolean>;
80
82
  /** Whether the number of selected elements matches the total number of rows. */
81
83
  readonly isAllSelected: Signal<boolean>;
82
84
  readonly isAnySelected: Signal<boolean>;
@@ -106,5 +108,5 @@ export declare abstract class TableBaseComponent<TItem extends IObjectLiteral> {
106
108
  closeExpandedCell(): void;
107
109
  refreshUI(): void;
108
110
  static ɵfac: i0.ɵɵFactoryDeclaration<TableBaseComponent<any>, never>;
109
- static ɵcmp: i0.ɵɵComponentDeclaration<TableBaseComponent<any>, "ng-component", never, { "rowOptions": { "alias": "rowOptions"; "required": false; "isSignal": true; }; "centerCells": { "alias": "centerCells"; "required": false; "isSignal": true; }; "curvy": { "alias": "curvy"; "required": false; "isSignal": true; }; "distinct": { "alias": "distinct"; "required": false; "isSignal": true; }; "header": { "alias": "header"; "required": false; "isSignal": true; }; "isExpandable": { "alias": "isExpandable"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "isDisabledFunc": { "alias": "isDisabledFunc"; "required": false; "isSignal": true; }; "noItemTxt": { "alias": "noItemTxt"; "required": false; "isSignal": true; }; "nowrap": { "alias": "nowrap"; "required": false; "isSignal": true; }; "expandedRowTemplate": { "alias": "expandedRowTemplate"; "required": false; "isSignal": true; }; "orderDirection": { "alias": "orderDirection"; "required": false; "isSignal": true; }; "orderField": { "alias": "orderField"; "required": false; "isSignal": true; }; "pageSize": { "alias": "pageSize"; "required": false; "isSignal": true; }; "startSectionTemplate": { "alias": "startSectionTemplate"; "required": false; "isSignal": true; }; "pageSizeOptions": { "alias": "pageSizeOptions"; "required": false; "isSignal": true; }; "placeSelectionAtRight": { "alias": "placeSelectionAtRight"; "required": false; "isSignal": true; }; "showAdditionalColumns": { "alias": "showAdditionalColumns"; "required": false; "isSignal": true; }; "showExport": { "alias": "showExport"; "required": false; "isSignal": true; }; "showRowPointer": { "alias": "showRowPointer"; "required": false; "isSignal": true; }; "smallerFonts": { "alias": "smallerFonts"; "required": false; "isSignal": true; }; "striped": { "alias": "striped"; "required": false; "isSignal": true; }; "tableContainerClass": { "alias": "tableContainerClass"; "required": false; "isSignal": true; }; "useSelection": { "alias": "useSelection"; "required": false; "isSignal": true; }; "formSchemaToColumns": { "alias": "formSchemaToColumns"; "required": false; "isSignal": true; }; "uploadSchemaToColumns": { "alias": "uploadSchemaToColumns"; "required": false; "isSignal": true; }; "displayedColumns": { "alias": "displayedColumns"; "required": false; "isSignal": true; }; }, { "_rowClick": "rowClick"; "selectionChanged": "selectionChanged"; "emitCheckbox": "emitCheckbox"; }, never, never, true, never>;
111
+ static ɵcmp: i0.ɵɵComponentDeclaration<TableBaseComponent<any>, "ng-component", never, { "rowOptions": { "alias": "rowOptions"; "required": false; "isSignal": true; }; "centerCells": { "alias": "centerCells"; "required": false; "isSignal": true; }; "curvy": { "alias": "curvy"; "required": false; "isSignal": true; }; "distinct": { "alias": "distinct"; "required": false; "isSignal": true; }; "header": { "alias": "header"; "required": false; "isSignal": true; }; "isExpandable": { "alias": "isExpandable"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "isDisabledFunc": { "alias": "isDisabledFunc"; "required": false; "isSignal": true; }; "noItemTxt": { "alias": "noItemTxt"; "required": false; "isSignal": true; }; "nowrap": { "alias": "nowrap"; "required": false; "isSignal": true; }; "expandedRowTemplate": { "alias": "expandedRowTemplate"; "required": false; "isSignal": true; }; "orderDirection": { "alias": "orderDirection"; "required": false; "isSignal": true; }; "orderField": { "alias": "orderField"; "required": false; "isSignal": true; }; "pageSize": { "alias": "pageSize"; "required": false; "isSignal": true; }; "startSectionTemplate": { "alias": "startSectionTemplate"; "required": false; "isSignal": true; }; "pageSizeOptions": { "alias": "pageSizeOptions"; "required": false; "isSignal": true; }; "placeSelectionAtRight": { "alias": "placeSelectionAtRight"; "required": false; "isSignal": true; }; "showAdditionalColumns": { "alias": "showAdditionalColumns"; "required": false; "isSignal": true; }; "showExport": { "alias": "showExport"; "required": false; "isSignal": true; }; "showRowPointer": { "alias": "showRowPointer"; "required": false; "isSignal": true; }; "smallerFonts": { "alias": "smallerFonts"; "required": false; "isSignal": true; }; "striped": { "alias": "striped"; "required": false; "isSignal": true; }; "tableContainerClass": { "alias": "tableContainerClass"; "required": false; "isSignal": true; }; "useSelection": { "alias": "useSelection"; "required": false; "isSignal": true; }; "formSchemaToColumns": { "alias": "formSchemaToColumns"; "required": false; "isSignal": true; }; "uploadSchemaToColumns": { "alias": "uploadSchemaToColumns"; "required": false; "isSignal": true; }; "_displayedColumns": { "alias": "displayedColumns"; "required": false; "isSignal": true; }; "useCustomLabels": { "alias": "useCustomLabels"; "required": false; "isSignal": true; }; }, { "_rowClick": "rowClick"; "selectionChanged": "selectionChanged"; "emitCheckbox": "emitCheckbox"; "useCustomLabels": "useCustomLabelsChange"; }, never, never, true, never>;
110
112
  }
@@ -1,10 +1,14 @@
1
1
  import { IKVP, TableCol } from '../../models/index.model';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class TableService {
4
+ customLabelMap: {
5
+ [field: string]: string;
6
+ };
4
7
  constructor();
5
8
  formatToColours: (key: any, codes?: IKVP[]) => string;
6
9
  getRawFields(arr: TableCol[], optionsLen?: number, useSelection?: boolean, placeSelectionAtRight?: boolean, // the parameter is to support setting the selection checkboxes as the last item instead of the first
7
10
  isExpandable?: boolean): string[];
11
+ globalColumnsFormatter: <TRow>(columns: TableCol<TRow>[]) => TableCol<TRow>[];
8
12
  arrayToCSVWorker: (array: any[], filename: string, columns?: string[], showHeader?: boolean) => Promise<void>;
9
13
  static ɵfac: i0.ɵɵFactoryDeclaration<TableService, never>;
10
14
  static ɵprov: i0.ɵɵInjectableDeclaration<TableService>;
@@ -1,4 +1,4 @@
1
- import { TemplateRef, Signal } from '@angular/core';
1
+ import { TemplateRef } from '@angular/core';
2
2
  import { Observable } from 'rxjs';
3
3
  import { InputType } from '../../models/index.model';
4
4
  import { TextCaseService } from './text-case.service';
@@ -26,9 +26,9 @@ export declare class TextCase2Component<T = any> {
26
26
  isEmail: import("@angular/core").InputSignal<boolean>;
27
27
  isPhone: import("@angular/core").InputSignal<boolean>;
28
28
  tS: TextCaseService;
29
- computedRoute: Signal<Observable<string> | Promise<string>>;
30
- computedValue: Signal<string | number | boolean>;
31
- computedValueFormatter: Signal<Promise<string | number | boolean> | Observable<string | number | boolean>>;
29
+ computedRoute: import("@angular/core").Signal<Promise<string> | Observable<string>>;
30
+ computedValue: import("@angular/core").Signal<string | number | boolean>;
31
+ computedValueFormatter: import("@angular/core").Signal<Promise<string | number | boolean> | Observable<string | number | boolean>>;
32
32
  static ɵfac: i0.ɵɵFactoryDeclaration<TextCase2Component<any>, never>;
33
33
  static ɵcmp: i0.ɵɵComponentDeclaration<TextCase2Component<any>, "text-case-2", never, { "action": { "alias": "action"; "required": false; "isSignal": true; }; "name": { "alias": "name"; "required": false; "isSignal": true; }; "data": { "alias": "data"; "required": false; "isSignal": true; }; "coloredLbl": { "alias": "coloredLbl"; "required": false; "isSignal": true; }; "coloredVal": { "alias": "coloredVal"; "required": false; "isSignal": true; }; "centered": { "alias": "centered"; "required": false; "isSignal": true; }; "customValueTemplate": { "alias": "customValueTemplate"; "required": false; "isSignal": true; }; "formatter": { "alias": "formatter"; "required": false; "isSignal": true; }; "hint": { "alias": "hint"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "light": { "alias": "light"; "required": false; "isSignal": true; }; "mini": { "alias": "mini"; "required": false; "isSignal": true; }; "route": { "alias": "route"; "required": false; "isSignal": true; }; "routeFunc": { "alias": "routeFunc"; "required": false; "isSignal": true; }; "editable": { "alias": "editable"; "required": false; "isSignal": true; }; "stacked": { "alias": "stacked"; "required": false; "isSignal": true; }; "type": { "alias": "type"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "wrapLabel": { "alias": "wrapLabel"; "required": false; "isSignal": true; }; "isEmail": { "alias": "isEmail"; "required": false; "isSignal": true; }; "isPhone": { "alias": "isPhone"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
34
34
  }
@@ -76,17 +76,28 @@ declare global {
76
76
  }): T[];
77
77
  /**
78
78
  * Converts an array to a key value pair.
79
- * @param arr Array to be converted
80
79
  * @param keyField The field to be used as the key
81
80
  * @returns An index object containing the keyField as the index key and each item of the array as value assigned to each index
82
81
  */
83
82
  toMap(keyField: keyof T): {
84
83
  [x: string]: T;
85
84
  };
86
- toMap<NT>(keyField: keyof T, map: (item: T) => NT): {
85
+ /**
86
+ * Converts an array to a key value pair.
87
+ * @param keyMap Function to set the key of the map
88
+ */
89
+ toMap(keyMap: (row: T) => string | number): {
90
+ [x: string]: T;
91
+ };
92
+ /**
93
+ * Converts an array to a key value pair.
94
+ * @param keyField The field to be used as the key
95
+ * @param valueMap Function to set the values of each key in the map
96
+ * @returns An index object containing the keyField as the index key and each item of the array as value assigned to each index
97
+ */
98
+ toMap<NT>(keyField: keyof T, valueMap: (item: T) => NT): {
87
99
  [x: string]: NT;
88
100
  };
89
- toMap<NT>(keyField: keyof T, map?: (item: T) => NT): any;
90
101
  /**
91
102
  * Groups an array by unique entries in a field.
92
103
  * @param arr Array to be grouped
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ets-fe-ng-sdk",
3
- "version": "17.0.428",
3
+ "version": "17.0.430",
4
4
  "repository": {
5
5
  "url": "https://github.com/Evolutics-Tech/ets-fe-sdk"
6
6
  },