@davidsouther/jiffies 2.2.4 → 2.3.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 (367) hide show
  1. package/LICENSE +1 -1
  2. package/lib/cjs/assert.d.ts +2 -2
  3. package/lib/cjs/awaitable.d.ts +1 -1
  4. package/lib/cjs/components/button_bar.d.ts +2 -2
  5. package/lib/cjs/components/inline_edit.d.ts +2 -2
  6. package/lib/cjs/components/logger.d.ts +1 -1
  7. package/lib/cjs/components/select.d.ts +4 -7
  8. package/lib/cjs/components/test.d.ts +1 -1
  9. package/lib/cjs/components/virtual_scroll.d.ts +6 -4
  10. package/lib/cjs/context.d.ts +5 -9
  11. package/lib/cjs/debounce.d.ts +1 -1
  12. package/lib/cjs/diff.d.ts +2 -2
  13. package/lib/cjs/display.d.ts +1 -1
  14. package/lib/cjs/dom/css/border.d.ts +2 -2
  15. package/lib/cjs/dom/css/constants.d.ts +3 -3
  16. package/lib/cjs/dom/css/core.d.ts +1 -1
  17. package/lib/cjs/dom/css/fstyle.d.ts +2 -2
  18. package/lib/cjs/dom/css/sizing.d.ts +2 -2
  19. package/lib/cjs/dom/dom.d.ts +8 -8
  20. package/lib/cjs/dom/fc.d.ts +8 -12
  21. package/lib/cjs/dom/form/form.d.ts +5 -6
  22. package/lib/cjs/dom/html.d.ts +112 -113
  23. package/lib/cjs/dom/observable.d.ts +1 -1
  24. package/lib/cjs/dom/provide.d.ts +1 -1
  25. package/lib/cjs/dom/router/router.d.ts +2 -2
  26. package/lib/cjs/dom/svg.d.ts +64 -64
  27. package/lib/cjs/dom/types/css.d.ts +10 -32
  28. package/lib/cjs/dom/types/html.d.ts +4 -6
  29. package/lib/cjs/equal.d.ts +8 -5
  30. package/lib/cjs/flags.d.ts +1 -1
  31. package/lib/cjs/fs.d.ts +3 -3
  32. package/lib/cjs/fs_node.d.ts +1 -1
  33. package/lib/cjs/lock.d.ts +1 -1
  34. package/lib/cjs/log.d.ts +9 -9
  35. package/lib/cjs/observable/event.d.ts +2 -2
  36. package/lib/cjs/observable/observable.d.ts +37 -35
  37. package/lib/cjs/result.d.ts +21 -21
  38. package/lib/cjs/safe.d.ts +1 -1
  39. package/lib/cjs/scope/describe.d.ts +4 -4
  40. package/lib/cjs/scope/display/console.d.ts +1 -1
  41. package/lib/cjs/scope/display/dom.d.ts +2 -2
  42. package/lib/cjs/scope/display/junit.d.ts +1 -1
  43. package/lib/cjs/scope/execute.d.ts +2 -2
  44. package/lib/cjs/scope/index.d.ts +3 -3
  45. package/lib/cjs/scope/scope.d.ts +3 -3
  46. package/lib/cjs/scope/state.d.ts +1 -1
  47. package/lib/cjs/server/http/apps.d.ts +1 -1
  48. package/lib/cjs/server/http/css.d.ts +1 -1
  49. package/lib/cjs/server/http/index.d.ts +4 -9
  50. package/lib/cjs/server/http/response.d.ts +3 -3
  51. package/lib/cjs/server/http/sitemap.d.ts +1 -1
  52. package/lib/cjs/server/http/static.d.ts +1 -1
  53. package/lib/cjs/server/http/typescript.d.ts +1 -1
  54. package/lib/cjs/test_all.d.ts +9 -9
  55. package/lib/cjs/tsconfig.tsbuildinfo +1 -1
  56. package/lib/esm/assert.d.ts +2 -2
  57. package/lib/esm/awaitable.d.ts +1 -1
  58. package/lib/esm/components/button_bar.d.ts +2 -2
  59. package/lib/esm/components/inline_edit.d.ts +2 -2
  60. package/lib/esm/components/logger.d.ts +1 -1
  61. package/lib/esm/components/select.d.ts +3 -3
  62. package/lib/esm/components/test.d.ts +1 -1
  63. package/lib/esm/components/virtual_scroll.d.ts +6 -4
  64. package/lib/esm/context.d.ts +5 -9
  65. package/lib/esm/debounce.d.ts +1 -2
  66. package/lib/esm/diff.d.ts +2 -2
  67. package/lib/esm/display.d.ts +1 -1
  68. package/lib/esm/dom/css/border.d.ts +2 -2
  69. package/lib/esm/dom/css/constants.d.ts +3 -3
  70. package/lib/esm/dom/css/core.d.ts +1 -1
  71. package/lib/esm/dom/css/fstyle.d.ts +2 -2
  72. package/lib/esm/dom/css/sizing.d.ts +2 -2
  73. package/lib/esm/dom/dom.d.ts +8 -8
  74. package/lib/esm/dom/fc.d.ts +8 -12
  75. package/lib/esm/dom/form/form.d.ts +5 -6
  76. package/lib/esm/dom/html.d.ts +112 -113
  77. package/lib/esm/dom/observable.d.ts +1 -1
  78. package/lib/esm/dom/provide.d.ts +1 -1
  79. package/lib/esm/dom/router/router.d.ts +2 -2
  80. package/lib/esm/dom/svg.d.ts +64 -64
  81. package/lib/esm/dom/types/css.d.ts +10 -32
  82. package/lib/esm/dom/types/html.d.ts +4 -6
  83. package/lib/esm/equal.d.ts +8 -5
  84. package/lib/esm/flags.d.ts +1 -1
  85. package/lib/esm/fs.d.ts +3 -3
  86. package/lib/esm/fs_node.d.ts +1 -1
  87. package/lib/esm/lock.d.ts +1 -1
  88. package/lib/esm/log.d.ts +9 -9
  89. package/lib/esm/observable/event.d.ts +2 -2
  90. package/lib/esm/observable/observable.d.ts +37 -35
  91. package/lib/esm/result.d.ts +21 -21
  92. package/lib/esm/safe.d.ts +1 -1
  93. package/lib/esm/scope/describe.d.ts +4 -4
  94. package/lib/esm/scope/display/console.d.ts +1 -1
  95. package/lib/esm/scope/display/dom.d.ts +2 -2
  96. package/lib/esm/scope/display/junit.d.ts +1 -1
  97. package/lib/esm/scope/execute.d.ts +2 -2
  98. package/lib/esm/scope/index.d.ts +3 -3
  99. package/lib/esm/scope/scope.d.ts +3 -3
  100. package/lib/esm/scope/state.d.ts +1 -1
  101. package/lib/esm/server/http/apps.d.ts +1 -1
  102. package/lib/esm/server/http/css.d.ts +1 -1
  103. package/lib/esm/server/http/index.d.ts +4 -9
  104. package/lib/esm/server/http/response.d.ts +3 -3
  105. package/lib/esm/server/http/sitemap.d.ts +1 -1
  106. package/lib/esm/server/http/static.d.ts +1 -1
  107. package/lib/esm/server/http/typescript.d.ts +1 -1
  108. package/lib/esm/test_all.d.ts +9 -9
  109. package/lib/esm/tsconfig.tsbuildinfo +1 -1
  110. package/package.json +11 -9
  111. package/src/assert.ts +5 -5
  112. package/src/components/button_bar.ts +28 -30
  113. package/src/components/inline_edit.ts +8 -7
  114. package/src/components/logger.ts +6 -6
  115. package/src/components/select.ts +7 -7
  116. package/src/components/test.ts +5 -0
  117. package/src/components/virtual_scroll.test.ts +9 -6
  118. package/src/components/virtual_scroll.ts +29 -24
  119. package/src/context.test.ts +4 -4
  120. package/src/context.ts +16 -11
  121. package/src/debounce.ts +9 -3
  122. package/src/diff.test.ts +4 -4
  123. package/src/diff.ts +14 -16
  124. package/src/dom/css/border.ts +11 -11
  125. package/src/dom/css/core.ts +1 -1
  126. package/src/dom/css/fstyle.ts +4 -4
  127. package/src/dom/css/sizing.ts +1 -1
  128. package/src/dom/dom.ts +57 -47
  129. package/src/dom/fc.test.ts +8 -8
  130. package/src/dom/fc.ts +32 -35
  131. package/src/dom/form/form.app.ts +9 -9
  132. package/src/dom/form/form.ts +25 -16
  133. package/src/dom/form/index.html +3 -2
  134. package/src/dom/html.test.ts +12 -10
  135. package/src/dom/html.ts +2 -3
  136. package/src/dom/observable.test.ts +6 -6
  137. package/src/dom/observable.ts +2 -2
  138. package/src/dom/provide.ts +1 -1
  139. package/src/dom/router/link.ts +3 -3
  140. package/src/dom/router/router.ts +5 -5
  141. package/src/dom/svg.ts +7 -6
  142. package/src/dom/test.ts +3 -0
  143. package/src/dom/types/css.ts +43 -61
  144. package/src/dom/types/html.ts +2 -4
  145. package/src/dom/xml.ts +2 -2
  146. package/src/equal.test.ts +3 -3
  147. package/src/equal.ts +27 -14
  148. package/src/flags.test.ts +2 -2
  149. package/src/flags.ts +2 -2
  150. package/src/fs.test.ts +5 -5
  151. package/src/fs.ts +26 -20
  152. package/src/fs_node.ts +4 -4
  153. package/src/fs_win.test.ts +1 -1
  154. package/src/generator.test.ts +4 -3
  155. package/src/generator.ts +1 -1
  156. package/src/hooks/_notes +4 -1
  157. package/src/index.html +7 -7
  158. package/src/lock.test.ts +4 -4
  159. package/src/lock.ts +8 -7
  160. package/src/log.ts +28 -18
  161. package/src/observable/event.ts +7 -7
  162. package/src/observable/observable.test.ts +3 -3
  163. package/src/observable/observable.ts +71 -52
  164. package/src/result.test.ts +7 -10
  165. package/src/result.ts +51 -47
  166. package/src/safe.ts +1 -1
  167. package/src/scope/describe.ts +12 -11
  168. package/src/scope/display/console.ts +4 -4
  169. package/src/scope/display/dom.ts +9 -9
  170. package/src/scope/display/junit.ts +21 -24
  171. package/src/scope/execute.ts +17 -12
  172. package/src/scope/expect.ts +22 -22
  173. package/src/scope/fix.ts +10 -7
  174. package/src/scope/index.ts +3 -3
  175. package/src/scope/scope.ts +2 -2
  176. package/src/scope/state.ts +2 -2
  177. package/src/server/http/apps.ts +5 -5
  178. package/src/server/http/css.ts +10 -26
  179. package/src/server/http/index.ts +30 -24
  180. package/src/server/http/response.ts +12 -5
  181. package/src/server/http/sitemap.ts +8 -8
  182. package/src/server/http/static.ts +9 -6
  183. package/src/server/http/typescript.ts +25 -25
  184. package/src/server/main.ts +7 -4
  185. package/src/test.mjs +8 -8
  186. package/src/test_all.ts +16 -13
  187. package/src/transpile.mjs +6 -18
  188. package/build/pico.css +0 -2466
  189. package/build/pico.css.map +0 -1
  190. package/lib/cjs/assert.js +0 -46
  191. package/lib/cjs/awaitable.js +0 -2
  192. package/lib/cjs/case.js +0 -9
  193. package/lib/cjs/components/button_bar.js +0 -29
  194. package/lib/cjs/components/inline_edit.js +0 -51
  195. package/lib/cjs/components/logger.js +0 -27
  196. package/lib/cjs/components/select.js +0 -6
  197. package/lib/cjs/components/test.js +0 -7
  198. package/lib/cjs/components/virtual_scroll.js +0 -102
  199. package/lib/cjs/components/virtual_scroll.test.js +0 -22
  200. package/lib/cjs/context.js +0 -48
  201. package/lib/cjs/context.test.js +0 -48
  202. package/lib/cjs/debounce.js +0 -12
  203. package/lib/cjs/diff.js +0 -58
  204. package/lib/cjs/diff.test.js +0 -41
  205. package/lib/cjs/display.js +0 -16
  206. package/lib/cjs/dom/css/border.js +0 -33
  207. package/lib/cjs/dom/css/constants.js +0 -31
  208. package/lib/cjs/dom/css/core.js +0 -31
  209. package/lib/cjs/dom/css/fstyle.js +0 -36
  210. package/lib/cjs/dom/css/sizing.js +0 -14
  211. package/lib/cjs/dom/dom.js +0 -110
  212. package/lib/cjs/dom/fc.js +0 -39
  213. package/lib/cjs/dom/fc.test.js +0 -23
  214. package/lib/cjs/dom/form/form.app.js +0 -27
  215. package/lib/cjs/dom/form/form.js +0 -49
  216. package/lib/cjs/dom/form/form.test.js +0 -1
  217. package/lib/cjs/dom/html.js +0 -119
  218. package/lib/cjs/dom/html.test.js +0 -60
  219. package/lib/cjs/dom/observable.js +0 -10
  220. package/lib/cjs/dom/observable.test.js +0 -35
  221. package/lib/cjs/dom/provide.js +0 -12
  222. package/lib/cjs/dom/router/link.js +0 -7
  223. package/lib/cjs/dom/router/router.js +0 -55
  224. package/lib/cjs/dom/svg.js +0 -69
  225. package/lib/cjs/dom/test.js +0 -13
  226. package/lib/cjs/dom/types/css.js +0 -24
  227. package/lib/cjs/dom/types/dom.js +0 -1
  228. package/lib/cjs/dom/types/html.js +0 -2
  229. package/lib/cjs/dom/xml.js +0 -8
  230. package/lib/cjs/equal.js +0 -48
  231. package/lib/cjs/equal.test.js +0 -22
  232. package/lib/cjs/flags.js +0 -52
  233. package/lib/cjs/flags.test.js +0 -37
  234. package/lib/cjs/fs.js +0 -235
  235. package/lib/cjs/fs.test.js +0 -86
  236. package/lib/cjs/fs_node.js +0 -50
  237. package/lib/cjs/fs_win.test.js +0 -10
  238. package/lib/cjs/generator.js +0 -14
  239. package/lib/cjs/generator.test.js +0 -26
  240. package/lib/cjs/is_browser.js +0 -4
  241. package/lib/cjs/loader-register.d.mts +0 -1
  242. package/lib/cjs/loader-register.d.ts +0 -1
  243. package/lib/cjs/loader-register.js +0 -4
  244. package/lib/cjs/loader-register.mjs +0 -4
  245. package/lib/cjs/loader.d.mts +0 -23
  246. package/lib/cjs/loader.mjs +0 -41
  247. package/lib/cjs/lock.js +0 -27
  248. package/lib/cjs/lock.test.js +0 -18
  249. package/lib/cjs/log.js +0 -98
  250. package/lib/cjs/observable/event.js +0 -61
  251. package/lib/cjs/observable/observable.js +0 -363
  252. package/lib/cjs/observable/observable.test.js +0 -65
  253. package/lib/cjs/package.json +0 -1
  254. package/lib/cjs/range.js +0 -11
  255. package/lib/cjs/result.js +0 -80
  256. package/lib/cjs/result.test.js +0 -78
  257. package/lib/cjs/safe.js +0 -14
  258. package/lib/cjs/scope/describe.js +0 -73
  259. package/lib/cjs/scope/display/console.js +0 -25
  260. package/lib/cjs/scope/display/dom.js +0 -30
  261. package/lib/cjs/scope/display/junit.js +0 -21
  262. package/lib/cjs/scope/execute.js +0 -91
  263. package/lib/cjs/scope/expect.js +0 -110
  264. package/lib/cjs/scope/fix.js +0 -26
  265. package/lib/cjs/scope/index.js +0 -15
  266. package/lib/cjs/scope/scope.js +0 -2
  267. package/lib/cjs/scope/state.js +0 -12
  268. package/lib/cjs/server/http/apps.js +0 -27
  269. package/lib/cjs/server/http/css.js +0 -54
  270. package/lib/cjs/server/http/index.js +0 -77
  271. package/lib/cjs/server/http/response.js +0 -45
  272. package/lib/cjs/server/http/sitemap.js +0 -46
  273. package/lib/cjs/server/http/static.js +0 -25
  274. package/lib/cjs/server/http/typescript.js +0 -44
  275. package/lib/cjs/server/main.js +0 -14
  276. package/lib/cjs/test.mjs +0 -28
  277. package/lib/cjs/test_all.js +0 -30
  278. package/lib/cjs/transpile.mjs +0 -22
  279. package/lib/esm/assert.js +0 -38
  280. package/lib/esm/awaitable.js +0 -1
  281. package/lib/esm/case.js +0 -5
  282. package/lib/esm/components/button_bar.js +0 -27
  283. package/lib/esm/components/inline_edit.js +0 -48
  284. package/lib/esm/components/logger.js +0 -22
  285. package/lib/esm/components/select.js +0 -3
  286. package/lib/esm/components/test.js +0 -3
  287. package/lib/esm/components/virtual_scroll.js +0 -94
  288. package/lib/esm/components/virtual_scroll.test.js +0 -20
  289. package/lib/esm/context.js +0 -43
  290. package/lib/esm/context.test.js +0 -46
  291. package/lib/esm/debounce.js +0 -8
  292. package/lib/esm/diff.js +0 -54
  293. package/lib/esm/diff.test.js +0 -39
  294. package/lib/esm/display.js +0 -11
  295. package/lib/esm/dom/css/border.js +0 -27
  296. package/lib/esm/dom/css/constants.js +0 -28
  297. package/lib/esm/dom/css/core.js +0 -24
  298. package/lib/esm/dom/css/fstyle.js +0 -32
  299. package/lib/esm/dom/css/sizing.js +0 -10
  300. package/lib/esm/dom/dom.js +0 -104
  301. package/lib/esm/dom/fc.js +0 -35
  302. package/lib/esm/dom/fc.test.js +0 -21
  303. package/lib/esm/dom/form/form.app.js +0 -23
  304. package/lib/esm/dom/form/form.js +0 -34
  305. package/lib/esm/dom/form/form.test.js +0 -1
  306. package/lib/esm/dom/html.js +0 -114
  307. package/lib/esm/dom/html.test.js +0 -58
  308. package/lib/esm/dom/observable.js +0 -6
  309. package/lib/esm/dom/observable.test.js +0 -33
  310. package/lib/esm/dom/provide.js +0 -7
  311. package/lib/esm/dom/router/link.js +0 -3
  312. package/lib/esm/dom/router/router.js +0 -52
  313. package/lib/esm/dom/svg.js +0 -65
  314. package/lib/esm/dom/test.js +0 -9
  315. package/lib/esm/dom/types/css.js +0 -23
  316. package/lib/esm/dom/types/dom.js +0 -1
  317. package/lib/esm/dom/types/html.js +0 -1
  318. package/lib/esm/dom/xml.js +0 -4
  319. package/lib/esm/equal.js +0 -41
  320. package/lib/esm/equal.test.js +0 -20
  321. package/lib/esm/flags.js +0 -48
  322. package/lib/esm/flags.test.js +0 -35
  323. package/lib/esm/fs.js +0 -226
  324. package/lib/esm/fs.test.js +0 -84
  325. package/lib/esm/fs_node.js +0 -45
  326. package/lib/esm/fs_win.test.js +0 -8
  327. package/lib/esm/generator.js +0 -10
  328. package/lib/esm/generator.test.js +0 -24
  329. package/lib/esm/is_browser.js +0 -1
  330. package/lib/esm/loader-register.d.mts +0 -1
  331. package/lib/esm/loader-register.mjs +0 -2
  332. package/lib/esm/loader.d.mts +0 -23
  333. package/lib/esm/loader.mjs +0 -36
  334. package/lib/esm/lock.js +0 -23
  335. package/lib/esm/lock.test.js +0 -16
  336. package/lib/esm/log.js +0 -88
  337. package/lib/esm/observable/event.js +0 -46
  338. package/lib/esm/observable/observable.js +0 -343
  339. package/lib/esm/observable/observable.test.js +0 -63
  340. package/lib/esm/range.js +0 -7
  341. package/lib/esm/result.js +0 -65
  342. package/lib/esm/result.test.js +0 -76
  343. package/lib/esm/safe.js +0 -10
  344. package/lib/esm/scope/describe.js +0 -60
  345. package/lib/esm/scope/display/console.js +0 -21
  346. package/lib/esm/scope/display/dom.js +0 -26
  347. package/lib/esm/scope/display/junit.js +0 -17
  348. package/lib/esm/scope/execute.js +0 -85
  349. package/lib/esm/scope/expect.js +0 -104
  350. package/lib/esm/scope/fix.js +0 -22
  351. package/lib/esm/scope/index.js +0 -3
  352. package/lib/esm/scope/scope.js +0 -1
  353. package/lib/esm/scope/state.js +0 -8
  354. package/lib/esm/server/http/apps.js +0 -23
  355. package/lib/esm/server/http/css.js +0 -50
  356. package/lib/esm/server/http/index.js +0 -73
  357. package/lib/esm/server/http/response.js +0 -40
  358. package/lib/esm/server/http/sitemap.js +0 -42
  359. package/lib/esm/server/http/static.js +0 -21
  360. package/lib/esm/server/http/typescript.js +0 -40
  361. package/lib/esm/server/main.js +0 -12
  362. package/lib/esm/test.mjs +0 -26
  363. package/lib/esm/test_all.js +0 -28
  364. package/lib/esm/transpile.mjs +0 -18
  365. package/src/components/test.js +0 -3
  366. package/src/loader-register.mjs +0 -3
  367. package/src/loader.mjs +0 -46
