@sd-angular/core 1.3.117 → 1.3.119

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.
Files changed (556) hide show
  1. package/assets/img/file-types/eps/001-file.eps +143 -143
  2. package/assets/img/file-types/eps/002-file-1.eps +136 -136
  3. package/assets/img/file-types/eps/003-file-2.eps +130 -130
  4. package/assets/img/file-types/eps/004-file-3.eps +127 -127
  5. package/assets/img/file-types/eps/005-file-4.eps +120 -120
  6. package/assets/img/file-types/eps/006-file-5.eps +133 -133
  7. package/assets/img/file-types/eps/007-file-6.eps +133 -133
  8. package/assets/img/file-types/eps/008-file-7.eps +144 -144
  9. package/assets/img/file-types/eps/009-file-8.eps +150 -150
  10. package/assets/img/file-types/eps/010-file-9.eps +155 -155
  11. package/assets/img/file-types/eps/011-file-10.eps +124 -124
  12. package/assets/img/file-types/eps/012-file-11.eps +147 -147
  13. package/assets/img/file-types/eps/013-file-12.eps +125 -125
  14. package/assets/img/file-types/eps/014-file-13.eps +129 -129
  15. package/assets/img/file-types/eps/015-file-14.eps +143 -143
  16. package/assets/img/file-types/eps/016-file-15.eps +130 -130
  17. package/assets/img/file-types/eps/017-file-16.eps +197 -197
  18. package/assets/img/file-types/eps/018-file-17.eps +146 -146
  19. package/assets/img/file-types/eps/019-file-18.eps +131 -131
  20. package/assets/img/file-types/eps/020-file-19.eps +137 -137
  21. package/assets/img/file-types/eps/021-file-20.eps +134 -134
  22. package/assets/img/file-types/eps/022-file-21.eps +130 -130
  23. package/assets/img/file-types/eps/023-file-22.eps +161 -161
  24. package/assets/img/file-types/eps/024-file-23.eps +144 -144
  25. package/assets/img/file-types/eps/025-file-24.eps +164 -164
  26. package/assets/img/file-types/eps/026-file-25.eps +135 -135
  27. package/assets/img/file-types/eps/027-file-26.eps +124 -124
  28. package/assets/img/file-types/eps/028-file-27.eps +120 -120
  29. package/assets/img/file-types/eps/029-file-28.eps +141 -141
  30. package/assets/img/file-types/eps/030-file-29.eps +130 -130
  31. package/assets/img/file-types/eps/031-file-30.eps +157 -157
  32. package/assets/img/file-types/eps/032-file-31.eps +139 -139
  33. package/assets/img/file-types/eps/033-file-32.eps +139 -139
  34. package/assets/img/file-types/eps/034-file-33.eps +189 -189
  35. package/assets/img/file-types/eps/035-file-34.eps +162 -162
  36. package/assets/img/file-types/eps/036-file-35.eps +142 -142
  37. package/assets/img/file-types/eps/037-file-36.eps +123 -123
  38. package/assets/img/file-types/eps/038-file-37.eps +127 -127
  39. package/assets/img/file-types/eps/039-file-38.eps +146 -146
  40. package/assets/img/file-types/eps/040-file-39.eps +126 -126
  41. package/assets/img/file-types/eps/041-file-40.eps +117 -117
  42. package/assets/img/file-types/eps/042-file-41.eps +156 -156
  43. package/assets/img/file-types/eps/043-file-42.eps +118 -118
  44. package/assets/img/file-types/eps/044-file-43.eps +172 -172
  45. package/assets/img/file-types/eps/045-file-44.eps +201 -201
  46. package/assets/img/file-types/eps/046-file-45.eps +94 -94
  47. package/assets/img/file-types/eps/047-file-46.eps +176 -176
  48. package/assets/img/file-types/eps/048-file-47.eps +238 -238
  49. package/assets/img/file-types/eps/049-file-48.eps +187 -187
  50. package/assets/img/file-types/eps/050-file-49.eps +137 -137
  51. package/bundles/sd-angular-core-grid-material.umd.js +77 -9
  52. package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
  53. package/bundles/sd-angular-core-grid-material.umd.min.js +2 -2
  54. package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
  55. package/bundles/sd-angular-core-side-drawer.umd.js +21 -1
  56. package/bundles/sd-angular-core-side-drawer.umd.js.map +1 -1
  57. package/bundles/sd-angular-core-side-drawer.umd.min.js +2 -2
  58. package/bundles/sd-angular-core-side-drawer.umd.min.js.map +1 -1
  59. package/esm2015/api/index.js +1 -1
  60. package/esm2015/api/sd-angular-core-api.js +1 -1
  61. package/esm2015/api/src/lib/api.model.js +1 -1
  62. package/esm2015/api/src/lib/api.module.js +1 -1
  63. package/esm2015/api/src/lib/api.service.js +1 -1
  64. package/esm2015/api/src/lib/http.interceptor.js +1 -1
  65. package/esm2015/api/src/lib/http.service.js +1 -1
  66. package/esm2015/api/src/lib/token.service.js +1 -1
  67. package/esm2015/api/src/public-api.js +1 -1
  68. package/esm2015/autocomplete/index.js +1 -1
  69. package/esm2015/autocomplete/sd-angular-core-autocomplete.js +1 -1
  70. package/esm2015/autocomplete/src/lib/autocomplete-display-def.directive.js +1 -1
  71. package/esm2015/autocomplete/src/lib/autocomplete.component.js +1 -1
  72. package/esm2015/autocomplete/src/lib/autocomplete.module.js +1 -1
  73. package/esm2015/autocomplete/src/public-api.js +1 -1
  74. package/esm2015/badge/index.js +1 -1
  75. package/esm2015/badge/sd-angular-core-badge.js +1 -1
  76. package/esm2015/badge/src/lib/badge.component.js +1 -1
  77. package/esm2015/badge/src/lib/badge.module.js +1 -1
  78. package/esm2015/badge/src/public-api.js +1 -1
  79. package/esm2015/button/index.js +1 -1
  80. package/esm2015/button/sd-angular-core-button.js +1 -1
  81. package/esm2015/button/src/lib/button.component.js +1 -1
  82. package/esm2015/button/src/lib/button.module.js +1 -1
  83. package/esm2015/button/src/public-api.js +1 -1
  84. package/esm2015/cache/index.js +1 -1
  85. package/esm2015/cache/sd-angular-core-cache.js +1 -1
  86. package/esm2015/cache/src/lib/cache.model.js +1 -1
  87. package/esm2015/cache/src/lib/cache.service.js +1 -1
  88. package/esm2015/cache/src/public-api.js +1 -1
  89. package/esm2015/chart/index.js +1 -1
  90. package/esm2015/chart/sd-angular-core-chart.js +1 -1
  91. package/esm2015/chart/src/lib/chart.component.js +1 -1
  92. package/esm2015/chart/src/lib/chart.model.js +1 -1
  93. package/esm2015/chart/src/lib/chart.module.js +1 -1
  94. package/esm2015/chart/src/public-api.js +1 -1
  95. package/esm2015/checkbox/index.js +1 -1
  96. package/esm2015/checkbox/sd-angular-core-checkbox.js +1 -1
  97. package/esm2015/checkbox/src/lib/checkbox.component.js +1 -1
  98. package/esm2015/checkbox/src/lib/checkbox.module.js +1 -1
  99. package/esm2015/checkbox/src/public-api.js +1 -1
  100. package/esm2015/chip/index.js +1 -1
  101. package/esm2015/chip/sd-angular-core-chip.js +1 -1
  102. package/esm2015/chip/src/lib/chip.component.js +1 -1
  103. package/esm2015/chip/src/lib/chip.model.js +1 -1
  104. package/esm2015/chip/src/lib/chip.module.js +1 -1
  105. package/esm2015/chip/src/lib/directives/sd-chip-display-def.directive.js +1 -1
  106. package/esm2015/chip/src/lib/pipes/removable-chip.pipe.js +1 -1
  107. package/esm2015/chip/src/public-api.js +1 -1
  108. package/esm2015/comment/index.js +1 -1
  109. package/esm2015/comment/sd-angular-core-comment.js +1 -1
  110. package/esm2015/comment/src/lib/comment.component.js +1 -1
  111. package/esm2015/comment/src/lib/comment.model.js +1 -1
  112. package/esm2015/comment/src/lib/comment.module.js +1 -1
  113. package/esm2015/comment/src/public-api.js +1 -1
  114. package/esm2015/common/index.js +1 -1
  115. package/esm2015/common/sd-angular-core-common.js +1 -1
  116. package/esm2015/common/src/lib/common.module.js +1 -1
  117. package/esm2015/common/src/lib/configurations/firebase.configuration.js +1 -1
  118. package/esm2015/common/src/lib/configurations/form.configuration.js +1 -1
  119. package/esm2015/common/src/lib/directives/sd-lable.directive.js +1 -1
  120. package/esm2015/common/src/lib/directives/sd-let.directive.js +1 -1
  121. package/esm2015/common/src/lib/directives/sd-scroll.directive.js +1 -1
  122. package/esm2015/common/src/lib/directives/sd-suffix.directive.js +1 -1
  123. package/esm2015/common/src/lib/directives/view-def.directive.js +1 -1
  124. package/esm2015/common/src/lib/models/sd-form-control.js +1 -1
  125. package/esm2015/common/src/lib/services/browser.service.js +1 -1
  126. package/esm2015/common/src/lib/typings/array.extension.js +1 -1
  127. package/esm2015/common/src/lib/typings/date.extension.js +1 -1
  128. package/esm2015/common/src/lib/typings/index.js +1 -1
  129. package/esm2015/common/src/lib/typings/number.extension.js +1 -1
  130. package/esm2015/common/src/lib/typings/string.extension.js +1 -1
  131. package/esm2015/common/src/lib/typings/utility.extension.js +1 -1
  132. package/esm2015/common/src/public-api.js +1 -1
  133. package/esm2015/confirm/index.js +1 -1
  134. package/esm2015/confirm/sd-angular-core-confirm.js +1 -1
  135. package/esm2015/confirm/src/lib/components/dialog-confirm/dialog-confirm.component.js +1 -1
  136. package/esm2015/confirm/src/lib/confirm.module.js +1 -1
  137. package/esm2015/confirm/src/lib/confirm.service.js +1 -1
  138. package/esm2015/confirm/src/public-api.js +1 -1
  139. package/esm2015/date-month/index.js +1 -1
  140. package/esm2015/date-month/sd-angular-core-date-month.js +1 -1
  141. package/esm2015/date-month/src/lib/date-month.component.js +1 -1
  142. package/esm2015/date-month/src/lib/date-month.module.js +1 -1
  143. package/esm2015/date-month/src/public-api.js +1 -1
  144. package/esm2015/date-range/index.js +1 -1
  145. package/esm2015/date-range/sd-angular-core-date-range.js +1 -1
  146. package/esm2015/date-range/src/lib/date-range.component.js +1 -1
  147. package/esm2015/date-range/src/lib/date-range.module.js +1 -1
  148. package/esm2015/date-range/src/public-api.js +1 -1
  149. package/esm2015/date-time/index.js +1 -1
  150. package/esm2015/date-time/sd-angular-core-date-time.js +1 -1
  151. package/esm2015/date-time/src/lib/date-time.component.js +1 -1
  152. package/esm2015/date-time/src/lib/date-time.module.js +1 -1
  153. package/esm2015/date-time/src/public-api.js +1 -1
  154. package/esm2015/db/index.js +1 -1
  155. package/esm2015/db/sd-angular-core-db.js +1 -1
  156. package/esm2015/db/src/lib/db.model.js +1 -1
  157. package/esm2015/db/src/lib/db.service.js +1 -1
  158. package/esm2015/db/src/public-api.js +1 -1
  159. package/esm2015/dynamic-report/index.js +1 -1
  160. package/esm2015/dynamic-report/sd-angular-core-dynamic-report.js +1 -1
  161. package/esm2015/dynamic-report/src/lib/dynamic-report.component.js +1 -1
  162. package/esm2015/dynamic-report/src/lib/dynamic-report.module.js +1 -1
  163. package/esm2015/dynamic-report/src/public-api.js +1 -1
  164. package/esm2015/editor/index.js +1 -1
  165. package/esm2015/editor/sd-angular-core-editor.js +1 -1
  166. package/esm2015/editor/src/lib/constant.js +1 -1
  167. package/esm2015/editor/src/lib/editor.component.js +1 -1
  168. package/esm2015/editor/src/lib/editor.model.js +1 -1
  169. package/esm2015/editor/src/lib/editor.module.js +1 -1
  170. package/esm2015/editor/src/public-api.js +1 -1
  171. package/esm2015/export/index.js +1 -1
  172. package/esm2015/export/sd-angular-core-export.js +1 -1
  173. package/esm2015/export/src/lib/excel.model.js +1 -1
  174. package/esm2015/export/src/lib/export.model.js +1 -1
  175. package/esm2015/export/src/lib/export.service.js +1 -1
  176. package/esm2015/export/src/public-api.js +1 -1
  177. package/esm2015/filter/index.js +1 -1
  178. package/esm2015/filter/sd-angular-core-filter.js +1 -1
  179. package/esm2015/filter/src/lib/directives/sd-filter-def.directive.js +1 -1
  180. package/esm2015/filter/src/lib/filter.component.js +1 -1
  181. package/esm2015/filter/src/lib/filter.model.js +1 -1
  182. package/esm2015/filter/src/lib/filter.module.js +1 -1
  183. package/esm2015/filter/src/lib/filter.service.js +1 -1
  184. package/esm2015/filter/src/lib/pipes/values-local.pipe.js +1 -1
  185. package/esm2015/filter/src/lib/pipes/values-server.pipe.js +1 -1
  186. package/esm2015/filter/src/public-api.js +1 -1
  187. package/esm2015/form/index.js +1 -1
  188. package/esm2015/form/sd-angular-core-form.js +1 -1
  189. package/esm2015/form/src/lib/form.module.js +1 -1
  190. package/esm2015/form/src/public-api.js +1 -1
  191. package/esm2015/grid/index.js +1 -1
  192. package/esm2015/grid/sd-angular-core-grid.js +1 -1
  193. package/esm2015/grid/src/lib/components/grid-config/grid-config.component.js +1 -1
  194. package/esm2015/grid/src/lib/components/grid-config/grid-config.model.js +1 -1
  195. package/esm2015/grid/src/lib/components/grid-desktop-column-children-view/grid-desktop-column-children-view.component.js +1 -1
  196. package/esm2015/grid/src/lib/components/grid-desktop-column-edit/grid-desktop-column-edit.component.js +1 -1
  197. package/esm2015/grid/src/lib/components/grid-desktop-column-view/grid-desktop-column-view.component.js +1 -1
  198. package/esm2015/grid/src/lib/components/grid-desktop-inline-filter/grid-desktop-inline-filter.component.js +1 -1
  199. package/esm2015/grid/src/lib/components/grid-import-excel/grid-import-excel.component.js +1 -1
  200. package/esm2015/grid/src/lib/components/grid-mobile-item-view/grid-mobile-item-view.component.js +1 -1
  201. package/esm2015/grid/src/lib/components/grid-popup-editor/grid-popup-editor.component.js +1 -1
  202. package/esm2015/grid/src/lib/components/grid-popup-export-excel/grid-popup-export-excel.component.js +1 -1
  203. package/esm2015/grid/src/lib/components/grid-popup-export-excel/grid-popup-export-excel.model.js +1 -1
  204. package/esm2015/grid/src/lib/components/grid-popup-filter/grid-popup-filter.component.js +1 -1
  205. package/esm2015/grid/src/lib/components/grid-popup-filter/grid-popup-filter.model.js +1 -1
  206. package/esm2015/grid/src/lib/components/grid-popup-quick-filter-detail/grid-popup-quick-filter-detail.component.js +1 -1
  207. package/esm2015/grid/src/lib/components/grid-sub-information/grid-sub-information.component.js +1 -1
  208. package/esm2015/grid/src/lib/directives/cell-def.directive.js +1 -1
  209. package/esm2015/grid/src/lib/directives/cell-editor-def.directive.js +1 -1
  210. package/esm2015/grid/src/lib/directives/cell-footer-def.directive.js +1 -1
  211. package/esm2015/grid/src/lib/directives/sub-information-header-def.directive.js +1 -1
  212. package/esm2015/grid/src/lib/grid.component.js +1 -1
  213. package/esm2015/grid/src/lib/grid.model.js +1 -1
  214. package/esm2015/grid/src/lib/grid.module.js +1 -1
  215. package/esm2015/grid/src/lib/models/filter-info.model.js +1 -1
  216. package/esm2015/grid/src/lib/models/grid-configuration.model.js +1 -1
  217. package/esm2015/grid/src/lib/models/handler-dotnet.js +1 -1
  218. package/esm2015/grid/src/lib/models/handler-local.js +1 -1
  219. package/esm2015/grid/src/lib/models/handler.js +1 -1
  220. package/esm2015/grid/src/lib/pipes/cell-desktop-class-name.pipe.js +1 -1
  221. package/esm2015/grid/src/lib/pipes/cell-mobile-class-name.pipe.js +1 -1
  222. package/esm2015/grid/src/lib/pipes/column-command-filter.pipe.js +1 -1
  223. package/esm2015/grid/src/lib/pipes/column-html-template.pipe.js +1 -1
  224. package/esm2015/grid/src/lib/pipes/column-title.pipe.js +1 -1
  225. package/esm2015/grid/src/lib/pipes/column-values.pipe.js +1 -1
  226. package/esm2015/grid/src/lib/pipes/command-disabled.pipe.js +1 -1
  227. package/esm2015/grid/src/lib/pipes/command-filter.pipe.js +1 -1
  228. package/esm2015/grid/src/lib/pipes/command-hidden.pipe.js +1 -1
  229. package/esm2015/grid/src/lib/pipes/command-icon.pipe.js +1 -1
  230. package/esm2015/grid/src/lib/pipes/command-title.pipe.js +1 -1
  231. package/esm2015/grid/src/lib/pipes/dynamic-items.pipe.js +1 -1
  232. package/esm2015/grid/src/lib/pipes/editor-dynamic-item.pipe.js +1 -1
  233. package/esm2015/grid/src/lib/pipes/editor-handler.pipe.js +1 -1
  234. package/esm2015/grid/src/lib/pipes/editor-popup-visible.pipe.js +1 -1
  235. package/esm2015/grid/src/lib/pipes/editor-sub-information-handler.pipe.js +1 -1
  236. package/esm2015/grid/src/lib/pipes/editor-validate.pipe.js +1 -1
  237. package/esm2015/grid/src/lib/pipes/filter-mobile.pipe.js +1 -1
  238. package/esm2015/grid/src/lib/pipes/mobile-command-filter.js +1 -1
  239. package/esm2015/grid/src/lib/pipes/mobile-view-html-template.pipe.js +1 -1
  240. package/esm2015/grid/src/lib/pipes/value-transform.pipe.js +1 -1
  241. package/esm2015/grid/src/public-api.js +1 -1
  242. package/esm2015/grid-material/index.js +1 -1
  243. package/esm2015/grid-material/sd-angular-core-grid-material.js +1 -1
  244. package/esm2015/grid-material/src/lib/components/column-inline-filter/column-inline-filter.component.js +21 -5
  245. package/esm2015/grid-material/src/lib/components/desktop-cell/desktop-cell.component.js +1 -1
  246. package/esm2015/grid-material/src/lib/components/desktop-cell-children-view/desktop-cell-children-view.component.js +1 -1
  247. package/esm2015/grid-material/src/lib/components/desktop-cell-editor/desktop-cell-editor.component.js +1 -1
  248. package/esm2015/grid-material/src/lib/components/desktop-cell-view/desktop-cell-view.component.js +1 -1
  249. package/esm2015/grid-material/src/lib/components/desktop-command/desktop-command.component.js +1 -1
  250. package/esm2015/grid-material/src/lib/components/desktop-editor-validation/desktop-editor-validation.component.js +1 -1
  251. package/esm2015/grid-material/src/lib/components/dynamic-column/dynamic-column.component.js +1 -1
  252. package/esm2015/grid-material/src/lib/components/grid-filter/grid-filter.component.js +1 -1
  253. package/esm2015/grid-material/src/lib/components/popup-export/popup-export.component.js +1 -1
  254. package/esm2015/grid-material/src/lib/components/popup-filter/popup-filter.component.js +1 -1
  255. package/esm2015/grid-material/src/lib/components/popup-grid-configuration/popup-grid-configuration.component.js +1 -1
  256. package/esm2015/grid-material/src/lib/components/quick-action/quick-action.component.js +1 -1
  257. package/esm2015/grid-material/src/lib/directives/sd-material-cell-def.directive.js +1 -1
  258. package/esm2015/grid-material/src/lib/directives/sd-material-empty-data-def.directive.js +1 -1
  259. package/esm2015/grid-material/src/lib/directives/sd-material-filter-def.directive.js +1 -1
  260. package/esm2015/grid-material/src/lib/directives/sd-material-footer-def.directive.js +1 -1
  261. package/esm2015/grid-material/src/lib/directives/sd-material-sub-information-def.directive.js +1 -1
  262. package/esm2015/grid-material/src/lib/functions/calculate-sd-id.js +1 -1
  263. package/esm2015/grid-material/src/lib/grid-material.component.js +10 -5
  264. package/esm2015/grid-material/src/lib/grid-material.module.js +1 -1
  265. package/esm2015/grid-material/src/lib/models/grid-action.model.js +1 -1
  266. package/esm2015/grid-material/src/lib/models/grid-cell.model.js +1 -1
  267. package/esm2015/grid-material/src/lib/models/grid-column.model.js +39 -2
  268. package/esm2015/grid-material/src/lib/models/grid-command.model.js +1 -1
  269. package/esm2015/grid-material/src/lib/models/grid-config.model.js +1 -1
  270. package/esm2015/grid-material/src/lib/models/grid-configuration.model.js +1 -1
  271. package/esm2015/grid-material/src/lib/models/grid-editor.model.js +1 -1
  272. package/esm2015/grid-material/src/lib/models/grid-export.model.js +1 -1
  273. package/esm2015/grid-material/src/lib/models/grid-group.model.js +1 -1
  274. package/esm2015/grid-material/src/lib/models/grid-option.model.js +1 -1
  275. package/esm2015/grid-material/src/lib/models/grid-reload.model.js +1 -1
  276. package/esm2015/grid-material/src/lib/models/grid-selection.model.js +1 -1
  277. package/esm2015/grid-material/src/lib/models/grid-style.model.js +1 -1
  278. package/esm2015/grid-material/src/lib/models/grid-sub-information.model.js +1 -1
  279. package/esm2015/grid-material/src/lib/models/grid.model.js +1 -1
  280. package/esm2015/grid-material/src/lib/pipes/cell-view.pipe.js +1 -1
  281. package/esm2015/grid-material/src/lib/pipes/column-badge.pipe.js +1 -1
  282. package/esm2015/grid-material/src/lib/pipes/column-children-filter.pipe.js +1 -1
  283. package/esm2015/grid-material/src/lib/pipes/column-html-template.pipe.js +1 -1
  284. package/esm2015/grid-material/src/lib/pipes/column-title.pipe.js +1 -1
  285. package/esm2015/grid-material/src/lib/pipes/column-tooltip.pipe.js +1 -1
  286. package/esm2015/grid-material/src/lib/pipes/column-transform.pipe.js +1 -1
  287. package/esm2015/grid-material/src/lib/pipes/column-values.pipe.js +1 -1
  288. package/esm2015/grid-material/src/lib/pipes/command-disable.pipe.js +1 -1
  289. package/esm2015/grid-material/src/lib/pipes/command-filter.pipe.js +1 -1
  290. package/esm2015/grid-material/src/lib/pipes/command-icon.pipe.js +1 -1
  291. package/esm2015/grid-material/src/lib/pipes/command-title.pipe.js +1 -1
  292. package/esm2015/grid-material/src/lib/pipes/editor-handler-column.pipe.js +1 -1
  293. package/esm2015/grid-material/src/lib/pipes/editor-handler-row.pipe.js +1 -1
  294. package/esm2015/grid-material/src/lib/pipes/editor-validate.pipe.js +1 -1
  295. package/esm2015/grid-material/src/lib/pipes/filter-column.pipe.js +1 -1
  296. package/esm2015/grid-material/src/lib/pipes/filter-external.pipe.js +1 -1
  297. package/esm2015/grid-material/src/lib/pipes/grid-configuration-result.pipe.js +1 -1
  298. package/esm2015/grid-material/src/lib/pipes/sd-group.pipe.js +1 -1
  299. package/esm2015/grid-material/src/lib/pipes/selection-action-filter.pipe.js +1 -1
  300. package/esm2015/grid-material/src/lib/pipes/selection-disable.pipe.js +1 -1
  301. package/esm2015/grid-material/src/lib/pipes/selection-visible-select-all.pipe.js +1 -1
  302. package/esm2015/grid-material/src/lib/pipes/selection-visible.pipe.js +1 -1
  303. package/esm2015/grid-material/src/lib/pipes/style-row-css.pipe.js +1 -1
  304. package/esm2015/grid-material/src/lib/services/generated-column/generated-column.model.js +1 -1
  305. package/esm2015/grid-material/src/lib/services/generated-column/generated-column.service.js +1 -1
  306. package/esm2015/grid-material/src/lib/services/grid-configuration.service.js +1 -1
  307. package/esm2015/grid-material/src/lib/services/grid-filter/grid-filter.model.js +1 -1
  308. package/esm2015/grid-material/src/lib/services/grid-filter/grid-filter.service.js +3 -2
  309. package/esm2015/grid-material/src/public-api.js +1 -1
  310. package/esm2015/group/index.js +1 -1
  311. package/esm2015/group/sd-angular-core-group.js +1 -1
  312. package/esm2015/group/src/lib/group.component.js +1 -1
  313. package/esm2015/group/src/lib/group.module.js +1 -1
  314. package/esm2015/group/src/public-api.js +1 -1
  315. package/esm2015/header-title/index.js +1 -1
  316. package/esm2015/header-title/sd-angular-core-header-title.js +1 -1
  317. package/esm2015/header-title/src/lib/header-title.component.js +1 -1
  318. package/esm2015/header-title/src/lib/header-title.module.js +1 -1
  319. package/esm2015/header-title/src/public-api.js +1 -1
  320. package/esm2015/image-preview/index.js +1 -1
  321. package/esm2015/image-preview/sd-angular-core-image-preview.js +1 -1
  322. package/esm2015/image-preview/src/lib/directives/image-preview.directive.js +1 -1
  323. package/esm2015/image-preview/src/lib/image-preview/image-preview-sdmodal.component.js +1 -1
  324. package/esm2015/image-preview/src/lib/image-preview/image-preview.component.js +1 -1
  325. package/esm2015/image-preview/src/lib/image-preview/image-preview.module.js +1 -1
  326. package/esm2015/image-preview/src/lib/models/image-preview.model.js +1 -1
  327. package/esm2015/image-preview/src/public-api.js +1 -1
  328. package/esm2015/input/index.js +1 -1
  329. package/esm2015/input/sd-angular-core-input.js +1 -1
  330. package/esm2015/input/src/lib/directives/input-suffix.directive.js +1 -1
  331. package/esm2015/input/src/lib/directives/touch.directive.js +1 -1
  332. package/esm2015/input/src/lib/input-tooltip.pipe.js +1 -1
  333. package/esm2015/input/src/lib/input.component.js +1 -1
  334. package/esm2015/input/src/lib/input.module.js +1 -1
  335. package/esm2015/input/src/public-api.js +1 -1
  336. package/esm2015/input-currency/index.js +1 -1
  337. package/esm2015/input-currency/sd-angular-core-input-currency.js +1 -1
  338. package/esm2015/input-currency/src/lib/input-currency-tooltip.pipe.js +1 -1
  339. package/esm2015/input-currency/src/lib/input-currency.component.js +1 -1
  340. package/esm2015/input-currency/src/lib/input-currency.module.js +1 -1
  341. package/esm2015/input-currency/src/public-api.js +1 -1
  342. package/esm2015/input-dropdown/index.js +1 -1
  343. package/esm2015/input-dropdown/sd-angular-core-input-dropdown.js +1 -1
  344. package/esm2015/input-dropdown/src/lib/input-tooltip.pipe.js +1 -1
  345. package/esm2015/input-dropdown/src/lib/input.component.js +1 -1
  346. package/esm2015/input-dropdown/src/lib/input.module.js +1 -1
  347. package/esm2015/input-dropdown/src/public-api.js +1 -1
  348. package/esm2015/input-number/index.js +1 -1
  349. package/esm2015/input-number/sd-angular-core-input-number.js +1 -1
  350. package/esm2015/input-number/src/lib/input-number.component.js +1 -1
  351. package/esm2015/input-number/src/lib/input-number.module.js +1 -1
  352. package/esm2015/input-number/src/public-api.js +1 -1
  353. package/esm2015/input-upload-file/index.js +1 -1
  354. package/esm2015/input-upload-file/sd-angular-core-input-upload-file.js +1 -1
  355. package/esm2015/input-upload-file/src/lib/input-upload-file.component.js +1 -1
  356. package/esm2015/input-upload-file/src/lib/input-upload-file.module.js +1 -1
  357. package/esm2015/input-upload-file/src/public-api.js +1 -1
  358. package/esm2015/json-editor/index.js +1 -1
  359. package/esm2015/json-editor/sd-angular-core-json-editor.js +1 -1
  360. package/esm2015/json-editor/src/lib/json-editor.component.js +1 -1
  361. package/esm2015/json-editor/src/lib/json-editor.module.js +1 -1
  362. package/esm2015/json-editor/src/public-api.js +1 -1
  363. package/esm2015/konva/index.js +1 -1
  364. package/esm2015/konva/sd-angular-core-konva.js +1 -1
  365. package/esm2015/konva/src/lib/konva.module.js +1 -1
  366. package/esm2015/konva/src/lib/merge-images/merge-images.component.js +1 -1
  367. package/esm2015/konva/src/public-api.js +1 -1
  368. package/esm2015/label/index.js +1 -1
  369. package/esm2015/label/sd-angular-core-label.js +1 -1
  370. package/esm2015/label/src/lib/label.component.js +1 -1
  371. package/esm2015/label/src/lib/label.module.js +1 -1
  372. package/esm2015/label/src/public-api.js +1 -1
  373. package/esm2015/lib/core.module.js +1 -1
  374. package/esm2015/lib/material.module.js +1 -1
  375. package/esm2015/loading/index.js +1 -1
  376. package/esm2015/loading/sd-angular-core-loading.js +1 -1
  377. package/esm2015/loading/src/lib/loading.service.js +1 -1
  378. package/esm2015/loading/src/public-api.js +1 -1
  379. package/esm2015/modal/index.js +1 -1
  380. package/esm2015/modal/sd-angular-core-modal.js +1 -1
  381. package/esm2015/modal/src/lib/bottom-sheet/bottom-sheet-body/bottom-sheet-body.component.js +1 -1
  382. package/esm2015/modal/src/lib/bottom-sheet/bottom-sheet-footer/bottom-sheet-footer.component.js +1 -1
  383. package/esm2015/modal/src/lib/bottom-sheet/bottom-sheet-header/bottom-sheet-header.component.js +1 -1
  384. package/esm2015/modal/src/lib/bottom-sheet/bottom-sheet.component.js +1 -1
  385. package/esm2015/modal/src/lib/modal/modal-body/modal-body.component.js +1 -1
  386. package/esm2015/modal/src/lib/modal/modal-footer/modal-footer.component.js +1 -1
  387. package/esm2015/modal/src/lib/modal/modal-header/modal-header.component.js +1 -1
  388. package/esm2015/modal/src/lib/modal/modal.component.js +1 -1
  389. package/esm2015/modal/src/lib/modal.module.js +1 -1
  390. package/esm2015/modal/src/public-api.js +1 -1
  391. package/esm2015/modal-resizable/index.js +1 -1
  392. package/esm2015/modal-resizable/sd-angular-core-modal-resizable.js +1 -1
  393. package/esm2015/modal-resizable/src/lib/modal-resizable/modal-resizable.component.js +1 -1
  394. package/esm2015/modal-resizable/src/lib/modal-resizable.module.js +1 -1
  395. package/esm2015/modal-resizable/src/public-api.js +1 -1
  396. package/esm2015/notify/index.js +1 -1
  397. package/esm2015/notify/sd-angular-core-notify.js +1 -1
  398. package/esm2015/notify/src/lib/components/dialog-confirm/dialog-confirm.component.js +1 -1
  399. package/esm2015/notify/src/lib/configurations/notify.configuration.js +1 -1
  400. package/esm2015/notify/src/lib/notify.module.js +1 -1
  401. package/esm2015/notify/src/lib/notify.service.js +1 -1
  402. package/esm2015/notify/src/public-api.js +1 -1
  403. package/esm2015/pdf/index.js +1 -1
  404. package/esm2015/pdf/sd-angular-core-pdf.js +1 -1
  405. package/esm2015/pdf/src/lib/pdf.module.js +1 -1
  406. package/esm2015/pdf/src/lib/pdf.service.js +1 -1
  407. package/esm2015/pdf/src/public-api.js +1 -1
  408. package/esm2015/popover/index.js +1 -1
  409. package/esm2015/popover/sd-angular-core-popover.js +1 -1
  410. package/esm2015/popover/src/lib/directives/popover-content.directive.js +1 -1
  411. package/esm2015/popover/src/lib/directives/popover-trigger.directive.js +1 -1
  412. package/esm2015/popover/src/lib/popover/popover.component.js +1 -1
  413. package/esm2015/popover/src/lib/popover.model.js +1 -1
  414. package/esm2015/popover/src/lib/popover.module.js +1 -1
  415. package/esm2015/popover/src/public-api.js +1 -1
  416. package/esm2015/print/index.js +1 -1
  417. package/esm2015/print/sd-angular-core-print.js +1 -1
  418. package/esm2015/print/src/lib/fonts/times/bold-italic.js +1 -1
  419. package/esm2015/print/src/lib/fonts/times/bold.js +1 -1
  420. package/esm2015/print/src/lib/fonts/times/italic.js +1 -1
  421. package/esm2015/print/src/lib/fonts/times/normal.js +1 -1
  422. package/esm2015/print/src/lib/print.component.js +1 -1
  423. package/esm2015/print/src/lib/print.module.js +1 -1
  424. package/esm2015/print/src/public-api.js +1 -1
  425. package/esm2015/public-api.js +1 -1
  426. package/esm2015/quick-action/index.js +1 -1
  427. package/esm2015/quick-action/sd-angular-core-quick-action.js +1 -1
  428. package/esm2015/quick-action/src/lib/quick-action.component.js +1 -1
  429. package/esm2015/quick-action/src/lib/quick-action.module.js +1 -1
  430. package/esm2015/quick-action/src/public-api.js +1 -1
  431. package/esm2015/radio/index.js +1 -1
  432. package/esm2015/radio/sd-angular-core-radio.js +1 -1
  433. package/esm2015/radio/src/lib/radio.component.js +1 -1
  434. package/esm2015/radio/src/lib/radio.module.js +1 -1
  435. package/esm2015/radio/src/public-api.js +1 -1
  436. package/esm2015/sd-angular-core.js +1 -1
  437. package/esm2015/select/index.js +1 -1
  438. package/esm2015/select/sd-angular-core-select.js +1 -1
  439. package/esm2015/select/src/lib/select-display-def.directive.js +1 -1
  440. package/esm2015/select/src/lib/select.component.js +1 -1
  441. package/esm2015/select/src/lib/select.module.js +1 -1
  442. package/esm2015/select/src/public-api.js +1 -1
  443. package/esm2015/select-badge/index.js +1 -1
  444. package/esm2015/select-badge/sd-angular-core-select-badge.js +1 -1
  445. package/esm2015/select-badge/src/lib/select-badge-display-def.directive.js +1 -1
  446. package/esm2015/select-badge/src/lib/select-badge.component.js +1 -1
  447. package/esm2015/select-badge/src/lib/select-badge.module.js +1 -1
  448. package/esm2015/select-badge/src/public-api.js +1 -1
  449. package/esm2015/select-editor/index.js +1 -1
  450. package/esm2015/select-editor/sd-angular-core-select-editor.js +1 -1
  451. package/esm2015/select-editor/src/lib/select-editor.component.js +1 -1
  452. package/esm2015/select-editor/src/lib/select-editor.module.js +1 -1
  453. package/esm2015/select-editor/src/public-api.js +1 -1
  454. package/esm2015/service/index.js +1 -1
  455. package/esm2015/service/sd-angular-core-service.js +1 -1
  456. package/esm2015/service/src/lib/service.module.js +1 -1
  457. package/esm2015/service/src/public-api.js +1 -1
  458. package/esm2015/setting/index.js +1 -1
  459. package/esm2015/setting/sd-angular-core-setting.js +1 -1
  460. package/esm2015/setting/src/lib/setting.model.js +1 -1
  461. package/esm2015/setting/src/lib/setting.service.js +1 -1
  462. package/esm2015/setting/src/public-api.js +1 -1
  463. package/esm2015/side-drawer/index.js +1 -1
  464. package/esm2015/side-drawer/sd-angular-core-side-drawer.js +1 -1
  465. package/esm2015/side-drawer/src/lib/side-drawer/side-drawer.component.js +14 -2
  466. package/esm2015/side-drawer/src/lib/side-drawer.module.js +1 -1
  467. package/esm2015/side-drawer/src/public-api.js +1 -1
  468. package/esm2015/switch/index.js +1 -1
  469. package/esm2015/switch/sd-angular-core-switch.js +1 -1
  470. package/esm2015/switch/src/lib/switch.component.js +1 -1
  471. package/esm2015/switch/src/lib/switch.module.js +1 -1
  472. package/esm2015/switch/src/public-api.js +1 -1
  473. package/esm2015/tab-router/index.js +1 -1
  474. package/esm2015/tab-router/sd-angular-core-tab-router.js +1 -1
  475. package/esm2015/tab-router/src/lib/actions/tab-router.action.js +1 -1
  476. package/esm2015/tab-router/src/lib/components/tab-router-item/tab-router-item.component.js +1 -1
  477. package/esm2015/tab-router/src/lib/components/tab-router-nav/tab-router-nav.component.js +1 -1
  478. package/esm2015/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.js +1 -1
  479. package/esm2015/tab-router/src/lib/decorators/tab.decorator.js +1 -1
  480. package/esm2015/tab-router/src/lib/directives/router-link-mouse-down.directive.js +1 -1
  481. package/esm2015/tab-router/src/lib/events/tab-router.event.js +1 -1
  482. package/esm2015/tab-router/src/lib/models/tab-router.model.js +1 -1
  483. package/esm2015/tab-router/src/lib/pipes/tab-info.pipe.js +1 -1
  484. package/esm2015/tab-router/src/lib/services/tab-decorator.service.js +1 -1
  485. package/esm2015/tab-router/src/lib/services/tab-router.service.js +1 -1
  486. package/esm2015/tab-router/src/lib/tab-router.module.js +1 -1
  487. package/esm2015/tab-router/src/public-api.js +1 -1
  488. package/esm2015/textarea/index.js +1 -1
  489. package/esm2015/textarea/sd-angular-core-textarea.js +1 -1
  490. package/esm2015/textarea/src/lib/textarea.component.js +1 -1
  491. package/esm2015/textarea/src/lib/textarea.module.js +1 -1
  492. package/esm2015/textarea/src/public-api.js +1 -1
  493. package/esm2015/time/index.js +1 -1
  494. package/esm2015/time/sd-angular-core-time.js +1 -1
  495. package/esm2015/time/src/lib/time.component.js +1 -1
  496. package/esm2015/time/src/lib/time.module.js +1 -1
  497. package/esm2015/time/src/public-api.js +1 -1
  498. package/esm2015/timeline/index.js +1 -1
  499. package/esm2015/timeline/sd-angular-core-timeline.js +1 -1
  500. package/esm2015/timeline/src/lib/components/timeline.component.js +1 -1
  501. package/esm2015/timeline/src/lib/directives/timeline-def.directive.js +1 -1
  502. package/esm2015/timeline/src/lib/timeline.module.js +1 -1
  503. package/esm2015/timeline/src/public-api.js +1 -1
  504. package/esm2015/translate/index.js +1 -1
  505. package/esm2015/translate/sd-angular-core-translate.js +1 -1
  506. package/esm2015/translate/src/lib/translate.model.js +1 -1
  507. package/esm2015/translate/src/lib/translate.module.js +1 -1
  508. package/esm2015/translate/src/lib/translate.pipe.js +1 -1
  509. package/esm2015/translate/src/lib/translate.service.js +1 -1
  510. package/esm2015/upload-excel/index.js +1 -1
  511. package/esm2015/upload-excel/sd-angular-core-upload-excel.js +1 -1
  512. package/esm2015/upload-excel/src/lib/pipes/columm-hidden.pipe.js +1 -1
  513. package/esm2015/upload-excel/src/lib/pipes/column-transform.pipe.js +1 -1
  514. package/esm2015/upload-excel/src/lib/upload-excel.component.js +1 -1
  515. package/esm2015/upload-excel/src/lib/upload-excel.model.js +1 -1
  516. package/esm2015/upload-excel/src/lib/upload-excel.module.js +1 -1
  517. package/esm2015/upload-excel/src/public-api.js +1 -1
  518. package/esm2015/upload-file/index.js +1 -1
  519. package/esm2015/upload-file/sd-angular-core-upload-file.js +1 -1
  520. package/esm2015/upload-file/src/lib/upload-file.component.js +1 -1
  521. package/esm2015/upload-file/src/lib/upload-file.module.js +1 -1
  522. package/esm2015/upload-file/src/public-api.js +1 -1
  523. package/esm2015/utility/index.js +1 -1
  524. package/esm2015/utility/sd-angular-core-utility.js +1 -1
  525. package/esm2015/utility/src/lib/directives/desktop.directive.js +1 -1
  526. package/esm2015/utility/src/lib/directives/mobile-tablet.directive.js +1 -1
  527. package/esm2015/utility/src/lib/directives/mobile.directive.js +1 -1
  528. package/esm2015/utility/src/lib/directives/tablet.directive.js +1 -1
  529. package/esm2015/utility/src/lib/pipes/currency.pipe.js +1 -1
  530. package/esm2015/utility/src/lib/pipes/safe-html.pipe.js +1 -1
  531. package/esm2015/utility/src/lib/pipes/time-different.pipe.js +1 -1
  532. package/esm2015/utility/src/lib/utility.module.js +1 -1
  533. package/esm2015/utility/src/lib/utility.service.js +1 -1
  534. package/esm2015/utility/src/public-api.js +1 -1
  535. package/esm2015/view/index.js +1 -1
  536. package/esm2015/view/sd-angular-core-view.js +1 -1
  537. package/esm2015/view/src/lib/view.module.js +1 -1
  538. package/esm2015/view/src/public-api.js +1 -1
  539. package/esm2015/zip/index.js +1 -1
  540. package/esm2015/zip/sd-angular-core-zip.js +1 -1
  541. package/esm2015/zip/src/lib/zip.module.js +1 -1
  542. package/esm2015/zip/src/lib/zip.service.js +1 -1
  543. package/esm2015/zip/src/public-api.js +1 -1
  544. package/fesm2015/sd-angular-core-grid-material.js +69 -9
  545. package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
  546. package/fesm2015/sd-angular-core-side-drawer.js +13 -1
  547. package/fesm2015/sd-angular-core-side-drawer.js.map +1 -1
  548. package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
  549. package/grid-material/src/lib/components/column-inline-filter/column-inline-filter.component.d.ts +8 -1
  550. package/grid-material/src/lib/grid-material.component.d.ts +2 -0
  551. package/grid-material/src/lib/models/grid-column.model.d.ts +11 -2
  552. package/grid-material/src/lib/services/grid-filter/grid-filter.model.d.ts +6 -9
  553. package/package.json +1 -1
  554. package/{sd-angular-core-1.3.117.tgz → sd-angular-core-1.3.119.tgz} +0 -0
  555. package/side-drawer/sd-angular-core-side-drawer.metadata.json +1 -1
  556. package/side-drawer/src/lib/side-drawer/side-drawer.component.d.ts +4 -0
