angular-slickgrid 4.2.0 → 4.2.3

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 (415) hide show
  1. package/LICENSE +20 -20
  2. package/{dist/app → app}/modules/angular-slickgrid/components/angular-slickgrid.component.d.ts +2 -2
  3. package/{dist/app → app}/modules/angular-slickgrid/constants.d.ts +0 -0
  4. package/{dist/app → app}/modules/angular-slickgrid/extensions/index.d.ts +0 -0
  5. package/{dist/app → app}/modules/angular-slickgrid/extensions/slickRowDetailView.d.ts +0 -2
  6. package/{dist/app → app}/modules/angular-slickgrid/global-grid-options.d.ts +0 -0
  7. package/{dist/app → app}/modules/angular-slickgrid/index.d.ts +0 -0
  8. package/{dist/app → app}/modules/angular-slickgrid/models/angularComponentOutput.interface.d.ts +0 -0
  9. package/{dist/app → app}/modules/angular-slickgrid/models/angularGridInstance.interface.d.ts +0 -0
  10. package/{dist/app → app}/modules/angular-slickgrid/models/externalTestingDependencies.interface.d.ts +0 -0
  11. package/{dist/app → app}/modules/angular-slickgrid/models/gridOption.interface.d.ts +0 -0
  12. package/{dist/app → app}/modules/angular-slickgrid/models/index.d.ts +0 -0
  13. package/{dist/app → app}/modules/angular-slickgrid/models/rowDetailView.interface.d.ts +0 -0
  14. package/{dist/app → app}/modules/angular-slickgrid/models/slickGrid.interface.d.ts +0 -0
  15. package/{dist/app → app}/modules/angular-slickgrid/modules/angular-slickgrid.module.d.ts +0 -0
  16. package/{dist/app → app}/modules/angular-slickgrid/services/angularUtil.service.d.ts +0 -0
  17. package/{dist/app → app}/modules/angular-slickgrid/services/bsDropdown.service.d.ts +0 -0
  18. package/{dist/app → app}/modules/angular-slickgrid/services/container.service.d.ts +1 -0
  19. package/{dist/app → app}/modules/angular-slickgrid/services/index.d.ts +0 -0
  20. package/{dist/app → app}/modules/angular-slickgrid/services/translater.service.d.ts +0 -0
  21. package/{dist/app → app}/modules/angular-slickgrid/services/utilities.d.ts +0 -0
  22. package/{dist/app → app}/modules/angular-slickgrid/slickgrid-config.d.ts +0 -0
  23. package/docs/assets/lib/multiple-select/README.md +17 -0
  24. package/{dist/esm2020 → esm2020}/angular-slickgrid.mjs +0 -0
  25. package/esm2020/app/modules/angular-slickgrid/components/angular-slickgrid.component.mjs +1170 -0
  26. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/constants.mjs +1 -1
  27. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/extensions/index.mjs +1 -1
  28. package/esm2020/app/modules/angular-slickgrid/extensions/slickRowDetailView.mjs +298 -0
  29. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/global-grid-options.mjs +1 -1
  30. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/index.mjs +1 -1
  31. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/models/angularComponentOutput.interface.mjs +1 -1
  32. package/esm2020/app/modules/angular-slickgrid/models/angularGridInstance.interface.mjs +2 -0
  33. package/esm2020/app/modules/angular-slickgrid/models/externalTestingDependencies.interface.mjs +2 -0
  34. package/esm2020/app/modules/angular-slickgrid/models/gridOption.interface.mjs +2 -0
  35. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/models/index.mjs +1 -1
  36. package/esm2020/app/modules/angular-slickgrid/models/rowDetailView.interface.mjs +2 -0
  37. package/esm2020/app/modules/angular-slickgrid/models/slickGrid.interface.mjs +2 -0
  38. package/esm2020/app/modules/angular-slickgrid/modules/angular-slickgrid.module.mjs +43 -0
  39. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/services/angularUtil.service.mjs +4 -4
  40. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/services/bsDropdown.service.mjs +4 -4
  41. package/esm2020/app/modules/angular-slickgrid/services/container.service.mjs +29 -0
  42. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/services/index.mjs +1 -1
  43. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/services/translater.service.mjs +4 -4
  44. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/services/utilities.mjs +1 -1
  45. package/{dist/esm2020 → esm2020}/app/modules/angular-slickgrid/slickgrid-config.mjs +1 -1
  46. package/{dist/esm2020 → esm2020}/public_api.mjs +1 -1
  47. package/{dist/fesm2015 → fesm2015}/angular-slickgrid.mjs +48 -51
  48. package/fesm2015/angular-slickgrid.mjs.map +1 -0
  49. package/{dist/fesm2020 → fesm2020}/angular-slickgrid.mjs +48 -51
  50. package/fesm2020/angular-slickgrid.mjs.map +1 -0
  51. package/{dist/i18n → i18n}/en.json +89 -89
  52. package/{dist/i18n → i18n}/fr.json +90 -90
  53. package/{dist/angular-slickgrid.d.ts → index.d.ts} +0 -0
  54. package/package.json +33 -118
  55. package/{dist/public_api.d.ts → public_api.d.ts} +0 -0
  56. package/test/cypress/node_modules/@cypress/request/README.md +1038 -0
  57. package/test/cypress/node_modules/@cypress/xvfb/README.md +48 -0
  58. package/test/cypress/node_modules/@cypress/xvfb/node_modules/debug/README.md +437 -0
  59. package/test/cypress/node_modules/@types/node/README.md +16 -0
  60. package/test/cypress/node_modules/@types/sinonjs__fake-timers/README.md +16 -0
  61. package/test/cypress/node_modules/@types/sizzle/README.md +16 -0
  62. package/test/cypress/node_modules/@types/yauzl/README.md +16 -0
  63. package/test/cypress/node_modules/@types/yauzl/node_modules/@types/node/README.md +16 -0
  64. package/test/cypress/node_modules/aggregate-error/README.md +61 -0
  65. package/test/cypress/node_modules/ansi-colors/README.md +315 -0
  66. package/test/cypress/node_modules/ansi-escapes/README.md +245 -0
  67. package/test/cypress/node_modules/ansi-regex/README.md +78 -0
  68. package/test/cypress/node_modules/ansi-styles/README.md +152 -0
  69. package/test/cypress/node_modules/arch/README.md +71 -0
  70. package/test/cypress/node_modules/asn1/README.md +50 -0
  71. package/test/cypress/node_modules/assert-plus/README.md +162 -0
  72. package/test/cypress/node_modules/astral-regex/README.md +46 -0
  73. package/test/cypress/node_modules/async/README.md +60 -0
  74. package/test/cypress/node_modules/asynckit/README.md +233 -0
  75. package/test/cypress/node_modules/at-least-node/README.md +25 -0
  76. package/test/cypress/node_modules/aws-sign2/README.md +4 -0
  77. package/test/cypress/node_modules/aws4/README.md +183 -0
  78. package/test/cypress/node_modules/balanced-match/README.md +91 -0
  79. package/test/cypress/node_modules/base64-js/README.md +34 -0
  80. package/test/cypress/node_modules/bcrypt-pbkdf/README.md +45 -0
  81. package/test/cypress/node_modules/blob-util/README.md +623 -0
  82. package/test/cypress/node_modules/bluebird/README.md +57 -0
  83. package/test/cypress/node_modules/brace-expansion/README.md +129 -0
  84. package/test/cypress/node_modules/buffer/README.md +410 -0
  85. package/test/cypress/node_modules/buffer-crc32/README.md +47 -0
  86. package/test/cypress/node_modules/cachedir/README.md +27 -0
  87. package/test/cypress/node_modules/caseless/README.md +45 -0
  88. package/test/cypress/node_modules/chalk/README.md +293 -0
  89. package/test/cypress/node_modules/chalk/node_modules/supports-color/README.md +76 -0
  90. package/test/cypress/node_modules/check-more-types/README.md +952 -0
  91. package/test/cypress/node_modules/ci-info/README.md +114 -0
  92. package/test/cypress/node_modules/clean-stack/README.md +76 -0
  93. package/test/cypress/node_modules/cli-cursor/README.md +55 -0
  94. package/test/cypress/node_modules/cli-table3/README.md +218 -0
  95. package/test/cypress/node_modules/cli-truncate/README.md +139 -0
  96. package/test/cypress/node_modules/color-convert/README.md +68 -0
  97. package/test/cypress/node_modules/color-name/README.md +11 -0
  98. package/test/cypress/node_modules/colorette/README.md +102 -0
  99. package/test/cypress/node_modules/colors/README.md +221 -0
  100. package/test/cypress/node_modules/combined-stream/README.md +138 -0
  101. package/test/cypress/node_modules/commander/README.md +737 -0
  102. package/test/cypress/node_modules/common-tags/README.md +687 -0
  103. package/test/cypress/node_modules/core-util-is/README.md +3 -0
  104. package/test/cypress/node_modules/cross-spawn/README.md +96 -0
  105. package/test/cypress/node_modules/cypress/README.md +25 -0
  106. package/test/cypress/node_modules/cypress/mount-utils/README.md +14 -0
  107. package/test/cypress/node_modules/cypress/react/README.md +414 -0
  108. package/test/cypress/node_modules/cypress/vue/README.md +678 -0
  109. package/test/cypress/node_modules/cypress/vue2/README.md +693 -0
  110. package/test/cypress/node_modules/dashdash/README.md +574 -0
  111. package/test/cypress/node_modules/dayjs/README.md +128 -0
  112. package/test/cypress/node_modules/debug/README.md +455 -0
  113. package/test/cypress/node_modules/delayed-stream/README.md +141 -0
  114. package/test/cypress/node_modules/ecc-jsbn/README.md +8 -0
  115. package/test/cypress/node_modules/emoji-regex/README.md +73 -0
  116. package/test/cypress/node_modules/end-of-stream/README.md +54 -0
  117. package/test/cypress/node_modules/enquirer/README.md +1752 -0
  118. package/test/cypress/node_modules/escape-string-regexp/README.md +27 -0
  119. package/test/cypress/node_modules/eventemitter2/README.md +809 -0
  120. package/test/cypress/node_modules/execa/README.md +656 -0
  121. package/test/cypress/node_modules/executable/README.md +64 -0
  122. package/test/cypress/node_modules/extend/README.md +81 -0
  123. package/test/cypress/node_modules/extract-zip/README.md +57 -0
  124. package/test/cypress/node_modules/extract-zip/node_modules/debug/README.md +455 -0
  125. package/test/cypress/node_modules/extsprintf/README.md +46 -0
  126. package/test/cypress/node_modules/fd-slicer/README.md +199 -0
  127. package/test/cypress/node_modules/figures/README.md +139 -0
  128. package/test/cypress/node_modules/forever-agent/README.md +4 -0
  129. package/test/cypress/node_modules/form-data/README.md +234 -0
  130. package/test/cypress/node_modules/fs-extra/README.md +264 -0
  131. package/test/cypress/node_modules/fs.realpath/README.md +33 -0
  132. package/test/cypress/node_modules/get-stream/README.md +124 -0
  133. package/test/cypress/node_modules/getos/README.md +79 -0
  134. package/test/cypress/node_modules/getpass/README.md +32 -0
  135. package/test/cypress/node_modules/glob/README.md +375 -0
  136. package/test/cypress/node_modules/global-dirs/README.md +72 -0
  137. package/test/cypress/node_modules/graceful-fs/README.md +133 -0
  138. package/test/cypress/node_modules/has-flag/README.md +89 -0
  139. package/test/cypress/node_modules/http-signature/README.md +80 -0
  140. package/test/cypress/node_modules/human-signals/README.md +155 -0
  141. package/test/cypress/node_modules/ieee754/README.md +51 -0
  142. package/test/cypress/node_modules/indent-string/README.md +70 -0
  143. package/test/cypress/node_modules/inflight/README.md +37 -0
  144. package/test/cypress/node_modules/inherits/README.md +42 -0
  145. package/test/cypress/node_modules/ini/README.md +102 -0
  146. package/test/cypress/node_modules/is-ci/README.md +50 -0
  147. package/test/cypress/node_modules/is-fullwidth-code-point/README.md +39 -0
  148. package/test/cypress/node_modules/is-installed-globally/README.md +31 -0
  149. package/test/cypress/node_modules/is-path-inside/README.md +63 -0
  150. package/test/cypress/node_modules/is-stream/README.md +57 -0
  151. package/test/cypress/node_modules/is-typedarray/README.md +16 -0
  152. package/test/cypress/node_modules/isexe/README.md +51 -0
  153. package/test/cypress/node_modules/isstream/README.md +66 -0
  154. package/test/cypress/node_modules/jsbn/README.md +175 -0
  155. package/test/cypress/node_modules/json-schema/README.md +3 -0
  156. package/test/cypress/node_modules/json-stringify-safe/README.md +52 -0
  157. package/test/cypress/node_modules/jsonfile/README.md +205 -0
  158. package/test/cypress/node_modules/jsonfile/node_modules/universalify/README.md +76 -0
  159. package/test/cypress/node_modules/jsprim/README.md +287 -0
  160. package/test/cypress/node_modules/lazy-ass/README.md +269 -0
  161. package/test/cypress/node_modules/listr2/README.md +17 -0
  162. package/test/cypress/node_modules/lodash/README.md +39 -0
  163. package/test/cypress/node_modules/lodash.once/README.md +18 -0
  164. package/test/cypress/node_modules/log-symbols/README.md +51 -0
  165. package/test/cypress/node_modules/log-update/README.md +97 -0
  166. package/test/cypress/node_modules/log-update/node_modules/slice-ansi/README.md +66 -0
  167. package/test/cypress/node_modules/log-update/node_modules/wrap-ansi/README.md +97 -0
  168. package/test/cypress/node_modules/lru-cache/README.md +166 -0
  169. package/test/cypress/node_modules/merge-stream/README.md +78 -0
  170. package/test/cypress/node_modules/mime-db/README.md +102 -0
  171. package/test/cypress/node_modules/mime-types/README.md +123 -0
  172. package/test/cypress/node_modules/mimic-fn/README.md +69 -0
  173. package/test/cypress/node_modules/minimatch/README.md +209 -0
  174. package/test/cypress/node_modules/ms/README.md +60 -0
  175. package/test/cypress/node_modules/npm-run-path/README.md +115 -0
  176. package/test/cypress/node_modules/once/README.md +79 -0
  177. package/test/cypress/node_modules/onetime/README.md +94 -0
  178. package/test/cypress/node_modules/ospath/README.md +53 -0
  179. package/test/cypress/node_modules/p-map/README.md +89 -0
  180. package/test/cypress/node_modules/path-is-absolute/README.md +59 -0
  181. package/test/cypress/node_modules/path-key/README.md +61 -0
  182. package/test/cypress/node_modules/pend/README.md +41 -0
  183. package/test/cypress/node_modules/performance-now/README.md +30 -0
  184. package/test/cypress/node_modules/pify/README.md +119 -0
  185. package/test/cypress/node_modules/pretty-bytes/README.md +131 -0
  186. package/test/cypress/node_modules/proxy-from-env/README.md +131 -0
  187. package/test/cypress/node_modules/psl/README.md +215 -0
  188. package/test/cypress/node_modules/pump/README.md +65 -0
  189. package/test/cypress/node_modules/punycode/README.md +122 -0
  190. package/test/cypress/node_modules/qs/README.md +475 -0
  191. package/test/cypress/node_modules/request-progress/README.md +78 -0
  192. package/test/cypress/node_modules/restore-cursor/README.md +26 -0
  193. package/test/cypress/node_modules/rimraf/README.md +101 -0
  194. package/test/cypress/node_modules/rxjs/README.md +147 -0
  195. package/test/cypress/node_modules/rxjs/_esm2015/README.md +147 -0
  196. package/test/cypress/node_modules/rxjs/_esm5/README.md +147 -0
  197. package/test/cypress/node_modules/rxjs/src/README.md +147 -0
  198. package/test/cypress/node_modules/safe-buffer/README.md +584 -0
  199. package/test/cypress/node_modules/safer-buffer/README.md +156 -0
  200. package/test/cypress/node_modules/semver/README.md +566 -0
  201. package/test/cypress/node_modules/shebang-command/README.md +34 -0
  202. package/test/cypress/node_modules/shebang-regex/README.md +33 -0
  203. package/test/cypress/node_modules/signal-exit/README.md +39 -0
  204. package/test/cypress/node_modules/slice-ansi/README.md +72 -0
  205. package/test/cypress/node_modules/sshpk/README.md +804 -0
  206. package/test/cypress/node_modules/string-width/README.md +50 -0
  207. package/test/cypress/node_modules/strip-ansi/README.md +46 -0
  208. package/test/cypress/node_modules/strip-final-newline/README.md +30 -0
  209. package/test/cypress/node_modules/supports-color/README.md +77 -0
  210. package/test/cypress/node_modules/throttleit/README.md +32 -0
  211. package/test/cypress/node_modules/tmp/README.md +365 -0
  212. package/test/cypress/node_modules/tough-cookie/README.md +527 -0
  213. package/test/cypress/node_modules/tslib/README.md +142 -0
  214. package/test/cypress/node_modules/tunnel-agent/README.md +4 -0
  215. package/test/cypress/node_modules/tweetnacl/README.md +459 -0
  216. package/test/cypress/node_modules/type-fest/README.md +760 -0
  217. package/test/cypress/node_modules/universalify/README.md +76 -0
  218. package/test/cypress/node_modules/untildify/README.md +30 -0
  219. package/test/cypress/node_modules/uuid/README.md +505 -0
  220. package/test/cypress/node_modules/verror/README.md +528 -0
  221. package/test/cypress/node_modules/verror/node_modules/extsprintf/README.md +46 -0
  222. package/test/cypress/node_modules/which/README.md +54 -0
  223. package/test/cypress/node_modules/wrap-ansi/README.md +91 -0
  224. package/test/cypress/node_modules/wrappy/README.md +36 -0
  225. package/test/cypress/node_modules/yallist/README.md +204 -0
  226. package/test/cypress/node_modules/yauzl/README.md +658 -0
  227. package/.browserslistrc +0 -12
  228. package/.codecov.yml +0 -17
  229. package/.editorconfig +0 -18
  230. package/.eslintrc.json +0 -50
  231. package/.github/CODE_OF_CONDUCT.md +0 -76
  232. package/.github/FUNDING.yml +0 -8
  233. package/.github/ISSUE_TEMPLATE/bug_report.yml +0 -54
  234. package/.github/ISSUE_TEMPLATE/config.yml +0 -5
  235. package/.github/ISSUE_TEMPLATE/feature_request.yml +0 -44
  236. package/.github/renovate.json5 +0 -26
  237. package/.github/stale.yml +0 -7
  238. package/.github/workflows/main.yml +0 -83
  239. package/.vscode/extensions.json +0 -9
  240. package/.vscode/launch.json +0 -72
  241. package/.vscode/settings.json +0 -7
  242. package/.vscode/tasks.json +0 -77
  243. package/CHANGELOG.md +0 -1172
  244. package/angular.json +0 -148
  245. package/dist/LICENSE +0 -20
  246. package/dist/README.md +0 -182
  247. package/dist/esm2020/app/modules/angular-slickgrid/components/angular-slickgrid.component.mjs +0 -1171
  248. package/dist/esm2020/app/modules/angular-slickgrid/extensions/slickRowDetailView.mjs +0 -300
  249. package/dist/esm2020/app/modules/angular-slickgrid/models/angularGridInstance.interface.mjs +0 -2
  250. package/dist/esm2020/app/modules/angular-slickgrid/models/externalTestingDependencies.interface.mjs +0 -2
  251. package/dist/esm2020/app/modules/angular-slickgrid/models/gridOption.interface.mjs +0 -2
  252. package/dist/esm2020/app/modules/angular-slickgrid/models/rowDetailView.interface.mjs +0 -2
  253. package/dist/esm2020/app/modules/angular-slickgrid/models/slickGrid.interface.mjs +0 -2
  254. package/dist/esm2020/app/modules/angular-slickgrid/modules/angular-slickgrid.module.mjs +0 -46
  255. package/dist/esm2020/app/modules/angular-slickgrid/services/container.service.mjs +0 -26
  256. package/dist/fesm2015/angular-slickgrid.mjs.map +0 -1
  257. package/dist/fesm2020/angular-slickgrid.mjs.map +0 -1
  258. package/dist/package.json +0 -79
  259. package/global.d.ts +0 -1
  260. package/ngcc.config.js +0 -13
  261. package/screenshots/column-picker.png +0 -0
  262. package/screenshots/composite-editor.png +0 -0
  263. package/screenshots/draggable-grouping.png +0 -0
  264. package/screenshots/editors.png +0 -0
  265. package/screenshots/export-to-file.png +0 -0
  266. package/screenshots/filter_and_sort.png +0 -0
  267. package/screenshots/formatters.png +0 -0
  268. package/screenshots/frozen.png +0 -0
  269. package/screenshots/multipleSelectFilter.png +0 -0
  270. package/screenshots/pagination.png +0 -0
  271. package/screenshots/selectFilter.png +0 -0
  272. package/screenshots/singleFilter.png +0 -0
  273. package/src/app/app-routing.module.ts +0 -83
  274. package/src/app/app.component.html +0 -160
  275. package/src/app/app.component.scss +0 -65
  276. package/src/app/app.component.ts +0 -10
  277. package/src/app/app.module.ts +0 -175
  278. package/src/app/examples/custom-angularComponentEditor.ts +0 -184
  279. package/src/app/examples/custom-angularComponentFilter.ts +0 -126
  280. package/src/app/examples/custom-inputEditor.ts +0 -124
  281. package/src/app/examples/custom-inputFilter.ts +0 -142
  282. package/src/app/examples/custom-titleFormatter.component.ts +0 -8
  283. package/src/app/examples/editor-ng-select.component.ts +0 -37
  284. package/src/app/examples/filter-ng-select.component.ts +0 -32
  285. package/src/app/examples/grid-additem.component.html +0 -48
  286. package/src/app/examples/grid-additem.component.ts +0 -272
  287. package/src/app/examples/grid-angular.component.html +0 -79
  288. package/src/app/examples/grid-angular.component.scss +0 -28
  289. package/src/app/examples/grid-angular.component.ts +0 -370
  290. package/src/app/examples/grid-autoheight.component.html +0 -52
  291. package/src/app/examples/grid-autoheight.component.ts +0 -147
  292. package/src/app/examples/grid-basic.component.html +0 -29
  293. package/src/app/examples/grid-basic.component.ts +0 -82
  294. package/src/app/examples/grid-clientside.component.html +0 -51
  295. package/src/app/examples/grid-clientside.component.ts +0 -293
  296. package/src/app/examples/grid-colspan.component.html +0 -39
  297. package/src/app/examples/grid-colspan.component.scss +0 -11
  298. package/src/app/examples/grid-colspan.component.ts +0 -155
  299. package/src/app/examples/grid-composite-editor.component.html +0 -79
  300. package/src/app/examples/grid-composite-editor.component.scss +0 -19
  301. package/src/app/examples/grid-composite-editor.component.ts +0 -948
  302. package/src/app/examples/grid-contextmenu.component.html +0 -62
  303. package/src/app/examples/grid-contextmenu.component.scss +0 -44
  304. package/src/app/examples/grid-contextmenu.component.ts +0 -473
  305. package/src/app/examples/grid-custom-tooltip.component.html +0 -25
  306. package/src/app/examples/grid-custom-tooltip.component.scss +0 -77
  307. package/src/app/examples/grid-custom-tooltip.component.ts +0 -483
  308. package/src/app/examples/grid-draggrouping.component.html +0 -93
  309. package/src/app/examples/grid-draggrouping.component.ts +0 -397
  310. package/src/app/examples/grid-editor.component.html +0 -88
  311. package/src/app/examples/grid-editor.component.ts +0 -699
  312. package/src/app/examples/grid-formatter.component.html +0 -26
  313. package/src/app/examples/grid-formatter.component.ts +0 -162
  314. package/src/app/examples/grid-frozen.component.html +0 -65
  315. package/src/app/examples/grid-frozen.component.scss +0 -11
  316. package/src/app/examples/grid-frozen.component.ts +0 -303
  317. package/src/app/examples/grid-graphql-nopage.component.html +0 -33
  318. package/src/app/examples/grid-graphql-nopage.component.scss +0 -9
  319. package/src/app/examples/grid-graphql-nopage.component.ts +0 -242
  320. package/src/app/examples/grid-graphql.component.html +0 -87
  321. package/src/app/examples/grid-graphql.component.ts +0 -304
  322. package/src/app/examples/grid-grouping.component.html +0 -80
  323. package/src/app/examples/grid-grouping.component.ts +0 -313
  324. package/src/app/examples/grid-headerbutton.component.html +0 -31
  325. package/src/app/examples/grid-headerbutton.component.scss +0 -10
  326. package/src/app/examples/grid-headerbutton.component.ts +0 -233
  327. package/src/app/examples/grid-headermenu.component.html +0 -31
  328. package/src/app/examples/grid-headermenu.component.scss +0 -25
  329. package/src/app/examples/grid-headermenu.component.ts +0 -159
  330. package/src/app/examples/grid-localization.component.html +0 -54
  331. package/src/app/examples/grid-localization.component.ts +0 -293
  332. package/src/app/examples/grid-menu.component.html +0 -37
  333. package/src/app/examples/grid-menu.component.scss +0 -28
  334. package/src/app/examples/grid-menu.component.ts +0 -229
  335. package/src/app/examples/grid-odata.component.html +0 -116
  336. package/src/app/examples/grid-odata.component.ts +0 -441
  337. package/src/app/examples/grid-range.component.html +0 -74
  338. package/src/app/examples/grid-range.component.ts +0 -291
  339. package/src/app/examples/grid-remote.component.html +0 -37
  340. package/src/app/examples/grid-remote.component.ts +0 -153
  341. package/src/app/examples/grid-resize-by-content.component.html +0 -62
  342. package/src/app/examples/grid-resize-by-content.component.scss +0 -19
  343. package/src/app/examples/grid-resize-by-content.component.ts +0 -780
  344. package/src/app/examples/grid-rowdetail.component.html +0 -35
  345. package/src/app/examples/grid-rowdetail.component.ts +0 -205
  346. package/src/app/examples/grid-rowmove.component.html +0 -49
  347. package/src/app/examples/grid-rowmove.component.ts +0 -234
  348. package/src/app/examples/grid-rowselection.component.html +0 -76
  349. package/src/app/examples/grid-rowselection.component.ts +0 -267
  350. package/src/app/examples/grid-state.component.html +0 -36
  351. package/src/app/examples/grid-state.component.ts +0 -259
  352. package/src/app/examples/grid-tabs.component.html +0 -35
  353. package/src/app/examples/grid-tabs.component.ts +0 -115
  354. package/src/app/examples/grid-trading.component.html +0 -58
  355. package/src/app/examples/grid-trading.component.scss +0 -49
  356. package/src/app/examples/grid-trading.component.ts +0 -319
  357. package/src/app/examples/grid-tree-data-hierarchical.component.html +0 -79
  358. package/src/app/examples/grid-tree-data-hierarchical.component.scss +0 -47
  359. package/src/app/examples/grid-tree-data-hierarchical.component.ts +0 -311
  360. package/src/app/examples/grid-tree-data-parent-child.component.html +0 -108
  361. package/src/app/examples/grid-tree-data-parent-child.component.scss +0 -10
  362. package/src/app/examples/grid-tree-data-parent-child.component.ts +0 -351
  363. package/src/app/examples/home.component.html +0 -41
  364. package/src/app/examples/home.component.ts +0 -9
  365. package/src/app/examples/rowdetail-preload.component.ts +0 -10
  366. package/src/app/examples/rowdetail-view.component.html +0 -36
  367. package/src/app/examples/rowdetail-view.component.ts +0 -54
  368. package/src/app/examples/swt-common-grid-pagination.component.ts +0 -156
  369. package/src/app/examples/swt-common-grid-test.component.html +0 -30
  370. package/src/app/examples/swt-common-grid-test.component.ts +0 -219
  371. package/src/app/examples/swt-common-grid.component.ts +0 -436
  372. package/src/app/examples/swt-logger.service.ts +0 -165
  373. package/src/app/modules/angular-slickgrid/components/angular-slickgrid.component.html +0 -4
  374. package/src/app/modules/angular-slickgrid/components/angular-slickgrid.component.ts +0 -1395
  375. package/src/app/modules/angular-slickgrid/constants.ts +0 -97
  376. package/src/app/modules/angular-slickgrid/extensions/index.ts +0 -1
  377. package/src/app/modules/angular-slickgrid/extensions/slickRowDetailView.ts +0 -375
  378. package/src/app/modules/angular-slickgrid/global-grid-options.ts +0 -245
  379. package/src/app/modules/angular-slickgrid/index.ts +0 -11
  380. package/src/app/modules/angular-slickgrid/models/angularComponentOutput.interface.ts +0 -6
  381. package/src/app/modules/angular-slickgrid/models/angularGridInstance.interface.ts +0 -68
  382. package/src/app/modules/angular-slickgrid/models/externalTestingDependencies.interface.ts +0 -37
  383. package/src/app/modules/angular-slickgrid/models/gridOption.interface.ts +0 -12
  384. package/src/app/modules/angular-slickgrid/models/index.ts +0 -6
  385. package/src/app/modules/angular-slickgrid/models/rowDetailView.interface.ts +0 -33
  386. package/src/app/modules/angular-slickgrid/models/slickGrid.interface.ts +0 -7
  387. package/src/app/modules/angular-slickgrid/modules/angular-slickgrid.module.ts +0 -37
  388. package/src/app/modules/angular-slickgrid/services/angularUtil.service.ts +0 -48
  389. package/src/app/modules/angular-slickgrid/services/bsDropdown.service.ts +0 -142
  390. package/src/app/modules/angular-slickgrid/services/container.service.ts +0 -24
  391. package/src/app/modules/angular-slickgrid/services/index.ts +0 -5
  392. package/src/app/modules/angular-slickgrid/services/translater.service.ts +0 -38
  393. package/src/app/modules/angular-slickgrid/services/utilities.ts +0 -19
  394. package/src/app/modules/angular-slickgrid/slickgrid-config.ts +0 -10
  395. package/src/app/slickgrid-custom-variables.scss +0 -10
  396. package/src/assets/.gitkeep +0 -0
  397. package/src/assets/data/collection_100_numbers.json +0 -12
  398. package/src/assets/data/collection_500_numbers.json +0 -52
  399. package/src/assets/data/countries.json +0 -245
  400. package/src/assets/data/country_names.json +0 -245
  401. package/src/assets/data/customers_100.json +0 -102
  402. package/src/assets/i18n/en.json +0 -90
  403. package/src/assets/i18n/fr.json +0 -91
  404. package/src/environments/environment.prod.ts +0 -3
  405. package/src/environments/environment.ts +0 -8
  406. package/src/favicon.ico +0 -0
  407. package/src/index.html +0 -18
  408. package/src/main.ts +0 -13
  409. package/src/polyfills.ts +0 -52
  410. package/src/public_api.ts +0 -1
  411. package/src/styles.scss +0 -66
  412. package/src/typings.d.ts +0 -10
  413. package/tsconfig.app.json +0 -25
  414. package/tsconfig.json +0 -40
  415. package/tsconfig.spec.json +0 -23
