@hanzogui/button 2.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/LICENSE +21 -0
- package/dist/cjs/Button.cjs +218 -0
- package/dist/cjs/Button.native.js +224 -0
- package/dist/cjs/Button.native.js.map +1 -0
- package/dist/cjs/Button.test.cjs +36 -0
- package/dist/cjs/Button.test.native.js +39 -0
- package/dist/cjs/Button.test.native.js.map +1 -0
- package/dist/cjs/index.cjs +18 -0
- package/dist/cjs/index.native.js +21 -0
- package/dist/cjs/index.native.js.map +1 -0
- package/dist/cjs/v1/Button.cjs +259 -0
- package/dist/cjs/v1/Button.native.js +265 -0
- package/dist/cjs/v1/Button.native.js.map +1 -0
- package/dist/cjs/v1/Button.test.cjs +9 -0
- package/dist/cjs/v1/Button.test.native.js +12 -0
- package/dist/cjs/v1/Button.test.native.js.map +1 -0
- package/dist/cjs/v1/index.cjs +18 -0
- package/dist/cjs/v1/index.native.js +21 -0
- package/dist/cjs/v1/index.native.js.map +1 -0
- package/dist/esm/Button.mjs +194 -0
- package/dist/esm/Button.mjs.map +1 -0
- package/dist/esm/Button.native.js +197 -0
- package/dist/esm/Button.native.js.map +1 -0
- package/dist/esm/Button.test.mjs +37 -0
- package/dist/esm/Button.test.mjs.map +1 -0
- package/dist/esm/Button.test.native.js +37 -0
- package/dist/esm/Button.test.native.js.map +1 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/index.mjs +2 -0
- package/dist/esm/index.mjs.map +1 -0
- package/dist/esm/index.native.js +2 -0
- package/dist/esm/index.native.js.map +1 -0
- package/dist/esm/v1/Button.mjs +231 -0
- package/dist/esm/v1/Button.mjs.map +1 -0
- package/dist/esm/v1/Button.native.js +234 -0
- package/dist/esm/v1/Button.native.js.map +1 -0
- package/dist/esm/v1/Button.test.mjs +10 -0
- package/dist/esm/v1/Button.test.mjs.map +1 -0
- package/dist/esm/v1/Button.test.native.js +10 -0
- package/dist/esm/v1/Button.test.native.js.map +1 -0
- package/dist/esm/v1/index.mjs +2 -0
- package/dist/esm/v1/index.mjs.map +1 -0
- package/dist/esm/v1/index.native.js +2 -0
- package/dist/esm/v1/index.native.js.map +1 -0
- package/dist/jsx/Button.mjs +194 -0
- package/dist/jsx/Button.mjs.map +1 -0
- package/dist/jsx/Button.native.js +224 -0
- package/dist/jsx/Button.native.js.map +1 -0
- package/dist/jsx/Button.test.mjs +37 -0
- package/dist/jsx/Button.test.mjs.map +1 -0
- package/dist/jsx/Button.test.native.js +39 -0
- package/dist/jsx/Button.test.native.js.map +1 -0
- package/dist/jsx/index.js +2 -0
- package/dist/jsx/index.js.map +1 -0
- package/dist/jsx/index.mjs +2 -0
- package/dist/jsx/index.mjs.map +1 -0
- package/dist/jsx/index.native.js +21 -0
- package/dist/jsx/index.native.js.map +1 -0
- package/dist/jsx/v1/Button.mjs +231 -0
- package/dist/jsx/v1/Button.mjs.map +1 -0
- package/dist/jsx/v1/Button.native.js +265 -0
- package/dist/jsx/v1/Button.native.js.map +1 -0
- package/dist/jsx/v1/Button.test.mjs +10 -0
- package/dist/jsx/v1/Button.test.mjs.map +1 -0
- package/dist/jsx/v1/Button.test.native.js +12 -0
- package/dist/jsx/v1/Button.test.native.js.map +1 -0
- package/dist/jsx/v1/index.mjs +2 -0
- package/dist/jsx/v1/index.mjs.map +1 -0
- package/dist/jsx/v1/index.native.js +21 -0
- package/dist/jsx/v1/index.native.js.map +1 -0
- package/package.json +59 -0
- package/src/Button.test.tsx +45 -0
- package/src/Button.tsx +272 -0
- package/src/index.ts +1 -0
- package/src/v1/Button.test.tsx +21 -0
- package/src/v1/Button.tsx +336 -0
- package/src/v1/index.ts +1 -0
- package/types/Button.d.ts +123 -0
- package/types/Button.test.d.ts +2 -0
- package/types/index.d.ts +2 -0
- package/types/v1/Button.d.ts +302 -0
- package/types/v1/Button.test.d.ts +2 -0
- package/types/v1/index.d.ts +2 -0
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
import { getFontSize } from "@hanzo/gui-font-size";
|
|
2
|
+
import { getButtonSized } from "@hanzo/gui-get-button-sized";
|
|
3
|
+
import { getIcon, useCurrentColor } from "@hanzo/gui-helpers";
|
|
4
|
+
import { ButtonNestingContext, getElevation, themeableVariants } from "@hanzo/gui-stacks";
|
|
5
|
+
import { SizableText, wrapChildrenInText } from "@hanzo/gui-text";
|
|
6
|
+
import { createStyledContext, getTokenValue, styled, useProps, View, withStaticProperties } from "@hanzo/gui-web";
|
|
7
|
+
import { useContext } from "react";
|
|
8
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
9
|
+
const context = createStyledContext({
|
|
10
|
+
size: void 0,
|
|
11
|
+
variant: void 0,
|
|
12
|
+
color: void 0,
|
|
13
|
+
elevation: void 0
|
|
14
|
+
}),
|
|
15
|
+
Frame = styled(View, {
|
|
16
|
+
context,
|
|
17
|
+
name: "Button",
|
|
18
|
+
role: "button",
|
|
19
|
+
render: /* @__PURE__ */jsx("button", {
|
|
20
|
+
type: "button"
|
|
21
|
+
}),
|
|
22
|
+
tabIndex: 0,
|
|
23
|
+
variants: {
|
|
24
|
+
unstyled: {
|
|
25
|
+
false: {
|
|
26
|
+
size: "$true",
|
|
27
|
+
justifyContent: "center",
|
|
28
|
+
alignItems: "center",
|
|
29
|
+
flexWrap: "nowrap",
|
|
30
|
+
flexDirection: "row",
|
|
31
|
+
cursor: "pointer",
|
|
32
|
+
backgroundColor: "$background",
|
|
33
|
+
borderWidth: 1,
|
|
34
|
+
borderColor: "transparent",
|
|
35
|
+
hoverStyle: {
|
|
36
|
+
backgroundColor: "$backgroundHover",
|
|
37
|
+
borderColor: "$borderColorHover"
|
|
38
|
+
},
|
|
39
|
+
pressStyle: {
|
|
40
|
+
backgroundColor: "$backgroundPress",
|
|
41
|
+
borderColor: "$borderColorHover"
|
|
42
|
+
},
|
|
43
|
+
focusVisibleStyle: {
|
|
44
|
+
outlineColor: "$outlineColor",
|
|
45
|
+
outlineStyle: "solid",
|
|
46
|
+
outlineWidth: 2
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
variant: {
|
|
51
|
+
outlined: process.env.HANZO_GUI_HEADLESS === "1" ? {} : {
|
|
52
|
+
backgroundColor: "transparent",
|
|
53
|
+
borderWidth: 1,
|
|
54
|
+
borderColor: "$borderColor",
|
|
55
|
+
hoverStyle: {
|
|
56
|
+
backgroundColor: "transparent",
|
|
57
|
+
borderColor: "$borderColorHover"
|
|
58
|
+
},
|
|
59
|
+
pressStyle: {
|
|
60
|
+
backgroundColor: "transparent",
|
|
61
|
+
borderColor: "$borderColorPress"
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
circular: themeableVariants.circular,
|
|
66
|
+
chromeless: themeableVariants.chromeless,
|
|
67
|
+
size: {
|
|
68
|
+
"...size": (val, extras) => {
|
|
69
|
+
const buttonStyle = getButtonSized(val, extras),
|
|
70
|
+
gap = getTokenValue(val);
|
|
71
|
+
return {
|
|
72
|
+
...buttonStyle,
|
|
73
|
+
gap
|
|
74
|
+
};
|
|
75
|
+
},
|
|
76
|
+
":number": (val, extras) => {
|
|
77
|
+
const buttonStyle = getButtonSized(val, extras),
|
|
78
|
+
gap = val * 0.4;
|
|
79
|
+
return {
|
|
80
|
+
...buttonStyle,
|
|
81
|
+
gap
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
},
|
|
85
|
+
elevation: {
|
|
86
|
+
"...size": getElevation,
|
|
87
|
+
":number": getElevation
|
|
88
|
+
},
|
|
89
|
+
disabled: {
|
|
90
|
+
true: {
|
|
91
|
+
pointerEvents: "none",
|
|
92
|
+
// @ts-ignore
|
|
93
|
+
"aria-disabled": !0
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
},
|
|
97
|
+
defaultVariants: {
|
|
98
|
+
unstyled: process.env.HANZO_GUI_HEADLESS === "1"
|
|
99
|
+
}
|
|
100
|
+
}),
|
|
101
|
+
Text = styled(SizableText, {
|
|
102
|
+
context,
|
|
103
|
+
variants: {
|
|
104
|
+
unstyled: {
|
|
105
|
+
false: {
|
|
106
|
+
userSelect: "none",
|
|
107
|
+
cursor: "pointer",
|
|
108
|
+
// flexGrow 1 leads to inconsistent native style where text pushes to start of view
|
|
109
|
+
flexGrow: 0,
|
|
110
|
+
flexShrink: 1,
|
|
111
|
+
ellipsis: !0,
|
|
112
|
+
color: "$color"
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
},
|
|
116
|
+
defaultVariants: {
|
|
117
|
+
unstyled: process.env.HANZO_GUI_HEADLESS === "1"
|
|
118
|
+
}
|
|
119
|
+
}),
|
|
120
|
+
Icon = props => {
|
|
121
|
+
const {
|
|
122
|
+
children,
|
|
123
|
+
scaleIcon = 1,
|
|
124
|
+
size
|
|
125
|
+
} = props,
|
|
126
|
+
styledContext = context.useStyledContext();
|
|
127
|
+
if (!styledContext) throw new Error("Button.Icon must be used within a Button");
|
|
128
|
+
const sizeToken = size ?? styledContext.size,
|
|
129
|
+
iconColor = useCurrentColor(styledContext.color),
|
|
130
|
+
iconSize = (typeof sizeToken == "number" ? sizeToken * 0.5 : getFontSize(sizeToken)) * scaleIcon;
|
|
131
|
+
return getIcon(children, {
|
|
132
|
+
size: iconSize,
|
|
133
|
+
color: iconColor
|
|
134
|
+
});
|
|
135
|
+
},
|
|
136
|
+
ButtonContext = createStyledContext({
|
|
137
|
+
size: void 0,
|
|
138
|
+
variant: void 0,
|
|
139
|
+
color: void 0
|
|
140
|
+
}),
|
|
141
|
+
ButtonComponent = Frame.styleable((propsIn, ref) => {
|
|
142
|
+
const isNested = useContext(ButtonNestingContext),
|
|
143
|
+
processedProps = useProps(propsIn, {
|
|
144
|
+
noNormalize: !0,
|
|
145
|
+
noExpand: !0
|
|
146
|
+
}),
|
|
147
|
+
{
|
|
148
|
+
children,
|
|
149
|
+
iconSize,
|
|
150
|
+
icon,
|
|
151
|
+
iconAfter,
|
|
152
|
+
scaleIcon = 1,
|
|
153
|
+
...props
|
|
154
|
+
} = processedProps,
|
|
155
|
+
size = propsIn.size || (propsIn.unstyled ? void 0 : "$true"),
|
|
156
|
+
styledContext = context.useStyledContext(),
|
|
157
|
+
iconColor = useCurrentColor(styledContext?.color),
|
|
158
|
+
finalSize = iconSize ?? size ?? styledContext?.size,
|
|
159
|
+
iconSizeNumber = (typeof finalSize == "number" ? finalSize * 0.5 : getFontSize(finalSize)) * scaleIcon,
|
|
160
|
+
[themedIcon, themedIconAfter] = [icon, iconAfter].map(icon2 => icon2 ? getIcon(icon2, {
|
|
161
|
+
size: iconSizeNumber,
|
|
162
|
+
color: iconColor
|
|
163
|
+
// No marginLeft or marginRight needed - spacing is handled by the gap property in Frame's size variants
|
|
164
|
+
}) : null),
|
|
165
|
+
wrappedChildren = wrapChildrenInText(Text, {
|
|
166
|
+
children
|
|
167
|
+
}, {
|
|
168
|
+
unstyled: process.env.HANZO_GUI_HEADLESS === "1",
|
|
169
|
+
size: finalSize ?? styledContext?.size
|
|
170
|
+
});
|
|
171
|
+
return /* @__PURE__ */jsx(ButtonNestingContext.Provider, {
|
|
172
|
+
value: !0,
|
|
173
|
+
children: /* @__PURE__ */jsxs(Frame, {
|
|
174
|
+
ref,
|
|
175
|
+
...props,
|
|
176
|
+
...(isNested && {
|
|
177
|
+
render: "span"
|
|
178
|
+
}),
|
|
179
|
+
...(props.circular && !propsIn.size && {
|
|
180
|
+
size
|
|
181
|
+
}),
|
|
182
|
+
tabIndex: 0,
|
|
183
|
+
children: [themedIcon, wrappedChildren, themedIconAfter]
|
|
184
|
+
})
|
|
185
|
+
});
|
|
186
|
+
}),
|
|
187
|
+
Button = withStaticProperties(ButtonComponent, {
|
|
188
|
+
Apply: context.Provider,
|
|
189
|
+
Frame,
|
|
190
|
+
Text,
|
|
191
|
+
Icon
|
|
192
|
+
});
|
|
193
|
+
export { Button, ButtonContext };
|
|
194
|
+
//# sourceMappingURL=Button.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["getFontSize","getButtonSized","getIcon","useCurrentColor","ButtonNestingContext","getElevation","themeableVariants","SizableText","wrapChildrenInText","createStyledContext","getTokenValue","styled","useProps","View","withStaticProperties","useContext","jsx","jsxs","context","size","variant","color","elevation","Frame","name","role","render","type","tabIndex","variants","unstyled","false","justifyContent","alignItems","flexWrap","flexDirection","cursor","backgroundColor","borderWidth","borderColor","hoverStyle","pressStyle","focusVisibleStyle","outlineColor","outlineStyle","outlineWidth","outlined","process","env","HANZO_GUI_HEADLESS","circular","chromeless","...size","val","extras","buttonStyle","gap",":number","disabled","true","pointerEvents","defaultVariants","Text","userSelect","flexGrow","flexShrink","ellipsis","Icon","props","children","scaleIcon","styledContext","useStyledContext","Error","sizeToken","iconColor","iconSize","ButtonContext","ButtonComponent","styleable","propsIn","ref","isNested","processedProps","noNormalize","noExpand","icon","iconAfter","finalSize","iconSizeNumber","themedIcon","themedIconAfter","map","icon2","wrappedChildren","Provider","value","Button","Apply"],"sources":["../../src/Button.tsx"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all) __defProp(target, name, {
|
|
9
|
+
get: all[name],
|
|
10
|
+
enumerable: !0
|
|
11
|
+
});
|
|
12
|
+
},
|
|
13
|
+
__copyProps = (to, from, except, desc) => {
|
|
14
|
+
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
|
|
15
|
+
get: () => from[key],
|
|
16
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
17
|
+
});
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
|
|
21
|
+
value: !0
|
|
22
|
+
}), mod);
|
|
23
|
+
var Button_exports = {};
|
|
24
|
+
__export(Button_exports, {
|
|
25
|
+
Button: () => Button,
|
|
26
|
+
ButtonContext: () => ButtonContext
|
|
27
|
+
});
|
|
28
|
+
module.exports = __toCommonJS(Button_exports);
|
|
29
|
+
var import_jsx_runtime = require("react/jsx-runtime"),
|
|
30
|
+
import_gui_font_size = require("@hanzo/gui-font-size"),
|
|
31
|
+
import_gui_get_button_sized = require("@hanzo/gui-get-button-sized"),
|
|
32
|
+
import_gui_helpers = require("@hanzo/gui-helpers"),
|
|
33
|
+
import_gui_stacks = require("@hanzo/gui-stacks"),
|
|
34
|
+
import_gui_text = require("@hanzo/gui-text"),
|
|
35
|
+
import_gui_web = require("@hanzo/gui-web"),
|
|
36
|
+
import_react = require("react"),
|
|
37
|
+
context = (0, import_gui_web.createStyledContext)({
|
|
38
|
+
size: void 0,
|
|
39
|
+
variant: void 0,
|
|
40
|
+
color: void 0,
|
|
41
|
+
elevation: void 0
|
|
42
|
+
}),
|
|
43
|
+
Frame = (0, import_gui_web.styled)(import_gui_web.View, {
|
|
44
|
+
context,
|
|
45
|
+
name: "Button",
|
|
46
|
+
role: "button",
|
|
47
|
+
render: /* @__PURE__ */(0, import_jsx_runtime.jsx)("button", {
|
|
48
|
+
type: "button"
|
|
49
|
+
}),
|
|
50
|
+
tabIndex: 0,
|
|
51
|
+
variants: {
|
|
52
|
+
unstyled: {
|
|
53
|
+
false: {
|
|
54
|
+
size: "$true",
|
|
55
|
+
justifyContent: "center",
|
|
56
|
+
alignItems: "center",
|
|
57
|
+
flexWrap: "nowrap",
|
|
58
|
+
flexDirection: "row",
|
|
59
|
+
cursor: "pointer",
|
|
60
|
+
backgroundColor: "$background",
|
|
61
|
+
borderWidth: 1,
|
|
62
|
+
borderColor: "transparent",
|
|
63
|
+
hoverStyle: {
|
|
64
|
+
backgroundColor: "$backgroundHover",
|
|
65
|
+
borderColor: "$borderColorHover"
|
|
66
|
+
},
|
|
67
|
+
pressStyle: {
|
|
68
|
+
backgroundColor: "$backgroundPress",
|
|
69
|
+
borderColor: "$borderColorHover"
|
|
70
|
+
},
|
|
71
|
+
focusVisibleStyle: {
|
|
72
|
+
outlineColor: "$outlineColor",
|
|
73
|
+
outlineStyle: "solid",
|
|
74
|
+
outlineWidth: 2
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
variant: {
|
|
79
|
+
outlined: process.env.HANZO_GUI_HEADLESS === "1" ? {} : {
|
|
80
|
+
backgroundColor: "transparent",
|
|
81
|
+
borderWidth: 1,
|
|
82
|
+
borderColor: "$borderColor",
|
|
83
|
+
hoverStyle: {
|
|
84
|
+
backgroundColor: "transparent",
|
|
85
|
+
borderColor: "$borderColorHover"
|
|
86
|
+
},
|
|
87
|
+
pressStyle: {
|
|
88
|
+
backgroundColor: "transparent",
|
|
89
|
+
borderColor: "$borderColorPress"
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
},
|
|
93
|
+
circular: import_gui_stacks.themeableVariants.circular,
|
|
94
|
+
chromeless: import_gui_stacks.themeableVariants.chromeless,
|
|
95
|
+
size: {
|
|
96
|
+
"...size": function (val, extras) {
|
|
97
|
+
var buttonStyle = (0, import_gui_get_button_sized.getButtonSized)(val, extras),
|
|
98
|
+
gap = (0, import_gui_web.getTokenValue)(val);
|
|
99
|
+
return {
|
|
100
|
+
...buttonStyle,
|
|
101
|
+
gap
|
|
102
|
+
};
|
|
103
|
+
},
|
|
104
|
+
":number": function (val, extras) {
|
|
105
|
+
var buttonStyle = (0, import_gui_get_button_sized.getButtonSized)(val, extras),
|
|
106
|
+
gap = val * 0.4;
|
|
107
|
+
return {
|
|
108
|
+
...buttonStyle,
|
|
109
|
+
gap
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
},
|
|
113
|
+
elevation: {
|
|
114
|
+
"...size": import_gui_stacks.getElevation,
|
|
115
|
+
":number": import_gui_stacks.getElevation
|
|
116
|
+
},
|
|
117
|
+
disabled: {
|
|
118
|
+
true: {
|
|
119
|
+
pointerEvents: "none",
|
|
120
|
+
// @ts-ignore
|
|
121
|
+
"aria-disabled": !0
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
},
|
|
125
|
+
defaultVariants: {
|
|
126
|
+
unstyled: process.env.HANZO_GUI_HEADLESS === "1"
|
|
127
|
+
}
|
|
128
|
+
}),
|
|
129
|
+
Text = (0, import_gui_web.styled)(import_gui_text.SizableText, {
|
|
130
|
+
context,
|
|
131
|
+
variants: {
|
|
132
|
+
unstyled: {
|
|
133
|
+
false: {
|
|
134
|
+
userSelect: "none",
|
|
135
|
+
cursor: "pointer",
|
|
136
|
+
// flexGrow 1 leads to inconsistent native style where text pushes to start of view
|
|
137
|
+
flexGrow: 0,
|
|
138
|
+
flexShrink: 1,
|
|
139
|
+
ellipsis: !0,
|
|
140
|
+
color: "$color"
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
},
|
|
144
|
+
defaultVariants: {
|
|
145
|
+
unstyled: process.env.HANZO_GUI_HEADLESS === "1"
|
|
146
|
+
}
|
|
147
|
+
}),
|
|
148
|
+
Icon = function (props) {
|
|
149
|
+
var {
|
|
150
|
+
children,
|
|
151
|
+
scaleIcon = 1,
|
|
152
|
+
size
|
|
153
|
+
} = props,
|
|
154
|
+
styledContext = context.useStyledContext();
|
|
155
|
+
if (!styledContext) throw new Error("Button.Icon must be used within a Button");
|
|
156
|
+
var sizeToken = size ?? styledContext.size,
|
|
157
|
+
iconColor = (0, import_gui_helpers.useCurrentColor)(styledContext.color),
|
|
158
|
+
iconSize = (typeof sizeToken == "number" ? sizeToken * 0.5 : (0, import_gui_font_size.getFontSize)(sizeToken)) * scaleIcon;
|
|
159
|
+
return (0, import_gui_helpers.getIcon)(children, {
|
|
160
|
+
size: iconSize,
|
|
161
|
+
color: iconColor
|
|
162
|
+
});
|
|
163
|
+
},
|
|
164
|
+
ButtonContext = (0, import_gui_web.createStyledContext)({
|
|
165
|
+
size: void 0,
|
|
166
|
+
variant: void 0,
|
|
167
|
+
color: void 0
|
|
168
|
+
}),
|
|
169
|
+
ButtonComponent = Frame.styleable(function (propsIn, ref) {
|
|
170
|
+
var isNested = (0, import_react.useContext)(import_gui_stacks.ButtonNestingContext),
|
|
171
|
+
processedProps = (0, import_gui_web.useProps)(propsIn, {
|
|
172
|
+
noNormalize: !0,
|
|
173
|
+
noExpand: !0
|
|
174
|
+
}),
|
|
175
|
+
{
|
|
176
|
+
children,
|
|
177
|
+
iconSize,
|
|
178
|
+
icon,
|
|
179
|
+
iconAfter,
|
|
180
|
+
scaleIcon = 1,
|
|
181
|
+
...props
|
|
182
|
+
} = processedProps,
|
|
183
|
+
size = propsIn.size || (propsIn.unstyled ? void 0 : "$true"),
|
|
184
|
+
styledContext = context.useStyledContext(),
|
|
185
|
+
iconColor = (0, import_gui_helpers.useCurrentColor)(styledContext?.color),
|
|
186
|
+
_ref,
|
|
187
|
+
finalSize = (_ref = iconSize ?? size) !== null && _ref !== void 0 ? _ref : styledContext?.size,
|
|
188
|
+
iconSizeNumber = (typeof finalSize == "number" ? finalSize * 0.5 : (0, import_gui_font_size.getFontSize)(finalSize)) * scaleIcon,
|
|
189
|
+
[themedIcon, themedIconAfter] = [icon, iconAfter].map(function (icon2) {
|
|
190
|
+
return icon2 ? (0, import_gui_helpers.getIcon)(icon2, {
|
|
191
|
+
size: iconSizeNumber,
|
|
192
|
+
color: iconColor
|
|
193
|
+
}) : null;
|
|
194
|
+
}),
|
|
195
|
+
wrappedChildren = (0, import_gui_text.wrapChildrenInText)(Text, {
|
|
196
|
+
children
|
|
197
|
+
}, {
|
|
198
|
+
unstyled: process.env.HANZO_GUI_HEADLESS === "1",
|
|
199
|
+
size: finalSize ?? styledContext?.size
|
|
200
|
+
});
|
|
201
|
+
return /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_gui_stacks.ButtonNestingContext.Provider, {
|
|
202
|
+
value: !0,
|
|
203
|
+
children: /* @__PURE__ */(0, import_jsx_runtime.jsxs)(Frame, {
|
|
204
|
+
ref,
|
|
205
|
+
...props,
|
|
206
|
+
...(isNested && {
|
|
207
|
+
render: "span"
|
|
208
|
+
}),
|
|
209
|
+
// Pass resolved size to circular variant when no explicit size provided
|
|
210
|
+
...(props.circular && !propsIn.size && {
|
|
211
|
+
size
|
|
212
|
+
}),
|
|
213
|
+
tabIndex: 0,
|
|
214
|
+
children: [themedIcon, wrappedChildren, themedIconAfter]
|
|
215
|
+
})
|
|
216
|
+
});
|
|
217
|
+
}),
|
|
218
|
+
Button = (0, import_gui_web.withStaticProperties)(ButtonComponent, {
|
|
219
|
+
Apply: context.Provider,
|
|
220
|
+
Frame,
|
|
221
|
+
Text,
|
|
222
|
+
Icon
|
|
223
|
+
});
|
|
224
|
+
//# sourceMappingURL=Button.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["__defProp","Object","defineProperty","__getOwnPropDesc","getOwnPropertyDescriptor","__getOwnPropNames","getOwnPropertyNames","__hasOwnProp","prototype","hasOwnProperty","__export","target","all","name","get","enumerable","__copyProps","to","from","except","desc","key","call","__toCommonJS","mod","value","Button_exports","Button","ButtonContext","module","exports","import_jsx_runtime","require","import_gui_font_size","import_gui_get_button_sized","import_gui_helpers","import_gui_stacks","import_gui_text","import_gui_web","import_react","context","createStyledContext","size","variant","color","elevation","Frame","styled","View","role","render","jsx","type","tabIndex","variants","unstyled","false","justifyContent","alignItems","flexWrap","flexDirection","cursor","backgroundColor","borderWidth","borderColor","hoverStyle","pressStyle","focusVisibleStyle","outlineColor","outlineStyle","outlineWidth","outlined","process","env","HANZO_GUI_HEADLESS","circular","themeableVariants","chromeless","...size","val","extras","buttonStyle","getButtonSized","gap","getTokenValue",":number","getElevation","disabled","true","pointerEvents","defaultVariants","Text","SizableText","userSelect","flexGrow","flexShrink","ellipsis","Icon","props","children","scaleIcon","styledContext","useStyledContext","Error","sizeToken","iconColor","useCurrentColor","iconSize","getFontSize","getIcon","ButtonComponent","styleable","propsIn","ref","isNested","useContext","ButtonNestingContext","processedProps","useProps","noNormalize","noExpand","icon","iconAfter","_ref","finalSize","iconSizeNumber","themedIcon","themedIconAfter","map","icon2","wrappedChildren","wrapChildrenInText","Provider","jsxs"],"sources":["../../src/Button.tsx"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { getDefaultTamaguiConfig } from "@hanzo/gui-config-default";
|
|
2
|
+
import { createTamagui } from "@hanzo/gui-core";
|
|
3
|
+
import { describe, expect, test } from "vitest";
|
|
4
|
+
import { Button } from "./Button.mjs";
|
|
5
|
+
import { jsx } from "react/jsx-runtime";
|
|
6
|
+
const conf = createTamagui(getDefaultTamaguiConfig());
|
|
7
|
+
describe("Button", () => {
|
|
8
|
+
test("123", () => {
|
|
9
|
+
expect(!0).toBeTruthy();
|
|
10
|
+
}), test("accepts native button html props", () => {
|
|
11
|
+
const _submitBtn = /* @__PURE__ */jsx(Button, {
|
|
12
|
+
type: "submit",
|
|
13
|
+
children: "Submit"
|
|
14
|
+
}),
|
|
15
|
+
_resetBtn = /* @__PURE__ */jsx(Button, {
|
|
16
|
+
type: "reset",
|
|
17
|
+
children: "Reset"
|
|
18
|
+
}),
|
|
19
|
+
_buttonBtn = /* @__PURE__ */jsx(Button, {
|
|
20
|
+
type: "button",
|
|
21
|
+
children: "Button"
|
|
22
|
+
}),
|
|
23
|
+
_formBtn = /* @__PURE__ */jsx(Button, {
|
|
24
|
+
type: "submit",
|
|
25
|
+
form: "myForm",
|
|
26
|
+
formAction: "/submit",
|
|
27
|
+
formMethod: "post",
|
|
28
|
+
formTarget: "_blank",
|
|
29
|
+
formNoValidate: !0,
|
|
30
|
+
name: "submitBtn",
|
|
31
|
+
value: "submit",
|
|
32
|
+
children: "Submit"
|
|
33
|
+
});
|
|
34
|
+
expect(!0).toBeTruthy();
|
|
35
|
+
});
|
|
36
|
+
});
|
|
37
|
+
//# sourceMappingURL=Button.test.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["getDefaultTamaguiConfig","createTamagui","describe","expect","test","Button","jsx","conf","toBeTruthy","_submitBtn","type","children","_resetBtn","_buttonBtn","_formBtn","form","formAction","formMethod","formTarget","formNoValidate","name","value"],"sources":["../../src/Button.test.tsx"],"sourcesContent":[null],"mappings":"AAAA,SAASA,uBAAA,QAA+B;AACxC,SAASC,aAAA,QAAqB;AAC9B,SAASC,QAAA,EAAUC,MAAA,EAAQC,IAAA,QAAY;AACvC,SAASC,MAAA,QAAc;AAYA,SAAAC,GAAA;AAVvB,MAAMC,IAAA,GAAON,aAAA,CAAcD,uBAAA,CAAwB,CAAC;AAEpDE,QAAA,CAAS,UAAU,MAAM;EACvBE,IAAA,CAAK,OAAO,MAAM;IAChBD,MAAA,CAAO,EAAI,EAAEK,UAAA,CAAW;EAC1B,CAAC,GAGDJ,IAAA,CAAK,oCAAoC,MAAM;IAE7C,MAAMK,UAAA,GAAa,eAAAH,GAAA,CAACD,MAAA;QAAOK,IAAA,EAAK;QAASC,QAAA;MAAA,CAAM;MACzCC,SAAA,GAAY,eAAAN,GAAA,CAACD,MAAA;QAAOK,IAAA,EAAK;QAAQC,QAAA;MAAA,CAAK;MACtCE,UAAA,GAAa,eAAAP,GAAA,CAACD,MAAA;QAAOK,IAAA,EAAK;QAASC,QAAA;MAAA,CAAM;MACzCG,QAAA,GACJ,eAAAR,GAAA,CAACD,MAAA;QACCK,IAAA,EAAK;QACLK,IAAA,EAAK;QACLC,UAAA,EAAW;QACXC,UAAA,EAAW;QACXC,UAAA,EAAW;QACXC,cAAA,EAAc;QACdC,IAAA,EAAK;QACLC,KAAA,EAAM;QACPV,QAAA;MAAA,CAED;IAEFR,MAAA,CAAO,EAAI,EAAEK,UAAA,CAAW;EAC1B,CAAC;AAWH,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var import_jsx_runtime = require("react/jsx-runtime"),
|
|
4
|
+
import_gui_config_default = require("@hanzo/gui-config-default"),
|
|
5
|
+
import_gui_core = require("@hanzo/gui-core"),
|
|
6
|
+
import_vitest = require("vitest"),
|
|
7
|
+
import_Button = require("./Button.native.js"),
|
|
8
|
+
conf = (0, import_gui_core.createTamagui)((0, import_gui_config_default.getDefaultTamaguiConfig)());
|
|
9
|
+
(0, import_vitest.describe)("Button", function () {
|
|
10
|
+
(0, import_vitest.test)("123", function () {
|
|
11
|
+
(0, import_vitest.expect)(!0).toBeTruthy();
|
|
12
|
+
}), (0, import_vitest.test)("accepts native button html props", function () {
|
|
13
|
+
var _submitBtn = /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_Button.Button, {
|
|
14
|
+
type: "submit",
|
|
15
|
+
children: "Submit"
|
|
16
|
+
}),
|
|
17
|
+
_resetBtn = /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_Button.Button, {
|
|
18
|
+
type: "reset",
|
|
19
|
+
children: "Reset"
|
|
20
|
+
}),
|
|
21
|
+
_buttonBtn = /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_Button.Button, {
|
|
22
|
+
type: "button",
|
|
23
|
+
children: "Button"
|
|
24
|
+
}),
|
|
25
|
+
_formBtn = /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_Button.Button, {
|
|
26
|
+
type: "submit",
|
|
27
|
+
form: "myForm",
|
|
28
|
+
formAction: "/submit",
|
|
29
|
+
formMethod: "post",
|
|
30
|
+
formTarget: "_blank",
|
|
31
|
+
formNoValidate: !0,
|
|
32
|
+
name: "submitBtn",
|
|
33
|
+
value: "submit",
|
|
34
|
+
children: "Submit"
|
|
35
|
+
});
|
|
36
|
+
(0, import_vitest.expect)(!0).toBeTruthy();
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
//# sourceMappingURL=Button.test.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["import_jsx_runtime","require","import_gui_config_default","import_gui_core","import_vitest","import_Button","conf","createTamagui","getDefaultTamaguiConfig","describe","test","expect","toBeTruthy","_submitBtn","jsx","Button","type","children","_resetBtn","_buttonBtn","_formBtn","form","formAction","formMethod","formTarget","formNoValidate","name","value"],"sources":["../../src/Button.test.tsx"],"sourcesContent":[null],"mappings":"AAAA,YAAS;;AACT,IAAAA,kBAAS,GAAAC,OAAqB;EAAAC,yBAAA,GAAAD,OAAA;EAAAE,eAAA,GAAAF,OAAA;EAAAG,aAAA,GAAAH,OAAA;EAAAI,aAAA,GAAAJ,OAAA;EAAAK,IAAA,OAAAH,eAAA,CAAAI,aAAA,MAAAL,yBAAA,CAAAM,uBAAA;AAC9B,IAAAJ,aAAS,CAAAK,QAAU,EAAQ,sBAAY;EACvC,IAAAL,aAAS,CAAAM,IAAc;IAYA,IAAAN,aAAA,CAAAO,MAAA,MAAAC,UAAA;EAVvB,IAAM,IAAAR,aAAO,CAAAM,IAAc,oCAAyB;IAEpD,IAAAG,UAAS,GAAU,eAAM,IAAAb,kBAAA,CAAAc,GAAA,EAAAT,aAAA,CAAAU,MAAA;QACvBC,IAAK,UAAa;QAChBC,QAAW,EAAE;MACd,EAGD;MAAAC,SAAK,sBAAAlB,kBAA0C,CAAAc,GAAA,EAAAT,aAAA,CAAAU,MAAA;QAE7CC,IAAM;QAIHC,QAAA;MAAA;MAAAE,UAAA,sBAAAnB,kBAAA,CAAAc,GAAA,EAAAT,aAAA,CAAAU,MAAA;QAAAC,IACC,UAAK;QAAAC,QACA;MAAA;MACLG,QAAA,kBAAW,IAAApB,kBAAA,CAAAc,GAAA,EAAAT,aAAA,CAAAU,MAAA;QAAAC,IACX,UAAW;QAAAK,IACX,UAAW;QAAAC,UACX,WAAc;QAAAC,UACT;QAAAC,UACC;QAAAC,cACP;QAAAC,IAAA;QAEDC,KAAA;QAEFV,QAAW,EAAE;MACd;IAWF,IAAAb,aAAA,CAAAO,MAAA,MAAAC,UAAA","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AAAA,cAAc","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AAAA,cAAc","ignoreList":[]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __copyProps = (to, from, except, desc) => {
|
|
8
|
+
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
|
|
9
|
+
get: () => from[key],
|
|
10
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
11
|
+
});
|
|
12
|
+
return to;
|
|
13
|
+
},
|
|
14
|
+
__reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
15
|
+
var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
|
|
16
|
+
value: !0
|
|
17
|
+
}), mod);
|
|
18
|
+
var index_exports = {};
|
|
19
|
+
module.exports = __toCommonJS(index_exports);
|
|
20
|
+
__reExport(index_exports, require("./Button.native.js"), module.exports);
|
|
21
|
+
//# sourceMappingURL=index.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AAAA","ignoreList":[]}
|