@@ -1710,9 +1710,10 @@
1710
1710
  set: function (value) {
1711
1711
  var keys = Object.keys(value || {});
1712
1712
  var current = filterValue_1.get();
1713
- var columnFilter = current.columnFilter, externalFilter = current.externalFilter, filterDef = current.filterDef, notReload = current.notReload;
1713
+ var columnOperator = current.columnOperator, columnFilter = current.columnFilter, externalFilter = current.externalFilter, filterDef = current.filterDef, notReload = current.notReload;
1714
1714
  var updatedFilter = {
1715
1715
  // Filter column
1716
+ columnOperator: keys.includes('columnOperator') ? (value === null || value === void 0 ? void 0 : value.columnOperator) || {} : columnOperator,
1716
1717
  columnFilter: keys.includes('columnFilter') ? (value === null || value === void 0 ? void 0 : value.columnFilter) || {} : columnFilter,
1717
1718
  // Filter external
1718
1719
  externalFilter: keys.includes('externalFilter') ? (value === null || value === void 0 ? void 0 : value.externalFilter) || {} : externalFilter,
@@ -2022,6 +2023,7 @@
2022
2023
  this.sdFilterDefs = new core.QueryList();
2023
2024
  this.filterDefs = [];
2024
2025
  // Filter
2026
+ this.columnOperator = {};
2025
2027
  this.columnFilter = {};
2026
2028
  // Subcription
2027
2029
  _subscription$1.set(this, new rxjs.Subscription());
@@ -2089,8 +2091,9 @@
2089
2091
  });
