@sd-angular/core 1.0.3 → 1.0.7

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 (460) 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 +32 -26
  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-utility.umd.js +1 -1
  56. package/bundles/sd-angular-core-utility.umd.js.map +1 -1
  57. package/bundles/sd-angular-core-utility.umd.min.js +1 -1
  58. package/bundles/sd-angular-core-utility.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/directives/sd-let.directive.js +1 -1
  118. package/esm2015/common/src/lib/directives/sd-scroll.directive.js +1 -1
  119. package/esm2015/common/src/lib/directives/view-def.directive.js +1 -1
  120. package/esm2015/common/src/lib/models/sd-form-control.js +1 -1
  121. package/esm2015/common/src/lib/typings/array.extension.js +1 -1
  122. package/esm2015/common/src/lib/typings/date.extension.js +1 -1
  123. package/esm2015/common/src/lib/typings/number.extension.js +1 -1
  124. package/esm2015/common/src/lib/typings/string.extension.js +1 -1
  125. package/esm2015/common/src/public-api.js +1 -1
  126. package/esm2015/date-range/index.js +1 -1
  127. package/esm2015/date-range/sd-angular-core-date-range.js +1 -1
  128. package/esm2015/date-range/src/lib/date-range.component.js +1 -1
  129. package/esm2015/date-range/src/lib/date-range.module.js +1 -1
  130. package/esm2015/date-range/src/public-api.js +1 -1
  131. package/esm2015/date-time/index.js +1 -1
  132. package/esm2015/date-time/sd-angular-core-date-time.js +1 -1
  133. package/esm2015/date-time/src/lib/date-time.component.js +1 -1
  134. package/esm2015/date-time/src/lib/date-time.module.js +1 -1
  135. package/esm2015/date-time/src/public-api.js +1 -1
  136. package/esm2015/dynamic-report/index.js +1 -1
  137. package/esm2015/dynamic-report/sd-angular-core-dynamic-report.js +1 -1
  138. package/esm2015/dynamic-report/src/lib/dynamic-report.component.js +1 -1
  139. package/esm2015/dynamic-report/src/lib/dynamic-report.module.js +1 -1
  140. package/esm2015/dynamic-report/src/public-api.js +1 -1
  141. package/esm2015/editor/index.js +1 -1
  142. package/esm2015/editor/sd-angular-core-editor.js +1 -1
  143. package/esm2015/editor/src/lib/constant.js +1 -1
  144. package/esm2015/editor/src/lib/editor.component.js +1 -1
  145. package/esm2015/editor/src/lib/editor.module.js +1 -1
  146. package/esm2015/editor/src/public-api.js +1 -1
  147. package/esm2015/excel/index.js +1 -1
  148. package/esm2015/excel/sd-angular-core-excel.js +1 -1
  149. package/esm2015/excel/src/lib/excel.model.js +1 -1
  150. package/esm2015/excel/src/lib/excel.service.js +1 -1
  151. package/esm2015/excel/src/public-api.js +1 -1
  152. package/esm2015/export/index.js +1 -1
  153. package/esm2015/export/sd-angular-core-export.js +1 -1
  154. package/esm2015/export/src/lib/export.model.js +1 -1
  155. package/esm2015/export/src/lib/export.service.js +1 -1
  156. package/esm2015/export/src/public-api.js +1 -1
  157. package/esm2015/filter/index.js +1 -1
  158. package/esm2015/filter/sd-angular-core-filter.js +1 -1
  159. package/esm2015/filter/src/lib/directives/sd-filter-def.directive.js +1 -1
  160. package/esm2015/filter/src/lib/filter.component.js +1 -1
  161. package/esm2015/filter/src/lib/filter.model.js +1 -1
  162. package/esm2015/filter/src/lib/filter.module.js +1 -1
  163. package/esm2015/filter/src/lib/filter.service.js +1 -1
  164. package/esm2015/filter/src/lib/pipes/values-local.pipe.js +1 -1
  165. package/esm2015/filter/src/lib/pipes/values-server.pipe.js +1 -1
  166. package/esm2015/filter/src/public-api.js +1 -1
  167. package/esm2015/form/index.js +1 -1
  168. package/esm2015/form/sd-angular-core-form.js +1 -1
  169. package/esm2015/form/src/lib/form.module.js +1 -1
  170. package/esm2015/form/src/public-api.js +1 -1
  171. package/esm2015/grid/index.js +1 -1
  172. package/esm2015/grid/sd-angular-core-grid.js +1 -1
  173. package/esm2015/grid/src/lib/components/grid-config/grid-config.component.js +1 -1
  174. package/esm2015/grid/src/lib/components/grid-config/grid-config.model.js +1 -1
  175. package/esm2015/grid/src/lib/components/grid-desktop-column-children-view/grid-desktop-column-children-view.component.js +1 -1
  176. package/esm2015/grid/src/lib/components/grid-desktop-column-edit/grid-desktop-column-edit.component.js +1 -1
  177. package/esm2015/grid/src/lib/components/grid-desktop-column-view/grid-desktop-column-view.component.js +1 -1
  178. package/esm2015/grid/src/lib/components/grid-desktop-inline-filter/grid-desktop-inline-filter.component.js +1 -1
  179. package/esm2015/grid/src/lib/components/grid-import-excel/grid-import-excel.component.js +1 -1
  180. package/esm2015/grid/src/lib/components/grid-mobile-item-view/grid-mobile-item-view.component.js +1 -1
  181. package/esm2015/grid/src/lib/components/grid-popup-editor/grid-popup-editor.component.js +1 -1
  182. package/esm2015/grid/src/lib/components/grid-popup-export-excel/grid-popup-export-excel.component.js +1 -1
  183. package/esm2015/grid/src/lib/components/grid-popup-export-excel/grid-popup-export-excel.model.js +1 -1
  184. package/esm2015/grid/src/lib/components/grid-popup-filter/grid-popup-filter.component.js +1 -1
  185. package/esm2015/grid/src/lib/components/grid-popup-filter/grid-popup-filter.model.js +1 -1
  186. package/esm2015/grid/src/lib/components/grid-popup-quick-filter-detail/grid-popup-quick-filter-detail.component.js +1 -1
  187. package/esm2015/grid/src/lib/components/grid-sub-information/grid-sub-information.component.js +1 -1
  188. package/esm2015/grid/src/lib/directives/cell-def.directive.js +1 -1
  189. package/esm2015/grid/src/lib/directives/cell-editor-def.directive.js +1 -1
  190. package/esm2015/grid/src/lib/directives/cell-footer-def.directive.js +1 -1
  191. package/esm2015/grid/src/lib/directives/sub-information-header-def.directive.js +1 -1
  192. package/esm2015/grid/src/lib/grid.component.js +1 -1
  193. package/esm2015/grid/src/lib/grid.model.js +1 -1
  194. package/esm2015/grid/src/lib/grid.module.js +1 -1
  195. package/esm2015/grid/src/lib/models/filter-info.model.js +1 -1
  196. package/esm2015/grid/src/lib/models/grid-configuration.model.js +1 -1
  197. package/esm2015/grid/src/lib/models/handler-dotnet.js +1 -1
  198. package/esm2015/grid/src/lib/models/handler-local.js +1 -1
  199. package/esm2015/grid/src/lib/models/handler.js +1 -1
  200. package/esm2015/grid/src/lib/pipes/cell-desktop-class-name.pipe.js +1 -1
  201. package/esm2015/grid/src/lib/pipes/cell-mobile-class-name.pipe.js +1 -1
  202. package/esm2015/grid/src/lib/pipes/column-command-filter.pipe.js +1 -1
  203. package/esm2015/grid/src/lib/pipes/column-html-template.pipe.js +1 -1
  204. package/esm2015/grid/src/lib/pipes/column-title.pipe.js +1 -1
  205. package/esm2015/grid/src/lib/pipes/column-values.pipe.js +1 -1
  206. package/esm2015/grid/src/lib/pipes/command-disabled.pipe.js +1 -1
  207. package/esm2015/grid/src/lib/pipes/command-filter.pipe.js +1 -1
  208. package/esm2015/grid/src/lib/pipes/command-hidden.pipe.js +1 -1
  209. package/esm2015/grid/src/lib/pipes/command-icon.pipe.js +1 -1
  210. package/esm2015/grid/src/lib/pipes/command-title.pipe.js +1 -1
  211. package/esm2015/grid/src/lib/pipes/dynamic-items.pipe.js +1 -1
  212. package/esm2015/grid/src/lib/pipes/editor-dynamic-item.pipe.js +1 -1
  213. package/esm2015/grid/src/lib/pipes/editor-handler.pipe.js +1 -1
  214. package/esm2015/grid/src/lib/pipes/editor-popup-visible.pipe.js +1 -1
  215. package/esm2015/grid/src/lib/pipes/editor-sub-information-handler.pipe.js +1 -1
  216. package/esm2015/grid/src/lib/pipes/editor-validate.pipe.js +1 -1
  217. package/esm2015/grid/src/lib/pipes/filter-mobile.pipe.js +1 -1
  218. package/esm2015/grid/src/lib/pipes/mobile-command-filter.js +1 -1
  219. package/esm2015/grid/src/lib/pipes/mobile-view-html-template.pipe.js +1 -1
  220. package/esm2015/grid/src/lib/pipes/value-transform.pipe.js +1 -1
  221. package/esm2015/grid/src/public-api.js +1 -1
  222. package/esm2015/grid-material/index.js +1 -1
  223. package/esm2015/grid-material/sd-angular-core-grid-material.js +1 -1
  224. package/esm2015/grid-material/src/lib/components/column-inline-filter/column-inline-filter.component.js +1 -1
  225. package/esm2015/grid-material/src/lib/components/desktop-cell/desktop-cell.component.js +1 -1
  226. package/esm2015/grid-material/src/lib/components/desktop-cell-children-view/desktop-cell-children-view.component.js +1 -1
  227. package/esm2015/grid-material/src/lib/components/desktop-cell-editor/desktop-cell-editor.component.js +1 -1
  228. package/esm2015/grid-material/src/lib/components/desktop-cell-view/desktop-cell-view.component.js +3 -3
  229. package/esm2015/grid-material/src/lib/components/desktop-command/desktop-command.component.js +1 -1
  230. package/esm2015/grid-material/src/lib/components/desktop-editor-validation/desktop-editor-validation.component.js +1 -1
  231. package/esm2015/grid-material/src/lib/components/dynamic-column/dynamic-column.component.js +1 -1
  232. package/esm2015/grid-material/src/lib/components/grid-filter/grid-filter.component.js +2 -2
  233. package/esm2015/grid-material/src/lib/components/popup-export/popup-export.component.js +1 -1
  234. package/esm2015/grid-material/src/lib/components/popup-filter/popup-filter.component.js +1 -1
  235. package/esm2015/grid-material/src/lib/components/popup-grid-configuration/popup-grid-configuration.component.js +1 -1
  236. package/esm2015/grid-material/src/lib/components/quick-action/quick-action.component.js +1 -1
  237. package/esm2015/grid-material/src/lib/directives/sd-material-cell-def.directive.js +1 -1
  238. package/esm2015/grid-material/src/lib/directives/sd-material-empty-data-def.directive.js +1 -1
  239. package/esm2015/grid-material/src/lib/directives/sd-material-filter-def.directive.js +1 -1
  240. package/esm2015/grid-material/src/lib/directives/sd-material-footer-def.directive.js +1 -1
  241. package/esm2015/grid-material/src/lib/directives/sd-material-sub-information-def.directive.js +1 -1
  242. package/esm2015/grid-material/src/lib/grid-material.component.js +18 -15
  243. package/esm2015/grid-material/src/lib/grid-material.module.js +1 -1
  244. package/esm2015/grid-material/src/lib/models/grid-action.model.js +1 -1
  245. package/esm2015/grid-material/src/lib/models/grid-column.model.js +1 -1
  246. package/esm2015/grid-material/src/lib/models/grid-command.model.js +1 -1
  247. package/esm2015/grid-material/src/lib/models/grid-config.model.js +1 -1
  248. package/esm2015/grid-material/src/lib/models/grid-configuration.model.js +1 -1
  249. package/esm2015/grid-material/src/lib/models/grid-editor.model.js +1 -1
  250. package/esm2015/grid-material/src/lib/models/grid-export.model.js +1 -1
  251. package/esm2015/grid-material/src/lib/models/grid-filter.model.js +1 -1
  252. package/esm2015/grid-material/src/lib/models/grid-option.model.js +1 -1
  253. package/esm2015/grid-material/src/lib/models/grid-reload.model.js +1 -1
  254. package/esm2015/grid-material/src/lib/models/grid-selection.model.js +1 -1
  255. package/esm2015/grid-material/src/lib/models/grid-style.model.js +1 -1
  256. package/esm2015/grid-material/src/lib/models/grid-sub-information.model.js +1 -1
  257. package/esm2015/grid-material/src/lib/models/grid.model.js +1 -1
  258. package/esm2015/grid-material/src/lib/pipes/column-badge.pipe.js +1 -1
  259. package/esm2015/grid-material/src/lib/pipes/column-children-filter.pipe.js +1 -1
  260. package/esm2015/grid-material/src/lib/pipes/column-html-template.pipe.js +1 -1
  261. package/esm2015/grid-material/src/lib/pipes/column-title.pipe.js +1 -1
  262. package/esm2015/grid-material/src/lib/pipes/column-tooltip.pipe.js +1 -1
  263. package/esm2015/grid-material/src/lib/pipes/column-transform.pipe.js +1 -1
  264. package/esm2015/grid-material/src/lib/pipes/column-values.pipe.js +1 -1
  265. package/esm2015/grid-material/src/lib/pipes/command-disable.pipe.js +1 -1
  266. package/esm2015/grid-material/src/lib/pipes/command-filter.pipe.js +1 -1
  267. package/esm2015/grid-material/src/lib/pipes/command-icon.pipe.js +1 -1
  268. package/esm2015/grid-material/src/lib/pipes/command-title.pipe.js +1 -1
  269. package/esm2015/grid-material/src/lib/pipes/editor-handler-column.pipe.js +1 -1
  270. package/esm2015/grid-material/src/lib/pipes/editor-handler-row.pipe.js +1 -1
  271. package/esm2015/grid-material/src/lib/pipes/editor-validate.pipe.js +1 -1
  272. package/esm2015/grid-material/src/lib/pipes/filter-column.pipe.js +1 -1
  273. package/esm2015/grid-material/src/lib/pipes/filter-external.pipe.js +1 -1
  274. package/esm2015/grid-material/src/lib/pipes/grid-configuration-result.pipe.js +1 -1
  275. package/esm2015/grid-material/src/lib/pipes/sd-id.pipe.js +1 -1
  276. package/esm2015/grid-material/src/lib/pipes/selection-action-filter.pipe.js +1 -1
  277. package/esm2015/grid-material/src/lib/pipes/selection-disable.pipe.js +1 -1
  278. package/esm2015/grid-material/src/lib/pipes/selection-visible-select-all.pipe.js +1 -1
  279. package/esm2015/grid-material/src/lib/pipes/selection-visible.pipe.js +1 -1
  280. package/esm2015/grid-material/src/lib/pipes/style-row-css.pipe.js +1 -1
  281. package/esm2015/grid-material/src/lib/services/generated-column/generated-column.model.js +1 -1
  282. package/esm2015/grid-material/src/lib/services/generated-column/generated-column.service.js +1 -1
  283. package/esm2015/grid-material/src/lib/services/grid-configuration.service.js +1 -1
  284. package/esm2015/grid-material/src/lib/services/grid-filter.service.js +1 -1
  285. package/esm2015/grid-material/src/lib/services/grid.service.js +1 -1
  286. package/esm2015/grid-material/src/public-api.js +1 -1
  287. package/esm2015/image-preview/index.js +1 -1
  288. package/esm2015/image-preview/sd-angular-core-image-preview.js +1 -1
  289. package/esm2015/image-preview/src/lib/directives/image-preview.directive.js +1 -1
  290. package/esm2015/image-preview/src/lib/image-preview/image-preview.component.js +1 -1
  291. package/esm2015/image-preview/src/lib/image-preview/image-preview.module.js +1 -1
  292. package/esm2015/image-preview/src/lib/models/image-preview.model.js +1 -1
  293. package/esm2015/image-preview/src/public-api.js +1 -1
  294. package/esm2015/input/index.js +1 -1
  295. package/esm2015/input/sd-angular-core-input.js +1 -1
  296. package/esm2015/input/src/lib/directives/input-suffix.directive.js +1 -1
  297. package/esm2015/input/src/lib/directives/touch.directive.js +1 -1
  298. package/esm2015/input/src/lib/input-tooltip.pipe.js +1 -1
  299. package/esm2015/input/src/lib/input.component.js +1 -1
  300. package/esm2015/input/src/lib/input.module.js +1 -1
  301. package/esm2015/input/src/public-api.js +1 -1
  302. package/esm2015/input-currency/index.js +1 -1
  303. package/esm2015/input-currency/sd-angular-core-input-currency.js +1 -1
  304. package/esm2015/input-currency/src/lib/input-currency-tooltip.pipe.js +1 -1
  305. package/esm2015/input-currency/src/lib/input-currency.component.js +1 -1
  306. package/esm2015/input-currency/src/lib/input-currency.module.js +1 -1
  307. package/esm2015/input-currency/src/public-api.js +1 -1
  308. package/esm2015/input-dropdown/index.js +1 -1
  309. package/esm2015/input-dropdown/sd-angular-core-input-dropdown.js +1 -1
  310. package/esm2015/input-dropdown/src/lib/input-tooltip.pipe.js +1 -1
  311. package/esm2015/input-dropdown/src/lib/input.component.js +1 -1
  312. package/esm2015/input-dropdown/src/lib/input.module.js +1 -1
  313. package/esm2015/input-dropdown/src/public-api.js +1 -1
  314. package/esm2015/input-upload-file/index.js +1 -1
  315. package/esm2015/input-upload-file/sd-angular-core-input-upload-file.js +1 -1
  316. package/esm2015/input-upload-file/src/lib/input-upload-file.component.js +1 -1
  317. package/esm2015/input-upload-file/src/lib/input-upload-file.module.js +1 -1
  318. package/esm2015/input-upload-file/src/public-api.js +1 -1
  319. package/esm2015/konva/index.js +1 -1
  320. package/esm2015/konva/sd-angular-core-konva.js +1 -1
  321. package/esm2015/konva/src/lib/konva.module.js +1 -1
  322. package/esm2015/konva/src/lib/merge-images/merge-images.component.js +1 -1
  323. package/esm2015/konva/src/public-api.js +1 -1
  324. package/esm2015/label/index.js +1 -1
  325. package/esm2015/label/sd-angular-core-label.js +1 -1
  326. package/esm2015/label/src/lib/label.component.js +1 -1
  327. package/esm2015/label/src/lib/label.module.js +1 -1
  328. package/esm2015/label/src/public-api.js +1 -1
  329. package/esm2015/lib/core.module.js +1 -1
  330. package/esm2015/lib/material.module.js +1 -1
  331. package/esm2015/loading/index.js +1 -1
  332. package/esm2015/loading/sd-angular-core-loading.js +1 -1
  333. package/esm2015/loading/src/lib/loading.service.js +1 -1
  334. package/esm2015/loading/src/public-api.js +1 -1
  335. package/esm2015/modal/index.js +1 -1
  336. package/esm2015/modal/sd-angular-core-modal.js +1 -1
  337. package/esm2015/modal/src/lib/bottom-sheet/bottom-sheet-body/bottom-sheet-body.component.js +1 -1
  338. package/esm2015/modal/src/lib/bottom-sheet/bottom-sheet-footer/bottom-sheet-footer.component.js +1 -1
  339. package/esm2015/modal/src/lib/bottom-sheet/bottom-sheet-header/bottom-sheet-header.component.js +1 -1
  340. package/esm2015/modal/src/lib/bottom-sheet/bottom-sheet.component.js +1 -1
  341. package/esm2015/modal/src/lib/modal/modal-body/modal-body.component.js +1 -1
  342. package/esm2015/modal/src/lib/modal/modal-footer/modal-footer.component.js +1 -1
  343. package/esm2015/modal/src/lib/modal/modal-header/modal-header.component.js +1 -1
  344. package/esm2015/modal/src/lib/modal/modal.component.js +1 -1
  345. package/esm2015/modal/src/lib/modal.module.js +1 -1
  346. package/esm2015/modal/src/public-api.js +1 -1
  347. package/esm2015/modal-resizable/index.js +1 -1
  348. package/esm2015/modal-resizable/sd-angular-core-modal-resizable.js +1 -1
  349. package/esm2015/modal-resizable/src/lib/modal-resizable/modal-resizable.component.js +1 -1
  350. package/esm2015/modal-resizable/src/lib/modal-resizable.module.js +1 -1
  351. package/esm2015/modal-resizable/src/public-api.js +1 -1
  352. package/esm2015/notify/index.js +1 -1
  353. package/esm2015/notify/sd-angular-core-notify.js +1 -1
  354. package/esm2015/notify/src/lib/components/dialog-confirm/dialog-confirm.component.js +1 -1
  355. package/esm2015/notify/src/lib/notify.module.js +1 -1
  356. package/esm2015/notify/src/lib/notify.service.js +1 -1
  357. package/esm2015/notify/src/public-api.js +1 -1
  358. package/esm2015/public-api.js +1 -1
  359. package/esm2015/quick-action/index.js +1 -1
  360. package/esm2015/quick-action/sd-angular-core-quick-action.js +1 -1
  361. package/esm2015/quick-action/src/lib/quick-action.component.js +1 -1
  362. package/esm2015/quick-action/src/lib/quick-action.module.js +1 -1
  363. package/esm2015/quick-action/src/public-api.js +1 -1
  364. package/esm2015/radio/index.js +1 -1
  365. package/esm2015/radio/sd-angular-core-radio.js +1 -1
  366. package/esm2015/radio/src/lib/radio.component.js +1 -1
  367. package/esm2015/radio/src/lib/radio.module.js +1 -1
  368. package/esm2015/radio/src/public-api.js +1 -1
  369. package/esm2015/sd-angular-core.js +1 -1
  370. package/esm2015/select/index.js +1 -1
  371. package/esm2015/select/sd-angular-core-select.js +1 -1
  372. package/esm2015/select/src/lib/select-display-def.directive.js +1 -1
  373. package/esm2015/select/src/lib/select.component.js +1 -1
  374. package/esm2015/select/src/lib/select.module.js +1 -1
  375. package/esm2015/select/src/public-api.js +1 -1
  376. package/esm2015/select-editor/index.js +1 -1
  377. package/esm2015/select-editor/sd-angular-core-select-editor.js +1 -1
  378. package/esm2015/select-editor/src/lib/select-editor.component.js +1 -1
  379. package/esm2015/select-editor/src/lib/select-editor.module.js +1 -1
  380. package/esm2015/select-editor/src/public-api.js +1 -1
  381. package/esm2015/service/index.js +1 -1
  382. package/esm2015/service/sd-angular-core-service.js +1 -1
  383. package/esm2015/service/src/lib/service.module.js +1 -1
  384. package/esm2015/service/src/public-api.js +1 -1
  385. package/esm2015/setting/index.js +1 -1
  386. package/esm2015/setting/sd-angular-core-setting.js +1 -1
  387. package/esm2015/setting/src/lib/setting.model.js +1 -1
  388. package/esm2015/setting/src/lib/setting.service.js +1 -1
  389. package/esm2015/setting/src/public-api.js +1 -1
  390. package/esm2015/side-drawer/index.js +1 -1
  391. package/esm2015/side-drawer/sd-angular-core-side-drawer.js +1 -1
  392. package/esm2015/side-drawer/src/lib/side-drawer/side-drawer.component.js +1 -1
  393. package/esm2015/side-drawer/src/lib/side-drawer.module.js +1 -1
  394. package/esm2015/side-drawer/src/public-api.js +1 -1
  395. package/esm2015/switch/index.js +1 -1
  396. package/esm2015/switch/sd-angular-core-switch.js +1 -1
  397. package/esm2015/switch/src/lib/switch.component.js +1 -1
  398. package/esm2015/switch/src/lib/switch.module.js +1 -1
  399. package/esm2015/switch/src/public-api.js +1 -1
  400. package/esm2015/tab-router/index.js +1 -1
  401. package/esm2015/tab-router/sd-angular-core-tab-router.js +1 -1
  402. package/esm2015/tab-router/src/lib/actions/tab-router.action.js +1 -1
  403. package/esm2015/tab-router/src/lib/components/tab-router-item/tab-router-item.component.js +1 -1
  404. package/esm2015/tab-router/src/lib/components/tab-router-nav/tab-router-nav.component.js +1 -1
  405. package/esm2015/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.js +1 -1
  406. package/esm2015/tab-router/src/lib/decorators/tab.decorator.js +1 -1
  407. package/esm2015/tab-router/src/lib/events/tab-router.event.js +1 -1
  408. package/esm2015/tab-router/src/lib/models/tab-router.model.js +1 -1
  409. package/esm2015/tab-router/src/lib/pipes/tab-info.pipe.js +1 -1
  410. package/esm2015/tab-router/src/lib/services/tab-decorator.service.js +1 -1
  411. package/esm2015/tab-router/src/lib/services/tab-router.service.js +1 -1
  412. package/esm2015/tab-router/src/lib/tab-router.module.js +1 -1
  413. package/esm2015/tab-router/src/public-api.js +1 -1
  414. package/esm2015/textarea/index.js +1 -1
  415. package/esm2015/textarea/sd-angular-core-textarea.js +1 -1
  416. package/esm2015/textarea/src/lib/textarea.component.js +1 -1
  417. package/esm2015/textarea/src/lib/textarea.module.js +1 -1
  418. package/esm2015/textarea/src/public-api.js +1 -1
  419. package/esm2015/time/index.js +1 -1
  420. package/esm2015/time/sd-angular-core-time.js +1 -1
  421. package/esm2015/time/src/lib/time.component.js +1 -1
  422. package/esm2015/time/src/lib/time.module.js +1 -1
  423. package/esm2015/time/src/public-api.js +1 -1
  424. package/esm2015/translate/index.js +1 -1
  425. package/esm2015/translate/sd-angular-core-translate.js +1 -1
  426. package/esm2015/translate/src/lib/translate.model.js +1 -1
  427. package/esm2015/translate/src/lib/translate.module.js +1 -1
  428. package/esm2015/translate/src/lib/translate.pipe.js +1 -1
  429. package/esm2015/translate/src/lib/translate.service.js +1 -1
  430. package/esm2015/upload-excel/index.js +1 -1
  431. package/esm2015/upload-excel/sd-angular-core-upload-excel.js +1 -1
  432. package/esm2015/upload-excel/src/lib/upload-excel.component.js +1 -1
  433. package/esm2015/upload-excel/src/lib/upload-excel.model.js +1 -1
  434. package/esm2015/upload-excel/src/lib/upload-excel.module.js +1 -1
  435. package/esm2015/upload-excel/src/public-api.js +1 -1
  436. package/esm2015/upload-file/index.js +1 -1
  437. package/esm2015/upload-file/sd-angular-core-upload-file.js +1 -1
  438. package/esm2015/upload-file/src/lib/upload-file.component.js +1 -1
  439. package/esm2015/upload-file/src/lib/upload-file.module.js +1 -1
  440. package/esm2015/upload-file/src/public-api.js +1 -1
  441. package/esm2015/utility/index.js +1 -1
  442. package/esm2015/utility/sd-angular-core-utility.js +1 -1
  443. package/esm2015/utility/src/lib/directives/desktop.directive.js +1 -1
  444. package/esm2015/utility/src/lib/directives/mobile-tablet.directive.js +1 -1
  445. package/esm2015/utility/src/lib/directives/mobile.directive.js +1 -1
  446. package/esm2015/utility/src/lib/directives/tablet.directive.js +1 -1
  447. package/esm2015/utility/src/lib/pipes/currency.pipe.js +1 -1
  448. package/esm2015/utility/src/lib/pipes/safe-html.pipe.js +1 -1
  449. package/esm2015/utility/src/lib/pipes/time-different.pipe.js +2 -2
  450. package/esm2015/utility/src/lib/utility.module.js +1 -1
  451. package/esm2015/utility/src/lib/utility.service.js +1 -1
  452. package/esm2015/utility/src/public-api.js +1 -1
  453. package/fesm2015/sd-angular-core-grid-material.js +20 -17
  454. package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
  455. package/fesm2015/sd-angular-core-utility.js +1 -1
  456. package/fesm2015/sd-angular-core-utility.js.map +1 -1
  457. package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
  458. package/grid-material/src/lib/grid-material.component.d.ts +1 -1
  459. package/package.json +1 -1
  460. package/{sd-angular-core-1.0.3.tgz → sd-angular-core-1.0.7.tgz} +0 -0
