ripple 0.3.72 → 0.3.76

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 (172) hide show
  1. package/CHANGELOG.md +116 -0
  2. package/package.json +3 -3
  3. package/src/jsx-runtime.d.ts +4 -10
  4. package/src/runtime/dynamic-client.js +33 -0
  5. package/src/runtime/dynamic-server.js +80 -0
  6. package/src/runtime/index-client.js +5 -13
  7. package/src/runtime/index-server.js +2 -0
  8. package/src/runtime/internal/client/blocks.js +6 -27
  9. package/src/runtime/internal/client/composite.js +11 -6
  10. package/src/runtime/internal/client/for.js +80 -5
  11. package/src/runtime/internal/client/index.js +0 -2
  12. package/src/runtime/internal/client/render.js +5 -2
  13. package/src/runtime/internal/client/types.d.ts +0 -10
  14. package/src/runtime/internal/server/index.js +8 -1
  15. package/tests/client/__snapshots__/computed-properties.test.tsrx.snap +8 -0
  16. package/tests/client/__snapshots__/for.test.tsrx.snap +22 -0
  17. package/tests/client/__snapshots__/html.test.tsrx.snap +4 -0
  18. package/tests/client/array/array.copy-within.test.tsrx +19 -19
  19. package/tests/client/array/array.derived.test.tsrx +97 -109
  20. package/tests/client/array/array.iteration.test.tsrx +28 -28
  21. package/tests/client/array/array.mutations.test.tsrx +68 -68
  22. package/tests/client/array/array.static.test.tsrx +82 -92
  23. package/tests/client/array/array.to-methods.test.tsrx +15 -15
  24. package/tests/client/async-suspend.test.tsrx +180 -179
  25. package/tests/client/basic/__snapshots__/basic.attributes.test.tsrx.snap +2 -0
  26. package/tests/client/basic/__snapshots__/basic.rendering.test.tsrx.snap +4 -0
  27. package/tests/client/basic/basic.attributes.test.tsrx +273 -317
  28. package/tests/client/basic/basic.collections.test.tsrx +55 -61
  29. package/tests/client/basic/basic.components.test.tsrx +198 -220
  30. package/tests/client/basic/basic.errors.test.tsrx +70 -76
  31. package/tests/client/basic/basic.events.test.tsrx +80 -85
  32. package/tests/client/basic/basic.get-set.test.tsrx +54 -64
  33. package/tests/client/basic/basic.hmr.test.tsrx +15 -19
  34. package/tests/client/basic/basic.reactivity.test.tsrx +121 -135
  35. package/tests/client/basic/basic.rendering.test.tsrx +273 -178
  36. package/tests/client/basic/basic.styling.test.tsrx +16 -14
  37. package/tests/client/basic/basic.utilities.test.tsrx +8 -10
  38. package/tests/client/boundaries.test.tsrx +18 -18
  39. package/tests/client/compiler/compiler.assignments.test.tsrx +77 -76
  40. package/tests/client/compiler/compiler.attributes.test.tsrx +18 -14
  41. package/tests/client/compiler/compiler.basic.test.tsrx +357 -288
  42. package/tests/client/compiler/compiler.regex.test.tsrx +40 -44
  43. package/tests/client/compiler/compiler.tracked-access.test.tsrx +57 -38
  44. package/tests/client/compiler/compiler.try-in-function.test.tsrx +16 -16
  45. package/tests/client/compiler/compiler.typescript.test.tsrx +4 -3
  46. package/tests/client/composite/composite.dynamic-components.test.tsrx +62 -47
  47. package/tests/client/composite/composite.generics.test.tsrx +165 -167
  48. package/tests/client/composite/composite.props.test.tsrx +66 -74
  49. package/tests/client/composite/composite.reactivity.test.tsrx +132 -166
  50. package/tests/client/composite/composite.render.test.tsrx +92 -101
  51. package/tests/client/computed-properties.test.tsrx +14 -18
  52. package/tests/client/context.test.tsrx +14 -18
  53. package/tests/client/css/global-additional-cases.test.tsrx +493 -439
  54. package/tests/client/css/global-advanced-selectors.test.tsrx +169 -153
  55. package/tests/client/css/global-at-rules.test.tsrx +71 -66
  56. package/tests/client/css/global-basic.test.tsrx +105 -98
  57. package/tests/client/css/global-classes-ids.test.tsrx +128 -114
  58. package/tests/client/css/global-combinators.test.tsrx +83 -78
  59. package/tests/client/css/global-complex-nesting.test.tsrx +134 -120
  60. package/tests/client/css/global-edge-cases.test.tsrx +138 -120
  61. package/tests/client/css/global-keyframes.test.tsrx +108 -96
  62. package/tests/client/css/global-nested.test.tsrx +88 -78
  63. package/tests/client/css/global-pseudo.test.tsrx +104 -98
  64. package/tests/client/css/global-scoping.test.tsrx +145 -125
  65. package/tests/client/css/style-identifier.test.tsrx +65 -72
  66. package/tests/client/date.test.tsrx +83 -83
  67. package/tests/client/dynamic-elements.test.tsrx +318 -299
  68. package/tests/client/events.test.tsrx +252 -266
  69. package/tests/client/for.test.tsrx +120 -127
  70. package/tests/client/head.test.tsrx +74 -48
  71. package/tests/client/html.test.tsrx +37 -49
  72. package/tests/client/input-value.test.tsrx +1125 -1354
  73. package/tests/client/lazy-array.test.tsrx +10 -16
  74. package/tests/client/lazy-destructuring.test.tsrx +169 -221
  75. package/tests/client/map.test.tsrx +39 -41
  76. package/tests/client/media-query.test.tsrx +15 -19
  77. package/tests/client/object.test.tsrx +46 -56
  78. package/tests/client/portal.test.tsrx +31 -37
  79. package/tests/client/ref.test.tsrx +173 -193
  80. package/tests/client/return.test.tsrx +62 -37
  81. package/tests/client/set.test.tsrx +33 -33
  82. package/tests/client/svg.test.tsrx +197 -216
  83. package/tests/client/switch.test.tsrx +201 -191
  84. package/tests/client/track-async-hydration.test.tsrx +14 -18
  85. package/tests/client/tracked-index-access.test.tsrx +18 -28
  86. package/tests/client/try.test.tsrx +494 -619
  87. package/tests/client/tsx.test.tsrx +286 -292
  88. package/tests/client/typescript-generics.test.tsrx +121 -129
  89. package/tests/client/url/url.derived.test.tsrx +21 -25
  90. package/tests/client/url/url.parsing.test.tsrx +35 -35
  91. package/tests/client/url/url.partial-removal.test.tsrx +32 -32
  92. package/tests/client/url/url.reactivity.test.tsrx +68 -72
  93. package/tests/client/url/url.serialization.test.tsrx +8 -8
  94. package/tests/client/url-search-params/url-search-params.derived.test.tsrx +21 -27
  95. package/tests/client/url-search-params/url-search-params.initialization.test.tsrx +16 -16
  96. package/tests/client/url-search-params/url-search-params.iteration.test.tsrx +37 -37
  97. package/tests/client/url-search-params/url-search-params.mutation.test.tsrx +56 -60
  98. package/tests/client/url-search-params/url-search-params.retrieval.test.tsrx +32 -34
  99. package/tests/client/url-search-params/url-search-params.serialization.test.tsrx +9 -9
  100. package/tests/client/url-search-params/url-search-params.tracked-url.test.tsrx +10 -10
  101. package/tests/hydration/compiled/client/basic.js +390 -319
  102. package/tests/hydration/compiled/client/composite.js +52 -44
  103. package/tests/hydration/compiled/client/for.js +734 -604
  104. package/tests/hydration/compiled/client/head.js +183 -103
  105. package/tests/hydration/compiled/client/html.js +93 -86
  106. package/tests/hydration/compiled/client/if-children.js +95 -71
  107. package/tests/hydration/compiled/client/if.js +113 -89
  108. package/tests/hydration/compiled/client/mixed-control-flow.js +225 -209
  109. package/tests/hydration/compiled/client/nested-control-flow.js +94 -98
  110. package/tests/hydration/compiled/client/reactivity.js +26 -24
  111. package/tests/hydration/compiled/client/return.js +8 -42
  112. package/tests/hydration/compiled/client/switch.js +208 -173
  113. package/tests/hydration/compiled/client/track-async-serialization.js +176 -128
  114. package/tests/hydration/compiled/client/try.js +29 -21
  115. package/tests/hydration/compiled/server/basic.js +210 -221
  116. package/tests/hydration/compiled/server/composite.js +13 -14
  117. package/tests/hydration/compiled/server/for.js +427 -444
  118. package/tests/hydration/compiled/server/head.js +199 -189
  119. package/tests/hydration/compiled/server/html.js +33 -41
  120. package/tests/hydration/compiled/server/if-children.js +114 -117
  121. package/tests/hydration/compiled/server/if.js +77 -83
  122. package/tests/hydration/compiled/server/mixed-control-flow.js +145 -150
  123. package/tests/hydration/compiled/server/nested-control-flow.js +10 -0
  124. package/tests/hydration/compiled/server/reactivity.js +24 -22
  125. package/tests/hydration/compiled/server/return.js +6 -18
  126. package/tests/hydration/compiled/server/switch.js +179 -176
  127. package/tests/hydration/compiled/server/track-async-serialization.js +88 -70
  128. package/tests/hydration/compiled/server/try.js +31 -35
  129. package/tests/hydration/components/basic.tsrx +216 -258
  130. package/tests/hydration/components/composite.tsrx +32 -42
  131. package/tests/hydration/components/events.tsrx +81 -101
  132. package/tests/hydration/components/for.tsrx +270 -336
  133. package/tests/hydration/components/head.tsrx +43 -39
  134. package/tests/hydration/components/hmr.tsrx +16 -22
  135. package/tests/hydration/components/html-in-template.tsrx +15 -21
  136. package/tests/hydration/components/html.tsrx +442 -526
  137. package/tests/hydration/components/if-children.tsrx +107 -125
  138. package/tests/hydration/components/if.tsrx +68 -90
  139. package/tests/hydration/components/mixed-control-flow.tsrx +65 -72
  140. package/tests/hydration/components/nested-control-flow.tsrx +202 -216
  141. package/tests/hydration/components/portal.tsrx +33 -41
  142. package/tests/hydration/components/reactivity.tsrx +26 -34
  143. package/tests/hydration/components/return.tsrx +4 -6
  144. package/tests/hydration/components/switch.tsrx +73 -78
  145. package/tests/hydration/components/track-async-serialization.tsrx +83 -93
  146. package/tests/hydration/components/try.tsrx +37 -51
  147. package/tests/hydration/switch.test.js +8 -8
  148. package/tests/server/await.test.tsrx +3 -3
  149. package/tests/server/basic.attributes.test.tsrx +117 -162
  150. package/tests/server/basic.components.test.tsrx +164 -194
  151. package/tests/server/basic.test.tsrx +299 -199
  152. package/tests/server/compiler.test.tsrx +142 -72
  153. package/tests/server/composite.props.test.tsrx +54 -58
  154. package/tests/server/composite.test.tsrx +165 -167
  155. package/tests/server/context.test.tsrx +13 -17
  156. package/tests/server/dynamic-elements.test.tsrx +147 -148
  157. package/tests/server/for.test.tsrx +115 -84
  158. package/tests/server/head.test.tsrx +54 -31
  159. package/tests/server/html-nesting-validation.test.tsrx +16 -8
  160. package/tests/server/if.test.tsrx +49 -59
  161. package/tests/server/lazy-destructuring.test.tsrx +288 -366
  162. package/tests/server/return.test.tsrx +58 -36
  163. package/tests/server/streaming-ssr.test.tsrx +4 -4
  164. package/tests/server/style-identifier.test.tsrx +61 -69
  165. package/tests/server/switch.test.tsrx +89 -97
  166. package/tests/server/track-async-serialization.test.tsrx +85 -103
  167. package/tests/server/try.test.tsrx +275 -360
  168. package/tests/utils/ref-types.test.js +72 -0
  169. package/tests/utils/vite-plugin-config.test.js +41 -74
  170. package/types/index.d.ts +29 -4
  171. package/src/runtime/internal/client/compat.js +0 -40
  172. package/tests/utils/compiler-compat-config.test.js +0 -38
