@hokulea/ember 0.8.0 → 0.10.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 (392) hide show
  1. package/declarations/-private/helpers.d.ts +3 -1
  2. package/declarations/-private/helpers.d.ts.map +1 -1
  3. package/declarations/-private/push.gts.d.ts +20 -0
  4. package/declarations/-private/push.gts.d.ts.map +1 -0
  5. package/declarations/-private/shapes.d.ts +5 -0
  6. package/declarations/-private/shapes.d.ts.map +1 -0
  7. package/declarations/-private/stories.d.ts +2 -0
  8. package/declarations/-private/stories.d.ts.map +1 -1
  9. package/declarations/components/actions/-button.d.ts.map +1 -0
  10. package/declarations/components/actions/button.gts.d.ts +24 -0
  11. package/declarations/components/actions/button.gts.d.ts.map +1 -0
  12. package/declarations/components/actions/icon-button.gts.d.ts +25 -0
  13. package/declarations/components/actions/icon-button.gts.d.ts.map +1 -0
  14. package/declarations/components/app-header.gts.d.ts +1 -48
  15. package/declarations/components/app-header.gts.d.ts.map +1 -1
  16. package/declarations/components/avatar.gts.d.ts +2 -0
  17. package/declarations/components/avatar.gts.d.ts.map +1 -0
  18. package/declarations/components/box.gts.d.ts +1 -15
  19. package/declarations/components/box.gts.d.ts.map +1 -1
  20. package/declarations/components/button.gts.d.ts +1 -25
  21. package/declarations/components/button.gts.d.ts.map +1 -1
  22. package/declarations/components/card.gts.d.ts +1 -12
  23. package/declarations/components/card.gts.d.ts.map +1 -1
  24. package/declarations/components/checkbox.gts.d.ts +1 -8
  25. package/declarations/components/checkbox.gts.d.ts.map +1 -1
  26. package/declarations/components/content/box.gts.d.ts +16 -0
  27. package/declarations/components/content/box.gts.d.ts.map +1 -0
  28. package/declarations/components/content/card.gts.d.ts +12 -0
  29. package/declarations/components/content/card.gts.d.ts.map +1 -0
  30. package/declarations/components/content/section.gts.d.ts +18 -0
  31. package/declarations/components/content/section.gts.d.ts.map +1 -0
  32. package/declarations/components/{-input.d.ts → controls/-input.d.ts} +3 -2
  33. package/declarations/components/controls/-input.d.ts.map +1 -0
  34. package/declarations/components/{-menu.d.ts → controls/-menu.gts.d.ts} +3 -4
  35. package/declarations/components/controls/-menu.gts.d.ts.map +1 -0
  36. package/declarations/components/controls/checkbox.gts.d.ts +8 -0
  37. package/declarations/components/controls/checkbox.gts.d.ts.map +1 -0
  38. package/declarations/components/controls/currency-input.gts.d.ts +8 -0
  39. package/declarations/components/controls/currency-input.gts.d.ts.map +1 -0
  40. package/declarations/components/controls/date-input.gts.d.ts +8 -0
  41. package/declarations/components/controls/date-input.gts.d.ts.map +1 -0
  42. package/declarations/components/controls/email-input.gts.d.ts +8 -0
  43. package/declarations/components/controls/email-input.gts.d.ts.map +1 -0
  44. package/declarations/components/controls/input-builder.gts.d.ts +30 -0
  45. package/declarations/components/controls/input-builder.gts.d.ts.map +1 -0
  46. package/declarations/components/controls/list.gts.d.ts +51 -0
  47. package/declarations/components/controls/list.gts.d.ts.map +1 -0
  48. package/declarations/components/controls/menu.gts.d.ts +39 -0
  49. package/declarations/components/controls/menu.gts.d.ts.map +1 -0
  50. package/declarations/components/controls/number-input.gts.d.ts +8 -0
  51. package/declarations/components/controls/number-input.gts.d.ts.map +1 -0
  52. package/declarations/components/controls/password-input.gts.d.ts +8 -0
  53. package/declarations/components/controls/password-input.gts.d.ts.map +1 -0
  54. package/declarations/components/controls/phone-input.gts.d.ts +8 -0
  55. package/declarations/components/controls/phone-input.gts.d.ts.map +1 -0
  56. package/declarations/components/controls/radio.gts.d.ts +8 -0
  57. package/declarations/components/controls/radio.gts.d.ts.map +1 -0
  58. package/declarations/components/controls/range-input.gts.d.ts +13 -0
  59. package/declarations/components/controls/range-input.gts.d.ts.map +1 -0
  60. package/declarations/components/controls/select.gts.d.ts +39 -0
  61. package/declarations/components/controls/select.gts.d.ts.map +1 -0
  62. package/declarations/components/controls/tabs.gts.d.ts +61 -0
  63. package/declarations/components/controls/tabs.gts.d.ts.map +1 -0
  64. package/declarations/components/controls/text-area.gts.d.ts +8 -0
  65. package/declarations/components/controls/text-area.gts.d.ts.map +1 -0
  66. package/declarations/components/controls/text-input.gts.d.ts +8 -0
  67. package/declarations/components/controls/text-input.gts.d.ts.map +1 -0
  68. package/declarations/components/currency-input.gts.d.ts +1 -8
  69. package/declarations/components/currency-input.gts.d.ts.map +1 -1
  70. package/declarations/components/data/data-table.gts.d.ts +19 -0
  71. package/declarations/components/data/data-table.gts.d.ts.map +1 -0
  72. package/declarations/components/data-table.gts.d.ts +2 -0
  73. package/declarations/components/data-table.gts.d.ts.map +1 -0
  74. package/declarations/components/date-input.gts.d.ts +1 -8
  75. package/declarations/components/date-input.gts.d.ts.map +1 -1
  76. package/declarations/components/email-input.gts.d.ts +1 -8
  77. package/declarations/components/email-input.gts.d.ts.map +1 -1
  78. package/declarations/components/focus-page.gts.d.ts +2 -0
  79. package/declarations/components/focus-page.gts.d.ts.map +1 -0
  80. package/declarations/components/form/description.gts.d.ts +1 -2
  81. package/declarations/components/form/description.gts.d.ts.map +1 -1
  82. package/declarations/components/form/errors.gts.d.ts +1 -2
  83. package/declarations/components/form/errors.gts.d.ts.map +1 -1
  84. package/declarations/components/form/field.gts.d.ts +2 -2
  85. package/declarations/components/form/field.gts.d.ts.map +1 -1
  86. package/declarations/components/form/fields/checkbox.gts.d.ts +2 -2
  87. package/declarations/components/form/fields/checkbox.gts.d.ts.map +1 -1
  88. package/declarations/components/form/fields/currency.gts.d.ts +2 -2
  89. package/declarations/components/form/fields/currency.gts.d.ts.map +1 -1
  90. package/declarations/components/form/fields/date.gts.d.ts +2 -2
  91. package/declarations/components/form/fields/date.gts.d.ts.map +1 -1
  92. package/declarations/components/form/fields/email.gts.d.ts +2 -2
  93. package/declarations/components/form/fields/email.gts.d.ts.map +1 -1
  94. package/declarations/components/form/fields/list.gts.d.ts +3 -3
  95. package/declarations/components/form/fields/list.gts.d.ts.map +1 -1
  96. package/declarations/components/form/fields/multiple-choice.gts.d.ts +2 -2
  97. package/declarations/components/form/fields/multiple-choice.gts.d.ts.map +1 -1
  98. package/declarations/components/form/fields/number.gts.d.ts +2 -2
  99. package/declarations/components/form/fields/number.gts.d.ts.map +1 -1
  100. package/declarations/components/form/fields/password.gts.d.ts +2 -2
  101. package/declarations/components/form/fields/password.gts.d.ts.map +1 -1
  102. package/declarations/components/form/fields/phone.gts.d.ts +2 -2
  103. package/declarations/components/form/fields/phone.gts.d.ts.map +1 -1
  104. package/declarations/components/form/fields/range.gts.d.ts +2 -2
  105. package/declarations/components/form/fields/range.gts.d.ts.map +1 -1
  106. package/declarations/components/form/fields/select.gts.d.ts +2 -2
  107. package/declarations/components/form/fields/select.gts.d.ts.map +1 -1
  108. package/declarations/components/form/fields/singular-choice.gts.d.ts +2 -2
  109. package/declarations/components/form/fields/singular-choice.gts.d.ts.map +1 -1
  110. package/declarations/components/form/fields/text-area.gts.d.ts +2 -2
  111. package/declarations/components/form/fields/text-area.gts.d.ts.map +1 -1
  112. package/declarations/components/form/fields/text.gts.d.ts +2 -2
  113. package/declarations/components/form/fields/text.gts.d.ts.map +1 -1
  114. package/declarations/components/form/form.gts.d.ts +31 -30
  115. package/declarations/components/form/form.gts.d.ts.map +1 -1
  116. package/declarations/components/form/index.d.ts +1 -1
  117. package/declarations/components/form/index.d.ts.map +1 -1
  118. package/declarations/components/form/label.gts.d.ts +1 -2
  119. package/declarations/components/form/label.gts.d.ts.map +1 -1
  120. package/declarations/components/form/reset.gts.d.ts +5 -6
  121. package/declarations/components/form/reset.gts.d.ts.map +1 -1
  122. package/declarations/components/form/rules.gts.d.ts +1 -1
  123. package/declarations/components/form/rules.gts.d.ts.map +1 -1
  124. package/declarations/components/form/submit.gts.d.ts +5 -6
  125. package/declarations/components/form/submit.gts.d.ts.map +1 -1
  126. package/declarations/components/form.gts.d.ts +1 -1
  127. package/declarations/components/form.gts.d.ts.map +1 -1
  128. package/declarations/components/graphics/avatar.gts.d.ts +10 -0
  129. package/declarations/components/graphics/avatar.gts.d.ts.map +1 -0
  130. package/declarations/components/graphics/icon.gts.d.ts +13 -0
  131. package/declarations/components/graphics/icon.gts.d.ts.map +1 -0
  132. package/declarations/components/icon-button.gts.d.ts +1 -25
  133. package/declarations/components/icon-button.gts.d.ts.map +1 -1
  134. package/declarations/components/icon.gts.d.ts +1 -13
  135. package/declarations/components/icon.gts.d.ts.map +1 -1
  136. package/declarations/components/input-builder.gts.d.ts +1 -28
  137. package/declarations/components/input-builder.gts.d.ts.map +1 -1
  138. package/declarations/components/layouts/focus-page.gts.d.ts +24 -0
  139. package/declarations/components/layouts/focus-page.gts.d.ts.map +1 -0
  140. package/declarations/components/layouts/page.gts.d.ts +24 -0
  141. package/declarations/components/layouts/page.gts.d.ts.map +1 -0
  142. package/declarations/components/layouts/pages.d.ts +15 -0
  143. package/declarations/components/layouts/pages.d.ts.map +1 -0
  144. package/declarations/components/layouts/sectioned-page.gts.d.ts +26 -0
  145. package/declarations/components/layouts/sectioned-page.gts.d.ts.map +1 -0
  146. package/declarations/components/link.gts.d.ts +2 -0
  147. package/declarations/components/link.gts.d.ts.map +1 -0
  148. package/declarations/components/list.gts.d.ts +1 -50
  149. package/declarations/components/list.gts.d.ts.map +1 -1
  150. package/declarations/components/menu.gts.d.ts +1 -38
  151. package/declarations/components/menu.gts.d.ts.map +1 -1
  152. package/declarations/components/navigation/-pagination.d.ts +17 -0
  153. package/declarations/components/navigation/-pagination.d.ts.map +1 -0
  154. package/declarations/components/navigation/app-header.gts.d.ts +54 -0
  155. package/declarations/components/navigation/app-header.gts.d.ts.map +1 -0
  156. package/declarations/components/navigation/link.gts.d.ts +13 -0
  157. package/declarations/components/navigation/link.gts.d.ts.map +1 -0
  158. package/declarations/components/navigation/nav-link.gts.d.ts +12 -0
  159. package/declarations/components/navigation/nav-link.gts.d.ts.map +1 -0
  160. package/declarations/components/navigation/navigation-list.gts.d.ts +19 -0
  161. package/declarations/components/navigation/navigation-list.gts.d.ts.map +1 -0
  162. package/declarations/components/navigation/pagination.gts.d.ts +78 -0
  163. package/declarations/components/navigation/pagination.gts.d.ts.map +1 -0
  164. package/declarations/components/navigation-list.gts.d.ts +2 -0
  165. package/declarations/components/navigation-list.gts.d.ts.map +1 -0
  166. package/declarations/components/number-input.gts.d.ts +1 -8
  167. package/declarations/components/number-input.gts.d.ts.map +1 -1
  168. package/declarations/components/page.gts.d.ts +1 -35
  169. package/declarations/components/page.gts.d.ts.map +1 -1
  170. package/declarations/components/pagination.gts.d.ts +2 -0
  171. package/declarations/components/pagination.gts.d.ts.map +1 -0
  172. package/declarations/components/password-input.gts.d.ts +1 -8
  173. package/declarations/components/password-input.gts.d.ts.map +1 -1
  174. package/declarations/components/phone-input.gts.d.ts +1 -8
  175. package/declarations/components/phone-input.gts.d.ts.map +1 -1
  176. package/declarations/components/popover.gts.d.ts +1 -9
  177. package/declarations/components/popover.gts.d.ts.map +1 -1
  178. package/declarations/components/radio.gts.d.ts +1 -8
  179. package/declarations/components/radio.gts.d.ts.map +1 -1
  180. package/declarations/components/range-input.gts.d.ts +1 -13
  181. package/declarations/components/range-input.gts.d.ts.map +1 -1
  182. package/declarations/components/section.gts.d.ts +1 -18
  183. package/declarations/components/section.gts.d.ts.map +1 -1
  184. package/declarations/components/sectioned-page.gts.d.ts +2 -0
  185. package/declarations/components/sectioned-page.gts.d.ts.map +1 -0
  186. package/declarations/components/select.gts.d.ts +1 -35
  187. package/declarations/components/select.gts.d.ts.map +1 -1
  188. package/declarations/components/tabs.gts.d.ts +1 -60
  189. package/declarations/components/tabs.gts.d.ts.map +1 -1
  190. package/declarations/components/text-area.gts.d.ts +1 -8
  191. package/declarations/components/text-area.gts.d.ts.map +1 -1
  192. package/declarations/components/text-input.gts.d.ts +1 -8
  193. package/declarations/components/text-input.gts.d.ts.map +1 -1
  194. package/declarations/components/windows/popover.gts.d.ts +9 -0
  195. package/declarations/components/windows/popover.gts.d.ts.map +1 -0
  196. package/declarations/helpers/popover.d.ts +1 -1
  197. package/declarations/helpers/popover.d.ts.map +1 -1
  198. package/declarations/index.d.ts +33 -26
  199. package/declarations/index.d.ts.map +1 -1
  200. package/declarations/registry.d.ts +2 -0
  201. package/declarations/registry.d.ts.map +1 -0
  202. package/declarations/services/-hokulea.d.ts.map +1 -1
  203. package/declarations/template-registry.d.ts +49 -35
  204. package/declarations/template-registry.d.ts.map +1 -1
  205. package/declarations/test-support/index.d.ts +5 -1
  206. package/declarations/test-support/index.d.ts.map +1 -1
  207. package/declarations/test-support/page-objects/-navigation.d.ts +9 -0
  208. package/declarations/test-support/page-objects/-navigation.d.ts.map +1 -0
  209. package/declarations/test-support/page-objects/app-header.d.ts +1 -1
  210. package/declarations/test-support/page-objects/app-header.d.ts.map +1 -1
  211. package/declarations/test-support/page-objects/avatar.d.ts +10 -0
  212. package/declarations/test-support/page-objects/avatar.d.ts.map +1 -0
  213. package/declarations/test-support/page-objects/data-table.d.ts +36 -0
  214. package/declarations/test-support/page-objects/data-table.d.ts.map +1 -0
  215. package/declarations/test-support/page-objects/input.d.ts +1 -0
  216. package/declarations/test-support/page-objects/input.d.ts.map +1 -1
  217. package/declarations/test-support/page-objects/navigation-list.d.ts +10 -0
  218. package/declarations/test-support/page-objects/navigation-list.d.ts.map +1 -0
  219. package/declarations/test-support/page-objects/page.d.ts +3 -1
  220. package/declarations/test-support/page-objects/page.d.ts.map +1 -1
  221. package/declarations/test-support/page-objects/pagination.d.ts +65 -0
  222. package/declarations/test-support/page-objects/pagination.d.ts.map +1 -0
  223. package/declarations/test-support/page-objects/select.d.ts +1 -0
  224. package/declarations/test-support/page-objects/select.d.ts.map +1 -1
  225. package/declarations/test-support/page-objects/tabs.d.ts.map +1 -1
  226. package/dist/-button-KUaJCQaB.js.map +1 -1
  227. package/dist/-input-DGR-n9U_.js.map +1 -1
  228. package/dist/_app_/components/avatar.js +1 -0
  229. package/dist/_app_/components/data-table.js +1 -0
  230. package/dist/_app_/components/focus-page.js +1 -0
  231. package/dist/_app_/components/link.js +1 -0
  232. package/dist/_app_/components/navigation-list.js +1 -0
  233. package/dist/_app_/components/pagination.js +1 -0
  234. package/dist/_app_/components/sectioned-page.js +1 -0
  235. package/dist/app-header-nmqytjxx.js +117 -0
  236. package/dist/app-header-nmqytjxx.js.map +1 -0
  237. package/dist/avatar-CtqAk4G6.js +29 -0
  238. package/dist/avatar-CtqAk4G6.js.map +1 -0
  239. package/dist/box-DU6m9gDw.js +20 -0
  240. package/dist/box-DU6m9gDw.js.map +1 -0
  241. package/dist/button-BhxkZ70u.js +26 -0
  242. package/dist/button-BhxkZ70u.js.map +1 -0
  243. package/dist/card-tK78paQn.js +16 -0
  244. package/dist/card-tK78paQn.js.map +1 -0
  245. package/dist/checkbox-D3_2ps5M.js +18 -0
  246. package/dist/checkbox-D3_2ps5M.js.map +1 -0
  247. package/dist/components/app-header.js +1 -131
  248. package/dist/components/app-header.js.map +1 -1
  249. package/dist/components/avatar.js +2 -0
  250. package/dist/components/avatar.js.map +1 -0
  251. package/dist/components/box.js +1 -19
  252. package/dist/components/box.js.map +1 -1
  253. package/dist/components/button.js +1 -23
  254. package/dist/components/button.js.map +1 -1
  255. package/dist/components/card.js +1 -15
  256. package/dist/components/card.js.map +1 -1
  257. package/dist/components/checkbox.js +1 -17
  258. package/dist/components/checkbox.js.map +1 -1
  259. package/dist/components/currency-input.js +1 -21
  260. package/dist/components/currency-input.js.map +1 -1
  261. package/dist/components/data-table.js +2 -0
  262. package/dist/components/data-table.js.map +1 -0
  263. package/dist/components/date-input.js +1 -17
  264. package/dist/components/date-input.js.map +1 -1
  265. package/dist/components/email-input.js +1 -17
  266. package/dist/components/email-input.js.map +1 -1
  267. package/dist/components/focus-page.js +2 -0
  268. package/dist/components/focus-page.js.map +1 -0
  269. package/dist/components/form.js +1 -1
  270. package/dist/components/icon-button.js +1 -36
  271. package/dist/components/icon-button.js.map +1 -1
  272. package/dist/components/icon.js +1 -15
  273. package/dist/components/icon.js.map +1 -1
  274. package/dist/components/input-builder.js +1 -19
  275. package/dist/components/input-builder.js.map +1 -1
  276. package/dist/components/link.js +2 -0
  277. package/dist/components/link.js.map +1 -0
  278. package/dist/components/list.js +1 -65
  279. package/dist/components/list.js.map +1 -1
  280. package/dist/components/menu.js +1 -115
  281. package/dist/components/menu.js.map +1 -1
  282. package/dist/components/navigation-list.js +2 -0
  283. package/dist/components/navigation-list.js.map +1 -0
  284. package/dist/components/number-input.js +1 -19
  285. package/dist/components/number-input.js.map +1 -1
  286. package/dist/components/page.js +1 -62
  287. package/dist/components/page.js.map +1 -1
  288. package/dist/components/pagination.js +2 -0
  289. package/dist/components/pagination.js.map +1 -0
  290. package/dist/components/password-input.js +1 -17
  291. package/dist/components/password-input.js.map +1 -1
  292. package/dist/components/phone-input.js +1 -17
  293. package/dist/components/phone-input.js.map +1 -1
  294. package/dist/components/popover.js +1 -13
  295. package/dist/components/popover.js.map +1 -1
  296. package/dist/components/radio.js +1 -17
  297. package/dist/components/radio.js.map +1 -1
  298. package/dist/components/range-input.js +1 -36
  299. package/dist/components/range-input.js.map +1 -1
  300. package/dist/components/section.js +1 -24
  301. package/dist/components/section.js.map +1 -1
  302. package/dist/components/sectioned-page.js +2 -0
  303. package/dist/components/sectioned-page.js.map +1 -0
  304. package/dist/components/select.js +1 -38
  305. package/dist/components/select.js.map +1 -1
  306. package/dist/components/tabs.js +1 -110
  307. package/dist/components/tabs.js.map +1 -1
  308. package/dist/components/text-area.js +1 -17
  309. package/dist/components/text-area.js.map +1 -1
  310. package/dist/components/text-input.js +1 -17
  311. package/dist/components/text-input.js.map +1 -1
  312. package/dist/currency-input-tBhgIMTh.js +22 -0
  313. package/dist/currency-input-tBhgIMTh.js.map +1 -0
  314. package/dist/data-table-5VDYeRya.js +18 -0
  315. package/dist/data-table-5VDYeRya.js.map +1 -0
  316. package/dist/date-input-DLv9jE39.js +18 -0
  317. package/dist/date-input-DLv9jE39.js.map +1 -0
  318. package/dist/email-input-BR33Qevz.js +18 -0
  319. package/dist/email-input-BR33Qevz.js.map +1 -0
  320. package/dist/focus-page-DFu6qtBk.js +23 -0
  321. package/dist/focus-page-DFu6qtBk.js.map +1 -0
  322. package/dist/{form-DBuzL4_0.js → form-VsNkRlXs.js} +16 -16
  323. package/dist/form-VsNkRlXs.js.map +1 -0
  324. package/dist/helpers/popover.js +1 -1
  325. package/dist/helpers/popover.js.map +1 -1
  326. package/dist/{helpers-DS9du02l.js → helpers-D4So5-uK.js} +8 -2
  327. package/dist/helpers-D4So5-uK.js.map +1 -0
  328. package/dist/icon-BfRBkZ72.js +16 -0
  329. package/dist/icon-BfRBkZ72.js.map +1 -0
  330. package/dist/icon-button-DBt7fMi1.js +38 -0
  331. package/dist/icon-button-DBt7fMi1.js.map +1 -0
  332. package/dist/index.js +34 -27
  333. package/dist/index.js.map +1 -1
  334. package/dist/input-builder-DHYx-2Yz.js +20 -0
  335. package/dist/input-builder-DHYx-2Yz.js.map +1 -0
  336. package/dist/link-bqsg26Cc.js +18 -0
  337. package/dist/link-bqsg26Cc.js.map +1 -0
  338. package/dist/list-CsLvih6-.js +66 -0
  339. package/dist/list-CsLvih6-.js.map +1 -0
  340. package/dist/menu-s0AthZse.js +118 -0
  341. package/dist/menu-s0AthZse.js.map +1 -0
  342. package/dist/nav-link-CDtYj6HW.js +22 -0
  343. package/dist/nav-link-CDtYj6HW.js.map +1 -0
  344. package/dist/navigation-list-Ng5UsNCY.js +22 -0
  345. package/dist/navigation-list-Ng5UsNCY.js.map +1 -0
  346. package/dist/number-input-FJympEv2.js +20 -0
  347. package/dist/number-input-FJympEv2.js.map +1 -0
  348. package/dist/page-BuLkLO08.js +23 -0
  349. package/dist/page-BuLkLO08.js.map +1 -0
  350. package/dist/pages-DgHJEvSy.js +31 -0
  351. package/dist/pages-DgHJEvSy.js.map +1 -0
  352. package/dist/pagination-DCMxI10i.js +124 -0
  353. package/dist/pagination-DCMxI10i.js.map +1 -0
  354. package/dist/password-input-DV5yb10h.js +18 -0
  355. package/dist/password-input-DV5yb10h.js.map +1 -0
  356. package/dist/phone-input-Uv5v9hK9.js +18 -0
  357. package/dist/phone-input-Uv5v9hK9.js.map +1 -0
  358. package/dist/popover-B6j413u9.js +14 -0
  359. package/dist/popover-B6j413u9.js.map +1 -0
  360. package/dist/push-DnJFFc_p.js +24 -0
  361. package/dist/push-DnJFFc_p.js.map +1 -0
  362. package/dist/radio-CLF40kob.js +18 -0
  363. package/dist/radio-CLF40kob.js.map +1 -0
  364. package/dist/range-input-BIb7GkKH.js +37 -0
  365. package/dist/range-input-BIb7GkKH.js.map +1 -0
  366. package/dist/registry.js +14 -0
  367. package/dist/registry.js.map +1 -0
  368. package/dist/section-BAdmc3Yn.js +25 -0
  369. package/dist/section-BAdmc3Yn.js.map +1 -0
  370. package/dist/sectioned-page-CgINWVQ2.js +25 -0
  371. package/dist/sectioned-page-CgINWVQ2.js.map +1 -0
  372. package/dist/select-CeO8AZMK.js +42 -0
  373. package/dist/select-CeO8AZMK.js.map +1 -0
  374. package/dist/services/-hokulea.js +1 -8
  375. package/dist/services/-hokulea.js.map +1 -1
  376. package/dist/tabs-DAscspzh.js +111 -0
  377. package/dist/tabs-DAscspzh.js.map +1 -0
  378. package/dist/test-support/index.js +82 -18
  379. package/dist/test-support/index.js.map +1 -1
  380. package/dist/text-area-DF8-cDiy.js +18 -0
  381. package/dist/text-area-DF8-cDiy.js.map +1 -0
  382. package/dist/text-input-CcIcYksE.js +18 -0
  383. package/dist/text-input-CcIcYksE.js.map +1 -0
  384. package/package.json +21 -13
  385. package/declarations/components/-button.d.ts.map +0 -1
  386. package/declarations/components/-input.d.ts.map +0 -1
  387. package/declarations/components/-menu.d.ts.map +0 -1
  388. package/declarations/components/-stories.d.ts +0 -3
  389. package/declarations/components/-stories.d.ts.map +0 -1
  390. package/dist/form-DBuzL4_0.js.map +0 -1
  391. package/dist/helpers-DS9du02l.js.map +0 -1
  392. /package/declarations/components/{-button.d.ts → actions/-button.d.ts} +0 -0
