imm-element-ui 1.7.8 → 1.7.9
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.
|
@@ -65,12 +65,11 @@ const _gridUtils = {
|
|
|
65
65
|
const textWidth = gridUtils.getLangWidth(headerName);
|
|
66
66
|
const totalWidth = textWidth + 16 + 48;
|
|
67
67
|
let minWidth = item.minWidth;
|
|
68
|
+
item.headerName = headerName;
|
|
68
69
|
if (currentLang != 'zh-CN') {
|
|
69
70
|
minWidth = totalWidth > item.minWidth ? totalWidth : item.minWidth;
|
|
70
|
-
item.headerName = headerName;
|
|
71
71
|
item.minWidth = minWidth;
|
|
72
72
|
}
|
|
73
|
-
// cols = { ...item, headerName,minWidth };
|
|
74
73
|
// delete cols.i18nKey;
|
|
75
74
|
}
|
|
76
75
|
// columnDefs.push(cols);
|
|
@@ -146,4 +145,4 @@ export const gridUtils = {
|
|
|
146
145
|
mergeOptions: _gridUtils.mergeOptions,
|
|
147
146
|
getLangWidth: _gridUtils.getLangWidth
|
|
148
147
|
};
|
|
149
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-utils.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/grid/grid-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { $dt } from '@primeng/themes';\r\nimport { themeQuartz } from 'ag-grid-enterprise';\r\nimport { ThemeConfigService } from '../service/themeConfig.service';\r\nimport { AG_GRID_LOCALE_CN, AG_GRID_LOCALE_EN } from '@ag-grid-community/locale';\r\nimport { filterObjectByKeys } from '../share/utils';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { GridOptions } from './grid/grid.component';\r\nimport { ActionService } from '../service/action.service';\r\n\r\nconst _gridUtils = {\r\n\tcalcRowIds: (api: any, isServerSide: boolean): any[] => {\r\n\t\tconst result: any[] = [];\r\n\t\tapi.forEachNode((node: any) => {\r\n\t\t\tnode.isSelected() && result.push(node.data);\r\n\t\t});\r\n\t\treturn result;\r\n\t},\r\n\tselectionHandler: (api: any, selectionKeys: any[], startRow: number, dataKey?: string) => {\r\n\t\tconst field = dataKey || 'id';\r\n\t\tfor (let i = startRow; i < api.getDisplayedRowCount(); i++) {\r\n\t\t\tconst node = api.getDisplayedRowAtIndex(i);\r\n\t\t\tif (node.data && selectionKeys?.includes(node.data[field])) {\r\n\t\t\t\tnode.setSelected(true, false);\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n\tcalcGridHeight(rowCount: number, margin: number) {\r\n\t\tconst headerHeight = 49;\r\n\t\tconst rowHeight = 42;\r\n\t\tconst totalHeight = headerHeight + rowCount * rowHeight + margin;\r\n\t\treturn Math.max(totalHeight, headerHeight + rowHeight + margin);\r\n\t},\r\n\tgetTheme(themeConfig: ThemeConfigService) {\r\n\t\tconst primary = themeConfig.appState()?.primary as string;\r\n\t\treturn themeQuartz.withParams({\r\n\t\t\taccentColor: primary,\r\n\t\t\tselectedRowBackgroundColor: $dt(`${primary}.50`).value,\r\n\t\t\tcheckboxCheckedBackgroundColor: $dt(`${primary}.500`).value,\r\n\t\t\trowHoverColor: $dt(`${primary}.50`).value,\r\n\t\t\trangeSelectionBackgroundColor: $dt(`${primary}.100`).value,\r\n\t\t\trangeSelectionBorderColor: $dt(`${primary}.100`).value,\r\n\t\t\twrapperBorderRadius: 0,\r\n\t\t});\r\n\t},\r\n\t// ag-grid 本地国际化 官方无泰文翻译包 目前暂用英文 后续需要再翻译\r\n\tgetLocalText(local: string) {\r\n\t\tlet localeText;\r\n\t\tswitch (local) {\r\n\t\t\tcase 'zh-CN':\r\n\t\t\t\tlocaleText = AG_GRID_LOCALE_CN;\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'en-US':\r\n\t\t\t\tlocaleText = AG_GRID_LOCALE_EN;\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'th-TH':\r\n\t\t\t\tlocaleText = AG_GRID_LOCALE_EN;\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\t'';\r\n\t\t}\r\n\t\treturn localeText;\r\n\t},\r\n\thandleI18nKey(cols: any[], i18n: I18nService) {\r\n\t\t// const columnDefs: any[] = [];\r\n\t\tcols.forEach((item: any) => {\r\n\t\t\t// let cols: any;\r\n\t\t\tif (item.hasOwnProperty('i18nKey')) {\r\n\t\t\t\tlet headerName = i18n.fanyi(item.i18nKey);\r\n\t\t\t\tlet currentLang = i18n.currentLang\r\n\t\t\t\tconst textWidth = gridUtils.getLangWidth(headerName)\r\n\t\t\t\tconst totalWidth = textWidth + 16 + 48;\r\n\t\t\t\tlet  minWidth = item.minWidth\r\n\t\t\t\tif(currentLang != 'zh-CN'){\r\n\t\t\t\t\tminWidth = totalWidth > item.minWidth ? totalWidth : item.minWidth\r\n\t\t\t\t\titem.headerName = headerName\r\n\t\t\t\t\titem.minWidth = minWidth\r\n\t\t\t\t}\r\n\t\t\t\t// cols = { ...item, headerName,minWidth };\r\n\t\t\t\t// delete cols.i18nKey;\r\n\t\t\t}\r\n\t\t\t// columnDefs.push(cols);\r\n\t\t});\r\n\t\treturn cols;\r\n\t},\r\n\tgetTreeOptions(columnDef: any): any {\r\n\t\tconst treeOptions = {\r\n\t\t\ttreeData: true,\r\n\t\t\ttreeDataChildrenField: 'children',\r\n\t\t\trowSelection: {\r\n\t\t\t\tmode: 'multiRow',\r\n\t\t\t},\r\n\t\t\tautoGroupColumnDef: {\r\n\t\t\t\tcellStyle: { color: 'var(--p-form-field-focus-border-color)' },\r\n\t\t\t\tcellRenderer: 'agGroupCellRenderer',\r\n\t\t\t\tcellRendererParams: {\r\n\t\t\t\t\t...columnDef.cellRendererParams,\r\n\t\t\t\t\tinnerRenderer: 'linkRenderer',\r\n\t\t\t\t\tsuppressCount: true,\r\n\t\t\t\t},\r\n\t\t\t\t...filterObjectByKeys(columnDef, ['headerName', 'field', 'minWidth']),\r\n\t\t\t},\r\n\t\t\tisServerSideGroup: (dataItem: any) => {\r\n\t\t\t\treturn !!dataItem.children;\r\n\t\t\t},\r\n\t\t\tgetServerSideGroupKey: (dataItem: any) => {\r\n\t\t\t\treturn dataItem.id;\r\n\t\t\t},\r\n\t\t\tonRowSelected: (event: any, x: any) => {\r\n\t\t\t\tconst node = event.node;\r\n\t\t\t\tif (!node.group) return;\r\n\t\t\t\tnode.childrenAfterGroup.forEach((child: any) => {\r\n\t\t\t\t\tchild.setSelected(node.isSelected(), false);\r\n\t\t\t\t});\r\n\t\t\t},\r\n\t\t};\r\n\t\treturn treeOptions;\r\n\t},\r\n\tmergeOptions(gridOptions: GridOptions, cacheBlockSize: any, action: ActionService): any {\r\n\t\tgridOptions.cacheBlockSize = cacheBlockSize ?? 50;\r\n\t\tif (gridOptions.treeDataField) {\r\n\t\t\tlet columnDef: any = gridOptions.columnDefs?.find((col: any) => col.field == gridOptions.treeDataField);\r\n\t\t\tcolumnDef.hide = true;\r\n\t\t\treturn { ...gridOptions, ..._gridUtils.getTreeOptions(columnDef) };\r\n\t\t}\r\n\t\tif (gridOptions.showIndex) {\r\n\t\t\tgridOptions.columnDefs?.unshift({\r\n\t\t\t\theaderName: '#',\r\n\t\t\t\tvalueGetter: (params) => (params.node?.rowIndex || 0) + 1,\r\n\t\t\t\twidth: 80,\r\n\t\t\t\tminWidth: 80,\r\n\t\t\t\tmaxWidth: 80,\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn { ...gridOptions };\r\n\t},\r\n\tgetLangWidth(text:string,font?:any){\r\n\t\tconst canvas = document.createElement('canvas');\r\n  \tconst context = canvas.getContext('2d');\r\n\t\tcontext!.font = font || getComputedStyle(document.body).font;\r\n\t\treturn context!.measureText(text).width;\r\n\t}\r\n};\r\nexport const gridUtils = {\r\n\tcalcRowIds: _gridUtils.calcRowIds,\r\n\tselectionHandler: _gridUtils.selectionHandler,\r\n\tcalcGridHeight: _gridUtils.calcGridHeight,\r\n\tgetTheme: _gridUtils.getTheme,\r\n\tgetLocalText: _gridUtils.getLocalText,\r\n\thandleI18nKey: _gridUtils.handleI18nKey,\r\n\tmergeOptions: _gridUtils.mergeOptions,\r\n\tgetLangWidth: _gridUtils.getLangWidth\r\n};\r\n"]}
|
|
148
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-utils.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/grid/grid-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { $dt } from '@primeng/themes';\r\nimport { themeQuartz } from 'ag-grid-enterprise';\r\nimport { ThemeConfigService } from '../service/themeConfig.service';\r\nimport { AG_GRID_LOCALE_CN, AG_GRID_LOCALE_EN } from '@ag-grid-community/locale';\r\nimport { filterObjectByKeys } from '../share/utils';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { GridOptions } from './grid/grid.component';\r\nimport { ActionService } from '../service/action.service';\r\n\r\nconst _gridUtils = {\r\n\tcalcRowIds: (api: any, isServerSide: boolean): any[] => {\r\n\t\tconst result: any[] = [];\r\n\t\tapi.forEachNode((node: any) => {\r\n\t\t\tnode.isSelected() && result.push(node.data);\r\n\t\t});\r\n\t\treturn result;\r\n\t},\r\n\tselectionHandler: (api: any, selectionKeys: any[], startRow: number, dataKey?: string) => {\r\n\t\tconst field = dataKey || 'id';\r\n\t\tfor (let i = startRow; i < api.getDisplayedRowCount(); i++) {\r\n\t\t\tconst node = api.getDisplayedRowAtIndex(i);\r\n\t\t\tif (node.data && selectionKeys?.includes(node.data[field])) {\r\n\t\t\t\tnode.setSelected(true, false);\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n\tcalcGridHeight(rowCount: number, margin: number) {\r\n\t\tconst headerHeight = 49;\r\n\t\tconst rowHeight = 42;\r\n\t\tconst totalHeight = headerHeight + rowCount * rowHeight + margin;\r\n\t\treturn Math.max(totalHeight, headerHeight + rowHeight + margin);\r\n\t},\r\n\tgetTheme(themeConfig: ThemeConfigService) {\r\n\t\tconst primary = themeConfig.appState()?.primary as string;\r\n\t\treturn themeQuartz.withParams({\r\n\t\t\taccentColor: primary,\r\n\t\t\tselectedRowBackgroundColor: $dt(`${primary}.50`).value,\r\n\t\t\tcheckboxCheckedBackgroundColor: $dt(`${primary}.500`).value,\r\n\t\t\trowHoverColor: $dt(`${primary}.50`).value,\r\n\t\t\trangeSelectionBackgroundColor: $dt(`${primary}.100`).value,\r\n\t\t\trangeSelectionBorderColor: $dt(`${primary}.100`).value,\r\n\t\t\twrapperBorderRadius: 0,\r\n\t\t});\r\n\t},\r\n\t// ag-grid 本地国际化 官方无泰文翻译包 目前暂用英文 后续需要再翻译\r\n\tgetLocalText(local: string) {\r\n\t\tlet localeText;\r\n\t\tswitch (local) {\r\n\t\t\tcase 'zh-CN':\r\n\t\t\t\tlocaleText = AG_GRID_LOCALE_CN;\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'en-US':\r\n\t\t\t\tlocaleText = AG_GRID_LOCALE_EN;\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'th-TH':\r\n\t\t\t\tlocaleText = AG_GRID_LOCALE_EN;\r\n\t\t\t\tbreak;\r\n\t\t\tdefault:\r\n\t\t\t\t'';\r\n\t\t}\r\n\t\treturn localeText;\r\n\t},\r\n\thandleI18nKey(cols: any[], i18n: I18nService) {\r\n\t\t// const columnDefs: any[] = [];\r\n\t\tcols.forEach((item: any) => {\r\n\t\t\t// let cols: any;\r\n\t\t\tif (item.hasOwnProperty('i18nKey')) {\r\n\t\t\t\tlet headerName = i18n.fanyi(item.i18nKey);\r\n\t\t\t\tlet currentLang = i18n.currentLang\r\n\t\t\t\tconst textWidth = gridUtils.getLangWidth(headerName)\r\n\t\t\t\tconst totalWidth = textWidth + 16 + 48;\r\n\t\t\t\tlet  minWidth = item.minWidth\r\n\t\t\t\titem.headerName = headerName\r\n\t\t\t\tif(currentLang != 'zh-CN'){\r\n\t\t\t\t\tminWidth = totalWidth > item.minWidth ? totalWidth : item.minWidth\r\n\t\t\t\t\titem.minWidth = minWidth\r\n\t\t\t\t}\r\n\t\t\t\t// delete cols.i18nKey;\r\n\t\t\t}\r\n\t\t\t// columnDefs.push(cols);\r\n\t\t});\r\n\t\treturn cols;\r\n\t},\r\n\tgetTreeOptions(columnDef: any): any {\r\n\t\tconst treeOptions = {\r\n\t\t\ttreeData: true,\r\n\t\t\ttreeDataChildrenField: 'children',\r\n\t\t\trowSelection: {\r\n\t\t\t\tmode: 'multiRow',\r\n\t\t\t},\r\n\t\t\tautoGroupColumnDef: {\r\n\t\t\t\tcellStyle: { color: 'var(--p-form-field-focus-border-color)' },\r\n\t\t\t\tcellRenderer: 'agGroupCellRenderer',\r\n\t\t\t\tcellRendererParams: {\r\n\t\t\t\t\t...columnDef.cellRendererParams,\r\n\t\t\t\t\tinnerRenderer: 'linkRenderer',\r\n\t\t\t\t\tsuppressCount: true,\r\n\t\t\t\t},\r\n\t\t\t\t...filterObjectByKeys(columnDef, ['headerName', 'field', 'minWidth']),\r\n\t\t\t},\r\n\t\t\tisServerSideGroup: (dataItem: any) => {\r\n\t\t\t\treturn !!dataItem.children;\r\n\t\t\t},\r\n\t\t\tgetServerSideGroupKey: (dataItem: any) => {\r\n\t\t\t\treturn dataItem.id;\r\n\t\t\t},\r\n\t\t\tonRowSelected: (event: any, x: any) => {\r\n\t\t\t\tconst node = event.node;\r\n\t\t\t\tif (!node.group) return;\r\n\t\t\t\tnode.childrenAfterGroup.forEach((child: any) => {\r\n\t\t\t\t\tchild.setSelected(node.isSelected(), false);\r\n\t\t\t\t});\r\n\t\t\t},\r\n\t\t};\r\n\t\treturn treeOptions;\r\n\t},\r\n\tmergeOptions(gridOptions: GridOptions, cacheBlockSize: any, action: ActionService): any {\r\n\t\tgridOptions.cacheBlockSize = cacheBlockSize ?? 50;\r\n\t\tif (gridOptions.treeDataField) {\r\n\t\t\tlet columnDef: any = gridOptions.columnDefs?.find((col: any) => col.field == gridOptions.treeDataField);\r\n\t\t\tcolumnDef.hide = true;\r\n\t\t\treturn { ...gridOptions, ..._gridUtils.getTreeOptions(columnDef) };\r\n\t\t}\r\n\t\tif (gridOptions.showIndex) {\r\n\t\t\tgridOptions.columnDefs?.unshift({\r\n\t\t\t\theaderName: '#',\r\n\t\t\t\tvalueGetter: (params) => (params.node?.rowIndex || 0) + 1,\r\n\t\t\t\twidth: 80,\r\n\t\t\t\tminWidth: 80,\r\n\t\t\t\tmaxWidth: 80,\r\n\t\t\t});\r\n\t\t}\r\n\t\treturn { ...gridOptions };\r\n\t},\r\n\tgetLangWidth(text:string,font?:any){\r\n\t\tconst canvas = document.createElement('canvas');\r\n  \tconst context = canvas.getContext('2d');\r\n\t\tcontext!.font = font || getComputedStyle(document.body).font;\r\n\t\treturn context!.measureText(text).width;\r\n\t}\r\n};\r\nexport const gridUtils = {\r\n\tcalcRowIds: _gridUtils.calcRowIds,\r\n\tselectionHandler: _gridUtils.selectionHandler,\r\n\tcalcGridHeight: _gridUtils.calcGridHeight,\r\n\tgetTheme: _gridUtils.getTheme,\r\n\tgetLocalText: _gridUtils.getLocalText,\r\n\thandleI18nKey: _gridUtils.handleI18nKey,\r\n\tmergeOptions: _gridUtils.mergeOptions,\r\n\tgetLangWidth: _gridUtils.getLangWidth\r\n};\r\n"]}
|
|
@@ -30,6 +30,7 @@ export class SearchComponent {
|
|
|
30
30
|
effect(() => {
|
|
31
31
|
const columnDefs = this.gridOptions()?.columnDefs;
|
|
32
32
|
this.visible = this.gridOptions()?.showSearch ?? true;
|
|
33
|
+
console.log('mount------');
|
|
33
34
|
this.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);
|
|
34
35
|
this.sortOptions = columnDefs.map((columnDef) => ({ key: columnDef.field, label: columnDef.headerName }));
|
|
35
36
|
}, { allowSignalWrites: true });
|
|
@@ -69,6 +70,10 @@ export class SearchComponent {
|
|
|
69
70
|
}
|
|
70
71
|
ngOnInit() {
|
|
71
72
|
this.i18n.change.subscribe((res) => {
|
|
73
|
+
const columnDefs = this.gridOptions()?.columnDefs;
|
|
74
|
+
this.visible = this.gridOptions()?.showSearch ?? true;
|
|
75
|
+
this.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);
|
|
76
|
+
this.sortOptions = columnDefs.map((columnDef) => ({ key: columnDef.field, label: columnDef.headerName }));
|
|
72
77
|
this.reload = false;
|
|
73
78
|
setTimeout(() => {
|
|
74
79
|
this.reload = true;
|
|
@@ -150,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
150
155
|
type: ViewChild,
|
|
151
156
|
args: ['textPanel']
|
|
152
157
|
}] } });
|
|
153
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search.component.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/search/search/search.component.ts","../../../../../../projects/imm-element-ui/src/lib/search/search/search.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAsB,MAAM,eAAe,CAAC;AAE7G,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;;;;;AA0C1C,MAAM,OAAO,eAAe;IAmB3B,YACS,MAAqB,EACrB,IAAiB;QADjB,WAAM,GAAN,MAAM,CAAe;QACrB,SAAI,GAAJ,IAAI,CAAa;QAjB1B,cAAS,GAAG,KAAK,EAAU,CAAC;QAC5B,gBAAW,GAAG,KAAK,EAAe,CAAC;QACnC,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,SAAS,CAAC,CAAC;gBAAE,OAAO;YACvF,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC;YACrF,OAAO,MAAM,CAAC;QACf,CAAC,CAAC,CAAC;QAGH,eAAU,GAAW,GAAG,CAAC;QACzB,cAAS,GAAG,EAAE,CAAC;QACf,aAAQ,GAAG,KAAK,CAAC;QACjB,YAAO,GAAG,IAAI,CAAC;QACf,WAAM,GAAG,IAAI,CAAC;QAMb,MAAM,CACL,GAAG,EAAE;YACJ,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,EAAE,EAAE,UAAU,CAAC;YAClD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,EAAE,UAAU,IAAI,IAAI,CAAC;YACtD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC,kBAAkB,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YACzE,IAAI,CAAC,WAAW,GAAG,UAAW,CAAC,GAAG,CAAC,CAAC,SAAc,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,SAAS,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;QACjH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC3B,CAAC;QACF,MAAM,CAAC,GAAG,EAAE;YACX,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YACnC,IAAI,SAAS,EAAE,aAAa,EAAE,MAAM,IAAI,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;gBACnE,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,aAAa,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC;YACpH,CAAC;QACF,CAAC,CAAC,CAAC;QACH,MAAM,CACL,GAAG,EAAE;YACJ,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;YAC/C,MAAM,SAAS,GAAG,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,SAAS,CAAC,CAAC;YACjE,IAAI,UAAU,IAAI,SAAS;gBAAE,OAAO;YACpC,IAAI,CAAC,MAAM,CAAC,SAAS,CACpB,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,WAAW,CAAC,cAAc,CAAC,UAAU,CAAE,CAAC,EACnG,SAAS,CACT,CAAC;QACH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC3B,CAAC;QACF,MAAM,CACL,GAAG,EAAE;YACJ,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;YACjD,MAAM,SAAS,GAAG,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,SAAS,CAAC,CAAC;YACjE,IAAI,WAAW,IAAI,SAAS;gBAAE,OAAO;YACrC,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YAC9C,MAAM,GAAG;gBACR,GAAG,MAAM;gBACT,aAAa,EAAE,WAAW,CAAC,oBAAoB,CAAC,WAAW,GAAG,EAAE,EAAE,MAAM,EAAE,aAAa,IAAI,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC;aAChH,CAAC;YACF,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAC1C,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC3B,CAAC;QACF,MAAM,CACL,GAAG,EAAE;YACJ,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;YAC3C,IAAI,QAAQ,KAAK,SAAS;gBAAE,OAAO;YACnC,MAAM,SAAS,GAAG,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,SAAS,CAAC,CAAC;YACjE,IAAI,KAAK,GAAW,QAAQ,CAAC,MAAO,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,QAAS,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACzF,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE,aAAa,IAAI,EAAE,EAAE,KAAK,EAAE,EAAE,SAAS,CAAC,CAAC;QACnH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC3B,CAAC;IACH,CAAC;IAED,QAAQ;QACP,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACvC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,UAAU,CAAC,GAAG,EAAE;gBACf,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACpB,CAAC,EAAE,GAAG,CAAC,CAAC;QACT,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,WAAW;QACV,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;IAED,OAAO,CAAC,KAAU,EAAE,SAAc;QACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QACtC,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QACvC,CAAC;IACF,CAAC;IAED,eAAe,CAAC,KAAU,EAAE,SAAc;QACzC,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACrB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QACxC,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;QACzC,CAAC;IACF,CAAC;IAED,OAAO,CAAC,KAAU,EAAE,SAAc;QACjC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;YACrC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACvB,CAAC;aAAM,CAAC;YACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;YACtC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtB,CAAC;IACF,CAAC;IAED,SAAS,CAAC,KAAU;QACnB,IAAI,CAAC,cAAc,EAAE,CAAC;IACvB,CAAC;IAED,SAAS,CAAC,KAAU;QACnB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC;IAC9E,CAAC;IAED,cAAc;QACb,IAAI,CAAC,IAAI,CAAC,SAAS;YAAE,OAAO;QAC5B,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;QAC3E,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QACvD,MAAM,MAAM,GAAG,aAAa,CAAC,KAAK,GAAG,UAAU,GAAG,IAAI,CAAC;QACvD,IAAI,CAAC,UAAU,GAAG,MAAM,GAAG,IAAI,CAAC;IACjC,CAAC;IAED,oBAAoB,CAAC,KAAa;QACjC,OAAO,IAAI,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/E,CAAC;IAED,kBAAkB,CAAC,KAAa;QAC/B,MAAM,MAAM,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAM,CAAC,CAAC;QACjD,MAAM,MAAM,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;QACvH,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QAC7B,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;IAClC,CAAC;IAED,cAAc,CAAC,KAAU;QACxB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;+GApJW,eAAe;mGAAf,eAAe,2nBCpD5B,ylEAwDA,gpNDRW,WAAW,+mBAAE,iBAAiB,2GAAE,kBAAkB,wHAAE,kBAAkB,+GAAE,aAAa,kDAAE,OAAO;;4FAI5F,eAAe;kBAP3B,SAAS;+BACC,eAAe,cACb,IAAI,WACP,CAAC,WAAW,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,aAAa,EAAE,OAAO,CAAC;4GAK9D,SAAS;sBAAnD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAClB,QAAQ;sBAA9B,SAAS;uBAAC,UAAU;gBACG,SAAS;sBAAhC,SAAS;uBAAC,WAAW","sourcesContent":["import { Component, input, effect, untracked, computed, ViewChild, ElementRef, signal } from '@angular/core';\r\nimport { GridOptions } from '../../grid/grid/grid.component';\r\nimport { PopPanelComponent } from '../pop-panel/pop-panel.component';\r\nimport { TextPanelComponent } from '../text-panel/text-panel.component';\r\nimport { SearchTipComponent } from '../search-tip/search-tip.component';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { ActionService, SortItem } from '../../service/action.service';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { searchUtils } from '../search-utils';\r\nimport { Search, Sort } from '../../am/am.component';\r\nimport { Popover } from 'primeng/popover';\r\nimport { Observable } from 'rxjs';\r\nimport { I18nService } from '../../service/i18n.service';\r\n\r\nexport type SearchType = 'text' | 'list' | 'select' | 'date' | 'number' | 'tree';\r\nexport interface SearchItemOption {\r\n\tkey?: string;\r\n\tlabel?: string;\r\n\tchecked?: boolean;\r\n}\r\nexport interface SearchItem {\r\n\tfield?: string;\r\n\tlabel?: string;\r\n\tselected?: boolean;\r\n\tfilter?: boolean;\r\n\tformat?: string;\r\n\tfilterType?: SearchType;\r\n\toptions?: SearchItemOption[];\r\n\tcascade?: boolean;\r\n\tcascadeKey?: string;\r\n\tmultiple?: boolean;\r\n\tgroup?: boolean;\r\n\tvalue?: any;\r\n\tfrom?: string;\r\n\tto?: string;\r\n\toperator?: string;\r\n\tcascadeFunc?: (value: any) => Observable<SearchItemOption[]>;\r\n\t[propsName: string]: any;\r\n}\r\n\r\nexport interface SearchOptions {\r\n\tsearchItems?: SearchItem[];\r\n\tmodelName?: string;\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-search',\r\n\tstandalone: true,\r\n\timports: [FormsModule, PopPanelComponent, TextPanelComponent, SearchTipComponent, TranslatePipe, Popover],\r\n\ttemplateUrl: './search.component.html',\r\n\tstyleUrl: './search.component.scss',\r\n})\r\nexport class SearchComponent {\r\n\t@ViewChild('searchRef', { static: false }) searchRef!: ElementRef;\r\n\t@ViewChild('popPanel') popPanel!: Popover;\r\n\t@ViewChild('textPanel') textPanel!: Popover;\r\n\tsearchPrm = input<Search>();\r\n\tgridOptions = input<GridOptions>();\r\n\tsearchModel = computed(() => {\r\n\t\tif (!this.action.searchMonitor(untracked(() => this.gridOptions()?.modelName))) return;\r\n\t\tconst search = this.action.getSearch(untracked(() => this.gridOptions()?.modelName));\r\n\t\treturn search;\r\n\t});\r\n\tsearchItems!: SearchItem[];\r\n\tsortOptions!: SearchItemOption[];\r\n\tmarginLeft: string = '0';\r\n\tsearchStr = '';\r\n\tisActive = false;\r\n\tvisible = true;\r\n\treload = true;\r\n\r\n\tconstructor(\r\n\t\tprivate action: ActionService,\r\n\t\tprivate i18n: I18nService,\r\n\t) {\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tconst columnDefs = this.gridOptions()?.columnDefs;\r\n\t\t\t\tthis.visible = this.gridOptions()?.showSearch ?? true;\r\n\t\t\t\tthis.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);\r\n\t\t\t\tthis.sortOptions = columnDefs!.map((columnDef: any) => ({ key: columnDef.field, label: columnDef.headerName }));\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t\teffect(() => {\r\n\t\t\tconst searchPrm = this.searchPrm();\r\n\t\t\tif (searchPrm?.columnFilters?.length || searchPrm?.groups?.length) {\r\n\t\t\t\tthis.action.setSearch({ columnFilters: searchPrm?.columnFilters, groups: searchPrm?.groups }, searchPrm.modelName);\r\n\t\t\t}\r\n\t\t});\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tconst searchItem = this.action.getSearchItem();\r\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\r\n\t\t\t\tif (searchItem == undefined) return;\r\n\t\t\t\tthis.action.setSearch(\r\n\t\t\t\t\tsearchUtils.concatFilter(this.action.getSearch(modelName), searchUtils.transferFilter(searchItem)!),\r\n\t\t\t\t\tmodelName,\r\n\t\t\t\t);\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tconst searchClear = this.action.getSearchClear();\r\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\r\n\t\t\t\tif (searchClear == undefined) return;\r\n\t\t\t\tlet search = this.action.getSearch(modelName);\r\n\t\t\t\tsearch = {\r\n\t\t\t\t\t...search,\r\n\t\t\t\t\tcolumnFilters: searchUtils.cascadeColumnFilters(searchClear + '', search?.columnFilters || [], this.searchItems),\r\n\t\t\t\t};\r\n\t\t\t\tthis.action.setSearch(search, modelName);\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tconst sortItem = this.action.getSortItem();\r\n\t\t\t\tif (sortItem === undefined) return;\r\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\r\n\t\t\t\tlet sorts: Sort[] = sortItem.fields!.map((field) => ({ field, isAsc: sortItem!.isAsc }));\r\n\t\t\t\tthis.action.setSearch({ columnFilters: this.action.getSearch(modelName)?.columnFilters || [], sorts }, modelName);\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t}\r\n\r\n\tngOnInit() {\r\n\t\tthis.i18n.change.subscribe((res: any) => {\r\n\t\t\tthis.reload = false;\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.reload = true;\r\n\t\t\t}, 200);\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.action.clear();\r\n\t}\r\n\r\n\tonFocus(event: any, searchRef: any) {\r\n\t\tthis.isActive = true;\r\n\t\tif (!this.searchStr) {\r\n\t\t\tthis.popPanel.show(event, searchRef);\r\n\t\t} else {\r\n\t\t\tthis.textPanel.show(event, searchRef);\r\n\t\t}\r\n\t}\r\n\r\n\tonDropDownClick(event: any, searchRef: any) {\r\n\t\tthis.isActive = !this.isActive;\r\n\t\tif (!this.searchStr) {\r\n\t\t\tthis.popPanel.toggle(event, searchRef);\r\n\t\t} else {\r\n\t\t\tthis.textPanel.toggle(event, searchRef);\r\n\t\t}\r\n\t}\r\n\r\n\tonInput(event: any, searchRef: any) {\r\n\t\tif (!event.target?.value) {\r\n\t\t\tthis.popPanel.show(event, searchRef);\r\n\t\t\tthis.textPanel.hide();\r\n\t\t} else {\r\n\t\t\tthis.textPanel.show(event, searchRef);\r\n\t\t\tthis.popPanel.hide();\r\n\t\t}\r\n\t}\r\n\r\n\tonPopShow(event: any) {\r\n\t\tthis.calcMarginLeft();\r\n\t}\r\n\r\n\tonPopHide(event: any) {\r\n\t\tthis.isActive = this.popPanel.overlayVisible || this.popPanel.overlayVisible;\r\n\t}\r\n\r\n\tcalcMarginLeft() {\r\n\t\tif (!this.searchRef) return;\r\n\t\tconst searchRefRect = this.searchRef.nativeElement.getBoundingClientRect();\r\n\t\tconst panelWidth = window.innerWidth > 768 ? 535 : 305;\r\n\t\tconst offset = searchRefRect.width - panelWidth - 23.5;\r\n\t\tthis.marginLeft = offset + 'px';\r\n\t}\r\n\r\n\tgetSearchItemByField(field: string) {\r\n\t\treturn this.searchItems?.filter((searchItem) => searchItem.field == field)[0];\r\n\t}\r\n\r\n\tgetSortItemBySorts(sorts: Sort[]): SortItem | undefined {\r\n\t\tconst fields = sorts?.map((sort) => sort.field!);\r\n\t\tconst labels = sorts?.map((sort) => this.sortOptions?.find((sortOption) => sortOption.key == sort.field)?.label || '');\r\n\t\tconst isAsc = sorts[0].isAsc;\r\n\t\treturn { fields, labels, isAsc };\r\n\t}\r\n\r\n\tonStrItemClick(event: any) {\r\n\t\tthis.isActive = false;\r\n\t\tthis.searchStr = '';\r\n\t\tthis.textPanel.hide();\r\n\t}\r\n}\r\n","@if (visible && reload) {\r\n\t<div\r\n\t\t#searchRef\r\n\t\tclass=\"s-main\">\r\n\t\t<div [class]=\"'flex items-center s-container ' + (isActive ? 's-active' : 's-unactive')\">\r\n\t\t\t<span class=\"flex-none s-search pi pi-search\"></span>\r\n\t\t\t<div class=\"flex-1 flex items-center content-center flex-wrap\">\r\n\t\t\t\t@for (columnFilter of searchModel()?.columnFilters; track columnFilter) {\r\n\t\t\t\t\t<search-tip\r\n\t\t\t\t\t\t[columnFilter]=\"columnFilter\"\r\n\t\t\t\t\t\t[searchItem]=\"getSearchItemByField(columnFilter.columnField!)\"></search-tip>\r\n\t\t\t\t}\r\n\t\t\t\t@if (searchModel()?.sorts?.length) {\r\n\t\t\t\t\t<search-tip\r\n\t\t\t\t\t\t[sorts]=\"searchModel()?.sorts\"\r\n\t\t\t\t\t\t[sortItem]=\"getSortItemBySorts(searchModel()?.sorts!)\"></search-tip>\r\n\t\t\t\t}\r\n\t\t\t\t<div class=\"flex-1\">\r\n\t\t\t\t\t<input\r\n\t\t\t\t\t\ttype=\"text\"\r\n\t\t\t\t\t\tclass=\"s-input\"\r\n\t\t\t\t\t\t[placeholder]=\"'search.search' | translate\"\r\n\t\t\t\t\t\t[(ngModel)]=\"searchStr\"\r\n\t\t\t\t\t\t(focus)=\"onFocus($event, searchRef)\"\r\n\t\t\t\t\t\t(input)=\"onInput($event, searchRef)\" />\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div\r\n\t\t\t[class]=\"'s-dropdown ' + (isActive ? 's-active' : 's-unactive')\"\r\n\t\t\t(click)=\"onDropDownClick($event, searchRef)\">\r\n\t\t\t<span [class]=\"'s-dropdown-icon pi pi-chevron-' + (isActive ? 'up' : 'down')\"></span>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<p-popover\r\n\t\t[style]=\"{ marginLeft, maxHeight: '75vh', overflowY: 'scroll' }\"\r\n\t\t(onShow)=\"onPopShow($event)\"\r\n\t\t(onHide)=\"onPopHide($event)\"\r\n\t\t#popPanel>\r\n\t\t<pop-panel\r\n\t\t\t[searchItems]=\"searchItems\"\r\n\t\t\t[sortOptions]=\"sortOptions\"\r\n\t\t\t[modelName]=\"gridOptions()?.modelName\"></pop-panel>\r\n\t</p-popover>\r\n\r\n\t<p-popover\r\n\t\t[style]=\"{ maxHeight: '75vh', overflowY: 'scroll' }\"\r\n\t\t(onHide)=\"onPopHide($event)\"\r\n\t\t#textPanel>\r\n\t\t<text-panel\r\n\t\t\t[searchItems]=\"searchItems\"\r\n\t\t\t[searchStr]=\"searchStr\"\r\n\t\t\t(strItemClick)=\"onStrItemClick($event)\"></text-panel>\r\n\t</p-popover>\r\n}\r\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search.component.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/search/search/search.component.ts","../../../../../../projects/imm-element-ui/src/lib/search/search/search.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, input, effect, untracked, computed, ViewChild, ElementRef, signal } from '@angular/core';\r\nimport { GridOptions } from '../../grid/grid/grid.component';\r\nimport { PopPanelComponent } from '../pop-panel/pop-panel.component';\r\nimport { TextPanelComponent } from '../text-panel/text-panel.component';\r\nimport { SearchTipComponent } from '../search-tip/search-tip.component';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { ActionService, SortItem } from '../../service/action.service';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { searchUtils } from '../search-utils';\r\nimport { Search, Sort } from '../../am/am.component';\r\nimport { Popover } from 'primeng/popover';\r\nimport { Observable } from 'rxjs';\r\nimport { I18nService } from '../../service/i18n.service';\r\n\r\nexport type SearchType = 'text' | 'list' | 'select' | 'date' | 'number' | 'tree';\r\nexport interface SearchItemOption {\r\n\tkey?: string;\r\n\tlabel?: string;\r\n\tchecked?: boolean;\r\n}\r\nexport interface SearchItem {\r\n\tfield?: string;\r\n\tlabel?: string;\r\n\tselected?: boolean;\r\n\tfilter?: boolean;\r\n\tformat?: string;\r\n\tfilterType?: SearchType;\r\n\toptions?: SearchItemOption[];\r\n\tcascade?: boolean;\r\n\tcascadeKey?: string;\r\n\tmultiple?: boolean;\r\n\tgroup?: boolean;\r\n\tvalue?: any;\r\n\tfrom?: string;\r\n\tto?: string;\r\n\toperator?: string;\r\n\tcascadeFunc?: (value: any) => Observable<SearchItemOption[]>;\r\n\t[propsName: string]: any;\r\n}\r\n\r\nexport interface SearchOptions {\r\n\tsearchItems?: SearchItem[];\r\n\tmodelName?: string;\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-search',\r\n\tstandalone: true,\r\n\timports: [FormsModule, PopPanelComponent, TextPanelComponent, SearchTipComponent, TranslatePipe, Popover],\r\n\ttemplateUrl: './search.component.html',\r\n\tstyleUrl: './search.component.scss',\r\n})\r\nexport class SearchComponent {\r\n\t@ViewChild('searchRef', { static: false }) searchRef!: ElementRef;\r\n\t@ViewChild('popPanel') popPanel!: Popover;\r\n\t@ViewChild('textPanel') textPanel!: Popover;\r\n\tsearchPrm = input<Search>();\r\n\tgridOptions = input<GridOptions>();\r\n\tsearchModel = computed(() => {\r\n\t\tif (!this.action.searchMonitor(untracked(() => this.gridOptions()?.modelName))) return;\r\n\t\tconst search = this.action.getSearch(untracked(() => this.gridOptions()?.modelName));\r\n\t\treturn search;\r\n\t});\r\n\tsearchItems!: SearchItem[];\r\n\tsortOptions!: SearchItemOption[];\r\n\tmarginLeft: string = '0';\r\n\tsearchStr = '';\r\n\tisActive = false;\r\n\tvisible = true;\r\n\treload = true;\r\n\r\n\tconstructor(\r\n\t\tprivate action: ActionService,\r\n\t\tprivate i18n: I18nService,\r\n\t) {\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tconst columnDefs = this.gridOptions()?.columnDefs;\r\n\t\t\t\tthis.visible = this.gridOptions()?.showSearch ?? true;\r\n\t\t\t\tconsole.log('mount------')\r\n\t\t\t\tthis.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);\r\n\t\t\t\tthis.sortOptions = columnDefs!.map((columnDef: any) => ({ key: columnDef.field, label: columnDef.headerName }));\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t\teffect(() => {\r\n\t\t\tconst searchPrm = this.searchPrm();\r\n\t\t\tif (searchPrm?.columnFilters?.length || searchPrm?.groups?.length) {\r\n\t\t\t\tthis.action.setSearch({ columnFilters: searchPrm?.columnFilters, groups: searchPrm?.groups }, searchPrm.modelName);\r\n\t\t\t}\r\n\t\t});\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tconst searchItem = this.action.getSearchItem();\r\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\r\n\t\t\t\tif (searchItem == undefined) return;\r\n\t\t\t\tthis.action.setSearch(\r\n\t\t\t\t\tsearchUtils.concatFilter(this.action.getSearch(modelName), searchUtils.transferFilter(searchItem)!),\r\n\t\t\t\t\tmodelName,\r\n\t\t\t\t);\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tconst searchClear = this.action.getSearchClear();\r\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\r\n\t\t\t\tif (searchClear == undefined) return;\r\n\t\t\t\tlet search = this.action.getSearch(modelName);\r\n\t\t\t\tsearch = {\r\n\t\t\t\t\t...search,\r\n\t\t\t\t\tcolumnFilters: searchUtils.cascadeColumnFilters(searchClear + '', search?.columnFilters || [], this.searchItems),\r\n\t\t\t\t};\r\n\t\t\t\tthis.action.setSearch(search, modelName);\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tconst sortItem = this.action.getSortItem();\r\n\t\t\t\tif (sortItem === undefined) return;\r\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\r\n\t\t\t\tlet sorts: Sort[] = sortItem.fields!.map((field) => ({ field, isAsc: sortItem!.isAsc }));\r\n\t\t\t\tthis.action.setSearch({ columnFilters: this.action.getSearch(modelName)?.columnFilters || [], sorts }, modelName);\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t}\r\n\r\n\tngOnInit() {\r\n\t\tthis.i18n.change.subscribe((res: any) => {\r\n\t\t\tconst columnDefs = this.gridOptions()?.columnDefs;\r\n\t\t\tthis.visible = this.gridOptions()?.showSearch ?? true;\r\n\t\t\tthis.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);\r\n\t\t\tthis.sortOptions = columnDefs!.map((columnDef: any) => ({ key: columnDef.field, label: columnDef.headerName }));\r\n\t\t\tthis.reload = false;\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.reload = true;\r\n\t\t\t}, 200);\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.action.clear();\r\n\t}\r\n\r\n\tonFocus(event: any, searchRef: any) {\r\n\t\tthis.isActive = true;\r\n\t\tif (!this.searchStr) {\r\n\t\t\tthis.popPanel.show(event, searchRef);\r\n\t\t} else {\r\n\t\t\tthis.textPanel.show(event, searchRef);\r\n\t\t}\r\n\t}\r\n\r\n\tonDropDownClick(event: any, searchRef: any) {\r\n\t\tthis.isActive = !this.isActive;\r\n\t\tif (!this.searchStr) {\r\n\t\t\tthis.popPanel.toggle(event, searchRef);\r\n\t\t} else {\r\n\t\t\tthis.textPanel.toggle(event, searchRef);\r\n\t\t}\r\n\t}\r\n\r\n\tonInput(event: any, searchRef: any) {\r\n\t\tif (!event.target?.value) {\r\n\t\t\tthis.popPanel.show(event, searchRef);\r\n\t\t\tthis.textPanel.hide();\r\n\t\t} else {\r\n\t\t\tthis.textPanel.show(event, searchRef);\r\n\t\t\tthis.popPanel.hide();\r\n\t\t}\r\n\t}\r\n\r\n\tonPopShow(event: any) {\r\n\t\tthis.calcMarginLeft();\r\n\t}\r\n\r\n\tonPopHide(event: any) {\r\n\t\tthis.isActive = this.popPanel.overlayVisible || this.popPanel.overlayVisible;\r\n\t}\r\n\r\n\tcalcMarginLeft() {\r\n\t\tif (!this.searchRef) return;\r\n\t\tconst searchRefRect = this.searchRef.nativeElement.getBoundingClientRect();\r\n\t\tconst panelWidth = window.innerWidth > 768 ? 535 : 305;\r\n\t\tconst offset = searchRefRect.width - panelWidth - 23.5;\r\n\t\tthis.marginLeft = offset + 'px';\r\n\t}\r\n\r\n\tgetSearchItemByField(field: string) {\r\n\t\treturn this.searchItems?.filter((searchItem) => searchItem.field == field)[0];\r\n\t}\r\n\r\n\tgetSortItemBySorts(sorts: Sort[]): SortItem | undefined {\r\n\t\tconst fields = sorts?.map((sort) => sort.field!);\r\n\t\tconst labels = sorts?.map((sort) => this.sortOptions?.find((sortOption) => sortOption.key == sort.field)?.label || '');\r\n\t\tconst isAsc = sorts[0].isAsc;\r\n\t\treturn { fields, labels, isAsc };\r\n\t}\r\n\r\n\tonStrItemClick(event: any) {\r\n\t\tthis.isActive = false;\r\n\t\tthis.searchStr = '';\r\n\t\tthis.textPanel.hide();\r\n\t}\r\n}\r\n","@if (visible && reload) {\r\n\t<div\r\n\t\t#searchRef\r\n\t\tclass=\"s-main\">\r\n\t\t<div [class]=\"'flex items-center s-container ' + (isActive ? 's-active' : 's-unactive')\">\r\n\t\t\t<span class=\"flex-none s-search pi pi-search\"></span>\r\n\t\t\t<div class=\"flex-1 flex items-center content-center flex-wrap\">\r\n\t\t\t\t@for (columnFilter of searchModel()?.columnFilters; track columnFilter) {\r\n\t\t\t\t\t<search-tip\r\n\t\t\t\t\t\t[columnFilter]=\"columnFilter\"\r\n\t\t\t\t\t\t[searchItem]=\"getSearchItemByField(columnFilter.columnField!)\"></search-tip>\r\n\t\t\t\t}\r\n\t\t\t\t@if (searchModel()?.sorts?.length) {\r\n\t\t\t\t\t<search-tip\r\n\t\t\t\t\t\t[sorts]=\"searchModel()?.sorts\"\r\n\t\t\t\t\t\t[sortItem]=\"getSortItemBySorts(searchModel()?.sorts!)\"></search-tip>\r\n\t\t\t\t}\r\n\t\t\t\t<div class=\"flex-1\">\r\n\t\t\t\t\t<input\r\n\t\t\t\t\t\ttype=\"text\"\r\n\t\t\t\t\t\tclass=\"s-input\"\r\n\t\t\t\t\t\t[placeholder]=\"'search.search' | translate\"\r\n\t\t\t\t\t\t[(ngModel)]=\"searchStr\"\r\n\t\t\t\t\t\t(focus)=\"onFocus($event, searchRef)\"\r\n\t\t\t\t\t\t(input)=\"onInput($event, searchRef)\" />\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t\t<div\r\n\t\t\t[class]=\"'s-dropdown ' + (isActive ? 's-active' : 's-unactive')\"\r\n\t\t\t(click)=\"onDropDownClick($event, searchRef)\">\r\n\t\t\t<span [class]=\"'s-dropdown-icon pi pi-chevron-' + (isActive ? 'up' : 'down')\"></span>\r\n\t\t</div>\r\n\t</div>\r\n\r\n\t<p-popover\r\n\t\t[style]=\"{ marginLeft, maxHeight: '75vh', overflowY: 'scroll' }\"\r\n\t\t(onShow)=\"onPopShow($event)\"\r\n\t\t(onHide)=\"onPopHide($event)\"\r\n\t\t#popPanel>\r\n\t\t<pop-panel\r\n\t\t\t[searchItems]=\"searchItems\"\r\n\t\t\t[sortOptions]=\"sortOptions\"\r\n\t\t\t[modelName]=\"gridOptions()?.modelName\"></pop-panel>\r\n\t</p-popover>\r\n\r\n\t<p-popover\r\n\t\t[style]=\"{ maxHeight: '75vh', overflowY: 'scroll' }\"\r\n\t\t(onHide)=\"onPopHide($event)\"\r\n\t\t#textPanel>\r\n\t\t<text-panel\r\n\t\t\t[searchItems]=\"searchItems\"\r\n\t\t\t[searchStr]=\"searchStr\"\r\n\t\t\t(strItemClick)=\"onStrItemClick($event)\"></text-panel>\r\n\t</p-popover>\r\n}\r\n"]}
|
|
@@ -4592,12 +4592,11 @@ const _gridUtils = {
|
|
|
4592
4592
|
const textWidth = gridUtils.getLangWidth(headerName);
|
|
4593
4593
|
const totalWidth = textWidth + 16 + 48;
|
|
4594
4594
|
let minWidth = item.minWidth;
|
|
4595
|
+
item.headerName = headerName;
|
|
4595
4596
|
if (currentLang != 'zh-CN') {
|
|
4596
4597
|
minWidth = totalWidth > item.minWidth ? totalWidth : item.minWidth;
|
|
4597
|
-
item.headerName = headerName;
|
|
4598
4598
|
item.minWidth = minWidth;
|
|
4599
4599
|
}
|
|
4600
|
-
// cols = { ...item, headerName,minWidth };
|
|
4601
4600
|
// delete cols.i18nKey;
|
|
4602
4601
|
}
|
|
4603
4602
|
// columnDefs.push(cols);
|
|
@@ -7051,6 +7050,7 @@ class SearchComponent {
|
|
|
7051
7050
|
effect(() => {
|
|
7052
7051
|
const columnDefs = this.gridOptions()?.columnDefs;
|
|
7053
7052
|
this.visible = this.gridOptions()?.showSearch ?? true;
|
|
7053
|
+
console.log('mount------');
|
|
7054
7054
|
this.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);
|
|
7055
7055
|
this.sortOptions = columnDefs.map((columnDef) => ({ key: columnDef.field, label: columnDef.headerName }));
|
|
7056
7056
|
}, { allowSignalWrites: true });
|
|
@@ -7090,6 +7090,10 @@ class SearchComponent {
|
|
|
7090
7090
|
}
|
|
7091
7091
|
ngOnInit() {
|
|
7092
7092
|
this.i18n.change.subscribe((res) => {
|
|
7093
|
+
const columnDefs = this.gridOptions()?.columnDefs;
|
|
7094
|
+
this.visible = this.gridOptions()?.showSearch ?? true;
|
|
7095
|
+
this.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);
|
|
7096
|
+
this.sortOptions = columnDefs.map((columnDef) => ({ key: columnDef.field, label: columnDef.headerName }));
|
|
7093
7097
|
this.reload = false;
|
|
7094
7098
|
setTimeout(() => {
|
|
7095
7099
|
this.reload = true;
|