@ni/nimble-components 18.5.7 → 18.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (615) hide show
  1. package/dist/all-components-bundle.js +482 -35
  2. package/dist/all-components-bundle.js.map +1 -1
  3. package/dist/all-components-bundle.min.js +3261 -3221
  4. package/dist/all-components-bundle.min.js.map +1 -1
  5. package/dist/esm/anchor/index.d.ts +1 -0
  6. package/dist/esm/anchor/index.js +1 -0
  7. package/dist/esm/anchor/index.js.map +1 -1
  8. package/dist/esm/anchor-button/index.d.ts +1 -0
  9. package/dist/esm/anchor-button/index.js +1 -0
  10. package/dist/esm/anchor-button/index.js.map +1 -1
  11. package/dist/esm/anchor-tab/index.d.ts +1 -0
  12. package/dist/esm/anchor-tab/index.js +1 -0
  13. package/dist/esm/anchor-tab/index.js.map +1 -1
  14. package/dist/esm/anchor-tabs/index.d.ts +1 -0
  15. package/dist/esm/anchor-tabs/index.js +1 -0
  16. package/dist/esm/anchor-tabs/index.js.map +1 -1
  17. package/dist/esm/anchored-region/index.d.ts +1 -0
  18. package/dist/esm/anchored-region/index.js +1 -0
  19. package/dist/esm/anchored-region/index.js.map +1 -1
  20. package/dist/esm/banner/index.d.ts +1 -0
  21. package/dist/esm/banner/index.js +1 -0
  22. package/dist/esm/banner/index.js.map +1 -1
  23. package/dist/esm/breadcrumb/index.d.ts +1 -0
  24. package/dist/esm/breadcrumb/index.js +1 -0
  25. package/dist/esm/breadcrumb/index.js.map +1 -1
  26. package/dist/esm/breadcrumb-item/index.d.ts +1 -0
  27. package/dist/esm/breadcrumb-item/index.js +1 -0
  28. package/dist/esm/breadcrumb-item/index.js.map +1 -1
  29. package/dist/esm/button/index.d.ts +1 -0
  30. package/dist/esm/button/index.js +1 -0
  31. package/dist/esm/button/index.js.map +1 -1
  32. package/dist/esm/card-button/index.d.ts +1 -0
  33. package/dist/esm/card-button/index.js +1 -0
  34. package/dist/esm/card-button/index.js.map +1 -1
  35. package/dist/esm/checkbox/index.d.ts +1 -0
  36. package/dist/esm/checkbox/index.js +1 -0
  37. package/dist/esm/checkbox/index.js.map +1 -1
  38. package/dist/esm/combobox/index.d.ts +1 -0
  39. package/dist/esm/combobox/index.js +1 -0
  40. package/dist/esm/combobox/index.js.map +1 -1
  41. package/dist/esm/dialog/index.d.ts +1 -0
  42. package/dist/esm/dialog/index.js +1 -0
  43. package/dist/esm/dialog/index.js.map +1 -1
  44. package/dist/esm/drawer/index.d.ts +1 -0
  45. package/dist/esm/drawer/index.js +1 -0
  46. package/dist/esm/drawer/index.js.map +1 -1
  47. package/dist/esm/icons/add.d.ts +1 -0
  48. package/dist/esm/icons/add.js +2 -0
  49. package/dist/esm/icons/add.js.map +1 -1
  50. package/dist/esm/icons/arrow-down-right-and-arrow-up-left.d.ts +1 -0
  51. package/dist/esm/icons/arrow-down-right-and-arrow-up-left.js +2 -0
  52. package/dist/esm/icons/arrow-down-right-and-arrow-up-left.js.map +1 -1
  53. package/dist/esm/icons/arrow-down.d.ts +1 -0
  54. package/dist/esm/icons/arrow-down.js +2 -0
  55. package/dist/esm/icons/arrow-down.js.map +1 -1
  56. package/dist/esm/icons/arrow-expander-down.d.ts +1 -0
  57. package/dist/esm/icons/arrow-expander-down.js +2 -0
  58. package/dist/esm/icons/arrow-expander-down.js.map +1 -1
  59. package/dist/esm/icons/arrow-expander-left.d.ts +1 -0
  60. package/dist/esm/icons/arrow-expander-left.js +2 -0
  61. package/dist/esm/icons/arrow-expander-left.js.map +1 -1
  62. package/dist/esm/icons/arrow-expander-right.d.ts +1 -0
  63. package/dist/esm/icons/arrow-expander-right.js +2 -0
  64. package/dist/esm/icons/arrow-expander-right.js.map +1 -1
  65. package/dist/esm/icons/arrow-expander-up.d.ts +1 -0
  66. package/dist/esm/icons/arrow-expander-up.js +2 -0
  67. package/dist/esm/icons/arrow-expander-up.js.map +1 -1
  68. package/dist/esm/icons/arrow-left-from-line.d.ts +1 -0
  69. package/dist/esm/icons/arrow-left-from-line.js +2 -0
  70. package/dist/esm/icons/arrow-left-from-line.js.map +1 -1
  71. package/dist/esm/icons/arrow-partial-rotate-left.d.ts +1 -0
  72. package/dist/esm/icons/arrow-partial-rotate-left.js +2 -0
  73. package/dist/esm/icons/arrow-partial-rotate-left.js.map +1 -1
  74. package/dist/esm/icons/arrow-right-to-line.d.ts +1 -0
  75. package/dist/esm/icons/arrow-right-to-line.js +2 -0
  76. package/dist/esm/icons/arrow-right-to-line.js.map +1 -1
  77. package/dist/esm/icons/arrow-rotate-right.d.ts +1 -0
  78. package/dist/esm/icons/arrow-rotate-right.js +2 -0
  79. package/dist/esm/icons/arrow-rotate-right.js.map +1 -1
  80. package/dist/esm/icons/arrow-u-rotate-left.d.ts +1 -0
  81. package/dist/esm/icons/arrow-u-rotate-left.js +2 -0
  82. package/dist/esm/icons/arrow-u-rotate-left.js.map +1 -1
  83. package/dist/esm/icons/arrow-up-left-and-arrow-down-right.d.ts +1 -0
  84. package/dist/esm/icons/arrow-up-left-and-arrow-down-right.js +2 -0
  85. package/dist/esm/icons/arrow-up-left-and-arrow-down-right.js.map +1 -1
  86. package/dist/esm/icons/arrow-up.d.ts +1 -0
  87. package/dist/esm/icons/arrow-up.js +2 -0
  88. package/dist/esm/icons/arrow-up.js.map +1 -1
  89. package/dist/esm/icons/arrows-maximize.d.ts +1 -0
  90. package/dist/esm/icons/arrows-maximize.js +2 -0
  91. package/dist/esm/icons/arrows-maximize.js.map +1 -1
  92. package/dist/esm/icons/arrows-repeat.d.ts +1 -0
  93. package/dist/esm/icons/arrows-repeat.js +2 -0
  94. package/dist/esm/icons/arrows-repeat.js.map +1 -1
  95. package/dist/esm/icons/bars.d.ts +1 -0
  96. package/dist/esm/icons/bars.js +2 -0
  97. package/dist/esm/icons/bars.js.map +1 -1
  98. package/dist/esm/icons/bell-and-comment.d.ts +1 -0
  99. package/dist/esm/icons/bell-and-comment.js +2 -0
  100. package/dist/esm/icons/bell-and-comment.js.map +1 -1
  101. package/dist/esm/icons/bell-circle.d.ts +1 -0
  102. package/dist/esm/icons/bell-circle.js +2 -0
  103. package/dist/esm/icons/bell-circle.js.map +1 -1
  104. package/dist/esm/icons/bell-solid-circle.d.ts +1 -0
  105. package/dist/esm/icons/bell-solid-circle.js +2 -0
  106. package/dist/esm/icons/bell-solid-circle.js.map +1 -1
  107. package/dist/esm/icons/bell.d.ts +1 -0
  108. package/dist/esm/icons/bell.js +2 -0
  109. package/dist/esm/icons/bell.js.map +1 -1
  110. package/dist/esm/icons/block-with-ribbon.d.ts +1 -0
  111. package/dist/esm/icons/block-with-ribbon.js +2 -0
  112. package/dist/esm/icons/block-with-ribbon.js.map +1 -1
  113. package/dist/esm/icons/book-magnifying-glass.d.ts +1 -0
  114. package/dist/esm/icons/book-magnifying-glass.js +2 -0
  115. package/dist/esm/icons/book-magnifying-glass.js.map +1 -1
  116. package/dist/esm/icons/calendar.d.ts +1 -0
  117. package/dist/esm/icons/calendar.js +2 -0
  118. package/dist/esm/icons/calendar.js.map +1 -1
  119. package/dist/esm/icons/chart-diagram-child-focus.d.ts +1 -0
  120. package/dist/esm/icons/chart-diagram-child-focus.js +2 -0
  121. package/dist/esm/icons/chart-diagram-child-focus.js.map +1 -1
  122. package/dist/esm/icons/chart-diagram-parent-focus-two-child.d.ts +1 -0
  123. package/dist/esm/icons/chart-diagram-parent-focus-two-child.js +2 -0
  124. package/dist/esm/icons/chart-diagram-parent-focus-two-child.js.map +1 -1
  125. package/dist/esm/icons/chart-diagram-parent-focus.d.ts +1 -0
  126. package/dist/esm/icons/chart-diagram-parent-focus.js +2 -0
  127. package/dist/esm/icons/chart-diagram-parent-focus.js.map +1 -1
  128. package/dist/esm/icons/chart-diagram.d.ts +1 -0
  129. package/dist/esm/icons/chart-diagram.js +2 -0
  130. package/dist/esm/icons/chart-diagram.js.map +1 -1
  131. package/dist/esm/icons/check-dot.d.ts +1 -0
  132. package/dist/esm/icons/check-dot.js +2 -0
  133. package/dist/esm/icons/check-dot.js.map +1 -1
  134. package/dist/esm/icons/check-large.d.ts +1 -0
  135. package/dist/esm/icons/check-large.js +2 -0
  136. package/dist/esm/icons/check-large.js.map +1 -1
  137. package/dist/esm/icons/check.d.ts +1 -0
  138. package/dist/esm/icons/check.js +2 -0
  139. package/dist/esm/icons/check.js.map +1 -1
  140. package/dist/esm/icons/circle-broken.d.ts +1 -0
  141. package/dist/esm/icons/circle-broken.js +2 -0
  142. package/dist/esm/icons/circle-broken.js.map +1 -1
  143. package/dist/esm/icons/circle-check.d.ts +1 -0
  144. package/dist/esm/icons/circle-check.js +2 -0
  145. package/dist/esm/icons/circle-check.js.map +1 -1
  146. package/dist/esm/icons/circle-filled.d.ts +1 -0
  147. package/dist/esm/icons/circle-filled.js +2 -0
  148. package/dist/esm/icons/circle-filled.js.map +1 -1
  149. package/dist/esm/icons/circle-partial-broken.d.ts +1 -0
  150. package/dist/esm/icons/circle-partial-broken.js +2 -0
  151. package/dist/esm/icons/circle-partial-broken.js.map +1 -1
  152. package/dist/esm/icons/circle-slash.d.ts +1 -0
  153. package/dist/esm/icons/circle-slash.js +2 -0
  154. package/dist/esm/icons/circle-slash.js.map +1 -1
  155. package/dist/esm/icons/circle-x.d.ts +1 -0
  156. package/dist/esm/icons/circle-x.js +2 -0
  157. package/dist/esm/icons/circle-x.js.map +1 -1
  158. package/dist/esm/icons/circle.d.ts +1 -0
  159. package/dist/esm/icons/circle.js +2 -0
  160. package/dist/esm/icons/circle.js.map +1 -1
  161. package/dist/esm/icons/clipboard.d.ts +1 -0
  162. package/dist/esm/icons/clipboard.js +2 -0
  163. package/dist/esm/icons/clipboard.js.map +1 -1
  164. package/dist/esm/icons/clock-cog.d.ts +1 -0
  165. package/dist/esm/icons/clock-cog.js +2 -0
  166. package/dist/esm/icons/clock-cog.js.map +1 -1
  167. package/dist/esm/icons/clock-triangle.d.ts +1 -0
  168. package/dist/esm/icons/clock-triangle.js +2 -0
  169. package/dist/esm/icons/clock-triangle.js.map +1 -1
  170. package/dist/esm/icons/clock.d.ts +1 -0
  171. package/dist/esm/icons/clock.js +2 -0
  172. package/dist/esm/icons/clock.js.map +1 -1
  173. package/dist/esm/icons/clone.d.ts +1 -0
  174. package/dist/esm/icons/clone.js +2 -0
  175. package/dist/esm/icons/clone.js.map +1 -1
  176. package/dist/esm/icons/cloud-upload.d.ts +1 -0
  177. package/dist/esm/icons/cloud-upload.js +2 -0
  178. package/dist/esm/icons/cloud-upload.js.map +1 -1
  179. package/dist/esm/icons/cloud-with-arrow.d.ts +1 -0
  180. package/dist/esm/icons/cloud-with-arrow.js +2 -0
  181. package/dist/esm/icons/cloud-with-arrow.js.map +1 -1
  182. package/dist/esm/icons/cloud.d.ts +1 -0
  183. package/dist/esm/icons/cloud.js +2 -0
  184. package/dist/esm/icons/cloud.js.map +1 -1
  185. package/dist/esm/icons/cog-database-inset.d.ts +1 -0
  186. package/dist/esm/icons/cog-database-inset.js +2 -0
  187. package/dist/esm/icons/cog-database-inset.js.map +1 -1
  188. package/dist/esm/icons/cog-database.d.ts +1 -0
  189. package/dist/esm/icons/cog-database.js +2 -0
  190. package/dist/esm/icons/cog-database.js.map +1 -1
  191. package/dist/esm/icons/cog-small-cog.d.ts +1 -0
  192. package/dist/esm/icons/cog-small-cog.js +2 -0
  193. package/dist/esm/icons/cog-small-cog.js.map +1 -1
  194. package/dist/esm/icons/cog-zoomed.d.ts +1 -0
  195. package/dist/esm/icons/cog-zoomed.js +2 -0
  196. package/dist/esm/icons/cog-zoomed.js.map +1 -1
  197. package/dist/esm/icons/cog.d.ts +1 -0
  198. package/dist/esm/icons/cog.js +2 -0
  199. package/dist/esm/icons/cog.js.map +1 -1
  200. package/dist/esm/icons/comment.d.ts +1 -0
  201. package/dist/esm/icons/comment.js +2 -0
  202. package/dist/esm/icons/comment.js.map +1 -1
  203. package/dist/esm/icons/computer-and-monitor.d.ts +1 -0
  204. package/dist/esm/icons/computer-and-monitor.js +2 -0
  205. package/dist/esm/icons/computer-and-monitor.js.map +1 -1
  206. package/dist/esm/icons/copy-text.d.ts +1 -0
  207. package/dist/esm/icons/copy-text.js +2 -0
  208. package/dist/esm/icons/copy-text.js.map +1 -1
  209. package/dist/esm/icons/copy.d.ts +1 -0
  210. package/dist/esm/icons/copy.js +2 -0
  211. package/dist/esm/icons/copy.js.map +1 -1
  212. package/dist/esm/icons/dashboard-builder-legend.d.ts +1 -0
  213. package/dist/esm/icons/dashboard-builder-legend.js +2 -0
  214. package/dist/esm/icons/dashboard-builder-legend.js.map +1 -1
  215. package/dist/esm/icons/dashboard-builder-templates.d.ts +1 -0
  216. package/dist/esm/icons/dashboard-builder-templates.js +2 -0
  217. package/dist/esm/icons/dashboard-builder-templates.js.map +1 -1
  218. package/dist/esm/icons/dashboard-builder-tile.d.ts +1 -0
  219. package/dist/esm/icons/dashboard-builder-tile.js +2 -0
  220. package/dist/esm/icons/dashboard-builder-tile.js.map +1 -1
  221. package/dist/esm/icons/dashboard-builder.d.ts +1 -0
  222. package/dist/esm/icons/dashboard-builder.js +2 -0
  223. package/dist/esm/icons/dashboard-builder.js.map +1 -1
  224. package/dist/esm/icons/database-check.d.ts +1 -0
  225. package/dist/esm/icons/database-check.js +2 -0
  226. package/dist/esm/icons/database-check.js.map +1 -1
  227. package/dist/esm/icons/database.d.ts +1 -0
  228. package/dist/esm/icons/database.js +2 -0
  229. package/dist/esm/icons/database.js.map +1 -1
  230. package/dist/esm/icons/desktop.d.ts +1 -0
  231. package/dist/esm/icons/desktop.js +2 -0
  232. package/dist/esm/icons/desktop.js.map +1 -1
  233. package/dist/esm/icons/donut-chart.d.ts +1 -0
  234. package/dist/esm/icons/donut-chart.js +2 -0
  235. package/dist/esm/icons/donut-chart.js.map +1 -1
  236. package/dist/esm/icons/dot-solid-dot-stroke-measurement.d.ts +1 -0
  237. package/dist/esm/icons/dot-solid-dot-stroke-measurement.js +2 -0
  238. package/dist/esm/icons/dot-solid-dot-stroke-measurement.js.map +1 -1
  239. package/dist/esm/icons/dot-solid-dot-stroke.d.ts +1 -0
  240. package/dist/esm/icons/dot-solid-dot-stroke.js +2 -0
  241. package/dist/esm/icons/dot-solid-dot-stroke.js.map +1 -1
  242. package/dist/esm/icons/download.d.ts +1 -0
  243. package/dist/esm/icons/download.js +2 -0
  244. package/dist/esm/icons/download.js.map +1 -1
  245. package/dist/esm/icons/electronic-chip-zoomed.d.ts +1 -0
  246. package/dist/esm/icons/electronic-chip-zoomed.js +2 -0
  247. package/dist/esm/icons/electronic-chip-zoomed.js.map +1 -1
  248. package/dist/esm/icons/exclamation-mark.d.ts +1 -0
  249. package/dist/esm/icons/exclamation-mark.js +2 -0
  250. package/dist/esm/icons/exclamation-mark.js.map +1 -1
  251. package/dist/esm/icons/eye.d.ts +1 -0
  252. package/dist/esm/icons/eye.js +2 -0
  253. package/dist/esm/icons/eye.js.map +1 -1
  254. package/dist/esm/icons/fancy-a.d.ts +1 -0
  255. package/dist/esm/icons/fancy-a.js +2 -0
  256. package/dist/esm/icons/fancy-a.js.map +1 -1
  257. package/dist/esm/icons/file-drawer.d.ts +1 -0
  258. package/dist/esm/icons/file-drawer.js +2 -0
  259. package/dist/esm/icons/file-drawer.js.map +1 -1
  260. package/dist/esm/icons/file-search.d.ts +1 -0
  261. package/dist/esm/icons/file-search.js +2 -0
  262. package/dist/esm/icons/file-search.js.map +1 -1
  263. package/dist/esm/icons/file.d.ts +1 -0
  264. package/dist/esm/icons/file.js +2 -0
  265. package/dist/esm/icons/file.js.map +1 -1
  266. package/dist/esm/icons/filter.d.ts +1 -0
  267. package/dist/esm/icons/filter.js +2 -0
  268. package/dist/esm/icons/filter.js.map +1 -1
  269. package/dist/esm/icons/floppy-disk-checkmark.d.ts +1 -0
  270. package/dist/esm/icons/floppy-disk-checkmark.js +2 -0
  271. package/dist/esm/icons/floppy-disk-checkmark.js.map +1 -1
  272. package/dist/esm/icons/floppy-disk-star-arrow-right.d.ts +1 -0
  273. package/dist/esm/icons/floppy-disk-star-arrow-right.js +2 -0
  274. package/dist/esm/icons/floppy-disk-star-arrow-right.js.map +1 -1
  275. package/dist/esm/icons/floppy-disk-three-dots.d.ts +1 -0
  276. package/dist/esm/icons/floppy-disk-three-dots.js +2 -0
  277. package/dist/esm/icons/floppy-disk-three-dots.js.map +1 -1
  278. package/dist/esm/icons/floppy-disk.d.ts +1 -0
  279. package/dist/esm/icons/floppy-disk.js +2 -0
  280. package/dist/esm/icons/floppy-disk.js.map +1 -1
  281. package/dist/esm/icons/folder-open.d.ts +1 -0
  282. package/dist/esm/icons/folder-open.js +2 -0
  283. package/dist/esm/icons/folder-open.js.map +1 -1
  284. package/dist/esm/icons/folder.d.ts +1 -0
  285. package/dist/esm/icons/folder.js +2 -0
  286. package/dist/esm/icons/folder.js.map +1 -1
  287. package/dist/esm/icons/forward-slash.d.ts +1 -0
  288. package/dist/esm/icons/forward-slash.js +2 -0
  289. package/dist/esm/icons/forward-slash.js.map +1 -1
  290. package/dist/esm/icons/four-dots-square.d.ts +1 -0
  291. package/dist/esm/icons/four-dots-square.js +2 -0
  292. package/dist/esm/icons/four-dots-square.js.map +1 -1
  293. package/dist/esm/icons/function.d.ts +1 -0
  294. package/dist/esm/icons/function.js +2 -0
  295. package/dist/esm/icons/function.js.map +1 -1
  296. package/dist/esm/icons/gauge-simple.d.ts +1 -0
  297. package/dist/esm/icons/gauge-simple.js +2 -0
  298. package/dist/esm/icons/gauge-simple.js.map +1 -1
  299. package/dist/esm/icons/grid-three-by-three.d.ts +1 -0
  300. package/dist/esm/icons/grid-three-by-three.js +2 -0
  301. package/dist/esm/icons/grid-three-by-three.js.map +1 -1
  302. package/dist/esm/icons/grid-two-by-two.d.ts +1 -0
  303. package/dist/esm/icons/grid-two-by-two.js +2 -0
  304. package/dist/esm/icons/grid-two-by-two.js.map +1 -1
  305. package/dist/esm/icons/hammer.d.ts +1 -0
  306. package/dist/esm/icons/hammer.js +2 -0
  307. package/dist/esm/icons/hammer.js.map +1 -1
  308. package/dist/esm/icons/hashtag.d.ts +1 -0
  309. package/dist/esm/icons/hashtag.js +2 -0
  310. package/dist/esm/icons/hashtag.js.map +1 -1
  311. package/dist/esm/icons/home.d.ts +1 -0
  312. package/dist/esm/icons/home.js +2 -0
  313. package/dist/esm/icons/home.js.map +1 -1
  314. package/dist/esm/icons/hourglass.d.ts +1 -0
  315. package/dist/esm/icons/hourglass.js +2 -0
  316. package/dist/esm/icons/hourglass.js.map +1 -1
  317. package/dist/esm/icons/indeterminant-checkbox.d.ts +1 -0
  318. package/dist/esm/icons/indeterminant-checkbox.js +2 -0
  319. package/dist/esm/icons/indeterminant-checkbox.js.map +1 -1
  320. package/dist/esm/icons/info-circle.d.ts +1 -0
  321. package/dist/esm/icons/info-circle.js +2 -0
  322. package/dist/esm/icons/info-circle.js.map +1 -1
  323. package/dist/esm/icons/info.d.ts +1 -0
  324. package/dist/esm/icons/info.js +2 -0
  325. package/dist/esm/icons/info.js.map +1 -1
  326. package/dist/esm/icons/key.d.ts +1 -0
  327. package/dist/esm/icons/key.js +2 -0
  328. package/dist/esm/icons/key.js.map +1 -1
  329. package/dist/esm/icons/laptop.d.ts +1 -0
  330. package/dist/esm/icons/laptop.js +2 -0
  331. package/dist/esm/icons/laptop.js.map +1 -1
  332. package/dist/esm/icons/layer-group.d.ts +1 -0
  333. package/dist/esm/icons/layer-group.js +2 -0
  334. package/dist/esm/icons/layer-group.js.map +1 -1
  335. package/dist/esm/icons/lightning-bolt.d.ts +1 -0
  336. package/dist/esm/icons/lightning-bolt.js +2 -0
  337. package/dist/esm/icons/lightning-bolt.js.map +1 -1
  338. package/dist/esm/icons/link-cancel.d.ts +1 -0
  339. package/dist/esm/icons/link-cancel.js +2 -0
  340. package/dist/esm/icons/link-cancel.js.map +1 -1
  341. package/dist/esm/icons/link.d.ts +1 -0
  342. package/dist/esm/icons/link.js +2 -0
  343. package/dist/esm/icons/link.js.map +1 -1
  344. package/dist/esm/icons/list-tree-database.d.ts +1 -0
  345. package/dist/esm/icons/list-tree-database.js +2 -0
  346. package/dist/esm/icons/list-tree-database.js.map +1 -1
  347. package/dist/esm/icons/list-tree.d.ts +1 -0
  348. package/dist/esm/icons/list-tree.js +2 -0
  349. package/dist/esm/icons/list-tree.js.map +1 -1
  350. package/dist/esm/icons/list.d.ts +1 -0
  351. package/dist/esm/icons/list.js +2 -0
  352. package/dist/esm/icons/list.js.map +1 -1
  353. package/dist/esm/icons/lock.d.ts +1 -0
  354. package/dist/esm/icons/lock.js +2 -0
  355. package/dist/esm/icons/lock.js.map +1 -1
  356. package/dist/esm/icons/magnifying-glass.d.ts +1 -0
  357. package/dist/esm/icons/magnifying-glass.js +2 -0
  358. package/dist/esm/icons/magnifying-glass.js.map +1 -1
  359. package/dist/esm/icons/markdown.d.ts +1 -0
  360. package/dist/esm/icons/markdown.js +2 -0
  361. package/dist/esm/icons/markdown.js.map +1 -1
  362. package/dist/esm/icons/minus-wide.d.ts +1 -0
  363. package/dist/esm/icons/minus-wide.js +2 -0
  364. package/dist/esm/icons/minus-wide.js.map +1 -1
  365. package/dist/esm/icons/minus.d.ts +1 -0
  366. package/dist/esm/icons/minus.js +2 -0
  367. package/dist/esm/icons/minus.js.map +1 -1
  368. package/dist/esm/icons/mobile.d.ts +1 -0
  369. package/dist/esm/icons/mobile.js +2 -0
  370. package/dist/esm/icons/mobile.js.map +1 -1
  371. package/dist/esm/icons/notebook.d.ts +1 -0
  372. package/dist/esm/icons/notebook.js +2 -0
  373. package/dist/esm/icons/notebook.js.map +1 -1
  374. package/dist/esm/icons/paste.d.ts +1 -0
  375. package/dist/esm/icons/paste.js +2 -0
  376. package/dist/esm/icons/paste.js.map +1 -1
  377. package/dist/esm/icons/pencil.d.ts +1 -0
  378. package/dist/esm/icons/pencil.js +2 -0
  379. package/dist/esm/icons/pencil.js.map +1 -1
  380. package/dist/esm/icons/pot-with-lid.d.ts +1 -0
  381. package/dist/esm/icons/pot-with-lid.js +2 -0
  382. package/dist/esm/icons/pot-with-lid.js.map +1 -1
  383. package/dist/esm/icons/question.d.ts +1 -0
  384. package/dist/esm/icons/question.js +2 -0
  385. package/dist/esm/icons/question.js.map +1 -1
  386. package/dist/esm/icons/running-arrow.d.ts +1 -0
  387. package/dist/esm/icons/running-arrow.js +2 -0
  388. package/dist/esm/icons/running-arrow.js.map +1 -1
  389. package/dist/esm/icons/server.d.ts +1 -0
  390. package/dist/esm/icons/server.js +2 -0
  391. package/dist/esm/icons/server.js.map +1 -1
  392. package/dist/esm/icons/share-nodes.d.ts +1 -0
  393. package/dist/esm/icons/share-nodes.js +2 -0
  394. package/dist/esm/icons/share-nodes.js.map +1 -1
  395. package/dist/esm/icons/share-square.d.ts +1 -0
  396. package/dist/esm/icons/share-square.js +2 -0
  397. package/dist/esm/icons/share-square.js.map +1 -1
  398. package/dist/esm/icons/shield-check.d.ts +1 -0
  399. package/dist/esm/icons/shield-check.js +2 -0
  400. package/dist/esm/icons/shield-check.js.map +1 -1
  401. package/dist/esm/icons/shield-xmark.d.ts +1 -0
  402. package/dist/esm/icons/shield-xmark.js +2 -0
  403. package/dist/esm/icons/shield-xmark.js.map +1 -1
  404. package/dist/esm/icons/signal-bars.d.ts +1 -0
  405. package/dist/esm/icons/signal-bars.js +2 -0
  406. package/dist/esm/icons/signal-bars.js.map +1 -1
  407. package/dist/esm/icons/sine-graph.d.ts +1 -0
  408. package/dist/esm/icons/sine-graph.js +2 -0
  409. package/dist/esm/icons/sine-graph.js.map +1 -1
  410. package/dist/esm/icons/skip-arrow.d.ts +1 -0
  411. package/dist/esm/icons/skip-arrow.js +2 -0
  412. package/dist/esm/icons/skip-arrow.js.map +1 -1
  413. package/dist/esm/icons/spinner.d.ts +1 -0
  414. package/dist/esm/icons/spinner.js +2 -0
  415. package/dist/esm/icons/spinner.js.map +1 -1
  416. package/dist/esm/icons/square-check.d.ts +1 -0
  417. package/dist/esm/icons/square-check.js +2 -0
  418. package/dist/esm/icons/square-check.js.map +1 -1
  419. package/dist/esm/icons/square-t.d.ts +1 -0
  420. package/dist/esm/icons/square-t.js +2 -0
  421. package/dist/esm/icons/square-t.js.map +1 -1
  422. package/dist/esm/icons/t.d.ts +1 -0
  423. package/dist/esm/icons/t.js +2 -0
  424. package/dist/esm/icons/t.js.map +1 -1
  425. package/dist/esm/icons/tablet.d.ts +1 -0
  426. package/dist/esm/icons/tablet.js +2 -0
  427. package/dist/esm/icons/tablet.js.map +1 -1
  428. package/dist/esm/icons/tag.d.ts +1 -0
  429. package/dist/esm/icons/tag.js +2 -0
  430. package/dist/esm/icons/tag.js.map +1 -1
  431. package/dist/esm/icons/tags.d.ts +1 -0
  432. package/dist/esm/icons/tags.js +2 -0
  433. package/dist/esm/icons/tags.js.map +1 -1
  434. package/dist/esm/icons/target-crosshairs-progress.d.ts +1 -0
  435. package/dist/esm/icons/target-crosshairs-progress.js +2 -0
  436. package/dist/esm/icons/target-crosshairs-progress.js.map +1 -1
  437. package/dist/esm/icons/target-crosshairs.d.ts +1 -0
  438. package/dist/esm/icons/target-crosshairs.js +2 -0
  439. package/dist/esm/icons/target-crosshairs.js.map +1 -1
  440. package/dist/esm/icons/three-dots-line.d.ts +1 -0
  441. package/dist/esm/icons/three-dots-line.js +2 -0
  442. package/dist/esm/icons/three-dots-line.js.map +1 -1
  443. package/dist/esm/icons/three-vertical-lines.d.ts +1 -0
  444. package/dist/esm/icons/three-vertical-lines.js +2 -0
  445. package/dist/esm/icons/three-vertical-lines.js.map +1 -1
  446. package/dist/esm/icons/thumbtack.d.ts +1 -0
  447. package/dist/esm/icons/thumbtack.js +2 -0
  448. package/dist/esm/icons/thumbtack.js.map +1 -1
  449. package/dist/esm/icons/tile-size.d.ts +1 -0
  450. package/dist/esm/icons/tile-size.js +2 -0
  451. package/dist/esm/icons/tile-size.js.map +1 -1
  452. package/dist/esm/icons/times.d.ts +1 -0
  453. package/dist/esm/icons/times.js +2 -0
  454. package/dist/esm/icons/times.js.map +1 -1
  455. package/dist/esm/icons/trash.d.ts +1 -0
  456. package/dist/esm/icons/trash.js +2 -0
  457. package/dist/esm/icons/trash.js.map +1 -1
  458. package/dist/esm/icons/triangle-filled.d.ts +1 -0
  459. package/dist/esm/icons/triangle-filled.js +2 -0
  460. package/dist/esm/icons/triangle-filled.js.map +1 -1
  461. package/dist/esm/icons/triangle.d.ts +1 -0
  462. package/dist/esm/icons/triangle.js +2 -0
  463. package/dist/esm/icons/triangle.js.map +1 -1
  464. package/dist/esm/icons/true-false-rectangle.d.ts +1 -0
  465. package/dist/esm/icons/true-false-rectangle.js +2 -0
  466. package/dist/esm/icons/true-false-rectangle.js.map +1 -1
  467. package/dist/esm/icons/unlink.d.ts +1 -0
  468. package/dist/esm/icons/unlink.js +2 -0
  469. package/dist/esm/icons/unlink.js.map +1 -1
  470. package/dist/esm/icons/unlock.d.ts +1 -0
  471. package/dist/esm/icons/unlock.js +2 -0
  472. package/dist/esm/icons/unlock.js.map +1 -1
  473. package/dist/esm/icons/upload.d.ts +1 -0
  474. package/dist/esm/icons/upload.js +2 -0
  475. package/dist/esm/icons/upload.js.map +1 -1
  476. package/dist/esm/icons/user.d.ts +1 -0
  477. package/dist/esm/icons/user.js +2 -0
  478. package/dist/esm/icons/user.js.map +1 -1
  479. package/dist/esm/icons/watch.d.ts +1 -0
  480. package/dist/esm/icons/watch.js +2 -0
  481. package/dist/esm/icons/watch.js.map +1 -1
  482. package/dist/esm/icons/waveform.d.ts +1 -0
  483. package/dist/esm/icons/waveform.js +2 -0
  484. package/dist/esm/icons/waveform.js.map +1 -1
  485. package/dist/esm/icons/webvi-custom.d.ts +1 -0
  486. package/dist/esm/icons/webvi-custom.js +2 -0
  487. package/dist/esm/icons/webvi-custom.js.map +1 -1
  488. package/dist/esm/icons/webvi-host.d.ts +1 -0
  489. package/dist/esm/icons/webvi-host.js +2 -0
  490. package/dist/esm/icons/webvi-host.js.map +1 -1
  491. package/dist/esm/icons/window-code.d.ts +1 -0
  492. package/dist/esm/icons/window-code.js +2 -0
  493. package/dist/esm/icons/window-code.js.map +1 -1
  494. package/dist/esm/icons/window-text.d.ts +1 -0
  495. package/dist/esm/icons/window-text.js +2 -0
  496. package/dist/esm/icons/window-text.js.map +1 -1
  497. package/dist/esm/icons/wrench-hammer.d.ts +1 -0
  498. package/dist/esm/icons/wrench-hammer.js +2 -0
  499. package/dist/esm/icons/wrench-hammer.js.map +1 -1
  500. package/dist/esm/icons/xmark-check.d.ts +1 -0
  501. package/dist/esm/icons/xmark-check.js +2 -0
  502. package/dist/esm/icons/xmark-check.js.map +1 -1
  503. package/dist/esm/icons/xmark.d.ts +1 -0
  504. package/dist/esm/icons/xmark.js +2 -0
  505. package/dist/esm/icons/xmark.js.map +1 -1
  506. package/dist/esm/list-option/index.d.ts +1 -0
  507. package/dist/esm/list-option/index.js +1 -0
  508. package/dist/esm/list-option/index.js.map +1 -1
  509. package/dist/esm/menu/index.d.ts +1 -0
  510. package/dist/esm/menu/index.js +1 -0
  511. package/dist/esm/menu/index.js.map +1 -1
  512. package/dist/esm/menu-button/index.d.ts +1 -0
  513. package/dist/esm/menu-button/index.js +1 -0
  514. package/dist/esm/menu-button/index.js.map +1 -1
  515. package/dist/esm/menu-item/index.d.ts +1 -0
  516. package/dist/esm/menu-item/index.js +1 -0
  517. package/dist/esm/menu-item/index.js.map +1 -1
  518. package/dist/esm/number-field/index.d.ts +1 -0
  519. package/dist/esm/number-field/index.js +1 -0
  520. package/dist/esm/number-field/index.js.map +1 -1
  521. package/dist/esm/radio/index.d.ts +1 -0
  522. package/dist/esm/radio/index.js +1 -0
  523. package/dist/esm/radio/index.js.map +1 -1
  524. package/dist/esm/radio-group/index.d.ts +1 -0
  525. package/dist/esm/radio-group/index.js +1 -0
  526. package/dist/esm/radio-group/index.js.map +1 -1
  527. package/dist/esm/select/index.d.ts +1 -0
  528. package/dist/esm/select/index.js +1 -0
  529. package/dist/esm/select/index.js.map +1 -1
  530. package/dist/esm/spinner/index.d.ts +1 -0
  531. package/dist/esm/spinner/index.js +1 -0
  532. package/dist/esm/spinner/index.js.map +1 -1
  533. package/dist/esm/switch/index.d.ts +1 -0
  534. package/dist/esm/switch/index.js +1 -0
  535. package/dist/esm/switch/index.js.map +1 -1
  536. package/dist/esm/tab/index.d.ts +1 -0
  537. package/dist/esm/tab/index.js +1 -0
  538. package/dist/esm/tab/index.js.map +1 -1
  539. package/dist/esm/tab-panel/index.d.ts +1 -0
  540. package/dist/esm/tab-panel/index.js +1 -0
  541. package/dist/esm/tab-panel/index.js.map +1 -1
  542. package/dist/esm/table/components/cell/index.d.ts +1 -1
  543. package/dist/esm/table/components/cell/index.js.map +1 -1
  544. package/dist/esm/table/components/cell/template.d.ts +1 -1
  545. package/dist/esm/table/components/header/index.d.ts +6 -0
  546. package/dist/esm/table/components/header/index.js +32 -0
  547. package/dist/esm/table/components/header/index.js.map +1 -1
  548. package/dist/esm/table/components/header/styles.js +5 -0
  549. package/dist/esm/table/components/header/styles.js.map +1 -1
  550. package/dist/esm/table/components/header/template.js +15 -2
  551. package/dist/esm/table/components/header/template.js.map +1 -1
  552. package/dist/esm/table/components/row/index.d.ts +5 -1
  553. package/dist/esm/table/components/row/index.js.map +1 -1
  554. package/dist/esm/table/components/row/template.d.ts +1 -1
  555. package/dist/esm/table/index.d.ts +14 -2
  556. package/dist/esm/table/index.js +63 -30
  557. package/dist/esm/table/index.js.map +1 -1
  558. package/dist/esm/table/models/sort-operations.d.ts +7 -0
  559. package/dist/esm/table/models/sort-operations.js +36 -0
  560. package/dist/esm/table/models/sort-operations.js.map +1 -0
  561. package/dist/esm/table/models/table-validator.d.ts +2 -0
  562. package/dist/esm/table/models/table-validator.js +14 -1
  563. package/dist/esm/table/models/table-validator.js.map +1 -1
  564. package/dist/esm/table/template.js +6 -1
  565. package/dist/esm/table/template.js.map +1 -1
  566. package/dist/esm/table/types.d.ts +10 -17
  567. package/dist/esm/table/types.js +8 -1
  568. package/dist/esm/table/types.js.map +1 -1
  569. package/dist/esm/table-column/base/index.d.ts +23 -1
  570. package/dist/esm/table-column/base/index.js +25 -3
  571. package/dist/esm/table-column/base/index.js.map +1 -1
  572. package/dist/esm/table-column/base/types.d.ts +26 -0
  573. package/dist/esm/table-column/base/types.js +15 -0
  574. package/dist/esm/table-column/base/types.js.map +1 -0
  575. package/dist/esm/table-column/text/index.d.ts +8 -1
  576. package/dist/esm/table-column/text/index.js +5 -1
  577. package/dist/esm/table-column/text/index.js.map +1 -1
  578. package/dist/esm/table-column/text/template.d.ts +1 -1
  579. package/dist/esm/tabs/index.d.ts +1 -0
  580. package/dist/esm/tabs/index.js +1 -0
  581. package/dist/esm/tabs/index.js.map +1 -1
  582. package/dist/esm/tabs-toolbar/index.d.ts +1 -0
  583. package/dist/esm/tabs-toolbar/index.js +1 -0
  584. package/dist/esm/tabs-toolbar/index.js.map +1 -1
  585. package/dist/esm/text-area/index.d.ts +1 -0
  586. package/dist/esm/text-area/index.js +1 -0
  587. package/dist/esm/text-area/index.js.map +1 -1
  588. package/dist/esm/text-field/index.d.ts +1 -0
  589. package/dist/esm/text-field/index.js +1 -0
  590. package/dist/esm/text-field/index.js.map +1 -1
  591. package/dist/esm/theme-provider/index.d.ts +1 -0
  592. package/dist/esm/theme-provider/index.js +1 -0
  593. package/dist/esm/theme-provider/index.js.map +1 -1
  594. package/dist/esm/toggle-button/index.d.ts +1 -0
  595. package/dist/esm/toggle-button/index.js +1 -0
  596. package/dist/esm/toggle-button/index.js.map +1 -1
  597. package/dist/esm/toolbar/index.d.ts +1 -0
  598. package/dist/esm/toolbar/index.js +1 -0
  599. package/dist/esm/toolbar/index.js.map +1 -1
  600. package/dist/esm/tooltip/index.d.ts +1 -0
  601. package/dist/esm/tooltip/index.js +1 -0
  602. package/dist/esm/tooltip/index.js.map +1 -1
  603. package/dist/esm/tree-item/index.d.ts +1 -0
  604. package/dist/esm/tree-item/index.js +1 -0
  605. package/dist/esm/tree-item/index.js.map +1 -1
  606. package/dist/esm/tree-view/index.d.ts +1 -0
  607. package/dist/esm/tree-view/index.js +1 -0
  608. package/dist/esm/tree-view/index.js.map +1 -1
  609. package/dist/esm/wafer-map/index.d.ts +1 -0
  610. package/dist/esm/wafer-map/index.js +1 -0
  611. package/dist/esm/wafer-map/index.js.map +1 -1
  612. package/package.json +2 -2
  613. package/dist/esm/table/models/table-validator.spec.d.ts +0 -1
  614. package/dist/esm/table/models/table-validator.spec.js +0 -276
  615. package/dist/esm/table/models/table-validator.spec.js.map +0 -1
