Global templates/Proposed specification/tr

  Татары, узбеки и ненцы И весь украинский народ, И даже приволжские немцы К себе переводчиков ждут. И может быть в эту минуту Меня на турецкий язык Японец какой переводит И в самую душу проник. —Осип Мандельштам

Bu, küresel şablonlar ve modüller için işlevsel gereksinimler için bir tekliftir.

Ayrıca bu teklifin tek sayfalık bir sürümünü de okuyabilirsiniz.

'''Bu, herhangi bir zamanda herhangi bir zamanda herhangi bir kişi tarafından yürütülmekte veya yürütülmesi planlanan bir proje değildir, en azından henüz değil. Çok detaylı da olsa bu sadece bir fikir.'''

Nihai amaç, uygun mimari, ürün ve proje yönetimi, topluluk katılımı vb. ile bunları uygulama konusunda ekipler arası ve projeler arası bir taahhüt oluşturmaktır.

Bu belge, depolama, önbellekleme, dağıtım, PHP kod tasarımı vb. bakımından teknik uygulamanın ayrıntılarına girmeye çalışmaz. Yalnızca bu özelliğin kullanıcılar açısından nasıl çalışacağıyla ilgili gereksinimleri tanımlamaya çalışır:


 * 1) Şablon ve modül oluşturan ve bakımını yapan kişiler.
 * 2) Şablonları ve modülleri aşan sayfalar oluşturan ve düzenleyen kullanıcılar. Bu, tüm editörleri ve her türlü sayfayı içerir:
 * 3) * Tüm deneyim seviyeleri: tamamen yeni olanlardan binlerce düzenleme yapanlara
 * 4) * Her türlü düzenleme aracı: viki sözdizimi düzenleme, Görsel Düzenleyici, İçerik Çevirisi ve diğerleri (hatta bot operatörleri)
 * 5) * Tüm vikiler: Vikipedi, Vikisözlük, Vikigezgin, Vikiveri, Incubator, vb. ve gelecekteki yeni projeler
 * 6) * Tüm diller: İngilizce, Fransızca, Rusça, İspanyolca, Ermenice, Farsça, Zulu, Manipuri, vb.
 * 7) * Her türlü sayfa: Vikipedi maddeleri, madde tartışma sayfaları, kullanıcı mesaj sayfaları, topluluk tartışma sayfaları, Vikiproje sayfaları, kategoriler, şablon belge sayfaları vb.

Asansör aralığı
Wikimedia sitelerinin işlevselliğinin büyük bir kısmı şablonlarda ve Lua modüllerinde uygulanmaktadır. Mevcut haliyle farklı vikiler ve diller arasında paylaşılamazlar. Bu nedenle, Görsel Düzenleyici, Vikiveri ve İçerik Çevirisi gibi maddeler oluşturmanın ve düzenlemenin modern yollarıyla entegre etmek zordur. Ayrıca mobil cihazlara uyum sağlamak da zordur. Bu, katkıda bulunanların çabalarının boşa gitmesine ve yeni editörler ve daha küçük projeler için zorluklara neden olur. Commons görüntülerine benzer şekilde bunları wiki sitelerinde paylaşmak mümkün olmalıdır. Bu, yazılım geliştirmeyi daha hızlı ve daha sağlam hale getirecek ve editörlerin yazmaya daha fazla odaklanmalarını sağlayacaktır.

Sorun
Genel yorum: Aksi belirtilmedikçe, “şablonlar”'a yapılan tüm atıflar Scribunto Lua modülleri için de geçerlidir.

Şablonlar, Wikimedia sitelerinin özelliklerini uygular. Bu özelliklerin bazıları, özellikle bilgi kutuları, kaynakça, “gerekli atıflar” ve diğerleri gibi oldukça belirgindir. Tüm okuyucular onları görür ve tüm editörler hemen hemen her düzenleme eyleminde bunlara rastlar. Ayrıca, sitelerin dahili topluluk yönetimi özelliklerinin çoğunu uygularlar: silme istekleri, engellemeyi kaldırma istekleri, tartışmalarda desteği ifade etme, Vikiprojeler için maddeler sıralama vb.

Şablonlar, birçok sayfada yinelenen metin ve işaretleme parçalarını hızlı bir şekilde tasarlamak, dağıtmak ve kullanmak için etkili bir mekanizma sağlar. Bununla birlikte, şablonların her türlü editör için birkaç akut kullanılabilirlik sorunu vardır.

Viki sözdizimi editörleri
Viki sözdizimindeki editörler için şablonları anlamak genellikle zordur. Belirli bir şablonu kullanma konusunda deneyimli kişiler muhtemelen şablonu tanıyacak ve bunu içeren bir sayfayı düzenleyebileceklerdir. Bununla birlikte, bu şablona aşina olmayan editörlerin, genellikle düzenleme ve diğer şablonlarla deneyimli olsalar bile, karşılaştıklarında belgelerine bakmaları gerekecektir. Ve düşük deneyime sahip editörler, kıvırcık parantez, boru karakterleri, eşit işaretler vb. İle parolalı metin tarafından şaşkına dönecektir.

Şablon olarak uygulanan bir özelliği kullanmak için şablonun adını bilmek ve bunu süslü parantez içine yazmak ( – ) veya başka bir sayfadan kopyalamak gerekir. Bu yeni kullanıcılar için açık değildir ve deneyimli kullanıcılar her yeni şablonu da ayrı ayrı öğrenmek zorundadır.

Bazı vikilerde, bu projede ortak olan şablonları düzenleme araç çubuğuna ekleyen düğmeler ekleyen araçlar bulunur. Şablonların birçoğu projeler ve diller arasında benzer işlevselliğe sahip olsa da bunlar her vikide farklıdır.

Görsel Düzenleyici kullanıcıları
VisualEditor kullanıcılarının şablonları kullanma konusunda bazı avantajları vardır, ancak onlarla ilgili birçok sorun da vardır. Özellikle, benzer bir bulunabilirlik sorunu var: Görsel Düzenleyici'de, tüm şablonların işlevleri “ → ” menü öğesinin arkasında gizlidir ve kullanıcının şablonu kullanmadan önce bilmesi gerekir.

Görsel Düzenleyici'nin “” menüsünde Matematik formülleri, Mısır Hiyeroglifleri, Müzik notaları ve uzantı olarak uygulanan diğer bazı işlevler vardır, ancak “Bilgi kutusu”, “Kaynak belirtilmeli”, “Birim dönüşümü”, "Teklif" vb. gibi öğeleri yoktur. Tüm şablonlar aynı türden genel öğelerdir.

Dikkate değer bir istisna vardır: Bazı wikilerin kaynak şablonları içeren dipnotlar ekleyen “” düğmesi vardır. Ancak, kuralı ispatlayan bir istisnadır. Temel işlevler için bile manüel yapılandırma gerektirir, bu yapılandırma her wiki için ayrıdır ve sonuç olarak birçok vikide bu düğme yoktur. 2019'un sonlarında eklenen başka bir karşılaştırılabilir istisna, “Kaynak belirtilmeli” şablonlar için özel destektir, ancak bunun aynı zamanda gerçekte çalışması için her bir viki üzerinde bazı özel yapılandırmalara ihtiyacı vardır.