@@ -0,0 +1,31 @@
1
+ import Helper from '@ember/component/helper';
2
+ import { registerDestructor } from '@ember/destroyable';
3
+ import { service } from '@ember/service';
4
+ import Modifier from 'ember-modifier';
5
+ import { g, i } from 'decorator-transforms/runtime-esm';
6
+
7
+ class PageElement extends Helper {
8
+ static {
9
+ g(this.prototype, "hokulea", [service('-hokulea')]);
10
+ }
11
+ #hokulea = (i(this, "hokulea"), void 0);
12
+ compute() {
13
+ const element = this.hokulea.pageLevel === 0 ? 'main' : 'section';
14
+ this.hokulea.pageLevel++;
15
+ return element;
16
+ }
17
+ }
18
+ class PageDestructor extends Modifier {
19
+ static {
20
+ g(this.prototype, "hokulea", [service('-hokulea')]);
21
+ }
22
+ #hokulea = (i(this, "hokulea"), void 0);
23
+ modify() {
24
+ registerDestructor(this, () => {
25
+ this.hokulea.pageLevel--;
26
+ });
27
+ }
28
+ }
29
+
30
+ export { PageDestructor as P, PageElement as a };
31
+ //# sourceMappingURL=pages-DgHJEvSy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pages-DgHJEvSy.js","sources":["../src/components/layouts/pages.ts"],"sourcesContent":["import Helper from '@ember/component/helper';\nimport { registerDestructor } from '@ember/destroyable';\nimport { service } from '@ember/service';\n\nimport Modifier from 'ember-modifier';\n\nimport type HokuleaService from '../../services/-hokulea';\n\nclass PageElement extends Helper<{ Return: 'main' | 'section' }> {\n @service('-hokulea') declare hokulea: HokuleaService;\n\n compute(): 'main' | 'section' {\n const element = this.hokulea.pageLevel === 0 ? 'main' : 'section';\n\n this.hokulea.pageLevel++;\n\n return element;\n }\n}\n\nclass PageDestructor extends Modifier {\n @service('-hokulea') declare hokulea: HokuleaService;\n\n modify(): void {\n registerDestructor(this, () => {\n this.hokulea.pageLevel--;\n });\n }\n}\n\nexport { PageDestructor as pageDestructor, PageElement as pageElement };\n"],"names":["PageElement","Helper","g","prototype","service","i","void 0","compute","element","hokulea","pageLevel","PageDestructor","Modifier","modify","registerDestructor"],"mappings":";;;;;;AAQA,MAAMA,WAAW,SAASC,MAAM,CAAiC;AAAA,EAAA;AAAAC,IAAAA,CAAA,MAAAC,SAAA,EAAA,SAAA,EAAA,CAC9DC,OAAO,CAAC,UAAU,CAAC,CAAA,CAAA;AAAA;AAAA,EAAA,QAAA,IAAAC,CAAA,CAAA,IAAA,EAAA,SAAA,CAAA,EAAAC,MAAA;AAEpBC,EAAAA,OAAOA,GAAuB;AAC5B,IAAA,MAAMC,OAAO,GAAG,IAAI,CAACC,OAAO,CAACC,SAAS,KAAK,CAAC,GAAG,MAAM,GAAG,SAAS;AAEjE,IAAA,IAAI,CAACD,OAAO,CAACC,SAAS,EAAE;AAExB,IAAA,OAAOF,OAAO;AAChB,EAAA;AACF;AAEA,MAAMG,cAAc,SAASC,QAAQ,CAAC;AAAA,EAAA;AAAAV,IAAAA,CAAA,MAAAC,SAAA,EAAA,SAAA,EAAA,CACnCC,OAAO,CAAC,UAAU,CAAC,CAAA,CAAA;AAAA;AAAA,EAAA,QAAA,IAAAC,CAAA,CAAA,IAAA,EAAA,SAAA,CAAA,EAAAC,MAAA;AAEpBO,EAAAA,MAAMA,GAAS;IACbC,kBAAkB,CAAC,IAAI,EAAE,MAAM;AAC7B,MAAA,IAAI,CAACL,OAAO,CAACC,SAAS,EAAE;AAC1B,IAAA,CAAC,CAAC;AACJ,EAAA;AACF;;;;"}
@@ -0,0 +1,124 @@
1
+ import Component from '@glimmer/component';
2
+ import { tracked } from '@glimmer/tracking';
3
+ import styles from '@hokulea/core/navigation.module.css';
4
+ import { c as asNumber, r as range, g as gt } from './helpers-D4So5-uK.js';
5
+ import { I as IconButton } from './icon-button-DBt7fMi1.js';
6
+ import { N as NumberInput } from './number-input-FJympEv2.js';
7
+ import { S as Select } from './select-CeO8AZMK.js';
8
+ import { precompileTemplate } from '@ember/template-compilation';
9
+ import { setComponentTemplate } from '@ember/component';
10
+ import { g, i } from 'decorator-transforms/runtime-esm';
11
+
12
+ const PrevIcon = `<svg xmlns="http://www.w3.org/2000/svg" width="256" height="256" viewBox="0 0 256 256"><path fill="currentColor" d="M168 48v160a8 8 0 0 1-13.66 5.66l-80-80a8 8 0 0 1 0-11.32l80-80A8 8 0 0 1 168 48"/></svg>`;
13
+ const NextIcon = `<svg xmlns="http://www.w3.org/2000/svg" width="256" height="256" viewBox="0 0 256 256"><path fill="currentColor" d="m181.66 133.66l-80 80A8 8 0 0 1 88 208V48a8 8 0 0 1 13.66-5.66l80 80a8 8 0 0 1 0 11.32"/></svg>`;
14
+ const LABELS = {
15
+ backward: 'Previous page',
16
+ forward: 'Next page',
17
+ itemPerPage: 'Items per page:',
18
+ itemRange: (min, max, total) => `${min} – ${max} of ${total} items`,
19
+ item: (min, max) => `${min} – ${max} items`,
20
+ page: page => `page ${page}`,
21
+ pageRange: total => `of ${total} ${total === 1 ? 'page' : 'pages'}`,
22
+ pageNumber: 'Page Number'
23
+ };
24
+
25
+ class Pagination extends Component {
26
+ static {
27
+ g(this.prototype, "total", [tracked], function () {
28
+ return 0;
29
+ });
30
+ }
31
+ #total = (i(this, "total"), void 0);
32
+ get minItems() {
33
+ return (this.page - 1) * this.args.pageSize + 1;
34
+ }
35
+ get maxItems() {
36
+ return this.page * this.args.pageSize;
37
+ }
38
+ get pages() {
39
+ if (this.args.totalItems) {
40
+ return Math.ceil(this.args.totalItems / this.args.pageSize);
41
+ }
42
+ return undefined;
43
+ }
44
+ get page() {
45
+ return this.args.page ?? 1;
46
+ }
47
+ get itemsPerPageLabel() {
48
+ return this.args.itemsPerPageLabel ?? LABELS.itemPerPage;
49
+ }
50
+ get itemRangeLabel() {
51
+ return (this.args.itemRangeLabel ?? LABELS.itemRange)(this.minItems, this.maxItems, this.args.totalItems ?? 1);
52
+ }
53
+ get itemLabel() {
54
+ return (this.args.itemLabel ?? LABELS.item)(this.minItems, this.maxItems);
55
+ }
56
+ get pageLabel() {
57
+ return (this.args.pageLabel ?? LABELS.page)(this.page);
58
+ }
59
+ get pageNumberLabel() {
60
+ return this.args.pageNumberLabel ?? LABELS.pageNumber;
61
+ }
62
+ get pageRangeLabel() {
63
+ return (this.args.pageRangeLabel ?? LABELS.pageRange)(this.pages ?? 0);
64
+ }
65
+ get pageSizeOptions() {
66
+ return (this.args.pageSizes ?? []).map(i => typeof i === 'object' ? i : {
67
+ value: i,
68
+ label: i
69
+ });
70
+ }
71
+ get backwardLabel() {
72
+ return this.args.backwardLabel ?? LABELS.backward;
73
+ }
74
+ get forwardLabel() {
75
+ return this.args.forwardLabel ?? LABELS.forward;
76
+ }
77
+ changePage = page => {
78
+ if (page) {
79
+ this.args.change?.({
80
+ page: this.pages ? Math.min(page, this.pages) : page,
81
+ pageSize: this.args.pageSize
82
+ });
83
+ }
84
+ };
85
+ changePageSize = pageSize => {
86
+ this.args.change?.({
87
+ page: this.page,
88
+ pageSize: Number.parseInt(pageSize)
89
+ });
90
+ };
91
+ prev = () => {
92
+ if (this.page > 1) {
93
+ this.changePage(this.page - 1);
94
+ }
95
+ };
96
+ next = () => {
97
+ if (this.pages) {
98
+ if (this.page < this.pages) {
99
+ this.changePage(this.page + 1);
100
+ }
101
+ } else {
102
+ this.changePage(this.page + 1);
103
+ }
104
+ };
105
+ static {
106
+ setComponentTemplate(precompileTemplate("\n <div class={{styles.pagination}} data-test-pagination>\n {{#if @pageSizes}}\n <span part=\"page-size\">\n {{this.itemsPerPageLabel}}\n\n {{!-- @glint-ignore --}}\n <Select @spacing=\"-1\" @value={{@pageSize}} @update={{this.changePageSize}} as |s|>\n {{#each this.pageSizeOptions as |o|}}\n <s.Option @value={{o.value}}>{{o.label}}</s.Option>\n {{/each}}\n </Select>\n </span>\n {{/if}}\n <span part=\"items\">\n {{#if @totalItems}}\n {{this.itemRangeLabel}}\n {{else}}\n {{this.itemLabel}}\n {{/if}}\n </span>\n <span part=\"page\">\n {{#if @totalItems}}\n {{#if (gt this.pages 20)}}\n <NumberInput @spacing=\"-1\" @value={{this.page}} @update={{this.changePage}} />\n {{else}}\n {{!-- @glint-ignore --}}\n <Select @spacing=\"-1\" @value={{this.page}} @update={{this.changePage}} as |s|>\n {{#each (range (asNumber this.pages)) as |p|}}\n <s.Option @value={{p}}>{{p}}</s.Option>\n {{/each}}\n </Select>\n {{/if}}\n {{this.pageRangeLabel}}\n {{else}}\n {{this.pageLabel}}\n {{/if}}\n </span>\n <span part=\"nav\">\n <IconButton @push={{this.prev}} @icon={{PrevIcon}} @label={{this.backwardLabel}} @importance=\"plain\" @spacing=\"-1\" data-test-prev />\n <IconButton @push={{this.next}} @icon={{NextIcon}} @label={{this.forwardLabel}} @importance=\"plain\" @spacing=\"-1\" data-test-next />\n </span>\n </div>\n ", {
107
+ strictMode: true,
108
+ scope: () => ({
109
+ styles,
110
+ Select,
111
+ gt,
112
+ NumberInput,
113
+ range,
114
+ asNumber,
115
+ IconButton,
116
+ PrevIcon,
117
+ NextIcon
118
+ })
119
+ }), this);
120
+ }
121
+ }
122
+
123
+ export { Pagination as P };
124
+ //# sourceMappingURL=pagination-DCMxI10i.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pagination-DCMxI10i.js","sources":["../src/components/navigation/-pagination.ts","../src/components/navigation/pagination.gts"],"sourcesContent":["export const FirstIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"256\" height=\"256\" viewBox=\"0 0 256 256\"><path fill=\"currentColor\" d=\"M200 48v160a8 8 0 0 1-13.66 5.66l-80-80a8 8 0 0 1 0-11.32l80-80A8 8 0 0 1 200 48M72 40a8 8 0 0 0-8 8v160a8 8 0 0 0 16 0V48a8 8 0 0 0-8-8\"/></svg>`;\nexport const PrevIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"256\" height=\"256\" viewBox=\"0 0 256 256\"><path fill=\"currentColor\" d=\"M168 48v160a8 8 0 0 1-13.66 5.66l-80-80a8 8 0 0 1 0-11.32l80-80A8 8 0 0 1 168 48\"/></svg>`;\nexport const NextIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"256\" height=\"256\" viewBox=\"0 0 256 256\"><path fill=\"currentColor\" d=\"m181.66 133.66l-80 80A8 8 0 0 1 88 208V48a8 8 0 0 1 13.66-5.66l80 80a8 8 0 0 1 0 11.32\"/></svg>`;\nexport const LastIcon = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"256\" height=\"256\" viewBox=\"0 0 256 256\"><path fill=\"currentColor\" d=\"M149.66 122.34a8 8 0 0 1 0 11.32l-80 80A8 8 0 0 1 56 208V48a8 8 0 0 1 13.66-5.66ZM184 40a8 8 0 0 0-8 8v160a8 8 0 0 0 16 0V48a8 8 0 0 0-8-8\"/></svg>`;\n\nexport const LABELS = {\n backward: 'Previous page',\n first: 'First page',\n forward: 'Next page',\n last: 'Last page',\n itemPerPage: 'Items per page:',\n itemRange: (min: number, max: number, total: number) => `${min} – ${max} of ${total} items`,\n item: (min: number, max: number) => `${min} – ${max} items`,\n page: (page: number) => `page ${page}`,\n pageRange: (total: number) => `of ${total} ${total === 1 ? 'page' : 'pages'}`,\n pageNumber: 'Page Number'\n};\n","import Component from '@glimmer/component';\nimport { tracked } from '@glimmer/tracking';\n\nimport styles from '@hokulea/core/navigation.module.css';\n\nimport { asNumber, gt, range } from '../../-private/helpers.ts';\nimport { IconButton } from '../actions/icon-button.gts';\nimport { NumberInput } from '../controls/number-input.gts';\nimport { Select } from '../controls/select.gts';\nimport { LABELS, NextIcon, PrevIcon } from './-pagination.ts';\n\ninterface PaginationSignature {\n Element: HTMLElement;\n Args: {\n backwardLabel?: string;\n\n forwardLabel?: string;\n\n change?: (value: { page: number; pageSize: number }) => void;\n\n /**\n * The translatable text indicating the number of items per page.\n */\n itemsPerPageLabel?: string;\n /**\n * The function returning a translatable text showing where the current page is,\n * in a manner of the range of items.\n */\n itemRangeLabel?: (min: number, max: number, total: number) => string;\n itemLabel?: (min: number, max: number) => string;\n\n /**\n * The current page.\n */\n page?: number;\n\n /**\n * The number dictating how many items a page contains.\n */\n pageSize: number;\n\n /**\n * The choices for `pageSize`.\n */\n pageSizes?: number[] | { label: string; value: number }[];\n /**\n * The translatable text showing the current page.\n */\n pageLabel?: (page: number) => string;\n /**\n * A function returning PII showing where the current page is.\n */\n pageRangeLabel?: (total: number) => string;\n pageNumberLabel?: string;\n /**\n * The total number of items.\n */\n totalItems?: number;\n };\n}\n\nexport class Pagination extends Component<PaginationSignature> {\n @tracked total = 0;\n\n get minItems() {\n return (this.page - 1) * this.args.pageSize + 1;\n }\n\n get maxItems() {\n return this.page * this.args.pageSize;\n }\n\n get pages(): number | undefined {\n if (this.args.totalItems) {\n return Math.ceil(this.args.totalItems / this.args.pageSize);\n }\n\n return undefined;\n }\n\n get page() {\n return this.args.page ?? 1;\n }\n\n get itemsPerPageLabel() {\n return this.args.itemsPerPageLabel ?? LABELS.itemPerPage;\n }\n\n get itemRangeLabel() {\n return (this.args.itemRangeLabel ?? LABELS.itemRange)(\n this.minItems,\n this.maxItems,\n this.args.totalItems ?? 1\n );\n }\n\n get itemLabel() {\n return (this.args.itemLabel ?? LABELS.item)(this.minItems, this.maxItems);\n }\n\n get pageLabel() {\n return (this.args.pageLabel ?? LABELS.page)(this.page);\n }\n\n get pageNumberLabel() {\n return this.args.pageNumberLabel ?? LABELS.pageNumber;\n }\n\n get pageRangeLabel() {\n return (this.args.pageRangeLabel ?? LABELS.pageRange)(this.pages ?? 0);\n }\n\n get pageSizeOptions() {\n return (this.args.pageSizes ?? []).map((i) =>\n typeof i === 'object' ? i : { value: i, label: i }\n );\n }\n\n get backwardLabel() {\n return this.args.backwardLabel ?? LABELS.backward;\n }\n\n get forwardLabel() {\n return this.args.forwardLabel ?? LABELS.forward;\n }\n\n changePage = (page?: number) => {\n if (page) {\n this.args.change?.({\n page: this.pages ? Math.min(page, this.pages) : page,\n pageSize: this.args.pageSize\n });\n }\n };\n\n changePageSize = (pageSize: string) => {\n this.args.change?.({\n page: this.page,\n pageSize: Number.parseInt(pageSize)\n });\n };\n\n prev = () => {\n if (this.page > 1) {\n this.changePage(this.page - 1);\n }\n };\n\n next = () => {\n if (this.pages) {\n if (this.page < this.pages) {\n this.changePage(this.page + 1);\n }\n } else {\n this.changePage(this.page + 1);\n }\n };\n\n <template>\n <div class={{styles.pagination}} data-test-pagination>\n {{#if @pageSizes}}\n <span part=\"page-size\">\n {{this.itemsPerPageLabel}}\n\n {{! @glint-ignore }}\n <Select @spacing=\"-1\" @value={{@pageSize}} @update={{this.changePageSize}} as |s|>\n {{#each this.pageSizeOptions as |o|}}\n <s.Option @value={{o.value}}>{{o.label}}</s.Option>\n {{/each}}\n </Select>\n </span>\n {{/if}}\n <span part=\"items\">\n {{#if @totalItems}}\n {{this.itemRangeLabel}}\n {{else}}\n {{this.itemLabel}}\n {{/if}}\n </span>\n <span part=\"page\">\n {{#if @totalItems}}\n {{#if (gt this.pages 20)}}\n <NumberInput @spacing=\"-1\" @value={{this.page}} @update={{this.changePage}} />\n {{else}}\n {{! @glint-ignore }}\n <Select @spacing=\"-1\" @value={{this.page}} @update={{this.changePage}} as |s|>\n {{#each (range (asNumber this.pages)) as |p|}}\n <s.Option @value={{p}}>{{p}}</s.Option>\n {{/each}}\n </Select>\n {{/if}}\n {{this.pageRangeLabel}}\n {{else}}\n {{this.pageLabel}}\n {{/if}}\n </span>\n <span part=\"nav\">\n <IconButton\n @push={{this.prev}}\n @icon={{PrevIcon}}\n @label={{this.backwardLabel}}\n @importance=\"plain\"\n @spacing=\"-1\"\n data-test-prev\n />\n <IconButton\n @push={{this.next}}\n @icon={{NextIcon}}\n @label={{this.forwardLabel}}\n @importance=\"plain\"\n @spacing=\"-1\"\n data-test-next\n />\n </span>\n </div>\n </template>\n}\n"],"names":["PrevIcon","NextIcon","LABELS","backward","first","forward","last","itemPerPage","itemRange","min","max","total","item","page","pageRange","pageNumber","Pagination","Component","g","prototype","tracked","i","void 0","minItems","args","pageSize","maxItems","pages","totalItems","Math","ceil","undefined","itemsPerPageLabel","itemRangeLabel","itemLabel","pageLabel","pageNumberLabel","pageRangeLabel","pageSizeOptions","pageSizes","map","value","label","backwardLabel","forwardLabel","changePage","change","changePageSize","Number","parseInt","prev","next","setComponentTemplate","precompileTemplate","strictMode","scope","styles","Select","gt","NumberInput","range","asNumber","IconButton"],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { on } from '@ember/modifier';
2
+ import styles from '@hokulea/core/controls.module.css';
3
+ import { p as pick } from './helpers-D4So5-uK.js';
4
+ import { precompileTemplate } from '@ember/template-compilation';
5
+ import { setComponentTemplate } from '@ember/component';
6
+ import templateOnly from '@ember/component/template-only';
7
+
8
+ const PasswordInput = setComponentTemplate(precompileTemplate("\n <input class={{styles.input}} type=\"password\" value={{@value}} disabled={{@disabled}} data-spacing={{@spacing}} data-test-input {{on \"input\" (pick \"target.value\" @update) capture=true}} ...attributes />\n", {
9
+ strictMode: true,
10
+ scope: () => ({
11
+ styles,
12
+ on,
13
+ pick
14
+ })
15
+ }), templateOnly());
16
+
17
+ export { PasswordInput as P };
18
+ //# sourceMappingURL=password-input-DV5yb10h.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"password-input-DV5yb10h.js","sources":["../src/components/controls/password-input.gts"],"sourcesContent":["import { on } from '@ember/modifier';\n\nimport styles from '@hokulea/core/controls.module.css';\n\nimport { pick } from '../../-private/helpers.ts';\n\nimport type { InputArgs } from './-input.ts';\nimport type { TOC } from '@ember/component/template-only';\n\nexport interface PasswordInputSignature {\n Element: HTMLInputElement;\n Args: InputArgs<string>;\n}\n\nexport const PasswordInput: TOC<PasswordInputSignature> = <template>\n <input\n class={{styles.input}}\n type=\"password\"\n value={{@value}}\n disabled={{@disabled}}\n data-spacing={{@spacing}}\n data-test-input\n {{on \"input\" (pick \"target.value\" @update) capture=true}}\n ...attributes\n />\n</template>;\n"],"names":["PasswordInput","setComponentTemplate","precompileTemplate","strictMode","scope","styles","on","pick","templateOnly"],"mappings":";;;;;;;MAcaA,aAAmB,GAAAC,oBAAA,CAA0BC,kBAAA,CAAA,wNAAA,EAW1D;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;IAAAC,MAAA;IAAAC,EAAA;AAAAC,IAAAA;AAAA,GAAA;AAAU,CAAA,CAAA,EAAAC,YAAA,EAAA;;;;"}
@@ -0,0 +1,18 @@
1
+ import { on } from '@ember/modifier';
2
+ import styles from '@hokulea/core/controls.module.css';
3
+ import { p as pick } from './helpers-D4So5-uK.js';
4
+ import { precompileTemplate } from '@ember/template-compilation';
5
+ import { setComponentTemplate } from '@ember/component';
6
+ import templateOnly from '@ember/component/template-only';
7
+
8
+ const PhoneInput = setComponentTemplate(precompileTemplate("\n <input class={{styles.input}} type=\"tel\" value={{@value}} disabled={{@disabled}} data-spacing={{@spacing}} data-test-input {{on \"input\" (pick \"target.value\" @update) capture=true}} ...attributes />\n", {
9
+ strictMode: true,
10
+ scope: () => ({
11
+ styles,
12
+ on,
13
+ pick
14
+ })
15
+ }), templateOnly());
16
+
17
+ export { PhoneInput as P };
18
+ //# sourceMappingURL=phone-input-Uv5v9hK9.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"phone-input-Uv5v9hK9.js","sources":["../src/components/controls/phone-input.gts"],"sourcesContent":["import { on } from '@ember/modifier';\n\nimport styles from '@hokulea/core/controls.module.css';\n\nimport { pick } from '../../-private/helpers.ts';\n\nimport type { InputArgs } from './-input.ts';\nimport type { TOC } from '@ember/component/template-only';\n\nexport interface PhoneInputSignature {\n Element: HTMLInputElement;\n Args: InputArgs<string>;\n}\n\nexport const PhoneInput: TOC<PhoneInputSignature> = <template>\n <input\n class={{styles.input}}\n type=\"tel\"\n value={{@value}}\n disabled={{@disabled}}\n data-spacing={{@spacing}}\n data-test-input\n {{on \"input\" (pick \"target.value\" @update) capture=true}}\n ...attributes\n />\n</template>;\n"],"names":["PhoneInput","setComponentTemplate","precompileTemplate","strictMode","scope","styles","on","pick","templateOnly"],"mappings":";;;;;;;MAcaA,UAAgB,GAAAC,oBAAA,CAAuBC,kBAAA,CAAA,mNAAA,EAWpD;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;IAAAC,MAAA;IAAAC,EAAA;AAAAC,IAAAA;AAAA,GAAA;AAAU,CAAA,CAAA,EAAAC,YAAA,EAAA;;;;"}
@@ -0,0 +1,14 @@
1
+ import styles from '@hokulea/core/windows.module.css';
2
+ import { precompileTemplate } from '@ember/template-compilation';
3
+ import { setComponentTemplate } from '@ember/component';
4
+ import templateOnly from '@ember/component/template-only';
5
+
6
+ const Popover = setComponentTemplate(precompileTemplate("\n <div class={{styles.popover}} data-test-popover ...attributes>\n {{yield}}\n </div>\n", {
7
+ strictMode: true,
8
+ scope: () => ({
9
+ styles
10
+ })
11
+ }), templateOnly());
12
+
13
+ export { Popover as P };
14
+ //# sourceMappingURL=popover-B6j413u9.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"popover-B6j413u9.js","sources":["../src/components/windows/popover.gts"],"sourcesContent":["import styles from '@hokulea/core/windows.module.css';\n\nimport type { TOC } from '@ember/component/template-only';\n\nexport interface PopoverSignature {\n Element: HTMLDivElement;\n Blocks: {\n default: [];\n };\n}\n\nexport const Popover: TOC<PopoverSignature> = <template>\n <div class={{styles.popover}} data-test-popover ...attributes>\n {{yield}}\n </div>\n</template>;\n"],"names":["Popover","setComponentTemplate","precompileTemplate","strictMode","scope","styles","templateOnly"],"mappings":";;;;;MAWaA,OAAa,GAAAC,oBAAA,CAAoBC,kBAAA,CAAA,+FAAA,EAI9C;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;AAAAC,IAAAA;AAAA,GAAA;AAAU,CAAA,CAAA,EAAAC,YAAA,EAAA;;;;"}
@@ -0,0 +1,24 @@
1
+ import { on } from '@ember/modifier';
2
+ import { CommandElement } from 'ember-command';
3
+ import { element } from 'ember-element-helper';
4
+ import { link, Link } from 'ember-link';
5
+ import { precompileTemplate } from '@ember/template-compilation';
6
+ import { setComponentTemplate } from '@ember/component';
7
+ import templateOnly from '@ember/component/template-only';
8
+
9
+ const isActive = commandable => {
10
+ return commandable instanceof Link && commandable.isActive;
11
+ };
12
+ const PushElement = setComponentTemplate(precompileTemplate("\n {{#if @href}}\n {{#let (link @href) as |l|}}\n <a href={{l.url}} {{on \"click\" l.open}} aria-current=\"{{if (isActive l) \"page\"}}\" ...attributes>\n {{yield}}\n </a>\n {{/let}}\n {{else if @push}}\n <CommandElement @element={{@element}} @command={{@push}} aria-current=\"{{if (isActive @push) \"page\"}}\" ...attributes>\n {{yield}}\n </CommandElement>\n {{else}}\n {{#let (if @element @element (element \"span\")) as |Element|}}\n <Element ...attributes>\n {{yield}}\n </Element>\n {{/let}}\n {{/if}}\n", {
13
+ strictMode: true,
14
+ scope: () => ({
15
+ link,
16
+ isActive,
17
+ on,
18
+ CommandElement,
19
+ element
20
+ })
21
+ }), templateOnly());
22
+
23
+ export { PushElement as P, isActive as i };
24
+ //# sourceMappingURL=push-DnJFFc_p.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"push-DnJFFc_p.js","sources":["../src/-private/push.gts"],"sourcesContent":["import { on } from '@ember/modifier';\n\nimport { type CommandAction, CommandElement } from 'ember-command';\nimport { element, type ElementFromTagName, type ElementSignature } from 'ember-element-helper';\nimport { Link, link } from 'ember-link';\n\nimport type { TOC } from '@ember/component/template-only';\n\nexport const isActive = (commandable: CommandAction) => {\n return commandable instanceof Link && commandable.isActive;\n};\n\nexport interface PushArgs {\n push?: CommandAction;\n href?: string;\n}\n\ninterface PushSignature<T extends string = 'span'> {\n Element: HTMLButtonElement | HTMLAnchorElement | ElementFromTagName<T>;\n Args: PushArgs & {\n element?: ElementSignature<'a' | 'button' | T>['Return'];\n };\n Blocks: {\n default: [];\n };\n}\n\nexport const PushElement: TOC<PushSignature> = <template>\n {{#if @href}}\n {{#let (link @href) as |l|}}\n <a\n href={{l.url}}\n {{on \"click\" l.open}}\n aria-current=\"{{if (isActive l) 'page'}}\"\n ...attributes\n >\n {{yield}}\n </a>\n {{/let}}\n {{else if @push}}\n <CommandElement\n @element={{@element}}\n @command={{@push}}\n aria-current=\"{{if (isActive @push) 'page'}}\"\n ...attributes\n >\n {{yield}}\n </CommandElement>\n {{else}}\n {{#let (if @element @element (element \"span\")) as |Element|}}\n <Element ...attributes>\n {{yield}}\n </Element>\n {{/let}}\n {{/if}}\n</template>;\n"],"names":["isActive","commandable","Link","PushElement","setComponentTemplate","precompileTemplate","strictMode","scope","link","on","CommandElement","element","templateOnly"],"mappings":";;;;;;;;AAQO,MAAMA,QAAA,GAAYC,WAAa,IAAA;AACpC,EAAA,OAAOA,WAAA,YAAuBC,IAAA,IAAQD,WAAA,CAAYD,QAAQ;AAC5D;MAiBaG,WAAiB,GAAAC,oBAAA,CAAiBC,kBAAA,CAAA,4jBAAA,EA4B/C;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;IAAAC,IAAA;IAAAR,QAAA;IAAAS,EAAA;IAAAC,cAAA;AAAAC,IAAAA;AAAA,GAAA;AAAU,CAAA,CAAA,EAAAC,YAAA,EAAA;;;;"}
@@ -0,0 +1,18 @@
1
+ import { on } from '@ember/modifier';
2
+ import styles from '@hokulea/core/controls.module.css';
3
+ import { p as pick } from './helpers-D4So5-uK.js';
4
+ import { precompileTemplate } from '@ember/template-compilation';
5
+ import { setComponentTemplate } from '@ember/component';
6
+ import templateOnly from '@ember/component/template-only';
7
+
8
+ const Radio = setComponentTemplate(precompileTemplate("\n <input class={{styles.choice}} type=\"radio\" checked={{@value}} disabled={{@disabled}} data-spacing={{@spacing}} data-test-choice {{on \"input\" (pick \"target.checked\" @update) capture=true}} ...attributes />\n", {
9
+ strictMode: true,
10
+ scope: () => ({
11
+ styles,
12
+ on,
13
+ pick
14
+ })
15
+ }), templateOnly());
16
+
17
+ export { Radio as R };
18
+ //# sourceMappingURL=radio-CLF40kob.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio-CLF40kob.js","sources":["../src/components/controls/radio.gts"],"sourcesContent":["import { on } from '@ember/modifier';\n\nimport styles from '@hokulea/core/controls.module.css';\n\nimport { pick } from '../../-private/helpers.ts';\n\nimport type { InputArgs } from './-input.ts';\nimport type { TOC } from '@ember/component/template-only';\n\nexport interface RadioSignature {\n Element: HTMLInputElement;\n Args: InputArgs<boolean>;\n}\n\nexport const Radio: TOC<RadioSignature> = <template>\n <input\n class={{styles.choice}}\n type=\"radio\"\n checked={{@value}}\n disabled={{@disabled}}\n data-spacing={{@spacing}}\n data-test-choice\n {{on \"input\" (pick \"target.checked\" @update) capture=true}}\n ...attributes\n />\n</template>;\n"],"names":["Radio","setComponentTemplate","precompileTemplate","strictMode","scope","styles","on","pick","templateOnly"],"mappings":";;;;;;;MAcaA,KAAW,GAAAC,oBAAA,CAAkBC,kBAAA,CAAA,2NAAA,EAW1C;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;IAAAC,MAAA;IAAAC,EAAA;AAAAC,IAAAA;AAAA,GAAA;AAAU,CAAA,CAAA,EAAAC,YAAA,EAAA;;;;"}
@@ -0,0 +1,37 @@
1
+ import { on } from '@ember/modifier';
2
+ import { modifier } from 'ember-modifier';
3
+ import styles from '@hokulea/core/controls.module.css';
4
+ import { p as pick } from './helpers-D4So5-uK.js';
5
+ import { p as pickAsNumber } from './-input-DGR-n9U_.js';
6
+ import { precompileTemplate } from '@ember/template-compilation';
7
+ import { setComponentTemplate } from '@ember/component';
8
+ import templateOnly from '@ember/component/template-only';
9
+
10
+ function applyProgressStyle(range, value) {
11
+ const min = Number.parseFloat(range.min) || 0;
12
+ const max = Number.parseFloat(range.max) || 100;
13
+ const currentVal = value ?? Number.parseFloat(range.value);
14
+ const progress = (currentVal - min) / (max - min) * 100;
15
+ range.style.setProperty('--_hokulea-slider-progress', `${progress}%`);
16
+ }
17
+ const progressStyle = modifier((element, [value]) => {
18
+ applyProgressStyle(element, value);
19
+ const listenForProgressChange = () => {
20
+ applyProgressStyle(element);
21
+ };
22
+ element.addEventListener('input', listenForProgressChange);
23
+ return () => element.removeEventListener('input', listenForProgressChange);
24
+ });
25
+ const RangeInput = setComponentTemplate(precompileTemplate("\n <input class={{styles.range}} type=\"range\" value={{@value}} disabled={{@disabled}} data-test-input data-orientation={{@orientation}} {{on \"input\" (pick \"target.value\" (pickAsNumber @update)) capture=true}} {{progressStyle @value}} ...attributes />\n", {
26
+ strictMode: true,
27
+ scope: () => ({
28
+ styles,
29
+ on,
30
+ pick,
31
+ pickAsNumber,
32
+ progressStyle
33
+ })
34
+ }), templateOnly());
35
+
36
+ export { RangeInput as R };
37
+ //# sourceMappingURL=range-input-BIb7GkKH.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"range-input-BIb7GkKH.js","sources":["../src/components/controls/range-input.gts"],"sourcesContent":["import { on } from '@ember/modifier';\n\nimport { modifier } from 'ember-modifier';\n\nimport styles from '@hokulea/core/controls.module.css';\n\nimport { pick } from '../../-private/helpers.ts';\nimport { pickAsNumber } from './-input.ts';\n\nimport type { InputArgs } from './-input.ts';\nimport type { TOC } from '@ember/component/template-only';\n\nfunction applyProgressStyle(range: HTMLInputElement, value?: number) {\n const min = Number.parseFloat(range.min) || 0;\n const max = Number.parseFloat(range.max) || 100;\n const currentVal = value ?? Number.parseFloat(range.value);\n const progress = ((currentVal - min) / (max - min)) * 100;\n\n range.style.setProperty('--_hokulea-slider-progress', `${progress}%`);\n}\n\nconst progressStyle = modifier((element: HTMLInputElement, [value]: [number?]) => {\n applyProgressStyle(element, value);\n\n const listenForProgressChange = () => {\n applyProgressStyle(element);\n };\n\n element.addEventListener('input', listenForProgressChange);\n\n return () => element.removeEventListener('input', listenForProgressChange);\n});\n\nexport interface RangeInputSignature {\n Element: HTMLInputElement;\n Args: Omit<InputArgs<number>, 'spacing'> & {\n min?: number;\n max?: number;\n step?: number | 'any';\n orientation?: 'horizontal' | 'vertical';\n };\n}\n\nexport const RangeInput: TOC<RangeInputSignature> = <template>\n <input\n class={{styles.range}}\n type=\"range\"\n value={{@value}}\n disabled={{@disabled}}\n data-test-input\n data-orientation={{@orientation}}\n {{on \"input\" (pick \"target.value\" (pickAsNumber @update)) capture=true}}\n {{progressStyle @value}}\n ...attributes\n />\n</template>;\n"],"names":["applyProgressStyle","range","value","min","Number","parseFloat","max","currentVal","progress","style","setProperty","progressStyle","modifier","element","listenForProgressChange","addEventListener","removeEventListener","RangeInput","setComponentTemplate","precompileTemplate","strictMode","scope","styles","on","pick","pickAsNumber","templateOnly"],"mappings":";;;;;;;;;AAYA,SAASA,kBAAAA,CAAmBC,KAAuB,EAAEC,KAAc,EAAA;EACjE,MAAMC,MAAMC,MAAA,CAAOC,UAAU,CAACJ,KAAA,CAAME,GAAG,CAAA,IAAK,CAAA;EAC5C,MAAMG,MAAMF,MAAA,CAAOC,UAAU,CAACJ,KAAA,CAAMK,GAAG,CAAA,IAAK,GAAA;EAC5C,MAAMC,aAAaL,KAAA,IAASE,MAAA,CAAOC,UAAU,CAACJ,MAAMC,KAAK,CAAA;AACzD,EAAA,MAAMM,QAAA,GAAY,CAACD,UAAA,GAAaJ,GAAG,KAAKG,GAAA,GAAMH,GAAG,CAAC,GAAI,GAAA;EAEtDF,KAAA,CAAMQ,KAAK,CAACC,WAAW,CAAC,8BAA8B,CAAA,EAAGF,QAAA,CAAA,CAAA,CAAW,CAAA;AACtE;AAEA,MAAMG,aAAA,GAAgBC,SAAS,CAACC,SAA2B,CAACX,KAAA,CAAiB,KAAA;AAC3EF,EAAAA,kBAAA,CAAmBa,OAAA,EAASX,KAAA,CAAA;EAE5B,MAAMY,uBAAA,GAA0BA,MAAA;IAC9Bd,kBAAA,CAAmBa,OAAA,CAAA;EACrB,CAAA;AAEAA,EAAAA,OAAA,CAAQE,gBAAgB,CAAC,OAAA,EAASD,uBAAA,CAAA;EAElC,OAAO,MAAMD,OAAA,CAAQG,mBAAmB,CAAC,OAAA,EAASF,uBAAA,CAAA;AACpD,CAAA,CAAA;MAYaG,UAAgB,GAAAC,oBAAA,CAAuBC,kBAAA,CAAA,qQAAA,EAYpD;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;IAAAC,MAAA;IAAAC,EAAA;IAAAC,IAAA;IAAAC,YAAA;AAAAd,IAAAA;AAAA,GAAA;AAAU,CAAA,CAAA,EAAAe,YAAA,EAAA;;;;"}
@@ -0,0 +1,14 @@
1
+ import { LinkManagerService } from 'ember-link';
2
+ import PortalService from 'ember-stargate/services/-portal';
3
+ import { buildRegistry } from 'ember-strict-application-resolver/build-registry';
4
+ import HokuleaService from './services/-hokulea.js';
5
+
6
+ const hokuleaRegistry = buildRegistry({
7
+ './services/-hokulea': HokuleaService,
8
+ // external addons
9
+ './services/link-manager': LinkManagerService,
10
+ './services/-portal': PortalService
11
+ });
12
+
13
+ export { hokuleaRegistry };
14
+ //# sourceMappingURL=registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.js","sources":["../src/registry.ts"],"sourcesContent":["import { LinkManagerService } from 'ember-link';\nimport PortalService from 'ember-stargate/services/-portal';\nimport { buildRegistry } from 'ember-strict-application-resolver/build-registry';\n\nimport HokuleaService from './services/-hokulea.ts';\n\nexport const hokuleaRegistry = buildRegistry({\n './services/-hokulea': HokuleaService,\n\n // external addons\n './services/link-manager': LinkManagerService,\n './services/-portal': PortalService\n});\n"],"names":["hokuleaRegistry","buildRegistry","HokuleaService","LinkManagerService","PortalService"],"mappings":";;;;;AAMO,MAAMA,eAAe,GAAGC,aAAa,CAAC;AAC3C,EAAA,qBAAqB,EAAEC,cAAc;AAErC;AACA,EAAA,yBAAyB,EAAEC,kBAAkB;AAC7C,EAAA,oBAAoB,EAAEC;AACxB,CAAC;;;;"}
@@ -0,0 +1,25 @@
1
+ import { assert } from '@ember/debug';
2
+ import { element } from 'ember-element-helper';
3
+ import styles$1 from '@hokulea/core/content.module.css';
4
+ import styles from '@hokulea/core/layouts.module.css';
5
+ import { precompileTemplate } from '@ember/template-compilation';
6
+ import { setComponentTemplate } from '@ember/component';
7
+ import templateOnly from '@ember/component/template-only';
8
+
9
+ function elementForLevel(level) {
10
+ const lvl = level ? Number.parseInt(level) : 2;
11
+ assert(`@level for <Section> must be between 1 and 6, received '${lvl}'`, lvl >= 1 && lvl <= 6);
12
+ return `h${lvl}`;
13
+ }
14
+ const Section = setComponentTemplate(precompileTemplate("\n <section class=\"{{styles.section}} {{layouts.flow}}\" data-test-section ...attributes>\n {{#if @title}}\n <header data-test-section=\"header\" part=\"header\">\n {{#if @title}}\n {{#let (element (elementForLevel @level)) as |Headline|}}\n <Headline data-test-section=\"title\" class={{styles.sectionTitle}}>{{@title}}</Headline>\n {{/let}}\n {{/if}}\n </header>\n {{/if}}\n\n {{#if (has-block)}}\n {{yield}}\n {{/if}}\n </section>\n", {
15
+ strictMode: true,
16
+ scope: () => ({
17
+ styles: styles$1,
18
+ layouts: styles,
19
+ element,
20
+ elementForLevel
21
+ })
22
+ }), templateOnly());
23
+
24
+ export { Section as S };
25
+ //# sourceMappingURL=section-BAdmc3Yn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"section-BAdmc3Yn.js","sources":["../src/components/content/section.gts"],"sourcesContent":["import { assert } from '@ember/debug';\n\nimport { element } from 'ember-element-helper';\n\n// eslint-disable-next-line import-x/no-duplicates\nimport styles from '@hokulea/core/content.module.css';\n// eslint-disable-next-line import-x/no-duplicates\nimport layouts from '@hokulea/core/layouts.module.css';\n\nimport type { TOC } from '@ember/component/template-only';\n\nexport interface SectionSignature {\n Element: HTMLElement;\n Args: {\n title?: string;\n /**\n * The level of the component, 1-6 as in `<h1>` to `<h6>`\n *\n * @defaultValue 2\n */\n level?: string;\n };\n Blocks: {\n default: [];\n };\n}\n\nfunction elementForLevel(level?: string) {\n const lvl = level ? Number.parseInt(level) : 2;\n\n assert(`@level for <Section> must be between 1 and 6, received '${lvl}'`, lvl >= 1 && lvl <= 6);\n\n return `h${lvl}`;\n}\n\nexport const Section: TOC<SectionSignature> = <template>\n <section class=\"{{styles.section}} {{layouts.flow}}\" data-test-section ...attributes>\n {{#if @title}}\n <header data-test-section=\"header\" part=\"header\">\n {{#if @title}}\n {{#let (element (elementForLevel @level)) as |Headline|}}\n <Headline data-test-section=\"title\" class={{styles.sectionTitle}}>{{@title}}</Headline>\n {{/let}}\n {{/if}}\n </header>\n {{/if}}\n\n {{#if (has-block)}}\n {{yield}}\n {{/if}}\n </section>\n</template>;\n"],"names":["elementForLevel","level","lvl","Number","parseInt","assert","Section","setComponentTemplate","precompileTemplate","strictMode","scope","styles","layouts","element","templateOnly"],"mappings":";;;;;;;;AA2BA,SAASA,eAAAA,CAAgBC,KAAc,EAAA;EACrC,MAAMC,GAAA,GAAMD,KAAA,GAAQE,MAAA,CAAOC,QAAQ,CAACH,KAAA,CAAA,GAAS,CAAA;AAE7CI,EAAAA,MAAA,CAAO,CAAA,wDAAA,EAA2DH,GAAA,CAAA,CAAA,CAAM,EAAEA,GAAA,IAAO,CAAA,IAAKA,GAAA,IAAO,CAAA,CAAA;EAE7F,OAAO,CAAA,CAAA,EAAIA,GAAA,CAAA,CAAK;AAClB;MAEaI,OAAa,GAAAC,oBAAA,CAAoBC,kBAAA,CAAA,8fAAA,EAgB9C;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;YAAAC,QAAA;aAAAC,MAAA;IAAAC,OAAA;AAAAb,IAAAA;AAAA,GAAA;AAAU,CAAA,CAAA,EAAAc,YAAA,EAAA;;;;"}
@@ -0,0 +1,25 @@
1
+ import { element } from 'ember-element-helper';
2
+ import styles from '@hokulea/core/layouts.module.css';
3
+ import typo from '@hokulea/core/typography.module.css';
4
+ import { o as or } from './helpers-D4So5-uK.js';
5
+ import { N as NavLink } from './nav-link-CDtYj6HW.js';
6
+ import { P as PageDestructor, a as PageElement } from './pages-DgHJEvSy.js';
7
+ import { precompileTemplate } from '@ember/template-compilation';
8
+ import { setComponentTemplate } from '@ember/component';
9
+ import templateOnly from '@ember/component/template-only';
10
+
11
+ const SectionedPage = setComponentTemplate(precompileTemplate("\n {{#let (if @element @element (element (pageElement))) as |Element|}}\n <Element class={{styles.sectionedPage}} {{pageDestructor}} ...attributes data-test-page>\n {{#if (or @title @description (has-block \"title\") (has-block \"description\") (has-block \"nav\"))}}\n <header class={{styles.pageContent}}>\n <h1 class={{typo.display}}>\n {{#if (has-block \"title\")}}\n {{yield to=\"title\"}}\n {{else if @title}}\n {{@title}}\n {{/if}}\n </h1>\n\n {{#if (or (has-block \"description\") @description)}}\n <p>\n {{#if (has-block \"description\")}}\n {{yield to=\"description\"}}\n {{else if @description}}\n {{@description}}\n {{/if}}\n </p>\n {{/if}}\n\n {{#if (has-block \"nav\")}}\n <nav>\n {{yield NavLink to=\"nav\"}}\n </nav>\n {{/if}}\n </header>\n {{/if}}\n\n <div class=\"{{styles.pageContent}} {{styles.flow}}\" part=\"content\">\n {{#if (has-block \"content\")}}\n {{yield to=\"content\"}}\n {{else if (has-block)}}\n {{yield}}\n {{/if}}\n </div>\n </Element>\n {{/let}}\n", {
12
+ strictMode: true,
13
+ scope: () => ({
14
+ element,
15
+ pageElement: PageElement,
16
+ styles,
17
+ pageDestructor: PageDestructor,
18
+ or,
19
+ typo,
20
+ NavLink
21
+ })
22
+ }), templateOnly());
23
+
24
+ export { SectionedPage as S };
25
+ //# sourceMappingURL=sectioned-page-CgINWVQ2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sectioned-page-CgINWVQ2.js","sources":["../src/components/layouts/sectioned-page.gts"],"sourcesContent":["import { element } from 'ember-element-helper';\n\n// eslint-disable-next-line import-x/no-duplicates\nimport styles from '@hokulea/core/layouts.module.css';\n// eslint-disable-next-line import-x/no-duplicates\nimport typo from '@hokulea/core/typography.module.css';\n\nimport { or } from '../../-private/helpers.ts';\nimport { NavLink } from '../navigation/nav-link.gts';\nimport { pageDestructor, pageElement } from './pages.ts';\n\nimport type { TOC } from '@ember/component/template-only';\nimport type { ComponentLike } from '@glint/template';\n\ninterface SectionedPageSignature {\n Element: HTMLElement;\n Args: {\n title?: string;\n description?: string;\n element?: ComponentLike<{ Element: HTMLElement; Blocks: { default: [] } }>;\n };\n Blocks: {\n title?: [];\n description?: [];\n nav?: [typeof NavLink];\n content?: [];\n default?: [];\n };\n}\n\nexport const SectionedPage: TOC<SectionedPageSignature> = <template>\n {{#let (if @element @element (element (pageElement))) as |Element|}}\n <Element class={{styles.sectionedPage}} {{pageDestructor}} ...attributes data-test-page>\n {{#if\n (or @title @description (has-block \"title\") (has-block \"description\") (has-block \"nav\"))\n }}\n <header class={{styles.pageContent}}>\n <h1 class={{typo.display}}>\n {{#if (has-block \"title\")}}\n {{yield to=\"title\"}}\n {{else if @title}}\n {{@title}}\n {{/if}}\n </h1>\n\n {{#if (or (has-block \"description\") @description)}}\n <p>\n {{#if (has-block \"description\")}}\n {{yield to=\"description\"}}\n {{else if @description}}\n {{@description}}\n {{/if}}\n </p>\n {{/if}}\n\n {{#if (has-block \"nav\")}}\n <nav>\n {{yield NavLink to=\"nav\"}}\n </nav>\n {{/if}}\n </header>\n {{/if}}\n\n <div class=\"{{styles.pageContent}} {{styles.flow}}\" part=\"content\">\n {{#if (has-block \"content\")}}\n {{yield to=\"content\"}}\n {{else if (has-block)}}\n {{yield}}\n {{/if}}\n </div>\n </Element>\n {{/let}}\n</template>;\n"],"names":["SectionedPage","setComponentTemplate","precompileTemplate","strictMode","scope","element","pageElement","styles","pageDestructor","or","typo","NavLink","templateOnly"],"mappings":";;;;;;;;;;MA8BaA,aAAmB,GAAAC,oBAAA,CAA0BC,kBAAA,CAAA,0xCAAA,EA0C1D;EAAAC,UAAA,EAAA,IAAA;AAAAC,EAAAA,KAAA,EAAAA,OAAA;IAAAC,OAAA;iBAAAC,WAAA;IAAAC,MAAA;oBAAAC,cAAA;IAAAC,EAAA;IAAAC,IAAA;AAAAC,IAAAA;AAAA,GAAA;AAAU,CAAA,CAAA,EAAAC,YAAA,EAAA;;;;"}
@@ -0,0 +1,42 @@
1
+ import Component from '@glimmer/component';
2
+ import { hash } from '@ember/helper';
3
+ import { on } from '@ember/modifier';
4
+ import styles from '@hokulea/core/controls.module.css';
5
+ import { precompileTemplate } from '@ember/template-compilation';
6
+ import { setComponentTemplate } from '@ember/component';
7
+ import templateOnly from '@ember/component/template-only';
8
+
9
+ const Option = setComponentTemplate(precompileTemplate("\n <option value={{@value}} selected={{@isSelected @value}} ...attributes>\n {{#if (has-block)}}\n {{yield}}\n {{else}}\n {{@value}}\n {{/if}}\n </option>\n", {
10
+ strictMode: true
11
+ }), templateOnly());
12
+ class Select extends Component {
13
+ isSelected = option => {
14
+ if (Array.isArray(this.args.value)) {
15
+ return this.args.value.includes(option);
16
+ }
17
+ return String(option) === String(this.args.value);
18
+ };
19
+ select = event => {
20
+ const select = event.target;
21
+ const selection = Array.of(...select.selectedOptions).map(option => option.value);
22
+ const value = selection.length === 1 ? selection[0] : selection;
23
+ this.args.update?.(value);
24
+ };
25
+ get spacing() {
26
+ return this.args.spacing ?? 1;
27
+ }
28
+ static {
29
+ setComponentTemplate(precompileTemplate("\n <span class={{styles.select}} data-spacing={{this.spacing}}>\n <select disabled={{@disabled}} data-test-select {{on \"input\" this.select capture=true}} ...attributes>\n {{yield (hash Option=(component Option isSelected=this.isSelected))}}\n </select>\n </span>\n ", {
30
+ strictMode: true,
31
+ scope: () => ({
32
+ styles,
33
+ on,
34
+ hash,
35
+ Option
36
+ })
37
+ }), this);
38
+ }
39
+ }
40
+
41
+ export { Select as S };
42
+ //# sourceMappingURL=select-CeO8AZMK.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select-CeO8AZMK.js","sources":["../src/components/controls/select.gts"],"sourcesContent":["import Component from '@glimmer/component';\nimport { hash } from '@ember/helper';\nimport { on } from '@ember/modifier';\n\nimport styles from '@hokulea/core/controls.module.css';\n\nimport type { TOC } from '@ember/component/template-only';\nimport type { WithBoundArgs } from '@glint/template';\nimport type { Spacing } from '@hokulea/tokens';\n\nexport type Value = string | number;\n\nexport interface OptionSignature {\n Element: HTMLOptionElement;\n Args: {\n value: Value;\n isSelected: (option: Value) => boolean;\n };\n Blocks: {\n default: [];\n };\n}\n\nconst Option: TOC<OptionSignature> = <template>\n <option value={{@value}} selected={{@isSelected @value}} ...attributes>\n {{#if (has-block)}}\n {{yield}}\n {{else}}\n {{@value}}\n {{/if}}\n </option>\n</template>;\n\nexport interface SelectSignature {\n Element: HTMLSelectElement;\n Args: {\n value?: Value | Value[];\n update?: (value: Value | Value[]) => void;\n disabled?: boolean;\n spacing?: Spacing;\n };\n Blocks: {\n default: [\n {\n Option: WithBoundArgs<typeof Option, 'isSelected'>;\n }\n ];\n };\n}\n\nexport class Select extends Component<SelectSignature> {\n isSelected = (option: Value) => {\n if (Array.isArray(this.args.value)) {\n return this.args.value.includes(option);\n }\n\n return String(option) === String(this.args.value);\n };\n\n select = (event: Event) => {\n const select = event.target as HTMLSelectElement;\n const selection = Array.of(...select.selectedOptions).map((option) => option.value);\n const value = selection.length === 1 ? (selection[0] as Value) : (selection as Value[]);\n\n this.args.update?.(value);\n };\n\n get spacing() {\n return this.args.spacing ?? 1;\n }\n\n <template>\n <span class={{styles.select}} data-spacing={{this.spacing}}>\n <select\n disabled={{@disabled}}\n data-test-select\n {{on \"input\" this.select capture=true}}\n ...attributes\n >\n {{yield (hash Option=(component Option isSelected=this.isSelected))}}\n </select>\n </span>\n </template>\n}\n"],"names":["Option","setComponentTemplate","precompileTemplate","strictMode","templateOnly","Select","Component","isSelected","option","Array","isArray","args","value","includes","String","select","event","target","selection","of","selectedOptions","map","length","update","spacing","scope","styles","on","hash"],"mappings":";;;;;;;;AAuBA,MAAMA,MAAY,GAAAC,oBAAA,CAAmBC,kBAAA,CAAA,mLAAA,EAQrC;EAAAC,UAAA,EAAA;AAAU,CAAA,CAAA,EAAAC,YAAA,EAAA,CAAA;AAmBH,MAAMC,eAAeC,SAAA,CAAU;EACpCC,UAAA,GAAcC,MAAQ,IAAA;IACpB,IAAIC,KAAA,CAAMC,OAAO,CAAC,IAAI,CAACC,IAAI,CAACC,KAAK,CAAA,EAAG;MAClC,OAAO,IAAI,CAACD,IAAI,CAACC,KAAK,CAACC,QAAQ,CAACL,MAAA,CAAA;AAClC,IAAA;AAEA,IAAA,OAAOM,OAAON,MAAA,CAAA,KAAYM,MAAA,CAAO,IAAI,CAACH,IAAI,CAACC,KAAK,CAAA;EAClD,CAAA;EAEAG,MAAA,GAAUC,KAAO,IAAA;AACf,IAAA,MAAMD,MAAA,GAASC,KAAA,CAAMC,MAAU;AAC/B,IAAA,MAAMC,SAAA,GAAYT,KAAA,CAAMU,EAAE,CAAA,GAAIJ,MAAA,CAAOK,eAAe,CAAA,CAAEC,GAAG,CAAEb,MAAA,IAAWA,MAAA,CAAOI,KAAK,CAAA;AAClF,IAAA,MAAMA,KAAA,GAAQM,SAAA,CAAUI,MAAM,KAAK,IAAKJ,SAAS,CAAC,CAAA,CAAE,GAAcA,SAAoB;AAEtF,IAAA,IAAI,CAACP,IAAI,CAACY,MAAM,GAAGX,KAAA,CAAA;EACrB,CAAA;EAEA,IAAIY,OAAAA,GAAU;AACZ,IAAA,OAAO,IAAI,CAACb,IAAI,CAACa,OAAO,IAAI,CAAA;AAC9B,EAAA;AAEA,EAAA;IAAAvB,oBAAA,CAAAC,kBAAA,CAAA,qSAAA,EAWA;MAAAC,UAAA,EAAA,IAAA;AAAAsB,MAAAA,KAAA,EAAAA,OAAA;QAAAC,MAAA;QAAAC,EAAA;QAAAC,IAAA;AAAA5B,QAAAA;AAAA,OAAA;KAAU,CAAA,EAAV,IAAW,CAAA;AAAD;AACZ;;;;"}
@@ -1,14 +1,7 @@
1
- import { tracked } from '@glimmer/tracking';
2
1
  import Service from '@ember/service';
