├── .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 | 
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 | 
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 | 
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 | 
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 |
--------------------------------------------------------------------------------