Birden fazla projede yazan editörler için zorluklar
 Yesterday came suddenly, tomorrow we’ll receive, Today now you’re at the wheel I’ll ask how does it feel.

Yesterday when heaven’s gates I’d contemplate they’d seem so far, Today they ain’t so far away and almost seem ajar.

Keep what ya got by giving it all away. Keep what ya got by giving it all away. Keep what ya got, Hold it, don’t stop, Keep what ya got by giving it all away. —Ian Brown Birçok şablon bir projede bulunur, ancak diğer projelerde yoktur ve genellikle bir şablon mevcuttur, ancak farklı bir formdadır. Bu nedenle, bir projede kazanılan becerileri yeniden kullanmak zor veya imkansızdır: şablonun sağladığı işlevsellik bazen mevcut değildir ve bazen farklı çalışır. Bu sadece farklı dillerdeki vikiler için değil aynı zamanda Türkçe Vikipedi ve Türkçe Vikikaynak gibi aynı dildeki farklı vikiler için de geçerlidir.

Farklı dillerde düzenleme yapan kişiler için şablonlar çeviriyi zorlaştırır. Bir sayfayı çevirirken, çevirinin elle mi yoksa İçerik Çevirisi ile mi yapıldığına bakılmaksızın, şablonların madde metninden (“nesir”) çok daha zordur. Kullanıcılar genellikle makaleyi yayınladıktan sonra şablonu atlamak veya düzeltmek zorundadır. Şablon çevirisi korkutucu göründüğünden, bu durum çevirilerin terk edilmesine de neden olur.

İçerik Çevirisinde en sık bildirilen sorunlar şablonlarla ilgilidir.

İçerik Çevirisi, bu işlemin bazı bölümlerini otomatikleştiren bir şablon uyarlama özelliğine sahiptir, ancak yalnızca her iki dilde karşılık gelen bir şablon varsa ve tüm parametreler şablon koruyucular tarafından titizlikle eşlendiyse çalışır. Bu, her dildeki her şablon için ayrı ve manüel olarak yapılmalı ve kaynak şablon değiştiğinde sürekli olarak korunmalıdır. Bu, şablonların dillerdeki işlevi çoğu zaman aynı olmasına rağmen olur.

İdeal olarak, şablonlar ve parametreleri çevrilen sayfaya neredeyse tamamen otomatik olarak aktarılmalıdır, böylece çevirmenler nesir yazmaya odaklanabilir, çünkü nesir yazmak insan çalışmasının en çok ihtiyaç duyduğu alandır.

Bir şablon bir vikiden diğerine aktarılabilir, ancak bu yapıldıktan sonra şablon çatallı bir kopya haline gelir. İhraç edildiği durumda kalır veya ayrı olarak geliştirilmeye devam ederek uyumsuzluğa neden olur. Bazen insanlar farklı kopyaları saklamaya devam ederler, ancak bu sağlam değildir ve sahip olduğumuz yüzlerce viki için ölçeklendirilemez.

Şablon parametreleri aynı işlevselliğe sahip olabilir, ancak farklı vikilerde farklı adlar olabilir. TemplateData takma adları kullanılarak uyarlanabilirler, ancak bu bir yetersiz hacktir: TemplateData'nın başlangıçta yaptığı şey değildir ve her dil çifti için manüel olarak yapılması gerekir.

Şablonlar algoritmik mantığı, okunabilir metin dizelerini ve biçimlendirmeyi bir araya getirir. Bu nedenle, MediaWiki çekirdeği ve uzantılarıyla yapıldığı için şablonların kullanıcı arayüzü dizelerini çevirmenin sağlam bir yolu yoktur.

Küçük vikilerdeki editör zorlukları
Temel MediaWiki yüklenerek ve varsayılan bir uzantı kümesi etkinleştirilerek yeni bir viki projesi oluşturulur. Pratikte bu, düz bir oyun alanı oluşturmaz, çünkü daha büyük wikilerin birçok temel özelliği şablonlarda uygulanır: bilgi kutuları, kaynaklar, bakım notları ( gibi), vb.

Yazılım geliştirici zorlukları
MediaWiki çekirdeği, uzantılar, robotlar ve viki sayfası içeriğini analiz eden, üreten veya değiştiren diğer araçlar geliştiriciler için, bir vikide belirli şablonların varlığına bağlı özellikler geliştirmek zordur. GrowthExperiments, PageTriage, ContentTranslation, Wikibase'in bazı bileşenleri ve diğerleri gibi uzantıların geliştiricileri, bunları üretimde test etmelidir, bu da kötü bir fikirdir veya şablonları yerel vikilerine veya çevrimiçi test vikilerine aktarmak zorundadır.

Şablonlara dayalı viki içeriği hakkında veri alan araştırmacılar, her bir viki için analiz kodlarını ayrı ayrı yazmak zorundadırlar ve bazen sadece bir viki için yaparlar. Dikkate değer bir örnek, sayfa konularını analiz etmek ve makale kalitesini değerlendirmek için Türkçe Vikipedi'nin Vikiproje şablonlarını kullanmaktır.

Uzantılar ve Şablonlar: Benzerlikler ve farklılıklar
Bu proje teklifinin ana varsayımlarından biri, şablonların ve modüllerin MediaWiki çekirdeğine ve uzantılarına çok benzemesidir: Yazılımdır ve editör topluluğunun ihtiyaç duyduğu özellikleri uygularlar. Özellikle, şablonlar genellikle editörler tarafından geliştirildiğinden, gerçekten topluluğunun onlara ihtiyacı olduğu açıktır. Nasıl geliştirildikleri, yerelleştirildikleri ve konuşlandırıldıkları arasındaki yalan arasındaki büyük farklardır.

