side_menu/src/admin.js

133 lines
3.7 KiB
JavaScript
Raw Normal View History

2020-04-09 09:55:45 +02:00
/**
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
let elements = []
2020-04-09 09:55:45 +02:00
const selector = '#side-menu-message';
const userConfig = (name, value, callbacks) => {
const url = OC.generateUrl('/apps/side_menu/personalSetting/valueSet')
$.post(url, {name: name, value: value}, callbacks.success)
.fail(callbacks.error)
}
const appConfig = (name, value, callbacks) => {
OCP.AppConfig.setValue('side_menu', name, value, callbacks)
}
2020-04-09 09:55:45 +02:00
const saveSettings = (key) => {
const element = elements.get(key)
let value
let name
2020-09-04 15:34:09 +02:00
if (jQuery(element).is('[data-checkbox]')) {
name = jQuery(element).attr('data-name')
const inputs = jQuery('input[name="' + name + '[]"]:checked')
value = []
inputs.each((i, v) => {
value.push(v.value)
})
value = JSON.stringify(value)
} else {
2020-09-04 15:34:09 +02:00
name = jQuery(element).attr('name')
value = jQuery(element).val()
}
2020-04-09 09:55:45 +02:00
const size = elements.length
2020-08-13 23:02:28 +02:00
if (name === 'cache') {
++value
2020-04-09 09:55:45 +02:00
}
const callbacks = {
2020-04-09 09:55:45 +02:00
success: () => {
OC.msg.finishedSuccess(
selector,
2020-04-09 10:33:54 +02:00
t('side_menu', (key + 1) + '/' + size)
2020-04-09 09:55:45 +02:00
)
if (key < size - 1) {
2020-04-09 09:55:45 +02:00
saveSettings(++key)
} else {
2020-04-09 10:33:54 +02:00
OC.msg.finishedSuccess(selector, t('side_menu', 'Saved'))
2020-04-09 09:55:45 +02:00
}
},
error: () => {
OC.msg.finishedError(selector, t('side_menu', 'Error while saving "' + element + '"'))
}
}
2020-09-04 15:34:09 +02:00
if (jQuery(element).is('[data-personal]')) {
userConfig(name, value, callbacks)
} else {
appConfig(name, value, callbacks)
}
2020-04-09 09:55:45 +02:00
}
const elementToggler = (element) => {
jQuery(element).toggle()
}
2020-09-04 15:34:09 +02:00
jQuery(document).ready(() => {
elements = jQuery('.side-menu-setting')
2020-09-04 15:34:09 +02:00
jQuery('#side-menu-save').on('click', (event) => {
event.preventDefault()
OC.msg.startSaving(selector)
2020-04-09 09:55:45 +02:00
saveSettings(0)
});
2020-09-04 15:32:30 +02:00
2020-09-04 15:34:09 +02:00
jQuery('.side-menu-display').on('click', (event) => {
2020-09-04 16:43:27 +02:00
var target = jQuery(event.target)
2020-09-04 15:34:09 +02:00
jQuery('.side-menu-display').removeClass('is-active')
2020-09-04 16:43:27 +02:00
target.addClass('is-active')
jQuery('#side-menu-always-displayed').val(target.attr('data-alwaysdiplayed'))
jQuery('#side-menu-big-menu').val(target.attr('data-bigmenu'))
})
jQuery('.side-menu-setting-live').on('change', (event) => {
var target = jQuery(event.target)
var name = target.attr('name')
var value = target.val()
if (name === 'opener') {
var url = OC.generateUrl(`/apps/side_menu/img/${value}.svg`).replace('/index.php', '')
value = `url(${url})`;
}
if (name === 'icon-invert-filter' || name === 'icon-opacity') {
value/=100;
}
2020-09-04 15:32:30 +02:00
2020-09-04 16:43:27 +02:00
document.documentElement.style.setProperty('--side-menu-' + name, value)
2020-09-04 15:32:30 +02:00
})
jQuery('.side-menu-toggler').on('click', (event) => {
var target = jQuery(event.target)
var element = target.attr('data-target')
elementToggler(element)
})
2020-04-09 09:55:45 +02:00
});