@davidsouther/jiffies 1.0.0-beta.1 → 2.0.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 (447) hide show
  1. package/{build → lib/cjs}/assert.d.ts +0 -0
  2. package/lib/cjs/assert.js +40 -0
  3. package/{build → lib/cjs}/case.d.ts +0 -0
  4. package/lib/cjs/case.js +9 -0
  5. package/{build → lib/cjs}/components/button_bar.d.ts +1 -1
  6. package/lib/cjs/components/button_bar.js +29 -0
  7. package/{build → lib/cjs}/components/inline_edit.d.ts +1 -1
  8. package/lib/cjs/components/inline_edit.js +51 -0
  9. package/{build → lib/cjs}/components/logger.d.ts +2 -3
  10. package/lib/cjs/components/logger.js +27 -0
  11. package/lib/cjs/components/select.d.ts +10 -0
  12. package/lib/cjs/components/select.js +6 -0
  13. package/lib/cjs/components/test.d.ts +1 -0
  14. package/lib/cjs/components/test.js +7 -0
  15. package/{build → lib/cjs}/components/virtual_scroll.d.ts +3 -4
  16. package/lib/cjs/components/virtual_scroll.js +102 -0
  17. package/{build → lib/cjs}/components/virtual_scroll.test.d.ts +0 -0
  18. package/lib/cjs/components/virtual_scroll.test.js +22 -0
  19. package/{build → lib/cjs}/context.d.ts +0 -0
  20. package/lib/cjs/context.js +48 -0
  21. package/{build → lib/cjs}/context.test.d.ts +0 -0
  22. package/lib/cjs/context.test.js +48 -0
  23. package/{build → lib/cjs}/debounce.d.ts +0 -0
  24. package/lib/cjs/debounce.js +11 -0
  25. package/lib/cjs/diff.d.ts +15 -0
  26. package/lib/cjs/diff.js +58 -0
  27. package/{build/components/index.d.ts → lib/cjs/diff.test.d.ts} +0 -0
  28. package/lib/cjs/diff.test.js +41 -0
  29. package/{build → lib/cjs}/display.d.ts +0 -0
  30. package/lib/cjs/display.js +16 -0
  31. package/{build → lib/cjs}/dom/css/border.d.ts +0 -0
  32. package/lib/cjs/dom/css/border.js +33 -0
  33. package/{build → lib/cjs}/dom/css/constants.d.ts +0 -0
  34. package/lib/cjs/dom/css/constants.js +31 -0
  35. package/{build → lib/cjs}/dom/css/core.d.ts +0 -0
  36. package/lib/cjs/dom/css/core.js +31 -0
  37. package/{build → lib/cjs}/dom/css/fstyle.d.ts +0 -0
  38. package/lib/cjs/dom/css/fstyle.js +36 -0
  39. package/{build → lib/cjs}/dom/css/sizing.d.ts +0 -0
  40. package/lib/cjs/dom/css/sizing.js +14 -0
  41. package/lib/cjs/dom/dom.d.ts +27 -0
  42. package/lib/cjs/dom/dom.js +110 -0
  43. package/{build → lib/cjs}/dom/fc.d.ts +5 -5
  44. package/lib/cjs/dom/fc.js +39 -0
  45. package/{build → lib/cjs}/dom/fc.test.d.ts +0 -0
  46. package/lib/cjs/dom/fc.test.js +23 -0
  47. package/lib/cjs/dom/form/form.app.d.ts +1 -0
  48. package/lib/cjs/dom/form/form.app.js +27 -0
  49. package/lib/cjs/dom/form/form.d.ts +26 -0
  50. package/lib/cjs/dom/form/form.js +49 -0
  51. package/{build → lib/cjs}/dom/form/form.test.d.ts +0 -0
  52. package/{build → lib/cjs}/dom/form/form.test.js +0 -0
  53. package/lib/cjs/dom/html.d.ts +113 -0
  54. package/lib/cjs/dom/html.js +119 -0
  55. package/{build → lib/cjs}/dom/html.test.d.ts +0 -0
  56. package/lib/cjs/dom/html.test.js +60 -0
  57. package/lib/cjs/dom/observable.d.ts +2 -0
  58. package/lib/cjs/dom/observable.js +10 -0
  59. package/{build/components/index.js → lib/cjs/dom/observable.test.d.ts} +0 -0
  60. package/lib/cjs/dom/observable.test.js +35 -0
  61. package/lib/cjs/dom/provide.d.ts +3 -0
  62. package/lib/cjs/dom/provide.js +12 -0
  63. package/lib/cjs/dom/router/link.d.ts +6 -0
  64. package/lib/cjs/dom/router/link.js +7 -0
  65. package/{build → lib/cjs}/dom/router/router.d.ts +3 -3
  66. package/lib/cjs/dom/router/router.js +52 -0
  67. package/lib/cjs/dom/svg.d.ts +64 -0
  68. package/lib/cjs/dom/svg.js +69 -0
  69. package/lib/cjs/dom/test.d.ts +1 -0
  70. package/lib/cjs/dom/test.js +13 -0
  71. package/{build → lib/cjs}/dom/types/css.d.ts +0 -0
  72. package/lib/cjs/dom/types/css.js +24 -0
  73. package/{build → lib/cjs}/dom/types/dom.d.ts +0 -0
  74. package/{build → lib/cjs}/dom/types/dom.js +0 -0
  75. package/{build → lib/cjs}/dom/types/html.d.ts +1 -1
  76. package/lib/cjs/dom/types/html.js +2 -0
  77. package/{build → lib/cjs}/dom/xml.d.ts +0 -0
  78. package/lib/cjs/dom/xml.js +8 -0
  79. package/lib/cjs/equal.d.ts +5 -0
  80. package/lib/cjs/equal.js +43 -0
  81. package/{build → lib/cjs}/equal.test.d.ts +0 -0
  82. package/lib/cjs/equal.test.js +22 -0
  83. package/{build → lib/cjs}/flags.d.ts +0 -0
  84. package/lib/cjs/flags.js +52 -0
  85. package/{build → lib/cjs}/flags.test.d.ts +0 -0
  86. package/lib/cjs/flags.test.js +37 -0
  87. package/lib/cjs/fs.d.ts +48 -0
  88. package/lib/cjs/fs.js +151 -0
  89. package/{build/components/test.d.ts → lib/cjs/fs.test.d.ts} +0 -0
  90. package/lib/cjs/fs.test.js +45 -0
  91. package/{build → lib/cjs}/generator.d.ts +0 -0
  92. package/lib/cjs/generator.js +14 -0
  93. package/{build → lib/cjs}/generator.test.d.ts +0 -0
  94. package/lib/cjs/generator.test.js +26 -0
  95. package/{build → lib/cjs}/is_browser.d.ts +0 -0
  96. package/lib/cjs/is_browser.js +4 -0
  97. package/{build → lib/cjs}/loader.d.mts +0 -0
  98. package/lib/cjs/loader.mjs +40 -0
  99. package/{build → lib/cjs}/lock.d.ts +0 -0
  100. package/lib/cjs/lock.js +27 -0
  101. package/{build → lib/cjs}/lock.test.d.ts +0 -0
  102. package/lib/cjs/lock.test.js +18 -0
  103. package/{build → lib/cjs}/log.d.ts +0 -0
  104. package/lib/cjs/log.js +54 -0
  105. package/lib/cjs/observable/event.d.ts +35 -0
  106. package/lib/cjs/observable/event.js +61 -0
  107. package/lib/cjs/observable/observable.d.ts +132 -0
  108. package/lib/cjs/observable/observable.js +363 -0
  109. package/{build/dom/test.d.ts → lib/cjs/observable/observable.test.d.ts} +0 -0
  110. package/lib/cjs/observable/observable.test.js +65 -0
  111. package/{build → lib/cjs}/range.d.ts +0 -0
  112. package/lib/cjs/range.js +11 -0
  113. package/{build → lib/cjs}/result.d.ts +11 -11
  114. package/lib/cjs/result.js +80 -0
  115. package/{build → lib/cjs}/result.test.d.ts +0 -0
  116. package/lib/cjs/result.test.js +73 -0
  117. package/{build → lib/cjs}/safe.d.ts +0 -0
  118. package/lib/cjs/safe.js +14 -0
  119. package/{build → lib/cjs}/scope/describe.d.ts +4 -0
  120. package/lib/cjs/scope/describe.js +73 -0
  121. package/{build → lib/cjs}/scope/display/console.d.ts +0 -0
  122. package/lib/cjs/scope/display/console.js +25 -0
  123. package/{build → lib/cjs}/scope/display/dom.d.ts +2 -2
  124. package/lib/cjs/scope/display/dom.js +30 -0
  125. package/{build → lib/cjs}/scope/display/junit.d.ts +0 -0
  126. package/lib/cjs/scope/display/junit.js +21 -0
  127. package/{build → lib/cjs}/scope/execute.d.ts +1 -1
  128. package/lib/cjs/scope/execute.js +91 -0
  129. package/{build → lib/cjs}/scope/expect.d.ts +1 -1
  130. package/lib/cjs/scope/expect.js +114 -0
  131. package/{build → lib/cjs}/scope/fix.d.ts +0 -0
  132. package/lib/cjs/scope/fix.js +26 -0
  133. package/{build → lib/cjs}/scope/index.d.ts +0 -0
  134. package/lib/cjs/scope/index.js +15 -0
  135. package/{build → lib/cjs}/scope/scope.d.ts +0 -0
  136. package/lib/cjs/scope/scope.js +2 -0
  137. package/lib/cjs/scope/state.d.ts +1 -0
  138. package/lib/cjs/scope/state.js +11 -0
  139. package/{build → lib/cjs}/server/http/apps.d.ts +0 -0
  140. package/lib/cjs/server/http/apps.js +27 -0
  141. package/lib/cjs/server/http/css.d.ts +5 -0
  142. package/lib/cjs/server/http/css.js +54 -0
  143. package/{build → lib/cjs}/server/http/index.d.ts +0 -0
  144. package/lib/cjs/server/http/index.js +77 -0
  145. package/{build → lib/cjs}/server/http/response.d.ts +0 -0
  146. package/lib/cjs/server/http/response.js +45 -0
  147. package/{build → lib/cjs}/server/http/sitemap.d.ts +0 -0
  148. package/lib/cjs/server/http/sitemap.js +46 -0
  149. package/{build → lib/cjs}/server/http/static.d.ts +0 -0
  150. package/lib/cjs/server/http/static.js +25 -0
  151. package/{build → lib/cjs}/server/http/typescript.d.ts +0 -0
  152. package/lib/cjs/server/http/typescript.js +44 -0
  153. package/{build → lib/cjs}/server/main.d.ts +0 -0
  154. package/lib/cjs/server/main.js +14 -0
  155. package/{build → lib/cjs}/test.d.mts +0 -0
  156. package/lib/cjs/test.mjs +28 -0
  157. package/lib/cjs/test_all.d.ts +9 -0
  158. package/lib/cjs/test_all.js +30 -0
  159. package/{build → lib/cjs}/transpile.d.mts +0 -0
  160. package/lib/cjs/transpile.mjs +22 -0
  161. package/lib/cjs/tsconfig.tsbuildinfo +1 -0
  162. package/lib/esm/assert.d.ts +23 -0
  163. package/{build → lib/esm}/assert.js +1 -1
  164. package/lib/esm/case.d.ts +1 -0
  165. package/{build → lib/esm}/case.js +0 -0
  166. package/lib/esm/components/button_bar.d.ts +8 -0
  167. package/lib/esm/components/button_bar.js +27 -0
  168. package/lib/esm/components/inline_edit.d.ts +12 -0
  169. package/{build → lib/esm}/components/inline_edit.js +3 -3
  170. package/lib/esm/components/logger.d.ts +6 -0
  171. package/{build → lib/esm}/components/logger.js +3 -3
  172. package/lib/esm/components/select.d.ts +10 -0
  173. package/{build → lib/esm}/components/select.js +2 -2
  174. package/lib/esm/components/test.d.ts +1 -0
  175. package/lib/esm/components/test.js +3 -0
  176. package/lib/esm/components/virtual_scroll.d.ts +40 -0
  177. package/{build → lib/esm}/components/virtual_scroll.js +3 -3
  178. package/{build/dom/types/html.js → lib/esm/components/virtual_scroll.test.d.ts} +0 -0
  179. package/{build → lib/esm}/components/virtual_scroll.test.js +3 -4
  180. package/lib/esm/context.d.ts +15 -0
  181. package/{build → lib/esm}/context.js +3 -3
  182. package/{build/scope/scope.js → lib/esm/context.test.d.ts} +0 -0
  183. package/{build → lib/esm}/context.test.js +0 -0
  184. package/lib/esm/debounce.d.ts +1 -0
  185. package/{build → lib/esm}/debounce.js +0 -0
  186. package/lib/esm/diff.d.ts +15 -0
  187. package/lib/esm/diff.js +54 -0
  188. package/{build/test_all.d.ts → lib/esm/diff.test.d.ts} +0 -0
  189. package/lib/esm/diff.test.js +39 -0
  190. package/lib/esm/display.d.ts +5 -0
  191. package/lib/esm/display.js +11 -0
  192. package/lib/esm/dom/css/border.d.ts +11 -0
  193. package/{build → lib/esm}/dom/css/border.js +0 -0
  194. package/lib/esm/dom/css/constants.d.ts +31 -0
  195. package/{build → lib/esm}/dom/css/constants.js +0 -0
  196. package/lib/esm/dom/css/core.d.ts +5 -0
  197. package/{build → lib/esm}/dom/css/core.js +0 -0
  198. package/lib/esm/dom/css/fstyle.d.ts +5 -0
  199. package/{build → lib/esm}/dom/css/fstyle.js +0 -0
  200. package/lib/esm/dom/css/sizing.d.ts +5 -0
  201. package/{build → lib/esm}/dom/css/sizing.js +0 -0
  202. package/lib/esm/dom/dom.d.ts +27 -0
  203. package/{build → lib/esm}/dom/dom.js +44 -34
  204. package/lib/esm/dom/fc.d.ts +14 -0
  205. package/{build → lib/esm}/dom/fc.js +1 -1
  206. package/lib/esm/dom/fc.test.d.ts +1 -0
  207. package/{build → lib/esm}/dom/fc.test.js +0 -0
  208. package/lib/esm/dom/form/form.app.d.ts +1 -0
  209. package/{build → lib/esm}/dom/form/form.app.js +0 -0
  210. package/lib/esm/dom/form/form.d.ts +26 -0
  211. package/{build → lib/esm}/dom/form/form.js +14 -5
  212. package/lib/esm/dom/form/form.test.d.ts +0 -0
  213. package/lib/esm/dom/form/form.test.js +1 -0
  214. package/lib/esm/dom/html.d.ts +113 -0
  215. package/{build → lib/esm}/dom/html.js +0 -0
  216. package/lib/esm/dom/html.test.d.ts +1 -0
  217. package/{build → lib/esm}/dom/html.test.js +4 -4
  218. package/lib/esm/dom/observable.d.ts +2 -0
  219. package/lib/esm/dom/observable.js +6 -0
  220. package/lib/esm/dom/observable.test.d.ts +1 -0
  221. package/lib/esm/dom/observable.test.js +33 -0
  222. package/lib/esm/dom/provide.d.ts +3 -0
  223. package/lib/esm/dom/provide.js +7 -0
  224. package/lib/esm/dom/router/link.d.ts +6 -0
  225. package/{build → lib/esm}/dom/router/link.js +0 -0
  226. package/lib/esm/dom/router/router.d.ts +12 -0
  227. package/{build → lib/esm}/dom/router/router.js +0 -0
  228. package/lib/esm/dom/svg.d.ts +64 -0
  229. package/{build → lib/esm}/dom/svg.js +0 -0
  230. package/lib/esm/dom/test.d.ts +1 -0
  231. package/lib/esm/dom/test.js +9 -0
  232. package/lib/esm/dom/types/css.d.ts +6612 -0
  233. package/{build → lib/esm}/dom/types/css.js +0 -0
  234. package/lib/esm/dom/types/dom.d.ts +0 -0
  235. package/lib/esm/dom/types/dom.js +1 -0
  236. package/lib/esm/dom/types/html.d.ts +616 -0
  237. package/lib/esm/dom/types/html.js +1 -0
  238. package/lib/esm/dom/xml.d.ts +1 -0
  239. package/{build → lib/esm}/dom/xml.js +1 -2
  240. package/lib/esm/equal.d.ts +5 -0
  241. package/lib/esm/equal.js +37 -0
  242. package/lib/esm/equal.test.d.ts +1 -0
  243. package/{build → lib/esm}/equal.test.js +0 -0
  244. package/lib/esm/flags.d.ts +7 -0
  245. package/{build → lib/esm}/flags.js +1 -1
  246. package/lib/esm/flags.test.d.ts +1 -0
  247. package/{build → lib/esm}/flags.test.js +0 -0
  248. package/lib/esm/fs.d.ts +48 -0
  249. package/lib/esm/fs.js +144 -0
  250. package/lib/esm/fs.test.d.ts +1 -0
  251. package/lib/esm/fs.test.js +43 -0
  252. package/lib/esm/generator.d.ts +1 -0
  253. package/{build → lib/esm}/generator.js +0 -0
  254. package/lib/esm/generator.test.d.ts +1 -0
  255. package/{build → lib/esm}/generator.test.js +0 -0
  256. package/lib/esm/is_browser.d.ts +1 -0
  257. package/{build → lib/esm}/is_browser.js +0 -0
  258. package/lib/esm/loader.d.mts +22 -0
  259. package/{build → lib/esm}/loader.mjs +0 -0
  260. package/lib/esm/lock.d.ts +1 -0
  261. package/{build → lib/esm}/lock.js +0 -0
  262. package/lib/esm/lock.test.d.ts +1 -0
  263. package/{build → lib/esm}/lock.test.js +0 -0
  264. package/lib/esm/log.d.ts +26 -0
  265. package/{build → lib/esm}/log.js +16 -4
  266. package/lib/esm/observable/event.d.ts +35 -0
  267. package/lib/esm/observable/event.js +46 -0
  268. package/lib/esm/observable/observable.d.ts +132 -0
  269. package/lib/esm/observable/observable.js +343 -0
  270. package/lib/esm/observable/observable.test.d.ts +1 -0
  271. package/lib/esm/observable/observable.test.js +63 -0
  272. package/lib/esm/range.d.ts +1 -0
  273. package/{build → lib/esm}/range.js +0 -0
  274. package/lib/esm/result.d.ts +31 -0
  275. package/{build → lib/esm}/result.js +3 -3
  276. package/lib/esm/result.test.d.ts +1 -0
  277. package/{build → lib/esm}/result.test.js +0 -0
  278. package/lib/esm/safe.d.ts +1 -0
  279. package/{build → lib/esm}/safe.js +0 -0
  280. package/lib/esm/scope/describe.d.ts +18 -0
  281. package/{build → lib/esm}/scope/describe.js +14 -6
  282. package/lib/esm/scope/display/console.d.ts +2 -0
  283. package/{build → lib/esm}/scope/display/console.js +0 -0
  284. package/lib/esm/scope/display/dom.d.ts +3 -0
  285. package/{build → lib/esm}/scope/display/dom.js +0 -0
  286. package/lib/esm/scope/display/junit.d.ts +2 -0
  287. package/{build → lib/esm}/scope/display/junit.js +0 -0
  288. package/lib/esm/scope/execute.d.ts +12 -0
  289. package/{build → lib/esm}/scope/execute.js +3 -3
  290. package/lib/esm/scope/expect.d.ts +23 -0
  291. package/{build → lib/esm}/scope/expect.js +4 -3
  292. package/lib/esm/scope/fix.d.ts +4 -0
  293. package/{build → lib/esm}/scope/fix.js +0 -0
  294. package/{build/scope/index.js → lib/esm/scope/index.d.ts} +0 -0
  295. package/lib/esm/scope/index.js +3 -0
  296. package/lib/esm/scope/scope.d.ts +17 -0
  297. package/lib/esm/scope/scope.js +1 -0
  298. package/lib/esm/scope/state.d.ts +1 -0
  299. package/lib/esm/scope/state.js +7 -0
  300. package/lib/esm/server/http/apps.d.ts +5 -0
  301. package/{build → lib/esm}/server/http/apps.js +0 -0
  302. package/lib/esm/server/http/css.d.ts +5 -0
  303. package/lib/esm/server/http/css.js +50 -0
  304. package/lib/esm/server/http/index.d.ts +21 -0
  305. package/{build → lib/esm}/server/http/index.js +4 -2
  306. package/lib/esm/server/http/response.d.ts +4 -0
  307. package/{build → lib/esm}/server/http/response.js +6 -3
  308. package/lib/esm/server/http/sitemap.d.ts +2 -0
  309. package/{build → lib/esm}/server/http/sitemap.js +0 -0
  310. package/lib/esm/server/http/static.d.ts +2 -0
  311. package/{build → lib/esm}/server/http/static.js +0 -0
  312. package/lib/esm/server/http/typescript.d.ts +5 -0
  313. package/{build → lib/esm}/server/http/typescript.js +0 -0
  314. package/lib/esm/server/main.d.ts +2 -0
  315. package/{build → lib/esm}/server/main.js +5 -2
  316. package/lib/esm/test.d.mts +2 -0
  317. package/lib/esm/test.mjs +26 -0
  318. package/lib/esm/test_all.d.ts +9 -0
  319. package/lib/esm/test_all.js +28 -0
  320. package/lib/esm/transpile.d.mts +3 -0
  321. package/{build → lib/esm}/transpile.mjs +0 -0
  322. package/lib/esm/tsconfig.tsbuildinfo +1 -0
  323. package/package.json +18 -16
  324. package/src/assert.ts +1 -1
  325. package/src/components/button_bar.ts +33 -27
  326. package/src/components/inline_edit.ts +3 -3
  327. package/src/components/logger.ts +5 -6
  328. package/src/components/select.ts +3 -3
  329. package/src/components/test.js +3 -2
  330. package/src/components/virtual_scroll.test.ts +4 -4
  331. package/src/components/virtual_scroll.ts +8 -8
  332. package/src/context.ts +3 -3
  333. package/src/diff.test.ts +48 -0
  334. package/src/diff.ts +84 -0
  335. package/src/display.ts +8 -2
  336. package/src/dom/css/border.ts +3 -3
  337. package/src/dom/css/core.ts +1 -1
  338. package/src/dom/css/fstyle.ts +2 -2
  339. package/src/dom/css/sizing.ts +1 -1
  340. package/src/dom/dom.ts +73 -60
  341. package/src/dom/fc.test.ts +3 -3
  342. package/src/dom/fc.ts +11 -10
  343. package/src/dom/form/form.app.ts +2 -2
  344. package/src/dom/form/form.ts +33 -10
  345. package/src/dom/html.test.ts +8 -8
  346. package/src/dom/html.ts +7 -10
  347. package/src/dom/observable.test.ts +43 -0
  348. package/src/dom/observable.ts +11 -0
  349. package/src/dom/provide.ts +11 -0
  350. package/src/dom/router/link.ts +2 -2
  351. package/src/dom/router/router.ts +5 -5
  352. package/src/dom/svg.ts +1 -1
  353. package/src/dom/test.ts +8 -2
  354. package/src/dom/types/html.ts +1 -1
  355. package/src/dom/xml.ts +1 -2
  356. package/src/equal.ts +22 -11
  357. package/src/flags.ts +1 -1
  358. package/src/fs.test.ts +53 -0
  359. package/src/fs.ts +180 -0
  360. package/src/index.html +16 -13
  361. package/src/log.ts +8 -4
  362. package/src/observable/_notes +21 -8
  363. package/src/observable/event.ts +93 -0
  364. package/src/observable/observable.test.ts +73 -0
  365. package/src/observable/observable.ts +463 -0
  366. package/src/pico/_variables.scss +66 -0
  367. package/src/pico/components/_accordion.scss +112 -0
  368. package/src/pico/components/_button-group.scss +51 -0
  369. package/src/pico/components/_card.scss +47 -0
  370. package/src/pico/components/_dropdown.scss +203 -0
  371. package/src/pico/components/_modal.scss +181 -0
  372. package/src/pico/components/_nav.scss +79 -0
  373. package/src/pico/components/_progress.scss +70 -0
  374. package/src/pico/components/_property.scss +34 -0
  375. package/src/pico/content/_button.scss +152 -0
  376. package/src/pico/content/_code.scss +63 -0
  377. package/src/pico/content/_embedded.scss +0 -0
  378. package/src/pico/content/_form-alt.scss +276 -0
  379. package/src/pico/content/_form.scss +259 -0
  380. package/src/pico/content/_misc.scss +0 -0
  381. package/src/pico/content/_table.scss +28 -0
  382. package/src/pico/content/_toggle.scss +132 -0
  383. package/src/pico/content/_typography.scss +232 -0
  384. package/src/pico/layout/_container.scss +40 -0
  385. package/src/pico/layout/_document.scss +0 -0
  386. package/src/pico/layout/_flex.scss +46 -0
  387. package/src/pico/layout/_grid.scss +24 -0
  388. package/src/pico/layout/_scroller.scss +16 -0
  389. package/src/pico/layout/_section.scss +8 -0
  390. package/src/pico/layout/_sectioning.scss +55 -0
  391. package/src/pico/pico.scss +60 -0
  392. package/src/pico/reset/_accessibility.scss +34 -0
  393. package/src/pico/reset/_button.scss +17 -0
  394. package/src/pico/reset/_code.scss +15 -0
  395. package/src/pico/reset/_document.scss +48 -0
  396. package/src/pico/reset/_embedded.scss +39 -0
  397. package/src/pico/reset/_form.scss +97 -0
  398. package/src/pico/reset/_misc.scss +23 -0
  399. package/src/pico/reset/_nav.scss +5 -0
  400. package/src/pico/reset/_progress.scss +4 -0
  401. package/src/pico/reset/_table.scss +8 -0
  402. package/src/pico/reset/_typography.scss +25 -0
  403. package/src/pico/themes/default/_colors.scss +65 -0
  404. package/src/pico/themes/default/_dark.scss +148 -0
  405. package/src/pico/themes/default/_light.scss +149 -0
  406. package/src/pico/themes/default/_styles.scss +272 -0
  407. package/src/pico/themes/default.scss +34 -0
  408. package/src/pico/utilities/_accessibility.scss +3 -0
  409. package/src/pico/utilities/_loading.scss +52 -0
  410. package/src/pico/utilities/_reduce-motion.scss +27 -0
  411. package/src/pico/utilities/_tooltip.scss +101 -0
  412. package/src/result.ts +17 -21
  413. package/src/scope/describe.ts +16 -6
  414. package/src/scope/display/console.ts +4 -4
  415. package/src/scope/display/dom.ts +7 -7
  416. package/src/scope/display/junit.ts +3 -3
  417. package/src/scope/execute.ts +5 -8
  418. package/src/scope/expect.ts +12 -11
  419. package/src/scope/state.ts +10 -0
  420. package/src/server/http/css.ts +65 -0
  421. package/src/server/http/index.ts +4 -2
  422. package/src/server/http/response.ts +7 -4
  423. package/src/server/http/sitemap.ts +1 -1
  424. package/src/server/main.ts +9 -2
  425. package/src/test.mjs +22 -18
  426. package/src/test_all.ts +20 -9
  427. package/src/zip/spec.txt +3260 -0
  428. package/build/components/button_bar.js +0 -16
  429. package/build/components/select.d.ts +0 -13
  430. package/build/components/test.js +0 -2
  431. package/build/display.js +0 -3
  432. package/build/dom/dom.d.ts +0 -27
  433. package/build/dom/form/form.app.d.ts +0 -1
  434. package/build/dom/form/form.d.ts +0 -25
  435. package/build/dom/html.d.ts +0 -117
  436. package/build/dom/router/link.d.ts +0 -6
  437. package/build/dom/svg.d.ts +0 -64
  438. package/build/dom/test.js +0 -2
  439. package/build/equal.d.ts +0 -4
  440. package/build/equal.js +0 -22
  441. package/build/index.d.ts +0 -13
  442. package/build/index.js +0 -13
  443. package/build/parcel_resolver.d.ts +0 -3
  444. package/build/parcel_resolver.js +0 -19
  445. package/build/test.mjs +0 -23
  446. package/build/test_all.js +0 -19
  447. package/src/observable/observable._js +0 -175