Şablonlar ve modüller, şu anda sahip olmadıkları bazı önemli özelliklerde uzantılara benzer olmalı ve uzantıların eksik olduğu bazı iyi özellikleri korumalıdır. (Türkçe okuyucular tarafından kolayca anlaşılabilmesi için tabloda Türkçe Vikipedi'den şablon örnekleri verilmiştir. Ayrıca başka herhangi bir viki ve başka bir dilden de gelebilirler.)

Şablon ve modül geliştirme becerileri
Bu teklifin dayandığı bir diğer önemli varsayımlar kümesi şöyledir:
 * Şablon ve modül geliştirme becerileri önemsiz değildir. Hem şablonlar hem de modüller çok fazla belirsiz özelliğe sahiptir.
 * Sitelerin en dikkate değer özelliklerinin birçoğu şablon ve modül olarak uygulansa da, bu beceriler genellikle fark edilmez, takdir edilmez ve kabul edilir.
 * Bu becerilere sahip onlarca kişi var ve birçok viki düzenliyorlar. Genellikle ana vikilerine odaklanırlar ve diğer vikilerden veya diğer dillerden katkıda bulunanlarla nispeten nadiren iletişim kurarlar. Temel teknoloji her yerde aynı olsa da, küresel MediaWiki çekirdek ve uzantı geliştiricileri topluluğuyla karşılaştırılabilecek gerçek bir küresel şablon geliştiricileri topluluğu yoktur. Belirli şablonlarda çapraz wiki işbirliği vakaları vardır, ancak bunlar tutarsızdır.
 * Bu becerilere sahip olan editörlerin bulunmadığı birçok vikiler de vardır. Nasıl çalıştıklarını tam olarak anlamadan ve etkili bir şekilde yerelleştirme ve bakım yapma yeteneği olmadan başka vikilerden şablonlar ve modüller kopyalarlar veya hiç şablon kullanmazlar.

Bu durum optimal olmaktan uzaktır. Şablon ve modül geliştiricilerinin becerileri daha fazla takdir gerektirir. Gerçekten ihtiyaç duyulan özellikler geliştirirler ve editör topluluklarına yerleştirilirler. Birçok dilde vikilerde, şablon geliştiriciler yapılandırılmış içerik, veri sunumu ve modülerleştirme için yenilikçi özellikler ortaya koyar. Bu yenilikler birçok vikide yararlı olabilir, ancak şu anda bunu başarmak için uygun bir mekanizma bulunmamaktadır.

Ve elbette, bu sorunlara yönelik herhangi bir çözüm, şablon sahiplerinin edindiği uzun yıllara dayanan uygulamalı deneyimleri atacak tamamen yeni teknolojiler üretmemelidir. Bu nedenle, şablon ve modül geliştirmek için sözdiziminde mümkün olduğunca az değişiklik yapılmalıdır. Değişmesi gereken şeyler, vikilere dağıtıldıkları ve yayıldıkları ve içindeki insan tarafından okunabilen dizilerin yerelleştirildiği (çevrildiği) yollardır.

Önerilen çözüm: Özet
MediaWiki'nin vikiler genelinde küresel olan birçok özelliği var: resimler (Commons kullanarak), engelleme, kullanıcı hesapları (CentralAuth), tercihler, kullanıcı sayfaları, kullanıcı JS ve CSS sayfaları ve diğerleri.

Şablonları ve modülleri de küresel bir depoda saklamak ve uzantılarla olduğu kadar sağlam bir şekilde yerelleştirmek mümkün olmalıdır.

Küresel şablonlar ve modüller, şablonların kodunu geliştirmede daha kolay işbirliği yapmalarını sağlayarak tüm vikilerde şablon koruyucuyu güçlendirir.

Küresel şablonlar ve modüller, çevirmenleri ve yerelleştiricileri, koddaki dizeleri aramak zorunda kalmadan yalnızca kullanıcı arabirimi dizelerini (“mesajlar”) çevirmeye odaklanmalarına izin vererek ve çeviri için aynı becerileri ve araçları kullanmalarına izin vererek güçlendirir. şablonları ve MediaWiki uzantıları.

Küresel şablonlar ve modüller, tüm wikilerdeki içerik editörlerini, bu şablonları kullanan içeriği, farklılıklara dalmak zorunda kalmadan ve her vikide farklı kural ve becerileri yeniden öğrenmek zorunda kalmadan yazma ve çevirme konusunda güçlendirecektir.

Şablon ve modül geliştirme sözdizimi ve genel şablon bakım ve dağıtım döngüsü değişmeyecektir, bu nedenle şablon koruyucusunun yıllar boyunca edindiği tüm beceriler alakalı olacaktır.

Tüm vikiler küresel şablonları kullanabilir, ancak bunu yapmak zorunda kalmazlar. Topluluklar tüm küresel işlevleri, tasarımları, iş akışlarını ve verileri geçersiz kılma yeteneklerini koruyacaktır.

Şablonları yerelleştirmek, MediaWiki uzantılarını yerelleştirmek kadar kolay olacaktır.

Şablonlar anlamsal ve küresel olmalıdır
Anlamsal, diğer yazılım bileşenlerinin, özellikle Görsel Düzenleyici ve İçerik Çevirisi'nin, bir şablonun var olduğunu ve belirli işlevsellik sağladığını anlamanın genel bir yoluna sahip olması gerektiği anlamına gelir, böylece onu sayfaya bir sayfaya eklemek mümkün olur bilgi kutusu, bir alıntı, bir bakım etiketi, vb. ve yalnızca genel bir şablon olarak değil. Şu anda, şablonları semantik hale getirmek için en yakın şey TemplateData'dır, ancak yalnızca şablonun parametrelerini açıklamaktadır. Örneğin, Görsel Düzenleyici'nin araç çubuğuna bir "Bilgi kutusu ekle" düğmesi eklemesine yardımcı olmaz.

Küresel bir şablonun kodunun tek bir yerde muhafaza edilmesi ve tüm vikilerde kullanılabilmesi anlamına gelir.

Şablonları anlamsal yapma
Şablonlar, sayfaları işleyen yazılımlar tarafından kolayca idare edilme anlamında hiçbir zaman sağlam bir anlamsal olmamıştır.

Anlamsal hale getirilmiş şablonlardan sadece birkaç örneği vardır:


 * Visual Editor araç çubuğu “” düğmesinden kullanılabilen çeşitli kaynak şablonları. Bunları kullanmak isteyen her vikide Citoid'i yapılandırmak için birçok ayrı kod yazmayı gerektirirler.
 * 2019'un sonlarında Görsel Düzenleyici'ye uyarlanan “kaynak belirtilmeli”. Ayrıca her vikide yapılandırma gerektirir. Örneğin: İngilizce, İngilizce, İbranice, Slovence. Bu yazıdan itibaren, Fransızca, İspanyolca ve diğer birçok dil, bu tür şablonlara sahip olsalar da, bunun için yapılandırılmamıştır.
 * Flow yapılandırmasındaki yerel yapılandırma gerektiren kullanıcılardan bahsettiği şablonlar.
 * Bazı döküm işleme ve araştırma araçları Türkçe Vikipedi2nin genellikle tartışma sayfalarına eklenen Vikiproje sayfa değerlendirme şablonlarını ayrıştırabilir.
 * GrowthExperiments uzantısı, editörlere makalelerde yer alan şablonlara dayalı olarak belirli görevleri gerçekleştirmelerini önerir. Şablon adlarının her bir vikide ayrı ayrı JSON dosyaları yazarak manüel olarak yapılandırılması gerekir. Örneğin: Çekçe, Vietnamca, Korece, Arapça.
 * PageTriage uzantısı Türkçe Vikipedi'nin hatnot şablonlarıyla (“etiketler” olarak da bilinir) çalışacak şekilde yapılandırılmıştır.

PageTriage durumunda, uzantı tek bir viki şablonunu temel olarak kodlar, bu da önemli bir yeniden yazma olmadan diğer vikilerde kullanılamaz hale getirir. Viki üzerinde yapılandırma adımı küçük olsa bile, Flow örneğinde olduğu gibi, yine de yapılması gerekir. Bu, Wikimedia'nın sahip olduğu 900 viki ve gelecekte sahip olacağı binlerce wikis için iyi değildir.

Bunlar varsayılan olarak küresel olmalıdır, böylece uzantılar, botlar, döküm analizörleri vb. tarafından tüm wikiler üzerinde en azından temel bir varsayılan yapılandırmada hemen kullanılabilir olacaklardır.

Depolama ve teslimat
Küresel şablonlar ve modüller merkezi bir vikide (Meta, Commons veya tamamen yeni bir wiki) saklanabilir ve hatta Gerrit veya başka bir depo olabilir.

En iyi çözüm muhtemelen görüntülerle, genel topluluk tartışmasıyla vb. karıştırılmadan onları saklayacak yeni bir viki oluşturmaktır.

Gerrit'i şablonlar ve modüller kodu için depolama alanı olarak kullanmak teknik olarak mümkündür, ancak şablon koruyucular için önemli bir erişilebilirlik unsurunu kaybeder: viki sayfasındaki bir şablonu düzenlemek, şablon sahiplerinin büyük çoğunluğuna Git taahhütlerini yapmaktan çok daha kolay ve tanıdıktır. kod incelemesi bekleniyor. Bu nedenle Gerrit muhtemelen şablon ve modül kodunu saklamanın bir yolu olmamalı, en azından birincil kod değildir.

Küresel şablonlar ve modüller, çoğu viki düzenleyicisi tarafından düzenlenebilen ortak bir depoda saklanmalıdır. Engelleme ve özel izinlerle ilgili kurallar başlangıçta diğer vikilerdeki kurallara benzer olmalıdır: her şey varsayılan olarak açık olmalı ve çok yaygın, hassas veya sık sık saldırıya uğramış şablonları korumak mümkün olmalıdır. Koruma düzeyleri hakkında daha ayrıntılı kurallar daha sonra editörler topluluğu tarafından geliştirilebilir.

Şablonların hedef vikilere nasıl dağıtılacağı, diğer gereksinimler karşılandığı sürece bir iç mühendislik ve mimarlık sorunudur. Bu sorular geçmişte bazı platform geliştiricileri tarafından, örneğin Gölge ad alanları projesi etrafında tartışıldı. Bu belge, şablon kullanan bir sayfayı düzenleyen veya şablonun kendisini koruyan kullanıcı için nasıl çalıştığı ile ilgili soruları çözmeye çalışır; yerelleştirilebilir şekilde nasıl yazılır; nasıl çevrilir; yerel olarak nasıl özelleştirilir; Bu sorular konuyla ilgili önceki mimari tartışmalarda yeterince ele alınmamıştır.

Şablonların değiştirilmesi kolay olmalıdır
Şablonların şu anda nasıl çalıştığının önemli bir özelliği, viki sayfaları gibi düzenlendikleri ve inceleme veya dağıtım yapılmadan yayınlandıktan hemen sonra işlevsel hale gelmeleridir. Bu biraz tehlikelidir, çünkü kötü bir düzenleme birçok sayfayı mahvedebilir, ancak gerçek şu ki çoğunlukla iyi çalışır.

Bu kolaylığın korunması gerekir. Şablonları koruyan topluluk üyeleri, tamamen yeni beceriler edinmelerini ve yorucu bir inceleme ve dağıtım aşamasıyla her değişikliği sürüklemelerini gerektiren yeni bir sisteme geçmeyi reddedecektir. Bu muhtemelen, şablonların Gerrit'te depolanmasının işe yaramayacağı anlamına gelir, belki de inceleme ve dağıtım süreci uzantılardan daha çok kolay olmayacaksa.

Bazı şablonları global olmayan yapmak mümkün olmalıdır
Tüm şablonlar küresel olmaya zorlanmamalıdır.

Aslında, bazı şablonlar yerel olmalıdır çünkü belirli bir dile özgü bir işlevsellik uygularlar. Doğası gereği, bu tür şablonların çevrilmesi gerekmez ve hem insan editörlere hem de çeviri araçlarına (İçerik Çevirisi gibi) uyarlanmaları gerekmediği konusunda bir ipucu vermenin bir yolu olmalıdır. atlandı veya değiştirildi. Bu, şablonları daha anlamsal hale getirme çabasının bir parçasıdır.

Genel bir şablonun bazı işlevlerini veya görünümünü geçersiz kılmak mümkün olmalıdır
Hiçbir topluluk, Türkçe Vikipedi topluluğu, Vikiveri topluluğu, WMF veya başka herhangi biri gibi güçlü bir harici oyuncu tarafından bir işlevsellik uygulandığını düşünmemelidir. Küresel şablonlar ortak yarar için birlikte geliştirilmeli ve kullanılmalıdır. Çoğu zaman herkes için çalışmalıdır.

Bazen bazı topluluklar, dillerinde veya projelerinde farklı olacak belirli bir işlevsellik veya tasarıma sahip olmak veya diğer projelerde gösterilenden farklı bilgiler içeren bir bilgi kutusu göstermek veya hiç göstermemek konusunda güçlü fikirlere sahip olabilirler. Yerel olarak bir şeyleri geçersiz kılma özelliğine başlangıçtan itibaren izin verilmelidir. (Daha doğrusu, götürülmemelidir.)

Küresel bir şablon her vikide hemen kullanılabilir olmalıdır
Küresel bir kullanıcı sayfasının yerel kullanıcı sayfasının olmadığı her vikide hemen kullanılabilir olması gibi, küresel altyapıda oluşturulan her şablon veya modülün her vikide hemen kullanılabilir olması gerekir.

Bu, viki sayfalarını kopyalama, yerel adla sarma şablonları oluşturma, yönetici müdahalesi, önbelleklerin yenilenmesini saatlerce bekleme gibi herhangi bir ek adım gerektirmemelidir.

Merkezi sürüm güncellendikten sonra, güncellenen sürüm hemen her yerde gösterilecektir. Vandalizmi önlemek için editörler topluluğu izinler ve koruma seviyeleri hakkında politikalar geliştirecektir.

Kullanıcı arabirimi dizeleri (“iletiler” olarak da bilinir) çevrilmezse, şablon yine de kullanılabilir ve dizeler geri dönüş dilide gösterilir. Daha fazla ayrıntı için yerelleştirme ile ilgili bölümlere bakın.

Kullanıcıya yönelik tüm dizeleri çevirmek mümkün olmalıdır
Temel MediaWiki'nin kullanıcı arabirimi dizeleri (mesajları) ve Sayfa Görüntüleme gibi bazı harici araçların çevirisi translatewiki.net'te rahat ve sağlam bir şekilde çevrilmiştir. Bu yerelleştirme işlemi, tüm dillerdeki en azından bazı editörlere aşinadır.

Şu anda şablonlarla aynı şeyi yapmak mümkün değildir. Commons ve mediawiki.org gibi çok dilli siteler, bazı şablonları çevirmek için “TNT” sistemine sahiptir, ancak çok karmaşıktır ve Vikipedi, Vikikaynak vb. için tekrar kullanılamaz.

İdeal olarak, Translate uzantısına sahip bir viki kullanarak şablonları çekirdek ve uzantılar gibi çevirmek mümkün olmalıdır.

Çevrilen dize, Çeviri arabirimi kullanılarak çeviri gönderildikten hemen sonra kullanılabilir hale gelmelidir.

Ham viki sayfalarındaki kullanıcı arabirimi dizelerini düzenlemek mümkün olabilir, ancak ideal olarak öncelikle özel bir çeviri arabirimi aracılığıyla düzenlenmelidir.

Çevirmenler metinden başka bir şeyi çevirmeye odaklanabilmelidir. Etrafında herhangi bir kod görmek, programlama ve JSON dosyaları konusunda deneyimli olmayan kişilerin kolayca katkıda bulunmasını zorlaştırır. Ayrıca, ham metin dosyalarında sağdan sola yazılan dillere çevirileri düzenlemek son derece elverişsizdir. Translate uzantısı bu sorunların tümünü zaten ele alıyor.

Şablon belgelendirme sayfaları da çevrilebilir olmalıdır. Translate uzantısının sayfa çevirisi özelliğini kullanarak bunu yapmak yeterlidir, ancak bazı uyarlamalar gerekebilir.

Dizelerin kullanıcıya gösterildiği dil
Şablonlar öncelikle içeriğe entegre edildiğinde kullanılır, bu nedenle varsayılan olarak çevrilmiş mesajların vikinin içerik dilinde gösterilmesi gerekir.

Bununla birlikte, bazı şablonlar kullanıcı arabirimi öğeleri olarak kullanılır. Bu nedenle, viki içerik dilinden farklı olduğunda, çevrilmiş dizelerin kullanıcı dilinde gösterilmesine izin vermek de belki mantıklıdır. Bu özellikle Commons, Vikiveri, Meta ve mediawiki.org gibi çok dilli siteler için geçerli olabilir.

Bir çeviri olmadığında, MediaWiki’nin normal yedek dil zincirleri kullanılmalıdır. Örneğin, bir mesaj Quechua veya Guarani'ye çevrilmezse, İspanyolca, Başkurtça veya Çuvaşça'ya çevrilmemişse, Rusça ve benzeri gösterilecektir. En son geri dönüş dili İngilizce'dir, bu nedenle bu mesaj İspanyolca veya Rusça'ya çevrilmezse, İngilizce olarak gösterilecektir.

Mesaj anahtarları
Mesajlar, MediaWiki çekirdeğinde, uzantılarda ve araçlarda nasıl yapıldığına benzer şekilde anahtarlar olarak gösterilmelidir.

Çevrilebilir dizeler yazmak, şablon geliştiricilerin alışması gereken şablon geliştirme sürecindeki en büyük değişiklik olacaktır. Sabit kodlu dizelerin ayrılması ve anahtarla düzenlenen iletilere taşınması gerekir. Sadece çevirmenler için değil, aynı zamanda şablon koruyucular için de mümkün olduğunca kolay yapılmalıdır. Aksi takdirde, aslında yapmazlar ve özellik etkili bir şekilde reddedilir.

Anahtarları dünya çapında benzersiz kılmak için, genel şablon adını otomatik olarak mesaj anahtarına dahil etmekte sorun yoktur.

Geçiş araçları
Bir şablon veya modülün merkezi depolamaya geçişine yardımcı olacak bir araç geliştirilmelidir. Aşağıdaki adımları yapabilir:
 * 1) Yerel bir vikiden bir şablonu dışa aktarın ve genel vikiye içe aktarın.
 * 2) Bu şablon tarafından kullanılan tüm şablonları dışa aktarın (basamaklı).
 * 3) Okunabilir dizeleri tanımlayın, anahtarlar içeren bir listeye dönüştürün ve bunları şablonun kaynak kodundaki anahtarlarla değiştirin.
 * 4) Şablonun belgelendirme sayfasını ve TemplateData'yı içe aktarın.
 * 5) Gerekli CSS sayfalarını içe aktarın.

