one
Version:
One is a new React Framework that makes Vite serve both native and web.
185 lines (183 loc) • 6.2 kB
JavaScript
;
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 TabTrigger_exports = {};
__export(TabTrigger_exports, {
TabTrigger: () => TabTrigger,
isTabTrigger: () => isTabTrigger,
useTabTrigger: () => useTabTrigger
});
module.exports = __toCommonJS(TabTrigger_exports);
var import_jsx_runtime = require("react/jsx-runtime");
var import_react_slot = require("@radix-ui/react-slot");
var import_react = require("react");
var import_react_native = require("react-native");
var import_getPathFromState_mods = require("../fork/getPathFromState-mods.native.js");
var import_imperative_api = require("../router/imperative-api.native.js");
var import_matchers = require("../router/matchers.native.js");
var import_Navigator = require("../views/Navigator.native.js");
var import_TabContext = require("./TabContext.native.js");
var TabTriggerSlot = import_react_slot.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__ */(0, import_jsx_runtime.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__ */(0, import_jsx_runtime.jsx)(import_react_native.Pressable, {
style: styles.tabTrigger,
...reactNativeWebProps,
...props,
...triggerProps,
children: props.children
});
}
}
function isTabTrigger(child) {
return child.type === TabTrigger;
}
function useTabTrigger(options) {
var {
state,
navigation
} = (0, import_Navigator.useNavigatorContext)();
var {
name,
resetOnFocus,
onPress,
onLongPress
} = options;
var triggerMap = (0, import_react.use)(import_TabContext.TabTriggerMapContext);
var getTrigger = (0, import_react.useCallback)(function (name2) {
var config = triggerMap[name2];
if (!config) {
return;
}
return {
isFocused: state.index === config.index,
route: state.routes[config.index],
resolvedHref: (0, import_matchers.stripGroupSegmentsFromPath)((0, import_getPathFromState_mods.appendBaseUrl)(config.href)),
...config
};
}, [triggerMap, state]);
var trigger = name !== void 0 ? getTrigger(name) : void 0;
var switchTab = (0, import_react.useCallback)(function (name2, options2) {
var config = triggerMap[name2];
if (config) {
if (config.type === "external") {
return import_imperative_api.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 = (0, import_react.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 = (0, import_react.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 = import_react_native.StyleSheet.create({
tabTrigger: {
flexDirection: "row",
justifyContent: "space-between"
}
});
//# sourceMappingURL=TabTrigger.native.js.map