2090
2092
  _filterExportInfo.set(this, function (pageNumber, pageSize) {
2091
2093
  var _a, _b;
2092
- var _5 = _this.filterRegister.value.get(), columnFilter = _5.columnFilter, externalFilter = _5.externalFilter, filterDef = _5.filterDef;
2094
+ var _5 = _this.filterRegister.value.get(), columnOperator = _5.columnOperator, columnFilter = _5.columnFilter, externalFilter = _5.externalFilter, filterDef = _5.filterDef;
2093
2095
  return {
2096
+ columnOperator: columnOperator || {},
2094
2097
  rawColumnFilter: columnFilter || {},
2095
2098
  rawExternalFilter: externalFilter || {},
2096
2099
  rawFilterDef: filterDef || {},
@@ -2125,7 +2128,8 @@
2125
2128
  });
2126
2129
  __classPrivateFieldGet(_this, _subscription$1).add(_this.filterRegister.value.observer
2127
2130
  .pipe(operators.debounceTime(500), operators.map(function (filterValue) {
2128
- var columnFilter = filterValue.columnFilter, notReload = filterValue.notReload;
2131
+ var columnOperator = filterValue.columnOperator, columnFilter = filterValue.columnFilter, notReload = filterValue.notReload;
2132
+ _this.columnOperator = columnOperator;
2129
2133
  _this.columnFilter = columnFilter;
2130
2134
  if (!notReload) {
2131
2135
  __classPrivateFieldGet(_this, _paginator).pageIndex = 0;
@@ -2266,8 +2270,9 @@
2266
2270
  });
2267
2271
  _getFilter.set(this, function () {
2268
2272
  var _a, _b, _c, _d, _e, _f;
2269
- var _5 = _this.filterRegister.value.get(), columnFilter = _5.columnFilter, externalFilter = _5.externalFilter, filterDef = _5.filterDef;
2273
+ var _5 = _this.filterRegister.value.get(), columnOperator = _5.columnOperator, columnFilter = _5.columnFilter, externalFilter = _5.externalFilter, filterDef = _5.filterDef;
2270
2274
  return {
2275
+ columnOperator: columnOperator || {},
2271
2276
  rawColumnFilter: columnFilter || {},
2272
2277
  rawExternalFilter: externalFilter || {},
2273
2278
  rawFilterDef: filterDef || {},
@@ -2827,6 +2832,7 @@
2827
2832
  (_b = (_a = _this.gridFilter) === null || _a === void 0 ? void 0 : _a.updateFilter) === null || _b === void 0 ? void 0 : _b.call(_a);
2828
2833
  if ((_d = (_c = _this.gridOption) === null || _c === void 0 ? void 0 : _c.filter) === null || _d === void 0 ? void 0 : _d.inlineColumn) {
2829
2834
  _this.filterRegister.value.set({
2835
+ columnOperator: _this.columnOperator,
2830
2836
  columnFilter: _this.columnFilter,
2831
2837
  });
2832
2838
  }
@@ -3321,7 +3327,7 @@
3321
3327
  SdGridMaterial.decorators = [
3322
3328
  { type: core.Component, args: [{
3323
3329
  selector: 'sd-grid-material',
3324
- template: "<ng-container *ngIf=\"gridConfigurationObserver | async as gridConfiguration\">\r\n <ng-container *ngIf=\"\r\n gridConfiguration\r\n | sdGridConfigurationResult\r\n : gridOption\r\n : sdSubInformation as configuration\r\n \">\r\n <sd-grid-filter *ngIf=\"!gridOption.filter?.disabled && filterRegister\" [filterRegister]=\"filterRegister\" [filter]=\"gridOption?.filter\"\r\n [columns]=\"configuration.firstColumns\" [externalFilters]=\"gridOption?.filter?.externalFilters\" [filterDefs]=\"filterDefs\" #gridFilter>\r\n </sd-grid-filter>\r\n <ng-container *ngIf=\"items | sdGroup:gridOption; $implicit as groupedItems\">\r\n <div class=\"c-container {{ gridOption?.style?.grid }}\" [ngClass]=\"{ 'mat-elevation-z2': gridOption?.shadow }\">\r\n <div class=\"c-loading\" *ngIf=\"isLoading\">\r\n <mat-spinner *ngIf=\"isLoading\"></mat-spinner>\r\n </div>\r\n <ng-container>\r\n <div class=\"c-table\" sdScroll [ngStyle]=\"{\r\n 'max-height': gridOption?.maxHeight,\r\n 'min-height': gridOption?.minHeight\r\n }\">\r\n <table *ngIf=\"items?.length; else elseEmpty\" mat-table [dataSource]=\"groupedItems\" matSort\r\n [matSortDisabled]=\"!gridOption.sortable\" cdkDropList cdkDropListOrientation=\"horizontal\"\r\n [cdkDropListDisabled]=\"!gridOption.dropDragColumnEnable\"\r\n (cdkDropListDropped)=\"drop($event, configuration.displayedColumns)\" multiTemplateDataRows>\r\n\r\n <ng-container matColumnDef=\"sdSubInformation\" sticky>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\" [attr.colspan]=\"configuration.displayedColumns.length\">\r\n <ng-container *ngIf=\"sdSubInformation?.templateRef\">\r\n <ng-container *ngIf=\"gridOption?.subInformation?.always;else useExpandCollapse\">\r\n <ng-container *ngTemplateOutlet=\"\r\n sdSubInformation.templateRef;\r\n context: { item: item }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #useExpandCollapse>\r\n <div [@detailExpand]=\"item.isExpanded ? 'expanded' : 'collapsed'\">\r\n <ng-container *ngIf=\"item.isExpanded\">\r\n <ng-container *ngTemplateOutlet=\"\r\n sdSubInformation.templateRef;\r\n context: { item: item }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSubInformationAction\" stickyEnd>\r\n <th class=\"p-0\" mat-header-cell *matHeaderCellDef style=\"width: 1px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td mat-cell *matCellDef=\"let element\">\r\n <button *ngIf=\"!element.isExpanding && !gridOption?.subInformation?.always\" mat-icon-button\r\n aria-label=\"Expand & Collapse\" (click)=\"onExpand(element)\">\r\n <mat-icon *ngIf=\"!element.isExpanded\">expand_more</mat-icon>\r\n <mat-icon *ngIf=\"element.isExpanded\">expand_less</mat-icon>\r\n </button>\r\n <div *ngIf=\"element.isExpanding\" class=\"lds-ring\">\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n </div>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSelection\" sticky>\r\n <th class=\"text-center px-15\" mat-header-cell *matHeaderCellDef style=\"min-width: 50px; max-width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n <ng-container *ngIf=\"items | selectionVisibleSelectAll: gridOption?.selection | async\">\r\n <mat-checkbox *ngIf=\"!gridOption.selection?.single\" class=\"c-selection\" color=\"primary\"\r\n [(ngModel)]=\"isSelectAll\" (change)=\"onSelectAll()\">\r\n </mat-checkbox>\r\n </ng-container>\r\n\r\n </th>\r\n <td class=\"text-center px-15\" mat-cell *matCellDef=\"let item\" style=\"min-width: 50px; max-width: 50px\">\r\n <ng-container *ngIf=\"item | selectionVisible:gridOption?.selection\">\r\n <mat-checkbox class=\"c-selection\" color=\"primary\" [(ngModel)]=\"item.isSelected\"\r\n (change)=\"onSelect(item)\" [disabled]=\"\r\n selectedItems | selectionDisable: item:gridOption?.selection\r\n \">\r\n </mat-checkbox>\r\n </ng-container>\r\n\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEditorValidation\">\r\n <th class=\"p-0\" mat-header-cell *matHeaderCellDef style=\"width: 2px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n </th>\r\n <td class=\"p-0 position-relative\" mat-cell *matCellDef=\"let item; index as idx\">\r\n <sd-desktop-editor-validation [sdId]=\"item.sdId\" [item]=\"item\" [items]=\"items\"\r\n [gridOption]=\"gridOption\">\r\n </sd-desktop-editor-validation>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEditor\">\r\n <th class=\"px-8 py-8\" mat-header-cell *matHeaderCellDef style=\"width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n <button class=\"c-btn-add\"\r\n *ngIf=\"gridOption.editor?.addable && (!gridOption.editor.limit || gridOption.editor.limit > items.length)\"\r\n (click)=\"onCreate()\" aria-hidden=\"true\" mat-icon-button>\r\n <mat-icon class=\"c-icon-add\">add</mat-icon>\r\n </button>\r\n </th>\r\n <td class=\"px-8\" mat-cell *matCellDef=\"let item; index as idx\">\r\n <ng-container *sdLet=\"item.editorStatus | sdEditorHandlerRow:item:gridOption as editorHandler\">\r\n <div *ngIf=\"editorHandler\" class=\"d-flex align-items-center justify-content-center\">\r\n <button *ngIf=\"editorHandler.editable\" class=\"mx-2\" (click)=\"onUpdate(item)\" aria-hidden=\"true\"\r\n mat-icon-button>\r\n <mat-icon class=\"c-icon\">edit</mat-icon>\r\n </button>\r\n <button *ngIf=\"editorHandler.removable\" class=\"mx-2\" (click)=\"onRemove(item)\" aria-hidden=\"true\"\r\n mat-icon-button>\r\n <mat-icon class=\"c-icon\">delete</mat-icon>\r\n </button>\r\n <button *ngIf=\"editorHandler.savable\" class=\"mx-2\" (click)=\"onSave(item)\" aria-hidden=\"true\"\r\n mat-icon-button>\r\n <mat-icon class=\"c-icon\">save</mat-icon>\r\n </button>\r\n <button *ngIf=\"editorHandler.cancelable\" class=\"mx-2\" (click)=\"onCancel(item)\" aria-hidden=\"true\"\r\n mat-icon-button>\r\n <mat-icon class=\"c-icon\">close</mat-icon>\r\n </button>\r\n </div>\r\n </ng-container>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdCommand\">\r\n <th class=\"px-8 py-8\" mat-header-cell *matHeaderCellDef style=\"width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td class=\"px-8\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-command [commands]=\"gridOption.commands\" [item]=\"item\"></sd-desktop-command>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdGroup\">\r\n <th mat-header-cell *matHeaderCellDef class=\"px-8 py-8\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n </th>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\"\r\n [attr.colspan]=\"!item?.sdGroup ? 1 : configuration.displayedColumns.length\">\r\n <div [innerHtml]=\"item?.sdGroup?.htmlTemplate | safeHtml\">\r\n </div>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.firstColumns; let i = index\"\r\n [matColumnDef]=\"column.field\" [sticky]=\"configuration.fixedColumn[column.field]\">\r\n <th mat-header-cell *matHeaderCellDef cdkDrag class=\"px-8 py-8 c-th\"\r\n [ngStyle]=\"{ 'min-width': configuration.firstColumns[i].width }\" [attr.rowspan]=\"\r\n configuration.multipleHeader && column.type !== 'children-col'\r\n ? 2\r\n : 1\r\n \" [attr.colspan]=\"\r\n column.type === 'children-col' ? column.children?.length : 1\r\n \">\r\n <div>\r\n <div aria-hidden=\"false\" role=\"presentation\" mat-sort-header [disabled]=\"\r\n !column.sortable || column.type === 'children-col'\r\n \" [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\"\r\n [innerHTML]=\"configuration.firstColumns[i].titleHtml || configuration.firstColumns[i].title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\"\r\n [value]=\"columnFilter[column.field]\" [columnFilter]=\"columnFilter\" [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-0\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell class=\"d-block px-8\" *ngIf=\"!item?.sdGroup\" [sdId]=\"item.sdId\" [key]=\"key\"\r\n [value]=\"item[column.field]\" [column]=\"column\" [item]=\"item\" [idx]=\"i\" [cellDef]=\"cellDef\"\r\n [gridOption]=\"gridOption\">\r\n </sd-desktop-cell>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef>\r\n <ng-container *ngIf=\"footerDef[column.field]\">\r\n <ng-container *ngTemplateOutlet=\"\r\n footerDef[column.field].templateRef;\r\n context: { items: items, column: column }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.secondColumns; let i = index\"\r\n [matColumnDef]=\"column.field\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header class=\"c-th px-8\"\r\n [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div>\r\n <div [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\" [innerHTML]=\"column.titleHtml || column.title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\"\r\n [value]=\"columnFilter[column.field]\" [columnFilter]=\"columnFilter\" [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-0\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell class=\"d-block px-8\" [sdId]=\"item.sdId\" [key]=\"key\" [value]=\"item[column.field]\"\r\n [column]=\"column\" [item]=\"item\" [idx]=\"i\" [cellDef]=\"cellDef\" [gridOption]=\"gridOption\">\r\n </sd-desktop-cell>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef>\r\n <ng-container *ngIf=\"footerDef[column.field]\">\r\n <ng-container *ngTemplateOutlet=\"\r\n footerDef[column.field].templateRef;\r\n context: { items: items, column: column }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n <tr class=\"c-first-header\" mat-header-row *matHeaderRowDef=\"configuration.firstHeaders; sticky: true\">\r\n </tr>\r\n <ng-container *ngIf=\"configuration.secondHeaders?.length\">\r\n <tr class=\"c-second-header\" mat-header-row *matHeaderRowDef=\"configuration.secondHeaders; sticky: true\">\r\n </tr>\r\n </ng-container>\r\n <tr mat-row *matRowDef=\"let row; columns: configuration.displayedColumns\" matRipple class=\"c-row\"\r\n [class.selected]=\"row.isSelected\" [style]=\"row | sdStyleRowCss:gridOption\"></tr>\r\n\r\n <tr mat-row *matRowDef=\"let row; columns: ['sdSubInformation']\" class=\"c-detail-row\"></tr>\r\n <ng-container *ngIf=\"hasFooter && configuration.displayedFooters?.length\">\r\n <tr mat-footer-row *matFooterRowDef=\"configuration.displayedFooters; sticky: true\"></tr>\r\n </ng-container>\r\n </table>\r\n <ng-template #elseEmpty>\r\n <table mat-table [dataSource]=\"[{}]\">\r\n <ng-container matColumnDef=\"sdSelection\" sticky>\r\n <th class=\"px-15\" mat-header-cell *matHeaderCellDef style=\"min-width: 50px; max-width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEditorValidation\">\r\n <th class=\"p-0\" mat-header-cell *matHeaderCellDef style=\"width: 4px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n </th>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\">\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEditor\">\r\n <th class=\"px-8 py-8\" mat-header-cell *matHeaderCellDef style=\"min-width: 50px; max-width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n <button class=\"c-btn-add\"\r\n *ngIf=\"gridOption.editor?.addable && (!gridOption.editor.limit || gridOption.editor.limit > items.length)\"\r\n (click)=\"onCreate()\" aria-hidden=\"true\" mat-icon-button>\r\n <mat-icon class=\"c-icon-add\">add</mat-icon>\r\n </button>\r\n </th>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdCommand\">\r\n <th class=\"px-8\" mat-header-cell *matHeaderCellDef style=\"min-width: 50px; max-width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSubInformationAction\">\r\n <th class=\"p-0\" mat-header-cell *matHeaderCellDef style=\"width: 1px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEmpty\">\r\n <td class=\"c-empty\" mat-cell *matCellDef=\"let item\"\r\n [attr.colspan]=\"configuration.displayedColumns.length\">\r\n <ng-container *ngIf=\"sdEmptyData?.templateRef; else sdEmptyDataNoRef\">\r\n <ng-container *ngTemplateOutlet=\"\r\n sdEmptyData.templateRef;\r\n context: { item: item }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #sdEmptyDataNoRef>\r\n <mat-icon fontSet=\"material-icons-outlined\">leaderboard</mat-icon>\r\n </ng-template>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdGroup\">\r\n <th mat-header-cell *matHeaderCellDef class=\"px-8 py-8\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n </th>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\">\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.columns\" [matColumnDef]=\"column.field\"\r\n [sticky]=\"configuration.fixedColumn[column.field]\">\r\n <th mat-header-cell *matHeaderCellDef class=\"c-th px-8 py-8\"\r\n [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\" [innerHTML]=\"column.titleHtml || column.title\">\r\n </div>\r\n </th>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.firstColumns; let i = index\"\r\n [matColumnDef]=\"column.field\" [sticky]=\"configuration.fixedColumn[column.field]\">\r\n <th mat-header-cell *matHeaderCellDef class=\"c-th px-8 py-8\"\r\n [ngStyle]=\"{ 'min-width': configuration.firstColumns[i].width }\" [attr.rowspan]=\"\r\n configuration.multipleHeader &&\r\n column.type !== 'children-col'\r\n ? 2\r\n : 1\r\n \" [attr.colspan]=\"\r\n column.type === 'children-col' ? column.children?.length : 1\r\n \">\r\n <div>\r\n <div [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\"\r\n [innerHTML]=\"configuration.firstColumns[i].titleHtml || configuration.firstColumns[i].title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\"\r\n [value]=\"columnFilter[column.field]\" [columnFilter]=\"columnFilter\" [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\"></sd-column-inline-filter>\r\n </div>\r\n </th>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.secondColumns\" [matColumnDef]=\"column.field\">\r\n <th mat-header-cell *matHeaderCellDef class=\"c-th px-8 py-8\"\r\n [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div>\r\n <div [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\" [innerHTML]=\"column.titleHtml || column.title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\"\r\n [value]=\"columnFilter[column.field]\" [columnFilter]=\"columnFilter\" [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\"></sd-column-inline-filter>\r\n </div>\r\n </th>\r\n </ng-container>\r\n <tr class=\"c-first-header\" mat-header-row *matHeaderRowDef=\"configuration.firstHeaders; sticky: true\">\r\n </tr>\r\n <tr class=\"c-second-header\" mat-header-row *matHeaderRowDef=\"configuration.secondHeaders; sticky: true\">\r\n </tr>\r\n <tr mat-row *matRowDef=\"let row; columns: ['sdEmpty']\"></tr>\r\n </table>\r\n </ng-template>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-paginator\">\r\n <div class=\"c-action\">\r\n <sd-button *ngIf=\"gridFilter && !gridOption.filter?.inlineColumn\r\n \" class=\"mr-10\" [title]=\"'Filter' | sdTranslate\" icon=\"filter_alt\" size=\"sm\" (action)=\"gridFilter.open()\"\r\n type=\"link\">\r\n </sd-button>\r\n <sd-button *ngIf=\"gridOption.reload?.visible\" class=\"mr-10\" [title]=\"'Reload' | sdTranslate\" icon=\"refresh\"\r\n size=\"sm\" (action)=\"reload()\" [disabled]=\"!items?.length\" type=\"link\">\r\n </sd-button>\r\n <ng-container *ngIf=\"gridOption.export?.visible && items?.length\">\r\n <ng-container *ngIf=\"isExporting; else unExporting\">\r\n <sd-button class=\"mr-10\" [loading]=\"isExporting\" [title]=\"exportTitle | sdTranslate\" icon=\"get_app\"\r\n size=\"sm\" type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-template #unExporting>\r\n <sd-button class=\"mr-10\" [title]=\"exportTitle | sdTranslate\" icon=\"get_app\" size=\"sm\"\r\n [matMenuTriggerFor]=\"menu\" type=\"link\">\r\n </sd-button>\r\n </ng-template>\r\n\r\n <mat-menu #menu=\"matMenu\">\r\n <button *ngIf=\"gridOption.export?.visibleExcel !== false\" mat-menu-item\r\n (click)=\"sdPopupExport.exportDefault()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">file_download</mat-icon>\r\n <span> {{ \"Export excel\" | sdTranslate }}</span>\r\n </button>\r\n <button *ngIf=\"gridOption.export?.visibleCSV !== false\" mat-menu-item\r\n (click)=\"sdPopupExport.exportCSV()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">file_download</mat-icon>\r\n <span> {{ \"Export CSV\" | sdTranslate }}</span>\r\n </button>\r\n <button *ngIf=\"gridOption.export?.key\" mat-menu-item (click)=\"sdPopupExport.open()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">settings</mat-icon>\r\n <span> {{ \"Configure\" | sdTranslate }}</span>\r\n </button>\r\n </mat-menu>\r\n </ng-container>\r\n <sd-button *ngIf=\"gridOption.config?.visible\" class=\"mr-10\" [title]=\"'Configure' | sdTranslate\"\r\n icon=\"settings\" size=\"sm\" (action)=\"popupGridConfiguration.open()\" type=\"link\">\r\n </sd-button>\r\n </div>\r\n <mat-paginator [class.d-none]=\"gridOption.paginate?.hidden\" [length]=\"total\"\r\n [pageSize]=\"gridOption.paginate?.pageSize\" [pageSizeOptions]=\"gridOption.paginate?.pages\"\r\n [showFirstLastButtons]=\"gridOption.paginate?.showFirstLastButtons\"></mat-paginator>\r\n </div>\r\n </div>\r\n <sd-grid-quick-action [gridOption]=\"gridOption\" [selectedItems]=\"selectedItems\"\r\n (clear)=\"onClearSelection(groupedItems)\">\r\n </sd-grid-quick-action>\r\n <sd-popup-export *ngIf=\"gridOption.export?.visible\" [configuration]=\"configuration\" [gridOption]=\"gridOption\"\r\n (export)=\"onExport($event)\" #sdPopupExport>\r\n </sd-popup-export>\r\n <sd-popup-grid-configuration [gridOption]=\"gridOption\" [key]=\"key\" #popupGridConfiguration>\r\n </sd-popup-grid-configuration>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>",
3330
+ template: "<ng-container *ngIf=\"gridConfigurationObserver | async as gridConfiguration\">\r\n <ng-container *ngIf=\"\r\n gridConfiguration\r\n | sdGridConfigurationResult\r\n : gridOption\r\n : sdSubInformation as configuration\r\n \">\r\n <sd-grid-filter *ngIf=\"!gridOption.filter?.disabled && filterRegister\" [filterRegister]=\"filterRegister\" [filter]=\"gridOption?.filter\"\r\n [columns]=\"configuration.firstColumns\" [externalFilters]=\"gridOption?.filter?.externalFilters\" [filterDefs]=\"filterDefs\" #gridFilter>\r\n </sd-grid-filter>\r\n <ng-container *ngIf=\"items | sdGroup:gridOption; $implicit as groupedItems\">\r\n <div class=\"c-container {{ gridOption?.style?.grid }}\" [ngClass]=\"{ 'mat-elevation-z2': gridOption?.shadow }\">\r\n <div class=\"c-loading\" *ngIf=\"isLoading\">\r\n <mat-spinner *ngIf=\"isLoading\"></mat-spinner>\r\n </div>\r\n <ng-container>\r\n <div class=\"c-table\" sdScroll [ngStyle]=\"{\r\n 'max-height': gridOption?.maxHeight,\r\n 'min-height': gridOption?.minHeight\r\n }\">\r\n <table *ngIf=\"items?.length; else elseEmpty\" mat-table [dataSource]=\"groupedItems\" matSort\r\n [matSortDisabled]=\"!gridOption.sortable\" cdkDropList cdkDropListOrientation=\"horizontal\"\r\n [cdkDropListDisabled]=\"!gridOption.dropDragColumnEnable\"\r\n (cdkDropListDropped)=\"drop($event, configuration.displayedColumns)\" multiTemplateDataRows>\r\n\r\n <ng-container matColumnDef=\"sdSubInformation\" sticky>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\" [attr.colspan]=\"configuration.displayedColumns.length\">\r\n <ng-container *ngIf=\"sdSubInformation?.templateRef\">\r\n <ng-container *ngIf=\"gridOption?.subInformation?.always;else useExpandCollapse\">\r\n <ng-container *ngTemplateOutlet=\"\r\n sdSubInformation.templateRef;\r\n context: { item: item }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #useExpandCollapse>\r\n <div [@detailExpand]=\"item.isExpanded ? 'expanded' : 'collapsed'\">\r\n <ng-container *ngIf=\"item.isExpanded\">\r\n <ng-container *ngTemplateOutlet=\"\r\n sdSubInformation.templateRef;\r\n context: { item: item }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSubInformationAction\" stickyEnd>\r\n <th class=\"p-0\" mat-header-cell *matHeaderCellDef style=\"width: 1px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td mat-cell *matCellDef=\"let element\">\r\n <button *ngIf=\"!element.isExpanding && !gridOption?.subInformation?.always\" mat-icon-button\r\n aria-label=\"Expand & Collapse\" (click)=\"onExpand(element)\">\r\n <mat-icon *ngIf=\"!element.isExpanded\">expand_more</mat-icon>\r\n <mat-icon *ngIf=\"element.isExpanded\">expand_less</mat-icon>\r\n </button>\r\n <div *ngIf=\"element.isExpanding\" class=\"lds-ring\">\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n <div></div>\r\n </div>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSelection\" sticky>\r\n <th class=\"text-center px-15\" mat-header-cell *matHeaderCellDef style=\"min-width: 50px; max-width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n <ng-container *ngIf=\"items | selectionVisibleSelectAll: gridOption?.selection | async\">\r\n <mat-checkbox *ngIf=\"!gridOption.selection?.single\" class=\"c-selection\" color=\"primary\"\r\n [(ngModel)]=\"isSelectAll\" (change)=\"onSelectAll()\">\r\n </mat-checkbox>\r\n </ng-container>\r\n\r\n </th>\r\n <td class=\"text-center px-15\" mat-cell *matCellDef=\"let item\" style=\"min-width: 50px; max-width: 50px\">\r\n <ng-container *ngIf=\"item | selectionVisible:gridOption?.selection\">\r\n <mat-checkbox class=\"c-selection\" color=\"primary\" [(ngModel)]=\"item.isSelected\"\r\n (change)=\"onSelect(item)\" [disabled]=\"\r\n selectedItems | selectionDisable: item:gridOption?.selection\r\n \">\r\n </mat-checkbox>\r\n </ng-container>\r\n\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEditorValidation\">\r\n <th class=\"p-0\" mat-header-cell *matHeaderCellDef style=\"width: 2px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n </th>\r\n <td class=\"p-0 position-relative\" mat-cell *matCellDef=\"let item; index as idx\">\r\n <sd-desktop-editor-validation [sdId]=\"item.sdId\" [item]=\"item\" [items]=\"items\"\r\n [gridOption]=\"gridOption\">\r\n </sd-desktop-editor-validation>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEditor\">\r\n <th class=\"px-8 py-8\" mat-header-cell *matHeaderCellDef style=\"width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n <button class=\"c-btn-add\"\r\n *ngIf=\"gridOption.editor?.addable && (!gridOption.editor.limit || gridOption.editor.limit > items.length)\"\r\n (click)=\"onCreate()\" aria-hidden=\"true\" mat-icon-button>\r\n <mat-icon class=\"c-icon-add\">add</mat-icon>\r\n </button>\r\n </th>\r\n <td class=\"px-8\" mat-cell *matCellDef=\"let item; index as idx\">\r\n <ng-container *sdLet=\"item.editorStatus | sdEditorHandlerRow:item:gridOption as editorHandler\">\r\n <div *ngIf=\"editorHandler\" class=\"d-flex align-items-center justify-content-center\">\r\n <button *ngIf=\"editorHandler.editable\" class=\"mx-2\" (click)=\"onUpdate(item)\" aria-hidden=\"true\"\r\n mat-icon-button>\r\n <mat-icon class=\"c-icon\">edit</mat-icon>\r\n </button>\r\n <button *ngIf=\"editorHandler.removable\" class=\"mx-2\" (click)=\"onRemove(item)\" aria-hidden=\"true\"\r\n mat-icon-button>\r\n <mat-icon class=\"c-icon\">delete</mat-icon>\r\n </button>\r\n <button *ngIf=\"editorHandler.savable\" class=\"mx-2\" (click)=\"onSave(item)\" aria-hidden=\"true\"\r\n mat-icon-button>\r\n <mat-icon class=\"c-icon\">save</mat-icon>\r\n </button>\r\n <button *ngIf=\"editorHandler.cancelable\" class=\"mx-2\" (click)=\"onCancel(item)\" aria-hidden=\"true\"\r\n mat-icon-button>\r\n <mat-icon class=\"c-icon\">close</mat-icon>\r\n </button>\r\n </div>\r\n </ng-container>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdCommand\">\r\n <th class=\"px-8 py-8\" mat-header-cell *matHeaderCellDef style=\"width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n <td class=\"px-8\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-command [commands]=\"gridOption.commands\" [item]=\"item\"></sd-desktop-command>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdGroup\">\r\n <th mat-header-cell *matHeaderCellDef class=\"px-8 py-8\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n </th>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\"\r\n [attr.colspan]=\"!item?.sdGroup ? 1 : configuration.displayedColumns.length\">\r\n <div [innerHtml]=\"item?.sdGroup?.htmlTemplate | safeHtml\">\r\n </div>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.firstColumns; let i = index\"\r\n [matColumnDef]=\"column.field\" [sticky]=\"configuration.fixedColumn[column.field]\">\r\n <th mat-header-cell *matHeaderCellDef cdkDrag class=\"px-8 py-8 c-th\"\r\n [ngStyle]=\"{ 'min-width': configuration.firstColumns[i].width }\" [attr.rowspan]=\"\r\n configuration.multipleHeader && column.type !== 'children-col'\r\n ? 2\r\n : 1\r\n \" [attr.colspan]=\"\r\n column.type === 'children-col' ? column.children?.length : 1\r\n \">\r\n <div>\r\n <div aria-hidden=\"false\" role=\"presentation\" mat-sort-header [disabled]=\"\r\n !column.sortable || column.type === 'children-col'\r\n \" [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\"\r\n [innerHTML]=\"configuration.firstColumns[i].titleHtml || configuration.firstColumns[i].title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\"\r\n [value]=\"columnFilter[column.field]\" [columnOperator]=\"columnOperator\" [columnFilter]=\"columnFilter\" [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-0\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell class=\"d-block px-8\" *ngIf=\"!item?.sdGroup\" [sdId]=\"item.sdId\" [key]=\"key\"\r\n [value]=\"item[column.field]\" [column]=\"column\" [item]=\"item\" [idx]=\"i\" [cellDef]=\"cellDef\"\r\n [gridOption]=\"gridOption\">\r\n </sd-desktop-cell>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef>\r\n <ng-container *ngIf=\"footerDef[column.field]\">\r\n <ng-container *ngTemplateOutlet=\"\r\n footerDef[column.field].templateRef;\r\n context: { items: items, column: column }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.secondColumns; let i = index\"\r\n [matColumnDef]=\"column.field\">\r\n <th mat-header-cell *matHeaderCellDef mat-sort-header class=\"c-th px-8\"\r\n [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div>\r\n <div [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\" [innerHTML]=\"column.titleHtml || column.title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\"\r\n [value]=\"columnFilter[column.field]\" [columnFilter]=\"columnFilter\" [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-0\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell class=\"d-block px-8\" [sdId]=\"item.sdId\" [key]=\"key\" [value]=\"item[column.field]\"\r\n [column]=\"column\" [item]=\"item\" [idx]=\"i\" [cellDef]=\"cellDef\" [gridOption]=\"gridOption\">\r\n </sd-desktop-cell>\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef>\r\n <ng-container *ngIf=\"footerDef[column.field]\">\r\n <ng-container *ngTemplateOutlet=\"\r\n footerDef[column.field].templateRef;\r\n context: { items: items, column: column }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n <tr class=\"c-first-header\" mat-header-row *matHeaderRowDef=\"configuration.firstHeaders; sticky: true\">\r\n </tr>\r\n <ng-container *ngIf=\"configuration.secondHeaders?.length\">\r\n <tr class=\"c-second-header\" mat-header-row *matHeaderRowDef=\"configuration.secondHeaders; sticky: true\">\r\n </tr>\r\n </ng-container>\r\n <tr mat-row *matRowDef=\"let row; columns: configuration.displayedColumns\" matRipple class=\"c-row\"\r\n [class.selected]=\"row.isSelected\" [style]=\"row | sdStyleRowCss:gridOption\"></tr>\r\n\r\n <tr mat-row *matRowDef=\"let row; columns: ['sdSubInformation']\" class=\"c-detail-row\"></tr>\r\n <ng-container *ngIf=\"hasFooter && configuration.displayedFooters?.length\">\r\n <tr mat-footer-row *matFooterRowDef=\"configuration.displayedFooters; sticky: true\"></tr>\r\n </ng-container>\r\n </table>\r\n <ng-template #elseEmpty>\r\n <table mat-table [dataSource]=\"[{}]\">\r\n <ng-container matColumnDef=\"sdSelection\" sticky>\r\n <th class=\"px-15\" mat-header-cell *matHeaderCellDef style=\"min-width: 50px; max-width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEditorValidation\">\r\n <th class=\"p-0\" mat-header-cell *matHeaderCellDef style=\"width: 4px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n </th>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\">\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEditor\">\r\n <th class=\"px-8 py-8\" mat-header-cell *matHeaderCellDef style=\"min-width: 50px; max-width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n <button class=\"c-btn-add\"\r\n *ngIf=\"gridOption.editor?.addable && (!gridOption.editor.limit || gridOption.editor.limit > items.length)\"\r\n (click)=\"onCreate()\" aria-hidden=\"true\" mat-icon-button>\r\n <mat-icon class=\"c-icon-add\">add</mat-icon>\r\n </button>\r\n </th>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdCommand\">\r\n <th class=\"px-8\" mat-header-cell *matHeaderCellDef style=\"min-width: 50px; max-width: 50px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdSubInformationAction\">\r\n <th class=\"p-0\" mat-header-cell *matHeaderCellDef style=\"width: 1px\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\"></th>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdEmpty\">\r\n <td class=\"c-empty\" mat-cell *matCellDef=\"let item\"\r\n [attr.colspan]=\"configuration.displayedColumns.length\">\r\n <ng-container *ngIf=\"sdEmptyData?.templateRef; else sdEmptyDataNoRef\">\r\n <ng-container *ngTemplateOutlet=\"\r\n sdEmptyData.templateRef;\r\n context: { item: item }\r\n \">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #sdEmptyDataNoRef>\r\n <mat-icon fontSet=\"material-icons-outlined\">leaderboard</mat-icon>\r\n </ng-template>\r\n </td>\r\n </ng-container>\r\n <ng-container matColumnDef=\"sdGroup\">\r\n <th mat-header-cell *matHeaderCellDef class=\"px-8 py-8\"\r\n [attr.rowspan]=\"configuration.multipleHeader ? 2 : 1\">\r\n </th>\r\n <td class=\"p-0\" mat-cell *matCellDef=\"let item\">\r\n </td>\r\n <td mat-footer-cell *matFooterCellDef></td>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.columns\" [matColumnDef]=\"column.field\"\r\n [sticky]=\"configuration.fixedColumn[column.field]\">\r\n <th mat-header-cell *matHeaderCellDef class=\"c-th px-8 py-8\"\r\n [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\" [innerHTML]=\"column.titleHtml || column.title\">\r\n </div>\r\n </th>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.firstColumns; let i = index\"\r\n [matColumnDef]=\"column.field\" [sticky]=\"configuration.fixedColumn[column.field]\">\r\n <th mat-header-cell *matHeaderCellDef class=\"c-th px-8 py-8\"\r\n [ngStyle]=\"{ 'min-width': configuration.firstColumns[i].width }\" [attr.rowspan]=\"\r\n configuration.multipleHeader &&\r\n column.type !== 'children-col'\r\n ? 2\r\n : 1\r\n \" [attr.colspan]=\"\r\n column.type === 'children-col' ? column.children?.length : 1\r\n \">\r\n <div>\r\n <div [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\"\r\n [innerHTML]=\"configuration.firstColumns[i].titleHtml || configuration.firstColumns[i].title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\"\r\n [value]=\"columnFilter[column.field]\" [columnFilter]=\"columnFilter\" [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\"></sd-column-inline-filter>\r\n </div>\r\n </th>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of configuration.secondColumns\" [matColumnDef]=\"column.field\">\r\n <th mat-header-cell *matHeaderCellDef class=\"c-th px-8 py-8\"\r\n [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div>\r\n <div [class.text-right]=\"column.align === 'right' || (!column.align && column.type === 'number')\"\r\n [class.text-center]=\"column.align === 'center'\" [innerHTML]=\"column.titleHtml || column.title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\"\r\n [value]=\"columnFilter[column.field]\" [columnFilter]=\"columnFilter\" [column]=\"column\"\r\n (filterChange)=\"onFilterChange()\"></sd-column-inline-filter>\r\n </div>\r\n </th>\r\n </ng-container>\r\n <tr class=\"c-first-header\" mat-header-row *matHeaderRowDef=\"configuration.firstHeaders; sticky: true\">\r\n </tr>\r\n <tr class=\"c-second-header\" mat-header-row *matHeaderRowDef=\"configuration.secondHeaders; sticky: true\">\r\n </tr>\r\n <tr mat-row *matRowDef=\"let row; columns: ['sdEmpty']\"></tr>\r\n </table>\r\n </ng-template>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-paginator\">\r\n <div class=\"c-action\">\r\n <sd-button *ngIf=\"gridFilter && !gridOption.filter?.inlineColumn\r\n \" class=\"mr-10\" [title]=\"'Filter' | sdTranslate\" icon=\"filter_alt\" size=\"sm\" (action)=\"gridFilter.open()\"\r\n type=\"link\">\r\n </sd-button>\r\n <sd-button *ngIf=\"gridOption.reload?.visible\" class=\"mr-10\" [title]=\"'Reload' | sdTranslate\" icon=\"refresh\"\r\n size=\"sm\" (action)=\"reload()\" [disabled]=\"!items?.length\" type=\"link\">\r\n </sd-button>\r\n <ng-container *ngIf=\"gridOption.export?.visible && items?.length\">\r\n <ng-container *ngIf=\"isExporting; else unExporting\">\r\n <sd-button class=\"mr-10\" [loading]=\"isExporting\" [title]=\"exportTitle | sdTranslate\" icon=\"get_app\"\r\n size=\"sm\" type=\"link\">\r\n </sd-button>\r\n </ng-container>\r\n <ng-template #unExporting>\r\n <sd-button class=\"mr-10\" [title]=\"exportTitle | sdTranslate\" icon=\"get_app\" size=\"sm\"\r\n [matMenuTriggerFor]=\"menu\" type=\"link\">\r\n </sd-button>\r\n </ng-template>\r\n\r\n <mat-menu #menu=\"matMenu\">\r\n <button *ngIf=\"gridOption.export?.visibleExcel !== false\" mat-menu-item\r\n (click)=\"sdPopupExport.exportDefault()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">file_download</mat-icon>\r\n <span> {{ \"Export excel\" | sdTranslate }}</span>\r\n </button>\r\n <button *ngIf=\"gridOption.export?.visibleCSV !== false\" mat-menu-item\r\n (click)=\"sdPopupExport.exportCSV()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">file_download</mat-icon>\r\n <span> {{ \"Export CSV\" | sdTranslate }}</span>\r\n </button>\r\n <button *ngIf=\"gridOption.export?.key\" mat-menu-item (click)=\"sdPopupExport.open()\" type=\"button\">\r\n <mat-icon fontSet=\"material-icons-outlined\">settings</mat-icon>\r\n <span> {{ \"Configure\" | sdTranslate }}</span>\r\n </button>\r\n </mat-menu>\r\n </ng-container>\r\n <sd-button *ngIf=\"gridOption.config?.visible\" class=\"mr-10\" [title]=\"'Configure' | sdTranslate\"\r\n icon=\"settings\" size=\"sm\" (action)=\"popupGridConfiguration.open()\" type=\"link\">\r\n </sd-button>\r\n </div>\r\n <mat-paginator [class.d-none]=\"gridOption.paginate?.hidden\" [length]=\"total\"\r\n [pageSize]=\"gridOption.paginate?.pageSize\" [pageSizeOptions]=\"gridOption.paginate?.pages\"\r\n [showFirstLastButtons]=\"gridOption.paginate?.showFirstLastButtons\"></mat-paginator>\r\n </div>\r\n </div>\r\n <sd-grid-quick-action [gridOption]=\"gridOption\" [selectedItems]=\"selectedItems\"\r\n (clear)=\"onClearSelection(groupedItems)\">\r\n </sd-grid-quick-action>\r\n <sd-popup-export *ngIf=\"gridOption.export?.visible\" [configuration]=\"configuration\" [gridOption]=\"gridOption\"\r\n (export)=\"onExport($event)\" #sdPopupExport>\r\n </sd-popup-export>\r\n <sd-popup-grid-configuration [gridOption]=\"gridOption\" [key]=\"key\" #popupGridConfiguration>\r\n </sd-popup-grid-configuration>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>",
3325
3331
  animations: [
3326
3332
  animations.trigger('detailExpand', [
3327
3333
  animations.state('collapsed', animations.style({ height: '0', minHeight: '0', visibility: 'hidden' })),
@@ -4694,11 +4700,52 @@
4694
4700
  gridOption: [{ type: core.Input }]
4695
4701
  };
4696
4702
 
4703
+ var SdFilterOperators = [
4704
+ {
4705
+ value: 'EQUAL',
4706
+ display: '=',
4707
+ },
4708
+ {
4709
+ value: 'NOT_EQUAL',
4710
+ display: '!=',
4711
+ },
4712
+ {
4713
+ value: 'CONTAIN',
4714
+ display: '∈',
4715
+ },
4716
+ // {
4717
+ // value: 'START_WITH';
4718
+ // display: '=';
4719
+ // },
4720
+ // {
4721
+ // value: 'END_WITH';
4722
+ // display: '=';
4723
+ // },
4724
+ {
4725
+ value: 'GREATER_THAN',
4726
+ display: '>',
4727
+ },
4728
+ {
4729
+ value: 'LESS_THAN',
4730
+ display: '<',
4731
+ },
4732
+ {
4733
+ value: 'GREATER_OR_EQUAL',
4734
+ display: '>=',
4735
+ },
4736
+ {
4737
+ value: 'LESS_OR_EQUAL',
4738
+ display: '<=',
4739
+ },
4740
+ ];
4741
+
4697
4742
  var _valueChanges, _subcription;
4698
4743
  var SdColumnInlineFilter = /** @class */ (function () {
4699
4744
  function SdColumnInlineFilter() {
4700
4745
  var _this = this;
4746
+ this.columnOperator = {};
4701
4747
  this.columnFilter = {};
4748
+ this.operators = [];
4702
4749
  this.filterChange = new core.EventEmitter();
4703
4750
  _valueChanges.set(this, new rxjs.Subject());
4704
4751
  _subcription.set(this, new rxjs.Subscription());
@@ -4710,6 +4757,13 @@
4710
4757
  this.value = value;
4711
4758
  __classPrivateFieldGet(this, _valueChanges).next();
4712
4759
  };
4760
+ Object.defineProperty(SdColumnInlineFilter.prototype, "_columnOperator", {
4761
+ set: function (columnOperator) {
4762
+ this.columnOperator = columnOperator || {};
4763
+ },
4764
+ enumerable: false,
4765
+ configurable: true
4766
+ });
4713
4767
  Object.defineProperty(SdColumnInlineFilter.prototype, "_columnFilter", {
4714
4768
  set: function (columnFilter) {
4715
4769
  this.columnFilter = columnFilter || {};
@@ -4718,7 +4772,20 @@
4718
4772
  enumerable: false,
4719
4773
  configurable: true
4720
4774
  });
4721
- ;
4775
+ Object.defineProperty(SdColumnInlineFilter.prototype, "_column", {
4776
+ set: function (column) {
4777
+ var _a, _b, _c;
4778
+ this.column = column;
4779
+ if (!((_a = column === null || column === void 0 ? void 0 : column.filter) === null || _a === void 0 ? void 0 : _a.disabled) && ((_c = (_b = column === null || column === void 0 ? void 0 : column.filter) === null || _b === void 0 ? void 0 : _b.operator) === null || _c === void 0 ? void 0 : _c.enable)) {
4780
+ this.operators = SdFilterOperators.filter(function (e) { var _a, _b; return (_b = (_a = column.filter.operator.list) === null || _a === void 0 ? void 0 : _a.includes) === null || _b === void 0 ? void 0 : _b.call(_a, e.value); });
4781
+ }
4782
+ else {
4783
+ this.operators = [];
4784
+ }
4785
+ },
4786
+ enumerable: false,
4787
+ configurable: true
4788
+ });
4722
4789
  SdColumnInlineFilter.prototype.ngOnInit = function () {
4723
4790
  var _this = this;
4724
4791
  __classPrivateFieldGet(this, _subcription).add(__classPrivateFieldGet(this, _valueChanges).pipe(operators.startWith(this.columnFilter)).subscribe(function () {
@@ -4727,7 +4794,7 @@
4727
4794
  if (!((_b = (_a = _this.column) === null || _a === void 0 ? void 0 : _a.option) === null || _b === void 0 ? void 0 : _b.useFilterDate)) {
4728
4795
  _this.columnFilter[_this.column.field] = _this.columnFilter[_this.column.field] || {
4729
4796
  from: null,
4730
- to: null
4797
+ to: null,
4731
4798
  };
4732
4799
  }
4733
4800
  }
@@ -4742,7 +4809,7 @@
4742
4809
  SdColumnInlineFilter.decorators = [
4743
4810
  { type: core.Component, args: [{
4744
4811
  selector: 'sd-column-inline-filter',
4745
- template: "<div class=\"c-inline-column\">\r\n <ng-container *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 <sd-input *ngIf=\"column.type === 'string'\" size=\"sm\" type=\"text\" [(model)]=\"columnFilter[column.field]\"\r\n (keyupEnter)=\"onFilterChange()\" [disabled]=\"column.filter?.disabled\">\r\n </sd-input>\r\n <sd-input-number *ngIf=\"column.type === 'number'\" size=\"sm\" [(model)]=\"columnFilter[column.field]\"\r\n (keyupEnter)=\"onFilterChange()\" [disabled]=\"column.filter?.disabled\">\r\n </sd-input-number>\r\n <sd-select *ngIf=\"column.type === 'bool'\" size=\"sm\" [items]=\"[\r\n { value: '1', display: column.option?.displayOnTrue || 'True' },\r\n { value: '0', display: column.option?.displayOnFalse || 'False' }\r\n ]\" valueField=\"value\" displayField=\"display\" [(model)]=\"columnFilter[column.field]\" (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'\">\r\n </sd-badge>\r\n <sd-badge *ngIf=\"item.value === '0'\" color=\"danger\" [title]=\"column.option?.displayOnFalse || 'False'\">\r\n </sd-badge>\r\n </ng-template>\r\n </sd-select>\r\n <sd-select *ngIf=\"\r\n column.type === 'values' && column?.option?.selection !== 'AUTOCOMPLETE'\r\n \" size=\"sm\" [items]=\"column.option.items\" [valueField]=\"column.option.valueField\"\r\n [displayField]=\"column.option.displayField\" [(model)]=\"columnFilter[column.field]\" (sdChange)=\"onFilterChange()\"\r\n [disabled]=\"column.filter?.disabled\" [multiple]=\"\r\n column?.option?.selection === 'MULTIPLE' ||\r\n column?.option?.selection === 'MULTIPLEAUTOCOMPLETE'\r\n \" [filtered]=\"column?.option?.selection === 'MULTIPLEAUTOCOMPLETE'\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"\r\n column.type === 'values' && column?.option?.selection === 'AUTOCOMPLETE'\r\n \" size=\"sm\" [items]=\"column.option.items\" [valueField]=\"column.option.valueField\"\r\n [displayField]=\"column.option.displayField\" [(model)]=\"columnFilter[column.field]\" (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 *ngIf=\"!column.option?.useFilterDate\" size=\"sm\" [(from)]=\"columnFilter[column.field].from\"\r\n [(to)]=\"columnFilter[column.field].to\" (sdChange)=\"onFilterChange()\" [disabled]=\"column.filter?.disabled\">\r\n </sd-date-range>\r\n <sd-date-time *ngIf=\"column.option?.useFilterDate\" type=\"date\" size=\"sm\" [(model)]=\"columnFilter[column.field]\"\r\n (sdChange)=\"onFilterChange()\" [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>",
4812
+ 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 required\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",
4746
4813
  changeDetection: core.ChangeDetectionStrategy.OnPush,
4747
4814
  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}"]
4748
4815
  },] }
@@ -4750,8 +4817,9 @@
4750
4817
  SdColumnInlineFilter.ctorParameters = function () { return []; };
4751
4818
  SdColumnInlineFilter.propDecorators = {
4752
4819
  _value: [{ type: core.Input, args: ['value',] }],
4820
+ _columnOperator: [{ type: core.Input, args: ['columnOperator',] }],
4753
4821
  _columnFilter: [{ type: core.Input, args: ['columnFilter',] }],
4754
- column: [{ type: core.Input }],
4822
+ _column: [{ type: core.Input, args: ['column',] }],
4755
4823
  filterChange: [{ type: core.Output }]
4756
4824
  };
4757
4825