lego-dom 0.0.8 → 0.0.9
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/README.md +48 -432
- package/docs/.vitepress/config.js +4 -4
- package/docs/.vitepress/dist/404.html +3 -3
- package/docs/.vitepress/dist/api/define.html +6 -6
- package/docs/.vitepress/dist/api/directives.html +6 -6
- package/docs/.vitepress/dist/api/globals.html +7 -7
- package/docs/.vitepress/dist/api/index.html +7 -7
- package/docs/.vitepress/dist/api/lifecycle.html +6 -6
- package/docs/.vitepress/dist/api/route.html +6 -6
- package/docs/.vitepress/dist/api/vite-plugin.html +7 -7
- package/docs/.vitepress/dist/assets/{api_globals.md.DOjt7AV0.js → api_globals.md.CEznyRAY.js} +1 -1
- package/docs/.vitepress/dist/assets/api_index.md.IEYUxUIr.js +1 -0
- package/docs/.vitepress/dist/assets/{api_vite-plugin.md.DNn9VhL5.js → api_vite-plugin.md.DC8Li09k.js} +1 -1
- package/docs/.vitepress/dist/assets/{app.BG5s3B0P.js → app.BfblNDJy.js} +1 -1
- package/docs/.vitepress/dist/assets/chunks/@localSearchIndexroot.Crdp7-Zp.js +1 -0
- package/docs/.vitepress/dist/assets/chunks/{VPLocalSearchBox.BO-PSxt1.js → VPLocalSearchBox.C18E44rY.js} +1 -1
- package/docs/.vitepress/dist/assets/chunks/{theme.DA-iSa9B.js → theme.VX3itTW6.js} +2 -2
- package/docs/.vitepress/dist/assets/{examples_form.md.B3stGKbu.js → examples_form.md.DQoAgbLR.js} +1 -1
- package/docs/.vitepress/dist/assets/{examples_index.md.BDEG_D4J.js → examples_index.md.CVJJjXXE.js} +3 -5
- package/docs/.vitepress/dist/assets/{examples_routing.md.bqZ9DjDK.js → examples_routing.md.sRnA5RXw.js} +4 -4
- package/docs/.vitepress/dist/assets/{examples_sfc-showcase.md.DLXaUiop.js → examples_sfc-showcase.md.DPf9Wm99.js} +4 -4
- package/docs/.vitepress/dist/assets/{examples_todo-app.md.D5RhZoo5.js → examples_todo-app.md.CqF4JaWn.js} +2 -2
- package/docs/.vitepress/dist/assets/{guide_cdn-usage.md.CAjf03Lr.js → guide_cdn-usage.md.CjIjusre.js} +8 -8
- package/docs/.vitepress/dist/assets/{guide_components.md.BIFWF1Hc.js → guide_components.md.CMU3iM6R.js} +1 -1
- package/docs/.vitepress/dist/assets/guide_contributing.md.Crrv3T_0.js +1 -0
- package/docs/.vitepress/dist/assets/{guide_directives.md.Bi3ynu1d.js → guide_directives.md.DFwqvqOv.js} +1 -1
- package/docs/.vitepress/dist/assets/{guide_getting-started.md.2Nr1lp2z.js → guide_getting-started.md.DtaJPe0i.js} +5 -5
- package/docs/.vitepress/dist/assets/guide_index.md.DtJVpLI9.js +2 -0
- package/docs/.vitepress/dist/assets/guide_index.md.DtJVpLI9.lean.js +1 -0
- package/docs/.vitepress/dist/assets/{guide_lifecycle.md.B28j1OzS.js → guide_lifecycle.md.CfY3jlU1.js} +1 -1
- package/docs/.vitepress/dist/assets/{guide_quick-start.md.CNk3VGTF.js → guide_quick-start.md.CwdNNA21.js} +4 -4
- package/docs/.vitepress/dist/assets/{guide_reactivity.md.CVsaMaPv.js → guide_reactivity.md.DgTH0MTn.js} +8 -8
- package/docs/.vitepress/dist/assets/{guide_routing.md.DSpDP25o.js → guide_routing.md.nMB0QOBR.js} +3 -3
- package/docs/.vitepress/dist/assets/{guide_sfc.md.CVUP66tS.js → guide_sfc.md.BUkWma1z.js} +39 -39
- package/docs/.vitepress/dist/assets/{guide_templating.md.BgCGe4aa.js → guide_templating.md.XI3uUlYI.js} +2 -2
- package/docs/.vitepress/dist/assets/guide_templating.md.XI3uUlYI.lean.js +1 -0
- package/docs/.vitepress/dist/assets/{index.md.xV1taCED.js → index.md.M4_o26kF.js} +2 -2
- package/docs/.vitepress/dist/assets/index.md.M4_o26kF.lean.js +1 -0
- package/docs/.vitepress/dist/examples/form.html +7 -7
- package/docs/.vitepress/dist/examples/index.html +26 -342
- package/docs/.vitepress/dist/examples/routing.html +11 -11
- package/docs/.vitepress/dist/examples/sfc-showcase.html +11 -11
- package/docs/.vitepress/dist/examples/todo-app.html +8 -8
- package/docs/.vitepress/dist/guide/cdn-usage.html +14 -14
- package/docs/.vitepress/dist/guide/components.html +7 -7
- package/docs/.vitepress/dist/guide/contributing.html +7 -7
- package/docs/.vitepress/dist/guide/directives.html +8 -8
- package/docs/.vitepress/dist/guide/getting-started.html +11 -11
- package/docs/.vitepress/dist/guide/index.html +8 -8
- package/docs/.vitepress/dist/guide/lifecycle.html +7 -7
- package/docs/.vitepress/dist/guide/quick-start.html +10 -10
- package/docs/.vitepress/dist/guide/reactivity.html +14 -14
- package/docs/.vitepress/dist/guide/routing.html +9 -9
- package/docs/.vitepress/dist/guide/sfc.html +46 -46
- package/docs/.vitepress/dist/guide/templating.html +8 -8
- package/docs/.vitepress/dist/hashmap.json +1 -1
- package/docs/.vitepress/dist/index.html +8 -8
- package/docs/.vitepress/dist/logo.svg +1 -1
- package/docs/api/globals.md +1 -1
- package/docs/api/index.md +2 -2
- package/docs/api/vite-plugin.md +1 -1
- package/docs/examples/form.md +1 -1
- package/docs/examples/index.md +3 -3
- package/docs/examples/routing.md +4 -4
- package/docs/examples/sfc-showcase.md +4 -4
- package/docs/examples/todo-app.md +2 -2
- package/docs/guide/cdn-usage.md +8 -8
- package/docs/guide/components.md +1 -1
- package/docs/guide/contributing.md +2 -2
- package/docs/guide/directives.md +1 -1
- package/docs/guide/getting-started.md +6 -6
- package/docs/guide/index.md +9 -9
- package/docs/guide/lifecycle.md +1 -1
- package/docs/guide/quick-start.md +4 -4
- package/docs/guide/reactivity.md +8 -8
- package/docs/guide/routing.md +3 -3
- package/docs/guide/sfc.md +39 -39
- package/docs/guide/templating.md +2 -2
- package/docs/index.md +10 -10
- package/docs/public/logo.svg +17 -38
- package/examples/vite-app/README.md +2 -2
- package/examples/vite-app/index.html +8 -4
- package/examples/vite-app/src/components/greeting-card.lego +25 -25
- package/examples/vite-app/src/components/sample-component.lego +44 -44
- package/examples/vite-app/src/components/todo-list.lego +242 -0
- package/examples/vite-app/src/main.js +3 -3
- package/examples/vite-app/vite.config.js +2 -1
- package/examples.js +3 -3
- package/go.html +117 -0
- package/lego.js +2 -0
- package/main.js +41 -35
- package/package.json +8 -3
- package/parse-lego.test.js +1 -1
- package/vite-plugin.js +2 -2
- package/docs/.vitepress/dist/assets/api_index.md.OS6h01ct.js +0 -1
- package/docs/.vitepress/dist/assets/chunks/@localSearchIndexroot.DQmuWC2Z.js +0 -1
- package/docs/.vitepress/dist/assets/guide_contributing.md.BgbUN-Mr.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_templating.md.BgCGe4aa.lean.js +0 -1
- package/docs/.vitepress/dist/assets/index.md.xV1taCED.lean.js +0 -1
- /package/docs/.vitepress/dist/assets/{api_globals.md.DOjt7AV0.lean.js → api_globals.md.CEznyRAY.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{api_index.md.OS6h01ct.lean.js → api_index.md.IEYUxUIr.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{api_vite-plugin.md.DNn9VhL5.lean.js → api_vite-plugin.md.DC8Li09k.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{examples_form.md.B3stGKbu.lean.js → examples_form.md.DQoAgbLR.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{examples_index.md.BDEG_D4J.lean.js → examples_index.md.CVJJjXXE.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{examples_routing.md.bqZ9DjDK.lean.js → examples_routing.md.sRnA5RXw.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{examples_sfc-showcase.md.DLXaUiop.lean.js → examples_sfc-showcase.md.DPf9Wm99.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{examples_todo-app.md.D5RhZoo5.lean.js → examples_todo-app.md.CqF4JaWn.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_cdn-usage.md.CAjf03Lr.lean.js → guide_cdn-usage.md.CjIjusre.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_components.md.BIFWF1Hc.lean.js → guide_components.md.CMU3iM6R.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_contributing.md.BgbUN-Mr.lean.js → guide_contributing.md.Crrv3T_0.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_directives.md.Bi3ynu1d.lean.js → guide_directives.md.DFwqvqOv.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_getting-started.md.2Nr1lp2z.lean.js → guide_getting-started.md.DtaJPe0i.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_lifecycle.md.B28j1OzS.lean.js → guide_lifecycle.md.CfY3jlU1.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_quick-start.md.CNk3VGTF.lean.js → guide_quick-start.md.CwdNNA21.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_reactivity.md.CVsaMaPv.lean.js → guide_reactivity.md.DgTH0MTn.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_routing.md.DSpDP25o.lean.js → guide_routing.md.nMB0QOBR.lean.js} +0 -0
- /package/docs/.vitepress/dist/assets/{guide_sfc.md.CVUP66tS.lean.js → guide_sfc.md.BUkWma1z.lean.js} +0 -0
|
@@ -1,31 +1,31 @@
|
|
|
1
|
-
<
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
}
|
|
1
|
+
<style>
|
|
2
|
+
self {
|
|
3
|
+
display: block;
|
|
4
|
+
padding: 1rem;
|
|
5
|
+
background: #f3f4f6;
|
|
6
|
+
border-radius: 0.5rem;
|
|
7
|
+
margin: 0.5rem 0;
|
|
8
|
+
}
|
|
10
9
|
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
10
|
+
input {
|
|
11
|
+
padding: 0.5rem;
|
|
12
|
+
border: 1px solid #d1d5db;
|
|
13
|
+
border-radius: 0.25rem;
|
|
14
|
+
margin-right: 0.5rem;
|
|
15
|
+
font-size: 1rem;
|
|
16
|
+
}
|
|
18
17
|
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
18
|
+
.greeting {
|
|
19
|
+
margin-top: 1rem;
|
|
20
|
+
padding: 1rem;
|
|
21
|
+
background: white;
|
|
22
|
+
border-radius: 0.25rem;
|
|
23
|
+
font-size: 1.25rem;
|
|
24
|
+
color: #1f2937;
|
|
25
|
+
}
|
|
26
|
+
</style>
|
|
28
27
|
|
|
28
|
+
<template>
|
|
29
29
|
<div>
|
|
30
30
|
<input b-sync="name" type="text" placeholder="Enter your name">
|
|
31
31
|
<div class="greeting" b-if="name">
|
|
@@ -1,55 +1,55 @@
|
|
|
1
|
-
<
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
}
|
|
1
|
+
<style>
|
|
2
|
+
self {
|
|
3
|
+
display: block;
|
|
4
|
+
padding: 1.5rem;
|
|
5
|
+
margin: 1rem 0;
|
|
6
|
+
border: 2px solid #4f46e5;
|
|
7
|
+
border-radius: 0.5rem;
|
|
8
|
+
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
|
|
9
|
+
color: white;
|
|
10
|
+
font-family: system-ui, -apple-system, sans-serif;
|
|
11
|
+
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
|
|
12
|
+
}
|
|
14
13
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
14
|
+
.header {
|
|
15
|
+
font-size: 1.5rem;
|
|
16
|
+
font-weight: bold;
|
|
17
|
+
margin-bottom: 0.5rem;
|
|
18
|
+
}
|
|
20
19
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
20
|
+
.content {
|
|
21
|
+
margin: 1rem 0;
|
|
22
|
+
line-height: 1.6;
|
|
23
|
+
}
|
|
25
24
|
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
25
|
+
button {
|
|
26
|
+
background: white;
|
|
27
|
+
color: #4f46e5;
|
|
28
|
+
border: none;
|
|
29
|
+
padding: 0.5rem 1rem;
|
|
30
|
+
border-radius: 0.25rem;
|
|
31
|
+
font-weight: 600;
|
|
32
|
+
cursor: pointer;
|
|
33
|
+
transition: transform 0.2s;
|
|
34
|
+
}
|
|
36
35
|
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
36
|
+
button:hover {
|
|
37
|
+
transform: scale(1.05);
|
|
38
|
+
}
|
|
40
39
|
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
40
|
+
.count {
|
|
41
|
+
display: inline-block;
|
|
42
|
+
background: rgba(255, 255, 255, 0.2);
|
|
43
|
+
padding: 0.25rem 0.75rem;
|
|
44
|
+
border-radius: 0.25rem;
|
|
45
|
+
margin-left: 0.5rem;
|
|
46
|
+
}
|
|
47
|
+
</style>
|
|
49
48
|
|
|
49
|
+
<template>
|
|
50
50
|
<div class="header">{{ title }}</div>
|
|
51
51
|
<div class="content">
|
|
52
|
-
<p>This is a sample
|
|
52
|
+
<p>This is a sample Lego component loaded from a .lego file!</p>
|
|
53
53
|
<p>Message: {{ message }}</p>
|
|
54
54
|
</div>
|
|
55
55
|
<button @click="incrementCount()">
|
|
@@ -0,0 +1,242 @@
|
|
|
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>
|
|
166
|
+
<li b-for="todo in filteredTodos()">
|
|
167
|
+
<input type="checkbox" b-sync="todo.done">
|
|
168
|
+
<span class="todo-text {{ todo.done ? 'done' : '' }}">
|
|
169
|
+
{{ todo.text }} - first
|
|
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-if="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
|
+
const index = this.todos.indexOf(todo);
|
|
216
|
+
if (index > -1) {
|
|
217
|
+
this.todos.splice(index, 1);
|
|
218
|
+
}
|
|
219
|
+
},
|
|
220
|
+
|
|
221
|
+
filteredTodos() {
|
|
222
|
+
if (this.filter === 'active') {
|
|
223
|
+
return this.todos.filter(t => !t.done);
|
|
224
|
+
} else if (this.filter === 'completed') {
|
|
225
|
+
return this.todos.filter(t => t.done);
|
|
226
|
+
}
|
|
227
|
+
return this.todos;
|
|
228
|
+
},
|
|
229
|
+
|
|
230
|
+
remaining() {
|
|
231
|
+
return this.todos.filter(t => !t.done).length;
|
|
232
|
+
},
|
|
233
|
+
|
|
234
|
+
completedCount() {
|
|
235
|
+
return this.todos.filter(t => t.done).length;
|
|
236
|
+
},
|
|
237
|
+
|
|
238
|
+
clearCompleted() {
|
|
239
|
+
this.todos = this.todos.filter(t => !t.done);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
</script>
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// Import
|
|
1
|
+
// Import Lego core
|
|
2
2
|
import { Lego } from 'lego-dom/main.js';
|
|
3
3
|
|
|
4
4
|
// Import virtual module that auto-discovers and registers all .lego components
|
|
@@ -7,5 +7,5 @@ import registerComponents from 'virtual:lego-components';
|
|
|
7
7
|
// Register all auto-discovered components
|
|
8
8
|
registerComponents();
|
|
9
9
|
|
|
10
|
-
// Initialize
|
|
11
|
-
console.log('
|
|
10
|
+
// Initialize Lego
|
|
11
|
+
console.log('Lego initialized with auto-discovered components!');
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { defineConfig } from 'vite';
|
|
2
|
+
import path from 'path';
|
|
2
3
|
import legoPlugin from 'lego-dom/vite-plugin';
|
|
3
4
|
|
|
4
5
|
export default defineConfig({
|
|
@@ -10,7 +11,7 @@ export default defineConfig({
|
|
|
10
11
|
],
|
|
11
12
|
resolve: {
|
|
12
13
|
alias: {
|
|
13
|
-
'lego-dom/main.js':
|
|
14
|
+
'lego-dom/main.js': path.resolve(__dirname, '../../lego.js')
|
|
14
15
|
}
|
|
15
16
|
}
|
|
16
17
|
});
|
package/examples.js
CHANGED
|
@@ -2,7 +2,7 @@ export const examples = {
|
|
|
2
2
|
counter: `<!DOCTYPE html>
|
|
3
3
|
<html>
|
|
4
4
|
<head>
|
|
5
|
-
<title>
|
|
5
|
+
<title>Lego Counter</title>
|
|
6
6
|
</head>
|
|
7
7
|
<body>
|
|
8
8
|
<template b-id="click-counter">
|
|
@@ -24,7 +24,7 @@ export const examples = {
|
|
|
24
24
|
<head>
|
|
25
25
|
<meta charset="UTF-8">
|
|
26
26
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
27
|
-
<title>Todo App -
|
|
27
|
+
<title>Todo App - Lego</title>
|
|
28
28
|
<style>
|
|
29
29
|
body {
|
|
30
30
|
font-family: system-ui, -apple-system, sans-serif;
|
|
@@ -53,7 +53,7 @@ export const examples = {
|
|
|
53
53
|
form: `<!DOCTYPE html>
|
|
54
54
|
<html>
|
|
55
55
|
<head>
|
|
56
|
-
<title>
|
|
56
|
+
<title>Lego Form</title>
|
|
57
57
|
</head>
|
|
58
58
|
<body>
|
|
59
59
|
<template b-id="login-form">
|
package/go.html
ADDED
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
<html lang="en">
|
|
2
|
+
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8">
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
6
|
+
<title>Lego Test</title>
|
|
7
|
+
<script src="./main.js"></script>
|
|
8
|
+
</head>
|
|
9
|
+
|
|
10
|
+
<body @todo-added="() => {console.log('Todo added!')}">
|
|
11
|
+
<template b-id="todo-list">
|
|
12
|
+
<style>
|
|
13
|
+
:host {
|
|
14
|
+
display: block;
|
|
15
|
+
font-family: system-ui, sans-serif;
|
|
16
|
+
padding: 20px;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.done {
|
|
20
|
+
text-decoration: line-through;
|
|
21
|
+
color: #888;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.input {
|
|
25
|
+
padding: .4em;
|
|
26
|
+
border: 1px solid #ccc;
|
|
27
|
+
border-radius: 0.1em;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
.item-row {
|
|
31
|
+
margin-bottom: 8px;
|
|
32
|
+
display: flex;
|
|
33
|
+
align-items: center;
|
|
34
|
+
gap: 10px;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
button {
|
|
38
|
+
cursor: pointer;
|
|
39
|
+
border: none;
|
|
40
|
+
padding: 5px 10px;
|
|
41
|
+
border-radius: 0px;
|
|
42
|
+
background-color: #404;
|
|
43
|
+
color: #fff;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
h3 {
|
|
47
|
+
color: #318d8d;
|
|
48
|
+
margin-top: 0;
|
|
49
|
+
}
|
|
50
|
+
</style>
|
|
51
|
+
|
|
52
|
+
<h3>{{title}}</h3>
|
|
53
|
+
<p>{{ items.filter(t => !t.done).length }} of {{ items.length }} items remaining</p>
|
|
54
|
+
<div style="margin-bottom: 20px;">
|
|
55
|
+
<input b-sync="newItem" placeholder="Add task..." class="input" @keydown="() => {
|
|
56
|
+
}">
|
|
57
|
+
<button @click="() => {
|
|
58
|
+
if(!newItem.trim()) return;
|
|
59
|
+
items.push({text: `${newItem} - ${items.length + 1} - ${$ancestors('user-card').name}`, done: false});
|
|
60
|
+
newItem = '';
|
|
61
|
+
$emit('todo-added', { item: newItem });
|
|
62
|
+
}">Add</button>
|
|
63
|
+
</div>
|
|
64
|
+
|
|
65
|
+
<div b-for="todo in items">
|
|
66
|
+
<div class="item-row {{todo.done ? 'done' : ''}}">
|
|
67
|
+
<input type="checkbox" b-sync="todo.done">
|
|
68
|
+
<span>{{todo.text}}</span>
|
|
69
|
+
</div>
|
|
70
|
+
</div>
|
|
71
|
+
</template>
|
|
72
|
+
|
|
73
|
+
<template b-id="user-card">
|
|
74
|
+
<style>
|
|
75
|
+
:host {
|
|
76
|
+
display: block;
|
|
77
|
+
font-family: system-ui, sans-serif;
|
|
78
|
+
padding: 20px;
|
|
79
|
+
border: 1px solid #ccc;
|
|
80
|
+
border-radius: 8px;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
h3 {
|
|
84
|
+
color: #62318d;
|
|
85
|
+
margin-top: 0;
|
|
86
|
+
}
|
|
87
|
+
</style>
|
|
88
|
+
|
|
89
|
+
<h3>{{name}}</h3>
|
|
90
|
+
<p>{{bio}}</p>
|
|
91
|
+
<slot></slot>
|
|
92
|
+
</template>
|
|
93
|
+
|
|
94
|
+
<user-card b-data="{
|
|
95
|
+
name: 'John Doe',
|
|
96
|
+
bio: 'Software Engineer'
|
|
97
|
+
}">
|
|
98
|
+
<p>Additional content here</p>
|
|
99
|
+
<todo-list b-data="{
|
|
100
|
+
title: 'Enterprise Todo List',
|
|
101
|
+
items: [{text: 'Fix b-for strikethrough', done: true}],
|
|
102
|
+
newItem: '',
|
|
103
|
+
mounted() {
|
|
104
|
+
console.log('THis lego block has been mounted!');
|
|
105
|
+
},
|
|
106
|
+
updated() {
|
|
107
|
+
console.log('This lego block has been updated!');
|
|
108
|
+
},
|
|
109
|
+
unmounted() {
|
|
110
|
+
console.log('This lego block has been unmounted!');
|
|
111
|
+
}
|
|
112
|
+
}">
|
|
113
|
+
</todo-list>
|
|
114
|
+
</user-card>
|
|
115
|
+
</body>
|
|
116
|
+
|
|
117
|
+
</html>
|
package/lego.js
ADDED