generated from obsidianmd/obsidian-sample-plugin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.js
160 lines (155 loc) · 19.9 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
/*
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: () => GenerateDiffPlugin
});
module.exports = __toCommonJS(main_exports);
var import_obsidian = require("obsidian");
// src/constants.ts
var DIRECTORY_PATH = "generate-and-diff";
var RESULTS_DIRECTORY_PATH = `${DIRECTORY_PATH}/results`;
// src/utils.ts
var GenerateDiffPluginUtils = class {
static formatDate(date) {
const year = date.getFullYear();
const month = (date.getMonth() + 1).toString().padStart(2, "0");
const day = date.getDate().toString().padStart(2, "0");
const hours = date.getHours().toString().padStart(2, "0");
const minutes = date.getMinutes().toString().padStart(2, "0");
const seconds = date.getSeconds().toString().padStart(2, "0");
return `${year}${month}${day}-${hours}${minutes}${seconds}`;
}
static getDeviceName() {
let platform = "";
if (navigator.userAgent) {
platform = navigator.userAgent.toLowerCase();
}
if (platform.includes("windows"))
return "Windows";
if (platform.includes("macintosh")) {
if (platform.includes("mobile"))
return "iPadOS";
return "Mac";
}
if (platform.includes("linux"))
return "Linux";
if (platform.includes("iphone"))
return "iOS";
if (platform.includes("android"))
return "Android";
return "Unknown";
}
};
// main.ts
var GenerateDiffPlugin = class extends import_obsidian.Plugin {
// Try to detect device status
get syncPlugin() {
return this.app.internalPlugins.getPluginById("sync");
}
// Plugin is loaded
async onload() {
var _a;
console.log("Loading Generate and Diff " + this.manifest.version);
const syncEnabled = ((_a = this.syncPlugin) == null ? void 0 : _a.instance) != void 0;
this.device = syncEnabled ? this.syncPlugin.instance.deviceName.length > 0 ? this.syncPlugin.instance.deviceName : this.syncPlugin.instance.getDefaultDeviceName() : "Unknown";
console.debug("Generate and Diff:", this.device);
this.addCommand({
// Give it an id
id: "generate-file-list",
// Give it a name
name: "Generate File List",
// Give it a callback
callback: () => this.generateFileList()
});
this.addCommand({
// Give it an id
id: "compare-files",
// Give it a name
name: "Compare Files",
// Give it a callback
callback: () => this.compareFiles()
});
}
/* Now we move onto running the commands */
// Generate file list once the command is called
async generateFileList() {
const files = this.app.vault.getFiles();
let fileContent = "# File List\n\n";
for (const file of files) {
const fileStats = file.stat;
fileContent += `- **Path**: ${file.path} | **Last Modified**: ${new Date(fileStats.mtime).toLocaleString()}
`;
}
const deviceName = GenerateDiffPluginUtils.getDeviceName();
const timestamp = GenerateDiffPluginUtils.formatDate(new Date());
const fileName = `${DIRECTORY_PATH}/${timestamp}-${deviceName}.md`;
const directoryExists = await this.app.vault.adapter.exists(DIRECTORY_PATH);
if (!directoryExists) {
await this.app.vault.createFolder(DIRECTORY_PATH);
}
try {
await this.app.vault.create(fileName, fileContent);
console.log(`File list generated: ${fileName}`);
} catch (error) {
console.error(`Error generating file list: ${error}`);
}
}
// compare files once the command is called
async compareFiles() {
var _a, _b;
const fileList = this.app.vault.getFiles().filter((file) => file.path.startsWith(DIRECTORY_PATH + "/") && !file.path.startsWith(RESULTS_DIRECTORY_PATH + "/"));
let fileMap = {};
for (const file of fileList) {
const fileContent = await this.app.vault.read(file);
const lines = fileContent.split("\n").filter((line) => line.startsWith("- **Path**:"));
const deviceName = (_b = (_a = file.name.split("-").pop()) == null ? void 0 : _a.split(".")[0]) != null ? _b : "Unknown";
for (const line of lines) {
const filePath = line.split("|")[0].trim().replace("- **Path**: ", "");
if (!fileMap[filePath]) {
fileMap[filePath] = [];
}
fileMap[filePath].push(deviceName);
}
}
let comparisonResults = "# Comparison Results\n\n";
for (const [filePath, devices] of Object.entries(fileMap)) {
if (devices.length === 1) {
comparisonResults += `- **Path**: ${filePath} | **Exists on**: ${devices[0]}
`;
}
}
const timestamp = GenerateDiffPluginUtils.formatDate(new Date());
const resultsFileName = `${RESULTS_DIRECTORY_PATH}/${timestamp}-comparison-results.md`;
const resultsDirectoryExists = await this.app.vault.adapter.exists(RESULTS_DIRECTORY_PATH);
if (!resultsDirectoryExists) {
await this.app.vault.createFolder(RESULTS_DIRECTORY_PATH);
}
await this.app.vault.create(resultsFileName, comparisonResults);
console.log("Your results have been compared.");
}
async onunload() {
console.log("Unloading Generate and Diff");
}
};
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["main.ts", "src/constants.ts", "src/utils.ts"],
  "sourcesContent": ["/// <reference path=\"src/types.ts\" />\n\n// Import from Obsidian API\nimport {Plugin} from 'obsidian';\n\n// Import from SRC\nimport {DIRECTORY_PATH, RESULTS_DIRECTORY_PATH} from 'src/constants';\nimport {GenerateDiffPluginUtils} from 'src/utils';\n\n// Create Plugin wrapper\nexport default class GenerateDiffPlugin extends Plugin {\n    device: string;\n\n    // Try to detect device status\n    get syncPlugin() {\n        return this.app.internalPlugins.getPluginById(\"sync\");\n    }\n\n    // Plugin is loaded\n    async onload() {\n        // Print that the plugin has been loaded\n        console.log(\"Loading Generate and Diff \" + this.manifest.version);\n\n        // Get device names\n        const syncEnabled = this.syncPlugin?.instance != undefined;\n        this.device = syncEnabled\n            ? (this.syncPlugin.instance.deviceName.length > 0\n                ? this.syncPlugin.instance.deviceName\n                : this.syncPlugin.instance.getDefaultDeviceName())\n            : \"Unknown\";\n        console.debug(\"Generate and Diff:\", this.device);\n\n        // Add a command to generate file list to command palette\n        this.addCommand({\n            // Give it an id\n            id: 'generate-file-list', // Give it a name\n            name: 'Generate File List', // Give it a callback\n            callback: () => this.generateFileList(),\n        });\n\n        // Add a command to compare files to command palette\n        this.addCommand({\n            // Give it an id\n            id: 'compare-files', // Give it a name\n            name: 'Compare Files', // Give it a callback\n            callback: () => this.compareFiles(),\n        });\n        // Nothing else we need to do\n    }\n\n    /* Now we move onto running the commands */\n\n    // Generate file list once the command is called\n    async generateFileList() {\n        // Get all the files in the vault and call it with files\n        const files = this.app.vault.getFiles();\n        // Create a file content\n        let fileContent = '# File List\\n\\n';\n\n        // Loop through the files recursively\n        for (const file of files) {\n            // Get the file stats\n            const fileStats = file.stat;\n            // Add the file path and last modified date to the file content\n            fileContent += `- **Path**: ${file.path} | **Last Modified**: ${new Date(fileStats.mtime).toLocaleString()}\\n`;\n            // End loop\n        }\n\n        // Get the device name\n        const deviceName = GenerateDiffPluginUtils.getDeviceName();\n        // Get the timestamp\n        const timestamp = GenerateDiffPluginUtils.formatDate(new Date());\n        // Create the file name\n        const fileName = `${DIRECTORY_PATH}/${timestamp}-${deviceName}.md`;\n\n        // Ensure the directory exists, and if not, create it\n        const directoryExists = await this.app.vault.adapter.exists(DIRECTORY_PATH);\n        if (!directoryExists) {\n            await this.app.vault.createFolder(DIRECTORY_PATH);\n        }\n\n        // try and catch for file generation\n        try {\n            await this.app.vault.create(fileName, fileContent);\n            console.log(`File list generated: ${fileName}`);\n        } catch (error) {\n            console.error(`Error generating file list: ${error}`);\n        }\n    }\n\n    // compare files once the command is called\n    async compareFiles() {\n        // Get all the files in the vault and call it with files\n        const fileList = this.app.vault.getFiles().filter(file => file.path.startsWith(DIRECTORY_PATH + '/') && !file.path.startsWith(RESULTS_DIRECTORY_PATH + '/'));\n        // Create a file map\n        let fileMap: { [key: string]: string[] } = {};\n\n        // Loop through the files recursively\n        for (const file of fileList) {\n            // Get the file content\n            const fileContent = await this.app.vault.read(file);\n            // Get the lines and determine where linebreaks are\n            const lines = fileContent.split('\\n').filter(line => line.startsWith('- **Path**:'));\n            // Get the device name\n            const deviceName = file.name.split('-').pop()?.split('.')[0] ?? 'Unknown';\n\n            // Loop through the lines\n            for (const line of lines) {\n                // Get the file path\n                const filePath = line.split('|')[0].trim().replace('- **Path**: ', '');\n                // If the file path doesn't exist in the file map, create an empty array\n                if (!fileMap[filePath]) {\n                    // Create an empty array\n                    fileMap[filePath] = [];\n                }\n                // Push the device name to the file map\n                fileMap[filePath].push(deviceName);\n            }\n            // End loop\n        }\n\n        // Create a comparison results\n        let comparisonResults = '# Comparison Results\\n\\n';\n        // Loop through the file map\n        for (const [filePath, devices] of Object.entries(fileMap)) {\n            // If the file exists on only one device\n            if (devices.length === 1) {\n                // Add the comparison results\n                comparisonResults += `- **Path**: ${filePath} | **Exists on**: ${devices[0]}\\n`;\n            }\n            // End loop\n        }\n\n        // Get the timestamp\n        const timestamp = GenerateDiffPluginUtils.formatDate(new Date());\n        // Create the results file name\n        const resultsFileName = `${RESULTS_DIRECTORY_PATH}/${timestamp}-comparison-results.md`;\n\n        // Ensure the results directory exists\n        const resultsDirectoryExists = await this.app.vault.adapter.exists(RESULTS_DIRECTORY_PATH);\n        if (!resultsDirectoryExists) {\n            await this.app.vault.createFolder(RESULTS_DIRECTORY_PATH);\n        }\n\n\n        // Create the results file\n        await this.app.vault.create(resultsFileName, comparisonResults);\n\n        // Log the comparison results\n        console.log(\"Your results have been compared.\");\n    }\n\n\tasync onunload() {\n\t\tconsole.log('Unloading Generate and Diff');\n\t}\n}\n", "export const DIRECTORY_PATH = 'generate-and-diff';\nexport const RESULTS_DIRECTORY_PATH = `${DIRECTORY_PATH}/results`;\n", "export class GenerateDiffPluginUtils {\n    static formatDate(date: Date): string {\n        const year = date.getFullYear();\n        const month = (date.getMonth() + 1).toString().padStart(2, '0');\n        const day = date.getDate().toString().padStart(2, '0');\n        const hours = date.getHours().toString().padStart(2, '0');\n        const minutes = date.getMinutes().toString().padStart(2, '0');\n        const seconds = date.getSeconds().toString().padStart(2, '0');\n        return `${year}${month}${day}-${hours}${minutes}${seconds}`;\n    }\n\n    static getDeviceName(): string {\n        let platform: string = '';\n\n        if (navigator.userAgent) {\n            platform = navigator.userAgent.toLowerCase();\n        }\n\n        if (platform.includes('windows')) return 'Windows';\n        if (platform.includes('macintosh')) {\n            if (platform.includes('mobile')) return 'iPadOS';\n            return 'Mac';\n        }\n        if (platform.includes('linux')) return 'Linux';\n        if (platform.includes('iphone')) return 'iOS';\n        if (platform.includes('android')) return 'Android';\n        return 'Unknown';\n    }\n}\n"],
  "mappings": "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",
  "names": []
}
