one
Version:
One is a new React Framework that makes Vite serve both native and web.
79 lines (78 loc) • 3.22 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: !0 });
}, __copyProps = (to, from, except, desc) => {
if (from && typeof from == "object" || typeof from == "function")
for (let key of __getOwnPropNames(from))
!__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: !0 }), mod);
var Tabs_exports = {};
__export(Tabs_exports, {
Tabs: () => Tabs,
default: () => Tabs_default
});
module.exports = __toCommonJS(Tabs_exports);
var import_jsx_runtime = require("react/jsx-runtime"), import_bottom_tabs = require("@react-navigation/bottom-tabs"), import_react_native = require("react-native"), import_Link = require("../link/Link"), import_withLayoutContext = require("./withLayoutContext"), TabBar = function(param) {
var { state, ...restProps } = param, filteredRoutes = state.routes.filter(function(r) {
return r.name !== "+not-found" && !r.name.startsWith("_sitemap");
});
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_bottom_tabs.BottomTabBar, {
state: {
...state,
routes: filteredRoutes
},
...restProps
});
}, BottomTabNavigator = (0, import_bottom_tabs.createBottomTabNavigator)().Navigator, Tabs = (0, import_withLayoutContext.withLayoutContext)(BottomTabNavigator, function(screens) {
return screens.map(function(screen) {
var _screen_options;
if (typeof screen.options != "function" && ((_screen_options = screen.options) === null || _screen_options === void 0 ? void 0 : _screen_options.href) !== void 0) {
var { href, ...options } = screen.options;
if (options.tabBarButton)
throw new Error("Cannot use `href` and `tabBarButton` together.");
return {
...screen,
options: {
...options,
tabBarButton: function(props) {
if (href == null)
return null;
var children = import_react_native.Platform.OS === "web" ? props.children : /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_native.Pressable, {
children: props.children
});
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_Link.Link, {
...props,
style: [
{
display: "flex"
},
props.style
],
href,
asChild: import_react_native.Platform.OS !== "web",
// biome-ignore lint/correctness/noChildrenProp: <explanation>
children
});
}
}
};
}
return screen;
});
}, {
props: {
tabBar: TabBar
}
}), Tabs_default = Tabs;
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
Tabs
});
//# sourceMappingURL=Tabs.js.map