@@ -0,0 +1,51 @@
1
+ /**
2
+ * Input group and button group
3
+ */
4
+
5
+ .button-group,
6
+ .input-group {
7
+ // Stick buttons together
8
+ display: flex;
9
+ flex-direction: row;
10
+
11
+ // Buttons have no margin-bottom set
12
+ & > button,
13
+ & > label,
14
+ & > select,
15
+ & > input:not([type="checkbox"]):not([type="radio"]) {
16
+ margin-bottom: 0;
17
+ }
18
+
19
+ // No round corners in button groups
20
+ & > button:not(:last-child),
21
+ & > [role="button"]:not(:last-child),
22
+ & > input:not(:last-child),
23
+ & > select:not(:last-child) {
24
+ border-top-right-radius: 0;
25
+ border-bottom-right-radius: 0;
26
+ /* border-right: 0;*/
27
+ }
28
+
29
+ & > [role="button"]:not(:first-child),
30
+ & > input:not(:first-child),
31
+ & > button:not(:first-child),
32
+ & > select:not(:first-child) {
33
+ border-top-left-radius: 0;
34
+ border-bottom-left-radius: 0;
35
+ border-left: 0;
36
+ }
37
+ }
38
+
39
+ // Radio groups need a text label
40
+ .input-group > [type="radio"] ~ label {
41
+ margin-right: 0;
42
+ }
43
+
44
+ // The selected radio button will be outlined when outline class is choose and in reverse
45
+ .input-group:not(.outline)
46
+ > input[type="radio"]:not(:checked)
47
+ + label[role="button"],
48
+ .input-group.outline > input[type="radio"]:checked + label[role="button"] {
49
+ --background-color: transparent;
50
+ --color: var(--primary);
51
+ }
@@ -0,0 +1,47 @@
1
+ article {
2
+ display: flex;
3
+ flex-direction: column;
4
+ margin: var(--block-spacing-vertical) 0;
5
+ padding: var(--block-spacing-vertical) var(--block-spacing-horizontal);
6
+ border-radius: var(--border-radius);
7
+ background: var(--card-background-color);
8
+ box-shadow: var(--card-box-shadow);
9
+
10
+ > header,
11
+ > footer {
12
+ display: flex;
13
+ flex-direction: row;
14
+ justify-content: space-between;
15
+ margin-right: calc(var(--block-spacing-horizontal) * -1);
16
+ margin-left: calc(var(--block-spacing-horizontal) * -1);
17
+ padding: calc(var(--block-spacing-vertical) * 0.66)
18
+ var(--block-spacing-horizontal);
19
+ background-color: var(--card-sectionning-background-color);
20
+ }
21
+
22
+ > header {
23
+ margin-top: calc(var(--block-spacing-vertical) * -1);
24
+ margin-bottom: var(--block-spacing-vertical);
25
+ border-bottom: var(--border-width) solid var(--card-border-color);
26
+
27
+ nav ul {
28
+ &:first-of-type {
29
+ margin: inherit;
30
+ }
31
+
32
+ li {
33
+ padding: 0 calc(var(--nav-element-spacing-horizontal) / 2);
34
+ }
35
+ }
36
+ }
37
+
38
+ > main {
39
+ flex: 1;
40
+ }
41
+
42
+ > footer {
43
+ margin-top: var(--block-spacing-vertical);
44
+ margin-bottom: calc(var(--block-spacing-vertical) * -1);
45
+ border-top: var(--border-width) solid var(--card-border-color);
46
+ }
47
+ }
@@ -0,0 +1,203 @@
1
+ details[role="list"],
2
+ li[role="list"] {
3
+ position: relative;
4
+ }
5
+
6
+ details[role="list"] summary + ul,
7
+ li[role="list"] > ul {
8
+ display: flex;
9
+ z-index: 99;
10
+ position: absolute;
11
+ top: auto;
12
+ right: 0;
13
+ left: 0;
14
+ flex-direction: column;
15
+ margin: 0;
16
+ padding: 0;
17
+ border: var(--border-width) solid var(--dropdown-border-color);
18
+ border-radius: var(--border-radius);
19
+ border-top-right-radius: 0;
20
+ border-top-left-radius: 0;
21
+ background-color: var(--dropdown-background-color);
22
+ box-shadow: var(--card-box-shadow);
23
+ color: var(--dropdown-color);
24
+ white-space: nowrap;
25
+
26
+ li {
27
+ width: 100%;
28
+ margin-bottom: 0;
29
+ padding: calc(var(--form-element-spacing-vertical) * 0.5)
30
+ var(--form-element-spacing-horizontal);
31
+ list-style: none;
32
+
33
+ &:first-of-type {
34
+ margin-top: calc(var(--form-element-spacing-vertical) * 0.5);
35
+ }
36
+
37
+ &:last-of-type {
38
+ margin-bottom: calc(var(--form-element-spacing-vertical) * 0.5);
39
+ }
40
+
41
+ a {
42
+ display: block;
43
+ margin: calc(var(--form-element-spacing-vertical) * -0.5)
44
+ calc(var(--form-element-spacing-horizontal) * -1);
45
+ padding: calc(var(--form-element-spacing-vertical) * 0.5)
46
+ var(--form-element-spacing-horizontal);
47
+ overflow: hidden;
48
+ color: var(--dropdown-color);
49
+ text-decoration: none;
50
+ text-overflow: ellipsis;
51
+
52
+ &:hover {
53
+ background-color: var(--dropdown-hover-background-color);
54
+ }
55
+ }
56
+ }
57
+ }
58
+
59
+ // Marker
60
+ details[role="list"] summary,
61
+ li[role="list"] > a {
62
+ &::after {
63
+ display: block;
64
+ width: 1rem;
65
+ height: calc(1rem * var(--line-height, 1.5));
66
+ margin-inline-start: 0.5rem;
67
+ float: right;
68
+ transform: rotate(0deg);
69
+ background-position: right center;
70
+ background-size: 1rem auto;
71
+ background-repeat: no-repeat;
72
+ content: "";
73
+ }
74
+ }
75
+
76
+ // Global dropdown only
77
+ details[role="list"] {
78
+ padding: 0;
79
+ border-bottom: none;
80
+
81
+ // Style <summary> as <select>
82
+ summary {
83
+ margin-bottom: 0;
84
+
85
+ &:not([role]) {
86
+ height: calc(
87
+ 1rem * var(--line-height) + var(--form-element-spacing-vertical) * 2 +
88
+ var(--border-width) * 2
89
+ );
90
+ padding: var(--form-element-spacing-vertical)
91
+ var(--form-element-spacing-horizontal);
92
+ border: var(--border-width) solid var(--form-element-border-color);
93
+ border-radius: var(--border-radius);
94
+ background-color: var(--form-element-background-color);
95
+ color: var(--form-element-placeholder-color);
96
+ line-height: inherit;
97
+ cursor: pointer;
98
+
99
+ @if $enable-transitions {
100
+ transition: background-color var(--transition),
101
+ border-color var(--transition), color var(--transition),
102
+ box-shadow var(--transition);
103
+ }
104
+
105
+ &:active,
106
+ &:focus {
107
+ border-color: var(--form-element-active-border-color);
108
+ background-color: var(--form-element-active-background-color);
109
+ }
110
+
111
+ &:focus {
112
+ box-shadow: 0 0 0 var(--outline-width) var(--form-element-focus-color);
113
+ }
114
+ }
115
+ }
116
+
117
+ // Close for details[role="list"]
118
+ &[open] summary {
119
+ border-bottom-right-radius: 0;
120
+ border-bottom-left-radius: 0;
121
+
122
+ &::before {
123
+ display: block;
124
+ z-index: 1;
125
+ position: fixed;
126
+ top: 0;
127
+ right: 0;
128
+ bottom: 0;
129
+ left: 0;
130
+ background: none;
131
+ content: "";
132
+ cursor: default;
133
+ }
134
+ }
135
+ }
136
+
137
+ // All Dropdowns inside <nav>
138
+ nav details[role="list"] summary,
139
+ nav li[role="list"] a {
140
+ display: flex;
141
+ direction: ltr;
142
+ }
143
+
144
+ nav details[role="list"] summary + ul,
145
+ nav li[role="list"] > ul {
146
+ min-width: fit-content;
147
+ border-radius: var(--border-radius);
148
+
149
+ li a {
150
+ border-radius: 0;
151
+ }
152
+ }
153
+
154
+ // Dropdowns inside <nav> as nested <details>
155
+ nav details[role="list"] {
156
+ summary,
157
+ summary:not([role]) {
158
+ height: auto;
159
+ padding: var(--nav-link-spacing-vertical) var(--nav-link-spacing-horizontal);
160
+ }
161
+
162
+ &[open] summary {
163
+ border-radius: var(--border-radius);
164
+ }
165
+
166
+ summary + ul {
167
+ margin-top: var(--outline-width);
168
+ margin-inline-start: 0;
169
+ }
170
+
171
+ summary[role="link"] {
172
+ margin-bottom: calc(var(--nav-link-spacing-vertical) * -1);
173
+ line-height: var(--line-height);
174
+
175
+ + ul {
176
+ margin-top: calc(var(--nav-link-spacing-vertical) + var(--outline-width));
177
+ margin-inline-start: calc(var(--nav-link-spacing-horizontal) * -1);
178
+ }
179
+ }
180
+ }
181
+
182
+ // Dropdowns inside a <nav> without using <details>
183
+ li[role="list"] {
184
+ // Open on hover (for mobile)
185
+ // or on active/focus (for keyboard navigation)
186
+ &:hover > ul,
187
+ a:active ~ ul,
188
+ a:focus ~ ul {
189
+ display: flex;
190
+ }
191
+
192
+ > ul {
193
+ display: none;
194
+ margin-top: calc(var(--nav-link-spacing-vertical) + var(--outline-width));
195
+ margin-inline-start: calc(
196
+ var(--nav-element-spacing-horizontal) - var(--nav-link-spacing-horizontal)
197
+ );
198
+ }
199
+
200
+ > a::after {
201
+ background-image: var(--icon-chevron);
202
+ }
203
+ }
@@ -0,0 +1,181 @@
1
+ :root {
2
+ --scrollbar-width: 0px;
3
+ }
4
+
5
+ dialog {
6
+ display: flex;
7
+ z-index: 999;
8
+ position: fixed;
9
+ top: 0;
10
+ right: 0;
11
+ bottom: 0;
12
+ left: 0;
13
+ align-items: center;
14
+ justify-content: center;
15
+ width: inherit;
16
+ min-width: 100%;
17
+ height: inherit;
18
+ min-height: 100%;
19
+ padding: var(--spacing);
20
+ border: 0;
21
+ background-color: var(--modal-overlay-background-color);
22
+
23
+ // Content
24
+ article {
25
+ max-height: calc(100vh - var(--spacing) * 2);
26
+ width: calc(100vw - var(--spacing) * 2);
27
+ overflow: auto;
28
+
29
+ @if map-get($breakpoints, "sm") {
30
+ @media (min-width: map-get($breakpoints, "sm")) {
31
+ width: map-get($viewports, "sm");
32
+ }
33
+ }
34
+
35
+ @if map-get($breakpoints, "md") {
36
+ @media (min-width: map-get($breakpoints, "md")) {
37
+ width: map-get($viewports, "md");
38
+ }
39
+ }
40
+
41
+ @if map-get($breakpoints, "lg") {
42
+ @media (min-width: map-get($breakpoints, "lg")) {
43
+ width: map-get($viewports, "lg");
44
+ }
45
+ }
46
+
47
+ @if map-get($breakpoints, "xl") {
48
+ @media (min-width: map-get($breakpoints, "xl")) {
49
+ width: map-get($viewports, "xl");
50
+ }
51
+ }
52
+
53
+ > header,
54
+ > footer {
55
+ padding: calc(var(--block-spacing-vertical) * 0.5)
56
+ var(--block-spacing-horizontal);
57
+ }
58
+
59
+ > header {
60
+ .close {
61
+ margin: 0;
62
+ margin-left: var(--spacing);
63
+ float: right;
64
+ }
65
+ }
66
+
67
+ > footer {
68
+ text-align: right;
69
+
70
+ [role="button"] {
71
+ margin-bottom: 0;
72
+
73
+ &:not(:first-of-type) {
74
+ margin-left: calc(var(--spacing) * 0.5);
75
+ }
76
+ }
77
+ }
78
+
79
+ p {
80
+ &:last-of-type {
81
+ margin: 0;
82
+ }
83
+ }
84
+
85
+ // Close icon
86
+ @if $enable-classes {
87
+ .close {
88
+ display: block;
89
+ width: 1rem;
90
+ height: 1rem;
91
+ margin-top: calc(var(--block-spacing-vertical) * -0.5);
92
+ margin-bottom: var(--typography-spacing-vertical);
93
+ margin-left: auto;
94
+ background-image: var(--icon-close);
95
+ background-position: center;
96
+ background-size: auto 1rem;
97
+ background-repeat: no-repeat;
98
+ opacity: 0.5;
99
+
100
+ @if $enable-transitions {
101
+ transition: opacity var(--transition);
102
+ }
103
+
104
+ &:is([aria-current], :hover, :active, :focus) {
105
+ opacity: 1;
106
+ }
107
+ }
108
+ }
109
+ }
110
+
111
+ // Closed state
112
+ &:not([open]),
113
+ &[open="false"] {
114
+ display: none;
115
+ }
116
+ }
117
+
118
+ // Utilities
119
+ @if $enable-classes {
120
+ .modal-is-open {
121
+ padding-right: var(--scrollbar-width, 0px);
122
+ overflow: hidden;
123
+ pointer-events: none;
124
+
125
+ dialog {
126
+ pointer-events: auto;
127
+ }
128
+ }
129
+ }
130
+
131
+ // Animations
132
+ @if ($enable-classes and $enable-transitions) {
133
+ $animation-duration: 0.2s;
134
+
135
+ :where(.modal-is-opening, .modal-is-closing) {
136
+ dialog,
137
+ dialog > article {
138
+ animation-duration: $animation-duration;
139
+ animation-timing-function: ease-in-out;
140
+ animation-fill-mode: both;
141
+ }
142
+
143
+ dialog {
144
+ animation-duration: ($animation-duration * 4);
145
+ animation-name: fadeIn;
146
+
147
+ > article {
148
+ animation-delay: $animation-duration;
149
+ animation-name: slideInDown;
150
+ }
151
+ }
152
+ }
153
+
154
+ .modal-is-closing {
155
+ dialog,
156
+ dialog > article {
157
+ animation-delay: 0s;
158
+ animation-direction: reverse;
159
+ }
160
+ }
161
+
162
+ @keyframes fadeIn {
163
+ from {
164
+ background-color: transparent;
165
+ }
166
+ to {
167
+ background-color: var(--modal-overlay-background-color);
168
+ }
169
+ }
170
+
171
+ @keyframes slideInDown {
172
+ from {
173
+ transform: translateY(-100%);
174
+ opacity: 0;
175
+ }
176
+ to {
177
+ transform: translateY(0);
178
+ opacity: 1;
179
+ }
180
+ }
181
+ }
@@ -0,0 +1,79 @@
1
+ nav,
2
+ nav ul {
3
+ display: flex;
4
+ }
5
+
6
+ nav {
7
+ justify-content: space-between;
8
+
9
+ ol,
10
+ ul {
11
+ align-items: center;
12
+ margin-bottom: 0;
13
+ padding: 0;
14
+ list-style: none;
15
+
16
+ &:first-of-type {
17
+ margin-left: calc(var(--nav-element-spacing-horizontal) * -1);
18
+ }
19
+ &:last-of-type {
20
+ margin-right: calc(var(--nav-element-spacing-horizontal) * -1);
21
+ }
22
+ }
23
+
24
+ li {
25
+ display: inline-block;
26
+ margin: 0;
27
+ padding: var(--nav-element-spacing-vertical)
28
+ var(--nav-element-spacing-horizontal);
29
+
30
+ // Minimal support for buttons and forms elements
31
+ > * {
32
+ --spacing: 0;
33
+ }
34
+ }
35
+
36
+ :where(a, [role="link"]) {
37
+ display: inline-block;
38
+ margin: calc(var(--nav-link-spacing-vertical) * -1)
39
+ calc(var(--nav-link-spacing-horizontal) * -1);
40
+ padding: var(--nav-link-spacing-vertical) var(--nav-link-spacing-horizontal);
41
+ border-radius: var(--border-radius);
42
+ text-decoration: none;
43
+
44
+ &:is([aria-current], :hover, :active, :focus) {
45
+ text-decoration: none;
46
+ }
47
+ }
48
+
49
+ // Minimal support for role="button"
50
+ [role="button"] {
51
+ margin-right: inherit;
52
+ margin-left: inherit;
53
+ padding: var(--nav-link-spacing-vertical) var(--nav-link-spacing-horizontal);
54
+ }
55
+ }
56
+
57
+ // Vertical Nav
58
+ aside {
59
+ nav,
60
+ ol,
61
+ ul,
62
+ li {
63
+ display: block;
64
+ }
65
+
66
+ li {
67
+ padding: calc(var(--nav-element-spacing-vertical) * 0.5)
68
+ var(--nav-element-spacing-horizontal);
69
+
70
+ a {
71
+ display: block;
72
+ }
73
+
74
+ // Minimal support for links as buttons
75
+ [role="button"] {
76
+ margin: inherit;
77
+ }
78
+ }
79
+ }
@@ -0,0 +1,70 @@
1
+ progress {
2
+ // Reset the default appearance
3
+ -webkit-appearance: none;
4
+ -moz-appearance: none;
5
+
6
+ // Styles
7
+ display: inline-block;
8
+ appearance: none;
9
+ width: 100%;
10
+ height: 0.5rem;
11
+ margin-bottom: calc(var(--spacing) * 0.5);
12
+ overflow: hidden;
13
+
14
+ // Remove Firefox and Opera border
15
+ border: 0;
16
+ border-radius: var(--border-radius);
17
+ background-color: var(--progress-background-color);
18
+
19
+ // IE10 uses `color` to set the bar background-color
20
+ color: var(--progress-color);
21
+
22
+ &::-webkit-progress-bar {
23
+ border-radius: var(--border-radius);
24
+ background: none;
25
+ }
26
+ &[value]::-webkit-progress-value {
27
+ background-color: var(--progress-color);
28
+ }
29
+ &::-moz-progress-bar {
30
+ background-color: var(--progress-color);
31
+ }
32
+
33
+ // Indeterminate state
34
+ @media (prefers-reduced-motion: no-preference) {
35
+ &:indeterminate {
36
+ background: var(--progress-background-color)
37
+ linear-gradient(
38
+ to right,
39
+ var(--progress-color) 30%,
40
+ var(--progress-background-color) 30%
41
+ )
42
+ top left / 150% 150% no-repeat;
43
+ animation: progressIndeterminate 1s linear infinite;
44
+
45
+ &[value]::-webkit-progress-value {
46
+ background-color: transparent;
47
+ }
48
+ &::-moz-progress-bar {
49
+ background-color: transparent;
50
+ }
51
+ }
52
+ }
53
+ }
54
+
55
+ [dir="rtl"] {
56
+ @media (prefers-reduced-motion: no-preference) {
57
+ progress:indeterminate {
58
+ animation-direction: reverse;
59
+ }
60
+ }
61
+ }
62
+
63
+ @keyframes progressIndeterminate {
64
+ 0% {
65
+ background-position: 200% 0;
66
+ }
67
+ 100% {
68
+ background-position: -200% 0;
69
+ }
70
+ }
@@ -0,0 +1,34 @@
1
+ dl {
2
+ display: grid;
3
+ grid-template-columns: minmax(max-content, 1fr) minmax(auto, 2fr);
4
+ }
5
+
6
+ dt {
7
+ grid-column-start: 1;
8
+ }
9
+
10
+ dd {
11
+ grid-column-start: 2;
12
+ margin: 0;
13
+ }
14
+
15
+ dl > header {
16
+ grid-column: 1 / span 2;
17
+ font-weight: bold;
18
+ background-color: var(--muted-color);
19
+ color: var(--primary-inverse);
20
+ padding: var(--form-element-spacing-vertical)
21
+ var(--form-element-spacing-horizontal);
22
+ }
23
+
24
+ dd,
25
+ dt {
26
+ padding: var(--form-element-spacing-vertical)
27
+ var(--form-element-spacing-horizontal);
28
+ border: 1px solid var(--muted-border-color);
29
+ }
30
+
31
+ dd:nth-of-type(even),
32
+ dt:nth-of-type(even) {
33
+ background-color: var(--table-row-stripped-background-color);
34
+ }