From 7de0c1254709ab1c4021b340babd3b134e639f39 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Fri, 30 Aug 2024 11:43:07 +0200 Subject: [PATCH 01/11] add two suggestions for testing --- languages.ts | 12 ++ package-lock.json | 197 +++++++++++++++++++- package.json | 2 + studioShared/deskStructure.ts | 66 +++++++ studioShared/sanity.config.ts | 22 ++- studioShared/schemas/documents/blogPosts.ts | 15 +- 6 files changed, 304 insertions(+), 10 deletions(-) create mode 100644 languages.ts create mode 100644 studioShared/deskStructure.ts diff --git a/languages.ts b/languages.ts new file mode 100644 index 000000000..915dfaf2a --- /dev/null +++ b/languages.ts @@ -0,0 +1,12 @@ +const languages = [ + { id: "en", title: "English", isDefault: true }, + { id: "se", title: "Swedish" }, + { id: "no", title: "Norwegian" }, +]; + +const i18n = { + languages, + base: "en", +}; + +export { i18n }; diff --git a/package-lock.json b/package-lock.json index d0401ed61..48e858f5b 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,6 +9,7 @@ "version": "0.1.0", "dependencies": { "@google-cloud/pubsub": "^4.5.0", + "@sanity/document-internationalization": "^3.0.1", "@sanity/image-url": "^1.0.2", "@sanity/preview-url-secret": "^1.6.11", "@sanity/react-loader": "^1.9.15", @@ -20,6 +21,7 @@ "react-dom": "^18", "react-focus-on": "^3.9.3", "sanity": "^3.50.0", + "sanity-plugin-documents-pane": "^2.3.0", "styled-components": "^6.1.8" }, "devDependencies": { @@ -4840,6 +4842,42 @@ "node": ">=10" } }, + "node_modules/@sanity/assist": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/@sanity/assist/-/assist-3.0.6.tgz", + "integrity": "sha512-CFbpY+eI5CCEuYq61tFtKql1SAbxkT0KHECcWjRWthwBaGuePwrZt/9T/kPr0T4YWIPyH/NJc4b/bIM0dhYa6A==", + "license": "MIT", + "dependencies": { + "@sanity/icons": "^2.11.7", + "@sanity/incompatible-plugin": "^1.0.4", + "@sanity/ui": "^2.1.0", + "date-fns": "^3.6.0", + "lodash": "^4.17.21", + "lodash-es": "^4.17.21", + "react-fast-compare": "^3.2.2", + "rxjs": "^7.8.1", + "rxjs-exhaustmap-with-trailing": "^2.1.1" + }, + "engines": { + "node": ">=14" + }, + "peerDependencies": { + "@sanity/mutator": "^3.36.4", + "react": "^18", + "sanity": "^3.36.4", + "styled-components": "^6.1" + } + }, + "node_modules/@sanity/assist/node_modules/date-fns": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-3.6.0.tgz", + "integrity": "sha512-fRHTG8g/Gif+kSh50gaGEdToemgfj74aRX3swtiouboip5JDLAyDE9F11nHMIcvOaXeOC6D7SpNhi7uFyB7Uww==", + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/kossnocorp" + } + }, "node_modules/@sanity/bifur-client": { "version": "0.4.1", "resolved": "https://registry.npmjs.org/@sanity/bifur-client/-/bifur-client-0.4.1.tgz", @@ -5092,6 +5130,31 @@ "node": ">=14.18" } }, + "node_modules/@sanity/document-internationalization": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@sanity/document-internationalization/-/document-internationalization-3.0.1.tgz", + "integrity": "sha512-ijnKWgzMZ5XED2sc+WaqOGiFAm2C1FpRQGxFmJBx8/rdmbINO/R95S4bg5+fm+cmiSQYimVNHKzCbKfyvpMk9A==", + "license": "MIT", + "dependencies": { + "@sanity/icons": "^2.11.7", + "@sanity/incompatible-plugin": "^1.0.4", + "@sanity/ui": "^2.1.0", + "@sanity/uuid": "^3.0.2", + "sanity-plugin-internationalized-array": "^2.0.0", + "sanity-plugin-utils": "^1.6.4" + }, + "engines": { + "node": ">=14" + }, + "peerDependencies": { + "@sanity/mutator": "^3.40.0", + "@sanity/ui": "^2.1", + "react": "^18", + "react-dom": "^18", + "sanity": "^3.40.0", + "styled-components": "^6.1" + } + }, "node_modules/@sanity/eventsource": { "version": "5.0.2", "resolved": "https://registry.npmjs.org/@sanity/eventsource/-/eventsource-5.0.2.tgz", @@ -5176,7 +5239,6 @@ "resolved": "https://registry.npmjs.org/@sanity/icons/-/icons-2.11.8.tgz", "integrity": "sha512-C4ViXtk6eyiNTQ5OmxpfmcK6Jw+LLTi9zg9XBUD15DzC4xTHaGW9SVfUa43YtPGs3WC3M0t0K59r0GDjh52HIg==", "license": "MIT", - "peer": true, "engines": { "node": ">=14.0.0" }, @@ -5289,6 +5351,29 @@ "node": ">=4" } }, + "node_modules/@sanity/incompatible-plugin": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/@sanity/incompatible-plugin/-/incompatible-plugin-1.0.4.tgz", + "integrity": "sha512-2z39G9PTM8MXOF4fJNx3TG4tH0RrTjtH6dVLW93DSjCPbIS7FgCY5yWjZfQ+HVkwhLsF7ATDAGLA/jp65pFjAg==", + "license": "MIT", + "dependencies": { + "@sanity/icons": "^1.3", + "react-copy-to-clipboard": "^5.1.0" + }, + "peerDependencies": { + "react": "^16.9 || ^17 || ^18", + "react-dom": "^16.9 || ^17 || ^18" + } + }, + "node_modules/@sanity/incompatible-plugin/node_modules/@sanity/icons": { + "version": "1.3.10", + "resolved": "https://registry.npmjs.org/@sanity/icons/-/icons-1.3.10.tgz", + "integrity": "sha512-5wVG/vIiGuGrSmq+Bl3PY7XDgQrGv0fyHdJI64FSulnr2wH3NMqZ6C59UFxnrZ93sr7kOt0zQFoNv2lkPBi0Cg==", + "license": "MIT", + "peerDependencies": { + "react": "^16.9 || ^17 || ^18" + } + }, "node_modules/@sanity/insert-menu": { "version": "1.0.8", "resolved": "https://registry.npmjs.org/@sanity/insert-menu/-/insert-menu-1.0.8.tgz", @@ -5321,6 +5406,29 @@ "react": "^18.3 || >=19.0.0-rc" } }, + "node_modules/@sanity/language-filter": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/@sanity/language-filter/-/language-filter-4.0.2.tgz", + "integrity": "sha512-guL7vZv/QwDdbzVbCA8YqY8G0tH6KW2obyp5UCbFvFy9NqlmfuaHtle/VIO+UwqbCXck2Xpz0WihFeQHHjhCcw==", + "license": "MIT", + "dependencies": { + "@sanity/icons": "^2.11.7", + "@sanity/incompatible-plugin": "^1.0.4", + "@sanity/ui": "^2.1.0", + "lodash": "^4.17.21" + }, + "engines": { + "node": ">=14" + }, + "peerDependencies": { + "@sanity/ui": "^2.1.0", + "@sanity/util": "^3.36.4", + "react": "^18", + "react-dom": "^18", + "sanity": "^3.36.4", + "styled-components": "^6.1" + } + }, "node_modules/@sanity/logos": { "version": "2.1.13", "resolved": "https://registry.npmjs.org/@sanity/logos/-/logos-2.1.13.tgz", @@ -12419,6 +12527,12 @@ "url": "https://github.com/sponsors/wooorm" } }, + "node_modules/dlv": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", + "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==", + "license": "MIT" + }, "node_modules/doc-path": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/doc-path/-/doc-path-4.1.1.tgz", @@ -19674,6 +19788,12 @@ "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", "license": "MIT" }, + "node_modules/lodash-es": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.21.tgz", + "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==", + "license": "MIT" + }, "node_modules/lodash.camelcase": { "version": "4.3.0", "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", @@ -24408,6 +24528,81 @@ "node": ">=14.18" } }, + "node_modules/sanity-plugin-documents-pane": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/sanity-plugin-documents-pane/-/sanity-plugin-documents-pane-2.3.0.tgz", + "integrity": "sha512-2gDYMW9UonENGcSAsAVlnGo6GKBDIAsZY7fpMDZ3/1le0qKAKFnXTbmov7fCCW6uNI+3VNQ2xhhicscr8iEgTQ==", + "license": "MIT", + "dependencies": { + "@sanity/icons": "^2.0.0", + "@sanity/incompatible-plugin": "^1.0.4", + "@sanity/ui": "^1.0 || ^2.0", + "@sanity/util": "^3.0.0", + "@sanity/uuid": "^3.0.1", + "dlv": "^1.1.3", + "react-fast-compare": "^3.2.0", + "rxjs": "^7.0.0", + "sanity-plugin-utils": "^1.6.3" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@sanity/ui": "^1.0 || ^2.0", + "react": "^18", + "react-dom": "^18", + "sanity": "^3.24.1", + "styled-components": "^5.0 || ^6.0" + } + }, + "node_modules/sanity-plugin-internationalized-array": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/sanity-plugin-internationalized-array/-/sanity-plugin-internationalized-array-2.1.0.tgz", + "integrity": "sha512-YpG8O3wdNbewsPNhSHZ13MYTPDqsf0Iz8eC6fB5hhDwttxcM6ftD40R1qXT73Ccl68X4DrbHi3bQzXC60E7D7g==", + "license": "MIT", + "dependencies": { + "@sanity/icons": "^2.11.7", + "@sanity/incompatible-plugin": "^1.0.4", + "@sanity/language-filter": "^4.0.2", + "@sanity/ui": "^2.1.0", + "fast-deep-equal": "^3.1.3", + "lodash": "^4.17.21", + "suspend-react": "0.1.3" + }, + "engines": { + "node": ">=14" + }, + "peerDependencies": { + "@sanity/ui": "^2.1.0", + "react": "^18", + "react-dom": "^18", + "sanity": "^3.36.4", + "styled-components": "^6.1" + } + }, + "node_modules/sanity-plugin-utils": { + "version": "1.6.5", + "resolved": "https://registry.npmjs.org/sanity-plugin-utils/-/sanity-plugin-utils-1.6.5.tgz", + "integrity": "sha512-QJOBaNSIR7nG8xaSRD/CsqPMz8ZMZIkJ2pCIzB14uD9J4iiCaRh6V4R6We6L4gNJ/Pr57AuzQS/SGqlyTue5Qw==", + "license": "MIT", + "dependencies": { + "@sanity/icons": "^2.11.8", + "@sanity/incompatible-plugin": "^1.0.4", + "styled-components": "^6.1.6" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@sanity/ui": "^1.0 || ^2.0", + "react": "^18", + "react-dom": "^18", + "react-fast-compare": "^3.2.2", + "rxjs": "^7.8.1", + "sanity": "^3.43.0", + "styled-components": "^6.1.11" + } + }, "node_modules/sanity/node_modules/@sanity/icons": { "version": "3.4.0", "resolved": "https://registry.npmjs.org/@sanity/icons/-/icons-3.4.0.tgz", diff --git a/package.json b/package.json index 41e98a2d0..09766b4ae 100644 --- a/package.json +++ b/package.json @@ -13,6 +13,7 @@ }, "dependencies": { "@google-cloud/pubsub": "^4.5.0", + "@sanity/document-internationalization": "^3.0.1", "@sanity/image-url": "^1.0.2", "@sanity/preview-url-secret": "^1.6.11", "@sanity/react-loader": "^1.9.15", @@ -24,6 +25,7 @@ "react-dom": "^18", "react-focus-on": "^3.9.3", "sanity": "^3.50.0", + "sanity-plugin-documents-pane": "^2.3.0", "styled-components": "^6.1.8" }, "devDependencies": { diff --git a/studioShared/deskStructure.ts b/studioShared/deskStructure.ts new file mode 100644 index 000000000..34ba9692f --- /dev/null +++ b/studioShared/deskStructure.ts @@ -0,0 +1,66 @@ +import { i18n } from "languages"; +import { + StructureResolver, + DefaultDocumentNodeResolver, +} from "sanity/structure"; +import { blogPostsID } from "studioShared/schemas/documents/blogPosts"; + +export const deskStructure: StructureResolver = (S) => + S.list() + .title("Content") + .items([ + S.listItem() + .title("Blogposts sorted by base language") + .child( + S.documentTypeList(blogPostsID) + .title("List of Blogposts") + .filter("_type == $type && language == $lang") + .params({ type: blogPostsID, lang: i18n.base }) + ), + S.listItem() + .title("Blogposts sorted into language folders") + .child( + S.list() + .title("Blogposts") + .items([ + S.listItem() + .title("Blogposts (EN)") + .child( + S.documentTypeList(blogPostsID) + .title("List of Blogposts (EN)") + .filter("_type == $type && language == $lang") + .params({ type: blogPostsID, lang: "en" }) + ), + S.listItem() + .title("Blogposts (NO)") + .child( + S.documentTypeList(blogPostsID) + .title("List of Blogposts (NO)") + .filter("_type == $type && language == $lang") + .params({ type: blogPostsID, lang: "no" }) + ), + S.listItem() + .title("Blogposts (SE)") + .child( + S.documentTypeList(blogPostsID) + .title("List of Blogposts (SE)") + .filter("_type == $type && language == $lang") + .params({ type: blogPostsID, lang: "se" }) + ), + // Add more languages as needed + ]) + ), + // Other items can be added here if needed + ]); + +export const defaultDocumentNode: DefaultDocumentNodeResolver = ( + S, + { schemaType } +) => { + switch (schemaType) { + case blogPostsID: + return S.document().views([S.view.form()]); + default: + return S.document(); + } +}; diff --git a/studioShared/sanity.config.ts b/studioShared/sanity.config.ts index 731bb3307..df4d62b67 100644 --- a/studioShared/sanity.config.ts +++ b/studioShared/sanity.config.ts @@ -1,7 +1,13 @@ import { defineConfig } from "sanity"; import { structureTool } from "sanity/structure"; -import { dataset, projectId } from "./env"; +import { visionTool } from "@sanity/vision"; +import { apiVersion, dataset, projectId } from "./env"; import { schema } from "./schema"; +import { documentInternationalization } from "@sanity/document-internationalization"; +import { i18n } from "languages"; +import { blogPostsID } from "./schemas/documents/blogPosts"; +import { deskStructure } from "./deskStructure"; +import { titleSlug } from "studio/schemas/schemaTypes/slug"; /** * This configuration is used for the Sanity Studio that’s mounted on the `/app/shared/[[...index]]/page.tsx` route @@ -12,5 +18,17 @@ export default defineConfig({ projectId, dataset, schema, - plugins: [structureTool()], + plugins: [ + structureTool({ + structure: deskStructure, + }), + visionTool({ defaultApiVersion: apiVersion }), + documentInternationalization({ + supportedLanguages: i18n.languages, + schemaTypes: [blogPostsID], + languageField: `language`, + metadataFields: [titleSlug], + apiVersion, + }), + ], }); diff --git a/studioShared/schemas/documents/blogPosts.ts b/studioShared/schemas/documents/blogPosts.ts index 10208b062..a8cbb3a20 100644 --- a/studioShared/schemas/documents/blogPosts.ts +++ b/studioShared/schemas/documents/blogPosts.ts @@ -23,13 +23,8 @@ const blogPosts = defineType({ // Ensure date is not undefined or null if (!date) return "The publish date is required."; - // Ensure context.document is defined and _createdAt exists - if (!context.document || !context.document._createdAt) { - return "Creation date is missing."; - } - const selectedDate = new Date(date); - const createdAt = new Date(context.document._createdAt as string); + const createdAt = new Date(context.document?._createdAt as string); const now = new Date(); // Add a small buffer of 1 second (1000 milliseconds) @@ -50,6 +45,12 @@ const blogPosts = defineType({ ...richText, description: "Enter the body content of the post.", }), + defineField({ + name: "language", + type: "string", + readOnly: true, + hidden: true, + }), ], preview: { select: { @@ -58,7 +59,7 @@ const blogPosts = defineType({ }, prepare({ title, date }) { const subtitles = [date && format(parseISO(date), "LLL d, yyyy")].filter( - Boolean, + Boolean ); return { title, subtitle: subtitles.join(" ") }; From 637dd41076d4ecb5fbdbe14d2cdc3c2e5d424857 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Fri, 30 Aug 2024 14:19:15 +0200 Subject: [PATCH 02/11] uninstall sanity-plugin-documents-pane --- package-lock.json | 76 ----------------------------------- package.json | 1 - studioShared/deskStructure.ts | 12 ------ 3 files changed, 89 deletions(-) diff --git a/package-lock.json b/package-lock.json index 48e858f5b..21cc96f15 100644 --- a/package-lock.json +++ b/package-lock.json @@ -21,7 +21,6 @@ "react-dom": "^18", "react-focus-on": "^3.9.3", "sanity": "^3.50.0", - "sanity-plugin-documents-pane": "^2.3.0", "styled-components": "^6.1.8" }, "devDependencies": { @@ -4842,42 +4841,6 @@ "node": ">=10" } }, - "node_modules/@sanity/assist": { - "version": "3.0.6", - "resolved": "https://registry.npmjs.org/@sanity/assist/-/assist-3.0.6.tgz", - "integrity": "sha512-CFbpY+eI5CCEuYq61tFtKql1SAbxkT0KHECcWjRWthwBaGuePwrZt/9T/kPr0T4YWIPyH/NJc4b/bIM0dhYa6A==", - "license": "MIT", - "dependencies": { - "@sanity/icons": "^2.11.7", - "@sanity/incompatible-plugin": "^1.0.4", - "@sanity/ui": "^2.1.0", - "date-fns": "^3.6.0", - "lodash": "^4.17.21", - "lodash-es": "^4.17.21", - "react-fast-compare": "^3.2.2", - "rxjs": "^7.8.1", - "rxjs-exhaustmap-with-trailing": "^2.1.1" - }, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "@sanity/mutator": "^3.36.4", - "react": "^18", - "sanity": "^3.36.4", - "styled-components": "^6.1" - } - }, - "node_modules/@sanity/assist/node_modules/date-fns": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-3.6.0.tgz", - "integrity": "sha512-fRHTG8g/Gif+kSh50gaGEdToemgfj74aRX3swtiouboip5JDLAyDE9F11nHMIcvOaXeOC6D7SpNhi7uFyB7Uww==", - "license": "MIT", - "funding": { - "type": "github", - "url": "https://github.com/sponsors/kossnocorp" - } - }, "node_modules/@sanity/bifur-client": { "version": "0.4.1", "resolved": "https://registry.npmjs.org/@sanity/bifur-client/-/bifur-client-0.4.1.tgz", @@ -12527,12 +12490,6 @@ "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/dlv": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", - "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==", - "license": "MIT" - }, "node_modules/doc-path": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/doc-path/-/doc-path-4.1.1.tgz", @@ -19788,12 +19745,6 @@ "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", "license": "MIT" }, - "node_modules/lodash-es": { - "version": "4.17.21", - "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.21.tgz", - "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==", - "license": "MIT" - }, "node_modules/lodash.camelcase": { "version": "4.3.0", "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz", @@ -24528,33 +24479,6 @@ "node": ">=14.18" } }, - "node_modules/sanity-plugin-documents-pane": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/sanity-plugin-documents-pane/-/sanity-plugin-documents-pane-2.3.0.tgz", - "integrity": "sha512-2gDYMW9UonENGcSAsAVlnGo6GKBDIAsZY7fpMDZ3/1le0qKAKFnXTbmov7fCCW6uNI+3VNQ2xhhicscr8iEgTQ==", - "license": "MIT", - "dependencies": { - "@sanity/icons": "^2.0.0", - "@sanity/incompatible-plugin": "^1.0.4", - "@sanity/ui": "^1.0 || ^2.0", - "@sanity/util": "^3.0.0", - "@sanity/uuid": "^3.0.1", - "dlv": "^1.1.3", - "react-fast-compare": "^3.2.0", - "rxjs": "^7.0.0", - "sanity-plugin-utils": "^1.6.3" - }, - "engines": { - "node": ">=18" - }, - "peerDependencies": { - "@sanity/ui": "^1.0 || ^2.0", - "react": "^18", - "react-dom": "^18", - "sanity": "^3.24.1", - "styled-components": "^5.0 || ^6.0" - } - }, "node_modules/sanity-plugin-internationalized-array": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/sanity-plugin-internationalized-array/-/sanity-plugin-internationalized-array-2.1.0.tgz", diff --git a/package.json b/package.json index 09766b4ae..cf1119089 100644 --- a/package.json +++ b/package.json @@ -25,7 +25,6 @@ "react-dom": "^18", "react-focus-on": "^3.9.3", "sanity": "^3.50.0", - "sanity-plugin-documents-pane": "^2.3.0", "styled-components": "^6.1.8" }, "devDependencies": { diff --git a/studioShared/deskStructure.ts b/studioShared/deskStructure.ts index 34ba9692f..234af76aa 100644 --- a/studioShared/deskStructure.ts +++ b/studioShared/deskStructure.ts @@ -52,15 +52,3 @@ export const deskStructure: StructureResolver = (S) => ), // Other items can be added here if needed ]); - -export const defaultDocumentNode: DefaultDocumentNodeResolver = ( - S, - { schemaType } -) => { - switch (schemaType) { - case blogPostsID: - return S.document().views([S.view.form()]); - default: - return S.document(); - } -}; From 6cec3f56dc323c279b4ff24ca243f1d37b205dc2 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Tue, 3 Sep 2024 08:34:42 +0200 Subject: [PATCH 03/11] use costumer cases and add language field --- studioShared/deskStructure.ts | 49 +++---------------- .../schemas/documents/customerCases.ts | 5 ++ 2 files changed, 11 insertions(+), 43 deletions(-) diff --git a/studioShared/deskStructure.ts b/studioShared/deskStructure.ts index 234af76aa..bc691ceb6 100644 --- a/studioShared/deskStructure.ts +++ b/studioShared/deskStructure.ts @@ -1,54 +1,17 @@ import { i18n } from "languages"; -import { - StructureResolver, - DefaultDocumentNodeResolver, -} from "sanity/structure"; -import { blogPostsID } from "studioShared/schemas/documents/blogPosts"; +import { StructureResolver } from "sanity/structure"; +import { customerCasesID } from "./schemas/documents/customerCases"; export const deskStructure: StructureResolver = (S) => S.list() .title("Content") .items([ S.listItem() - .title("Blogposts sorted by base language") + .title("Costumer cases") .child( - S.documentTypeList(blogPostsID) - .title("List of Blogposts") + S.documentTypeList(customerCasesID) + .title("Costumer cases") .filter("_type == $type && language == $lang") - .params({ type: blogPostsID, lang: i18n.base }) + .params({ type: customerCasesID, lang: i18n.base }) ), - S.listItem() - .title("Blogposts sorted into language folders") - .child( - S.list() - .title("Blogposts") - .items([ - S.listItem() - .title("Blogposts (EN)") - .child( - S.documentTypeList(blogPostsID) - .title("List of Blogposts (EN)") - .filter("_type == $type && language == $lang") - .params({ type: blogPostsID, lang: "en" }) - ), - S.listItem() - .title("Blogposts (NO)") - .child( - S.documentTypeList(blogPostsID) - .title("List of Blogposts (NO)") - .filter("_type == $type && language == $lang") - .params({ type: blogPostsID, lang: "no" }) - ), - S.listItem() - .title("Blogposts (SE)") - .child( - S.documentTypeList(blogPostsID) - .title("List of Blogposts (SE)") - .filter("_type == $type && language == $lang") - .params({ type: blogPostsID, lang: "se" }) - ), - // Add more languages as needed - ]) - ), - // Other items can be added here if needed ]); diff --git a/studioShared/schemas/documents/customerCases.ts b/studioShared/schemas/documents/customerCases.ts index 5a84a6a7c..dba36fec1 100644 --- a/studioShared/schemas/documents/customerCases.ts +++ b/studioShared/schemas/documents/customerCases.ts @@ -10,6 +10,11 @@ const customerCases = defineType({ type: "document", title: "Costumer Cases", fields: [ + defineField({ + name: "language", + type: "string", + readOnly: true, + }), title, titleSlug, defineField({ From d12b1e1924d40cb20142c2908185e6dcacc97f11 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Tue, 10 Sep 2024 21:10:26 +0200 Subject: [PATCH 04/11] make base lang default document --- package-lock.json | 250 ++++++++++++------ studioShared/deskStructure.ts | 10 +- studioShared/sanity.config.ts | 27 +- studioShared/schema.ts | 2 +- .../{customerCases.ts => customerCase.ts} | 15 +- 5 files changed, 195 insertions(+), 109 deletions(-) rename studioShared/schemas/documents/{customerCases.ts => customerCase.ts} (59%) diff --git a/package-lock.json b/package-lock.json index 21cc96f15..76f2bad93 100644 --- a/package-lock.json +++ b/package-lock.json @@ -4660,9 +4660,9 @@ } }, "node_modules/@portabletext/editor": { - "version": "1.0.18", - "resolved": "https://registry.npmjs.org/@portabletext/editor/-/editor-1.0.18.tgz", - "integrity": "sha512-EYgeX+dZr8v9aEtTcSfptozPWOnXG5skEs/eBr+qhlMgl5e+BgM4Zbkeh/dNSO6ub50x+fM3KrX7oxVlVAQVNA==", + "version": "1.0.19", + "resolved": "https://registry.npmjs.org/@portabletext/editor/-/editor-1.0.19.tgz", + "integrity": "sha512-ZNOvErcy2OYchsHVpVtJdhGb12YI6m0vOSubKu8t1X6wllkJPNyduW6xxLbmJiv/Z/+Ua1gVEvczdkfsU2qvvQ==", "license": "MIT", "dependencies": { "@portabletext/patches": "1.1.0", @@ -4852,35 +4852,35 @@ } }, "node_modules/@sanity/block-tools": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/block-tools/-/block-tools-3.55.0.tgz", - "integrity": "sha512-sTbPYD9pBJetGCpRRNOoHCDwZl1YDDB/0KNgvpNm6freKdsRTUyjN5YEXLnXeFYuHej6LmcDUHAvUtXWnZK+QA==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/block-tools/-/block-tools-3.57.1.tgz", + "integrity": "sha512-qGfc1nuwuZdthf2DQVEbMJyU97FXrWh/69FOc3pVmmLMXQDbuGHGq6TClnhcKBxBCd3y7GAB/J0cuy5h04b4vA==", "license": "MIT", "dependencies": { - "@sanity/types": "3.55.0", + "@sanity/types": "3.57.1", "@types/react": "^18.3.3", "get-random-values-esm": "1.0.2", "lodash": "^4.17.21" } }, "node_modules/@sanity/cli": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/cli/-/cli-3.55.0.tgz", - "integrity": "sha512-Pu0QRiOB0bFBJtBOC9fjNEpyIi8Y7vmAXXWcZLQGMWF/a2JybuTRNnfZIGEvH+EqPXJB9jpdz4y/9UHCcl4AWA==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/cli/-/cli-3.57.1.tgz", + "integrity": "sha512-nXlbHwUxL+K21Zie4ycrImKW8BpzIY6v5RFs9fGM3dCMUUkdFvd4d1qs8u2q/n6ONdr3yQS8TlT8VfHX1pFYFg==", "license": "MIT", "dependencies": { "@babel/traverse": "^7.23.5", "@sanity/client": "^6.21.2", - "@sanity/codegen": "3.55.0", + "@sanity/codegen": "3.57.1", "@sanity/telemetry": "^0.7.7", - "@sanity/util": "3.55.0", + "@sanity/util": "3.57.1", "chalk": "^4.1.2", "debug": "^4.3.4", "decompress": "^4.2.0", "esbuild": "0.21.5", "esbuild-register": "^3.5.0", "get-it": "^8.6.5", - "groq-js": "^1.12.0", + "groq-js": "^1.13.0", "node-machine-id": "^1.1.12", "pkg-dir": "^5.0.0", "prettier": "^3.3.0", @@ -4986,9 +4986,9 @@ } }, "node_modules/@sanity/codegen": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/codegen/-/codegen-3.55.0.tgz", - "integrity": "sha512-zTYrWOiqNWBjEF8GLfYFqnOvYShZfnmPILaPqdm3zGjDXnHSj9WSx6sPrklBTDSWFqPmYxDBxScpga6wcLgKzg==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/codegen/-/codegen-3.57.1.tgz", + "integrity": "sha512-47j7xxluLP2pmwFHKEzxWwIw6V8Xgx4s0IsewZ8g1MEoIv0DDSqxyBxKFo1ieC4Fh6oHz8JISXKclq2LzSjbzQ==", "license": "MIT", "dependencies": { "@babel/core": "^7.23.9", @@ -5001,8 +5001,8 @@ "@babel/types": "^7.23.9", "debug": "^4.3.4", "globby": "^10.0.0", - "groq": "3.55.0", - "groq-js": "^1.12.0", + "groq": "3.57.1", + "groq-js": "^1.13.0", "json5": "^2.2.3", "tsconfig-paths": "^4.2.0", "zod": "^3.22.4" @@ -5073,9 +5073,9 @@ } }, "node_modules/@sanity/diff": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/diff/-/diff-3.55.0.tgz", - "integrity": "sha512-D3LE2j/ZWMLb+0prpr+CMbskcF5sceuyPoXc3NbsI2usQiUh2hS7pxpBZGH9GGZjwAhgzf2j8IbZTTYdh6niUA==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/diff/-/diff-3.57.1.tgz", + "integrity": "sha512-uGRtwCQwsLkujiJ/KrXEQrYPWVQ34t5t7QWrqzGSyiTnASc3pjfiWwFSVwSKkCyO9AiLT+/ynCBuKsAhnYWAwQ==", "license": "MIT", "dependencies": { "@sanity/diff-match-patch": "^3.1.1" @@ -5406,19 +5406,19 @@ } }, "node_modules/@sanity/migrate": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/migrate/-/migrate-3.55.0.tgz", - "integrity": "sha512-lXwVHLbMnbjpHtf1YZeQHXrZJxM1u7WCGDXQCvFHSHOPWJ9uG/lCW6Ew/8hm+Zteix8oWVay983O+ipaUERvmw==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/migrate/-/migrate-3.57.1.tgz", + "integrity": "sha512-zYGyxfrJLsshcOtycD4VXt9BjIdY8z/DfZ4jEzV0s76yjD2g92ZEAdRQ40QcXVnll4UO+Pl9Ae31srIzo4N/AQ==", "license": "MIT", "dependencies": { "@sanity/client": "^6.21.2", "@sanity/mutate": "^0.8.0", - "@sanity/types": "3.55.0", - "@sanity/util": "3.55.0", + "@sanity/types": "3.57.1", + "@sanity/util": "3.57.1", "arrify": "^2.0.1", "debug": "^4.3.4", "fast-fifo": "^1.3.2", - "groq-js": "^1.12.0", + "groq-js": "^1.13.0", "p-map": "^7.0.1" }, "engines": { @@ -5482,13 +5482,13 @@ } }, "node_modules/@sanity/mutator": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/mutator/-/mutator-3.55.0.tgz", - "integrity": "sha512-B/qmBhpluHSCZdPlS88nUGbj5fM4SP0/G12szqQL4Chxbj1JJSlUm4//KDg/ms5ZwiLeDJJAhWRSOPan/E9y2g==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/mutator/-/mutator-3.57.1.tgz", + "integrity": "sha512-G9blglmLkv+lsyTxnoDc2Tr/R8J2W9ZpAGFhwJo+Xg0ZcFQOOGg9hptJqCCzlQFo1pppKK0oDdLjwSzDNH6HhQ==", "license": "MIT", "dependencies": { "@sanity/diff-match-patch": "^3.1.1", - "@sanity/types": "3.55.0", + "@sanity/types": "3.57.1", "@sanity/uuid": "^3.0.1", "debug": "^4.3.4", "lodash": "^4.17.21" @@ -5629,15 +5629,15 @@ } }, "node_modules/@sanity/schema": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/schema/-/schema-3.55.0.tgz", - "integrity": "sha512-vHdxkXw6cXlm+hpOteEcSS8hMuu2cbqkIZ5v8zYp7d8Nd/u1nXeAhyAsqsjOrOh2GJbHhff8zzX+5ILvmWNmqw==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/schema/-/schema-3.57.1.tgz", + "integrity": "sha512-gbuZW0QPgp4ZSDsCV0L0esDXGPokSfZRXo7DV3D1qT5QiBu1qImaDqqXIoL5+qn4MEcwcEGrdXgmXpcw3p5+iw==", "license": "MIT", "dependencies": { "@sanity/generate-help-url": "^3.0.0", - "@sanity/types": "3.55.0", + "@sanity/types": "3.57.1", "arrify": "^1.0.1", - "groq-js": "^1.12.0", + "groq-js": "^1.13.0", "humanize-list": "^1.0.1", "leven": "^3.1.0", "lodash": "^4.17.21", @@ -5671,9 +5671,9 @@ } }, "node_modules/@sanity/types": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/types/-/types-3.55.0.tgz", - "integrity": "sha512-3oeVFeYVWurYXN3qN23kpwS1KfZ1Jk1J/fybHrAHSl2bRrnvAoLkbtTvuvOuR4/kOup0o1S/aNTYLzQmu+xGOA==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/types/-/types-3.57.1.tgz", + "integrity": "sha512-zozN7U0xdaT9c1VzYP58N6geyQFMDksYL5J2g3l4VRne2BzfjXAO+1H/q9FbdazOe6j2UMXwJRKPjiMLEiN1kg==", "license": "MIT", "dependencies": { "@sanity/client": "^6.21.2", @@ -5717,13 +5717,13 @@ } }, "node_modules/@sanity/util": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/@sanity/util/-/util-3.55.0.tgz", - "integrity": "sha512-R1yFfLo8UVw7kQ7moJiVLg02F+xzg3KoewG50iETIGg+i1S9uGBIAVZrStWdd5Fhrj0x5vxGKhi4pmEzfxxjxQ==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/@sanity/util/-/util-3.57.1.tgz", + "integrity": "sha512-OFK1kd9rS81953K8eBG4mizF1Iz/yC9zzLFKL+OJ71uunxjf8bpuY4bBuybnFc3xhJ54V9IGDg/Jy19QrNWi1Q==", "license": "MIT", "dependencies": { "@sanity/client": "^6.21.2", - "@sanity/types": "3.55.0", + "@sanity/types": "3.57.1", "get-random-values-esm": "1.0.2", "moment": "^2.29.4", "rxjs": "^7.8.1" @@ -10031,9 +10031,9 @@ "license": "MIT" }, "node_modules/body-parser": { - "version": "1.20.2", - "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.2.tgz", - "integrity": "sha512-ml9pReCu3M61kGlqoTm2umSXTlRTuGTx0bfYj+uIUKKYycG5NtSbeetV3faSU6R7ajOPw0g/J1PvK4qNy7s5bA==", + "version": "1.20.3", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.3.tgz", + "integrity": "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==", "dev": true, "license": "MIT", "dependencies": { @@ -10045,7 +10045,7 @@ "http-errors": "2.0.0", "iconv-lite": "0.4.24", "on-finished": "2.4.1", - "qs": "6.11.0", + "qs": "6.13.0", "raw-body": "2.5.2", "type-is": "~1.6.18", "unpipe": "1.0.0" @@ -10072,6 +10072,22 @@ "dev": true, "license": "MIT" }, + "node_modules/body-parser/node_modules/qs": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.13.0.tgz", + "integrity": "sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "side-channel": "^1.0.6" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/boolbase": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", @@ -13948,38 +13964,38 @@ "license": "MIT" }, "node_modules/express": { - "version": "4.19.2", - "resolved": "https://registry.npmjs.org/express/-/express-4.19.2.tgz", - "integrity": "sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==", + "version": "4.20.0", + "resolved": "https://registry.npmjs.org/express/-/express-4.20.0.tgz", + "integrity": "sha512-pLdae7I6QqShF5PnNTCVn4hI91Dx0Grkn2+IAsMTgMIKuQVte2dN9PeGSSAME2FR8anOhVA62QDIUaWVfEXVLw==", "dev": true, "license": "MIT", "dependencies": { "accepts": "~1.3.8", "array-flatten": "1.1.1", - "body-parser": "1.20.2", + "body-parser": "1.20.3", "content-disposition": "0.5.4", "content-type": "~1.0.4", "cookie": "0.6.0", "cookie-signature": "1.0.6", "debug": "2.6.9", "depd": "2.0.0", - "encodeurl": "~1.0.2", + "encodeurl": "~2.0.0", "escape-html": "~1.0.3", "etag": "~1.8.1", "finalhandler": "1.2.0", "fresh": "0.5.2", "http-errors": "2.0.0", - "merge-descriptors": "1.0.1", + "merge-descriptors": "1.0.3", "methods": "~1.1.2", "on-finished": "2.4.1", "parseurl": "~1.3.3", - "path-to-regexp": "0.1.7", + "path-to-regexp": "0.1.10", "proxy-addr": "~2.0.7", "qs": "6.11.0", "range-parser": "~1.2.1", "safe-buffer": "5.2.1", - "send": "0.18.0", - "serve-static": "1.15.0", + "send": "0.19.0", + "serve-static": "1.16.0", "setprototypeof": "1.2.0", "statuses": "2.0.1", "type-is": "~1.6.18", @@ -14000,6 +14016,16 @@ "ms": "2.0.0" } }, + "node_modules/express/node_modules/encodeurl": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-2.0.0.tgz", + "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/express/node_modules/ms": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", @@ -15487,9 +15513,9 @@ "license": "MIT" }, "node_modules/groq": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/groq/-/groq-3.55.0.tgz", - "integrity": "sha512-oDMnjsIfEMtGfPJOMFx+6qS8fdX8YIRYbslF/VE6H77kKGOGOlrMK81diphkoiV0/xg0mS++gf9fCGbdasZIRQ==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/groq/-/groq-3.57.1.tgz", + "integrity": "sha512-V/g54pJotZ+mS50kqw2hjde3STD4w1XtKNE//pbUXdR1DzqRCAkMhxr2tao8nU1r5DeA9OTAqsIHX53XyKOFKQ==", "license": "MIT", "engines": { "node": ">=18" @@ -20035,11 +20061,14 @@ } }, "node_modules/merge-descriptors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", - "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.3.tgz", + "integrity": "sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==", "dev": true, - "license": "MIT" + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } }, "node_modules/merge-stream": { "version": "2.0.0", @@ -21995,9 +22024,9 @@ "license": "ISC" }, "node_modules/path-to-regexp": { - "version": "0.1.7", - "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", - "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==", + "version": "0.1.10", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.10.tgz", + "integrity": "sha512-7lf7qcQidTku0Gu3YDPc8DJ1q7OOucfa/BSsIwjuh56VU7katFvuM8hULfkwB3Fns/rsVF7PwPKVw1sl5KQS9w==", "dev": true, "license": "MIT" }, @@ -24333,9 +24362,9 @@ "license": "MIT" }, "node_modules/sanity": { - "version": "3.55.0", - "resolved": "https://registry.npmjs.org/sanity/-/sanity-3.55.0.tgz", - "integrity": "sha512-FYKYWQc4VZwHkwswT/Y7sWYq9dSvuFtQe2yeZLq9eWQPMyBBiuw4Y3F3YqwpAHl/18uxOeSOhHRbZP9+1dd0nQ==", + "version": "3.57.1", + "resolved": "https://registry.npmjs.org/sanity/-/sanity-3.57.1.tgz", + "integrity": "sha512-C6YMsJAV0Dep9da/TKF2eWXne6/HfvNfMqFYGk7OsoXbYMBBzSAzkgHeZMsz9rmjp9PUK03ktdFvP0u2ts+8hQ==", "license": "MIT", "dependencies": { "@dnd-kit/core": "^6.0.5", @@ -24343,32 +24372,32 @@ "@dnd-kit/sortable": "^7.0.1", "@dnd-kit/utilities": "^3.2.0", "@juggle/resize-observer": "^3.3.1", - "@portabletext/editor": "^1.0.15", + "@portabletext/editor": "^1.0.19", "@portabletext/react": "^3.0.0", "@rexxars/react-json-inspector": "^8.0.1", "@sanity/asset-utils": "^1.2.5", "@sanity/bifur-client": "^0.4.1", - "@sanity/block-tools": "3.55.0", - "@sanity/cli": "3.55.0", + "@sanity/block-tools": "3.57.1", + "@sanity/cli": "3.57.1", "@sanity/client": "^6.21.2", "@sanity/color": "^3.0.0", - "@sanity/diff": "3.55.0", + "@sanity/diff": "3.57.1", "@sanity/diff-match-patch": "^3.1.1", "@sanity/eventsource": "^5.0.0", "@sanity/export": "^3.41.0", - "@sanity/icons": "^3.3.1", + "@sanity/icons": "^3.4.0", "@sanity/image-url": "^1.0.2", "@sanity/import": "^3.37.3", "@sanity/insert-menu": "1.0.8", "@sanity/logos": "^2.1.4", - "@sanity/migrate": "3.55.0", - "@sanity/mutator": "3.55.0", + "@sanity/migrate": "3.57.1", + "@sanity/mutator": "3.57.1", "@sanity/presentation": "1.16.4", - "@sanity/schema": "3.55.0", + "@sanity/schema": "3.57.1", "@sanity/telemetry": "^0.7.7", - "@sanity/types": "3.55.0", + "@sanity/types": "3.57.1", "@sanity/ui": "^2.8.8", - "@sanity/util": "3.55.0", + "@sanity/util": "3.57.1", "@sanity/uuid": "^3.0.1", "@sentry/react": "^8.7.0", "@tanstack/react-table": "^8.16.0", @@ -24401,7 +24430,7 @@ "framer-motion": "11.0.8", "get-it": "^8.6.5", "get-random-values-esm": "1.0.2", - "groq-js": "^1.12.0", + "groq-js": "^1.13.0", "history": "^5.3.0", "i18next": "^23.2.7", "import-fresh": "^3.3.0", @@ -24855,9 +24884,9 @@ } }, "node_modules/send": { - "version": "0.18.0", - "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", - "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", + "version": "0.19.0", + "resolved": "https://registry.npmjs.org/send/-/send-0.19.0.tgz", + "integrity": "sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw==", "dev": true, "license": "MIT", "dependencies": { @@ -24914,9 +24943,9 @@ } }, "node_modules/serve-static": { - "version": "1.15.0", - "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", - "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", + "version": "1.16.0", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.16.0.tgz", + "integrity": "sha512-pDLK8zwl2eKaYrs8mrPZBJua4hMplRWJ1tIFksVC3FtBEBnl8dxgeHtsaMS8DhS9i4fLObaon6ABoc4/hQGdPA==", "dev": true, "license": "MIT", "dependencies": { @@ -24929,6 +24958,55 @@ "node": ">= 0.8.0" } }, + "node_modules/serve-static/node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/serve-static/node_modules/debug/node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true, + "license": "MIT" + }, + "node_modules/serve-static/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/serve-static/node_modules/send": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", + "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "mime": "1.6.0", + "ms": "2.1.3", + "on-finished": "2.4.1", + "range-parser": "~1.2.1", + "statuses": "2.0.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, "node_modules/set-blocking": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", diff --git a/studioShared/deskStructure.ts b/studioShared/deskStructure.ts index bc691ceb6..cc90993bf 100644 --- a/studioShared/deskStructure.ts +++ b/studioShared/deskStructure.ts @@ -1,17 +1,17 @@ import { i18n } from "languages"; import { StructureResolver } from "sanity/structure"; -import { customerCasesID } from "./schemas/documents/customerCases"; +import { customerCaseID } from "./schemas/documents/customerCase"; export const deskStructure: StructureResolver = (S) => S.list() .title("Content") .items([ S.listItem() - .title("Costumer cases") + .title("Customer cases") .child( - S.documentTypeList(customerCasesID) - .title("Costumer cases") + S.documentTypeList(customerCaseID) + .title("Customer cases") .filter("_type == $type && language == $lang") - .params({ type: customerCasesID, lang: i18n.base }) + .params({ type: customerCaseID, lang: i18n.base }) ), ]); diff --git a/studioShared/sanity.config.ts b/studioShared/sanity.config.ts index df4d62b67..4d7320e8e 100644 --- a/studioShared/sanity.config.ts +++ b/studioShared/sanity.config.ts @@ -1,34 +1,43 @@ -import { defineConfig } from "sanity"; -import { structureTool } from "sanity/structure"; +import { defineConfig, defineField } from "sanity"; +import { documentInternationalization } from "@sanity/document-internationalization"; import { visionTool } from "@sanity/vision"; +import { structureTool } from "sanity/structure"; import { apiVersion, dataset, projectId } from "./env"; import { schema } from "./schema"; -import { documentInternationalization } from "@sanity/document-internationalization"; import { i18n } from "languages"; -import { blogPostsID } from "./schemas/documents/blogPosts"; +import { customerCaseID } from "./schemas/documents/customerCase"; import { deskStructure } from "./deskStructure"; -import { titleSlug } from "studio/schemas/schemaTypes/slug"; /** * This configuration is used for the Sanity Studio that’s mounted on the `/app/shared/[[...index]]/page.tsx` route */ - export default defineConfig({ basePath: "/shared", projectId, dataset, - schema, + schema: { + ...schema, + templates: (prev) => + prev.filter((template) => template.value.language === i18n.base), + }, plugins: [ structureTool({ structure: deskStructure, }), visionTool({ defaultApiVersion: apiVersion }), documentInternationalization({ + // TODO: a function that takes the client and returns a promise of an array of supported languages + // MUST return an "id" and "title" as strings + // supportedLanguages: (client) => client.fetch(`*[_type == "language"]{id, title}`), supportedLanguages: i18n.languages, - schemaTypes: [blogPostsID], + schemaTypes: [customerCaseID], languageField: `language`, - metadataFields: [titleSlug], + metadataFields: [defineField({ name: "slug", type: "slug" })], apiVersion, + // Optional + // Adds UI for publishing all translations at once. Requires access to the Scheduling API + // https://www.sanity.io/docs/scheduling-api + // bulkPublish: true, }), ], }); diff --git a/studioShared/schema.ts b/studioShared/schema.ts index 7d0ee34f3..321db988c 100644 --- a/studioShared/schema.ts +++ b/studioShared/schema.ts @@ -1,6 +1,6 @@ import { type SchemaTypeDefinition } from "sanity"; import blogPosts from "./schemas/documents/blogPosts"; -import customerCases from "./schemas/documents/customerCases"; +import customerCases from "./schemas/documents/customerCase"; export const schema: { types: SchemaTypeDefinition[] } = { types: [blogPosts, customerCases], diff --git a/studioShared/schemas/documents/customerCases.ts b/studioShared/schemas/documents/customerCase.ts similarity index 59% rename from studioShared/schemas/documents/customerCases.ts rename to studioShared/schemas/documents/customerCase.ts index dba36fec1..b82dc622c 100644 --- a/studioShared/schemas/documents/customerCases.ts +++ b/studioShared/schemas/documents/customerCase.ts @@ -1,14 +1,13 @@ import { defineField, defineType } from "sanity"; -import { format, parseISO } from "date-fns"; import { richText, title } from "studio/schemas/fields/text"; import { titleSlug } from "studio/schemas/schemaTypes/slug"; -export const customerCasesID = "costumerCases"; +export const customerCaseID = "CustomerCase"; -const customerCases = defineType({ - name: customerCasesID, +const customerCase = defineType({ + name: customerCaseID, type: "document", - title: "Costumer Cases", + title: "Customer Case", fields: [ defineField({ name: "language", @@ -19,7 +18,7 @@ const customerCases = defineType({ titleSlug, defineField({ ...richText, - description: "Enter the body content of the costumer case.", + description: "Enter the body content of the Customer case.", }), ], preview: { @@ -27,9 +26,9 @@ const customerCases = defineType({ title: "basicTitle", }, prepare({ title }) { - return { title, subtitle: "Costumer case" }; + return { title, subtitle: "Customer case" }; }, }, }); -export default customerCases; +export default customerCase; From c6471e6ff4d9e570d4c379da43b7551d81b7bef1 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Tue, 10 Sep 2024 22:04:24 +0200 Subject: [PATCH 05/11] fix lint --- studioShared/deskStructure.ts | 2 +- studioShared/schemas/documents/blogPosts.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/studioShared/deskStructure.ts b/studioShared/deskStructure.ts index cc90993bf..0f19063f5 100644 --- a/studioShared/deskStructure.ts +++ b/studioShared/deskStructure.ts @@ -12,6 +12,6 @@ export const deskStructure: StructureResolver = (S) => S.documentTypeList(customerCaseID) .title("Customer cases") .filter("_type == $type && language == $lang") - .params({ type: customerCaseID, lang: i18n.base }) + .params({ type: customerCaseID, lang: i18n.base }), ), ]); diff --git a/studioShared/schemas/documents/blogPosts.ts b/studioShared/schemas/documents/blogPosts.ts index a8cbb3a20..599c567d0 100644 --- a/studioShared/schemas/documents/blogPosts.ts +++ b/studioShared/schemas/documents/blogPosts.ts @@ -59,7 +59,7 @@ const blogPosts = defineType({ }, prepare({ title, date }) { const subtitles = [date && format(parseISO(date), "LLL d, yyyy")].filter( - Boolean + Boolean, ); return { title, subtitle: subtitles.join(" ") }; From 1c375385f363899c4b629f76789371c11a3f8d35 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Tue, 10 Sep 2024 22:19:54 +0200 Subject: [PATCH 06/11] revert changes to blogpost --- studioShared/schemas/documents/blogPosts.ts | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/studioShared/schemas/documents/blogPosts.ts b/studioShared/schemas/documents/blogPosts.ts index 599c567d0..9b4c52ed4 100644 --- a/studioShared/schemas/documents/blogPosts.ts +++ b/studioShared/schemas/documents/blogPosts.ts @@ -23,8 +23,13 @@ const blogPosts = defineType({ // Ensure date is not undefined or null if (!date) return "The publish date is required."; + // Ensure context.document is defined and _createdAt exists + if (!context.document || !context.document._createdAt) { + return "Creation date is missing."; + } + const selectedDate = new Date(date); - const createdAt = new Date(context.document?._createdAt as string); + const createdAt = new Date(context.document._createdAt as string); const now = new Date(); // Add a small buffer of 1 second (1000 milliseconds) @@ -45,12 +50,6 @@ const blogPosts = defineType({ ...richText, description: "Enter the body content of the post.", }), - defineField({ - name: "language", - type: "string", - readOnly: true, - hidden: true, - }), ], preview: { select: { @@ -59,7 +58,7 @@ const blogPosts = defineType({ }, prepare({ title, date }) { const subtitles = [date && format(parseISO(date), "LLL d, yyyy")].filter( - Boolean, + Boolean ); return { title, subtitle: subtitles.join(" ") }; From dd7d4b18ba87b2fda63bc945537c134127446731 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Tue, 10 Sep 2024 22:20:56 +0200 Subject: [PATCH 07/11] lint fix --- studioShared/schemas/documents/blogPosts.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/studioShared/schemas/documents/blogPosts.ts b/studioShared/schemas/documents/blogPosts.ts index 9b4c52ed4..10208b062 100644 --- a/studioShared/schemas/documents/blogPosts.ts +++ b/studioShared/schemas/documents/blogPosts.ts @@ -58,7 +58,7 @@ const blogPosts = defineType({ }, prepare({ title, date }) { const subtitles = [date && format(parseISO(date), "LLL d, yyyy")].filter( - Boolean + Boolean, ); return { title, subtitle: subtitles.join(" ") }; From a8117f3e2a42243ecfacf3db44f17be5696fef47 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Wed, 11 Sep 2024 12:39:36 +0200 Subject: [PATCH 08/11] fix merge conflicts --- studioShared/studioConfig.tsx | 40 ++++++++++++++++++++++++++++++----- 1 file changed, 35 insertions(+), 5 deletions(-) diff --git a/studioShared/studioConfig.tsx b/studioShared/studioConfig.tsx index 856fb4947..e9a0e713c 100644 --- a/studioShared/studioConfig.tsx +++ b/studioShared/studioConfig.tsx @@ -1,8 +1,14 @@ -import { dataset, projectId } from "./env"; -import { schema } from "./schema"; -import { structureTool } from "sanity/structure"; import { WorkspaceOptions } from "sanity"; import StudioIcon from "../studio/components/studioIcon/StudioIcon"; +import { defineField } from "sanity"; +import { documentInternationalization } from "@sanity/document-internationalization"; +import { visionTool } from "@sanity/vision"; +import { structureTool } from "sanity/structure"; +import { apiVersion, dataset, projectId } from "./env"; +import { schema } from "./schema"; +import { i18n } from "languages"; +import { customerCaseID } from "./schemas/documents/customerCase"; +import { deskStructure } from "./deskStructure"; const config: WorkspaceOptions = { name: "sharedStudio", @@ -12,8 +18,32 @@ const config: WorkspaceOptions = { basePath: "/shared", projectId, dataset, - schema, - plugins: [structureTool()], + schema: { + ...schema, + templates: (prev) => + prev.filter((template) => template.value.language === i18n.base), + }, + plugins: [ + structureTool({ + structure: deskStructure, + }), + visionTool({ defaultApiVersion: apiVersion }), + documentInternationalization({ + // TODO: a function that takes the client and returns a promise of an array of supported languages + // MUST return an "id" and "title" as strings + // supportedLanguages: (client) => client.fetch(`*[_type == "language"]{id, title}`), + supportedLanguages: i18n.languages, + schemaTypes: [customerCaseID], + languageField: `language`, + metadataFields: [defineField({ name: "slug", type: "slug" })], + apiVersion, + // TODO: + // Optional + // Adds UI for publishing all translations at once. Requires access to the Scheduling API + // https://www.sanity.io/docs/scheduling-api + // bulkPublish: true, + }), + ], }; export default config; From 2b4517561ee6c54d4e5456a1869a17d2a1e86275 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Wed, 11 Sep 2024 13:06:15 +0200 Subject: [PATCH 09/11] remove unused --- languages.ts | 2 +- studioShared/studioConfig.tsx | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/languages.ts b/languages.ts index 915dfaf2a..eaf9ff349 100644 --- a/languages.ts +++ b/languages.ts @@ -1,5 +1,5 @@ const languages = [ - { id: "en", title: "English", isDefault: true }, + { id: "en", title: "English" }, { id: "se", title: "Swedish" }, { id: "no", title: "Norwegian" }, ]; diff --git a/studioShared/studioConfig.tsx b/studioShared/studioConfig.tsx index e9a0e713c..50b45d955 100644 --- a/studioShared/studioConfig.tsx +++ b/studioShared/studioConfig.tsx @@ -35,7 +35,6 @@ const config: WorkspaceOptions = { supportedLanguages: i18n.languages, schemaTypes: [customerCaseID], languageField: `language`, - metadataFields: [defineField({ name: "slug", type: "slug" })], apiVersion, // TODO: // Optional From 63888e19ec8ae711cc159bb7600ccb01da6629df Mon Sep 17 00:00:00 2001 From: christinaroise Date: Wed, 11 Sep 2024 13:14:12 +0200 Subject: [PATCH 10/11] change documentTypeList to documentList --- studioShared/deskStructure.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/studioShared/deskStructure.ts b/studioShared/deskStructure.ts index 0f19063f5..8bcb38cc2 100644 --- a/studioShared/deskStructure.ts +++ b/studioShared/deskStructure.ts @@ -9,9 +9,9 @@ export const deskStructure: StructureResolver = (S) => S.listItem() .title("Customer cases") .child( - S.documentTypeList(customerCaseID) + S.documentList() .title("Customer cases") .filter("_type == $type && language == $lang") - .params({ type: customerCaseID, lang: i18n.base }), + .params({ type: customerCaseID, lang: i18n.base }) ), ]); From 3e6cf3a90bc5d743057b923f2fb6b3eeea3b3137 Mon Sep 17 00:00:00 2001 From: christinaroise Date: Wed, 11 Sep 2024 13:15:03 +0200 Subject: [PATCH 11/11] lint --- studioShared/deskStructure.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/studioShared/deskStructure.ts b/studioShared/deskStructure.ts index 8bcb38cc2..355513603 100644 --- a/studioShared/deskStructure.ts +++ b/studioShared/deskStructure.ts @@ -12,6 +12,6 @@ export const deskStructure: StructureResolver = (S) => S.documentList() .title("Customer cases") .filter("_type == $type && language == $lang") - .params({ type: customerCaseID, lang: i18n.base }) + .params({ type: customerCaseID, lang: i18n.base }), ), ]);