imm-element-ui 1.3.8 → 1.4.0

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.
@@ -30,7 +30,7 @@ export class SearchComponent {
30
30
  effect(() => {
31
31
  const columnDefs = this.gridOptions()?.columnDefs;
32
32
  this.visible = this.gridOptions()?.showSearch ?? true;
33
- this.searchItems = searchUtils.extractSearchItems(columnDefs);
33
+ this.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);
34
34
  this.sortOptions = columnDefs.map((columnDef) => ({ key: columnDef.field, label: columnDef.headerName }));
35
35
  }, { allowSignalWrites: true });
36
36
  effect(() => {
@@ -150,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
150
150
  type: ViewChild,
151
151
  args: ['textPanel']
152
152
  }] } });
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,CAAC,CAAC;YAC9D,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,y+DAwDA,yoNDRW,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';\nimport { GridOptions } from '../../grid/grid/grid.component';\nimport { PopPanelComponent } from '../pop-panel/pop-panel.component';\nimport { TextPanelComponent } from '../text-panel/text-panel.component';\nimport { SearchTipComponent } from '../search-tip/search-tip.component';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { ActionService, SortItem } from '../../service/action.service';\nimport { FormsModule } from '@angular/forms';\nimport { searchUtils } from '../search-utils';\nimport { Search, Sort } from '../../am/am.component';\nimport { Popover } from 'primeng/popover';\nimport { Observable } from 'rxjs';\nimport { I18nService } from '../../service/i18n.service';\n\nexport type SearchType = 'text' | 'list' | 'select' | 'date' | 'number' | 'tree';\nexport interface SearchItemOption {\n\tkey?: string;\n\tlabel?: string;\n\tchecked?: boolean;\n}\nexport interface SearchItem {\n\tfield?: string;\n\tlabel?: string;\n\tselected?: boolean;\n\tfilter?: boolean;\n\tformat?: string;\n\tfilterType?: SearchType;\n\toptions?: SearchItemOption[];\n\tcascade?: boolean;\n\tcascadeKey?: string;\n\tmultiple?: boolean;\n\tgroup?: boolean;\n\tvalue?: any;\n\tfrom?: string;\n\tto?: string;\n\toperator?: string;\n\tcascadeFunc?: (value: any) => Observable<SearchItemOption[]>;\n\t[propsName: string]: any;\n}\n\nexport interface SearchOptions {\n\tsearchItems?: SearchItem[];\n\tmodelName?: string;\n}\n\n@Component({\n\tselector: 'custom-search',\n\tstandalone: true,\n\timports: [FormsModule, PopPanelComponent, TextPanelComponent, SearchTipComponent, TranslatePipe, Popover],\n\ttemplateUrl: './search.component.html',\n\tstyleUrl: './search.component.scss',\n})\nexport class SearchComponent {\n\t@ViewChild('searchRef', { static: false }) searchRef!: ElementRef;\n\t@ViewChild('popPanel') popPanel!: Popover;\n\t@ViewChild('textPanel') textPanel!: Popover;\n\tsearchPrm = input<Search>();\n\tgridOptions = input<GridOptions>();\n\tsearchModel = computed(() => {\n\t\tif (!this.action.searchMonitor(untracked(() => this.gridOptions()?.modelName))) return;\n\t\tconst search = this.action.getSearch(untracked(() => this.gridOptions()?.modelName));\n\t\treturn search;\n\t});\n\tsearchItems!: SearchItem[];\n\tsortOptions!: SearchItemOption[];\n\tmarginLeft: string = '0';\n\tsearchStr = '';\n\tisActive = false;\n\tvisible = true;\n\treload = true;\n\n\tconstructor(\n\t\tprivate action: ActionService,\n\t\tprivate i18n: I18nService,\n\t) {\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst columnDefs = this.gridOptions()?.columnDefs;\n\t\t\t\tthis.visible = this.gridOptions()?.showSearch ?? true;\n\t\t\t\tthis.searchItems = searchUtils.extractSearchItems(columnDefs);\n\t\t\t\tthis.sortOptions = columnDefs!.map((columnDef: any) => ({ key: columnDef.field, label: columnDef.headerName }));\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t\teffect(() => {\n\t\t\tconst searchPrm = this.searchPrm();\n\t\t\tif (searchPrm?.columnFilters?.length || searchPrm?.groups?.length) {\n\t\t\t\tthis.action.setSearch({ columnFilters: searchPrm?.columnFilters, groups: searchPrm?.groups }, searchPrm.modelName);\n\t\t\t}\n\t\t});\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst searchItem = this.action.getSearchItem();\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\n\t\t\t\tif (searchItem == undefined) return;\n\t\t\t\tthis.action.setSearch(\n\t\t\t\t\tsearchUtils.concatFilter(this.action.getSearch(modelName), searchUtils.transferFilter(searchItem)!),\n\t\t\t\t\tmodelName,\n\t\t\t\t);\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst searchClear = this.action.getSearchClear();\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\n\t\t\t\tif (searchClear == undefined) return;\n\t\t\t\tlet search = this.action.getSearch(modelName);\n\t\t\t\tsearch = {\n\t\t\t\t\t...search,\n\t\t\t\t\tcolumnFilters: searchUtils.cascadeColumnFilters(searchClear + '', search?.columnFilters || [], this.searchItems),\n\t\t\t\t};\n\t\t\t\tthis.action.setSearch(search, modelName);\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst sortItem = this.action.getSortItem();\n\t\t\t\tif (sortItem === undefined) return;\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\n\t\t\t\tlet sorts: Sort[] = sortItem.fields!.map((field) => ({ field, isAsc: sortItem!.isAsc }));\n\t\t\t\tthis.action.setSearch({ columnFilters: this.action.getSearch(modelName)?.columnFilters || [], sorts }, modelName);\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t}\n\n\tngOnInit() {\n\t\tthis.i18n.change.subscribe((res: any) => {\n\t\t\tthis.reload = false;\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.reload = true;\n\t\t\t}, 200);\n\t\t});\n\t}\n\n\tngOnDestroy() {\n\t\tthis.action.clear();\n\t}\n\n\tonFocus(event: any, searchRef: any) {\n\t\tthis.isActive = true;\n\t\tif (!this.searchStr) {\n\t\t\tthis.popPanel.show(event, searchRef);\n\t\t} else {\n\t\t\tthis.textPanel.show(event, searchRef);\n\t\t}\n\t}\n\n\tonDropDownClick(event: any, searchRef: any) {\n\t\tthis.isActive = !this.isActive;\n\t\tif (!this.searchStr) {\n\t\t\tthis.popPanel.toggle(event, searchRef);\n\t\t} else {\n\t\t\tthis.textPanel.toggle(event, searchRef);\n\t\t}\n\t}\n\n\tonInput(event: any, searchRef: any) {\n\t\tif (!event.target?.value) {\n\t\t\tthis.popPanel.show(event, searchRef);\n\t\t\tthis.textPanel.hide();\n\t\t} else {\n\t\t\tthis.textPanel.show(event, searchRef);\n\t\t\tthis.popPanel.hide();\n\t\t}\n\t}\n\n\tonPopShow(event: any) {\n\t\tthis.calcMarginLeft();\n\t}\n\n\tonPopHide(event: any) {\n\t\tthis.isActive = this.popPanel.overlayVisible || this.popPanel.overlayVisible;\n\t}\n\n\tcalcMarginLeft() {\n\t\tif (!this.searchRef) return;\n\t\tconst searchRefRect = this.searchRef.nativeElement.getBoundingClientRect();\n\t\tconst panelWidth = window.innerWidth > 768 ? 535 : 305;\n\t\tconst offset = searchRefRect.width - panelWidth - 23.5;\n\t\tthis.marginLeft = offset + 'px';\n\t}\n\n\tgetSearchItemByField(field: string) {\n\t\treturn this.searchItems?.filter((searchItem) => searchItem.field == field)[0];\n\t}\n\n\tgetSortItemBySorts(sorts: Sort[]): SortItem | undefined {\n\t\tconst fields = sorts?.map((sort) => sort.field!);\n\t\tconst labels = sorts?.map((sort) => this.sortOptions?.find((sortOption) => sortOption.key == sort.field)?.label || '');\n\t\tconst isAsc = sorts[0].isAsc;\n\t\treturn { fields, labels, isAsc };\n\t}\n\n\tonStrItemClick(event: any) {\n\t\tthis.isActive = false;\n\t\tthis.searchStr = '';\n\t\tthis.textPanel.hide();\n\t}\n}\n","@if (visible && reload) {\n\t<div\n\t\t#searchRef\n\t\tclass=\"s-main\">\n\t\t<div [class]=\"'flex items-center s-container ' + (isActive ? 's-active' : 's-unactive')\">\n\t\t\t<span class=\"flex-none s-search pi pi-search\"></span>\n\t\t\t<div class=\"flex-1 flex items-center content-center flex-wrap\">\n\t\t\t\t@for (columnFilter of searchModel()?.columnFilters; track columnFilter) {\n\t\t\t\t\t<search-tip\n\t\t\t\t\t\t[columnFilter]=\"columnFilter\"\n\t\t\t\t\t\t[searchItem]=\"getSearchItemByField(columnFilter.columnField!)\"></search-tip>\n\t\t\t\t}\n\t\t\t\t@if (searchModel()?.sorts?.length) {\n\t\t\t\t\t<search-tip\n\t\t\t\t\t\t[sorts]=\"searchModel()?.sorts\"\n\t\t\t\t\t\t[sortItem]=\"getSortItemBySorts(searchModel()?.sorts!)\"></search-tip>\n\t\t\t\t}\n\t\t\t\t<div class=\"flex-1\">\n\t\t\t\t\t<input\n\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\tclass=\"s-input\"\n\t\t\t\t\t\t[placeholder]=\"'search.search' | translate\"\n\t\t\t\t\t\t[(ngModel)]=\"searchStr\"\n\t\t\t\t\t\t(focus)=\"onFocus($event, searchRef)\"\n\t\t\t\t\t\t(input)=\"onInput($event, searchRef)\" />\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div\n\t\t\t[class]=\"'s-dropdown ' + (isActive ? 's-active' : 's-unactive')\"\n\t\t\t(click)=\"onDropDownClick($event, searchRef)\">\n\t\t\t<span [class]=\"'s-dropdown-icon pi pi-chevron-' + (isActive ? 'up' : 'down')\"></span>\n\t\t</div>\n\t</div>\n\n\t<p-popover\n\t\t[style]=\"{ marginLeft, maxHeight: '75vh', overflowY: 'scroll' }\"\n\t\t(onShow)=\"onPopShow($event)\"\n\t\t(onHide)=\"onPopHide($event)\"\n\t\t#popPanel>\n\t\t<pop-panel\n\t\t\t[searchItems]=\"searchItems\"\n\t\t\t[sortOptions]=\"sortOptions\"\n\t\t\t[modelName]=\"gridOptions()?.modelName\"></pop-panel>\n\t</p-popover>\n\n\t<p-popover\n\t\t[style]=\"{ maxHeight: '75vh', overflowY: 'scroll' }\"\n\t\t(onHide)=\"onPopHide($event)\"\n\t\t#textPanel>\n\t\t<text-panel\n\t\t\t[searchItems]=\"searchItems\"\n\t\t\t[searchStr]=\"searchStr\"\n\t\t\t(strItemClick)=\"onStrItemClick($event)\"></text-panel>\n\t</p-popover>\n}\n"]}
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":"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","sourcesContent":["import { Component, input, effect, untracked, computed, ViewChild, ElementRef, signal } from '@angular/core';\nimport { GridOptions } from '../../grid/grid/grid.component';\nimport { PopPanelComponent } from '../pop-panel/pop-panel.component';\nimport { TextPanelComponent } from '../text-panel/text-panel.component';\nimport { SearchTipComponent } from '../search-tip/search-tip.component';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { ActionService, SortItem } from '../../service/action.service';\nimport { FormsModule } from '@angular/forms';\nimport { searchUtils } from '../search-utils';\nimport { Search, Sort } from '../../am/am.component';\nimport { Popover } from 'primeng/popover';\nimport { Observable } from 'rxjs';\nimport { I18nService } from '../../service/i18n.service';\n\nexport type SearchType = 'text' | 'list' | 'select' | 'date' | 'number' | 'tree';\nexport interface SearchItemOption {\n\tkey?: string;\n\tlabel?: string;\n\tchecked?: boolean;\n}\nexport interface SearchItem {\n\tfield?: string;\n\tlabel?: string;\n\tselected?: boolean;\n\tfilter?: boolean;\n\tformat?: string;\n\tfilterType?: SearchType;\n\toptions?: SearchItemOption[];\n\tcascade?: boolean;\n\tcascadeKey?: string;\n\tmultiple?: boolean;\n\tgroup?: boolean;\n\tvalue?: any;\n\tfrom?: string;\n\tto?: string;\n\toperator?: string;\n\tcascadeFunc?: (value: any) => Observable<SearchItemOption[]>;\n\t[propsName: string]: any;\n}\n\nexport interface SearchOptions {\n\tsearchItems?: SearchItem[];\n\tmodelName?: string;\n}\n\n@Component({\n\tselector: 'custom-search',\n\tstandalone: true,\n\timports: [FormsModule, PopPanelComponent, TextPanelComponent, SearchTipComponent, TranslatePipe, Popover],\n\ttemplateUrl: './search.component.html',\n\tstyleUrl: './search.component.scss',\n})\nexport class SearchComponent {\n\t@ViewChild('searchRef', { static: false }) searchRef!: ElementRef;\n\t@ViewChild('popPanel') popPanel!: Popover;\n\t@ViewChild('textPanel') textPanel!: Popover;\n\tsearchPrm = input<Search>();\n\tgridOptions = input<GridOptions>();\n\tsearchModel = computed(() => {\n\t\tif (!this.action.searchMonitor(untracked(() => this.gridOptions()?.modelName))) return;\n\t\tconst search = this.action.getSearch(untracked(() => this.gridOptions()?.modelName));\n\t\treturn search;\n\t});\n\tsearchItems!: SearchItem[];\n\tsortOptions!: SearchItemOption[];\n\tmarginLeft: string = '0';\n\tsearchStr = '';\n\tisActive = false;\n\tvisible = true;\n\treload = true;\n\n\tconstructor(\n\t\tprivate action: ActionService,\n\t\tprivate i18n: I18nService,\n\t) {\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst columnDefs = this.gridOptions()?.columnDefs;\n\t\t\t\tthis.visible = this.gridOptions()?.showSearch ?? true;\n\t\t\t\tthis.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);\n\t\t\t\tthis.sortOptions = columnDefs!.map((columnDef: any) => ({ key: columnDef.field, label: columnDef.headerName }));\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t\teffect(() => {\n\t\t\tconst searchPrm = this.searchPrm();\n\t\t\tif (searchPrm?.columnFilters?.length || searchPrm?.groups?.length) {\n\t\t\t\tthis.action.setSearch({ columnFilters: searchPrm?.columnFilters, groups: searchPrm?.groups }, searchPrm.modelName);\n\t\t\t}\n\t\t});\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst searchItem = this.action.getSearchItem();\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\n\t\t\t\tif (searchItem == undefined) return;\n\t\t\t\tthis.action.setSearch(\n\t\t\t\t\tsearchUtils.concatFilter(this.action.getSearch(modelName), searchUtils.transferFilter(searchItem)!),\n\t\t\t\t\tmodelName,\n\t\t\t\t);\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst searchClear = this.action.getSearchClear();\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\n\t\t\t\tif (searchClear == undefined) return;\n\t\t\t\tlet search = this.action.getSearch(modelName);\n\t\t\t\tsearch = {\n\t\t\t\t\t...search,\n\t\t\t\t\tcolumnFilters: searchUtils.cascadeColumnFilters(searchClear + '', search?.columnFilters || [], this.searchItems),\n\t\t\t\t};\n\t\t\t\tthis.action.setSearch(search, modelName);\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst sortItem = this.action.getSortItem();\n\t\t\t\tif (sortItem === undefined) return;\n\t\t\t\tconst modelName = untracked(() => this.gridOptions()?.modelName);\n\t\t\t\tlet sorts: Sort[] = sortItem.fields!.map((field) => ({ field, isAsc: sortItem!.isAsc }));\n\t\t\t\tthis.action.setSearch({ columnFilters: this.action.getSearch(modelName)?.columnFilters || [], sorts }, modelName);\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t}\n\n\tngOnInit() {\n\t\tthis.i18n.change.subscribe((res: any) => {\n\t\t\tthis.reload = false;\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.reload = true;\n\t\t\t}, 200);\n\t\t});\n\t}\n\n\tngOnDestroy() {\n\t\tthis.action.clear();\n\t}\n\n\tonFocus(event: any, searchRef: any) {\n\t\tthis.isActive = true;\n\t\tif (!this.searchStr) {\n\t\t\tthis.popPanel.show(event, searchRef);\n\t\t} else {\n\t\t\tthis.textPanel.show(event, searchRef);\n\t\t}\n\t}\n\n\tonDropDownClick(event: any, searchRef: any) {\n\t\tthis.isActive = !this.isActive;\n\t\tif (!this.searchStr) {\n\t\t\tthis.popPanel.toggle(event, searchRef);\n\t\t} else {\n\t\t\tthis.textPanel.toggle(event, searchRef);\n\t\t}\n\t}\n\n\tonInput(event: any, searchRef: any) {\n\t\tif (!event.target?.value) {\n\t\t\tthis.popPanel.show(event, searchRef);\n\t\t\tthis.textPanel.hide();\n\t\t} else {\n\t\t\tthis.textPanel.show(event, searchRef);\n\t\t\tthis.popPanel.hide();\n\t\t}\n\t}\n\n\tonPopShow(event: any) {\n\t\tthis.calcMarginLeft();\n\t}\n\n\tonPopHide(event: any) {\n\t\tthis.isActive = this.popPanel.overlayVisible || this.popPanel.overlayVisible;\n\t}\n\n\tcalcMarginLeft() {\n\t\tif (!this.searchRef) return;\n\t\tconst searchRefRect = this.searchRef.nativeElement.getBoundingClientRect();\n\t\tconst panelWidth = window.innerWidth > 768 ? 535 : 305;\n\t\tconst offset = searchRefRect.width - panelWidth - 23.5;\n\t\tthis.marginLeft = offset + 'px';\n\t}\n\n\tgetSearchItemByField(field: string) {\n\t\treturn this.searchItems?.filter((searchItem) => searchItem.field == field)[0];\n\t}\n\n\tgetSortItemBySorts(sorts: Sort[]): SortItem | undefined {\n\t\tconst fields = sorts?.map((sort) => sort.field!);\n\t\tconst labels = sorts?.map((sort) => this.sortOptions?.find((sortOption) => sortOption.key == sort.field)?.label || '');\n\t\tconst isAsc = sorts[0].isAsc;\n\t\treturn { fields, labels, isAsc };\n\t}\n\n\tonStrItemClick(event: any) {\n\t\tthis.isActive = false;\n\t\tthis.searchStr = '';\n\t\tthis.textPanel.hide();\n\t}\n}\n","@if (visible && reload) {\n\t<div\n\t\t#searchRef\n\t\tclass=\"s-main\">\n\t\t<div [class]=\"'flex items-center s-container ' + (isActive ? 's-active' : 's-unactive')\">\n\t\t\t<span class=\"flex-none s-search pi pi-search\"></span>\n\t\t\t<div class=\"flex-1 flex items-center content-center flex-wrap\">\n\t\t\t\t@for (columnFilter of searchModel()?.columnFilters; track columnFilter) {\n\t\t\t\t\t<search-tip\n\t\t\t\t\t\t[columnFilter]=\"columnFilter\"\n\t\t\t\t\t\t[searchItem]=\"getSearchItemByField(columnFilter.columnField!)\"></search-tip>\n\t\t\t\t}\n\t\t\t\t@if (searchModel()?.sorts?.length) {\n\t\t\t\t\t<search-tip\n\t\t\t\t\t\t[sorts]=\"searchModel()?.sorts\"\n\t\t\t\t\t\t[sortItem]=\"getSortItemBySorts(searchModel()?.sorts!)\"></search-tip>\n\t\t\t\t}\n\t\t\t\t<div class=\"flex-1\">\n\t\t\t\t\t<input\n\t\t\t\t\t\ttype=\"text\"\n\t\t\t\t\t\tclass=\"s-input\"\n\t\t\t\t\t\t[placeholder]=\"'search.search' | translate\"\n\t\t\t\t\t\t[(ngModel)]=\"searchStr\"\n\t\t\t\t\t\t(focus)=\"onFocus($event, searchRef)\"\n\t\t\t\t\t\t(input)=\"onInput($event, searchRef)\" />\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div\n\t\t\t[class]=\"'s-dropdown ' + (isActive ? 's-active' : 's-unactive')\"\n\t\t\t(click)=\"onDropDownClick($event, searchRef)\">\n\t\t\t<span [class]=\"'s-dropdown-icon pi pi-chevron-' + (isActive ? 'up' : 'down')\"></span>\n\t\t</div>\n\t</div>\n\n\t<p-popover\n\t\t[style]=\"{ marginLeft, maxHeight: '75vh', overflowY: 'scroll' }\"\n\t\t(onShow)=\"onPopShow($event)\"\n\t\t(onHide)=\"onPopHide($event)\"\n\t\t#popPanel>\n\t\t<pop-panel\n\t\t\t[searchItems]=\"searchItems\"\n\t\t\t[sortOptions]=\"sortOptions\"\n\t\t\t[modelName]=\"gridOptions()?.modelName\"></pop-panel>\n\t</p-popover>\n\n\t<p-popover\n\t\t[style]=\"{ maxHeight: '75vh', overflowY: 'scroll' }\"\n\t\t(onHide)=\"onPopHide($event)\"\n\t\t#textPanel>\n\t\t<text-panel\n\t\t\t[searchItems]=\"searchItems\"\n\t\t\t[searchStr]=\"searchStr\"\n\t\t\t(strItemClick)=\"onStrItemClick($event)\"></text-panel>\n\t</p-popover>\n}\n"]}
@@ -75,16 +75,23 @@ const _searchUitls = {
75
75
  }
76
76
  return columnFilters?.filter((columnFilter) => !cascadeClearList.includes(columnFilter.columnField));
77
77
  },
