lego-dom 0.0.8 → 1.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 (175) hide show
  1. package/CHANGELOG.md +44 -0
  2. package/README.md +49 -432
  3. package/cdn.html +124 -0
  4. package/docs/.vitepress/config.js +43 -5
  5. package/docs/api/directives.md +3 -3
  6. package/docs/api/globals.md +1 -1
  7. package/docs/api/index.md +3 -3
  8. package/docs/api/vite-plugin.md +1 -1
  9. package/docs/contributing/01-welcome.md +36 -0
  10. package/docs/contributing/02-registry.md +99 -0
  11. package/docs/contributing/03-batcher.md +110 -0
  12. package/docs/contributing/04-reactivity.md +87 -0
  13. package/docs/contributing/05-caching.md +59 -0
  14. package/docs/contributing/06-init.md +125 -0
  15. package/docs/contributing/07-observer.md +69 -0
  16. package/docs/contributing/08-snap.md +126 -0
  17. package/docs/contributing/09-diffing.md +69 -0
  18. package/docs/contributing/10-studs.md +76 -0
  19. package/docs/contributing/11-scanner.md +104 -0
  20. package/docs/contributing/12-render.md +116 -0
  21. package/docs/contributing/13-directives.md +225 -0
  22. package/docs/contributing/14-events.md +57 -0
  23. package/docs/contributing/15-router.md +9 -0
  24. package/docs/contributing/16-state.md +48 -0
  25. package/docs/contributing/17-legodom.md +55 -0
  26. package/docs/contributing/index.md +5 -0
  27. package/docs/examples/form.md +2 -2
  28. package/docs/examples/index.md +4 -4
  29. package/docs/examples/routing.md +8 -8
  30. package/docs/examples/sfc-showcase.md +4 -4
  31. package/docs/examples/todo-app.md +3 -3
  32. package/docs/guide/cdn-usage.md +16 -8
  33. package/docs/guide/components.md +34 -16
  34. package/docs/guide/contributing.md +2 -2
  35. package/docs/guide/directives.md +23 -23
  36. package/docs/guide/getting-started.md +41 -16
  37. package/docs/guide/index.md +12 -12
  38. package/docs/guide/lifecycle.md +1 -1
  39. package/docs/guide/quick-start.md +8 -5
  40. package/docs/guide/reactivity.md +30 -9
  41. package/docs/guide/routing.md +189 -289
  42. package/docs/guide/sfc.md +40 -40
  43. package/docs/guide/templating.md +4 -4
  44. package/docs/index.md +48 -14
  45. package/docs/public/logo.svg +17 -38
  46. package/docs/router/basic-routing.md +103 -0
  47. package/docs/router/cold-entry.md +91 -0
  48. package/docs/router/history.md +69 -0
  49. package/docs/router/index.md +73 -0
  50. package/docs/router/resolver.md +74 -0
  51. package/docs/router/surgical-swaps.md +134 -0
  52. package/examples/vite-app/README.md +2 -2
  53. package/examples/vite-app/index.html +9 -13
  54. package/examples/vite-app/package.json +4 -2
  55. package/examples/vite-app/src/app.css +3 -0
  56. package/examples/vite-app/src/app.js +29 -0
  57. package/examples/vite-app/src/components/app-navbar.lego +34 -0
  58. package/examples/vite-app/src/components/customers/customer-details.lego +24 -0
  59. package/examples/vite-app/src/components/customers/customer-orders.lego +21 -0
  60. package/examples/vite-app/src/components/customers/order-list.lego +55 -0
  61. package/examples/vite-app/src/components/greeting-card.lego +26 -26
  62. package/examples/vite-app/src/components/sample-component.lego +58 -58
  63. package/examples/vite-app/src/components/shells/customers-shell.lego +21 -0
  64. package/examples/vite-app/src/components/todo-list.lego +239 -0
  65. package/examples/vite-app/src/components/widgets/user-card.lego +27 -0
  66. package/examples/vite-app/vite.config.js +7 -2
  67. package/lego.js +2 -0
  68. package/main.js +280 -83
  69. package/package.json +8 -3
  70. package/parse-lego.js +17 -8
  71. package/parse-lego.test.js +1 -1
  72. package/{main.test.js → tests/main.test.js} +34 -17
  73. package/tests/parse-lego.test.js +65 -0
  74. package/vite-plugin.js +62 -24
  75. package/docs/.vitepress/dist/404.html +0 -22
  76. package/docs/.vitepress/dist/api/define.html +0 -35
  77. package/docs/.vitepress/dist/api/directives.html +0 -32
  78. package/docs/.vitepress/dist/api/globals.html +0 -27
  79. package/docs/.vitepress/dist/api/index.html +0 -25
  80. package/docs/.vitepress/dist/api/lifecycle.html +0 -38
  81. package/docs/.vitepress/dist/api/route.html +0 -34
  82. package/docs/.vitepress/dist/api/vite-plugin.html +0 -37
  83. package/docs/.vitepress/dist/assets/api_define.md.UA-ygUnQ.js +0 -11
  84. package/docs/.vitepress/dist/assets/api_define.md.UA-ygUnQ.lean.js +0 -1
  85. package/docs/.vitepress/dist/assets/api_directives.md.BV-D251p.js +0 -8
  86. package/docs/.vitepress/dist/assets/api_directives.md.BV-D251p.lean.js +0 -1
  87. package/docs/.vitepress/dist/assets/api_globals.md.DOjt7AV0.js +0 -3
  88. package/docs/.vitepress/dist/assets/api_globals.md.DOjt7AV0.lean.js +0 -1
  89. package/docs/.vitepress/dist/assets/api_index.md.OS6h01ct.js +0 -1
  90. package/docs/.vitepress/dist/assets/api_index.md.OS6h01ct.lean.js +0 -1
  91. package/docs/.vitepress/dist/assets/api_lifecycle.md.Ccm5xw6-.js +0 -14
  92. package/docs/.vitepress/dist/assets/api_lifecycle.md.Ccm5xw6-.lean.js +0 -1
  93. package/docs/.vitepress/dist/assets/api_route.md.CAHf_KNp.js +0 -10
  94. package/docs/.vitepress/dist/assets/api_route.md.CAHf_KNp.lean.js +0 -1
  95. package/docs/.vitepress/dist/assets/api_vite-plugin.md.DNn9VhL5.js +0 -13
  96. package/docs/.vitepress/dist/assets/api_vite-plugin.md.DNn9VhL5.lean.js +0 -1
  97. package/docs/.vitepress/dist/assets/app.BG5s3B0P.js +0 -1
  98. package/docs/.vitepress/dist/assets/chunks/@localSearchIndexroot.DQmuWC2Z.js +0 -1
  99. package/docs/.vitepress/dist/assets/chunks/VPLocalSearchBox.BO-PSxt1.js +0 -9
  100. package/docs/.vitepress/dist/assets/chunks/framework.B7OFBR9X.js +0 -19
  101. package/docs/.vitepress/dist/assets/chunks/theme.DA-iSa9B.js +0 -2
  102. package/docs/.vitepress/dist/assets/examples_form.md.B3stGKbu.js +0 -34
  103. package/docs/.vitepress/dist/assets/examples_form.md.B3stGKbu.lean.js +0 -1
  104. package/docs/.vitepress/dist/assets/examples_index.md.BDEG_D4J.js +0 -30
  105. package/docs/.vitepress/dist/assets/examples_index.md.BDEG_D4J.lean.js +0 -1
  106. package/docs/.vitepress/dist/assets/examples_routing.md.bqZ9DjDK.js +0 -338
  107. package/docs/.vitepress/dist/assets/examples_routing.md.bqZ9DjDK.lean.js +0 -1
  108. package/docs/.vitepress/dist/assets/examples_sfc-showcase.md.DLXaUiop.js +0 -13
  109. package/docs/.vitepress/dist/assets/examples_sfc-showcase.md.DLXaUiop.lean.js +0 -1
  110. package/docs/.vitepress/dist/assets/examples_todo-app.md.D5RhZoo5.js +0 -297
  111. package/docs/.vitepress/dist/assets/examples_todo-app.md.D5RhZoo5.lean.js +0 -1
  112. package/docs/.vitepress/dist/assets/guide_cdn-usage.md.CAjf03Lr.js +0 -182
  113. package/docs/.vitepress/dist/assets/guide_cdn-usage.md.CAjf03Lr.lean.js +0 -1
  114. package/docs/.vitepress/dist/assets/guide_components.md.BIFWF1Hc.js +0 -174
  115. package/docs/.vitepress/dist/assets/guide_components.md.BIFWF1Hc.lean.js +0 -1
  116. package/docs/.vitepress/dist/assets/guide_contributing.md.BgbUN-Mr.js +0 -1
  117. package/docs/.vitepress/dist/assets/guide_contributing.md.BgbUN-Mr.lean.js +0 -1
  118. package/docs/.vitepress/dist/assets/guide_directives.md.Bi3ynu1d.js +0 -140
  119. package/docs/.vitepress/dist/assets/guide_directives.md.Bi3ynu1d.lean.js +0 -1
  120. package/docs/.vitepress/dist/assets/guide_getting-started.md.2Nr1lp2z.js +0 -107
  121. package/docs/.vitepress/dist/assets/guide_getting-started.md.2Nr1lp2z.lean.js +0 -1
  122. package/docs/.vitepress/dist/assets/guide_index.md.GvZq_Yf2.js +0 -2
  123. package/docs/.vitepress/dist/assets/guide_index.md.GvZq_Yf2.lean.js +0 -1
  124. package/docs/.vitepress/dist/assets/guide_lifecycle.md.B28j1OzS.js +0 -304
  125. package/docs/.vitepress/dist/assets/guide_lifecycle.md.B28j1OzS.lean.js +0 -1
  126. package/docs/.vitepress/dist/assets/guide_quick-start.md.CNk3VGTF.js +0 -33
  127. package/docs/.vitepress/dist/assets/guide_quick-start.md.CNk3VGTF.lean.js +0 -1
  128. package/docs/.vitepress/dist/assets/guide_reactivity.md.CVsaMaPv.js +0 -135
  129. package/docs/.vitepress/dist/assets/guide_reactivity.md.CVsaMaPv.lean.js +0 -1
  130. package/docs/.vitepress/dist/assets/guide_routing.md.DSpDP25o.js +0 -193
  131. package/docs/.vitepress/dist/assets/guide_routing.md.DSpDP25o.lean.js +0 -1
  132. package/docs/.vitepress/dist/assets/guide_sfc.md.CVUP66tS.js +0 -187
  133. package/docs/.vitepress/dist/assets/guide_sfc.md.CVUP66tS.lean.js +0 -1
  134. package/docs/.vitepress/dist/assets/guide_templating.md.BgCGe4aa.js +0 -119
  135. package/docs/.vitepress/dist/assets/guide_templating.md.BgCGe4aa.lean.js +0 -1
  136. package/docs/.vitepress/dist/assets/index.md.xV1taCED.js +0 -23
  137. package/docs/.vitepress/dist/assets/index.md.xV1taCED.lean.js +0 -1
  138. package/docs/.vitepress/dist/assets/inter-italic-cyrillic-ext.r48I6akx.woff2 +0 -0
  139. package/docs/.vitepress/dist/assets/inter-italic-cyrillic.By2_1cv3.woff2 +0 -0
  140. package/docs/.vitepress/dist/assets/inter-italic-greek-ext.1u6EdAuj.woff2 +0 -0
  141. package/docs/.vitepress/dist/assets/inter-italic-greek.DJ8dCoTZ.woff2 +0 -0
  142. package/docs/.vitepress/dist/assets/inter-italic-latin-ext.CN1xVJS-.woff2 +0 -0
  143. package/docs/.vitepress/dist/assets/inter-italic-latin.C2AdPX0b.woff2 +0 -0
  144. package/docs/.vitepress/dist/assets/inter-italic-vietnamese.BSbpV94h.woff2 +0 -0
  145. package/docs/.vitepress/dist/assets/inter-roman-cyrillic-ext.BBPuwvHQ.woff2 +0 -0
  146. package/docs/.vitepress/dist/assets/inter-roman-cyrillic.C5lxZ8CY.woff2 +0 -0
  147. package/docs/.vitepress/dist/assets/inter-roman-greek-ext.CqjqNYQ-.woff2 +0 -0
  148. package/docs/.vitepress/dist/assets/inter-roman-greek.BBVDIX6e.woff2 +0 -0
  149. package/docs/.vitepress/dist/assets/inter-roman-latin-ext.4ZJIpNVo.woff2 +0 -0
  150. package/docs/.vitepress/dist/assets/inter-roman-latin.Di8DUHzh.woff2 +0 -0
  151. package/docs/.vitepress/dist/assets/inter-roman-vietnamese.BjW4sHH5.woff2 +0 -0
  152. package/docs/.vitepress/dist/assets/style.eycE2Jhw.css +0 -1
  153. package/docs/.vitepress/dist/examples/form.html +0 -58
  154. package/docs/.vitepress/dist/examples/index.html +0 -368
  155. package/docs/.vitepress/dist/examples/routing.html +0 -362
  156. package/docs/.vitepress/dist/examples/sfc-showcase.html +0 -37
  157. package/docs/.vitepress/dist/examples/todo-app.html +0 -321
  158. package/docs/.vitepress/dist/guide/cdn-usage.html +0 -206
  159. package/docs/.vitepress/dist/guide/components.html +0 -198
  160. package/docs/.vitepress/dist/guide/contributing.html +0 -25
  161. package/docs/.vitepress/dist/guide/directives.html +0 -164
  162. package/docs/.vitepress/dist/guide/getting-started.html +0 -131
  163. package/docs/.vitepress/dist/guide/index.html +0 -26
  164. package/docs/.vitepress/dist/guide/lifecycle.html +0 -328
  165. package/docs/.vitepress/dist/guide/quick-start.html +0 -57
  166. package/docs/.vitepress/dist/guide/reactivity.html +0 -159
  167. package/docs/.vitepress/dist/guide/routing.html +0 -217
  168. package/docs/.vitepress/dist/guide/sfc.html +0 -211
  169. package/docs/.vitepress/dist/guide/templating.html +0 -143
  170. package/docs/.vitepress/dist/hashmap.json +0 -1
  171. package/docs/.vitepress/dist/index.html +0 -47
  172. package/docs/.vitepress/dist/logo.svg +0 -38
  173. package/docs/.vitepress/dist/vp-icons.css +0 -1
  174. package/examples/vite-app/src/main.js +0 -11
  175. package/examples.js +0 -99
