@sanity/document-internationalization 2.0.0-studio-v3-plugin-v2.5 → 2.0.0-studio-v3-plugin-v2.6

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.
@@ -1 +1 @@
1
- {"version":3,"file":"index.esm.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
1
+ {"version":3,"file":"index.esm.js","sources":["../src/constants.ts","../src/schema/translation/metadata.ts","../node_modules/suspend-react/dist/index.js","../src/hooks/useOpenInNewPane.tsx","../src/components/LanguageOption.tsx","../src/hooks/useLanguageMetadata.tsx","../src/components/LanguageManage.tsx","../src/components/LanguagePatch.tsx","../src/components/MenuButton.tsx","../src/badges/index.tsx","../src/plugin.tsx"],"sourcesContent":["export const METADATA_SCHEMA_NAME = `translation.metadata`\nexport const API_VERSION = `2022-11-27`\n","import {TranslateIcon} from '@sanity/icons'\nimport {defineField, defineType, DocumentDefinition} from 'sanity'\n\nimport {METADATA_SCHEMA_NAME} from '../../constants'\n\nexport default (schemaTypes: string[]): DocumentDefinition =>\n defineType({\n type: 'document',\n name: METADATA_SCHEMA_NAME,\n title: 'Translation metadata',\n icon: TranslateIcon,\n liveEdit: true,\n fields: [\n defineField({\n name: 'translations',\n type: 'internationalizedArrayReference',\n }),\n defineField({\n name: 'schemaTypes',\n description:\n 'Used to filter the reference fields above so all translations share the same types.',\n type: 'array',\n // For some reason TS dislikes this line because of the DocumentDefinition return type\n // @ts-expect-error\n of: [{type: 'string'}],\n options: {list: schemaTypes},\n readOnly: ({value}) => Boolean(value),\n }),\n ],\n preview: {\n select: {\n translations: 'translations',\n documentSchemaTypes: 'schemaTypes',\n },\n prepare(selection) {\n const {translations, documentSchemaTypes} = selection\n const title =\n translations.length === 1\n ? `1 Translation`\n : `${translations.length} Translations`\n const languageKeys = translations.length\n ? translations\n .map((t: {_key: string}) => t._key.toUpperCase())\n .join(', ')\n : ``\n const subtitle = [\n languageKeys ? `(${languageKeys})` : null,\n documentSchemaTypes?.length\n ? documentSchemaTypes.map((s: string) => s.toUpperCase()).join(`, `)\n : `No Schemas Defined`,\n ]\n .filter(Boolean)\n .join(` `)\n\n return {\n title,\n subtitle,\n }\n },\n },\n })\n","function shallowEqualArrays(arrA, arrB, equal = (a, b) => a === b) {\n if (arrA === arrB) return true;\n if (!arrA || !arrB) return false;\n const len = arrA.length;\n if (arrB.length !== len) return false;\n\n for (let i = 0; i < len; i++) if (!equal(arrA[i], arrB[i])) return false;\n\n return true;\n}\n\nconst globalCache = [];\n\nfunction query(fn, keys, preload = false, config = {}) {\n for (const entry of globalCache) {\n // Find a match\n if (shallowEqualArrays(keys, entry.keys, entry.equal)) {\n // If we're pre-loading and the element is present, just return\n if (preload) return undefined; // If an error occurred, throw\n\n if (Object.prototype.hasOwnProperty.call(entry, 'error')) throw entry.error; // If a response was successful, return\n\n if (Object.prototype.hasOwnProperty.call(entry, 'response')) return entry.response; // If the promise is still unresolved, throw\n\n if (!preload) throw entry.promise;\n }\n } // The request is new or has changed.\n\n\n const entry = {\n keys,\n equal: config.equal,\n promise: // Execute the promise\n fn(...keys) // When it resolves, store its value\n .then(response => entry.response = response) // Remove the entry if a lifespan was given\n .then(() => {\n if (config.lifespan && config.lifespan > 0) {\n setTimeout(() => {\n const index = globalCache.indexOf(entry);\n if (index !== -1) globalCache.splice(index, 1);\n }, config.lifespan);\n }\n }) // Store caught errors, they will be thrown in the render-phase to bubble into an error-bound\n .catch(error => entry.error = error)\n }; // Register the entry\n\n globalCache.push(entry); // And throw the promise, this yields control back to React\n\n if (!preload) throw entry.promise;\n return undefined;\n}\n\nconst suspend = (fn, keys, config) => query(fn, keys, false, config);\n\nconst preload = (fn, keys, config) => void query(fn, keys, true, config);\n\nconst peek = keys => {\n var _globalCache$find;\n\n return (_globalCache$find = globalCache.find(entry => shallowEqualArrays(keys, entry.keys, entry.equal))) == null ? void 0 : _globalCache$find.response;\n};\n\nconst clear = keys => {\n if (keys === undefined || keys.length === 0) globalCache.splice(0, globalCache.length);else {\n const entry = globalCache.find(entry => shallowEqualArrays(keys, entry.keys, entry.equal));\n\n if (entry) {\n const index = globalCache.indexOf(entry);\n if (index !== -1) globalCache.splice(index, 1);\n }\n }\n};\n\nexport { clear, peek, preload, suspend };\n","import React from 'react'\nimport {usePaneRouter} from 'sanity/desk'\nimport {RouterContext} from 'sanity/router'\n\nexport function useOpenInNewPane(id?: string, type?: string) {\n const routerContext = React.useContext(RouterContext)\n const {routerPanesState, groupIndex} = usePaneRouter()\n\n const openInNewPane = React.useCallback(() => {\n if (!routerContext || !id || !type) {\n return\n }\n\n const panes = [...routerPanesState]\n panes.splice(groupIndex + 1, 0, [\n {\n id: id,\n params: {type},\n },\n ])\n\n const href = routerContext.resolvePathFromState({panes})\n routerContext.navigateUrl({path: href})\n }, [id, type, routerContext, routerPanesState, groupIndex])\n\n return openInNewPane\n}\n","import React, {useCallback} from 'react'\nimport {useClient} from 'sanity'\nimport {Button, Badge, Box, Flex, Text, useToast, Spinner} from '@sanity/ui'\nimport {uuid} from '@sanity/uuid'\nimport {SplitVerticalIcon, AddIcon, CheckmarkIcon} from '@sanity/icons'\n\nimport {Language, Metadata, TranslationReference} from '../types'\nimport {API_VERSION, METADATA_SCHEMA_NAME} from '../constants'\nimport {useOpenInNewPane} from '../hooks/useOpenInNewPane'\n\ntype LanguageOptionProps = {\n language: Language\n languageField: string\n index: number\n schemaType: string\n documentId: string\n disabled: boolean\n current: boolean\n sourceId: string\n sourceLanguageId?: string\n metadata?: Metadata | null\n translation?: TranslationReference\n apiVersion?: string\n}\n\nfunction createReference(key: string, ref: string, type: string) {\n return {\n _key: key,\n value: {\n _type: 'reference',\n _ref: ref,\n _weak: true,\n _strengthenOnPublish: {\n type,\n },\n },\n }\n}\n\nexport default function LanguageOption(props: LanguageOptionProps) {\n const {\n apiVersion = API_VERSION,\n index,\n language,\n languageField,\n schemaType,\n documentId,\n disabled,\n current,\n sourceId,\n sourceLanguageId,\n metadata,\n translation,\n } = props\n const client = useClient({apiVersion})\n const toast = useToast()\n\n const open = useOpenInNewPane(translation?.value?._ref, schemaType)\n const handleOpen = useCallback(() => open(), [open])\n\n const handleCreate = useCallback(async () => {\n const metadataExists = Boolean(metadata?._id)\n const transaction = client.transaction()\n\n // 1. Duplicate current document\n // 2. Update language\n // 3. Add to translation metadata\n const documentIds = documentId.startsWith(`drafts.`)\n ? [documentId, documentId.replace(`drafts.`, ``)]\n : [documentId, `drafts.${documentId}`]\n const latestDocument = await client.fetch(`*[_id in $ids]|order(_updatedAt desc)[0]`, {\n ids: documentIds,\n })\n const newTranslationDocument = {\n ...latestDocument,\n _id: `drafts.${uuid()}`,\n [languageField]: language.id,\n }\n\n transaction.create(newTranslationDocument)\n\n const metadataId = metadata?._id ?? uuid()\n const newTranslationReference = createReference(\n language.id,\n newTranslationDocument._id.replace(`drafts.`, ``),\n schemaType\n )\n\n // Create translation metadata document if it doesn't already exist\n if (metadataExists) {\n const path = `translations[${index - 1}]`\n const metadataPatch = client\n .patch(metadataId)\n .setIfMissing({translations: []})\n .insert(`before`, path, [newTranslationReference])\n\n transaction.patch(metadataPatch)\n } else {\n // Source language relies on a field named `language` on the document\n const sourceReference = sourceLanguageId\n ? createReference(sourceLanguageId, sourceId, schemaType)\n : null\n\n transaction.createIfNotExists({\n _id: metadataId,\n _type: METADATA_SCHEMA_NAME,\n schemaTypes: [schemaType],\n translations: [newTranslationReference, sourceReference].filter(Boolean),\n })\n }\n\n transaction\n .commit()\n .then(() => {\n // openDocumentInSidePane(metadataId, `translation.metadata`)\n return toast.push({\n status: 'success',\n title: `Created ${language.title} translation`,\n description: metadataExists\n ? `Updated Translations Metadata`\n : `Created Translations Metadata`,\n })\n })\n .catch((err) => {\n console.error(err)\n\n return toast.push({\n status: 'error',\n title: `Error creating translation`,\n description: err.message,\n })\n })\n }, [\n client,\n documentId,\n index,\n language,\n languageField,\n metadata?._id,\n schemaType,\n sourceId,\n sourceLanguageId,\n toast,\n ])\n\n return (\n <Button\n onClick={translation ? handleOpen : handleCreate}\n mode={current ? `default` : `bleed`}\n disabled={disabled || current}\n >\n <Flex gap={3} align=\"center\">\n {disabled ? (\n <Spinner />\n ) : (\n <Text size={2}>\n {/* eslint-disable-next-line no-nested-ternary */}\n {translation ? <SplitVerticalIcon /> : current ? <CheckmarkIcon /> : <AddIcon />}\n </Text>\n )}\n <Box flex={1}>\n <Text>{language.title}</Text>\n </Box>\n <Badge tone={disabled || current ? `default` : `primary`}>{language.id}</Badge>\n </Flex>\n </Button>\n )\n}\n","import React from 'react'\nimport {useListeningQuery} from 'sanity-plugin-utils'\nimport {METADATA_SCHEMA_NAME} from '../constants'\n\nimport {Metadata} from '../types'\n\nexport function useTranslationMetadata(\n id: string,\n schemaType: string\n): {\n data: Metadata | null\n loading: boolean\n error: boolean\n} {\n const query = `*[_type == $translationSchema && $id in translations[].value._ref][0]`\n const {data, loading, error} = useListeningQuery<Metadata>(query, {\n params: {id, translationSchema: METADATA_SCHEMA_NAME},\n })\n\n return {data, loading, error}\n}\n","import React from 'react'\nimport {CogIcon} from '@sanity/icons'\nimport {Button} from '@sanity/ui'\n\nimport {useOpenInNewPane} from '../hooks/useOpenInNewPane'\nimport {METADATA_SCHEMA_NAME} from '../constants'\n\ntype LanguageManageProps = {\n id?: string\n}\n\nexport default function LanguageManage(props: LanguageManageProps) {\n const {id} = props\n const open = useOpenInNewPane(id, METADATA_SCHEMA_NAME)\n\n return (\n <Button\n disabled={!id}\n mode=\"ghost\"\n text=\"Manage Translations\"\n icon={CogIcon}\n onClick={() => open()}\n />\n )\n}\n","import React from 'react'\nimport {ChevronRightIcon} from '@sanity/icons'\nimport {Button, useToast} from '@sanity/ui'\nimport {SanityDocument, useClient} from 'sanity'\n\nimport {Language} from '../types'\nimport {API_VERSION} from '../constants'\n\ntype LanguagePatchProps = {\n language: Language\n languageField: string\n documentId: string\n schemaType: string\n source: SanityDocument | null\n disabled: boolean\n apiVersion?: string\n}\n\nexport default function LanguagePatch(props: LanguagePatchProps) {\n const {\n apiVersion = API_VERSION,\n language,\n languageField,\n documentId,\n schemaType,\n source,\n disabled = false,\n } = props\n const client = useClient({apiVersion})\n const toast = useToast()\n\n const handleClick = React.useCallback(() => {\n const currentId = source ? source._id : `draft.${documentId}`\n const transaction = client.transaction()\n\n if (!source) {\n transaction.createIfNotExists({\n _id: currentId,\n _type: schemaType,\n })\n }\n\n const patch = client.patch(currentId).set({[languageField]: language.id})\n transaction.patch(patch)\n\n transaction\n .commit()\n .then(() => {\n toast.push({\n title: `Set document language to ${language.title}`,\n status: `success`,\n })\n })\n .catch((err) => {\n console.error(err)\n\n return toast.push({\n title: `Failed to set document language to ${language.title}`,\n status: `error`,\n })\n })\n }, [source, documentId, client, languageField, language, schemaType, toast])\n\n return (\n <Button\n mode=\"ghost\"\n text={language.title}\n icon={ChevronRightIcon}\n onClick={() => handleClick()}\n disabled={disabled}\n justify=\"flex-start\"\n />\n )\n}\n","import {suspend} from 'suspend-react'\nimport React, {useCallback, useState} from 'react'\nimport {Text, Card, useClickOutside, Stack, Popover, Button, Box} from '@sanity/ui'\nimport {TranslateIcon} from '@sanity/icons'\nimport {useClient, useEditState, useWorkspace} from 'sanity'\n\nimport {SupportedLanguages} from '../types'\nimport LanguageOption from './LanguageOption'\nimport {useTranslationMetadata} from '../hooks/useLanguageMetadata'\nimport LanguageManage from './LanguageManage'\nimport LanguagePatch from './LanguagePatch'\nimport {API_VERSION} from '../constants'\n\ntype MenuButtonProps = {\n supportedLanguages: SupportedLanguages\n schemaType: string\n documentId: string\n languageField: string\n apiVersion?: string\n}\n\nexport default function MenuButton(props: MenuButtonProps) {\n const {apiVersion = API_VERSION, schemaType, documentId, languageField} = props\n\n const client = useClient({apiVersion})\n const supportedLanguages = Array.isArray(props.supportedLanguages)\n ? props.supportedLanguages\n : // eslint-disable-next-line require-await\n suspend(async () => {\n if (typeof props.supportedLanguages === 'function') {\n return props.supportedLanguages(client)\n }\n return props.supportedLanguages\n }, [])\n\n const [open, setOpen] = useState(false)\n const handleClick = useCallback(() => setOpen((o) => !o), [])\n const [button, setButton] = useState<HTMLElement | null>(null)\n const [popover, setPopover] = useState<HTMLElement | null>(null)\n const handleClickOutside = useCallback(() => setOpen(false), [])\n useClickOutside(handleClickOutside, [button, popover])\n const {data: metadata, loading, error} = useTranslationMetadata(documentId, schemaType)\n const {draft, published} = useEditState(documentId, schemaType)\n const source = draft || published\n\n const sourceLanguageId = source?.[languageField] as string | undefined\n const sourceLanguageIsValid = supportedLanguages.some((l) => l.id === sourceLanguageId)\n const allLanguagesAreValid = React.useMemo(() => {\n const valid = supportedLanguages.every((l) => l.id && l.title)\n if (!valid) {\n console.warn(\n `Not all languages are valid. It should be an array of objects with an \"id\" and \"title\" property. Or a function that returns an array of objects with an \"id\" and \"title\" property.`,\n supportedLanguages\n )\n }\n\n return valid\n }, [supportedLanguages])\n\n const content = (\n <Box>\n {error ? (\n <Card tone=\"critical\" padding={2}>\n <Text>Error: {error}</Text>\n </Card>\n ) : (\n <Stack padding={1} space={1}>\n {supportedLanguages.length > 0 ? (\n <>\n {supportedLanguages.map((language, langIndex) =>\n !loading && sourceLanguageId && sourceLanguageIsValid ? (\n // Button to duplicate this document to a new translation\n // And either create or update the metadata document\n <LanguageOption\n key={language.id || language.title || `lang-${langIndex}`}\n index={langIndex}\n language={language}\n languageField={languageField}\n schemaType={schemaType}\n documentId={documentId}\n disabled={loading || !allLanguagesAreValid}\n current={language.id === sourceLanguageId}\n metadata={metadata}\n sourceId={documentId}\n sourceLanguageId={sourceLanguageId}\n translation={metadata?.translations.find((t) => t._key === language.id)}\n />\n ) : (\n // Button to set a language field on *this* document\n <LanguagePatch\n key={language.id || language.title || `lang-${langIndex}`}\n languageField={languageField}\n source={source}\n documentId={documentId}\n schemaType={schemaType}\n language={language}\n // Only allow language patch change to:\n // - Keys not in metadata\n // - The key of this document in the metadata\n disabled={\n (!allLanguagesAreValid ||\n metadata?.translations\n .filter((t) => t?.value?._ref !== documentId)\n .some((t) => t._key === language.id)) ??\n false\n }\n />\n )\n )}\n {/* Once metadata is loaded, there may be issues */}\n {loading ? null : (\n <>\n {/* Not all languages are valid */}\n {allLanguagesAreValid ? null : (\n <Card tone=\"caution\" padding={3}>\n <Text size={1}>Not all language objects are valid. See the console.</Text>\n </Card>\n )}\n {/* Current document has no language field */}\n {sourceLanguageId ? null : (\n <Card tone=\"caution\" padding={3}>\n <Text size={1}>\n Choose a language to <br />\n apply to <strong>this Document</strong>\n </Text>\n </Card>\n )}\n {/* Current document has an invalid language field */}\n {sourceLanguageId && !sourceLanguageIsValid ? (\n <Card tone=\"caution\" padding={3}>\n <Text size={1}>\n Change the current language value <code>{sourceLanguageId}</code>\n <br />\n to one of the supported languages\n </Text>\n </Card>\n ) : null}\n </>\n )}\n </>\n ) : null}\n <LanguageManage id={metadata?._id} />\n </Stack>\n )}\n </Box>\n )\n\n return (\n <Popover constrainSize content={content} open={open} portal ref={setPopover} overflow=\"auto\">\n <Button\n text=\"Translations\"\n mode=\"bleed\"\n disabled={!source}\n tone={\n !source || (!loading && sourceLanguageId && sourceLanguageIsValid) ? undefined : `caution`\n }\n icon={TranslateIcon}\n onClick={handleClick}\n ref={setButton}\n selected={open}\n />\n </Popover>\n )\n}\n","import {DocumentBadgeDescription, DocumentBadgeProps} from 'sanity'\n\nimport {SupportedLanguages} from '../types'\n\nexport function LanguageBadge(\n props: DocumentBadgeProps,\n supportedLanguages: SupportedLanguages,\n languageField: string\n): DocumentBadgeDescription | null {\n const source = props?.draft || props?.published\n const languageId = source?.[languageField]\n\n if (!languageId) {\n return null\n }\n\n const language = Array.isArray(supportedLanguages)\n ? supportedLanguages.find((l) => l.id === languageId)\n : null\n\n // Currently we only show the language id if the supportedLanguages are async\n return {\n label: language?.id ?? String(languageId),\n title: language?.title ?? undefined,\n color: `primary`,\n }\n}\n","import React from 'react'\nimport {definePlugin, defineField} from 'sanity'\nimport {internationalizedArray} from 'sanity-plugin-internationalized-array'\nimport {Stack} from '@sanity/ui'\n\nimport metadata from './schema/translation/metadata'\nimport MenuButton from './components/MenuButton'\nimport {PluginConfig} from './types'\nimport {LanguageBadge} from './badges'\nimport {METADATA_SCHEMA_NAME} from './constants'\nimport BulkPublish from './components/BulkPublish'\n\nconst DEFAULT_CONFIG = {\n supportedLanguages: [],\n schemaTypes: [],\n languageField: `language`,\n bulkPublish: false,\n}\n\nexport const documentInternationalization = definePlugin<PluginConfig>((config) => {\n const {supportedLanguages, schemaTypes, languageField, bulkPublish} = {\n ...DEFAULT_CONFIG,\n ...config,\n }\n\n const renderLanguageFilter = (schemaType: string, documentId?: string) => {\n return (\n <MenuButton\n supportedLanguages={supportedLanguages}\n schemaType={schemaType}\n documentId={documentId ?? ``}\n languageField={languageField}\n />\n )\n }\n\n return {\n name: '@sanity/document-internationalization',\n\n // Adds:\n // - A bulk-publishing UI component to the form\n // - Will only work for projects on a compatible plan\n form: {\n components: {\n input: (props) => {\n if (\n bulkPublish &&\n props.id === 'root' &&\n props.schemaType.name === METADATA_SCHEMA_NAME\n ) {\n return (\n <Stack space={5}>\n {/* <BulkPublish {...props} /> */}\n {props.renderDefault(props)}\n </Stack>\n )\n }\n\n return props.renderDefault(props)\n },\n },\n },\n\n // Adds:\n // - The `Translations` dropdown to the editing form\n // - `Badges` to documents with a language value\n document: {\n unstable_languageFilter: (prev, ctx) => {\n const {schemaType, documentId} = ctx\n\n return schemaTypes.includes(schemaType)\n ? [...prev, () => renderLanguageFilter(schemaType, documentId)]\n : prev\n },\n badges: (prev, {schemaType}) => {\n if (!schemaTypes.includes(schemaType)) {\n return prev\n }\n\n return [(props) => LanguageBadge(props, supportedLanguages, languageField), ...prev]\n },\n },\n\n // Adds:\n // - The `Translations metadata` document type to the schema\n schema: {\n // Create the metadata document type\n types: [metadata(schemaTypes)],\n\n // For every schema type this plugin is enabled on\n // Create an initial value template to set the language\n templates: (prev, {schema}) => {\n // Templates are not setup for async languages\n if (!Array.isArray(supportedLanguages)) {\n return prev\n }\n\n const parameterizedTemplates = schemaTypes.map((schemaType) => ({\n id: `${schemaType}-parameterized`,\n title: `${schema?.get(schemaType)?.title ?? schemaType}: with Language`,\n schemaType,\n parameters: [{name: `languageId`, title: `Language ID`, type: `string`}],\n value: ({languageId}: {languageId: string}) => ({\n [languageField]: languageId,\n }),\n }))\n\n const staticTemplates = schemaTypes.flatMap((schemaType) => {\n return supportedLanguages.map((language) => ({\n id: `${schemaType}-${language.id}`,\n title: `${language.title} ${schema?.get(schemaType)?.title ?? schemaType}`,\n schemaType,\n value: {\n [languageField]: language.id,\n },\n }))\n })\n\n return [...prev, ...parameterizedTemplates, ...staticTemplates]\n },\n },\n\n // Uses:\n // - `sanity-plugin-internationalized-array` to maintain the translations array\n plugins: [\n // Translation metadata stores its references using this plugin\n // It cuts down on attribute usage and gives UI conveniences to add new translations\n internationalizedArray({\n languages: supportedLanguages,\n fieldTypes: [\n // TODO: The plugin should allow this kind of input\n // @ts-ignore\n defineField(\n {\n name: 'reference',\n type: 'reference',\n to: schemaTypes.map((type) => ({type: type})),\n // TODO: Add a validation rule to *ensure* the document's language matches the array key\n // Reference filters don't actually enforce validation!\n // validation: (Rule) => Rule.custom(),\n options: {\n collapsed: false,\n // TODO: Update type once it knows the values of this filter\n // @ts-ignore\n filter: ({parent, document}) => {\n if (!parent) return null\n\n // I'm not sure in what instance there's an array of parents\n // But the Type suggests it's possible\n const parentArray = Array.isArray(parent) ? parent : [parent]\n const language = parentArray.find((p) => p._key)\n\n if (!language?._key) return null\n\n if (document.schemaTypes) {\n return {\n filter: `_type in $schemaTypes && ${languageField} == $language`,\n params: {schemaTypes: document.schemaTypes, language: language._key},\n }\n }\n\n return {\n filter: `${languageField} == $language`,\n params: {language: language._key},\n }\n },\n },\n },\n {strict: false}\n ),\n ],\n }),\n ],\n }\n})\n"],"names":["METADATA_SCHEMA_NAME","API_VERSION","metadata","schemaTypes","defineType","type","name","title","icon","TranslateIcon","liveEdit","fields","defineField","description","of","options","list","readOnly","_ref","value","Boolean","preview","select","translations","documentSchemaTypes","prepare","selection","length","concat","languageKeys","map","t","_key","toUpperCase","join","subtitle","s","filter","shallowEqualArrays","arrA","arrB","equal","arguments","undefined","a","b","len","i","globalCache","query","fn","keys","preload","config","entry","Object","prototype","hasOwnProperty","call","error","response","promise","then","lifespan","setTimeout","index","indexOf","splice","catch","push","suspend","useOpenInNewPane","id","routerContext","React","useContext","RouterContext","routerPanesState","groupIndex","usePaneRouter","openInNewPane","useCallback","panes","params","href","resolvePathFromState","navigateUrl","path","createReference","key","ref","_type","_weak","_strengthenOnPublish","LanguageOption","props","_a","apiVersion","language","languageField","schemaType","documentId","disabled","current","sourceId","sourceLanguageId","translation","client","useClient","toast","useToast","open","handleOpen","handleCreate","metadataExists","_id","transaction","documentIds","startsWith","replace","latestDocument","fetch","ids","newTranslationDocument","uuid","create","metadataId","newTranslationReference","metadataPatch","patch","setIfMissing","insert","sourceReference","createIfNotExists","commit","status","err","console","message","jsx","Button","onClick","mode","children","jsxs","Flex","gap","align","Spinner","Text","size","SplitVerticalIcon","CheckmarkIcon","AddIcon","Box","flex","Badge","tone","useTranslationMetadata","data","loading","useListeningQuery","translationSchema","LanguageManage","text","CogIcon","LanguagePatch","source","handleClick","currentId","set","ChevronRightIcon","justify","MenuButton","supportedLanguages","Array","isArray","setOpen","useState","o","button","setButton","popover","setPopover","handleClickOutside","useClickOutside","draft","published","useEditState","sourceLanguageIsValid","some","l","allLanguagesAreValid","useMemo","valid","every","warn","content","Card","padding","Stack","space","Fragment","langIndex","find","Popover","constrainSize","portal","overflow","selected","LanguageBadge","_b","languageId","label","String","color","DEFAULT_CONFIG","bulkPublish","documentInternationalization","definePlugin","renderLanguageFilter","form","components","input","renderDefault","document","unstable_languageFilter","prev","ctx","includes","badges","_ref2","schema","types","templates","_ref3","parameterizedTemplates","get","parameters","_ref4","staticTemplates","flatMap","plugins","internationalizedArray","languages","fieldTypes","to","collapsed","_ref5","parent","parentArray","p","strict"],"mappings":"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","x_google_ignoreList":[2]}