resig.js
Version:
Universal reactive signal library with complete platform features: signals, animations, CRDTs, scheduling, DOM integration. Works identically across React, SolidJS, Svelte, Vue, and Qwik.
184 lines • 14.2 kB
JavaScript
/**
* Framework Adapters for Router
* Universal router integration with React, Svelte, Vue, etc.
*/
import { router, treeRouter } from './router';
import { createBrowserNav, createNodeNav } from './navigation';
/**
* React Router Adapter
*/
export const useReactRouter = (routes) => {
const React = require('react');
const routerSignal = router(routes, createBrowserNav());
// Force re-renders when route changes
const [, forceUpdate] = React.useReducer((x) => x + 1, 0);
React.useEffect(() => {
const unsubscribe = routerSignal.subscribe(() => forceUpdate());
return unsubscribe;
}, []);
return {
route: routerSignal.route.value(),
params: routerSignal.params.value(),
navigate: (to) => {
routerSignal.navigate(to);
},
back: () => routerSignal.back(),
forward: () => routerSignal.forward(),
replace: (to) => routerSignal.replace(to)
};
};
/**
* React Tree Router Adapter
*/
export const useReactTreeRouter = (tree) => {
const React = require('react');
const routerSignal = treeRouter(tree, createBrowserNav());
const [, forceUpdate] = React.useReducer((x) => x + 1, 0);
React.useEffect(() => {
const unsubscribe = routerSignal.subscribe(() => forceUpdate());
return unsubscribe;
}, []);
return {
route: routerSignal.route.value(),
params: routerSignal.params.value(),
navigate: (to) => routerSignal.navigate(to),
back: () => routerSignal.back(),
forward: () => routerSignal.forward(),
replace: (to) => routerSignal.replace(to)
};
};
/**
* Svelte Router Adapter
*/
export const useSvelteRouter = (routes) => {
const routerSignal = router(routes, createBrowserNav());
// In Svelte 5, we can use $effect for reactivity
if (typeof globalThis !== 'undefined' && globalThis.$effect) {
globalThis.$effect(() => {
// This will automatically track the router signal
routerSignal.value();
});
}
return {
route: routerSignal.route,
params: routerSignal.params,
navigate: (to) => routerSignal.navigate(to),
back: () => routerSignal.back(),
forward: () => routerSignal.forward(),
replace: (to) => routerSignal.replace(to)
};
};
/**
* Vue Router Adapter
*/
export const useVueRouter = (routes) => {
const vue = require('vue');
const routerSignal = router(routes, createBrowserNav());
const route = vue.ref(routerSignal.route.value());
const params = vue.ref(routerSignal.params.value());
// Watch for changes
routerSignal.subscribe(() => {
route.value = routerSignal.route.value();
params.value = routerSignal.params.value();
});
return {
route,
params,
navigate: (to) => routerSignal.navigate(to),
back: () => routerSignal.back(),
forward: () => routerSignal.forward(),
replace: (to) => routerSignal.replace(to)
};
};
/**
* SolidJS Router Adapter
*/
export const useSolidRouter = (routes) => {
const solid = require('solid-js');
const routerSignal = router(routes, createBrowserNav());
const [route, setRoute] = solid.createSignal(routerSignal.route.value());
const [params, setParams] = solid.createSignal(routerSignal.params.value());
// Subscribe to changes
routerSignal.subscribe(() => {
setRoute(routerSignal.route.value());
setParams(routerSignal.params.value());
});
return {
route,
params,
navigate: (to) => routerSignal.navigate(to),
back: () => routerSignal.back(),
forward: () => routerSignal.forward(),
replace: (to) => routerSignal.replace(to)
};
};
/**
* Universal Router Hook
* Automatically detects framework and returns appropriate adapter
*/
export const useRouter = (routes) => {
// Framework detection
if (typeof window !== 'undefined') {
// Check for React
if (globalThis.React || window.React) {
return useReactRouter(routes);
}
// Check for Vue
if (globalThis.Vue || window.Vue) {
return useVueRouter(routes);
}
// Check for SolidJS
if (globalThis.solid || window.solid) {
return useSolidRouter(routes);
}
// Default to Svelte
return useSvelteRouter(routes);
}
// SSR fallback
return {
route: { tag: 'None' },
params: null,
navigate: (_to) => { },
back: () => { },
forward: () => { },
replace: (_to) => { }
};
};
/**
* Server-Side Rendering Adapter
*/
export const createSSRRouter = (routes, initialPath) => {
const env = createNodeNav(initialPath);
const routerSignal = router(routes, env);
return {
getRoute: () => routerSignal.route.value(),
getParams: () => routerSignal.params.value(),
setPath: (path) => env.setPath(path),
render: () => {
const route = routerSignal.route.value();
const params = routerSignal.params.value();
return {
route,
params,
path: env.getCurrentPath()
};
}
};
};
/**
* Testing Adapter
*/
export const createTestRouter = (routes, initialPath = '/') => {
const { createMemoryNav } = require('./navigation');
const env = createMemoryNav(initialPath);
const routerSignal = router(routes, env);
return {
router: routerSignal,
navigate: (to) => routerSignal.navigate(to),
getPath: () => env.getCurrentPath(),
setPath: (path) => env.setPath(path),
back: () => routerSignal.back(),
forward: () => routerSignal.forward()
};
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapters.js","sourceRoot":"","sources":["../../../src/router/adapters.ts"],"names":[],"mappings":"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"}