Yaklaşan Intlayer sürümleri hakkında bildirim alın
    Oluşturma:2025-03-13Son güncelleme:2025-10-05

    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-plugin

    Hızlı başlangıç

    Eklentiyi intlayer.config.ts dosyanıza ekleyin ve mevcut JSON yapınıza işaret edin.

    intlayer.config.ts
    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):

    intlayer.config.ts
    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
    intlayer.config.ts
    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:

    1. En yüksek önceliğe sahip eklenti nihai değeri belirler
    2. Daha düşük öncelikli kaynaklar, eksik anahtarlar için yedek olarak kullanılır
    3. 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.

    intlayer.config.ts
    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.

    intlayer.config.ts
    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:

    intlayer.config.ts
    plugins: [  syncJSON({    source: ({ locale }) => `./locales/${locale}.json`,  }),];

    vue-i18n

    Her yerel için ya da her ad alanı için tek bir dosya olabilir:

    intlayer.config.ts
    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.
    Yaklaşan Intlayer sürümleri hakkında bildirim alın