@@ -815,7 +815,7 @@
815
815
  SdGridFilter.decorators = [
816
816
  { type: core.Component, args: [{
817
817
  selector: 'sd-grid-filter',
818
- template: "<ng-container *ngIf=\"isVisible\">\r\n <div *ngIf=\"!isMobileOrTablet && (columns?.length || externalFilters?.length || filterDefs?.length)\"\r\n class=\"row mx-0 pb-10\">\r\n <ng-container *ngIf=\"filter?.sorts?.length\">\r\n <ng-container *ngFor=\"let field of filter?.sorts\">\r\n <ng-container *ngIf=\"columns?.length && !filter?.inlineColumn\">\r\n <ng-container *ngFor=\"let item of columns | sdFilterColumn:field\">\r\n <ng-container *ngTemplateOutlet=\"filterColumn; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"externalFilters?.length\">\r\n <ng-container *ngFor=\"let item of externalFilters | sdFilterExternal:field\">\r\n <ng-container *ngTemplateOutlet=\"filterExternal; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngFor=\"let item of filterDefs\">\r\n <div *ngIf=\"inlineFilterDef[item.sdMaterialFilterDef] && item.sdMaterialFilterDef === field\"\r\n class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef;context:{filterDef:filterDef, isInline: true}\">\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!filter?.sorts?.length\">\r\n <ng-container *ngIf=\"columns?.length && !filter?.inlineColumn\">\r\n <ng-container *ngFor=\"let item of columns | sdFilterColumn\">\r\n <ng-container *ngTemplateOutlet=\"filterColumn; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"externalFilters?.length\">\r\n <ng-container *ngFor=\"let item of externalFilters | sdFilterExternal\">\r\n <ng-container *ngTemplateOutlet=\"filterExternal; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngFor=\"let item of filterDefs\">\r\n <div *ngIf=\"inlineFilterDef[item.sdMaterialFilterDef]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef;context:{filterDef:filterDef, isInline: true}\">\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n <ng-template #filterColumn let-item=\"item\">\r\n <div *ngIf=\"inlineColumn[item.field]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\" [(model)]=\"columnFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\">\r\n </sd-input>\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'number'\" type=\"number\" [(model)]=\"columnFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\">\r\n </sd-input>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.option?.displayOnTrue || 'True' },\r\n {value:'0',display:item.option?.displayOnFalse || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\">\r\n </sd-select>\r\n <sd-select *ngIf=\"item.type === 'values' && item?.option?.selection !== 'AUTOCOMPLETE'\"\r\n [items]=\"item.option?.items\" [valueField]=\"item.option?.valueField\"\r\n [displayField]=\"item.option.displayField\" [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\"\r\n [disabled]=\"item.filter?.disabled\"\r\n [multiple]=\"item?.option?.selection === 'MULTIPLE' || item?.item?.selection === 'MULTIPLEAUTOCOMPLETE'\"\r\n [filtered]=\"item?.option?.selection === 'MULTIPLEAUTOCOMPLETE'\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.type === 'values' && item?.option?.selection === 'AUTOCOMPLETE'\"\r\n [items]=\"item.option?.items\" [valueField]=\"item.option?.valueField\"\r\n [displayField]=\"item.option?.displayField\" [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\"\r\n [disabled]=\"item.filter?.disabled\">\r\n </sd-autocomplete>\r\n <sd-date-time *ngIf=\"item.type === 'date' || item.type === 'datetime' || item.type === 'time'\"\r\n [label]=\"item.title\" [(model)]=\"columnFilter[item.field]\" [type]=\"item.type\" (sdChange)=\"onFilter(item)\">\r\n </sd-date-time>\r\n </div>\r\n </ng-template>\r\n <ng-template #filterExternal let-item=\"item\">\r\n <div *ngIf=\"inlineExternal[item.field]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\" [(model)]=\"externalFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\">\r\n </sd-input>\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'number'\" type=\"number\" [(model)]=\"externalFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\">\r\n </sd-input>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.option?.displayOnTrue || 'True' },\r\n {value:'0',display:item.option?.displayOnFalse || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\">\r\n </sd-select>\r\n <ng-container *ngIf=\"item.type === 'values' && item.option\">\r\n <sd-select *ngIf=\"item.option?.selection === 'MULTIPLE'\" [label]=\"item.title\" [items]=\"item.option.items\"\r\n [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" [selectAll]=\"item.option.selectAll\" multiple=\"true\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.option?.selection === 'AUTOCOMPLETE'\" [label]=\"item.title\"\r\n [items]=\"item.option.items\" [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\">\r\n </sd-autocomplete>\r\n <sd-select *ngIf=\"item.option?.selection === 'MULTIPLEAUTOCOMPLETE'\" [label]=\"item.title\"\r\n [items]=\"item.option.items\" [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" filtered=\"true\" multiple>\r\n </sd-select>\r\n <sd-select *ngIf=\"!item.option?.selection\" [label]=\"item.title\" [items]=\"item.option.items\"\r\n [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\">\r\n </sd-select>\r\n </ng-container>\r\n <sd-date-time [label]=\"item.title\" *ngIf=\"item.type ==='date' || item.type ==='datetime'\"\r\n [(model)]=\"externalFilter[item.field]\" [type]=\"item.type\" (sdChange)=\"onFilter(item)\">\r\n </sd-date-time>\r\n <sd-date-range [label]=\"item.title\" *ngIf=\"item.type ==='daterange' && externalFilter[item.field]\"\r\n [(from)]=\"externalFilter[item.field].from\" [(to)]=\"externalFilter[item.field].to\" [min]=\"item.minDate\"\r\n [max]=\"item.maxDate\" (sdChange)=\"onFilter(item)\">\r\n </sd-date-range>\r\n </div>\r\n </ng-template>\r\n <sd-popup-filter [columns]=\"columns\" [externalFilters]=\"externalFilters\" (changeFilter)=\"onChangeFilter($event)\"\r\n (clearFilter)=\"onReset()\" [filterDefs]=\"filterDefs\">\r\n </sd-popup-filter>\r\n</ng-container>",
818
+ template: "<ng-container *ngIf=\"isVisible\">\r\n <div *ngIf=\"!isMobileOrTablet && ((columns?.length && !filter?.inlineColumn) || externalFilters?.length || filterDefs?.length)\"\r\n class=\"row mx-0 pb-10\">\r\n <ng-container *ngIf=\"filter?.sorts?.length\">\r\n <ng-container *ngFor=\"let field of filter?.sorts\">\r\n <ng-container *ngIf=\"columns?.length && !filter?.inlineColumn\">\r\n <ng-container *ngFor=\"let item of columns | sdFilterColumn:field\">\r\n <ng-container *ngTemplateOutlet=\"filterColumn; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"externalFilters?.length\">\r\n <ng-container *ngFor=\"let item of externalFilters | sdFilterExternal:field\">\r\n <ng-container *ngTemplateOutlet=\"filterExternal; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngFor=\"let item of filterDefs\">\r\n <div *ngIf=\"inlineFilterDef[item.sdMaterialFilterDef] && item.sdMaterialFilterDef === field\"\r\n class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef;context:{filterDef:filterDef, isInline: true}\">\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!filter?.sorts?.length\">\r\n <ng-container *ngIf=\"columns?.length && !filter?.inlineColumn\">\r\n <ng-container *ngFor=\"let item of columns | sdFilterColumn\">\r\n <ng-container *ngTemplateOutlet=\"filterColumn; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"externalFilters?.length\">\r\n <ng-container *ngFor=\"let item of externalFilters | sdFilterExternal\">\r\n <ng-container *ngTemplateOutlet=\"filterExternal; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngFor=\"let item of filterDefs\">\r\n <div *ngIf=\"inlineFilterDef[item.sdMaterialFilterDef]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef;context:{filterDef:filterDef, isInline: true}\">\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n <ng-template #filterColumn let-item=\"item\">\r\n <div *ngIf=\"inlineColumn[item.field]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\" [(model)]=\"columnFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\">\r\n </sd-input>\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'number'\" type=\"number\" [(model)]=\"columnFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\">\r\n </sd-input>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.option?.displayOnTrue || 'True' },\r\n {value:'0',display:item.option?.displayOnFalse || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\">\r\n </sd-select>\r\n <sd-select *ngIf=\"item.type === 'values' && item?.option?.selection !== 'AUTOCOMPLETE'\"\r\n [items]=\"item.option?.items\" [valueField]=\"item.option?.valueField\"\r\n [displayField]=\"item.option.displayField\" [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\"\r\n [disabled]=\"item.filter?.disabled\"\r\n [multiple]=\"item?.option?.selection === 'MULTIPLE' || item?.item?.selection === 'MULTIPLEAUTOCOMPLETE'\"\r\n [filtered]=\"item?.option?.selection === 'MULTIPLEAUTOCOMPLETE'\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.type === 'values' && item?.option?.selection === 'AUTOCOMPLETE'\"\r\n [items]=\"item.option?.items\" [valueField]=\"item.option?.valueField\"\r\n [displayField]=\"item.option?.displayField\" [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\"\r\n [disabled]=\"item.filter?.disabled\">\r\n </sd-autocomplete>\r\n <sd-date-time *ngIf=\"item.type === 'date' || item.type === 'datetime' || item.type === 'time'\"\r\n [label]=\"item.title\" [(model)]=\"columnFilter[item.field]\" [type]=\"item.type\" (sdChange)=\"onFilter(item)\">\r\n </sd-date-time>\r\n </div>\r\n </ng-template>\r\n <ng-template #filterExternal let-item=\"item\">\r\n <div *ngIf=\"inlineExternal[item.field]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\" [(model)]=\"externalFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\">\r\n </sd-input>\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'number'\" type=\"number\" [(model)]=\"externalFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\">\r\n </sd-input>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.option?.displayOnTrue || 'True' },\r\n {value:'0',display:item.option?.displayOnFalse || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\">\r\n </sd-select>\r\n <ng-container *ngIf=\"item.type === 'values' && item.option\">\r\n <sd-select *ngIf=\"item.option?.selection === 'MULTIPLE'\" [label]=\"item.title\" [items]=\"item.option.items\"\r\n [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" [selectAll]=\"item.option.selectAll\" multiple=\"true\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.option?.selection === 'AUTOCOMPLETE'\" [label]=\"item.title\"\r\n [items]=\"item.option.items\" [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\">\r\n </sd-autocomplete>\r\n <sd-select *ngIf=\"item.option?.selection === 'MULTIPLEAUTOCOMPLETE'\" [label]=\"item.title\"\r\n [items]=\"item.option.items\" [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" filtered=\"true\" multiple>\r\n </sd-select>\r\n <sd-select *ngIf=\"!item.option?.selection\" [label]=\"item.title\" [items]=\"item.option.items\"\r\n [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\">\r\n </sd-select>\r\n </ng-container>\r\n <sd-date-time [label]=\"item.title\" *ngIf=\"item.type ==='date' || item.type ==='datetime'\"\r\n [(model)]=\"externalFilter[item.field]\" [type]=\"item.type\" (sdChange)=\"onFilter(item)\">\r\n </sd-date-time>\r\n <sd-date-range [label]=\"item.title\" *ngIf=\"item.type ==='daterange' && externalFilter[item.field]\"\r\n [(from)]=\"externalFilter[item.field].from\" [(to)]=\"externalFilter[item.field].to\" [min]=\"item.minDate\"\r\n [max]=\"item.maxDate\" (sdChange)=\"onFilter(item)\">\r\n </sd-date-range>\r\n </div>\r\n </ng-template>\r\n <sd-popup-filter [columns]=\"columns\" [externalFilters]=\"externalFilters\" (changeFilter)=\"onChangeFilter($event)\"\r\n (clearFilter)=\"onReset()\" [filterDefs]=\"filterDefs\">\r\n </sd-popup-filter>\r\n</ng-container>",
819
819
  styles: [":host{display:block;padding-left:0;padding-right:0}:host ::ng-deep .mat-form-field-wrapper{padding-bottom:0}"]
820
820
  },] }
821
821
  ];
