@sd-angular/core 1.3.133 → 1.3.135
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/assets/scss/sd-core.scss +1 -0
- package/bundles/sd-angular-core-button.umd.js.map +1 -1
- package/bundles/sd-angular-core-button.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-grid-material.umd.js +92 -43
- package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
- package/bundles/sd-angular-core-grid-material.umd.min.js +2 -2
- package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
- package/button/sd-angular-core-button.metadata.json +1 -1
- package/button/src/lib/button.component.d.ts +1 -1
- package/esm2015/button/src/lib/button.component.js +1 -1
- package/esm2015/grid-material/src/lib/components/column-inline-filter/column-inline-filter.component.js +3 -2
- package/esm2015/grid-material/src/lib/grid-material.component.js +15 -2
- package/esm2015/grid-material/src/lib/models/grid-column.model.js +43 -19
- package/esm2015/grid-material/src/lib/models/grid-configuration.model.js +3 -3
- package/fesm2015/sd-angular-core-button.js.map +1 -1
- package/fesm2015/sd-angular-core-grid-material.js +60 -22
- package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
- package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
- package/grid-material/src/lib/components/column-inline-filter/column-inline-filter.component.d.ts +1 -0
- package/grid-material/src/lib/models/grid-column.model.d.ts +2 -1
- package/grid-material/src/lib/models/grid-configuration.model.d.ts +6 -0
- package/package.json +2 -1
- package/{sd-angular-core-1.3.133.tgz → sd-angular-core-1.3.135.tgz} +0 -0
|
@@ -1,39 +1,63 @@
|
|
|
1
1
|
export const SdFilterOperators = [
|
|
2
2
|
{
|
|
3
3
|
value: 'EQUAL',
|
|
4
|
-
|
|
4
|
+
symbol: '=',
|
|
5
|
+
display: 'Bằng',
|
|
5
6
|
},
|
|
6
7
|
{
|
|
7
8
|
value: 'NOT_EQUAL',
|
|
8
|
-
|
|
9
|
+
symbol: '!=',
|
|
10
|
+
display: 'Không bằng',
|
|
9
11
|
},
|
|
10
|
-
{
|
|
11
|
-
value: 'CONTAIN',
|
|
12
|
-
display: '∈',
|
|
13
|
-
},
|
|
14
|
-
// {
|
|
15
|
-
// value: 'START_WITH';
|
|
16
|
-
// display: '=';
|
|
17
|
-
// },
|
|
18
|
-
// {
|
|
19
|
-
// value: 'END_WITH';
|
|
20
|
-
// display: '=';
|
|
21
|
-
// },
|
|
22
12
|
{
|
|
23
13
|
value: 'GREATER_THAN',
|
|
24
|
-
|
|
14
|
+
symbol: '>',
|
|
15
|
+
display: 'Lớn hơn',
|
|
25
16
|
},
|
|
26
17
|
{
|
|
27
18
|
value: 'LESS_THAN',
|
|
28
|
-
|
|
19
|
+
symbol: '<',
|
|
20
|
+
display: 'Nhỏ hơn',
|
|
29
21
|
},
|
|
30
22
|
{
|
|
31
23
|
value: 'GREATER_OR_EQUAL',
|
|
32
|
-
|
|
24
|
+
symbol: '>=',
|
|
25
|
+
display: 'Lớn hơn, hoặc bằng'
|
|
33
26
|
},
|
|
34
27
|
{
|
|
35
28
|
value: 'LESS_OR_EQUAL',
|
|
36
|
-
|
|
29
|
+
symbol: '<=',
|
|
30
|
+
display: 'Nhỏ hơn, hoặc bằng'
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
value: 'CONTAIN',
|
|
34
|
+
symbol: 'join_inner',
|
|
35
|
+
display: 'Chứa',
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
value: 'NOT_CONTAIN',
|
|
39
|
+
symbol: 'join',
|
|
40
|
+
display: 'Không chứa',
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
value: 'START_WITH',
|
|
44
|
+
symbol: 'line_start_circle',
|
|
45
|
+
display: 'Bắt đầu bởi'
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
value: 'END_WITH',
|
|
49
|
+
symbol: 'line_end_circle',
|
|
50
|
+
display: 'Kết thúc bởi'
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
value: 'IN',
|
|
54
|
+
symbol: 'checklist_rtl',
|
|
55
|
+
display: 'Nằm trong'
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
value: 'NOT_IN',
|
|
59
|
+
symbol: 'event_list',
|
|
60
|
+
display: 'Không nằm trong'
|
|
37
61
|
},
|
|
38
62
|
];
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-column.model.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid-material/","sources":["src/lib/models/grid-column.model.ts"],"names":[],"mappings":"AAuBA,MAAM,CAAC,MAAM,iBAAiB,GAAmD;IAC/E;QACE,KAAK,EAAE,OAAO;QACd,OAAO,EAAE,GAAG;KACb;IACD;QACE,KAAK,EAAE,WAAW;QAClB,OAAO,EAAE,IAAI;KACd;IACD;QACE,KAAK,EAAE,SAAS;QAChB,OAAO,EAAE,GAAG;KACb;IACD,IAAI;IACJ,yBAAyB;IACzB,kBAAkB;IAClB,KAAK;IACL,IAAI;IACJ,uBAAuB;IACvB,kBAAkB;IAClB,KAAK;IACL;QACE,KAAK,EAAE,cAAc;QACrB,OAAO,EAAE,GAAG;KACb;IACD;QACE,KAAK,EAAE,WAAW;QAClB,OAAO,EAAE,GAAG;KACb;IACD;QACE,KAAK,EAAE,kBAAkB;QACzB,OAAO,EAAE,IAAI;KACd;IACD;QACE,KAAK,EAAE,eAAe;QACtB,OAAO,EAAE,IAAI;KACd;CACF,CAAC","sourcesContent":["import { SdBadgeColor } from '@sd-angular/core/badge';\r\n\r\nexport type SdGridMaterialColumn<T = any> =\r\n  | SdGridMaterialColumnText<T>\r\n  | SdGridMaterialColumnNumber<T>\r\n  | SdGridMaterialBool<T>\r\n  | SdGridMaterialColumnDate<T>\r\n  | SdGridMaterialColumnValues<T>\r\n  | SdGridMaterialColumnImage<T>\r\n  | SdGridMaterialColumnChildren<T>\r\n  | SdGridMaterialColumnChildrenCol<T>;\r\n\r\nexport type SdFilterOperator =\r\n  | 'EQUAL'\r\n  | 'NOT_EQUAL'\r\n  | 'CONTAIN'\r\n  | 'START_WITH'\r\n  | 'END_WITH'\r\n  | 'GREATER_THAN'\r\n  | 'LESS_THAN'\r\n  | 'GREATER_OR_EQUAL'\r\n  | 'LESS_OR_EQUAL';\r\n\r\nexport const SdFilterOperators: { value: SdFilterOperator, display: string }[] = [\r\n  {\r\n    value: 'EQUAL',\r\n    display: '=',\r\n  },\r\n  {\r\n    value: 'NOT_EQUAL',\r\n    display: '!=',\r\n  },\r\n  {\r\n    value: 'CONTAIN',\r\n    display: '∈',\r\n  },\r\n  // {\r\n  //   value: 'START_WITH';\r\n  //   display: '=';\r\n  // },\r\n  // {\r\n  //   value: 'END_WITH';\r\n  //   display: '=';\r\n  // },\r\n  {\r\n    value: 'GREATER_THAN',\r\n    display: '>',\r\n  },\r\n  {\r\n    value: 'LESS_THAN',\r\n    display: '<',\r\n  },\r\n  {\r\n    value: 'GREATER_OR_EQUAL',\r\n    display: '>=',\r\n  },\r\n  {\r\n    value: 'LESS_OR_EQUAL',\r\n    display: '<=',\r\n  },\r\n];\r\n\r\nexport type TransformFunc<T = any> = (\r\n  value: any,\r\n  rowData: T,\r\n  args?: {\r\n    isExport?: boolean;\r\n  }\r\n) => string | Promise<string>;\r\n\r\ninterface SdGridMaterialBaseColumn<T = any> {\r\n  field: string;\r\n  title: string;\r\n  titleHtml?: string;\r\n  description?: string;\r\n  width?: string;\r\n  hidden?: boolean;\r\n  invisible?: boolean;\r\n  fixed?: boolean;\r\n  align?: 'center' | 'left' | 'right';\r\n  htmlTemplate?: (value: any, rowData: T, isMobileOrTablet: boolean) => string;\r\n  transform?: TransformFunc<T>;\r\n  tooltip?: (value: any, rowData: T) => string;\r\n  click?: (value: any, rowData: T) => void;\r\n  sortable?: boolean;\r\n  filter?: {\r\n    disabled?: boolean;\r\n    defaultShowing?: boolean;\r\n    default?: any;\r\n    // Chỉ dành cho filter inline column\r\n    operator?: {\r\n      enable?: boolean;\r\n      list?: SdFilterOperator[];\r\n    };\r\n  };\r\n  export?: {\r\n    disabled?: boolean;\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialColumnText<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'string';\r\n  badge?: (value: any, rowData: T) => SdBadgeColor;\r\n  badgeIcon?: (value: any, rowData: T) => string;\r\n  badgeType?: 'circle' | 'icon';\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n    minLength?: number;\r\n    maxLength?: number;\r\n    validator?: (rowData: T) => string;\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialColumnNumber<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'number';\r\n  badge?: (value: any, rowData: T) => SdBadgeColor;\r\n  badgeIcon?: (value: any, rowData: T) => string;\r\n  badgeType?: 'circle' | 'icon';\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n    minValue?: number;\r\n    maxValue?: number;\r\n    precision?: number;\r\n    validator?: (rowData: T) => string;\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialBool<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'bool';\r\n  option?: {\r\n    displayOnTrue?: string;\r\n    displayOnFalse?: string;\r\n  };\r\n  badgeType?: 'circle';\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialColumnDate<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'date' | 'datetime' | 'time';\r\n  option?: {\r\n    useFilterDate?: boolean;\r\n    timeDifferent?: 'second' | 'minute' | 'hour' | 'day' | 'month';\r\n  };\r\n  transformDate?: (value: any, rowData: T) => string | Date;\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n  };\r\n}\r\n\r\nexport interface SdGridMaterialColumnValues<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'values';\r\n  badge?: (value: any, rowData: T) => SdBadgeColor;\r\n  badgeIcon?: (value: any, rowData: T) => string;\r\n  badgeType?: 'circle' | 'icon';\r\n  option: {\r\n    items: any[] | ((searchText?: string, isFormValue?: boolean) => Promise<any[]>) | ((searchText?: string[], isFormValue?: boolean) => Promise<any[]>);\r\n    valueField: string;\r\n    displayField: string;\r\n    selection?:\r\n      | 'AUTOCOMPLETE'\r\n      | 'MULTIPLE'\r\n      | 'MULTIPLEAUTOCOMPLETE'\r\n      | 'AUTOCOMPLETE_EDITOR'\r\n      | 'MULTIPLE_EDITOR'\r\n      | 'MULTIPLEAUTOCOMPLETE_EDITOR';\r\n  };\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    add?: (rowData: T) => void;\r\n    edit?: (option: any, rowData: T) => void;\r\n    delete?: (option: any, rowData: T) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialColumnImage<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'image';\r\n  option: {\r\n    height: number;\r\n    width: number;\r\n  };\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n  };\r\n}\r\n\r\ntype SdGridMaterialNormalColumn<T> = Exclude<\r\n  Exclude<SdGridMaterialColumn<T>, SdGridMaterialColumnChildren<T>>,\r\n  SdGridMaterialColumnChildrenCol<T>\r\n>;\r\n\r\nexport type SdGridMaterialChildColumn<T = any> = SdGridMaterialNormalColumn<T> & {\r\n  dynamicTitle?: (rowData: T) => string | Promise<string>;\r\n  colSpan: 1 | 2;\r\n};\r\n\r\nexport interface SdGridMaterialColumnChildren<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'children';\r\n  children: SdGridMaterialChildColumn<T>[];\r\n}\r\n\r\nexport interface SdGridMaterialColumnChildrenCol<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'children-col';\r\n  children: SdGridMaterialNormalColumn<T>[];\r\n}\r\n"]}
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-column.model.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid-material/","sources":["src/lib/models/grid-column.model.ts"],"names":[],"mappings":"AA0BA,MAAM,CAAC,MAAM,iBAAiB,GAAoE;IAChG;QACE,KAAK,EAAE,OAAO;QACd,MAAM,EAAE,GAAG;QACX,OAAO,EAAE,MAAM;KAChB;IACD;QACE,KAAK,EAAE,WAAW;QAClB,MAAM,EAAE,IAAI;QACZ,OAAO,EAAE,YAAY;KACtB;IACD;QACE,KAAK,EAAE,cAAc;QACrB,MAAM,EAAE,GAAG;QACX,OAAO,EAAE,SAAS;KACnB;IACD;QACE,KAAK,EAAE,WAAW;QAClB,MAAM,EAAE,GAAG;QACX,OAAO,EAAE,SAAS;KACnB;IACD;QACE,KAAK,EAAE,kBAAkB;QACzB,MAAM,EAAE,IAAI;QACZ,OAAO,EAAE,oBAAoB;KAC9B;IACD;QACE,KAAK,EAAE,eAAe;QACtB,MAAM,EAAE,IAAI;QACZ,OAAO,EAAE,oBAAoB;KAC9B;IACD;QACE,KAAK,EAAE,SAAS;QAChB,MAAM,EAAE,YAAY;QACpB,OAAO,EAAE,MAAM;KAChB;IACD;QACE,KAAK,EAAE,aAAa;QACpB,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,YAAY;KACtB;IACD;QACE,KAAK,EAAE,YAAY;QACnB,MAAM,EAAE,mBAAmB;QAC3B,OAAO,EAAE,aAAa;KACvB;IACD;QACE,KAAK,EAAE,UAAU;QACjB,MAAM,EAAE,iBAAiB;QACzB,OAAO,EAAE,cAAc;KACxB;IACD;QACE,KAAK,EAAE,IAAI;QACX,MAAM,EAAE,eAAe;QACvB,OAAO,EAAE,WAAW;KACrB;IACD;QACE,KAAK,EAAE,QAAQ;QACf,MAAM,EAAE,YAAY;QACpB,OAAO,EAAE,iBAAiB;KAC3B;CACF,CAAC","sourcesContent":["import { SdBadgeColor } from '@sd-angular/core/badge';\r\n\r\nexport type SdGridMaterialColumn<T = any> =\r\n  | SdGridMaterialColumnText<T>\r\n  | SdGridMaterialColumnNumber<T>\r\n  | SdGridMaterialBool<T>\r\n  | SdGridMaterialColumnDate<T>\r\n  | SdGridMaterialColumnValues<T>\r\n  | SdGridMaterialColumnImage<T>\r\n  | SdGridMaterialColumnChildren<T>\r\n  | SdGridMaterialColumnChildrenCol<T>;\r\n\r\nexport type SdFilterOperator =\r\n  | 'EQUAL'\r\n  | 'NOT_EQUAL'\r\n  | 'CONTAIN'\r\n  | 'NOT_CONTAIN'\r\n  | 'IN'\r\n  | 'NOT_IN'\r\n  | 'START_WITH'\r\n  | 'END_WITH'\r\n  | 'GREATER_THAN'\r\n  | 'LESS_THAN'\r\n  | 'GREATER_OR_EQUAL'\r\n  | 'LESS_OR_EQUAL';\r\n\r\nexport const SdFilterOperators: { value: SdFilterOperator, symbol?: string, display: string }[] = [\r\n  {\r\n    value: 'EQUAL',\r\n    symbol: '=',\r\n    display: 'Bằng',\r\n  },\r\n  {\r\n    value: 'NOT_EQUAL',\r\n    symbol: '!=',\r\n    display: 'Không bằng',\r\n  },\r\n  {\r\n    value: 'GREATER_THAN',\r\n    symbol: '>',\r\n    display: 'Lớn hơn',\r\n  },\r\n  {\r\n    value: 'LESS_THAN',\r\n    symbol: '<',\r\n    display: 'Nhỏ hơn',\r\n  },\r\n  {\r\n    value: 'GREATER_OR_EQUAL',\r\n    symbol: '>=',\r\n    display: 'Lớn hơn, hoặc bằng'\r\n  },\r\n  {\r\n    value: 'LESS_OR_EQUAL',\r\n    symbol: '<=',\r\n    display: 'Nhỏ hơn, hoặc bằng'\r\n  },\r\n  {\r\n    value: 'CONTAIN',\r\n    symbol: 'join_inner',\r\n    display: 'Chứa',\r\n  },\r\n  {\r\n    value: 'NOT_CONTAIN',\r\n    symbol: 'join',\r\n    display: 'Không chứa',\r\n  },\r\n  {\r\n    value: 'START_WITH',\r\n    symbol: 'line_start_circle',\r\n    display: 'Bắt đầu bởi'\r\n  },\r\n  {\r\n    value: 'END_WITH',\r\n    symbol: 'line_end_circle',\r\n    display: 'Kết thúc bởi'\r\n  },\r\n  {\r\n    value: 'IN',\r\n    symbol: 'checklist_rtl',\r\n    display: 'Nằm trong'\r\n  },\r\n  {\r\n    value: 'NOT_IN',\r\n    symbol: 'event_list',\r\n    display: 'Không nằm trong'\r\n  },\r\n];\r\n\r\nexport type TransformFunc<T = any> = (\r\n  value: any,\r\n  rowData: T,\r\n  args?: {\r\n    isExport?: boolean;\r\n  }\r\n) => string | Promise<string>;\r\n\r\ninterface SdGridMaterialBaseColumn<T = any> {\r\n  field: string;\r\n  title: string;\r\n  titleHtml?: string;\r\n  description?: string;\r\n  width?: string;\r\n  hidden?: boolean;\r\n  invisible?: boolean;\r\n  fixed?: boolean;\r\n  align?: 'center' | 'left' | 'right';\r\n  htmlTemplate?: (value: any, rowData: T, isMobileOrTablet: boolean) => string;\r\n  transform?: TransformFunc<T>;\r\n  tooltip?: (value: any, rowData: T) => string;\r\n  click?: (value: any, rowData: T) => void;\r\n  sortable?: boolean;\r\n  filter?: {\r\n    disabled?: boolean;\r\n    defaultShowing?: boolean;\r\n    default?: any;\r\n    // Chỉ dành cho filter inline column\r\n    operator?: {\r\n      enable?: boolean;\r\n      list?: SdFilterOperator[];\r\n    };\r\n  };\r\n  export?: {\r\n    disabled?: boolean;\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialColumnText<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'string';\r\n  badge?: (value: any, rowData: T) => SdBadgeColor;\r\n  badgeIcon?: (value: any, rowData: T) => string;\r\n  badgeType?: 'circle' | 'icon';\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n    minLength?: number;\r\n    maxLength?: number;\r\n    validator?: (rowData: T) => string;\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialColumnNumber<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'number';\r\n  badge?: (value: any, rowData: T) => SdBadgeColor;\r\n  badgeIcon?: (value: any, rowData: T) => string;\r\n  badgeType?: 'circle' | 'icon';\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n    minValue?: number;\r\n    maxValue?: number;\r\n    precision?: number;\r\n    validator?: (rowData: T) => string;\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialBool<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'bool';\r\n  option?: {\r\n    displayOnTrue?: string;\r\n    displayOnFalse?: string;\r\n  };\r\n  badgeType?: 'circle';\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialColumnDate<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'date' | 'datetime' | 'time';\r\n  option?: {\r\n    useFilterDate?: boolean;\r\n    timeDifferent?: 'second' | 'minute' | 'hour' | 'day' | 'month';\r\n  };\r\n  transformDate?: (value: any, rowData: T) => string | Date;\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n  };\r\n}\r\n\r\nexport interface SdGridMaterialColumnValues<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'values';\r\n  badge?: (value: any, rowData: T) => SdBadgeColor;\r\n  badgeIcon?: (value: any, rowData: T) => string;\r\n  badgeType?: 'circle' | 'icon';\r\n  option: {\r\n    items: any[] | ((searchText?: string, isFormValue?: boolean) => Promise<any[]>) | ((searchText?: string[], isFormValue?: boolean) => Promise<any[]>);\r\n    valueField: string;\r\n    displayField: string;\r\n    selection?:\r\n      | 'AUTOCOMPLETE'\r\n      | 'MULTIPLE'\r\n      | 'MULTIPLEAUTOCOMPLETE'\r\n      | 'AUTOCOMPLETE_EDITOR'\r\n      | 'MULTIPLE_EDITOR'\r\n      | 'MULTIPLEAUTOCOMPLETE_EDITOR';\r\n  };\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    add?: (rowData: T) => void;\r\n    edit?: (option: any, rowData: T) => void;\r\n    delete?: (option: any, rowData: T) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n  };\r\n}\r\n\r\ninterface SdGridMaterialColumnImage<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'image';\r\n  option: {\r\n    height: number;\r\n    width: number;\r\n  };\r\n  editor?: {\r\n    change?: (rowData: T, selected?: any) => void;\r\n    hidden?: boolean | ((rowData: T) => boolean);\r\n    disabled?: boolean | ((rowData: T) => boolean);\r\n    required?: boolean | ((rowData: T) => boolean);\r\n  };\r\n}\r\n\r\ntype SdGridMaterialNormalColumn<T> = Exclude<\r\n  Exclude<SdGridMaterialColumn<T>, SdGridMaterialColumnChildren<T>>,\r\n  SdGridMaterialColumnChildrenCol<T>\r\n>;\r\n\r\nexport type SdGridMaterialChildColumn<T = any> = SdGridMaterialNormalColumn<T> & {\r\n  dynamicTitle?: (rowData: T) => string | Promise<string>;\r\n  colSpan: 1 | 2;\r\n};\r\n\r\nexport interface SdGridMaterialColumnChildren<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'children';\r\n  children: SdGridMaterialChildColumn<T>[];\r\n}\r\n\r\nexport interface SdGridMaterialColumnChildrenCol<T = any> extends SdGridMaterialBaseColumn<T> {\r\n  type: 'children-col';\r\n  children: SdGridMaterialNormalColumn<T>[];\r\n}\r\n"]}
|
|
@@ -2,8 +2,8 @@ import { InjectionToken } from '@angular/core';
|
|
|
2
2
|
export const DEFAULT_GRID_MATERIAL_CONFIG = {
|
|
3
3
|
paginate: {
|
|
4
4
|
pageSize: 50,
|
|
5
|
-
pages: [50, 100, 200]
|
|
6
|
-
}
|
|
5
|
+
pages: [50, 100, 200],
|
|
6
|
+
},
|
|
7
7
|
};
|
|
8
8
|
export const GRID_MATERIAL_CONFIG = new InjectionToken('sd-grid-material.configuration');
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1jb25maWd1cmF0aW9uLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLW1hdGVyaWFsLyIsInNvdXJjZXMiOlsic3JjL2xpYi9tb2RlbHMvZ3JpZC1jb25maWd1cmF0aW9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFtQi9DLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFpQztJQUN4RSxRQUFRLEVBQUU7UUFDUixRQUFRLEVBQUUsRUFBRTtRQUNaLEtBQUssRUFBRSxDQUFDLEVBQUUsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDO0tBQ3RCO0NBQ0YsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLElBQUksY0FBYyxDQUErQixnQ0FBZ0MsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2RGaWx0ZXJPcGVyYXRvciB9IGZyb20gJy4vZ3JpZC1jb2x1bW4ubW9kZWwnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJU2RHcmlkTWF0ZXJpYWxDb25maWd1cmF0aW9uIHtcclxuICBmaWx0ZXI/OiB7XHJcbiAgICBxdWlja0ZpbHRlcj86IGJvb2xlYW47XHJcbiAgICBvcGVyYXRvcj86IHtcclxuICAgICAgZGVmYXVsdExpc3RTdHJpbmc/OiBTZEZpbHRlck9wZXJhdG9yW107XHJcbiAgICAgIGRlZmF1bHRMaXN0TnVtYmVyPzogU2RGaWx0ZXJPcGVyYXRvcltdO1xyXG4gICAgICBkZWZhdWx0TGlzdERhdGU/OiBTZEZpbHRlck9wZXJhdG9yW107XHJcbiAgICB9O1xyXG4gIH07XHJcbiAgcGFnaW5hdGU/OiB7XHJcbiAgICBwYWdlU2l6ZT86IG51bWJlcjtcclxuICAgIHBhZ2VzPzogbnVtYmVyW107XHJcbiAgfTtcclxuICB0cmFuc2xhdGU/OiBib29sZWFuO1xyXG59XHJcblxyXG5leHBvcnQgY29uc3QgREVGQVVMVF9HUklEX01BVEVSSUFMX0NPTkZJRzogSVNkR3JpZE1hdGVyaWFsQ29uZmlndXJhdGlvbiA9IHtcclxuICBwYWdpbmF0ZToge1xyXG4gICAgcGFnZVNpemU6IDUwLFxyXG4gICAgcGFnZXM6IFs1MCwgMTAwLCAyMDBdLFxyXG4gIH0sXHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgR1JJRF9NQVRFUklBTF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48SVNkR3JpZE1hdGVyaWFsQ29uZmlndXJhdGlvbj4oJ3NkLWdyaWQtbWF0ZXJpYWwuY29uZmlndXJhdGlvbicpO1xyXG4iXX0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-angular-core-button.js","sources":["../../../../projects/sd-core/button/src/lib/button.component.ts","../../../../projects/sd-core/button/src/lib/button.module.ts","../../../../projects/sd-core/button/src/public-api.ts","../../../../projects/sd-core/button/sd-angular-core-button.ts"],"sourcesContent":["import {\r\n Component,\r\n Input,\r\n Output,\r\n EventEmitter,\r\n ChangeDetectorRef,\r\n OnInit,\r\n AfterViewInit,\r\n ViewChild,\r\n ElementRef,\r\n ChangeDetectionStrategy,\r\n} from '@angular/core';\r\nimport { Subscription, fromEvent } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { MatButton } from '@angular/material/button';\r\n\r\n@Component({\r\n selector: 'sd-button',\r\n templateUrl: './button.component.html',\r\n styleUrls: ['./button.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n host: {\r\n '[attr.disabled]': 'isDisabled ? true : null'\r\n }\r\n})\r\n\r\nexport class SdButton implements OnInit, AfterViewInit {\r\n @ViewChild('button') button: MatButton;\r\n #disabled = false;\r\n #initialized = false;\r\n isDisabled = false;\r\n type: 'fill' | 'light' | 'outline' | 'link' = 'light';\r\n @Input('type') set _type(type: 'fill' | 'light' | 'outline' | 'link') {\r\n this.type = type || 'light';\r\n }\r\n color: 'primary' | 'accent' | 'warn' | 'info' | 'success' | 'warning' | 'danger' | 'secondary' = 'secondary';\r\n @Input('color') set _color(color: 'primary' | 'accent' | 'warn' | 'info' | 'success' | 'warning' | 'danger' | 'secondary') {\r\n this.color = color || 'secondary';\r\n }\r\n @Input() title: string;\r\n @Input() icon: string;\r\n @Input() width: string;\r\n @Input() size: 'sm' | 'lg';\r\n @Input() tooltip: string;\r\n @Input() iconSuffix = false;\r\n @Input() fontSet: 'material-icons' |\r\n 'material-icons-outlined' |\r\n 'material-icons-round' |\r\n 'material-icons-sharp' = 'material-icons';\r\n @Input() set disabled(value: boolean) {\r\n this.#disabled = value || false;\r\n if (this.#initialized) {\r\n this.#onChanges();\r\n }\r\n }\r\n @Input() loading = false;\r\n @Output() action = new EventEmitter();\r\n #subscription = new Subscription();\r\n constructor(private ref: ChangeDetectorRef) {\r\n }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n ngAfterViewInit() {\r\n this.#onChanges();\r\n this.#subscription.add(fromEvent(this.button._elementRef.nativeElement, 'click').pipe(debounceTime(200)).subscribe($event => {\r\n if (this.loading) {\r\n return;\r\n }\r\n this.action.emit($event);\r\n }));\r\n this.#initialized = true;\r\n }\r\n\r\n ngOnDestroy() {\r\n this.#subscription.unsubscribe();\r\n }\r\n\r\n #onChanges = () => {\r\n this.isDisabled = this.#disabled;\r\n this.ref.detectChanges();\r\n }\r\n\r\n onClick = ($event: any) => {\r\n if (this.loading) {\r\n return;\r\n }\r\n this.action.emit($event);\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { SdButton } from './button.component';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n MatIconModule,\r\n MatButtonModule,\r\n MatProgressSpinnerModule,\r\n MatTooltipModule\r\n ],\r\n declarations: [\r\n SdButton\r\n ],\r\n exports: [\r\n SdButton\r\n ]\r\n})\r\nexport class SdButtonModule { }\r\n","/*\r\n * Public API Surface of superdev-angular-core\r\n */\r\n\r\nexport { SdButtonModule } from './lib/button.module';\r\nexport * from './lib/button.component';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;;;MA0Ba,QAAQ;
|
|
1
|
+
{"version":3,"file":"sd-angular-core-button.js","sources":["../../../../projects/sd-core/button/src/lib/button.component.ts","../../../../projects/sd-core/button/src/lib/button.module.ts","../../../../projects/sd-core/button/src/public-api.ts","../../../../projects/sd-core/button/sd-angular-core-button.ts"],"sourcesContent":["import {\r\n Component,\r\n Input,\r\n Output,\r\n EventEmitter,\r\n ChangeDetectorRef,\r\n OnInit,\r\n AfterViewInit,\r\n ViewChild,\r\n ElementRef,\r\n ChangeDetectionStrategy,\r\n} from '@angular/core';\r\nimport { Subscription, fromEvent } from 'rxjs';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { MatButton } from '@angular/material/button';\r\n\r\n@Component({\r\n selector: 'sd-button',\r\n templateUrl: './button.component.html',\r\n styleUrls: ['./button.component.scss'],\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n host: {\r\n '[attr.disabled]': 'isDisabled ? true : null'\r\n }\r\n})\r\n\r\nexport class SdButton implements OnInit, AfterViewInit {\r\n @ViewChild('button') button: MatButton;\r\n #disabled = false;\r\n #initialized = false;\r\n isDisabled = false;\r\n type: 'fill' | 'light' | 'outline' | 'link' = 'light';\r\n @Input('type') set _type(type: 'fill' | 'light' | 'outline' | 'link') {\r\n this.type = type || 'light';\r\n }\r\n color: 'primary' | 'accent' | 'warn' | 'info' | 'success' | 'warning' | 'danger' | 'secondary' = 'secondary';\r\n @Input('color') set _color(color: 'primary' | 'accent' | 'warn' | 'info' | 'success' | 'warning' | 'danger' | 'secondary') {\r\n this.color = color || 'secondary';\r\n }\r\n @Input() title: string;\r\n @Input() icon: string;\r\n @Input() width: string;\r\n @Input() size: 'sm' | 'lg';\r\n @Input() tooltip: string;\r\n @Input() iconSuffix = false;\r\n @Input() fontSet: 'material-icons' |\r\n 'material-icons-outlined' |\r\n 'material-icons-round' |\r\n 'material-icons-sharp' |\r\n 'material-symbols-outlined' = 'material-icons';\r\n @Input() set disabled(value: boolean) {\r\n this.#disabled = value || false;\r\n if (this.#initialized) {\r\n this.#onChanges();\r\n }\r\n }\r\n @Input() loading = false;\r\n @Output() action = new EventEmitter();\r\n #subscription = new Subscription();\r\n constructor(private ref: ChangeDetectorRef) {\r\n }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n ngAfterViewInit() {\r\n this.#onChanges();\r\n this.#subscription.add(fromEvent(this.button._elementRef.nativeElement, 'click').pipe(debounceTime(200)).subscribe($event => {\r\n if (this.loading) {\r\n return;\r\n }\r\n this.action.emit($event);\r\n }));\r\n this.#initialized = true;\r\n }\r\n\r\n ngOnDestroy() {\r\n this.#subscription.unsubscribe();\r\n }\r\n\r\n #onChanges = () => {\r\n this.isDisabled = this.#disabled;\r\n this.ref.detectChanges();\r\n }\r\n\r\n onClick = ($event: any) => {\r\n if (this.loading) {\r\n return;\r\n }\r\n this.action.emit($event);\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { SdButton } from './button.component';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n MatIconModule,\r\n MatButtonModule,\r\n MatProgressSpinnerModule,\r\n MatTooltipModule\r\n ],\r\n declarations: [\r\n SdButton\r\n ],\r\n exports: [\r\n SdButton\r\n ]\r\n})\r\nexport class SdButtonModule { }\r\n","/*\r\n * Public API Surface of superdev-angular-core\r\n */\r\n\r\nexport { SdButtonModule } from './lib/button.module';\r\nexport * from './lib/button.component';\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;;;MA0Ba,QAAQ;IAiCnB,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QA/B1C,oBAAY,KAAK,EAAC;QAClB,uBAAe,KAAK,EAAC;QACrB,eAAU,GAAG,KAAK,CAAC;QACnB,SAAI,GAA0C,OAAO,CAAC;QAItD,UAAK,GAA4F,WAAW,CAAC;QASpG,eAAU,GAAG,KAAK,CAAC;QACnB,YAAO,GAIgB,gBAAgB,CAAC;QAOxC,YAAO,GAAG,KAAK,CAAC;QACf,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QACtC,wBAAgB,IAAI,YAAY,EAAE,EAAC;QAsBnC,qBAAa;YACX,IAAI,CAAC,UAAU,0CAAiB,CAAC;YACjC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;SAC1B,EAAA;QAED,YAAO,GAAG,CAAC,MAAW;YACpB,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChB,OAAO;aACR;YACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC1B,CAAA;KA9BA;IA5BD,IAAmB,KAAK,CAAC,IAA2C;QAClE,IAAI,CAAC,IAAI,GAAG,IAAI,IAAI,OAAO,CAAC;KAC7B;IAED,IAAoB,MAAM,CAAC,KAA8F;QACvH,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,WAAW,CAAC;KACnC;IAYD,IAAa,QAAQ,CAAC,KAAc;QAClC,uBAAA,IAAI,aAAa,KAAK,IAAI,KAAK,EAAC;QAChC,gDAAuB;YACrB,8CAAA,IAAI,CAAa,CAAC;SACnB;KACF;IAOD,QAAQ;KACP;IAED,eAAe;QACb,8CAAA,IAAI,CAAa,CAAC;QAClB,4CAAmB,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM;YACvH,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChB,OAAO;aACR;YACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC1B,CAAC,CAAC,CAAC;QACJ,uBAAA,IAAI,gBAAgB,IAAI,EAAC;KAC1B;IAED,WAAW;QACT,4CAAmB,WAAW,EAAE,CAAC;KAClC;;;;YA9DF,SAAS,SAAC;gBACT,QAAQ,EAAE,WAAW;gBACrB,w5EAAsC;gBAEtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,IAAI,EAAE;oBACJ,iBAAiB,EAAE,0BAA0B;iBAC9C;;aACF;;;YAnBC,iBAAiB;;;qBAsBhB,SAAS,SAAC,QAAQ;oBAKlB,KAAK,SAAC,MAAM;qBAIZ,KAAK,SAAC,OAAO;oBAGb,KAAK;mBACL,KAAK;oBACL,KAAK;mBACL,KAAK;sBACL,KAAK;yBACL,KAAK;sBACL,KAAK;uBAKL,KAAK;sBAML,KAAK;qBACL,MAAM;;;MClCI,cAAc;;;YAf1B,QAAQ,SAAC;gBACR,OAAO,EAAE;oBACP,YAAY;oBACZ,aAAa;oBACb,eAAe;oBACf,wBAAwB;oBACxB,gBAAgB;iBACjB;gBACD,YAAY,EAAE;oBACZ,QAAQ;iBACT;gBACD,OAAO,EAAE;oBACP,QAAQ;iBACT;aACF;;;ACtBD;;;;ACAA;;;;;;"}
|
|
@@ -128,8 +128,8 @@ SdMaterialSubInformationDefDirective.ctorParameters = () => [
|
|
|
128
128
|
const DEFAULT_GRID_MATERIAL_CONFIG = {
|
|
129
129
|
paginate: {
|
|
130
130
|
pageSize: 50,
|
|
131
|
-
pages: [50, 100, 200]
|
|
132
|
-
}
|
|
131
|
+
pages: [50, 100, 200],
|
|
132
|
+
},
|
|
133
133
|
};
|
|
134
134
|
const GRID_MATERIAL_CONFIG = new InjectionToken('sd-grid-material.configuration');
|
|
135
135
|
|
|
@@ -1441,7 +1441,7 @@ class SdGridMaterial {
|
|
|
1441
1441
|
};
|
|
1442
1442
|
});
|
|
1443
1443
|
_initConfiguration$1.set(this, (option) => {
|
|
1444
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
|
|
1444
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4;
|
|
1445
1445
|
// Init pagination
|
|
1446
1446
|
option.paginate = {
|
|
1447
1447
|
hidden: (_a = option === null || option === void 0 ? void 0 : option.paginate) === null || _a === void 0 ? void 0 : _a.hidden,
|
|
@@ -1449,6 +1449,19 @@ class SdGridMaterial {
|
|
|
1449
1449
|
pages: (_m = (_j = (_h = option === null || option === void 0 ? void 0 : option.paginate) === null || _h === void 0 ? void 0 : _h.pages) !== null && _j !== void 0 ? _j : (_l = (_k = this.configuration) === null || _k === void 0 ? void 0 : _k.paginate) === null || _l === void 0 ? void 0 : _l.pages) !== null && _m !== void 0 ? _m : (_o = DEFAULT_GRID_MATERIAL_CONFIG.paginate) === null || _o === void 0 ? void 0 : _o.pages,
|
|
1450
1450
|
showFirstLastButtons: (_q = (_p = option === null || option === void 0 ? void 0 : option.paginate) === null || _p === void 0 ? void 0 : _p.showFirstLastButtons) !== null && _q !== void 0 ? _q : false,
|
|
1451
1451
|
};
|
|
1452
|
+
for (const column of option.columns || []) {
|
|
1453
|
+
if (((_s = (_r = column.filter) === null || _r === void 0 ? void 0 : _r.operator) === null || _s === void 0 ? void 0 : _s.enable) && !((_v = (_u = (_t = column.filter) === null || _t === void 0 ? void 0 : _t.operator) === null || _u === void 0 ? void 0 : _u.list) === null || _v === void 0 ? void 0 : _v.length)) {
|
|
1454
|
+
if (column.type === 'string') {
|
|
1455
|
+
column.filter.operator.list = ((_y = (_x = (_w = this.configuration) === null || _w === void 0 ? void 0 : _w.filter) === null || _x === void 0 ? void 0 : _x.operator) === null || _y === void 0 ? void 0 : _y.defaultListString) || [];
|
|
1456
|
+
}
|
|
1457
|
+
if (column.type === 'number') {
|
|
1458
|
+
column.filter.operator.list = ((_1 = (_0 = (_z = this.configuration) === null || _z === void 0 ? void 0 : _z.filter) === null || _0 === void 0 ? void 0 : _0.operator) === null || _1 === void 0 ? void 0 : _1.defaultListNumber) || [];
|
|
1459
|
+
}
|
|
1460
|
+
if (column.type === 'date' || column.type === 'datetime') {
|
|
1461
|
+
column.filter.operator.list = ((_4 = (_3 = (_2 = this.configuration) === null || _2 === void 0 ? void 0 : _2.filter) === null || _3 === void 0 ? void 0 : _3.operator) === null || _4 === void 0 ? void 0 : _4.defaultListDate) || [];
|
|
1462
|
+
}
|
|
1463
|
+
}
|
|
1464
|
+
}
|
|
1452
1465
|
return option;
|
|
1453
1466
|
});
|
|
1454
1467
|
_loadFilterRegister.set(this, () => {
|
|
@@ -3470,39 +3483,63 @@ SdDesktopEditorValidation.propDecorators = {
|
|
|
3470
3483
|
const SdFilterOperators = [
|
|
3471
3484
|
{
|
|
3472
3485
|
value: 'EQUAL',
|
|
3473
|
-
|
|
3486
|
+
symbol: '=',
|
|
3487
|
+
display: 'Bằng',
|
|
3474
3488
|
},
|
|
3475
3489
|
{
|
|
3476
3490
|
value: 'NOT_EQUAL',
|
|
3477
|
-
|
|
3478
|
-
|
|
3479
|
-
{
|
|
3480
|
-
value: 'CONTAIN',
|
|
3481
|
-
display: '∈',
|
|
3491
|
+
symbol: '!=',
|
|
3492
|
+
display: 'Không bằng',
|
|
3482
3493
|
},
|
|
3483
|
-
// {
|
|
3484
|
-
// value: 'START_WITH';
|
|
3485
|
-
// display: '=';
|
|
3486
|
-
// },
|
|
3487
|
-
// {
|
|
3488
|
-
// value: 'END_WITH';
|
|
3489
|
-
// display: '=';
|
|
3490
|
-
// },
|
|
3491
3494
|
{
|
|
3492
3495
|
value: 'GREATER_THAN',
|
|
3493
|
-
|
|
3496
|
+
symbol: '>',
|
|
3497
|
+
display: 'Lớn hơn',
|
|
3494
3498
|
},
|
|
3495
3499
|
{
|
|
3496
3500
|
value: 'LESS_THAN',
|
|
3497
|
-
|
|
3501
|
+
symbol: '<',
|
|
3502
|
+
display: 'Nhỏ hơn',
|
|
3498
3503
|
},
|
|
3499
3504
|
{
|
|
3500
3505
|
value: 'GREATER_OR_EQUAL',
|
|
3501
|
-
|
|
3506
|
+
symbol: '>=',
|
|
3507
|
+
display: 'Lớn hơn, hoặc bằng'
|
|
3502
3508
|
},
|
|
3503
3509
|
{
|
|
3504
3510
|
value: 'LESS_OR_EQUAL',
|
|
3505
|
-
|
|
3511
|
+
symbol: '<=',
|
|
3512
|
+
display: 'Nhỏ hơn, hoặc bằng'
|
|
3513
|
+
},
|
|
3514
|
+
{
|
|
3515
|
+
value: 'CONTAIN',
|
|
3516
|
+
symbol: 'join_inner',
|
|
3517
|
+
display: 'Chứa',
|
|
3518
|
+
},
|
|
3519
|
+
{
|
|
3520
|
+
value: 'NOT_CONTAIN',
|
|
3521
|
+
symbol: 'join',
|
|
3522
|
+
display: 'Không chứa',
|
|
3523
|
+
},
|
|
3524
|
+
{
|
|
3525
|
+
value: 'START_WITH',
|
|
3526
|
+
symbol: 'line_start_circle',
|
|
3527
|
+
display: 'Bắt đầu bởi'
|
|
3528
|
+
},
|
|
3529
|
+
{
|
|
3530
|
+
value: 'END_WITH',
|
|
3531
|
+
symbol: 'line_end_circle',
|
|
3532
|
+
display: 'Kết thúc bởi'
|
|
3533
|
+
},
|
|
3534
|
+
{
|
|
3535
|
+
value: 'IN',
|
|
3536
|
+
symbol: 'checklist_rtl',
|
|
3537
|
+
display: 'Nằm trong'
|
|
3538
|
+
},
|
|
3539
|
+
{
|
|
3540
|
+
value: 'NOT_IN',
|
|
3541
|
+
symbol: 'event_list',
|
|
3542
|
+
display: 'Không nằm trong'
|
|
3506
3543
|
},
|
|
3507
3544
|
];
|
|
3508
3545
|
|
|
@@ -3510,6 +3547,7 @@ var _valueChanges, _subcription;
|
|
|
3510
3547
|
class SdColumnInlineFilter {
|
|
3511
3548
|
constructor() {
|
|
3512
3549
|
this.columnOperator = {};
|
|
3550
|
+
this.columnSymbol = 'filter_alt';
|
|
3513
3551
|
this.columnFilter = {};
|
|
3514
3552
|
this.operators = [];
|
|
3515
3553
|
this.filterChange = new EventEmitter();
|
|
@@ -3561,7 +3599,7 @@ _valueChanges = new WeakMap(), _subcription = new WeakMap();
|
|
|
3561
3599
|
SdColumnInlineFilter.decorators = [
|
|
3562
3600
|
{ type: Component, args: [{
|
|
3563
3601
|
selector: 'sd-column-inline-filter',
|
|
3564
|
-
template: "<div class=\"d-flex c-inline-column\">\r\n <ng-container\r\n *ngIf=\"\r\n column.type === 'string' ||\r\n column.type === 'number' ||\r\n column.type === 'bool' ||\r\n column.type === 'values' ||\r\n column.type === 'date' ||\r\n column.type === 'datetime' ||\r\n column.type === 'time';\r\n else noFilter\r\n \">\r\n <sd-select\r\n *ngIf=\"operators.length\"\r\n style=\"width: 60px; margin-right: 4px\"\r\n size=\"sm\"\r\n [items]=\"operators\"\r\n valueField=\"value\"\r\n displayField=\"display\"\r\n
|
|
3602
|
+
template: "<div class=\"d-flex c-inline-column align-items-end\">\r\n <ng-container\r\n *ngIf=\"\r\n column.type === 'string' ||\r\n column.type === 'number' ||\r\n column.type === 'bool' ||\r\n column.type === 'values' ||\r\n column.type === 'date' ||\r\n column.type === 'datetime' ||\r\n column.type === 'time';\r\n else noFilter\r\n \">\r\n <ng-container *ngIf=\"operators.length\">\r\n <!-- <div style=\"width: 60px; margin-right: 4px\" [matMenuTriggerFor]=\"menu\">\r\n <span>=</span>\r\n </div> -->\r\n <sd-button class=\"mr-2\" fontSet=\"material-symbols-outlined\" [icon]=\"columnSymbol\" size=\"sm\" [matMenuTriggerFor]=\"menu\" type=\"link\"> </sd-button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button\r\n *ngFor=\"let operator of operators\"\r\n (click)=\"columnOperator[column.field] = operator.value; columnSymbol = operator.symbol\"\r\n mat-menu-item\r\n type=\"button\">\r\n <mat-icon fontSet=\"material-symbols-outlined\">{{ operator.symbol }}</mat-icon>\r\n <span> {{ operator.display }}</span>\r\n </button>\r\n </mat-menu>\r\n </ng-container>\r\n <!-- <sd-select\r\n *ngIf=\"operators.length\"\r\n style=\"width: 60px; margin-right: 4px\"\r\n size=\"sm\"\r\n [items]=\"operators\"\r\n valueField=\"value\"\r\n displayField=\"display\"\r\n [(model)]=\"columnOperator[column.field]\"></sd-select> -->\r\n <sd-input\r\n *ngIf=\"column.type === 'string'\"\r\n style=\"flex: 1\"\r\n size=\"sm\"\r\n type=\"text\"\r\n [(model)]=\"columnFilter[column.field]\"\r\n (keyupEnter)=\"onFilterChange()\"\r\n [disabled]=\"column.filter?.disabled\">\r\n </sd-input>\r\n <sd-input-number\r\n *ngIf=\"column.type === 'number'\"\r\n style=\"flex: 1\"\r\n size=\"sm\"\r\n [(model)]=\"columnFilter[column.field]\"\r\n (keyupEnter)=\"onFilterChange()\"\r\n [disabled]=\"column.filter?.disabled\">\r\n </sd-input-number>\r\n <sd-select\r\n *ngIf=\"column.type === 'bool'\"\r\n style=\"flex: 1\"\r\n size=\"sm\"\r\n [items]=\"[\r\n { value: '1', display: column.option?.displayOnTrue || 'True' },\r\n { value: '0', display: column.option?.displayOnFalse || 'False' }\r\n ]\"\r\n valueField=\"value\"\r\n displayField=\"display\"\r\n [(model)]=\"columnFilter[column.field]\"\r\n (sdChange)=\"onFilterChange()\"\r\n [disabled]=\"column.filter?.disabled\">\r\n <ng-template sdSelectDisplayDef let-item=\"item\">\r\n <sd-badge *ngIf=\"item.value === '1'\" color=\"success\" [title]=\"column.option?.displayOnTrue || 'True'\"> </sd-badge>\r\n <sd-badge *ngIf=\"item.value === '0'\" color=\"danger\" [title]=\"column.option?.displayOnFalse || 'False'\"> </sd-badge>\r\n </ng-template>\r\n </sd-select>\r\n <sd-select\r\n *ngIf=\"column.type === 'values' && column?.option?.selection !== 'AUTOCOMPLETE'\"\r\n style=\"flex: 1\"\r\n size=\"sm\"\r\n [items]=\"column.option.items\"\r\n [valueField]=\"column.option.valueField\"\r\n [displayField]=\"column.option.displayField\"\r\n [(model)]=\"columnFilter[column.field]\"\r\n (sdChange)=\"onFilterChange()\"\r\n [disabled]=\"column.filter?.disabled\"\r\n [multiple]=\"column?.option?.selection === 'MULTIPLE' || column?.option?.selection === 'MULTIPLEAUTOCOMPLETE'\"\r\n [filtered]=\"column?.option?.selection === 'MULTIPLEAUTOCOMPLETE'\">\r\n </sd-select>\r\n <sd-autocomplete\r\n *ngIf=\"column.type === 'values' && column?.option?.selection === 'AUTOCOMPLETE'\"\r\n style=\"flex: 1\"\r\n size=\"sm\"\r\n [items]=\"column.option.items\"\r\n [valueField]=\"column.option.valueField\"\r\n [displayField]=\"column.option.displayField\"\r\n [(model)]=\"columnFilter[column.field]\"\r\n (sdChange)=\"onFilterChange()\"\r\n [disabled]=\"column.filter?.disabled\">\r\n </sd-autocomplete>\r\n <ng-container *ngIf=\"column.type === 'date' || column.type === 'datetime' || column.type === 'time'\">\r\n <sd-date-range\r\n *ngIf=\"!column.option?.useFilterDate\"\r\n style=\"flex: 1\"\r\n size=\"sm\"\r\n [(from)]=\"columnFilter[column.field].from\"\r\n [(to)]=\"columnFilter[column.field].to\"\r\n (sdChange)=\"onFilterChange()\"\r\n [disabled]=\"column.filter?.disabled\">\r\n </sd-date-range>\r\n <sd-date-time\r\n *ngIf=\"column.option?.useFilterDate\"\r\n style=\"flex: 1\"\r\n type=\"date\"\r\n size=\"sm\"\r\n [(model)]=\"columnFilter[column.field]\"\r\n (sdChange)=\"onFilterChange()\"\r\n [disabled]=\"column.filter?.disabled\">\r\n </sd-date-time>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #noFilter>\r\n <sd-input type=\"text\" size=\"sm\" disabled> </sd-input>\r\n </ng-template>\r\n</div>\r\n",
|
|
3565
3603
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
3566
3604
|
styles: [":host ::ng-deep .c-inline-column .mat-form-field-wrapper{background-color:#fff;border-radius:8px;margin:8px 0 0!important;padding:0!important}"]
|
|
3567
3605
|
},] }
|