@@ -1,31 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getSide = exports.getSize = exports.isSize = exports.isSide = void 0;
4
- const constants_js_1 = require("./constants.js");
5
- function isSide(v) {
6
- return constants_js_1.Sides[v] !== undefined;
7
- }
8
- exports.isSide = isSide;
9
- function isSize(v) {
10
- return constants_js_1.Sizes[v] !== undefined;
11
- }
12
- exports.isSize = isSize;
13
- function getSize(size) {
14
- return constants_js_1.Sizes[size];
15
- }
16
- exports.getSize = getSize;
17
- function getSide(side) {
18
- switch (side) {
19
- case "t":
20
- return [...getSide("tl"), ...getSide("tr")];
21
- case "r":
22
- return [...getSide("tr"), ...getSide("br")];
23
- case "b":
24
- return [...getSide("br"), ...getSide("bl")];
25
- case "l":
26
- return [...getSide("tl"), ...getSide("bl")];
27
- default:
28
- return [constants_js_1.Sides[side]];
29
- }
30
- }
31
- exports.getSide = getSide;
@@ -1,36 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.compileFStyle = void 0;
4
- const case_js_1 = require("../../case.js");
5
- function compileFStyle(fstyle, prefix = "") {
6
- const properties = [];
7
- const rules = [];
8
- for (const [key, value] of Object.entries(fstyle)) {
9
- if (typeof value == "string") {
10
- properties.push({ key, value });
11
- }
12
- else {
13
- rules.push({ key, value });
14
- }
15
- }
16
- let rule = "";
17
- if (properties.length > 0) {
18
- rule += `${prefix} {\n`;
19
- for (const { key, value } of properties) {
20
- rule += ` ${(0, case_js_1.dashCase)(key)}: ${value};\n`;
21
- }
22
- rule += "}\n\n";
23
- }
24
- for (const { key, value } of rules) {
25
- if (key.startsWith("@media")) {
26
- rule += `${key} {\n`;
27
- rule += compileFStyle(value, " ");
28
- rule += `}\n\n`;
29
- }
30
- else {
31
- rule += compileFStyle(value, `${prefix} ${key}`);
32
- }
33
- }
34
- return rule;
35
- }
36
- exports.compileFStyle = compileFStyle;
@@ -1,14 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.width = void 0;
4
- const constants_js_1 = require("./constants.js");
5
- function width(amount, block) {
6
- if (amount === undefined && constants_js_1.Widths[block] !== undefined) {
7
- amount = block;
8
- }
9
- return {
10
- ...(block === "inline" ? { display: "inline-block" } : {}),
11
- width: constants_js_1.Widths[amount] ?? "0",
12
- };
13
- }
14
- exports.width = width;
@@ -1,110 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.update = exports.up = exports.normalizeArguments = exports.CLEAR = void 0;
4
- const Events = Symbol("events");
5
- exports.CLEAR = Symbol("Clear children");
6
- function isAttrs(attrs) {
7
- if (!attrs) {
8
- return false;
9
- }
10
- if (typeof attrs === "object") {
11
- return !attrs.nodeType;
12
- }
13
- return false;
14
- }
15
- function normalizeArguments(attrs, children = [], defaultAttrs = {}) {
16
- let attributes;
17
- if (isAttrs(attrs)) {
18
- attributes = attrs;
19
- }
20
- else {
21
- if (attrs !== undefined) {
22
- children.unshift(attrs);
23
- }
24
- attributes = defaultAttrs;
25
- }
26
- return [attributes, children.flat()];
27
- }
28
- exports.normalizeArguments = normalizeArguments;
29
- function up(element, attrs, ...children) {
30
- return update(element, ...normalizeArguments(attrs, children));
31
- }
32
- exports.up = up;
33
- function update(element, attrs, children) {
34
- // Track events, to remove later
35
- const $events = (element[Events] ??= new Map());
36
- const { style = {}, events = {}, ...rest } = attrs;
37
- Object.entries(events).forEach(([k, v]) => {
38
- if (v === null) {
39
- if ($events.has(k)) {
40
- const listener = $events.get(k);
41
- element.removeEventListener(k, listener);
42
- }
43
- }
44
- else if (v !== undefined) {
45
- element.addEventListener(k, v);
46
- $events.set(k, v);
47
- }
48
- });
49
- const _style = element.style;
50
- if (_style) {
51
- if (typeof style === "string") {
52
- _style.cssText = style;
53
- }
54
- else {
55
- Object.entries(style).forEach(([k, v]) => {
56
- // @ts-ignore Object.entries is unable to statically look into args
57
- _style[k] = v;
58
- });
59
- }
60
- }
61
- Object.entries(rest).forEach(([k, v]) => {
62
- if (k === "class") {
63
- v = Array.isArray(v)
64
- ? v
65
- : (typeof v === "string" ? v : `${v}`).split(/\s+/m);
66
- v
67
- .filter((s) => s !== "")
68
- .forEach((c) => {
69
- if (c.startsWith("!")) {
70
- element.classList.remove(c.substring(1));
71
- }
72
- else {
73
- element.classList.add(c);
74
- }
75
- });
76
- return;
77
- }
78
- const useNamespace = element.namespaceURI &&
79
- element.namespaceURI != "http://www.w3.org/1999/xhtml";
80
- const remove = !v;
81
- if (useNamespace) {
82
- if (remove) {
83
- element.removeAttributeNS(element.namespaceURI, k);
84
- }
85
- else if (v === true) {
86
- element.setAttributeNS(element.namespaceURI, k, k);
87
- }
88
- else {
89
- element.setAttributeNS(element.namespaceURI, k, v);
90
- }
91
- }
92
- else {
93
- if (remove) {
94
- element.removeAttribute(k);
95
- }
96
- else if (v === true) {
97
- element.setAttribute(k, k);
98
- }
99
- else {
100
- element.setAttribute(k, v);
101
- }
102
- }
103
- });
104
- if (children?.length > 0) {
105
- element.replaceChildren(...(children[0] === exports.CLEAR ? [] : children));
106
- }
107
- element.update ??= (attrs, ...children) => update(element, ...normalizeArguments(attrs, children));
108
- return element;
109
- }
110
- exports.update = update;
package/lib/cjs/dom/fc.js DELETED
@@ -1,39 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FC = exports.State = void 0;
4
- const dom_js_1 = require("./dom.js");
5
- exports.State = Symbol();
6
- function FC(name, component) {
7
- class FCImpl extends HTMLElement {
8
- constructor() {
9
- super();
10
- }
11
- [exports.State] = {};
12
- #attrs = {};
13
- #children = [];
14
- update(attrs, ...children) {
15
- [attrs, children] = (0, dom_js_1.normalizeArguments)(attrs, children);
16
- if (children[0] === dom_js_1.CLEAR) {
17
- this.#children = [];
18
- }
19
- else if (children.length > 0) {
20
- this.#children = children;
21
- }
22
- this.#attrs = { ...this.#attrs, ...attrs };
23
- // Apply updates from the attrs to the dom node itself
24
- (0, dom_js_1.update)(this, this.#attrs, []);
25
- // Re-run the component function using new element, attrs, and children.
26
- const replace = [component(this, this.#attrs, this.#children)];
27
- this.replaceChildren(...replace.flat());
28
- return this;
29
- }
30
- }
31
- customElements.define(name, FCImpl);
32
- const ctor = (attrs, ...children) => {
33
- const element = document.createElement(name);
34
- element.update(attrs, ...children);
35
- return element;
36
- };
37
- return ctor;
38
- }
39
- exports.FC = FC;
@@ -1,23 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const index_js_1 = require("../scope/index.js");
4
- const html_js_1 = require("./html.js");
5
- const fc_js_1 = require("./fc.js");
6
- (0, index_js_1.describe)("FC", () => {
7
- (0, index_js_1.it)("creates FCs", () => {
8
- const Input = (0, fc_js_1.FC)("fc-input", (el, attrs, children) => (0, html_js_1.label)(attrs.placeholder ?? attrs.name, (0, html_js_1.input)(attrs), ...children));
9
- const f = (0, html_js_1.form)({ action: "#", method: "POST" }, (0, html_js_1.div)({ class: "grid" }, Input({
10
- name: "firstName",
11
- placeholder: "First Name",
12
- required: true,
13
- }), Input({
14
- name: "lastName",
15
- placeholder: "Last Name",
16
- required: true,
17
- })), Input({ name: "email", type: "email", placeholder: "E-Mail" }, (0, html_js_1.small)("We'll never share your information.")), (0, html_js_1.button)({ type: "submit" }, "Submit"));
18
- // document.body.appendChild(f);
19
- (0, index_js_1.expect)(f.children.length).toBe(3);
20
- (0, index_js_1.expect)(f.querySelectorAll("input[required]").length).toBe(2);
21
- (0, index_js_1.expect)(f.querySelectorAll('input[name="firstName"]').length).toBe(1);
22
- });
23
- });
@@ -1,27 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.App = void 0;
4
- const html_js_1 = require("../html.js");
5
- const form_js_1 = require("./form.js");
6
- const App = () => (0, html_js_1.main)({ class: "container" }, (0, html_js_1.article)((0, form_js_1.Form)({
7
- events: {
8
- submit(event) {
9
- console.log("Should see fields for firstname, lastname, email, etc");
10
- console.log(event);
11
- },
12
- },
13
- }, (0, html_js_1.div)({ class: "grid" }, (0, form_js_1.Input)({ id: "firstname", placeholder: "First name" }), (0, form_js_1.Input)({ id: "lastname", placeholder: "Last name" })), (0, form_js_1.Input)({
14
- id: "email",
15
- type: "email",
16
- placeholder: "Email address",
17
- required: true,
18
- }, (0, html_js_1.small)("We will never share your email with anyone.")), (0, html_js_1.button)({ type: "submit" }, "Submit"), (0, html_js_1.div)({ class: "grid" }, (0, form_js_1.Input)({ id: "valid", placeholder: "Valid", "aria-invalid": "false" }), (0, form_js_1.Input)({
19
- id: "invalid",
20
- placeholder: "Invalid",
21
- "aria-invalid": "true",
22
- }), (0, form_js_1.Input)({ id: "disabled", placeholder: "Disabled", disabled: true }), (0, form_js_1.Input)({ id: "readonly", value: "Readonly", readOnly: true }))
23
- // Dropdown({id: 'fruit', label: "Fruit", placeholder: "Select a fruit...", options: ['Banana', 'Watermelon', 'Apple', 'Orange', 'Mango']}),
24
- // Radios({legend: 'Size', options: {small: 'Small', medium: 'Medium', large: 'Large', extralarge: "Extra Large"}, checked: 'small'}),
25
- // Checkboxes({options: {terms: 'I agree to the Terms and Conditions', termsSharing: {label: 'I agree to share my information with partners', disabled: true, checked: true}}),
26
- )));
27
- exports.App = App;
@@ -1,49 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Switch = exports.Checkbox = exports.Radio = exports.Switches = exports.Checks = exports.Radios = exports.Dropdown = exports.Option = exports.Button = exports.Select = exports.Input = exports.Form = void 0;
4
- const html_js_1 = require("../html.js");
5
- const Form = (attrs, ...children) => {
6
- if (attrs.events?.submit) {
7
- const submit = attrs.events.submit;
8
- attrs.events.submit = (event) => {
9
- event.preventDefault();
10
- submit(event);
11
- };
12
- }
13
- return (0, html_js_1.form)(attrs, ...children);
14
- };
15
- exports.Form = Form;
16
- const Input = (attrs, ...children) => (0, html_js_1.label)((0, html_js_1.input)(attrs), ...children);
17
- exports.Input = Input;
18
- const Select = (attrs) => (0, html_js_1.label)({ style: attrs.style ?? {} }, (0, html_js_1.select)({ events: attrs.events ?? {} }, ...prepareOptions(attrs.options, attrs.selected).map(exports.Option)));
19
- exports.Select = Select;
20
- const Button = () => { };
21
- exports.Button = Button;
22
- const prepareOptions = (attrs, selected) => Array.isArray(attrs)
23
- ? attrs.map((value) => ({
24
- value,
25
- label: value,
26
- selected: selected == value,
27
- }))
28
- : Object.entries(attrs).map(([value, label]) => typeof label === "string"
29
- ? { value, label, selected: selected === value }
30
- : { value, ...label });
31
- const Option = (attrs) => (0, html_js_1.option)(attrs);
32
- exports.Option = Option;
33
- const Dropdown = (attrs, ...options) => (0, exports.Select)({
34
- ...attrs,
35
- options: typeof options[0] == "string" ? options : options[0],
36
- });
37
- exports.Dropdown = Dropdown;
38
- const Radios = () => { };
39
- exports.Radios = Radios;
40
- const Checks = () => { };
41
- exports.Checks = Checks;
42
- const Switches = () => { };
43
- exports.Switches = Switches;
44
- const Radio = (attrs) => (0, exports.Input)({ type: "radio" });
45
- exports.Radio = Radio;
46
- const Checkbox = (attrs) => (0, exports.Input)({ type: "checkbox" });
47
- exports.Checkbox = Checkbox;
48
- const Switch = () => (0, exports.Checkbox)({ role: "switch" });
49
- exports.Switch = Switch;
@@ -1 +0,0 @@
1
- "use strict";
@@ -1,119 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.i = exports.html = exports.hr = exports.hgroup = exports.header = exports.head = exports.h6 = exports.h5 = exports.h4 = exports.h3 = exports.h2 = exports.h1 = exports.form = exports.footer = exports.figure = exports.figcaption = exports.fieldset = exports.embed = exports.em = exports.dt = exports.dl = exports.div = exports.dialog = exports.dfn = exports.details = exports.del = exports.dd = exports.datalist = exports.data = exports.colgroup = exports.col = exports.code = exports.cite = exports.caption = exports.canvas = exports.button = exports.br = exports.body = exports.blockquote = exports.bdo = exports.bdi = exports.base = exports.b = exports.audio = exports.aside = exports.article = exports.area = exports.address = exports.abbr = exports.a = void 0;
4
- exports.textarea = exports.template = exports.td = exports.tbody = exports.table = exports.sup = exports.summary = exports.sub = exports.style = exports.strong = exports.span = exports.source = exports.small = exports.slot = exports.select = exports.section = exports.script = exports.samp = exports.s = exports.ruby = exports.rt = exports.rp = exports.q = exports.progress = exports.pre = exports.picture = exports.param = exports.p = exports.output = exports.option = exports.optgroup = exports.ol = exports.object = exports.noscript = exports.nav = exports.meter = exports.meta = exports.menu = exports.mark = exports.map = exports.main = exports.link = exports.li = exports.legend = exports.label = exports.kbd = exports.ins = exports.input = exports.img = exports.iframe = void 0;
5
- exports.wbr = exports.video = exports.htmlvar = exports.ul = exports.u = exports.track = exports.tr = exports.title = exports.time = exports.thead = exports.th = exports.tfoot = void 0;
6
- const dom_js_1 = require("./dom.js");
7
- const makeHTMLElement = (name) => (attrs, ...children) => (0, dom_js_1.up)(document.createElement(name), attrs, ...children);
8
- exports.a = makeHTMLElement("a");
9
- exports.abbr = makeHTMLElement("abbr");
10
- exports.address = makeHTMLElement("address");
11
- exports.area = makeHTMLElement("area");
12
- exports.article = makeHTMLElement("article");
13
- exports.aside = makeHTMLElement("aside");
14
- exports.audio = makeHTMLElement("audio");
15
- exports.b = makeHTMLElement("b");
16
- exports.base = makeHTMLElement("base");
17
- exports.bdi = makeHTMLElement("bdi");
18
- exports.bdo = makeHTMLElement("bdo");
19
- exports.blockquote = makeHTMLElement("blockquote");
20
- exports.body = makeHTMLElement("body");
21
- exports.br = makeHTMLElement("br");
22
- exports.button = makeHTMLElement("button");
23
- exports.canvas = makeHTMLElement("canvas");
24
- exports.caption = makeHTMLElement("caption");
25
- exports.cite = makeHTMLElement("cite");
26
- exports.code = makeHTMLElement("code");
27
- exports.col = makeHTMLElement("col");
28
- exports.colgroup = makeHTMLElement("colgroup");
29
- exports.data = makeHTMLElement("data");
30
- exports.datalist = makeHTMLElement("datalist");
31
- exports.dd = makeHTMLElement("dd");
32
- exports.del = makeHTMLElement("del");
33
- exports.details = makeHTMLElement("details");
34
- exports.dfn = makeHTMLElement("dfn");
35
- exports.dialog = makeHTMLElement("dialog");
36
- exports.div = makeHTMLElement("div");
37
- exports.dl = makeHTMLElement("dl");
38
- exports.dt = makeHTMLElement("dt");
39
- exports.em = makeHTMLElement("em");
40
- exports.embed = makeHTMLElement("embed");
41
- exports.fieldset = makeHTMLElement("fieldset");
42
- exports.figcaption = makeHTMLElement("figcaption");
43
- exports.figure = makeHTMLElement("figure");
44
- exports.footer = makeHTMLElement("footer");
45
- exports.form = makeHTMLElement("form");
46
- exports.h1 = makeHTMLElement("h1");
47
- exports.h2 = makeHTMLElement("h2");
48
- exports.h3 = makeHTMLElement("h3");
49
- exports.h4 = makeHTMLElement("h4");
50
- exports.h5 = makeHTMLElement("h5");
51
- exports.h6 = makeHTMLElement("h6");
52
- exports.head = makeHTMLElement("head");
53
- exports.header = makeHTMLElement("header");
54
- exports.hgroup = makeHTMLElement("hgroup");
55
- exports.hr = makeHTMLElement("hr");
56
- exports.html = makeHTMLElement("html");
57
- exports.i = makeHTMLElement("i");
58
- exports.iframe = makeHTMLElement("iframe");
59
- exports.img = makeHTMLElement("img");
60
- exports.input = makeHTMLElement("input");
61
- exports.ins = makeHTMLElement("ins");
62
- exports.kbd = makeHTMLElement("kbd");
63
- exports.label = makeHTMLElement("label");
64
- exports.legend = makeHTMLElement("legend");
65
- exports.li = makeHTMLElement("li");
66
- exports.link = makeHTMLElement("link");
67
- exports.main = makeHTMLElement("main");
68
- exports.map = makeHTMLElement("map");
69
- exports.mark = makeHTMLElement("mark");
70
- exports.menu = makeHTMLElement("menu");
71
- exports.meta = makeHTMLElement("meta");
72
- exports.meter = makeHTMLElement("meter");
73
- exports.nav = makeHTMLElement("nav");
74
- exports.noscript = makeHTMLElement("noscript");
75
- exports.object = makeHTMLElement("object");
76
- exports.ol = makeHTMLElement("ol");
77
- exports.optgroup = makeHTMLElement("optgroup");
78
- exports.option = makeHTMLElement("option");
79
- exports.output = makeHTMLElement("output");
80
- exports.p = makeHTMLElement("p");
81
- exports.param = makeHTMLElement("param");
82
- exports.picture = makeHTMLElement("picture");
83
- exports.pre = makeHTMLElement("pre");
84
- exports.progress = makeHTMLElement("progress");
85
- exports.q = makeHTMLElement("q");
86
- exports.rp = makeHTMLElement("rp");
87
- exports.rt = makeHTMLElement("rt");
88
- exports.ruby = makeHTMLElement("ruby");
89
- exports.s = makeHTMLElement("s");
90
- exports.samp = makeHTMLElement("samp");
91
- exports.script = makeHTMLElement("script");
92
- exports.section = makeHTMLElement("section");
93
- exports.select = makeHTMLElement("select");
94
- exports.slot = makeHTMLElement("slot");
95
- exports.small = makeHTMLElement("small");
96
- exports.source = makeHTMLElement("source");
97
- exports.span = makeHTMLElement("span");
98
- exports.strong = makeHTMLElement("strong");
99
- exports.style = makeHTMLElement("style");
100
- exports.sub = makeHTMLElement("sub");
101
- exports.summary = makeHTMLElement("summary");
102
- exports.sup = makeHTMLElement("sup");
103
- exports.table = makeHTMLElement("table");
104
- exports.tbody = makeHTMLElement("tbody");
105
- exports.td = makeHTMLElement("td");
106
- exports.template = makeHTMLElement("template");
107
- exports.textarea = makeHTMLElement("textarea");
108
- exports.tfoot = makeHTMLElement("tfoot");
109
- exports.th = makeHTMLElement("th");
110
- exports.thead = makeHTMLElement("thead");
111
- exports.time = makeHTMLElement("time");
112
- exports.title = makeHTMLElement("title");
113
- exports.tr = makeHTMLElement("tr");
114
- exports.track = makeHTMLElement("track");
115
- exports.u = makeHTMLElement("u");
116
- exports.ul = makeHTMLElement("ul");
117
- exports.htmlvar = makeHTMLElement("var"); // var is reserved, export as variable
118
- exports.video = makeHTMLElement("video");
119
- exports.wbr = makeHTMLElement("wbr");
@@ -1,60 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const describe_js_1 = require("../scope/describe.js");
4
- const expect_js_1 = require("../scope/expect.js");
5
- const html_js_1 = require("./html.js");
6
- (0, describe_js_1.describe)("html", () => {
7
- (0, describe_js_1.it)("creates HTML Elements", () => {
8
- let tableBody;
9
- const myTable = (0, html_js_1.table)((0, html_js_1.thead)((0, html_js_1.tr)((0, html_js_1.th)("Col A"), (0, html_js_1.th)("Col B"))), (tableBody = (0, html_js_1.tbody)()));
10
- for (let x = 1; x <= 3; x++) {
11
- tableBody.appendChild((0, html_js_1.tr)((0, html_js_1.td)(`${x}`), (0, html_js_1.td)(`${x * 2}`)));
12
- }
13
- (0, expect_js_1.expect)(myTable.textContent).toEqual("Col ACol B122436");
14
- });
15
- (0, describe_js_1.it)("attaches event handlers", () => {
16
- let clicked = 0;
17
- const btn = (0, html_js_1.button)({
18
- events: {
19
- click: () => {
20
- clicked += 1;
21
- },
22
- },
23
- });
24
- btn.dispatchEvent(new Event("click"));
25
- (0, expect_js_1.expect)(clicked).toBe(1);
26
- });
27
- (0, describe_js_1.it)("removes event handlers", () => {
28
- let clicked = 0;
29
- const btn = (0, html_js_1.button)({
30
- events: {
31
- click: () => {
32
- clicked += 1;
33
- },
34
- },
35
- });
36
- btn.dispatchEvent(new Event("click"));
37
- (0, expect_js_1.expect)(clicked).toBe(1);
38
- btn.update({ events: { click: null } });
39
- btn.dispatchEvent(new Event("click"));
40
- (0, expect_js_1.expect)(clicked).toBe(1);
41
- });
42
- (0, describe_js_1.it)("sets style properties", () => {
43
- const btn = (0, html_js_1.button)({
44
- style: { flexDirection: "column" },
45
- });
46
- (0, expect_js_1.expect)(btn.style.flexDirection).toBe("column");
47
- });
48
- (0, describe_js_1.it)("sets style, attributes, and events together", () => {
49
- let clicked = false;
50
- const btn = (0, html_js_1.button)({
51
- class: "test-class",
52
- style: { flexDirection: "column" },
53
- events: { click: () => (clicked = true) },
54
- });
55
- btn.dispatchEvent(new Event("click"));
56
- (0, expect_js_1.expect)(btn.classList.contains("test-class")).toBe(true);
57
- (0, expect_js_1.expect)(btn.style.flexDirection).toBe("column");
58
- (0, expect_js_1.expect)(clicked).toBe(true);
59
- });
60
- });
@@ -1,10 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.O = void 0;
4
- function O(element, observable) {
5
- observable.subscribe((t) => {
6
- element.update(...t);
7
- });
8
- return element;
9
- }
10
- exports.O = O;
@@ -1,35 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const observable_js_1 = require("./observable.js");
4
- const observable_js_2 = require("../observable/observable.js");
5
- const describe_js_1 = require("../scope/describe.js");
6
- const expect_js_1 = require("../scope/expect.js");
7
- const html_js_1 = require("./html.js");
8
- (0, describe_js_1.describe)("DOM Observable", () => {
9
- (0, describe_js_1.it)("updates a dom node with observable results", async () => {
10
- const subject = new observable_js_2.Subject();
11
- const observable = subject.pipe((0, observable_js_2.map)((s) => [s]));
12
- const element = (0, observable_js_1.O)((0, html_js_1.div)(), observable);
13
- (0, expect_js_1.expect)(element.innerText).toEqual("");
14
- await subject.next("H");
15
- (0, expect_js_1.expect)(element.innerText).toEqual("H");
16
- await subject.next("He");
17
- (0, expect_js_1.expect)(element.innerText).toEqual("He");
18
- });
19
- (0, describe_js_1.it)("updates a dom node's attributes", async () => {
20
- const classes = new observable_js_2.Subject();
21
- const observable = classes.map((c) => [{ class: c.join(" ") }]);
22
- const element = (0, observable_js_1.O)((0, html_js_1.span)(), observable);
23
- (0, expect_js_1.expect)(element.classList.contains("warning")).toBe(false);
24
- (0, expect_js_1.expect)(element.classList.contains("error")).toBe(false);
25
- await classes.next(["warning"]);
26
- (0, expect_js_1.expect)(element.classList.contains("warning")).toBe(true);
27
- (0, expect_js_1.expect)(element.classList.contains("error")).toBe(false);
28
- await classes.next(["error"]);
29
- (0, expect_js_1.expect)(element.classList.contains("warning")).toBe(true);
30
- (0, expect_js_1.expect)(element.classList.contains("error")).toBe(true);
31
- await classes.next(["!warning", "!error"]);
32
- (0, expect_js_1.expect)(element.classList.contains("warning")).toBe(false);
33
- (0, expect_js_1.expect)(element.classList.contains("error")).toBe(false);
34
- });
35
- });
@@ -1,12 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.retrieve = exports.provide = void 0;
4
- let registry = {};
5
- function provide(items) {
6
- registry = { ...registry, ...items };
7
- }
8
- exports.provide = provide;
9
- function retrieve(key) {
10
- return registry[key];
11
- }
12
- exports.retrieve = retrieve;
@@ -1,7 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.link = void 0;
4
- const html_js_1 = require("../html.js");
5
- const router_js_1 = require("./router.js");
6
- const link = ({ href, link }) => (0, html_js_1.a)({ href: router_js_1.Router.href(href), events: { click: router_js_1.Router.navigate(href) } }, link);
7
- exports.link = link;
@@ -1,55 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Router = void 0;
4
- let baseURI = `${document.baseURI}`;
5
- const normalizeHref = () => {
6
- return location.href + "/" === baseURI ? baseURI : location.href;
7
- };
8
- let globalRouter;
9
- exports.Router = {
10
- local(links, index) {
11
- return exports.Router.for(links, index, false);
12
- },
13
- for(links, index, setGlobalRouter = true) {
14
- let target;
15
- const partialRouter = (t) => {
16
- target = t;
17
- const href = normalizeHref();
18
- const route = href === baseURI ? baseURI + index : href;
19
- doNavigate(route);
20
- window.addEventListener("popstate", () => {
21
- doNavigate(location.href);
22
- });
23
- return target;
24
- };
25
- const doNavigate = (link) => {
26
- link = link.replace(baseURI, "") || index;
27
- if (link === partialRouter.current) {
28
- return false;
29
- }
30
- partialRouter.current = link;
31
- target.update((links.find(({ href }) => link.endsWith(href))?.target ??
32
- (() => undefined))());
33
- return true;
34
- };
35
- const navigate = (url) => {
36
- return (event) => {
37
- event.preventDefault();
38
- if (doNavigate(url || index)) {
39
- history.pushState(null, "", url);
40
- }
41
- };
42
- };
43
- partialRouter.navigate = navigate;
44
- if (setGlobalRouter) {
45
- globalRouter = partialRouter;
46
- }
47
- return partialRouter;
48
- },
49
- href(link) {
50
- return `${baseURI}${link.replace(/^\//, "")}`;
51
- },
52
- navigate(href) {
53
- return globalRouter?.navigate(href);
54
- },
55
- };