side_menu/src/admin.js

166 lines
5.1 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-side-with-categories').val(target.attr('data-sidewithcategories'))
2020-09-04 16:43:27 +02:00
})
jQuery('.side-menu-setting-live').on('change', (event) => {
var target = jQuery(event.target)
var name = target.attr('name')
var value = target.val()
2021-07-03 20:23:39 +02:00
if ('background-color-opacity' === name) {
return $('#side-menu-background-color, #side-menu-background-color-to').trigger('change');
} else if ('dark-mode-background-color-opacity' === name) {
return $('#side-menu-dark-mode-background-color, #side-menu-dark-mode-background-color-to').trigger('change');
}
2020-09-04 16:43:27 +02:00
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
2021-07-03 20:23:39 +02:00
if (['dark-mode-background-color', 'dark-mode-background-color-to'].indexOf(name) > -1) {
var opacity = parseInt($('#side-menu-dark-mode-background-color-opacity').val() * 255 / 100);
value = [value, opacity.toString(16)].join('');
} else if (['background-color', 'background-color-to'].indexOf(name) > -1) {
var opacity = parseInt($('#side-menu-background-color-opacity').val() * 255 / 100);
value = [value, opacity.toString(16)].join('');
}
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)
})
2021-02-03 10:14:03 +01:00
2021-02-03 10:27:08 +01:00
jQuery("#categories-list .side-menu-setting-list").sortable({
2021-02-03 10:14:03 +01:00
forcePlaceholderSize: true,
placeholder: 'placeholder',
stop: function (event, ui) {
let value = []
2021-02-03 10:27:08 +01:00
jQuery('#categories-list .side-menu-setting-list-item').each(function() {
2021-02-03 10:14:03 +01:00
value.push(jQuery(this).attr('data-id'))
});
value = JSON.stringify(value)
jQuery('input[name="categories-order"]').val(value)
}
});
2020-04-09 09:55:45 +02:00
});