La documentation pour ce module peut être créée à Module:traduction/doc

local m_bases = require("Module:bases")
local m_params = require("Module:paramètres")
local m_langs = require("Module:âyângâködörö")

local p = {}

local cats = {}
-- Shows categories when true.
-- For debugging purposes, deactivate *before* saving.
local DEBUG = false

--- Returns the category with the given name.
--- @param categoryName string The category’s name.
--- @param sortingKey string The sorting key.
--- @param asLink boolean Whether the category should be a link or not.
--- @return string The category.
local function getCategory(categoryName, sortingKey, asLink)
  if DEBUG then
    if sortingKey then
      return m_bases.fait_categorie(categoryName, nil, true) .. "(" .. sortingKey .. ")"
    else
      return m_bases.fait_categorie(categoryName, nil, true)
    end
  else
    return m_bases.fait_categorie_contenu(categoryName, sortingKey, asLink)
  end
end

--- Formats a language name.
--- @param langName string The language’s name.
--- @param langCode string The language’s code.
--- @return string The formated language name.
local function formatLanguageName(langName, langCode)
  if langName and langCode then
    return mw.ustring.format('<span class="trad-%s">%s</span>', langCode, langName)
  else
    return ""
  end
end

--- Function for the template {{T}}.
---  frame.args[1] (string): Language code.
---  frame.args[2] (string): If equal to "trier", tells that this translation has to be sorted by users.
--- @return string Template’s code.
function p.templateT(frame)
  local args = m_params.process(frame:getParent().args, {
    [1] = {},
    [2] = {},
  })
  local langCode = args[1]
  local sort = args[2] == "trier"

  -- Language code is mandatory.
  if not langCode then
    return "[[WT:Liste des langues|Langue à préciser]]"
        .. getCategory("Wiktionary:Âgbïänngö-yângâ T sans langue précisée")
  end

  local langName = m_langs.get_nom(langCode)
  local formatedText
  local category

  if langName then
    formatedText = m_bases.ucfirst(langName)
    local categoryNamePrefix = sort and "Wiktionary:Âgbïänngö-yângâ (leke) na " or "Âgbïänngö-yângâ na "
    category = getCategory(categoryNamePrefix .. m_bases.ucfirst(langName))

    -- Undefined language code, categorize for easy checking.
  else
    formatedText = mw.ustring.format('<i><span style="color:red">%s</span></i>[[WT:Liste des langues|*]]', langCode)
    category = getCategory("Wiktionary:Âgbïänngö-yângâ G avec code langue non défini", langCode).. getCategory("Wiktionary:Âgbïänngö-yângâ G avec code langue non défini:"..langCode, langCode)
  end

  return formatLanguageName(formatedText, langCode) .. category
end

--- Generates the link pointing to another Wiktionary.
--- @param langCode string Word’s language code.
--- @param word string The word to link to.
--- @param status string The status (either "existe", "inconnu", "absent", "" or nil).
--- @return string The outgoing link.
local function generateOutgoingLink(langCode, word, status)
  local displayedText = ""

  -- Link destination
  local wikiLangCode = m_langs.get_lien_Wikimedia(langCode) or langCode
  word = mw.ustring.gsub(word, "[’ʼ]", "'") -- apostrophes dactylographique et modificative
  local destination = mw.ustring.format(":%s:%s", wikiLangCode, word)

  -- No status or unknown, do not display anything.
  if not status then
    displayedText = ""
    destination = nil

    -- No matching wiki
  elseif status == "nowikt" then
    displayedText = '<span class="trad-nowikt">(*)</span>'
    destination = "Wiktionary:Pas de wiktionnaire dans cette langue"
  elseif status == "existe" then
    displayedText = mw.ustring.format('<span class="trad-existe">(%s)</span>', wikiLangCode)
  elseif status == "inconnu" then
    displayedText = mw.ustring.format('<span class="trad-inconnu">(%s)</span>', wikiLangCode)
  elseif status == "absent" then
    displayedText = mw.ustring.format('<span class="trad-absent">(%s)</span>', wikiLangCode)
  end

  return destination
      and mw.ustring.format('<span class="trad-exposant">[[%s|%s]]</span>', destination, displayedText)
      or ""
end

--- Formats the given text as traditional script (mainly for Chinese).
--- @param langCode string The language code.
--- @param word string The word to format.
--- @return string The formated word.
local function formatTraditionalScript(langCode, word)
  if not word then
    return nil
  end

  -- Traditional Chinese is better displayed by browsers when using the code zh-Hant.
  if langCode == "zh" then
    langCode = "zh-Hant"
  elseif langCode == "ko" then
    langCode = "ko-Hani"
  end
  -- Mark the text as “traditional” for gadgets.
  local shownText = mw.ustring.format('<span class="ecrit_tradi">%s</span>', word)

  return m_bases.lien_modele(word, langCode, nil, shownText, true)
end

--- Formats a transcription.
--- @param langCode string Transcription’s language code.
--- @param transcription string Text to format.
--- @param traditionalLangCode string Optional language code for traditional scripts.
--- @return string The formated transcription.
local function formatTranscription(langCode, transcription, traditionalLangCode)
  if not transcription or not langCode then
    return nil
  end

  local lang = traditionalLangCode or langCode .. "-Latn"
  return m_bases.balise_langue(transcription, lang)
end

