ripple 0.2.208 → 0.2.211

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 (112) hide show
  1. package/CHANGELOG.md +57 -0
  2. package/README.md +2 -1
  3. package/package.json +2 -6
  4. package/shims/rollup-estree-types.d.ts +1 -1
  5. package/src/compiler/index.d.ts +1 -0
  6. package/src/compiler/index.js +7 -1
  7. package/src/compiler/phases/1-parse/index.js +24 -7
  8. package/src/compiler/phases/2-analyze/css-analyze.js +100 -104
  9. package/src/compiler/phases/2-analyze/index.js +215 -2
  10. package/src/compiler/phases/3-transform/client/index.js +388 -50
  11. package/src/compiler/phases/3-transform/segments.js +123 -39
  12. package/src/compiler/phases/3-transform/server/index.js +266 -13
  13. package/src/compiler/types/index.d.ts +15 -3
  14. package/src/compiler/utils.js +1 -15
  15. package/src/constants.js +0 -2
  16. package/src/helpers.d.ts +4 -0
  17. package/src/html-tree-validation.js +211 -0
  18. package/src/jsx-runtime.d.ts +260 -259
  19. package/src/jsx-runtime.js +12 -12
  20. package/src/runtime/array.js +17 -17
  21. package/src/runtime/create-subscriber.js +1 -1
  22. package/src/runtime/index-client.js +1 -5
  23. package/src/runtime/index-server.js +15 -0
  24. package/src/runtime/internal/client/compat.js +3 -3
  25. package/src/runtime/internal/client/composite.js +6 -1
  26. package/src/runtime/internal/client/head.js +50 -4
  27. package/src/runtime/internal/client/html.js +73 -12
  28. package/src/runtime/internal/client/hydration.js +12 -0
  29. package/src/runtime/internal/client/index.js +1 -1
  30. package/src/runtime/internal/client/portal.js +54 -29
  31. package/src/runtime/internal/client/rpc.js +3 -1
  32. package/src/runtime/internal/client/switch.js +5 -0
  33. package/src/runtime/internal/client/template.js +119 -12
  34. package/src/runtime/internal/client/try.js +1 -0
  35. package/src/runtime/internal/server/index.js +113 -1
  36. package/src/runtime/internal/server/rpc.js +4 -4
  37. package/src/runtime/map.js +2 -2
  38. package/src/runtime/object.js +6 -6
  39. package/src/runtime/proxy.js +12 -11
  40. package/src/runtime/reactive-value.js +9 -1
  41. package/src/runtime/set.js +12 -7
  42. package/src/runtime/url-search-params.js +0 -1
  43. package/src/server/index.js +4 -0
  44. package/src/utils/hashing.js +15 -0
  45. package/src/utils/normalize_css_property_name.js +1 -1
  46. package/tests/client/array/array.mutations.test.ripple +8 -8
  47. package/tests/client/basic/basic.errors.test.ripple +28 -0
  48. package/tests/client/basic/basic.events.test.ripple +6 -3
  49. package/tests/client/basic/basic.utilities.test.ripple +1 -1
  50. package/tests/client/compiler/compiler.regex.test.ripple +10 -8
  51. package/tests/client/composite/composite.generics.test.ripple +5 -2
  52. package/tests/client/dynamic-elements.test.ripple +30 -1
  53. package/tests/client/function-overload-import.ripple +6 -7
  54. package/tests/client/html.test.ripple +0 -1
  55. package/tests/client/object.test.ripple +2 -2
  56. package/tests/client/portal.test.ripple +3 -3
  57. package/tests/client/return.test.ripple +2500 -0
  58. package/tests/client/try.test.ripple +69 -0
  59. package/tests/client/typescript-generics.test.ripple +1 -1
  60. package/tests/client/url/url.derived.test.ripple +1 -1
  61. package/tests/client/url/url.parsing.test.ripple +3 -3
  62. package/tests/client/url/url.partial-removal.test.ripple +7 -7
  63. package/tests/client/url/url.reactivity.test.ripple +15 -15
  64. package/tests/client/url/url.serialization.test.ripple +2 -2
  65. package/tests/hydration/basic.test.js +23 -0
  66. package/tests/hydration/build-components.js +10 -4
  67. package/tests/hydration/compiled/client/basic.js +165 -3
  68. package/tests/hydration/compiled/client/composite.js +139 -0
  69. package/tests/hydration/compiled/client/for.js +1140 -23
  70. package/tests/hydration/compiled/client/head.js +234 -0
  71. package/tests/hydration/compiled/client/html.js +135 -0
  72. package/tests/hydration/compiled/client/portal.js +172 -0
  73. package/tests/hydration/compiled/client/reactivity.js +3 -1
  74. package/tests/hydration/compiled/client/return.js +1976 -0
  75. package/tests/hydration/compiled/client/switch.js +162 -0
  76. package/tests/hydration/compiled/server/basic.js +249 -0
  77. package/tests/hydration/compiled/server/composite.js +176 -0
  78. package/tests/hydration/compiled/server/events.js +1 -1
  79. package/tests/hydration/compiled/server/for.js +891 -1
  80. package/tests/hydration/compiled/server/head.js +291 -0
  81. package/tests/hydration/compiled/server/html.js +133 -0
  82. package/tests/hydration/compiled/server/if.js +1 -1
  83. package/tests/hydration/compiled/server/portal.js +250 -0
  84. package/tests/hydration/compiled/server/reactivity.js +1 -1
  85. package/tests/hydration/compiled/server/return.js +1969 -0
  86. package/tests/hydration/compiled/server/switch.js +130 -0
  87. package/tests/hydration/components/basic.ripple +55 -0
  88. package/tests/hydration/components/composite.ripple +37 -0
  89. package/tests/hydration/components/for.ripple +403 -0
  90. package/tests/hydration/components/head.ripple +111 -0
  91. package/tests/hydration/components/html.ripple +38 -0
  92. package/tests/hydration/components/portal.ripple +49 -0
  93. package/tests/hydration/components/return.ripple +564 -0
  94. package/tests/hydration/components/switch.ripple +51 -0
  95. package/tests/hydration/composite.test.js +42 -0
  96. package/tests/hydration/for.test.js +363 -0
  97. package/tests/hydration/head.test.js +105 -0
  98. package/tests/hydration/html.test.js +46 -0
  99. package/tests/hydration/portal.test.js +71 -0
  100. package/tests/hydration/return.test.js +544 -0
  101. package/tests/hydration/switch.test.js +42 -0
  102. package/tests/server/basic.attributes.test.ripple +1 -1
  103. package/tests/server/compiler.test.ripple +22 -0
  104. package/tests/server/composite.test.ripple +5 -2
  105. package/tests/server/html-nesting-validation.test.ripple +237 -0
  106. package/tests/server/return.test.ripple +1379 -0
  107. package/tests/setup-hydration.js +6 -1
  108. package/tests/utils/escaping.test.js +3 -1
  109. package/tests/utils/normalize_css_property_name.test.js +0 -1
  110. package/tests/utils/patterns.test.js +6 -2
  111. package/tests/utils/sanitize_template_string.test.js +3 -2
  112. package/types/server.d.ts +16 -0
