UNPKG

@crossed/ui

Version:

A universal & performant styling library for React Native, Next.js & React

89 lines (88 loc) 2.79 kB
var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var Root_exports = {}; __export(Root_exports, { Root: () => Root }); module.exports = __toCommonJS(Root_exports); var import_jsx_runtime = require("react/jsx-runtime"); var import_core = require("@crossed/core"); var import_react_native_reanimated = require("react-native-reanimated"); var import_react = require("react"); var import_context = require("./context"); var import_react_native = require("react-native"); var import_styled = require("@crossed/styled"); const Root = ({ value: valueProps, onChange: onChangeProps, children, defaultValue = false, disabled, ...props }) => { const DURATION = 300; const [value, setValue] = (0, import_core.useUncontrolled)({ defaultValue, value: valueProps, onChange: onChangeProps }); const height = (0, import_react_native_reanimated.useSharedValue)(24); const width = (0, import_react_native_reanimated.useSharedValue)(48); const onChange = (0, import_react.useCallback)(() => { setValue(!value); }, [value, setValue]); return /* @__PURE__ */ (0, import_jsx_runtime.jsx)( import_context.localContext.Provider, { value: { height, width, duration: DURATION, value, disabled }, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)( import_react_native.Pressable, { onPress: onChange, disabled, "aria-checked": value, role: "switch", style: (0, import_styled.composeStyles)( (0, import_styled.inlineStyle)(({ space }) => ({ base: { display: "flex", flexDirection: "row", gap: space.xs, alignItems: "center" } })), props.style ).style().style, ...props, children } ) } ); }; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { Root }); //# sourceMappingURL=Root.js.map