@plumile/router 0.1.21 → 0.1.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -27,6 +27,21 @@ This package requires the following peer dependencies:
27
27
  npm install react react-dom react-relay relay-runtime @types/react @types/react-dom @types/react-relay
28
28
  ```
29
29
 
30
+ ## Module Entry Points
31
+
32
+ - `@plumile/router`: primary ESM entry exporting runtime APIs and types.
33
+ - `@plumile/router/lib/esm/*`: direct file imports when you need to tree-shake specific helpers.
34
+ - `@plumile/router/lib/types/*`: TypeScript declaration files (consumed automatically via `types` field).
35
+
36
+ This package is ESM-only. If your tooling expects CommonJS, enable ESM support (e.g. Vite, Next.js, or webpack with `type: 'module'`).
37
+
38
+ ## Documentation & Guides
39
+
40
+ - Getting started: [docs/index.md](../../docs/index.md)
41
+ - Relay integration walkthrough: [docs/router-relay.md](../../docs/router-relay.md)
42
+ - Devtools: [docs/devtools.md](../../docs/devtools.md)
43
+ - Examples: [EXAMPLES.md](./EXAMPLES.md)
44
+
30
45
  ## Quick Start
31
46
 
32
47
  ### 1. Define Your Routes
@@ -65,9 +80,11 @@ const routes: Route<any, any>[] = [
65
80
  ### 2. Create the Router
66
81
 
67
82
  ```typescript
68
- import createRouter from '@plumile/router';
83
+ import { createRouter } from '@plumile/router';
69
84
 
70
- const { context, cleanup } = createRouter(routes);
85
+ export const router = createRouter(routes);
86
+ const { context, cleanup } = router;
87
+ // Call cleanup() when tearing the app down (tests, SSR shell disposal, etc.).
71
88
  ```
72
89
 
73
90
  ### 3. Provide Router Context
@@ -75,6 +92,9 @@ const { context, cleanup } = createRouter(routes);
75
92
  ```tsx
76
93
  import React from 'react';
77
94
  import { RoutingContext, RouterRenderer } from '@plumile/router';
95
+ import { router } from './router';
96
+
97
+ const { context } = router;
78
98
 
79
99
  function App() {
80
100
  return (
@@ -107,6 +127,24 @@ function Navigation() {
107
127
  }
108
128
  ```
109
129
 
130
+ ## Hooks Overview
131
+
132
+ | Hook | Signature | Purpose | Example |
133
+ | --------------------------- | -------------------------------------- | ----------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- | --------------------------- |
134
+ | `useNavigate()` | `() => Navigate` | Imperative navigation with type-safe filters + params. | `const navigate = useNavigate(); navigate({ pathname: '/products', filters: { page: { eq: 2 } } });` |
135
+ | `useFilters(schema)` | `(schema) => [filters, actions]` | Read/mutate filters derived from the given schema; actions include `set`, `remove`, `merge`, `clear`. | `const [filters, actions] = useFilters(productFilters); actions.set('price', 'gt', 10);` |
136
+ | `useQuery()` | `() => Record<string, string | string[]>` | Raw query aggregation (legacy/simple use). | `const query = useQuery();` |
137
+ | `useQueryState(key, opts?)` | `(key, options?) => [value, setValue]` | Two-way binding for a single query parameter with default/replace options. | `const [page, setPage] = useQueryState('page', { defaultValue: 1 });` |
138
+ | `useFilterDiagnostics()` | `() => Diagnostic[]` | Surface parsing issues (unknown field/operator) for UI or devtools overlays. | `const diagnostics = useFilterDiagnostics();` |
139
+ | `useAllQuery(opts?)` | `(options?) => QueryLike` | Access filters + raw query merged together, useful for debugging or incremental migrations. | `const all = useAllQuery();` |
140
+
141
+ ## Devtools Overview
142
+
143
+ - Enable via `createRouter(routes, { devtools: { panel: true, global: true } })` (defaults: global on in dev, panel off).
144
+ - Global helper: `window.__PLUMILE_ROUTER__?.get()` returns the current route entry (filters, query, prepared data).
145
+ - Panel overlay toggled with `Alt+Shift+R` (configurable via `devtools.shortcut`).
146
+ - Use `subscribe` to watch navigation changes for logging or live debugging.
147
+
110
148
  ## API Reference
111
149
 
112
150
  ### Core Components
@@ -262,16 +300,22 @@ const routes = [
262
300
  ];
263
301
  ```
264
302
 
265
- ### Accessing Filters
303
+ ### Accessing Filters (Strongly Typed)
304
+
305
+ `useFilters` now requires the schema as a mandatory argument (dynamic discovery was removed). It returns a tuple `[filters, actions]` where `filters` is fully inferred from the provided schema and `actions` are strongly typed mutation helpers.
266
306
 
267
307
  ```tsx
268
308
  import { useFilters } from '@plumile/router';
309
+ import { productFilters } from './schemas'; // assume you exported the schema above
269
310
 
270
311
  function List() {
271
- const [filters, actions] = useFilters();
272
- // filters.price?.gt, filters.title?.contains, filters.page?.eq
273
- actions.set('price', 'gt', 10);
274
- actions.set('page', 'eq', 2); // becomes page=2 in URL
312
+ const [filters, { set, remove, merge, clear }] = useFilters(productFilters);
313
+ // All operators/values are type‑checked against the schema
314
+ set('price', 'gt', 10); // => ?price.gt=10
315
+ set('page', 'eq', 2); // => ?page=2 (page normalization will clamp <1 to 1)
316
+ remove('price', 'gt'); // remove only that operator
317
+ merge({ price: { between: [10, 20] }, title: { contains: 'ultra' } });
318
+ clear(); // remove all active filters
275
319
  return null;
276
320
  }
277
321
  ```
@@ -311,20 +355,21 @@ Filters cache: repeated navigations with semantically identical search strings r
311
355
  </Link>
312
356
  ```
313
357
 
314
- Renders `href="/products?page=1&price.gt=10"`.
358
+ Renders: `/products?page=1&price.gt=10`.
315
359
 
316
360
  ### Manual Serialization Example
317
361
 
318
362
  If you need to build a URL outside of navigation (e.g. constructing a sitemap entry):
319
363
 
320
364
  ```ts
321
- import buildCombinedSearch from '@plumile/router/lib/esm/routing/tools/buildCombinedSearch.js'; // or routed re-export
365
+ import { buildCombinedSearch } from '@plumile/router';
366
+ // or: import buildCombinedSearch from '@plumile/router/lib/esm/routing/tools/buildCombinedSearch.js';
322
367
 
323
368
  const search = buildCombinedSearch({
324
369
  filters: { page: { eq: 1 }, price: { gt: 10 } },
325
- schema: productFilters,
370
+ querySchema: productFilters,
326
371
  });
327
- // search === '?page=1&price.gt=10'
372
+ // => '?page=1&price.gt=10'
328
373
  ```
329
374
 
330
375
  Guideline: If you need to derive lightweight projections (e.g. `const { page } = typed`), you can still destructure; but avoid spreading into a new object if you rely on reference equality downstream.
@@ -473,11 +518,11 @@ export const routes = [
473
518
  ];
474
519
 
475
520
  function Items() {
476
- const [filters, { set, remove, clear, merge }] = useFilters();
477
- set('price', 'gt', 10); // => ?price.gt=10
478
- set('page', 'eq', 2); // => ?page=2
479
- remove('price', 'gt');
480
- merge([{ field: 'price', op: 'between', value: [10, 20] }]);
521
+ const [filters, { set, remove, clear, merge }] = useFilters(querySchema);
522
+ set('price', 'gt', 10); // => ?price.gt=10
523
+ set('page', 'eq', 2); // => ?page=2
524
+ remove('price', 'gt'); // remove only that operator
525
+ merge({ price: { between: [10, 20] } }); // descriptor-array form removed; use object patch
481
526
  clear();
482
527
  return null;
483
528
  }
@@ -485,6 +530,19 @@ function Items() {
485
530
 
486
531
  `navigate({ filters })` is available for programmatic updates. Serialization order: schema field keys first, then any extra non‑schema keys (if present). Operators follow deterministic ordering from `@plumile/filter-query`.
487
532
 
533
+ #### Typed Actions Cheat‑Sheet
534
+
535
+ ```ts
536
+ const [filters, a] = useFilters(querySchema);
537
+ a.set('price', 'in', [10, 20, 30]); // array operators allowed when schema supports it
538
+ a.set('title', 'contains', 'ultra');
539
+ a.remove('price', 'in'); // remove only that operator
540
+ a.merge({ page: { eq: 3 }, price: { gt: 50 } }); // deep merge per field
541
+ a.clear(); // wipe everything (noop if already empty)
542
+ ```
543
+
544
+ Navigation is skipped automatically if the structural filters object doesn't change (shallow compare) to avoid redundant history entries.
545
+
488
546
  Diagnostics (unknown field/operator, invalid values, etc.) are accessible via `useFilterDiagnostics()`.
489
547
 
490
548
  ### ESLint Rule: no-direct-window-location-search
@@ -536,26 +594,34 @@ with:
536
594
  const query = useQuery(); // raw key=value aggregation (simple); prefer useFilters() for structured access.
537
595
  ```
538
596
 
539
- ### Migration Guide (Legacy DSL → Unified Filters)
597
+ ### Migration Guide (Legacy DSL → Unified Filters + Typed Hook Update)
540
598
 
541
599
  1. Remove legacy imports of `q`, `parseTypedQuery`, `buildSearch`.
542
- 2. Define a schema with `defineSchema` from `@plumile/filter-query` and attach as `querySchema`.
543
- 3. Replace (removed) `useTypedQuery()` usages with `useFilters()`.
544
- 4. Update navigation: `navigate({ filters: { page: { eq: 2 } } })`.
600
+ 2. Define a schema with `defineSchema` from `@plumile/filter-query` and attach as `querySchema` on the route needing filters.
601
+ 3. Replace (removed) `useTypedQuery()` usages with `useFilters(querySchema)` (schema argument now mandatory – breaking change vs earlier experimental auto‑discovery version).
602
+ 4. Update navigation: `navigate({ filters: { page: { eq: 2 } } })` (unchanged pattern).
545
603
  5. Update links: `<Link to="/x" filters={{ page: { eq: 2 } }} />`.
546
- 6. Page defaults / normalization: rely on built-in clamp (`page < 1 -> 1`).
547
- 7. Remove any type tests referencing the DSL; rely on schema inference.
604
+ 6. Replace any previous `merge([{ field, op, value }])` descriptor array calls with `merge({ field: { op: value } })` object patches.
605
+ 7. Page defaults / normalization: rely on built-in clamp (`page < 1 -> 1`).
606
+ 8. Remove any type tests referencing the DSL; rely on schema inference from `defineSchema`.
607
+ 9. If you manually used `buildCombinedSearch({ schema })`, rename the option to `querySchema`.
548
608
 
549
- ### Removed APIs
609
+ ### Removed & Changed APIs
550
610
 
551
- The following legacy APIs were removed in favor of the unified filter model:
611
+ Removed in favor of the unified model:
552
612
 
553
- - `q.*` descriptor DSL (replaced by `defineSchema` in `@plumile/filter-query`)
613
+ - `q.*` descriptor DSL (use `defineSchema`)
554
614
  - `parseTypedQuery`
555
615
  - `buildSearch` (use `buildCombinedSearch`)
556
616
  - `useTypedQuery`
557
617
 
558
- Use `@plumile/filter-query` for schema definitions and `useFilters` / `buildCombinedSearch` for runtime access & serialization.
618
+ Changed (breaking):
619
+
620
+ - `useFilters()` → `useFilters(schema)` (schema argument required; no dynamic discovery)
621
+ - `merge` action signature: descriptor array → object patch (`merge({ field: { operator: value } })`)
622
+ - `buildCombinedSearch({ schema })` → `buildCombinedSearch({ querySchema })`
623
+
624
+ Use `@plumile/filter-query` for schema definitions and `useFilters(schema)` / `buildCombinedSearch` for runtime access & serialization.
559
625
 
560
626
  ### useQueryState Hook
561
627
 
@@ -1 +1 @@
1
- {"version":3,"file":"createRouter.d.ts","sourceRoot":"","sources":["../../../src/routing/createRouter.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAEV,kBAAkB,EAElB,QAAQ,EACR,cAAc,EAEf,MAAM,aAAa,CAAC;AAKrB,MAAM,MAAM,kBAAkB,CAAC,CAAC,SAAS,QAAQ,EAAE,IAAI;IAErD,OAAO,EAAE,MAAM,IAAI,CAAC;IAEpB,OAAO,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;CACtD,CAAC;AAqCF,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,CAAC,SAAS,QAAQ,EAAE,EACvD,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,EAAE,EAC3B,IAAI,GAAE;IACJ,QAAQ,CAAC,EACL,OAAO,GACP;QAAE,MAAM,CAAC,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,OAAO,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;CACzD,GACL,kBAAkB,CAAC,CAAC,SAAS,QAAQ,EAAE,GAAG,CAAC,GAAG,QAAQ,EAAE,CAAC,CA2sB3D"}
1
+ {"version":3,"file":"createRouter.d.ts","sourceRoot":"","sources":["../../../src/routing/createRouter.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAEV,kBAAkB,EAElB,QAAQ,EACR,cAAc,EAEf,MAAM,aAAa,CAAC;AAKrB,MAAM,MAAM,kBAAkB,CAAC,CAAC,SAAS,QAAQ,EAAE,IAAI;IAErD,OAAO,EAAE,MAAM,IAAI,CAAC;IAEpB,OAAO,EAAE,kBAAkB,CAAC,GAAG,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;CACtD,CAAC;AAqCF,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,CAAC,SAAS,QAAQ,EAAE,EACvD,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,EAAE,EAC3B,IAAI,GAAE;IACJ,QAAQ,CAAC,EACL,OAAO,GACP;QAAE,MAAM,CAAC,EAAE,OAAO,CAAC;QAAC,KAAK,CAAC,EAAE,OAAO,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;CACzD,GACL,kBAAkB,CAAC,CAAC,SAAS,QAAQ,EAAE,GAAG,CAAC,GAAG,QAAQ,EAAE,CAAC,CAisB3D"}
@@ -45,14 +45,10 @@ export default function createRouter(routes, opts = {}) {
45
45
  const initialRawQuery = parseRawQuery(history.location.search);
46
46
  let initialUnifiedSchema;
47
47
  if (route != null) {
48
- const collected = [];
49
- for (const r of route.route.routes) {
50
- const maybe = r.querySchema;
51
- if (maybe != null)
52
- collected.push(maybe);
48
+ const last = route.route.routes.at(-1);
49
+ if (last != null) {
50
+ initialUnifiedSchema = last.querySchema;
53
51
  }
54
- if (collected.length > 0)
55
- initialUnifiedSchema = collected.at(-1);
56
52
  }
57
53
  let initialFilters;
58
54
  let initialFilterDiagnostics;
@@ -126,14 +122,9 @@ export default function createRouter(routes, opts = {}) {
126
122
  const query = parseRawQuery(location.search);
127
123
  let querySchema;
128
124
  if (nextRoute != null) {
129
- const collected = [];
130
- for (const r of nextRoute.route.routes) {
131
- const maybeF = r.querySchema;
132
- if (maybeF != null)
133
- collected.push(maybeF);
134
- }
135
- if (collected.length > 0) {
136
- querySchema = collected.at(-1);
125
+ const last = nextRoute.route.routes.at(-1);
126
+ if (last != null) {
127
+ querySchema = last.querySchema;
137
128
  }
138
129
  }
139
130
  let filters;
@@ -243,26 +234,16 @@ export default function createRouter(routes, opts = {}) {
243
234
  const current = currentEntry;
244
235
  const targetPathname = pathname ?? current.location.pathname;
245
236
  let destSchema;
246
- function collectSchema(routesArr) {
247
- if (routesArr == null) {
248
- return;
249
- }
250
- const collected = [];
251
- for (const r of routesArr) {
252
- const maybeF = r
253
- .querySchema;
254
- if (maybeF != null)
255
- collected.push(maybeF);
256
- }
257
- if (collected.length > 0) {
258
- destSchema = collected.at(-1);
259
- }
260
- }
261
237
  const destRoute = getMatchedRoute(flatRoutes, {
262
238
  ...window.location,
263
239
  pathname: targetPathname,
264
240
  });
265
- collectSchema(destRoute?.route.routes);
241
+ if (destRoute != null) {
242
+ const last = destRoute.route.routes.at(-1);
243
+ if (last != null) {
244
+ destSchema = last.querySchema;
245
+ }
246
+ }
266
247
  destSchema ??= current.activeQuerySchema;
267
248
  const effectiveFilters = navFilters ?? current.filters;
268
249
  const filtersInput = effectiveFilters ?? query;
@@ -630,4 +611,4 @@ export default function createRouter(routes, opts = {}) {
630
611
  }
631
612
  return { cleanup, context };
632
613
  }
633
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createRouter.js","sourceRoot":"","sources":["../../../src/routing/createRouter.ts"],"names":[],"mappings":"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","sourcesContent":["import { buildRoutes } from '../builder.js';\nimport { BrowserHistory } from '../history/index.js';\nimport { getMatchedRoute, prepareMatch } from '../tools.js';\nimport { parseRawQuery } from '../tools/query.js';\nimport buildCombinedSearch from '../tools/buildCombinedSearch.js';\nimport { parse as parseFilters } from '@plumile/filter-query';\nimport type {\n  RouteEntry,\n  RoutingContextType,\n  SubscribeCallback,\n  AnyRoute,\n  PreparedAccess,\n  NavigateOverloads,\n} from '../types.js';\n\n/**\n * Return type for the createRouter function.\n */\nexport type CreateRouterReturn<R extends AnyRoute[]> = {\n  /** Function to clean up router listeners and resources */\n  cleanup: () => void;\n  /** Router context object for the React Context Provider */\n  context: RoutingContextType<any> & PreparedAccess<R>;\n};\n\n/**\n * Creates a complete router system from route configurations.\n *\n * This router is built from the same primitives as react-router but with additional\n * features for data preloading and code splitting. Each route can contain both a\n * Component and a prepare() function that can preload data for the component.\n *\n * The router watches for changes to the current location via the HTML5 History API,\n * maps the location to the corresponding route entry, and then preloads the code\n * and data for the route before rendering.\n *\n * @param routes - Array of route configurations\n * @returns Object containing the router context and cleanup function\n *\n  preparedMatch: prepareMatch(route, parseRawQuery(history.location.search)),\n * ```typescript\n * const routes = [\n *   {\n *     path: '/users/:id',\n *     resourcePage: getResourcePage('UserProfile', () => import('./UserProfile')),\n *     prepare: ({ variables }) => ({ userId: variables.id })\n *   }\n * ];\n *\n * const { context, cleanup } = createRouter(routes);\n *\n * // Use in React app\n * <RoutingContext.Provider value={context}>\n *   <RouterRenderer />\n * </RoutingContext.Provider>\n * ```\n */\n/**\n * Create a router (typed overload). When called with a const tuple of routes, generics are preserved.\n */\nexport default function createRouter<R extends AnyRoute[]>(\n  routes: [...R] | AnyRoute[],\n  opts: {\n    devtools?:\n      | boolean\n      | { global?: boolean; panel?: boolean; shortcut?: string };\n  } = {},\n): CreateRouterReturn<R extends AnyRoute[] ? R : AnyRoute[]> {\n  // Normalize devtools options maintaining backwards compatibility\n  let devtoolsGlobal: boolean;\n  let devtoolsPanel = false;\n  let devtoolsShortcut = 'Alt+Shift+R';\n  if (typeof opts.devtools === 'object') {\n    const baseEnabled = (() => {\n      try {\n        return (\n          typeof process !== 'undefined' &&\n          process.env.NODE_ENV !== 'production'\n        );\n      } catch {\n        return false;\n      }\n    })();\n    devtoolsGlobal = opts.devtools.global ?? baseEnabled;\n    devtoolsPanel = !!opts.devtools.panel;\n    if (\n      typeof opts.devtools.shortcut === 'string' &&\n      opts.devtools.shortcut.trim() !== ''\n    ) {\n      devtoolsShortcut = opts.devtools.shortcut;\n    }\n  } else {\n    // boolean or undefined\n    const enabled = (() => {\n      if (typeof opts.devtools === 'boolean') return opts.devtools;\n      try {\n        return (\n          typeof process !== 'undefined' &&\n          process.env.NODE_ENV !== 'production'\n        );\n      } catch {\n        return false;\n      }\n    })();\n    devtoolsGlobal = enabled;\n  }\n  // Initialize browser history manager\n  const history = new BrowserHistory();\n\n  // Build a flat list of routes for efficient matching\n  const flatRoutes = buildRoutes(routes);\n\n  // Find the initial route match and prepare it for rendering\n  const route = getMatchedRoute(flatRoutes, history.location);\n  const initialRawQuery = parseRawQuery(history.location.search);\n  // Determine unified schema (querySchema) from deepest route\n  let initialUnifiedSchema: any;\n  if (route != null) {\n    const collected: any[] = [];\n    for (const r of route.route.routes) {\n      const maybe = (r as unknown as { querySchema?: unknown }).querySchema;\n      if (maybe != null) collected.push(maybe);\n    }\n    if (collected.length > 0) initialUnifiedSchema = collected.at(-1);\n  }\n  let initialFilters: Record<string, unknown> | undefined;\n  let initialFilterDiagnostics: any[] | undefined;\n  if (initialUnifiedSchema != null) {\n    const parsed = parseFilters(history.location.search, initialUnifiedSchema);\n    initialFilters = parsed.filters as unknown as Record<string, unknown>;\n    initialFilterDiagnostics = parsed.diagnostics as unknown[];\n  }\n  const preparedMatch = prepareMatch(route, initialFilters);\n  // Helper to build the raw query object from a search string\n  let currentEntry: RouteEntry<any> = {\n    forceRerender: false,\n    location: history.location,\n    route,\n    preparedMatch,\n    rawSearch: history.location.search,\n    query: initialRawQuery,\n    // typedQuery removed (unified into filters/query)\n    filters: initialFilters,\n    filterDiagnostics: initialFilterDiagnostics,\n    activeQuerySchema: initialUnifiedSchema,\n  };\n\n  // Initial normalization pass (e.g., clamp page)\n  const initTyped = currentEntry.filters as unknown as\n    | Record<string, unknown>\n    | undefined;\n  let initPageNumeric: number | undefined;\n  if (initTyped != null) {\n    const rawPage = initTyped.page;\n    if (typeof rawPage === 'number') initPageNumeric = rawPage;\n    else if (\n      rawPage != null &&\n      typeof rawPage === 'object' &&\n      !Array.isArray(rawPage) &&\n      Object.prototype.hasOwnProperty.call(rawPage, 'eq') &&\n      typeof (rawPage as Record<string, unknown>).eq === 'number'\n    ) {\n      initPageNumeric = (rawPage as Record<string, unknown>).eq as number;\n    }\n  }\n  if (\n    typeof initPageNumeric === 'number' &&\n    initPageNumeric < 1 &&\n    initialUnifiedSchema != null &&\n    initTyped != null\n  ) {\n    const norm = { ...initTyped, page: { eq: 1 } } as Record<string, unknown>;\n    currentEntry.filters = norm; // immediate visibility\n    const normalizedSearch = buildCombinedSearch({\n      filters: norm,\n      querySchema: initialUnifiedSchema,\n    }); // returns '' or string starting with '?'\n    if (normalizedSearch !== history.location.search) {\n      history.set({\n        pathname: history.location.pathname,\n        search: normalizedSearch,\n        hash: '',\n      });\n      // Update currentEntry.location to reflect new search directly (history.set triggers async subscriber)\n      currentEntry = {\n        ...currentEntry,\n        location: { ...currentEntry.location, search: normalizedSearch },\n        rawSearch: normalizedSearch,\n      };\n    }\n  }\n\n  // Maintain a set of subscribers to the active route entry\n  let nextId = 0;\n  const subscribers = new Map<number, SubscribeCallback<any>>();\n\n  // Listen for location changes, match to the route entry, prepare the entry,\n  // and notify subscribers. This pattern ensures that data-loading\n  // occurs *outside* of - and *before* - rendering.\n  const cleanup = history.subscribe((location, forceRerender) => {\n    const samePathname = location.pathname === currentEntry.location.pathname;\n    const sameSearch = location.search === currentEntry.rawSearch;\n\n    if (!forceRerender && samePathname && sameSearch) {\n      // Nothing changed that we care about\n      return;\n    }\n\n    // If only the search changed we still want to propagate the change.\n    // Keep the existing preparedMatch when pathname is identical to avoid redundant work.\n    let nextPreparedMatch = currentEntry.preparedMatch;\n    let nextRoute = currentEntry.route;\n\n    if (!samePathname) {\n      // Path changed: recompute match + prepared data including query\n      nextRoute = getMatchedRoute(flatRoutes, history.location);\n      // we will set below after computing typed query\n    }\n\n    // Build raw query object (basic aggregation) from location.search\n    const query = parseRawQuery(location.search);\n    // Determine schema from deepest matched route\n    let querySchema: any;\n    if (nextRoute != null) {\n      const collected: any[] = [];\n      for (const r of nextRoute.route.routes) {\n        const maybeF = (r as unknown as { querySchema?: unknown }).querySchema;\n        if (maybeF != null) collected.push(maybeF);\n      }\n      if (collected.length > 0) {\n        querySchema = collected.at(-1);\n      }\n    }\n    // Parse unified filters\n    let filters: Record<string, unknown> | undefined;\n    let filterDiagnostics: any[] | undefined;\n    if (querySchema != null) {\n      const parsedF = parseFilters(location.search, querySchema);\n      filters = parsedF.filters as unknown as Record<string, unknown>;\n      filterDiagnostics = parsedF.diagnostics as unknown[];\n    }\n    // Normalization: clamp page >= 1 if numeric page present\n    let normalized = false;\n    let pg: unknown;\n    if (filters != null) {\n      const f: Record<string, unknown> = filters;\n      const maybe = f.page;\n      if (\n        maybe != null &&\n        typeof maybe === 'object' &&\n        !Array.isArray(maybe) &&\n        Object.prototype.hasOwnProperty.call(maybe, 'eq')\n      ) {\n        pg = (maybe as Record<string, unknown>).eq;\n      } else {\n        pg = maybe;\n      }\n    }\n    if (typeof pg === 'number' && pg < 1) {\n      const clone = { ...(filters as Record<string, any>), page: { eq: 1 } };\n      filters = clone;\n      normalized = true;\n    }\n\n    // If only the search changed (same pathname) we still need to re-run prepare\n    if (!samePathname || !sameSearch) {\n      nextPreparedMatch = prepareMatch(nextRoute, undefined);\n    }\n\n    const nextEntry: RouteEntry<any> = {\n      forceRerender: forceRerender || (samePathname && !sameSearch),\n      location,\n      route: nextRoute,\n      preparedMatch: nextPreparedMatch,\n      rawSearch: location.search,\n      query,\n      filters,\n      filterDiagnostics,\n      activeQuerySchema: querySchema,\n    };\n\n    // If normalization changed the typed query we trigger a replace with normalized search\n    if (normalized && querySchema != null) {\n      const normalizedSearch = buildCombinedSearch({\n        filters,\n        querySchema,\n      });\n      if (normalizedSearch !== location.search) {\n        let nextSearchStr = normalizedSearch;\n        if (!nextSearchStr.startsWith('?')) {\n          if (nextSearchStr === '') nextSearchStr = '';\n          else nextSearchStr = `?${nextSearchStr}`;\n        }\n        history.set({\n          pathname: location.pathname,\n          search: nextSearchStr,\n          hash: '',\n        });\n        return; // early: subsequent set will trigger rerun\n      }\n    }\n\n    // Update current entry and notify all subscribers\n    currentEntry = nextEntry;\n    subscribers.forEach((callback) => {\n      callback(nextEntry);\n    });\n  });\n\n  // The router context object that will be passed to React Context\n  const context: RoutingContextType<any> &\n    PreparedAccess<AnyRoute[]> & {\n      navigate: NavigateOverloads<AnyRoute[]>;\n    } = {\n    history,\n    get() {\n      return currentEntry;\n    },\n    preloadCode(pathname) {\n      // Preload just the component code for a route without storing the result\n      const matches = getMatchedRoute(flatRoutes, {\n        ...window.location,\n        pathname,\n      });\n\n      if (matches == null) {\n        return;\n      }\n\n      // Load all resource pages for the matched route\n      matches.route.routes.forEach(({ resourcePage }) => {\n        if (resourcePage == null) {\n          return;\n        }\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        resourcePage.load();\n      });\n    },\n    preload(pathname) {\n      // Preload both the component code and prepared data for a route\n      const matches = getMatchedRoute(flatRoutes, {\n        ...window.location,\n        pathname,\n      });\n      prepareMatch(matches);\n    },\n    subscribe(callback) {\n      // Add a new subscriber and return unsubscribe function\n      nextId += 1;\n      const id = nextId;\n      // eslint-disable-next-line func-style\n      const dispose = () => {\n        subscribers.delete(id);\n      };\n      subscribers.set(id, callback);\n      return dispose;\n    },\n    navigate({ pathname, query, filters: navFilters, replace }: any) {\n      const current = currentEntry;\n      const targetPathname = pathname ?? current.location.pathname;\n      // Determine schema of destination (if same path and we have route we can reuse, else rematch)\n      let destSchema: any;\n      /** Collect deepest query schema from route chain */\n      function collectSchema(routesArr: any[] | undefined): void {\n        if (routesArr == null) {\n          return;\n        }\n        const collected: any[] = [];\n        for (const r of routesArr) {\n          const maybeF = (r as unknown as { querySchema?: unknown })\n            .querySchema;\n          if (maybeF != null) collected.push(maybeF);\n        }\n        if (collected.length > 0) {\n          destSchema = collected.at(-1);\n        }\n      }\n      // Always attempt full match for destination to ensure schema present even if same pathname\n      const destRoute = getMatchedRoute(flatRoutes, {\n        ...window.location,\n        pathname: targetPathname,\n      });\n      collectSchema(destRoute?.route.routes);\n      // Fallback to currently active schema if destination schema not found (e.g., race conditions)\n      destSchema ??= current.activeQuerySchema;\n      const effectiveFilters = navFilters ?? current.filters;\n      // Treat legacy navigate({ query }) as filters in unified model for backward compatibility\n      const filtersInput =\n        effectiveFilters ?? (query as Record<string, unknown> | undefined);\n      const search = buildCombinedSearch({\n        filters: filtersInput,\n        querySchema: destSchema,\n      });\n      const locationObj = { pathname: targetPathname, search, hash: '' };\n      if (replace === true) {\n        history.set(locationObj);\n      } else {\n        history.push(locationObj);\n      }\n    },\n    getPrepared(path) {\n      try {\n        const entry = currentEntry;\n        // Find last prepared route with matching path\n        for (const pr of entry.preparedMatch.routes) {\n          if (pr.path === path) {\n            return pr.prepared as any;\n          }\n        }\n        return undefined;\n      } catch {\n        return undefined;\n      }\n    },\n    // getTypedQuery removed\n  };\n\n  // Return both the context object and a cleanup function\n  // Devtools exposure (development only)\n  if (devtoolsGlobal) {\n    try {\n      if (typeof window !== 'undefined') {\n        (window as unknown as { __PLUMILE_ROUTER__?: any }).__PLUMILE_ROUTER__ =\n          {\n            get: context.get,\n            subscribe: context.subscribe,\n          };\n      }\n    } catch {\n      /* ignore */\n    }\n  }\n  // Optional in-page devtools panel (lightweight overlay)\n  if (devtoolsPanel) {\n    try {\n      if (\n        typeof window !== 'undefined' &&\n        typeof document !== 'undefined' &&\n        document.querySelector('[data-plumile-router-devtools-panel]') == null\n      ) {\n        const host = document.createElement('div');\n        host.setAttribute('data-plumile-router-devtools-panel', '');\n        host.style.position = 'fixed';\n        host.style.zIndex = '2147483646';\n        host.style.bottom = '8px';\n        host.style.right = '8px';\n        host.style.fontFamily =\n          'ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, \"Liberation Mono\", monospace';\n        host.style.fontSize = '12px';\n        host.style.lineHeight = '1.3';\n        host.style.color = '#111';\n        host.style.background = 'transparent';\n        host.style.pointerEvents = 'none';\n        const shadow = host.attachShadow({ mode: 'open' });\n        const panel = document.createElement('div');\n        panel.style.pointerEvents = 'auto';\n        panel.style.minWidth = '260px';\n        panel.style.maxWidth = '420px';\n        panel.style.maxHeight = '50vh';\n        panel.style.overflow = 'auto';\n        panel.style.background = 'rgba(255,255,255,0.95)';\n        panel.style.border = '1px solid #ccc';\n        panel.style.borderRadius = '6px';\n        panel.style.boxShadow = '0 2px 8px rgba(0,0,0,0.15)';\n        panel.style.padding = '6px 8px 8px';\n        panel.style.backdropFilter = 'blur(4px)';\n        panel.style.display = 'flex';\n        panel.style.flexDirection = 'column';\n        panel.style.rowGap = '4px';\n        const header = document.createElement('div');\n        header.style.display = 'flex';\n        header.style.alignItems = 'center';\n        header.style.justifyContent = 'space-between';\n        header.style.gap = '8px';\n        const title = document.createElement('span');\n        title.textContent = 'Plumile Router';\n        title.style.fontWeight = '600';\n        const buttons = document.createElement('div');\n        buttons.style.display = 'flex';\n        buttons.style.gap = '4px';\n        const collapseBtn = document.createElement('button');\n        collapseBtn.textContent = '−';\n        const closeBtn = document.createElement('button');\n        closeBtn.textContent = '×';\n        const btns: HTMLButtonElement[] = [collapseBtn, closeBtn];\n        for (const b of btns) {\n          b.style.cursor = 'pointer';\n          b.style.background = '#eee';\n          b.style.border = '1px solid #ccc';\n          b.style.borderRadius = '4px';\n          b.style.fontSize = '11px';\n          b.style.lineHeight = '1';\n          b.style.padding = '2px 5px';\n        }\n        header.appendChild(title);\n        buttons.appendChild(collapseBtn);\n        buttons.appendChild(closeBtn);\n        header.appendChild(buttons);\n        const pathEl = document.createElement('div');\n        pathEl.style.whiteSpace = 'nowrap';\n        const varsEl = document.createElement('pre');\n        const queryEl = document.createElement('pre');\n        // typed query element removed\n        const filtersEl = document.createElement('pre');\n        const filterDiagEl = document.createElement('pre');\n        // Timeline container\n        const timelineWrap = document.createElement('div');\n        timelineWrap.style.display = 'flex';\n        timelineWrap.style.flexDirection = 'column';\n        timelineWrap.style.gap = '2px';\n        timelineWrap.style.marginTop = '4px';\n        const timelineHeader = document.createElement('div');\n        timelineHeader.textContent = 'Timeline (query changes)';\n        timelineHeader.style.fontWeight = '600';\n        timelineHeader.style.fontSize = '11px';\n        const timeline = document.createElement('div');\n        timeline.style.display = 'flex';\n        timeline.style.flexDirection = 'column-reverse'; // newest on top visually while appending at end for cheaper ops\n        timeline.style.maxHeight = '140px';\n        timeline.style.overflowY = 'auto';\n        timeline.style.border = '1px solid #e2e2e2';\n        timeline.style.borderRadius = '4px';\n        timeline.style.background = '#fafbfc';\n        timeline.style.fontFamily = 'inherit';\n        timeline.style.fontSize = '11px';\n        timelineWrap.appendChild(timelineHeader);\n        timelineWrap.appendChild(timeline);\n        const pres: HTMLPreElement[] = [\n          varsEl,\n          queryEl,\n          filtersEl,\n          filterDiagEl,\n        ];\n        for (const p of pres) {\n          p.style.margin = '0';\n          p.style.padding = '4px';\n          p.style.background = '#f6f8fa';\n          p.style.border = '1px solid #e2e2e2';\n          p.style.borderRadius = '4px';\n          p.style.overflowX = 'auto';\n          p.style.maxHeight = '160px';\n        }\n        const small = document.createElement('div');\n        small.style.fontSize = '10px';\n        small.style.opacity = '0.7';\n        small.textContent = `Shortcut: ${devtoolsShortcut}`;\n        panel.appendChild(header);\n        panel.appendChild(pathEl);\n        panel.appendChild(varsEl);\n        panel.appendChild(queryEl);\n        // typedEl removed\n        panel.appendChild(timelineWrap);\n        panel.appendChild(filtersEl);\n        panel.appendChild(filterDiagEl);\n        panel.appendChild(small);\n        shadow.appendChild(panel);\n        document.body.appendChild(host);\n        let collapsed = false;\n        collapseBtn.addEventListener('click', () => {\n          collapsed = !collapsed;\n          if (collapsed) {\n            panel.style.maxHeight = '24px';\n            panel.style.overflow = 'hidden';\n            collapseBtn.textContent = '+';\n          } else {\n            panel.style.maxHeight = '50vh';\n            panel.style.overflow = 'auto';\n            collapseBtn.textContent = '−';\n          }\n        });\n        let unsub: (() => void) | undefined;\n        closeBtn.addEventListener('click', () => {\n          host.remove();\n          if (typeof unsub === 'function') {\n            unsub();\n          }\n        });\n        /** Update panel content from current route entry */\n        // Keep last query snapshot for diff\n        let lastQuery: Record<string, unknown> | undefined;\n        let lastSearch: string | undefined;\n        /**\n         * Compute diff classification between two query objects.\n         */\n        function diffQueries(\n          prev: Record<string, unknown> | undefined,\n          next: Record<string, unknown>,\n        ): {\n          added: string[];\n          removed: string[];\n          changed: string[];\n          unchanged: string[];\n        } {\n          const added: string[] = [];\n          const removed: string[] = [];\n          const changed: string[] = [];\n          const unchanged: string[] = [];\n          const prevKeys = new Set(Object.keys(prev ?? {}));\n          const nextKeys = new Set(Object.keys(next));\n          nextKeys.forEach((k) => {\n            if (!prevKeys.has(k)) {\n              added.push(k);\n              return;\n            }\n            let pv: unknown;\n            if (prev != null) {\n              // prev is a plain record; direct index (runtime safe)\n              // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n              pv = (prev as any)[k];\n            }\n            const nv = next[k];\n            let same = false;\n            if (Array.isArray(pv) && Array.isArray(nv)) {\n              if (pv.length === (nv as unknown[]).length) {\n                same = pv.every((v, i) => {\n                  return v === (nv as unknown[])[i];\n                });\n              }\n            } else {\n              same = pv === nv;\n            }\n            if (same) {\n              unchanged.push(k);\n            } else {\n              changed.push(k);\n            }\n            prevKeys.delete(k);\n          });\n          prevKeys.forEach((k) => {\n            removed.push(k);\n          });\n          return { added, removed, changed, unchanged };\n        }\n        /** Update panel content and maybe push timeline entry */\n        function render(): void {\n          try {\n            const entry = context.get();\n            pathEl.textContent = `${entry.location.pathname}${entry.location.search}`;\n            const varsJson = JSON.stringify(entry.route?.params ?? {}, null, 2);\n            varsEl.textContent = `vars: ${varsJson}`;\n            const rawJson = JSON.stringify(entry.query, null, 2);\n            queryEl.textContent = `raw:  ${rawJson}`;\n            // typed query removed\n            const filtersJson = JSON.stringify(entry.filters, null, 2);\n            filtersEl.textContent = `filters:${filtersJson}`;\n            const diag = entry.filterDiagnostics ?? [];\n            filterDiagEl.textContent = `filterDiagnostics: ${diag.length}`;\n            // Timeline log if query search changed\n            if (entry.rawSearch !== lastSearch) {\n              const nowQuery = entry.query as Record<string, unknown>;\n              const diff = diffQueries(lastQuery, nowQuery);\n              const row = document.createElement('div');\n              row.style.display = 'flex';\n              row.style.flexDirection = 'column';\n              row.style.borderBottom = '1px solid #e9e9e9';\n              row.style.padding = '3px 4px';\n              const head = document.createElement('div');\n              head.style.display = 'flex';\n              head.style.justifyContent = 'space-between';\n              const ts = new Date().toLocaleTimeString();\n              let searchDisplay = '(empty)';\n              if (entry.location.search !== '') {\n                searchDisplay = entry.location.search;\n              }\n              head.innerHTML = `<strong>${ts}</strong> <code style=\"background:#eee;padding:1px 3px;border-radius:3px;\">${searchDisplay}</code>`;\n              const body = document.createElement('div');\n              body.style.display = 'flex';\n              body.style.flexWrap = 'wrap';\n              body.style.gap = '4px';\n              /** Create a colored pill element */\n              function pill(\n                label: string,\n                kind: 'added' | 'removed' | 'changed' | 'unchanged',\n              ): HTMLSpanElement {\n                const span = document.createElement('span');\n                span.textContent = label;\n                span.style.padding = '1px 4px';\n                span.style.borderRadius = '10px';\n                span.style.fontSize = '10px';\n                span.style.border = '1px solid';\n                switch (kind) {\n                  case 'added':\n                    span.style.background = '#e6ffed';\n                    span.style.borderColor = '#2cbe4e';\n                    span.style.color = '#22863a';\n                    break;\n                  case 'removed':\n                    span.style.background = '#ffeef0';\n                    span.style.borderColor = '#d73a49';\n                    span.style.color = '#cb2431';\n                    break;\n                  case 'changed':\n                    span.style.background = '#fff5b1';\n                    span.style.borderColor = '#ffd33d';\n                    span.style.color = '#735c0f';\n                    break;\n                  case 'unchanged':\n                    span.style.background = '#f1f8ff';\n                    span.style.borderColor = '#79b8ff';\n                    span.style.color = '#0366d6';\n                    break;\n                  default:\n                    break; // exhaustive\n                }\n                return span;\n              }\n              if (diff.added.length > 0) {\n                body.append(\n                  ...diff.added.map((k) => {\n                    return pill(`+${k}`, 'added');\n                  }),\n                );\n              }\n              if (diff.changed.length > 0) {\n                body.append(\n                  ...diff.changed.map((k) => {\n                    return pill(`~${k}`, 'changed');\n                  }),\n                );\n              }\n              if (diff.removed.length > 0) {\n                body.append(\n                  ...diff.removed.map((k) => {\n                    return pill(`-${k}`, 'removed');\n                  }),\n                );\n              }\n              const noAdds = diff.added.length === 0;\n              const noChanges = diff.changed.length === 0;\n              const noRemovals = diff.removed.length === 0;\n              if (noAdds && noChanges && noRemovals) {\n                body.append(pill('no-change', 'unchanged'));\n              }\n              row.appendChild(head);\n              row.appendChild(body);\n              timeline.appendChild(row);\n              if (timeline.childElementCount > 50) {\n                const first = timeline.firstElementChild;\n                if (first != null) {\n                  timeline.removeChild(first);\n                }\n              }\n              lastQuery = nowQuery;\n              lastSearch = entry.rawSearch;\n            }\n          } catch {\n            /* ignore */\n          }\n        }\n        render();\n        unsub = context.subscribe(() => {\n          render();\n        });\n        window.addEventListener('keydown', (ev) => {\n          try {\n            const parts: string[] = [];\n            if (ev.altKey) parts.push('Alt');\n            if (ev.shiftKey) parts.push('Shift');\n            if (ev.ctrlKey) parts.push('Ctrl');\n            let keyPart = ev.key;\n            if (ev.key.length === 1) {\n              keyPart = ev.key.toUpperCase();\n            }\n            parts.push(keyPart);\n            const combo = parts.join('+');\n            if (combo === devtoolsShortcut.replace(/\\s+/g, '')) {\n              if (host.style.display === 'none') {\n                host.style.display = 'block';\n              } else {\n                host.style.display = 'none';\n              }\n            }\n          } catch {\n            /* ignore */\n          }\n        });\n      }\n    } catch {\n      /* ignore */\n    }\n  }\n  return { cleanup, context } as CreateRouterReturn<any>;\n}\n"]}
614
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"createRouter.js","sourceRoot":"","sources":["../../../src/routing/createRouter.ts"],"names":[],"mappings":"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","sourcesContent":["import { buildRoutes } from '../builder.js';\nimport { BrowserHistory } from '../history/index.js';\nimport { getMatchedRoute, prepareMatch } from '../tools.js';\nimport { parseRawQuery } from '../tools/query.js';\nimport buildCombinedSearch from '../tools/buildCombinedSearch.js';\nimport { parse as parseFilters } from '@plumile/filter-query';\nimport type {\n  RouteEntry,\n  RoutingContextType,\n  SubscribeCallback,\n  AnyRoute,\n  PreparedAccess,\n  NavigateOverloads,\n} from '../types.js';\n\n/**\n * Return type for the createRouter function.\n */\nexport type CreateRouterReturn<R extends AnyRoute[]> = {\n  /** Function to clean up router listeners and resources */\n  cleanup: () => void;\n  /** Router context object for the React Context Provider */\n  context: RoutingContextType<any> & PreparedAccess<R>;\n};\n\n/**\n * Creates a complete router system from route configurations.\n *\n * This router is built from the same primitives as react-router but with additional\n * features for data preloading and code splitting. Each route can contain both a\n * Component and a prepare() function that can preload data for the component.\n *\n * The router watches for changes to the current location via the HTML5 History API,\n * maps the location to the corresponding route entry, and then preloads the code\n * and data for the route before rendering.\n *\n * @param routes - Array of route configurations\n * @returns Object containing the router context and cleanup function\n *\n  preparedMatch: prepareMatch(route, parseRawQuery(history.location.search)),\n * ```typescript\n * const routes = [\n *   {\n *     path: '/users/:id',\n *     resourcePage: getResourcePage('UserProfile', () => import('./UserProfile')),\n *     prepare: ({ variables }) => ({ userId: variables.id })\n *   }\n * ];\n *\n * const { context, cleanup } = createRouter(routes);\n *\n * // Use in React app\n * <RoutingContext.Provider value={context}>\n *   <RouterRenderer />\n * </RoutingContext.Provider>\n * ```\n */\n/**\n * Create a router (typed overload). When called with a const tuple of routes, generics are preserved.\n */\nexport default function createRouter<R extends AnyRoute[]>(\n  routes: [...R] | AnyRoute[],\n  opts: {\n    devtools?:\n      | boolean\n      | { global?: boolean; panel?: boolean; shortcut?: string };\n  } = {},\n): CreateRouterReturn<R extends AnyRoute[] ? R : AnyRoute[]> {\n  // Normalize devtools options maintaining backwards compatibility\n  let devtoolsGlobal: boolean;\n  let devtoolsPanel = false;\n  let devtoolsShortcut = 'Alt+Shift+R';\n  if (typeof opts.devtools === 'object') {\n    const baseEnabled = (() => {\n      try {\n        return (\n          typeof process !== 'undefined' &&\n          process.env.NODE_ENV !== 'production'\n        );\n      } catch {\n        return false;\n      }\n    })();\n    devtoolsGlobal = opts.devtools.global ?? baseEnabled;\n    devtoolsPanel = !!opts.devtools.panel;\n    if (\n      typeof opts.devtools.shortcut === 'string' &&\n      opts.devtools.shortcut.trim() !== ''\n    ) {\n      devtoolsShortcut = opts.devtools.shortcut;\n    }\n  } else {\n    // boolean or undefined\n    const enabled = (() => {\n      if (typeof opts.devtools === 'boolean') return opts.devtools;\n      try {\n        return (\n          typeof process !== 'undefined' &&\n          process.env.NODE_ENV !== 'production'\n        );\n      } catch {\n        return false;\n      }\n    })();\n    devtoolsGlobal = enabled;\n  }\n  // Initialize browser history manager\n  const history = new BrowserHistory();\n\n  // Build a flat list of routes for efficient matching\n  const flatRoutes = buildRoutes(routes);\n\n  // Find the initial route match and prepare it for rendering\n  const route = getMatchedRoute(flatRoutes, history.location);\n  const initialRawQuery = parseRawQuery(history.location.search);\n  // Direct schema: only the matched route's own querySchema (no hierarchical discovery)\n  let initialUnifiedSchema: any;\n  if (route != null) {\n    const last = route.route.routes.at(-1) as unknown as {\n      querySchema?: unknown;\n    } | null;\n    if (last != null) {\n      initialUnifiedSchema = last.querySchema;\n    }\n  }\n  let initialFilters: Record<string, unknown> | undefined;\n  let initialFilterDiagnostics: any[] | undefined;\n  if (initialUnifiedSchema != null) {\n    const parsed = parseFilters(history.location.search, initialUnifiedSchema);\n    initialFilters = parsed.filters as unknown as Record<string, unknown>;\n    initialFilterDiagnostics = parsed.diagnostics as unknown[];\n  }\n  const preparedMatch = prepareMatch(route, initialFilters);\n  // Helper to build the raw query object from a search string\n  let currentEntry: RouteEntry<any> = {\n    forceRerender: false,\n    location: history.location,\n    route,\n    preparedMatch,\n    rawSearch: history.location.search,\n    query: initialRawQuery,\n    // typedQuery removed (unified into filters/query)\n    filters: initialFilters,\n    filterDiagnostics: initialFilterDiagnostics,\n    activeQuerySchema: initialUnifiedSchema,\n  };\n\n  // Initial normalization pass (e.g., clamp page)\n  const initTyped = currentEntry.filters as unknown as\n    | Record<string, unknown>\n    | undefined;\n  let initPageNumeric: number | undefined;\n  if (initTyped != null) {\n    const rawPage = initTyped.page;\n    if (typeof rawPage === 'number') initPageNumeric = rawPage;\n    else if (\n      rawPage != null &&\n      typeof rawPage === 'object' &&\n      !Array.isArray(rawPage) &&\n      Object.prototype.hasOwnProperty.call(rawPage, 'eq') &&\n      typeof (rawPage as Record<string, unknown>).eq === 'number'\n    ) {\n      initPageNumeric = (rawPage as Record<string, unknown>).eq as number;\n    }\n  }\n  if (\n    typeof initPageNumeric === 'number' &&\n    initPageNumeric < 1 &&\n    initialUnifiedSchema != null &&\n    initTyped != null\n  ) {\n    const norm = { ...initTyped, page: { eq: 1 } } as Record<string, unknown>;\n    currentEntry.filters = norm; // immediate visibility\n    const normalizedSearch = buildCombinedSearch({\n      filters: norm,\n      querySchema: initialUnifiedSchema,\n    }); // returns '' or string starting with '?'\n    if (normalizedSearch !== history.location.search) {\n      history.set({\n        pathname: history.location.pathname,\n        search: normalizedSearch,\n        hash: '',\n      });\n      // Update currentEntry.location to reflect new search directly (history.set triggers async subscriber)\n      currentEntry = {\n        ...currentEntry,\n        location: { ...currentEntry.location, search: normalizedSearch },\n        rawSearch: normalizedSearch,\n      };\n    }\n  }\n\n  // Maintain a set of subscribers to the active route entry\n  let nextId = 0;\n  const subscribers = new Map<number, SubscribeCallback<any>>();\n\n  // Listen for location changes, match to the route entry, prepare the entry,\n  // and notify subscribers. This pattern ensures that data-loading\n  // occurs *outside* of - and *before* - rendering.\n  const cleanup = history.subscribe((location, forceRerender) => {\n    const samePathname = location.pathname === currentEntry.location.pathname;\n    const sameSearch = location.search === currentEntry.rawSearch;\n\n    if (!forceRerender && samePathname && sameSearch) {\n      // Nothing changed that we care about\n      return;\n    }\n\n    // If only the search changed we still want to propagate the change.\n    // Keep the existing preparedMatch when pathname is identical to avoid redundant work.\n    let nextPreparedMatch = currentEntry.preparedMatch;\n    let nextRoute = currentEntry.route;\n\n    if (!samePathname) {\n      // Path changed: recompute match + prepared data including query\n      nextRoute = getMatchedRoute(flatRoutes, history.location);\n      // we will set below after computing typed query\n    }\n\n    // Build raw query object (basic aggregation) from location.search\n    const query = parseRawQuery(location.search);\n    // Determine schema from deepest matched route\n    let querySchema: any;\n    if (nextRoute != null) {\n      const last = nextRoute.route.routes.at(-1) as unknown as {\n        querySchema?: unknown;\n      } | null;\n      if (last != null) {\n        querySchema = last.querySchema;\n      }\n    }\n    // Parse unified filters\n    let filters: Record<string, unknown> | undefined;\n    let filterDiagnostics: any[] | undefined;\n    if (querySchema != null) {\n      const parsedF = parseFilters(location.search, querySchema);\n      filters = parsedF.filters as unknown as Record<string, unknown>;\n      filterDiagnostics = parsedF.diagnostics as unknown[];\n    }\n    // Normalization: clamp page >= 1 if numeric page present\n    let normalized = false;\n    let pg: unknown;\n    if (filters != null) {\n      const f: Record<string, unknown> = filters;\n      const maybe = f.page;\n      if (\n        maybe != null &&\n        typeof maybe === 'object' &&\n        !Array.isArray(maybe) &&\n        Object.prototype.hasOwnProperty.call(maybe, 'eq')\n      ) {\n        pg = (maybe as Record<string, unknown>).eq;\n      } else {\n        pg = maybe;\n      }\n    }\n    if (typeof pg === 'number' && pg < 1) {\n      const clone = { ...(filters as Record<string, any>), page: { eq: 1 } };\n      filters = clone;\n      normalized = true;\n    }\n\n    // If only the search changed (same pathname) we still need to re-run prepare\n    if (!samePathname || !sameSearch) {\n      nextPreparedMatch = prepareMatch(nextRoute, undefined);\n    }\n\n    const nextEntry: RouteEntry<any> = {\n      forceRerender: forceRerender || (samePathname && !sameSearch),\n      location,\n      route: nextRoute,\n      preparedMatch: nextPreparedMatch,\n      rawSearch: location.search,\n      query,\n      filters,\n      filterDiagnostics,\n      activeQuerySchema: querySchema,\n    };\n\n    // If normalization changed the typed query we trigger a replace with normalized search\n    if (normalized && querySchema != null) {\n      const normalizedSearch = buildCombinedSearch({\n        filters,\n        querySchema,\n      });\n      if (normalizedSearch !== location.search) {\n        let nextSearchStr = normalizedSearch;\n        if (!nextSearchStr.startsWith('?')) {\n          if (nextSearchStr === '') nextSearchStr = '';\n          else nextSearchStr = `?${nextSearchStr}`;\n        }\n        history.set({\n          pathname: location.pathname,\n          search: nextSearchStr,\n          hash: '',\n        });\n        return; // early: subsequent set will trigger rerun\n      }\n    }\n\n    // Update current entry and notify all subscribers\n    currentEntry = nextEntry;\n    subscribers.forEach((callback) => {\n      callback(nextEntry);\n    });\n  });\n\n  // The router context object that will be passed to React Context\n  const context: RoutingContextType<any> &\n    PreparedAccess<AnyRoute[]> & {\n      navigate: NavigateOverloads<AnyRoute[]>;\n    } = {\n    history,\n    get() {\n      return currentEntry;\n    },\n    preloadCode(pathname) {\n      // Preload just the component code for a route without storing the result\n      const matches = getMatchedRoute(flatRoutes, {\n        ...window.location,\n        pathname,\n      });\n\n      if (matches == null) {\n        return;\n      }\n\n      // Load all resource pages for the matched route\n      matches.route.routes.forEach(({ resourcePage }) => {\n        if (resourcePage == null) {\n          return;\n        }\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        resourcePage.load();\n      });\n    },\n    preload(pathname) {\n      // Preload both the component code and prepared data for a route\n      const matches = getMatchedRoute(flatRoutes, {\n        ...window.location,\n        pathname,\n      });\n      prepareMatch(matches);\n    },\n    subscribe(callback) {\n      // Add a new subscriber and return unsubscribe function\n      nextId += 1;\n      const id = nextId;\n      // eslint-disable-next-line func-style\n      const dispose = () => {\n        subscribers.delete(id);\n      };\n      subscribers.set(id, callback);\n      return dispose;\n    },\n    navigate({ pathname, query, filters: navFilters, replace }: any) {\n      const current = currentEntry;\n      const targetPathname = pathname ?? current.location.pathname;\n      // Determine schema of destination (if same path and we have route we can reuse, else rematch)\n      let destSchema: any;\n      // Always attempt full match for destination to ensure schema present even if same pathname\n      const destRoute = getMatchedRoute(flatRoutes, {\n        ...window.location,\n        pathname: targetPathname,\n      });\n      if (destRoute != null) {\n        const last = destRoute.route.routes.at(-1) as unknown as {\n          querySchema?: unknown;\n        } | null;\n        if (last != null) {\n          destSchema = last.querySchema;\n        }\n      }\n      // Fallback to currently active schema if destination schema not found (e.g., race conditions)\n      destSchema ??= current.activeQuerySchema;\n      const effectiveFilters = navFilters ?? current.filters;\n      // Treat legacy navigate({ query }) as filters in unified model for backward compatibility\n      const filtersInput =\n        effectiveFilters ?? (query as Record<string, unknown> | undefined);\n      const search = buildCombinedSearch({\n        filters: filtersInput,\n        querySchema: destSchema,\n      });\n      const locationObj = { pathname: targetPathname, search, hash: '' };\n      if (replace === true) {\n        history.set(locationObj);\n      } else {\n        history.push(locationObj);\n      }\n    },\n    getPrepared(path) {\n      try {\n        const entry = currentEntry;\n        // Find last prepared route with matching path\n        for (const pr of entry.preparedMatch.routes) {\n          if (pr.path === path) {\n            return pr.prepared as any;\n          }\n        }\n        return undefined;\n      } catch {\n        return undefined;\n      }\n    },\n    // getTypedQuery removed\n  };\n\n  // Return both the context object and a cleanup function\n  // Devtools exposure (development only)\n  if (devtoolsGlobal) {\n    try {\n      if (typeof window !== 'undefined') {\n        (window as unknown as { __PLUMILE_ROUTER__?: any }).__PLUMILE_ROUTER__ =\n          {\n            get: context.get,\n            subscribe: context.subscribe,\n          };\n      }\n    } catch {\n      /* ignore */\n    }\n  }\n  // Optional in-page devtools panel (lightweight overlay)\n  if (devtoolsPanel) {\n    try {\n      if (\n        typeof window !== 'undefined' &&\n        typeof document !== 'undefined' &&\n        document.querySelector('[data-plumile-router-devtools-panel]') == null\n      ) {\n        const host = document.createElement('div');\n        host.setAttribute('data-plumile-router-devtools-panel', '');\n        host.style.position = 'fixed';\n        host.style.zIndex = '2147483646';\n        host.style.bottom = '8px';\n        host.style.right = '8px';\n        host.style.fontFamily =\n          'ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, \"Liberation Mono\", monospace';\n        host.style.fontSize = '12px';\n        host.style.lineHeight = '1.3';\n        host.style.color = '#111';\n        host.style.background = 'transparent';\n        host.style.pointerEvents = 'none';\n        const shadow = host.attachShadow({ mode: 'open' });\n        const panel = document.createElement('div');\n        panel.style.pointerEvents = 'auto';\n        panel.style.minWidth = '260px';\n        panel.style.maxWidth = '420px';\n        panel.style.maxHeight = '50vh';\n        panel.style.overflow = 'auto';\n        panel.style.background = 'rgba(255,255,255,0.95)';\n        panel.style.border = '1px solid #ccc';\n        panel.style.borderRadius = '6px';\n        panel.style.boxShadow = '0 2px 8px rgba(0,0,0,0.15)';\n        panel.style.padding = '6px 8px 8px';\n        panel.style.backdropFilter = 'blur(4px)';\n        panel.style.display = 'flex';\n        panel.style.flexDirection = 'column';\n        panel.style.rowGap = '4px';\n        const header = document.createElement('div');\n        header.style.display = 'flex';\n        header.style.alignItems = 'center';\n        header.style.justifyContent = 'space-between';\n        header.style.gap = '8px';\n        const title = document.createElement('span');\n        title.textContent = 'Plumile Router';\n        title.style.fontWeight = '600';\n        const buttons = document.createElement('div');\n        buttons.style.display = 'flex';\n        buttons.style.gap = '4px';\n        const collapseBtn = document.createElement('button');\n        collapseBtn.textContent = '−';\n        const closeBtn = document.createElement('button');\n        closeBtn.textContent = '×';\n        const btns: HTMLButtonElement[] = [collapseBtn, closeBtn];\n        for (const b of btns) {\n          b.style.cursor = 'pointer';\n          b.style.background = '#eee';\n          b.style.border = '1px solid #ccc';\n          b.style.borderRadius = '4px';\n          b.style.fontSize = '11px';\n          b.style.lineHeight = '1';\n          b.style.padding = '2px 5px';\n        }\n        header.appendChild(title);\n        buttons.appendChild(collapseBtn);\n        buttons.appendChild(closeBtn);\n        header.appendChild(buttons);\n        const pathEl = document.createElement('div');\n        pathEl.style.whiteSpace = 'nowrap';\n        const varsEl = document.createElement('pre');\n        const queryEl = document.createElement('pre');\n        // typed query element removed\n        const filtersEl = document.createElement('pre');\n        const filterDiagEl = document.createElement('pre');\n        // Timeline container\n        const timelineWrap = document.createElement('div');\n        timelineWrap.style.display = 'flex';\n        timelineWrap.style.flexDirection = 'column';\n        timelineWrap.style.gap = '2px';\n        timelineWrap.style.marginTop = '4px';\n        const timelineHeader = document.createElement('div');\n        timelineHeader.textContent = 'Timeline (query changes)';\n        timelineHeader.style.fontWeight = '600';\n        timelineHeader.style.fontSize = '11px';\n        const timeline = document.createElement('div');\n        timeline.style.display = 'flex';\n        timeline.style.flexDirection = 'column-reverse'; // newest on top visually while appending at end for cheaper ops\n        timeline.style.maxHeight = '140px';\n        timeline.style.overflowY = 'auto';\n        timeline.style.border = '1px solid #e2e2e2';\n        timeline.style.borderRadius = '4px';\n        timeline.style.background = '#fafbfc';\n        timeline.style.fontFamily = 'inherit';\n        timeline.style.fontSize = '11px';\n        timelineWrap.appendChild(timelineHeader);\n        timelineWrap.appendChild(timeline);\n        const pres: HTMLPreElement[] = [\n          varsEl,\n          queryEl,\n          filtersEl,\n          filterDiagEl,\n        ];\n        for (const p of pres) {\n          p.style.margin = '0';\n          p.style.padding = '4px';\n          p.style.background = '#f6f8fa';\n          p.style.border = '1px solid #e2e2e2';\n          p.style.borderRadius = '4px';\n          p.style.overflowX = 'auto';\n          p.style.maxHeight = '160px';\n        }\n        const small = document.createElement('div');\n        small.style.fontSize = '10px';\n        small.style.opacity = '0.7';\n        small.textContent = `Shortcut: ${devtoolsShortcut}`;\n        panel.appendChild(header);\n        panel.appendChild(pathEl);\n        panel.appendChild(varsEl);\n        panel.appendChild(queryEl);\n        // typedEl removed\n        panel.appendChild(timelineWrap);\n        panel.appendChild(filtersEl);\n        panel.appendChild(filterDiagEl);\n        panel.appendChild(small);\n        shadow.appendChild(panel);\n        document.body.appendChild(host);\n        let collapsed = false;\n        collapseBtn.addEventListener('click', () => {\n          collapsed = !collapsed;\n          if (collapsed) {\n            panel.style.maxHeight = '24px';\n            panel.style.overflow = 'hidden';\n            collapseBtn.textContent = '+';\n          } else {\n            panel.style.maxHeight = '50vh';\n            panel.style.overflow = 'auto';\n            collapseBtn.textContent = '−';\n          }\n        });\n        let unsub: (() => void) | undefined;\n        closeBtn.addEventListener('click', () => {\n          host.remove();\n          if (typeof unsub === 'function') {\n            unsub();\n          }\n        });\n        /** Update panel content from current route entry */\n        // Keep last query snapshot for diff\n        let lastQuery: Record<string, unknown> | undefined;\n        let lastSearch: string | undefined;\n        /**\n         * Compute diff classification between two query objects.\n         */\n        function diffQueries(\n          prev: Record<string, unknown> | undefined,\n          next: Record<string, unknown>,\n        ): {\n          added: string[];\n          removed: string[];\n          changed: string[];\n          unchanged: string[];\n        } {\n          const added: string[] = [];\n          const removed: string[] = [];\n          const changed: string[] = [];\n          const unchanged: string[] = [];\n          const prevKeys = new Set(Object.keys(prev ?? {}));\n          const nextKeys = new Set(Object.keys(next));\n          nextKeys.forEach((k) => {\n            if (!prevKeys.has(k)) {\n              added.push(k);\n              return;\n            }\n            let pv: unknown;\n            if (prev != null) {\n              // prev is a plain record; direct index (runtime safe)\n              // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n              pv = (prev as any)[k];\n            }\n            const nv = next[k];\n            let same = false;\n            if (Array.isArray(pv) && Array.isArray(nv)) {\n              if (pv.length === (nv as unknown[]).length) {\n                same = pv.every((v, i) => {\n                  return v === (nv as unknown[])[i];\n                });\n              }\n            } else {\n              same = pv === nv;\n            }\n            if (same) {\n              unchanged.push(k);\n            } else {\n              changed.push(k);\n            }\n            prevKeys.delete(k);\n          });\n          prevKeys.forEach((k) => {\n            removed.push(k);\n          });\n          return { added, removed, changed, unchanged };\n        }\n        /** Update panel content and maybe push timeline entry */\n        function render(): void {\n          try {\n            const entry = context.get();\n            pathEl.textContent = `${entry.location.pathname}${entry.location.search}`;\n            const varsJson = JSON.stringify(entry.route?.params ?? {}, null, 2);\n            varsEl.textContent = `vars: ${varsJson}`;\n            const rawJson = JSON.stringify(entry.query, null, 2);\n            queryEl.textContent = `raw:  ${rawJson}`;\n            // typed query removed\n            const filtersJson = JSON.stringify(entry.filters, null, 2);\n            filtersEl.textContent = `filters:${filtersJson}`;\n            const diag = entry.filterDiagnostics ?? [];\n            filterDiagEl.textContent = `filterDiagnostics: ${diag.length}`;\n            // Timeline log if query search changed\n            if (entry.rawSearch !== lastSearch) {\n              const nowQuery = entry.query as Record<string, unknown>;\n              const diff = diffQueries(lastQuery, nowQuery);\n              const row = document.createElement('div');\n              row.style.display = 'flex';\n              row.style.flexDirection = 'column';\n              row.style.borderBottom = '1px solid #e9e9e9';\n              row.style.padding = '3px 4px';\n              const head = document.createElement('div');\n              head.style.display = 'flex';\n              head.style.justifyContent = 'space-between';\n              const ts = new Date().toLocaleTimeString();\n              let searchDisplay = '(empty)';\n              if (entry.location.search !== '') {\n                searchDisplay = entry.location.search;\n              }\n              head.innerHTML = `<strong>${ts}</strong> <code style=\"background:#eee;padding:1px 3px;border-radius:3px;\">${searchDisplay}</code>`;\n              const body = document.createElement('div');\n              body.style.display = 'flex';\n              body.style.flexWrap = 'wrap';\n              body.style.gap = '4px';\n              /** Create a colored pill element */\n              function pill(\n                label: string,\n                kind: 'added' | 'removed' | 'changed' | 'unchanged',\n              ): HTMLSpanElement {\n                const span = document.createElement('span');\n                span.textContent = label;\n                span.style.padding = '1px 4px';\n                span.style.borderRadius = '10px';\n                span.style.fontSize = '10px';\n                span.style.border = '1px solid';\n                switch (kind) {\n                  case 'added':\n                    span.style.background = '#e6ffed';\n                    span.style.borderColor = '#2cbe4e';\n                    span.style.color = '#22863a';\n                    break;\n                  case 'removed':\n                    span.style.background = '#ffeef0';\n                    span.style.borderColor = '#d73a49';\n                    span.style.color = '#cb2431';\n                    break;\n                  case 'changed':\n                    span.style.background = '#fff5b1';\n                    span.style.borderColor = '#ffd33d';\n                    span.style.color = '#735c0f';\n                    break;\n                  case 'unchanged':\n                    span.style.background = '#f1f8ff';\n                    span.style.borderColor = '#79b8ff';\n                    span.style.color = '#0366d6';\n                    break;\n                  default:\n                    break; // exhaustive\n                }\n                return span;\n              }\n              if (diff.added.length > 0) {\n                body.append(\n                  ...diff.added.map((k) => {\n                    return pill(`+${k}`, 'added');\n                  }),\n                );\n              }\n              if (diff.changed.length > 0) {\n                body.append(\n                  ...diff.changed.map((k) => {\n                    return pill(`~${k}`, 'changed');\n                  }),\n                );\n              }\n              if (diff.removed.length > 0) {\n                body.append(\n                  ...diff.removed.map((k) => {\n                    return pill(`-${k}`, 'removed');\n                  }),\n                );\n              }\n              const noAdds = diff.added.length === 0;\n              const noChanges = diff.changed.length === 0;\n              const noRemovals = diff.removed.length === 0;\n              if (noAdds && noChanges && noRemovals) {\n                body.append(pill('no-change', 'unchanged'));\n              }\n              row.appendChild(head);\n              row.appendChild(body);\n              timeline.appendChild(row);\n              if (timeline.childElementCount > 50) {\n                const first = timeline.firstElementChild;\n                if (first != null) {\n                  timeline.removeChild(first);\n                }\n              }\n              lastQuery = nowQuery;\n              lastSearch = entry.rawSearch;\n            }\n          } catch {\n            /* ignore */\n          }\n        }\n        render();\n        unsub = context.subscribe(() => {\n          render();\n        });\n        window.addEventListener('keydown', (ev) => {\n          try {\n            const parts: string[] = [];\n            if (ev.altKey) parts.push('Alt');\n            if (ev.shiftKey) parts.push('Shift');\n            if (ev.ctrlKey) parts.push('Ctrl');\n            let keyPart = ev.key;\n            if (ev.key.length === 1) {\n              keyPart = ev.key.toUpperCase();\n            }\n            parts.push(keyPart);\n            const combo = parts.join('+');\n            if (combo === devtoolsShortcut.replace(/\\s+/g, '')) {\n              if (host.style.display === 'none') {\n                host.style.display = 'block';\n              } else {\n                host.style.display = 'none';\n              }\n            }\n          } catch {\n            /* ignore */\n          }\n        });\n      }\n    } catch {\n      /* ignore */\n    }\n  }\n  return { cleanup, context } as CreateRouterReturn<any>;\n}\n"]}
@@ -1,16 +1,3 @@
1
- export type FilterActions = {
2
- set: (field: string, operator: string, value: unknown | undefined, opts?: {
3
- replace?: boolean;
4
- }) => void;
5
- remove: (field: string, operator?: string, opts?: {
6
- replace?: boolean;
7
- }) => void;
8
- merge: (patch: Record<string, unknown>, opts?: {
9
- replace?: boolean;
10
- }) => void;
11
- clear: (opts?: {
12
- replace?: boolean;
13
- }) => void;
14
- };
15
- export default function useFilters(): [Record<string, unknown>, FilterActions];
1
+ import type { FilterSchema, TypedFilterActions, InferFilters } from '../types.js';
2
+ export default function useFilters<S extends FilterSchema>(schema: S): [InferFilters<S>, TypedFilterActions<S>];
16
3
  //# sourceMappingURL=useFilters.d.ts.map