UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

155 lines (154 loc) 4.9 kB
import { jsx as _jsx } from "react/jsx-runtime"; import { Slot } from "@radix-ui/react-slot"; import { use, useCallback } from "react"; import { Pressable, StyleSheet } from "react-native"; import { appendBaseUrl } from "../fork/getPathFromState-mods.native.js"; import { router } from "../router/imperative-api.native.js"; import { stripGroupSegmentsFromPath } from "../router/matchers.native.js"; import { useNavigatorContext } from "../views/Navigator.native.js"; import { TabTriggerMapContext } from "./TabContext.native.js"; var TabTriggerSlot = Slot; function shouldHandleMouseEvent(e) { if (!e) return true; if ("button" in e) { return !e.metaKey && !e.altKey && !e.ctrlKey && !e.shiftKey && (e.button == null || e.button === 0) && [void 0, null, "", "self"].includes(e.currentTarget.target); } return true; } function TabTrigger(param) { var { asChild, name, href, resetOnFocus, ...props } = param; var { trigger, triggerProps } = useTabTrigger({ name, resetOnFocus, ...props }); if (asChild) { return /* @__PURE__ */_jsx(TabTriggerSlot, { style: styles.tabTrigger, ...props, ...triggerProps, href: trigger === null || trigger === void 0 ? void 0 : trigger.resolvedHref, children: props.children }); } else { var reactNativeWebProps = { href: trigger === null || trigger === void 0 ? void 0 : trigger.resolvedHref }; return /* @__PURE__ */_jsx(Pressable, { style: styles.tabTrigger, ...reactNativeWebProps, ...props, ...triggerProps, children: props.children }); } } function isTabTrigger(child) { return child.type === TabTrigger; } function useTabTrigger(options) { var { state, navigation } = useNavigatorContext(); var { name, resetOnFocus, onPress, onLongPress } = options; var triggerMap = use(TabTriggerMapContext); var getTrigger = useCallback(function (name2) { var config = triggerMap[name2]; if (!config) { return; } return { isFocused: state.index === config.index, route: state.routes[config.index], resolvedHref: stripGroupSegmentsFromPath(appendBaseUrl(config.href)), ...config }; }, [triggerMap, state]); var trigger = name !== void 0 ? getTrigger(name) : void 0; var switchTab = useCallback(function (name2, options2) { var config = triggerMap[name2]; if (config) { if (config.type === "external") { return router.navigate(config.href); } else { return navigation === null || navigation === void 0 ? void 0 : navigation.dispatch({ ...config.action, type: "JUMP_TO", payload: { ...config.action.payload, ...options2 } }); } } else { return navigation === null || navigation === void 0 ? void 0 : navigation.dispatch({ type: "JUMP_TO", payload: { name: name2 } }); } }, [navigation, triggerMap]); var handleOnPress = useCallback(function (event) { onPress === null || onPress === void 0 ? void 0 : onPress(event); if (!trigger) return; if (event === null || event === void 0 ? void 0 : event.isDefaultPrevented()) return; navigation === null || navigation === void 0 ? void 0 : navigation.emit({ type: "tabPress", target: trigger.type === "internal" ? trigger.route.key : trigger === null || trigger === void 0 ? void 0 : trigger.href, canPreventDefault: true }); if (!shouldHandleMouseEvent(event)) return; if (trigger.isFocused) return; switchTab(name, { resetOnFocus }); }, [onPress, name, resetOnFocus, trigger, navigation, switchTab]); var handleOnLongPress = useCallback(function (event) { onLongPress === null || onLongPress === void 0 ? void 0 : onLongPress(event); if (!trigger) return; if (event === null || event === void 0 ? void 0 : event.isDefaultPrevented()) return; navigation === null || navigation === void 0 ? void 0 : navigation.emit({ type: "tabLongPress", target: trigger.type === "internal" ? trigger.route.key : trigger === null || trigger === void 0 ? void 0 : trigger.href }); if (!shouldHandleMouseEvent(event)) return; switchTab(name, { resetOnFocus }); }, [onLongPress, name, resetOnFocus, trigger, navigation, switchTab]); var triggerProps = { isFocused: Boolean(trigger === null || trigger === void 0 ? void 0 : trigger.isFocused), onPress: handleOnPress, onLongPress: handleOnLongPress }; return { switchTab, getTrigger, trigger, triggerProps }; } var styles = StyleSheet.create({ tabTrigger: { flexDirection: "row", justifyContent: "space-between" } }); export { TabTrigger, isTabTrigger, useTabTrigger }; //# sourceMappingURL=TabTrigger.native.js.map