├── .editorconfig ├── .eslintignore ├── .eslintrc ├── .github └── workflows │ └── release.yml ├── .gitignore ├── .npmrc ├── LICENSE ├── README.md ├── esbuild.config.mjs ├── main.ts ├── manifest.json ├── noteset-info.png ├── noteset-select-modal.png ├── noteset-settings.png ├── package-lock.json ├── package.json ├── settings.png ├── src ├── UI │ ├── icon.ts │ ├── noteset │ │ ├── noteSetDeleteModal.ts │ │ ├── noteSetEditModal.ts │ │ └── noteSetInfoModal.ts │ ├── selectNoteSetModal.ts │ ├── settingsTab.ts │ └── sidebar │ │ └── sidebarView.ts ├── dataview │ ├── dataviewFacade.ts │ └── dataviewService.ts ├── noteSet │ ├── INoteSet.ts │ ├── INoteSetStats.ts │ ├── noteReviewPriorityHelpers.ts │ ├── noteSetInfoService.ts │ ├── noteSetService.ts │ ├── notesetValidationErrors.ts │ └── reviewFrequency.ts ├── notes │ └── fileService.ts ├── queues │ ├── noteQueue.ts │ └── reviewService.ts ├── settings │ ├── joinLogicOperators.ts │ ├── pluginSettings.ts │ └── reviewAlgorightms.ts └── utils │ ├── dateUtils.ts │ └── metadataService.ts ├── styles.css ├── tsconfig.json ├── version-bump.mjs └── versions.json /.editorconfig: -------------------------------------------------------------------------------- 1 | # top-most EditorConfig file 2 | root = true 3 | 4 | [*] 5 | charset = utf-8 6 | insert_final_newline = true 7 | indent_style = tab 8 | indent_size = 4 9 | tab_width = 4 10 | -------------------------------------------------------------------------------- /.eslintignore: -------------------------------------------------------------------------------- 1 | npm node_modules 2 | build -------------------------------------------------------------------------------- /.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "root": true, 3 | "parser": "@typescript-eslint/parser", 4 | "env": { "node": true }, 5 | "plugins": [ 6 | "@typescript-eslint" 7 | ], 8 | "extends": [ 9 | "eslint:recommended", 10 | "plugin:@typescript-eslint/eslint-recommended", 11 | "plugin:@typescript-eslint/recommended" 12 | ], 13 | "parserOptions": { 14 | "sourceType": "module" 15 | }, 16 | "rules": { 17 | "no-unused-vars": "off", 18 | "@typescript-eslint/no-unused-vars": ["error", { "args": "none" }], 19 | "@typescript-eslint/ban-ts-comment": "off", 20 | "no-prototype-builtins": "off", 21 | "@typescript-eslint/no-empty-function": "off" 22 | } 23 | } -------------------------------------------------------------------------------- /.github/workflows/release.yml: -------------------------------------------------------------------------------- 1 | name: Create release 2 | 3 | on: 4 | push: 5 | tags: 6 | - "*" 7 | 8 | jobs: 9 | build: 10 | runs-on: ubuntu-latest 11 | 12 | steps: 13 | - uses: actions/checkout@v3 14 | 15 | - name: Use Node.js 16 | uses: actions/setup-node@v3 17 | with: 18 | node-version: "18.x" 19 | 20 | - name: Build plugin 21 | run: | 22 | npm install 23 | npm run build 24 | 25 | 26 | - name: Create release 27 | env: 28 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} 29 | run: | 30 | tag="${{ github.ref_name }}" 31 | 32 | gh release create "$tag" \ 33 | --title="$tag" \ 34 | --draft \ 35 | main.js manifest.json styles.css -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # vscode 2 | .vscode 3 | 4 | # Intellij 5 | *.iml 6 | .idea 7 | 8 | # npm 9 | node_modules 10 | 11 | # Don't include the compiled main.js file in the repo. 12 | # They should be uploaded to GitHub releases instead. 13 | main.js 14 | 15 | # Exclude sourcemaps 16 | *.map 17 | 18 | # obsidian 19 | data.json 20 | 21 | # Exclude macOS Finder (System Explorer) View States 22 | .DS_Store 23 | -------------------------------------------------------------------------------- /.npmrc: -------------------------------------------------------------------------------- 1 | tag-version-prefix="" -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) [2022] [Daniel Nikolaev] 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Simple Note Review 2 | Simple and flexible plugin for note review, resurfacing, and repetition. 3 | 4 | > IMPORTANT: this plugin uses [Dataview](https://github.com/blacksmithgu/obsidian-dataview) plugin as its search engine. 5 | Please make sure you have Dataview plugin installed. 6 | 7 | ### Is this a spaced repitition plugin? 8 | Not quite. 9 | 10 | This is a plugin for people who want to review, resurface, and rediscover their notes, but do not want to build a rigid system with a schedule. 11 | 12 | The philosophy is: "define a set of notes and review them at your own pace". 13 | 14 | ## How does it work? 15 | #### Define a note set based on tags, folders, or a dataviewJS query. 16 | Simple Note Review can create a noteset with a flexible set of rules: tags and/or folders, creation date, or even a dataviewJS query. 17 | A note can be in any number of note sets. 18 | 19 | ![image](https://github.com/dartungar/obsidian-simple-note-review/assets/36126057/60c9501c-aa4c-4d09-bd77-4ebf2dd9bb0b) 20 | 21 | #### Use toolbar or commands for reviewing 22 | When you start a review of a noteset for the first time, the plugin creates a persistent queue with all the notes in this noteset. 23 | 24 | You can proceed reviewing notes in order, or choose a random one. 25 | 26 | If you want to start a fresh review, reset the noteset queue with corresponding button on the sidebar or a command. 27 | 28 | IMPORTANT: review queue does not update automatically, so it's always best to reset the queue when starting a new review! 29 | 30 | ![sidebar](https://github.com/dartungar/obsidian-simple-note-review/assets/36126057/f85c88f9-819f-40ec-a5ee-2db623d32733) 31 | 32 | #### Review or skip note 33 | To review or skip a note, click button on a sidebar or use a corresponding command. 34 | Skipping a note removes it from a current review queue; it will be back when you reset the queue. 35 | 36 | ![review-note](https://github.com/dartungar/obsidian-simple-note-review/assets/36126057/9d18dc36-2c98-43bb-8101-12d8cf7cc313) 37 | 38 | 39 | #### Change review frequency for notes or exclude them from reviews 40 | You can optionally set each note's review frequency in the sidebar on via command: 41 | - high 42 | - normal 43 | - low 44 | - ignore (exclude from all reviews) 45 | 46 | #### What does "current note set" mean? 47 | It is a note set you are currently reviewing. 48 | Since one note can be in any number of note sets, the plugin needs to understand which queue to use. 49 | 50 | #### Noteset Stats 51 | You can see noteset stats in settings or in sidebar. 52 | 53 | ![image](https://github.com/dartungar/obsidian-simple-note-review/assets/36126057/257d2a64-60fc-470d-8649-9541b47159cf) 54 | 55 | -------------------------------------------------------------------------------- /esbuild.config.mjs: -------------------------------------------------------------------------------- 1 | import esbuild from "esbuild"; 2 | import process from "process"; 3 | import builtins from 'builtin-modules' 4 | 5 | const banner = 6 | `/* 7 | THIS IS A GENERATED/BUNDLED FILE BY ESBUILD 8 | if you want to view the source, please visit the github repository of this plugin 9 | */ 10 | `; 11 | 12 | const prod = (process.argv[2] === 'production'); 13 | 14 | esbuild.build({ 15 | banner: { 16 | js: banner, 17 | }, 18 | entryPoints: ['main.ts'], 19 | bundle: true, 20 | external: [ 21 | 'obsidian', 22 | 'electron', 23 | '@codemirror/autocomplete', 24 | '@codemirror/closebrackets', 25 | '@codemirror/collab', 26 | '@codemirror/commands', 27 | '@codemirror/comment', 28 | '@codemirror/fold', 29 | '@codemirror/gutter', 30 | '@codemirror/highlight', 31 | '@codemirror/history', 32 | '@codemirror/language', 33 | '@codemirror/lint', 34 | '@codemirror/matchbrackets', 35 | '@codemirror/panel', 36 | '@codemirror/rangeset', 37 | '@codemirror/rectangular-selection', 38 | '@codemirror/search', 39 | '@codemirror/state', 40 | '@codemirror/stream-parser', 41 | '@codemirror/text', 42 | '@codemirror/tooltip', 43 | '@codemirror/view', 44 | ...builtins], 45 | format: 'cjs', 46 | watch: !prod, 47 | target: 'es2016', 48 | logLevel: "info", 49 | sourcemap: prod ? false : 'inline', 50 | treeShaking: true, 51 | outfile: 'main.js', 52 | }).catch(() => process.exit(1)); 53 | -------------------------------------------------------------------------------- /main.ts: -------------------------------------------------------------------------------- 1 | import { Notice, Plugin } from "obsidian"; 2 | import { getAPI } from "obsidian-dataview"; 3 | import { NoteSetService } from "src/noteSet/noteSetService"; 4 | import { SelectNoteSetModal } from "src/UI/selectNoteSetModal"; 5 | import { 6 | DefaultSettings, 7 | SimpleNoteReviewPluginSettings, 8 | } from "src/settings/pluginSettings"; 9 | import { SimpleNoteReviewPluginSettingsTab } from "src/UI/settingsTab"; 10 | import { ReviewFrequency } from "src/noteSet/reviewFrequency"; 11 | import { SimpleNoteReviewSidebarView } from "src/UI/sidebar/sidebarView"; 12 | import { FileService } from "src/notes/fileService"; 13 | import { ReviewService } from "src/queues/reviewService"; 14 | 15 | export default class SimpleNoteReviewPlugin extends Plugin { 16 | settings: SimpleNoteReviewPluginSettings; 17 | noteSetService: NoteSetService = new NoteSetService(this.app, this); 18 | reviewService: ReviewService = new ReviewService(this.app, this); 19 | fileService: FileService = new FileService(this.app, this); 20 | 21 | readonly openModalIconName: string = "glasses"; 22 | readonly markAsReviewedIconName: string = "checkmark"; 23 | 24 | async onload() { 25 | this.app.workspace.onLayoutReady(() => { 26 | if (!this.dataviewIsInstalled()) { 27 | this.showNotice( 28 | "Could not find Dataview plugin. To use Simple Note Review plugin, please install Dataview plugin first." 29 | ); 30 | } 31 | }); 32 | 33 | await this.loadSettings(); 34 | 35 | this.noteSetService.updateNoteSetDisplayNames(); 36 | 37 | this.registerView( 38 | SimpleNoteReviewSidebarView.VIEW_TYPE, 39 | (leaf) => new SimpleNoteReviewSidebarView(leaf, this) 40 | ); 41 | 42 | this.addRibbonIcon( 43 | this.openModalIconName, 44 | "Simple Note Review: Open Sidebar View", 45 | (evt: MouseEvent) => { 46 | this.activateView(); 47 | } 48 | ); 49 | 50 | this.addRibbonIcon( 51 | "play", 52 | "Simple Note Review: Continue Review of Current Note Set", 53 | (evt: MouseEvent) => { 54 | this.reviewService.startReview(this.settings.currentNoteSetId); 55 | } 56 | ); 57 | 58 | this.addCommands(); 59 | 60 | this.addSettingTab( 61 | new SimpleNoteReviewPluginSettingsTab(this, this.app) 62 | ); 63 | 64 | this.app.vault.on("delete", file => this.noteSetService.onPhysicalDeleteNote(file)); 65 | } 66 | 67 | onunload() {} 68 | 69 | async loadSettings() { 70 | this.settings = Object.assign( 71 | {}, 72 | new DefaultSettings(), 73 | await this.loadData() 74 | ); 75 | 76 | this.settings.noteSets = this.noteSetService.sortNoteSets(this.settings.noteSets); 77 | await this.noteSetService.validateAllNotesets(); 78 | } 79 | 80 | async saveSettings() { 81 | this.settings.noteSets = this.noteSetService.sortNoteSets(this.settings.noteSets); 82 | await this.saveData(this.settings); 83 | } 84 | 85 | public showNotice(message: string): void { 86 | new Notice(message); 87 | } 88 | 89 | private dataviewIsInstalled(): boolean { 90 | return !!getAPI(); 91 | } 92 | 93 | private addCommands(): void { 94 | this.addCommand({ 95 | id: "start-review", 96 | name: "Start reviewing notes in current note set", 97 | callback: () => { 98 | this.reviewService.startReview(this.settings.currentNoteSetId); 99 | }, 100 | }); 101 | 102 | this.addCommand({ 103 | id: "open-sidebar", 104 | name: "Open Sidebar View", 105 | callback: () => { 106 | this.activateView(); 107 | }, 108 | }); 109 | 110 | this.addCommand({ 111 | id: "open-random-note", 112 | name: "Open random note from the current note set", 113 | callback: () => { 114 | this.reviewService.openRandomNoteInQueue( 115 | this.settings.currentNoteSetId 116 | ); 117 | }, 118 | }); 119 | 120 | this.addCommand({ 121 | id: "reset-queue", 122 | name: "reset queue for the current note set", 123 | callback: () => { 124 | this.reviewService.resetNotesetQueueWithValidation( 125 | this.settings.currentNoteSetId 126 | ); 127 | }, 128 | }); 129 | 130 | this.addCommand({ 131 | id: "open-modal", 132 | name: "Select note set for reviewing", 133 | callback: () => { 134 | new SelectNoteSetModal(this.app, this).open(); 135 | }, 136 | }); 137 | 138 | this.addCommand({ 139 | id: "mark-current-note-as-reviewed", 140 | name: "Mark current note as reviewed", 141 | callback: () => { 142 | this.reviewService.reviewNote( 143 | this.app.workspace.getActiveFile(), 144 | this.settings.currentNoteSetId 145 | ); 146 | }, 147 | }); 148 | 149 | this.addCommand({ 150 | id: "set-review-frequency-high", 151 | name: "Set review frequency to high", 152 | callback: () => { 153 | this.fileService.setReviewFrequency( 154 | this.app.workspace.getActiveFile(), 155 | ReviewFrequency.high 156 | ); 157 | }, 158 | }); 159 | 160 | this.addCommand({ 161 | id: "set-review-frequency-normal", 162 | name: "Set review frequency to normal", 163 | callback: () => { 164 | this.fileService.setReviewFrequency( 165 | this.app.workspace.getActiveFile(), 166 | ReviewFrequency.normal 167 | ); 168 | }, 169 | }); 170 | 171 | this.addCommand({ 172 | id: "set-review-frequency-low", 173 | name: "Set review frequency to low", 174 | callback: () => { 175 | this.fileService.setReviewFrequency( 176 | this.app.workspace.getActiveFile(), 177 | ReviewFrequency.low 178 | ); 179 | }, 180 | }); 181 | 182 | this.addCommand({ 183 | id: "set-review-frequency-ignore", 184 | name: "Set review frequency to none (ignore this note in all reviews)", 185 | callback: () => { 186 | this.fileService.setReviewFrequency( 187 | this.app.workspace.getActiveFile(), 188 | ReviewFrequency.ignore 189 | ); 190 | }, 191 | }); 192 | 193 | this.addCommand({ 194 | id: "skip-note", 195 | name: "Skip note from current review", 196 | callback: () => { 197 | this.reviewService.skipNote( 198 | this.app.workspace.getActiveFile(), 199 | this.settings.currentNoteSetId 200 | ); 201 | }, 202 | }); 203 | } 204 | 205 | async activateView() { 206 | this.app.workspace.detachLeavesOfType( 207 | SimpleNoteReviewSidebarView.VIEW_TYPE 208 | ); 209 | 210 | await this.app.workspace.getRightLeaf(false).setViewState({ 211 | type: SimpleNoteReviewSidebarView.VIEW_TYPE, 212 | active: true, 213 | }); 214 | 215 | this.app.workspace.revealLeaf( 216 | this.app.workspace.getLeavesOfType( 217 | SimpleNoteReviewSidebarView.VIEW_TYPE 218 | )[0] 219 | ); 220 | } 221 | } 222 | -------------------------------------------------------------------------------- /manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "id": "simple-note-review", 3 | "name": "Simple Note Review", 4 | "version": "1.2.6", 5 | "minAppVersion": "1.1.0", 6 | "description": "Simple, customizable plugin for easy note review, resurfacing & repetition.", 7 | "author": "dartungar", 8 | "authorUrl": "https://dartungar.com", 9 | "fundingUrl": "https://www.paypal.com/paypalme/dartungar", 10 | "isDesktopOnly": false 11 | } 12 | -------------------------------------------------------------------------------- /noteset-info.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/dartungar/obsidian-simple-note-review/caff68188f5571a168bc1705edd9ae9610ca7ee1/noteset-info.png -------------------------------------------------------------------------------- /noteset-select-modal.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/dartungar/obsidian-simple-note-review/caff68188f5571a168bc1705edd9ae9610ca7ee1/noteset-select-modal.png -------------------------------------------------------------------------------- /noteset-settings.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/dartungar/obsidian-simple-note-review/caff68188f5571a168bc1705edd9ae9610ca7ee1/noteset-settings.png -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "obsidian-sample-plugin", 3 | "version": "1.0.1", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "obsidian-sample-plugin", 9 | "version": "1.0.1", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@types/node": "^16.18.87", 13 | "@typescript-eslint/eslint-plugin": "5.29.0", 14 | "@typescript-eslint/parser": "5.29.0", 15 | "builtin-modules": "^3.2.0", 16 | "esbuild": "0.14.47", 17 | "obsidian": "^1.5.7-1", 18 | "obsidian-dataview": "^0.5.46", 19 | "tslib": "2.4.0", 20 | "typescript": "4.7.4" 21 | } 22 | }, 23 | "node_modules/@codemirror/language": { 24 | "version": "6.2.1", 25 | "resolved": "git+ssh://git@github.com/lishid/cm-language.git#073afd8e6bc4d8e5cf6170a50f9b668a98c39f1c", 26 | "dev": true, 27 | "license": "MIT", 28 | "dependencies": { 29 | "@codemirror/state": "^6.0.0", 30 | "@codemirror/view": "^6.0.0", 31 | "@lezer/common": "^1.0.0", 32 | "@lezer/highlight": "^1.0.0", 33 | "@lezer/lr": "^1.0.0", 34 | "style-mod": "^4.0.0" 35 | } 36 | }, 37 | "node_modules/@codemirror/state": { 38 | "version": "6.0.1", 39 | "resolved": "https://registry.npmjs.org/@codemirror/state/-/state-6.0.1.tgz", 40 | "integrity": "sha512-6vYgaXc4KjSY0BUfSVDJooGcoswg/RJZpq/ZGjsUYmY0KN1lmB8u03nv+jiG1ncUV5qoggyxFT5AGD5Ak+5Zrw==", 41 | "dev": true 42 | }, 43 | "node_modules/@codemirror/view": { 44 | "version": "6.0.2", 45 | "resolved": "https://registry.npmjs.org/@codemirror/view/-/view-6.0.2.tgz", 46 | "integrity": "sha512-mnVT/q1JvKPjpmjXJNeCi/xHyaJ3abGJsumIVpdQ1nE1MXAyHf7GHWt8QpWMUvDiqF0j+inkhVR2OviTdFFX7Q==", 47 | "dev": true, 48 | "dependencies": { 49 | "@codemirror/state": "^6.0.0", 50 | "style-mod": "^4.0.0", 51 | "w3c-keyname": "^2.2.4" 52 | } 53 | }, 54 | "node_modules/@eslint/eslintrc": { 55 | "version": "1.3.0", 56 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.3.0.tgz", 57 | "integrity": "sha512-UWW0TMTmk2d7hLcWD1/e2g5HDM/HQ3csaLSqXCfqwh4uNDuNqlaKWXmEsL4Cs41Z0KnILNvwbHAah3C2yt06kw==", 58 | "dev": true, 59 | "peer": true, 60 | "dependencies": { 61 | "ajv": "^6.12.4", 62 | "debug": "^4.3.2", 63 | "espree": "^9.3.2", 64 | "globals": "^13.15.0", 65 | "ignore": "^5.2.0", 66 | "import-fresh": "^3.2.1", 67 | "js-yaml": "^4.1.0", 68 | "minimatch": "^3.1.2", 69 | "strip-json-comments": "^3.1.1" 70 | }, 71 | "engines": { 72 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 73 | } 74 | }, 75 | "node_modules/@humanwhocodes/config-array": { 76 | "version": "0.9.5", 77 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.5.tgz", 78 | "integrity": "sha512-ObyMyWxZiCu/yTisA7uzx81s40xR2fD5Cg/2Kq7G02ajkNubJf6BopgDTmDyc3U7sXpNKM8cYOw7s7Tyr+DnCw==", 79 | "dev": true, 80 | "peer": true, 81 | "dependencies": { 82 | "@humanwhocodes/object-schema": "^1.2.1", 83 | "debug": "^4.1.1", 84 | "minimatch": "^3.0.4" 85 | }, 86 | "engines": { 87 | "node": ">=10.10.0" 88 | } 89 | }, 90 | "node_modules/@humanwhocodes/object-schema": { 91 | "version": "1.2.1", 92 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 93 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 94 | "dev": true, 95 | "peer": true 96 | }, 97 | "node_modules/@lezer/common": { 98 | "version": "1.0.1", 99 | "resolved": "https://registry.npmjs.org/@lezer/common/-/common-1.0.1.tgz", 100 | "integrity": "sha512-8TR5++Q/F//tpDsLd5zkrvEX5xxeemafEaek7mUp7Y+bI8cKQXdSqhzTOBaOogETcMOVr0pT3BBPXp13477ciw==", 101 | "dev": true 102 | }, 103 | "node_modules/@lezer/highlight": { 104 | "version": "1.1.1", 105 | "resolved": "https://registry.npmjs.org/@lezer/highlight/-/highlight-1.1.1.tgz", 106 | "integrity": "sha512-duv9D23O9ghEDnnUDmxu+L8pJy4nYo4AbCOHIudUhscrLSazqeJeK1V50EU6ZufWF1zv0KJwu/frFRyZWXxHBQ==", 107 | "dev": true, 108 | "dependencies": { 109 | "@lezer/common": "^1.0.0" 110 | } 111 | }, 112 | "node_modules/@lezer/lr": { 113 | "version": "1.2.3", 114 | "resolved": "https://registry.npmjs.org/@lezer/lr/-/lr-1.2.3.tgz", 115 | "integrity": "sha512-qpB7rBzH8f6Mzjv2AVZRahcm+2Cf7nbIH++uXbvVOL1yIRvVWQ3HAM/saeBLCyz/togB7LGo76qdJYL1uKQlqA==", 116 | "dev": true, 117 | "dependencies": { 118 | "@lezer/common": "^1.0.0" 119 | } 120 | }, 121 | "node_modules/@nodelib/fs.scandir": { 122 | "version": "2.1.5", 123 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 124 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 125 | "dev": true, 126 | "dependencies": { 127 | "@nodelib/fs.stat": "2.0.5", 128 | "run-parallel": "^1.1.9" 129 | }, 130 | "engines": { 131 | "node": ">= 8" 132 | } 133 | }, 134 | "node_modules/@nodelib/fs.stat": { 135 | "version": "2.0.5", 136 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 137 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 138 | "dev": true, 139 | "engines": { 140 | "node": ">= 8" 141 | } 142 | }, 143 | "node_modules/@nodelib/fs.walk": { 144 | "version": "1.2.8", 145 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 146 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 147 | "dev": true, 148 | "dependencies": { 149 | "@nodelib/fs.scandir": "2.1.5", 150 | "fastq": "^1.6.0" 151 | }, 152 | "engines": { 153 | "node": ">= 8" 154 | } 155 | }, 156 | "node_modules/@types/codemirror": { 157 | "version": "0.0.108", 158 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.108.tgz", 159 | "integrity": "sha512-3FGFcus0P7C2UOGCNUVENqObEb4SFk+S8Dnxq7K6aIsLVs/vDtlangl3PEO0ykaKXyK56swVF6Nho7VsA44uhw==", 160 | "dev": true, 161 | "dependencies": { 162 | "@types/tern": "*" 163 | } 164 | }, 165 | "node_modules/@types/estree": { 166 | "version": "0.0.52", 167 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.52.tgz", 168 | "integrity": "sha512-BZWrtCU0bMVAIliIV+HJO1f1PR41M7NKjfxrFJwwhKI1KwhwOxYw1SXg9ao+CIMt774nFuGiG6eU+udtbEI9oQ==", 169 | "dev": true 170 | }, 171 | "node_modules/@types/json-schema": { 172 | "version": "7.0.11", 173 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", 174 | "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==", 175 | "dev": true 176 | }, 177 | "node_modules/@types/node": { 178 | "version": "16.18.87", 179 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.87.tgz", 180 | "integrity": "sha512-+IzfhNirR/MDbXz6Om5eHV54D9mQlEMGag6AgEzlju0xH3M8baCXYwqQ6RKgGMpn9wSTx6Ltya/0y4Z8eSfdLw==", 181 | "dev": true 182 | }, 183 | "node_modules/@types/tern": { 184 | "version": "0.23.4", 185 | "resolved": "https://registry.npmjs.org/@types/tern/-/tern-0.23.4.tgz", 186 | "integrity": "sha512-JAUw1iXGO1qaWwEOzxTKJZ/5JxVeON9kvGZ/osgZaJImBnyjyn0cjovPsf6FNLmyGY8Vw9DoXZCMlfMkMwHRWg==", 187 | "dev": true, 188 | "dependencies": { 189 | "@types/estree": "*" 190 | } 191 | }, 192 | "node_modules/@typescript-eslint/eslint-plugin": { 193 | "version": "5.29.0", 194 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.29.0.tgz", 195 | "integrity": "sha512-kgTsISt9pM53yRFQmLZ4npj99yGl3x3Pl7z4eA66OuTzAGC4bQB5H5fuLwPnqTKU3yyrrg4MIhjF17UYnL4c0w==", 196 | "dev": true, 197 | "dependencies": { 198 | "@typescript-eslint/scope-manager": "5.29.0", 199 | "@typescript-eslint/type-utils": "5.29.0", 200 | "@typescript-eslint/utils": "5.29.0", 201 | "debug": "^4.3.4", 202 | "functional-red-black-tree": "^1.0.1", 203 | "ignore": "^5.2.0", 204 | "regexpp": "^3.2.0", 205 | "semver": "^7.3.7", 206 | "tsutils": "^3.21.0" 207 | }, 208 | "engines": { 209 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 210 | }, 211 | "funding": { 212 | "type": "opencollective", 213 | "url": "https://opencollective.com/typescript-eslint" 214 | }, 215 | "peerDependencies": { 216 | "@typescript-eslint/parser": "^5.0.0", 217 | "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" 218 | }, 219 | "peerDependenciesMeta": { 220 | "typescript": { 221 | "optional": true 222 | } 223 | } 224 | }, 225 | "node_modules/@typescript-eslint/eslint-plugin/node_modules/tslib": { 226 | "version": "1.14.1", 227 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 228 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 229 | "dev": true 230 | }, 231 | "node_modules/@typescript-eslint/eslint-plugin/node_modules/tsutils": { 232 | "version": "3.21.0", 233 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 234 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 235 | "dev": true, 236 | "dependencies": { 237 | "tslib": "^1.8.1" 238 | }, 239 | "engines": { 240 | "node": ">= 6" 241 | }, 242 | "peerDependencies": { 243 | "typescript": ">=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta" 244 | } 245 | }, 246 | "node_modules/@typescript-eslint/parser": { 247 | "version": "5.29.0", 248 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.29.0.tgz", 249 | "integrity": "sha512-ruKWTv+x0OOxbzIw9nW5oWlUopvP/IQDjB5ZqmTglLIoDTctLlAJpAQFpNPJP/ZI7hTT9sARBosEfaKbcFuECw==", 250 | "dev": true, 251 | "dependencies": { 252 | "@typescript-eslint/scope-manager": "5.29.0", 253 | "@typescript-eslint/types": "5.29.0", 254 | "@typescript-eslint/typescript-estree": "5.29.0", 255 | "debug": "^4.3.4" 256 | }, 257 | "engines": { 258 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 259 | }, 260 | "funding": { 261 | "type": "opencollective", 262 | "url": "https://opencollective.com/typescript-eslint" 263 | }, 264 | "peerDependencies": { 265 | "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" 266 | }, 267 | "peerDependenciesMeta": { 268 | "typescript": { 269 | "optional": true 270 | } 271 | } 272 | }, 273 | "node_modules/@typescript-eslint/scope-manager": { 274 | "version": "5.29.0", 275 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.29.0.tgz", 276 | "integrity": "sha512-etbXUT0FygFi2ihcxDZjz21LtC+Eps9V2xVx09zFoN44RRHPrkMflidGMI+2dUs821zR1tDS6Oc9IXxIjOUZwA==", 277 | "dev": true, 278 | "dependencies": { 279 | "@typescript-eslint/types": "5.29.0", 280 | "@typescript-eslint/visitor-keys": "5.29.0" 281 | }, 282 | "engines": { 283 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 284 | }, 285 | "funding": { 286 | "type": "opencollective", 287 | "url": "https://opencollective.com/typescript-eslint" 288 | } 289 | }, 290 | "node_modules/@typescript-eslint/type-utils": { 291 | "version": "5.29.0", 292 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.29.0.tgz", 293 | "integrity": "sha512-JK6bAaaiJozbox3K220VRfCzLa9n0ib/J+FHIwnaV3Enw/TO267qe0pM1b1QrrEuy6xun374XEAsRlA86JJnyg==", 294 | "dev": true, 295 | "dependencies": { 296 | "@typescript-eslint/utils": "5.29.0", 297 | "debug": "^4.3.4", 298 | "tsutils": "^3.21.0" 299 | }, 300 | "engines": { 301 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 302 | }, 303 | "funding": { 304 | "type": "opencollective", 305 | "url": "https://opencollective.com/typescript-eslint" 306 | }, 307 | "peerDependencies": { 308 | "eslint": "*" 309 | }, 310 | "peerDependenciesMeta": { 311 | "typescript": { 312 | "optional": true 313 | } 314 | } 315 | }, 316 | "node_modules/@typescript-eslint/type-utils/node_modules/tslib": { 317 | "version": "1.14.1", 318 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 319 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 320 | "dev": true 321 | }, 322 | "node_modules/@typescript-eslint/type-utils/node_modules/tsutils": { 323 | "version": "3.21.0", 324 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 325 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 326 | "dev": true, 327 | "dependencies": { 328 | "tslib": "^1.8.1" 329 | }, 330 | "engines": { 331 | "node": ">= 6" 332 | }, 333 | "peerDependencies": { 334 | "typescript": ">=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta" 335 | } 336 | }, 337 | "node_modules/@typescript-eslint/types": { 338 | "version": "5.29.0", 339 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.29.0.tgz", 340 | "integrity": "sha512-X99VbqvAXOMdVyfFmksMy3u8p8yoRGITgU1joBJPzeYa0rhdf5ok9S56/itRoUSh99fiDoMtarSIJXo7H/SnOg==", 341 | "dev": true, 342 | "engines": { 343 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 344 | }, 345 | "funding": { 346 | "type": "opencollective", 347 | "url": "https://opencollective.com/typescript-eslint" 348 | } 349 | }, 350 | "node_modules/@typescript-eslint/typescript-estree": { 351 | "version": "5.29.0", 352 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.29.0.tgz", 353 | "integrity": "sha512-mQvSUJ/JjGBdvo+1LwC+GY2XmSYjK1nAaVw2emp/E61wEVYEyibRHCqm1I1vEKbXCpUKuW4G7u9ZCaZhJbLoNQ==", 354 | "dev": true, 355 | "dependencies": { 356 | "@typescript-eslint/types": "5.29.0", 357 | "@typescript-eslint/visitor-keys": "5.29.0", 358 | "debug": "^4.3.4", 359 | "globby": "^11.1.0", 360 | "is-glob": "^4.0.3", 361 | "semver": "^7.3.7", 362 | "tsutils": "^3.21.0" 363 | }, 364 | "engines": { 365 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 366 | }, 367 | "funding": { 368 | "type": "opencollective", 369 | "url": "https://opencollective.com/typescript-eslint" 370 | }, 371 | "peerDependenciesMeta": { 372 | "typescript": { 373 | "optional": true 374 | } 375 | } 376 | }, 377 | "node_modules/@typescript-eslint/typescript-estree/node_modules/tslib": { 378 | "version": "1.14.1", 379 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 380 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 381 | "dev": true 382 | }, 383 | "node_modules/@typescript-eslint/typescript-estree/node_modules/tsutils": { 384 | "version": "3.21.0", 385 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 386 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 387 | "dev": true, 388 | "dependencies": { 389 | "tslib": "^1.8.1" 390 | }, 391 | "engines": { 392 | "node": ">= 6" 393 | }, 394 | "peerDependencies": { 395 | "typescript": ">=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta" 396 | } 397 | }, 398 | "node_modules/@typescript-eslint/utils": { 399 | "version": "5.29.0", 400 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.29.0.tgz", 401 | "integrity": "sha512-3Eos6uP1nyLOBayc/VUdKZikV90HahXE5Dx9L5YlSd/7ylQPXhLk1BYb29SDgnBnTp+jmSZUU0QxUiyHgW4p7A==", 402 | "dev": true, 403 | "dependencies": { 404 | "@types/json-schema": "^7.0.9", 405 | "@typescript-eslint/scope-manager": "5.29.0", 406 | "@typescript-eslint/types": "5.29.0", 407 | "@typescript-eslint/typescript-estree": "5.29.0", 408 | "eslint-scope": "^5.1.1", 409 | "eslint-utils": "^3.0.0" 410 | }, 411 | "engines": { 412 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 413 | }, 414 | "funding": { 415 | "type": "opencollective", 416 | "url": "https://opencollective.com/typescript-eslint" 417 | }, 418 | "peerDependencies": { 419 | "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" 420 | } 421 | }, 422 | "node_modules/@typescript-eslint/visitor-keys": { 423 | "version": "5.29.0", 424 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.29.0.tgz", 425 | "integrity": "sha512-Hpb/mCWsjILvikMQoZIE3voc9wtQcS0A9FUw3h8bhr9UxBdtI/tw1ZDZUOXHXLOVMedKCH5NxyzATwnU78bWCQ==", 426 | "dev": true, 427 | "dependencies": { 428 | "@typescript-eslint/types": "5.29.0", 429 | "eslint-visitor-keys": "^3.3.0" 430 | }, 431 | "engines": { 432 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 433 | }, 434 | "funding": { 435 | "type": "opencollective", 436 | "url": "https://opencollective.com/typescript-eslint" 437 | } 438 | }, 439 | "node_modules/acorn": { 440 | "version": "8.7.1", 441 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz", 442 | "integrity": "sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A==", 443 | "dev": true, 444 | "peer": true, 445 | "bin": { 446 | "acorn": "bin/acorn" 447 | }, 448 | "engines": { 449 | "node": ">=0.4.0" 450 | } 451 | }, 452 | "node_modules/acorn-jsx": { 453 | "version": "5.3.2", 454 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 455 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 456 | "dev": true, 457 | "peer": true, 458 | "peerDependencies": { 459 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 460 | } 461 | }, 462 | "node_modules/ajv": { 463 | "version": "6.12.6", 464 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 465 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 466 | "dev": true, 467 | "peer": true, 468 | "dependencies": { 469 | "fast-deep-equal": "^3.1.1", 470 | "fast-json-stable-stringify": "^2.0.0", 471 | "json-schema-traverse": "^0.4.1", 472 | "uri-js": "^4.2.2" 473 | }, 474 | "funding": { 475 | "type": "github", 476 | "url": "https://github.com/sponsors/epoberezkin" 477 | } 478 | }, 479 | "node_modules/ansi-regex": { 480 | "version": "5.0.1", 481 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 482 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 483 | "dev": true, 484 | "peer": true, 485 | "engines": { 486 | "node": ">=8" 487 | } 488 | }, 489 | "node_modules/ansi-styles": { 490 | "version": "4.3.0", 491 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 492 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 493 | "dev": true, 494 | "peer": true, 495 | "dependencies": { 496 | "color-convert": "^2.0.1" 497 | }, 498 | "engines": { 499 | "node": ">=8" 500 | }, 501 | "funding": { 502 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 503 | } 504 | }, 505 | "node_modules/argparse": { 506 | "version": "2.0.1", 507 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 508 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 509 | "dev": true, 510 | "peer": true 511 | }, 512 | "node_modules/array-union": { 513 | "version": "2.1.0", 514 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 515 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 516 | "dev": true, 517 | "engines": { 518 | "node": ">=8" 519 | } 520 | }, 521 | "node_modules/balanced-match": { 522 | "version": "1.0.2", 523 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 524 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 525 | "dev": true, 526 | "peer": true 527 | }, 528 | "node_modules/brace-expansion": { 529 | "version": "1.1.11", 530 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 531 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 532 | "dev": true, 533 | "peer": true, 534 | "dependencies": { 535 | "balanced-match": "^1.0.0", 536 | "concat-map": "0.0.1" 537 | } 538 | }, 539 | "node_modules/braces": { 540 | "version": "3.0.2", 541 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 542 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 543 | "dev": true, 544 | "dependencies": { 545 | "fill-range": "^7.0.1" 546 | }, 547 | "engines": { 548 | "node": ">=8" 549 | } 550 | }, 551 | "node_modules/builtin-modules": { 552 | "version": "3.3.0", 553 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.3.0.tgz", 554 | "integrity": "sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw==", 555 | "dev": true, 556 | "engines": { 557 | "node": ">=6" 558 | }, 559 | "funding": { 560 | "url": "https://github.com/sponsors/sindresorhus" 561 | } 562 | }, 563 | "node_modules/callsites": { 564 | "version": "3.1.0", 565 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 566 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 567 | "dev": true, 568 | "peer": true, 569 | "engines": { 570 | "node": ">=6" 571 | } 572 | }, 573 | "node_modules/chalk": { 574 | "version": "4.1.2", 575 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 576 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 577 | "dev": true, 578 | "peer": true, 579 | "dependencies": { 580 | "ansi-styles": "^4.1.0", 581 | "supports-color": "^7.1.0" 582 | }, 583 | "engines": { 584 | "node": ">=10" 585 | }, 586 | "funding": { 587 | "url": "https://github.com/chalk/chalk?sponsor=1" 588 | } 589 | }, 590 | "node_modules/color-convert": { 591 | "version": "2.0.1", 592 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 593 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 594 | "dev": true, 595 | "peer": true, 596 | "dependencies": { 597 | "color-name": "~1.1.4" 598 | }, 599 | "engines": { 600 | "node": ">=7.0.0" 601 | } 602 | }, 603 | "node_modules/color-name": { 604 | "version": "1.1.4", 605 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 606 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 607 | "dev": true, 608 | "peer": true 609 | }, 610 | "node_modules/concat-map": { 611 | "version": "0.0.1", 612 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 613 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 614 | "dev": true, 615 | "peer": true 616 | }, 617 | "node_modules/cross-spawn": { 618 | "version": "7.0.3", 619 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 620 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 621 | "dev": true, 622 | "peer": true, 623 | "dependencies": { 624 | "path-key": "^3.1.0", 625 | "shebang-command": "^2.0.0", 626 | "which": "^2.0.1" 627 | }, 628 | "engines": { 629 | "node": ">= 8" 630 | } 631 | }, 632 | "node_modules/debug": { 633 | "version": "4.3.4", 634 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 635 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 636 | "dev": true, 637 | "dependencies": { 638 | "ms": "2.1.2" 639 | }, 640 | "engines": { 641 | "node": ">=6.0" 642 | }, 643 | "peerDependenciesMeta": { 644 | "supports-color": { 645 | "optional": true 646 | } 647 | } 648 | }, 649 | "node_modules/deep-is": { 650 | "version": "0.1.4", 651 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 652 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 653 | "dev": true, 654 | "peer": true 655 | }, 656 | "node_modules/dir-glob": { 657 | "version": "3.0.1", 658 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 659 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 660 | "dev": true, 661 | "dependencies": { 662 | "path-type": "^4.0.0" 663 | }, 664 | "engines": { 665 | "node": ">=8" 666 | } 667 | }, 668 | "node_modules/doctrine": { 669 | "version": "3.0.0", 670 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 671 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 672 | "dev": true, 673 | "peer": true, 674 | "dependencies": { 675 | "esutils": "^2.0.2" 676 | }, 677 | "engines": { 678 | "node": ">=6.0.0" 679 | } 680 | }, 681 | "node_modules/emoji-regex": { 682 | "version": "10.1.0", 683 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.1.0.tgz", 684 | "integrity": "sha512-xAEnNCT3w2Tg6MA7ly6QqYJvEoY1tm9iIjJ3yMKK9JPlWuRHAMoe5iETwQnx3M9TVbFMfsrBgWKR+IsmswwNjg==", 685 | "dev": true 686 | }, 687 | "node_modules/esbuild": { 688 | "version": "0.14.47", 689 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.47.tgz", 690 | "integrity": "sha512-wI4ZiIfFxpkuxB8ju4MHrGwGLyp1+awEHAHVpx6w7a+1pmYIq8T9FGEVVwFo0iFierDoMj++Xq69GXWYn2EiwA==", 691 | "dev": true, 692 | "hasInstallScript": true, 693 | "bin": { 694 | "esbuild": "bin/esbuild" 695 | }, 696 | "engines": { 697 | "node": ">=12" 698 | }, 699 | "optionalDependencies": { 700 | "esbuild-android-64": "0.14.47", 701 | "esbuild-android-arm64": "0.14.47", 702 | "esbuild-darwin-64": "0.14.47", 703 | "esbuild-darwin-arm64": "0.14.47", 704 | "esbuild-freebsd-64": "0.14.47", 705 | "esbuild-freebsd-arm64": "0.14.47", 706 | "esbuild-linux-32": "0.14.47", 707 | "esbuild-linux-64": "0.14.47", 708 | "esbuild-linux-arm": "0.14.47", 709 | "esbuild-linux-arm64": "0.14.47", 710 | "esbuild-linux-mips64le": "0.14.47", 711 | "esbuild-linux-ppc64le": "0.14.47", 712 | "esbuild-linux-riscv64": "0.14.47", 713 | "esbuild-linux-s390x": "0.14.47", 714 | "esbuild-netbsd-64": "0.14.47", 715 | "esbuild-openbsd-64": "0.14.47", 716 | "esbuild-sunos-64": "0.14.47", 717 | "esbuild-windows-32": "0.14.47", 718 | "esbuild-windows-64": "0.14.47", 719 | "esbuild-windows-arm64": "0.14.47" 720 | } 721 | }, 722 | "node_modules/esbuild-android-64": { 723 | "version": "0.14.47", 724 | "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.14.47.tgz", 725 | "integrity": "sha512-R13Bd9+tqLVFndncMHssZrPWe6/0Kpv2/dt4aA69soX4PRxlzsVpCvoJeFE8sOEoeVEiBkI0myjlkDodXlHa0g==", 726 | "cpu": [ 727 | "x64" 728 | ], 729 | "dev": true, 730 | "optional": true, 731 | "os": [ 732 | "android" 733 | ], 734 | "engines": { 735 | "node": ">=12" 736 | } 737 | }, 738 | "node_modules/esbuild-android-arm64": { 739 | "version": "0.14.47", 740 | "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.47.tgz", 741 | "integrity": "sha512-OkwOjj7ts4lBp/TL6hdd8HftIzOy/pdtbrNA4+0oVWgGG64HrdVzAF5gxtJufAPOsEjkyh1oIYvKAUinKKQRSQ==", 742 | "cpu": [ 743 | "arm64" 744 | ], 745 | "dev": true, 746 | "optional": true, 747 | "os": [ 748 | "android" 749 | ], 750 | "engines": { 751 | "node": ">=12" 752 | } 753 | }, 754 | "node_modules/esbuild-darwin-64": { 755 | "version": "0.14.47", 756 | "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.47.tgz", 757 | "integrity": "sha512-R6oaW0y5/u6Eccti/TS6c/2c1xYTb1izwK3gajJwi4vIfNs1s8B1dQzI1UiC9T61YovOQVuePDcfqHLT3mUZJA==", 758 | "cpu": [ 759 | "x64" 760 | ], 761 | "dev": true, 762 | "optional": true, 763 | "os": [ 764 | "darwin" 765 | ], 766 | "engines": { 767 | "node": ">=12" 768 | } 769 | }, 770 | "node_modules/esbuild-darwin-arm64": { 771 | "version": "0.14.47", 772 | "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.47.tgz", 773 | "integrity": "sha512-seCmearlQyvdvM/noz1L9+qblC5vcBrhUaOoLEDDoLInF/VQ9IkobGiLlyTPYP5dW1YD4LXhtBgOyevoIHGGnw==", 774 | "cpu": [ 775 | "arm64" 776 | ], 777 | "dev": true, 778 | "optional": true, 779 | "os": [ 780 | "darwin" 781 | ], 782 | "engines": { 783 | "node": ">=12" 784 | } 785 | }, 786 | "node_modules/esbuild-freebsd-64": { 787 | "version": "0.14.47", 788 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.47.tgz", 789 | "integrity": "sha512-ZH8K2Q8/Ux5kXXvQMDsJcxvkIwut69KVrYQhza/ptkW50DC089bCVrJZZ3sKzIoOx+YPTrmsZvqeZERjyYrlvQ==", 790 | "cpu": [ 791 | "x64" 792 | ], 793 | "dev": true, 794 | "optional": true, 795 | "os": [ 796 | "freebsd" 797 | ], 798 | "engines": { 799 | "node": ">=12" 800 | } 801 | }, 802 | "node_modules/esbuild-freebsd-arm64": { 803 | "version": "0.14.47", 804 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.47.tgz", 805 | "integrity": "sha512-ZJMQAJQsIOhn3XTm7MPQfCzEu5b9STNC+s90zMWe2afy9EwnHV7Ov7ohEMv2lyWlc2pjqLW8QJnz2r0KZmeAEQ==", 806 | "cpu": [ 807 | "arm64" 808 | ], 809 | "dev": true, 810 | "optional": true, 811 | "os": [ 812 | "freebsd" 813 | ], 814 | "engines": { 815 | "node": ">=12" 816 | } 817 | }, 818 | "node_modules/esbuild-linux-32": { 819 | "version": "0.14.47", 820 | "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.47.tgz", 821 | "integrity": "sha512-FxZOCKoEDPRYvq300lsWCTv1kcHgiiZfNrPtEhFAiqD7QZaXrad8LxyJ8fXGcWzIFzRiYZVtB3ttvITBvAFhKw==", 822 | "cpu": [ 823 | "ia32" 824 | ], 825 | "dev": true, 826 | "optional": true, 827 | "os": [ 828 | "linux" 829 | ], 830 | "engines": { 831 | "node": ">=12" 832 | } 833 | }, 834 | "node_modules/esbuild-linux-64": { 835 | "version": "0.14.47", 836 | "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.47.tgz", 837 | "integrity": "sha512-nFNOk9vWVfvWYF9YNYksZptgQAdstnDCMtR6m42l5Wfugbzu11VpMCY9XrD4yFxvPo9zmzcoUL/88y0lfJZJJw==", 838 | "cpu": [ 839 | "x64" 840 | ], 841 | "dev": true, 842 | "optional": true, 843 | "os": [ 844 | "linux" 845 | ], 846 | "engines": { 847 | "node": ">=12" 848 | } 849 | }, 850 | "node_modules/esbuild-linux-arm": { 851 | "version": "0.14.47", 852 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.47.tgz", 853 | "integrity": "sha512-ZGE1Bqg/gPRXrBpgpvH81tQHpiaGxa8c9Rx/XOylkIl2ypLuOcawXEAo8ls+5DFCcRGt/o3sV+PzpAFZobOsmA==", 854 | "cpu": [ 855 | "arm" 856 | ], 857 | "dev": true, 858 | "optional": true, 859 | "os": [ 860 | "linux" 861 | ], 862 | "engines": { 863 | "node": ">=12" 864 | } 865 | }, 866 | "node_modules/esbuild-linux-arm64": { 867 | "version": "0.14.47", 868 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.47.tgz", 869 | "integrity": "sha512-ywfme6HVrhWcevzmsufjd4iT3PxTfCX9HOdxA7Hd+/ZM23Y9nXeb+vG6AyA6jgq/JovkcqRHcL9XwRNpWG6XRw==", 870 | "cpu": [ 871 | "arm64" 872 | ], 873 | "dev": true, 874 | "optional": true, 875 | "os": [ 876 | "linux" 877 | ], 878 | "engines": { 879 | "node": ">=12" 880 | } 881 | }, 882 | "node_modules/esbuild-linux-mips64le": { 883 | "version": "0.14.47", 884 | "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.47.tgz", 885 | "integrity": "sha512-mg3D8YndZ1LvUiEdDYR3OsmeyAew4MA/dvaEJxvyygahWmpv1SlEEnhEZlhPokjsUMfRagzsEF/d/2XF+kTQGg==", 886 | "cpu": [ 887 | "mips64el" 888 | ], 889 | "dev": true, 890 | "optional": true, 891 | "os": [ 892 | "linux" 893 | ], 894 | "engines": { 895 | "node": ">=12" 896 | } 897 | }, 898 | "node_modules/esbuild-linux-ppc64le": { 899 | "version": "0.14.47", 900 | "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.47.tgz", 901 | "integrity": "sha512-WER+f3+szmnZiWoK6AsrTKGoJoErG2LlauSmk73LEZFQ/iWC+KhhDsOkn1xBUpzXWsxN9THmQFltLoaFEH8F8w==", 902 | "cpu": [ 903 | "ppc64" 904 | ], 905 | "dev": true, 906 | "optional": true, 907 | "os": [ 908 | "linux" 909 | ], 910 | "engines": { 911 | "node": ">=12" 912 | } 913 | }, 914 | "node_modules/esbuild-linux-riscv64": { 915 | "version": "0.14.47", 916 | "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.14.47.tgz", 917 | "integrity": "sha512-1fI6bP3A3rvI9BsaaXbMoaOjLE3lVkJtLxsgLHqlBhLlBVY7UqffWBvkrX/9zfPhhVMd9ZRFiaqXnB1T7BsL2g==", 918 | "cpu": [ 919 | "riscv64" 920 | ], 921 | "dev": true, 922 | "optional": true, 923 | "os": [ 924 | "linux" 925 | ], 926 | "engines": { 927 | "node": ">=12" 928 | } 929 | }, 930 | "node_modules/esbuild-linux-s390x": { 931 | "version": "0.14.47", 932 | "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.14.47.tgz", 933 | "integrity": "sha512-eZrWzy0xFAhki1CWRGnhsHVz7IlSKX6yT2tj2Eg8lhAwlRE5E96Hsb0M1mPSE1dHGpt1QVwwVivXIAacF/G6mw==", 934 | "cpu": [ 935 | "s390x" 936 | ], 937 | "dev": true, 938 | "optional": true, 939 | "os": [ 940 | "linux" 941 | ], 942 | "engines": { 943 | "node": ">=12" 944 | } 945 | }, 946 | "node_modules/esbuild-netbsd-64": { 947 | "version": "0.14.47", 948 | "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.47.tgz", 949 | "integrity": "sha512-Qjdjr+KQQVH5Q2Q1r6HBYswFTToPpss3gqCiSw2Fpq/ua8+eXSQyAMG+UvULPqXceOwpnPo4smyZyHdlkcPppQ==", 950 | "cpu": [ 951 | "x64" 952 | ], 953 | "dev": true, 954 | "optional": true, 955 | "os": [ 956 | "netbsd" 957 | ], 958 | "engines": { 959 | "node": ">=12" 960 | } 961 | }, 962 | "node_modules/esbuild-openbsd-64": { 963 | "version": "0.14.47", 964 | "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.47.tgz", 965 | "integrity": "sha512-QpgN8ofL7B9z8g5zZqJE+eFvD1LehRlxr25PBkjyyasakm4599iroUpaj96rdqRlO2ShuyqwJdr+oNqWwTUmQw==", 966 | "cpu": [ 967 | "x64" 968 | ], 969 | "dev": true, 970 | "optional": true, 971 | "os": [ 972 | "openbsd" 973 | ], 974 | "engines": { 975 | "node": ">=12" 976 | } 977 | }, 978 | "node_modules/esbuild-sunos-64": { 979 | "version": "0.14.47", 980 | "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.47.tgz", 981 | "integrity": "sha512-uOeSgLUwukLioAJOiGYm3kNl+1wJjgJA8R671GYgcPgCx7QR73zfvYqXFFcIO93/nBdIbt5hd8RItqbbf3HtAQ==", 982 | "cpu": [ 983 | "x64" 984 | ], 985 | "dev": true, 986 | "optional": true, 987 | "os": [ 988 | "sunos" 989 | ], 990 | "engines": { 991 | "node": ">=12" 992 | } 993 | }, 994 | "node_modules/esbuild-windows-32": { 995 | "version": "0.14.47", 996 | "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.47.tgz", 997 | "integrity": "sha512-H0fWsLTp2WBfKLBgwYT4OTfFly4Im/8B5f3ojDv1Kx//kiubVY0IQunP2Koc/fr/0wI7hj3IiBDbSrmKlrNgLQ==", 998 | "cpu": [ 999 | "ia32" 1000 | ], 1001 | "dev": true, 1002 | "optional": true, 1003 | "os": [ 1004 | "win32" 1005 | ], 1006 | "engines": { 1007 | "node": ">=12" 1008 | } 1009 | }, 1010 | "node_modules/esbuild-windows-64": { 1011 | "version": "0.14.47", 1012 | "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.47.tgz", 1013 | "integrity": "sha512-/Pk5jIEH34T68r8PweKRi77W49KwanZ8X6lr3vDAtOlH5EumPE4pBHqkCUdELanvsT14yMXLQ/C/8XPi1pAtkQ==", 1014 | "cpu": [ 1015 | "x64" 1016 | ], 1017 | "dev": true, 1018 | "optional": true, 1019 | "os": [ 1020 | "win32" 1021 | ], 1022 | "engines": { 1023 | "node": ">=12" 1024 | } 1025 | }, 1026 | "node_modules/esbuild-windows-arm64": { 1027 | "version": "0.14.47", 1028 | "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.47.tgz", 1029 | "integrity": "sha512-HFSW2lnp62fl86/qPQlqw6asIwCnEsEoNIL1h2uVMgakddf+vUuMcCbtUY1i8sst7KkgHrVKCJQB33YhhOweCQ==", 1030 | "cpu": [ 1031 | "arm64" 1032 | ], 1033 | "dev": true, 1034 | "optional": true, 1035 | "os": [ 1036 | "win32" 1037 | ], 1038 | "engines": { 1039 | "node": ">=12" 1040 | } 1041 | }, 1042 | "node_modules/escape-string-regexp": { 1043 | "version": "4.0.0", 1044 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1045 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1046 | "dev": true, 1047 | "peer": true, 1048 | "engines": { 1049 | "node": ">=10" 1050 | }, 1051 | "funding": { 1052 | "url": "https://github.com/sponsors/sindresorhus" 1053 | } 1054 | }, 1055 | "node_modules/eslint": { 1056 | "version": "8.18.0", 1057 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.18.0.tgz", 1058 | "integrity": "sha512-As1EfFMVk7Xc6/CvhssHUjsAQSkpfXvUGMFC3ce8JDe6WvqCgRrLOBQbVpsBFr1X1V+RACOadnzVvcUS5ni2bA==", 1059 | "dev": true, 1060 | "peer": true, 1061 | "dependencies": { 1062 | "@eslint/eslintrc": "^1.3.0", 1063 | "@humanwhocodes/config-array": "^0.9.2", 1064 | "ajv": "^6.10.0", 1065 | "chalk": "^4.0.0", 1066 | "cross-spawn": "^7.0.2", 1067 | "debug": "^4.3.2", 1068 | "doctrine": "^3.0.0", 1069 | "escape-string-regexp": "^4.0.0", 1070 | "eslint-scope": "^7.1.1", 1071 | "eslint-utils": "^3.0.0", 1072 | "eslint-visitor-keys": "^3.3.0", 1073 | "espree": "^9.3.2", 1074 | "esquery": "^1.4.0", 1075 | "esutils": "^2.0.2", 1076 | "fast-deep-equal": "^3.1.3", 1077 | "file-entry-cache": "^6.0.1", 1078 | "functional-red-black-tree": "^1.0.1", 1079 | "glob-parent": "^6.0.1", 1080 | "globals": "^13.15.0", 1081 | "ignore": "^5.2.0", 1082 | "import-fresh": "^3.0.0", 1083 | "imurmurhash": "^0.1.4", 1084 | "is-glob": "^4.0.0", 1085 | "js-yaml": "^4.1.0", 1086 | "json-stable-stringify-without-jsonify": "^1.0.1", 1087 | "levn": "^0.4.1", 1088 | "lodash.merge": "^4.6.2", 1089 | "minimatch": "^3.1.2", 1090 | "natural-compare": "^1.4.0", 1091 | "optionator": "^0.9.1", 1092 | "regexpp": "^3.2.0", 1093 | "strip-ansi": "^6.0.1", 1094 | "strip-json-comments": "^3.1.0", 1095 | "text-table": "^0.2.0", 1096 | "v8-compile-cache": "^2.0.3" 1097 | }, 1098 | "bin": { 1099 | "eslint": "bin/eslint.js" 1100 | }, 1101 | "engines": { 1102 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1103 | }, 1104 | "funding": { 1105 | "url": "https://opencollective.com/eslint" 1106 | } 1107 | }, 1108 | "node_modules/eslint-scope": { 1109 | "version": "5.1.1", 1110 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 1111 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 1112 | "dev": true, 1113 | "dependencies": { 1114 | "esrecurse": "^4.3.0", 1115 | "estraverse": "^4.1.1" 1116 | }, 1117 | "engines": { 1118 | "node": ">=8.0.0" 1119 | } 1120 | }, 1121 | "node_modules/eslint-utils": { 1122 | "version": "3.0.0", 1123 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 1124 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 1125 | "dev": true, 1126 | "dependencies": { 1127 | "eslint-visitor-keys": "^2.0.0" 1128 | }, 1129 | "engines": { 1130 | "node": "^10.0.0 || ^12.0.0 || >= 14.0.0" 1131 | }, 1132 | "funding": { 1133 | "url": "https://github.com/sponsors/mysticatea" 1134 | }, 1135 | "peerDependencies": { 1136 | "eslint": ">=5" 1137 | } 1138 | }, 1139 | "node_modules/eslint-utils/node_modules/eslint-visitor-keys": { 1140 | "version": "2.1.0", 1141 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 1142 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 1143 | "dev": true, 1144 | "engines": { 1145 | "node": ">=10" 1146 | } 1147 | }, 1148 | "node_modules/eslint-visitor-keys": { 1149 | "version": "3.3.0", 1150 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", 1151 | "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", 1152 | "dev": true, 1153 | "engines": { 1154 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1155 | } 1156 | }, 1157 | "node_modules/eslint/node_modules/eslint-scope": { 1158 | "version": "7.1.1", 1159 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", 1160 | "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", 1161 | "dev": true, 1162 | "peer": true, 1163 | "dependencies": { 1164 | "esrecurse": "^4.3.0", 1165 | "estraverse": "^5.2.0" 1166 | }, 1167 | "engines": { 1168 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1169 | } 1170 | }, 1171 | "node_modules/eslint/node_modules/estraverse": { 1172 | "version": "5.3.0", 1173 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1174 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1175 | "dev": true, 1176 | "peer": true, 1177 | "engines": { 1178 | "node": ">=4.0" 1179 | } 1180 | }, 1181 | "node_modules/espree": { 1182 | "version": "9.3.2", 1183 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.2.tgz", 1184 | "integrity": "sha512-D211tC7ZwouTIuY5x9XnS0E9sWNChB7IYKX/Xp5eQj3nFXhqmiUDB9q27y76oFl8jTg3pXcQx/bpxMfs3CIZbA==", 1185 | "dev": true, 1186 | "peer": true, 1187 | "dependencies": { 1188 | "acorn": "^8.7.1", 1189 | "acorn-jsx": "^5.3.2", 1190 | "eslint-visitor-keys": "^3.3.0" 1191 | }, 1192 | "engines": { 1193 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1194 | } 1195 | }, 1196 | "node_modules/esquery": { 1197 | "version": "1.4.0", 1198 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 1199 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 1200 | "dev": true, 1201 | "peer": true, 1202 | "dependencies": { 1203 | "estraverse": "^5.1.0" 1204 | }, 1205 | "engines": { 1206 | "node": ">=0.10" 1207 | } 1208 | }, 1209 | "node_modules/esquery/node_modules/estraverse": { 1210 | "version": "5.3.0", 1211 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1212 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1213 | "dev": true, 1214 | "peer": true, 1215 | "engines": { 1216 | "node": ">=4.0" 1217 | } 1218 | }, 1219 | "node_modules/esrecurse": { 1220 | "version": "4.3.0", 1221 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1222 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1223 | "dev": true, 1224 | "dependencies": { 1225 | "estraverse": "^5.2.0" 1226 | }, 1227 | "engines": { 1228 | "node": ">=4.0" 1229 | } 1230 | }, 1231 | "node_modules/esrecurse/node_modules/estraverse": { 1232 | "version": "5.3.0", 1233 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1234 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1235 | "dev": true, 1236 | "engines": { 1237 | "node": ">=4.0" 1238 | } 1239 | }, 1240 | "node_modules/estraverse": { 1241 | "version": "4.3.0", 1242 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 1243 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 1244 | "dev": true, 1245 | "engines": { 1246 | "node": ">=4.0" 1247 | } 1248 | }, 1249 | "node_modules/esutils": { 1250 | "version": "2.0.3", 1251 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1252 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1253 | "dev": true, 1254 | "peer": true, 1255 | "engines": { 1256 | "node": ">=0.10.0" 1257 | } 1258 | }, 1259 | "node_modules/fast-deep-equal": { 1260 | "version": "3.1.3", 1261 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1262 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1263 | "dev": true, 1264 | "peer": true 1265 | }, 1266 | "node_modules/fast-glob": { 1267 | "version": "3.2.11", 1268 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.11.tgz", 1269 | "integrity": "sha512-xrO3+1bxSo3ZVHAnqzyuewYT6aMFHRAd4Kcs92MAonjwQZLsK9d0SF1IyQ3k5PoirxTW0Oe/RqFgMQ6TcNE5Ew==", 1270 | "dev": true, 1271 | "dependencies": { 1272 | "@nodelib/fs.stat": "^2.0.2", 1273 | "@nodelib/fs.walk": "^1.2.3", 1274 | "glob-parent": "^5.1.2", 1275 | "merge2": "^1.3.0", 1276 | "micromatch": "^4.0.4" 1277 | }, 1278 | "engines": { 1279 | "node": ">=8.6.0" 1280 | } 1281 | }, 1282 | "node_modules/fast-glob/node_modules/glob-parent": { 1283 | "version": "5.1.2", 1284 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1285 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1286 | "dev": true, 1287 | "dependencies": { 1288 | "is-glob": "^4.0.1" 1289 | }, 1290 | "engines": { 1291 | "node": ">= 6" 1292 | } 1293 | }, 1294 | "node_modules/fast-json-stable-stringify": { 1295 | "version": "2.1.0", 1296 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1297 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1298 | "dev": true, 1299 | "peer": true 1300 | }, 1301 | "node_modules/fast-levenshtein": { 1302 | "version": "2.0.6", 1303 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1304 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1305 | "dev": true, 1306 | "peer": true 1307 | }, 1308 | "node_modules/fastq": { 1309 | "version": "1.13.0", 1310 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", 1311 | "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", 1312 | "dev": true, 1313 | "dependencies": { 1314 | "reusify": "^1.0.4" 1315 | } 1316 | }, 1317 | "node_modules/file-entry-cache": { 1318 | "version": "6.0.1", 1319 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1320 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1321 | "dev": true, 1322 | "peer": true, 1323 | "dependencies": { 1324 | "flat-cache": "^3.0.4" 1325 | }, 1326 | "engines": { 1327 | "node": "^10.12.0 || >=12.0.0" 1328 | } 1329 | }, 1330 | "node_modules/fill-range": { 1331 | "version": "7.0.1", 1332 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1333 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1334 | "dev": true, 1335 | "dependencies": { 1336 | "to-regex-range": "^5.0.1" 1337 | }, 1338 | "engines": { 1339 | "node": ">=8" 1340 | } 1341 | }, 1342 | "node_modules/flat-cache": { 1343 | "version": "3.0.4", 1344 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 1345 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 1346 | "dev": true, 1347 | "peer": true, 1348 | "dependencies": { 1349 | "flatted": "^3.1.0", 1350 | "rimraf": "^3.0.2" 1351 | }, 1352 | "engines": { 1353 | "node": "^10.12.0 || >=12.0.0" 1354 | } 1355 | }, 1356 | "node_modules/flatted": { 1357 | "version": "3.2.5", 1358 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.5.tgz", 1359 | "integrity": "sha512-WIWGi2L3DyTUvUrwRKgGi9TwxQMUEqPOPQBVi71R96jZXJdFskXEmf54BoZaS1kknGODoIGASGEzBUYdyMCBJg==", 1360 | "dev": true, 1361 | "peer": true 1362 | }, 1363 | "node_modules/fs.realpath": { 1364 | "version": "1.0.0", 1365 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1366 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1367 | "dev": true, 1368 | "peer": true 1369 | }, 1370 | "node_modules/functional-red-black-tree": { 1371 | "version": "1.0.1", 1372 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1373 | "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", 1374 | "dev": true 1375 | }, 1376 | "node_modules/glob": { 1377 | "version": "7.2.3", 1378 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1379 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1380 | "dev": true, 1381 | "peer": true, 1382 | "dependencies": { 1383 | "fs.realpath": "^1.0.0", 1384 | "inflight": "^1.0.4", 1385 | "inherits": "2", 1386 | "minimatch": "^3.1.1", 1387 | "once": "^1.3.0", 1388 | "path-is-absolute": "^1.0.0" 1389 | }, 1390 | "engines": { 1391 | "node": "*" 1392 | }, 1393 | "funding": { 1394 | "url": "https://github.com/sponsors/isaacs" 1395 | } 1396 | }, 1397 | "node_modules/glob-parent": { 1398 | "version": "6.0.2", 1399 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1400 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1401 | "dev": true, 1402 | "peer": true, 1403 | "dependencies": { 1404 | "is-glob": "^4.0.3" 1405 | }, 1406 | "engines": { 1407 | "node": ">=10.13.0" 1408 | } 1409 | }, 1410 | "node_modules/globals": { 1411 | "version": "13.15.0", 1412 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.15.0.tgz", 1413 | "integrity": "sha512-bpzcOlgDhMG070Av0Vy5Owklpv1I6+j96GhUI7Rh7IzDCKLzboflLrrfqMu8NquDbiR4EOQk7XzJwqVJxicxog==", 1414 | "dev": true, 1415 | "peer": true, 1416 | "dependencies": { 1417 | "type-fest": "^0.20.2" 1418 | }, 1419 | "engines": { 1420 | "node": ">=8" 1421 | }, 1422 | "funding": { 1423 | "url": "https://github.com/sponsors/sindresorhus" 1424 | } 1425 | }, 1426 | "node_modules/globby": { 1427 | "version": "11.1.0", 1428 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 1429 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 1430 | "dev": true, 1431 | "dependencies": { 1432 | "array-union": "^2.1.0", 1433 | "dir-glob": "^3.0.1", 1434 | "fast-glob": "^3.2.9", 1435 | "ignore": "^5.2.0", 1436 | "merge2": "^1.4.1", 1437 | "slash": "^3.0.0" 1438 | }, 1439 | "engines": { 1440 | "node": ">=10" 1441 | }, 1442 | "funding": { 1443 | "url": "https://github.com/sponsors/sindresorhus" 1444 | } 1445 | }, 1446 | "node_modules/has-flag": { 1447 | "version": "4.0.0", 1448 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1449 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1450 | "dev": true, 1451 | "peer": true, 1452 | "engines": { 1453 | "node": ">=8" 1454 | } 1455 | }, 1456 | "node_modules/ignore": { 1457 | "version": "5.2.0", 1458 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", 1459 | "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", 1460 | "dev": true, 1461 | "engines": { 1462 | "node": ">= 4" 1463 | } 1464 | }, 1465 | "node_modules/immediate": { 1466 | "version": "3.0.6", 1467 | "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.0.6.tgz", 1468 | "integrity": "sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ==", 1469 | "dev": true 1470 | }, 1471 | "node_modules/import-fresh": { 1472 | "version": "3.3.0", 1473 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1474 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1475 | "dev": true, 1476 | "peer": true, 1477 | "dependencies": { 1478 | "parent-module": "^1.0.0", 1479 | "resolve-from": "^4.0.0" 1480 | }, 1481 | "engines": { 1482 | "node": ">=6" 1483 | }, 1484 | "funding": { 1485 | "url": "https://github.com/sponsors/sindresorhus" 1486 | } 1487 | }, 1488 | "node_modules/imurmurhash": { 1489 | "version": "0.1.4", 1490 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1491 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 1492 | "dev": true, 1493 | "peer": true, 1494 | "engines": { 1495 | "node": ">=0.8.19" 1496 | } 1497 | }, 1498 | "node_modules/inflight": { 1499 | "version": "1.0.6", 1500 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1501 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1502 | "dev": true, 1503 | "peer": true, 1504 | "dependencies": { 1505 | "once": "^1.3.0", 1506 | "wrappy": "1" 1507 | } 1508 | }, 1509 | "node_modules/inherits": { 1510 | "version": "2.0.4", 1511 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1512 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1513 | "dev": true, 1514 | "peer": true 1515 | }, 1516 | "node_modules/is-extglob": { 1517 | "version": "2.1.1", 1518 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1519 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1520 | "dev": true, 1521 | "engines": { 1522 | "node": ">=0.10.0" 1523 | } 1524 | }, 1525 | "node_modules/is-glob": { 1526 | "version": "4.0.3", 1527 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1528 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1529 | "dev": true, 1530 | "dependencies": { 1531 | "is-extglob": "^2.1.1" 1532 | }, 1533 | "engines": { 1534 | "node": ">=0.10.0" 1535 | } 1536 | }, 1537 | "node_modules/is-number": { 1538 | "version": "7.0.0", 1539 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1540 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1541 | "dev": true, 1542 | "engines": { 1543 | "node": ">=0.12.0" 1544 | } 1545 | }, 1546 | "node_modules/isexe": { 1547 | "version": "2.0.0", 1548 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1549 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1550 | "dev": true, 1551 | "peer": true 1552 | }, 1553 | "node_modules/js-yaml": { 1554 | "version": "4.1.0", 1555 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1556 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1557 | "dev": true, 1558 | "peer": true, 1559 | "dependencies": { 1560 | "argparse": "^2.0.1" 1561 | }, 1562 | "bin": { 1563 | "js-yaml": "bin/js-yaml.js" 1564 | } 1565 | }, 1566 | "node_modules/json-schema-traverse": { 1567 | "version": "0.4.1", 1568 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1569 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1570 | "dev": true, 1571 | "peer": true 1572 | }, 1573 | "node_modules/json-stable-stringify-without-jsonify": { 1574 | "version": "1.0.1", 1575 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1576 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 1577 | "dev": true, 1578 | "peer": true 1579 | }, 1580 | "node_modules/levn": { 1581 | "version": "0.4.1", 1582 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1583 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1584 | "dev": true, 1585 | "peer": true, 1586 | "dependencies": { 1587 | "prelude-ls": "^1.2.1", 1588 | "type-check": "~0.4.0" 1589 | }, 1590 | "engines": { 1591 | "node": ">= 0.8.0" 1592 | } 1593 | }, 1594 | "node_modules/lie": { 1595 | "version": "3.1.1", 1596 | "resolved": "https://registry.npmjs.org/lie/-/lie-3.1.1.tgz", 1597 | "integrity": "sha512-RiNhHysUjhrDQntfYSfY4MU24coXXdEOgw9WGcKHNeEwffDYbF//u87M1EWaMGzuFoSbqW0C9C6lEEhDOAswfw==", 1598 | "dev": true, 1599 | "dependencies": { 1600 | "immediate": "~3.0.5" 1601 | } 1602 | }, 1603 | "node_modules/localforage": { 1604 | "version": "1.10.0", 1605 | "resolved": "https://registry.npmjs.org/localforage/-/localforage-1.10.0.tgz", 1606 | "integrity": "sha512-14/H1aX7hzBBmmh7sGPd+AOMkkIrHM3Z1PAyGgZigA1H1p5O5ANnMyWzvpAETtG68/dC4pC0ncy3+PPGzXZHPg==", 1607 | "dev": true, 1608 | "dependencies": { 1609 | "lie": "3.1.1" 1610 | } 1611 | }, 1612 | "node_modules/lodash.merge": { 1613 | "version": "4.6.2", 1614 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1615 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1616 | "dev": true, 1617 | "peer": true 1618 | }, 1619 | "node_modules/lru-cache": { 1620 | "version": "6.0.0", 1621 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1622 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1623 | "dev": true, 1624 | "dependencies": { 1625 | "yallist": "^4.0.0" 1626 | }, 1627 | "engines": { 1628 | "node": ">=10" 1629 | } 1630 | }, 1631 | "node_modules/luxon": { 1632 | "version": "2.4.0", 1633 | "resolved": "https://registry.npmjs.org/luxon/-/luxon-2.4.0.tgz", 1634 | "integrity": "sha512-w+NAwWOUL5hO0SgwOHsMBAmZ15SoknmQXhSO0hIbJCAmPKSsGeK8MlmhYh2w6Iib38IxN2M+/ooXWLbeis7GuA==", 1635 | "dev": true, 1636 | "engines": { 1637 | "node": ">=12" 1638 | } 1639 | }, 1640 | "node_modules/merge2": { 1641 | "version": "1.4.1", 1642 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1643 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1644 | "dev": true, 1645 | "engines": { 1646 | "node": ">= 8" 1647 | } 1648 | }, 1649 | "node_modules/micromatch": { 1650 | "version": "4.0.5", 1651 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1652 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1653 | "dev": true, 1654 | "dependencies": { 1655 | "braces": "^3.0.2", 1656 | "picomatch": "^2.3.1" 1657 | }, 1658 | "engines": { 1659 | "node": ">=8.6" 1660 | } 1661 | }, 1662 | "node_modules/minimatch": { 1663 | "version": "3.1.2", 1664 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1665 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1666 | "dev": true, 1667 | "peer": true, 1668 | "dependencies": { 1669 | "brace-expansion": "^1.1.7" 1670 | }, 1671 | "engines": { 1672 | "node": "*" 1673 | } 1674 | }, 1675 | "node_modules/moment": { 1676 | "version": "2.29.3", 1677 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.3.tgz", 1678 | "integrity": "sha512-c6YRvhEo//6T2Jz/vVtYzqBzwvPT95JBQ+smCytzf7c50oMZRsR/a4w88aD34I+/QVSfnoAnSBFPJHItlOMJVw==", 1679 | "dev": true, 1680 | "engines": { 1681 | "node": "*" 1682 | } 1683 | }, 1684 | "node_modules/ms": { 1685 | "version": "2.1.2", 1686 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1687 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1688 | "dev": true 1689 | }, 1690 | "node_modules/natural-compare": { 1691 | "version": "1.4.0", 1692 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1693 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 1694 | "dev": true, 1695 | "peer": true 1696 | }, 1697 | "node_modules/obsidian": { 1698 | "version": "1.5.7-1", 1699 | "resolved": "https://registry.npmjs.org/obsidian/-/obsidian-1.5.7-1.tgz", 1700 | "integrity": "sha512-T5ZRuQ1FnfXqEoakTTHVDYvzUEEoT8zSPnQCW31PVgYwG4D4tZCQfKHN2hTz1ifnCe8upvwa6mBTAP2WUA5Vng==", 1701 | "dev": true, 1702 | "dependencies": { 1703 | "@types/codemirror": "5.60.8", 1704 | "moment": "2.29.4" 1705 | }, 1706 | "peerDependencies": { 1707 | "@codemirror/state": "^6.0.0", 1708 | "@codemirror/view": "^6.0.0" 1709 | } 1710 | }, 1711 | "node_modules/obsidian-calendar-ui": { 1712 | "version": "0.3.12", 1713 | "resolved": "https://registry.npmjs.org/obsidian-calendar-ui/-/obsidian-calendar-ui-0.3.12.tgz", 1714 | "integrity": "sha512-hdoRqCPnukfRgCARgArXaqMQZ+Iai0eY7f0ZsFHHfywpv4gKg3Tx5p47UsLvRO5DD+4knlbrL7Gel57MkfcLTw==", 1715 | "dev": true, 1716 | "dependencies": { 1717 | "obsidian-daily-notes-interface": "0.8.4", 1718 | "svelte": "3.35.0", 1719 | "tslib": "2.1.0" 1720 | } 1721 | }, 1722 | "node_modules/obsidian-calendar-ui/node_modules/tslib": { 1723 | "version": "2.1.0", 1724 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.1.0.tgz", 1725 | "integrity": "sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A==", 1726 | "dev": true 1727 | }, 1728 | "node_modules/obsidian-daily-notes-interface": { 1729 | "version": "0.8.4", 1730 | "resolved": "https://registry.npmjs.org/obsidian-daily-notes-interface/-/obsidian-daily-notes-interface-0.8.4.tgz", 1731 | "integrity": "sha512-REKQtAuIOKDbvNH/th1C1gWmJWCP5tRn9T/mfZGZt4Zncgko7McXK0aSKFtEInipvgbZJ2nScivvyLdiWluSMw==", 1732 | "dev": true, 1733 | "dependencies": { 1734 | "obsidian": "github:obsidianmd/obsidian-api#master", 1735 | "tslib": "2.1.0" 1736 | }, 1737 | "bin": { 1738 | "obsidian-daily-notes-interface": "dist/main.js" 1739 | } 1740 | }, 1741 | "node_modules/obsidian-daily-notes-interface/node_modules/obsidian": { 1742 | "version": "0.15.3", 1743 | "resolved": "git+ssh://git@github.com/obsidianmd/obsidian-api.git#d4b79f95ccf3838a305915a137a844250766d023", 1744 | "dev": true, 1745 | "license": "MIT", 1746 | "dependencies": { 1747 | "@types/codemirror": "0.0.108", 1748 | "moment": "2.29.3" 1749 | }, 1750 | "peerDependencies": { 1751 | "@codemirror/state": "^6.0.0", 1752 | "@codemirror/view": "^6.0.0" 1753 | } 1754 | }, 1755 | "node_modules/obsidian-daily-notes-interface/node_modules/tslib": { 1756 | "version": "2.1.0", 1757 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.1.0.tgz", 1758 | "integrity": "sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A==", 1759 | "dev": true 1760 | }, 1761 | "node_modules/obsidian-dataview": { 1762 | "version": "0.5.46", 1763 | "resolved": "https://registry.npmjs.org/obsidian-dataview/-/obsidian-dataview-0.5.46.tgz", 1764 | "integrity": "sha512-/y5NjL4w1kLdwO515nyzPXmYqYSw9Z6G5uV0YXdBgjE1sKUUeJANOQKAaKmbD010BgHjzkEjfbgJxIr7dbgIGw==", 1765 | "dev": true, 1766 | "dependencies": { 1767 | "@codemirror/language": "git+https://github.com/lishid/cm-language.git", 1768 | "@codemirror/state": "^6.0.1", 1769 | "@codemirror/view": "^6.0.1", 1770 | "emoji-regex": "^10.0.0", 1771 | "localforage": "^1.10.0", 1772 | "luxon": "^2.4.0", 1773 | "obsidian-calendar-ui": "^0.3.12", 1774 | "papaparse": "^5.3.1", 1775 | "parsimmon": "^1.18.0", 1776 | "preact": "^10.6.5" 1777 | } 1778 | }, 1779 | "node_modules/obsidian/node_modules/@types/codemirror": { 1780 | "version": "5.60.8", 1781 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-5.60.8.tgz", 1782 | "integrity": "sha512-VjFgDF/eB+Aklcy15TtOTLQeMjTo07k7KAjql8OK5Dirr7a6sJY4T1uVBDuTVG9VEmn1uUsohOpYnVfgC6/jyw==", 1783 | "dev": true, 1784 | "dependencies": { 1785 | "@types/tern": "*" 1786 | } 1787 | }, 1788 | "node_modules/obsidian/node_modules/moment": { 1789 | "version": "2.29.4", 1790 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 1791 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 1792 | "dev": true, 1793 | "engines": { 1794 | "node": "*" 1795 | } 1796 | }, 1797 | "node_modules/once": { 1798 | "version": "1.4.0", 1799 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1800 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1801 | "dev": true, 1802 | "peer": true, 1803 | "dependencies": { 1804 | "wrappy": "1" 1805 | } 1806 | }, 1807 | "node_modules/optionator": { 1808 | "version": "0.9.1", 1809 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 1810 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 1811 | "dev": true, 1812 | "peer": true, 1813 | "dependencies": { 1814 | "deep-is": "^0.1.3", 1815 | "fast-levenshtein": "^2.0.6", 1816 | "levn": "^0.4.1", 1817 | "prelude-ls": "^1.2.1", 1818 | "type-check": "^0.4.0", 1819 | "word-wrap": "^1.2.3" 1820 | }, 1821 | "engines": { 1822 | "node": ">= 0.8.0" 1823 | } 1824 | }, 1825 | "node_modules/papaparse": { 1826 | "version": "5.3.2", 1827 | "resolved": "https://registry.npmjs.org/papaparse/-/papaparse-5.3.2.tgz", 1828 | "integrity": "sha512-6dNZu0Ki+gyV0eBsFKJhYr+MdQYAzFUGlBMNj3GNrmHxmz1lfRa24CjFObPXtjcetlOv5Ad299MhIK0znp3afw==", 1829 | "dev": true 1830 | }, 1831 | "node_modules/parent-module": { 1832 | "version": "1.0.1", 1833 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1834 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1835 | "dev": true, 1836 | "peer": true, 1837 | "dependencies": { 1838 | "callsites": "^3.0.0" 1839 | }, 1840 | "engines": { 1841 | "node": ">=6" 1842 | } 1843 | }, 1844 | "node_modules/parsimmon": { 1845 | "version": "1.18.1", 1846 | "resolved": "https://registry.npmjs.org/parsimmon/-/parsimmon-1.18.1.tgz", 1847 | "integrity": "sha512-u7p959wLfGAhJpSDJVYXoyMCXWYwHia78HhRBWqk7AIbxdmlrfdp5wX0l3xv/iTSH5HvhN9K7o26hwwpgS5Nmw==", 1848 | "dev": true 1849 | }, 1850 | "node_modules/path-is-absolute": { 1851 | "version": "1.0.1", 1852 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1853 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1854 | "dev": true, 1855 | "peer": true, 1856 | "engines": { 1857 | "node": ">=0.10.0" 1858 | } 1859 | }, 1860 | "node_modules/path-key": { 1861 | "version": "3.1.1", 1862 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1863 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1864 | "dev": true, 1865 | "peer": true, 1866 | "engines": { 1867 | "node": ">=8" 1868 | } 1869 | }, 1870 | "node_modules/path-type": { 1871 | "version": "4.0.0", 1872 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1873 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1874 | "dev": true, 1875 | "engines": { 1876 | "node": ">=8" 1877 | } 1878 | }, 1879 | "node_modules/picomatch": { 1880 | "version": "2.3.1", 1881 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1882 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1883 | "dev": true, 1884 | "engines": { 1885 | "node": ">=8.6" 1886 | }, 1887 | "funding": { 1888 | "url": "https://github.com/sponsors/jonschlinkert" 1889 | } 1890 | }, 1891 | "node_modules/preact": { 1892 | "version": "10.8.2", 1893 | "resolved": "https://registry.npmjs.org/preact/-/preact-10.8.2.tgz", 1894 | "integrity": "sha512-AKGt0BsDSiAYzVS78jZ9qRwuorY2CoSZtf1iOC6gLb/3QyZt+fLT09aYJBjRc/BEcRc4j+j3ggERMdNE43i1LQ==", 1895 | "dev": true, 1896 | "funding": { 1897 | "type": "opencollective", 1898 | "url": "https://opencollective.com/preact" 1899 | } 1900 | }, 1901 | "node_modules/prelude-ls": { 1902 | "version": "1.2.1", 1903 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1904 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1905 | "dev": true, 1906 | "peer": true, 1907 | "engines": { 1908 | "node": ">= 0.8.0" 1909 | } 1910 | }, 1911 | "node_modules/punycode": { 1912 | "version": "2.1.1", 1913 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1914 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1915 | "dev": true, 1916 | "peer": true, 1917 | "engines": { 1918 | "node": ">=6" 1919 | } 1920 | }, 1921 | "node_modules/queue-microtask": { 1922 | "version": "1.2.3", 1923 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1924 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1925 | "dev": true, 1926 | "funding": [ 1927 | { 1928 | "type": "github", 1929 | "url": "https://github.com/sponsors/feross" 1930 | }, 1931 | { 1932 | "type": "patreon", 1933 | "url": "https://www.patreon.com/feross" 1934 | }, 1935 | { 1936 | "type": "consulting", 1937 | "url": "https://feross.org/support" 1938 | } 1939 | ] 1940 | }, 1941 | "node_modules/regexpp": { 1942 | "version": "3.2.0", 1943 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 1944 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 1945 | "dev": true, 1946 | "engines": { 1947 | "node": ">=8" 1948 | }, 1949 | "funding": { 1950 | "url": "https://github.com/sponsors/mysticatea" 1951 | } 1952 | }, 1953 | "node_modules/resolve-from": { 1954 | "version": "4.0.0", 1955 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1956 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1957 | "dev": true, 1958 | "peer": true, 1959 | "engines": { 1960 | "node": ">=4" 1961 | } 1962 | }, 1963 | "node_modules/reusify": { 1964 | "version": "1.0.4", 1965 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1966 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1967 | "dev": true, 1968 | "engines": { 1969 | "iojs": ">=1.0.0", 1970 | "node": ">=0.10.0" 1971 | } 1972 | }, 1973 | "node_modules/rimraf": { 1974 | "version": "3.0.2", 1975 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1976 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1977 | "dev": true, 1978 | "peer": true, 1979 | "dependencies": { 1980 | "glob": "^7.1.3" 1981 | }, 1982 | "bin": { 1983 | "rimraf": "bin.js" 1984 | }, 1985 | "funding": { 1986 | "url": "https://github.com/sponsors/isaacs" 1987 | } 1988 | }, 1989 | "node_modules/run-parallel": { 1990 | "version": "1.2.0", 1991 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 1992 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 1993 | "dev": true, 1994 | "funding": [ 1995 | { 1996 | "type": "github", 1997 | "url": "https://github.com/sponsors/feross" 1998 | }, 1999 | { 2000 | "type": "patreon", 2001 | "url": "https://www.patreon.com/feross" 2002 | }, 2003 | { 2004 | "type": "consulting", 2005 | "url": "https://feross.org/support" 2006 | } 2007 | ], 2008 | "dependencies": { 2009 | "queue-microtask": "^1.2.2" 2010 | } 2011 | }, 2012 | "node_modules/semver": { 2013 | "version": "7.3.7", 2014 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", 2015 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", 2016 | "dev": true, 2017 | "dependencies": { 2018 | "lru-cache": "^6.0.0" 2019 | }, 2020 | "bin": { 2021 | "semver": "bin/semver.js" 2022 | }, 2023 | "engines": { 2024 | "node": ">=10" 2025 | } 2026 | }, 2027 | "node_modules/shebang-command": { 2028 | "version": "2.0.0", 2029 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2030 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2031 | "dev": true, 2032 | "peer": true, 2033 | "dependencies": { 2034 | "shebang-regex": "^3.0.0" 2035 | }, 2036 | "engines": { 2037 | "node": ">=8" 2038 | } 2039 | }, 2040 | "node_modules/shebang-regex": { 2041 | "version": "3.0.0", 2042 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2043 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2044 | "dev": true, 2045 | "peer": true, 2046 | "engines": { 2047 | "node": ">=8" 2048 | } 2049 | }, 2050 | "node_modules/slash": { 2051 | "version": "3.0.0", 2052 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2053 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2054 | "dev": true, 2055 | "engines": { 2056 | "node": ">=8" 2057 | } 2058 | }, 2059 | "node_modules/strip-ansi": { 2060 | "version": "6.0.1", 2061 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2062 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2063 | "dev": true, 2064 | "peer": true, 2065 | "dependencies": { 2066 | "ansi-regex": "^5.0.1" 2067 | }, 2068 | "engines": { 2069 | "node": ">=8" 2070 | } 2071 | }, 2072 | "node_modules/strip-json-comments": { 2073 | "version": "3.1.1", 2074 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2075 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2076 | "dev": true, 2077 | "peer": true, 2078 | "engines": { 2079 | "node": ">=8" 2080 | }, 2081 | "funding": { 2082 | "url": "https://github.com/sponsors/sindresorhus" 2083 | } 2084 | }, 2085 | "node_modules/style-mod": { 2086 | "version": "4.0.0", 2087 | "resolved": "https://registry.npmjs.org/style-mod/-/style-mod-4.0.0.tgz", 2088 | "integrity": "sha512-OPhtyEjyyN9x3nhPsu76f52yUGXiZcgvsrFVtvTkyGRQJ0XK+GPc6ov1z+lRpbeabka+MYEQxOYRnt5nF30aMw==", 2089 | "dev": true 2090 | }, 2091 | "node_modules/supports-color": { 2092 | "version": "7.2.0", 2093 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2094 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2095 | "dev": true, 2096 | "peer": true, 2097 | "dependencies": { 2098 | "has-flag": "^4.0.0" 2099 | }, 2100 | "engines": { 2101 | "node": ">=8" 2102 | } 2103 | }, 2104 | "node_modules/svelte": { 2105 | "version": "3.35.0", 2106 | "resolved": "https://registry.npmjs.org/svelte/-/svelte-3.35.0.tgz", 2107 | "integrity": "sha512-gknlZkR2sXheu/X+B7dDImwANVvK1R0QGQLd8CNIfxxGPeXBmePnxfzb6fWwTQRsYQG7lYkZXvpXJvxvpsoB7g==", 2108 | "dev": true, 2109 | "engines": { 2110 | "node": ">= 8" 2111 | } 2112 | }, 2113 | "node_modules/text-table": { 2114 | "version": "0.2.0", 2115 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2116 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 2117 | "dev": true, 2118 | "peer": true 2119 | }, 2120 | "node_modules/to-regex-range": { 2121 | "version": "5.0.1", 2122 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2123 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2124 | "dev": true, 2125 | "dependencies": { 2126 | "is-number": "^7.0.0" 2127 | }, 2128 | "engines": { 2129 | "node": ">=8.0" 2130 | } 2131 | }, 2132 | "node_modules/tslib": { 2133 | "version": "2.4.0", 2134 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz", 2135 | "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==", 2136 | "dev": true 2137 | }, 2138 | "node_modules/type-check": { 2139 | "version": "0.4.0", 2140 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2141 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2142 | "dev": true, 2143 | "peer": true, 2144 | "dependencies": { 2145 | "prelude-ls": "^1.2.1" 2146 | }, 2147 | "engines": { 2148 | "node": ">= 0.8.0" 2149 | } 2150 | }, 2151 | "node_modules/type-fest": { 2152 | "version": "0.20.2", 2153 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2154 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2155 | "dev": true, 2156 | "peer": true, 2157 | "engines": { 2158 | "node": ">=10" 2159 | }, 2160 | "funding": { 2161 | "url": "https://github.com/sponsors/sindresorhus" 2162 | } 2163 | }, 2164 | "node_modules/typescript": { 2165 | "version": "4.7.4", 2166 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.7.4.tgz", 2167 | "integrity": "sha512-C0WQT0gezHuw6AdY1M2jxUO83Rjf0HP7Sk1DtXj6j1EwkQNZrHAg2XPWlq62oqEhYvONq5pkC2Y9oPljWToLmQ==", 2168 | "dev": true, 2169 | "bin": { 2170 | "tsc": "bin/tsc", 2171 | "tsserver": "bin/tsserver" 2172 | }, 2173 | "engines": { 2174 | "node": ">=4.2.0" 2175 | } 2176 | }, 2177 | "node_modules/uri-js": { 2178 | "version": "4.4.1", 2179 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2180 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2181 | "dev": true, 2182 | "peer": true, 2183 | "dependencies": { 2184 | "punycode": "^2.1.0" 2185 | } 2186 | }, 2187 | "node_modules/v8-compile-cache": { 2188 | "version": "2.3.0", 2189 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 2190 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 2191 | "dev": true, 2192 | "peer": true 2193 | }, 2194 | "node_modules/w3c-keyname": { 2195 | "version": "2.2.4", 2196 | "resolved": "https://registry.npmjs.org/w3c-keyname/-/w3c-keyname-2.2.4.tgz", 2197 | "integrity": "sha512-tOhfEwEzFLJzf6d1ZPkYfGj+FWhIpBux9ppoP3rlclw3Z0BZv3N7b7030Z1kYth+6rDuAsXUFr+d0VE6Ed1ikw==", 2198 | "dev": true 2199 | }, 2200 | "node_modules/which": { 2201 | "version": "2.0.2", 2202 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2203 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2204 | "dev": true, 2205 | "peer": true, 2206 | "dependencies": { 2207 | "isexe": "^2.0.0" 2208 | }, 2209 | "bin": { 2210 | "node-which": "bin/node-which" 2211 | }, 2212 | "engines": { 2213 | "node": ">= 8" 2214 | } 2215 | }, 2216 | "node_modules/word-wrap": { 2217 | "version": "1.2.3", 2218 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2219 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2220 | "dev": true, 2221 | "peer": true, 2222 | "engines": { 2223 | "node": ">=0.10.0" 2224 | } 2225 | }, 2226 | "node_modules/wrappy": { 2227 | "version": "1.0.2", 2228 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2229 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 2230 | "dev": true, 2231 | "peer": true 2232 | }, 2233 | "node_modules/yallist": { 2234 | "version": "4.0.0", 2235 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2236 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2237 | "dev": true 2238 | } 2239 | }, 2240 | "dependencies": { 2241 | "@codemirror/language": { 2242 | "version": "git+ssh://git@github.com/lishid/cm-language.git#073afd8e6bc4d8e5cf6170a50f9b668a98c39f1c", 2243 | "dev": true, 2244 | "from": "@codemirror/language@git+https://github.com/lishid/cm-language.git", 2245 | "requires": { 2246 | "@codemirror/state": "^6.0.0", 2247 | "@codemirror/view": "^6.0.0", 2248 | "@lezer/common": "^1.0.0", 2249 | "@lezer/highlight": "^1.0.0", 2250 | "@lezer/lr": "^1.0.0", 2251 | "style-mod": "^4.0.0" 2252 | } 2253 | }, 2254 | "@codemirror/state": { 2255 | "version": "6.0.1", 2256 | "resolved": "https://registry.npmjs.org/@codemirror/state/-/state-6.0.1.tgz", 2257 | "integrity": "sha512-6vYgaXc4KjSY0BUfSVDJooGcoswg/RJZpq/ZGjsUYmY0KN1lmB8u03nv+jiG1ncUV5qoggyxFT5AGD5Ak+5Zrw==", 2258 | "dev": true 2259 | }, 2260 | "@codemirror/view": { 2261 | "version": "6.0.2", 2262 | "resolved": "https://registry.npmjs.org/@codemirror/view/-/view-6.0.2.tgz", 2263 | "integrity": "sha512-mnVT/q1JvKPjpmjXJNeCi/xHyaJ3abGJsumIVpdQ1nE1MXAyHf7GHWt8QpWMUvDiqF0j+inkhVR2OviTdFFX7Q==", 2264 | "dev": true, 2265 | "requires": { 2266 | "@codemirror/state": "^6.0.0", 2267 | "style-mod": "^4.0.0", 2268 | "w3c-keyname": "^2.2.4" 2269 | } 2270 | }, 2271 | "@eslint/eslintrc": { 2272 | "version": "1.3.0", 2273 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.3.0.tgz", 2274 | "integrity": "sha512-UWW0TMTmk2d7hLcWD1/e2g5HDM/HQ3csaLSqXCfqwh4uNDuNqlaKWXmEsL4Cs41Z0KnILNvwbHAah3C2yt06kw==", 2275 | "dev": true, 2276 | "peer": true, 2277 | "requires": { 2278 | "ajv": "^6.12.4", 2279 | "debug": "^4.3.2", 2280 | "espree": "^9.3.2", 2281 | "globals": "^13.15.0", 2282 | "ignore": "^5.2.0", 2283 | "import-fresh": "^3.2.1", 2284 | "js-yaml": "^4.1.0", 2285 | "minimatch": "^3.1.2", 2286 | "strip-json-comments": "^3.1.1" 2287 | } 2288 | }, 2289 | "@humanwhocodes/config-array": { 2290 | "version": "0.9.5", 2291 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.9.5.tgz", 2292 | "integrity": "sha512-ObyMyWxZiCu/yTisA7uzx81s40xR2fD5Cg/2Kq7G02ajkNubJf6BopgDTmDyc3U7sXpNKM8cYOw7s7Tyr+DnCw==", 2293 | "dev": true, 2294 | "peer": true, 2295 | "requires": { 2296 | "@humanwhocodes/object-schema": "^1.2.1", 2297 | "debug": "^4.1.1", 2298 | "minimatch": "^3.0.4" 2299 | } 2300 | }, 2301 | "@humanwhocodes/object-schema": { 2302 | "version": "1.2.1", 2303 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", 2304 | "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", 2305 | "dev": true, 2306 | "peer": true 2307 | }, 2308 | "@lezer/common": { 2309 | "version": "1.0.1", 2310 | "resolved": "https://registry.npmjs.org/@lezer/common/-/common-1.0.1.tgz", 2311 | "integrity": "sha512-8TR5++Q/F//tpDsLd5zkrvEX5xxeemafEaek7mUp7Y+bI8cKQXdSqhzTOBaOogETcMOVr0pT3BBPXp13477ciw==", 2312 | "dev": true 2313 | }, 2314 | "@lezer/highlight": { 2315 | "version": "1.1.1", 2316 | "resolved": "https://registry.npmjs.org/@lezer/highlight/-/highlight-1.1.1.tgz", 2317 | "integrity": "sha512-duv9D23O9ghEDnnUDmxu+L8pJy4nYo4AbCOHIudUhscrLSazqeJeK1V50EU6ZufWF1zv0KJwu/frFRyZWXxHBQ==", 2318 | "dev": true, 2319 | "requires": { 2320 | "@lezer/common": "^1.0.0" 2321 | } 2322 | }, 2323 | "@lezer/lr": { 2324 | "version": "1.2.3", 2325 | "resolved": "https://registry.npmjs.org/@lezer/lr/-/lr-1.2.3.tgz", 2326 | "integrity": "sha512-qpB7rBzH8f6Mzjv2AVZRahcm+2Cf7nbIH++uXbvVOL1yIRvVWQ3HAM/saeBLCyz/togB7LGo76qdJYL1uKQlqA==", 2327 | "dev": true, 2328 | "requires": { 2329 | "@lezer/common": "^1.0.0" 2330 | } 2331 | }, 2332 | "@nodelib/fs.scandir": { 2333 | "version": "2.1.5", 2334 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 2335 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 2336 | "dev": true, 2337 | "requires": { 2338 | "@nodelib/fs.stat": "2.0.5", 2339 | "run-parallel": "^1.1.9" 2340 | } 2341 | }, 2342 | "@nodelib/fs.stat": { 2343 | "version": "2.0.5", 2344 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 2345 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 2346 | "dev": true 2347 | }, 2348 | "@nodelib/fs.walk": { 2349 | "version": "1.2.8", 2350 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 2351 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 2352 | "dev": true, 2353 | "requires": { 2354 | "@nodelib/fs.scandir": "2.1.5", 2355 | "fastq": "^1.6.0" 2356 | } 2357 | }, 2358 | "@types/codemirror": { 2359 | "version": "0.0.108", 2360 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.108.tgz", 2361 | "integrity": "sha512-3FGFcus0P7C2UOGCNUVENqObEb4SFk+S8Dnxq7K6aIsLVs/vDtlangl3PEO0ykaKXyK56swVF6Nho7VsA44uhw==", 2362 | "dev": true, 2363 | "requires": { 2364 | "@types/tern": "*" 2365 | } 2366 | }, 2367 | "@types/estree": { 2368 | "version": "0.0.52", 2369 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.52.tgz", 2370 | "integrity": "sha512-BZWrtCU0bMVAIliIV+HJO1f1PR41M7NKjfxrFJwwhKI1KwhwOxYw1SXg9ao+CIMt774nFuGiG6eU+udtbEI9oQ==", 2371 | "dev": true 2372 | }, 2373 | "@types/json-schema": { 2374 | "version": "7.0.11", 2375 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", 2376 | "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==", 2377 | "dev": true 2378 | }, 2379 | "@types/node": { 2380 | "version": "16.18.87", 2381 | "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.87.tgz", 2382 | "integrity": "sha512-+IzfhNirR/MDbXz6Om5eHV54D9mQlEMGag6AgEzlju0xH3M8baCXYwqQ6RKgGMpn9wSTx6Ltya/0y4Z8eSfdLw==", 2383 | "dev": true 2384 | }, 2385 | "@types/tern": { 2386 | "version": "0.23.4", 2387 | "resolved": "https://registry.npmjs.org/@types/tern/-/tern-0.23.4.tgz", 2388 | "integrity": "sha512-JAUw1iXGO1qaWwEOzxTKJZ/5JxVeON9kvGZ/osgZaJImBnyjyn0cjovPsf6FNLmyGY8Vw9DoXZCMlfMkMwHRWg==", 2389 | "dev": true, 2390 | "requires": { 2391 | "@types/estree": "*" 2392 | } 2393 | }, 2394 | "@typescript-eslint/eslint-plugin": { 2395 | "version": "5.29.0", 2396 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.29.0.tgz", 2397 | "integrity": "sha512-kgTsISt9pM53yRFQmLZ4npj99yGl3x3Pl7z4eA66OuTzAGC4bQB5H5fuLwPnqTKU3yyrrg4MIhjF17UYnL4c0w==", 2398 | "dev": true, 2399 | "requires": { 2400 | "@typescript-eslint/scope-manager": "5.29.0", 2401 | "@typescript-eslint/type-utils": "5.29.0", 2402 | "@typescript-eslint/utils": "5.29.0", 2403 | "debug": "^4.3.4", 2404 | "functional-red-black-tree": "^1.0.1", 2405 | "ignore": "^5.2.0", 2406 | "regexpp": "^3.2.0", 2407 | "semver": "^7.3.7", 2408 | "tsutils": "^3.21.0" 2409 | }, 2410 | "dependencies": { 2411 | "tslib": { 2412 | "version": "1.14.1", 2413 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2414 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2415 | "dev": true 2416 | }, 2417 | "tsutils": { 2418 | "version": "3.21.0", 2419 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 2420 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 2421 | "dev": true, 2422 | "requires": { 2423 | "tslib": "^1.8.1" 2424 | } 2425 | } 2426 | } 2427 | }, 2428 | "@typescript-eslint/parser": { 2429 | "version": "5.29.0", 2430 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.29.0.tgz", 2431 | "integrity": "sha512-ruKWTv+x0OOxbzIw9nW5oWlUopvP/IQDjB5ZqmTglLIoDTctLlAJpAQFpNPJP/ZI7hTT9sARBosEfaKbcFuECw==", 2432 | "dev": true, 2433 | "requires": { 2434 | "@typescript-eslint/scope-manager": "5.29.0", 2435 | "@typescript-eslint/types": "5.29.0", 2436 | "@typescript-eslint/typescript-estree": "5.29.0", 2437 | "debug": "^4.3.4" 2438 | } 2439 | }, 2440 | "@typescript-eslint/scope-manager": { 2441 | "version": "5.29.0", 2442 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.29.0.tgz", 2443 | "integrity": "sha512-etbXUT0FygFi2ihcxDZjz21LtC+Eps9V2xVx09zFoN44RRHPrkMflidGMI+2dUs821zR1tDS6Oc9IXxIjOUZwA==", 2444 | "dev": true, 2445 | "requires": { 2446 | "@typescript-eslint/types": "5.29.0", 2447 | "@typescript-eslint/visitor-keys": "5.29.0" 2448 | } 2449 | }, 2450 | "@typescript-eslint/type-utils": { 2451 | "version": "5.29.0", 2452 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.29.0.tgz", 2453 | "integrity": "sha512-JK6bAaaiJozbox3K220VRfCzLa9n0ib/J+FHIwnaV3Enw/TO267qe0pM1b1QrrEuy6xun374XEAsRlA86JJnyg==", 2454 | "dev": true, 2455 | "requires": { 2456 | "@typescript-eslint/utils": "5.29.0", 2457 | "debug": "^4.3.4", 2458 | "tsutils": "^3.21.0" 2459 | }, 2460 | "dependencies": { 2461 | "tslib": { 2462 | "version": "1.14.1", 2463 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2464 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2465 | "dev": true 2466 | }, 2467 | "tsutils": { 2468 | "version": "3.21.0", 2469 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 2470 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 2471 | "dev": true, 2472 | "requires": { 2473 | "tslib": "^1.8.1" 2474 | } 2475 | } 2476 | } 2477 | }, 2478 | "@typescript-eslint/types": { 2479 | "version": "5.29.0", 2480 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.29.0.tgz", 2481 | "integrity": "sha512-X99VbqvAXOMdVyfFmksMy3u8p8yoRGITgU1joBJPzeYa0rhdf5ok9S56/itRoUSh99fiDoMtarSIJXo7H/SnOg==", 2482 | "dev": true 2483 | }, 2484 | "@typescript-eslint/typescript-estree": { 2485 | "version": "5.29.0", 2486 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.29.0.tgz", 2487 | "integrity": "sha512-mQvSUJ/JjGBdvo+1LwC+GY2XmSYjK1nAaVw2emp/E61wEVYEyibRHCqm1I1vEKbXCpUKuW4G7u9ZCaZhJbLoNQ==", 2488 | "dev": true, 2489 | "requires": { 2490 | "@typescript-eslint/types": "5.29.0", 2491 | "@typescript-eslint/visitor-keys": "5.29.0", 2492 | "debug": "^4.3.4", 2493 | "globby": "^11.1.0", 2494 | "is-glob": "^4.0.3", 2495 | "semver": "^7.3.7", 2496 | "tsutils": "^3.21.0" 2497 | }, 2498 | "dependencies": { 2499 | "tslib": { 2500 | "version": "1.14.1", 2501 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", 2502 | "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", 2503 | "dev": true 2504 | }, 2505 | "tsutils": { 2506 | "version": "3.21.0", 2507 | "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", 2508 | "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", 2509 | "dev": true, 2510 | "requires": { 2511 | "tslib": "^1.8.1" 2512 | } 2513 | } 2514 | } 2515 | }, 2516 | "@typescript-eslint/utils": { 2517 | "version": "5.29.0", 2518 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.29.0.tgz", 2519 | "integrity": "sha512-3Eos6uP1nyLOBayc/VUdKZikV90HahXE5Dx9L5YlSd/7ylQPXhLk1BYb29SDgnBnTp+jmSZUU0QxUiyHgW4p7A==", 2520 | "dev": true, 2521 | "requires": { 2522 | "@types/json-schema": "^7.0.9", 2523 | "@typescript-eslint/scope-manager": "5.29.0", 2524 | "@typescript-eslint/types": "5.29.0", 2525 | "@typescript-eslint/typescript-estree": "5.29.0", 2526 | "eslint-scope": "^5.1.1", 2527 | "eslint-utils": "^3.0.0" 2528 | } 2529 | }, 2530 | "@typescript-eslint/visitor-keys": { 2531 | "version": "5.29.0", 2532 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.29.0.tgz", 2533 | "integrity": "sha512-Hpb/mCWsjILvikMQoZIE3voc9wtQcS0A9FUw3h8bhr9UxBdtI/tw1ZDZUOXHXLOVMedKCH5NxyzATwnU78bWCQ==", 2534 | "dev": true, 2535 | "requires": { 2536 | "@typescript-eslint/types": "5.29.0", 2537 | "eslint-visitor-keys": "^3.3.0" 2538 | } 2539 | }, 2540 | "acorn": { 2541 | "version": "8.7.1", 2542 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz", 2543 | "integrity": "sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A==", 2544 | "dev": true, 2545 | "peer": true 2546 | }, 2547 | "acorn-jsx": { 2548 | "version": "5.3.2", 2549 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 2550 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 2551 | "dev": true, 2552 | "peer": true, 2553 | "requires": {} 2554 | }, 2555 | "ajv": { 2556 | "version": "6.12.6", 2557 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2558 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2559 | "dev": true, 2560 | "peer": true, 2561 | "requires": { 2562 | "fast-deep-equal": "^3.1.1", 2563 | "fast-json-stable-stringify": "^2.0.0", 2564 | "json-schema-traverse": "^0.4.1", 2565 | "uri-js": "^4.2.2" 2566 | } 2567 | }, 2568 | "ansi-regex": { 2569 | "version": "5.0.1", 2570 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2571 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2572 | "dev": true, 2573 | "peer": true 2574 | }, 2575 | "ansi-styles": { 2576 | "version": "4.3.0", 2577 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2578 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2579 | "dev": true, 2580 | "peer": true, 2581 | "requires": { 2582 | "color-convert": "^2.0.1" 2583 | } 2584 | }, 2585 | "argparse": { 2586 | "version": "2.0.1", 2587 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2588 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2589 | "dev": true, 2590 | "peer": true 2591 | }, 2592 | "array-union": { 2593 | "version": "2.1.0", 2594 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 2595 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 2596 | "dev": true 2597 | }, 2598 | "balanced-match": { 2599 | "version": "1.0.2", 2600 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2601 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2602 | "dev": true, 2603 | "peer": true 2604 | }, 2605 | "brace-expansion": { 2606 | "version": "1.1.11", 2607 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2608 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2609 | "dev": true, 2610 | "peer": true, 2611 | "requires": { 2612 | "balanced-match": "^1.0.0", 2613 | "concat-map": "0.0.1" 2614 | } 2615 | }, 2616 | "braces": { 2617 | "version": "3.0.2", 2618 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2619 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2620 | "dev": true, 2621 | "requires": { 2622 | "fill-range": "^7.0.1" 2623 | } 2624 | }, 2625 | "builtin-modules": { 2626 | "version": "3.3.0", 2627 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.3.0.tgz", 2628 | "integrity": "sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw==", 2629 | "dev": true 2630 | }, 2631 | "callsites": { 2632 | "version": "3.1.0", 2633 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2634 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2635 | "dev": true, 2636 | "peer": true 2637 | }, 2638 | "chalk": { 2639 | "version": "4.1.2", 2640 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2641 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2642 | "dev": true, 2643 | "peer": true, 2644 | "requires": { 2645 | "ansi-styles": "^4.1.0", 2646 | "supports-color": "^7.1.0" 2647 | } 2648 | }, 2649 | "color-convert": { 2650 | "version": "2.0.1", 2651 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2652 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2653 | "dev": true, 2654 | "peer": true, 2655 | "requires": { 2656 | "color-name": "~1.1.4" 2657 | } 2658 | }, 2659 | "color-name": { 2660 | "version": "1.1.4", 2661 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2662 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2663 | "dev": true, 2664 | "peer": true 2665 | }, 2666 | "concat-map": { 2667 | "version": "0.0.1", 2668 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2669 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2670 | "dev": true, 2671 | "peer": true 2672 | }, 2673 | "cross-spawn": { 2674 | "version": "7.0.3", 2675 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2676 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2677 | "dev": true, 2678 | "peer": true, 2679 | "requires": { 2680 | "path-key": "^3.1.0", 2681 | "shebang-command": "^2.0.0", 2682 | "which": "^2.0.1" 2683 | } 2684 | }, 2685 | "debug": { 2686 | "version": "4.3.4", 2687 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2688 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2689 | "dev": true, 2690 | "requires": { 2691 | "ms": "2.1.2" 2692 | } 2693 | }, 2694 | "deep-is": { 2695 | "version": "0.1.4", 2696 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2697 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2698 | "dev": true, 2699 | "peer": true 2700 | }, 2701 | "dir-glob": { 2702 | "version": "3.0.1", 2703 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 2704 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 2705 | "dev": true, 2706 | "requires": { 2707 | "path-type": "^4.0.0" 2708 | } 2709 | }, 2710 | "doctrine": { 2711 | "version": "3.0.0", 2712 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2713 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2714 | "dev": true, 2715 | "peer": true, 2716 | "requires": { 2717 | "esutils": "^2.0.2" 2718 | } 2719 | }, 2720 | "emoji-regex": { 2721 | "version": "10.1.0", 2722 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.1.0.tgz", 2723 | "integrity": "sha512-xAEnNCT3w2Tg6MA7ly6QqYJvEoY1tm9iIjJ3yMKK9JPlWuRHAMoe5iETwQnx3M9TVbFMfsrBgWKR+IsmswwNjg==", 2724 | "dev": true 2725 | }, 2726 | "esbuild": { 2727 | "version": "0.14.47", 2728 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.47.tgz", 2729 | "integrity": "sha512-wI4ZiIfFxpkuxB8ju4MHrGwGLyp1+awEHAHVpx6w7a+1pmYIq8T9FGEVVwFo0iFierDoMj++Xq69GXWYn2EiwA==", 2730 | "dev": true, 2731 | "requires": { 2732 | "esbuild-android-64": "0.14.47", 2733 | "esbuild-android-arm64": "0.14.47", 2734 | "esbuild-darwin-64": "0.14.47", 2735 | "esbuild-darwin-arm64": "0.14.47", 2736 | "esbuild-freebsd-64": "0.14.47", 2737 | "esbuild-freebsd-arm64": "0.14.47", 2738 | "esbuild-linux-32": "0.14.47", 2739 | "esbuild-linux-64": "0.14.47", 2740 | "esbuild-linux-arm": "0.14.47", 2741 | "esbuild-linux-arm64": "0.14.47", 2742 | "esbuild-linux-mips64le": "0.14.47", 2743 | "esbuild-linux-ppc64le": "0.14.47", 2744 | "esbuild-linux-riscv64": "0.14.47", 2745 | "esbuild-linux-s390x": "0.14.47", 2746 | "esbuild-netbsd-64": "0.14.47", 2747 | "esbuild-openbsd-64": "0.14.47", 2748 | "esbuild-sunos-64": "0.14.47", 2749 | "esbuild-windows-32": "0.14.47", 2750 | "esbuild-windows-64": "0.14.47", 2751 | "esbuild-windows-arm64": "0.14.47" 2752 | } 2753 | }, 2754 | "esbuild-android-64": { 2755 | "version": "0.14.47", 2756 | "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.14.47.tgz", 2757 | "integrity": "sha512-R13Bd9+tqLVFndncMHssZrPWe6/0Kpv2/dt4aA69soX4PRxlzsVpCvoJeFE8sOEoeVEiBkI0myjlkDodXlHa0g==", 2758 | "dev": true, 2759 | "optional": true 2760 | }, 2761 | "esbuild-android-arm64": { 2762 | "version": "0.14.47", 2763 | "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.47.tgz", 2764 | "integrity": "sha512-OkwOjj7ts4lBp/TL6hdd8HftIzOy/pdtbrNA4+0oVWgGG64HrdVzAF5gxtJufAPOsEjkyh1oIYvKAUinKKQRSQ==", 2765 | "dev": true, 2766 | "optional": true 2767 | }, 2768 | "esbuild-darwin-64": { 2769 | "version": "0.14.47", 2770 | "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.47.tgz", 2771 | "integrity": "sha512-R6oaW0y5/u6Eccti/TS6c/2c1xYTb1izwK3gajJwi4vIfNs1s8B1dQzI1UiC9T61YovOQVuePDcfqHLT3mUZJA==", 2772 | "dev": true, 2773 | "optional": true 2774 | }, 2775 | "esbuild-darwin-arm64": { 2776 | "version": "0.14.47", 2777 | "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.47.tgz", 2778 | "integrity": "sha512-seCmearlQyvdvM/noz1L9+qblC5vcBrhUaOoLEDDoLInF/VQ9IkobGiLlyTPYP5dW1YD4LXhtBgOyevoIHGGnw==", 2779 | "dev": true, 2780 | "optional": true 2781 | }, 2782 | "esbuild-freebsd-64": { 2783 | "version": "0.14.47", 2784 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.47.tgz", 2785 | "integrity": "sha512-ZH8K2Q8/Ux5kXXvQMDsJcxvkIwut69KVrYQhza/ptkW50DC089bCVrJZZ3sKzIoOx+YPTrmsZvqeZERjyYrlvQ==", 2786 | "dev": true, 2787 | "optional": true 2788 | }, 2789 | "esbuild-freebsd-arm64": { 2790 | "version": "0.14.47", 2791 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.47.tgz", 2792 | "integrity": "sha512-ZJMQAJQsIOhn3XTm7MPQfCzEu5b9STNC+s90zMWe2afy9EwnHV7Ov7ohEMv2lyWlc2pjqLW8QJnz2r0KZmeAEQ==", 2793 | "dev": true, 2794 | "optional": true 2795 | }, 2796 | "esbuild-linux-32": { 2797 | "version": "0.14.47", 2798 | "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.47.tgz", 2799 | "integrity": "sha512-FxZOCKoEDPRYvq300lsWCTv1kcHgiiZfNrPtEhFAiqD7QZaXrad8LxyJ8fXGcWzIFzRiYZVtB3ttvITBvAFhKw==", 2800 | "dev": true, 2801 | "optional": true 2802 | }, 2803 | "esbuild-linux-64": { 2804 | "version": "0.14.47", 2805 | "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.47.tgz", 2806 | "integrity": "sha512-nFNOk9vWVfvWYF9YNYksZptgQAdstnDCMtR6m42l5Wfugbzu11VpMCY9XrD4yFxvPo9zmzcoUL/88y0lfJZJJw==", 2807 | "dev": true, 2808 | "optional": true 2809 | }, 2810 | "esbuild-linux-arm": { 2811 | "version": "0.14.47", 2812 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.47.tgz", 2813 | "integrity": "sha512-ZGE1Bqg/gPRXrBpgpvH81tQHpiaGxa8c9Rx/XOylkIl2ypLuOcawXEAo8ls+5DFCcRGt/o3sV+PzpAFZobOsmA==", 2814 | "dev": true, 2815 | "optional": true 2816 | }, 2817 | "esbuild-linux-arm64": { 2818 | "version": "0.14.47", 2819 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.47.tgz", 2820 | "integrity": "sha512-ywfme6HVrhWcevzmsufjd4iT3PxTfCX9HOdxA7Hd+/ZM23Y9nXeb+vG6AyA6jgq/JovkcqRHcL9XwRNpWG6XRw==", 2821 | "dev": true, 2822 | "optional": true 2823 | }, 2824 | "esbuild-linux-mips64le": { 2825 | "version": "0.14.47", 2826 | "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.47.tgz", 2827 | "integrity": "sha512-mg3D8YndZ1LvUiEdDYR3OsmeyAew4MA/dvaEJxvyygahWmpv1SlEEnhEZlhPokjsUMfRagzsEF/d/2XF+kTQGg==", 2828 | "dev": true, 2829 | "optional": true 2830 | }, 2831 | "esbuild-linux-ppc64le": { 2832 | "version": "0.14.47", 2833 | "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.47.tgz", 2834 | "integrity": "sha512-WER+f3+szmnZiWoK6AsrTKGoJoErG2LlauSmk73LEZFQ/iWC+KhhDsOkn1xBUpzXWsxN9THmQFltLoaFEH8F8w==", 2835 | "dev": true, 2836 | "optional": true 2837 | }, 2838 | "esbuild-linux-riscv64": { 2839 | "version": "0.14.47", 2840 | "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.14.47.tgz", 2841 | "integrity": "sha512-1fI6bP3A3rvI9BsaaXbMoaOjLE3lVkJtLxsgLHqlBhLlBVY7UqffWBvkrX/9zfPhhVMd9ZRFiaqXnB1T7BsL2g==", 2842 | "dev": true, 2843 | "optional": true 2844 | }, 2845 | "esbuild-linux-s390x": { 2846 | "version": "0.14.47", 2847 | "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.14.47.tgz", 2848 | "integrity": "sha512-eZrWzy0xFAhki1CWRGnhsHVz7IlSKX6yT2tj2Eg8lhAwlRE5E96Hsb0M1mPSE1dHGpt1QVwwVivXIAacF/G6mw==", 2849 | "dev": true, 2850 | "optional": true 2851 | }, 2852 | "esbuild-netbsd-64": { 2853 | "version": "0.14.47", 2854 | "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.47.tgz", 2855 | "integrity": "sha512-Qjdjr+KQQVH5Q2Q1r6HBYswFTToPpss3gqCiSw2Fpq/ua8+eXSQyAMG+UvULPqXceOwpnPo4smyZyHdlkcPppQ==", 2856 | "dev": true, 2857 | "optional": true 2858 | }, 2859 | "esbuild-openbsd-64": { 2860 | "version": "0.14.47", 2861 | "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.47.tgz", 2862 | "integrity": "sha512-QpgN8ofL7B9z8g5zZqJE+eFvD1LehRlxr25PBkjyyasakm4599iroUpaj96rdqRlO2ShuyqwJdr+oNqWwTUmQw==", 2863 | "dev": true, 2864 | "optional": true 2865 | }, 2866 | "esbuild-sunos-64": { 2867 | "version": "0.14.47", 2868 | "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.47.tgz", 2869 | "integrity": "sha512-uOeSgLUwukLioAJOiGYm3kNl+1wJjgJA8R671GYgcPgCx7QR73zfvYqXFFcIO93/nBdIbt5hd8RItqbbf3HtAQ==", 2870 | "dev": true, 2871 | "optional": true 2872 | }, 2873 | "esbuild-windows-32": { 2874 | "version": "0.14.47", 2875 | "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.47.tgz", 2876 | "integrity": "sha512-H0fWsLTp2WBfKLBgwYT4OTfFly4Im/8B5f3ojDv1Kx//kiubVY0IQunP2Koc/fr/0wI7hj3IiBDbSrmKlrNgLQ==", 2877 | "dev": true, 2878 | "optional": true 2879 | }, 2880 | "esbuild-windows-64": { 2881 | "version": "0.14.47", 2882 | "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.47.tgz", 2883 | "integrity": "sha512-/Pk5jIEH34T68r8PweKRi77W49KwanZ8X6lr3vDAtOlH5EumPE4pBHqkCUdELanvsT14yMXLQ/C/8XPi1pAtkQ==", 2884 | "dev": true, 2885 | "optional": true 2886 | }, 2887 | "esbuild-windows-arm64": { 2888 | "version": "0.14.47", 2889 | "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.47.tgz", 2890 | "integrity": "sha512-HFSW2lnp62fl86/qPQlqw6asIwCnEsEoNIL1h2uVMgakddf+vUuMcCbtUY1i8sst7KkgHrVKCJQB33YhhOweCQ==", 2891 | "dev": true, 2892 | "optional": true 2893 | }, 2894 | "escape-string-regexp": { 2895 | "version": "4.0.0", 2896 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2897 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2898 | "dev": true, 2899 | "peer": true 2900 | }, 2901 | "eslint": { 2902 | "version": "8.18.0", 2903 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.18.0.tgz", 2904 | "integrity": "sha512-As1EfFMVk7Xc6/CvhssHUjsAQSkpfXvUGMFC3ce8JDe6WvqCgRrLOBQbVpsBFr1X1V+RACOadnzVvcUS5ni2bA==", 2905 | "dev": true, 2906 | "peer": true, 2907 | "requires": { 2908 | "@eslint/eslintrc": "^1.3.0", 2909 | "@humanwhocodes/config-array": "^0.9.2", 2910 | "ajv": "^6.10.0", 2911 | "chalk": "^4.0.0", 2912 | "cross-spawn": "^7.0.2", 2913 | "debug": "^4.3.2", 2914 | "doctrine": "^3.0.0", 2915 | "escape-string-regexp": "^4.0.0", 2916 | "eslint-scope": "^7.1.1", 2917 | "eslint-utils": "^3.0.0", 2918 | "eslint-visitor-keys": "^3.3.0", 2919 | "espree": "^9.3.2", 2920 | "esquery": "^1.4.0", 2921 | "esutils": "^2.0.2", 2922 | "fast-deep-equal": "^3.1.3", 2923 | "file-entry-cache": "^6.0.1", 2924 | "functional-red-black-tree": "^1.0.1", 2925 | "glob-parent": "^6.0.1", 2926 | "globals": "^13.15.0", 2927 | "ignore": "^5.2.0", 2928 | "import-fresh": "^3.0.0", 2929 | "imurmurhash": "^0.1.4", 2930 | "is-glob": "^4.0.0", 2931 | "js-yaml": "^4.1.0", 2932 | "json-stable-stringify-without-jsonify": "^1.0.1", 2933 | "levn": "^0.4.1", 2934 | "lodash.merge": "^4.6.2", 2935 | "minimatch": "^3.1.2", 2936 | "natural-compare": "^1.4.0", 2937 | "optionator": "^0.9.1", 2938 | "regexpp": "^3.2.0", 2939 | "strip-ansi": "^6.0.1", 2940 | "strip-json-comments": "^3.1.0", 2941 | "text-table": "^0.2.0", 2942 | "v8-compile-cache": "^2.0.3" 2943 | }, 2944 | "dependencies": { 2945 | "eslint-scope": { 2946 | "version": "7.1.1", 2947 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", 2948 | "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", 2949 | "dev": true, 2950 | "peer": true, 2951 | "requires": { 2952 | "esrecurse": "^4.3.0", 2953 | "estraverse": "^5.2.0" 2954 | } 2955 | }, 2956 | "estraverse": { 2957 | "version": "5.3.0", 2958 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 2959 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 2960 | "dev": true, 2961 | "peer": true 2962 | } 2963 | } 2964 | }, 2965 | "eslint-scope": { 2966 | "version": "5.1.1", 2967 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", 2968 | "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", 2969 | "dev": true, 2970 | "requires": { 2971 | "esrecurse": "^4.3.0", 2972 | "estraverse": "^4.1.1" 2973 | } 2974 | }, 2975 | "eslint-utils": { 2976 | "version": "3.0.0", 2977 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", 2978 | "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", 2979 | "dev": true, 2980 | "requires": { 2981 | "eslint-visitor-keys": "^2.0.0" 2982 | }, 2983 | "dependencies": { 2984 | "eslint-visitor-keys": { 2985 | "version": "2.1.0", 2986 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", 2987 | "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", 2988 | "dev": true 2989 | } 2990 | } 2991 | }, 2992 | "eslint-visitor-keys": { 2993 | "version": "3.3.0", 2994 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", 2995 | "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", 2996 | "dev": true 2997 | }, 2998 | "espree": { 2999 | "version": "9.3.2", 3000 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.3.2.tgz", 3001 | "integrity": "sha512-D211tC7ZwouTIuY5x9XnS0E9sWNChB7IYKX/Xp5eQj3nFXhqmiUDB9q27y76oFl8jTg3pXcQx/bpxMfs3CIZbA==", 3002 | "dev": true, 3003 | "peer": true, 3004 | "requires": { 3005 | "acorn": "^8.7.1", 3006 | "acorn-jsx": "^5.3.2", 3007 | "eslint-visitor-keys": "^3.3.0" 3008 | } 3009 | }, 3010 | "esquery": { 3011 | "version": "1.4.0", 3012 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", 3013 | "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", 3014 | "dev": true, 3015 | "peer": true, 3016 | "requires": { 3017 | "estraverse": "^5.1.0" 3018 | }, 3019 | "dependencies": { 3020 | "estraverse": { 3021 | "version": "5.3.0", 3022 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 3023 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 3024 | "dev": true, 3025 | "peer": true 3026 | } 3027 | } 3028 | }, 3029 | "esrecurse": { 3030 | "version": "4.3.0", 3031 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 3032 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 3033 | "dev": true, 3034 | "requires": { 3035 | "estraverse": "^5.2.0" 3036 | }, 3037 | "dependencies": { 3038 | "estraverse": { 3039 | "version": "5.3.0", 3040 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 3041 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 3042 | "dev": true 3043 | } 3044 | } 3045 | }, 3046 | "estraverse": { 3047 | "version": "4.3.0", 3048 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 3049 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 3050 | "dev": true 3051 | }, 3052 | "esutils": { 3053 | "version": "2.0.3", 3054 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 3055 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 3056 | "dev": true, 3057 | "peer": true 3058 | }, 3059 | "fast-deep-equal": { 3060 | "version": "3.1.3", 3061 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 3062 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 3063 | "dev": true, 3064 | "peer": true 3065 | }, 3066 | "fast-glob": { 3067 | "version": "3.2.11", 3068 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.11.tgz", 3069 | "integrity": "sha512-xrO3+1bxSo3ZVHAnqzyuewYT6aMFHRAd4Kcs92MAonjwQZLsK9d0SF1IyQ3k5PoirxTW0Oe/RqFgMQ6TcNE5Ew==", 3070 | "dev": true, 3071 | "requires": { 3072 | "@nodelib/fs.stat": "^2.0.2", 3073 | "@nodelib/fs.walk": "^1.2.3", 3074 | "glob-parent": "^5.1.2", 3075 | "merge2": "^1.3.0", 3076 | "micromatch": "^4.0.4" 3077 | }, 3078 | "dependencies": { 3079 | "glob-parent": { 3080 | "version": "5.1.2", 3081 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 3082 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 3083 | "dev": true, 3084 | "requires": { 3085 | "is-glob": "^4.0.1" 3086 | } 3087 | } 3088 | } 3089 | }, 3090 | "fast-json-stable-stringify": { 3091 | "version": "2.1.0", 3092 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 3093 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 3094 | "dev": true, 3095 | "peer": true 3096 | }, 3097 | "fast-levenshtein": { 3098 | "version": "2.0.6", 3099 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 3100 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 3101 | "dev": true, 3102 | "peer": true 3103 | }, 3104 | "fastq": { 3105 | "version": "1.13.0", 3106 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.13.0.tgz", 3107 | "integrity": "sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==", 3108 | "dev": true, 3109 | "requires": { 3110 | "reusify": "^1.0.4" 3111 | } 3112 | }, 3113 | "file-entry-cache": { 3114 | "version": "6.0.1", 3115 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 3116 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 3117 | "dev": true, 3118 | "peer": true, 3119 | "requires": { 3120 | "flat-cache": "^3.0.4" 3121 | } 3122 | }, 3123 | "fill-range": { 3124 | "version": "7.0.1", 3125 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 3126 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 3127 | "dev": true, 3128 | "requires": { 3129 | "to-regex-range": "^5.0.1" 3130 | } 3131 | }, 3132 | "flat-cache": { 3133 | "version": "3.0.4", 3134 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", 3135 | "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", 3136 | "dev": true, 3137 | "peer": true, 3138 | "requires": { 3139 | "flatted": "^3.1.0", 3140 | "rimraf": "^3.0.2" 3141 | } 3142 | }, 3143 | "flatted": { 3144 | "version": "3.2.5", 3145 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.5.tgz", 3146 | "integrity": "sha512-WIWGi2L3DyTUvUrwRKgGi9TwxQMUEqPOPQBVi71R96jZXJdFskXEmf54BoZaS1kknGODoIGASGEzBUYdyMCBJg==", 3147 | "dev": true, 3148 | "peer": true 3149 | }, 3150 | "fs.realpath": { 3151 | "version": "1.0.0", 3152 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 3153 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 3154 | "dev": true, 3155 | "peer": true 3156 | }, 3157 | "functional-red-black-tree": { 3158 | "version": "1.0.1", 3159 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 3160 | "integrity": "sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g==", 3161 | "dev": true 3162 | }, 3163 | "glob": { 3164 | "version": "7.2.3", 3165 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 3166 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 3167 | "dev": true, 3168 | "peer": true, 3169 | "requires": { 3170 | "fs.realpath": "^1.0.0", 3171 | "inflight": "^1.0.4", 3172 | "inherits": "2", 3173 | "minimatch": "^3.1.1", 3174 | "once": "^1.3.0", 3175 | "path-is-absolute": "^1.0.0" 3176 | } 3177 | }, 3178 | "glob-parent": { 3179 | "version": "6.0.2", 3180 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 3181 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 3182 | "dev": true, 3183 | "peer": true, 3184 | "requires": { 3185 | "is-glob": "^4.0.3" 3186 | } 3187 | }, 3188 | "globals": { 3189 | "version": "13.15.0", 3190 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.15.0.tgz", 3191 | "integrity": "sha512-bpzcOlgDhMG070Av0Vy5Owklpv1I6+j96GhUI7Rh7IzDCKLzboflLrrfqMu8NquDbiR4EOQk7XzJwqVJxicxog==", 3192 | "dev": true, 3193 | "peer": true, 3194 | "requires": { 3195 | "type-fest": "^0.20.2" 3196 | } 3197 | }, 3198 | "globby": { 3199 | "version": "11.1.0", 3200 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 3201 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 3202 | "dev": true, 3203 | "requires": { 3204 | "array-union": "^2.1.0", 3205 | "dir-glob": "^3.0.1", 3206 | "fast-glob": "^3.2.9", 3207 | "ignore": "^5.2.0", 3208 | "merge2": "^1.4.1", 3209 | "slash": "^3.0.0" 3210 | } 3211 | }, 3212 | "has-flag": { 3213 | "version": "4.0.0", 3214 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 3215 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 3216 | "dev": true, 3217 | "peer": true 3218 | }, 3219 | "ignore": { 3220 | "version": "5.2.0", 3221 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.0.tgz", 3222 | "integrity": "sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==", 3223 | "dev": true 3224 | }, 3225 | "immediate": { 3226 | "version": "3.0.6", 3227 | "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.0.6.tgz", 3228 | "integrity": "sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ==", 3229 | "dev": true 3230 | }, 3231 | "import-fresh": { 3232 | "version": "3.3.0", 3233 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 3234 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 3235 | "dev": true, 3236 | "peer": true, 3237 | "requires": { 3238 | "parent-module": "^1.0.0", 3239 | "resolve-from": "^4.0.0" 3240 | } 3241 | }, 3242 | "imurmurhash": { 3243 | "version": "0.1.4", 3244 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 3245 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 3246 | "dev": true, 3247 | "peer": true 3248 | }, 3249 | "inflight": { 3250 | "version": "1.0.6", 3251 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 3252 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 3253 | "dev": true, 3254 | "peer": true, 3255 | "requires": { 3256 | "once": "^1.3.0", 3257 | "wrappy": "1" 3258 | } 3259 | }, 3260 | "inherits": { 3261 | "version": "2.0.4", 3262 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 3263 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 3264 | "dev": true, 3265 | "peer": true 3266 | }, 3267 | "is-extglob": { 3268 | "version": "2.1.1", 3269 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 3270 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 3271 | "dev": true 3272 | }, 3273 | "is-glob": { 3274 | "version": "4.0.3", 3275 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 3276 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 3277 | "dev": true, 3278 | "requires": { 3279 | "is-extglob": "^2.1.1" 3280 | } 3281 | }, 3282 | "is-number": { 3283 | "version": "7.0.0", 3284 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 3285 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 3286 | "dev": true 3287 | }, 3288 | "isexe": { 3289 | "version": "2.0.0", 3290 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 3291 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 3292 | "dev": true, 3293 | "peer": true 3294 | }, 3295 | "js-yaml": { 3296 | "version": "4.1.0", 3297 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 3298 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 3299 | "dev": true, 3300 | "peer": true, 3301 | "requires": { 3302 | "argparse": "^2.0.1" 3303 | } 3304 | }, 3305 | "json-schema-traverse": { 3306 | "version": "0.4.1", 3307 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 3308 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 3309 | "dev": true, 3310 | "peer": true 3311 | }, 3312 | "json-stable-stringify-without-jsonify": { 3313 | "version": "1.0.1", 3314 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 3315 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 3316 | "dev": true, 3317 | "peer": true 3318 | }, 3319 | "levn": { 3320 | "version": "0.4.1", 3321 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 3322 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 3323 | "dev": true, 3324 | "peer": true, 3325 | "requires": { 3326 | "prelude-ls": "^1.2.1", 3327 | "type-check": "~0.4.0" 3328 | } 3329 | }, 3330 | "lie": { 3331 | "version": "3.1.1", 3332 | "resolved": "https://registry.npmjs.org/lie/-/lie-3.1.1.tgz", 3333 | "integrity": "sha512-RiNhHysUjhrDQntfYSfY4MU24coXXdEOgw9WGcKHNeEwffDYbF//u87M1EWaMGzuFoSbqW0C9C6lEEhDOAswfw==", 3334 | "dev": true, 3335 | "requires": { 3336 | "immediate": "~3.0.5" 3337 | } 3338 | }, 3339 | "localforage": { 3340 | "version": "1.10.0", 3341 | "resolved": "https://registry.npmjs.org/localforage/-/localforage-1.10.0.tgz", 3342 | "integrity": "sha512-14/H1aX7hzBBmmh7sGPd+AOMkkIrHM3Z1PAyGgZigA1H1p5O5ANnMyWzvpAETtG68/dC4pC0ncy3+PPGzXZHPg==", 3343 | "dev": true, 3344 | "requires": { 3345 | "lie": "3.1.1" 3346 | } 3347 | }, 3348 | "lodash.merge": { 3349 | "version": "4.6.2", 3350 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 3351 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 3352 | "dev": true, 3353 | "peer": true 3354 | }, 3355 | "lru-cache": { 3356 | "version": "6.0.0", 3357 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3358 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3359 | "dev": true, 3360 | "requires": { 3361 | "yallist": "^4.0.0" 3362 | } 3363 | }, 3364 | "luxon": { 3365 | "version": "2.4.0", 3366 | "resolved": "https://registry.npmjs.org/luxon/-/luxon-2.4.0.tgz", 3367 | "integrity": "sha512-w+NAwWOUL5hO0SgwOHsMBAmZ15SoknmQXhSO0hIbJCAmPKSsGeK8MlmhYh2w6Iib38IxN2M+/ooXWLbeis7GuA==", 3368 | "dev": true 3369 | }, 3370 | "merge2": { 3371 | "version": "1.4.1", 3372 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 3373 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 3374 | "dev": true 3375 | }, 3376 | "micromatch": { 3377 | "version": "4.0.5", 3378 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 3379 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 3380 | "dev": true, 3381 | "requires": { 3382 | "braces": "^3.0.2", 3383 | "picomatch": "^2.3.1" 3384 | } 3385 | }, 3386 | "minimatch": { 3387 | "version": "3.1.2", 3388 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3389 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3390 | "dev": true, 3391 | "peer": true, 3392 | "requires": { 3393 | "brace-expansion": "^1.1.7" 3394 | } 3395 | }, 3396 | "moment": { 3397 | "version": "2.29.3", 3398 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.3.tgz", 3399 | "integrity": "sha512-c6YRvhEo//6T2Jz/vVtYzqBzwvPT95JBQ+smCytzf7c50oMZRsR/a4w88aD34I+/QVSfnoAnSBFPJHItlOMJVw==", 3400 | "dev": true 3401 | }, 3402 | "ms": { 3403 | "version": "2.1.2", 3404 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3405 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3406 | "dev": true 3407 | }, 3408 | "natural-compare": { 3409 | "version": "1.4.0", 3410 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3411 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 3412 | "dev": true, 3413 | "peer": true 3414 | }, 3415 | "obsidian": { 3416 | "version": "1.5.7-1", 3417 | "resolved": "https://registry.npmjs.org/obsidian/-/obsidian-1.5.7-1.tgz", 3418 | "integrity": "sha512-T5ZRuQ1FnfXqEoakTTHVDYvzUEEoT8zSPnQCW31PVgYwG4D4tZCQfKHN2hTz1ifnCe8upvwa6mBTAP2WUA5Vng==", 3419 | "dev": true, 3420 | "requires": { 3421 | "@types/codemirror": "5.60.8", 3422 | "moment": "2.29.4" 3423 | }, 3424 | "dependencies": { 3425 | "@types/codemirror": { 3426 | "version": "5.60.8", 3427 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-5.60.8.tgz", 3428 | "integrity": "sha512-VjFgDF/eB+Aklcy15TtOTLQeMjTo07k7KAjql8OK5Dirr7a6sJY4T1uVBDuTVG9VEmn1uUsohOpYnVfgC6/jyw==", 3429 | "dev": true, 3430 | "requires": { 3431 | "@types/tern": "*" 3432 | } 3433 | }, 3434 | "moment": { 3435 | "version": "2.29.4", 3436 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 3437 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 3438 | "dev": true 3439 | } 3440 | } 3441 | }, 3442 | "obsidian-calendar-ui": { 3443 | "version": "0.3.12", 3444 | "resolved": "https://registry.npmjs.org/obsidian-calendar-ui/-/obsidian-calendar-ui-0.3.12.tgz", 3445 | "integrity": "sha512-hdoRqCPnukfRgCARgArXaqMQZ+Iai0eY7f0ZsFHHfywpv4gKg3Tx5p47UsLvRO5DD+4knlbrL7Gel57MkfcLTw==", 3446 | "dev": true, 3447 | "requires": { 3448 | "obsidian-daily-notes-interface": "0.8.4", 3449 | "svelte": "3.35.0", 3450 | "tslib": "2.1.0" 3451 | }, 3452 | "dependencies": { 3453 | "tslib": { 3454 | "version": "2.1.0", 3455 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.1.0.tgz", 3456 | "integrity": "sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A==", 3457 | "dev": true 3458 | } 3459 | } 3460 | }, 3461 | "obsidian-daily-notes-interface": { 3462 | "version": "0.8.4", 3463 | "resolved": "https://registry.npmjs.org/obsidian-daily-notes-interface/-/obsidian-daily-notes-interface-0.8.4.tgz", 3464 | "integrity": "sha512-REKQtAuIOKDbvNH/th1C1gWmJWCP5tRn9T/mfZGZt4Zncgko7McXK0aSKFtEInipvgbZJ2nScivvyLdiWluSMw==", 3465 | "dev": true, 3466 | "requires": { 3467 | "obsidian": "github:obsidianmd/obsidian-api#master", 3468 | "tslib": "2.1.0" 3469 | }, 3470 | "dependencies": { 3471 | "obsidian": { 3472 | "version": "git+ssh://git@github.com/obsidianmd/obsidian-api.git#d4b79f95ccf3838a305915a137a844250766d023", 3473 | "dev": true, 3474 | "from": "obsidian@github:obsidianmd/obsidian-api#master", 3475 | "requires": { 3476 | "@types/codemirror": "0.0.108", 3477 | "moment": "2.29.3" 3478 | } 3479 | }, 3480 | "tslib": { 3481 | "version": "2.1.0", 3482 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.1.0.tgz", 3483 | "integrity": "sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A==", 3484 | "dev": true 3485 | } 3486 | } 3487 | }, 3488 | "obsidian-dataview": { 3489 | "version": "0.5.46", 3490 | "resolved": "https://registry.npmjs.org/obsidian-dataview/-/obsidian-dataview-0.5.46.tgz", 3491 | "integrity": "sha512-/y5NjL4w1kLdwO515nyzPXmYqYSw9Z6G5uV0YXdBgjE1sKUUeJANOQKAaKmbD010BgHjzkEjfbgJxIr7dbgIGw==", 3492 | "dev": true, 3493 | "requires": { 3494 | "@codemirror/language": "git+https://github.com/lishid/cm-language.git", 3495 | "@codemirror/state": "^6.0.1", 3496 | "@codemirror/view": "^6.0.1", 3497 | "emoji-regex": "^10.0.0", 3498 | "localforage": "^1.10.0", 3499 | "luxon": "^2.4.0", 3500 | "obsidian-calendar-ui": "^0.3.12", 3501 | "papaparse": "^5.3.1", 3502 | "parsimmon": "^1.18.0", 3503 | "preact": "^10.6.5" 3504 | } 3505 | }, 3506 | "once": { 3507 | "version": "1.4.0", 3508 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3509 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 3510 | "dev": true, 3511 | "peer": true, 3512 | "requires": { 3513 | "wrappy": "1" 3514 | } 3515 | }, 3516 | "optionator": { 3517 | "version": "0.9.1", 3518 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", 3519 | "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", 3520 | "dev": true, 3521 | "peer": true, 3522 | "requires": { 3523 | "deep-is": "^0.1.3", 3524 | "fast-levenshtein": "^2.0.6", 3525 | "levn": "^0.4.1", 3526 | "prelude-ls": "^1.2.1", 3527 | "type-check": "^0.4.0", 3528 | "word-wrap": "^1.2.3" 3529 | } 3530 | }, 3531 | "papaparse": { 3532 | "version": "5.3.2", 3533 | "resolved": "https://registry.npmjs.org/papaparse/-/papaparse-5.3.2.tgz", 3534 | "integrity": "sha512-6dNZu0Ki+gyV0eBsFKJhYr+MdQYAzFUGlBMNj3GNrmHxmz1lfRa24CjFObPXtjcetlOv5Ad299MhIK0znp3afw==", 3535 | "dev": true 3536 | }, 3537 | "parent-module": { 3538 | "version": "1.0.1", 3539 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3540 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3541 | "dev": true, 3542 | "peer": true, 3543 | "requires": { 3544 | "callsites": "^3.0.0" 3545 | } 3546 | }, 3547 | "parsimmon": { 3548 | "version": "1.18.1", 3549 | "resolved": "https://registry.npmjs.org/parsimmon/-/parsimmon-1.18.1.tgz", 3550 | "integrity": "sha512-u7p959wLfGAhJpSDJVYXoyMCXWYwHia78HhRBWqk7AIbxdmlrfdp5wX0l3xv/iTSH5HvhN9K7o26hwwpgS5Nmw==", 3551 | "dev": true 3552 | }, 3553 | "path-is-absolute": { 3554 | "version": "1.0.1", 3555 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3556 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3557 | "dev": true, 3558 | "peer": true 3559 | }, 3560 | "path-key": { 3561 | "version": "3.1.1", 3562 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3563 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3564 | "dev": true, 3565 | "peer": true 3566 | }, 3567 | "path-type": { 3568 | "version": "4.0.0", 3569 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 3570 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 3571 | "dev": true 3572 | }, 3573 | "picomatch": { 3574 | "version": "2.3.1", 3575 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3576 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3577 | "dev": true 3578 | }, 3579 | "preact": { 3580 | "version": "10.8.2", 3581 | "resolved": "https://registry.npmjs.org/preact/-/preact-10.8.2.tgz", 3582 | "integrity": "sha512-AKGt0BsDSiAYzVS78jZ9qRwuorY2CoSZtf1iOC6gLb/3QyZt+fLT09aYJBjRc/BEcRc4j+j3ggERMdNE43i1LQ==", 3583 | "dev": true 3584 | }, 3585 | "prelude-ls": { 3586 | "version": "1.2.1", 3587 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3588 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3589 | "dev": true, 3590 | "peer": true 3591 | }, 3592 | "punycode": { 3593 | "version": "2.1.1", 3594 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 3595 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 3596 | "dev": true, 3597 | "peer": true 3598 | }, 3599 | "queue-microtask": { 3600 | "version": "1.2.3", 3601 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 3602 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 3603 | "dev": true 3604 | }, 3605 | "regexpp": { 3606 | "version": "3.2.0", 3607 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", 3608 | "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", 3609 | "dev": true 3610 | }, 3611 | "resolve-from": { 3612 | "version": "4.0.0", 3613 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3614 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3615 | "dev": true, 3616 | "peer": true 3617 | }, 3618 | "reusify": { 3619 | "version": "1.0.4", 3620 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 3621 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 3622 | "dev": true 3623 | }, 3624 | "rimraf": { 3625 | "version": "3.0.2", 3626 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3627 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3628 | "dev": true, 3629 | "peer": true, 3630 | "requires": { 3631 | "glob": "^7.1.3" 3632 | } 3633 | }, 3634 | "run-parallel": { 3635 | "version": "1.2.0", 3636 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 3637 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 3638 | "dev": true, 3639 | "requires": { 3640 | "queue-microtask": "^1.2.2" 3641 | } 3642 | }, 3643 | "semver": { 3644 | "version": "7.3.7", 3645 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz", 3646 | "integrity": "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==", 3647 | "dev": true, 3648 | "requires": { 3649 | "lru-cache": "^6.0.0" 3650 | } 3651 | }, 3652 | "shebang-command": { 3653 | "version": "2.0.0", 3654 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3655 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3656 | "dev": true, 3657 | "peer": true, 3658 | "requires": { 3659 | "shebang-regex": "^3.0.0" 3660 | } 3661 | }, 3662 | "shebang-regex": { 3663 | "version": "3.0.0", 3664 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3665 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3666 | "dev": true, 3667 | "peer": true 3668 | }, 3669 | "slash": { 3670 | "version": "3.0.0", 3671 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3672 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3673 | "dev": true 3674 | }, 3675 | "strip-ansi": { 3676 | "version": "6.0.1", 3677 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3678 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3679 | "dev": true, 3680 | "peer": true, 3681 | "requires": { 3682 | "ansi-regex": "^5.0.1" 3683 | } 3684 | }, 3685 | "strip-json-comments": { 3686 | "version": "3.1.1", 3687 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3688 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3689 | "dev": true, 3690 | "peer": true 3691 | }, 3692 | "style-mod": { 3693 | "version": "4.0.0", 3694 | "resolved": "https://registry.npmjs.org/style-mod/-/style-mod-4.0.0.tgz", 3695 | "integrity": "sha512-OPhtyEjyyN9x3nhPsu76f52yUGXiZcgvsrFVtvTkyGRQJ0XK+GPc6ov1z+lRpbeabka+MYEQxOYRnt5nF30aMw==", 3696 | "dev": true 3697 | }, 3698 | "supports-color": { 3699 | "version": "7.2.0", 3700 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3701 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3702 | "dev": true, 3703 | "peer": true, 3704 | "requires": { 3705 | "has-flag": "^4.0.0" 3706 | } 3707 | }, 3708 | "svelte": { 3709 | "version": "3.35.0", 3710 | "resolved": "https://registry.npmjs.org/svelte/-/svelte-3.35.0.tgz", 3711 | "integrity": "sha512-gknlZkR2sXheu/X+B7dDImwANVvK1R0QGQLd8CNIfxxGPeXBmePnxfzb6fWwTQRsYQG7lYkZXvpXJvxvpsoB7g==", 3712 | "dev": true 3713 | }, 3714 | "text-table": { 3715 | "version": "0.2.0", 3716 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3717 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3718 | "dev": true, 3719 | "peer": true 3720 | }, 3721 | "to-regex-range": { 3722 | "version": "5.0.1", 3723 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3724 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3725 | "dev": true, 3726 | "requires": { 3727 | "is-number": "^7.0.0" 3728 | } 3729 | }, 3730 | "tslib": { 3731 | "version": "2.4.0", 3732 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz", 3733 | "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==", 3734 | "dev": true 3735 | }, 3736 | "type-check": { 3737 | "version": "0.4.0", 3738 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3739 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3740 | "dev": true, 3741 | "peer": true, 3742 | "requires": { 3743 | "prelude-ls": "^1.2.1" 3744 | } 3745 | }, 3746 | "type-fest": { 3747 | "version": "0.20.2", 3748 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3749 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3750 | "dev": true, 3751 | "peer": true 3752 | }, 3753 | "typescript": { 3754 | "version": "4.7.4", 3755 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.7.4.tgz", 3756 | "integrity": "sha512-C0WQT0gezHuw6AdY1M2jxUO83Rjf0HP7Sk1DtXj6j1EwkQNZrHAg2XPWlq62oqEhYvONq5pkC2Y9oPljWToLmQ==", 3757 | "dev": true 3758 | }, 3759 | "uri-js": { 3760 | "version": "4.4.1", 3761 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3762 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3763 | "dev": true, 3764 | "peer": true, 3765 | "requires": { 3766 | "punycode": "^2.1.0" 3767 | } 3768 | }, 3769 | "v8-compile-cache": { 3770 | "version": "2.3.0", 3771 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", 3772 | "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", 3773 | "dev": true, 3774 | "peer": true 3775 | }, 3776 | "w3c-keyname": { 3777 | "version": "2.2.4", 3778 | "resolved": "https://registry.npmjs.org/w3c-keyname/-/w3c-keyname-2.2.4.tgz", 3779 | "integrity": "sha512-tOhfEwEzFLJzf6d1ZPkYfGj+FWhIpBux9ppoP3rlclw3Z0BZv3N7b7030Z1kYth+6rDuAsXUFr+d0VE6Ed1ikw==", 3780 | "dev": true 3781 | }, 3782 | "which": { 3783 | "version": "2.0.2", 3784 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3785 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3786 | "dev": true, 3787 | "peer": true, 3788 | "requires": { 3789 | "isexe": "^2.0.0" 3790 | } 3791 | }, 3792 | "word-wrap": { 3793 | "version": "1.2.3", 3794 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3795 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3796 | "dev": true, 3797 | "peer": true 3798 | }, 3799 | "wrappy": { 3800 | "version": "1.0.2", 3801 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3802 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 3803 | "dev": true, 3804 | "peer": true 3805 | }, 3806 | "yallist": { 3807 | "version": "4.0.0", 3808 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3809 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3810 | "dev": true 3811 | } 3812 | } 3813 | } 3814 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "obsidian-sample-plugin", 3 | "version": "1.0.1", 4 | "description": "This is a sample plugin for Obsidian (https://obsidian.md)", 5 | "main": "main.js", 6 | "scripts": { 7 | "dev": "node esbuild.config.mjs", 8 | "build": "tsc -noEmit -skipLibCheck && node esbuild.config.mjs production", 9 | "version": "node version-bump.mjs && git add manifest.json versions.json" 10 | }, 11 | "keywords": [], 12 | "author": "", 13 | "license": "MIT", 14 | "devDependencies": { 15 | "@types/node": "^16.18.87", 16 | "@typescript-eslint/eslint-plugin": "5.29.0", 17 | "@typescript-eslint/parser": "5.29.0", 18 | "builtin-modules": "^3.2.0", 19 | "esbuild": "0.14.47", 20 | "obsidian": "^1.5.7-1", 21 | "obsidian-dataview": "^0.5.46", 22 | "tslib": "2.4.0", 23 | "typescript": "4.7.4" 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /settings.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/dartungar/obsidian-simple-note-review/caff68188f5571a168bc1705edd9ae9610ca7ee1/settings.png -------------------------------------------------------------------------------- /src/UI/icon.ts: -------------------------------------------------------------------------------- 1 | import { addIcon } from "obsidian"; 2 | 3 | export function addSimpleNoteReviewIcon(): void { 4 | addIcon("simple-note-review-icon", ` 5 | `) 6 | } -------------------------------------------------------------------------------- /src/UI/noteset/noteSetDeleteModal.ts: -------------------------------------------------------------------------------- 1 | import { App, Modal } from "obsidian"; 2 | import { SimpleNoteReviewPluginSettingsTab } from "src/UI/settingsTab"; 3 | import { INoteSet } from "../../noteSet/INoteSet"; 4 | import { NoteSetService } from "../../noteSet/noteSetService"; 5 | 6 | export class NoteSetDeleteModal extends Modal { 7 | 8 | constructor(app: App, private settingsTab: SimpleNoteReviewPluginSettingsTab, private noteSet: INoteSet, private service: NoteSetService) { 9 | super(app); 10 | } 11 | 12 | onOpen() { 13 | const { contentEl } = this; 14 | contentEl.addClass("note-set-delete-modal"); 15 | contentEl.setText(`Delete note set "${this.noteSet.displayName}" ?`); 16 | const btnsDiv = contentEl.createDiv(); 17 | const okBtn = btnsDiv.createEl("button", {text: "Ok"}); 18 | okBtn.onClickEvent(async () => { 19 | await this.service.deleteNoteSet(this.noteSet); 20 | this.settingsTab.refresh(); 21 | this.close(); 22 | }); 23 | const cancelBtn = btnsDiv.createEl("button", {text: "Cancel"}); 24 | cancelBtn.onClickEvent(() => this.close()); 25 | } 26 | 27 | onClose() { 28 | const { contentEl } = this; 29 | contentEl.empty(); 30 | } 31 | } -------------------------------------------------------------------------------- /src/UI/noteset/noteSetEditModal.ts: -------------------------------------------------------------------------------- 1 | import SimpleNoteReviewPlugin from "main"; 2 | import { ButtonComponent, Modal, Setting } from "obsidian"; 3 | import { INoteSet } from "src/noteSet/INoteSet"; 4 | import { JoinLogicOperators } from "src/settings/joinLogicOperators"; 5 | 6 | 7 | export class NoteSetEditModal extends Modal { 8 | 9 | constructor(private _noteSet: INoteSet, private _plugin: SimpleNoteReviewPlugin) { 10 | super(app); 11 | } 12 | 13 | onOpen() { 14 | 15 | const { contentEl } = this; 16 | 17 | contentEl.createEl("h3", {text: `Note set "${this._noteSet.displayName}"`}); 18 | 19 | const nameSetting = new Setting(contentEl); 20 | nameSetting.setName("Name"); 21 | nameSetting.setDesc("If omitted, the name will be created from tags, folders, or dataviewJS query (if these are set).") 22 | nameSetting.addText(textField => { 23 | textField.setValue(this._noteSet.name) 24 | .setPlaceholder(this._noteSet.displayName) 25 | .onChange(value => { 26 | if (value === this._noteSet.name) { 27 | return; 28 | } 29 | this._noteSet.name = value != "" ? value : null; 30 | if (value == "") { 31 | textField.setPlaceholder(this._noteSet.displayName); 32 | } 33 | }) 34 | }); 35 | 36 | const tagsSetting = new Setting(contentEl); 37 | tagsSetting.setName("Tags"); 38 | tagsSetting.setDesc(`One or more tags, separated by comma. Note set will contain notes tagged with ${this._noteSet.tagsJoinType === JoinLogicOperators.AND ? "all" : "any"} of these. Example: #review, #knowledge`) 39 | tagsSetting.addTextArea(textArea => { 40 | textArea.setValue(this._noteSet.tags ? this._noteSet.tags.join(",") : "") 41 | .setPlaceholder("Tags") 42 | .onChange(value => { 43 | this._noteSet.tags = value != "" ? value.split(',').map(f => f.trim()) : []; 44 | }); 45 | }); 46 | 47 | const foldersSetting = new Setting(contentEl); 48 | foldersSetting.setName("Folders"); 49 | foldersSetting.setDesc(`One or more folder paths relative to vault root, surrounded by quotes and separated by comma. Note set will contain notes located in any of these. Top-level folders must not contain slash in their path. Example: "notes", "notes/programming"`) 50 | foldersSetting.addTextArea(textArea => { 51 | textArea.setValue(this._noteSet.folders ? this._noteSet.folders.join(',') : "") 52 | .setPlaceholder("Folders") 53 | .onChange(value => { 54 | this._noteSet.folders = value != "" ? value.split(',').map(f => f.trim()) : []; 55 | }); 56 | }); 57 | 58 | const createdDateSetting = new Setting(contentEl); 59 | createdDateSetting.setName("Created in last N days"); 60 | createdDateSetting.setDesc(`Number of days`); 61 | createdDateSetting.addText(text => { 62 | text.inputEl.type = 'number'; 63 | text.setValue(`${this._noteSet.createdInLastNDays}`); 64 | text.onChange(async (val) => { 65 | this._noteSet.createdInLastNDays = parseInt(val); 66 | } ); 67 | }); 68 | 69 | const modifiedDateSetting = new Setting(contentEl); 70 | modifiedDateSetting.setName("Modified in last N days"); 71 | modifiedDateSetting.setDesc(`Number of days`); 72 | modifiedDateSetting.addText(text => { 73 | text.inputEl.type = 'number'; 74 | text.setValue(`${this._noteSet.modifiedInLastNDays}`); 75 | text.onChange(async (val) => { 76 | this._noteSet.modifiedInLastNDays = parseInt(val); 77 | } ); 78 | }); 79 | 80 | 81 | 82 | 83 | // Advanced Settings 84 | 85 | const advancedSectionHeader = new Setting(contentEl); 86 | advancedSectionHeader.setHeading(); 87 | advancedSectionHeader.setName("Advanced Settings"); 88 | 89 | const advancedSectionBodyEl = contentEl.createDiv({cls: ["setting-body-advanced", "is-collapsed"]}); 90 | 91 | const tagJoinTypeSetting = new Setting(advancedSectionBodyEl); 92 | tagJoinTypeSetting.setName("If tags are specified, match notes with:") 93 | tagJoinTypeSetting.addDropdown(dropdown => { 94 | dropdown 95 | .addOption(JoinLogicOperators.OR, "any of the tags") 96 | .addOption(JoinLogicOperators.AND, "all of the tags") 97 | .setValue(this._noteSet.tagsJoinType as string || JoinLogicOperators.OR) 98 | .onChange((value: JoinLogicOperators) => { 99 | this._noteSet.tagsJoinType = value; 100 | } ) 101 | }); 102 | 103 | const folderTagJoinTypeSetting = new Setting(advancedSectionBodyEl); 104 | folderTagJoinTypeSetting.setName("If folders *and* tags are specified, match notes with: ") 105 | folderTagJoinTypeSetting.addDropdown(dropdown => { 106 | dropdown.addOption(JoinLogicOperators.OR, "specified tags OR in these folders").addOption(JoinLogicOperators.AND, "specified tags AND in these folders") 107 | .setValue(this._noteSet.foldersToTagsJoinType as string || JoinLogicOperators.OR) 108 | .onChange((value: JoinLogicOperators) => { 109 | this._noteSet.foldersToTagsJoinType = value; 110 | }) 111 | }); 112 | 113 | const dataviewQuerySetting = new Setting(advancedSectionBodyEl); 114 | dataviewQuerySetting.setName("DataviewJS query"); 115 | dataviewQuerySetting.setDesc(`DataviewJS-style query for more flexible control over the note set. If used, *overrides* Tags & Folders. Example: "(#knowledge and #review) or ('./notes')"`); 116 | dataviewQuerySetting.addTextArea(textArea => { 117 | textArea.setValue(this._noteSet.dataviewQuery) 118 | .setPlaceholder("DataviewJS query") 119 | .onChange(value => { 120 | this._noteSet.dataviewQuery = value; 121 | updateTagsFoldersSettingsAvailability(value); 122 | }); 123 | }); 124 | 125 | const saveBtn = new ButtonComponent(contentEl); 126 | saveBtn.setButtonText("Save"); 127 | saveBtn.onClick(async () => await this.save()); 128 | 129 | // Helpers 130 | 131 | const updateTagsFoldersSettingsAvailability = (dataviewJsQueryValue: string) : void => { 132 | const disableTagsFoldersSettings = dataviewJsQueryValue && (dataviewJsQueryValue != ""); 133 | if (disableTagsFoldersSettings) { 134 | tagsSetting.settingEl.style.opacity = "50%"; 135 | foldersSetting.settingEl.style.opacity = "50%"; 136 | } else { 137 | tagsSetting.settingEl.style.opacity = "100%"; 138 | foldersSetting.settingEl.style.opacity = "100%"; 139 | } 140 | tagsSetting.setDisabled(disableTagsFoldersSettings); 141 | foldersSetting.setDisabled(disableTagsFoldersSettings); 142 | } 143 | 144 | updateTagsFoldersSettingsAvailability(this._noteSet.dataviewQuery); 145 | 146 | } 147 | 148 | 149 | 150 | async save() { 151 | this._plugin.settings.noteSets.forEach((noteSet, index) => { 152 | if (noteSet.id === this._noteSet.id) { 153 | this._plugin.settings.noteSets[index] = this._noteSet; 154 | } 155 | }); 156 | this._plugin.noteSetService.validateRulesAndSave(this._noteSet); 157 | this._plugin.reviewService.resetNotesetQueueWithValidation(this._noteSet.id); 158 | this._plugin.noteSetService.updateNoteSetDisplayNameAndDescription(this._noteSet); 159 | this._plugin.noteSetService.updateNoteSetStats(this._noteSet); 160 | await this._plugin.saveSettings(); 161 | await this._plugin.activateView(); 162 | this._plugin.showNotice(`Saved note set "${this._noteSet.displayName}".`); 163 | this.close(); 164 | } 165 | 166 | } -------------------------------------------------------------------------------- /src/UI/noteset/noteSetInfoModal.ts: -------------------------------------------------------------------------------- 1 | import { App, Modal } from "obsidian"; 2 | import { INoteSet } from "../../noteSet/INoteSet"; 3 | import { NoteSetService } from "../../noteSet/noteSetService"; 4 | 5 | export class NoteSetInfoModal extends Modal { 6 | constructor(app: App, private noteSet: INoteSet, private service: NoteSetService) { 7 | super(app); 8 | } 9 | 10 | async onOpen() { 11 | this.service.updateNoteSetDisplayNameAndDescription(this.noteSet); 12 | await this.service.updateNoteSetStats(this.noteSet); 13 | const { contentEl } = this; 14 | 15 | contentEl.createEl("h3", {text: `Note set "${this.noteSet.displayName}"`}); 16 | contentEl.createDiv({text: `This query ${this.noteSet.description}.`}); 17 | contentEl.createEl("br"); 18 | let tableEl = contentEl.createEl("table"); 19 | let tbodyEl = tableEl.createEl("tbody"); 20 | 21 | this.addTableRow(tbodyEl, "Total notes", this.noteSet.stats.totalCount); 22 | this.addTableRow(tbodyEl, "Reviewed in last 7 days", this.noteSet.stats.reviewedLastSevenDaysCount); 23 | this.addTableRow(tbodyEl, "Reviewed in last 30 days", this.noteSet.stats.reviewedLastThirtyDaysCount); 24 | this.addTableRow(tbodyEl, "Not reviewed yet", this.noteSet.stats.notRewiewedCount); 25 | } 26 | 27 | private addTableRow(tbodyEl: HTMLElement, name: string, value: string | number): void { 28 | let valueStr = typeof value === 'number' ? value.toString() : value; 29 | 30 | let rowEl = tbodyEl.createEl("tr"); 31 | let nameRow = rowEl.createEl("td"); 32 | nameRow.setText(name); 33 | nameRow.style.paddingRight = "1rem"; 34 | rowEl.createEl("td").setText(valueStr); 35 | } 36 | 37 | onClose() { 38 | const { contentEl } = this; 39 | contentEl.empty(); 40 | } 41 | } -------------------------------------------------------------------------------- /src/UI/selectNoteSetModal.ts: -------------------------------------------------------------------------------- 1 | import SimpleNoteReviewPlugin from "main"; 2 | import { App, SuggestModal } from "obsidian"; 3 | import { INoteSet } from "../noteSet/INoteSet"; 4 | import { NoteSetEmptyError } from "src/noteSet/noteSetService"; 5 | 6 | export class SelectNoteSetModal extends SuggestModal { 7 | /** 8 | * 9 | */ 10 | constructor(private _app: App, private _plugin: SimpleNoteReviewPlugin) { 11 | super(_app); 12 | } 13 | 14 | getSuggestions(query: string): INoteSet[] { 15 | this.setPlaceholder("Select a note set to start reviewing notes"); 16 | return this._plugin.settings.noteSets.filter( 17 | q => { 18 | if (query === "") { 19 | return true; 20 | } 21 | 22 | const name = q.displayName; 23 | if (!name || name === "") { 24 | return false; 25 | } 26 | 27 | return name.toLowerCase().includes(query.toLowerCase()); 28 | }); 29 | } 30 | 31 | renderSuggestion(noteSet: INoteSet, el: HTMLElement) { 32 | el.createDiv({text: noteSet.displayName}); 33 | el.createEl("small", {text: noteSet.description}).style.opacity = "60%"; 34 | } 35 | 36 | async onChooseSuggestion(noteSet: INoteSet, evt: MouseEvent | KeyboardEvent) { 37 | try { 38 | await this._plugin.reviewService.startReview(noteSet.id); 39 | this._plugin.settings.currentNoteSetId = noteSet.id; 40 | this._plugin.showNotice(`Set current note set to ${noteSet.displayName}.`); 41 | this._plugin.saveSettings(); 42 | } 43 | catch (error) { 44 | if (error instanceof NoteSetEmptyError) { 45 | this._plugin.showNotice(`note set ${noteSet.displayName ?? noteSet.name} is empty.`) 46 | } 47 | throw error; 48 | } 49 | } 50 | 51 | } -------------------------------------------------------------------------------- /src/UI/settingsTab.ts: -------------------------------------------------------------------------------- 1 | import SimpleNoteReviewPlugin from "main"; 2 | import { App, PluginSettingTab, Setting } from "obsidian"; 3 | import { NoteSetDeleteModal } from "src/UI/noteset/noteSetDeleteModal"; 4 | import { NoteSetInfoModal } from "src/UI/noteset/noteSetInfoModal"; 5 | import { NoteSetEditModal } from "./noteset/noteSetEditModal"; 6 | 7 | export class SimpleNoteReviewPluginSettingsTab extends PluginSettingTab { 8 | constructor(private _plugin: SimpleNoteReviewPlugin, app: App) { 9 | super(app, _plugin); 10 | } 11 | 12 | refresh(): void { 13 | this.display(); 14 | } 15 | 16 | display(): void { 17 | const { containerEl } = this; 18 | 19 | containerEl.empty(); 20 | 21 | containerEl.createEl("h2", { text: "Simple Note Review Settings" }); 22 | 23 | // General settings 24 | 25 | new Setting(containerEl) 26 | .setName("Open next note in the note set after reviewing a note") 27 | .setDesc( 28 | "After marking note as reviewed, automatically open next note in the note set." 29 | ) 30 | .addToggle((toggle) => { 31 | toggle 32 | .setValue(this._plugin.settings.openNextNoteAfterReviewing) 33 | .onChange((value) => { 34 | this._plugin.settings.openNextNoteAfterReviewing = 35 | value; 36 | this._plugin.saveSettings(); 37 | }); 38 | }); 39 | 40 | new Setting(containerEl) 41 | .setName("Use review frequency") 42 | .setDesc( 43 | "Set review frequency level (high, normal, low, ignore) for each note. Notes with higher review frequency will be presented for review more often. Default is 'normal'." 44 | ) 45 | .addToggle((toggle) => { 46 | toggle 47 | .setValue(this._plugin.settings.useReviewFrequency) 48 | .onChange((value) => { 49 | this._plugin.settings.useReviewFrequency = value; 50 | this._plugin.saveSettings(); 51 | }); 52 | }); 53 | 54 | new Setting(containerEl) 55 | .setName("Start with unreviewed notes") 56 | .setDesc( 57 | "Start review with notes that have no review date. If turned off, notes without the review date will have lower priority than notes with early review dates." 58 | ) 59 | .addToggle((toggle) => { 60 | toggle 61 | .setValue(this._plugin.settings.unreviewedNotesFirst) 62 | .onChange((value) => { 63 | this._plugin.settings.unreviewedNotesFirst = value; 64 | this._plugin.saveSettings(); 65 | }); 66 | }); 67 | 68 | // NoteSet settings 69 | 70 | containerEl.createEl("h3", { text: "Note Sets" }); 71 | 72 | this._plugin.settings && 73 | this._plugin.settings.noteSets && 74 | this._plugin.settings.noteSets.forEach((noteSet, index) => { 75 | this._plugin.noteSetService.updateNoteSetDisplayNameAndDescription( 76 | noteSet 77 | ); 78 | 79 | // Header 80 | const setting = new Setting(containerEl); 81 | 82 | setting.setName(`Note Set "${noteSet.displayName}"`); 83 | 84 | const updateHeader = (text: string): void => { 85 | setting.setName(`Note Set "${text}"`); 86 | }; 87 | 88 | updateHeader(noteSet.displayName); 89 | 90 | if (noteSet?.validationErrors?.length > 0) { 91 | setting.addExtraButton((cb) => { 92 | cb.setIcon("alert-triangle") 93 | .setTooltip(noteSet?.validationErrors.join(";\n")); 94 | }); 95 | } 96 | 97 | setting.addExtraButton((cb) => { 98 | cb.setIcon("info") 99 | .setTooltip("Note set info & stats") 100 | .onClick(() => { 101 | new NoteSetInfoModal( 102 | this.app, 103 | noteSet, 104 | this._plugin.noteSetService 105 | ).open(); 106 | }); 107 | }); 108 | 109 | setting.addExtraButton((cb) => { 110 | cb.setIcon("rotate-cw") 111 | .setTooltip("Reset review queue and update stats for this note set") 112 | .onClick(async () => { 113 | await this._plugin.noteSetService.validateRulesAndSave(noteSet); 114 | await this._plugin.reviewService.resetNotesetQueueWithValidation(noteSet.id); 115 | await this._plugin.noteSetService.updateNoteSetStats(noteSet); 116 | this.display(); 117 | } 118 | ); 119 | }); 120 | 121 | setting.addExtraButton(cb => { 122 | cb.setIcon('arrow-up') 123 | .setTooltip("Move element up") 124 | .setDisabled(index === 0) 125 | .onClick(() => { 126 | if (index > 0) { 127 | const temp = this._plugin.settings.noteSets[index - 1].sortOrder; 128 | this._plugin.settings.noteSets[index - 1].sortOrder = noteSet.sortOrder; 129 | noteSet.sortOrder = temp; 130 | this._plugin.saveSettings(); 131 | this.display(); 132 | } 133 | }) 134 | }); 135 | 136 | setting.addExtraButton(cb => { 137 | cb.setIcon('arrow-down') 138 | .setTooltip("Move element down") 139 | .setDisabled(index >= this._plugin.settings.noteSets.length - 1) 140 | .onClick(() => { 141 | if (index < this._plugin.settings.noteSets.length - 1) { 142 | const temp = this._plugin.settings.noteSets[index + 1].sortOrder; 143 | this._plugin.settings.noteSets[index + 1].sortOrder = noteSet.sortOrder; 144 | noteSet.sortOrder = temp; 145 | this._plugin.saveSettings(); 146 | this.display(); 147 | } 148 | }) 149 | }); 150 | 151 | setting.addExtraButton((cb) => { 152 | cb.setIcon("edit") 153 | .setTooltip("Edit Note set") 154 | .onClick(() => { 155 | const modal = new NoteSetEditModal(noteSet, this._plugin); 156 | modal.open(); 157 | modal.onClose = () => { 158 | this.refresh(); 159 | }; 160 | }); 161 | }); 162 | 163 | setting.addExtraButton((cb) => { 164 | cb.setIcon("trash") 165 | .setTooltip("Delete note set") 166 | .onClick(async () => { 167 | new NoteSetDeleteModal( 168 | this.app, 169 | this, 170 | noteSet, 171 | this._plugin.noteSetService 172 | ).open(); 173 | }); 174 | }); 175 | }); 176 | 177 | new Setting(containerEl).addButton((btn) => { 178 | btn.setButtonText("Add Note Set"); 179 | btn.onClick(async () => { 180 | await this._plugin.noteSetService.addEmptyNoteSet(); 181 | this.refresh(); 182 | }); 183 | }); 184 | } 185 | } 186 | -------------------------------------------------------------------------------- /src/UI/sidebar/sidebarView.ts: -------------------------------------------------------------------------------- 1 | import SimpleNoteReviewPlugin from "main"; 2 | import { 3 | ItemView, 4 | Setting, 5 | WorkspaceLeaf, 6 | } from "obsidian"; 7 | import { INoteSet } from "src/noteSet/INoteSet"; 8 | import { NoteSetInfoModal } from "../noteset/noteSetInfoModal"; 9 | import { ReviewFrequency } from "src/noteSet/reviewFrequency"; 10 | import { NoteSetEmptyError } from "src/noteSet/noteSetService"; 11 | 12 | export class SimpleNoteReviewSidebarView extends ItemView { 13 | static readonly VIEW_TYPE = "simple-note-review-sidebar-view"; 14 | static readonly DISPLAY_TEXT = "Simple Note Review"; 15 | static readonly SNR_ICON_NAME = "glasses"; 16 | 17 | constructor(leaf: WorkspaceLeaf, private _plugin: SimpleNoteReviewPlugin) { 18 | super(leaf); 19 | } 20 | 21 | async onOpen() { 22 | await this.renderView(); 23 | } 24 | 25 | async onClose() { 26 | // Nothing to clean up. 27 | } 28 | 29 | async renderView(): Promise { 30 | this.contentEl.empty(); 31 | 32 | this.createGeneralActionsEl(this.contentEl); 33 | 34 | this.createCurrentFileActionsEl(this.contentEl); 35 | 36 | this.contentEl.createEl("h4", { text: "Note Sets" }); 37 | 38 | this._plugin.settings.noteSets.forEach((noteSet) => { 39 | this.createNotesetSection(noteSet); 40 | }); 41 | } 42 | 43 | private createGeneralActionsEl(parentEl: HTMLElement): HTMLElement { 44 | const actionsEl = new Setting(parentEl); 45 | 46 | actionsEl.setDesc("general actions:"); 47 | 48 | actionsEl.addExtraButton((cb) => { 49 | cb.setIcon("refresh-cw") 50 | .setTooltip("refresh sidebar") 51 | .onClick(async () => { 52 | await this.onOpen(); 53 | }); 54 | }); 55 | 56 | actionsEl.addExtraButton((cb) => { 57 | cb.setIcon("settings") 58 | .setTooltip("open plugin settings") 59 | .onClick(() => { 60 | // eslint-disable-next-line @typescript-eslint/no-explicit-any 61 | (this.app as any).setting.open(); 62 | // eslint-disable-next-line @typescript-eslint/no-explicit-any 63 | (this.app as any).setting.openTabById("simple-note-review"); 64 | }); 65 | }); 66 | 67 | return actionsEl.settingEl; 68 | } 69 | 70 | private createCurrentFileActionsEl(parentEl: HTMLElement): HTMLElement { 71 | const actionsEl = new Setting(parentEl); 72 | 73 | actionsEl.setDesc("current file actions:"); 74 | 75 | actionsEl.addExtraButton((cb) => { 76 | cb.setIcon("ban") 77 | .setTooltip("ignore this note in all reviews") 78 | .onClick(() => { 79 | this._plugin.fileService.setReviewFrequency( 80 | this.app.workspace.getActiveFile(), 81 | ReviewFrequency.ignore 82 | ); 83 | }); 84 | }); 85 | 86 | actionsEl.addExtraButton((cb) => { 87 | cb.setIcon("signal-low") 88 | .setTooltip("set review frequency to low") 89 | .onClick(() => { 90 | this._plugin.fileService.setReviewFrequency( 91 | this.app.workspace.getActiveFile(), 92 | ReviewFrequency.low 93 | ); 94 | }); 95 | }); 96 | 97 | actionsEl.addExtraButton((cb) => { 98 | cb.setIcon("signal-medium") 99 | .setTooltip("set review frequency to normal") 100 | .onClick(() => { 101 | this._plugin.fileService.setReviewFrequency( 102 | this.app.workspace.getActiveFile(), 103 | ReviewFrequency.normal 104 | ); 105 | }); 106 | }); 107 | 108 | actionsEl.addExtraButton((cb) => { 109 | cb.setIcon("signal") 110 | .setTooltip("set review frequency to high") 111 | .onClick(() => { 112 | this._plugin.fileService.setReviewFrequency( 113 | this.app.workspace.getActiveFile(), 114 | ReviewFrequency.high 115 | ); 116 | }); 117 | }); 118 | 119 | actionsEl.addExtraButton((cb) => { 120 | cb.setIcon("skip-forward") 121 | .setTooltip("skip note for current review") 122 | .onClick(() => { 123 | this._plugin.reviewService.skipNote( 124 | this.app.workspace.getActiveFile(), 125 | this._plugin.settings.currentNoteSetId 126 | ); 127 | }); 128 | }); 129 | 130 | actionsEl.addExtraButton((cb) => { 131 | cb.setIcon("file-check") 132 | .setTooltip( 133 | "mark current note as reviewed & go to the next file" 134 | ) 135 | .onClick(() => { 136 | this._plugin.reviewService.reviewNote( 137 | this.app.workspace.getActiveFile(), 138 | this._plugin.settings.currentNoteSetId 139 | ); 140 | }); 141 | }); 142 | 143 | return actionsEl.settingEl; 144 | } 145 | 146 | private createNotesetSection(noteSet: INoteSet): HTMLElement { 147 | const section = new Setting(this.contentEl); 148 | 149 | const trimmedName = 150 | noteSet.displayName.length > 20 151 | ? noteSet.displayName.substring(0, 20) + "..." 152 | : noteSet.displayName; 153 | section.setName(trimmedName); 154 | 155 | if ( 156 | this._plugin.settings.currentNoteSetId && 157 | this._plugin.settings.currentNoteSetId === noteSet.id 158 | ) { 159 | section.setDesc("current note set"); 160 | } else { 161 | section.setDesc(""); 162 | } 163 | 164 | if (noteSet?.validationErrors?.length > 0) { 165 | section.addExtraButton((cb) => { 166 | cb.setIcon("alert-triangle") 167 | .setTooltip(noteSet?.validationErrors.join(";\n")); 168 | }); 169 | } 170 | 171 | section.addExtraButton((cb) => { 172 | cb.setIcon("info") 173 | .setTooltip("view note set info & stats") 174 | .onClick(() => { 175 | new NoteSetInfoModal( 176 | this.app, 177 | noteSet, 178 | this._plugin.noteSetService 179 | ).open(); 180 | }); 181 | }); 182 | 183 | section.addExtraButton((cb) => { 184 | cb.setIcon("dices") 185 | .setTooltip("open random note from this note set") 186 | .onClick(async () => 187 | this.startReviewWithDelegate( 188 | noteSet.id, 189 | this._plugin.reviewService.openRandomNoteInQueue 190 | ) 191 | ); 192 | }); 193 | 194 | // TODO: confirmation window 195 | section.addExtraButton((cb) => { 196 | cb.setIcon("rotate-cw") 197 | .setTooltip("reset review queue for this note set") 198 | .onClick(async () => { 199 | await this._plugin.noteSetService.validateRulesAndSave(noteSet); 200 | await this._plugin.reviewService.resetNotesetQueueWithValidation(noteSet.id); 201 | await this.renderView(); 202 | } 203 | ); 204 | }); 205 | 206 | section.addExtraButton((cb) => { 207 | cb.setIcon("play") 208 | .setTooltip("review this note set") 209 | .onClick(async () => 210 | this.startReviewWithDelegate( 211 | noteSet.id, 212 | this._plugin.reviewService.startReview 213 | ) 214 | ); 215 | }); 216 | 217 | return section.settingEl; 218 | } 219 | 220 | getViewType(): string { 221 | return SimpleNoteReviewSidebarView.VIEW_TYPE; 222 | } 223 | 224 | getDisplayText(): string { 225 | return SimpleNoteReviewSidebarView.DISPLAY_TEXT; 226 | } 227 | 228 | getIcon(): string { 229 | return SimpleNoteReviewSidebarView.SNR_ICON_NAME; 230 | } 231 | 232 | private async startReviewWithDelegate( 233 | noteSetId: string, 234 | delegate: (noteSetId: string) => Promise 235 | ) { 236 | const noteSet = this._plugin.noteSetService.getNoteSet(noteSetId); 237 | try { 238 | await delegate.bind(this._plugin.reviewService)(noteSetId); 239 | } catch (error) { 240 | const noteSet = this._plugin.noteSetService.getNoteSet(noteSetId); 241 | if (error instanceof NoteSetEmptyError) { 242 | this._plugin.showNotice(`note set ${noteSet.displayName ?? noteSet.name} is empty.`) 243 | } 244 | throw error; 245 | } 246 | 247 | if (this._plugin.settings.currentNoteSetId !== noteSet.id) { 248 | this._plugin.settings.currentNoteSetId = noteSet.id; 249 | await this._plugin.saveSettings(); 250 | this._plugin.showNotice( 251 | `Set current note set to ${noteSet.displayName}.` 252 | ); 253 | } 254 | this._plugin.activateView(); 255 | } 256 | } 257 | -------------------------------------------------------------------------------- /src/dataview/dataviewFacade.ts: -------------------------------------------------------------------------------- 1 | import { getAPI, DataviewApi, DataArray } from "obsidian-dataview"; 2 | 3 | export class DataviewNotInstalledError extends Error { 4 | constructor() { 5 | super(); 6 | this.message = "Dataview plugin not installed. To use Simple Note Review, Dataview plugin is needed."; 7 | } 8 | } 9 | 10 | export class DataviewFacade { 11 | private _api: DataviewApi; 12 | public isDataviewInstalled = false; 13 | 14 | constructor() { 15 | try { 16 | this._api = getAPI(); 17 | if (this._api) 18 | this.isDataviewInstalled = true; 19 | } catch (error) { 20 | throw new DataviewNotInstalledError(); 21 | } 22 | } 23 | 24 | public isDataviewInitialized(): boolean { 25 | return this._api.index.initialized; 26 | } 27 | 28 | public async pages(query: string): Promise>> { 29 | return await this.invokeAndReinitDvCacheOnError(() => this._api.pages(query)); 30 | } 31 | 32 | public async page(filepath: string): Promise> { 33 | return await this.invokeAndReinitDvCacheOnError(() => this._api.page(filepath)); 34 | } 35 | 36 | public async validate(query: string): Promise { 37 | const result = await this.invokeAndReinitDvCacheOnError(() => this._api.query(`LIST FROM ${query}`)); 38 | return result.successful; 39 | } 40 | 41 | public async getMetadataFieldValue(filepath: string, fieldName: string): Promise { 42 | const page = await this.page(filepath); 43 | return page[fieldName]; 44 | } 45 | 46 | private async invokeAndReinitDvCacheOnError(func: (...args: any[]) 47 | => TReturn, ...args: any[]): Promise { 48 | try { 49 | if (!this.isDataviewInstalled) 50 | throw new DataviewNotInstalledError(); 51 | return func(args); 52 | } catch (error) { 53 | await this._api.index.reinitialize(); 54 | return func(args); 55 | } 56 | } 57 | } -------------------------------------------------------------------------------- /src/dataview/dataviewService.ts: -------------------------------------------------------------------------------- 1 | import { DataArray } from "obsidian-dataview"; 2 | import { DataviewFacade, DataviewNotInstalledError } from "src/dataview/dataviewFacade"; 3 | import { getDateOffsetByNDays } from "src/utils/dateUtils"; 4 | import { INoteSet } from "../noteSet/INoteSet"; 5 | import { DataviewQueryError } from "../noteSet/noteSetService"; 6 | 7 | 8 | export class DataviewService { 9 | private _dataviewApi = new DataviewFacade(); 10 | 11 | get isDataviewInitialized(): boolean { 12 | return this._dataviewApi.isDataviewInitialized(); 13 | } 14 | 15 | public async getNoteSetFiles(noteSet: INoteSet): Promise>> { 16 | const query = this.getOrCreateBaseDataviewQuery(noteSet); 17 | try { 18 | let pages = await this._dataviewApi.pages(query); 19 | if (noteSet.createdInLastNDays) { 20 | pages = pages.where(p => p.file.cday > getDateOffsetByNDays(noteSet.createdInLastNDays)); 21 | } 22 | if (noteSet.modifiedInLastNDays) { 23 | pages = pages.where(p => p.file.mday > getDateOffsetByNDays(noteSet.modifiedInLastNDays)); 24 | } 25 | return pages; 26 | } catch (error) { 27 | if (error instanceof DataviewNotInstalledError) { 28 | throw error; 29 | } else { 30 | console.error(`Simple Note Review - dataview API error: ${error.message}`); 31 | throw new DataviewQueryError(`Error while trying to get next note in noteset "${query}" via Dataview API. Please check noteset settings and/or disabling and enabling Simple Note Review plugin again.`) 32 | } 33 | } 34 | } 35 | 36 | public getOrCreateBaseDataviewQuery(noteSet: INoteSet): string { 37 | if (noteSet.dataviewQuery && noteSet.dataviewQuery != "") 38 | return noteSet.dataviewQuery; 39 | 40 | let tags = ""; 41 | let folders = ""; 42 | if (noteSet.tags) { 43 | tags = noteSet.tags.map(p => { 44 | if (p[0] !== "#") return "#" + p; 45 | return p; 46 | }).join(` ${noteSet.tagsJoinType || "or"} `); 47 | } 48 | 49 | if (noteSet.folders) { 50 | folders = noteSet.folders.join(" or "); 51 | } 52 | 53 | if (tags && folders) return `(${tags}) ${noteSet.foldersToTagsJoinType || "or"} (${folders})`; 54 | 55 | if (tags) return tags; 56 | 57 | if (folders) return folders; 58 | 59 | return null; 60 | } 61 | 62 | public validateQuery(query: string): Promise { 63 | return this._dataviewApi.validate(query); 64 | } 65 | 66 | public getPageFromPath(filepath: string): Record { 67 | return this._dataviewApi.page(filepath); 68 | } 69 | 70 | public async getMetadataFieldValue(filepath: string, fieldName: string): Promise { 71 | return await this._dataviewApi.getMetadataFieldValue(filepath, fieldName); 72 | } 73 | 74 | 75 | } -------------------------------------------------------------------------------- /src/noteSet/INoteSet.ts: -------------------------------------------------------------------------------- 1 | import { INoteQueue } from "src/queues/noteQueue" 2 | import { JoinLogicOperators } from "../settings/joinLogicOperators" 3 | import { INoteSetStats } from "./INoteSetStats" 4 | import { NotesetValidationErrors } from "./notesetValidationErrors" 5 | 6 | // TODO: excluded tags, folders, frontmatter keys 7 | export interface INoteSet { 8 | id: string 9 | sortOrder: number | undefined 10 | name: string 11 | displayName: string 12 | description: string 13 | tags: string[] 14 | tagsJoinType: JoinLogicOperators 15 | folders: string[] 16 | foldersToTagsJoinType: JoinLogicOperators 17 | createdInLastNDays: number | undefined 18 | modifiedInLastNDays: number | undefined 19 | dataviewQuery: string 20 | stats: INoteSetStats 21 | queue: INoteQueue 22 | validationErrors: NotesetValidationErrors[] 23 | } 24 | 25 | export class EmptyNoteSet implements INoteSet { 26 | id = crypto.randomUUID() 27 | sortOrder: undefined 28 | name: "new note set" 29 | displayName: string 30 | description: string 31 | tags: [] 32 | tagsJoinType: JoinLogicOperators.OR 33 | folders: [] 34 | foldersToTagsJoinType: JoinLogicOperators.OR 35 | createdInLastNDays: undefined 36 | modifiedInLastNDays: undefined 37 | dataviewQuery: "" 38 | stats: INoteSetStats 39 | queue: INoteQueue 40 | validationErrors: [] 41 | } -------------------------------------------------------------------------------- /src/noteSet/INoteSetStats.ts: -------------------------------------------------------------------------------- 1 | export interface INoteSetStats { 2 | totalCount: number, 3 | notRewiewedCount: number, 4 | reviewedLastSevenDaysCount: number, 5 | reviewedLastThirtyDaysCount: number 6 | } -------------------------------------------------------------------------------- /src/noteSet/noteReviewPriorityHelpers.ts: -------------------------------------------------------------------------------- 1 | import SimpleNoteReviewPlugin from "main"; 2 | import { ReviewFrequency } from "./reviewFrequency"; 3 | import { getNumberOfDaysFromToday } from "src/utils/dateUtils"; 4 | 5 | /** Calculate Note review priority score. (days elapsed from last review * (review frequency rank ** 2)) 6 | * @param {SimpleNoteReviewPlugin} plugin 7 | * @param {Record} note 8 | * @returns number 9 | */ 10 | export function calculateNoteReviewPriority(plugin: SimpleNoteReviewPlugin, note: Record): number { 11 | const reviewedFieldName = plugin.settings.reviewedFieldName; 12 | const frequencyFieldName = plugin.settings.reviewFrequencyFieldName; 13 | 14 | let score = 0; 15 | 16 | switch (note[frequencyFieldName]) { 17 | case ReviewFrequency.high: 18 | score = 5; 19 | break; 20 | case null: 21 | case "": 22 | case undefined: 23 | score = 4; 24 | break; 25 | case ReviewFrequency.normal: 26 | score = 3; 27 | break; 28 | case ReviewFrequency.low: 29 | score = 2; 30 | break; 31 | case ReviewFrequency.ignore: 32 | score = 0; 33 | return score; // ignored notes always get zero score 34 | default: 35 | throw new Error("Review Frequency error!"); 36 | } 37 | 38 | let multiplier = 1; 39 | 40 | if (note[reviewedFieldName] == null || note[reviewedFieldName] == "" || note[reviewedFieldName] == undefined) 41 | multiplier = plugin.settings.unreviewedNotesFirst ? 10000 : 300; 42 | else 43 | multiplier = getNumberOfDaysFromToday(note[reviewedFieldName]); 44 | 45 | return (score ** 2) * multiplier; 46 | } -------------------------------------------------------------------------------- /src/noteSet/noteSetInfoService.ts: -------------------------------------------------------------------------------- 1 | import { JoinLogicOperators } from "src/settings/joinLogicOperators"; 2 | import { INoteSet } from "./INoteSet"; 3 | import { DataviewService } from "../dataview/dataviewService"; 4 | import { getDateOffsetByNDays } from "src/utils/dateUtils"; 5 | import { NoteSetService } from "./noteSetService"; 6 | 7 | export class NoteSetInfoService { 8 | 9 | constructor(private _dataviewService: DataviewService) { } 10 | 11 | public async updateNoteSetStats(noteSet: INoteSet): Promise { 12 | const pages = await this._dataviewService.getNoteSetFiles(noteSet); 13 | noteSet.stats = { 14 | totalCount: pages.length, 15 | notRewiewedCount: pages.where(p => !p.reviewed).length, 16 | reviewedLastSevenDaysCount: pages.where(p => p.reviewed > getDateOffsetByNDays(7)).length, 17 | reviewedLastThirtyDaysCount: pages.where(p => p.reviewed > getDateOffsetByNDays(30)).length 18 | } 19 | } 20 | 21 | public updateNoteSetDisplayNameAndDescription(noteSet: INoteSet) { 22 | noteSet.displayName = this.getNoteSetDisplayName(noteSet); 23 | noteSet.description = this.getNoteSetDescription(noteSet); 24 | } 25 | 26 | private getNoteSetDisplayName(noteSet: INoteSet): string { 27 | if (noteSet.name && noteSet.name !== "" ) { 28 | return noteSet.name; 29 | } 30 | const alias = this._dataviewService.getOrCreateBaseDataviewQuery(noteSet); 31 | return alias && alias != "" ? alias : "blank note set"; 32 | } 33 | 34 | private getNoteSetDescription(noteSet: INoteSet): string { 35 | 36 | if (this.queryMatchesAllNotes(noteSet)) { 37 | return NoteSetService.MATCHES_ALL_STRING; 38 | } 39 | 40 | const desc: string[] = []; 41 | 42 | if (noteSet.dataviewQuery && noteSet.dataviewQuery !== "") { 43 | desc.push(`are matched with dataviewJS query ${noteSet.dataviewQuery}; `); 44 | } 45 | 46 | if (noteSet.tags && noteSet.tags?.length > 0) { 47 | let tagString = `contain ${noteSet.tagsJoinType === JoinLogicOperators.AND ? "all" : "any"} of these tags: ${noteSet.tags.join(", ")}`; 48 | if (noteSet.folders && noteSet.folders?.length > 0) { 49 | tagString += ` ${noteSet.foldersToTagsJoinType === JoinLogicOperators.AND ? "and" : "or"} `; 50 | } 51 | desc.push(tagString); 52 | } 53 | 54 | if (noteSet.folders && noteSet.folders?.length > 0) { 55 | desc.push(`are inside any of these folders (including nested folders): ${noteSet.folders.join(", ")}`); 56 | } 57 | 58 | if (noteSet.createdInLastNDays) { 59 | desc.push(`are created in the last ${noteSet.createdInLastNDays} days`); 60 | } 61 | 62 | if (noteSet.modifiedInLastNDays) { 63 | desc.push(`are modified in the last ${noteSet.modifiedInLastNDays} days`); 64 | } 65 | 66 | return `matches notes that: ` + desc.join("; "); 67 | } 68 | 69 | private queryMatchesAllNotes(noteset: INoteSet): boolean { 70 | return !(this._dataviewService.getOrCreateBaseDataviewQuery(noteset) || noteset.createdInLastNDays || noteset.createdInLastNDays); 71 | } 72 | 73 | 74 | } -------------------------------------------------------------------------------- /src/noteSet/noteSetService.ts: -------------------------------------------------------------------------------- 1 | import { EmptyNoteSet, INoteSet } from "./INoteSet"; 2 | import { App, TAbstractFile } from "obsidian"; 3 | import SimpleNoteReviewPlugin from "main"; 4 | import { DataviewService } from "../dataview/dataviewService"; 5 | import { NoteSetInfoService } from "./noteSetInfoService"; 6 | import { NotesetValidationErrors } from "./notesetValidationErrors"; 7 | 8 | export class NoteSetEmptyError extends Error { 9 | message = 10 | "Could not get the next note in note set. Please check note set settings and make sure it has notes."; 11 | } 12 | export class OpenNextFileInNoteSetError extends Error { 13 | message = 14 | "Could not open next note in note set. If this keeps happening, please try to disable and enable plugin. If that fails, try to restart Obsidian."; 15 | } 16 | 17 | export class DataviewQueryError extends Error {} 18 | 19 | export class NoteSetService { 20 | private _dataviewService = new DataviewService(); 21 | private _noteSetInfoService = new NoteSetInfoService(this._dataviewService); 22 | 23 | public static readonly MATCHES_ALL_STRING = "matches all notes"; 24 | 25 | constructor(private _app: App, private _plugin: SimpleNoteReviewPlugin) {} 26 | 27 | public getNoteSet(noteSetId: string): INoteSet { 28 | const notesets = this._plugin.settings.noteSets.filter(x => x.id === noteSetId); 29 | if (notesets.length === 0) { 30 | throw new Error(`Noteset not found`); 31 | } 32 | return notesets[0]; 33 | } 34 | 35 | public async saveNoteSet(noteSet: INoteSet) { 36 | if (!noteSet.id) { 37 | noteSet.id = crypto.randomUUID(); 38 | } 39 | this._plugin.settings.noteSets = this._plugin.settings.noteSets.filter( 40 | (x) => x.id !== noteSet.id 41 | ); 42 | this._plugin.settings.noteSets.push(noteSet); 43 | this._plugin.saveSettings(); 44 | } 45 | 46 | public async deleteNoteSet(noteSet: INoteSet) { 47 | this._plugin.settings.noteSets = this._plugin.settings.noteSets.filter( 48 | (q) => q.id !== noteSet.id 49 | ); 50 | await this._plugin.saveSettings(); 51 | } 52 | 53 | public async addEmptyNoteSet() { 54 | const emptyNoteSet = new EmptyNoteSet(); 55 | this.saveNoteSet(emptyNoteSet); 56 | } 57 | 58 | public updateNoteSetDisplayNames() { 59 | this._plugin.settings.noteSets.forEach((q) => 60 | this.updateNoteSetDisplayNameAndDescription(q) 61 | ); 62 | } 63 | 64 | public updateNoteSetDisplayNameAndDescription(noteSet: INoteSet) { 65 | this._noteSetInfoService.updateNoteSetDisplayNameAndDescription( 66 | noteSet 67 | ); 68 | } 69 | 70 | public sortNoteSets(noteSets: INoteSet[]): INoteSet[] { 71 | // Find the highest sortOrder that is defined 72 | const maxSortOrder = noteSets.reduce((max, note) => { 73 | if (note.sortOrder !== undefined && note.sortOrder > max) { 74 | return note.sortOrder; 75 | } 76 | return max; 77 | }, 0); 78 | 79 | // Fill undefined sortOrder values with incrementing numbers starting from maxSortOrder + 1 80 | let nextSortOrder = maxSortOrder + 1; 81 | const filledNotes = noteSets.map((noteSet) => ({ 82 | ...noteSet, 83 | sortOrder: 84 | noteSet.sortOrder !== undefined 85 | ? noteSet.sortOrder 86 | : nextSortOrder++, 87 | })); 88 | 89 | // Now, sort the notes array by sortOrder 90 | filledNotes.sort((a, b) => a.sortOrder - b.sortOrder); 91 | 92 | return filledNotes; 93 | } 94 | 95 | public async updateNoteSetStats(noteSet: INoteSet): Promise { 96 | await this._noteSetInfoService.updateNoteSetStats(noteSet); 97 | } 98 | 99 | public async validateAllNotesets(): Promise { 100 | await Promise.all( 101 | this._plugin.settings.noteSets.map((noteset) => 102 | this.validateRulesAndSave(noteset) 103 | ) 104 | ); 105 | } 106 | 107 | public async validateRulesAndSave(noteSet: INoteSet): Promise { 108 | const validationErrors = await this.getValidationErrors(noteSet); 109 | noteSet.validationErrors = validationErrors; 110 | await this.saveNoteSet(noteSet); 111 | } 112 | 113 | public async onPhysicalDeleteNote(note: TAbstractFile) { 114 | this._plugin.settings.noteSets.forEach(x => x.queue.filenames.remove(note.path)); 115 | this._plugin.saveSettings(); 116 | } 117 | 118 | private async getValidationErrors( 119 | noteset: INoteSet 120 | ): Promise { 121 | const errors: NotesetValidationErrors[] = []; 122 | 123 | if (!noteset.queue?.filenames?.length) 124 | errors.push(NotesetValidationErrors.QueueEmpty); 125 | 126 | const customDvQueryIsValid = 127 | !noteset.dataviewQuery || 128 | (await this._dataviewService.validateQuery(noteset.dataviewQuery)); 129 | if (!customDvQueryIsValid) 130 | errors.push(NotesetValidationErrors.CustomDataviewIncorrect); 131 | 132 | const constructedDvQuery = 133 | this._dataviewService.getOrCreateBaseDataviewQuery(noteset); 134 | const constructedDvQueryIsValid = 135 | await this._dataviewService.validateQuery(constructedDvQuery); 136 | if (!constructedDvQueryIsValid) 137 | errors.push(NotesetValidationErrors.RulesAreIncorrect); 138 | 139 | if (this._dataviewService.isDataviewInitialized) { 140 | const queueActual = await this._dataviewService.getNoteSetFiles(noteset); 141 | 142 | if (!queueActual?.length || queueActual.length === 0) { 143 | errors.push(NotesetValidationErrors.RulesDoNotMatchAnyNotes); 144 | } 145 | } 146 | return errors; 147 | } 148 | } 149 | -------------------------------------------------------------------------------- /src/noteSet/notesetValidationErrors.ts: -------------------------------------------------------------------------------- 1 | 2 | export enum NotesetValidationErrors { 3 | QueueEmpty = "Noteset review queue is empty. If this seems wrong, try resetting queue and/or checking noteset rules.", 4 | RulesAreIncorrect = "Noteset rules are incorrect. Please check noteset settings.", 5 | CustomDataviewIncorrect = "Custom DataviewJS query is incorrect. Please check noteset settings.", 6 | RulesDoNotMatchAnyNotes = "Noteset rules do not match any notes.", 7 | } -------------------------------------------------------------------------------- /src/noteSet/reviewFrequency.ts: -------------------------------------------------------------------------------- 1 | export enum ReviewFrequency { 2 | high = "high", 3 | normal = "normal", 4 | low = "low", 5 | ignore = "ignore" 6 | } -------------------------------------------------------------------------------- /src/notes/fileService.ts: -------------------------------------------------------------------------------- 1 | import SimpleNoteReviewPlugin from "main"; 2 | import { App, TAbstractFile, TFile } from "obsidian"; 3 | import { DataviewService } from "src/dataview/dataviewService"; 4 | import { ReviewFrequency } from "src/noteSet/reviewFrequency"; 5 | import { getTodayAsYyyyMmDd } from "src/utils/dateUtils"; 6 | import { MetadataService } from "src/utils/metadataService"; 7 | 8 | 9 | export class FileService { 10 | private _dataviewService = new DataviewService(); 11 | private _metadataService = new MetadataService(this._app); 12 | 13 | constructor(private _app: App, private _plugin: SimpleNoteReviewPlugin) { } 14 | 15 | public async setReviewFrequency(note: TAbstractFile, frequency: ReviewFrequency): Promise { 16 | if (!(note instanceof TFile)) 17 | return; 18 | try { 19 | await this._metadataService.setAndSaveMetadataFieldValue(note, 20 | { 21 | name: this._plugin.settings.reviewFrequencyFieldName, 22 | value: frequency 23 | }); 24 | } catch (error) { 25 | this._plugin.showNotice(error.message); 26 | throw error; 27 | } 28 | } 29 | 30 | public async setReviewedToToday(file: TFile): Promise { 31 | const todayString = getTodayAsYyyyMmDd(); // "yyyy-mm-dd" 32 | 33 | const fieldsToSet = [{ 34 | name: this._plugin.settings.reviewedFieldName, 35 | value: todayString 36 | }]; 37 | 38 | if (this._plugin.settings.useReviewFrequency) { 39 | const reviewFrequency = await this.getReviewFrequency(file); 40 | fieldsToSet.push({ 41 | name: this._plugin.settings.reviewFrequencyFieldName, 42 | value: reviewFrequency ?? ReviewFrequency.normal 43 | } 44 | ); 45 | } 46 | 47 | await this._metadataService.setAndSaveMetadataFieldsValue(file, fieldsToSet); 48 | this._plugin.showNotice(`Marked note "${file.path}" as reviewed today.`) 49 | } 50 | 51 | private async getReviewFrequency(file: TFile): Promise { 52 | 53 | const frequencyValue = await this._dataviewService.getMetadataFieldValue( 54 | file.path, this._plugin.settings.reviewFrequencyFieldName); 55 | 56 | switch (frequencyValue) { 57 | case ReviewFrequency.high: 58 | return ReviewFrequency.high; 59 | case ReviewFrequency.normal: 60 | return ReviewFrequency.normal; 61 | case ReviewFrequency.low: 62 | return ReviewFrequency.low; 63 | case ReviewFrequency.ignore: 64 | return ReviewFrequency.ignore; 65 | default: 66 | return null; 67 | } 68 | } 69 | } -------------------------------------------------------------------------------- /src/queues/noteQueue.ts: -------------------------------------------------------------------------------- 1 | 2 | export interface INoteQueue { 3 | filenames: string[] // TODO 4 | } 5 | 6 | export class NoteQueue implements INoteQueue { 7 | filenames: string[] 8 | 9 | constructor(filePaths: string[]) { 10 | this.filenames = filePaths; 11 | } 12 | } 13 | -------------------------------------------------------------------------------- /src/queues/reviewService.ts: -------------------------------------------------------------------------------- 1 | import SimpleNoteReviewPlugin from "main"; 2 | import { App, TAbstractFile, TFile } from "obsidian"; 3 | import { NoteQueue } from "./noteQueue"; 4 | import { DataArray } from "obsidian-dataview"; 5 | import { INoteSet } from "src/noteSet/INoteSet"; 6 | import { calculateNoteReviewPriority } from "src/noteSet/noteReviewPriorityHelpers"; 7 | import { ReviewFrequency } from "src/noteSet/reviewFrequency"; 8 | import { DataviewService } from "src/dataview/dataviewService"; 9 | 10 | export class ReviewService { 11 | private _dataviewService = new DataviewService(); 12 | 13 | constructor(private _app: App, private _plugin: SimpleNoteReviewPlugin) {} 14 | 15 | public async startReview(noteSetId: string): Promise { 16 | const noteset = this._plugin.noteSetService.getNoteSet(noteSetId); 17 | await this.createNotesetQueueIfNotExists(noteset); 18 | await this.openNextNoteInQueue(noteset); 19 | } 20 | 21 | public async resetNotesetQueueWithValidation(noteSetId: string): Promise { 22 | const noteset = this._plugin.noteSetService.getNoteSet(noteSetId); 23 | await this.createNotesetQueueWithValidation(noteset); 24 | } 25 | 26 | /** Mark note as reviewed today. If setting "open next note in noteSet after reviewing" is enabled, 27 | * open next note in noteSet (current noteSet by default). 28 | * @param {TAbstractFile} note 29 | * @param {INoteSet=this._plugin.settings.currentnoteSet} noteSet 30 | * @returns Promise 31 | */ 32 | public async reviewNote( 33 | note: TAbstractFile, 34 | noteSetId: string 35 | ): Promise { 36 | // "note" must be an actual note, not folder 37 | if (!(note instanceof TFile)) return; 38 | 39 | const noteSet = this._plugin.noteSetService.getNoteSet(noteSetId); 40 | 41 | try { 42 | this._plugin.fileService.setReviewedToToday(note); 43 | this.removeNoteFromQueue(note, noteSet); 44 | } catch (error) { 45 | this._plugin.showNotice(error.message); 46 | } 47 | 48 | if (this._plugin.settings.openNextNoteAfterReviewing) { 49 | await this.openNextNoteInQueue(noteSet); 50 | } 51 | } 52 | 53 | public async openRandomNoteInQueue(noteSetId: string) { 54 | const noteSet = this._plugin.noteSetService.getNoteSet(noteSetId); 55 | 56 | await this.createNotesetQueueIfNotExists(noteSet); 57 | 58 | const randomIndex = Math.floor( 59 | Math.random() * noteSet.queue.filenames.length 60 | ); 61 | const filePath = noteSet.queue.filenames[randomIndex]; 62 | const abstractFile = this._app.vault.getAbstractFileByPath(filePath); 63 | await this._app.workspace 64 | .getMostRecentLeaf() 65 | .openFile(abstractFile as TFile); 66 | } 67 | 68 | public async skipNote( 69 | note: TAbstractFile, 70 | noteSetId: string 71 | ): Promise { 72 | // TODO: check if current note is in queue 73 | const noteSet = this._plugin.noteSetService.getNoteSet(noteSetId); 74 | this.removeNoteFromQueue(note, noteSet); 75 | await this.openNextNoteInQueue(noteSet); 76 | } 77 | 78 | private async removeNoteFromQueue( 79 | note: TAbstractFile, 80 | noteSet: INoteSet 81 | ): Promise { 82 | noteSet.queue.filenames.remove(note.path); 83 | await this._plugin.noteSetService.saveNoteSet(noteSet); 84 | } 85 | 86 | private async openNextNoteInQueue(noteSet: INoteSet): Promise { 87 | const errorMsgBase = `Error opening next note in note set ${noteSet.displayName}: \n`; 88 | if (!noteSet.queue?.filenames?.length) { 89 | this._plugin.showNotice(errorMsgBase + "review queue is empty. Check note set in plugin settings."); 90 | return; 91 | } 92 | const filePath = noteSet.queue.filenames[0]; 93 | const abstractFile = this._app.vault.getAbstractFileByPath(filePath); 94 | if (!abstractFile || !(abstractFile instanceof TFile)) { 95 | this._plugin.showNotice( 96 | errorMsgBase + 97 | `could not get the note file with path "${filePath}" from Obsidian.` 98 | ); 99 | return; 100 | } 101 | const leaf = this._app.workspace.getMostRecentLeaf(); 102 | if (!leaf) { 103 | this._plugin.showNotice( 104 | errorMsgBase + "could not get a leaf from Obsidian." 105 | ); 106 | return; 107 | } 108 | await leaf.openFile(abstractFile as TFile); 109 | } 110 | 111 | private async createNotesetQueueWithValidation(noteSet: INoteSet): Promise { 112 | const files = await this.generateNotesetQueue(noteSet); 113 | noteSet.queue = new NoteQueue(files); 114 | await this._plugin.noteSetService.validateRulesAndSave(noteSet); 115 | if (noteSet?.validationErrors?.length > 0) { 116 | const errorsString = noteSet.validationErrors.join(";\n"); 117 | this._plugin.showNotice( 118 | `Error while trying to create review queue for note set "${noteSet.displayName}":\n ${errorsString}` 119 | ); 120 | } 121 | } 122 | 123 | 124 | private async createNotesetQueueIfNotExists( 125 | noteSet: INoteSet 126 | ): Promise { 127 | if ( 128 | !noteSet.queue || 129 | !noteSet.queue?.filenames?.length || 130 | noteSet.queue.filenames.length === 0 131 | ) { 132 | await this.createNotesetQueueWithValidation(noteSet); 133 | } 134 | } 135 | 136 | private async generateNotesetQueue(noteSet: INoteSet): Promise { 137 | const reviewedFieldName = this._plugin.settings.reviewedFieldName; 138 | const freqFieldname = this._plugin.settings.reviewFrequencyFieldName; 139 | const pages = ( 140 | await this._dataviewService.getNoteSetFiles(noteSet) 141 | ).filter((x) => x[freqFieldname] !== ReviewFrequency.ignore); 142 | let sorted: DataArray>; 143 | 144 | if (this._plugin.settings.useReviewFrequency) { 145 | sorted = pages.sort( 146 | (x) => calculateNoteReviewPriority(this._plugin, x), 147 | "desc" 148 | ); 149 | } else { 150 | sorted = pages.sort((x) => x[reviewedFieldName], "asc"); 151 | } 152 | 153 | if (sorted.length > 0) { 154 | return sorted.map((x) => x.file.path).array(); 155 | } 156 | 157 | return []; 158 | } 159 | } 160 | -------------------------------------------------------------------------------- /src/settings/joinLogicOperators.ts: -------------------------------------------------------------------------------- 1 | export enum JoinLogicOperators { 2 | AND = "and", 3 | OR = "or" 4 | } -------------------------------------------------------------------------------- /src/settings/pluginSettings.ts: -------------------------------------------------------------------------------- 1 | import { INoteSet } from "src/noteSet/INoteSet"; 2 | import { ReviewAlgorithm } from "./reviewAlgorightms"; 3 | 4 | export interface SimpleNoteReviewPluginSettings { 5 | reviewedFieldName: string 6 | reviewFrequencyFieldName: string 7 | noteSets: INoteSet[] 8 | currentNoteSetId?: string 9 | openNextNoteAfterReviewing: boolean 10 | openRandomNote: boolean 11 | reviewAlgorithm: ReviewAlgorithm 12 | useReviewFrequency: boolean 13 | unreviewedNotesFirst: boolean 14 | } 15 | 16 | export class DefaultSettings implements SimpleNoteReviewPluginSettings { 17 | reviewedFieldName = "reviewed"; 18 | reviewFrequencyFieldName = "review-frequency"; 19 | noteSets: INoteSet[] = []; 20 | currentNoteSetId?: string = null; 21 | openNextNoteAfterReviewing = true; 22 | openRandomNote = false; 23 | reviewAlgorithm: ReviewAlgorithm.default; 24 | useReviewFrequency = false; 25 | unreviewedNotesFirst = false; 26 | } -------------------------------------------------------------------------------- /src/settings/reviewAlgorightms.ts: -------------------------------------------------------------------------------- 1 | export enum ReviewAlgorithm { 2 | default = "default", 3 | random = "random" 4 | } -------------------------------------------------------------------------------- /src/utils/dateUtils.ts: -------------------------------------------------------------------------------- 1 | 2 | export function getDateOffsetByNDays(days: number): Date { 3 | const today = new Date(); 4 | const offsetDate = new Date(); 5 | offsetDate.setDate(today.getDate() - days); 6 | return offsetDate; 7 | } 8 | 9 | export function getNumberOfDaysFromToday(datestring: string): number { 10 | const date = new Date(datestring); 11 | const today = new Date(); 12 | const diff = today.getTime() - date.getTime(); 13 | return Math.round(diff / (1000 * 60 * 60 * 24)); 14 | } 15 | 16 | export function getTodayAsYyyyMmDd(): string { 17 | const date = new Date(); 18 | const year = date.toLocaleString('default', {year: 'numeric'}); 19 | const month = date.toLocaleString('default', {month: '2-digit'}); 20 | const day = date.toLocaleString('default', {day: '2-digit'}); 21 | 22 | return [year, month, day].join('-'); 23 | } -------------------------------------------------------------------------------- /src/utils/metadataService.ts: -------------------------------------------------------------------------------- 1 | import { App, TFile } from "obsidian"; 2 | 3 | // matches whole YAML frontmatter 4 | const FRONTMATTER_REGEX = /^---\r?\n((?:.*\r?\n)*?)---/; 5 | // matches any number of fields in frontmatter 6 | const FIELDS_REGEX_PART = '((?:.*\n)*)'; 7 | 8 | export interface IMetadataField { 9 | name: string, 10 | value: string 11 | } 12 | 13 | export class MetadataService { 14 | constructor(private app: App) { } 15 | 16 | 17 | /** Change or add metadata field and value, and save modified file. 18 | * @param {TFile=null} file 19 | * @param {IMetadataField[]} fields 20 | * @returns Promise 21 | */ 22 | public async setAndSaveMetadataFieldsValue(file: TFile = null, fields: IMetadataField[]): Promise { 23 | const fileContent = await app.vault.read(file); 24 | let newFileContent = fileContent; 25 | for (const field of fields) { 26 | newFileContent = this.setMetadataFieldValue(newFileContent, field); 27 | } 28 | await this.app.vault.modify(file, newFileContent); 29 | } 30 | 31 | /** Change or add multiple metadata fields and their values, and save modified file. 32 | * @param {TFile=null} file 33 | * @param {IMetadataField} field 34 | * @returns Promise 35 | */ 36 | public async setAndSaveMetadataFieldValue(file: TFile = null, field: IMetadataField): Promise { 37 | this.setAndSaveMetadataFieldsValue(file, [field]); 38 | } 39 | 40 | private setMetadataFieldValue(fileContent: string, data: IMetadataField): string { 41 | const fieldText = `${data.name}: ${data.value}\n`; 42 | let newFileContent: string; 43 | 44 | const fieldRegex = this.createFieldRegex(data.name); 45 | 46 | if (fieldRegex.test(fileContent)) { 47 | const result = fieldRegex.exec(fileContent); 48 | const partBefore = result[1]; 49 | const partAfter = result[3]; 50 | newFileContent = fileContent.replace(fieldRegex, `---\n${partBefore}${fieldText}${partAfter}---`); 51 | } 52 | else if (FRONTMATTER_REGEX.test(fileContent)) { 53 | const metadata = FRONTMATTER_REGEX.exec(fileContent); 54 | const partBefore = metadata[1]; 55 | newFileContent = fileContent.replace(FRONTMATTER_REGEX, `---\n${partBefore}${fieldText}---`) 56 | } else { 57 | newFileContent = `---\n${fieldText}---\n\n${fileContent}`; 58 | } 59 | 60 | return newFileContent; 61 | } 62 | 63 | private createSingleFieldRegexString(fieldName: string): string { 64 | //eslint-disable-next-line 65 | return `(${fieldName}\s*:\s*.*\n)`; 66 | } 67 | 68 | private createFieldRegex(fieldName: string): RegExp { 69 | // match fieldname:somevalue 70 | //eslint-disable-next-line 71 | return new RegExp(`---\n(?:${FIELDS_REGEX_PART}${this.createSingleFieldRegexString(fieldName)}${FIELDS_REGEX_PART})---`); 72 | } 73 | 74 | } -------------------------------------------------------------------------------- /styles.css: -------------------------------------------------------------------------------- 1 | /* settings */ 2 | /* .section-setting { 3 | display: block; 4 | } */ 5 | 6 | /* .note-set-delete-modal { 7 | display: flex; 8 | flex-direction: column; 9 | align-items: center; 10 | } */ 11 | 12 | /* SIDEBAR */ 13 | .sidebar-noteset-section { 14 | display: flex; 15 | flex-direction: row; 16 | justify-content: space-between; 17 | margin: 5px 0; 18 | border-radius: var(--border-radius); 19 | } 20 | 21 | .sidebar-noteset-section:hover { 22 | background-color: var(--background-primary); 23 | } 24 | 25 | .sidebar-noteset-section > span { 26 | margin: 0 10px; 27 | } -------------------------------------------------------------------------------- /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 | "isolatedModules": true, 13 | "lib": [ 14 | "DOM", 15 | "ES5", 16 | "ES6", 17 | "ES7" 18 | ] 19 | }, 20 | "include": [ 21 | "**/*.ts" 22 | ] 23 | } 24 | -------------------------------------------------------------------------------- /version-bump.mjs: -------------------------------------------------------------------------------- 1 | import { readFileSync, writeFileSync } from "fs"; 2 | 3 | const targetVersion = process.env.npm_package_version; 4 | 5 | // read minAppVersion from manifest.json and bump version to target version 6 | let manifest = JSON.parse(readFileSync("manifest.json", "utf8")); 7 | const { minAppVersion } = manifest; 8 | manifest.version = targetVersion; 9 | writeFileSync("manifest.json", JSON.stringify(manifest, null, "\t")); 10 | 11 | // update versions.json with target version and minAppVersion from manifest.json 12 | let versions = JSON.parse(readFileSync("versions.json", "utf8")); 13 | versions[targetVersion] = minAppVersion; 14 | writeFileSync("versions.json", JSON.stringify(versions, null, "\t")); 15 | -------------------------------------------------------------------------------- /versions.json: -------------------------------------------------------------------------------- 1 | { 2 | "1.0.0": "0.9.7", 3 | "1.0.1": "0.12.0" 4 | } 5 | --------------------------------------------------------------------------------