/* 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: () => lineArrange }); module.exports = __toCommonJS(main_exports); var import_obsidian = require("obsidian"); var lineArrange = class extends import_obsidian.Plugin { // Method called when the plugin is loaded async onload() { this.addCommand({ id: "lexisort-lines", name: "Lexisort lines", editorCallback: (editor) => { const selection = editor.getSelection(); editor.replaceSelection(lexiSortLines(selection)); } }); this.addCommand({ id: "reverse-lines", name: "Reverse lines", editorCallback: (editor) => { const selection = editor.getSelection(); editor.replaceSelection(reverseLines(selection)); } }); this.addCommand({ id: "sort-lines", name: "Sort lines", editorCallback: (editor) => { const selection = editor.getSelection(); editor.replaceSelection(sortLines(selection)); } }); this.addCommand({ id: "shuffle-lines", name: "Shuffle lines", editorCallback: (editor) => { const selection = editor.getSelection(); editor.replaceSelection(shuffleLines(selection)); } }); } }; var textSize = getComputedStyle(document.body).getPropertyValue("--font-text-size"); var textFont = getComputedStyle(document.body).getPropertyValue("--font-text"); function lexiSortLines(orgText) { const lines = orgText.split("\n"); lines.sort(); let srtLines = ""; lines.forEach((line) => { if (line.length > 0) { srtLines += line + "\n"; } else { srtLines = "\n" + srtLines; } }); return srtLines.trimEnd(); } function reverseLines(orgText) { const lines = orgText.split("\n"); lines.reverse(); let revLines = ""; lines.forEach((line) => { if (line.length > 0) { revLines += line + "\n"; } else { revLines = "\n" + revLines; } }); return revLines.trimEnd(); } function sortLines(orgText) { const lines = orgText.split("\n"); const arr1 = new Arrangement(lines, realLineWidth); return orderedText(arr1); } function realLineWidth(line) { const canvas = document.createElement("canvas"); const context = canvas.getContext("2d"); if (!context) { throw new Error("Failed to get 2D context"); } context.font = textSize + " " + textFont; return Math.round(1e4 * context.measureText(line).width); } function shuffleLines(orgText) { const lines = orgText.split("\n"); const arr2 = new Arrangement(lines, randomLineWidth); return orderedText(arr2); } function randomLineWidth(line) { if (line.length > 0) return Math.round(1e4 * (Math.random() + 1)); else return 0; } var Arrangement = class { // Creates a key for each unique line-width and associates line to respective slot constructor(linesList, lineFunction) { linesList.forEach((line) => { const width = lineFunction(line); if (!(width in this)) { this[width] = line; } else { this[width] = this[width].concat("\n" + line); } }); } }; function orderedText(orderedLines) { let finalText = ""; for (const lineKey in orderedLines) { finalText += orderedLines[lineKey] + "\n"; } return finalText.trimEnd(); } //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["main.ts"],
  "sourcesContent": ["import { Editor, Plugin } from 'obsidian';\n\nexport default class lineArrange extends Plugin {\n    // Method called when the plugin is loaded\n    async onload() {\n\n        // Add a command to lexically sort lines in the editor\n        this.addCommand({\n            id: 'lexisort-lines',\n            name: 'Lexisort lines',\n            editorCallback: (editor: Editor) => {\n                const selection = editor.getSelection(); // Get the selected text\n                editor.replaceSelection(lexiSortLines(selection)); // Replace selection with lexically sorted lines\n            },\n        });\n\n        // Add a command to reverse lines in the editor\n        this.addCommand({\n            id: 'reverse-lines',\n            name: 'Reverse lines',\n            editorCallback: (editor: Editor) => {\n                const selection = editor.getSelection(); // Get the selected text\n                editor.replaceSelection(reverseLines(selection)); // Replace selection with reversed lines\n            },\n        });\n\n        // Add a command to sort lines in the editor\n        this.addCommand({\n            id: 'sort-lines',\n            name: 'Sort lines',\n            editorCallback: (editor: Editor) => {\n                const selection = editor.getSelection(); // Get the selected text\n                editor.replaceSelection(sortLines(selection)); // Replace selection with sorted lines\n            },\n        });\n\n        // Add a command to shuffle lines in the editor\n        this.addCommand({\n            id: 'shuffle-lines',\n            name: 'Shuffle lines',\n            editorCallback: (editor: Editor) => {\n                const selection = editor.getSelection(); // Get the selected text\n                editor.replaceSelection(shuffleLines(selection)); // Replace selection with shuffled lines\n            },\n        });\n    }\n}\n\nconst textSize = getComputedStyle(document.body).getPropertyValue(\"--font-text-size\");\nconst textFont = getComputedStyle(document.body).getPropertyValue(\"--font-text\");\n\n// Function to lexically sort the selected lines of text\nfunction lexiSortLines(orgText: string): string {\n    const lines = orgText.split(\"\\n\"); // Split the original text into lines\n    lines.sort(); // Sort the array of lines\n    let srtLines = \"\";\n    lines.forEach(line => {\n        if (line.length > 0) {\n            srtLines += (line + '\\n'); // Add each line to the returning text string\n        }\n        else {\n            srtLines = ('\\n' + srtLines); \n        }\n    });\n    return srtLines.trimEnd(); // Return the lexically sorted lines\n}\n\n// Function to reverse the selected lines of text\nfunction reverseLines(orgText: string): string {\n    const lines = orgText.split(\"\\n\"); // Split the original text into lines\n    lines.reverse(); // Reverse the array of lines\n    let revLines = \"\";\n    lines.forEach(line => {\n        if (line.length > 0) {\n            revLines += (line + '\\n'); // Add each line to the returning text string\n        }\n        else {\n            revLines = ('\\n' + revLines);\n        }\n    });\n    return revLines.trimEnd(); // Return the reversed lines\n}\n\n// Function to sort lines based on their visual width\nfunction sortLines(orgText: string): string {\n    const lines = orgText.split(\"\\n\"); // Split the original text into lines\n    const arr1 = new Arrangement(lines, realLineWidth); // Create an arrangement based on real line width\n    return orderedText(arr1); // Return the ordered text from the arrangement\n}\n\n// Function to calculate the visual width of a line\nfunction realLineWidth(line: string): number {\n    const canvas = document.createElement('canvas');\n    const context = canvas.getContext('2d');\n    if (!context) {\n        throw new Error('Failed to get 2D context');\n    }\n    context.font = textSize + \" \" + textFont;\n    return Math.round(10000 * (context.measureText(line).width)); // Return the width as a normalised integer\n}\n\n// Function to shuffle lines randomly\nfunction shuffleLines(orgText: string) {\n    const lines = orgText.split(\"\\n\"); // Split the original text into lines\n    const arr2 = new Arrangement(lines, randomLineWidth); // Create an arrangement based on random line width\n    return orderedText(arr2); // Return the ordered text from the arrangement\n}\n\n// Function to generate a random width for a line\nfunction randomLineWidth(line: string): number {\n    if (line.length > 0)\n        return Math.round(10000 * (Math.random() + 1)); // Return a random number as a normalised integer\n    else\n        return 0; // Return 0 for empty lines\n}\n\n// Class to arrange lines based on their calculated widths\nclass Arrangement {\n    [width: number]: string;\n\n    // Creates a key for each unique line-width and associates line to respective slot\n    constructor(linesList: string[], lineFunction: (line: string) => number) {\n        linesList.forEach(line => {\n            const width = lineFunction(line);\n            if (!(width in this)) {\n                this[width] = line; // Store the line if the width key doesn't exist\n            } else {\n                this[width] = this[width].concat(\"\\n\" + line); // Concatenate lines with the same width slot\n            }\n        });\n    }\n}\n\n// Function to generate the final ordered text from the arrangement\nfunction orderedText(orderedLines: Arrangement): string {\n    let finalText = \"\";\n    for (const lineKey in orderedLines) {\n        finalText += (orderedLines[lineKey] + '\\n'); // Append each line followed by a newline character\n    }\n    return finalText.trimEnd(); // Trim the final text to remove trailing newlines\n}\n"],
  "mappings": "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",
  "names": []
}
