@rogieking/figui3 1.0.95 → 1.0.97
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/bun.lockb +0 -0
- package/example.html +4 -0
- package/fig.css +52 -6
- package/fig.js +26 -17
- package/index.ts +1 -0
- package/package.json +12 -1
- package/tsconfig.json +27 -0
package/bun.lockb
ADDED
|
Binary file
|
package/example.html
CHANGED
|
@@ -18,6 +18,9 @@
|
|
|
18
18
|
</fig-header>
|
|
19
19
|
<h2>Heading 2</h2>
|
|
20
20
|
<h3>Heading 3</h3>
|
|
21
|
+
<form onsubmit="console.log('submit'); return false;">
|
|
22
|
+
<fig-button type="submit">Submit</fig-button>
|
|
23
|
+
</form>
|
|
21
24
|
<br />
|
|
22
25
|
<fig-button id="button-progressive-blur"
|
|
23
26
|
variant="ghost"
|
|
@@ -64,6 +67,7 @@
|
|
|
64
67
|
<fig-slider min="0"
|
|
65
68
|
max="1"
|
|
66
69
|
transform="100"
|
|
70
|
+
variant="minimal"
|
|
67
71
|
step="0.01"
|
|
68
72
|
text="true"
|
|
69
73
|
style="width:300px;"
|
package/fig.css
CHANGED
|
@@ -1430,6 +1430,7 @@ details {
|
|
|
1430
1430
|
.fig-slider,
|
|
1431
1431
|
fig-slider {
|
|
1432
1432
|
--slider-height: 1rem;
|
|
1433
|
+
--slider-thumb-size: var(--slider-height);
|
|
1433
1434
|
--slider-percent: calc(var(--slider-complete) * 100%);
|
|
1434
1435
|
--start-percent: calc(var(--default, 0) * 100%);
|
|
1435
1436
|
--slider-tick-size: calc(var(--slider-height) / 4);
|
|
@@ -1560,9 +1561,10 @@ fig-slider {
|
|
|
1560
1561
|
&::-webkit-slider-thumb {
|
|
1561
1562
|
appearance: none;
|
|
1562
1563
|
-webkit-appearance: none;
|
|
1563
|
-
border-radius:
|
|
1564
|
-
height: var(--slider-
|
|
1565
|
-
width: var(--slider-
|
|
1564
|
+
border-radius: 100%;
|
|
1565
|
+
height: var(--slider-thumb-size);
|
|
1566
|
+
width: var(--slider-thumb-size);
|
|
1567
|
+
margin-top: calc(var(--slider-height) / 2 - var(--slider-thumb-size) / 2);
|
|
1566
1568
|
aspect-ratio: 1;
|
|
1567
1569
|
border: none;
|
|
1568
1570
|
position: relative;
|
|
@@ -1628,9 +1630,9 @@ fig-slider {
|
|
|
1628
1630
|
|
|
1629
1631
|
&::-moz-range-thumb {
|
|
1630
1632
|
appearance: none;
|
|
1631
|
-
border-radius:
|
|
1632
|
-
height: var(--slider-
|
|
1633
|
-
width: var(--slider-
|
|
1633
|
+
border-radius: 100%;
|
|
1634
|
+
height: var(--slider-thumb-size);
|
|
1635
|
+
width: var(--slider-thumb-size);
|
|
1634
1636
|
aspect-ratio: 1;
|
|
1635
1637
|
border: none;
|
|
1636
1638
|
position: relative;
|
|
@@ -1707,8 +1709,52 @@ fig-slider {
|
|
|
1707
1709
|
}
|
|
1708
1710
|
}
|
|
1709
1711
|
}
|
|
1712
|
+
&[variant="minimal"]{
|
|
1713
|
+
transition: all 0.2s ease-in-out;
|
|
1714
|
+
}
|
|
1715
|
+
&[variant="minimal"] {
|
|
1716
|
+
--slider-height: 0.25rem;
|
|
1717
|
+
--slider-thumb-size: 0.5rem;
|
|
1718
|
+
height: 1.5rem;
|
|
1719
|
+
.fig-slider-input-container {
|
|
1720
|
+
height: var(--slider-height);
|
|
1721
|
+
position: relative;
|
|
1722
|
+
display: block;
|
|
1723
|
+
width: 100%;
|
|
1724
|
+
|
|
1725
|
+
/* Track */
|
|
1726
|
+
&::before {
|
|
1727
|
+
box-shadow: none;
|
|
1728
|
+
background: var(--figma-color-text-onbrand-tertiary);
|
|
1729
|
+
}
|
|
1730
|
+
|
|
1731
|
+
input[type="range"] {
|
|
1732
|
+
&::-webkit-slider-runnable-track {
|
|
1733
|
+
box-shadow: none;
|
|
1734
|
+
}
|
|
1735
|
+
}
|
|
1736
|
+
}
|
|
1737
|
+
fig-input-text {
|
|
1738
|
+
height: calc(var(--slider-height) * 2);
|
|
1739
|
+
background-color: transparent;
|
|
1740
|
+
}
|
|
1741
|
+
&:hover,
|
|
1742
|
+
&:focus-within {
|
|
1743
|
+
--slider-height: 1rem;
|
|
1744
|
+
--slider-thumb-size: 1rem;
|
|
1745
|
+
.fig-slider-input-container {
|
|
1746
|
+
&::before {
|
|
1747
|
+
background: var(--figma-color-bg-brand);
|
|
1748
|
+
}
|
|
1749
|
+
}
|
|
1750
|
+
fig-input-text {
|
|
1751
|
+
height: auto;
|
|
1752
|
+
}
|
|
1753
|
+
}
|
|
1754
|
+
}
|
|
1710
1755
|
}
|
|
1711
1756
|
|
|
1757
|
+
|
|
1712
1758
|
/* Popovers/Dialogs */
|
|
1713
1759
|
.dialog,
|
|
1714
1760
|
dialog,
|
package/fig.js
CHANGED
|
@@ -8,14 +8,14 @@ function supportsPopover() {
|
|
|
8
8
|
if (window.customElements && !window.customElements.get("fig-button")) {
|
|
9
9
|
/* Button */
|
|
10
10
|
class FigButton extends HTMLElement {
|
|
11
|
-
|
|
11
|
+
type;
|
|
12
12
|
#selected;
|
|
13
13
|
constructor() {
|
|
14
14
|
super();
|
|
15
15
|
this.attachShadow({ mode: "open" });
|
|
16
16
|
}
|
|
17
17
|
connectedCallback() {
|
|
18
|
-
this
|
|
18
|
+
this.type = this.getAttribute("type") || "button";
|
|
19
19
|
this.shadowRoot.innerHTML = `
|
|
20
20
|
<style>
|
|
21
21
|
button, button:hover, button:active {
|
|
@@ -36,7 +36,7 @@ if (window.customElements && !window.customElements.get("fig-button")) {
|
|
|
36
36
|
height: var(--spacer-4);
|
|
37
37
|
}
|
|
38
38
|
</style>
|
|
39
|
-
<button type="${this
|
|
39
|
+
<button type="${this.type}">
|
|
40
40
|
<slot></slot>
|
|
41
41
|
</button>
|
|
42
42
|
`;
|
|
@@ -44,45 +44,54 @@ if (window.customElements && !window.customElements.get("fig-button")) {
|
|
|
44
44
|
this.#selected =
|
|
45
45
|
this.hasAttribute("selected") &&
|
|
46
46
|
this.getAttribute("selected") !== "false";
|
|
47
|
-
this.addEventListener("click", this.#handleClick.bind(this));
|
|
48
47
|
|
|
49
48
|
requestAnimationFrame(() => {
|
|
50
|
-
this.button = this.querySelector("button");
|
|
49
|
+
this.button = this.shadowRoot.querySelector("button");
|
|
50
|
+
this.button.addEventListener("click", this.#handleClick.bind(this));
|
|
51
51
|
});
|
|
52
52
|
}
|
|
53
53
|
|
|
54
54
|
get type() {
|
|
55
|
-
return this
|
|
55
|
+
return this.type;
|
|
56
56
|
}
|
|
57
57
|
set type(value) {
|
|
58
|
-
this.#type = value;
|
|
59
|
-
this.button.type = value;
|
|
60
58
|
this.setAttribute("type", value);
|
|
61
59
|
}
|
|
62
60
|
get selected() {
|
|
63
61
|
return this.#selected;
|
|
64
62
|
}
|
|
65
63
|
set selected(value) {
|
|
66
|
-
this.#selected = value;
|
|
67
64
|
this.setAttribute("selected", value);
|
|
68
65
|
}
|
|
69
66
|
|
|
70
|
-
#handleClick(
|
|
71
|
-
if (this
|
|
72
|
-
this.selected
|
|
67
|
+
#handleClick() {
|
|
68
|
+
if (this.type === "toggle") {
|
|
69
|
+
this.toggleAttribute("selected", !this.hasAttribute("selected"));
|
|
73
70
|
}
|
|
74
|
-
if (this
|
|
75
|
-
this.
|
|
71
|
+
if (this.type === "submit") {
|
|
72
|
+
this.closest("form").dispatchEvent(new Event("submit"));
|
|
76
73
|
}
|
|
77
74
|
}
|
|
78
75
|
static get observedAttributes() {
|
|
79
|
-
return ["disabled"];
|
|
76
|
+
return ["disabled", "selected"];
|
|
80
77
|
}
|
|
81
78
|
attributeChangedCallback(name, oldValue, newValue) {
|
|
82
79
|
if (this.button) {
|
|
83
80
|
this.button[name] = newValue;
|
|
84
|
-
|
|
85
|
-
|
|
81
|
+
switch (name) {
|
|
82
|
+
case "disabled":
|
|
83
|
+
this.disabled = this.button.disabled =
|
|
84
|
+
newValue === "true" ||
|
|
85
|
+
(newValue === undefined && newValue !== null);
|
|
86
|
+
break;
|
|
87
|
+
case "type":
|
|
88
|
+
this.type = newValue;
|
|
89
|
+
this.button.type = this.type;
|
|
90
|
+
this.button.setAttribute("type", this.type);
|
|
91
|
+
break;
|
|
92
|
+
case "selected":
|
|
93
|
+
this.#selected = newValue === "true";
|
|
94
|
+
break;
|
|
86
95
|
}
|
|
87
96
|
}
|
|
88
97
|
}
|
package/index.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
console.log("Hello via Bun!");
|
package/package.json
CHANGED
|
@@ -1,4 +1,15 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rogieking/figui3",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.97",
|
|
4
|
+
"module": "index.ts",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"devDependencies": {
|
|
7
|
+
"@types/bun": "latest"
|
|
8
|
+
},
|
|
9
|
+
"peerDependencies": {
|
|
10
|
+
"typescript": "^5.0.0"
|
|
11
|
+
},
|
|
12
|
+
"scripts": {
|
|
13
|
+
"build": "bun build fig.js --minify --outdir dist"
|
|
14
|
+
}
|
|
4
15
|
}
|
package/tsconfig.json
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
// Enable latest features
|
|
4
|
+
"lib": ["ESNext", "DOM"],
|
|
5
|
+
"target": "ESNext",
|
|
6
|
+
"module": "ESNext",
|
|
7
|
+
"moduleDetection": "force",
|
|
8
|
+
"jsx": "react-jsx",
|
|
9
|
+
"allowJs": true,
|
|
10
|
+
|
|
11
|
+
// Bundler mode
|
|
12
|
+
"moduleResolution": "bundler",
|
|
13
|
+
"allowImportingTsExtensions": true,
|
|
14
|
+
"verbatimModuleSyntax": true,
|
|
15
|
+
"noEmit": true,
|
|
16
|
+
|
|
17
|
+
// Best practices
|
|
18
|
+
"strict": true,
|
|
19
|
+
"skipLibCheck": true,
|
|
20
|
+
"noFallthroughCasesInSwitch": true,
|
|
21
|
+
|
|
22
|
+
// Some stricter flags (disabled by default)
|
|
23
|
+
"noUnusedLocals": false,
|
|
24
|
+
"noUnusedParameters": false,
|
|
25
|
+
"noPropertyAccessFromIndexSignature": false
|
|
26
|
+
}
|
|
27
|
+
}
|