mirror of
https://github.com/ankitects/anki.git
synced 2025-09-19 14:32:22 -04:00

* Update to Svelte 5
* Fix `<tr> is invalid inside <table>`
* Update sveltekit-svg to match svelte version
Fixes deck options failing to load, and a bunch of warnings with
./yarn dev
* Fix graph tooltips
* Fix editor loading
* Fix MathJax editor not loading
* Formatting
* Fix new formatting errors
* Merge remote-tracking branch 'origin/main' into svelte5
* Remove slot inside EditorToolbar
I think this is just stray code left over from a refactor, but I'm
not 100% sure.
Fixes
Error: Object literal may only specify known properties, and 'children' does not exist in type '{ size: number; wrap: boolean; api?: Partial<EditorToolbarAPI> | undefined; }'. (ts)
<div class="note-editor">
<EditorToolbar {size} {wrap} api={toolbar}>
<slot slot="notetypeButtons" name="notetypeButtons" />
* Fix component typing error
* Comment out svelte/internal exports, so editor loads
* Fix image occlusions in editor
* Revert "Remove slot inside EditorToolbar"
This reverts commit b3095e07ac
,
which prevented the Preview button from showing in the browser.
This will break our tests again.
* Update vite
* Disable routes/tmp for now
* Fix references issue in routes/tmp
66 lines
2.3 KiB
Svelte
66 lines
2.3 KiB
Svelte
<!--
|
|
Copyright: Ankitects Pty Ltd and contributors
|
|
License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html
|
|
-->
|
|
<script lang="ts">
|
|
import { promiseWithResolver } from "@tslib/promise";
|
|
|
|
import type { StyleLinkType, StyleObject } from "./CustomStyles.svelte";
|
|
import CustomStyles from "./CustomStyles.svelte";
|
|
import { mount } from "svelte";
|
|
|
|
export let callback: (styles: Record<string, any>) => void;
|
|
|
|
const [userBaseStyle, userBaseResolve] = promiseWithResolver<StyleObject>();
|
|
const [userBaseRule, userBaseRuleResolve] = promiseWithResolver<CSSStyleRule>();
|
|
|
|
const stylesDidLoad: Promise<unknown> = Promise.all([userBaseStyle, userBaseRule]);
|
|
|
|
userBaseStyle.then((baseStyle: StyleObject) => {
|
|
const sheet = baseStyle.element.sheet as CSSStyleSheet;
|
|
const baseIndex = sheet.insertRule("anki-editable {}");
|
|
userBaseRuleResolve(sheet.cssRules[baseIndex] as CSSStyleRule);
|
|
});
|
|
|
|
export let color: string;
|
|
export let fontFamily: string;
|
|
export let fontSize: number;
|
|
export let direction: "ltr" | "rtl";
|
|
|
|
async function setStyling(property: string, value: unknown): Promise<void> {
|
|
const rule = await userBaseRule;
|
|
rule.style[property] = value;
|
|
|
|
// if we don't set the textContent of the underlying HTMLStyleElement, addons
|
|
// which extend the custom style and set textContent of their registered tags
|
|
// will cause the userBase style tag here to be ignored
|
|
const baseStyle = await userBaseStyle;
|
|
baseStyle.element.textContent = rule.cssText;
|
|
}
|
|
|
|
$: setStyling("color", color);
|
|
$: setStyling("fontFamily", fontFamily);
|
|
$: setStyling("fontSize", fontSize + "px");
|
|
$: setStyling("direction", direction);
|
|
|
|
const styles = [
|
|
{
|
|
id: "rootStyle",
|
|
type: "link" as "link",
|
|
href: "./_anki/css/editable.css",
|
|
} as StyleLinkType,
|
|
];
|
|
|
|
function attachToShadow(element: Element) {
|
|
const customStyles = mount(CustomStyles, {
|
|
target: element.shadowRoot as any,
|
|
props: { styles },
|
|
});
|
|
customStyles.addStyleTag("userBase").then((styleTag) => {
|
|
userBaseResolve(styleTag);
|
|
callback(customStyles);
|
|
});
|
|
}
|
|
</script>
|
|
|
|
<slot {attachToShadow} {stylesDidLoad} />
|