Global templates/Alternative solutions/tr

Wikimedia projelerinde ve  her projede yereldir ve bu kullanılabilirlik, bulunabilirlik, bilgi eşitliği, içerik yayılımı ve yapılandırılmış veri işleme için bir sorundur.

Sorun daha ayrıntılı ve  daha ayrıntılı olarak açıklanmaktadır.

Yukarıda belirtilen sayfalar da çözümü önermektedir: Bazı şablonların ve modüllerin genel yapılmasına izin ver, Commons,, , vb.

Sorunun gerçek olduğunu ve çözülmesi gerektiğini kabul ediyorsanız, ancak şablonları ve modülleri küresel hale getirmenin önerilen çözümü uygun değildir ve bunun yerine başka bir şey yapılması gerekir, bu sayfa tam size göre. Son yıllarda önerilen sorunu çözmenin diğer birkaç yolunu tartışıyor ve neden şablon ve modülleri küresel hale getirmek kadar iyi olmadıklarını açıklıyor.

Bu tekliflerden bazıları sorunu kapsamlı bir şekilde ele almıyor, bazıları ise birbiriyle ilişkili, ancak farklı sorunları ele alıyor. Önerilen diğer çözümlerin her biri bu sayfadaki bir bölümde tartışılmıştır. Hala bir şeye katılmıyorsanız, bu sayfayı düzenlemek veya tartışma sayfasında tartışmaktan çekinmeyin.

Bazı şablonları ve modülleri uzantılara dönüştürün
TL;DR: Bazı şablonlar ve modüller için bunu yapmak iyidir, ancak hepsi için bunu yapmak mümkün değildir.

Bazı şablonlar ve modüller uzantılara dönüştürülebilir. Bunun aşağıdaki avantajları olacaktır:
 * Uzantıların tüm vikilere yüklenmesi kolaydır.
 * Translatewiki'de uzantıların yerini belirlemek kolaydır.
 * Uzantıların kod inceleme, entegrasyon ve dağıtım için sağlam bir süreci vardır ve bu kararlılık, test ve güvenlik için iyidir.

Bununla birlikte, bu yaklaşımla ilgili birkaç sorun da vardır:
 * Programlama dilleri farklıdır: Şablonlar viki sözdizimindedir ve modüller Lua'da ve uzantılar PHP ve JavaScript'tedir. Bu nedenle, bir şablonu dönüştürmek, tam bir yeniden yazma gerektirir ve bu da önemli miktarda kaynak ve zaman gerektirir.
 * Nihai ürün daha sağlam olsa da, hatalar herhangi bir yeniden yazma işleminde olduğu gibi yol boyunca sokulabilir.
 * Çoğu şablon koruyucusu PHP, JavaScript ve Git hakkında bilgi sahibi değildir. Viki sözdizimini, Lua'yı ve viki sayfalarını düzenlemeyi tercih ederler. Yüzlerce şablon sahibi var ve deneyimlerini ve becerilerini atmak hem sosyal hem de pratikte doğru değil. İşlem şablon koruyucular ve wiki düzenleyicilerini yabancılaştıracaksa, uzantıları atar ve şablonları kullanmaya devam eder.
 * Mevcut Gerrit kodu inceleme ve dağıtım işlemi, özellikle şablonların hemen dağıtımına kıyasla son derece yavaştır.

Sorunlara rağmen, bazı şablonların ve modüllerin uzantılar olarak yeniden yazılması, özellikle karmaşık, kararlı, nadiren değiştirilen, birçok vikide açıkça yararlı olan ve yüksek güvenlik, kararlılık ve performans gereklilikleri. Özellikle, bu, uzantılarda nispeten kolayca paketlenebilen modüller için oldukça kolay olabilir. Uzantılarda Lua dosyalarını paketleme yeteneği zaten var, ancak nadiren kullanılıyor. Bununla birlikte, tüm şablonları uzantı olarak yeniden yazmak ne uygun ne de arzu edilir.

Mevcut şablonların parametrelerini birbirleriyle eşleştirin
TL;DR: Zaten yapılıyor ve biraz yardımcı oluyor, ancak ölçeklenebilir değil.

Şablonlar arasında projeler arasındaki uyumsuzluk sorununu gidermek için bazı öneriler şablonların parametrelerinin birbiriyle eşlenmesini önerir.

Bu çözüm gerçekten bir dereceye kadar uyumsuzluk sorununu hafifletebilir. İçerik Çeviri uzantısında, parametreleri eşlemek için TemplateData diğer adlarını kullanan bir saldırı olarak zaten yapılmıştır. Bu, Vikipedi madde çevirisini biraz daha sağlam hale getirdi. Bu, hangi parametrelerin eşlenmesi gerektiğini tahmin etmek için bazı makine öğrenme teknikleri kullanılarak İçerik Çevirisi'nde daha da geliştirilmektedir ( sayfasına bakın).

