luxen-ui 0.6.2 → 0.8.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/bin/cli.mjs +54 -10
- package/cdn/chunks/decorate.js +1 -1
- package/cdn/chunks/floating-ui.dom.js +2 -0
- package/cdn/chunks/floating-ui.dom.js.map +1 -0
- package/cdn/chunks/lit-html.js +3 -0
- package/cdn/chunks/lit-html.js.map +1 -0
- package/cdn/chunks/lit.js +1 -2
- package/cdn/chunks/lit.js.map +1 -1
- package/cdn/chunks/module.js +717 -0
- package/cdn/chunks/module.js.map +1 -0
- package/cdn/chunks/native.js +2 -0
- package/cdn/chunks/native.js.map +1 -0
- package/cdn/chunks/static-html.js +2 -0
- package/cdn/chunks/static-html.js.map +1 -0
- package/cdn/custom-elements.json +1412 -12629
- package/cdn/elements/avatar/avatar.d.ts +5 -0
- package/cdn/elements/avatar/avatar.d.ts.map +1 -1
- package/cdn/elements/avatar/avatar.js +5 -5
- package/cdn/elements/avatar/avatar.js.map +1 -1
- package/cdn/elements/button/button.meta.d.ts +33 -0
- package/cdn/elements/button/button.meta.d.ts.map +1 -0
- package/cdn/elements/button/button.meta.js +0 -0
- package/cdn/elements/carousel/carousel.d.ts +6 -0
- package/cdn/elements/carousel/carousel.d.ts.map +1 -1
- package/cdn/elements/carousel/carousel.js +1 -1
- package/cdn/elements/carousel/carousel.js.map +1 -1
- package/cdn/elements/carousel-item/carousel-item.d.ts +2 -0
- package/cdn/elements/carousel-item/carousel-item.d.ts.map +1 -1
- package/cdn/elements/carousel-item/carousel-item.js +1 -1
- package/cdn/elements/carousel-item/carousel-item.js.map +1 -1
- package/cdn/elements/close-button/close-button.meta.d.ts +24 -0
- package/cdn/elements/close-button/close-button.meta.d.ts.map +1 -0
- package/cdn/elements/close-button/close-button.meta.js +0 -0
- package/cdn/elements/dialog/dialog.d.ts +12 -6
- package/cdn/elements/dialog/dialog.d.ts.map +1 -1
- package/cdn/elements/dialog/dialog.js +8 -5
- package/cdn/elements/dialog/dialog.js.map +1 -1
- package/cdn/elements/dialog/dialog.styles.js +1 -1
- package/cdn/elements/dialog/dialog.styles.js.map +1 -1
- package/cdn/elements/disclosure/disclosure.meta.d.ts +28 -0
- package/cdn/elements/disclosure/disclosure.meta.d.ts.map +1 -0
- package/cdn/elements/disclosure/disclosure.meta.js +0 -0
- package/cdn/elements/divider/divider.d.ts +1 -1
- package/cdn/elements/divider/divider.js.map +1 -1
- package/cdn/elements/drawer/drawer.d.ts +5 -0
- package/cdn/elements/drawer/drawer.d.ts.map +1 -1
- package/cdn/elements/drawer/drawer.js +1 -1
- package/cdn/elements/drawer/drawer.js.map +1 -1
- package/cdn/elements/dropdown/dropdown.d.ts +2 -0
- package/cdn/elements/dropdown/dropdown.d.ts.map +1 -1
- package/cdn/elements/dropdown/dropdown.js +1 -1
- package/cdn/elements/dropdown/dropdown.js.map +1 -1
- package/cdn/elements/dropdown-item/dropdown-item.d.ts +2 -0
- package/cdn/elements/dropdown-item/dropdown-item.d.ts.map +1 -1
- package/cdn/elements/dropdown-item/dropdown-item.js +1 -1
- package/cdn/elements/dropdown-item/dropdown-item.js.map +1 -1
- package/cdn/elements/icon/icon.js +1 -1
- package/cdn/elements/icon/icon.js.map +1 -1
- package/cdn/elements/input-otp/input-otp.d.ts +2 -0
- package/cdn/elements/input-otp/input-otp.d.ts.map +1 -1
- package/cdn/elements/input-otp/input-otp.js.map +1 -1
- package/cdn/elements/input-stepper/input-stepper.d.ts +2 -0
- package/cdn/elements/input-stepper/input-stepper.d.ts.map +1 -1
- package/cdn/elements/input-stepper/input-stepper.js +1 -1
- package/cdn/elements/input-stepper/input-stepper.js.map +1 -1
- package/cdn/elements/kbd/kbd.meta.d.ts +14 -0
- package/cdn/elements/kbd/kbd.meta.d.ts.map +1 -0
- package/cdn/elements/kbd/kbd.meta.js +0 -0
- package/cdn/elements/popover/popover.js +1 -1
- package/cdn/elements/popover/popover.js.map +1 -1
- package/cdn/elements/progress/progress.meta.d.ts +22 -0
- package/cdn/elements/progress/progress.meta.d.ts.map +1 -0
- package/cdn/elements/progress/progress.meta.js +0 -0
- package/cdn/elements/prose-editor/index.d.ts +2 -0
- package/cdn/elements/prose-editor/index.d.ts.map +1 -0
- package/cdn/elements/prose-editor/index.js +2 -0
- package/cdn/elements/prose-editor/index.js.map +1 -0
- package/cdn/elements/prose-editor/prose-editor.d.ts +113 -0
- package/cdn/elements/prose-editor/prose-editor.d.ts.map +1 -0
- package/cdn/elements/prose-editor/prose-editor.js +180 -0
- package/cdn/elements/prose-editor/prose-editor.js.map +1 -0
- package/cdn/elements/rating/rating.d.ts +2 -0
- package/cdn/elements/rating/rating.d.ts.map +1 -1
- package/cdn/elements/rating/rating.js +1 -1
- package/cdn/elements/rating/rating.js.map +1 -1
- package/cdn/elements/select/select.meta.d.ts +28 -0
- package/cdn/elements/select/select.meta.d.ts.map +1 -0
- package/cdn/elements/select/select.meta.js +0 -0
- package/cdn/elements/skeleton/skeleton.d.ts +3 -0
- package/cdn/elements/skeleton/skeleton.d.ts.map +1 -1
- package/cdn/elements/skeleton/skeleton.js.map +1 -1
- package/cdn/elements/spinner/spinner.js +1 -1
- package/cdn/elements/spinner/spinner.js.map +1 -1
- package/cdn/elements/sticky-bar/sticky-bar.js +1 -1
- package/cdn/elements/sticky-bar/sticky-bar.js.map +1 -1
- package/cdn/elements/stories-viewer/stories-viewer.d.ts +1 -1
- package/cdn/elements/stories-viewer/stories-viewer.d.ts.map +1 -1
- package/cdn/elements/stories-viewer/stories-viewer.js +26 -26
- package/cdn/elements/stories-viewer/stories-viewer.js.map +1 -1
- package/cdn/elements/story/story.d.ts +10 -1
- package/cdn/elements/story/story.d.ts.map +1 -1
- package/cdn/elements/story/story.js +20 -20
- package/cdn/elements/story/story.js.map +1 -1
- package/cdn/elements/toast/toast.d.ts +5 -0
- package/cdn/elements/toast/toast.d.ts.map +1 -1
- package/cdn/elements/toast/toast.js.map +1 -1
- package/cdn/elements/tooltip/tooltip.js +1 -1
- package/cdn/elements/tooltip/tooltip.js.map +1 -1
- package/cdn/elements/tree/tree.d.ts +2 -0
- package/cdn/elements/tree/tree.d.ts.map +1 -1
- package/cdn/elements/tree/tree.js +1 -1
- package/cdn/elements/tree/tree.js.map +1 -1
- package/cdn/elements/tree-item/tree-item.d.ts +2 -0
- package/cdn/elements/tree-item/tree-item.d.ts.map +1 -1
- package/cdn/elements/tree-item/tree-item.js +1 -1
- package/cdn/elements/tree-item/tree-item.js.map +1 -1
- package/cdn/registry.d.ts +1 -1
- package/cdn/registry.d.ts.map +1 -1
- package/cdn/registry.js.map +1 -1
- package/cdn/shared/controllers/has-slot-controller.d.ts +37 -0
- package/cdn/shared/controllers/has-slot-controller.d.ts.map +1 -0
- package/cdn/shared/controllers/has-slot-controller.js +2 -0
- package/cdn/shared/controllers/has-slot-controller.js.map +1 -0
- package/cdn/shared/controllers/popover.js +1 -1
- package/cdn/shared/controllers/popover.js.map +1 -1
- package/cdn/shared/styles/host.styles.js +1 -1
- package/cdn/standalone.css +132 -1
- package/cdn/standalone.js +25743 -191
- package/cdn/standalone.js.map +1 -1
- package/cdn/static-tag.d.ts +17 -0
- package/cdn/static-tag.d.ts.map +1 -0
- package/cdn/static-tag.js +2 -0
- package/cdn/static-tag.js.map +1 -0
- package/cdn/styles/elements/prose-editor.css +129 -0
- package/cdn/styles/elements/toast.css +1 -1
- package/dist/css/elements/prose-editor.css +129 -0
- package/dist/css/elements/toast.css +1 -1
- package/dist/custom-elements.json +1412 -12629
- package/dist/elements/avatar/avatar.d.ts +5 -0
- package/dist/elements/avatar/avatar.d.ts.map +1 -1
- package/dist/elements/avatar/avatar.js +5 -0
- package/dist/elements/button/button.meta.d.ts +33 -0
- package/dist/elements/button/button.meta.d.ts.map +1 -0
- package/dist/elements/button/button.meta.js +44 -0
- package/dist/elements/carousel/carousel.d.ts +6 -0
- package/dist/elements/carousel/carousel.d.ts.map +1 -1
- package/dist/elements/carousel/carousel.js +6 -0
- package/dist/elements/carousel-item/carousel-item.d.ts +2 -0
- package/dist/elements/carousel-item/carousel-item.d.ts.map +1 -1
- package/dist/elements/carousel-item/carousel-item.js +2 -0
- package/dist/elements/close-button/close-button.meta.d.ts +24 -0
- package/dist/elements/close-button/close-button.meta.d.ts.map +1 -0
- package/dist/elements/close-button/close-button.meta.js +30 -0
- package/dist/elements/dialog/dialog.css +15 -0
- package/dist/elements/dialog/dialog.d.ts +12 -6
- package/dist/elements/dialog/dialog.d.ts.map +1 -1
- package/dist/elements/dialog/dialog.js +21 -7
- package/dist/elements/disclosure/disclosure.meta.d.ts +28 -0
- package/dist/elements/disclosure/disclosure.meta.d.ts.map +1 -0
- package/dist/elements/disclosure/disclosure.meta.js +34 -0
- package/dist/elements/divider/divider.d.ts +1 -1
- package/dist/elements/divider/divider.js +1 -1
- package/dist/elements/drawer/drawer.d.ts +5 -0
- package/dist/elements/drawer/drawer.d.ts.map +1 -1
- package/dist/elements/drawer/drawer.js +5 -0
- package/dist/elements/dropdown/dropdown.d.ts +2 -0
- package/dist/elements/dropdown/dropdown.d.ts.map +1 -1
- package/dist/elements/dropdown/dropdown.js +2 -0
- package/dist/elements/dropdown-item/dropdown-item.d.ts +2 -0
- package/dist/elements/dropdown-item/dropdown-item.d.ts.map +1 -1
- package/dist/elements/dropdown-item/dropdown-item.js +2 -0
- package/dist/elements/input-otp/input-otp.d.ts +2 -0
- package/dist/elements/input-otp/input-otp.d.ts.map +1 -1
- package/dist/elements/input-otp/input-otp.js +2 -0
- package/dist/elements/input-stepper/input-stepper.d.ts +2 -0
- package/dist/elements/input-stepper/input-stepper.d.ts.map +1 -1
- package/dist/elements/input-stepper/input-stepper.js +5 -1
- package/dist/elements/kbd/kbd.meta.d.ts +14 -0
- package/dist/elements/kbd/kbd.meta.d.ts.map +1 -0
- package/dist/elements/kbd/kbd.meta.js +20 -0
- package/dist/elements/progress/progress.meta.d.ts +22 -0
- package/dist/elements/progress/progress.meta.d.ts.map +1 -0
- package/dist/elements/progress/progress.meta.js +28 -0
- package/dist/elements/prose-editor/index.d.ts +2 -0
- package/dist/elements/prose-editor/index.d.ts.map +1 -0
- package/dist/elements/prose-editor/index.js +4 -0
- package/dist/elements/prose-editor/prose-editor.css +133 -0
- package/dist/elements/prose-editor/prose-editor.d.ts +114 -0
- package/dist/elements/prose-editor/prose-editor.d.ts.map +1 -0
- package/dist/elements/prose-editor/prose-editor.js +481 -0
- package/dist/elements/rating/rating.d.ts +2 -0
- package/dist/elements/rating/rating.d.ts.map +1 -1
- package/dist/elements/rating/rating.js +2 -0
- package/dist/elements/select/select.meta.d.ts +28 -0
- package/dist/elements/select/select.meta.d.ts.map +1 -0
- package/dist/elements/select/select.meta.js +34 -0
- package/dist/elements/skeleton/skeleton.d.ts +3 -0
- package/dist/elements/skeleton/skeleton.d.ts.map +1 -1
- package/dist/elements/skeleton/skeleton.js +3 -0
- package/dist/elements/stories-viewer/stories-viewer.d.ts +1 -1
- package/dist/elements/stories-viewer/stories-viewer.d.ts.map +1 -1
- package/dist/elements/stories-viewer/stories-viewer.js +23 -19
- package/dist/elements/story/story.d.ts +10 -1
- package/dist/elements/story/story.d.ts.map +1 -1
- package/dist/elements/story/story.js +29 -17
- package/dist/elements/toast/toast.d.ts +5 -0
- package/dist/elements/toast/toast.d.ts.map +1 -1
- package/dist/elements/toast/toast.js +5 -0
- package/dist/elements/tree/tree.d.ts +2 -0
- package/dist/elements/tree/tree.d.ts.map +1 -1
- package/dist/elements/tree/tree.js +2 -0
- package/dist/elements/tree-item/tree-item.d.ts +2 -0
- package/dist/elements/tree-item/tree-item.d.ts.map +1 -1
- package/dist/elements/tree-item/tree-item.js +2 -0
- package/dist/metadata/avatar.json +83 -0
- package/dist/metadata/badge.json +59 -0
- package/dist/metadata/button.json +138 -0
- package/dist/metadata/carousel-item.json +32 -0
- package/dist/metadata/carousel.json +388 -0
- package/dist/metadata/close-button.json +90 -0
- package/dist/metadata/dialog.json +163 -0
- package/dist/metadata/disclosure.json +88 -0
- package/dist/metadata/divider.json +65 -0
- package/dist/metadata/drawer.json +176 -0
- package/dist/metadata/dropdown-item.json +85 -0
- package/dist/metadata/dropdown.json +157 -0
- package/dist/metadata/icon.json +49 -0
- package/dist/metadata/index.json +4062 -0
- package/dist/metadata/input-otp.json +86 -0
- package/dist/metadata/input-stepper.json +122 -0
- package/dist/metadata/kbd.json +37 -0
- package/dist/metadata/popover.json +157 -0
- package/dist/metadata/progress.json +71 -0
- package/dist/metadata/prose-editor.json +365 -0
- package/dist/metadata/rating.json +126 -0
- package/dist/metadata/select.json +82 -0
- package/dist/metadata/skeleton.json +56 -0
- package/dist/metadata/spinner.json +47 -0
- package/dist/metadata/sticky-bar.json +93 -0
- package/dist/metadata/stories-viewer.json +316 -0
- package/dist/metadata/stories.json +109 -0
- package/dist/metadata/story.json +148 -0
- package/dist/metadata/tabs.json +74 -0
- package/dist/metadata/toast.json +122 -0
- package/dist/metadata/tooltip.json +144 -0
- package/dist/metadata/tree-item.json +199 -0
- package/dist/metadata/tree.json +130 -0
- package/dist/registry.d.ts +1 -1
- package/dist/registry.d.ts.map +1 -1
- package/dist/shared/controllers/has-slot-controller.d.ts +37 -0
- package/dist/shared/controllers/has-slot-controller.d.ts.map +1 -0
- package/dist/shared/controllers/has-slot-controller.js +66 -0
- package/dist/static-tag.d.ts +17 -0
- package/dist/static-tag.d.ts.map +1 -0
- package/dist/static-tag.js +22 -0
- package/dist/templates/elements/avatar.md +21 -24
- package/dist/templates/elements/badge.md +9 -15
- package/dist/templates/elements/button.md +31 -41
- package/dist/templates/elements/close-button.md +24 -36
- package/dist/templates/elements/dialog.md +73 -54
- package/dist/templates/elements/drawer.md +39 -52
- package/dist/templates/elements/progress.md +13 -23
- package/dist/templates/elements/prose-editor.md +211 -0
- package/dist/templates/elements/select.md +20 -31
- package/dist/templates/elements/sticky-bar.md +16 -60
- package/dist/templates/elements/toast.md +33 -53
- package/dist/templates/elements/tree.md +39 -67
- package/elements.json +46 -1
- package/package.json +13 -3
- package/templates/SKILL.md.tpl +5 -1
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "disclosure",
|
|
3
|
+
"displayName": "Disclosure",
|
|
4
|
+
"type": "native",
|
|
5
|
+
"isCustomElement": false,
|
|
6
|
+
"tag": null,
|
|
7
|
+
"nativeTag": "details",
|
|
8
|
+
"selector": ".l-disclosure",
|
|
9
|
+
"summary": "A headless, animated disclosure built on native `<details>`/`<summary>`.",
|
|
10
|
+
"status": "stable",
|
|
11
|
+
"appearances": [],
|
|
12
|
+
"import": {
|
|
13
|
+
"css": "luxen-ui/css/disclosure",
|
|
14
|
+
"js": null
|
|
15
|
+
},
|
|
16
|
+
"properties": [],
|
|
17
|
+
"attributes": [
|
|
18
|
+
{
|
|
19
|
+
"name": "open",
|
|
20
|
+
"data": false,
|
|
21
|
+
"values": [],
|
|
22
|
+
"description": "Native attribute — starts the disclosure expanded."
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
"name": "name",
|
|
26
|
+
"data": false,
|
|
27
|
+
"values": [],
|
|
28
|
+
"description": "Native attribute — groups disclosures into an exclusive accordion."
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
"name": "data-marker",
|
|
32
|
+
"data": true,
|
|
33
|
+
"values": [
|
|
34
|
+
"arrow",
|
|
35
|
+
"plus"
|
|
36
|
+
],
|
|
37
|
+
"description": "Marker icon: `arrow` rotates 180° when open; `plus` rotates 45° into a cross."
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
"name": "data-variant",
|
|
41
|
+
"data": true,
|
|
42
|
+
"values": [],
|
|
43
|
+
"description": "bordered — Adds border, background, and border-radius."
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
"name": "disabled",
|
|
47
|
+
"data": false,
|
|
48
|
+
"values": [],
|
|
49
|
+
"description": "Disables interaction (set on `<details>` or `<summary>`)."
|
|
50
|
+
}
|
|
51
|
+
],
|
|
52
|
+
"events": [
|
|
53
|
+
{
|
|
54
|
+
"name": "toggle",
|
|
55
|
+
"description": "Fires when the disclosure opens or closes (`e.newState` is `\"open\"` or `\"closed\"`).",
|
|
56
|
+
"cancelable": false
|
|
57
|
+
}
|
|
58
|
+
],
|
|
59
|
+
"methods": [],
|
|
60
|
+
"slots": [],
|
|
61
|
+
"cssClasses": [
|
|
62
|
+
{
|
|
63
|
+
"name": ".l-disclosure",
|
|
64
|
+
"description": "Headless base — layout, animation, and marker behavior only."
|
|
65
|
+
}
|
|
66
|
+
],
|
|
67
|
+
"cssParts": [],
|
|
68
|
+
"cssProperties": [
|
|
69
|
+
{
|
|
70
|
+
"name": "--marker-size",
|
|
71
|
+
"default": "20px",
|
|
72
|
+
"description": "Marker icon size."
|
|
73
|
+
},
|
|
74
|
+
{
|
|
75
|
+
"name": "--marker-color",
|
|
76
|
+
"default": "var(--l-color-text-tertiary)",
|
|
77
|
+
"description": "Marker icon color ()."
|
|
78
|
+
}
|
|
79
|
+
],
|
|
80
|
+
"commands": [],
|
|
81
|
+
"examples": [
|
|
82
|
+
{
|
|
83
|
+
"title": "Bordered with arrow marker",
|
|
84
|
+
"language": "html",
|
|
85
|
+
"code": "<details class=\"l-disclosure\" data-variant=\"bordered\" data-marker=\"arrow\">\n<summary>Details</summary>\n<div>Content</div>\n</details>"
|
|
86
|
+
}
|
|
87
|
+
]
|
|
88
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "divider",
|
|
3
|
+
"displayName": "Divider",
|
|
4
|
+
"type": "custom",
|
|
5
|
+
"isCustomElement": true,
|
|
6
|
+
"tag": "l-divider",
|
|
7
|
+
"nativeTag": null,
|
|
8
|
+
"selector": "l-divider",
|
|
9
|
+
"summary": "Dividers visually separate or group elements.",
|
|
10
|
+
"status": "stable",
|
|
11
|
+
"appearances": [],
|
|
12
|
+
"import": {
|
|
13
|
+
"css": "luxen-ui/css/divider",
|
|
14
|
+
"js": "luxen-ui/divider"
|
|
15
|
+
},
|
|
16
|
+
"properties": [
|
|
17
|
+
{
|
|
18
|
+
"name": "orientation",
|
|
19
|
+
"attribute": "orientation",
|
|
20
|
+
"type": "DividerOrientation",
|
|
21
|
+
"default": "'horizontal'",
|
|
22
|
+
"reflects": true,
|
|
23
|
+
"description": "The divider's orientation."
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
"name": "label",
|
|
27
|
+
"attribute": "label",
|
|
28
|
+
"type": "string | undefined",
|
|
29
|
+
"default": null,
|
|
30
|
+
"reflects": true,
|
|
31
|
+
"description": "Optional text label displayed over the divider line."
|
|
32
|
+
}
|
|
33
|
+
],
|
|
34
|
+
"attributes": [],
|
|
35
|
+
"events": [],
|
|
36
|
+
"methods": [],
|
|
37
|
+
"slots": [],
|
|
38
|
+
"cssClasses": [],
|
|
39
|
+
"cssParts": [],
|
|
40
|
+
"cssProperties": [
|
|
41
|
+
{
|
|
42
|
+
"name": "--color",
|
|
43
|
+
"default": null,
|
|
44
|
+
"description": "The color of the divider line."
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
"name": "--thickness",
|
|
48
|
+
"default": null,
|
|
49
|
+
"description": "The thickness of the divider line."
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
"name": "--spacing",
|
|
53
|
+
"default": null,
|
|
54
|
+
"description": "The spacing between the divider and its neighboring elements."
|
|
55
|
+
}
|
|
56
|
+
],
|
|
57
|
+
"commands": [],
|
|
58
|
+
"examples": [
|
|
59
|
+
{
|
|
60
|
+
"title": null,
|
|
61
|
+
"language": "html",
|
|
62
|
+
"code": "<l-divider></l-divider>"
|
|
63
|
+
}
|
|
64
|
+
]
|
|
65
|
+
}
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "drawer",
|
|
3
|
+
"displayName": "Drawer",
|
|
4
|
+
"type": "shadow",
|
|
5
|
+
"isCustomElement": true,
|
|
6
|
+
"tag": "l-drawer",
|
|
7
|
+
"nativeTag": null,
|
|
8
|
+
"selector": "l-drawer",
|
|
9
|
+
"summary": "A drawer that slides in from a screen edge. Extends `<l-dialog>`.\n\nOpen and close by toggling the `open` property (or the `--show` / `--hide`\nInvoker commands). Always opens as modal.",
|
|
10
|
+
"status": "stable",
|
|
11
|
+
"appearances": [],
|
|
12
|
+
"import": {
|
|
13
|
+
"css": null,
|
|
14
|
+
"js": "luxen-ui/drawer"
|
|
15
|
+
},
|
|
16
|
+
"properties": [
|
|
17
|
+
{
|
|
18
|
+
"name": "placement",
|
|
19
|
+
"attribute": "placement",
|
|
20
|
+
"type": "'start' | 'end' | 'bottom' | undefined",
|
|
21
|
+
"default": null,
|
|
22
|
+
"reflects": true,
|
|
23
|
+
"description": "Edge the drawer slides in from. Defaults to the start (inline-start) edge."
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
"name": "title",
|
|
27
|
+
"attribute": "title",
|
|
28
|
+
"type": "string",
|
|
29
|
+
"default": "''",
|
|
30
|
+
"reflects": false,
|
|
31
|
+
"description": "Dialog title rendered in the header."
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
"name": "open",
|
|
35
|
+
"attribute": "open",
|
|
36
|
+
"type": "boolean",
|
|
37
|
+
"default": "false",
|
|
38
|
+
"reflects": true,
|
|
39
|
+
"description": "Whether the dialog is open."
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
"name": "lightDismiss",
|
|
43
|
+
"attribute": "light-dismiss",
|
|
44
|
+
"type": "boolean",
|
|
45
|
+
"default": "false",
|
|
46
|
+
"reflects": true,
|
|
47
|
+
"description": "Close when the backdrop is clicked."
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
"name": "withoutHeader",
|
|
51
|
+
"attribute": "without-header",
|
|
52
|
+
"type": "boolean",
|
|
53
|
+
"default": "false",
|
|
54
|
+
"reflects": true,
|
|
55
|
+
"description": "Hide the header entirely (title and close slot)."
|
|
56
|
+
}
|
|
57
|
+
],
|
|
58
|
+
"attributes": [],
|
|
59
|
+
"events": [
|
|
60
|
+
{
|
|
61
|
+
"name": "show",
|
|
62
|
+
"description": "Fired when the drawer opens. Not cancelable.",
|
|
63
|
+
"cancelable": false
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
"name": "after-show",
|
|
67
|
+
"description": "Fired after the open animation completes.",
|
|
68
|
+
"cancelable": false
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
"name": "hide",
|
|
72
|
+
"description": "Fired when the drawer is about to close. Cancelable — call `event.preventDefault()` to keep it open.",
|
|
73
|
+
"cancelable": true
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
"name": "after-hide",
|
|
77
|
+
"description": "Fired after the close animation completes.",
|
|
78
|
+
"cancelable": false
|
|
79
|
+
}
|
|
80
|
+
],
|
|
81
|
+
"methods": [],
|
|
82
|
+
"slots": [
|
|
83
|
+
{
|
|
84
|
+
"name": "",
|
|
85
|
+
"description": "Body content."
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
"name": "close",
|
|
89
|
+
"description": "Close button (typically `<button class=\"l-close\">`)."
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
"name": "footer",
|
|
93
|
+
"description": "Footer actions."
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
"name": "title",
|
|
97
|
+
"description": "Custom heading element. Overrides the default `<h2>` rendered from the `title` property."
|
|
98
|
+
}
|
|
99
|
+
],
|
|
100
|
+
"cssClasses": [],
|
|
101
|
+
"cssParts": [
|
|
102
|
+
{
|
|
103
|
+
"name": "dialog",
|
|
104
|
+
"description": "The native `<dialog>` element."
|
|
105
|
+
},
|
|
106
|
+
{
|
|
107
|
+
"name": "header",
|
|
108
|
+
"description": "The header wrapper containing the title and close slot."
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
"name": "title",
|
|
112
|
+
"description": "The drawer title heading."
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
"name": "body",
|
|
116
|
+
"description": "The body wrapper around the default slot."
|
|
117
|
+
},
|
|
118
|
+
{
|
|
119
|
+
"name": "footer",
|
|
120
|
+
"description": "The footer wrapper around the footer slot."
|
|
121
|
+
}
|
|
122
|
+
],
|
|
123
|
+
"cssProperties": [
|
|
124
|
+
{
|
|
125
|
+
"name": "--size",
|
|
126
|
+
"default": "320px",
|
|
127
|
+
"description": "Drawer size on the axis perpendicular to its edge (width for `start`/`end`, height for `bottom`)."
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
"name": "--border-radius",
|
|
131
|
+
"default": "6px",
|
|
132
|
+
"description": "Drawer border radius on the inner edges."
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
"name": "--show-duration",
|
|
136
|
+
"default": "200ms",
|
|
137
|
+
"description": "Open transition duration."
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
"name": "--hide-duration",
|
|
141
|
+
"default": "200ms",
|
|
142
|
+
"description": "Close transition duration."
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
"name": "--backdrop",
|
|
146
|
+
"default": null,
|
|
147
|
+
"description": "Backdrop color."
|
|
148
|
+
},
|
|
149
|
+
{
|
|
150
|
+
"name": "--width",
|
|
151
|
+
"default": "31rem",
|
|
152
|
+
"description": "Dialog width."
|
|
153
|
+
},
|
|
154
|
+
{
|
|
155
|
+
"name": "--padding",
|
|
156
|
+
"default": "1.5rem",
|
|
157
|
+
"description": "Padding applied to the header, footer, and inline-padding of the body. Set to `0` to remove all internal spacing (e.g. for edge-to-edge media)."
|
|
158
|
+
},
|
|
159
|
+
{
|
|
160
|
+
"name": "--backdrop-blur",
|
|
161
|
+
"default": "0",
|
|
162
|
+
"description": "Backdrop blur amount (any CSS length). `0` means no blur; set e.g. `4px` for a subtle frost."
|
|
163
|
+
}
|
|
164
|
+
],
|
|
165
|
+
"commands": [
|
|
166
|
+
{
|
|
167
|
+
"name": "--show",
|
|
168
|
+
"description": "Sets `open = true`."
|
|
169
|
+
},
|
|
170
|
+
{
|
|
171
|
+
"name": "--hide",
|
|
172
|
+
"description": "Sets `open = false`."
|
|
173
|
+
}
|
|
174
|
+
],
|
|
175
|
+
"examples": []
|
|
176
|
+
}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "dropdown-item",
|
|
3
|
+
"displayName": "Dropdown item",
|
|
4
|
+
"type": "custom",
|
|
5
|
+
"isCustomElement": true,
|
|
6
|
+
"tag": "l-dropdown-item",
|
|
7
|
+
"nativeTag": null,
|
|
8
|
+
"selector": "l-dropdown-item",
|
|
9
|
+
"summary": "A menu item for use inside `<l-dropdown>`.",
|
|
10
|
+
"status": "stable",
|
|
11
|
+
"appearances": [],
|
|
12
|
+
"import": {
|
|
13
|
+
"css": null,
|
|
14
|
+
"js": "luxen-ui/dropdown-item"
|
|
15
|
+
},
|
|
16
|
+
"properties": [
|
|
17
|
+
{
|
|
18
|
+
"name": "value",
|
|
19
|
+
"attribute": "value",
|
|
20
|
+
"type": "string",
|
|
21
|
+
"default": "''",
|
|
22
|
+
"reflects": false,
|
|
23
|
+
"description": "The value associated with this item."
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
"name": "disabled",
|
|
27
|
+
"attribute": "disabled",
|
|
28
|
+
"type": "boolean",
|
|
29
|
+
"default": "false",
|
|
30
|
+
"reflects": true,
|
|
31
|
+
"description": "Disables the item."
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
"name": "type",
|
|
35
|
+
"attribute": "type",
|
|
36
|
+
"type": "'normal' | 'checkbox'",
|
|
37
|
+
"default": "'normal'",
|
|
38
|
+
"reflects": false,
|
|
39
|
+
"description": "The type of item: `normal` or `checkbox`."
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
"name": "checked",
|
|
43
|
+
"attribute": "checked",
|
|
44
|
+
"type": "boolean",
|
|
45
|
+
"default": "false",
|
|
46
|
+
"reflects": true,
|
|
47
|
+
"description": "Whether the checkbox item is checked."
|
|
48
|
+
}
|
|
49
|
+
],
|
|
50
|
+
"attributes": [],
|
|
51
|
+
"events": [],
|
|
52
|
+
"methods": [
|
|
53
|
+
{
|
|
54
|
+
"name": "getTextLabel",
|
|
55
|
+
"params": [],
|
|
56
|
+
"returns": "string",
|
|
57
|
+
"description": "Returns the text label of this item."
|
|
58
|
+
}
|
|
59
|
+
],
|
|
60
|
+
"slots": [
|
|
61
|
+
{
|
|
62
|
+
"name": "",
|
|
63
|
+
"description": "Label text."
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
"name": "prefix",
|
|
67
|
+
"description": "Leading content (e.g. icon)."
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
"name": "suffix",
|
|
71
|
+
"description": "Trailing content."
|
|
72
|
+
}
|
|
73
|
+
],
|
|
74
|
+
"cssClasses": [],
|
|
75
|
+
"cssParts": [],
|
|
76
|
+
"cssProperties": [
|
|
77
|
+
{
|
|
78
|
+
"name": "--color",
|
|
79
|
+
"default": null,
|
|
80
|
+
"description": "Text color."
|
|
81
|
+
}
|
|
82
|
+
],
|
|
83
|
+
"commands": [],
|
|
84
|
+
"examples": []
|
|
85
|
+
}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "dropdown",
|
|
3
|
+
"displayName": "Dropdown",
|
|
4
|
+
"type": "shadow",
|
|
5
|
+
"isCustomElement": true,
|
|
6
|
+
"tag": "l-dropdown",
|
|
7
|
+
"nativeTag": null,
|
|
8
|
+
"selector": "l-dropdown",
|
|
9
|
+
"summary": "A dropdown menu anchored to a trigger element.",
|
|
10
|
+
"status": "stable",
|
|
11
|
+
"appearances": [],
|
|
12
|
+
"import": {
|
|
13
|
+
"css": null,
|
|
14
|
+
"js": "luxen-ui/dropdown"
|
|
15
|
+
},
|
|
16
|
+
"properties": [
|
|
17
|
+
{
|
|
18
|
+
"name": "open",
|
|
19
|
+
"attribute": "open",
|
|
20
|
+
"type": "boolean",
|
|
21
|
+
"default": "false",
|
|
22
|
+
"reflects": true,
|
|
23
|
+
"description": "Whether the dropdown is open."
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
"name": "placement",
|
|
27
|
+
"attribute": "placement",
|
|
28
|
+
"type": "Placement",
|
|
29
|
+
"default": "'bottom-start'",
|
|
30
|
+
"reflects": false,
|
|
31
|
+
"description": "Preferred placement of the panel."
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
"name": "distance",
|
|
35
|
+
"attribute": "distance",
|
|
36
|
+
"type": "number",
|
|
37
|
+
"default": "4",
|
|
38
|
+
"reflects": false,
|
|
39
|
+
"description": "Distance in pixels from the trigger."
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
"name": "disabled",
|
|
43
|
+
"attribute": "disabled",
|
|
44
|
+
"type": "boolean",
|
|
45
|
+
"default": "false",
|
|
46
|
+
"reflects": true,
|
|
47
|
+
"description": "Disables the dropdown trigger."
|
|
48
|
+
}
|
|
49
|
+
],
|
|
50
|
+
"attributes": [],
|
|
51
|
+
"events": [
|
|
52
|
+
{
|
|
53
|
+
"name": "show",
|
|
54
|
+
"description": "Fired before the dropdown opens. Cancelable.",
|
|
55
|
+
"cancelable": true
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
"name": "after-show",
|
|
59
|
+
"description": "Fired after the open animation completes.",
|
|
60
|
+
"cancelable": false
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
"name": "hide",
|
|
64
|
+
"description": "Fired before the dropdown closes. Cancelable.",
|
|
65
|
+
"cancelable": true
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
"name": "after-hide",
|
|
69
|
+
"description": "Fired after the close animation completes.",
|
|
70
|
+
"cancelable": false
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
"name": "select",
|
|
74
|
+
"description": "Fired when an item is selected. Detail: `{ item: DropdownItem }`.",
|
|
75
|
+
"cancelable": false
|
|
76
|
+
}
|
|
77
|
+
],
|
|
78
|
+
"methods": [
|
|
79
|
+
{
|
|
80
|
+
"name": "show",
|
|
81
|
+
"params": [],
|
|
82
|
+
"returns": null,
|
|
83
|
+
"description": ""
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
"name": "hide",
|
|
87
|
+
"params": [],
|
|
88
|
+
"returns": null,
|
|
89
|
+
"description": ""
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
"name": "toggle",
|
|
93
|
+
"params": [],
|
|
94
|
+
"returns": null,
|
|
95
|
+
"description": ""
|
|
96
|
+
}
|
|
97
|
+
],
|
|
98
|
+
"slots": [
|
|
99
|
+
{
|
|
100
|
+
"name": "trigger",
|
|
101
|
+
"description": "The element that triggers the dropdown."
|
|
102
|
+
},
|
|
103
|
+
{
|
|
104
|
+
"name": "header",
|
|
105
|
+
"description": "Optional content rendered above the menu items (e.g. a user profile row). Use an `<l-divider>` (or `<hr>`) after it to separate from items."
|
|
106
|
+
},
|
|
107
|
+
{
|
|
108
|
+
"name": "",
|
|
109
|
+
"description": "Menu content (`l-dropdown-item` elements). Drop an `<l-divider>` (or `<hr>`) between items to render a section separator."
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
"name": "footer",
|
|
113
|
+
"description": "Optional content rendered below the menu items (e.g. a version label or shortcut row). Use an `<l-divider>` (or `<hr>`) before it to separate from items."
|
|
114
|
+
}
|
|
115
|
+
],
|
|
116
|
+
"cssClasses": [],
|
|
117
|
+
"cssParts": [
|
|
118
|
+
{
|
|
119
|
+
"name": "panel",
|
|
120
|
+
"description": "The floating menu container."
|
|
121
|
+
}
|
|
122
|
+
],
|
|
123
|
+
"cssProperties": [
|
|
124
|
+
{
|
|
125
|
+
"name": "--background",
|
|
126
|
+
"default": null,
|
|
127
|
+
"description": "Panel background color."
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
"name": "--border-radius",
|
|
131
|
+
"default": "8px",
|
|
132
|
+
"description": "Panel border radius."
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
"name": "--padding",
|
|
136
|
+
"default": "0.25rem",
|
|
137
|
+
"description": "Panel inner padding. Slotted `<l-divider>` elements bleed by this amount on each side to span the panel edges."
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
"name": "--shadow",
|
|
141
|
+
"default": null,
|
|
142
|
+
"description": "Panel box shadow."
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
"name": "--show-duration",
|
|
146
|
+
"default": "150",
|
|
147
|
+
"description": "Show animation duration in ms."
|
|
148
|
+
},
|
|
149
|
+
{
|
|
150
|
+
"name": "--hide-duration",
|
|
151
|
+
"default": "150",
|
|
152
|
+
"description": "Hide animation duration in ms."
|
|
153
|
+
}
|
|
154
|
+
],
|
|
155
|
+
"commands": [],
|
|
156
|
+
"examples": []
|
|
157
|
+
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "icon",
|
|
3
|
+
"displayName": "Icon",
|
|
4
|
+
"type": "shadow",
|
|
5
|
+
"isCustomElement": true,
|
|
6
|
+
"tag": "l-icon",
|
|
7
|
+
"nativeTag": null,
|
|
8
|
+
"selector": "l-icon",
|
|
9
|
+
"summary": "An icon component that renders icons from any Iconify icon set. Decorative by default. Set `label` for meaningful icons.",
|
|
10
|
+
"status": "stable",
|
|
11
|
+
"appearances": [],
|
|
12
|
+
"import": {
|
|
13
|
+
"css": null,
|
|
14
|
+
"js": "luxen-ui/icon"
|
|
15
|
+
},
|
|
16
|
+
"properties": [
|
|
17
|
+
{
|
|
18
|
+
"name": "name",
|
|
19
|
+
"attribute": "name",
|
|
20
|
+
"type": "string",
|
|
21
|
+
"default": "''",
|
|
22
|
+
"reflects": false,
|
|
23
|
+
"description": "The icon name in Iconify format (e.g. `mdi:home`, `lucide:check`)."
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
"name": "label",
|
|
27
|
+
"attribute": "label",
|
|
28
|
+
"type": "string | undefined",
|
|
29
|
+
"default": null,
|
|
30
|
+
"reflects": false,
|
|
31
|
+
"description": "Accessible label. When set, the icon becomes meaningful (`role=\"img\"` + `aria-label`). When absent, the icon is decorative."
|
|
32
|
+
}
|
|
33
|
+
],
|
|
34
|
+
"attributes": [],
|
|
35
|
+
"events": [],
|
|
36
|
+
"methods": [],
|
|
37
|
+
"slots": [],
|
|
38
|
+
"cssClasses": [],
|
|
39
|
+
"cssParts": [],
|
|
40
|
+
"cssProperties": [
|
|
41
|
+
{
|
|
42
|
+
"name": "--color",
|
|
43
|
+
"default": "currentColor",
|
|
44
|
+
"description": "The color of the icon."
|
|
45
|
+
}
|
|
46
|
+
],
|
|
47
|
+
"commands": [],
|
|
48
|
+
"examples": []
|
|
49
|
+
}
|