1
0
Fork 0
mirror of https://github.com/bra1n/townsquare.git synced 2025-04-04 22:24:36 +00:00
townsquare/src/store/persistence.js
Pingumask 67ff3ddf6a Upgrade node to 22, bundle with vite
Updated docker compose for --watch usage
2024-12-09 22:26:20 +01:00

198 lines
5.8 KiB
JavaScript

export default (store) => {
const updatePagetitle = (isPublic) =>
(document.title = `Blood on the Clocktower ${
isPublic ? "Town Square" : "Grimoire"
}`);
// initialize data
if (localStorage.getItem("background")) {
store.commit("setBackground", localStorage.background);
}
if (localStorage.getItem("muted")) {
store.commit("toggleMuted", true);
}
if (localStorage.getItem("static")) {
store.commit("toggleStatic", true);
}
if (localStorage.getItem("imageOptIn")) {
store.commit("toggleImageOptIn", true);
}
if (localStorage.getItem("streamerMode")) {
store.commit("toggleStreamerMode", true);
}
if (localStorage.getItem("zoom")) {
store.commit("setZoom", parseFloat(localStorage.getItem("zoom")));
}
if (localStorage.getItem("isGrimoire")) {
store.commit("toggleGrimoire", false);
updatePagetitle(false);
}
if (localStorage.roles !== undefined) {
store.commit("setCustomRoles", JSON.parse(localStorage.roles));
store.commit("setEdition", { id: "custom" });
}
if (localStorage.edition !== undefined) {
// this will initialize state.roles for official editions
store.commit("setEdition", JSON.parse(localStorage.edition));
}
if (localStorage.bluffs !== undefined) {
JSON.parse(localStorage.bluffs).forEach((role, index) => {
store.commit("players/setBluff", {
index,
role: store.state.roles.get(role) || {},
});
});
}
if (localStorage.fabled !== undefined) {
store.commit("players/setFabled", {
fabled: JSON.parse(localStorage.fabled).map(
(fabled) => store.state.fabled.get(fabled.id) || fabled,
),
});
}
if (localStorage.players) {
store.commit(
"players/set",
JSON.parse(localStorage.players).map((player) => ({
...player,
role:
store.state.roles.get(player.role) ||
store.getters.rolesJSONbyId.get(player.role) ||
{},
})),
);
}
/**** Session related data *****/
if (localStorage.getItem("playerId")) {
store.commit("session/setPlayerId", localStorage.getItem("playerId"));
}
if (localStorage.getItem("session") && !window.location.hash.substr(1)) {
const [spectator, sessionId] = JSON.parse(localStorage.getItem("session"));
store.commit("session/setSpectator", spectator);
store.commit("session/setSessionId", sessionId);
}
// listen to mutations
store.subscribe(({ type, payload }, state) => {
switch (type) {
case "toggleGrimoire":
if (!state.grimoire.isPublic) {
localStorage.setItem("isGrimoire", 1);
} else {
localStorage.removeItem("isGrimoire");
}
updatePagetitle(state.grimoire.isPublic);
break;
case "setBackground":
if (payload) {
localStorage.setItem("background", payload);
} else {
localStorage.removeItem("background");
}
break;
case "toggleMuted":
if (state.grimoire.isMuted) {
localStorage.setItem("muted", 1);
} else {
localStorage.removeItem("muted");
}
break;
case "toggleStatic":
if (state.grimoire.isStatic) {
localStorage.setItem("static", 1);
} else {
localStorage.removeItem("static");
}
break;
case "toggleImageOptIn":
if (state.grimoire.isImageOptIn) {
localStorage.setItem("imageOptIn", 1);
} else {
localStorage.removeItem("imageOptIn");
}
break;
case "toggleStreamerMode":
if (state.grimoire.isStreamerMode) {
localStorage.setItem("streamerMode", 1);
} else {
localStorage.removeItem("streamerMode");
}
break;
case "setZoom":
if (payload !== 0) {
localStorage.setItem("zoom", payload);
} else {
localStorage.removeItem("zoom");
}
break;
case "setEdition":
localStorage.setItem("edition", JSON.stringify(payload));
if (state.edition.isOfficial) {
localStorage.removeItem("roles");
}
break;
case "setCustomRoles":
if (!payload.length) {
localStorage.removeItem("roles");
} else {
localStorage.setItem("roles", JSON.stringify(payload));
}
break;
case "players/setBluff":
localStorage.setItem(
"bluffs",
JSON.stringify(state.players.bluffs.map(({ id }) => id)),
);
break;
case "players/setFabled":
localStorage.setItem(
"fabled",
JSON.stringify(
state.players.fabled.map((fabled) =>
fabled.isCustom ? fabled : { id: fabled.id },
),
),
);
break;
case "players/add":
case "players/update":
case "players/remove":
case "players/clear":
case "players/set":
case "players/swap":
case "players/move":
if (state.players.players.length) {
localStorage.setItem(
"players",
JSON.stringify(
state.players.players.map((player) => ({
...player,
// simplify the stored data
role: player.role.id || {},
})),
),
);
} else {
localStorage.removeItem("players");
}
break;
case "session/setSessionId":
if (payload) {
localStorage.setItem(
"session",
JSON.stringify([state.session.isSpectator, payload]),
);
} else {
localStorage.removeItem("session");
}
break;
case "session/setPlayerId":
if (payload) {
localStorage.setItem("playerId", payload);
} else {
localStorage.removeItem("playerId");
}
break;
}
});
};