Ancak, bu gelişmelerle bile, bu asla tam bir çözüm olmayacaktır. Her şeyden önce, tüm sorunu ele almaz. Mevcut şablonlar arasındaki uyumsuzluk sorunun sadece bir yönüdür. Daha geniş bir problem, birçok projede, söz konusu şablonların gerekli olsalar bile, hiç bulunmamasıdır.

Ayrıca, parametre eşlemesinin her dil çiftindeki her şablon için manüel ve sürekli olarak sürdürülmesi gerekir ve bu ölçeklenmez. Bazı yaygın şablonlar için yapılmış olsa bile, yeni şablonlar yerel olarak oluşturulmaya devam edecek ve daha manüel haritalama gerektirecektir. Bunun sonu yok.

Küresel şablon teklifi, parametre adlarını yerelleştirmek için merkezi ve sağlam bir sistem önerir (“Parametreleri yerelleştirme” bölümünde). Bu, tüm parametrelerin, açıkça yerelleştirilmemiş olsalar bile, editörler adına herhangi bir çaba göstermeden tüm vikilerde kullanılabileceğini garanti edecektir.

Şablon oluşturma için viki sözdizimini geliştirin
TL;DR: Farklı sorunları çözer, ancak söz konusu olanı çözmez.

Şablonlar için viki sözdizimi zor, karmaşık, karmaşık ve göz korkutucu. Birçok şablonun kaynak kodu, süslü parantezler, boru karakterleri, eşit işaretler, hash işaretleri vb. ile aşırı yüklenmiştir. Ayrıştırma ekibi bu alanda birkaç iyi teklifte bulunmuştur; bir örnek için Wikimania 2019'dan Gelişen vikimetin: artımlılığı kucaklamak sunumuna bakın.

Bu geçerli bir sorundur ve çözülmesi gerekir, ancak Küresel şablonlar teklifinin ele almaya çalıştığı sorundan farklıdır. “Evrimleşen vikimetin” projesi, şablon dilinin kendisini geliştirmektir, “Küresel şablonlar” projesi ise şablonların nasıl saklandığı ve dağıtıldığı ve editörlere nasıl keşfedilebileceği ile ilgilidir. Gelişen vikimetin, şablonun kendisini geliştirmeyi kolaylaştırıyor ve Global şablonlar, herhangi bir vikide şablon kullanmaya başlamak için gereken adım sayısını sıfıra indirmeye çalışıyor.

İki proje birbiriyle çelişmez ve birbirlerinin başarılı olmasına yardımcı olabilir. Bu, başka bir Wikimania 2019 sunumu tarafından onaylandı, Şablonların çalışma şeklini tamamen değiştirelim, her iki sorunu da ayrı ayrı gösteriyor. Şablonları küresel olarak depolamak mümkün olursa, bir şablonun kaynağında, Gelişen vikimetin girişiminin bir parçası olarak yapılması gereken değişikliklerin yalnızca bir kez yapılması gerekir. Şablonlar küresel olmadığı sürece, her şablon için birden çok kez yapılması gerekir.

Ayrıca, gelişen vikimetinin kendi başına, sadece şablon ve modül geliştiricileri üzerinde doğrudan etkisi olacağı unutulmamalıdır. Bu, onların daha verimli çalışmasını sağlar ve daha iyi ve daha kullanışlı şablonlar geliştirmelerine yardımcı olabilir. Bu arzu edilir, ancak daha az görülebilir. Şablonları küresel hale getirmek ise, yalnızca geliştiriciler üzerinde değil, tüm vikilerdeki tüm editörler ve okuyucular üzerinde doğrudan, pozitif ve görünür bir etkiye sahip olacaktır.

Yapısal verileri viki sözdizimine entegre etme
TL;DR: İyi bir uzun vadeli stratejik hedeftir, ancak şimdilik çok ileri getirilmiştir ve küresel bir şablon deposu, bunu uygulamak için gerekli bir adım olacaktır.

“Evrimleşen vikimetin” ,le benzeyen bir başka teklif, viki sözdizimini, mevcut, çoğunlukla yapısız wikitext ve Vikiveri gibi tamamen yapılandırılmış bir depolama alanı arasında orta zemin olarak veri için daha yapılandırılmış hale getirmektir. User:Tgr (WMF)/structured article data sayfasında açıklanmaktadır.

Bu geçerli bir tekliftir ve bazı toplulukların bilgileri sayfalarda yerel olarak kontrol etme isteği ile yapılandırılmış bilgiyi yazılımla anlamsal olarak işleme ihtiyacı arasındaki dengeyi ele alır. Ancak, "Evrimleşen vikimetin" önerisi ve bu sayfada açıklanan diğer bazı teklifler gibi, son derece teknik şablonları korumak için gerekli beceriye sahip olmayan vikilerin ihtiyaçlarını karşılamamaktadır.

