├── .eslintignore ├── .eslintrc ├── .github └── workflows │ └── build.yml ├── .gitignore ├── .nvmrc ├── .prettierrc.json ├── LICENSE ├── README.md ├── main.ts ├── manifest.json ├── package-lock.json ├── package.json ├── rollup.config.js ├── styles.css ├── tsconfig.json ├── types.d.ts └── versions.json /.eslintignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | *.js -------------------------------------------------------------------------------- /.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "root": true, 3 | "ignorePatterns": ["**.js", "**/node_modules/**"], 4 | "parser": "@typescript-eslint/parser", 5 | "plugins": ["@typescript-eslint", "prettier"], 6 | "extends": [ 7 | "eslint:recommended", 8 | "plugin:@typescript-eslint/eslint-recommended", 9 | "plugin:@typescript-eslint/recommended" 10 | ], 11 | "parserOptions": { 12 | "project": "./tsconfig.json", 13 | "sourceType": "module" 14 | }, 15 | "rules": { 16 | "prettier/prettier": "error", 17 | "@typescript-eslint/ban-ts-comment": "error", 18 | "@typescript-eslint/no-unused-vars": [ 19 | "error", 20 | { 21 | "argsIgnorePattern": "^_", 22 | "varsIgnorePattern": "^_", 23 | "caughtErrorsIgnorePattern": "^_" 24 | } 25 | ], 26 | "@typescript-eslint/no-explicit-any": ["error"], 27 | "no-console": "error", 28 | "array-callback-return": ["error"], 29 | "padding-line-between-statements": [ 30 | "warn", 31 | { 32 | "blankLine": "always", 33 | "prev": "*", 34 | "next": [ 35 | "return", 36 | "if", 37 | "multiline-const", 38 | "function", 39 | "multiline-expression", 40 | "multiline-let", 41 | "block-like" 42 | ] 43 | }, 44 | { 45 | "blankLine": "always", 46 | "prev": ["function"], 47 | "next": "*" 48 | } 49 | ] 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /.github/workflows/build.yml: -------------------------------------------------------------------------------- 1 | on: 2 | pull_request: 3 | types: [edited, synchronize, opened] 4 | push: 5 | branches: [master] 6 | jobs: 7 | build: 8 | runs-on: ubuntu-latest 9 | steps: 10 | - uses: actions/checkout@v4 11 | - name: 'Use node version' 12 | uses: actions/setup-node@v4 13 | with: 14 | node-version-file: .nvmrc 15 | cache: 'npm' 16 | - name: 'Install dependencies' 17 | run: npm install 18 | - name: 'Build' 19 | run: npm run build-ci 20 | lint: 21 | runs-on: ubuntu-latest 22 | steps: 23 | - uses: actions/checkout@v4 24 | - name: 'Use node version' 25 | uses: actions/setup-node@v4 26 | with: 27 | node-version-file: .nvmrc 28 | cache: 'npm' 29 | - name: 'Install dependencies' 30 | run: npm install 31 | - name: 'Linting with ESLint' 32 | run: npm run lint 33 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Intellij 2 | *.iml 3 | .idea 4 | settings.json 5 | 6 | # npm 7 | node_modules 8 | 9 | # build 10 | build 11 | main.js 12 | *.js.map 13 | 14 | # obsidian 15 | data.json 16 | 17 | # mac 18 | .DS_store 19 | 20 | -------------------------------------------------------------------------------- /.nvmrc: -------------------------------------------------------------------------------- 1 | v21.5.0 2 | -------------------------------------------------------------------------------- /.prettierrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "printWidth": 80, 3 | "semi": true, 4 | "singleQuote": true, 5 | "bracketSpacing": true, 6 | "useTabs": false, 7 | "endOfLine": "auto", 8 | "overrides": [ 9 | { 10 | "files": [".prettierrc", ".eslintrc"], 11 | "options": { "parser": "json" } 12 | } 13 | ] 14 | } 15 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2021 Sam Lewis 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. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # CustomJS 2 | 3 | CustomJS is a plugin for Obsidian that allows users to write custom Javascript that you can call anywhere you can write JS — including `dataviewjs` blocks and templater templates. 4 | 5 | ✅ Works on desktop and mobile! 6 | 7 | ## Installation 8 | 9 | #### Recommended 10 | 11 | CustomJS is available in the Obsidian community plugin browser. 12 | 13 | #### Manual 14 | 15 | Go to the [releases](https://github.com/samlewis0602/obsidian-custom-js/releases) and download the latest `main.js` and `manifest.json` files. Create a folder called `customjs` inside `.obsidian/plugins` and place both files in it. 16 | 17 | ## Settings 18 | 19 | Tell CustomJS what code to load. 20 | NOTE: only use forward slashes in your paths, back slashes will break non-windows platforms. 21 | 22 | ### Individual files 23 | 24 | A comma-separated list of files you'd like to load. 25 | 26 | ### Folder 27 | 28 | Path to a folder that contains JS files you'd like to load. The folder setting will load all `*.js` files in that folder **recursively**. So setting `scripts` will load `scripts/a.js` and `scripts/other/b.js`. 29 | 30 | > ⚠️ Files are loaded in alphabetical order by **_file name_** for consistency, enabling dependencies on each other. 31 | 32 | ### Registered invocable scripts 33 | 34 | Allows you to bind an [Invocable Script](#invocable-scripts) to a hotkey. 35 | 36 | ### Startup scripts 37 | 38 | [Invocable Scripts](#invocable-scripts) executed when the plugin is loaded. You may want use it to initialize something when Obsidian is loaded. 39 | 40 | > ⚠️ Changes made in the `Startup scripts` to the `window.customJS` object might get overridden. To avoid that follow [State](#state) tips. 41 | 42 | ## Usage/Example 43 | 44 | CustomJS works by writing javascript classes. Each file can contain one class _and only one class_. Imports, constants, etc defined outside the class will break CustomJS. 45 | 46 | ### Accessing your classes 47 | 48 | **Global Object: `customJS`** 49 | During startup, an instance of the custom classes is made available in the global `window.customJS` object. 50 | 51 | Generally, the global object can be safely used in any kind of template, as those are invoked by user action after Obsidian loaded. 52 | 53 | **Async Function: `await cJS()`** 54 | Since the global object is initialized [asynchronously](#asynchronous-usage), you might need to use the loader function `cJS()` to ensure all classes are fully loaded before accessing your custom functions. 55 | 56 | The async function is the official way of accessing your custom classes and should be used in code blocks of your notes. This ensures, that notes that are automatically opened when Obsidian starts up, do not throw an JS error 57 | 58 | ### Sample 59 | 60 | ```` 61 | // in vault at scripts/coolString.js 62 | class CoolString { 63 | coolify(s) { 64 | return `😎 ${s} 😎` 65 | } 66 | } 67 | 68 | 69 | // dataviewjs block in *.md 70 | ```dataviewjs 71 | const {CoolString} = await cJS() 72 | dv.list(dv.pages().file.name.map(n => CoolString.coolify(n))) 73 | ``` 74 | 75 | // templater template 76 | <%* 77 | const {CoolString} = await cJS(); 78 | tR += CoolString.coolify(tp.file.title); 79 | %> 80 | ```` 81 | 82 | Make sure you add `scripts/coolString.js` to the settings page for CustomJS and voila! When entering preview mode for the dataviewjs block you should see a list of all your files with a little extra 😎 — inserting the templater template will output a similar result with just the current file name. 83 | 84 | > ⚠️ CustomJS will initialize any class as a singleton instance. If you want to create an isolated instance use `create${className}Instance` instead, such as `createCoolStringInstance` for the above class. 85 | 86 | --- 87 | 88 | ## Advanced Docs 89 | 90 | ### Global object 91 | 92 | The `window.customJS` object holds instances to all your custom JS classes, as well as some special properties: 93 | 94 | - `customJS.state: object` .. The customJS [state](#state) object 95 | - `customJS.obsidian: Module` .. Internal [Obsidian API](https://github.com/obsidianmd/obsidian-api/blob/master/obsidian.d.ts) functions 96 | - `customJS.app: App` .. Obsidian's [`class App`](https://github.com/obsidianmd/obsidian-api/blob/master/obsidian.d.ts) instance (same as `window.app`) 97 | 98 | Every custom class you add creates two new properties: 99 | - `customJS.MyModule: object` .. holds an instance to the `class MyModule {}` class 100 | - `customJS.createMyModuleInstance: Function` .. A method that returns a _new_ instance to `MyModule`. Note that you cannot pass any argument to the constructor 101 | 102 | ### Asynchronous Usage 103 | 104 | CustomJS loads your modules at Obsidian's startup by hooking an event that says that Obsidian is ready. This is an event that is used by _other_ plugins as well (such as [Templater](https://github.com/SilentVoid13/Templater) and its startup template, or [JS Engine](https://github.com/mProjectsCode/obsidian-js-engine-plugin)), and unfortunately this means that if you want to use CustomJS with them there can be problems. 105 | 106 | > `customJS` is not defined 107 | 108 | If you see issues where the `customJS` variable is not defined, this is when you want to force it to load before your script continues. In order to allow this, we provide the asynchronous function `cJS()`, also defined globally. This means that you can `await` it, thereby ensuring that `customJS` will be available when you need it. 109 | 110 | ```js 111 | await cJS() 112 | ``` 113 | 114 | That said, most of the time **_you do not need to do this_**. In the vast majority of JavaScript execution taking place within Obsidian, customJS will be loaded. 115 | 116 | #### Check loading state 117 | 118 | You can check the special [state](#state) value of `customJS.state._ready` to determine, if your custom JS code is fully loaded and can be used: 119 | 120 | ```` 121 | ```dataviewjs 122 | if (!customJS?.state?._ready) { 123 | // CustomJS is not fully loaded. Abort the script and do not output anything 124 | return 125 | } 126 | 127 | // Arriving here means, all customJS properties are ready to be used 128 | customJS.MyModule.doSomething() 129 | ``` 130 | ```` 131 | 132 | Wait for the plugin to fully load: 133 | ```` 134 | ```js-engine 135 | while (!customJS?.state?._ready) { 136 | await new Promise(resolve => setTimeout(resolve, 50)) 137 | } 138 | 139 | // Arriving here means, all customJS properties are ready to be used 140 | customJS.MyModule.doSomething() 141 | ``` 142 | ```` 143 | 144 | #### The `cJS()` function 145 | 146 | CustomJS provides several ways on how to use the `cJS()` function: 147 | 148 | 1. `async cJS(): customJS` .. The default return value is the [global object](#global-object). 149 | 2. `async cJS( moduleName: string ): object` .. Using a string parameter will return a single property of the global object. 150 | 3. `async cJS( async Function ): customJS` .. Using a callback function will pass the global object as only parameter to that function. 151 | 152 | **Samples** 153 | 154 | Access the fully initialized customJS object 155 | ```` 156 | ```dataviewjs 157 | const modules = await cJS() 158 | modules.MyModule.doSomething() 159 | ``` 160 | ```` 161 | 162 | Access a single module from the customJS object 163 | ```` 164 | ```dataviewjs 165 | const MyModule = await cJS('MyModule') 166 | MyModule.doSomething() 167 | ``` 168 | ```` 169 | 170 | Run custom code via callback: 171 | ```` 172 | ```dataviewjs 173 | await cJS( customJS => customJS.MyModule.doSomething(dv) ) 174 | 175 | // Or 176 | await cJS( ({MyModule}) => MyModule.doSomething(dv) ) 177 | ``` 178 | ```` 179 | 180 | Run a custom async-callback when the customJS object is ready: 181 | ```` 182 | ```js-engine 183 | async function runAsync(customJS) { 184 | await customJS.MyModule.doSomethingAsync(engine) 185 | } 186 | await cJS(runAsync) 187 | 188 | // Or, as one-liner: 189 | await cJS( async (customJS) => {await customJS.MyModule.doSomethingAsync(engine)} ) 190 | ``` 191 | ```` 192 | 193 | Note: It's recommended to always use the `await` keyword when calling `cJS()`, even in the last sample (using the callback). 194 | 195 | ### Invocable Scripts 196 | 197 | _Invocable Script_ is the class with the defined method 198 | 199 | ```js 200 | async invoke() { 201 | ... 202 | } 203 | ``` 204 | 205 | You can run such scripts via `CustomJS: Invoke Script` command. 206 | 207 | Also you can register individual commands via [settings](#registered-invocable-scripts) for the desired script and invoke it via `CustomJS: MyScriptName` command. Additionally you can assign a custom hotkey for that registered commands. 208 | 209 | ### State 210 | 211 | `window.customJS` object is being overridden every time any `js` file is modified in the vault. If you need some data to be preserved during such modifications, store them in `window.customJS.state`. 212 | 213 | ### `deconstructor` usage 214 | 215 | Since the `window.customJS` object is overwritten each time the `js` files are reloaded, the option of defining a `deconstructor` has been added. 216 | 217 | In your Javascript class, which you have CustomJS load, you can define a `deconstructor`, which is then called on every reload. This gives you the option of having cleanup work carried out. 218 | 219 | ```js 220 | deconstructor() { 221 | ... 222 | } 223 | ``` 224 | 225 | #### Example definition of a `deconstructor` 226 | 227 | For example, you can deregister events that you have previously registered: 228 | 229 | ```js 230 | deconstructor() { 231 | this.app.workspace.off('file-menu', this.eventHandler); 232 | } 233 | ``` 234 | 235 | ### Re-execute the start scripts on reload 236 | 237 | There is also the option of having the start scripts re-executed each time the `js` files are reloaded. This can be activated in the settings and is deactivated by default. 238 | 239 | #### Complete example `deconstructor` & re-execute start scripts 240 | 241 | These two functions, the `deconstructor` and the automatic re-execution of the start scripts, make it possible, for example, to implement your own context menu in Obsidian. 242 | 243 | To do this, you must register the corresponding event in the `invoke` start function and deregister it again in the `deconstructor`. 244 | 245 | Please be aware of any binding issues and refer to the Obsidian API documentation. 246 | 247 | ```js 248 | class AddCustomMenuEntry { 249 | constructor() { 250 | // Binding the event handler to the `this` context of the class. 251 | this.eventHandler = this.eventHandler.bind(this); 252 | } 253 | 254 | async invoke() { 255 | this.app.workspace.on('file-menu', this.eventHandler); 256 | } 257 | 258 | deconstructor() { 259 | this.app.workspace.off('file-menu', this.eventHandler); 260 | } 261 | 262 | eventHandler(menu, file) { 263 | // Look in the API documentation for this feature 264 | // https://docs.obsidian.md/Plugins/User+interface/Context+menus 265 | menu.addSeparator(); 266 | menu.addItem((item) => { 267 | item 268 | .setTitle('Custom menu entry text..') 269 | .setIcon('file-plus-2') // Look in the API documentation for the available icons 270 | .onClick(() => { // https://docs.obsidian.md/Plugins/User+interface/Icons 271 | // Insert the code here that is to be executed when the context menu entry is clicked. 272 | }); 273 | }); 274 | } 275 | } 276 | ``` 277 | 278 | ## ☕️ Support 279 | 280 | Do you find CustomJS useful? Consider buying me a coffee to fuel updates and more useful software like this. Thank you! 281 | 282 | Buy Me A Coffee 283 | 284 | ## Local development 285 | 286 | 1. Clone this repository into `/.obsidian/plugins` 287 | 288 | Note: it is recommended to use a test vault when developing plugins. 289 | 290 | 2. (if you are using node version manager, use the version from package.json -> devDependencies -> @types/node) 291 | 292 | 3. Install dependencies: `npm install` 293 | 294 | 4. Build in dev mode with `npm run dev` 295 | 296 | NOTE: if you place your repository somewhere else than in `plugins`, you can customize the output path with 297 | 298 | `OUTPUT_DIR=/.obsidian/plugins/obsidian-custom-js npm run dev` 299 | 300 | See also: 301 | 302 | - Obsidian development guide: https://docs.obsidian.md/Plugins/Getting+started/Build+a+plugin 303 | - Hot reloading plugin: https://docs.obsidian.md/Plugins/Getting+started/Development+workflow 304 | -------------------------------------------------------------------------------- /main.ts: -------------------------------------------------------------------------------- 1 | import { 2 | App, 3 | Plugin, 4 | PluginSettingTab, 5 | Setting, 6 | TAbstractFile, 7 | FuzzySuggestModal, 8 | FuzzyMatch, 9 | Notice, 10 | } from 'obsidian'; 11 | import * as obsidian from 'obsidian'; 12 | import compareVersions from 'compare-versions'; 13 | import debuggableEval from 'debuggable-eval'; 14 | import { CustomJSType } from './types'; 15 | 16 | interface CustomJSSettings { 17 | jsFiles: string; 18 | jsFolder: string; 19 | startupScriptNames: string[]; 20 | registeredInvocableScriptNames: string[]; 21 | rerunStartupScriptsOnFileChange: boolean; 22 | } 23 | 24 | const DEFAULT_SETTINGS: CustomJSSettings = { 25 | jsFiles: '', 26 | jsFolder: '', 27 | startupScriptNames: [], 28 | registeredInvocableScriptNames: [], 29 | rerunStartupScriptsOnFileChange: false, 30 | }; 31 | 32 | interface Invocable { 33 | invoke: () => Promise; 34 | } 35 | 36 | function isInvocable(x: unknown): x is Invocable { 37 | return typeof (x as { invoke: 'function' })?.invoke === 'function'; 38 | } 39 | 40 | export default class CustomJS extends Plugin { 41 | settings: CustomJSSettings; 42 | deconstructorsOfLoadedFiles: { deconstructor: () => void; name: string }[] = 43 | []; 44 | loaderPromise: Promise | null = null; 45 | 46 | async onload() { 47 | // eslint-disable-next-line no-console 48 | console.log('Loading CustomJS'); 49 | await this.loadSettings(); 50 | this.registerEvent(this.app.vault.on('modify', this.reloadIfNeeded, this)); 51 | 52 | window.forceLoadCustomJS = async () => { 53 | await this.initCustomJS(); 54 | }; 55 | 56 | window.cJS = async ( 57 | moduleOrCallback?: string | ((customJS: CustomJSType) => void), 58 | ) => { 59 | if (!window.customJS?.state?._ready) { 60 | await this.initCustomJS(); 61 | } 62 | 63 | if (moduleOrCallback) { 64 | if ('string' === typeof moduleOrCallback) { 65 | return window.customJS[moduleOrCallback]; 66 | } else if ('function' === typeof moduleOrCallback) { 67 | await moduleOrCallback(window.customJS); 68 | } 69 | } 70 | 71 | return window.customJS; 72 | }; 73 | 74 | this.app.workspace.onLayoutReady(async () => { 75 | await this.loadClasses(); 76 | 77 | for (const startupScriptName of this.settings.startupScriptNames) { 78 | await this.invokeScript(startupScriptName); 79 | } 80 | }); 81 | this.addSettingTab(new CustomJSSettingsTab(this.app, this)); 82 | 83 | this.addCommand({ 84 | id: 'invokeScript', 85 | name: 'Invoke Script', 86 | callback: this.selectAndInvokeScript.bind(this), 87 | }); 88 | 89 | for (const scriptName of this.settings.registeredInvocableScriptNames) { 90 | this.registerInvocableScript(scriptName); 91 | } 92 | } 93 | 94 | async onunload() { 95 | await this.deconstructLoadedFiles(); 96 | delete window.customJS; 97 | } 98 | 99 | private async selectAndInvokeScript() { 100 | const modal = new InvocableScriptSelectorModal(this.app, []); 101 | const scriptName = await modal.promise; 102 | await this.invokeScript(scriptName); 103 | } 104 | 105 | public async invokeScript(scriptName: string | null) { 106 | if (!scriptName) { 107 | return; 108 | } 109 | 110 | const scriptObj = window.customJS[scriptName]; 111 | 112 | if (!scriptObj) { 113 | // eslint-disable-next-line no-console 114 | console.warn(`Script '${scriptName}' is not defined`); 115 | 116 | return; 117 | } 118 | 119 | if (!isInvocable(scriptObj)) { 120 | // eslint-disable-next-line no-console 121 | console.warn(`Script '${scriptName}' is not invocable`); 122 | 123 | return; 124 | } 125 | 126 | try { 127 | await scriptObj.invoke(); 128 | } catch (e) { 129 | const message = `Script '${scriptName}' failed`; 130 | 131 | new Notice( 132 | `${message}\n${e.message}\nSee error console for more details`, 133 | ); 134 | // eslint-disable-next-line no-console 135 | console.error(message); 136 | // eslint-disable-next-line no-console 137 | console.error(e); 138 | } 139 | } 140 | 141 | async deconstructLoadedFiles() { 142 | // Run deconstructor if exists 143 | for (const deconstructor of this.deconstructorsOfLoadedFiles) { 144 | try { 145 | await deconstructor.deconstructor(); 146 | } catch (e) { 147 | // eslint-disable-next-line no-console 148 | console.error(`${deconstructor.name} failed`); 149 | // eslint-disable-next-line no-console 150 | console.error(e); 151 | } 152 | } 153 | 154 | // Clear the list 155 | this.deconstructorsOfLoadedFiles = []; 156 | } 157 | 158 | async reloadIfNeeded(f: TAbstractFile) { 159 | if (f.path.endsWith('.js')) { 160 | // Run deconstructor if exists 161 | await this.deconstructLoadedFiles(); 162 | 163 | await this.initCustomJS(); 164 | 165 | // invoke startup scripts again if wanted 166 | if (this.settings.rerunStartupScriptsOnFileChange) { 167 | for (const startupScriptName of this.settings.startupScriptNames) { 168 | await this.invokeScript(startupScriptName); 169 | } 170 | } 171 | 172 | // reload dataviewjs blocks if installed & version >= 0.4.11 173 | if (this.app.plugins.enabledPlugins.has('dataview')) { 174 | const version = this.app.plugins.plugins?.dataview?.manifest.version; 175 | 176 | if (compareVersions(version, '0.4.11') < 0) return; 177 | 178 | this.app.plugins.plugins.dataview?.api?.index?.touch(); 179 | } 180 | } 181 | } 182 | 183 | async loadSettings() { 184 | const settings = await this.loadData(); 185 | this.settings = { ...DEFAULT_SETTINGS, ...settings }; 186 | } 187 | 188 | async saveSettings() { 189 | await this.saveData(this.settings); 190 | } 191 | 192 | async evalFile(f: string): Promise { 193 | try { 194 | const file = await this.app.vault.adapter.read(f); 195 | 196 | const def = debuggableEval(`(${file})`, f) as new () => { 197 | deconstructor?: () => void; 198 | }; 199 | 200 | // Store the existing instance 201 | const cls = new def(); 202 | window.customJS[cls.constructor.name] = cls; 203 | 204 | // Check if the class has a deconstructor 205 | if (typeof cls.deconstructor === 'function') { 206 | // Add the deconstructor to the list 207 | const deconstructor = cls.deconstructor.bind(cls); 208 | 209 | const deconstructorWrapper = { 210 | deconstructor: deconstructor, 211 | name: `Deconstructor of ${cls.constructor.name}`, 212 | }; 213 | this.deconstructorsOfLoadedFiles.push(deconstructorWrapper); 214 | } 215 | 216 | // Provide a way to create a new instance 217 | window.customJS[`create${def.name}Instance`] = () => new def(); 218 | } catch (e) { 219 | // eslint-disable-next-line no-console 220 | console.error(`CustomJS couldn't import ${f}`); 221 | // eslint-disable-next-line no-console 222 | console.error(e); 223 | } 224 | } 225 | 226 | async initCustomJS() { 227 | if (!this.loaderPromise) { 228 | this.loaderPromise = this.loadClasses().finally(() => { 229 | this.loaderPromise = null; 230 | }); 231 | } 232 | 233 | await this.loaderPromise; 234 | } 235 | 236 | async loadClasses() { 237 | window.customJS = { 238 | obsidian, 239 | state: window.customJS?.state ?? {}, 240 | app: this.app, 241 | }; 242 | const filesToLoad = []; 243 | window.customJS.state._ready = false; 244 | 245 | // Get individual paths 246 | if (this.settings.jsFiles != '') { 247 | const individualFiles = this.settings.jsFiles 248 | .split(',') 249 | .map((s) => s.trim()) 250 | .sort(); 251 | 252 | for (const f of individualFiles) { 253 | if (f != '' && f.endsWith('.js')) { 254 | filesToLoad.push(f); 255 | } 256 | } 257 | } 258 | 259 | // Get paths in folder 260 | if (this.settings.jsFolder != '') { 261 | const prefix = this.settings.jsFolder; 262 | const files = this.app.vault.getFiles(); 263 | 264 | const scripts = files.filter( 265 | (f) => f.path.startsWith(prefix) && f.path.endsWith('.js'), 266 | ); 267 | 268 | for (const s of scripts) { 269 | if (s.path != '' && s.path.endsWith('.js')) { 270 | filesToLoad.push(s.path); 271 | } 272 | } 273 | } 274 | 275 | this.sortByFileName(filesToLoad); 276 | 277 | // load all scripts 278 | for (const f of filesToLoad) { 279 | await this.evalFile(f); 280 | } 281 | window.customJS.state._ready = true; 282 | } 283 | 284 | sortByFileName(files: string[]) { 285 | files.sort((a, b) => { 286 | const nameA = a.split('/').last(); 287 | const nameB = b.split('/').last(); 288 | 289 | return nameA.localeCompare(nameB); 290 | }); 291 | } 292 | 293 | private getInvocableScriptCommandId(scriptName: string) { 294 | return `invoke-${scriptName}`; 295 | } 296 | 297 | async registerInvocableScript(scriptName: string) { 298 | this.addCommand({ 299 | id: this.getInvocableScriptCommandId(scriptName), 300 | name: scriptName, 301 | callback: async () => { 302 | await this.invokeScript(scriptName); 303 | }, 304 | }); 305 | 306 | if (!this.settings.registeredInvocableScriptNames.includes(scriptName)) { 307 | this.settings.registeredInvocableScriptNames.push(scriptName); 308 | await this.saveSettings(); 309 | } 310 | } 311 | 312 | async unregisterInvocableScript(scriptName: string) { 313 | this.app.commands.removeCommand( 314 | `${this.manifest.id}:${this.getInvocableScriptCommandId(scriptName)}`, 315 | ); 316 | 317 | const index = 318 | this.settings.registeredInvocableScriptNames.indexOf(scriptName); 319 | this.settings.registeredInvocableScriptNames.splice(index, 1); 320 | await this.saveSettings(); 321 | } 322 | 323 | async addStartupScript(scriptName: string) { 324 | this.settings.startupScriptNames.push(scriptName); 325 | await this.saveSettings(); 326 | } 327 | 328 | async deleteStartupScript(scriptName: string) { 329 | const index = this.settings.startupScriptNames.indexOf(scriptName); 330 | this.settings.startupScriptNames.splice(index, 1); 331 | await this.saveSettings(); 332 | } 333 | } 334 | 335 | class CustomJSSettingsTab extends PluginSettingTab { 336 | plugin: CustomJS; 337 | 338 | constructor(app: App, plugin: CustomJS) { 339 | super(app, plugin); 340 | this.plugin = plugin; 341 | } 342 | 343 | display(): void { 344 | const { containerEl } = this; 345 | containerEl.empty(); 346 | containerEl.createEl('h2', { text: 'CustomJS' }); 347 | 348 | // individual files 349 | new Setting(containerEl) 350 | .setName('Individual files') 351 | .setDesc('Comma-separated list of files to load') 352 | .addText((text) => 353 | text 354 | .setPlaceholder('jsfile1.js,jsfile2.js') 355 | .setValue(this.plugin.settings.jsFiles) 356 | .onChange(async (value) => { 357 | this.plugin.settings.jsFiles = value; 358 | await this.plugin.saveSettings(); 359 | await this.plugin.loadClasses(); 360 | }), 361 | ); 362 | 363 | // folder 364 | new Setting(containerEl) 365 | .setName('Folder') 366 | .setDesc('Path to folder containing JS files to load') 367 | .addText((text) => 368 | text 369 | .setPlaceholder('js/scripts') 370 | .setValue(this.plugin.settings.jsFolder) 371 | .onChange(async (value) => { 372 | this.plugin.settings.jsFolder = value; 373 | await this.plugin.saveSettings(); 374 | await this.plugin.loadClasses(); 375 | }), 376 | ); 377 | 378 | let descriptionTemplate = document.createElement('template'); 379 | 380 | descriptionTemplate.innerHTML = 381 | 'Allows you to bind an invocable script to a hotkey'; 382 | 383 | new Setting(containerEl) 384 | .setName('Registered invocable scripts') 385 | .setDesc(descriptionTemplate.content); 386 | 387 | for (const scriptName of this.plugin.settings 388 | .registeredInvocableScriptNames) { 389 | new Setting(containerEl) 390 | .addText((text) => text.setValue(scriptName).setDisabled(true)) 391 | .addExtraButton((cb) => 392 | cb 393 | .setIcon('any-key') 394 | .setTooltip('Configure Hotkey') 395 | .onClick(() => { 396 | const hotkeysTab = this.app.setting.openTabById('hotkeys'); 397 | 398 | hotkeysTab.searchComponent.setValue( 399 | `${this.plugin.manifest.name}: ${scriptName}`, 400 | ); 401 | hotkeysTab.updateHotkeyVisibility(); 402 | }), 403 | ) 404 | .addExtraButton((cb) => 405 | cb 406 | .setIcon('cross') 407 | .setTooltip('Delete') 408 | .onClick(async () => { 409 | this.plugin.unregisterInvocableScript(scriptName); 410 | this.display(); 411 | }), 412 | ); 413 | } 414 | 415 | new Setting(this.containerEl).addButton((cb) => 416 | cb 417 | .setButtonText('Register invocable script') 418 | .setCta() 419 | .onClick(async () => { 420 | const modal = new InvocableScriptSelectorModal( 421 | this.app, 422 | this.plugin.settings.registeredInvocableScriptNames, 423 | ); 424 | const scriptName = await modal.promise; 425 | 426 | if (scriptName) { 427 | this.plugin.registerInvocableScript(scriptName); 428 | this.display(); 429 | } 430 | }), 431 | ); 432 | 433 | descriptionTemplate = document.createElement('template'); 434 | 435 | descriptionTemplate.innerHTML = 436 | 'Invocable scripts executed when the plugin is loaded'; 437 | 438 | new Setting(containerEl) 439 | .setName('Startup scripts') 440 | .setDesc(descriptionTemplate.content); 441 | 442 | for (const scriptName of this.plugin.settings.startupScriptNames) { 443 | new Setting(containerEl) 444 | .addText((text) => text.setValue(scriptName).setDisabled(true)) 445 | .addExtraButton((cb) => 446 | cb 447 | .setIcon('cross') 448 | .setTooltip('Delete') 449 | .onClick(async () => { 450 | this.plugin.deleteStartupScript(scriptName); 451 | this.display(); 452 | }), 453 | ); 454 | } 455 | 456 | new Setting(this.containerEl).addButton((cb) => 457 | cb 458 | .setButtonText('Add startup script') 459 | .setCta() 460 | .onClick(async () => { 461 | const modal = new InvocableScriptSelectorModal( 462 | this.app, 463 | this.plugin.settings.startupScriptNames, 464 | ); 465 | const scriptName = await modal.promise; 466 | 467 | if (scriptName) { 468 | this.plugin.addStartupScript(scriptName); 469 | this.display(); 470 | } 471 | }), 472 | ); 473 | 474 | new Setting(containerEl) 475 | .setName('Re-execute the start scripts when reloading') 476 | .setDesc( 477 | 'Decides whether the startup scripts should be executed again after reloading the scripts', 478 | ) 479 | .addToggle((toggle) => 480 | toggle 481 | .setValue(this.plugin.settings.rerunStartupScriptsOnFileChange) 482 | .onChange(async (value) => { 483 | this.plugin.settings.rerunStartupScriptsOnFileChange = value; 484 | await this.plugin.saveSettings(); 485 | }), 486 | ); 487 | } 488 | } 489 | 490 | class InvocableScriptSelectorModal extends FuzzySuggestModal { 491 | private resolve: (value: string) => void; 492 | private isSelected: boolean; 493 | private excludedScriptNames: Set; 494 | public promise: Promise; 495 | 496 | constructor(app: App, excludedScriptNames: string[]) { 497 | super(app); 498 | 499 | this.promise = new Promise((resolve) => { 500 | this.resolve = resolve; 501 | }); 502 | 503 | this.excludedScriptNames = new Set(excludedScriptNames); 504 | this.open(); 505 | } 506 | 507 | getItems(): string[] { 508 | const entries = ( 509 | Object.entries(window.customJS) as [string, Record][] 510 | ).map(([scriptName, scriptObj]) => ({ 511 | scriptName, 512 | scriptObj, 513 | })); 514 | 515 | const invocableScriptNames = entries 516 | .filter((entry) => isInvocable(entry.scriptObj)) 517 | .map((entry) => entry.scriptName) 518 | .filter((scriptName) => !this.excludedScriptNames.has(scriptName)) 519 | .sort(); 520 | 521 | return invocableScriptNames; 522 | } 523 | 524 | getItemText(item: string): string { 525 | return item; 526 | } 527 | 528 | selectSuggestion( 529 | value: FuzzyMatch, 530 | evt: MouseEvent | KeyboardEvent, 531 | ): void { 532 | this.isSelected = true; 533 | super.selectSuggestion(value, evt); 534 | } 535 | 536 | onChooseItem(item: string, _evt: MouseEvent | KeyboardEvent): void { 537 | this.resolve(item); 538 | } 539 | 540 | onClose(): void { 541 | if (!this.isSelected) { 542 | this.resolve(null); 543 | } 544 | } 545 | } 546 | -------------------------------------------------------------------------------- /manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "id": "customjs", 3 | "name": "CustomJS", 4 | "version": "1.0.21", 5 | "minAppVersion": "0.9.12", 6 | "description": "This plugin lets you use custom javascript files inside your vault.", 7 | "author": "Sam Lewis", 8 | "authorUrl": "https://github.com/samlewis0602", 9 | "isDesktopOnly": false 10 | } -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "customjs", 3 | "version": "1.0.21", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "customjs", 9 | "version": "1.0.21", 10 | "license": "MIT", 11 | "dependencies": { 12 | "compare-versions": "^3.6.0", 13 | "debuggable-eval": "^1.0.0" 14 | }, 15 | "devDependencies": { 16 | "@rollup/plugin-commonjs": "^18.0.0", 17 | "@rollup/plugin-node-resolve": "^11.2.1", 18 | "@rollup/plugin-typescript": "^8.2.1", 19 | "@types/node": "^20.10.6", 20 | "@typescript-eslint/eslint-plugin": "^6.17.0", 21 | "@typescript-eslint/parser": "^6.17.0", 22 | "eslint": "^8.56.0", 23 | "eslint-plugin-prettier": "^5.1.2", 24 | "obsidian": "^0.12.0", 25 | "obsidian-dataview": "^0.4.11", 26 | "prettier": "^3.1.1", 27 | "rollup": "^2.32.1", 28 | "rollup-plugin-copy": "^3.4.0", 29 | "tslib": "^2.2.0", 30 | "typescript": "^4.2.4" 31 | } 32 | }, 33 | "node_modules/@aashutoshrathi/word-wrap": { 34 | "version": "1.2.6", 35 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 36 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 37 | "dev": true, 38 | "engines": { 39 | "node": ">=0.10.0" 40 | } 41 | }, 42 | "node_modules/@codemirror/state": { 43 | "version": "6.4.0", 44 | "resolved": "https://registry.npmjs.org/@codemirror/state/-/state-6.4.0.tgz", 45 | "integrity": "sha512-hm8XshYj5Fo30Bb922QX9hXB/bxOAVH+qaqHBzw5TKa72vOeslyGwd4X8M0c1dJ9JqxlaMceOQ8RsL9tC7gU0A==", 46 | "dev": true, 47 | "peer": true 48 | }, 49 | "node_modules/@codemirror/view": { 50 | "version": "6.23.0", 51 | "resolved": "https://registry.npmjs.org/@codemirror/view/-/view-6.23.0.tgz", 52 | "integrity": "sha512-/51px9N4uW8NpuWkyUX+iam5+PM6io2fm+QmRnzwqBy5v/pwGg9T0kILFtYeum8hjuvENtgsGNKluOfqIICmeQ==", 53 | "dev": true, 54 | "peer": true, 55 | "dependencies": { 56 | "@codemirror/state": "^6.4.0", 57 | "style-mod": "^4.1.0", 58 | "w3c-keyname": "^2.2.4" 59 | } 60 | }, 61 | "node_modules/@eslint-community/eslint-utils": { 62 | "version": "4.4.0", 63 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 64 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 65 | "dev": true, 66 | "dependencies": { 67 | "eslint-visitor-keys": "^3.3.0" 68 | }, 69 | "engines": { 70 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 71 | }, 72 | "peerDependencies": { 73 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 74 | } 75 | }, 76 | "node_modules/@eslint-community/regexpp": { 77 | "version": "4.10.0", 78 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 79 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 80 | "dev": true, 81 | "engines": { 82 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 83 | } 84 | }, 85 | "node_modules/@eslint/eslintrc": { 86 | "version": "2.1.4", 87 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 88 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 89 | "dev": true, 90 | "dependencies": { 91 | "ajv": "^6.12.4", 92 | "debug": "^4.3.2", 93 | "espree": "^9.6.0", 94 | "globals": "^13.19.0", 95 | "ignore": "^5.2.0", 96 | "import-fresh": "^3.2.1", 97 | "js-yaml": "^4.1.0", 98 | "minimatch": "^3.1.2", 99 | "strip-json-comments": "^3.1.1" 100 | }, 101 | "engines": { 102 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 103 | }, 104 | "funding": { 105 | "url": "https://opencollective.com/eslint" 106 | } 107 | }, 108 | "node_modules/@eslint/js": { 109 | "version": "8.56.0", 110 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.56.0.tgz", 111 | "integrity": "sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A==", 112 | "dev": true, 113 | "engines": { 114 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 115 | } 116 | }, 117 | "node_modules/@humanwhocodes/config-array": { 118 | "version": "0.11.13", 119 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.13.tgz", 120 | "integrity": "sha512-JSBDMiDKSzQVngfRjOdFXgFfklaXI4K9nLF49Auh21lmBWRLIK3+xTErTWD4KU54pb6coM6ESE7Awz/FNU3zgQ==", 121 | "dev": true, 122 | "dependencies": { 123 | "@humanwhocodes/object-schema": "^2.0.1", 124 | "debug": "^4.1.1", 125 | "minimatch": "^3.0.5" 126 | }, 127 | "engines": { 128 | "node": ">=10.10.0" 129 | } 130 | }, 131 | "node_modules/@humanwhocodes/module-importer": { 132 | "version": "1.0.1", 133 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 134 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 135 | "dev": true, 136 | "engines": { 137 | "node": ">=12.22" 138 | }, 139 | "funding": { 140 | "type": "github", 141 | "url": "https://github.com/sponsors/nzakas" 142 | } 143 | }, 144 | "node_modules/@humanwhocodes/object-schema": { 145 | "version": "2.0.1", 146 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.1.tgz", 147 | "integrity": "sha512-dvuCeX5fC9dXgJn9t+X5atfmgQAzUOWqS1254Gh0m6i8wKd10ebXkfNKiRK+1GWi/yTvvLDHpoxLr0xxxeslWw==", 148 | "dev": true 149 | }, 150 | "node_modules/@nodelib/fs.scandir": { 151 | "version": "2.1.5", 152 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 153 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 154 | "dev": true, 155 | "dependencies": { 156 | "@nodelib/fs.stat": "2.0.5", 157 | "run-parallel": "^1.1.9" 158 | }, 159 | "engines": { 160 | "node": ">= 8" 161 | } 162 | }, 163 | "node_modules/@nodelib/fs.stat": { 164 | "version": "2.0.5", 165 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 166 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 167 | "dev": true, 168 | "engines": { 169 | "node": ">= 8" 170 | } 171 | }, 172 | "node_modules/@nodelib/fs.walk": { 173 | "version": "1.2.8", 174 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 175 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 176 | "dev": true, 177 | "dependencies": { 178 | "@nodelib/fs.scandir": "2.1.5", 179 | "fastq": "^1.6.0" 180 | }, 181 | "engines": { 182 | "node": ">= 8" 183 | } 184 | }, 185 | "node_modules/@pkgr/core": { 186 | "version": "0.1.0", 187 | "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.1.0.tgz", 188 | "integrity": "sha512-Zwq5OCzuwJC2jwqmpEQt7Ds1DTi6BWSwoGkbb1n9pO3hzb35BoJELx7c0T23iDkBGkh2e7tvOtjF3tr3OaQHDQ==", 189 | "dev": true, 190 | "engines": { 191 | "node": "^12.20.0 || ^14.18.0 || >=16.0.0" 192 | }, 193 | "funding": { 194 | "url": "https://opencollective.com/unts" 195 | } 196 | }, 197 | "node_modules/@rollup/plugin-commonjs": { 198 | "version": "18.1.0", 199 | "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-18.1.0.tgz", 200 | "integrity": "sha512-h3e6T9rUxVMAQswpDIobfUHn/doMzM9sgkMrsMWCFLmB84PSoC8mV8tOloAJjSRwdqhXBqstlX2BwBpHJvbhxg==", 201 | "dev": true, 202 | "dependencies": { 203 | "@rollup/pluginutils": "^3.1.0", 204 | "commondir": "^1.0.1", 205 | "estree-walker": "^2.0.1", 206 | "glob": "^7.1.6", 207 | "is-reference": "^1.2.1", 208 | "magic-string": "^0.25.7", 209 | "resolve": "^1.17.0" 210 | }, 211 | "engines": { 212 | "node": ">= 8.0.0" 213 | }, 214 | "peerDependencies": { 215 | "rollup": "^2.30.0" 216 | } 217 | }, 218 | "node_modules/@rollup/plugin-node-resolve": { 219 | "version": "11.2.1", 220 | "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-11.2.1.tgz", 221 | "integrity": "sha512-yc2n43jcqVyGE2sqV5/YCmocy9ArjVAP/BeXyTtADTBBX6V0e5UMqwO8CdQ0kzjb6zu5P1qMzsScCMRvE9OlVg==", 222 | "dev": true, 223 | "dependencies": { 224 | "@rollup/pluginutils": "^3.1.0", 225 | "@types/resolve": "1.17.1", 226 | "builtin-modules": "^3.1.0", 227 | "deepmerge": "^4.2.2", 228 | "is-module": "^1.0.0", 229 | "resolve": "^1.19.0" 230 | }, 231 | "engines": { 232 | "node": ">= 10.0.0" 233 | }, 234 | "peerDependencies": { 235 | "rollup": "^1.20.0||^2.0.0" 236 | } 237 | }, 238 | "node_modules/@rollup/plugin-typescript": { 239 | "version": "8.5.0", 240 | "resolved": "https://registry.npmjs.org/@rollup/plugin-typescript/-/plugin-typescript-8.5.0.tgz", 241 | "integrity": "sha512-wMv1/scv0m/rXx21wD2IsBbJFba8wGF3ErJIr6IKRfRj49S85Lszbxb4DCo8iILpluTjk2GAAu9CoZt4G3ppgQ==", 242 | "dev": true, 243 | "dependencies": { 244 | "@rollup/pluginutils": "^3.1.0", 245 | "resolve": "^1.17.0" 246 | }, 247 | "engines": { 248 | "node": ">=8.0.0" 249 | }, 250 | "peerDependencies": { 251 | "rollup": "^2.14.0", 252 | "tslib": "*", 253 | "typescript": ">=3.7.0" 254 | }, 255 | "peerDependenciesMeta": { 256 | "tslib": { 257 | "optional": true 258 | } 259 | } 260 | }, 261 | "node_modules/@rollup/pluginutils": { 262 | "version": "3.1.0", 263 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", 264 | "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", 265 | "dev": true, 266 | "dependencies": { 267 | "@types/estree": "0.0.39", 268 | "estree-walker": "^1.0.1", 269 | "picomatch": "^2.2.2" 270 | }, 271 | "engines": { 272 | "node": ">= 8.0.0" 273 | }, 274 | "peerDependencies": { 275 | "rollup": "^1.20.0||^2.0.0" 276 | } 277 | }, 278 | "node_modules/@rollup/pluginutils/node_modules/estree-walker": { 279 | "version": "1.0.1", 280 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", 281 | "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", 282 | "dev": true 283 | }, 284 | "node_modules/@types/codemirror": { 285 | "version": "0.0.108", 286 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.108.tgz", 287 | "integrity": "sha512-3FGFcus0P7C2UOGCNUVENqObEb4SFk+S8Dnxq7K6aIsLVs/vDtlangl3PEO0ykaKXyK56swVF6Nho7VsA44uhw==", 288 | "dev": true, 289 | "dependencies": { 290 | "@types/tern": "*" 291 | } 292 | }, 293 | "node_modules/@types/estree": { 294 | "version": "0.0.39", 295 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", 296 | "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", 297 | "dev": true 298 | }, 299 | "node_modules/@types/fs-extra": { 300 | "version": "8.1.2", 301 | "resolved": "https://registry.npmjs.org/@types/fs-extra/-/fs-extra-8.1.2.tgz", 302 | "integrity": "sha512-SvSrYXfWSc7R4eqnOzbQF4TZmfpNSM9FrSWLU3EUnWBuyZqNBOrv1B1JA3byUDPUl9z4Ab3jeZG2eDdySlgNMg==", 303 | "dev": true, 304 | "dependencies": { 305 | "@types/node": "*" 306 | } 307 | }, 308 | "node_modules/@types/glob": { 309 | "version": "7.2.0", 310 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", 311 | "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", 312 | "dev": true, 313 | "dependencies": { 314 | "@types/minimatch": "*", 315 | "@types/node": "*" 316 | } 317 | }, 318 | "node_modules/@types/json-schema": { 319 | "version": "7.0.15", 320 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 321 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 322 | "dev": true 323 | }, 324 | "node_modules/@types/minimatch": { 325 | "version": "5.1.2", 326 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", 327 | "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", 328 | "dev": true 329 | }, 330 | "node_modules/@types/node": { 331 | "version": "20.10.6", 332 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.10.6.tgz", 333 | "integrity": "sha512-Vac8H+NlRNNlAmDfGUP7b5h/KA+AtWIzuXy0E6OyP8f1tCLYAtPvKRRDJjAPqhpCb0t6U2j7/xqAuLEebW2kiw==", 334 | "dev": true, 335 | "dependencies": { 336 | "undici-types": "~5.26.4" 337 | } 338 | }, 339 | "node_modules/@types/resolve": { 340 | "version": "1.17.1", 341 | "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.17.1.tgz", 342 | "integrity": "sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==", 343 | "dev": true, 344 | "dependencies": { 345 | "@types/node": "*" 346 | } 347 | }, 348 | "node_modules/@types/semver": { 349 | "version": "7.5.6", 350 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz", 351 | "integrity": "sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A==", 352 | "dev": true 353 | }, 354 | "node_modules/@types/tern": { 355 | "version": "0.23.4", 356 | "resolved": "https://registry.npmjs.org/@types/tern/-/tern-0.23.4.tgz", 357 | "integrity": "sha512-JAUw1iXGO1qaWwEOzxTKJZ/5JxVeON9kvGZ/osgZaJImBnyjyn0cjovPsf6FNLmyGY8Vw9DoXZCMlfMkMwHRWg==", 358 | "dev": true, 359 | "dependencies": { 360 | "@types/estree": "*" 361 | } 362 | }, 363 | "node_modules/@typescript-eslint/eslint-plugin": { 364 | "version": "6.17.0", 365 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.17.0.tgz", 366 | "integrity": "sha512-Vih/4xLXmY7V490dGwBQJTpIZxH4ZFH6eCVmQ4RFkB+wmaCTDAx4dtgoWwMNGKLkqRY1L6rPqzEbjorRnDo4rQ==", 367 | "dev": true, 368 | "dependencies": { 369 | "@eslint-community/regexpp": "^4.5.1", 370 | "@typescript-eslint/scope-manager": "6.17.0", 371 | "@typescript-eslint/type-utils": "6.17.0", 372 | "@typescript-eslint/utils": "6.17.0", 373 | "@typescript-eslint/visitor-keys": "6.17.0", 374 | "debug": "^4.3.4", 375 | "graphemer": "^1.4.0", 376 | "ignore": "^5.2.4", 377 | "natural-compare": "^1.4.0", 378 | "semver": "^7.5.4", 379 | "ts-api-utils": "^1.0.1" 380 | }, 381 | "engines": { 382 | "node": "^16.0.0 || >=18.0.0" 383 | }, 384 | "funding": { 385 | "type": "opencollective", 386 | "url": "https://opencollective.com/typescript-eslint" 387 | }, 388 | "peerDependencies": { 389 | "@typescript-eslint/parser": "^6.0.0 || ^6.0.0-alpha", 390 | "eslint": "^7.0.0 || ^8.0.0" 391 | }, 392 | "peerDependenciesMeta": { 393 | "typescript": { 394 | "optional": true 395 | } 396 | } 397 | }, 398 | "node_modules/@typescript-eslint/parser": { 399 | "version": "6.17.0", 400 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.17.0.tgz", 401 | "integrity": "sha512-C4bBaX2orvhK+LlwrY8oWGmSl4WolCfYm513gEccdWZj0CwGadbIADb0FtVEcI+WzUyjyoBj2JRP8g25E6IB8A==", 402 | "dev": true, 403 | "dependencies": { 404 | "@typescript-eslint/scope-manager": "6.17.0", 405 | "@typescript-eslint/types": "6.17.0", 406 | "@typescript-eslint/typescript-estree": "6.17.0", 407 | "@typescript-eslint/visitor-keys": "6.17.0", 408 | "debug": "^4.3.4" 409 | }, 410 | "engines": { 411 | "node": "^16.0.0 || >=18.0.0" 412 | }, 413 | "funding": { 414 | "type": "opencollective", 415 | "url": "https://opencollective.com/typescript-eslint" 416 | }, 417 | "peerDependencies": { 418 | "eslint": "^7.0.0 || ^8.0.0" 419 | }, 420 | "peerDependenciesMeta": { 421 | "typescript": { 422 | "optional": true 423 | } 424 | } 425 | }, 426 | "node_modules/@typescript-eslint/scope-manager": { 427 | "version": "6.17.0", 428 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.17.0.tgz", 429 | "integrity": "sha512-RX7a8lwgOi7am0k17NUO0+ZmMOX4PpjLtLRgLmT1d3lBYdWH4ssBUbwdmc5pdRX8rXon8v9x8vaoOSpkHfcXGA==", 430 | "dev": true, 431 | "dependencies": { 432 | "@typescript-eslint/types": "6.17.0", 433 | "@typescript-eslint/visitor-keys": "6.17.0" 434 | }, 435 | "engines": { 436 | "node": "^16.0.0 || >=18.0.0" 437 | }, 438 | "funding": { 439 | "type": "opencollective", 440 | "url": "https://opencollective.com/typescript-eslint" 441 | } 442 | }, 443 | "node_modules/@typescript-eslint/type-utils": { 444 | "version": "6.17.0", 445 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.17.0.tgz", 446 | "integrity": "sha512-hDXcWmnbtn4P2B37ka3nil3yi3VCQO2QEB9gBiHJmQp5wmyQWqnjA85+ZcE8c4FqnaB6lBwMrPkgd4aBYz3iNg==", 447 | "dev": true, 448 | "dependencies": { 449 | "@typescript-eslint/typescript-estree": "6.17.0", 450 | "@typescript-eslint/utils": "6.17.0", 451 | "debug": "^4.3.4", 452 | "ts-api-utils": "^1.0.1" 453 | }, 454 | "engines": { 455 | "node": "^16.0.0 || >=18.0.0" 456 | }, 457 | "funding": { 458 | "type": "opencollective", 459 | "url": "https://opencollective.com/typescript-eslint" 460 | }, 461 | "peerDependencies": { 462 | "eslint": "^7.0.0 || ^8.0.0" 463 | }, 464 | "peerDependenciesMeta": { 465 | "typescript": { 466 | "optional": true 467 | } 468 | } 469 | }, 470 | "node_modules/@typescript-eslint/types": { 471 | "version": "6.17.0", 472 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.17.0.tgz", 473 | "integrity": "sha512-qRKs9tvc3a4RBcL/9PXtKSehI/q8wuU9xYJxe97WFxnzH8NWWtcW3ffNS+EWg8uPvIerhjsEZ+rHtDqOCiH57A==", 474 | "dev": true, 475 | "engines": { 476 | "node": "^16.0.0 || >=18.0.0" 477 | }, 478 | "funding": { 479 | "type": "opencollective", 480 | "url": "https://opencollective.com/typescript-eslint" 481 | } 482 | }, 483 | "node_modules/@typescript-eslint/typescript-estree": { 484 | "version": "6.17.0", 485 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.17.0.tgz", 486 | "integrity": "sha512-gVQe+SLdNPfjlJn5VNGhlOhrXz4cajwFd5kAgWtZ9dCZf4XJf8xmgCTLIqec7aha3JwgLI2CK6GY1043FRxZwg==", 487 | "dev": true, 488 | "dependencies": { 489 | "@typescript-eslint/types": "6.17.0", 490 | "@typescript-eslint/visitor-keys": "6.17.0", 491 | "debug": "^4.3.4", 492 | "globby": "^11.1.0", 493 | "is-glob": "^4.0.3", 494 | "minimatch": "9.0.3", 495 | "semver": "^7.5.4", 496 | "ts-api-utils": "^1.0.1" 497 | }, 498 | "engines": { 499 | "node": "^16.0.0 || >=18.0.0" 500 | }, 501 | "funding": { 502 | "type": "opencollective", 503 | "url": "https://opencollective.com/typescript-eslint" 504 | }, 505 | "peerDependenciesMeta": { 506 | "typescript": { 507 | "optional": true 508 | } 509 | } 510 | }, 511 | "node_modules/@typescript-eslint/typescript-estree/node_modules/brace-expansion": { 512 | "version": "2.0.1", 513 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 514 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 515 | "dev": true, 516 | "dependencies": { 517 | "balanced-match": "^1.0.0" 518 | } 519 | }, 520 | "node_modules/@typescript-eslint/typescript-estree/node_modules/globby": { 521 | "version": "11.1.0", 522 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 523 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 524 | "dev": true, 525 | "dependencies": { 526 | "array-union": "^2.1.0", 527 | "dir-glob": "^3.0.1", 528 | "fast-glob": "^3.2.9", 529 | "ignore": "^5.2.0", 530 | "merge2": "^1.4.1", 531 | "slash": "^3.0.0" 532 | }, 533 | "engines": { 534 | "node": ">=10" 535 | }, 536 | "funding": { 537 | "url": "https://github.com/sponsors/sindresorhus" 538 | } 539 | }, 540 | "node_modules/@typescript-eslint/typescript-estree/node_modules/minimatch": { 541 | "version": "9.0.3", 542 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", 543 | "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", 544 | "dev": true, 545 | "dependencies": { 546 | "brace-expansion": "^2.0.1" 547 | }, 548 | "engines": { 549 | "node": ">=16 || 14 >=14.17" 550 | }, 551 | "funding": { 552 | "url": "https://github.com/sponsors/isaacs" 553 | } 554 | }, 555 | "node_modules/@typescript-eslint/utils": { 556 | "version": "6.17.0", 557 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.17.0.tgz", 558 | "integrity": "sha512-LofsSPjN/ITNkzV47hxas2JCsNCEnGhVvocfyOcLzT9c/tSZE7SfhS/iWtzP1lKNOEfLhRTZz6xqI8N2RzweSQ==", 559 | "dev": true, 560 | "dependencies": { 561 | "@eslint-community/eslint-utils": "^4.4.0", 562 | "@types/json-schema": "^7.0.12", 563 | "@types/semver": "^7.5.0", 564 | "@typescript-eslint/scope-manager": "6.17.0", 565 | "@typescript-eslint/types": "6.17.0", 566 | "@typescript-eslint/typescript-estree": "6.17.0", 567 | "semver": "^7.5.4" 568 | }, 569 | "engines": { 570 | "node": "^16.0.0 || >=18.0.0" 571 | }, 572 | "funding": { 573 | "type": "opencollective", 574 | "url": "https://opencollective.com/typescript-eslint" 575 | }, 576 | "peerDependencies": { 577 | "eslint": "^7.0.0 || ^8.0.0" 578 | } 579 | }, 580 | "node_modules/@typescript-eslint/visitor-keys": { 581 | "version": "6.17.0", 582 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.17.0.tgz", 583 | "integrity": "sha512-H6VwB/k3IuIeQOyYczyyKN8wH6ed8EwliaYHLxOIhyF0dYEIsN8+Bk3GE19qafeMKyZJJHP8+O1HiFhFLUNKSg==", 584 | "dev": true, 585 | "dependencies": { 586 | "@typescript-eslint/types": "6.17.0", 587 | "eslint-visitor-keys": "^3.4.1" 588 | }, 589 | "engines": { 590 | "node": "^16.0.0 || >=18.0.0" 591 | }, 592 | "funding": { 593 | "type": "opencollective", 594 | "url": "https://opencollective.com/typescript-eslint" 595 | } 596 | }, 597 | "node_modules/@ungap/structured-clone": { 598 | "version": "1.2.0", 599 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 600 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 601 | "dev": true 602 | }, 603 | "node_modules/acorn": { 604 | "version": "7.4.1", 605 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 606 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 607 | "bin": { 608 | "acorn": "bin/acorn" 609 | }, 610 | "engines": { 611 | "node": ">=0.4.0" 612 | } 613 | }, 614 | "node_modules/acorn-jsx": { 615 | "version": "5.3.2", 616 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 617 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 618 | "dev": true, 619 | "peerDependencies": { 620 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 621 | } 622 | }, 623 | "node_modules/acorn-node": { 624 | "version": "1.8.2", 625 | "resolved": "https://registry.npmjs.org/acorn-node/-/acorn-node-1.8.2.tgz", 626 | "integrity": "sha512-8mt+fslDufLYntIoPAaIMUe/lrbrehIiwmR3t2k9LljIzoigEPF27eLk2hy8zSGzmR/ogr7zbRKINMo1u0yh5A==", 627 | "dependencies": { 628 | "acorn": "^7.0.0", 629 | "acorn-walk": "^7.0.0", 630 | "xtend": "^4.0.2" 631 | } 632 | }, 633 | "node_modules/acorn-walk": { 634 | "version": "7.2.0", 635 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", 636 | "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", 637 | "engines": { 638 | "node": ">=0.4.0" 639 | } 640 | }, 641 | "node_modules/ajv": { 642 | "version": "6.12.6", 643 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 644 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 645 | "dev": true, 646 | "dependencies": { 647 | "fast-deep-equal": "^3.1.1", 648 | "fast-json-stable-stringify": "^2.0.0", 649 | "json-schema-traverse": "^0.4.1", 650 | "uri-js": "^4.2.2" 651 | }, 652 | "funding": { 653 | "type": "github", 654 | "url": "https://github.com/sponsors/epoberezkin" 655 | } 656 | }, 657 | "node_modules/ansi-regex": { 658 | "version": "5.0.1", 659 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 660 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 661 | "dev": true, 662 | "engines": { 663 | "node": ">=8" 664 | } 665 | }, 666 | "node_modules/ansi-styles": { 667 | "version": "4.3.0", 668 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 669 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 670 | "dev": true, 671 | "dependencies": { 672 | "color-convert": "^2.0.1" 673 | }, 674 | "engines": { 675 | "node": ">=8" 676 | }, 677 | "funding": { 678 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 679 | } 680 | }, 681 | "node_modules/argparse": { 682 | "version": "2.0.1", 683 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 684 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 685 | "dev": true 686 | }, 687 | "node_modules/array-union": { 688 | "version": "2.1.0", 689 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 690 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 691 | "dev": true, 692 | "engines": { 693 | "node": ">=8" 694 | } 695 | }, 696 | "node_modules/balanced-match": { 697 | "version": "1.0.2", 698 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 699 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 700 | "dev": true 701 | }, 702 | "node_modules/brace-expansion": { 703 | "version": "1.1.11", 704 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 705 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 706 | "dev": true, 707 | "dependencies": { 708 | "balanced-match": "^1.0.0", 709 | "concat-map": "0.0.1" 710 | } 711 | }, 712 | "node_modules/braces": { 713 | "version": "3.0.2", 714 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 715 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 716 | "dev": true, 717 | "dependencies": { 718 | "fill-range": "^7.0.1" 719 | }, 720 | "engines": { 721 | "node": ">=8" 722 | } 723 | }, 724 | "node_modules/builtin-modules": { 725 | "version": "3.3.0", 726 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.3.0.tgz", 727 | "integrity": "sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw==", 728 | "dev": true, 729 | "engines": { 730 | "node": ">=6" 731 | }, 732 | "funding": { 733 | "url": "https://github.com/sponsors/sindresorhus" 734 | } 735 | }, 736 | "node_modules/callsites": { 737 | "version": "3.1.0", 738 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 739 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 740 | "dev": true, 741 | "engines": { 742 | "node": ">=6" 743 | } 744 | }, 745 | "node_modules/chalk": { 746 | "version": "4.1.2", 747 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 748 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 749 | "dev": true, 750 | "dependencies": { 751 | "ansi-styles": "^4.1.0", 752 | "supports-color": "^7.1.0" 753 | }, 754 | "engines": { 755 | "node": ">=10" 756 | }, 757 | "funding": { 758 | "url": "https://github.com/chalk/chalk?sponsor=1" 759 | } 760 | }, 761 | "node_modules/color-convert": { 762 | "version": "2.0.1", 763 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 764 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 765 | "dev": true, 766 | "dependencies": { 767 | "color-name": "~1.1.4" 768 | }, 769 | "engines": { 770 | "node": ">=7.0.0" 771 | } 772 | }, 773 | "node_modules/color-name": { 774 | "version": "1.1.4", 775 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 776 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 777 | "dev": true 778 | }, 779 | "node_modules/colorette": { 780 | "version": "1.4.0", 781 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.4.0.tgz", 782 | "integrity": "sha512-Y2oEozpomLn7Q3HFP7dpww7AtMJplbM9lGZP6RDfHqmbeRjiwRg4n6VM6j4KLmRke85uWEI7JqF17f3pqdRA0g==", 783 | "dev": true 784 | }, 785 | "node_modules/commondir": { 786 | "version": "1.0.1", 787 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 788 | "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", 789 | "dev": true 790 | }, 791 | "node_modules/compare-versions": { 792 | "version": "3.6.0", 793 | "resolved": "https://registry.npmjs.org/compare-versions/-/compare-versions-3.6.0.tgz", 794 | "integrity": "sha512-W6Af2Iw1z4CB7q4uU4hv646dW9GQuBM+YpC0UvUCWSD8w90SJjp+ujJuXaEMtAXBtSqGfMPuFOVn4/+FlaqfBA==" 795 | }, 796 | "node_modules/concat-map": { 797 | "version": "0.0.1", 798 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 799 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 800 | "dev": true 801 | }, 802 | "node_modules/cross-spawn": { 803 | "version": "7.0.3", 804 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 805 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 806 | "dev": true, 807 | "dependencies": { 808 | "path-key": "^3.1.0", 809 | "shebang-command": "^2.0.0", 810 | "which": "^2.0.1" 811 | }, 812 | "engines": { 813 | "node": ">= 8" 814 | } 815 | }, 816 | "node_modules/debug": { 817 | "version": "4.3.4", 818 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 819 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 820 | "dev": true, 821 | "dependencies": { 822 | "ms": "2.1.2" 823 | }, 824 | "engines": { 825 | "node": ">=6.0" 826 | }, 827 | "peerDependenciesMeta": { 828 | "supports-color": { 829 | "optional": true 830 | } 831 | } 832 | }, 833 | "node_modules/debuggable-eval": { 834 | "version": "1.2.0", 835 | "resolved": "https://registry.npmjs.org/debuggable-eval/-/debuggable-eval-1.2.0.tgz", 836 | "integrity": "sha512-JQwOiSLWpM4TobqW0H/YGMPcYw01glVmq6Bn683bOqoaByPi4q2mlmMyOwtA/4KgeT9dKiezIazaFPz229gpoQ==", 837 | "dependencies": { 838 | "syntax-error": "^1.4.0" 839 | } 840 | }, 841 | "node_modules/deep-is": { 842 | "version": "0.1.4", 843 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 844 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 845 | "dev": true 846 | }, 847 | "node_modules/deepmerge": { 848 | "version": "4.3.1", 849 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", 850 | "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", 851 | "dev": true, 852 | "engines": { 853 | "node": ">=0.10.0" 854 | } 855 | }, 856 | "node_modules/dir-glob": { 857 | "version": "3.0.1", 858 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 859 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 860 | "dev": true, 861 | "dependencies": { 862 | "path-type": "^4.0.0" 863 | }, 864 | "engines": { 865 | "node": ">=8" 866 | } 867 | }, 868 | "node_modules/doctrine": { 869 | "version": "3.0.0", 870 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 871 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 872 | "dev": true, 873 | "dependencies": { 874 | "esutils": "^2.0.2" 875 | }, 876 | "engines": { 877 | "node": ">=6.0.0" 878 | } 879 | }, 880 | "node_modules/emoji-regex": { 881 | "version": "10.2.1", 882 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.2.1.tgz", 883 | "integrity": "sha512-97g6QgOk8zlDRdgq1WxwgTMgEWGVAQvB5Fdpgc1MkNy56la5SKP9GsMXKDOdqwn90/41a8yPwIGk1Y6WVbeMQA==", 884 | "dev": true 885 | }, 886 | "node_modules/escape-string-regexp": { 887 | "version": "4.0.0", 888 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 889 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 890 | "dev": true, 891 | "engines": { 892 | "node": ">=10" 893 | }, 894 | "funding": { 895 | "url": "https://github.com/sponsors/sindresorhus" 896 | } 897 | }, 898 | "node_modules/eslint": { 899 | "version": "8.56.0", 900 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.56.0.tgz", 901 | "integrity": "sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==", 902 | "dev": true, 903 | "dependencies": { 904 | "@eslint-community/eslint-utils": "^4.2.0", 905 | "@eslint-community/regexpp": "^4.6.1", 906 | "@eslint/eslintrc": "^2.1.4", 907 | "@eslint/js": "8.56.0", 908 | "@humanwhocodes/config-array": "^0.11.13", 909 | "@humanwhocodes/module-importer": "^1.0.1", 910 | "@nodelib/fs.walk": "^1.2.8", 911 | "@ungap/structured-clone": "^1.2.0", 912 | "ajv": "^6.12.4", 913 | "chalk": "^4.0.0", 914 | "cross-spawn": "^7.0.2", 915 | "debug": "^4.3.2", 916 | "doctrine": "^3.0.0", 917 | "escape-string-regexp": "^4.0.0", 918 | "eslint-scope": "^7.2.2", 919 | "eslint-visitor-keys": "^3.4.3", 920 | "espree": "^9.6.1", 921 | "esquery": "^1.4.2", 922 | "esutils": "^2.0.2", 923 | "fast-deep-equal": "^3.1.3", 924 | "file-entry-cache": "^6.0.1", 925 | "find-up": "^5.0.0", 926 | "glob-parent": "^6.0.2", 927 | "globals": "^13.19.0", 928 | "graphemer": "^1.4.0", 929 | "ignore": "^5.2.0", 930 | "imurmurhash": "^0.1.4", 931 | "is-glob": "^4.0.0", 932 | "is-path-inside": "^3.0.3", 933 | "js-yaml": "^4.1.0", 934 | "json-stable-stringify-without-jsonify": "^1.0.1", 935 | "levn": "^0.4.1", 936 | "lodash.merge": "^4.6.2", 937 | "minimatch": "^3.1.2", 938 | "natural-compare": "^1.4.0", 939 | "optionator": "^0.9.3", 940 | "strip-ansi": "^6.0.1", 941 | "text-table": "^0.2.0" 942 | }, 943 | "bin": { 944 | "eslint": "bin/eslint.js" 945 | }, 946 | "engines": { 947 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 948 | }, 949 | "funding": { 950 | "url": "https://opencollective.com/eslint" 951 | } 952 | }, 953 | "node_modules/eslint-plugin-prettier": { 954 | "version": "5.1.2", 955 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.1.2.tgz", 956 | "integrity": "sha512-dhlpWc9vOwohcWmClFcA+HjlvUpuyynYs0Rf+L/P6/0iQE6vlHW9l5bkfzN62/Stm9fbq8ku46qzde76T1xlSg==", 957 | "dev": true, 958 | "dependencies": { 959 | "prettier-linter-helpers": "^1.0.0", 960 | "synckit": "^0.8.6" 961 | }, 962 | "engines": { 963 | "node": "^14.18.0 || >=16.0.0" 964 | }, 965 | "funding": { 966 | "url": "https://opencollective.com/eslint-plugin-prettier" 967 | }, 968 | "peerDependencies": { 969 | "@types/eslint": ">=8.0.0", 970 | "eslint": ">=8.0.0", 971 | "eslint-config-prettier": "*", 972 | "prettier": ">=3.0.0" 973 | }, 974 | "peerDependenciesMeta": { 975 | "@types/eslint": { 976 | "optional": true 977 | }, 978 | "eslint-config-prettier": { 979 | "optional": true 980 | } 981 | } 982 | }, 983 | "node_modules/eslint-scope": { 984 | "version": "7.2.2", 985 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 986 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 987 | "dev": true, 988 | "dependencies": { 989 | "esrecurse": "^4.3.0", 990 | "estraverse": "^5.2.0" 991 | }, 992 | "engines": { 993 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 994 | }, 995 | "funding": { 996 | "url": "https://opencollective.com/eslint" 997 | } 998 | }, 999 | "node_modules/eslint-visitor-keys": { 1000 | "version": "3.4.3", 1001 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 1002 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 1003 | "dev": true, 1004 | "engines": { 1005 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1006 | }, 1007 | "funding": { 1008 | "url": "https://opencollective.com/eslint" 1009 | } 1010 | }, 1011 | "node_modules/eslint/node_modules/glob-parent": { 1012 | "version": "6.0.2", 1013 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 1014 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 1015 | "dev": true, 1016 | "dependencies": { 1017 | "is-glob": "^4.0.3" 1018 | }, 1019 | "engines": { 1020 | "node": ">=10.13.0" 1021 | } 1022 | }, 1023 | "node_modules/espree": { 1024 | "version": "9.6.1", 1025 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 1026 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 1027 | "dev": true, 1028 | "dependencies": { 1029 | "acorn": "^8.9.0", 1030 | "acorn-jsx": "^5.3.2", 1031 | "eslint-visitor-keys": "^3.4.1" 1032 | }, 1033 | "engines": { 1034 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 1035 | }, 1036 | "funding": { 1037 | "url": "https://opencollective.com/eslint" 1038 | } 1039 | }, 1040 | "node_modules/espree/node_modules/acorn": { 1041 | "version": "8.11.3", 1042 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 1043 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 1044 | "dev": true, 1045 | "bin": { 1046 | "acorn": "bin/acorn" 1047 | }, 1048 | "engines": { 1049 | "node": ">=0.4.0" 1050 | } 1051 | }, 1052 | "node_modules/esquery": { 1053 | "version": "1.5.0", 1054 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 1055 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 1056 | "dev": true, 1057 | "dependencies": { 1058 | "estraverse": "^5.1.0" 1059 | }, 1060 | "engines": { 1061 | "node": ">=0.10" 1062 | } 1063 | }, 1064 | "node_modules/esrecurse": { 1065 | "version": "4.3.0", 1066 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 1067 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 1068 | "dev": true, 1069 | "dependencies": { 1070 | "estraverse": "^5.2.0" 1071 | }, 1072 | "engines": { 1073 | "node": ">=4.0" 1074 | } 1075 | }, 1076 | "node_modules/estraverse": { 1077 | "version": "5.3.0", 1078 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1079 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1080 | "dev": true, 1081 | "engines": { 1082 | "node": ">=4.0" 1083 | } 1084 | }, 1085 | "node_modules/estree-walker": { 1086 | "version": "2.0.2", 1087 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", 1088 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==", 1089 | "dev": true 1090 | }, 1091 | "node_modules/esutils": { 1092 | "version": "2.0.3", 1093 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1094 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1095 | "dev": true, 1096 | "engines": { 1097 | "node": ">=0.10.0" 1098 | } 1099 | }, 1100 | "node_modules/fast-deep-equal": { 1101 | "version": "3.1.3", 1102 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 1103 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 1104 | "dev": true 1105 | }, 1106 | "node_modules/fast-diff": { 1107 | "version": "1.3.0", 1108 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", 1109 | "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", 1110 | "dev": true 1111 | }, 1112 | "node_modules/fast-glob": { 1113 | "version": "3.3.1", 1114 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.1.tgz", 1115 | "integrity": "sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg==", 1116 | "dev": true, 1117 | "dependencies": { 1118 | "@nodelib/fs.stat": "^2.0.2", 1119 | "@nodelib/fs.walk": "^1.2.3", 1120 | "glob-parent": "^5.1.2", 1121 | "merge2": "^1.3.0", 1122 | "micromatch": "^4.0.4" 1123 | }, 1124 | "engines": { 1125 | "node": ">=8.6.0" 1126 | } 1127 | }, 1128 | "node_modules/fast-json-stable-stringify": { 1129 | "version": "2.1.0", 1130 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1131 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1132 | "dev": true 1133 | }, 1134 | "node_modules/fast-levenshtein": { 1135 | "version": "2.0.6", 1136 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1137 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 1138 | "dev": true 1139 | }, 1140 | "node_modules/fastq": { 1141 | "version": "1.15.0", 1142 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 1143 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 1144 | "dev": true, 1145 | "dependencies": { 1146 | "reusify": "^1.0.4" 1147 | } 1148 | }, 1149 | "node_modules/file-entry-cache": { 1150 | "version": "6.0.1", 1151 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 1152 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 1153 | "dev": true, 1154 | "dependencies": { 1155 | "flat-cache": "^3.0.4" 1156 | }, 1157 | "engines": { 1158 | "node": "^10.12.0 || >=12.0.0" 1159 | } 1160 | }, 1161 | "node_modules/fill-range": { 1162 | "version": "7.0.1", 1163 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1164 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1165 | "dev": true, 1166 | "dependencies": { 1167 | "to-regex-range": "^5.0.1" 1168 | }, 1169 | "engines": { 1170 | "node": ">=8" 1171 | } 1172 | }, 1173 | "node_modules/find-up": { 1174 | "version": "5.0.0", 1175 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1176 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1177 | "dev": true, 1178 | "dependencies": { 1179 | "locate-path": "^6.0.0", 1180 | "path-exists": "^4.0.0" 1181 | }, 1182 | "engines": { 1183 | "node": ">=10" 1184 | }, 1185 | "funding": { 1186 | "url": "https://github.com/sponsors/sindresorhus" 1187 | } 1188 | }, 1189 | "node_modules/flat-cache": { 1190 | "version": "3.2.0", 1191 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 1192 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 1193 | "dev": true, 1194 | "dependencies": { 1195 | "flatted": "^3.2.9", 1196 | "keyv": "^4.5.3", 1197 | "rimraf": "^3.0.2" 1198 | }, 1199 | "engines": { 1200 | "node": "^10.12.0 || >=12.0.0" 1201 | } 1202 | }, 1203 | "node_modules/flatted": { 1204 | "version": "3.2.9", 1205 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", 1206 | "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==", 1207 | "dev": true 1208 | }, 1209 | "node_modules/fs-extra": { 1210 | "version": "8.1.0", 1211 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 1212 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 1213 | "dev": true, 1214 | "dependencies": { 1215 | "graceful-fs": "^4.2.0", 1216 | "jsonfile": "^4.0.0", 1217 | "universalify": "^0.1.0" 1218 | }, 1219 | "engines": { 1220 | "node": ">=6 <7 || >=8" 1221 | } 1222 | }, 1223 | "node_modules/fs.realpath": { 1224 | "version": "1.0.0", 1225 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1226 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1227 | "dev": true 1228 | }, 1229 | "node_modules/fsevents": { 1230 | "version": "2.3.3", 1231 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 1232 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 1233 | "dev": true, 1234 | "hasInstallScript": true, 1235 | "optional": true, 1236 | "os": [ 1237 | "darwin" 1238 | ], 1239 | "engines": { 1240 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1241 | } 1242 | }, 1243 | "node_modules/function-bind": { 1244 | "version": "1.1.1", 1245 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1246 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1247 | "dev": true 1248 | }, 1249 | "node_modules/glob": { 1250 | "version": "7.2.3", 1251 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1252 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1253 | "dev": true, 1254 | "dependencies": { 1255 | "fs.realpath": "^1.0.0", 1256 | "inflight": "^1.0.4", 1257 | "inherits": "2", 1258 | "minimatch": "^3.1.1", 1259 | "once": "^1.3.0", 1260 | "path-is-absolute": "^1.0.0" 1261 | }, 1262 | "engines": { 1263 | "node": "*" 1264 | }, 1265 | "funding": { 1266 | "url": "https://github.com/sponsors/isaacs" 1267 | } 1268 | }, 1269 | "node_modules/glob-parent": { 1270 | "version": "5.1.2", 1271 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1272 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1273 | "dev": true, 1274 | "dependencies": { 1275 | "is-glob": "^4.0.1" 1276 | }, 1277 | "engines": { 1278 | "node": ">= 6" 1279 | } 1280 | }, 1281 | "node_modules/globals": { 1282 | "version": "13.24.0", 1283 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 1284 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 1285 | "dev": true, 1286 | "dependencies": { 1287 | "type-fest": "^0.20.2" 1288 | }, 1289 | "engines": { 1290 | "node": ">=8" 1291 | }, 1292 | "funding": { 1293 | "url": "https://github.com/sponsors/sindresorhus" 1294 | } 1295 | }, 1296 | "node_modules/globby": { 1297 | "version": "10.0.1", 1298 | "resolved": "https://registry.npmjs.org/globby/-/globby-10.0.1.tgz", 1299 | "integrity": "sha512-sSs4inE1FB2YQiymcmTv6NWENryABjUNPeWhOvmn4SjtKybglsyPZxFB3U1/+L1bYi0rNZDqCLlHyLYDl1Pq5A==", 1300 | "dev": true, 1301 | "dependencies": { 1302 | "@types/glob": "^7.1.1", 1303 | "array-union": "^2.1.0", 1304 | "dir-glob": "^3.0.1", 1305 | "fast-glob": "^3.0.3", 1306 | "glob": "^7.1.3", 1307 | "ignore": "^5.1.1", 1308 | "merge2": "^1.2.3", 1309 | "slash": "^3.0.0" 1310 | }, 1311 | "engines": { 1312 | "node": ">=8" 1313 | } 1314 | }, 1315 | "node_modules/graceful-fs": { 1316 | "version": "4.2.11", 1317 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1318 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 1319 | "dev": true 1320 | }, 1321 | "node_modules/graphemer": { 1322 | "version": "1.4.0", 1323 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 1324 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 1325 | "dev": true 1326 | }, 1327 | "node_modules/has": { 1328 | "version": "1.0.3", 1329 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1330 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1331 | "dev": true, 1332 | "dependencies": { 1333 | "function-bind": "^1.1.1" 1334 | }, 1335 | "engines": { 1336 | "node": ">= 0.4.0" 1337 | } 1338 | }, 1339 | "node_modules/has-flag": { 1340 | "version": "4.0.0", 1341 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1342 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1343 | "dev": true, 1344 | "engines": { 1345 | "node": ">=8" 1346 | } 1347 | }, 1348 | "node_modules/ignore": { 1349 | "version": "5.2.4", 1350 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 1351 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 1352 | "dev": true, 1353 | "engines": { 1354 | "node": ">= 4" 1355 | } 1356 | }, 1357 | "node_modules/import-fresh": { 1358 | "version": "3.3.0", 1359 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 1360 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 1361 | "dev": true, 1362 | "dependencies": { 1363 | "parent-module": "^1.0.0", 1364 | "resolve-from": "^4.0.0" 1365 | }, 1366 | "engines": { 1367 | "node": ">=6" 1368 | }, 1369 | "funding": { 1370 | "url": "https://github.com/sponsors/sindresorhus" 1371 | } 1372 | }, 1373 | "node_modules/imurmurhash": { 1374 | "version": "0.1.4", 1375 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1376 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 1377 | "dev": true, 1378 | "engines": { 1379 | "node": ">=0.8.19" 1380 | } 1381 | }, 1382 | "node_modules/inflight": { 1383 | "version": "1.0.6", 1384 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1385 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1386 | "dev": true, 1387 | "dependencies": { 1388 | "once": "^1.3.0", 1389 | "wrappy": "1" 1390 | } 1391 | }, 1392 | "node_modules/inherits": { 1393 | "version": "2.0.4", 1394 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1395 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1396 | "dev": true 1397 | }, 1398 | "node_modules/is-core-module": { 1399 | "version": "2.13.0", 1400 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.0.tgz", 1401 | "integrity": "sha512-Z7dk6Qo8pOCp3l4tsX2C5ZVas4V+UxwQodwZhLopL91TX8UyyHEXafPcyoeeWuLrwzHcr3igO78wNLwHJHsMCQ==", 1402 | "dev": true, 1403 | "dependencies": { 1404 | "has": "^1.0.3" 1405 | }, 1406 | "funding": { 1407 | "url": "https://github.com/sponsors/ljharb" 1408 | } 1409 | }, 1410 | "node_modules/is-extglob": { 1411 | "version": "2.1.1", 1412 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1413 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1414 | "dev": true, 1415 | "engines": { 1416 | "node": ">=0.10.0" 1417 | } 1418 | }, 1419 | "node_modules/is-glob": { 1420 | "version": "4.0.3", 1421 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1422 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1423 | "dev": true, 1424 | "dependencies": { 1425 | "is-extglob": "^2.1.1" 1426 | }, 1427 | "engines": { 1428 | "node": ">=0.10.0" 1429 | } 1430 | }, 1431 | "node_modules/is-module": { 1432 | "version": "1.0.0", 1433 | "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", 1434 | "integrity": "sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g==", 1435 | "dev": true 1436 | }, 1437 | "node_modules/is-number": { 1438 | "version": "7.0.0", 1439 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1440 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1441 | "dev": true, 1442 | "engines": { 1443 | "node": ">=0.12.0" 1444 | } 1445 | }, 1446 | "node_modules/is-path-inside": { 1447 | "version": "3.0.3", 1448 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 1449 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 1450 | "dev": true, 1451 | "engines": { 1452 | "node": ">=8" 1453 | } 1454 | }, 1455 | "node_modules/is-plain-object": { 1456 | "version": "3.0.1", 1457 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-3.0.1.tgz", 1458 | "integrity": "sha512-Xnpx182SBMrr/aBik8y+GuR4U1L9FqMSojwDQwPMmxyC6bvEqly9UBCxhauBF5vNh2gwWJNX6oDV7O+OM4z34g==", 1459 | "dev": true, 1460 | "engines": { 1461 | "node": ">=0.10.0" 1462 | } 1463 | }, 1464 | "node_modules/is-reference": { 1465 | "version": "1.2.1", 1466 | "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-1.2.1.tgz", 1467 | "integrity": "sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==", 1468 | "dev": true, 1469 | "dependencies": { 1470 | "@types/estree": "*" 1471 | } 1472 | }, 1473 | "node_modules/isexe": { 1474 | "version": "2.0.0", 1475 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1476 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1477 | "dev": true 1478 | }, 1479 | "node_modules/js-yaml": { 1480 | "version": "4.1.0", 1481 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 1482 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 1483 | "dev": true, 1484 | "dependencies": { 1485 | "argparse": "^2.0.1" 1486 | }, 1487 | "bin": { 1488 | "js-yaml": "bin/js-yaml.js" 1489 | } 1490 | }, 1491 | "node_modules/json-buffer": { 1492 | "version": "3.0.1", 1493 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 1494 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 1495 | "dev": true 1496 | }, 1497 | "node_modules/json-schema-traverse": { 1498 | "version": "0.4.1", 1499 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1500 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1501 | "dev": true 1502 | }, 1503 | "node_modules/json-stable-stringify-without-jsonify": { 1504 | "version": "1.0.1", 1505 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1506 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 1507 | "dev": true 1508 | }, 1509 | "node_modules/jsonfile": { 1510 | "version": "4.0.0", 1511 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 1512 | "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", 1513 | "dev": true, 1514 | "optionalDependencies": { 1515 | "graceful-fs": "^4.1.6" 1516 | } 1517 | }, 1518 | "node_modules/keyv": { 1519 | "version": "4.5.4", 1520 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 1521 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 1522 | "dev": true, 1523 | "dependencies": { 1524 | "json-buffer": "3.0.1" 1525 | } 1526 | }, 1527 | "node_modules/levn": { 1528 | "version": "0.4.1", 1529 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 1530 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 1531 | "dev": true, 1532 | "dependencies": { 1533 | "prelude-ls": "^1.2.1", 1534 | "type-check": "~0.4.0" 1535 | }, 1536 | "engines": { 1537 | "node": ">= 0.8.0" 1538 | } 1539 | }, 1540 | "node_modules/locate-path": { 1541 | "version": "6.0.0", 1542 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1543 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1544 | "dev": true, 1545 | "dependencies": { 1546 | "p-locate": "^5.0.0" 1547 | }, 1548 | "engines": { 1549 | "node": ">=10" 1550 | }, 1551 | "funding": { 1552 | "url": "https://github.com/sponsors/sindresorhus" 1553 | } 1554 | }, 1555 | "node_modules/lodash.merge": { 1556 | "version": "4.6.2", 1557 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 1558 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 1559 | "dev": true 1560 | }, 1561 | "node_modules/lru-cache": { 1562 | "version": "6.0.0", 1563 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1564 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1565 | "dev": true, 1566 | "dependencies": { 1567 | "yallist": "^4.0.0" 1568 | }, 1569 | "engines": { 1570 | "node": ">=10" 1571 | } 1572 | }, 1573 | "node_modules/luxon": { 1574 | "version": "2.5.2", 1575 | "resolved": "https://registry.npmjs.org/luxon/-/luxon-2.5.2.tgz", 1576 | "integrity": "sha512-Yg7/RDp4nedqmLgyH0LwgGRvMEKVzKbUdkBYyCosbHgJ+kaOUx0qzSiSatVc3DFygnirTPYnMM2P5dg2uH1WvA==", 1577 | "dev": true, 1578 | "engines": { 1579 | "node": ">=12" 1580 | } 1581 | }, 1582 | "node_modules/magic-string": { 1583 | "version": "0.25.9", 1584 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 1585 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 1586 | "dev": true, 1587 | "dependencies": { 1588 | "sourcemap-codec": "^1.4.8" 1589 | } 1590 | }, 1591 | "node_modules/merge2": { 1592 | "version": "1.4.1", 1593 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 1594 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 1595 | "dev": true, 1596 | "engines": { 1597 | "node": ">= 8" 1598 | } 1599 | }, 1600 | "node_modules/micromatch": { 1601 | "version": "4.0.5", 1602 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 1603 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 1604 | "dev": true, 1605 | "dependencies": { 1606 | "braces": "^3.0.2", 1607 | "picomatch": "^2.3.1" 1608 | }, 1609 | "engines": { 1610 | "node": ">=8.6" 1611 | } 1612 | }, 1613 | "node_modules/minimatch": { 1614 | "version": "3.1.2", 1615 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 1616 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 1617 | "dev": true, 1618 | "dependencies": { 1619 | "brace-expansion": "^1.1.7" 1620 | }, 1621 | "engines": { 1622 | "node": "*" 1623 | } 1624 | }, 1625 | "node_modules/moment": { 1626 | "version": "2.29.1", 1627 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 1628 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==", 1629 | "dev": true, 1630 | "engines": { 1631 | "node": "*" 1632 | } 1633 | }, 1634 | "node_modules/ms": { 1635 | "version": "2.1.2", 1636 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1637 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1638 | "dev": true 1639 | }, 1640 | "node_modules/natural-compare": { 1641 | "version": "1.4.0", 1642 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1643 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 1644 | "dev": true 1645 | }, 1646 | "node_modules/obsidian": { 1647 | "version": "0.12.17", 1648 | "resolved": "https://registry.npmjs.org/obsidian/-/obsidian-0.12.17.tgz", 1649 | "integrity": "sha512-YvCAlRym9D8zNPXt6Ez8QubSTVGoChx6lb58zqI13Dcrz3l1lgUO+pcOGDiD5Qa67nzDZLXo3aV2rqkCCpTvGQ==", 1650 | "dev": true, 1651 | "dependencies": { 1652 | "@types/codemirror": "0.0.108", 1653 | "moment": "2.29.1" 1654 | } 1655 | }, 1656 | "node_modules/obsidian-calendar-ui": { 1657 | "version": "0.3.12", 1658 | "resolved": "https://registry.npmjs.org/obsidian-calendar-ui/-/obsidian-calendar-ui-0.3.12.tgz", 1659 | "integrity": "sha512-hdoRqCPnukfRgCARgArXaqMQZ+Iai0eY7f0ZsFHHfywpv4gKg3Tx5p47UsLvRO5DD+4knlbrL7Gel57MkfcLTw==", 1660 | "dev": true, 1661 | "dependencies": { 1662 | "obsidian-daily-notes-interface": "0.8.4", 1663 | "svelte": "3.35.0", 1664 | "tslib": "2.1.0" 1665 | } 1666 | }, 1667 | "node_modules/obsidian-calendar-ui/node_modules/tslib": { 1668 | "version": "2.1.0", 1669 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.1.0.tgz", 1670 | "integrity": "sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A==", 1671 | "dev": true 1672 | }, 1673 | "node_modules/obsidian-daily-notes-interface": { 1674 | "version": "0.8.4", 1675 | "resolved": "https://registry.npmjs.org/obsidian-daily-notes-interface/-/obsidian-daily-notes-interface-0.8.4.tgz", 1676 | "integrity": "sha512-REKQtAuIOKDbvNH/th1C1gWmJWCP5tRn9T/mfZGZt4Zncgko7McXK0aSKFtEInipvgbZJ2nScivvyLdiWluSMw==", 1677 | "dev": true, 1678 | "dependencies": { 1679 | "obsidian": "github:obsidianmd/obsidian-api#master", 1680 | "tslib": "2.1.0" 1681 | }, 1682 | "bin": { 1683 | "obsidian-daily-notes-interface": "dist/main.js" 1684 | } 1685 | }, 1686 | "node_modules/obsidian-daily-notes-interface/node_modules/@types/codemirror": { 1687 | "version": "5.60.8", 1688 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-5.60.8.tgz", 1689 | "integrity": "sha512-VjFgDF/eB+Aklcy15TtOTLQeMjTo07k7KAjql8OK5Dirr7a6sJY4T1uVBDuTVG9VEmn1uUsohOpYnVfgC6/jyw==", 1690 | "dev": true, 1691 | "dependencies": { 1692 | "@types/tern": "*" 1693 | } 1694 | }, 1695 | "node_modules/obsidian-daily-notes-interface/node_modules/moment": { 1696 | "version": "2.29.4", 1697 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 1698 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 1699 | "dev": true, 1700 | "engines": { 1701 | "node": "*" 1702 | } 1703 | }, 1704 | "node_modules/obsidian-daily-notes-interface/node_modules/obsidian": { 1705 | "version": "1.4.4", 1706 | "resolved": "git+ssh://git@github.com/obsidianmd/obsidian-api.git#5178e27f0eb12741c79914f52146de8ff827e390", 1707 | "integrity": "sha512-9tP/rlolCjjrYdVDD6cIy/jLSd9/Hrdo8Jo9loGk9KiQbHWiWISrw5V2SyA5RmD7qX/+2Au2hfVwS+Ye8lZArA==", 1708 | "dev": true, 1709 | "license": "MIT", 1710 | "dependencies": { 1711 | "@types/codemirror": "5.60.8", 1712 | "moment": "2.29.4" 1713 | }, 1714 | "peerDependencies": { 1715 | "@codemirror/state": "^6.0.0", 1716 | "@codemirror/view": "^6.0.0" 1717 | } 1718 | }, 1719 | "node_modules/obsidian-daily-notes-interface/node_modules/tslib": { 1720 | "version": "2.1.0", 1721 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.1.0.tgz", 1722 | "integrity": "sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A==", 1723 | "dev": true 1724 | }, 1725 | "node_modules/obsidian-dataview": { 1726 | "version": "0.4.25", 1727 | "resolved": "https://registry.npmjs.org/obsidian-dataview/-/obsidian-dataview-0.4.25.tgz", 1728 | "integrity": "sha512-Na0/3BDFn04jHN0La4F1YgoGg2AwKuH8UrL+oYAczXQDqOsvghGeuZBf4nATj1eDUk0HbVmrKYdnqoSec/Tt6Q==", 1729 | "dev": true, 1730 | "dependencies": { 1731 | "emoji-regex": "^10.0.0", 1732 | "luxon": "^2.0.2", 1733 | "obsidian-calendar-ui": "^0.3.12", 1734 | "papaparse": "^5.3.1", 1735 | "parsimmon": "^1.18.0", 1736 | "preact": "^10.6.5" 1737 | } 1738 | }, 1739 | "node_modules/once": { 1740 | "version": "1.4.0", 1741 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1742 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 1743 | "dev": true, 1744 | "dependencies": { 1745 | "wrappy": "1" 1746 | } 1747 | }, 1748 | "node_modules/optionator": { 1749 | "version": "0.9.3", 1750 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 1751 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 1752 | "dev": true, 1753 | "dependencies": { 1754 | "@aashutoshrathi/word-wrap": "^1.2.3", 1755 | "deep-is": "^0.1.3", 1756 | "fast-levenshtein": "^2.0.6", 1757 | "levn": "^0.4.1", 1758 | "prelude-ls": "^1.2.1", 1759 | "type-check": "^0.4.0" 1760 | }, 1761 | "engines": { 1762 | "node": ">= 0.8.0" 1763 | } 1764 | }, 1765 | "node_modules/p-limit": { 1766 | "version": "3.1.0", 1767 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 1768 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 1769 | "dev": true, 1770 | "dependencies": { 1771 | "yocto-queue": "^0.1.0" 1772 | }, 1773 | "engines": { 1774 | "node": ">=10" 1775 | }, 1776 | "funding": { 1777 | "url": "https://github.com/sponsors/sindresorhus" 1778 | } 1779 | }, 1780 | "node_modules/p-locate": { 1781 | "version": "5.0.0", 1782 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1783 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1784 | "dev": true, 1785 | "dependencies": { 1786 | "p-limit": "^3.0.2" 1787 | }, 1788 | "engines": { 1789 | "node": ">=10" 1790 | }, 1791 | "funding": { 1792 | "url": "https://github.com/sponsors/sindresorhus" 1793 | } 1794 | }, 1795 | "node_modules/papaparse": { 1796 | "version": "5.4.1", 1797 | "resolved": "https://registry.npmjs.org/papaparse/-/papaparse-5.4.1.tgz", 1798 | "integrity": "sha512-HipMsgJkZu8br23pW15uvo6sib6wne/4woLZPlFf3rpDyMe9ywEXUsuD7+6K9PRkJlVT51j/sCOYDKGGS3ZJrw==", 1799 | "dev": true 1800 | }, 1801 | "node_modules/parent-module": { 1802 | "version": "1.0.1", 1803 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1804 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1805 | "dev": true, 1806 | "dependencies": { 1807 | "callsites": "^3.0.0" 1808 | }, 1809 | "engines": { 1810 | "node": ">=6" 1811 | } 1812 | }, 1813 | "node_modules/parsimmon": { 1814 | "version": "1.18.1", 1815 | "resolved": "https://registry.npmjs.org/parsimmon/-/parsimmon-1.18.1.tgz", 1816 | "integrity": "sha512-u7p959wLfGAhJpSDJVYXoyMCXWYwHia78HhRBWqk7AIbxdmlrfdp5wX0l3xv/iTSH5HvhN9K7o26hwwpgS5Nmw==", 1817 | "dev": true 1818 | }, 1819 | "node_modules/path-exists": { 1820 | "version": "4.0.0", 1821 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1822 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1823 | "dev": true, 1824 | "engines": { 1825 | "node": ">=8" 1826 | } 1827 | }, 1828 | "node_modules/path-is-absolute": { 1829 | "version": "1.0.1", 1830 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1831 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 1832 | "dev": true, 1833 | "engines": { 1834 | "node": ">=0.10.0" 1835 | } 1836 | }, 1837 | "node_modules/path-key": { 1838 | "version": "3.1.1", 1839 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1840 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1841 | "dev": true, 1842 | "engines": { 1843 | "node": ">=8" 1844 | } 1845 | }, 1846 | "node_modules/path-parse": { 1847 | "version": "1.0.7", 1848 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1849 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 1850 | "dev": true 1851 | }, 1852 | "node_modules/path-type": { 1853 | "version": "4.0.0", 1854 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 1855 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 1856 | "dev": true, 1857 | "engines": { 1858 | "node": ">=8" 1859 | } 1860 | }, 1861 | "node_modules/picomatch": { 1862 | "version": "2.3.1", 1863 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1864 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1865 | "dev": true, 1866 | "engines": { 1867 | "node": ">=8.6" 1868 | }, 1869 | "funding": { 1870 | "url": "https://github.com/sponsors/jonschlinkert" 1871 | } 1872 | }, 1873 | "node_modules/preact": { 1874 | "version": "10.17.1", 1875 | "resolved": "https://registry.npmjs.org/preact/-/preact-10.17.1.tgz", 1876 | "integrity": "sha512-X9BODrvQ4Ekwv9GURm9AKAGaomqXmip7NQTZgY7gcNmr7XE83adOMJvd3N42id1tMFU7ojiynRsYnY6/BRFxLA==", 1877 | "dev": true, 1878 | "funding": { 1879 | "type": "opencollective", 1880 | "url": "https://opencollective.com/preact" 1881 | } 1882 | }, 1883 | "node_modules/prelude-ls": { 1884 | "version": "1.2.1", 1885 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 1886 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 1887 | "dev": true, 1888 | "engines": { 1889 | "node": ">= 0.8.0" 1890 | } 1891 | }, 1892 | "node_modules/prettier": { 1893 | "version": "3.1.1", 1894 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.1.1.tgz", 1895 | "integrity": "sha512-22UbSzg8luF4UuZtzgiUOfcGM8s4tjBv6dJRT7j275NXsy2jb4aJa4NNveul5x4eqlF1wuhuR2RElK71RvmVaw==", 1896 | "dev": true, 1897 | "bin": { 1898 | "prettier": "bin/prettier.cjs" 1899 | }, 1900 | "engines": { 1901 | "node": ">=14" 1902 | }, 1903 | "funding": { 1904 | "url": "https://github.com/prettier/prettier?sponsor=1" 1905 | } 1906 | }, 1907 | "node_modules/prettier-linter-helpers": { 1908 | "version": "1.0.0", 1909 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 1910 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 1911 | "dev": true, 1912 | "dependencies": { 1913 | "fast-diff": "^1.1.2" 1914 | }, 1915 | "engines": { 1916 | "node": ">=6.0.0" 1917 | } 1918 | }, 1919 | "node_modules/punycode": { 1920 | "version": "2.3.1", 1921 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 1922 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 1923 | "dev": true, 1924 | "engines": { 1925 | "node": ">=6" 1926 | } 1927 | }, 1928 | "node_modules/queue-microtask": { 1929 | "version": "1.2.3", 1930 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 1931 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 1932 | "dev": true, 1933 | "funding": [ 1934 | { 1935 | "type": "github", 1936 | "url": "https://github.com/sponsors/feross" 1937 | }, 1938 | { 1939 | "type": "patreon", 1940 | "url": "https://www.patreon.com/feross" 1941 | }, 1942 | { 1943 | "type": "consulting", 1944 | "url": "https://feross.org/support" 1945 | } 1946 | ] 1947 | }, 1948 | "node_modules/resolve": { 1949 | "version": "1.22.4", 1950 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.4.tgz", 1951 | "integrity": "sha512-PXNdCiPqDqeUou+w1C2eTQbNfxKSuMxqTCuvlmmMsk1NWHL5fRrhY6Pl0qEYYc6+QqGClco1Qj8XnjPego4wfg==", 1952 | "dev": true, 1953 | "dependencies": { 1954 | "is-core-module": "^2.13.0", 1955 | "path-parse": "^1.0.7", 1956 | "supports-preserve-symlinks-flag": "^1.0.0" 1957 | }, 1958 | "bin": { 1959 | "resolve": "bin/resolve" 1960 | }, 1961 | "funding": { 1962 | "url": "https://github.com/sponsors/ljharb" 1963 | } 1964 | }, 1965 | "node_modules/resolve-from": { 1966 | "version": "4.0.0", 1967 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1968 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1969 | "dev": true, 1970 | "engines": { 1971 | "node": ">=4" 1972 | } 1973 | }, 1974 | "node_modules/reusify": { 1975 | "version": "1.0.4", 1976 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 1977 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 1978 | "dev": true, 1979 | "engines": { 1980 | "iojs": ">=1.0.0", 1981 | "node": ">=0.10.0" 1982 | } 1983 | }, 1984 | "node_modules/rimraf": { 1985 | "version": "3.0.2", 1986 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 1987 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 1988 | "dev": true, 1989 | "dependencies": { 1990 | "glob": "^7.1.3" 1991 | }, 1992 | "bin": { 1993 | "rimraf": "bin.js" 1994 | }, 1995 | "funding": { 1996 | "url": "https://github.com/sponsors/isaacs" 1997 | } 1998 | }, 1999 | "node_modules/rollup": { 2000 | "version": "2.79.1", 2001 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.79.1.tgz", 2002 | "integrity": "sha512-uKxbd0IhMZOhjAiD5oAFp7BqvkA4Dv47qpOCtaNvng4HBwdbWtdOh8f5nZNuk2rp51PMGk3bzfWu5oayNEuYnw==", 2003 | "dev": true, 2004 | "bin": { 2005 | "rollup": "dist/bin/rollup" 2006 | }, 2007 | "engines": { 2008 | "node": ">=10.0.0" 2009 | }, 2010 | "optionalDependencies": { 2011 | "fsevents": "~2.3.2" 2012 | } 2013 | }, 2014 | "node_modules/rollup-plugin-copy": { 2015 | "version": "3.4.0", 2016 | "resolved": "https://registry.npmjs.org/rollup-plugin-copy/-/rollup-plugin-copy-3.4.0.tgz", 2017 | "integrity": "sha512-rGUmYYsYsceRJRqLVlE9FivJMxJ7X6jDlP79fmFkL8sJs7VVMSVyA2yfyL+PGyO/vJs4A87hwhgVfz61njI+uQ==", 2018 | "dev": true, 2019 | "dependencies": { 2020 | "@types/fs-extra": "^8.0.1", 2021 | "colorette": "^1.1.0", 2022 | "fs-extra": "^8.1.0", 2023 | "globby": "10.0.1", 2024 | "is-plain-object": "^3.0.0" 2025 | }, 2026 | "engines": { 2027 | "node": ">=8.3" 2028 | } 2029 | }, 2030 | "node_modules/run-parallel": { 2031 | "version": "1.2.0", 2032 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2033 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2034 | "dev": true, 2035 | "funding": [ 2036 | { 2037 | "type": "github", 2038 | "url": "https://github.com/sponsors/feross" 2039 | }, 2040 | { 2041 | "type": "patreon", 2042 | "url": "https://www.patreon.com/feross" 2043 | }, 2044 | { 2045 | "type": "consulting", 2046 | "url": "https://feross.org/support" 2047 | } 2048 | ], 2049 | "dependencies": { 2050 | "queue-microtask": "^1.2.2" 2051 | } 2052 | }, 2053 | "node_modules/semver": { 2054 | "version": "7.5.4", 2055 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 2056 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 2057 | "dev": true, 2058 | "dependencies": { 2059 | "lru-cache": "^6.0.0" 2060 | }, 2061 | "bin": { 2062 | "semver": "bin/semver.js" 2063 | }, 2064 | "engines": { 2065 | "node": ">=10" 2066 | } 2067 | }, 2068 | "node_modules/shebang-command": { 2069 | "version": "2.0.0", 2070 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2071 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2072 | "dev": true, 2073 | "dependencies": { 2074 | "shebang-regex": "^3.0.0" 2075 | }, 2076 | "engines": { 2077 | "node": ">=8" 2078 | } 2079 | }, 2080 | "node_modules/shebang-regex": { 2081 | "version": "3.0.0", 2082 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2083 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2084 | "dev": true, 2085 | "engines": { 2086 | "node": ">=8" 2087 | } 2088 | }, 2089 | "node_modules/slash": { 2090 | "version": "3.0.0", 2091 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2092 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2093 | "dev": true, 2094 | "engines": { 2095 | "node": ">=8" 2096 | } 2097 | }, 2098 | "node_modules/sourcemap-codec": { 2099 | "version": "1.4.8", 2100 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 2101 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 2102 | "deprecated": "Please use @jridgewell/sourcemap-codec instead", 2103 | "dev": true 2104 | }, 2105 | "node_modules/strip-ansi": { 2106 | "version": "6.0.1", 2107 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2108 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2109 | "dev": true, 2110 | "dependencies": { 2111 | "ansi-regex": "^5.0.1" 2112 | }, 2113 | "engines": { 2114 | "node": ">=8" 2115 | } 2116 | }, 2117 | "node_modules/strip-json-comments": { 2118 | "version": "3.1.1", 2119 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 2120 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 2121 | "dev": true, 2122 | "engines": { 2123 | "node": ">=8" 2124 | }, 2125 | "funding": { 2126 | "url": "https://github.com/sponsors/sindresorhus" 2127 | } 2128 | }, 2129 | "node_modules/style-mod": { 2130 | "version": "4.1.0", 2131 | "resolved": "https://registry.npmjs.org/style-mod/-/style-mod-4.1.0.tgz", 2132 | "integrity": "sha512-Ca5ib8HrFn+f+0n4N4ScTIA9iTOQ7MaGS1ylHcoVqW9J7w2w8PzN6g9gKmTYgGEBH8e120+RCmhpje6jC5uGWA==", 2133 | "dev": true, 2134 | "peer": true 2135 | }, 2136 | "node_modules/supports-color": { 2137 | "version": "7.2.0", 2138 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2139 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2140 | "dev": true, 2141 | "dependencies": { 2142 | "has-flag": "^4.0.0" 2143 | }, 2144 | "engines": { 2145 | "node": ">=8" 2146 | } 2147 | }, 2148 | "node_modules/supports-preserve-symlinks-flag": { 2149 | "version": "1.0.0", 2150 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2151 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2152 | "dev": true, 2153 | "engines": { 2154 | "node": ">= 0.4" 2155 | }, 2156 | "funding": { 2157 | "url": "https://github.com/sponsors/ljharb" 2158 | } 2159 | }, 2160 | "node_modules/svelte": { 2161 | "version": "3.35.0", 2162 | "resolved": "https://registry.npmjs.org/svelte/-/svelte-3.35.0.tgz", 2163 | "integrity": "sha512-gknlZkR2sXheu/X+B7dDImwANVvK1R0QGQLd8CNIfxxGPeXBmePnxfzb6fWwTQRsYQG7lYkZXvpXJvxvpsoB7g==", 2164 | "dev": true, 2165 | "engines": { 2166 | "node": ">= 8" 2167 | } 2168 | }, 2169 | "node_modules/synckit": { 2170 | "version": "0.8.8", 2171 | "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.8.8.tgz", 2172 | "integrity": "sha512-HwOKAP7Wc5aRGYdKH+dw0PRRpbO841v2DENBtjnR5HFWoiNByAl7vrx3p0G/rCyYXQsrxqtX48TImFtPcIHSpQ==", 2173 | "dev": true, 2174 | "dependencies": { 2175 | "@pkgr/core": "^0.1.0", 2176 | "tslib": "^2.6.2" 2177 | }, 2178 | "engines": { 2179 | "node": "^14.18.0 || >=16.0.0" 2180 | }, 2181 | "funding": { 2182 | "url": "https://opencollective.com/unts" 2183 | } 2184 | }, 2185 | "node_modules/syntax-error": { 2186 | "version": "1.4.0", 2187 | "resolved": "https://registry.npmjs.org/syntax-error/-/syntax-error-1.4.0.tgz", 2188 | "integrity": "sha512-YPPlu67mdnHGTup2A8ff7BC2Pjq0e0Yp/IyTFN03zWO0RcK07uLcbi7C2KpGR2FvWbaB0+bfE27a+sBKebSo7w==", 2189 | "dependencies": { 2190 | "acorn-node": "^1.2.0" 2191 | } 2192 | }, 2193 | "node_modules/text-table": { 2194 | "version": "0.2.0", 2195 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2196 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 2197 | "dev": true 2198 | }, 2199 | "node_modules/to-regex-range": { 2200 | "version": "5.0.1", 2201 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2202 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2203 | "dev": true, 2204 | "dependencies": { 2205 | "is-number": "^7.0.0" 2206 | }, 2207 | "engines": { 2208 | "node": ">=8.0" 2209 | } 2210 | }, 2211 | "node_modules/ts-api-utils": { 2212 | "version": "1.0.3", 2213 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.0.3.tgz", 2214 | "integrity": "sha512-wNMeqtMz5NtwpT/UZGY5alT+VoKdSsOOP/kqHFcUW1P/VRhH2wJ48+DN2WwUliNbQ976ETwDL0Ifd2VVvgonvg==", 2215 | "dev": true, 2216 | "engines": { 2217 | "node": ">=16.13.0" 2218 | }, 2219 | "peerDependencies": { 2220 | "typescript": ">=4.2.0" 2221 | } 2222 | }, 2223 | "node_modules/tslib": { 2224 | "version": "2.6.2", 2225 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 2226 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", 2227 | "dev": true 2228 | }, 2229 | "node_modules/type-check": { 2230 | "version": "0.4.0", 2231 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 2232 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 2233 | "dev": true, 2234 | "dependencies": { 2235 | "prelude-ls": "^1.2.1" 2236 | }, 2237 | "engines": { 2238 | "node": ">= 0.8.0" 2239 | } 2240 | }, 2241 | "node_modules/type-fest": { 2242 | "version": "0.20.2", 2243 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 2244 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 2245 | "dev": true, 2246 | "engines": { 2247 | "node": ">=10" 2248 | }, 2249 | "funding": { 2250 | "url": "https://github.com/sponsors/sindresorhus" 2251 | } 2252 | }, 2253 | "node_modules/typescript": { 2254 | "version": "4.9.5", 2255 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.5.tgz", 2256 | "integrity": "sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g==", 2257 | "dev": true, 2258 | "bin": { 2259 | "tsc": "bin/tsc", 2260 | "tsserver": "bin/tsserver" 2261 | }, 2262 | "engines": { 2263 | "node": ">=4.2.0" 2264 | } 2265 | }, 2266 | "node_modules/undici-types": { 2267 | "version": "5.26.5", 2268 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 2269 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", 2270 | "dev": true 2271 | }, 2272 | "node_modules/universalify": { 2273 | "version": "0.1.2", 2274 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 2275 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 2276 | "dev": true, 2277 | "engines": { 2278 | "node": ">= 4.0.0" 2279 | } 2280 | }, 2281 | "node_modules/uri-js": { 2282 | "version": "4.4.1", 2283 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 2284 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 2285 | "dev": true, 2286 | "dependencies": { 2287 | "punycode": "^2.1.0" 2288 | } 2289 | }, 2290 | "node_modules/w3c-keyname": { 2291 | "version": "2.2.8", 2292 | "resolved": "https://registry.npmjs.org/w3c-keyname/-/w3c-keyname-2.2.8.tgz", 2293 | "integrity": "sha512-dpojBhNsCNN7T82Tm7k26A6G9ML3NkhDsnw9n/eoxSRlVBB4CEtIQ/KTCLI2Fwf3ataSXRhYFkQi3SlnFwPvPQ==", 2294 | "dev": true, 2295 | "peer": true 2296 | }, 2297 | "node_modules/which": { 2298 | "version": "2.0.2", 2299 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2300 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2301 | "dev": true, 2302 | "dependencies": { 2303 | "isexe": "^2.0.0" 2304 | }, 2305 | "bin": { 2306 | "node-which": "bin/node-which" 2307 | }, 2308 | "engines": { 2309 | "node": ">= 8" 2310 | } 2311 | }, 2312 | "node_modules/wrappy": { 2313 | "version": "1.0.2", 2314 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2315 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 2316 | "dev": true 2317 | }, 2318 | "node_modules/xtend": { 2319 | "version": "4.0.2", 2320 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 2321 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 2322 | "engines": { 2323 | "node": ">=0.4" 2324 | } 2325 | }, 2326 | "node_modules/yallist": { 2327 | "version": "4.0.0", 2328 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2329 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 2330 | "dev": true 2331 | }, 2332 | "node_modules/yocto-queue": { 2333 | "version": "0.1.0", 2334 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 2335 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 2336 | "dev": true, 2337 | "engines": { 2338 | "node": ">=10" 2339 | }, 2340 | "funding": { 2341 | "url": "https://github.com/sponsors/sindresorhus" 2342 | } 2343 | } 2344 | }, 2345 | "dependencies": { 2346 | "@aashutoshrathi/word-wrap": { 2347 | "version": "1.2.6", 2348 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz", 2349 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==", 2350 | "dev": true 2351 | }, 2352 | "@codemirror/state": { 2353 | "version": "6.4.0", 2354 | "resolved": "https://registry.npmjs.org/@codemirror/state/-/state-6.4.0.tgz", 2355 | "integrity": "sha512-hm8XshYj5Fo30Bb922QX9hXB/bxOAVH+qaqHBzw5TKa72vOeslyGwd4X8M0c1dJ9JqxlaMceOQ8RsL9tC7gU0A==", 2356 | "dev": true, 2357 | "peer": true 2358 | }, 2359 | "@codemirror/view": { 2360 | "version": "6.23.0", 2361 | "resolved": "https://registry.npmjs.org/@codemirror/view/-/view-6.23.0.tgz", 2362 | "integrity": "sha512-/51px9N4uW8NpuWkyUX+iam5+PM6io2fm+QmRnzwqBy5v/pwGg9T0kILFtYeum8hjuvENtgsGNKluOfqIICmeQ==", 2363 | "dev": true, 2364 | "peer": true, 2365 | "requires": { 2366 | "@codemirror/state": "^6.4.0", 2367 | "style-mod": "^4.1.0", 2368 | "w3c-keyname": "^2.2.4" 2369 | } 2370 | }, 2371 | "@eslint-community/eslint-utils": { 2372 | "version": "4.4.0", 2373 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 2374 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 2375 | "dev": true, 2376 | "requires": { 2377 | "eslint-visitor-keys": "^3.3.0" 2378 | } 2379 | }, 2380 | "@eslint-community/regexpp": { 2381 | "version": "4.10.0", 2382 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.0.tgz", 2383 | "integrity": "sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==", 2384 | "dev": true 2385 | }, 2386 | "@eslint/eslintrc": { 2387 | "version": "2.1.4", 2388 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", 2389 | "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", 2390 | "dev": true, 2391 | "requires": { 2392 | "ajv": "^6.12.4", 2393 | "debug": "^4.3.2", 2394 | "espree": "^9.6.0", 2395 | "globals": "^13.19.0", 2396 | "ignore": "^5.2.0", 2397 | "import-fresh": "^3.2.1", 2398 | "js-yaml": "^4.1.0", 2399 | "minimatch": "^3.1.2", 2400 | "strip-json-comments": "^3.1.1" 2401 | } 2402 | }, 2403 | "@eslint/js": { 2404 | "version": "8.56.0", 2405 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.56.0.tgz", 2406 | "integrity": "sha512-gMsVel9D7f2HLkBma9VbtzZRehRogVRfbr++f06nL2vnCGCNlzOD+/MUov/F4p8myyAHspEhVobgjpX64q5m6A==", 2407 | "dev": true 2408 | }, 2409 | "@humanwhocodes/config-array": { 2410 | "version": "0.11.13", 2411 | "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.13.tgz", 2412 | "integrity": "sha512-JSBDMiDKSzQVngfRjOdFXgFfklaXI4K9nLF49Auh21lmBWRLIK3+xTErTWD4KU54pb6coM6ESE7Awz/FNU3zgQ==", 2413 | "dev": true, 2414 | "requires": { 2415 | "@humanwhocodes/object-schema": "^2.0.1", 2416 | "debug": "^4.1.1", 2417 | "minimatch": "^3.0.5" 2418 | } 2419 | }, 2420 | "@humanwhocodes/module-importer": { 2421 | "version": "1.0.1", 2422 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 2423 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 2424 | "dev": true 2425 | }, 2426 | "@humanwhocodes/object-schema": { 2427 | "version": "2.0.1", 2428 | "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.1.tgz", 2429 | "integrity": "sha512-dvuCeX5fC9dXgJn9t+X5atfmgQAzUOWqS1254Gh0m6i8wKd10ebXkfNKiRK+1GWi/yTvvLDHpoxLr0xxxeslWw==", 2430 | "dev": true 2431 | }, 2432 | "@nodelib/fs.scandir": { 2433 | "version": "2.1.5", 2434 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 2435 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 2436 | "dev": true, 2437 | "requires": { 2438 | "@nodelib/fs.stat": "2.0.5", 2439 | "run-parallel": "^1.1.9" 2440 | } 2441 | }, 2442 | "@nodelib/fs.stat": { 2443 | "version": "2.0.5", 2444 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 2445 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 2446 | "dev": true 2447 | }, 2448 | "@nodelib/fs.walk": { 2449 | "version": "1.2.8", 2450 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 2451 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 2452 | "dev": true, 2453 | "requires": { 2454 | "@nodelib/fs.scandir": "2.1.5", 2455 | "fastq": "^1.6.0" 2456 | } 2457 | }, 2458 | "@pkgr/core": { 2459 | "version": "0.1.0", 2460 | "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.1.0.tgz", 2461 | "integrity": "sha512-Zwq5OCzuwJC2jwqmpEQt7Ds1DTi6BWSwoGkbb1n9pO3hzb35BoJELx7c0T23iDkBGkh2e7tvOtjF3tr3OaQHDQ==", 2462 | "dev": true 2463 | }, 2464 | "@rollup/plugin-commonjs": { 2465 | "version": "18.1.0", 2466 | "resolved": "https://registry.npmjs.org/@rollup/plugin-commonjs/-/plugin-commonjs-18.1.0.tgz", 2467 | "integrity": "sha512-h3e6T9rUxVMAQswpDIobfUHn/doMzM9sgkMrsMWCFLmB84PSoC8mV8tOloAJjSRwdqhXBqstlX2BwBpHJvbhxg==", 2468 | "dev": true, 2469 | "requires": { 2470 | "@rollup/pluginutils": "^3.1.0", 2471 | "commondir": "^1.0.1", 2472 | "estree-walker": "^2.0.1", 2473 | "glob": "^7.1.6", 2474 | "is-reference": "^1.2.1", 2475 | "magic-string": "^0.25.7", 2476 | "resolve": "^1.17.0" 2477 | } 2478 | }, 2479 | "@rollup/plugin-node-resolve": { 2480 | "version": "11.2.1", 2481 | "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-11.2.1.tgz", 2482 | "integrity": "sha512-yc2n43jcqVyGE2sqV5/YCmocy9ArjVAP/BeXyTtADTBBX6V0e5UMqwO8CdQ0kzjb6zu5P1qMzsScCMRvE9OlVg==", 2483 | "dev": true, 2484 | "requires": { 2485 | "@rollup/pluginutils": "^3.1.0", 2486 | "@types/resolve": "1.17.1", 2487 | "builtin-modules": "^3.1.0", 2488 | "deepmerge": "^4.2.2", 2489 | "is-module": "^1.0.0", 2490 | "resolve": "^1.19.0" 2491 | } 2492 | }, 2493 | "@rollup/plugin-typescript": { 2494 | "version": "8.5.0", 2495 | "resolved": "https://registry.npmjs.org/@rollup/plugin-typescript/-/plugin-typescript-8.5.0.tgz", 2496 | "integrity": "sha512-wMv1/scv0m/rXx21wD2IsBbJFba8wGF3ErJIr6IKRfRj49S85Lszbxb4DCo8iILpluTjk2GAAu9CoZt4G3ppgQ==", 2497 | "dev": true, 2498 | "requires": { 2499 | "@rollup/pluginutils": "^3.1.0", 2500 | "resolve": "^1.17.0" 2501 | } 2502 | }, 2503 | "@rollup/pluginutils": { 2504 | "version": "3.1.0", 2505 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", 2506 | "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", 2507 | "dev": true, 2508 | "requires": { 2509 | "@types/estree": "0.0.39", 2510 | "estree-walker": "^1.0.1", 2511 | "picomatch": "^2.2.2" 2512 | }, 2513 | "dependencies": { 2514 | "estree-walker": { 2515 | "version": "1.0.1", 2516 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", 2517 | "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", 2518 | "dev": true 2519 | } 2520 | } 2521 | }, 2522 | "@types/codemirror": { 2523 | "version": "0.0.108", 2524 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.108.tgz", 2525 | "integrity": "sha512-3FGFcus0P7C2UOGCNUVENqObEb4SFk+S8Dnxq7K6aIsLVs/vDtlangl3PEO0ykaKXyK56swVF6Nho7VsA44uhw==", 2526 | "dev": true, 2527 | "requires": { 2528 | "@types/tern": "*" 2529 | } 2530 | }, 2531 | "@types/estree": { 2532 | "version": "0.0.39", 2533 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", 2534 | "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", 2535 | "dev": true 2536 | }, 2537 | "@types/fs-extra": { 2538 | "version": "8.1.2", 2539 | "resolved": "https://registry.npmjs.org/@types/fs-extra/-/fs-extra-8.1.2.tgz", 2540 | "integrity": "sha512-SvSrYXfWSc7R4eqnOzbQF4TZmfpNSM9FrSWLU3EUnWBuyZqNBOrv1B1JA3byUDPUl9z4Ab3jeZG2eDdySlgNMg==", 2541 | "dev": true, 2542 | "requires": { 2543 | "@types/node": "*" 2544 | } 2545 | }, 2546 | "@types/glob": { 2547 | "version": "7.2.0", 2548 | "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", 2549 | "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", 2550 | "dev": true, 2551 | "requires": { 2552 | "@types/minimatch": "*", 2553 | "@types/node": "*" 2554 | } 2555 | }, 2556 | "@types/json-schema": { 2557 | "version": "7.0.15", 2558 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", 2559 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", 2560 | "dev": true 2561 | }, 2562 | "@types/minimatch": { 2563 | "version": "5.1.2", 2564 | "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", 2565 | "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", 2566 | "dev": true 2567 | }, 2568 | "@types/node": { 2569 | "version": "20.10.6", 2570 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.10.6.tgz", 2571 | "integrity": "sha512-Vac8H+NlRNNlAmDfGUP7b5h/KA+AtWIzuXy0E6OyP8f1tCLYAtPvKRRDJjAPqhpCb0t6U2j7/xqAuLEebW2kiw==", 2572 | "dev": true, 2573 | "requires": { 2574 | "undici-types": "~5.26.4" 2575 | } 2576 | }, 2577 | "@types/resolve": { 2578 | "version": "1.17.1", 2579 | "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.17.1.tgz", 2580 | "integrity": "sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==", 2581 | "dev": true, 2582 | "requires": { 2583 | "@types/node": "*" 2584 | } 2585 | }, 2586 | "@types/semver": { 2587 | "version": "7.5.6", 2588 | "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz", 2589 | "integrity": "sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A==", 2590 | "dev": true 2591 | }, 2592 | "@types/tern": { 2593 | "version": "0.23.4", 2594 | "resolved": "https://registry.npmjs.org/@types/tern/-/tern-0.23.4.tgz", 2595 | "integrity": "sha512-JAUw1iXGO1qaWwEOzxTKJZ/5JxVeON9kvGZ/osgZaJImBnyjyn0cjovPsf6FNLmyGY8Vw9DoXZCMlfMkMwHRWg==", 2596 | "dev": true, 2597 | "requires": { 2598 | "@types/estree": "*" 2599 | } 2600 | }, 2601 | "@typescript-eslint/eslint-plugin": { 2602 | "version": "6.17.0", 2603 | "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.17.0.tgz", 2604 | "integrity": "sha512-Vih/4xLXmY7V490dGwBQJTpIZxH4ZFH6eCVmQ4RFkB+wmaCTDAx4dtgoWwMNGKLkqRY1L6rPqzEbjorRnDo4rQ==", 2605 | "dev": true, 2606 | "requires": { 2607 | "@eslint-community/regexpp": "^4.5.1", 2608 | "@typescript-eslint/scope-manager": "6.17.0", 2609 | "@typescript-eslint/type-utils": "6.17.0", 2610 | "@typescript-eslint/utils": "6.17.0", 2611 | "@typescript-eslint/visitor-keys": "6.17.0", 2612 | "debug": "^4.3.4", 2613 | "graphemer": "^1.4.0", 2614 | "ignore": "^5.2.4", 2615 | "natural-compare": "^1.4.0", 2616 | "semver": "^7.5.4", 2617 | "ts-api-utils": "^1.0.1" 2618 | } 2619 | }, 2620 | "@typescript-eslint/parser": { 2621 | "version": "6.17.0", 2622 | "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.17.0.tgz", 2623 | "integrity": "sha512-C4bBaX2orvhK+LlwrY8oWGmSl4WolCfYm513gEccdWZj0CwGadbIADb0FtVEcI+WzUyjyoBj2JRP8g25E6IB8A==", 2624 | "dev": true, 2625 | "requires": { 2626 | "@typescript-eslint/scope-manager": "6.17.0", 2627 | "@typescript-eslint/types": "6.17.0", 2628 | "@typescript-eslint/typescript-estree": "6.17.0", 2629 | "@typescript-eslint/visitor-keys": "6.17.0", 2630 | "debug": "^4.3.4" 2631 | } 2632 | }, 2633 | "@typescript-eslint/scope-manager": { 2634 | "version": "6.17.0", 2635 | "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.17.0.tgz", 2636 | "integrity": "sha512-RX7a8lwgOi7am0k17NUO0+ZmMOX4PpjLtLRgLmT1d3lBYdWH4ssBUbwdmc5pdRX8rXon8v9x8vaoOSpkHfcXGA==", 2637 | "dev": true, 2638 | "requires": { 2639 | "@typescript-eslint/types": "6.17.0", 2640 | "@typescript-eslint/visitor-keys": "6.17.0" 2641 | } 2642 | }, 2643 | "@typescript-eslint/type-utils": { 2644 | "version": "6.17.0", 2645 | "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.17.0.tgz", 2646 | "integrity": "sha512-hDXcWmnbtn4P2B37ka3nil3yi3VCQO2QEB9gBiHJmQp5wmyQWqnjA85+ZcE8c4FqnaB6lBwMrPkgd4aBYz3iNg==", 2647 | "dev": true, 2648 | "requires": { 2649 | "@typescript-eslint/typescript-estree": "6.17.0", 2650 | "@typescript-eslint/utils": "6.17.0", 2651 | "debug": "^4.3.4", 2652 | "ts-api-utils": "^1.0.1" 2653 | } 2654 | }, 2655 | "@typescript-eslint/types": { 2656 | "version": "6.17.0", 2657 | "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.17.0.tgz", 2658 | "integrity": "sha512-qRKs9tvc3a4RBcL/9PXtKSehI/q8wuU9xYJxe97WFxnzH8NWWtcW3ffNS+EWg8uPvIerhjsEZ+rHtDqOCiH57A==", 2659 | "dev": true 2660 | }, 2661 | "@typescript-eslint/typescript-estree": { 2662 | "version": "6.17.0", 2663 | "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.17.0.tgz", 2664 | "integrity": "sha512-gVQe+SLdNPfjlJn5VNGhlOhrXz4cajwFd5kAgWtZ9dCZf4XJf8xmgCTLIqec7aha3JwgLI2CK6GY1043FRxZwg==", 2665 | "dev": true, 2666 | "requires": { 2667 | "@typescript-eslint/types": "6.17.0", 2668 | "@typescript-eslint/visitor-keys": "6.17.0", 2669 | "debug": "^4.3.4", 2670 | "globby": "^11.1.0", 2671 | "is-glob": "^4.0.3", 2672 | "minimatch": "9.0.3", 2673 | "semver": "^7.5.4", 2674 | "ts-api-utils": "^1.0.1" 2675 | }, 2676 | "dependencies": { 2677 | "brace-expansion": { 2678 | "version": "2.0.1", 2679 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 2680 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 2681 | "dev": true, 2682 | "requires": { 2683 | "balanced-match": "^1.0.0" 2684 | } 2685 | }, 2686 | "globby": { 2687 | "version": "11.1.0", 2688 | "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", 2689 | "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", 2690 | "dev": true, 2691 | "requires": { 2692 | "array-union": "^2.1.0", 2693 | "dir-glob": "^3.0.1", 2694 | "fast-glob": "^3.2.9", 2695 | "ignore": "^5.2.0", 2696 | "merge2": "^1.4.1", 2697 | "slash": "^3.0.0" 2698 | } 2699 | }, 2700 | "minimatch": { 2701 | "version": "9.0.3", 2702 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", 2703 | "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", 2704 | "dev": true, 2705 | "requires": { 2706 | "brace-expansion": "^2.0.1" 2707 | } 2708 | } 2709 | } 2710 | }, 2711 | "@typescript-eslint/utils": { 2712 | "version": "6.17.0", 2713 | "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.17.0.tgz", 2714 | "integrity": "sha512-LofsSPjN/ITNkzV47hxas2JCsNCEnGhVvocfyOcLzT9c/tSZE7SfhS/iWtzP1lKNOEfLhRTZz6xqI8N2RzweSQ==", 2715 | "dev": true, 2716 | "requires": { 2717 | "@eslint-community/eslint-utils": "^4.4.0", 2718 | "@types/json-schema": "^7.0.12", 2719 | "@types/semver": "^7.5.0", 2720 | "@typescript-eslint/scope-manager": "6.17.0", 2721 | "@typescript-eslint/types": "6.17.0", 2722 | "@typescript-eslint/typescript-estree": "6.17.0", 2723 | "semver": "^7.5.4" 2724 | } 2725 | }, 2726 | "@typescript-eslint/visitor-keys": { 2727 | "version": "6.17.0", 2728 | "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.17.0.tgz", 2729 | "integrity": "sha512-H6VwB/k3IuIeQOyYczyyKN8wH6ed8EwliaYHLxOIhyF0dYEIsN8+Bk3GE19qafeMKyZJJHP8+O1HiFhFLUNKSg==", 2730 | "dev": true, 2731 | "requires": { 2732 | "@typescript-eslint/types": "6.17.0", 2733 | "eslint-visitor-keys": "^3.4.1" 2734 | } 2735 | }, 2736 | "@ungap/structured-clone": { 2737 | "version": "1.2.0", 2738 | "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", 2739 | "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", 2740 | "dev": true 2741 | }, 2742 | "acorn": { 2743 | "version": "7.4.1", 2744 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 2745 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==" 2746 | }, 2747 | "acorn-jsx": { 2748 | "version": "5.3.2", 2749 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 2750 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 2751 | "dev": true, 2752 | "requires": {} 2753 | }, 2754 | "acorn-node": { 2755 | "version": "1.8.2", 2756 | "resolved": "https://registry.npmjs.org/acorn-node/-/acorn-node-1.8.2.tgz", 2757 | "integrity": "sha512-8mt+fslDufLYntIoPAaIMUe/lrbrehIiwmR3t2k9LljIzoigEPF27eLk2hy8zSGzmR/ogr7zbRKINMo1u0yh5A==", 2758 | "requires": { 2759 | "acorn": "^7.0.0", 2760 | "acorn-walk": "^7.0.0", 2761 | "xtend": "^4.0.2" 2762 | } 2763 | }, 2764 | "acorn-walk": { 2765 | "version": "7.2.0", 2766 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", 2767 | "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==" 2768 | }, 2769 | "ajv": { 2770 | "version": "6.12.6", 2771 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 2772 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 2773 | "dev": true, 2774 | "requires": { 2775 | "fast-deep-equal": "^3.1.1", 2776 | "fast-json-stable-stringify": "^2.0.0", 2777 | "json-schema-traverse": "^0.4.1", 2778 | "uri-js": "^4.2.2" 2779 | } 2780 | }, 2781 | "ansi-regex": { 2782 | "version": "5.0.1", 2783 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2784 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2785 | "dev": true 2786 | }, 2787 | "ansi-styles": { 2788 | "version": "4.3.0", 2789 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2790 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2791 | "dev": true, 2792 | "requires": { 2793 | "color-convert": "^2.0.1" 2794 | } 2795 | }, 2796 | "argparse": { 2797 | "version": "2.0.1", 2798 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 2799 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", 2800 | "dev": true 2801 | }, 2802 | "array-union": { 2803 | "version": "2.1.0", 2804 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", 2805 | "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", 2806 | "dev": true 2807 | }, 2808 | "balanced-match": { 2809 | "version": "1.0.2", 2810 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2811 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 2812 | "dev": true 2813 | }, 2814 | "brace-expansion": { 2815 | "version": "1.1.11", 2816 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2817 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2818 | "dev": true, 2819 | "requires": { 2820 | "balanced-match": "^1.0.0", 2821 | "concat-map": "0.0.1" 2822 | } 2823 | }, 2824 | "braces": { 2825 | "version": "3.0.2", 2826 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2827 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2828 | "dev": true, 2829 | "requires": { 2830 | "fill-range": "^7.0.1" 2831 | } 2832 | }, 2833 | "builtin-modules": { 2834 | "version": "3.3.0", 2835 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.3.0.tgz", 2836 | "integrity": "sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw==", 2837 | "dev": true 2838 | }, 2839 | "callsites": { 2840 | "version": "3.1.0", 2841 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 2842 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 2843 | "dev": true 2844 | }, 2845 | "chalk": { 2846 | "version": "4.1.2", 2847 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2848 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2849 | "dev": true, 2850 | "requires": { 2851 | "ansi-styles": "^4.1.0", 2852 | "supports-color": "^7.1.0" 2853 | } 2854 | }, 2855 | "color-convert": { 2856 | "version": "2.0.1", 2857 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2858 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2859 | "dev": true, 2860 | "requires": { 2861 | "color-name": "~1.1.4" 2862 | } 2863 | }, 2864 | "color-name": { 2865 | "version": "1.1.4", 2866 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2867 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2868 | "dev": true 2869 | }, 2870 | "colorette": { 2871 | "version": "1.4.0", 2872 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-1.4.0.tgz", 2873 | "integrity": "sha512-Y2oEozpomLn7Q3HFP7dpww7AtMJplbM9lGZP6RDfHqmbeRjiwRg4n6VM6j4KLmRke85uWEI7JqF17f3pqdRA0g==", 2874 | "dev": true 2875 | }, 2876 | "commondir": { 2877 | "version": "1.0.1", 2878 | "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", 2879 | "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", 2880 | "dev": true 2881 | }, 2882 | "compare-versions": { 2883 | "version": "3.6.0", 2884 | "resolved": "https://registry.npmjs.org/compare-versions/-/compare-versions-3.6.0.tgz", 2885 | "integrity": "sha512-W6Af2Iw1z4CB7q4uU4hv646dW9GQuBM+YpC0UvUCWSD8w90SJjp+ujJuXaEMtAXBtSqGfMPuFOVn4/+FlaqfBA==" 2886 | }, 2887 | "concat-map": { 2888 | "version": "0.0.1", 2889 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2890 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 2891 | "dev": true 2892 | }, 2893 | "cross-spawn": { 2894 | "version": "7.0.3", 2895 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2896 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2897 | "dev": true, 2898 | "requires": { 2899 | "path-key": "^3.1.0", 2900 | "shebang-command": "^2.0.0", 2901 | "which": "^2.0.1" 2902 | } 2903 | }, 2904 | "debug": { 2905 | "version": "4.3.4", 2906 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 2907 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 2908 | "dev": true, 2909 | "requires": { 2910 | "ms": "2.1.2" 2911 | } 2912 | }, 2913 | "debuggable-eval": { 2914 | "version": "1.2.0", 2915 | "resolved": "https://registry.npmjs.org/debuggable-eval/-/debuggable-eval-1.2.0.tgz", 2916 | "integrity": "sha512-JQwOiSLWpM4TobqW0H/YGMPcYw01glVmq6Bn683bOqoaByPi4q2mlmMyOwtA/4KgeT9dKiezIazaFPz229gpoQ==", 2917 | "requires": { 2918 | "syntax-error": "^1.4.0" 2919 | } 2920 | }, 2921 | "deep-is": { 2922 | "version": "0.1.4", 2923 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 2924 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 2925 | "dev": true 2926 | }, 2927 | "deepmerge": { 2928 | "version": "4.3.1", 2929 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", 2930 | "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", 2931 | "dev": true 2932 | }, 2933 | "dir-glob": { 2934 | "version": "3.0.1", 2935 | "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", 2936 | "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", 2937 | "dev": true, 2938 | "requires": { 2939 | "path-type": "^4.0.0" 2940 | } 2941 | }, 2942 | "doctrine": { 2943 | "version": "3.0.0", 2944 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 2945 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 2946 | "dev": true, 2947 | "requires": { 2948 | "esutils": "^2.0.2" 2949 | } 2950 | }, 2951 | "emoji-regex": { 2952 | "version": "10.2.1", 2953 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.2.1.tgz", 2954 | "integrity": "sha512-97g6QgOk8zlDRdgq1WxwgTMgEWGVAQvB5Fdpgc1MkNy56la5SKP9GsMXKDOdqwn90/41a8yPwIGk1Y6WVbeMQA==", 2955 | "dev": true 2956 | }, 2957 | "escape-string-regexp": { 2958 | "version": "4.0.0", 2959 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 2960 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 2961 | "dev": true 2962 | }, 2963 | "eslint": { 2964 | "version": "8.56.0", 2965 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.56.0.tgz", 2966 | "integrity": "sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==", 2967 | "dev": true, 2968 | "requires": { 2969 | "@eslint-community/eslint-utils": "^4.2.0", 2970 | "@eslint-community/regexpp": "^4.6.1", 2971 | "@eslint/eslintrc": "^2.1.4", 2972 | "@eslint/js": "8.56.0", 2973 | "@humanwhocodes/config-array": "^0.11.13", 2974 | "@humanwhocodes/module-importer": "^1.0.1", 2975 | "@nodelib/fs.walk": "^1.2.8", 2976 | "@ungap/structured-clone": "^1.2.0", 2977 | "ajv": "^6.12.4", 2978 | "chalk": "^4.0.0", 2979 | "cross-spawn": "^7.0.2", 2980 | "debug": "^4.3.2", 2981 | "doctrine": "^3.0.0", 2982 | "escape-string-regexp": "^4.0.0", 2983 | "eslint-scope": "^7.2.2", 2984 | "eslint-visitor-keys": "^3.4.3", 2985 | "espree": "^9.6.1", 2986 | "esquery": "^1.4.2", 2987 | "esutils": "^2.0.2", 2988 | "fast-deep-equal": "^3.1.3", 2989 | "file-entry-cache": "^6.0.1", 2990 | "find-up": "^5.0.0", 2991 | "glob-parent": "^6.0.2", 2992 | "globals": "^13.19.0", 2993 | "graphemer": "^1.4.0", 2994 | "ignore": "^5.2.0", 2995 | "imurmurhash": "^0.1.4", 2996 | "is-glob": "^4.0.0", 2997 | "is-path-inside": "^3.0.3", 2998 | "js-yaml": "^4.1.0", 2999 | "json-stable-stringify-without-jsonify": "^1.0.1", 3000 | "levn": "^0.4.1", 3001 | "lodash.merge": "^4.6.2", 3002 | "minimatch": "^3.1.2", 3003 | "natural-compare": "^1.4.0", 3004 | "optionator": "^0.9.3", 3005 | "strip-ansi": "^6.0.1", 3006 | "text-table": "^0.2.0" 3007 | }, 3008 | "dependencies": { 3009 | "glob-parent": { 3010 | "version": "6.0.2", 3011 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 3012 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 3013 | "dev": true, 3014 | "requires": { 3015 | "is-glob": "^4.0.3" 3016 | } 3017 | } 3018 | } 3019 | }, 3020 | "eslint-plugin-prettier": { 3021 | "version": "5.1.2", 3022 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.1.2.tgz", 3023 | "integrity": "sha512-dhlpWc9vOwohcWmClFcA+HjlvUpuyynYs0Rf+L/P6/0iQE6vlHW9l5bkfzN62/Stm9fbq8ku46qzde76T1xlSg==", 3024 | "dev": true, 3025 | "requires": { 3026 | "prettier-linter-helpers": "^1.0.0", 3027 | "synckit": "^0.8.6" 3028 | } 3029 | }, 3030 | "eslint-scope": { 3031 | "version": "7.2.2", 3032 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", 3033 | "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", 3034 | "dev": true, 3035 | "requires": { 3036 | "esrecurse": "^4.3.0", 3037 | "estraverse": "^5.2.0" 3038 | } 3039 | }, 3040 | "eslint-visitor-keys": { 3041 | "version": "3.4.3", 3042 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 3043 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 3044 | "dev": true 3045 | }, 3046 | "espree": { 3047 | "version": "9.6.1", 3048 | "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", 3049 | "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", 3050 | "dev": true, 3051 | "requires": { 3052 | "acorn": "^8.9.0", 3053 | "acorn-jsx": "^5.3.2", 3054 | "eslint-visitor-keys": "^3.4.1" 3055 | }, 3056 | "dependencies": { 3057 | "acorn": { 3058 | "version": "8.11.3", 3059 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 3060 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 3061 | "dev": true 3062 | } 3063 | } 3064 | }, 3065 | "esquery": { 3066 | "version": "1.5.0", 3067 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 3068 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 3069 | "dev": true, 3070 | "requires": { 3071 | "estraverse": "^5.1.0" 3072 | } 3073 | }, 3074 | "esrecurse": { 3075 | "version": "4.3.0", 3076 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 3077 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 3078 | "dev": true, 3079 | "requires": { 3080 | "estraverse": "^5.2.0" 3081 | } 3082 | }, 3083 | "estraverse": { 3084 | "version": "5.3.0", 3085 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 3086 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 3087 | "dev": true 3088 | }, 3089 | "estree-walker": { 3090 | "version": "2.0.2", 3091 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", 3092 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==", 3093 | "dev": true 3094 | }, 3095 | "esutils": { 3096 | "version": "2.0.3", 3097 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 3098 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 3099 | "dev": true 3100 | }, 3101 | "fast-deep-equal": { 3102 | "version": "3.1.3", 3103 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 3104 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", 3105 | "dev": true 3106 | }, 3107 | "fast-diff": { 3108 | "version": "1.3.0", 3109 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", 3110 | "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", 3111 | "dev": true 3112 | }, 3113 | "fast-glob": { 3114 | "version": "3.3.1", 3115 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.1.tgz", 3116 | "integrity": "sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg==", 3117 | "dev": true, 3118 | "requires": { 3119 | "@nodelib/fs.stat": "^2.0.2", 3120 | "@nodelib/fs.walk": "^1.2.3", 3121 | "glob-parent": "^5.1.2", 3122 | "merge2": "^1.3.0", 3123 | "micromatch": "^4.0.4" 3124 | } 3125 | }, 3126 | "fast-json-stable-stringify": { 3127 | "version": "2.1.0", 3128 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 3129 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 3130 | "dev": true 3131 | }, 3132 | "fast-levenshtein": { 3133 | "version": "2.0.6", 3134 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 3135 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", 3136 | "dev": true 3137 | }, 3138 | "fastq": { 3139 | "version": "1.15.0", 3140 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", 3141 | "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", 3142 | "dev": true, 3143 | "requires": { 3144 | "reusify": "^1.0.4" 3145 | } 3146 | }, 3147 | "file-entry-cache": { 3148 | "version": "6.0.1", 3149 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", 3150 | "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", 3151 | "dev": true, 3152 | "requires": { 3153 | "flat-cache": "^3.0.4" 3154 | } 3155 | }, 3156 | "fill-range": { 3157 | "version": "7.0.1", 3158 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 3159 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 3160 | "dev": true, 3161 | "requires": { 3162 | "to-regex-range": "^5.0.1" 3163 | } 3164 | }, 3165 | "find-up": { 3166 | "version": "5.0.0", 3167 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 3168 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 3169 | "dev": true, 3170 | "requires": { 3171 | "locate-path": "^6.0.0", 3172 | "path-exists": "^4.0.0" 3173 | } 3174 | }, 3175 | "flat-cache": { 3176 | "version": "3.2.0", 3177 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", 3178 | "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", 3179 | "dev": true, 3180 | "requires": { 3181 | "flatted": "^3.2.9", 3182 | "keyv": "^4.5.3", 3183 | "rimraf": "^3.0.2" 3184 | } 3185 | }, 3186 | "flatted": { 3187 | "version": "3.2.9", 3188 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", 3189 | "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==", 3190 | "dev": true 3191 | }, 3192 | "fs-extra": { 3193 | "version": "8.1.0", 3194 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", 3195 | "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", 3196 | "dev": true, 3197 | "requires": { 3198 | "graceful-fs": "^4.2.0", 3199 | "jsonfile": "^4.0.0", 3200 | "universalify": "^0.1.0" 3201 | } 3202 | }, 3203 | "fs.realpath": { 3204 | "version": "1.0.0", 3205 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 3206 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 3207 | "dev": true 3208 | }, 3209 | "fsevents": { 3210 | "version": "2.3.3", 3211 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 3212 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 3213 | "dev": true, 3214 | "optional": true 3215 | }, 3216 | "function-bind": { 3217 | "version": "1.1.1", 3218 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 3219 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 3220 | "dev": true 3221 | }, 3222 | "glob": { 3223 | "version": "7.2.3", 3224 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 3225 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 3226 | "dev": true, 3227 | "requires": { 3228 | "fs.realpath": "^1.0.0", 3229 | "inflight": "^1.0.4", 3230 | "inherits": "2", 3231 | "minimatch": "^3.1.1", 3232 | "once": "^1.3.0", 3233 | "path-is-absolute": "^1.0.0" 3234 | } 3235 | }, 3236 | "glob-parent": { 3237 | "version": "5.1.2", 3238 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 3239 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 3240 | "dev": true, 3241 | "requires": { 3242 | "is-glob": "^4.0.1" 3243 | } 3244 | }, 3245 | "globals": { 3246 | "version": "13.24.0", 3247 | "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", 3248 | "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", 3249 | "dev": true, 3250 | "requires": { 3251 | "type-fest": "^0.20.2" 3252 | } 3253 | }, 3254 | "globby": { 3255 | "version": "10.0.1", 3256 | "resolved": "https://registry.npmjs.org/globby/-/globby-10.0.1.tgz", 3257 | "integrity": "sha512-sSs4inE1FB2YQiymcmTv6NWENryABjUNPeWhOvmn4SjtKybglsyPZxFB3U1/+L1bYi0rNZDqCLlHyLYDl1Pq5A==", 3258 | "dev": true, 3259 | "requires": { 3260 | "@types/glob": "^7.1.1", 3261 | "array-union": "^2.1.0", 3262 | "dir-glob": "^3.0.1", 3263 | "fast-glob": "^3.0.3", 3264 | "glob": "^7.1.3", 3265 | "ignore": "^5.1.1", 3266 | "merge2": "^1.2.3", 3267 | "slash": "^3.0.0" 3268 | } 3269 | }, 3270 | "graceful-fs": { 3271 | "version": "4.2.11", 3272 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 3273 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 3274 | "dev": true 3275 | }, 3276 | "graphemer": { 3277 | "version": "1.4.0", 3278 | "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", 3279 | "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", 3280 | "dev": true 3281 | }, 3282 | "has": { 3283 | "version": "1.0.3", 3284 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 3285 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 3286 | "dev": true, 3287 | "requires": { 3288 | "function-bind": "^1.1.1" 3289 | } 3290 | }, 3291 | "has-flag": { 3292 | "version": "4.0.0", 3293 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 3294 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 3295 | "dev": true 3296 | }, 3297 | "ignore": { 3298 | "version": "5.2.4", 3299 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", 3300 | "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", 3301 | "dev": true 3302 | }, 3303 | "import-fresh": { 3304 | "version": "3.3.0", 3305 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 3306 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 3307 | "dev": true, 3308 | "requires": { 3309 | "parent-module": "^1.0.0", 3310 | "resolve-from": "^4.0.0" 3311 | } 3312 | }, 3313 | "imurmurhash": { 3314 | "version": "0.1.4", 3315 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 3316 | "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", 3317 | "dev": true 3318 | }, 3319 | "inflight": { 3320 | "version": "1.0.6", 3321 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 3322 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 3323 | "dev": true, 3324 | "requires": { 3325 | "once": "^1.3.0", 3326 | "wrappy": "1" 3327 | } 3328 | }, 3329 | "inherits": { 3330 | "version": "2.0.4", 3331 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 3332 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 3333 | "dev": true 3334 | }, 3335 | "is-core-module": { 3336 | "version": "2.13.0", 3337 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.0.tgz", 3338 | "integrity": "sha512-Z7dk6Qo8pOCp3l4tsX2C5ZVas4V+UxwQodwZhLopL91TX8UyyHEXafPcyoeeWuLrwzHcr3igO78wNLwHJHsMCQ==", 3339 | "dev": true, 3340 | "requires": { 3341 | "has": "^1.0.3" 3342 | } 3343 | }, 3344 | "is-extglob": { 3345 | "version": "2.1.1", 3346 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 3347 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 3348 | "dev": true 3349 | }, 3350 | "is-glob": { 3351 | "version": "4.0.3", 3352 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 3353 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 3354 | "dev": true, 3355 | "requires": { 3356 | "is-extglob": "^2.1.1" 3357 | } 3358 | }, 3359 | "is-module": { 3360 | "version": "1.0.0", 3361 | "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", 3362 | "integrity": "sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g==", 3363 | "dev": true 3364 | }, 3365 | "is-number": { 3366 | "version": "7.0.0", 3367 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 3368 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 3369 | "dev": true 3370 | }, 3371 | "is-path-inside": { 3372 | "version": "3.0.3", 3373 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 3374 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 3375 | "dev": true 3376 | }, 3377 | "is-plain-object": { 3378 | "version": "3.0.1", 3379 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-3.0.1.tgz", 3380 | "integrity": "sha512-Xnpx182SBMrr/aBik8y+GuR4U1L9FqMSojwDQwPMmxyC6bvEqly9UBCxhauBF5vNh2gwWJNX6oDV7O+OM4z34g==", 3381 | "dev": true 3382 | }, 3383 | "is-reference": { 3384 | "version": "1.2.1", 3385 | "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-1.2.1.tgz", 3386 | "integrity": "sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==", 3387 | "dev": true, 3388 | "requires": { 3389 | "@types/estree": "*" 3390 | } 3391 | }, 3392 | "isexe": { 3393 | "version": "2.0.0", 3394 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 3395 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 3396 | "dev": true 3397 | }, 3398 | "js-yaml": { 3399 | "version": "4.1.0", 3400 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 3401 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 3402 | "dev": true, 3403 | "requires": { 3404 | "argparse": "^2.0.1" 3405 | } 3406 | }, 3407 | "json-buffer": { 3408 | "version": "3.0.1", 3409 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 3410 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", 3411 | "dev": true 3412 | }, 3413 | "json-schema-traverse": { 3414 | "version": "0.4.1", 3415 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 3416 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 3417 | "dev": true 3418 | }, 3419 | "json-stable-stringify-without-jsonify": { 3420 | "version": "1.0.1", 3421 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 3422 | "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", 3423 | "dev": true 3424 | }, 3425 | "jsonfile": { 3426 | "version": "4.0.0", 3427 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 3428 | "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", 3429 | "dev": true, 3430 | "requires": { 3431 | "graceful-fs": "^4.1.6" 3432 | } 3433 | }, 3434 | "keyv": { 3435 | "version": "4.5.4", 3436 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 3437 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 3438 | "dev": true, 3439 | "requires": { 3440 | "json-buffer": "3.0.1" 3441 | } 3442 | }, 3443 | "levn": { 3444 | "version": "0.4.1", 3445 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 3446 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 3447 | "dev": true, 3448 | "requires": { 3449 | "prelude-ls": "^1.2.1", 3450 | "type-check": "~0.4.0" 3451 | } 3452 | }, 3453 | "locate-path": { 3454 | "version": "6.0.0", 3455 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 3456 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 3457 | "dev": true, 3458 | "requires": { 3459 | "p-locate": "^5.0.0" 3460 | } 3461 | }, 3462 | "lodash.merge": { 3463 | "version": "4.6.2", 3464 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 3465 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", 3466 | "dev": true 3467 | }, 3468 | "lru-cache": { 3469 | "version": "6.0.0", 3470 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 3471 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 3472 | "dev": true, 3473 | "requires": { 3474 | "yallist": "^4.0.0" 3475 | } 3476 | }, 3477 | "luxon": { 3478 | "version": "2.5.2", 3479 | "resolved": "https://registry.npmjs.org/luxon/-/luxon-2.5.2.tgz", 3480 | "integrity": "sha512-Yg7/RDp4nedqmLgyH0LwgGRvMEKVzKbUdkBYyCosbHgJ+kaOUx0qzSiSatVc3DFygnirTPYnMM2P5dg2uH1WvA==", 3481 | "dev": true 3482 | }, 3483 | "magic-string": { 3484 | "version": "0.25.9", 3485 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.9.tgz", 3486 | "integrity": "sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==", 3487 | "dev": true, 3488 | "requires": { 3489 | "sourcemap-codec": "^1.4.8" 3490 | } 3491 | }, 3492 | "merge2": { 3493 | "version": "1.4.1", 3494 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 3495 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 3496 | "dev": true 3497 | }, 3498 | "micromatch": { 3499 | "version": "4.0.5", 3500 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", 3501 | "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", 3502 | "dev": true, 3503 | "requires": { 3504 | "braces": "^3.0.2", 3505 | "picomatch": "^2.3.1" 3506 | } 3507 | }, 3508 | "minimatch": { 3509 | "version": "3.1.2", 3510 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 3511 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 3512 | "dev": true, 3513 | "requires": { 3514 | "brace-expansion": "^1.1.7" 3515 | } 3516 | }, 3517 | "moment": { 3518 | "version": "2.29.1", 3519 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.1.tgz", 3520 | "integrity": "sha512-kHmoybcPV8Sqy59DwNDY3Jefr64lK/by/da0ViFcuA4DH0vQg5Q6Ze5VimxkfQNSC+Mls/Kx53s7TjP1RhFEDQ==", 3521 | "dev": true 3522 | }, 3523 | "ms": { 3524 | "version": "2.1.2", 3525 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3526 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3527 | "dev": true 3528 | }, 3529 | "natural-compare": { 3530 | "version": "1.4.0", 3531 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3532 | "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", 3533 | "dev": true 3534 | }, 3535 | "obsidian": { 3536 | "version": "0.12.17", 3537 | "resolved": "https://registry.npmjs.org/obsidian/-/obsidian-0.12.17.tgz", 3538 | "integrity": "sha512-YvCAlRym9D8zNPXt6Ez8QubSTVGoChx6lb58zqI13Dcrz3l1lgUO+pcOGDiD5Qa67nzDZLXo3aV2rqkCCpTvGQ==", 3539 | "dev": true, 3540 | "requires": { 3541 | "@types/codemirror": "0.0.108", 3542 | "moment": "2.29.1" 3543 | } 3544 | }, 3545 | "obsidian-calendar-ui": { 3546 | "version": "0.3.12", 3547 | "resolved": "https://registry.npmjs.org/obsidian-calendar-ui/-/obsidian-calendar-ui-0.3.12.tgz", 3548 | "integrity": "sha512-hdoRqCPnukfRgCARgArXaqMQZ+Iai0eY7f0ZsFHHfywpv4gKg3Tx5p47UsLvRO5DD+4knlbrL7Gel57MkfcLTw==", 3549 | "dev": true, 3550 | "requires": { 3551 | "obsidian-daily-notes-interface": "0.8.4", 3552 | "svelte": "3.35.0", 3553 | "tslib": "2.1.0" 3554 | }, 3555 | "dependencies": { 3556 | "tslib": { 3557 | "version": "2.1.0", 3558 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.1.0.tgz", 3559 | "integrity": "sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A==", 3560 | "dev": true 3561 | } 3562 | } 3563 | }, 3564 | "obsidian-daily-notes-interface": { 3565 | "version": "0.8.4", 3566 | "resolved": "https://registry.npmjs.org/obsidian-daily-notes-interface/-/obsidian-daily-notes-interface-0.8.4.tgz", 3567 | "integrity": "sha512-REKQtAuIOKDbvNH/th1C1gWmJWCP5tRn9T/mfZGZt4Zncgko7McXK0aSKFtEInipvgbZJ2nScivvyLdiWluSMw==", 3568 | "dev": true, 3569 | "requires": { 3570 | "obsidian": "github:obsidianmd/obsidian-api#master", 3571 | "tslib": "2.1.0" 3572 | }, 3573 | "dependencies": { 3574 | "@types/codemirror": { 3575 | "version": "5.60.8", 3576 | "resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-5.60.8.tgz", 3577 | "integrity": "sha512-VjFgDF/eB+Aklcy15TtOTLQeMjTo07k7KAjql8OK5Dirr7a6sJY4T1uVBDuTVG9VEmn1uUsohOpYnVfgC6/jyw==", 3578 | "dev": true, 3579 | "requires": { 3580 | "@types/tern": "*" 3581 | } 3582 | }, 3583 | "moment": { 3584 | "version": "2.29.4", 3585 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", 3586 | "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", 3587 | "dev": true 3588 | }, 3589 | "obsidian": { 3590 | "version": "git+ssh://git@github.com/obsidianmd/obsidian-api.git#5178e27f0eb12741c79914f52146de8ff827e390", 3591 | "integrity": "sha512-9tP/rlolCjjrYdVDD6cIy/jLSd9/Hrdo8Jo9loGk9KiQbHWiWISrw5V2SyA5RmD7qX/+2Au2hfVwS+Ye8lZArA==", 3592 | "dev": true, 3593 | "from": "obsidian@github:obsidianmd/obsidian-api#master", 3594 | "requires": { 3595 | "@types/codemirror": "5.60.8", 3596 | "moment": "2.29.4" 3597 | } 3598 | }, 3599 | "tslib": { 3600 | "version": "2.1.0", 3601 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.1.0.tgz", 3602 | "integrity": "sha512-hcVC3wYEziELGGmEEXue7D75zbwIIVUMWAVbHItGPx0ziyXxrOMQx4rQEVEV45Ut/1IotuEvwqPopzIOkDMf0A==", 3603 | "dev": true 3604 | } 3605 | } 3606 | }, 3607 | "obsidian-dataview": { 3608 | "version": "0.4.25", 3609 | "resolved": "https://registry.npmjs.org/obsidian-dataview/-/obsidian-dataview-0.4.25.tgz", 3610 | "integrity": "sha512-Na0/3BDFn04jHN0La4F1YgoGg2AwKuH8UrL+oYAczXQDqOsvghGeuZBf4nATj1eDUk0HbVmrKYdnqoSec/Tt6Q==", 3611 | "dev": true, 3612 | "requires": { 3613 | "emoji-regex": "^10.0.0", 3614 | "luxon": "^2.0.2", 3615 | "obsidian-calendar-ui": "^0.3.12", 3616 | "papaparse": "^5.3.1", 3617 | "parsimmon": "^1.18.0", 3618 | "preact": "^10.6.5" 3619 | } 3620 | }, 3621 | "once": { 3622 | "version": "1.4.0", 3623 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3624 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 3625 | "dev": true, 3626 | "requires": { 3627 | "wrappy": "1" 3628 | } 3629 | }, 3630 | "optionator": { 3631 | "version": "0.9.3", 3632 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz", 3633 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==", 3634 | "dev": true, 3635 | "requires": { 3636 | "@aashutoshrathi/word-wrap": "^1.2.3", 3637 | "deep-is": "^0.1.3", 3638 | "fast-levenshtein": "^2.0.6", 3639 | "levn": "^0.4.1", 3640 | "prelude-ls": "^1.2.1", 3641 | "type-check": "^0.4.0" 3642 | } 3643 | }, 3644 | "p-limit": { 3645 | "version": "3.1.0", 3646 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 3647 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 3648 | "dev": true, 3649 | "requires": { 3650 | "yocto-queue": "^0.1.0" 3651 | } 3652 | }, 3653 | "p-locate": { 3654 | "version": "5.0.0", 3655 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 3656 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 3657 | "dev": true, 3658 | "requires": { 3659 | "p-limit": "^3.0.2" 3660 | } 3661 | }, 3662 | "papaparse": { 3663 | "version": "5.4.1", 3664 | "resolved": "https://registry.npmjs.org/papaparse/-/papaparse-5.4.1.tgz", 3665 | "integrity": "sha512-HipMsgJkZu8br23pW15uvo6sib6wne/4woLZPlFf3rpDyMe9ywEXUsuD7+6K9PRkJlVT51j/sCOYDKGGS3ZJrw==", 3666 | "dev": true 3667 | }, 3668 | "parent-module": { 3669 | "version": "1.0.1", 3670 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 3671 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 3672 | "dev": true, 3673 | "requires": { 3674 | "callsites": "^3.0.0" 3675 | } 3676 | }, 3677 | "parsimmon": { 3678 | "version": "1.18.1", 3679 | "resolved": "https://registry.npmjs.org/parsimmon/-/parsimmon-1.18.1.tgz", 3680 | "integrity": "sha512-u7p959wLfGAhJpSDJVYXoyMCXWYwHia78HhRBWqk7AIbxdmlrfdp5wX0l3xv/iTSH5HvhN9K7o26hwwpgS5Nmw==", 3681 | "dev": true 3682 | }, 3683 | "path-exists": { 3684 | "version": "4.0.0", 3685 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 3686 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 3687 | "dev": true 3688 | }, 3689 | "path-is-absolute": { 3690 | "version": "1.0.1", 3691 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3692 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 3693 | "dev": true 3694 | }, 3695 | "path-key": { 3696 | "version": "3.1.1", 3697 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3698 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3699 | "dev": true 3700 | }, 3701 | "path-parse": { 3702 | "version": "1.0.7", 3703 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 3704 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 3705 | "dev": true 3706 | }, 3707 | "path-type": { 3708 | "version": "4.0.0", 3709 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", 3710 | "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", 3711 | "dev": true 3712 | }, 3713 | "picomatch": { 3714 | "version": "2.3.1", 3715 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3716 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3717 | "dev": true 3718 | }, 3719 | "preact": { 3720 | "version": "10.17.1", 3721 | "resolved": "https://registry.npmjs.org/preact/-/preact-10.17.1.tgz", 3722 | "integrity": "sha512-X9BODrvQ4Ekwv9GURm9AKAGaomqXmip7NQTZgY7gcNmr7XE83adOMJvd3N42id1tMFU7ojiynRsYnY6/BRFxLA==", 3723 | "dev": true 3724 | }, 3725 | "prelude-ls": { 3726 | "version": "1.2.1", 3727 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 3728 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 3729 | "dev": true 3730 | }, 3731 | "prettier": { 3732 | "version": "3.1.1", 3733 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.1.1.tgz", 3734 | "integrity": "sha512-22UbSzg8luF4UuZtzgiUOfcGM8s4tjBv6dJRT7j275NXsy2jb4aJa4NNveul5x4eqlF1wuhuR2RElK71RvmVaw==", 3735 | "dev": true 3736 | }, 3737 | "prettier-linter-helpers": { 3738 | "version": "1.0.0", 3739 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 3740 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 3741 | "dev": true, 3742 | "requires": { 3743 | "fast-diff": "^1.1.2" 3744 | } 3745 | }, 3746 | "punycode": { 3747 | "version": "2.3.1", 3748 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 3749 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 3750 | "dev": true 3751 | }, 3752 | "queue-microtask": { 3753 | "version": "1.2.3", 3754 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 3755 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 3756 | "dev": true 3757 | }, 3758 | "resolve": { 3759 | "version": "1.22.4", 3760 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.4.tgz", 3761 | "integrity": "sha512-PXNdCiPqDqeUou+w1C2eTQbNfxKSuMxqTCuvlmmMsk1NWHL5fRrhY6Pl0qEYYc6+QqGClco1Qj8XnjPego4wfg==", 3762 | "dev": true, 3763 | "requires": { 3764 | "is-core-module": "^2.13.0", 3765 | "path-parse": "^1.0.7", 3766 | "supports-preserve-symlinks-flag": "^1.0.0" 3767 | } 3768 | }, 3769 | "resolve-from": { 3770 | "version": "4.0.0", 3771 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 3772 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 3773 | "dev": true 3774 | }, 3775 | "reusify": { 3776 | "version": "1.0.4", 3777 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 3778 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 3779 | "dev": true 3780 | }, 3781 | "rimraf": { 3782 | "version": "3.0.2", 3783 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 3784 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 3785 | "dev": true, 3786 | "requires": { 3787 | "glob": "^7.1.3" 3788 | } 3789 | }, 3790 | "rollup": { 3791 | "version": "2.79.1", 3792 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.79.1.tgz", 3793 | "integrity": "sha512-uKxbd0IhMZOhjAiD5oAFp7BqvkA4Dv47qpOCtaNvng4HBwdbWtdOh8f5nZNuk2rp51PMGk3bzfWu5oayNEuYnw==", 3794 | "dev": true, 3795 | "requires": { 3796 | "fsevents": "~2.3.2" 3797 | } 3798 | }, 3799 | "rollup-plugin-copy": { 3800 | "version": "3.4.0", 3801 | "resolved": "https://registry.npmjs.org/rollup-plugin-copy/-/rollup-plugin-copy-3.4.0.tgz", 3802 | "integrity": "sha512-rGUmYYsYsceRJRqLVlE9FivJMxJ7X6jDlP79fmFkL8sJs7VVMSVyA2yfyL+PGyO/vJs4A87hwhgVfz61njI+uQ==", 3803 | "dev": true, 3804 | "requires": { 3805 | "@types/fs-extra": "^8.0.1", 3806 | "colorette": "^1.1.0", 3807 | "fs-extra": "^8.1.0", 3808 | "globby": "10.0.1", 3809 | "is-plain-object": "^3.0.0" 3810 | } 3811 | }, 3812 | "run-parallel": { 3813 | "version": "1.2.0", 3814 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 3815 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 3816 | "dev": true, 3817 | "requires": { 3818 | "queue-microtask": "^1.2.2" 3819 | } 3820 | }, 3821 | "semver": { 3822 | "version": "7.5.4", 3823 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", 3824 | "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", 3825 | "dev": true, 3826 | "requires": { 3827 | "lru-cache": "^6.0.0" 3828 | } 3829 | }, 3830 | "shebang-command": { 3831 | "version": "2.0.0", 3832 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3833 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3834 | "dev": true, 3835 | "requires": { 3836 | "shebang-regex": "^3.0.0" 3837 | } 3838 | }, 3839 | "shebang-regex": { 3840 | "version": "3.0.0", 3841 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3842 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3843 | "dev": true 3844 | }, 3845 | "slash": { 3846 | "version": "3.0.0", 3847 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 3848 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 3849 | "dev": true 3850 | }, 3851 | "sourcemap-codec": { 3852 | "version": "1.4.8", 3853 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.8.tgz", 3854 | "integrity": "sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==", 3855 | "dev": true 3856 | }, 3857 | "strip-ansi": { 3858 | "version": "6.0.1", 3859 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3860 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3861 | "dev": true, 3862 | "requires": { 3863 | "ansi-regex": "^5.0.1" 3864 | } 3865 | }, 3866 | "strip-json-comments": { 3867 | "version": "3.1.1", 3868 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 3869 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 3870 | "dev": true 3871 | }, 3872 | "style-mod": { 3873 | "version": "4.1.0", 3874 | "resolved": "https://registry.npmjs.org/style-mod/-/style-mod-4.1.0.tgz", 3875 | "integrity": "sha512-Ca5ib8HrFn+f+0n4N4ScTIA9iTOQ7MaGS1ylHcoVqW9J7w2w8PzN6g9gKmTYgGEBH8e120+RCmhpje6jC5uGWA==", 3876 | "dev": true, 3877 | "peer": true 3878 | }, 3879 | "supports-color": { 3880 | "version": "7.2.0", 3881 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 3882 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 3883 | "dev": true, 3884 | "requires": { 3885 | "has-flag": "^4.0.0" 3886 | } 3887 | }, 3888 | "supports-preserve-symlinks-flag": { 3889 | "version": "1.0.0", 3890 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3891 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 3892 | "dev": true 3893 | }, 3894 | "svelte": { 3895 | "version": "3.35.0", 3896 | "resolved": "https://registry.npmjs.org/svelte/-/svelte-3.35.0.tgz", 3897 | "integrity": "sha512-gknlZkR2sXheu/X+B7dDImwANVvK1R0QGQLd8CNIfxxGPeXBmePnxfzb6fWwTQRsYQG7lYkZXvpXJvxvpsoB7g==", 3898 | "dev": true 3899 | }, 3900 | "synckit": { 3901 | "version": "0.8.8", 3902 | "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.8.8.tgz", 3903 | "integrity": "sha512-HwOKAP7Wc5aRGYdKH+dw0PRRpbO841v2DENBtjnR5HFWoiNByAl7vrx3p0G/rCyYXQsrxqtX48TImFtPcIHSpQ==", 3904 | "dev": true, 3905 | "requires": { 3906 | "@pkgr/core": "^0.1.0", 3907 | "tslib": "^2.6.2" 3908 | } 3909 | }, 3910 | "syntax-error": { 3911 | "version": "1.4.0", 3912 | "resolved": "https://registry.npmjs.org/syntax-error/-/syntax-error-1.4.0.tgz", 3913 | "integrity": "sha512-YPPlu67mdnHGTup2A8ff7BC2Pjq0e0Yp/IyTFN03zWO0RcK07uLcbi7C2KpGR2FvWbaB0+bfE27a+sBKebSo7w==", 3914 | "requires": { 3915 | "acorn-node": "^1.2.0" 3916 | } 3917 | }, 3918 | "text-table": { 3919 | "version": "0.2.0", 3920 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3921 | "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", 3922 | "dev": true 3923 | }, 3924 | "to-regex-range": { 3925 | "version": "5.0.1", 3926 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3927 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3928 | "dev": true, 3929 | "requires": { 3930 | "is-number": "^7.0.0" 3931 | } 3932 | }, 3933 | "ts-api-utils": { 3934 | "version": "1.0.3", 3935 | "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.0.3.tgz", 3936 | "integrity": "sha512-wNMeqtMz5NtwpT/UZGY5alT+VoKdSsOOP/kqHFcUW1P/VRhH2wJ48+DN2WwUliNbQ976ETwDL0Ifd2VVvgonvg==", 3937 | "dev": true, 3938 | "requires": {} 3939 | }, 3940 | "tslib": { 3941 | "version": "2.6.2", 3942 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 3943 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", 3944 | "dev": true 3945 | }, 3946 | "type-check": { 3947 | "version": "0.4.0", 3948 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 3949 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 3950 | "dev": true, 3951 | "requires": { 3952 | "prelude-ls": "^1.2.1" 3953 | } 3954 | }, 3955 | "type-fest": { 3956 | "version": "0.20.2", 3957 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", 3958 | "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", 3959 | "dev": true 3960 | }, 3961 | "typescript": { 3962 | "version": "4.9.5", 3963 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.5.tgz", 3964 | "integrity": "sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g==", 3965 | "dev": true 3966 | }, 3967 | "undici-types": { 3968 | "version": "5.26.5", 3969 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 3970 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", 3971 | "dev": true 3972 | }, 3973 | "universalify": { 3974 | "version": "0.1.2", 3975 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 3976 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 3977 | "dev": true 3978 | }, 3979 | "uri-js": { 3980 | "version": "4.4.1", 3981 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 3982 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 3983 | "dev": true, 3984 | "requires": { 3985 | "punycode": "^2.1.0" 3986 | } 3987 | }, 3988 | "w3c-keyname": { 3989 | "version": "2.2.8", 3990 | "resolved": "https://registry.npmjs.org/w3c-keyname/-/w3c-keyname-2.2.8.tgz", 3991 | "integrity": "sha512-dpojBhNsCNN7T82Tm7k26A6G9ML3NkhDsnw9n/eoxSRlVBB4CEtIQ/KTCLI2Fwf3ataSXRhYFkQi3SlnFwPvPQ==", 3992 | "dev": true, 3993 | "peer": true 3994 | }, 3995 | "which": { 3996 | "version": "2.0.2", 3997 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3998 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3999 | "dev": true, 4000 | "requires": { 4001 | "isexe": "^2.0.0" 4002 | } 4003 | }, 4004 | "wrappy": { 4005 | "version": "1.0.2", 4006 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 4007 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 4008 | "dev": true 4009 | }, 4010 | "xtend": { 4011 | "version": "4.0.2", 4012 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 4013 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==" 4014 | }, 4015 | "yallist": { 4016 | "version": "4.0.0", 4017 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 4018 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 4019 | "dev": true 4020 | }, 4021 | "yocto-queue": { 4022 | "version": "0.1.0", 4023 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 4024 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 4025 | "dev": true 4026 | } 4027 | } 4028 | } -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "customjs", 3 | "version": "1.0.21", 4 | "description": "This is a plugin for Obsidian (https://obsidian.md) that enables custom javascript across mobile and desktop.", 5 | "main": "main.js", 6 | "scripts": { 7 | "dev": "rollup --config rollup.config.js -w", 8 | "build": "rollup --config rollup.config.js --environment BUILD:production", 9 | "build-ci": "npm run build -- --failAfterWarnings", 10 | "lint": "eslint --ext .ts .", 11 | "lint-fix": "eslint '--fix --ext .ts .'", 12 | "format": "prettier --write ." 13 | }, 14 | "keywords": [], 15 | "author": "Sam Lewis", 16 | "license": "MIT", 17 | "devDependencies": { 18 | "@rollup/plugin-commonjs": "^18.0.0", 19 | "@rollup/plugin-node-resolve": "^11.2.1", 20 | "@rollup/plugin-typescript": "^8.2.1", 21 | "@types/node": "^20.10.6", 22 | "@typescript-eslint/eslint-plugin": "^6.17.0", 23 | "@typescript-eslint/parser": "^6.17.0", 24 | "eslint": "^8.56.0", 25 | "eslint-plugin-prettier": "^5.1.2", 26 | "obsidian": "^0.12.0", 27 | "obsidian-dataview": "^0.4.11", 28 | "prettier": "^3.1.1", 29 | "rollup": "^2.32.1", 30 | "rollup-plugin-copy": "^3.4.0", 31 | "tslib": "^2.2.0", 32 | "typescript": "^4.2.4" 33 | }, 34 | "dependencies": { 35 | "compare-versions": "^3.6.0", 36 | "debuggable-eval": "^1.0.0" 37 | } 38 | } -------------------------------------------------------------------------------- /rollup.config.js: -------------------------------------------------------------------------------- 1 | import typescript from '@rollup/plugin-typescript'; 2 | import { nodeResolve } from '@rollup/plugin-node-resolve'; 3 | import commonjs from '@rollup/plugin-commonjs'; 4 | import copy from 'rollup-plugin-copy'; 5 | 6 | const isProd = process.env.BUILD === 'production'; 7 | 8 | const banner = `/* 9 | THIS IS A GENERATED/BUNDLED FILE BY ROLLUP 10 | if you want to view the source visit the plugins github repository 11 | */ 12 | `; 13 | 14 | const cfg = { 15 | input: 'main.ts', 16 | output: { 17 | dir: isProd ? 'build' : './', 18 | sourcemap: 'inline', 19 | sourcemapExcludeSources: isProd, 20 | format: 'cjs', 21 | exports: 'default', 22 | banner, 23 | }, 24 | external: ['obsidian'], 25 | plugins: [ 26 | typescript({ 27 | allowSyntheticDefaultImports: true, 28 | }), 29 | nodeResolve({ browser: true }), 30 | commonjs(), 31 | ], 32 | onwarn: (warning, warn) => { 33 | // Quiet rollup warning about eval 34 | if (/Use of eval is strongly discouraged/.test(warning.message)) return; 35 | warn(warning); 36 | }, 37 | }; 38 | 39 | if (!isProd) { 40 | // Build by default to root of the plugin, but allow overriding if needed 41 | // run with overrides with OUTPUT_DIR='' npm run dev 42 | const devBuildPath = process.env.OUTPUT_DIR; 43 | 44 | if (devBuildPath) { 45 | cfg.plugins.push( 46 | copy({ 47 | targets: [ 48 | { src: 'manifest.json', dest: devBuildPath }, 49 | { 50 | src: 'styles.css', 51 | dest: devBuildPath, 52 | }, 53 | { 54 | src: 'main.js', 55 | dest: devBuildPath, 56 | }, 57 | ], 58 | }), 59 | ); 60 | } 61 | } 62 | 63 | export default cfg; 64 | -------------------------------------------------------------------------------- /styles.css: -------------------------------------------------------------------------------- 1 | /* Sets all the text color to red! */ 2 | /* body { 3 | color: red; 4 | } */ 5 | -------------------------------------------------------------------------------- /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 | "allowSyntheticDefaultImports": true, 13 | "lib": ["dom", "es5", "scripthost", "es2015"] 14 | }, 15 | "include": ["**/*.ts"] 16 | } 17 | -------------------------------------------------------------------------------- /types.d.ts: -------------------------------------------------------------------------------- 1 | import * as obsidian from 'obsidian'; 2 | import { DataviewAPI } from 'obsidian-dataview'; 3 | 4 | export type CustomJSType = { 5 | obsidian?: typeof obsidian; 6 | app?: obsidian.App; 7 | state?: Record; 8 | [scriptName: string]: unknown; 9 | }; 10 | 11 | declare global { 12 | interface Window { 13 | forceLoadCustomJS?: () => Promise; 14 | cJS?: ( 15 | moduleOrCallback?: string | ((customJS: CustomJSType) => void), 16 | ) => Promise; 17 | customJS?: CustomJSType; 18 | } 19 | } 20 | 21 | declare module 'obsidian' { 22 | interface App { 23 | plugins: { 24 | enabledPlugins: Set; 25 | plugins: { 26 | [id: string]: unknown; 27 | dataview?: { 28 | api?: DataviewAPI; 29 | manifest: { 30 | version: string; 31 | }; 32 | }; 33 | }; 34 | }; 35 | setting: { 36 | openTabById: (tabId: 'hotkeys') => { 37 | searchComponent: SearchComponent; 38 | updateHotkeyVisibility: () => void; 39 | }; 40 | }; 41 | commands: { 42 | removeCommand: (commandName: string) => void; 43 | }; 44 | } 45 | interface MetadataCache { 46 | on( 47 | name: 'dataview:api-ready', 48 | callback: (api: DataviewAPI) => unknown, 49 | ctx?: unknown, 50 | ): EventRef; 51 | on( 52 | name: 'dataview:metadata-change', 53 | callback: ( 54 | ...args: 55 | | [op: 'rename', file: TAbstractFile, oldPath: string] 56 | | [op: 'delete', file: TFile] 57 | | [op: 'update', file: TFile] 58 | ) => unknown, 59 | ctx?: unknown, 60 | ): EventRef; 61 | } 62 | } 63 | -------------------------------------------------------------------------------- /versions.json: -------------------------------------------------------------------------------- 1 | { 2 | "1.0.21": "0.9.7" 3 | } --------------------------------------------------------------------------------