one
Version:
One is a new React Framework that makes Vite serve both native and web.
195 lines (192 loc) • 7.74 kB
JavaScript
;
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
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 __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
// If the importer is in node compatibility mode or this is not an ESM
// file that has been converted to a CommonJS file using a Babel-
// compatible transform (i.e. "__esModule" has not been set), then set
// "default" to the CommonJS "module.exports" for node compatibility.
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
value: mod,
enumerable: true
}) : target, mod));
var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
value: true
}), mod);
var useLinking_native_exports = {};
__export(useLinking_native_exports, {
useLinking: () => useLinking
});
module.exports = __toCommonJS(useLinking_native_exports);
var import_core = require("@react-navigation/core");
var React = __toESM(require("react"), 1);
var import_react_native = require("react-native");
var import_extractPathFromURL = require("./extractPathFromURL.native.js");
function _type_of(obj) {
"@swc/helpers - typeof";
return obj && typeof Symbol !== "undefined" && obj.constructor === Symbol ? "symbol" : typeof obj;
}
var linkingHandlers = [];
function useLinking(ref, param, onUnhandledLinking) {
var {
enabled = true,
prefixes,
filter,
config,
getInitialURL = function () {
return Promise.race([import_react_native.Linking.getInitialURL(), new Promise(function (resolve) {
setTimeout(resolve, 150);
})]);
},
subscribe = function (listener) {
var _Linking_removeEventListener;
var callback = function (param2) {
var {
url
} = param2;
return listener(url);
};
var subscription = import_react_native.Linking.addEventListener("url", callback);
var removeEventListener = (_Linking_removeEventListener = import_react_native.Linking.removeEventListener) === null || _Linking_removeEventListener === void 0 ? void 0 : _Linking_removeEventListener.bind(import_react_native.Linking);
return function () {
if (subscription === null || subscription === void 0 ? void 0 : subscription.remove) {
subscription.remove();
} else {
removeEventListener === null || removeEventListener === void 0 ? void 0 : removeEventListener("url", callback);
}
};
},
getStateFromPath = import_core.getStateFromPath,
getActionFromState = import_core.getActionFromState
} = param;
var independent = (0, import_core.useNavigationIndependentTree)();
React.useEffect(function () {
if (process.env.NODE_ENV === "production") {
return void 0;
}
if (independent) {
return void 0;
}
if (enabled !== false && linkingHandlers.length && import_react_native.Platform.OS !== "android") {
if (linkingHandlers.length > 1) {
console.error(["Looks like you have configured linking in multiple places. This is likely an error since deep links should only be handled in one place to avoid conflicts. Make sure that:", "- You don't have multiple NavigationContainers in the app each with 'linking' enabled", "- Only a single instance of the root component is rendered"].join("\n").trim());
}
}
var handler = Symbol();
if (enabled !== false) {
linkingHandlers.push(handler);
}
return function () {
var index = linkingHandlers.indexOf(handler);
if (index > -1) {
linkingHandlers.splice(index, 1);
}
};
}, [enabled, independent]);
var enabledRef = React.useRef(enabled);
var prefixesRef = React.useRef(prefixes);
var filterRef = React.useRef(filter);
var configRef = React.useRef(config);
var getInitialURLRef = React.useRef(getInitialURL);
var getStateFromPathRef = React.useRef(getStateFromPath);
var getActionFromStateRef = React.useRef(getActionFromState);
React.useEffect(function () {
enabledRef.current = enabled;
prefixesRef.current = prefixes;
filterRef.current = filter;
configRef.current = config;
getInitialURLRef.current = getInitialURL;
getStateFromPathRef.current = getStateFromPath;
getActionFromStateRef.current = getActionFromState;
});
var getStateFromURL = React.useCallback(function (url) {
if (!url || filterRef.current && !filterRef.current(url)) {
return void 0;
}
var path = (0, import_extractPathFromURL.extractPathFromURL)(prefixesRef.current, url);
return path !== void 0 ? getStateFromPathRef.current(path, configRef.current) : void 0;
}, []);
var getInitialState = React.useCallback(function () {
var state;
if (enabledRef.current) {
var url = getInitialURLRef.current();
if (url != null) {
if (typeof url !== "string") {
return url.then(function (url2) {
var state2 = getStateFromURL(url2);
if (typeof url2 === "string") {
onUnhandledLinking((0, import_extractPathFromURL.extractPathFromURL)(prefixes, url2));
}
return state2;
});
} else {
onUnhandledLinking((0, import_extractPathFromURL.extractPathFromURL)(prefixes, url));
}
}
state = getStateFromURL(url);
}
var thenable = {
// biome-ignore lint/suspicious/noThenProperty: don't check copied code
then(onfulfilled) {
return Promise.resolve(onfulfilled ? onfulfilled(state) : state);
},
catch() {
return thenable;
}
};
return thenable;
}, [getStateFromURL, onUnhandledLinking, prefixes]);
React.useEffect(function () {
var listener = function (url) {
if (!enabled) {
return;
}
var navigation = ref.current;
var state = navigation ? getStateFromURL(url) : void 0;
if (navigation && state) {
onUnhandledLinking((0, import_extractPathFromURL.extractPathFromURL)(prefixes, url));
var rootState = navigation.getRootState();
if (state.routes.some(function (r) {
var _rootState_routeNames;
return !(rootState === null || rootState === void 0 ? void 0 : (_rootState_routeNames = rootState.routeNames) === null || _rootState_routeNames === void 0 ? void 0 : _rootState_routeNames.includes(r.name));
})) {
return;
}
var action = getActionFromStateRef.current(state, configRef.current);
if (action !== void 0) {
try {
navigation.dispatch(action);
} catch (e) {
console.warn(`An error occurred when trying to handle the link '${url}': ${(typeof e === "undefined" ? "undefined" : _type_of(e)) === "object" && e != null && "message" in e ? e.message : e}`);
}
} else {
navigation.resetRoot(state);
}
}
};
return subscribe(listener);
}, [enabled, getStateFromURL, onUnhandledLinking, prefixes, ref, subscribe]);
return {
getInitialState
};
}
//# sourceMappingURL=useLinking.native.js.map