Bu teklif Küresel şablonlar teklifiyle çelişmez ve her ikisi de uygulanabilir. Bununla birlikte, bu teklif aynı zamanda şablonlar küresel hale getirilmeden uygulanırsa, en azından öngörülebilir gelecekte büyük olasılıkla yalnızca en büyük vikilerde kullanılacaktır.

JavaScript'te modül yazmaya izin verin
TL;DR: Farklı sorunları çözer, ancak söz konusu olanı çözmez.

Scribunto modüllerinin Lua dışındaki dillerde, özellikle JavaScript'te yazılmasına izin vermek için birkaç teklif var. Bir örnek için yukarıda belirtilen sunumunda ve 18'e Şablonların Çalışma Şeklini Tamamen Değiştirelim! belgesine bakın.

Bu geçerli bir teklif. JavaScript'i Lua'dan daha fazla kişi biliyor, bu nedenle modül geliştirmeyi daha fazla kişi için erişilebilir hale getirmeli ve modül geliştiricilerinin sayısı artabilir.

Ancak yine de, bu sadece üye olarak geliştiricileri olan toplulukları etkileyecektir. Diğer birçok dilde viki topluluklarında hiç geliştirici yoktur, bu nedenle bu özelliğin meyvelerinden zevk almazlar.

Şablonların bir projeden diğerine daha kolay kopyalanması için bir paket yönetim sistemi oluşturun
TL;DR: Kullanıcılar için uygun bir şey gibi görünüyor, ancak aslında ölçeklenebilir değil ve sadece işleri karmaşıklaştıracak.

Şu anda, bir şablonu bir vikiden diğerine kopyalamak için düzenleyicinin şablonu, bazı basamaklı sayfalar da dahil olmak üzere kaynak vikiden bir viki sayfası olarak dışa aktarması, hedef vikiye aktarması, insan tarafından okunabilir dizeler için viki sözdizimini araması gerekir. Bunları çevirin ve kalan hataları düzeltin. Sonuç gerektiği gibi çalışabilir, ancak kaynak şablonun bir çatalı olacaktır. Bu son derece manüel ve zor bir süreçtir ve sonuçlar mükemmel olmaktan uzaktır.

Bazen şablonlar ve modüller için paket yönetimi gibi bir şey yapma önerileri vardır, böylece kopyalama daha kolay hale gelir. Ancak, bu da çok kısmi bir çözüm olacaktır. İyi bir şekilde yapılsa bile, her şablon için bu kopyalama işleminin yürütülmesini gerektirirken, küresel bir havuz tüm şablonu sıfır ekstra adımlarla hemen kullanılabilir hale getirecektir. However, this will also be a very partial solution. Even if it is done well, it will require running this copying process for each template, whereas a global repository will make all template immediately available with zero extra steps. Böyle bir paket geliştirmek, sayfada hakkında açıklanan araçlara benzer bir şey gerektirir. Eğer yapılırsa, sonuna kadar gitmek ve küresel bir depo yapmak daha iyidir. This cannot scale for the thousands of templates that have to be shared.

Küçük araçları küresel yapın
TL;DR: Farklı sorunları çözer, ancak söz konusu olanı çözmez.

Küçük araçlar, vikide tarafından geliştirilen ve kullanıcı tercihleri aracılığıyla bunları kolayca etkinleştirip devre dışı bırakacak şekilde paketlenmiş JavaScript parçalarıdır.

Şablonlar gibi, bunlar açıklandığı gibi Wikimedia yazılımının “Yerel özelleştirmeler” tarafına aittir. Küçük araçlara ilgili sorunlar şablonlardaki soruna benzer: bir vikiden diğerine kolayca taşınamazlar ve ünlü HotCat küçük aracı tarafından kullanılanlar gibi vikiler üzerinde çalışmasını sağlamak için mevcut hackler bile kusurludur. Ek olarak, uzantılar için olduğu gibi, yerelleştirme için uygun ve tekdüze bir çerçeveye sahip değildirler.

Bu nedenle, araçları küresel hale getirmek de mümkün olmalıdır. Aslında, “Küresel küçük araçları” 2016 Topluluk İstek Listesi Anketi de 1 numarada yer aldı, ancak Topluluk Teknik ekibi için çok büyük olduğu için uygulanmadı.

Ancak, küresel küçük araçlar için teknoloji, küresel şablonlar için olan teknolojiden oldukça farklı olacaktır. Küçük araçlar yalnızca ön uç bileşenleridir ve bazen sayfa içeriğini etkilese de, çoğunlukla kullanıcı arayüzünü değiştirirler. Küçük araçların işlevselliği ayrıştırıcı ve MediaWiki arka ucundan neredeyse hiç etkilenmez (belki ResourceLoader hariç).

