2024-09-17 21:29:16 +02:00

251 lines
34 KiB
JavaScript
Executable File

/*
THIS IS A GENERATED/BUNDLED FILE BY ESBUILD
if you want to view the source, please visit the github repository of this plugin
*/
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
var __export = (target, all) => {
__markAsModule(target);
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __reExport = (target, module2, desc) => {
if (module2 && typeof module2 === "object" || typeof module2 === "function") {
for (let key of __getOwnPropNames(module2))
if (!__hasOwnProp.call(target, key) && key !== "default")
__defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
}
return target;
};
var __toModule = (module2) => {
return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", module2 && module2.__esModule && "default" in module2 ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
};
var __async = (__this, __arguments, generator) => {
return new Promise((resolve, reject) => {
var fulfilled = (value) => {
try {
step(generator.next(value));
} catch (e) {
reject(e);
}
};
var rejected = (value) => {
try {
step(generator.throw(value));
} catch (e) {
reject(e);
}
};
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
step((generator = generator.apply(__this, __arguments)).next());
});
};
// src/main.ts
__export(exports, {
default: () => HeadingIndent
});
var import_obsidian2 = __toModule(require("obsidian"));
// src/preview_indenting.ts
var containerSelector = ".workspace-leaf.mod-active .markdown-reading-view .markdown-preview-section";
var arrClassesHeadings = {
1: "heading_h1",
2: "heading_h2",
3: "heading_h3",
4: "heading_h4",
5: "heading_h5",
6: "heading_h6"
};
var arrClassesData = {
0: "data_no-heading",
1: "data_h1",
2: "data_h2",
3: "data_h3",
4: "data_h4",
5: "data_h5",
6: "data_h6"
};
function setObserverToActiveLeaf(plugin) {
if (plugin.previewObserver !== void 0) {
plugin.previewObserver.disconnect();
}
const targetNode = activeDocument.querySelector(containerSelector);
if (targetNode == null) {
console.log("target node is NULL");
return;
}
const config = { childList: true };
const callback = (mutationList, observer) => {
for (const mutation of mutationList) {
if (mutation.type === "childList") {
wrapperIndentPreview(plugin, 100, true);
}
}
};
plugin.previewObserver = new MutationObserver(callback);
plugin.previewObserver.observe(targetNode, config);
}
function wrapperIndentPreview(plugin, timeout, flag) {
timeout = timeout || 100;
if (flag) {
if (plugin.flagExecute == void 0)
plugin.flagExecute = 1;
if (plugin.flagExecute == 1) {
plugin.flagExecute = 2;
setTimeout(function() {
return __async(this, null, function* () {
indentPreview(plugin);
});
}, timeout);
setTimeout(() => {
plugin.flagExecute = 1;
}, timeout + 50);
}
} else {
setTimeout(function() {
return __async(this, null, function* () {
indentPreview(plugin);
});
}, timeout);
}
}
function indentPreview(plugin) {
const settings = plugin.settings;
const divsNodeList = activeDocument.querySelectorAll(containerSelector + " > div");
if (!divsNodeList) {
return;
}
const arrDivs = Array.from(divsNodeList);
const excludedClassNames = ["mod-header", "mod-footer", "markdown-preview-pusher"];
cleanSectionModifications(arrDivs);
const arrMargins = {
0: 0,
1: parseInt(settings.h1) || 0,
2: parseInt(settings.h2) || 0,
3: parseInt(settings.h3) || 0,
4: parseInt(settings.h4) || 0,
5: parseInt(settings.h5) || 0,
6: parseInt(settings.h6) || 0
};
let hNumber = 0;
suck:
for (const div of arrDivs) {
if (excludedClassNames.some((className) => div.classList.contains(className))) {
continue suck;
}
let headingNodeList = div.querySelectorAll("h1, h2, h3, h4, h5, h6"), currentDivIsHeading = headingNodeList.length > 0;
if (currentDivIsHeading) {
let hTag = headingNodeList[0].tagName.toLowerCase();
hNumber = parseInt(hTag.replace(/^\D+/g, ""));
div.style.marginLeft = arrMargins[hNumber - 1] + "px";
div.classList.add(arrClassesHeadings[hNumber]);
} else {
div.style.marginLeft = arrMargins[hNumber] + "px";
div.classList.add(arrClassesData[hNumber]);
}
}
}
function cleanSectionModifications(arrDivs) {
for (const div of arrDivs) {
div.style.marginLeft = null;
div.classList.forEach((item) => {
if (item.startsWith("data_") || item.startsWith("heading_")) {
div.classList.remove(item);
}
});
}
}
// src/settings.ts
var import_obsidian = __toModule(require("obsidian"));
var DEFAULT_SETTINGS = {
h1: "30",
h2: "50",
h3: "70",
h4: "90",
h5: "110",
h6: "130"
};
var IndentSettingTab = class extends import_obsidian.PluginSettingTab {
constructor(app, plugin) {
super(app, plugin);
this.plugin = plugin;
}
display() {
const { containerEl } = this;
containerEl.empty();
containerEl.createEl("h2", { text: "Set identations for each heading (in pixels)" });
new import_obsidian.Setting(containerEl).setName("H1 Identation").addText((number) => number.setPlaceholder("").setValue(this.plugin.settings.h1).onChange((value) => __async(this, null, function* () {
this.plugin.settings.h1 = value;
yield this.plugin.saveSettings();
})));
new import_obsidian.Setting(containerEl).setName("H2 Identation").addText((text) => text.setPlaceholder("").setValue(this.plugin.settings.h2).onChange((value) => __async(this, null, function* () {
this.plugin.settings.h2 = value;
yield this.plugin.saveSettings();
})));
new import_obsidian.Setting(containerEl).setName("H3 Identation").addText((text) => text.setPlaceholder("").setValue(this.plugin.settings.h3).onChange((value) => __async(this, null, function* () {
this.plugin.settings.h3 = value;
yield this.plugin.saveSettings();
})));
new import_obsidian.Setting(containerEl).setName("H4 Identation").addText((text) => text.setPlaceholder("").setValue(this.plugin.settings.h4).onChange((value) => __async(this, null, function* () {
this.plugin.settings.h4 = value;
yield this.plugin.saveSettings();
})));
new import_obsidian.Setting(containerEl).setName("H5 Identation").addText((text) => text.setPlaceholder("").setValue(this.plugin.settings.h5).onChange((value) => __async(this, null, function* () {
this.plugin.settings.h5 = value;
yield this.plugin.saveSettings();
})));
new import_obsidian.Setting(containerEl).setName("H6 Identation").addText((text) => text.setPlaceholder("").setValue(this.plugin.settings.h6).onChange((value) => __async(this, null, function* () {
this.plugin.settings.h6 = value;
yield this.plugin.saveSettings();
})));
}
};
// src/main.ts
var HeadingIndent = class extends import_obsidian2.Plugin {
onload() {
return __async(this, null, function* () {
yield this.loadSettings();
console.log("plugin Heading Indent Settings loaded");
this.addSettingTab(new IndentSettingTab(this.app, this));
this.app.workspace.onLayoutReady(() => {
wrapperIndentPreview(this, 100, false);
wrapperIndentPreview(this, 300, false);
wrapperIndentPreview(this, 1e3, false);
setObserverToActiveLeaf(this);
});
this.registerEvent(this.app.workspace.on("active-leaf-change", () => {
indentPreview(this);
wrapperIndentPreview(this, 100, false);
setObserverToActiveLeaf(this);
}));
this.registerEvent(this.app.workspace.on("layout-change", () => {
setObserverToActiveLeaf(this);
}));
});
}
onunload() {
this.previewObserver && this.previewObserver.disconnect();
}
loadSettings() {
return __async(this, null, function* () {
this.settings = Object.assign({}, DEFAULT_SETTINGS, yield this.loadData());
});
}
saveSettings() {
return __async(this, null, function* () {
yield this.saveData(this.settings);
indentPreview(this);
});
}
};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["src/main.ts", "src/preview_indenting.ts", "src/settings.ts"],
  "sourcesContent": ["import { MarkdownView, Plugin } from 'obsidian';\r\nimport { wrapperIndentPreview, indentPreview, setObserverToActiveLeaf } from \"./preview_indenting\";\r\nimport { IndentSettingTab, HeadingIndentSettings, DEFAULT_SETTINGS } from './settings';\r\n\r\n// import { App, Editor, PluginSettingTab, MarkdownPostProcessorContext, Setting, MarkdownPreviewRenderer } from 'obsidian';\r\n\r\n// declare module \"obsidian\" {\r\n// \tinterface App {\r\n// \t\t// trick con el <flag> para que la funcion se procese las minimas veces posibles\r\n// \t\tflagExecute?: number,\r\n// \t\t// save observer in app.variable in order to control and prevent stacking of observers\r\n// \t\tpreviewObserver?: any\r\n// \t}\r\n// }\r\n\r\n\r\nexport default class HeadingIndent extends Plugin {\r\n\tsettings: HeadingIndentSettings;\r\n\tflagExecute?: number; // trick con el <flag> para que la funcion se procese las minimas veces posibles\r\n\tpreviewObserver?: any; // save observer in app.variable in order to control and prevent stacking of observers\r\n\r\n\t// Configure resources needed by the plugin.\r\n\tasync onload() {\r\n\t\tawait this.loadSettings();\r\n\t\t\r\n\t\tconsole.log(\"plugin Heading Indent Settings loaded\");\r\n\r\n\t\t// This adds a settings tab so the user can configure various aspects of the plugin\r\n\t\tthis.addSettingTab(new IndentSettingTab(this.app, this));\r\n\r\n\t\t// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++\r\n\t\t// registerMarkdownPostProcessor callback is for creation of new html elements, but i have to \r\n\t\t// manipulate the rendered dom of existing elements. for example the div that contains a paragraph. \r\n\t\t// The callback `registerMarkdownPostProcessor` is called n times, depending on the number of elements\r\n\t\t// (paragraph, code-block, heading, etc) are modified before toggling to reading view. i.e., if i modify \r\n\t\t// one header and 2 paragraps, this callback will be fired 3 times when reading view will be activated, \r\n\t\t// each time passing the corresponding modified element. This precisely is the problem - i just need \r\n\t\t// something like document.ready, that will be fire only once, when ALL modified elements are already \r\n\t\t// rendered, so i can work on the whole rendered DOM and not on each modified element separately.\r\n\t\t// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++\r\n\t\t// this.registerMarkdownPostProcessor((el, ctx) => {\r\n\r\n\t\t\t// const markdownView = this.app.workspace.getActiveViewOfType(MarkdownView);\r\n\t\t\t// const mode = markdownView.getMode();\r\n\t\t\t// markdownView.previewMode.renderer.sections\r\n\t\t\t// console.log(markdownView.previewMode.renderer.sections);\r\n\r\n\t\t\t// wrapperIndentPreview(this,100,true);\r\n\t\t// }, 0)\r\n\r\n\r\n\t\t// When obsidian in started\r\n\t\tthis.app.workspace.onLayoutReady(() => {\r\n\t\t\t// console.log(\"\u2B50onLayoutReady\");\r\n\t\t\t\r\n\t\t\t// run without blocking (without flag)\r\n\t\t\twrapperIndentPreview(this,100,false);\r\n\t\t\twrapperIndentPreview(this,300,false);\r\n\t\t\twrapperIndentPreview(this,1000,false);\r\n\r\n            setObserverToActiveLeaf(this);\r\n\t\t\t\r\n        });\r\n\r\n\t\t// When tab is switched\r\n\t\tthis.registerEvent(this.app.workspace.on(\"active-leaf-change\", () => {\r\n\t\t\t// console.log(\"\u2B50\u2B50event:active-leaf-change\");\r\n\r\n\t\t\t// const activeViewOfMarkdown = this.app.workspace.getActiveViewOfType(MarkdownView);\r\n\t\t\t// const mode = activeViewOfMarkdown != null\r\n\t\t\t// \t? activeViewOfMarkdown.getMode()\r\n\t\t\t// \t: null;\r\n\t\t\t\r\n\t\t\t/**\r\n\t\t\t * run directly (without timeout & flag) in order to apply indent faster\r\n\t\t\t * process the sections that are already rendered; the rest of the sections\r\n\t\t\t * (which not rendered yet) we will process with observer callback\r\n\t\t\t */\r\n\t\t\tindentPreview(this);\r\n\r\n\t\t\t/**\r\n\t\t\t * when leaf is opened <in new tab> from <quick-switcher> and its content fits into\r\n\t\t\t * the <viewport>, its not triggering observer callback, I guess its cuz the divs are \r\n\t\t\t * rendered at once\r\n\t\t\t * \r\n\t\t\t * Run without flag cuz I think will be better for other cases - itwont be blocking \r\n\t\t\t * subsequent calls from observer callback \r\n\t\t\t */\r\n\t\t\twrapperIndentPreview(this,100,false);\r\n\r\n\t\t\tsetObserverToActiveLeaf(this);\r\n\t\t}));\r\n\r\n\r\n\t\t// When toggle between source/preview mode\r\n\t\tthis.registerEvent(this.app.workspace.on(\"layout-change\", () => {\r\n\t\t\t\r\n\t\t\tsetObserverToActiveLeaf(this);\r\n\t\t}));\r\n\r\n\r\n\t\t// this.registerEvent(this.app.workspace.on(\"editor-change\", (editor: Editor, MarkdownView: MarkdownView) => {\r\n\t\t// \t// console.log(\"\u2B50\u2B50event:editor-change\");\r\n\r\n\t\t// \t// let currentLine = editor.getCursor().line;\r\n\t\t// \t// console.log(editor.getLine(currentLine));\r\n\r\n\t\t// \tconsole.log(editor);\r\n\t\t// \tdavayIndentSource(this);\r\n\r\n\t\t// \t// wrapperIndentPreview(this,100,true);\r\n\t\t// }));\r\n\r\n\t\t//todo: source\r\n\t\t// .workspace-leaf.mod-active .markdown-source-view .cm-contentContainer > div:nth-child(2)\r\n\t\t// this.registerEditorExtension(activeVisualLine);\r\n\t\t// ref dynamic highlight plug k crea span inside cm-line\r\n\t}\r\n\r\n\t// Release any resources configured by the plugin.\r\n\tonunload() {\r\n\t\t// if (this.previewObserver !== undefined) this.previewObserver.disconnect();\r\n\t\tthis.previewObserver && this.previewObserver.disconnect();\r\n\t}\r\n\r\n\tasync loadSettings() {\r\n\t\tthis.settings = Object.assign({}, DEFAULT_SETTINGS, await this.loadData());\r\n\t}\r\n\r\n\tasync saveSettings() {\r\n\t\tawait this.saveData(this.settings);\r\n\t\tindentPreview(this);\r\n\t}\r\n\r\n}\r\n", "import { App, Editor, MarkdownView, Setting } from 'obsidian';\nimport { DecorationSet, EditorView, ViewPlugin, ViewUpdate } from \"@codemirror/view\";\nimport HeadingIndent from './main';\n\ninterface Dictionary<Type> {\n\t[key: string]: Type;\n}\n\nconst containerSelector: string = \".workspace-leaf.mod-active .markdown-reading-view .markdown-preview-section\";\n\nconst arrClassesHeadings: Dictionary<string> = {\n\t1: \"heading_h1\",\n\t2: \"heading_h2\",\n\t3: \"heading_h3\",\n\t4: \"heading_h4\",\n\t5: \"heading_h5\",\n\t6: \"heading_h6\",\n};\n\nconst arrClassesData: Dictionary<string> = {\n\t0: \"data_no-heading\",\n\t1: \"data_h1\",\n\t2: \"data_h2\",\n\t3: \"data_h3\",\n\t4: \"data_h4\",\n\t5: \"data_h5\",\n\t6: \"data_h6\",\n};\n\n\n/**\n * The observer callback will trigger each time sections (preview) / lines (source) are added/removed\n * \n * [preview]\n * \t  When preview is toggled and there are changes in sections to be rendered\n * \n * [preview,source]\n * \t  When switch note, the sections will be rendered\n * \n * \t  If the active leaf is large (preview is codemirror and it \n *    supports huge files)  the callback triggers while we scroll, cuz the editor only \n *    renders the editor's viewport (that renders only what's is visible)\n *    https://marcus.se.net/obsidian-plugin-docs/editor/extensions/viewport\n * \n * \t  Trigger when heading fold/unfold; si abrimos nota y algun heading esta oculto,\n *    la funcion al ejecutarse previamente no hizo nada con esos divs porque cuando \n *    estan ocultos, desaparecen del DOM\n */\nexport function setObserverToActiveLeaf(plugin: HeadingIndent){\n\n    if (plugin.previewObserver !== undefined){\n        // prevent stacking: disconnect existing observer first before creating a new one\n        plugin.previewObserver.disconnect();\n    }\n\n    // `activeDcoument` instead of `document` to work in obsidian-popups \n    const targetNode = activeDocument.querySelector(containerSelector); \n\n    // if new tab is opened (ctrl+t) the leaf is empty and targetNode is null\n    if (targetNode == null){\n        console.log(\"target node is NULL\");\n        return;\n    }\n\n    // Options for the observer (which mutations to observe)\n    const config = { childList: true };\n\n    // Callback function to execute when mutations are observed\n    const callback = (mutationList: any, observer: any) => {\n        \n        for (const mutation of mutationList) {\n            \n            if (mutation.type === 'childList') {\n                // console.log('A child node has been added or removed.');\n                // indentPreview(plugin);\n                wrapperIndentPreview(plugin,100,true);\n            }\n        }\n    };\n\n    // Create an observer instance linked to the callback function\n    plugin.previewObserver = new MutationObserver(callback);\n    // Start observing the target node for configured mutations\n    plugin.previewObserver.observe(targetNode, config);\n}\n\n/**\n * \n * @param timeout \tin order to process when the \"sections\" are already rendered\n * @param flag \t\tsee this.flagExecute interface\n */\nexport function wrapperIndentPreview(plugin: HeadingIndent, timeout: number, flag: boolean){\n\n    timeout = timeout || 100;\n\n    if (flag){\n\n        if (plugin.flagExecute == undefined) plugin.flagExecute = 1;\n    \n        if (plugin.flagExecute == 1){\n    \n            // console.log(\"za-e-b-a-shit\");\n            plugin.flagExecute = 2;\n    \n            setTimeout(async function(){\n                indentPreview(plugin);\n            }, timeout)\n            \n            setTimeout(() => {\n                plugin.flagExecute = 1;\n            }, timeout+50)\n        }\n\n    }else{\n\n        setTimeout(async function(){\n            indentPreview(plugin);\n        }, timeout)\n    }\n\n}\n\nexport function indentPreview(plugin: HeadingIndent) {\n    const settings = plugin.settings;\n\n    // console.log(\"\uD83C\uDF32\uD83C\uDF32\uD83C\uDF32\uD83C\uDF32\uD83C\uDF32\uD83C\uDF32\uD83C\uDF32\uD83C\uDF32 dayIndent {PREVIEW}\");\n\n    const divsNodeList = activeDocument.querySelectorAll<HTMLElement>(containerSelector + \" > div\");\n    if (!divsNodeList){return}\n    \n    const arrDivs = Array.from(divsNodeList);\n    \n    // do not process divs with followings classes\n    const excludedClassNames = ['mod-header', 'mod-footer', 'markdown-preview-pusher'];\n    \n    cleanSectionModifications(arrDivs);\n\n    const arrMargins: Dictionary<number> = {\n        0: 0, // no heading\n        1: parseInt(settings.h1) || 0,\n        2: parseInt(settings.h2) || 0,\n        3: parseInt(settings.h3) || 0,\n        4: parseInt(settings.h4) || 0,\n        5: parseInt(settings.h5) || 0,\n        6: parseInt(settings.h6) || 0,\n        // 1: 0,\n        // 2: 0,\n        // 3: 0,\n        // 4: 51,\n        // 5: 100,\n        // 6: 150,\n    };\n\n    \n    let hNumber: number = 0;\n\n    suck: for (const div of arrDivs) {\n\n        // skip excluded divs\n        if (excludedClassNames.some(className => div.classList.contains(className))) {\n            continue suck;\n        }\n\n        let headingNodeList = div.querySelectorAll('h1, h2, h3, h4, h5, h6'),\n            currentDivIsHeading = headingNodeList.length > 0;\n\n        if (currentDivIsHeading) {\n            \n            let hTag: string = headingNodeList[0].tagName.toLowerCase();\n            \n            hNumber = parseInt(hTag.replace(/^\\D+/g, '')); // h5 -> 5, h1 -> 1, etc.\n            \n            div.style.marginLeft = arrMargins[hNumber-1]+\"px\";\n            div.classList.add(arrClassesHeadings[hNumber]);\n\n        }else{\n\n            div.style.marginLeft = arrMargins[hNumber]+\"px\";\n            div.classList.add(arrClassesData[hNumber]);\n        }\n    }\n}\n\nfunction cleanSectionModifications(arrDivs: any) {\n\n    for (const div of arrDivs) {\n\n        // div.classList.remove(\"undefined\");\n\n        div.style.marginLeft = null;\n\n        div.classList.forEach((item: string)=>{\n            if(item.startsWith('data_') || item.startsWith('heading_')) {\n                div.classList.remove(item);\n            }\n        })\n\n    }\n\n}", "import { App, PluginSettingTab, Setting } from 'obsidian';\nimport HeadingIndent from './main';\n\nexport interface HeadingIndentSettings {\n\th1: string,\n\th2: string,\n\th3: string,\n\th4: string,\n\th5: string,\n\th6: string,\n}\n\nexport const DEFAULT_SETTINGS: HeadingIndentSettings = {\n\th1: '30',\n\th2: '50',\n\th3: '70',\n\th4: '90',\n\th5: '110',\n\th6: '130',\n}\n\nexport class IndentSettingTab extends PluginSettingTab {\n\tplugin: HeadingIndent;\n\n\tconstructor(app: App, plugin: HeadingIndent) {\n\t\tsuper(app, plugin);\n\t\tthis.plugin = plugin;\n\t}\n\n\tdisplay(): void {\n\t\tconst {containerEl} = this;\n\n\t\tcontainerEl.empty();\n\n\t\tcontainerEl.createEl('h2', {text: 'Set identations for each heading (in pixels)'});\n\n\t\tnew Setting(containerEl)\n\t\t\t.setName('H1 Identation')\n\t\t\t// .setDesc('')\n\t\t\t// .setTooltip(tooltip: \"assad\")\n\t\t\t.addText(number => number\n\t\t\t\t.setPlaceholder('')\n\t\t\t\t.setValue(this.plugin.settings.h1)\n\t\t\t\t.onChange(async (value) => {\n\t\t\t\t\t// console.log('Secret: ' + value);\n\t\t\t\t\tthis.plugin.settings.h1 = value;\n\t\t\t\t\tawait this.plugin.saveSettings();\n\t\t\t\t}));\n\t\tnew Setting(containerEl)\n\t\t\t.setName('H2 Identation')\n\t\t\t// .setDesc('')\n\t\t\t.addText(text => text\n\t\t\t\t.setPlaceholder('')\n\t\t\t\t.setValue(this.plugin.settings.h2)\n\t\t\t\t.onChange(async (value) => {\n\t\t\t\t\t// console.log('Secret: ' + value);\n\t\t\t\t\tthis.plugin.settings.h2 = value;\n\t\t\t\t\tawait this.plugin.saveSettings();\n\t\t\t\t}));\n\t\tnew Setting(containerEl)\n\t\t\t.setName('H3 Identation')\n\t\t\t// .setDesc('')\n\t\t\t.addText(text => text\n\t\t\t\t.setPlaceholder('')\n\t\t\t\t.setValue(this.plugin.settings.h3)\n\t\t\t\t.onChange(async (value) => {\n\t\t\t\t\t// console.log('Secret: ' + value);\n\t\t\t\t\tthis.plugin.settings.h3 = value;\n\t\t\t\t\tawait this.plugin.saveSettings();\n\t\t\t\t}));\n\t\tnew Setting(containerEl)\n\t\t\t.setName('H4 Identation')\n\t\t\t// .setDesc('')\n\t\t\t.addText(text => text\n\t\t\t\t.setPlaceholder('')\n\t\t\t\t.setValue(this.plugin.settings.h4)\n\t\t\t\t.onChange(async (value) => {\n\t\t\t\t\t// console.log('Secret: ' + value);\n\t\t\t\t\tthis.plugin.settings.h4 = value;\n\t\t\t\t\tawait this.plugin.saveSettings();\n\t\t\t\t}));\n\t\tnew Setting(containerEl)\n\t\t\t.setName('H5 Identation')\n\t\t\t// .setDesc('')\n\t\t\t.addText(text => text\n\t\t\t\t.setPlaceholder('')\n\t\t\t\t.setValue(this.plugin.settings.h5)\n\t\t\t\t.onChange(async (value) => {\n\t\t\t\t\t// console.log('Secret: ' + value);\n\t\t\t\t\tthis.plugin.settings.h5 = value;\n\t\t\t\t\tawait this.plugin.saveSettings();\n\t\t\t\t}));\n\t\tnew Setting(containerEl)\n\t\t\t.setName('H6 Identation')\n\t\t\t// .setDesc('')\n\t\t\t.addText(text => text\n\t\t\t\t.setPlaceholder('')\n\t\t\t\t.setValue(this.plugin.settings.h6)\n\t\t\t\t.onChange(async (value) => {\n\t\t\t\t\t// console.log('Secret: ' + value);\n\t\t\t\t\tthis.plugin.settings.h6 = value;\n\t\t\t\t\tawait this.plugin.saveSettings();\n\t\t\t\t}));\n\t}\n}"],
  "mappings": "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",
  "names": []
}
