1 --- AceDBOptions-3.0 provides a universal AceConfig options screen for managing AceDB-3.0 profiles.
3 -- @name AceDBOptions-3.0
4 -- @release $Id: AceDBOptions-3.0.lua 1140 2016-07-03 07:53:29Z nevcairiel $
5 local ACEDBO_MAJOR, ACEDBO_MINOR = "AceDBOptions-3.0", 15
6 local AceDBOptions, oldminor = LibStub:NewLibrary(ACEDBO_MAJOR, ACEDBO_MINOR)
8 if not AceDBOptions then return end -- No upgrade needed
11 local pairs, next = pairs, next
14 local UnitClass = UnitClass
16 -- Global vars/functions that we don't upvalue since they might get hooked, or upgraded
17 -- List them here for Mikk's FindGlobals script
18 -- GLOBALS: NORMAL_FONT_COLOR_CODE, FONT_COLOR_CODE_CLOSE
20 AceDBOptions.optionTables = AceDBOptions.optionTables or {}
21 AceDBOptions.handlers = AceDBOptions.handlers or {}
24 Localization of AceDBOptions-3.0
28 choose = "Existing Profiles",
29 choose_desc = "You can either create a new profile by entering a name in the editbox, or choose one of the already existing profiles.",
30 choose_sub = "Select one of your currently available profiles.",
32 copy_desc = "Copy the settings from one existing profile into the currently active profile.",
33 current = "Current Profile:",
35 delete = "Delete a Profile",
36 delete_confirm = "Are you sure you want to delete the selected profile?",
37 delete_desc = "Delete existing and unused profiles from the database to save space, and cleanup the SavedVariables file.",
38 delete_sub = "Deletes a profile from the database.",
39 intro = "You can change the active database profile, so you can have different settings for every character.",
41 new_sub = "Create a new empty profile.",
42 profiles = "Profiles",
43 profiles_sub = "Manage Profiles",
44 reset = "Reset Profile",
45 reset_desc = "Reset the current profile back to its default values, in case your configuration is broken, or you simply want to start over.",
46 reset_sub = "Reset the current profile to the default",
49 local LOCALE = GetLocale()
50 if LOCALE == "deDE" then
51 L["choose"] = "Vorhandene Profile"
52 L["choose_desc"] = "Du kannst ein neues Profil erstellen, indem du einen neuen Namen in der Eingabebox 'Neu' eingibst, oder wähle eines der vorhandenen Profile aus."
53 L["choose_sub"] = "Wählt ein bereits vorhandenes Profil aus."
54 L["copy"] = "Kopieren von..."
55 L["copy_desc"] = "Kopiere die Einstellungen von einem vorhandenen Profil in das aktive Profil."
56 L["current"] = "Aktuelles Profil:"
57 L["default"] = "Standard"
58 L["delete"] = "Profil löschen"
59 L["delete_confirm"] = "Willst du das ausgewählte Profil wirklich löschen?"
60 L["delete_desc"] = "Lösche vorhandene oder unbenutzte Profile aus der Datenbank, um Platz zu sparen und die SavedVariables-Datei 'sauber' zu halten."
61 L["delete_sub"] = "Löscht ein Profil aus der Datenbank."
62 L["intro"] = "Hier kannst du das aktive Datenbankprofil ändern, damit du verschiedene Einstellungen für jeden Charakter erstellen kannst, wodurch eine sehr flexible Konfiguration möglich wird."
64 L["new_sub"] = "Ein neues Profil erstellen."
65 L["profiles"] = "Profile"
66 L["profiles_sub"] = "Profile verwalten"
67 L["reset"] = "Profil zurücksetzen"
68 L["reset_desc"] = "Setzt das momentane Profil auf Standardwerte zurück, für den Fall, dass mit der Konfiguration etwas schief lief oder weil du einfach neu starten willst."
69 L["reset_sub"] = "Das aktuelle Profil auf Standard zurücksetzen."
70 elseif LOCALE == "frFR" then
71 L["choose"] = "Profils existants"
72 L["choose_desc"] = "Vous pouvez créer un nouveau profil en entrant un nouveau nom dans la boîte de saisie, ou en choississant un des profils déjà existants."
73 L["choose_sub"] = "Permet de choisir un des profils déjà disponibles."
74 L["copy"] = "Copier à partir de"
75 L["copy_desc"] = "Copie les paramètres d'un profil déjà existant dans le profil actuellement actif."
76 L["current"] = "Profil actuel :"
77 L["default"] = "Défaut"
78 L["delete"] = "Supprimer un profil"
79 L["delete_confirm"] = "Etes-vous sûr de vouloir supprimer le profil sélectionné ?"
80 L["delete_desc"] = "Supprime les profils existants inutilisés de la base de données afin de gagner de la place et de nettoyer le fichier SavedVariables."
81 L["delete_sub"] = "Supprime un profil de la base de données."
82 L["intro"] = "Vous pouvez changer le profil actuel afin d'avoir des paramètres différents pour chaque personnage, permettant ainsi d'avoir une configuration très flexible."
84 L["new_sub"] = "Créée un nouveau profil vierge."
85 L["profiles"] = "Profils"
86 L["profiles_sub"] = "Gestion des profils"
87 L["reset"] = "Réinitialiser le profil"
88 L["reset_desc"] = "Réinitialise le profil actuel au cas où votre configuration est corrompue ou si vous voulez tout simplement faire table rase."
89 L["reset_sub"] = "Réinitialise le profil actuel avec les paramètres par défaut."
90 elseif LOCALE == "koKR" then
91 L["choose"] = "저장 중인 프로필"
92 L["choose_desc"] = "입력창에 새로운 이름을 입력하거나 저장 중인 프로필 중 하나를 선택하여 새로운 프로필을 만들 수 있습니다."
93 L["choose_sub"] = "현재 이용할 수 있는 프로필 중 하나를 선택합니다."
95 L["copy_desc"] = "현재 사용 중인 프로필에 선택한 프로필의 설정을 복사합니다."
96 L["current"] = "현재 프로필:"
98 L["delete"] = "프로필 삭제"
99 L["delete_confirm"] = "정말로 선택한 프로필을 삭제할까요?"
100 L["delete_desc"] = "저장 공간 절약과 SavedVariables 파일의 정리를 위해 데이터베이스에서 사용하지 않는 프로필을 삭제하세요."
101 L["delete_sub"] = "데이터베이스의 프로필을 삭제합니다."
102 L["intro"] = "활성 데이터베이스 프로필을 변경할 수 있고, 각 캐릭터 별로 다른 설정을 할 수 있습니다."
104 L["new_sub"] = "새로운 프로필을 만듭니다."
105 L["profiles"] = "프로필"
106 L["profiles_sub"] = "프로필 관리"
107 L["reset"] = "프로필 초기화"
108 L["reset_desc"] = "설정이 깨졌거나 처음부터 다시 설정을 원하는 경우, 현재 프로필을 기본값으로 초기화하세요."
109 L["reset_sub"] = "현재 프로필을 기본값으로 초기화합니다"
110 elseif LOCALE == "esES" or LOCALE == "esMX" then
111 L["choose"] = "Perfiles existentes"
112 L["choose_desc"] = "Puedes crear un nuevo perfil introduciendo un nombre en el recuadro o puedes seleccionar un perfil de los ya existentes."
113 L["choose_sub"] = "Selecciona uno de los perfiles disponibles."
114 L["copy"] = "Copiar de"
115 L["copy_desc"] = "Copia los ajustes de un perfil existente al perfil actual."
116 L["current"] = "Perfil actual:"
117 L["default"] = "Por defecto"
118 L["delete"] = "Borrar un Perfil"
119 L["delete_confirm"] = "¿Estas seguro que quieres borrar el perfil seleccionado?"
120 L["delete_desc"] = "Borra los perfiles existentes y sin uso de la base de datos para ganar espacio y limpiar el archivo SavedVariables."
121 L["delete_sub"] = "Borra un perfil de la base de datos."
122 L["intro"] = "Puedes cambiar el perfil activo de tal manera que cada personaje tenga diferentes configuraciones."
124 L["new_sub"] = "Crear un nuevo perfil vacio."
125 L["profiles"] = "Perfiles"
126 L["profiles_sub"] = "Manejar Perfiles"
127 L["reset"] = "Reiniciar Perfil"
128 L["reset_desc"] = "Reinicia el perfil actual a los valores por defectos, en caso de que se haya estropeado la configuración o quieras volver a empezar de nuevo."
129 L["reset_sub"] = "Reinicar el perfil actual al de por defecto"
130 elseif LOCALE == "zhTW" then
131 L["choose"] = "現有的設定檔"
132 L["choose_desc"] = "您可以在文字方塊內輸入名字以建立新的設定檔,或是選擇一個現有的設定檔使用。"
133 L["choose_sub"] = "從當前可用的設定檔裡面選擇一個。"
135 L["copy_desc"] = "從一個現有的設定檔,將設定複製到現在使用中的設定檔。"
136 L["current"] = "目前設定檔:"
138 L["delete"] = "刪除一個設定檔"
139 L["delete_confirm"] = "確定要刪除所選擇的設定檔嗎?"
140 L["delete_desc"] = "從資料庫裡刪除不再使用的設定檔,以節省空間,並且清理 SavedVariables 檔案。"
141 L["delete_sub"] = "從資料庫裡刪除一個設定檔。"
142 L["intro"] = "您可以從資料庫中選擇一個設定檔來使用,如此就可以讓每個角色使用不同的設定。"
144 L["new_sub"] = "新建一個空的設定檔。"
145 L["profiles"] = "設定檔"
146 L["profiles_sub"] = "管理設定檔"
148 L["reset_desc"] = "將現用的設定檔重置為預設值;用於設定檔損壞,或者單純想要重來的情況。"
149 L["reset_sub"] = "將目前的設定檔重置為預設值"
150 elseif LOCALE == "zhCN" then
151 L["choose"] = "现有的配置文件"
152 L["choose_desc"] = "你可以通过在文本框内输入一个名字创立一个新的配置文件,也可以选择一个已经存在的配置文件。"
153 L["choose_sub"] = "从当前可用的配置文件里面选择一个。"
155 L["copy_desc"] = "从当前某个已保存的配置文件复制到当前正使用的配置文件。"
156 L["current"] = "当前配置文件:"
158 L["delete"] = "删除一个配置文件"
159 L["delete_confirm"] = "你确定要删除所选择的配置文件么?"
160 L["delete_desc"] = "从数据库里删除不再使用的配置文件,以节省空间,并且清理SavedVariables文件。"
161 L["delete_sub"] = "从数据库里删除一个配置文件。"
162 L["intro"] = "你可以选择一个活动的数据配置文件,这样你的每个角色就可以拥有不同的设置值,可以给你的插件配置带来极大的灵活性。"
164 L["new_sub"] = "新建一个空的配置文件。"
165 L["profiles"] = "配置文件"
166 L["profiles_sub"] = "管理配置文件"
167 L["reset"] = "重置配置文件"
168 L["reset_desc"] = "将当前的配置文件恢复到它的默认值,用于你的配置文件损坏,或者你只是想重来的情况。"
169 L["reset_sub"] = "将当前的配置文件恢复为默认值"
170 elseif LOCALE == "ruRU" then
171 L["choose"] = "Существующие профили"
172 L["choose_desc"] = "Вы можете создать новый профиль, введя название в поле ввода, или выбрать один из уже существующих профилей."
173 L["choose_sub"] = "Выбор одиного из уже доступных профилей"
174 L["copy"] = "Скопировать из"
175 L["copy_desc"] = "Скопировать настройки из выбранного профиля в активный."
176 L["current"] = "Текущий профиль:"
177 L["default"] = "По умолчанию"
178 L["delete"] = "Удалить профиль"
179 L["delete_confirm"] = "Вы уверены, что вы хотите удалить выбранный профиль?"
180 L["delete_desc"] = "Удалить существующий и неиспользуемый профиль из БД для сохранения места, и очистить SavedVariables файл."
181 L["delete_sub"] = "Удаление профиля из БД"
182 L["intro"] = "Изменяя активный профиль, вы можете задать различные настройки модификаций для каждого персонажа."
184 L["new_sub"] = "Создать новый чистый профиль"
185 L["profiles"] = "Профили"
186 L["profiles_sub"] = "Управление профилями"
187 L["reset"] = "Сброс профиля"
188 L["reset_desc"] = "Сбросить текущий профиль к стандартным настройкам, если ваша конфигурация испорчена или вы хотите настроить всё заново."
189 L["reset_sub"] = "Сброс текущего профиля на стандартный"
190 elseif LOCALE == "itIT" then
191 L["choose"] = "Profili Esistenti"
192 L["choose_desc"] = "Puoi creare un nuovo profilo digitando il nome della casella di testo, oppure scegliendone uno tra i profili già esistenti."
193 L["choose_sub"] = "Seleziona uno dei profili attualmente disponibili."
194 L["copy"] = "Copia Da"
195 L["copy_desc"] = "Copia le impostazioni da un profilo esistente, nel profilo attivo in questo momento."
196 L["current"] = "Profilo Attivo:"
197 L["default"] = "Standard"
198 L["delete"] = "Cancella un Profilo"
199 L["delete_confirm"] = "Sei sicuro di voler cancellare il profilo selezionato?"
200 L["delete_desc"] = "Cancella i profili non utilizzati dal database per risparmiare spazio e mantenere puliti i file di configurazione SavedVariables."
201 L["delete_sub"] = "Cancella un profilo dal Database."
202 L["intro"] = "Puoi cambiare il profilo attivo, in modo da usare impostazioni diverse per ogni personaggio."
204 L["new_sub"] = "Crea un nuovo profilo vuoto."
205 L["profiles"] = "Profili"
206 L["profiles_sub"] = "Gestisci Profili"
207 L["reset"] = "Reimposta Profilo"
208 L["reset_desc"] = "Riporta il tuo profilo attivo alle sue impostazioni predefinite, nel caso in cui la tua configurazione si sia corrotta, o semplicemente tu voglia re-inizializzarla."
209 L["reset_sub"] = "Reimposta il profilo ai suoi valori predefiniti."
210 elseif LOCALE == "ptBR" then
211 L["choose"] = "Perfis Existentes"
212 L["choose_desc"] = "Você pode tanto criar um perfil novo tanto digitando um nome na caixa de texto, quanto escolher um dos perfis já existentes."
213 L["choose_sub"] = "Selecione um de seus perfis atualmente disponíveis."
214 L["copy"] = "Copiar De"
215 L["copy_desc"] = "Copia as definições de um perfil existente no perfil atualmente ativo."
216 L["current"] = "Perfil Autal:"
217 L["default"] = "Padrão"
218 L["delete"] = "Remover um Perfil"
219 L["delete_confirm"] = "Tem certeza que deseja remover o perfil selecionado?"
220 L["delete_desc"] = "Remove perfis existentes e inutilizados do banco de dados para economizar espaço, e limpar o arquivo SavedVariables."
221 L["delete_sub"] = "Remove um perfil do banco de dados."
222 L["intro"] = "Você pode alterar o perfil do banco de dados ativo, para que possa ter definições diferentes para cada personagem."
224 L["new_sub"] = "Cria um novo perfil vazio."
225 L["profiles"] = "Perfis"
226 L["profiles_sub"] = "Gerenciar Perfis"
227 L["reset"] = "Resetar Perfil"
228 L["reset_desc"] = "Reseta o perfil atual para os valores padrões, no caso de sua configuração estar quebrada, ou simplesmente se deseja começar novamente."
229 L["reset_sub"] = "Resetar o perfil atual ao padrão"
232 local defaultProfiles
233 local tmpprofiles = {}
235 -- Get a list of available profiles for the specified database.
236 -- You can specify which profiles to include/exclude in the list using the two boolean parameters listed below.
237 -- @param db The db object to retrieve the profiles from
238 -- @param common If true, getProfileList will add the default profiles to the return list, even if they have not been created yet
239 -- @param nocurrent If true, then getProfileList will not display the current profile in the list
240 -- @return Hashtable of all profiles with the internal name as keys and the display name as value.
241 local function getProfileList(db, common, nocurrent)
244 -- copy existing profiles into the table
245 local currentProfile = db:GetCurrentProfile()
246 for i,v in pairs(db:GetProfiles(tmpprofiles)) do
247 if not (nocurrent and v == currentProfile) then
252 -- add our default profiles to choose from ( or rename existing profiles)
253 for k,v in pairs(defaultProfiles) do
254 if (common or profiles[k]) and not (nocurrent and k == currentProfile) then
263 OptionsHandlerPrototype
264 prototype class for handling the options in a sane way
266 local OptionsHandlerPrototype = {}
268 --[[ Reset the profile ]]
269 function OptionsHandlerPrototype:Reset()
270 self.db:ResetProfile()
273 --[[ Set the profile to value ]]
274 function OptionsHandlerPrototype:SetProfile(info, value)
275 self.db:SetProfile(value)
278 --[[ returns the currently active profile ]]
279 function OptionsHandlerPrototype:GetCurrentProfile()
280 return self.db:GetCurrentProfile()
284 List all active profiles
285 you can control the output with the .arg variable
286 currently four modes are supported
288 (empty) - return all available profiles
289 "nocurrent" - returns all available profiles except the currently active profile
290 "common" - returns all avaialble profiles + some commonly used profiles ("char - realm", "realm", "class", "Default")
291 "both" - common except the active profile
293 function OptionsHandlerPrototype:ListProfiles(info)
296 if arg == "common" and not self.noDefaultProfiles then
297 profiles = getProfileList(self.db, true, nil)
298 elseif arg == "nocurrent" then
299 profiles = getProfileList(self.db, nil, true)
300 elseif arg == "both" then -- currently not used
301 profiles = getProfileList(self.db, (not self.noDefaultProfiles) and true, true)
303 profiles = getProfileList(self.db)
309 function OptionsHandlerPrototype:HasNoProfiles(info)
310 local profiles = self:ListProfiles(info)
311 return ((not next(profiles)) and true or false)
314 --[[ Copy a profile ]]
315 function OptionsHandlerPrototype:CopyProfile(info, value)
316 self.db:CopyProfile(value)
319 --[[ Delete a profile from the db ]]
320 function OptionsHandlerPrototype:DeleteProfile(info, value)
321 self.db:DeleteProfile(value)
324 --[[ fill defaultProfiles with some generic values ]]
325 local function generateDefaultProfiles(db)
327 ["Default"] = L["default"],
328 [db.keys.char] = db.keys.char,
329 [db.keys.realm] = db.keys.realm,
330 [db.keys.class] = UnitClass("player")
334 --[[ create and return a handler object for the db, or upgrade it if it already existed ]]
335 local function getOptionsHandler(db, noDefaultProfiles)
336 if not defaultProfiles then
337 generateDefaultProfiles(db)
340 local handler = AceDBOptions.handlers[db] or { db = db, noDefaultProfiles = noDefaultProfiles }
342 for k,v in pairs(OptionsHandlerPrototype) do
346 AceDBOptions.handlers[db] = handler
351 the real options table
353 local optionsTable = {
356 type = "description",
357 name = L["intro"] .. "\n",
361 type = "description",
362 name = L["reset_desc"],
368 desc = L["reset_sub"],
373 type = "description",
374 name = function(info) return L["current"] .. " " .. NORMAL_FONT_COLOR_CODE .. info.handler:GetCurrentProfile() .. FONT_COLOR_CODE_CLOSE end,
379 type = "description",
380 name = "\n" .. L["choose_desc"],
392 desc = L["choose_sub"],
395 get = "GetCurrentProfile",
397 values = "ListProfiles",
402 type = "description",
403 name = "\n" .. L["copy_desc"],
409 desc = L["copy_desc"],
412 values = "ListProfiles",
413 disabled = "HasNoProfiles",
418 type = "description",
419 name = "\n" .. L["delete_desc"],
425 desc = L["delete_sub"],
427 set = "DeleteProfile",
428 values = "ListProfiles",
429 disabled = "HasNoProfiles",
432 confirmText = L["delete_confirm"],
436 --- Get/Create a option table that you can use in your addon to control the profiles of AceDB-3.0.
437 -- @param db The database object to create the options table for.
438 -- @return The options table to be used in AceConfig-3.0
440 -- -- Assuming `options` is your top-level options table and `self.db` is your database:
441 -- options.args.profiles = LibStub("AceDBOptions-3.0"):GetOptionsTable(self.db)
442 function AceDBOptions:GetOptionsTable(db, noDefaultProfiles)
443 local tbl = AceDBOptions.optionTables[db] or {
445 name = L["profiles"],
446 desc = L["profiles_sub"],
449 tbl.handler = getOptionsHandler(db, noDefaultProfiles)
450 tbl.args = optionsTable
452 AceDBOptions.optionTables[db] = tbl
456 -- upgrade existing tables
457 for db,tbl in pairs(AceDBOptions.optionTables) do
458 tbl.handler = getOptionsHandler(db)
459 tbl.args = optionsTable