sanity-plugin-motionpoint
v2.14.0
Published
This plugin provides an in-studio integration with MotionPoint. It allows your editors to send any document to MotionPoint with the click of a button, monitor ongoing translations, and import partial or complete translations back into the studio.
Downloads
2
Readme
This is a Sanity Studio v3 plugin.
Package Installation
npm install sanity-plugin-motionpoint
This plugin integrates your Sanity Studio with MotionPoint and facilitates seamless translation management by enabling you to dispatch content for translation, oversee the progress, and effortlessly retrieve the finalized translations upon completion.
Table of Contents
Quickstart
MotionPoint’s Connector Requirements
The MotionPoint connector requires the following:
- A MotionPoint username
- An API ID and an API access token
Both can be requested by contacting MotionPoint here or [email protected]. Someone from our team will contact you about your inquiry within one business day.
Installation Instructions
- Navigate to your Sanity Studio folder and run the following command:
npm install sanity-plugin-motionpoint
- Ensure the plugin has access to your MotionPoint secrets. You'll want to create a document that includes your project name, organization name, and a token with appropriate access.
Please refer to the MotionPoint documentation on creating a token if you don't have one already.
In your Studio folder, create a file called populateMotionPointSecrets.js
with the following contents:
// ./populateMotionPointSecrets.js
// Do not commit this file to your repository
import {getCliClient} from 'sanity/cli'
const client = getCliClient({apiVersion: '2023-02-15'})
client.createOrReplace({
// The `.` in this _id will ensure the document is private
// even in a public dataset!
_id: 'motionPoint.secrets',
_type: 'motionPointSettings',
// Replace these with your values
project_id: 'YOUR_MOTIONPOINT_PROJECT_ID_HERE',
base_language: 'YOUR_MOTIONPOINT_ORIGIN_LANGUAGE_HERE',
username: 'YOUR_MOTIONPOINT_USERNAME_HERE',
api_token: 'YOUR_MOTIONPOINT_TOKEN_HERE'
})
On the command line, run the file:
npx sanity exec populateMotionPointSecrets.js --with-user-token
Verify that the document was created using the Vision Tool in the Studio and query *[_id == 'motionPoint.secrets']
. Note: If you have multiple datasets, you'll have to do this across all of them.
If the document was found in your dataset(s), delete populateMotionPointSecrets.js
.
If you have concerns about this being exposed to authenticated users of your studio, you can control access to this path with role-based access control.
- Get the MotionPoint tab on your desired document type, using whatever pattern you like. You'll use the desk structure for this. The options for translation will be nested under this desired document type's views. Here's an example:
import {DefaultDocumentNodeResolver} from 'sanity/desk'
//...your other desk structure imports...
import {TranslationsTab, defaultDocumentLevelConfig} from 'sanity-plugin-motionpoint'
export const getDefaultDocumentNode: DefaultDocumentNodeResolver = (S, {schemaType}) => {
if (schemaType === 'myTranslatableDocumentType') {
return S.document().views([
S.view.form(),
//...my other views -- for example, live preview, the i18n plugin, etc.,
S.view.component(TranslationsTab).title('MotionPoint').options(defaultDocumentLevelConfig)
])
}
return S.document()
}
And that should do it! Go into your studio, click around, and check the document in MotionPoint (it should be under its Sanity _id
). Once it's translated, check the import by clicking the Import
button on your MotionPoint tab!
Assumptions
To use the default config mentioned above, we assume that you are following the conventions we outline in our documentation on localization.
Document level translations
Since we often find users want to use the Document internationalization plugin if they're using document-level translations, we assume that any documents you want in different languages will follow the pattern {id-of-base-language-document}__i18n_{locale}
Final note
It's okay if your data doesn't follow these patterns and you don't want to change them! You will simply have to override how the plugin gets and patches back information from your documents. Please see Overriding defaults.
Studio experience
By adding the TranslationsTab
to your desk structure, your users should now have an additional view. The boxes at the top of the tab can be used to send translations off to MotionPoint, and once those jobs are started, they should see progress bars monitoring the progress of the jobs. They can import a partial or complete job back.
Overriding defaults
To personalize this configuration it's useful to know what arguments go into TranslationsTab
as options (the defaultConfigs
are just wrappers for these):
exportForTranslation
: a function that takes your document id and returns an object withname
: the field you want to use identify your doc in MotionPoint (by default this is_id
andcontent
: a serialized HTML string of all the fields in your document to be translated.importTranslation
: a function that takes inid
(your document id)localeId
(the locale of the imported language) anddocument
the translated HTML from MotionPoint. It will deserialize your document back into an object that can be patched into your Sanity data, and then executes that patch.Adapter
: An interface with methods to send things over to MotionPoint. You likely don't want to override this!
There are several reasons to override these functions. More general cases are often around ensuring documents serialize and deserialize correctly. Since the serialization functions are used across all our translation plugins currently, you can find some frequently encountered scenarios at their repository here, along with code examples for new config.
Migrating to Sanity Studio v3
You should not have to do anything to migrate to Sanity Studio v3. If you are using the default configs, you should be able to upgrade without any changes. If you are using custom serialization, you may need to update how BaseDocumentSerializer
receives your schema.
These are outlined in the serializer README here.
License
MIT © Sanity.io
Develop & test
This plugin uses @sanity/plugin-kit with default configuration for build & watch scripts.
See Testing a plugin in Sanity Studio on how to run this plugin with hotreload in the studio.