@@ -0,0 +1,139 @@
1
+ import * as _$_ from 'ripple/internal/client';
2
+
3
+ var root = _$_.template(`<div class="layout"><!></div>`, 0);
4
+ var root_1 = _$_.template(`<div class="single">single</div>`, 0);
5
+ var root_2 = _$_.template(`<h1>title</h1><p>description</p>`, 1);
6
+ var root_3 = _$_.template(`<!>`, 1);
7
+ var root_5 = _$_.template(`<!>`, 1);
8
+ var root_4 = _$_.template(`<!>`, 1);
9
+ var root_7 = _$_.template(`<!><div class="extra">extra</div>`, 1);
10
+ var root_6 = _$_.template(`<!>`, 1);
11
+ var root_9 = _$_.template(`<!>`, 1);
12
+ var root_8 = _$_.template(`<!>`, 1);
13
+
14
+ export function Layout(__anchor, __props, __block) {
15
+ _$_.push_component();
16
+
17
+ var div_1 = root();
18
+
19
+ {
20
+ var node = _$_.child(div_1);
21
+
22
+ _$_.composite(() => __props.children, node, {});
23
+ _$_.pop(div_1);
24
+ }
25
+
26
+ _$_.append(__anchor, div_1);
27
+ _$_.pop_component();
28
+ }
29
+
30
+ export function SingleChild(__anchor, _, __block) {
31
+ _$_.push_component();
32
+
33
+ var div_2 = root_1();
34
+
35
+ _$_.append(__anchor, div_2);
36
+ _$_.pop_component();
37
+ }
38
+
39
+ export function MultiRootChild(__anchor, _, __block) {
40
+ _$_.push_component();
41
+
42
+ var fragment = root_2();
43
+
44
+ _$_.next();
45
+ _$_.append(__anchor, fragment, true);
46
+ _$_.pop_component();
47
+ }
48
+
49
+ export function EmptyLayout(__anchor, _, __block) {
50
+ _$_.push_component();
51
+
52
+ var fragment_1 = root_3();
53
+ var node_1 = _$_.first_child_frag(fragment_1);
54
+
55
+ Layout(node_1, {}, _$_.active_block);
56
+ _$_.append(__anchor, fragment_1);
57
+ _$_.pop_component();
58
+ }
59
+
60
+ export function LayoutWithSingleChild(__anchor, _, __block) {
61
+ _$_.push_component();
62
+
63
+ var fragment_2 = root_4();
64
+ var node_2 = _$_.first_child_frag(fragment_2);
65
+
66
+ Layout(
67
+ node_2,
68
+ {
69
+ children(__anchor, _, __block) {
70
+ _$_.push_component();
71
+
72
+ var fragment_3 = root_5();
73
+ var node_3 = _$_.first_child_frag(fragment_3);
74
+
75
+ SingleChild(node_3, {}, _$_.active_block);
76
+ _$_.append(__anchor, fragment_3);
77
+ _$_.pop_component();
78
+ }
79
+ },
80
+ _$_.active_block
81
+ );
82
+
83
+ _$_.append(__anchor, fragment_2);
84
+ _$_.pop_component();
85
+ }
86
+
87
+ export function LayoutWithMultipleChildren(__anchor, _, __block) {
88
+ _$_.push_component();
89
+
90
+ var fragment_4 = root_6();
91
+ var node_4 = _$_.first_child_frag(fragment_4);
92
+
93
+ Layout(
94
+ node_4,
95
+ {
96
+ children(__anchor, _, __block) {
97
+ _$_.push_component();
98
+
99
+ var fragment_5 = root_7();
100
+ var node_5 = _$_.first_child_frag(fragment_5);
101
+
102
+ SingleChild(node_5, {}, _$_.active_block);
103
+ _$_.append(__anchor, fragment_5);
104
+ _$_.pop_component();
105
+ }
106
+ },
107
+ _$_.active_block
108
+ );
109
+
110
+ _$_.append(__anchor, fragment_4);
111
+ _$_.pop_component();
112
+ }
113
+
114
+ export function LayoutWithMultiRootChild(__anchor, _, __block) {
115
+ _$_.push_component();
116
+
117
+ var fragment_6 = root_8();
118
+ var node_6 = _$_.first_child_frag(fragment_6);
119
+
120
+ Layout(
121
+ node_6,
122
+ {
123
+ children(__anchor, _, __block) {
124
+ _$_.push_component();
125
+
126
+ var fragment_7 = root_9();
127
+ var node_7 = _$_.first_child_frag(fragment_7);
128
+
129
+ MultiRootChild(node_7, {}, _$_.active_block);
130
+ _$_.append(__anchor, fragment_7);
131
+ _$_.pop_component();
132
+ }
133
+ },
134
+ _$_.active_block
135
+ );
136
+
137
+ _$_.append(__anchor, fragment_6);
138
+ _$_.pop_component();
139
+ }