3
- import { g, i } from 'decorator-transforms/runtime-esm';
4
2
 
5
3
  class HokuleaService extends Service {
6
- static {
7
- g(this.prototype, "pageLevel", [tracked], function () {
8
- return 0;
9
- });
10
- }
11
- #pageLevel = (i(this, "pageLevel"), void 0);
4
+ pageLevel = 0;
12
5
  }
13
6
 
14
7
  export { HokuleaService as default };
@@ -1 +1 @@
1
- {"version":3,"file":"-hokulea.js","sources":["../../src/services/-hokulea.ts"],"sourcesContent":["import { tracked } from '@glimmer/tracking';\nimport Service from '@ember/service';\n\nexport default class HokuleaService extends Service {\n @tracked pageLevel = 0;\n}\n"],"names":["HokuleaService","Service","g","prototype","tracked","i","void 0"],"mappings":";;;;AAGe,MAAMA,cAAc,SAASC,OAAO,CAAC;AAAA,EAAA;IAAAC,CAAA,CAAA,IAAA,CAAAC,SAAA,EAAA,WAAA,EAAA,CACjDC,OAAO,CAAA,EAAA,YAAA;AAAA,MAAA,OAAa,CAAC;AAAA,IAAA,CAAA,CAAA;AAAA;AAAA,EAAA,UAAA,IAAAC,CAAA,CAAA,IAAA,EAAA,WAAA,CAAA,EAAAC,MAAA;AACxB;;;;"}
1
+ {"version":3,"file":"-hokulea.js","sources":["../../src/services/-hokulea.ts"],"sourcesContent":["import Service from '@ember/service';\n\nexport default class HokuleaService extends Service {\n pageLevel = 0;\n}\n"],"names":["HokuleaService","Service","pageLevel"],"mappings":";;AAEe,MAAMA,cAAc,SAASC,OAAO,CAAC;AAClDC,EAAAA,SAAS,GAAG,CAAC;AACf;;;;"}