1
0
Fork 0
digital-art-composition-book/.obsidian/plugins/line-arrange/main.js
2024-09-14 11:25:13 -04:00

142 lines
15 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: () => 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": []
}
