sprae 12.3.8 → 12.4.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 (79) hide show
  1. package/core.js +236 -59
  2. package/directive/_.js +8 -0
  3. package/directive/class.js +9 -0
  4. package/directive/each.js +41 -17
  5. package/directive/else.js +6 -2
  6. package/directive/event.js +9 -0
  7. package/directive/fx.js +5 -0
  8. package/directive/hidden.js +6 -0
  9. package/directive/html.js +29 -6
  10. package/directive/if.js +7 -2
  11. package/directive/portal.js +38 -0
  12. package/directive/ref.js +8 -0
  13. package/directive/scope.js +7 -0
  14. package/directive/sequence.js +9 -1
  15. package/directive/spread.js +6 -0
  16. package/directive/style.js +9 -0
  17. package/directive/text.js +5 -0
  18. package/directive/value.js +13 -3
  19. package/dist/sprae.js +3 -5
  20. package/dist/sprae.js.map +4 -4
  21. package/dist/sprae.umd.js +3 -5
  22. package/dist/sprae.umd.js.map +4 -4
  23. package/package.json +35 -8
  24. package/readme.md +39 -54
  25. package/signal.js +41 -3
  26. package/sprae.js +117 -21
  27. package/store.js +54 -13
  28. package/types/core.d.ts +222 -0
  29. package/types/core.d.ts.map +1 -0
  30. package/types/directive/_.d.ts +3 -0
  31. package/types/directive/_.d.ts.map +1 -0
  32. package/types/directive/aria.d.ts.map +1 -0
  33. package/types/directive/class.d.ts +3 -0
  34. package/types/directive/class.d.ts.map +1 -0
  35. package/types/directive/data.d.ts.map +1 -0
  36. package/types/directive/each.d.ts +6 -0
  37. package/types/directive/each.d.ts.map +1 -0
  38. package/types/directive/else.d.ts +3 -0
  39. package/types/directive/else.d.ts.map +1 -0
  40. package/types/directive/event.d.ts +5 -0
  41. package/types/directive/event.d.ts.map +1 -0
  42. package/types/directive/fx.d.ts +3 -0
  43. package/types/directive/fx.d.ts.map +1 -0
  44. package/types/directive/hidden.d.ts +3 -0
  45. package/types/directive/hidden.d.ts.map +1 -0
  46. package/types/directive/html.d.ts +3 -0
  47. package/types/directive/html.d.ts.map +1 -0
  48. package/types/directive/if.d.ts +3 -0
  49. package/types/directive/if.d.ts.map +1 -0
  50. package/types/directive/item.d.ts.map +1 -0
  51. package/types/directive/portal.d.ts +3 -0
  52. package/types/directive/portal.d.ts.map +1 -0
  53. package/types/directive/ref.d.ts +5 -0
  54. package/types/directive/ref.d.ts.map +1 -0
  55. package/types/directive/resize.d.ts.map +1 -0
  56. package/types/directive/scope.d.ts +3 -0
  57. package/types/directive/scope.d.ts.map +1 -0
  58. package/types/directive/sequence.d.ts +5 -0
  59. package/types/directive/sequence.d.ts.map +1 -0
  60. package/types/directive/spread.d.ts +3 -0
  61. package/types/directive/spread.d.ts.map +1 -0
  62. package/types/directive/style.d.ts +3 -0
  63. package/types/directive/style.d.ts.map +1 -0
  64. package/types/directive/text.d.ts +3 -0
  65. package/types/directive/text.d.ts.map +1 -0
  66. package/types/directive/value.d.ts +4 -0
  67. package/types/directive/value.d.ts.map +1 -0
  68. package/types/signal.d.ts +6 -0
  69. package/types/signal.d.ts.map +1 -0
  70. package/types/sprae.d.ts +15 -0
  71. package/types/sprae.d.ts.map +1 -0
  72. package/types/store.d.ts +15 -0
  73. package/types/store.d.ts.map +1 -0
  74. package/directive/aria.js +0 -0
  75. package/directive/data.js +0 -0
  76. package/directive/item.js +0 -0
  77. package/dist/sprae.micro.js +0 -5
  78. package/dist/sprae.micro.js.map +0 -7
  79. package/micro.js +0 -56
package/micro.js DELETED
@@ -1,56 +0,0 @@
1
- // Microsprae.
2
- // No prop mods, sync effects, no aliases, no chains, core effects
3
-
4
- import sprae, { effect, parse, _state, _dispose, use, directive, store } from "./core.js"
5
-
6
- import _if from "./directive/if.js";
7
- import _else from "./directive/else.js";
8
- import _text from "./directive/text.js";
9
- import _class from "./directive/class.js";
10
- import _style from "./directive/style.js";
11
- import _fx from "./directive/fx.js";
12
- import _value from "./directive/value.js";
13
- import _ref from "./directive/ref.js";
14
- import _scope from "./directive/scope.js";
15
- import _each from "./directive/each.js";
16
- import _default from "./directive/_.js";
17
- import _spread from "./directive/spread.js";
18
- import _event from "./directive/event.js";
19
-
20
-
21
- use({
22
- compile: expr => sprae.constructor(`with (arguments[0]) { ${expr} }`),
23
- dir(target, name, expr, state) {
24
- let [dirName] = name.split('.'), d = directive[dirName] || directive._
25
-
26
- return (_update, _eval) => (
27
- (_update = d(target, state, expr, name))[_dispose] ??
28
- (
29
- _eval = _update.eval ?? parse(expr),
30
- state = target[_state] ?? state,
31
- effect(() => _eval(state, _update))
32
- )
33
- )
34
- }
35
- })
36
-
37
- Object.assign(directive, {
38
- // _: (el, state, expr, name) => (name.startsWith('on') ? _default : _event)(el, state, expr, name),
39
- _: _default,
40
- // '': _spread,
41
- class: _class,
42
- text: _text,
43
- // style: _style,
44
- fx: _fx,
45
- // value: _value,
46
- ref: _ref,
47
- // scope: _scope,
48
- // if: _if,
49
- // else: _else,
50
- // each: _each
51
- })
52
-
53
-
54
- export { sprae, store }
55
-
56
- export default sprae