├── .DS_Store ├── .gitignore ├── FinderMirror.jpg ├── ObsidianMirror.gif ├── README.md ├── data.json ├── main.js ├── main.ts ├── manifest.json ├── package-lock.json ├── package.json ├── rollup.config.js ├── styles.css ├── tsconfig.json └── versions.json /.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wildspecial/obsidian-mirror/c32614d4b893578bb4bfd7ca05326f7c649c904e/.DS_Store -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Intellij 2 | *.iml 3 | .idea 4 | 5 | # npm 6 | node_modules 7 | package-lock.json 8 | 9 | # build 10 | main.js 11 | *.js.map 12 | 13 | # obsidian 14 | data.json 15 | -------------------------------------------------------------------------------- /FinderMirror.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wildspecial/obsidian-mirror/c32614d4b893578bb4bfd7ca05326f7c649c904e/FinderMirror.jpg -------------------------------------------------------------------------------- /ObsidianMirror.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wildspecial/obsidian-mirror/c32614d4b893578bb4bfd7ca05326f7c649c904e/ObsidianMirror.gif -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## Obsidian Mirror Plugin 2 | 3 | Here we are, you have multiple monitors (sometimes I have up to 6 monitors) and you want to be 200% productive with Obsidian. 4 | 5 | On one monitor you have a file opened and on another monitor you want to have a **full screen** `local graph` that helps you to connect the dots (in your mind) 6 | 7 | Why? simply because the local graph in the same Obsidian instance is too small! 8 | 9 | I was desperate and fortunately I found a workaround to run multiple instances of Obsidian in the forum using *symlink* [here](https://forum.obsidian.md/t/floating-pop-out-multiple-windows-of-the-same-vault/837/58) 10 | NB: *symlink* to create virtual links. 11 | 12 | After successfully created symlinks `ln -s` you should be able to have a "mirror" Vault which will contain the symlink of the main Vault you want to use. 13 | 14 | Here is an example: 15 | 16 | ![FinderMirror](FinderMirror.jpg) 17 | 18 | Unfortunatelly this solution partially works cause when I switch context from the main Obsidian's instance, there is no way to propagate this to a second obsidian's instance. 19 | 20 | So I created (in several hours) this plugin that syncs the active file among different Obsidian's instances. 21 | 22 | Here's a quick gif that shows how it works (right side the main Obsidian'instance, left side the secondary *mirror* obsidian's instance) 23 | 24 | ![Gif](ObsidianMirror.gif) 25 | 26 | This plugin is far from being perfect. I rely on the community to enhance it and make it more rubust. 27 | 28 | In the meantime, if you are not a developer, you can FINALLY use the precious **local graph** on a different monitor. 29 | 30 | 31 | ## Installation Info 32 | 33 | This plugin is not (yet) available in the official plugin lists. I created a pull request and waiting for a confirmation. 34 | 35 | ### Manual 36 | 1) Download/clone this repo 37 | 2) Copy the folder `obsidian-mirror` to the `plugin` folder of the main Obsidian's instance 38 | 3) Copy the same folder `obsidian-mirror` to the `plugin` folder of the second Obsidian's instance 39 | 4) Activate the plugin in both obsidian's instances 40 | 5) Go to the settings of both Obsidian's instances 41 | 6) Make sure you configure exactly the same info in both instances 42 | 7) Put the **main** vault's name (Voult's name of the main Obsidian's instance) 43 | 8) Chose a name for the file that the plugin will use to sync the workspaces 44 | 45 | 46 | ### Official 47 | *pending approval* 48 | 49 | 50 | ## Additional Info 51 | The fastes way that came in my mind in order to sync the opened file among different instances was to use a *temporary* file in the main Vault. 52 | 53 | The main instance of Obsidina will write the active file path in the temporary file and the secondary instance will read that content and open the active file. 54 | 55 | No timer/setinterval mechanisms are used. Everything is *event based*. Obsidian writes/reads the file content only when it changes. 56 | 57 | 58 | Enjoy! -------------------------------------------------------------------------------- /data.json: -------------------------------------------------------------------------------- 1 | { 2 | "isMirror": false, 3 | "vault": "TechKnowledge", 4 | "fileName": "ObsidianMirror.md", 5 | "fileNameGraph": "ObsidianMirror._graph.md" 6 | } -------------------------------------------------------------------------------- /main.js: -------------------------------------------------------------------------------- 1 | /* 2 | THIS IS A GENERATED/BUNDLED FILE BY ROLLUP 3 | if you want to view the source visit the plugins github repository 4 | */ 5 | 6 | 'use strict'; 7 | 8 | var obsidian = require('obsidian'); 9 | 10 | /*! ***************************************************************************** 11 | Copyright (c) Microsoft Corporation. 12 | 13 | Permission to use, copy, modify, and/or distribute this software for any 14 | purpose with or without fee is hereby granted. 15 | 16 | THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH 17 | REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY 18 | AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, 19 | INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM 20 | LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR 21 | OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 22 | PERFORMANCE OF THIS SOFTWARE. 23 | ***************************************************************************** */ 24 | 25 | function __awaiter(thisArg, _arguments, P, generator) { 26 | function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } 27 | return new (P || (P = Promise))(function (resolve, reject) { 28 | function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } 29 | function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } 30 | function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } 31 | step((generator = generator.apply(thisArg, _arguments || [])).next()); 32 | }); 33 | } 34 | 35 | const DEFAULT_SETTINGS = { 36 | isMirror: false, 37 | vault: "", 38 | fileName: "ObsidianMirror.md", 39 | fileNameGraph: "ObsidianMirror_graph.md" 40 | }; 41 | class ObidianMirrorPlugin extends obsidian.Plugin { 42 | constructor() { 43 | super(...arguments); 44 | this.openedByThisPlugin = false; 45 | this.wroteByThisPlugin = false; 46 | this.activeFile = this.app.workspace.getActiveFile(); 47 | } 48 | onload() { 49 | return __awaiter(this, void 0, void 0, function* () { 50 | console.log('loading plugin'); 51 | yield this.loadSettings(); 52 | this.addRibbonIcon('dice', 'Obsidian Mirror', () => { 53 | new obsidian.Notice('This is a notice!'); 54 | }); 55 | this.addStatusBarItem().setText('Obsidian Mirror'); 56 | this.addCommand({ 57 | id: 'open-sample-modal', 58 | name: 'Open Sample Modal', 59 | // callback: () => { 60 | // console.log('Simple Callback'); 61 | // }, 62 | checkCallback: (checking) => { 63 | let leaf = this.app.workspace.activeLeaf; 64 | if (leaf) { 65 | if (!checking) { 66 | new SampleModal(this.app).open(); 67 | } 68 | return true; 69 | } 70 | return false; 71 | } 72 | }); 73 | this.addSettingTab(new ObsidianMirrorSettingTab(this.app, this)); 74 | this.registerCodeMirror((cm) => { 75 | console.log('codemirror', cm); 76 | }); 77 | this.registerDomEvent(document, 'click', (evt) => { 78 | console.log('click', evt); 79 | }); 80 | this.registerInterval(window.setInterval(() => console.log('setInterval'), 5 * 60 * 1000)); 81 | this.app.workspace.on('file-open', () => __awaiter(this, void 0, void 0, function* () { 82 | const activeLeaf = this.app.workspace.activeLeaf; 83 | if (!activeLeaf) { 84 | return; 85 | } 86 | this.lastFile(); 87 | })); 88 | this.registerEvent(this.app.vault.on('modify', (file) => this.onChangeFile(file))); 89 | }); 90 | } 91 | onChangeFile(file) { 92 | return __awaiter(this, void 0, void 0, function* () { 93 | console.log("this.settings.isMirror:" + this.settings.isMirror); 94 | console.log("vault this.settings.fileName:" + this.settings.vault + "/" + this.settings.fileName); 95 | console.log("vault + filnemagraph:" + this.settings.vault + "/" + this.settings.fileNameGraph); 96 | console.log("active file:" + this.app.workspace.getActiveFile().path); 97 | console.log("file.path:" + file.path); 98 | if (!this.openedByThisPlugin) { 99 | if (this.settings.isMirror && file.path == this.settings.vault + "/" + this.settings.fileName || !this.settings.isMirror && file.path == this.settings.fileNameGraph) { 100 | console.log("passed"); 101 | this.readActiveOpenedFile(); 102 | } 103 | } 104 | else { 105 | this.openedByThisPlugin = false; 106 | } 107 | }); 108 | } 109 | lastFile() { 110 | return __awaiter(this, void 0, void 0, function* () { 111 | this.activeFile = this.app.workspace.getActiveFile(); 112 | console.log("lastFile"); 113 | setTimeout(() => { 114 | this.watchFileAndWrite(); 115 | }, 800); 116 | }); 117 | } 118 | watchFileAndWrite() { 119 | return __awaiter(this, void 0, void 0, function* () { 120 | var activeFile = this.activeFile; 121 | var sideCarFile = !this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName; })[0] : this.app.vault.getFiles().filter(f => { return f.path == this.settings.vault + "/" + this.settings.fileNameGraph; })[0]; 122 | console.log("sideCarFile:"); 123 | console.log(sideCarFile); 124 | if (!sideCarFile) { 125 | this.app.vault.create(!this.settings.isMirror ? this.settings.fileName : this.settings.vault + "/" + this.settings.fileNameGraph, ""); 126 | console.log("passato"); 127 | sideCarFile = this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName; })[0] : this.app.vault.getFiles().filter(f => { return f.path == this.settings.vault + "/" + this.settings.fileNameGraph; })[0]; 128 | } 129 | if (activeFile != null && activeFile != undefined) { 130 | console.log(`this is active file ${activeFile.name}`); 131 | yield this.app.vault.modify(sideCarFile, activeFile.name); 132 | } 133 | }); 134 | } 135 | readActiveOpenedFile() { 136 | return __awaiter(this, void 0, void 0, function* () { 137 | var sideCarFile = this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName; })[0] : this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileNameGraph; })[0]; 138 | console.log("sideCar:" + sideCarFile.name); 139 | var fileNameToOpen = yield (yield this.app.vault.read(sideCarFile)).trim(); 140 | var fileToOpen = this.app.vault.getFiles().filter(f => { return f.name == fileNameToOpen; })[0]; 141 | if (fileToOpen) { 142 | if ((fileToOpen === null || fileToOpen === void 0 ? void 0 : fileToOpen.name) != this.app.workspace.getActiveFile().name) { 143 | this.openedByThisPlugin = true; 144 | this.app.workspace.activeLeaf.openFile(fileToOpen); 145 | new obsidian.Notice(`ObsidianMirror: ${fileToOpen.basename} file opened`, 5000); 146 | } 147 | else { 148 | console.log("invalid file found or already opened"); 149 | } 150 | } 151 | }); 152 | } 153 | onunload() { 154 | console.log('unloading plugin'); 155 | } 156 | loadSettings() { 157 | return __awaiter(this, void 0, void 0, function* () { 158 | this.settings = Object.assign({}, DEFAULT_SETTINGS, yield this.loadData()); 159 | }); 160 | } 161 | saveSettings() { 162 | return __awaiter(this, void 0, void 0, function* () { 163 | yield this.saveData(this.settings); 164 | }); 165 | } 166 | } 167 | class SampleModal extends obsidian.Modal { 168 | constructor(app) { 169 | super(app); 170 | } 171 | onOpen() { 172 | let { contentEl } = this; 173 | contentEl.setText('Woah!'); 174 | } 175 | onClose() { 176 | let { contentEl } = this; 177 | contentEl.empty(); 178 | } 179 | } 180 | class ObsidianMirrorSettingTab extends obsidian.PluginSettingTab { 181 | constructor(app, plugin) { 182 | super(app, plugin); 183 | this.plugin = plugin; 184 | } 185 | display() { 186 | const { containerEl } = this; 187 | containerEl.empty(); 188 | containerEl.createEl('h2', { text: 'Obsidian Mirror - Settings' }); 189 | new obsidian.Setting(containerEl) 190 | .setName('Is this Obsidian instance a Mirror?') 191 | .setDesc('If enabled, this instance will "follow" whatever the main Obsidian instance has opened' + 192 | 'PS: In order to launch multiple Obsidian instances you have to follow a workaround suggested in this community Forum') 193 | .addToggle((toggle) => toggle.setValue(this.plugin.settings.isMirror).onChange((value) => { 194 | this.plugin.settings.isMirror = value; 195 | this.plugin.saveData(this.plugin.settings); 196 | this.display(); 197 | })); 198 | new obsidian.Setting(containerEl) 199 | .setName('Vault Name') 200 | .setDesc('Please enter the Vault name your are using in the main instance of Obsidian') 201 | .addText((text) => text 202 | .setPlaceholder('MyVaultName') 203 | .setValue(this.plugin.settings.vault) 204 | .onChange((value) => __awaiter(this, void 0, void 0, function* () { 205 | this.plugin.settings.vault = value; 206 | yield this.plugin.saveSettings(); 207 | }))); 208 | new obsidian.Setting(containerEl) 209 | .setName('Mirror File') 210 | .setDesc('Please enter the file name you want to use. This plugin will use it in order to watch the active file opned. PS: You can use a name of your choice') 211 | .addText((text) => text 212 | .setPlaceholder('ObsidianMirror.md') 213 | .setValue(this.plugin.settings.fileName) 214 | .onChange((value) => __awaiter(this, void 0, void 0, function* () { 215 | this.plugin.settings.fileName = value; 216 | this.plugin.settings.fileNameGraph = value.substring(0, value.length - 2) + "_graph.md"; 217 | yield this.plugin.saveSettings(); 218 | }))); 219 | } 220 | } 221 | 222 | module.exports = ObidianMirrorPlugin; 223 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"main.js","sources":["node_modules/tslib/tslib.es6.js","main.ts"],"sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    if (typeof b !== \"function\" && b !== null)\r\n        throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n    if (k2 === undefined) k2 = k;\r\n    o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n    var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n    if (m) return m.call(o);\r\n    if (o && typeof o.length === \"number\") return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n    throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n        if (ar || !(i in from)) {\r\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n            ar[i] = from[i];\r\n        }\r\n    }\r\n    return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n    o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n    __setModuleDefault(result, mod);\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n    return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n    if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n    if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n    if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n    return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","import { App, Modal, Notice, Plugin, PluginSettingTab, Setting, TAbstractFile, TFile, Vault } from 'obsidian';\r\nimport { fileURLToPath } from 'url';\r\n\r\ninterface ObsidianMirrorSettings {\r\n\tisMirror: boolean;\r\n\tvault: string\r\n\tfileName: string;\r\n\tfileNameGraph: string;\r\n}\r\n\r\nconst DEFAULT_SETTINGS: ObsidianMirrorSettings = {\r\n\tisMirror: false,\r\n\tvault: \"\",\r\n\tfileName: \"ObsidianMirror.md\",\r\n\tfileNameGraph: \"ObsidianMirror_graph.md\"\r\n}\r\n\r\nexport default class ObidianMirrorPlugin extends Plugin {\r\n\tsettings: ObsidianMirrorSettings;\r\n\r\n\topenedByThisPlugin: boolean = false;\r\n\twroteByThisPlugin: boolean = false;\r\n\tactiveFile: TFile = this.app.workspace.getActiveFile();\r\n\r\n\tasync onload() {\r\n\t\tconsole.log('loading plugin');\r\n\r\n\t\tawait this.loadSettings();\r\n\r\n\t\tthis.addRibbonIcon('dice', 'Obsidian Mirror', () => {\r\n\t\t\tnew Notice('This is a notice!');\r\n\t\t});\r\n\r\n\t\tthis.addStatusBarItem().setText('Obsidian Mirror');\r\n\r\n\t\tthis.addCommand({\r\n\t\t\tid: 'open-sample-modal',\r\n\t\t\tname: 'Open Sample Modal',\r\n\t\t\t// callback: () => {\r\n\t\t\t// \tconsole.log('Simple Callback');\r\n\t\t\t// },\r\n\t\t\tcheckCallback: (checking: boolean) => {\r\n\t\t\t\tlet leaf = this.app.workspace.activeLeaf;\r\n\t\t\t\tif (leaf) {\r\n\t\t\t\t\tif (!checking) {\r\n\t\t\t\t\t\tnew SampleModal(this.app).open();\r\n\t\t\t\t\t}\r\n\t\t\t\t\treturn true;\r\n\t\t\t\t}\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tthis.addSettingTab(new ObsidianMirrorSettingTab(this.app, this));\r\n\r\n\t\tthis.registerCodeMirror((cm: CodeMirror.Editor) => {\r\n\t\t\tconsole.log('codemirror', cm);\r\n\t\t});\r\n\r\n\t\tthis.registerDomEvent(document, 'click', (evt: MouseEvent) => {\r\n\t\t\tconsole.log('click', evt);\r\n\t\t});\r\n\r\n\t\tthis.registerInterval(window.setInterval(() => console.log('setInterval'), 5 * 60 * 1000));\r\n\r\n\t\tthis.app.workspace.on('file-open', async () => {\r\n\r\n\t\t\tconst activeLeaf = this.app.workspace.activeLeaf\r\n\t\t\tif (!activeLeaf) {\r\n\t\t\t\treturn\r\n\t\t\t}\r\n\r\n\t\t\tthis.lastFile();\r\n\r\n\r\n\t\t})\r\n\r\n\r\n\t\tthis.registerEvent(\r\n\t\t\tthis.app.vault.on('modify', (file) => this.onChangeFile(file))\r\n\t\t);\r\n\r\n\r\n\t}\r\n\r\n\tasync onChangeFile(file: TAbstractFile) {\r\n\r\n\t\tconsole.log(\"this.settings.isMirror:\" + this.settings.isMirror);\r\n\t\tconsole.log(\"vault this.settings.fileName:\" + this.settings.vault + \"/\" + this.settings.fileName);\r\n\t\tconsole.log(\"vault + filnemagraph:\" + this.settings.vault + \"/\" + this.settings.fileNameGraph)\r\n\t\tconsole.log(\"active file:\" + this.app.workspace.getActiveFile().path)\r\n\t\tconsole.log(\"file.path:\" + file.path);\r\n\r\n\t\tif (!this.openedByThisPlugin) {\r\n\t\t\tif (this.settings.isMirror && file.path == this.settings.vault + \"/\" + this.settings.fileName || !this.settings.isMirror && file.path == this.settings.fileNameGraph) {\r\n\t\t\t\tconsole.log(\"passed\");\r\n\t\t\t\tthis.readActiveOpenedFile();\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tthis.openedByThisPlugin = false;\r\n\t\t}\r\n\t}\r\n\r\n\r\n\tasync lastFile() {\r\n\r\n\t\tthis.activeFile = this.app.workspace.getActiveFile();\r\n\r\n\t\tconsole.log(\"lastFile\");\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.watchFileAndWrite();\r\n\t\t}, 800);\r\n\r\n\t} \r\n\r\n\r\n\r\n\tasync watchFileAndWrite() {\r\n\r\n\r\n\t\tvar activeFile: TFile = this.activeFile;\r\n\t\tvar sideCarFile = !this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName })[0] : this.app.vault.getFiles().filter(f => { return f.path == this.settings.vault + \"/\" + this.settings.fileNameGraph })[0];\r\n\t\tconsole.log(\"sideCarFile:\")\r\n\t\tconsole.log(sideCarFile)\r\n\t\tif (!sideCarFile) {\r\n\t\t\tthis.app.vault.create(!this.settings.isMirror ? this.settings.fileName : this.settings.vault + \"/\" + this.settings.fileNameGraph, \"\");\r\n\t\t\tconsole.log(\"passato\")\r\n\t\t\tsideCarFile = this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName })[0] : this.app.vault.getFiles().filter(f => { return f.path == this.settings.vault + \"/\" + this.settings.fileNameGraph })[0];\r\n\t\t}\r\n\t\tif (activeFile != null && activeFile != undefined) {\r\n\t\t\tconsole.log(`this is active file ${activeFile.name}`);\r\n\r\n\t\t\tawait this.app.vault.modify(sideCarFile, activeFile.name);\r\n\r\n\t\t}\r\n\r\n\r\n\t}\r\n\r\n\r\n\tasync readActiveOpenedFile() {\r\n\t\tvar sideCarFile = this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName })[0] : this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileNameGraph })[0];\r\n\r\n\t\tconsole.log(\"sideCar:\" + sideCarFile.name);\r\n\r\n\r\n\t\tvar fileNameToOpen = await (await this.app.vault.read(sideCarFile)).trim();\r\n\t\tvar fileToOpen: TFile = this.app.vault.getFiles().filter(f => { return f.name == fileNameToOpen })[0];\r\n\r\n\r\n\t\tif (fileToOpen) {\r\n\t\t\tif (fileToOpen?.name != this.app.workspace.getActiveFile().name) {\r\n\t\t\t\tthis.openedByThisPlugin = true;\r\n\t\t\t\tthis.app.workspace.activeLeaf.openFile(fileToOpen);\r\n\t\t\t\tnew Notice(`ObsidianMirror: ${fileToOpen.basename} file opened`, 5000);\r\n\t\t\t} else {\r\n\t\t\t\tconsole.log(\"invalid file found or already opened\");\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tonunload() {\r\n\t\tconsole.log('unloading plugin');\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}\r\n}\r\n\r\nclass SampleModal extends Modal {\r\n\tconstructor(app: App) {\r\n\t\tsuper(app);\r\n\t}\r\n\r\n\tonOpen() {\r\n\t\tlet { contentEl } = this;\r\n\t\tcontentEl.setText('Woah!');\r\n\t}\r\n\r\n\tonClose() {\r\n\t\tlet { contentEl } = this;\r\n\t\tcontentEl.empty();\r\n\t}\r\n}\r\n\r\nclass ObsidianMirrorSettingTab extends PluginSettingTab {\r\n\tplugin: ObidianMirrorPlugin;\r\n\r\n\tconstructor(app: App, plugin: ObidianMirrorPlugin) {\r\n\t\tsuper(app, plugin);\r\n\t\tthis.plugin = plugin;\r\n\t}\r\n\r\n\tdisplay(): void {\r\n\r\n\t\tconst { containerEl } = this;\r\n\t\tcontainerEl.empty();\r\n\r\n\t\tcontainerEl.createEl('h2', { text: 'Obsidian Mirror - Settings' });\r\n\r\n\t\tnew Setting(containerEl)\r\n\t\t\t.setName('Is this Obsidian instance a Mirror?')\r\n\t\t\t.setDesc(\r\n\t\t\t\t'If enabled, this instance will \"follow\" whatever the main Obsidian instance has opened' +\r\n\t\t\t\t'PS: In order to launch multiple Obsidian instances you have to follow a workaround suggested in this community Forum'\r\n\t\t\t)\r\n\t\t\t.addToggle((toggle) =>\r\n\t\t\t\ttoggle.setValue(this.plugin.settings.isMirror).onChange((value) => {\r\n\t\t\t\t\tthis.plugin.settings.isMirror = value;\r\n\t\t\t\t\tthis.plugin.saveData(this.plugin.settings);\r\n\t\t\t\t\tthis.display();\r\n\t\t\t\t}),\r\n\t\t\t);\r\n\r\n\t\tnew Setting(containerEl)\r\n\t\t\t.setName('Vault Name')\r\n\t\t\t.setDesc(\r\n\t\t\t\t'Please enter the Vault name your are using in the main instance of Obsidian',\r\n\t\t\t)\r\n\t\t\t.addText((text) =>\r\n\t\t\t\ttext\r\n\t\t\t\t\t.setPlaceholder('MyVaultName')\r\n\t\t\t\t\t.setValue(this.plugin.settings.vault)\r\n\t\t\t\t\t.onChange(async (value) => {\r\n\t\t\t\t\t\tthis.plugin.settings.vault = value\r\n\t\t\t\t\t\tawait this.plugin.saveSettings();\r\n\t\t\t\t\t}),\r\n\t\t\t);\r\n\r\n\t\tnew Setting(containerEl)\r\n\t\t\t.setName('Mirror File')\r\n\t\t\t.setDesc(\r\n\t\t\t\t'Please enter the file name you want to use. This plugin will use it in order to watch the active file opned. PS: You can use a name of your choice',\r\n\t\t\t)\r\n\t\t\t.addText((text) =>\r\n\t\t\t\ttext\r\n\t\t\t\t\t.setPlaceholder('ObsidianMirror.md')\r\n\t\t\t\t\t.setValue(this.plugin.settings.fileName)\r\n\t\t\t\t\t.onChange(async (value) => {\r\n\t\t\t\t\t\tthis.plugin.settings.fileName = value\r\n\t\t\t\t\t\tthis.plugin.settings.fileNameGraph = value.substring(0, value.length - 2) + \"_graph.md\"\r\n\t\t\t\t\t\tawait this.plugin.saveSettings();\r\n\t\t\t\t\t}),\r\n\t\t\t);\r\n\r\n\r\n\t}\r\n}\r\n"],"names":["Plugin","Notice","Modal","PluginSettingTab","Setting"],"mappings":"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"} 224 | -------------------------------------------------------------------------------- /main.ts: -------------------------------------------------------------------------------- 1 | import { App, Modal, Notice, Plugin, PluginSettingTab, Setting, TAbstractFile, TFile, Vault } from 'obsidian'; 2 | import { fileURLToPath } from 'url'; 3 | 4 | interface ObsidianMirrorSettings { 5 | isMirror: boolean; 6 | vault: string 7 | fileName: string; 8 | fileNameGraph: string; 9 | } 10 | 11 | const DEFAULT_SETTINGS: ObsidianMirrorSettings = { 12 | isMirror: false, 13 | vault: "", 14 | fileName: "ObsidianMirror.md", 15 | fileNameGraph: "ObsidianMirror_graph.md" 16 | } 17 | 18 | export default class ObidianMirrorPlugin extends Plugin { 19 | settings: ObsidianMirrorSettings; 20 | 21 | openedByThisPlugin: boolean = false; 22 | wroteByThisPlugin: boolean = false; 23 | activeFile: TFile = this.app.workspace.getActiveFile(); 24 | 25 | async onload() { 26 | console.log('loading plugin'); 27 | 28 | await this.loadSettings(); 29 | 30 | this.addRibbonIcon('dice', 'Obsidian Mirror', () => { 31 | new Notice('This is a notice!'); 32 | }); 33 | 34 | this.addStatusBarItem().setText('Obsidian Mirror'); 35 | 36 | this.addCommand({ 37 | id: 'open-sample-modal', 38 | name: 'Open Sample Modal', 39 | // callback: () => { 40 | // console.log('Simple Callback'); 41 | // }, 42 | checkCallback: (checking: boolean) => { 43 | let leaf = this.app.workspace.activeLeaf; 44 | if (leaf) { 45 | if (!checking) { 46 | new SampleModal(this.app).open(); 47 | } 48 | return true; 49 | } 50 | return false; 51 | } 52 | }); 53 | 54 | this.addSettingTab(new ObsidianMirrorSettingTab(this.app, this)); 55 | 56 | this.registerCodeMirror((cm: CodeMirror.Editor) => { 57 | console.log('codemirror', cm); 58 | }); 59 | 60 | this.registerDomEvent(document, 'click', (evt: MouseEvent) => { 61 | console.log('click', evt); 62 | }); 63 | 64 | this.registerInterval(window.setInterval(() => console.log('setInterval'), 5 * 60 * 1000)); 65 | 66 | this.app.workspace.on('file-open', async () => { 67 | 68 | const activeLeaf = this.app.workspace.activeLeaf 69 | if (!activeLeaf) { 70 | return 71 | } 72 | 73 | this.lastFile(); 74 | 75 | 76 | }) 77 | 78 | 79 | this.registerEvent( 80 | this.app.vault.on('modify', (file) => this.onChangeFile(file)) 81 | ); 82 | 83 | 84 | } 85 | 86 | async onChangeFile(file: TAbstractFile) { 87 | 88 | console.log("this.settings.isMirror:" + this.settings.isMirror); 89 | console.log("vault this.settings.fileName:" + this.settings.vault + "/" + this.settings.fileName); 90 | console.log("vault + filnemagraph:" + this.settings.vault + "/" + this.settings.fileNameGraph) 91 | console.log("active file:" + this.app.workspace.getActiveFile().path) 92 | console.log("file.path:" + file.path); 93 | 94 | if (!this.openedByThisPlugin) { 95 | if (this.settings.isMirror && file.path == this.settings.vault + "/" + this.settings.fileName || !this.settings.isMirror && file.path == this.settings.fileNameGraph) { 96 | console.log("passed"); 97 | this.readActiveOpenedFile(); 98 | } 99 | } else { 100 | this.openedByThisPlugin = false; 101 | } 102 | } 103 | 104 | 105 | async lastFile() { 106 | 107 | this.activeFile = this.app.workspace.getActiveFile(); 108 | 109 | console.log("lastFile"); 110 | 111 | setTimeout(() => { 112 | this.watchFileAndWrite(); 113 | }, 800); 114 | 115 | } 116 | 117 | 118 | 119 | async watchFileAndWrite() { 120 | 121 | 122 | var activeFile: TFile = this.activeFile; 123 | var sideCarFile = !this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName })[0] : this.app.vault.getFiles().filter(f => { return f.path == this.settings.vault + "/" + this.settings.fileNameGraph })[0]; 124 | console.log("sideCarFile:") 125 | console.log(sideCarFile) 126 | if (!sideCarFile) { 127 | this.app.vault.create(!this.settings.isMirror ? this.settings.fileName : this.settings.vault + "/" + this.settings.fileNameGraph, ""); 128 | console.log("passato") 129 | sideCarFile = this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName })[0] : this.app.vault.getFiles().filter(f => { return f.path == this.settings.vault + "/" + this.settings.fileNameGraph })[0]; 130 | } 131 | if (activeFile != null && activeFile != undefined) { 132 | console.log(`this is active file ${activeFile.name}`); 133 | 134 | await this.app.vault.modify(sideCarFile, activeFile.name); 135 | 136 | } 137 | 138 | 139 | } 140 | 141 | 142 | async readActiveOpenedFile() { 143 | var sideCarFile = this.settings.isMirror ? this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileName })[0] : this.app.vault.getFiles().filter(f => { return f.name == this.settings.fileNameGraph })[0]; 144 | 145 | console.log("sideCar:" + sideCarFile.name); 146 | 147 | 148 | var fileNameToOpen = await (await this.app.vault.read(sideCarFile)).trim(); 149 | var fileToOpen: TFile = this.app.vault.getFiles().filter(f => { return f.name == fileNameToOpen })[0]; 150 | 151 | 152 | if (fileToOpen) { 153 | if (fileToOpen?.name != this.app.workspace.getActiveFile().name) { 154 | this.openedByThisPlugin = true; 155 | this.app.workspace.activeLeaf.openFile(fileToOpen); 156 | new Notice(`ObsidianMirror: ${fileToOpen.basename} file opened`, 5000); 157 | } else { 158 | console.log("invalid file found or already opened"); 159 | } 160 | } 161 | } 162 | 163 | onunload() { 164 | console.log('unloading plugin'); 165 | } 166 | 167 | async loadSettings() { 168 | this.settings = Object.assign({}, DEFAULT_SETTINGS, await this.loadData()); 169 | } 170 | 171 | async saveSettings() { 172 | await this.saveData(this.settings); 173 | } 174 | } 175 | 176 | class SampleModal extends Modal { 177 | constructor(app: App) { 178 | super(app); 179 | } 180 | 181 | onOpen() { 182 | let { contentEl } = this; 183 | contentEl.setText('Woah!'); 184 | } 185 | 186 | onClose() { 187 | let { contentEl } = this; 188 | contentEl.empty(); 189 | } 190 | } 191 | 192 | class ObsidianMirrorSettingTab extends PluginSettingTab { 193 | plugin: ObidianMirrorPlugin; 194 | 195 | constructor(app: App, plugin: ObidianMirrorPlugin) { 196 | super(app, plugin); 197 | this.plugin = plugin; 198 | } 199 | 200 | display(): void { 201 | 202 | const { containerEl } = this; 203 | containerEl.empty(); 204 | 205 | containerEl.createEl('h2', { text: 'Obsidian Mirror - Settings' }); 206 | 207 | new Setting(containerEl) 208 | .setName('Is this Obsidian instance a Mirror?') 209 | .setDesc( 210 | 'If enabled, this instance will "follow" whatever the main Obsidian instance has opened' + 211 | 'PS: In order to launch multiple Obsidian instances you have to follow a workaround suggested in this community Forum' 212 | ) 213 | .addToggle((toggle) => 214 | toggle.setValue(this.plugin.settings.isMirror).onChange((value) => { 215 | this.plugin.settings.isMirror = value; 216 | this.plugin.saveData(this.plugin.settings); 217 | this.display(); 218 | }), 219 | ); 220 | 221 | new Setting(containerEl) 222 | .setName('Vault Name') 223 | .setDesc( 224 | 'Please enter the Vault name your are using in the main instance of Obsidian', 225 | ) 226 | .addText((text) => 227 | text 228 | .setPlaceholder('MyVaultName') 229 | .setValue(this.plugin.settings.vault) 230 | .onChange(async (value) => { 231 | this.plugin.settings.vault = value 232 | await this.plugin.saveSettings(); 233 | }), 234 | ); 235 | 236 | new Setting(containerEl) 237 | .setName('Mirror File') 238 | .setDesc( 239 | 'Please enter the file name you want to use. This plugin will use it in order to watch the active file opned. PS: You can use a name of your choice', 240 | ) 241 | .addText((text) => 242 | text 243 | .setPlaceholder('ObsidianMirror.md') 244 | .setValue(this.plugin.settings.fileName) 245 | .onChange(async (value) => { 246 | this.plugin.settings.fileName = value 247 | this.plugin.settings.fileNameGraph = value.substring(0, value.length - 2) + "_graph.md" 248 | await this.plugin.saveSettings(); 249 | }), 250 | ); 251 | 252 | 253 | } 254 | } 255 | -------------------------------------------------------------------------------- /manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "id": "obsidian-mirror", 3 | "name": "Obsidian Mirror", 4 | "version": "0.0.1", 5 | "minAppVersion": "0.9.12", 6 | "description": "This plugins allows to sync the active open file among different Obsidian instances. Why? well, if you have multiple monitors and you want to use the local graph in a separate monitor, there is no chance to do it now. So I had the idea to run multiple instances of Obsidian using the workaround via symbolinc links. This way the 2 instances are not in sync. This plugin closes the gap and syncs the active opened file among multiple Obsidian instances", 7 | "author": "Francesco Pistillo", 8 | "authorUrl": "https://github.com/wildspecial/obsidian-mirror", 9 | "isDesktopOnly": false 10 | } 11 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "obsidian-sample-plugin", 3 | "version": "0.12.0", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "obsidian-sample-plugin", 9 | "version": "0.12.0", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@rollup/plugin-commonjs": "^18.0.0", 13 | "@rollup/plugin-node-resolve": "^11.2.1", 14 | "@rollup/plugin-typescript": "^8.2.1", 15 | "@types/node": "^14.14.37", 16 | "obsidian": "^0.12.0", 17 | "rollup": "^2.32.1", 18 | "tslib": "^2.2.0", 19 | "typescript": "^4.2.4" 20 | } 21 | }, 22 | "node_modules/@rollup/plugin-commonjs": { 23 | "version": "18.1.0", 24 | "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-18.1.0.tgz", 25 | "integrity": "sha512-h3e6T9rUxVMAQswpDIobfUHn/doMzM9sgkMrsMWCFLmB84PSoC8mV8tOloAJjSRwdqhXBqstlX2BwBpHJvbhxg==", 26 | "dev": true, 27 | "dependencies": { 28 | "@rollup/pluginutils": "^3.1.0", 29 | "commondir": "^1.0.1", 30 | "estree-walker": "^2.0.1", 31 | "glob": "^7.1.6", 32 | "is-reference": "^1.2.1", 33 | "magic-string": "^0.25.7", 34 | "resolve": "^1.17.0" 35 | }, 36 | "engines": { 37 | "node": ">= 8.0.0" 38 | }, 39 | "peerDependencies": { 40 | "rollup": "^2.30.0" 41 | } 42 | }, 43 | "node_modules/@rollup/plugin-node-resolve": { 44 | "version": "11.2.1", 45 | "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-11.2.1.tgz", 46 | "integrity": "sha512-yc2n43jcqVyGE2sqV5/YCmocy9ArjVAP/BeXyTtADTBBX6V0e5UMqwO8CdQ0kzjb6zu5P1qMzsScCMRvE9OlVg==", 47 | "dev": true, 48 | "dependencies": { 49 | "@rollup/pluginutils": "^3.1.0", 50 | "@types/resolve": "1.17.1", 51 | "builtin-modules": "^3.1.0", 52 | "deepmerge": "^4.2.2", 53 | "is-module": "^1.0.0", 54 | "resolve": "^1.19.0" 55 | }, 56 | "engines": { 57 | "node": ">= 10.0.0" 58 | }, 59 | "peerDependencies": { 60 | "rollup": "^1.20.0||^2.0.0" 61 | } 62 | }, 63 | "node_modules/@rollup/plugin-typescript": { 64 | "version": "8.2.5", 65 | "resolved": "https://registry.npmjs.org/@rollup/plugin-typescript/-/plugin-typescript-8.2.5.tgz", 66 | "integrity": "sha512-QL/LvDol/PAGB2O0S7/+q2HpSUNodpw7z6nGn9BfoVCPOZ0r4EALrojFU29Bkoi2Hr2jgTocTejJ5GGWZfOxbQ==", 67 | "dev": true, 68 | "dependencies": { 69 | "@rollup/pluginutils": "^3.1.0", 70 | "resolve": "^1.17.0" 71 | }, 72 | "engines": { 73 | "node": ">=8.0.0" 74 | }, 75 | "peerDependencies": { 76 | "rollup": "^2.14.0", 77 | "tslib": "*", 78 | "typescript": ">=3.7.0" 79 | } 80 | }, 81 | "node_modules/@rollup/pluginutils": { 82 | "version": "3.1.0", 83 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", 84 | "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", 85 | "dev": true, 86 | "dependencies": { 87 | "@types/estree": "0.0.39", 88 | "estree-walker": "^1.0.1", 89 | "picomatch": "^2.2.2" 90 | }, 91 | "engines": { 92 | "node": ">= 8.0.0" 93 | }, 94 | "peerDependencies": { 95 | "rollup": "^1.20.0||^2.0.0" 96 | } 97 | }, 98 | "node_modules/@rollup/pluginutils/node_modules/estree-walker": { 99 | "version": "1.0.1", 100 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", 101 | "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", 102 | "dev": true 103 | }, 104 | "node_modules/@types/codemirror": { 105 | "version": "0.0.108", 106 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.108.tgz", 107 | "integrity": "sha512-3FGFcus0P7C2UOGCNUVENqObEb4SFk+S8Dnxq7K6aIsLVs/vDtlangl3PEO0ykaKXyK56swVF6Nho7VsA44uhw==", 108 | "dev": true, 109 | "dependencies": { 110 | "@types/tern": "*" 111 | } 112 | }, 113 | "node_modules/@types/estree": { 114 | "version": "0.0.39", 115 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", 116 | "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", 117 | "dev": true 118 | }, 119 | "node_modules/@types/node": { 120 | "version": "14.17.12", 121 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.17.12.tgz", 122 | "integrity": "sha512-vhUqgjJR1qxwTWV5Ps5txuy2XMdf7Fw+OrdChRboy8BmWUPkckOhphaohzFG6b8DW7CrxaBMdrdJ47SYFq1okw==", 123 | "dev": true 124 | }, 125 | "node_modules/@types/resolve": { 126 | "version": "1.17.1", 127 | "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.17.1.tgz", 128 | "integrity": "sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==", 129 | "dev": true, 130 | "dependencies": { 131 | "@types/node": "*" 132 | } 133 | }, 134 | "node_modules/@types/tern": { 135 | "version": "0.23.4", 136 | "resolved": "https://registry.npmjs.org/@types/tern/-/tern-0.23.4.tgz", 137 | "integrity": "sha512-JAUw1iXGO1qaWwEOzxTKJZ/5JxVeON9kvGZ/osgZaJImBnyjyn0cjovPsf6FNLmyGY8Vw9DoXZCMlfMkMwHRWg==", 138 | "dev": true, 139 | "dependencies": { 140 | "@types/estree": "*" 141 | } 142 | }, 143 | "node_modules/balanced-match": { 144 | "version": "1.0.2", 145 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 146 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 147 | "dev": true 148 | }, 149 | "node_modules/brace-expansion": { 150 | "version": "1.1.11", 151 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 152 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 153 | "dev": true, 154 | "dependencies": { 155 | "balanced-match": "^1.0.0", 156 | "concat-map": "0.0.1" 157 | } 158 | }, 159 | "node_modules/builtin-modules": { 160 | "version": "3.2.0", 161 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.2.0.tgz", 162 | "integrity": "sha512-lGzLKcioL90C7wMczpkY0n/oART3MbBa8R9OFGE1rJxoVI86u4WAGfEk8Wjv10eKSyTHVGkSo3bvBylCEtk7LA==", 163 | "dev": true, 164 | "engines": { 165 | "node": ">=6" 166 | }, 167 | "funding": { 168 | "url": "https://github.com/sponsors/sindresorhus" 169 | } 170 | }, 171 | "node_modules/commondir": { 172 | "version": "1.0.1", 173 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 174 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", 175 | "dev": true 176 | }, 177 | "node_modules/concat-map": { 178 | "version": "0.0.1", 179 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 180 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 181 | "dev": true 182 | }, 183 | "node_modules/deepmerge": { 184 | "version": "4.2.2", 185 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", 186 | "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", 187 | "dev": true, 188 | "engines": { 189 | "node": ">=0.10.0" 190 | } 191 | }, 192 | "node_modules/estree-walker": { 193 | "version": "2.0.2", 194 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", 195 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==", 196 | "dev": true 197 | }, 198 | "node_modules/fs.realpath": { 199 | "version": "1.0.0", 200 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 201 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 202 | "dev": true 203 | }, 204 | "node_modules/fsevents": { 205 | "version": "2.3.2", 206 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 207 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 208 | "dev": true, 209 | "hasInstallScript": true, 210 | "optional": true, 211 | "os": [ 212 | "darwin" 213 | ], 214 | "engines": { 215 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 216 | } 217 | }, 218 | "node_modules/function-bind": { 219 | "version": "1.1.1", 220 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 221 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 222 | "dev": true 223 | }, 224 | "node_modules/glob": { 225 | "version": "7.1.7", 226 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 227 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 228 | "dev": true, 229 | "dependencies": { 230 | "fs.realpath": "^1.0.0", 231 | "inflight": "^1.0.4", 232 | "inherits": "2", 233 | "minimatch": "^3.0.4", 234 | "once": "^1.3.0", 235 | "path-is-absolute": "^1.0.0" 236 | }, 237 | "engines": { 238 | "node": "*" 239 | }, 240 | "funding": { 241 | "url": "https://github.com/sponsors/isaacs" 242 | } 243 | }, 244 | "node_modules/has": { 245 | "version": "1.0.3", 246 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 247 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 248 | "dev": true, 249 | "dependencies": { 250 | "function-bind": "^1.1.1" 251 | }, 252 | "engines": { 253 | "node": ">= 0.4.0" 254 | } 255 | }, 256 | "node_modules/inflight": { 257 | "version": "1.0.6", 258 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 259 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 260 | "dev": true, 261 | "dependencies": { 262 | "once": "^1.3.0", 263 | "wrappy": "1" 264 | } 265 | }, 266 | "node_modules/inherits": { 267 | "version": "2.0.4", 268 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 269 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 270 | "dev": true 271 | }, 272 | "node_modules/is-core-module": { 273 | "version": "2.6.0", 274 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.6.0.tgz", 275 | "integrity": "sha512-wShG8vs60jKfPWpF2KZRaAtvt3a20OAn7+IJ6hLPECpSABLcKtFKTTI4ZtH5QcBruBHlq+WsdHWyz0BCZW7svQ==", 276 | "dev": true, 277 | "dependencies": { 278 | "has": "^1.0.3" 279 | }, 280 | "funding": { 281 | "url": "https://github.com/sponsors/ljharb" 282 | } 283 | }, 284 | "node_modules/is-module": { 285 | "version": "1.0.0", 286 | "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", 287 | "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=", 288 | "dev": true 289 | }, 290 | "node_modules/is-reference": { 291 | "version": "1.2.1", 292 | "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-1.2.1.tgz", 293 | "integrity": "sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==", 294 | "dev": true, 295 | "dependencies": { 296 | "@types/estree": "*" 297 | } 298 | }, 299 | "node_modules/magic-string": { 300 | "version": "0.25.7", 301 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.7.tgz", 302 | "integrity": "sha512-4CrMT5DOHTDk4HYDlzmwu4FVCcIYI8gauveasrdCu2IKIFOJ3f0v/8MDGJCDL9oD2ppz/Av1b0Nj345H9M+XIA==", 303 | "dev": true, 304 | "dependencies": { 305 | "sourcemap-codec": "^1.4.4" 306 | } 307 | }, 308 | "node_modules/minimatch": { 309 | "version": "3.0.4", 310 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 311 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 312 | "dev": true, 313 | "dependencies": { 314 | "brace-expansion": "^1.1.7" 315 | }, 316 | "engines": { 317 | "node": "*" 318 | } 319 | }, 320 | "node_modules/moment": { 321 | "version": "2.29.1", 322 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 323 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==", 324 | "dev": true, 325 | "engines": { 326 | "node": "*" 327 | } 328 | }, 329 | "node_modules/obsidian": { 330 | "version": "0.12.11", 331 | "resolved": "https://registry.npmjs.org/obsidian/-/obsidian-0.12.11.tgz", 332 | "integrity": "sha512-Kv4m1n4nfd17FzpqHZfqFS2YZAyY+cxAUM7/5jqh1bmbPlmKoNd1XJZC7o9KvkXfTCxALiXfGRdrjHB+GUFAEA==", 333 | "dev": true, 334 | "dependencies": { 335 | "@types/codemirror": "0.0.108", 336 | "moment": "2.29.1" 337 | } 338 | }, 339 | "node_modules/once": { 340 | "version": "1.4.0", 341 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 342 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 343 | "dev": true, 344 | "dependencies": { 345 | "wrappy": "1" 346 | } 347 | }, 348 | "node_modules/path-is-absolute": { 349 | "version": "1.0.1", 350 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 351 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 352 | "dev": true, 353 | "engines": { 354 | "node": ">=0.10.0" 355 | } 356 | }, 357 | "node_modules/path-parse": { 358 | "version": "1.0.7", 359 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 360 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 361 | "dev": true 362 | }, 363 | "node_modules/picomatch": { 364 | "version": "2.3.0", 365 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 366 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 367 | "dev": true, 368 | "engines": { 369 | "node": ">=8.6" 370 | }, 371 | "funding": { 372 | "url": "https://github.com/sponsors/jonschlinkert" 373 | } 374 | }, 375 | "node_modules/resolve": { 376 | "version": "1.20.0", 377 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", 378 | "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", 379 | "dev": true, 380 | "dependencies": { 381 | "is-core-module": "^2.2.0", 382 | "path-parse": "^1.0.6" 383 | }, 384 | "funding": { 385 | "url": "https://github.com/sponsors/ljharb" 386 | } 387 | }, 388 | "node_modules/rollup": { 389 | "version": "2.56.3", 390 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.56.3.tgz", 391 | "integrity": "sha512-Au92NuznFklgQCUcV96iXlxUbHuB1vQMaH76DHl5M11TotjOHwqk9CwcrT78+Tnv4FN9uTBxq6p4EJoYkpyekg==", 392 | "dev": true, 393 | "bin": { 394 | "rollup": "dist/bin/rollup" 395 | }, 396 | "engines": { 397 | "node": ">=10.0.0" 398 | }, 399 | "optionalDependencies": { 400 | "fsevents": "~2.3.2" 401 | } 402 | }, 403 | "node_modules/sourcemap-codec": { 404 | "version": "1.4.8", 405 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 406 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 407 | "dev": true 408 | }, 409 | "node_modules/tslib": { 410 | "version": "2.3.1", 411 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 412 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 413 | "dev": true 414 | }, 415 | "node_modules/typescript": { 416 | "version": "4.4.2", 417 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.4.2.tgz", 418 | "integrity": "sha512-gzP+t5W4hdy4c+68bfcv0t400HVJMMd2+H9B7gae1nQlBzCqvrXX+6GL/b3GAgyTH966pzrZ70/fRjwAtZksSQ==", 419 | "dev": true, 420 | "bin": { 421 | "tsc": "bin/tsc", 422 | "tsserver": "bin/tsserver" 423 | }, 424 | "engines": { 425 | "node": ">=4.2.0" 426 | } 427 | }, 428 | "node_modules/wrappy": { 429 | "version": "1.0.2", 430 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 431 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 432 | "dev": true 433 | } 434 | }, 435 | "dependencies": { 436 | "@rollup/plugin-commonjs": { 437 | "version": "18.1.0", 438 | "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-18.1.0.tgz", 439 | "integrity": "sha512-h3e6T9rUxVMAQswpDIobfUHn/doMzM9sgkMrsMWCFLmB84PSoC8mV8tOloAJjSRwdqhXBqstlX2BwBpHJvbhxg==", 440 | "dev": true, 441 | "requires": { 442 | "@rollup/pluginutils": "^3.1.0", 443 | "commondir": "^1.0.1", 444 | "estree-walker": "^2.0.1", 445 | "glob": "^7.1.6", 446 | "is-reference": "^1.2.1", 447 | "magic-string": "^0.25.7", 448 | "resolve": "^1.17.0" 449 | } 450 | }, 451 | "@rollup/plugin-node-resolve": { 452 | "version": "11.2.1", 453 | "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-11.2.1.tgz", 454 | "integrity": "sha512-yc2n43jcqVyGE2sqV5/YCmocy9ArjVAP/BeXyTtADTBBX6V0e5UMqwO8CdQ0kzjb6zu5P1qMzsScCMRvE9OlVg==", 455 | "dev": true, 456 | "requires": { 457 | "@rollup/pluginutils": "^3.1.0", 458 | "@types/resolve": "1.17.1", 459 | "builtin-modules": "^3.1.0", 460 | "deepmerge": "^4.2.2", 461 | "is-module": "^1.0.0", 462 | "resolve": "^1.19.0" 463 | } 464 | }, 465 | "@rollup/plugin-typescript": { 466 | "version": "8.2.5", 467 | "resolved": "https://registry.npmjs.org/@rollup/plugin-typescript/-/plugin-typescript-8.2.5.tgz", 468 | "integrity": "sha512-QL/LvDol/PAGB2O0S7/+q2HpSUNodpw7z6nGn9BfoVCPOZ0r4EALrojFU29Bkoi2Hr2jgTocTejJ5GGWZfOxbQ==", 469 | "dev": true, 470 | "requires": { 471 | "@rollup/pluginutils": "^3.1.0", 472 | "resolve": "^1.17.0" 473 | } 474 | }, 475 | "@rollup/pluginutils": { 476 | "version": "3.1.0", 477 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", 478 | "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", 479 | "dev": true, 480 | "requires": { 481 | "@types/estree": "0.0.39", 482 | "estree-walker": "^1.0.1", 483 | "picomatch": "^2.2.2" 484 | }, 485 | "dependencies": { 486 | "estree-walker": { 487 | "version": "1.0.1", 488 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", 489 | "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", 490 | "dev": true 491 | } 492 | } 493 | }, 494 | "@types/codemirror": { 495 | "version": "0.0.108", 496 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.108.tgz", 497 | "integrity": "sha512-3FGFcus0P7C2UOGCNUVENqObEb4SFk+S8Dnxq7K6aIsLVs/vDtlangl3PEO0ykaKXyK56swVF6Nho7VsA44uhw==", 498 | "dev": true, 499 | "requires": { 500 | "@types/tern": "*" 501 | } 502 | }, 503 | "@types/estree": { 504 | "version": "0.0.39", 505 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", 506 | "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", 507 | "dev": true 508 | }, 509 | "@types/node": { 510 | "version": "14.17.12", 511 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.17.12.tgz", 512 | "integrity": "sha512-vhUqgjJR1qxwTWV5Ps5txuy2XMdf7Fw+OrdChRboy8BmWUPkckOhphaohzFG6b8DW7CrxaBMdrdJ47SYFq1okw==", 513 | "dev": true 514 | }, 515 | "@types/resolve": { 516 | "version": "1.17.1", 517 | "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.17.1.tgz", 518 | "integrity": "sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==", 519 | "dev": true, 520 | "requires": { 521 | "@types/node": "*" 522 | } 523 | }, 524 | "@types/tern": { 525 | "version": "0.23.4", 526 | "resolved": "https://registry.npmjs.org/@types/tern/-/tern-0.23.4.tgz", 527 | "integrity": "sha512-JAUw1iXGO1qaWwEOzxTKJZ/5JxVeON9kvGZ/osgZaJImBnyjyn0cjovPsf6FNLmyGY8Vw9DoXZCMlfMkMwHRWg==", 528 | "dev": true, 529 | "requires": { 530 | "@types/estree": "*" 531 | } 532 | }, 533 | "balanced-match": { 534 | "version": "1.0.2", 535 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 536 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 537 | "dev": true 538 | }, 539 | "brace-expansion": { 540 | "version": "1.1.11", 541 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 542 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 543 | "dev": true, 544 | "requires": { 545 | "balanced-match": "^1.0.0", 546 | "concat-map": "0.0.1" 547 | } 548 | }, 549 | "builtin-modules": { 550 | "version": "3.2.0", 551 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.2.0.tgz", 552 | "integrity": "sha512-lGzLKcioL90C7wMczpkY0n/oART3MbBa8R9OFGE1rJxoVI86u4WAGfEk8Wjv10eKSyTHVGkSo3bvBylCEtk7LA==", 553 | "dev": true 554 | }, 555 | "commondir": { 556 | "version": "1.0.1", 557 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 558 | "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", 559 | "dev": true 560 | }, 561 | "concat-map": { 562 | "version": "0.0.1", 563 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 564 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 565 | "dev": true 566 | }, 567 | "deepmerge": { 568 | "version": "4.2.2", 569 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", 570 | "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", 571 | "dev": true 572 | }, 573 | "estree-walker": { 574 | "version": "2.0.2", 575 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", 576 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==", 577 | "dev": true 578 | }, 579 | "fs.realpath": { 580 | "version": "1.0.0", 581 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 582 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 583 | "dev": true 584 | }, 585 | "fsevents": { 586 | "version": "2.3.2", 587 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 588 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 589 | "dev": true, 590 | "optional": true 591 | }, 592 | "function-bind": { 593 | "version": "1.1.1", 594 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 595 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 596 | "dev": true 597 | }, 598 | "glob": { 599 | "version": "7.1.7", 600 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz", 601 | "integrity": "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==", 602 | "dev": true, 603 | "requires": { 604 | "fs.realpath": "^1.0.0", 605 | "inflight": "^1.0.4", 606 | "inherits": "2", 607 | "minimatch": "^3.0.4", 608 | "once": "^1.3.0", 609 | "path-is-absolute": "^1.0.0" 610 | } 611 | }, 612 | "has": { 613 | "version": "1.0.3", 614 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 615 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 616 | "dev": true, 617 | "requires": { 618 | "function-bind": "^1.1.1" 619 | } 620 | }, 621 | "inflight": { 622 | "version": "1.0.6", 623 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 624 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 625 | "dev": true, 626 | "requires": { 627 | "once": "^1.3.0", 628 | "wrappy": "1" 629 | } 630 | }, 631 | "inherits": { 632 | "version": "2.0.4", 633 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 634 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 635 | "dev": true 636 | }, 637 | "is-core-module": { 638 | "version": "2.6.0", 639 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.6.0.tgz", 640 | "integrity": "sha512-wShG8vs60jKfPWpF2KZRaAtvt3a20OAn7+IJ6hLPECpSABLcKtFKTTI4ZtH5QcBruBHlq+WsdHWyz0BCZW7svQ==", 641 | "dev": true, 642 | "requires": { 643 | "has": "^1.0.3" 644 | } 645 | }, 646 | "is-module": { 647 | "version": "1.0.0", 648 | "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", 649 | "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=", 650 | "dev": true 651 | }, 652 | "is-reference": { 653 | "version": "1.2.1", 654 | "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-1.2.1.tgz", 655 | "integrity": "sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==", 656 | "dev": true, 657 | "requires": { 658 | "@types/estree": "*" 659 | } 660 | }, 661 | "magic-string": { 662 | "version": "0.25.7", 663 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.7.tgz", 664 | "integrity": "sha512-4CrMT5DOHTDk4HYDlzmwu4FVCcIYI8gauveasrdCu2IKIFOJ3f0v/8MDGJCDL9oD2ppz/Av1b0Nj345H9M+XIA==", 665 | "dev": true, 666 | "requires": { 667 | "sourcemap-codec": "^1.4.4" 668 | } 669 | }, 670 | "minimatch": { 671 | "version": "3.0.4", 672 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 673 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 674 | "dev": true, 675 | "requires": { 676 | "brace-expansion": "^1.1.7" 677 | } 678 | }, 679 | "moment": { 680 | "version": "2.29.1", 681 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 682 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==", 683 | "dev": true 684 | }, 685 | "obsidian": { 686 | "version": "0.12.11", 687 | "resolved": "https://registry.npmjs.org/obsidian/-/obsidian-0.12.11.tgz", 688 | "integrity": "sha512-Kv4m1n4nfd17FzpqHZfqFS2YZAyY+cxAUM7/5jqh1bmbPlmKoNd1XJZC7o9KvkXfTCxALiXfGRdrjHB+GUFAEA==", 689 | "dev": true, 690 | "requires": { 691 | "@types/codemirror": "0.0.108", 692 | "moment": "2.29.1" 693 | } 694 | }, 695 | "once": { 696 | "version": "1.4.0", 697 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 698 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 699 | "dev": true, 700 | "requires": { 701 | "wrappy": "1" 702 | } 703 | }, 704 | "path-is-absolute": { 705 | "version": "1.0.1", 706 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 707 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 708 | "dev": true 709 | }, 710 | "path-parse": { 711 | "version": "1.0.7", 712 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 713 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 714 | "dev": true 715 | }, 716 | "picomatch": { 717 | "version": "2.3.0", 718 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.0.tgz", 719 | "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==", 720 | "dev": true 721 | }, 722 | "resolve": { 723 | "version": "1.20.0", 724 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.20.0.tgz", 725 | "integrity": "sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==", 726 | "dev": true, 727 | "requires": { 728 | "is-core-module": "^2.2.0", 729 | "path-parse": "^1.0.6" 730 | } 731 | }, 732 | "rollup": { 733 | "version": "2.56.3", 734 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.56.3.tgz", 735 | "integrity": "sha512-Au92NuznFklgQCUcV96iXlxUbHuB1vQMaH76DHl5M11TotjOHwqk9CwcrT78+Tnv4FN9uTBxq6p4EJoYkpyekg==", 736 | "dev": true, 737 | "requires": { 738 | "fsevents": "~2.3.2" 739 | } 740 | }, 741 | "sourcemap-codec": { 742 | "version": "1.4.8", 743 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 744 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 745 | "dev": true 746 | }, 747 | "tslib": { 748 | "version": "2.3.1", 749 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 750 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 751 | "dev": true 752 | }, 753 | "typescript": { 754 | "version": "4.4.2", 755 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.4.2.tgz", 756 | "integrity": "sha512-gzP+t5W4hdy4c+68bfcv0t400HVJMMd2+H9B7gae1nQlBzCqvrXX+6GL/b3GAgyTH966pzrZ70/fRjwAtZksSQ==", 757 | "dev": true 758 | }, 759 | "wrappy": { 760 | "version": "1.0.2", 761 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 762 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 763 | "dev": true 764 | } 765 | } 766 | } 767 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "obsidian-sample-plugin", 3 | "version": "0.12.0", 4 | "description": "This is a sample plugin for Obsidian (https://obsidian.md)", 5 | "main": "main.js", 6 | "scripts": { 7 | "dev": "rollup --config rollup.config.js -w", 8 | "build": "rollup --config rollup.config.js --environment BUILD:production" 9 | }, 10 | "keywords": [], 11 | "author": "", 12 | "license": "MIT", 13 | "devDependencies": { 14 | "@rollup/plugin-commonjs": "^18.0.0", 15 | "@rollup/plugin-node-resolve": "^11.2.1", 16 | "@rollup/plugin-typescript": "^8.2.1", 17 | "@types/node": "^14.14.37", 18 | "obsidian": "^0.12.0", 19 | "rollup": "^2.32.1", 20 | "tslib": "^2.2.0", 21 | "typescript": "^4.2.4" 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /rollup.config.js: -------------------------------------------------------------------------------- 1 | import typescript from '@rollup/plugin-typescript'; 2 | import {nodeResolve} from '@rollup/plugin-node-resolve'; 3 | import commonjs from '@rollup/plugin-commonjs'; 4 | 5 | const isProd = (process.env.BUILD === 'production'); 6 | 7 | const banner = 8 | `/* 9 | THIS IS A GENERATED/BUNDLED FILE BY ROLLUP 10 | if you want to view the source visit the plugins github repository 11 | */ 12 | `; 13 | 14 | export default { 15 | input: 'main.ts', 16 | output: { 17 | dir: '.', 18 | sourcemap: 'inline', 19 | sourcemapExcludeSources: isProd, 20 | format: 'cjs', 21 | exports: 'default', 22 | banner, 23 | }, 24 | external: ['obsidian'], 25 | plugins: [ 26 | typescript(), 27 | nodeResolve({browser: true}), 28 | commonjs(), 29 | ] 30 | }; -------------------------------------------------------------------------------- /styles.css: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wildspecial/obsidian-mirror/c32614d4b893578bb4bfd7ca05326f7c649c904e/styles.css -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "baseUrl": ".", 4 | "inlineSourceMap": true, 5 | "inlineSources": true, 6 | "module": "ESNext", 7 | "target": "es6", 8 | "allowJs": true, 9 | "noImplicitAny": true, 10 | "moduleResolution": "node", 11 | "importHelpers": true, 12 | "lib": [ 13 | "dom", 14 | "es5", 15 | "scripthost", 16 | "es2015" 17 | ] 18 | }, 19 | "include": [ 20 | "**/*.ts" 21 | ] 22 | } 23 | -------------------------------------------------------------------------------- /versions.json: -------------------------------------------------------------------------------- 1 | { 2 | "1.0.1": "0.9.12", 3 | "1.0.0": "0.9.7" 4 | } 5 | --------------------------------------------------------------------------------