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.
- package/esm2022/lib/Reusables/reusable-comps/find-item/find-item.component.mjs +6 -3
- package/esm2022/lib/Shared/components/form-generator/form-generator.base.component.mjs +20 -8
- package/esm2022/lib/Shared/components/table-plain/table-base.component.mjs +8 -4
- package/esm2022/lib/Shared/components/table-plain/table-plain.service.mjs +3 -1
- package/esm2022/lib/Shared/components/text-case-2/text-case-2.component.mjs +2 -2
- package/esm2022/lib/Shared/prototypes/prototypes.mjs +11 -5
- package/fesm2022/ets-fe-ng-sdk.mjs +40 -14
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Reusables/reusable-comps/find-item/find-item.component.d.ts +3 -2
- package/lib/Services/api.service.d.ts +1 -1
- package/lib/Shared/components/form-generator/form-generated-value/form-generated-value.component.d.ts +1 -1
- package/lib/Shared/components/form-generator/form-generator.base.component.d.ts +9 -2
- package/lib/Shared/components/index-comp-layout/index-comp-layout.component.d.ts +1 -1
- package/lib/Shared/components/page-template/page-template.component.d.ts +1 -1
- package/lib/Shared/components/table-plain/table-base.component.d.ts +4 -2
- package/lib/Shared/components/table-plain/table-plain.service.d.ts +4 -0
- package/lib/Shared/components/text-case-2/text-case-2.component.d.ts +4 -4
- package/lib/Shared/prototypes/prototypes.d.ts +14 -3
- package/package.json +1 -1
|
@@ -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
|
|
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; }; "
|
|
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>
|
|
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
|
|
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
|
-
|
|
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<
|
|
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 |
|
|
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
|
|
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; }; "
|
|
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
|
|
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<
|
|
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
|
-
|
|
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
|