98 lines
4.9 KiB
HTML
98 lines
4.9 KiB
HTML
<!DOCTYPE html>
|
|
|
|
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<title>ExamplePlugin Configuration</title>
|
|
</head>
|
|
<body>
|
|
<div id="ExamplePluginConfigurationPage" data-role="page" class="page type-interior pluginConfigurationPage" data-require="emby-input,emby-button,emby-select,emby-checkbox">
|
|
<div data-role="content">
|
|
<div class="content-primary">
|
|
|
|
<form id="ExamplePluginConfigurationForm">
|
|
<div class="selectContainer">
|
|
<label class="selectLabel" for="Options">Options:</label>
|
|
<select is="emby-select" id="Options" name="Options" class="emby-select-withcolor emby-select">
|
|
<option id="optOneOption" value="OneOption">One Option</option>
|
|
<option id="optAnotherOption" value="AnotherOption">AnotherOption</option>
|
|
</select>
|
|
</div>
|
|
<div class="inputContainer">
|
|
<label class="inputeLabel inputLabelUnfocused" for="AnInteger">An Integer:</label>
|
|
<input id="AnInteger" name="AnInteger" type="number" is="emby-input" min="0"/>
|
|
<div class="fieldDescription">Numbers go here</div>
|
|
</div>
|
|
<div class="checkboxContainer checkboxContainer-withDescripton">
|
|
<label class="emby-checkbox-label">
|
|
<input id="TrueFalseSetting" name="TrueFalseCheckBox" type="checkbox" is="emby-checkbox"/>
|
|
<span>True or False</span>
|
|
</label>
|
|
</div>
|
|
<div class="inputContainer">
|
|
<label class="inputeLabel inputLabelUnfocused" for="AString">A String:</label>
|
|
<input id="AString" name="AString" type="text" is="emby-input" />
|
|
<div class="fieldDescription">Words go here</div>
|
|
</div>
|
|
<div>
|
|
<button is="emby-button" type="submit" class="raised button-submit block emby-button">
|
|
<span>Save</span>
|
|
</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
|
|
<script type="text/javascript">
|
|
var ExamplePluginConfigurationPage =
|
|
{
|
|
pluginUniqueId: "eb5d7894-8eef-4b36-aa6f-5d124e828ce1",
|
|
|
|
virtualFolders: [],
|
|
physicalFolders: [],
|
|
|
|
loadConfiguration: function() {
|
|
Dashboard.showLoadingMsg();
|
|
|
|
ApiClient.getPluginConfiguration(ExamplePluginConfigurationPage.pluginUniqueId).then(function (config) {
|
|
var page = $.mobile.activePage;
|
|
|
|
$('#Options', page).val(config.Options).change();
|
|
$('#AnInteger', page).val(config.AnInteger).change();
|
|
$('#TrueFalseSetting', page).checked(config.TrueFalseSetting).checkboxradio("refresh");
|
|
$('#AString', page).val(config.AString).change();
|
|
|
|
Dashboard.hideLoadingMsg();
|
|
});
|
|
},
|
|
|
|
saveConfiguration: function() {
|
|
Dashboard.showLoadingMsg();
|
|
|
|
var page = $.mobile.activePage;
|
|
|
|
ApiClient.getPluginConfiguration(ExamplePluginConfigurationPage.pluginUniqueId).then(function(config) {
|
|
|
|
config.Options = $('#Options', page).val();
|
|
config.AnInteger = $('#AnInteger').val();
|
|
config.TrueFalseSetting = $('#TrueFalseSetting').prop('checked');
|
|
config.AString = $('#AString').val();
|
|
ApiClient.updatePluginConfiguration(ExamplePluginConfigurationPage.pluginUniqueId, config).then(function (result) {
|
|
Dashboard.processPluginConfigurationUpdateResult(result);
|
|
});
|
|
});
|
|
},
|
|
};
|
|
|
|
$('#ExamplePluginConfigurationPage').on('pageshow', function () {
|
|
ExamplePluginConfigurationPage.loadConfiguration();
|
|
});
|
|
|
|
$('#ExamplePluginConfigurationForm').on('submit', function () {
|
|
ExamplePluginConfigurationPage.saveConfiguration();
|
|
return false;
|
|
});
|
|
</script>
|
|
</div>
|
|
</body>
|
|
</html> |