@ni/fast-foundation 0.0.2

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 (416) hide show
  1. package/README.md +58 -0
  2. package/dist/dts/accordion/accordion.d.ts +65 -0
  3. package/dist/dts/accordion/accordion.template.d.ts +8 -0
  4. package/dist/dts/accordion/index.d.ts +2 -0
  5. package/dist/dts/accordion-item/accordion-item.d.ts +76 -0
  6. package/dist/dts/accordion-item/accordion-item.template.d.ts +8 -0
  7. package/dist/dts/accordion-item/index.d.ts +2 -0
  8. package/dist/dts/anchor/anchor.d.ts +128 -0
  9. package/dist/dts/anchor/anchor.template.d.ts +8 -0
  10. package/dist/dts/anchor/index.d.ts +2 -0
  11. package/dist/dts/anchored-region/anchored-region-config.d.ts +117 -0
  12. package/dist/dts/anchored-region/anchored-region.d.ts +389 -0
  13. package/dist/dts/anchored-region/anchored-region.template.d.ts +8 -0
  14. package/dist/dts/anchored-region/index.d.ts +3 -0
  15. package/dist/dts/avatar/avatar.d.ts +62 -0
  16. package/dist/dts/avatar/avatar.template.d.ts +8 -0
  17. package/dist/dts/avatar/index.d.ts +2 -0
  18. package/dist/dts/badge/badge.d.ts +36 -0
  19. package/dist/dts/badge/badge.template.d.ts +8 -0
  20. package/dist/dts/badge/index.d.ts +2 -0
  21. package/dist/dts/breadcrumb/breadcrumb.d.ts +27 -0
  22. package/dist/dts/breadcrumb/breadcrumb.template.d.ts +8 -0
  23. package/dist/dts/breadcrumb/index.d.ts +2 -0
  24. package/dist/dts/breadcrumb-item/breadcrumb-item.d.ts +36 -0
  25. package/dist/dts/breadcrumb-item/breadcrumb-item.template.d.ts +8 -0
  26. package/dist/dts/breadcrumb-item/index.d.ts +2 -0
  27. package/dist/dts/button/button.d.ts +167 -0
  28. package/dist/dts/button/button.form-associated.d.ts +16 -0
  29. package/dist/dts/button/button.template.d.ts +8 -0
  30. package/dist/dts/button/index.d.ts +2 -0
  31. package/dist/dts/calendar/calendar.d.ts +178 -0
  32. package/dist/dts/calendar/calendar.template.d.ts +58 -0
  33. package/dist/dts/calendar/date-formatter.d.ts +124 -0
  34. package/dist/dts/calendar/index.d.ts +3 -0
  35. package/dist/dts/card/card.d.ts +10 -0
  36. package/dist/dts/card/card.template.d.ts +8 -0
  37. package/dist/dts/card/index.d.ts +2 -0
  38. package/dist/dts/checkbox/checkbox.d.ts +58 -0
  39. package/dist/dts/checkbox/checkbox.form-associated.d.ts +16 -0
  40. package/dist/dts/checkbox/checkbox.template.d.ts +8 -0
  41. package/dist/dts/checkbox/index.d.ts +2 -0
  42. package/dist/dts/combobox/combobox.d.ts +341 -0
  43. package/dist/dts/combobox/combobox.form-associated.d.ts +16 -0
  44. package/dist/dts/combobox/combobox.options.d.ts +15 -0
  45. package/dist/dts/combobox/combobox.template.d.ts +8 -0
  46. package/dist/dts/combobox/index.d.ts +3 -0
  47. package/dist/dts/data-grid/data-grid-cell.d.ts +62 -0
  48. package/dist/dts/data-grid/data-grid-cell.template.d.ts +9 -0
  49. package/dist/dts/data-grid/data-grid-row.d.ts +119 -0
  50. package/dist/dts/data-grid/data-grid-row.template.d.ts +10 -0
  51. package/dist/dts/data-grid/data-grid.d.ts +218 -0
  52. package/dist/dts/data-grid/data-grid.options.d.ts +49 -0
  53. package/dist/dts/data-grid/data-grid.template.d.ts +10 -0
  54. package/dist/dts/data-grid/index.d.ts +6 -0
  55. package/dist/dts/design-system/component-presentation.d.ts +66 -0
  56. package/dist/dts/design-system/design-system.d.ts +104 -0
  57. package/dist/dts/design-system/index.d.ts +3 -0
  58. package/dist/dts/design-system/registration-context.d.ts +106 -0
  59. package/dist/dts/design-token/custom-property-manager.d.ts +35 -0
  60. package/dist/dts/design-token/design-token.d.ts +139 -0
  61. package/dist/dts/design-token/interfaces.d.ts +31 -0
  62. package/dist/dts/di/di.d.ts +858 -0
  63. package/dist/dts/di/index.d.ts +1 -0
  64. package/dist/dts/dialog/dialog.d.ts +153 -0
  65. package/dist/dts/dialog/dialog.template.d.ts +8 -0
  66. package/dist/dts/dialog/index.d.ts +2 -0
  67. package/dist/dts/directives/reflect-attributes.d.ts +18 -0
  68. package/dist/dts/disclosure/disclosure.d.ts +59 -0
  69. package/dist/dts/disclosure/disclosure.template.d.ts +8 -0
  70. package/dist/dts/disclosure/index.d.ts +2 -0
  71. package/dist/dts/divider/divider.d.ts +28 -0
  72. package/dist/dts/divider/divider.options.d.ts +19 -0
  73. package/dist/dts/divider/divider.template.d.ts +8 -0
  74. package/dist/dts/divider/index.d.ts +2 -0
  75. package/dist/dts/flipper/flipper.d.ts +57 -0
  76. package/dist/dts/flipper/flipper.options.d.ts +13 -0
  77. package/dist/dts/flipper/flipper.template.d.ts +8 -0
  78. package/dist/dts/flipper/index.d.ts +2 -0
  79. package/dist/dts/form-associated/form-associated.d.ts +177 -0
  80. package/dist/dts/form-associated/index.d.ts +1 -0
  81. package/dist/dts/foundation-element/foundation-element.d.ts +120 -0
  82. package/dist/dts/foundation-element/index.d.ts +1 -0
  83. package/dist/dts/horizontal-scroll/horizontal-scroll.d.ts +242 -0
  84. package/dist/dts/horizontal-scroll/horizontal-scroll.template.d.ts +7 -0
  85. package/dist/dts/horizontal-scroll/index.d.ts +2 -0
  86. package/dist/dts/index-rollup.d.ts +2 -0
  87. package/dist/dts/index.d.ts +53 -0
  88. package/dist/dts/interfaces.d.ts +4 -0
  89. package/dist/dts/listbox/index.d.ts +3 -0
  90. package/dist/dts/listbox/listbox.d.ts +314 -0
  91. package/dist/dts/listbox/listbox.element.d.ts +223 -0
  92. package/dist/dts/listbox/listbox.template.d.ts +8 -0
  93. package/dist/dts/listbox-option/index.d.ts +2 -0
  94. package/dist/dts/listbox-option/listbox-option.d.ts +176 -0
  95. package/dist/dts/listbox-option/listbox-option.template.d.ts +8 -0
  96. package/dist/dts/menu/index.d.ts +2 -0
  97. package/dist/dts/menu/menu.d.ts +78 -0
  98. package/dist/dts/menu/menu.template.d.ts +8 -0
  99. package/dist/dts/menu-item/index.d.ts +2 -0
  100. package/dist/dts/menu-item/menu-item.d.ts +160 -0
  101. package/dist/dts/menu-item/menu-item.options.d.ts +29 -0
  102. package/dist/dts/menu-item/menu-item.template.d.ts +10 -0
  103. package/dist/dts/number-field/index.d.ts +2 -0
  104. package/dist/dts/number-field/number-field.d.ts +227 -0
  105. package/dist/dts/number-field/number-field.form-associated.d.ts +16 -0
  106. package/dist/dts/number-field/number-field.template.d.ts +8 -0
  107. package/dist/dts/patterns/aria-global.d.ts +189 -0
  108. package/dist/dts/patterns/index.d.ts +2 -0
  109. package/dist/dts/patterns/start-end.d.ts +65 -0
  110. package/dist/dts/picker/index.d.ts +10 -0
  111. package/dist/dts/picker/picker-list-item.d.ts +38 -0
  112. package/dist/dts/picker/picker-list-item.template.d.ts +8 -0
  113. package/dist/dts/picker/picker-list.d.ts +8 -0
  114. package/dist/dts/picker/picker-list.template.d.ts +8 -0
  115. package/dist/dts/picker/picker-menu-option.d.ts +37 -0
  116. package/dist/dts/picker/picker-menu-option.template.d.ts +8 -0
  117. package/dist/dts/picker/picker-menu.d.ts +46 -0
  118. package/dist/dts/picker/picker-menu.template.d.ts +8 -0
  119. package/dist/dts/picker/picker.d.ts +390 -0
  120. package/dist/dts/picker/picker.form-associated.d.ts +16 -0
  121. package/dist/dts/picker/picker.template.d.ts +8 -0
  122. package/dist/dts/progress/base-progress.d.ts +71 -0
  123. package/dist/dts/progress/index.d.ts +2 -0
  124. package/dist/dts/progress/progress.template.d.ts +8 -0
  125. package/dist/dts/progress-ring/index.d.ts +1 -0
  126. package/dist/dts/progress-ring/progress-ring.template.d.ts +8 -0
  127. package/dist/dts/radio/index.d.ts +2 -0
  128. package/dist/dts/radio/radio.d.ts +70 -0
  129. package/dist/dts/radio/radio.form-associated.d.ts +16 -0
  130. package/dist/dts/radio/radio.template.d.ts +8 -0
  131. package/dist/dts/radio-group/index.d.ts +2 -0
  132. package/dist/dts/radio-group/radio-group.d.ts +101 -0
  133. package/dist/dts/radio-group/radio-group.template.d.ts +8 -0
  134. package/dist/dts/search/index.d.ts +2 -0
  135. package/dist/dts/search/search.d.ts +162 -0
  136. package/dist/dts/search/search.form-associated.d.ts +16 -0
  137. package/dist/dts/search/search.template.d.ts +8 -0
  138. package/dist/dts/select/index.d.ts +3 -0
  139. package/dist/dts/select/select.d.ts +289 -0
  140. package/dist/dts/select/select.form-associated.d.ts +16 -0
  141. package/dist/dts/select/select.options.d.ts +13 -0
  142. package/dist/dts/select/select.template.d.ts +8 -0
  143. package/dist/dts/skeleton/index.d.ts +2 -0
  144. package/dist/dts/skeleton/skeleton.d.ts +47 -0
  145. package/dist/dts/skeleton/skeleton.template.d.ts +8 -0
  146. package/dist/dts/slider/index.d.ts +2 -0
  147. package/dist/dts/slider/slider-utilities.d.ts +5 -0
  148. package/dist/dts/slider/slider.d.ts +230 -0
  149. package/dist/dts/slider/slider.form-associated.d.ts +16 -0
  150. package/dist/dts/slider/slider.template.d.ts +8 -0
  151. package/dist/dts/slider-label/index.d.ts +2 -0
  152. package/dist/dts/slider-label/slider-label.d.ts +81 -0
  153. package/dist/dts/slider-label/slider-label.template.d.ts +8 -0
  154. package/dist/dts/switch/index.d.ts +2 -0
  155. package/dist/dts/switch/switch.d.ts +60 -0
  156. package/dist/dts/switch/switch.form-associated.d.ts +16 -0
  157. package/dist/dts/switch/switch.template.d.ts +8 -0
  158. package/dist/dts/tab/index.d.ts +2 -0
  159. package/dist/dts/tab/tab.d.ts +17 -0
  160. package/dist/dts/tab/tab.template.d.ts +8 -0
  161. package/dist/dts/tab-panel/index.d.ts +2 -0
  162. package/dist/dts/tab-panel/tab-panel.d.ts +10 -0
  163. package/dist/dts/tab-panel/tab-panel.template.d.ts +8 -0
  164. package/dist/dts/tabs/index.d.ts +2 -0
  165. package/dist/dts/tabs/tabs.d.ts +140 -0
  166. package/dist/dts/tabs/tabs.template.d.ts +8 -0
  167. package/dist/dts/test-utilities/fixture.d.ts +89 -0
  168. package/dist/dts/test-utilities/timeout.d.ts +4 -0
  169. package/dist/dts/text-area/index.d.ts +2 -0
  170. package/dist/dts/text-area/text-area.d.ts +149 -0
  171. package/dist/dts/text-area/text-area.form-associated.d.ts +16 -0
  172. package/dist/dts/text-area/text-area.options.d.ts +27 -0
  173. package/dist/dts/text-area/text-area.template.d.ts +8 -0
  174. package/dist/dts/text-field/index.d.ts +2 -0
  175. package/dist/dts/text-field/text-field.d.ts +166 -0
  176. package/dist/dts/text-field/text-field.form-associated.d.ts +16 -0
  177. package/dist/dts/text-field/text-field.options.d.ts +31 -0
  178. package/dist/dts/text-field/text-field.template.d.ts +8 -0
  179. package/dist/dts/toolbar/index.d.ts +2 -0
  180. package/dist/dts/toolbar/toolbar.d.ts +167 -0
  181. package/dist/dts/toolbar/toolbar.template.d.ts +9 -0
  182. package/dist/dts/tooltip/index.d.ts +2 -0
  183. package/dist/dts/tooltip/tooltip.d.ts +239 -0
  184. package/dist/dts/tooltip/tooltip.options.d.ts +69 -0
  185. package/dist/dts/tooltip/tooltip.template.d.ts +8 -0
  186. package/dist/dts/tree-item/index.d.ts +2 -0
  187. package/dist/dts/tree-item/tree-item.d.ts +141 -0
  188. package/dist/dts/tree-item/tree-item.template.d.ts +8 -0
  189. package/dist/dts/tree-view/index.d.ts +2 -0
  190. package/dist/dts/tree-view/tree-view.d.ts +99 -0
  191. package/dist/dts/tree-view/tree-view.template.d.ts +8 -0
  192. package/dist/dts/utilities/apply-mixins.d.ts +6 -0
  193. package/dist/dts/utilities/composed-contains.d.ts +12 -0
  194. package/dist/dts/utilities/composed-parent.d.ts +10 -0
  195. package/dist/dts/utilities/direction.d.ts +7 -0
  196. package/dist/dts/utilities/index.d.ts +8 -0
  197. package/dist/dts/utilities/intersection-service.d.ts +30 -0
  198. package/dist/dts/utilities/match-media-stylesheet-behavior.d.ts +124 -0
  199. package/dist/dts/utilities/property-stylesheet-behavior.d.ts +38 -0
  200. package/dist/dts/utilities/resize-observer.d.ts +31 -0
  201. package/dist/dts/utilities/root-active-element.d.ts +1 -0
  202. package/dist/dts/utilities/style/disabled.d.ts +5 -0
  203. package/dist/dts/utilities/style/display.d.ts +17 -0
  204. package/dist/dts/utilities/style/focus.d.ts +8 -0
  205. package/dist/dts/utilities/style/index.d.ts +3 -0
  206. package/dist/dts/utilities/whitespace-filter.d.ts +9 -0
  207. package/dist/esm/accordion/accordion.js +185 -0
  208. package/dist/esm/accordion/accordion.template.js +11 -0
  209. package/dist/esm/accordion/index.js +2 -0
  210. package/dist/esm/accordion-item/accordion-item.js +72 -0
  211. package/dist/esm/accordion-item/accordion-item.template.js +49 -0
  212. package/dist/esm/accordion-item/index.js +2 -0
  213. package/dist/esm/anchor/anchor.js +85 -0
  214. package/dist/esm/anchor/anchor.template.js +47 -0
  215. package/dist/esm/anchor/index.js +2 -0
  216. package/dist/esm/anchored-region/anchored-region-config.js +59 -0
  217. package/dist/esm/anchored-region/anchored-region.js +964 -0
  218. package/dist/esm/anchored-region/anchored-region.template.js +12 -0
  219. package/dist/esm/anchored-region/index.js +3 -0
  220. package/dist/esm/avatar/avatar.js +39 -0
  221. package/dist/esm/avatar/avatar.template.js +23 -0
  222. package/dist/esm/avatar/index.js +2 -0
  223. package/dist/esm/badge/badge.js +40 -0
  224. package/dist/esm/badge/badge.template.js +12 -0
  225. package/dist/esm/badge/index.js +2 -0
  226. package/dist/esm/breadcrumb/breadcrumb.js +70 -0
  227. package/dist/esm/breadcrumb/breadcrumb.template.js +14 -0
  228. package/dist/esm/breadcrumb/index.js +2 -0
  229. package/dist/esm/breadcrumb-item/breadcrumb-item.js +23 -0
  230. package/dist/esm/breadcrumb-item/breadcrumb-item.template.js +24 -0
  231. package/dist/esm/breadcrumb-item/index.js +2 -0
  232. package/dist/esm/button/button.form-associated.js +15 -0
  233. package/dist/esm/button/button.js +183 -0
  234. package/dist/esm/button/button.template.js +51 -0
  235. package/dist/esm/button/index.js +2 -0
  236. package/dist/esm/calendar/calendar.js +280 -0
  237. package/dist/esm/calendar/calendar.template.js +191 -0
  238. package/dist/esm/calendar/date-formatter.js +144 -0
  239. package/dist/esm/calendar/index.js +3 -0
  240. package/dist/esm/card/card.js +10 -0
  241. package/dist/esm/card/card.template.js +8 -0
  242. package/dist/esm/card/index.js +2 -0
  243. package/dist/esm/checkbox/checkbox.form-associated.js +15 -0
  244. package/dist/esm/checkbox/checkbox.js +75 -0
  245. package/dist/esm/checkbox/checkbox.template.js +35 -0
  246. package/dist/esm/checkbox/index.js +2 -0
  247. package/dist/esm/combobox/combobox.form-associated.js +15 -0
  248. package/dist/esm/combobox/combobox.js +587 -0
  249. package/dist/esm/combobox/combobox.options.js +10 -0
  250. package/dist/esm/combobox/combobox.template.js +66 -0
  251. package/dist/esm/combobox/index.js +3 -0
  252. package/dist/esm/data-grid/data-grid-cell.js +229 -0
  253. package/dist/esm/data-grid/data-grid-cell.template.js +23 -0
  254. package/dist/esm/data-grid/data-grid-row.js +203 -0
  255. package/dist/esm/data-grid/data-grid-row.template.js +47 -0
  256. package/dist/esm/data-grid/data-grid.js +440 -0
  257. package/dist/esm/data-grid/data-grid.options.js +31 -0
  258. package/dist/esm/data-grid/data-grid.template.js +36 -0
  259. package/dist/esm/data-grid/index.js +6 -0
  260. package/dist/esm/design-system/component-presentation.js +86 -0
  261. package/dist/esm/design-system/design-system.js +207 -0
  262. package/dist/esm/design-system/index.js +3 -0
  263. package/dist/esm/design-system/registration-context.js +1 -0
  264. package/dist/esm/design-token/custom-property-manager.js +216 -0
  265. package/dist/esm/design-token/design-token.js +657 -0
  266. package/dist/esm/design-token/interfaces.js +1 -0
  267. package/dist/esm/di/di.js +1341 -0
  268. package/dist/esm/di/index.js +1 -0
  269. package/dist/esm/dialog/dialog.js +280 -0
  270. package/dist/esm/dialog/dialog.template.js +30 -0
  271. package/dist/esm/dialog/index.js +2 -0
  272. package/dist/esm/directives/reflect-attributes.js +88 -0
  273. package/dist/esm/disclosure/disclosure.js +72 -0
  274. package/dist/esm/disclosure/disclosure.template.js +20 -0
  275. package/dist/esm/disclosure/index.js +2 -0
  276. package/dist/esm/divider/divider.js +39 -0
  277. package/dist/esm/divider/divider.options.js +14 -0
  278. package/dist/esm/divider/divider.template.js +8 -0
  279. package/dist/esm/divider/index.js +2 -0
  280. package/dist/esm/flipper/flipper.js +65 -0
  281. package/dist/esm/flipper/flipper.options.js +8 -0
  282. package/dist/esm/flipper/flipper.template.js +30 -0
  283. package/dist/esm/flipper/index.js +2 -0
  284. package/dist/esm/form-associated/form-associated.js +464 -0
  285. package/dist/esm/form-associated/index.js +1 -0
  286. package/dist/esm/foundation-element/foundation-element.js +132 -0
  287. package/dist/esm/foundation-element/index.js +1 -0
  288. package/dist/esm/horizontal-scroll/horizontal-scroll.js +380 -0
  289. package/dist/esm/horizontal-scroll/horizontal-scroll.template.js +62 -0
  290. package/dist/esm/horizontal-scroll/index.js +2 -0
  291. package/dist/esm/index-rollup.js +2 -0
  292. package/dist/esm/index.js +54 -0
  293. package/dist/esm/interfaces.js +1 -0
  294. package/dist/esm/listbox/index.js +3 -0
  295. package/dist/esm/listbox/listbox.element.js +448 -0
  296. package/dist/esm/listbox/listbox.js +528 -0
  297. package/dist/esm/listbox/listbox.template.js +27 -0
  298. package/dist/esm/listbox-option/index.js +2 -0
  299. package/dist/esm/listbox-option/listbox-option.js +200 -0
  300. package/dist/esm/listbox-option/listbox-option.template.js +25 -0
  301. package/dist/esm/menu/index.js +2 -0
  302. package/dist/esm/menu/menu.js +290 -0
  303. package/dist/esm/menu/menu.template.js +15 -0
  304. package/dist/esm/menu-item/index.js +2 -0
  305. package/dist/esm/menu-item/menu-item.js +251 -0
  306. package/dist/esm/menu-item/menu-item.options.js +26 -0
  307. package/dist/esm/menu-item/menu-item.template.js +78 -0
  308. package/dist/esm/number-field/index.js +2 -0
  309. package/dist/esm/number-field/number-field.form-associated.js +15 -0
  310. package/dist/esm/number-field/number-field.js +288 -0
  311. package/dist/esm/number-field/number-field.template.js +84 -0
  312. package/dist/esm/patterns/aria-global.js +70 -0
  313. package/dist/esm/patterns/index.js +2 -0
  314. package/dist/esm/patterns/start-end.js +84 -0
  315. package/dist/esm/picker/index.js +10 -0
  316. package/dist/esm/picker/picker-list-item.js +71 -0
  317. package/dist/esm/picker/picker-list-item.template.js +17 -0
  318. package/dist/esm/picker/picker-list.js +8 -0
  319. package/dist/esm/picker/picker-list.template.js +13 -0
  320. package/dist/esm/picker/picker-menu-option.js +61 -0
  321. package/dist/esm/picker/picker-menu-option.template.js +16 -0
  322. package/dist/esm/picker/picker-menu.js +59 -0
  323. package/dist/esm/picker/picker-menu.template.js +29 -0
  324. package/dist/esm/picker/picker.form-associated.js +15 -0
  325. package/dist/esm/picker/picker.js +759 -0
  326. package/dist/esm/picker/picker.template.js +97 -0
  327. package/dist/esm/progress/base-progress.js +69 -0
  328. package/dist/esm/progress/index.js +2 -0
  329. package/dist/esm/progress/progress.template.js +31 -0
  330. package/dist/esm/progress-ring/index.js +1 -0
  331. package/dist/esm/progress-ring/progress-ring.template.js +45 -0
  332. package/dist/esm/radio/index.js +2 -0
  333. package/dist/esm/radio/radio.form-associated.js +15 -0
  334. package/dist/esm/radio/radio.js +108 -0
  335. package/dist/esm/radio/radio.template.js +31 -0
  336. package/dist/esm/radio-group/index.js +2 -0
  337. package/dist/esm/radio-group/radio-group.js +390 -0
  338. package/dist/esm/radio-group/radio-group.template.js +29 -0
  339. package/dist/esm/search/index.js +2 -0
  340. package/dist/esm/search/search.form-associated.js +15 -0
  341. package/dist/esm/search/search.js +157 -0
  342. package/dist/esm/search/search.template.js +93 -0
  343. package/dist/esm/select/index.js +3 -0
  344. package/dist/esm/select/select.form-associated.js +15 -0
  345. package/dist/esm/select/select.js +490 -0
  346. package/dist/esm/select/select.options.js +8 -0
  347. package/dist/esm/select/select.template.js +72 -0
  348. package/dist/esm/skeleton/index.js +2 -0
  349. package/dist/esm/skeleton/skeleton.js +35 -0
  350. package/dist/esm/skeleton/skeleton.template.js +20 -0
  351. package/dist/esm/slider/index.js +2 -0
  352. package/dist/esm/slider/slider-utilities.js +11 -0
  353. package/dist/esm/slider/slider.form-associated.js +15 -0
  354. package/dist/esm/slider/slider.js +452 -0
  355. package/dist/esm/slider/slider.template.js +40 -0
  356. package/dist/esm/slider-label/index.js +2 -0
  357. package/dist/esm/slider-label/slider-label.js +158 -0
  358. package/dist/esm/slider-label/slider-label.template.js +24 -0
  359. package/dist/esm/switch/index.js +2 -0
  360. package/dist/esm/switch/switch.form-associated.js +15 -0
  361. package/dist/esm/switch/switch.js +79 -0
  362. package/dist/esm/switch/switch.template.js +37 -0
  363. package/dist/esm/tab/index.js +2 -0
  364. package/dist/esm/tab/tab.js +15 -0
  365. package/dist/esm/tab/tab.template.js +10 -0
  366. package/dist/esm/tab-panel/index.js +2 -0
  367. package/dist/esm/tab-panel/tab-panel.js +10 -0
  368. package/dist/esm/tab-panel/tab-panel.template.js +10 -0
  369. package/dist/esm/tabs/index.js +2 -0
  370. package/dist/esm/tabs/tabs.js +375 -0
  371. package/dist/esm/tabs/tabs.template.js +26 -0
  372. package/dist/esm/test-utilities/fixture.js +90 -0
  373. package/dist/esm/test-utilities/timeout.js +13 -0
  374. package/dist/esm/text-area/index.js +2 -0
  375. package/dist/esm/text-area/text-area.form-associated.js +15 -0
  376. package/dist/esm/text-area/text-area.js +146 -0
  377. package/dist/esm/text-area/text-area.options.js +22 -0
  378. package/dist/esm/text-area/text-area.template.js +64 -0
  379. package/dist/esm/text-field/index.js +2 -0
  380. package/dist/esm/text-field/text-field.form-associated.js +15 -0
  381. package/dist/esm/text-field/text-field.js +183 -0
  382. package/dist/esm/text-field/text-field.options.js +26 -0
  383. package/dist/esm/text-field/text-field.template.js +70 -0
  384. package/dist/esm/toolbar/index.js +2 -0
  385. package/dist/esm/toolbar/toolbar.js +271 -0
  386. package/dist/esm/toolbar/toolbar.template.js +37 -0
  387. package/dist/esm/tooltip/index.js +2 -0
  388. package/dist/esm/tooltip/tooltip.js +512 -0
  389. package/dist/esm/tooltip/tooltip.options.js +63 -0
  390. package/dist/esm/tooltip/tooltip.template.js +32 -0
  391. package/dist/esm/tree-item/index.js +2 -0
  392. package/dist/esm/tree-item/tree-item.js +150 -0
  393. package/dist/esm/tree-item/tree-item.template.js +52 -0
  394. package/dist/esm/tree-view/index.js +2 -0
  395. package/dist/esm/tree-view/tree-view.js +268 -0
  396. package/dist/esm/tree-view/tree-view.template.js +18 -0
  397. package/dist/esm/utilities/apply-mixins.js +20 -0
  398. package/dist/esm/utilities/composed-contains.js +22 -0
  399. package/dist/esm/utilities/composed-parent.js +23 -0
  400. package/dist/esm/utilities/direction.js +10 -0
  401. package/dist/esm/utilities/index.js +8 -0
  402. package/dist/esm/utilities/intersection-service.js +91 -0
  403. package/dist/esm/utilities/match-media-stylesheet-behavior.js +140 -0
  404. package/dist/esm/utilities/property-stylesheet-behavior.js +52 -0
  405. package/dist/esm/utilities/resize-observer.js +5 -0
  406. package/dist/esm/utilities/root-active-element.js +8 -0
  407. package/dist/esm/utilities/style/disabled.js +5 -0
  408. package/dist/esm/utilities/style/display.js +14 -0
  409. package/dist/esm/utilities/style/focus.js +9 -0
  410. package/dist/esm/utilities/style/index.js +3 -0
  411. package/dist/esm/utilities/whitespace-filter.js +13 -0
  412. package/dist/fast-foundation.d.ts +9744 -0
  413. package/dist/fast-foundation.js +19097 -0
  414. package/dist/fast-foundation.min.js +19 -0
  415. package/dist/tsdoc-metadata.json +11 -0
  416. package/package.json +101 -0