Çoğu durumda, bu otomatik işlem muhtemelen tamamen kullanılabilir ve sağlam bir şablon veya modül oluşturamaz, ancak geçiş işleminin başlamasına yardımcı olabilir.

Mesajları düzenleme
Translate uzantısı, iletileri "projeler" olarak da bilinen gruplara göre düzenler ve bunlar toplu gruplar tarafından daha da organize edilebilir. Örneğin, Madde Yer Tutucusu, Puan ve Şiir, karşılık gelen MediaWiki uzantılarını temsil eden gruplardır ve bunların çoğu, diğer birçok uzantıyla birlikte “Extensions used by Wikimedia - Advanced” toplu grubunda yer alır.

MediaWiki uzantılarını temsil eden projeler, translatewiki deposundaki YAML dosyalarında yapılandırılır ve “ileti grubu seçici” olarak da bilinen proje seçicisindeki Çevir kullanıcı arabiriminde gösterilir.

Uzantılardan çok daha fazla şablon olduğundan, Translate uzantısının şablon çevirisine uyum sağlamak için mesaj gruplarını işleme biçiminde bazı değişiklikler gerekebilir.

Her şablon bir mesaj grubu olmalıdır. Yakından ilişkili şablonlar, toplu bir mesaj grubunda gruplandırılmalıdır. Depolandıkları kategorilere benzer olabilirler ve aslında kategoriler tekrar kullanılabilir. Bu mesaj gruplarını düzenlemek için Git deposundaki dosyaları düzenlemek muhtemelen istenmez, çünkü çok karmaşık ve yavaştır.