@@ -0,0 +1,239 @@
1
+ <style>
2
+ self {
3
+ display: block;
4
+ background: white;
5
+ border-radius: 8px;
6
+ padding: 1.5rem;
7
+ box-shadow: 0 2px 8px rgba(0,0,0,0.1);
8
+ }
9
+
10
+ .input-group {
11
+ display: flex;
12
+ gap: 0.5rem;
13
+ margin-bottom: 1.5rem;
14
+ }
15
+
16
+ input[type="text"] {
17
+ flex: 1;
18
+ padding: 0.75rem;
19
+ font-size: 1rem;
20
+ border: 2px solid #e0e0e0;
21
+ border-radius: 4px;
22
+ }
23
+
24
+ input[type="text"]:focus {
25
+ outline: none;
26
+ border-color: #4CAF50;
27
+ }
28
+
29
+ .btn {
30
+ padding: 0.75rem 1.5rem;
31
+ font-size: 1rem;
32
+ border: none;
33
+ border-radius: 4px;
34
+ cursor: pointer;
35
+ font-weight: 600;
36
+ transition: background 0.2s;
37
+ }
38
+
39
+ .btn-primary {
40
+ background: #4CAF50;
41
+ color: white;
42
+ }
43
+
44
+ .btn-primary:hover {
45
+ background: #45a049;
46
+ }
47
+
48
+ .filters {
49
+ display: flex;
50
+ gap: 0.5rem;
51
+ margin-bottom: 1rem;
52
+ }
53
+
54
+ .filter-btn {
55
+ padding: 0.5rem 1rem;
56
+ background: #f0f0f0;
57
+ border: none;
58
+ border-radius: 4px;
59
+ cursor: pointer;
60
+ }
61
+
62
+ .filter-btn.active {
63
+ background: #4CAF50;
64
+ color: white;
65
+ }
66
+
67
+ ul {
68
+ list-style: none;
69
+ padding: 0;
70
+ margin: 0;
71
+ }
72
+
73
+ li {
74
+ display: flex;
75
+ align-items: center;
76
+ gap: 0.75rem;
77
+ padding: 0.75rem;
78
+ border-bottom: 1px solid #f0f0f0;
79
+ transition: background 0.2s;
80
+ }
81
+
82
+ li:hover {
83
+ background: #f9f9f9;
84
+ }
85
+
86
+ input[type="checkbox"] {
87
+ width: 20px;
88
+ height: 20px;
89
+ cursor: pointer;
90
+ }
91
+
92
+ .todo-text {
93
+ flex: 1;
94
+ font-size: 1rem;
95
+ }
96
+
97
+ .todo-text.done {
98
+ text-decoration: line-through;
99
+ color: #999;
100
+ }
101
+
102
+ .delete-btn {
103
+ padding: 0.25rem 0.5rem;
104
+ background: #f44336;
105
+ color: white;
106
+ border: none;
107
+ border-radius: 4px;
108
+ cursor: pointer;
109
+ font-size: 0.875rem;
110
+ }
111
+
112
+ .delete-btn:hover {
113
+ background: #da190b;
114
+ }
115
+
116
+ .stats {
117
+ margin-top: 1rem;
118
+ padding-top: 1rem;
119
+ border-top: 2px solid #f0f0f0;
120
+ display: flex;
121
+ justify-content: space-between;
122
+ color: #666;
123
+ font-size: 0.875rem;
124
+ }
125
+
126
+ .clear-completed {
127
+ background: none;
128
+ border: none;
129
+ color: #f44336;
130
+ cursor: pointer;
131
+ text-decoration: underline;
132
+ }
133
+ </style>
134
+
135
+ <template>
136
+ <h1>📝 Todo App</h1>
137
+
138
+ <div class="input-group">
139
+ <input
140
+ type="text"
141
+ b-sync="newTodo"
142
+ placeholder="What needs to be done?"
143
+ @keyup="event.key === 'Enter' && addTodo()">
144
+ <button class="btn btn-primary" @click="addTodo()">Add</button>
145
+ </div>
146
+
147
+ <div class="filters">
148
+ <button
149
+ class="filter-btn {{ filter === 'all' ? 'active' : '' }}"
150
+ @click="filter = 'all'">
151
+ All
152
+ </button>
153
+ <button
154
+ class="filter-btn {{ filter === 'active' ? 'active' : '' }}"
155
+ @click="filter = 'active'">
156
+ Active
157
+ </button>
158
+ <button
159
+ class="filter-btn {{ filter === 'completed' ? 'active' : '' }}"
160
+ @click="filter = 'completed'">
161
+ Completed
162
+ </button>
163
+ </div>
164
+
165
+ <ul b-for="todo in filteredTodos()">
166
+ <li>
167
+ <input type="checkbox" b-sync="todo.done">
168
+ <span class="todo-text {{ todo.done ? 'done' : '' }}">
169
+ {{ todo.text }}
170
+ </span>
171
+ <button class="delete-btn" @click="deleteTodo(todo)">Delete</button>
172
+ </li>
173
+ </ul>
174
+
175
+ <div class="stats">
176
+ <span>{{ remaining() }} item{{ remaining() === 1 ? '' : 's' }} left</span>
177
+ <button
178
+ class="clear-completed"
179
+ b-show="completedCount() > 0"
180
+ @click="clearCompleted()">
181
+ Clear completed ({{ completedCount() }})
182
+ </button>
183
+ </div>
184
+ </template>
185
+
186
+ <script>
187
+ export default {
188
+ newTodo: '',
189
+ filter: 'all',
190
+ todos: [],
191
+
192
+ mounted() {
193
+ const saved = localStorage.getItem('legojs-todos');
194
+ if (saved) {
195
+ this.todos = JSON.parse(saved);
196
+ }
197
+ },
198
+
199
+ updated() {
200
+ localStorage.setItem('legojs-todos', JSON.stringify(this.todos));
201
+ },
202
+
203
+ addTodo() {
204
+ if (this.newTodo.trim()) {
205
+ this.todos.push({
206
+ id: Date.now(),
207
+ text: this.newTodo,
208
+ done: false
209
+ });
210
+ this.newTodo = '';
211
+ }
212
+ },
213
+
214
+ deleteTodo(todo) {
215
+ this.todos = this.todos.filter(t => t.id !== todo.id);
216
+ },
217
+
218
+ filteredTodos() {
219
+ if (this.filter === 'active') {
220
+ return this.todos.filter(t => !t.done);
221
+ } else if (this.filter === 'completed') {
222
+ return this.todos.filter(t => t.done);
223
+ }
224
+ return this.todos;
225
+ },
226
+
227
+ remaining() {
228
+ return this.todos.filter(t => !t.done).length;
229
+ },
230
+
231
+ completedCount() {
232
+ return this.todos.filter(t => t.done).length;
233
+ },
234
+
235
+ clearCompleted() {
236
+ this.todos = this.todos.filter(t => !t.done);
237
+ }
238
+ }
239
+ </script>
@@ -0,0 +1,27 @@
1
+ <style>
2
+ self {
3
+ display: block;
4
+ padding: 1rem;
5
+ background: #f9fafb;
6
+ border-bottom: 1px solid #e0e0e0;
7
+ }
8
+ </style>
9
+
10
+
11
+ <template>
12
+ <div>
13
+ <h2>User Card</h2>
14
+ <p>Name: {{ name }}</p>
15
+ <p>Age: {{ age }}</p>
16
+ </div>
17
+ </template>
18
+
19
+ <script>
20
+ export default {
21
+ name: 'UserCard',
22
+ props: {
23
+ name: String,
24
+ age: Number
25
+ }
26
+ }
27
+ </script>
@@ -1,16 +1,21 @@
1
1
  import { defineConfig } from 'vite';
2
+ import path from 'path';
3
+
2
4
  import legoPlugin from 'lego-dom/vite-plugin';
5
+ import tailwindcss from '@tailwindcss/vite';
6
+
3
7
 
4
8
  export default defineConfig({
5
9
  plugins: [
6
10
  legoPlugin({
7
11
  componentsDir: './src/components',
8
12
  include: ['**/*.lego']
9
- })
13
+ }),
14
+ tailwindcss()
10
15
  ],
11
16
  resolve: {
12
17
  alias: {
13
- 'lego-dom/main.js': new URL('../../main.js', import.meta.url).pathname
18
+ 'lego-dom/main.js': path.resolve(__dirname, '../../lego.js')
14
19
  }
15
20
  }
16
21
  });
package/lego.js ADDED
@@ -0,0 +1,2 @@
1
+ import './main.js';
2
+ export const Lego = window.Lego;