f6486da233
* Allow user to select I/O notetype instead of enforcing a specific name * Display a clearer error when I/O note is missing an image Opening the card layout screen from "manage notetypes" was showing an error about the Anki version being too old. Replacement error is not currently translatable. * Preserve existing notetype when adding I/O notetype * Add a 'from clipboard' string The intention is to use this in the future to allow an image occlusion to be created from an image on the clipboard. * Tweak I/O init - Use union type instead of multiple nullable values - Pass the notetype id in to initialization * Fix image insertion in I/O note - The regex expected double quotes, and we were using single ones - Image tags don't need to be closed * Use more consistent naming in image_occlusion.proto * Tweaks to default I/O notetype - Show the header on the front side as well (I presume this is what users expect; if not am happy to revert) - Don't show comments on card (again, I presume users expect to use this field to add notes that aren't displayed during review, as they can use back extra for that) * Fix sticky footer missing background Caused by earlier CSS refactoring
44 lines
1.2 KiB
TypeScript
44 lines
1.2 KiB
TypeScript
// Copyright: Ankitects Pty Ltd and contributors
|
|
// License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html
|
|
|
|
import "./image-occlusion-base.scss";
|
|
|
|
import { ModuleName, setupI18n } from "@tslib/i18n";
|
|
|
|
import { checkNightMode } from "../lib/nightmode";
|
|
import ImageOcclusionPage from "./ImageOcclusionPage.svelte";
|
|
import type { IOMode } from "./lib";
|
|
|
|
const i18n = setupI18n({
|
|
modules: [
|
|
ModuleName.IMPORTING,
|
|
ModuleName.DECKS,
|
|
ModuleName.EDITING,
|
|
ModuleName.NOTETYPES,
|
|
ModuleName.ACTIONS,
|
|
ModuleName.BROWSING,
|
|
],
|
|
});
|
|
|
|
export async function setupImageOcclusion(mode: IOMode): Promise<ImageOcclusionPage> {
|
|
checkNightMode();
|
|
await i18n;
|
|
|
|
return new ImageOcclusionPage({
|
|
target: document.body,
|
|
props: {
|
|
mode,
|
|
},
|
|
});
|
|
}
|
|
|
|
if (window.location.hash.startsWith("#test-")) {
|
|
const imagePath = window.location.hash.replace("#test-", "");
|
|
setupImageOcclusion({ kind: "add", imagePath, notetypeId: 0 });
|
|
}
|
|
|
|
if (window.location.hash.startsWith("#testforedit-")) {
|
|
const noteId = parseInt(window.location.hash.replace("#testforedit-", ""));
|
|
setupImageOcclusion({ kind: "edit", noteId });
|
|
}
|