78
- extractSearchItems(columnDefs, searchItems = []) {
78
+ extractSearchItems(columnDefs, i18n, searchItems = []) {
79
79
  columnDefs?.forEach((col) => {
80
80
  if (col.children) {
81
- this.extractSearchItems(col.children, searchItems);
81
+ this.extractSearchItems(col.children, i18n, searchItems);
82
82
  }
83
83
  else {
84
84
  if (!col.search) {
85
85
  return;
86
86
  }
87
- let searchItem = { field: col.field, label: col.headerName || col.field, filterType: col.searchType, filter: true };
87
+ let label;
88
+ if (col.hasOwnProperty('i18nKey')) {
89
+ label = i18n.fanyi(col.i18nKey);
90
+ }
91
+ else {
92
+ label = col.headerName || col.field;
93
+ }
94
+ let searchItem = { field: col.field, label, filterType: col.searchType, filter: true };
88
95
  if (col.searchType == 'date') {
89
96
  searchItem.format = col.searchFormat ?? 'yy-mm-dd';
90
97
  }
@@ -128,4 +135,4 @@ export const searchUtils = {
128
135
  cascadeColumnFilters: _searchUitls.cascadeColumnFilters,
129
136
  translate: _searchUitls.translate,
130
137
  };
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-utils.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/search/search-utils.ts"],"names":[],"mappings":"AAGA,MAAM,YAAY,GAAG;IACpB,WAAW,EAAE,CAAC,KAAY,EAAS,EAAE;QACpC,IAAI,MAAM,GAAU,EAAE,CAAC;QACvB,KAAK,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACvB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAElB,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC/C,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;YACjE,CAAC;QACF,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IACf,CAAC;IACD,cAAc,EAAE,CAAC,IAAgB,EAA4B,EAAE;QAC9D,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,EAAE,CAAC;YAC/B,OAAO,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QACxC,CAAC;aAAM,IAAI,IAAI,CAAC,UAAU,IAAI,QAAQ,EAAE,CAAC;YACxC,OAAO,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC1C,CAAC;QACD,OAAO;YACN,WAAW,EAAE,IAAI,CAAC,KAAK;YACvB,IAAI,EAAE,IAAI,CAAC,QAAQ,IAAI,UAAU;YACjC,KAAK,EAAE,IAAI,CAAC,KAAK;SACjB,CAAC;IACH,CAAC;IACD,cAAc,EAAE,CAAC,IAAgB,EAA4B,EAAE;QAC9D,IAAI,IAAI,CAAC,QAAQ,IAAI,SAAS,EAAE,CAAC;YAChC,OAAO;gBACN,WAAW,EAAE,IAAI,CAAC,KAAK;gBACvB,IAAI,EAAE,IAAI,CAAC,QAAQ;gBACnB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,EAAE,EAAE,IAAI,CAAC,EAAE;aACX,CAAC;QACH,CAAC;QACD,OAAO;YACN,WAAW,EAAE,IAAI,CAAC,KAAK;YACvB,IAAI,EAAE,IAAI,CAAC,QAAQ;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK;SACjB,CAAC;IACH,CAAC;IACD,YAAY,EAAE,CAAC,IAAgB,EAA4B,EAAE;QAC5D,IAAI,IAAI,CAAC,QAAQ,IAAI,SAAS,EAAE,CAAC;YAChC,OAAO;gBACN,WAAW,EAAE,IAAI,CAAC,KAAK;gBACvB,IAAI,EAAE,IAAI,CAAC,QAAQ;gBACnB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,EAAE,EAAE,IAAI,CAAC,EAAE;aACX,CAAC;QACH,CAAC;QACD,OAAO;YACN,WAAW,EAAE,IAAI,CAAC,KAAK;YACvB,IAAI,EAAE,IAAI,CAAC,QAAQ;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK;SACjB,CAAC;IACH,CAAC;IACD,YAAY,EAAE,CAAC,SAAiB,EAAE,aAAa,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,MAAoB,EAAU,EAAE;QAClG,MAAM,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,IAAI,GAAG,CAAC,WAAW,CAAC,CAAC;QACpG,IAAI,CAAC,MAAM,EAAE,CAAC;YACb,OAAO,MAAM,CAAC;QACf,CAAC;QACD,IAAI,MAAM,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YACjD,OAAO,MAAM,CAAC;QACf,CAAC;QACD,MAAM,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QACnC,OAAO,MAAM,CAAC;IACf,CAAC;IACD,oBAAoB,CAAC,WAAmB,EAAE,aAA6B,EAAE,WAAyB;QACjG,MAAM,gBAAgB,GAAa,CAAC,WAAW,CAAC,CAAC;QACjD,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE,CAAC;YAC1C,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;gBACtC,IAAI,UAAU,CAAC,KAAK,IAAI,YAAY,CAAC,WAAW,IAAI,UAAU,CAAC,OAAO,IAAI,UAAU,CAAC,UAAU,IAAI,WAAW,EAAE,CAAC;oBAChH,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,WAAY,CAAC,CAAC;oBACjD,MAAM;gBACP,CAAC;YACF,CAAC;QACF,CAAC;QACD,OAAO,aAAa,EAAE,MAAM,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,gBAAgB,CAAC,QAAQ,CAAC,YAAY,CAAC,WAAY,CAAC,CAAC,CAAC;IACvG,CAAC;IACD,kBAAkB,CAAC,UAAe,EAAE,cAA4B,EAAE;QACjE,UAAU,EAAE,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;YAChC,IAAI,GAAG,CAAC,QAAQ,EAAE,CAAC;gBAClB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;YACpD,CAAC;iBAAM,CAAC;gBACP,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC;oBACjB,OAAO;gBACR,CAAC;gBACD,IAAI,UAAU,GAAe,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,GAAG,CAAC,UAAU,IAAI,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,CAAC,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;gBAChI,IAAI,GAAG,CAAC,UAAU,IAAI,MAAM,EAAE,CAAC;oBAC9B,UAAU,CAAC,MAAM,GAAG,GAAG,CAAC,YAAY,IAAI,UAAU,CAAC;gBACpD,CAAC;qBAAM,IAAI,GAAG,CAAC,UAAU,IAAI,QAAQ,EAAE,CAAC;oBACvC,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC;wBACjB,UAAU,CAAC,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC;wBACjC,UAAU,CAAC,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC;wBACvC,UAAU,CAAC,WAAW,GAAG,GAAG,CAAC,WAAW,CAAC;oBAC1C,CAAC;gBACF,CAAC;gBACD,IAAI,GAAG,CAAC,aAAa,EAAE,CAAC;oBACvB,GAAG,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,OAAY,EAAE,EAAE;wBAC5C,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;oBAC1D,CAAC,CAAC,CAAC;gBACJ,CAAC;gBACD,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;oBACrB,UAAU,CAAC,KAAK,GAAG,GAAG,CAAC,WAAW,CAAC;gBACpC,CAAC;gBACD,IAAI,GAAG,CAAC,QAAQ,EAAE,CAAC;oBAClB,UAAU,CAAC,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC;gBACpC,CAAC;gBACD,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC9B,CAAC;QACF,CAAC,CAAC,CAAC;QACH,OAAO,WAAW,CAAC;IACpB,CAAC;IACD,SAAS,CAAC,YAAmB,EAAE,IAAiB;QAC/C,OAAO,YAAY,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;YACpC,OAAO;gBACN,GAAG,QAAQ;gBACX,KAAK,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK;aACvE,CAAC;QACH,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAC;AACF,MAAM,CAAC,MAAM,WAAW,GAAG;IAC1B,WAAW,EAAE,YAAY,CAAC,WAAW;IACrC,cAAc,EAAE,YAAY,CAAC,cAAc;IAC3C,YAAY,EAAE,YAAY,CAAC,YAAY;IACvC,kBAAkB,EAAE,YAAY,CAAC,kBAAkB;IACnD,oBAAoB,EAAE,YAAY,CAAC,oBAAoB;IACvD,SAAS,EAAE,YAAY,CAAC,SAAS;CACjC,CAAC","sourcesContent":["import { SearchItem } from './search/search.component';\r\nimport { Search, ColumnFilter } from '../am/am.component';\r\nimport { I18nService } from '../service/i18n.service'\r\nconst _searchUitls = {\r\n\tflattenTree: (nodes: any[]): any[] => {\r\n\t\tlet result: any[] = [];\r\n\t\tnodes?.forEach((node) => {\r\n\t\t\tresult.push(node);\r\n\r\n\t\t\tif (node.children && node.children.length > 0) {\r\n\t\t\t\tresult = result.concat(_searchUitls.flattenTree(node.children));\r\n\t\t\t}\r\n\t\t});\r\n\t\treturn result;\r\n\t},\r\n\ttransferFilter: (item: SearchItem): ColumnFilter | undefined => {\r\n\t\tif (item.filterType == 'date') {\r\n\t\t\treturn _searchUitls.transferDate(item);\r\n\t\t} else if (item.filterType == 'number') {\r\n\t\t\treturn _searchUitls.transferNumber(item);\r\n\t\t}\r\n\t\treturn {\r\n\t\t\tcolumnField: item.field,\r\n\t\t\ttype: item.operator || 'contains',\r\n\t\t\tfiter: item.value,\r\n\t\t};\r\n\t},\r\n\ttransferNumber: (item: SearchItem): ColumnFilter | undefined => {\r\n\t\tif (item.operator == 'inRange') {\r\n\t\t\treturn {\r\n\t\t\t\tcolumnField: item.field,\r\n\t\t\t\ttype: item.operator,\r\n\t\t\t\tfrom: item.from,\r\n\t\t\t\tto: item.to,\r\n\t\t\t};\r\n\t\t}\r\n\t\treturn {\r\n\t\t\tcolumnField: item.field,\r\n\t\t\ttype: item.operator,\r\n\t\t\tfiter: item.value,\r\n\t\t};\r\n\t},\r\n\ttransferDate: (item: SearchItem): ColumnFilter | undefined => {\r\n\t\tif (item.operator == 'inRange') {\r\n\t\t\treturn {\r\n\t\t\t\tcolumnField: item.field,\r\n\t\t\t\ttype: item.operator,\r\n\t\t\t\tfrom: item.from,\r\n\t\t\t\tto: item.to,\r\n\t\t\t};\r\n\t\t}\r\n\t\treturn {\r\n\t\t\tcolumnField: item.field,\r\n\t\t\ttype: item.operator,\r\n\t\t\tfiter: item.value,\r\n\t\t};\r\n\t},\r\n\tconcatFilter: (search: Search = { columnFilters: [], groups: [] }, filter: ColumnFilter): Search => {\r\n\t\tsearch.columnFilters = search.columnFilters?.filter((fil) => filter.columnField != fil.columnField);\r\n\t\tif (!filter) {\r\n\t\t\treturn search;\r\n\t\t}\r\n\t\tif (filter.type == 'in' && !filter.fiter.length) {\r\n\t\t\treturn search;\r\n\t\t}\r\n\t\tsearch.columnFilters?.push(filter);\r\n\t\treturn search;\r\n\t},\r\n\tcascadeColumnFilters(searchClear: string, columnFilters: ColumnFilter[], searchItems: SearchItem[]): ColumnFilter[] {\r\n\t\tconst cascadeClearList: string[] = [searchClear];\r\n\t\tfor (const columnFilter of columnFilters) {\r\n\t\t\tfor (const searchItem of searchItems) {\r\n\t\t\t\tif (searchItem.field == columnFilter.columnField && searchItem.cascade && searchItem.cascadeKey == searchClear) {\r\n\t\t\t\t\tcascadeClearList.push(columnFilter.columnField!);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn columnFilters?.filter((columnFilter) => !cascadeClearList.includes(columnFilter.columnField!));\r\n\t},\r\n\textractSearchItems(columnDefs: any, searchItems: SearchItem[] = []): SearchItem[] {\r\n\t\tcolumnDefs?.forEach((col: any) => {\r\n\t\t\tif (col.children) {\r\n\t\t\t\tthis.extractSearchItems(col.children, searchItems);\r\n\t\t\t} else {\r\n\t\t\t\tif (!col.search) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t\tlet searchItem: SearchItem = { field: col.field, label: col.headerName || col.field, filterType: col.searchType, filter: true };\r\n\t\t\t\tif (col.searchType == 'date') {\r\n\t\t\t\t\tsearchItem.format = col.searchFormat ?? 'yy-mm-dd';\r\n\t\t\t\t} else if (col.searchType == 'select') {\r\n\t\t\t\t\tif (col.cascade) {\r\n\t\t\t\t\t\tsearchItem.cascade = col.cascade;\r\n\t\t\t\t\t\tsearchItem.cascadeKey = col.cascadeKey;\r\n\t\t\t\t\t\tsearchItem.cascadeFunc = col.cascadeFunc;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\tif (col.searchOptions) {\r\n\t\t\t\t\tcol.searchOptions.subscribe((options: any) => {\r\n\t\t\t\t\t\tsearchItem.options = JSON.parse(JSON.stringify(options));\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tif (col.searchGroup) {\r\n\t\t\t\t\tsearchItem.group = col.searchGroup;\r\n\t\t\t\t}\r\n\t\t\t\tif (col.multiple) {\r\n\t\t\t\t\tsearchItem.multiple = col.multiple;\r\n\t\t\t\t}\r\n\t\t\t\tsearchItems.push(searchItem);\r\n\t\t\t}\r\n\t\t});\r\n\t\treturn searchItems;\r\n\t},\r\n\ttranslate(operatorList: any[], i18n: I18nService) {\r\n\t\treturn operatorList.map((operator) => {\r\n\t\t\treturn {\r\n\t\t\t\t...operator,\r\n\t\t\t\tlabel: operator.i18nKey ? i18n.fanyi(operator.i18nKey) : operator.label,\r\n\t\t\t};\r\n\t\t});\r\n\t},\r\n};\r\nexport const searchUtils = {\r\n\tflattenTree: _searchUitls.flattenTree,\r\n\ttransferFilter: _searchUitls.transferFilter,\r\n\tconcatFilter: _searchUitls.concatFilter,\r\n\textractSearchItems: _searchUitls.extractSearchItems,\r\n\tcascadeColumnFilters: _searchUitls.cascadeColumnFilters,\r\n\ttranslate: _searchUitls.translate,\r\n};\r\n"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-utils.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/search/search-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { SearchItem } from './search/search.component';\nimport { Search, ColumnFilter } from '../am/am.component';\nimport { I18nService } from '../service/i18n.service';\nconst _searchUitls = {\n\tflattenTree: (nodes: any[]): any[] => {\n\t\tlet result: any[] = [];\n\t\tnodes?.forEach((node) => {\n\t\t\tresult.push(node);\n\n\t\t\tif (node.children && node.children.length > 0) {\n\t\t\t\tresult = result.concat(_searchUitls.flattenTree(node.children));\n\t\t\t}\n\t\t});\n\t\treturn result;\n\t},\n\ttransferFilter: (item: SearchItem): ColumnFilter | undefined => {\n\t\tif (item.filterType == 'date') {\n\t\t\treturn _searchUitls.transferDate(item);\n\t\t} else if (item.filterType == 'number') {\n\t\t\treturn _searchUitls.transferNumber(item);\n\t\t}\n\t\treturn {\n\t\t\tcolumnField: item.field,\n\t\t\ttype: item.operator || 'contains',\n\t\t\tfiter: item.value,\n\t\t};\n\t},\n\ttransferNumber: (item: SearchItem): ColumnFilter | undefined => {\n\t\tif (item.operator == 'inRange') {\n\t\t\treturn {\n\t\t\t\tcolumnField: item.field,\n\t\t\t\ttype: item.operator,\n\t\t\t\tfrom: item.from,\n\t\t\t\tto: item.to,\n\t\t\t};\n\t\t}\n\t\treturn {\n\t\t\tcolumnField: item.field,\n\t\t\ttype: item.operator,\n\t\t\tfiter: item.value,\n\t\t};\n\t},\n\ttransferDate: (item: SearchItem): ColumnFilter | undefined => {\n\t\tif (item.operator == 'inRange') {\n\t\t\treturn {\n\t\t\t\tcolumnField: item.field,\n\t\t\t\ttype: item.operator,\n\t\t\t\tfrom: item.from,\n\t\t\t\tto: item.to,\n\t\t\t};\n\t\t}\n\t\treturn {\n\t\t\tcolumnField: item.field,\n\t\t\ttype: item.operator,\n\t\t\tfiter: item.value,\n\t\t};\n\t},\n\tconcatFilter: (search: Search = { columnFilters: [], groups: [] }, filter: ColumnFilter): Search => {\n\t\tsearch.columnFilters = search.columnFilters?.filter((fil) => filter.columnField != fil.columnField);\n\t\tif (!filter) {\n\t\t\treturn search;\n\t\t}\n\t\tif (filter.type == 'in' && !filter.fiter.length) {\n\t\t\treturn search;\n\t\t}\n\t\tsearch.columnFilters?.push(filter);\n\t\treturn search;\n\t},\n\tcascadeColumnFilters(searchClear: string, columnFilters: ColumnFilter[], searchItems: SearchItem[]): ColumnFilter[] {\n\t\tconst cascadeClearList: string[] = [searchClear];\n\t\tfor (const columnFilter of columnFilters) {\n\t\t\tfor (const searchItem of searchItems) {\n\t\t\t\tif (searchItem.field == columnFilter.columnField && searchItem.cascade && searchItem.cascadeKey == searchClear) {\n\t\t\t\t\tcascadeClearList.push(columnFilter.columnField!);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn columnFilters?.filter((columnFilter) => !cascadeClearList.includes(columnFilter.columnField!));\n\t},\n\textractSearchItems(columnDefs: any, i18n: I18nService, searchItems: SearchItem[] = []): SearchItem[] {\n\t\tcolumnDefs?.forEach((col: any) => {\n\t\t\tif (col.children) {\n\t\t\t\tthis.extractSearchItems(col.children, i18n, searchItems);\n\t\t\t} else {\n\t\t\t\tif (!col.search) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tlet label;\n\t\t\t\tif (col.hasOwnProperty('i18nKey')) {\n\t\t\t\t\tlabel = i18n.fanyi(col.i18nKey);\n\t\t\t\t} else {\n\t\t\t\t\tlabel = col.headerName || col.field;\n\t\t\t\t}\n\t\t\t\tlet searchItem: SearchItem = { field: col.field, label, filterType: col.searchType, filter: true };\n\t\t\t\tif (col.searchType == 'date') {\n\t\t\t\t\tsearchItem.format = col.searchFormat ?? 'yy-mm-dd';\n\t\t\t\t} else if (col.searchType == 'select') {\n\t\t\t\t\tif (col.cascade) {\n\t\t\t\t\t\tsearchItem.cascade = col.cascade;\n\t\t\t\t\t\tsearchItem.cascadeKey = col.cascadeKey;\n\t\t\t\t\t\tsearchItem.cascadeFunc = col.cascadeFunc;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (col.searchOptions) {\n\t\t\t\t\tcol.searchOptions.subscribe((options: any) => {\n\t\t\t\t\t\tsearchItem.options = JSON.parse(JSON.stringify(options));\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tif (col.searchGroup) {\n\t\t\t\t\tsearchItem.group = col.searchGroup;\n\t\t\t\t}\n\t\t\t\tif (col.multiple) {\n\t\t\t\t\tsearchItem.multiple = col.multiple;\n\t\t\t\t}\n\t\t\t\tsearchItems.push(searchItem);\n\t\t\t}\n\t\t});\n\t\treturn searchItems;\n\t},\n\ttranslate(operatorList: any[], i18n: I18nService) {\n\t\treturn operatorList.map((operator) => {\n\t\t\treturn {\n\t\t\t\t...operator,\n\t\t\t\tlabel: operator.i18nKey ? i18n.fanyi(operator.i18nKey) : operator.label,\n\t\t\t};\n\t\t});\n\t},\n};\nexport const searchUtils = {\n\tflattenTree: _searchUitls.flattenTree,\n\ttransferFilter: _searchUitls.transferFilter,\n\tconcatFilter: _searchUitls.concatFilter,\n\textractSearchItems: _searchUitls.extractSearchItems,\n\tcascadeColumnFilters: _searchUitls.cascadeColumnFilters,\n\ttranslate: _searchUitls.translate,\n};\n"]}
@@ -1148,6 +1148,19 @@ const _fieldUtils = {
1148
1148
  ? _fieldUtils.props(field).options
1149
1149
  : undefined;
1150
1150
  },
1151
+ dafaultValueHandler(field, defaultValue, datePipe) {
1152
+ if (field.type == 'datepicker' && defaultValue === 'today') {
1153
+ return _fieldUtils.getCurrentDate();
1154
+ }
1155
+ return defaultValue;
1156
+ },
1157
+ getCurrentDate(separator = '-') {
1158
+ const now = new Date();
1159
+ const year = now.getFullYear();
1160
+ const month = String(now.getMonth() + 1).padStart(2, '0');
1161
+ const day = String(now.getDate()).padStart(2, '0');
1162
+ return `${year}${separator}${month}${separator}${day}`;
1163
+ },
1151
1164
  triggerHookAndSetValue: (field, value, emitEvent, emitHook, hookObservers, callback, datePipe) => {
1152
1165
  if (field.hook && isObservable(field.hook)) {
1153
1166
  const sub = field.hook
@@ -1238,8 +1251,8 @@ const _fieldUtils = {
1238
1251
  return '';
1239
1252
  }
1240
1253
  if (_fieldUtils.isISO8601(raw)) {
1241
- const dateFormat = field.datePickerProps?.showTime ? 'yyyy-MM-dd HH:mm:ss' : 'yyyy-MM-dd';
1242
- return datePipe.transform(raw, dateFormat, 'GMT') || raw;
1254
+ const datePipeFormat = field.datePickerProps?.datePipeFormat ?? 'yyyy-MM-dd';
1255
+ return datePipe.transform(raw, datePipeFormat, 'GMT') || raw;
1243
1256
  }
1244
1257
  if (!stringMode && field?.datePickerProps?.selectionMode == 'range' && raw.includes('~')) {
1245
1258
  const [start, end] = raw.split('~');
@@ -1325,6 +1338,7 @@ const fieldUtils = {
1325
1338
  props: _fieldUtils.props,
1326
1339
  label: _fieldUtils.label,
1327
1340
  fieldHandler: _fieldUtils.fieldHandler,
1341
+ dafaultValueHandler: _fieldUtils.dafaultValueHandler,
1328
1342
  triggerHookAndSetValue: _fieldUtils.triggerHookAndSetValue,
1329
1343
  fromFieldValue: _fieldUtils.fromFieldValue,
1330
1344
  preloadLog: _fieldUtils.preloadLog,
@@ -2091,6 +2105,7 @@ class DatePickerComponent {
2091
2105
  this.props = this.field().datePickerProps;
2092
2106
  this.handleHookChange();
2093
2107
  this.handleDisabled();
2108
+ this.handleDatePipeFormat();
2094
2109
  }
2095
2110
  });
2096
2111
  effect(() => {
@@ -2147,6 +2162,47 @@ class DatePickerComponent {
2147
2162
  throw new Error('Invalid date format. Expected yyyy-MM-dd hh:mm:ss');
2148
2163
  }
2149
2164
  }
2165
+ handleDatePipeFormat() {
2166
+ this.props.datePipeFormat = this.convertPrimeNgToDatePipeFormat(this.props.dateFormat);
2167
+ if (!this.props.showTime)
2168
+ return;
2169
+ const timeSeparator = this.props.timeSeparator ?? ':';
2170
+ const timeFormat = `HH${timeSeparator}mm${timeSeparator}ss`;
2171
+ this.props.datePipeFormat += ` ${timeFormat}`;
2172
+ }
2173
+ convertPrimeNgToDatePipeFormat(primeNgFormat) {
2174
+ if (!primeNgFormat)
2175
+ return 'yyyy-MM-dd';
2176
+ const formatMap = {
2177
+ d: 'd',
2178
+ dd: 'dd',
2179
+ m: 'M',
2180
+ mm: 'MM',
2181
+ M: 'MMM',
2182
+ MM: 'MMMM',
2183
+ y: 'yy',
2184
+ yy: 'yyyy',
2185
+ };
2186
+ const commonFormats = {
2187
+ 'mm/dd/yy': 'MM/dd/yyyy',
2188
+ 'dd/mm/yy': 'dd/MM/yyyy',
2189
+ 'yy-mm-dd': 'yyyy-MM-dd',
2190
+ 'dd-mm-yy': 'dd-MM-yyyy',
2191
+ 'mm-dd-yy': 'MM-dd-yyyy',
2192
+ };
2193
+ if (commonFormats[primeNgFormat]) {
2194
+ return commonFormats[primeNgFormat];
2195
+ }
2196
+ // 替换转义字符
2197
+ let result = primeNgFormat.replace(/'([^']*)'/g, (match, p1) => {
2198
+ return `'${p1}'`;
2199
+ });
2200
+ // 替换格式标记
2201
+ result = result.replace(/[a-zA-Z]+/g, (match) => {
2202
+ return formatMap[match] || match;
2203
+ });
2204
+ return result;
2205
+ }
2150
2206
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, deps: [{ token: ActionService }, { token: i0.Renderer2 }, { token: i1$2.DatePipe }], target: i0.ɵɵFactoryTarget.Component }); }
2151
2207
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DatePickerComponent, isStandalone: true, selector: "form-datepicker", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null } }, providers: [DatePipe], viewQueries: [{ propertyName: "datePicker", first: true, predicate: DatePicker, descendants: true }, { propertyName: "datePickerRef", first: true, predicate: DatePicker, descendants: true, read: ElementRef }], ngImport: i0, template: `<p-datepicker
2152
2208
  [id]="field()?.uuid"
@@ -4443,7 +4499,7 @@ const _gridUtils = {
4443
4499
  if (item.hasOwnProperty('i18nKey')) {
4444
4500
  let headerName = i18n.fanyi(item.i18nKey);
4445
4501
  cols = { ...item, headerName };
4446
- delete cols.i18nKey;
4502
+ // delete cols.i18nKey;
4447
4503
  }
4448
4504
  else {
4449
4505
  cols = { ...item };
@@ -6391,16 +6447,23 @@ const _searchUitls = {
6391
6447
  }
6392
6448
  return columnFilters?.filter((columnFilter) => !cascadeClearList.includes(columnFilter.columnField));
6393
6449
  },
6394
- extractSearchItems(columnDefs, searchItems = []) {
6450
+ extractSearchItems(columnDefs, i18n, searchItems = []) {
6395
6451
  columnDefs?.forEach((col) => {
6396
6452
  if (col.children) {
6397
- this.extractSearchItems(col.children, searchItems);
6453
+ this.extractSearchItems(col.children, i18n, searchItems);
6398
6454
  }
6399
6455
  else {
6400
6456
  if (!col.search) {
6401
6457
  return;
6402
6458
  }
6403
- let searchItem = { field: col.field, label: col.headerName || col.field, filterType: col.searchType, filter: true };
6459
+ let label;
6460
+ if (col.hasOwnProperty('i18nKey')) {
6461
+ label = i18n.fanyi(col.i18nKey);
6462
+ }
6463
+ else {
6464
+ label = col.headerName || col.field;
6465
+ }
6466
+ let searchItem = { field: col.field, label, filterType: col.searchType, filter: true };
6404
6467
  if (col.searchType == 'date') {
6405
6468
  searchItem.format = col.searchFormat ?? 'yy-mm-dd';
6406
6469
  }
@@ -6855,7 +6918,7 @@ class SearchComponent {
6855
6918
  effect(() => {
6856
6919
  const columnDefs = this.gridOptions()?.columnDefs;
6857
6920
  this.visible = this.gridOptions()?.showSearch ?? true;
6858
- this.searchItems = searchUtils.extractSearchItems(columnDefs);
6921
+ this.searchItems = searchUtils.extractSearchItems(columnDefs, this.i18n);
6859
6922
  this.sortOptions = columnDefs.map((columnDef) => ({ key: columnDef.field, label: columnDef.headerName }));
6860
6923
  }, { allowSignalWrites: true });
6861
6924
  effect(() => {
@@ -7486,7 +7549,7 @@ class FormComponent {
7486
7549
  if (this.model()[field.key] !== undefined)
7487
7550
  return;
7488
7551
  untracked(() => {
7489
- this.handleValueChange(field.default, field);
7552
+ this.handleValueChange(fieldUtils.dafaultValueHandler(field, field.default, this.datePipe), field);
7490
7553
  });
7491
7554
  });
7492
7555
  }