252 lines
6.5 KiB
JavaScript
252 lines
6.5 KiB
JavaScript
import * as i18n from "@/i18n";
|
|
import { state } from "./state.js";
|
|
import router from "@/router";
|
|
import { emitStateChanged } from './eventBus'; // Import the function from eventBus.js
|
|
import { usersApi } from "@/api";
|
|
import { notify } from "@/notify";
|
|
import { sortedItems } from "@/utils/sort.js";
|
|
|
|
export const mutations = {
|
|
setGallerySize: (value) => {
|
|
state.user.gallerySize = value
|
|
emitStateChanged();
|
|
usersApi.update(state.user, ['gallerySize']);
|
|
},
|
|
setActiveSettingsView: (value) => {
|
|
state.activeSettingsView = value;
|
|
router.push({ hash: "#" + value });
|
|
const element = document.getElementById(value);
|
|
if (element) {
|
|
element.scrollIntoView({
|
|
behavior: "smooth",
|
|
block: "center",
|
|
inline: "nearest",
|
|
});
|
|
}
|
|
emitStateChanged();
|
|
},
|
|
setSettings: (value) => {
|
|
state.settings = value;
|
|
emitStateChanged();
|
|
},
|
|
setMobile() {
|
|
state.isMobile = window.innerWidth <= 800
|
|
emitStateChanged();
|
|
},
|
|
toggleDarkMode() {
|
|
mutations.updateCurrentUser({ "darkMode": !state.user.darkMode });
|
|
emitStateChanged();
|
|
},
|
|
toggleSidebar() {
|
|
if (state.user.stickySidebar) {
|
|
localStorage.setItem("stickySidebar", "false");
|
|
mutations.updateCurrentUser({ "stickySidebar": false }); // turn off sticky when closed
|
|
state.showSidebar = false;
|
|
} else {
|
|
state.showSidebar = !state.showSidebar;
|
|
}
|
|
emitStateChanged();
|
|
},
|
|
closeSidebar() {
|
|
if (state.showSidebar) {
|
|
state.showSidebar = false;
|
|
emitStateChanged();
|
|
}
|
|
},
|
|
setUpload(value) {
|
|
state.upload = value;
|
|
emitStateChanged();
|
|
},
|
|
setUsage: (value) => {
|
|
state.usage = value;
|
|
emitStateChanged();
|
|
},
|
|
closeHovers: () => {
|
|
state.prompts = [];
|
|
if (!state.stickySidebar) {
|
|
state.showSidebar = false;
|
|
}
|
|
emitStateChanged();
|
|
},
|
|
showHover: (value) => {
|
|
if (typeof value === "object") {
|
|
state.prompts.push({
|
|
name: value?.name,
|
|
confirm: value?.confirm,
|
|
action: value?.action,
|
|
props: value?.props,
|
|
});
|
|
} else {
|
|
state.prompts.push({
|
|
name: value,
|
|
confirm: value?.confirm,
|
|
action: value?.action,
|
|
props: value?.props,
|
|
});
|
|
}
|
|
emitStateChanged();
|
|
},
|
|
showError: () => {
|
|
state.prompts.push("error");
|
|
emitStateChanged();
|
|
},
|
|
setLoading: (loadType, status) => {
|
|
if (status === false) {
|
|
delete state.loading[loadType];
|
|
} else {
|
|
state.loading = { ...state.loading, [loadType]: true };
|
|
}
|
|
emitStateChanged();
|
|
},
|
|
setReload: (value) => {
|
|
state.reload = value;
|
|
emitStateChanged();
|
|
},
|
|
setCurrentUser: (value) => {
|
|
localStorage.setItem("userData", undefined);
|
|
// If value is null or undefined, emit state change and exit early
|
|
if (!value) {
|
|
state.user = value;
|
|
emitStateChanged();
|
|
return;
|
|
}
|
|
|
|
if (value.username != "publicUser") {
|
|
localStorage.setItem("userData", JSON.stringify(value));
|
|
}
|
|
// Ensure locale exists and is valid
|
|
if (!value.locale) {
|
|
value.locale = i18n.detectLocale(); // Default to detected locale if missing
|
|
}
|
|
state.user = value;
|
|
// Emit state change after setting the user and locale
|
|
emitStateChanged();
|
|
},
|
|
setJWT: (value) => {
|
|
state.jwt = value;
|
|
emitStateChanged();
|
|
},
|
|
setSession: (value) => {
|
|
state.sessionId = value;
|
|
emitStateChanged();
|
|
},
|
|
setMultiple: (value) => {
|
|
state.multiple = value;
|
|
if (value == true) {
|
|
notify.showMultipleSelection()
|
|
} else {
|
|
notify.closePopUp()
|
|
}
|
|
emitStateChanged();
|
|
},
|
|
addSelected: (value) => {
|
|
console.log("addSelected", value)
|
|
state.selected.push(value);
|
|
emitStateChanged();
|
|
},
|
|
removeSelected: (value) => {
|
|
console.log("removeSelected", value)
|
|
|
|
let i = state.selected.indexOf(value);
|
|
if (i === -1) return;
|
|
state.selected.splice(i, 1);
|
|
emitStateChanged();
|
|
},
|
|
resetSelected: () => {
|
|
console.log("resetSelected")
|
|
|
|
state.selected = [];
|
|
mutations.setMultiple(false);
|
|
emitStateChanged();
|
|
},
|
|
setRaw: (value) => {
|
|
state.previewRaw = value;
|
|
emitStateChanged();
|
|
},
|
|
updateCurrentUser: (value) => {
|
|
localStorage.setItem("userData", undefined);
|
|
// Ensure the input is a valid object
|
|
if (typeof value !== "object" || value === null) return;
|
|
|
|
// Initialize state.user if it's null
|
|
if (!state.user) {
|
|
state.user = {};
|
|
}
|
|
|
|
// Store previous state for comparison
|
|
const previousUser = { ...state.user };
|
|
|
|
// Merge the new values into the current user state
|
|
state.user = { ...state.user, ...value };
|
|
|
|
// Handle locale change
|
|
if (state.user.locale !== previousUser.locale) {
|
|
//state.user.locale = i18n.detectLocale();
|
|
i18n.setLocale(state.user.locale);
|
|
i18n.default.locale = state.user.locale;
|
|
}
|
|
|
|
// Update localStorage if stickySidebar exists
|
|
if ('stickySidebar' in state.user) {
|
|
localStorage.setItem("stickySidebar", state.user.stickySidebar);
|
|
}
|
|
// Update users if there's any change in state.user
|
|
if (JSON.stringify(state.user) !== JSON.stringify(previousUser)) {
|
|
usersApi.update(state.user, Object.keys(value));
|
|
}
|
|
|
|
if (state.user.username != "publicUser") {
|
|
localStorage.setItem("userData", JSON.stringify(state.user));
|
|
}
|
|
// Emit state change event
|
|
emitStateChanged();
|
|
},
|
|
replaceRequest: (value) => {
|
|
state.selected = [];
|
|
if (!value?.items) {
|
|
state.req = value;
|
|
emitStateChanged();
|
|
return
|
|
}
|
|
if (state.user.hideDotfiles) {
|
|
value.items = value.items.filter((item) => !item.name.startsWith("."));
|
|
}
|
|
value.items.map((item, index) => {
|
|
item.index = index;
|
|
return item;
|
|
})
|
|
state.req = value;
|
|
emitStateChanged();
|
|
},
|
|
setRoute: (value) => {
|
|
state.route = value;
|
|
emitStateChanged();
|
|
},
|
|
updateListingSortConfig: ({ field, asc }) => {
|
|
state.user.sorting.by = field;
|
|
state.user.sorting.asc = asc;
|
|
emitStateChanged();
|
|
},
|
|
updateListingItems: () => {
|
|
state.req.items = sortedItems(state.req.items, state.user.sorting.by)
|
|
mutations.replaceRequest(state.req);
|
|
emitStateChanged();
|
|
},
|
|
updateClipboard: (value) => {
|
|
state.clipboard.key = value.key;
|
|
state.clipboard.items = value.items;
|
|
state.clipboard.path = value.path;
|
|
emitStateChanged();
|
|
},
|
|
resetClipboard: () => {
|
|
state.clipboard.key = "";
|
|
state.clipboard.items = [];
|
|
emitStateChanged();
|
|
},
|
|
setSharePassword: (value) => {
|
|
state.sharePassword = value;
|
|
emitStateChanged();
|
|
}
|
|
};
|
|
|