2024-02-25 20:31:16 -05:00
|
|
|
const mixinsVue = {
|
|
|
|
delimiters: ['@#', '#@'],
|
|
|
|
data: {
|
|
|
|
preferredTemplate: null,
|
2024-03-03 20:36:17 -05:00
|
|
|
isMobile: false,
|
|
|
|
adaptedTemplates: [
|
|
|
|
{ key: 'default', name: 'Default', icon: 'th large' },
|
|
|
|
{ key: 'angel-kanade', name: 'AngelKanade', icon: 'square' },
|
2024-06-16 06:04:27 -04:00
|
|
|
{ key: 'server-status', name: 'ServerStatus', icon: 'list' }
|
2024-03-03 20:36:17 -05:00
|
|
|
]
|
2024-02-25 20:31:16 -05:00
|
|
|
},
|
|
|
|
created() {
|
|
|
|
this.isMobile = this.checkIsMobile();
|
|
|
|
this.preferredTemplate = this.getCookie('preferred_theme') ? this.getCookie('preferred_theme') : this.$root.defaultTemplate;
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
toggleTemplate(template) {
|
|
|
|
if( template != this.preferredTemplate){
|
|
|
|
this.preferredTemplate = template;
|
|
|
|
this.updateCookie("preferred_theme", template);
|
|
|
|
window.location.reload();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
updateCookie(name, value) {
|
|
|
|
document.cookie = name + "=" + value +"; path=/";
|
|
|
|
},
|
|
|
|
getCookie(name) {
|
|
|
|
const cookies = document.cookie.split(';');
|
|
|
|
let cookieValue = null;
|
|
|
|
for (let i = 0; i < cookies.length; i++) {
|
|
|
|
const cookie = cookies[i].trim();
|
|
|
|
if (cookie.startsWith(name + '=')) {
|
|
|
|
cookieValue = cookie.substring(name.length + 1, cookie.length);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return cookieValue;
|
|
|
|
},
|
|
|
|
checkIsMobile() { // 检测设备类型,页面宽度小于768px认为是移动设备
|
|
|
|
return window.innerWidth <= 768;
|
|
|
|
},
|
|
|
|
logOut(id) {
|
|
|
|
$.ajax({
|
|
|
|
type: 'POST',
|
|
|
|
url: '/api/logout',
|
|
|
|
data: JSON.stringify({ id: id }),
|
|
|
|
contentType: 'application/json',
|
|
|
|
success: function (resp) {
|
|
|
|
if (resp.code == 200) {
|
|
|
|
window.location.reload();
|
|
|
|
} else {
|
|
|
|
alert('注销失败(Error ' + resp.code + '): ' + resp.message);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
error: function (err) {
|
|
|
|
alert('网络错误: ' + err.responseText);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|