@@ -2,11 +2,9 @@ import { Fragment, flushSync, track } from 'ripple';
2
2
 
3
3
  describe('Fragment innerHTML', () => {
4
4
  it('renders host innerHTML as content instead of an attribute', () => {
5
- function App() {
6
- return <>
7
- const html = '<span>Host HTML</span>';
8
- <code innerHTML={html} />
9
- </>;
5
+ function App() @{
6
+ const html = '<span>Host HTML</span>';
7
+ <code innerHTML={html} />
10
8
  }
11
9
 
12
10
  render(App);
@@ -17,14 +15,14 @@ describe('Fragment innerHTML', () => {
17
15
  });
18
16
 
19
17
  it('renders spread innerHTML as content instead of an attribute', () => {
20
- function App() {
21
- return <>
22
- let &[attrs] = track<{ innerHTML?: string }>({
23
- innerHTML: '<span>Spread HTML</span>',
24
- });
18
+ function App() @{
19
+ let &[attrs] = track<{ innerHTML?: string }>({
20
+ innerHTML: '<span>Spread HTML</span>',
21
+ });
22
+ <>
25
23
  <code {...attrs} />
26
24
  <button onClick={() => (attrs = { innerHTML: '<em>Updated HTML</em>' })}>{'Update'}</button>
27
- </>;
25
+ </>
28
26
  }
29
27
 
30
28
  render(App);
@@ -42,11 +40,9 @@ describe('Fragment innerHTML', () => {
42
40
  });
43
41
 
44
42
  it('uses the last innerHTML value when spreads and direct props are mixed', () => {
45
- function App() {
46
- return <>
47
- const attrs = { innerHTML: '<span>Spread HTML</span>' };
48
- <code {...attrs} innerHTML="<em>Direct HTML</em>" />
49
- </>;
43
+ function App() @{
44
+ const attrs = { innerHTML: '<span>Spread HTML</span>' };
45
+ <code {...attrs} innerHTML="<em>Direct HTML</em>" />
50
46
  }
51
47
 
52
48
  render(App);
@@ -57,11 +53,9 @@ describe('Fragment innerHTML', () => {
57
53
  });
58
54
 
59
55
  it('renders static innerHTML fragments', () => {
60
- function App() {
61
- return <>
62
- let str = '<div>Test</div>';
63
- <Fragment innerHTML={str} />
64
- </>;
56
+ function App() @{
57
+ let str = '<div>Test</div>';
58
+ <Fragment innerHTML={str} />
65
59
  }
66
60
 
67
61
  render(App);
@@ -69,18 +63,16 @@ describe('Fragment innerHTML', () => {
69
63
  });
70
64
 
71
65
  it('renders dynamic innerHTML fragments', () => {
72
- function App() {
73
- return <>
74
- let &[str] = track('<div>Test</div>');
66
+ function App() @{
67
+ let &[str] = track('<div>Test</div>');
68
+ <>
75
69
  <Fragment innerHTML={str} />
76
70
  <button
77
71
  onClick={() => {
78
72
  str = '<div>Updated</div>';
79
73
  }}
80
- >
81
- {'Update'}
82
- </button>
83
- </>;
74
+ >{'Update'}</button>
75
+ </>
84
76
  }
85
77
 
86
78
  render(App);
@@ -94,11 +86,9 @@ describe('Fragment innerHTML', () => {
94
86
  });
95
87
 
96
88
  it('renders static Fragment innerHTML', () => {
97
- function App() {
98
- return <>
99
- const html = '<strong>Fragment HTML</strong>';
100
- <Fragment innerHTML={html} />
101
- </>;
89
+ function App() @{
90
+ const html = '<strong>Fragment HTML</strong>';
91
+ <Fragment innerHTML={html} />
102
92
  }
103
93
 
104
94
  render(App);
@@ -108,12 +98,12 @@ describe('Fragment innerHTML', () => {
108
98
  });
109
99
 
110
100
  it('updates dynamic Fragment innerHTML', () => {
111
- function App() {
112
- return <>
113
- let &[html] = track('<span>First</span>');
101
+ function App() @{
102
+ let &[html] = track('<span>First</span>');
103
+ <>
114
104
  <Fragment innerHTML={html} />
115
105
  <button onClick={() => (html = '<em>Second</em>')}>{'Update'}</button>
116
- </>;
106
+ </>
117
107
  }
118
108
 
119
109
  render(App);
@@ -130,13 +120,11 @@ describe('Fragment innerHTML', () => {
130
120
  });
131
121
 
132
122
  it('renders the correct namespace for child svg element when html is surrounded by <svg>', () => {
133
- function App() {
134
- return <>
135
- let str = '<circle r="45" cx="50" cy="50" fill="red" />';
136
- <svg height="100" width="100">
137
- <Fragment innerHTML={str} />
138
- </svg>
139
- </>;
123
+ function App() @{
124
+ let str = '<circle r="45" cx="50" cy="50" fill="red" />';
125
+ <svg height="100" width="100">
126
+ <Fragment innerHTML={str} />
127
+ </svg>
140
128
  }
141
129
 
142
130
  render(App);
@@ -148,11 +136,11 @@ describe('Fragment innerHTML', () => {
148
136
  it(
149
137
  'renders the correct namespace for child math element when html is surrounded by <math>',
150
138
  () => {
151
- function App() {
152
- return <>
153
- let str = '<mi>x</mi><mo>+</mo><mi>y</mi>';
154
- <math><Fragment innerHTML={str} /></math>
155
- </>;
139
+ function App() @{
140
+ let str = '<mi>x</mi><mo>+</mo><mi>y</mi>';
141
+ <math>
142
+ <Fragment innerHTML={str} />
143
+ </math>
156
144
  }
157
145
 
158
146
  render(App);