sanity-plugin-studio-smartling 4.0.2-beta → 4.0.4-beta
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/dist/index.d.ts +5 -0
- package/dist/index.esm.js +7 -3
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +9 -0
package/dist/index.d.ts
CHANGED
|
@@ -7,6 +7,7 @@ import {defaultStopTypes} from 'sanity-translations-tab'
|
|
|
7
7
|
import {documentLevelPatch} from 'sanity-translations-tab'
|
|
8
8
|
import {fieldLevelPatch} from 'sanity-translations-tab'
|
|
9
9
|
import {findLatestDraft} from 'sanity-translations-tab'
|
|
10
|
+
import {legacyDocumentLevelPatch} from 'sanity-translations-tab'
|
|
10
11
|
import {SerializedDocument} from 'sanity-naive-html-serializer'
|
|
11
12
|
import {TranslationFunctionContext} from 'sanity-translations-tab'
|
|
12
13
|
import {TranslationsTab} from 'sanity-translations-tab'
|
|
@@ -46,6 +47,10 @@ export {fieldLevelPatch}
|
|
|
46
47
|
|
|
47
48
|
export {findLatestDraft}
|
|
48
49
|
|
|
50
|
+
export declare const legacyDocumentLevelConfig: ConfigOptions
|
|
51
|
+
|
|
52
|
+
export {legacyDocumentLevelPatch}
|
|
53
|
+
|
|
49
54
|
export declare const SmartlingAdapter: Adapter
|
|
50
55
|
|
|
51
56
|
export {TranslationsTab}
|
package/dist/index.esm.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { baseDocumentLevelConfig, baseFieldLevelConfig } from 'sanity-translations-tab';
|
|
2
|
-
export { BaseDocumentDeserializer, BaseDocumentMerger, BaseDocumentSerializer, TranslationsTab, customSerializers, defaultStopTypes, documentLevelPatch, fieldLevelPatch, findLatestDraft } from 'sanity-translations-tab';
|
|
1
|
+
import { baseDocumentLevelConfig, legacyDocumentLevelConfig as legacyDocumentLevelConfig$1, baseFieldLevelConfig } from 'sanity-translations-tab';
|
|
2
|
+
export { BaseDocumentDeserializer, BaseDocumentMerger, BaseDocumentSerializer, TranslationsTab, customSerializers, defaultStopTypes, documentLevelPatch, fieldLevelPatch, findLatestDraft, legacyDocumentLevelPatch } from 'sanity-translations-tab';
|
|
3
3
|
import { Buffer } from 'buffer';
|
|
4
4
|
const authenticate = secrets => {
|
|
5
5
|
const url = "https://api.smartling.com/auth-api/v2/authenticate";
|
|
@@ -236,9 +236,13 @@ const defaultDocumentLevelConfig = {
|
|
|
236
236
|
...baseDocumentLevelConfig,
|
|
237
237
|
adapter: SmartlingAdapter
|
|
238
238
|
};
|
|
239
|
+
const legacyDocumentLevelConfig = {
|
|
240
|
+
...legacyDocumentLevelConfig$1,
|
|
241
|
+
adapter: SmartlingAdapter
|
|
242
|
+
};
|
|
239
243
|
const defaultFieldLevelConfig = {
|
|
240
244
|
...baseFieldLevelConfig,
|
|
241
245
|
adapter: SmartlingAdapter
|
|
242
246
|
};
|
|
243
|
-
export { SmartlingAdapter, defaultDocumentLevelConfig, defaultFieldLevelConfig };
|
|
247
|
+
export { SmartlingAdapter, defaultDocumentLevelConfig, defaultFieldLevelConfig, legacyDocumentLevelConfig };
|
|
244
248
|
//# sourceMappingURL=index.esm.js.map
|
package/dist/index.esm.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.esm.js","sources":["../src/adapter/helpers.ts","../src/adapter/getLocales.ts","../src/adapter/getTranslationTask.ts","../src/adapter/createTask.ts","../src/adapter/getTranslation.ts","../src/adapter/index.ts","../src/index.ts"],"sourcesContent":["import {Secrets} from 'sanity-translations-tab'\n\ninterface Headers {\n [key: string]: string\n}\n\nexport const authenticate = (secrets: Secrets): Promise<string> => {\n const url = 'https://api.smartling.com/auth-api/v2/authenticate'\n const headers = {\n 'content-type': 'application/json',\n 'X-URL': url,\n }\n const {secret, proxy} = secrets\n if (!secret || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a secret key and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n return fetch(proxy, {\n headers,\n method: 'POST',\n body: JSON.stringify(secret),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.accessToken)\n}\n\nexport const getHeaders = (url: string, accessToken: string): Headers => ({\n Authorization: `Bearer ${accessToken}`,\n 'X-URL': url,\n})\n\nexport const findExistingJob = (\n documentId: string,\n secrets: Secrets,\n accessToken: string\n): Promise<string> => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs?jobName=${documentId}`\n return fetch(proxy, {\n method: 'POST',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => {\n if (res.response.data.items.length) {\n //smartling will fuzzy match job names. We need to be precise.\n const correctJob = res.response.data.items.find(\n (item: {jobName: string}) => item.jobName && item.jobName === documentId\n )\n if (correctJob) {\n return correctJob.translationJobUid\n }\n return ''\n }\n return ''\n })\n}\n","import {authenticate, getHeaders} from './helpers'\nimport {Secrets} from 'sanity-translations-tab'\nimport {Adapter} from 'sanity-translations-tab'\n\nexport const getLocales: Adapter['getLocales'] = async (secrets: Secrets | null) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n return []\n }\n const {project, proxy} = secrets\n const url = `https://api.smartling.com/projects-api/v2/projects/${project}`\n const accessToken = await authenticate(secrets)\n return fetch(proxy, {\n method: 'GET',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.targetLocales)\n}\n","import {authenticate, getHeaders, findExistingJob} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\n\ninterface WorkflowProgressItem {\n workflowStepSummaryReportItemList: {\n wordCount: number\n }[]\n}\n\ninterface SmartlingProgressItem {\n targetLocaleId: string\n progress: {\n percentComplete: number\n totalWordCount: number\n }\n workflowProgressReportList: WorkflowProgressItem[]\n}\n\nexport const getTranslationTask: Adapter['getTranslationTask'] = async (\n documentId: string,\n secrets: Secrets | null\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n return {\n documentId,\n taskId: documentId,\n locales: [],\n }\n }\n\n const {project, proxy} = secrets\n\n const accessToken = await authenticate(secrets)\n const taskId = await findExistingJob(documentId, secrets, accessToken)\n if (!taskId) {\n return {\n documentId,\n taskId: documentId,\n locales: [],\n }\n }\n\n const progressUrl = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs/${taskId}/progress`\n const smartlingTask = await fetch(proxy, {\n method: 'GET',\n headers: getHeaders(progressUrl, accessToken),\n })\n .then((res) => res.json())\n .then((res) => res.response.data)\n\n let locales = []\n if (smartlingTask && smartlingTask.contentProgressReport) {\n locales = smartlingTask.contentProgressReport.map((item: SmartlingProgressItem) => {\n let progress = item.progress ? item.progress.percentComplete : 0\n if (\n item.workflowProgressReportList &&\n item.workflowProgressReportList.length > 0 &&\n item.progress\n ) {\n //default to the first workflow -- it's likely what is being used\n const progressItem = item.workflowProgressReportList[0]\n //this is a list of the various steps in the workflow\n if (\n progressItem.workflowStepSummaryReportItemList &&\n progressItem.workflowStepSummaryReportItemList.length > 1\n ) {\n //get the last step in the workflow -- usually \"published\"\n const lastStep = progressItem.workflowStepSummaryReportItemList.at(-1)\n //get the percentage of how many words have reached the last step\n if (lastStep && lastStep.wordCount >= 0) {\n progress = Math.floor((lastStep.wordCount / item.progress.totalWordCount) * 100) ?? 0\n }\n }\n }\n return {\n localeId: item.targetLocaleId,\n progress,\n }\n })\n }\n\n return {\n documentId,\n locales,\n //since our download is tied to document id for smartling, keep track of it as a task\n taskId: documentId,\n linkToVendorTask: `https://dashboard.smartling.com/app/projects/${project}/account-jobs/${project}:${taskId}`,\n }\n}\n","import {authenticate, getHeaders, findExistingJob} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\nimport {getTranslationTask} from './getTranslationTask'\nimport {Buffer} from 'buffer'\n\nconst createJob = (jobName: string, secrets: Secrets, localeIds: string[], accessToken: string) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const url = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs`\n return fetch(proxy, {\n method: 'POST',\n headers: {\n ...getHeaders(url, accessToken),\n 'content-type': 'application/json',\n },\n body: JSON.stringify({\n jobName,\n targetLocaleIds: localeIds,\n }),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.translationJobUid)\n}\n\n/* we're using batches here because it eliminates some\n * new string authorization issues for updating existing jobs,\n * and is able to be used for new bulk\n * job functionality.\n */\n\nconst createJobBatch = (\n jobId: string,\n secrets: Secrets,\n documentName: string,\n accessToken: string,\n localeIds: string[],\n workflowUid?: string\n //eslint-disable-next-line max-params\n) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/job-batches-api/v2/projects/${project}/batches`\n const reqBody: {\n authorize: boolean\n translationJobUid: string\n fileUris: string[]\n localeWorkflows?: {targetLocaleId: string; workflowUid: string}[]\n } = {\n authorize: true,\n translationJobUid: jobId,\n fileUris: [documentName],\n }\n\n if (workflowUid) {\n reqBody.localeWorkflows = localeIds.map((l) => ({\n targetLocaleId: l,\n workflowUid,\n }))\n }\n\n return fetch(proxy, {\n method: 'POST',\n headers: {\n ...getHeaders(url, accessToken),\n 'content-type': 'application/json',\n },\n body: JSON.stringify(reqBody),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.batchUid)\n}\n\nconst uploadFileToBatch = (\n batchUid: string,\n document: Record<string, any>,\n secrets: Secrets,\n localeIds: string[],\n accessToken: string\n) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/job-batches-api/v2/projects/${project}/batches/${batchUid}/file`\n const formData = new FormData()\n formData.append('fileUri', document.name)\n formData.append('fileType', 'html')\n const htmlBuffer = Buffer.from(document.content, 'utf-8')\n formData.append('file', new Blob([htmlBuffer]), `${document.name}.html`)\n localeIds.forEach((localeId) => formData.append('localeIdsToAuthorize[]', localeId))\n\n return fetch(proxy, {\n method: 'POST',\n headers: getHeaders(url, accessToken),\n body: formData,\n }).then((res) => res.json())\n}\n\nexport const createTask: Adapter['createTask'] = async (\n documentId: string,\n document: Record<string, any>,\n localeIds: string[],\n secrets: Secrets | null,\n workflowUid?: string\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n throw new Error(\n 'The Smartling adapter requires a project ID, a secret key, and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const accessToken = await authenticate(secrets)\n\n let taskId = await findExistingJob(document.name, secrets, accessToken)\n if (!taskId) {\n taskId = await createJob(document.name, secrets, localeIds, accessToken)\n }\n\n const batchUid = await createJobBatch(\n taskId,\n secrets,\n document.name,\n accessToken,\n localeIds,\n workflowUid\n )\n const uploadFileRes = await uploadFileToBatch(batchUid, document, secrets, localeIds, accessToken)\n //eslint-disable-next-line no-console -- for developer debugging\n console.info('Upload status from Smartling: ', uploadFileRes)\n\n return getTranslationTask(documentId, secrets)\n}\n","import {authenticate, getHeaders} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\n\nexport const getTranslation: Adapter['getTranslation'] = async (\n taskId: string,\n localeId: string,\n secrets: Secrets | null\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n throw new Error(\n 'The Smartling adapter requires a project ID, a secret key, and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const {project, proxy} = secrets\n\n const url = `https://api.smartling.com/files-api/v2/projects/${project}/locales/${localeId}/file?fileUri=${taskId}&retrievalType=pending`\n const accessToken = await authenticate(secrets)\n const translatedHTML = await fetch(proxy, {\n method: 'GET',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => {\n if (res.body) {\n return res.body\n } else if (res.response.errors) {\n const errMsg =\n res.response.errors[0]?.message || 'Error retrieving translation from Smartling'\n throw new Error(errMsg)\n }\n return ''\n })\n\n return translatedHTML\n}\n","import {Adapter} from 'sanity-translations-tab'\nimport {getLocales} from './getLocales'\nimport {getTranslationTask} from './getTranslationTask'\nimport {createTask} from './createTask'\nimport {getTranslation} from './getTranslation'\n\nexport const SmartlingAdapter: Adapter = {\n getLocales,\n getTranslationTask,\n createTask,\n getTranslation,\n}\n","import {SerializedDocument} from 'sanity-naive-html-serializer'\nimport {\n TranslationsTab,\n baseDocumentLevelConfig,\n baseFieldLevelConfig,\n findLatestDraft,\n BaseDocumentDeserializer,\n BaseDocumentSerializer,\n BaseDocumentMerger,\n defaultStopTypes,\n customSerializers,\n Adapter,\n documentLevelPatch,\n fieldLevelPatch,\n TranslationFunctionContext,\n} from 'sanity-translations-tab'\nimport {SmartlingAdapter} from './adapter'\n\ninterface ConfigOptions {\n adapter: Adapter\n secretsNamespace: string | null\n exportForTranslation: (\n id: string,\n context: TranslationFunctionContext\n ) => Promise<SerializedDocument>\n importTranslation: (\n id: string,\n localeId: string,\n doc: string,\n context: TranslationFunctionContext\n ) => Promise<void>\n}\nconst defaultDocumentLevelConfig: ConfigOptions = {\n ...baseDocumentLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nconst defaultFieldLevelConfig: ConfigOptions = {\n ...baseFieldLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nexport {\n TranslationsTab,\n findLatestDraft,\n documentLevelPatch,\n fieldLevelPatch,\n BaseDocumentDeserializer,\n BaseDocumentSerializer,\n BaseDocumentMerger,\n defaultStopTypes,\n customSerializers,\n SmartlingAdapter,\n defaultDocumentLevelConfig,\n defaultFieldLevelConfig,\n}\n"],"names":["authenticate","secrets","url","headers","secret","proxy","Error","fetch","method","body","JSON","stringify","then","res","json","response","data","accessToken","getHeaders","Authorization","findExistingJob","documentId","project","concat","items","length","correctJob","find","item","jobName","translationJobUid","getLocales","targetLocales","getTranslationTask","taskId","locales","progressUrl","smartlingTask","contentProgressReport","map","_a","progress","percentComplete","workflowProgressReportList","progressItem","workflowStepSummaryReportItemList","lastStep","at","wordCount","Math","floor","totalWordCount","localeId","targetLocaleId","linkToVendorTask","createJob","localeIds","targetLocaleIds","createJobBatch","jobId","documentName","workflowUid","reqBody","authorize","fileUris","localeWorkflows","l","batchUid","uploadFileToBatch","document","formData","FormData","append","name","htmlBuffer","Buffer","from","content","Blob","forEach","createTask","uploadFileRes","console","info","getTranslation","translatedHTML","errors","errMsg","message","SmartlingAdapter","defaultDocumentLevelConfig","baseDocumentLevelConfig","adapter","defaultFieldLevelConfig","baseFieldLevelConfig"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.esm.js","sources":["../src/adapter/helpers.ts","../src/adapter/getLocales.ts","../src/adapter/getTranslationTask.ts","../src/adapter/createTask.ts","../src/adapter/getTranslation.ts","../src/adapter/index.ts","../src/index.ts"],"sourcesContent":["import {Secrets} from 'sanity-translations-tab'\n\ninterface Headers {\n [key: string]: string\n}\n\nexport const authenticate = (secrets: Secrets): Promise<string> => {\n const url = 'https://api.smartling.com/auth-api/v2/authenticate'\n const headers = {\n 'content-type': 'application/json',\n 'X-URL': url,\n }\n const {secret, proxy} = secrets\n if (!secret || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a secret key and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n return fetch(proxy, {\n headers,\n method: 'POST',\n body: JSON.stringify(secret),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.accessToken)\n}\n\nexport const getHeaders = (url: string, accessToken: string): Headers => ({\n Authorization: `Bearer ${accessToken}`,\n 'X-URL': url,\n})\n\nexport const findExistingJob = (\n documentId: string,\n secrets: Secrets,\n accessToken: string\n): Promise<string> => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs?jobName=${documentId}`\n return fetch(proxy, {\n method: 'POST',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => {\n if (res.response.data.items.length) {\n //smartling will fuzzy match job names. We need to be precise.\n const correctJob = res.response.data.items.find(\n (item: {jobName: string}) => item.jobName && item.jobName === documentId\n )\n if (correctJob) {\n return correctJob.translationJobUid\n }\n return ''\n }\n return ''\n })\n}\n","import {authenticate, getHeaders} from './helpers'\nimport {Secrets} from 'sanity-translations-tab'\nimport {Adapter} from 'sanity-translations-tab'\n\nexport const getLocales: Adapter['getLocales'] = async (secrets: Secrets | null) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n return []\n }\n const {project, proxy} = secrets\n const url = `https://api.smartling.com/projects-api/v2/projects/${project}`\n const accessToken = await authenticate(secrets)\n return fetch(proxy, {\n method: 'GET',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.targetLocales)\n}\n","import {authenticate, getHeaders, findExistingJob} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\n\ninterface WorkflowProgressItem {\n workflowStepSummaryReportItemList: {\n wordCount: number\n }[]\n}\n\ninterface SmartlingProgressItem {\n targetLocaleId: string\n progress: {\n percentComplete: number\n totalWordCount: number\n }\n workflowProgressReportList: WorkflowProgressItem[]\n}\n\nexport const getTranslationTask: Adapter['getTranslationTask'] = async (\n documentId: string,\n secrets: Secrets | null\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n return {\n documentId,\n taskId: documentId,\n locales: [],\n }\n }\n\n const {project, proxy} = secrets\n\n const accessToken = await authenticate(secrets)\n const taskId = await findExistingJob(documentId, secrets, accessToken)\n if (!taskId) {\n return {\n documentId,\n taskId: documentId,\n locales: [],\n }\n }\n\n const progressUrl = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs/${taskId}/progress`\n const smartlingTask = await fetch(proxy, {\n method: 'GET',\n headers: getHeaders(progressUrl, accessToken),\n })\n .then((res) => res.json())\n .then((res) => res.response.data)\n\n let locales = []\n if (smartlingTask && smartlingTask.contentProgressReport) {\n locales = smartlingTask.contentProgressReport.map((item: SmartlingProgressItem) => {\n let progress = item.progress ? item.progress.percentComplete : 0\n if (\n item.workflowProgressReportList &&\n item.workflowProgressReportList.length > 0 &&\n item.progress\n ) {\n //default to the first workflow -- it's likely what is being used\n const progressItem = item.workflowProgressReportList[0]\n //this is a list of the various steps in the workflow\n if (\n progressItem.workflowStepSummaryReportItemList &&\n progressItem.workflowStepSummaryReportItemList.length > 1\n ) {\n //get the last step in the workflow -- usually \"published\"\n const lastStep = progressItem.workflowStepSummaryReportItemList.at(-1)\n //get the percentage of how many words have reached the last step\n if (lastStep && lastStep.wordCount >= 0) {\n progress = Math.floor((lastStep.wordCount / item.progress.totalWordCount) * 100) ?? 0\n }\n }\n }\n return {\n localeId: item.targetLocaleId,\n progress,\n }\n })\n }\n\n return {\n documentId,\n locales,\n //since our download is tied to document id for smartling, keep track of it as a task\n taskId: documentId,\n linkToVendorTask: `https://dashboard.smartling.com/app/projects/${project}/account-jobs/${project}:${taskId}`,\n }\n}\n","import {authenticate, getHeaders, findExistingJob} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\nimport {getTranslationTask} from './getTranslationTask'\nimport {Buffer} from 'buffer'\n\nconst createJob = (jobName: string, secrets: Secrets, localeIds: string[], accessToken: string) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const url = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs`\n return fetch(proxy, {\n method: 'POST',\n headers: {\n ...getHeaders(url, accessToken),\n 'content-type': 'application/json',\n },\n body: JSON.stringify({\n jobName,\n targetLocaleIds: localeIds,\n }),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.translationJobUid)\n}\n\n/* we're using batches here because it eliminates some\n * new string authorization issues for updating existing jobs,\n * and is able to be used for new bulk\n * job functionality.\n */\n\nconst createJobBatch = (\n jobId: string,\n secrets: Secrets,\n documentName: string,\n accessToken: string,\n localeIds: string[],\n workflowUid?: string\n //eslint-disable-next-line max-params\n) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/job-batches-api/v2/projects/${project}/batches`\n const reqBody: {\n authorize: boolean\n translationJobUid: string\n fileUris: string[]\n localeWorkflows?: {targetLocaleId: string; workflowUid: string}[]\n } = {\n authorize: true,\n translationJobUid: jobId,\n fileUris: [documentName],\n }\n\n if (workflowUid) {\n reqBody.localeWorkflows = localeIds.map((l) => ({\n targetLocaleId: l,\n workflowUid,\n }))\n }\n\n return fetch(proxy, {\n method: 'POST',\n headers: {\n ...getHeaders(url, accessToken),\n 'content-type': 'application/json',\n },\n body: JSON.stringify(reqBody),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.batchUid)\n}\n\nconst uploadFileToBatch = (\n batchUid: string,\n document: Record<string, any>,\n secrets: Secrets,\n localeIds: string[],\n accessToken: string\n) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/job-batches-api/v2/projects/${project}/batches/${batchUid}/file`\n const formData = new FormData()\n formData.append('fileUri', document.name)\n formData.append('fileType', 'html')\n const htmlBuffer = Buffer.from(document.content, 'utf-8')\n formData.append('file', new Blob([htmlBuffer]), `${document.name}.html`)\n localeIds.forEach((localeId) => formData.append('localeIdsToAuthorize[]', localeId))\n\n return fetch(proxy, {\n method: 'POST',\n headers: getHeaders(url, accessToken),\n body: formData,\n }).then((res) => res.json())\n}\n\nexport const createTask: Adapter['createTask'] = async (\n documentId: string,\n document: Record<string, any>,\n localeIds: string[],\n secrets: Secrets | null,\n workflowUid?: string\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n throw new Error(\n 'The Smartling adapter requires a project ID, a secret key, and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const accessToken = await authenticate(secrets)\n\n let taskId = await findExistingJob(document.name, secrets, accessToken)\n if (!taskId) {\n taskId = await createJob(document.name, secrets, localeIds, accessToken)\n }\n\n const batchUid = await createJobBatch(\n taskId,\n secrets,\n document.name,\n accessToken,\n localeIds,\n workflowUid\n )\n const uploadFileRes = await uploadFileToBatch(batchUid, document, secrets, localeIds, accessToken)\n //eslint-disable-next-line no-console -- for developer debugging\n console.info('Upload status from Smartling: ', uploadFileRes)\n\n return getTranslationTask(documentId, secrets)\n}\n","import {authenticate, getHeaders} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\n\nexport const getTranslation: Adapter['getTranslation'] = async (\n taskId: string,\n localeId: string,\n secrets: Secrets | null\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n throw new Error(\n 'The Smartling adapter requires a project ID, a secret key, and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const {project, proxy} = secrets\n\n const url = `https://api.smartling.com/files-api/v2/projects/${project}/locales/${localeId}/file?fileUri=${taskId}&retrievalType=pending`\n const accessToken = await authenticate(secrets)\n const translatedHTML = await fetch(proxy, {\n method: 'GET',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => {\n if (res.body) {\n return res.body\n } else if (res.response.errors) {\n const errMsg =\n res.response.errors[0]?.message || 'Error retrieving translation from Smartling'\n throw new Error(errMsg)\n }\n return ''\n })\n\n return translatedHTML\n}\n","import {Adapter} from 'sanity-translations-tab'\nimport {getLocales} from './getLocales'\nimport {getTranslationTask} from './getTranslationTask'\nimport {createTask} from './createTask'\nimport {getTranslation} from './getTranslation'\n\nexport const SmartlingAdapter: Adapter = {\n getLocales,\n getTranslationTask,\n createTask,\n getTranslation,\n}\n","import {SerializedDocument} from 'sanity-naive-html-serializer'\nimport {\n TranslationsTab,\n baseDocumentLevelConfig,\n legacyDocumentLevelConfig as baseLegacyDocumentLevelConfig,\n baseFieldLevelConfig,\n findLatestDraft,\n BaseDocumentDeserializer,\n BaseDocumentSerializer,\n BaseDocumentMerger,\n defaultStopTypes,\n customSerializers,\n Adapter,\n legacyDocumentLevelPatch,\n documentLevelPatch,\n fieldLevelPatch,\n TranslationFunctionContext,\n} from 'sanity-translations-tab'\nimport {SmartlingAdapter} from './adapter'\n\ninterface ConfigOptions {\n adapter: Adapter\n secretsNamespace: string | null\n exportForTranslation: (\n id: string,\n context: TranslationFunctionContext\n ) => Promise<SerializedDocument>\n importTranslation: (\n id: string,\n localeId: string,\n doc: string,\n context: TranslationFunctionContext\n ) => Promise<void>\n}\nconst defaultDocumentLevelConfig: ConfigOptions = {\n ...baseDocumentLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nconst legacyDocumentLevelConfig: ConfigOptions = {\n ...baseLegacyDocumentLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nconst defaultFieldLevelConfig: ConfigOptions = {\n ...baseFieldLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nexport {\n TranslationsTab,\n findLatestDraft,\n legacyDocumentLevelPatch,\n documentLevelPatch,\n fieldLevelPatch,\n BaseDocumentDeserializer,\n BaseDocumentSerializer,\n BaseDocumentMerger,\n defaultStopTypes,\n customSerializers,\n SmartlingAdapter,\n legacyDocumentLevelConfig,\n defaultDocumentLevelConfig,\n defaultFieldLevelConfig,\n}\n"],"names":["authenticate","secrets","url","headers","secret","proxy","Error","fetch","method","body","JSON","stringify","then","res","json","response","data","accessToken","getHeaders","Authorization","findExistingJob","documentId","project","concat","items","length","correctJob","find","item","jobName","translationJobUid","getLocales","targetLocales","getTranslationTask","taskId","locales","progressUrl","smartlingTask","contentProgressReport","map","_a","progress","percentComplete","workflowProgressReportList","progressItem","workflowStepSummaryReportItemList","lastStep","at","wordCount","Math","floor","totalWordCount","localeId","targetLocaleId","linkToVendorTask","createJob","localeIds","targetLocaleIds","createJobBatch","jobId","documentName","workflowUid","reqBody","authorize","fileUris","localeWorkflows","l","batchUid","uploadFileToBatch","document","formData","FormData","append","name","htmlBuffer","Buffer","from","content","Blob","forEach","createTask","uploadFileRes","console","info","getTranslation","translatedHTML","errors","errMsg","message","SmartlingAdapter","defaultDocumentLevelConfig","baseDocumentLevelConfig","adapter","legacyDocumentLevelConfig","baseLegacyDocumentLevelConfig","defaultFieldLevelConfig","baseFieldLevelConfig"],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -240,6 +240,10 @@ const defaultDocumentLevelConfig = {
|
|
|
240
240
|
...sanityTranslationsTab.baseDocumentLevelConfig,
|
|
241
241
|
adapter: SmartlingAdapter
|
|
242
242
|
};
|
|
243
|
+
const legacyDocumentLevelConfig = {
|
|
244
|
+
...sanityTranslationsTab.legacyDocumentLevelConfig,
|
|
245
|
+
adapter: SmartlingAdapter
|
|
246
|
+
};
|
|
243
247
|
const defaultFieldLevelConfig = {
|
|
244
248
|
...sanityTranslationsTab.baseFieldLevelConfig,
|
|
245
249
|
adapter: SmartlingAdapter
|
|
@@ -298,7 +302,14 @@ Object.defineProperty(exports, 'findLatestDraft', {
|
|
|
298
302
|
return sanityTranslationsTab.findLatestDraft;
|
|
299
303
|
}
|
|
300
304
|
});
|
|
305
|
+
Object.defineProperty(exports, 'legacyDocumentLevelPatch', {
|
|
306
|
+
enumerable: true,
|
|
307
|
+
get: function () {
|
|
308
|
+
return sanityTranslationsTab.legacyDocumentLevelPatch;
|
|
309
|
+
}
|
|
310
|
+
});
|
|
301
311
|
exports.SmartlingAdapter = SmartlingAdapter;
|
|
302
312
|
exports.defaultDocumentLevelConfig = defaultDocumentLevelConfig;
|
|
303
313
|
exports.defaultFieldLevelConfig = defaultFieldLevelConfig;
|
|
314
|
+
exports.legacyDocumentLevelConfig = legacyDocumentLevelConfig;
|
|
304
315
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../src/adapter/helpers.ts","../src/adapter/getLocales.ts","../src/adapter/getTranslationTask.ts","../src/adapter/createTask.ts","../src/adapter/getTranslation.ts","../src/adapter/index.ts","../src/index.ts"],"sourcesContent":["import {Secrets} from 'sanity-translations-tab'\n\ninterface Headers {\n [key: string]: string\n}\n\nexport const authenticate = (secrets: Secrets): Promise<string> => {\n const url = 'https://api.smartling.com/auth-api/v2/authenticate'\n const headers = {\n 'content-type': 'application/json',\n 'X-URL': url,\n }\n const {secret, proxy} = secrets\n if (!secret || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a secret key and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n return fetch(proxy, {\n headers,\n method: 'POST',\n body: JSON.stringify(secret),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.accessToken)\n}\n\nexport const getHeaders = (url: string, accessToken: string): Headers => ({\n Authorization: `Bearer ${accessToken}`,\n 'X-URL': url,\n})\n\nexport const findExistingJob = (\n documentId: string,\n secrets: Secrets,\n accessToken: string\n): Promise<string> => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs?jobName=${documentId}`\n return fetch(proxy, {\n method: 'POST',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => {\n if (res.response.data.items.length) {\n //smartling will fuzzy match job names. We need to be precise.\n const correctJob = res.response.data.items.find(\n (item: {jobName: string}) => item.jobName && item.jobName === documentId\n )\n if (correctJob) {\n return correctJob.translationJobUid\n }\n return ''\n }\n return ''\n })\n}\n","import {authenticate, getHeaders} from './helpers'\nimport {Secrets} from 'sanity-translations-tab'\nimport {Adapter} from 'sanity-translations-tab'\n\nexport const getLocales: Adapter['getLocales'] = async (secrets: Secrets | null) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n return []\n }\n const {project, proxy} = secrets\n const url = `https://api.smartling.com/projects-api/v2/projects/${project}`\n const accessToken = await authenticate(secrets)\n return fetch(proxy, {\n method: 'GET',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.targetLocales)\n}\n","import {authenticate, getHeaders, findExistingJob} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\n\ninterface WorkflowProgressItem {\n workflowStepSummaryReportItemList: {\n wordCount: number\n }[]\n}\n\ninterface SmartlingProgressItem {\n targetLocaleId: string\n progress: {\n percentComplete: number\n totalWordCount: number\n }\n workflowProgressReportList: WorkflowProgressItem[]\n}\n\nexport const getTranslationTask: Adapter['getTranslationTask'] = async (\n documentId: string,\n secrets: Secrets | null\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n return {\n documentId,\n taskId: documentId,\n locales: [],\n }\n }\n\n const {project, proxy} = secrets\n\n const accessToken = await authenticate(secrets)\n const taskId = await findExistingJob(documentId, secrets, accessToken)\n if (!taskId) {\n return {\n documentId,\n taskId: documentId,\n locales: [],\n }\n }\n\n const progressUrl = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs/${taskId}/progress`\n const smartlingTask = await fetch(proxy, {\n method: 'GET',\n headers: getHeaders(progressUrl, accessToken),\n })\n .then((res) => res.json())\n .then((res) => res.response.data)\n\n let locales = []\n if (smartlingTask && smartlingTask.contentProgressReport) {\n locales = smartlingTask.contentProgressReport.map((item: SmartlingProgressItem) => {\n let progress = item.progress ? item.progress.percentComplete : 0\n if (\n item.workflowProgressReportList &&\n item.workflowProgressReportList.length > 0 &&\n item.progress\n ) {\n //default to the first workflow -- it's likely what is being used\n const progressItem = item.workflowProgressReportList[0]\n //this is a list of the various steps in the workflow\n if (\n progressItem.workflowStepSummaryReportItemList &&\n progressItem.workflowStepSummaryReportItemList.length > 1\n ) {\n //get the last step in the workflow -- usually \"published\"\n const lastStep = progressItem.workflowStepSummaryReportItemList.at(-1)\n //get the percentage of how many words have reached the last step\n if (lastStep && lastStep.wordCount >= 0) {\n progress = Math.floor((lastStep.wordCount / item.progress.totalWordCount) * 100) ?? 0\n }\n }\n }\n return {\n localeId: item.targetLocaleId,\n progress,\n }\n })\n }\n\n return {\n documentId,\n locales,\n //since our download is tied to document id for smartling, keep track of it as a task\n taskId: documentId,\n linkToVendorTask: `https://dashboard.smartling.com/app/projects/${project}/account-jobs/${project}:${taskId}`,\n }\n}\n","import {authenticate, getHeaders, findExistingJob} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\nimport {getTranslationTask} from './getTranslationTask'\nimport {Buffer} from 'buffer'\n\nconst createJob = (jobName: string, secrets: Secrets, localeIds: string[], accessToken: string) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const url = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs`\n return fetch(proxy, {\n method: 'POST',\n headers: {\n ...getHeaders(url, accessToken),\n 'content-type': 'application/json',\n },\n body: JSON.stringify({\n jobName,\n targetLocaleIds: localeIds,\n }),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.translationJobUid)\n}\n\n/* we're using batches here because it eliminates some\n * new string authorization issues for updating existing jobs,\n * and is able to be used for new bulk\n * job functionality.\n */\n\nconst createJobBatch = (\n jobId: string,\n secrets: Secrets,\n documentName: string,\n accessToken: string,\n localeIds: string[],\n workflowUid?: string\n //eslint-disable-next-line max-params\n) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/job-batches-api/v2/projects/${project}/batches`\n const reqBody: {\n authorize: boolean\n translationJobUid: string\n fileUris: string[]\n localeWorkflows?: {targetLocaleId: string; workflowUid: string}[]\n } = {\n authorize: true,\n translationJobUid: jobId,\n fileUris: [documentName],\n }\n\n if (workflowUid) {\n reqBody.localeWorkflows = localeIds.map((l) => ({\n targetLocaleId: l,\n workflowUid,\n }))\n }\n\n return fetch(proxy, {\n method: 'POST',\n headers: {\n ...getHeaders(url, accessToken),\n 'content-type': 'application/json',\n },\n body: JSON.stringify(reqBody),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.batchUid)\n}\n\nconst uploadFileToBatch = (\n batchUid: string,\n document: Record<string, any>,\n secrets: Secrets,\n localeIds: string[],\n accessToken: string\n) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/job-batches-api/v2/projects/${project}/batches/${batchUid}/file`\n const formData = new FormData()\n formData.append('fileUri', document.name)\n formData.append('fileType', 'html')\n const htmlBuffer = Buffer.from(document.content, 'utf-8')\n formData.append('file', new Blob([htmlBuffer]), `${document.name}.html`)\n localeIds.forEach((localeId) => formData.append('localeIdsToAuthorize[]', localeId))\n\n return fetch(proxy, {\n method: 'POST',\n headers: getHeaders(url, accessToken),\n body: formData,\n }).then((res) => res.json())\n}\n\nexport const createTask: Adapter['createTask'] = async (\n documentId: string,\n document: Record<string, any>,\n localeIds: string[],\n secrets: Secrets | null,\n workflowUid?: string\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n throw new Error(\n 'The Smartling adapter requires a project ID, a secret key, and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const accessToken = await authenticate(secrets)\n\n let taskId = await findExistingJob(document.name, secrets, accessToken)\n if (!taskId) {\n taskId = await createJob(document.name, secrets, localeIds, accessToken)\n }\n\n const batchUid = await createJobBatch(\n taskId,\n secrets,\n document.name,\n accessToken,\n localeIds,\n workflowUid\n )\n const uploadFileRes = await uploadFileToBatch(batchUid, document, secrets, localeIds, accessToken)\n //eslint-disable-next-line no-console -- for developer debugging\n console.info('Upload status from Smartling: ', uploadFileRes)\n\n return getTranslationTask(documentId, secrets)\n}\n","import {authenticate, getHeaders} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\n\nexport const getTranslation: Adapter['getTranslation'] = async (\n taskId: string,\n localeId: string,\n secrets: Secrets | null\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n throw new Error(\n 'The Smartling adapter requires a project ID, a secret key, and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const {project, proxy} = secrets\n\n const url = `https://api.smartling.com/files-api/v2/projects/${project}/locales/${localeId}/file?fileUri=${taskId}&retrievalType=pending`\n const accessToken = await authenticate(secrets)\n const translatedHTML = await fetch(proxy, {\n method: 'GET',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => {\n if (res.body) {\n return res.body\n } else if (res.response.errors) {\n const errMsg =\n res.response.errors[0]?.message || 'Error retrieving translation from Smartling'\n throw new Error(errMsg)\n }\n return ''\n })\n\n return translatedHTML\n}\n","import {Adapter} from 'sanity-translations-tab'\nimport {getLocales} from './getLocales'\nimport {getTranslationTask} from './getTranslationTask'\nimport {createTask} from './createTask'\nimport {getTranslation} from './getTranslation'\n\nexport const SmartlingAdapter: Adapter = {\n getLocales,\n getTranslationTask,\n createTask,\n getTranslation,\n}\n","import {SerializedDocument} from 'sanity-naive-html-serializer'\nimport {\n TranslationsTab,\n baseDocumentLevelConfig,\n baseFieldLevelConfig,\n findLatestDraft,\n BaseDocumentDeserializer,\n BaseDocumentSerializer,\n BaseDocumentMerger,\n defaultStopTypes,\n customSerializers,\n Adapter,\n documentLevelPatch,\n fieldLevelPatch,\n TranslationFunctionContext,\n} from 'sanity-translations-tab'\nimport {SmartlingAdapter} from './adapter'\n\ninterface ConfigOptions {\n adapter: Adapter\n secretsNamespace: string | null\n exportForTranslation: (\n id: string,\n context: TranslationFunctionContext\n ) => Promise<SerializedDocument>\n importTranslation: (\n id: string,\n localeId: string,\n doc: string,\n context: TranslationFunctionContext\n ) => Promise<void>\n}\nconst defaultDocumentLevelConfig: ConfigOptions = {\n ...baseDocumentLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nconst defaultFieldLevelConfig: ConfigOptions = {\n ...baseFieldLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nexport {\n TranslationsTab,\n findLatestDraft,\n documentLevelPatch,\n fieldLevelPatch,\n BaseDocumentDeserializer,\n BaseDocumentSerializer,\n BaseDocumentMerger,\n defaultStopTypes,\n customSerializers,\n SmartlingAdapter,\n defaultDocumentLevelConfig,\n defaultFieldLevelConfig,\n}\n"],"names":["authenticate","secrets","url","headers","secret","proxy","Error","fetch","method","body","JSON","stringify","then","res","json","response","data","accessToken","getHeaders","Authorization","findExistingJob","documentId","project","concat","items","length","correctJob","find","item","jobName","translationJobUid","getLocales","targetLocales","getTranslationTask","taskId","locales","progressUrl","smartlingTask","contentProgressReport","map","_a","progress","percentComplete","workflowProgressReportList","progressItem","workflowStepSummaryReportItemList","lastStep","at","wordCount","Math","floor","totalWordCount","localeId","targetLocaleId","linkToVendorTask","createJob","localeIds","targetLocaleIds","createJobBatch","jobId","documentName","workflowUid","reqBody","authorize","fileUris","localeWorkflows","l","batchUid","uploadFileToBatch","document","formData","FormData","append","name","htmlBuffer","Buffer","from","content","Blob","forEach","createTask","uploadFileRes","console","info","getTranslation","translatedHTML","errors","errMsg","message","SmartlingAdapter","defaultDocumentLevelConfig","baseDocumentLevelConfig","adapter","defaultFieldLevelConfig","baseFieldLevelConfig"],"mappings":";;;;;;;AAMa,MAAAA,YAAA,GAAgBC,OAAsC,IAAA;EACjE,MAAMC,GAAM,GAAA,oDAAA;EACZ,MAAMC,OAAU,GAAA;IACd,cAAgB,EAAA,kBAAA;IAChB,OAAS,EAAAD;EAAA,CACX;EACM,MAAA;IAACE,MAAQ;IAAAC;EAAS,CAAA,GAAAJ,OAAA;EACpB,IAAA,CAACG,MAAU,IAAA,CAACC,KAAO,EAAA;IACrB,MAAM,IAAIC,KAAA,CACR,gJAAA,CACF;EACF;EACA,OAAOC,MAAMF,KAAO,EAAA;IAClBF,OAAA;IACAK,MAAQ,EAAA,MAAA;IACRC,IAAA,EAAMC,IAAK,CAAAC,SAAA,CAAUP,MAAM;EAC5B,CAAA,CAAA,CACEQ,IAAK,CAACC,OAAQA,GAAI,CAAAC,IAAA,EAAM,CAAA,CACxBF,KAAMC,GAAA,IAAQA,GAAI,CAAAE,QAAA,CAASC,KAAKC,WAAW,CAAA;AAChD,CAAA;AAEa,MAAAC,UAAA,GAAaA,CAAChB,GAAA,EAAae,WAAkC,MAAA;EACxEE,gCAAyBF,WAAA,CAAA;EACzB,OAAS,EAAAf;AACX,CAAA,CAAA;AAEO,MAAMkB,eAAkB,GAAAA,CAC7BC,UACA,EAAApB,OAAA,EACAgB,WACoB,KAAA;EACd,MAAA;IAACK,OAAS;IAAAjB;EAAS,CAAA,GAAAJ,OAAA;EACrB,IAAA,CAACqB,OAAW,IAAA,CAACjB,KAAO,EAAA;IACtB,MAAM,IAAIC,KAAA,CACR,kKAAA,CACF;EACF;EACM,MAAAJ,GAAA,qDAAAqB,MAAA,CAAwDD,OAAwB,oBAAAC,MAAA,CAAAF,UAAA,CAAA;EACtF,OAAOd,MAAMF,KAAO,EAAA;IAClBG,MAAQ,EAAA,MAAA;IACRL,OAAA,EAASe,UAAW,CAAAhB,GAAA,EAAKe,WAAW;EAAA,CACrC,CACE,CAAAL,IAAA,CAAMC,GAAA,IAAQA,GAAI,CAAAC,IAAA,EAAM,CAAA,CACxBF,IAAK,CAACC,GAAQ,IAAA;IACb,IAAIA,GAAI,CAAAE,QAAA,CAASC,IAAK,CAAAQ,KAAA,CAAMC,MAAQ,EAAA;MAElC,MAAMC,UAAa,GAAAb,GAAA,CAAIE,QAAS,CAAAC,IAAA,CAAKQ,KAAM,CAAAG,IAAA,CACxCC,IAAA,IAA4BA,IAAK,CAAAC,OAAA,IAAWD,KAAKC,OAAY,KAAAR,UAAA,CAChE;MACA,IAAIK,UAAY,EAAA;QACd,OAAOA,UAAW,CAAAI,iBAAA;MACpB;MACO,OAAA,EAAA;IACT;IACO,OAAA,EAAA;EAAA,CACR,CAAA;AACL,CAAA;AC1Da,MAAAC,UAAA,GAAoC,MAAO9B,OAA4B,IAAA;EAC9E,IAAA,EAACA,mCAASqB,OAAW,CAAA,IAAA,EAACrB,mCAASG,MAAU,CAAA,IAAA,EAACH,mCAASI,KAAO,CAAA,EAAA;IAC5D,OAAO,EAAC;EACV;EACM,MAAA;IAACiB,OAAS;IAAAjB;EAAS,CAAA,GAAAJ,OAAA;EACzB,MAAMC,mEAA4DoB,OAAA,CAAA;EAC5D,MAAAL,WAAA,GAAc,MAAMjB,YAAA,CAAaC,OAAO,CAAA;EAC9C,OAAOM,MAAMF,KAAO,EAAA;IAClBG,MAAQ,EAAA,KAAA;IACRL,OAAA,EAASe,UAAW,CAAAhB,GAAA,EAAKe,WAAW;EACrC,CAAA,CAAA,CACEL,IAAK,CAACC,OAAQA,GAAI,CAAAC,IAAA,EAAM,CAAA,CACxBF,KAAMC,GAAA,IAAQA,GAAI,CAAAE,QAAA,CAASC,KAAKgB,aAAa,CAAA;AAClD,CAAA;ACCa,MAAAC,kBAAA,GAAoD,MAAAA,CAC/DZ,UAAA,EACApB,OACG,KAAA;EACC,IAAA,EAACA,mCAASqB,OAAW,CAAA,IAAA,EAACrB,mCAASG,MAAU,CAAA,IAAA,EAACH,mCAASI,KAAO,CAAA,EAAA;IACrD,OAAA;MACLgB,UAAA;MACAa,MAAQ,EAAAb,UAAA;MACRc,SAAS;IAAC,CACZ;EACF;EAEM,MAAA;IAACb,OAAS;IAAAjB;EAAS,CAAA,GAAAJ,OAAA;EAEnB,MAAAgB,WAAA,GAAc,MAAMjB,YAAA,CAAaC,OAAO,CAAA;EAC9C,MAAMiC,MAAS,GAAA,MAAMd,eAAgB,CAAAC,UAAA,EAAYpB,SAASgB,WAAW,CAAA;EACrE,IAAI,CAACiB,MAAQ,EAAA;IACJ,OAAA;MACLb,UAAA;MACAa,MAAQ,EAAAb,UAAA;MACRc,SAAS;IAAC,CACZ;EACF;EAEM,MAAAC,WAAA,qDAAAb,MAAA,CAAgED,OAAgB,YAAAC,MAAA,CAAAW,MAAA,cAAA;EAChF,MAAAG,aAAA,GAAgB,MAAM9B,KAAA,CAAMF,KAAO,EAAA;IACvCG,MAAQ,EAAA,KAAA;IACRL,OAAA,EAASe,UAAW,CAAAkB,WAAA,EAAanB,WAAW;EAC7C,CAAA,CAAA,CACEL,IAAK,CAACC,OAAQA,GAAI,CAAAC,IAAA,EAAM,CAAA,CACxBF,IAAK,CAACC,GAAQ,IAAAA,GAAA,CAAIE,SAASC,IAAI,CAAA;EAElC,IAAImB,UAAU,EAAC;EACX,IAAAE,aAAA,IAAiBA,cAAcC,qBAAuB,EAAA;IACxDH,OAAA,GAAUE,aAAc,CAAAC,qBAAA,CAAsBC,GAAI,CAACX,IAAgC,IAAA;MApDvF,IAAAY,EAAA;MAqDM,IAAIC,QAAW,GAAAb,IAAA,CAAKa,QAAW,GAAAb,IAAA,CAAKa,SAASC,eAAkB,GAAA,CAAA;MAC/D,IACEd,KAAKe,0BACL,IAAAf,IAAA,CAAKe,2BAA2BlB,MAAS,GAAA,CAAA,IACzCG,KAAKa,QACL,EAAA;QAEM,MAAAG,YAAA,GAAehB,IAAK,CAAAe,0BAAA,CAA2B,CAAC,CAAA;QAEtD,IACEC,YAAa,CAAAC,iCAAA,IACbD,YAAa,CAAAC,iCAAA,CAAkCpB,SAAS,CACxD,EAAA;UAEA,MAAMqB,QAAW,GAAAF,YAAA,CAAaC,iCAAkC,CAAAE,EAAA,CAAG,CAAE,CAAA,CAAA;UAEjE,IAAAD,QAAA,IAAYA,QAAS,CAAAE,SAAA,IAAa,CAAG,EAAA;YAC5BP,QAAA,GAAA,CAAAD,EAAA,GAAAS,IAAA,CAAKC,MAAOJ,QAAS,CAAAE,SAAA,GAAYpB,KAAKa,QAAS,CAAAU,cAAA,GAAkB,GAAG,CAAA,KAApE,IAAyE,GAAAX,EAAA,GAAA,CAAA;UACtF;QACF;MACF;MACO,OAAA;QACLY,UAAUxB,IAAK,CAAAyB,cAAA;QACfZ;MAAA,CACF;IAAA,CACD,CAAA;EACH;EAEO,OAAA;IACLpB,UAAA;IACAc,OAAA;IAAA;IAEAD,MAAQ,EAAAb,UAAA;IACRiC,gBAAA,kDAAA/B,MAAA,CAAkED,OAAA,oBAAAC,MAAA,CAAwBD,OAAW,OAAAC,MAAA,CAAAW,MAAA;EAAA,CACvG;AACF,CAAA;ACnFA,MAAMqB,SAAY,GAAAA,CAAC1B,OAAiB,EAAA5B,OAAA,EAAkBuD,WAAqBvC,WAAwB,KAAA;EAC3F,MAAA;IAACK,OAAS;IAAAjB;EAAS,CAAA,GAAAJ,OAAA;EACrB,IAAA,CAACqB,OAAW,IAAA,CAACjB,KAAO,EAAA;IACtB,MAAM,IAAIC,KAAA,CACR,kKAAA,CACF;EACF;EAEA,MAAMJ,+DAAwDoB,OAAA,UAAA;EAC9D,OAAOf,MAAMF,KAAO,EAAA;IAClBG,MAAQ,EAAA,MAAA;IACRL,OAAS,EAAA;MACP,GAAGe,UAAW,CAAAhB,GAAA,EAAKe,WAAW,CAAA;MAC9B,cAAgB,EAAA;IAClB,CAAA;IACAR,IAAA,EAAMC,KAAKC,SAAU,CAAA;MACnBkB,OAAA;MACA4B,eAAiB,EAAAD;IAAA,CAClB;EACF,CAAA,CAAA,CACE5C,IAAK,CAACC,OAAQA,GAAI,CAAAC,IAAA,EAAM,CAAA,CACxBF,KAAMC,GAAA,IAAQA,GAAI,CAAAE,QAAA,CAASC,KAAKc,iBAAiB,CAAA;AACtD,CAAA;AAQA,MAAM4B,iBAAiBA,CACrBC,KAAA,EACA1D,SACA2D,YACA,EAAA3C,WAAA,EACAuC,WACAK,WAEG,KAAA;EACG,MAAA;IAACvC,OAAS;IAAAjB;EAAS,CAAA,GAAAJ,OAAA;EACrB,IAAA,CAACqB,OAAW,IAAA,CAACjB,KAAO,EAAA;IACtB,MAAM,IAAIC,KAAA,CACR,kKAAA,CACF;EACF;EACA,MAAMJ,sEAA+DoB,OAAA,aAAA;EACrE,MAAMwC,OAKF,GAAA;IACFC,SAAW,EAAA,IAAA;IACXjC,iBAAmB,EAAA6B,KAAA;IACnBK,QAAA,EAAU,CAACJ,YAAY;EAAA,CACzB;EAEA,IAAIC,WAAa,EAAA;IACfC,OAAA,CAAQG,eAAkB,GAAAT,SAAA,CAAUjB,GAAI,CAAC2B,CAAO,KAAA;MAC9Cb,cAAgB,EAAAa,CAAA;MAChBL;IACA,CAAA,CAAA,CAAA;EACJ;EAEA,OAAOtD,MAAMF,KAAO,EAAA;IAClBG,MAAQ,EAAA,MAAA;IACRL,OAAS,EAAA;MACP,GAAGe,UAAW,CAAAhB,GAAA,EAAKe,WAAW,CAAA;MAC9B,cAAgB,EAAA;IAClB,CAAA;IACAR,IAAA,EAAMC,IAAK,CAAAC,SAAA,CAAUmD,OAAO;EAC7B,CAAA,CAAA,CACElD,IAAK,CAACC,OAAQA,GAAI,CAAAC,IAAA,EAAM,CAAA,CACxBF,KAAMC,GAAA,IAAQA,GAAI,CAAAE,QAAA,CAASC,KAAKmD,QAAQ,CAAA;AAC7C,CAAA;AAEA,MAAMC,oBAAoBA,CACxBD,QAAA,EACAE,QACA,EAAApE,OAAA,EACAuD,WACAvC,WACG,KAAA;EACG,MAAA;IAACK,OAAS;IAAAjB;EAAS,CAAA,GAAAJ,OAAA;EACrB,IAAA,CAACqB,OAAW,IAAA,CAACjB,KAAO,EAAA;IACtB,MAAM,IAAIC,KAAA,CACR,kKAAA,CACF;EACF;EACM,MAAAJ,GAAA,4DAAAqB,MAAA,CAA+DD,OAAmB,eAAAC,MAAA,CAAA4C,QAAA,UAAA;EAClF,MAAAG,QAAA,GAAW,IAAIC,QAAS,EAAA;EACrBD,QAAA,CAAAE,MAAA,CAAO,SAAW,EAAAH,QAAA,CAASI,IAAI,CAAA;EAC/BH,QAAA,CAAAE,MAAA,CAAO,YAAY,MAAM,CAAA;EAClC,MAAME,UAAa,GAAAC,MAAAA,CAAAA,MAAA,CAAOC,IAAK,CAAAP,QAAA,CAASQ,SAAS,OAAO,CAAA;EAC/CP,QAAA,CAAAE,MAAA,CAAO,MAAQ,EAAA,IAAIM,IAAK,CAAA,CAACJ,UAAU,CAAC,CAAA,KAAAnD,MAAA,CAAM8C,QAAA,CAASI,IAAW,WAAA;EACvEjB,SAAA,CAAUuB,QAAS3B,QAAA,IAAakB,SAASE,MAAO,CAAA,wBAAA,EAA0BpB,QAAQ,CAAC,CAAA;EAEnF,OAAO7C,MAAMF,KAAO,EAAA;IAClBG,MAAQ,EAAA,MAAA;IACRL,OAAA,EAASe,UAAW,CAAAhB,GAAA,EAAKe,WAAW,CAAA;IACpCR,IAAM,EAAA6D;EAAA,CACP,CAAE,CAAA1D,IAAA,CAAMC,GAAQ,IAAAA,GAAA,CAAIC,MAAM,CAAA;AAC7B,CAAA;AAEO,MAAMkE,aAAoC,MAAAA,CAC/C3D,UAAA,EACAgD,QACA,EAAAb,SAAA,EACAvD,SACA4D,WACG,KAAA;EACC,IAAA,EAAC5D,mCAASqB,OAAW,CAAA,IAAA,EAACrB,mCAASG,MAAU,CAAA,IAAA,EAACH,mCAASI,KAAO,CAAA,EAAA;IAC5D,MAAM,IAAIC,KAAA,CACR,+JAAA,CACF;EACF;EAEM,MAAAW,WAAA,GAAc,MAAMjB,YAAA,CAAaC,OAAO,CAAA;EAE9C,IAAIiC,SAAS,MAAMd,eAAA,CAAgBiD,QAAS,CAAAI,IAAA,EAAMxE,SAASgB,WAAW,CAAA;EACtE,IAAI,CAACiB,MAAQ,EAAA;IACXA,MAAA,GAAS,MAAMqB,SAAU,CAAAc,QAAA,CAASI,IAAM,EAAAxE,OAAA,EAASuD,WAAWvC,WAAW,CAAA;EACzE;EAEA,MAAMkD,WAAW,MAAMT,cAAA,CACrBxB,MAAA,EACAjC,OAAA,EACAoE,QAAS,CAAAI,IAAA,EACTxD,WAAA,EACAuC,SAAA,EACAK,WAAA,CACF;EACA,MAAMoB,gBAAgB,MAAMb,iBAAA,CAAkBD,UAAUE,QAAU,EAAApE,OAAA,EAASuD,WAAWvC,WAAW,CAAA;EAEzFiE,OAAA,CAAAC,IAAA,CAAK,kCAAkCF,aAAa,CAAA;EAErD,OAAAhD,kBAAA,CAAmBZ,YAAYpB,OAAO,CAAA;AAC/C,CAAA;AC3IO,MAAMmF,cAA4C,GAAA,MAAAA,CACvDlD,MACA,EAAAkB,QAAA,EACAnD,OACG,KAAA;EACC,IAAA,EAACA,mCAASqB,OAAW,CAAA,IAAA,EAACrB,mCAASG,MAAU,CAAA,IAAA,EAACH,mCAASI,KAAO,CAAA,EAAA;IAC5D,MAAM,IAAIC,KAAA,CACR,+JAAA,CACF;EACF;EAEM,MAAA;IAACgB,OAAS;IAAAjB;EAAS,CAAA,GAAAJ,OAAA;EAEnB,MAAAC,GAAA,sDAAAqB,MAAA,CAAyDD,OAAA,eAAAC,MAAA,CAAmB6B,QAAyB,oBAAA7B,MAAA,CAAAW,MAAA,2BAAA;EACrG,MAAAjB,WAAA,GAAc,MAAMjB,YAAA,CAAaC,OAAO,CAAA;EACxC,MAAAoF,cAAA,GAAiB,MAAM9E,KAAA,CAAMF,KAAO,EAAA;IACxCG,MAAQ,EAAA,KAAA;IACRL,OAAA,EAASe,UAAW,CAAAhB,GAAA,EAAKe,WAAW;EAAA,CACrC,CACE,CAAAL,IAAA,CAAMC,GAAA,IAAQA,GAAI,CAAAC,IAAA,EAAM,CAAA,CACxBF,IAAK,CAACC,GAAQ,IAAA;IAvBnB,IAAA2B,EAAA;IAwBM,IAAI3B,IAAIJ,IAAM,EAAA;MACZ,OAAOI,GAAI,CAAAJ,IAAA;IAAA,CACb,MAAA,IAAWI,GAAI,CAAAE,QAAA,CAASuE,MAAQ,EAAA;MAC9B,MAAMC,WACJ/C,EAAI,GAAA3B,GAAA,CAAAE,QAAA,CAASuE,OAAO,CAAC,CAAA,KAArB,mBAAwBE,OAAW,KAAA,6CAAA;MAC/B,MAAA,IAAIlF,MAAMiF,MAAM,CAAA;IACxB;IACO,OAAA,EAAA;EAAA,CACR,CAAA;EAEI,OAAAF,cAAA;AACT,CAAA;AC7BO,MAAMI,gBAA4B,GAAA;EACvC1D,UAAA;EACAE,kBAAA;EACA+C,UAAA;EACAI;AACF,CAAA;ACqBA,MAAMM,0BAA4C,GAAA;EAChD,GAAGC,qBAAA,CAAAA,uBAAA;EACHC,OAAS,EAAAH;AACX,CAAA;AAEA,MAAMI,uBAAyC,GAAA;EAC7C,GAAGC,qBAAA,CAAAA,oBAAA;EACHF,OAAS,EAAAH;AACX,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/adapter/helpers.ts","../src/adapter/getLocales.ts","../src/adapter/getTranslationTask.ts","../src/adapter/createTask.ts","../src/adapter/getTranslation.ts","../src/adapter/index.ts","../src/index.ts"],"sourcesContent":["import {Secrets} from 'sanity-translations-tab'\n\ninterface Headers {\n [key: string]: string\n}\n\nexport const authenticate = (secrets: Secrets): Promise<string> => {\n const url = 'https://api.smartling.com/auth-api/v2/authenticate'\n const headers = {\n 'content-type': 'application/json',\n 'X-URL': url,\n }\n const {secret, proxy} = secrets\n if (!secret || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a secret key and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n return fetch(proxy, {\n headers,\n method: 'POST',\n body: JSON.stringify(secret),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.accessToken)\n}\n\nexport const getHeaders = (url: string, accessToken: string): Headers => ({\n Authorization: `Bearer ${accessToken}`,\n 'X-URL': url,\n})\n\nexport const findExistingJob = (\n documentId: string,\n secrets: Secrets,\n accessToken: string\n): Promise<string> => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs?jobName=${documentId}`\n return fetch(proxy, {\n method: 'POST',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => {\n if (res.response.data.items.length) {\n //smartling will fuzzy match job names. We need to be precise.\n const correctJob = res.response.data.items.find(\n (item: {jobName: string}) => item.jobName && item.jobName === documentId\n )\n if (correctJob) {\n return correctJob.translationJobUid\n }\n return ''\n }\n return ''\n })\n}\n","import {authenticate, getHeaders} from './helpers'\nimport {Secrets} from 'sanity-translations-tab'\nimport {Adapter} from 'sanity-translations-tab'\n\nexport const getLocales: Adapter['getLocales'] = async (secrets: Secrets | null) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n return []\n }\n const {project, proxy} = secrets\n const url = `https://api.smartling.com/projects-api/v2/projects/${project}`\n const accessToken = await authenticate(secrets)\n return fetch(proxy, {\n method: 'GET',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.targetLocales)\n}\n","import {authenticate, getHeaders, findExistingJob} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\n\ninterface WorkflowProgressItem {\n workflowStepSummaryReportItemList: {\n wordCount: number\n }[]\n}\n\ninterface SmartlingProgressItem {\n targetLocaleId: string\n progress: {\n percentComplete: number\n totalWordCount: number\n }\n workflowProgressReportList: WorkflowProgressItem[]\n}\n\nexport const getTranslationTask: Adapter['getTranslationTask'] = async (\n documentId: string,\n secrets: Secrets | null\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n return {\n documentId,\n taskId: documentId,\n locales: [],\n }\n }\n\n const {project, proxy} = secrets\n\n const accessToken = await authenticate(secrets)\n const taskId = await findExistingJob(documentId, secrets, accessToken)\n if (!taskId) {\n return {\n documentId,\n taskId: documentId,\n locales: [],\n }\n }\n\n const progressUrl = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs/${taskId}/progress`\n const smartlingTask = await fetch(proxy, {\n method: 'GET',\n headers: getHeaders(progressUrl, accessToken),\n })\n .then((res) => res.json())\n .then((res) => res.response.data)\n\n let locales = []\n if (smartlingTask && smartlingTask.contentProgressReport) {\n locales = smartlingTask.contentProgressReport.map((item: SmartlingProgressItem) => {\n let progress = item.progress ? item.progress.percentComplete : 0\n if (\n item.workflowProgressReportList &&\n item.workflowProgressReportList.length > 0 &&\n item.progress\n ) {\n //default to the first workflow -- it's likely what is being used\n const progressItem = item.workflowProgressReportList[0]\n //this is a list of the various steps in the workflow\n if (\n progressItem.workflowStepSummaryReportItemList &&\n progressItem.workflowStepSummaryReportItemList.length > 1\n ) {\n //get the last step in the workflow -- usually \"published\"\n const lastStep = progressItem.workflowStepSummaryReportItemList.at(-1)\n //get the percentage of how many words have reached the last step\n if (lastStep && lastStep.wordCount >= 0) {\n progress = Math.floor((lastStep.wordCount / item.progress.totalWordCount) * 100) ?? 0\n }\n }\n }\n return {\n localeId: item.targetLocaleId,\n progress,\n }\n })\n }\n\n return {\n documentId,\n locales,\n //since our download is tied to document id for smartling, keep track of it as a task\n taskId: documentId,\n linkToVendorTask: `https://dashboard.smartling.com/app/projects/${project}/account-jobs/${project}:${taskId}`,\n }\n}\n","import {authenticate, getHeaders, findExistingJob} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\nimport {getTranslationTask} from './getTranslationTask'\nimport {Buffer} from 'buffer'\n\nconst createJob = (jobName: string, secrets: Secrets, localeIds: string[], accessToken: string) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const url = `https://api.smartling.com/jobs-api/v3/projects/${project}/jobs`\n return fetch(proxy, {\n method: 'POST',\n headers: {\n ...getHeaders(url, accessToken),\n 'content-type': 'application/json',\n },\n body: JSON.stringify({\n jobName,\n targetLocaleIds: localeIds,\n }),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.translationJobUid)\n}\n\n/* we're using batches here because it eliminates some\n * new string authorization issues for updating existing jobs,\n * and is able to be used for new bulk\n * job functionality.\n */\n\nconst createJobBatch = (\n jobId: string,\n secrets: Secrets,\n documentName: string,\n accessToken: string,\n localeIds: string[],\n workflowUid?: string\n //eslint-disable-next-line max-params\n) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/job-batches-api/v2/projects/${project}/batches`\n const reqBody: {\n authorize: boolean\n translationJobUid: string\n fileUris: string[]\n localeWorkflows?: {targetLocaleId: string; workflowUid: string}[]\n } = {\n authorize: true,\n translationJobUid: jobId,\n fileUris: [documentName],\n }\n\n if (workflowUid) {\n reqBody.localeWorkflows = localeIds.map((l) => ({\n targetLocaleId: l,\n workflowUid,\n }))\n }\n\n return fetch(proxy, {\n method: 'POST',\n headers: {\n ...getHeaders(url, accessToken),\n 'content-type': 'application/json',\n },\n body: JSON.stringify(reqBody),\n })\n .then((res) => res.json())\n .then((res) => res.response.data.batchUid)\n}\n\nconst uploadFileToBatch = (\n batchUid: string,\n document: Record<string, any>,\n secrets: Secrets,\n localeIds: string[],\n accessToken: string\n) => {\n const {project, proxy} = secrets\n if (!project || !proxy) {\n throw new Error(\n 'The Smartling adapter requires a Smartling project identifier and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n const url = `https://api.smartling.com/job-batches-api/v2/projects/${project}/batches/${batchUid}/file`\n const formData = new FormData()\n formData.append('fileUri', document.name)\n formData.append('fileType', 'html')\n const htmlBuffer = Buffer.from(document.content, 'utf-8')\n formData.append('file', new Blob([htmlBuffer]), `${document.name}.html`)\n localeIds.forEach((localeId) => formData.append('localeIdsToAuthorize[]', localeId))\n\n return fetch(proxy, {\n method: 'POST',\n headers: getHeaders(url, accessToken),\n body: formData,\n }).then((res) => res.json())\n}\n\nexport const createTask: Adapter['createTask'] = async (\n documentId: string,\n document: Record<string, any>,\n localeIds: string[],\n secrets: Secrets | null,\n workflowUid?: string\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n throw new Error(\n 'The Smartling adapter requires a project ID, a secret key, and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const accessToken = await authenticate(secrets)\n\n let taskId = await findExistingJob(document.name, secrets, accessToken)\n if (!taskId) {\n taskId = await createJob(document.name, secrets, localeIds, accessToken)\n }\n\n const batchUid = await createJobBatch(\n taskId,\n secrets,\n document.name,\n accessToken,\n localeIds,\n workflowUid\n )\n const uploadFileRes = await uploadFileToBatch(batchUid, document, secrets, localeIds, accessToken)\n //eslint-disable-next-line no-console -- for developer debugging\n console.info('Upload status from Smartling: ', uploadFileRes)\n\n return getTranslationTask(documentId, secrets)\n}\n","import {authenticate, getHeaders} from './helpers'\nimport {Adapter, Secrets} from 'sanity-translations-tab'\n\nexport const getTranslation: Adapter['getTranslation'] = async (\n taskId: string,\n localeId: string,\n secrets: Secrets | null\n) => {\n if (!secrets?.project || !secrets?.secret || !secrets?.proxy) {\n throw new Error(\n 'The Smartling adapter requires a project ID, a secret key, and a proxy URL. Please check your secrets document in this dataset, per the plugin documentation.'\n )\n }\n\n const {project, proxy} = secrets\n\n const url = `https://api.smartling.com/files-api/v2/projects/${project}/locales/${localeId}/file?fileUri=${taskId}&retrievalType=pending`\n const accessToken = await authenticate(secrets)\n const translatedHTML = await fetch(proxy, {\n method: 'GET',\n headers: getHeaders(url, accessToken),\n })\n .then((res) => res.json())\n .then((res) => {\n if (res.body) {\n return res.body\n } else if (res.response.errors) {\n const errMsg =\n res.response.errors[0]?.message || 'Error retrieving translation from Smartling'\n throw new Error(errMsg)\n }\n return ''\n })\n\n return translatedHTML\n}\n","import {Adapter} from 'sanity-translations-tab'\nimport {getLocales} from './getLocales'\nimport {getTranslationTask} from './getTranslationTask'\nimport {createTask} from './createTask'\nimport {getTranslation} from './getTranslation'\n\nexport const SmartlingAdapter: Adapter = {\n getLocales,\n getTranslationTask,\n createTask,\n getTranslation,\n}\n","import {SerializedDocument} from 'sanity-naive-html-serializer'\nimport {\n TranslationsTab,\n baseDocumentLevelConfig,\n legacyDocumentLevelConfig as baseLegacyDocumentLevelConfig,\n baseFieldLevelConfig,\n findLatestDraft,\n BaseDocumentDeserializer,\n BaseDocumentSerializer,\n BaseDocumentMerger,\n defaultStopTypes,\n customSerializers,\n Adapter,\n legacyDocumentLevelPatch,\n documentLevelPatch,\n fieldLevelPatch,\n TranslationFunctionContext,\n} from 'sanity-translations-tab'\nimport {SmartlingAdapter} from './adapter'\n\ninterface ConfigOptions {\n adapter: Adapter\n secretsNamespace: string | null\n exportForTranslation: (\n id: string,\n context: TranslationFunctionContext\n ) => Promise<SerializedDocument>\n importTranslation: (\n id: string,\n localeId: string,\n doc: string,\n context: TranslationFunctionContext\n ) => Promise<void>\n}\nconst defaultDocumentLevelConfig: ConfigOptions = {\n ...baseDocumentLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nconst legacyDocumentLevelConfig: ConfigOptions = {\n ...baseLegacyDocumentLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nconst defaultFieldLevelConfig: ConfigOptions = {\n ...baseFieldLevelConfig,\n adapter: SmartlingAdapter,\n}\n\nexport {\n TranslationsTab,\n findLatestDraft,\n legacyDocumentLevelPatch,\n documentLevelPatch,\n fieldLevelPatch,\n BaseDocumentDeserializer,\n BaseDocumentSerializer,\n BaseDocumentMerger,\n defaultStopTypes,\n customSerializers,\n SmartlingAdapter,\n legacyDocumentLevelConfig,\n defaultDocumentLevelConfig,\n defaultFieldLevelConfig,\n}\n"],"names":["authenticate","secrets","url","headers","secret","proxy","Error","fetch","method","body","JSON","stringify","then","res","json","response","data","accessToken","getHeaders","Authorization","findExistingJob","documentId","project","concat","items","length","correctJob","find","item","jobName","translationJobUid","getLocales","targetLocales","getTranslationTask","taskId","locales","progressUrl","smartlingTask","contentProgressReport","map","_a","progress","percentComplete","workflowProgressReportList","progressItem","workflowStepSummaryReportItemList","lastStep","at","wordCount","Math","floor","totalWordCount","localeId","targetLocaleId","linkToVendorTask","createJob","localeIds","targetLocaleIds","createJobBatch","jobId","documentName","workflowUid","reqBody","authorize","fileUris","localeWorkflows","l","batchUid","uploadFileToBatch","document","formData","FormData","append","name","htmlBuffer","Buffer","from","content","Blob","forEach","createTask","uploadFileRes","console","info","getTranslation","translatedHTML","errors","errMsg","message","SmartlingAdapter","defaultDocumentLevelConfig","baseDocumentLevelConfig","adapter","legacyDocumentLevelConfig","baseLegacyDocumentLevelConfig","defaultFieldLevelConfig","baseFieldLevelConfig"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/index.ts
CHANGED
|
@@ -2,6 +2,7 @@ import {SerializedDocument} from 'sanity-naive-html-serializer'
|
|
|
2
2
|
import {
|
|
3
3
|
TranslationsTab,
|
|
4
4
|
baseDocumentLevelConfig,
|
|
5
|
+
legacyDocumentLevelConfig as baseLegacyDocumentLevelConfig,
|
|
5
6
|
baseFieldLevelConfig,
|
|
6
7
|
findLatestDraft,
|
|
7
8
|
BaseDocumentDeserializer,
|
|
@@ -10,6 +11,7 @@ import {
|
|
|
10
11
|
defaultStopTypes,
|
|
11
12
|
customSerializers,
|
|
12
13
|
Adapter,
|
|
14
|
+
legacyDocumentLevelPatch,
|
|
13
15
|
documentLevelPatch,
|
|
14
16
|
fieldLevelPatch,
|
|
15
17
|
TranslationFunctionContext,
|
|
@@ -35,6 +37,11 @@ const defaultDocumentLevelConfig: ConfigOptions = {
|
|
|
35
37
|
adapter: SmartlingAdapter,
|
|
36
38
|
}
|
|
37
39
|
|
|
40
|
+
const legacyDocumentLevelConfig: ConfigOptions = {
|
|
41
|
+
...baseLegacyDocumentLevelConfig,
|
|
42
|
+
adapter: SmartlingAdapter,
|
|
43
|
+
}
|
|
44
|
+
|
|
38
45
|
const defaultFieldLevelConfig: ConfigOptions = {
|
|
39
46
|
...baseFieldLevelConfig,
|
|
40
47
|
adapter: SmartlingAdapter,
|
|
@@ -43,6 +50,7 @@ const defaultFieldLevelConfig: ConfigOptions = {
|
|
|
43
50
|
export {
|
|
44
51
|
TranslationsTab,
|
|
45
52
|
findLatestDraft,
|
|
53
|
+
legacyDocumentLevelPatch,
|
|
46
54
|
documentLevelPatch,
|
|
47
55
|
fieldLevelPatch,
|
|
48
56
|
BaseDocumentDeserializer,
|
|
@@ -51,6 +59,7 @@ export {
|
|
|
51
59
|
defaultStopTypes,
|
|
52
60
|
customSerializers,
|
|
53
61
|
SmartlingAdapter,
|
|
62
|
+
legacyDocumentLevelConfig,
|
|
54
63
|
defaultDocumentLevelConfig,
|
|
55
64
|
defaultFieldLevelConfig,
|
|
56
65
|
}
|