--- Returns the full gender label for the given code.
--- @param gender string Gender code.
--- @return string The full gender label.
local function formatGender(gender)
  if not gender then
    return nil
  end

  -- List of authorized genders and associated numbers
  local gendersList = {
    ["m"] = "linô kôlï", -- masculin
    ["lk"] = "linô kôlï", -- masculin
    ["f"] = "linô gâlï", --"féminin",
    ["lg"] = "linô gâlï", --"féminin",
    ["n"] = "linô wâwa", -- neutre,
    ["lw"] = "linô wâwa", -- neutre,
    ["c"] = "linô kôlï wa gâlï", -- "commun",
    ["s"] = "singulier",
    ["lks"] = "lîno kötï sêmîngi",
    ["lgs"] = "lîno gâlï sêmîngi",
    ["fp"]  = "lîno gâlï sêmîngi",
    ["mp"] = "lîno kötï sêmîngi",    
    ["p"] = "lîno sêmîngi",
    ["ls"] = "lîno sêmîngi",
    ["d"] = "duel",
    ["lkg"] = "linô kôlï wa gâlï", -- "masculin et féminin identiques",
    ["mf"] = "linô kôlï wa gâlï", -- "masculin et féminin identiques",
    ["mfp"] = "masculin et féminin pluriel",
    ["np"] = "neutre pluriel",
    ["ma"] = "masculin animé",
    ["mi"] = "masculin inanimé",
    ["fa"] = "féminin animé",
    ["fi"] = "féminin inanimé",
    ["na"] = "neutre animé",
    ["ni"] = "neutre inanimé",
    ["pf"] = "pf",    
    ["impf"] = "impf",        
  }

  if gendersList[gender] then
    return mw.ustring.format("''%s''", gendersList[gender])
  else
    table.insert(cats, getCategory("Wiktionary:Âgbïänngö-yângâ avec genre inexistant", gender))
    table.insert(cats, getCategory("Wiktionary:Âgbïänngö-yângâ avec genre inexistant:"..gender, gender))
    return ""
  end
end

--- Generates the code for the templates {{trad}}, {{trad+}}, {{trad-}} and {{trad--}}.
--- @param status string Status of the interwiki link.
--- @param langCode string Translation’s language code.
--- @param word string The translation.
--- @param gender string Word’s gender.
--- @param alternativeText string Alternative text to display instead of the word.
--- @param transcription string Word’s transcription.
--- @param traditionalLangCode string Language code for traditional script if any (for Chinese and Korean).
--- @param traditionalTerm string Word for traditional script (for Chinese and Korean).
--- @return string Template’s code.
function p._templateTrad(status, langCode, word, gender, alternativeText, transcription, traditionalLangCode, traditionalTerm)
  if not langCode then
    table.insert(cats, getCategory("Wiktionary:Âgbïänngö-yângâ sans langue précisée"))
    return '<span style="color:red;">[[WT:Liste des langues|Langue à préciser]] (paramètre 1)</span>'
  elseif m_langs.get_nom(langCode) == nil then
    table.insert(cats, getCategory("Wiktionary:Âgbïänngö-yângâ trad avec code langue non défini"))
  end

  local localLink = ""
  local superscriptText = ""

  if not word then
    table.insert(cats, getCategory("Wiktionary:Âgbïänngö-yângâ sans traduction précisée"))
    localLink = '<span style="color:red">pas de traduction précisée (paramètre 2)</span>'
  else
    localLink = m_bases.lien_modele(word, langCode, nil, alternativeText, true)
    superscriptText = generateOutgoingLink(langCode, word, status)
  end

  local formatedTraditionalScript = traditionalTerm and formatTraditionalScript(langCode, traditionalTerm) or nil
  local formatedTranscription = transcription and formatTranscription(langCode, transcription, traditionalLangCode) or nil
  local formatedGender = formatGender(gender)

  local finalText = localLink

  if superscriptText then
    finalText = finalText .. "&nbsp;" .. superscriptText
  end
  if formatedTraditionalScript then
    finalText = finalText .. " (" .. formatedTraditionalScript .. ")"
  end
  if formatedTranscription then
    finalText = finalText .. " " .. formatedTranscription
  end
  if formatedGender then
    finalText = finalText .. " " .. formatedGender
  end

  return finalText
end

--- Generates the code for the templates {{trad}}, {{trad+}}, {{trad-}} and {{trad--}}.
---  frame.args["statut"] (string): Status of the interwiki link.
---  parent frame.args[1] (string): Translation’s language code.
---  parent frame.args[2] (string): The translation.
---  parent frame.args[3] (string): Word’s gender.
---  parent frame.args["dif"] (string): Alternative text to display instead of the word.
---  parent frame.args["tr"]/parent frame.args["R"] (string): Word’s transcription.
---  parent frame.args["lang-tr"]/parent frame.args["lang-R"] (string): Language code for traditional script if any (for Chinese and Korean).
---  parent frame.args["tradi"] (string): Word for traditional script (for Chinese and Korean).
--- @return string Template’s code.
function p.templateTrad(frame)
  local status = m_params.process(frame.args, {
    ["statut"] = { enum = { "nowikt", "existe", "inconnu", "absent", nil } },
  })["statut"]

  local args = m_params.process(frame:getParent().args, {
    [1] = {},
    [2] = {},
    [3] = {},
    ["lang-tr"] = {},
    ["lang-R"] = { alias_of = "lang-tr" },
    ["tr"] = {},
    ["R"] = { alias_of = "tr" },
    ["dif"] = {},
    ["tradi"] = {},
  })
  local langCode = args[1]
  local traditionalLangCode = args["lang-tr"]

  local word = args[2]
  local alternativeText = args["dif"]
  local traditionalTerm = args["tradi"]
  local transcription = args["tr"]

  local gender = args[3]

  local wikicode = p._templateTrad(status, langCode, word, gender, alternativeText, transcription, traditionalLangCode, traditionalTerm)
  return wikicode .. table.concat(cats)
end

return p