@@ -1,4 +1,5 @@
1
1
  import { FoundationElement } from '@microsoft/fast-foundation';
2
+ import { TableColumnSortDirection } from '../../types';
2
3
  declare global {
3
4
  interface HTMLElementTagNameMap {
4
5
  'nimble-table-header': TableHeader;
@@ -9,4 +10,9 @@ declare global {
9
10
  * @internal
10
11
  */
11
12
  export declare class TableHeader extends FoundationElement {
13
+ sortDirection: TableColumnSortDirection;
14
+ firstSortedColumn: boolean;
15
+ protected sortDirectionChanged(_prev: TableColumnSortDirection | undefined, _next: TableColumnSortDirection): void;
16
+ protected firstSortedColumnChanged(_prev: boolean | undefined, _next: boolean): void;
17
+ private updateAriaSort;
12
18
  }
@@ -1,4 +1,7 @@
1
+ import { __decorate } from "tslib";
2
+ import { attr } from '@microsoft/fast-element';
1
3
  import { DesignSystem, FoundationElement } from '@microsoft/fast-foundation';
4
+ import { TableColumnSortDirection } from '../../types';
2
5
  import { styles } from './styles';
3
6
  import { template } from './template';
4
7
  /**
@@ -6,7 +9,36 @@ import { template } from './template';
6
9
  * @internal
7
10
  */
8
11
  export class TableHeader extends FoundationElement {
12
+ constructor() {
13
+ super(...arguments);
14
+ this.sortDirection = TableColumnSortDirection.none;
15
+ this.firstSortedColumn = false;
16
+ }
17
+ sortDirectionChanged(_prev, _next) {
18
+ this.updateAriaSort();
19
+ }
20
+ firstSortedColumnChanged(_prev, _next) {
21
+ this.updateAriaSort();
22
+ }
23
+ updateAriaSort() {
24
+ if (!this.firstSortedColumn
25
+ || this.sortDirection === TableColumnSortDirection.none) {
26
+ this.ariaSort = null;
27
+ }
28
+ else if (this.sortDirection === TableColumnSortDirection.ascending) {
29
+ this.ariaSort = 'ascending';
30
+ }
31
+ else {
32
+ this.ariaSort = 'descending';
33
+ }
34
+ }
9
35
  }
36
+ __decorate([
37
+ attr({ attribute: 'sort-direction' })
38
+ ], TableHeader.prototype, "sortDirection", void 0);
39
+ __decorate([
40
+ attr({ attribute: 'first-sorted-column', mode: 'boolean' })
41
+ ], TableHeader.prototype, "firstSortedColumn", void 0);
10
42
  const nimbleTableHeader = TableHeader.compose({
11
43
  baseName: 'table-header',
12
44
  template,
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/table/components/header/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC7E,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAQtC;;;GAGG;AACH,MAAM,OAAO,WAAY,SAAQ,iBAAiB;CAAG;AAErD,MAAM,iBAAiB,GAAG,WAAW,CAAC,OAAO,CAAC;IAC1C,QAAQ,EAAE,cAAc;IACxB,QAAQ;IACR,MAAM;CACT,CAAC,CAAC;AAEH,YAAY,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/table/components/header/index.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC7E,OAAO,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;AACvD,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAQtC;;;GAGG;AACH,MAAM,OAAO,WAAY,SAAQ,iBAAiB;IAAlD;;QAEW,kBAAa,GAA6B,wBAAwB,CAAC,IAAI,CAAC;QAGxE,sBAAiB,GAAG,KAAK,CAAC;IA4BrC,CAAC;IA1Ba,oBAAoB,CAC1B,KAA2C,EAC3C,KAA+B;QAE/B,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAES,wBAAwB,CAC9B,KAA0B,EAC1B,KAAc;QAEd,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAEO,cAAc;QAClB,IACI,CAAC,IAAI,CAAC,iBAAiB;eACpB,IAAI,CAAC,aAAa,KAAK,wBAAwB,CAAC,IAAI,EACzD;YACE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;SACxB;aAAM,IAAI,IAAI,CAAC,aAAa,KAAK,wBAAwB,CAAC,SAAS,EAAE;YAClE,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC;SAC/B;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,YAAY,CAAC;SAChC;IACL,CAAC;CACJ;AA/BG;IADC,IAAI,CAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC;kDACyC;AAG/E;IADC,IAAI,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;sDAC3B;AA8BrC,MAAM,iBAAiB,GAAG,WAAW,CAAC,OAAO,CAAC;IAC1C,QAAQ,EAAE,cAAc;IACxB,QAAQ;IACR,MAAM;CACT,CAAC,CAAC;AAEH,YAAY,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC,CAAC"}
@@ -13,5 +13,10 @@ export const styles = css `
13
13
  ${iconColor.cssCustomProperty}: ${tableHeaderFontColor};
14
14
  text-transform: uppercase;
15
15
  }
16
+
17
+ .sort-indicator {
18
+ padding: 0px calc(${standardPadding} / 2);
19
+ width: ${standardPadding};
20
+ }
16
21
  `;
17
22
  //# sourceMappingURL=styles.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../../src/table/components/header/styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,yBAAyB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EACH,aAAa,EACb,SAAS,EACT,eAAe,EACf,eAAe,EACf,oBAAoB,EACvB,MAAM,uCAAuC,CAAC;AAE/C,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;MACnB,OAAO,CAAC,MAAM,CAAC;;;kBAGH,aAAa;;4BAEH,eAAe;gBAC3B,eAAe;iBACd,oBAAoB;UAC3B,SAAS,CAAC,iBAAiB,KAAK,oBAAoB;;;CAG7D,CAAC"}
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../../src/table/components/header/styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,yBAAyB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EACH,aAAa,EACb,SAAS,EACT,eAAe,EACf,eAAe,EACf,oBAAoB,EACvB,MAAM,uCAAuC,CAAC;AAE/C,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;MACnB,OAAO,CAAC,MAAM,CAAC;;;kBAGH,aAAa;;4BAEH,eAAe;gBAC3B,eAAe;iBACd,oBAAoB;UAC3B,SAAS,CAAC,iBAAiB,KAAK,oBAAoB;;;;;4BAKlC,eAAe;iBAC1B,eAAe;;CAE/B,CAAC"}
@@ -1,8 +1,21 @@
1
- import { html } from '@microsoft/fast-element';
1
+ import { html, when } from '@microsoft/fast-element';
2
+ import { DesignSystem } from '@microsoft/fast-foundation';
3
+ import { IconArrowDown } from '../../../icons/arrow-down';
4
+ import { IconArrowUp } from '../../../icons/arrow-up';
5
+ import { TableColumnSortDirection } from '../../types';
2
6
  // prettier-ignore
3
7
  export const template = html `
4
- <template role="columnheader">
8
+ <template role="columnheader" aria-sort="${x => x.ariaSort}">
5
9
  <slot></slot>
10
+
11
+ <span class="sort-indicator" aria-hidden="true">
12
+ ${when(x => x.sortDirection === TableColumnSortDirection.ascending, html `
13
+ <${DesignSystem.tagFor(IconArrowUp)}></${DesignSystem.tagFor(IconArrowUp)}>
14
+ `)}
15
+ ${when(x => x.sortDirection === TableColumnSortDirection.descending, html `
16
+ <${DesignSystem.tagFor(IconArrowDown)}></${DesignSystem.tagFor(IconArrowDown)}>
17
+ `)}
18
+ </span>
6
19
  </template>
7
20
  `;
8
21
  //# sourceMappingURL=template.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../../src/table/components/header/template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AAG/C,kBAAkB;AAClB,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,CAAa;;;;CAIxC,CAAC"}
1
+ {"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../../src/table/components/header/template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE1D,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;AAEvD,kBAAkB;AAClB,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,CAAa;+CACM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ;;;;cAIhD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,KAAK,wBAAwB,CAAC,SAAS,EAAE,IAAI,CAAA;mBACjE,YAAY,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,YAAY,CAAC,MAAM,CAAC,WAAW,CAAC;aAC5E,CAAC;cACA,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,KAAK,wBAAwB,CAAC,UAAU,EAAE,IAAI,CAAA;mBAClE,YAAY,CAAC,MAAM,CAAC,aAAa,CAAC,MAAM,YAAY,CAAC,MAAM,CAAC,aAAa,CAAC;aAChF,CAAC;;;CAGb,CAAC"}
@@ -1,5 +1,6 @@
1
1
  import { FoundationElement } from '@microsoft/fast-foundation';
2
- import type { TableCellState, TableDataRecord } from '../../types';
2
+ import type { TableCellState } from '../../../table-column/base/types';
3
+ import type { TableRecord } from '../../types';
3
4
  import type { TableColumn } from '../../../table-column/base';
4
5
  import type { MenuButtonToggleEventDetail } from '../../../menu-button/types';
5
6
  declare global {
@@ -11,6 +12,9 @@ export interface ColumnState {
11
12
  column: TableColumn;
12
13
  cellState: TableCellState;
13
14
  }
15
+ /** Represents a single row (element) in the Table's data */
16
+ export interface TableDataRecord extends TableRecord {
17
+ }
14
18
  /**
15
19
  * A styled row that is used within the nimble-table.
16
20
  * @internal
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/table/components/row/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/table/components/row/index.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AACrE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC7E,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAyBtC;;;GAGG;AACH,MAAM,OAAO,QAEX,SAAQ,iBAAiB;IAF3B;;QAUW,YAAO,GAAkB,EAAE,CAAC;QAM5B,aAAQ,GAAG,KAAK,CAAC;IAqE5B,CAAC;IAlEG,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;YAC7B,MAAM,UAAU,GAAG,MAAM,CAAC,oBAAoB,CAAC;YAC/C,IAAI,SAAyB,CAAC;YAC9B,IAAI,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE;gBACxD,MAAM,cAAc,GAAG,UAAU,CAAC,GAAG,CACjC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,UAAW,CAAC,KAAK,CAAC,CACnC,CAAC;gBACF,MAAM,UAAU,GAAG,MAAM,CAAC,WAAW,CACjC,MAAM,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;oBACtC,CAAC;oBACD,cAAc,CAAC,CAAC,CAAC;iBACpB,CAAC,CACL,CAAC;gBACF,MAAM,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,EAAE,CAAC;gBAC/C,SAAS,GAAG;oBACR,UAAU;oBACV,YAAY;iBACf,CAAC;aACL;iBAAM;gBACH,SAAS,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC;aACpD;YAED,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;QACjC,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,4BAA4B,CAC/B,KAA+C,EAC/C,MAAmB;QAEnB,IAAI,CAAC,uBAAuB,GAAG,MAAM,CAAC;QACtC,IAAI,CAAC,eAAe,CAChB,8BAA8B,EAC9B,KAAK,CAAC,MAAM,EACZ,MAAM,CACT,CAAC;IACN,CAAC;IAEM,sBAAsB,CACzB,KAA+C,EAC/C,MAAmB;QAEnB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,eAAe,CAAC,wBAAwB,EAAE,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzE,CAAC;IAEO,eAAe,CACnB,SAAiB,EACjB,qBAAkD,EAClD,MAAmB;QAEnB,MAAM,MAAM,GAAqC;YAC7C,QAAQ,EAAE,qBAAqB,CAAC,QAAQ;YACxC,QAAQ,EAAE,qBAAqB,CAAC,QAAQ;YACxC,SAAS,EAAE,CAAC,IAAI,CAAC,QAAS,CAAC;YAC3B,QAAQ,EAAE,MAAM,CAAC,QAAQ;SAC5B,CAAC;QACF,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IAClC,CAAC;IAEO,kBAAkB,CACtB,IAA6C;QAE7C,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC;IAChD,CAAC;CACJ;AAjFG;IADC,IAAI,CAAC,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC;0CACR;AAGzB;IADC,UAAU;4CACqB;AAGhC;IADC,UAAU;yCACwB;AAGnC;IADC,UAAU;yDACkC;AAG7C;IADC,IAAI,CAAC,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;0CAC1B;AAGxB;IADC,QAAQ;4CA0BR;AA2CL,MAAM,cAAc,GAAG,QAAQ,CAAC,OAAO,CAAC;IACpC,QAAQ,EAAE,WAAW;IACrB,QAAQ;IACR,MAAM;CACT,CAAC,CAAC;AAEH,YAAY,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,cAAc,EAAE,CAAC,CAAC"}
@@ -1,2 +1,2 @@
1
1
  import type { TableRow } from '.';
2
- export declare const template: import("@microsoft/fast-element").ViewTemplate<TableRow<import("../../types").TableDataRecord>, any>;
2
+ export declare const template: import("@microsoft/fast-element").ViewTemplate<TableRow<import(".").TableDataRecord>, any>;
@@ -1,12 +1,16 @@
1
1
  import { FoundationElement } from '@microsoft/fast-foundation';
2
2
  import { TableColumn } from '../table-column/base';
3
- import type { TableActionMenuToggleEventDetail, TableRecord, TableRowState, TableValidity } from './types';
3
+ import { TableActionMenuToggleEventDetail, TableRecord, TableValidity } from './types';
4
4
  import { Virtualizer } from './models/virtualizer';
5
5
  declare global {
6
6
  interface HTMLElementTagNameMap {
7
7
  'nimble-table': Table;
8
8
  }
9
9
  }
10
+ interface TableRowState<TData extends TableRecord = TableRecord> {
11
+ record: TData;
12
+ id: string;
13
+ }
10
14
  /**
11
15
  * A nimble-styled table.
12
16
  */
@@ -45,6 +49,10 @@ export declare class Table<TData extends TableRecord = TableRecord> extends Foun
45
49
  * @internal
46
50
  */
47
51
  readonly virtualizer: Virtualizer<TData>;
52
+ /**
53
+ * @internal
54
+ */
55
+ firstSortedColumn?: TableColumn;
48
56
  private readonly table;
49
57
  private options;
50
58
  private readonly tableValidator;
@@ -70,10 +78,14 @@ export declare class Table<TData extends TableRecord = TableRecord> extends Foun
70
78
  private removeColumnObservers;
71
79
  private validateAndObserveColumns;
72
80
  private validateColumnIds;
81
+ private validateColumnSortIndices;
82
+ private getColumnsParticipatingInSorting;
73
83
  private updateColumnsFromChildItems;
74
84
  private setTableData;
75
85
  private refreshRows;
76
86
  private updateTableOptions;
77
- private readonly update;
87
+ private setSortState;
78
88
  private generateTanStackColumns;
79
89
  }
90
+ export declare const tableTag: string;
91
+ export {};
@@ -1,12 +1,14 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { attr, Observable, observable } from '@microsoft/fast-element';
3
3
  import { DesignSystem, FoundationElement } from '@microsoft/fast-foundation';
4
- import { createTable as tanStackCreateTable, getCoreRowModel as tanStackGetCoreRowModel } from '@tanstack/table-core';
4
+ import { createTable as tanStackCreateTable, getCoreRowModel as tanStackGetCoreRowModel, getSortedRowModel as tanStackGetSortedRowModel } from '@tanstack/table-core';
5
5
  import { TableColumn } from '../table-column/base';
6
6
  import { TableValidator } from './models/table-validator';
7
7
  import { styles } from './styles';
8
8
  import { template } from './template';
9
+ import { TableColumnSortDirection } from './types';
9
10
  import { Virtualizer } from './models/virtualizer';
11
+ import { getTanStackSortingFunction } from './models/sort-operations';
10
12
  /**
11
13
  * A nimble-styled table.
12
14
  */
@@ -35,25 +37,14 @@ export class Table extends FoundationElement {
35
37
  this.canRenderRows = true;
36
38
  this.tableValidator = new TableValidator();
37
39
  this.columnNotifiers = [];
38
- this.update = (state) => {
39
- this.table.setOptions(prev => ({
40
- ...prev,
41
- ...this.options,
42
- state,
43
- onStateChange: (updater) => {
44
- const updatedState = typeof updater === 'function'
45
- ? updater(state)
46
- : updater;
47
- this.update(updatedState);
48
- }
49
- }));
50
- };
51
40
  this.options = {
52
41
  data: [],
53
42
  onStateChange: (_) => { },
54
43
  getCoreRowModel: tanStackGetCoreRowModel(),
44
+ getSortedRowModel: tanStackGetSortedRowModel(),
55
45
  columns: [],
56
46
  state: {},
47
+ enableSorting: true,
57
48
  renderFallbackValue: null,
58
49
  autoResetAll: false
59
50
  };
@@ -64,7 +55,6 @@ export class Table extends FoundationElement {
64
55
  return this.tableValidator.getValidity();
65
56
  }
66
57
  setData(newData) {
67
- this.generateTanStackColumns(newData);
68
58
  this.setTableData(newData);
69
59
  }
70
60
  connectedCallback() {
@@ -92,6 +82,14 @@ export class Table extends FoundationElement {
92
82
  if (args === 'columnId') {
93
83
  this.validateColumnIds();
94
84
  }
85
+ else if (args === 'operandDataRecordFieldName'
86
+ || args === 'sortOperation') {
87
+ this.generateTanStackColumns();
88
+ }
89
+ else if (args === 'sortIndex' || args === 'sortDirection') {
90
+ this.validateColumnSortIndices();
91
+ this.setSortState();
92
+ }
95
93
  }
96
94
  }
97
95
  onRowActionMenuBeforeToggle(event) {
@@ -114,6 +112,8 @@ export class Table extends FoundationElement {
114
112
  return;
115
113
  }
116
114
  this.validateAndObserveColumns();
115
+ this.generateTanStackColumns();
116
+ this.setSortState();
117
117
  const slots = new Set();
118
118
  for (const column of this.columns) {
119
119
  if (column.actionMenuSlot) {
@@ -136,11 +136,20 @@ export class Table extends FoundationElement {
136
136
  this.columnNotifiers.push(notifier);
137
137
  }
138
138
  this.validateColumnIds();
139
+ this.validateColumnSortIndices();
139
140
  }
140
141
  validateColumnIds() {
141
142
  this.tableValidator.validateColumnIds(this.columns.map(x => x.columnId));
142
143
  this.canRenderRows = this.checkValidity();
143
144
  }
145
+ validateColumnSortIndices() {
146
+ this.tableValidator.validateColumnSortIndices(this.getColumnsParticipatingInSorting().map(x => x.sortIndex));
147
+ this.canRenderRows = this.checkValidity();
148
+ }
149
+ getColumnsParticipatingInSorting() {
150
+ return this.columns.filter(x => x.sortDirection !== TableColumnSortDirection.none
151
+ && typeof x.sortIndex === 'number');
152
+ }
144
153
  async updateColumnsFromChildItems() {
145
154
  const definedElements = this.childItems.map(async (item) => (item.matches(':not(:defined)')
146
155
  ? customElements.whenDefined(item.localName)
@@ -174,27 +183,47 @@ export class Table extends FoundationElement {
174
183
  this.virtualizer.dataChanged();
175
184
  }
176
185
  updateTableOptions(updatedOptions) {
177
- this.options = { ...this.options, ...updatedOptions };
178
- this.update(this.table.initialState);
186
+ this.options = {
187
+ ...this.options,
188
+ ...updatedOptions,
189
+ state: { ...this.options.state, ...updatedOptions.state }
190
+ };
191
+ this.table.setOptions(this.options);
179
192
  this.refreshRows();
180
193
  }
181
- // Generate columns for TanStack that correspond to all the keys in TData because all operations,
182
- // such as grouping and sorting, will be performed on the data's records, not the values rendered within a cell.
183
- generateTanStackColumns(data) {
184
- if (data.length === 0) {
185
- return;
186
- }
187
- const firstItem = data[0];
188
- const keys = Object.keys(firstItem);
189
- const generatedColumns = keys.map(key => {
194
+ setSortState() {
195
+ const sortedColumns = this.getColumnsParticipatingInSorting().sort((x, y) => x.sortIndex - y.sortIndex);
196
+ this.firstSortedColumn = sortedColumns.length
197
+ ? sortedColumns[0]
198
+ : undefined;
199
+ const tanStackSortingState = sortedColumns.map(column => {
200
+ return {
201
+ id: column.internalUniqueId,
202
+ desc: column.sortDirection
203
+ === TableColumnSortDirection.descending
204
+ };
205
+ });
206
+ this.updateTableOptions({
207
+ state: {
208
+ sorting: tanStackSortingState
209
+ }
210
+ });
211
+ }
212
+ generateTanStackColumns() {
213
+ const generatedColumns = this.columns.map(column => {
190
214
  const columnDef = {
191
- id: key,
192
- accessorKey: key,
193
- header: key
215
+ id: column.internalUniqueId,
216
+ accessorKey: column.operandDataRecordFieldName,
217
+ sortingFn: getTanStackSortingFunction(column.sortOperation)
194
218
  };
195
219
  return columnDef;
196
220
  });
197
- this.updateTableOptions({ columns: generatedColumns });
221
+ this.updateTableOptions({
222
+ // Force TanStack to detect a data update because a columns's accessor is
223
+ // referenced when creating a new row model.
224
+ data: [...this.table.options.data],
225
+ columns: generatedColumns
226
+ });
198
227
  }
199
228
  }
200
229
  __decorate([
@@ -218,10 +247,14 @@ __decorate([
218
247
  __decorate([
219
248
  observable
220
249
  ], Table.prototype, "canRenderRows", void 0);
250
+ __decorate([
251
+ observable
252
+ ], Table.prototype, "firstSortedColumn", void 0);
221
253
  const nimbleTable = Table.compose({
222
254
  baseName: 'table',
223
255
  template,
224
256
  styles
225
257
  });
226
258
  DesignSystem.getOrCreate().withPrefix('nimble').register(nimbleTable());
259
+ export const tableTag = DesignSystem.tagFor(Table);
227
260
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/table/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/table/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { SortingFnOption as TanStackSortingFnOption } from '@tanstack/table-core';
2
+ import { TableColumnSortOperation } from '../../table-column/base/types';
3
+ /**
4
+ * Returns the sorting function for TanStack to use based on the specified
5
+ * TableColumnSortOperation
6
+ */
7
+ export declare function getTanStackSortingFunction<TData>(sortOperation: TableColumnSortOperation): TanStackSortingFnOption<TData>;
@@ -0,0 +1,36 @@
1
+ import { sortingFns as TanStackSortingFns } from '@tanstack/table-core';
2
+ import { TableColumnSortOperation } from '../../table-column/base/types';
3
+ /**
4
+ * Returns the sorting function for TanStack to use based on the specified
5
+ * TableColumnSortOperation
6
+ */
7
+ export function getTanStackSortingFunction(sortOperation) {
8
+ switch (sortOperation) {
9
+ case TableColumnSortOperation.basic:
10
+ return TanStackSortingFns.basic;
11
+ case TableColumnSortOperation.localeAwareCaseSensitive:
12
+ return localeAwareCaseSensitiveSortFunction;
13
+ default:
14
+ return TanStackSortingFns.basic;
15
+ }
16
+ }
17
+ /**
18
+ * A function to perform locale-aware and case-senstitive sorting of two rows from
19
+ * TanStack for a given column. The function sorts `undefined` followed by `null`
20
+ * before all defined strings.
21
+ */
22
+ function localeAwareCaseSensitiveSortFunction(rowA, rowB, columnId) {
23
+ const valueA = rowA.getValue(columnId);
24
+ const valueB = rowB.getValue(columnId);
25
+ if (typeof valueA === 'string' && typeof valueB === 'string') {
26
+ return valueA.localeCompare(valueB);
27
+ }
28
+ if (valueA === valueB) {
29
+ return 0;
30
+ }
31
+ if (valueA === undefined || (valueA === null && valueB !== undefined)) {
32
+ return -1;
33
+ }
34
+ return 1;
35
+ }
36
+ //# sourceMappingURL=sort-operations.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sort-operations.js","sourceRoot":"","sources":["../../../../src/table/models/sort-operations.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,UAAU,IAAI,kBAAkB,EAEnC,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAEzE;;;GAGG;AACH,MAAM,UAAU,0BAA0B,CACtC,aAAuC;IAEvC,QAAQ,aAAa,EAAE;QACnB,KAAK,wBAAwB,CAAC,KAAK;YAC/B,OAAO,kBAAkB,CAAC,KAAK,CAAC;QACpC,KAAK,wBAAwB,CAAC,wBAAwB;YAClD,OAAO,oCAAoC,CAAC;QAChD;YACI,OAAO,kBAAkB,CAAC,KAAK,CAAC;KACvC;AACL,CAAC;AAED;;;;GAIG;AACH,SAAS,oCAAoC,CACzC,IAAwB,EACxB,IAAwB,EACxB,QAAgB;IAEhB,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAA4B,QAAQ,CAAC,CAAC;IAClE,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAA4B,QAAQ,CAAC,CAAC;IAElE,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE;QAC1D,OAAO,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;KACvC;IACD,IAAI,MAAM,KAAK,MAAM,EAAE;QACnB,OAAO,CAAC,CAAC;KACZ;IACD,IAAI,MAAM,KAAK,SAAS,IAAI,CAAC,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,SAAS,CAAC,EAAE;QACnE,OAAO,CAAC,CAAC,CAAC;KACb;IACD,OAAO,CAAC,CAAC;AACb,CAAC"}
@@ -9,8 +9,10 @@ export declare class TableValidator<TData extends TableRecord> {
9
9
  private invalidRecordId;
10
10
  private duplicateColumnId;
11
11
  private missingColumnId;
12
+ private duplicateSortIndex;
12
13
  getValidity(): TableValidity;
13
14
  isValid(): boolean;
14
15
  validateRecordIds(data: TData[], idFieldName: string | undefined): boolean;
15
16
  validateColumnIds(columnIds: (string | undefined)[]): boolean;
17
+ validateColumnSortIndices(sortIndices: number[]): boolean;
16
18
  }
@@ -9,6 +9,7 @@ export class TableValidator {
9
9
  this.invalidRecordId = false;
10
10
  this.duplicateColumnId = false;
11
11
  this.missingColumnId = false;
12
+ this.duplicateSortIndex = false;
12
13
  }
13
14
  getValidity() {
14
15
  return {
@@ -16,7 +17,8 @@ export class TableValidator {
16
17
  missingRecordId: this.missingRecordId,
17
18
  invalidRecordId: this.invalidRecordId,
18
19
  duplicateColumnId: this.duplicateColumnId,
19
- missingColumnId: this.missingColumnId
20
+ missingColumnId: this.missingColumnId,
21
+ duplicateSortIndex: this.duplicateSortIndex
20
22
  };
21
23
  }
22
24
  isValid() {
@@ -70,5 +72,16 @@ export class TableValidator {
70
72
  }
71
73
  return !this.missingColumnId && !this.duplicateColumnId;
72
74
  }
75
+ validateColumnSortIndices(sortIndices) {
76
+ this.duplicateSortIndex = false;
77
+ const sortIndexSet = new Set();
78
+ for (const sortIndex of sortIndices) {
79
+ if (sortIndexSet.has(sortIndex)) {
80
+ this.duplicateSortIndex = true;
81
+ }
82
+ sortIndexSet.add(sortIndex);
83
+ }
84
+ return !this.duplicateSortIndex;
85
+ }
73
86
  }
74
87
  //# sourceMappingURL=table-validator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"table-validator.js","sourceRoot":"","sources":["../../../../src/table/models/table-validator.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,OAAO,cAAc;IAA3B;QACY,sBAAiB,GAAG,KAAK,CAAC;QAC1B,oBAAe,GAAG,KAAK,CAAC;QACxB,oBAAe,GAAG,KAAK,CAAC;QACxB,sBAAiB,GAAG,KAAK,CAAC;QAC1B,oBAAe,GAAG,KAAK,CAAC;IAgFpC,CAAC;IA9EU,WAAW;QACd,OAAO;YACH,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,eAAe,EAAE,IAAI,CAAC,eAAe;SACxC,CAAC;IACN,CAAC;IAEM,OAAO;QACV,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC;IACrE,CAAC;IAEM,iBAAiB,CACpB,IAAa,EACb,WAA+B;QAE/B,2CAA2C;QAC3C,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAE7B,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE;YACjC,OAAO,IAAI,CAAC;SACf;QAED,MAAM,GAAG,GAAG,IAAI,GAAG,EAAU,CAAC;QAC9B,KAAK,MAAM,MAAM,IAAI,IAAI,EAAE;YACvB,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,EAAE,WAAW,CAAC,EAAE;gBAC5D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;gBAC5B,SAAS;aACZ;YAED,MAAM,EAAE,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;YAC/B,IAAI,OAAO,EAAE,KAAK,QAAQ,EAAE;gBACxB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;gBAC5B,SAAS;aACZ;YAED,IAAI,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBACb,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;aACjC;YACD,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;SACf;QAED,OAAO,CACH,CAAC,IAAI,CAAC,eAAe;eAClB,CAAC,IAAI,CAAC,eAAe;eACrB,CAAC,IAAI,CAAC,iBAAiB,CAC7B,CAAC;IACN,CAAC;IAEM,iBAAiB,CAAC,SAAiC;QACtD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAE/B,MAAM,iBAAiB,GAAG,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QAEnD,IAAI,CAAC,iBAAiB,EAAE;YACpB,OAAO,IAAI,CAAC;SACf;QAED,MAAM,KAAK,GAAG,IAAI,GAAG,EAAU,CAAC;QAChC,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;YAC9B,IAAI,CAAC,QAAQ,EAAE;gBACX,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;gBAC5B,SAAS;aACZ;YAED,IAAI,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;gBACrB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;aACjC;YACD,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;SACvB;QAED,OAAO,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC;IAC5D,CAAC;CACJ"}
1
+ {"version":3,"file":"table-validator.js","sourceRoot":"","sources":["../../../../src/table/models/table-validator.ts"],"names":[],"mappings":"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"}
@@ -2,6 +2,7 @@ import { children, elements, html, ref, repeat, when } from '@microsoft/fast-ele
2
2
  import { DesignSystem } from '@microsoft/fast-foundation';
3
3
  import { TableHeader } from './components/header';
4
4
  import { TableRow } from './components/row';
5
+ import { TableColumnSortDirection } from './types';
5
6
  // prettier-ignore
6
7
  export const template = html `
7
8
  <template role="table" ${children({ property: 'childItems', filter: elements() })}>
@@ -10,7 +11,11 @@ export const template = html `
10
11
  <div class="header-row" role="row">
11
12
  ${repeat(x => x.columns, html `
12
13
  ${when(x => !x.columnHidden, html `
13
- <${DesignSystem.tagFor(TableHeader)} class="header">
14
+ <${DesignSystem.tagFor(TableHeader)}
15
+ class="header"
16
+ sort-direction="${x => (typeof x.sortIndex === 'number' ? x.sortDirection : TableColumnSortDirection.none)}"
17
+ ?first-sorted-column="${(x, c) => x === c.parent.firstSortedColumn}"
18
+ >
14
19
  <slot name="${x => x.slot}"></slot>
15
20
  </${DesignSystem.tagFor(TableHeader)}>
16
21
  `)}
@@ -1 +1 @@
1
- {"version":3,"file":"template.js","sourceRoot":"","sources":["../../../src/table/template.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,QAAQ,EACR,QAAQ,EACR,IAAI,EACJ,GAAG,EACH,MAAM,EACN,IAAI,EACP,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAG1D,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAI5C,kBAAkB;AAClB,MAAM,CAAC,MAAM,QAAQ,GAAG,IAAI,CAAO;6BACN,QAAQ,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,CAAC;;;;sBAI/D,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAa;0BACpC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,IAAI,CAAa;+BACvC,YAAY,CAAC,MAAM,CAAC,WAAW,CAAC;8CACjB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI;gCACzB,YAAY,CAAC,MAAM,CAAC,WAAW,CAAC;yBACvC,CAAC;qBACL,CAAC;yEACmD,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,0BAA0B;;;0CAG5E,GAAG,CAAC,UAAU,CAAC;2DACE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,aAAa;+EACZ,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,WAAW,CAAC,mBAAmB,KAAK;sBACvG,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,IAAI,CAAO;0BAC1D,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,YAAY,EAAE,IAAI,CAAoB;+BAC3D,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC;;6CAEf,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE;+CACvC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,MAAM;4CAChD,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO;iEACL,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,2BAA2B,CAAC,CAAC,CAAC,KAAsD,CAAC;2DAC9G,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC,CAAC,KAAsD,CAAC;iDAC5G,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI;;8BAE9B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAE,CAAC,CAAC,MAAgB,CAAC,sBAAsB,KAAM,CAAC,CAAC,MAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,IAAI,CAAoB;kCAC9H,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAE,CAAC,CAAC,MAAgB,CAAC,eAAe,EAAE,IAAI,CAAe;;gDAE3D,CAAC,CAAC,EAAE,CAAC,CAAC;gDACN,CAAC,CAAC,EAAE,CAAC,mBAAmB,CAAC,EAAE;;iCAE1C,CAAC;6BACL,CAAC;gCACE,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC;yBACpC,CAAC;qBACL,CAAC;;;;;CAKrB,CAAC"}
1
+ {"version":3,"file":"template.js","sourceRoot":"","sources":["../../../src/table/template.ts"],"names":[],"mappings":"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"}
@@ -16,32 +16,16 @@ export declare type TableFieldValue = string | number | boolean | null | undefin
16
16
  export interface TableRecord {
17
17
  [key: TableFieldName]: TableFieldValue;
18
18
  }
19
- /** Represents a single row (element) in the Table's data */
20
- export interface TableDataRecord extends TableRecord {
21
- }
22
- /**
23
- * An object whose fields are defined by a particular TableColumn, which is used by the column's
24
- * cellTemplate implementation.
25
- */
26
- export interface TableCellRecord extends TableRecord {
27
- }
28
19
  export declare type TableStringField<FieldName extends TableFieldName> = {
29
20
  [name in FieldName]: string | null | undefined;
30
21
  };
31
- export interface TableCellState<TCellRecord extends TableCellRecord = TableCellRecord, TColumnConfig = unknown> {
32
- cellRecord: TCellRecord;
33
- columnConfig: TColumnConfig;
34
- }
35
22
  export interface TableValidity {
36
23
  readonly duplicateRecordId: boolean;
37
24
  readonly missingRecordId: boolean;
38
25
  readonly invalidRecordId: boolean;
39
26
  readonly duplicateColumnId: boolean;
40
27
  readonly missingColumnId: boolean;
41
- }
42
- export interface TableRowState<TData extends TableRecord = TableRecord> {
43
- record: TData;
44
- id: string;
28
+ readonly duplicateSortIndex: boolean;
45
29
  }
46
30
  export interface TableActionMenuToggleEventDetail {
47
31
  newState: boolean;
@@ -49,3 +33,12 @@ export interface TableActionMenuToggleEventDetail {
49
33
  recordIds: string[];
50
34
  columnId?: string;
51
35
  }
36
+ /**
37
+ * The possible directions a table column can be sorted in.
38
+ */
39
+ export declare const TableColumnSortDirection: {
40
+ readonly none: undefined;
41
+ readonly ascending: "ascending";
42
+ readonly descending: "descending";
43
+ };
44
+ export declare type TableColumnSortDirection = (typeof TableColumnSortDirection)[keyof typeof TableColumnSortDirection];
@@ -1,2 +1,9 @@
1
- export {};
1
+ /**
2
+ * The possible directions a table column can be sorted in.
3
+ */
4
+ export const TableColumnSortDirection = {
5
+ none: undefined,
6
+ ascending: 'ascending',
7
+ descending: 'descending'
8
+ };
2
9
  //# sourceMappingURL=types.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/table/types.ts"],"names":[],"mappings":""}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/table/types.ts"],"names":[],"mappings":"AAyCA;;GAEG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAAG;IACpC,IAAI,EAAE,SAAS;IACf,SAAS,EAAE,WAAW;IACtB,UAAU,EAAE,YAAY;CAClB,CAAC"}