UNPKG

@tanstack/router-core

Version:

Modern and scalable routing for React applications

51 lines (50 loc) 1.65 kB
import { GLOBAL_TSR } from "../constants.js"; import { createPlugin } from "seroval"; //#region src/ssr/serializer/transformer.ts /** * Create a strongly-typed serialization adapter for SSR hydration. * Use to register custom types with the router serializer. */ function createSerializationAdapter(opts) { return opts; } /** Create a Seroval plugin for server-side serialization only. */ function makeSsrSerovalPlugin(serializationAdapter, options) { return createPlugin({ tag: "$TSR/t/" + serializationAdapter.key, test: serializationAdapter.test, parse: { stream(value, ctx) { return ctx.parse(serializationAdapter.toSerializable(value)); } }, serialize(node, ctx) { options.didRun = true; return GLOBAL_TSR + ".t.get(\"" + serializationAdapter.key + "\")(" + ctx.serialize(node) + ")"; }, deserialize: void 0 }); } /** Create a Seroval plugin for client/server symmetric (de)serialization. */ function makeSerovalPlugin(serializationAdapter) { return createPlugin({ tag: "$TSR/t/" + serializationAdapter.key, test: serializationAdapter.test, parse: { sync(value, ctx) { return ctx.parse(serializationAdapter.toSerializable(value)); }, async async(value, ctx) { return await ctx.parse(serializationAdapter.toSerializable(value)); }, stream(value, ctx) { return ctx.parse(serializationAdapter.toSerializable(value)); } }, serialize: void 0, deserialize(node, ctx) { return serializationAdapter.fromSerializable(ctx.deserialize(node)); } }); } //#endregion export { createSerializationAdapter, makeSerovalPlugin, makeSsrSerovalPlugin }; //# sourceMappingURL=transformer.js.map