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.
- package/CHANGELOG.md +44 -0
- package/README.md +49 -432
- package/cdn.html +124 -0
- package/docs/.vitepress/config.js +43 -5
- package/docs/api/directives.md +3 -3
- package/docs/api/globals.md +1 -1
- package/docs/api/index.md +3 -3
- package/docs/api/vite-plugin.md +1 -1
- package/docs/contributing/01-welcome.md +36 -0
- package/docs/contributing/02-registry.md +99 -0
- package/docs/contributing/03-batcher.md +110 -0
- package/docs/contributing/04-reactivity.md +87 -0
- package/docs/contributing/05-caching.md +59 -0
- package/docs/contributing/06-init.md +125 -0
- package/docs/contributing/07-observer.md +69 -0
- package/docs/contributing/08-snap.md +126 -0
- package/docs/contributing/09-diffing.md +69 -0
- package/docs/contributing/10-studs.md +76 -0
- package/docs/contributing/11-scanner.md +104 -0
- package/docs/contributing/12-render.md +116 -0
- package/docs/contributing/13-directives.md +225 -0
- package/docs/contributing/14-events.md +57 -0
- package/docs/contributing/15-router.md +9 -0
- package/docs/contributing/16-state.md +48 -0
- package/docs/contributing/17-legodom.md +55 -0
- package/docs/contributing/index.md +5 -0
- package/docs/examples/form.md +2 -2
- package/docs/examples/index.md +4 -4
- package/docs/examples/routing.md +8 -8
- package/docs/examples/sfc-showcase.md +4 -4
- package/docs/examples/todo-app.md +3 -3
- package/docs/guide/cdn-usage.md +16 -8
- package/docs/guide/components.md +34 -16
- package/docs/guide/contributing.md +2 -2
- package/docs/guide/directives.md +23 -23
- package/docs/guide/getting-started.md +41 -16
- package/docs/guide/index.md +12 -12
- package/docs/guide/lifecycle.md +1 -1
- package/docs/guide/quick-start.md +8 -5
- package/docs/guide/reactivity.md +30 -9
- package/docs/guide/routing.md +189 -289
- package/docs/guide/sfc.md +40 -40
- package/docs/guide/templating.md +4 -4
- package/docs/index.md +48 -14
- package/docs/public/logo.svg +17 -38
- package/docs/router/basic-routing.md +103 -0
- package/docs/router/cold-entry.md +91 -0
- package/docs/router/history.md +69 -0
- package/docs/router/index.md +73 -0
- package/docs/router/resolver.md +74 -0
- package/docs/router/surgical-swaps.md +134 -0
- package/examples/vite-app/README.md +2 -2
- package/examples/vite-app/index.html +9 -13
- package/examples/vite-app/package.json +4 -2
- package/examples/vite-app/src/app.css +3 -0
- package/examples/vite-app/src/app.js +29 -0
- package/examples/vite-app/src/components/app-navbar.lego +34 -0
- package/examples/vite-app/src/components/customers/customer-details.lego +24 -0
- package/examples/vite-app/src/components/customers/customer-orders.lego +21 -0
- package/examples/vite-app/src/components/customers/order-list.lego +55 -0
- package/examples/vite-app/src/components/greeting-card.lego +26 -26
- package/examples/vite-app/src/components/sample-component.lego +58 -58
- package/examples/vite-app/src/components/shells/customers-shell.lego +21 -0
- package/examples/vite-app/src/components/todo-list.lego +239 -0
- package/examples/vite-app/src/components/widgets/user-card.lego +27 -0
- package/examples/vite-app/vite.config.js +7 -2
- package/lego.js +2 -0
- package/main.js +280 -83
- package/package.json +8 -3
- package/parse-lego.js +17 -8
- package/parse-lego.test.js +1 -1
- package/{main.test.js → tests/main.test.js} +34 -17
- package/tests/parse-lego.test.js +65 -0
- package/vite-plugin.js +62 -24
- package/docs/.vitepress/dist/404.html +0 -22
- package/docs/.vitepress/dist/api/define.html +0 -35
- package/docs/.vitepress/dist/api/directives.html +0 -32
- package/docs/.vitepress/dist/api/globals.html +0 -27
- package/docs/.vitepress/dist/api/index.html +0 -25
- package/docs/.vitepress/dist/api/lifecycle.html +0 -38
- package/docs/.vitepress/dist/api/route.html +0 -34
- package/docs/.vitepress/dist/api/vite-plugin.html +0 -37
- package/docs/.vitepress/dist/assets/api_define.md.UA-ygUnQ.js +0 -11
- package/docs/.vitepress/dist/assets/api_define.md.UA-ygUnQ.lean.js +0 -1
- package/docs/.vitepress/dist/assets/api_directives.md.BV-D251p.js +0 -8
- package/docs/.vitepress/dist/assets/api_directives.md.BV-D251p.lean.js +0 -1
- package/docs/.vitepress/dist/assets/api_globals.md.DOjt7AV0.js +0 -3
- package/docs/.vitepress/dist/assets/api_globals.md.DOjt7AV0.lean.js +0 -1
- package/docs/.vitepress/dist/assets/api_index.md.OS6h01ct.js +0 -1
- package/docs/.vitepress/dist/assets/api_index.md.OS6h01ct.lean.js +0 -1
- package/docs/.vitepress/dist/assets/api_lifecycle.md.Ccm5xw6-.js +0 -14
- package/docs/.vitepress/dist/assets/api_lifecycle.md.Ccm5xw6-.lean.js +0 -1
- package/docs/.vitepress/dist/assets/api_route.md.CAHf_KNp.js +0 -10
- package/docs/.vitepress/dist/assets/api_route.md.CAHf_KNp.lean.js +0 -1
- package/docs/.vitepress/dist/assets/api_vite-plugin.md.DNn9VhL5.js +0 -13
- package/docs/.vitepress/dist/assets/api_vite-plugin.md.DNn9VhL5.lean.js +0 -1
- package/docs/.vitepress/dist/assets/app.BG5s3B0P.js +0 -1
- package/docs/.vitepress/dist/assets/chunks/@localSearchIndexroot.DQmuWC2Z.js +0 -1
- package/docs/.vitepress/dist/assets/chunks/VPLocalSearchBox.BO-PSxt1.js +0 -9
- package/docs/.vitepress/dist/assets/chunks/framework.B7OFBR9X.js +0 -19
- package/docs/.vitepress/dist/assets/chunks/theme.DA-iSa9B.js +0 -2
- package/docs/.vitepress/dist/assets/examples_form.md.B3stGKbu.js +0 -34
- package/docs/.vitepress/dist/assets/examples_form.md.B3stGKbu.lean.js +0 -1
- package/docs/.vitepress/dist/assets/examples_index.md.BDEG_D4J.js +0 -30
- package/docs/.vitepress/dist/assets/examples_index.md.BDEG_D4J.lean.js +0 -1
- package/docs/.vitepress/dist/assets/examples_routing.md.bqZ9DjDK.js +0 -338
- package/docs/.vitepress/dist/assets/examples_routing.md.bqZ9DjDK.lean.js +0 -1
- package/docs/.vitepress/dist/assets/examples_sfc-showcase.md.DLXaUiop.js +0 -13
- package/docs/.vitepress/dist/assets/examples_sfc-showcase.md.DLXaUiop.lean.js +0 -1
- package/docs/.vitepress/dist/assets/examples_todo-app.md.D5RhZoo5.js +0 -297
- package/docs/.vitepress/dist/assets/examples_todo-app.md.D5RhZoo5.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_cdn-usage.md.CAjf03Lr.js +0 -182
- package/docs/.vitepress/dist/assets/guide_cdn-usage.md.CAjf03Lr.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_components.md.BIFWF1Hc.js +0 -174
- package/docs/.vitepress/dist/assets/guide_components.md.BIFWF1Hc.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_contributing.md.BgbUN-Mr.js +0 -1
- package/docs/.vitepress/dist/assets/guide_contributing.md.BgbUN-Mr.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_directives.md.Bi3ynu1d.js +0 -140
- package/docs/.vitepress/dist/assets/guide_directives.md.Bi3ynu1d.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_getting-started.md.2Nr1lp2z.js +0 -107
- package/docs/.vitepress/dist/assets/guide_getting-started.md.2Nr1lp2z.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_index.md.GvZq_Yf2.js +0 -2
- package/docs/.vitepress/dist/assets/guide_index.md.GvZq_Yf2.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_lifecycle.md.B28j1OzS.js +0 -304
- package/docs/.vitepress/dist/assets/guide_lifecycle.md.B28j1OzS.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_quick-start.md.CNk3VGTF.js +0 -33
- package/docs/.vitepress/dist/assets/guide_quick-start.md.CNk3VGTF.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_reactivity.md.CVsaMaPv.js +0 -135
- package/docs/.vitepress/dist/assets/guide_reactivity.md.CVsaMaPv.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_routing.md.DSpDP25o.js +0 -193
- package/docs/.vitepress/dist/assets/guide_routing.md.DSpDP25o.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_sfc.md.CVUP66tS.js +0 -187
- package/docs/.vitepress/dist/assets/guide_sfc.md.CVUP66tS.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_templating.md.BgCGe4aa.js +0 -119
- package/docs/.vitepress/dist/assets/guide_templating.md.BgCGe4aa.lean.js +0 -1
- package/docs/.vitepress/dist/assets/index.md.xV1taCED.js +0 -23
- package/docs/.vitepress/dist/assets/index.md.xV1taCED.lean.js +0 -1
- package/docs/.vitepress/dist/assets/inter-italic-cyrillic-ext.r48I6akx.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-cyrillic.By2_1cv3.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-greek-ext.1u6EdAuj.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-greek.DJ8dCoTZ.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-latin-ext.CN1xVJS-.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-latin.C2AdPX0b.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-vietnamese.BSbpV94h.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-cyrillic-ext.BBPuwvHQ.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-cyrillic.C5lxZ8CY.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-greek-ext.CqjqNYQ-.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-greek.BBVDIX6e.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-latin-ext.4ZJIpNVo.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-latin.Di8DUHzh.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-vietnamese.BjW4sHH5.woff2 +0 -0
- package/docs/.vitepress/dist/assets/style.eycE2Jhw.css +0 -1
- package/docs/.vitepress/dist/examples/form.html +0 -58
- package/docs/.vitepress/dist/examples/index.html +0 -368
- package/docs/.vitepress/dist/examples/routing.html +0 -362
- package/docs/.vitepress/dist/examples/sfc-showcase.html +0 -37
- package/docs/.vitepress/dist/examples/todo-app.html +0 -321
- package/docs/.vitepress/dist/guide/cdn-usage.html +0 -206
- package/docs/.vitepress/dist/guide/components.html +0 -198
- package/docs/.vitepress/dist/guide/contributing.html +0 -25
- package/docs/.vitepress/dist/guide/directives.html +0 -164
- package/docs/.vitepress/dist/guide/getting-started.html +0 -131
- package/docs/.vitepress/dist/guide/index.html +0 -26
- package/docs/.vitepress/dist/guide/lifecycle.html +0 -328
- package/docs/.vitepress/dist/guide/quick-start.html +0 -57
- package/docs/.vitepress/dist/guide/reactivity.html +0 -159
- package/docs/.vitepress/dist/guide/routing.html +0 -217
- package/docs/.vitepress/dist/guide/sfc.html +0 -211
- package/docs/.vitepress/dist/guide/templating.html +0 -143
- package/docs/.vitepress/dist/hashmap.json +0 -1
- package/docs/.vitepress/dist/index.html +0 -47
- package/docs/.vitepress/dist/logo.svg +0 -38
- package/docs/.vitepress/dist/vp-icons.css +0 -1
- package/examples/vite-app/src/main.js +0 -11
- 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':
|
|
18
|
+
'lego-dom/main.js': path.resolve(__dirname, '../../lego.js')
|
|
14
19
|
}
|
|
15
20
|
}
|
|
16
21
|
});
|
package/lego.js
ADDED