1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261 |
- /*
- THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
- if you want to view the source, please visit the github repository of this plugin
- */
- var __defProp = Object.defineProperty;
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
- var __getOwnPropNames = Object.getOwnPropertyNames;
- var __hasOwnProp = Object.prototype.hasOwnProperty;
- var __export = (target, all) => {
- for (var name in all)
- __defProp(target, name, { get: all[name], enumerable: true });
- };
- var __copyProps = (to, from, except, desc) => {
- if (from && typeof from === "object" || typeof from === "function") {
- for (let key of __getOwnPropNames(from))
- if (!__hasOwnProp.call(to, key) && key !== except)
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
- }
- return to;
- };
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
- // main.ts
- var main_exports = {};
- __export(main_exports, {
- default: () => FastTextColorPlugin
- });
- module.exports = __toCommonJS(main_exports);
- var import_obsidian8 = require("obsidian");
- // src/FastTextColorSettings.ts
- var import_obsidian4 = require("obsidian");
- // src/color/TextColor.ts
- var TextColor = class {
- /**
- * Create a basic Text Color
- *
- * @param {string} color - [TODO:description]
- * @param {string} id - the id or name of the color
- * @param {string} themeName - the associated theme that this color belongs to
- * @param {boolean} [italic] - italic text
- * @param {boolean} [bold] - bold text
- * @param {number} [cap_mode_index] - the index for the cap mode
- * @param {number} [line_mode_index] - the index for the line mode
- * @param {string} [keybind] - the associated keybind
- * @param {string} colorVariable - the builtin Css color variable that this color uses.
- */
- constructor(color, id, themeName, italic = false, bold = false, cap_mode_index = 0, line_mode_index = 0, keybind = "", useCssColorVariable = false, colorVariable = "--color-base-00") {
- this.color = color;
- this.id = id;
- this.keybind = keybind;
- this.italic = italic;
- this.bold = bold;
- this.cap_mode = new CycleState(["normal", "all_caps", "small_caps"], cap_mode_index);
- this.line_mode = new CycleState(["none", "underline", "overline", "line-through"], line_mode_index);
- this.useCssColorVariable = useCssColorVariable;
- this.colorVariable = colorVariable;
- this.className = `${CSS_COLOR_PREFIX}${themeName}-${this.id}`;
- }
- getCssClass() {
- return `.${CSS_COLOR_PREFIX}${this.id} {
- color : ${this.useCssColorVariable ? `var(${this.colorVariable})` : this.color}
- ;
- ${this.italic ? "font-style: italic;\n" : ""}
- ${this.bold ? "font-weight: bold;\n" : ""}
- ${this.line_mode.state != "none" ? `text-decoration: ${this.line_mode.state};
- ` : ""}
- ${this.cap_mode.state == "all_caps" ? "text-transform: uppercase;\n" : this.cap_mode.state == "small_caps" ? "font-variant: small-caps;\n" : ""}
- ${VAR_COLOR_PREFIX}${this.id} : ${this.color};
- }`;
- }
- /**
- * get the inner css of the class for the color.
- *
- * @returns {string} the inner css.
- */
- getInnerCss() {
- return `color : ${this.useCssColorVariable ? `var(${this.colorVariable})` : this.color};
- ${this.italic ? "font-style: italic;\n" : ""}${this.bold ? "font-weight: bold;\n" : ""}${this.line_mode.state != "none" ? `text-decoration: ${this.line_mode.state};
- ` : ""}${this.cap_mode.state == "all_caps" ? "text-transform: uppercase;\n" : this.cap_mode.state == "small_caps" ? "font-variant: small-caps;\n" : ""}`;
- }
- getCssInlineStyle() {
- return `color : ${this.useCssColorVariable ? `var(${this.colorVariable})` : this.color}
- ;
- ${this.italic ? "font-style: italic;" : ""}
- ${this.bold ? "font-weight: bold;" : ""}
- ${this.line_mode.state != "none" ? `text-decoration: ${this.line_mode.state};` : ""}
- ${this.cap_mode.state == "all_caps" ? "text-transform: uppercase;" : this.cap_mode.state == "small_caps" ? "font-variant: small-caps;" : ""}
- `;
- }
- };
- var CycleState = class {
- constructor(states, index = 0) {
- this.states = states;
- if (states.length <= 0) {
- this.state = "error";
- return;
- }
- this.state = this.states[index];
- this.index = index;
- }
- cycle() {
- this.index = (this.index + 1) % this.states.length;
- this.state = this.states[this.index];
- }
- };
- // src/color/TextColorTheme.ts
- var TextColorTheme = class {
- constructor(name, colors) {
- this.colors = colors;
- this.name = name;
- }
- };
- // src/utils/ConfirmationModal.ts
- var import_obsidian = require("obsidian");
- var ConfirmationModal = class extends import_obsidian.Modal {
- constructor(app, message, heading) {
- super(app);
- this.message = message;
- this.heading = heading;
- this.confirmed = false;
- this.finished = false;
- }
- onOpen() {
- const { contentEl } = this;
- contentEl.createEl("h1", { text: this.heading });
- contentEl.createDiv({ text: this.message });
- new import_obsidian.Setting(contentEl).addButton((btn) => btn.setButtonText("OK").setCta().onClick(() => {
- this.finished = true;
- this.confirmed = true;
- })).addButton((btn) => btn.setButtonText("Cancel").setCta().onClick(() => {
- this.finished = true;
- }));
- }
- onClose() {
- let { contentEl } = this;
- contentEl.empty();
- }
- };
- async function confirmByModal(app, message = "", heading = "") {
- let modal = new ConfirmationModal(app, message != "" ? message : "Are you sure?", heading != "" ? heading : "Confirm");
- modal.open();
- while (!modal.finished) {
- await sleep(16);
- }
- let result = modal.confirmed;
- modal.close();
- return result;
- }
- // src/utils/CreateNewThemeModal.ts
- var import_obsidian2 = require("obsidian");
- var CreateNewThemeModal = class extends import_obsidian2.Modal {
- constructor(app, settings) {
- super(app);
- this.settings = settings;
- this.name = "newTheme";
- }
- onOpen() {
- const { contentEl } = this;
- contentEl.createEl("h1", { text: "Create new theme" });
- new import_obsidian2.Setting(contentEl).setName(this.name).addText((txt) => {
- txt.setValue(this.name).setPlaceholder("Theme name").onChange((value) => {
- this.name = value;
- this.evalNameErrors();
- });
- });
- this.errorDiv = contentEl.createDiv();
- this.errorDiv.addClass("ftc-theme-name-error");
- new import_obsidian2.Setting(contentEl).addButton((btn) => {
- btn.setButtonText("create").onClick((evt) => {
- if (!this.evalNameErrors()) {
- return;
- }
- addTheme(this.settings, this.name, DEFAULT_COLORS);
- this.doOnSuccess();
- this.close();
- });
- }).addButton((btn) => {
- btn.setButtonText("cancel").onClick((evt) => {
- this.close();
- });
- });
- }
- onClose() {
- let { contentEl } = this;
- contentEl.empty();
- }
- onSuccess(callback) {
- this.doOnSuccess = callback;
- }
- evalNameErrors() {
- if (this.settings.themes.some((theme) => {
- return theme.name == this.name;
- })) {
- this.errorDiv.innerText = "a theme with this name already exists.";
- return false;
- }
- if (this.name == "") {
- this.errorDiv.innerText = "name can not be empty.";
- return false;
- }
- this.errorDiv.innerText = "";
- return true;
- }
- };
- // src/utils/KeyBindModal.ts
- var import_obsidian3 = require("obsidian");
- var KeyBindModal = class extends import_obsidian3.Modal {
- constructor(app) {
- super(app);
- this.finished = false;
- }
- onOpen() {
- const { contentEl } = this;
- contentEl.createEl("h1", { text: "Press any key" });
- this.handler = this.handleKeypress.bind(this);
- window.addEventListener("keypress", this.handler);
- new import_obsidian3.Setting(contentEl).addButton((btn) => {
- btn.setButtonText("Cancel").onClick((evt) => {
- this.close();
- });
- });
- }
- onClose() {
- let { contentEl } = this;
- contentEl.empty();
- }
- handleKeypress(evt) {
- this.result = evt.key.toUpperCase();
- this.modalEl.removeEventListener("keypress", this.handler, true);
- this.finished = true;
- }
- };
- async function getKeyBindWithModal(app) {
- let modal = new KeyBindModal(app);
- modal.open();
- while (!modal.finished) {
- await sleep(16);
- }
- let result = modal.result;
- modal.close();
- return result;
- }
- // src/FastTextColorSettings.ts
- var CSS_COLOR_PREFIX = "ftc-color-";
- var VAR_COLOR_PREFIX = "--ftc-color-";
- var SETTINGS_VERSION = "3";
- var BUILTIN_COLORS = [
- new TextColor("#000000", "red", "builtin", false, false, 0, 0, "R", true, "--color-red"),
- new TextColor("#000000", "orange", "builtin", false, false, 0, 0, "O", true, "--color-orange"),
- new TextColor("#000000", "yellow", "builtin", false, false, 0, 0, "Y", true, "--color-yellow"),
- new TextColor("#000000", "green", "builtin", false, false, 0, 0, "G", true, "--color-green"),
- new TextColor("#000000", "cyan", "builtin", false, false, 0, 0, "C", true, "--color-cyan"),
- new TextColor("#000000", "blue", "builtin", false, false, 0, 0, "B", true, "--color-blue"),
- new TextColor("#000000", "purple", "builtin", false, false, 0, 0, "P", true, "--color-purple"),
- new TextColor("#000000", "pink", "builtin", false, false, 0, 0, "I", true, "--color-pink")
- ];
- var DEFAULT_COLORS = [
- new TextColor("#ff0000", `red`, "default", false, false, 0, 0, "R"),
- new TextColor("#00ff00", `green`, "default", false, false, 0, 0, "G"),
- new TextColor("#0000ff", `blue`, "default", false, false, 0, 0, "B"),
- new TextColor("#00ffff", `cyan`, "default", false, false, 0, 0, "C"),
- new TextColor("#ff00ff", `magenta`, "default", false, false, 0, 0, "M"),
- new TextColor("#ffff00", `yellow`, "default", false, false, 0, 0, "Y"),
- new TextColor("#000000", `black`, "default", false, false, 0, 0, "K")
- ];
- var DEFAULT_SETTINGS = {
- themes: [new TextColorTheme("default", DEFAULT_COLORS), new TextColorTheme("builtin", BUILTIN_COLORS)],
- themeIndex: 0,
- version: SETTINGS_VERSION,
- interactiveDelimiters: true,
- useKeybindings: true,
- useNodeRebuilding: false
- };
- function getColors(settings, index = -1) {
- if (index == -1) {
- index = settings.themeIndex;
- }
- return settings.themes[index].colors;
- }
- function getCurrentTheme(settings, index = -1) {
- if (index == -1) {
- index = settings.themeIndex;
- }
- return settings.themes[index];
- }
- function addTheme(settings, name, colors = DEFAULT_COLORS) {
- settings.themes.push(new TextColorTheme(name, colors));
- }
- function deleteTheme(settings, index = -1) {
- if (settings.themes.length <= 1) {
- return;
- }
- if (index == -1) {
- index = settings.themeIndex;
- }
- settings.themes.remove(settings.themes[index]);
- if (index <= settings.themeIndex) {
- settings.themeIndex = Math.max(settings.themeIndex - 1, 0);
- }
- }
- function updateSettings(settings) {
- switch (settings.version) {
- case "1":
- case "2":
- const colors = settings.colors.map((color) => {
- return new TextColor(color.color, color.id, "default", color.italic, color.bold, color.cap_mode.index, color.line_mode.index, color.keybind);
- });
- const outSettings = {
- themes: [new TextColorTheme("default", colors)],
- themeIndex: 0,
- version: SETTINGS_VERSION,
- interactiveDelimiters: settings.interactiveDelimiters,
- useKeybindings: true,
- useNodeRebuilding: false
- };
- return outSettings;
- default:
- console.log(`There is not update method for Settings Version ${settings.version}!
- ${settings}`);
- return DEFAULT_SETTINGS;
- }
- }
- var FastTextColorPluginSettingTab = class extends import_obsidian4.PluginSettingTab {
- constructor(app, plugin) {
- super(app, plugin);
- this.plugin = plugin;
- this.newId = "";
- this.editThemeIndex = plugin.settings.themeIndex;
- }
- display() {
- const { containerEl } = this;
- const { settings } = this.plugin;
- containerEl.empty();
- new import_obsidian4.Setting(containerEl).setName("Colors").setHeading();
- new import_obsidian4.Setting(containerEl).setName("Set active theme").setDesc("Set global active theme.").addDropdown((dd) => {
- let count2 = 0;
- settings.themes.forEach((theme) => {
- dd.addOption(count2.toString(), theme.name);
- count2++;
- });
- dd.setValue(settings.themeIndex.toString());
- dd.onChange((value) => {
- settings.themeIndex = +value;
- this.plugin.saveSettings();
- this.plugin.setCssVariables();
- this.display();
- });
- });
- new import_obsidian4.Setting(containerEl).setName("Edit themes").setDesc("Add new themes or edit existings ones.").setClass("ftc-settings-theme-header").addDropdown((dd) => {
- let count2 = 0;
- settings.themes.forEach((theme) => {
- dd.addOption(count2.toString(), theme.name);
- count2++;
- });
- dd.setValue(this.editThemeIndex.toString());
- dd.onChange((value) => {
- this.editThemeIndex = +value;
- this.display();
- });
- }).addButton((btn) => {
- btn.setIcon("plus").setTooltip("add new Theme").onClick((evt) => {
- const modal = new CreateNewThemeModal(this.app, settings);
- modal.onSuccess(() => {
- this.plugin.saveSettings();
- this.display();
- });
- modal.open();
- });
- }).addButton((btn) => {
- btn.setIcon("trash").setTooltip("delete theme").onClick(async (evt) => {
- if (await confirmByModal(this.app, `Are you sure?
- The theme ${settings.themes[settings.themeIndex].name} will no longer be available. `)) {
- deleteTheme(settings, this.editThemeIndex);
- this.editThemeIndex = 0;
- this.plugin.saveSettings();
- this.display();
- }
- });
- });
- const themeColorsEl = containerEl.createDiv();
- themeColorsEl.addClass("ftc-theme-colors");
- let count = 1;
- getColors(settings, this.editThemeIndex).forEach((color) => {
- this.createColorSetting(themeColorsEl, color, count);
- count++;
- });
- new import_obsidian4.Setting(containerEl).setName("Add new color to theme").setClass("ftc-settings-theme-footer").addText((txt) => {
- txt.setValue(this.newId == "" ? (getColors(settings).length + 1).toString() : this.newId).onChange((value) => {
- this.newId = value;
- });
- }).addButton((btn) => {
- btn.setButtonText("+").onClick(async (evt) => {
- let colors = getColors(settings, this.editThemeIndex);
- if (colors.some((tColor) => {
- return tColor.id == this.newId;
- })) {
- new import_obsidian4.Notice(`color with id ${this.newId} already exists!`);
- }
- let newColorName = this.newId == "" ? (colors.length + 1).toString() : this.newId;
- colors.push(new TextColor("#ffffff", newColorName, getCurrentTheme(settings, this.editThemeIndex).name));
- await this.plugin.saveSettings();
- this.display();
- });
- });
- new import_obsidian4.Setting(containerEl).setName("Other").setHeading();
- new import_obsidian4.Setting(containerEl).setName("Interactive delimiters").setDesc("Use interactive delimiter to change colors inside the editor.").addToggle((tgl) => {
- tgl.setValue(settings.interactiveDelimiters).onChange(async (value) => {
- settings.interactiveDelimiters = value;
- await this.plugin.saveSettings();
- });
- });
- new import_obsidian4.Setting(containerEl).setName("Use keybindings and colormenu").setDesc("If enabled will allow you to use keybindings to activate colors from a custom colormenu.").addToggle((tgl) => {
- tgl.setValue(settings.useKeybindings).onChange(async (value) => {
- settings.useKeybindings = value;
- await this.plugin.saveSettings();
- });
- });
- }
- /**
- * Create a color row in the theme view
- *
- * @param {HTMLElement} container - the root container of the element.
- * @param {TextColor} tColor - the color to be used for display
- * @param {number} count - the index of the color
- */
- createColorSetting(container, tColor, count) {
- let nameFragment = new DocumentFragment();
- let nameDiv = nameFragment.createDiv();
- nameDiv.addClass("ftc-name-div");
- const key = nameDiv.createDiv();
- key.innerText = `${tColor.id}`;
- const exampletext = nameDiv.createDiv();
- exampletext.setAttr("style", tColor.getCssInlineStyle());
- exampletext.innerText = `~={${tColor.id}}This is colored text=~`;
- let saveAndApply = async () => {
- await this.plugin.saveSettings();
- this.plugin.setCssVariables();
- exampletext.setAttr("style", tColor.getCssInlineStyle());
- };
- const setting = new import_obsidian4.Setting(container).setName(nameFragment).setClass("ftc-settings-item").addButton((btn) => {
- btn.setButtonText(`${tColor.keybind}`.toUpperCase()).setTooltip("set keybinding").setClass("key-indicator").onClick(async (evt) => {
- tColor.keybind = await getKeyBindWithModal(this.app);
- btn.setButtonText(`${tColor.keybind}`);
- await this.plugin.saveSettings();
- this.plugin.setCssVariables();
- });
- }).addButton((btn) => {
- btn.setButtonText("B").setTooltip("Bold").setClass("ftc-format-item").onClick(async (evt) => {
- tColor.bold = !tColor.bold;
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.bold);
- btn.buttonEl.setCssStyles({ fontWeight: tColor.bold ? "bold" : "normal" });
- saveAndApply();
- });
- btn.buttonEl.addClass("ftc-format-left");
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.bold);
- btn.buttonEl.setCssStyles({ fontWeight: tColor.bold ? "bold" : "normal" });
- }).addButton((btn) => {
- btn.setButtonText("I").setTooltip("Italic").setClass("ftc-format-item").onClick(async (evt) => {
- tColor.italic = !tColor.italic;
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.italic);
- btn.buttonEl.setCssStyles({ fontStyle: tColor.italic ? "italic" : "normal" });
- saveAndApply();
- });
- btn.buttonEl.addClass("ftc-format-middle");
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.italic);
- btn.buttonEl.setCssStyles({ fontStyle: tColor.italic ? "italic" : "normal" });
- }).addButton((btn) => {
- btn.setButtonText("U").setTooltip("Lining").setClass("ftc-format-item").onClick(async (evt) => {
- tColor.line_mode.cycle();
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.line_mode.state != "none");
- btn.buttonEl.setCssStyles({ textDecoration: tColor.line_mode.state });
- saveAndApply();
- });
- btn.buttonEl.addClass("ftc-format-middle");
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.line_mode.state != "none");
- btn.buttonEl.setCssStyles({ textDecoration: tColor.line_mode.state });
- }).addButton((btn) => {
- btn.setButtonText("Tt").setTooltip("Capitalization").setClass("ftc-format-item").onClick(async (evt) => {
- tColor.cap_mode.cycle();
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.cap_mode.state != "normal");
- btn.buttonEl.toggleClass("ftc-uppercase", tColor.cap_mode.state == "all_caps");
- btn.buttonEl.toggleClass("ftc-small-caps", tColor.cap_mode.state == "small_caps");
- await this.plugin.saveSettings();
- this.plugin.setCssVariables();
- exampletext.setAttr("style", tColor.getCssInlineStyle());
- });
- btn.buttonEl.addClass("ftc-format-right");
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.cap_mode.state != "normal");
- btn.buttonEl.setCssStyles(
- tColor.cap_mode.state == "all_caps" ? { textTransform: "uppercase" } : tColor.cap_mode.state == "small_caps" ? { fontVariant: "small_caps" } : {}
- );
- });
- if (tColor.useCssColorVariable) {
- setting.addDropdown((dd) => {
- dd.addOptions({
- "--color-red": "red",
- "--color-orange": "orange",
- "--color-yellow": "yellow",
- "--color-green": "green",
- "--color-cyan": "cyan",
- "--color-blue": "blue",
- "--color-purple": "purple",
- "--color-pink": "pink"
- // "--color-blue" : "50",
- // "--color-blue" : "60",
- // "--color-blue" : "70",
- // "--color-base-100": "100",
- }).setValue(tColor.colorVariable).onChange((value) => {
- tColor.colorVariable = value;
- saveAndApply();
- });
- });
- } else {
- setting.addColorPicker((cb) => {
- cb.setValue(tColor.color).onChange(async (value) => {
- tColor.color = value;
- saveAndApply();
- });
- });
- }
- setting.addButton((btn) => {
- btn.setTooltip("use builtin obsidian colors").setClass("ftc-format-item-small").onClick(async (evt) => {
- tColor.useCssColorVariable = !tColor.useCssColorVariable;
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.useCssColorVariable);
- saveAndApply();
- this.display();
- });
- btn.buttonEl.toggleClass("ftc-format-item-enabled", tColor.useCssColorVariable);
- }).addButton((btn) => {
- btn.setIcon("chevron-up").setTooltip("move item up").setClass("ftc-move-btn-left").onClick(async (evt) => {
- moveColor(count - 1, -1, this.plugin.settings);
- await this.plugin.saveSettings();
- this.display();
- });
- }).addButton((btn) => {
- btn.setIcon("chevron-down").setTooltip("move item down").setClass("ftc-move-btn-right").onClick(async (evt) => {
- moveColor(count - 1, 1, this.plugin.settings);
- await this.plugin.saveSettings();
- this.display();
- });
- }).addButton((btn) => {
- btn.setIcon("trash").setTooltip("delete color").setClass("ftc-move-btn-right").onClick(async (evt) => {
- if (await confirmByModal(
- this.app,
- `Colored section whith the id "${tColor.id}" will no longer be colored until you add another color with that id.`,
- `Delete color: ${tColor.id}`
- )) {
- getColors(this.plugin.settings).remove(tColor);
- }
- await this.plugin.saveSettings();
- this.display();
- });
- });
- }
- };
- function moveColor(index, direction, settings) {
- if (direction < 0 && index == 0 || direction > 0 && index == getColors(settings).length - 1) {
- return;
- }
- let temp = getColors(settings)[index + direction];
- getColors(settings)[index + direction] = getColors(settings)[index];
- getColors(settings)[index] = temp;
- }
- // src/rendering/TextColorViewPlugin.ts
- var import_state3 = require("@codemirror/state");
- var import_view3 = require("@codemirror/view");
- // src/rendering/TextColorStateField.ts
- var import_state = require("@codemirror/state");
- // src/rendering/language/textColorLanguageParser.js
- var import_lr = require("@lezer/lr");
- var parser = import_lr.LRParser.deserialize({
- version: 14,
- states: "%dQQOPOOOcOQO'#C_OqOPO'#C^O!SOPO'#CmOOOO'#Co'#CoQQOPOOOOOO'#Ca'#CaO!eOQO,59UOOOO,58y,58yOOOO,59U,59UO!pOQO'#C_OOOO'#Cp'#CpO!xOPO'#CeOOOO'#Cf'#CfO#ZOPO'#CqO#lOPO'#CdO#lOPO'#CdO#zOPO'#C^OOOO,58x,58xOOOO'#Cr'#CrO$SOPO,59XOOOO,59X,59XOOOO-E6m-E6mOOOO,58{,58{OOOO1G.p1G.pO$eOQO'#CaOOOO-E6n-E6nOOOO,59],59]OOOO-E6o-E6oOOOO,59O,59OO#lOPO,59OOOOO-E6p-E6pOOOO1G.s1G.sOOOO1G.j1G.j",
- stateData: "$m~OSPOZSO[SObROhSO~OUVOVUO_XO`XO~OSYOZ]O[]O]]OhZO~OSPOZcO[cObeOhcO~OVgO_hO`hO~OUiOVUO~OhZOSXXZXX[XX]XX~OhZOSeXZeX[eX]eX~OSYOZ]O[]O]]O~OSYOhZO~OSPOZcO[cObpOhcO~OVgO~OSZ~",
- goto: "#lgPPhwP!UPP!Y!^!ePPP!oPP!wP!{#R#Z#fSSOTY^Q_`anTcRdWQORTdZaQ_`anTWPYTbQaS`QaRk^QXQSm_`RqnSSOTTcRdTSOTQTORfTU[Q^aRj[S_QaSl_nRn`QdRRod",
- nodeNames: "\u26A0 TextColor Expression TcLeft LMarker Description Color InnerMarker TcRight Text REnd RMarker ENDLN EOF Unfinished ColorEOF ColorWS CodeSection CODE",
- maxTerm: 24,
- skippedNodes: [0],
- repeatNodeCount: 4,
- tokenData: "%f~RcXY!^YZ!c]^!^pq!^qr!^rs!^s!_!^!_!`!p!`#O!^#O#P!}#P#S!^#S#T$q#T#r!^#r#s$v#s;'S!^;'S;=`%Z<%l~!^~O!^~~%a~!cOh~~!hPh~YZ!k~!pO[~~!uPh~#r#s!x~!}OZ~~#SXh~rs!^!P!Q!^#O#P!^#U#V!^#Y#Z!^#b#c!^#f#g!^#h#i!^#i#j#o~#rR!Q![#{!c!i#{#T#Z#{~$OR!Q![$X!c!i$X#T#Z$X~$[R!Q![$e!c!i$e#T#Z$e~$hR!Q![!^!c!i!^#T#Z!^~$vOb~~${Ph~!_!`%O~%RP#o#p%U~%ZOS~~%^P;=`<%l!^~%fO]~",
- tokenizers: [1, new import_lr.LocalTokenGroup("!X~R[X^wpqw#q#r|#y#zw$f$gw#BY#BZw$IS$I_w$I|$JOw$JT$JUw$KV$KWw&FU&FVw~~!R~|O`~~!ROV~~!WO_~~", 54, 6)],
- topRules: { "TextColor": [0, 1] },
- tokenPrec: 164
- });
- // src/rendering/language/textColorLanguage.ts
- var import_language = require("@codemirror/language");
- var textColorLanguage = import_language.LRLanguage.define({
- name: "textColorLanguage",
- parser: parser.configure({})
- });
- // src/rendering/TextColorStateField.ts
- var import_common = require("@lezer/common");
- var import_language2 = require("@codemirror/language");
- var textColorParserField = import_state.StateField.define({
- create(state) {
- const parsedTree = textColorLanguage.parser.parse(state.doc.toString());
- return {
- tree: parsedTree,
- fragment: import_common.TreeFragment.addTree(parsedTree)
- };
- },
- update(value, transaction) {
- if (!transaction.docChanged) {
- return value;
- }
- const changed_ranges = [];
- transaction.changes.iterChangedRanges(
- (from, to, fromB, toB) => changed_ranges.push({ fromA: from, toA: to, fromB, toB })
- );
- let fragments = import_common.TreeFragment.applyChanges(value.fragment, changed_ranges);
- const tree = textColorLanguage.parser.parse(new import_language2.DocInput(transaction.state.doc), fragments);
- fragments = import_common.TreeFragment.addTree(tree, fragments);
- return { tree, fragment: fragments };
- }
- });
- // src/widgets/MarkerWidget.ts
- var import_view = require("@codemirror/view");
- var MarkerWidget = class extends import_view.WidgetType {
- constructor() {
- super();
- }
- toDOM(view) {
- const div = document.createElement("span");
- return div;
- }
- };
- // src/widgets/ColorWidget.ts
- var import_view2 = require("@codemirror/view");
- var import_obsidian5 = require("obsidian");
- // src/SettingsFacet.ts
- var import_state2 = require("@codemirror/state");
- var settingsFacet = import_state2.Facet.define(
- {
- combine: (inputs) => {
- if (inputs.length <= 0) {
- return DEFAULT_SETTINGS;
- }
- return inputs[inputs.length - 1];
- }
- }
- );
- // src/widgets/ColorWidget.ts
- var ColorWidget = class extends import_view2.WidgetType {
- constructor(id, from, to, expressionTo, themeName) {
- super();
- this.id = id;
- this.from = from;
- this.to = to;
- this.expressionTo = expressionTo;
- this.themeName = themeName;
- }
- toDOM(view) {
- const div = document.createElement("span");
- div.addClass(`${CSS_COLOR_PREFIX}${this.themeName}-${this.id}`);
- div.addClass("ftc-color-delimiter");
- div.innerText = "\u2B24";
- const settings = view.state.facet(settingsFacet);
- div.onclick = (event) => {
- if (this.menu != null) {
- }
- view.dispatch({
- selection: {
- anchor: this.from,
- head: this.to
- }
- });
- };
- div.onmouseover = (event) => {
- if (this.menu != null) {
- return;
- }
- this.menu = new import_obsidian5.Menu();
- getColors(settings).forEach((tColor) => {
- this.menu.addItem((item) => {
- item.setTitle(tColor.id).onClick((evt) => {
- view.dispatch({
- changes: {
- from: this.from,
- to: this.to,
- insert: tColor.id
- }
- });
- }).setIcon("palette");
- item.dom.addClass(tColor.className);
- });
- });
- this.menu.addItem((item) => {
- item.setTitle("Remove").setIcon("ban").onClick((evt) => {
- view.dispatch({
- changes: [
- {
- from: this.from - 3,
- to: this.to + 1,
- insert: ""
- },
- {
- from: this.expressionTo - 2,
- to: this.expressionTo,
- insert: ""
- }
- ]
- });
- });
- });
- const rect = div.getBoundingClientRect();
- this.menu.showAtPosition({ x: rect.left, y: rect.bottom });
- };
- return div;
- }
- };
- // src/rendering/TextColorViewPlugin.ts
- var import_obsidian6 = require("obsidian");
- var TextColorViewPlugin = class {
- constructor(view) {
- this.decorations = this.buildDecorations(view);
- }
- update(update) {
- var _a;
- if (!isLivePreview(update.state)) {
- if (this.decorations.size > 0) {
- this.decorations = new import_state3.RangeSetBuilder().finish();
- }
- this.notLivePreview = true;
- return;
- }
- if (this.notLivePreview) {
- this.notLivePreview = false;
- this.decorations = this.buildDecorations(update.view);
- return;
- }
- const selectionChanged = update.selectionSet && !((_a = update.view.plugin(import_obsidian6.livePreviewState)) == null ? void 0 : _a.mousedown);
- if (update.docChanged || update.viewportChanged || selectionChanged) {
- this.decorations = this.buildDecorations(update.view);
- }
- }
- destroy() {
- }
- buildDecorations(view) {
- const builder = new import_state3.RangeSetBuilder();
- for (let { from, to } of view.visibleRanges) {
- view.state.field(textColorParserField).tree.iterate({
- from,
- to,
- enter(node) {
- if (node.type.name == "TextColor") {
- return true;
- }
- if (node.type.name != "Expression") {
- return false;
- }
- handleExpression(node, builder, view.state);
- return false;
- }
- });
- }
- return builder.finish();
- }
- };
- function isLivePreview(state) {
- return state.field(import_obsidian6.editorLivePreviewField).valueOf();
- }
- function handleExpression(ExpressionNode, builder, state) {
- const from = ExpressionNode.from;
- let colorStack = [];
- const stateFrom = state.selection.main.from;
- const stateTo = state.selection.main.to;
- const settings = state.facet(settingsFacet);
- const frontmatterTheme = getThemeFromFrontmatter(state);
- const themeName = frontmatterTheme == "" ? getCurrentTheme(settings).name : frontmatterTheme;
- ExpressionNode.node.toTree().iterate({
- // toTree allocates a tree, this might be a point of optimization. TODO optimization
- enter(node) {
- var _a, _b, _c, _d;
- switch (node.type.name) {
- case "RMarker":
- let inside = (_a = colorStack.pop()) == null ? void 0 : _a.inside;
- if (inside) {
- return true;
- }
- builder.add(node.from + from, node.to + from, import_view3.Decoration.replace({ widget: new MarkerWidget(), block: false }));
- return true;
- case "EOF":
- case "ENDLN":
- (_b = colorStack.pop()) == null ? void 0 : _b.inside;
- return true;
- case "TcLeft":
- if ((_c = colorStack.last()) == null ? void 0 : _c.inside) {
- return true;
- }
- builder.add(node.from + from, node.to + from, import_view3.Decoration.replace({ widget: new MarkerWidget(), block: false }));
- return true;
- case "Color":
- let color = state.sliceDoc(from + node.from, from + node.to);
- colorStack[colorStack.length - 1].color = color;
- if (((_d = colorStack.last()) == null ? void 0 : _d.inside) && settings.interactiveDelimiters) {
- if (stateFrom <= from + node.to && stateTo >= from + node.from) {
- return true;
- }
- const widget = new ColorWidget(color, node.from + from, node.to + from, ExpressionNode.to, themeName);
- builder.add(node.from + from, node.to + from, import_view3.Decoration.replace({ widget, block: false }));
- }
- return true;
- case "Text":
- builder.add(node.from + from, node.to + from, import_view3.Decoration.mark({ class: `${CSS_COLOR_PREFIX}${themeName}-${colorStack[colorStack.length - 1].color}` }));
- return false;
- case "Expression":
- colorStack.push({ color: "", inside: stateFrom <= from + node.to && stateTo >= from + node.from });
- return true;
- default:
- break;
- }
- }
- });
- }
- function getThemeFromFrontmatter(state) {
- var _a;
- const editorInfo = state.field(import_obsidian6.editorInfoField);
- const file = editorInfo.file;
- if (!file) {
- return "";
- }
- const frontmatter = (_a = editorInfo.app.metadataCache.getFileCache(file)) == null ? void 0 : _a.frontmatter;
- if (!frontmatter) {
- return "";
- }
- const name = frontmatter["ftcTheme"];
- return name ? name : "";
- }
- var pluginSpec = {
- decorations: (value) => value.decorations
- };
- var textColorViewPlugin = import_view3.ViewPlugin.fromClass(
- TextColorViewPlugin,
- pluginSpec
- );
- // src/utils/regularExpressions.ts
- var PREFIX = /\~\=\{\S+\}/g;
- var SUFFIX = /\=\~/g;
- // src/rendering/TextColorPostProcessor.ts
- var textColorPostProcessor = (el, context, settings) => {
- if (!el.innerHTML.match(PREFIX)) {
- return;
- }
- let themeName = context.frontmatter ? context.frontmatter["ftcTheme"] : null;
- themeName = themeName ? themeName : getCurrentTheme(settings).name;
- const emergencyCopy = el.cloneNode(true);
- try {
- rebuildNode(el, themeName);
- } catch (e) {
- console.error(`fatal in rebuildNode: ${e}`);
- el.childNodes.forEach((c) => {
- var _a;
- (_a = c.parentNode) == null ? void 0 : _a.removeChild(c);
- });
- emergencyCopy.childNodes.forEach((c) => {
- el.appendChild(c);
- });
- }
- return;
- };
- function rebuildNode(node, themeName, level = 0, nodeStack = []) {
- var _a, _b, _c, _d;
- if (node.nodeName == "CODE") {
- return node;
- }
- if (level > 1e3) {
- console.error("fatal: reached depth 1000 in recursion");
- }
- let lastLength = node.childNodes.length;
- for (let i = 0; i < node.childNodes.length; i++) {
- lastLength = node.childNodes.length;
- let childNode = node.childNodes.item(i);
- const text = childNode.nodeValue;
- if (nodeStack.last() != void 0 && nodeStack.last() != childNode && !(childNode.compareDocumentPosition(nodeStack.last()) & Node.DOCUMENT_POSITION_CONTAINS)) {
- (_a = childNode.parentNode) == null ? void 0 : _a.removeChild(childNode);
- (_b = nodeStack.last()) == null ? void 0 : _b.appendChild(childNode);
- if (lastLength > node.childNodes.length) {
- i -= lastLength - node.childNodes.length;
- }
- }
- if (childNode.nodeType != Node.TEXT_NODE) {
- childNode = rebuildNode(childNode, themeName, level + 1, nodeStack);
- continue;
- }
- if (text == null || text == "") {
- continue;
- }
- let prefix = GetFirstMatch(text, PREFIX);
- let suffix = GetFirstMatch(text, SUFFIX);
- if (prefix == null && suffix == null) {
- continue;
- }
- let nextPrefixPosition = prefix != null ? prefix.index : Number.POSITIVE_INFINITY;
- let nextSuffixPosition = suffix != null ? suffix.index : Number.POSITIVE_INFINITY;
- if (nextPrefixPosition == nextSuffixPosition) {
- console.error(`fatal: nextPrefixPosition and nextSuffixPosition are the same but not infinity!!: ${nextPrefixPosition}`);
- return node;
- }
- if (nextPrefixPosition < nextSuffixPosition) {
- prefix = prefix;
- let textBeforeDelim2 = text.slice(0, nextPrefixPosition);
- let textAfterDelim2 = text.slice(prefix.end);
- let prefixContent = prefix.value;
- let color = prefixContent.slice(3, prefixContent.length - 1);
- let colorSpan = document.createElement("span");
- colorSpan.addClass(`${CSS_COLOR_PREFIX}${themeName}-${color}`);
- childNode.nodeValue = textBeforeDelim2;
- (_c = childNode.parentNode) == null ? void 0 : _c.insertAfter(colorSpan, childNode);
- let newNode2 = document.createTextNode(textAfterDelim2);
- colorSpan.appendChild(newNode2);
- nodeStack.push(colorSpan);
- continue;
- }
- let textBeforeDelim = text.slice(0, nextSuffixPosition);
- let textAfterDelim = text.slice(suffix.end);
- childNode.nodeValue = textBeforeDelim;
- let prevNode = nodeStack.pop();
- let newNode = document.createTextNode(textAfterDelim);
- (_d = prevNode.parentNode) == null ? void 0 : _d.insertAfter(newNode, prevNode);
- continue;
- }
- return node;
- }
- function GetFirstMatch(text, regex) {
- const regexCopy = new RegExp(regex.source, "g");
- const matches = [];
- let m = regexCopy.exec(text);
- if (m !== null) {
- return {
- index: m.index,
- value: m[0],
- end: m.index + m[0].length
- };
- }
- return null;
- }
- // main.ts
- var import_state4 = require("@codemirror/state");
- var import_view4 = require("@codemirror/view");
- // src/color/TextColorFunctions.ts
- function applyColor(tColor, editor) {
- let prefix = `~={${tColor.id}}`;
- let suffix = `=~`;
- if (!editor.somethingSelected()) {
- editor.replaceSelection(prefix);
- let pos = editor.getCursor();
- editor.replaceSelection(suffix);
- editor.setCursor(pos);
- return;
- }
- let selected = editor.getSelection();
- let coloredText = `${prefix}${selected}${suffix}`;
- editor.replaceSelection(coloredText);
- }
- function removeColor(editor, view) {
- var _a, _b;
- const tree = view.state.field(textColorParserField).tree;
- let node = tree.resolveInner(view.state.selection.main.head);
- while (node.parent != null) {
- if (node.type.name != "Expression") {
- node = node.parent;
- continue;
- }
- const TcLeft = node.getChild("TcLeft");
- const Rmarker = (_b = (_a = node.getChild("TcRight")) == null ? void 0 : _a.getChild("REnd")) == null ? void 0 : _b.getChild("RMarker");
- view.dispatch({
- changes: [
- {
- from: TcLeft ? TcLeft.from : 0,
- to: TcLeft ? TcLeft.to : 0,
- insert: ""
- },
- {
- from: Rmarker ? Rmarker.from : 0,
- to: Rmarker ? Rmarker.to : 0,
- insert: ""
- }
- ]
- });
- return;
- }
- return;
- }
- // src/utils/ColorSuggestModal.ts
- var import_obsidian7 = require("obsidian");
- var ColorSuggestModal = class extends import_obsidian7.SuggestModal {
- constructor(app, colors, editor) {
- super(app);
- this.colors = colors;
- this.editor = editor;
- }
- getSuggestions(query) {
- return this.colors.filter((tColor) => tColor.id.startsWith(query) || tColor.keybind == query);
- }
- renderSuggestion(tColor, el) {
- let div = el.createDiv();
- div.innerText = tColor.id;
- div.setAttr("style", tColor.getCssInlineStyle());
- }
- onChooseSuggestion(tColor, evt) {
- applyColor(tColor, this.editor);
- }
- };
- // main.ts
- var MAX_MENU_ITEMS = 10;
- var FastTextColorPlugin = class extends import_obsidian8.Plugin {
- async onload() {
- await this.loadSettings();
- this.registerEditorExtension(textColorParserField);
- this.registerEditorExtension(textColorViewPlugin);
- this.registerMarkdownPostProcessor((el, ctx) => {
- textColorPostProcessor(el, ctx, this.settings);
- }, -1e3);
- this.registerMarkdownPostProcessor((el, ctx) => {
- textColorPostProcessor(el, ctx, this.settings);
- }, 1e3);
- this.settingsCompartment = new import_state4.Compartment();
- this.settingsExtension = this.settingsCompartment.of(settingsFacet.of(this.settings));
- this.registerEditorExtension(this.settingsExtension);
- this.registerEditorExtension(
- import_state4.Prec.high(
- import_view4.keymap.of([
- {
- key: "Tab",
- run: (editorView) => this.jumpOut(editorView)
- }
- ])
- )
- );
- this.addCommand({
- id: "change-text-color",
- name: "Change text color",
- editorCallback: (editor) => {
- this.openColorMenu(editor);
- }
- });
- this.addCommand({
- id: "remove-text-color",
- name: "Remove text color",
- editorCallback: (editor, view) => {
- const editorView = view.editor.cm;
- removeColor(editor, editorView);
- }
- });
- this.registerEvent(
- this.app.workspace.on("editor-menu", (menu, editor, view) => {
- if (editor.getSelection() == "") {
- return;
- }
- menu.addItem((item) => {
- item.setSection("selection").setTitle("Color").setIcon("palette");
- const submenu = item.setSubmenu();
- getColors(this.settings).forEach((tColor) => {
- submenu.addItem((subitem) => {
- subitem.setTitle(tColor.id).setIcon("circle").onClick((evt) => {
- applyColor(tColor, editor);
- });
- subitem.dom.addClass(tColor.className);
- subitem.iconEl.addClass(tColor.className);
- });
- });
- });
- })
- );
- this.addSettingTab(new FastTextColorPluginSettingTab(this.app, this));
- this.setCssVariables();
- }
- onunload() {
- this.styleElement.remove();
- this.closeColorMenu();
- }
- async loadSettings() {
- const rawSettings = await this.loadData();
- if (rawSettings && +rawSettings.version < +SETTINGS_VERSION) {
- console.log("outdated Settings! Trying to update.");
- this.settings = updateSettings(rawSettings);
- await this.saveData(this.settings);
- return;
- }
- this.settings = Object.assign({}, DEFAULT_SETTINGS, await this.loadData());
- for (let j = 0; j < this.settings.themes.length; j++) {
- const colors = getColors(this.settings, j);
- for (let i = 0; i < colors.length; i++) {
- let obj = colors[i];
- colors[i] = new TextColor(obj.color, obj.id, this.settings.themes[j].name, obj.italic, obj.bold, obj.cap_mode.index, obj.line_mode.index, obj.keybind, obj.useCssColorVariable, obj.colorVariable);
- }
- }
- }
- async saveSettings() {
- var _a;
- await this.saveData(this.settings);
- const view = this.app.workspace.getActiveViewOfType(import_obsidian8.MarkdownView);
- const editorView = (_a = view == null ? void 0 : view.editor) == null ? void 0 : _a.cm;
- if (editorView == null) {
- return;
- }
- editorView.dispatch({
- effects: this.settingsCompartment.reconfigure(settingsFacet.of(this.settings))
- });
- }
- // create and open the color menu
- /**
- * opens the color menu and pushed the scope onto the keybindings.
- *
- * @param {Editor} editor - [TODO:description]
- */
- openColorMenu(editor) {
- var _a;
- if (!this.settings.useKeybindings) {
- let modal = new ColorSuggestModal(this.app, getColors(this.settings), editor);
- modal.open();
- return;
- }
- if (this.colorMenu != null) {
- return;
- }
- this.colorMenu = createDiv();
- if (!this.colorMenu) {
- new import_obsidian8.Notice("could not create Colormenu!");
- return;
- }
- let attributes = `bottom: 8.25em; grid-template-columns: ${"1fr ".repeat(getColors(this.settings).length)}`;
- this.colorMenu.setAttribute("style", attributes);
- this.colorMenu.setAttribute("id", "fast-color-menu");
- this.colorMenu.addClass("fast-color-menu");
- (_a = document.body.querySelector(".mod-vertical.mod-root")) == null ? void 0 : _a.insertAdjacentElement("afterbegin", this.colorMenu);
- for (let i = 0; i < Math.min(getColors(this.settings).length, MAX_MENU_ITEMS); i++) {
- this.createColorItem(this.colorMenu, getColors(this.settings)[i], i + 1, editor);
- }
- this.colorMenu.setAttribute("style", `left: calc(50% - ${this.colorMenu.offsetWidth}px / 2); ${attributes}`);
- if (!this.settings.useKeybindings) {
- return;
- }
- this.constructScope(editor);
- this.app.keymap.pushScope(this.scope);
- }
- closeColorMenu() {
- if (this.colorMenu) {
- this.colorMenu.remove();
- this.colorMenu = null;
- }
- this.app.keymap.popScope(this.scope);
- }
- constructScope(editor) {
- this.scope = new import_obsidian8.Scope();
- let { scope } = this;
- for (let i = 0; i < getColors(this.settings).length; i++) {
- const tColor = getColors(this.settings)[i];
- scope.register([], tColor.keybind, (event) => {
- if (event.isComposing) {
- return true;
- }
- applyColor(tColor, editor);
- this.closeColorMenu();
- return false;
- });
- }
- scope.register([], "Escape", (event) => {
- if (event.isComposing) {
- return true;
- }
- this.closeColorMenu();
- return false;
- });
- scope.register([], "Delete", (event) => {
- if (event.isComposing) {
- return true;
- }
- this.closeColorMenu();
- return false;
- });
- scope.register([], "Backspace", (event) => {
- if (event.isComposing) {
- return true;
- }
- this.closeColorMenu();
- return false;
- });
- }
- /**
- * Move the cursor behind the next end marker.
- *
- * @param {EditorView} editorView
- * @returns {boolean} true if jump possible.
- */
- jumpOut(editorView) {
- var _a;
- const state = editorView.state;
- const tree = state.field(textColorParserField).tree;
- const editor = (_a = this.app.workspace.getActiveViewOfType(import_obsidian8.MarkdownView)) == null ? void 0 : _a.editor;
- if (!editor) {
- return false;
- }
- let inner = tree.resolve(state.selection.main.head);
- if (inner.type.name == "Text" && inner.parent != null) {
- inner = inner.parent;
- }
- if (inner.type.name != "TcRight") {
- return false;
- }
- editor.setCursor(editor.offsetToPos(inner.to));
- return true;
- }
- createColorItem(menu, tColor, counter, editor) {
- new import_obsidian8.ButtonComponent(menu).setButtonText(`${tColor.keybind}`).setClass("fast-color-menu-item").onClick(() => {
- let n = new import_obsidian8.Notice("activated color");
- n.noticeEl.setAttr("style", `background-color: ${tColor.color}`);
- applyColor(tColor, editor);
- this.closeColorMenu();
- }).buttonEl.setAttr("style", `background-color: ${tColor.color}`);
- }
- /**
- * creates the stylesheet needed for the colors in the root of the document.
- * A different set of classes is created for each theme.
- *
- */
- setCssVariables() {
- if (!this.styleElement) {
- const root = document.querySelector(":root");
- if (!root) {
- return;
- }
- this.styleElement = root.createEl("style");
- this.styleElement.id = "fast-text-color-stylesheet";
- }
- this.styleElement.innerText = "";
- for (let i = 0; i < this.settings.themes.length; i++) {
- getColors(this.settings, i).forEach((tColor) => {
- const theme = this.settings.themes[i];
- const className = `.${CSS_COLOR_PREFIX}${theme.name}-${tColor.id}`;
- let cssClass = `${className} {
- ${tColor.getInnerCss()}}`;
- this.styleElement.innerText += cssClass + "\n";
- });
- }
- }
- };
|