Şablonlar farklıdır: içerikte güçlü bir şekilde oluşturulmuş ve sunucu tarafında oluşturulmuştur, bu nedenle çekirdek platform ve özellikle ayrıştırıcı ile güçlü bir şekilde birleştirilirler. Buna ek olarak, küçük araçlar öncelikle vikilerin güç kullanıcıları tarafından kullanılırken, şablonların kodu tüm editörler tarafından görülür ve şablonların çıktısı tüm okuyucular tarafından görülür, bu nedenle şablonların etkisi çok daha büyüktür.

Küresel şablonlar ve küçük araçlar için genel olabilecek en alakalı şey, yerelleştirmelerini depolamak ve yönetmektir, ancak bu bile kesin değildir. Kullanıcı arabirimi dizelerinin (mesajlarının) yerelleştirilmesi benzer olabilir, ancak şablonların şablon adının ve parametrelerin yerelleştirilmesi gibi ek ihtiyaçları vardır.

Dolayısıyla evet — küçük araçların, şablonların ve modüllerin tümü küresel olmakla birlikte, küçük araçlarını çoğunlukla modüllerden ve şablonlardan ayrı olarak ele almak mantıklıdır.

Merkezi bir depodan şablon kopyalayan bir bot oluşturun
TL;DR: Aynı sorunu çözer, ancak mükemmel değildir ve projenin yaratıcıları bunu kabul eder.

This is what the Multilingual Templates and Modules proposal is about. It is a reasonable approach given the current MediaWiki platform, but it has some disadvantages. In fact, that project’s own description page admits that it is not the best approach.

The bot approach requires several manual steps for each template in each language. It does not have full-fledged translation tools for localizing the messages, and requires editing JSON files instead.

Finally, it does not truly make templates available in all languages. This system still requires the editors to opt in for each template in each wiki. This opt-in process is somewhat easier than the fully manual template importing process, but it still requires several steps for each template.

So yes, it is probably still the best approach given the state of MediaWiki technology in late 2019. It can serve as a testing ground and a transition phase towards true support for global templates and modules in the software platform. But it is not perfect.

Update the frontend development library
TL;DR: It resolves different problems, but not the one in question.

In 2019 (or even earlier), serious discussions began about upgrading MediaWiki’s frontend development library from a mix of jQuery, ResourceLoader, and OOJS UI to something new (see ). This has also been presented as a possible solution for sharing structured frontend software between projects. While theoretically possible, in practice it is probably more applicable to gadgets than to templates. Completely moving templates to JavaScript will mean giving up on wikitext, which is not really feasible for the community in the foreseeable future.

Switching to a new frontend development library can be an opportunity to improve the interface between JavaScript code and templates, but JavaScript, even in a modernized form, cannot replace wikitext completely. A global templates repository is a proposal for new storage of wikitext (and Lua).

Wikilambda or Abstract Wikipedia
TL;DR: 'This project has bigger goals. It includes a global code repository, which is essentially the same as Global templates. The Global templates proposal can be implemented as part of it.'

The Wikilambda proposal, also known as “Abstract Wikipedia” or “Multilingual Wikipedia” is an idea to make a global repository of functions that automatically generate prose for Wikipedia articles in multiple languages from a central set of data and abstract descriptions of topics. Of all the different alternative proposals on this page, this one is perhaps the closest to the Global templates proposals, but it is not a replacement for it.

The main functionality that Wikilambda suggests is considerably more advanced in its capabilities to generate text (prose) in natural language than the current technology for modules and templates. However, its central functions repository is essentially the same thing that is needed for Global templates and modules. The Wikilambda task list as of May 2020 even explicitly includes “A cross-wiki repository to share templates and modules between the WMF projects” as one of the first deliverables, although it is much less detailed in how will it actually work than the.

So, both Wikilambda and Global templates will need a new wiki that will serve as a repository of code: templates, modules, and text generation functions. Both will also need a modernized mechanism for managing dependencies and change propagation across wikis, also known as “Dependency engine”. But the eventual goals of Wikilambda and Global templates are distinct, and they will complement each other. Because of their familiarity to the editors, modules and templates should be made global and available to wiki editors first, and Wikilambda prose rendering functions should follow.

Conclusion
There are many ways in which the technology around templates and modules could be improved. Some of them will clearly be beneficial to Wikimedia projects in various, and they should be carried out. However, none of them fully or even partially resolves the problem described in : the need to have features that are useful to multiple wikis and implemented as templates easily and immediately available to everyone who needs them, while preserving the ease and the agility of template development and deployment. Only the implementation of Global templates will resolve this problem comprehensively.