@@ -1,51 +0,0 @@
1
- <div id="demo-container" class="container-fluid">
2
- <h2>
3
- {{title}}
4
- <span class="float-end">
5
- <a style="font-size: 18px"
6
- target="_blank"
7
- href="https://github.com/ghiscoding/Angular-Slickgrid/blob/master/src/app/examples/grid-clientside.component.ts">
8
- <span class="fa fa-link"></span> code
9
- </a>
10
- </span>
11
- </h2>
12
- <div class="subtitle" [innerHTML]="subTitle"></div>
13
-
14
- <br />
15
- <span *ngIf="metrics" style="margin-right: 10px">
16
- <b>Metrics:</b> {{metrics.startTime | date: 'yyyy-MM-dd hh:mm aaaaa\'m\''}} | {{metrics.itemCount}} of
17
- {{metrics.totalItemCount}} items
18
- </span>
19
- <div class="btn-group" role="group">
20
- <button class="btn btn-sm btn-outline-secondary" data-test="scroll-top-btn" (click)="scrollGridTop()">
21
- <i class="fa fa-arrow-up"></i>
22
- </button>
23
- <button class="btn btn-sm btn-outline-secondary" data-test="scroll-bottom-btn" (click)="scrollGridBottom()">
24
- <i class="fa fa-arrow-down"></i>
25
- </button>
26
- </div>
27
- <button class="btn btn-outline-secondary btn-sm" data-test="clear-filters"
28
- (click)="angularGrid.filterService.clearFilters()">
29
- Clear Filters
30
- </button>
31
- <button class="btn btn-outline-secondary btn-sm" data-test="clear-sorting"
32
- (click)="angularGrid.sortService.clearSorting()">
33
- Clear Sorting
34
- </button>
35
- <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-filter" (click)="setFiltersDynamically()">
36
- Set Filters Dynamically
37
- </button>
38
- <button class="btn btn-outline-secondary btn-sm" data-test="set-dynamic-sorting" (click)="setSortingDynamically()">
39
- Set Sorting Dynamically
40
- </button>
41
-
42
- <angular-slickgrid gridId="grid4"
43
- [columnDefinitions]="columnDefinitions"
44
- [gridOptions]="gridOptions"
45
- [dataset]="dataset"
46
- (onAngularGridCreated)="angularGridReady($event.detail)"
47
- (onGridStateChanged)="gridStateChanged($event.detail)"
48
- (onBeforeGridDestroy)="saveCurrentGridState()"
49
- (onRowCountChanged)="refreshMetrics($event.detail.eventData, $event.detail.args)">
50
- </angular-slickgrid>
51
- </div>
@@ -1,293 +0,0 @@
1
- import { Component, OnInit } from '@angular/core';
2
- import { HttpClient } from '@angular/common/http';
3
- import { ExcelExportService } from '@slickgrid-universal/excel-export';
4
- import { TranslateService } from '@ngx-translate/core';
5
- import {
6
- AngularGridInstance,
7
- Column,
8
- FieldType,
9
- Filters,
10
- FlatpickrOption,
11
- Formatters,
12
- GridOption,
13
- GridStateChange,
14
- Metrics,
15
- MultipleSelectOption,
16
- OperatorType,
17
- } from './../modules/angular-slickgrid';
18
- import { CustomInputFilter } from './custom-inputFilter';
19
-
20
- function randomBetween(min: number, max: number) {
21
- return Math.floor(Math.random() * (max - min + 1) + min);
22
- }
23
- const NB_ITEMS = 1500;
24
- const URL_SAMPLE_COLLECTION_DATA = 'assets/data/collection_500_numbers.json';
25
-
26
- @Component({
27
- templateUrl: './grid-clientside.component.html'
28
- })
29
- export class GridClientSideComponent implements OnInit {
30
- title = 'Example 4: Client Side Sort/Filter';
31
- subTitle = `
32
- Sort/Filter on client side only using SlickGrid DataView (<a href="https://github.com/ghiscoding/Angular-Slickgrid/wiki/Sorting" target="_blank">Wiki docs</a>)
33
- <br/>
34
- <ul class="small">
35
- <li>Support multi-sort (by default), hold "Shift" key and click on the next column to sort.</li>
36
- <li>All column types support the following operators: (>, >=, <, <=, <>, !=, =, ==, *)</li>
37
- <ul>
38
- <li>Example: >100 ... >=2001-01-01 ... >02/28/17</li>
39
- <li><b>Note:</b> For filters to work properly (default is string), make sure to provide a FieldType (type is against the dataset, not the Formatter)</li>
40
- </ul>
41
- <li>Date Filters</li>
42
- <ul>
43
- <li>
44
- FieldType of dateUtc/date (from dataset) can use an extra option of "filterSearchType" to let user filter more easily.
45
- For example, in the "UTC Date" field below, you can type "&gt;02/28/2017", also when dealing with UTC you have to take the time difference in consideration.
46
- </li>
47
- </ul>
48
- <li>On String filters, (*) can be used as startsWith (Hello* => matches "Hello Word") ... endsWith (*Doe => matches: "John Doe")</li>
49
- <li>Custom Filter are now possible, "Description" column below, is a customized InputFilter with different placeholder. See <a href="https://github.com/ghiscoding/Angular-Slickgrid/wiki/Custom-Filter" target="_blank">Wiki - Custom Filter</a>
50
- <li>MultipleSelect & SingeSelect Filters can use a regular "collection" or "collectionAsync" to load it asynchronously</li>
51
- </ul>
52
- `;
53
-
54
- angularGrid!: AngularGridInstance;
55
- columnDefinitions: Column[] = [];
56
- gridOptions!: GridOption;
57
- dataset!: any[];
58
- metrics!: Metrics;
59
-
60
- constructor(private http: HttpClient, private translate: TranslateService) { }
61
-
62
- ngOnInit(): void {
63
- this.columnDefinitions = [
64
- {
65
- id: 'title', name: 'Title', field: 'title', sortable: true, minWidth: 55,
66
- type: FieldType.string, filterable: true, filter: { model: Filters.compoundInputText }
67
- },
68
- {
69
- id: 'description', name: 'Description', field: 'description', filterable: true, sortable: true, minWidth: 80,
70
- type: FieldType.string,
71
- filter: {
72
- model: new CustomInputFilter(), // create a new instance to make each Filter independent from each other
73
- enableTrimWhiteSpace: true // or use global "enableFilterTrimWhiteSpace" to trim on all Filters
74
- }
75
- },
76
- {
77
- id: 'duration', name: 'Duration (days)', field: 'duration', sortable: true, type: FieldType.number, exportCsvForceToKeepAsString: true,
78
- minWidth: 55,
79
- filterable: true,
80
- filter: {
81
- collectionAsync: this.http.get<{ option: string; value: string; }[]>(URL_SAMPLE_COLLECTION_DATA),
82
- // collectionFilterBy & collectionSortBy accept a single or multiple options
83
- // we can exclude certains values 365 & 360 from the dropdown filter
84
- collectionFilterBy: [{
85
- property: 'value',
86
- operator: OperatorType.notEqual,
87
- value: 360
88
- }, {
89
- property: 'value',
90
- operator: OperatorType.notEqual,
91
- value: 365
92
- }],
93
- collectionSortBy: {
94
- property: 'value',
95
- sortDesc: true,
96
- fieldType: FieldType.number
97
- },
98
- customStructure: {
99
- value: 'value',
100
- label: 'label',
101
- optionLabel: 'value', // if selected text is too long, we can use option labels instead
102
- labelSuffix: 'text',
103
- },
104
- collectionOptions: {
105
- separatorBetweenTextLabels: ' ',
106
- filterResultAfterEachPass: 'chain' // options are "merge" or "chain" (defaults to "chain")
107
- },
108
- model: Filters.multipleSelect,
109
-
110
- // we could add certain option(s) to the "multiple-select" plugin
111
- filterOptions: {
112
- maxHeight: 250,
113
- width: 175,
114
-
115
- // if we want to display shorter text as the selected text (on the select filter itself, parent element)
116
- // we can use "useSelectOptionLabel" or "useSelectOptionLabelToHtml" the latter will parse html
117
- useSelectOptionLabelToHtml: true
118
- } as MultipleSelectOption
119
- }
120
- },
121
- {
122
- id: 'complete', name: '% Complete', field: 'percentComplete', formatter: Formatters.percentCompleteBar, minWidth: 70, type: FieldType.number, sortable: true,
123
- filterable: true, filter: { model: Filters.compoundInputNumber }
124
- },
125
- {
126
- id: 'start', name: 'Start', field: 'start', formatter: Formatters.dateIso, sortable: true, minWidth: 75, exportWithFormatter: false,
127
- type: FieldType.date, filterable: true, filter: { model: Filters.compoundDate }
128
- },
129
- {
130
- id: 'usDateShort', name: 'US Date Short', field: 'usDateShort', sortable: true, minWidth: 70, width: 70,
131
- type: FieldType.dateUsShort, exportWithFormatter: true, filterable: true, filter: { model: Filters.compoundDate }
132
- },
133
- {
134
- id: 'utcDate', name: 'UTC Date', field: 'utcDate', formatter: Formatters.dateTimeIsoAmPm, sortable: true, minWidth: 115,
135
- type: FieldType.dateUtc, exportWithFormatter: true, outputType: FieldType.dateTimeIsoAmPm, filterable: true,
136
- filter: {
137
- model: Filters.compoundDate,
138
- // override any of the Flatpickr options through "filterOptions"
139
- // please note that there's no TSlint on this property since it's generic for any filter, so make sure you entered the correct filter option(s)
140
- filterOptions: { minDate: 'today' } as FlatpickrOption
141
- }
142
- },
143
- {
144
- id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven.isEffort', minWidth: 85, maxWidth: 85,
145
- type: FieldType.boolean,
146
- sortable: true,
147
- exportCustomFormatter: Formatters.complexObject,
148
-
149
- // to pass multiple formatters, use the params property
150
- // also these formatters are executed in sequence, so if you want the checkmark to work correctly, it has to be the last formatter defined
151
- formatter: Formatters.multiple,
152
- params: { formatters: [Formatters.complexObject, Formatters.checkmark] },
153
-
154
- // when the "field" string includes the dot "." notation, the library will consider this to be a complex object and Filter accordingly
155
- filterable: true,
156
- filter: {
157
- // We can also add HTML text to be rendered (any bad script will be sanitized) but we have to opt-in, else it will be sanitized
158
- // enableRenderHtml: true,
159
- // collection: [{ value: '', label: '' }, { value: true, label: 'True', labelPrefix: `<i class="fa fa-check"></i> ` }, { value: false, label: 'False' }],
160
-
161
- collection: [{ isEffort: '', label: '' }, { isEffort: true, label: 'True' }, { isEffort: false, label: 'False' }],
162
- customStructure: {
163
- value: 'isEffort',
164
- label: 'label'
165
- },
166
- model: Filters.singleSelect,
167
-
168
- // we could add certain option(s) to the "multiple-select" plugin
169
- filterOptions: { autoDropWidth: true } as MultipleSelectOption,
170
- }
171
- }
172
- ];
173
-
174
- this.gridOptions = {
175
- autoResize: {
176
- container: '#demo-container',
177
- rightPadding: 10
178
- },
179
- enableExcelExport: true,
180
- enableExcelCopyBuffer: true,
181
- enableFiltering: true,
182
- // enableFilterTrimWhiteSpace: true,
183
- i18n: this.translate,
184
- showCustomFooter: true, // display some metrics in the bottom custom footer
185
-
186
- // use columnDef searchTerms OR use presets as shown below
187
- presets: {
188
- filters: [
189
- { columnId: 'duration', searchTerms: [10, 98] },
190
- // { columnId: 'complete', searchTerms: ['5'], operator: '>' },
191
- { columnId: 'usDateShort', operator: '<', searchTerms: ['4/20/25'] },
192
- // { columnId: 'effort-driven', searchTerms: [true] },
193
- ],
194
- sorters: [
195
- { columnId: 'duration', direction: 'DESC' },
196
- { columnId: 'complete', direction: 'ASC' }
197
- ],
198
- },
199
- registerExternalResources: [new ExcelExportService()],
200
- };
201
-
202
- // mock a dataset
203
- this.dataset = this.mockData(NB_ITEMS);
204
- }
205
-
206
- angularGridReady(angularGrid: AngularGridInstance) {
207
- this.angularGrid = angularGrid;
208
- }
209
-
210
- mockData(itemCount: number, startingIndex = 0): any[] {
211
- // mock a dataset
212
- const tempDataset = [];
213
- for (let i = startingIndex; i < (startingIndex + itemCount); i++) {
214
- const randomDuration = Math.round(Math.random() * 100);
215
- const randomYear = randomBetween(2000, 2035);
216
- const randomYearShort = randomBetween(10, 35);
217
- const randomMonth = randomBetween(1, 12);
218
- const randomMonthStr = (randomMonth < 10) ? `0${randomMonth}` : randomMonth;
219
- const randomDay = randomBetween(10, 28);
220
- const randomPercent = randomBetween(0, 100);
221
- const randomHour = randomBetween(10, 23);
222
- const randomTime = randomBetween(10, 59);
223
- const randomMilliseconds = `${randomBetween(1, 9)}${randomBetween(10, 99)}`;
224
- const randomIsEffort = (i % 3 === 0);
225
-
226
- tempDataset.push({
227
- id: i,
228
- title: 'Task ' + i,
229
- description: (i % 5) ? 'desc ' + i : null, // also add some random to test NULL field
230
- duration: randomDuration,
231
- percentComplete: randomPercent,
232
- percentCompleteNumber: randomPercent,
233
- start: (i % 4) ? null : new Date(randomYear, randomMonth, randomDay), // provide a Date format
234
- usDateShort: `${randomMonth}/${randomDay}/${randomYearShort}`, // provide a date US Short in the dataset
235
- utcDate: `${randomYear}-${randomMonthStr}-${randomDay}T${randomHour}:${randomTime}:${randomTime}.${randomMilliseconds}Z`,
236
- effortDriven: {
237
- isEffort: randomIsEffort,
238
- label: randomIsEffort ? 'Effort' : 'NoEffort',
239
- }
240
- });
241
- }
242
- return tempDataset;
243
- }
244
-
245
- /** Dispatched event of a Grid State Changed event */
246
- gridStateChanged(gridState: GridStateChange) {
247
- console.log('Client sample, Grid State changed:: ', gridState);
248
- }
249
-
250
- /** Save current Filters, Sorters in LocaleStorage or DB */
251
- saveCurrentGridState() {
252
- console.log('Client sample, last Grid State:: ', this.angularGrid.gridStateService.getCurrentGridState());
253
- }
254
-
255
- setFiltersDynamically() {
256
- // we can Set Filters Dynamically (or different filters) afterward through the FilterService
257
- this.angularGrid.filterService.updateFilters([
258
- { columnId: 'duration', searchTerms: [2, 25, 48, 50] },
259
- { columnId: 'complete', searchTerms: [95], operator: '<' },
260
- { columnId: 'effort-driven', searchTerms: [true] },
261
- { columnId: 'start', operator: '>=', searchTerms: ['2001-02-28'] },
262
- ]);
263
- }
264
-
265
- setSortingDynamically() {
266
- this.angularGrid.sortService.updateSorting([
267
- // orders matter, whichever is first in array will be the first sorted column
268
- { columnId: 'duration', direction: 'ASC' },
269
- { columnId: 'start', direction: 'DESC' },
270
- ]);
271
- }
272
-
273
- refreshMetrics(e: Event, args: any) {
274
- if (args && args.current >= 0) {
275
- setTimeout(() => {
276
- this.metrics = {
277
- startTime: new Date(),
278
- endTime: new Date(),
279
- itemCount: args && args.current || 0,
280
- totalItemCount: this.dataset.length || 0
281
- };
282
- });
283
- }
284
- }
285
-
286
- scrollGridBottom() {
287
- this.angularGrid.slickGrid.navigateBottom();
288
- }
289
-
290
- scrollGridTop() {
291
- this.angularGrid.slickGrid.navigateTop();
292
- }
293
- }
@@ -1,39 +0,0 @@
1
- <div id="demo-container" class="container-fluid">
2
- <h2>
3
- {{title}}
4
- <span class="float-end">
5
- <a style="font-size: 18px"
6
- target="_blank"
7
- href="https://github.com/ghiscoding/Angular-Slickgrid/blob/master/src/app/examples/grid-colspan.component.ts">
8
- <span class="fa fa-link"></span> code
9
- </a>
10
- </span>
11
- </h2>
12
- <div class="subtitle" [innerHTML]="subTitle"></div>
13
-
14
- <h3>Grid 1 <small>(with Header Grouping &amp; Colspan)</small></h3>
15
- <angular-slickgrid gridId="grid1"
16
- [columnDefinitions]="columnDefinitions1"
17
- [gridOptions]="gridOptions1"
18
- [dataset]="dataset1">
19
- </angular-slickgrid>
20
-
21
- <hr />
22
-
23
- <h3>Grid 2 <small>(with Header Grouping &amp; Frozen/Pinned Columns)</small></h3>
24
- <div class="col-sm 12">
25
- <button class="btn btn-outline-secondary btn-sm" (click)="setFrozenColumns2(-1)"
26
- data-test="remove-frozen-column-button">
27
- <i class="fa fa-times fa-lg"></i> Remove Frozen Columns
28
- </button>
29
- <button class="btn btn-outline-secondary btn-sm" (click)="setFrozenColumns2(2)" data-test="set-3frozen-columns">
30
- <i class="fa fa-thumb-tack fa-lg"></i> Set 3 Frozen Columns
31
- </button>
32
- </div>
33
- <angular-slickgrid gridId="grid2"
34
- [columnDefinitions]="columnDefinitions2"
35
- [gridOptions]="gridOptions2"
36
- [dataset]="dataset2"
37
- (onAngularGridCreated)="angularGridReady2($event.detail)">
38
- </angular-slickgrid>
39
- </div>
@@ -1,11 +0,0 @@
1
- /** You can change the pinned/frozen border styling through this css override */
2
-
3
- .slick-row .slick-cell.frozen:last-child,
4
- .slick-headerrow-column.frozen:last-child,
5
- .slick-footerrow-column.frozen:last-child {
6
- border-right: 1px solid #969696 !important;
7
- }
8
-
9
- .slick-pane-bottom {
10
- border-top: 1px solid #969696 !important;
11
- }
@@ -1,155 +0,0 @@
1
- import { Component, OnInit } from '@angular/core';
2
- import { ExcelExportService } from '@slickgrid-universal/excel-export';
3
-
4
- import { AngularGridInstance, Column, FieldType, GridOption, ItemMetadata } from './../modules/angular-slickgrid';
5
-
6
- @Component({
7
- templateUrl: './grid-colspan.component.html',
8
- styleUrls: ['./grid-colspan.component.scss'],
9
- })
10
- export class GridColspanComponent implements OnInit {
11
- title = 'Example 15: Column Span & Header Grouping';
12
- subTitle = `
13
- This example demonstrates how to easily span a row over multiple columns & how to group header titles.
14
- <ul>
15
- <li>
16
- Row Colspan - (<a href="https://github.com/ghiscoding/Angular-Slickgrid/wiki/Row-Colspan" target="_blank">Wiki docs</a>) /
17
- Header Grouping - (<a href="https://github.com/ghiscoding/Angular-Slickgrid/wiki/Header-Title-Grouping" target="_blank">Wiki docs</a>)
18
- </li>
19
- <li>Note that you can add Sort but remember that it will sort by the data which the row contains, even if the data is visually hidden by colspan it will still sort it</li>
20
- <li>
21
- Header Grouping spanning accross multiple columns is working but has some UI issues on window resize.
22
- If anyone can fix it, probably some CSS issues, please let us know.
23
- </li>
24
- </ul>
25
- `;
26
-
27
- angularGrid2!: AngularGridInstance;
28
- gridObj2: any;
29
- columnDefinitions1!: Column[];
30
- columnDefinitions2!: Column[];
31
- gridOptions1!: GridOption;
32
- gridOptions2!: GridOption;
33
- dataset1: any[] = [];
34
- dataset2: any[] = [];
35
-
36
- ngOnInit(): void {
37
- this.prepareGrid1();
38
- this.prepareGrid2();
39
- }
40
-
41
- angularGridReady2(angularGrid: AngularGridInstance) {
42
- this.angularGrid2 = angularGrid;
43
- this.gridObj2 = angularGrid.slickGrid;
44
- }
45
-
46
- prepareGrid1() {
47
- this.columnDefinitions1 = [
48
- { id: 'title', name: 'Title', field: 'title', sortable: true, columnGroup: 'Common Factor' },
49
- { id: 'duration', name: 'Duration', field: 'duration', columnGroup: 'Common Factor' },
50
- { id: 'start', name: 'Start', field: 'start', columnGroup: 'Period' },
51
- { id: 'finish', name: 'Finish', field: 'finish', columnGroup: 'Period' },
52
- { id: '%', name: '% Complete', field: 'percentComplete', selectable: false, columnGroup: 'Analysis' },
53
- { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', type: FieldType.boolean, columnGroup: 'Analysis' }
54
- ];
55
-
56
- this.gridOptions1 = {
57
- gridHeight: 275,
58
- gridWidth: 800,
59
- enableAutoResize: false,
60
- enableCellNavigation: true,
61
- enableSorting: true,
62
- createPreHeaderPanel: true,
63
- showPreHeaderPanel: true,
64
- preHeaderPanelHeight: 28,
65
- explicitInitialization: true,
66
- colspanCallback: this.renderDifferentColspan,
67
- enableExcelExport: true,
68
- excelExportOptions: {
69
- exportWithFormatter: false
70
- },
71
- registerExternalResources: [new ExcelExportService()],
72
- };
73
-
74
- this.dataset1 = this.getData(500);
75
- }
76
-
77
- prepareGrid2() {
78
- this.columnDefinitions2 = [
79
- { id: 'sel', name: '#', field: 'num', behavior: 'select', cssClass: 'cell-selection', width: 40, resizable: false, selectable: false },
80
- { id: 'title', name: 'Title', field: 'title', sortable: true, columnGroup: 'Common Factor' },
81
- { id: 'duration', name: 'Duration', field: 'duration', columnGroup: 'Common Factor' },
82
- { id: 'start', name: 'Start', field: 'start', columnGroup: 'Period' },
83
- { id: 'finish', name: 'Finish', field: 'finish', columnGroup: 'Period' },
84
- { id: '%', name: '% Complete', field: 'percentComplete', selectable: false, columnGroup: 'Analysis' },
85
- { id: 'effort-driven', name: 'Effort Driven', field: 'effortDriven', type: FieldType.boolean, columnGroup: 'Analysis' }
86
- ];
87
-
88
- this.gridOptions2 = {
89
- gridHeight: 275,
90
- gridWidth: 800,
91
- enableCellNavigation: true,
92
- createPreHeaderPanel: true,
93
- showPreHeaderPanel: true,
94
- preHeaderPanelHeight: 25,
95
- explicitInitialization: true,
96
- frozenColumn: 2,
97
- gridMenu: { hideClearFrozenColumnsCommand: false },
98
- headerMenu: { hideFreezeColumnsCommand: false },
99
- enableExcelExport: true,
100
- excelExportOptions: {
101
- exportWithFormatter: false
102
- },
103
- registerExternalResources: [new ExcelExportService()],
104
- };
105
-
106
- this.dataset2 = this.getData(500);
107
- }
108
-
109
- getData(count: number) {
110
- // Set up some test columns.
111
- const mockDataset = [];
112
- for (let i = 0; i < count; i++) {
113
- mockDataset[i] = {
114
- id: i,
115
- num: i,
116
- title: 'Task ' + i,
117
- duration: '5 days',
118
- percentComplete: Math.round(Math.random() * 100),
119
- start: '01/01/2009',
120
- finish: '01/05/2009',
121
- effortDriven: (i % 5 === 0)
122
- };
123
- }
124
- return mockDataset;
125
- }
126
-
127
- setFrozenColumns2(frozenCols: number) {
128
- this.gridObj2.setOptions({ frozenColumn: frozenCols });
129
- this.gridOptions2 = this.gridObj2.getOptions();
130
- }
131
-
132
- /**
133
- * A callback to render different row column span
134
- * Your callback will always have the "item" argument which you can use to decide on the colspan
135
- * Your return must always be in the form of:: return { columns: {}}
136
- */
137
- renderDifferentColspan(item: any): ItemMetadata {
138
- if (item.id % 2 === 1) {
139
- return {
140
- columns: {
141
- duration: {
142
- colspan: 3 // "duration" will span over 3 columns
143
- }
144
- }
145
- };
146
- }
147
- return {
148
- columns: {
149
- 0: {
150
- colspan: '*' // starting at column index 0, we will span accross all column (*)
151
- }
152
- }
153
- };
154
- }
155
- }
@@ -1,79 +0,0 @@
1
- <div id="demo-container" class="container-fluid">
2
- <h2>
3
- {{title}}
4
- <span class="float-end">
5
- <a style="font-size: 18px"
6
- target="_blank"
7
- href="https://github.com/ghiscoding/Angular-Slickgrid/blob/master/src/app/examples/grid-composite-editor.component.ts">
8
- <span class="fa fa-link"></span> code
9
- </a>
10
- </span>
11
- </h2>
12
- <div class="subtitle" [innerHTML]="subTitle"></div>
13
-
14
- <div class="mb-2">
15
- <div class="btn-group btn-group-sm" role="group" aria-label="Basic Editing Commands">
16
- <button type="button" class="btn btn-outline-secondary" data-test="toggle-readonly-btn"
17
- (click)="toggleGridEditReadonly()">
18
- <i class="fa fa-table"></i> Toggle Edit/Readonly Grid
19
- </button>
20
- <button type="button" class="btn btn-outline-secondary" data-test="undo-last-edit-btn"
21
- (click)="undoLastEdit()">
22
- <i class="fa fa-undo"></i> Undo Last Edit
23
- </button>
24
- <button type="button" class="btn btn-outline-secondary" data-test="undo-open-editor-btn"
25
- (click)="undoLastEdit(true)">
26
- <i class="fa fa-undo"></i> Undo Last Edit &amp; Open Editor
27
- </button>
28
- <button type="button" class="btn btn-outline-secondary" data-test="undo-all-edits-btn"
29
- (click)="undoAllEdits()">
30
- <i class="fa fa-history"></i> Undo All Edits
31
- </button>
32
- <button type="button" class="btn btn-outline-secondary" data-test="save-all-btn"
33
- (click)="saveAll()">
34
- <i class="fa fa-save"></i> Save All
35
- </button>
36
- </div>
37
- </div>
38
-
39
- <div class="mb-3">
40
- <div class="btn-group btn-group-sm" role="group" aria-label="Basic example">
41
- <button type="button" class="btn btn-outline-secondary" data-test="open-modal-create-btn"
42
- (click)="openCompositeModal('create')" [disabled]="isCompositeDisabled">
43
- <i class="fa fa-plus"></i> Item Create
44
- </button>
45
- <button type="button" class="btn btn-outline-secondary" data-test="open-modal-clone-btn"
46
- (click)="openCompositeModal('clone')" [disabled]="isCompositeDisabled">
47
- <i class="fa fa-clone"></i> Item Clone
48
- </button>
49
- <button type="button" class="btn btn-outline-secondary" data-test="open-modal-edit-btn"
50
- (click)="openCompositeModal('edit')" [disabled]="isCompositeDisabled">
51
- <i class="fa fa-pencil"></i> Item Edit
52
- </button>
53
- <button type="button" class="btn btn-outline-secondary" data-test="open-modal-mass-update-btn"
54
- (click)="openCompositeModal('mass-update')" [disabled]="isCompositeDisabled">
55
- <i class="fa fa-pencil-square-o"></i> Mass Update
56
- </button>
57
- <button type="button" class="btn btn-outline-secondary" data-test="open-modal-mass-selection-btn"
58
- (click)="openCompositeModal('mass-selection')" [disabled]="isMassSelectionDisabled">
59
- <i class="fa fa-check-square-o"></i> Update Selected
60
- </button>
61
- </div>
62
- </div>
63
-
64
-
65
- <angular-slickgrid gridId="grid30"
66
- [columnDefinitions]="columnDefinitions"
67
- [gridOptions]="gridOptions"
68
- [dataset]="dataset"
69
- (onAngularGridCreated)="angularGridReady($event.detail)"
70
- (onBeforeEditCell)="handleOnBeforeEditCell($event.detail.eventData, $event.detail.args)"
71
- (onCellChange)="handleOnCellChange($event.detail.eventData, $event.detail.args)"
72
- (onClick)="handleOnCellClicked($event.detail.eventData, $event.detail.args)"
73
- (onCompositeEditorChange)="handleOnCompositeEditorChange($event.detail.eventData, $event.detail.args)"
74
- (onItemDeleted)="handleItemDeleted($event.detail.eventData, $event.detail.args)"
75
- (onGridStateChanged)="handleOnGridStateChanged($event.detail)"
76
- (onPaginationChanged)="handlePaginationChanged()"
77
- (onValidationError)="handleValidationError($event.detail.eventData, $event.detail.args)">
78
- </angular-slickgrid>
79
- </div>
@@ -1,19 +0,0 @@
1
- $slick-button-border-color: #ababab !default;
2
-
3
- .editable-field {
4
- background-color: rgba(227, 240, 251, 0.569) !important;
5
- }
6
- .unsaved-editable-field {
7
- background-color: #fbfdd1 !important;
8
- }
9
- .button-style {
10
- cursor: pointer;
11
- background-color: white;
12
- border: 1px solid #{$slick-button-border-color};
13
- border-radius: 2px;
14
- justify-content: center;
15
- text-align: center;
16
- &:hover {
17
- border-color: darken($slick-button-border-color, 10%);
18
- }
19
- }