@@ -1837,28 +1837,28 @@
1837
1837
  var rawColumnFilter = filterInfo.rawColumnFilter, orderBy = filterInfo.orderBy, orderDirection = filterInfo.orderDirection, pageSize = filterInfo.pageSize, pageNumber = filterInfo.pageNumber;
1838
1838
  var items = localItems.filter(function (item) {
1839
1839
  var e_4, _t;
1840
- var _a, _b;
1840
+ var _a, _b, _c, _d;
1841
1841
  try {
1842
1842
  for (var columns_1 = __values(columns), columns_1_1 = columns_1.next(); !columns_1_1.done; columns_1_1 = columns_1.next()) {
1843
1843
  var column = columns_1_1.value;
1844
- var field = column.field;
1844
+ var field = column.field, type = column.type;
1845
1845
  var filterValue = (rawColumnFilter[field] || '').toString().trim().toLowerCase();
1846
1846
  var columnValue = (item[field] || '').toString().trim().toLowerCase();
1847
1847
  if (filterValue) {
1848
- if (!columnValue) {
1848
+ if (!columnValue && type !== 'datetime' && type !== 'date' && type !== 'time') {
1849
1849
  return false;
1850
1850
  }
1851
- if (column.type === 'string') {
1851
+ if (type === 'string') {
1852
1852
  if (columnValue.indexOf(filterValue) === -1) {
1853
1853
  return false;
1854
1854
  }
1855
1855
  }
1856
- else if (column.type === 'values') {
1856
+ else if (type === 'values') {
1857
1857
  if (columnValue !== filterValue) {
1858
1858
  return false;
1859
1859
  }
1860
1860
  }
1861
- else if (column.type === 'number') {
1861
+ else if (type === 'number') {
1862
1862
  var fValue = +filterValue.replace('>=', '').replace('<=', '').replace('>', '').replace('<', '');
1863
1863
  var cValue = +columnValue;
1864
1864
  if (fValue || fValue === 0) {
@@ -1882,7 +1882,7 @@
1882
1882
  }
1883
1883
  }
1884
1884
  }
1885
- else if (column.type === 'bool') {
1885
+ else if (type === 'bool') {
1886
1886
  if (filterValue === '1' && columnValue !== '1' && columnValue !== 'true') {
1887
1887
  return false;
1888
1888
  }
@@ -1890,12 +1890,15 @@
1890
1890
  return false;
1891
1891
  }
1892
1892
  }
1893
- else if (column.type === 'datetime' || column.type === 'date' || column.type === 'time') {
1894
- var from = (_a = filterInfo.rawColumnFilter[column.field]) === null || _a === void 0 ? void 0 : _a.from;
1895
- var to = (_b = filterInfo.rawColumnFilter[column.field]) === null || _b === void 0 ? void 0 : _b.to;
1893
+ else if (type === 'datetime' || type === 'date' || type === 'time') {
1894
+ var from = (_b = (_a = rawColumnFilter[field]) === null || _a === void 0 ? void 0 : _a.from) !== null && _b !== void 0 ? _b : rawColumnFilter[field];
1895
+ var to = (_d = (_c = rawColumnFilter[field]) === null || _c === void 0 ? void 0 : _c.to) !== null && _d !== void 0 ? _d : rawColumnFilter[field];
1896
1896
  var fromDate = Date.begin(from);
1897
1897
  var toDate = Date.end(to);
1898
1898
  if (fromDate && toDate) {
1899
+ if (!columnValue) {
1900
+ return false;
1901
+ }
1899
1902
  if (new Date(columnValue).getTime() < fromDate.getTime() || new Date(columnValue).getTime() >= toDate.getTime()) {
1900
1903
  return false;
1901
1904
  }
@@ -2027,18 +2030,21 @@
2027
2030
  }
2028
2031
  });
2029
2032
  }); });
2030
- this.reload = function () { return __awaiter(_this, void 0, void 0, function () {
2031
- var data;
2032
- return __generator(this, function (_t) {
2033
- switch (_t.label) {
2034
- case 0: return [4 /*yield*/, __classPrivateFieldGet(this, _load$1).call(this, __classPrivateFieldGet(this, _getFilter).call(this))];
2035
- case 1:
2036
- data = _t.sent();
2037
- __classPrivateFieldGet(this, _render).call(this, data);
2038
- return [2 /*return*/];
2039
- }
2033
+ this.reload = function (force) {
2034
+ if (force === void 0) { force = true; }
2035
+ return __awaiter(_this, void 0, void 0, function () {
2036
+ var data;
2037
+ return __generator(this, function (_t) {
2038
+ switch (_t.label) {
2039
+ case 0: return [4 /*yield*/, __classPrivateFieldGet(this, _load$1).call(this, __classPrivateFieldGet(this, _getFilter).call(this), force)];
2040
+ case 1:
2041
+ data = _t.sent();
2042
+ __classPrivateFieldGet(this, _render).call(this, data);
2043
+ return [2 /*return*/];
2044
+ }
2045
+ });
2040
2046
  });
2041
- }); };
2047
+ };
2042
2048
  _exportedItems.set(this, function (pageNumber, pageSize) {
2043
2049
  if (pageNumber === void 0) { pageNumber = 0; }
2044
2050
  if (pageSize === void 0) { pageSize = 10000; }
@@ -2369,7 +2375,7 @@
2369
2375
  }); };
2370
2376
  this.onFilterChange = function () {
2371
2377
  __classPrivateFieldGet(_this, _paginator).pageIndex = 0;
2372
- _this.reload();
2378
+ _this.reload(false);
2373
2379
  };
2374
2380
  this.onExpand = function (rowData) { return __awaiter(_this, void 0, void 0, function () {
2375
2381
  var _q, _r, _s, data;
@@ -2734,7 +2740,7 @@
2734
2740
  SdGridMaterial.decorators = [
2735
2741
  { type: core.Component, args: [{
2736
2742
  selector: 'sd-grid-material',
2737
- 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 <ng-container *ngIf=\"!gridOption.filter?.disabled\">\r\n <sd-grid-filter [filter]=\"gridOption?.filter\" [columns]=\"configuration.firstColumns\" [filterDefs]=\"filterDefs\">\r\n </sd-grid-filter>\r\n </ng-container>\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]=\"items\" matSort\r\n [matSortDisabled]=\"!gridOption.sortable\" cdkDropList cdkDropListOrientation=\"horizontal\"\r\n [cdkDropListDisabled]=\"!gridOption.dropDragColumnEnable\"\r\n (cdkDropListDropped)=\"drop($event, configuration.displayedColumns)\" multiTemplateDataRows>\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 <div *ngIf=\"sdSubInformation?.templateRef\" [@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 </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\" mat-icon-button aria-label=\"Expand & Collapse\"\r\n (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\" [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 *ngFor=\"let column of configuration.firstColumns; let i = index\" [matColumnDef]=\"column.field\"\r\n [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 \" [innerHTML]=\"configuration.firstColumns[i].titleHtml || configuration.firstColumns[i].title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\" [value]=\"columnFilter[column.field]\"\r\n [columnFilter]=\"columnFilter\" [column]=\"column\" (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-8\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell [sdId]=\"item.sdId\" [key]=\"key\" [value]=\"item[column.field]\" [column]=\"column\"\r\n [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 <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 [innerHTML]=\"column.titleHtml || column.title\"></div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\" [value]=\"columnFilter[column.field]\"\r\n [columnFilter]=\"columnFilter\" [column]=\"column\" (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-8\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell [sdId]=\"item.sdId\" [key]=\"key\" [value]=\"item[column.field]\" [column]=\"column\"\r\n [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\"></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 <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\" 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 *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\" [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div [innerHTML]=\"column.titleHtml || column.title\"></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 [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\" [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div>\r\n <div [innerHTML]=\"column.titleHtml || column.title\"></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=\"\r\n !gridOption.filter?.disabled && !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.exportDefault(true)\" 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-popup-export *ngIf=\"gridOption.export?.visible\" [gridOption]=\"gridOption\" (export)=\"onExport($event)\"\r\n #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<sd-grid-quick-action [gridOption]=\"gridOption\" [selectedItems]=\"selectedItems\" (clear)=\"onClearSelection()\">\r\n</sd-grid-quick-action>",
2743
+ 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 <ng-container *ngIf=\"!gridOption.filter?.disabled\">\r\n <sd-grid-filter [filter]=\"gridOption?.filter\" [columns]=\"configuration.firstColumns\" [filterDefs]=\"filterDefs\">\r\n </sd-grid-filter>\r\n </ng-container>\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]=\"items\" matSort\r\n [matSortDisabled]=\"!gridOption.sortable\" cdkDropList cdkDropListOrientation=\"horizontal\"\r\n [cdkDropListDisabled]=\"!gridOption.dropDragColumnEnable\"\r\n (cdkDropListDropped)=\"drop($event, configuration.displayedColumns)\" multiTemplateDataRows>\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 <div *ngIf=\"sdSubInformation?.templateRef\" [@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 </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\" mat-icon-button aria-label=\"Expand & Collapse\"\r\n (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\" [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 *ngFor=\"let column of configuration.firstColumns; let i = index\" [matColumnDef]=\"column.field\"\r\n [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 \" [innerHTML]=\"configuration.firstColumns[i].titleHtml || configuration.firstColumns[i].title\">\r\n </div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\" [value]=\"columnFilter[column.field]\"\r\n [columnFilter]=\"columnFilter\" [column]=\"column\" (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-8\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell [sdId]=\"item.sdId\" [key]=\"key\" [value]=\"item[column.field]\" [column]=\"column\"\r\n [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 <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 [innerHTML]=\"column.titleHtml || column.title\"></div>\r\n <sd-column-inline-filter *ngIf=\"gridOption.filter?.inlineColumn\" [value]=\"columnFilter[column.field]\"\r\n [columnFilter]=\"columnFilter\" [column]=\"column\" (filterChange)=\"onFilterChange()\">\r\n </sd-column-inline-filter>\r\n </div>\r\n </th>\r\n <td class=\"c-td px-8\" mat-cell *matCellDef=\"let item\">\r\n <sd-desktop-cell [sdId]=\"item.sdId\" [key]=\"key\" [value]=\"item[column.field]\" [column]=\"column\"\r\n [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\"></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 <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 *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\" [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div [innerHTML]=\"column.titleHtml || column.title\"></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 [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\" [ngStyle]=\"{ 'min-width': column.width }\">\r\n <div>\r\n <div [innerHTML]=\"column.titleHtml || column.title\"></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=\"\r\n !gridOption.filter?.disabled && !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.exportDefault(true)\" 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-popup-export *ngIf=\"gridOption.export?.visible\" [gridOption]=\"gridOption\" (export)=\"onExport($event)\"\r\n #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<sd-grid-quick-action [gridOption]=\"gridOption\" [selectedItems]=\"selectedItems\" (clear)=\"onClearSelection()\">\r\n</sd-grid-quick-action>",
2738
2744
  animations: [
2739
2745
  animations.trigger('detailExpand', [
2740
2746
  animations.state('collapsed', animations.style({ height: '0', minHeight: '0', visibility: 'hidden' })),
@@ -3017,9 +3023,9 @@
3017
3023
  SdDesktopCellView.decorators = [
3018
3024
  { type: core.Component, args: [{
3019
3025
  selector: 'sd-desktop-cell-view',
3020
- template: "<ng-container *ngIf=\"column.htmlTemplate;else useDefaultView\">\r\n <div (click)=\"column.click && column.click(item[column.field], item)\" style=\"overflow-wrap: break-word;\"\r\n [ngClass]=\"{'cursor-pointer':column.click}\"\r\n [innerHTML]=\"(item[column.field] | columnHtmlTemplate:item:column) | safeHtml\">\r\n </div>\r\n</ng-container>\r\n<ng-template #useDefaultView>\r\n <ng-container *sdLet=\"item[column.field] | columnBadge:item:column as badge\">\r\n <ng-container *sdLet=\"item[column.field] | columnTooltip:item:column as tooltip\">\r\n <ng-container *sdLet=\"item[column.field] | columnTransform:item:column:key | async as val\">\r\n <ng-container\r\n *ngIf=\"column.type === 'string' || column.type === 'number' || column.type === 'bool' || column.type === 'values'\">\r\n <ng-container *ngIf=\"!!badge\">\r\n <sd-badge [type]=\"badge.type\" [title]=\"val\" [color]=\"badge.color\" [icon]=\"badge.icon\" [tooltip]=\"tooltip\"\r\n (sdClick)=\"column.click(item[column.field], item)\"></sd-badge>\r\n </ng-container>\r\n <ng-container *ngIf=\"!badge\">\r\n <div class=\"text-break\" [matTooltip]=\"tooltip\">\r\n <a *ngIf=\"column.click\" href=\"javascript:;\" (click)=\"column.click(item[column.field], item)\">{{val}}</a>\r\n <ng-container *ngIf=\"!column.click\">{{val}}\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <div *ngIf=\"column.type === 'date'\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | date:'dd/MM/yyyy'\">\r\n {{val | sdTimeDifferent:'dd/MM/yyyy':column.option?.timeDifferent | async}}\r\n </div>\r\n <div *ngIf=\"column.type === 'datetime'\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | date:'dd/MM/yyyy HH:mm'\">\r\n {{val | sdTimeDifferent:'dd/MM/yyyy HH:mm':column.option?.timeDifferent | async}}\r\n </div>\r\n <div *ngIf=\"column.type === 'time'\">\r\n {{val | date:'HH:mm'}}\r\n </div>\r\n <div *ngIf=\"column.type === 'image'\" class=\"align-middle text-center\">\r\n <img *ngIf=\"val\" [src]=\"val\" [width]=\"column.option?.width\" [height]=\"column.option?.height\"\r\n style=\"margin: 5px 0;object-fit: contain;\" (click)=\"column.click && column.click(item[column.field], item)\"\r\n [ngClass]=\"{'pointer':column.click}\">\r\n <mat-icon *ngIf=\"!val\" class=\"c-img\" [ngClass]=\"{'pointer':column.click}\"\r\n (click)=\"column.click && column.click(item[column.field], item)\">image</mat-icon>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <sd-desktop-cell-children-view *ngIf=\"column.type === 'children'\" [key]=\"key\" [item]=\"item\" [column]=\"column\">\r\n </sd-desktop-cell-children-view>\r\n</ng-template>",
3026
+ template: "<ng-container *ngIf=\"column.htmlTemplate;else useDefaultView\">\r\n <div (click)=\"column.click && column.click(item[column.field], item)\" style=\"overflow-wrap: break-word;\"\r\n [ngClass]=\"{'cursor-pointer':column.click}\"\r\n [innerHTML]=\"(item[column.field] | columnHtmlTemplate:item:column) | safeHtml\">\r\n </div>\r\n</ng-container>\r\n<ng-template #useDefaultView>\r\n <ng-container *sdLet=\"item[column.field] | columnBadge:item:column as badge\">\r\n <ng-container *sdLet=\"item[column.field] | columnTooltip:item:column as tooltip\">\r\n <ng-container *sdLet=\"item[column.field] | columnTransform:item:column:key | async as val\">\r\n <ng-container\r\n *ngIf=\"column.type === 'string' || column.type === 'number' || column.type === 'bool' || column.type === 'values'\">\r\n <ng-container *ngIf=\"!!badge\">\r\n <sd-badge [type]=\"badge.type\" [title]=\"val\" [color]=\"badge.color\" [icon]=\"badge.icon\" [tooltip]=\"tooltip\"\r\n (sdClick)=\"column.click(item[column.field], item)\"></sd-badge>\r\n </ng-container>\r\n <ng-container *ngIf=\"!badge\">\r\n <div class=\"text-break\" [matTooltip]=\"tooltip\">\r\n <a *ngIf=\"column.click\" href=\"javascript:;\" (click)=\"column.click(item[column.field], item)\">{{val}}</a>\r\n <ng-container *ngIf=\"!column.click\">{{val}}\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <div *ngIf=\"column.type === 'date'\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | date:'dd/MM/yyyy'\">\r\n <ng-container *ngIf=\"column.option?.timeDifferent;else noTimeDifferent\">\r\n {{val | sdTimeDifferent:'dd/MM/yyyy':column.option?.timeDifferent | async}}\r\n </ng-container>\r\n <ng-template #noTimeDifferent>\r\n {{val | date:'dd/MM/yyyy'}}\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"column.type === 'datetime'\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"item[column.field] | date:'dd/MM/yyyy HH:mm'\">\r\n <ng-container *ngIf=\"column.option?.timeDifferent;else noTimeDifferent\">\r\n {{val | sdTimeDifferent:'dd/MM/yyyy HH:mm':column.option?.timeDifferent | async}}\r\n </ng-container>\r\n <ng-template #noTimeDifferent>\r\n <span class=\"d-block T14R c-time\">{{val | date:'HH:mm'}}</span>\r\n <span class=\"d-block T14R\">{{val | date:'dd/MM/yyyy'}}</span>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"column.type === 'time'\">\r\n <span class=\"d-block T14R c-time\">{{val | date:'HH:mm'}}</span>\r\n </div>\r\n <div *ngIf=\"column.type === 'image'\" class=\"align-middle text-center\">\r\n <img *ngIf=\"val\" [src]=\"val\" [width]=\"column.option?.width\" [height]=\"column.option?.height\"\r\n style=\"margin: 5px 0;object-fit: contain;\" (click)=\"column.click && column.click(item[column.field], item)\"\r\n [ngClass]=\"{'pointer':column.click}\">\r\n <mat-icon *ngIf=\"!val\" class=\"c-img\" [ngClass]=\"{'pointer':column.click}\"\r\n (click)=\"column.click && column.click(item[column.field], item)\">image</mat-icon>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <sd-desktop-cell-children-view *ngIf=\"column.type === 'children'\" [key]=\"key\" [item]=\"item\" [column]=\"column\">\r\n </sd-desktop-cell-children-view>\r\n</ng-template>",
3021
3027
  changeDetection: core.ChangeDetectionStrategy.OnPush,
3022
- styles: [".c-color-success{color:#4caf50}.c-color-danger{color:#f82c13}.c-img{font-size:30px;opacity:.5}.c-img.pointer:hover{opacity:.9}"]
3028
+ styles: [".c-color-success{color:#4caf50}.c-color-danger{color:#f82c13}.c-img{font-size:30px;opacity:.5}.c-img.pointer:hover{opacity:.9}.c-time{color:#757575}"]
3023
3029
  },] }
3024
3030
  ];
3025
3031
  SdDesktopCellView.ctorParameters = function () { return []; };