UG9wcGluczo1MDA=
.tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="14499ecc53c422806d7eb82c92cc7061"] { border-radius: 20px;background:linear-gradient(rgba( 232, 222, 245, 0.02 ),rgba( 232, 222, 245, 0.02 )),  rgba( 255, 255, 255, 0 ) url('https://ptc.wpml.org/wp-content/uploads/2024/02/Hero-bg-min.png') center top no-repeat;background-size:auto, cover;padding: 0px;margin-top: 48px;margin-bottom: 48px; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="59903908a90e1dabe8352d6dab2d4b8c"] { border-top-left-radius: 20px;border-top-right-radius: 20px;background: url('https://ptc.wpml.org/wp-content/uploads/2024/02/Border-min.png') center bottom no-repeat;background-size:contain;padding: 0px;min-height: 2px;display:ms-flexbox !important;display:flex !important;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="15406ceb75f588e0c27cafacc3eecdf8"] { padding: 48px; } .tb-button{color:#f1f1f1}.tb-button--left{text-align:left}.tb-button--center{text-align:center}.tb-button--right{text-align:right}.tb-button__link{color:inherit;cursor:pointer;display:inline-block;line-height:100%;text-decoration:none !important;text-align:center;transition:all 0.3s ease}.tb-button__link:hover,.tb-button__link:focus,.tb-button__link:visited{color:inherit}.tb-button__link:hover .tb-button__content,.tb-button__link:focus .tb-button__content,.tb-button__link:visited .tb-button__content{font-family:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-shadow:inherit;text-transform:inherit}.tb-button__content{vertical-align:middle;transition:all 0.3s ease}.tb-button__icon{transition:all 0.3s ease;display:inline-block;vertical-align:middle;font-style:normal !important}.tb-button__icon::before{content:attr(data-font-code);font-weight:normal !important}.tb-button__link{background-color:#444;border-radius:0.3em;font-size:1.3em;margin-bottom:0.76em;padding:0.55em 1.5em 0.55em} .tb-button[data-toolset-blocks-button="2d0bf2f3525530cde5d75af09d3c23a1"] .tb-button__link { background-color: rgba( 212, 180, 253, 1 );border-radius: 10px;color: rgba( 22, 26, 27, 1 );padding: 16px 32px 16px 32px;margin-bottom: 0px;font-size: 16px;line-height: 24px;font-family: Poppins;font-weight: 500;color: rgba( 22, 26, 27, 1 ); } .tb-button[data-toolset-blocks-button="2d0bf2f3525530cde5d75af09d3c23a1"] .tb-button__link:hover { background-color: rgba( 255, 255, 255, 1 ); } .tb-button[data-toolset-blocks-button="2d0bf2f3525530cde5d75af09d3c23a1"] .tb-button__icon { font-family: dashicons; } .tb-heading[data-toolset-blocks-heading="ac07fc5744b99dd249e504170156018c"]  { font-size: 17px;line-height: 30px;color: rgba( 201, 223, 232, 1 );padding-top: 0px;padding-bottom: 0px;margin-top: 24px;margin-bottom: 24px; }  h3.tb-heading[data-toolset-blocks-heading="1c396cc94e18e00c865d013d82261e7f"]  { color: rgba( 255, 255, 255, 1 );margin-top: 0px;margin-bottom: 16px; }  .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="f1c525482d64a022a84c8549df0e71e7"] { border-top-left-radius: 20px;border-top-right-radius: 20px;background: url('https://ptc.wpml.org/wp-content/uploads/2024/02/Border-min.png') center top no-repeat;background-size:contain;padding: 0px;min-height: 2px;display:ms-flexbox !important;display:flex !important;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="9c9db18c812f55e8beacaa272456187c"] { padding: 32px 32px 20px 32px;margin-top: 0px;margin-bottom: 0px; } .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="fb27c2050bcce564418b7b8e928ae52a"] { background: url('https://ptc.wpml.org/wp-content/uploads/2025/03/No-1.png') center center no-repeat;background-size: 28px 28px;min-height: 28px; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="79f69b57db0add18f492fb70d303ae09"] { border-radius: 20px;padding: 32px 32px 20px 32px;margin-top: 0px;margin-bottom: 0px;border: 1px solid rgba( 212, 180, 253, 1 ); } .tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] { margin-bottom: 24px;grid-template-columns: minmax(0, 0.045fr) minmax(0, 0.955fr);grid-column-gap: 12px;grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 } .tb-heading[data-toolset-blocks-heading="69fe9c2eddbf42fac6cd0e3f8dca26d2"]  { font-size: 18px;line-height: 1.6em;padding-top: 0px;padding-bottom: 0px;margin-top: 0px;margin-bottom: 0px; }  .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="3af0069a8da5c275d704ed6fbf9c2df5"] { background: url('https://ptc.wpml.org/wp-content/uploads/2025/03/Yes.png') center center no-repeat;background-size: 28px 28px;min-height: 28px; } .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="3034fbe886c11054e95b46b09d3e4112"] { display: flex; } @media only screen and (max-width: 781px) { .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-button{color:#f1f1f1}.tb-button--left{text-align:left}.tb-button--center{text-align:center}.tb-button--right{text-align:right}.tb-button__link{color:inherit;cursor:pointer;display:inline-block;line-height:100%;text-decoration:none !important;text-align:center;transition:all 0.3s ease}.tb-button__link:hover,.tb-button__link:focus,.tb-button__link:visited{color:inherit}.tb-button__link:hover .tb-button__content,.tb-button__link:focus .tb-button__content,.tb-button__link:visited .tb-button__content{font-family:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-shadow:inherit;text-transform:inherit}.tb-button__content{vertical-align:middle;transition:all 0.3s ease}.tb-button__icon{transition:all 0.3s ease;display:inline-block;vertical-align:middle;font-style:normal !important}.tb-button__icon::before{content:attr(data-font-code);font-weight:normal !important}.tb-button__link{background-color:#444;border-radius:0.3em;font-size:1.3em;margin-bottom:0.76em;padding:0.55em 1.5em 0.55em}  .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] { grid-template-columns: minmax(0, 0.05fr) minmax(0, 0.95fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 }  .tb-container .tb-container-inner{width:100%;margin:0 auto}.wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="3034fbe886c11054e95b46b09d3e4112"] { display: flex; }  } @media only screen and (max-width: 599px) { .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="15406ceb75f588e0c27cafacc3eecdf8"] { padding: 40px 25px 40px 25px; } .tb-button{color:#f1f1f1}.tb-button--left{text-align:left}.tb-button--center{text-align:center}.tb-button--right{text-align:right}.tb-button__link{color:inherit;cursor:pointer;display:inline-block;line-height:100%;text-decoration:none !important;text-align:center;transition:all 0.3s ease}.tb-button__link:hover,.tb-button__link:focus,.tb-button__link:visited{color:inherit}.tb-button__link:hover .tb-button__content,.tb-button__link:focus .tb-button__content,.tb-button__link:visited .tb-button__content{font-family:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-shadow:inherit;text-transform:inherit}.tb-button__content{vertical-align:middle;transition:all 0.3s ease}.tb-button__icon{transition:all 0.3s ease;display:inline-block;vertical-align:middle;font-style:normal !important}.tb-button__icon::before{content:attr(data-font-code);font-weight:normal !important}.tb-button__link{background-color:#444;border-radius:0.3em;font-size:1.3em;margin-bottom:0.76em;padding:0.55em 1.5em 0.55em} h3.tb-heading[data-toolset-blocks-heading="1c396cc94e18e00c865d013d82261e7f"]  { font-size: 20px; }  .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="9c9db18c812f55e8beacaa272456187c"] { padding: 0px; } .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="79f69b57db0add18f492fb70d303ae09"] { border-radius: 0;padding: 0px;border: 0px solid rgba( 0, 0, 0, 1 ); } .tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] { grid-template-columns: minmax(0, 0.1fr) minmax(0, 0.9fr);grid-column-gap: 12px;grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="4bbe8ec0fd886080b677da4e0a26c4c3"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 }  .tb-container .tb-container-inner{width:100%;margin:0 auto}.wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="3034fbe886c11054e95b46b09d3e4112"] { display: flex; }  } 
PTC delivers Better Than Human AI translations for JSON files used in web and mobile frameworks like React, Vue.js, Angular, React Native, Swift, and Kotlin. Learn how to prepare and translate your JSON files using PTC.
Translating JSON Files with PTC: First-Time Setup
Your first setup will take a few steps. You’ll structure your JSON files correctly, connect your repository to PTC, and provide PTC with the context it needs to deliver great translations. Then, PTC will handle the rest.
Step 1: Add All User-Facing Text to JSON Files
Store every UI string in your JSON files as key-value pairs. PTC reads these keys and values and returns translated versions for the selected languages.
Organize related strings into nested objects to keep files manageable and provide valuable context for translation.
Don’t hardcode translatable text directly in your source code. Hardcoded text like this won’t be extracted or translated by PTC.
Step 2: Use Placeholders for Dynamic Values
Use placeholders for variable content like usernames, counts, or dates. This helps preserve sentence structure and grammar in each language.
Your placeholder format may vary depending on your localization library. PTC supports all common placeholder formats, such as {userName}
, {name}
, %1$s
, or {{name}}
, so your dynamic content is preserved correctly in translation.
Splitting strings can break grammar and word order in other languages, leading to bad translations.
Step 3: Create a Free PTC Account and Connect Your Repository
PTC works by integrating directly with your GitHub, GitLab, or Bitbucket repository. To start using PTC:Â
- Create your free 30-day PTC account.
- Use the setup wizard to connect your code repository.
- Grant PTC read and write access so it can:
- Detect your JSON resource files
- Translate them automatically
- Push translated files back to your repo via a merge request
Step 4: Confirm or Adjust the Output File Paths
PTC shows you each resource file it will translate and the corresponding output file where it will write the translations.
You can:
- Accept the suggested output path and filename, or
- Update the path and filename to match your project’s structure
This step ensures your software can correctly locate and load the translations later.
Step 5: Tell PTC About Your Software and Choose Target Languages
PTC uses context to deliver accurate, natural translations. You’ll need to:
- Provide the name of your software
- Describe what it does
- Say who it’s for
This helps PTC choose the right tone, terminology, and phrasing for each language.
After that, choose the languages you want to translate into. PTC supports 33+ languages.
Step 6: Check the Output Files and Accept the Merge Request
When PTC finishes translating your JSON files, it creates a merge request in your repository.
PTC provides Better Than Human, context-aware translations, so you don’t need to review the translations for quality. You just need to:
- Confirm that the output files are in the right place
- Check that filenames and structure match what your software expects
- Make sure placeholders and formatting are intact
Example translated file:
{
"homepage": {
"title": "Bienvenido a nuestro sitio",
"description": "Descubre nuestros productos y servicios"
},
"form": {
"submit": "Enviar",
"reset": "Restablecer",
"greeting": "Hola, {userName}! ÂżCĂłmo podemos ayudarte hoy?"
},
"footer": {
"contact": "Contáctanos",
"terms": "Términos del servicio",
"privacy": "PolĂtica de privacidad"
}
}
If everything looks right, merge the request to add the translated files to your project. If you need to make changes before merging, go to Settings in your PTC dashboard. There, you can update the output file paths, monitored branches, or placeholder formats.
Step 7: Make Sure Your Software Loads the Translated Files
After you merge the translated JSON files, your software needs to load the correct file based on the user’s language.
If your project already uses a localization library like i18next or vue-i18n, and your file paths match its expected structure, you don’t need to make further changes.
If not, check that:
- Your software’s configuration points to the correct folders and filenames
- Your language selection logic is working and loading the right file for each language
Once set up correctly, your software will automatically display translations based on the selected or detected language.
Bonus Step: Translate Content That Isn’t Stored in JSON Files
PTC handles all your JSON translation automatically, but if your software includes translatable content that isn’t stored in JSON files, you can translate it manually using Paste to translate.
Common use cases include:
- Email content
- App store listingsÂ
- Release notes
- Other content not tracked in version control but still part of the user experience
To translate this type of content:
- Navigate to your PTC project dashboard
- Go to Translations → Paste to translate
- Add your text, choose the languages, and get instant translations
These translations aren’t added to your codebase automatically—you’ll need to paste them into your app store listing, release notes, or email configuration.
How PTC Keeps Your Translations Up to Date
After the initial setup, PTC continues working in the background. Whenever you update your source JSON files, PTC:
- Detects any new or modified strings
- Translates them automatically
- Sends a merge request with the changes
You don’t need to repeat the setup or manually update translation files. Your translations stay current without extra work.