Grup ve şablon adlarını seçicide yerelleştirilmiş olarak göstermek iyi olur, ancak İngilizce olarak gösterilmeleri de sorun olmaz. Uzantı yerelleştiricileri için yeterince iyiyse, şablon yerelleştiricileri için de iyidir.

Şablonlar, Translate uzantısının Dil istatistikleri özel sayfasında (Special:LanguageStats) mesaj grupları olarak gösterilmelidir. Bu, yerelleştiricilerin hangi şablonların çevrilmesi gerektiğini bulmasına yardımcı olur. Bu genellikle tüm mesaj gruplarına benzer olmalıdır, ancak şablonlar için bazı özel hususlar vardır:
 * Binlerce şablon olacak, bu yüzden tablonun tasarımı buna bir şekilde karşılık gelirse iyi olacak.
 * Tablo, her bir şablonun sayfanın transkript edildiğini göstermeli ve yerelleştiricilerin çevrilmesi gereken önemli şeylere öncelik vermesine yardımcı olmak için bu sayıya göre satırları sıralamayı mümkün kılmalıdır.

Bir şablonu nasıl çevireceğinizi bulma
Her şablon açıklaması sayfasının, kullanıcının diline çevirmek için doğrudan bir bağlantısı olmalıdır.

Bazı şablonlar, sabit kodlama dizeleri yerine kullanıcı arayüzlerinin bir parçası olarak Vikiveri etiketlerini kullanır. Bu şu anda Commons'ta Vikiveri Bilgi Kutusu, Katalanca Vikipedi'de Infotaula persona (Bilgi kutusu kişisi) ve diğer birçok şablonda yapılır. Bu etiketler ve değerler Vikiveri'nin kendisinde yerelleştirilebilir. Bu tür kullanım, şablon yerelleştirmenin tüm ihtiyaçlarını karşılayamaz, ancak belirli amaçlar için meşru ve kullanışlıdır. Bu, şablon belgelerinde düzgün bir şekilde açıklandığı sürece, bu kullanılmaya devam edebilir ve muhtemelen özel altyapı adaptasyonlarına ihtiyaç duymaz. (Belki de ilgili etiketlerin ve değerlerin çevirisi, şablonu yerelleştirmek için bir şekilde Çeviri arayüzüne entegre edilebilir, ancak bu isteğe bağlıdır.)

