5028feff8b3c861bad51c938df251bf9a28386c5
[wowui.git] / RaidFrameCustomizationConfig / libs / AceDBOptions-3.0 / AceDBOptions-3.0.lua
1 --- AceDBOptions-3.0 provides a universal AceConfig options screen for managing AceDB-3.0 profiles.
2 -- @class file
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)
7
8 if not AceDBOptions then return end -- No upgrade needed
9
10 -- Lua APIs
11 local pairs, next = pairs, next
12
13 -- WoW APIs
14 local UnitClass = UnitClass
15
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
19
20 AceDBOptions.optionTables = AceDBOptions.optionTables or {}
21 AceDBOptions.handlers = AceDBOptions.handlers or {}
22
23 --[[
24         Localization of AceDBOptions-3.0
25 ]]
26
27 local L = {
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.",
31         copy = "Copy From",
32         copy_desc = "Copy the settings from one existing profile into the currently active profile.",
33         current = "Current Profile:",
34         default = "Default",
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.",
40         new = "New",
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",
47 }
48
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."
63         L["new"] = "Neu"
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."
83         L["new"] = "Nouveau"
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"] = "현재 이용할 수 있는 프로필 중 하나를 선택합니다."
94         L["copy"] = "복사해오기"
95         L["copy_desc"] = "현재 사용 중인 프로필에 선택한 프로필의 설정을 복사합니다."
96         L["current"] = "현재 프로필:"
97         L["default"] = "기본값"
98         L["delete"] = "프로필 삭제"
99         L["delete_confirm"] = "정말로 선택한 프로필을 삭제할까요?"
100         L["delete_desc"] = "저장 공간 절약과 SavedVariables 파일의 정리를 위해 데이터베이스에서 사용하지 않는 프로필을 삭제하세요."
101         L["delete_sub"] = "데이터베이스의 프로필을 삭제합니다."
102         L["intro"] = "활성 데이터베이스 프로필을 변경할 수 있고, 각 캐릭터 별로 다른 설정을 할 수 있습니다."
103         L["new"] = "새로운 프로필"
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."
123         L["new"] = "Nuevo"
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"] = "從當前可用的設定檔裡面選擇一個。"
134         L["copy"] = "複製自"
135         L["copy_desc"] = "從一個現有的設定檔,將設定複製到現在使用中的設定檔。"
136         L["current"] = "目前設定檔:"
137         L["default"] = "預設"
138         L["delete"] = "刪除一個設定檔"
139         L["delete_confirm"] = "確定要刪除所選擇的設定檔嗎?"
140         L["delete_desc"] = "從資料庫裡刪除不再使用的設定檔,以節省空間,並且清理 SavedVariables 檔案。"
141         L["delete_sub"] = "從資料庫裡刪除一個設定檔。"
142         L["intro"] = "您可以從資料庫中選擇一個設定檔來使用,如此就可以讓每個角色使用不同的設定。"
143         L["new"] = "新建"
144         L["new_sub"] = "新建一個空的設定檔。"
145         L["profiles"] = "設定檔"
146         L["profiles_sub"] = "管理設定檔"
147         L["reset"] = "重置設定檔"
148         L["reset_desc"] = "將現用的設定檔重置為預設值;用於設定檔損壞,或者單純想要重來的情況。"
149         L["reset_sub"] = "將目前的設定檔重置為預設值"
150 elseif LOCALE == "zhCN" then
151         L["choose"] = "现有的配置文件"
152         L["choose_desc"] = "你可以通过在文本框内输入一个名字创立一个新的配置文件,也可以选择一个已经存在的配置文件。"
153         L["choose_sub"] = "从当前可用的配置文件里面选择一个。"
154         L["copy"] = "复制自"
155         L["copy_desc"] = "从当前某个已保存的配置文件复制到当前正使用的配置文件。"
156         L["current"] = "当前配置文件:"
157         L["default"] = "默认"
158         L["delete"] = "删除一个配置文件"
159         L["delete_confirm"] = "你确定要删除所选择的配置文件么?"
160         L["delete_desc"] = "从数据库里删除不再使用的配置文件,以节省空间,并且清理SavedVariables文件。"
161         L["delete_sub"] = "从数据库里删除一个配置文件。"
162         L["intro"] = "你可以选择一个活动的数据配置文件,这样你的每个角色就可以拥有不同的设置值,可以给你的插件配置带来极大的灵活性。"
163         L["new"] = "新建"
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"] = "Изменяя активный профиль, вы можете задать различные настройки модификаций для каждого персонажа."
183         L["new"] = "Новый"
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."
203         L["new"] = "Nuovo"
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."
223         L["new"] = "Novo"
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"
230 end
231
232 local defaultProfiles
233 local tmpprofiles = {}
234
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)
242         local profiles = {}
243         
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 
248                         profiles[v] = v 
249                 end 
250         end
251         
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
255                         profiles[k] = v
256                 end
257         end
258         
259         return profiles
260 end
261
262 --[[
263         OptionsHandlerPrototype
264         prototype class for handling the options in a sane way
265 ]]
266 local OptionsHandlerPrototype = {}
267
268 --[[ Reset the profile ]]
269 function OptionsHandlerPrototype:Reset()
270         self.db:ResetProfile()
271 end
272
273 --[[ Set the profile to value ]]
274 function OptionsHandlerPrototype:SetProfile(info, value)
275         self.db:SetProfile(value)
276 end
277
278 --[[ returns the currently active profile ]]
279 function OptionsHandlerPrototype:GetCurrentProfile()
280         return self.db:GetCurrentProfile()
281 end
282
283 --[[ 
284         List all active profiles
285         you can control the output with the .arg variable
286         currently four modes are supported
287         
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
292 ]]
293 function OptionsHandlerPrototype:ListProfiles(info)
294         local arg = info.arg
295         local profiles
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)
302         else
303                 profiles = getProfileList(self.db)
304         end
305         
306         return profiles
307 end
308
309 function OptionsHandlerPrototype:HasNoProfiles(info)
310         local profiles = self:ListProfiles(info)
311         return ((not next(profiles)) and true or false)
312 end
313
314 --[[ Copy a profile ]]
315 function OptionsHandlerPrototype:CopyProfile(info, value)
316         self.db:CopyProfile(value)
317 end
318
319 --[[ Delete a profile from the db ]]
320 function OptionsHandlerPrototype:DeleteProfile(info, value)
321         self.db:DeleteProfile(value)
322 end
323
324 --[[ fill defaultProfiles with some generic values ]]
325 local function generateDefaultProfiles(db)
326         defaultProfiles = {
327                 ["Default"] = L["default"],
328                 [db.keys.char] = db.keys.char,
329                 [db.keys.realm] = db.keys.realm,
330                 [db.keys.class] = UnitClass("player")
331         }
332 end
333
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)
338         end
339         
340         local handler = AceDBOptions.handlers[db] or { db = db, noDefaultProfiles = noDefaultProfiles }
341         
342         for k,v in pairs(OptionsHandlerPrototype) do
343                 handler[k] = v
344         end
345         
346         AceDBOptions.handlers[db] = handler
347         return handler
348 end
349
350 --[[
351         the real options table 
352 ]]
353 local optionsTable = {
354         desc = {
355                 order = 1,
356                 type = "description",
357                 name = L["intro"] .. "\n",
358         },
359         descreset = {
360                 order = 9,
361                 type = "description",
362                 name = L["reset_desc"],
363         },
364         reset = {
365                 order = 10,
366                 type = "execute",
367                 name = L["reset"],
368                 desc = L["reset_sub"],
369                 func = "Reset",
370         },
371         current = {
372                 order = 11,
373                 type = "description",
374                 name = function(info) return L["current"] .. " " .. NORMAL_FONT_COLOR_CODE .. info.handler:GetCurrentProfile() .. FONT_COLOR_CODE_CLOSE end,
375                 width = "default",
376         },
377         choosedesc = {
378                 order = 20,
379                 type = "description",
380                 name = "\n" .. L["choose_desc"],
381         },
382         new = {
383                 name = L["new"],
384                 desc = L["new_sub"],
385                 type = "input",
386                 order = 30,
387                 get = false,
388                 set = "SetProfile",
389         },
390         choose = {
391                 name = L["choose"],
392                 desc = L["choose_sub"],
393                 type = "select",
394                 order = 40,
395                 get = "GetCurrentProfile",
396                 set = "SetProfile",
397                 values = "ListProfiles",
398                 arg = "common",
399         },
400         copydesc = {
401                 order = 50,
402                 type = "description",
403                 name = "\n" .. L["copy_desc"],
404         },
405         copyfrom = {
406                 order = 60,
407                 type = "select",
408                 name = L["copy"],
409                 desc = L["copy_desc"],
410                 get = false,
411                 set = "CopyProfile",
412                 values = "ListProfiles",
413                 disabled = "HasNoProfiles",
414                 arg = "nocurrent",
415         },
416         deldesc = {
417                 order = 70,
418                 type = "description",
419                 name = "\n" .. L["delete_desc"],
420         },
421         delete = {
422                 order = 80,
423                 type = "select",
424                 name = L["delete"],
425                 desc = L["delete_sub"],
426                 get = false,
427                 set = "DeleteProfile",
428                 values = "ListProfiles",
429                 disabled = "HasNoProfiles",
430                 arg = "nocurrent",
431                 confirm = true,
432                 confirmText = L["delete_confirm"],
433         },
434 }
435
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
439 -- @usage 
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 {
444                         type = "group",
445                         name = L["profiles"],
446                         desc = L["profiles_sub"],
447                 }
448         
449         tbl.handler = getOptionsHandler(db, noDefaultProfiles)
450         tbl.args = optionsTable
451
452         AceDBOptions.optionTables[db] = tbl
453         return tbl
454 end
455
456 -- upgrade existing tables
457 for db,tbl in pairs(AceDBOptions.optionTables) do
458         tbl.handler = getOptionsHandler(db)
459         tbl.args = optionsTable
460 end