131 lines
16 KiB
JavaScript
131 lines
16 KiB
JavaScript
/*
|
|
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: () => MenuPlugin
|
|
});
|
|
module.exports = __toCommonJS(main_exports);
|
|
var import_obsidian = require("obsidian");
|
|
var { shell } = require("electron");
|
|
var MenuPlugin = class extends import_obsidian.Plugin {
|
|
async onload() {
|
|
this.registerMarkdownCodeBlockProcessor("menu", (source, el, ctx) => {
|
|
const lines = source.trim().split("\n");
|
|
let layout = "";
|
|
let colors = {};
|
|
const links = [];
|
|
for (const line of lines) {
|
|
const trimmed = line.trim();
|
|
if (trimmed.startsWith("layout:") || trimmed.startsWith("class:")) {
|
|
const colonIndex = trimmed.indexOf(":");
|
|
layout = trimmed.substring(colonIndex + 1).trim();
|
|
} else if (trimmed.includes(":") && !trimmed.startsWith("[") && !trimmed.startsWith("[[")) {
|
|
const [key, ...valueParts] = trimmed.split(":");
|
|
const value = valueParts.join(":").trim();
|
|
if (key && value && !key.includes("//") && !key.includes("http")) {
|
|
colors[key.trim()] = value;
|
|
}
|
|
} else if (trimmed && !trimmed.includes(":")) {
|
|
links.push(trimmed);
|
|
} else if (trimmed.startsWith("[")) {
|
|
links.push(trimmed);
|
|
}
|
|
}
|
|
const finalLayout = layout || "default";
|
|
const container = el.createEl("div", { cls: `menu-container ${finalLayout}` });
|
|
if (Object.keys(colors).length > 0) {
|
|
for (const [key, value] of Object.entries(colors)) {
|
|
let cssKey = key.replace(/accent/g, "hover-text");
|
|
container.style.setProperty(`--${cssKey}`, value);
|
|
}
|
|
if (colors["hover-text"]) {
|
|
container.style.setProperty("--hover-text", colors["hover-text"]);
|
|
}
|
|
}
|
|
for (const link of links) {
|
|
if (link.startsWith("[[") && link.endsWith("]]")) {
|
|
const linkContent = link.slice(2, -2);
|
|
let href = linkContent;
|
|
let text = linkContent;
|
|
if (linkContent.includes("|")) {
|
|
[href, text] = linkContent.split("|");
|
|
}
|
|
const a = container.createEl("a", {
|
|
text,
|
|
attr: { "data-href": href }
|
|
});
|
|
a.addClass("menu-internal-link");
|
|
a.style.cursor = "pointer";
|
|
a.addEventListener("click", (e) => {
|
|
e.preventDefault();
|
|
const vaultName = this.app.vault.getName();
|
|
const encodedFile = encodeURIComponent(href);
|
|
const uri = `obsidian://open?vault=${encodeURIComponent(vaultName)}&file=${encodedFile}`;
|
|
window.open(uri);
|
|
});
|
|
} else if (link.match(/^\[.*\]\(.*\)$/)) {
|
|
const match = link.match(/^\[(.*)\]\((.*)\)$/);
|
|
if (match) {
|
|
const text = match[1];
|
|
const url = match[2];
|
|
const a = container.createEl("a", {
|
|
text,
|
|
attr: url.startsWith("file://") ? {} : { href: url, target: "_blank", rel: "noopener noreferrer" }
|
|
});
|
|
a.style.cursor = "pointer";
|
|
if (url.startsWith("file://")) {
|
|
a.addClass("menu-file-link");
|
|
} else {
|
|
a.addClass("menu-external-link");
|
|
}
|
|
a.addEventListener("click", (e) => {
|
|
e.preventDefault();
|
|
if (url.startsWith("file://")) {
|
|
try {
|
|
let filePath = decodeURIComponent(url.substring(7));
|
|
if (filePath.startsWith("/") && filePath.charAt(2) === ":") {
|
|
filePath = filePath.substring(1);
|
|
}
|
|
console.log("Opening file path:", filePath);
|
|
shell.openPath(filePath);
|
|
} catch (error) {
|
|
console.error("Failed to open file:", error);
|
|
}
|
|
} else {
|
|
window.open(url, "_blank", "noopener,noreferrer");
|
|
}
|
|
});
|
|
}
|
|
}
|
|
}
|
|
});
|
|
}
|
|
onunload() {
|
|
}
|
|
};
|
|
// Annotate the CommonJS export names for ESM import in node:
|
|
0 && (module.exports = {});
|
|
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["main.ts"],
  "sourcesContent": ["import { Plugin } from 'obsidian';\r\nimport { fileURLToPath } from 'url';\r\n\r\nconst { shell } = require('electron');\r\n\r\n// Simple YAML parser for color properties\r\nfunction parseYAML(text: string) {\r\n\tconst result: Record<string, string> = {};\r\n\tconst lines = text.split('\\n');\r\n\tfor (const line of lines) {\r\n\t\tconst trimmed = line.trim();\r\n\t\tif (trimmed && trimmed.includes(':')) {\r\n\t\t\tconst [key, ...valueParts] = trimmed.split(':');\r\n\t\t\tconst value = valueParts.join(':').trim();\r\n\t\t\tif (key && value) {\r\n\t\t\t\tresult[key.trim()] = value;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\treturn result;\r\n}\r\n\r\nexport default class MenuPlugin extends Plugin {\r\n\tasync onload() {\r\n\t\tthis.registerMarkdownCodeBlockProcessor('menu', (source, el, ctx) => {\r\n\t\t\tconst lines = source.trim().split('\\n');\r\n\t\t\tlet layout = '';\r\n\t\t\tlet colors: Record<string, string> = {};\r\n\t\t\tconst links: string[] = [];\r\n\t\t\t\r\n\t\t\t// Parse YAML-like properties and links\r\n\t\t\tfor (const line of lines) {\r\n\t\t\t\tconst trimmed = line.trim();\r\n\t\t\t\tif (trimmed.startsWith('layout:') || trimmed.startsWith('class:')) {\r\n\t\t\t\t\tconst colonIndex = trimmed.indexOf(':');\r\n\t\t\t\t\tlayout = trimmed.substring(colonIndex + 1).trim();\r\n\t\t\t\t} else if (trimmed.includes(':') && !trimmed.startsWith('[') && !trimmed.startsWith('[[')) {\r\n\t\t\t\t\t// Parse color properties\r\n\t\t\t\t\tconst [key, ...valueParts] = trimmed.split(':');\r\n\t\t\t\t\tconst value = valueParts.join(':').trim();\r\n\t\t\t\t\tif (key && value && !key.includes('//') && !key.includes('http')) {\r\n\t\t\t\t\t\tcolors[key.trim()] = value;\r\n\t\t\t\t\t}\r\n\t\t\t\t} else if (trimmed && !trimmed.includes(':')) {\r\n\t\t\t\t\tlinks.push(trimmed);\r\n\t\t\t\t} else if (trimmed.startsWith('[')) {\r\n\t\t\t\t\tlinks.push(trimmed);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\t\r\n\t\t\tconst finalLayout = layout || 'default';\r\n\t\t\tconst container = el.createEl('div', { cls: `menu-container ${finalLayout}` });\r\n\t\t\t\r\n\t\t\t// Apply custom colors as CSS variables\r\n\t\t\tif (Object.keys(colors).length > 0) {\r\n\t\t\t\tfor (const [key, value] of Object.entries(colors)) {\r\n\t\t\t\t\t// Replace 'accent' with 'hover-text' for consistency\r\n\t\t\t\t\tlet cssKey = key.replace(/accent/g, 'hover-text');\r\n\t\t\t\t\tcontainer.style.setProperty(`--${cssKey}`, value);\r\n\t\t\t\t}\r\n\t\t\t\t// Example: ensure hover-text is set and add a comment for usage\r\n\t\t\t\tif (colors['hover-text']) {\r\n\t\t\t\t\tcontainer.style.setProperty('--hover-text', colors['hover-text']);\r\n\t\t\t\t\t// To use in CSS: a:hover { color: var(--hover-text); }\r\n\t\t\t\t}\r\n\t\t\t}\r\n \r\n\t\t\t// Process each link\r\n\t\t\tfor (const link of links) {\r\n\t\t\t\tif (link.startsWith('[[') && link.endsWith(']]')) {\r\n\t\t\t\t\t// Internal link\r\n\t\t\t\t\tconst linkContent = link.slice(2, -2);\r\n\t\t\t\t\tlet href = linkContent;\r\n\t\t\t\t\tlet text = linkContent;\r\n\t\t\t\t\tif (linkContent.includes('|')) {\r\n\t\t\t\t\t\t[href, text] = linkContent.split('|');\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconst a = container.createEl('a', {\r\n\t\t\t\t\t\ttext: text,\r\n\t\t\t\t\t\tattr: { 'data-href': href }\r\n\t\t\t\t\t});\r\n\t\t\t\t\ta.addClass('menu-internal-link');\r\n\t\t\t\t\ta.style.cursor = 'pointer';\r\n\t\t\t\t\ta.addEventListener('click', (e) => {\r\n\t\t\t\t\t\te.preventDefault();\r\n\t\t\t\t\t\tconst vaultName = this.app.vault.getName();\r\n\t\t\t\t\t\tconst encodedFile = encodeURIComponent(href);\r\n\t\t\t\t\t\tconst uri = `obsidian://open?vault=${encodeURIComponent(vaultName)}&file=${encodedFile}`;\r\n\t\t\t\t\t\twindow.open(uri);\r\n\t\t\t\t\t});\r\n\t\t\t\t} else if (link.match(/^\\[.*\\]\\(.*\\)$/)) {\r\n\t\t\t\t\t// External link\r\n\t\t\t\t\tconst match = link.match(/^\\[(.*)\\]\\((.*)\\)$/);\r\n\t\t\t\t\tif (match) {\r\n\t\t\t\t\t\tconst text = match[1];\r\n\t\t\t\t\t\tconst url = match[2];\r\n\t\t\t\t\t\tconst a = container.createEl('a', {\r\n\t\t\t\t\t\t\ttext: text,\r\n\t\t\t\t\t\t\tattr: url.startsWith('file://') ? {} : { href: url, target: '_blank', rel: 'noopener noreferrer' }\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\ta.style.cursor = 'pointer';\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t\t// Add appropriate class based on link type\r\n\t\t\t\t\t\tif (url.startsWith('file://')) {\r\n\t\t\t\t\t\t\ta.addClass('menu-file-link');\r\n\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\ta.addClass('menu-external-link');\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\ta.addEventListener('click', (e) => {\r\n\t\t\t\t\t\t\te.preventDefault();\r\n\t\t\t\t\t\t\tif (url.startsWith('file://')) {\r\n\t\t\t\t\t\t\t\ttry {\r\n\t\t\t\t\t\t\t\t\t// Convert file URL to path and handle Windows paths\r\n\t\t\t\t\t\t\t\t\tlet filePath = decodeURIComponent(url.substring(7)); // Remove 'file://'\r\n\t\t\t\t\t\t\t\t\t// Handle Windows paths that start with /C:\r\n\t\t\t\t\t\t\t\t\tif (filePath.startsWith('/') && filePath.charAt(2) === ':') {\r\n\t\t\t\t\t\t\t\t\t\tfilePath = filePath.substring(1);\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\tconsole.log('Opening file path:', filePath);\r\n\t\t\t\t\t\t\t\t\tshell.openPath(filePath);\r\n\t\t\t\t\t\t\t\t} catch (error) {\r\n\t\t\t\t\t\t\t\t\tconsole.error('Failed to open file:', error);\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t} else {\r\n\t\t\t\t\t\t\t\twindow.open(url, '_blank', 'noopener,noreferrer');\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tonunload() {\r\n\t\t// Cleanup if needed\r\n\t}\r\n}\r\n"],
  "mappings": "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",
  "names": []
}

|