Sorunuzu sorun ve bu sayfaya ve seçtiğiniz AI sağlayıcısına referans vererek belgenin bir özetini alın
Intlayer MCP Sunucusunu favori AI asistanınıza entegre ederek tüm belgeleri doğrudan ChatGPT, DeepSeek, Cursor, VSCode vb. üzerinden alabilirsiniz.
MCP Sunucu belgesini görüntüleSürüm Geçmişi
- İlk JSON Senkronizasyon Eklentisi dokümantasyonuv6.1.605.10.2025
Bu sayfanın içeriği bir yapay zeka kullanılarak çevrildi.
Orijinal içeriğin İngilizce son sürümünü görüntüleyinBu dokümantasyonu geliştirmek için bir fikriniz varsa, lütfen GitHub'da bir çekme isteği göndererek katkıda bulunmaktan çekinmeyin.
Dokümantasyon için GitHub bağlantısıBelge Markdown'ını panoya kopyala
JSON Senkronizasyonu (i18n köprüleri)
Intlayer'ı mevcut i18n yapınıza bir eklenti olarak kullanın. Bu eklenti, JSON mesajlarınızı Intlayer sözlükleriyle senkronize tutar, böylece:
- i18next, next-intl, react-intl, vue-i18n, next-translate, nuxt-i18n, Solid-i18next, svelte-i18n vb. kullanmaya devam edebilirsiniz.
- Uygulamanızı yeniden yapılandırmadan Intlayer (CLI, CI, sağlayıcılar, CMS) ile mesajlarınızı yönetip çevirebilirsiniz.
- Her ekosistemi hedefleyen eğitimler ve SEO içerikleri sunabilir, aynı zamanda Intlayer'ı JSON yönetim katmanı olarak önerebilirsiniz.
Notlar ve mevcut kapsam:
- CMS'ye dışa aktarma, çeviriler ve klasik metinler için çalışır.
- Henüz eklemeler, çoğullar/ICU veya diğer kütüphanelerin gelişmiş çalışma zamanı özellikleri desteklenmemektedir.
- Görsel editör, üçüncü taraf i18n çıktıları için henüz desteklenmemektedir.
Bu eklenti ne zaman kullanılmalı
- Zaten bir i18n kütüphanesi kullanıyor ve mesajları JSON dosyalarında saklıyorsunuz.
- Rendering çalışma zamanınızı değiştirmeden AI destekli doldurma, CI'da test ve içerik operasyonları yapmak istiyorsunuz.
Kurulum
pnpm add -D @intlayer/sync-json-plugin# veyanpm i -D @intlayer/sync-json-pluginHızlı başlangıç
Eklentiyi intlayer.config.ts dosyanıza ekleyin ve mevcut JSON yapınıza işaret edin.
Kodu panoya kopyala
import { defineConfig, Locales } from "intlayer";import { syncJSON } from "@intlayer/sync-json-plugin";export default defineConfig({ internationalization: { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], defaultLocale: Locales.ENGLISH, }, // Mevcut JSON dosyalarınızı Intlayer sözlükleriyle senkronize tutun plugins: [ syncJSON({ // Yerel başına, ad alanı başına düzen (örneğin, next-intl, ad alanları ile i18next) source: ({ key, locale }) => `./locales/${locale}/${key}.json`, }), ],});Alternatif: her yerel için tek dosya (i18next/react-intl yapılandırmalarında yaygın):
Kodu panoya kopyala
plugins: [ syncJSON({ source: ({ locale }) => `./locales/${locale}.json`, }),];Nasıl çalışır
- Okuma: eklenti, source yapıcınızdan JSON dosyalarını keşfeder ve bunları Intlayer sözlükleri olarak yükler.
- Yazma: derlemeler ve doldurmalar sonrası, yerelleştirilmiş JSON'u aynı yollara yazar (biçimlendirme sorunlarını önlemek için sonuna yeni satır ekleyerek).
- Otomatik doldurma: eklenti, her sözlük için bir autoFill yolu belirtir. intlayer fill komutunu çalıştırmak, JSON dosyalarınızdaki yalnızca eksik çevirileri varsayılan olarak günceller.
API:
syncJSON({ source: ({ key, locale }) => string, // zorunlu location?: string, // isteğe bağlı etiket, varsayılan: "plugin" priority?: number, // isteğe bağlı öncelik, çakışma çözümü için, varsayılan: 0});Birden fazla JSON kaynağı ve öncelik
Farklı JSON kaynaklarını senkronize etmek için birden fazla syncJSON eklentisi ekleyebilirsiniz. Bu, projenizde birden fazla i18n kütüphanesi veya farklı JSON yapıları olduğunda faydalıdır.
Öncelik sistemi
Birden fazla eklenti aynı sözlük anahtarını hedeflediğinde, priority parametresi hangi eklentinin öncelikli olduğunu belirler:
Daha yüksek öncelik numaraları, daha düşük olanlara karşı kazanır
- .content dosyalarının varsayılan önceliği 0'dır
- Eklentilerin içerik dosyalarının varsayılan önceliği -1'dir
- Aynı önceliğe sahip eklentiler, yapılandırmada göründükleri sırayla işlenir
Kodu panoya kopyala
import { defineConfig, Locales } from "intlayer";import { syncJSON } from "@intlayer/sync-json-plugin";export default defineConfig({ internationalization: { locales: [Locales.ENGLISH, Locales.FRENCH], defaultLocale: Locales.ENGLISH, }, plugins: [ // Birincil JSON kaynağı (en yüksek öncelik) syncJSON({ source: ({ key, locale }) => `./locales/${locale}/${key}.json`, location: "main-translations", priority: 10, }), // Yedek JSON kaynağı (daha düşük öncelik) syncJSON({ source: ({ locale }) => `./fallback-locales/${locale}.json`, location: "fallback-translations", priority: 5, }), // Eski JSON kaynağı (en düşük öncelik) syncJSON({ source: ({ locale }) => `/my/other/app/legacy/${locale}/messages.json`, location: "legacy-translations", priority: 1, }), ],});Çakışma çözümü
Aynı çeviri anahtarı birden fazla JSON kaynağında mevcutsa:
- En yüksek önceliğe sahip eklenti nihai değeri belirler
- Daha düşük öncelikli kaynaklar, eksik anahtarlar için yedek olarak kullanılır
- Bu, eski çevirileri korumanıza ve yeni yapılara kademeli olarak geçiş yapmanıza olanak tanır
Entegrasyonlar
Aşağıda yaygın eşlemeler bulunmaktadır. Çalışma zamanınızı değiştirmeyin; sadece eklentiyi ekleyin.
i18next
Tipik dosya düzeni: ./public/locales/{locale}/{namespace}.json veya ./locales/{locale}/{namespace}.json.
Kodu panoya kopyala
import { syncJSON } from "@intlayer/sync-json-plugin";export default { plugins: [ syncJSON({ source: ({ key, locale }) => `./locales/${locale}/${key}.json`, }), ],};next-intl
Her yerel için JSON mesajları (genellikle ./messages/{locale}.json) veya her ad alanı için.
Kodu panoya kopyala
plugins: [ syncJSON({ source: ({ locale, key }) => `./messages/${locale}/${key}.json`, }),];Ayrıca bakınız: docs/tr/intlayer_with_next-intl.md.
react-intl
Her yerel için tek JSON yaygındır:
Kodu panoya kopyala
plugins: [ syncJSON({ source: ({ locale }) => `./locales/${locale}.json`, }),];vue-i18n
Her yerel için ya da her ad alanı için tek bir dosya olabilir:
Kodu panoya kopyala
plugins: [ syncJSON({ source: ({ key, locale }) => `./src/locales/${locale}/${key}.json`, }),];CLI
Eşzamanlanmış JSON dosyaları diğer .content dosyaları gibi kabul edilecektir. Bu, tüm intlayer komutlarının eşzamanlanmış JSON dosyaları için de kullanılabilir olduğu anlamına gelir. Şunları içerir:
- Eksik çevirilerin olup olmadığını test etmek için intlayer content test
- Eşzamanlanmış JSON dosyalarını listelemek için intlayer content list
- Eksik çevirileri doldurmak için intlayer content fill
- Eşzamanlanmış JSON dosyalarını göndermek için intlayer content push
- Eşzamanlanmış JSON dosyalarını çekmek için intlayer content pull
Daha fazla detay için Intlayer CLI sayfasına bakınız.
Sınırlamalar (mevcut)
- Üçüncü taraf kütüphaneler hedeflendiğinde ekleme veya çoğul/ICU desteği yoktur.
- Görsel editör henüz Intlayer dışı çalışma zamanları için mevcut değildir.
- Sadece JSON senkronizasyonu; JSON olmayan katalog formatları desteklenmemektedir.
Neden bu önemli
- Yerleşik i18n çözümlerini önerebilir ve Intlayer'ı bir eklenti olarak konumlandırabiliriz.
- JSON yönetimi için Intlayer öneren eğitimlerle onların SEO/anahtar kelimelerinden faydalanırız.
- Hedef kitlesini “yeni projeler”den “zaten i18n kullanan herhangi bir ekip”e genişletir.