Mesaj parametreleri ve sihirli kelimeler
Temel MediaWiki ve uzantılarda, çoğu iletide bazen “yer tutucu” olarak da bilinen parametreler bulunur. Bunlara $1, $2 vb. adı verilir ve çalışma zamanında doldurulur. Parametreler, farklı diller farklı kelime sırasına sahip olduğu için iletileri sağlam bir şekilde çevrilebilir hale getirmek için özellikle önemlidir.

Şablonlarda da böyle bir şeye ihtiyaç vardır, ancak formun $1, $2 olması gerekmez, ancak üçlü kıvırcık parantez içeren şablon benzeri parametreler ( { – } ). Bu, ayrıştırma ve yerelleştirme kolaylığı hususlarına göre kararlaştırılacaktır.

PLURAL, GENDER ve GRAMMAR sihirli sözcükleri şablon mesajlarında MediaWiki mesajlarında olduğu gibi desteklenmelidir.

Mesaj belgeleri
Temel MediaWiki ve uzantılarda, çevrilebilir her mesaj, geliştiricilerin ve çevirmenlerin rahatlığı için belgelenmiştir. Belgeler, iletinin nerede göründüğü, $1, $2 vb. parametrelerin ne olduğu, kelimenin bir fiil mi yoksa bir sıfat mı olduğu hakkında bilgiler içerebilir. Bu belgeler, qqq koduyla sözde dil olarak saklanır.

Bu tür belgeler şablon çevirisi için de yararlı olacaktır. Nasıl saklandığı teknik mimari meselesidir. Belki TemplateData ile birleştirilebilir, belki bir qqq dili olarak saklanabilir ve belki de başka bir şey olabilir.

Kaynak dil
Şablonlar, yalnızca İngilizce projelerinden değil, birçok dilde vikilerden de küresel depolamaya aktarılacaktır. Yerelleştirme araçları, her zamankinden daha fazla, yalnızca İngilizce'den değil, herhangi bir dilden çeviriyi desteklemelidir.

Bulanıklaştırma
Temel MediaWiki ve uzantılarda ve çevrilebilir sayfalarda, İngilizce kaynak mesaj değişirse, mesaj otomatik olarak eski veya “bulanık” olarak işaretlenir. Mevcut çeviriler çalışmaya devam ediyor, ancak çevirmenlere güncellenmesi gerektiği gösteriliyor. (Çeviri hizmetlisi ayrıca bir iletiyi bulanıklaştırmaya gerek duymayacak şekilde işaretleyebilir.)

Şablon yerelleştirmesi için benzer bir mekanizma gerekecektir. Ancak, İngilizceyi kaynak dil olarak zorlamamak hoş olacağından, iletileri bulanık olarak işaretlemenin daha fazla yolu olmalıdır.

