Added toasts to export/import success

This commit is contained in:
Mitchell McCaffrey 2021-02-16 17:32:41 +11:00
parent b809cdf620
commit b8d3c24e1d

View File

@ -3,6 +3,7 @@ import { Box, Label, Text, Button, Flex } from "theme-ui";
import { saveAs } from "file-saver"; import { saveAs } from "file-saver";
import * as Comlink from "comlink"; import * as Comlink from "comlink";
import shortid from "shortid"; import shortid from "shortid";
import { useToasts } from "react-toast-notifications";
import Modal from "../components/Modal"; import Modal from "../components/Modal";
import LoadingOverlay from "../components/LoadingOverlay"; import LoadingOverlay from "../components/LoadingOverlay";
@ -23,6 +24,7 @@ const importDBName = "OwlbearRodeoImportDB";
function ImportExportModal({ isOpen, onRequestClose }) { function ImportExportModal({ isOpen, onRequestClose }) {
const { userId } = useAuth(); const { userId } = useAuth();
const [isLoading, setIsLoading] = useState(false); const [isLoading, setIsLoading] = useState(false);
const [error, setError] = useState(); const [error, setError] = useState();
@ -32,6 +34,19 @@ function ImportExportModal({ isOpen, onRequestClose }) {
const [showImportSelector, setShowImportSelector] = useState(false); const [showImportSelector, setShowImportSelector] = useState(false);
const [showExportSelector, setShowExportSelector] = useState(false); const [showExportSelector, setShowExportSelector] = useState(false);
const { addToast } = useToasts();
function addSuccessToast(message, maps, tokens) {
const mapText = `${maps.length} map${maps.length > 1 ? "s" : ""}`;
const tokenText = `${tokens.length} token${tokens.length > 1 ? "s" : ""}`;
if (maps.length > 0 && tokens.length > 0) {
addToast(`${message} ${mapText} and ${tokenText}`);
} else if (maps.length > 0) {
addToast(`${message} ${mapText}`);
} else if (tokens.length > 0) {
addToast(`${message} ${tokenText}`);
}
}
function openFileDialog() { function openFileDialog() {
if (fileInputRef.current) { if (fileInputRef.current) {
fileInputRef.current.click(); fileInputRef.current.click();
@ -116,45 +131,49 @@ function ImportExportModal({ isOpen, onRequestClose }) {
const importDB = getDatabase({}, importDBName); const importDB = getDatabase({}, importDBName);
const db = getDatabase({}); const db = getDatabase({});
try {
// Keep track of a mapping of old token ids to new ones to apply them to the map states // Keep track of a mapping of old token ids to new ones to apply them to the map states
let newTokenIds = {}; let newTokenIds = {};
if (checkedTokens.length > 0) { if (checkedTokens.length > 0) {
const tokenIds = checkedTokens.map((token) => token.id); const tokenIds = checkedTokens.map((token) => token.id);
const tokensToAdd = await importDB.table("tokens").bulkGet(tokenIds); const tokensToAdd = await importDB.table("tokens").bulkGet(tokenIds);
let newTokens = []; let newTokens = [];
for (let token of tokensToAdd) { for (let token of tokensToAdd) {
const newId = shortid.generate(); const newId = shortid.generate();
newTokenIds[token.id] = newId; newTokenIds[token.id] = newId;
// Generate new id and change owner // Generate new id and change owner
newTokens.push({ ...token, id: newId, owner: userId }); newTokens.push({ ...token, id: newId, owner: userId });
}
await db.table("tokens").bulkAdd(newTokens);
}
if (checkedMaps.length > 0) {
const mapIds = checkedMaps.map((map) => map.id);
const mapsToAdd = await importDB.table("maps").bulkGet(mapIds);
let newMaps = [];
let newStates = [];
for (let map of mapsToAdd) {
let state = await importDB.table("states").get(map.id);
// Apply new token ids to imported state
for (let tokenState of Object.values(state.tokens)) {
if (tokenState.tokenId in newTokenIds) {
state.tokens[tokenState.id].tokenId =
newTokenIds[tokenState.tokenId];
}
} }
const newId = shortid.generate(); await db.table("tokens").bulkAdd(newTokens);
// Generate new id and change owner
newMaps.push({ ...map, id: newId, owner: userId });
newStates.push({ ...state, mapId: newId });
} }
await db.table("maps").bulkAdd(newMaps);
await db.table("states").bulkAdd(newStates);
}
if (checkedMaps.length > 0) {
const mapIds = checkedMaps.map((map) => map.id);
const mapsToAdd = await importDB.table("maps").bulkGet(mapIds);
let newMaps = [];
let newStates = [];
for (let map of mapsToAdd) {
let state = await importDB.table("states").get(map.id);
// Apply new token ids to imported state
for (let tokenState of Object.values(state.tokens)) {
if (tokenState.tokenId in newTokenIds) {
state.tokens[tokenState.id].tokenId =
newTokenIds[tokenState.tokenId];
}
}
const newId = shortid.generate();
// Generate new id and change owner
newMaps.push({ ...map, id: newId, owner: userId });
newStates.push({ ...state, mapId: newId });
}
await db.table("maps").bulkAdd(newMaps);
await db.table("states").bulkAdd(newStates);
}
addSuccessToast("Imported", checkedMaps, checkedTokens);
} catch (e) {
console.error(e);
setError(new Error("Unable to import data"));
}
await importDB.delete(); await importDB.delete();
importDB.close(); importDB.close();
db.close(); db.close();
@ -195,6 +214,7 @@ function ImportExportModal({ isOpen, onRequestClose }) {
tokenIds tokenIds
); );
saveAs(blob, `${shortid.generate()}.owlbear`); saveAs(blob, `${shortid.generate()}.owlbear`);
addSuccessToast("Exported", checkedMaps, checkedTokens);
} catch (e) { } catch (e) {
setError(e); setError(e);
} }