├── .gitattributes ├── .obsidian ├── app.json ├── appearance.json ├── community-plugins.json ├── core-plugins-migration.json ├── core-plugins.json ├── hotkeys.json ├── plugins │ ├── dataview │ │ ├── main.js │ │ ├── manifest.json │ │ └── styles.css │ ├── templater-obsidian │ │ ├── data.json │ │ ├── main.js │ │ ├── manifest.json │ │ └── styles.css │ └── wikilinks-to-mdlinks-obsidian │ │ ├── main.js │ │ └── manifest.json └── workspace.json ├── PowerShell Script Example.md ├── README.md ├── TEMPLATES ├── Execute PowerShell5 Selected Text.md ├── Execute PowerShell7 Selected Text.md └── Execute cmd.exe Selected Text.md ├── attachments ├── Pasted image 20230312113439.png ├── Pasted image 20230312113550.png ├── Pasted image 20230312113743.png ├── Pasted image 20230312113952.png ├── Pasted image 20230312114222.png ├── Pasted image 20230312114606.png ├── Pasted image 20230312114655.png ├── Pasted image 20230312115546.png ├── Pasted image 20230312115849.png ├── Pasted image 20230312124148.png ├── Pasted image 20230312131658.png ├── Pasted image 20230312132859.png.md ├── Pasted image 20230312140552.png ├── Pasted image 20230312140640.png ├── Pasted image 20230312141836.png ├── Pasted image 20230312142213.png ├── Pasted image 20230312143001.png ├── Pasted image 20230312161834.png ├── Pasted image 20230312162144.png ├── ping_example.gif └── ping_example_hotkey.gif └── ping example.md /.gitattributes: -------------------------------------------------------------------------------- 1 | # Auto detect text files and perform LF normalization 2 | * text=auto 3 | -------------------------------------------------------------------------------- /.obsidian/app.json: -------------------------------------------------------------------------------- 1 | { 2 | "spellcheck": true, 3 | "promptDelete": false, 4 | "attachmentFolderPath": "attachments", 5 | "showUnsupportedFiles": true, 6 | "newLinkFormat": "absolute", 7 | "useMarkdownLinks": true, 8 | "livePreview": true 9 | } -------------------------------------------------------------------------------- /.obsidian/appearance.json: -------------------------------------------------------------------------------- 1 | { 2 | "accentColor": "" 3 | } -------------------------------------------------------------------------------- /.obsidian/community-plugins.json: -------------------------------------------------------------------------------- 1 | [ 2 | "templater-obsidian", 3 | "dataview", 4 | "wikilinks-to-mdlinks-obsidian" 5 | ] -------------------------------------------------------------------------------- /.obsidian/core-plugins-migration.json: -------------------------------------------------------------------------------- 1 | { 2 | "file-explorer": true, 3 | "global-search": true, 4 | "switcher": true, 5 | "graph": true, 6 | "backlink": true, 7 | "canvas": true, 8 | "outgoing-link": true, 9 | "tag-pane": true, 10 | "page-preview": true, 11 | "daily-notes": true, 12 | "templates": true, 13 | "note-composer": true, 14 | "command-palette": true, 15 | "slash-command": false, 16 | "editor-status": true, 17 | "starred": true, 18 | "markdown-importer": false, 19 | "zk-prefixer": false, 20 | "random-note": false, 21 | "outline": true, 22 | "word-count": true, 23 | "slides": false, 24 | "audio-recorder": false, 25 | "workspaces": false, 26 | "file-recovery": true, 27 | "publish": false, 28 | "sync": false 29 | } -------------------------------------------------------------------------------- /.obsidian/core-plugins.json: -------------------------------------------------------------------------------- 1 | [ 2 | "file-explorer", 3 | "global-search", 4 | "switcher", 5 | "graph", 6 | "backlink", 7 | "canvas", 8 | "outgoing-link", 9 | "tag-pane", 10 | "page-preview", 11 | "daily-notes", 12 | "templates", 13 | "note-composer", 14 | "command-palette", 15 | "editor-status", 16 | "starred", 17 | "outline", 18 | "word-count", 19 | "file-recovery" 20 | ] -------------------------------------------------------------------------------- /.obsidian/hotkeys.json: -------------------------------------------------------------------------------- 1 | { 2 | "templater-obsidian:TEMPLATES/Execute PowerShell5 Selected Text.md": [ 3 | { 4 | "modifiers": [ 5 | "Mod", 6 | "Shift" 7 | ], 8 | "key": "1" 9 | } 10 | ] 11 | } -------------------------------------------------------------------------------- /.obsidian/plugins/dataview/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "id": "dataview", 3 | "name": "Dataview", 4 | "version": "0.5.55", 5 | "minAppVersion": "0.13.11", 6 | "description": "Complex data views for the data-obsessed.", 7 | "author": "Michael Brenan ", 8 | "authorUrl": "https://github.com/blacksmithgu", 9 | "isDesktopOnly": false 10 | } 11 | -------------------------------------------------------------------------------- /.obsidian/plugins/dataview/styles.css: -------------------------------------------------------------------------------- 1 | /** Live Preview padding fixes, specifically for DataviewJS custom HTML elements. */ 2 | .is-live-preview .block-language-dataviewjs > p, .is-live-preview .block-language-dataviewjs > span { 3 | line-height: 1.0; 4 | } 5 | 6 | .block-language-dataview { 7 | overflow-y: auto; 8 | } 9 | 10 | /*****************/ 11 | /** Table Views **/ 12 | /*****************/ 13 | 14 | /* List View Default Styling; rendered internally as a table. */ 15 | .table-view-table { 16 | width: 100%; 17 | } 18 | 19 | .table-view-table > thead > tr, .table-view-table > tbody > tr { 20 | margin-top: 1em; 21 | margin-bottom: 1em; 22 | text-align: left; 23 | } 24 | 25 | .table-view-table > tbody > tr:hover { 26 | background-color: var(--text-selection) !important; 27 | } 28 | 29 | .table-view-table > thead > tr > th { 30 | font-weight: 700; 31 | font-size: larger; 32 | border-top: none; 33 | border-left: none; 34 | border-right: none; 35 | border-bottom: solid; 36 | 37 | max-width: 100%; 38 | } 39 | 40 | .table-view-table > tbody > tr > td { 41 | text-align: left; 42 | border: none; 43 | font-weight: 400; 44 | max-width: 100%; 45 | } 46 | 47 | .table-view-table ul, .table-view-table ol { 48 | margin-block-start: 0.2em !important; 49 | margin-block-end: 0.2em !important; 50 | } 51 | 52 | /** Rendered value styling for any view. */ 53 | .dataview-result-list-root-ul { 54 | padding: 0em !important; 55 | margin: 0em !important; 56 | } 57 | 58 | .dataview-result-list-ul { 59 | margin-block-start: 0.2em !important; 60 | margin-block-end: 0.2em !important; 61 | } 62 | 63 | /** Generic grouping styling. */ 64 | .dataview.result-group { 65 | padding-left: 8px; 66 | } 67 | 68 | /*******************/ 69 | /** Inline Fields **/ 70 | /*******************/ 71 | 72 | .dataview.inline-field-key { 73 | padding-left: 8px; 74 | padding-right: 8px; 75 | font-family: var(--font-monospace); 76 | background-color: var(--background-primary-alt); 77 | color: var(--text-nav-selected); 78 | } 79 | 80 | .dataview.inline-field-value { 81 | padding-left: 8px; 82 | padding-right: 8px; 83 | font-family: var(--font-monospace); 84 | background-color: var(--background-secondary-alt); 85 | color: var(--text-nav-selected); 86 | } 87 | 88 | .dataview.inline-field-standalone-value { 89 | padding-left: 8px; 90 | padding-right: 8px; 91 | font-family: var(--font-monospace); 92 | background-color: var(--background-secondary-alt); 93 | color: var(--text-nav-selected); 94 | } 95 | 96 | /***************/ 97 | /** Task View **/ 98 | /***************/ 99 | 100 | .dataview.task-list-item, .dataview.task-list-basic-item { 101 | margin-top: 3px; 102 | margin-bottom: 3px; 103 | transition: 0.4s; 104 | } 105 | 106 | .dataview.task-list-item:hover, .dataview.task-list-basic-item:hover { 107 | background-color: var(--text-selection); 108 | box-shadow: -40px 0 0 var(--text-selection); 109 | cursor: pointer; 110 | } 111 | 112 | /*****************/ 113 | /** Error Views **/ 114 | /*****************/ 115 | 116 | div.dataview-error-box { 117 | width: 100%; 118 | min-height: 150px; 119 | display: flex; 120 | align-items: center; 121 | justify-content: center; 122 | border: 4px dashed var(--background-secondary); 123 | } 124 | 125 | .dataview-error-message { 126 | color: var(--text-muted); 127 | text-align: center; 128 | } 129 | 130 | /*************************/ 131 | /** Additional Metadata **/ 132 | /*************************/ 133 | 134 | .dataview.small-text { 135 | font-size: smaller; 136 | color: var(--text-muted); 137 | margin-left: 3px; 138 | } 139 | 140 | .dataview.small-text::before { 141 | content: "("; 142 | } 143 | 144 | .dataview.small-text::after { 145 | content: ")"; 146 | } 147 | -------------------------------------------------------------------------------- /.obsidian/plugins/templater-obsidian/data.json: -------------------------------------------------------------------------------- 1 | { 2 | "command_timeout": 5, 3 | "templates_folder": "TEMPLATES", 4 | "templates_pairs": [ 5 | [ 6 | "cmd_exec", 7 | "cmd /C %Cmd%" 8 | ], 9 | [ 10 | "pwsh5_exec", 11 | "PowerShell -NoProfile -Command Invoke-Expression(\"$Env:Pwsh\")" 12 | ], 13 | [ 14 | "pwsh7_exec", 15 | "pwsh -NoProfile -Command Invoke-Expression(\"$Env:Pwsh\")" 16 | ], 17 | [ 18 | "", 19 | "" 20 | ] 21 | ], 22 | "trigger_on_file_creation": false, 23 | "auto_jump_to_cursor": false, 24 | "enable_system_commands": true, 25 | "shell_path": "", 26 | "user_scripts_folder": "TEMPLATES/Functions", 27 | "enable_folder_templates": true, 28 | "folder_templates": [ 29 | { 30 | "folder": "", 31 | "template": "" 32 | } 33 | ], 34 | "syntax_highlighting": true, 35 | "enabled_templates_hotkeys": [ 36 | "TEMPLATES/Execute PowerShell5 Selected Text.md" 37 | ], 38 | "startup_templates": [ 39 | "" 40 | ], 41 | "enable_ribbon_icon": true 42 | } -------------------------------------------------------------------------------- /.obsidian/plugins/templater-obsidian/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "id": "templater-obsidian", 3 | "name": "Templater", 4 | "version": "1.16.0", 5 | "description": "Create and use templates", 6 | "minAppVersion": "0.11.13", 7 | "author": "SilentVoid", 8 | "authorUrl": "https://github.com/SilentVoid13", 9 | "isDesktopOnly": false 10 | } 11 | -------------------------------------------------------------------------------- /.obsidian/plugins/templater-obsidian/styles.css: -------------------------------------------------------------------------------- 1 | .templater_search { 2 | width: calc(100% - 20px); 3 | } 4 | 5 | .templater_div { 6 | border-top: 1px solid var(--background-modifier-border); 7 | } 8 | 9 | .templater_div > .setting-item { 10 | border-top: none !important; 11 | align-self: center; 12 | } 13 | 14 | .templater_div > .setting-item > .setting-item-control { 15 | justify-content: space-around; 16 | padding: 0; 17 | width: 100%; 18 | } 19 | 20 | .templater_div 21 | > .setting-item 22 | > .setting-item-control 23 | > .setting-editor-extra-setting-button { 24 | align-self: center; 25 | } 26 | 27 | .templater_donating { 28 | margin: 10px; 29 | } 30 | 31 | .templater_title { 32 | margin: 0; 33 | padding: 0; 34 | margin-top: 5px; 35 | text-align: center; 36 | } 37 | 38 | .templater_template { 39 | align-self: center; 40 | margin-left: 5px; 41 | margin-right: 5px; 42 | width: 70%; 43 | } 44 | 45 | .templater_cmd { 46 | margin-left: 5px; 47 | margin-right: 5px; 48 | font-size: 14px; 49 | width: 100%; 50 | } 51 | 52 | .templater_div2 > .setting-item { 53 | align-content: center; 54 | justify-content: center; 55 | } 56 | 57 | .templater-prompt-div { 58 | display: flex; 59 | } 60 | 61 | .templater-prompt-form { 62 | display: flex; 63 | flex-grow: 1; 64 | } 65 | 66 | .templater-prompt-input { 67 | flex-grow: 1; 68 | } 69 | 70 | .templater-button-div { 71 | display: flex; 72 | flex-direction: column; 73 | align-items: center; 74 | margin-top: 1rem; 75 | } 76 | 77 | textarea.templater-prompt-input { 78 | height: 10rem; 79 | } 80 | 81 | textarea.templater-prompt-input:focus { 82 | border-color: var(--interactive-accent); 83 | } 84 | 85 | .cm-s-obsidian .templater-command-bg { 86 | left: 0px; 87 | right: 0px; 88 | background-color: var(--background-primary-alt); 89 | } 90 | 91 | .cm-s-obsidian .cm-templater-command { 92 | font-size: 0.85em; 93 | font-family: var(--font-monospace); 94 | line-height: 1.3; 95 | } 96 | 97 | .cm-s-obsidian .templater-inline .cm-templater-command { 98 | background-color: var(--background-primary-alt); 99 | } 100 | 101 | .cm-s-obsidian .cm-templater-command.cm-templater-opening-tag { 102 | font-weight: bold; 103 | } 104 | 105 | .cm-s-obsidian .cm-templater-command.cm-templater-closing-tag { 106 | font-weight: bold; 107 | } 108 | 109 | .cm-s-obsidian .cm-templater-command.cm-templater-interpolation-tag { 110 | color: #008bff; 111 | } 112 | 113 | .cm-s-obsidian .cm-templater-command.cm-templater-execution-tag { 114 | color: #c0d700; 115 | } 116 | 117 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-keyword { 118 | color: #00a7aa; 119 | font-weight: normal; 120 | } 121 | 122 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-atom { 123 | color: #f39b35; 124 | } 125 | 126 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-number { 127 | color: #a06fca; 128 | } 129 | 130 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-type { 131 | color: #a06fca; 132 | } 133 | 134 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-def { 135 | color: #98e342; 136 | } 137 | 138 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-property { 139 | color: #d4d4d4; 140 | } 141 | 142 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-variable { 143 | color: #d4d4d4; 144 | } 145 | 146 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-variable-2 { 147 | color: #da7dae; 148 | } 149 | 150 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-variable-3 { 151 | color: #a06fca; 152 | } 153 | 154 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-type.cm-def { 155 | color: #fc4384; 156 | } 157 | 158 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-property.cm-def { 159 | color: #fc4384; 160 | } 161 | 162 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-callee { 163 | color: #fc4384; 164 | } 165 | 166 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-operator { 167 | color: #fc4384; 168 | } 169 | 170 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-qualifier { 171 | color: #fc4384; 172 | } 173 | 174 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-tag { 175 | color: #fc4384; 176 | } 177 | 178 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-tag.cm-bracket { 179 | color: #d4d4d4; 180 | } 181 | 182 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-attribute { 183 | color: #a06fca; 184 | } 185 | 186 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-comment { 187 | color: #696d70; 188 | } 189 | 190 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-comment.cm-tag { 191 | color: #fc4384; 192 | } 193 | 194 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-comment.cm-attribute { 195 | color: #d4d4d4; 196 | } 197 | 198 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-string { 199 | color: #e6db74; 200 | } 201 | 202 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-string-2 { 203 | color: #f39b35; 204 | } 205 | 206 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-meta { 207 | color: #d4d4d4; 208 | background: inherit; 209 | } 210 | 211 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-builtin { 212 | color: #fc4384; 213 | } 214 | 215 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-header { 216 | color: #da7dae; 217 | } 218 | 219 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-hr { 220 | color: #98e342; 221 | } 222 | 223 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-link { 224 | color: #696d70; 225 | } 226 | 227 | .theme-dark .cm-s-obsidian .cm-templater-command.cm-error { 228 | border-bottom: 1px solid #c42412; 229 | } 230 | 231 | .theme-dark .cm-s-obsidian pre.HyperMD-codeblock .cm-keyword { 232 | font-weight: normal; 233 | } 234 | 235 | .theme-dark 236 | .cm-s-obsidian 237 | .cm-templater-command.CodeMirror-activeline-background { 238 | background: #272727; 239 | } 240 | 241 | .theme-dark .cm-s-obsidian .cm-templater-command.CodeMirror-matchingbracket { 242 | outline: 1px solid grey; 243 | color: #d4d4d4 !important; 244 | } 245 | 246 | .CodeMirror-hints { 247 | position: absolute; 248 | z-index: 10; 249 | overflow: hidden; 250 | list-style: none; 251 | 252 | margin: 0; 253 | padding: 2px; 254 | 255 | -webkit-box-shadow: 2px 3px 5px rgba(0, 0, 0, 0.2); 256 | -moz-box-shadow: 2px 3px 5px rgba(0, 0, 0, 0.2); 257 | box-shadow: 2px 3px 5px rgba(0, 0, 0, 0.2); 258 | border-radius: 3px; 259 | border: 1px solid silver; 260 | 261 | background: white; 262 | font-size: 90%; 263 | font-family: monospace; 264 | 265 | max-height: 20em; 266 | overflow-y: auto; 267 | } 268 | 269 | .CodeMirror-hint { 270 | margin: 0; 271 | padding: 0 4px; 272 | border-radius: 2px; 273 | white-space: pre; 274 | color: black; 275 | cursor: pointer; 276 | } 277 | 278 | li.CodeMirror-hint-active { 279 | background: #08f; 280 | color: white; 281 | } 282 | -------------------------------------------------------------------------------- /.obsidian/plugins/wikilinks-to-mdlinks-obsidian/main.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | var obsidian = require('obsidian'); 4 | 5 | /*! ***************************************************************************** 6 | Copyright (c) Microsoft Corporation. 7 | 8 | Permission to use, copy, modify, and/or distribute this software for any 9 | purpose with or without fee is hereby granted. 10 | 11 | THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH 12 | REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY 13 | AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, 14 | INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM 15 | LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR 16 | OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 17 | PERFORMANCE OF THIS SOFTWARE. 18 | ***************************************************************************** */ 19 | /* global Reflect, Promise */ 20 | 21 | var extendStatics = function(d, b) { 22 | extendStatics = Object.setPrototypeOf || 23 | ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || 24 | function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; 25 | return extendStatics(d, b); 26 | }; 27 | 28 | function __extends(d, b) { 29 | extendStatics(d, b); 30 | function __() { this.constructor = d; } 31 | d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); 32 | } 33 | 34 | var WikilinksToMdlinks = /** @class */ (function (_super) { 35 | __extends(WikilinksToMdlinks, _super); 36 | function WikilinksToMdlinks() { 37 | return _super !== null && _super.apply(this, arguments) || this; 38 | } 39 | WikilinksToMdlinks.prototype.onload = function () { 40 | var _this = this; 41 | console.log('loading wikilinks-to-mdlinks plugin...'); 42 | this.addCommand({ 43 | id: "toggle-wiki-md-links", 44 | name: "Toggle selected wikilink to markdown link and vice versa", 45 | checkCallback: function (checking) { 46 | var currentView = _this.app.workspace.getActiveLeafOfViewType(obsidian.MarkdownView); 47 | if ((currentView == null) || (currentView.getMode() !== 'source')) { 48 | return false; 49 | } 50 | if (!checking) { 51 | _this.toggleLink(); 52 | } 53 | return true; 54 | }, 55 | hotkeys: [{ 56 | modifiers: ["Mod", "Shift"], 57 | key: "L" 58 | }] 59 | }); 60 | }; 61 | WikilinksToMdlinks.prototype.onunload = function () { 62 | console.log('unloading wikilinks-to-mdlinks plugin'); 63 | }; 64 | WikilinksToMdlinks.prototype.toggleLink = function () { 65 | var currentView = this.app.workspace.getActiveLeafOfViewType(obsidian.MarkdownView); 66 | var editor = currentView.sourceMode.cmEditor; 67 | var cursor = editor.getCursor(); 68 | var line = editor.getDoc().getLine(cursor.line); 69 | var regexHasExtension = /^([^\\]*)\.(\w+)$/; 70 | var regexWiki = /\[\[([^\]]+)\]\]/; 71 | var regexParenthesis = /\((.*?)\)/; 72 | var regexWikiGlobal = /\[\[([^\]]*)\]\]/g; 73 | var regexMdGlobal = /\[([^\]]*)\]\(([^\(]*)\)/g; 74 | var wikiMatches = line.match(regexWikiGlobal); 75 | var mdMatches = line.match(regexMdGlobal); 76 | var ifFoundMatch = false; 77 | // If there are wikiMatches find if the cursor is inside the selected text 78 | var i = 0; 79 | if (wikiMatches) { 80 | for (var _i = 0, wikiMatches_1 = wikiMatches; _i < wikiMatches_1.length; _i++) { 81 | var item = wikiMatches_1[_i]; 82 | var temp = line.slice(i, line.length); 83 | var index = i + temp.indexOf(item); 84 | var indexEnd = index + item.length; 85 | i = indexEnd; 86 | if ((cursor.ch >= index) && (cursor.ch <= indexEnd)) { 87 | ifFoundMatch = true; 88 | var text = item.match(regexWiki)[1]; 89 | // Check if it is a markdown file 90 | var matches = text.match(regexHasExtension); 91 | var newText = text; 92 | if (matches) { 93 | var filename = matches[1]; 94 | var extension = matches[2]; 95 | } 96 | else { 97 | newText = newText + ".md"; 98 | } 99 | var encodedText = encodeURI(newText); 100 | var newItem = "[" + text + "](" + encodedText + ")"; 101 | var cursorStart = { 102 | line: cursor.line, 103 | ch: index 104 | }; 105 | var cursorEnd = { 106 | line: cursor.line, 107 | ch: indexEnd 108 | }; 109 | editor.replaceRange(newItem, cursorStart, cursorEnd); 110 | } 111 | } 112 | } 113 | i = 0; 114 | if (ifFoundMatch == false) { 115 | if (mdMatches) { 116 | for (var _a = 0, mdMatches_1 = mdMatches; _a < mdMatches_1.length; _a++) { 117 | var item = mdMatches_1[_a]; 118 | var temp = line.slice(i, line.length); 119 | var index = i + temp.indexOf(item); 120 | var indexEnd = index + item.length; 121 | i = indexEnd; 122 | if ((cursor.ch >= index) && (cursor.ch <= indexEnd)) { 123 | ifFoundMatch = true; 124 | var text = item.match(regexParenthesis)[1]; 125 | text = decodeURI(text); 126 | // Check if it is a markdown file 127 | var matches = text.match(regexHasExtension); 128 | if (matches) { 129 | var filename = matches[1]; 130 | var extension = matches[2]; 131 | if (extension == 'md') { 132 | text = filename; 133 | } 134 | } 135 | var newItem = "[[" + text + "]]"; 136 | var cursorStart = { 137 | line: cursor.line, 138 | ch: index 139 | }; 140 | var cursorEnd = { 141 | line: cursor.line, 142 | ch: indexEnd 143 | }; 144 | editor.replaceRange(newItem, cursorStart, cursorEnd); 145 | } 146 | } 147 | } 148 | } 149 | }; 150 | return WikilinksToMdlinks; 151 | }(obsidian.Plugin)); 152 | 153 | module.exports = WikilinksToMdlinks; 154 | //# 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    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\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\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 __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, privateMap) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to get private field on non-instance\");\r\n    }\r\n    return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to set private field on non-instance\");\r\n    }\r\n    privateMap.set(receiver, value);\r\n    return value;\r\n}\r\n","import { strict } from 'assert'\r\nimport { App, Modal, Notice, Plugin, PluginSettingTab, Setting } from 'obsidian'\r\nimport { MarkdownView, TFile } from 'obsidian'\r\n\r\nexport default class WikilinksToMdlinks extends Plugin {\r\n\tonload() {\r\n\t\tconsole.log('loading wikilinks-to-mdlinks plugin...')\r\n\r\n\t\tthis.addCommand({\r\n\t\t\tid: \"toggle-wiki-md-links\",\r\n\t\t\tname: \"Toggle selected wikilink to markdown link and vice versa\",\r\n\t\t\tcheckCallback: (checking: boolean) => {\r\n\t\t\t\tconst currentView = this.app.workspace.getActiveLeafOfViewType(MarkdownView)\r\n\r\n\t\t\t\tif ((currentView == null) || (currentView.getMode() !== 'source'))  {\r\n\t\t\t\t\treturn false\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (!checking) {\r\n\t\t\t\t\tthis.toggleLink()\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn true\r\n\t\t\t},\r\n\t\t\thotkeys: [{\r\n\t\t\t\tmodifiers: [\"Mod\", \"Shift\"],\r\n\t\t\t\tkey: \"L\"\r\n\t\t\t}]\r\n\t\t})\r\n\r\n\t}\r\n\r\n\tonunload() {\r\n\t\tconsole.log('unloading wikilinks-to-mdlinks plugin')\r\n\t}\r\n\r\n\ttoggleLink() {\r\n\t\tconst currentView = this.app.workspace.getActiveLeafOfViewType(MarkdownView)\r\n\t\tconst editor = currentView.sourceMode.cmEditor\r\n\r\n\r\n\t\tconst cursor = editor.getCursor()\r\n\t\tconst line = editor.getDoc().getLine(cursor.line);\r\n\r\n\t\tconst regexHasExtension = /^([^\\\\]*)\\.(\\w+)$/\r\n\r\n\t\tconst regexWiki = /\\[\\[([^\\]]+)\\]\\]/\r\n\t\tconst regexParenthesis = /\\((.*?)\\)/\r\n\t\tconst regexWikiGlobal = /\\[\\[([^\\]]*)\\]\\]/g\r\n\t\tconst regexMdGlobal = /\\[([^\\]]*)\\]\\(([^\\(]*)\\)/g\r\n\r\n\t\tlet wikiMatches = line.match(regexWikiGlobal)\r\n\t\tlet mdMatches = line.match(regexMdGlobal)\r\n\r\n\t\tlet ifFoundMatch = false\r\n\r\n\t\t// If there are wikiMatches find if the cursor is inside the selected text\r\n\t\tlet i = 0\r\n\t\tif (wikiMatches) {\r\n\t\t\tfor (const item of wikiMatches) {\r\n\r\n\t\t\t\tlet temp = line.slice(i, line.length)\r\n\r\n\t\t\t\tlet index = i + temp.indexOf(item)\r\n\t\t\t\tlet indexEnd = index + item.length\r\n\r\n\t\t\t\ti = indexEnd\r\n\t\t\t\tif ((cursor.ch >= index ) && (cursor.ch <= indexEnd )) {\r\n\t\t\t\t\tifFoundMatch = true\r\n\t\t\t\t\tlet text = item.match(regexWiki)[1]\r\n\t\t\t\t\t// Check if it is a markdown file\r\n\t\t\t\t\tconst matches = text.match(regexHasExtension);\r\n\t\t\t\t\tlet newText = text\r\n\t\t\t\t\tif (matches) {\r\n\t\t\t\t\t\tconst filename = matches[1]\r\n\t\t\t\t\t\tconst extension = matches[2]\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tnewText = newText + \".md\"\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconst encodedText = encodeURI(newText)\r\n\t\t\t\t\tlet newItem = `[${text}](${encodedText})`\r\n\r\n\t\t\t\t\tconst cursorStart = {\r\n\t\t\t\t\t\tline: cursor.line,\r\n\t\t\t\t\t\tch: index\r\n\t\t\t\t\t}\r\n\t\t\t\t\tconst cursorEnd = {\r\n\t\t\t\t\t\tline: cursor.line,\r\n\t\t\t\t\t\tch: indexEnd\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\teditor.replaceRange(newItem, cursorStart, cursorEnd);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\ti = 0\r\n\t\tif (ifFoundMatch == false) {\r\n\t\t\tif (mdMatches) {\r\n\t\t\t\tfor (const item of mdMatches) {\r\n\t\t\t\t\tlet temp = line.slice(i, line.length)\r\n\t\t\t\t\tlet index = i + temp.indexOf(item)\r\n\t\t\t\t\tlet indexEnd = index + item.length\r\n\t\t\t\t\ti = indexEnd\r\n\r\n\t\t\t\t\tif ((cursor.ch >= index ) && (cursor.ch <= indexEnd )) {\r\n\t\t\t\t\t\tifFoundMatch = true\r\n\t\t\t\t\t\tlet text = item.match(regexParenthesis)[1]\r\n\t\t\t\t\t\ttext = decodeURI(text)\r\n\r\n\t\t\t\t\t\t// Check if it is a markdown file\r\n\t\t\t\t\t\tconst matches = text.match(regexHasExtension);\r\n\t\t\t\t\t\tif (matches) {\r\n\t\t\t\t\t\t\tconst filename = matches[1]\r\n\t\t\t\t\t\t\tconst extension = matches[2]\r\n\r\n\t\t\t\t\t\t\tif (extension == 'md') {\r\n\t\t\t\t\t\t\t\ttext = filename\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tlet newItem = `[[${text}]]`\r\n\r\n\t\t\t\t\t\tconst cursorStart = {\r\n\t\t\t\t\t\t\tline: cursor.line,\r\n\t\t\t\t\t\t\tch: index\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tconst cursorEnd = {\r\n\t\t\t\t\t\t\tline: cursor.line,\r\n\t\t\t\t\t\t\tch: indexEnd\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\teditor.replaceRange(newItem, cursorStart, cursorEnd);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n"],"names":["MarkdownView","Plugin"],"mappings":"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"} 155 | -------------------------------------------------------------------------------- /.obsidian/plugins/wikilinks-to-mdlinks-obsidian/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "id": "wikilinks-to-mdlinks-obsidian", 3 | "name": "Wikilinks to MDLinks", 4 | "version": "0.0.12", 5 | "minAppVersion": "0.9.12", 6 | "description": "A plugin that converts wikilinks to markdown links and vice versa", 7 | "author": "Agatha Uy", 8 | "authorUrl": "https://github.com/agathauy", 9 | "isDesktopOnly": false 10 | } 11 | -------------------------------------------------------------------------------- /.obsidian/workspace.json: -------------------------------------------------------------------------------- 1 | { 2 | "main": { 3 | "id": "1b0a74a337dc32bd", 4 | "type": "split", 5 | "children": [ 6 | { 7 | "id": "29a1766ef7723bd0", 8 | "type": "tabs", 9 | "children": [ 10 | { 11 | "id": "9353b986f88ba232", 12 | "type": "leaf", 13 | "state": { 14 | "type": "markdown", 15 | "state": { 16 | "file": "ping example.md", 17 | "mode": "source", 18 | "source": false 19 | } 20 | } 21 | }, 22 | { 23 | "id": "56a45af6be70493b", 24 | "type": "leaf", 25 | "state": { 26 | "type": "markdown", 27 | "state": { 28 | "file": "README.md", 29 | "mode": "source", 30 | "source": false 31 | } 32 | } 33 | } 34 | ], 35 | "currentTab": 1 36 | } 37 | ], 38 | "direction": "vertical" 39 | }, 40 | "left": { 41 | "id": "88569b557936dd60", 42 | "type": "split", 43 | "children": [ 44 | { 45 | "id": "b4c0e0b44a090aa5", 46 | "type": "tabs", 47 | "children": [ 48 | { 49 | "id": "b5914aae5de2efca", 50 | "type": "leaf", 51 | "state": { 52 | "type": "file-explorer", 53 | "state": { 54 | "sortOrder": "alphabetical" 55 | } 56 | } 57 | }, 58 | { 59 | "id": "ba35d6eab2ad0fc2", 60 | "type": "leaf", 61 | "state": { 62 | "type": "search", 63 | "state": { 64 | "query": "", 65 | "matchingCase": false, 66 | "explainSearch": false, 67 | "collapseAll": false, 68 | "extraContext": false, 69 | "sortOrder": "alphabetical" 70 | } 71 | } 72 | }, 73 | { 74 | "id": "e51e8f6466785fec", 75 | "type": "leaf", 76 | "state": { 77 | "type": "starred", 78 | "state": {} 79 | } 80 | } 81 | ] 82 | } 83 | ], 84 | "direction": "horizontal", 85 | "width": 300 86 | }, 87 | "right": { 88 | "id": "9df4606d9e9dbc5f", 89 | "type": "split", 90 | "children": [ 91 | { 92 | "id": "9514e6cc4fe57830", 93 | "type": "tabs", 94 | "children": [ 95 | { 96 | "id": "54525f7c1b493d00", 97 | "type": "leaf", 98 | "state": { 99 | "type": "backlink", 100 | "state": { 101 | "file": "README.md", 102 | "collapseAll": false, 103 | "extraContext": false, 104 | "sortOrder": "alphabetical", 105 | "showSearch": false, 106 | "searchQuery": "", 107 | "backlinkCollapsed": false, 108 | "unlinkedCollapsed": true 109 | } 110 | } 111 | }, 112 | { 113 | "id": "4836c7768fe83dc1", 114 | "type": "leaf", 115 | "state": { 116 | "type": "outgoing-link", 117 | "state": { 118 | "file": "README.md", 119 | "linksCollapsed": false, 120 | "unlinkedCollapsed": true 121 | } 122 | } 123 | }, 124 | { 125 | "id": "5532750709a44710", 126 | "type": "leaf", 127 | "state": { 128 | "type": "tag", 129 | "state": { 130 | "sortOrder": "frequency", 131 | "useHierarchy": true 132 | } 133 | } 134 | }, 135 | { 136 | "id": "f2c82eb4294aa303", 137 | "type": "leaf", 138 | "state": { 139 | "type": "outline", 140 | "state": { 141 | "file": "README.md" 142 | } 143 | } 144 | } 145 | ], 146 | "currentTab": 3 147 | } 148 | ], 149 | "direction": "horizontal", 150 | "width": 300 151 | }, 152 | "left-ribbon": { 153 | "hiddenItems": { 154 | "switcher:Open quick switcher": false, 155 | "graph:Open graph view": false, 156 | "canvas:Create new canvas": false, 157 | "daily-notes:Open today's daily note": false, 158 | "templates:Insert template": false, 159 | "command-palette:Open command palette": false, 160 | "templater-obsidian:Templater": false 161 | } 162 | }, 163 | "active": "56a45af6be70493b", 164 | "lastOpenFiles": [ 165 | "attachments/Pasted image 20230312162144.png", 166 | "PowerShell Script Example.md", 167 | "README.md", 168 | "attachments/Pasted image 20230312161834.png", 169 | "ping example.md", 170 | "Obsidian-System-Commands-Execution-Templates", 171 | "attachments/Pasted image 20230312143001.png", 172 | "attachments/Pasted image 20230312142213.png", 173 | "README.md.md", 174 | "attachments/Pasted image 20230312141836.png", 175 | "attachments/ping_example_hotkey.gif", 176 | "attachments/Pasted image 20230312140640.png", 177 | "attachments/Pasted image 20230312140552.png", 178 | "attachments/ping_example.gif", 179 | "attachments/Pasted image 20230312113439.png", 180 | "attachments", 181 | "attachments/Pasted image 20230312132859.png.md", 182 | "Pasted image 20230312132859.png", 183 | "TEMPLATES/Execute cmd.exe Selected Text.md", 184 | "TEMPLATES/Execute PowerShell5 Selected Text.md", 185 | "TEMPLATES/Execute PowerShell7 Selected Text.md", 186 | "TEMPLATES/Functions", 187 | "TEMPLATES" 188 | ] 189 | } -------------------------------------------------------------------------------- /PowerShell Script Example.md: -------------------------------------------------------------------------------- 1 | # System information 2 | ## Computer information 3 | 4 | Host Name | User Name | CMD Path (Comspec) | OS Type 5 | --- | --- | --- | --- 6 | `TESTCOMPUTER`|`SuperUser`|`C:\Windows\system32\cmd.exe`|`Windows_NT` 7 | 8 | ## Network Adapter Information 9 | 10 | Card Name | Driver Path | Driver Version 11 | --- | --- | --- 12 | `VMware Network Adapter VMnet8`|`\SystemRoot\system32\DRIVERS\vmnetadapter.sys`|`14.0.0.5` 13 | 14 | All values were produced from Get-ObsidianThings.ps1 -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | This vault is to showcase the power of using user defined functions and system commands created through the `Templater` plugin. 2 | 3 | ## Forewarning 4 | 5 | Keep in mind that running system commands through any application is to be considered extremely dangerous if you don't know what you're doing. In normal circumstances when applications pass user input through an `exec()` or `eval()` statement, the result can lead to remote command execution if the passed input isn't properly sanitized. Given that Obsidian is a _local_ application that isn't interacting with remote user input, I'm comfortable extending Obsidian the benefits of running local scripts and Cmdlets to have their output parsed directly into the note I'm working on. 6 | 7 | With that said, **DO NOT RUN COMMANDS POSTED ON THE INTERNET IF YOU DON'T FULLY UNDERSTAND WHAT THEY ARE DOING**. I accept 0 responsibility for what you do with the educational information provided in this repository. If you run something that wipes your entire OS of the face of the earth, that's on you. 8 | 9 | ## Steps 10 | 11 | The following are requirements to grant Obsidian access to return output of system commands into notes. 12 | 13 | 1. Enable community plugins (Disable `safe mode`) 14 | 2. Download Templater 15 | 1. Create a templates folder 16 | 2. Enable system commands 17 | 3. Create user defined shell execution functions 18 | 4. Map hotkeys to each desired shell 19 | 3. Execute system command and have output returned directly to note 20 | 21 | 22 | ### Enabling Community Plugins 23 | 24 | Open settings with `Ctrl+ ,` > `Community Plugins` > `Turn on Community Plugins` 25 | ![Pasted image 20230312113550.png](attachments/Pasted%20image%2020230312113550.png) 26 | 27 | Click `Browse` 28 | ![Pasted image 20230312113743.png](attachments/Pasted%20image%2020230312113743.png) 29 | 30 | Type `Templater` and select the plugin by `SilentVoid`. Click `Install` then `Enable`. 31 | 32 | ![Pasted image 20230312113952.png](attachments/Pasted%20image%2020230312113952.png) 33 | 34 | 35 | ### Creating Template Folder 36 | 37 | Create a template folder in your desired location within the vault. I chose the root of the vault because it's easier to navigate and create templates but the folder name or location doesn't matter. 38 | 39 | ![Pasted image 20230312114222.png](attachments/Pasted%20image%2020230312114222.png) 40 | 41 | I will also create a `Functions` folder under the `TEMPLATES` folder to hold user defined JavaScript functions (we'll go over this in a bit) which similarly extend scripting capabilities but their setup is a bit more involved. This step isn't necessary if you're only wanting to run system commands and have their output returned to the calling note. 42 | 43 | 44 | ![Pasted image 20230312114606.png](attachments/Pasted%20image%2020230312114606.png) 45 | ![Pasted image 20230312114655.png](attachments/Pasted%20image%2020230312114655.png) 46 | 47 | 48 | ### Enabling Templater System Commands 49 | 50 | Open Templater's settings menu and set the template folder to the first created folder. In my case it is the `TEMPLATES` folder. This grants Templater access to templates within the folder of our choosing. Tweak the `Timeout` seconds if you think you'll be running commands that will take longer than 5 seconds to return output. 51 | 52 | ![Pasted image 20230312115546.png](attachments/Pasted%20image%2020230312115546.png) 53 | 54 | ![Pasted image 20230312115849.png](attachments/Pasted%20image%2020230312115849.png) 55 | 56 | > [!Note] Console Differences 57 | > Windows and \*Nix systems use different shells for command execution. Tweak your `Shell binary location` to match the shell your system is using i.e. `/bin/bash`, `/usr/bin/sh`, `/bin/zsh` etc. For Windows machines this can be left blank. Windows will automatically scan the system $PATH variable to find the shells we define in the next section. 58 | 59 | 60 | 61 | ### Creating User Functions 62 | 63 | User Functions allow us to map system command strings containing variables to JS functions that can be invoked through Templater. Template variables are passed to the defined functions as arguments that are defined when invoking the function. 64 | 65 | There are two ways to create user functions via Templater: 66 | 67 | 1. Templater's `Add New User Function` option which allows us to create a user function directly in Templater's settings menu. 68 | 2. Enabling Templater's `User Script Functions` which enables supported for exported JS script modules. 69 | 70 | We'll be covering option 1 now as it is the easier of the two options. A sample `User Script Function` will be included in the [[#Appendix]] section. 71 | 72 | In `User System Command Functions` click `Add New User Function` and add the desired function names and command strings for each shell. 73 | 74 | ![Pasted image 20230312124148.png](attachments/Pasted%20image%2020230312124148.png) 75 | 76 | Function Name | System Command String | Variable Name 77 | --- | --- | --- 78 | `cmd_exec` | `cmd /C %Cmd%` | `Cmd` 79 | `pwsh5_exec` | `PowerShell -NoProfile -Command Invoke-Expression("$Env:Pwsh")` | `Pwsh` 80 | `pwsh7_exec` | `pwsh -NoProfile -Command Invoke-Expression("$Env:Pwsh")` | `Pwsh` 81 | 82 | 83 | After a function is created with this method it can be invoked via a Templater template using the syntax: 84 | 85 | ```js 86 | <% tp.user.({: }) %> 87 | ``` 88 | 89 | Lets break down an example that will convert selected note text into a PowerShell command. This command can be copied and run despite being broken into multiple lines. I personally comment my templates like this to remember exactly how the template functions. 90 | 91 | ```js 92 | <% 93 | // Templater required opening tag 94 | tp. // Templater object 95 | user. // User Functions 96 | pwsh5_exec({ // Use the "Function Name" pwsh5_exec which maps to Invoke-Expression 97 | Pwsh: // "Pwsh" part of "$Env:Pwsh" i.e. the argument expected by pwsh5_exec 98 | tp.file.selection() // The command that will be executed / What has been highlighted on the screen 99 | }) 100 | // template required closing tag stripping whitespace after inserting output 101 | _%> 102 | ``` 103 | 104 | Now that the template format is understood, we can create new templates mapping to `PowerShell5.1`, `PowerShell7`, and `Cmd.exe`. Create 3 new files under the `TEMPLATES` directory: 105 | 106 | - `Execute PowerShell5 Selected Text` 107 | - `Execute PowerShell7 Selected Text` 108 | - `Execute cmd.exe Selected Text` 109 | 110 | ![Pasted image 20230312131658.png](attachments/Pasted%20image%2020230312131658.png) 111 | 112 | Pate the following into each respective file. Note that the `variable` and `argument` have been augmented to match the functions we created in the beginning of [[#Creating User Functions]]. 113 | 114 | #### Execute PowerShell5 Selected Text 115 | ```js 116 | <% 117 | // Templater required opening tag 118 | tp. // Templater object 119 | user. // User Functions 120 | pwsh5_exec({ // Use the "Function Name" pwsh5_exec which maps to Invoke-Expression 121 | Pwsh: // "Pwsh" part of "$Env:Pwsh" i.e. the argument expected by pwsh5_exec 122 | tp.file.selection() // The command that will be executed / What has been highlighted on the screen 123 | }) 124 | // template required closing tag stripping whitespace after inserting output 125 | _%> 126 | ``` 127 | 128 | #### Execute PowerShell7 Selected Text 129 | ```js 130 | <% 131 | // Templater required opening tag 132 | tp. // Templater object 133 | user. // User Functions 134 | pwsh7_exec({ // Use the "Function Name" pwsh5_exec which maps to Invoke-Expression 135 | Pwsh: // "Pwsh" part of "$Env:Pwsh" i.e. the argument expected by pwsh7_exec 136 | tp.file.selection() // The command that will be executed / What has been highlighted on the screen 137 | }) 138 | // template required closing tag stripping whitespace after inserting output 139 | _%> 140 | ``` 141 | 142 | #### Execute cmd.exe Selected Text 143 | ```js 144 | <% 145 | // Templater required opening tag 146 | tp. // Templater object 147 | user. // User Functions 148 | cmd_exec({ // Use the "Function Name" cmd_exec which maps to cmd /C 149 | Cmd: // Argument expected by cmd_exec i.e. %Cmd% 150 | tp.file.selection() // The command that will be executed / What has been highlighted on the screen 151 | }) 152 | // template required closing tag stripping whitespace after inserting output 153 | _%> 154 | ``` 155 | 156 | 157 | ### Command Execution Example 158 | 159 | With the 3 template files added to the `TEMPLATES` directory we can now convert highlighted text into a system command. Note that note text must match the syntax of the corresponding shell. Let's look at a PowerShell example where the output of a `ping` command to Google's DNS server is returned to the note. 160 | 161 | 1. Open a new note 162 | 2. Type `ping -n 2 8.8.8.8` in the new note 163 | 3. Select the typed text 164 | 4. Click the Templater Icon 165 | 5. Select the corresponding shell to run the command 166 | 167 | ![ping_example.gif](attachments/ping_example.gif) 168 | 169 | Start to see how incredibly powerful this capability is, particularly with ingesting data into our PKMs. I run a substantial number of scripts during penetration testing whose output is eventually copy and paste into Obsidian. This functionality will significantly reduce the overhead by automating data ingestion into Obsidian. We can also execute local scripts in the same manor that might generate markdown formatted output, which in term would automatically format the note to our liking. 170 | 171 | ### Executing a PowerShell Script 172 | 173 | The following script is named "Get-ObsidianThings.ps1". It collects data about the computer and first registered ethernet card, then outputs content into a Markdown formatted table. 174 | 175 | ```powershell 176 | # Get-ObsidianThings.ps1 177 | # showcase how output can be formatted to markdown from within a script 178 | $HostName = $env:COMPUTERNAME 179 | $Accountname = $env:USERNAME 180 | $CMDPath = $env:ComSpec 181 | $OSType = $env:OS 182 | 183 | $NetAdapter = Get-NetAdapter |Select-Object -First 1 | Select-Object DriverName, Name, DriverVersion 184 | 185 | $NetCardname = $NetAdapter.Name 186 | $NetCardDriverPath = $NetAdapter.DriverName 187 | $NetCardDriverVer = $NetAdapter.DriverVersion 188 | 189 | 190 | # Format the markdown that will exist in note 191 | 192 | "# System information" | Write-Output 193 | "## Computer information`n" | Write-Output 194 | "Host Name | User Name | CMD Path (Comspec) | OS Type" | Write-Output 195 | " --- | --- | --- | --- "| Write-Output 196 | "``$HostName``|``$Accountname``|``$CMDPath``|``$OSType```n" | Write-Output 197 | "## Network Adaper Informaiton`n"| Write-Output 198 | "Card Name | Driver Path | Driver Version"| Write-Output 199 | " --- | --- | --- "| Write-Output 200 | "``$NetCardname``|``$NetCardDriverPath``|``$NetCardDriverVer```n"| Write-Output 201 | "All values were produced from Get-ObsidianThings.ps1"| Write-Output 202 | ``` 203 | 204 | To invoke this script, type the script's full path and select the text as before before running the Templater PowerShell execution template. **NOTE** when running on windows each backslash character `\` needs to be escaped with a second backslash or all slashes must be converted into forward slashes to run the command. 205 | 206 | ![](attachments/Pasted%20image%2020230312161834.png) 207 | 208 | Select the text and use the appropriate shell execution template to run the command. Output will be written directly into the note. 209 | 210 | ![](attachments/Pasted%20image%2020230312162144.png) 211 | The `ping` example was nice but this example showcases the potential of pre-emptively wrapping script output into markdown format, circumventing the need to copy and paste (and reformat) script output into our PKM systems. 212 | 213 | 214 | ### Mapping Template Hotkeys 215 | 216 | The execution templates can also be mapped to hot keys further reducing overhead. To map one of the shell executions to a hot key open `Templater settings > Template Hotkeys >` and add each shell to the hotkey of choice. 217 | 218 | ![Pasted image 20230312140552.png](attachments/Pasted%20image%2020230312140552.png) 219 | 220 | The hotkey can then be configured through the context menu. 221 | 222 | ![Pasted image 20230312140640.png](attachments/Pasted%20image%2020230312140640.png) 223 | 224 | Now to execute a system command through PowerShell5, simply highlight the text and press `Ctrl + Shift + 1` to have its output returned to the terminal. 225 | 226 | ![ping_example_hotkey.gif](attachments/ping_example_hotkey.gif) 227 | 228 | 229 | ## Appendix 230 | 231 | ### Creating CommonJS Modules (Script Modules) 232 | Documentation on a simple script module can be found on Templater's [Help Page](https://silentvoid13.github.io/Templater/) 233 | Enable script modules by specifying the module path. In my case its `TEMPLATES/Funtions`. 234 | 235 | ![Pasted image 20230312141836.png](attachments/Pasted%20image%2020230312141836.png) 236 | To extend a script module to Templater, a script must be placed in the above folder. Script modules must end in `.js`. Obsidian by default doesn't show unknown filetypes. This setting must be changed within `Files & Links`. 237 | 238 | ![Pasted image 20230312142213.png](attachments/Pasted%20image%2020230312142213.png) 239 | 240 | 241 | Open your favorite text editor and paste the following, naming the file `shell.js`. This won't be possible through Obsidian because it doesn't have a handler for `.js` files. 242 | > credits: https://forum.obsidian.md/t/templater-system-commands-file-lists-weather-and-git/36197 243 | 244 | ```js 245 | // In: cmd = a complete command to run in the command line shell. It is up 246 | // to the user to make certain the command is properly formatted 247 | // for their platform 248 | // Out: an object with two properties: 249 | // out = the trimmed content the command sent to standard out. 250 | // err = the trimmed content the command sent to standard error. 251 | async function shell(cmd) 252 | { 253 | const { promisify } = require('util'); 254 | const exec = promisify(require('child_process').exec); 255 | const result = await exec(cmd); 256 | return {out: result.stdout.trim(), err: result.stderr.trim()}; 257 | } 258 | module.exports = shell; 259 | ``` 260 | 261 | This example supposedly works on Linux based systems but it fails as it is on Windows. This example is for edification purposes to show how exporting modules works. 262 | 263 | To extend the module functionality to Templater, open settings and click the refresh button. The module should then appear in `Detected (x) User Scripts`. 264 | 265 | ![Pasted image 20230312143001.png](attachments/Pasted%20image%2020230312143001.png) 266 | - this module would then be used by calling `tp.user.shell()` the same way previous functions were called. 267 | 268 | 269 | ### Resources 270 | - https://medium.com/@gareth.stretton/obsidian-do-almost-anything-really-with-system-commands-b496ffd0679c 271 | - https://github.com/djjoa/Obsidian-System-Commands-Execution-Templates 272 | - https://silentvoid13.github.io/Templater/user-functions/script-user-functions.html 273 | - https://silentvoid13.github.io/Templater/introduction.html -------------------------------------------------------------------------------- /TEMPLATES/Execute PowerShell5 Selected Text.md: -------------------------------------------------------------------------------- 1 | <% 2 | // Templater required opening tag 3 | tp. // Templater object 4 | user. // User Functions 5 | pwsh5_exec({ // Use the "Function Name" pwsh5_exec which maps to Invoke-Expression 6 | Pwsh: // "Pwsh" part of "$Env:Pwsh" i.e. the argument expected by pwsh5_exec 7 | tp.file.selection() // The command that will be executed / What has been highlighted on the screen 8 | }) 9 | // template required closing tag stripping whitespace after inserting output 10 | _%> -------------------------------------------------------------------------------- /TEMPLATES/Execute PowerShell7 Selected Text.md: -------------------------------------------------------------------------------- 1 | <% 2 | // Templater required opening tag 3 | tp. // Templater object 4 | user. // User Functions 5 | pwsh7_exec({ // Use the "Function Name" pwsh5_exec which maps to Invoke-Expression 6 | Pwsh: // "Pwsh" part of "$Env:Pwsh" i.e. the argument expected by pwsh5_exec 7 | tp.file.selection() // The command that will be executed / What has been highlighted on the screen 8 | }) 9 | // template required closing tag stripping whitespace after inserting output 10 | _%> -------------------------------------------------------------------------------- /TEMPLATES/Execute cmd.exe Selected Text.md: -------------------------------------------------------------------------------- 1 | <% 2 | // Templater required opening tag 3 | tp. // Templater object 4 | user. // User Functions 5 | cmd_exec({ // Use the "Function Name" cmd_exec which maps to cmd /C 6 | Cmd: // Argument expected by cmd_exec i.e. %Cmd% 7 | tp.file.selection() // The command that will be executed / What has been highlighted on the screen 8 | }) 9 | // template required closing tag stripping whitespace after inserting output 10 | _%> -------------------------------------------------------------------------------- /attachments/Pasted image 20230312113439.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312113439.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312113550.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312113550.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312113743.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312113743.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312113952.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312113952.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312114222.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312114222.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312114606.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312114606.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312114655.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312114655.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312115546.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312115546.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312115849.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312115849.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312124148.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312124148.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312131658.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312131658.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312132859.png.md: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312132859.png.md -------------------------------------------------------------------------------- /attachments/Pasted image 20230312140552.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312140552.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312140640.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312140640.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312141836.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312141836.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312142213.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312142213.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312143001.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312143001.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312161834.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312161834.png -------------------------------------------------------------------------------- /attachments/Pasted image 20230312162144.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/Pasted image 20230312162144.png -------------------------------------------------------------------------------- /attachments/ping_example.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/ping_example.gif -------------------------------------------------------------------------------- /attachments/ping_example_hotkey.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/attachments/ping_example_hotkey.gif -------------------------------------------------------------------------------- /ping example.md: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/djjoa/Obsidian-System-Commands-Execution-Templates/c4ec40c129b75772c5312940b5dec07d6da99fbc/ping example.md --------------------------------------------------------------------------------