Modüller için yerelleştirme hususları
Lua modülleri çevrilebilir MediaWiki dizelerini yükleyebilir ve ayrıştırabilir, ancak bu dizeleri wiki sayfaları olarak tutulan Lua modülleri için depolamanın tanımlanmış bir yolu yoktur. Lua modüllerini uzantıların bir parçası olarak paketlemek mümkündür ve daha sonra uzantıların i18/*.json dosyalarından mesaj yükleyebilirler, ancak bu şu anda çok az sayıda uzantıda yapılmaktadır. Lua'daki şablonların yeniden yazılması, mühendislik açısından daha sağlam bir çözüm olabilir, ancak Lua, mevcut tüm şablon koruyucular tarafından benimsenmeyebilir ve işbirliği, projenin başarısı için çok önemli olacaktır, bu nedenle tüm şablonlar için yapılamaz.

Yaygın olarak kullanılan, nadiren değiştirilen ve uluslararasılaşma gerektirmeyen bazı çok içsel, teknik modüller muhtemelen ağrısız bir şekilde Scribunto uzantısının kendisine taşınabilir. No globals ve Arguments örnek olarak verilebilir.

Şablon adını yerelleştirme
Şablon her dilde farklı bir ada sahip olabilir, ancak doğrudan merkezi depolama birimine bağlı olmalıdır.

Küresel şablonların ve modüllerin herhangi bir ek adım olmadan tüm vikilerde hemen kullanılabilir olması gerekir; bu nedenle, küresel adını kullanarak yerel bir viki sayfasına küresel bir şablon eklemek mümkün olmalıdır. Çapraz viki editörleri topluluğu bu küresel isimler için politikanın ne olacağına karar verecek.

Parametre adlarına benzer şekilde, şablonlar farklı dillerde farklı adlara sahip olabilir ve bu korunmalıdır. Şablon adlarını çevirmek için yapılandırılmış bir yol olmalıdır. Belki de Vikiveri site bağlantıları bir rol oynayabilir, ancak zorunlu değildir.

Bu yapılmazsa, editörler küresel şablonlardan kaçınır veya küresel şablonu çevrilmiş adla yerel bir şablona sarar ve bu muhtemelen şablonun global varlıkla bağlantıyı kaybetmesine neden olur. Bu arzu edilmez ve projenin tüm noktasını kaçırır.

Şablon adları yalnızca vikilerin içerik dili olabilecek dillere çevrilmelidir. Resmi Almanca veya İngiliz İngilizcesine çeviri yapılması gereksizdir. Takma adlar veya yönlendirmeler almanın bir yolu olabilir. Sırpça ve Çince gibi dil değişkenleri bu dillerin ihtiyaçlarına göre desteklenmelidir.

Bir vikide yerel bir şablon varsa ve genel şablonun yerelleştirilmiş adıyla aynı ada sahipse, yerel şablon kullanılır. Bu, aynı ada sahip yerel dosyaların Commons'ta genel dosyaları nasıl geçersiz kıldığına ve MediaWiki alanındaki yerel iletilerin koddan gelen yerelleştirmeyi nasıl geçersiz kıldığına benzer.

Lua modül adları da genellikle yerelleştirilir. Adları, viki sayfalarından doğrudan çağırmak için yerelleştirilebilir, ancak kod genellikle İngilizce'ye benzer tanımlayıcılar kullandığından, dahili genel adların muhtemelen kodun kendisinde, örneğin  ifadelerinde kullanılması tercih edilmelidir.

Parametre adlarını yerelleştirme
Parametre adları her dilde farklıdır. Genellikle her dildeki kelimelere dayanırlar, bu nedenle viki sözdizimindeki dönüşümü uygun şekilde düzenlemek önemlidir.

İdeal olarak, küresel şablonun farklı dillere çevirileri olan genel dahili parametre adları olmalıdır. Bu, Vikiveri özellik adı etiketlerine biraz benzer, ancak daha basit olabilir: İngilizce, yazılım geliştiricileri ve şablonlar için bir lingua franca olduğu için bir tür yazılım olduğundan, İngilizceyi varsayılan kaynak dili yerine varsayılan olarak kullanmak iyi olur, Vikiveri'de olduğu gibi genel sayılar.

Bu genel parametre adları, genel varsayılan adlar olacaktır. Vikide tüm dillerde çalışacaklar. Yerelleştirilmiş adlar, o dili içerik dili olarak kullanan vikilerde çalışır.

These translations of parameter names must be validated:


 * they must not include invalid characters
 * they must not be repeated within one template in one language
 * Anything else?

The actual process of translating the parameter names may be different from translating user interface strings. These names have technical constraints, and they must remain stable because changing a name of parameter will break existing transclusions, so there should be some safeguards against this.

Automatic parameter translation
If all the localized template and parameter names are stored centrally, it will possible to have a simple service that gets a valid template call with parameters, a source language name, and a target language name, and outputs a localized template call. For example:

Input:

Output:

In Content Translation this will be the primary way to adapt templates. Unlike the current template adaptation in Content Translation, this will be precise and complete, rather than based on guesses.

In visual editing and in 2017-style wiki syntax editing, simply copying and pasting a template from wiki in another language will do the parameter translation automatically.

For plain wiki syntax editing, there should be a simple way to operate this service, for example a special page or a dialog box where an editor can paste the template and the source language, and get the template with translated parameters.

In both cases only the names of the template and the parameters will be translated. Translating the parameter values is discussed separately.

Nameless parameters
Nameless numbered parameters must continue working, of course.

A decision is needed about how will their names be localized.

Translating parameter values
In addition to making the templates’ functionality and design shared, some thought must be given to making the template parameter values shared, as well as not shared.

Some parameter values are the same in all languages by their nature. Some examples include an IPA pronunciation of a place’s native name (e.g. [dɛn ˈɦaːx] for The Hague), the year of foundation of a city, the chemical formula of a compound, etc. At least some of these should probably be stored in Wikidata and easily loadable in a template.

Some parameter values have to be translated or transliterated, for example people’s names, translations of country mottos, etc.

Global templates must make this possible, but in practice, these things are still often copied across wikis, and this must be taken into account as well.

Some parameter values can be reliably and predictably converted automatically, and the global templates infrastructure must support this. For example, number formats and digit characters are often different in Burmese, in languages of India, and in some other languages, but they can be reliably converted using simple software.

Valid and functional parameter values must be usable in multiple languages and must not be language-specific. For example, using “yes” and “no” as boolean values is too English-centric. This probably doesn’t require changes in the infrastructure, but mostly an agreement in the cross-wiki template development community on good practices for adaptation to all languages.

Text direction
Templates must adapt themselves to the text direction (ltr / rtl) of the wiki in which they are displayed.

It must be convenient to write a template in a direction-neutral way, with as little explicit right and left alignment as possible.

Bots
Many templates in many wikis are regularly edited by bots. This capability must be preserved.

This is not supposed to require any changes in the software infrastructure, but it is mentioned here for completeness because it’s an important use case.

Transitioning the templates from the large wikis to central storage
 וּמֵעֵבֶר לְשׁוּרַת הַבְּרוֹשִׁים עָבְרָה הָרַכֶּבֶת אֲבָל אֲנַחְנוּ רַק שָׁמַעְנוּ אוֹתָהּ, וְלֹא רָאִינוּ. וְכָל הַדְּבָרִים שֶׁדִּבָּרְנוּ בֵּינֵינוּ הִתְחִילוּ בַּמִּלִּים, „אֲבָל אֲנַחְנוּ”. —יהודה עמיחי The most popular source language for translation in Content Translation is English, by far. After it come Spanish, Russian, French, German, Catalan, Ukrainian, Italian, Chinese, and Portuguese. Because of this, it makes sense that the common templates in the editions of Wikipedia in these most common languages, especially those in English, are the ones that are the most important to make global for the benefit of all other languages.

Somewhat paradoxically, however, the editors in these largest languages are also the least interested in making them global:


 * The templates already work well for them and most people there don’t directly care about the convenience of translation to other languages.
 * Rewriting the templates so that the strings will be translatable may be time-consuming and may force them to learn some new template maintenance skills.
 * Making the templates suddenly used by many more projects may make it harder to achieve consensus about making future changes in how the templates work.
 * Editors from different major wikis will have to work on reaching consensus about merging some templates with similar functionality that already exist on their sites.

This is more of a consideration of practicality and community relations than a consideration of engineering, but it must be taken into account when making technical architectural decisions. Without doing proper preparation in this area, the whole project will fail.

As long as there are important common templates that are not global, Content Translation and other software that handles templates from different wikis in any way, will have to keep supporting them. If the infrastructure for global templates is created, and migration of existing templates proceeds in a good pace, developers may consider stopping developing and some day deprecating the code for non-global template adaptation.

The pace of migrating templates from large wikis to the central repository can be one of the success metrics for the project.

It must be possible to use templates completely in both wiki syntax and in visual editing
It’s obvious, but should be mentioned anyway: Wiki syntax editing is not going away soon, and it must be possible to keep editing template transclusions in pages as it is done now. This must not become more complicated.

However, Visual Editor is increasingly embraced by both experienced and new editors, so every feature of how templates work must work well in both visual and wiki syntax editing.

Other features related to templates
There are some features that deal with templates in core MediaWiki and its extensions. All of them must continue working, and may need updating for the global templates age.

Core MediaWiki
There should be on-wiki tools for showing at least basic analysis of templates’ and modules’ usage on pages: the number of transclusions and invocations grouped by wiki, and lists of pages that use the templates and the modules. The feature that shows which templates does a page transclude while it’s being edited must continue working with global templates.

The What links here page must keep working, and remain useful for global transclusions.

TemplateData

 * It is possible to translate template and parameter descriptions in TemplateData, and the translations are displayed in the user interface language in Visual Editor’s template insertion dialog. This is good and must be preserved. The translation interface could possibly be improved, but the beginning is good. Adding support for TemplateData in the Translate extension can be a solution for this, but there can also be other solutions.
 * Wikitext format parameter (inline, block, custom) must keep working. It must also be possible to customize them per wiki—some wikis may prefer to see a certain template written in wiki syntax as one line, and some may prefer multiple lines.

Citoid

 * Citoid has to be configured on every wiki separately using JSON files, such as Citoid-template-type-map.json. In the global templates age, it must become possible to share these files, so that the “” button would be available in all wikis and work identically everywhere by default. As with templates, there must be a way to override this default in each wiki where the community wants different behavior.

TemplateStyles

 * There must be a possibility to write Template Styles pages in the same central repository as templates. The central style must be loaded by default, and it must be possible to override it locally.

TemplateSandbox

 * Special:TemplateSandbox must keep working.
 * It must be possible to edit a template in the central repository and preview it in a page in the target wiki.

TemplateWizard

 * The current system uses a wiki’s standard search to find templates. The results are presented in a list that might need to be changed to make the global or local status visible.
 * TemplateWizard gets its information for templates from the TemplateData API, so as long as that keeps returning the same structure there shouldn’t be any issues, and i18n is already working.

Wikibase

 * Wikidata can be used to bring in some parameter values from a central repository to the wiki. This is used productively in Wikipedia in several languages, among them French, Hebrew, Basque, Russian, Catalan, Estonian, and some others, as well as in Commons, although the actual implementation may differ. This must continue working, of course. Unifying the way in which it is done across different wikis may become one of this project’s most significant impact areas.
 * It may also make it much easier to implement Wikidata Bridge, the project to allow editing template values from within wikis. The modifications to the templates themselves will have to be done only once in the global templates, and not in each wiki.

VisualEditor

 * VisualEditor obviously needs to be able to insert both global and local templates.
 * VisualEditor shows a link to the template description page in the template editing dialog. This link should point directly to the global template when it is used.

Development and deployment
 Quam multa fieri non posse prius quam sunt facta iudicantur —C. Plinius Secundus Developing the infrastructure for global templates and modules is a large and complex project. It must be divided into manageable parts to get done. Roughly, the multiple parts of this project should be developed in the following sequence:


 * 1) Translatable modules: Before making the modules shareable across wikis, the internationalization and localization framework for them should be developed. This will be immediately useful to modules on wikis that are already multilingual, most notably Commons and Wikidata. Some of them are currently translated using the “TNT” system, but this could be better.
 * 2) Global modules: Modules become shareable across wikis. This should happen before making templates shareable, because the modules’ infrastructure is less coupled to core MediaWiki, and they will be easier to migrate.
 * 3) Translatable templates: This is similar to Translatable modules above, and can reuse much of the same framework, but it will also need the capability to translate the names of the template itself and its parameters and some other features. See the sections on localization in the specification.
 * 4) Global templates: Complete the project with making the templates global.

The development of more advanced features, such as making templates semantic can and should come later, after they are shareable. If they become semantic before they are shareable, the code that describes them semantically will be forked on different wikis, like the templates themselves, which will make code reuse even harder than it is today.

Access to global templates and modules will be available from all the Wikimedia wikis. This includes editions of Wikipedia, Wiktionary, Wikivoyage, etc. in all the languages, as well as Commons, Wikidata, Meta, mediawiki.org, Wikitech, etc., as well as test wikis (test.wikipedia.org, etc.) This is similar to how images on Commons are available on all the wikis. Even though the global templates and modules will be available to the wikis, the wikis won’t be obliged to use them.

Making templates easily reusable on non-Wikimedia projects may be desirable, too. Even though it doesn’t directly benefit Wikimedia projects, it may make sense to consider making templates easily reusable not only across Wikimedia projects, but also on other MediaWiki sites. Doing this will probably require some more work, but it may contribute to better modularization, and this may eventually benefit Wikimedia projects, too. This is comparable to the capability of direct embedding of images from Commons on non-Wikimedia websites.

Imagine a world
Imagine a world in which every single human being can freely share in the sum of all knowledge and it’s actually a really easy thing to do because templates are global:

(Note: The “With global templates” column assumes that the infrastructure is deployed in all Wikimedia wikis, and that the most often used templates are moved to the central infrastructure.)

Status
 А мы всё молчим, Мы всё считаем и ждём; Мы всё поём о себе, О чём же нам петь ещё? —Борис Гребенщиков

As noted above, as of October 2019, this page is only an idea, and not a commitment to implement a project.

Similar ideas were suggested in the past. The oldest known suggestion to make templates reusable across wikis was raised in December 2004 in Bugzilla: Interwiki templates. Several other similar ideas were raised later, for example Phabricator. In February 2017 a similar proposal called Global-Wiki was closed as "consensus". Some of its components were implemented, such as global preferences, but not the templates.

The wish "Central global repository for templates, gadgets and Lua modules" was voted #3 at the Community Wishlist Survey 2015 and "Global gadgets" was voted #1 in Community Wishlist Survey 2016. Despite the community support, neither was implemented, because they weren’t appropriate for the Community Tech team, and they weren’t transferred to another team either.

The Platform Evolution project (2018) indicated some intentions to have support for global templates in the future. The page Platform Evolution/Recommendations discusses ideas for updating content modularity, and says:


 * ... “boxes” are an ideal focus area for creating modularity. They represent self contained features and also an opportunity to enable equitable sharing of user features across projects and languages be establishing a cross-project service to share templates. This project will also force us to consider how to handle content layout and structure separately from composable pieces content.

The closely related page Platform Evolution/Goals lists this as one of the goals:


 * Increase equity and power of contribution tools. We want to support the contribution of more content types of content, including media, in more interactive ways and across all projects. This means making some existing tools - like templates - available for consistent reuse across all projects and languages. It also means improving translation tools to remove silos of content. Finally, we also want to make it easy for contributors to create new cross-project, localizable content tools.

Other than these goals, however, there is no detailed plan for how such a feature will work. This page is an attempt to propose such a plan and listen to feedback from editors.

Useful links
Some relevant pages that discuss similar topics:


 * Platform Evolution/Goals
 * Platform Evolution/Recommendations
 * Multilingual Templates and Modules - An attempt to implement a similar feature using bots
 * meta:Community Wishlist Survey 2015/Results - Central Global Repository for Templates, Lua modules, and Gadgets came in as #3 in the Community Wishlist vote. Listed as “In development - Parsing team”, but not actually done.
 * meta:Which templates should be global? - an informal list made by various editors
 * Requests for comment/Shadow namespaces - a dormant RFC about one proposal for a technical implementation of such an infrastructure
 * - an existing rudimentary mechanism for transcluding content across projects. Considered inefficient and insecure, and disabled on Wikimedia projects.
 * meta:Global-Wiki - a similar proposal, with a wider scope. Was open for discussion for several years, and closed as "consensus". Some things in it were implemented, such as global user pages and preferences, but it also includes global templates, which are not yet done.