@@ -0,0 +1,229 @@
1
+ import { __decorate } from "tslib";
2
+ import { attr, html, observable } from "@ni/fast-element";
3
+ import { eventFocusIn, eventFocusOut, eventKeyDown, keyEnter, keyEscape, keyFunction2, } from "@ni/fast-web-utilities";
4
+ import { FoundationElement } from "../foundation-element/foundation-element.js";
5
+ import { DataGridCellTypes } from "./data-grid.options.js";
6
+ export { DataGridCellTypes };
7
+ const defaultCellContentsTemplate = html `
8
+ <template>
9
+ ${x => x.rowData === null ||
10
+ x.columnDefinition === null ||
11
+ x.columnDefinition.columnDataKey === null
12
+ ? null
13
+ : x.rowData[x.columnDefinition.columnDataKey]}
14
+ </template>
15
+ `;
16
+ const defaultHeaderCellContentsTemplate = html `
17
+ <template>
18
+ ${x => x.columnDefinition === null
19
+ ? null
20
+ : x.columnDefinition.title === undefined
21
+ ? x.columnDefinition.columnDataKey
22
+ : x.columnDefinition.title}
23
+ </template>
24
+ `;
25
+ /**
26
+ * A Data Grid Cell Custom HTML Element.
27
+ *
28
+ * @fires cell-focused - Fires a custom 'cell-focused' event when focus is on the cell or its contents
29
+ * @slot - The default slot for cell contents. The "cell contents template" renders here.
30
+ * @public
31
+ */
32
+ export class DataGridCell extends FoundationElement {
33
+ constructor() {
34
+ super(...arguments);
35
+ /**
36
+ * The type of cell
37
+ *
38
+ * @public
39
+ * @remarks
40
+ * HTML Attribute: cell-type
41
+ */
42
+ this.cellType = DataGridCellTypes.default;
43
+ /**
44
+ * The base data for the parent row
45
+ *
46
+ * @public
47
+ */
48
+ this.rowData = null;
49
+ /**
50
+ * The base data for the column
51
+ *
52
+ * @public
53
+ */
54
+ this.columnDefinition = null;
55
+ this.isActiveCell = false;
56
+ this.customCellView = null;
57
+ this.updateCellStyle = () => {
58
+ this.style.gridColumn = this.gridColumn;
59
+ };
60
+ }
61
+ cellTypeChanged() {
62
+ if (this.$fastController.isConnected) {
63
+ this.updateCellView();
64
+ }
65
+ }
66
+ gridColumnChanged() {
67
+ if (this.$fastController.isConnected) {
68
+ this.updateCellStyle();
69
+ }
70
+ }
71
+ columnDefinitionChanged(oldValue, newValue) {
72
+ if (this.$fastController.isConnected) {
73
+ this.updateCellView();
74
+ }
75
+ }
76
+ /**
77
+ * @internal
78
+ */
79
+ connectedCallback() {
80
+ var _a;
81
+ super.connectedCallback();
82
+ this.addEventListener(eventFocusIn, this.handleFocusin);
83
+ this.addEventListener(eventFocusOut, this.handleFocusout);
84
+ this.addEventListener(eventKeyDown, this.handleKeydown);
85
+ this.style.gridColumn = `${((_a = this.columnDefinition) === null || _a === void 0 ? void 0 : _a.gridColumn) === undefined
86
+ ? 0
87
+ : this.columnDefinition.gridColumn}`;
88
+ this.updateCellView();
89
+ this.updateCellStyle();
90
+ }
91
+ /**
92
+ * @internal
93
+ */
94
+ disconnectedCallback() {
95
+ super.disconnectedCallback();
96
+ this.removeEventListener(eventFocusIn, this.handleFocusin);
97
+ this.removeEventListener(eventFocusOut, this.handleFocusout);
98
+ this.removeEventListener(eventKeyDown, this.handleKeydown);
99
+ this.disconnectCellView();
100
+ }
101
+ handleFocusin(e) {
102
+ if (this.isActiveCell) {
103
+ return;
104
+ }
105
+ this.isActiveCell = true;
106
+ switch (this.cellType) {
107
+ case DataGridCellTypes.columnHeader:
108
+ if (this.columnDefinition !== null &&
109
+ this.columnDefinition.headerCellInternalFocusQueue !== true &&
110
+ typeof this.columnDefinition.headerCellFocusTargetCallback ===
111
+ "function") {
112
+ // move focus to the focus target
113
+ const focusTarget = this.columnDefinition.headerCellFocusTargetCallback(this);
114
+ if (focusTarget !== null) {
115
+ focusTarget.focus();
116
+ }
117
+ }
118
+ break;
119
+ default:
120
+ if (this.columnDefinition !== null &&
121
+ this.columnDefinition.cellInternalFocusQueue !== true &&
122
+ typeof this.columnDefinition.cellFocusTargetCallback === "function") {
123
+ // move focus to the focus target
124
+ const focusTarget = this.columnDefinition.cellFocusTargetCallback(this);
125
+ if (focusTarget !== null) {
126
+ focusTarget.focus();
127
+ }
128
+ }
129
+ break;
130
+ }
131
+ this.$emit("cell-focused", this);
132
+ }
133
+ handleFocusout(e) {
134
+ if (this !== document.activeElement && !this.contains(document.activeElement)) {
135
+ this.isActiveCell = false;
136
+ }
137
+ }
138
+ handleKeydown(e) {
139
+ if (e.defaultPrevented ||
140
+ this.columnDefinition === null ||
141
+ (this.cellType === DataGridCellTypes.default &&
142
+ this.columnDefinition.cellInternalFocusQueue !== true) ||
143
+ (this.cellType === DataGridCellTypes.columnHeader &&
144
+ this.columnDefinition.headerCellInternalFocusQueue !== true)) {
145
+ return;
146
+ }
147
+ switch (e.key) {
148
+ case keyEnter:
149
+ case keyFunction2:
150
+ if (this.contains(document.activeElement) &&
151
+ document.activeElement !== this) {
152
+ return;
153
+ }
154
+ switch (this.cellType) {
155
+ case DataGridCellTypes.columnHeader:
156
+ if (this.columnDefinition.headerCellFocusTargetCallback !==
157
+ undefined) {
158
+ const focusTarget = this.columnDefinition.headerCellFocusTargetCallback(this);
159
+ if (focusTarget !== null) {
160
+ focusTarget.focus();
161
+ }
162
+ e.preventDefault();
163
+ }
164
+ break;
165
+ default:
166
+ if (this.columnDefinition.cellFocusTargetCallback !== undefined) {
167
+ const focusTarget = this.columnDefinition.cellFocusTargetCallback(this);
168
+ if (focusTarget !== null) {
169
+ focusTarget.focus();
170
+ }
171
+ e.preventDefault();
172
+ }
173
+ break;
174
+ }
175
+ break;
176
+ case keyEscape:
177
+ if (this.contains(document.activeElement) &&
178
+ document.activeElement !== this) {
179
+ this.focus();
180
+ e.preventDefault();
181
+ }
182
+ break;
183
+ }
184
+ }
185
+ updateCellView() {
186
+ this.disconnectCellView();
187
+ if (this.columnDefinition === null) {
188
+ return;
189
+ }
190
+ switch (this.cellType) {
191
+ case DataGridCellTypes.columnHeader:
192
+ if (this.columnDefinition.headerCellTemplate !== undefined) {
193
+ this.customCellView = this.columnDefinition.headerCellTemplate.render(this, this);
194
+ }
195
+ else {
196
+ this.customCellView = defaultHeaderCellContentsTemplate.render(this, this);
197
+ }
198
+ break;
199
+ case undefined:
200
+ case DataGridCellTypes.rowHeader:
201
+ case DataGridCellTypes.default:
202
+ if (this.columnDefinition.cellTemplate !== undefined) {
203
+ this.customCellView = this.columnDefinition.cellTemplate.render(this, this);
204
+ }
205
+ else {
206
+ this.customCellView = defaultCellContentsTemplate.render(this, this);
207
+ }
208
+ break;
209
+ }
210
+ }
211
+ disconnectCellView() {
212
+ if (this.customCellView !== null) {
213
+ this.customCellView.dispose();
214
+ this.customCellView = null;
215
+ }
216
+ }
217
+ }
218
+ __decorate([
219
+ attr({ attribute: "cell-type" })
220
+ ], DataGridCell.prototype, "cellType", void 0);
221
+ __decorate([
222
+ attr({ attribute: "grid-column" })
223
+ ], DataGridCell.prototype, "gridColumn", void 0);
224
+ __decorate([
225
+ observable
226
+ ], DataGridCell.prototype, "rowData", void 0);
227
+ __decorate([
228
+ observable
229
+ ], DataGridCell.prototype, "columnDefinition", void 0);
@@ -0,0 +1,23 @@
1
+ import { html } from "@ni/fast-element";
2
+ /**
3
+ * Generates a template for the {@link @ni/fast-foundation#DataGridCell} component using
4
+ * the provided prefix.
5
+ * @public
6
+ */
7
+ export const dataGridCellTemplate = (context, definition) => {
8
+ return html `
9
+ <template
10
+ tabindex="-1"
11
+ role="${x => !x.cellType || x.cellType === "default" ? "gridcell" : x.cellType}"
12
+ class="
13
+ ${x => x.cellType === "columnheader"
14
+ ? "column-header"
15
+ : x.cellType === "rowheader"
16
+ ? "row-header"
17
+ : ""}
18
+ "
19
+ >
20
+ <slot></slot>
21
+ </template>
22
+ `;
23
+ };
@@ -0,0 +1,203 @@
1
+ import { __decorate } from "tslib";
2
+ import { attr, observable, RepeatDirective, } from "@ni/fast-element";
3
+ import { eventFocusOut, eventKeyDown, keyArrowLeft, keyArrowRight, keyEnd, keyHome, } from "@ni/fast-web-utilities";
4
+ import { FoundationElement } from "../foundation-element/foundation-element.js";
5
+ import { DataGridRowTypes } from "./data-grid.options.js";
6
+ /**
7
+ * A Data Grid Row Custom HTML Element.
8
+ *
9
+ * @fires row-focused - Fires a custom 'row-focused' event when focus is on an element (usually a cell or its contents) in the row
10
+ * @slot - The default slot for custom cell elements
11
+ * @public
12
+ */
13
+ export class DataGridRow extends FoundationElement {
14
+ constructor() {
15
+ super(...arguments);
16
+ /**
17
+ * The type of row
18
+ *
19
+ * @public
20
+ * @remarks
21
+ * HTML Attribute: row-type
22
+ */
23
+ this.rowType = DataGridRowTypes.default;
24
+ /**
25
+ * The base data for this row
26
+ *
27
+ * @public
28
+ */
29
+ this.rowData = null;
30
+ /**
31
+ * The column definitions of the row
32
+ *
33
+ * @public
34
+ */
35
+ this.columnDefinitions = null;
36
+ /**
37
+ * Whether focus is on/in a cell within this row.
38
+ *
39
+ * @internal
40
+ */
41
+ this.isActiveRow = false;
42
+ this.cellsRepeatBehavior = null;
43
+ this.cellsPlaceholder = null;
44
+ /**
45
+ * @internal
46
+ */
47
+ this.focusColumnIndex = 0;
48
+ this.refocusOnLoad = false;
49
+ this.updateRowStyle = () => {
50
+ this.style.gridTemplateColumns = this.gridTemplateColumns;
51
+ };
52
+ }
53
+ gridTemplateColumnsChanged() {
54
+ if (this.$fastController.isConnected) {
55
+ this.updateRowStyle();
56
+ }
57
+ }
58
+ rowTypeChanged() {
59
+ if (this.$fastController.isConnected) {
60
+ this.updateItemTemplate();
61
+ }
62
+ }
63
+ rowDataChanged() {
64
+ if (this.rowData !== null && this.isActiveRow) {
65
+ this.refocusOnLoad = true;
66
+ return;
67
+ }
68
+ }
69
+ cellItemTemplateChanged() {
70
+ this.updateItemTemplate();
71
+ }
72
+ headerCellItemTemplateChanged() {
73
+ this.updateItemTemplate();
74
+ }
75
+ /**
76
+ * @internal
77
+ */
78
+ connectedCallback() {
79
+ super.connectedCallback();
80
+ // note that row elements can be reused with a different data object
81
+ // as the parent grid's repeat behavior reacts to changes in the data set.
82
+ if (this.cellsRepeatBehavior === null) {
83
+ this.cellsPlaceholder = document.createComment("");
84
+ this.appendChild(this.cellsPlaceholder);
85
+ this.updateItemTemplate();
86
+ this.cellsRepeatBehavior = new RepeatDirective(x => x.columnDefinitions, x => x.activeCellItemTemplate, { positioning: true }).createBehavior(this.cellsPlaceholder);
87
+ /* eslint-disable-next-line @typescript-eslint/no-non-null-assertion */
88
+ this.$fastController.addBehaviors([this.cellsRepeatBehavior]);
89
+ }
90
+ this.addEventListener("cell-focused", this.handleCellFocus);
91
+ this.addEventListener(eventFocusOut, this.handleFocusout);
92
+ this.addEventListener(eventKeyDown, this.handleKeydown);
93
+ this.updateRowStyle();
94
+ if (this.refocusOnLoad) {
95
+ // if focus was on the row when data changed try to refocus on same cell
96
+ this.refocusOnLoad = false;
97
+ if (this.cellElements.length > this.focusColumnIndex) {
98
+ this.cellElements[this.focusColumnIndex].focus();
99
+ }
100
+ }
101
+ }
102
+ /**
103
+ * @internal
104
+ */
105
+ disconnectedCallback() {
106
+ super.disconnectedCallback();
107
+ this.removeEventListener("cell-focused", this.handleCellFocus);
108
+ this.removeEventListener(eventFocusOut, this.handleFocusout);
109
+ this.removeEventListener(eventKeyDown, this.handleKeydown);
110
+ }
111
+ handleFocusout(e) {
112
+ if (!this.contains(e.target)) {
113
+ this.isActiveRow = false;
114
+ this.focusColumnIndex = 0;
115
+ }
116
+ }
117
+ handleCellFocus(e) {
118
+ this.isActiveRow = true;
119
+ this.focusColumnIndex = this.cellElements.indexOf(e.target);
120
+ this.$emit("row-focused", this);
121
+ }
122
+ handleKeydown(e) {
123
+ if (e.defaultPrevented) {
124
+ return;
125
+ }
126
+ let newFocusColumnIndex = 0;
127
+ switch (e.key) {
128
+ case keyArrowLeft:
129
+ // focus left one cell
130
+ newFocusColumnIndex = Math.max(0, this.focusColumnIndex - 1);
131
+ this.cellElements[newFocusColumnIndex].focus();
132
+ e.preventDefault();
133
+ break;
134
+ case keyArrowRight:
135
+ // focus right one cell
136
+ newFocusColumnIndex = Math.min(this.cellElements.length - 1, this.focusColumnIndex + 1);
137
+ this.cellElements[newFocusColumnIndex].focus();
138
+ e.preventDefault();
139
+ break;
140
+ case keyHome:
141
+ if (!e.ctrlKey) {
142
+ this.cellElements[0].focus();
143
+ e.preventDefault();
144
+ }
145
+ break;
146
+ case keyEnd:
147
+ if (!e.ctrlKey) {
148
+ // focus last cell of the row
149
+ this.cellElements[this.cellElements.length - 1].focus();
150
+ e.preventDefault();
151
+ }
152
+ break;
153
+ }
154
+ }
155
+ updateItemTemplate() {
156
+ this.activeCellItemTemplate =
157
+ this.rowType === DataGridRowTypes.default &&
158
+ this.cellItemTemplate !== undefined
159
+ ? this.cellItemTemplate
160
+ : this.rowType === DataGridRowTypes.default &&
161
+ this.cellItemTemplate === undefined
162
+ ? this.defaultCellItemTemplate
163
+ : this.headerCellItemTemplate !== undefined
164
+ ? this.headerCellItemTemplate
165
+ : this.defaultHeaderCellItemTemplate;
166
+ }
167
+ }
168
+ __decorate([
169
+ attr({ attribute: "grid-template-columns" })
170
+ ], DataGridRow.prototype, "gridTemplateColumns", void 0);
171
+ __decorate([
172
+ attr({ attribute: "row-type" })
173
+ ], DataGridRow.prototype, "rowType", void 0);
174
+ __decorate([
175
+ observable
176
+ ], DataGridRow.prototype, "rowData", void 0);
177
+ __decorate([
178
+ observable
179
+ ], DataGridRow.prototype, "columnDefinitions", void 0);
180
+ __decorate([
181
+ observable
182
+ ], DataGridRow.prototype, "cellItemTemplate", void 0);
183
+ __decorate([
184
+ observable
185
+ ], DataGridRow.prototype, "headerCellItemTemplate", void 0);
186
+ __decorate([
187
+ observable
188
+ ], DataGridRow.prototype, "rowIndex", void 0);
189
+ __decorate([
190
+ observable
191
+ ], DataGridRow.prototype, "isActiveRow", void 0);
192
+ __decorate([
193
+ observable
194
+ ], DataGridRow.prototype, "activeCellItemTemplate", void 0);
195
+ __decorate([
196
+ observable
197
+ ], DataGridRow.prototype, "defaultCellItemTemplate", void 0);
198
+ __decorate([
199
+ observable
200
+ ], DataGridRow.prototype, "defaultHeaderCellItemTemplate", void 0);
201
+ __decorate([
202
+ observable
203
+ ], DataGridRow.prototype, "cellElements", void 0);
@@ -0,0 +1,47 @@
1
+ import { children, elements, html, slotted } from "@ni/fast-element";
2
+ import { DataGridCell } from "./data-grid-cell.js";
3
+ function createCellItemTemplate(context) {
4
+ const cellTag = context.tagFor(DataGridCell);
5
+ return html `
6
+ <${cellTag}
7
+ cell-type="${x => (x.isRowHeader ? "rowheader" : undefined)}"
8
+ grid-column="${(x, c) => c.index + 1}"
9
+ :rowData="${(x, c) => c.parent.rowData}"
10
+ :columnDefinition="${x => x}"
11
+ ></${cellTag}>
12
+ `;
13
+ }
14
+ function createHeaderCellItemTemplate(context) {
15
+ const cellTag = context.tagFor(DataGridCell);
16
+ return html `
17
+ <${cellTag}
18
+ cell-type="columnheader"
19
+ grid-column="${(x, c) => c.index + 1}"
20
+ :columnDefinition="${x => x}"
21
+ ></${cellTag}>
22
+ `;
23
+ }
24
+ /**
25
+ * Generates a template for the {@link @ni/fast-foundation#DataGridRow} component using
26
+ * the provided prefix.
27
+ *
28
+ * @public
29
+ */
30
+ export const dataGridRowTemplate = (context, definition) => {
31
+ const cellItemTemplate = createCellItemTemplate(context);
32
+ const headerCellItemTemplate = createHeaderCellItemTemplate(context);
33
+ return html `
34
+ <template
35
+ role="row"
36
+ class="${x => (x.rowType !== "default" ? x.rowType : "")}"
37
+ :defaultCellItemTemplate="${cellItemTemplate}"
38
+ :defaultHeaderCellItemTemplate="${headerCellItemTemplate}"
39
+ ${children({
40
+ property: "cellElements",
41
+ filter: elements('[role="cell"],[role="gridcell"],[role="columnheader"],[role="rowheader"]'),
42
+ })}
43
+ >
44
+ <slot ${slotted("slottedCellElements")}></slot>
45
+ </template>
46
+ `;
47
+ };