2024-01-09 23:44:52 +00:00
|
|
|
local types = require('openmw.types')
|
|
|
|
local self = require('openmw.self')
|
|
|
|
|
2022-04-27 19:28:16 +00:00
|
|
|
local common = require('scripts.omw.settings.common')
|
2024-01-09 23:44:52 +00:00
|
|
|
|
|
|
|
local function registerPage(options)
|
|
|
|
types.Player.sendMenuEvent(self, common.registerPageEvent, options)
|
|
|
|
end
|
2022-04-13 18:08:33 +00:00
|
|
|
|
2022-05-01 14:57:33 +00:00
|
|
|
---
|
|
|
|
-- @type PageOptions
|
|
|
|
-- @field #string key A unique key
|
|
|
|
-- @field #string l10n A localization context (an argument of core.l10n)
|
|
|
|
-- @field #string name A key from the localization context
|
2022-05-14 10:27:30 +00:00
|
|
|
-- @field #string description A key from the localization context (optional, can be `nil`)
|
2022-05-01 14:57:33 +00:00
|
|
|
|
|
|
|
---
|
|
|
|
-- @type GroupOptions
|
|
|
|
-- @field #string key A unique key, starts with "Settings" by convention
|
|
|
|
-- @field #string l10n A localization context (an argument of core.l10n)
|
|
|
|
-- @field #string name A key from the localization context
|
2022-05-14 10:27:30 +00:00
|
|
|
-- @field #string description A key from the localization context (optional, can be `nil`)
|
2022-05-01 14:57:33 +00:00
|
|
|
-- @field #string page Key of a page which will contain this group
|
|
|
|
-- @field #number order Groups within the same page are sorted by this number, or their key for equal values.
|
|
|
|
-- Defaults to 0.
|
2022-05-16 21:24:20 +00:00
|
|
|
-- @field #boolean permanentStorage Whether the group should be stored in permanent storage, or in the save file
|
2023-01-30 10:13:26 +00:00
|
|
|
-- @field #list<#SettingOptions> settings A [iterables#List](iterables.html#List) table of #SettingOptions
|
2022-05-01 14:57:33 +00:00
|
|
|
|
|
|
|
---
|
2023-01-30 10:13:26 +00:00
|
|
|
-- Table of setting options
|
2022-05-01 14:57:33 +00:00
|
|
|
-- @type SettingOptions
|
|
|
|
-- @field #string key A unique key
|
|
|
|
-- @field #string name A key from the localization context
|
2022-05-14 10:27:30 +00:00
|
|
|
-- @field #string description A key from the localization context (optional, can be `nil`)
|
2022-05-01 14:57:33 +00:00
|
|
|
-- @field default A default value
|
2022-05-24 19:11:13 +00:00
|
|
|
-- @field #string renderer A renderer key (see the "Built-in Setting Renderers" page)
|
2022-05-01 14:57:33 +00:00
|
|
|
-- @field argument An argument for the renderer
|
|
|
|
|
2022-03-07 20:28:05 +00:00
|
|
|
return {
|
|
|
|
interfaceName = 'Settings',
|
2022-05-01 14:57:33 +00:00
|
|
|
---
|
|
|
|
-- @module Settings
|
|
|
|
-- @usage
|
|
|
|
-- -- In a player script
|
|
|
|
-- local storage = require('openmw.storage')
|
|
|
|
-- local I = require('openmw.interfaces')
|
2022-05-14 10:27:30 +00:00
|
|
|
-- I.Settings.registerPage {
|
|
|
|
-- key = 'MyModPage',
|
|
|
|
-- l10n = 'MyMod',
|
|
|
|
-- name = 'My Mod Name',
|
|
|
|
-- description = 'My Mod Description',
|
|
|
|
-- }
|
|
|
|
-- I.Settings.registerGroup {
|
2022-05-01 14:57:33 +00:00
|
|
|
-- key = 'SettingsPlayerMyMod',
|
2022-05-14 10:27:30 +00:00
|
|
|
-- page = 'MyModPage',
|
|
|
|
-- l10n = 'MyMod',
|
|
|
|
-- name = 'My Group Name',
|
|
|
|
-- description = 'My Group Description',
|
2022-05-16 21:24:20 +00:00
|
|
|
-- permanentStorage = false,
|
2022-05-01 14:57:33 +00:00
|
|
|
-- settings = {
|
|
|
|
-- {
|
|
|
|
-- key = 'Greeting',
|
2022-05-14 10:27:30 +00:00
|
|
|
-- renderer = 'textLine',
|
|
|
|
-- name = 'Greeting',
|
|
|
|
-- description = 'Text to display when the game starts',
|
2022-05-01 14:57:33 +00:00
|
|
|
-- default = 'Hello, world!',
|
|
|
|
-- },
|
|
|
|
-- },
|
2022-05-14 10:27:30 +00:00
|
|
|
-- }
|
2022-05-01 14:57:33 +00:00
|
|
|
-- local playerSettings = storage.playerSection('SettingsPlayerMyMod')
|
2022-05-14 10:27:30 +00:00
|
|
|
-- ...
|
|
|
|
-- ui.showMessage(playerSettings:get('Greeting'))
|
|
|
|
-- -- ...
|
2022-05-01 14:57:33 +00:00
|
|
|
-- -- access a setting page registered by a global script
|
|
|
|
-- local globalSettings = storage.globalSection('SettingsGlobalMyMod')
|
2022-03-07 20:28:05 +00:00
|
|
|
interface = {
|
2022-05-01 14:57:33 +00:00
|
|
|
---
|
2024-01-08 20:55:09 +00:00
|
|
|
-- @field [parent=#Settings] #number version
|
|
|
|
version = 1,
|
2022-05-01 14:57:33 +00:00
|
|
|
---
|
|
|
|
-- @function [parent=#Settings] registerPage Register a page to be displayed in the settings menu,
|
2024-01-08 20:55:09 +00:00
|
|
|
-- available in player and menu scripts
|
2022-05-01 14:57:33 +00:00
|
|
|
-- @param #PageOptions options
|
|
|
|
-- @usage
|
|
|
|
-- I.Settings.registerPage({
|
|
|
|
-- key = 'MyModName',
|
|
|
|
-- l10n = 'MyModName',
|
|
|
|
-- name = 'MyModName',
|
|
|
|
-- description = 'MyModDescription',
|
|
|
|
-- })---
|
2024-01-09 23:44:52 +00:00
|
|
|
registerPage = registerPage,
|
2022-05-01 14:57:33 +00:00
|
|
|
---
|
|
|
|
-- @function [parent=#Settings] registerRenderer Register a renderer,
|
2024-01-14 12:38:35 +00:00
|
|
|
-- only available in menu scripts (DEPRECATED in player scripts)
|
2022-05-01 14:57:33 +00:00
|
|
|
-- @param #string key
|
|
|
|
-- @param #function renderer A renderer function, receives setting's value,
|
|
|
|
-- a function to change it and an argument from the setting options
|
|
|
|
-- @usage
|
|
|
|
-- I.Settings.registerRenderer('text', function(value, set, arg)
|
|
|
|
-- return {
|
|
|
|
-- type = ui.TYPE.TextEdit,
|
|
|
|
-- props = {
|
|
|
|
-- size = util.vector2(arg and arg.size or 150, 30),
|
|
|
|
-- text = value,
|
|
|
|
-- textColor = util.color.rgb(1, 1, 1),
|
|
|
|
-- textSize = 15,
|
|
|
|
-- textAlignV = ui.ALIGNMENT.End,
|
|
|
|
-- },
|
|
|
|
-- events = {
|
|
|
|
-- textChanged = async:callback(function(s) set(s) end),
|
|
|
|
-- },
|
|
|
|
-- }
|
|
|
|
-- end)
|
2024-01-09 23:44:52 +00:00
|
|
|
registerRenderer = function(name)
|
|
|
|
print(([[Can't register setting renderer "%s". registerRenderer and moved to Menu context Settings interface]])
|
|
|
|
:format(name))
|
2024-01-08 20:55:09 +00:00
|
|
|
end,
|
2022-05-01 14:57:33 +00:00
|
|
|
---
|
|
|
|
-- @function [parent=#Settings] registerGroup Register a group to be attached to a page,
|
2024-01-10 22:10:19 +00:00
|
|
|
-- available in player, menu and global scripts
|
|
|
|
-- Note: menu scripts only allow group with permanentStorage = true, but can render the page before a game is loaded!
|
2022-05-01 14:57:33 +00:00
|
|
|
-- @param #GroupOptions options
|
|
|
|
-- @usage
|
|
|
|
-- I.Settings.registerGroup {
|
|
|
|
-- key = 'SettingsTest',
|
|
|
|
-- page = 'test',
|
|
|
|
-- l10n = 'test',
|
|
|
|
-- name = 'Player',
|
|
|
|
-- description = 'Player settings group',
|
2022-05-16 21:24:20 +00:00
|
|
|
-- permanentStorage = false,
|
2022-05-01 14:57:33 +00:00
|
|
|
-- settings = {
|
|
|
|
-- {
|
|
|
|
-- key = 'Greeting',
|
|
|
|
-- default = 'Hi',
|
2022-05-14 10:27:30 +00:00
|
|
|
-- renderer = 'textLine',
|
2022-05-01 14:57:33 +00:00
|
|
|
-- name = 'Text Input',
|
|
|
|
-- description = 'Short text input',
|
|
|
|
-- },
|
|
|
|
-- {
|
2022-05-14 10:27:30 +00:00
|
|
|
-- key = 'Flag',
|
|
|
|
-- default = false,
|
2023-03-01 06:04:53 +00:00
|
|
|
-- renderer = 'checkbox',
|
2022-05-14 10:27:30 +00:00
|
|
|
-- name = 'Flag',
|
|
|
|
-- description = 'Flag toggle',
|
2022-05-01 14:57:33 +00:00
|
|
|
-- },
|
|
|
|
-- }
|
|
|
|
-- }
|
2022-04-27 19:28:16 +00:00
|
|
|
registerGroup = common.registerGroup,
|
2022-05-19 19:49:14 +00:00
|
|
|
---
|
|
|
|
-- @function [parent=#Settings] updateRendererArgument Change the renderer argument of a setting
|
2024-01-10 22:10:19 +00:00
|
|
|
-- available both in player, menu and global scripts
|
2022-05-19 19:49:14 +00:00
|
|
|
-- @param #string groupKey A settings group key
|
|
|
|
-- @param #string settingKey A setting key
|
|
|
|
-- @param argument A renderer argument
|
|
|
|
updateRendererArgument = common.updateRendererArgument,
|
2022-03-07 20:28:05 +00:00
|
|
|
},
|
|
|
|
engineHandlers = {
|
2022-04-27 19:28:16 +00:00
|
|
|
onLoad = common.onLoad,
|
|
|
|
onSave = common.onSave,
|
2022-03-07 20:28:05 +00:00
|
|
|
},
|
2023-01-30 10:13:26 +00:00
|
|
|
}
|