Add payload plugin for ClientSchedule
Add plugin to serialise ClientSchedule objects as JSON when it's passed from the server to client on SSR requests.
This commit is contained in:
parent
fb7a60db28
commit
73bb12c104
3 changed files with 28 additions and 2 deletions
|
@ -1,6 +1,7 @@
|
||||||
// https://nuxt.com/docs/api/configuration/nuxt-config
|
// https://nuxt.com/docs/api/configuration/nuxt-config
|
||||||
const enableDevtools = !process.env.DISABLE_DEV_TOOLS
|
const enableDevtools = !process.env.DISABLE_DEV_TOOLS
|
||||||
export default defineNuxtConfig({
|
export default defineNuxtConfig({
|
||||||
|
experimental: { renderJsonPayloads: true },
|
||||||
compatibilityDate: '2024-11-01',
|
compatibilityDate: '2024-11-01',
|
||||||
devtools: { enabled: enableDevtools },
|
devtools: { enabled: enableDevtools },
|
||||||
runtimeConfig: {
|
runtimeConfig: {
|
||||||
|
|
25
plugins/schedule-payload-type.ts
Normal file
25
plugins/schedule-payload-type.ts
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
import { Info } from "~/shared/utils/luxon";
|
||||||
|
|
||||||
|
export default definePayloadPlugin(() => {
|
||||||
|
definePayloadReducer(
|
||||||
|
"ClientSchedule",
|
||||||
|
data => {
|
||||||
|
if (!(data instanceof ClientSchedule)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const accountStore = useAccountStore();
|
||||||
|
return {
|
||||||
|
timezone: accountStore.activeTimezone,
|
||||||
|
locale: accountStore.activeLocale,
|
||||||
|
api: data.toApi(false)
|
||||||
|
};
|
||||||
|
},
|
||||||
|
);
|
||||||
|
definePayloadReviver(
|
||||||
|
"ClientSchedule",
|
||||||
|
({ timezone, locale, api }) => {
|
||||||
|
const zone = Info.normalizeZone(timezone);
|
||||||
|
return ClientSchedule.fromApi(api, { zone, locale })
|
||||||
|
},
|
||||||
|
);
|
||||||
|
});
|
|
@ -1,5 +1,5 @@
|
||||||
// Wrapper around Luxon to make sure the throwOnInvalid option is set
|
// Wrapper around Luxon to make sure the throwOnInvalid option is set
|
||||||
import { Settings, DateTime, FixedOffsetZone, Zone } from "luxon";
|
import { DateTime, FixedOffsetZone, Info, Settings, Zone } from "luxon";
|
||||||
|
|
||||||
Settings.throwOnInvalid = true;
|
Settings.throwOnInvalid = true;
|
||||||
declare module 'luxon' {
|
declare module 'luxon' {
|
||||||
|
@ -8,4 +8,4 @@ declare module 'luxon' {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export { DateTime, FixedOffsetZone, Zone }
|
export { DateTime, FixedOffsetZone, Info, Zone }
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue