diff --git a/.env.production b/.env.production new file mode 100644 index 0000000..c0a3cdc --- /dev/null +++ b/.env.production @@ -0,0 +1,2 @@ +VITE_BETTER_SQLITE3_BINDING=.\resources\app.asar\native\better_sqlite3.node +VITE_INSTALL=false \ No newline at end of file diff --git a/.gitignore b/.gitignore index 75920e4..ae3c994 100644 --- a/.gitignore +++ b/.gitignore @@ -1,28 +1,38 @@ -.DS_Store -node_modules -/dist - - -# local env files -.env.local -.env.*.local - -# Log files +# Logs +logs +*.log npm-debug.log* yarn-debug.log* yarn-error.log* pnpm-debug.log* +lerna-debug.log* + +node_modules +dist +dist-ssr +dist-electron +native +release +*.local +.env # Editor directories and files +.vscode/.debug.env .idea -.vscode +.DS_Store *.suo *.ntvs* *.njsproj *.sln *.sw? -#Electron-builder output -/dist_electron +# lockfile +package-lock.json +pnpm-lock.yaml +yarn.lock -/build +# VSCode +.history + +# Rust +target \ No newline at end of file diff --git a/.prettierrc b/.prettierrc deleted file mode 100644 index 3748136..0000000 --- a/.prettierrc +++ /dev/null @@ -1,3 +0,0 @@ -{ - "printWidth": 160, -} diff --git a/.vscode/.debug.script.mjs b/.vscode/.debug.script.mjs new file mode 100644 index 0000000..e3674cb --- /dev/null +++ b/.vscode/.debug.script.mjs @@ -0,0 +1,23 @@ +import fs from 'node:fs' +import path from 'node:path' +import { fileURLToPath } from 'node:url' +import { createRequire } from 'node:module' +import { spawn } from 'node:child_process' + +const pkg = createRequire(import.meta.url)('../package.json') +const __dirname = path.dirname(fileURLToPath(import.meta.url)) + +// write .debug.env +const envContent = Object.entries(pkg.debug.env).map(([key, val]) => `${key}=${val}`) +fs.writeFileSync(path.join(__dirname, '.debug.env'), envContent.join('\n')) + +// bootstrap +spawn( + // TODO: terminate `npm run dev` when Debug exits. + process.platform === 'win32' ? 'npm.cmd' : 'npm', + ['run', 'dev'], + { + stdio: 'inherit', + env: Object.assign(process.env, { VSCODE_DEBUG: 'true' }), + }, +) diff --git a/.vscode/extensions.json b/.vscode/extensions.json new file mode 100644 index 0000000..232ead7 --- /dev/null +++ b/.vscode/extensions.json @@ -0,0 +1,6 @@ +{ + "recommendations": [ + "Vue.volar", + "Vue.vscode-typescript-vue-plugin" + ] +} diff --git a/.vscode/launch.json b/.vscode/launch.json new file mode 100644 index 0000000..3d01d65 --- /dev/null +++ b/.vscode/launch.json @@ -0,0 +1,53 @@ +{ + // Use IntelliSense to learn about possible attributes. + // Hover to view descriptions of existing attributes. + // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 + "version": "0.2.0", + "compounds": [ + { + "name": "Debug App", + "preLaunchTask": "Before Debug", + "configurations": [ + "Debug Main Process", + "Debug Renderer Process" + ], + "presentation": { + "hidden": false, + "group": "", + "order": 1 + }, + "stopAll": true + } + ], + "configurations": [ + { + "name": "Debug Main Process", + "type": "node", + "request": "launch", + "runtimeExecutable": "${workspaceRoot}/node_modules/.bin/electron", + "windows": { + "runtimeExecutable": "${workspaceRoot}/node_modules/.bin/electron.cmd" + }, + "runtimeArgs": [ + "--remote-debugging-port=9229", + "." + ], + "envFile": "${workspaceFolder}/.vscode/.debug.env", + "console": "integratedTerminal" + }, + { + "name": "Debug Renderer Process", + "port": 9229, + "request": "attach", + "type": "chrome", + "timeout": 60000, + "skipFiles": [ + "/**", + "${workspaceRoot}/node_modules/**", + "${workspaceRoot}/dist-electron/**", + // Skip files in host(VITE_DEV_SERVER_URL) + "http://127.0.0.1:3344/**" + ] + }, + ] +} diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..1e3e2cd --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,13 @@ +{ + "typescript.tsdk": "node_modules/typescript/lib", + "typescript.tsc.autoDetect": "off", + "json.schemas": [ + { + "fileMatch": [ + "/*electron-builder.json5", + "/*electron-builder.json" + ], + "url": "https://json.schemastore.org/electron-builder" + } + ] +} diff --git a/.vscode/tasks.json b/.vscode/tasks.json new file mode 100644 index 0000000..adb5c58 --- /dev/null +++ b/.vscode/tasks.json @@ -0,0 +1,31 @@ +{ + // See https://go.microsoft.com/fwlink/?LinkId=733558 + // for the documentation about the tasks.json format + "version": "2.0.0", + "tasks": [ + { + "label": "Before Debug", + "type": "shell", + "command": "node .vscode/.debug.script.mjs", + "isBackground": true, + "problemMatcher": { + "owner": "typescript", + "fileLocation": "relative", + "pattern": { + // TODO: correct "regexp" + "regexp": "^([a-zA-Z]\\:\/?([\\w\\-]\/?)+\\.\\w+):(\\d+):(\\d+): (ERROR|WARNING)\\: (.*)$", + "file": 1, + "line": 3, + "column": 4, + "code": 5, + "message": 6 + }, + "background": { + "activeOnStart": true, + "beginsPattern": "^.*VITE v.* ready in \\d* ms.*$", + "endsPattern": "^.*\\[startup\\] Electron App.*$" + } + } + } + ] +} diff --git a/Cargo.lock b/Cargo.lock new file mode 100644 index 0000000..17f4723 --- /dev/null +++ b/Cargo.lock @@ -0,0 +1,748 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "adler" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe" + +[[package]] +name = "aho-corasick" +version = "1.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b2969dcb958b36655471fc61f7e416fa76033bdd4bfed0678d8fee1e2d07a1f0" +dependencies = [ + "memchr", +] + +[[package]] +name = "autocfg" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" + +[[package]] +name = "base64" +version = "0.21.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "35636a1494ede3b646cc98f74f8e62c773a38a659ebc777a2cf26b9b74171df9" + +[[package]] +name = "bit_field" +version = "0.10.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc827186963e592360843fb5ba4b973e145841266c1357f7180c43526f2e5b61" + +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + +[[package]] +name = "bitflags" +version = "2.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "327762f6e5a765692301e5bb513e0d9fef63be86bbc14528052b1cd3e6f03e07" + +[[package]] +name = "bytemuck" +version = "1.14.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "374d28ec25809ee0e23827c2ab573d729e293f281dfe393500e7ad618baa61c6" + +[[package]] +name = "byteorder" +version = "1.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "clipboard-win" +version = "4.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7191c27c2357d9b7ef96baac1773290d4ca63b24205b82a3fd8a0637afcf0362" +dependencies = [ + "error-code", + "str-buf", + "winapi", +] + +[[package]] +name = "color_quant" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3d7b894f5411737b7867f4827955924d7c254fc9f4d91a6aad6b097804b1018b" + +[[package]] +name = "convert_case" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ec182b0ca2f35d8fc196cf3404988fd8b8c739a4d270ff118a398feb0cbec1ca" +dependencies = [ + "unicode-segmentation", +] + +[[package]] +name = "crc32fast" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b540bd8bc810d3885c6ea91e2018302f68baba2129ab3e88f32389ee9370880d" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "crossbeam-deque" +version = "0.8.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ce6fd6f855243022dcecf8702fef0c297d4338e226845fe067f6341ad9fa0cef" +dependencies = [ + "cfg-if", + "crossbeam-epoch", + "crossbeam-utils", +] + +[[package]] +name = "crossbeam-epoch" +version = "0.9.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ae211234986c545741a7dc064309f67ee1e5ad243d0e48335adc0484d960bcc7" +dependencies = [ + "autocfg", + "cfg-if", + "crossbeam-utils", + "memoffset", + "scopeguard", +] + +[[package]] +name = "crossbeam-utils" +version = "0.8.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5a22b2d63d4d1dc0b7f1b6b2747dd0088008a9be28b6ddf0b1e7d335e3037294" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "crunchy" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7a81dae078cea95a014a339291cec439d2f232ebe854a9d672b796c6afafa9b7" + +[[package]] +name = "ctor" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "37e366bff8cd32dd8754b0991fb66b279dc48f598c3a18914852a6673deef583" +dependencies = [ + "quote", + "syn 2.0.38", +] + +[[package]] +name = "either" +version = "1.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a26ae43d7bcc3b814de94796a5e736d4029efb0ee900c12e2d54c993ad1a1e07" + +[[package]] +name = "error-code" +version = "2.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "64f18991e7bf11e7ffee451b5318b5c1a73c52d0d0ada6e5a3017c8c1ced6a21" +dependencies = [ + "libc", + "str-buf", +] + +[[package]] +name = "exr" +version = "1.71.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "832a761f35ab3e6664babfbdc6cef35a4860e816ec3916dcfd0882954e98a8a8" +dependencies = [ + "bit_field", + "flume", + "half", + "lebe", + "miniz_oxide", + "rayon-core", + "smallvec", + "zune-inflate", +] + +[[package]] +name = "fdeflate" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "64d6dafc854908ff5da46ff3f8f473c6984119a2876a383a860246dd7841a868" +dependencies = [ + "simd-adler32", +] + +[[package]] +name = "flate2" +version = "1.0.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "46303f565772937ffe1d394a4fac6f411c6013172fadde9dcdb1e147a086940e" +dependencies = [ + "crc32fast", + "miniz_oxide", +] + +[[package]] +name = "flume" +version = "0.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "55ac459de2512911e4b674ce33cf20befaba382d05b62b008afc1c8b57cbf181" +dependencies = [ + "spin", +] + +[[package]] +name = "gif" +version = "0.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "80792593675e051cf94a4b111980da2ba60d4a83e43e0048c5693baab3977045" +dependencies = [ + "color_quant", + "weezl", +] + +[[package]] +name = "half" +version = "2.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "02b4af3693f1b705df946e9fe5631932443781d0aabb423b62fcd4d73f6d2fd0" +dependencies = [ + "crunchy", +] + +[[package]] +name = "image" +version = "0.24.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6f3dfdbdd72063086ff443e297b61695500514b1e41095b6fb9a5ab48a70a711" +dependencies = [ + "bytemuck", + "byteorder", + "color_quant", + "exr", + "gif", + "jpeg-decoder", + "num-rational", + "num-traits", + "png", + "qoi", + "tiff", +] + +[[package]] +name = "itoa" +version = "1.0.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" + +[[package]] +name = "jpeg-decoder" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bc0000e42512c92e31c2252315bda326620a4e034105e900c98ec492fa077b3e" +dependencies = [ + "rayon", +] + +[[package]] +name = "lebe" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "03087c2bad5e1034e8cace5926dec053fb3790248370865f5117a7d0213354c8" + +[[package]] +name = "libc" +version = "0.2.149" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a08173bc88b7955d1b3145aa561539096c421ac8debde8cbc3612ec635fee29b" + +[[package]] +name = "libloading" +version = "0.7.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b67380fd3b2fbe7527a606e18729d21c6f3951633d0500574c4dc22d2d638b9f" +dependencies = [ + "cfg-if", + "winapi", +] + +[[package]] +name = "lock_api" +version = "0.4.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c168f8615b12bc01f9c17e2eb0cc07dcae1940121185446edc3744920e8ef45" +dependencies = [ + "autocfg", + "scopeguard", +] + +[[package]] +name = "memchr" +version = "2.6.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f665ee40bc4a3c5590afb1e9677db74a508659dfd71e126420da8274909a0167" + +[[package]] +name = "memoffset" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5a634b1c61a95585bd15607c6ab0c4e5b226e695ff2800ba0cdccddf208c406c" +dependencies = [ + "autocfg", +] + +[[package]] +name = "miniz_oxide" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e7810e0be55b428ada41041c41f32c9f1a42817901b4ccf45fa3d4b6561e74c7" +dependencies = [ + "adler", + "simd-adler32", +] + +[[package]] +name = "napi" +version = "2.13.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fd063c93b900149304e3ba96ce5bf210cd4f81ef5eb80ded0d100df3e85a3ac0" +dependencies = [ + "bitflags 2.4.1", + "ctor", + "napi-derive", + "napi-sys", + "once_cell", +] + +[[package]] +name = "napi-build" +version = "2.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "882a73d9ef23e8dc2ebbffb6a6ae2ef467c0f18ac10711e4cc59c5485d41df0e" + +[[package]] +name = "napi-derive" +version = "2.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "da1c6a8fa84d549aa8708fcd062372bf8ec6e849de39016ab921067d21bde367" +dependencies = [ + "cfg-if", + "convert_case", + "napi-derive-backend", + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "napi-derive-backend" +version = "1.0.52" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "20bbc7c69168d06a848f925ec5f0e0997f98e8c8d4f2cc30157f0da51c009e17" +dependencies = [ + "convert_case", + "once_cell", + "proc-macro2", + "quote", + "regex", + "semver", + "syn 1.0.109", +] + +[[package]] +name = "napi-sys" +version = "2.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "166b5ef52a3ab5575047a9fe8d4a030cdd0f63c96f071cd6907674453b07bae3" +dependencies = [ + "libloading", +] + +[[package]] +name = "num-integer" +version = "0.1.45" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "225d3389fb3509a24c93f5c29eb6bde2586b98d9f016636dff58d7c6f7569cd9" +dependencies = [ + "autocfg", + "num-traits", +] + +[[package]] +name = "num-rational" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0638a1c9d0a3c0914158145bc76cff373a75a627e6ecbfb71cbe6f453a5a19b0" +dependencies = [ + "autocfg", + "num-integer", + "num-traits", +] + +[[package]] +name = "num-traits" +version = "0.2.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "39e3200413f237f41ab11ad6d161bc7239c84dcb631773ccd7de3dfe4b5c267c" +dependencies = [ + "autocfg", +] + +[[package]] +name = "once_cell" +version = "1.18.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" + +[[package]] +name = "png" +version = "0.17.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dd75bf2d8dd3702b9707cdbc56a5b9ef42cec752eb8b3bafc01234558442aa64" +dependencies = [ + "bitflags 1.3.2", + "crc32fast", + "fdeflate", + "flate2", + "miniz_oxide", +] + +[[package]] +name = "proc-macro2" +version = "1.0.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "134c189feb4956b20f6f547d2cf727d4c0fe06722b20a0eec87ed445a97f92da" +dependencies = [ + "unicode-ident", +] + +[[package]] +name = "qoi" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f6d64c71eb498fe9eae14ce4ec935c555749aef511cca85b5568910d6e48001" +dependencies = [ + "bytemuck", +] + +[[package]] +name = "quote" +version = "1.0.33" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5267fca4496028628a95160fc423a33e8b2e6af8a5302579e322e4b520293cae" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "rayon" +version = "1.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9c27db03db7734835b3f53954b534c91069375ce6ccaa2e065441e07d9b6cdb1" +dependencies = [ + "either", + "rayon-core", +] + +[[package]] +name = "rayon-core" +version = "1.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5ce3fb6ad83f861aac485e76e1985cd109d9a3713802152be56c3b1f0e0658ed" +dependencies = [ + "crossbeam-deque", + "crossbeam-utils", +] + +[[package]] +name = "regex" +version = "1.10.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "380b951a9c5e80ddfd6136919eef32310721aa4aacd4889a8d39124b026ab343" +dependencies = [ + "aho-corasick", + "memchr", + "regex-automata", + "regex-syntax", +] + +[[package]] +name = "regex-automata" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5f804c7828047e88b2d32e2d7fe5a105da8ee3264f01902f796c8e067dc2483f" +dependencies = [ + "aho-corasick", + "memchr", + "regex-syntax", +] + +[[package]] +name = "regex-syntax" +version = "0.8.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c08c74e62047bb2de4ff487b251e4a92e24f48745648451635cec7d591162d9f" + +[[package]] +name = "rust" +version = "0.0.0" +dependencies = [ + "base64", + "clipboard-win", + "image", + "napi", + "napi-build", + "napi-derive", + "serde", + "serde_json", + "static_vcruntime", + "windows", +] + +[[package]] +name = "ryu" +version = "1.0.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1ad4cc8da4ef723ed60bced201181d83791ad433213d8c24efffda1eec85d741" + +[[package]] +name = "scopeguard" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" + +[[package]] +name = "semver" +version = "1.0.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "836fa6a3e1e547f9a2c4040802ec865b5d85f4014efe00555d7090a3dcaa1090" + +[[package]] +name = "serde" +version = "1.0.190" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "91d3c334ca1ee894a2c6f6ad698fe8c435b76d504b13d436f0685d648d6d96f7" +dependencies = [ + "serde_derive", +] + +[[package]] +name = "serde_derive" +version = "1.0.190" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "67c5609f394e5c2bd7fc51efda478004ea80ef42fee983d5c67a65e34f32c0e3" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "serde_json" +version = "1.0.108" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3d1c7e3eac408d115102c4c24ad393e0821bb3a5df4d506a80f85f7a742a526b" +dependencies = [ + "itoa", + "ryu", + "serde", +] + +[[package]] +name = "simd-adler32" +version = "0.3.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d66dc143e6b11c1eddc06d5c423cfc97062865baf299914ab64caa38182078fe" + +[[package]] +name = "smallvec" +version = "1.11.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "942b4a808e05215192e39f4ab80813e599068285906cc91aa64f923db842bd5a" + +[[package]] +name = "spin" +version = "0.9.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6980e8d7511241f8acf4aebddbb1ff938df5eebe98691418c4468d0b72a96a67" +dependencies = [ + "lock_api", +] + +[[package]] +name = "static_vcruntime" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "954e3e877803def9dc46075bf4060147c55cd70db97873077232eae0269dc89b" + +[[package]] +name = "str-buf" +version = "1.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9e08d8363704e6c71fc928674353e6b7c23dcea9d82d7012c8faf2a3a025f8d0" + +[[package]] +name = "syn" +version = "1.0.109" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "syn" +version = "2.0.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e96b79aaa137db8f61e26363a0c9b47d8b4ec75da28b7d1d614c2303e232408b" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "tiff" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6d172b0f4d3fba17ba89811858b9d3d97f928aece846475bbda076ca46736211" +dependencies = [ + "flate2", + "jpeg-decoder", + "weezl", +] + +[[package]] +name = "unicode-ident" +version = "1.0.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" + +[[package]] +name = "unicode-segmentation" +version = "1.10.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1dd624098567895118886609431a7c3b8f516e41d30e0643f03d94592a147e36" + +[[package]] +name = "weezl" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9193164d4de03a926d909d3bc7c30543cecb35400c02114792c2cae20d5e2dbb" + +[[package]] +name = "winapi" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5c839a674fcd7a98952e593242ea400abe93992746761e38641405d28b00f419" +dependencies = [ + "winapi-i686-pc-windows-gnu", + "winapi-x86_64-pc-windows-gnu", +] + +[[package]] +name = "winapi-i686-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" + +[[package]] +name = "winapi-x86_64-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" + +[[package]] +name = "windows" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e686886bc078bc1b0b600cac0147aadb815089b6e4da64016cbd754b6342700f" +dependencies = [ + "windows-targets", +] + +[[package]] +name = "windows-targets" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" +dependencies = [ + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", +] + +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" + +[[package]] +name = "windows_aarch64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" + +[[package]] +name = "windows_i686_gnu" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" + +[[package]] +name = "windows_i686_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" + +[[package]] +name = "windows_x86_64_gnu" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" + +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" + +[[package]] +name = "zune-inflate" +version = "0.2.54" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "73ab332fe2f6680068f3582b16a24f90ad7096d5d39b974d1c0aff0125116f02" +dependencies = [ + "simd-adler32", +] diff --git a/LICENSE b/LICENSE.txt similarity index 100% rename from LICENSE rename to LICENSE.txt diff --git a/README.md b/README.md index 3c9b771..afe1ec8 100644 --- a/README.md +++ b/README.md @@ -1,37 +1,70 @@ -# Dawn Launcher -Windows快捷启动工具,帮助您整理杂乱无章的桌面,分门别类管理您的桌面快捷方式,让您的桌面保持干净整洁。 +# 更新 + +消失了三个多月,我将`Dawn Launcher`代码进行重构,因为一开始没有开发`NodeJS`和`Electron`的经验,`Vue`也写的不好,代码写的有些潦草,所以进行了代码重构,新版使用了`Electron26 + Vite + Vue3 + TS`,UI 框架使用了`Naive`,关于原生 API 方面,我从`C++`切换到了 `Rust`,数据库从`electron-store`切换到了`SQLite3`,语言也新增了`英语`。 + +# Dawn Launcher + +`Windows`快捷启动工具,帮助您整理杂乱无章的桌面,分门别类管理您的桌面快捷方式,让您的桌面保持干净整洁。 + +支持关联文件夹(实时同步文件夹内容)、快速搜索、相对路径(便携路径)、扫描本机开始菜单、本地扫描本机 Appx 应用列表、添加网址并一键获取网址信息。 + +# 技术栈 + +`Electron + Vite + Vue3 + TS` -支持相对路径(便携路径),支持扫描本机开始菜单、本地Appx应用列表添加项目、支持多项目添加,一次启动多个项目、支持添加网址并一键获取网址信息。 -# 开发框架 -Electron # 支持平台 -Windows + +`Windows(10/11)` + # 编译步骤 -1. 需要配置 node-gyp 环境,这个可以自行搜索一下。 -2. yarn install 安装依赖。 -3. node-gyp rebuild --arch=x64 或 node-gyp rebuild --arch=ia32 编译64位或32位DLL。 -4. yarn electron:serve 本地运行项目。 -5. yarn electron:build 打包项目,打包64位和32位的时候,需要分两次打包,将 vue.config.js 配置中的 pluginOptions.electronBuilder.builderOptions.win.target.arch 修改为x64或者ia32。 + +1. 首先需要安装`node-gyp`,编译本地模块需要用到。 +2. 然后运行`yarn install`安装项目依赖(如果修改了`Rust`代码也需要重新运行`yarn install`)。 +3. `yarn run dev`本地运行项目。 +4. `yarn run build`打包项目。 +5. 便携版和安装版需要分两次打包,通过修改`.env.production`中的`VITE_INSTALL`,`true`为安装版,`false`为便携版。 + # 官网 + [dawnlauncher.com](https://dawnlauncher.com/) + # 捐赠 + ![微信](/images/wechat.png) ![支付宝](/images/alipay.png) + # 界面 -![界面](/images/界面.png) + +![界面](/images/soft1.png) + ## 子分类 -![子分类](/images/子分类.png) + +![子分类](/images/soft2.png) + ## 自定义主题 -![自定义主题](/images/自定义主题.png) + +![自定义主题](/images/soft3.png) + ## 自定义背景 -![自定义背景](/images/自定义背景.png) + +![自定义背景](/images/soft4.png) + ## 快速搜索 -![快速搜索](/images/快速搜索.gif) + +![快速搜索](/images/soft5.png) + ## 一键获取网址信息 -![一键获取网址信息](/images/一键获取网址信息.gif) + +![一键获取网址信息](/images/soft6.webp) + ## 相对路径(便携路径) -![相对路径(便携路径)](/images/相对路径.png) + +![相对路径(便携路径)](/images/soft7.png) + ## 关联文件夹 -![关联文件夹](/images/关联文件夹.gif) + +![关联文件夹](/images/soft8.webp) + # License + Apache License Version 2.0 diff --git a/babel.config.js b/babel.config.js deleted file mode 100644 index ca2a3c1..0000000 --- a/babel.config.js +++ /dev/null @@ -1,4 +0,0 @@ -module.exports = { - presets: ["@vue/cli-plugin-babel/preset"], - plugins: [], -}; diff --git a/binding.gyp b/binding.gyp deleted file mode 100644 index 5c01172..0000000 --- a/binding.gyp +++ /dev/null @@ -1,14 +0,0 @@ -{ - "targets": [ - { - "target_name": "api", - "cflags!": [ "-fno-exceptions" ], - "cflags_cc!": [ "-fno-exceptions" ], - "sources": [ "./src/main/api/api.cc" ], - "include_dirs": [ - " { + return '与"' + value + '"分类快捷键产生冲突,请重新设置。'; + }, + shortcutKeyPrompt3: (value: string) => { + return '与"' + value + '"项目快捷键产生冲突,请重新设置。'; + }, + shortcutKeyPrompt4: + '与"设置-常规"中的"显示/隐藏"快捷键产生冲突,请重新设置。', + shortcutKeyPrompt5: '与"设置-常规"中的"搜索"快捷键产生冲突,请重新设置。', + shortcutKeyPrompt6: + '与"设置-快速搜索"中的"显示/隐藏"快捷键产生冲突,请重新设置。', + show: "显示", + showFollowMousePosition: "显示时跟随鼠标位置", + showHide: "显示/隐藏", + showOnlyFiles: "只显示文件", + showOnlyFolders: "只显示文件夹", + shutdown: "关机", + simplifiedChinese: "简体中文", + size: "尺寸", + sleep: "睡眠", + small: "小", + sort: "排序", + startLocation: "起始位置", + startMenu: "开始菜单", + startup: "启动", + startupTray: "启动后最小化到系统托盘", + subclassification: "子分类", + svgIcon: "SVG图标", + svgIconPrompt1: "输入SVG代码后,需要先点击“校验代码”按钮。", + switch: "切换", + switchClassificationCollapseOtherSubClassification: + "切换分类时收起其他子分类", + switchEnglish: "显示窗口时将输入法切换为英文模式", + system: "系统", + target: "目标", + taskManager: "任务管理器", + theme: "主题", + timeInterval: "时间间隔", + tile: "平铺", + title: "标题", + top: "顶部", + traditionalChinese: "繁体中文", + turnOffMonitor: "关闭显示器", + unlockClassification: "解锁分类", + unlockItem: "解锁项目", + uploadIcon: "上传图标", + url: "网址", + useItemOpen: "从程序外拖动文件到项目图标上时用此项目打开文件", + useProxy: "使用代理", + useQuickSearch: "使用快速搜索", + username: "用户名", + update: "更新", + webSearch: "网络搜索", + webSearchModePrompt1: + '输入"冒号 + 关键字 + 空格"或"关键字 + 空格"使用网络搜索,例如使用谷歌搜索,输入":g"或"g",然后按下空格键,进入网络搜索模式。', + webSearchModePrompt2: "{w}为搜索关键字。", + width: "宽度", + window: "窗口", + zoom: "缩放", +}; + +let traditionalChinese = { + about: "關於", + add: "新增", + address: "地址", + aggregateClassification: "聚合分類", + aggregateClassificationPrompt1: + "聚合分類可以將所有分類下的項目聚合到一起,按照設定的排序方式、項目數量進行排序和顯示。", + aggregateClassificationPrompt2: "當前分類為父級分類,不能設置聚合分類。", + aggregateClassificationPrompt3: + "當前設置排序為按打開次數,需開啟設置-項目-記錄打開次數。", + aggregateClassificationPrompt4: + "設置聚合分類會清空原分類下所有項目,請謹慎操作,是否確認?", + align: "對齊", + all: "全部", + altNumberKey: "Alt + 數字鍵", + alwaysCenter: "永遠居中", + alwaysTop: "永遠置頂", + appearance: "外觀", + appx: "Appx", + associateFolder: "關聯文件夾", + associateFolderPrompt1: + "關聯文件夾可以實時監控指定文件夾內的變化並同步到對應分類中。", + associateFolderPrompt2: "需要隱藏的文件/文件夾名稱,多個按英文逗號分割", + associateFolderPrompt3: "當前分類為父級分類,不能設置關聯文件夾。", + associateFolderPrompt4: "目標路徑不存在。", + associateFolderPrompt5: "目標路徑必須是文件夾。", + associateFolderPrompt6: + "設置關聯文件夾會清空原分類下所有項目,請謹慎操作,是否確認?", + associateFolderPrompt7: + "目標路徑為空,當前分類將會自動轉換為普通分類,是否確認?", + autoSwitchClassification: "項目列表滾動到底部或頂部時自動切換分類", + backgroundIcon: "背景圖標", + backgroundImage: "背景圖", + backgroundImageMode: "背景圖模式", + backgroundImagePostion: "背景圖定位", + backgroundImageTransparent: "背景圖透明", + backgroundTransparent: "背景透明", + backup: "備份", + backupRestoreData: "備份/還原數據", + backupRestoreDataPrompt: + "如果要還原1.2.3及之前版本的備份數據,請在還原時選擇導入JSON格式的文件。", + batchConvertAbsolutePath: "轉為絕對路徑", + batchConvertRelativePath: "轉為相對路徑", + batchCopyTo: "批量復製到", + batchDelete: "批量刪除", + batchDeletePrompt: "是否批量刪除項目?", + batchMoveTo: "批量移動到", + batchOperation: "批量操作", + batchRefreshIcon: "批量刷新圖標", + borderColor: "邊框顏色", + bottom: "底部", + byInitialLetter: "按首字母", + byLastOpen: "按最後打開", + byOpenNumber: "按打開次數", + calculator: "計算器", + cancel: "取消", + cancelBatchOperation: "取消批量操作", + center: "居中", + checkCode: "校驗代碼", + checkInvalidItem: "檢查無效項目", + checkUpdates: "檢查更新", + checkUpdatesPrompt1: '檢查到有新版本,點擊"確定"跳轉官網下載最新版本。', + checkUpdatesPrompt2: "當前已經是最新版本。", + checkUpdatesPrompt3: "檢查更新失敗,請確認網絡。", + classification: "分類", + clear: "清空", + close: "關閉", + colon: ":", + colonKeywordSpace: "冒號 + 關鍵字 + 空格", + color: "顏色", + columnNumber: "列數", + commandPrompt: "命令提示符", + computer: "計算機", + computerManagement: "計算機管理", + controlPanel: "控製面板", + convertAbsolutePath: "轉為絕對路徑", + convertRelativePath: "轉為相對路徑", + copyFullPath: "復製完整路徑", + copyTo: "復製到", + createShortcut: "創建快捷方式", + ctrlNumberKey: "Ctrl + 數字鍵", + default: "默認", + defaultIcon: "默認圖標", + delayDisplay: "延遲顯示", + delayHide: "延遲隱藏", + delete: "刪除", + deleteClassificationPrompt: "是否刪除當前分類?", + deleteIcon: "刪除圖標", + deleteItemPrompt: "是否刪除當前項目?", + description: "描述", + display: "顯示", + displayMainWindow: "顯示主界面", + documents: "文檔", + doubleClickOpen: "雙擊打開", + doubleClickTaskbar: "雙擊任務欄", + downloadImagePrompt1: "下載圖片失敗。", + downloadImagePrompt2: "鏈接不是圖片格式。", + dontPromptAgain: "不再提示", + edgeAutoHide: "停靠在桌面邊緣時自動隱藏", + edgeDock: "邊緣吸附", + edit: "編輯", + editClassification: "編輯分類", + editItem: "編輯項目", + editSubclassification: "編輯子分類", + emptyRecycleBin: "清空回收站", + enable: "啟用", + english: "英語", + excludeSearch: "排除搜索", + exit: "退出", + explorerMenu: "資源管理器菜單", + exportIcon: "導出圖標", + extraLarge: "超大", + feedback: "反饋", + file: "文件", + fileExplorer: "文件資源管理器", + fixedClassification: "固定分類", + fixedIcon: "固定圖標", + fixedPosition: "固定位置", + folder: "文件夾", + folderPath: "文件夾路徑", + fontLineHeight: "字體行高", + fontMainColor: "字體主色", + fontSecondaryColor: "字體副色", + fontShadow: "字體陰影", + fontSize: "字體大小", + fontWeight: "字體粗細", + functions: "功能", + general: "常規", + getIcon: "獲取圖標", + getURLInformation: "獲取網址信息", + globalShortcutKey: "全局快捷鍵", + hiddenItems: "隱藏項", + hideEllipses: "隱藏省略號", + hideLoseFocus: "失去焦點後隱藏", + hideName: "隱藏名稱", + hideTray: "隱藏托盤圖標", + hideWindowCollapseSubClassification: "隱藏窗口時收起子分類", + history: "歷史記錄", + hover: "懸停", + icon: "圖標", + imageLink: "圖片鏈接", + item: "項目", + itemAddEditPrompt1: "選中固定圖標後,當前項目不參與刷新圖標。", + itemAddEditPrompt2: "無特殊需求為空即可", + itemAddEditPrompt3: "添加成功。", + itemAddEditPrompt4: "目標不存在。", + itemAddEditPrompt5: "獲取網址信息失敗。", + itemList: "項目列表", + keyword: "關鍵字", + keywordSpace: "關鍵字 + 空格", + language: "語言", + large: "大", + layout: "布局", + layoutListModeTakeEffect: '布局為"列表"模式下生效。', + layoutTileModeTakeEffect: '布局為"平鋪"模式下生效。', + left: "左側", + lineNumber: "行數", + list: "列表", + lock: "鎖定", + lockClassification: "鎖定分類", + lockItem: "鎖定項目", + lockSize: "鎖定尺寸", + mainColor: "主色", + matchCondition: "匹配條件", + medium: "中", + middleClick: "中鍵單擊", + millisecond: "毫秒", + mode: "模式", + modifyIcon: "修改圖標", + mouseHover: "鼠標懸停", + mouseWheel: "鼠標滾輪", + moveTo: "移動到", + multiItems: "多項目", + name: "名稱", + network: "網絡", + networkIcon: "網絡圖標", + networkIconPrompt1: "支持JPG/JPEG/GIF/PNG/ICO/SVG/WEBP格式圖片。", + networkShareCenter: "網絡和共享中心", + newClassification: "新建分類", + newClassificationName: "新分類", + newItem: "新建項目", + newSubclassification: "新建子分類", + none: "無", + noRepeat: "不重復", + normal: "普通", + notDisturb: "勿擾模式", + notDisturbPrompt: + "開啟勿擾模式後,計算機在遊戲、應用全屏模式下不會彈出Dawn Launcher窗口。", + notFoundFile: "找不到指定的文件", + notFoundFolder: "找不到指定的文件夾", + number: "數量", + numberKey: "數字鍵", + officialWebsite: "官方網站", + ok: "確定", + open: "打開", + openAfterHideMainInterface: "打開後隱藏主界面", + openAfterHideQuickSearchWindow: "打開後隱藏窗口", + openFileLocation: "打開文件所在位置", + openNow: "僅剩一項時立即打開", + openNumber: "打開次數", + parameters: "參數", + password: "密碼", + pasteIcon: "粘貼圖標", + powerOptions: "電源選項", + programsFeatures: "程序和功能", + proxy: "代理", + proxyPrompt: + "僅支持HTTP代理,填寫「地址」時需要帶通信協議和端口,例如:http://127.0.0.1:7890,如果沒有用戶名和密碼,為空即可。", + quickSearch: "快速搜索", + recordOpenNumber: "記錄打開次數", + recycleBin: "回收站", + refreshIcon: "刷新圖標", + registryEditor: "註冊表編輯器", + remark: "備註", + rememberSelectionState: "記住選擇狀態", + repeat: "重復", + resourceMonitor: "資源監視器", + restart: "重啟", + restore: "還原", + restoreDataPrompt: "還原數據失敗。", + rewardSponsor: "打賞&贊助", + right: "右側", + roundedCorners: "圓角", + runAsAdministrator: "以管理員身份運行", + runSystemStartup: "開機啟動", + save: "保存", + search: "搜索", + searchSource: "搜索源", + secondaryColor: "副色", + select: "選擇", + selectAll: "全選", + selectItem: "選擇項目", + services: "服務", + setClassificationIcon: "設置分類圖標", + setIcon: "設置圖標", + settings: "設置", + shortcutKey: "快捷鍵", + shortcutKeyPrompt1: "快捷鍵不完整,請完善快捷鍵。", + shortcutKeyPrompt2: (value: string) => { + return '與"' + value + '"分類快捷鍵產生沖突,請重新設置。'; + }, + shortcutKeyPrompt3: (value: string) => { + return '與"' + value + '"項目快捷鍵產生沖突,請重新設置。'; + }, + shortcutKeyPrompt4: + '與"設置-常規"中的"顯示/隱藏"快捷鍵產生沖突,請重新設置。', + shortcutKeyPrompt5: '與"設置-常規"中的"搜索"快捷鍵產生沖突,請重新設置。', + shortcutKeyPrompt6: + '與"設置-快速搜索"中的"顯示/隱藏"快捷鍵產生沖突,請重新設置。', + show: "顯示", + showFollowMousePosition: "顯示時跟隨鼠標位置", + showHide: "顯示/隱藏", + showOnlyFiles: "只顯示文件", + showOnlyFolders: "只顯示文件夾", + shutdown: "關機", + simplifiedChinese: "簡體中文", + size: "尺寸", + sleep: "睡眠", + small: "小", + sort: "排序", + startLocation: "起始位置", + startMenu: "開始菜單", + startup: "啟動", + startupTray: "啟動後最小化到系統托盤", + subclassification: "子分類", + svgIcon: "SVG圖標", + svgIconPrompt1: "輸入SVG代碼後,需要先點擊「校驗代碼」按鈕。", + switch: "切換", + switchClassificationCollapseOtherSubClassification: + "切換分類時收起其他子分類", + switchEnglish: "顯示窗口時將輸入法切換為英文模式", + system: "系統", + target: "目標", + taskManager: "任務管理器", + theme: "主題", + timeInterval: "時間間隔", + tile: "平鋪", + title: "標題", + top: "頂部", + traditionalChinese: "繁體中文", + turnOffMonitor: "關閉顯示器", + unlockClassification: "解鎖分類", + unlockItem: "解鎖項目", + uploadIcon: "上傳圖標", + url: "網址", + useItemOpen: "從程序外拖動文件到項目圖標上時用此項目打開文件", + useProxy: "使用代理", + useQuickSearch: "使用快速搜索", + username: "用戶名", + update: "更新", + webSearch: "網絡搜索", + webSearchModePrompt1: + '輸入"冒號 + 關鍵字 + 空格"或"關鍵字 + 空格"使用網絡搜索,例如使用谷歌搜索,輸入":g"或"g",然後按下空格鍵,進入網絡搜索模式。', + webSearchModePrompt2: "{w}為搜索關鍵字。", + width: "寬度", + window: "窗口", + zoom: "縮放", +}; + +// 英语 +let english = { + about: "About", + add: "Add", + address: "Address", + aggregateClassification: "Aggregate Classification", + aggregateClassificationPrompt1: + "Aggregation classification can aggregate items under all categories together, sort and display them according to the set sorting method and number of items.", + aggregateClassificationPrompt2: + "The current classification is the parent classification, and aggregate classification cannot be set.", + aggregateClassificationPrompt3: + "The current settings are sorted by the number of opens. You need to enable Settings-Item-Open Count the number of opens.", + aggregateClassificationPrompt4: + "Setting an aggregation classification will clear all items under the original classification. Please operate with caution. Are you sure?", + align: "Align", + all: "All", + altNumberKey: "Alt + Number Key", + alwaysCenter: "Always Center", + alwaysTop: "Always Top", + appearance: "Appearance", + appx: "Appx", + associateFolder: "Associate Folder", + associateFolderPrompt1: + "Associate folder can monitor changes in the specified folder in real time and synchronize them to the corresponding classification.", + associateFolderPrompt2: + "Name of the file/folder to be hidden, multiple separated by commas", + associateFolderPrompt3: + "The current classification is the parent classification and associate folder cannot be set.", + associateFolderPrompt4: "The target path does not exist.", + associateFolderPrompt5: "The destination path must be a folder.", + associateFolderPrompt6: + "Setting the associate folder will clear all items under the original classification. Please operate with caution. Are you sure?", + associateFolderPrompt7: + "The target path is empty. The current classification will be automatically converted to a normal classification. Are you sure?", + autoSwitchClassification: "Auto Switch Classification on Scroll", + backgroundIcon: "Background Icon", + backgroundImage: "Background Image", + backgroundImageMode: "Background Image Mode", + backgroundImagePostion: "Background Image Postion", + backgroundImageTransparent: "Background Image Transparent", + backgroundTransparent: "Background Transparent", + backup: "Backup", + backupRestoreData: "Backup/Restore Data", + backupRestoreDataPrompt: + "If you want to restore the backup data of versions 1.2.3 and earlier, please choose to import a file in JSON format when restoring.", + batchConvertAbsolutePath: "Batch Convert to Absolute Path", + batchConvertRelativePath: "Batch Convert to Relative Path", + batchCopyTo: "Batch Copy to", + batchDelete: "Batch Delete", + batchDeletePrompt: "Delete items in batches?", + batchMoveTo: "Batch Move to", + batchOperation: "Batch Operation", + batchRefreshIcon: "Batch Refresh Icon", + borderColor: "Border Color", + bottom: "Bottom", + byInitialLetter: "by Initial Letter", + byLastOpen: "by Last Open", + byOpenNumber: "by Open Count", + calculator: "Calculator", + cancel: "Cancel", + cancelBatchOperation: "Cancel Batch Operation", + center: "Center", + checkCode: "Check Code", + checkInvalidItem: "Check for Invalid Items", + checkUpdates: "Check Updates", + checkUpdatesPrompt1: + 'Check that there is a new version, click "OK" to jump to the official website to download the latest version.', + checkUpdatesPrompt2: "It is currently the latest version.", + checkUpdatesPrompt3: + "Failed to check for updates, please confirm the network.", + classification: "Classification", + clear: "Clear", + close: "Close", + colon: ": ", + colonKeywordSpace: "Colon + Keyword + Space", + color: "Color", + columnNumber: "Column Number", + commandPrompt: "Command Prompt", + computer: "Computer", + computerManagement: "Computer Management", + controlPanel: "Control Panel", + convertAbsolutePath: "Convert to Absolute Path", + convertRelativePath: "Convert to Relative Path", + copyFullPath: "Copy Full Path", + copyTo: "Copy to", + createShortcut: "Create Shortcut", + ctrlNumberKey: "Ctrl + Number Key", + default: "Default", + defaultIcon: "Default Icon", + delayDisplay: "Delay Display", + delayHide: "Delay Hide", + delete: "Delete", + deleteClassificationPrompt: "Delete current classification?", + deleteIcon: "Delete Icon", + deleteItemPrompt: "Delete current item?", + description: "Description", + display: "Display", + displayMainWindow: "Display Main Interface", + documents: "Documents", + doubleClickOpen: "Double Click Open", + doubleClickTaskbar: "Double Click Taskbar", + downloadImagePrompt1: "Failed to download image.", + downloadImagePrompt2: "The link is not in image format.", + dontPromptAgain: "Don't prompt again", + edgeAutoHide: "Auto Hide at Desktop Edge", + edgeDock: "Edge Dock", + edit: "Edit", + editClassification: "Edit Classification", + editItem: "Edit Item", + editSubclassification: "Edit Subclassification", + emptyRecycleBin: "Empty Recycle Bin", + enable: "Enable", + english: "English", + excludeSearch: "Exclude Search", + exit: "Exit", + explorerMenu: "Explorer Menu", + exportIcon: "Export Icon", + extraLarge: "Extra Large", + feedback: "Feedback", + file: "File", + fileExplorer: "File Explorer", + fixedClassification: "Fixed Classification", + fixedIcon: "Fixed Icon", + fixedPosition: "Fixed Position", + folder: "Folder", + folderPath: "Folder Path", + fontLineHeight: "Font Line Height", + fontMainColor: "Font Main Color", + fontSecondaryColor: "Font Secondary Color", + fontShadow: "Font Shadow", + fontSize: "Font Size", + fontWeight: "Font Weight", + functions: "Functions", + general: "General", + getIcon: "Get Icon", + getURLInformation: "Get URL Information", + globalShortcutKey: "Global Shortcut Key", + hiddenItems: "Hidden Items", + hideEllipses: "Hide Ellipses", + hideLoseFocus: "Hide After Lose Focus", + hideName: "Hide Name", + hideTray: "Hide Tray", + hideWindowCollapseSubClassification: + "Collapse Subclassification when Hide Window", + history: "History", + hover: "Hover", + icon: "Icon", + imageLink: "Image Link", + item: "Item", + itemAddEditPrompt1: + "After selecting the fixed icon, the current project will not participate in refreshing the icon.", + itemAddEditPrompt2: "Leave it blank if there are no special requirements", + itemAddEditPrompt3: "Add successfully.", + itemAddEditPrompt4: "The target does not exist.", + itemAddEditPrompt5: "Failed to obtain URL information.", + itemList: "Item List", + keyword: "Keyword", + keywordSpace: "Leyword + Space", + language: "Language", + large: "Large", + layout: "Layout", + layoutListModeTakeEffect: 'Effective when the layout is in "list" mode.', + layoutTileModeTakeEffect: 'Effective when the layout is in "tile" mode.', + left: "Left", + lineNumber: "Number of Lines", + list: "List", + lock: "Lock", + lockClassification: "Lock Classification", + lockItem: "Lock Item", + lockSize: "Lock Size", + mainColor: "Main Color", + matchCondition: "Match Condition", + medium: "Medium", + middleClick: "Middle Click", + millisecond: "Millisecond", + mode: "Mode", + modifyIcon: "Modify Icon", + mouseHover: "Mouse Hover", + mouseWheel: "Mouse Wheel", + moveTo: "Move to", + multiItems: "Multi Items", + name: "Name", + network: "Network", + networkIcon: "Network Icon", + networkIconPrompt1: "Supports JPG/JPEG/GIF/PNG/ICO/SVG/WEBP format images.", + networkShareCenter: "Network Share Center", + newClassification: "New Classification", + newClassificationName: "New Classification", + newItem: "New Item", + newSubclassification: "New Subclassification", + none: "None", + noRepeat: "No Repeat", + normal: "Normal", + notDisturb: "Not Disturb Mode", + notDisturbPrompt: + "After turning on Do Not Disturb mode, the Dawn Launcher window will not pop up when the computer is in full-screen mode for games or applications.", + notFoundFile: "The file specified cannot be found", + notFoundFolder: "The specified folder cannot be found", + number: "Number", + numberKey: "Number Key", + officialWebsite: "Official Website", + ok: "OK", + open: "Open", + openAfterHideMainInterface: "Hide Main Interface After Open", + openAfterHideQuickSearchWindow: "Hide Window After Open", + openFileLocation: "Open File Location", + openNow: "Open when Only One Item", + openNumber: "Open Count", + parameters: "Parameters", + password: "Password", + pasteIcon: "Paste Icon", + powerOptions: "Power Options", + programsFeatures: "Programs Features", + proxy: "Proxy", + proxyPrompt: + 'Only HTTP proxy is supported. When filling in the "address", you need to include the communication protocol and port, for example: http://127.0.0.1:7890. If there is no username and password, just leave it blank.', + quickSearch: "Quick Search", + recordOpenNumber: "Record Open Count", + recycleBin: "Recycle Bin", + refreshIcon: "Refresh Icon", + registryEditor: "Registry Editor", + remark: "Remark", + rememberSelectionState: "Remember Selection State", + repeat: "Repeat", + resourceMonitor: "Resource Monitor", + restart: "Restart", + restore: "Restore", + restoreDataPrompt: "Failed to restore data.", + rewardSponsor: "Reward&Sponsor", + right: "Right", + roundedCorners: "Rounded Corners", + runAsAdministrator: "Run as Administrator", + runSystemStartup: "Run System Startup", + save: "Save", + search: "Search", + searchSource: "Search Source", + secondaryColor: "Secondary Color", + select: "Select", + selectAll: "Select All", + selectItem: "Select Item", + services: "Services", + setClassificationIcon: "Set Classification Icon", + setIcon: "Set Icon", + settings: "Settings", + shortcutKey: "Shortcut Key", + shortcutKeyPrompt1: + "The shortcut keys are incomplete, please improve the shortcut keys.", + shortcutKeyPrompt2: (value: string) => { + return ( + "There is a conflict with the " + + value + + " classification shortcut keys, please reset." + ); + }, + shortcutKeyPrompt3: (value: string) => { + return ( + "There is a conflict with the " + + value + + " item shortcut keys, please reset." + ); + }, + shortcutKeyPrompt4: + 'It conflicts with the "Show/Hide" shortcut key in "Settings-General", please reset it.', + shortcutKeyPrompt5: + 'It conflicts with the "Search" shortcut key in "Settings-General", please reset it.', + shortcutKeyPrompt6: + 'It conflicts with the "Show/Hide" shortcut key in "Settings-Quick Search", please reset it.', + show: "Show", + showFollowMousePosition: "Follows Mouse Position on Display", + showHide: "Show/Hide", + showOnlyFiles: "Show Only Files", + showOnlyFolders: "Show Only Folders", + shutdown: "Shutdown关机", + simplifiedChinese: "Simplified Chinese", + size: "Size", + sleep: "Sleep", + small: "Small", + sort: "Sort", + startLocation: "Start Location", + startMenu: "Start Menu", + startup: "Startup", + startupTray: "Minimize to System Tray on Startup", + subclassification: "Subclassification", + svgIcon: "SVG Icon", + svgIconPrompt1: + 'After entering the SVG code, you need to click the "Check Code" button first.', + switch: "Switch", + switchClassificationCollapseOtherSubClassification: + "Collapse Other Subclassification on Classification Switch", + switchEnglish: "Switch to English Input on Window Display", + system: "System", + target: "Target", + taskManager: "Task Manager", + theme: "Theme", + timeInterval: "Time Interval", + tile: "Tile", + title: "Title", + top: "Top", + traditionalChinese: "Traditional Chinese", + turnOffMonitor: "Turn Off Monitor", + unlockClassification: "Unlock Classification", + unlockItem: "Unlock Item", + uploadIcon: "Upload Icon", + url: "URL", + useItemOpen: "Use This Item to Open Dragged Files", + useProxy: "Use Proxy", + useQuickSearch: "Use Quick Search", + username: "Username", + update: "Update", + webSearch: "Web Search", + webSearchModePrompt1: + 'Enter "Colon + Keyword + Space" or "Keyword + Space" to use a web search, such as using Google search, enter ":g" or "g", and then press the space bar to enter web search mode.', + webSearchModePrompt2: "{w} is the search keyword.", + width: "Width", + window: "Window", + zoom: "Zoom", +}; + +/** + * 获取语言 + * @param language + * @returns + */ +function getLanguage(language: string | null) { + if (language === "SimplifiedChinese") { + return simplifiedChinese; + } else if (language === "TraditionalChinese") { + return traditionalChinese; + } else if (language === "English") { + return english; + } + return simplifiedChinese; +} + +export { getLanguage }; diff --git a/commons/data/theme.d.ts b/commons/data/theme.d.ts new file mode 100644 index 0000000..456064b --- /dev/null +++ b/commons/data/theme.d.ts @@ -0,0 +1,4 @@ +// 无用,为了tsc编译通过 +import { Theme } from "../../types/setting"; + +export const themeList: Array; diff --git a/commons/data/theme.ts b/commons/data/theme.ts new file mode 100644 index 0000000..4d25df2 --- /dev/null +++ b/commons/data/theme.ts @@ -0,0 +1,86 @@ +import { Theme } from "../../types/setting"; + +const themeList: Array = [ + { + name: "#FFFFFF", + mainFontColor: "#505050FF", + secondFontColor: "#505050FF", + mainBackgroundColor: "#FFFFFFFF", + secondBackgroundColor: "#DCDEDFFF", + borderColor: "#F0F0F0FF", + }, + { + name: "#2B2B2B", + mainFontColor: "#BBBBBBFF", + secondFontColor: "#BBBBBBFF", + mainBackgroundColor: "#2B2B2BFF", + secondBackgroundColor: "#3C3F41FF", + borderColor: "#3C3F41FF", + }, + { + name: "#508CC8", + mainFontColor: "#FFFFFFFF", + secondFontColor: "#FFFFFFFF", + mainBackgroundColor: "#508CC8FF", + secondBackgroundColor: "#6FA0D2FF", + borderColor: "#6FA0D2FF", + }, + { + name: "#024351", + mainFontColor: "#FFFFFFFF", + secondFontColor: "#FFFFFFFF", + mainBackgroundColor: "#024351FF", + secondBackgroundColor: "#025A6CFF", + borderColor: "#025A6CFF", + }, + { + name: "#516FA3", + mainFontColor: "#FFFFFFFF", + secondFontColor: "#FFFFFFFF", + mainBackgroundColor: "#516FA3FF", + secondBackgroundColor: "#91A8D0FF", + borderColor: "#91A8D0FF", + }, + { + name: "#45326E", + mainFontColor: "#FFFFFFFF", + secondFontColor: "#FFFFFFFF", + mainBackgroundColor: "#45326EFF", + secondBackgroundColor: "#5F4B8BFF", + borderColor: "#5F4B8BFF", + }, + { + name: "#693030", + mainFontColor: "#FFFFFFFF", + secondFontColor: "#FFFFFFFF", + mainBackgroundColor: "#693030FF", + secondBackgroundColor: "#955151FF", + borderColor: "#803A3AFF", + }, + { + name: "#9F2F4A", + mainFontColor: "#FFFFFFFF", + secondFontColor: "#FFFFFFFF", + mainBackgroundColor: "#9F2F4AFF", + secondBackgroundColor: "#EA6F8CFF", + borderColor: "#AD3350FF", + }, + { + name: "#000000,#FFDB00", + mainFontColor: "#B3B3B3FF", + secondFontColor: "#000000FF", + mainBackgroundColor: "#000000FF", + secondBackgroundColor: "#FFDB00FF", + borderColor: "#1D1D1DFF", + }, + { + name: "#000000,#FFFFFF", + mainFontColor: "#B3B3B3FF", + secondFontColor: "#000000FF", + mainBackgroundColor: "#000000FF", + secondBackgroundColor: "#FFFFFFFF", + borderColor: "#1D1D1DFF", + }, +]; + +export { themeList }; diff --git a/commons/data/webSearchSource.d.ts b/commons/data/webSearchSource.d.ts new file mode 100644 index 0000000..155e4dc --- /dev/null +++ b/commons/data/webSearchSource.d.ts @@ -0,0 +1,4 @@ +// 无用,为了tsc编译通过 +import { WebSearchSource } from "../../types/setting"; + +export const webSearchSourceList: Array; diff --git a/commons/data/webSearchSource.ts b/commons/data/webSearchSource.ts new file mode 100644 index 0000000..7d2efd9 --- /dev/null +++ b/commons/data/webSearchSource.ts @@ -0,0 +1,41 @@ +import { WebSearchSource } from "../../types/setting"; + +const webSearchSourceList: Array = [ + { + id: 1, + keyword: "g", + name: "Google", + url: "https://www.google.com/search?q={w}", + description: null, + }, + { + id: 2, + keyword: "b", + name: "Baidu", + url: "https://www.baidu.com/s?wd={w}", + description: null, + }, + { + id: 3, + keyword: "bing", + name: "Bing", + url: "https://cn.bing.com/search?q={w}", + description: null, + }, + { + id: 4, + keyword: "so", + name: "360", + url: "https://www.so.com/s?q={w}", + description: null, + }, + { + id: 5, + keyword: "sogou", + name: "Sogou", + url: "https://www.sogou.com/web?query={w}", + description: null, + }, +]; + +export { webSearchSourceList }; diff --git a/commons/utils/common.d.ts b/commons/utils/common.d.ts new file mode 100644 index 0000000..47e6409 --- /dev/null +++ b/commons/utils/common.d.ts @@ -0,0 +1,71 @@ +// 无用,为了tsc编译通过 +import { Classification, ClassificationData } from "../../types/classification"; +import { CommonItem, CommonItemData, Item, ItemData } from "../../types/item"; + +export function convert(from: F): T; +export function isAbsolutePath(path: string): boolean; +export function deleteExtname(name: string | null): string | null; +export function getFileName(path: string | null): string | null; +export function getFileExtname(path: string | null): string | null; +export function newClassification(data: { + id?: number | null; + parentId?: number | null; + name?: string | null; + type?: number | null; + data?: ClassificationData | null; + shortcutKey?: string | null; + globalShortcutKey?: boolean | null; + order?: number | null; + childList?: Array | null; +}): Classification; +export function newClassificationData(data: { + icon?: string | null; + associateFolderPath?: string | null; + associateFolderHiddenItems?: string | null; + itemLayout?: "default" | "tile" | "list"; + itemSort?: "default" | "initial" | "openNumber" | "lastOpen"; + itemColumnNumber?: number | null; + itemIconSize?: number | null; + itemShowOnly?: "default" | "file" | "folder"; + fixed?: boolean | null; + aggregateItemCount?: number | null; +}): ClassificationData; +export function newCommonItem(data: { + id?: number | null; + name?: string | null; + data?: CommonItemData | null; + order?: number | null; +}): CommonItem; +export function newCommonItemData(data: { + target?: string | null; + params?: string | null; + icon?: string | null; + htmlIcon?: string | null; +}): CommonItemData; +export function newItem(data: { + id?: number | null; + classificationId: number; + name?: string | null; + type?: number | null; + data?: ItemData | null; + shortcutKey?: string | null; + globalShortcutKey?: boolean | null; + order?: number | null; +}): Item; +export function newItemData(data: { + startLocation?: string | null; + target?: string | null; + params?: string | null; + runAsAdmin?: boolean | null; + icon?: string | null; + htmlIcon?: string | null; + remark?: string | null; + iconBackgroundColor?: boolean | null; + fixedIcon?: boolean | null; + openNumber?: number | null; + lastOpen?: number | null; + quickSearchOpenNumber?: number | null; + quickSearchLastOpen?: number | null; + multiItemsTimeInterval?: number | null; +}): ItemData; +export function getItemName(name: string | null): string; diff --git a/commons/utils/common.ts b/commons/utils/common.ts new file mode 100644 index 0000000..164f482 --- /dev/null +++ b/commons/utils/common.ts @@ -0,0 +1,308 @@ +import { Classification, ClassificationData } from "../../types/classification"; +import { CommonItem, CommonItemData, Item, ItemData } from "../../types/item"; + +/** + * 转换 + */ +function convert(from: F): T { + return JSON.parse(JSON.stringify(from)) as T; +} + +/** + * 是否是绝对路径 + * @param path + * @returns + */ +function isAbsolutePath(path: string) { + const regex = /^[a-zA-Z]:\\/; + return regex.test(path); +} + +/** + * 删除文件后缀 + * @param name + * @returns + */ +function deleteExtname(name: string | null) { + if (name && name.trim() !== "") { + if (name.indexOf(".") > 0) { + return name.substring(0, name.lastIndexOf(".")); + } else { + return name; + } + } + return null; +} + +/** + * 获取文件名 + * @param path + * @returns + */ +function getFileName(path: string | null) { + if (path && path.trim() !== "") { + let split = path.split("\\"); + return split[split.length - 1]; + } else { + return null; + } +} + +/** + * 获取文件拓展名 + * @param path + * @returns + */ +function getFileExtname(path: string | null) { + // 获取文件名 + let fileName = getFileName(path); + if (fileName && fileName.trim() !== "") { + if (fileName.indexOf(".") >= 0) { + return fileName.substring(fileName.lastIndexOf(".") + 1).toLowerCase(); + } + } + return null; +} + +/** + * 初始化CLassification + * @returns + */ +function newClassification({ + id = null, + parentId = null, + name = null, + type = null, + data = null, + shortcutKey = null, + globalShortcutKey = false, + order = null, + childList = null, +}: { + id?: number | null; + parentId?: number | null; + name?: string | null; + type?: number | null; + data?: ClassificationData | null; + shortcutKey?: string | null; + globalShortcutKey?: boolean | null; + order?: number | null; + childList?: Array | null; +}): Classification { + return { + id: id ?? 0, + parentId: parentId ?? null, + name: name ?? null, + type: type ?? 0, + data: data ? newClassificationData(data) : newClassificationData({}), + shortcutKey: shortcutKey ?? null, + globalShortcutKey: globalShortcutKey ?? false, + order: order ?? 0, + childList: childList ?? null, + }; +} + +/** + * 初始化ClassificationData + * @returns + */ +function newClassificationData({ + icon = null, + associateFolderPath = null, + associateFolderHiddenItems = null, + itemLayout = "default", + itemSort = "default", + itemColumnNumber = null, + itemIconSize = null, + itemShowOnly = "default", + fixed = false, + aggregateItemCount = 50, + excludeSearch = false, +}: { + icon?: string | null; + associateFolderPath?: string | null; + associateFolderHiddenItems?: string | null; + itemLayout?: "default" | "tile" | "list"; + itemSort?: "default" | "initial" | "openNumber" | "lastOpen"; + itemColumnNumber?: number | null; + itemIconSize?: number | null; + itemShowOnly?: "default" | "file" | "folder"; + fixed?: boolean | null; + aggregateItemCount?: number | null; + excludeSearch?: boolean | null; +}): ClassificationData { + return { + icon: icon ?? null, + associateFolderPath: associateFolderPath ?? null, + associateFolderHiddenItems: associateFolderHiddenItems ?? null, + itemLayout: itemLayout ?? "default", + itemSort: itemSort ?? "default", + itemColumnNumber: itemColumnNumber ?? null, + itemIconSize: itemIconSize ?? null, + itemShowOnly: itemShowOnly ?? "default", + fixed: fixed ?? false, + aggregateItemCount: aggregateItemCount ?? 50, + excludeSearch: excludeSearch ?? false, + }; +} + +/** + * 初始化CommonItem + * @returns + */ +function newCommonItem({ + id = null, + name = null, + data = null, + order = null, +}: { + id?: number | null; + name?: string | null; + data?: CommonItemData | null; + order?: number | null; +}): CommonItem { + return { + id: id ?? 0, + name: name ?? null, + data: data ? newCommonItemData(data) : newCommonItemData({}), + order: order ?? 0, + }; +} + +/** + * 初始化CommonItemData + * @returns + */ +function newCommonItemData({ + target = null, + params = null, + icon = null, + htmlIcon = null, +}: { + target?: string | null; + params?: string | null; + icon?: string | null; + htmlIcon?: string | null; +}): CommonItemData { + return { + target: target ?? null, + params: params ?? null, + icon: icon ?? null, + htmlIcon: htmlIcon ?? null, + }; +} + +/** + * 初始化Item + * @returns + */ +function newItem({ + id = null, + classificationId, + name = null, + type = null, + data = null, + shortcutKey = null, + globalShortcutKey = false, + order = null, +}: { + id?: number | null; + classificationId: number; + name?: string | null; + type?: number | null; + data?: ItemData | null; + shortcutKey?: string | null; + globalShortcutKey?: boolean | null; + order?: number | null; +}): Item { + return { + id: id ?? 0, + classificationId, + name: name ?? null, + type: type ?? 0, + data: data ? newItemData(data) : newItemData({}), + shortcutKey: shortcutKey ?? null, + globalShortcutKey: globalShortcutKey ?? false, + order: order ?? 0, + }; +} + +/** + * 初始化ItemData + * @returns + */ +function newItemData({ + startLocation = null, + target = null, + params = null, + runAsAdmin = false, + icon = null, + htmlIcon = null, + remark = null, + iconBackgroundColor = false, + fixedIcon = false, + openNumber = 0, + lastOpen = 0, + quickSearchOpenNumber = 0, + quickSearchLastOpen = 0, + multiItemsTimeInterval = 0, +}: { + startLocation?: string | null; + target?: string | null; + params?: string | null; + runAsAdmin?: boolean | null; + icon?: string | null; + htmlIcon?: string | null; + remark?: string | null; + iconBackgroundColor?: boolean | null; + fixedIcon?: boolean | null; + openNumber?: number | null; + lastOpen?: number | null; + quickSearchOpenNumber?: number | null; + quickSearchLastOpen?: number | null; + multiItemsTimeInterval?: number | null; +}): ItemData { + return { + startLocation: startLocation ?? null, + target: target ?? null, + params: params ?? null, + runAsAdmin: runAsAdmin ?? false, + icon: icon ?? null, + htmlIcon: htmlIcon ?? null, + remark: remark ?? null, + iconBackgroundColor: iconBackgroundColor ?? false, + fixedIcon: fixedIcon ?? false, + openNumber: openNumber ?? 0, + lastOpen: lastOpen ?? 0, + quickSearchOpenNumber: quickSearchOpenNumber ?? 0, + quickSearchLastOpen: quickSearchLastOpen ?? 0, + multiItemsTimeInterval: multiItemsTimeInterval ?? 0, + }; +} + +/** + * 获取项目名 + * @param name + * @returns + */ +function getItemName(name: string | null) { + if (name) { + return name.replace(/\\n/g, " "); + } + return ""; +} + +export { + convert, + isAbsolutePath, + deleteExtname, + getFileName, + getFileExtname, + newClassification, + newClassificationData, + newCommonItem, + newCommonItemData, + newItem, + newItemData, + getItemName, +}; diff --git a/commons/utils/setting.d.ts b/commons/utils/setting.d.ts new file mode 100644 index 0000000..9be03b8 --- /dev/null +++ b/commons/utils/setting.d.ts @@ -0,0 +1,4 @@ +// 无用,为了tsc编译通过 +import { Setting } from "../../types/setting"; + +export function getSetting(setting: Setting | null): Setting; diff --git a/commons/utils/setting.ts b/commons/utils/setting.ts new file mode 100644 index 0000000..994e74d --- /dev/null +++ b/commons/utils/setting.ts @@ -0,0 +1,378 @@ +import { + Appearance, + Classification, + General, + Item, + Network, + Proxy, + QuickSearch, + Setting, + SubClassification, + Theme, + WebSearch, + WebSearchSource, +} from "../../types/setting"; +import { convert } from "./common"; +import { themeList } from "../data/theme"; +import { webSearchSourceList } from "../data/webSearchSource"; + +/** + * 常规 + * @returns + */ +function getGeneral({ + startup = false, + startupTray = false, + showHideShortcutKey = null, + language = "SimplifiedChinese", + alwaysTop = false, + edgeAdsorb = true, + edgeAutoHide = false, + lockSize = false, + hideLoseFocus = false, + hideTray = false, + fixedPosition = false, + alwaysCenter = false, + showHideMouseWheelClick = false, + showFollowMousePosition = false, + notDisturb = false, + showHideDoubleClickTaskbar = false, + delayDisplayMs = 0, + delayHideMs = 0, + switchEnglish = false, + searchShowHideShortcutKey = "TAB", + checkUpdates = true, +}: { + startup?: boolean | null; + startupTray?: boolean | null; + showHideShortcutKey?: string | null; + language?: string | null; + alwaysTop?: boolean | null; + edgeAdsorb?: boolean | null; + edgeAutoHide?: boolean | null; + lockSize?: boolean | null; + hideLoseFocus?: boolean | null; + hideTray?: boolean | null; + fixedPosition?: boolean | null; + alwaysCenter?: boolean | null; + showHideMouseWheelClick?: boolean | null; + showFollowMousePosition?: boolean | null; + notDisturb?: boolean | null; + showHideDoubleClickTaskbar?: boolean | null; + delayDisplayMs?: number | null; + delayHideMs?: number | null; + switchEnglish?: boolean | null; + searchShowHideShortcutKey?: string | null; + checkUpdates?: boolean | null; +}): General { + return { + startup: startup ?? false, + startupTray: startupTray ?? false, + showHideShortcutKey: showHideShortcutKey ?? null, + language: language ?? "SimplifiedChinese", + alwaysTop: alwaysTop ?? false, + edgeAdsorb: edgeAdsorb ?? true, + edgeAutoHide: edgeAutoHide ?? false, + lockSize: lockSize ?? false, + hideLoseFocus: hideLoseFocus ?? false, + hideTray: hideTray ?? false, + fixedPosition: fixedPosition ?? false, + alwaysCenter: alwaysCenter ?? false, + showHideMouseWheelClick: showHideMouseWheelClick ?? false, + showFollowMousePosition: showFollowMousePosition ?? false, + notDisturb: notDisturb ?? false, + showHideDoubleClickTaskbar: showHideDoubleClickTaskbar ?? false, + delayDisplayMs: delayDisplayMs ?? 0, + delayHideMs: delayHideMs ?? 0, + switchEnglish: switchEnglish ?? false, + searchShowHideShortcutKey: searchShowHideShortcutKey ?? null, + checkUpdates: checkUpdates ?? true, + }; +} + +/** + * 外观 + * @returns + */ +function getAppearance({ + theme = convert(themeList[0]), + transparency = 1, + backgroundImage = null, + backgroundImageTransparency = 1, + backgroundImageMode = "repeat", + backgroundImagePosition = "default", + fontShadow = false, + fontShadowColor = "#000000", + windowRounded = false, + title = "Dawn Launcher", +}: { + theme?: Theme | null; + transparency?: number | null; + backgroundImage?: string | null; + backgroundImageTransparency?: number | null; + backgroundImageMode?: string | null; + backgroundImagePosition?: string | null; + fontShadow?: boolean | null; + fontShadowColor?: string | null; + windowRounded?: boolean | null; + title?: string | null; +}): Appearance { + return { + theme: theme ?? convert(themeList[0]), + transparency: transparency ?? 1, + backgroundImage: backgroundImage ?? null, + backgroundImageTransparency: backgroundImageTransparency ?? 1, + backgroundImageMode: backgroundImageMode ?? "repeat", + backgroundImagePosition: backgroundImagePosition ?? "default", + fontShadow: fontShadow ?? false, + fontShadowColor: fontShadowColor ?? "#000000", + windowRounded: windowRounded ?? false, + title: title ?? "Dawn Launcher", + }; +} + +/** + * 分类 + * @returns + */ +function getClassification({ + width = 140, + layout = "left", + mouseHover = false, + mouseHoverMs = 0, + mouseWheel = false, + rememberSelectionState = false, + nameAlign = "left", + mode = "normal", + autoSwitchClassification = false, + hideWindowCollapseSubClassification = false, + switchClassificationCollapseOtherSubClassification = false, +}: { + width?: number | null; + layout?: string | null; + mouseHover?: boolean | null; + mouseHoverMs?: number | null; + mouseWheel?: boolean | null; + rememberSelectionState?: boolean | null; + nameAlign?: string | null; + mode?: string | null; + autoSwitchClassification?: boolean | null; + hideWindowCollapseSubClassification?: boolean | null; + switchClassificationCollapseOtherSubClassification?: boolean | null; +}): Classification { + return { + width: width ?? 140, + layout: layout ?? "left", + mouseHover: mouseHover ?? false, + mouseHoverMs: mouseHoverMs ?? 0, + mouseWheel: mouseWheel ?? false, + rememberSelectionState: rememberSelectionState ?? false, + nameAlign: nameAlign ?? "left", + mode: mode ?? "normal", + autoSwitchClassification: autoSwitchClassification ?? false, + hideWindowCollapseSubClassification: + hideWindowCollapseSubClassification ?? false, + switchClassificationCollapseOtherSubClassification: + switchClassificationCollapseOtherSubClassification ?? false, + }; +} + +/** + * 子分类 + * @returns + */ +function getSubClassification({ + itemAreaNameFontSize = 14, + itemAreaNameFontWeight = 700, + itemAreaNameFontLineHeight = 1.25, +}: { + itemAreaNameFontSize?: number | null; + itemAreaNameFontWeight?: number | null; + itemAreaNameFontLineHeight?: number | null; +}): SubClassification { + return { + itemAreaNameFontSize: itemAreaNameFontSize ?? 14, + itemAreaNameFontWeight: itemAreaNameFontWeight ?? 700, + itemAreaNameFontLineHeight: itemAreaNameFontLineHeight ?? 1.25, + }; +} + +/** + * 项目 + * @returns + */ +function getItem({ + layout = "tile", + iconSize = 40, + doubleClickOpen = false, + openAfterHideMainInterface = false, + useItemOpen = false, + openNumber = false, + hideItemName = false, + hideEllipsis = false, + itemNameRowCount = 2, + width = 85, + columnNumber = 1, + checkInvalidItem = false, + fontSize = 14, + fontWeight = 400, + fontLineHeight = 1.25, +}: { + layout?: string | null; + iconSize?: number | null; + doubleClickOpen?: boolean | null; + openAfterHideMainInterface?: boolean | null; + useItemOpen?: boolean | null; + openNumber?: boolean | null; + hideItemName?: boolean | null; + hideEllipsis?: boolean | null; + itemNameRowCount?: number | null; + width?: number | null; + columnNumber?: number | null; + checkInvalidItem?: boolean | null; + fontSize?: number | null; + fontWeight?: number | null; + fontLineHeight?: number | null; +}): Item { + return { + layout: layout ?? "tile", + iconSize: iconSize ?? 40, + doubleClickOpen: doubleClickOpen ?? false, + openAfterHideMainInterface: openAfterHideMainInterface ?? false, + useItemOpen: useItemOpen ?? false, + openNumber: openNumber ?? false, + hideItemName: hideItemName ?? false, + hideEllipsis: hideEllipsis ?? false, + itemNameRowCount: itemNameRowCount ?? 2, + width: width ?? 85, + columnNumber: columnNumber ?? 1, + checkInvalidItem: checkInvalidItem ?? false, + fontSize: fontSize ?? 14, + fontWeight: fontWeight ?? 400, + fontLineHeight: fontLineHeight ?? 1.25, + }; +} + +/** + * 快速搜索 + * @returns + */ +function getQuickSearch({ + enable = true, + showHideShortcutKey = "Alt + Space", + openShortcutKey = "none", + hideLoseFocus = false, + openNow = false, + showHistory = false, + showHistorySort = "lastOpen", + useItemOpen = false, + openAfterHideQuickSearchWindow = true, + matchConditionsRemark = false, +}: { + enable?: boolean | null; + showHideShortcutKey?: string | null; + openShortcutKey?: string | null; + hideLoseFocus?: boolean | null; + openNow?: boolean | null; + showHistory?: boolean | null; + showHistorySort?: string | null; + useItemOpen?: boolean | null; + openAfterHideQuickSearchWindow?: boolean | null; + matchConditionsRemark?: boolean | null; +}): QuickSearch { + return { + enable: enable ?? true, + showHideShortcutKey: showHideShortcutKey ?? "Alt + Space", + openShortcutKey: openShortcutKey ?? "none", + hideLoseFocus: hideLoseFocus ?? false, + openNow: openNow ?? false, + showHistory: showHistory ?? false, + showHistorySort: showHistorySort ?? "lastOpen", + useItemOpen: useItemOpen ?? false, + openAfterHideQuickSearchWindow: openAfterHideQuickSearchWindow ?? true, + matchConditionsRemark: matchConditionsRemark ?? false, + }; +} + +/** + * 网络搜索 + * @returns + */ +function getWebSearch({ + mode = 0, + searchSourceList = webSearchSourceList, +}: { + mode?: number | null; + searchSourceList?: Array | null; +}): WebSearch { + return { + mode: mode ?? 0, + searchSourceList: searchSourceList ?? webSearchSourceList, + }; +} + +/** + * 网络 + * @returns + */ +function getNetwork({ + useProxy = false, + proxy = getProxy({}), +}: { + useProxy?: boolean | null; + proxy?: Proxy | null; +}): Network { + return { + useProxy: useProxy ?? false, + proxy: proxy ? getProxy(proxy) : getProxy({}), + }; +} + +/** + * 代理 + * @returns + */ +function getProxy({ + address = "", + username = null, + password = null, +}: { + address?: string | null; + username?: string | null; + password?: string | null; +}): Proxy { + return { + address: address ?? "", + username: username ?? null, + password: password ?? null, + }; +} + +/** + * 设置 + * @returns + */ +function getSetting(setting: Setting | null): Setting { + return { + general: getGeneral(setting && setting.general ? setting.general : {}), + appearance: getAppearance( + setting && setting.appearance ? setting.appearance : {} + ), + classification: getClassification( + setting && setting.classification ? setting.classification : {} + ), + subClassification: getSubClassification( + setting && setting.subClassification ? setting.subClassification : {} + ), + item: getItem(setting && setting.item ? setting.item : {}), + quickSearch: getQuickSearch( + setting && setting.quickSearch ? setting.quickSearch : {} + ), + webSearch: getWebSearch( + setting && setting.webSearch ? setting.webSearch : {} + ), + network: getNetwork(setting && setting.network ? setting.network : {}), + }; +} + +export { getSetting }; diff --git a/electron-builder.json5 b/electron-builder.json5 new file mode 100644 index 0000000..372ec7c --- /dev/null +++ b/electron-builder.json5 @@ -0,0 +1,35 @@ +/** + * @see https://www.electron.build/configuration/configuration + */ +{ + $schema: "https://raw.githubusercontent.com/electron-userland/electron-builder/master/packages/app-builder-lib/scheme.json", + appId: "com.dawnlauncher.application", + asar: true, + compression: "maximum", + productName: "Dawn Launcher", + directories: { + output: "release/${version}", + }, + asarUnpack: ["**/*.node"], + npmRebuild: false, + files: ["dist", "dist-electron", "native", "!node_modules/**/*"], + win: { + appId: "com.dawnlauncher.application", + target: [ + { + target: "nsis", + arch: ["x64"], + }, + ], + artifactName: "${productName}-Windows-${version}-Setup.${ext}", + icon: "public/logo.ico", + }, + nsis: { + artifactName: "${productName}-${version}.${ext}", + oneClick: false, + allowElevation: true, + allowToChangeInstallationDirectory: true, + createDesktopShortcut: true, + createStartMenuShortcut: true, + }, +} diff --git a/electron/commons/betterSqlite3.ts b/electron/commons/betterSqlite3.ts new file mode 100644 index 0000000..9b768eb --- /dev/null +++ b/electron/commons/betterSqlite3.ts @@ -0,0 +1,40 @@ +import { join, dirname } from "node:path"; +import Database from "better-sqlite3-multiple-ciphers"; +import { getUserDataPath } from "../main/commons"; + +let database: Database.Database; +let cacheDatabase: Database.Database; + +function getDataSqlite3() { + let filename = join(getUserDataPath(), "Data.db"); + database ??= new Database(filename, { + nativeBinding: join( + process.env.NODE_ENV !== "development" ? dirname(process.execPath) : "", + import.meta.env.VITE_BETTER_SQLITE3_BINDING + ), + }); + return database; +} + +function getCacheDataSqlite3() { + let filename = join(getUserDataPath(), "CacheData.db"); + cacheDatabase ??= new Database(filename, { + nativeBinding: join( + process.env.NODE_ENV !== "development" ? dirname(process.execPath) : "", + import.meta.env.VITE_BETTER_SQLITE3_BINDING + ), + }); + return cacheDatabase; +} + +function getCustomDataSqlite3(filePath: string) { + let db = new Database(filePath, { + nativeBinding: join( + process.env.NODE_ENV !== "development" ? dirname(process.execPath) : "", + import.meta.env.VITE_BETTER_SQLITE3_BINDING + ), + }); + return db; +} + +export { getDataSqlite3, getCacheDataSqlite3, getCustomDataSqlite3 }; diff --git a/electron/commons/constants.ts b/electron/commons/constants.ts new file mode 100644 index 0000000..73f1fab --- /dev/null +++ b/electron/commons/constants.ts @@ -0,0 +1,15 @@ +// 网络和共享中心图标 +export let networkSharingCenterIcon = + ""; + +// 计算器图标 +export let calcIcon = + ""; + +// 文件资源管理器图标 +export let fileExplorerIcon = + ""; + +// 电源图标 +export let powerIcon = + ""; diff --git a/electron/commons/logger.ts b/electron/commons/logger.ts new file mode 100644 index 0000000..cf973fb --- /dev/null +++ b/electron/commons/logger.ts @@ -0,0 +1,32 @@ +import { app } from "electron"; +import Logger from "electron-log"; +import { join, dirname } from "node:path"; + +// 名称 +let date = new Date(); +let logName = + date.getFullYear() + + "-" + + (date.getMonth() + 1 < 10 + ? "0" + (date.getMonth() + 1) + : date.getMonth() + 1) + + "-" + + date.getDate(); + +// 日志 +if ( + process.env.NODE_ENV !== "development" && + import.meta.env.VITE_INSTALL === "false" +) { + Logger.transports.file.resolvePathFn = () => + join(dirname(process.execPath), "data", "logs", logName + ".log"); +} else { + Logger.transports.file.resolvePathFn = () => + join(app.getPath("userData"), "logs", logName + ".log"); +} + +export default { + error(content: any) { + Logger.error(content); + }, +}; diff --git a/electron/commons/utilityProcessUtils.ts b/electron/commons/utilityProcessUtils.ts new file mode 100644 index 0000000..93b2e7b --- /dev/null +++ b/electron/commons/utilityProcessUtils.ts @@ -0,0 +1,80 @@ +import { MessageChannelMain, app, utilityProcess } from "electron"; +import { join } from "node:path"; +import { writeFileSync, readFileSync, unlink } from "node:fs"; +import { ChildProcessInfo } from "../types/global"; + +/** + * 子进程 + * @param name + * @param data + */ +function fork(name: string, data: any, callback: Function) { + // 随机数 + let min = 1; + let max = 99999; + let random = Math.floor(Math.random() * (max - min + 1)) + min; + // 子进程 + const { port1, port2 } = new MessageChannelMain(); + const childProcess = utilityProcess.fork(join(__dirname, "worker.js")); + // 存储子进程信息 + if (!global.childProcessMap) { + global.childProcessMap = new Map(); + } + global.childProcessMap.set(childProcess.pid, { + utilityProcess: childProcess, + port1, + port2, + }); + // 获取临时目录 + let temp = app.getPath("temp"); + // 参数文件 + let paramFilePath = + temp + "\\" + random + "." + new Date().getTime() + "." + name + ".txt"; + // 创建文件并写入数据 + writeFileSync(paramFilePath, JSON.stringify(data), { + encoding: "utf-8", + }); + // 发送消息 + let params = { + name, + data: { + filePath: paramFilePath, + }, + }; + // 创建子进程完成后发送消息 + childProcess.once("spawn", () => { + childProcess.postMessage(JSON.stringify(params), [port1]); + }); + // 等待接收消息 + port2.start(); + port2.once("message", (event) => { + let data: string = event.data; + try { + if (data !== "exit") { + // 读取文件 + let res = readFileSync(data, { encoding: "utf-8" }); + // 删除文件 + unlink(data, () => {}); + // 回调 + callback(JSON.parse(res)); + } + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + } finally { + // 关闭子进程 + childProcess.kill(); + } + }); + // 监听关闭子进程 + childProcess.once("exit", () => { + // 关闭通道 + port1.close(); + port2.close(); + // 删除信息 + global.childProcessMap.delete(childProcess.pid); + }); +} + +export { fork }; diff --git a/electron/commons/utils.ts b/electron/commons/utils.ts new file mode 100644 index 0000000..96acc95 --- /dev/null +++ b/electron/commons/utils.ts @@ -0,0 +1,155 @@ +import { resolve, dirname, parse } from "node:path"; +import { isAbsolutePath } from "../../commons/utils/common"; +import mime from "mime"; +import { readFileSync } from "node:fs"; + +// 图标格式 +const iconExts = ["jpg", "jpeg", "png", "gif", "ico", "svg", "webp"]; + +/** + * 随机user-agent + */ +function getRandomUserAgent() { + const userAgents = [ + "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36", + "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36", + "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:89.0) Gecko/20100101 Firefox/89.0", + "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Firefox/89.0", + "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Safari/537.36", + "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Safari/537.36", + "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36 Edg/91.0.864.59", + "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36 Edg/91.0.864.59", + "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:89.0) Gecko/20100101 Firefox/89.0", + "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Firefox/89.0", + "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36 OPR/76.0.4017.123", + "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36 OPR/76.0.4017.123", + "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:89.0) Gecko/20100101 Firefox/89.0", + "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Firefox/89.0", + ]; + const randomIndex = Math.floor(Math.random() * userAgents.length); + return userAgents[randomIndex]; +} + +/** + * 组装参数 + * @param paramsMap + * @returns + */ +function getURLParams(paramsMap: Map) { + let res = ""; + if (paramsMap.size > 0) { + res += "?"; + let params: string | null = null; + paramsMap.forEach((value, key) => { + if (params) { + params += "&" + key + "=" + value; + } else { + params = key + "=" + value; + } + }); + res += params; + } + return res; +} + +/** + * 解析环境变量 + * @param path + */ +function parseEnvPath(path: string) { + // 尝试解析路径中的环境变量 + let parsedPath = parse(path); + let isBase = false; + let pathArr: Array = []; + if (!parsedPath.dir || parsedPath.dir.trim() === "") { + pathArr = parsedPath.base.split("\\"); + isBase = true; + } else { + pathArr = parsedPath.dir.split("\\"); + } + // 新路径 + let newPathArr: Array = []; + // 正则提取环境变量 %{path}% 提取中间的path名称 + const pattern = /^%.*%$/; + for (let string of pathArr) { + // 符合环境变量正则 + if (pattern.test(string)) { + // 尝试获取 + let env: string | null = global.addon.getEnvByName( + string.substring(1, string.length - 1) + ); + // 如果提取到环境变量了就使用环境变量路径,如果没有就使用原路径 + if (env && env.trim() !== "") { + newPathArr.push(env); + } else { + newPathArr.push(string); + } + } else { + // 没有匹配到正则,使用原路径 + newPathArr.push(string); + } + } + // 根据上方解析,如果拥有dir的话,需要追加base变量 + if (!isBase) { + newPathArr.push(parsedPath.base); + } + // 拼接并返回 + return newPathArr.join("\\"); +} + +/** + * 获取绝对路径 + * @param path + */ +function getAbsolutePath(path: string) { + if (!isAbsolutePath(path)) { + // 尝试解析环境变量 + let newPath = parseEnvPath(path); + // 判断解析之后的路径是否是绝对路径 + if (isAbsolutePath(newPath)) { + return newPath; + } else { + return resolve( + process.env.NODE_ENV === "development" + ? resolve(".") + : dirname(process.execPath), + path + ); + } + } + return path; +} + +/** + * 获取文件图标 + * @param filePath + */ +function getFileIcon(filePath: string | null) { + // 图标 + let icon: string | null = null; + if (filePath) { + // 获取后缀 + let ext = mime.getExtension(mime.getType(filePath)); + if (iconExts.includes(ext)) { + // 读取文件 + let buffer = readFileSync(filePath); + icon = + "data:" + + mime.getType(filePath) + + ";base64," + + buffer.toString("base64"); + } else { + // 获取图标 + icon = global.addon.getFileIcon(filePath); + } + } + return icon; +} + +export { + getURLParams, + getAbsolutePath, + getFileIcon, + iconExts, + getRandomUserAgent, +}; diff --git a/electron/electron-env.d.ts b/electron/electron-env.d.ts new file mode 100644 index 0000000..b4c4211 --- /dev/null +++ b/electron/electron-env.d.ts @@ -0,0 +1,11 @@ +/// + +declare namespace NodeJS { + interface ProcessEnv { + VSCODE_DEBUG?: 'true' + DIST_ELECTRON: string + DIST: string + /** /dist/ or /public/ */ + VITE_PUBLIC: string + } +} diff --git a/electron/main/about/index.ts b/electron/main/about/index.ts new file mode 100644 index 0000000..3038e2f --- /dev/null +++ b/electron/main/about/index.ts @@ -0,0 +1,58 @@ +import { BrowserWindow, shell } from "electron"; +import { closeWindow, getMainBackgorunColor } from "../commons"; +import { join } from "node:path"; + +// 窗口 +let aboutWindow: BrowserWindow | null = null; + +/** + * 关于窗口 + */ +function createWindow() { + // 如果窗口存在先关闭窗口 + closeWindow(aboutWindow); + // 创建窗口 + aboutWindow = global.aboutWindow = new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.mainWindow, + height: 212, + width: 600, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + if (process.env.VITE_DEV_SERVER_URL) { + aboutWindow.loadURL(process.env.VITE_DEV_SERVER_URL + "About"); + } else { + aboutWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/About", + }); + } + aboutWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + aboutWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + aboutWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + aboutWindow.setEnabled(true); + }, 100); + return true; + }); +} + +export { createWindow }; diff --git a/electron/main/about/ipcEvent.ts b/electron/main/about/ipcEvent.ts new file mode 100644 index 0000000..4872fc5 --- /dev/null +++ b/electron/main/about/ipcEvent.ts @@ -0,0 +1,20 @@ +import { ipcMain } from "electron"; +import { createWindow } from "."; +import { closeWindow } from "../commons"; + +export default function () { + // 创建窗口 + ipcMain.on("createAboutWindow", (event, args) => { + createWindow(); + }); + // 显示窗口 + ipcMain.on("showAboutWindow", (event, args) => { + if (global.aboutWindow) { + global.aboutWindow.show(); + } + }); + // 关闭窗口 + ipcMain.on("closeAboutWindow", (event, args) => { + closeWindow(global.aboutWindow); + }); +} diff --git a/electron/main/classification/data.ts b/electron/main/classification/data.ts new file mode 100644 index 0000000..bd516a2 --- /dev/null +++ b/electron/main/classification/data.ts @@ -0,0 +1,397 @@ +import { deleteAssociateFolderWatcher } from "."; +import { + Classification, + ClassificationData, +} from "../../../types/classification"; +import { + newClassification, + newClassificationData, +} from "../../../commons/utils/common"; +import { deleteByClassificationId, updateClassificationId } from "../item/data"; +import { getDataSqlite3 } from "../../commons/betterSqlite3"; + +// 获取数据库 +let db = getDataSqlite3(); + +// 分类表名 +let classificationTableName = "classification"; + +// 查询字段 +let selectColumn = + "id, parent_id parentId, name, type, data, shortcut_key shortcutKey, global_shortcut_key globalShortcutKey, `order`"; + +/** + * 分类 + */ +function getClassification(row: any): Classification { + return newClassification({ + id: row.id, + parentId: row.parentId, + name: row.name, + type: row.type, + data: newClassificationData(JSON.parse(row.data)), + shortcutKey: row.shortcutKey, + globalShortcutKey: row.globalShortcutKey === 1, + order: row.order, + }); +} + +/** + * 初始化 + */ +function init() { + // sql + let sql = `CREATE TABLE IF NOT EXISTS ${classificationTableName} ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + parent_id INTEGER, + name TEXT NOT NULL, + type INTEGER NOT NULL, + data TEXT NOT NULL, + shortcut_key TEXT, + global_shortcut_key INTEGER NOT NULL, + \`order\` INTEGER NOT NULL)`; + // 运行 + db.exec(sql); + // 查询有多少条数据 + sql = `SELECT COUNT(id) count FROM ${classificationTableName}`; + let row: any = db.prepare(sql).get(); + let count = row.count as number; + if (count === 0) { + // 新增分类 + add(null, global.language.newClassificationName, null, false); + } +} + +/** + * 列表 + * @param parentId + */ +function list(parentId: number | null = null) { + // 参数 + let params = []; + // sql + let sql = `SELECT ${selectColumn} FROM ${classificationTableName}`; + if (parentId) { + sql += " WHERE parent_id = ?"; + params.push(parentId); + } + sql += " ORDER BY `order` ASC"; + // 查询 + let list = db.prepare(sql).all(params); + // 返回 + return list.map((row) => { + return getClassification(row); + }); +} + +/** + * 添加 + * @param parentId + * @param name + * @param shortcutKey + * @param globalShortcutKey + * @returns + */ +function add( + parentId: number | null, + name: string, + shortcutKey: string | null, + globalShortcutKey: boolean, + data: ClassificationData = newClassificationData({}), + type: number = 0 +): Classification | null { + // 获取序号 + let newOrder = getMaxOrder(parentId) + 1; + // SQL + let sql = `INSERT INTO ${classificationTableName} (parent_id, name, type, data, shortcut_key, global_shortcut_key, \`order\`) VALUES (?, ?, ?, ?, ?, ?, ?)`; + // 运行 + let id = db + .prepare(sql) + .run( + parentId, + name, + type, + JSON.stringify(data), + shortcutKey, + globalShortcutKey ? 1 : 0, + newOrder + ).lastInsertRowid as number; + if (id) { + let classification = newClassification({ + id, + name, + parentId, + type, + data, + shortcutKey, + globalShortcutKey, + order: newOrder, + }); + // 如果是添加子分类,将父级分类下的项目移动到新建的子分类中 + if (parentId) { + updateClassificationId(parentId, id); + } + return classification; + } + return null; +} + +/** + * 更新 + * @param id + * @param name + * @param shortcutKey + * @param globalShortcutKey + * @returns + */ +function update(classification: Classification) { + // SQL + let sql = `UPDATE ${classificationTableName} SET name = ?, type = ?, data = ?, shortcut_key = ?, global_shortcut_key = ? WHERE id = ?`; + // 运行 + return ( + db + .prepare(sql) + .run( + classification.name, + classification.type, + JSON.stringify(classification.data), + classification.shortcutKey, + classification.globalShortcutKey ? 1 : 0, + classification.id + ).changes > 0 + ); +} + +/** + * 更新数据 + * @param id + * @param data + */ +function updateData(id: number, data: ClassificationData) { + // SQL + let sql = `UPDATE ${classificationTableName} SET data = ? WHERE id = ?`; + return db.prepare(sql).run(JSON.stringify(data), id).changes > 0; +} + +/** + * 根据ID查询 + * @param id + */ +function selectById(id: number): Classification | null { + // SQL + let sql = `SELECT ${selectColumn} FROM ${classificationTableName} WHERE id = ?`; + // 运行 + let row = db.prepare(sql).get(id); + // 返回 + if (row) { + return getClassification(row); + } else { + return null; + } +} + +/** + * 删除 + * @param id + */ +function del(id: number) { + // 查询数据 + let classifictaion = selectById(id); + if (classifictaion) { + // 查询有无子分类 + let childList = list(classifictaion.id); + // SQL + let sql = `DELETE FROM ${classificationTableName} WHERE id = ? or parent_id = ?`; + // 运行 + let res = db.prepare(sql).run(id, id).changes > 0; + if (res) { + // 更新序号 + reorder(classifictaion.parentId); + // 删除分类下所有项目 + deleteByClassificationId(id); + // 删除子分类下所有项目 + for (const child of childList) { + deleteByClassificationId(child.id); + if (child.type === 1) { + // 删除关联文件夹 + deleteAssociateFolderWatcher(child.id); + } + } + if (classifictaion.type === 1) { + // 删除关联文件夹 + deleteAssociateFolderWatcher(classifictaion.id); + } + return true; + } else { + return false; + } + } else { + return false; + } +} + +/** + * 排序 + * @param fromId + * @param toId + * @param parentId + */ +function updateOrder( + fromId: number, + toId: number | null, + parentId: number | null +) { + // 查询来源分类 + let fromClassification = selectById(fromId); + if (fromClassification) { + // 新序号 + let newOrder = 1; + // 如果目标ID不为空获取项目并获取序号 + if (toId) { + let toClassification = selectById(toId); + if (toClassification) { + newOrder = toClassification.order; + } + } else { + newOrder = getMaxOrder(parentId) + 1; + } + // SQL + let sql = `UPDATE ${classificationTableName} SET \`order\` = ? WHERE id = ?`; + // 更新排序 + db.prepare(sql).run(newOrder, fromClassification.id); + // 判断新序号和老序号之间的数据是+1还是-1 + if (newOrder > fromClassification.order) { + // 新序号和老序号之间数据,序号-1 + let params = [fromClassification.order, newOrder, fromClassification.id]; + sql = `UPDATE ${classificationTableName} SET \`order\` = \`order\` - 1 WHERE \`order\` > ? AND \`order\` <= ? AND id != ?`; + if (parentId) { + sql += " AND parent_id = ?"; + params.push(parentId); + } else { + sql += " AND parent_id is NULL"; + } + db.prepare(sql).run(params); + } else { + // 新序号和老序号之间数据,序号+1 + let params = [newOrder, fromClassification.order, fromClassification.id]; + sql = `UPDATE ${classificationTableName} SET \`order\` = \`order\` + 1 WHERE \`order\` >= ? AND \`order\` < ? AND id != ?`; + if (parentId) { + sql += " AND parent_id = ?"; + params.push(parentId); + } else { + sql += " AND parent_id is NULL"; + } + db.prepare(sql).run(params); + } + return true; + } + return false; +} + +/** + * 重新排序 + * @param parentId + */ +function reorder(parentId: number | null) { + // 查询分类列表 + let classificationList = list(parentId); + // 开启事务 + db.transaction(() => { + // SQL + let sql = `UPDATE ${classificationTableName} SET \`order\` = ? WHERE id = ?`; + // 更新序号 + for (let i = 0; i < classificationList.length; i++) { + db.prepare(sql).run(i + 1, classificationList[i].id); + } + })(); +} + +/** + * 查询最大序号 + * @param parentId + */ +function getMaxOrder(parentId: number | null) { + // SQL + let sql = `SELECT MAX(\`order\`) \`order\` FROM ${classificationTableName}`; + if (parentId) { + sql += " WHERE parent_id = ?"; + } else { + sql += " WHERE parent_id IS NULL"; + } + // 运行 + let row: any = db.prepare(sql).get(parentId ? [parentId] : []); + if (!row || !row.order) { + return 0; + } else { + return row.order; + } +} + +/** + * 更新图标 + * @param id + * @param icon + */ +function updateIcon(id: number, icon: string | null) { + // 查询分类 + let classification = selectById(id); + if (classification) { + // SQL + let sql = `UPDATE ${classificationTableName} SET data = ? WHERE id = ?`; + // 更新图标 + classification.data.icon = icon; + return ( + db.prepare(sql).run(JSON.stringify(classification.data), id).changes > 0 + ); + } + return false; +} + +/** + * 是否有子分类 + * @param id + */ +function hasChildClassification(id: number) { + let classificationList = list(id); + return classificationList.length > 0; +} + +/** + * 更新固定分类 + * @param classification + * @param fixed + */ +function updateFixed(classification: Classification, fixed: boolean) { + classification.data.fixed = fixed; + updateData(classification.id, classification.data); +} + +/** + * 批量更新固定分类 + * @param id + */ +function batchUpdateFixed(id: number | null = null) { + // 事务 + db.transaction(() => { + // 查询所有分类 + let classificationList = list(); + // 更新 + for (const classification of classificationList) { + updateFixed(classification, id === classification.id); + } + })(); +} + +export { + init, + list, + add, + del, + selectById, + update, + updateData, + updateOrder, + updateIcon, + hasChildClassification, + batchUpdateFixed, +}; diff --git a/electron/main/classification/index.ts b/electron/main/classification/index.ts new file mode 100644 index 0000000..c4b039f --- /dev/null +++ b/electron/main/classification/index.ts @@ -0,0 +1,954 @@ +import { BrowserWindow, MenuItem, shell } from "electron"; +import { join, basename } from "node:path"; +import { getURLParams } from "../../commons/utils"; +import { + add, + hasChildClassification, + list, + selectById, + update, + updateData, +} from "./data"; +import { watch, statSync, Stats, readdirSync } from "node:fs"; +import { getDirectoryList } from "../item"; +import { AssociateFolderData } from "../../types/global"; +import { Classification } from "../../../types/classification"; +import { + closeWindow, + getDot, + getMainBackgorunColor, + sendToWebContent, +} from "../commons/index"; +import { deleteByClassificationId } from "../item/data"; + +// 窗口 +let classificationAddEditWindow: BrowserWindow | null = null; +let classificationSetIconWindow: BrowserWindow | null = null; +let classificationAssociateFolderWindow: BrowserWindow | null = null; +let classificationAggregateWindow: BrowserWindow | null = null; + +/** + * 添加/修改窗口 + * @param id + * @param parentId + */ +function createAddEditWindow(id: number | null, parentId: number | null) { + // 如果窗口存在先关闭窗口 + closeWindow(classificationAddEditWindow); + // 创建窗口 + classificationAddEditWindow = global.classificationAddEditWindow = + new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.mainWindow, + height: 174, + width: 400, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + // 参数 + let params = new Map(); + if (id) { + params.set("id", id); + } + if (parentId) { + params.set("parentId", parentId); + } + if (process.env.VITE_DEV_SERVER_URL) { + classificationAddEditWindow.loadURL( + process.env.VITE_DEV_SERVER_URL + + "Classification/AddEdit" + + getURLParams(params) + ); + } else { + classificationAddEditWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/Classification/AddEdit", + search: getURLParams(params), + }); + } + classificationAddEditWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + classificationAddEditWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + classificationAddEditWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + classificationAddEditWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 设置图标窗口 + * @param id + */ +function createSetIconWindow(id: number) { + // 如果窗口存在先关闭窗口 + closeWindow(classificationSetIconWindow); + // 创建窗口 + classificationSetIconWindow = global.classificationSetIconWindow = + new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.mainWindow, + height: 500, + width: 358, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + // 参数 + let params = new Map(); + params.set("id", id); + if (process.env.VITE_DEV_SERVER_URL) { + classificationSetIconWindow.loadURL( + process.env.VITE_DEV_SERVER_URL + + "Classification/SetIcon" + + getURLParams(params) + ); + } else { + classificationSetIconWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/Classification/SetIcon", + search: getURLParams(params), + }); + } + classificationSetIconWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + classificationSetIconWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + classificationSetIconWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + classificationSetIconWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 关联文件夹窗口 + * @param id + */ +function createAssociateFolderWindow(id: number) { + // 如果窗口存在先关闭窗口 + closeWindow(classificationAssociateFolderWindow); + // 创建窗口 + classificationAssociateFolderWindow = + global.classificationAssociateFolderWindow = new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.mainWindow, + height: 249, + width: 400, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + // 参数 + let params = new Map(); + params.set("id", id); + if (process.env.VITE_DEV_SERVER_URL) { + classificationAssociateFolderWindow.loadURL( + process.env.VITE_DEV_SERVER_URL + + "Classification/AssociateFolder" + + getURLParams(params) + ); + } else { + classificationAssociateFolderWindow.loadFile( + join(process.env.DIST, "index.html"), + { + hash: "/Classification/AssociateFolder", + search: getURLParams(params), + } + ); + } + classificationAssociateFolderWindow.webContents.setWindowOpenHandler( + ({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + } + ); + // 禁用标题栏右键 + classificationAssociateFolderWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + classificationAssociateFolderWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + classificationAssociateFolderWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 聚合分类窗口 + * @param id + */ +function createAggregateWindow(id: number) { + // 如果窗口存在先关闭窗口 + closeWindow(classificationAggregateWindow); + // 创建窗口 + classificationAggregateWindow = global.classificationAggregateWindow = + new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.mainWindow, + height: 144, + width: 400, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + // 参数 + let params = new Map(); + params.set("id", id); + if (process.env.VITE_DEV_SERVER_URL) { + classificationAggregateWindow.loadURL( + process.env.VITE_DEV_SERVER_URL + + "Classification/Aggregate" + + getURLParams(params) + ); + } else { + classificationAggregateWindow.loadFile( + join(process.env.DIST, "index.html"), + { + hash: "/Classification/Aggregate", + search: getURLParams(params), + } + ); + } + classificationAggregateWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + classificationAggregateWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + classificationAggregateWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + classificationAggregateWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 新建文件夹监听 + */ +function addAssociateFolderWatcher( + classificationId: number, + dir: string, + hiddenItems: string | null +) { + // 先删除原有监听 + deleteAssociateFolderWatcher(classificationId); + // 新建监听 + let data: AssociateFolderData = { + classificationId, + dir, + hiddenItems, + watch: null, + }; + // 定时器 + let timer: NodeJS.Timeout | null = null; + let dirWatch = watch(dir, () => { + if (timer) { + clearTimeout(timer); + timer = null; + } + // 启动定时器,在指定的时间间隔后发送合并后的通知 + timer = setTimeout(() => { + getDirectoryList(classificationId, dir, hiddenItems, false, true); + clearTimeout(timer); + timer = null; + }, 2000); + }); + dirWatch.on("error", () => { + dirWatch.close(); + global.associateFolderWatcher.delete(classificationId); + }); + // 保存 + data.watch = dirWatch; + if (!global.associateFolderWatcher) { + global.associateFolderWatcher = new Map(); + } + global.associateFolderWatcher.set(classificationId, data); +} + +/** + * 删除关联文件夹监听 + */ +function deleteAssociateFolderWatcher(classificationId: number) { + if (global.associateFolderWatcher) { + if (global.associateFolderWatcher.has(classificationId)) { + let data = global.associateFolderWatcher.get(classificationId); + if (data.watch) { + data.watch.close(); + data.watch = null; + } + global.associateFolderWatcher.delete(classificationId); + } + } else { + global.associateFolderWatcher = new Map(); + } +} + +/** + * 设置关联文件夹 + * @param id + * @param dir + * @param hiddenItems + */ +function setAssociateFolder( + id: number, + dir: string | null, + hiddenItems: string | null +) { + // 查询分类 + let classification = selectById(id); + if (classification) { + // 类型 + if (!dir) { + classification.type = 0; + classification.data.associateFolderPath = null; + } else { + classification.type = 1; + classification.data.associateFolderPath = dir; + } + classification.data.associateFolderHiddenItems = hiddenItems; + // 更新 + let res = update(classification); + if (res) { + // 如果类型为1,开始读取文件夹的文件 + if (classification.type === 1) { + // 读取文件夹并创建监听 + getDirectoryList(classification.id, dir, hiddenItems, true, true); + } else { + // 删除监听 + deleteAssociateFolderWatcher(classification.id); + } + return classification; + } + } + return null; +} + +/** + * 初始化关联文件夹 + */ +function initAssociateFolder() { + // 初始化Map + global.associateFolderWatcher = new Map(); + // 查询分类 + let classificationList = list(null); + // 初始化 + for (const classification of classificationList) { + if (classification.type === 1) { + // 读取文件夹并创建监听 + getDirectoryList( + classification.id, + classification.data.associateFolderPath, + classification.data.associateFolderHiddenItems, + true, + true + ); + } + } +} + +/** + * 获取项目布局菜单 + * @param classification + * @returns + */ +function getItemLayoutMenu(classification: Classification) { + // 是否拥有子级 + let hasChild = hasChildClassification(classification.id); + // 菜单 + let submenus: any = [ + new MenuItem({ + label: global.language.default, + icon: + classification.data.itemLayout === "default" && !hasChild + ? getDot() + : null, + click: () => { + updateItemLayout(classification, "default"); + }, + }), + new MenuItem({ + label: global.language.tile, + icon: + classification.data.itemLayout === "tile" && !hasChild + ? getDot() + : null, + click: () => { + updateItemLayout(classification, "tile"); + }, + }), + new MenuItem({ + label: global.language.list, + icon: + classification.data.itemLayout === "list" && !hasChild + ? getDot() + : null, + click: () => { + updateItemLayout(classification, "list"); + }, + }), + ]; + return new MenuItem({ + label: global.language.layout, + submenu: submenus, + }); +} + +/** + * 修改项目布局 + * @param classification + * @param layout + */ +function updateItemLayout( + classification: Classification, + layout: "default" | "tile" | "list" +) { + let resultList = []; + // 尝试获取子级分类 + let childList = list(classification.id); + let idList = []; + // 如果有子级分类的话,连同子级分类一起修改 + if (childList && childList.length > 0) { + idList.push(...childList.map((c) => c.id)); + } + idList.push(classification.id); + // 修改 + for (const id of idList) { + // 查询分类 + let classification = selectById(id); + if (classification) { + classification.data.itemLayout = layout; + if (updateData(classification.id, classification.data)) { + resultList.push({ + id, + layout, + }); + } + } + } + // 通知页面 + sendToWebContent("mainWindow", "onUpdateItemLayout", resultList); +} + +/** + * 获取项目排序菜单 + * @param classification + * @returns + */ +function getItemSortMenu(classification: Classification) { + // 是否拥有子级 + let hasChild = hasChildClassification(classification.id); + // 菜单 + let submenus: any = [ + new MenuItem({ + label: global.language.default, + icon: + classification.data.itemSort === "default" && !hasChild + ? getDot() + : null, + click: () => { + updateItemSort(classification, "default"); + }, + }), + new MenuItem({ + label: global.language.byInitialLetter, + icon: + classification.data.itemSort === "initial" && !hasChild + ? getDot() + : null, + click: () => { + updateItemSort(classification, "initial"); + }, + }), + new MenuItem({ + label: global.language.byLastOpen, + icon: + classification.data.itemSort === "lastOpen" && !hasChild + ? getDot() + : null, + click: () => { + updateItemSort(classification, "lastOpen"); + }, + }), + ]; + if (global.setting.item.openNumber) { + submenus.push( + new MenuItem({ + label: global.language.byOpenNumber, + icon: + classification.data.itemSort === "openNumber" && !hasChild + ? getDot() + : null, + click: () => { + updateItemSort(classification, "openNumber"); + }, + }) + ); + } + return new MenuItem({ + label: global.language.sort, + submenu: submenus, + }); +} + +/** + * 修改项目排序 + * @param classification + * @param sort + */ +function updateItemSort( + classification: Classification, + sort: "default" | "initial" | "openNumber" | "lastOpen" +) { + let resultList = []; + // 尝试获取子级分类 + let childList = list(classification.id); + let idList = []; + // 如果有子级分类的话,连同子级分类一起修改 + if (childList && childList.length > 0) { + idList.push(...childList.map((c) => c.id)); + } + idList.push(classification.id); + // 修改 + for (const id of idList) { + // 查询分类 + let classification = selectById(id); + if (classification && classification.type !== 2) { + classification.data.itemSort = sort; + if (updateData(classification.id, classification.data)) { + resultList.push({ + id, + sort, + }); + } + } + } + // 通知页面 + sendToWebContent("mainWindow", "onUpdateItemSort", resultList); +} + +/** + * 获取项目列数菜单 + * @param classification + * @returns + */ +function getItemColumnNumber(classification: Classification) { + // 菜单 + let submenus: any = [ + new MenuItem({ + label: global.language.default, + icon: !classification.data.itemColumnNumber ? getDot() : null, + click: () => { + updateItemColumnNumber(classification, null); + }, + }), + ]; + for (let i = 0; i < 20; i++) { + submenus.push({ + label: (i + 1).toString(), + icon: + classification.data.itemColumnNumber && + classification.data.itemColumnNumber === i + 1 + ? getDot() + : null, + click: () => { + updateItemColumnNumber(classification, i + 1); + }, + }); + } + return new MenuItem({ + label: global.language.columnNumber, + submenu: submenus, + }); +} + +/** + * 修改项目列数 + * @param classification + * @param columnNumber + */ +function updateItemColumnNumber( + classification: Classification, + columnNumber: number | null +) { + // 查询分类 + let curClassification = selectById(classification.id); + if (curClassification) { + curClassification.data.itemColumnNumber = columnNumber; + if (updateData(curClassification.id, curClassification.data)) { + // 通知页面 + sendToWebContent("mainWindow", "onUpdateItemColumnNumber", { + id: curClassification.id, + columnNumber: columnNumber, + }); + } + } +} + +/** + * 获取项目图标大小菜单 + * @param classification + * @returns + */ +function getItemIconSize(classification: Classification) { + // 是否拥有子级 + let hasChild = hasChildClassification(classification.id); + // 菜单 + let submenus: any = [ + new MenuItem({ + label: global.language.default, + icon: !classification.data.itemIconSize && !hasChild ? getDot() : null, + click: () => { + updateItemIconSize(classification, null); + }, + }), + new MenuItem({ + label: global.language.extraLarge, + icon: + classification.data.itemIconSize === 48 && !hasChild ? getDot() : null, + click: () => { + updateItemIconSize(classification, 48); + }, + }), + new MenuItem({ + label: global.language.large, + icon: + classification.data.itemIconSize === 40 && !hasChild ? getDot() : null, + click: () => { + updateItemIconSize(classification, 40); + }, + }), + new MenuItem({ + label: global.language.medium, + icon: + classification.data.itemIconSize === 32 && !hasChild ? getDot() : null, + click: () => { + updateItemIconSize(classification, 32); + }, + }), + new MenuItem({ + label: global.language.small, + icon: + classification.data.itemIconSize === 24 && !hasChild ? getDot() : null, + click: () => { + updateItemIconSize(classification, 24); + }, + }), + ]; + return new MenuItem({ + label: global.language.icon, + submenu: submenus, + }); +} + +/** + * 修改项目图标大小 + * @param classification + * @param iconSize + */ +function updateItemIconSize( + classification: Classification, + iconSize: number | null +) { + let resultList = []; + // 尝试获取子级分类 + let childList = list(classification.id); + let idList = []; + // 如果有子级分类的话,连同子级分类一起修改 + if (childList && childList.length > 0) { + idList.push(...childList.map((c) => c.id)); + } + idList.push(classification.id); + // 修改 + for (const id of idList) { + // 查询分类 + let classification = selectById(id); + if (classification) { + classification.data.itemIconSize = iconSize; + if (updateData(classification.id, classification.data)) { + resultList.push({ + id, + iconSize, + }); + } + } + } + // 通知页面 + sendToWebContent("mainWindow", "onUpdateItemIconSize", resultList); +} + +/** + * 根据文件夹创建分类 + * @param pathList + */ +function addClassificationByDirectory(pathList: Array) { + // 返回信息 + let resultList = []; + // 循环每个路径 + for (let path of pathList) { + try { + // 获取文件类型 + let stats: Stats | null = null; + try { + stats = statSync(path); + } catch (e) { + path = path.replace(" (x86)", ""); + try { + stats = statSync(path); + } catch (e) {} + } + // 只要文件夹 + if (stats && stats.isDirectory()) { + // 文件夹名称 + let name = basename(path); + // 添加分类 + let classification = add(null, name, null, false); + if (classification) { + // 读取文件夹下的内容 + let files = readdirSync(path); + // 组装路径 + let fileList = []; + for (let file of files) { + fileList.push(join(path, file)); + } + // 返回信息 + resultList.push({ + classification, + fileList, + }); + } + } + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + } + } + return resultList; +} + +/** + * 获取项目显示菜单 + * @param classification + * @returns + */ +function getItemShowOnly(classification: Classification) { + // 是否拥有子级 + let hasChild = hasChildClassification(classification.id); + // 菜单 + let submenus: any = [ + new MenuItem({ + label: global.language.all, + icon: + classification.data.itemShowOnly === "default" && !hasChild + ? getDot() + : null, + click: () => { + updateItemShowOnly(classification, "default"); + }, + }), + new MenuItem({ + label: global.language.showOnlyFiles, + icon: + classification.data.itemShowOnly === "file" && !hasChild + ? getDot() + : null, + click: () => { + updateItemShowOnly(classification, "file"); + }, + }), + new MenuItem({ + label: global.language.showOnlyFolders, + icon: + classification.data.itemShowOnly === "folder" && !hasChild + ? getDot() + : null, + click: () => { + updateItemShowOnly(classification, "folder"); + }, + }), + ]; + return new MenuItem({ + label: global.language.show, + submenu: submenus, + }); +} + +/** + * 修改项目显示 + * @param classification + * @param iconSize + */ +function updateItemShowOnly( + classification: Classification, + showOnly: "default" | "file" | "folder" +) { + let resultList = []; + // 尝试获取子级分类 + let childList = list(classification.id); + let idList = []; + // 如果有子级分类的话,连同子级分类一起修改 + if (childList && childList.length > 0) { + idList.push(...childList.map((c) => c.id)); + } + idList.push(classification.id); + // 修改 + for (const id of idList) { + // 查询分类 + let classification = selectById(id); + if (classification) { + classification.data.itemShowOnly = showOnly; + if (updateData(classification.id, classification.data)) { + resultList.push({ + id, + showOnly, + }); + } + } + } + // 通知页面 + sendToWebContent("mainWindow", "onUpdateItemShowOnly", resultList); +} + +/** + * 将排序为打开次数的分类修改为默认排序 + */ +function updateItemOpenNumberSortToDefualt() { + let resultList = []; + // 查询分类 + let classificationList = list(); + // 筛选出来排序是打开次数的分类 + let filterList = classificationList.filter( + (c) => c.data.itemSort === "openNumber" && (c.type === 0 || c.type === 1) + ); + // 修改 + for (const classification of filterList) { + classification.data.itemSort = "default"; + if (updateData(classification.id, classification.data)) { + resultList.push(classification.id); + } + } + // 通知页面 + sendToWebContent( + "mainWindow", + "onUpdateItemOpenNumberSortToDefualt", + resultList + ); +} + +/** + * 更新聚合分类 + * @param id + * @param sort + * @param itemCount + */ +function updateAggregate( + id: number, + sort: "default" | "initial" | "openNumber" | "lastOpen", + itemCount: number +) { + let classification = selectById(id); + if (classification) { + classification.type = 2; + classification.data.itemSort = sort; + classification.data.aggregateItemCount = itemCount; + let res = update(classification); + if (res) { + deleteByClassificationId(id); + } + return res; + } + return false; +} + +/** + * 更新排除搜索 + * @param id + * @param value + */ +function updateExcludeSearch(id: number, value: boolean) { + // 查询分类 + let classification = selectById(id); + if (classification) { + classification.data.excludeSearch = value; + updateData(id, classification.data); + } +} + +export { + createAddEditWindow, + createSetIconWindow, + createAssociateFolderWindow, + createAggregateWindow, + setAssociateFolder, + addAssociateFolderWatcher, + initAssociateFolder, + deleteAssociateFolderWatcher, + getItemSortMenu, + getItemLayoutMenu, + getItemColumnNumber, + getItemIconSize, + addClassificationByDirectory, + getItemShowOnly, + updateItemOpenNumberSortToDefualt, + updateAggregate, + updateExcludeSearch, +}; diff --git a/electron/main/classification/ipcEvent.ts b/electron/main/classification/ipcEvent.ts new file mode 100644 index 0000000..1f6d006 --- /dev/null +++ b/electron/main/classification/ipcEvent.ts @@ -0,0 +1,336 @@ +import { Menu, MenuItem, ipcMain, dialog } from "electron"; +import { Classification } from "../../../types/classification"; +import { + createAddEditWindow, + createAssociateFolderWindow, + createSetIconWindow, + getItemLayoutMenu, + getItemSortMenu, + getItemColumnNumber, + setAssociateFolder, + getItemIconSize, + addClassificationByDirectory, + getItemShowOnly, + createAggregateWindow, + updateAggregate, + updateExcludeSearch, +} from "./index"; +import { + add, + del, + list, + selectById, + update, + updateOrder, + updateIcon, + hasChildClassification, + batchUpdateFixed, +} from "./data"; +import { setShortcutKey } from "../setting"; +import { closeWindow, getDot, sendToWebContent } from "../commons/index"; + +export default function () { + // 获取分类列表 + ipcMain.on("getClassificationList", (event) => { + event.returnValue = list(null); + }); + // 根据ID查询分类 + ipcMain.on("getClassificationById", (event, args) => { + event.returnValue = selectById(args.id); + }); + // 添加分类 + ipcMain.on("addClassification", (event, args) => { + let classification = add( + args.parentId, + args.name, + args.shortcutKey, + args.globalShortcutKey + ); + setShortcutKey(); + event.returnValue = classification; + }); + // 更新分类 + ipcMain.on("updateClassification", (event, args) => { + let res = update(args); + setShortcutKey(); + event.returnValue = res; + }); + // 更新序号 + ipcMain.on("updateClassificationOrder", (event, args) => { + event.returnValue = updateOrder(args.fromId, args.toId, args.parentId); + }); + // 更新图标 + ipcMain.on("updateClassificationIcon", (event, args) => { + event.returnValue = updateIcon(args.id, args.icon); + }); + // 显示新增/修改窗口 + ipcMain.on("showClassificationAddEditWindow", () => { + if (global.classificationAddEditWindow) { + global.classificationAddEditWindow.show(); + } + }); + // 关闭新增/修改窗口 + ipcMain.on("closeClassificationAddEditWindow", () => { + closeWindow(global.classificationAddEditWindow); + }); + // 显示设置图标窗口 + ipcMain.on("showClassificationSetIconWindow", () => { + if (global.classificationSetIconWindow) { + global.classificationSetIconWindow.show(); + } + }); + // 关闭设置图标窗口 + ipcMain.on("closeClassificationSetIconWindow", () => { + closeWindow(global.classificationSetIconWindow); + }); + // 右键菜单 + ipcMain.on("showClassificationRightMenu", (event, args) => { + // 锁定/解锁分类 + let lockClassification: boolean = args.lockClassification; + // 分类 + let classification: Classification | null = args.classification; + // 菜单 + let menuList: Array = []; + // 组装菜单 + if (!classification) { + menuList.push( + new MenuItem({ + label: global.language.newClassification, + click: () => { + // 创建窗口 + createAddEditWindow(null, null); + }, + }), + new MenuItem({ type: "separator" }), + new MenuItem({ + label: !lockClassification + ? global.language.lockClassification + : global.language.unlockClassification, + click: () => { + sendToWebContent("mainWindow", "onLockClassification", []); + }, + }) + ); + } else { + if (!classification.parentId && classification.type === 0) { + menuList.push( + new MenuItem({ + label: global.language.newSubclassification, + click: () => { + // 创建窗口 + createAddEditWindow(null, classification.id); + }, + }), + new MenuItem({ type: "separator" }) + ); + } + menuList.push( + new MenuItem({ + label: global.language.fixedClassification, + icon: classification.data.fixed ? getDot() : null, + click: () => { + batchUpdateFixed( + classification.data.fixed ? null : classification.id + ); + sendToWebContent( + "mainWindow", + "onUpdateClassificationFixed", + classification.data.fixed ? null : classification.id + ); + }, + }) + ); + if (classification.type === 0 || classification.type === 1) { + menuList.push( + new MenuItem({ + label: global.language.excludeSearch, + icon: classification.data.excludeSearch ? getDot() : null, + click: () => { + updateExcludeSearch( + classification.id, + !classification.data.excludeSearch + ); + sendToWebContent( + "mainWindow", + "onUpdateClassificationExcludeSearch", + { + id: classification.id, + value: !classification.data.excludeSearch, + } + ); + }, + }) + ); + } + menuList.push(new MenuItem({ type: "separator" })); + menuList.push( + new MenuItem({ + label: global.language.setIcon, + click: () => { + // 创建窗口 + createSetIconWindow(classification.id); + }, + }), + new MenuItem({ + label: global.language.deleteIcon, + click: () => { + let res = updateIcon(classification.id, null); + if (res) { + sendToWebContent("mainWindow", "onUpdateClassificationIcon", { + id: classification.id, + icon: null, + }); + } + }, + }) + ); + // 子分类、没有子分类的父级分类可以显示 + if ( + classification.parentId || + (!classification.parentId && !hasChildClassification(classification.id)) + ) { + menuList.push(new MenuItem({ type: "separator" })); + if (classification.type === 0 || classification.type === 1) { + menuList.push( + new MenuItem({ + label: global.language.associateFolder, + click: () => { + // 创建窗口 + createAssociateFolderWindow(classification.id); + }, + }) + ); + } + if (classification.type === 0 || classification.type === 2) { + menuList.push( + new MenuItem({ + label: global.language.aggregateClassification, + click: () => { + // 创建窗口 + createAggregateWindow(classification.id); + }, + }) + ); + } + } + // 分割线 + menuList.push(new MenuItem({ type: "separator" })); + if (classification.type !== 2) { + // 排序 + menuList.push(getItemSortMenu(classification)); + } + // 布局 + menuList.push(getItemLayoutMenu(classification)); + // 列数 + if ( + !hasChildClassification(classification.id) && + (classification.data.itemLayout === "list" || + (global.setting.item.layout === "list" && + classification.data.itemLayout === "default")) + ) { + // 只有子级分类或没有子级分类的父级分类并且布局是列表的才显示列数 + menuList.push(getItemColumnNumber(classification)); + } + // 图标 + menuList.push(getItemIconSize(classification)); + // 显示 + menuList.push(getItemShowOnly(classification)); + // 编辑/删除 + menuList.push( + new MenuItem({ type: "separator" }), + new MenuItem({ + label: global.language.edit, + click: () => { + // 创建窗口 + createAddEditWindow(classification.id, null); + }, + }), + new MenuItem({ + label: global.language.delete, + click: () => { + let res = dialog.showMessageBoxSync(global.mainWindow, { + message: global.language.deleteClassificationPrompt, + buttons: [global.language.ok, global.language.cancel], + type: "question", + noLink: true, + cancelId: 1, + }); + if (res === 0) { + // 删除数据 + if (del(classification.id)) { + // 快捷键 + setShortcutKey(); + // 通知前端删除数据 + sendToWebContent( + "mainWindow", + "onDeleteClassification", + classification.id + ); + } + } + }, + }) + ); + } + // 载入菜单 + let menu = Menu.buildFromTemplate(menuList); + // 菜单显示 + menu.on("menu-will-show", () => { + global.classificationRightMenu = true; + }); + // 菜单关闭 + menu.on("menu-will-close", () => { + global.classificationRightMenu = false; + }); + // 显示 + menu.popup(); + }); + // 显示关联文件夹窗口 + ipcMain.on("showClassificationAssociateFolderWindow", () => { + if (global.classificationAssociateFolderWindow) { + global.classificationAssociateFolderWindow.show(); + } + }); + // 关闭关联文件夹窗口 + ipcMain.on("closeClassificationAssociateFolderWindow", () => { + closeWindow(global.classificationAssociateFolderWindow); + }); + // 设置关联文件夹 + ipcMain.on("setClassificationAssociateFolder", (event, args) => { + // 分类ID + let id: number = args.id; + // 文件夹路径 + let dir: string | null = args.dir; + if (!dir || dir.trim() === "") { + dir = null; + } + // 隐藏项 + let hiddenItems: string | null = args.hiddenItems; + // 设置 + event.returnValue = setAssociateFolder(id, dir, hiddenItems); + }); + // 是否拥有子分类 + ipcMain.on("hasChildClassification", (event, args) => { + event.returnValue = hasChildClassification(args); + }); + // 根据文件夹创建分类 + ipcMain.on("addClassificationByDirectory", (event, args) => { + let res = addClassificationByDirectory(args); + // 通知页面 + sendToWebContent("mainWindow", "onAddClassificationByDirectory", res); + }); + // 显示聚合分类窗口 + ipcMain.on("showClassificationAggregateWindow", () => { + if (global.classificationAggregateWindow) { + global.classificationAggregateWindow.show(); + } + }); + // 关闭聚合分类窗口 + ipcMain.on("closeClassificationAggregateWindow", () => { + closeWindow(global.classificationAggregateWindow); + }); + // 更新聚合分类 + ipcMain.on("updateClassificationAggregate", (event, args) => { + event.returnValue = updateAggregate(args.id, args.sort, args.itemCount); + }); +} diff --git a/electron/main/commons/cacheData.ts b/electron/main/commons/cacheData.ts new file mode 100644 index 0000000..a1e768f --- /dev/null +++ b/electron/main/commons/cacheData.ts @@ -0,0 +1,12 @@ +import Store from "electron-store"; +import { getUserDataPath } from "."; + +const cacheStore = new Store({ + name: "Cache", + clearInvalidConfig: true, + cwd: getUserDataPath(), +}); + +export default { + cacheStore, +}; diff --git a/electron/main/commons/index.ts b/electron/main/commons/index.ts new file mode 100644 index 0000000..75f208c --- /dev/null +++ b/electron/main/commons/index.ts @@ -0,0 +1,481 @@ +import { Result } from "../../../types/common"; +import { resolve, dirname, relative, join } from "node:path"; +import { mkdirSync, existsSync } from "node:fs"; +import mime from "mime"; +import retry from "retry"; +import request from "request"; +import * as cheerio from "cheerio"; +import { isAbsolutePath } from "../../../commons/utils/common"; +import { BrowserWindow, app, dialog, nativeImage, nativeTheme } from "electron"; +import { getRandomUserAgent, iconExts } from "../../commons/utils"; +import URI from "urijs"; +import { hideMainWindow } from "../main"; +import { hideQuickSearchWindow } from "../search"; + +/** + * 获取代理 + */ +function getProxy() { + if ( + global.setting.network.useProxy && + global.setting.network.proxy.address && + global.setting.network.proxy.address.trim() !== "" + ) { + let uri = new URI(global.setting.network.proxy.address); + if (uri.protocol() && uri.protocol().trim() !== "") { + let address = uri.protocol().toLowerCase() + "://"; + if ( + global.setting.network.proxy.username && + global.setting.network.proxy.username.trim() !== "" && + global.setting.network.proxy.password && + global.setting.network.proxy.password.trim() !== "" + ) { + address += + global.setting.network.proxy.username + + ":" + + global.setting.network.proxy.password + + "@"; + } + address += uri.hostname() + ":" + uri.port(); + return address; + } + } + return null; +} + +/** + * 下载图片 + * @param windowName + * @param url + */ +function downloadImage(windowName: string, url: string) { + let result: Result = { + status: false, + message: global.language.downloadImagePrompt1, + icon: null, + name: null, + }; + // 重试 + const operation = retry.operation({ + retries: 5, // 最多重试 5 次 + factor: 1, // 每次重试之间的时间间隔加倍 + minTimeout: 1000, // 第一次重试之前等待的时间 + maxTimeout: 5000, // 最长等待时间 + }); + operation.attempt((currentAttempt) => { + // 下载图片 + request( + { + uri: url, + proxy: getProxy(), + encoding: null, + timeout: 5000, + headers: { + "User-Agent": getRandomUserAgent(), + }, + }, + function (error, response, body) { + if (operation.retry(error)) { + return; + } + if ( + !error && + response.statusCode >= 200 && + response.statusCode <= 299 + ) { + if (response.headers && response.headers["content-type"]) { + let ext = mime.getExtension(response.headers["content-type"]); + if (iconExts.includes(ext)) { + let buffer = Buffer.from(body); + result.icon = + "data:" + + mime.getType(response.headers["content-type"]) + + ";base64," + + buffer.toString("base64"); + result.status = true; + result.message = null; + } else { + result.icon = null; + result.status = false; + result.message = global.language.downloadImagePrompt2; + } + } + } + // window + sendToWebContent(windowName, "onDownloadImage", result); + } + ); + }); +} + +/** + * 获取网址信息 + * @param windowName + * @param url + * @param redirect + */ +function getURLInfo(windowName: string, url: string, redirect: boolean) { + let result: Result = { + status: false, + message: null, + name: null, + icon: null, + }; + // 重试 + const operation = retry.operation({ + retries: 5, // 最多重试 5 次 + factor: 1, // 每次重试之间的时间间隔加倍 + minTimeout: 1000, // 第一次重试之前等待的时间 + maxTimeout: 5000, // 最长等待时间 + }); + try { + // 发起请求 + operation.attempt((currentAttempt) => { + request( + { + uri: url, + proxy: getProxy(), + timeout: 5000, + headers: { + "User-Agent": getRandomUserAgent(), + }, + }, + function (error, response, body) { + if (operation.retry(error)) { + return; + } + if ( + !error && + response.statusCode >= 200 && + response.statusCode <= 299 + ) { + const $ = cheerio.load(body); + // 是否有跳转标签 + let refresh = $("meta[http-equiv='refresh']"); + // content + let content = refresh.attr("content"); + if (content && content.trim() !== "" && redirect) { + // 如果有跳转标签的话,就请求新网址并获取网址信息 + let contentSplit = content.split(";"); + let urlProperty = contentSplit[contentSplit.length - 1]; + let urlPropertySplit = urlProperty.split("="); + let newURL = urlPropertySplit[urlPropertySplit.length - 1]; + // 重新获取新网址信息 + getURLInfo(windowName, newURL, false); + } else { + // 解析HTML并返回信息 + analysisHTML(windowName, url, body); + } + } else { + sendUrlInfo(windowName, result); + } + } + ); + }); + } catch (e) { + sendUrlInfo(windowName, result); + } +} + +/** + * 解析HTML并返回信息 + * @param windowName + * @param url + * @param data + */ +function analysisHTML(windowName: string, url: string, data: string) { + let result: Result = { + status: false, + message: null, + name: null, + icon: null, + }; + try { + // 解析HTML + let $ = cheerio.load(data); + // 获取标题 + result.name = $("head").find("title").text(); + // 获取图标URL + let iconURL: string | null = null; + let icon = $("link[rel='icon']"); + let href = icon.attr("href"); + if (href && href.trim() !== "") { + iconURL = href; + } else { + let shortcutIcon = $("link[rel='shortcut icon']"); + let shortcutIconhref = shortcutIcon.attr("href"); + if (shortcutIconhref && shortcutIconhref.trim() !== "") { + iconURL = shortcutIconhref; + } else { + iconURL = "/favicon.ico"; + } + } + if (iconURL) { + // 去掉类似//www.baidu.com/favicon.ico这样域名的”//“字符 + if (iconURL.indexOf("//") === 0) { + iconURL = "http:" + iconURL; + } + // 无协议头,使用当前网址域名 + if (iconURL.indexOf("http://") < 0 && iconURL.indexOf("https://") < 0) { + iconURL = url + (iconURL.indexOf("//") === 0 ? "" : "//") + iconURL; + } + // 重试 + const operation = retry.operation({ + retries: 5, // 最多重试 5 次 + factor: 1, // 每次重试之间的时间间隔加倍 + minTimeout: 1000, // 第一次重试之前等待的时间 + maxTimeout: 5000, // 最长等待时间 + }); + operation.attempt((currentAttempt) => { + // 下载图标 + request( + { + uri: iconURL, + proxy: getProxy(), + encoding: null, + timeout: 5000, + headers: { + "User-Agent": getRandomUserAgent(), + }, + }, + function (error, response, body) { + if (operation.retry(error)) { + return; + } + if ( + !error && + response.statusCode >= 200 && + response.statusCode <= 299 + ) { + let buffer = Buffer.from(body); + result.icon = + "data:" + + mime.getType(iconURL) + + ";base64," + + buffer.toString("base64"); + result.status = true; + sendUrlInfo(windowName, result); + } else { + sendUrlInfo(windowName, result); + } + } + ); + }); + } else { + sendUrlInfo(windowName, result); + } + } catch (e) { + sendUrlInfo(windowName, result); + } +} + +/** + * 发送网址信息 + * @param result + */ +function sendUrlInfo(windowName: string, result: Result) { + sendToWebContent(windowName, "onGetURLInfo", result); +} + +/** + * 路径转换 + * @param path + */ +function convertPath(path: string) { + let appPath = + process.env.NODE_ENV === "development" + ? resolve(".") + : dirname(process.execPath); + if (isAbsolutePath(path)) { + return relative(appPath, path); + } else { + return resolve(appPath, path); + } +} + +/** + * 发送IPC到所有窗口 + * @param channel + * @param data + */ +function sendAllWindows(channel: string, data: any) { + for (const window of BrowserWindow.getAllWindows()) { + if (!window.isDestroyed()) { + window.webContents.send(channel, data); + } + } +} +/** + * 获取窗口实例 + * @param name + */ +function getWindow(name: string): BrowserWindow | null { + let window: BrowserWindow | null = null; + if (name === "mainWindow") { + window = global.mainWindow; + } else if (name === "quickSearchWindow") { + window = global.quickSearchWindow; + } else if (name === "settingWindow") { + window = global.settingWindow; + } else if (name === "classificationAddEditWindow") { + window = global.classificationAddEditWindow; + } else if (name === "classificationSetIconWindow") { + window = global.classificationSetIconWindow; + } else if (name === "classificationAssociateFolderWindow") { + window = global.classificationAssociateFolderWindow; + } else if (name === "classificationAggregateWindow") { + window = global.classificationAggregateWindow; + } else if (name === "itemAddEditWindow") { + window = global.itemAddEditWindow; + } else if (name === "itemNetworkIconWindow") { + window = global.itemNetworkIconWindow; + } else if (name === "itemSVGIconWindow") { + window = global.itemSVGIconWindow; + } else if (name === "aboutWindow") { + window = global.aboutWindow; + } else if (name === "backupRestoreDataWindow") { + window = global.backupRestoreDataWindow; + } + if (window && !window.isDestroyed()) { + return window; + } else { + return null; + } +} + +/** + * 关闭窗口 + * @param window + */ +function closeWindow(window: BrowserWindow | null) { + if (window && !window.isDestroyed() && window.isVisible()) { + window.close(); + } +} + +/** + * 获取图标点 + */ +function getDot() { + return nativeImage.createFromDataURL( + !nativeTheme.shouldUseDarkColors + ? "" + : "" + ); +} + +/** + * 发送消息到页面 + * @param windowName + * @param listener + * @param params + */ +function sendToWebContent(windowName: string, listener: string, params: any) { + // 获取窗口 + let window = getWindow(windowName); + if (window && !window.isDestroyed()) { + window.webContents.send(listener, params); + } +} + +/** + * 关闭所有子进程 + */ +function closeAllChildProcess() { + if (global.childProcessMap) { + global.childProcessMap.forEach((value, key) => { + try { + value.utilityProcess.kill(); + } catch (e) {} + try { + value.port1.close(); + } catch (e) {} + try { + value.port2.close(); + } catch (e) {} + }); + global.childProcessMap.clear(); + } +} + +/** + * 打开后隐藏窗口 + * @param type + */ +function openAfterHideWindow(type: string) { + if (type === "main" || type === "search") { + if (global.setting.item.openAfterHideMainInterface) { + hideMainWindow(); + } + } else if (type === "quickSearch") { + if (global.setting.quickSearch.openAfterHideQuickSearchWindow) { + hideQuickSearchWindow(); + } + } +} + +/** + * 错误提示框 + * @param windowName + * @param message + */ +function showErrorMessageBox(windowName: string, message: string) { + dialog.showMessageBoxSync(getWindow(windowName), { + message: message, + buttons: [global.language.ok], + type: "error", + noLink: true, + }); +} + +/** + * 重启 + */ +function relaunch() { + app.relaunch(); + app.quit(); +} + +// 数据存储目录 +function getUserDataPath() { + let userDataPath = app.getPath("userData"); + if ( + process.env.NODE_ENV !== "development" && + import.meta.env.VITE_INSTALL === "false" + ) { + userDataPath = join(dirname(process.execPath), "data"); + if (!existsSync(userDataPath)) { + mkdirSync(userDataPath, { recursive: true }); + } + } + return userDataPath; +} + +/** + * 获取主背景颜色 + */ +function getMainBackgorunColor() { + let backgroundColor = global.setting.appearance.theme.mainBackgroundColor; + if (backgroundColor.length === 9) { + return backgroundColor.substring(0, 7); + } else { + return backgroundColor; + } +} + +export { + downloadImage, + getURLInfo, + convertPath, + sendAllWindows, + closeWindow, + getDot, + getWindow, + sendToWebContent, + closeAllChildProcess, + openAfterHideWindow, + showErrorMessageBox, + relaunch, + getUserDataPath, + getMainBackgorunColor, +}; diff --git a/electron/main/commons/ipcEvent.ts b/electron/main/commons/ipcEvent.ts new file mode 100644 index 0000000..ee38d27 --- /dev/null +++ b/electron/main/commons/ipcEvent.ts @@ -0,0 +1,166 @@ +import { app, dialog, ipcMain, OpenDialogSyncOptions, shell } from "electron"; +import { getFileIcon } from "../../commons/utils"; +import mime from "mime"; +import { ShortcutInfo } from "../../../types/common"; +import { + convertPath, + downloadImage, + getURLInfo, + sendToWebContent, + showErrorMessageBox, +} from "."; +import { statSync } from "node:fs"; +import { getWindow } from "../commons/index"; + +export default function () { + // emit + ipcMain.on("emit", (event, args) => { + sendToWebContent(args.windowName, args.listener, args.paylod); + }); + // 错误提示框 + ipcMain.on("showErrorMessageBox", (event, args) => { + showErrorMessageBox(args.windowName, args.message); + }); + // 信息提示框 + ipcMain.on("showInfoMessageBox", (event, args) => { + dialog.showMessageBoxSync(getWindow(args.windowName), { + message: args.message, + buttons: [global.language.ok], + type: "info", + noLink: true, + }); + }); + // 对话框 + ipcMain.on("showConfirmBox", (event, args) => { + // 弹出对话框 + let res = dialog.showMessageBoxSync(getWindow(args.windowName), { + message: args.message, + buttons: [global.language.ok, global.language.cancel], + type: "question", + noLink: true, + cancelId: 1, + }); + event.returnValue = res === 0; + }); + // 选择文件 + ipcMain.on("selectFile", (event, args) => { + // 窗口名称 + let windowName: string = args.windowName; + // 是否寻找目标 + let target: boolean = args.target; + // 默认路径 + let defaultPath: string | null = args.defaultPath; + // 参数 + let options: OpenDialogSyncOptions = {}; + if (defaultPath && defaultPath.trim() !== "") { + options.defaultPath = defaultPath; + } else { + options.defaultPath = app.getPath("desktop"); + } + let filePathList = dialog.showOpenDialogSync( + getWindow(windowName), + options + ); + if (filePathList && filePathList.length > 0) { + let filePath = filePathList[0]; + if (target) { + if (mime.getType(filePath) === "application/x-ms-shortcut") { + // 获取真实文件路径和参数 + let shortcutInfo: ShortcutInfo | null = + global.addon.getShortcutFileInfo(filePath); + if (shortcutInfo && shortcutInfo.target) { + // 路径 + filePath = shortcutInfo.target; + } + } + } + event.returnValue = filePath; + } else { + event.returnValue = null; + } + }); + // 选择文件夹 + ipcMain.on("selectDirectory", (event, args) => { + // 窗口名称 + let windowName: string = args.windowName; + // 默认路径 + let defaultPath: string | null = args.defaultPath; + // 参数 + let options: OpenDialogSyncOptions = { + properties: ["openDirectory"], + }; + if (defaultPath && defaultPath.trim() !== "") { + options.defaultPath = defaultPath; + } else { + options.defaultPath = app.getPath("desktop"); + } + let dirPathList = dialog.showOpenDialogSync(getWindow(windowName), options); + if (dirPathList && dirPathList.length > 0) { + let dirPath = dirPathList[0]; + event.returnValue = dirPath; + } else { + event.returnValue = null; + } + }); + // 获取图标 + ipcMain.on("getFileIcon", (event, args) => { + // 窗口名称 + let windowName: string = args.windowName; + // 路径 + let filePath: string | null = args.path; + if (filePath) { + // 图标 + let icon: string | null = getFileIcon(filePath); + // 发送到页面 + sendToWebContent(windowName, "onGetFileIcon", icon); + } + }); + // 下载图片 + ipcMain.on("downloadImage", (event, args) => { + downloadImage(args.windowName, args.url); + }); + // 获取网址信息 + ipcMain.on("getURLInfo", (event, args) => { + getURLInfo(args.windowName, args.url, true); + }); + // 转换路径 + ipcMain.on("convertPath", (event, args) => { + event.returnValue = convertPath(args.path); + }); + // 路径是否存在 + ipcMain.on("pathExist", (event, args) => { + try { + statSync(args.path); + event.returnValue = true; + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + event.returnValue = false; + } + }); + // 是否是文件 + ipcMain.on("isFile", (event, args) => { + try { + const stats = statSync(args.path); + event.returnValue = stats.isFile(); + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + event.returnValue = true; + } + }); + // 打开URL + ipcMain.on("openURL", (event, args) => { + shell.openExternal(args); + }); + // 获取版本 + ipcMain.on("getVersion", (event, args) => { + event.returnValue = app.getVersion(); + }); + // 退出 + ipcMain.on("exit", () => { + app.quit(); + }); +} diff --git a/electron/main/data/data.ts b/electron/main/data/data.ts new file mode 100644 index 0000000..f5ced59 --- /dev/null +++ b/electron/main/data/data.ts @@ -0,0 +1,486 @@ +import Database from "better-sqlite3-multiple-ciphers"; +import { + getCustomDataSqlite3, + getDataSqlite3, +} from "../../commons/betterSqlite3"; +import Store from "electron-store"; +import { extname, parse } from "node:path"; +import { + newClassification, + newClassificationData, + newItem, + newItemData, +} from "../../../commons/utils/common"; +import { add as addClassification } from "../classification/data"; +import { add as addItem } from "../item/data"; +import { getSetting } from "../../../commons/utils/setting"; +import { add as addSetting } from "../setting/data"; + +/** + * 恢复数据 + * @param filePath + */ +function restore(filePath: string) { + // 获取文件后缀 + let ext = extname(filePath); + if (ext.toLowerCase() === ".db") { + // 数据库文件 + return databaseRestore(filePath); + } else if (ext.toLowerCase() === ".json") { + // 旧版JSON + return jsonRestore(filePath); + } + return false; +} + +/** + * 数据库恢复数据 + * @param filePath + * @returns + */ +function databaseRestore(filePath: string) { + try { + // 获取导入DB + let importDB = getCustomDataSqlite3(filePath); + // 查询分类数据 + let classificationList = importDB + .prepare("SELECT * FROM classification") + .all(); + // 查询项目数据 + let itemList = importDB.prepare("SELECT * FROM item").all(); + // 查询设置数据 + let setting = importDB.prepare("SELECT * FROM setting").all(); + // 查询ID索引表数据 + let sequence = importDB.prepare("SELECT * FROM sqlite_sequence").all(); + // 获取当前DB + let db = getDataSqlite3(); + // 开启事务 + db.transaction(() => { + // 清空并导入数据 + clearAndInsert(db, "classification", classificationList); + clearAndInsert(db, "item", itemList); + clearAndInsert(db, "setting", setting); + clearAndInsert(db, "sqlite_sequence", sequence); + })(); + return true; + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + } + return false; +} + +/** + * 清空并插入数据 + * @param tableName + * @param list + */ +function clearAndInsert( + db: Database.Database, + tableName: string, + list: Array +) { + // 清空数据 + db.prepare(`DELETE FROM ${tableName}`).run(); + // 插入数据 + list.forEach((row) => { + const keys = Object.keys(row); + const columns = keys.map((key) => `\`${key}\``); + const placeholders = keys.map(() => "?").join(","); + const values = keys.map((key) => row[key]); + db.prepare( + `INSERT INTO ${tableName} (${columns.join(",")}) VALUES (${placeholders})` + ).run(values); + }); +} + +/** + * JSON恢复数据 + * @param filePath + * @returns + */ +function jsonRestore(filePath: string) { + try { + // 获取当前DB + let db = getDataSqlite3(); + // 解析路径 + let pathParse = parse(filePath); + // 读取JSON + const store = new Store({ + name: pathParse.name, + cwd: pathParse.dir, + fileExtension: pathParse.ext.replace(".", ""), + encryptionKey: "0b52eb58-4c0f-5ff1-b062-031546a8d269", + }); + // 开启事务 + db.transaction(() => { + // 图标数据 + let iconData = store.get("iconData") as Array; + // 清空数据 + db.prepare(`DELETE FROM classification`).run(); + db.prepare(`DELETE FROM item`).run(); + db.prepare(`DELETE FROM setting`).run(); + db.prepare(`DELETE FROM sqlite_sequence`).run(); + // 导入数据 + let list = store.get("list") as Array; + if (list && list.length > 0) { + for (let i = 0; i < list.length; i++) { + let parent = list[i]; + // 添加分类 + let classification = jsonAddClassification(parent, null); + if (classification) { + if (parent.childList && parent.childList.length > 0) { + // 子分类 + for (let j = 0; j < parent.childList.length; j++) { + const child = parent.childList[j]; + let childClassification = jsonAddClassification( + child, + classification.id + ); + if ( + childClassification && + child.itemList && + child.itemList.length > 0 + ) { + // 项目 + for (let k = 0; k < child.itemList.length; k++) { + jsonAddItem( + child.itemList[k], + child, + childClassification.id, + iconData + ); + } + } + } + } else { + if (parent.itemList && parent.itemList.length > 0) { + // 项目 + for (let k = 0; k < parent.itemList.length; k++) { + jsonAddItem( + parent.itemList[k], + parent, + classification.id, + iconData + ); + } + } + } + } + } + } + // 设置 + if (store.get("setting")) { + jsonAddSetting(store.get("setting")); + } + })(); + return true; + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + } + return false; +} + +/** + * 添加分类 + * @param oldClassification + * @param parentId + * @returns + */ +function jsonAddClassification( + oldClassification: any, + parentId: number | null +) { + // 排序 + let itemSort: "default" | "initial" | "openNumber" | "lastOpen" = "default"; + // 如果是聚合分类的话,获取聚合分类排序,否则就获取普通排序 + if ( + oldClassification.aggregateSort && + oldClassification.aggregateSort.trim() != "" && + (oldClassification.aggregateSort == "initial" || + oldClassification.aggregateSort == "openNumber" || + oldClassification.aggregateSort == "lastOpen") + ) { + // 聚合分类 + itemSort = oldClassification.aggregateSort; + } else if ( + oldClassification.sort == "initial" || + oldClassification.sort == "openNumber" || + oldClassification.sort == "lastOpen" + ) { + // 普通 + itemSort = oldClassification.sort; + } + let data = newClassificationData({ + icon: oldClassification.icon, + excludeSearch: oldClassification.excludeSearch, + itemLayout: + oldClassification.layout == "tile" || oldClassification.layout == "list" + ? oldClassification.layout + : "default", + itemSort: itemSort, + itemColumnNumber: oldClassification.columnNumber, + itemIconSize: oldClassification.iconSize, + itemShowOnly: + oldClassification.showOnly == "file" || + oldClassification.showOnly == "folder" + ? oldClassification.showOnly + : "default", + associateFolderHiddenItems: oldClassification.hiddenItem, + associateFolderPath: oldClassification.mapDirectory, + aggregateItemCount: oldClassification.aggregateItemNumber, + }); + // 类型 0:普通分类 1:关联文件夹 2:聚合分类 + let type = 0; + if ( + oldClassification.mapDirectory && + oldClassification.mapDirectory.trim() != "" + ) { + // 关联文件夹 + type = 1; + } else if ( + oldClassification.aggregateSort && + oldClassification.aggregateSort.trim() != "" + ) { + // 聚合分类 + type = 2; + } + let classification = newClassification({ + parentId, + name: oldClassification.name, + type, + data, + shortcutKey: oldClassification.shortcutKey, + globalShortcutKey: oldClassification.globalShortcutKey, + }); + return addClassification( + classification.parentId, + classification.name, + classification.shortcutKey, + classification.globalShortcutKey, + classification.data, + classification.type + ); +} + +/** + * 添加项目 + * @param oldItem + * @param oldClassification + * @param classificationId + * @param iconData + */ +function jsonAddItem( + oldItem: any, + oldClassification: any, + classificationId: number, + iconData: Array +) { + // 类型 + let type = oldItem.type; + if (type == 4) { + type = 5; + } else if (type == 5) { + type = 4; + } + // 多项目不导入 + if (type == 5) { + return null; + } + // 合并目标 + let target = oldItem.path; + if (oldItem.url && oldItem.url.trim() != "") { + // 网址 + target = oldItem.url; + } else if (oldItem.shell && oldItem.shell.trim() != "") { + // 系统 + target = oldItem.shell; + } + // 图标 + let icon = oldItem.icon; + if (iconData) { + for (let i = 0; i < iconData.length; i++) { + const data = iconData[i]; + if (oldClassification.parentId) { + if ( + data.classificationParentId == oldClassification.parentId && + data.classificationChildId == oldClassification.id && + data.itemId == oldItem.id && + data.icon && + data.icon.trim() != "" + ) { + icon = data.icon; + } + } else { + if ( + data.classificationParentId == oldClassification.id && + data.itemId == oldItem.id && + data.icon && + data.icon.trim() != "" + ) { + icon = data.icon; + } + } + } + } + let data = newItemData({ + startLocation: oldItem.startLocation, + target, + params: oldItem.params, + runAsAdmin: oldItem.admin, + icon, + htmlIcon: + !oldItem.htmlIcon || oldItem.htmlIcon.trim() == "" + ? null + : oldItem.htmlIcon, + remark: oldItem.remark, + iconBackgroundColor: oldItem.useAppxBackgroundColor, + fixedIcon: oldItem.notRefreshIcon, + openNumber: oldItem.openNumber, + lastOpen: oldItem.lastOpen, + quickSearchOpenNumber: oldItem.quickSearchOpenNumber, + quickSearchLastOpen: oldItem.quickSearchLastOpen, + }); + let item = newItem({ + classificationId, + name: oldItem.name, + type, + data, + shortcutKey: oldItem.shortcutKey, + globalShortcutKey: oldItem.globalShortcutKey, + }); + return addItem(item, false); +} + +/** + * 添加设置 + * @param oldSetting + */ +function jsonAddSetting(oldSetting: any) { + let setting = getSetting(null); + // 常规 + if (oldSetting.general) { + setting.general.startup = oldSetting.general.startup; + setting.general.startupTray = oldSetting.general.startupTray; + setting.general.showHideShortcutKey = + oldSetting.general.showHideShortcutKey; + setting.general.alwaysTop = oldSetting.general.alwaysTop; + setting.general.edgeAutoHide = oldSetting.general.edgeAutoHide; + setting.general.lockSize = oldSetting.general.lockSize; + setting.general.hideLoseFocus = oldSetting.general.hideLosingFocus; + setting.general.hideTray = oldSetting.general.hideTray; + setting.general.showHideMouseWheelClick = + oldSetting.general.showHideMouseWheelClick; + setting.general.fixedPosition = oldSetting.general.fixedPosition; + setting.general.alwaysCenter = oldSetting.general.alwaysCenter; + setting.general.showFollowMousePosition = + oldSetting.general.showFollowMousePosition; + setting.general.notDisturb = oldSetting.general.notDisturb; + setting.general.showHideDoubleClickTaskbar = + oldSetting.general.doubleClickTaskbar; + setting.general.delayDisplayMs = oldSetting.general.delayDisplayMS; + setting.general.delayHideMs = oldSetting.general.delayHidingMS; + setting.general.switchEnglish = oldSetting.general.switchEnglish; + if (oldSetting.item) { + setting.general.searchShowHideShortcutKey = + oldSetting.item.searchShortcutKey; + } + } + // 分类 + if (oldSetting.classification) { + setting.classification.width = oldSetting.classification.width; + setting.classification.layout = oldSetting.classification.layout; + setting.classification.mouseHover = oldSetting.classification.mouseHover; + setting.classification.mouseHoverMs = + oldSetting.classification.mouseHoverMS; + setting.classification.mouseWheel = oldSetting.classification.mouseWheel; + setting.classification.rememberSelectionState = + oldSetting.classification.rememberSelectionState; + setting.classification.nameAlign = oldSetting.classification.nameAlign; + setting.classification.mode = oldSetting.classification.mode; + setting.classification.autoSwitchClassification = + oldSetting.classification.autoSwitchClassification; + setting.classification.hideWindowCollapseSubClassification = + oldSetting.classification.hideWindowFoldChildClassification; + setting.classification.switchClassificationCollapseOtherSubClassification = + oldSetting.classification.switchClassificationCollapseOtherSubClassification; + } + // 项目 + if (oldSetting.item) { + setting.item.layout = oldSetting.item.layout; + setting.item.iconSize = oldSetting.item.iconSize; + setting.item.doubleClickOpen = oldSetting.item.doubleClickRunItem; + setting.item.openAfterHideMainInterface = + oldSetting.item.openAfterHideMainInterface; + setting.item.useItemOpen = oldSetting.item.useItemOpen; + setting.item.openNumber = oldSetting.item.openNumber; + setting.item.hideItemName = oldSetting.item.hideItemName; + setting.item.hideEllipsis = oldSetting.item.hideEllipsis; + setting.item.itemNameRowCount = oldSetting.item.itemNameRowCount; + setting.item.width = oldSetting.item.width; + setting.item.columnNumber = oldSetting.item.columnNumber; + setting.item.checkInvalidItem = oldSetting.item.checkInvalidItem; + setting.item.fontSize = oldSetting.item.fontSize; + setting.item.fontWeight = oldSetting.item.fontWeight; + setting.item.fontLineHeight = oldSetting.item.fontLineHeight; + } + // 子分类 + if (oldSetting.subClassification) { + setting.subClassification.itemAreaNameFontSize = + oldSetting.subClassification.itemAreaNameFontSize; + setting.subClassification.itemAreaNameFontWeight = + oldSetting.subClassification.itemAreaNameFontWeight; + setting.subClassification.itemAreaNameFontLineHeight = + oldSetting.subClassification.itemAreaNameFontLineHeight; + } + // 快速搜索 + if (oldSetting.quickSearch) { + setting.quickSearch.enable = oldSetting.quickSearch.enable; + setting.quickSearch.showHideShortcutKey = + oldSetting.quickSearch.showHideShortcutKey; + setting.quickSearch.openShortcutKey = + oldSetting.quickSearch.openShortcutKey; + setting.quickSearch.hideLoseFocus = oldSetting.quickSearch.hideLosingFocus; + setting.quickSearch.openNow = oldSetting.quickSearch.openNow; + setting.quickSearch.showHistory = oldSetting.quickSearch.showHistory; + setting.quickSearch.showHistorySort = + oldSetting.quickSearch.showHistorySort; + setting.quickSearch.useItemOpen = oldSetting.quickSearch.useItemOpen; + setting.quickSearch.openAfterHideQuickSearchWindow = + oldSetting.quickSearch.openAfterHideQuickSearchWindow; + setting.quickSearch.matchConditionsRemark = + oldSetting.quickSearch.matchingConditionsRemark; + } + // 网络搜索 + if (oldSetting.webSearch) { + setting.webSearch.mode = oldSetting.webSearch.mode; + if (oldSetting.webSearch.searchSourceList) { + setting.webSearch.searchSourceList = []; + for (let i = 0; i < oldSetting.webSearch.searchSourceList.length; i++) { + const oldSearchSource = oldSetting.webSearch.searchSourceList[i]; + setting.webSearch.searchSourceList.push({ + id: oldSearchSource.id, + keyword: oldSearchSource.keyword, + name: oldSearchSource.name, + url: oldSearchSource.URL, + description: oldSearchSource.description, + }); + } + } + } + // 网络 + if (oldSetting.network) { + setting.network.useProxy = oldSetting.network.useProxy; + if (oldSetting.network.proxy) { + setting.network.proxy.address = oldSetting.network.proxy.address; + setting.network.proxy.username = oldSetting.network.proxy.username; + setting.network.proxy.password = oldSetting.network.proxy.password; + } + } + return addSetting(getSetting(setting)); +} + +export { restore }; diff --git a/electron/main/data/index.ts b/electron/main/data/index.ts new file mode 100644 index 0000000..08085ec --- /dev/null +++ b/electron/main/data/index.ts @@ -0,0 +1,71 @@ +import { BrowserWindow, shell } from "electron"; +import { closeWindow, getMainBackgorunColor } from "../commons"; +import { join } from "node:path"; +import { getDataSqlite3 } from "../../commons/betterSqlite3"; + +// 窗口 +let backupRestoreDataWindow: BrowserWindow | null = null; + +/** + * 备份/恢复数据窗口 + */ +function createBackupRestoreDataWindow() { + // 如果窗口存在先关闭窗口 + closeWindow(backupRestoreDataWindow); + // 创建窗口 + backupRestoreDataWindow = global.backupRestoreDataWindow = new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.mainWindow, + height: 108, + width: 400, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + if (process.env.VITE_DEV_SERVER_URL) { + backupRestoreDataWindow.loadURL( + process.env.VITE_DEV_SERVER_URL + "Data/BackupRestore" + ); + } else { + backupRestoreDataWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/Data/BackupRestore", + }); + } + backupRestoreDataWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + backupRestoreDataWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + backupRestoreDataWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + backupRestoreDataWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 备份数据 + */ +function backupData(filePath: string) { + // 获取数据库 + let db = getDataSqlite3(); + // 备份数据 + return db.backup(filePath); +} + +export { createBackupRestoreDataWindow, backupData }; diff --git a/electron/main/data/ipcEvent.ts b/electron/main/data/ipcEvent.ts new file mode 100644 index 0000000..01450ec --- /dev/null +++ b/electron/main/data/ipcEvent.ts @@ -0,0 +1,75 @@ +import { dialog, ipcMain } from "electron"; +import { backupData, createBackupRestoreDataWindow } from "."; +import { closeWindow, relaunch, showErrorMessageBox } from "../commons"; +import { restore } from "./data"; + +export default function () { + // 创建备份/恢复数据窗口 + ipcMain.on("createBackupRestoreDataWindow", (event, args) => { + createBackupRestoreDataWindow(); + }); + // 显示备份/恢复数据窗口 + ipcMain.on("showBackupRestoreDataWindow", (event, args) => { + if (global.backupRestoreDataWindow) { + global.backupRestoreDataWindow.show(); + } + }); + // 关闭备份/恢复数据窗口 + ipcMain.on("closeBackupRestoreDataWindow", (event, args) => { + closeWindow(global.backupRestoreDataWindow); + }); + // 备份数据 + ipcMain.on("backupData", () => { + try { + let filePath = dialog.showSaveDialogSync(global.backupRestoreDataWindow, { + defaultPath: "Data", + filters: [{ name: "DB", extensions: ["db"] }], + }); + if (filePath && filePath.trim() !== "") { + backupData(filePath).finally(() => { + // 关闭备份/恢复窗口 + closeWindow(global.backupRestoreDataWindow); + }); + } + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + } + }); + // 恢复数据 + ipcMain.on("restoreData", () => { + try { + let filePathList = dialog.showOpenDialogSync( + global.backupRestoreDataWindow, + { + filters: [{ name: "Data", extensions: ["db", "json"] }], + } + ); + if (filePathList && filePathList.length > 0) { + let filePath = filePathList[0]; + if (restore(filePath)) { + // 清空localStorage + global.mainWindow.webContents.session.clearStorageData({ + storages: ["localstorage"], + }); + // 重新启动程序 + relaunch(); + } else { + showErrorMessageBox( + "backupRestoreDataWindow", + global.language.restoreDataPrompt + ); + } + } + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + showErrorMessageBox( + "backupRestoreDataWindow", + global.language.restoreDataPrompt + ); + } + }); +} diff --git a/electron/main/index.ts b/electron/main/index.ts new file mode 100644 index 0000000..d55b408 --- /dev/null +++ b/electron/main/index.ts @@ -0,0 +1,159 @@ +import { app, BrowserWindow, dialog } from "electron"; +import { release } from "node:os"; +import { join, dirname } from "node:path"; +import indexIpcEvent from "./main/ipcEvent"; +import classificationIpcEvent from "./classification/ipcEvent"; +import { init as classificationDataInit } from "./classification/data"; +import { init as itemDataInit } from "./item/data"; +import { initSystemItem } from "./item/commons/data"; +import commonIpcEvent from "./commons/ipcEvent"; +import itemIpcEvent from "./item/ipcEvent"; +import settingIpcEvent from "./setting/ipcEvent"; +import { init as settingDataInit } from "./setting/data"; +import { setShortcutKey } from "./setting"; +import searchIpcEvent from "./search/ipcEvent"; +import { createMainWindow } from "./main"; +import { closeAllChildProcess } from "./commons"; +import { createQuickSearchWindow } from "./search"; +import { getLanguage } from "../../commons/data/languages"; +import aboutIpcEvent from "./about/ipcEvent"; +import dataIpcEvent from "./data/ipcEvent"; + +// 数据存储目录 +if ( + process.env.NODE_ENV !== "development" && + import.meta.env.VITE_INSTALL === "false" +) { + app.setPath("appData", join(dirname(process.execPath), "data")); + app.setPath("userData", join(dirname(process.execPath), "data")); +} + +process.env.DIST_ELECTRON = join(__dirname, ".."); +process.env.DIST = join(process.env.DIST_ELECTRON, "../dist"); +process.env.VITE_PUBLIC = process.env.VITE_DEV_SERVER_URL + ? join(process.env.DIST_ELECTRON, "../public") + : process.env.DIST; + +// Disable GPU Acceleration for Windows 7 +if (release().startsWith("6.1")) app.disableHardwareAcceleration(); + +// Set application name for Windows 10+ notifications +if (process.platform === "win32") app.setAppUserModelId(app.getName()); + +if (!app.requestSingleInstanceLock()) { + app.quit(); + process.exit(0); +} + +// Remove electron security warnings +// This warning only shows in development mode +// Read more on https://www.electronjs.org/docs/latest/tutorial/security +// process.env['ELECTRON_DISABLE_SECURITY_WARNINGS'] = 'true' +app.whenReady().then(() => { + try { + // addon + global.addon = require("../../native/addon.node"); + // 初始化数据 + settingDataInit(); + // 获取语言 + global.language = getLanguage(global.setting.general.language); + // 禁用debugtron + for (let i = 0; i < process.argv.length; i++) { + const arg = process.argv[i]; + if ( + arg.indexOf("--inspect") !== -1 || + arg.indexOf("--remote-debugging-port") !== -1 + ) { + dialog.showMessageBoxSync(null, { + message: "达咩呦达咩达咩~", + buttons: [global.language.ok], + type: "error", + noLink: true, + }); + app.quit(); + return; + } + } + // 禁止多开 + const instanceLock = app.requestSingleInstanceLock(); + if (!instanceLock) { + app.quit(); + return; + } + // 初始化数据 + classificationDataInit(); + itemDataInit(); + initSystemItem(); + // 初始化监听 + indexIpcEvent(); + commonIpcEvent(); + classificationIpcEvent(); + itemIpcEvent(); + settingIpcEvent(); + searchIpcEvent(); + aboutIpcEvent(); + dataIpcEvent(); + // 创建主窗口 + createMainWindow(); + if (global.setting.quickSearch.enable) { + // 创建快速搜索窗口 + createQuickSearchWindow(); + } + // 设置快捷键 + setShortcutKey(); + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } else { + dialog.showMessageBoxSync({ + type: "error", + title: "Dawn Launcher", + message: e.stack, + }); + app.quit(); + } + } +}); + +// 全局异常 +process.on("uncaughtException", (err) => { + dialog.showMessageBoxSync({ + type: "error", + title: "Dawn Launcher", + message: err.stack, + }); + // 关闭所有子进程 + closeAllChildProcess(); + // 退出 + app.quit(); +}); + +app.on("before-quit", () => { + // 关闭所有子进程 + closeAllChildProcess(); +}); + +app.on("window-all-closed", () => { + if (process.platform !== "darwin") app.quit(); +}); + +app.on("second-instance", () => { + if (mainWindow) { + if (!mainWindow.isVisible()) { + mainWindow.show(); + mainWindow.focus(); + global.blurHide = true; + } else { + mainWindow.focus(); + } + } +}); + +app.on("activate", () => { + const allWindows = BrowserWindow.getAllWindows(); + if (allWindows.length) { + allWindows[0].focus(); + } else { + createMainWindow(); + } +}); diff --git a/electron/main/item/commons/data.ts b/electron/main/item/commons/data.ts new file mode 100644 index 0000000..dc0ac54 --- /dev/null +++ b/electron/main/item/commons/data.ts @@ -0,0 +1,561 @@ +import { CommonItem } from "../../../../types/item"; +import { + newCommonItem, + newCommonItemData, +} from "../../../../commons/utils/common"; +import { + calcIcon, + fileExplorerIcon, + networkSharingCenterIcon, + powerIcon, +} from "../../../commons/constants"; +import { getCacheDataSqlite3 } from "../../../commons/betterSqlite3"; + +// 获取数据库 +let db = getCacheDataSqlite3(); + +// 系统项目表名 +let systenItemTableName = "system_item"; + +// 开始菜单项目表名 +let startMenuItemTableName = "start_menu_item"; + +/** + * 通用项目 + */ +function getCommonItem(row: any): CommonItem { + let data = JSON.parse(row.data); + return newCommonItem({ + id: row.id, + name: row.name, + data: newCommonItemData({ + target: data.target, + params: data.params, + icon: data.icon, + htmlIcon: data.htmlIcon, + }), + }); +} + +/** + * 初始化系统项目表 + */ +function initSystemItemTable() { + // sql + let sql = `CREATE TABLE IF NOT EXISTS ${systenItemTableName} ( + id INTEGER PRIMARY KEY, + name TEXT NOT NULL, + data TEXT NOT NULL, + \`order\` INTEGER NOT NULL)`; + // 运行 + db.exec(sql); +} + +/** + * 初始化系统项目 + */ +function initSystemItem() { + // 初始化表 + initSystemItemTable(); + // 初始化数据 + // 计算机 + let computer = selectById(systenItemTableName, 1); + if (!computer) { + let icon: string | null = global.addon.getFileIcon( + "shell:MyComputerFolder" + ); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 1, + name: global.language.computer, + data: newCommonItemData({ + target: "shell:MyComputerFolder", + icon: icon, + }), + order: 1, + }) + ); + } + } + // 文档 + let document = selectById(systenItemTableName, 2); + if (!document) { + let icon: string | null = global.addon.getFileIcon("shell:Local Documents"); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 2, + name: global.language.documents, + data: newCommonItemData({ + target: "shell:Local Documents", + icon: icon, + }), + order: 2, + }) + ); + } + } + // 控制面板 + let controlPanel = selectById(systenItemTableName, 3); + if (!controlPanel) { + let icon: string | null = global.addon.getFileIcon( + "shell:ControlPanelFolder" + ); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 3, + name: global.language.controlPanel, + data: newCommonItemData({ + target: "shell:ControlPanelFolder", + icon: icon, + }), + order: 3, + }) + ); + } + } + // 网络和共享中心 + let networkSharingCenter = selectById(systenItemTableName, 4); + if (!networkSharingCenter) { + add( + systenItemTableName, + newCommonItem({ + id: 4, + name: global.language.networkShareCenter, + data: newCommonItemData({ + target: "control.exe", + params: "/name Microsoft.NetworkAndSharingCenter", + icon: networkSharingCenterIcon, + }), + order: 4, + }) + ); + } + // 回收站 + let recyleBin = selectById(systenItemTableName, 5); + if (!recyleBin) { + let icon: string | null = global.addon.getFileIcon( + "shell:RecycleBinFolder" + ); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 5, + name: global.language.recycleBin, + data: newCommonItemData({ + target: "shell:RecycleBinFolder", + icon: icon, + }), + order: 5, + }) + ); + } + } + // 文件资源管理器 + let fileExplorer = selectById(systenItemTableName, 6); + if (!fileExplorer) { + add( + systenItemTableName, + newCommonItem({ + id: 6, + name: global.language.fileExplorer, + data: newCommonItemData({ + target: "control.exe", + params: "folders", + icon: fileExplorerIcon, + }), + order: 6, + }) + ); + } + // 程序和功能 + let programFeatures = selectById(systenItemTableName, 7); + if (!programFeatures) { + let icon: string | null = global.addon.getFileIcon( + "shell:ChangeRemoveProgramsFolder" + ); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 7, + name: global.language.programsFeatures, + data: newCommonItemData({ + target: "shell:ChangeRemoveProgramsFolder", + icon: icon, + }), + order: 7, + }) + ); + } + } + // 文件资源管理器 + let calc = selectById(systenItemTableName, 8); + if (!calc) { + add( + systenItemTableName, + newCommonItem({ + id: 8, + name: global.language.calculator, + data: newCommonItemData({ + target: "calc.exe", + icon: calcIcon, + }), + order: 8, + }) + ); + } + // 服务 + let services = selectById(systenItemTableName, 9); + if (!services) { + let path: string | null = global.addon.searchPath("services.msc"); + if (path) { + let icon: string | null = global.addon.getFileIcon(path); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 9, + name: global.language.services, + data: newCommonItemData({ + target: "services.msc", + icon: icon, + }), + order: 9, + }) + ); + } + } + } + // 命令提示符 + let cmd = selectById(systenItemTableName, 10); + if (!cmd) { + let path: string | null = global.addon.searchPath("cmd.exe"); + if (path) { + let icon: string | null = global.addon.getFileIcon(path); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 10, + name: global.language.commandPrompt, + data: newCommonItemData({ + target: "cmd.exe", + icon: icon, + }), + order: 10, + }) + ); + } + } + } + // 任务管理器 + let taskmgr = selectById(systenItemTableName, 11); + if (!taskmgr) { + let path: string | null = global.addon.searchPath("taskmgr.exe"); + if (path) { + let icon: string | null = global.addon.getFileIcon(path); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 11, + name: global.language.taskManager, + data: newCommonItemData({ + target: "taskmgr.exe", + icon: icon, + }), + order: 11, + }) + ); + } + } + } + // 注册表编辑 + let regedit = selectById(systenItemTableName, 12); + if (!regedit) { + let path: string | null = global.addon.searchPath("regedit.exe"); + if (path) { + let icon: string | null = global.addon.getFileIcon(path); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 12, + name: global.language.registryEditor, + data: newCommonItemData({ + target: "regedit.exe", + icon: icon, + }), + order: 12, + }) + ); + } + } + } + // 电源选项 + let powercfg = selectById(systenItemTableName, 13); + if (!powercfg) { + add( + systenItemTableName, + newCommonItem({ + id: 13, + name: global.language.powerOptions, + data: newCommonItemData({ + target: "control.exe", + params: "powercfg.cpl", + icon: powerIcon, + }), + order: 13, + }) + ); + } + // 资源监视器 + let perfmon = selectById(systenItemTableName, 14); + if (!perfmon) { + let path: string | null = global.addon.searchPath("perfmon.exe"); + if (path) { + let icon: string | null = global.addon.getFileIcon(path); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 14, + name: global.language.resourceMonitor, + data: newCommonItemData({ + target: "perfmon.exe", + params: "/res", + icon: icon, + }), + order: 14, + }) + ); + } + } + } + // 计算机管理 + let compmgmt = selectById(systenItemTableName, 15); + if (!compmgmt) { + let path: string | null = global.addon.searchPath("compmgmt.msc"); + if (path) { + let icon: string | null = global.addon.getFileIcon(path); + if (icon) { + add( + systenItemTableName, + newCommonItem({ + id: 15, + name: global.language.computerManagement, + data: newCommonItemData({ + target: "compmgmt.msc", + params: "/s", + icon: icon, + }), + order: 15, + }) + ); + } + } + } + // 关机 + let shutdown = selectById(systenItemTableName, 16); + if (!shutdown) { + add( + systenItemTableName, + newCommonItem({ + id: 16, + name: global.language.shutdown, + data: newCommonItemData({ + target: "shutdown", + params: "-s -t 0", + htmlIcon: + '', + }), + order: 16, + }) + ); + } + // 重启 + let restart = selectById(systenItemTableName, 17); + if (!restart) { + add( + systenItemTableName, + newCommonItem({ + id: 17, + name: global.language.restart, + data: newCommonItemData({ + target: "shutdown", + params: "-r -t 0", + htmlIcon: + '', + }), + order: 17, + }) + ); + } + // 睡眠 + let sleep = selectById(systenItemTableName, 18); + if (!sleep) { + add( + systenItemTableName, + newCommonItem({ + id: 18, + name: global.language.sleep, + data: newCommonItemData({ + target: "rundll32.exe", + params: "powrprof.dll, SetSuspendState Sleep", + htmlIcon: + '', + }), + order: 18, + }) + ); + } + // 锁定 + let lock = selectById(systenItemTableName, 19); + if (!lock) { + add( + systenItemTableName, + newCommonItem({ + id: 19, + name: global.language.lock, + data: newCommonItemData({ + target: "rundll32.exe", + params: "user32.dll LockWorkStation", + htmlIcon: + '', + }), + order: 19, + }) + ); + } + // 关闭显示器 + let turnOffMonitor = selectById(systenItemTableName, 20); + if (!turnOffMonitor) { + add( + systenItemTableName, + newCommonItem({ + id: 20, + name: global.language.turnOffMonitor, + data: newCommonItemData({ + target: "static:TurnOffMonitor", + htmlIcon: + '', + }), + order: 20, + }) + ); + } +} + +/** + * 初始化开始菜单项目表 + */ +function initStartMenuItemTable() { + // sql + let sql = `CREATE TABLE IF NOT EXISTS ${startMenuItemTableName} ( + id INTEGER PRIMARY KEY, + name TEXT NOT NULL, + data TEXT NOT NULL, + \`order\` INTEGER NOT NULL)`; + // 运行 + db.exec(sql); +} + +/** + * 列表 + * @param table + */ +function list(table: string) { + // sql + let sql = `SELECT id, name, data, \`order\` FROM ${table}`; + // 查询 + let list = db.prepare(sql).all(); + // 返回 + return list.map((row) => { + return getCommonItem(row); + }); +} + +/** + * 根据ID查询 + * @param table + * @param id + */ +function selectById(table: string, id: number): CommonItem | null { + // SQL + let sql = `SELECT id, name, data, \`order\` FROM ${table} WHERE id = ?`; + // 运行 + let row = db.prepare(sql).get(id); + // 返回 + if (row) { + return getCommonItem(row); + } else { + return null; + } +} + +/** + * 添加 + * @param table + * @param commonItem + * @returns + */ +function add(table: string, commonItem: CommonItem) { + // SQL + let sql = `INSERT INTO ${table} (id, name, data, \`order\`) VALUES (?, ?, ?, ?)`; + // 运行 + db.prepare(sql).run( + commonItem.id, + commonItem.name, + JSON.stringify(commonItem.data), + commonItem.order + ); +} + +/** + * 删除所有数据 + * @param table + */ +function deleteAll(table: string) { + // SQL + let sql = `DELETE FROM ${table}`; + // 运行 + db.prepare(sql).run(); +} + +/** + * 批量添加 + * @param list + */ +function batchAdd(list: Array) { + // 开启事务 + db.transaction(() => { + // SQL + let sql = `INSERT INTO ${startMenuItemTableName} VALUES(?, ?, ?, ?)`; + // 添加到缓存表中 + for (let i = 0; i < list.length; i++) { + db.prepare(sql).run( + i + 1, + list[i].name, + JSON.stringify(list[i].data), + i + 1 + ); + } + })(); +} + +export { + systenItemTableName, + startMenuItemTableName, + initSystemItem, + initStartMenuItemTable, + list, + deleteAll, + batchAdd, +}; diff --git a/electron/main/item/commons/index.ts b/electron/main/item/commons/index.ts new file mode 100644 index 0000000..cb0adb0 --- /dev/null +++ b/electron/main/item/commons/index.ts @@ -0,0 +1,60 @@ +import { release } from "node:os"; +import { + batchAdd, + deleteAll, + initStartMenuItemTable, + initSystemItem, + list, + startMenuItemTableName, + systenItemTableName, +} from "./data"; +import { CommonItem } from "../../../../types/item"; +import { fork } from "../../../commons/utilityProcessUtils"; +import { sendToWebContent } from "../../commons"; + +/** + * 获取系统项目 + */ +function getSystemItemList() { + initSystemItem(); + return list(systenItemTableName); +} + +/** + * 获取开始菜单项目列表 + */ +function getStartMenuItemList() { + // 初始化表 + initStartMenuItemTable(); + // 查询缓存 + let cacheList = list(startMenuItemTableName); + // 清空表 + deleteAll(startMenuItemTableName); + // 子进程 + fork("getStartMenuItemList", cacheList, (resultList: Array) => { + // 添加缓存 + batchAdd(resultList); + // 发送消息到页面 + sendToWebContent("itemAddEditWindow", "onGetStartMenuItemList", resultList); + }); +} + +/** + * APPX项目 + */ +function getAppxItemList() { + // 大于win10才有APPX + let releaseArr = release().split("."); + if (Number(releaseArr[0]) >= 10) { + // 子进程 + fork("getAppxItemList", {}, (resultList: Array) => { + // 发送消息到页面 + sendToWebContent("itemAddEditWindow", "onGetAppxItemList", resultList); + }); + } else { + // 发送消息到页面 + sendToWebContent("itemAddEditWindow", "onGetAppxItemList", []); + } +} + +export { getSystemItemList, getStartMenuItemList, getAppxItemList }; diff --git a/electron/main/item/data.ts b/electron/main/item/data.ts new file mode 100644 index 0000000..af7a09f --- /dev/null +++ b/electron/main/item/data.ts @@ -0,0 +1,427 @@ +import { Item, ItemData } from "../../../types/item"; +import { newItem, newItemData } from "../../../commons/utils/common"; +import { list as selectClassificationList } from "../classification/data"; +import { getDataSqlite3 } from "../../commons/betterSqlite3"; + +// 获取数据库 +let db = getDataSqlite3(); + +// 项目表名 +let itemTableName = "item"; + +// 查询字段 +let selectColumn = + "id, classification_id classificationId, name, type, data, shortcut_key shortcutKey, global_shortcut_key globalShortcutKey, `order`"; +let simpleSelectColumn = + "id, classification_id classificationId, name, type, shortcut_key shortcutKey, global_shortcut_key globalShortcutKey, `order`"; + +/** + * 项目 + */ +function getItem(row: any): Item { + return newItem({ + id: row.id, + classificationId: row.classificationId, + name: row.name, + type: row.type, + data: newItemData(row.data ? JSON.parse(row.data) : {}), + shortcutKey: row.shortcutKey, + globalShortcutKey: row.globalShortcutKey === 1, + order: row.order, + }); +} + +/** + * 初始化项目表 + */ +function init() { + // sql + let sql = `CREATE TABLE IF NOT EXISTS ${itemTableName} ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + classification_id INTEGER NOT NULL, + name TEXT NOT NULL, + type INTEGER NOT NULL, + data TEXT NOT NULL, + shortcut_key TEXT, + global_shortcut_key INTEGER NOT NULL, + \`order\` INTEGER NOT NULL)`; + // 运行 + db.exec(sql); +} + +/** + * 添加 + * @param item + * @param reuseId + */ +function add(item: Item, reuseId: boolean = false) { + // 获取序号 + let newOrder = getMaxOrder(item.classificationId) + 1; + // SQL + let sql = `INSERT INTO ${itemTableName} + (classification_id, name, type, data, shortcut_key, global_shortcut_key, \`order\`) + VALUES (?, ?, ?, ?, ?, ?, ?)`; + // 参数 + let params = [ + item.classificationId, + item.name, + item.type, + JSON.stringify(item.data), + item.shortcutKey, + item.globalShortcutKey ? 1 : 0, + newOrder, + ]; + // 重复使用ID + if (reuseId && item.id) { + sql = `INSERT INTO ${itemTableName} + (id, classification_id, name, type, data, shortcut_key, global_shortcut_key, \`order\`) + VALUES (?, ?, ?, ?, ?, ?, ?, ?)`; + params.unshift(item.id); + } + // 运行 + let id = db.prepare(sql).run(params).lastInsertRowid as number; + if (id) { + item.id = id; + item.order = newOrder; + return item; + } + return null; +} + +/** + * 批量添加 + * @param classificationId + * @param itemList + * @param reuseId + */ +function batchAdd( + classificationId: number, + itemList: Array, + reuseId: boolean = false +) { + // 返回信息 + let resultList: Array = []; + // 事务 + db.transaction(() => { + // 获取序号 + let newOrder = getMaxOrder(classificationId) + 1; + // 循环添加 + for (let item of itemList) { + // SQL + let sql = `INSERT INTO ${itemTableName} + (classification_id, name, type, data, shortcut_key, global_shortcut_key, \`order\`) + VALUES (?, ?, ?, ?, ?, ?, ?)`; + // 参数 + let params = [ + classificationId, + item.name, + item.type, + JSON.stringify(item.data), + item.shortcutKey, + item.globalShortcutKey ? 1 : 0, + newOrder, + ]; + // 重复使用ID + if (reuseId && item.id) { + sql = `INSERT INTO ${itemTableName} + (id, classification_id, name, type, data, shortcut_key, global_shortcut_key, \`order\`) + VALUES (?, ?, ?, ?, ?, ?, ?, ?)`; + params.unshift(item.id); + } + // 运行 + let id = db.prepare(sql).run(params).lastInsertRowid as number; + if (id) { + item.id = id; + item.order = newOrder; + resultList.push(item); + } + newOrder++; + } + })(); + return resultList; +} + +/** + * 更新 + * @param item + */ +function update(item: Item) { + // SQL + let sql = `UPDATE ${itemTableName} + SET name = ?, + data = ?, + shortcut_key = ?, + global_shortcut_key = ? + WHERE id = ?`; + // 运行 + return ( + db + .prepare(sql) + .run( + item.name, + JSON.stringify(item.data), + item.shortcutKey, + item.globalShortcutKey ? 1 : 0, + item.id + ).changes > 0 + ); +} + +/** + * 更新分类ID + * @param oldClassificationId + * @param newlassificationId + */ +function updateClassificationId( + oldClassificationId: number, + newClassificationId: number +) { + // SQL + let sql = `UPDATE ${itemTableName} + SET classification_id = ? + WHERE classification_id = ?`; + // 运行 + return ( + db.prepare(sql).run(newClassificationId, oldClassificationId).changes > 0 + ); +} + +/** + * 更新数据 + * @param id + * @param itemData + */ +function updateData(id: number, itemData: ItemData) { + // SQL + let sql = `UPDATE ${itemTableName} + SET data = ? + WHERE id = ?`; + // 运行 + return db.prepare(sql).run(JSON.stringify(itemData), id).changes > 0; +} + +/** + * 查询最大序号 + * @param classificationId + */ +function getMaxOrder(classificationId: number) { + // SQL + let sql = `SELECT MAX(\`order\`) \`order\` FROM ${itemTableName} WHERE classification_id = ?`; + // 运行 + let row: any = db.prepare(sql).get(classificationId); + if (row && row.order) { + return row.order; + } else { + return 0; + } +} + +/** + * 根据ID查询 + * @param id + */ +function selectById(id: number): Item | null { + // SQL + let sql = `SELECT ${selectColumn} FROM ${itemTableName} WHERE id = ?`; + // 运行 + let row = db.prepare(sql).get(id); + // 返回 + if (row) { + return getItem(row); + } else { + return null; + } +} + +/** + * 列表 + * @param simple + * @param classificationId + */ +function list(simple: boolean = false, classificationId: number | null = null) { + // 参数 + let params = []; + // sql + let sql = `SELECT ${ + simple ? simpleSelectColumn : selectColumn + } FROM ${itemTableName}`; + if (classificationId) { + sql += " WHERE classification_id = ?"; + params.push(classificationId); + } + sql += " ORDER BY `order` ASC"; + // 查询 + let list = db.prepare(sql).all(params); + // 返回 + return list.map((row) => { + return getItem(row); + }); +} + +/** + * 根据ID列表查询 + * @param simple + * @param idList + */ +function selectByIdList(simple: boolean, idList: Array) { + // 参数 + let params = []; + // sql + let sql = `SELECT ${ + simple ? simpleSelectColumn : selectColumn + } FROM ${itemTableName} WHERE id IN (`; + for (let i = 0; i < idList.length; i++) { + sql += "?"; + if (i !== idList.length - 1) { + sql += ","; + } + params.push(idList[i]); + } + sql += ")"; + // 查询 + let list = db.prepare(sql).all(params); + // 转为Item + let itemList = list.map((row) => { + return getItem(row); + }); + // 返回列表 + let resultList: Array = []; + // 根据传入的参数排序 + for (const id of idList) { + for (const item of itemList) { + if (id === item.id) { + resultList.push(item); + break; + } + } + } + return resultList; +} + +/** + * 删除 + * @param id + */ +function del(id: number) { + // 查询数据 + let item = selectById(id); + if (item) { + // SQL + let sql = `DELETE FROM ${itemTableName} WHERE id = ?`; + // 运行 + let res = db.prepare(sql).run(id).changes > 0; + if (res) { + // 更新序号 + reorder(item.classificationId); + return true; + } else { + return false; + } + } else { + return false; + } +} + +/** + * 删除 + * @param classificationId + */ +function deleteByClassificationId(classificationId: number) { + // SQL + let sql = `DELETE FROM ${itemTableName} WHERE classification_id = ?`; + // 运行 + return db.prepare(sql).run(classificationId).changes > 0; +} + +/** + * 重新排序 + * @param classification_id + */ +function reorder(classification_id: number) { + // 查询项目列表 + let itemList = list(true, classification_id); + // 开启事务 + db.transaction(() => { + // SQL + let sql = `UPDATE ${itemTableName} SET \`order\` = ? WHERE id = ?`; + // 更新序号 + for (let i = 0; i < itemList.length; i++) { + db.prepare(sql).run(i + 1, itemList[i].id); + } + })(); +} + +/** + * 项目排序 + * @param fromIdList + * @param toClassificationId + * @param toId + */ +function updateOrder( + fromIdList: Array, + toClassificationId: number, + newIndex: number | null +) { + // 查询来源项目 + let fromItemList = selectByIdList(true, fromIdList); + if (fromItemList.length > 0) { + // 查询目标分类是否是父级分类,如果是父级分类的话,获取他下面的第一个子分类 + let classificationList = selectClassificationList(toClassificationId); + if (classificationList.length > 0) { + toClassificationId = classificationList[0].id; + } + // 记录来源项目都是来源于哪些分类,需要重新排序 + let fromClassificationIdList = []; + for (const item of fromItemList) { + if ( + item.classificationId !== toClassificationId && + !fromClassificationIdList.includes(item.classificationId) + ) { + fromClassificationIdList.push(item.classificationId); + } + } + // 查询目标项目列表 + let toItemList = list(true, toClassificationId); + // 来源项目分类可能和目标项目分类是一样的,首先先从目标项目列表去掉来源项目 + for (const id of fromIdList) { + toItemList = toItemList.filter((item) => item.id !== id); + } + // 将来源项目插入到目标项目列表 + if (newIndex !== null) { + toItemList.splice(newIndex, 0, ...fromItemList); + } else { + // 尾部追加 + toItemList.push(...fromItemList); + } + // 开启事务 + db.transaction(() => { + // SQL + let sql = `UPDATE ${itemTableName} SET \`order\` = ?, classification_id = ? WHERE id = ?`; + // 更新序号 + for (let i = 0; i < toItemList.length; i++) { + db.prepare(sql).run(i + 1, toClassificationId, toItemList[i].id); + } + })(); + // 重排序其来源分类项目列表 + for (const id of fromClassificationIdList) { + reorder(id); + } + return true; + } + return false; +} + +export { + init, + list, + add, + batchAdd, + update, + del, + selectById, + selectByIdList, + deleteByClassificationId, + updateOrder, + updateData, + updateClassificationId, +}; diff --git a/electron/main/item/index.ts b/electron/main/item/index.ts new file mode 100644 index 0000000..54fda4b --- /dev/null +++ b/electron/main/item/index.ts @@ -0,0 +1,687 @@ +import { BrowserWindow, shell, dialog, app } from "electron"; +import { join } from "node:path"; +import { getAbsolutePath, getURLParams } from "../../commons/utils"; +import { Item } from "../../../types/item"; +import { + batchAdd, + deleteByClassificationId, + list, + selectById, + selectByIdList, + updateData, + updateOrder, +} from "./data"; +import { accessSync, writeFile, statSync, readFileSync } from "node:fs"; +import mime from "mime"; +import { + deleteExtname, + getItemName, + isAbsolutePath, +} from "../../../commons/utils/common"; +import { iconExts } from "../../commons/utils"; +import { addAssociateFolderWatcher } from "../classification"; +import { + closeWindow, + convertPath, + getMainBackgorunColor, + sendToWebContent, +} from "../commons/index"; +import { fork } from "../../commons/utilityProcessUtils"; + +// 窗口 +let itemAddEditWindow: BrowserWindow | null = null; +let itemNetworkIconWindow: BrowserWindow | null = null; +let itemSVGIconWindow: BrowserWindow | null = null; + +/** + * 添加/修改窗口 + * @param id + * @param classificationId + */ +async function createAddEditWindow( + id: number | null, + classificationId: number | null +) { + // 如果窗口存在先关闭窗口 + closeWindow(itemAddEditWindow); + // 创建窗口 + itemAddEditWindow = global.itemAddEditWindow = new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.mainWindow, + height: 500, + width: 600, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + // 参数 + let params = new Map(); + if (id) { + params.set("id", id); + } + if (classificationId) { + params.set("classificationId", classificationId); + } + if (process.env.VITE_DEV_SERVER_URL) { + itemAddEditWindow.loadURL( + process.env.VITE_DEV_SERVER_URL + "item/AddEdit" + getURLParams(params) + ); + } else { + itemAddEditWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/item/AddEdit", + search: getURLParams(params), + }); + } + itemAddEditWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + itemAddEditWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + itemAddEditWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + itemAddEditWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 网络图标窗口 + */ +async function createNetworkIconWindow() { + // 如果窗口存在先关闭窗口 + closeWindow(itemNetworkIconWindow); + // 创建窗口 + itemNetworkIconWindow = global.itemNetworkIconWindow = new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.itemAddEditWindow, + height: 230, + width: 400, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + if (process.env.VITE_DEV_SERVER_URL) { + itemNetworkIconWindow.loadURL( + process.env.VITE_DEV_SERVER_URL + "item/NetworkIcon" + ); + } else { + itemNetworkIconWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/item/NetworkIcon", + }); + } + itemNetworkIconWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + itemNetworkIconWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + itemNetworkIconWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + itemNetworkIconWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * SVG图标窗口 + */ +async function createSVGIconWindow() { + // 如果窗口存在先关闭窗口 + closeWindow(itemSVGIconWindow); + // 创建窗口 + itemSVGIconWindow = global.itemSVGIconWindow = new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.itemAddEditWindow, + height: 230, + width: 400, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + focusable: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + if (process.env.VITE_DEV_SERVER_URL) { + itemSVGIconWindow.loadURL(process.env.VITE_DEV_SERVER_URL + "item/SVGIcon"); + } else { + itemSVGIconWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/item/SVGIcon", + }); + } + itemSVGIconWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + itemSVGIconWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + itemSVGIconWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + itemSVGIconWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 复制项目 + * @param idList + * @param toClassificationId + */ +function copy(idList: Array, toClassificationId: number) { + // 返回列表 + let resultList: Array = []; + // 查询项目 + let itemList = selectByIdList(false, idList); + if (itemList.length > 0) { + // 清空打开信息 + resultList.forEach((item) => clearOpenInfo(item)); + // 批量添加 + resultList = batchAdd(toClassificationId, itemList); + } + if (resultList.length > 0) { + // 通知前端 + sendToWebContent("mainWindow", "onAddItem", { + itemList: resultList, + clear: false, + classificationId: null, + }); + } +} + +/** + * 复制/移动项目 + * @param idList + * @param toClassificationId + */ +function move(idList: Array, toClassificationId: number) { + // 移动项目 + let res = updateOrder(idList, toClassificationId, null); + if (res) { + // 通知前端 + sendToWebContent("mainWindow", "onMoveItem", { + idList, + toClassificationId, + }); + } +} + +/** + * 拖入项目 + * @param classificationId + * @param pathList + */ +function drop(classificationId: number, pathList: Array) { + fork( + "getDropItemInfo", + { + classificationId, + pathList, + }, + (resultList: Array) => { + // 添加项目 + let itemList = batchAdd(classificationId, resultList); + // 发送消息到页面 + sendToWebContent("mainWindow", "onAddItem", { + itemList, + clear: false, + classificationId: null, + }); + } + ); +} + +/** + * 更新项目打开信息 + * @param type + * @param id + */ +function updateOpenInfo(type: string, id: number) { + // 查询项目 + let curItem = selectById(id); + if (curItem) { + if (type === "main" || type === "search") { + // 记录打开信息 + curItem.data.lastOpen = new Date().getTime(); + // 记录打开次数 + if (global.setting.item.openNumber) { + curItem.data.openNumber += 1; + } + } else if (type === "quickSearch") { + // 记录打开信息 + curItem.data.quickSearchLastOpen = new Date().getTime(); + // 记录打开次数 + curItem.data.quickSearchOpenNumber += 1; + } + if (updateData(curItem.id, curItem.data)) { + sendToWebContent("mainWindow", "onUpdateOpenInfo", { + id: curItem.id, + openNumber: curItem.data.openNumber, + lastOpen: curItem.data.lastOpen, + quickSearchOpenNumber: curItem.data.quickSearchOpenNumber, + quickSearchLastOpen: curItem.data.quickSearchLastOpen, + type, + }); + } + } +} + +/** + * 运行项目 + * @param type + * @param operation + * @param item + */ +function run( + type: string, + operation: "open" | "runas" | "openFileLocation", + item: Item +) { + if (item.data) { + // 更新打开信息 + updateOpenInfo(type, item.id); + // 判断类型 + if (item.type === 2) { + // 网址 + shell.openExternal(item.data.target); + } else if (item.type === 3 || item.type === 4) { + // 系统 或 appx + global.addon.systemItemExecute(item.data.target, item.data.params); + } else { + // 获取绝对路径 + if (item.type === 0 || item.type === 1) { + // 获取路径 + item.data.target = getAbsolutePath(item.data.target); + } + try { + // 判断文件或文件夹是否存在 + accessSync(item.data.target); + // 存在 + if (operation === "openFileLocation") { + // 打开文件所在位置 + global.addon.openFileLocation(item.data.target); + } else { + // 运行 + global.addon.shellExecute( + operation, + item.data.target, + item.data.params ?? "", + item.data.startLocation + ); + } + } catch (e) { + let message: string | null = null; + if (item.type === 0 && operation !== "openFileLocation") { + message = global.language.notFoundFile; + } else { + message = global.language.notFoundFolder; + } + message += '"' + item.data.target + '"'; + dialog.showMessageBox(global.mainWindow, { + title: "Dawn Launcher", + message: message, + buttons: [global.language.ok], + type: "error", + noLink: true, + }); + } + } + } +} + +/** + * 转换目标路径 + * @param idList + * @param type + */ +function convertTarget(idList: Array, type: "Absolute" | "Relative") { + // 返回数据 + let resultList = []; + // 查询数据 + let itemList = selectByIdList(false, idList); + for (let item of itemList) { + // 是否是绝对路径 + let isAbsolute = isAbsolutePath(item.data.target); + // 如果是绝对路径并且type是Relative,就转为相对路径 + // 如果不是绝对路径并且type是Absolute,就转为绝对路径 + if ( + (isAbsolute && type === "Relative") || + (!isAbsolute && type === "Absolute") + ) { + // 转换路径 + item.data.target = convertPath(item.data.target); + // 更新 + updateData(item.id, item.data); + // push + resultList.push({ + id: item.id, + target: item.data.target, + }); + } + } + // 通知页面 + sendToWebContent("mainWindow", "onConvertPath", resultList); +} + +/** + * 导出图标 + * @param item + */ +function exportIcon(item: Item) { + if (item.data.icon || item.data.htmlIcon) { + // SVG代码图标 + let svgCode = false; + // 拓展名 + let extensionName: string | null = null; + // 内容 + let content: string | null = null; + if (item.data.htmlIcon && item.data.htmlIcon.trim() !== "") { + // 保存为SVG图片 + svgCode = true; + extensionName = "svg"; + content = item.data.htmlIcon.trim(); + } else if (item.data.icon && item.data.icon.trim() !== "") { + // 提取base64类型 + let re = new RegExp("data:(?.*?);base64,.*"); + let res = re.exec(item.data.icon); + if (res && res.groups) { + // 获取拓展名 + extensionName = mime.getExtension(res.groups.ext); + if (item.data.icon.trim().split(",").length === 2) { + content = item.data.icon.trim().split(",")[1]; + } + } + } + // 弹出文件对话框保存 + if (extensionName && content) { + let path = dialog.showSaveDialogSync(global.mainWindow, { + defaultPath: "icon", + filters: [ + { + name: extensionName, + extensions: [extensionName], + }, + ], + }); + // 保存 + if (path) { + if (svgCode) { + writeFile(path, content, function (err) {}); + } else { + let dataBuffer = Buffer.from(content, "base64"); + writeFile(path, dataBuffer, function (err) {}); + } + } + } + } +} + +/** + * 刷新图标 + * @param idList + */ +function refreshIcon(idList: Array) { + // 查询项目 + let itemList = selectByIdList(false, idList); + // 过滤掉固定图标项目 + itemList = itemList.filter((item) => !item.data.fixedIcon); + // 子进程 + fork( + "refreshItemIcon", + itemList, + (resultList: Array<{ id: number; icon: string }>) => { + // 项目列表 + let itemList: Array<{ id: number; icon: string }> = []; + // 更新项目图标 + for (const data of resultList) { + let item = selectById(data.id); + if (item) { + item.data.icon = data.icon; + item.data.htmlIcon = null; + let res = updateData(item.id, item.data); + if (res) { + itemList.push({ + id: item.id, + icon: item.data.icon, + }); + } + } + } + // 发送消息到页面 + sendToWebContent("mainWindow", "onRefreshItemIcon", itemList); + } + ); +} + +/** + * 创建快捷方式 + * @param item + */ +async function createShortcut(item: Item) { + let target = item.data.target; + if (item.type === 0 || item.type === 1) { + // 获取绝对路径 + target = getAbsolutePath(target); + } + // 保存路径 + let savePath = + app.getPath("desktop") + + "\\" + + deleteExtname(getItemName(item.name)) + + ".lnk"; + shell.writeShortcutLink(savePath, "create", { + target: target, + }); +} + +/** + * 读取文件夹下的项目 + * @param classificationId + * @param dir + * @param hiddenItems + * @param listen 是否创建监听 + * @param clear 是否清空原有项目 + */ +function getDirectoryList( + classificationId: number, + dir: string | null, + hiddenItems: string | null, + listen: boolean, + clear: boolean +) { + // 校验目录 + if (!dir || dir.trim() === "") { + return; + } + // 校验是否存在,校验是否是文件夹 + try { + let stats = statSync(dir); + if (!stats.isDirectory()) { + return; + } + } catch (e) { + return; + } + // 查询旧数据 + let oldList = list(false, classificationId); + // 子进程 + fork( + "getDirectoryItemList", + { + classificationId, + dir, + hiddenItems, + oldList, + }, + (resultList: Array) => { + if (clear) { + // 删除旧数据 + deleteByClassificationId(classificationId); + } + // 添加项目 + let itemList = batchAdd(classificationId, resultList, true); + if (listen) { + // 创建关联文件夹监听 + addAssociateFolderWatcher(classificationId, dir, hiddenItems); + } + if (global.mainWindow && !global.mainWindow.isDestroyed()) { + // 发送消息到页面 + sendToWebContent("mainWindow", "onAddItem", { + itemList, + clear, + classificationId, + }); + } + } + ); +} + +/** + * 获取剪切板图片文件 + */ +function getClipboardImageFile() { + // 获取文件列表 + let fileList: Array = global.addon.getClipboardFileList(); + // 多个文件返回空,单个文件返回文件路径 + if (fileList.length === 1) { + let filePath = fileList[0]; + // 获取后缀 + let ext = mime.getExtension(mime.getType(filePath)); + if (iconExts.includes(ext)) { + return filePath; + } + } + return null; +} + +/** + * 粘贴图标 + * @param id + */ +function pasteIcon(id: number | null) { + if (id) { + // 查询项目 + let item = selectById(id); + if (item) { + // 图标 + let icon = null; + // 获取剪切板图片文件 + let imageFile = getClipboardImageFile(); + if (imageFile) { + try { + // 读取文件 + let buffer = readFileSync(imageFile); + // 图标 + icon = + "data:" + + mime.getType(imageFile) + + ";base64," + + buffer.toString("base64"); + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + } + } else { + let bitmap = global.addon.getClipboardBitmapBase64(); + if (bitmap) { + icon = bitmap; + } + } + if (icon) { + item.data.icon = icon; + // 更新 + updateData(item.id, item.data); + // 通知页面刷新图标 + sendToWebContent("mainWindow", "onRefreshItemIcon", [ + { id, icon: item.data.icon }, + ]); + } + } + } +} + +/** + * 检查无效项目 + */ +function checkInvalid() { + // 查询项目列表 + let itemList = list(); + // 去掉图标 + for (const item of itemList) { + item.data.icon = null; + } + // 子进程 + fork("checkInvalidItem", itemList, (resultList: Array) => { + // 发送消息到页面 + sendToWebContent("mainWindow", "onCheckInvalidItem", resultList); + }); +} + +/** + * 清空打开信息 + * @param item + */ +function clearOpenInfo(item: Item) { + item.data.openNumber = 0; + item.data.lastOpen = 0; + item.data.quickSearchOpenNumber = 0; + item.data.quickSearchLastOpen = 0; +} + +export { + createAddEditWindow, + createNetworkIconWindow, + createSVGIconWindow, + copy, + move, + drop, + updateOpenInfo, + run, + convertTarget, + exportIcon, + refreshIcon, + createShortcut, + getDirectoryList, + getClipboardImageFile, + pasteIcon, + checkInvalid, +}; diff --git a/electron/main/item/ipcEvent.ts b/electron/main/item/ipcEvent.ts new file mode 100644 index 0000000..f7119b4 --- /dev/null +++ b/electron/main/item/ipcEvent.ts @@ -0,0 +1,680 @@ +import { + Menu, + MenuItem, + dialog, + ipcMain, + clipboard, + MenuItemConstructorOptions, +} from "electron"; +import { getAbsolutePath } from "../../commons/utils"; +import { + convertTarget, + createAddEditWindow, + createNetworkIconWindow, + createSVGIconWindow, + createShortcut, + drop, + exportIcon, + refreshIcon, + run, + copy, + move, + getClipboardImageFile, + pasteIcon, + updateOpenInfo, +} from "."; +import { + getAppxItemList, + getStartMenuItemList, + getSystemItemList, +} from "./commons"; +import { add, del, list, selectById, update, updateOrder } from "./data"; +import { Item } from "../../../types/item"; +import { getFileExtname, isAbsolutePath } from "../../../commons/utils/common"; +import { + list as selectClassificationList, + selectById as selectClassificationById, + hasChildClassification, +} from "../classification/data"; +import { getWindowInScreen } from "../main/index"; +import { + getItemLayoutMenu, + getItemSortMenu, + getItemColumnNumber, + getItemIconSize, + getItemShowOnly, +} from "../classification"; +import { join } from "node:path"; +import { setShortcutKey } from "../setting"; +import { + closeWindow, + openAfterHideWindow, + sendToWebContent, +} from "../commons/index"; + +/** + * 获取复制/移动菜单 + * @param idList + * @param type + * @returns + */ +function getCopyMoveMenuItems( + idList: Array, + type: "MoveItem" | "CopyItem" +) { + // 菜单 + let menuItems: Array = []; + // 查询分类 + let classificationList = selectClassificationList(null); + for (const parent of classificationList) { + if (parent.parentId || parent.type !== 0) { + continue; + } + let submenus: Array = []; + // 子分类 + for (const child of classificationList) { + if (parent.id === child.parentId && child.type === 0) { + submenus.push({ + label: child.name, + click: () => { + if (type === "CopyItem") { + copy(idList, child.id); + } else { + move(idList, child.id); + } + }, + }); + } + } + if (submenus.length > 0) { + menuItems.push({ + label: parent.name, + submenu: submenus, + }); + } else { + menuItems.push({ + label: parent.name, + click: () => { + if (type === "CopyItem") { + copy(idList, parent.id); + } else { + move(idList, parent.id); + } + }, + }); + } + } + return menuItems; +} + +export default function () { + // 显示新增/修改窗口 + ipcMain.on("showItemAddEditWindow", () => { + if (global.itemAddEditWindow) { + global.itemAddEditWindow.show(); + } + }); + // 关闭新增/修改窗口 + ipcMain.on("closeItemAddEditWindow", () => { + closeWindow(global.itemAddEditWindow); + }); + // 获取项目列表 + ipcMain.on("getItemList", (event) => { + event.returnValue = list(); + }); + // 获取简单项目列表 + ipcMain.on("getSimpleItemList", (event) => { + event.returnValue = list(true); + }); + // 根据ID查询项目 + ipcMain.on("getItemById", (event, args) => { + event.returnValue = selectById(args.id); + }); + // 添加项目 + ipcMain.on("addItem", (event, args) => { + let item = add(args); + setShortcutKey(); + event.returnValue = item; + }); + // 更新项目 + ipcMain.on("updateItem", (event, args) => { + let res = update(args); + setShortcutKey(); + event.returnValue = res; + }); + // 项目排序 + ipcMain.on("updateItemOrder", (event, args) => { + event.returnValue = updateOrder( + args.fromIdList, + args.toClassificationId, + args.newIndex + ); + }); + // 右键菜单 + ipcMain.on("showItemRightMenu", (event, args) => { + // 类型 main:主界面 search:搜索模块 + let type: string = args.type; + // 项目 + let item: Item | null = args.item; + // 锁定/解锁项目 + let lockItem: boolean = type === "main" ? args.lockItem : false; + // 批量操作 + let batchOperation: boolean = type === "main" ? args.batchOperation : false; + // 批量操作ID列表 + let batchSelectedIdList: Array = + type === "main" ? args.batchSelectedIdList : []; + // 分类ID + let classificationId: number = + type === "main" ? args.classificationId : item.classificationId; + // 查询分类信息 + let classification = selectClassificationById(classificationId); + if (!classification) { + return; + } + // 菜单 + let menuList: Array = []; + // 组装菜单 + if (!batchOperation) { + if (item) { + // 后缀 + let ext: string | null = null; + // 排除 + if (item.type === 0) { + ext = getFileExtname(item.data.target); + } + // "打开"菜单 + let openMenu = false; + if (item.type === 0 && ext && (ext === "exe" || ext === "bat")) { + menuList.push( + new MenuItem({ + label: global.language.runAsAdministrator, + click: () => { + // 运行 + run(type, "runas", item); + openAfterHideWindow(type); + }, + }) + ); + openMenu = true; + } + if (item.type === 0 || item.type === 1) { + menuList.push( + new MenuItem({ + label: global.language.openFileLocation, + click: () => { + // 运行 + run(type, "openFileLocation", item); + openAfterHideWindow(type); + }, + }) + ); + openMenu = true; + } + if (item.type === 3 && item.data.target === "shell:RecycleBinFolder") { + menuList.push( + new MenuItem({ + label: global.language.emptyRecycleBin, + click: () => { + global.addon.emptyRecycleBin( + global.mainWindow.getNativeWindowHandle().readInt32LE(0) + ); + }, + }) + ); + openMenu = true; + } + if ( + item.type === 0 || + item.type === 1 || + (item.type === 3 && item.data.target.indexOf("shell:") >= 0) + ) { + menuList.push( + new MenuItem({ + label: global.language.explorerMenu, + click: () => { + // 获取当前窗口所在屏幕 + let screen = getWindowInScreen(); + let scaleFactor = 1; + if (screen && screen.length > 0) { + scaleFactor = screen[0].scaleFactor; + } + // 弹出资源管理器菜单 + sendToWebContent( + type === "quickSearch" ? "quickSearchWindow" : "mainWindow", + "onItemExplorerMenu", + { + type: type, + id: item.id, + } + ); + // 禁用鼠标HOOK + global.addon.disableMouseHook(); + // 弹出资源管理器菜单 + global.addon.explorerContextMenu( + global.mainWindow.getNativeWindowHandle().readInt32LE(0), + item.type === 0 || item.type === 1 + ? getAbsolutePath(item.data.target) + : item.data.target, + args.x * scaleFactor, + args.y * scaleFactor + ); + // 开启鼠标HOOK + global.addon.enableMouseHook(); + sendToWebContent( + type === "quickSearch" ? "quickSearchWindow" : "mainWindow", + "onItemRightMenuClose", + {} + ); + }, + }) + ); + openMenu = true; + } + if (openMenu) { + menuList.push(new MenuItem({ type: "separator" })); + } + // "路径"菜单 + let pathMenu = false; + if (item.type === 0 || item.type === 1 || item.type === 2) { + menuList.push( + new MenuItem({ + label: global.language.copyFullPath, + click: () => { + clipboard.writeText( + item.type === 0 || item.type === 1 + ? getAbsolutePath(item.data.target) + : item.data.target + ); + }, + }) + ); + pathMenu = true; + } + if ( + type === "main" && + (item.type === 0 || item.type === 1) && + classification.type === 0 + ) { + menuList.push( + new MenuItem({ + label: isAbsolutePath(item.data.target) + ? global.language.convertRelativePath + : global.language.convertAbsolutePath, + click: () => { + convertTarget( + [item.id], + isAbsolutePath(item.data.target) ? "Relative" : "Absolute" + ); + }, + }) + ); + pathMenu = true; + } + if (item.type === 0 || item.type === 1 || item.type === 2) { + menuList.push( + new MenuItem({ + label: global.language.createShortcut, + click: () => { + createShortcut(item); + }, + }) + ); + pathMenu = true; + } + if (pathMenu) { + menuList.push(new MenuItem({ type: "separator" })); + } + if (type === "main") { + // "图标"菜单 + let existPasteIcon = false; + // 获取剪切板图片文件 + let imageFile = getClipboardImageFile(); + if (imageFile) { + existPasteIcon = true; + } else { + // 判断剪切板中的BITMAP是否存在 + let hasBitmap = global.addon.clipboardHasBitmap(); + if (hasBitmap) { + existPasteIcon = true; + } + } + if (existPasteIcon) { + menuList.push( + new MenuItem({ + label: global.language.pasteIcon, + click: () => { + pasteIcon(item.id); + }, + }) + ); + } + } + menuList.push( + new MenuItem({ + label: global.language.exportIcon, + click: () => { + exportIcon(item); + }, + }) + ); + if ( + type === "main" && + (item.type === 0 || item.type === 1) && + !item.data.fixedIcon + ) { + menuList.push( + new MenuItem({ + label: global.language.refreshIcon, + click: () => { + refreshIcon([item.id]); + }, + }) + ); + } + if (type === "main" && classification.type === 0) { + menuList.push(new MenuItem({ type: "separator" })); + menuList.push( + new MenuItem({ + label: global.language.moveTo, + submenu: getCopyMoveMenuItems([item.id], "MoveItem"), + }) + ); + menuList.push( + new MenuItem({ + label: global.language.copyTo, + submenu: getCopyMoveMenuItems([item.id], "CopyItem"), + }) + ); + menuList.push(new MenuItem({ type: "separator" })); + // 项目通用 + menuList.push( + new MenuItem({ + label: global.language.edit, + click: () => { + // 创建窗口 + createAddEditWindow(item.id, null); + }, + }), + new MenuItem({ + label: global.language.delete, + click: () => { + let res = dialog.showMessageBoxSync(global.mainWindow, { + message: global.language.deleteItemPrompt, + buttons: [global.language.ok, global.language.cancel], + type: "question", + noLink: true, + cancelId: 1, + }); + if (res === 0) { + // 删除数据 + del(item.id); + // 快捷键 + setShortcutKey(); + // 通知前端删除数据 + sendToWebContent("mainWindow", "onDeleteItem", [item.id]); + } + }, + }) + ); + } + } else { + // 尝试查询分类下有没有子分类 + let classificationList = selectClassificationList(classificationId); + // 添加项目选项 + if (classificationList && classificationList.length > 0) { + let submenus = []; + for (const classification of classificationList) { + if (classification.type === 0) { + submenus.push( + new MenuItem({ + label: classification.name, + click: () => { + // 创建窗口 + createAddEditWindow(null, classification.id); + }, + }) + ); + } + } + if (submenus.length > 0) { + menuList.push( + new MenuItem({ + label: global.language.newItem, + submenu: submenus, + }) + ); + } + } else { + if (classification.type === 0) { + menuList.push( + new MenuItem({ + label: global.language.newItem, + click: () => { + // 创建窗口 + createAddEditWindow(null, classificationId); + }, + }) + ); + } + } + // 分割线 + menuList.push(new MenuItem({ type: "separator" })); + if (classification.type !== 2) { + // 排序 + menuList.push(getItemSortMenu(classification)); + } + // 布局 + menuList.push(getItemLayoutMenu(classification)); + // 列数 + if ( + !hasChildClassification(classificationId) && + (classification.data.itemLayout === "list" || + (global.setting.item.layout === "list" && + classification.data.itemLayout === "default")) + ) { + // 只有子级分类或没有子级分类的父级分类并且布局是列表的才显示列数 + menuList.push(getItemColumnNumber(classification)); + } + // 图标 + menuList.push(getItemIconSize(classification)); + // 显示 + menuList.push(getItemShowOnly(classification)); + // 只有普通分类可以锁定/解锁分类 + if (classification.type === 0) { + menuList.push( + new MenuItem({ type: "separator" }), + new MenuItem({ + label: !lockItem + ? global.language.lockItem + : global.language.unlockItem, + click: () => { + sendToWebContent("mainWindow", "onLockItem", {}); + }, + }) + ); + } + } + } else { + if (classification.type === 0) { + menuList.push( + new MenuItem({ + label: global.language.selectAll, + click: () => { + sendToWebContent( + "mainWindow", + "onItembatchOperationSelectAll", + {} + ); + }, + }), + new MenuItem({ type: "separator" }), + new MenuItem({ + label: global.language.batchMoveTo, + submenu: getCopyMoveMenuItems(batchSelectedIdList, "MoveItem"), + }), + new MenuItem({ + label: global.language.batchCopyTo, + submenu: getCopyMoveMenuItems(batchSelectedIdList, "CopyItem"), + }), + new MenuItem({ type: "separator" }), + new MenuItem({ + label: global.language.batchConvertRelativePath, + click: () => { + convertTarget(batchSelectedIdList, "Relative"); + }, + }), + new MenuItem({ + label: global.language.batchConvertAbsolutePath, + click: () => { + convertTarget(batchSelectedIdList, "Absolute"); + }, + }), + new MenuItem({ type: "separator" }), + new MenuItem({ + label: global.language.batchRefreshIcon, + click: () => { + refreshIcon(batchSelectedIdList); + }, + }), + new MenuItem({ type: "separator" }), + new MenuItem({ + label: global.language.batchDelete, + click: () => { + let res = dialog.showMessageBoxSync(global.mainWindow, { + message: global.language.batchDeletePrompt, + buttons: [global.language.ok, global.language.cancel], + type: "question", + noLink: true, + cancelId: 1, + }); + if (res === 0) { + for (const id of batchSelectedIdList) { + // 删除数据 + del(id); + // 快捷键 + setShortcutKey(); + } + // 通知前端删除数据 + sendToWebContent( + "mainWindow", + "onDeleteItem", + batchSelectedIdList + ); + } + }, + }) + ); + } + } + // 非锁定项目下可以批量操作 + if (type === "main" && !lockItem && classification.type === 0) { + menuList.push( + new MenuItem({ type: "separator" }), + new MenuItem({ + label: !batchOperation + ? global.language.batchOperation + : global.language.cancelBatchOperation, + click: () => { + sendToWebContent( + "mainWindow", + "onItemBatchOperation", + !batchOperation + ); + }, + }) + ); + } + if (menuList.length > 0) { + // 载入菜单 + let menu = Menu.buildFromTemplate(menuList); + // 菜单显示 + menu.on("menu-will-show", () => { + global.itemRightMenu = true; + }); + // 菜单关闭 + menu.on("menu-will-close", () => { + global.itemRightMenu = false; + sendToWebContent( + type === "quickSearch" ? "quickSearchWindow" : "mainWindow", + "onItemRightMenuClose", + [] + ); + }); + // 显示 + menu.popup(); + } + }); + // 创建网络图标窗口 + ipcMain.on("createItemNetworkIconWindow", () => { + createNetworkIconWindow(); + }); + // 显示网络图标窗口 + ipcMain.on("showItemNetworkIconWindow", () => { + if (global.itemNetworkIconWindow) { + global.itemNetworkIconWindow.show(); + } + }); + // 关闭网络图标窗口 + ipcMain.on("closeItemNetworkIconWindow", () => { + closeWindow(global.itemNetworkIconWindow); + }); + // 创建SVG图标窗口 + ipcMain.on("createItemSVGIconWindow", () => { + createSVGIconWindow(); + }); + // 显示SVG图标窗口 + ipcMain.on("showItemSVGIconWindow", () => { + if (global.itemSVGIconWindow) { + global.itemSVGIconWindow.show(); + } + }); + // 关闭SVG图标窗口 + ipcMain.on("closeItemSVGIconWindow", () => { + closeWindow(global.itemSVGIconWindow); + }); + // 获取系统项目 + ipcMain.on("getSystemItemList", (event, args) => { + let res = getSystemItemList(); + sendToWebContent("itemAddEditWindow", "onGetSystemItemList", res); + }); + // 获取开始菜单项目 + ipcMain.on("getStartMenuItemList", (event, args) => { + getStartMenuItemList(); + }); + // 获取APPX项目 + ipcMain.on("getAppxItemList", (event, args) => { + getAppxItemList(); + }); + // 拖入项目 + ipcMain.on("dropItem", (event, args) => { + drop(args.classificationId, args.pathList); + }); + // 运行项目 + ipcMain.on("runItem", (event, args) => { + run(args.type, args.operation, args.item); + }); + // 项目拖出 + ipcMain.on("itemDragOut", (event, args) => { + let item: Item = args; + try { + // 网站和系统不能拖出 + if (item.type === 2 || item.type === 3) { + // 取消拖出状态 + sendToWebContent("mainWindow", "onItemCancelDragOut", {}); + return; + } + let icon = join(process.env.VITE_PUBLIC, "drag-and-drop.png"); + event.sender.startDrag({ + file: getAbsolutePath(item.data.target), + icon: icon, + }); + } finally { + // 取消拖出状态 + sendToWebContent("mainWindow", "onItemCancelDragOut", {}); + } + }); + // 更新打开信息 + ipcMain.on("updateItemOpenInfo", (event, args) => { + updateOpenInfo(args.type, args.id); + }); +} diff --git a/electron/main/main/index.ts b/electron/main/main/index.ts new file mode 100644 index 0000000..3a518d5 --- /dev/null +++ b/electron/main/main/index.ts @@ -0,0 +1,701 @@ +import { + BrowserWindow, + Display, + Menu, + Tray, + app, + screen, + shell, +} from "electron"; +import { createSettingWindow } from "../setting"; +import { join } from "node:path"; +import cacheData from "../commons/cacheData"; +import { getMainBackgorunColor, sendToWebContent } from "../commons"; + +// 窗口 +let mainWindow: BrowserWindow | null = null; + +/** + * 主窗口 + */ +function createMainWindow() { + // 如果窗口存在先关闭窗口 + if (mainWindow && !mainWindow.isDestroyed() && mainWindow.isVisible()) { + mainWindow.close(); + mainWindow = null; + global.mainWindow = null; + } + // 创建窗口 + mainWindow = global.mainWindow = new BrowserWindow({ + title: "Dawn Launcher", + width: 800, + height: 600, + type: "toolbar", + frame: false, + show: false, + maximizable: false, + minimizable: false, + fullscreenable: false, + transparent: global.setting.appearance.transparency < 1, + skipTaskbar: true, + backgroundColor: + global.setting.appearance.transparency === 1 + ? getMainBackgorunColor() + : null, + webPreferences: { + spellcheck: false, + backgroundThrottling: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + if (process.env.VITE_DEV_SERVER_URL) { + mainWindow.loadURL(process.env.VITE_DEV_SERVER_URL); + } else { + mainWindow.loadFile(join(process.env.DIST, "index.html")); + } + // 加载完毕 + mainWindow.webContents.on("did-finish-load", () => { + // 恢复上一次的位置 + let bounds = cacheData.cacheStore.get("mainWindowBounds"); + if (bounds) { + mainWindow.setBounds(bounds); + } + // 永远居中不可移动 + if (global.setting.general.alwaysCenter) { + mainWindow.setMovable(false); + } else { + mainWindow.setMovable(!global.setting.general.fixedPosition); + } + // 永远置顶 + if (global.setting.general.alwaysTop) { + mainWindow.setAlwaysOnTop(true, "screen-saver"); + } + // 锁定尺寸 + if (!global.setting.general.lockSize) { + mainWindow.setResizable(!global.setting.general.lockSize); + } + // 托盘 + createTray(!global.setting.general.hideTray); + // 永远居中 + alwaysCenter(); + // 判断窗口位置 + let displays = getWindowInScreen(); + if (displays.length === 0) { + // 代表窗口的位置不再任一屏幕内,将窗口位置移动到主窗口 + mainWindow.center(); + } + // 边缘吸附 + edgeAdsorb(null); + }); + mainWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 显示窗口 + mainWindow.on("show", () => { + // 显示窗口时将输入法切换为英文模式 + if (global.setting.general.switchEnglish) { + global.addon.switchEnglish( + mainWindow.getNativeWindowHandle().readInt32LE(0) + ); + } + // 边缘吸附 + edgeAdsorb(null); + }); + // 失去焦点 + mainWindow.on("blur", () => { + if (global.setting.general.edgeAutoHide && global.blurHide) { + let scaleFactor = screen.getPrimaryDisplay().scaleFactor; + autoHide( + screen.getCursorScreenPoint().x * scaleFactor, + screen.getCursorScreenPoint().y * scaleFactor, + 0, + false + ); + } + if ( + mainWindow.isVisible() && + global.setting.general.hideLoseFocus && + !global.setting.general.alwaysTop + ) { + // 如果当前还有打开的子窗口就不执行失去焦点隐藏 + if (mainWindow.getChildWindows().length === 0) { + hideMainWindow(); + } + } + }); + // 窗口移动完毕 + mainWindow.on("moved", () => { + // 边缘吸附 + edgeAdsorb(null); + // 永远居中 + alwaysCenter(); + // 记录位置 + cacheData.cacheStore.set("mainWindowBounds", mainWindow.getBounds()); + }); + // 改变窗口大小完毕 + mainWindow.on("resized", () => { + // 边缘吸附 + edgeAdsorb(null); + // 永远居中 + alwaysCenter(); + // 记录位置 + cacheData.cacheStore.set("mainWindowBounds", mainWindow.getBounds()); + }); + // 窗口隐藏事件 + mainWindow.on("hide", () => { + // 收起子分类 + if (global.setting.classification.hideWindowCollapseSubClassification) { + sendToWebContent("mainWindow", "onCollapseSubClassification", {}); + } + }); + // 创建鼠标hook + addon.createMouseHook((...args: any[]) => { + let res = JSON.parse(args[1]); + let event: string = res.event; + let x: number = res.x; + let y: number = res.y; + // 1左键 2右键 3滚轮 + let button: number = res.button; + if (event === "mousemove") { + // 鼠标移动 + if (!global.blurHide) { + // 停靠在桌面边缘时自动隐藏 + autoHide(x, y, 40, true); + } + } else if (event === "mousedown") { + // 鼠标按下 + } else if (event === "mouseup") { + // 鼠标抬起 + if (button === 3) { + // 中间单击 + // 显示隐藏窗口 + showHideMouseWheelClick(); + } + // 双击任务栏 + doubleClickTaskbar(button); + } + }); + // 禁用标题栏右键 + mainWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + mainWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + mainWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 显示窗口之前 + * @param blurHide + * @param selectedClassificationId + */ +function showMainWindowBefore( + blurHide: boolean, + selectedClassificationId: number | null = null +) { + // 向主窗口发送通知 + sendToWebContent("mainWindow", "onShowMainWindowBefore", { + blurHide, + selectedClassificationId, + }); +} + +/** + * 显示窗口 + * @param blurHide + */ +function showMainWindow(blurHide: boolean) { + // flag + let flag = true; + // 是否开启勿扰模式 + if (global.setting.general.notDisturb) { + if (global.addon.isFullscreen()) { + flag = false; + } + } + // 显示时跟随鼠标位置 + showFollowMousePosition(); + if (flag) { + global.mainWindow.show(); + // 如果没有设置置顶时,显示窗口先置顶一下,再取消 + if (!global.mainWindow.isAlwaysOnTop) { + mainWindow.setAlwaysOnTop(true, "screen-saver"); + mainWindow.setAlwaysOnTop(false); + } + global.mainWindow.focus(); + global.blurHide = blurHide; + if (blurHide) { + global.blurHide = true; + } else { + global.blurHide = false; + } + } +} + +/** + * 隐藏窗口 + */ +function hideMainWindow() { + if (global.mainWindow.isVisible()) { + global.mainWindow.hide(); + global.blurHide = false; + } +} + +/** + * 托盘 + */ +function createTray(show: boolean) { + if (show) { + // 销毁托盘 + if (global.tray && !global.tray.isDestroyed()) { + global.tray.destroy(); + global.tray = null; + } + // 创建托盘 + global.tray = new Tray(join(process.env.VITE_PUBLIC, "tray.ico")); + // 菜单 + let contextMenu = Menu.buildFromTemplate([ + { + label: global.language.displayMainWindow, + click: function () { + showMainWindowBefore(true); + }, + }, + { + label: global.language.settings, + click: function () { + createSettingWindow(); + }, + }, + { + label: global.language.exit, + click: function () { + app.quit(); + }, + }, + ]); + global.tray.setToolTip("Dawn Launcher"); + global.tray.setContextMenu(contextMenu); + // 点击托盘 + global.tray.on("click", () => { + showMainWindowBefore(true); + }); + } else { + // 销毁托盘 + if (global.tray && !global.tray.isDestroyed()) { + global.tray.destroy(); + global.tray = null; + } + } +} + +/** + * 获取窗口所在的屏幕 + */ +function getWindowInScreen() { + let inDisplays: Array = []; + let displays = screen.getAllDisplays(); + let bounds = global.mainWindow.getBounds(); + for (let display of displays) { + let workArea = display.workArea; + if ( + ((workArea.x <= bounds.x && workArea.x + workArea.width >= bounds.x) || + (workArea.x <= bounds.x + bounds.width && + workArea.x + workArea.width >= bounds.x + bounds.width)) && + ((workArea.y <= bounds.y && workArea.y + workArea.height >= bounds.y) || + (workArea.y <= bounds.y + bounds.height && + workArea.y + workArea.height >= bounds.y + bounds.height)) + ) { + inDisplays.push(display); + } + } + return inDisplays; +} + +/** + * 边缘吸附 + * @param display + * @returns + */ +function edgeAdsorb(display: Display | null) { + // 如果勾选停靠在桌面边缘时自动隐藏,放行 + if ( + global.mainWindow.isDestroyed() || + (!global.setting.general.edgeAdsorb && !global.setting.general.edgeAutoHide) + ) { + return; + } + try { + // 清空方向 + global.mainWindowDirection = null; + // 屏幕 + let displays = display ? [display] : getWindowInScreen(); + if (displays.length > 1 || displays.length === 0) { + return; + } + // 获取屏幕工作区域 + let workArea = displays[0].workArea; + // 窗口位置信息 + let bounds = global.mainWindow.getBounds(); + if (bounds.x + bounds.width >= workArea.x + workArea.width) { + // 右侧 + global.mainWindow.setBounds({ + x: workArea.x + workArea.width - bounds.width, + }); + global.mainWindowDirection = "right"; + global.blurHide = false; + } else if (bounds.x <= workArea.x) { + // 左侧 + global.mainWindow.setBounds({ x: workArea.x }); + global.mainWindowDirection = "left"; + global.blurHide = false; + } + if (bounds.y + bounds.height >= workArea.y + workArea.height) { + // 底部 + global.mainWindow.setBounds({ + y: workArea.y + workArea.height - bounds.height, + }); + global.mainWindowDirection = "bottom"; + global.blurHide = false; + } else if (bounds.y <= workArea.y) { + // 顶部 + global.mainWindow.setBounds({ y: workArea.y }); + global.mainWindowDirection = "top"; + global.blurHide = false; + } + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + global.mainWindow.setBounds({ x: 1, y: 1 }); + } +} + +/** + * 显示时跟随鼠标位置 + */ +function showFollowMousePosition() { + // 当永远居中、固定位置勾选后不能使用显示时跟随鼠标位置 + if ( + !global.setting.general.alwaysCenter && + !global.setting.general.fixedPosition && + global.setting.general.showFollowMousePosition + ) { + // 获取鼠标位置 + let point = screen.getCursorScreenPoint(); + // 窗口位置信息 + let bounds = global.mainWindow.getBounds(); + let x = Math.round(bounds.width / 2); + let y = Math.round(bounds.height / 2); + // 设置窗口位置 + global.mainWindow.setPosition(point.x - x, point.y - y); + for (let i = 0; i < 10; i++) { + global.mainWindow.setSize(bounds.width, bounds.height); + } + // 获取当前鼠标所在屏幕 + let display = screen.getDisplayNearestPoint(point); + // 边缘吸附 + edgeAdsorb(display); + } +} + +/** + * 中间单击显示/隐藏窗口 + */ +function showHideMouseWheelClick() { + if (global.setting.general.showHideMouseWheelClick) { + if (global.mainWindow.isVisible()) { + hideMainWindow(); + } else { + showMainWindowBefore(true); + } + } +} + +/** + * 永远居中 + */ +function alwaysCenter() { + if (global.setting.general.alwaysCenter) { + mainWindow.center(); + } +} + +/** + * 边缘自动隐藏 + * @param x + * @param y + * @param size + * @param timer 是否启用延迟显示/隐藏 + * @returns + */ +function autoHide(x: number, y: number, size: number, timer: boolean) { + if (global.mainWindow.isDestroyed() || !global.setting.general.edgeAutoHide) { + return; + } + // 当有子窗口时不自动隐藏 + if (mainWindow.getChildWindows().length > 0) { + return; + } + try { + // 屏幕 + let displays = getWindowInScreen(); + if (displays.length > 1 || displays.length === 0) { + return; + } + // 工作区域 + let workArea = displays[0].workArea; + // 缩放比例 + let scaleFactor = displays[0].scaleFactor; + // 窗口位置信息 + let bounds = mainWindow.getBounds(); + if (mainWindow.isVisible()) { + let flag = false; + if (bounds.x + bounds.width >= workArea.x + workArea.width) { + // 右侧 + flag = + x <= bounds.x * scaleFactor - size || + y <= bounds.y * scaleFactor - size || + y >= (bounds.y + bounds.height) * scaleFactor + size; + } else if (bounds.x === workArea.x) { + // 左侧 + flag = + x > (bounds.x + bounds.width) * scaleFactor + size || + y <= bounds.y * scaleFactor - size || + y >= (bounds.y + bounds.height) * scaleFactor + size; + } else if (bounds.y + bounds.height >= workArea.y + workArea.height) { + // 底部 + flag = + y < bounds.y * scaleFactor - size || + x <= bounds.x * scaleFactor - size || + x >= (bounds.x + bounds.width) * scaleFactor + size; + } else if (bounds.y === workArea.y) { + // 顶部 + flag = + y > (bounds.y + bounds.height) * scaleFactor + size || + x <= bounds.x * scaleFactor - size || + x >= (bounds.x + bounds.width) * scaleFactor + size; + } + if (flag && !global.classificationRightMenu && !global.itemRightMenu) { + if ( + timer && + global.setting.general.delayHideMs > 0 && + !global.autoHideTimer + ) { + // 延迟隐藏 + global.autoHideTimer = setTimeout(function () { + hideMainWindow(); + }, global.setting.general.delayHideMs); + } else if (!timer || global.setting.general.delayHideMs === 0) { + // 隐藏 + hideMainWindow(); + } + } else { + // 清空timer + clearTimeout(global.autoHideTimer); + global.autoHideTimer = null; + } + } else { + if (global.mainWindowDirection) { + let flag = false; + let scaleFactorX = bounds.x * scaleFactor; + let scaleFactorY = bounds.y * scaleFactor; + let windowWidthPosition = (bounds.x + bounds.width) * scaleFactor; + let windowHeightPosition = (bounds.y + bounds.height) * scaleFactor; + if ( + global.mainWindowDirection === "right" && + x >= windowWidthPosition - 1 && + y >= scaleFactorY && + y <= windowHeightPosition + ) { + // 右侧 + flag = true; + } else if ( + global.mainWindowDirection === "left" && + x <= workArea.x && + y >= scaleFactorY && + y <= windowHeightPosition + ) { + // 左侧 + flag = true; + } else if ( + global.mainWindowDirection === "bottom" && + y >= windowHeightPosition - 1 && + x >= scaleFactorX && + x <= windowWidthPosition + ) { + // 底部 + flag = true; + } else if ( + global.mainWindowDirection === "top" && + y <= workArea.y && + x >= scaleFactorX && + x <= windowWidthPosition + ) { + // 顶部 + flag = true; + } + if (flag) { + if ( + timer && + global.setting.general.delayDisplayMs > 0 && + !global.autoHideTimer + ) { + // 延迟显示 + global.autoHideTimer = setTimeout(function () { + showMainWindowBefore(false); + }, global.setting.general.delayDisplayMs); + } else if (!timer || global.setting.general.delayDisplayMs === 0) { + // 显示 + showMainWindowBefore(false); + } + } else { + // 清空timer + clearTimeout(global.autoHideTimer); + global.autoHideTimer = null; + } + } + } + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + global.mainWindow.setBounds({ x: 1, y: 1 }); + } +} + +/** + * 双击任务栏显示/隐藏 + */ +function doubleClickTaskbar(button: number) { + // 必须开启设置 + if (!global.setting.general.showHideDoubleClickTaskbar) { + return; + } + // 不是左键的话 + if (button !== 1) { + // 清除timeout + clearTimeout(global.doubleClickTaskbarTimer); + // 清空计数 + global.doubleClickTaskbarCounter = 0; + return; + } + // 获取屏幕 + let displays = getWindowInScreen(); + if (displays.length > 1 || displays.length === 0) { + // 清除timeout + clearTimeout(global.doubleClickTaskbarTimer); + // 清空计数 + global.doubleClickTaskbarCounter = 0; + return; + } + // 获取鼠标位置 + let point = screen.getCursorScreenPoint(); + // 判断鼠标是否在当前屏幕内 + if ( + point.x >= displays[0].bounds.x && + point.x <= displays[0].bounds.x + displays[0].bounds.width && + point.y >= displays[0].bounds.y && + point.y <= displays[0].bounds.y + displays[0].bounds.height + ) { + // 判断是否双击在任务栏上 + let flag = false; + // 判断任务栏在哪一侧 + if (displays[0].bounds.height > displays[0].workArea.height) { + if (displays[0].bounds.y === displays[0].workArea.y) { + // 底部 + let top = displays[0].workArea.y + displays[0].workArea.height; + let bottom = displays[0].bounds.y + displays[0].bounds.height; + if (point.y >= top && point.y <= bottom) { + flag = true; + } + } else { + // 顶部 + if ( + point.y >= displays[0].bounds.y && + point.y <= displays[0].workArea.y + ) { + flag = true; + } + } + } else if (displays[0].bounds.width > displays[0].workArea.width) { + if (displays[0].bounds.x === displays[0].workArea.x) { + // 右侧 + let left = displays[0].workArea.x + displays[0].workArea.width; + let right = displays[0].bounds.x + displays[0].bounds.width; + if (point.x >= left && point.x <= right) { + flag = true; + } + } else { + // 左侧 + if ( + point.x >= displays[0].bounds.x && + point.x <= displays[0].workArea.x + ) { + flag = true; + } + } + } + if (flag) { + // 监听双击 + if (!global.doubleClickTaskbarCounter) { + global.doubleClickTaskbarCounter = 0; + } + // +1 + global.doubleClickTaskbarCounter++; + // 等于2就是双击 + if ( + global.doubleClickTaskbarCounter && + global.doubleClickTaskbarCounter === 2 + ) { + // 清除timeout + clearTimeout(global.doubleClickTaskbarTimer); + // 清空计数 + global.doubleClickTaskbarCounter = 0; + // 判断点击的窗口ClassName + let className = global.addon.getCursorPosWindowClassName(); + if (className.indexOf("MSTask") >= 0 || className === "Shell_TrayWnd") { + if (mainWindow.isVisible()) { + hideMainWindow(); + } else { + showMainWindowBefore(false); + } + } + } else { + // 间隔为500毫秒,如果超过500毫秒就代表不是双击 + global.doubleClickTaskbarTimer = setTimeout(function () { + global.doubleClickTaskbarCounter = 0; + }, 500); + } + } else { + // 清除timeout + clearTimeout(global.doubleClickTaskbarTimer); + // 清空计数 + global.doubleClickTaskbarCounter = 0; + } + } else { + // 清除timeout + clearTimeout(global.doubleClickTaskbarTimer); + // 清空计数 + global.doubleClickTaskbarCounter = 0; + } +} + +export { + createMainWindow, + showMainWindowBefore, + showMainWindow, + hideMainWindow, + createTray, + edgeAdsorb, + getWindowInScreen, + showHideMouseWheelClick, + alwaysCenter, + autoHide, +}; diff --git a/electron/main/main/ipcEvent.ts b/electron/main/main/ipcEvent.ts new file mode 100644 index 0000000..ccea079 --- /dev/null +++ b/electron/main/main/ipcEvent.ts @@ -0,0 +1,33 @@ +import { ipcMain } from "electron"; +import { createTray, hideMainWindow, showMainWindow } from "./index"; +import { initAssociateFolder } from "../classification"; +import { checkInvalid } from "../item"; + +export default function () { + // 显示窗口 + ipcMain.on("showMainWindow", (event, args) => { + showMainWindow(args.blurHide); + }); + // 隐藏窗口 + ipcMain.on("hideMainWindow", () => { + hideMainWindow(); + }); + // 托盘 + ipcMain.on("setTray", (event, args) => { + createTray(args); + }); + // 初始化数据 + ipcMain.on("mainWindowInitData", () => { + // 初始化关联文件夹 + initAssociateFolder(); + // 检测无效项目 + if (global.setting.item.checkInvalidItem) { + // 五分钟检测一次 + global.checkInvalidItemInterval = setInterval(() => { + checkInvalid(); + }, 300000); + // 初始化执行一次 + checkInvalid(); + } + }); +} diff --git a/electron/main/search/index.ts b/electron/main/search/index.ts new file mode 100644 index 0000000..79cb52b --- /dev/null +++ b/electron/main/search/index.ts @@ -0,0 +1,131 @@ +import { BrowserWindow, shell } from "electron"; +import { join } from "node:path"; +import { getMainBackgorunColor, sendToWebContent } from "../commons"; +import cacheData from "../commons/cacheData"; + +// 窗口 +let quickSearchWindow: BrowserWindow | null = null; + +/** + * 快速搜索窗口 + */ +function createQuickSearchWindow() { + // 创建窗口 + global.quickSearchWindowInit = false; + quickSearchWindow = global.quickSearchWindow = new BrowserWindow({ + title: "Dawn Launcher", + width: 600, + height: 44, + type: "toolbar", + frame: false, + show: false, + maximizable: false, + minimizable: false, + fullscreenable: false, + resizable: false, + alwaysOnTop: true, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + backgroundThrottling: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + if (process.env.VITE_DEV_SERVER_URL) { + quickSearchWindow.loadURL( + process.env.VITE_DEV_SERVER_URL + "Search/QuickSearch" + ); + } else { + quickSearchWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/Search/QuickSearch", + }); + } + quickSearchWindow.webContents.on("did-finish-load", function () { + // 恢复上一次的位置 + let bounds = cacheData.cacheStore.get("quickSearchWindowBounds"); + if (bounds) { + quickSearchWindow.setBounds(bounds); + } + // 设置可以显示 + global.searchWindowShow = true; + }); + quickSearchWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 失去焦点 + quickSearchWindow.on("blur", () => { + // 失去焦点后隐藏 + if (global.setting.quickSearch.hideLoseFocus) { + hideQuickSearchWindow(); + } + }); + // 显示窗口 + quickSearchWindow.on("show", () => { + // 背景色 + quickSearchWindow.setBackgroundColor( + global.setting.appearance.theme.mainBackgroundColor + ); + // 显示窗口时将输入法切换为英文模式 + if (global.setting.general.switchEnglish) { + global.addon.switchEnglish( + quickSearchWindow.getNativeWindowHandle().readInt32LE(0) + ); + } + }); + // 窗口移动完毕 + quickSearchWindow.on("moved", () => { + // 记录位置 + cacheData.cacheStore.set( + "quickSearchWindowBounds", + quickSearchWindow.getBounds() + ); + }); + // 隐藏窗口 + quickSearchWindow.on("hide", () => { + // 设置默认高度 + quickSearchWindow.setBounds({ height: 44 }); + // 发送消息清空数据 + quickSearchWindow.webContents.send("onQuickSearchClearData"); + }); + // 禁用标题栏右键 + quickSearchWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + quickSearchWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + quickSearchWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 显示快速搜索窗口之前 + */ +function showQuickSearchWindowBefore() { + // 向主窗口发送通知 + sendToWebContent("quickSearchWindow", "onShowQuickSearchWindowBefore", null); +} + +/** + * 显示快速搜索窗口 + */ +function showQuickSearchWindow() { + quickSearchWindow.show(); +} + +/** + * 隐藏快速搜索窗口 + */ +function hideQuickSearchWindow() { + quickSearchWindow.hide(); +} + +export { + createQuickSearchWindow, + showQuickSearchWindow, + hideQuickSearchWindow, + showQuickSearchWindowBefore, +}; diff --git a/electron/main/search/ipcEvent.ts b/electron/main/search/ipcEvent.ts new file mode 100644 index 0000000..fdfc40c --- /dev/null +++ b/electron/main/search/ipcEvent.ts @@ -0,0 +1,21 @@ +import { ipcMain } from "electron"; +import { hideQuickSearchWindow, showQuickSearchWindow } from "."; + +export default function () { + // 快速搜索初始化完成 + ipcMain.on("quickSearchInitFinished", () => { + global.quickSearchWindowInit = true; + }); + // 显示快速搜索窗口 + ipcMain.on("showQuickSearchWindow", () => { + showQuickSearchWindow(); + }); + // 隐藏快速搜索窗口 + ipcMain.on("hideQuickSearchWindow", () => { + hideQuickSearchWindow(); + }); + // 设置快速搜索窗口高度 + ipcMain.on("setQuickSearchWindowHeight", (event, args) => { + global.quickSearchWindow.setBounds({ height: args }); + }); +} diff --git a/electron/main/setting/data.ts b/electron/main/setting/data.ts new file mode 100644 index 0000000..4634e54 --- /dev/null +++ b/electron/main/setting/data.ts @@ -0,0 +1,82 @@ +import { Setting } from "../../../types/setting"; +import { getSetting } from "../../../commons/utils/setting"; +import { getDataSqlite3 } from "../../commons/betterSqlite3"; + +// 获取数据库 +let db = getDataSqlite3(); + +// 设置表名 +let settingTableName = "setting"; + +/** + * 初始化 + */ +function init() { + // sql + let sql = `CREATE TABLE IF NOT EXISTS ${settingTableName} ( + id INTEGER PRIMARY KEY AUTOINCREMENT, + setting TEXT NOT NULL)`; + // 运行 + db.exec(sql); + // 如果无数据的话,初始化 + let setting = select(); + if (setting) { + global.setting = setting; + } else { + setting = getSetting(null); + if (add(setting)) { + global.setting = setting; + } + } +} + +/** + * 查询 + */ +function select() { + // sql + let sql = `SELECT setting FROM ${settingTableName} WHERE id = 1`; + // 运行 + let row: any = db.prepare(sql).get(); + // 返回 + if (row && row.setting) { + return getSetting(JSON.parse(row.setting)); + } else { + return null; + } +} + +/** + * 添加 + */ +function add(setting: Setting) { + // SQL + let sql = `INSERT INTO ${settingTableName} + (id, setting) + VALUES (?, ?)`; + // 运行 + let id = db.prepare(sql).run(1, JSON.stringify(setting)).lastInsertRowid; + if (id) { + global.setting = setting; + return true; + } + return false; +} + +/** + * 更新 + */ +function update(setting: Setting) { + // SQL + let sql = `UPDATE ${settingTableName} + SET setting = ? + WHERE id = ?`; + // 运行 + let res = db.prepare(sql).run(JSON.stringify(setting), 1).changes > 0; + if (res) { + global.setting = setting; + } + return res; +} + +export { init, select, add, update }; diff --git a/electron/main/setting/index.ts b/electron/main/setting/index.ts new file mode 100644 index 0000000..1ef1a86 --- /dev/null +++ b/electron/main/setting/index.ts @@ -0,0 +1,146 @@ +import { BrowserWindow, globalShortcut, shell } from "electron"; +import { join } from "node:path"; +import { Setting } from "../../../types/setting"; +import { hideMainWindow, showMainWindowBefore } from "../main/index"; +import { list as selectClassificationList } from "../classification/data"; +import { list as selectItemList } from "../item/data"; +import { run } from "../item"; +import { closeWindow, getMainBackgorunColor } from "../commons/index"; +import { + createQuickSearchWindow, + hideQuickSearchWindow, + showQuickSearchWindowBefore, +} from "../search"; + +// 窗口 +let settingWindow: BrowserWindow | null = null; + +/** + * 设置窗口 + */ +function createSettingWindow() { + // 如果窗口存在先关闭窗口 + closeWindow(settingWindow); + // 创建窗口 + settingWindow = global.settingWindow = new BrowserWindow({ + title: "Dawn Launcher", + frame: false, + parent: global.mainWindow, + height: 500, + width: 600, + type: "toolbar", + maximizable: false, + minimizable: false, + resizable: false, + fullscreenable: false, + skipTaskbar: true, + show: false, + backgroundColor: getMainBackgorunColor(), + webPreferences: { + spellcheck: false, + preload: join(__dirname, "../preload/index.js"), + devTools: process.env.NODE_ENV === "development", + }, + }); + if (process.env.VITE_DEV_SERVER_URL) { + settingWindow.loadURL(process.env.VITE_DEV_SERVER_URL + "Setting/Index"); + } else { + settingWindow.loadFile(join(process.env.DIST, "index.html"), { + hash: "/Setting/Index", + }); + } + settingWindow.webContents.setWindowOpenHandler(({ url }) => { + if (url.startsWith("https:")) shell.openExternal(url); + return { action: "deny" }; + }); + // 禁用标题栏右键 + settingWindow.hookWindowMessage(278, function (e) { + // 窗口禁用 + settingWindow.setEnabled(false); + // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 + setTimeout(() => { + settingWindow.setEnabled(true); + }, 100); + return true; + }); +} + +/** + * 设置快捷键 + */ +function setShortcutKey(setting: Setting = global.setting) { + // 取消所有快捷键 + globalShortcut.unregisterAll(); + // 设置主窗口显示/隐藏快捷键 + if ( + setting.general.showHideShortcutKey && + setting.general.showHideShortcutKey.trim() !== "" + ) { + globalShortcut.register(setting.general.showHideShortcutKey, () => { + if (global.mainWindow.isVisible()) { + hideMainWindow(); + } else { + showMainWindowBefore(true); + } + }); + } + // 分类快捷键 + let classificationList = selectClassificationList(); + for (const classification of classificationList) { + if (classification.globalShortcutKey && classification.shortcutKey) { + globalShortcut.register(classification.shortcutKey, () => { + // 分类 + showMainWindowBefore(true, classification.id); + }); + } + } + // 项目快捷键 + let itemList = selectItemList(); + for (const item of itemList) { + if (item.globalShortcutKey && item.shortcutKey) { + globalShortcut.register(item.shortcutKey, () => { + // 项目 + run("main", "open", item); + }); + } + } + // 快速搜索 + if ( + setting.quickSearch.showHideShortcutKey && + setting.quickSearch.showHideShortcutKey.trim() !== "" + ) { + globalShortcut.register(setting.quickSearch.showHideShortcutKey, () => { + // 如果窗口不存在或者被销毁的话,就创建窗口 + if (!global.quickSearchWindow || global.quickSearchWindow.isDestroyed()) { + createQuickSearchWindow(); + } + // 如果初始化完毕并且窗口状态是正常的话,可以进行显示/隐藏 + if ( + global.quickSearchWindowInit && + global.quickSearchWindow && + !global.quickSearchWindow.isDestroyed() + ) { + if (global.quickSearchWindow.isVisible()) { + hideQuickSearchWindow(); + } else { + showQuickSearchWindowBefore(); + } + } + }); + } +} + +/** + * 固定位置 + * @param fixedPosition + * @param alwaysCenter + */ +function setFixedPosition(fixedPosition: boolean, alwaysCenter: boolean) { + global.mainWindow.setMovable(!fixedPosition); + // 固定位置和永远居中不能同时存在 + if (alwaysCenter && fixedPosition) { + global.mainWindow.setMovable(false); + } +} + +export { createSettingWindow, setShortcutKey, setFixedPosition }; diff --git a/electron/main/setting/ipcEvent.ts b/electron/main/setting/ipcEvent.ts new file mode 100644 index 0000000..e903915 --- /dev/null +++ b/electron/main/setting/ipcEvent.ts @@ -0,0 +1,207 @@ +import { app, dialog, ipcMain } from "electron"; +import { + closeWindow, + getUserDataPath, + relaunch, + sendToWebContent, +} from "../commons/index"; +import { createSettingWindow, setFixedPosition, setShortcutKey } from "."; +import { add, select, update } from "./data"; +import { basename } from "node:path"; +import { edgeAdsorb } from "../main"; +import { sendAllWindows } from "../commons"; +import { parse } from "node:path"; +import { statSync, mkdirSync, copyFileSync, readFileSync } from "node:fs"; +import mime from "mime"; +import { checkInvalid } from "../item"; +import { updateItemOpenNumberSortToDefualt } from "../classification"; + +export default function () { + // 创建设置窗口 + ipcMain.on("createSettingWindow", () => { + createSettingWindow(); + }); + // 显示设置窗口 + ipcMain.on("showSettingWindow", () => { + if (global.settingWindow) { + global.settingWindow.show(); + } + }); + // 关闭设置窗口 + ipcMain.on("closeSettingWindow", () => { + closeWindow(global.settingWindow); + }); + // 查询设置 + ipcMain.on("selectSetting", (event, args) => { + event.returnValue = select(); + }); + // 添加设置 + ipcMain.on("addSetting", (event, args) => { + event.returnValue = add(args); + }); + // 更新设置 + ipcMain.on("updateSetting", (event, args) => { + // 记录旧透明度 + let oldTransparency = global.setting.appearance.transparency; + // 记录旧语言 + let oldLanguage = global.setting.general.language; + // 更新 + event.returnValue = update(args); + // 判断是否需要重启主界面 + if ( + (oldTransparency === 1 && global.setting.appearance.transparency < 1) || + (oldTransparency < 1 && global.setting.appearance.transparency === 1) + ) { + // 重新启动程序 + relaunch(); + return; + } else if (global.setting.general.language !== oldLanguage) { + // 重新启动程序 + relaunch(); + return; + } + // 通知所有窗口 + sendAllWindows("onUpdateSetting", args); + }); + // 开机启动 + ipcMain.on("startup", (event, args) => { + if (process.env.NODE_ENV !== "development") { + const exeName = basename(process.execPath); + app.setLoginItemSettings({ + openAtLogin: args, + openAsHidden: false, + path: process.execPath, + args: ["--processStart", `"${exeName}"`], + }); + } + }); + // 设置快捷键 + ipcMain.on("setShortcutKey", (event, args) => { + setShortcutKey(args); + }); + // 永远置顶 + ipcMain.on("setAlwaysTop", (event, args) => { + if (args) { + global.mainWindow.setAlwaysOnTop(true, "screen-saver"); + } else { + global.mainWindow.setAlwaysOnTop(false); + } + }); + // 锁定尺寸 + ipcMain.on("setLockSize", (event, args) => { + global.mainWindow.setResizable(!args); + }); + // 固定位置 + ipcMain.on("setFixedPosition", (event, args) => { + setFixedPosition(args.fixedPosition, args.alwaysCenter); + }); + // 永远居中 + ipcMain.on("setAlwaysCenter", (event, args) => { + if (args.alwaysCenter) { + global.mainWindow.center(); + global.mainWindow.setMovable(false); + } else { + setFixedPosition(args.fixedPosition, args.alwaysCenter); + } + }); + // 边缘吸附 + ipcMain.on("setEdgeAdsorb", (event, args) => { + if (args) { + global.setting.general.edgeAdsorb = true; + edgeAdsorb(null); + } + }); + // 上传背景图 + ipcMain.on("uploadBackgrounImage", (event, args) => { + // 打开文件对话框 + let filePathList = dialog.showOpenDialogSync(global.settingWindow, { + filters: [ + { + name: "Images", + extensions: ["jpg", "jpeg", "png", "gif", "ico", "svg", "webp"], + }, + ], + }); + if (filePathList && filePathList.length > 0) { + // 获取文件路径 + let filePath = filePathList[0]; + // 解析路径 + let parsedPath = parse(filePath); + // 拷贝的路径 + let destPath = getUserDataPath() + "\\images"; + // 不存在目录,创建目录 + try { + statSync(destPath); + } catch (e) { + mkdirSync(destPath); + } + // 图片名 + let name = "backgroundImage" + parsedPath.ext; + // 全路径 + let copyFullPath = destPath + "\\" + name; + try { + // 拷贝 + copyFileSync(filePath, copyFullPath); + // 图片转base64 + let buffer = readFileSync(copyFullPath); + let image = + "data:" + + mime.getType(copyFullPath) + + ";base64," + + buffer.toString("base64"); + // 返回base64 + event.returnValue = { + name, + image, + }; + } catch (e) { + if (process.env.NODE_ENV === "development") { + console.log(e); + } + event.returnValue = null; + } + } else { + event.returnValue = null; + } + }); + // 获取背景图 + ipcMain.on("getBackgroundImage", (event, args) => { + // 图片名 + let name: string = args.name; + // 窗口 + let windowName: string = args.windowName; + try { + // 读取图片转为BASE64 + let data = readFileSync(getUserDataPath() + "\\images\\" + name); + let buffer = Buffer.from(data); + let image = + "data:" + mime.getType(name) + ";base64," + buffer.toString("base64"); + // 通知窗口 + sendToWebContent(windowName, "onSetBacngroundImage", image); + } catch (e) {} + }); + // 检测无效项目 + ipcMain.on("setCheckInvalidItem", (event, args) => { + if (args) { + if (!global.checkInvalidItemInterval) { + // 五分钟检测一次 + global.checkInvalidItemInterval = setInterval(() => { + checkInvalid(); + }, 300000); + // 执行一次 + checkInvalid(); + } + } else { + // 清空定时 + clearInterval(global.checkInvalidItemInterval); + global.checkInvalidItemInterval = null; + } + }); + // 项目打开次数 + ipcMain.on("setItemOpenNumber", (event, args) => { + if (!args) { + // 将排序为打开次数的分类修改为默认排序 + updateItemOpenNumberSortToDefualt(); + } + }); +} diff --git a/electron/main/worker.ts b/electron/main/worker.ts new file mode 100644 index 0000000..b32122d --- /dev/null +++ b/electron/main/worker.ts @@ -0,0 +1,793 @@ +import mime from "mime"; +import { + deleteExtname, + getFileName, + newItem, +} from "../../commons/utils/common"; +import { CommonItem, Item } from "../../types/item"; +import { parse, join } from "node:path"; +import { readdirSync, readFileSync, statSync, writeFileSync } from "node:fs"; +import { execSync } from "node:child_process"; +import xml2js from "xml2js"; +import { newCommonItem, newCommonItemData } from "../../commons/utils/common"; +import { ShortcutInfo } from "../../types/common"; +import { getAbsolutePath, getFileIcon } from "../commons/utils"; + +// AppxInfo +export interface AppxInfo { + packageFamilyName: string; + installLocation: string; + appId: string | null; + icon: string | null; + name: string | null; +} + +// addon +global.addon = require("../../native/addon.node"); + +// 接收消息 +process.parentPort.once("message", async (event) => { + // 参数 + let data = event.data; + // 通道 + let port = event.ports[0]; + try { + // 转为实体 + let params = JSON.parse(data); + // 获取数据参数 + let dataParamStr = readFileSync(params.data.filePath, { + encoding: "utf-8", + }); + // 转为JSON + let dataParam = JSON.parse(dataParamStr); + // 返回信息 + let res = null; + if (params.name === "getStartMenuItemList") { + res = await getStartMenuItemList(dataParam); + } else if (params.name === "getAppxItemList") { + res = await getAppxItemList(); + } else if (params.name === "getDropItemInfo") { + res = await getDropItemInfo( + dataParam.classificationId, + dataParam.pathList + ); + } else if (params.name === "refreshItemIcon") { + res = await refreshItemIcon(dataParam); + } else if (params.name === "getDirectoryItemList") { + res = await getDirectoryItemList( + dataParam.classificationId, + dataParam.dir, + dataParam.hiddenItems, + dataParam.oldList + ); + } else if (params.name === "checkInvalidItem") { + res = checkInvalidItem(dataParam); + } + // 写入结果 + writeFileSync(params.data.filePath, JSON.stringify(res)); + port.postMessage(params.data.filePath); + } catch (e) { + process.exit(); + } +}); + +/** + * 读取路径下的文件 + * @param dir + */ +function getFiles(dir: string) { + let resultList: Array = []; + try { + // 读取开始菜单下所有内容 + let pathList = readdirSync(dir); + // 循环判断文件类型 + for (let path of pathList) { + // 完整路径 + let fullPath = dir + "\\" + path; + // 判断文件类型 + let stats; + try { + // 文件类型 + stats = statSync(fullPath); + // 如果是文件夹继续向下读取,如果是文件则添加到返回列表 + if (stats.isDirectory()) { + // 文件夹 + resultList.push(...getFiles(fullPath)); + } else { + // 文件 + resultList.push(fullPath); + } + } catch (e) {} + } + } catch (e) {} + return resultList; +} +/** + * 获取开始菜单项目 + * @param cacheList + */ +async function getStartMenuItemList(cacheList: Array) { + // 返回列表 + let resultList: Array = []; + // appData + let appDataPathList = getFiles( + process.env["AppData"] + "\\Microsoft\\Windows\\Start Menu\\Programs" + ); + // programData + let programDataPathList = getFiles( + process.env["ProgramData"] + "\\Microsoft\\Windows\\Start Menu\\Programs" + ); + // 文件列表 + let filePathList: Array = []; + filePathList.push(...appDataPathList); + filePathList.push(...programDataPathList); + // 循环组装数据 + for (let filePath of filePathList) { + // 获取后缀,必须是快捷方式 + if (mime.getType(filePath) === "application/x-ms-shortcut") { + // 获取名称去掉后缀 + let name = deleteExtname(getFileName(filePath)); + // 参数 + let params = null; + // 获取真实文件路径和参数 + let shortcutInfo: ShortcutInfo | null = + global.addon.getShortcutFileInfo(filePath); + if (shortcutInfo) { + // 路径 + if (shortcutInfo.target) { + filePath = shortcutInfo.target; + } + // 参数 + if (shortcutInfo.arguments) { + params = shortcutInfo.arguments; + } + } + // 查重 + let flag = false; + for (let item of resultList) { + if (item.data.target.toLowerCase() === filePath.toLowerCase()) { + flag = true; + break; + } + } + if (!flag) { + let exist = false; + // 是否存在如果存在的话不需要重新获取图标 + if (cacheList && cacheList.length > 0) { + for (let cacheItem of cacheList) { + if (filePath === cacheItem.data.target) { + resultList.push(newCommonItem(cacheItem)); + exist = true; + break; + } + } + } + if (!exist) { + // item + let item = newCommonItem({ + name, + data: newCommonItemData({ + target: filePath, + icon: getFileIcon(filePath), + params, + }), + }); + // push + resultList.push(item); + } + } + } + } + return resultList; +} + +/** + * APPX项目 + */ +async function getAppxItemList() { + // 返回列表 + let resultList: Array = []; + try { + // ID + let id = 1; + // 获取APPX信息 + let stdout = execSync( + 'powershell -Command "Get-AppxPackage | Select-Object PackageFamilyName, InstallLocation | Format-list"' + ); + let strAppxInfo = stdout.toString("utf-8"); + // 按换行符分割 + let lines = strAppxInfo + .trim() + .split("\r\n") + .filter((str) => str.trim() !== ""); + // 临时列表 + let tempList: Array = []; + // APPX包名 + let packageFamilyName: string | null = null; + // APPX路径 + let installLocation: string | null = null; + // 循环的前一个信息 + let prev = null; + // 解析每一行 + for (let i = 0; i < lines.length; i++) { + let line = lines[i].trim(); + let arr = line.split(" : "); + if (arr.length > 1) { + if (arr[0].trim() === "PackageFamilyName") { + if (packageFamilyName && installLocation) { + tempList.push({ + packageFamilyName: packageFamilyName, + installLocation: installLocation, + appId: null, + icon: null, + name: null, + }); + packageFamilyName = arr[1].trim(); + installLocation = null; + prev = "PackageFamilyName"; + } else { + packageFamilyName = arr[1].trim(); + prev = "PackageFamilyName"; + } + } else if (arr[0].trim() === "InstallLocation") { + installLocation = arr[1].trim(); + prev = "InstallLocation"; + } + } else { + if (prev === "PackageFamilyName") { + packageFamilyName += line; + } else if (prev === "InstallLocation") { + installLocation += line; + } + } + } + if (packageFamilyName && installLocation) { + tempList.push({ + packageFamilyName: packageFamilyName, + installLocation: installLocation, + appId: null, + icon: null, + name: null, + }); + } + // 读取XML获取图标路径和名称 + for (let temp of tempList) { + let appxInfo = await getAppxInfo(temp.installLocation); + temp.appId = appxInfo.appId; + temp.icon = appxInfo.icon; + temp.name = appxInfo.name; + } + // 过滤 + let filterList = tempList.filter((e) => e.icon && e.appId && e.name); + // 图标转BASE64 + for (let appxInfo of filterList) { + try { + let buffer = readFileSync(appxInfo.icon); + let icon = + "data:" + + mime.getType(appxInfo.icon) + + ";base64," + + buffer.toString("base64"); + appxInfo.icon = icon; + } catch (ex) { + appxInfo.icon = null; + } + } + // 筛选出有图标的数据 + filterList = filterList.filter((e) => e.icon); + // 返回列表 + for (const appxInfo of filterList) { + resultList.push( + newCommonItem({ + id: id++, + name: appxInfo.name, + data: newCommonItemData({ + icon: appxInfo.icon, + target: + "Shell:AppsFolder\\" + + appxInfo.packageFamilyName + + "!" + + appxInfo.appId, + }), + }) + ); + } + // 排序 + resultList.sort((a, b) => a.name.localeCompare(b.name)); + } catch (e) {} + return resultList; +} + +/** + * 获取Appx信息 + */ +async function getAppxInfo(installLocation: string) { + // appx信息 + let appxInfo: AppxInfo = { + packageFamilyName: null, + installLocation: null, + appId: null, + icon: null, + name: null, + }; + // buffer, 解析结果 + let buffer: Buffer, result: any; + try { + // 解析 + buffer = readFileSync(installLocation + "\\AppxManifest.xml"); + result = await xml2jsSync(buffer); + // 备用名称 + let executable = null; + // targetsize图标 + let targetSizeIcon: string | null = null; + let targetSizeIconMax: number | null = null; + // scale图标 + let scaleIcon = null; + let scaleIconMax = null; + // 图标 APPID + if (result.Package.Applications && result.Package.Applications[0]) { + if (result.Package.Applications[0].Application[0]) { + // APPID + appxInfo.appId = result.Package.Applications[0].Application[0].$.Id; + // Executable + executable = result.Package.Applications[0].Application[0].$.Executable; + // 获取图标 + if ( + result.Package.Applications[0].Application[0]["uap:VisualElements"] != + null + ) { + // logo地址 + let logo = + result.Package.Applications[0].Application[0][ + "uap:VisualElements" + ][0].$.Square44x44Logo; + // 解析路径 + let parsedPath = parse(logo); + // 获取文件夹下所有文件 + let fileNameList = readdirSync( + installLocation + "\\" + parsedPath.dir + ); + // 筛选出和包含logo名称的文件名 + let filterList = fileNameList.filter( + (f) => f.indexOf(parsedPath.name) >= 0 + ); + if (filterList.length > 1) { + // 获取targetsize图片 + let targetSizeList = filterList.filter( + (f) => f.indexOf(parsedPath.name + ".targetsize") >= 0 + ); + if (targetSizeList.length > 0) { + // 获取最大图标尺寸 + let max = getMaxIconSize( + targetSizeList, + parsedPath.name, + "targetsize" + ); + if (max) { + // 记录max + targetSizeIconMax = max; + // 先获取最终图标 + let defaultList = targetSizeList.filter( + (f) => + f === + parsedPath.name + + ".targetsize-" + + max + + "_altform-unplated_devicefamily-colorfulunplated.png" + ); + targetSizeIcon = + defaultList.length > 0 + ? installLocation + + "\\" + + parsedPath.dir + + "\\" + + parsedPath.name + + ".targetsize-" + + max + + "_altform-unplated_devicefamily-colorfulunplated.png" + : null; + if (!targetSizeIcon) { + // 获取 名称.targetsize-{max}_altform-unplated.png + let defaultUnplatedList = targetSizeList.filter( + (f) => + f === + parsedPath.name + + ".targetsize-" + + max + + "_altform-unplated.png" + ); + if (defaultUnplatedList.length > 0) { + targetSizeIcon = + installLocation + + "\\" + + parsedPath.dir + + "\\" + + parsedPath.name + + ".targetsize-" + + max + + "_altform-unplated.png"; + } else { + // 获取 名称.targetsize-{max}_altform.png + let defaultAltFormList = targetSizeList.filter( + (f) => + f === + parsedPath.name + ".targetsize-" + max + "_altform.png" + ); + if (defaultAltFormList.length > 0) { + targetSizeIcon = + installLocation + + "\\" + + parsedPath.dir + + "\\" + + parsedPath.name + + ".targetsize-" + + max + + "_altform.png"; + } else { + // 获取 名称.targetsize-{max}.png + let defaultTargetSizeList = targetSizeList.filter( + (f) => + f === parsedPath.name + ".targetsize-" + max + ".png" + ); + if (defaultTargetSizeList.length > 0) { + targetSizeIcon = + installLocation + + "\\" + + parsedPath.dir + + "\\" + + defaultTargetSizeList[0]; + } + } + } + } + } + } + // 获取scale图片 + let scaleList = filterList.filter( + (f) => f.indexOf(parsedPath.name + ".scale") >= 0 + ); + if (scaleList.length > 0) { + // 获取最大图标尺寸 + let max = getMaxIconSize(scaleList, parsedPath.name, "scale"); + if (max) { + // 记录max + scaleIconMax = max; + // 获取 名称.scale-{max}.png + let defaultList = scaleList.filter( + (f) => f === parsedPath.name + ".scale-" + max + ".png" + ); + if (defaultList.length > 0) { + scaleIcon = + installLocation + + "\\" + + parsedPath.dir + + "\\" + + defaultList[0]; + } + } + } else { + scaleList = filterList.filter( + (f) => f.indexOf(parsedPath.name + ".Theme-Dark_Scale") >= 0 + ); + if (scaleList.length > 0) { + let max = getMaxIconSize( + scaleList, + parsedPath.name, + "Theme-Dark_Scale" + ); + if (max) { + // 记录max + scaleIconMax = max; + // 获取 名称.Theme-Dark_Scale{max}.png + let defaultList = scaleList.filter( + (f) => + f === + parsedPath.name + ".Theme-Dark_Scale-" + max + ".png" + ); + if (defaultList.length > 0) { + scaleIcon = + installLocation + + "\\" + + parsedPath.dir + + "\\" + + defaultList[0]; + } + } + } + } + } else { + if (filterList.length === 1) { + // 只有一张图片 + appxInfo.icon = + installLocation + "\\" + parsedPath.dir + "\\" + filterList[0]; + } + } + } + } + } + if (!appxInfo.icon) { + // 判断图标大小 + if (targetSizeIcon && !scaleIcon) { + appxInfo.icon = targetSizeIcon; + } else if (!targetSizeIcon && scaleIcon) { + appxInfo.icon = scaleIcon; + } else if (targetSizeIcon && scaleIcon) { + if (targetSizeIconMax === 256 || targetSizeIconMax > scaleIconMax) { + appxInfo.icon = targetSizeIcon; + } else if (targetSizeIconMax < scaleIconMax) { + appxInfo.icon = scaleIcon; + } else { + appxInfo.icon = targetSizeIcon; + } + } else if (!targetSizeIcon && !scaleIcon) { + let propertiesIcon = getPropertiesIcon(installLocation, result); + if (propertiesIcon) { + appxInfo.icon = propertiesIcon; + } + } + } + // 名称 + if (result.Package.Properties) { + if (result.Package.Properties[0].DisplayName) { + appxInfo.name = result.Package.Properties[0].DisplayName[0]; + } + } + if ( + !appxInfo.name || + (appxInfo.name && appxInfo.name.indexOf("ms-resource:") >= 0) + ) { + if (executable && executable.indexOf("ms-resource:") < 0) { + appxInfo.name = parse(executable).name; + } else { + appxInfo.name = null; + } + } + if (!appxInfo.name) { + if (result.Package.Identity && result.Package.Identity[0]) { + let name = result.Package.Identity[0].$.Name; + if (name && name.indexOf("ms-resource:") < 0) { + appxInfo.name = name; + } + } + } + } catch (ex) { + if (result) { + let propertiesIcon = getPropertiesIcon(installLocation, result); + if (propertiesIcon) { + appxInfo.icon = propertiesIcon; + } + } + } + return appxInfo; +} + +/** + * 解析XML同步 + * @param xml + */ +async function xml2jsSync(xml: Buffer) { + let parser = new xml2js.Parser(); + return new Promise((resolve, reject) => { + parser.parseString(xml, function (err, json) { + if (err) reject(err); + else resolve(json); + }); + }); +} + +/** + * 获取最大图标尺寸 + * @param list + * @param name + * @param type + * @returns + */ +function getMaxIconSize(list: Array, name: string, type: string) { + // 获取最大图标尺寸 + let max: number | null = null; + for (let targetSize of list) { + let size = Number( + targetSize + .replace(name + "." + type + "-", "") + .split("_")[0] + .replace(".png", "") + ); + if (!max) { + max = size; + } else { + if (size > max) { + max = size; + } + } + } + return max; +} + +/** + * 获取AppxPropertiesLogo + * @param installLocation + * @param result + */ +function getPropertiesIcon(installLocation: string, result: any) { + if (result.Package.Properties) { + if (result.Package.Properties[0].Logo) { + let logo = result.Package.Properties[0].Logo[0]; + return installLocation + "\\" + logo; + } + } + return null; +} + +/** + * 通过路径获取项目信息 + * @param classificationId + * @param pathList + */ +async function getDropItemInfo( + classificationId: number, + pathList: Array +) { + // 项目列表 + let itemList: Array = []; + // 解析文件信息并添加项目 + for (const path of pathList) { + try { + // item + let item = newItem({ classificationId }); + // 目标 + item.data.target = path; + // 名称 + item.name = getFileName(item.data.target); + // 判断是否是快捷方式,如果是的话,需要获取真实路径 + if (mime.getType(path) === "application/x-ms-shortcut") { + // 快捷方式 + // 获取真实文件路径和参数 + let shortcutInfo: ShortcutInfo | null = + global.addon.getShortcutFileInfo(path); + if (shortcutInfo) { + // 路径 + if (shortcutInfo.target) { + item.data.target = shortcutInfo.target; + } + // 参数 + if (shortcutInfo.arguments) { + item.data.params = shortcutInfo.arguments; + } + } + } + // 文件类型 + let stats = statSync(item.data.target); + // 路径 + item.type = stats.isFile() ? 0 : 1; + // 获取图标 + item.data.icon = getFileIcon(item.data.target); + // 去掉后缀 + if (item.type === 0) { + item.name = deleteExtname(item.name); + } + // push + itemList.push(item); + } catch (e) {} + } + return itemList; +} + +/** + * 刷新项目图标 + * @param itemList + */ +async function refreshItemIcon(itemList: Array) { + // 返回数据 + let resultList: Array<{ + id: number; + icon: string; + }> = []; + // 刷新图标 + for (const item of itemList) { + if (item.type === 0 || item.type === 1) { + let icon: string | null = getFileIcon(item.data.target); + if (icon) { + resultList.push({ + id: item.id, + icon, + }); + } + } + } + return resultList; +} + +/** + * 读取文件夹下的项目 + * @param classificationId + * @param dir + * @param hiddenItems + * @param oldList + * @returns + */ +async function getDirectoryItemList( + classificationId: number, + dir: string, + hiddenItems: string | null, + oldList: Array +) { + // 返回列表 + let resultList: Array = []; + // 转map + let oldMap = new Map( + oldList.map((item) => [item.data.target.toLowerCase(), item]) + ); + try { + // 文件类型 + let stats = statSync(dir); + // 必须是文件夹 + if (stats.isDirectory()) { + // 转为数组 + let hiddenItemList = []; + if (hiddenItems && hiddenItems.trim() !== "") { + hiddenItemList = hiddenItems.split(","); + } + // 读取文件夹下面的所有文件 + let nameList = readdirSync(dir); + for (const name of nameList) { + try { + // 判断是否隐藏 + let hidden = false; + for (let hiddenItem of hiddenItemList) { + if (hiddenItem.trim().toLowerCase() === name.trim().toLowerCase()) { + hidden = true; + break; + } + } + if (hidden) { + continue; + } + // item + let item: Item | null = null; + // 组合路径 + let path = join(dir, name); + // 获取类型 0:文件 1:文件夹 + let type = statSync(path).isDirectory() ? 1 : 0; + // 是否有旧数据 + if (oldMap.has(path.toLowerCase())) { + let oldItem = oldMap.get(path.toLowerCase()); + if (oldItem.type === type) { + item = newItem(oldItem); + } + } + if (!item) { + item = newItem({ classificationId, type }); + item.name = deleteExtname(getFileName(path)); + item.data.target = path; + item.data.icon = getFileIcon(path); + } + // push + resultList.push(item); + } catch (e) {} + } + } + } catch (e) {} + return resultList; +} + +/** + * 检查无效项目 + */ +function checkInvalidItem(itemList: Array) { + // 无效项目ID列表 + let resultList: Array = []; + // 循环校验每个项目 + for (const item of itemList) { + // 只校验文件和文件夹 + if (item.type === 0 || item.type === 1) { + // 获取绝对路径 + let path = getAbsolutePath(item.data.target); + try { + statSync(path); + } catch (e) { + resultList.push(item.id); + } + } + } + return resultList; +} diff --git a/electron/preload/index.ts b/electron/preload/index.ts new file mode 100644 index 0000000..269dad1 --- /dev/null +++ b/electron/preload/index.ts @@ -0,0 +1,850 @@ +import { contextBridge, ipcRenderer } from "electron"; +import { Classification } from "../../types/classification"; +import { Item } from "../../types/item"; +import { Setting } from "../../types/setting"; + +contextBridge.exposeInMainWorld("api", { + // emit + emit: (windowName: string, listener: string, paylod: any) => { + ipcRenderer.send("emit", { windowName, listener, paylod }); + }, + // 错误提示框 + showErrorMessageBox: (windowName: string, message: string) => { + ipcRenderer.send("showErrorMessageBox", { windowName, message }); + }, + // 信息提示框 + showInfoMessageBox: (windowName: string, message: string) => { + ipcRenderer.send("showInfoMessageBox", { windowName, message }); + }, + // 对话框 + showConfirmBox: (windowName: string, message: string): boolean => { + return ipcRenderer.sendSync("showConfirmBox", { windowName, message }); + }, + // 选择文件 + selectFile: ( + windowName: string, + target: boolean, + defaultPath: string | null + ): string | null => { + return ipcRenderer.sendSync("selectFile", { + windowName, + target, + defaultPath, + }); + }, + // 选择文件夹 + selectDirectory: ( + windowName: string, + defaultPath: string | null + ): string | null => { + return ipcRenderer.sendSync("selectDirectory", { + windowName, + defaultPath, + }); + }, + // 获取图标 + getFileIcon: (windowName: string, path: string) => { + ipcRenderer.send("getFileIcon", { windowName, path }); + }, + // 监听获取图标 + onGetFileIcon: (callback): Function => { + ipcRenderer.on("onGetFileIcon", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onGetFileIcon"); + }; + }, + // 下载图片 + downloadImage: (windowName: string, url: string) => { + ipcRenderer.send("downloadImage", { windowName, url }); + }, + // 监听下载图片 + onDownloadImage: (callback): Function => { + ipcRenderer.on("onDownloadImage", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onDownloadImage"); + }; + }, + // 获取网址信息 + getURLInfo: (windowName: string, url: string) => { + ipcRenderer.send("getURLInfo", { windowName, url }); + }, + // 监听获取网址信息 + onGetURLInfo: (callback): Function => { + ipcRenderer.on("onGetURLInfo", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onGetURLInfo"); + }; + }, + // 转换路径 + convertPath: (path: string): string => { + return ipcRenderer.sendSync("convertPath", { path }); + }, + // 路径是否存在 + pathExist: (path: string): boolean => { + return ipcRenderer.sendSync("pathExist", { path }); + }, + // 是否是文件 + isFile: (path: string): boolean => { + return ipcRenderer.sendSync("isFile", { path }); + }, + // 打开URL + openURL: (url: string) => { + ipcRenderer.send("openURL", url); + }, + // 获取版本 + getVersion: (): string => { + return ipcRenderer.sendSync("getVersion"); + }, + // 退出 + exit: () => { + ipcRenderer.send("exit"); + }, +}); + +contextBridge.exposeInMainWorld("main", { + // 显示窗口 + showWindow: (blurHide: boolean) => { + ipcRenderer.send("showMainWindow", { blurHide }); + }, + // 隐藏窗口 + hideWindow: () => { + ipcRenderer.send("hideMainWindow"); + }, + // 初始化数据 + initData: () => { + ipcRenderer.send("mainWindowInitData"); + }, + // 显示窗口之前 + onShowWindowBefore: (callback): Function => { + ipcRenderer.on("onShowMainWindowBefore", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onShowMainWindowBefore"); + }; + }, +}); + +contextBridge.exposeInMainWorld("classification", { + // 获取分类列表 + list: (): Array => { + return ipcRenderer.sendSync("getClassificationList"); + }, + // 根据ID查询分类 + selectById: (id: number): Classification | null => { + return ipcRenderer.sendSync("getClassificationById", { id }); + }, + // 新增分类 + add: ( + parentId: number | null, + name: string, + shortcutKey: string | null, + globalShortcutKey: boolean + ): Classification | null => { + return ipcRenderer.sendSync("addClassification", { + parentId, + name, + shortcutKey, + globalShortcutKey, + }); + }, + // 更新分类 + update: (classifictaion: Classification): boolean => { + return ipcRenderer.sendSync("updateClassification", classifictaion); + }, + // 更新序号 + updateOrder: ( + fromId: number, + toId: number | null, + parentId: number | null + ): boolean => { + return ipcRenderer.sendSync("updateClassificationOrder", { + fromId, + toId, + parentId, + }); + }, + // 更新图标 + updateIcon: (id: number, icon: string | null): boolean => { + return ipcRenderer.sendSync("updateClassificationIcon", { + id, + icon, + }); + }, + // 显示新增/修改窗口 + showAddEditWindow: () => { + ipcRenderer.send("showClassificationAddEditWindow"); + }, + // 关闭新增/修改窗口 + closeAddEditWindow: () => { + ipcRenderer.send("closeClassificationAddEditWindow"); + }, + // 显示设置图标窗口 + showSetIconWindow: () => { + ipcRenderer.send("showClassificationSetIconWindow"); + }, + // 关闭设置图标窗口 + closeSetIconWindow: () => { + ipcRenderer.send("closeClassificationSetIconWindow"); + }, + // 右键菜单 + showRightMenu: ( + classification: Classification | null, + lockClassification: boolean + ) => { + ipcRenderer.send("showClassificationRightMenu", { + classification, + lockClassification, + }); + }, + // 监听新增分类 + onAdd: (callback): Function => { + ipcRenderer.on("onAddClassification", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onAddClassification"); + }; + }, + // 监听更新分类 + onUpdate: (callback): Function => { + ipcRenderer.on("onUpdateClassification", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateClassification"); + }; + }, + // 监听删除分类 + onDelete: (callback): Function => { + ipcRenderer.on("onDeleteClassification", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onDeleteClassification"); + }; + }, + // 监听锁定/解锁分类 + onLock: (callback): Function => { + ipcRenderer.on("onLockClassification", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onLockClassification"); + }; + }, + // 更新分类图标 + onUpdateIcon: (callback): Function => { + ipcRenderer.on("onUpdateClassificationIcon", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateClassificationIcon"); + }; + }, + // 显示关联文件夹窗口 + showAssociateFolderWindow: () => { + ipcRenderer.send("showClassificationAssociateFolderWindow"); + }, + // 关闭关联文件夹窗口 + closeAssociateFolderWindow: () => { + ipcRenderer.send("closeClassificationAssociateFolderWindow"); + }, + // 设置关联文件夹 + setAssociateFolder: ( + id: number, + dir: string | null, + hiddenItems: string | null + ): Classification => { + return ipcRenderer.sendSync("setClassificationAssociateFolder", { + id, + dir, + hiddenItems, + }); + }, + // 监听更新关联文件夹 + onUpdateAssociateFolder: (callback): Function => { + ipcRenderer.on("onUpdateAssociateFolderClassification", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateAssociateFolderClassification"); + }; + }, + // 是否拥有子分类 + hasChildClassification: (id: number): boolean => { + return ipcRenderer.sendSync("hasChildClassification", id); + }, + // 监听收起子分类 + onCollapseSubClassification: (callback) => { + ipcRenderer.on("onCollapseSubClassification", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onCollapseSubClassification"); + }; + }, + // 修改项目布局 + onUpdateItemLayout: (callback) => { + ipcRenderer.on("onUpdateItemLayout", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateItemLayout"); + }; + }, + // 修改项目排序 + onUpdateItemSort: (callback) => { + ipcRenderer.on("onUpdateItemSort", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateItemSort"); + }; + }, + // 修改项目列数 + onUpdateItemColumnNumber: (callback) => { + ipcRenderer.on("onUpdateItemColumnNumber", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateItemColumnNumber"); + }; + }, + // 修改项目图标 + onUpdateItemIconSize: (callback) => { + ipcRenderer.on("onUpdateItemIconSize", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateItemIconSize"); + }; + }, + // 根据文件夹创建分类 + addClassificationByDirectory: (pathList: Array) => { + ipcRenderer.send("addClassificationByDirectory", pathList); + }, + // 监听根据文件夹创建分类 + onAddClassificationByDirectory: (callback) => { + ipcRenderer.on("onAddClassificationByDirectory", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onAddClassificationByDirectory"); + }; + }, + // 修改项目显示 + onUpdateItemShowOnly: (callback) => { + ipcRenderer.on("onUpdateItemShowOnly", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateItemShowOnly"); + }; + }, + // 修改固定分类 + onUpdateFixed: (callback) => { + ipcRenderer.on("onUpdateClassificationFixed", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateClassificationFixed"); + }; + }, + // 将排序为打开次数的分类修改为默认排序 + onUpdateItemOpenNumberSortToDefualt: (callback) => { + ipcRenderer.on("onUpdateItemOpenNumberSortToDefualt", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateItemOpenNumberSortToDefualt"); + }; + }, + // 显示聚合分类窗口 + showAggregateWindow: () => { + ipcRenderer.send("showClassificationAggregateWindow"); + }, + // 关闭聚合分类窗口 + closeAggregateWindow: () => { + ipcRenderer.send("closeClassificationAggregateWindow"); + }, + // 更新聚合分类 + updateAggregate: (id: number, sort: string, itemCount: number): boolean => { + return ipcRenderer.sendSync("updateClassificationAggregate", { + id, + sort, + itemCount, + }); + }, + // 监听更新聚合分类 + onUpdateAggregate: (callback) => { + ipcRenderer.on("onUpdateClassificationAggregate", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateClassificationAggregate"); + }; + }, + // 监听修改排除搜索 + onUpdateExcludeSearch: (callback) => { + ipcRenderer.on("onUpdateClassificationExcludeSearch", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateClassificationExcludeSearch"); + }; + }, +}); + +contextBridge.exposeInMainWorld("item", { + // 显示新增/修改窗口 + showAddEditWindow: () => { + ipcRenderer.send("showItemAddEditWindow"); + }, + // 关闭新增/修改窗口 + closeAddEditWindow: () => { + ipcRenderer.send("closeItemAddEditWindow"); + }, + // 获取项目列表 + list: (): Array => { + return ipcRenderer.sendSync("getItemList"); + }, + // 获取简单项目列表 + simpleList: (): Array => { + return ipcRenderer.sendSync("getSimpleItemList"); + }, + // 根据ID查询分类 + selectById: (id: number): Item | null => { + return ipcRenderer.sendSync("getItemById", { id }); + }, + // 新增项目 + add: (item: Item): Item | null => { + return ipcRenderer.sendSync("addItem", item); + }, + // 更新项目 + update: (item: Item): boolean => { + return ipcRenderer.sendSync("updateItem", item); + }, + // 项目排序 + updateOrder: ( + fromIdList: Array, + toClassificationId: number, + newIndex: number | null + ): boolean => { + return ipcRenderer.sendSync("updateItemOrder", { + fromIdList, + toClassificationId, + newIndex, + }); + }, + // 右键菜单 + showRightMenu: (params: any) => { + ipcRenderer.send("showItemRightMenu", params); + }, + // 创建网络图标窗口 + createNetworkIconWindow: () => { + ipcRenderer.send("createItemNetworkIconWindow"); + }, + // 显示网络图标窗口 + showNetworkIconWindow: () => { + ipcRenderer.send("showItemNetworkIconWindow"); + }, + // 关闭网络图标窗口 + closeNetworkIconWindow: () => { + ipcRenderer.send("closeItemNetworkIconWindow"); + }, + // 监听网络图标 + onNetworkIcon: (callback): Function => { + ipcRenderer.on("onItemNetworkIcon", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onItemNetworkIcon"); + }; + }, + // 创建SVG图标窗口 + createSVGIconWindow: () => { + ipcRenderer.send("createItemSVGIconWindow"); + }, + // 显示SVG图标窗口 + showSVGIconWindow: () => { + ipcRenderer.send("showItemSVGIconWindow"); + }, + // 关闭SVG图标窗口 + closeSVGIconWindow: () => { + ipcRenderer.send("closeItemSVGIconWindow"); + }, + // 监听SVG图标 + onSVGIcon: (callback): Function => { + ipcRenderer.on("onItemSVGIcon", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onItemSVGIcon"); + }; + }, + // 获取系统项目 + getSystemItemList: () => { + ipcRenderer.send("getSystemItemList"); + }, + // 监听获取系统项目 + onGetSystemItemList: (callback): Function => { + ipcRenderer.on("onGetSystemItemList", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onGetSystemItemList"); + }; + }, + // 获取开始菜单项目 + getStartMenuItemList: () => { + ipcRenderer.send("getStartMenuItemList"); + }, + // 监听获取开始菜单项目 + onGetStartMenuItemList: (callback): Function => { + ipcRenderer.on("onGetStartMenuItemList", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onGetStartMenuItemList"); + }; + }, + // 获取APPX项目 + getAppxItemList: () => { + ipcRenderer.send("getAppxItemList"); + }, + // 监听APPX项目 + onGetAppxItemList: (callback): Function => { + ipcRenderer.on("onGetAppxItemList", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onGetAppxItemList"); + }; + }, + // 监听新增项目 + onAdd: (callback): Function => { + ipcRenderer.on("onAddItem", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onAddItem"); + }; + }, + // 监听更新项目 + onUpdate: (callback): Function => { + ipcRenderer.on("onUpdateItem", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateItem"); + }; + }, + // 监听删除项目 + onDelete: (callback): Function => { + ipcRenderer.on("onDeleteItem", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onDeleteItem"); + }; + }, + // 监听锁定/解锁项目 + onLock: (callback): Function => { + ipcRenderer.on("onLockItem", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onLockItem"); + }; + }, + // 拖入项目 + drop: (classificationId: number, pathList: Array) => { + ipcRenderer.send("dropItem", { + classificationId, + pathList, + }); + }, + // 监听批量操作 + onBatchOperation: (callback): Function => { + ipcRenderer.on("onItemBatchOperation", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onItemBatchOperation"); + }; + }, + // 运行项目 + run: (type: string, operation: string, item: Item) => { + ipcRenderer.send("runItem", { operation, item, type }); + }, + // 监听转换路径 + onConvertPath: (callback): Function => { + ipcRenderer.on("onConvertPath", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onConvertPath"); + }; + }, + // 监听刷新图标 + onRefreshIcon: (callback): Function => { + ipcRenderer.on("onRefreshItemIcon", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onRefreshItemIcon"); + }; + }, + // 监听移动项目 + onMove: (callback): Function => { + ipcRenderer.on("onMoveItem", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onMoveItem"); + }; + }, + // 监听批量操作全选 + onBatchOperationSelectAll: (callback): Function => { + ipcRenderer.on("onItembatchOperationSelectAll", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onItembatchOperationSelectAll"); + }; + }, + // 监听项目右键菜单关闭 + onRightMenuClose: (callback): Function => { + ipcRenderer.on("onItemRightMenuClose", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onItemRightMenuClose"); + }; + }, + // 监听项目资源管理器菜单 + onExplorerMenu: (callback): Function => { + ipcRenderer.on("onItemExplorerMenu", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onItemExplorerMenu"); + }; + }, + // 项目拖出 + dragOut: (item: Item) => { + ipcRenderer.send("itemDragOut", item); + }, + // 取消项目拖出 + onCancelDragOut: (callback): Function => { + ipcRenderer.on("onItemCancelDragOut", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onItemCancelDragOut"); + }; + }, + // 监听更新打开信息 + onUpdateOpenInfo: (callback): Function => { + ipcRenderer.on("onUpdateOpenInfo", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateOpenInfo"); + }; + }, + // 监听无效项目 + onCheckInvalid: (callback): Function => { + ipcRenderer.on("onCheckInvalidItem", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onCheckInvalidItem"); + }; + }, + // 更新打开信息 + updateOpenInfo: (type: string, id: number) => { + ipcRenderer.send("updateItemOpenInfo", { type, id }); + }, +}); + +contextBridge.exposeInMainWorld("setting", { + // 创建设置窗口 + createWindow: () => { + ipcRenderer.send("createSettingWindow"); + }, + // 显示设置窗口 + showWindow: () => { + ipcRenderer.send("showSettingWindow"); + }, + // 关闭设置窗口 + closeWindow: () => { + ipcRenderer.send("closeSettingWindow"); + }, + // 查询设置 + select: (): Setting | null => { + return ipcRenderer.sendSync("selectSetting"); + }, + // 新增设置 + add: (setting: Setting): boolean => { + return ipcRenderer.sendSync("addSetting", setting); + }, + // 更新设置 + update: (setting: Setting): boolean => { + return ipcRenderer.sendSync("updateSetting", setting); + }, + // 监听更新设置 + onUpdate: (callback): Function => { + ipcRenderer.on("onUpdateSetting", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onUpdateSetting"); + }; + }, + // 开机启动 + setStartup: (value: boolean) => { + ipcRenderer.send("startup", value); + }, + // 隐藏托盘图标 + setTray: (show: boolean) => { + ipcRenderer.send("setTray", show); + }, + // 设置快捷键 + setShortcutKey: (setting: Setting) => { + ipcRenderer.send("setShortcutKey", setting); + }, + // 永远置顶 + setAlwaysTop: (value: boolean) => { + ipcRenderer.send("setAlwaysTop", value); + }, + // 锁定尺寸 + setLockSize: (value: boolean) => { + ipcRenderer.send("setLockSize", value); + }, + // 固定位置 + setFixedPosition: (fixedPosition: boolean, alwaysCenter: boolean) => { + ipcRenderer.send("setFixedPosition", { + fixedPosition, + alwaysCenter, + }); + }, + // 永远居中 + setAlwaysCenter: (fixedPosition: boolean, alwaysCenter: boolean) => { + ipcRenderer.send("setAlwaysCenter", { + fixedPosition, + alwaysCenter, + }); + }, + // 边缘吸附 + setEdgeAdsorb: (value: boolean) => { + ipcRenderer.send("setEdgeAdsorb", value); + }, + // 上传背景图 + uploadBackgrounImage: (): any => { + return ipcRenderer.sendSync("uploadBackgrounImage"); + }, + // 监听设置背景图 + onSetBacngroundImage: (callback) => { + ipcRenderer.on("onSetBacngroundImage", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onSetBacngroundImage"); + }; + }, + // 获取背景图 + getBackgroundImage: (name: string, windowName: string) => { + ipcRenderer.send("getBackgroundImage", { name, windowName }); + }, + // 检测无效项目 + setCheckInvalidItem: (value: boolean) => { + ipcRenderer.send("setCheckInvalidItem", value); + }, + // 项目打开次数 + setOpenNumber: (value: boolean) => { + ipcRenderer.send("setItemOpenNumber", value); + }, +}); + +contextBridge.exposeInMainWorld("quickSearch", { + // 初始化完毕 + initFinished: () => { + ipcRenderer.send("quickSearchInitFinished"); + }, + // 显示窗口 + showWindow: () => { + ipcRenderer.send("showQuickSearchWindow"); + }, + // 隐藏窗口 + hideWindow: () => { + ipcRenderer.send("hideQuickSearchWindow"); + }, + // 显示窗口之前 + onShowWindowBefore: (callback): Function => { + ipcRenderer.on("onShowQuickSearchWindowBefore", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onShowQuickSearchWindowBefore"); + }; + }, + // 清空数据 + onClearData: (callback): Function => { + ipcRenderer.on("onQuickSearchClearData", (event, data) => { + callback(data); + }); + return () => { + ipcRenderer.removeAllListeners("onQuickSearchClearData"); + }; + }, + // 设置窗口高度 + setWindowHeight: (height: number) => { + ipcRenderer.send("setQuickSearchWindowHeight", height); + }, +}); + +contextBridge.exposeInMainWorld("about", { + // 创建窗口 + createWindow: () => { + ipcRenderer.send("createAboutWindow"); + }, + // 显示窗口 + showWindow: () => { + ipcRenderer.send("showAboutWindow"); + }, + // 关闭窗口 + closeWindow: () => { + ipcRenderer.send("closeAboutWindow"); + }, +}); + +contextBridge.exposeInMainWorld("data", { + // 创建备份/恢复数据窗口 + createBackupRestoreDataWindow: () => { + ipcRenderer.send("createBackupRestoreDataWindow"); + }, + // 显示备份/恢复数据窗口 + showBackupRestoreDataWindow: () => { + ipcRenderer.send("showBackupRestoreDataWindow"); + }, + // 关闭备份/恢复数据窗口 + closeBackupRestoreDataWindow: () => { + ipcRenderer.send("closeBackupRestoreDataWindow"); + }, + // 备份数据 + backupData: () => { + ipcRenderer.send("backupData"); + }, + // 恢复数据 + restoreData: () => { + ipcRenderer.send("restoreData"); + }, +}); diff --git a/electron/types/global.d.ts b/electron/types/global.d.ts new file mode 100644 index 0000000..e60a6ce --- /dev/null +++ b/electron/types/global.d.ts @@ -0,0 +1,75 @@ +import { BrowserWindow, Tray } from "electron"; +import { FSWatcher } from "node:fs"; +import { Setting } from "../../types/setting"; + +declare global { + // addon + var addon: any; + // 语言 + var language: any; + // 主窗口 + var mainWindow: BrowserWindow | null; + // 快速搜索窗口 + var quickSearchWindow: BrowserWindow | null; + // 快速搜索窗口是否初始化完成 + var quickSearchWindowInit: Boolean | null; + // 设置窗口 + var settingWindow: BrowserWindow | null; + // 分类添加/编辑窗口 + var classificationAddEditWindow: BrowserWindow | null; + // 分类图标窗口 + var classificationSetIconWindow: BrowserWindow | null; + // 关联分类窗口 + var classificationAssociateFolderWindow: BrowserWindow | null; + // 聚合分类窗口 + var classificationAggregateWindow: BrowserWindow | null; + // 项目添加/编辑窗口 + var itemAddEditWindow: BrowserWindow | null; + // 项目网络图标窗口 + var itemNetworkIconWindow: BrowserWindow | null; + // 项目SVG图标窗口 + var itemSVGIconWindow: BrowserWindow | null; + // 关于窗口 + var aboutWindow: BrowserWindow | null; + // 备份/恢复数据窗口 + var backupRestoreDataWindow: BrowserWindow | null; + // 存储关联分类监听 + var associateFolderWatcher: Map; + // 设置 + var setting: Setting | null; + // 托盘 + var tray: Tray; + // 主窗口方向 + var mainWindowDirection: String | null; + // 停靠在桌面边缘时自动隐藏timer + var autoHideTimer: NodeJS.Timeout; + // 需要失去焦点时隐藏 + var blurHide: boolean | null; + // 双击任务栏显示/隐藏timer + var doubleClickTaskbarTimer: NodeJS.Timeout; + // 双击任务栏显示/隐藏counter + var doubleClickTaskbarCounter: number; + // 监测无效项目interval + var checkInvalidItemInterval: NodeJS.Timeout; + // 存储子进程信息 + var childProcessMap: Map; + // 分类右键菜单显示 + var classificationRightMenu: boolean | null; + // 项目右键菜单显示 + var itemRightMenu: boolean | null; +} + +export interface ChildProcessInfo { + utilityProcess: Electron.UtilityProcess; + port1: Electron.MessagePortMain; + port2: Electron.MessagePortMain; +} + +export interface AssociateFolderData { + classificationId: number; + dir: string; + hiddenItems: string | null; + watch: FSWatcher; +} + +export {}; diff --git a/images/soft1.png b/images/soft1.png new file mode 100644 index 0000000..c1408cc Binary files /dev/null and b/images/soft1.png differ diff --git a/images/soft2.png b/images/soft2.png new file mode 100644 index 0000000..9d1c228 Binary files /dev/null and b/images/soft2.png differ diff --git a/images/soft3.png b/images/soft3.png new file mode 100644 index 0000000..2cf60ff Binary files /dev/null and b/images/soft3.png differ diff --git a/images/soft4.png b/images/soft4.png new file mode 100644 index 0000000..8385f44 Binary files /dev/null and b/images/soft4.png differ diff --git a/images/soft5.png b/images/soft5.png new file mode 100644 index 0000000..60c3bdf Binary files /dev/null and b/images/soft5.png differ diff --git a/images/soft6.webp b/images/soft6.webp new file mode 100644 index 0000000..4f3bae0 Binary files /dev/null and b/images/soft6.webp differ diff --git a/images/soft7.png b/images/soft7.png new file mode 100644 index 0000000..dd73231 Binary files /dev/null and b/images/soft7.png differ diff --git a/images/soft8.webp b/images/soft8.webp new file mode 100644 index 0000000..1a08a39 Binary files /dev/null and b/images/soft8.webp differ diff --git a/images/一键获取网址信息.gif b/images/一键获取网址信息.gif deleted file mode 100644 index c4bf8dc..0000000 Binary files a/images/一键获取网址信息.gif and /dev/null differ diff --git a/images/关联文件夹.gif b/images/关联文件夹.gif deleted file mode 100644 index 56d1a7d..0000000 Binary files a/images/关联文件夹.gif and /dev/null differ diff --git a/images/子分类.png b/images/子分类.png deleted file mode 100644 index 79a4b9e..0000000 Binary files a/images/子分类.png and /dev/null differ diff --git a/images/快速搜索.gif b/images/快速搜索.gif deleted file mode 100644 index 7af5b34..0000000 Binary files a/images/快速搜索.gif and /dev/null differ diff --git a/images/界面.png b/images/界面.png deleted file mode 100644 index 92f1bf3..0000000 Binary files a/images/界面.png and /dev/null differ diff --git a/images/相对路径.png b/images/相对路径.png deleted file mode 100644 index 2517e7c..0000000 Binary files a/images/相对路径.png and /dev/null differ diff --git a/images/自定义主题.png b/images/自定义主题.png deleted file mode 100644 index 5dcdc09..0000000 Binary files a/images/自定义主题.png and /dev/null differ diff --git a/images/自定义背景.png b/images/自定义背景.png deleted file mode 100644 index 02e3998..0000000 Binary files a/images/自定义背景.png and /dev/null differ diff --git a/index.html b/index.html new file mode 100644 index 0000000..125221e --- /dev/null +++ b/index.html @@ -0,0 +1,16 @@ + + + + + + + + Dawn Launcher + + + +
+ + + + \ No newline at end of file diff --git a/jsconfig.JSON b/jsconfig.JSON deleted file mode 100644 index 4aafc5f..0000000 --- a/jsconfig.JSON +++ /dev/null @@ -1,19 +0,0 @@ -{ - "compilerOptions": { - "target": "es5", - "module": "esnext", - "baseUrl": "./", - "moduleResolution": "node", - "paths": { - "@/*": [ - "src/*" - ] - }, - "lib": [ - "esnext", - "dom", - "dom.iterable", - "scripthost" - ] - } -} diff --git a/package.json b/package.json index 2dc9e81..1438c4c 100644 --- a/package.json +++ b/package.json @@ -1,60 +1,73 @@ { - "name": "DawnLauncher", + "name": "dawn-launcher", "productName": "Dawn Launcher", - "author": "Dawn Launcher", - "version": "1.2.3", + "version": "1.3.1", + "main": "dist-electron/main/index.js", + "description": "Windows 快捷启动工具,帮助您整理杂乱无章的桌面,分门别类管理您的桌面快捷方式,让您的桌面保持干净整洁。", + "author": "FanChenIO", "private": true, - "gypfile": true, - "scripts": { - "serve": "vue-cli-service serve", - "build": "vue-cli-service build", - "electron:build": "vue-cli-service electron:build", - "electron:serve": "vue-cli-service electron:serve", - "postinstall": "electron-builder install-app-deps", - "postuninstall": "electron-builder install-app-deps" + "keywords": [ + "electron", + "vite", + "vue" + ], + "debug": { + "env": { + "VITE_DEV_SERVER_URL": "http://127.0.0.1:3344/" + } }, - "dependencies": { - "@ckpack/vue-color": "^1.4.1", - "bindings": "^1.5.0", - "cheerio": "^1.0.0-rc.12", - "core-js": "^3.8.3", - "dompurify": "^3.0.3", - "electron-store": "^8.1.0", - "jimp": "^0.22.7", - "mime": "^3.0.0", - "node-addon-api": "^5.0.0", - "pinyin-match": "^1.2.4", - "request": "^2.88.2", - "retry": "^0.13.1", - "simplebar": "^5.3.8", - "sortablejs": "^1.15.0", - "urijs": "^1.19.11", - "uuid": "^9.0.0", - "vue": "^3.3.4", - "vue-router": "^4.2.0", - "vuex": "^4.1.0", - "xml2js": "^0.5.0" + "scripts": { + "dev": "vite", + "build": "vue-tsc --noEmit && vite build && electron-builder", + "preview": "vite preview", + "rsbuild": "napi build --release --strip ./native", + "rebuild": "electron rebuild.js", + "postinstall": "yarn run rebuild && yarn run rsbuild" + }, + "napi": { + "name": "addon" }, "devDependencies": { - "@babel/core": "^7.12.16", - "@tailwindcss/forms": "^0.5.3", - "@vue/cli-plugin-babel": "~5.0.0", - "@vue/cli-service": "~5.0.0", - "autoprefixer": "^10.4.8", - "electron": "^22.3.17", - "electron-builder": "^24.4.0", - "electron-devtools-installer": "^3.2.0", - "modclean": "^3.0.0-beta.1", - "postcss": "^8.4.16", - "prettier": "^2.7.1", - "tailwindcss": "^3.1.8", - "terser-webpack-plugin": "^5.3.8", - "vue-cli-plugin-electron-builder": "^3.0.0-alpha.4" + "@napi-rs/cli": "^2.16.3", + "@vicons/material": "^0.12.0", + "@vicons/utils": "^0.1.4", + "@vitejs/plugin-vue": "^4.4.0", + "autoprefixer": "^10.4.16", + "better-sqlite3-multiple-ciphers": "^9.0.0", + "electron": "^26.4.2", + "electron-builder": "^24.6.4", + "less": "^4.2.0", + "less-loader": "^11.1.3", + "naive-ui": "^2.35.0", + "postcss": "^8.4.31", + "tailwindcss": "^3.3.5", + "typescript": "^5.2.2", + "vite": "^4.4.11", + "vite-plugin-electron": "^0.14.1", + "vue": "^3.3.7", + "vue-tsc": "^1.8.22" }, - "browserslist": [ - "> 1%", - "last 2 versions", - "not dead", - "not ie 11" - ] -} + "dependencies": { + "@types/dompurify": "^3.0.3", + "@types/mime": "^3.0.2", + "@types/request": "^2.48.10", + "@types/retry": "^0.12.3", + "@types/sortablejs": "^1.15.3", + "@types/urijs": "^1.19.22", + "@types/xml2js": "^0.4.12", + "cheerio": "1.0.0-rc.12", + "dompurify": "^3.0.6", + "electron-log": "^5.0.0", + "electron-store": "^8.1.0", + "mime": "^3.0.0", + "pinia": "^2.1.7", + "pinyin-pro": "^3.17.0", + "request": "^2.88.2", + "retry": "^0.13.1", + "simplebar": "^6.2.5", + "sortablejs": "^1.15.0", + "urijs": "^1.19.11", + "vue-router": "^4.2.5", + "xml2js": "^0.6.2" + } +} \ No newline at end of file diff --git a/postcss.config.js b/postcss.config.js index 33ad091..96bb01e 100644 --- a/postcss.config.js +++ b/postcss.config.js @@ -3,4 +3,4 @@ module.exports = { tailwindcss: {}, autoprefixer: {}, }, -} +} \ No newline at end of file diff --git a/public/images/drag-and-drop.png b/public/drag-and-drop.png similarity index 100% rename from public/images/drag-and-drop.png rename to public/drag-and-drop.png diff --git a/public/images/logo.png b/public/images/logo.png deleted file mode 100644 index 7447b95..0000000 Binary files a/public/images/logo.png and /dev/null differ diff --git a/public/images/logo-transparent.png b/public/logo-transparent.png similarity index 100% rename from public/images/logo-transparent.png rename to public/logo-transparent.png diff --git a/public/images/logo.ico b/public/logo.ico similarity index 100% rename from public/images/logo.ico rename to public/logo.ico diff --git a/public/images/logo-thick.ico b/public/tray.ico similarity index 100% rename from public/images/logo-thick.ico rename to public/tray.ico diff --git a/rebuild.js b/rebuild.js new file mode 100644 index 0000000..e184de8 --- /dev/null +++ b/rebuild.js @@ -0,0 +1,33 @@ +const path = require("path"); +const child = require("child_process"); + +// If you prefer electron-rebuild: +// 👉 https://github.com/WiseLibs/better-sqlite3/blob/v8.5.2/docs/troubleshooting.md#electron +// 👉 https://stackoverflow.com/questions/46384591/node-was-compiled-against-a-different-node-js-version-using-node-module-versio/52796884#52796884 + +const better_sqlite3 = require.resolve("better-sqlite3-multiple-ciphers"); +const better_sqlite3_root = path.posix.join( + better_sqlite3.slice(0, better_sqlite3.lastIndexOf("node_modules")), + "node_modules/better-sqlite3-multiple-ciphers" +); +const cp = child.spawn( + process.platform === "win32" ? "npm.cmd" : "npm", + [ + "run", + "build-release", + `--target=${process.versions.electron}`, + // https://github.com/electron/electron/blob/v26.1.0/docs/tutorial/using-native-node-modules.md#manually-building-for-electron + "--dist-url=https://electronjs.org/headers", + ], + { + cwd: better_sqlite3_root, + stdio: "inherit", + } +); + +cp.on("exit", (code) => { + if (code === 0) { + console.log("Rebuild better-sqlite3 success."); + } + process.exit(code); +}); diff --git a/rust/lib.rs b/rust/lib.rs new file mode 100644 index 0000000..8f2e460 --- /dev/null +++ b/rust/lib.rs @@ -0,0 +1,167 @@ +use napi::JsFunction; +use napi_derive::napi; +use std::collections::HashMap; + +mod windows; + +/** + * 获取图标 + */ +#[allow(dead_code)] +#[napi] +fn get_file_icon(path: String) -> Option { + windows::get_file_icon(&path) +} + +/** + * 搜索路径 + */ +#[allow(dead_code)] +#[napi] +fn search_path(path: String) -> Option { + windows::search_path(&path) +} + +/** + * 解析快捷方式 + */ +#[allow(dead_code)] +#[napi] +fn get_shortcut_file_info(path: String) -> Option> { + windows::get_shortcut_file_info(&path) +} + +/** + * 运行 + */ +#[allow(dead_code)] +#[napi] +fn shell_execute(operation: String, file: String, params: String, start_location: Option) { + windows::shell_execute(operation, file, params, start_location) +} + +/** + * 运行系统项目 + */ +#[allow(dead_code)] +#[napi] +fn system_item_execute(target: String, params: Option) { + windows::system_item_execute(&target, params.as_deref()) +} + +/** + * 打开文件所在位置 + */ +#[allow(dead_code)] +#[napi] +fn open_file_location(path: String) { + windows::open_file_location(&path) +} + +/** + * 资源管理器菜单 + */ +#[allow(dead_code)] +#[napi] +fn explorer_context_menu(window: i32, path: String, x: i32, y: i32) { + windows::explorer_context_menu(window, &path, x, y) +} + +/** + * 获取环境变量 + */ +#[allow(dead_code)] +#[napi] +fn get_env_by_name(name: String) -> Option { + windows::get_env_by_name(&name) +} + +/** + * 是否是全屏模式 + */ +#[allow(dead_code)] +#[napi] +fn is_fullscreen() -> bool { + windows::is_fullscreen() +} + +/** + * 切换英文输入法 + */ +#[allow(dead_code)] +#[napi] +fn switch_english(window: i32) { + windows::switch_english(window) +} + +/** + * 创建鼠标HOOK + */ +#[allow(dead_code)] +#[napi] +fn create_mouse_hook(callback: JsFunction) { + windows::create_mouse_hook(callback) +} + +/** + * 启用鼠标HOOK + */ +#[allow(dead_code)] +#[napi] +fn enable_mouse_hook() { + windows::enable_mouse_hook() +} + +/** + * 禁用鼠标HOOK + */ +#[allow(dead_code)] +#[napi] +fn disable_mouse_hook() { + windows::disable_mouse_hook() +} + +/** + * 获取鼠标点击的窗口ClassName + */ +#[allow(dead_code)] +#[napi] +pub fn get_cursor_pos_window_class_name() -> String { + windows::get_cursor_pos_window_class_name() +} + +/** + * 获取剪切板文件列表 + */ +#[allow(dead_code)] +#[napi] +pub fn get_clipboard_file_list() -> Vec { + windows::get_clipboard_file_list() +} + +/** + * 剪切板是否存在BITMAP + */ +#[allow(dead_code)] +#[napi] +pub fn clipboard_has_bitmap() -> bool { + windows::clipboard_has_bitmap() +} + +/** + * 获取剪切板BITMAP的BASE64 + */ +#[allow(dead_code)] +#[napi] +pub fn get_clipboard_bitmap_base64() -> Option { + windows::get_clipboard_bitmap_base64() +} + +/** + * 清空回收站 + */ +#[allow(dead_code)] +#[napi] +pub fn empty_recycle_bin(window: i32) { + windows::empty_recycle_bin(window) +} diff --git a/rust/windows.rs b/rust/windows.rs new file mode 100644 index 0000000..ba1487c --- /dev/null +++ b/rust/windows.rs @@ -0,0 +1,673 @@ +use base64::{engine::general_purpose, Engine as _}; +use clipboard_win::{formats, get_clipboard}; +use image::{imageops::flip_vertical, ImageBuffer, ImageFormat, Rgba}; +use napi::{ + threadsafe_function::{ThreadsafeFunction, ThreadsafeFunctionCallMode}, + JsFunction, +}; +use serde::{Deserialize, Serialize}; +use std::{ + collections::HashMap, + io::Cursor, + path::Path, + process::Command, + sync::atomic::{AtomicBool, Ordering}, +}; +use windows::{ + core::{ComInterface, HSTRING, PCSTR, PCWSTR}, + w, + Win32::{ + Foundation::{HWND, LPARAM, LRESULT, MAX_PATH, POINT, RECT, SIZE, WPARAM}, + Graphics::Gdi::{ + GetMonitorInfoW, GetObjectW, MonitorFromWindow, BITMAP, MONITORINFO, + MONITOR_DEFAULTTONEAREST, + }, + Storage::FileSystem::SearchPathW, + System::{ + Com::{ + CoCreateInstance, CoInitializeEx, CoUninitialize, IPersistFile, + CLSCTX_INPROC_SERVER, COINIT_APARTMENTTHREADED, STGM_READ, + }, + Environment::GetEnvironmentVariableW, + SystemInformation::GetSystemDirectoryW, + }, + UI::{ + Input::Ime::{ + ImmGetContext, ImmReleaseContext, ImmSetConversionStatus, IME_CMODE_ALPHANUMERIC, + IME_SMODE_AUTOMATIC, + }, + Shell::{ + BHID_SFUIObject, IContextMenu, IShellItem, IShellItemImageFactory, IShellLinkW, + SHCreateItemFromParsingName, SHEmptyRecycleBinW, SHQueryUserNotificationState, + ShellExecuteW, ShellLink, CMF_NORMAL, CMINVOKECOMMANDINFO, + QUNS_ACCEPTS_NOTIFICATIONS, QUNS_APP, QUNS_BUSY, QUNS_NOT_PRESENT, + QUNS_PRESENTATION_MODE, QUNS_QUIET_TIME, QUNS_RUNNING_D3D_FULL_SCREEN, + SHERB_NOSOUND, SIIGBF_ICONONLY, SLGP_UNCPRIORITY, + }, + WindowsAndMessaging::{ + CallNextHookEx, CreatePopupMenu, DestroyMenu, FindWindowW, GetClassNameW, + GetCursorPos, GetForegroundWindow, GetSystemMetrics, GetWindowRect, SendMessageW, + SetForegroundWindow, SetWindowsHookExW, TrackPopupMenu, WindowFromPoint, HHOOK, + MSLLHOOKSTRUCT, SC_MONITORPOWER, SM_CXSCREEN, SM_CYSCREEN, SW_NORMAL, + SW_SHOWDEFAULT, TPM_NONOTIFY, TPM_RETURNCMD, WH_MOUSE_LL, WM_LBUTTONDOWN, + WM_LBUTTONUP, WM_MBUTTONDOWN, WM_MBUTTONUP, WM_MOUSEHWHEEL, WM_MOUSEMOVE, + WM_MOUSEWHEEL, WM_RBUTTONDOWN, WM_RBUTTONUP, WM_SYSCOMMAND, + }, + }, + }, +}; + +// 获取图标并转为BASE64 +pub fn get_file_icon(path: &str) -> Option { + // 返回信息 + let mut base64 = None; + // HSTRING + let path = HSTRING::from(path); + // PCWSTR + let path: PCWSTR = PCWSTR(path.as_ptr()); + // unsafe + unsafe { + // Init + let _ = CoInitializeEx(None, COINIT_APARTMENTTHREADED); + } + // IShellItemImageFactory + let result = unsafe { + SHCreateItemFromParsingName::, IShellItemImageFactory>(path, None) + }; + if let Ok(shell_item_image_factory) = result { + if let Some(mut image_buffer) = get_file_icon_image_buffer(&shell_item_image_factory, 256) { + // 判断像素点,是否是小图标 + let mut transparency: f64 = 0_f64; + let mut non_transparency: f64 = 0_f64; + for y in 0..image_buffer.height() { + for x in 0..image_buffer.width() { + let pixel = image_buffer.get_pixel(x, y); + let alpha = pixel[3]; // 获取像素的 Alpha 通道值 + if alpha == 0 { + // 透明 + transparency += 1_f64; + } else { + // 不透明 + non_transparency += 1_f64; + } + } + } + // 计算如果透明区域大于百分之70就代表是小图标 + let proportion = + (transparency / (transparency + non_transparency) * 100_f64).round() as u32; + if proportion >= 70 { + // 获取小图标 + if let Some(image_buffer_small) = + get_file_icon_image_buffer(&shell_item_image_factory, 48) + { + image_buffer = image_buffer_small; + } + } + // 翻转图片 + image_buffer = flip_vertical(&image_buffer); + // 转码 + base64 = Some(image_buffer_to_base64(image_buffer)); + } + } + unsafe { + // UnInit + CoUninitialize(); + } + base64 +} + +// 获取图标并转为ImageBuffer +fn get_file_icon_image_buffer( + shell_item_image_factory: &IShellItemImageFactory, + size: i32, +) -> Option, Vec>> { + // 获取图片 + let result = + unsafe { shell_item_image_factory.GetImage(SIZE { cx: size, cy: size }, SIIGBF_ICONONLY) }; + if let Ok(h_bitmap) = result { + // 转为BITMAP + let mut bitmap: BITMAP = BITMAP::default(); + unsafe { + GetObjectW( + h_bitmap, + std::mem::size_of::() as i32, + Some(&mut bitmap as *mut _ as _), + ); + } + // 转换ImageBuffer + let width: u32 = bitmap.bmWidth as u32; + let height = bitmap.bmHeight as u32; + let pixel_data: &[u8] = unsafe { + std::slice::from_raw_parts(bitmap.bmBits as *const u8, (width * height * 4) as usize) + }; + let result = ImageBuffer::, _>::from_raw(width, height, pixel_data.to_vec()); + if let Some(mut image_buffer) = result { + // 将ImageBuffer的颜色通道顺序从BGRA转为RGB + for pixel in image_buffer.pixels_mut() { + let b = pixel[0]; + let r = pixel[2]; + pixel[0] = r; + pixel[2] = b; + } + return Some(image_buffer); + } + } + None +} + +/** + * imageBuffer转BASE64 + */ +fn image_buffer_to_base64(image_buffer: ImageBuffer, Vec>) -> String { + // imageBufferData + let mut image_buffer_data = Cursor::new(Vec::new()); + // write + image_buffer + .write_to(&mut image_buffer_data, ImageFormat::Png) + .unwrap(); + // 转码 + format!( + "data:image/png;base64,{}", + general_purpose::STANDARD.encode(image_buffer_data.into_inner()) + ) +} + +/** + * 运行 + */ +pub fn shell_execute( + operation: String, + file: String, + params: String, + start_location: Option, +) { + // dir + let dir = start_location.unwrap_or_else(|| { + // 判断是否是文件夹 + let path = Path::new(&file); + if path.is_dir() { + // 文件夹 + file.clone() + } else { + // 文件 获取上一级目录 + path.parent().unwrap().display().to_string() + } + }); + // HSTRING + let operation = HSTRING::from(operation.as_str()); + let file = HSTRING::from(file.as_str()); + let params = HSTRING::from(params.as_str()); + let dir = HSTRING::from(dir.as_str()); + // PCWSTR + let operation = PCWSTR(operation.as_ptr()); + let file = PCWSTR(file.as_ptr()); + let params = PCWSTR(params.as_ptr()); + let dir = PCWSTR(dir.as_ptr()); + unsafe { + // execute + ShellExecuteW(None, operation, file, params, dir, SW_SHOWDEFAULT); + } +} + +/** + * 获取快捷方式信息 + */ +pub fn get_shortcut_file_info(path: &str) -> Option> { + // HSTRING + let path = HSTRING::from(path); + unsafe { + // Init + let _ = CoInitializeEx(None, COINIT_APARTMENTTHREADED); + } + // IShellLinkW + let shell_link_result: Result = + unsafe { CoCreateInstance(&ShellLink, None, CLSCTX_INPROC_SERVER) }; + if let Ok(shell_link) = shell_link_result { + // IPersistFile + let persist_file_result: Result = shell_link.cast(); + if let Ok(persist_file) = persist_file_result { + let load_result = unsafe { + // 加载路径 + persist_file.Load(PCWSTR(path.as_ptr()), STGM_READ) + }; + if let Ok(()) = load_result { + // 获取目标 + let mut target_buffer = [0u16; MAX_PATH as usize]; + let _ = unsafe { + shell_link.GetPath( + &mut target_buffer, + std::ptr::null_mut(), + SLGP_UNCPRIORITY.0 as u32, + ) + }; + // 获取参数 + let mut arguments_buffer = [0u16; MAX_PATH as usize]; + let _ = unsafe { shell_link.GetArguments(&mut arguments_buffer) }; + // map + let mut map = HashMap::with_capacity(2); + map.insert(String::from("target"), u16_to_string(&target_buffer)); + map.insert(String::from("arguments"), u16_to_string(&arguments_buffer)); + return Some(map); + } + } + } + unsafe { + // UnInit + CoUninitialize(); + } + None +} + +/** + * 运行命令 + */ +pub fn system_item_execute(target: &str, params: Option<&str>) { + if target == "static:TurnOffMonitor" { + // 关闭显示器 + turn_off_monitor() + } else { + let mut file = target.to_string(); + if !target.starts_with("shell:") { + // 如果不是shell开头,就查询路径 + file = search_path(target).unwrap_or(target.to_string()); + } + let file = HSTRING::from(file); + let params = match params { + Some(p) => HSTRING::from(p), + _ => HSTRING::new(), + }; + // 获取系统盘路径当作工作目录 + let mut buffer = [0u16; MAX_PATH as usize]; + unsafe { + GetSystemDirectoryW(Some(&mut buffer)); + } + let dir = u16_to_string(&buffer); + let dir = HSTRING::from(dir); + // execute + unsafe { + ShellExecuteW( + None, + w!("open"), + PCWSTR(file.as_ptr()), + PCWSTR(params.as_ptr()), + PCWSTR(dir.as_ptr()), + SW_SHOWDEFAULT, + ); + } + } +} + +/** + * 关闭显示器 + */ +pub fn turn_off_monitor() { + unsafe { + let _ = SendMessageW( + FindWindowW(PCWSTR::null(), PCWSTR::null()), + WM_SYSCOMMAND, + WPARAM(SC_MONITORPOWER as usize), + LPARAM(2), + ); + } +} + +/** + * 打开文件所在位置 + */ +pub fn open_file_location(path: &str) { + let _ = Command::new("explorer").arg("/select,").arg(path).spawn(); +} + +/** + * 资源管理器菜单 + */ +pub fn explorer_context_menu(window: i32, path: &str, x: i32, y: i32) { + // IShellItem + let path = HSTRING::from(path); + if let Ok(shell_item) = + unsafe { SHCreateItemFromParsingName::<_, _, IShellItem>(PCWSTR(path.as_ptr()), None) } + { + // IContextMenu + if let Ok(context_menu) = + unsafe { shell_item.BindToHandler::<_, IContextMenu>(None, &BHID_SFUIObject) } + { + // Menu + if let Ok(menu) = unsafe { CreatePopupMenu() } { + // 写入菜单 + if let Ok(()) = + unsafe { context_menu.QueryContextMenu(menu, 0, 1, 0x7FFF, CMF_NORMAL) } + { + // HWND + let hwnd = HWND(window as isize); + // 弹出菜单 + let res = unsafe { + SetForegroundWindow(hwnd); + TrackPopupMenu(menu, TPM_RETURNCMD | TPM_NONOTIFY, x, y, 0, hwnd, None) + }; + unsafe { + DestroyMenu(menu); + } + if res.as_bool() { + let mut info = CMINVOKECOMMANDINFO::default(); + info.cbSize = std::mem::size_of::() as u32; + info.hwnd = hwnd; + info.lpVerb = PCSTR((res.0 - 1) as *mut u8); + info.nShow = SW_NORMAL.0 as i32; + let _ = unsafe { context_menu.InvokeCommand(&info) }; + } + } + } + } + } +} + +/** + * 搜索路径 + */ +pub fn search_path(name: &str) -> Option { + let name = HSTRING::from(name); + let mut buffer = [0u16; MAX_PATH as usize]; + let result = unsafe { + SearchPathW( + PCWSTR::null(), + PCWSTR(name.as_ptr()), + PCWSTR::null(), + Some(&mut buffer), + None, + ) + }; + if result > 0 { + Some(u16_to_string(&buffer)) + } else { + None + } +} + +/** + * 数组转String + */ +fn u16_to_string(slice: &[u16]) -> String { + let mut vec = vec![]; + for s in slice { + if *s > 0 { + vec.push(*s); + } + } + String::from_utf16_lossy(&vec) +} + +/** + * 获取环境变量 + */ +pub fn get_env_by_name(name: &str) -> Option { + let name = HSTRING::from(name); + let mut buffer = [0u16; MAX_PATH as usize]; + let result = unsafe { GetEnvironmentVariableW(PCWSTR(name.as_ptr()), Some(&mut buffer)) }; + if result > 0 { + Some(u16_to_string(&buffer)) + } else { + None + } +} + +/** + * 是否有全屏窗口 + */ +fn is_fullscreen_window() -> bool { + // 获取当前活动窗口的句柄 + let foreground_window = unsafe { GetForegroundWindow() }; + // 获取活动窗口的位置信息 + let mut window_rect = RECT::default(); + unsafe { GetWindowRect(foreground_window, &mut window_rect) }; + // 获取包含活动窗口的显示器句柄 + let monitor = unsafe { MonitorFromWindow(foreground_window, MONITOR_DEFAULTTONEAREST) }; + // 获取显示器信息 + let mut monitor_info = MONITORINFO::default(); + monitor_info.cbSize = std::mem::size_of::() as u32; + unsafe { GetMonitorInfoW(monitor, &mut monitor_info) }; + // 获取屏幕的尺寸 + let screen_width = unsafe { GetSystemMetrics(SM_CXSCREEN) }; + let screen_height = unsafe { GetSystemMetrics(SM_CYSCREEN) }; + // 比较窗口位置和显示器尺寸来判断是否处于全屏模式 + if window_rect.left <= 0 + && window_rect.top <= 0 + && window_rect.right >= screen_width + && window_rect.bottom >= screen_height + && monitor_info.rcMonitor.left == 0 + && monitor_info.rcMonitor.top == 0 + && monitor_info.rcMonitor.right == screen_width + && monitor_info.rcMonitor.bottom == screen_height + { + // 获取窗口类名 + let mut buffer = [0u16; MAX_PATH as usize]; + unsafe { GetClassNameW(foreground_window, &mut buffer) }; + // 转为String + let name = u16_to_string(&buffer); + if name != "WorkerW" { + return true; + } + } + false +} + +/** + * 是否是全屏模式 + */ +pub fn is_fullscreen() -> bool { + if let Ok(state) = unsafe { SHQueryUserNotificationState() } { + if state == QUNS_NOT_PRESENT { + // 非全屏(机器锁定/屏幕保护程序/用户切换) + return false; + } else if state == QUNS_BUSY { + // 全屏(F11 全屏,我试过的所有视频游戏都使用它) + return is_fullscreen_window(); + } else if state == QUNS_RUNNING_D3D_FULL_SCREEN { + // 全屏(Direct3D 应用程序以独占模式运行,即全屏) + return true; + } else if state == QUNS_PRESENTATION_MODE { + // 全屏(一种用于显示全屏演示文稿的特殊模式) + return true; + } else if state == QUNS_ACCEPTS_NOTIFICATIONS { + // 不是全屏 + return false; + } else if state == QUNS_QUIET_TIME { + // 不是全屏 + return false; + } else if state == QUNS_APP { + // 不是全屏 + return false; + } + } + false +} + +/** + * 切换英文输入法 + */ +pub fn switch_english(window: i32) { + // 窗口句柄 + let hwnd = HWND(window as isize); + // 获取输入法上下文 + let imc = unsafe { ImmGetContext(hwnd) }; + // 设置输入法的首选转换模式为英文 + unsafe { ImmSetConversionStatus(imc, IME_CMODE_ALPHANUMERIC, IME_SMODE_AUTOMATIC) }; + // 释放输入法上下文 + unsafe { ImmReleaseContext(hwnd, imc) }; +} + +// 是否回调 +static mut MOUSE_HOOK_CALL: AtomicBool = AtomicBool::new(false); +// ThreadsafeFunction +static mut TSFN: Option> = None; +// 全局鼠标HOOK +static mut MOUSE_HOOK: Option = None; + +// 鼠标事件 +#[derive(Debug, Serialize, Deserialize)] +struct MouseEvent { + event: String, + x: i32, + y: i32, + button: i32, + mouse_data: u32, +} + +/** + * HOOK回调方法 + */ +unsafe extern "system" fn mouse_proc(code: i32, wparam: WPARAM, lparam: LPARAM) -> LRESULT { + if code >= 0 && MOUSE_HOOK_CALL.load(Ordering::Relaxed) { + // 鼠标坐标 + let msll_struct = lparam.0 as *const MSLLHOOKSTRUCT; + let x = (*msll_struct).pt.x; + let y = (*msll_struct).pt.y; + let mouse_data = (*msll_struct).mouseData; + // 参数 + let param = wparam.0 as u32; + // 事件 + let mut event = String::from(""); + // 按键类型 + let mut button = -1; + // 判断事件 + if param == WM_MOUSEMOVE { + // 鼠标移动 + event.push_str("mousemove"); + } else { + // 鼠标操作 + if param == WM_LBUTTONUP || param == WM_RBUTTONUP || param == WM_MBUTTONUP { + event.push_str("mouseup"); + } else if param == WM_LBUTTONDOWN || param == WM_RBUTTONDOWN || param == WM_MBUTTONDOWN + { + event.push_str("mousedown"); + } else if param == WM_MOUSEWHEEL || param == WM_MOUSEHWHEEL { + event.push_str("mousewheel"); + } + // 按键类型 + if param == WM_LBUTTONUP || param == WM_LBUTTONDOWN { + button = 1; + } else if param == WM_RBUTTONUP || param == WM_RBUTTONDOWN { + button = 2; + } else if param == WM_MBUTTONUP || param == WM_MBUTTONDOWN { + button = 3; + } else if param == WM_MOUSEWHEEL { + button = 0; + } else if param == WM_MOUSEHWHEEL { + button = 1; + } + } + if event != "" { + if let Some(func) = TSFN.as_ref() { + let mouse_event = MouseEvent { + event, + x, + y, + mouse_data, + button, + }; + func.call( + Ok(serde_json::to_string(&mouse_event).unwrap()), + ThreadsafeFunctionCallMode::NonBlocking, + ); + } + } + } + return CallNextHookEx(MOUSE_HOOK.unwrap(), code, wparam, lparam); +} + +/** + * 创建鼠标hook + */ +pub fn create_mouse_hook(callback: JsFunction) { + // 创建回调 + if let Ok(threadsafe_function) = + callback.create_threadsafe_function(0, |ctx| Ok(vec![ctx.value])) + { + unsafe { TSFN = Some(threadsafe_function) }; + // 创建鼠标HOOK + if let Ok(hook) = unsafe { SetWindowsHookExW(WH_MOUSE_LL, Some(mouse_proc), None, 0) } { + unsafe { + MOUSE_HOOK = Some(hook); + MOUSE_HOOK_CALL.store(true, Ordering::Relaxed); + }; + } + } +} + +/** + * 启用鼠标HOOK + */ +pub fn enable_mouse_hook() { + unsafe { MOUSE_HOOK_CALL.store(true, Ordering::Relaxed) } +} + +/** + * 禁用鼠标HOOK + */ +pub fn disable_mouse_hook() { + unsafe { MOUSE_HOOK_CALL.store(false, Ordering::Relaxed) } +} + +/** + * 获取鼠标点击的窗口ClassName + */ +pub fn get_cursor_pos_window_class_name() -> String { + // 获取鼠标位置 + let mut point: POINT = POINT::default(); + unsafe { + GetCursorPos(&mut point); + } + // 获取鼠标所在的窗口句柄 + let hwnd = unsafe { WindowFromPoint(point) }; + // 获取窗口的ClassName + let mut buffer = [0u16; MAX_PATH as usize]; + unsafe { + GetClassNameW(hwnd, &mut buffer); + }; + // 返回 + u16_to_string(&buffer) +} + +/** + * 获取剪切板文件列表 + */ +pub fn get_clipboard_file_list() -> Vec { + match get_clipboard(formats::FileList) { + Ok(vec) => vec, + Err(_) => vec![], + } +} + +/** + * 剪切板是否存在BITMAP + */ +pub fn clipboard_has_bitmap() -> bool { + match get_clipboard(formats::Bitmap) { + Ok(_) => true, + Err(_) => false, + } +} + +/** + * 获取剪切板BITMAP的BASE64 + */ +pub fn get_clipboard_bitmap_base64() -> Option { + match get_clipboard(formats::Bitmap) { + Ok(data) => Some(format!( + "data:image/bmp;base64,{}", + general_purpose::STANDARD.encode(data) + )), + Err(_) => None, + } +} + +/** + * 清空回收站 + */ +pub fn empty_recycle_bin(window: i32) { + // HWND + let hwnd = HWND(window as isize); + // 清空回收站 + unsafe { + let _ = SHEmptyRecycleBinW(hwnd, None, SHERB_NOSOUND); + }; +} diff --git a/src/App.vue b/src/App.vue new file mode 100644 index 0000000..931601d --- /dev/null +++ b/src/App.vue @@ -0,0 +1,282 @@ + + diff --git a/src/components/CustomItemIcon.vue b/src/components/CustomItemIcon.vue new file mode 100644 index 0000000..d24f684 --- /dev/null +++ b/src/components/CustomItemIcon.vue @@ -0,0 +1,91 @@ + + +../../types/item diff --git a/src/components/Desc.vue b/src/components/Desc.vue new file mode 100644 index 0000000..81d4caf --- /dev/null +++ b/src/components/Desc.vue @@ -0,0 +1,20 @@ + + diff --git a/src/components/ItemIcon.vue b/src/components/ItemIcon.vue new file mode 100644 index 0000000..1bb6ded --- /dev/null +++ b/src/components/ItemIcon.vue @@ -0,0 +1,172 @@ + + +../../types/item diff --git a/src/index.d.ts b/src/index.d.ts new file mode 100644 index 0000000..4a63818 --- /dev/null +++ b/src/index.d.ts @@ -0,0 +1,185 @@ +import { Classification } from "../types/classification"; +import { Item } from "../types/item"; + +type Callback = (param: any) => void; + +declare global { + interface Window { + api: { + emit: (windowName: string, listener: string, paylod: any) => void; + showErrorMessageBox: (windowName: string, message: string) => void; + showInfoMessageBox: (windowName: string, message: string) => void; + showConfirmBox: (windowName: string, message: string) => boolean; + selectFile: ( + windowName: string, + target: boolean, + defaultPath: string | null + ) => string | null; + selectDirectory: ( + windowName: string, + defaultPath: string | null + ) => string | null; + getFileIcon: (windowName: string, path: string) => void; + onGetFileIcon: (callback: Callback) => Function; + downloadImage: (windowName: string, url: string) => void; + onDownloadImage: (callback: Callback) => Function; + getURLInfo: (windowName: string, url: string) => void; + onGetURLInfo: (callback: Callback) => Function; + convertPath: (path: string) => string; + pathExist: (path: string) => boolean; + isFile: (path: string) => boolean; + openURL: (url: string) => void; + getVersion: () => string; + exit: () => void; + }; + main: { + showWindow: (blurHide: boolean) => void; + hideWindow: () => void; + initData: () => void; + onShowWindowBefore: (callback: Callback) => Function; + }; + classification: { + list: () => Array; + selectById: (id: number) => Classification | null; + add: ( + parentId: number | null, + name: string, + shortcutKey: string | null, + globalShortcutKey: boolean + ) => Classification | null; + update: (classifictaion: Classification) => boolean; + updateOrder: ( + fromId: number, + toId: number | null, + parentId: number | null + ) => boolean; + updateIcon: (id: number, icon: string | null) => boolean; + showAddEditWindow: () => void; + closeAddEditWindow: () => void; + showSetIconWindow: () => void; + closeSetIconWindow: () => void; + showRightMenu: ( + classification: Classification | null, + lockClassification: boolean + ) => void; + onAdd: (callback: Callback) => Function; + onUpdate: (callback: Callback) => Function; + onDelete: (callback: Callback) => Function; + onLock: (callback: Callback) => Function; + onUpdateIcon: (callback: Callback) => Function; + showAssociateFolderWindow: () => void; + closeAssociateFolderWindow: () => void; + setAssociateFolder: ( + id: number, + dir: string | null, + hiddenItems: string | null + ) => Classification; + onUpdateAssociateFolder: (callback: Callback) => Function; + hasChildClassification: (id: number) => boolean; + onCollapseSubClassification: (callback: Callback) => Function; + onUpdateItemLayout: (callback: Callback) => Function; + onUpdateItemSort: (callback: Callback) => Function; + onUpdateItemColumnNumber: (callback: Callback) => Function; + onUpdateItemIconSize: (callback: Callback) => Function; + addClassificationByDirectory: (pathList: Array) => void; + onAddClassificationByDirectory: (callback: Callback) => Function; + onUpdateItemShowOnly: (callback: Callback) => Function; + onUpdateFixed: (callback: Callback) => Function; + onUpdateItemOpenNumberSortToDefualt: (callback: Callback) => Function; + showAggregateWindow: () => void; + closeAggregateWindow: () => void; + updateAggregate: (id: number, sort: string, itemCount: number) => boolean; + onUpdateAggregate: (callback: Callback) => Function; + onUpdateExcludeSearch: (callback: Callback) => Function; + }; + item: { + showAddEditWindow: () => void; + closeAddEditWindow: () => void; + list: () => Array; + simpleList: () => Array; + selectById: (id: number) => Item | null; + add: (item: Item) => Item | null; + update: (item: Item) => boolean; + updateOrder: ( + fromIdList: Array, + toClassificationId: number, + newIndex: number | null + ) => boolean; + showRightMenu: (params: any) => void; + createNetworkIconWindow: () => void; + showNetworkIconWindow: () => void; + closeNetworkIconWindow: () => void; + onNetworkIcon: (callback: Callback) => Function; + createSVGIconWindow: () => void; + showSVGIconWindow: () => void; + closeSVGIconWindow: () => void; + onSVGIcon: (callback: Callback) => Function; + getSystemItemList: () => void; + onGetSystemItemList: (callback: Callback) => Function; + getStartMenuItemList: () => void; + onGetStartMenuItemList: (callback: Callback) => Function; + getAppxItemList: () => void; + onGetAppxItemList: (callback: Callback) => Function; + onAdd: (callback: Callback) => Function; + onUpdate: (callback: Callback) => Function; + onDelete: (callback: Callback) => Function; + onLock: (callback: Callback) => Function; + drop: (classificationId: number, pathList: Array) => void; + onBatchOperation: (callback: Callback) => Function; + run: (type: string, operation: string, item: Item) => void; + onConvertPath: (callback: Callback) => Function; + onRefreshIcon: (callback: Callback) => Function; + onMove: (callback: Callback) => Function; + onBatchOperationSelectAll: (callback: Callback) => Function; + onRightMenuClose: (callback: Callback) => Function; + onExplorerMenu: (callback: Callback) => Function; + dragOut: (item: Item) => void; + onCancelDragOut: (callback: Callback) => Function; + onUpdateOpenInfo: (callback: Callback) => Function; + onCheckInvalid: (callback: Callback) => Function; + updateOpenInfo: (type: string, id: number) => void; + }; + setting: { + createWindow: () => void; + showWindow: () => void; + closeWindow: () => void; + select: () => Setting | null; + add: (setting: Setting) => boolean; + update: (setting: Setting) => boolean; + onUpdate: (callback: Callback) => Function; + setStartup: (value: boolean) => void; + setTray: (show: boolean) => void; + setShortcutKey: (setting: Setting) => void; + setAlwaysTop: (value: boolean) => void; + setLockSize: (value: boolean) => void; + setFixedPosition: (fixedPosition: boolean, alwaysCenter: boolean) => void; + setAlwaysCenter: (fixedPosition: boolean, alwaysCenter: boolean) => void; + setEdgeAdsorb: (value: boolean) => void; + uploadBackgrounImage: () => any; + onSetBacngroundImage: (callback: Callback) => Function; + getBackgroundImage: (name: string, windowName: string) => void; + setCheckInvalidItem: (value: boolean) => void; + setOpenNumber: (value: boolean) => void; + }; + quickSearch: { + initFinished: () => void; + showWindow: () => void; + hideWindow: () => void; + onShowWindowBefore: (callback: Callback) => Function; + onClearData: (callback: Callback) => Function; + setWindowHeight: (height: number) => void; + }; + about: { + createWindow: () => void; + showWindow: () => void; + closeWindow: () => void; + }; + data: { + createBackupRestoreDataWindow: () => void; + showBackupRestoreDataWindow: () => void; + closeBackupRestoreDataWindow: () => void; + backupData: () => void; + restoreData: () => void; + }; + } +} diff --git a/src/main.ts b/src/main.ts new file mode 100644 index 0000000..5b93b35 --- /dev/null +++ b/src/main.ts @@ -0,0 +1,9 @@ +import { createApp } from "vue"; +import "./styles/style.css"; +import "./styles/tailwind.css"; +import router from "./router/index"; +import App from "./App.vue"; +import { createPinia } from "pinia"; +const pinia = createPinia(); + +createApp(App).use(router).use(pinia).mount("#app"); diff --git a/src/main/api/api.cc b/src/main/api/api.cc deleted file mode 100644 index 450e61f..0000000 --- a/src/main/api/api.cc +++ /dev/null @@ -1,589 +0,0 @@ -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#pragma comment(lib, "imm32.lib") - -std::string UTF8ToGBK(const char *source) -{ - int length = MultiByteToWideChar(CP_UTF8, 0, source, -1, NULL, 0); - wchar_t *wcGBK = new wchar_t[length + 1]; - memset(wcGBK, 0, length * 2 + 2); - MultiByteToWideChar(CP_UTF8, 0, source, -1, wcGBK, length); - length = WideCharToMultiByte(CP_ACP, 0, wcGBK, -1, NULL, 0, NULL, NULL); - char *cGBK = new char[length + 1]; - memset(cGBK, 0, length + 1); - WideCharToMultiByte(CP_ACP, 0, wcGBK, -1, cGBK, length, NULL, NULL); - std::string strTemp(cGBK); - if (wcGBK) - delete[] wcGBK; - if (cGBK) - delete[] cGBK; - return strTemp; -} - -std::string GBKToUTF8(const char *source) -{ - int length = MultiByteToWideChar(CP_ACP, 0, source, -1, NULL, 0); - wchar_t *wStr = new wchar_t[length + 1]; - memset(wStr, 0, length + 1); - MultiByteToWideChar(CP_ACP, 0, source, -1, wStr, length); - length = WideCharToMultiByte(CP_UTF8, 0, wStr, -1, NULL, 0, NULL, NULL); - char *str = new char[length + 1]; - memset(str, 0, length + 1); - WideCharToMultiByte(CP_UTF8, 0, wStr, -1, str, length, NULL, NULL); - std::string strTemp = str; - if (wStr) - delete[] wStr; - if (str) - delete[] str; - return strTemp; -} - -LPCWSTR StringToLPCWSTR(std::string source) -{ - size_t size = source.length(); - int wLen = ::MultiByteToWideChar(CP_UTF8, - 0, - source.c_str(), - -1, - NULL, - 0); - wchar_t *buffer = new wchar_t[wLen + 1]; - memset(buffer, 0, (wLen + 1) * sizeof(wchar_t)); - MultiByteToWideChar(CP_ACP, 0, source.c_str(), size, (LPWSTR)buffer, wLen); - return buffer; -} - -Napi::Number SaveIcon(std::string source, std::string target, int size, Napi::Env env) -{ - CoInitialize(NULL); - IShellItemImageFactory *itemImageFactory; - HBITMAP bitmap; - SIZE s = {size, size}; - if (SUCCEEDED(SHCreateItemFromParsingName(StringToLPCWSTR(source), NULL, IID_PPV_ARGS(&itemImageFactory)))) - { - itemImageFactory->GetImage(s, SIIGBF_ICONONLY, &bitmap); - itemImageFactory->Release(); - } - CoUninitialize(); - if (NULL == &bitmap) - { - return Napi::Number::New(env, 0); - } - else - { - CImage image; - image.Attach(bitmap); - image.SetHasAlphaChannel(1); - image.Save(target.c_str()); - return Napi::Number::New(env, 1); - } -} - -Napi::Number GetFileIcon(const Napi::CallbackInfo &info) -{ - Napi::Env env = info.Env(); - std::string source = info[0].ToString().Utf8Value(); - std::string target = info[1].ToString().Utf8Value(); - int size = info[2].As().Int32Value(); - return SaveIcon(UTF8ToGBK(source.c_str()), UTF8ToGBK(target.c_str()), size, env); -} - -Napi::Object GetShortcutFile(const Napi::CallbackInfo &info) -{ - Napi::Env env = info.Env(); - std::string source = info[0].ToString().Utf8Value(); - source = UTF8ToGBK(source.c_str()); - Napi::Object shortcutFileInfo; - CoInitialize(NULL); - CHAR target[MAX_PATH]; - CHAR arguments[MAX_PATH]; - WIN32_FIND_DATA fd; - IShellLink *shellLink; - HRESULT result = CoCreateInstance(CLSID_ShellLink, NULL, CLSCTX_INPROC_SERVER, IID_IShellLink, (void **)&shellLink); - if (SUCCEEDED(result)) - { - IPersistFile *persistFile; - result = shellLink->QueryInterface(IID_IPersistFile, (void **)&persistFile); - if (SUCCEEDED(result)) - { - result = persistFile->Load(StringToLPCWSTR(source), STGM_READ); - if (SUCCEEDED(result)) - { - shellLink->GetPath(target, MAX_PATH, &fd, SLGP_UNCPRIORITY); - shellLink->GetArguments(arguments, MAX_PATH); - shortcutFileInfo = Napi::Object::New(env); - shortcutFileInfo.Set(Napi::String::New(env, "target"), Napi::String::New(env, GBKToUTF8(target))); - shortcutFileInfo.Set(Napi::String::New(env, "arguments"), Napi::String::New(env, GBKToUTF8(arguments))); - } - } - if (NULL != persistFile) - { - persistFile->Release(); - } - } - if (NULL != shellLink) - { - shellLink->Release(); - } - CoUninitialize(); - return shortcutFileInfo; -} - -Napi::Number RunItem(const Napi::CallbackInfo &info) -{ - Napi::Env env = info.Env(); - std::string type = info[0].ToString().Utf8Value(); - std::string source = info[1].ToString().Utf8Value(); - std::string parameters = info[2].ToString().Utf8Value(); - LPCWSTR ldir; - if (info[3] != NULL) - { - std::string dir = info[3].ToString().Utf8Value(); - ldir = StringToLPCWSTR(UTF8ToGBK(dir.c_str())); - } - return Napi::Number::New(env, (unsigned long)ShellExecuteW(NULL, StringToLPCWSTR(type), StringToLPCWSTR(UTF8ToGBK(source.c_str())), StringToLPCWSTR(UTF8ToGBK(parameters.c_str())), ldir, SW_SHOWDEFAULT)); -} - -Napi::ThreadSafeFunction _tsfn; -HANDLE _hThread; -std::atomic_bool captureMouseMove = false; -// PostThreadMessage races with the actual thread; we'll get a thread ID -// and won't be able to post to it because it's "invalid" during the early -// lifecycle of the thread. To ensure that immediate pauses don't get dropped, -// we'll use this flag instead of distinct message IDs. -std::atomic_bool installEventHook = false; -DWORD dwThreadID = 0; - -struct MouseEventContext -{ -public: - int nCode; - WPARAM wParam; - LONG ptX; - LONG ptY; - DWORD mouseData; -}; - -void onMainThread(Napi::Env env, Napi::Function function, MouseEventContext *pMouseEvent) -{ - auto nCode = pMouseEvent->nCode; - auto wParam = pMouseEvent->wParam; - auto ptX = pMouseEvent->ptX; - auto ptY = pMouseEvent->ptY; - auto nMouseData = pMouseEvent->mouseData; - - delete pMouseEvent; - - if (nCode >= 0) - { - auto name = ""; - auto button = -1; - - // Isolate mouse movement, as it's more CPU intensive - if (wParam == WM_MOUSEMOVE) - { - // Is mouse movement - if (captureMouseMove.load()) - { - name = "mousemove"; - } - } - else - { - // Is not mouse movement - - // Determine event type - if (wParam == WM_LBUTTONUP || wParam == WM_RBUTTONUP || wParam == WM_MBUTTONUP) - { - name = "mouseup"; - } - else if (wParam == WM_LBUTTONDOWN || wParam == WM_RBUTTONDOWN || wParam == WM_MBUTTONDOWN) - { - name = "mousedown"; - } - else if (wParam == WM_MOUSEWHEEL || wParam == WM_MOUSEHWHEEL) - { - name = "mousewheel"; - } - - // Determine button - if (wParam == WM_LBUTTONUP || wParam == WM_LBUTTONDOWN) - { - button = 1; - } - else if (wParam == WM_RBUTTONUP || wParam == WM_RBUTTONDOWN) - { - button = 2; - } - else if (wParam == WM_MBUTTONUP || wParam == WM_MBUTTONDOWN) - { - button = 3; - } - else if (wParam == WM_MOUSEWHEEL) - { - button = 0; - } - else if (wParam == WM_MOUSEHWHEEL) - { - button = 1; - } - } - - // Only proceed if an event was identified - if (name != "") - { - Napi::HandleScope scope(env); - - auto x = Napi::Number::New(env, ptX); - auto y = Napi::Number::New(env, ptY); - - auto mouseData = Napi::Number::New(env, nMouseData); - - // Yell back to NodeJS - function.Call(env.Global(), - {Napi::String::New(env, name), x, y, - Napi::Number::New(env, button), mouseData}); - } - } -} - -LRESULT CALLBACK HookCallback(int nCode, WPARAM wParam, LPARAM lParam) -{ - - // If not WM_MOUSEMOVE or WM_MOUSEMOVE has been requested, process event - if (!(wParam == WM_MOUSEMOVE && !captureMouseMove.load())) - { - // Prepare data to be processed - MSLLHOOKSTRUCT *data = (MSLLHOOKSTRUCT *)lParam; - auto pMouseEvent = new MouseEventContext(); - pMouseEvent->nCode = nCode; - pMouseEvent->wParam = wParam; - pMouseEvent->ptX = data->pt.x; - pMouseEvent->ptY = data->pt.y; - pMouseEvent->mouseData = data->mouseData; - - // Process event on non-blocking thread - _tsfn.NonBlockingCall(pMouseEvent, onMainThread); - } - - // Let Windows continue with this event as normal - return CallNextHookEx(NULL, nCode, wParam, lParam); -} - -DWORD WINAPI MouseHookThread(LPVOID lpParam) -{ - MSG msg; - HHOOK hook = installEventHook.load() ? SetWindowsHookEx(WH_MOUSE_LL, HookCallback, NULL, 0) : NULL; - - while (GetMessage(&msg, NULL, 0, 0) > 0) - { - if (msg.message != WM_USER) - continue; - if (!installEventHook.load() && hook != NULL) - { - if (!UnhookWindowsHookEx(hook)) - break; - hook = NULL; - } - else if (installEventHook.load() && hook == NULL) - { - hook = SetWindowsHookEx(WH_MOUSE_LL, HookCallback, NULL, 0); - if (hook == NULL) - break; - } - } - - _tsfn.Release(); - return GetLastError(); -} - -Napi::Boolean createMouseHook(const Napi::CallbackInfo &info) -{ - _hThread = CreateThread(NULL, 0, MouseHookThread, NULL, CREATE_SUSPENDED, &dwThreadID); - _tsfn = Napi::ThreadSafeFunction::New( - info.Env(), - info[0].As(), - "WH_MOUSE_LL Hook Thread", - 512, - 1, - [](Napi::Env) - { CloseHandle(_hThread); }); - - ResumeThread(_hThread); - return Napi::Boolean::New(info.Env(), true); -} - -void enableMouseMove(const Napi::CallbackInfo &info) -{ - captureMouseMove = true; -} - -void disableMouseMove(const Napi::CallbackInfo &info) -{ - captureMouseMove = false; -} - -Napi::Boolean pauseMouseEvents(const Napi::CallbackInfo &info) -{ - BOOL bDidPost = FALSE; - if (dwThreadID != 0) - { - installEventHook = false; - bDidPost = PostThreadMessageW(dwThreadID, WM_USER, NULL, NULL); - } - return Napi::Boolean::New(info.Env(), bDidPost); -} - -Napi::Boolean resumeMouseEvents(const Napi::CallbackInfo &info) -{ - BOOL bDidPost = FALSE; - if (dwThreadID != 0) - { - installEventHook = true; - bDidPost = PostThreadMessageW(dwThreadID, WM_USER, NULL, NULL); - } - return Napi::Boolean::New(info.Env(), bDidPost); -} - -Napi::Boolean IsFullscreenSize(const Napi::CallbackInfo &info) -{ - // 获取当前活动窗口的句柄 - HWND foregroundWindow = GetForegroundWindow(); - // 获取活动窗口的位置信息 - RECT windowRect; - GetWindowRect(foregroundWindow, &windowRect); - // 获取包含活动窗口的显示器句柄 - HMONITOR monitor = MonitorFromWindow(foregroundWindow, MONITOR_DEFAULTTONEAREST); - // 获取显示器信息 - MONITORINFO monitorInfo = { sizeof(MONITORINFO) }; - GetMonitorInfo(monitor, &monitorInfo); - // 获取屏幕的尺寸 - int screenWidth = GetSystemMetrics(SM_CXSCREEN); - int screenHeight = GetSystemMetrics(SM_CYSCREEN); - // 比较窗口位置和显示器尺寸来判断是否处于全屏模式 - if (windowRect.left <= 0 && windowRect.top <= 0 && - windowRect.right >= screenWidth && windowRect.bottom >= screenHeight && - monitorInfo.rcMonitor.left == 0 && monitorInfo.rcMonitor.top == 0 && - monitorInfo.rcMonitor.right == screenWidth && monitorInfo.rcMonitor.bottom == screenHeight) - { - // 获取窗口类名 - char className[256]; - GetClassName(foregroundWindow, className, sizeof(className)); - std::string classNameStr(className); - if (classNameStr != "WorkerW") - { - return Napi::Boolean::New(info.Env(), true); - } - } - return Napi::Boolean::New(info.Env(), false); -} - -Napi::Boolean IsFullscreen(const Napi::CallbackInfo &info) -{ - QUERY_USER_NOTIFICATION_STATE state; - HRESULT hr = SHQueryUserNotificationState(&state); - if (hr == S_OK) - { - switch (state) - { - case QUNS_NOT_PRESENT: - // 非全屏(机器锁定/屏幕保护程序/用户切换) - return Napi::Boolean::New(info.Env(), false); - case QUNS_BUSY: - // 全屏(F11 全屏,我试过的所有视频游戏都使用它) - return IsFullscreenSize(info); - case QUNS_RUNNING_D3D_FULL_SCREEN: - // 全屏(Direct3D 应用程序以独占模式运行,即全屏) - return Napi::Boolean::New(info.Env(), true); - case QUNS_PRESENTATION_MODE: - // 全屏(一种用于显示全屏演示文稿的特殊模式) - return Napi::Boolean::New(info.Env(), true); - case QUNS_ACCEPTS_NOTIFICATIONS: - // 不是全屏 - return Napi::Boolean::New(info.Env(), false); - case QUNS_QUIET_TIME: - // 不是全屏 - return Napi::Boolean::New(info.Env(), false); - case QUNS_APP: - // 不是全屏 - return Napi::Boolean::New(info.Env(), false); - } - return Napi::Boolean::New(info.Env(), false); - } - else - { - return Napi::Boolean::New(info.Env(), false); - } -} - -Napi::Boolean ContextMenu(const Napi::CallbackInfo &info) -{ - // CoInitialize - CoInitialize(NULL); - // 获取文件路径 - std::string filePath = info[1].ToString().Utf8Value(); - // 获取文件的 IShellItem 接口 - IShellItem *pItem; - HRESULT hr = SHCreateItemFromParsingName(StringToLPCWSTR(UTF8ToGBK(filePath.c_str())), NULL, IID_PPV_ARGS(&pItem)); - if (FAILED(hr)) - { - return Napi::Boolean::New(info.Env(), false); - } - // 获取文件的 IContextMenu 接口 - IContextMenu *pContextMenu; - hr = pItem->BindToHandler(NULL, BHID_SFUIObject, IID_PPV_ARGS(&pContextMenu)); - if (FAILED(hr)) - { - pItem->Release(); - return Napi::Boolean::New(info.Env(), false); - } - // 创建菜单 - HMENU hMenu = CreatePopupMenu(); - if (hMenu == NULL) - { - pContextMenu->Release(); - pItem->Release(); - return Napi::Boolean::New(info.Env(), false); - } - hr = pContextMenu->QueryContextMenu(hMenu, 0, 1, 0x7FFF, CMF_NORMAL); - if (FAILED(hr)) - { - DestroyMenu(hMenu); - pContextMenu->Release(); - pItem->Release(); - return Napi::Boolean::New(info.Env(), false); - } - // 获取当前窗口句柄 - Napi::Buffer buffer = info[0].As>(); - HWND hWnd = static_cast(*reinterpret_cast(buffer.Data())); - if (!IsWindow(hWnd)) - { - return Napi::Boolean::New(info.Env(), false); - } - // 弹出菜单 - int command = TrackPopupMenuEx(hMenu, TPM_RETURNCMD | TPM_NONOTIFY, info[2].As(), info[3].As(), hWnd, NULL); - if (command > 0) - { - CMINVOKECOMMANDINFOEX info = {0}; - info.cbSize = sizeof(info); - info.hwnd = hWnd; - info.lpVerb = MAKEINTRESOURCEA(command - 1); - info.nShow = SW_NORMAL; - pContextMenu->InvokeCommand((LPCMINVOKECOMMANDINFO)&info); - } - // 释放资源 - DestroyMenu(hMenu); - pContextMenu->Release(); - pItem->Release(); - // CoUninitialize - CoUninitialize(); - return Napi::Boolean::New(info.Env(), true); -} - -Napi::Boolean SwitchEnglish(const Napi::CallbackInfo &info) -{ - // 获取当前窗口句柄 - Napi::Buffer buffer = info[0].As>(); - HWND hWnd = static_cast(*reinterpret_cast(buffer.Data())); - if (!IsWindow(hWnd)) - { - return Napi::Boolean::New(info.Env(), false); - } - // 获取输入法上下文 - HIMC hImc = ImmGetContext(hWnd); - if (hImc == nullptr) - { - return Napi::Boolean::New(info.Env(), false); - } - // 设置输入法的首选转换模式为英文 - ImmSetConversionStatus(hImc, IME_CMODE_ALPHANUMERIC, IME_SMODE_AUTOMATIC); - // 释放输入法上下文 - ImmReleaseContext(hWnd, hImc); - return Napi::Boolean::New(info.Env(), true); -} - -Napi::String getCursorPosWindowClassName(const Napi::CallbackInfo &info) -{ - POINT cursorPos; - GetCursorPos(&cursorPos); - HWND windowHandle = WindowFromPoint(cursorPos); - char className[256]; - GetClassName(windowHandle, className, sizeof(className)); - std::string classNameStr(className); - return Napi::String::New(info.Env(), className); -} - -Napi::Boolean TurnOffMonitor(const Napi::CallbackInfo &info) -{ - // 关闭显示器 - SendMessage(FindWindow(0, 0), WM_SYSCOMMAND, SC_MONITORPOWER, (LPARAM)2); - return Napi::Boolean::New(info.Env(), true); -} - -Napi::Boolean EmptyRecycleBin(const Napi::CallbackInfo &info) { - // 获取当前窗口句柄 - Napi::Buffer buffer = info[0].As>(); - HWND hWnd = static_cast(*reinterpret_cast(buffer.Data())); - if (!IsWindow(hWnd)) - { - return Napi::Boolean::New(info.Env(), false); - } - SHEmptyRecycleBinW(hWnd, NULL, SHERB_NOSOUND); - return Napi::Boolean::New(info.Env(), true); -} - -Napi::Object Init(Napi::Env env, Napi::Object exports) -{ - exports.Set(Napi::String::New(env, "GetFileIcon"), - Napi::Function::New(env, GetFileIcon)); - - exports.Set(Napi::String::New(env, "GetShortcutFile"), - Napi::Function::New(env, GetShortcutFile)); - - exports.Set(Napi::String::New(env, "RunItem"), - Napi::Function::New(env, RunItem)); - - exports.Set(Napi::String::New(env, "createMouseHook"), - Napi::Function::New(env, createMouseHook)); - - exports.Set(Napi::String::New(env, "enableMouseMove"), - Napi::Function::New(env, enableMouseMove)); - - exports.Set(Napi::String::New(env, "disableMouseMove"), - Napi::Function::New(env, disableMouseMove)); - - exports.Set(Napi::String::New(env, "pauseMouseEvents"), - Napi::Function::New(env, pauseMouseEvents)); - - exports.Set(Napi::String::New(env, "resumeMouseEvents"), - Napi::Function::New(env, resumeMouseEvents)); - - exports.Set(Napi::String::New(env, "IsFullscreen"), - Napi::Function::New(env, IsFullscreen)); - - exports.Set(Napi::String::New(env, "ContextMenu"), - Napi::Function::New(env, ContextMenu)); - - exports.Set(Napi::String::New(env, "SwitchEnglish"), - Napi::Function::New(env, SwitchEnglish)); - - exports.Set(Napi::String::New(env, "getCursorPosWindowClassName"), - Napi::Function::New(env, getCursorPosWindowClassName)); - - exports.Set(Napi::String::New(env, "TurnOffMonitor"), - Napi::Function::New(env, TurnOffMonitor)); - - exports.Set(Napi::String::New(env, "EmptyRecycleBin"), - Napi::Function::New(env, EmptyRecycleBin)); - return exports; -} - -NODE_API_MODULE(hello, Init) diff --git a/src/main/appInit.js b/src/main/appInit.js deleted file mode 100644 index 28a645f..0000000 --- a/src/main/appInit.js +++ /dev/null @@ -1,32 +0,0 @@ -import { app } from "electron"; -import fs from "fs"; -import path from "path"; - -function getDawnLauncherProfilePath() { - let p; - if (process.env.NODE_ENV !== "production") { - p = path.resolve("."); - } else { - p = path.dirname(process.execPath); - } - p = path.resolve(p, ".."); - p = path.join(p, ".dawn_launcher_profile"); - return p; -} - -try { - // 安装版 - // 记录一下默认目录 - global.defaultAppDataPath = app.getPath("appData"); - // 获取数据目录配置文件地址 - let dataDirPath = getDawnLauncherProfilePath(); - // 读取文件内容 - let r = fs.readFileSync(dataDirPath); - if (r != null) { - let appDataPath = r.toString(); - fs.statSync(appDataPath); - app.setPath("appData", appDataPath); - } - // 免安装版 - // app.setPath("appData", process.env.NODE_ENV !== "production" ? path.resolve(".") + "/data" : path.dirname(process.execPath) + "/data"); -} catch (e) {} diff --git a/src/main/cache/data.js b/src/main/cache/data.js deleted file mode 100644 index 4ac86d7..0000000 --- a/src/main/cache/data.js +++ /dev/null @@ -1,7 +0,0 @@ -import Store from "electron-store"; - -const cacheStore = new Store({ name: "cache", encryptionKey: "41fdb85a-4706-57b1-ba22-d7556f3723c7", clearInvalidConfig: true }); - -export default { - cacheStore, -}; diff --git a/src/main/classification/index.js b/src/main/classification/index.js deleted file mode 100644 index 975e355..0000000 --- a/src/main/classification/index.js +++ /dev/null @@ -1,50 +0,0 @@ -import util from "../util" - -/** - * 获取分类 - * @param parentId - * @param childId - * @returns {*|null|{childList}|any|any} - */ -function getClassificationById(parentId, childId) { - if (parentId != null) { - let classificationParent; - for (let c of global.list) { - if (c.id == parentId) { - classificationParent = c; - break; - } - } - if (classificationParent != null && childId != null) { - if (!util.arrayIsEmpty(classificationParent.childList)) { - let classificationChild; - for (let c of classificationParent.childList) { - if (c.id == childId) { - classificationChild = c; - break; - } - } - return classificationChild; - } else { - return classificationParent; - } - } else { - return classificationParent; - } - } - return null; -} - -/** - * 转换ID - * @param id - * @param parentId - */ -function convertClassificationId(id, parentId) { - return { classificationParentId: parentId != null ? parentId : id, classificationChildId: parentId != null ? id : null }; -} - -export default { - getClassificationById, - convertClassificationId, -}; diff --git a/src/main/classification/ipcEvent.js b/src/main/classification/ipcEvent.js deleted file mode 100644 index ee32432..0000000 --- a/src/main/classification/ipcEvent.js +++ /dev/null @@ -1,338 +0,0 @@ -import { dialog, ipcMain, Menu } from "electron"; -import data from "../data"; -import ItemJS from "../item/index"; -import cacheData from "../cache/data"; -import util from "../util"; - -/** - * 删除分类提示 - * @param params - * @param callback - */ -function classificationDeleteDialog(params, callback) { - let name = params.classificationChildId != null ? params.classificationChildName : params.classificationParentName; - dialog - .showMessageBox(global.mainWindow, { - message: global.currentLanguage.deleteClassificationMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - callback(params); - } - }); -} - -export default function () { - // 分类空白处右键菜单 - ipcMain.on("classificationContentRightMenu", (event, args) => { - let m = Menu.buildFromTemplate([ - { - label: global.currentLanguage.newClassification, - click: () => { - let params = { - type: 0, - }; - global.mainWindow.webContents.send("showClassificationAddEditWindow", JSON.stringify(params)); - }, - }, - ]); - util.menuListen(m); - m.popup(); - }); - // 某个父级分类上右键菜单 - ipcMain.on("classificationRightMenu", (event, args) => { - let p = JSON.parse(args); - let menuList = [ - { - label: global.currentLanguage.newSubClassification, - click: () => { - let params = { - type: 0, - parentId: p.classificationParentId, - }; - global.mainWindow.webContents.send("showClassificationAddEditWindow", JSON.stringify(params)); - }, - }, - { type: "separator" }, - { - label: global.currentLanguage.newClassification, - click: () => { - let params = { - type: 0, - }; - global.mainWindow.webContents.send("showClassificationAddEditWindow", JSON.stringify(params)); - }, - }, - { type: "separator" }, - ]; - // 固定分类 - let fixedClassificationData = data.store.get("fixedClassification"); - let selected = - fixedClassificationData != null && - fixedClassificationData.classificationParentId == p.classificationParentId && - fixedClassificationData.classificationChildId == null; - menuList.push({ - label: global.currentLanguage.fixedClassification, - icon: selected ? util.getDot() : null, - click: () => { - if (selected) { - data.store.set("fixedClassification", null); - } else { - data.store.set("fixedClassification", { classificationParentId: p.classificationParentId }); - } - }, - }); - if (!p.aggregate) { - menuList.push({ - label: global.currentLanguage.excludeSearch, - icon: p.excludeSearch ? util.getDot() : null, - click: () => { - let params = { - classificationParentId: p.classificationParentId, - }; - global.mainWindow.webContents.send("classificationExcludeSearch", JSON.stringify(params)); - }, - }); - } - menuList.push({ type: "separator" }); - if (!p.haveClassificationChild) { - if (!p.aggregate) { - // 关联文件夹 - menuList.push({ - label: global.currentLanguage.associatedFolder, - click: () => { - let params = { - id: p.classificationParentId, - }; - global.mainWindow.webContents.send("showClassificationAssociatedFolderWindow", JSON.stringify(params)); - }, - }); - } - if (!p.isMapDirectory) { - menuList.push({ - label: "聚合分类", - click: () => { - let params = { - id: p.classificationParentId, - }; - global.mainWindow.webContents.send("showClassificationAggregateWindow", JSON.stringify(params)); - }, - }); - } - menuList.push({ type: "separator" }); - } - menuList.push({ - label: global.currentLanguage.setIcon, - click: () => { - let params = { - id: p.classificationParentId, - }; - global.mainWindow.webContents.send("showSetClassificationIconWindow", JSON.stringify(params)); - }, - }); - menuList.push({ - label: global.currentLanguage.deleteIcon, - click: () => { - let params = { - id: p.classificationParentId, - }; - global.mainWindow.webContents.send("deleteSetClassificationIcon", JSON.stringify(params)); - }, - }); - menuList.push({ type: "separator" }); - if (!p.aggregate) { - menuList.push(ItemJS.itemSortMenu(p.classificationParentId, null, p.haveClassificationChild, p.sort)); - } - menuList.push(...ItemJS.itemLayoutIconSize(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.layout, p.iconSize)); - menuList.push(ItemJS.itemShowOnly(p.classificationParentId, null, p.haveClassificationChild, p.showOnly)); - if ( - !p.haveClassificationChild && - ((p.layout != null && p.layout == "list") || (global.setting.item.layout == "list" && (p.layout == null || p.layout == "default"))) - ) { - menuList.push(ItemJS.itemColumnNumber(p.classificationParentId, null, p.haveClassificationChild, p.columnNumber)); - } - menuList.push({ type: "separator" }); - menuList.push( - { - label: global.currentLanguage.edit, - click: () => { - let params = { - type: 1, - id: p.classificationParentId, - }; - global.mainWindow.webContents.send("showClassificationAddEditWindow", JSON.stringify(params)); - }, - }, - { - label: global.currentLanguage.delete, - click: () => { - classificationDeleteDialog(p, (p) => { - let params = { - id: p.classificationParentId, - }; - global.mainWindow.webContents.send("classificationDelete", JSON.stringify(params)); - }); - }, - } - ); - menuList.push({ type: "separator" }); - menuList.push({ - label: p.lockClassification ? global.currentLanguage.unlockClassification : global.currentLanguage.lockClassification, - click: () => { - global.mainWindow.webContents.send("setLockClassification", !p.lockClassification); - cacheData.cacheStore.set("lockClassification", !p.lockClassification); - }, - }); - let m = Menu.buildFromTemplate(menuList); - util.menuListen(m); - m.popup(); - }); - // 某个子级分类上右键菜单 - ipcMain.on("classificationChildRightMenu", (event, args) => { - let p = JSON.parse(args); - let menuList = []; - // 固定分类 - let fixedClassificationData = data.store.get("fixedClassification"); - let selected = - fixedClassificationData != null && - fixedClassificationData.classificationParentId == p.classificationParentId && - fixedClassificationData.classificationChildId == p.classificationChildId; - menuList.push({ - label: global.currentLanguage.fixedClassification, - icon: selected ? util.getDot() : null, - click: () => { - if (selected) { - data.store.set("fixedClassification", null); - } else { - data.store.set("fixedClassification", { classificationParentId: p.classificationParentId, classificationChildId: p.classificationChildId }); - } - }, - }); - if (!p.aggregate) { - menuList.push({ - label: global.currentLanguage.excludeSearch, - icon: p.excludeSearch ? util.getDot() : null, - click: () => { - let params = { - classificationParentId: p.classificationParentId, - classificationChildId: p.classificationChildId, - }; - global.mainWindow.webContents.send("classificationExcludeSearch", JSON.stringify(params)); - }, - }); - } - menuList.push({ type: "separator" }); - if (!p.aggregate) { - // 关联文件夹 - menuList.push({ - label: global.currentLanguage.associatedFolder, - click: () => { - let params = { - id: p.classificationChildId, - parentId: p.classificationParentId, - }; - global.mainWindow.webContents.send("showClassificationAssociatedFolderWindow", JSON.stringify(params)); - }, - }); - } - if (!p.isMapDirectory) { - menuList.push({ - label: "聚合分类", - click: () => { - let params = { - id: p.classificationChildId, - parentId: p.classificationParentId, - }; - global.mainWindow.webContents.send("showClassificationAggregateWindow", JSON.stringify(params)); - }, - }); - } - menuList.push({ type: "separator" }); - menuList.push({ - label: global.currentLanguage.setIcon, - click: () => { - let params = { - id: p.classificationChildId, - parentId: p.classificationParentId, - }; - global.mainWindow.webContents.send("showSetClassificationIconWindow", JSON.stringify(params)); - }, - }); - menuList.push({ - label: global.currentLanguage.deleteIcon, - click: () => { - let params = { - id: p.classificationChildId, - parentId: p.classificationParentId, - }; - global.mainWindow.webContents.send("deleteSetClassificationIcon", JSON.stringify(params)); - }, - }); - menuList.push({ type: "separator" }); - if (!p.aggregate) { - menuList.push(ItemJS.itemSortMenu(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.sort)); - } - menuList.push(...ItemJS.itemLayoutIconSize(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.layout, p.iconSize)); - menuList.push(ItemJS.itemShowOnly(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.showOnly)); - if ( - !p.haveClassificationChild && - ((p.layout != null && p.layout == "list") || (global.setting.item.layout == "list" && (p.layout == null || p.layout == "default"))) - ) { - menuList.push(ItemJS.itemColumnNumber(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.columnNumber)); - } - menuList.push({ type: "separator" }); - menuList.push( - { - label: global.currentLanguage.edit, - click: () => { - let params = { - type: 1, - id: p.classificationChildId, - parentId: p.classificationParentId, - }; - global.mainWindow.webContents.send("showClassificationAddEditWindow", JSON.stringify(params)); - }, - }, - { - label: global.currentLanguage.delete, - click: () => { - classificationDeleteDialog(p, (p) => { - let params = { - id: p.classificationChildId, - parentId: p.classificationParentId, - }; - global.mainWindow.webContents.send("classificationDelete", JSON.stringify(params)); - }); - }, - } - ); - menuList.push({ type: "separator" }); - menuList.push({ - label: p.lockClassification ? global.currentLanguage.unlockClassification : global.currentLanguage.lockClassification, - click: () => { - global.mainWindow.webContents.send("setLockClassification", !p.lockClassification); - cacheData.cacheStore.set("lockClassification", !p.lockClassification); - }, - }); - let m = Menu.buildFromTemplate(menuList); - util.menuListen(m); - m.popup(); - }); - // 获取锁定分类状态 - ipcMain.on("getLockClassification", (event, args) => { - let lockClassification = cacheData.cacheStore.get("lockClassification"); - event.returnValue = lockClassification == null ? false : lockClassification; - }); - // 获取固定分类 - ipcMain.on("getFixedClassification", (event, args) => { - event.returnValue = data.store.get("fixedClassification"); - }); - // 设置固定分类 - ipcMain.on("setFixedClassification", (event, args) => { - data.store.set("fixedClassification", args); - }); -} diff --git a/src/main/data.js b/src/main/data.js deleted file mode 100644 index f80d96d..0000000 --- a/src/main/data.js +++ /dev/null @@ -1,126 +0,0 @@ -import ClassificationJS from "./classification/index"; -const Store = require("electron-store"); -const store = new Store({ name: "data", encryptionKey: "0b52eb58-4c0f-5ff1-b062-031546a8d269", clearInvalidConfig: true }); - -/** - * 默认初始化 - * @returns {Promise} - */ -function initData() { - let list = store.get("list"); - if (list == null || list.length == 0) { - list = [ - { - id: 1, - name: "新分类", - order: 0, - }, - ]; - store.set("list", list); - } - global.list = list; -} - -/** - * 分离数据 - */ -function splitData() { - let iconData = store.get("iconData"); - if (iconData == null) { - iconData = []; - for (let c of global.list) { - if (c.childList != null) { - for (let cc of c.childList) { - if (cc.itemList != null) { - for (let item of cc.itemList) { - let icon = { - classificationParentId: item.classificationParentId, - classificationChildId: item.classificationId, - itemId: item.id, - icon: item.icon, - }; - item.icon = null; - iconData.push(icon); - } - } - } - } else { - if (c.itemList != null) { - for (let item of c.itemList) { - let icon = { - classificationParentId: item.classificationId, - classificationChildId: null, - itemId: item.id, - icon: item.icon, - }; - item.icon = null; - iconData.push(icon); - } - } - } - } - store.set("iconData", iconData); - store.set("list", global.list); - } -} - -/** - * 校验数据 - */ -function validData() { - let iconData = store.get("iconData"); - if (iconData != null) { - let newIconData = []; - for (let icon of iconData) { - let classification = ClassificationJS.getClassificationById(icon.classificationParentId, icon.classificationChildId); - if (classification != null && classification.itemList != null && classification.itemList.length > 0) { - for (let item of classification.itemList) { - if (icon.itemId == item.id) { - newIconData.push(icon); - break; - } - } - } - } - store.set("iconData", newIconData); - } -} - -/** - * 获取分类数据 - * @returns {Promise} - */ -function getList() { - this.initData(); - let list = store.get("list"); - global.list = list; - return list; -} - -/** - * 保存 - * @param list - * @returns {Promise} - */ -function setList(list) { - store.set("list", list); - global.list = list; -} - -/** - * 获取图标 - * @returns {Promise} - */ -function getIconData() { - return store.get("iconData"); -} - -export default { - store, - initData, - splitData, - validData, - getList, - setList, - getIconData, -}; diff --git a/src/main/ipcEvent.js b/src/main/ipcEvent.js deleted file mode 100644 index 5082e07..0000000 --- a/src/main/ipcEvent.js +++ /dev/null @@ -1,414 +0,0 @@ -import { ipcMain, dialog, Menu, app, shell } from "electron"; -import os from "os"; -import data from "@/main/data"; -import fs from "fs"; -import settingIndex from "./setting/index"; -import util from "./util"; -import retry from "retry"; -import request from "request"; -import mime from "mime"; -import path from "path"; - -/** - * 固定位置 - * @param fixedPosition - * @param alwaysCenter - */ -function setFixedPosition(fixedPosition, alwaysCenter) { - global.mainWindow.setMovable(fixedPosition); - if (alwaysCenter) { - global.mainWindow.setMovable(false); - } -} - -export default function () { - // 隐藏 - ipcMain.on("hide", (event, args) => { - global.mainWindow.hide(); - }); - // 隐藏 - ipcMain.on("hideMainWindow", (event, args) => { - global.mainWindow.webContents.send("hideMainWindowBefore"); - }); - // 关闭 - ipcMain.on("close", (event, args) => { - global.mainWindow.close(); - }); - // 获取数据 - ipcMain.on("getList", (event) => { - let list = data.getList(); - event.returnValue = list; - }); - // 保存数据 - ipcMain.on("setList", (event, args) => { - let params = JSON.parse(args); - data.setList(params.list); - settingIndex.setShortcutKey(global.setting); - if (params.searchWindowGetData != null && params.searchWindowGetData) { - if (global.searchWindow != null && !global.searchWindow.isDestroyed()) { - global.searchWindow.webContents.send("searchWindowGetData"); - } - } - }); - // 错误消息 - ipcMain.on("errorMessage", (event, args) => { - dialog.showMessageBox(global.mainWindow, { - title: "Dawn Launcher", - message: args, - buttons: [global.currentLanguage.ok], - type: "error", - noLink: true, - cancelId: 1, - }); - }); - // 文本框菜单 - ipcMain.on("textRightMenu", (event, args) => { - // 菜单 - let m = Menu.buildFromTemplate([ - { - role: "cut", - label: global.currentLanguage.cut, - }, - { - role: "copy", - label: global.currentLanguage.copy, - }, - { - role: "paste", - label: global.currentLanguage.paste, - }, - ]); - util.menuListen(m); - m.popup(); - }); - // 获取版本 - ipcMain.on("getVersion", (event) => { - event.returnValue = app.getVersion(); - }); - // 打开网页 - ipcMain.on("openUrl", (event, args) => { - shell.openExternal(args); - }); - // 检查更新 - ipcMain.on("checkUpdate", () => { - util.checkUpdate("checkUpdate"); - }); - // 统计 - ipcMain.on("statistics", () => { - try { - let data = { - system: os.type(), - release: os.release(), - locale: app.getLocale(), - appVersion: app.getVersion(), - }; - // 重试 - const operation = retry.operation({ - retries: 5, // 最多重试 5 次 - factor: 1, // 每次重试之间的时间间隔加倍 - minTimeout: 1000, // 第一次重试之前等待的时间 - maxTimeout: 5000, // 最长等待时间 - }); - // 发起请求 - operation.attempt((currentAttempt) => { - request( - { - uri: "https://client.dawnlauncher.com/access/statistics/add", - method: "POST", - json: true, - headers: { - "content-type": "application/json", - }, - body: data, - timeout: 5000, - }, - function (error, response, body) { - if (operation.retry(error)) { - return; - } - } - ); - }); - } catch (e) {} - }); - // 备份数据 - ipcMain.on("backup", () => { - try { - dialog - .showSaveDialog(global.mainWindow, { - title: global.currentLanguage.backUpData, - defaultPath: "data", - filters: [{ name: "JSON", extensions: ["json"] }], - }) - .then((r) => { - if (!r.canceled && !util.strIsEmpty(r.filePath)) { - fs.copyFileSync(app.getPath("userData") + "\\data.json", r.filePath); - global.mainWindow.webContents.send("hideBackupRestore"); - } - }); - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - }); - // 恢复数据 - ipcMain.on("restore", () => { - try { - dialog - .showOpenDialog(global.mainWindow, { - title: global.currentLanguage.restoreData, - filters: [{ name: "JSON", extensions: ["json"] }], - }) - .then((r) => { - if (!r.canceled && !util.arrayIsEmpty(r.filePaths)) { - if (!util.strIsEmpty(r.filePaths[0])) { - fs.copyFileSync(r.filePaths[0], app.getPath("userData") + "\\data.json"); - // 清空所有文件映射监听 - if (global.mapDirectoryWatcher != null) { - for (let value of global.mapDirectoryWatcher.values()) { - if (value != null && value.watch != null && value.watch) { - value.watch.close(); - } - } - global.mapDirectoryWatcher = new Map(); - } - // 初始化图标数据 - data.getList(); - data.splitData(); - // 重新获取数据 - global.mainWindow.webContents.send("getAllData"); - } - } - }); - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - }); - // 设置置顶 - ipcMain.on("setAlwaysTop", (event, args) => { - if (args) { - global.mainWindow.setAlwaysOnTop(true, "screen-saver"); - } else { - global.mainWindow.setAlwaysOnTop(false); - } - }); - // 反馈 - ipcMain.on("feedback", () => { - shell.openExternal("https://support.qq.com/product/487828"); - }); - // 锁定尺寸 - ipcMain.on("setResize", (event, args) => { - global.mainWindow.setResizable(args); - }); - // 设置透明度 - ipcMain.on("setOpacity", (event, args) => { - global.mainWindow.setOpacity(Number(args)); - }); - // 设置固定位置 - ipcMain.on("setFixedPosition", (event, args) => { - setFixedPosition(args[0], args[1]); - }); - // 永远居中 - ipcMain.on("setAlwaysCenter", (event, args) => { - if (args[0]) { - global.mainWindow.center(); - global.mainWindow.setMovable(false); - } else { - setFixedPosition(args[1], args[2]); - } - }); - // 打赏赞助 - ipcMain.on("rewardAndSponsorship", () => { - shell.openExternal("https://dawnlauncher.com/sponsor"); - }); - // 跳转搜索窗口高度 - ipcMain.on("setSearchWindowHeight", (event, args) => { - global.searchWindow.setBounds({ height: args }); - }); - // 隐藏搜索窗口 - ipcMain.on("hideSearchWindow", () => { - if (global.searchWindow.isVisible()) { - global.searchWindow.hide(); - } - }); - // 窗口设置透明 - ipcMain.on("setSearchWindowOpacity", (event, args) => { - global.searchWindow.setOpacity(args); - event.returnValue = null; - }); - // 获取release - ipcMain.on("getRelease", (event, args) => { - event.returnValue = os.release(); - }); - // 获取背景图 - ipcMain.on("getBackgroundImageBase64", (event, args) => { - let params = JSON.parse(args); - fs.readFile(app.getPath("userData") + "\\images\\" + params.backgroundImage, (err, data) => { - if (!err) { - try { - let buffer = Buffer.from(data); - let image = "data:" + mime.getType(params.backgroundImage) + ";base64," + buffer.toString("base64"); - if (params.page == "main") { - global.mainWindow.webContents.send("returnBackgroundImageBase64", image); - } else { - global.settingWindow.webContents.send("returnBackgroundImageBase64", image); - } - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - } - }); - }); - // 通知快速搜索窗口获取数据 - ipcMain.on("noticeSearchWindowGetData", () => { - if (global.searchWindow != null) { - global.searchWindow.webContents.send("searchWindowGetData"); - } - }); - // 获取软件目录 - ipcMain.on("getPath", (event, args) => { - event.returnValue = process.env.NODE_ENV !== "production" ? path.resolve(".") : path.dirname(process.execPath); - }); - // 获取图标 - ipcMain.on("getIconData", (event) => { - let iconData = data.getIconData(); - event.returnValue = iconData; - }); - // 更新图标 - ipcMain.on("updateIconData", (event, args) => { - // 参数 - let updateIconData = JSON.parse(args); - // 获取图标数据 - let iconData = data.store.get("iconData"); - if (iconData != null) { - // 删除 - if (!util.arrayIsEmpty(updateIconData.delete)) { - for (let del of updateIconData.delete) { - let index; - for (let i = 0; i < iconData.length; i++) { - if ( - iconData[i].classificationParentId == del.classificationParentId && - iconData[i].classificationChildId == del.classificationChildId && - iconData[i].itemId == del.itemId - ) { - index = i; - break; - } - } - if (index != null) { - iconData.splice(index, 1); - } - } - } - // 添加 - if (!util.arrayIsEmpty(updateIconData.add)) { - for (let add of updateIconData.add) { - let icon = { - classificationParentId: add.classificationParentId, - classificationChildId: add.classificationChildId, - itemId: add.itemId, - icon: add.icon, - }; - iconData.push(icon); - } - } - // 更新 - if (!util.arrayIsEmpty(updateIconData.update)) { - for (let update of updateIconData.update) { - let flag = false; - for (let icon of iconData) { - if ( - icon.classificationParentId == update.classificationParentId && - icon.classificationChildId == update.classificationChildId && - icon.itemId == update.itemId - ) { - icon.icon = update.icon; - flag = true; - break; - } - } - if (!flag) { - iconData.push(update); - } - } - } - // set - data.store.set("iconData", iconData); - } - // 更新搜索框图标数据 - if (global.searchWindow != null && !global.searchWindow.isDestroyed()) { - global.searchWindow.webContents.send("searchWindowUpdateIconData", args); - } - }); - // 通知搜索窗口重新获取图标数据 - ipcMain.on("searchWindowGetIconData", (event, args) => { - if (global.searchWindow != null && !global.searchWindow.isDestroyed()) { - global.searchWindow.webContents.send("getIconData"); - } - }); - // showMessageBoxSync - ipcMain.on("showMessageBoxSync", (event, args) => { - let index = dialog.showMessageBoxSync(global.mainWindow, { - title: "Dawn Launcher", - message: args, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }); - event.returnValue = index == 0 ? true : false; - }); - // 选择文件夹 - ipcMain.on("openDirectory", (event, args) => { - let params = JSON.parse(args); - let options = { - properties: ["openDirectory"], - }; - if (!util.strIsEmpty(params.defaultPath)) { - options.defaultPath = params.defaultPath; - } else { - options.defaultPath = app.getPath("desktop"); - } - dialog.showOpenDialog(params.window == "mainWindow" ? global.mainWindow : null, options).then((r) => { - if (r.filePaths.length > 0) { - event.returnValue = r.filePaths[0]; - } else { - event.returnValue = null; - } - }); - }); - // 选择文件 - ipcMain.on("openFile", (event, args) => { - let params = JSON.parse(args); - let options = {}; - if (!util.strIsEmpty(params.defaultPath)) { - options.defaultPath = params.defaultPath; - } else { - options.defaultPath = app.getPath("desktop"); - } - dialog.showOpenDialog(params.window == "mainWindow" ? global.mainWindow : null, options).then((r) => { - if (r.filePaths.length > 0) { - let filePath = r.filePaths[0]; - if (params.target) { - if (mime.getType(filePath) == "application/x-ms-shortcut") { - // 快捷方式 - // 获取真实文件路径和参数 - let shortcutDetail = global.api.GetShortcutFile(filePath); - if (!util.strIsEmpty(shortcutDetail.target)) { - // 路径 - filePath = shortcutDetail.target; - } - } - } - event.returnValue = filePath; - } else { - event.returnValue = null; - } - }); - }); -} diff --git a/src/main/item/index.js b/src/main/item/index.js deleted file mode 100644 index 009f9d9..0000000 --- a/src/main/item/index.js +++ /dev/null @@ -1,790 +0,0 @@ -import { shell, dialog, app } from "electron"; -import path from "path"; -import fs from "fs"; -import util from "../util"; -import { v4 } from "uuid"; -import Jimp from "jimp"; -import ClassificationJS from "../classification/index.js"; -import data from "../data"; -const { exec } = require("child_process"); - -/** - * 校验无效项目 - * @param itemList - */ -function checkInvalidItemList(itemList) { - let list = []; - if (!util.arrayIsEmpty(itemList)) { - for (let item of itemList) { - // 只校验文件和文件夹 - if (item.type == 0 || item.type == 1) { - // 获取绝对路径 - item.path = getAbsolutePath(item.path); - try { - fs.statSync(item.path); - } catch (e) { - if (item.classificationParentId != null) { - list.push(item.classificationParentId + "-" + item.classificationId + "-" + item.id); - } else { - list.push(item.classificationId + "-" + item.id); - } - } - } - } - } - return list; -} - -/** - * 校验无效项目 - * @returns {*[]} - */ -function checkInvalidItem() { - let list = []; - for (let c of global.list) { - if (!util.arrayIsEmpty(c.childList)) { - for (let cc of c.childList) { - if (util.strIsEmpty(cc.mapDirectory)) { - list.push(...checkInvalidItemList(cc.itemList)); - } - } - } else { - if (util.strIsEmpty(c.mapDirectory)) { - list.push(...checkInvalidItemList(c.itemList)); - } - } - } - return list; -} - -/** - * 解析环境变量 - * @param p - */ -function parseEnvPath(p) { - // 尝试解析环境变量 - let parsedPath = path.parse(p); - let isBase = false; - let dirArr; - if (util.strIsEmpty(parsedPath.dir)) { - dirArr = parsedPath.base.split("\\"); - isBase = true; - } else { - dirArr = parsedPath.dir.split("\\"); - } - let newPathArr = []; - const pattern = /^%.*%$/; - for (let string of dirArr) { - if (pattern.test(string)) { - let nString = string.substring(1, string.length - 1); - if (!util.strIsEmpty(process.env[nString])) { - newPathArr.push(process.env[nString]); - } else { - newPathArr.push(string); - } - } else { - newPathArr.push(string); - } - } - if (!isBase) { - newPathArr.push(parsedPath.base); - } - return newPathArr.join("\\"); -} - -/** - * 是否是绝对路径 - * @param p - */ -function isAbsolutePath(p) { - const regex = /^[a-zA-Z]:\\/; - return regex.test(p); -} - -/** - * 获取绝对路径 - * @param path - */ -function getAbsolutePath(p) { - if (!isAbsolutePath(p)) { - // 尝试解析环境变量 - let newPath = parseEnvPath(p); - // 判断解析之后的路径是否是绝对路径 - if (isAbsolutePath(newPath)) { - return newPath; - } else { - return path.resolve(process.env.NODE_ENV !== "production" ? path.resolve(".") : path.dirname(process.execPath), p); - } - } - return p; -} - -/** - * 运行项目 - * @param item - * @param location 是否打开文件所在的位置 - * @param openWith 打开方式 - */ -function itemRun(item, location, openWith) { - // 系统 - if (item.type == 3) { - if (item.shell.indexOf("shell:") >= 0) { - shell.openExternal(item.shell); - } else { - if (item.shell == "cmd") { - if (item.admin) { - exec('powershell -Command "Start-Process cmd -Verb RunAs"', (error, stdout, stderr) => {}); - } else { - exec("start cmd.exe", (error, stdout, stderr) => {}); - } - } else if (item.shell == "turnOffMonitor") { - global.api.TurnOffMonitor(); - } else { - exec(item.shell, (error, stdout, stderr) => {}); - } - } - return; - } else if (item.type == 5) { - exec("start " + item.shell, (error, stdout, stderr) => {}); - return; - } - // 如果是类型是0或者1并且是相对路径的话,恢复为绝对路径 - if (item.type == 0 || item.type == 1) { - // 获取路径 - item.path = getAbsolutePath(item.path); - } - let t = item.path; - let params = !util.strIsEmpty(item.params) ? item.params.trim() : ""; - if (openWith != null && openWith && item.type == 0) { - exec("RUNDLL32.EXE SHELL32.DLL,OpenAs_RunDLL " + t + "", (error, stdout, stderr) => {}); - } else { - let type = "open"; - if (item.type == 0) { - if (location) { - // 如果是打开文件所在位置 - exec('start %windir%\\explorer.exe /select, "' + item.path + '"', (error, stdout, stderr) => {}); - return; - } else { - // 以管理员身份运行 - if (item.admin && (item.extension == ".exe" || item.extension == ".bat")) { - type = "runas"; - } - } - } else if (item.type == 2) { - // 网址 - t = item.url; - } - if (item.type == 0 || item.type == 1) { - // 判断文件或文件夹是否存在 - try { - fs.accessSync(t); - global.api.RunItem(type, t, params, item.type == 0 && !util.strIsEmpty(item.startLocation) ? item.startLocation : path.dirname(item.path)); - } catch (e) { - let message; - if (item.type == 0 && !location) { - message = global.currentLanguage.notFoundFileMessage; - } else { - message = global.currentLanguage.notFoundFolderMessage; - } - message += '"' + t + '"。'; - dialog.showMessageBox(global.mainWindow, { - title: "Dawn Launcher", - message: message, - buttons: [global.currentLanguage.ok], - type: "error", - noLink: true, - }); - } - } else { - global.api.RunItem(type, t, params, null); - } - } -} - -/** - * 返回排序菜单 - * @param classificationParentId - * @param classificationChildId - * @param haveClassificationChild - * @param sort - */ -function itemSortMenu(classificationParentId, classificationChildId, haveClassificationChild, sort) { - let submenu = [ - { - label: global.currentLanguage.default, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - sort: "default", - }; - global.mainWindow.webContents.send("itemSort", JSON.stringify(params)); - }, - icon: (sort == null || sort == "default") && !haveClassificationChild ? util.getDot() : null, - }, - { - label: global.currentLanguage.byInitial, - type: "normal", - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - sort: "initial", - }; - global.mainWindow.webContents.send("itemSort", JSON.stringify(params)); - }, - icon: sort != null && sort == "initial" ? util.getDot() : null, - }, - ]; - if (global.setting.item.openNumber) { - submenu.push({ - label: global.currentLanguage.byOpenNumber, - type: "normal", - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - sort: "openNumber", - }; - global.mainWindow.webContents.send("itemSort", JSON.stringify(params)); - }, - icon: sort != null && sort == "openNumber" ? util.getDot() : null, - }); - } - return { - label: global.currentLanguage.sort, - type: "submenu", - submenu: submenu, - }; -} - -/** - * 返回布局和图标大小 - * @param classificationParentId - * @param classificationChildId - * @param haveClassificationChild - * @param layout - * @param iconSize - */ -function itemLayoutIconSize(classificationParentId, classificationChildId, haveClassificationChild, layout, iconSize) { - let menuList = [ - { - label: global.currentLanguage.layout, - type: "submenu", - submenu: [ - { - label: global.currentLanguage.default, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: "default", - }; - global.mainWindow.webContents.send("itemTile", JSON.stringify(params)); - }, - icon: (layout == null || layout == "default") && !haveClassificationChild ? util.getDot() : null, - }, - { - label: global.currentLanguage.tile, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: "tile", - }; - global.mainWindow.webContents.send("itemTile", JSON.stringify(params)); - }, - icon: layout != null && layout == "tile" ? util.getDot() : null, - }, - { - label: global.currentLanguage.list, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: "list", - }; - global.mainWindow.webContents.send("itemTile", JSON.stringify(params)); - }, - icon: layout != null && layout == "list" ? util.getDot() : null, - }, - ], - }, - ]; - menuList.push({ - label: global.currentLanguage.iconSize, - type: "submenu", - submenu: [ - { - label: global.currentLanguage.default, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: null, - }; - global.mainWindow.webContents.send("itemIconSize", JSON.stringify(params)); - }, - icon: iconSize == null && !haveClassificationChild ? util.getDot() : null, - }, - { - label: global.currentLanguage.extraLarge, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: 48, - }; - global.mainWindow.webContents.send("itemIconSize", JSON.stringify(params)); - }, - icon: iconSize != null && iconSize == 48 ? util.getDot() : null, - }, - { - label: global.currentLanguage.large, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: 40, - }; - global.mainWindow.webContents.send("itemIconSize", JSON.stringify(params)); - }, - icon: iconSize != null && iconSize == 40 ? util.getDot() : null, - }, - { - label: global.currentLanguage.medium, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: 32, - }; - global.mainWindow.webContents.send("itemIconSize", JSON.stringify(params)); - }, - icon: iconSize != null && iconSize == 32 ? util.getDot() : null, - }, - { - label: global.currentLanguage.small, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: 24, - }; - global.mainWindow.webContents.send("itemIconSize", JSON.stringify(params)); - }, - icon: iconSize != null && iconSize == 24 ? util.getDot() : null, - }, - ], - }); - return menuList; -} - -/** - * 返回显示菜单 - * @param classificationParentId - * @param classificationChildId - * @param haveClassificationChild - * @param showOnly - */ -function itemShowOnly(classificationParentId, classificationChildId, haveClassificationChild, showOnly) { - let submenu = [ - { - label: global.currentLanguage.default, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - showOnly: "default", - }; - global.mainWindow.webContents.send("itemShowOnly", JSON.stringify(params)); - }, - icon: (showOnly == null || showOnly == "default") && !haveClassificationChild ? util.getDot() : null, - }, - { - label: global.currentLanguage.showOnlyFiles, - type: "normal", - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - showOnly: "file", - }; - global.mainWindow.webContents.send("itemShowOnly", JSON.stringify(params)); - }, - icon: showOnly != null && showOnly == "file" ? util.getDot() : null, - }, - { - label: global.currentLanguage.showOnlyFolders, - type: "normal", - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - showOnly: "folder", - }; - global.mainWindow.webContents.send("itemShowOnly", JSON.stringify(params)); - }, - icon: showOnly != null && showOnly == "folder" ? util.getDot() : null, - }, - ]; - return { - label: global.currentLanguage.show, - type: "submenu", - submenu: submenu, - }; -} - -/** - * 返回列数菜单 - * @param classificationParentId - * @param classificationChildId - * @param haveClassificationChild - * @param columnNumber - */ -function itemColumnNumber(classificationParentId, classificationChildId, haveClassificationChild, columnNumber) { - let submenu = [ - { - label: global.currentLanguage.default, - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - columnNumber: 0, - }; - global.mainWindow.webContents.send("itemColumnNumber", JSON.stringify(params)); - }, - icon: (columnNumber == null || columnNumber == 0) && !haveClassificationChild ? util.getDot() : null, - }, - ]; - for (let i = 0; i < 20; i++) { - submenu.push({ - label: (i + 1).toString(), - click: () => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - columnNumber: i + 1, - }; - global.mainWindow.webContents.send("itemColumnNumber", JSON.stringify(params)); - }, - icon: columnNumber != null && columnNumber == i + 1 ? util.getDot() : null, - }); - } - return { - label: global.currentLanguage.numberOfColumns, - type: "submenu", - submenu: submenu, - }; -} - -/** - * 获取文件图标 - * @param target - * @param message - */ -async function getFileIcon(target, message) { - // 获取绝对路径 - target = getAbsolutePath(target); - let size = 256; - try { - // 先获取一下文件判断是否存在,不存在抛出异常 - let stats = fs.statSync(target); - // 图标临时地址 - let tempPath = app.getPath("temp") + "\\" + v4() + ".png"; - // 获取图标 - let result = global.api.GetFileIcon(target, tempPath, size); - // 1为成功 - if (result == 1) { - // 读取图标文件 - let buffer = fs.readFileSync(tempPath); - // 如果透明区域占比大于80代表这个图标没有超大图标,那么就获取48*48图标 - let tempResult = await Jimp.read(tempPath); - let zero = 0; - let color = 0; - for (const { x, y, image } of tempResult.scanIterator(0, 0, tempResult.bitmap.width, tempResult.bitmap.height)) { - if (image.getPixelColor(x, y) == 0) { - zero++; - } else { - color++; - } - } - // 计算占比 - let proportion = Math.round((zero / (zero + color)) * 100); - // 删除临时文件 - fs.unlink(tempPath, (err) => {}); - // 透明区域大于80,获取48*48图标 - if (proportion >= 80) { - // 图标临时地址 - tempPath = app.getPath("temp") + "\\" + v4() + ".png"; - // 获取48*48图标 - result = global.api.GetFileIcon(target, tempPath, 48); - // 1成功 - if (result == 1) { - // 读取图标文件 - buffer = fs.readFileSync(tempPath); - // 删除文件 - fs.unlink(tempPath, (err) => {}); - } - } - // 图标 - let base64 = "data:image/png;base64," + buffer.toString("base64"); - // 返回base64 - return base64; - } - } catch (e) { - if (message) { - dialog.showMessageBox(global.mainWindow, { - title: "Dawn Launcher", - message: global.currentLanguage.targetNotExist + '"' + target + '"。', - buttons: [global.currentLanguage.ok], - type: "error", - noLink: true, - cancelId: 1, - }); - } - } - return null; -} - -/** - * 新建文件夹监听 - */ -function addMapDirectoryWatcher(classificationParentId, classificationChildId, mapDirectory) { - // key - let key = classificationParentId + (classificationChildId != null ? "-" + classificationChildId : ""); - // 先删除原有监听 - deleteMapDirectoryWatcher(classificationParentId, classificationChildId); - // 新建监听 - let data = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - mapDirectory: mapDirectory, - }; - let timer; - let watch = fs.watch(mapDirectory, (event, filename) => { - if (timer) { - clearTimeout(timer); - timer = null; - } - // 启动定时器,在指定的时间间隔后发送合并后的通知 - timer = setTimeout(() => { - readMapDirectory(classificationParentId, classificationChildId, mapDirectory, false, true, true); - clearTimeout(timer); - timer = null; - }, 1000); - }); - watch.on("error", (error) => { - watch.close(); - global.mapDirectoryWatcher.delete(key); - }); - // 保存 - data.watch = watch; - global.mapDirectoryWatcher.set(key, data); -} - -/** - * 删除文件夹监听 - */ -function deleteMapDirectoryWatcher(classificationParentId, classificationChildId) { - // 判断是否存在 - let key = classificationParentId + (classificationChildId != null ? "-" + classificationChildId : ""); - let watcherData = global.mapDirectoryWatcher.get(key); - if (watcherData != null) { - // 存在 - if (watcherData.watch != null && watcherData.watch) { - watcherData.watch.close(); - watcherData.watch = null; - } - global.mapDirectoryWatcher.delete(key); - } -} - -/** - * 读取映射文件夹内容 - * @param classificationParentId - * @param classificationChildId - * @param mapDirectory - * @param listener - * @param old - * @param notice - */ -async function readMapDirectory(classificationParentId, classificationChildId, mapDirectory, listener, old, notice) { - let itemList = []; - try { - // 判断是否含有环境变量 - mapDirectory = parseEnvPath(mapDirectory); - // 获取图标数据 - let iconData = data.store.get("iconData"); - let iconDataMap = new Map(); - // 转为Map - if (!util.arrayIsEmpty(iconData)) { - for (let icon of iconData) { - iconDataMap.set(util.getKey(icon.classificationParentId, icon.classificationChildId, icon.itemId), icon); - } - } - // 文件类型 - let stats = fs.statSync(mapDirectory); - // 必须是文件夹 - if (stats.isDirectory()) { - // 获取旧列表 - let oldItemList = []; - let hiddenItem; - // 分类 - let classification = ClassificationJS.getClassificationById(classificationParentId, classificationChildId); - if (classification != null) { - if (old != null && old) { - oldItemList = classification.itemList; - } - hiddenItem = classification.hiddenItem; - } - // 转为数组 - let hiddenItemArr = []; - if (!util.strIsEmpty(hiddenItem)) { - hiddenItemArr = hiddenItem.split(","); - } - // 读取文件夹下面的所有文件 - let pathList = fs.readdirSync(mapDirectory); - let i = 1; - for (let p of pathList) { - try { - // 判断是否隐藏 - let flag = false; - for (let item of hiddenItemArr) { - if (item != null && p == item.trim()) { - flag = true; - break; - } - } - if (flag) { - continue; - } - // 组合路径 - let np = path.join(mapDirectory, p); - // 获取类型 0:文件 1:文件夹 - let type = fs.statSync(np).isDirectory() ? 1 : 0; - // 如果旧数据有的话,获取旧数据 - let icon; - let openNumber; - let lastOpen; - let quickSearchOpenNumber; - let quickSearchLastOpen; - if (!util.arrayIsEmpty(oldItemList)) { - for (let oldItem of oldItemList) { - if ( - (type == 0 && oldItem.name == util.removeSuffix(p) && oldItem.path == np && oldItem.type == type) || - (type == 1 && oldItem.name == p && oldItem.path == np && oldItem.type == type) - ) { - // 通过旧数据获取图标 - let oldIcon = iconDataMap.get(util.getKey(classificationParentId, classificationChildId, oldItem.id)); - if (oldIcon != null) { - icon = oldIcon.icon; - } - openNumber = oldItem.openNumber; - lastOpen = oldItem.lastOpen; - quickSearchOpenNumber = oldItem.quickSearchOpenNumber; - quickSearchLastOpen = oldItem.quickSearchLastOpen; - break; - } - } - } - let item = { - // id - id: i++, - // 路径 - path: np, - // 名称 - name: type == 1 ? p : util.removeSuffix(p), - // 全称 - fullName: p, - // 图标 - icon: icon != null ? icon : await getFileIcon(np, false), - // 类型 0:文件 1:文件夹 - type: type, - // 打开次数 - openNumber: openNumber, - // 最近打开 - lastOpen: lastOpen, - // 快速搜索 打开次数 - quickSearchOpenNumber: quickSearchOpenNumber, - // 快速搜索 最近打开 - quickSearchLastOpen: quickSearchLastOpen, - }; - itemList.push(item); - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - } - if (listener != null && listener) { - // 新建监听 - addMapDirectoryWatcher(classificationParentId, classificationChildId, mapDirectory); - } - if (notice) { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - itemList: itemList, - clear: true, - }; - // 添加项目 - global.mainWindow.webContents.send("itemAdd", JSON.stringify(params)); - } - } - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - return itemList; -} - -/** - * 初始化映射文件夹 - */ -async function initMapDirectory() { - let list = []; - for (let c of global.list) { - if (util.arrayIsEmpty(c.childList)) { - // 没有子级 - if (!util.strIsEmpty(c.mapDirectory)) { - let { classificationParentId, classificationChildId } = ClassificationJS.convertClassificationId(c.id, c.parentId); - let itemList = await readMapDirectory(classificationParentId, classificationChildId, c.mapDirectory, true, true, false); - list.push({ - classificationParentId: classificationParentId, - itemList: itemList, - }); - } - } else { - for (let cc of c.childList) { - if (!util.strIsEmpty(cc.mapDirectory)) { - let { classificationParentId, classificationChildId } = ClassificationJS.convertClassificationId(cc.id, cc.parentId); - let itemList = await readMapDirectory(classificationParentId, classificationChildId, cc.mapDirectory, true, true, false); - list.push({ - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - itemList: itemList, - }); - } - } - } - } - return list; -} - -export default { - checkInvalidItem, - isAbsolutePath, - getAbsolutePath, - itemRun, - itemSortMenu, - itemLayoutIconSize, - itemShowOnly, - itemColumnNumber, - getFileIcon, - addMapDirectoryWatcher, - readMapDirectory, - deleteMapDirectoryWatcher, - initMapDirectory, -}; diff --git a/src/main/item/ipcEvent.js b/src/main/item/ipcEvent.js deleted file mode 100644 index ce479ee..0000000 --- a/src/main/item/ipcEvent.js +++ /dev/null @@ -1,1897 +0,0 @@ -import { ipcMain, dialog, Menu, clipboard, shell } from "electron"; -import * as cheerio from "cheerio"; -import url from "url"; -import fs from "fs"; -import path from "path"; -import mime from "mime"; -import index from "./index"; -import util from "../util"; -import xml2js from "xml2js"; -import os from "os"; -import request from "request"; -import URI from "urijs"; -import retry from "retry"; -import cacheData from "../cache/data"; -import ItemJS from "@/main/item/index"; -import ClassificationJS from "@/main/classification/index"; -const { execSync } = require("child_process"); - -/** - * 随机user-agent - * @returns {string} - */ -function getRandomUserAgent() { - const userAgents = [ - "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36", - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36", - "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:89.0) Gecko/20100101 Firefox/89.0", - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Firefox/89.0", - "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Safari/537.36", - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Safari/537.36", - "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36 Edg/91.0.864.59", - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36 Edg/91.0.864.59", - "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:89.0) Gecko/20100101 Firefox/89.0", - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Firefox/89.0", - "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36 OPR/76.0.4017.123", - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36 OPR/76.0.4017.123", - "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:89.0) Gecko/20100101 Firefox/89.0", - "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Firefox/89.0", - ]; - const randomIndex = Math.floor(Math.random() * userAgents.length); - return userAgents[randomIndex]; -} - -/** - * 发送网址信息 - * @param item - */ -function sendUrlInfo(item) { - global.mainWindow.webContents.send("getUrlInfo", JSON.stringify(item)); -} - -/** - * 获取代理 - */ -function getProxy() { - if (global.setting.network.useProxy && !util.strIsEmpty(global.setting.network.proxy.address)) { - let uri = new URI(global.setting.network.proxy.address); - if (!util.strIsEmpty(uri.protocol())) { - let address = uri.protocol().toLowerCase() + "://"; - if (!util.strIsEmpty(global.setting.network.proxy.username) && !util.strIsEmpty(global.setting.network.proxy.password)) { - address += global.setting.network.proxy.username + ":" + global.setting.network.proxy.password + "@"; - } - address += uri.hostname() + ":" + uri.port(); - return address; - } - } - return null; -} - -/** - * 获取网址信息 - * @param u 网址 - * @param r 是否支持跳转获取 - */ -function getUrlInfo(u, r) { - let result = { - status: false, - message: null, - name: null, - icon: null, - }; - // 重试 - const operation = retry.operation({ - retries: 5, // 最多重试 5 次 - factor: 1, // 每次重试之间的时间间隔加倍 - minTimeout: 1000, // 第一次重试之前等待的时间 - maxTimeout: 5000, // 最长等待时间 - }); - try { - // 发起请求 - operation.attempt((currentAttempt) => { - request( - { - uri: u, - proxy: getProxy(), - timeout: 5000, - headers: { - "User-Agent": getRandomUserAgent(), - }, - }, - function (error, response, body) { - if (operation.retry(error)) { - return; - } - if (!error && response.statusCode >= 200 && response.statusCode <= 299) { - // 解析HTML - let $ = cheerio.load(body); - // 是否有跳转标签 - let refresh = $("meta[http-equiv='refresh']"); - if (refresh != null && !util.strIsEmpty(refresh.attr("content")) && r) { - // 如果有跳转标签的话,就请求新网址并获取网址信息 - let content = refresh.attr("content"); - let contentSplit = content.split(";"); - let urlProperty = contentSplit[contentSplit.length - 1]; - let urlPropertySplit = urlProperty.split("="); - let newUrl = urlPropertySplit[urlPropertySplit.length - 1]; - // 重新获取新网址信息 - getUrlInfo(newUrl, false); - } else { - // 解析HTML并返回信息 - analysisHTML(u, body); - } - } else { - sendUrlInfo(result); - } - } - ); - }); - } catch (e) { - sendUrlInfo(result); - } -} - -/** - * 解析HTML并返回信息 - * @param u url - * @param data HTML - */ -function analysisHTML(u, data) { - let result = { - status: false, - message: null, - name: null, - icon: null, - }; - try { - // 解析HTML - let $ = cheerio.load(data); - // 获取标题 - result.name = $("head").find("title").text(); - // 获取图标URL - let iconUrl; - let icon = $("link[rel='icon']"); - if (icon != null && !util.strIsEmpty(icon.attr("href"))) { - iconUrl = icon.attr("href"); - } else { - let shortcutIcon = $("link[rel='shortcut icon']"); - if (shortcutIcon != null && !util.strIsEmpty(shortcutIcon.attr("href"))) { - iconUrl = shortcutIcon.attr("href"); - } else { - iconUrl = "/favicon.ico"; - } - } - if (!util.strIsEmpty(iconUrl)) { - // 解析URL - let urlParse = url.parse(u); - // 新图标URL - let newIconUrl = ""; - // 去掉类似//www.baidu.com/favicon.ico这样域名的”//“字符 - if (iconUrl.indexOf("//") == 0) { - iconUrl = "http:" + iconUrl; - } - // 如果url包含https://或者http://就是正常的链接 - if (iconUrl.indexOf("http://") >= 0 || iconUrl.indexOf("https://") >= 0) { - newIconUrl = iconUrl; - } else { - // 无协议头,使用当前网址域名 - newIconUrl = url.resolve("http://" + urlParse.host + (urlParse.port != null ? ":" + urlParse.port : ""), iconUrl); - } - // 重试 - const operation = retry.operation({ - retries: 5, // 最多重试 5 次 - factor: 1, // 每次重试之间的时间间隔加倍 - minTimeout: 1000, // 第一次重试之前等待的时间 - maxTimeout: 5000, // 最长等待时间 - }); - operation.attempt((currentAttempt) => { - // 下载图标 - request( - { - uri: newIconUrl, - proxy: getProxy(), - encoding: null, - timeout: 5000, - headers: { - "User-Agent": getRandomUserAgent(), - }, - }, - function (error, response, body) { - if (operation.retry(error)) { - return; - } - if (!error && response.statusCode >= 200 && response.statusCode <= 299) { - let buffer = Buffer.from(body); - result.icon = "data:" + mime.getType(newIconUrl) + ";base64," + buffer.toString("base64"); - result.status = true; - sendUrlInfo(result); - } else { - sendUrlInfo(result); - } - } - ); - }); - } else { - sendUrlInfo(result); - } - } catch (e) { - sendUrlInfo(result); - } -} - -/** - * 获取文件图标 - * @param target - * @param message - */ -async function getFileIcon(target, message) { - return await index.getFileIcon(target, message); -} - -/** - * 转换为菜单 - * - * @param classificationParentId - * @param classificationChildId - * @param id - * @param list - * @param del - */ -function convertMenu(classificationParentId, classificationChildId, id, list, del) { - let menuList = []; - for (let i = 0; i < list.length; i++) { - let classification = list[i]; - let menu = { - label: classification.name, - }; - let submenu = []; - if (!util.arrayIsEmpty(classification.childList)) { - for (let j = 0; j < classification.childList.length; j++) { - if (util.strIsEmpty(classification.childList[j].mapDirectory) && (classification.childList[j].type == null || classification.childList[j].type != 1)) { - submenu.push({ - label: classification.childList[j].name, - click: () => { - let params = { - from: { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - id: id, - }, - to: { - classificationParentId: classification.id, - classificationChildId: classification.childList[j].id, - }, - del: del, - }; - global.mainWindow.webContents.send("moveItem", JSON.stringify(params)); - }, - }); - } - } - } - if (!util.arrayIsEmpty(submenu)) { - menu.submenu = submenu; - menu.type = "submenu"; - } else { - menu.type = "normal"; - menu.click = () => { - let params = { - from: { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - id: id, - }, - to: { - classificationParentId: classification.id, - classificationChildId: null, - }, - del: del, - }; - global.mainWindow.webContents.send("moveItem", JSON.stringify(params)); - }; - } - if (util.strIsEmpty(classification.mapDirectory) && (classification.type == null || classification.type != 1)) { - menuList.push(menu); - } - } - return menuList; -} - -/** - * 批量操作转换为菜单 - * - * @param list - * @param del - */ -function batchOperationConvertMenu(list, del) { - let menuList = []; - for (let i = 0; i < list.length; i++) { - let classification = list[i]; - let menu = { - label: classification.name, - }; - let submenu = []; - if (!util.arrayIsEmpty(classification.childList)) { - for (let j = 0; j < classification.childList.length; j++) { - if (util.strIsEmpty(classification.childList[j].mapDirectory) && (classification.childList[j].type == null || classification.childList[j].type != 1)) { - submenu.push({ - label: classification.childList[j].name, - click: () => { - dialog - .showMessageBox(global.mainWindow, { - message: del ? global.currentLanguage.batchMoveItemMessage : global.currentLanguage.batchCopyItemMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - let params = { - to: { - classificationParentId: classification.id, - classificationChildId: classification.childList[j].id, - }, - del: del, - }; - global.mainWindow.webContents.send("batchMoveItem", JSON.stringify(params)); - } - }); - }, - }); - } - } - } - if (!util.arrayIsEmpty(submenu)) { - menu.submenu = submenu; - menu.type = "submenu"; - } else { - menu.type = "normal"; - menu.click = () => { - dialog - .showMessageBox(global.mainWindow, { - message: del ? global.currentLanguage.batchMoveItemMessage : global.currentLanguage.batchCopyItemMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - let params = { - to: { - classificationParentId: classification.id, - classificationChildId: null, - }, - del: del, - }; - global.mainWindow.webContents.send("batchMoveItem", JSON.stringify(params)); - } - }); - }; - } - if (util.strIsEmpty(classification.mapDirectory) && (classification.type == null || classification.type != 1)) { - menuList.push(menu); - } - } - return menuList; -} - -/** - * 读取路径下的文件 - * @param path - * @returns {*[]} - */ -function getPathProgramList(path) { - let resultList = []; - try { - // 读取开始菜单下所有内容 - let pathList = fs.readdirSync(path); - // 循环判断文件类型 - for (let p of pathList) { - // 完整路径 - let fullPath = path + "\\" + p; - // 判断文件类型 - let stats; - try { - // 文件类型 - stats = fs.statSync(fullPath); - // 如果是文件夹继续向下读取,如果是文件则添加到返回列表 - if (stats.isDirectory()) { - // 文件夹 - resultList.push(...getPathProgramList(fullPath)); - } else { - // 文件 - resultList.push(fullPath); - } - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - } - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - return resultList; -} - -/** - * 获取最大图标尺寸 - */ -function getMaxIconSize(list, name, type) { - // 获取最大图标尺寸 - let max = null; - for (let targetSize of list) { - let s = targetSize.replace(name + "." + type + "-", "").split("_"); - let size = Number(s[0].replace(".png", "")); - if (max == null) { - max = size; - } else { - if (size > max) { - max = size; - } - } - } - return max; -} - -/** - * 接续XML同步 - * @param xml - * @returns {Promise} - */ -async function xml2jsSync(xml) { - let parser = new xml2js.Parser(); - return new Promise((resolve, reject) => { - parser.parseString(xml, function (err, json) { - if (err) reject(err); - else resolve(json); - }); - }); -} - -/** - * 获取AppxPropertiesLogo - * @param installLocation - * @param result - * @returns {string|null} - */ -function getPropertiesIcon(installLocation, result) { - if (result.Package.Properties != null) { - if (result.Package.Properties[0].Logo != null) { - let logo = result.Package.Properties[0].Logo[0]; - return installLocation + "\\" + logo; - } - } - return null; -} - -/** - * 获取Appx信息 - */ -async function getAppxInfo(installLocation) { - let appxInfo = {}; - let buffer, result; - try { - buffer = fs.readFileSync(installLocation + "\\AppxManifest.xml"); - result = await xml2jsSync(buffer); - // 备用,如果没有名称的话 - let executable = null; - // targetsize图标 - let targetSizeIcon = null; - let targetSizeIconMax = null; - // scale图标 - let scaleIcon = null; - let scaleIconMax = null; - // 图标 APPID - if (result.Package.Applications != null && result.Package.Applications[0] != null) { - if (result.Package.Applications[0].Application[0] != null) { - // APPID - appxInfo.appId = result.Package.Applications[0].Application[0].$.Id; - // Executable - executable = result.Package.Applications[0].Application[0].$.Executable; - // 图标 - if (result.Package.Applications[0].Application[0]["uap:VisualElements"] != null) { - // logo地址 - let logo = result.Package.Applications[0].Application[0]["uap:VisualElements"][0].$.Square44x44Logo; - // 解析路径 - let parsedPath = path.parse(logo); - // 获取文件夹下所有文件 - let fileNameList = fs.readdirSync(installLocation + "\\" + parsedPath.dir); - // 筛选出和包含logo名称的文件名 - let filterList = fileNameList.filter((f) => f.indexOf(parsedPath.name) >= 0); - if (filterList.length > 1) { - // 获取targetsize图片 - let targetSizeList = filterList.filter((f) => f.indexOf(parsedPath.name + ".targetsize") >= 0); - if (targetSizeList.length > 0) { - // 获取最大图标尺寸 - let max = getMaxIconSize(targetSizeList, parsedPath.name, "targetsize"); - if (max != null) { - // 记录max - targetSizeIconMax = max; - // 先获取最终图标 - let defaultList = targetSizeList.filter( - (f) => f == parsedPath.name + ".targetsize-" + max + "_altform-unplated_devicefamily-colorfulunplated.png" - ); - targetSizeIcon = - defaultList.length > 0 - ? installLocation + - "\\" + - parsedPath.dir + - "\\" + - parsedPath.name + - ".targetsize-" + - max + - "_altform-unplated_devicefamily-colorfulunplated.png" - : null; - if (targetSizeIcon == null) { - // 获取 名称.targetsize-{max}_altform-unplated.png - let defaultUnplatedList = targetSizeList.filter((f) => f == parsedPath.name + ".targetsize-" + max + "_altform-unplated.png"); - if (defaultUnplatedList.length > 0) { - targetSizeIcon = installLocation + "\\" + parsedPath.dir + "\\" + parsedPath.name + ".targetsize-" + max + "_altform-unplated.png"; - } else { - // 获取 名称.targetsize-{max}_altform.png - let defaultAltFormList = targetSizeList.filter((f) => f == parsedPath.name + ".targetsize-" + max + "_altform.png"); - if (defaultAltFormList.length > 0) { - targetSizeIcon = installLocation + "\\" + parsedPath.dir + "\\" + parsedPath.name + ".targetsize-" + max + "_altform.png"; - } else { - // 获取 名称.targetsize-{max}.png - let defaultTargetSizeList = targetSizeList.filter((f) => f == parsedPath.name + ".targetsize-" + max + ".png"); - if (defaultTargetSizeList.length > 0) { - targetSizeIcon = installLocation + "\\" + parsedPath.dir + "\\" + defaultTargetSizeList[0]; - } - } - } - } - } - } - // 获取scale图片 - let scaleList = filterList.filter((f) => f.indexOf(parsedPath.name + ".scale") >= 0); - if (scaleList.length > 0) { - // 获取最大图标尺寸 - let max = getMaxIconSize(scaleList, parsedPath.name, "scale"); - if (max != null) { - // 记录max - scaleIconMax = max; - // 获取 名称.scale-{max}.png - let defaultList = scaleList.filter((f) => f == parsedPath.name + ".scale-" + max + ".png"); - if (defaultList.length > 0) { - scaleIcon = installLocation + "\\" + parsedPath.dir + "\\" + defaultList[0]; - } - } - } else { - scaleList = filterList.filter((f) => f.indexOf(parsedPath.name + ".Theme-Dark_Scale") >= 0); - if (scaleList.length > 0) { - let max = getMaxIconSize(scaleList, parsedPath.name, "Theme-Dark_Scale"); - if (max != null) { - // 记录max - scaleIconMax = max; - // 获取 名称.Theme-Dark_Scale{max}.png - let defaultList = scaleList.filter((f) => f == parsedPath.name + ".Theme-Dark_Scale-" + max + ".png"); - if (defaultList.length > 0) { - scaleIcon = installLocation + "\\" + parsedPath.dir + "\\" + defaultList[0]; - } - } - } - } - } else { - if (filterList.length == 1) { - // 只有一张图片 - appxInfo.icon = installLocation + "\\" + parsedPath.dir + "\\" + filterList[0]; - } - } - } - } - } - if (appxInfo.icon == null) { - // 判断图标大小 - if (targetSizeIcon != null && scaleIcon == null) { - appxInfo.icon = targetSizeIcon; - } else if (targetSizeIcon == null && scaleIcon != null) { - appxInfo.icon = scaleIcon; - } else if (targetSizeIcon != null && scaleIcon != null) { - if (targetSizeIconMax == 256 || targetSizeIconMax > scaleIconMax) { - appxInfo.icon = targetSizeIcon; - } else if (targetSizeIconMax < scaleIconMax) { - appxInfo.icon = scaleIcon; - } else { - appxInfo.icon = targetSizeIcon; - } - } else if (targetSizeIcon == null && scaleIcon == null) { - let propertiesIcon = getPropertiesIcon(installLocation, result); - if (propertiesIcon != null) { - appxInfo.icon = propertiesIcon; - } - } - } - // 名称 - if (result.Package.Properties != null) { - if (result.Package.Properties[0].DisplayName != null) { - appxInfo.name = result.Package.Properties[0].DisplayName[0]; - } - } - if (appxInfo.name == null || (appxInfo.name != null && appxInfo.name.indexOf("ms-resource:") >= 0)) { - if (executable != null && executable.indexOf("ms-resource:") < 0) { - appxInfo.name = path.parse(executable).name; - } else { - appxInfo.name = null; - } - } - if (appxInfo.name == null) { - if (result.Package.Identity != null && result.Package.Identity[0] != null) { - let name = result.Package.Identity[0].$.Name; - if (name != null && name.indexOf("ms-resource:") < 0) { - appxInfo.name = name; - } - } - } - } catch (ex) { - if (result != null) { - let propertiesIcon = getPropertiesIcon(installLocation, result); - if (propertiesIcon != null) { - appxInfo.icon = propertiesIcon; - } - } - if (process.env.NODE_ENV !== "production") { - console.log(ex); - } - } - return appxInfo; -} - -/** - * 刷新图标缓存 - * @param item - */ -async function refreshIconCache(item) { - let info = {}; - if (item.type == 0 || item.type == 1) { - info.icon = await getFileIcon(item.path, false); - } else { - let appxInfo = await getAppxInfo(item.installLocation); - if (appxInfo.icon != null) { - try { - let buffer = fs.readFileSync(appxInfo.icon); - info.icon = "data:" + mime.getType(appxInfo.icon) + ";base64," + buffer.toString("base64"); - info.iconPath = appxInfo.icon; - } catch (ex) { - if (process.env.NODE_ENV !== "production") { - console.log(ex); - } - } - } - } - return info; -} - -/** - * 刷新图标缓存 - * @param item - */ -async function refreshIconCacheList(classificationParentId, classificationChildId) { - // 获取分类下所有项目 - let classification; - if (classificationParentId != null) { - let classificationParent; - for (let c of global.list) { - if (c.id == classificationParentId) { - classificationParent = c; - break; - } - } - if (classificationChildId != null) { - if (!util.arrayIsEmpty(classificationParent.childList)) { - let classificationChild; - for (let c of classificationParent.childList) { - if (c.id == classificationChildId) { - classificationChild = c; - break; - } - } - classification = classificationChild; - } else { - classification = classificationParent; - } - } else { - classification = classificationParent; - } - } - let resultList = []; - if (classification != null && !util.arrayIsEmpty(classification.itemList)) { - // 刷新所有项目图标 - for (let item of classification.itemList) { - if ((item.type == 0 || item.type == 1 || item.type == 5) && (item.notRefreshIcon == null || !item.notRefreshIcon)) { - let info = await refreshIconCache(item); - info.itemId = item.id; - resultList.push(info); - } - } - } - return resultList; -} - -/** - * 读取文件 - * @param pathArr - */ -async function readFiles(pathArr) { - let itemList = []; - for (let filePath of pathArr) { - try { - let item = { - // id - id: null, - // 路径 - path: null, - // url - url: null, - // 名称 - name: null, - // 图标 - icon: null, - // 参数 - params: null, - // 以管理员身份运行 - admin: false, - // 类型 0:文件 1:文件夹 2:网址 - type: 0, - // 排序 - order: 0, - }; - // path - let target = filePath; - // 文件名 - item.name = path.basename(target); - // 判断是否是快捷方式,如果是的话,需要获取真实路径 - if (mime.getType(filePath) == "application/x-ms-shortcut") { - // 快捷方式 - // 获取真实文件路径和参数 - let shortcutDetail = global.api.GetShortcutFile(filePath); - if (util.strIsEmpty(shortcutDetail.target)) { - // 路径 - target = filePath; - } else { - // 路径 - target = shortcutDetail.target; - } - // 参数 - item.params = !util.strIsEmpty(shortcutDetail.arguments) ? shortcutDetail.arguments : null; - } - // 文件类型 - let stats = fs.statSync(target); - // 路径 - item.path = target; - item.type = stats.isFile() ? 0 : 1; - // 获取图标 - item.icon = await getFileIcon(target, true); - // 去掉后缀 - if (item.type == 0) { - item.name = util.removeSuffix(item.name); - } - // add - itemList.push(item); - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - } - return itemList; -} - -/** - * 获取开始菜单程序 - */ -async function getStartMenuProgramList() { - // 返回列表 - let resultList = []; - // appData - let appDataPathList = getPathProgramList(process.env["AppData"] + "\\Microsoft\\Windows\\Start Menu\\Programs"); - // programData - let programDataPathList = getPathProgramList(process.env["ProgramData"] + "\\Microsoft\\Windows\\Start Menu\\Programs"); - // list - let pathList = []; - pathList.push(...appDataPathList); - pathList.push(...programDataPathList); - // 查询缓存 - let cacheStartMenuProgramList = cacheData.cacheStore.get("startMenuProgramList"); - // 循环组装数据 - for (let p of pathList) { - // 获取后缀,必须是快捷方式 - if (mime.getType(p) == "application/x-ms-shortcut") { - // 获取名称去掉后缀 - let name = util.removeSuffix(path.basename(p)); - // 查重 - let flag = false; - for (let e of resultList) { - if (e.name == name) { - flag = true; - break; - } - } - if (!flag) { - let exist = false; - // 是否存在如果存在的话不需要重新获取图标 - if (!util.arrayIsEmpty(cacheStartMenuProgramList)) { - for (let pro of cacheStartMenuProgramList) { - if (name == pro.name && p == pro.path) { - resultList.push(pro); - exist = true; - break; - } - } - } - if (!exist) { - // data - let data = { - name: name, - path: p, - icon: await getFileIcon(p, true), - }; - // push - resultList.push(data); - } - } - } - } - // 排序 - resultList.sort((a, b) => a.name.localeCompare(b.name)); - // 写入缓存 - cacheData.cacheStore.set("startMenuProgramList", resultList); - // 返回 - return resultList; -} - -/** - * 获取Appx列表 - */ -async function getAppxList() { - let resultList = []; - try { - let release = os.release(); - let releaseSplit = release.split("."); - if (Number(releaseSplit[0]) >= 10) { - let stdout = execSync('powershell -Command "Get-AppxPackage | Select-Object PackageFamilyName, InstallLocation | Format-list"'); - stdout = stdout.toString("UTF8"); - let split = stdout.trim().split("\r\n"); - split = split.filter((str) => str.trim() != ""); - let list = []; - let packageFamilyName = null; - let installLocation = null; - let prev = null; - for (let i = 0; i < split.length; i++) { - let t = split[i].trim(); - let s = t.split(" : "); - if (s.length > 1) { - if (s[0].trim() == "PackageFamilyName") { - if (packageFamilyName != null && installLocation != null) { - list.push({ - packageFamilyName: packageFamilyName, - installLocation: installLocation, - }); - packageFamilyName = s[1].trim(); - installLocation = null; - prev = "PackageFamilyName"; - } else { - packageFamilyName = s[1].trim(); - prev = "PackageFamilyName"; - } - } else if (s[0].trim() == "InstallLocation") { - installLocation = s[1].trim(); - prev = "InstallLocation"; - } - } else { - if (prev == "PackageFamilyName") { - packageFamilyName += t; - } else if (prev == "InstallLocation") { - installLocation += t; - } - } - } - if (packageFamilyName != null && installLocation != null) { - list.push({ - packageFamilyName: packageFamilyName, - installLocation: installLocation, - }); - } - // 读取XML获取图标路径和名称 - for (let e of list) { - let appxInfo = await getAppxInfo(e.installLocation); - e.appId = appxInfo.appId; - e.icon = appxInfo.icon; - e.name = appxInfo.name; - } - // 过滤 - let filterList = list.filter((e) => e.icon != null && e.appId != null && e.name != null); - // 图标转BASE64 - for (let e of filterList) { - try { - let buffer = fs.readFileSync(e.icon); - let icon = "data:" + mime.getType(e.icon) + ";base64," + buffer.toString("base64"); - e.originalIcon = e.icon; - e.icon = icon; - } catch (ex) { - if (process.env.NODE_ENV !== "production") { - console.log(ex); - } - e.icon = null; - } - } - // 返回列表 - resultList = filterList.filter((e) => e.icon != null); - // 排序 - resultList.sort((a, b) => a.name.localeCompare(b.name)); - } - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - return resultList; -} - -/** - * 图片转BASE64 - */ -function imageToBase64(path) { - fs.readFile(path, (err, data) => { - let buffer = Buffer.from(data); - let icon = "data:" + mime.getType(path) + ";base64," + buffer.toString("base64"); - global.mainWindow.webContents.send("imageToBase64", icon); - }); -} - -/** - * 下载图片 - * @param url - */ -function downloadImage(url) { - let result = { - status: false, - message: global.currentLanguage.downloadImageFailedMessage, - name: null, - icon: null, - }; - // 重试 - const operation = retry.operation({ - retries: 5, // 最多重试 5 次 - factor: 1, // 每次重试之间的时间间隔加倍 - minTimeout: 1000, // 第一次重试之前等待的时间 - maxTimeout: 5000, // 最长等待时间 - }); - operation.attempt((currentAttempt) => { - // 下载图片 - request( - { - uri: url, - proxy: getProxy(), - encoding: null, - timeout: 5000, - headers: { - "User-Agent": getRandomUserAgent(), - }, - }, - function (error, response, body) { - if (operation.retry(error)) { - return; - } - if (!error && response.statusCode >= 200 && response.statusCode <= 299) { - if (response.headers != null && response.headers["content-type"] != null) { - let ext = mime.getExtension(response.headers["content-type"]); - if (ext == "jpg" || ext == "jpeg" || ext == "png" || ext == "gif" || ext == "ico" || ext == "svg") { - let buffer = Buffer.from(body); - result.icon = "data:" + mime.getType(response.headers["content-type"]) + ";base64," + buffer.toString("base64"); - result.status = true; - result.message = null; - } else { - result.icon = null; - result.status = false; - result.message = global.currentLanguage.downloadImageNotImageFormatMessage; - } - } - } - returnDownloadImage(result); - } - ); - }); -} - -/** - * 返回下载图片信息 - * @param result - */ -function returnDownloadImage(result) { - global.mainWindow.webContents.send("returnDownloadImage", JSON.stringify(result)); -} - -/** - * 添加/修改项目菜单项 - * @param type - * @param classificationParentId - * @param classificationChildId - * @param id - * @param itemType - */ -function addEditItemMenu(type, classificationParentId, classificationChildId, id, itemType) { - let params = { - type: type, - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - id: id, - itemType: itemType, - }; - global.mainWindow.webContents.send("showItemAddEditWindow", JSON.stringify(params)); -} - -/** - * 清空项目菜单 - * @param classificationParentId - * @param classificationChildId - * @param confirm - */ -function clearItemMenu(classificationParentId, classificationChildId, confirm) { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - confirm: confirm, - }; - global.mainWindow.webContents.send("clearItem", JSON.stringify(params)); -} - -/** - * 项目刷新图标缓存列表菜单 - * @param classificationParentId - * @param classificationChildId - */ -function refreshIconCacheListItemMenu(classificationParentId, classificationChildId) { - dialog - .showMessageBox(global.mainWindow, { - message: global.currentLanguage.refreshIconCurrentClassificationMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - refreshIconCacheList(classificationParentId, classificationChildId).then((res) => { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - list: res, - }; - global.mainWindow.webContents.send("refreshIconCacheList", JSON.stringify(params)); - }); - } - }); -} - -/** - * 项目转换路径菜单 - * @param classificationParentId - * @param classificationChildId - * @param type - */ -function convertPathListItemMenu(classificationParentId, classificationChildId, type) { - dialog - .showMessageBox(global.mainWindow, { - message: type == "relative" ? global.currentLanguage.relativeCurrentClassificationMessage : global.currentLanguage.absoluteCurrentClassificationMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - type: type, - }; - global.mainWindow.webContents.send("convertPathList", JSON.stringify(params)); - } - }); -} - -export default function () { - // 项目空白处右键菜单 - ipcMain.on("itemContentRightMenu", (event, args) => { - // 参数 - let p = JSON.parse(args); - // 在拥有子级分类的父级分类下右键 - let addSubmenu = []; - let clearSubmenu = []; - let refreshIconCacheSubmenu = []; - let convertRelativePathSubmenu = []; - let convertAbsolutePathSubmenu = []; - if (p.haveClassificationChild && p.classificationChildId == null) { - for (let i = 0; i < global.list.length; i++) { - if (global.list[i].id == p.classificationParentId) { - for (let j = 0; j < global.list[i].childList.length; j++) { - if ( - util.strIsEmpty(global.list[i].childList[j].mapDirectory) && - (global.list[i].childList[j].type == null || global.list[i].childList[j].type != 1) - ) { - addSubmenu.push({ - label: global.list[i].childList[j].name, - click: () => { - addEditItemMenu(0, p.classificationParentId, global.list[i].childList[j].id); - }, - }); - clearSubmenu.push({ - label: global.list[i].childList[j].name, - click: () => { - clearItemMenu(p.classificationParentId, global.list[i].childList[j].id, true); - }, - }); - convertRelativePathSubmenu.push({ - label: global.list[i].childList[j].name, - click: () => { - convertPathListItemMenu(p.classificationParentId, global.list[i].childList[j].id, "relative"); - }, - }); - convertAbsolutePathSubmenu.push({ - label: global.list[i].childList[j].name, - click: () => { - convertPathListItemMenu(p.classificationParentId, global.list[i].childList[j].id, "absolute"); - }, - }); - } - if (global.list[i].childList[j].type == null || global.list[i].childList[j].type != 1) { - refreshIconCacheSubmenu.push({ - label: global.list[i].childList[j].name, - click: () => { - refreshIconCacheListItemMenu(p.classificationParentId, global.list[i].childList[j].id); - }, - }); - } - } - } - } - } - // 菜单 - let menuList = []; - if (p.haveClassificationChild && p.classificationChildId == null) { - if (!util.arrayIsEmpty(addSubmenu)) { - menuList.push({ - label: global.currentLanguage.newItem, - type: "submenu", - submenu: addSubmenu, - }); - } - } else { - if (!p.isMapDirectory && !p.aggregate) { - menuList.push({ - label: global.currentLanguage.newItem, - click: () => { - addEditItemMenu(0, p.classificationParentId, p.classificationChildId); - }, - }); - } - } - if (!p.aggregate) { - menuList.push(index.itemSortMenu(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.sort)); - } - menuList.push(...index.itemLayoutIconSize(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.layout, p.iconSize)); - menuList.push(ItemJS.itemShowOnly(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.showOnly)); - if ( - !p.haveClassificationChild && - ((p.layout != null && p.layout == "list") || (global.setting.item.layout == "list" && (p.layout == null || p.layout == "default"))) - ) { - menuList.push(ItemJS.itemColumnNumber(p.classificationParentId, p.classificationChildId, p.haveClassificationChild, p.columnNumber)); - } - menuList.push({ type: "separator" }); - if (p.haveClassificationChild && p.classificationChildId == null) { - if (!util.arrayIsEmpty(refreshIconCacheSubmenu)) { - menuList.push({ - label: global.currentLanguage.batchRefreshIconCache, - type: "submenu", - submenu: refreshIconCacheSubmenu, - }); - } - } else { - if (!p.aggregate) { - menuList.push({ - label: global.currentLanguage.batchRefreshIconCache, - click: () => { - refreshIconCacheListItemMenu(p.classificationParentId, p.classificationChildId); - }, - }); - } - } - if (p.haveClassificationChild && p.classificationChildId == null) { - if (!util.arrayIsEmpty(convertRelativePathSubmenu)) { - menuList.push({ - label: global.currentLanguage.batchConversionRelativePath, - type: "submenu", - submenu: convertRelativePathSubmenu, - }); - } - } else { - if (!p.isMapDirectory && !p.aggregate) { - menuList.push({ - label: global.currentLanguage.batchConversionRelativePath, - click: () => { - convertPathListItemMenu(p.classificationParentId, p.classificationChildId, "relative"); - }, - }); - } - } - if (p.haveClassificationChild && p.classificationChildId == null) { - if (!util.arrayIsEmpty(convertAbsolutePathSubmenu)) { - menuList.push({ - label: global.currentLanguage.batchConversionAbsolutePath, - type: "submenu", - submenu: convertAbsolutePathSubmenu, - }); - } - } else { - if (!p.isMapDirectory && !p.aggregate) { - menuList.push({ - label: global.currentLanguage.batchConversionAbsolutePath, - click: () => { - convertPathListItemMenu(p.classificationParentId, p.classificationChildId, "absolute"); - }, - }); - } - } - menuList.push({ type: "separator" }); - if (p.haveClassificationChild && p.classificationChildId == null) { - if (!util.arrayIsEmpty(clearSubmenu)) { - menuList.push({ - label: global.currentLanguage.clearItem, - type: "submenu", - submenu: clearSubmenu, - }); - } - } else { - if (!p.isMapDirectory && !p.aggregate) { - menuList.push({ - label: global.currentLanguage.clearItem, - click: () => { - clearItemMenu(p.classificationParentId, p.classificationChildId, true); - }, - }); - } - } - menuList.push({ type: "separator" }); - if (!p.isMapDirectory && !p.aggregate) { - menuList.push({ - label: p.lockItem ? global.currentLanguage.unlockItem : global.currentLanguage.lockItem, - click: () => { - global.mainWindow.webContents.send("setLockItem", !p.lockItem); - cacheData.cacheStore.set("lockItem", !p.lockItem); - }, - }); - menuList.push({ type: "separator" }); - } - if (!p.lockItem && !p.isMapDirectory && !p.aggregate) { - menuList.push({ - label: p.batchOperation ? global.currentLanguage.cancelBatchOperation : global.currentLanguage.batchOperation, - click: () => { - global.mainWindow.webContents.send("setBatchOperation", !p.batchOperation); - }, - }); - } - let m = Menu.buildFromTemplate(menuList); - util.menuListen(m); - m.popup(); - }); - // 项目右键 - ipcMain.on("itemRightMenu", (event, args) => { - // 参数 - let p = JSON.parse(args); - // 项目 - let item = p.item; - // 转为菜单 - let moveSubmenu = []; - let copySubmenu = []; - if ((p.search == null || !p.search) && (p.searchWindow == null || !p.searchWindow) && !p.isMapDirectory && !p.aggregate) { - moveSubmenu = convertMenu(p.classificationParentId, p.classificationChildId, item.id, global.list, true); - copySubmenu = convertMenu(p.classificationParentId, p.classificationChildId, item.id, global.list, false); - } - // 菜单 - let menuList = [ - { - label: global.currentLanguage.open, - click: () => { - if (p.searchWindow != null && p.searchWindow) { - global.searchWindow.hide(); - } - index.itemRun(item, false); - if (p.search != null && p.search) { - global.mainWindow.webContents.send("closeSearch"); - } - }, - }, - { - label: global.currentLanguage.emptyRecycleBin, - visible: item.type == 3 && item.shell == "shell:RecycleBinFolder", - click: () => { - global.api.EmptyRecycleBin(global.mainWindow.getNativeWindowHandle()); - }, - }, - { - label: global.currentLanguage.openWith, - visible: item.type == 0 && item.extension != ".exe" && item.extension != ".bat" && item.extension != ".lnk", - click: () => { - if (p.searchWindow != null && p.searchWindow) { - global.searchWindow.hide(); - } - index.itemRun(item, false, true); - if (p.search != null && p.search) { - global.mainWindow.webContents.send("closeSearch"); - } - }, - }, - { - label: global.currentLanguage.runAsAdministrator, - visible: (item.type == 0 && (item.extension == ".exe" || item.extension == ".bat")) || (item.type == 3 && item.shell == "cmd"), - click: () => { - item.admin = true; - index.itemRun(item, false); - if (p.search != null && p.search) { - global.mainWindow.webContents.send("closeSearch"); - } - if (p.searchWindow != null && p.searchWindow) { - global.searchWindow.hide(); - } - }, - }, - { - label: global.currentLanguage.openLocation, - visible: item.type == 0, - click: () => { - index.itemRun(item, true); - if (p.search != null && p.search) { - global.mainWindow.webContents.send("closeSearch"); - } - if (p.searchWindow != null && p.searchWindow) { - global.searchWindow.hide(); - } - }, - }, - ]; - menuList.push({ - type: "separator", - }); - if (item.type != 3 && item.type != 4 && item.type != 5) { - menuList.push({ - label: global.currentLanguage.copyFullPath, - click: () => { - if (item.type == 0 || item.type == 1) { - clipboard.writeText(index.getAbsolutePath(item.path)); - } else if (item.type == 2) { - clipboard.writeText(item.url); - } - if (p.search != null && p.search) { - global.mainWindow.webContents.send("closeSearch"); - } - if (p.searchWindow != null && p.searchWindow) { - global.searchWindow.hide(); - } - }, - }); - } - if (item.type == 0 || item.type == 1 || item.type == 5) { - menuList.push({ - label: global.currentLanguage.createDesktopShortcut, - click: () => { - dialog - .showSaveDialog(global.mainWindow, { - title: global.currentLanguage.createDesktopShortcut, - defaultPath: util.removeSuffix(item.name.replace(/\\n/g, " ")), - filters: [{ name: "lnk", extensions: ["lnk"] }], - }) - .then((r) => { - if (!r.canceled && !util.strIsEmpty(r.filePath)) { - if (item.type == 0 || item.type == 1) { - // 获取绝对路径 - item.path = index.getAbsolutePath(item.path); - } - shell.writeShortcutLink(r.filePath, "create", { - target: item.type == 5 ? item.shell : item.path, - }); - } - }); - }, - }); - } - menuList.push({ - label: global.currentLanguage.exportIcon, - click: () => { - if (!util.strIsEmpty(item.icon) || !util.strIsEmpty(item.htmlIcon)) { - let re = new RegExp("data:(?.*?);base64,.*"); - let res = re.exec(item.icon); - let htmlIcon = !util.strIsEmpty(item.htmlIcon); - if (res || htmlIcon) { - try { - dialog - .showSaveDialog(global.mainWindow, { - title: global.currentLanguage.exportIcon, - defaultPath: "icon", - filters: [{ name: htmlIcon ? "svg" : mime.getExtension(res.groups.ext), extensions: [htmlIcon ? "svg" : mime.getExtension(res.groups.ext)] }], - }) - .then((r) => { - if (!r.canceled && !util.strIsEmpty(r.filePath)) { - if (htmlIcon) { - fs.writeFile(r.filePath, item.htmlIcon, function (err) {}); - } else { - let arr = item.icon.split(","); - if (arr.length == 2) { - let base64Data = arr[1]; - let dataBuffer = Buffer.from(base64Data, "base64"); - fs.writeFile(r.filePath, dataBuffer, function (err) {}); - } - } - } - }); - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - } - } - }, - }); - if ( - (item.type == 0 || item.type == 1 || item.type == 5) && - (p.search == null || !p.search) && - (p.searchWindow == null || !p.searchWindow) && - (item.notRefreshIcon == null || !item.notRefreshIcon) && - !p.aggregate - ) { - menuList.push({ - label: global.currentLanguage.refreshIconCache, - click: () => { - // 获取图标 - refreshIconCache(item).then((res) => { - if (res.icon != null) { - let { classificationParentId, classificationChildId } = ClassificationJS.convertClassificationId( - item.classificationId, - item.classificationParentId - ); - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - id: item.id, - icon: res.icon, - }; - if (item.type == 5) { - params.iconPath = res.iconPath; - } - global.mainWindow.webContents.send("refreshIconCache", JSON.stringify(params)); - } - }); - }, - }); - } - if ( - (item.type == 0 || item.type == 1) && - (p.search == null || !p.search) && - (p.searchWindow == null || !p.searchWindow) && - !p.isMapDirectory && - !p.aggregate - ) { - menuList.push({ - label: ItemJS.isAbsolutePath(item.path) ? global.currentLanguage.convertRelativePath : global.currentLanguage.convertAbsolutePath, - click: () => { - let { classificationParentId, classificationChildId } = ClassificationJS.convertClassificationId(item.classificationId, item.classificationParentId); - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - id: item.id, - type: ItemJS.isAbsolutePath(item.path) ? "relative" : "absolute", - }; - global.mainWindow.webContents.send("convertPath", JSON.stringify(params)); - }, - }); - } - if (item.type == 0 || item.type == 1 || item.type == 3) { - let flag = false; - let itemPath; - if (item.type == 3) { - if ( - item.shell == "shell:MyComputerFolder" || - item.shell == "shell:DocumentsLibrary" || - item.shell == "shell:ControlPanelFolder" || - item.shell == "shell:RecycleBinFolder" - ) { - itemPath = item.shell; - flag = true; - } else if (item.shell == "services.msc") { - itemPath = process.env.SystemRoot + "\\System32\\services.msc"; - flag = true; - } else if (item.shell == "cmd") { - itemPath = process.env.SystemRoot + "\\System32\\cmd.exe"; - flag = true; - } else if (item.shell == "taskmgr") { - itemPath = process.env.SystemRoot + "\\System32\\taskmgr.exe"; - flag = true; - } else if (item.shell == "regedit") { - itemPath = process.env.SystemRoot + "\\regedit.exe"; - flag = true; - } else if (item.shell == "powercfg.cpl") { - itemPath = process.env.SystemRoot + "\\System32\\powercfg.exe"; - flag = true; - } else if (item.shell == "compmgmt.msc /s") { - itemPath = process.env.SystemRoot + "\\System32\\compmgmt.msc"; - flag = true; - } - } else { - flag = true; - itemPath = index.getAbsolutePath(item.path); - } - if (flag) { - menuList.push({ - type: "separator", - }); - menuList.push({ - label: global.currentLanguage.explorerMenu, - click: () => { - const mouseEvent = require("../mouse"); - let screen = util.getWindowInScreen(); - let scaleFactor = 1; - if (!util.arrayIsEmpty(screen)) { - scaleFactor = screen[0].scaleFactor; - } - // 暂停鼠标事件 - mouseEvent.pauseMouseEvents(); - try { - global.api.ContextMenu(global.mainWindow.getNativeWindowHandle(), itemPath, p.x * scaleFactor, p.y * scaleFactor); - } finally { - // 恢复鼠标事件 - mouseEvent.resumeMouseEvents(); - } - }, - }); - } - } - if ( - (!util.arrayIsEmpty(moveSubmenu) || !util.arrayIsEmpty(copySubmenu)) && - (p.search == null || !p.search) && - (p.searchWindow == null || !p.searchWindow) && - !p.isMapDirectory && - !p.aggregate - ) { - menuList.push({ - type: "separator", - }); - if (!util.arrayIsEmpty(moveSubmenu)) { - menuList.push({ - label: global.currentLanguage.moveTo, - visible: !util.arrayIsEmpty(moveSubmenu), - type: "submenu", - submenu: moveSubmenu, - }); - } - if (!util.arrayIsEmpty(copySubmenu)) { - menuList.push({ - label: global.currentLanguage.copyTo, - visible: !util.arrayIsEmpty(copySubmenu), - type: "submenu", - submenu: copySubmenu, - }); - } - } - if ((p.search == null || !p.search) && (p.searchWindow == null || !p.searchWindow) && !p.isMapDirectory && !p.aggregate) { - menuList.push( - { - type: "separator", - }, - { - label: global.currentLanguage.newItem, - click: () => { - addEditItemMenu(0, p.classificationParentId, p.classificationChildId); - }, - }, - { - type: "separator", - }, - { - label: global.currentLanguage.edit, - click: () => { - addEditItemMenu(1, p.classificationParentId, p.classificationChildId, item.id, item.type); - }, - }, - { - label: global.currentLanguage.delete, - click: () => { - dialog - .showMessageBox(global.mainWindow, { - message: global.currentLanguage.deleteItemMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - let params = { - classificationParentId: p.classificationParentId, - classificationChildId: p.classificationChildId, - id: item.id, - }; - global.mainWindow.webContents.send("deleteItem", JSON.stringify(params)); - } - }); - }, - } - ); - } - if ((p.search == null || !p.search) && (p.searchWindow == null || !p.searchWindow) && p.isMapDirectory && !p.aggregate) { - menuList.push({ type: "separator" }); - menuList.push({ - label: global.currentLanguage.hideThisItem, - click: () => { - let params = { - classificationParentId: p.classificationParentId, - classificationChildId: p.classificationChildId, - item: item, - }; - global.mainWindow.webContents.send("hiddenItem", JSON.stringify(params)); - }, - }); - } - // 菜单 - let m = Menu.buildFromTemplate(menuList); - util.menuListen(m); - m.popup(); - }); - // 多选项目右键 - ipcMain.on("multiItemRightMenu", (event, args) => { - // 菜单列表 - let menuList = []; - // 全选 - menuList.push({ - label: global.currentLanguage.selectAll, - click: () => { - global.mainWindow.webContents.send("batchOperationSelectAll"); - }, - }); - menuList.push({ type: "separator" }); - // 转为菜单 - let moveSubmenu = batchOperationConvertMenu(global.list, true); - let copySubmenu = batchOperationConvertMenu(global.list, false); - // 移动 复制 - if (!util.arrayIsEmpty(moveSubmenu) || !util.arrayIsEmpty(copySubmenu)) { - if (!util.arrayIsEmpty(moveSubmenu)) { - menuList.push({ - label: global.currentLanguage.moveTo, - visible: !util.arrayIsEmpty(moveSubmenu), - type: "submenu", - submenu: moveSubmenu, - }); - } - if (!util.arrayIsEmpty(copySubmenu)) { - menuList.push({ - label: global.currentLanguage.copyTo, - visible: !util.arrayIsEmpty(copySubmenu), - type: "submenu", - submenu: copySubmenu, - }); - } - } - menuList.push({ type: "separator" }); - menuList.push({ - label: global.currentLanguage.delete, - click: () => { - dialog - .showMessageBox(global.mainWindow, { - message: global.currentLanguage.batchDeleteItemMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - global.mainWindow.webContents.send("batchDeleteItem"); - } - }); - }, - }); - menuList.push({ type: "separator" }); - menuList.push({ - label: global.currentLanguage.cancelBatchOperation, - click: () => { - global.mainWindow.webContents.send("setBatchOperation", false); - }, - }); - // 菜单 - let m = Menu.buildFromTemplate(menuList); - util.menuListen(m); - m.popup(); - }); - // 运行项目 - ipcMain.on("itemRun", (event, args) => { - let params = JSON.parse(args); - index.itemRun(params.item, params.location); - let setItemDataParams = { - item: params.item, - recordQuickSearch: params.recordQuickSearch, - }; - global.mainWindow.webContents.send("setItemData", JSON.stringify(setItemDataParams)); - }); - // 获取文件图标 - ipcMain.on("getFileIcon", (event, args) => { - getFileIcon(args, true).then((res) => { - event.sender.send("getFileBase64", res); - }); - }); - // 获取网址信息 - ipcMain.on("getUrlInfo", (event, args) => { - getUrlInfo(args, true); - }); - // 读取文件 - ipcMain.on("readFiles", (event, args) => { - let params = JSON.parse(args); - readFiles(params.path).then((res) => { - // 主窗口编辑分类 - let itemAddParams = { - classificationParentId: params.classificationParentId, - classificationChildId: params.classificationChildId, - itemList: res, - clear: false, - }; - global.mainWindow.webContents.send("itemAdd", JSON.stringify(itemAddParams)); - }); - }); - // 图片转base64 - ipcMain.on("imageToBase64", (event, args) => { - imageToBase64(args); - }); - // 清空项目 - ipcMain.on("clearItemDialog", (event, args) => { - let params = JSON.parse(args); - dialog - .showMessageBox(global.mainWindow, { - message: global.currentLanguage.clearItemMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - clearItemMenu(params.classificationParentId, params.classificationChildId, false); - } - }); - }); - // 获取文件后缀 - ipcMain.on("getFileExtension", (event, args) => { - event.returnValue = path.extname(args); - }); - // 拖出文件 - ipcMain.on("ondragstart", (event, args) => { - let params = JSON.parse(args); - try { - // 网站和系统不能拖出 - if (params.type == 2 || params.type == 3) { - // 取消拖出状态 - global.mainWindow.webContents.send("cancelDragOut"); - return; - } - let icon; - // 环境判断 - if (process.env.NODE_ENV !== "production") { - // 开发 - icon = "./public/images/drag-and-drop.png"; - } else { - // 正式 - icon = path.join(__dirname, "./images/drag-and-drop.png"); - } - event.sender.startDrag({ - file: index.getAbsolutePath(params.path), - icon: icon, - }); - } finally { - // 取消拖出状态 - global.mainWindow.webContents.send("cancelDragOut"); - } - }); - // 获取锁定项目状态 - ipcMain.on("getLockItem", (event, args) => { - let lockItem = cacheData.cacheStore.get("lockItem"); - event.returnValue = lockItem == null ? false : lockItem; - }); - // 读取文件夹 - ipcMain.on("readDirectory", (event, args) => { - let pathArr = JSON.parse(args); - let resultList = []; - for (let p of pathArr) { - try { - // 获取文件类型 - let stats; - try { - // 文件类型 - stats = fs.statSync(p); - } catch (e) { - p = p.replace(" (x86)", ""); - try { - stats = fs.statSync(p); - } catch (e) {} - } - // 只要文件夹 - if (stats != null && stats.isDirectory()) { - // 读取文件夹下的内容 - let files = fs.readdirSync(p); - // 组装路径 - let fileList = []; - for (let file of files) { - fileList.push(path.join(p, file)); - } - // 返回信息 - let name = path.basename(p); - resultList.push({ - name: util.strIsEmpty(name) ? p : name, - fileList: fileList, - }); - } - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - } - // 返回 - event.returnValue = JSON.stringify(resultList); - }); - // 校验无效项目 - ipcMain.on("checkInvalidItem", (event, args) => { - global.mainWindow.webContents.send("checkInvalidItemResult", JSON.stringify(index.checkInvalidItem())); - }); - // 获取开始菜单程序 - ipcMain.on("getStartMenuProgramList", (event, args) => { - getStartMenuProgramList().then((res) => { - // 返回数据 - global.mainWindow.webContents.send("resultStartMenuProgramList", JSON.stringify(res)); - }); - }); - // 获取Appx列表 - ipcMain.on("getAppxList", (event, args) => { - getAppxList().then((res) => { - global.mainWindow.webContents.send("returnAppxList", JSON.stringify(res)); - }); - }); - // 初始化映射文件夹 - ipcMain.on("initMapDirectory", (event, args) => { - // 初始化映射文件夹 - index.initMapDirectory().then((res) => { - if (res != null) { - global.mainWindow.webContents.send("returnInitMapDirectory", JSON.stringify(res)); - } - }); - }); - // 读取映射文件夹 - ipcMain.on("readMapDirectory", (event, args) => { - let params = JSON.parse(args); - index.readMapDirectory(params.classificationParentId, params.classificationChildId, params.mapDirectory, true, false, true); - }); - // 删除文件夹监听 - ipcMain.on("deleteMapDirectoryWatch", (event, args) => { - let params = JSON.parse(args); - index.deleteMapDirectoryWatcher(params.classificationParentId, params.classificationChildId); - }); - // 上传图标 - ipcMain.on("uploadIcon", (event, args) => { - let ext = path.extname(args); - if (ext == ".jpg" || ext == ".jpeg" || ext == ".png" || ext == ".gif" || ext == ".ico" || ext == ".svg") { - // 图片 - imageToBase64(args); - } else { - // 获取文件图标 - getFileIcon(args, true).then((res) => { - event.sender.send("getFileBase64", res); - }); - } - }); - // 下载图片 - ipcMain.on("downloadImage", (event, args) => { - downloadImage(args); - }); -} diff --git a/src/main/main.js b/src/main/main.js deleted file mode 100644 index 36136f0..0000000 --- a/src/main/main.js +++ /dev/null @@ -1,816 +0,0 @@ -import appInit from "./appInit"; -import { app, BrowserWindow, dialog, ipcMain, Menu, protocol, Tray, screen } from "electron"; -import { createProtocol } from "vue-cli-plugin-electron-builder/lib"; -import classificationIpcEvent from "./classification/ipcEvent"; -import itemIpcEvent from "./item/ipcEvent"; -import settingIpcEvent from "./setting/ipcEvent"; -import ipcEvent from "./ipcEvent"; -import settingIndex from "./setting/index"; -import path from "path"; -import util from "./util"; -import itemIndex from "./item/index"; -import cacheData from "./cache/data"; -import data from "./data"; - -// 解决透明窗口闪烁 -app.commandLine.appendSwitch("wm-window-animations-disabled"); - -// 数据 -const settingData = require("./setting/data"); - -protocol.registerSchemesAsPrivileged([{ scheme: "app", privileges: { secure: true, standard: true } }]); - -// 主窗口 -let mainWindow = null; -// 设置窗口 -let settingWindow = null; -// 搜索框 -let searchWindow = null; - -/** - * 创建主窗口 - * @param init - * @returns {Promise} - */ -async function createWindow(init) { - // 浏览器开发者工具 - let devTools; - // 环境判断 - if (process.env.NODE_ENV !== "production") { - // 开发 - devTools = true; - } else { - // 正式 - devTools = false; - } - if (init) { - // 初始化监听 - await ipcEvent(); - await classificationIpcEvent(); - await itemIpcEvent(); - await settingIpcEvent(); - // 初始化数据 - await settingData.initData(); - await data.initData(); - await data.splitData(); - await data.validData(); - // watch - global.mapDirectoryWatcher = new Map(); - } - // 记录是否透明 - if (global.setting.appearance.backgroundTransparency == 1) { - global.backgroundTransparency = false; - } else { - global.backgroundTransparency = true; - } - // 主窗口 - global.mainWindow = mainWindow = new BrowserWindow({ - minWidth: 300, - minHeight: 400, - width: 800, - height: 600, - frame: false, - show: false, - maximizable: false, - minimizable: false, - fullscreenable: false, - transparent: global.backgroundTransparency, - skipTaskbar: true, - webPreferences: { - backgroundThrottling: false, - nodeIntegration: true, - contextIsolation: false, - spellcheck: false, - devTools: devTools, - }, - }); - // 加载页面 - if (process.env.WEBPACK_DEV_SERVER_URL) { - // Load the url of the dev server if in development mode - mainWindow.loadURL(process.env.WEBPACK_DEV_SERVER_URL); - } else { - createProtocol("app"); - // Load the index.html when not in development - mainWindow.loadURL("app://./index.html"); - } - // 加载完webContents后再显示窗口 - mainWindow.webContents.on("did-finish-load", function () { - // 透明度 - mainWindow.setOpacity(Number(global.setting.appearance.transparency)); - // 永远居中不可移动 - if (global.setting.general.alwaysCenter) { - // 是否可移动 - mainWindow.setMovable(false); - } else { - // 是否可移动 - mainWindow.setMovable(!global.setting.general.fixedPosition); - } - // 恢复上一次的位置 - let bounds = cacheData.cacheStore.get("bounds"); - if (bounds != null) { - mainWindow.setBounds(bounds); - } - // 永远置顶 - if (global.setting.general.alwaysTop) { - mainWindow.setAlwaysOnTop(true, "screen-saver"); - } - // 是否托盘化启动 - if (!global.setting.general.startupTray) { - mainWindow.show(); - } - // 锁定尺寸 - mainWindow.setResizable(!global.setting.general.lockSize); - // 检查更新 - let checkUpdate = cacheData.cacheStore.get("checkUpdate"); - if (checkUpdate == null || checkUpdate) { - util.checkUpdate("init"); - } - // 永远居中 - if (global.setting.general.alwaysCenter) { - mainWindow.center(); - } - // 判断窗口位置 - let displays = util.getWindowInScreen(); - if (displays.length == 0) { - // 代表窗口的位置不再任一屏幕内,将窗口位置移动到主窗口 - mainWindow.center(); - } - // 边缘吸附 - util.edgeAdsorb(); - }); - // 禁用标题栏右键 - mainWindow.hookWindowMessage(278, function (e) { - // 窗口禁用 - mainWindow.setEnabled(false); - // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 - setTimeout(() => { - mainWindow.setEnabled(true); - }, 100); - return true; - }); - // 窗口移动完毕 - mainWindow.on("moved", () => { - // 永远居中 - if (global.setting.general.alwaysCenter) { - mainWindow.center(); - } - // 记录位置 - cacheData.cacheStore.set("bounds", mainWindow.getBounds()); - // 边缘吸附 - util.edgeAdsorb(); - }); - // 改变窗口大小完毕 - mainWindow.on("resized", () => { - // 永远居中 - if (global.setting.general.alwaysCenter) { - mainWindow.center(); - } - // 记录位置 - cacheData.cacheStore.set("bounds", mainWindow.getBounds()); - }); - // 监听鼠标移动 - const mouseEvent = require("./mouse"); - mouseEvent.on("mousemove", (data) => { - if (global.setting.general.edgeAutoHide && (global.blurHide == null || !global.blurHide) && !global.setting.general.alwaysCenter) { - autoHide(data, 40, true); - } - }); - // 监听鼠标抬起 - mouseEvent.on("mouseup", (data) => { - // 中键单击 - if (data.button == 3 && global.setting.general.showHideMouseWheelClick) { - if (util.notDisturb()) { - return; - } - if (global.mainWindow.isVisible()) { - // global.mainWindow.hide(); - global.mainWindow.webContents.send("hideMainWindowBefore"); - } else { - util.showFollowMousePosition(); - global.mainWindow.show(); - global.mainWindow.focus(); - global.blurHide = true; - } - } - // 双击任务栏显示/隐藏窗口 - if (global.setting.general.doubleClickTaskbar) { - // 不是左键的话 - if (data.button != 1) { - // 清除timeout - clearTimeout(global.doubleClickTimer); - // 清空 - global.doubleClickCounter = 0; - return; - } - // 双击操作 - let displays = util.getWindowInScreen(); - if (displays.length > 1 || displays.length == 0) { - // 清除timeout - clearTimeout(global.doubleClickTimer); - // 清空 - global.doubleClickCounter = 0; - return; - } - // 获取鼠标位置 - let point = screen.getCursorScreenPoint(); - // 判断鼠标是否在当前屏幕内 - if ( - point.x >= displays[0].bounds.x && - point.x <= displays[0].bounds.x + displays[0].bounds.width && - point.y >= displays[0].bounds.y && - point.y <= displays[0].bounds.y + displays[0].bounds.height - ) { - // 判断是否双击在任务栏上 - let flag = false; - // 判断任务栏在哪一侧 - if (displays[0].bounds.height > displays[0].workArea.height) { - if (displays[0].bounds.y == displays[0].workArea.y) { - // 底部 - let top = displays[0].workArea.y + displays[0].workArea.height; - let bottom = displays[0].bounds.y + displays[0].bounds.height; - if (point.y >= top && point.y <= bottom) { - flag = true; - } - } else { - // 顶部 - if (point.y >= displays[0].bounds.y && point.y <= displays[0].workArea.y) { - flag = true; - } - } - } else if (displays[0].bounds.width > displays[0].workArea.width) { - if (displays[0].bounds.x == displays[0].workArea.x) { - // 右侧 - let left = displays[0].workArea.x + displays[0].workArea.width; - let right = displays[0].bounds.x + displays[0].bounds.width; - if (point.x >= left && point.x <= right) { - flag = true; - } - } else { - // 左侧 - if (point.x >= displays[0].bounds.x && point.x <= displays[0].workArea.x) { - flag = true; - } - } - } - if (flag) { - // 监听双击 - if (global.doubleClickCounter == null) { - global.doubleClickCounter = 0; - } - // +1 - global.doubleClickCounter++; - // 等于2就是双击 - if (global.doubleClickCounter != null && global.doubleClickCounter == 2) { - // 清除timeout - clearTimeout(global.doubleClickTimer); - // 清空 - global.doubleClickCounter = 0; - let className = global.api.getCursorPosWindowClassName(); - if (className.indexOf("MSTask") >= 0 || className == "Shell_TrayWnd") { - if (mainWindow.isVisible()) { - // mainWindow.hide(); - global.mainWindow.webContents.send("hideMainWindowBefore"); - } else { - util.showFollowMousePosition(); - mainWindow.show(); - } - } - } else { - // 间隔为500毫秒,如果超过500毫秒就代表不是双击 - global.doubleClickTimer = setTimeout(function () { - global.doubleClickCounter = 0; - }, 500); - } - } else { - // 清除timeout - clearTimeout(global.doubleClickTimer); - // 清空 - global.doubleClickCounter = 0; - } - } else { - // 清除timeout - clearTimeout(global.doubleClickTimer); - // 清空 - global.doubleClickCounter = 0; - } - } - }); - // 失去焦点 - mainWindow.on("blur", () => { - if (global.setting.general.edgeAutoHide && global.blurHide) { - let scaleFactor = screen.getPrimaryDisplay().scaleFactor; - let data = { - x: screen.getCursorScreenPoint().x * scaleFactor, - y: screen.getCursorScreenPoint().y * scaleFactor, - }; - autoHide(data, 0, false); - } - if (mainWindow.isVisible()) { - if (global.setting.general.hideLosingFocus && !global.setting.general.alwaysTop) { - // 隐藏 - // mainWindow.hide(); - global.mainWindow.webContents.send("hideMainWindowBefore"); - } - } - }); - // 显示窗口 - mainWindow.on("show", () => { - // 检测无效项目 - if (global.setting.item.checkInvalidItem) { - global.mainWindow.webContents.send("checkInvalidItemResult", JSON.stringify(itemIndex.checkInvalidItem())); - } - // 边缘吸附 - util.edgeAdsorb(); - // 显示窗口时将输入法切换为英文模式 - if (global.setting.general.switchEnglish) { - global.api.SwitchEnglish(mainWindow.getNativeWindowHandle()); - } - }); - // 隐藏窗口 - mainWindow.on("hide", () => { - global.blurHide = null; - }); - // 关闭窗口事件 - mainWindow.on("close", () => { - // 关闭搜索框 - if (searchWindow != null && !searchWindow.isDestroyed()) { - searchWindow.close(); - } - // 释放鼠标监听 - global.api.disableMouseMove(); - }); -} - -/** - * 创建搜索窗口 - * @returns {Promise} - */ -async function createSettingWindow() { - // 浏览器开发者工具 - let devTools; - // 环境判断 - if (process.env.NODE_ENV !== "production") { - // 开发 - devTools = true; - } else { - // 正式 - devTools = false; - } - // 设置窗口 - global.settingWindow = settingWindow = new BrowserWindow({ - width: 600, - height: 500, - frame: false, - show: false, - maximizable: false, - minimizable: false, - fullscreenable: false, - skipTaskbar: true, - parent: mainWindow, - resizable: false, - webPreferences: { - nodeIntegration: true, - contextIsolation: false, - spellcheck: false, - devTools: devTools, - }, - }); - // 加载页面 - if (process.env.WEBPACK_DEV_SERVER_URL) { - // Load the url of the dev server if in development mode - settingWindow.loadURL(process.env.WEBPACK_DEV_SERVER_URL + "#/setting"); - } else { - createProtocol("app"); - // Load the index.html when not in development - settingWindow.loadURL("app://./index.html#setting"); - } - // 加载完webContents后再显示窗口 - settingWindow.webContents.on("did-finish-load", function () { - // 显示窗口 - settingWindow.show(); - }); - // 禁用标题栏右键 - settingWindow.hookWindowMessage(278, function (e) { - // 窗口禁用 - settingWindow.setEnabled(false); - // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 - setTimeout(() => { - settingWindow.setEnabled(true); - }, 100); - return true; - }); -} - -/** - * 创建搜索窗口 - * @returns {Promise} - */ -async function createSearchWindow() { - // 是否可以显示 - global.searchWindowShow = false; - if (searchWindow != null && !searchWindow.isDestroyed()) { - searchWindow.destroy(); - } - // 浏览器开发者工具 - let devTools; - // 环境判断 - if (process.env.NODE_ENV !== "production") { - // 开发 - devTools = true; - } else { - // 正式 - devTools = false; - } - // 窗口 - global.searchWindow = searchWindow = new BrowserWindow({ - width: 600, - height: 44, - type: "toolbar", - frame: false, - show: false, - maximizable: false, - minimizable: false, - fullscreenable: false, - resizable: false, - alwaysOnTop: true, - backgroundColor: global.setting.appearance.theme.mainBackground.replace("bg-[", "").replace("]", ""), - webPreferences: { - backgroundThrottling: false, - nodeIntegration: true, - contextIsolation: false, - spellcheck: false, - devTools: devTools, - }, - }); - // 加载页面 - if (process.env.WEBPACK_DEV_SERVER_URL) { - // Load the url of the dev server if in development mode - searchWindow.loadURL(process.env.WEBPACK_DEV_SERVER_URL + "#/searchWindow"); - } else { - createProtocol("app"); - // Load the index.html when not in development - searchWindow.loadURL("app://./index.html#searchWindow"); - } - // 加载完webContents后再显示窗口 - searchWindow.webContents.on("did-finish-load", function () { - // 恢复上一次的位置 - let bounds = cacheData.cacheStore.get("searchWindowBounds"); - if (bounds != null) { - searchWindow.setBounds({ x: bounds.x, y: bounds.y }); - } - // 设置可以显示 - global.searchWindowShow = true; - }); - // 隐藏窗口 - searchWindow.on("hide", () => { - searchWindow.setBounds({ height: 44 }); - searchWindow.webContents.send("hideSearchWindowOperation"); - }); - // 显示窗口 - searchWindow.on("show", () => { - searchWindow.setBackgroundColor(global.setting.appearance.theme.mainBackground.replace("bg-[", "").replace("]", "")); - // 显示窗口时将输入法切换为英文模式 - if (global.setting.general.switchEnglish) { - global.api.SwitchEnglish(searchWindow.getNativeWindowHandle()); - } - }); - // 窗口移动完毕 - searchWindow.on("moved", () => { - // 记录位置 - cacheData.cacheStore.set("searchWindowBounds", searchWindow.getBounds()); - }); - // 失去焦点 - searchWindow.on("blur", () => { - if (searchWindow.isVisible() && global.setting.quickSearch.hideLosingFocus) { - global.searchWindow.webContents.send("hideSearchWindowBefore"); - } - }); - // 禁用标题栏右键 - searchWindow.hookWindowMessage(278, function (e) { - // 窗口禁用 - searchWindow.setEnabled(false); - // 延时太快会立刻启动,太慢会妨碍窗口其他操作,可自行测试最佳时间 - setTimeout(() => { - searchWindow.setEnabled(true); - }, 100); - return true; - }); -} - -/** - * 自动隐藏 - * @param data - * @param size - * @param timer - */ -function autoHide(data, size, timer) { - if (global.mainWindow.isDestroyed()) { - return; - } - try { - let displays = util.getWindowInScreen(); - if (displays.length > 1 || displays.length == 0) { - return; - } - let workArea = displays[0].workArea; - let scaleFactor = displays[0].scaleFactor; - let bounds = mainWindow.getBounds(); - if (mainWindow.isVisible()) { - let flag = false; - if (bounds.x + bounds.width >= workArea.x + workArea.width) { - // 右侧 - flag = data.x <= bounds.x * scaleFactor - size || data.y <= bounds.y * scaleFactor - size || data.y >= (bounds.y + bounds.height) * scaleFactor + size; - } else if (bounds.x == workArea.x) { - // 左侧 - flag = - data.x > (bounds.x + bounds.width) * scaleFactor + size || - data.y <= bounds.y * scaleFactor - size || - data.y >= (bounds.y + bounds.height) * scaleFactor + size; - } else if (bounds.y + bounds.height >= workArea.y + workArea.height) { - // 底部 - flag = data.y < bounds.y * scaleFactor - size || data.x <= bounds.x * scaleFactor - size || data.x >= (bounds.x + bounds.width) * scaleFactor + size; - } else if (bounds.y == workArea.y) { - // 顶部 - flag = - data.y > (bounds.y + bounds.height) * scaleFactor + size || - data.x <= bounds.x * scaleFactor - size || - data.x >= (bounds.x + bounds.width) * scaleFactor + size; - } - if (flag) { - if (global.menuShow != null && global.menuShow) { - return; - } - if (timer && global.setting.general.delayHidingMS > 0 && global.autoHideTimer == null) { - global.autoHideTimer = setTimeout(function () { - // 隐藏 - // mainWindow.hide(); - global.mainWindow.webContents.send("hideMainWindowBefore"); - }, global.setting.general.delayHidingMS); - } else if (global.setting.general.delayHidingMS == 0 || !timer) { - // 隐藏 - // mainWindow.hide(); - global.mainWindow.webContents.send("hideMainWindowBefore"); - } - } else { - clearTimeout(global.autoHideTimer); - global.autoHideTimer = null; - } - } else { - if (global.direction != "none") { - let flag = false; - let x = bounds.x * scaleFactor; - let y = bounds.y * scaleFactor; - let windowWidthPosition = (bounds.x + bounds.width) * scaleFactor; - let windowHeightPosition = (bounds.y + bounds.height) * scaleFactor; - if (global.direction == "right" && data.x >= windowWidthPosition - 1 && data.y >= y && data.y <= windowHeightPosition) { - // 右侧 - flag = true; - } else if (global.direction == "left" && data.x <= workArea.x && data.y >= y && data.y <= windowHeightPosition) { - // 左侧 - flag = true; - } else if (global.direction == "bottom" && data.y >= windowHeightPosition - 1 && data.x >= x && data.x <= windowWidthPosition) { - // 底部 - flag = true; - } else if (global.direction == "top" && data.y <= workArea.y && data.x >= x && data.x <= windowWidthPosition) { - // 顶部 - flag = true; - } - if (flag) { - if (util.notDisturb()) { - return; - } - if (timer && global.setting.general.delayDisplayMS > 0 && global.autoHideTimer == null) { - global.autoHideTimer = setTimeout(function () { - // 显示 - mainWindow.show(); - if (!global.setting.general.alwaysTop) { - global.mainWindow.setAlwaysOnTop(true, "screen-saver"); - global.mainWindow.setAlwaysOnTop(false); - } - }, global.setting.general.delayDisplayMS); - } else if (global.setting.general.delayDisplayMS == 0 || !timer) { - // 显示 - mainWindow.show(); - if (!global.setting.general.alwaysTop) { - global.mainWindow.setAlwaysOnTop(true, "screen-saver"); - global.mainWindow.setAlwaysOnTop(false); - } - } - } else { - clearTimeout(global.autoHideTimer); - global.autoHideTimer = null; - } - } - } - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - global.mainWindow.setBounds({ x: 1, y: 1 }); - } -} - -/** - * 显示设置窗口 - */ -function showSettingWindow() { - if (settingWindow != null && !settingWindow.isDestroyed()) { - if (!settingWindow.isVisible()) { - settingWindow.show(); - } - settingWindow.focus(); - } else { - createSettingWindow(); - } -} - -app.whenReady().then(() => { - // 禁用debugtron - for (let i = 0; i < process.argv.length; i++) { - const arg = process.argv[i]; - if (arg.indexOf("--inspect") !== -1 || arg.indexOf("--remote-debugging-port") !== -1) { - dialog.showMessageBoxSync(global.mainWindow, { - title: "Dawn Launcher", - message: "达咩呦达咩达咩~", - buttons: ["确定"], - type: "error", - noLink: true, - }); - app.quit(); - return; - } - } - // 禁止多开 - const instanceLock = app.requestSingleInstanceLock(); - if (!instanceLock) { - app.quit(); - return; - } - // 设置快捷键 - let setting = settingData.get(); - settingIndex.setShortcutKey(setting); - // 引用c++ - try { - global.api = require("bindings")({ - bindings: "api.node", - module_root: process.env.NODE_ENV !== "production" ? path.resolve(".") : path.dirname(process.execPath), - }); - } catch (e) { - dialog.showMessageBoxSync(global.mainWindow, { - title: "Dawn Launcher", - message: "缺少DLL文件,请重新下载安装包,安装后运行。", - buttons: ["确定"], - type: "error", - noLink: true, - }); - app.quit(); - return; - } - // 创建窗口 - createWindow(true); -}); - -app.on("second-instance", (event, commandLine, workingDirectory) => { - if (mainWindow) { - if (!mainWindow.isVisible()) { - mainWindow.show(); - mainWindow.focus(); - global.blurHide = true; - } else { - mainWindow.focus(); - } - } -}); - -app.on("window-all-closed", () => { - // 释放鼠标监听 - global.api.disableMouseMove(); - if (process.platform !== "darwin") { - app.quit(); - } -}); - -app.on("activate", () => { - if (BrowserWindow.getAllWindows().length === 0) { - createWindow(false).then((r) => {}); - } -}); - -if (process.env.NODE_ENV === "production") { - // 开机启动 - const exeName = path.basename(process.execPath); - ipcMain.on("setAutoLaunch", (event, args) => { - app.setLoginItemSettings({ - openAtLogin: args, - openAsHidden: false, - path: process.execPath, - args: ["--processStart", `"${exeName}"`], - }); - }); -} - -// 设置当前语言 -ipcMain.on("setCurrentLanguage", (event, args) => { - let currentLanguage = JSON.parse(args); - global.currentLanguage = currentLanguage; - // 托盘菜单 - setTray(!global.setting.general.hideTray); -}); - -/** - * 托盘 - */ -function setTray(show) { - // 获取语言 - if (show) { - if (global.tray == null) { - // 环境判断 - if (process.env.NODE_ENV !== "production") { - // 开发 - global.tray = new Tray("./public/images/logo-thick.ico"); - } else { - // 正式 - global.tray = new Tray(path.join(__dirname, "./images/logo-thick.ico")); - } - } - let contextMenu = Menu.buildFromTemplate([ - { - label: global.currentLanguage.displayMainInterface, - click: function () { - mainWindow.show(); - global.blurHide = true; - }, - }, - { - label: global.currentLanguage.setting, - click: function () { - showSettingWindow(); - }, - }, - { - // 点击退出菜单退出程序 - label: global.currentLanguage.exit, - click: function () { - mainWindow.close(); - }, - }, - ]); - // 托盘 - global.tray.setToolTip("Dawn Launcher"); - global.tray.setContextMenu(contextMenu); - // 点击托盘图标,显示主窗口 - global.tray.on("click", () => { - mainWindow.show(); - global.blurHide = true; - }); - } else { - // 隐藏托盘 - if (global.tray != null) { - if (!global.tray.isDestroyed()) { - global.tray.destroy(); - global.tray = null; - } - } - } -} - -// 创建搜索窗口 -ipcMain.on("createSearchWindow", () => { - // 搜索框 - createSearchWindow(); -}); - -// 托盘 -ipcMain.on("setTray", (event, args) => { - setTray(args); -}); - -// 开启快捷搜索 -ipcMain.on("setEnableQuickSearch", (event, args) => { - // 设置快捷键 - let setting = settingData.get(); - setting.quickSearch.enable = args; - settingIndex.setShortcutKey(setting); -}); - -// 设置背景透明度 -ipcMain.on("setBackgroundTransparency", (event, args) => { - if ((Number(args) == 1 && global.backgroundTransparency) || (Number(args) != 1 && !global.backgroundTransparency)) { - mainWindow.destroy(); - global.mainWindow = mainWindow = null; - createWindow(false); - } -}); - -// 创建设置窗口 -ipcMain.on("createSettingWindow", (event, args) => { - showSettingWindow(); -}); - -// 显示搜索窗口 -ipcMain.on("searchWindowShow", (event, args) => { - if (args != null) { - searchWindow.setBounds({ height: args }); - } - searchWindow.show(); -}); diff --git a/src/main/mouse.js b/src/main/mouse.js deleted file mode 100644 index 8c4a857..0000000 --- a/src/main/mouse.js +++ /dev/null @@ -1,70 +0,0 @@ -"use strict"; -const { EventEmitter } = require("events"); -let paused = true; - -class MouseEvents extends EventEmitter { - constructor() { - super(); - if (require("os").platform() !== "win32") return; - let createdListener = false; - let registeredEvents = []; - this.on("newListener", (event) => { - if (registeredEvents.indexOf(event) !== -1) return; - // Enable WM_MOUSEMOVE capture if requested - if (event === "mousemove") { - global.api.enableMouseMove(); - } - if ((event === "mouseup" || event === "mousedown" || event === "mousemove" || event === "mousewheel") && !createdListener) { - // Careful: this currently "leaks" a thread every time it's called. - // We should probably get around to fixing that. - createdListener = global.api.createMouseHook((event, x, y, button, delta) => { - const payload = { x, y }; - if (event === "mousewheel") { - payload.delta = FromInt32(delta) / 120; - payload.axis = button; - } else if (event === "mousedown" || event === "mouseup") { - payload.button = button; - } - this.emit(event, payload); - }); - if (createdListener) { - this.resumeMouseEvents(); - } - } else { - return; - } - registeredEvents.push(event); - }); - this.on("removeListener", (event) => { - if (this.listenerCount(event) > 0) return; - registeredEvents = registeredEvents.filter((x) => x !== event); - if (event === "mousemove") { - global.api.disableMouseMove(); - } - }); - } - getPaused() { - return paused; - } - pauseMouseEvents() { - if (paused) return false; - paused = true; - return global.api.pauseMouseEvents(); - } - resumeMouseEvents() { - if (!paused) return false; - paused = false; - return global.api.resumeMouseEvents(); - } -} - -function FromInt32(x) { - var uint32 = x - Math.floor(x / 4294967296) * 4294967296; - if (uint32 >= 2147483648) { - return (uint32 - 4294967296) / 65536; - } else { - return uint32 / 65536; - } -} - -module.exports = new MouseEvents(); diff --git a/src/main/setting/data.js b/src/main/setting/data.js deleted file mode 100644 index 2ee89b3..0000000 --- a/src/main/setting/data.js +++ /dev/null @@ -1,516 +0,0 @@ -const Store = require("electron-store"); -const settingStore = new Store({ name: "setting", encryptionKey: "732b6562-c2dd-56c7-8fe9-ef3ed6646128", clearInvalidConfig: true }); -const store = new Store({ name: "data", encryptionKey: "0b52eb58-4c0f-5ff1-b062-031546a8d269", clearInvalidConfig: true }); - -module.exports = { - initData() { - let setting = store.get("setting"); - if (setting == null) { - let ss = settingStore.get("setting"); - if (ss == null) { - setting = { - general: { - // 开机启动 - startup: false, - // 启动后最小化到系统托盘 - startupTray: false, - // 显示/隐藏快捷键 - showHideShortcutKey: null, - // 语言 - language: "chinese", - // 永远置顶 - alwaysTop: false, - // 停靠在桌面边缘时自动隐藏 - edgeAutoHide: true, - // 锁定尺寸 - lockSize: false, - // 失去焦点后隐藏 - hideLosingFocus: false, - // 隐藏托盘图标 - hideTray: false, - // 中间单击 - showHideMouseWheelClick: false, - // 固定位置 - fixedPosition: false, - // 永远居中 - alwaysCenter: false, - // 显示时跟随鼠标位置 - showFollowMousePosition: false, - // 隐藏任务栏 - hideTaskbar: false, - // 勿扰模式 - notDisturb: false, - // 双击任务栏 - doubleClickTaskbar: false, - // 延迟显示(毫秒) - delayDisplayMS: 0, - // 延迟隐藏(毫秒) - delayHidingMS: 0, - // 显示窗口时将输入法切换为英文模式 - switchEnglish: false, - }, - appearance: { - // 主题 - theme: { - name: "#FFFFFF", - fontBasic: "#505050", - fontHover: "#FFFFFF", - mainBackground: "#FFFFFF", - minorBackground: "#999999", - border: "#F0F0F0", - }, - // 窗口透明度 - transparency: 1, - // 背景透明度 - backgroundTransparency: 1, - // 使用字体阴影 - useFontShadow: false, - // 文字阴影 - fontShadow: "#000000", - // 背景图 - backgroundImage: null, - // 背景图模式 - backgroundImageMode: "repeat", - // 背景图定位 - backgroundImagePosition: "default", - // 背景图透明度 - backgroundImageTransparency: 1, - // 窗口圆角 - windowRoundedCorners: false, - // 标题 - title: "Dawn Launcher", - }, - classification: { - // 宽度 - width: 140, - // 布局 - layout: "left", - // 鼠标悬停切换 - mouseHover: false, - // 悬停毫秒 - mouseHoverMS: 1000, - // 滚轮切换 - mouseWheel: false, - // 记住选择状态 - rememberSelectionState: false, - // 名称对齐 - nameAlign: "left", - // 模式 - mode: "normal", - // 项目列表滚动到底部或顶部时自动切换分类 - autoSwitchClassification: false, - // 隐藏窗口时折叠子分类 - hideWindowFoldChildClassification: false, - // 切换分类时收起其他子分类 - switchClassificationCollapseOtherSubClassification: false, - }, - item: { - // 布局 - layout: "tile", - // 图标大小 - iconSize: 40, - // 搜索快捷键 - searchShortcutKey: "TAB", - // 双击运行项目 - doubleClickRunItem: false, - // 打开后隐藏主界面 - openAfterHideMainInterface: false, - // 从程序外拖动文件到项目图标上时用此项目打开文件 - useItemOpen: false, - // 记录打开次数 - openNumber: false, - // 隐藏项目名称 - hideItemName: false, - // 隐藏省略号 - hideEllipsis: false, - // 项目名称行数 - itemNameRowCount: 2, - // 宽度 - width: 100, - // 列数 单列多列 - columnNumber: 1, - // 检测无效项目 - checkInvalidItem: true, - // 字体大小 - fontSize: 14, - // 字体粗细 - fontWeight: 400, - // 字体行高 - fontLineHeight: 1.25, - }, - quickSearch: { - // 开启 - enable: true, - // 快捷键 - showHideShortcutKey: "Alt + Enter", - // 打开快捷键 - openShortcutKey: "none", - // 失去焦点后隐藏 - hideLosingFocus: false, - // 仅剩一项时立即打开 - openNow: false, - // 显示历史记录 - showHistory: false, - // 历史记录排序 - showHistorySort: "lastOpen", - // 从程序外拖动文件到项目图标上时用此项目打开文件 - useItemOpen: false, - // 打开后隐藏快速搜索窗口 - openAfterHideQuickSearchWindow: true, - // 匹配条件 - matchingConditionsRemark: false, - }, - webSearch: { - // 模式 - mode: 0, - // 搜索源 - searchSourceList: [ - { - id: 1, - keyword: "g", - name: "Google", - URL: "https://www.google.com/search?q={w}", - }, - { - id: 2, - keyword: "b", - name: "Baidu", - URL: "https://www.baidu.com/s?wd={w}", - }, - { - id: 3, - keyword: "bing", - name: "Bing", - URL: "https://cn.bing.com/search?q={w}", - }, - { - id: 4, - keyword: "so", - name: "360", - URL: "https://www.so.com/s?q={w}", - }, - { - id: 5, - keyword: "sogou", - name: "Sogou", - URL: "https://www.sogou.com/web?query={w}", - }, - ], - }, - network: { - // 使用代理 - useProxy: false, - // 代理信息 - proxy: { - // address - address: null, - // 用户名 - username: null, - // 密码 - password: null, - }, - }, - // 子分类 - subClassification: { - // 名称字体(项目区域) - itemAreaNameFontSize: 14, - // 名称粗细(项目区域) - itemAreaNameFontWeight: 700, - // 名称字体行高(项目区域) - itemAreaNameFontLineHeight: 1.25, - }, - }; - } else { - setting = ss; - } - } - if (setting.general.language == null) { - setting.general.language = "chinese"; - } - if (setting.general.alwaysTop == null) { - setting.general.alwaysTop = false; - } - if (setting.general.fixedPosition == null) { - setting.general.fixedPosition = false; - } - if (setting.general.alwaysCenter == null) { - setting.general.alwaysCenter = false; - } - if (setting.general.showFollowMousePosition == null) { - setting.general.showFollowMousePosition = false; - } - if (setting.general.edgeAutoHide == null) { - setting.general.edgeAutoHide = true; - } - if (setting.general.startupTray == null) { - setting.general.startupTray = false; - } - if (setting.general.lockSize == null) { - setting.general.lockSize = false; - } - if (setting.general.hideLosingFocus == null) { - setting.general.hideLosingFocus = false; - } - if (setting.general.hideTray == null) { - setting.general.hideTray = false; - } - if (setting.general.showHideMouseWheelClick == null) { - setting.general.showHideMouseWheelClick = false; - } - if (setting.general.hideTaskbar == null) { - setting.general.hideTaskbar = false; - } - if (setting.general.notDisturb == null) { - setting.general.notDisturb = false; - } - if (setting.general.doubleClickTaskbar == null) { - setting.general.doubleClickTaskbar = false; - } - if (setting.general.delayDisplayMS == null) { - setting.general.delayDisplayMS = 0; - } - if (setting.general.delayHidingMS == null) { - setting.general.delayHidingMS = 0; - } - if (setting.general.switchEnglish == null) { - setting.general.switchEnglish = false; - } - if (setting.item.layout == null) { - setting.item.layout = "tile"; - } - if (setting.item.iconSize == null) { - setting.item.iconSize = 40; - } - if (setting.item.openAfterHideMainInterface == null) { - setting.item.openAfterHideMainInterface = false; - } - if (setting.item.useItemOpen == null) { - setting.item.useItemOpen = false; - } - if (setting.item.openNumber == null) { - setting.item.openNumber = false; - } - if (setting.item.hideItemName == null) { - setting.item.hideItemName = false; - } - if (setting.item.hideEllipsis == null) { - setting.item.hideEllipsis = false; - } - if (setting.item.itemNameRowCount == null) { - setting.item.itemNameRowCount = 2; - } - if (setting.item.width == null) { - setting.item.width = 100; - } - if (setting.item.columnNumber == null) { - setting.item.columnNumber = 1; - } else if (setting.item.columnNumber != null && setting.item.columnNumber == "single") { - setting.item.columnNumber = 1; - } else if (setting.item.columnNumber != null && setting.item.columnNumber == "multiple") { - setting.item.columnNumber = 2; - } - if (setting.item.checkInvalidItem == null) { - setting.item.checkInvalidItem = true; - } - if (setting.item.fontSize == null) { - setting.item.fontSize = 14; - } - if (setting.item.fontWeight == null) { - setting.item.fontWeight = 400; - } - if (setting.item.fontLineHeight == null) { - setting.item.fontLineHeight = 1.25; - } - if (setting.classification == null) { - setting.classification = {}; - } - if (setting.classification.width == null) { - setting.classification.width = 140; - } - if (setting.classification.layout == null) { - setting.classification.layout = "left"; - } - if (setting.classification.mouseHover == null) { - setting.classification.mouseHover = false; - } - if (setting.classification.mouseHoverMS == null) { - setting.classification.mouseHoverMS = 1000; - } - if (setting.classification.mouseWheel == null) { - setting.classification.mouseWheel = false; - } - if (setting.classification.rememberSelectionState == null) { - setting.classification.rememberSelectionState = false; - } - if (setting.classification.nameAlign == null) { - setting.classification.nameAlign = "left"; - } - if (setting.classification.mode == null) { - setting.classification.mode = "normal"; - } - if (setting.classification.autoSwitchClassification == null) { - setting.classification.autoSwitchClassification = false; - } - if (setting.classification.hideWindowFoldChildClassification == null) { - setting.classification.hideWindowFoldChildClassification = false; - } - if (setting.classification.switchClassificationCollapseOtherSubClassification == null) { - setting.classification.switchClassificationCollapseOtherSubClassification = false; - } - if (setting.appearance.theme.name.toUpperCase() == "#FFFFFF") { - setting.appearance.theme = { - name: "#FFFFFF", - fontBasic: "#505050", - fontHover: "#FFFFFF", - mainBackground: "#FFFFFF", - minorBackground: "#999999", - border: "#F0F0F0", - }; - } - if (setting.appearance.theme.name.toUpperCase() == "#2B2B2B") { - setting.appearance.theme = { - name: "#2B2B2B", - fontBasic: "#BBBBBB", - fontHover: "#BBBBBB", - mainBackground: "#2B2B2B", - minorBackground: "#3C3F41", - border: "#3C3F41", - }; - } - if (setting.appearance.transparency == null) { - setting.appearance.transparency = 1; - } - if (setting.appearance.backgroundTransparency == null) { - setting.appearance.backgroundTransparency = 1; - } - if (setting.appearance.useFontShadow == null) { - setting.appearance.useFontShadow = false; - } - if (setting.appearance.fontShadow == null) { - setting.appearance.fontShadow = "#000000"; - } - if (setting.appearance.backgroundImageMode == null) { - setting.appearance.backgroundImageMode = "repeat"; - } - if (setting.appearance.backgroundImagePosition == null) { - setting.appearance.backgroundImagePosition = "default"; - } - if (setting.appearance.backgroundImageTransparency == null) { - setting.appearance.backgroundImageTransparency = 1; - } - if (setting.appearance.windowRoundedCorners == null) { - setting.appearance.windowRoundedCorners = false; - } - if (setting.appearance.title == null) { - setting.appearance.title = "Dawn Launcher"; - } - if (setting.quickSearch == null) { - setting.quickSearch = {}; - } - if (setting.quickSearch.enable == null) { - setting.quickSearch.enable = true; - } - if (setting.quickSearch.showHideShortcutKey == null) { - setting.quickSearch.showHideShortcutKey = "Alt + Enter"; - } - if (setting.quickSearch.openShortcutKey == null) { - setting.quickSearch.openShortcutKey = "none"; - } - if (setting.quickSearch.hideLosingFocus == null) { - setting.quickSearch.hideLosingFocus = false; - } - if (setting.quickSearch.openNow == null) { - setting.quickSearch.openNow = false; - } - if (setting.quickSearch.showHistory == null) { - setting.quickSearch.showHistory = false; - } - if (setting.quickSearch.showHistorySort == null) { - setting.quickSearch.showHistorySort = "lastOpen"; - } - if (setting.quickSearch.useItemOpen == null) { - setting.quickSearch.useItemOpen = false; - } - if (setting.quickSearch.openAfterHideQuickSearchWindow == null) { - setting.quickSearch.openAfterHideQuickSearchWindow = true; - } - if (setting.quickSearch.matchingConditionsRemark == null) { - setting.quickSearch.matchingConditionsRemark = false; - } - if (setting.webSearch == null) { - setting.webSearch = {}; - } - if (setting.webSearch.mode == null) { - setting.webSearch.mode = 0; - } - if (setting.webSearch.searchSourceList == null || setting.webSearch.searchSourceList.length == 0) { - setting.webSearch.searchSourceList = [ - { - id: 1, - keyword: "g", - name: "Google", - URL: "https://www.google.com/search?q={w}", - }, - { - id: 2, - keyword: "b", - name: "Baidu", - URL: "https://www.baidu.com/s?wd={w}", - }, - { - id: 3, - keyword: "bing", - name: "Bing", - URL: "https://cn.bing.com/search?q={w}", - }, - { - id: 4, - keyword: "so", - name: "360", - URL: "https://www.so.com/s?q={w}", - }, - { - id: 5, - keyword: "sogou", - name: "Sogou", - URL: "https://www.sogou.com/web?query={w}", - }, - ]; - } - if (setting.network == null) { - setting.network = {}; - } - if (setting.network.useProxy == null) { - setting.network.useProxy = false; - } - if (setting.subClassification == null) { - setting.subClassification = {}; - } - if (setting.subClassification.itemAreaNameFontSize == null) { - setting.subClassification.itemAreaNameFontSize = 14; - } - if (setting.subClassification.itemAreaNameFontWeight == null) { - setting.subClassification.itemAreaNameFontWeight = 700; - } - if (setting.subClassification.itemAreaNameFontLineHeight == null) { - setting.subClassification.itemAreaNameFontLineHeight = 1.25; - } - this.set(setting); - global.setting = setting; - }, - /** - * get - */ - get() { - this.initData(); - return store.get("setting"); - }, - /** - * set - * @param setting - */ - set(setting) { - store.set("setting", setting); - global.setting = setting; - }, -}; diff --git a/src/main/setting/index.js b/src/main/setting/index.js deleted file mode 100644 index 9d9cbde..0000000 --- a/src/main/setting/index.js +++ /dev/null @@ -1,149 +0,0 @@ -import { globalShortcut } from "electron"; -import path from "path"; -import util from "../util"; -import itemJS from "../item/index"; -import ClassificationJS from "../classification/index"; - -/** - * 设置快捷键 - * @param setting - */ -function setShortcutKey(setting) { - // 取消所有快捷键 - globalShortcut.unregisterAll(); - if (setting != null) { - // 设置快捷键 - if (setting.general != null) { - if (!util.strIsEmpty(setting.general.showHideShortcutKey)) { - globalShortcut.register(setting.general.showHideShortcutKey, () => { - if (util.notDisturb()) { - return; - } - if (global.mainWindow.isVisible()) { - // global.mainWindow.hide(); - global.mainWindow.webContents.send("hideMainWindowBefore"); - } else { - util.showFollowMousePosition(); - global.mainWindow.show(); - global.mainWindow.focus(); - global.blurHide = true; - } - }); - } - } - if (setting.quickSearch != null) { - if (setting.quickSearch.enable && !util.strIsEmpty(setting.quickSearch.showHideShortcutKey)) { - globalShortcut.register(setting.quickSearch.showHideShortcutKey, () => { - if (util.notDisturb()) { - return; - } - if (global.searchWindow != null && global.searchWindowShow) { - if (global.searchWindow.isVisible()) { - global.searchWindow.webContents.send("hideSearchWindowBefore"); - } else { - let params = { - setting: global.setting, - list: global.list, - }; - global.searchWindow.webContents.send("showSearchWindowOperation", JSON.stringify(params)); - } - } - }); - } - } - // 扫描有没有全局快捷键分类、项目 - if (!util.arrayIsEmpty(global.list)) { - let itemList = []; - let classificationList = []; - for (let c of global.list) { - if (c.globalShortcutKey && !util.strIsEmpty(c.shortcutKey)) { - classificationList.push(c); - } - if (!util.arrayIsEmpty(c.childList)) { - for (let cc of c.childList) { - if (cc.globalShortcutKey && !util.strIsEmpty(cc.shortcutKey)) { - classificationList.push(cc); - } - if (!util.arrayIsEmpty(cc.itemList)) { - for (let item of cc.itemList) { - if (item.globalShortcutKey && !util.strIsEmpty(item.shortcutKey)) { - itemList.push(item); - } - } - } - } - } else { - if (!util.arrayIsEmpty(c.itemList)) { - for (let item of c.itemList) { - if (item.globalShortcutKey && !util.strIsEmpty(item.shortcutKey)) { - itemList.push(item); - } - } - } - } - } - // 设置快捷键 - for (let item of itemList) { - globalShortcut.register(item.shortcutKey, () => { - if (util.notDisturb()) { - return; - } - if (item.type == 4) { - if (!util.arrayIsEmpty(item.itemList)) { - for (let iItem of item.itemList) { - itemJS.itemRun(iItem, null, null); - } - } - } else { - itemJS.itemRun(item, null, null); - } - }); - } - for (let classification of classificationList) { - globalShortcut.register(classification.shortcutKey, () => { - if (util.notDisturb()) { - return; - } - if (global.mainWindow != null && !global.mainWindow.isDestroyed()) { - if (!global.mainWindow.isVisible()) { - global.mainWindow.show(); - global.mainWindow.focus(); - global.blurHide = true; - if (!global.setting.general.alwaysTop) { - global.mainWindow.setAlwaysOnTop(true, "screen-saver"); - global.mainWindow.setAlwaysOnTop(false); - } - } - let { classificationParentId, classificationChildId } = ClassificationJS.convertClassificationId(classification.id, classification.parentId); - let params = { - classificationParentId: classificationParentId, - classificationChildId: classificationChildId, - }; - global.mainWindow.webContents.send("changeClassification", JSON.stringify(params)); - } - }); - } - } - } -} - -/** - * 获取数据目录配置文件地址 - * @returns {string} - */ -function getDawnLauncherProfilePath() { - let p; - if (process.env.NODE_ENV !== "production") { - p = path.resolve("."); - } else { - p = path.dirname(process.execPath); - } - p = path.resolve(p, ".."); - p = path.join(p, ".dawn_launcher_profile"); - return p; -} - -export default { - setShortcutKey, - getDawnLauncherProfilePath, -}; diff --git a/src/main/setting/ipcEvent.js b/src/main/setting/ipcEvent.js deleted file mode 100644 index ba3348e..0000000 --- a/src/main/setting/ipcEvent.js +++ /dev/null @@ -1,162 +0,0 @@ -import { app, dialog, ipcMain } from "electron"; -import data from "./data"; -import index from "./index"; -import util from "../util"; -import fs from "fs"; -import path from "path"; - -/** - * 判断路径是否一样 - * @param currentAppDataPath - * @param profileAppDataPath - */ -function pathIsEqual(currentAppDataPath, profileAppDataPath) { - let c = path.normalize(currentAppDataPath); - let p = path.normalize(profileAppDataPath); - return c == p; -} - -export default function () { - // 获取数据 - ipcMain.on("getSetting", (event, args) => { - event.returnValue = data.get(); - }); - // set数据 - ipcMain.on("setSetting", (event, args) => { - let params = JSON.parse(args); - // 保存数据 - data.set(params.setting); - // 需要通知 - if (params.other.main) { - if (global.mainWindow != null) { - global.mainWindow.webContents.send("mainWindowGetData"); - } - } - if (params.other.search) { - if (global.searchWindow != null && !global.searchWindow.isDestroyed() && global.searchWindow.isVisible()) { - global.searchWindow.webContents.send("searchWindowGetData"); - global.searchWindow.setBackgroundColor(global.setting.appearance.theme.mainBackground.replace("bg-[", "").replace("]", "")); - } - } - if (params.other.setting) { - if (global.settingWindow != null && !global.settingWindow.isDestroyed() && global.settingWindow.isVisible()) { - global.settingWindow.webContents.send("settingWindowGetData"); - } - } - }); - // 设置快捷键 - ipcMain.on("setShortcutKey", (event, args) => { - let setting = JSON.parse(args); - index.setShortcutKey(setting); - }); - // 设置启动后最小化到系统托盘 - ipcMain.on("setStartupTray", (event, args) => { - if (args) { - util.edgeAdsorb(); - } - }); - // 获取数据目录 - ipcMain.on("getAppDataPath", (event, args) => { - try { - // 获取数据目录配置文件地址 - let p = index.getDawnLauncherProfilePath(); - // 读取文件 - let r = fs.readFileSync(p); - event.returnValue = r.toString(); - } catch (e) { - event.returnValue = app.getPath("appData"); - } - }); - // 选择用户数据目录 - ipcMain.on("chooseDataDirectory", (event, args) => { - dialog.showOpenDialog(global.settingWindow, { properties: ["openDirectory"] }).then((r) => { - if (r.filePaths.length > 0) { - event.returnValue = r.filePaths[0]; - } else { - event.returnValue = null; - } - }); - }); - // 提示切换数据目录 - ipcMain.on("promptChangeDataDirectory", (event, args) => { - dialog - .showMessageBox(global.mainWindow, { - message: global.currentLanguage.modifyDataDirectoryMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "question", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - // 获取数据目录配置文件地址 - let p = index.getDawnLauncherProfilePath(); - if (util.strIsEmpty(args)) { - try { - let profile = fs.readFileSync(p); - // 路径不一样的话,开始移动和删除文件 - if (!pathIsEqual(global.defaultAppDataPath, profile.toString())) { - try { - // 删除默认路径下的文件 - fs.rmdirSync(global.defaultAppDataPath + "\\Dawn Launcher"); - } catch (e) {} - try { - // 将现在文件夹的内容移动到默认路径下 - fs.cpSync(profile.toString() + "\\Dawn Launcher", global.defaultAppDataPath + "\\Dawn Launcher", { recursive: true }); - } catch (e) {} - } - // 删除配置数据目录文件 - try { - fs.rmSync(p); - } catch (e) {} - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } - } else { - try { - // 写入内容 - fs.writeFileSync(p, args); - try { - // 删除写入内容文件夹 - fs.rmdirSync(args + "\\Dawn Launcher"); - } catch (e) {} - try { - // 将现有文件夹内容移动到写入文件夹内容 - fs.cpSync(app.getPath("appData") + "\\Dawn Launcher", args + "\\Dawn Launcher", { recursive: true }); - } catch (e) {} - } catch (e) {} - } - app.relaunch(); - app.exit(); - } - }); - }); - // 拷贝背景图 - ipcMain.on("copyBackgroundImage", (event, args) => { - let parsedPath = path.parse(args); - let destPath = app.getPath("userData") + "\\images"; - let name = "backgroundImage" + parsedPath.ext; - try { - fs.statSync(destPath); - } catch (e) { - fs.mkdirSync(destPath); - } - try { - fs.copyFileSync(args, destPath + "\\" + name); - event.returnValue = name; - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - event.returnValue = null; - } - }); - // 关闭设置窗口 - ipcMain.on("closeSettingWindow", (event, args) => { - if (global.settingWindow != null && !global.settingWindow.isDestroyed()) { - global.settingWindow.close(); - } - }); -} diff --git a/src/main/util.js b/src/main/util.js deleted file mode 100644 index 3fd8754..0000000 --- a/src/main/util.js +++ /dev/null @@ -1,297 +0,0 @@ -import { screen, nativeImage, nativeTheme, app, dialog, shell } from "electron"; -import request from "request"; -import retry from "retry"; -import cacheData from "./cache/data"; - -/** - * 边缘吸附 - */ -function edgeAdsorb(display) { - if (global.mainWindow.isDestroyed()) { - return; - } - try { - global.direction = "none"; - let displays = display != null ? [display] : this.getWindowInScreen(); - if (displays.length > 1 || displays.length == 0) { - return; - } - let workArea = displays[0].workArea; - let bounds = global.mainWindow.getBounds(); - if (bounds.x + bounds.width >= workArea.x + workArea.width) { - // 右侧 - global.mainWindow.setBounds({ x: workArea.x + workArea.width - bounds.width }); - global.direction = "right"; - global.blurHide = null; - } else if (bounds.x <= workArea.x) { - // 左侧 - global.mainWindow.setBounds({ x: workArea.x }); - global.direction = "left"; - global.blurHide = null; - } - if (bounds.y + bounds.height >= workArea.y + workArea.height) { - // 底部 - global.mainWindow.setBounds({ y: workArea.y + workArea.height - bounds.height }); - global.direction = "bottom"; - global.blurHide = null; - } else if (bounds.y <= workArea.y) { - // 顶部 - global.mainWindow.setBounds({ y: workArea.y }); - global.direction = "top"; - global.blurHide = null; - } - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - global.mainWindow.setBounds({ x: 1, y: 1 }); - } -} - -/** - * 获取图标点 - * @returns {Electron.NativeImage} - */ -function getDot() { - return nativeImage.createFromDataURL( - !nativeTheme.shouldUseDarkColors - ? "" - : "" - ); -} - -/** - * 显示时跟随鼠标位置 - */ -function showFollowMousePosition() { - if (!global.setting.general.alwaysCenter && !global.setting.general.fixedPosition && global.setting.general.showFollowMousePosition) { - // 获取鼠标位置 - let point = screen.getCursorScreenPoint(); - // 获取窗口大小 - let bounds = global.mainWindow.getBounds(); - let x = Math.round(bounds.width / 2); - let y = Math.round(bounds.height / 2); - global.mainWindow.setPosition(point.x - x, point.y - y) - for (let i = 0; i < 10; i++) { - global.mainWindow.setSize(bounds.width, bounds.height) - } - // 获取当前鼠标所在屏幕 - let display = screen.getDisplayNearestPoint(point); - // 边缘吸附 - edgeAdsorb(display); - } -} - -/** - * 获取窗口所在的屏幕 - */ -function getWindowInScreen() { - let inDisplays = []; - let displays = screen.getAllDisplays(); - let bounds = global.mainWindow.getBounds(); - for (let display of displays) { - let workArea = display.workArea; - if ( - ((workArea.x <= bounds.x && workArea.x + workArea.width >= bounds.x) || - (workArea.x <= bounds.x + bounds.width && workArea.x + workArea.width >= bounds.x + bounds.width)) && - ((workArea.y <= bounds.y && workArea.y + workArea.height >= bounds.y) || - (workArea.y <= bounds.y + bounds.height && workArea.y + workArea.height >= bounds.y + bounds.height)) - ) { - inDisplays.push(display); - } - } - return inDisplays; -} - -/** - * 去掉后缀 - * @param name - */ -function removeSuffix(name) { - if (name != null && name.trim() != "") { - let arr = name.split("."); - if (arr.length > 1) { - let n = name.substring(0, name.lastIndexOf(".")); - if (n.trim() != "") { - name = n; - } - } - } - return name; -} - -/** - * 获取后缀 - * @param name - */ -function getSuffix(name) { - let suffix = ""; - if (name != null && name.trim() != "") { - let arr = name.split("."); - if (arr.length > 1) { - suffix = name.substring(name.lastIndexOf(".") + 1); - } - } - return suffix.toLowerCase(); -} - -/** - * 勿扰模式 - */ -function notDisturb() { - return global.setting.general.notDisturb && global.api.IsFullscreen(); -} - -/** - * 检查更新 - */ -function checkUpdate(type) { - try { - // 重试 - const operation = retry.operation({ - retries: 5, // 最多重试 5 次 - factor: 1, // 每次重试之间的时间间隔加倍 - minTimeout: 1000, // 第一次重试之前等待的时间 - maxTimeout: 5000, // 最长等待时间 - }); - // 发起请求 - operation.attempt((currentAttempt) => { - request( - { - uri: "https://dawnlauncher.com/version.json", - timeout: 5000, - }, - function (error, response, body) { - if (operation.retry(error)) { - return; - } - if (!error && response.statusCode == 200) { - let buffer = Buffer.from(body); - let json = JSON.parse(buffer.toString()); - if (json.version != app.getVersion()) { - if (type == "init") { - dialog - .showMessageBox(global.mainWindow, { - message: global.currentLanguage.checkForUpdatesNewVersionMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel, global.currentLanguage.notPrompt], - type: "info", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - shell.openExternal("https://dawnlauncher.com/"); - } else if (r.response == 2) { - cacheData.cacheStore.set("checkUpdate", false); - } - }); - } else { - dialog - .showMessageBox(global.mainWindow, { - message: global.currentLanguage.checkForUpdatesNewVersionMessage, - buttons: [global.currentLanguage.ok, global.currentLanguage.cancel], - type: "info", - noLink: true, - cancelId: 1, - }) - .then((r) => { - if (r.response == 0) { - shell.openExternal("https://dawnlauncher.com/"); - } - }); - } - } else { - if (type == "checkUpdate") { - dialog.showMessageBox(global.mainWindow, { - message: global.currentLanguage.checkForUpdatesLatestVersionMessage, - buttons: [global.currentLanguage.ok], - type: "info", - noLink: true, - }); - } - } - } else { - if (type == "checkUpdate") { - dialog.showMessageBox(global.mainWindow, { - message: global.currentLanguage.checkForUpdatesFailedMessage, - buttons: [global.currentLanguage.ok], - type: "error", - noLink: true, - }); - } - } - } - ); - }); - } catch (e) { - if (process.env.NODE_ENV !== "production") { - console.log(e); - } - } -} - -/** - * 判断数组是否等于空 - * @param arr - */ -function arrayIsEmpty(arr) { - if (arr == null || arr.length == 0) { - return true; - } - return false; -} - -/** - * 判断字符串是否为空 - * @param str - */ -function strIsEmpty(str) { - if (str == null || str.trim() == "") { - return true; - } - return false; -} - -/** - * 菜单监听 - * @param menu - */ -function menuListen(menu) { - menu.on("menu-will-show", () => { - global.menuShow = true; - }); - menu.on("menu-will-close", () => { - global.menuShow = false; - }); -} - -/** - * 获取Key - * @param classificationParentId - * @param classificationChildId - * @param itemId - * @returns {*} - */ -function getKey(classificationParentId, classificationChildId, itemId) { - let key = classificationParentId; - if (classificationChildId != null) { - key += "-" + classificationChildId; - } - key += "-" + itemId; - return key; -} - -export default { - edgeAdsorb, - getDot, - showFollowMousePosition, - getWindowInScreen, - removeSuffix, - notDisturb, - checkUpdate, - getSuffix, - arrayIsEmpty, - strIsEmpty, - menuListen, - getKey, -}; diff --git a/src/pages/about/Index.vue b/src/pages/about/Index.vue new file mode 100644 index 0000000..68b40d2 --- /dev/null +++ b/src/pages/about/Index.vue @@ -0,0 +1,85 @@ + + diff --git a/src/pages/classification/AddEdit.vue b/src/pages/classification/AddEdit.vue new file mode 100644 index 0000000..9a7728b --- /dev/null +++ b/src/pages/classification/AddEdit.vue @@ -0,0 +1,216 @@ + + +../../../types/classification diff --git a/src/pages/classification/Aggregate.vue b/src/pages/classification/Aggregate.vue new file mode 100644 index 0000000..3375c38 --- /dev/null +++ b/src/pages/classification/Aggregate.vue @@ -0,0 +1,213 @@ + + +./js/classification ../../../types/classification diff --git a/src/pages/classification/AssociateFolder.vue b/src/pages/classification/AssociateFolder.vue new file mode 100644 index 0000000..5132256 --- /dev/null +++ b/src/pages/classification/AssociateFolder.vue @@ -0,0 +1,224 @@ + + +./js/classification ../../../types/classification diff --git a/src/pages/classification/SetIcon.vue b/src/pages/classification/SetIcon.vue new file mode 100644 index 0000000..08cc311 --- /dev/null +++ b/src/pages/classification/SetIcon.vue @@ -0,0 +1,12354 @@ + + diff --git a/src/pages/classification/components/Content.vue b/src/pages/classification/components/Content.vue new file mode 100644 index 0000000..a6ec13c --- /dev/null +++ b/src/pages/classification/components/Content.vue @@ -0,0 +1,1403 @@ + + +../../../../types/classification diff --git a/src/pages/classification/js/index.ts b/src/pages/classification/js/index.ts new file mode 100644 index 0000000..0361ce2 --- /dev/null +++ b/src/pages/classification/js/index.ts @@ -0,0 +1,381 @@ +import { Classification } from "../../../../types/classification"; +import { useMainStore } from "../../../store"; +import { + deleteItemByClassificationId, + moveItemByClassificationId, +} from "../../item/js"; + +// pinia +const store = useMainStore(); + +/** + * 转换分类列表 + */ +function convertClassificationList( + classificationList: Array +): Array { + // 获取父级 + let parentList = classificationList.filter((c) => !c.parentId); + // 获取子级 + let childList = classificationList.filter((c) => c.parentId); + // 关联父子级 + for (let parent of parentList) { + for (const child of childList) { + if (parent.id === child.parentId) { + if (!parent.childList) { + parent.childList = []; + } + parent.childList.push(child); + } + } + } + return parentList; +} + +/** + * 根据ID查询分类 + */ +function getClassificationById(id: number): Classification | null { + for (let classification of store.classificationList) { + if (classification.id === id) { + return classification; + } else { + if (classification.childList) { + for (let childClassification of classification.childList) { + if (childClassification.id === id) { + return childClassification; + } + } + } + } + } + return null; +} + +/** + * 添加分类 + */ +function addClassification(classification: Classification) { + // 判断是否是子级分类 + if (!classification.parentId) { + // 父级 添加 + store.classificationList.push(classification); + } else { + // 子级 + // 寻找父级分类 + let parentClassification = getClassificationById(classification.parentId); + if (parentClassification) { + if (!parentClassification.childList) { + parentClassification.childList = []; + } + // 添加 + parentClassification.childList.push(classification); + // 将父级项目移动到子级 + moveItemByClassificationId(classification.parentId, classification.id); + } + } +} + +/** + * 更新分类 + * @param classification + */ +function updateClassification(classification: Classification) { + // 查询分类 + let curClassification = getClassificationById(classification.id); + // 更新字段 + if (curClassification) { + curClassification.name = classification.name; + curClassification.type = classification.type; + curClassification.data = classification.data; + curClassification.shortcutKey = classification.shortcutKey; + curClassification.globalShortcutKey = classification.globalShortcutKey; + } +} + +/** + * 删除分类 + * @param id + */ +function deleteClassification(id: number) { + // func + const del = (list: Array, id: number) => { + // index + let index: number | null = null; + // 当前分类 + let classification: Classification | null = null; + // 寻找需要删除的分类下标 + for (let i = 0; i < list.length; i++) { + if (list[i].id === id) { + // 下标 + index = i; + classification = list[i]; + break; + } + } + if (index !== null && classification) { + // 删除 + list.splice(index, 1); + // 删除项目 + deleteItemByClassificationId(id); + // 如果有子分类,删除子分类下所有项目 + if (classification.childList && classification.childList.length > 0) { + for (const child of classification.childList) { + deleteItemByClassificationId(child.id); + } + } + // 更新分类序号 + for (let i = 0; i < list.length; i++) { + list[i].order = i + 1; + } + } + }; + // 查询分类 + let classification = getClassificationById(id); + if (classification) { + // 是否有父级,如果有父级就先寻找父级,在父级列表中删除当前子分类 + if (classification.parentId) { + let parentClassification = getClassificationById(classification.parentId); + if ( + parentClassification && + parentClassification.childList && + parentClassification.childList.length > 0 + ) { + del(parentClassification.childList, id); + } + } else { + del(store.classificationList, id); + } + } +} + +/** + * 判断分类是否有子分类 + * @param id + * @returns + */ +function hasChildClassification(id: number | null): boolean { + if (id) { + let classification = getClassificationById(id); + if ( + classification && + classification.childList && + classification.childList.length > 0 + ) { + return true; + } + } + return false; +} + +/** + * 查询子分类列表 + * @param id + * @returns + */ +function getClassificationChildList(id: number | null): Array { + if (id) { + let classification = getClassificationById(id); + if ( + classification && + classification.childList && + classification.childList.length > 0 + ) { + return classification.childList; + } + } + return []; +} + +/** + * 分类排序 + * @param fromId + * @param toId + * @param parentId + */ +function updateClassificationOrder( + fromId: number, + toId: number | null, + parentId: number | null +) { + // update + const update = ( + list: Array, + id: number, + newOrder: number, + oldOrder: number + ) => { + // 当前分类 + let currentClassification = getClassificationById(id); + if (currentClassification) { + // 更新序号 + currentClassification.order = newOrder; + // 判断新序号和老序号之间的数据是+1还是-1 + for (let classification of list) { + if (newOrder > oldOrder) { + if ( + classification.order > oldOrder && + classification.order <= newOrder && + classification.id !== id + ) { + classification.order = classification.order - 1; + } + } else { + if ( + classification.order >= newOrder && + classification.order < oldOrder && + classification.id !== id + ) { + classification.order = classification.order + 1; + } + } + } + // 重新排序 + list.sort((a, b) => a.order - b.order); + } + }; + // 查询来源分类 + let fromClassification = getClassificationById(fromId); + if (fromClassification) { + // 新序号 + let newOrder: number | null = null; + // 如果目标ID不为空获取项目并获取序号 + if (toId) { + let toClassificationId = getClassificationById(toId); + if (toClassificationId) { + newOrder = toClassificationId.order; + } + } + if (!newOrder) { + // 查询最大序号 + let classificationList = parentId + ? getClassificationChildList(parentId) + : store.classificationList; + if (classificationList.length === 0) { + newOrder = 1; + } else { + newOrder = classificationList[classificationList.length - 1].order + 1; + } + } + // 父级分类ID不为空先查询父级分类 + if (parentId) { + let parentClassification = getClassificationById(parentId); + if (parentClassification && parentClassification.childList) { + // 更新序号 + update( + parentClassification.childList, + fromClassification.id, + newOrder, + fromClassification.order + ); + } + } else { + // 更新序号 + update( + store.classificationList, + fromClassification.id, + newOrder, + fromClassification.order + ); + } + } +} + +/** + * 更新分类图标 + * @param id + * @param icon + */ +function updateClassificationIcon(id: number, icon: string | null) { + // 查询分类 + let classification = getClassificationById(id); + if (classification) { + classification.data.icon = icon; + } +} + +/** + * 获取名称 + */ +function getClassificationName(classification: Classification) { + let name = ""; + if (classification.data.icon && classification.data.icon.trim() !== "") { + name += classification.data.icon; + } + if (store.setting.classification.mode === "normal") { + if (name.trim() !== "") { + name += " "; + } + name += classification.name; + } else { + if (name === "" && classification.name && classification.name.length > 0) { + name += classification.name.substring(0, 1); + } + } + return name; +} + +/** + * 获取当前选中的ID + * @returns + */ +function getSelectedClassificationId(): number | null { + if (store.selectedClassificationParentId) { + if (store.selectedClassificationChildId) { + return store.selectedClassificationChildId; + } else { + return store.selectedClassificationParentId; + } + } + return null; +} + +/** + * 查询固定分类 + */ +function getClassificationFixed(): Classification | null { + for (let classification of store.classificationList) { + if (classification.data.fixed) { + return classification; + } else { + if (classification.childList) { + for (let childClassification of classification.childList) { + if (childClassification.data.fixed) { + return childClassification; + } + } + } + } + } + return null; +} + +/** + * 获取分类名称 + * @param id + * @returns + */ +function getSearchItemClassificationName(id: number) { + let classification = getClassificationById(id); + if (classification) { + return "(" + getClassificationName(classification) + ")"; + } else { + return ""; + } +} + +export { + convertClassificationList, + getClassificationById, + hasChildClassification, + getClassificationName, + addClassification, + deleteClassification, + updateClassification, + updateClassificationOrder, + updateClassificationIcon, + getSelectedClassificationId, + getClassificationChildList, + getClassificationFixed, + getSearchItemClassificationName, +}; diff --git a/src/pages/data/BackupRestore.vue b/src/pages/data/BackupRestore.vue new file mode 100644 index 0000000..6fcb781 --- /dev/null +++ b/src/pages/data/BackupRestore.vue @@ -0,0 +1,94 @@ + + diff --git a/src/pages/index/Index.vue b/src/pages/index/Index.vue new file mode 100644 index 0000000..0b525c0 --- /dev/null +++ b/src/pages/index/Index.vue @@ -0,0 +1,576 @@ + + + +../../../types/setting diff --git a/src/pages/item/AddEdit.vue b/src/pages/item/AddEdit.vue new file mode 100644 index 0000000..0766b8f --- /dev/null +++ b/src/pages/item/AddEdit.vue @@ -0,0 +1,858 @@ + + +../../../types/common../../../types/item diff --git a/src/pages/item/NetworkIcon.vue b/src/pages/item/NetworkIcon.vue new file mode 100644 index 0000000..a56ed5e --- /dev/null +++ b/src/pages/item/NetworkIcon.vue @@ -0,0 +1,152 @@ + + +../../../types/common diff --git a/src/pages/item/SVGIcon.vue b/src/pages/item/SVGIcon.vue new file mode 100644 index 0000000..f57b5f9 --- /dev/null +++ b/src/pages/item/SVGIcon.vue @@ -0,0 +1,147 @@ + + diff --git a/src/pages/item/components/AppxItemList.vue b/src/pages/item/components/AppxItemList.vue new file mode 100644 index 0000000..c6a20c7 --- /dev/null +++ b/src/pages/item/components/AppxItemList.vue @@ -0,0 +1,213 @@ + + +../js/item ../../../../types/item diff --git a/src/pages/item/components/Content.vue b/src/pages/item/components/Content.vue new file mode 100644 index 0000000..ee76588 --- /dev/null +++ b/src/pages/item/components/Content.vue @@ -0,0 +1,894 @@ + + +../../../../types/item diff --git a/src/pages/item/components/List.vue b/src/pages/item/components/List.vue new file mode 100644 index 0000000..48c0cac --- /dev/null +++ b/src/pages/item/components/List.vue @@ -0,0 +1,267 @@ + + + +../../classification/js/classification../js/item +../../../../types/item../../../../types/classification diff --git a/src/pages/item/components/MultiItem.vue b/src/pages/item/components/MultiItem.vue new file mode 100644 index 0000000..1c71266 --- /dev/null +++ b/src/pages/item/components/MultiItem.vue @@ -0,0 +1,188 @@ + + diff --git a/src/pages/item/components/StartMenuItemList.vue b/src/pages/item/components/StartMenuItemList.vue new file mode 100644 index 0000000..9e2b123 --- /dev/null +++ b/src/pages/item/components/StartMenuItemList.vue @@ -0,0 +1,213 @@ + + +../js/item ../../../../types/item diff --git a/src/pages/item/components/SystemItemList.vue b/src/pages/item/components/SystemItemList.vue new file mode 100644 index 0000000..2289543 --- /dev/null +++ b/src/pages/item/components/SystemItemList.vue @@ -0,0 +1,214 @@ + + +../../entities/commonItem ../js/item ../../../../types/item diff --git a/src/pages/item/js/index.ts b/src/pages/item/js/index.ts new file mode 100644 index 0000000..48bd009 --- /dev/null +++ b/src/pages/item/js/index.ts @@ -0,0 +1,815 @@ +import { CommonItem, Item } from "../../../../types/item"; +import { useMainStore } from "../../../store"; +import { Classification } from "../../../../types/classification"; +import { + getClassificationById, + getClassificationChildList, +} from "../../classification/js"; +import { + convert, + getFileExtname, + getItemName, +} from "../../../../commons/utils/common"; +import { hexToRGBA, removeStyle, setStyle } from "../../../utils/style"; +import { pinyin, match } from "pinyin-pro"; +// pinia +const store = useMainStore(); + +/** + * 设置项目宽度 + */ +function setItemWidth() { + // 获取所有项目列表 + let itemListElementList = document.getElementsByClassName("item-list"); + for (let i = 0; i < itemListElementList.length; i++) { + let itemListElement = itemListElementList[i]; + // 分类ID + let classificationId = itemListElement.getAttribute("classification-id"); + // 查询分类 + let classification = classificationId + ? getClassificationById(parseInt(classificationId)) + : null; + // 当前项目区域宽度 + let width = itemListElement.getBoundingClientRect().width; + // 最小宽度 + let minWidth = store.setting.item.width; + // 获取项目数量 + let itemList = itemListElement.getElementsByClassName("item"); + // 每行数量 + let num = null; + // 布局 + let layout = getLayout( + classificationId ? parseInt(classificationId) : null + ); + // 无名称 + if (store.setting.item.hideItemName) { + minWidth = + getIconSize(classificationId ? parseInt(classificationId) : null) + 24; + num = Math.floor(width / (minWidth + 4)); + } else { + if (layout === "tile") { + // 平铺布局 + num = Math.floor(width / (minWidth + 4)); + } else if (layout === "list") { + // 列表布局 + // 先使用分类布局信息 + if (classification && classification.data.itemColumnNumber) { + if (classification.data.itemColumnNumber === 1) { + minWidth = width; + } else { + num = classification.data.itemColumnNumber; + } + } else { + // 设置-分类布局信息 + if (store.setting.item.columnNumber === 1) { + minWidth = width; + } else { + num = store.setting.item.columnNumber; + } + } + } + } + if ( + num !== null && + ((layout === "tile" && itemList.length >= num) || layout === "list") + ) { + for (let i = 0; i < itemList.length; i++) { + let itemElement = itemList[i] as HTMLElement; + itemElement.style.width = (width - num * 4) / num + "px"; + } + } else { + for (let i = 0; i < itemList.length; i++) { + let itemElement = itemList[i] as HTMLElement; + itemElement.style.width = minWidth + "px"; + } + } + } +} + +/** + * 转换项目列表 + */ +function convertItemList(itemList: Array): Map> { + let itemMap: Map> = new Map(); + // 根据分类ID将列表转为Map + itemList.forEach((item) => { + const { classificationId } = item; + if (!itemMap.has(classificationId)) { + itemMap.set(classificationId, []); + } + itemMap.get(classificationId)!.push(item); + }); + return itemMap; +} + +/** + * 获取项目列表 + */ +function getItemListByClassificationId( + classificationId: number | null +): Array { + let resultList: Array = []; + if (classificationId) { + if (store.itemMap.has(classificationId)) { + resultList = store.itemMap.get(classificationId)!; + } else { + store.itemMap.set(classificationId, resultList); + } + } + return resultList; +} + +/** + * 获取项目列表 + */ +function getShowItemListByClassificationId(classificationId: number | null) { + let resultList: Array = []; + if (classificationId) { + // 查询分类 + let classification = getClassificationById(classificationId); + if (classification) { + if (classification.type === 2) { + for (const value of store.itemMap.values()) { + resultList.push(...value); + } + } else { + if (store.itemMap.has(classificationId)) { + resultList = store.itemMap.get(classificationId)!; + } else { + store.itemMap.set(classificationId, resultList); + } + } + } + } + return { resultList, id: classificationId }; +} + +/** + * 添加项目 + */ +function addItem(item: Item) { + let itemList = getItemListByClassificationId(item.classificationId); + itemList.push(item); + // 重新排序 + itemList.sort((a, b) => a.order! - b.order!); +} + +/** + * 根据ID查询 + */ +function getItemById(id: number): Item | null { + for (let value of store.itemMap.values()) { + for (let item of value) { + if (item.id === id) { + return item; + } + } + } + return null; +} + +/** + * 更新项目 + */ +function updateItem(item: Item) { + // 查询项目 + let curItem = getItemById(item.id); + if (curItem) { + curItem.name = item.name; + curItem.shortcutKey = item.shortcutKey; + curItem.globalShortcutKey = item.globalShortcutKey; + if (curItem.data) { + curItem.data.startLocation = item.data.startLocation; + curItem.data.target = item.data.target; + curItem.data.params = item.data.params; + curItem.data.runAsAdmin = item.data.runAsAdmin; + curItem.data.icon = item.data.icon; + curItem.data.htmlIcon = item.data.htmlIcon; + curItem.data.remark = item.data.remark; + curItem.data.iconBackgroundColor = item.data.iconBackgroundColor; + curItem.data.fixedIcon = item.data.fixedIcon; + } + } +} + +/** + * 删除项目 + */ +function deleteItem(id: number) { + for (let value of store.itemMap.values()) { + // index + let index: number | null = null; + // 当前项目 + let item: Item | null = null; + for (let i = 0; i < value.length; i++) { + if (value[i].id === id) { + index = i; + item = value[i]; + break; + } + } + if (index !== null && item) { + // 删除 + value.splice(index, 1); + // 更新目标分类下其他项目序号 + for (let i of value) { + if (i.order >= item.order) { + i.order -= 1; + } + } + break; + } + } +} + +/** + * 根据分类ID删除项目 + */ +function deleteItemByClassificationId(classificationId: number | null) { + if (classificationId && store.itemMap.has(classificationId)) { + store.itemMap.delete(classificationId); + } +} + +/** + * 根据ID查询列表 + */ +function getItemByIdList(idList: Array): Array { + let itemList = []; + for (const id of idList) { + let item = getItemById(id); + if (item) { + itemList.push(item); + } + } + // 返回列表 + let resultList = []; + // 根据传入的参数排序 + for (const id of idList) { + for (const item of itemList) { + if (id === item.id) { + resultList.push(item); + break; + } + } + } + return resultList; +} + +/** + * 项目排序 + */ +function updateItemOrder( + fromIdList: Array, + toClassificationId: number, + newIndex: number | null +) { + // 查询来源项目 + let fromItemList = getItemByIdList(fromIdList); + if (fromItemList.length > 0) { + // 删除来源项目原有位置 + for (const item of fromItemList) { + deleteItem(item.id); + } + // 查询目标分类是否是父级分类,如果是父级分类的话,获取他下面的第一个子分类 + let childClassificationList = + getClassificationChildList(toClassificationId); + if (childClassificationList.length > 0) { + toClassificationId = childClassificationList[0].id; + } + // 记录来源项目都是来源于哪些分类,需要重新排序 + let fromClassificationIdList = []; + for (const item of fromItemList) { + if ( + item.classificationId != toClassificationId && + fromClassificationIdList.indexOf(item.classificationId) < 0 + ) { + fromClassificationIdList.push(item.classificationId); + } + } + // 查询目标项目列表 + let toItemList = getItemListByClassificationId(toClassificationId); + // 将来源项目插入到目标项目列表 + if (newIndex !== null) { + toItemList.splice(newIndex, 0, ...fromItemList); + } else { + toItemList.push(...fromItemList); + } + // 目标分类重新排序和修改分类信息 + for (let i = 0; i < toItemList.length; i++) { + toItemList[i].order = i + 1; + toItemList[i].classificationId = toClassificationId; + } + // 重新排序 + toItemList.sort((a, b) => a.order - b.order); + // 重排序其来源分类项目列表 + for (const id of fromClassificationIdList) { + let itemList = getItemListByClassificationId(id); + for (let i = 0; i < itemList.length; i++) { + itemList[i].order = i + 1; + } + // 重新排序 + itemList.sort((a, b) => a.order - b.order); + } + } +} + +/** + * 根据分类ID移动项目 + */ +function moveItemByClassificationId( + oldClassificationId: number, + newClassificationId: number +) { + if (store.itemMap.has(oldClassificationId)) { + store.itemMap.set( + newClassificationId, + store.itemMap.get(oldClassificationId)! + ); + deleteItemByClassificationId(oldClassificationId); + } else { + store.itemMap.set(newClassificationId, []); + } +} + +/** + * 获取名称缩写 + */ +function getAbbr(name: string): string | null { + let split = getItemName(name).split(" "); + let abbr = ""; + if (split.length > 1) { + for (let i = 0; i < split.length; i++) { + abbr += split[i].slice(0, 1); + } + } + return abbr === "" ? null : abbr; +} + +/** + * 获取搜索Map + */ +function getItemSearchMap( + itemList: Array, + remark: boolean = false +): Map> { + // 搜索Map + let searchMap: Map> = new Map(); + // 循环每一个项目提取名字和缩写找到相同的放到同一个列表中 + for (const item of itemList) { + if (!item.name) { + continue; + } + // 名称 + let name = item.name.toLowerCase(); + let nameList = searchMap.get(name); + if (!nameList) { + nameList = []; + } + nameList.push(item); + searchMap.set(name, nameList); + // 缩写 + let abbr = getAbbr(item.name); + if (abbr) { + abbr = abbr.toLowerCase(); + let abbrList = searchMap.get(abbr); + if (!abbrList) { + abbrList = []; + } + abbrList.push(item); + searchMap.set(abbr, abbrList); + } + // 备注 + if (remark) { + let r = (item as Item).data.remark; + if (r && r.trim() !== "") { + r = r.toLowerCase(); + let remarkList = searchMap.get(r); + if (!remarkList) { + remarkList = []; + } + remarkList.push(item); + searchMap.set(r, remarkList); + } + } + } + return searchMap; +} + +/** + * 判断是否有中文 + */ +function hasChinese(str: string): boolean { + const pattern = /[\u4e00-\u9fa5]/; // 中文字符的 Unicode 范围 + return pattern.test(str); +} + +/** + * 搜索通用项目 + */ +function searchItem( + text: string, + searchMap: Map>, + maxLength: number | null = null +): Array { + // 返回列表 + let resultList: Array = []; + // 转换为小写 + text = text.toLowerCase(); + // 循环搜索Map搜索项目 + for (const [key, value] of searchMap.entries()) { + let found = false; + if (hasChinese(key)) { + // 包含中文 + let res: Array = match(key, text, { + continuous: true, + space: "preserve", + }); + if (res && res.length > 0) { + found = true; + } + } else { + // 其他情况 + found = key.indexOf(text) >= 0; + } + if (found) { + // 去重并添加 + for (let vItem of value) { + let exists = false; + for (let rItem of resultList) { + if (vItem.id === rItem.id) { + exists = true; + break; + } + } + if (!exists) { + resultList.push(vItem); + } + } + } + } + // 最大长度 + if (maxLength) { + resultList = resultList.slice(0, maxLength); + } + return resultList; +} + +/** + * 显示项目列表 + * @param itemList + * @param classification + * @returns + */ +function showItemList( + itemList: Array, + classification: Classification | null +) { + // 返回数据 + let resultList = []; + // 隐藏项 + let hiddenItemArr: Array = []; + if ( + classification && + classification.type === 1 && + classification.data.associateFolderHiddenItems + ) { + hiddenItemArr = classification.data.associateFolderHiddenItems + .toLowerCase() + .split(","); + } + // 过滤 + for (const item of itemList) { + let extName = getFileExtname(item.data.target); + if ( + // 判断隐藏项 + (hiddenItemArr.length === 0 || + !extName || + (extName && hiddenItemArr.indexOf(extName.toLowerCase()) < 0)) && + // 判断显示项 + (!classification || + (classification && + (classification.data.itemShowOnly === "default" || + (classification.data.itemShowOnly === "file" && item.type !== 1) || + (classification.data.itemShowOnly === "folder" && + item.type === 1)))) + ) { + resultList.push(item); + } + } + // 排序 + if (classification && classification.data.itemSort !== "default") { + let sortList = sort(resultList, classification.data.itemSort); + if (sortList) { + resultList = sortList; + } + } + // 聚合分类 + if (classification && classification.type === 2) { + // 截取数据 + resultList = resultList.slice(0, classification.data.aggregateItemCount); + } + // 返回 + return resultList; +} + +/** + * 排序 + * @param list + * @param type + * @param key + */ +function sort( + list: Array, + type: + | "default" + | "initial" + | "openNumber" + | "lastOpen" + | "quickSearchOpenNumber" + | "quickSearchLastOpen" +) { + if (type === "initial") { + return list.sort((x, y) => { + let xn: any, yn: any; + if (x.name) { + xn = pinyin(x.name, { toneType: "none", type: "array" }) + .join("") + .charAt(0) + .toLowerCase(); + } else { + xn = ""; + } + if (y.name) { + yn = pinyin(y.name, { toneType: "none", type: "array" }) + .join("") + .charAt(0) + .toLowerCase(); + } else { + yn = ""; + } + // 判断是否是数字 + if (!isNaN(xn) && isNaN(yn)) { + // xn是数字而yn不是,返回1 + return 1; + } + if (!isNaN(yn) && isNaN(xn)) { + // yn是数字而xn不是,返回-1 + return -1; + } + if (xn < yn) { + return -1; + } + if (xn > yn) { + return 1; + } + if (xn == yn) { + if (x.name && y.name) { + if (x.name < y.name) { + return -1; + } + if (x.name < y.name) { + return 1; + } + } + } + return 0; + }); + } else if ( + type === "openNumber" || + type === "lastOpen" || + type === "quickSearchOpenNumber" || + type === "quickSearchLastOpen" + ) { + return list + .sort((x, y) => { + let xn = x.data[type] ?? 0; + let yn = y.data[type] ?? 0; + if (xn < yn) { + return -1; + } + if (xn > yn) { + return 1; + } + if (xn === yn) { + if (x.name && y.name) { + if (x.name < y.name) { + return -1; + } + if (x.name < y.name) { + return 1; + } + } + } + return 0; + }) + .reverse(); + } +} + +/** + * 运行项目 + * @param type + * @param operation + * @param item + */ +function run(type: string, operation: string, item: Item) { + let itemList: Array = []; + if (item.type === 5) { + if (item.data.target) { + let arr = item.data.target.split(","); + for (const a of arr) { + let item = getItemById(parseInt(a)); + if (item) { + itemList.push(item); + } + } + } + window.item.updateOpenInfo(type, item.id); + } else { + itemList.push(item); + } + if (item.type === 5 && item.data.multiItemsTimeInterval > 0) { + let index = 0; + const next = () => { + if (index < itemList.length) { + window.item.run(type, operation, convert(itemList[index])); + index = index + 1; + if (index < itemList.length) { + setTimeout(next, item.data.multiItemsTimeInterval); + } + } + }; + next(); + } else { + for (const element of itemList) { + window.item.run(type, operation, convert(element)); + } + } + if (store.setting.item.openAfterHideMainInterface) { + window.main.hideWindow(); + } +} + +/** + * 项目选中样式 + */ +function itemHoverStyle(e: any, className: string) { + let style: Map = new Map(); + style.set( + "background-color", + hexToRGBA(store.setting.appearance.theme.secondBackgroundColor, 0.3) + ); + setStyle(e, className, style); +} + +/** + * 项目移走样式 + */ +function itemRemoveStyle(e: any, className: string) { + let style: Map = new Map(); + style.set("background-color", null); + removeStyle(e, className, style); +} + +/** + * 去除所有项目选中效果 + */ +function allItemRemoveStyle() { + let elementList = document.getElementsByClassName("item"); + for (let i = 0; i < elementList.length; i++) { + itemRemoveStyle(elementList[i], "item"); + } +} + +/** + * 获取布局 + */ +function getLayout(classificationId: number | null) { + if (classificationId) { + let classification = getClassificationById(classificationId); + if (classification && classification.data.itemLayout !== "default") { + return classification.data.itemLayout; + } + } + return store.setting.item.layout; +} + +/** + * 获取图标大小 + */ +function getIconSize(classificationId: number | null) { + if (classificationId) { + let classification = getClassificationById(classificationId); + if (classification && classification.data.itemIconSize !== null) { + return classification.data.itemIconSize; + } + } + return store.setting.item.iconSize; +} + +/** + * 删除无效项目 + * @param id + */ +function removeInvalidItem(id: number) { + if (store.invalidItemIdList.includes(id)) { + let index = store.invalidItemIdList.indexOf(id); + if (index !== -1) { + store.invalidItemIdList.splice(index, 1); + } + } +} + +/** + * 获取名称 + */ +function getName(name: string | null) { + if (name) { + return name.replace(/\\n/g, " "); + } else { + return ""; + } +} + +/** + * 获取项目标题 + * @param item + * @returns + */ +function getItemTitle(item: Item) { + let name = + store.language.name + + store.language.colon + + (item.name ? item.name.replace(/\\n/g, " ") : ""); + if (store.setting.item.openNumber) { + name += + "\n" + + store.language.openNumber + + store.language.colon + + (item.data.openNumber ?? 0); + } + if (item.data.remark) { + name += + "\n" + store.language.remark + store.language.colon + item.data.remark; + } + return name; +} + +/** + * 过滤排除搜索 + * @returns + */ +function filterExcludeSearchItemList() { + // 项目列表 + let itemList: Array = []; + // 记录排除搜索的分类ID + let excludeSearchIdList = store.classificationList + .filter((classification) => classification.data.excludeSearch) + .map((classification) => classification.id); + for (const [key, value] of store.itemMap.entries()) { + // 查询分类 + let classification = getClassificationById(key); + if ( + classification && + !classification.data.excludeSearch && + !excludeSearchIdList.includes(classification.id) && + (!classification.parentId || + !excludeSearchIdList.includes(classification.parentId)) + ) { + itemList.push(...value); + } + } + return itemList; +} + +export { + setItemWidth, + getAbbr, + getItemSearchMap, + searchItem, + addItem, + getItemById, + updateItem, + deleteItem, + deleteItemByClassificationId, + updateItemOrder, + getItemListByClassificationId, + getShowItemListByClassificationId, + convertItemList, + showItemList, + run, + itemHoverStyle, + itemRemoveStyle, + allItemRemoveStyle, + moveItemByClassificationId, + getLayout, + getIconSize, + removeInvalidItem, + getItemByIdList, + hasChinese, + getName, + getItemTitle, + filterExcludeSearchItemList, + sort, +}; diff --git a/src/pages/search/QuickSearch.vue b/src/pages/search/QuickSearch.vue new file mode 100644 index 0000000..71c0e4b --- /dev/null +++ b/src/pages/search/QuickSearch.vue @@ -0,0 +1,640 @@ + + + diff --git a/src/pages/search/components/Search.vue b/src/pages/search/components/Search.vue new file mode 100644 index 0000000..8c31be6 --- /dev/null +++ b/src/pages/search/components/Search.vue @@ -0,0 +1,392 @@ + + diff --git a/src/pages/search/js/index.ts b/src/pages/search/js/index.ts new file mode 100644 index 0000000..c249006 --- /dev/null +++ b/src/pages/search/js/index.ts @@ -0,0 +1,51 @@ +import { itemRemoveStyle } from "../../item/js"; + +/** + * 删除所有选中项目样式 + * @param className + * @param selected + */ +function itemAllRemoveStyle(className: string, selected: number) { + let elementList = document.getElementsByClassName(className); + for (let i = 0; i < elementList.length; i++) { + const element = elementList[i]; + let index = element.getAttribute("index"); + if (index && selected !== parseInt(index)) { + itemRemoveStyle(element, className); + } + } +} + +/** + * 移动滚动条 + * @param className + * @param height + * @param type + * @param selected + */ +function searchResultDivMoveScroll( + className: string, + height: number, + type: "up" | "down", + selected: number +) { + let listEL = document.getElementById("search-result-list"); + let itemEl = document.getElementById(className + "-" + selected); + if (listEL && itemEl) { + let itemRect = itemEl.getBoundingClientRect(); + let realY = itemRect.y - height - 1 + 48; + if (type === "up") { + if (realY < 48) { + let sim = listEL.getElementsByClassName("simplebar-content-wrapper")[0]; + sim.scrollTop = sim.scrollTop - (48 - realY); + } + } else { + if (realY > listEL.clientHeight) { + let sim = listEL.getElementsByClassName("simplebar-content-wrapper")[0]; + sim.scrollTop = sim.scrollTop + (realY - listEL.clientHeight); + } + } + } +} + +export { itemAllRemoveStyle, searchResultDivMoveScroll }; diff --git a/src/pages/setting/Index.vue b/src/pages/setting/Index.vue new file mode 100644 index 0000000..d1d2312 --- /dev/null +++ b/src/pages/setting/Index.vue @@ -0,0 +1,2259 @@ + + +../../../types/setting diff --git a/src/renderer/App.vue b/src/renderer/App.vue deleted file mode 100644 index a80eddd..0000000 --- a/src/renderer/App.vue +++ /dev/null @@ -1,14 +0,0 @@ - - - diff --git a/src/renderer/assets/images/logo-thick.png b/src/renderer/assets/images/logo-thick.png deleted file mode 100644 index 75bdc58..0000000 Binary files a/src/renderer/assets/images/logo-thick.png and /dev/null differ diff --git a/src/renderer/assets/images/logo-transparent.png b/src/renderer/assets/images/logo-transparent.png deleted file mode 100644 index b4d5105..0000000 Binary files a/src/renderer/assets/images/logo-transparent.png and /dev/null differ diff --git a/src/renderer/common/index.js b/src/renderer/common/index.js deleted file mode 100644 index 5eec9ba..0000000 --- a/src/renderer/common/index.js +++ /dev/null @@ -1,300 +0,0 @@ -import store from "../store"; -import * as DOMPurify from "dompurify"; -import ClassificationJS from "@/views/classification/js"; - -/** - * 校验KeyCode - * @param e - */ -function checkKeyCode(e) { - // (e.keyCode >= 48 && e.keyCode <= 57) 键盘上方数字 - // (e.keyCode >= 65 && e.keyCode <= 90) 键盘字母a-z不区分大小写 - // (e.keyCode >= 96 && e.keyCode <= 111) 数字键盘 - // (e.keyCode >= 112 && e.keyCode <= 135) 键盘F1到F24 - // e.keyCode == 8 退格键 - // e.keyCode == 9 Tab - // e.keyCode == 12 Clear - // e.keyCode == 13 回车 - // e.keyCode == 16 Shift - // e.keyCode == 17 Control - // e.keyCode == 18 Alt - // e.keyCode == 20 Cape Lock 大小写 - // e.keyCode == 27 Esc - // (e.keyCode >= 32 && e.keyCode <= 40) 控制键盘区 - // e.keyCode == 45 Insert - // e.keyCode == 46 Delete - // e.keyCode == 144 Num Lock - // (e.keyCode >= 186 && e.keyCode <= 192) 符号;: =+ ,< -_ .> /? `~ - // (e.keyCode >= 219 && e.keyCode <= 222) 符号[{ \| ]} '" - if ( - (e.keyCode >= 48 && e.keyCode <= 57) || - (e.keyCode >= 65 && e.keyCode <= 90) || - (e.keyCode >= 96 && e.keyCode <= 111) || - (e.keyCode >= 112 && e.keyCode <= 135) || - e.keyCode == 8 || - e.keyCode == 9 || - e.keyCode == 12 || - e.keyCode == 13 || - e.keyCode == 16 || - e.keyCode == 17 || - e.keyCode == 18 || - e.keyCode == 20 || - e.keyCode == 27 || - (e.keyCode >= 32 && e.keyCode <= 40) || - e.keyCode == 45 || - e.keyCode == 46 || - e.keyCode == 144 || - (e.keyCode >= 186 && e.keyCode <= 192) || - (e.keyCode >= 219 && e.keyCode <= 222) - ) { - return true; - } - return false; -} - -/** - * 获取Key - * @param classificationParentId - * @param classificationChildId - * @param itemId - * @returns {*} - */ -function getKey(classificationParentId, classificationChildId, itemId) { - let key = classificationParentId; - if (classificationChildId != null) { - key += "-" + classificationChildId; - } - key += "-" + itemId; - return key; -} - -/** - * 获取图标 - */ -function getIcon(classificationParentId, classificationChildId, itemId) { - if (store.state.iconDataMap != null) { - let icon = store.state.iconDataMap.get(getKey(classificationParentId, classificationChildId, itemId)); - if (icon != null) { - return icon.icon; - } else { - return null; - } - } - return null; -} - -export default { - /** - * 转int - * @param v - */ - parseInt(v) { - return v != null ? parseInt(v) : null; - }, - /** - * 获取新ID - */ - getNewId(list) { - if (list == null || list.length == 0) { - return 1; - } - // 获取ID列表 - let idList = list.map((item) => item.id); - // 获取最大ID - let maxId = Math.max(...idList); - // +1 - return ++maxId; - }, - /** - * 设置快捷键 - */ - setShortcutKey(e, originalVal, preventDefault) { - if (preventDefault) { - e.preventDefault(); - } - if (checkKeyCode(e)) { - // Esc - if (e.keyCode == 27) { - return originalVal; - } - if (e.keyCode == 8) { - return null; - } else { - let keys = []; - // 如果是组合键 - if (e.ctrlKey && e.keyCode != 17) { - keys.push("Ctrl + "); - } - if (e.altKey && e.keyCode != 18) { - keys.push("Alt + "); - } - if (e.metaKey && e.keyCode != 91) { - keys.push("Win + "); - } - if (e.shiftKey && e.keyCode != 16) { - keys.push("Shift + "); - } - // 非组合键情况,按键是ctrl alt shift win - if (e.keyCode == 16 || e.keyCode == 17 || e.keyCode == 18 || e.keyCode == 91) { - let key; - if (e.ctrlKey && e.keyCode == 17) { - key = "Ctrl + "; - } - if (e.altKey && e.keyCode == 18) { - key = "Alt + "; - } - if (e.metaKey && e.keyCode == 91) { - key = "Win + "; - } - if (e.shiftKey && e.keyCode == 16) { - key = "Shift + "; - } - keys.push(key); - } else { - // 排序 - keys.sort((a, b) => a.localeCompare(b)); - // 其他 - if (e.key.toUpperCase() == "ENTER") { - keys.push("Enter"); - } else { - if (e.keyCode == 32) { - keys.push("Space"); - } else if (e.keyCode >= 96 && e.keyCode <= 105) { - keys.push("Num" + e.key); - } else if (e.keyCode >= 106 && e.keyCode <= 111) { - if (e.keyCode == 106) { - keys.push("NumMult"); - } else if (e.keyCode == 107) { - keys.push("NumAdd"); - } else if (e.keyCode == 109) { - keys.push("NumSub"); - } else if (e.keyCode == 110) { - keys.push("NumDec"); - } else if (e.keyCode == 111) { - keys.push("NumDiv"); - } - } else { - keys.push(e.key.replace("Arrow", "").toUpperCase()); - } - } - } - return keys.join(""); - } - } else { - return null; - } - }, - /** - * 校验快捷键完整 - * @param shortcutKey - * @returns {boolean} - */ - checkShortcutKeys(shortcutKey) { - if (shortcutKey != null && shortcutKey.trim() != "") { - let flag = false; - let split = shortcutKey.split("+"); - for (let s of split) { - if (s.trim() == "") { - return false; - } - if (s.trim() != "Ctrl" && s.trim() != "Alt" && s.trim() != "Shift" && s.trim() != "Win") { - flag = true; - } - } - return flag; - } - return false; - }, - /** - * 校验应用程序内快捷是否重复 - * @param shortcutKey - * @param appShortcutKeyMap - */ - checkAppShortcutKeysDuplicate(shortcutKey, appShortcutKeyMap) { - let s = appShortcutKeyMap.get(shortcutKey); - if (s != null) { - let name = s.classificationParentName; - if (s.type == "classification") { - if (s.classificationChildName != null && s.classificationChildName.trim() != "") { - name += "-" + s.classificationChildName; - } - return store.state.currentLanguage.shortcutKeyConflictMessage(name, 0); - } else { - if (s.classificationChildName != null && s.classificationChildName.trim() != "") { - name += "-" + s.classificationChildName; - } - name += "-" + s.itemName; - return store.state.currentLanguage.shortcutKeyConflictMessage(name, 1); - } - } - return null; - }, - /** - * 校验设置中的快捷键是否重复 - * @param shortcutKey - * @param setting - * @param exclude - * @returns {null} - */ - checkSettingShortcutKeysDuplicate(shortcutKey, setting, exclude) { - let msg = null; - let showHide, search, quickSearch; - if (setting.general != null && (exclude == null || exclude != "showHideShortcutKey")) { - showHide = setting.general.showHideShortcutKey; - } - if (setting.item != null && (exclude == null || exclude != "searchShortcutKey")) { - search = setting.item.searchShortcutKey; - } - if (setting.quickSearch != null && (exclude == null || exclude != "quickSearchShowHideShortcutKey")) { - quickSearch = setting.quickSearch.showHideShortcutKey; - } - if (showHide != null && showHide.trim() != "" && showHide == shortcutKey) { - msg = store.state.currentLanguage.shortcutKeyConflictSettingGeneralShowHideMessage; - } else if (search != null && search.trim() != "" && search == shortcutKey) { - msg = store.state.currentLanguage.shortcutKeyConflictSettingItemSearchMessage; - } else if (quickSearch != null && quickSearch.trim() != "" && quickSearch == shortcutKey) { - msg = store.state.currentLanguage.shortcutKeyConflictSettingQuickSearchShowHideMessage; - } - return msg; - }, - /** - * 判断数组是否等于空 - * @param arr - */ - arrayIsEmpty(arr) { - if (arr == null || arr.length == 0) { - return true; - } - return false; - }, - /** - * 判断字符串是否为空 - * @param str - */ - strIsEmpty(str) { - if (str == null || str.trim() == "") { - return true; - } - return false; - }, - DOMPurify, - /** - * 获取图标 - */ - getIcon, - /** - * 获取Key - * @param classificationParentId - * @param classificationChildId - * @param itemId - * @returns {*} - */ - getKey, - /** - * 获取图标根据分类 - */ - getIconByClassification(item) { - let { classificationParentId, classificationChildId } = ClassificationJS.convertClassificationId(item.classificationId, item.classificationParentId); - return getIcon(classificationParentId, classificationChildId, item.id); - }, -}; diff --git a/src/renderer/components/Button.vue b/src/renderer/components/Button.vue deleted file mode 100644 index eccce38..0000000 --- a/src/renderer/components/Button.vue +++ /dev/null @@ -1,71 +0,0 @@ - - - - - diff --git a/src/renderer/components/CheckBox.vue b/src/renderer/components/CheckBox.vue deleted file mode 100644 index 3b949e0..0000000 --- a/src/renderer/components/CheckBox.vue +++ /dev/null @@ -1,56 +0,0 @@ - - - - - diff --git a/src/renderer/components/Close.vue b/src/renderer/components/Close.vue deleted file mode 100644 index 4600fef..0000000 --- a/src/renderer/components/Close.vue +++ /dev/null @@ -1,33 +0,0 @@ - - - - - diff --git a/src/renderer/components/Color.vue b/src/renderer/components/Color.vue deleted file mode 100644 index f700911..0000000 --- a/src/renderer/components/Color.vue +++ /dev/null @@ -1,93 +0,0 @@ - - - - - diff --git a/src/renderer/components/Input.vue b/src/renderer/components/Input.vue deleted file mode 100644 index f076ec7..0000000 --- a/src/renderer/components/Input.vue +++ /dev/null @@ -1,39 +0,0 @@ - - - - - diff --git a/src/renderer/components/Popup.vue b/src/renderer/components/Popup.vue deleted file mode 100644 index 0561a1b..0000000 --- a/src/renderer/components/Popup.vue +++ /dev/null @@ -1,174 +0,0 @@ - - - - - diff --git a/src/renderer/components/Select.vue b/src/renderer/components/Select.vue deleted file mode 100644 index 20588d2..0000000 --- a/src/renderer/components/Select.vue +++ /dev/null @@ -1,130 +0,0 @@ - - - - - diff --git a/src/renderer/components/TopTitleBar.vue b/src/renderer/components/TopTitleBar.vue deleted file mode 100644 index afdbc9a..0000000 --- a/src/renderer/components/TopTitleBar.vue +++ /dev/null @@ -1,44 +0,0 @@ - - - - - diff --git a/src/renderer/main.js b/src/renderer/main.js deleted file mode 100644 index 345f28a..0000000 --- a/src/renderer/main.js +++ /dev/null @@ -1,125 +0,0 @@ -import { createApp } from "vue"; -import App from "./App.vue"; -import router from "./router"; -import store from "./store"; -import "./style/tailwind.css"; -import "./style/main.css"; - -/** - * 全局方法 - */ -const getClassElement = function getClassElement(e, className) { - let target; - if (e instanceof HTMLElement) { - target = e; - } else { - for (let i = 0; i < e.path.length; i++) { - if (e.path[i].classList != null && e.path[i].classList.length > 0) { - for (let clazz of e.path[i].classList) { - if (clazz == className) { - target = e.path[i]; - break; - } - } - } - } - } - return target; -}; - -/** - * 鼠标经过 - * @param e - * @param className - * @param style - * @param value - */ -const styleMouseover = function styleMouseover(e, className, style, value) { - let target = getClassElement(e, className); - if (target != null && style != null) { - for (let i = 0; i < style.length; i++) { - target.style.setProperty(style[i], value[i]); - } - } -}; - -/** - * 鼠标移开 - * @param e - * @param className - * @param style - */ -const styleMouseout = function styleMouseout(e, className, style, value) { - let target = getClassElement(e, className); - if (target != null && style != null) { - for (let i = 0; i < style.length; i++) { - if (value != null && value[i] != null) { - target.style.setProperty(style[i], value[i]); - } else { - target.style.removeProperty(style[i]); - } - } - } -}; - -/** - * 十六进制转 RGBA 的函数 - * @param hex - * @param a - * @returns {`rgba(${number}, ${number}, ${number}, ${string})`} - */ -const hexToRGBA = function hexToRGBA(hex, a) { - let hexValue = hex.replace("#", ""); - - // 将六位颜色值转为八位 - if (hexValue.length === 6) { - hexValue = hexValue + "ff"; - } - - // 获取rgba各分量值 - const red = parseInt(hexValue.substring(0, 2), 16); - const green = parseInt(hexValue.substring(2, 4), 16); - const blue = parseInt(hexValue.substring(4, 6), 16); - const alpha = parseInt(hexValue.substring(6, 8), 16) / 255; - - return `rgba(${red}, ${green}, ${blue}, ${a == 1 ? alpha : a})`; -}; - -/** - * 返回背景颜色 - * @param setting - * @returns {`rgba(${number}, ${number}, ${number}, ${string})`} - */ -const backgroundTransparencyBackgroundColor = function backgroundTransparencyBackgroundColor(setting) { - return hexToRGBA(setting.appearance.theme.mainBackground, setting.appearance.backgroundTransparency); -}; - -/** - * 返回字体颜色 - */ -const backgroundTransparencyFontColor = function backgroundTransparencyFontColor(setting, transparency) { - return hexToRGBA(setting.appearance.theme.fontBasic, transparency); -}; - -/** - * 获取冒号 - */ -const getColon = function getColon() { - return store.state.currentLanguage.colon; -}; - -createApp(App) - .mixin({ - methods: { - $styleMouseover: styleMouseover, - $styleMouseout: styleMouseout, - $hexToRGBA: hexToRGBA, - $backgroundTransparencyBackgroundColor: backgroundTransparencyBackgroundColor, - $backgroundTransparencyFontColor: backgroundTransparencyFontColor, - $getColon: getColon, - $getClassElement: getClassElement, - }, - }) - .use(store) - .use(router) - .mount("#app"); diff --git a/src/renderer/router/index.js b/src/renderer/router/index.js deleted file mode 100644 index 031dd85..0000000 --- a/src/renderer/router/index.js +++ /dev/null @@ -1,39 +0,0 @@ -import { createRouter, createWebHashHistory } from "vue-router"; - -const routes = [ - { - path: "/", - name: "Index", - component: () => import("@/views/index/Index.vue"), - }, - { - path: "/classification/addEdit", - name: "ClassificationAddEdit", - component: () => import("@/views/classification/AddEdit.vue"), - }, - { - path: "/item/addEdit", - name: "ItemAddEdit", - component: () => import("@/views/item/AddEdit.vue"), - }, - { - path: "/about", - name: "About", - component: () => import("@/views/about/Index.vue"), - }, - { - path: "/setting", - name: "Setting", - component: () => import("@/views/setting/Index.vue"), - }, - { - path: "/searchWindow", - name: "searchWindow", - component: () => import("@/views/search/Window.vue"), - }, -]; - -export default new createRouter({ - routes, - history: createWebHashHistory(), -}); diff --git a/src/renderer/store/index.js b/src/renderer/store/index.js deleted file mode 100644 index 73cc723..0000000 --- a/src/renderer/store/index.js +++ /dev/null @@ -1,608 +0,0 @@ -import { createStore } from "vuex"; - -export default createStore({ - state: { - // 列表 - list: [], - // 全局设置 - setting: {}, - // 应用内快捷键 - appShortcutKeyMap: new Map(), - // 当前语言 - currentLanguage: null, - // 语言 - language: { - chinese: { - setting: "设置", - about: "关于", - checkForUpdates: "检查更新", - checkForUpdatesNewVersionMessage: '检查到有新版本,点击"确定"跳转官网下载最新版本。', - checkForUpdatesLatestVersionMessage: "当前已经是最新版本。", - checkForUpdatesFailedMessage: "检查更新失败,请确认网络。", - exit: "退出", - ok: "确定", - cancel: "取消", - newClassification: "新建分类", - newSubClassification: "新建子分类", - editClassification: "编辑分类", - editSubClassification: "编辑子分类", - edit: "编辑", - delete: "删除", - cut: "剪切", - copy: "复制", - paste: "粘贴", - notFoundFileMessage: "找不到指定的文件", - notFoundFolderMessage: "找不到指定的文件夹", - newItem: "新建项目", - clearItem: "清空项目", - open: "打开", - runAsAdministrator: "以管理员身份运行", - openLocation: "打开文件所在的位置", - moveTo: "移动到", - copyTo: "复制到", - name: "名称", - shortcutKey: "快捷键", - shortcutKeyIncompleteMessage: "快捷键不完整,请完善您的快捷键。", - shortcutKeyConflictMessage(text, type) { - if (type == 0) { - return '与"' + text + '"分类快捷键产生冲突,请重新设置。'; - } else { - return '与"' + text + '"项目快捷键产生冲突,请重新设置。'; - } - }, - shortcutKeyConflictSettingGeneralShowHideMessage: '与"设置-常规"中的"显示/隐藏"快捷键产生冲突,请重新设置。', - shortcutKeyConflictSettingItemSearchMessage: '与"设置-项目"中的"搜索"快捷键产生冲突,请重新设置。', - shortcutKeyConflictSettingQuickSearchShowHideMessage: '与"设置-快速搜索"中的"显示/隐藏"快捷键产生冲突,请重新设置。', - editItem: "编辑项目", - colon: ":", - target: "目标", - browse: "浏览", - defaultIcon: "默认图标", - url: "网址", - getUrlInfo: "获取网址信息", - urlErrorMessage: "获取网址信息失败,请手动填写。", - arguments: "参数", - file: "文件", - folder: "文件夹", - gettingUrlInfo: "获取中", - officialWebsite: "官方网站", - start: "启动", - autoStart: "开机启动", - showHide: "显示/隐藏", - language: "语言", - theme: "主题", - search: "搜索", - doubleClickOpen: "双击打开", - general: "常规", - appearance: "外观", - item: "项目", - layout: "布局", - iconSize: "图标大小", - backupRestoreData: "备份/恢复数据", - backup: "备份", - restore: "恢复", - openAfterHideMainInterface: "打开后隐藏主界面", - tile: "平铺", - list: "列表", - large: "大", - medium: "中", - small: "小", - chinese: "简体中文", - traditionalChinese: "繁體中文", - window: "窗口", - alwaysTop: "永远置顶", - notPrompt: "不再提示", - feedback: "反馈", - system: "系统", - computer: "计算机", - document: "文档", - controlPanel: "控制面板", - networkAndSharingCenter: "网络和共享中心", - recycleBin: "回收站", - fileExplorerOptions: "文件资源管理器选项", - programsAndFeatures: "程序和功能", - calculator: "计算器", - services: "服务", - commandPrompt: "命令提示符", - taskManager: "任务管理器", - registryEditor: "注册表编辑器", - powerOptions: "电源选项", - menu: "菜单", - close: "关闭", - edgeAutoHide: "停靠在桌面边缘时自动隐藏", - startupTray: "启动后最小化到系统托盘", - save: "保存", - lockItem: "锁定项目", - unlockItem: "解锁项目", - copyFullPath: "复制完整路径", - lockSize: "锁定尺寸", - classification: "分类", - width: "宽度", - size: "尺寸", - hideLosingFocus: "失去焦点后隐藏", - mouseHover: "鼠标悬停", - switch: "切换", - useItemOpen: "从程序外拖动文件到项目图标上时用此项目打开文件", - hideTray: "隐藏托盘图标", - middleClick: "中键单击", - mouseWheel: "鼠标滚轮", - remark: "备注", - show: "显示", - sort: "排序", - ascendingOrder: "升序", - descendingOrder: "降序", - transparency: "窗口透明度", - byInitial: "按首字母", - recordOpenNumber: "记录打开次数", - openNumber: "打开次数", - byOpenNumber: "按打开次数", - fixedPosition: "固定位置", - data: "数据", - dataDirectory: "数据目录", - dataDirectoryNote: - '注意:无特殊需求请勿随意修改数据目录,如果修改数据目录后,会在Dawn Launcher程序目录的上一级目录创建名字为".dawn_launcher_profile"的文件来存储数据目录地址,请勿随意删除。', - select: "选择", - hide: "隐藏", - hideItemName: "隐藏名称", - alwaysCenter: "永远居中", - rewardAndSponsorship: "打赏&赞助", - showFollowMousePosition: "显示时跟随鼠标位置", - default: "默认", - quickSearch: "快速搜索", - rememberSelectionState: "记住选择状态", - onlyTileTakeEffect: "只在布局为“平铺”模式下生效。", - onlyListTakeEffect: "只在布局为“列表”模式下生效。", - left: "左侧", - top: "顶部", - right: "右侧", - enable: "启用", - lockClassification: "锁定分类", - unlockClassification: "解锁分类", - exportIcon: "导出图标", - information: "信息", - itemNameShowRowCount: "名称显示行数", - nameAlign: "名称对齐", - center: "居中", - webSearch: "网络搜索", - searchSource: "搜索源", - keyword: "关键字", - add: "新增", - wSearchKeyword: "{w}为搜索关键字。", - webSearchPrompt: '输入"冒号 + 关键字 + 空格"或"关键字 + 空格"使用网络搜索,例如使用谷歌搜索,输入":g"或"g",然后按下空格键,进入网络搜索模式。', - perfmon: "资源监视器", - computerManagement: "计算机管理", - openWith: "打开方式", - shutdown: "关机", - restart: "重启", - sleep: "睡眠", - lock: "锁定", - multipleItem: "多项目", - itemList: "项目列表", - selectedItems: "已选项目", - startMenu: "开始菜单", - loading: "加载中", - hoverMS: "悬停[毫秒]", - numberOfColumns: "列数", - globalShortcutKey: "全局快捷键", - backgroundTransparency: "背景透明度", - function: "功能", - checkInvalidItem: "检查无效项目", - useIconBackgroundColor: "使用图标背景颜色", - doNotDisturb: "勿扰模式", - doNotDisturbNote: "开启勿扰模式后,计算机在游戏、应用全屏模式下不会弹出Dawn Launcher窗口。", - createDesktopShortcut: "创建快捷方式", - fontSize: "字体大小", - network: "网络", - proxy: "代理", - useProxy: "使用代理", - username: "用户名", - password: "密码", - address: "地址", - proxyNote: "仅支持HTTP代理,填写“地址”时需要带通信协议和端口,例如:http://127.0.0.1:7890,如果没有用户名和密码,为空即可。", - color: "颜色", - fontShadow: "字体阴影", - mainColor: "主色", - secondaryColor: "副色", - mainFontColor: "字体主色", - secondaryFontColor: "字体副色", - borderColor: "边框色", - backgroundImage: "背景图", - backgroundImageMode: "背景图模式", - repeat: "重复", - notRepeat: "不重复", - zoom: "缩放", - backgroundImagePosition: "背景图定位", - bottom: "底部", - windowRoundedCorners: "窗口圆角", - doubleClickTaskbar: "双击任务栏", - refreshIconCache: "刷新图标缓存", - extraLarge: "超大", - titleBar: "标题栏", - title: "标题", - setClassificationIcon: "设置分类图标", - setIcon: "设置图标", - deleteIcon: "删除图标", - iconMode: "图标模式", - mode: "模式", - normal: "普通", - icon: "图标", - toRelativePath: "转相对路径", - toAbsolutePath: "转绝对路径", - delayDisplayMS: "延迟显示[毫秒]", - delayHidingMS: "延迟隐藏[毫秒]", - explorerMenu: "资源管理器菜单", - associatedFolder: "关联文件夹", - associatedFolderMessage: "设置关联文件夹会清空原分类下所有项目,请谨慎操作,是否确认?", - numberKey: "数字键", - none: "无", - ctrlNumberKey: "Ctrl + 数字键", - altNumberKey: "Alt + 数字键", - fixedClassification: "固定分类", - autoSwitchClassification: "项目列表滚动到底部或顶部时自动切换分类", - colonKeywordSpace: "冒号 + 关键字 + 空格", - keywordSpace: "关键字 + 空格", - excludeSearch: "排除搜索", - modifyIcon: "修改图标", - switchEnglish: "显示窗口时将输入法切换为英文模式", - startLocation: "起始位置", - startLocationNote: "无特殊需求为空即可", - batchOperation: "批量操作", - cancelBatchOperation: "取消批量操作", - openNow: "仅剩一项时立即打开", - backgroundImageTransparency: "背景图透明度", - batchDeleteItemMessage: "是否批量删除所选项目?", - turnOffMonitor: "关闭显示器", - showOnlyFiles: "只显示文件", - showOnlyFolders: "只显示文件夹", - description: "描述", - deleteClassificationMessage: "是否删除当前分类?", - batchMoveItemMessage: "是否批量移动项目?", - batchCopyItemMessage: "是否批量复制项目?", - downloadImageFailedMessage: "下载图片失败。", - downloadImageNotImageFormatMessage: "链接不是图片格式。", - refreshIconCurrentClassificationMessage: "是否刷新当前分类下所有项目图标缓存?", - relativeCurrentClassificationMessage: "是否将当前分类下所有项目都转为相对路径?", - absoluteCurrentClassificationMessage: "是否将当前分类下所有项目都转为绝对路径?", - batchRefreshIconCache: "批量刷新图标缓存", - batchConversionRelativePath: "批量转为相对路径", - batchConversionAbsolutePath: "批量转为绝对路径", - convertRelativePath: "转为相对路径", - convertAbsolutePath: "转为绝对路径", - deleteItemMessage: "是否删除项目?", - clearItemMessage: "是否清空当前分类下所有项目?", - modifyDataDirectoryMessage: "是否确定修改数据目录,点击”确定“后,将修改数据目录并重启应用程序。", - backUpData: "备份数据", - restoreData: "恢复数据", - aggregateClassification: "聚合分类", - aggregateClassificationNote: "说明:聚合分类可以将所有分类下的项目聚合到一起,按照设置的排序方式、项目数量进行排序和显示。", - aggregateClassificationSortNote: "如果选择按打开次数排序,需要进入设置-项目-打开-记录打开次数,开启记录打开次数功能。", - aggregateClassificationMessage: "设置聚合分类会清空原分类下所有项目,请谨慎操作,是否确认?", - itemNumber: "项目数量", - byLastOpen: "按最近打开", - hiddenItem: "隐藏项", - hiddenItemNote: "输入需要隐藏文件/文件夹名称,多个按英文逗号分割。", - svgCodeIcon: "SVG代码图标", - svgCodeIconPlaceholder: "请输入SVG代码...", - svgCodeIconValidationNote: "输入SVG代码后,需要先点击“校验”按钮。", - networkIcon: "网络图标", - networkIconPlaceholder: "请输入链接地址...", - networkIconNote: "支持JPG、JPEG、GIF、PNG、ICO、SVG格式图片。", - getIcon: "获取图标", - localIcon: "本地图标", - notRefreshIcon: "不参与刷新图标缓存", - targetNotExist: "目标不存在", - switchClassificationCollapseOtherSubClassification: "切换分类时收起其他子分类", - hideWindowFoldChildClassification: "隐藏窗口时收起子分类", - displayMainInterface: "显示主界面", - hideThisItem: "隐藏该项", - selectAll: "全选", - emptyRecycleBin: "清空回收站", - matchingConditions: "匹配条件", - historyRecord: "历史记录", - openAfterHideQuickSearchWindow: "打开后隐藏快速搜索窗口", - subClassification: "子分类", - fontWeight: "字体粗细", - fontLineHeight: "字体行高", - }, - traditionalChinese: { - setting: "設定", - about: "關於", - checkForUpdates: "檢查更新", - checkForUpdatesNewVersionMessage: '檢查到有新版本,點選"確定"跳轉官網下載最新版本。', - checkForUpdatesLatestVersionMessage: "當前已經是最新版本。", - checkForUpdatesFailedMessage: "檢查更新失敗,請確認網路。", - exit: "退出", - ok: "確定", - cancel: "取消", - newClassification: "新建分類", - newSubClassification: "新建子分類", - editClassification: "編輯分類", - editSubClassification: "編輯子分類", - edit: "編輯", - delete: "刪除", - cut: "剪切", - copy: "復制", - paste: "黏貼", - notFoundFileMessage: "找不到指定的文件", - notFoundFolderMessage: "找不到指定的檔案夾", - newItem: "新建項目", - clearItem: "清空項目", - open: "打開", - runAsAdministrator: "以管理員身份運行", - openLocation: "打開文件所在的位置", - moveTo: "移動到", - copyTo: "復制到", - name: "名稱", - shortcutKey: "快捷鍵", - shortcutKeyIncompleteMessage: "快捷鍵不完整,請完善您的快捷鍵。", - shortcutKeyConflictMessage(text, type) { - if (type == 0) { - return '與"' + text + '"分類快捷鍵產生沖突,請重新設定。'; - } else { - return '與"' + text + '"項目快捷鍵產生沖突,請重新設定。'; - } - }, - shortcutKeyConflictSettingGeneralShowHideMessage: '與"設定-常規"中的"顯示/隱藏"快捷鍵產生沖突,請重新設定。', - shortcutKeyConflictSettingItemSearchMessage: '與"設定-項目"中的"搜索"快捷鍵產生沖突,請重新設定。', - shortcutKeyConflictSettingQuickSearchShowHideMessage: '與"設定-快速搜索"中的"顯示/隱藏"快捷鍵產生沖突,請重新設定。', - editItem: "編輯項目", - colon: ":", - target: "目標", - browse: "瀏覽", - defaultIcon: "預設圖示", - url: "網址", - getUrlInfo: "獲取網址信息", - urlErrorMessage: "獲取網址信息失敗,請手動填寫。", - arguments: "參數", - file: "文件", - folder: "檔案夾", - gettingUrlInfo: "獲取中", - officialWebsite: "官方網站", - start: "啟動", - autoStart: "開機啟動", - showHide: "顯示/隱藏", - language: "語言", - theme: "主題", - search: "搜索", - doubleClickOpen: "雙擊打開", - general: "常規", - appearance: "外觀", - item: "項目", - layout: "佈局", - iconSize: "圖示大小", - backupRestoreData: "備份/恢復數據", - backup: "備份", - restore: "恢復", - openAfterHideMainInterface: "打開後隱藏主界面", - tile: "平鋪", - list: "列錶", - large: "大", - medium: "中", - small: "小", - chinese: "简体中文", - traditionalChinese: "繁體中文", - window: "視窗", - alwaysTop: "永遠置頂", - notPrompt: "不再提示", - feedback: "反饋", - system: "繫統", - computer: "計算機", - document: "文檔", - controlPanel: "控制面闆", - networkAndSharingCenter: "網路和共享中心", - recycleBin: "回收站", - fileExplorerOptions: "文件資源管理器選項", - programsAndFeatures: "程式和功能", - calculator: "計算器", - services: "服務", - commandPrompt: "命令提示符", - taskManager: "任務管理器", - registryEditor: "註冊錶編輯器", - powerOptions: "電源選項", - menu: "菜單", - close: "關閉", - edgeAutoHide: "停靠在桌面邊緣時自動隱藏", - startupTray: "啟動後最小化到繫統托盤", - save: "保存", - lockItem: "鎖定項目", - unlockItem: "解鎖項目", - copyFullPath: "復制完整路徑", - lockSize: "鎖定尺寸", - classification: "分類", - width: "寬度", - size: "尺寸", - hideLosingFocus: "失去焦點後隱藏", - mouseHover: "滑鼠懸停", - switch: "切換", - useItemOpen: "從程式外拖動文件到項目圖示上時用此項目打開文件", - hideTray: "隱藏托盤圖示", - middleClick: "中鍵單擊", - mouseWheel: "滑鼠滾輪", - remark: "備註", - show: "顯示", - sort: "排序", - ascendingOrder: "升序", - descendingOrder: "降序", - transparency: "視窗透明度", - byInitial: "按首字母", - recordOpenNumber: "記錄打開次數", - openNumber: "打開次數", - byOpenNumber: "按打開次數", - fixedPosition: "固定位置", - data: "數據", - dataDirectory: "數據目錄", - dataDirectoryNote: - '註意:無特殊需求請勿隨意修改數據目錄,如果修改數據目錄後,會在Dawn Launcher程式目錄的上一級目錄創建名字為".dawn_launcher_profile"的文件來存儲數據目錄地址,請勿隨意刪除。', - select: "選擇", - hide: "隱藏", - hideItemName: "隱藏名稱", - alwaysCenter: "永遠居中", - rewardAndSponsorship: "打賞&贊助", - showFollowMousePosition: "顯示時跟隨滑鼠位置", - default: "預設", - quickSearch: "快速搜索", - rememberSelectionState: "記住選擇狀態", - onlyTileTakeEffect: "只在佈局為“平鋪”模式下生效。", - onlyListTakeEffect: "只在佈局為“列錶”模式下生效。", - left: "左側", - top: "頂部", - right: "右側", - enable: "啟用", - lockClassification: "鎖定分類", - unlockClassification: "解鎖分類", - exportIcon: "導出圖示", - information: "信息", - itemNameShowRowCount: "名稱顯示行數", - nameAlign: "名稱對齊", - center: "居中", - webSearch: "網路搜索", - searchSource: "搜索源", - keyword: "關鍵字", - add: "新增", - wSearchKeyword: "{w}為搜索關鍵字。", - webSearchPrompt: '輸入"冒號 + 關鍵字 + 空格"或"關鍵字 + 空格"使用網路搜索,例如使用谷歌搜索,輸入":g"或"g",然後按下空格鍵,進入網路搜索模式。', - perfmon: "資源監視器", - computerManagement: "計算機管理", - openWith: "打開方式", - shutdown: "關機", - restart: "重啟", - sleep: "睡眠", - lock: "鎖定", - multipleItem: "多項目", - itemList: "項目列錶", - selectedItems: "已選項目", - startMenu: "開始菜單", - loading: "加載中", - hoverMS: "懸停[毫秒]", - numberOfColumns: "列數", - globalShortcutKey: "全局快捷鍵", - backgroundTransparency: "背景透明度", - function: "功能", - checkInvalidItem: "檢查無效項目", - useIconBackgroundColor: "使用圖示背景顏色", - doNotDisturb: "勿擾模式", - doNotDisturbNote: "開啟勿擾模式後,計算機在遊戲、應用全屏模式下不會彈出Dawn Launcher視窗。", - createDesktopShortcut: "創建捷徑", - fontSize: "字體大小", - network: "網路", - proxy: "代理", - useProxy: "使用代理", - username: "用戶名", - password: "密碼", - address: "地址", - proxyNote: "僅支援HTTP代理,填寫“地址”時需要帶通信協議和端口,例如:http://127.0.0.1:7890,如果沒有用戶名和密碼,為空即可。", - color: "顏色", - fontShadow: "字體陰影", - mainColor: "主色", - secondaryColor: "副色", - mainFontColor: "字體主色", - secondaryFontColor: "字體副色", - borderColor: "邊框色", - backgroundImage: "背景圖", - backgroundImageMode: "背景圖模式", - repeat: "重復", - notRepeat: "不重復", - zoom: "縮放", - backgroundImagePosition: "背景圖定位", - bottom: "底部", - windowRoundedCorners: "視窗圓角", - doubleClickTaskbar: "雙擊任務欄", - refreshIconCache: "刷新圖示緩存", - extraLarge: "超大", - titleBar: "標題欄", - title: "標題", - setClassificationIcon: "設定分類圖示", - setIcon: "設定圖示", - deleteIcon: "刪除圖示", - iconMode: "圖示模式", - mode: "模式", - normal: "普通", - icon: "圖示", - toRelativePath: "轉相對路徑", - toAbsolutePath: "轉絕對路徑", - delayDisplayMS: "延遲顯示[毫秒]", - delayHidingMS: "延遲隱藏[毫秒]", - explorerMenu: "資源管理器菜單", - associatedFolder: "關聯檔案夾", - associatedFolderMessage: "設定關聯檔案夾會清空原分類下所有項目,請謹慎操作,是否確認?", - numberKey: "數字鍵", - none: "無", - ctrlNumberKey: "Ctrl + 數字鍵", - altNumberKey: "Alt + 數字鍵", - fixedClassification: "固定分類", - autoSwitchClassification: "項目列錶滾動到底部或頂部時自動切換分類", - colonKeywordSpace: "冒號 + 關鍵字 + 空格", - keywordSpace: "關鍵字 + 空格", - excludeSearch: "排除搜索", - modifyIcon: "修改圖示", - switchEnglish: "顯示視窗時將輸入法切換為英文模式", - startLocation: "起始位置", - startLocationNote: "無特殊需求為空即可", - batchOperation: "批量操作", - cancelBatchOperation: "取消批量操作", - openNow: "僅剩一項時立即打開", - backgroundImageTransparency: "背景圖透明度", - batchDeleteItemMessage: "是否批量刪除所選項目?", - turnOffMonitor: "關閉顯示器", - showOnlyFiles: "只顯示文件", - showOnlyFolders: "只顯示檔案夾", - description: "描述", - deleteClassificationMessage: "是否刪除當前分類?", - batchMoveItemMessage: "是否批量移動項目?", - batchCopyItemMessage: "是否批量復制項目?", - downloadImageFailedMessage: "下載圖片失敗。", - downloadImageNotImageFormatMessage: "鏈接不是圖片格式。", - refreshIconCurrentClassificationMessage: "是否刷新當前分類下所有項目圖示緩存?", - relativeCurrentClassificationMessage: "是否將當前分類下所有項目都轉為相對路徑?", - absoluteCurrentClassificationMessage: "是否將當前分類下所有項目都轉為絕對路徑?", - batchRefreshIconCache: "批量刷新圖示緩存", - batchConversionRelativePath: "批量轉為相對路徑", - batchConversionAbsolutePath: "批量轉為絕對路徑", - convertRelativePath: "轉為相對路徑", - convertAbsolutePath: "轉為絕對路徑", - deleteItemMessage: "是否刪除項目?", - clearItemMessage: "是否清空當前分類下所有項目?", - modifyDataDirectoryMessage: "是否確定修改數據目錄,點選”確定“後,將修改數據目錄併重啟應用程式。", - backUpData: "備份數據", - restoreData: "恢復數據", - aggregateClassification: "聚合分類", - aggregateClassificationNote: "說明:聚合分類可以將所有分類下的項目聚合到一起,按照設定的排序方式、項目數量進行排序和顯示。", - aggregateClassificationSortNote: "如果選擇按打開次數排序,需要進入設定-項目-打開-記錄打開次數,開啟記錄打開次數功能。", - aggregateClassificationMessage: "設定聚合分類會清空原分類下所有項目,請謹慎操作,是否確認?", - itemNumber: "項目數量", - byLastOpen: "按最近打開", - hiddenItem: "隱藏項", - hiddenItemNote: "輸入需要隱藏文件/檔案夾名稱,多個按英文逗號分割。", - svgCodeIcon: "SVG代碼圖示", - svgCodeIconPlaceholder: "請輸入SVG代碼...", - svgCodeIconValidationNote: "輸入SVG代碼後,需要先點選“校驗”按鈕。", - networkIcon: "網路圖示", - networkIconPlaceholder: "請輸入鏈接地址...", - networkIconNote: "支援JPG、JPEG、GIF、PNG、ICO、SVG格式圖片。", - getIcon: "獲取圖示", - localIcon: "在地圖示", - notRefreshIcon: "不參與刷新圖示緩存", - targetNotExist: "目標不存在", - switchClassificationCollapseOtherSubClassification: "切換分類時收起其他子分類", - hideWindowFoldChildClassification: "隱藏視窗時收起子分類", - displayMainInterface: "顯示主界面", - hideThisItem: "隱藏該項", - selectAll: "全選", - emptyRecycleBin: "清空回收站", - matchingConditions: "匹配條件", - historyRecord: "歷史記錄", - openAfterHideQuickSearchWindow: "開啟後隱藏快速搜尋視窗", - subClassification: "子分類", - fontWeight: "字體粗細", - fontLineHeight: "字體行高", - }, - }, - // 背景图 - backgroundImage: null, - // 图标 - iconDataMap: null, - }, - mutations: {}, - actions: {}, - modules: {}, -}); diff --git a/src/renderer/views/about/Index.vue b/src/renderer/views/about/Index.vue deleted file mode 100644 index bf17f72..0000000 --- a/src/renderer/views/about/Index.vue +++ /dev/null @@ -1,59 +0,0 @@ - - - - - diff --git a/src/renderer/views/classification/AddEdit.vue b/src/renderer/views/classification/AddEdit.vue deleted file mode 100644 index 9c4c6f2..0000000 --- a/src/renderer/views/classification/AddEdit.vue +++ /dev/null @@ -1,234 +0,0 @@ - - - - - diff --git a/src/renderer/views/classification/Aggregate.vue b/src/renderer/views/classification/Aggregate.vue deleted file mode 100644 index 82d7fbd..0000000 --- a/src/renderer/views/classification/Aggregate.vue +++ /dev/null @@ -1,146 +0,0 @@ - - - - - diff --git a/src/renderer/views/classification/AssociatedFolder.vue b/src/renderer/views/classification/AssociatedFolder.vue deleted file mode 100644 index 2b32fe5..0000000 --- a/src/renderer/views/classification/AssociatedFolder.vue +++ /dev/null @@ -1,165 +0,0 @@ - - - - - diff --git a/src/renderer/views/classification/Icon.vue b/src/renderer/views/classification/Icon.vue deleted file mode 100644 index 3069198..0000000 --- a/src/renderer/views/classification/Icon.vue +++ /dev/null @@ -1,12281 +0,0 @@ - - - - - diff --git a/src/renderer/views/classification/js/index.js b/src/renderer/views/classification/js/index.js deleted file mode 100644 index 06e8912..0000000 --- a/src/renderer/views/classification/js/index.js +++ /dev/null @@ -1,59 +0,0 @@ -import store from "@/store"; -import CommonJS from "@/common"; - -export default { - /** - * 根据ID获取分类 - * @param parentId - * @param childId - * @returns {null|*} - */ - getClassificationById(parentId, childId) { - if (parentId != null) { - let classificationParent; - for (let c of store.state.list) { - if (c.id == parentId) { - classificationParent = c; - break; - } - } - if (classificationParent != null && childId != null) { - if (!CommonJS.arrayIsEmpty(classificationParent.childList)) { - let classificationChild; - for (let c of classificationParent.childList) { - if (c.id == childId) { - classificationChild = c; - break; - } - } - return classificationChild; - } else { - return classificationParent; - } - } else { - return classificationParent; - } - } - return null; - }, - /** - * 转换ID - * @param id - * @param parentId - */ - convertClassificationId(id, parentId) { - return { classificationParentId: parentId != null ? parentId : id, classificationChildId: parentId != null ? id : null }; - }, - /** - * 获取分类图标 - * @param c - * @returns {string} - */ - getIcon(c) { - if (c.icon != null) { - return c.icon + " "; - } else { - return ""; - } - }, -}; diff --git a/src/renderer/views/data/BackupRestore.vue b/src/renderer/views/data/BackupRestore.vue deleted file mode 100644 index 79324c7..0000000 --- a/src/renderer/views/data/BackupRestore.vue +++ /dev/null @@ -1,58 +0,0 @@ - - - - - diff --git a/src/renderer/views/index/Index.vue b/src/renderer/views/index/Index.vue deleted file mode 100644 index 146b729..0000000 --- a/src/renderer/views/index/Index.vue +++ /dev/null @@ -1,4246 +0,0 @@ - - - diff --git a/src/renderer/views/index/js/index.js b/src/renderer/views/index/js/index.js deleted file mode 100644 index ce7bc92..0000000 --- a/src/renderer/views/index/js/index.js +++ /dev/null @@ -1,2 +0,0 @@ -export default { -}; \ No newline at end of file diff --git a/src/renderer/views/item/AddEdit.vue b/src/renderer/views/item/AddEdit.vue deleted file mode 100644 index 5da9f51..0000000 --- a/src/renderer/views/item/AddEdit.vue +++ /dev/null @@ -1,1564 +0,0 @@ - - - - diff --git a/src/renderer/views/item/ItemList.vue b/src/renderer/views/item/ItemList.vue deleted file mode 100644 index 8b4b44d..0000000 --- a/src/renderer/views/item/ItemList.vue +++ /dev/null @@ -1,523 +0,0 @@ - - - - - diff --git a/src/renderer/views/item/SVGIcon.vue b/src/renderer/views/item/SVGIcon.vue deleted file mode 100644 index e63c605..0000000 --- a/src/renderer/views/item/SVGIcon.vue +++ /dev/null @@ -1,127 +0,0 @@ - - - - - diff --git a/src/renderer/views/item/URLIcon.vue b/src/renderer/views/item/URLIcon.vue deleted file mode 100644 index d5a1839..0000000 --- a/src/renderer/views/item/URLIcon.vue +++ /dev/null @@ -1,150 +0,0 @@ - - - - - diff --git a/src/renderer/views/item/js/index.js b/src/renderer/views/item/js/index.js deleted file mode 100644 index a3a0dba..0000000 --- a/src/renderer/views/item/js/index.js +++ /dev/null @@ -1,222 +0,0 @@ -import store from "@/store"; -import CommonJS from "@/common"; -const { ipcRenderer } = window.require("electron"); - -export default { - /** - * 运行项目 - * @param item - * @param location - * @param recordQuickSearch 记录快速搜索数据 - */ - itemRun(item, location, recordQuickSearch) { - if (item.type == 4) { - if (!CommonJS.arrayIsEmpty(item.itemList)) { - for (let iItem of item.itemList) { - ipcRenderer.send( - "itemRun", - JSON.stringify({ - item: iItem, - location: false, - recordQuickSearch: recordQuickSearch != null ? recordQuickSearch : false, - }) - ); - } - } - } else { - ipcRenderer.send( - "itemRun", - JSON.stringify({ - item: item, - location: location, - recordQuickSearch: recordQuickSearch != null ? recordQuickSearch : false, - }) - ); - } - if (store.state.setting.item.openAfterHideMainInterface == true) { - ipcRenderer.send("hideMainWindow"); - } - }, - /** - * 查询项目 - * @param classification - * @param id - */ - getItemById(classification, id) { - for (let item of classification.itemList) { - if (item.id == id) { - return item; - } - } - return null; - }, - /** - * 设置项目分类ID - * @param item - * @param classificationParentId - * @param classificationChildId - */ - setItemClassificationId(item, classificationParentId, classificationChildId) { - if (classificationChildId != null) { - item.classificationParentId = classificationParentId; - item.classificationId = classificationChildId; - } else { - item.classificationId = classificationParentId; - item.classificationParentId = null; - } - return item; - }, - /** - * 获取标题 - * @param item - */ - getItemTitle(item) { - let name = this.$store.state.currentLanguage.name + this.$store.state.currentLanguage.colon + item.name.replace(/\\n/g, " "); - if (this.$store.state.setting.item.openNumber) { - name += "\n" + this.$store.state.currentLanguage.openNumber + this.$store.state.currentLanguage.colon + (item.openNumber == null ? 0 : item.openNumber); - } - if (!CommonJS.strIsEmpty(item.remark)) { - name += "\n" + this.$store.state.currentLanguage.remark + this.$store.state.currentLanguage.colon + item.remark; - } - return name; - }, - /** - * 设置拼音 - */ - setPinyin(item) { - // if (hasChinese(item.name)) { - // // 拼音 - // let pinyin = cnchar.spell(item.name, "array", "poly"); - // let pinyinList = []; - // if (pinyin != null && pinyin.length > 0) { - // for (let py of pinyin) { - // let newList = []; - // let list = py.replace("(", "").replace(")", "").split("|"); - // for (let str of list) { - // if (!newList.some((nStr) => str == nStr)) { - // newList.push(str); - // } - // } - // pinyinList.push(newList); - // } - // } - // if (pinyinList.length > 0) { - // item.pinyin = merge(pinyinList); - // } - // // 首字母 - // let pinyinFirst = cnchar.spell(item.name, "array", "poly", "first"); - // let pinyinFirstList = []; - // if (pinyinFirst != null && pinyinFirst.length > 0) { - // for (let py of pinyinFirst) { - // let newList = []; - // let list = py.replace("(", "").replace(")", "").split("|"); - // for (let str of list) { - // if (!newList.some((nStr) => str == nStr)) { - // newList.push(str); - // } - // } - // pinyinFirstList.push(newList); - // } - // } - // if (pinyinFirstList.length > 0) { - // item.initial = merge(pinyinFirstList); - // } - // } - }, - /** - * 设置缩写 - * @param item - */ - setAbbr(item) { - if (!CommonJS.strIsEmpty(item.name)) { - let name = item.name.replace(/\\n/g, " "); - let split = name.split(" "); - let abbr = ""; - for (let i = 0; i < split.length; i++) { - if (!CommonJS.strIsEmpty(split[i])) { - abbr += split[i].slice(0, 1); - } - } - item.abbr = abbr; - } - }, - /** - * 获取名称 - */ - getName(name) { - return name.replace(/\\n/g, " "); - }, - /** - * 排序 - * @param type - * @param key - */ - sort(itemList, type, key) { - if (type == "initial") { - return itemList.sort((x, y) => { - let xn, yn; - if (!CommonJS.strIsEmpty(x.pinyin)) { - xn = x.pinyin.toLowerCase().charAt(0); - } else { - xn = x.name.toLowerCase().charAt(0); - } - if (!CommonJS.strIsEmpty(y.pinyin)) { - yn = y.pinyin.toLowerCase().charAt(0); - } else { - yn = y.name.toLowerCase().charAt(0); - } - // 判断是否是数字 - if (isNaN(xn) == false && isNaN(yn) == true) { - // xn是数字而yn不是,返回1 - return 1; - } - if (isNaN(yn) == false && isNaN(xn) == true) { - // yn是数字而xn不是,返回-1 - return -1; - } - if (xn < yn) { - return -1; - } - if (xn > yn) { - return 1; - } - if (xn == yn) { - if (x.name < y.name) { - return -1; - } - if (x.name < y.name) { - return 1; - } - } - return 0; - }); - } else if (type == "openNumber" || type == "lastOpen") { - return itemList.sort((x, y) => { - let xn = x[key] == null ? 0 : x[key]; - let yn = y[key] == null ? 0 : y[key]; - if (xn < yn) { - return -1; - } - if (xn > yn) { - return 1; - } - if (xn == yn) { - if (x.name < y.name) { - return -1; - } - if (x.name < y.name) { - return 1; - } - } - return 0; - }); - } - }, - /** - * 是否是绝对路径 - */ - isAbsolutePath(path) { - const regex = /^[a-zA-Z]:\\/; - return regex.test(path); - }, -}; diff --git a/src/renderer/views/item/js/systemIcon.js b/src/renderer/views/item/js/systemIcon.js deleted file mode 100644 index d5eeb8b..0000000 --- a/src/renderer/views/item/js/systemIcon.js +++ /dev/null @@ -1,59 +0,0 @@ -export default { - computer(release) { - return release.indexOf("10.0.2") >= 0 - ? "" - : ""; - }, - document(release) { - return release.indexOf("10.0.2") >= 0 - ? "" - : ""; - }, - controlPanel(release) { - return release.indexOf("10.0.2") >= 0 - ? "" - : ""; - }, - networkAndSharingCenter() { - return ""; - }, - recycleBin(release) { - return release.indexOf("10.0.2") >= 0 - ? "" - : ""; - }, - fileExplorerOptions(release) { - return release.indexOf("10.0.2") >= 0 - ? "" - : ""; - }, - programsAndFeatures() { - return ""; - }, - calculator() { - return ""; - }, - services() { - return ""; - }, - commandPrompt() { - return ""; - }, - taskManager(release) { - return release.indexOf("10.0.2") >= 0 - ? "" - : ""; - }, - registryEditor() { - return ""; - }, - powerOptions() { - return ""; - }, - perfmon() { - return ""; - }, - computerManagement() { - return ""; - }, -}; diff --git a/src/renderer/views/search/Index.vue b/src/renderer/views/search/Index.vue deleted file mode 100644 index c1f9761..0000000 --- a/src/renderer/views/search/Index.vue +++ /dev/null @@ -1,356 +0,0 @@ - - - - - diff --git a/src/renderer/views/search/Window.vue b/src/renderer/views/search/Window.vue deleted file mode 100644 index 0da1aa8..0000000 --- a/src/renderer/views/search/Window.vue +++ /dev/null @@ -1,806 +0,0 @@ - - - - diff --git a/src/renderer/views/search/js/index.js b/src/renderer/views/search/js/index.js deleted file mode 100644 index 201fc09..0000000 --- a/src/renderer/views/search/js/index.js +++ /dev/null @@ -1,149 +0,0 @@ -import PinyinMatch from "pinyin-match"; -import CommonJS from "@/common"; -import ItemJS from "@/views/item/js/index"; -import ClassificationJS from "@/views/classification/js/index"; -import store from "@/store"; - -/** - * 判断是否有中文 - * @param str - * @returns {boolean} - */ -function hasChinese(str) { - const pattern = /[\u4e00-\u9fa5]/; // 中文字符的 Unicode 范围 - return pattern.test(str); -} - -/** - * 判断是否是URL - * @param str - * @returns {boolean} - */ -function hasURL(str) { - const pattern = /[a-zA-Z]+:\/\/[^\\s]*/; - return pattern.test(str); -} - -export default { - convertToMap(list) { - let itemMap = new Map(); - // 将数据转为Map - for (let i of list) { - if (i.excludeSearch == null || !i.excludeSearch) { - if (!CommonJS.arrayIsEmpty(i.childList)) { - for (let c of i.childList) { - if (c.excludeSearch == null || !c.excludeSearch) { - this.setMap(itemMap, c.itemList, i.id + "-" + c.id, ClassificationJS.getIcon(i) + i.name + "/" + ClassificationJS.getIcon(c) + c.name); - } - } - } else { - this.setMap(itemMap, i.itemList, i.id, ClassificationJS.getIcon(i) + i.name); - } - } - } - return itemMap; - }, - /** - * 放数据 - */ - setMap(itemMap, itemList, classificationIds, classificationName) { - if (!CommonJS.arrayIsEmpty(itemList)) { - for (let t of itemList) { - // 设置信息 - let item = JSON.parse(JSON.stringify(t)); - item.classificationName = classificationName; - item.classificationIds = classificationIds; - // 名称 - let name = ItemJS.getName(item.name).toLowerCase(); - let list = itemMap.get(name); - if (CommonJS.arrayIsEmpty(list)) { - list = []; - } - list.push(item); - itemMap.set(name, list); - // 缩写 - if (!CommonJS.strIsEmpty(t.abbr)) { - let abbr = t.abbr.toLowerCase(); - let abbrList = itemMap.get(abbr); - if (CommonJS.arrayIsEmpty(abbrList)) { - abbrList = []; - } - abbrList.push(item); - itemMap.set(abbr, abbrList); - } - // 网址 - if (t.type == 2 && !CommonJS.strIsEmpty(t.url)) { - let url = t.url.toLowerCase(); - let urlList = itemMap.get(url); - if (CommonJS.arrayIsEmpty(urlList)) { - urlList = []; - } - urlList.push(item); - itemMap.set(url, urlList); - } - // 备注搜索 - if (store.state.setting.quickSearch.matchingConditionsRemark) { - if (!CommonJS.strIsEmpty(t.remark)) { - let remark = t.remark.toLowerCase(); - let remarkList = itemMap.get(remark); - if (CommonJS.arrayIsEmpty(remarkList)) { - remarkList = []; - } - remarkList.push(item); - itemMap.set(remark, remarkList); - } - } - } - } - }, - /** - * 搜索 - */ - search(name, itemMap) { - let resultList = []; - if (!CommonJS.strIsEmpty(name)) { - let n = name.toLowerCase(); - for (let [key, value] of itemMap.entries()) { - let flag = false; - if (hasURL(key)) { - // 网址 - flag = key.indexOf(n) >= 0; - } else if (hasChinese(key)) { - // 包含中文 - let match = PinyinMatch.match(key, n); - if (match != null && match.length > 0) { - flag = true; - } - } else { - // 其他情况 - flag = key.indexOf(n) >= 0; - } - if (flag) { - for (let v of value) { - let flag = false; - if (v.id != null && v.classificationIds != null) { - for (let r of resultList) { - if (v.classificationIds == r.classificationIds && v.id == r.id) { - flag = true; - break; - } - } - } else { - for (let r of resultList) { - if (v.name == r.name) { - flag = true; - break; - } - } - } - if (!flag) { - resultList.push(v); - } - } - } - } - } - resultList.sort((a, b) => a.name.localeCompare(b.name)); - return resultList; - }, -}; diff --git a/src/renderer/views/setting/Index.vue b/src/renderer/views/setting/Index.vue deleted file mode 100644 index 7667fec..0000000 --- a/src/renderer/views/setting/Index.vue +++ /dev/null @@ -1,1992 +0,0 @@ - - - - - diff --git a/src/renderer/views/setting/js/index.js b/src/renderer/views/setting/js/index.js deleted file mode 100644 index 9303021..0000000 --- a/src/renderer/views/setting/js/index.js +++ /dev/null @@ -1,27 +0,0 @@ -const { ipcRenderer } = window.require("electron"); - -export default { - /** - * 重新设置 - */ - resetSetting(setting) { - // 开机启动 - ipcRenderer.send("setAutoLaunch", setting.general.startup); - // 隐藏托盘图标 - ipcRenderer.send("setTray", !setting.general.hideTray); - // 永远置顶 - ipcRenderer.send("setAlwaysTop", setting.general.alwaysTop); - // 锁定尺寸 - ipcRenderer.send("setResize", !setting.general.lockSize); - // 固定位置 - ipcRenderer.send("setFixedPosition", [!setting.general.fixedPosition, setting.general.alwaysCenter]); - // 永远居中 - ipcRenderer.send("setAlwaysCenter", [setting.general.alwaysCenter, !setting.general.fixedPosition, setting.general.alwaysCenter]); - // 隐藏任务栏 - ipcRenderer.send("setHideTaskbar", setting.general.hideTaskbar); - // 设置透明度 - ipcRenderer.send("setOpacity", setting.appearance.transparency); - // 设置快捷键 - ipcRenderer.send("setShortcutKey", JSON.stringify(setting)); - }, -}; diff --git a/src/router/index.ts b/src/router/index.ts new file mode 100644 index 0000000..6be5a37 --- /dev/null +++ b/src/router/index.ts @@ -0,0 +1,77 @@ +import { + createRouter, + createWebHashHistory, + createWebHistory, + RouteRecordRaw, +} from "vue-router"; + +let prod = import.meta.env.PROD; + +const routes: Array = [ + { + path: "/", + component: () => import("../pages/index/Index.vue"), + }, + { + name: "SettingIndex", + path: "/Setting/Index", + component: () => import("../pages/setting/Index.vue"), + }, + { + name: "ClassificationAddEdit", + path: "/Classification/AddEdit", + component: () => import("../pages/classification/AddEdit.vue"), + }, + { + name: "ClassificationSetIcon", + path: "/Classification/SetIcon", + component: () => import("../pages/classification/SetIcon.vue"), + }, + { + name: "ClassificationAssociateFolder", + path: "/Classification/AssociateFolder", + component: () => import("../pages/classification/AssociateFolder.vue"), + }, + { + name: "ClassificationAggregate", + path: "/Classification/Aggregate", + component: () => import("../pages/classification/Aggregate.vue"), + }, + { + name: "ItemAddEdit", + path: "/Item/AddEdit", + component: () => import("../pages/item/AddEdit.vue"), + }, + { + name: "ItemNetworkIcon", + path: "/Item/NetworkIcon", + component: () => import("../pages/item/NetworkIcon.vue"), + }, + { + name: "ItemSVGIcon", + path: "/Item/SVGIcon", + component: () => import("../pages/item/SVGIcon.vue"), + }, + { + name: "QuickSearch", + path: "/Search/QuickSearch", + component: () => import("../pages/search/QuickSearch.vue"), + }, + { + name: "About", + path: "/About", + component: () => import("../pages/about/Index.vue"), + }, + { + name: "BackupRestoreData", + path: "/Data/BackupRestore", + component: () => import("../pages/data/BackupRestore.vue"), + }, +]; + +const router = createRouter({ + history: prod ? createWebHashHistory() : createWebHistory(), + routes, +}); + +export default router; diff --git a/src/store/index.ts b/src/store/index.ts new file mode 100644 index 0000000..42679dd --- /dev/null +++ b/src/store/index.ts @@ -0,0 +1,79 @@ +import { defineStore } from "pinia"; +import { Setting } from "../../types/setting"; +import { Classification } from "../../types/classification"; +import { getSetting } from "../../commons/utils/setting"; +import { Item } from "../../types/item"; +import { getLanguage } from "../../commons/data/languages"; + +export interface State { + // 设置 + setting: Setting; + // 分类列表 + classificationList: Array; + // 项目数据 + itemMap: Map>; + // 当前选中的父级分类ID + selectedClassificationParentId: number | null; + // 当前选中的子级分类ID + selectedClassificationChildId: number | null; + // 鼠标悬浮在分类上时的分类ID + mouseoverClassificationId: number | null; + // 分类是否在拖拽中 + classificationSorting: boolean; + // 滚轮切换分类事件 + classificationWheelEvent: WheelEvent | null; + // 项目是否在拖拽中 + itemSorting: boolean; + // 项目是否再拖出中 + itemDragOut: boolean; + // 项目拖出数据 + itemDragOutData: Item | null; + // 项目批量操作 + itemBatchOperation: boolean; + // 项目批量操作存储已选中项目 + itemBatchOperationDataArray: Array; + // 项目区域右键ID + itemRightMenuItemId: number | null; + // 无效项目 + invalidItemIdList: Array; + // 背景图 + backgroundImage: string | null; + // 重新加载项目列表标识 + reloadItemList: boolean; + // 搜索显示/隐藏标识 + search: boolean; + // 搜索功能项目区域右键ID + searchItemRightMenuItemId: number | null; + // 快速搜索功能项目区域右键ID + quickSearchItemRightMenuItemId: number | null; + // 当前语言 + language: any; +} + +export const useMainStore = defineStore("main", { + state: (): State => { + return { + setting: getSetting(null), + classificationList: [], + itemMap: new Map(), + selectedClassificationParentId: null, + selectedClassificationChildId: null, + mouseoverClassificationId: null, + classificationSorting: false, + classificationWheelEvent: null, + itemSorting: false, + itemDragOut: false, + itemDragOutData: null, + itemBatchOperation: false, + itemBatchOperationDataArray: [], + itemRightMenuItemId: null, + invalidItemIdList: [], + backgroundImage: null, + reloadItemList: false, + search: false, + searchItemRightMenuItemId: null, + quickSearchItemRightMenuItemId: null, + language: getLanguage(null), + }; + }, +}); diff --git a/src/renderer/style/main.css b/src/styles/style.css similarity index 61% rename from src/renderer/style/main.css rename to src/styles/style.css index 037e223..57d56e3 100644 --- a/src/renderer/style/main.css +++ b/src/styles/style.css @@ -1,5 +1,46 @@ body { font-family: system-ui; + margin: 0; + user-select: none; + -webkit-user-select: none; + cursor: default; + overflow: hidden; +} + +h1 { + font-weight: 400; + margin: 0; +} + +ul, +p { + margin: 0; + padding: 0; +} + +li { + list-style: none; +} + +:focus { + outline: none; +} + +input[type="range"] { + -webkit-appearance: none; + appearance: none; + background: transparent; + cursor: pointer; +} + +input[type="range"]:focus { + outline: none; +} + +input { + font-family: system-ui; + padding: 0; + border: none; } input:focus, @@ -19,14 +60,6 @@ input::-webkit-inner-spin-button { -webkit-appearance: none; } -input[type="number"] { - -moz-appearance: textfield; -} - -body { - overflow: hidden; -} - .app-region-drag { -webkit-app-region: drag; } @@ -35,25 +68,12 @@ body { -webkit-app-region: no-drag; } -.popup-header { - cursor: move; -} - -.right-menu.visible { - transform: scale(1); - transition: transform ease-in-out; -} - .simplebar-track.simplebar-vertical, .simplebar-track.simplebar-horizontal { width: 8px !important; top: -2px !important; } -textarea::-webkit-scrollbar { - width: 7px; -} - .item-name-tile-2 { word-break: break-all; overflow: hidden; @@ -85,3 +105,19 @@ textarea::-webkit-scrollbar { word-break: break-all; overflow: hidden; } + +.item-name-list { + word-break: break-all; + overflow: hidden; + text-overflow: ellipsis; + display: -webkit-box; + -webkit-line-clamp: 1; + line-clamp: 1; + -webkit-box-orient: vertical; +} + +.item-name-list-no-ellipsis { + max-height: 20px; + word-break: break-all; + overflow: hidden; +} diff --git a/src/renderer/style/tailwind.css b/src/styles/tailwind.css similarity index 64% rename from src/renderer/style/tailwind.css rename to src/styles/tailwind.css index b5c61c9..bd6213e 100644 --- a/src/renderer/style/tailwind.css +++ b/src/styles/tailwind.css @@ -1,3 +1,3 @@ @tailwind base; @tailwind components; -@tailwind utilities; +@tailwind utilities; \ No newline at end of file diff --git a/src/utils/common.ts b/src/utils/common.ts new file mode 100644 index 0000000..b4d9b23 --- /dev/null +++ b/src/utils/common.ts @@ -0,0 +1,243 @@ +import SimpleBar from "simplebar"; + +/** + * 组装URL + * @param url + * @param paramsMap + * @returns + */ +function getURL(url: string, paramsMap: Map): string { + let res = url; + if (paramsMap.size > 0) { + res += "?"; + let params: string | null = null; + for (let [key, value] of paramsMap.entries()) { + if (params) { + params += "&" + key + "=" + value; + } else { + params = key + "=" + value; + } + } + res += params; + } + return res; +} + +/** + * 滚动条置顶 + * @param simpleBar + */ +function scrollToTop(simpleBar: SimpleBar | null) { + if (simpleBar) { + let scroll = simpleBar.getScrollElement(); + if (scroll) { + scroll.scrollTop = 0; + } + } +} + +/** + * 寻找父级 + * @param e + * @param className + */ +function findElement(target: any, className: string) { + if (target && target.classList) { + let flag = false; + for (const clazz of target.classList) { + if (clazz === className) { + flag = true; + break; + } + } + if (flag) { + return target; + } else { + if (target.parentElement) { + return findElement(target.parentElement, className); + } + } + } + return null; +} + +/** + * 取消监听 + * @param arr + */ +function unlistens(arr: Array) { + for (const func of arr) { + if (func) { + func(); + } + } +} + +/** + * 获取新ID + */ +function getNewId(list: Array) { + if (list == null || list.length == 0) { + return 1; + } + // 获取ID列表 + let idList = list.map((item) => item.id); + // 获取最大ID + let maxId = Math.max(...idList); + // +1 + return ++maxId; +} + +/** + * 校验KeyCode + * @param e + * @returns + */ +function checkKeyCode(e: any) { + // (e.keyCode >= 48 && e.keyCode <= 57) 键盘上方数字 + // (e.keyCode >= 65 && e.keyCode <= 90) 键盘字母a-z不区分大小写 + // (e.keyCode >= 96 && e.keyCode <= 111) 数字键盘 + // (e.keyCode >= 112 && e.keyCode <= 135) 键盘F1到F24 + // e.keyCode == 8 退格键 + // e.keyCode == 9 Tab + // e.keyCode == 12 Clear + // e.keyCode == 13 回车 + // e.keyCode == 16 Shift + // e.keyCode == 17 Control + // e.keyCode == 18 Alt + // e.keyCode == 20 Cape Lock 大小写 + // e.keyCode == 27 Esc + // (e.keyCode >= 32 && e.keyCode <= 40) 控制键盘区 + // e.keyCode == 45 Insert + // e.keyCode == 46 Delete + // e.keyCode == 144 Num Lock + // (e.keyCode >= 186 && e.keyCode <= 192) 符号;: =+ ,< -_ .> /? `~ + // (e.keyCode >= 219 && e.keyCode <= 222) 符号[{ \| ]} '" + if ( + (e.keyCode >= 48 && e.keyCode <= 57) || + (e.keyCode >= 65 && e.keyCode <= 90) || + (e.keyCode >= 96 && e.keyCode <= 111) || + (e.keyCode >= 112 && e.keyCode <= 135) || + e.keyCode === 8 || + e.keyCode === 9 || + e.keyCode === 12 || + e.keyCode === 13 || + e.keyCode === 16 || + e.keyCode === 17 || + e.keyCode === 18 || + e.keyCode === 20 || + e.keyCode === 27 || + (e.keyCode >= 32 && e.keyCode <= 40) || + e.keyCode === 45 || + e.keyCode === 46 || + e.keyCode === 144 || + (e.keyCode >= 186 && e.keyCode <= 192) || + (e.keyCode >= 219 && e.keyCode <= 222) + ) { + return true; + } + return false; +} + +/** + * 获取快捷键 + * @param e + * @param originalVal + * @param preventDefault + * @returns + */ +function getShortcutKey( + e: any, + originalVal: string | null, + preventDefault: boolean +) { + if (preventDefault) { + e.preventDefault(); + } + if (checkKeyCode(e)) { + // Esc + if (e.keyCode === 27) { + return originalVal; + } + if (e.keyCode === 8) { + return null; + } else { + let keys = []; + // 如果是组合键 + if (e.ctrlKey && e.keyCode != 17) { + keys.push("Ctrl + "); + } + if (e.altKey && e.keyCode != 18) { + keys.push("Alt + "); + } + if (e.metaKey && e.keyCode != 91) { + keys.push("Win + "); + } + if (e.shiftKey && e.keyCode != 16) { + keys.push("Shift + "); + } + // 非组合键情况,按键是ctrl alt shift win + if ( + e.keyCode === 16 || + e.keyCode === 17 || + e.keyCode === 18 || + e.keyCode === 91 + ) { + let key; + if (e.ctrlKey && e.keyCode === 17) { + key = "Ctrl + "; + } + if (e.altKey && e.keyCode === 18) { + key = "Alt + "; + } + if (e.metaKey && e.keyCode === 91) { + key = "Win + "; + } + if (e.shiftKey && e.keyCode === 16) { + key = "Shift + "; + } + keys.push(key); + } else { + // 排序 + keys.sort((a, b) => a.localeCompare(b)); + // 其他 + if (e.key.toUpperCase() === "ENTER") { + keys.push("Enter"); + } else { + if (e.keyCode === 32) { + keys.push("Space"); + } else if (e.keyCode >= 96 && e.keyCode <= 105) { + keys.push("Num" + e.key); + } else if (e.keyCode >= 106 && e.keyCode <= 111) { + if (e.keyCode === 106) { + keys.push("NumMult"); + } else if (e.keyCode === 107) { + keys.push("NumAdd"); + } else if (e.keyCode === 109) { + keys.push("NumSub"); + } else if (e.keyCode === 110) { + keys.push("NumDec"); + } else if (e.keyCode === 111) { + keys.push("NumDiv"); + } + } else { + keys.push(e.key.replace("Arrow", "").toUpperCase()); + } + } + } + return keys.join(""); + } + } else { + return null; + } +} + +export { + getURL, + scrollToTop, + findElement, + unlistens, + getNewId, + getShortcutKey, + checkKeyCode, +}; diff --git a/src/utils/localSetting.ts b/src/utils/localSetting.ts new file mode 100644 index 0000000..1ae17e5 --- /dev/null +++ b/src/utils/localSetting.ts @@ -0,0 +1,39 @@ +/** + * 获取本地配置 + */ +function getLocalSetting(key: string): T | null { + let value = localStorage.getItem(key); + if (!value) { + return null; + } else { + return value as T; + } +} + +/** + * 设置本地配置 + */ +function setLocalSetting(key: string, value: string) { + localStorage.setItem(key, value); +} + +/** + * 删除本地配置 + */ +function deleteLocalSetting(key: string) { + localStorage.removeItem(key); +} + +/** + * 清空本地配置 + */ +function clearLocalSetting() { + localStorage.clear(); +} + +export { + getLocalSetting, + setLocalSetting, + deleteLocalSetting, + clearLocalSetting, +}; diff --git a/src/utils/shortcutKey.ts b/src/utils/shortcutKey.ts new file mode 100644 index 0000000..7ae70d0 --- /dev/null +++ b/src/utils/shortcutKey.ts @@ -0,0 +1,161 @@ +import { Classification } from "../../types/classification"; +import { Setting } from "../../types/setting"; +import { getItemName } from "../../commons/utils/common"; +import { convertClassificationList } from "../pages/classification/js"; +import { convertItemList } from "../pages/item/js"; +import { useMainStore } from "../store"; +// pinia +const store = useMainStore(); + +/** + * 校验快捷键 + * @param oldShortcutKey + * @param shortcutKey + * @param window + * @returns + */ +async function checkShortcutKey( + setting: Setting, + oldShortcutKey: string | null, + shortcutKey: string, + windowName: string, + type: + | "Classification" + | "Item" + | "GeneralShowHide" + | "GeneralSearch" + | "QuickSearch" +): Promise { + // 校验完整性 + if (!checkShortcutKeyComplete(shortcutKey)) { + window.api.showErrorMessageBox( + windowName, + store.language.shortcutKeyPrompt1 + ); + return false; + } + // 判断是否和旧快捷键相同,相同的话跳过 + if (oldShortcutKey && oldShortcutKey === shortcutKey) { + return true; + } + // 校验快捷键重复 + let message = await checkShortcutKeyDuplicate(setting, shortcutKey, type); + if (message) { + window.api.showErrorMessageBox(windowName, message); + return false; + } + return true; +} + +/** + * 校验快捷键完整 + */ +function checkShortcutKeyComplete(shortcutKey: string): boolean { + if (shortcutKey.trim() !== "") { + let flag = false; + let split = shortcutKey.split("+"); + for (let s of split) { + if (s.trim() === "") { + return false; + } + if ( + s.trim() !== "Ctrl" && + s.trim() !== "Alt" && + s.trim() !== "Shift" && + s.trim() !== "Win" + ) { + flag = true; + } + } + return flag; + } + return false; +} + +/** + * 校验快捷键重复 + * @param setting + * @param shortcutKey + * @param type + * @returns + */ +async function checkShortcutKeyDuplicate( + setting: Setting, + shortcutKey: string, + type: + | "Classification" + | "Item" + | "GeneralShowHide" + | "GeneralSearch" + | "QuickSearch" +): Promise { + // 查询分类 + let classificationList: Array = convertClassificationList( + window.classification.list() + ); + // 查询项目 + let itemMap = convertItemList(window.item.simpleList()); + // 校验 + for (const parent of classificationList) { + // 父级分类 + if (parent.shortcutKey === shortcutKey) { + return store.language.shortcutKeyPrompt2(parent.name); + } + // 项目 + let itemList = itemMap.get(parent.id); + if (!itemList) { + itemList = []; + } + for (const item of itemList) { + if (item.shortcutKey === shortcutKey) { + return store.language.shortcutKeyPrompt3( + parent.name + "-" + getItemName(item.name) + ); + } + } + // 有子分类 + if (parent.childList) { + for (const child of parent.childList) { + if (child.shortcutKey === shortcutKey) { + return store.language.shortcutKeyPrompt2( + parent.name + "-" + child.name + ); + } + // 项目 + let itemList = itemMap.get(child.id); + if (!itemList) { + itemList = []; + } + for (const item of itemList) { + if (item.shortcutKey === shortcutKey) { + return store.language.shortcutKeyPrompt3( + parent.name + "-" + child.name + "-" + getItemName(item.name) + ); + } + } + } + } + } + // 校验窗口显示/隐藏快捷键 + if ( + type !== "GeneralShowHide" && + shortcutKey === setting.general.showHideShortcutKey + ) { + return store.language.shortcutKeyPrompt4; + } + if ( + type !== "GeneralSearch" && + shortcutKey === setting.general.searchShowHideShortcutKey + ) { + return store.language.shortcutKeyPrompt5; + } + if ( + type !== "QuickSearch" && + shortcutKey === setting.quickSearch.showHideShortcutKey + ) { + return store.language.shortcutKeyPrompt6; + } + return null; +} + +export { checkShortcutKey }; diff --git a/src/utils/style.ts b/src/utils/style.ts new file mode 100644 index 0000000..31b0617 --- /dev/null +++ b/src/utils/style.ts @@ -0,0 +1,141 @@ +import { Setting } from "../../types/setting"; + +/** + * 根据类名获取元素 + * @param e + * @param className + * @returns + */ +function getClassElement(e: any, className: string) { + let target: any = null; + if (e instanceof HTMLElement) { + target = e; + } else { + const paths = e.composedPath && e.composedPath(); + for (let i = 0; i < paths.length; i++) { + if (paths[i].classList && paths[i].classList.length > 0) { + for (let clazz of paths[i].classList) { + if (clazz === className) { + target = paths[i]; + break; + } + } + } + } + } + return target; +} + +/** + * 根据ID获取元素 + * @param e + * @param className + * @returns + */ +function getIdElement(e: any, id: string) { + let target: any = null; + if (e instanceof HTMLElement) { + target = e; + } else { + const paths = e.composedPath && e.composedPath(); + for (let i = 0; i < paths.length; i++) { + if (paths[i].id === id) { + target = paths[i]; + break; + } + } + } + return target; +} + +/** + * 设置样式 + * @param e + * @param className + * @param style + */ +function setStyle(e: any, className: string, style: Map) { + let target = getClassElement(e, className); + if (target) { + for (const [key, value] of style) { + target.style.setProperty(key, value); + } + } +} + +/** + * 删除样式 + * @param e + * @param className + * @param style + */ +function removeStyle( + e: any, + className: string, + style: Map +) { + let target = getClassElement(e, className); + if (target) { + for (const [key, value] of style) { + if (value) { + target.style.setProperty(key, value); + } else { + target.style.removeProperty(key); + } + } + } +} + +/** + * 十六进制转RGBA的函数 + * @param hex + * @param a + * @returns + */ +function hexToRGBA(hex: string, a: number | null) { + // 去掉井号 + let hexValue = hex.replace("#", ""); + // 将六位颜色值转为八位 + if (hexValue.length === 6) { + hexValue = hexValue + "ff"; + } + // 获取rgba各分量值 + const red = parseInt(hexValue.substring(0, 2), 16); + const green = parseInt(hexValue.substring(2, 4), 16); + const blue = parseInt(hexValue.substring(4, 6), 16); + const alpha = parseInt(hexValue.substring(6, 8), 16) / 255; + // 返回 + return `rgba(${red}, ${green}, ${blue}, ${!a ? alpha : a})`; +} + +/** + * 设置图标样式 + * @param e + * @param className + */ +function setIconStyle(e: any, className: string, setting: Setting) { + setStyle( + e, + className, + new Map([["color", hexToRGBA(setting.appearance.theme.mainFontColor, 0.8)]]) + ); +} + +/** + * 删除图标样式 + * @param e + * @param className + */ +function removeIconStyle(e: any, className: string) { + removeStyle(e, className, new Map([["color", null]])); +} + +export { + getClassElement, + getIdElement, + setStyle, + removeStyle, + hexToRGBA, + setIconStyle, + removeIconStyle, +}; diff --git a/src/vite-env.d.ts b/src/vite-env.d.ts new file mode 100644 index 0000000..323c78a --- /dev/null +++ b/src/vite-env.d.ts @@ -0,0 +1,7 @@ +/// + +declare module '*.vue' { + import type { DefineComponent } from 'vue' + const component: DefineComponent<{}, {}, any> + export default component +} diff --git a/tailwind.config.js b/tailwind.config.js index 8a8e35b..7065373 100644 --- a/tailwind.config.js +++ b/tailwind.config.js @@ -1,14 +1,11 @@ +/** @type {import('tailwindcss').Config} */ module.exports = { - content: [ - "./src/**/*.{vue,js,ts,jsx,tsx}", - ], + corePlugins: { + preflight: false, + }, + content: ["index.html", "./src/**/*.{html,js,ts,jsx,tsx,vue}"], theme: { extend: {}, }, - variants: { - extend: {}, - }, - plugins: [require('@tailwindcss/forms')({ - strategy: 'class', // only generate classes - })], -} + plugins: [], +}; diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..7dc63c1 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,25 @@ +{ + "compilerOptions": { + "target": "ESNext", + "useDefineForClassFields": true, + "module": "ESNext", + "moduleResolution": "Node", + "strict": true, + "jsx": "preserve", + "resolveJsonModule": true, + "isolatedModules": true, + "esModuleInterop": true, + "lib": ["ESNext", "DOM"], + "skipLibCheck": true, + "noEmit": true + }, + "include": [ + "src", + "commons", + "types/classification.d.ts", + "types/common.d.ts", + "types/item.d.ts", + "types/setting.ts" + ], + "references": [{ "path": "./tsconfig.node.json" }] +} diff --git a/tsconfig.node.json b/tsconfig.node.json new file mode 100644 index 0000000..d7bac39 --- /dev/null +++ b/tsconfig.node.json @@ -0,0 +1,19 @@ +{ + "compilerOptions": { + "composite": true, + "module": "ESNext", + "moduleResolution": "Node", + "resolveJsonModule": true, + "allowSyntheticDefaultImports": true + }, + "include": [ + "vite.config.ts", + "package.json", + "electron", + "commons", + "types/classification.d.ts", + "types/common.d.ts", + "types/item.d.ts", + "types/setting.d.ts" + ] +} diff --git a/types/classification.d.ts b/types/classification.d.ts new file mode 100644 index 0000000..547b488 --- /dev/null +++ b/types/classification.d.ts @@ -0,0 +1,47 @@ +// 分类 +export interface Classification { + // ID + id: number; + // 父级ID + parentId: number | null; + // 名称 + name: string | null; + // 类型 0:普通分类 1:关联文件夹 2:聚合分类 + type: number; + // 数据 + data: ClassificationData; + // 快捷键 + shortcutKey: string | null; + // 全局快捷键 + globalShortcutKey: boolean; + // 顺序 + order: number; + // 子级分类 + childList: Array | null; +} + +// 分类数据 +export interface ClassificationData { + // 图标 + icon: string | null; + // 关联文件夹路径 + associateFolderPath: string | null; + // 关联文件夹隐藏项 + associateFolderHiddenItems: string | null; + // 项目布局 + itemLayout: "default" | "tile" | "list"; + // 项目排序 + itemSort: "default" | "initial" | "openNumber" | "lastOpen"; + // 项目列数 + itemColumnNumber: number | null; + // 项目图标大小 + itemIconSize: number | null; + // 只显示... + itemShowOnly: "default" | "file" | "folder"; + // 固定分类 + fixed: boolean; + // 聚合分类项目数量 + aggregateItemCount: number; + // 排除搜索 + excludeSearch: boolean; +} diff --git a/types/common.d.ts b/types/common.d.ts new file mode 100644 index 0000000..ec23c28 --- /dev/null +++ b/types/common.d.ts @@ -0,0 +1,13 @@ +// 快捷方式信息 +export interface ShortcutInfo { + target: string | null; + arguments: string | null; +} + +// 返回结果 +export interface Result { + status: boolean; + message: string | null; + icon: string | null; + name: string | null; +} diff --git a/types/item.d.ts b/types/item.d.ts new file mode 100644 index 0000000..ac92ab0 --- /dev/null +++ b/types/item.d.ts @@ -0,0 +1,75 @@ +// 通用项目 +export interface CommonItem { + // id + id: number; + // 名称 + name: string | null; + // 数据 + data: CommonItemData; + // 顺序 + order: number; +} + +// 通用项目数据 +export interface CommonItemData { + // 目标 + target: string | null; + // 参数 + params: string | null; + // 图标 + icon: string | null; + // html图标 + htmlIcon: string | null; +} + +// 项目 +export interface Item { + // id + id: number; + // 分类ID + classificationId: number; + // 名称 + name: string | null; + // 类型 0:文件 1:文件夹 2:网址 3:系统 4:Appx 5:多项目 + type: number; + // 数据 + data: ItemData; + // 快捷键 + shortcutKey: string | null; + // 全局快捷键 + globalShortcutKey: boolean; + // 顺序 + order: number; +} + +// 项目数据 +export interface ItemData { + // 起始位置 + startLocation: string | null; + // 目标 + target: string | null; + // 参数 + params: string | null; + // 以管理员身份运行 + runAsAdmin: boolean; + // 图标 + icon: string | null; + // html图标 + htmlIcon: string | null; + // 备注 + remark: string | null; + // 图标背景 + iconBackgroundColor: boolean; + // 固定图标 + fixedIcon: boolean; + // 打开次数 + openNumber: number; + // 最后打开时间 + lastOpen: number; + // 快速搜索-打开次数 + quickSearchOpenNumber: number; + // 快速搜索-最后打开时间 + quickSearchLastOpen: number; + // 多项目时间间隔(毫秒) + multiItemsTimeInterval: number; +} diff --git a/types/setting.d.ts b/types/setting.d.ts new file mode 100644 index 0000000..724e21e --- /dev/null +++ b/types/setting.d.ts @@ -0,0 +1,239 @@ +// 通用 +export interface General { + // 开机启动 + startup: boolean; + // 启动后最小化到系统托盘 + startupTray: boolean; + // 快捷键显示/隐藏 + showHideShortcutKey: string | null; + // 语言 + language: string; + // 永远置顶 + alwaysTop: boolean; + // 边缘吸附 + edgeAdsorb: boolean; + // 停靠在桌面边缘时自动隐藏 + edgeAutoHide: boolean; + // 锁定尺寸 + lockSize: boolean; + // 失去焦点后隐藏 + hideLoseFocus: boolean; + // 隐藏托盘图标 + hideTray: boolean; + // 固定位置 + fixedPosition: boolean; + // 永远居中 + alwaysCenter: boolean; + // 中间单击显示/隐藏 + showHideMouseWheelClick: boolean; + // 显示时跟随鼠标位置 + showFollowMousePosition: boolean; + // 勿扰模式 + notDisturb: boolean; + // 双击任务栏显示/隐藏 + showHideDoubleClickTaskbar: boolean; + // 延迟显示(毫秒) + delayDisplayMs: number; + // 延迟隐藏(毫秒) + delayHideMs: number; + // 显示窗口时将输入法切换为英文模式 + switchEnglish: boolean; + // 搜索显示/隐藏快捷键 + searchShowHideShortcutKey: string | null; + // 检查更新 + checkUpdates: boolean; +} + +// 外观 +export interface Appearance { + // 主题 + theme: Theme; + // 透明度 + transparency: number; + // 背景图 + backgroundImage: string | null; + // 背景图透明 + backgroundImageTransparency: number; + // 背景图模式 + backgroundImageMode: string; + // 背景图定位 + backgroundImagePosition: string; + // 字体阴影 + fontShadow: boolean; + // 字体阴影颜色 + fontShadowColor: string; + // 窗口圆角 + windowRounded: boolean; + // 标题 + title: string; +} + +// 主题 +export interface Theme { + // 名称 + name: string; + // 字体主颜色 + mainFontColor: string; + // 字体次颜色 + secondFontColor: string; + // 背景主颜色 + mainBackgroundColor: string; + // 背景次颜色 + secondBackgroundColor: string; + // 边框颜色 + borderColor: string; +} + +// 分类 +export interface Classification { + // 宽度 + width: number; + // 布局 left top right + layout: string; + // 鼠标悬停切换 + mouseHover: boolean; + // 悬停毫秒 + mouseHoverMs: number; + // 滚轮切换 + mouseWheel: boolean; + // 记住选择状态 + rememberSelectionState: boolean; + // 名称对齐 left center + nameAlign: string; + // 模式 normal icon + mode: string; + // 项目列表滚动到底部或顶部时自动切换分类 + autoSwitchClassification: boolean; + // 隐藏窗口时折叠子分类 + hideWindowCollapseSubClassification: boolean; + // 切换分类时收起其他子分类 + switchClassificationCollapseOtherSubClassification: boolean; +} + +// 子分类 +export interface SubClassification { + // 名称字体(项目区域) + itemAreaNameFontSize: number; + // 名称粗细(项目区域) + itemAreaNameFontWeight: number; + // 名称字体行高(项目区域) + itemAreaNameFontLineHeight: number; +} + +// 项目 +export interface Item { + // 布局 tile list + layout: string; + // 图标大小 + iconSize: number; + // 双击打开项目 + doubleClickOpen: boolean; + // 打开后隐藏主界面 + openAfterHideMainInterface: boolean; + // 从程序外拖动文件到项目图标上时用此项目打开文件 + useItemOpen: boolean; + // 记录打开次数 + openNumber: boolean; + // 隐藏项目名称 + hideItemName: boolean; + // 隐藏省略号 + hideEllipsis: boolean; + // 项目名称行数 + itemNameRowCount: number; + // 宽度 + width: number; + // 列数 单列多列 + columnNumber: number; + // 检测无效项目 + checkInvalidItem: boolean; + // 字体大小 + fontSize: number; + // 字体粗细 + fontWeight: number; + // 字体行高 + fontLineHeight: number; +} + +// 快速搜索 +export interface QuickSearch { + // 开启 + enable: boolean; + // 快捷键 + showHideShortcutKey: string | null; + // 打开快捷键 numberKey ctrlNumberKey altNumberKey + openShortcutKey: string; + // 失去焦点后隐藏 + hideLoseFocus: boolean; + // 仅剩一项时立即打开 + openNow: boolean; + // 显示历史记录 + showHistory: boolean; + // 历史记录排序 lastOpen openNumber + showHistorySort: string; + // 从程序外拖动文件到项目图标上时用此项目打开文件 + useItemOpen: boolean; + // 打开后隐藏快速搜索窗口 + openAfterHideQuickSearchWindow: boolean; + // 匹配条件:备注 + matchConditionsRemark: boolean; +} + +// 网络搜索 +export interface WebSearch { + // 模式 0:冒号 + 关键字 + 空格 1:关键字 + 空格 + mode: number; + // 搜索源 + searchSourceList: Array; +} + +// 网络搜索源 +export interface WebSearchSource { + // ID + id: number; + // 关键字 + keyword: string; + // 名称 + name: string; + // URL + url: string; + // 描述 + description: string | null; +} + +// 网络 +export interface Network { + // 使用代理 + useProxy: boolean; + // 代理信息 + proxy: Proxy; +} + +// 代理 +export interface Proxy { + // address + address: string; + // 用户名 + username: string | null; + // 密码 + password: string | null; +} + +// 设置 +export interface Setting { + // 常规 + general: General; + // 外观 + appearance: Appearance; + // 分类 + classification: Classification; + // 子分类 + subClassification: SubClassification; + // 项目 + item: Item; + // 快速搜索 + quickSearch: QuickSearch; + // 网络搜索 + webSearch: WebSearch; + // 网络 + network: Network; +} diff --git a/vite.config.ts b/vite.config.ts new file mode 100644 index 0000000..c1164b0 --- /dev/null +++ b/vite.config.ts @@ -0,0 +1,153 @@ +import { + rmSync, + mkdirSync, + existsSync, + copyFileSync, + writeFileSync, +} from "node:fs"; +import { resolve, join } from "node:path"; +import { type Plugin, defineConfig, normalizePath } from "vite"; +import vue from "@vitejs/plugin-vue"; +import electron from "vite-plugin-electron"; +import { notBundle } from "vite-plugin-electron/plugin"; +import pkg from "./package.json"; + +// https://vitejs.dev/config/ +export default defineConfig(({ command }) => { + rmSync("dist-electron", { recursive: true, force: true }); + const isServe = command === "serve"; + const isBuild = command === "build"; + const sourcemap = isServe || !!process.env.VSCODE_DEBUG; + return { + plugins: [ + vue(), + electron([ + { + entry: "electron/main/index.ts", + onstart({ startup }) { + if (process.env.VSCODE_DEBUG) { + console.log("[startup] Electron App"); + } else { + startup(); + } + }, + vite: { + build: { + sourcemap, + minify: isBuild, + outDir: "dist-electron/main", + commonjsOptions: { + ignoreDynamicRequires: true, + }, + rollupOptions: { + external: [], + }, + }, + plugins: [isServe && notBundle()], + }, + }, + { + entry: "electron/preload/index.ts", + onstart({ reload }) { + reload(); + }, + vite: { + build: { + sourcemap: sourcemap ? "inline" : undefined, + minify: isBuild, + outDir: "dist-electron/preload", + rollupOptions: { + external: [], + }, + }, + plugins: [isServe && notBundle()], + }, + }, + { + entry: "electron/main/worker.ts", + onstart({ reload }) { + reload(); + }, + vite: { + build: { + sourcemap: sourcemap ? "inline" : undefined, + minify: isBuild, + outDir: "dist-electron/main", + commonjsOptions: { + ignoreDynamicRequires: true, + }, + rollupOptions: { + external: [], + }, + }, + plugins: [isServe && notBundle()], + }, + }, + ]), + bindingSqlite3(), + ], + server: + process.env.VSCODE_DEBUG && + (() => { + const url = new URL(pkg.debug.env.VITE_DEV_SERVER_URL); + return { + host: url.hostname, + port: +url.port, + }; + })(), + clearScreen: false, + }; +}); + +function bindingSqlite3( + options: { + output?: string; + better_sqlite3_node?: string; + command?: string; + } = {} +): Plugin { + const TAG = "[vite-plugin-binding-sqlite3]"; + options.output ??= "native"; + options.better_sqlite3_node ??= "better_sqlite3.node"; + options.command ??= "build"; + + return { + name: "vite-plugin-binding-sqlite3", + config(config) { + // https://github.com/vitejs/vite/blob/v4.4.9/packages/vite/src/node/config.ts#L496-L499 + const resolvedRoot = normalizePath( + config.root ? resolve(config.root) : process.cwd() + ); + const output = resolve(resolvedRoot, options.output); + const better_sqlite3 = require.resolve("better-sqlite3-multiple-ciphers"); + const better_sqlite3_root = join( + better_sqlite3.slice(0, better_sqlite3.lastIndexOf("node_modules")), + "node_modules/better-sqlite3-multiple-ciphers" + ); + const better_sqlite3_node = join( + better_sqlite3_root, + "build/Release", + options.better_sqlite3_node + ); + const better_sqlite3_copy = join(output, options.better_sqlite3_node); + if (!existsSync(better_sqlite3_node)) { + throw new Error(`${TAG} Can not found "${better_sqlite3_node}".`); + } + if (!existsSync(output)) { + mkdirSync(output, { recursive: true }); + } + copyFileSync(better_sqlite3_node, better_sqlite3_copy); + /** `native/better_sqlite3.node` */ + const BETTER_SQLITE3_BINDING = better_sqlite3_copy.replace( + resolvedRoot + "/", + "" + ); + writeFileSync( + join(resolvedRoot, ".env"), + `VITE_BETTER_SQLITE3_BINDING=${BETTER_SQLITE3_BINDING}` + ); + + console.log(TAG, `binding to ${BETTER_SQLITE3_BINDING}`); + }, + }; +} diff --git a/vue.config.js b/vue.config.js deleted file mode 100644 index 59fcefd..0000000 --- a/vue.config.js +++ /dev/null @@ -1,82 +0,0 @@ -const { defineConfig } = require("@vue/cli-service"); -const TerserPlugin = require("terser-webpack-plugin"); -const path = require("path"); - -function resolve(dir) { - return path.join(__dirname, dir); -} - -module.exports = defineConfig({ - transpileDependencies: true, - assetsDir: "public", - productionSourceMap: false, - configureWebpack: { - entry: "./src/renderer/main.js", - resolve: { - extensions: [".js", ".vue", ".json", ".ts", ".less"], - alias: { - "@": resolve("src/renderer"), - }, - }, - optimization: { - usedExports: true, - splitChunks: { - chunks: "all", - }, - minimizer: [ - new TerserPlugin({ - extractComments: false, // 禁止生成license.txt文件 - terserOptions: { - compress: { - drop_console: true, // 删除console.log - drop_debugger: true, // 删除debugger - }, - }, - }), - ], - }, - }, - pluginOptions: { - electronBuilder: { - builderOptions: { - // 应用名称 - productName: "Dawn Launcher", - // 压缩级别 - compression: "maximum", - // 包含api目录 - extraFiles: ["build"], - // 图片 - extraResources: [{ from: "./public/images", to: "images" }], - // windows - win: { - // appId - appId: "com.dawnlauncher.application", - target: [ - { - target: "nsis", - // ia32 x64 - arch: ["x64"], - }, - ], - icon: "public/images/logo.ico", - }, - nsis: { - // 安装文件名称 - artifactName: "${productName}-${version}.${ext}", - // 是否一键安装,建议为false,可以让用户点击下一步、下一步、下一步的形式安装程序,如果为true,当用户双击构建好的程序,自动安装程序并打开,即:一键安装(one-click installer) - oneClick: false, - // 允许请求提升,如果为false,则用户必须使用提升的权限重新启动安装程序。 - allowElevation: true, - // 允许修改安装目录,建议为true,是否允许用户改变安装目录,默认是不允许。 - allowToChangeInstallationDirectory: true, - // 创建桌面图标 - createDesktopShortcut: true, - // 创建开始菜单图标 - createStartMenuShortcut: true, - }, - }, - mainProcessFile: "src/main/main.js", - mainProcessWatch: ["src/main"], - }, - }, -}); diff --git a/yarn.lock b/yarn.lock index 1efd748..2e50590 100644 --- a/yarn.lock +++ b/yarn.lock @@ -4,996 +4,57 @@ "7zip-bin@~5.1.1": version "5.1.1" - resolved "https://registry.yarnpkg.com/7zip-bin/-/7zip-bin-5.1.1.tgz#9274ec7460652f9c632c59addf24efb1684ef876" + resolved "https://registry.npmmirror.com/7zip-bin/-/7zip-bin-5.1.1.tgz#9274ec7460652f9c632c59addf24efb1684ef876" integrity sha512-sAP4LldeWNz0lNzmTird3uWfFDWWTeg6V/MsmyyLR9X1idwKBWIgt/ZvinqQldJm3LecKEs1emkbquO6PCiLVQ== -"@achrinza/node-ipc@^9.2.5": - version "9.2.5" - resolved "https://registry.yarnpkg.com/@achrinza/node-ipc/-/node-ipc-9.2.5.tgz#29788e608ff41121f0543491da723b243266ac28" - integrity sha512-kBX7Ay911iXZ3VZ1pYltj3Rfu7Ow9H7sK4H4RSfWIfWR2JKNB40K808wppoRIEzE2j2hXLU+r6TJgCAliCGhyQ== - dependencies: - "@node-ipc/js-queue" "2.0.3" - event-pubsub "4.3.0" - js-message "1.0.7" - -"@ampproject/remapping@^2.1.0": - version "2.2.0" - resolved "https://registry.yarnpkg.com/@ampproject/remapping/-/remapping-2.2.0.tgz#56c133824780de3174aed5ab6834f3026790154d" - integrity sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w== - dependencies: - "@jridgewell/gen-mapping" "^0.1.0" - "@jridgewell/trace-mapping" "^0.3.9" - -"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.18.6.tgz#3b25d38c89600baa2dcc219edfa88a74eb2c427a" - integrity sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q== - dependencies: - "@babel/highlight" "^7.18.6" - -"@babel/compat-data@^7.17.7", "@babel/compat-data@^7.18.8", "@babel/compat-data@^7.19.1": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.19.1.tgz#72d647b4ff6a4f82878d184613353af1dd0290f9" - integrity sha512-72a9ghR0gnESIa7jBN53U32FOVCEoztyIlKaNoU05zRhEecduGK9L9c3ww7Mp06JiR+0ls0GBPFJQwwtjn9ksg== - -"@babel/core@^7.12.16": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.19.1.tgz#c8fa615c5e88e272564ace3d42fbc8b17bfeb22b" - integrity sha512-1H8VgqXme4UXCRv7/Wa1bq7RVymKOzC7znjyFM8KiEzwFqcKUKYNoQef4GhdklgNvoBXyW4gYhuBNCM5o1zImw== - dependencies: - "@ampproject/remapping" "^2.1.0" - "@babel/code-frame" "^7.18.6" - "@babel/generator" "^7.19.0" - "@babel/helper-compilation-targets" "^7.19.1" - "@babel/helper-module-transforms" "^7.19.0" - "@babel/helpers" "^7.19.0" - "@babel/parser" "^7.19.1" - "@babel/template" "^7.18.10" - "@babel/traverse" "^7.19.1" - "@babel/types" "^7.19.0" - convert-source-map "^1.7.0" - debug "^4.1.0" - gensync "^1.0.0-beta.2" - json5 "^2.2.1" - semver "^6.3.0" - -"@babel/generator@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.19.0.tgz#785596c06425e59334df2ccee63ab166b738419a" - integrity sha512-S1ahxf1gZ2dpoiFgA+ohK9DIpz50bJ0CWs7Zlzb54Z4sG8qmdIrGrVqmy1sAtTVRb+9CU6U8VqT9L0Zj7hxHVg== - dependencies: - "@babel/types" "^7.19.0" - "@jridgewell/gen-mapping" "^0.3.2" - jsesc "^2.5.1" - -"@babel/helper-annotate-as-pure@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz#eaa49f6f80d5a33f9a5dd2276e6d6e451be0a6bb" - integrity sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA== - dependencies: - "@babel/types" "^7.18.6" - -"@babel/helper-builder-binary-assignment-operator-visitor@^7.18.6": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz#acd4edfd7a566d1d51ea975dff38fd52906981bb" - integrity sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw== - dependencies: - "@babel/helper-explode-assignable-expression" "^7.18.6" - "@babel/types" "^7.18.9" - -"@babel/helper-compilation-targets@^7.12.16", "@babel/helper-compilation-targets@^7.17.7", "@babel/helper-compilation-targets@^7.18.9", "@babel/helper-compilation-targets@^7.19.0", "@babel/helper-compilation-targets@^7.19.1": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.19.1.tgz#7f630911d83b408b76fe584831c98e5395d7a17c" - integrity sha512-LlLkkqhCMyz2lkQPvJNdIYU7O5YjWRgC2R4omjCTpZd8u8KMQzZvX4qce+/BluN1rcQiV7BoGUpmQ0LeHerbhg== - dependencies: - "@babel/compat-data" "^7.19.1" - "@babel/helper-validator-option" "^7.18.6" - browserslist "^4.21.3" - semver "^6.3.0" - -"@babel/helper-create-class-features-plugin@^7.18.6", "@babel/helper-create-class-features-plugin@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.19.0.tgz#bfd6904620df4e46470bae4850d66be1054c404b" - integrity sha512-NRz8DwF4jT3UfrmUoZjd0Uph9HQnP30t7Ash+weACcyNkiYTywpIjDBgReJMKgr+n86sn2nPVVmJ28Dm053Kqw== - dependencies: - "@babel/helper-annotate-as-pure" "^7.18.6" - "@babel/helper-environment-visitor" "^7.18.9" - "@babel/helper-function-name" "^7.19.0" - "@babel/helper-member-expression-to-functions" "^7.18.9" - "@babel/helper-optimise-call-expression" "^7.18.6" - "@babel/helper-replace-supers" "^7.18.9" - "@babel/helper-split-export-declaration" "^7.18.6" - -"@babel/helper-create-regexp-features-plugin@^7.18.6", "@babel/helper-create-regexp-features-plugin@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.19.0.tgz#7976aca61c0984202baca73d84e2337a5424a41b" - integrity sha512-htnV+mHX32DF81amCDrwIDr8nrp1PTm+3wfBN9/v8QJOLEioOCOG7qNyq0nHeFiWbT3Eb7gsPwEmV64UCQ1jzw== - dependencies: - "@babel/helper-annotate-as-pure" "^7.18.6" - regexpu-core "^5.1.0" - -"@babel/helper-define-polyfill-provider@^0.3.3": - version "0.3.3" - resolved "https://registry.yarnpkg.com/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.3.tgz#8612e55be5d51f0cd1f36b4a5a83924e89884b7a" - integrity sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww== - dependencies: - "@babel/helper-compilation-targets" "^7.17.7" - "@babel/helper-plugin-utils" "^7.16.7" - debug "^4.1.1" - lodash.debounce "^4.0.8" - resolve "^1.14.2" - semver "^6.1.2" - -"@babel/helper-environment-visitor@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz#0c0cee9b35d2ca190478756865bb3528422f51be" - integrity sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg== - -"@babel/helper-explode-assignable-expression@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz#41f8228ef0a6f1a036b8dfdfec7ce94f9a6bc096" - integrity sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg== - dependencies: - "@babel/types" "^7.18.6" - -"@babel/helper-function-name@^7.18.9", "@babel/helper-function-name@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz#941574ed5390682e872e52d3f38ce9d1bef4648c" - integrity sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w== - dependencies: - "@babel/template" "^7.18.10" - "@babel/types" "^7.19.0" - -"@babel/helper-hoist-variables@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz#d4d2c8fb4baeaa5c68b99cc8245c56554f926678" - integrity sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q== - dependencies: - "@babel/types" "^7.18.6" - -"@babel/helper-member-expression-to-functions@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.9.tgz#1531661e8375af843ad37ac692c132841e2fd815" - integrity sha512-RxifAh2ZoVU67PyKIO4AMi1wTenGfMR/O/ae0CCRqwgBAt5v7xjdtRw7UoSbsreKrQn5t7r89eruK/9JjYHuDg== - dependencies: - "@babel/types" "^7.18.9" - -"@babel/helper-module-imports@^7.0.0", "@babel/helper-module-imports@^7.12.13", "@babel/helper-module-imports@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz#1e3ebdbbd08aad1437b428c50204db13c5a3ca6e" - integrity sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA== - dependencies: - "@babel/types" "^7.18.6" - -"@babel/helper-module-transforms@^7.18.6", "@babel/helper-module-transforms@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.19.0.tgz#309b230f04e22c58c6a2c0c0c7e50b216d350c30" - integrity sha512-3HBZ377Fe14RbLIA+ac3sY4PTgpxHVkFrESaWhoI5PuyXPBBX8+C34qblV9G89ZtycGJCmCI/Ut+VUDK4bltNQ== - dependencies: - "@babel/helper-environment-visitor" "^7.18.9" - "@babel/helper-module-imports" "^7.18.6" - "@babel/helper-simple-access" "^7.18.6" - "@babel/helper-split-export-declaration" "^7.18.6" - "@babel/helper-validator-identifier" "^7.18.6" - "@babel/template" "^7.18.10" - "@babel/traverse" "^7.19.0" - "@babel/types" "^7.19.0" - -"@babel/helper-optimise-call-expression@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz#9369aa943ee7da47edab2cb4e838acf09d290ffe" - integrity sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA== - dependencies: - "@babel/types" "^7.18.6" - -"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.16.7", "@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.18.9", "@babel/helper-plugin-utils@^7.19.0", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.19.0.tgz#4796bb14961521f0f8715990bee2fb6e51ce21bf" - integrity sha512-40Ryx7I8mT+0gaNxm8JGTZFUITNqdLAgdg0hXzeVZxVD6nFsdhQvip6v8dqkRHzsz1VFpFAaOCHNn0vKBL7Czw== - -"@babel/helper-remap-async-to-generator@^7.18.6", "@babel/helper-remap-async-to-generator@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz#997458a0e3357080e54e1d79ec347f8a8cd28519" - integrity sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA== - dependencies: - "@babel/helper-annotate-as-pure" "^7.18.6" - "@babel/helper-environment-visitor" "^7.18.9" - "@babel/helper-wrap-function" "^7.18.9" - "@babel/types" "^7.18.9" - -"@babel/helper-replace-supers@^7.18.6", "@babel/helper-replace-supers@^7.18.9", "@babel/helper-replace-supers@^7.19.1": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.19.1.tgz#e1592a9b4b368aa6bdb8784a711e0bcbf0612b78" - integrity sha512-T7ahH7wV0Hfs46SFh5Jz3s0B6+o8g3c+7TMxu7xKfmHikg7EAZ3I2Qk9LFhjxXq8sL7UkP5JflezNwoZa8WvWw== - dependencies: - "@babel/helper-environment-visitor" "^7.18.9" - "@babel/helper-member-expression-to-functions" "^7.18.9" - "@babel/helper-optimise-call-expression" "^7.18.6" - "@babel/traverse" "^7.19.1" - "@babel/types" "^7.19.0" - -"@babel/helper-simple-access@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz#d6d8f51f4ac2978068df934b569f08f29788c7ea" - integrity sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g== - dependencies: - "@babel/types" "^7.18.6" - -"@babel/helper-skip-transparent-expression-wrappers@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.18.9.tgz#778d87b3a758d90b471e7b9918f34a9a02eb5818" - integrity sha512-imytd2gHi3cJPsybLRbmFrF7u5BIEuI2cNheyKi3/iOBC63kNn3q8Crn2xVuESli0aM4KYsyEqKyS7lFL8YVtw== - dependencies: - "@babel/types" "^7.18.9" - -"@babel/helper-split-export-declaration@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz#7367949bc75b20c6d5a5d4a97bba2824ae8ef075" - integrity sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA== - dependencies: - "@babel/types" "^7.18.6" - -"@babel/helper-string-parser@^7.18.10": - version "7.18.10" - resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.18.10.tgz#181f22d28ebe1b3857fa575f5c290b1aaf659b56" - integrity sha512-XtIfWmeNY3i4t7t4D2t02q50HvqHybPqW2ki1kosnvWCwuCMeo81Jf0gwr85jy/neUdg5XDdeFE/80DXiO+njw== - -"@babel/helper-validator-identifier@^7.18.6": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz#7eea834cf32901ffdc1a7ee555e2f9c27e249ca2" - integrity sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w== - -"@babel/helper-validator-option@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz#bf0d2b5a509b1f336099e4ff36e1a63aa5db4db8" - integrity sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw== - -"@babel/helper-wrap-function@^7.18.9": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/helper-wrap-function/-/helper-wrap-function-7.19.0.tgz#89f18335cff1152373222f76a4b37799636ae8b1" - integrity sha512-txX8aN8CZyYGTwcLhlk87KRqncAzhh5TpQamZUa0/u3an36NtDpUP6bQgBCBcLeBs09R/OwQu3OjK0k/HwfNDg== - dependencies: - "@babel/helper-function-name" "^7.19.0" - "@babel/template" "^7.18.10" - "@babel/traverse" "^7.19.0" - "@babel/types" "^7.19.0" - -"@babel/helpers@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.19.0.tgz#f30534657faf246ae96551d88dd31e9d1fa1fc18" - integrity sha512-DRBCKGwIEdqY3+rPJgG/dKfQy9+08rHIAJx8q2p+HSWP87s2HCrQmaAMMyMll2kIXKCW0cO1RdQskx15Xakftg== - dependencies: - "@babel/template" "^7.18.10" - "@babel/traverse" "^7.19.0" - "@babel/types" "^7.19.0" - -"@babel/highlight@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.18.6.tgz#81158601e93e2563795adcbfbdf5d64be3f2ecdf" - integrity sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g== - dependencies: - "@babel/helper-validator-identifier" "^7.18.6" - chalk "^2.0.0" - js-tokens "^4.0.0" - -"@babel/parser@^7.18.10", "@babel/parser@^7.19.1": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.19.1.tgz#6f6d6c2e621aad19a92544cc217ed13f1aac5b4c" - integrity sha512-h7RCSorm1DdTVGJf3P2Mhj3kdnkmF/EiysUkzS2TdgAYqyjFdMQJbVuXOBej2SBJaXan/lIVtT6KkGbyyq753A== - -"@babel/parser@^7.20.15", "@babel/parser@^7.21.3": - version "7.21.8" - resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.21.8.tgz#642af7d0333eab9c0ad70b14ac5e76dbde7bfdf8" - integrity sha512-6zavDGdzG3gUqAdWvlLFfk+36RilI+Pwyuuh7HItyeScCWP3k6i8vKclAQ0bM/0y/Kz/xiwvxhMv9MgTJP5gmA== - -"@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz#da5b8f9a580acdfbe53494dba45ea389fb09a4d2" - integrity sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.9.tgz#a11af19aa373d68d561f08e0a57242350ed0ec50" - integrity sha512-AHrP9jadvH7qlOj6PINbgSuphjQUAK7AOT7DPjBo9EHoLhQTnnK5u45e1Hd4DbSQEO9nqPWtQ89r+XEOWFScKg== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" - "@babel/plugin-proposal-optional-chaining" "^7.18.9" - -"@babel/plugin-proposal-async-generator-functions@^7.19.1": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.19.1.tgz#34f6f5174b688529342288cd264f80c9ea9fb4a7" - integrity sha512-0yu8vNATgLy4ivqMNBIwb1HebCelqN7YX8SL3FDXORv/RqT0zEEWUCH4GH44JsSrvCu6GqnAdR5EBFAPeNBB4Q== - dependencies: - "@babel/helper-environment-visitor" "^7.18.9" - "@babel/helper-plugin-utils" "^7.19.0" - "@babel/helper-remap-async-to-generator" "^7.18.9" - "@babel/plugin-syntax-async-generators" "^7.8.4" - -"@babel/plugin-proposal-class-properties@^7.12.13", "@babel/plugin-proposal-class-properties@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz#b110f59741895f7ec21a6fff696ec46265c446a3" - integrity sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-proposal-class-static-block@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz#8aa81d403ab72d3962fc06c26e222dacfc9b9020" - integrity sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-class-static-block" "^7.14.5" - -"@babel/plugin-proposal-decorators@^7.12.13": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-decorators/-/plugin-proposal-decorators-7.19.1.tgz#4bab3e7afe894fdbf47ffa86701266104fcb6ecc" - integrity sha512-LfIKNBBY7Q1OX5C4xAgRQffOg2OnhAo9fnbcOHgOC9Yytm2Sw+4XqHufRYU86tHomzepxtvuVaNO+3EVKR4ivw== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.19.0" - "@babel/helper-plugin-utils" "^7.19.0" - "@babel/helper-replace-supers" "^7.19.1" - "@babel/helper-split-export-declaration" "^7.18.6" - "@babel/plugin-syntax-decorators" "^7.19.0" - -"@babel/plugin-proposal-dynamic-import@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz#72bcf8d408799f547d759298c3c27c7e7faa4d94" - integrity sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-dynamic-import" "^7.8.3" - -"@babel/plugin-proposal-export-namespace-from@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz#5f7313ab348cdb19d590145f9247540e94761203" - integrity sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - "@babel/plugin-syntax-export-namespace-from" "^7.8.3" - -"@babel/plugin-proposal-json-strings@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz#7e8788c1811c393aff762817e7dbf1ebd0c05f0b" - integrity sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-json-strings" "^7.8.3" - -"@babel/plugin-proposal-logical-assignment-operators@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.9.tgz#8148cbb350483bf6220af06fa6db3690e14b2e23" - integrity sha512-128YbMpjCrP35IOExw2Fq+x55LMP42DzhOhX2aNNIdI9avSWl2PI0yuBWarr3RYpZBSPtabfadkH2yeRiMD61Q== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" - -"@babel/plugin-proposal-nullish-coalescing-operator@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz#fdd940a99a740e577d6c753ab6fbb43fdb9467e1" - integrity sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" - -"@babel/plugin-proposal-numeric-separator@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz#899b14fbafe87f053d2c5ff05b36029c62e13c75" - integrity sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-numeric-separator" "^7.10.4" - -"@babel/plugin-proposal-object-rest-spread@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.18.9.tgz#f9434f6beb2c8cae9dfcf97d2a5941bbbf9ad4e7" - integrity sha512-kDDHQ5rflIeY5xl69CEqGEZ0KY369ehsCIEbTGb4siHG5BE9sga/T0r0OUwyZNLMmZE79E1kbsqAjwFCW4ds6Q== - dependencies: - "@babel/compat-data" "^7.18.8" - "@babel/helper-compilation-targets" "^7.18.9" - "@babel/helper-plugin-utils" "^7.18.9" - "@babel/plugin-syntax-object-rest-spread" "^7.8.3" - "@babel/plugin-transform-parameters" "^7.18.8" - -"@babel/plugin-proposal-optional-catch-binding@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz#f9400d0e6a3ea93ba9ef70b09e72dd6da638a2cb" - integrity sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" - -"@babel/plugin-proposal-optional-chaining@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.9.tgz#e8e8fe0723f2563960e4bf5e9690933691915993" - integrity sha512-v5nwt4IqBXihxGsW2QmCWMDS3B3bzGIk/EQVZz2ei7f3NJl8NzAJVvUmpDW5q1CRNY+Beb/k58UAH1Km1N411w== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" - "@babel/plugin-syntax-optional-chaining" "^7.8.3" - -"@babel/plugin-proposal-private-methods@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz#5209de7d213457548a98436fa2882f52f4be6bea" - integrity sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA== - dependencies: - "@babel/helper-create-class-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-proposal-private-property-in-object@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.18.6.tgz#a64137b232f0aca3733a67eb1a144c192389c503" - integrity sha512-9Rysx7FOctvT5ouj5JODjAFAkgGoudQuLPamZb0v1TGLpapdNaftzifU8NTWQm0IRjqoYypdrSmyWgkocDQ8Dw== - dependencies: - "@babel/helper-annotate-as-pure" "^7.18.6" - "@babel/helper-create-class-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/plugin-syntax-private-property-in-object" "^7.14.5" - -"@babel/plugin-proposal-unicode-property-regex@^7.18.6", "@babel/plugin-proposal-unicode-property-regex@^7.4.4": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz#af613d2cd5e643643b65cded64207b15c85cb78e" - integrity sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-syntax-async-generators@^7.8.4": - version "7.8.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz#a983fb1aeb2ec3f6ed042a210f640e90e786fe0d" - integrity sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-class-properties@^7.12.13": - version "7.12.13" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz#b5c987274c4a3a82b89714796931a6b53544ae10" - integrity sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA== - dependencies: - "@babel/helper-plugin-utils" "^7.12.13" - -"@babel/plugin-syntax-class-static-block@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz#195df89b146b4b78b3bf897fd7a257c84659d406" - integrity sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw== - dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - -"@babel/plugin-syntax-decorators@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-decorators/-/plugin-syntax-decorators-7.19.0.tgz#5f13d1d8fce96951bea01a10424463c9a5b3a599" - integrity sha512-xaBZUEDntt4faL1yN8oIFlhfXeQAWJW7CLKYsHTUqriCUbj8xOra8bfxxKGi/UwExPFBuPdH4XfHc9rGQhrVkQ== - dependencies: - "@babel/helper-plugin-utils" "^7.19.0" - -"@babel/plugin-syntax-dynamic-import@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz#62bf98b2da3cd21d626154fc96ee5b3cb68eacb3" - integrity sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-export-namespace-from@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz#028964a9ba80dbc094c915c487ad7c4e7a66465a" - integrity sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q== - dependencies: - "@babel/helper-plugin-utils" "^7.8.3" - -"@babel/plugin-syntax-import-assertions@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.18.6.tgz#cd6190500a4fa2fe31990a963ffab4b63e4505e4" - integrity sha512-/DU3RXad9+bZwrgWJQKbr39gYbJpLJHezqEzRzi/BHRlJ9zsQb4CK2CA/5apllXNomwA1qHwzvHl+AdEmC5krQ== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-syntax-json-strings@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz#01ca21b668cd8218c9e640cb6dd88c5412b2c96a" - integrity sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-jsx@^7.0.0", "@babel/plugin-syntax-jsx@^7.12.13", "@babel/plugin-syntax-jsx@^7.2.0": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz#a8feef63b010150abd97f1649ec296e849943ca0" - integrity sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-syntax-logical-assignment-operators@^7.10.4": - version "7.10.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz#ca91ef46303530448b906652bac2e9fe9941f699" - integrity sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig== - dependencies: - "@babel/helper-plugin-utils" "^7.10.4" - -"@babel/plugin-syntax-nullish-coalescing-operator@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz#167ed70368886081f74b5c36c65a88c03b66d1a9" - integrity sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-numeric-separator@^7.10.4": - version "7.10.4" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz#b9b070b3e33570cd9fd07ba7fa91c0dd37b9af97" - integrity sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug== - dependencies: - "@babel/helper-plugin-utils" "^7.10.4" - -"@babel/plugin-syntax-object-rest-spread@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz#60e225edcbd98a640332a2e72dd3e66f1af55871" - integrity sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-optional-catch-binding@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz#6111a265bcfb020eb9efd0fdfd7d26402b9ed6c1" - integrity sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-optional-chaining@^7.8.3": - version "7.8.3" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz#4f69c2ab95167e0180cd5336613f8c5788f7d48a" - integrity sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg== - dependencies: - "@babel/helper-plugin-utils" "^7.8.0" - -"@babel/plugin-syntax-private-property-in-object@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz#0dc6671ec0ea22b6e94a1114f857970cd39de1ad" - integrity sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg== - dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - -"@babel/plugin-syntax-top-level-await@^7.14.5": - version "7.14.5" - resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz#c1cfdadc35a646240001f06138247b741c34d94c" - integrity sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw== - dependencies: - "@babel/helper-plugin-utils" "^7.14.5" - -"@babel/plugin-transform-arrow-functions@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz#19063fcf8771ec7b31d742339dac62433d0611fe" - integrity sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-async-to-generator@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz#ccda3d1ab9d5ced5265fdb13f1882d5476c71615" - integrity sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag== - dependencies: - "@babel/helper-module-imports" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/helper-remap-async-to-generator" "^7.18.6" - -"@babel/plugin-transform-block-scoped-functions@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz#9187bf4ba302635b9d70d986ad70f038726216a8" - integrity sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-block-scoping@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.18.9.tgz#f9b7e018ac3f373c81452d6ada8bd5a18928926d" - integrity sha512-5sDIJRV1KtQVEbt/EIBwGy4T01uYIo4KRB3VUqzkhrAIOGx7AoctL9+Ux88btY0zXdDyPJ9mW+bg+v+XEkGmtw== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-classes@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.19.0.tgz#0e61ec257fba409c41372175e7c1e606dc79bb20" - integrity sha512-YfeEE9kCjqTS9IitkgfJuxjcEtLUHMqa8yUJ6zdz8vR7hKuo6mOy2C05P0F1tdMmDCeuyidKnlrw/iTppHcr2A== - dependencies: - "@babel/helper-annotate-as-pure" "^7.18.6" - "@babel/helper-compilation-targets" "^7.19.0" - "@babel/helper-environment-visitor" "^7.18.9" - "@babel/helper-function-name" "^7.19.0" - "@babel/helper-optimise-call-expression" "^7.18.6" - "@babel/helper-plugin-utils" "^7.19.0" - "@babel/helper-replace-supers" "^7.18.9" - "@babel/helper-split-export-declaration" "^7.18.6" - globals "^11.1.0" - -"@babel/plugin-transform-computed-properties@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.9.tgz#2357a8224d402dad623caf6259b611e56aec746e" - integrity sha512-+i0ZU1bCDymKakLxn5srGHrsAPRELC2WIbzwjLhHW9SIE1cPYkLCL0NlnXMZaM1vhfgA2+M7hySk42VBvrkBRw== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-destructuring@^7.18.13": - version "7.18.13" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.18.13.tgz#9e03bc4a94475d62b7f4114938e6c5c33372cbf5" - integrity sha512-TodpQ29XekIsex2A+YJPj5ax2plkGa8YYY6mFjCohk/IG9IY42Rtuj1FuDeemfg2ipxIFLzPeA83SIBnlhSIow== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-dotall-regex@^7.18.6", "@babel/plugin-transform-dotall-regex@^7.4.4": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz#b286b3e7aae6c7b861e45bed0a2fafd6b1a4fef8" - integrity sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-duplicate-keys@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz#687f15ee3cdad6d85191eb2a372c4528eaa0ae0e" - integrity sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-exponentiation-operator@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz#421c705f4521888c65e91fdd1af951bfefd4dacd" - integrity sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw== - dependencies: - "@babel/helper-builder-binary-assignment-operator-visitor" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-for-of@^7.18.8": - version "7.18.8" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz#6ef8a50b244eb6a0bdbad0c7c61877e4e30097c1" - integrity sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-function-name@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz#cc354f8234e62968946c61a46d6365440fc764e0" - integrity sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ== - dependencies: - "@babel/helper-compilation-targets" "^7.18.9" - "@babel/helper-function-name" "^7.18.9" - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-literals@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz#72796fdbef80e56fba3c6a699d54f0de557444bc" - integrity sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-member-expression-literals@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz#ac9fdc1a118620ac49b7e7a5d2dc177a1bfee88e" - integrity sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-modules-amd@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.18.6.tgz#8c91f8c5115d2202f277549848874027d7172d21" - integrity sha512-Pra5aXsmTsOnjM3IajS8rTaLCy++nGM4v3YR4esk5PCsyg9z8NA5oQLwxzMUtDBd8F+UmVza3VxoAaWCbzH1rg== - dependencies: - "@babel/helper-module-transforms" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - babel-plugin-dynamic-import-node "^2.3.3" - -"@babel/plugin-transform-modules-commonjs@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.18.6.tgz#afd243afba166cca69892e24a8fd8c9f2ca87883" - integrity sha512-Qfv2ZOWikpvmedXQJDSbxNqy7Xr/j2Y8/KfijM0iJyKkBTmWuvCA1yeH1yDM7NJhBW/2aXxeucLj6i80/LAJ/Q== - dependencies: - "@babel/helper-module-transforms" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/helper-simple-access" "^7.18.6" - babel-plugin-dynamic-import-node "^2.3.3" - -"@babel/plugin-transform-modules-systemjs@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.19.0.tgz#5f20b471284430f02d9c5059d9b9a16d4b085a1f" - integrity sha512-x9aiR0WXAWmOWsqcsnrzGR+ieaTMVyGyffPVA7F8cXAGt/UxefYv6uSHZLkAFChN5M5Iy1+wjE+xJuPt22H39A== - dependencies: - "@babel/helper-hoist-variables" "^7.18.6" - "@babel/helper-module-transforms" "^7.19.0" - "@babel/helper-plugin-utils" "^7.19.0" - "@babel/helper-validator-identifier" "^7.18.6" - babel-plugin-dynamic-import-node "^2.3.3" - -"@babel/plugin-transform-modules-umd@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz#81d3832d6034b75b54e62821ba58f28ed0aab4b9" - integrity sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ== - dependencies: - "@babel/helper-module-transforms" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-named-capturing-groups-regex@^7.19.1": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.19.1.tgz#ec7455bab6cd8fb05c525a94876f435a48128888" - integrity sha512-oWk9l9WItWBQYS4FgXD4Uyy5kq898lvkXpXQxoJEY1RnvPk4R/Dvu2ebXU9q8lP+rlMwUQTFf2Ok6d78ODa0kw== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.19.0" - "@babel/helper-plugin-utils" "^7.19.0" - -"@babel/plugin-transform-new-target@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz#d128f376ae200477f37c4ddfcc722a8a1b3246a8" - integrity sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-object-super@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz#fb3c6ccdd15939b6ff7939944b51971ddc35912c" - integrity sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - "@babel/helper-replace-supers" "^7.18.6" - -"@babel/plugin-transform-parameters@^7.18.8": - version "7.18.8" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.18.8.tgz#ee9f1a0ce6d78af58d0956a9378ea3427cccb48a" - integrity sha512-ivfbE3X2Ss+Fj8nnXvKJS6sjRG4gzwPMsP+taZC+ZzEGjAYlvENixmt1sZ5Ca6tWls+BlKSGKPJ6OOXvXCbkFg== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-property-literals@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz#e22498903a483448e94e032e9bbb9c5ccbfc93a3" - integrity sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-regenerator@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.18.6.tgz#585c66cb84d4b4bf72519a34cfce761b8676ca73" - integrity sha512-poqRI2+qiSdeldcz4wTSTXBRryoq3Gc70ye7m7UD5Ww0nE29IXqMl6r7Nd15WBgRd74vloEMlShtH6CKxVzfmQ== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - regenerator-transform "^0.15.0" - -"@babel/plugin-transform-reserved-words@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz#b1abd8ebf8edaa5f7fe6bbb8d2133d23b6a6f76a" - integrity sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-runtime@^7.12.15": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.19.1.tgz#a3df2d7312eea624c7889a2dcd37fd1dfd25b2c6" - integrity sha512-2nJjTUFIzBMP/f/miLxEK9vxwW/KUXsdvN4sR//TmuDhe6yU2h57WmIOE12Gng3MDP/xpjUV/ToZRdcf8Yj4fA== - dependencies: - "@babel/helper-module-imports" "^7.18.6" - "@babel/helper-plugin-utils" "^7.19.0" - babel-plugin-polyfill-corejs2 "^0.3.3" - babel-plugin-polyfill-corejs3 "^0.6.0" - babel-plugin-polyfill-regenerator "^0.4.1" - semver "^6.3.0" - -"@babel/plugin-transform-shorthand-properties@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz#6d6df7983d67b195289be24909e3f12a8f664dc9" - integrity sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-spread@^7.19.0": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-spread/-/plugin-transform-spread-7.19.0.tgz#dd60b4620c2fec806d60cfaae364ec2188d593b6" - integrity sha512-RsuMk7j6n+r752EtzyScnWkQyuJdli6LdO5Klv8Yx0OfPVTcQkIUfS8clx5e9yHXzlnhOZF3CbQ8C2uP5j074w== - dependencies: - "@babel/helper-plugin-utils" "^7.19.0" - "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" - -"@babel/plugin-transform-sticky-regex@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz#c6706eb2b1524028e317720339583ad0f444adcc" - integrity sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q== - dependencies: - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/plugin-transform-template-literals@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz#04ec6f10acdaa81846689d63fae117dd9c243a5e" - integrity sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-typeof-symbol@^7.18.9": - version "7.18.9" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz#c8cea68263e45addcd6afc9091429f80925762c0" - integrity sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-unicode-escapes@^7.18.10": - version "7.18.10" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.10.tgz#1ecfb0eda83d09bbcb77c09970c2dd55832aa246" - integrity sha512-kKAdAI+YzPgGY/ftStBFXTI1LZFju38rYThnfMykS+IXy8BVx+res7s2fxf1l8I35DV2T97ezo6+SGrXz6B3iQ== - dependencies: - "@babel/helper-plugin-utils" "^7.18.9" - -"@babel/plugin-transform-unicode-regex@^7.18.6": - version "7.18.6" - resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz#194317225d8c201bbae103364ffe9e2cea36cdca" - integrity sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA== - dependencies: - "@babel/helper-create-regexp-features-plugin" "^7.18.6" - "@babel/helper-plugin-utils" "^7.18.6" - -"@babel/preset-env@^7.12.16": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.19.1.tgz#9f04c916f9c0205a48ebe5cc1be7768eb1983f67" - integrity sha512-c8B2c6D16Lp+Nt6HcD+nHl0VbPKVnNPTpszahuxJJnurfMtKeZ80A+qUv48Y7wqvS+dTFuLuaM9oYxyNHbCLWA== - dependencies: - "@babel/compat-data" "^7.19.1" - "@babel/helper-compilation-targets" "^7.19.1" - "@babel/helper-plugin-utils" "^7.19.0" - "@babel/helper-validator-option" "^7.18.6" - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression" "^7.18.6" - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.18.9" - "@babel/plugin-proposal-async-generator-functions" "^7.19.1" - "@babel/plugin-proposal-class-properties" "^7.18.6" - "@babel/plugin-proposal-class-static-block" "^7.18.6" - "@babel/plugin-proposal-dynamic-import" "^7.18.6" - "@babel/plugin-proposal-export-namespace-from" "^7.18.9" - "@babel/plugin-proposal-json-strings" "^7.18.6" - "@babel/plugin-proposal-logical-assignment-operators" "^7.18.9" - "@babel/plugin-proposal-nullish-coalescing-operator" "^7.18.6" - "@babel/plugin-proposal-numeric-separator" "^7.18.6" - "@babel/plugin-proposal-object-rest-spread" "^7.18.9" - "@babel/plugin-proposal-optional-catch-binding" "^7.18.6" - "@babel/plugin-proposal-optional-chaining" "^7.18.9" - "@babel/plugin-proposal-private-methods" "^7.18.6" - "@babel/plugin-proposal-private-property-in-object" "^7.18.6" - "@babel/plugin-proposal-unicode-property-regex" "^7.18.6" - "@babel/plugin-syntax-async-generators" "^7.8.4" - "@babel/plugin-syntax-class-properties" "^7.12.13" - "@babel/plugin-syntax-class-static-block" "^7.14.5" - "@babel/plugin-syntax-dynamic-import" "^7.8.3" - "@babel/plugin-syntax-export-namespace-from" "^7.8.3" - "@babel/plugin-syntax-import-assertions" "^7.18.6" - "@babel/plugin-syntax-json-strings" "^7.8.3" - "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" - "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" - "@babel/plugin-syntax-numeric-separator" "^7.10.4" - "@babel/plugin-syntax-object-rest-spread" "^7.8.3" - "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" - "@babel/plugin-syntax-optional-chaining" "^7.8.3" - "@babel/plugin-syntax-private-property-in-object" "^7.14.5" - "@babel/plugin-syntax-top-level-await" "^7.14.5" - "@babel/plugin-transform-arrow-functions" "^7.18.6" - "@babel/plugin-transform-async-to-generator" "^7.18.6" - "@babel/plugin-transform-block-scoped-functions" "^7.18.6" - "@babel/plugin-transform-block-scoping" "^7.18.9" - "@babel/plugin-transform-classes" "^7.19.0" - "@babel/plugin-transform-computed-properties" "^7.18.9" - "@babel/plugin-transform-destructuring" "^7.18.13" - "@babel/plugin-transform-dotall-regex" "^7.18.6" - "@babel/plugin-transform-duplicate-keys" "^7.18.9" - "@babel/plugin-transform-exponentiation-operator" "^7.18.6" - "@babel/plugin-transform-for-of" "^7.18.8" - "@babel/plugin-transform-function-name" "^7.18.9" - "@babel/plugin-transform-literals" "^7.18.9" - "@babel/plugin-transform-member-expression-literals" "^7.18.6" - "@babel/plugin-transform-modules-amd" "^7.18.6" - "@babel/plugin-transform-modules-commonjs" "^7.18.6" - "@babel/plugin-transform-modules-systemjs" "^7.19.0" - "@babel/plugin-transform-modules-umd" "^7.18.6" - "@babel/plugin-transform-named-capturing-groups-regex" "^7.19.1" - "@babel/plugin-transform-new-target" "^7.18.6" - "@babel/plugin-transform-object-super" "^7.18.6" - "@babel/plugin-transform-parameters" "^7.18.8" - "@babel/plugin-transform-property-literals" "^7.18.6" - "@babel/plugin-transform-regenerator" "^7.18.6" - "@babel/plugin-transform-reserved-words" "^7.18.6" - "@babel/plugin-transform-shorthand-properties" "^7.18.6" - "@babel/plugin-transform-spread" "^7.19.0" - "@babel/plugin-transform-sticky-regex" "^7.18.6" - "@babel/plugin-transform-template-literals" "^7.18.9" - "@babel/plugin-transform-typeof-symbol" "^7.18.9" - "@babel/plugin-transform-unicode-escapes" "^7.18.10" - "@babel/plugin-transform-unicode-regex" "^7.18.6" - "@babel/preset-modules" "^0.1.5" - "@babel/types" "^7.19.0" - babel-plugin-polyfill-corejs2 "^0.3.3" - babel-plugin-polyfill-corejs3 "^0.6.0" - babel-plugin-polyfill-regenerator "^0.4.1" - core-js-compat "^3.25.1" - semver "^6.3.0" - -"@babel/preset-modules@^0.1.5": - version "0.1.5" - resolved "https://registry.yarnpkg.com/@babel/preset-modules/-/preset-modules-0.1.5.tgz#ef939d6e7f268827e1841638dc6ff95515e115d9" - integrity sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA== - dependencies: - "@babel/helper-plugin-utils" "^7.0.0" - "@babel/plugin-proposal-unicode-property-regex" "^7.4.4" - "@babel/plugin-transform-dotall-regex" "^7.4.4" - "@babel/types" "^7.4.4" - esutils "^2.0.2" - -"@babel/runtime@^7.12.13", "@babel/runtime@^7.8.4": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.19.0.tgz#22b11c037b094d27a8a2504ea4dcff00f50e2259" - integrity sha512-eR8Lo9hnDS7tqkO7NsV+mKvCmv5boaXFSZ70DnfhcgiEne8hv9oCEd36Klw74EtizEqLsy4YnW8UWwpBVolHZA== - dependencies: - regenerator-runtime "^0.13.4" - -"@babel/template@^7.0.0", "@babel/template@^7.18.10": - version "7.18.10" - resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.18.10.tgz#6f9134835970d1dbf0835c0d100c9f38de0c5e71" - integrity sha512-TI+rCtooWHr3QJ27kJxfjutghu44DLnasDMwpDqCXVTal9RLp3RSYNh4NdBrRP2cQAoG9A8juOQl6P6oZG4JxA== - dependencies: - "@babel/code-frame" "^7.18.6" - "@babel/parser" "^7.18.10" - "@babel/types" "^7.18.10" - -"@babel/traverse@^7.0.0", "@babel/traverse@^7.19.0", "@babel/traverse@^7.19.1": - version "7.19.1" - resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.19.1.tgz#0fafe100a8c2a603b4718b1d9bf2568d1d193347" - integrity sha512-0j/ZfZMxKukDaag2PtOPDbwuELqIar6lLskVPPJDjXMXjfLb1Obo/1yjxIGqqAJrmfaTIY3z2wFLAQ7qSkLsuA== - dependencies: - "@babel/code-frame" "^7.18.6" - "@babel/generator" "^7.19.0" - "@babel/helper-environment-visitor" "^7.18.9" - "@babel/helper-function-name" "^7.19.0" - "@babel/helper-hoist-variables" "^7.18.6" - "@babel/helper-split-export-declaration" "^7.18.6" - "@babel/parser" "^7.19.1" - "@babel/types" "^7.19.0" - debug "^4.1.0" - globals "^11.1.0" - -"@babel/types@^7.0.0", "@babel/types@^7.18.10", "@babel/types@^7.18.6", "@babel/types@^7.18.9", "@babel/types@^7.19.0", "@babel/types@^7.4.4": - version "7.19.0" - resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.19.0.tgz#75f21d73d73dc0351f3368d28db73465f4814600" - integrity sha512-YuGopBq3ke25BVSiS6fgF49Ul9gH1x70Bcr6bqRLjWCkcX8Hre1/5+z+IiWOIerRMSSEfGZVB9z9kyq7wVs9YA== - dependencies: - "@babel/helper-string-parser" "^7.18.10" - "@babel/helper-validator-identifier" "^7.18.6" - to-fast-properties "^2.0.0" - -"@ckpack/vue-color@^1.4.1": - version "1.4.1" - resolved "https://registry.yarnpkg.com/@ckpack/vue-color/-/vue-color-1.4.1.tgz#d08c50755b2a731eb33d91b84b5997b98062ddc5" - integrity sha512-PPon4lIyKWgwexN4Gf8iRzqWVPWTa1nMoW37cKQbMakY/iBPiPzOtgGinNhD44STbv6GUnPLBCg6yfkXsPuFpw== - dependencies: - "@ctrl/tinycolor" "^3.6.0" - material-colors "^1.2.6" - -"@ctrl/tinycolor@^3.6.0": - version "3.6.0" - resolved "https://registry.yarnpkg.com/@ctrl/tinycolor/-/tinycolor-3.6.0.tgz#53fa5fe9c34faee89469e48f91d51a3766108bc8" - integrity sha512-/Z3l6pXthq0JvMYdUFyX9j0MaCltlIn6mfh9jLyQwg5aPKxkyNa0PTHtU1AlFXLNk55ZuAeJRcpvq+tmLfKmaQ== +"@alloc/quick-lru@^5.2.0": + version "5.2.0" + resolved "https://registry.npmmirror.com/@alloc/quick-lru/-/quick-lru-5.2.0.tgz#7bf68b20c0a350f936915fcae06f58e32007ce30" + integrity sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw== + +"@babel/parser@^7.23.0": + version "7.23.0" + resolved "https://registry.npmmirror.com/@babel/parser/-/parser-7.23.0.tgz#da950e622420bf96ca0d0f2909cdddac3acd8719" + integrity sha512-vvPKKdMemU85V9WE/l5wZEmImpCtLqbnTvqDS2U1fJ96KrxoW7KrXhNsNCblQlg8Ck4b85yxdTyelsMUgFUXiw== + +"@babel/runtime@^7.21.0": + version "7.23.2" + resolved "https://registry.npmmirror.com/@babel/runtime/-/runtime-7.23.2.tgz#062b0ac103261d68a966c4c7baf2ae3e62ec3885" + integrity sha512-mM8eg4yl5D6i3lu2QKPuPH4FArvJ8KhTofbE7jwMUv9KX5mBvwPAqnV3MlyBNqdp9RyRKP6Yck8TrfYrPvX3bg== + dependencies: + regenerator-runtime "^0.14.0" + +"@css-render/plugin-bem@^0.15.12": + version "0.15.12" + resolved "https://registry.npmmirror.com/@css-render/plugin-bem/-/plugin-bem-0.15.12.tgz#cd88e46a388e4786436bd622414da0aa6019af3b" + integrity sha512-Lq2jSOZn+wYQtsyaFj6QRz2EzAnd3iW5fZeHO1WSXQdVYwvwGX0ZiH3X2JQgtgYLT1yeGtrwrqJdNdMEUD2xTw== + +"@css-render/vue3-ssr@^0.15.10", "@css-render/vue3-ssr@^0.15.12": + version "0.15.12" + resolved "https://registry.npmmirror.com/@css-render/vue3-ssr/-/vue3-ssr-0.15.12.tgz#798d8dffadecd2bf8c80cbaab64e9df10be5626e" + integrity sha512-AQLGhhaE0F+rwybRCkKUdzBdTEM/5PZBYy+fSYe1T9z9+yxMuV/k7ZRqa4M69X+EI1W8pa4kc9Iq2VjQkZx4rg== "@develar/schema-utils@~2.6.5": version "2.6.5" - resolved "https://registry.yarnpkg.com/@develar/schema-utils/-/schema-utils-2.6.5.tgz#3ece22c5838402419a6e0425f85742b961d9b6c6" + resolved "https://registry.npmmirror.com/@develar/schema-utils/-/schema-utils-2.6.5.tgz#3ece22c5838402419a6e0425f85742b961d9b6c6" integrity sha512-0cp4PsWQ/9avqTVMCtZ+GirikIA36ikvjtHweU4/j8yLtgObI0+JUPhYFScgwlteveGB1rt3Cm8UhN04XayDig== dependencies: ajv "^6.12.0" ajv-keywords "^3.4.1" "@electron/asar@^3.2.1": - version "3.2.4" - resolved "https://registry.yarnpkg.com/@electron/asar/-/asar-3.2.4.tgz#7e8635a3c4f6d8b3f8ae6efaf5ecb9fbf3bd9864" - integrity sha512-lykfY3TJRRWFeTxccEKdf1I6BLl2Plw81H0bbp4Fc5iEc67foDCa5pjJQULVgo0wF+Dli75f3xVcdb/67FFZ/g== + version "3.2.7" + resolved "https://registry.npmmirror.com/@electron/asar/-/asar-3.2.7.tgz#bb8117dc6fd0c06a922ae7fb1c0e2d433e35a6e5" + integrity sha512-8FaSCAIiZGYFWyjeevPQt+0e9xCK9YmJ2Rjg5SXgdsXon6cRnU0Yxnbe6CvJbQn26baifur2Y2G5EBayRIsjyg== dependencies: - chromium-pickle-js "^0.2.0" commander "^5.0.0" glob "^7.1.6" minimatch "^3.0.4" "@electron/get@^2.0.0": - version "2.0.2" - resolved "https://registry.yarnpkg.com/@electron/get/-/get-2.0.2.tgz#ae2a967b22075e9c25aaf00d5941cd79c21efd7e" - integrity sha512-eFZVFoRXb3GFGd7Ak7W4+6jBl9wBtiZ4AaYOse97ej6mKj5tkyO0dUnUChs1IhJZtx1BENo4/p4WUTXpi6vT+g== + version "2.0.3" + resolved "https://registry.npmmirror.com/@electron/get/-/get-2.0.3.tgz#fba552683d387aebd9f3fcadbcafc8e12ee4f960" + integrity sha512-Qkzpg2s9GnVV2I2BjRksUi43U5e6+zaQMcjoJy0C+C5oxaKl+fmckGDQFtRpZpZV0NQekuZZ+tGz7EA9TVnQtQ== dependencies: debug "^4.1.1" env-paths "^2.2.0" @@ -1005,18 +66,19 @@ optionalDependencies: global-agent "^3.0.0" -"@electron/notarize@^1.2.3": - version "1.2.3" - resolved "https://registry.yarnpkg.com/@electron/notarize/-/notarize-1.2.3.tgz#38056a629e5a0b5fd56c975c4828c0f74285b644" - integrity sha512-9oRzT56rKh5bspk3KpAVF8lPKHYQrBnRwcgiOeR0hdilVEQmszDaAu0IPCPrwwzJN0ugNs0rRboTreHMt/6mBQ== +"@electron/notarize@2.1.0": + version "2.1.0" + resolved "https://registry.npmmirror.com/@electron/notarize/-/notarize-2.1.0.tgz#76aaec10c8687225e8d0a427cc9df67611c46ff3" + integrity sha512-Q02xem1D0sg4v437xHgmBLxI2iz/fc0D4K7fiVWHa/AnW8o7D751xyKNXgziA6HrTOme9ul1JfWN5ark8WH1xA== dependencies: debug "^4.1.1" fs-extra "^9.0.1" + promise-retry "^2.0.1" -"@electron/osx-sign@^1.0.4": - version "1.0.4" - resolved "https://registry.yarnpkg.com/@electron/osx-sign/-/osx-sign-1.0.4.tgz#8e91442846471636ca0469426a82b253b9170151" - integrity sha512-xfhdEcIOfAZg7scZ9RQPya1G1lWo8/zMCwUXAulq0SfY7ONIW+b9qGyKdMyuMctNYwllrIS+vmxfijSfjeh97g== +"@electron/osx-sign@1.0.5": + version "1.0.5" + resolved "https://registry.npmmirror.com/@electron/osx-sign/-/osx-sign-1.0.5.tgz#0af7149f2fce44d1a8215660fd25a9fb610454d8" + integrity sha512-k9ZzUQtamSoweGQDV2jILiRIHUu7lYlJ3c6IEmjv1hC17rclE+eb9U+f6UFlOOETo0JzY1HNlXy4YOlCvl+Lww== dependencies: compare-version "^0.1.2" debug "^4.3.4" @@ -1025,40 +87,10 @@ minimist "^1.2.6" plist "^3.0.5" -"@electron/rebuild@^3.2.13": - version "3.2.13" - resolved "https://registry.yarnpkg.com/@electron/rebuild/-/rebuild-3.2.13.tgz#98fbb98981b1a86162546a2ab91b2355569cca4c" - integrity sha512-DH9Ol4JCnHDYVOD0fKWq+Qqbn/0WU1O6QR0mIpMXEVU4YFM4PlaqNC9K36mGShNBxxGFotZCMDrB1wl/iHM12g== - dependencies: - "@malept/cross-spawn-promise" "^2.0.0" - chalk "^4.0.0" - debug "^4.1.1" - detect-libc "^2.0.1" - fs-extra "^10.0.0" - got "^11.7.0" - node-abi "^3.0.0" - node-api-version "^0.1.4" - node-gyp "^9.0.0" - ora "^5.1.0" - semver "^7.3.5" - tar "^6.0.5" - yargs "^17.0.1" - -"@electron/universal@1.0.5": - version "1.0.5" - resolved "https://registry.yarnpkg.com/@electron/universal/-/universal-1.0.5.tgz#b812340e4ef21da2b3ee77b2b4d35c9b86defe37" - integrity sha512-zX9O6+jr2NMyAdSkwEUlyltiI4/EBLu2Ls/VD3pUQdi3cAYeYfdQnT2AJJ38HE4QxLccbU13LSpccw1IWlkyag== - dependencies: - "@malept/cross-spawn-promise" "^1.1.0" - asar "^3.0.3" - debug "^4.3.1" - dir-compare "^2.4.0" - fs-extra "^9.0.1" - -"@electron/universal@1.3.4": - version "1.3.4" - resolved "https://registry.yarnpkg.com/@electron/universal/-/universal-1.3.4.tgz#bccd94b635d7c85eeed5eabba457eb4ed2be2777" - integrity sha512-BdhBgm2ZBnYyYRLRgOjM5VHkyFItsbggJ0MHycOjKWdFGYwK97ZFXH54dTvUWEfha81vfvwr5On6XBjt99uDcg== +"@electron/universal@1.4.1": + version "1.4.1" + resolved "https://registry.npmmirror.com/@electron/universal/-/universal-1.4.1.tgz#3fbda2a5ed9ff9f3304c8e8316b94c1e3a7b3785" + integrity sha512-lE/U3UNw1YHuowNbTmKNs9UlS3En3cPgwM5MI+agIgr/B1hSze9NdOP0qn7boZaI9Lph8IDv3/24g9IxnJP7aQ== dependencies: "@electron/asar" "^3.2.1" "@malept/cross-spawn-promise" "^1.1.0" @@ -1068,369 +100,168 @@ minimatch "^3.0.4" plist "^3.0.4" -"@gar/promisify@^1.1.3": - version "1.1.3" - resolved "https://registry.yarnpkg.com/@gar/promisify/-/promisify-1.1.3.tgz#555193ab2e3bb3b6adc3d551c9c030d9e860daf6" - integrity sha512-k2Ty1JcVojjJFwrg/ThKi2ujJ7XNLYaFGNB/bWT9wGR+oSMJHMa5w+CUq6p/pVrKeNNgA7pCqEcjSnHVoqJQFw== +"@emotion/hash@~0.8.0": + version "0.8.0" + resolved "https://registry.npmmirror.com/@emotion/hash/-/hash-0.8.0.tgz#bbbff68978fefdbe68ccb533bc8cbe1d1afb5413" + integrity sha512-kBJtf7PH6aWwZ6fka3zQ0p6SBYzx4fl1LoZXE2RrnYST9Xljm7WfKJrU4g/Xr3Beg72MLrp1AWNUmuYJTL7Cow== -"@hapi/hoek@^9.0.0": - version "9.3.0" - resolved "https://registry.yarnpkg.com/@hapi/hoek/-/hoek-9.3.0.tgz#8368869dcb735be2e7f5cb7647de78e167a251fb" - integrity sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ== +"@esbuild/android-arm64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/android-arm64/-/android-arm64-0.18.20.tgz#984b4f9c8d0377443cc2dfcef266d02244593622" + integrity sha512-Nz4rJcchGDtENV0eMKUNa6L12zz2zBDXuhj/Vjh18zGqB44Bi7MBMSXjgunJgjRhCmKOjnPuZp4Mb6OKqtMHLQ== -"@hapi/topo@^5.0.0": - version "5.1.0" - resolved "https://registry.yarnpkg.com/@hapi/topo/-/topo-5.1.0.tgz#dc448e332c6c6e37a4dc02fd84ba8d44b9afb012" - integrity sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg== - dependencies: - "@hapi/hoek" "^9.0.0" +"@esbuild/android-arm@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/android-arm/-/android-arm-0.18.20.tgz#fedb265bc3a589c84cc11f810804f234947c3682" + integrity sha512-fyi7TDI/ijKKNZTUJAQqiG5T7YjJXgnzkURqmGj13C6dCqckZBLdl4h7bkhHt/t0WP+zO9/zwroDvANaOqO5Sw== -"@jimp/bmp@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/bmp/-/bmp-0.22.7.tgz#354ecedb4cbe66587cd06d3cb713d7e0740d768e" - integrity sha512-0cfBPvugURS7G+60vRBL+penDRst8x40alS5Rhn2nlGsgsBHljFDw7+H4o5r6gldw9nv9PR9JA90Wloy7KMZdQ== - dependencies: - "@jimp/utils" "^0.22.7" - bmp-js "^0.1.0" +"@esbuild/android-x64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/android-x64/-/android-x64-0.18.20.tgz#35cf419c4cfc8babe8893d296cd990e9e9f756f2" + integrity sha512-8GDdlePJA8D6zlZYJV/jnrRAi6rOiNaCC/JclcXpB+KIuvfBN4owLtgzY2bsxnx666XjJx2kDPUmnTtR8qKQUg== -"@jimp/core@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/core/-/core-0.22.7.tgz#8bfa365b71669e9746ba0c3ec69029b8494a382c" - integrity sha512-lg4z+pw23v2Gp9LWQur0NqYtnmoNWnyN/Or96elhJgeEJskrDGwROdajortHCCOI1xDnUZSirg8sFvStC8BIlg== - dependencies: - "@jimp/utils" "^0.22.7" - any-base "^1.1.0" - buffer "^5.2.0" - exif-parser "^0.1.12" - file-type "^16.5.4" - isomorphic-fetch "^3.0.0" - mkdirp "^2.1.3" - pixelmatch "^4.0.2" - tinycolor2 "^1.6.0" +"@esbuild/darwin-arm64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/darwin-arm64/-/darwin-arm64-0.18.20.tgz#08172cbeccf95fbc383399a7f39cfbddaeb0d7c1" + integrity sha512-bxRHW5kHU38zS2lPTPOyuyTm+S+eobPUnTNkdJEfAddYgEcll4xkT8DB9d2008DtTbl7uJag2HuE5NZAZgnNEA== -"@jimp/custom@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/custom/-/custom-0.22.7.tgz#6d34a7df2a94eb295c822287109142fc20e46841" - integrity sha512-n+1+ZVDNumB1E+sL7KdGKAJ6MbgniX1/v/xOEFEQ46WDZ4cRTqP4+tXjHTuHSlOXiANH+K9zD6qgzqmgO6mCVw== - dependencies: - "@jimp/core" "^0.22.7" +"@esbuild/darwin-x64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/darwin-x64/-/darwin-x64-0.18.20.tgz#d70d5790d8bf475556b67d0f8b7c5bdff053d85d" + integrity sha512-pc5gxlMDxzm513qPGbCbDukOdsGtKhfxD1zJKXjCCcU7ju50O7MeAZ8c4krSJcOIJGFR+qx21yMMVYwiQvyTyQ== -"@jimp/gif@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/gif/-/gif-0.22.7.tgz#7194e9ae3ce86534918d356e5d31d44c6a3e3730" - integrity sha512-PGZMS8sYFnDcqg+t8IT3RaSJLrqB+3GzhI0hU5D4mmSuJ5UO/6Bdgu8nrwh3uFPxw0ZH6h9ozYk88cz0pKEhLQ== - dependencies: - "@jimp/utils" "^0.22.7" - gifwrap "^0.9.2" - omggif "^1.0.9" +"@esbuild/freebsd-arm64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.20.tgz#98755cd12707f93f210e2494d6a4b51b96977f54" + integrity sha512-yqDQHy4QHevpMAaxhhIwYPMv1NECwOvIpGCZkECn8w2WFHXjEwrBn3CeNIYsibZ/iZEUemj++M26W3cNR5h+Tw== -"@jimp/jpeg@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/jpeg/-/jpeg-0.22.7.tgz#31a92dbdc84c0648701a2a2f94c0dd7e7cb342c5" - integrity sha512-ptwWyX/7RPcREy8SpPN/8IlywbwyPXiuXmoHwM6m4iKcyaCmmnfCdZwLNXYliJzFAFLLOWDuOrwO3cZSkH6Czg== - dependencies: - "@jimp/utils" "^0.22.7" - jpeg-js "^0.4.4" +"@esbuild/freebsd-x64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/freebsd-x64/-/freebsd-x64-0.18.20.tgz#c1eb2bff03915f87c29cece4c1a7fa1f423b066e" + integrity sha512-tgWRPPuQsd3RmBZwarGVHZQvtzfEBOreNuxEMKFcd5DaDn2PbBxfwLcj4+aenoh7ctXcbXmOQIn8HI6mCSw5MQ== -"@jimp/plugin-blit@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-blit/-/plugin-blit-0.22.7.tgz#8f8c000e0b9a0e5710635465dba2ec68bf153926" - integrity sha512-8oXcBTSd/sBmTQATrCxQ1ZBER31Lge8vXzWqNCbC3b1ZvRggCcqnDzRRH1+JiI4i+jPRo3Fi6/sdvEUyQ5LY3g== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/linux-arm64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-arm64/-/linux-arm64-0.18.20.tgz#bad4238bd8f4fc25b5a021280c770ab5fc3a02a0" + integrity sha512-2YbscF+UL7SQAVIpnWvYwM+3LskyDmPhe31pE7/aoTMFKKzIc9lLbyGUpmmb8a8AixOL61sQ/mFh3jEjHYFvdA== -"@jimp/plugin-blur@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-blur/-/plugin-blur-0.22.7.tgz#497cfe9ce0fdc935cd584b2bee0d963845448da5" - integrity sha512-M+0I5CKFIpnIQE27j8o8NECBsOFBd4z7C95ydy2UohYopugFq+hSVtMs1D4pQgb0RW1DJPiXD/4PHqb+lzV5mA== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/linux-arm@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-arm/-/linux-arm-0.18.20.tgz#3e617c61f33508a27150ee417543c8ab5acc73b0" + integrity sha512-/5bHkMWnq1EgKr1V+Ybz3s1hWXok7mDFUMQ4cG10AfW3wL02PSZi5kFpYKrptDsgb2WAJIvRcDm+qIvXf/apvg== -"@jimp/plugin-circle@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-circle/-/plugin-circle-0.22.7.tgz#6d05361b04f58eeb7302a947880241d1d32904d6" - integrity sha512-zfZKKpOhlyiDeFjGW5JB9K4h/kvbdaAJWUEwmKrvvGar67G3j8dKu46AX0MeWRNZ1yk/lfz+JIa7TzKfxEBf6w== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/linux-ia32@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-ia32/-/linux-ia32-0.18.20.tgz#699391cccba9aee6019b7f9892eb99219f1570a7" + integrity sha512-P4etWwq6IsReT0E1KHU40bOnzMHoH73aXp96Fs8TIT6z9Hu8G6+0SHSw9i2isWrD2nbx2qo5yUqACgdfVGx7TA== -"@jimp/plugin-color@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-color/-/plugin-color-0.22.7.tgz#c705d4c245708dae731bf0ea1e2684c22892fb3c" - integrity sha512-OXro9pdB0twQjV4LgW0bTEXaX1VgBsTBcFoDAs8q9mtQzD5p3UQmJ+ykCiQ5rTPxNN1Buc44tcCIfp8haB1ZVQ== - dependencies: - "@jimp/utils" "^0.22.7" - tinycolor2 "^1.6.0" +"@esbuild/linux-loong64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-loong64/-/linux-loong64-0.18.20.tgz#e6fccb7aac178dd2ffb9860465ac89d7f23b977d" + integrity sha512-nXW8nqBTrOpDLPgPY9uV+/1DjxoQ7DoB2N8eocyq8I9XuqJ7BiAMDMf9n1xZM9TgW0J8zrquIb/A7s3BJv7rjg== -"@jimp/plugin-contain@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-contain/-/plugin-contain-0.22.7.tgz#f3caf429255ec601ff15ba2016721d10f48f7c91" - integrity sha512-GwUxZp4jMA0O0qbknUPDONJAfHFaTRs8kK+jgRtUfgb1Xi96l5RN/PMMDv4owZCUiPVAON80X1BMj7nSQWNVUw== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/linux-mips64el@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-mips64el/-/linux-mips64el-0.18.20.tgz#eeff3a937de9c2310de30622a957ad1bd9183231" + integrity sha512-d5NeaXZcHp8PzYy5VnXV3VSd2D328Zb+9dEq5HE6bw6+N86JVPExrA6O68OPwobntbNJ0pzCpUFZTo3w0GyetQ== -"@jimp/plugin-cover@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-cover/-/plugin-cover-0.22.7.tgz#15a08fae12a0386f1f2459717ba817793f7914db" - integrity sha512-PVXeQyofGepMoJaQ5XapLwCcZfsOF1IoAotHosh8AOP8niCP/Erm8T6ZWf5tf0sMJiLHQMPUyns186H5isqEMQ== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/linux-ppc64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-ppc64/-/linux-ppc64-0.18.20.tgz#2f7156bde20b01527993e6881435ad79ba9599fb" + integrity sha512-WHPyeScRNcmANnLQkq6AfyXRFr5D6N2sKgkFo2FqguP44Nw2eyDlbTdZwd9GYk98DZG9QItIiTlFLHJHjxP3FA== -"@jimp/plugin-crop@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-crop/-/plugin-crop-0.22.7.tgz#2f46bb905cd853618a19bc0d0b4b7fba9a7397bf" - integrity sha512-XXvUU+hPdodtTBSgyUJUnzh7JgKMVlS1GxjcQsjYU8iGr1dbpuazKMTQxc76ChVmy8ue4goi8bGstacWUHpl/Q== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/linux-riscv64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-riscv64/-/linux-riscv64-0.18.20.tgz#6628389f210123d8b4743045af8caa7d4ddfc7a6" + integrity sha512-WSxo6h5ecI5XH34KC7w5veNnKkju3zBRLEQNY7mv5mtBmrP/MjNBCAlsM2u5hDBlS3NGcTQpoBvRzqBcRtpq1A== -"@jimp/plugin-displace@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-displace/-/plugin-displace-0.22.7.tgz#a45de07dcaa5e5f7ca87c50b1245eaf7fe8ad5cf" - integrity sha512-CCNAkmm2OS4QQtNRfQvXqoAMxNE0maSlVEV5DNdioHOUKycy02EJ5hNYR3l0FG+NraQHOuqv9XV37sGRl6QzMA== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/linux-s390x@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-s390x/-/linux-s390x-0.18.20.tgz#255e81fb289b101026131858ab99fba63dcf0071" + integrity sha512-+8231GMs3mAEth6Ja1iK0a1sQ3ohfcpzpRLH8uuc5/KVDFneH6jtAJLFGafpzpMRO6DzJ6AvXKze9LfFMrIHVQ== -"@jimp/plugin-dither@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-dither/-/plugin-dither-0.22.7.tgz#7027aa10140f2b7429a05906d21b37d91452f424" - integrity sha512-ndCW5MIGMdh3aBvvgRCO7el9cIPG29kU7xQYlOs5+3JsDk3Vf7X30QGPjzxABOY95qLUNUjf5Qe/p/tqv/vbcw== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/linux-x64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/linux-x64/-/linux-x64-0.18.20.tgz#c7690b3417af318a9b6f96df3031a8865176d338" + integrity sha512-UYqiqemphJcNsFEskc73jQ7B9jgwjWrSayxawS6UVFZGWrAAtkzjxSqnoclCXxWtfwLdzU+vTpcNYhpn43uP1w== -"@jimp/plugin-fisheye@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-fisheye/-/plugin-fisheye-0.22.7.tgz#38e14dbb99835e3fac9cd0cffc332dcd43b68db4" - integrity sha512-boI1QowhZRfb6OF+ZPWtiSJP1GATsTHjd5Oy/lJ+n0L4rp439ZOTB1Elzcgc44O2C1mgZDdybRPQQvYdPF8slA== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/netbsd-x64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/netbsd-x64/-/netbsd-x64-0.18.20.tgz#30e8cd8a3dded63975e2df2438ca109601ebe0d1" + integrity sha512-iO1c++VP6xUBUmltHZoMtCUdPlnPGdBom6IrO4gyKPFFVBKioIImVooR5I83nTew5UOYrk3gIJhbZh8X44y06A== -"@jimp/plugin-flip@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-flip/-/plugin-flip-0.22.7.tgz#c6419645c49f5a9c4dd6dd19c91ed77ecbb0881a" - integrity sha512-/jkbgtvQPcKadAEV5ZXyoEpSdd7GEvGs/Ya/f48+LNszc+S24u4UXtuP3QPRJ5FHm0Re1t4uztM7xa6IPklAOA== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/openbsd-x64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/openbsd-x64/-/openbsd-x64-0.18.20.tgz#7812af31b205055874c8082ea9cf9ab0da6217ae" + integrity sha512-e5e4YSsuQfX4cxcygw/UCPIEP6wbIL+se3sxPdCiMbFLBWu0eiZOJ7WoD+ptCLrmjZBK1Wk7I6D/I3NglUGOxg== -"@jimp/plugin-gaussian@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-gaussian/-/plugin-gaussian-0.22.7.tgz#dcc3bfc05b7886dd5ef0ccb14a319085930dca2f" - integrity sha512-OB1sdnjzq2rfUHmx9Rvi3SJIDbQAgWFgYEw6KhN3TSVOdrJHvwrQkEnwR9PoUzQg992VIpGcVc9Y1s/SOU2oCA== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/sunos-x64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/sunos-x64/-/sunos-x64-0.18.20.tgz#d5c275c3b4e73c9b0ecd38d1ca62c020f887ab9d" + integrity sha512-kDbFRFp0YpTQVVrqUd5FTYmWo45zGaXe0X8E1G/LKFC0v8x0vWrhOWSLITcCn63lmZIxfOMXtCfti/RxN/0wnQ== -"@jimp/plugin-invert@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-invert/-/plugin-invert-0.22.7.tgz#96bfd07dbb68ad9558b5c6d19b6476aa072523f8" - integrity sha512-dX/TqACJ/M5uXDIEJlVPPwietMD6EWUeA/CV4uvhLz9EMjTgHociJ3TWqGCY/70phhIBLbhLcHUVBL/q65ynfQ== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/win32-arm64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/win32-arm64/-/win32-arm64-0.18.20.tgz#73bc7f5a9f8a77805f357fab97f290d0e4820ac9" + integrity sha512-ddYFR6ItYgoaq4v4JmQQaAI5s7npztfV4Ag6NrhiaW0RrnOXqBkgwZLofVTlq1daVTQNhtI5oieTvkRPfZrePg== -"@jimp/plugin-mask@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-mask/-/plugin-mask-0.22.7.tgz#37e8a06b23c47b1c4a3f18bed7f50a52cc25e236" - integrity sha512-rfKHKJLAtJG7qbB4zYAMcQ9ue3CIFRuAJ3xX0lzCxC0fGvCVuXlcxiAEauBxqaTWqiKMnahqpR3/Ah679K2FKQ== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/win32-ia32@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/win32-ia32/-/win32-ia32-0.18.20.tgz#ec93cbf0ef1085cc12e71e0d661d20569ff42102" + integrity sha512-Wv7QBi3ID/rROT08SABTS7eV4hX26sVduqDOTe1MvGMjNd3EjOz4b7zeexIR62GTIEKrfJXKL9LFxTYgkyeu7g== -"@jimp/plugin-normalize@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-normalize/-/plugin-normalize-0.22.7.tgz#cc64132e69862c8b2901a0be88cf9370b43dd1b6" - integrity sha512-t8x2jjKDmvUAZB4Wbeagr4D0BvoVCIWquy94mpglvSZ8ujKLt0aQBl3CBEIbXFAoVqNif+G36NtxPHNsjxIXOg== - dependencies: - "@jimp/utils" "^0.22.7" +"@esbuild/win32-x64@0.18.20": + version "0.18.20" + resolved "https://registry.npmmirror.com/@esbuild/win32-x64/-/win32-x64-0.18.20.tgz#786c5f41f043b07afb1af37683d7c33668858f6d" + integrity sha512-kTdfRcSiDfQca/y9QIkng02avJ+NCaQvrMejlsB3RRv5sE9rRoeBPISaZpKxHELzRxZyLvNts1P27W3wV+8geQ== -"@jimp/plugin-print@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-print/-/plugin-print-0.22.7.tgz#596251eaeedb5f0d1a2761771015d27242370edb" - integrity sha512-kx0+cPeinki1IFg9cJy7LC4uVuOEOa8TIrcERioB6PVgJ7EDzCAfatTKULZ+t4uSs2K/lQF97wPYlbiyxs/Hzg== - dependencies: - "@jimp/utils" "^0.22.7" - load-bmfont "^1.4.1" - -"@jimp/plugin-resize@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-resize/-/plugin-resize-0.22.7.tgz#d1b711664106b35e6cfcce73a6aefcffde65304f" - integrity sha512-pg7i0JIYt7x7ag+CoD/yG70Xvwm1sKRfcFjQh954yestiin14uppPgXchAmTBmctecBjLNdsVlqSXbPvU4Jvxw== - dependencies: - "@jimp/utils" "^0.22.7" - -"@jimp/plugin-rotate@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-rotate/-/plugin-rotate-0.22.7.tgz#a864d736f04e4a5d5813c1d5761b3af84c98cf52" - integrity sha512-Uh3Gb18IY8uXWk6E1bzMopum2GP+xwohbnMIDE0MSWmLaz7LXrfnvgXFba1uRGgn73CJz8UDS4fC1KIJMuxQZA== - dependencies: - "@jimp/utils" "^0.22.7" - -"@jimp/plugin-scale@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-scale/-/plugin-scale-0.22.7.tgz#5f520370914402b7da6a751f415e677da58cb9ff" - integrity sha512-3uHUrk5Rl6MCxuoJtHTSeJjSHIxHWqOOgmD2caKIvyxds0Zmofu/Fva+N4V/m80E4q4G2RXNsUplFpFGhUM7hw== - dependencies: - "@jimp/utils" "^0.22.7" - -"@jimp/plugin-shadow@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-shadow/-/plugin-shadow-0.22.7.tgz#311392c7727f43bb3cb06cda1dc9d2f985545bb4" - integrity sha512-NKEq5VR8U/d0OKf0hxFtrrbMCuNv7by31V+Kwgxb1oTP+j+zZEaww+m3YgEwIwRe7E8/yeDSHa5bJ+CmuyFZjw== - dependencies: - "@jimp/utils" "^0.22.7" - -"@jimp/plugin-threshold@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugin-threshold/-/plugin-threshold-0.22.7.tgz#d5efdfac88f22882f3eabee4525feddcaca51244" - integrity sha512-BH4aLwfmnqjRVhdzMIqUns4ycZ6QoHHFR6Qz+X2iSpH5a33xFA4DRbd3Ehtrs4Gk7XiCjWkUyM6wjmH7l/1hNQ== - dependencies: - "@jimp/utils" "^0.22.7" - -"@jimp/plugins@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/plugins/-/plugins-0.22.7.tgz#2ee1258a005f135f0bc103286faed05acdc8a3b0" - integrity sha512-AJmzTG/sa+CDpvle/UE89hjHR85gnRGSwLuQqPbhlY6GFCmC3uqHRJz9O5I8A4zdi9+e8LsBphuTlKV7RbuXOw== - dependencies: - "@jimp/plugin-blit" "^0.22.7" - "@jimp/plugin-blur" "^0.22.7" - "@jimp/plugin-circle" "^0.22.7" - "@jimp/plugin-color" "^0.22.7" - "@jimp/plugin-contain" "^0.22.7" - "@jimp/plugin-cover" "^0.22.7" - "@jimp/plugin-crop" "^0.22.7" - "@jimp/plugin-displace" "^0.22.7" - "@jimp/plugin-dither" "^0.22.7" - "@jimp/plugin-fisheye" "^0.22.7" - "@jimp/plugin-flip" "^0.22.7" - "@jimp/plugin-gaussian" "^0.22.7" - "@jimp/plugin-invert" "^0.22.7" - "@jimp/plugin-mask" "^0.22.7" - "@jimp/plugin-normalize" "^0.22.7" - "@jimp/plugin-print" "^0.22.7" - "@jimp/plugin-resize" "^0.22.7" - "@jimp/plugin-rotate" "^0.22.7" - "@jimp/plugin-scale" "^0.22.7" - "@jimp/plugin-shadow" "^0.22.7" - "@jimp/plugin-threshold" "^0.22.7" - timm "^1.6.1" - -"@jimp/png@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/png/-/png-0.22.7.tgz#4f2b641a99192419e3eef8e50e229115fa2df3cc" - integrity sha512-LxD3O9FKEwVv+j+HcUV7ez72Miy+823EjhtFZbBYXNp9qjHtHFBpgcSJBftUOCei8OlmmVgULYn9XjyfPsDgGw== - dependencies: - "@jimp/utils" "^0.22.7" - pngjs "^6.0.0" - -"@jimp/tiff@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/tiff/-/tiff-0.22.7.tgz#2f1c6d0ab71ab5b64d73e7b328a61a70c27f3c88" - integrity sha512-/oE8kLumzBfU1Z6h4TrDXYCGQNc4CjbZQvPssjImEqNLr5vbefpIpoy1fVMpsyuHZHsGovsBhBHxTJaRLO4+Og== - dependencies: - utif2 "^4.0.1" - -"@jimp/types@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/types/-/types-0.22.7.tgz#388ea61d08a0449eabc94d9b14737db66e83b276" - integrity sha512-1T8BxwDh5HJvBh3tt6HUd8r7ir5Ge3JWATXC8O3Y9QYwOaERjA2+FVhGSjtoo5xCeJvLRjSzEtfZ8heowMBL4w== - dependencies: - "@jimp/bmp" "^0.22.7" - "@jimp/gif" "^0.22.7" - "@jimp/jpeg" "^0.22.7" - "@jimp/png" "^0.22.7" - "@jimp/tiff" "^0.22.7" - timm "^1.6.1" - -"@jimp/utils@^0.22.7": - version "0.22.7" - resolved "https://registry.yarnpkg.com/@jimp/utils/-/utils-0.22.7.tgz#67a061c2f59e822d448b46fd7bb7dec36f8eb16d" - integrity sha512-4ax4IOWLIERx4yz9y3fNXKvQaPOY23yJF5h4sizxVkQUObkZHWE0kL0TVHodBt3rS8ksdbCL8Jkz4GeNP/Katg== - dependencies: - regenerator-runtime "^0.13.3" - -"@jridgewell/gen-mapping@^0.1.0": - version "0.1.1" - resolved "https://registry.yarnpkg.com/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz#e5d2e450306a9491e3bd77e323e38d7aff315996" - integrity sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w== - dependencies: - "@jridgewell/set-array" "^1.0.0" - "@jridgewell/sourcemap-codec" "^1.4.10" - -"@jridgewell/gen-mapping@^0.3.0", "@jridgewell/gen-mapping@^0.3.2": - version "0.3.2" - resolved "https://registry.yarnpkg.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz#c1aedc61e853f2bb9f5dfe6d4442d3b565b253b9" - integrity sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A== +"@jridgewell/gen-mapping@^0.3.2": + version "0.3.3" + resolved "https://registry.npmmirror.com/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz#7e02e6eb5df901aaedb08514203b096614024098" + integrity sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ== dependencies: "@jridgewell/set-array" "^1.0.1" "@jridgewell/sourcemap-codec" "^1.4.10" "@jridgewell/trace-mapping" "^0.3.9" -"@jridgewell/resolve-uri@3.1.0", "@jridgewell/resolve-uri@^3.0.3": - version "3.1.0" - resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz#2203b118c157721addfe69d47b70465463066d78" - integrity sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w== +"@jridgewell/resolve-uri@^3.1.0": + version "3.1.1" + resolved "https://registry.npmmirror.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz#c08679063f279615a3326583ba3a90d1d82cc721" + integrity sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA== -"@jridgewell/set-array@^1.0.0", "@jridgewell/set-array@^1.0.1": +"@jridgewell/set-array@^1.0.1": version "1.1.2" - resolved "https://registry.yarnpkg.com/@jridgewell/set-array/-/set-array-1.1.2.tgz#7c6cf998d6d20b914c0a55a91ae928ff25965e72" + resolved "https://registry.npmmirror.com/@jridgewell/set-array/-/set-array-1.1.2.tgz#7c6cf998d6d20b914c0a55a91ae928ff25965e72" integrity sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw== -"@jridgewell/source-map@^0.3.2": - version "0.3.2" - resolved "https://registry.yarnpkg.com/@jridgewell/source-map/-/source-map-0.3.2.tgz#f45351aaed4527a298512ec72f81040c998580fb" - integrity sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw== - dependencies: - "@jridgewell/gen-mapping" "^0.3.0" - "@jridgewell/trace-mapping" "^0.3.9" - -"@jridgewell/sourcemap-codec@1.4.14", "@jridgewell/sourcemap-codec@^1.4.10": - version "1.4.14" - resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz#add4c98d341472a289190b424efbdb096991bb24" - integrity sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw== - -"@jridgewell/sourcemap-codec@^1.4.13": +"@jridgewell/sourcemap-codec@^1.4.10", "@jridgewell/sourcemap-codec@^1.4.14", "@jridgewell/sourcemap-codec@^1.4.15": version "1.4.15" - resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz#d7c6e6755c78567a951e04ab52ef0fd26de59f32" + resolved "https://registry.npmmirror.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz#d7c6e6755c78567a951e04ab52ef0fd26de59f32" integrity sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg== -"@jridgewell/trace-mapping@^0.3.14", "@jridgewell/trace-mapping@^0.3.9": - version "0.3.15" - resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.15.tgz#aba35c48a38d3fd84b37e66c9c0423f9744f9774" - integrity sha512-oWZNOULl+UbhsgB51uuZzglikfIKSUBO/M9W2OfEjn7cmqoAiCgmv9lyACTUacZwBz0ITnJ2NqjU8Tx0DHL88g== +"@jridgewell/trace-mapping@^0.3.9": + version "0.3.20" + resolved "https://registry.npmmirror.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.20.tgz#72e45707cf240fa6b081d0366f8265b0cd10197f" + integrity sha512-R8LcPeWZol2zR8mmH3JeKQ6QRCFb7XgUhV9ZlGhHLGyg4wpPiPZNQOOWhFZhxKw8u//yTbNGI42Bx/3paXEQ+Q== dependencies: - "@jridgewell/resolve-uri" "^3.0.3" - "@jridgewell/sourcemap-codec" "^1.4.10" - -"@jridgewell/trace-mapping@^0.3.17": - version "0.3.18" - resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz#25783b2086daf6ff1dcb53c9249ae480e4dd4cd6" - integrity sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA== - dependencies: - "@jridgewell/resolve-uri" "3.1.0" - "@jridgewell/sourcemap-codec" "1.4.14" + "@jridgewell/resolve-uri" "^3.1.0" + "@jridgewell/sourcemap-codec" "^1.4.14" "@juggle/resize-observer@^3.3.1": version "3.4.0" - resolved "https://registry.yarnpkg.com/@juggle/resize-observer/-/resize-observer-3.4.0.tgz#08d6c5e20cf7e4cc02fd181c4b0c225cd31dbb60" + resolved "https://registry.npmmirror.com/@juggle/resize-observer/-/resize-observer-3.4.0.tgz#08d6c5e20cf7e4cc02fd181c4b0c225cd31dbb60" integrity sha512-dfLbk+PwWvFzSxwk3n5ySL0hfBog779o8h68wK/7/APo/7cgyWp5jcXockbxdk5kFRkbeXWm4Fbi9FrdN381sA== -"@leichtgewicht/ip-codec@^2.0.1": - version "2.0.4" - resolved "https://registry.yarnpkg.com/@leichtgewicht/ip-codec/-/ip-codec-2.0.4.tgz#b2ac626d6cb9c8718ab459166d4bb405b8ffa78b" - integrity sha512-Hcv+nVC0kZnQ3tD9GVu5xSMR4VVYOteQIr/hwFPVEvPdlXqgGEuRjiheChHgdM+JyqdgNcmzZOX/tnl0JOiI7A== - "@malept/cross-spawn-promise@^1.1.0": version "1.1.1" - resolved "https://registry.yarnpkg.com/@malept/cross-spawn-promise/-/cross-spawn-promise-1.1.1.tgz#504af200af6b98e198bce768bc1730c6936ae01d" + resolved "https://registry.npmmirror.com/@malept/cross-spawn-promise/-/cross-spawn-promise-1.1.1.tgz#504af200af6b98e198bce768bc1730c6936ae01d" integrity sha512-RTBGWL5FWQcg9orDOCcp4LvItNzUPcyEU9bwaeJX0rJ1IQxzucC48Y0/sQLp/g6t99IQgAlGIaesJS+gTn7tVQ== dependencies: cross-spawn "^7.0.1" -"@malept/cross-spawn-promise@^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@malept/cross-spawn-promise/-/cross-spawn-promise-2.0.0.tgz#d0772de1aa680a0bfb9ba2f32b4c828c7857cb9d" - integrity sha512-1DpKU0Z5ThltBwjNySMC14g0CkbyhCaz9FkhxqNsZI6uAPJXFS8cMXlBKo26FJ8ZuW6S9GCMcR9IO5k2X5/9Fg== - dependencies: - cross-spawn "^7.0.1" - "@malept/flatpak-bundler@^0.4.0": version "0.4.0" - resolved "https://registry.yarnpkg.com/@malept/flatpak-bundler/-/flatpak-bundler-0.4.0.tgz#e8a32c30a95d20c2b1bb635cc580981a06389858" + resolved "https://registry.npmmirror.com/@malept/flatpak-bundler/-/flatpak-bundler-0.4.0.tgz#e8a32c30a95d20c2b1bb635cc580981a06389858" integrity sha512-9QOtNffcOF/c1seMCDnjckb3R9WHcG34tky+FHpNKKCW0wc/scYLwMtO+ptyGUfMW0/b/n4qRiALlaFHc9Oj7Q== dependencies: debug "^4.1.1" @@ -1438,16 +269,14 @@ lodash "^4.17.15" tmp-promise "^3.0.2" -"@node-ipc/js-queue@2.0.3": - version "2.0.3" - resolved "https://registry.yarnpkg.com/@node-ipc/js-queue/-/js-queue-2.0.3.tgz#ac7fe33d766fa53e233ef8fedaf3443a01c5a4cd" - integrity sha512-fL1wpr8hhD5gT2dA1qifeVaoDFlQR5es8tFuKqjHX+kdOtdNHnxkVZbtIrR2rxnMFvehkjaZRNV2H/gPXlb0hw== - dependencies: - easy-stack "1.0.1" +"@napi-rs/cli@^2.16.3": + version "2.16.3" + resolved "https://registry.npmmirror.com/@napi-rs/cli/-/cli-2.16.3.tgz#6943d0614bbb4900a97b18ae074f735864f78c4b" + integrity sha512-3mLNPlbbOhpbIUKicLrJtIearlHXUuXL3UeueYyRRplpVMNkdn8xCyzY6PcYZi3JXR8bmCOiWgkVmLnrSL7DKw== "@nodelib/fs.scandir@2.1.5": version "2.1.5" - resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" + resolved "https://registry.npmmirror.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== dependencies: "@nodelib/fs.stat" "2.0.5" @@ -1455,134 +284,37 @@ "@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": version "2.0.5" - resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" + resolved "https://registry.npmmirror.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== "@nodelib/fs.walk@^1.2.3": version "1.2.8" - resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" + resolved "https://registry.npmmirror.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== dependencies: "@nodelib/fs.scandir" "2.1.5" fastq "^1.6.0" -"@npmcli/fs@^2.1.0": - version "2.1.2" - resolved "https://registry.yarnpkg.com/@npmcli/fs/-/fs-2.1.2.tgz#a9e2541a4a2fec2e69c29b35e6060973da79b865" - integrity sha512-yOJKRvohFOaLqipNtwYB9WugyZKhC/DZC4VYPmpaCzDBrA8YpK3qHZ8/HGscMnE4GqbkLNuVcCnxkeQEdGt6LQ== - dependencies: - "@gar/promisify" "^1.1.3" - semver "^7.3.5" - -"@npmcli/move-file@^2.0.0": - version "2.0.1" - resolved "https://registry.yarnpkg.com/@npmcli/move-file/-/move-file-2.0.1.tgz#26f6bdc379d87f75e55739bab89db525b06100e4" - integrity sha512-mJd2Z5TjYWq/ttPLLGqArdtnC74J6bOzg4rMDnN+p1xTacZ2yPRCk2y0oSWQtygLR9YVQXgOcONrwtnk3JupxQ== - dependencies: - mkdirp "^1.0.4" - rimraf "^3.0.2" - -"@polka/url@^1.0.0-next.20": - version "1.0.0-next.21" - resolved "https://registry.yarnpkg.com/@polka/url/-/url-1.0.0-next.21.tgz#5de5a2385a35309427f6011992b544514d559aa1" - integrity sha512-a5Sab1C4/icpTZVzZc5Ghpz88yQtGOyNqYXcZgOssB2uuAr+wF/MvN6bgtW32q7HHrvBki+BsZ0OuNv6EV3K9g== - -"@sideway/address@^4.1.3": - version "4.1.4" - resolved "https://registry.yarnpkg.com/@sideway/address/-/address-4.1.4.tgz#03dccebc6ea47fdc226f7d3d1ad512955d4783f0" - integrity sha512-7vwq+rOHVWjyXxVlR76Agnvhy8I9rpzjosTESvmhNeXOXdZZB15Fl+TI9x1SiHZH5Jv2wTGduSxFDIaq0m3DUw== - dependencies: - "@hapi/hoek" "^9.0.0" - -"@sideway/formula@^3.0.0": - version "3.0.0" - resolved "https://registry.yarnpkg.com/@sideway/formula/-/formula-3.0.0.tgz#fe158aee32e6bd5de85044be615bc08478a0a13c" - integrity sha512-vHe7wZ4NOXVfkoRb8T5otiENVlT7a3IAiw7H5M2+GO+9CDgcVUUsX1zalAztCmwyOr2RUTGJdgB+ZvSVqmdHmg== - -"@sideway/pinpoint@^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/@sideway/pinpoint/-/pinpoint-2.0.0.tgz#cff8ffadc372ad29fd3f78277aeb29e632cc70df" - integrity sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ== - -"@sindresorhus/is@^0.14.0": - version "0.14.0" - resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-0.14.0.tgz#9fb3a3cf3132328151f353de4632e01e52102bea" - integrity sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ== - "@sindresorhus/is@^4.0.0": version "4.6.0" - resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-4.6.0.tgz#3c7c9c46e678feefe7a2e5bb609d3dbd665ffb3f" + resolved "https://registry.npmmirror.com/@sindresorhus/is/-/is-4.6.0.tgz#3c7c9c46e678feefe7a2e5bb609d3dbd665ffb3f" integrity sha512-t09vSN3MdfsyCHoFcTRCH/iUtG7OJ0CsjzB8cjAmKc/va/kIgeDI/TxsigdncE/4be734m0cvIYwNaV4i2XqAw== -"@soda/friendly-errors-webpack-plugin@^1.8.0", "@soda/friendly-errors-webpack-plugin@^1.8.1": - version "1.8.1" - resolved "https://registry.yarnpkg.com/@soda/friendly-errors-webpack-plugin/-/friendly-errors-webpack-plugin-1.8.1.tgz#4d4fbb1108993aaa362116247c3d18188a2c6c85" - integrity sha512-h2ooWqP8XuFqTXT+NyAFbrArzfQA7R6HTezADrvD9Re8fxMLTPPniLdqVTdDaO0eIoLaAwKT+d6w+5GeTk7Vbg== - dependencies: - chalk "^3.0.0" - error-stack-parser "^2.0.6" - string-width "^4.2.3" - strip-ansi "^6.0.1" - -"@soda/get-current-script@^1.0.2": - version "1.0.2" - resolved "https://registry.yarnpkg.com/@soda/get-current-script/-/get-current-script-1.0.2.tgz#a53515db25d8038374381b73af20bb4f2e508d87" - integrity sha512-T7VNNlYVM1SgQ+VsMYhnDkcGmWhQdL0bDyGm5TlQ3GBXnJscEClUUOKduWTmm2zCnvNLC1hc3JpuXjs/nFOc5w== - -"@szmarczak/http-timer@^1.1.2": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-1.1.2.tgz#b1665e2c461a2cd92f4c1bbf50d5454de0d4b421" - integrity sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA== - dependencies: - defer-to-connect "^1.0.1" - "@szmarczak/http-timer@^4.0.5": version "4.0.6" - resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-4.0.6.tgz#b4a914bb62e7c272d4e5989fe4440f812ab1d807" + resolved "https://registry.npmmirror.com/@szmarczak/http-timer/-/http-timer-4.0.6.tgz#b4a914bb62e7c272d4e5989fe4440f812ab1d807" integrity sha512-4BAffykYOgO+5nzBWYwE3W90sBgLJoUPRWWcL8wlyiM8IB8ipJz3UMJ9KXQd1RKQXpKp8Tutn80HZtWsu2u76w== dependencies: defer-to-connect "^2.0.0" -"@tailwindcss/forms@^0.5.3": - version "0.5.3" - resolved "https://registry.yarnpkg.com/@tailwindcss/forms/-/forms-0.5.3.tgz#e4d7989686cbcaf416c53f1523df5225332a86e7" - integrity sha512-y5mb86JUoiUgBjY/o6FJSFZSEttfb3Q5gllE4xoKjAAD+vBrnIhE4dViwUuow3va8mpH4s9jyUbUbrRGoRdc2Q== - dependencies: - mini-svg-data-uri "^1.2.3" - -"@tokenizer/token@^0.3.0": - version "0.3.0" - resolved "https://registry.yarnpkg.com/@tokenizer/token/-/token-0.3.0.tgz#fe98a93fe789247e998c75e74e9c7c63217aa276" - integrity sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A== - "@tootallnate/once@2": version "2.0.0" - resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-2.0.0.tgz#f544a148d3ab35801c1f633a7441fd87c2e484bf" + resolved "https://registry.npmmirror.com/@tootallnate/once/-/once-2.0.0.tgz#f544a148d3ab35801c1f633a7441fd87c2e484bf" integrity sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A== -"@trysound/sax@0.2.0": - version "0.2.0" - resolved "https://registry.yarnpkg.com/@trysound/sax/-/sax-0.2.0.tgz#cccaab758af56761eb7bf37af6f03f326dd798ad" - integrity sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA== - -"@types/body-parser@*": - version "1.19.2" - resolved "https://registry.yarnpkg.com/@types/body-parser/-/body-parser-1.19.2.tgz#aea2059e28b7658639081347ac4fab3de166e6f0" - integrity sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g== - dependencies: - "@types/connect" "*" - "@types/node" "*" - -"@types/bonjour@^3.5.9": - version "3.5.10" - resolved "https://registry.yarnpkg.com/@types/bonjour/-/bonjour-3.5.10.tgz#0f6aadfe00ea414edc86f5d106357cda9701e275" - integrity sha512-p7ienRMiS41Nu2/igbJxxLDWrSZ0WxM8UQgCeO9KhoVF7cOVFkrKsiDr1EsJIla8vV3oEEjGcz11jc5yimhzZw== - dependencies: - "@types/node" "*" - "@types/cacheable-request@^6.0.1": version "6.0.3" - resolved "https://registry.yarnpkg.com/@types/cacheable-request/-/cacheable-request-6.0.3.tgz#a430b3260466ca7b5ca5bfd735693b36e7a9d183" + resolved "https://registry.npmmirror.com/@types/cacheable-request/-/cacheable-request-6.0.3.tgz#a430b3260466ca7b5ca5bfd735693b36e7a9d183" integrity sha512-IQ3EbTzGxIigb1I3qPZc1rWJnH0BmSKv5QYTalEwweFvyBDLSAe24zP0le/hyi7ecGfZVlIVAg4BZqb8WBwKqw== dependencies: "@types/http-cache-semantics" "*" @@ -1590,836 +322,341 @@ "@types/node" "*" "@types/responselike" "^1.0.0" -"@types/connect-history-api-fallback@^1.3.5": - version "1.3.5" - resolved "https://registry.yarnpkg.com/@types/connect-history-api-fallback/-/connect-history-api-fallback-1.3.5.tgz#d1f7a8a09d0ed5a57aee5ae9c18ab9b803205dae" - integrity sha512-h8QJa8xSb1WD4fpKBDcATDNGXghFj6/3GRWG6dhmRcu0RX1Ubasur2Uvx5aeEwlf0MwblEC2bMzzMQntxnw/Cw== - dependencies: - "@types/express-serve-static-core" "*" - "@types/node" "*" - -"@types/connect@*": - version "3.4.35" - resolved "https://registry.yarnpkg.com/@types/connect/-/connect-3.4.35.tgz#5fcf6ae445e4021d1fc2219a4873cc73a3bb2ad1" - integrity sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ== - dependencies: - "@types/node" "*" +"@types/caseless@*": + version "0.12.4" + resolved "https://registry.npmmirror.com/@types/caseless/-/caseless-0.12.4.tgz#1326429a519cc077028150343fd502b04686bd6f" + integrity sha512-2in/lrHRNmDvHPgyormtEralhPcN3An1gLjJzj2Bw145VBxkQ75JEXW6CTdMAwShiHQcYsl2d10IjQSdJSJz4g== "@types/debug@^4.1.6": - version "4.1.7" - resolved "https://registry.yarnpkg.com/@types/debug/-/debug-4.1.7.tgz#7cc0ea761509124709b8b2d1090d8f6c17aadb82" - integrity sha512-9AonUzyTjXXhEOa0DnqpzZi6VHlqKMswga9EXjpXnnqxwLtdvPPtlO8evrI5D9S6asFRCQ6v+wpiUKbw+vKqyg== + version "4.1.10" + resolved "https://registry.npmmirror.com/@types/debug/-/debug-4.1.10.tgz#f23148a6eb771a34c466a4fc28379d8101e84494" + integrity sha512-tOSCru6s732pofZ+sMv9o4o3Zc+Sa8l3bxd/tweTQudFn06vAzb13ZX46Zi6m6EJ+RUbRTHvgQJ1gBtSgkaUYA== dependencies: "@types/ms" "*" -"@types/eslint-scope@^3.7.3": - version "3.7.4" - resolved "https://registry.yarnpkg.com/@types/eslint-scope/-/eslint-scope-3.7.4.tgz#37fc1223f0786c39627068a12e94d6e6fc61de16" - integrity sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA== +"@types/dompurify@^3.0.3": + version "3.0.4" + resolved "https://registry.npmmirror.com/@types/dompurify/-/dompurify-3.0.4.tgz#8a6369dec2dd0c397d01751adf3364be035b40d8" + integrity sha512-1Jk8S/IRzNSbwQRbuGuLFHviwxQ8pX81ZEW3INY9432Cwb4VedkBYan8gSIXVLOLHBtimOmUTEYphjRVmo+30g== dependencies: - "@types/eslint" "*" - "@types/estree" "*" - -"@types/eslint@*": - version "8.4.6" - resolved "https://registry.yarnpkg.com/@types/eslint/-/eslint-8.4.6.tgz#7976f054c1bccfcf514bff0564c0c41df5c08207" - integrity sha512-/fqTbjxyFUaYNO7VcW5g+4npmqVACz1bB7RTHYuLj+PRjw9hrCwrUXVQFpChUS0JsyEFvMZ7U/PfmvWgxJhI9g== - dependencies: - "@types/estree" "*" - "@types/json-schema" "*" - -"@types/estree@*": - version "1.0.0" - resolved "https://registry.yarnpkg.com/@types/estree/-/estree-1.0.0.tgz#5fb2e536c1ae9bf35366eed879e827fa59ca41c2" - integrity sha512-WulqXMDUTYAXCjZnk6JtIHPigp55cVtDgDrO2gHRwhyJto21+1zbVCtOYB2L1F9w4qCQ0rOGWBnBe0FNTiEJIQ== - -"@types/estree@^0.0.51": - version "0.0.51" - resolved "https://registry.yarnpkg.com/@types/estree/-/estree-0.0.51.tgz#cfd70924a25a3fd32b218e5e420e6897e1ac4f40" - integrity sha512-CuPgU6f3eT/XgKKPqKd/gLZV1Xmvf1a2R5POBOGQa6uv82xpls89HU5zKeVoyR8XzHd1RGNOlQlvUe3CFkjWNQ== - -"@types/express-serve-static-core@*", "@types/express-serve-static-core@^4.17.18": - version "4.17.31" - resolved "https://registry.yarnpkg.com/@types/express-serve-static-core/-/express-serve-static-core-4.17.31.tgz#a1139efeab4e7323834bb0226e62ac019f474b2f" - integrity sha512-DxMhY+NAsTwMMFHBTtJFNp5qiHKJ7TeqOo23zVEM9alT1Ml27Q3xcTH0xwxn7Q0BbMcVEJOs/7aQtUWupUQN3Q== - dependencies: - "@types/node" "*" - "@types/qs" "*" - "@types/range-parser" "*" - -"@types/express@*", "@types/express@^4.17.13": - version "4.17.14" - resolved "https://registry.yarnpkg.com/@types/express/-/express-4.17.14.tgz#143ea0557249bc1b3b54f15db4c81c3d4eb3569c" - integrity sha512-TEbt+vaPFQ+xpxFLFssxUDXj5cWCxZJjIcB7Yg0k0GMHGtgtQgpvx/MUQUeAkNbA9AAGrwkAsoeItdTgS7FMyg== - dependencies: - "@types/body-parser" "*" - "@types/express-serve-static-core" "^4.17.18" - "@types/qs" "*" - "@types/serve-static" "*" + "@types/trusted-types" "*" "@types/fs-extra@9.0.13", "@types/fs-extra@^9.0.11": version "9.0.13" - resolved "https://registry.yarnpkg.com/@types/fs-extra/-/fs-extra-9.0.13.tgz#7594fbae04fe7f1918ce8b3d213f74ff44ac1f45" + resolved "https://registry.npmmirror.com/@types/fs-extra/-/fs-extra-9.0.13.tgz#7594fbae04fe7f1918ce8b3d213f74ff44ac1f45" integrity sha512-nEnwB++1u5lVDM2UI4c1+5R+FYaKfaAzS4OococimjVm3nQw3TuzH5UNsocrcTBbhnerblyHj4A49qXbIiZdpA== dependencies: "@types/node" "*" -"@types/glob@^7.1.1": - version "7.2.0" - resolved "https://registry.yarnpkg.com/@types/glob/-/glob-7.2.0.tgz#bc1b5bf3aa92f25bd5dd39f35c57361bdce5b2eb" - integrity sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA== - dependencies: - "@types/minimatch" "*" - "@types/node" "*" - -"@types/html-minifier-terser@^6.0.0": - version "6.1.0" - resolved "https://registry.yarnpkg.com/@types/html-minifier-terser/-/html-minifier-terser-6.1.0.tgz#4fc33a00c1d0c16987b1a20cf92d20614c55ac35" - integrity sha512-oh/6byDPnL1zeNXFrDXFLyZjkr1MsBG667IM792caf1L2UPOOMf65NFzjUH/ltyfwjAGfs1rsX1eftK0jC/KIg== - "@types/http-cache-semantics@*": - version "4.0.1" - resolved "https://registry.yarnpkg.com/@types/http-cache-semantics/-/http-cache-semantics-4.0.1.tgz#0ea7b61496902b95890dc4c3a116b60cb8dae812" - integrity sha512-SZs7ekbP8CN0txVG2xVRH6EgKmEm31BOxA07vkFaETzZz1xh+cbt8BcI0slpymvwhx5dlFnQG2rTlPVQn+iRPQ== + version "4.0.3" + resolved "https://registry.npmmirror.com/@types/http-cache-semantics/-/http-cache-semantics-4.0.3.tgz#a3ff232bf7d5c55f38e4e45693eda2ebb545794d" + integrity sha512-V46MYLFp08Wf2mmaBhvgjStM3tPa+2GAdy/iqoX+noX1//zje2x4XmrIU0cAwyClATsTmahbtoQ2EwP7I5WSiA== -"@types/http-proxy@^1.17.8": - version "1.17.9" - resolved "https://registry.yarnpkg.com/@types/http-proxy/-/http-proxy-1.17.9.tgz#7f0e7931343761efde1e2bf48c40f02f3f75705a" - integrity sha512-QsbSjA/fSk7xB+UXlCT3wHBy5ai9wOcNDWwZAtud+jXhwOM3l+EYZh8Lng4+/6n8uar0J7xILzqftJdJ/Wdfkw== - dependencies: - "@types/node" "*" - -"@types/json-schema@*", "@types/json-schema@^7.0.5", "@types/json-schema@^7.0.8", "@types/json-schema@^7.0.9": - version "7.0.11" - resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.11.tgz#d421b6c527a3037f7c84433fd2c4229e016863d3" - integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ== +"@types/katex@^0.16.2": + version "0.16.5" + resolved "https://registry.npmmirror.com/@types/katex/-/katex-0.16.5.tgz#76adc073ce58e860cb8c34b5673e1aea9a0172b0" + integrity sha512-DD2Y3xMlTQvAnN6d8803xdgnOeYZ+HwMglb7/9YCf49J9RkJL53azf9qKa40MkEYhqVwxZ1GS2+VlShnz4Z1Bw== "@types/keyv@^3.1.4": version "3.1.4" - resolved "https://registry.yarnpkg.com/@types/keyv/-/keyv-3.1.4.tgz#3ccdb1c6751b0c7e52300bcdacd5bcbf8faa75b6" + resolved "https://registry.npmmirror.com/@types/keyv/-/keyv-3.1.4.tgz#3ccdb1c6751b0c7e52300bcdacd5bcbf8faa75b6" integrity sha512-BQ5aZNSCpj7D6K2ksrRCTmKRLEpnPvWDiLPfoGyhZ++8YtiK9d/3DBKPJgry359X/P1PfruyYwvnvwFjuEiEIg== dependencies: "@types/node" "*" -"@types/mime@*": - version "3.0.1" - resolved "https://registry.yarnpkg.com/@types/mime/-/mime-3.0.1.tgz#5f8f2bca0a5863cb69bc0b0acd88c96cb1d4ae10" - integrity sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA== +"@types/lodash-es@^4.17.6", "@types/lodash-es@^4.17.9": + version "4.17.10" + resolved "https://registry.npmmirror.com/@types/lodash-es/-/lodash-es-4.17.10.tgz#1b36a76ca9eda20c0263e19bbe1a3adb1b317707" + integrity sha512-YJP+w/2khSBwbUSFdGsSqmDvmnN3cCKoPOL7Zjle6s30ZtemkkqhjVfFqGwPN7ASil5VyjE2GtyU/yqYY6mC0A== + dependencies: + "@types/lodash" "*" -"@types/minimatch@*": - version "5.1.2" - resolved "https://registry.yarnpkg.com/@types/minimatch/-/minimatch-5.1.2.tgz#07508b45797cb81ec3f273011b054cd0755eddca" - integrity sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA== +"@types/lodash@*", "@types/lodash@^4.14.198": + version "4.14.200" + resolved "https://registry.npmmirror.com/@types/lodash/-/lodash-4.14.200.tgz#435b6035c7eba9cdf1e039af8212c9e9281e7149" + integrity sha512-YI/M/4HRImtNf3pJgbF+W6FrXovqj+T+/HpENLTooK9PnkacBsDpeP3IpHab40CClUfhNmdM2WTNP2sa2dni5Q== -"@types/minimist@^1.2.0": - version "1.2.2" - resolved "https://registry.yarnpkg.com/@types/minimist/-/minimist-1.2.2.tgz#ee771e2ba4b3dc5b372935d549fd9617bf345b8c" - integrity sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ== +"@types/mime@^3.0.2": + version "3.0.3" + resolved "https://registry.npmmirror.com/@types/mime/-/mime-3.0.3.tgz#886674659ce55fe7c6c06ec5ca7c0eb276a08f91" + integrity sha512-i8MBln35l856k5iOhKk2XJ4SeAWg75mLIpZB4v6imOagKL6twsukBZGDMNhdOVk7yRFTMPpfILocMos59Q1otQ== "@types/ms@*": - version "0.7.31" - resolved "https://registry.yarnpkg.com/@types/ms/-/ms-0.7.31.tgz#31b7ca6407128a3d2bbc27fe2d21b345397f6197" - integrity sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA== + version "0.7.33" + resolved "https://registry.npmmirror.com/@types/ms/-/ms-0.7.33.tgz#80bf1da64b15f21fd8c1dc387c31929317d99ee9" + integrity sha512-AuHIyzR5Hea7ij0P9q7vx7xu4z0C28ucwjAZC0ja7JhINyCnOw8/DnvAPQQ9TfOlCtZAmCERKQX9+o1mgQhuOQ== "@types/node@*": - version "18.7.18" - resolved "https://registry.yarnpkg.com/@types/node/-/node-18.7.18.tgz#633184f55c322e4fb08612307c274ee6d5ed3154" - integrity sha512-m+6nTEOadJZuTPkKR/SYK3A2d7FZrgElol9UP1Kae90VVU4a6mxnPuLiIW1m4Cq4gZ/nWb9GrdVXJCoCazDAbg== + version "20.8.9" + resolved "https://registry.npmmirror.com/@types/node/-/node-20.8.9.tgz#646390b4fab269abce59c308fc286dcd818a2b08" + integrity sha512-UzykFsT3FhHb1h7yD4CA4YhBHq545JC0YnEz41xkipN88eKQtL6rSgocL5tbAP6Ola9Izm/Aw4Ora8He4x0BHg== + dependencies: + undici-types "~5.26.4" -"@types/node@16.9.1": - version "16.9.1" - resolved "https://registry.yarnpkg.com/@types/node/-/node-16.9.1.tgz#0611b37db4246c937feef529ddcc018cf8e35708" - integrity sha512-QpLcX9ZSsq3YYUUnD3nFDY8H7wctAhQj/TFKL8Ya8v5fMm3CFXxo8zStsLAl780ltoYoo1WvKUVGBQK+1ifr7g== +"@types/node@^18.11.18": + version "18.18.7" + resolved "https://registry.npmmirror.com/@types/node/-/node-18.18.7.tgz#bb3a7068dc4ba421b6968f2a259298b3a4e129e8" + integrity sha512-bw+lEsxis6eqJYW8Ql6+yTqkE6RuFtsQPSe5JxXbqYRFQEER5aJA9a5UH9igqDWm3X4iLHIKOHlnAXLM4mi7uQ== + dependencies: + undici-types "~5.26.4" -"@types/node@^16.11.26": - version "16.11.59" - resolved "https://registry.yarnpkg.com/@types/node/-/node-16.11.59.tgz#823f238b9063ccc3b3b7f13186f143a57926c4f6" - integrity sha512-6u+36Dj3aDzhfBVUf/mfmc92OEdzQ2kx2jcXGdigfl70E/neV21ZHE6UCz4MDzTRcVqGAM27fk+DLXvyDsn3Jw== - -"@types/normalize-package-data@^2.4.0": - version "2.4.1" - resolved "https://registry.yarnpkg.com/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz#d3357479a0fdfdd5907fe67e17e0a85c906e1301" - integrity sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw== - -"@types/parse-json@^4.0.0": - version "4.0.0" - resolved "https://registry.yarnpkg.com/@types/parse-json/-/parse-json-4.0.0.tgz#2f8bb441434d163b35fb8ffdccd7138927ffb8c0" - integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA== +"@types/node@~14.14.31": + version "14.14.45" + resolved "https://registry.npmmirror.com/@types/node/-/node-14.14.45.tgz#ec2dfb5566ff814d061aef7e141575aedba245cf" + integrity sha512-DssMqTV9UnnoxDWu959sDLZzfvqCF0qDNRjaWeYSui9xkFe61kKo4l1TWNTQONpuXEm+gLMRvdlzvNHBamzmEw== "@types/plist@^3.0.1": - version "3.0.2" - resolved "https://registry.yarnpkg.com/@types/plist/-/plist-3.0.2.tgz#61b3727bba0f5c462fe333542534a0c3e19ccb01" - integrity sha512-ULqvZNGMv0zRFvqn8/4LSPtnmN4MfhlPNtJCTpKuIIxGVGZ2rYWzFXrvEBoh9CVyqSE7D6YFRJ1hydLHI6kbWw== + version "3.0.4" + resolved "https://registry.npmmirror.com/@types/plist/-/plist-3.0.4.tgz#af0c5ffaf30d2302460adc17861021323c1410f9" + integrity sha512-pTa9xUFQFM9WJGSWHajYNljD+DbVylE1q9IweK1LBhUYJdJ28YNU8j3KZ4Q1Qw+cSl4+QLLLOVmqNjhhvVO8fA== dependencies: "@types/node" "*" xmlbuilder ">=11.0.1" -"@types/qs@*": - version "6.9.7" - resolved "https://registry.yarnpkg.com/@types/qs/-/qs-6.9.7.tgz#63bb7d067db107cc1e457c303bc25d511febf6cb" - integrity sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw== - -"@types/range-parser@*": - version "1.2.4" - resolved "https://registry.yarnpkg.com/@types/range-parser/-/range-parser-1.2.4.tgz#cd667bcfdd025213aafb7ca5915a932590acdcdc" - integrity sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw== +"@types/request@^2.48.10": + version "2.48.11" + resolved "https://registry.npmmirror.com/@types/request/-/request-2.48.11.tgz#04b597ea308418422f7901c9a52b24967a2c4ed2" + integrity sha512-HuihY1+Vss5RS9ZHzRyTGIzwPTdrJBkCm/mAeLRYrOQu/MGqyezKXWOK1VhCnR+SDbp9G2mRUP+OVEqCrzpcfA== + dependencies: + "@types/caseless" "*" + "@types/node" "*" + "@types/tough-cookie" "*" + form-data "^2.5.0" "@types/responselike@^1.0.0": - version "1.0.0" - resolved "https://registry.yarnpkg.com/@types/responselike/-/responselike-1.0.0.tgz#251f4fe7d154d2bad125abe1b429b23afd262e29" - integrity sha512-85Y2BjiufFzaMIlvJDvTTB8Fxl2xfLo4HgmHzVBz08w4wDePCTjYw66PdrolO0kzli3yam/YCgRufyo1DdQVTA== + version "1.0.2" + resolved "https://registry.npmmirror.com/@types/responselike/-/responselike-1.0.2.tgz#8de1b0477fd7c12df77e50832fa51701a8414bd6" + integrity sha512-/4YQT5Kp6HxUDb4yhRkm0bJ7TbjvTddqX7PZ5hz6qV3pxSo72f/6YPRo+Mu2DU307tm9IioO69l7uAwn5XNcFA== dependencies: "@types/node" "*" -"@types/retry@0.12.0": - version "0.12.0" - resolved "https://registry.yarnpkg.com/@types/retry/-/retry-0.12.0.tgz#2b35eccfcee7d38cd72ad99232fbd58bffb3c84d" - integrity sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA== +"@types/retry@^0.12.3": + version "0.12.4" + resolved "https://registry.npmmirror.com/@types/retry/-/retry-0.12.4.tgz#67d65e2df7a82b0b0ec0ba7fb2711c50c2adf1f4" + integrity sha512-l1YzFLj8Y6OhLdt7HKXlz56DoEmksB7qR8KVk+MpFsS4duwnoszLgDlLxJB0vgSqtg/rAS5gmYg5Bjw2sMJ8Ew== -"@types/serve-index@^1.9.1": - version "1.9.1" - resolved "https://registry.yarnpkg.com/@types/serve-index/-/serve-index-1.9.1.tgz#1b5e85370a192c01ec6cec4735cf2917337a6278" - integrity sha512-d/Hs3nWDxNL2xAczmOVZNj92YZCS6RGxfBPjKzuu/XirCgXdpKEb88dYNbrYGint6IVWLNP+yonwVAuRC0T2Dg== - dependencies: - "@types/express" "*" +"@types/sortablejs@^1.15.3": + version "1.15.4" + resolved "https://registry.npmmirror.com/@types/sortablejs/-/sortablejs-1.15.4.tgz#9ccaa84a64205defcbb78df63176a3722121ccd7" + integrity sha512-7oL7CcPSfoyoNx3Ba1+79ykJzpEKVhHUyfAiN5eT/FoeDXOR3eBDLXf9ndDNuxaExmjpI+zVi2dMMuaoXUOzNA== -"@types/serve-static@*", "@types/serve-static@^1.13.10": - version "1.15.0" - resolved "https://registry.yarnpkg.com/@types/serve-static/-/serve-static-1.15.0.tgz#c7930ff61afb334e121a9da780aac0d9b8f34155" - integrity sha512-z5xyF6uh8CbjAu9760KDKsH2FcDxZ2tFCsA4HIMWE6IkiYMXfVoa+4f9KX+FN0ZLsaMw1WNG2ETLA6N+/YA+cg== - dependencies: - "@types/mime" "*" - "@types/node" "*" +"@types/tough-cookie@*": + version "4.0.4" + resolved "https://registry.npmmirror.com/@types/tough-cookie/-/tough-cookie-4.0.4.tgz#cf2f0c7c51b985b6afecea73eb2cd65421ecb717" + integrity sha512-95Sfz4nvMAb0Nl9DTxN3j64adfwfbBPEYq14VN7zT5J5O2M9V6iZMIIQU1U+pJyl9agHYHNCqhCXgyEtIRRa5A== -"@types/sockjs@^0.3.33": - version "0.3.33" - resolved "https://registry.yarnpkg.com/@types/sockjs/-/sockjs-0.3.33.tgz#570d3a0b99ac995360e3136fd6045113b1bd236f" - integrity sha512-f0KEEe05NvUnat+boPTZ0dgaLZ4SfSouXUgv5noUiefG2ajgKjmETo9ZJyuqsl7dfl2aHlLJUiki6B4ZYldiiw== - dependencies: - "@types/node" "*" +"@types/trusted-types@*": + version "2.0.5" + resolved "https://registry.npmmirror.com/@types/trusted-types/-/trusted-types-2.0.5.tgz#5cac7e7df3275bb95f79594f192d97da3b4fd5fe" + integrity sha512-I3pkr8j/6tmQtKV/ZzHtuaqYSQvyjGRKH4go60Rr0IDLlFxuRT5V32uvB1mecM5G1EVAUyF/4r4QZ1GHgz+mxA== + +"@types/urijs@^1.19.22": + version "1.19.22" + resolved "https://registry.npmmirror.com/@types/urijs/-/urijs-1.19.22.tgz#188c573007001de3be3983af5437727bf3042dd6" + integrity sha512-qnYBwfN7O/+i6E1Kr8JaCKsrCLpRCiQ1XxkSxNIYuJ/5Aagt0+HlMX78DJMUrNzDULMz0eu2gcprlxJaDtACOw== "@types/verror@^1.10.3": - version "1.10.6" - resolved "https://registry.yarnpkg.com/@types/verror/-/verror-1.10.6.tgz#3e600c62d210c5826460858f84bcbb65805460bb" - integrity sha512-NNm+gdePAX1VGvPcGZCDKQZKYSiAWigKhKaz5KF94hG6f2s8de9Ow5+7AbXoeKxL8gavZfk4UquSAygOF2duEQ== + version "1.10.8" + resolved "https://registry.npmmirror.com/@types/verror/-/verror-1.10.8.tgz#5324a03e0885ffe6fef0192900aec317abbb2997" + integrity sha512-YhUhnxRYs/NiVUbIs3F/EzviDP/NZCEAE2Mx5DUqLdldUmphOhFCVh7Kc+7zlYEExM0P8dzfbJi0yRlNb2Bw5g== -"@types/ws@^8.5.1": - version "8.5.3" - resolved "https://registry.yarnpkg.com/@types/ws/-/ws-8.5.3.tgz#7d25a1ffbecd3c4f2d35068d0b283c037003274d" - integrity sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w== +"@types/xml2js@^0.4.12": + version "0.4.13" + resolved "https://registry.npmmirror.com/@types/xml2js/-/xml2js-0.4.13.tgz#219134d550c21e2f1d7b0e2fbb9174144c6053ed" + integrity sha512-nuT42GzgoUa4zZgBoF4d+Zqc12/FlVxXCT4xU6j3RfqTFVQWrUAClI/0sNJ5ImM9Wv6KB42KMG2xsVMn4cSBzA== dependencies: "@types/node" "*" -"@types/yargs-parser@*": - version "21.0.0" - resolved "https://registry.yarnpkg.com/@types/yargs-parser/-/yargs-parser-21.0.0.tgz#0c60e537fa790f5f9472ed2776c2b71ec117351b" - integrity sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA== - -"@types/yargs@^17.0.1": - version "17.0.12" - resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-17.0.12.tgz#0745ff3e4872b4ace98616d4b7e37ccbd75f9526" - integrity sha512-Nz4MPhecOFArtm81gFQvQqdV7XYCrWKx5uUt6GNHredFHn1i2mtWqXTON7EPXMtNi1qjtjEM/VCHDhcHsAMLXQ== - dependencies: - "@types/yargs-parser" "*" - "@types/yauzl@^2.9.1": - version "2.10.0" - resolved "https://registry.yarnpkg.com/@types/yauzl/-/yauzl-2.10.0.tgz#b3248295276cf8c6f153ebe6a9aba0c988cb2599" - integrity sha512-Cn6WYCm0tXv8p6k+A8PvbDG763EDpBoTzHdA+Q/MF6H3sapGjCm9NzoaJncJS9tUKSuCoDs9XHxYYsQDgxR6kw== + version "2.10.2" + resolved "https://registry.npmmirror.com/@types/yauzl/-/yauzl-2.10.2.tgz#dab926ef9b41a898bc943f11bca6b0bad6d4b729" + integrity sha512-Km7XAtUIduROw7QPgvcft0lIupeG8a8rdKL8RiSyKvlE7dYY31fEn41HVuQsRFDuROA8tA4K2UVL+WdfFmErBA== dependencies: "@types/node" "*" -"@vue/babel-helper-vue-jsx-merge-props@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-helper-vue-jsx-merge-props/-/babel-helper-vue-jsx-merge-props-1.4.0.tgz#8d53a1e21347db8edbe54d339902583176de09f2" - integrity sha512-JkqXfCkUDp4PIlFdDQ0TdXoIejMtTHP67/pvxlgeY+u5k3LEdKuWZ3LK6xkxo52uDoABIVyRwqVkfLQJhk7VBA== +"@vicons/material@^0.12.0": + version "0.12.0" + resolved "https://registry.npmmirror.com/@vicons/material/-/material-0.12.0.tgz#068e72fa40bd7f780af5fc68011fb69010c8e0b5" + integrity sha512-chv1CYAl8P32P3Ycwgd5+vw/OFNc2mtkKdb1Rw4T5IJmKy6GVDsoUKV3N2l208HATn7CCQphZtuPDdsm7K2kmA== -"@vue/babel-helper-vue-transform-on@^1.0.2": - version "1.0.2" - resolved "https://registry.yarnpkg.com/@vue/babel-helper-vue-transform-on/-/babel-helper-vue-transform-on-1.0.2.tgz#9b9c691cd06fc855221a2475c3cc831d774bc7dc" - integrity sha512-hz4R8tS5jMn8lDq6iD+yWL6XNB699pGIVLk7WSJnn1dbpjaazsjZQkieJoRX6gW5zpYSCFqQ7jUquPNY65tQYA== - -"@vue/babel-plugin-jsx@^1.0.3": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@vue/babel-plugin-jsx/-/babel-plugin-jsx-1.1.1.tgz#0c5bac27880d23f89894cd036a37b55ef61ddfc1" - integrity sha512-j2uVfZjnB5+zkcbc/zsOc0fSNGCMMjaEXP52wdwdIfn0qjFfEYpYZBFKFg+HHnQeJCVrjOeO0YxgaL7DMrym9w== +"@vicons/utils@^0.1.4": + version "0.1.4" + resolved "https://registry.npmmirror.com/@vicons/utils/-/utils-0.1.4.tgz#accea9226ff0078ebd80d00dcb63ef5e74b210ff" + integrity sha512-OHI19qVNN6i+uPQ+Y3f2s0dUxwsYnOCcKBW7XOU4yXXO1aU3ZoKpblCc3+4N0qmgoJs5rWKRAaMisipqEXJwAg== dependencies: - "@babel/helper-module-imports" "^7.0.0" - "@babel/plugin-syntax-jsx" "^7.0.0" - "@babel/template" "^7.0.0" - "@babel/traverse" "^7.0.0" - "@babel/types" "^7.0.0" - "@vue/babel-helper-vue-transform-on" "^1.0.2" - camelcase "^6.0.0" - html-tags "^3.1.0" - svg-tags "^1.0.0" + "@xicons/utils" "^0.1.4" -"@vue/babel-plugin-transform-vue-jsx@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-plugin-transform-vue-jsx/-/babel-plugin-transform-vue-jsx-1.4.0.tgz#4d4b3d46a39ea62b7467dd6e26ce47f7ceafb2fe" - integrity sha512-Fmastxw4MMx0vlgLS4XBX0XiBbUFzoMGeVXuMV08wyOfXdikAFqBTuYPR0tlk+XskL19EzHc39SgjrPGY23JnA== +"@vitejs/plugin-vue@^4.4.0": + version "4.4.0" + resolved "https://registry.npmmirror.com/@vitejs/plugin-vue/-/plugin-vue-4.4.0.tgz#8ae96573236cdb12de6850a6d929b5537ec85390" + integrity sha512-xdguqb+VUwiRpSg+nsc2HtbAUSGak25DXYvpQQi4RVU1Xq1uworyoH/md9Rfd8zMmPR/pSghr309QNcftUVseg== + +"@volar/language-core@1.10.7", "@volar/language-core@~1.10.5": + version "1.10.7" + resolved "https://registry.npmmirror.com/@volar/language-core/-/language-core-1.10.7.tgz#9d555bf0a3ca652c525651baba5ecf8a55cf3471" + integrity sha512-6+WI7HGqWCsKJ/bms4V45WP7eDeoGxDtLjYPrHB7QkIWVkRLIeGPzzBoonZz9kERM+Kld3W89Y+IlICejVAKhA== dependencies: - "@babel/helper-module-imports" "^7.0.0" - "@babel/plugin-syntax-jsx" "^7.2.0" - "@vue/babel-helper-vue-jsx-merge-props" "^1.4.0" - html-tags "^2.0.0" - lodash.kebabcase "^4.1.1" - svg-tags "^1.0.0" + "@volar/source-map" "1.10.7" -"@vue/babel-preset-app@^5.0.8": - version "5.0.8" - resolved "https://registry.yarnpkg.com/@vue/babel-preset-app/-/babel-preset-app-5.0.8.tgz#ce38f76314f5265d62a89756ef264c21f1d351a1" - integrity sha512-yl+5qhpjd8e1G4cMXfORkkBlvtPCIgmRf3IYCWYDKIQ7m+PPa5iTm4feiNmCMD6yGqQWMhhK/7M3oWGL9boKwg== +"@volar/source-map@1.10.7", "@volar/source-map@~1.10.5": + version "1.10.7" + resolved "https://registry.npmmirror.com/@volar/source-map/-/source-map-1.10.7.tgz#f2b5c6b99f3fc91c10d4013eaeb083fbbf4b9e0d" + integrity sha512-anA254XO0lmmeu0p/kvgPOCkrVpqNIHWMvEkPX70PSk4ntg0iBzN/f0Kip6deXvibl6v14Q3Z8RihWrZwdZEEQ== dependencies: - "@babel/core" "^7.12.16" - "@babel/helper-compilation-targets" "^7.12.16" - "@babel/helper-module-imports" "^7.12.13" - "@babel/plugin-proposal-class-properties" "^7.12.13" - "@babel/plugin-proposal-decorators" "^7.12.13" - "@babel/plugin-syntax-dynamic-import" "^7.8.3" - "@babel/plugin-syntax-jsx" "^7.12.13" - "@babel/plugin-transform-runtime" "^7.12.15" - "@babel/preset-env" "^7.12.16" - "@babel/runtime" "^7.12.13" - "@vue/babel-plugin-jsx" "^1.0.3" - "@vue/babel-preset-jsx" "^1.1.2" - babel-plugin-dynamic-import-node "^2.3.3" - core-js "^3.8.3" - core-js-compat "^3.8.3" - semver "^7.3.4" + muggle-string "^0.3.1" -"@vue/babel-preset-jsx@^1.1.2": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-preset-jsx/-/babel-preset-jsx-1.4.0.tgz#f4914ba314235ab097bc4372ed67473c0780bfcc" - integrity sha512-QmfRpssBOPZWL5xw7fOuHNifCQcNQC1PrOo/4fu6xlhlKJJKSA3HqX92Nvgyx8fqHZTUGMPHmFA+IDqwXlqkSA== +"@volar/typescript@~1.10.5": + version "1.10.7" + resolved "https://registry.npmmirror.com/@volar/typescript/-/typescript-1.10.7.tgz#2ed47e3260d4161445099ba89c7471fbc51133b6" + integrity sha512-2hvA3vjXVUn1vOpsP/nWLnE5DUmY6YKQhvDRoZVfBrnWwIo0ySxdTUP4XieXGGgSk43xJaeU1zqQS/3Wfm7QgA== dependencies: - "@vue/babel-helper-vue-jsx-merge-props" "^1.4.0" - "@vue/babel-plugin-transform-vue-jsx" "^1.4.0" - "@vue/babel-sugar-composition-api-inject-h" "^1.4.0" - "@vue/babel-sugar-composition-api-render-instance" "^1.4.0" - "@vue/babel-sugar-functional-vue" "^1.4.0" - "@vue/babel-sugar-inject-h" "^1.4.0" - "@vue/babel-sugar-v-model" "^1.4.0" - "@vue/babel-sugar-v-on" "^1.4.0" + "@volar/language-core" "1.10.7" + path-browserify "^1.0.1" -"@vue/babel-sugar-composition-api-inject-h@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-sugar-composition-api-inject-h/-/babel-sugar-composition-api-inject-h-1.4.0.tgz#187e1389f8871d89ece743bb50aed713be9d6c85" - integrity sha512-VQq6zEddJHctnG4w3TfmlVp5FzDavUSut/DwR0xVoe/mJKXyMcsIibL42wPntozITEoY90aBV0/1d2KjxHU52g== +"@vue/compiler-core@3.3.7": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/compiler-core/-/compiler-core-3.3.7.tgz#865a5734c971686d9737d85a0c5a08de045b6162" + integrity sha512-pACdY6YnTNVLXsB86YD8OF9ihwpolzhhtdLVHhBL6do/ykr6kKXNYABRtNMGrsQXpEXXyAdwvWWkuTbs4MFtPQ== dependencies: - "@babel/plugin-syntax-jsx" "^7.2.0" - -"@vue/babel-sugar-composition-api-render-instance@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-sugar-composition-api-render-instance/-/babel-sugar-composition-api-render-instance-1.4.0.tgz#2c1607ae6dffdab47e785bc01fa45ba756e992c1" - integrity sha512-6ZDAzcxvy7VcnCjNdHJ59mwK02ZFuP5CnucloidqlZwVQv5CQLijc3lGpR7MD3TWFi78J7+a8J56YxbCtHgT9Q== - dependencies: - "@babel/plugin-syntax-jsx" "^7.2.0" - -"@vue/babel-sugar-functional-vue@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-sugar-functional-vue/-/babel-sugar-functional-vue-1.4.0.tgz#60da31068567082287c7337c66ef4df04e0a1029" - integrity sha512-lTEB4WUFNzYt2In6JsoF9sAYVTo84wC4e+PoZWSgM6FUtqRJz7wMylaEhSRgG71YF+wfLD6cc9nqVeXN2rwBvw== - dependencies: - "@babel/plugin-syntax-jsx" "^7.2.0" - -"@vue/babel-sugar-inject-h@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-sugar-inject-h/-/babel-sugar-inject-h-1.4.0.tgz#bf39aa6631fb1d0399b1c49b4c59e1c8899b4363" - integrity sha512-muwWrPKli77uO2fFM7eA3G1lAGnERuSz2NgAxuOLzrsTlQl8W4G+wwbM4nB6iewlKbwKRae3nL03UaF5ffAPMA== - dependencies: - "@babel/plugin-syntax-jsx" "^7.2.0" - -"@vue/babel-sugar-v-model@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-sugar-v-model/-/babel-sugar-v-model-1.4.0.tgz#a51d986609f430c4f70ada3a93cc560a2970f720" - integrity sha512-0t4HGgXb7WHYLBciZzN5s0Hzqan4Ue+p/3FdQdcaHAb7s5D9WZFGoSxEZHrR1TFVZlAPu1bejTKGeAzaaG3NCQ== - dependencies: - "@babel/plugin-syntax-jsx" "^7.2.0" - "@vue/babel-helper-vue-jsx-merge-props" "^1.4.0" - "@vue/babel-plugin-transform-vue-jsx" "^1.4.0" - camelcase "^5.0.0" - html-tags "^2.0.0" - svg-tags "^1.0.0" - -"@vue/babel-sugar-v-on@^1.4.0": - version "1.4.0" - resolved "https://registry.yarnpkg.com/@vue/babel-sugar-v-on/-/babel-sugar-v-on-1.4.0.tgz#43b7106a9672d8cbeefc0eb8afe1d376edc6166e" - integrity sha512-m+zud4wKLzSKgQrWwhqRObWzmTuyzl6vOP7024lrpeJM4x2UhQtRDLgYjXAw9xBXjCwS0pP9kXjg91F9ZNo9JA== - dependencies: - "@babel/plugin-syntax-jsx" "^7.2.0" - "@vue/babel-plugin-transform-vue-jsx" "^1.4.0" - camelcase "^5.0.0" - -"@vue/cli-overlay@^5.0.8": - version "5.0.8" - resolved "https://registry.yarnpkg.com/@vue/cli-overlay/-/cli-overlay-5.0.8.tgz#b61477acdc43bbd42fce6326d228471201ecdcdd" - integrity sha512-KmtievE/B4kcXp6SuM2gzsnSd8WebkQpg3XaB6GmFh1BJGRqa1UiW9up7L/Q67uOdTigHxr5Ar2lZms4RcDjwQ== - -"@vue/cli-plugin-babel@~5.0.0": - version "5.0.8" - resolved "https://registry.yarnpkg.com/@vue/cli-plugin-babel/-/cli-plugin-babel-5.0.8.tgz#54f9a07900f29baff54803dcfa916c602894feb7" - integrity sha512-a4qqkml3FAJ3auqB2kN2EMPocb/iu0ykeELwed+9B1c1nQ1HKgslKMHMPavYx3Cd/QAx2mBD4hwKBqZXEI/CsQ== - dependencies: - "@babel/core" "^7.12.16" - "@vue/babel-preset-app" "^5.0.8" - "@vue/cli-shared-utils" "^5.0.8" - babel-loader "^8.2.2" - thread-loader "^3.0.0" - webpack "^5.54.0" - -"@vue/cli-plugin-router@^5.0.8": - version "5.0.8" - resolved "https://registry.yarnpkg.com/@vue/cli-plugin-router/-/cli-plugin-router-5.0.8.tgz#a113ec626f3d4216d20496c42d35533bce9e889f" - integrity sha512-Gmv4dsGdAsWPqVijz3Ux2OS2HkMrWi1ENj2cYL75nUeL+Xj5HEstSqdtfZ0b1q9NCce+BFB6QnHfTBXc/fCvMg== - dependencies: - "@vue/cli-shared-utils" "^5.0.8" - -"@vue/cli-plugin-vuex@^5.0.8": - version "5.0.8" - resolved "https://registry.yarnpkg.com/@vue/cli-plugin-vuex/-/cli-plugin-vuex-5.0.8.tgz#0d4cb3020f9102bea9288d750729dde176c66ccd" - integrity sha512-HSYWPqrunRE5ZZs8kVwiY6oWcn95qf/OQabwLfprhdpFWAGtLStShjsGED2aDpSSeGAskQETrtR/5h7VqgIlBA== - -"@vue/cli-service@~5.0.0": - version "5.0.8" - resolved "https://registry.yarnpkg.com/@vue/cli-service/-/cli-service-5.0.8.tgz#cf3f6f1b7bf0fba9cdab86b6bec4f9897f982dac" - integrity sha512-nV7tYQLe7YsTtzFrfOMIHc5N2hp5lHG2rpYr0aNja9rNljdgcPZLyQRb2YRivTHqTv7lI962UXFURcpStHgyFw== - dependencies: - "@babel/helper-compilation-targets" "^7.12.16" - "@soda/friendly-errors-webpack-plugin" "^1.8.0" - "@soda/get-current-script" "^1.0.2" - "@types/minimist" "^1.2.0" - "@vue/cli-overlay" "^5.0.8" - "@vue/cli-plugin-router" "^5.0.8" - "@vue/cli-plugin-vuex" "^5.0.8" - "@vue/cli-shared-utils" "^5.0.8" - "@vue/component-compiler-utils" "^3.3.0" - "@vue/vue-loader-v15" "npm:vue-loader@^15.9.7" - "@vue/web-component-wrapper" "^1.3.0" - acorn "^8.0.5" - acorn-walk "^8.0.2" - address "^1.1.2" - autoprefixer "^10.2.4" - browserslist "^4.16.3" - case-sensitive-paths-webpack-plugin "^2.3.0" - cli-highlight "^2.1.10" - clipboardy "^2.3.0" - cliui "^7.0.4" - copy-webpack-plugin "^9.0.1" - css-loader "^6.5.0" - css-minimizer-webpack-plugin "^3.0.2" - cssnano "^5.0.0" - debug "^4.1.1" - default-gateway "^6.0.3" - dotenv "^10.0.0" - dotenv-expand "^5.1.0" - fs-extra "^9.1.0" - globby "^11.0.2" - hash-sum "^2.0.0" - html-webpack-plugin "^5.1.0" - is-file-esm "^1.0.0" - launch-editor-middleware "^2.2.1" - lodash.defaultsdeep "^4.6.1" - lodash.mapvalues "^4.6.0" - mini-css-extract-plugin "^2.5.3" - minimist "^1.2.5" - module-alias "^2.2.2" - portfinder "^1.0.26" - postcss "^8.2.6" - postcss-loader "^6.1.1" - progress-webpack-plugin "^1.0.12" - ssri "^8.0.1" - terser-webpack-plugin "^5.1.1" - thread-loader "^3.0.0" - vue-loader "^17.0.0" - vue-style-loader "^4.1.3" - webpack "^5.54.0" - webpack-bundle-analyzer "^4.4.0" - webpack-chain "^6.5.1" - webpack-dev-server "^4.7.3" - webpack-merge "^5.7.3" - webpack-virtual-modules "^0.4.2" - whatwg-fetch "^3.6.2" - -"@vue/cli-shared-utils@^5.0.0-rc.1", "@vue/cli-shared-utils@^5.0.8": - version "5.0.8" - resolved "https://registry.yarnpkg.com/@vue/cli-shared-utils/-/cli-shared-utils-5.0.8.tgz#75fc96528eba2b1c7e33cb7e989a984ddef99c8a" - integrity sha512-uK2YB7bBVuQhjOJF+O52P9yFMXeJVj7ozqJkwYE9PlMHL1LMHjtCYm4cSdOebuPzyP+/9p0BimM/OqxsevIopQ== - dependencies: - "@achrinza/node-ipc" "^9.2.5" - chalk "^4.1.2" - execa "^1.0.0" - joi "^17.4.0" - launch-editor "^2.2.1" - lru-cache "^6.0.0" - node-fetch "^2.6.7" - open "^8.0.2" - ora "^5.3.0" - read-pkg "^5.1.1" - semver "^7.3.4" - strip-ansi "^6.0.0" - -"@vue/compiler-core@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/compiler-core/-/compiler-core-3.3.4.tgz#7fbf591c1c19e1acd28ffd284526e98b4f581128" - integrity sha512-cquyDNvZ6jTbf/+x+AgM2Arrp6G4Dzbb0R64jiG804HRMfRiFXWI6kqUVqZ6ZR0bQhIoQjB4+2bhNtVwndW15g== - dependencies: - "@babel/parser" "^7.21.3" - "@vue/shared" "3.3.4" + "@babel/parser" "^7.23.0" + "@vue/shared" "3.3.7" estree-walker "^2.0.2" source-map-js "^1.0.2" -"@vue/compiler-dom@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/compiler-dom/-/compiler-dom-3.3.4.tgz#f56e09b5f4d7dc350f981784de9713d823341151" - integrity sha512-wyM+OjOVpuUukIq6p5+nwHYtj9cFroz9cwkfmP9O1nzH68BenTTv0u7/ndggT8cIQlnBeOo6sUT/gvHcIkLA5w== +"@vue/compiler-dom@3.3.7", "@vue/compiler-dom@^3.3.0": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/compiler-dom/-/compiler-dom-3.3.7.tgz#a245aa03f9bfcdb537a239bf02842072de0644c9" + integrity sha512-0LwkyJjnUPssXv/d1vNJ0PKfBlDoQs7n81CbO6Q0zdL7H1EzqYRrTVXDqdBVqro0aJjo/FOa1qBAPVI4PGSHBw== dependencies: - "@vue/compiler-core" "3.3.4" - "@vue/shared" "3.3.4" + "@vue/compiler-core" "3.3.7" + "@vue/shared" "3.3.7" -"@vue/compiler-sfc@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/compiler-sfc/-/compiler-sfc-3.3.4.tgz#b19d942c71938893535b46226d602720593001df" - integrity sha512-6y/d8uw+5TkCuzBkgLS0v3lSM3hJDntFEiUORM11pQ/hKvkhSKZrXW6i69UyXlJQisJxuUEJKAWEqWbWsLeNKQ== +"@vue/compiler-sfc@3.3.7": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/compiler-sfc/-/compiler-sfc-3.3.7.tgz#219d04b3013c7b15fbc536e2279e07810b731cc2" + integrity sha512-7pfldWy/J75U/ZyYIXRVqvLRw3vmfxDo2YLMwVtWVNew8Sm8d6wodM+OYFq4ll/UxfqVr0XKiVwti32PCrruAw== dependencies: - "@babel/parser" "^7.20.15" - "@vue/compiler-core" "3.3.4" - "@vue/compiler-dom" "3.3.4" - "@vue/compiler-ssr" "3.3.4" - "@vue/reactivity-transform" "3.3.4" - "@vue/shared" "3.3.4" + "@babel/parser" "^7.23.0" + "@vue/compiler-core" "3.3.7" + "@vue/compiler-dom" "3.3.7" + "@vue/compiler-ssr" "3.3.7" + "@vue/reactivity-transform" "3.3.7" + "@vue/shared" "3.3.7" estree-walker "^2.0.2" - magic-string "^0.30.0" - postcss "^8.1.10" + magic-string "^0.30.5" + postcss "^8.4.31" source-map-js "^1.0.2" -"@vue/compiler-ssr@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/compiler-ssr/-/compiler-ssr-3.3.4.tgz#9d1379abffa4f2b0cd844174ceec4a9721138777" - integrity sha512-m0v6oKpup2nMSehwA6Uuu+j+wEwcy7QmwMkVNVfrV9P2qE5KshC6RwOCq8fjGS/Eak/uNb8AaWekfiXxbBB6gQ== +"@vue/compiler-ssr@3.3.7": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/compiler-ssr/-/compiler-ssr-3.3.7.tgz#eff4a70f7ceb800d60e68d208b96a030c0f1b636" + integrity sha512-TxOfNVVeH3zgBc82kcUv+emNHo+vKnlRrkv8YvQU5+Y5LJGJwSNzcmLUoxD/dNzv0bhQ/F0s+InlgV0NrApJZg== dependencies: - "@vue/compiler-dom" "3.3.4" - "@vue/shared" "3.3.4" - -"@vue/component-compiler-utils@^3.1.0", "@vue/component-compiler-utils@^3.3.0": - version "3.3.0" - resolved "https://registry.yarnpkg.com/@vue/component-compiler-utils/-/component-compiler-utils-3.3.0.tgz#f9f5fb53464b0c37b2c8d2f3fbfe44df60f61dc9" - integrity sha512-97sfH2mYNU+2PzGrmK2haqffDpVASuib9/w2/noxiFi31Z54hW+q3izKQXXQZSNhtiUpAI36uSuYepeBe4wpHQ== - dependencies: - consolidate "^0.15.1" - hash-sum "^1.0.2" - lru-cache "^4.1.2" - merge-source-map "^1.1.0" - postcss "^7.0.36" - postcss-selector-parser "^6.0.2" - source-map "~0.6.1" - vue-template-es2015-compiler "^1.9.0" - optionalDependencies: - prettier "^1.18.2 || ^2.0.0" - -"@vue/devtools-api@^6.0.0-beta.11": - version "6.4.4" - resolved "https://registry.yarnpkg.com/@vue/devtools-api/-/devtools-api-6.4.4.tgz#0b024fc8ca91bb4b6035abaf53c5aecc17119b3b" - integrity sha512-Ku31WzpOV/8cruFaXaEZKF81WkNnvCSlBY4eOGtz5WMSdJvX1v1WWlSMGZeqUwPtQ27ZZz7B62erEMq8JDjcXw== + "@vue/compiler-dom" "3.3.7" + "@vue/shared" "3.3.7" "@vue/devtools-api@^6.5.0": - version "6.5.0" - resolved "https://registry.yarnpkg.com/@vue/devtools-api/-/devtools-api-6.5.0.tgz#98b99425edee70b4c992692628fa1ea2c1e57d07" - integrity sha512-o9KfBeaBmCKl10usN4crU53fYtC1r7jJwdGKjPT24t348rHxgfpZ0xL3Xm/gLUYnc0oTp8LAmrxOeLyu6tbk2Q== + version "6.5.1" + resolved "https://registry.npmmirror.com/@vue/devtools-api/-/devtools-api-6.5.1.tgz#7f71f31e40973eeee65b9a64382b13593fdbd697" + integrity sha512-+KpckaAQyfbvshdDW5xQylLni1asvNSGme1JFs8I1+/H5pHEhqUKMEQD/qn3Nx5+/nycBq11qAEi8lk+LXI2dA== -"@vue/reactivity-transform@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/reactivity-transform/-/reactivity-transform-3.3.4.tgz#52908476e34d6a65c6c21cd2722d41ed8ae51929" - integrity sha512-MXgwjako4nu5WFLAjpBnCj/ieqcjE2aJBINUNQzkZQfzIZA4xn+0fV1tIYBJvvva3N3OvKGofRLvQIwEQPpaXw== +"@vue/language-core@1.8.22": + version "1.8.22" + resolved "https://registry.npmmirror.com/@vue/language-core/-/language-core-1.8.22.tgz#1ef62645fb9b1f830c6c84a5586e49e74727b1e3" + integrity sha512-bsMoJzCrXZqGsxawtUea1cLjUT9dZnDsy5TuZ+l1fxRMzUGQUG9+Ypq4w//CqpWmrx7nIAJpw2JVF/t258miRw== dependencies: - "@babel/parser" "^7.20.15" - "@vue/compiler-core" "3.3.4" - "@vue/shared" "3.3.4" + "@volar/language-core" "~1.10.5" + "@volar/source-map" "~1.10.5" + "@vue/compiler-dom" "^3.3.0" + "@vue/shared" "^3.3.0" + computeds "^0.0.1" + minimatch "^9.0.3" + muggle-string "^0.3.1" + vue-template-compiler "^2.7.14" + +"@vue/reactivity-transform@3.3.7": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/reactivity-transform/-/reactivity-transform-3.3.7.tgz#eb9f5110af5085079b851d162205394bc790d539" + integrity sha512-APhRmLVbgE1VPGtoLQoWBJEaQk4V8JUsqrQihImVqKT+8U6Qi3t5ATcg4Y9wGAPb3kIhetpufyZ1RhwbZCIdDA== + dependencies: + "@babel/parser" "^7.23.0" + "@vue/compiler-core" "3.3.7" + "@vue/shared" "3.3.7" estree-walker "^2.0.2" - magic-string "^0.30.0" + magic-string "^0.30.5" -"@vue/reactivity@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/reactivity/-/reactivity-3.3.4.tgz#a27a29c6cd17faba5a0e99fbb86ee951653e2253" - integrity sha512-kLTDLwd0B1jG08NBF3R5rqULtv/f8x3rOFByTDz4J53ttIQEDmALqKqXY0J+XQeN0aV2FBxY8nJDf88yvOPAqQ== +"@vue/reactivity@3.3.7": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/reactivity/-/reactivity-3.3.7.tgz#48b6671a45ba33039da2c0eb25ae702f924486a9" + integrity sha512-cZNVjWiw00708WqT0zRpyAgduG79dScKEPYJXq2xj/aMtk3SKvL3FBt2QKUlh6EHBJ1m8RhBY+ikBUzwc7/khg== dependencies: - "@vue/shared" "3.3.4" + "@vue/shared" "3.3.7" -"@vue/runtime-core@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/runtime-core/-/runtime-core-3.3.4.tgz#4bb33872bbb583721b340f3088888394195967d1" - integrity sha512-R+bqxMN6pWO7zGI4OMlmvePOdP2c93GsHFM/siJI7O2nxFRzj55pLwkpCedEY+bTMgp5miZ8CxfIZo3S+gFqvA== +"@vue/runtime-core@3.3.7": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/runtime-core/-/runtime-core-3.3.7.tgz#c1eece1c98f936dc69dd0667d11b464579b128fd" + integrity sha512-LHq9du3ubLZFdK/BP0Ysy3zhHqRfBn80Uc+T5Hz3maFJBGhci1MafccnL3rpd5/3wVfRHAe6c+PnlO2PAavPTQ== dependencies: - "@vue/reactivity" "3.3.4" - "@vue/shared" "3.3.4" + "@vue/reactivity" "3.3.7" + "@vue/shared" "3.3.7" -"@vue/runtime-dom@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/runtime-dom/-/runtime-dom-3.3.4.tgz#992f2579d0ed6ce961f47bbe9bfe4b6791251566" - integrity sha512-Aj5bTJ3u5sFsUckRghsNjVTtxZQ1OyMWCr5dZRAPijF/0Vy4xEoRCwLyHXcj4D0UFbJ4lbx3gPTgg06K/GnPnQ== +"@vue/runtime-dom@3.3.7": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/runtime-dom/-/runtime-dom-3.3.7.tgz#e7cf88cc01591fdf6e3164825554fdadc3137ffc" + integrity sha512-PFQU1oeJxikdDmrfoNQay5nD4tcPNYixUBruZzVX/l0eyZvFKElZUjW4KctCcs52nnpMGO6UDK+jF5oV4GT5Lw== dependencies: - "@vue/runtime-core" "3.3.4" - "@vue/shared" "3.3.4" - csstype "^3.1.1" + "@vue/runtime-core" "3.3.7" + "@vue/shared" "3.3.7" + csstype "^3.1.2" -"@vue/server-renderer@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/server-renderer/-/server-renderer-3.3.4.tgz#ea46594b795d1536f29bc592dd0f6655f7ea4c4c" - integrity sha512-Q6jDDzR23ViIb67v+vM1Dqntu+HUexQcsWKhhQa4ARVzxOY2HbC7QRW/ggkDBd5BU+uM1sV6XOAP0b216o34JQ== +"@vue/server-renderer@3.3.7": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/server-renderer/-/server-renderer-3.3.7.tgz#0cc3dc6ad39a54693e6e8f853caa3c7bb43b0364" + integrity sha512-UlpKDInd1hIZiNuVVVvLgxpfnSouxKQOSE2bOfQpBuGwxRV/JqqTCyyjXUWiwtVMyeRaZhOYYqntxElk8FhBhw== dependencies: - "@vue/compiler-ssr" "3.3.4" - "@vue/shared" "3.3.4" + "@vue/compiler-ssr" "3.3.7" + "@vue/shared" "3.3.7" -"@vue/shared@3.3.4": - version "3.3.4" - resolved "https://registry.yarnpkg.com/@vue/shared/-/shared-3.3.4.tgz#06e83c5027f464eef861c329be81454bc8b70780" - integrity sha512-7OjdcV8vQ74eiz1TZLzZP4JwqM5fA94K6yntPS5Z25r9HDuGNzaGdgvwKYq6S+MxwF0TFRwe50fIR/MYnakdkQ== +"@vue/shared@3.3.7", "@vue/shared@^3.3.0": + version "3.3.7" + resolved "https://registry.npmmirror.com/@vue/shared/-/shared-3.3.7.tgz#0091852fe5cc4237c8440fe32f3ab6bc920ae6d9" + integrity sha512-N/tbkINRUDExgcPTBvxNkvHGu504k8lzlNQRITVnm6YjOjwa4r0nnbd4Jb01sNpur5hAllyRJzSK5PvB9PPwRg== -"@vue/vue-loader-v15@npm:vue-loader@^15.9.7": - version "15.10.0" - resolved "https://registry.yarnpkg.com/vue-loader/-/vue-loader-15.10.0.tgz#2a12695c421a2a2cc2138f05a949d04ed086e38b" - integrity sha512-VU6tuO8eKajrFeBzMssFUP9SvakEeeSi1BxdTH5o3+1yUyrldp8IERkSdXlMI2t4kxF2sqYUDsQY+WJBxzBmZg== +"@xicons/utils@^0.1.4": + version "0.1.4" + resolved "https://registry.npmmirror.com/@xicons/utils/-/utils-0.1.4.tgz#cece50613b34d4b4c71e73bb0be92981067e11e1" + integrity sha512-uXxKDLz9abr80yJC05XSTq6wlyFcdW+N/1IYJkeHjzzXVc4VQ0sEYMoMMTjAH7HQBOyOkzOB4pf5NGF72lwa8Q== dependencies: - "@vue/component-compiler-utils" "^3.1.0" - hash-sum "^1.0.2" - loader-utils "^1.1.0" - vue-hot-reload-api "^2.3.0" - vue-style-loader "^4.1.0" + css-render "^0.13.2" -"@vue/web-component-wrapper@^1.3.0": - version "1.3.0" - resolved "https://registry.yarnpkg.com/@vue/web-component-wrapper/-/web-component-wrapper-1.3.0.tgz#b6b40a7625429d2bd7c2281ddba601ed05dc7f1a" - integrity sha512-Iu8Tbg3f+emIIMmI2ycSI8QcEuAUgPTgHwesDU1eKMLE4YC/c/sFbGc70QgMq31ijRftV0R7vCm9co6rldCeOA== +"@xmldom/xmldom@^0.8.8": + version "0.8.10" + resolved "https://registry.npmmirror.com/@xmldom/xmldom/-/xmldom-0.8.10.tgz#a1337ca426aa61cef9fe15b5b28e340a72f6fa99" + integrity sha512-2WALfTl4xo2SkGCYRt6rDTFfk9R1czmBvUQy12gK2KuRKIpWEhcbbzy8EZXtz/jkRqHX8bFEc6FC1HjX4TUWYw== -"@webassemblyjs/ast@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/ast/-/ast-1.11.1.tgz#2bfd767eae1a6996f432ff7e8d7fc75679c0b6a7" - integrity sha512-ukBh14qFLjxTQNTXocdyksN5QdM28S1CxHt2rdskFyL+xFV7VremuBLVbmCePj+URalXBENx/9Lm7lnhihtCSw== - dependencies: - "@webassemblyjs/helper-numbers" "1.11.1" - "@webassemblyjs/helper-wasm-bytecode" "1.11.1" - -"@webassemblyjs/floating-point-hex-parser@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.1.tgz#f6c61a705f0fd7a6aecaa4e8198f23d9dc179e4f" - integrity sha512-iGRfyc5Bq+NnNuX8b5hwBrRjzf0ocrJPI6GWFodBFzmFnyvrQ83SHKhmilCU/8Jv67i4GJZBMhEzltxzcNagtQ== - -"@webassemblyjs/helper-api-error@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.1.tgz#1a63192d8788e5c012800ba6a7a46c705288fd16" - integrity sha512-RlhS8CBCXfRUR/cwo2ho9bkheSXG0+NwooXcc3PAILALf2QLdFyj7KGsKRbVc95hZnhnERon4kW/D3SZpp6Tcg== - -"@webassemblyjs/helper-buffer@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.1.tgz#832a900eb444884cde9a7cad467f81500f5e5ab5" - integrity sha512-gwikF65aDNeeXa8JxXa2BAk+REjSyhrNC9ZwdT0f8jc4dQQeDQ7G4m0f2QCLPJiMTTO6wfDmRmj/pW0PsUvIcA== - -"@webassemblyjs/helper-numbers@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.1.tgz#64d81da219fbbba1e3bd1bfc74f6e8c4e10a62ae" - integrity sha512-vDkbxiB8zfnPdNK9Rajcey5C0w+QJugEglN0of+kmO8l7lDb77AnlKYQF7aarZuCrv+l0UvqL+68gSDr3k9LPQ== - dependencies: - "@webassemblyjs/floating-point-hex-parser" "1.11.1" - "@webassemblyjs/helper-api-error" "1.11.1" - "@xtuc/long" "4.2.2" - -"@webassemblyjs/helper-wasm-bytecode@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.1.tgz#f328241e41e7b199d0b20c18e88429c4433295e1" - integrity sha512-PvpoOGiJwXeTrSf/qfudJhwlvDQxFgelbMqtq52WWiXC6Xgg1IREdngmPN3bs4RoO83PnL/nFrxucXj1+BX62Q== - -"@webassemblyjs/helper-wasm-section@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.1.tgz#21ee065a7b635f319e738f0dd73bfbda281c097a" - integrity sha512-10P9No29rYX1j7F3EVPX3JvGPQPae+AomuSTPiF9eBQeChHI6iqjMIwR9JmOJXwpnn/oVGDk7I5IlskuMwU/pg== - dependencies: - "@webassemblyjs/ast" "1.11.1" - "@webassemblyjs/helper-buffer" "1.11.1" - "@webassemblyjs/helper-wasm-bytecode" "1.11.1" - "@webassemblyjs/wasm-gen" "1.11.1" - -"@webassemblyjs/ieee754@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/ieee754/-/ieee754-1.11.1.tgz#963929e9bbd05709e7e12243a099180812992614" - integrity sha512-hJ87QIPtAMKbFq6CGTkZYJivEwZDbQUgYd3qKSadTNOhVY7p+gfP6Sr0lLRVTaG1JjFj+r3YchoqRYxNH3M0GQ== - dependencies: - "@xtuc/ieee754" "^1.2.0" - -"@webassemblyjs/leb128@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/leb128/-/leb128-1.11.1.tgz#ce814b45574e93d76bae1fb2644ab9cdd9527aa5" - integrity sha512-BJ2P0hNZ0u+Th1YZXJpzW6miwqQUGcIHT1G/sf72gLVD9DZ5AdYTqPNbHZh6K1M5VmKvFXwGSWZADz+qBWxeRw== - dependencies: - "@xtuc/long" "4.2.2" - -"@webassemblyjs/utf8@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/utf8/-/utf8-1.11.1.tgz#d1f8b764369e7c6e6bae350e854dec9a59f0a3ff" - integrity sha512-9kqcxAEdMhiwQkHpkNiorZzqpGrodQQ2IGrHHxCy+Ozng0ofyMA0lTqiLkVs1uzTRejX+/O0EOT7KxqVPuXosQ== - -"@webassemblyjs/wasm-edit@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.1.tgz#ad206ebf4bf95a058ce9880a8c092c5dec8193d6" - integrity sha512-g+RsupUC1aTHfR8CDgnsVRVZFJqdkFHpsHMfJuWQzWU3tvnLC07UqHICfP+4XyL2tnr1amvl1Sdp06TnYCmVkA== - dependencies: - "@webassemblyjs/ast" "1.11.1" - "@webassemblyjs/helper-buffer" "1.11.1" - "@webassemblyjs/helper-wasm-bytecode" "1.11.1" - "@webassemblyjs/helper-wasm-section" "1.11.1" - "@webassemblyjs/wasm-gen" "1.11.1" - "@webassemblyjs/wasm-opt" "1.11.1" - "@webassemblyjs/wasm-parser" "1.11.1" - "@webassemblyjs/wast-printer" "1.11.1" - -"@webassemblyjs/wasm-gen@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.1.tgz#86c5ea304849759b7d88c47a32f4f039ae3c8f76" - integrity sha512-F7QqKXwwNlMmsulj6+O7r4mmtAlCWfO/0HdgOxSklZfQcDu0TpLiD1mRt/zF25Bk59FIjEuGAIyn5ei4yMfLhA== - dependencies: - "@webassemblyjs/ast" "1.11.1" - "@webassemblyjs/helper-wasm-bytecode" "1.11.1" - "@webassemblyjs/ieee754" "1.11.1" - "@webassemblyjs/leb128" "1.11.1" - "@webassemblyjs/utf8" "1.11.1" - -"@webassemblyjs/wasm-opt@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.1.tgz#657b4c2202f4cf3b345f8a4c6461c8c2418985f2" - integrity sha512-VqnkNqnZlU5EB64pp1l7hdm3hmQw7Vgqa0KF/KCNO9sIpI6Fk6brDEiX+iCOYrvMuBWDws0NkTOxYEb85XQHHw== - dependencies: - "@webassemblyjs/ast" "1.11.1" - "@webassemblyjs/helper-buffer" "1.11.1" - "@webassemblyjs/wasm-gen" "1.11.1" - "@webassemblyjs/wasm-parser" "1.11.1" - -"@webassemblyjs/wasm-parser@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.1.tgz#86ca734534f417e9bd3c67c7a1c75d8be41fb199" - integrity sha512-rrBujw+dJu32gYB7/Lup6UhdkPx9S9SnobZzRVL7VcBH9Bt9bCBLEuX/YXOOtBsOZ4NQrRykKhffRWHvigQvOA== - dependencies: - "@webassemblyjs/ast" "1.11.1" - "@webassemblyjs/helper-api-error" "1.11.1" - "@webassemblyjs/helper-wasm-bytecode" "1.11.1" - "@webassemblyjs/ieee754" "1.11.1" - "@webassemblyjs/leb128" "1.11.1" - "@webassemblyjs/utf8" "1.11.1" - -"@webassemblyjs/wast-printer@1.11.1": - version "1.11.1" - resolved "https://registry.yarnpkg.com/@webassemblyjs/wast-printer/-/wast-printer-1.11.1.tgz#d0c73beda8eec5426f10ae8ef55cee5e7084c2f0" - integrity sha512-IQboUWM4eKzWW+N/jij2sRatKMh99QEelo3Eb2q0qXkvPRISAj8Qxtmw5itwqK+TTkBuUIE45AxYPToqPtL5gg== - dependencies: - "@webassemblyjs/ast" "1.11.1" - "@xtuc/long" "4.2.2" - -"@xtuc/ieee754@^1.2.0": - version "1.2.0" - resolved "https://registry.yarnpkg.com/@xtuc/ieee754/-/ieee754-1.2.0.tgz#eef014a3145ae477a1cbc00cd1e552336dceb790" - integrity sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA== - -"@xtuc/long@4.2.2": - version "4.2.2" - resolved "https://registry.yarnpkg.com/@xtuc/long/-/long-4.2.2.tgz#d291c6a4e97989b5c61d9acf396ae4fe133a718d" - integrity sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ== - -abbrev@^1.0.0: - version "1.1.1" - resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" - integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== - -accepts@~1.3.4, accepts@~1.3.5, accepts@~1.3.8: - version "1.3.8" - resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.8.tgz#0bf0be125b67014adcb0b0921e62db7bffe16b2e" - integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== - dependencies: - mime-types "~2.1.34" - negotiator "0.6.3" - -acorn-import-assertions@^1.7.6: - version "1.8.0" - resolved "https://registry.yarnpkg.com/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz#ba2b5939ce62c238db6d93d81c9b111b29b855e9" - integrity sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw== - -acorn-node@^1.8.2: - version "1.8.2" - resolved "https://registry.yarnpkg.com/acorn-node/-/acorn-node-1.8.2.tgz#114c95d64539e53dede23de8b9d96df7c7ae2af8" - integrity sha512-8mt+fslDufLYntIoPAaIMUe/lrbrehIiwmR3t2k9LljIzoigEPF27eLk2hy8zSGzmR/ogr7zbRKINMo1u0yh5A== - dependencies: - acorn "^7.0.0" - acorn-walk "^7.0.0" - xtend "^4.0.2" - -acorn-walk@^7.0.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-7.2.0.tgz#0de889a601203909b0fbe07b8938dc21d2e967bc" - integrity sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA== - -acorn-walk@^8.0.0, acorn-walk@^8.0.2: - version "8.2.0" - resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.2.0.tgz#741210f2e2426454508853a2f44d0ab83b7f69c1" - integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA== - -acorn@^7.0.0: - version "7.4.1" - resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa" - integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A== - -acorn@^8.0.4, acorn@^8.0.5, acorn@^8.5.0, acorn@^8.7.1: - version "8.8.0" - resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.0.tgz#88c0187620435c7f6015803f5539dae05a9dbea8" - integrity sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w== - -address@^1.1.2: - version "1.2.1" - resolved "https://registry.yarnpkg.com/address/-/address-1.2.1.tgz#25bb61095b7522d65b357baa11bc05492d4c8acd" - integrity sha512-B+6bi5D34+fDYENiH5qOlA0cV2rAGKuWZ9LeyUUehbXy8e0VS9e498yO0Jeeh+iM+6KbfudHTFjXw2MmJD4QRA== - -agent-base@6, agent-base@^6.0.2: +agent-base@6: version "6.0.2" - resolved "https://registry.yarnpkg.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77" + resolved "https://registry.npmmirror.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77" integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ== dependencies: debug "4" -agentkeepalive@^4.2.1: - version "4.3.0" - resolved "https://registry.yarnpkg.com/agentkeepalive/-/agentkeepalive-4.3.0.tgz#bb999ff07412653c1803b3ced35e50729830a255" - integrity sha512-7Epl1Blf4Sy37j4v9f9FjICCh4+KAQOyXgHEwlyBiAQLbhKdq/i2QQU3amQalS/wPhdPzDXPL5DMR5bkn+YeWg== - dependencies: - debug "^4.1.0" - depd "^2.0.0" - humanize-ms "^1.2.1" - -aggregate-error@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" - integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== - dependencies: - clean-stack "^2.0.0" - indent-string "^4.0.0" - ajv-formats@^2.1.1: version "2.1.1" - resolved "https://registry.yarnpkg.com/ajv-formats/-/ajv-formats-2.1.1.tgz#6e669400659eb74973bbf2e33327180a0996b520" + resolved "https://registry.npmmirror.com/ajv-formats/-/ajv-formats-2.1.1.tgz#6e669400659eb74973bbf2e33327180a0996b520" integrity sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA== dependencies: ajv "^8.0.0" -ajv-keywords@^3.4.1, ajv-keywords@^3.5.2: +ajv-keywords@^3.4.1: version "3.5.2" - resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-3.5.2.tgz#31f29da5ab6e00d1c2d329acf7b5929614d5014d" + resolved "https://registry.npmmirror.com/ajv-keywords/-/ajv-keywords-3.5.2.tgz#31f29da5ab6e00d1c2d329acf7b5929614d5014d" integrity sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ== -ajv-keywords@^5.0.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-5.1.0.tgz#69d4d385a4733cdbeab44964a1170a88f87f0e16" - integrity sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw== - dependencies: - fast-deep-equal "^3.1.3" - -ajv@^6.10.0, ajv@^6.12.0, ajv@^6.12.3, ajv@^6.12.4, ajv@^6.12.5: +ajv@^6.10.0, ajv@^6.12.0, ajv@^6.12.3: version "6.12.6" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" + resolved "https://registry.npmmirror.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== dependencies: fast-deep-equal "^3.1.1" @@ -2427,137 +664,66 @@ ajv@^6.10.0, ajv@^6.12.0, ajv@^6.12.3, ajv@^6.12.4, ajv@^6.12.5: json-schema-traverse "^0.4.1" uri-js "^4.2.2" -ajv@^8.0.0, ajv@^8.6.3, ajv@^8.8.0: - version "8.11.0" - resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.11.0.tgz#977e91dd96ca669f54a11e23e378e33b884a565f" - integrity sha512-wGgprdCvMalC0BztXvitD2hC04YffAvtsUn93JbGXYLAtCUO4xd17mCCZQxUOItiBwZvJScWo8NIvQMQ71rdpg== +ajv@^8.0.0, ajv@^8.6.3: + version "8.12.0" + resolved "https://registry.npmmirror.com/ajv/-/ajv-8.12.0.tgz#d1a0527323e22f53562c567c00991577dfbe19d1" + integrity sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA== dependencies: fast-deep-equal "^3.1.1" json-schema-traverse "^1.0.0" require-from-string "^2.0.2" uri-js "^4.2.2" -ansi-align@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/ansi-align/-/ansi-align-3.0.1.tgz#0cdf12e111ace773a86e9a1fad1225c43cb19a59" - integrity sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w== - dependencies: - string-width "^4.1.0" - -ansi-escapes@^3.0.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-3.2.0.tgz#8780b98ff9dbf5638152d1f1fe5c1d7b4442976b" - integrity sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ== - -ansi-html-community@^0.0.8: - version "0.0.8" - resolved "https://registry.yarnpkg.com/ansi-html-community/-/ansi-html-community-0.0.8.tgz#69fbc4d6ccbe383f9736934ae34c3f8290f1bf41" - integrity sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw== - -ansi-regex@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.1.tgz#123d6479e92ad45ad897d4054e3c7ca7db4944e1" - integrity sha512-+O9Jct8wf++lXxxFc4hc8LsjaSq0HFzzL7cVsw8pRDIPdjKD2mT4ytDZlLuSBZ4cLKZFXIrMGO7DbQCtMJJMKw== - ansi-regex@^5.0.1: version "5.0.1" - resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" + resolved "https://registry.npmmirror.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== -ansi-styles@^3.2.1: - version "3.2.1" - resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" - integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== - dependencies: - color-convert "^1.9.0" - ansi-styles@^4.0.0, ansi-styles@^4.1.0: version "4.3.0" - resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" + resolved "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== dependencies: color-convert "^2.0.1" -any-base@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/any-base/-/any-base-1.1.0.tgz#ae101a62bc08a597b4c9ab5b7089d456630549fe" - integrity sha512-uMgjozySS8adZZYePpaWs8cxB9/kdzmpX6SgJZ+wbz1K5eYk5QMYDVJaZKhxyIHUdnnJkfR7SVgStgH7LkGUyg== - any-promise@^1.0.0: version "1.3.0" - resolved "https://registry.yarnpkg.com/any-promise/-/any-promise-1.3.0.tgz#abc6afeedcea52e809cdc0376aed3ce39635d17f" + resolved "https://registry.npmmirror.com/any-promise/-/any-promise-1.3.0.tgz#abc6afeedcea52e809cdc0376aed3ce39635d17f" integrity sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A== anymatch@~3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716" - integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg== + version "3.1.3" + resolved "https://registry.npmmirror.com/anymatch/-/anymatch-3.1.3.tgz#790c58b19ba1720a84205b57c618d5ad8524973e" + integrity sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw== dependencies: normalize-path "^3.0.0" picomatch "^2.0.4" -app-builder-bin@3.7.1: - version "3.7.1" - resolved "https://registry.yarnpkg.com/app-builder-bin/-/app-builder-bin-3.7.1.tgz#cb0825c5e12efc85b196ac3ed9c89f076c61040e" - integrity sha512-ql93vEUq6WsstGXD+SBLSIQw6SNnhbDEM0swzgugytMxLp3rT24Ag/jcC80ZHxiPRTdew1niuR7P3/FCrDqIjw== - app-builder-bin@4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/app-builder-bin/-/app-builder-bin-4.0.0.tgz#1df8e654bd1395e4a319d82545c98667d7eed2f0" + resolved "https://registry.npmmirror.com/app-builder-bin/-/app-builder-bin-4.0.0.tgz#1df8e654bd1395e4a319d82545c98667d7eed2f0" integrity sha512-xwdG0FJPQMe0M0UA4Tz0zEB8rBJTRA5a476ZawAqiBkMv16GRK5xpXThOjMaEOFnZ6zabejjG4J3da0SXG63KA== -app-builder-lib@22.14.13: - version "22.14.13" - resolved "https://registry.yarnpkg.com/app-builder-lib/-/app-builder-lib-22.14.13.tgz#c1f5b6afc86596357598bb90b69eef06c7c2eeb3" - integrity sha512-SufmrtxU+D0Tn948fjEwAOlCN9757UXLkzzTWXMwZKR/5hisvgqeeBepWfphMIE6OkDGz0fbzEhL1P2Pty4XMg== +app-builder-lib@24.6.4: + version "24.6.4" + resolved "https://registry.npmmirror.com/app-builder-lib/-/app-builder-lib-24.6.4.tgz#5bf77dd89d3ee557bc615b9ddfaf383f3e51577b" + integrity sha512-m9931WXb83teb32N0rKg+ulbn6+Hl8NV5SUpVDOVz9MWOXfhV6AQtTdftf51zJJvCQnQugGtSqoLvgw6mdF/Rg== dependencies: "7zip-bin" "~5.1.1" "@develar/schema-utils" "~2.6.5" - "@electron/universal" "1.0.5" - "@malept/flatpak-bundler" "^0.4.0" - async-exit-hook "^2.0.1" - bluebird-lst "^1.0.9" - builder-util "22.14.13" - builder-util-runtime "8.9.2" - chromium-pickle-js "^0.2.0" - debug "^4.3.2" - ejs "^3.1.6" - electron-osx-sign "^0.5.0" - electron-publish "22.14.13" - form-data "^4.0.0" - fs-extra "^10.0.0" - hosted-git-info "^4.0.2" - is-ci "^3.0.0" - isbinaryfile "^4.0.8" - js-yaml "^4.1.0" - lazy-val "^1.0.5" - minimatch "^3.0.4" - read-config-file "6.2.0" - sanitize-filename "^1.6.3" - semver "^7.3.5" - temp-file "^3.4.0" - -app-builder-lib@24.4.0: - version "24.4.0" - resolved "https://registry.yarnpkg.com/app-builder-lib/-/app-builder-lib-24.4.0.tgz#1606f94e99366eea9e7507228961b8396e40d546" - integrity sha512-EcdqtWvg1LAApKCfyRBukcVkmsa94s2e1VKHjZLpvA9/D14QEt8rHhffYeaA+cH/pVeoNVn2ob735KnfJKEEow== - dependencies: - "7zip-bin" "~5.1.1" - "@develar/schema-utils" "~2.6.5" - "@electron/notarize" "^1.2.3" - "@electron/osx-sign" "^1.0.4" - "@electron/rebuild" "^3.2.13" - "@electron/universal" "1.3.4" + "@electron/notarize" "2.1.0" + "@electron/osx-sign" "1.0.5" + "@electron/universal" "1.4.1" "@malept/flatpak-bundler" "^0.4.0" "@types/fs-extra" "9.0.13" async-exit-hook "^2.0.1" bluebird-lst "^1.0.9" - builder-util "24.4.0" + builder-util "24.5.0" builder-util-runtime "9.2.1" chromium-pickle-js "^0.2.0" debug "^4.3.4" ejs "^3.1.8" - electron-publish "24.4.0" + electron-publish "24.5.0" form-data "^4.0.0" fs-extra "^10.1.0" hosted-git-info "^4.1.0" @@ -2572,220 +738,125 @@ app-builder-lib@24.4.0: tar "^6.1.12" temp-file "^3.4.0" -"aproba@^1.0.3 || ^2.0.0": - version "2.0.0" - resolved "https://registry.yarnpkg.com/aproba/-/aproba-2.0.0.tgz#52520b8ae5b569215b354efc0caa3fe1e45a8adc" - integrity sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ== - -arch@^2.1.1: - version "2.2.0" - resolved "https://registry.yarnpkg.com/arch/-/arch-2.2.0.tgz#1bc47818f305764f23ab3306b0bfc086c5a29d11" - integrity sha512-Of/R0wqp83cgHozfIYLbBMnej79U/SVGOOyuB3VVFv1NRM/PSFMK12x9KVtiYzJqmnU5WR2qp0Z5rHb7sWGnFQ== - -are-we-there-yet@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-3.0.1.tgz#679df222b278c64f2cdba1175cdc00b0d96164bd" - integrity sha512-QZW4EDmGwlYur0Yyf/b2uGucHQMa8aFUP7eu9ddR73vvhFyt4V0Vl3QHPcTNJ8l6qYOBdxgXdnBXQrHilfRQBg== - dependencies: - delegates "^1.0.0" - readable-stream "^3.6.0" - arg@^5.0.2: version "5.0.2" - resolved "https://registry.yarnpkg.com/arg/-/arg-5.0.2.tgz#c81433cc427c92c4dcf4865142dbca6f15acd59c" + resolved "https://registry.npmmirror.com/arg/-/arg-5.0.2.tgz#c81433cc427c92c4dcf4865142dbca6f15acd59c" integrity sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg== argparse@^2.0.1: version "2.0.1" - resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" + resolved "https://registry.npmmirror.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== -array-flatten@1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" - integrity sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg== - -array-flatten@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-2.1.2.tgz#24ef80a28c1a893617e2149b0c6d0d788293b099" - integrity sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ== - -array-union@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" - integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== - -asar@^3.0.3: - version "3.2.0" - resolved "https://registry.yarnpkg.com/asar/-/asar-3.2.0.tgz#e6edb5edd6f627ebef04db62f771c61bea9c1221" - integrity sha512-COdw2ZQvKdFGFxXwX3oYh2/sOsJWJegrdJCGxnN4MZ7IULgRBp9P6665aqj9z1v9VwP4oP1hRBojRDQ//IGgAg== - dependencies: - chromium-pickle-js "^0.2.0" - commander "^5.0.0" - glob "^7.1.6" - minimatch "^3.0.4" - optionalDependencies: - "@types/glob" "^7.1.1" - asn1@~0.2.3: version "0.2.6" - resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.6.tgz#0d3a7bb6e64e02a90c0303b31f292868ea09a08d" + resolved "https://registry.npmmirror.com/asn1/-/asn1-0.2.6.tgz#0d3a7bb6e64e02a90c0303b31f292868ea09a08d" integrity sha512-ix/FxPn0MDjeyJ7i/yoHGFt/EX6LyNbxSEhPPXODPL+KB0VPk86UYfL0lMdy+KCnv+fmvIzySwaK5COwqVbWTQ== dependencies: safer-buffer "~2.1.0" assert-plus@1.0.0, assert-plus@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" + resolved "https://registry.npmmirror.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525" integrity sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw== astral-regex@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/astral-regex/-/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31" + resolved "https://registry.npmmirror.com/astral-regex/-/astral-regex-2.0.0.tgz#483143c567aeed4785759c0865786dc77d7d2e31" integrity sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ== async-exit-hook@^2.0.1: version "2.0.1" - resolved "https://registry.yarnpkg.com/async-exit-hook/-/async-exit-hook-2.0.1.tgz#8bd8b024b0ec9b1c01cccb9af9db29bd717dfaf3" + resolved "https://registry.npmmirror.com/async-exit-hook/-/async-exit-hook-2.0.1.tgz#8bd8b024b0ec9b1c01cccb9af9db29bd717dfaf3" integrity sha512-NW2cX8m1Q7KPA7a5M2ULQeZ2wR5qI5PAbw5L0UOMxdioVk9PMZ0h1TmyZEkPYrCvYjDlFICusOu1dlEKAAeXBw== -async@^2.6.4: - version "2.6.4" - resolved "https://registry.yarnpkg.com/async/-/async-2.6.4.tgz#706b7ff6084664cd7eae713f6f965433b5504221" - integrity sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA== - dependencies: - lodash "^4.17.14" +async-validator@^4.2.5: + version "4.2.5" + resolved "https://registry.npmmirror.com/async-validator/-/async-validator-4.2.5.tgz#c96ea3332a521699d0afaaceed510a54656c6339" + integrity sha512-7HhHjtERjqlNbZtqNqy2rckN/SpOOlmDliet+lP7k+eKZEjPk3DgyeU9lIXLdeLz0uBbbVp+9Qdow9wJWgwwfg== async@^3.2.3: version "3.2.4" - resolved "https://registry.yarnpkg.com/async/-/async-3.2.4.tgz#2d22e00f8cddeb5fde5dd33522b56d1cf569a81c" + resolved "https://registry.npmmirror.com/async/-/async-3.2.4.tgz#2d22e00f8cddeb5fde5dd33522b56d1cf569a81c" integrity sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ== asynckit@^0.4.0: version "0.4.0" - resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" + resolved "https://registry.npmmirror.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== at-least-node@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/at-least-node/-/at-least-node-1.0.0.tgz#602cd4b46e844ad4effc92a8011a3c46e0238dc2" + resolved "https://registry.npmmirror.com/at-least-node/-/at-least-node-1.0.0.tgz#602cd4b46e844ad4effc92a8011a3c46e0238dc2" integrity sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg== atomically@^1.7.0: version "1.7.0" - resolved "https://registry.yarnpkg.com/atomically/-/atomically-1.7.0.tgz#c07a0458432ea6dbc9a3506fffa424b48bccaafe" + resolved "https://registry.npmmirror.com/atomically/-/atomically-1.7.0.tgz#c07a0458432ea6dbc9a3506fffa424b48bccaafe" integrity sha512-Xcz9l0z7y9yQ9rdDaxlmaI4uJHf/T8g9hOEzJcsEqX2SjCj4J20uK7+ldkDHMbpJDK76wF7xEIgxc/vSlsfw5w== -autoprefixer@^10.2.4, autoprefixer@^10.4.8: - version "10.4.12" - resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-10.4.12.tgz#183f30bf0b0722af54ee5ef257f7d4320bb33129" - integrity sha512-WrCGV9/b97Pa+jtwf5UGaRjgQIg7OK3D06GnoYoZNcG1Xb8Gt3EfuKjlhh9i/VtT16g6PYjZ69jdJ2g8FxSC4Q== +autoprefixer@^10.4.16: + version "10.4.16" + resolved "https://registry.npmmirror.com/autoprefixer/-/autoprefixer-10.4.16.tgz#fad1411024d8670880bdece3970aa72e3572feb8" + integrity sha512-7vd3UC6xKp0HLfua5IjZlcXvGAGy7cBAXTg2lyQ/8WpNhd6SiZ8Be+xm3FyBSYJx5GKcpRCzBh7RH4/0dnY+uQ== dependencies: - browserslist "^4.21.4" - caniuse-lite "^1.0.30001407" - fraction.js "^4.2.0" + browserslist "^4.21.10" + caniuse-lite "^1.0.30001538" + fraction.js "^4.3.6" normalize-range "^0.1.2" picocolors "^1.0.0" postcss-value-parser "^4.2.0" -await-handler@^1.1.0: - version "1.1.2" - resolved "https://registry.yarnpkg.com/await-handler/-/await-handler-1.1.2.tgz#329c19e9382599898bc12c80c47efdcdaa1b4992" - integrity sha512-dihteGhwbJpT89kVbacWiyKeAZr+En0YGK6pAKQJLR0En9ZxSH2H4TTvfG4bBjzFq9gDAma4y9BrpDns6j5UiQ== - aws-sign2@~0.7.0: version "0.7.0" - resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8" + resolved "https://registry.npmmirror.com/aws-sign2/-/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8" integrity sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA== aws4@^1.8.0: version "1.12.0" - resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.12.0.tgz#ce1c9d143389679e253b314241ea9aa5cec980d3" + resolved "https://registry.npmmirror.com/aws4/-/aws4-1.12.0.tgz#ce1c9d143389679e253b314241ea9aa5cec980d3" integrity sha512-NmWvPnx0F1SfrQbYwOi7OeaNGokp9XhzNioJ/CSBs8Qa4vxug81mhJEAVZwxXuBmYB5KDRfMq/F3RR0BIU7sWg== -babel-loader@^8.2.2: - version "8.2.5" - resolved "https://registry.yarnpkg.com/babel-loader/-/babel-loader-8.2.5.tgz#d45f585e654d5a5d90f5350a779d7647c5ed512e" - integrity sha512-OSiFfH89LrEMiWd4pLNqGz4CwJDtbs2ZVc+iGu2HrkRfPxId9F2anQj38IxWpmRfsUY0aBZYi1EFcd3mhtRMLQ== - dependencies: - find-cache-dir "^3.3.1" - loader-utils "^2.0.0" - make-dir "^3.1.0" - schema-utils "^2.6.5" - -babel-plugin-dynamic-import-node@^2.3.3: - version "2.3.3" - resolved "https://registry.yarnpkg.com/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz#84fda19c976ec5c6defef57f9427b3def66e17a3" - integrity sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ== - dependencies: - object.assign "^4.1.0" - -babel-plugin-polyfill-corejs2@^0.3.3: - version "0.3.3" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.3.tgz#5d1bd3836d0a19e1b84bbf2d9640ccb6f951c122" - integrity sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q== - dependencies: - "@babel/compat-data" "^7.17.7" - "@babel/helper-define-polyfill-provider" "^0.3.3" - semver "^6.1.1" - -babel-plugin-polyfill-corejs3@^0.6.0: - version "0.6.0" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.6.0.tgz#56ad88237137eade485a71b52f72dbed57c6230a" - integrity sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA== - dependencies: - "@babel/helper-define-polyfill-provider" "^0.3.3" - core-js-compat "^3.25.1" - -babel-plugin-polyfill-regenerator@^0.4.1: - version "0.4.1" - resolved "https://registry.yarnpkg.com/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.4.1.tgz#390f91c38d90473592ed43351e801a9d3e0fd747" - integrity sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw== - dependencies: - "@babel/helper-define-polyfill-provider" "^0.3.3" - balanced-match@^1.0.0: version "1.0.2" - resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" + resolved "https://registry.npmmirror.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== base64-js@^1.3.1, base64-js@^1.5.1: version "1.5.1" - resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" + resolved "https://registry.npmmirror.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== -batch@0.6.1: - version "0.6.1" - resolved "https://registry.yarnpkg.com/batch/-/batch-0.6.1.tgz#dc34314f4e679318093fc760272525f94bf25c16" - integrity sha512-x+VAiMRL6UPkx+kudNvxTl6hB2XNNCG2r+7wixVfIYwu/2HKRXimwQyaumLjMveWvT2Hkd/cAJw+QBMfJ/EKVw== - bcrypt-pbkdf@^1.0.0: version "1.0.2" - resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz#a4301d389b6a43f9b67ff3ca11a3f6637e360e9e" + resolved "https://registry.npmmirror.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz#a4301d389b6a43f9b67ff3ca11a3f6637e360e9e" integrity sha512-qeFIXtP4MSoi6NLqO12WfqARWWuCKi2Rn/9hJLEmtB5yTNr9DqFWkJRCf2qShWzPeAMRnOgCrq0sg/KLv5ES9w== dependencies: tweetnacl "^0.14.3" -big.js@^5.2.2: - version "5.2.2" - resolved "https://registry.yarnpkg.com/big.js/-/big.js-5.2.2.tgz#65f0af382f578bcdc742bd9c281e9cb2d7768328" - integrity sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ== +better-sqlite3-multiple-ciphers@^9.0.0: + version "9.0.0" + resolved "https://registry.npmmirror.com/better-sqlite3-multiple-ciphers/-/better-sqlite3-multiple-ciphers-9.0.0.tgz#ce6f10dd5950a508c2bd1596e2863fd5faa3b0bc" + integrity sha512-bM0gv20exF1X1Q8/Rz0PasxCYcgb8VIbQKOhYe3Js35uFAmrvnX8AUqW6c/eq+i8WRtAoRw4yAOBs5Nxx7qaXw== + dependencies: + bindings "^1.5.0" + prebuild-install "^7.1.1" binary-extensions@^2.0.0: version "2.2.0" - resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" + resolved "https://registry.npmmirror.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== bindings@^1.5.0: version "1.5.0" - resolved "https://registry.yarnpkg.com/bindings/-/bindings-1.5.0.tgz#10353c9e945334bc0511a6d90b38fbc7c9c504df" + resolved "https://registry.npmmirror.com/bindings/-/bindings-1.5.0.tgz#10353c9e945334bc0511a6d90b38fbc7c9c504df" integrity sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ== dependencies: file-uri-to-path "1.0.0" -bl@^4.1.0: +bl@^4.0.3: version "4.1.0" - resolved "https://registry.yarnpkg.com/bl/-/bl-4.1.0.tgz#451535264182bec2fbbc83a62ab98cf11d9f7b3a" + resolved "https://registry.npmmirror.com/bl/-/bl-4.1.0.tgz#451535264182bec2fbbc83a62ab98cf11d9f7b3a" integrity sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w== dependencies: buffer "^5.5.0" @@ -2794,76 +865,29 @@ bl@^4.1.0: bluebird-lst@^1.0.9: version "1.0.9" - resolved "https://registry.yarnpkg.com/bluebird-lst/-/bluebird-lst-1.0.9.tgz#a64a0e4365658b9ab5fe875eb9dfb694189bb41c" + resolved "https://registry.npmmirror.com/bluebird-lst/-/bluebird-lst-1.0.9.tgz#a64a0e4365658b9ab5fe875eb9dfb694189bb41c" integrity sha512-7B1Rtx82hjnSD4PGLAjVWeYH3tHAcVUmChh85a3lltKQm6FresXh9ErQo6oAv6CqxttczC3/kEg8SY5NluPuUw== dependencies: bluebird "^3.5.5" -bluebird@^3.1.1, bluebird@^3.5.0, bluebird@^3.5.5: +bluebird@^3.5.5: version "3.7.2" - resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.7.2.tgz#9f229c15be272454ffa973ace0dbee79a1b0c36f" + resolved "https://registry.npmmirror.com/bluebird/-/bluebird-3.7.2.tgz#9f229c15be272454ffa973ace0dbee79a1b0c36f" integrity sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg== -bmp-js@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/bmp-js/-/bmp-js-0.1.0.tgz#e05a63f796a6c1ff25f4771ec7adadc148c07233" - integrity sha512-vHdS19CnY3hwiNdkaqk93DvjVLfbEcI8mys4UjuWrlX1haDmroo8o4xCzh4wD6DGV6HxRCyauwhHRqMTfERtjw== - -body-parser@1.20.0: - version "1.20.0" - resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.20.0.tgz#3de69bd89011c11573d7bfee6a64f11b6bd27cc5" - integrity sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg== - dependencies: - bytes "3.1.2" - content-type "~1.0.4" - debug "2.6.9" - depd "2.0.0" - destroy "1.2.0" - http-errors "2.0.0" - iconv-lite "0.4.24" - on-finished "2.4.1" - qs "6.10.3" - raw-body "2.5.1" - type-is "~1.6.18" - unpipe "1.0.0" - -bonjour-service@^1.0.11: - version "1.0.14" - resolved "https://registry.yarnpkg.com/bonjour-service/-/bonjour-service-1.0.14.tgz#c346f5bc84e87802d08f8d5a60b93f758e514ee7" - integrity sha512-HIMbgLnk1Vqvs6B4Wq5ep7mxvj9sGz5d1JJyDNSGNIdA/w2MCz6GTjWTdjqOJV1bEPj+6IkxDvWNFKEBxNt4kQ== - dependencies: - array-flatten "^2.1.2" - dns-equal "^1.0.0" - fast-deep-equal "^3.1.3" - multicast-dns "^7.2.5" - boolbase@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e" + resolved "https://registry.npmmirror.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e" integrity sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww== boolean@^3.0.1: version "3.2.0" - resolved "https://registry.yarnpkg.com/boolean/-/boolean-3.2.0.tgz#9e5294af4e98314494cbb17979fa54ca159f116b" + resolved "https://registry.npmmirror.com/boolean/-/boolean-3.2.0.tgz#9e5294af4e98314494cbb17979fa54ca159f116b" integrity sha512-d0II/GO9uf9lfUHH2BQsjxzRJZBdsjgsBiW4BvhWk/3qoKwQFjIDVN19PfX8F2D/r9PCMTtLWjYVCFrpeYUzsw== -boxen@^5.0.0: - version "5.1.2" - resolved "https://registry.yarnpkg.com/boxen/-/boxen-5.1.2.tgz#788cb686fc83c1f486dfa8a40c68fc2b831d2b50" - integrity sha512-9gYgQKXx+1nP8mP7CzFyaUARhg7D3n1dF/FnErWmu9l6JvGpNUN278h0aSb+QjoiKSWG+iZ3uHrcqk0qrY9RQQ== - dependencies: - ansi-align "^3.0.0" - camelcase "^6.2.0" - chalk "^4.1.0" - cli-boxes "^2.2.1" - string-width "^4.2.2" - type-fest "^0.20.2" - widest-line "^3.1.0" - wrap-ansi "^7.0.0" - brace-expansion@^1.1.7: version "1.1.11" - resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" + resolved "https://registry.npmmirror.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== dependencies: balanced-match "^1.0.0" @@ -2871,122 +895,63 @@ brace-expansion@^1.1.7: brace-expansion@^2.0.1: version "2.0.1" - resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" + resolved "https://registry.npmmirror.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" integrity sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA== dependencies: balanced-match "^1.0.0" braces@^3.0.2, braces@~3.0.2: version "3.0.2" - resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" + resolved "https://registry.npmmirror.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== dependencies: fill-range "^7.0.1" -browserslist@^4.0.0, browserslist@^4.14.5, browserslist@^4.16.3, browserslist@^4.16.6, browserslist@^4.20.3, browserslist@^4.21.3, browserslist@^4.21.4: - version "4.21.4" - resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.21.4.tgz#e7496bbc67b9e39dd0f98565feccdcb0d4ff6987" - integrity sha512-CBHJJdDmgjl3daYjN5Cp5kbTf1mUhZoS+beLklHIvkOWscs83YAhLlF3Wsh/lciQYAcbBJgTOD44VtG31ZM4Hw== +browserslist@^4.21.10: + version "4.22.1" + resolved "https://registry.npmmirror.com/browserslist/-/browserslist-4.22.1.tgz#ba91958d1a59b87dab6fed8dfbcb3da5e2e9c619" + integrity sha512-FEVc202+2iuClEhZhrWy6ZiAcRLvNMyYcxZ8raemul1DYVOVdFsbqckWLdsixQZCpJlwe77Z3UTalE7jsjnKfQ== dependencies: - caniuse-lite "^1.0.30001400" - electron-to-chromium "^1.4.251" - node-releases "^2.0.6" - update-browserslist-db "^1.0.9" - -buffer-alloc-unsafe@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/buffer-alloc-unsafe/-/buffer-alloc-unsafe-1.1.0.tgz#bd7dc26ae2972d0eda253be061dba992349c19f0" - integrity sha512-TEM2iMIEQdJ2yjPJoSIsldnleVaAk1oW3DBVUykyOLsEsFmEc9kn+SFFPz+gl54KQNxlDnAwCXosOS9Okx2xAg== - -buffer-alloc@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/buffer-alloc/-/buffer-alloc-1.2.0.tgz#890dd90d923a873e08e10e5fd51a57e5b7cce0ec" - integrity sha512-CFsHQgjtW1UChdXgbyJGtnm+O/uLQeZdtbDo8mfUgYXCHSM1wgrVxXm6bSyrUuErEb+4sYVGCzASBRot7zyrow== - dependencies: - buffer-alloc-unsafe "^1.1.0" - buffer-fill "^1.0.0" + caniuse-lite "^1.0.30001541" + electron-to-chromium "^1.4.535" + node-releases "^2.0.13" + update-browserslist-db "^1.0.13" buffer-crc32@~0.2.3: version "0.2.13" - resolved "https://registry.yarnpkg.com/buffer-crc32/-/buffer-crc32-0.2.13.tgz#0d333e3f00eac50aa1454abd30ef8c2a5d9a7242" + resolved "https://registry.npmmirror.com/buffer-crc32/-/buffer-crc32-0.2.13.tgz#0d333e3f00eac50aa1454abd30ef8c2a5d9a7242" integrity sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ== -buffer-equal@0.0.1: - version "0.0.1" - resolved "https://registry.yarnpkg.com/buffer-equal/-/buffer-equal-0.0.1.tgz#91bc74b11ea405bc916bc6aa908faafa5b4aac4b" - integrity sha512-RgSV6InVQ9ODPdLWJ5UAqBqJBOg370Nz6ZQtRzpt6nUjc8v0St97uJ4PYC6NztqIScrAXafKM3mZPMygSe1ggA== - -buffer-equal@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/buffer-equal/-/buffer-equal-1.0.0.tgz#59616b498304d556abd466966b22eeda3eca5fbe" - integrity sha512-tcBWO2Dl4e7Asr9hTGcpVrCe+F7DubpmqWCTbj4FHLmjqO2hIaC383acQubWtRJhdceqs5uBHs6Es+Sk//RKiQ== - buffer-equal@^1.0.0: version "1.0.1" - resolved "https://registry.yarnpkg.com/buffer-equal/-/buffer-equal-1.0.1.tgz#2f7651be5b1b3f057fcd6e7ee16cf34767077d90" + resolved "https://registry.npmmirror.com/buffer-equal/-/buffer-equal-1.0.1.tgz#2f7651be5b1b3f057fcd6e7ee16cf34767077d90" integrity sha512-QoV3ptgEaQpvVwbXdSO39iqPQTCxSF7A5U99AxbHYqUdCizL/lH2Z0A2y6nbZucxMEOtNyZfG2s6gsVugGpKkg== -buffer-fill@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/buffer-fill/-/buffer-fill-1.0.0.tgz#f8f78b76789888ef39f205cd637f68e702122b2c" - integrity sha512-T7zexNBwiiaCOGDg9xNX9PBmjrubblRkENuptryuI64URkXDFum9il/JGL8Lm8wYfAXpredVXXZz7eMHilimiQ== - buffer-from@^1.0.0: version "1.1.2" - resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" + resolved "https://registry.npmmirror.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== -buffer@^5.1.0, buffer@^5.2.0, buffer@^5.5.0: +buffer@^5.1.0, buffer@^5.5.0: version "5.7.1" - resolved "https://registry.yarnpkg.com/buffer/-/buffer-5.7.1.tgz#ba62e7c13133053582197160851a8f648e99eed0" + resolved "https://registry.npmmirror.com/buffer/-/buffer-5.7.1.tgz#ba62e7c13133053582197160851a8f648e99eed0" integrity sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ== dependencies: base64-js "^1.3.1" ieee754 "^1.1.13" -builder-util-runtime@8.9.2: - version "8.9.2" - resolved "https://registry.yarnpkg.com/builder-util-runtime/-/builder-util-runtime-8.9.2.tgz#a9669ae5b5dcabfe411ded26678e7ae997246c28" - integrity sha512-rhuKm5vh7E0aAmT6i8aoSfEjxzdYEFX7zDApK+eNgOhjofnWb74d9SRJv0H/8nsgOkos0TZ4zxW0P8J4N7xQ2A== - dependencies: - debug "^4.3.2" - sax "^1.2.4" - builder-util-runtime@9.2.1: version "9.2.1" - resolved "https://registry.yarnpkg.com/builder-util-runtime/-/builder-util-runtime-9.2.1.tgz#3184dcdf7ed6c47afb8df733813224ced4f624fd" + resolved "https://registry.npmmirror.com/builder-util-runtime/-/builder-util-runtime-9.2.1.tgz#3184dcdf7ed6c47afb8df733813224ced4f624fd" integrity sha512-2rLv/uQD2x+dJ0J3xtsmI12AlRyk7p45TEbE/6o/fbb633e/S3pPgm+ct+JHsoY7r39dKHnGEFk/AASRFdnXmA== dependencies: debug "^4.3.4" sax "^1.2.4" -builder-util@22.14.13: - version "22.14.13" - resolved "https://registry.yarnpkg.com/builder-util/-/builder-util-22.14.13.tgz#41b5b7b4ee53aff4e09cc007fb144522598f3ce6" - integrity sha512-oePC/qrrUuerhmH5iaCJzPRAKlSBylrhzuAJmRQClTyWnZUv6jbaHh+VoHMbEiE661wrj2S2aV7/bQh12cj1OA== - dependencies: - "7zip-bin" "~5.1.1" - "@types/debug" "^4.1.6" - "@types/fs-extra" "^9.0.11" - app-builder-bin "3.7.1" - bluebird-lst "^1.0.9" - builder-util-runtime "8.9.2" - chalk "^4.1.1" - cross-spawn "^7.0.3" - debug "^4.3.2" - fs-extra "^10.0.0" - http-proxy-agent "^5.0.0" - https-proxy-agent "^5.0.0" - is-ci "^3.0.0" - js-yaml "^4.1.0" - source-map-support "^0.5.19" - stat-mode "^1.0.0" - temp-file "^3.4.0" - -builder-util@24.4.0: - version "24.4.0" - resolved "https://registry.yarnpkg.com/builder-util/-/builder-util-24.4.0.tgz#dbb201a118fd573180e6a1070cf4c0be6de80cd7" - integrity sha512-tONb/GIK1MKa1BcOPHE1naId3o5nj6gdka5kP7yUJh2DOfF+jMq3laiu+UOZH6A7ZtkMtnGNMYFKFTIv408n/A== +builder-util@24.5.0: + version "24.5.0" + resolved "https://registry.npmmirror.com/builder-util/-/builder-util-24.5.0.tgz#8683c9a7a1c5c9f9a4c4d2789ecca0e47dddd3f9" + integrity sha512-STnBmZN/M5vGcv01u/K8l+H+kplTaq4PAIn3yeuufUKSpcdro0DhJWxPI81k5XcNfC//bjM3+n9nr8F9uV4uAQ== dependencies: "7zip-bin" "~5.1.1" "@types/debug" "^4.1.6" @@ -3005,62 +970,15 @@ builder-util@24.4.0: stat-mode "^1.0.0" temp-file "^3.4.0" -bytes@3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.0.0.tgz#d32815404d689699f85a4ea4fa8755dd13a96048" - integrity sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw== - -bytes@3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" - integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== - -cacache@^16.1.0: - version "16.1.3" - resolved "https://registry.yarnpkg.com/cacache/-/cacache-16.1.3.tgz#a02b9f34ecfaf9a78c9f4bc16fceb94d5d67a38e" - integrity sha512-/+Emcj9DAXxX4cwlLmRI9c166RuL3w30zp4R7Joiv2cQTtTtA+jeuCAjH3ZlGnYS3tKENSrKhAzVVP9GVyzeYQ== - dependencies: - "@npmcli/fs" "^2.1.0" - "@npmcli/move-file" "^2.0.0" - chownr "^2.0.0" - fs-minipass "^2.1.0" - glob "^8.0.1" - infer-owner "^1.0.4" - lru-cache "^7.7.1" - minipass "^3.1.6" - minipass-collect "^1.0.2" - minipass-flush "^1.0.5" - minipass-pipeline "^1.2.4" - mkdirp "^1.0.4" - p-map "^4.0.0" - promise-inflight "^1.0.1" - rimraf "^3.0.2" - ssri "^9.0.0" - tar "^6.1.11" - unique-filename "^2.0.0" - cacheable-lookup@^5.0.3: version "5.0.4" - resolved "https://registry.yarnpkg.com/cacheable-lookup/-/cacheable-lookup-5.0.4.tgz#5a6b865b2c44357be3d5ebc2a467b032719a7005" + resolved "https://registry.npmmirror.com/cacheable-lookup/-/cacheable-lookup-5.0.4.tgz#5a6b865b2c44357be3d5ebc2a467b032719a7005" integrity sha512-2/kNscPhpcxrOigMZzbiWF7dz8ilhb/nIHU3EyZiXWXpeq/au8qJ8VhdftMkty3n7Gj6HIGalQG8oiBNB3AJgA== -cacheable-request@^6.0.0: - version "6.1.0" - resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-6.1.0.tgz#20ffb8bd162ba4be11e9567d823db651052ca912" - integrity sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg== - dependencies: - clone-response "^1.0.2" - get-stream "^5.1.0" - http-cache-semantics "^4.0.0" - keyv "^3.0.0" - lowercase-keys "^2.0.0" - normalize-url "^4.1.0" - responselike "^1.0.2" - cacheable-request@^7.0.2: - version "7.0.2" - resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-7.0.2.tgz#ea0d0b889364a25854757301ca12b2da77f91d27" - integrity sha512-pouW8/FmiPQbuGpkXQ9BAPv/Mo5xDGANgSNXzTzJ8DrKGuXOssM4wIQRjfanNRh3Yu5cfYPvcorqbhg2KIJtew== + version "7.0.4" + resolved "https://registry.npmmirror.com/cacheable-request/-/cacheable-request-7.0.4.tgz#7a33ebf08613178b403635be7b899d3e69bbe817" + integrity sha512-v+p6ongsrp0yTGbJXjgxPow2+DL93DASP4kXCDKb8/bwRtt9OEF3whggkkDkGNzgcWy2XaF4a8nZglC7uElscg== dependencies: clone-response "^1.0.2" get-stream "^5.1.0" @@ -3070,92 +988,29 @@ cacheable-request@^7.0.2: normalize-url "^6.0.1" responselike "^2.0.0" -call-bind@^1.0.0, call-bind@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" - integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== - dependencies: - function-bind "^1.1.1" - get-intrinsic "^1.0.2" - -callsites@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" - integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== - -camel-case@^4.1.2: - version "4.1.2" - resolved "https://registry.yarnpkg.com/camel-case/-/camel-case-4.1.2.tgz#9728072a954f805228225a6deea6b38461e1bd5a" - integrity sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw== - dependencies: - pascal-case "^3.1.2" - tslib "^2.0.3" - camelcase-css@^2.0.1: version "2.0.1" - resolved "https://registry.yarnpkg.com/camelcase-css/-/camelcase-css-2.0.1.tgz#ee978f6947914cc30c6b44741b6ed1df7f043fd5" + resolved "https://registry.npmmirror.com/camelcase-css/-/camelcase-css-2.0.1.tgz#ee978f6947914cc30c6b44741b6ed1df7f043fd5" integrity sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA== -camelcase@^5.0.0: - version "5.3.1" - resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" - integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== - -camelcase@^6.0.0, camelcase@^6.2.0: - version "6.3.0" - resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.3.0.tgz#5685b95eb209ac9c0c177467778c9c84df58ba9a" - integrity sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA== - can-use-dom@^0.1.0: version "0.1.0" - resolved "https://registry.yarnpkg.com/can-use-dom/-/can-use-dom-0.1.0.tgz#22cc4a34a0abc43950f42c6411024a3f6366b45a" + resolved "https://registry.npmmirror.com/can-use-dom/-/can-use-dom-0.1.0.tgz#22cc4a34a0abc43950f42c6411024a3f6366b45a" integrity sha512-ceOhN1DL7Y4O6M0j9ICgmTYziV89WMd96SvSl0REd8PMgrY0B/WBOPoed5S1KUmJqXgUXh8gzSe6E3ae27upsQ== -caniuse-api@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/caniuse-api/-/caniuse-api-3.0.0.tgz#5e4d90e2274961d46291997df599e3ed008ee4c0" - integrity sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw== - dependencies: - browserslist "^4.0.0" - caniuse-lite "^1.0.0" - lodash.memoize "^4.1.2" - lodash.uniq "^4.5.0" - -caniuse-lite@^1.0.0, caniuse-lite@^1.0.30001400, caniuse-lite@^1.0.30001407: - version "1.0.30001407" - resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001407.tgz#92281a6ee67cb90bfd8a6a1201fcc2dc19b60a15" - integrity sha512-4ydV+t4P7X3zH83fQWNDX/mQEzYomossfpViCOx9zHBSMV+rIe3LFqglHHtVyvNl1FhTNxPxs3jei82iqOW04w== - -case-sensitive-paths-webpack-plugin@^2.3.0: - version "2.4.0" - resolved "https://registry.yarnpkg.com/case-sensitive-paths-webpack-plugin/-/case-sensitive-paths-webpack-plugin-2.4.0.tgz#db64066c6422eed2e08cc14b986ca43796dbc6d4" - integrity sha512-roIFONhcxog0JSSWbvVAh3OocukmSgpqOH6YpMkCvav/ySIV3JKg4Dc8vYtQjYi/UxpNE36r/9v+VqTQqgkYmw== +caniuse-lite@^1.0.30001538, caniuse-lite@^1.0.30001541: + version "1.0.30001558" + resolved "https://registry.npmmirror.com/caniuse-lite/-/caniuse-lite-1.0.30001558.tgz#d2c6e21fdbfe83817f70feab902421a19b7983ee" + integrity sha512-/Et7DwLqpjS47JPEcz6VnxU9PwcIdVi0ciLXRWBQdj1XFye68pSQYpV0QtPTfUKWuOaEig+/Vez2l74eDc1tPQ== caseless@~0.12.0: version "0.12.0" - resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" + resolved "https://registry.npmmirror.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" integrity sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw== -chalk@^2.0.0, chalk@^2.0.1, chalk@^2.1.0, chalk@^2.3.1, chalk@^2.4.1: - version "2.4.2" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" - integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== - dependencies: - ansi-styles "^3.2.1" - escape-string-regexp "^1.0.5" - supports-color "^5.3.0" - -chalk@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4" - integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg== - dependencies: - ansi-styles "^4.1.0" - supports-color "^7.1.0" - -chalk@^4.0.0, chalk@^4.0.2, chalk@^4.1.0, chalk@^4.1.1, chalk@^4.1.2: +chalk@^4.0.2, chalk@^4.1.2: version "4.1.2" - resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" + resolved "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== dependencies: ansi-styles "^4.1.0" @@ -3163,7 +1018,7 @@ chalk@^4.0.0, chalk@^4.0.2, chalk@^4.1.0, chalk@^4.1.1, chalk@^4.1.2: cheerio-select@^2.1.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/cheerio-select/-/cheerio-select-2.1.0.tgz#4d8673286b8126ca2a8e42740d5e3c4884ae21b4" + resolved "https://registry.npmmirror.com/cheerio-select/-/cheerio-select-2.1.0.tgz#4d8673286b8126ca2a8e42740d5e3c4884ae21b4" integrity sha512-9v9kG0LvzrlcungtnJtpGNxY+fzECQKhK4EGJX2vByejiMX84MFNQw4UxPJl3bFbTMw+Dfs37XaIkCwTZfLh4g== dependencies: boolbase "^1.0.0" @@ -3173,9 +1028,9 @@ cheerio-select@^2.1.0: domhandler "^5.0.3" domutils "^3.0.1" -cheerio@^1.0.0-rc.12: +cheerio@1.0.0-rc.12: version "1.0.0-rc.12" - resolved "https://registry.yarnpkg.com/cheerio/-/cheerio-1.0.0-rc.12.tgz#788bf7466506b1c6bf5fae51d24a2c4d62e47683" + resolved "https://registry.npmmirror.com/cheerio/-/cheerio-1.0.0-rc.12.tgz#788bf7466506b1c6bf5fae51d24a2c4d62e47683" integrity sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q== dependencies: cheerio-select "^2.1.0" @@ -3186,9 +1041,9 @@ cheerio@^1.0.0-rc.12: parse5 "^7.0.0" parse5-htmlparser2-tree-adapter "^7.0.0" -chokidar@^3.0.2, chokidar@^3.5.3: +chokidar@^3.5.3: version "3.5.3" - resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd" + resolved "https://registry.npmmirror.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd" integrity sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw== dependencies: anymatch "~3.1.2" @@ -3201,256 +1056,97 @@ chokidar@^3.0.2, chokidar@^3.5.3: optionalDependencies: fsevents "~2.3.2" +chownr@^1.1.1: + version "1.1.4" + resolved "https://registry.npmmirror.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" + integrity sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg== + chownr@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" + resolved "https://registry.npmmirror.com/chownr/-/chownr-2.0.0.tgz#15bfbe53d2eab4cf70f18a8cd68ebe5b3cb1dece" integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== -chrome-trace-event@^1.0.2: - version "1.0.3" - resolved "https://registry.yarnpkg.com/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz#1015eced4741e15d06664a957dbbf50d041e26ac" - integrity sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg== - chromium-pickle-js@^0.2.0: version "0.2.0" - resolved "https://registry.yarnpkg.com/chromium-pickle-js/-/chromium-pickle-js-0.2.0.tgz#04a106672c18b085ab774d983dfa3ea138f22205" + resolved "https://registry.npmmirror.com/chromium-pickle-js/-/chromium-pickle-js-0.2.0.tgz#04a106672c18b085ab774d983dfa3ea138f22205" integrity sha512-1R5Fho+jBq0DDydt+/vHWj5KJNJCKdARKOCwZUen84I5BreWoLqRLANH1U87eJy1tiASPtMnGqJJq0ZsLoRPOw== -ci-info@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" - integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== - ci-info@^3.2.0: - version "3.4.0" - resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-3.4.0.tgz#b28484fd436cbc267900364f096c9dc185efb251" - integrity sha512-t5QdPT5jq3o262DOQ8zA6E1tlH2upmUc4Hlvrbx1pGYJuiiHl7O7rvVNI+l8HTVhd/q3Qc9vqimkNk5yiXsAug== - -clean-css@^5.2.2: - version "5.3.1" - resolved "https://registry.yarnpkg.com/clean-css/-/clean-css-5.3.1.tgz#d0610b0b90d125196a2894d35366f734e5d7aa32" - integrity sha512-lCr8OHhiWCTw4v8POJovCoh4T7I9U11yVsPjMWWnnMmp9ZowCxyad1Pathle/9HjaDp+fdQKjO9fQydE6RHTZg== - dependencies: - source-map "~0.6.0" - -clean-stack@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" - integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== - -cli-boxes@^2.2.1: - version "2.2.1" - resolved "https://registry.yarnpkg.com/cli-boxes/-/cli-boxes-2.2.1.tgz#ddd5035d25094fce220e9cab40a45840a440318f" - integrity sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw== - -cli-cursor@^2.0.0, cli-cursor@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-2.1.0.tgz#b35dac376479facc3e94747d41d0d0f5238ffcb5" - integrity sha512-8lgKz8LmCRYZZQDpRyT2m5rKJ08TnU4tR9FFFW2rxpxR1FzWi4PQ/NfyODchAatHaUgnSPVcx/R5w6NuTBzFiw== - dependencies: - restore-cursor "^2.0.0" - -cli-cursor@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/cli-cursor/-/cli-cursor-3.1.0.tgz#264305a7ae490d1d03bf0c9ba7c925d1753af307" - integrity sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw== - dependencies: - restore-cursor "^3.1.0" - -cli-highlight@^2.1.10: - version "2.1.11" - resolved "https://registry.yarnpkg.com/cli-highlight/-/cli-highlight-2.1.11.tgz#49736fa452f0aaf4fae580e30acb26828d2dc1bf" - integrity sha512-9KDcoEVwyUXrjcJNvHD0NFc/hiwe/WPVYIleQh2O1N2Zro5gWJZ/K+3DGn8w8P/F6FxOgzyC5bxDyHIgCSPhGg== - dependencies: - chalk "^4.0.0" - highlight.js "^10.7.1" - mz "^2.4.0" - parse5 "^5.1.1" - parse5-htmlparser2-tree-adapter "^6.0.0" - yargs "^16.0.0" - -cli-spinners@^1.1.0: - version "1.3.1" - resolved "https://registry.yarnpkg.com/cli-spinners/-/cli-spinners-1.3.1.tgz#002c1990912d0d59580c93bd36c056de99e4259a" - integrity sha512-1QL4544moEsDVH9T/l6Cemov/37iv1RtoKf7NJ04A60+4MREXNfx/QvavbH6QoGdsD4N4Mwy49cmaINR/o2mdg== - -cli-spinners@^2.5.0: - version "2.7.0" - resolved "https://registry.yarnpkg.com/cli-spinners/-/cli-spinners-2.7.0.tgz#f815fd30b5f9eaac02db604c7a231ed7cb2f797a" - integrity sha512-qu3pN8Y3qHNgE2AFweciB1IfMnmZ/fsNTEE+NOFjmGB2F/7rLhnhzppvpCnN4FovtP26k8lHyy9ptEbNwWFLzw== + version "3.9.0" + resolved "https://registry.npmmirror.com/ci-info/-/ci-info-3.9.0.tgz#4279a62028a7b1f262f3473fc9605f5e218c59b4" + integrity sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ== cli-truncate@^2.1.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/cli-truncate/-/cli-truncate-2.1.0.tgz#c39e28bf05edcde5be3b98992a22deed5a2b93c7" + resolved "https://registry.npmmirror.com/cli-truncate/-/cli-truncate-2.1.0.tgz#c39e28bf05edcde5be3b98992a22deed5a2b93c7" integrity sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg== dependencies: slice-ansi "^3.0.0" string-width "^4.2.0" -clipboardy@^2.3.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/clipboardy/-/clipboardy-2.3.0.tgz#3c2903650c68e46a91b388985bc2774287dba290" - integrity sha512-mKhiIL2DrQIsuXMgBgnfEHOZOryC7kY7YO//TN6c63wlEm3NG5tz+YgY5rVi29KCmq/QQjKYvM7a19+MDOTHOQ== - dependencies: - arch "^2.1.1" - execa "^1.0.0" - is-wsl "^2.1.1" - -cliui@^7.0.2, cliui@^7.0.4: - version "7.0.4" - resolved "https://registry.yarnpkg.com/cliui/-/cliui-7.0.4.tgz#a0265ee655476fc807aea9df3df8df7783808b4f" - integrity sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ== - dependencies: - string-width "^4.2.0" - strip-ansi "^6.0.0" - wrap-ansi "^7.0.0" - cliui@^8.0.1: version "8.0.1" - resolved "https://registry.yarnpkg.com/cliui/-/cliui-8.0.1.tgz#0c04b075db02cbfe60dc8e6cf2f5486b1a3608aa" + resolved "https://registry.npmmirror.com/cliui/-/cliui-8.0.1.tgz#0c04b075db02cbfe60dc8e6cf2f5486b1a3608aa" integrity sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ== dependencies: string-width "^4.2.0" strip-ansi "^6.0.1" wrap-ansi "^7.0.0" -clone-deep@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/clone-deep/-/clone-deep-4.0.1.tgz#c19fd9bdbbf85942b4fd979c84dcf7d5f07c2387" - integrity sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ== - dependencies: - is-plain-object "^2.0.4" - kind-of "^6.0.2" - shallow-clone "^3.0.0" - clone-response@^1.0.2: version "1.0.3" - resolved "https://registry.yarnpkg.com/clone-response/-/clone-response-1.0.3.tgz#af2032aa47816399cf5f0a1d0db902f517abb8c3" + resolved "https://registry.npmmirror.com/clone-response/-/clone-response-1.0.3.tgz#af2032aa47816399cf5f0a1d0db902f517abb8c3" integrity sha512-ROoL94jJH2dUVML2Y/5PEDNaSHgeOdSDicUyS7izcF63G6sTc/FTjLub4b8Il9S8S0beOfYt0TaA5qvFK+w0wA== dependencies: mimic-response "^1.0.0" -clone@^1.0.2: - version "1.0.4" - resolved "https://registry.yarnpkg.com/clone/-/clone-1.0.4.tgz#da309cc263df15994c688ca902179ca3c7cd7c7e" - integrity sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg== - -color-convert@^1.9.0: - version "1.9.3" - resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" - integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== - dependencies: - color-name "1.1.3" - color-convert@^2.0.1: version "2.0.1" - resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" + resolved "https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== dependencies: color-name "~1.1.4" -color-name@1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" - integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== - -color-name@^1.1.4, color-name@~1.1.4: +color-name@~1.1.4: version "1.1.4" - resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" + resolved "https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== -color-support@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/color-support/-/color-support-1.1.3.tgz#93834379a1cc9a0c61f82f52f0d04322251bd5a2" - integrity sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg== - -colord@^2.9.1: - version "2.9.3" - resolved "https://registry.yarnpkg.com/colord/-/colord-2.9.3.tgz#4f8ce919de456f1d5c1c368c307fe20f3e59fb43" - integrity sha512-jeC1axXpnb0/2nn/Y1LPuLdgXBLH7aDcHu4KEKfqw3CUhX7ZpfBSlPKyqXE6btIgEzfWtrX3/tyBCaCvXvMkOw== - -colorette@^2.0.10: - version "2.0.19" - resolved "https://registry.yarnpkg.com/colorette/-/colorette-2.0.19.tgz#cdf044f47ad41a0f4b56b3a0d5b4e6e1a2d5a798" - integrity sha512-3tlv/dIP7FWvj3BsbHrGLJ6l/oKh1O3TcgBqMn+yyCagOxc23fyzDS6HypQbgxWbkpDnf52p1LuR4eWDQ/K9WQ== - -colors@1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/colors/-/colors-1.0.3.tgz#0433f44d809680fdeb60ed260f1b0c262e82a40b" - integrity sha512-pFGrxThWcWQ2MsAz6RtgeWe4NK2kUE1WfsrvvlctdII745EW9I0yflqhe7++M5LEc7bV2c/9/5zc8sFcpL0Drw== - combined-stream@^1.0.6, combined-stream@^1.0.8, combined-stream@~1.0.6: version "1.0.8" - resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" + resolved "https://registry.npmmirror.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== dependencies: delayed-stream "~1.0.0" -commander@2.9.0: - version "2.9.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-2.9.0.tgz#9c99094176e12240cb22d6c5146098400fe0f7d4" - integrity sha512-bmkUukX8wAOjHdN26xj5c4ctEV22TQ7dQYhSmuckKhToXrkUn0iIaolHdIxYYqD55nhpSPA9zPQ1yP57GdXP2A== - dependencies: - graceful-readlink ">= 1.0.0" - -commander@^2.20.0, commander@^2.9.0: - version "2.20.3" - resolved "https://registry.yarnpkg.com/commander/-/commander-2.20.3.tgz#fd485e84c03eb4881c20722ba48035e8531aeb33" - integrity sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ== +commander@^4.0.0: + version "4.1.1" + resolved "https://registry.npmmirror.com/commander/-/commander-4.1.1.tgz#9fd602bd936294e9e9ef46a3f4d6964044b18068" + integrity sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA== commander@^5.0.0: version "5.1.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-5.1.0.tgz#46abbd1652f8e059bddaef99bbdcb2ad9cf179ae" + resolved "https://registry.npmmirror.com/commander/-/commander-5.1.0.tgz#46abbd1652f8e059bddaef99bbdcb2ad9cf179ae" integrity sha512-P0CysNDQ7rtVw4QIQtm+MRxV66vKFSvlsQvGYXZWR3qFU0jlMKHZZZgw8e+8DSah4UDKMqnknRDQz+xuQXQ/Zg== -commander@^7.2.0: - version "7.2.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-7.2.0.tgz#a36cb57d0b501ce108e4d20559a150a391d97ab7" - integrity sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw== - -commander@^8.3.0: - version "8.3.0" - resolved "https://registry.yarnpkg.com/commander/-/commander-8.3.0.tgz#4837ea1b2da67b9c616a67afbb0fafee567bca66" - integrity sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww== - -commondir@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/commondir/-/commondir-1.0.1.tgz#ddd800da0c66127393cca5950ea968a3aaf1253b" - integrity sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg== - compare-version@^0.1.2: version "0.1.2" - resolved "https://registry.yarnpkg.com/compare-version/-/compare-version-0.1.2.tgz#0162ec2d9351f5ddd59a9202cba935366a725080" + resolved "https://registry.npmmirror.com/compare-version/-/compare-version-0.1.2.tgz#0162ec2d9351f5ddd59a9202cba935366a725080" integrity sha512-pJDh5/4wrEnXX/VWRZvruAGHkzKdr46z11OlTPN+VrATlWWhSKewNCJ1futCO5C7eJB3nPMFZA1LeYtcFboZ2A== -compressible@~2.0.16: - version "2.0.18" - resolved "https://registry.yarnpkg.com/compressible/-/compressible-2.0.18.tgz#af53cca6b070d4c3c0750fbd77286a6d7cc46fba" - integrity sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg== - dependencies: - mime-db ">= 1.43.0 < 2" - -compression@^1.7.4: - version "1.7.4" - resolved "https://registry.yarnpkg.com/compression/-/compression-1.7.4.tgz#95523eff170ca57c29a0ca41e6fe131f41e5bb8f" - integrity sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ== - dependencies: - accepts "~1.3.5" - bytes "3.0.0" - compressible "~2.0.16" - debug "2.6.9" - on-headers "~1.0.2" - safe-buffer "5.1.2" - vary "~1.1.2" +computeds@^0.0.1: + version "0.0.1" + resolved "https://registry.npmmirror.com/computeds/-/computeds-0.0.1.tgz#215b08a4ba3e08a11ff6eee5d6d8d7166a97ce2e" + integrity sha512-7CEBgcMjVmitjYo5q8JTJVra6X5mQ20uTThdK+0kR7UEaDrAWEQcRiBtWJzga4eRpP6afNwwLsX2SET2JhVB1Q== concat-map@0.0.1: version "0.0.1" - resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + resolved "https://registry.npmmirror.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== conf@^10.2.0: version "10.2.0" - resolved "https://registry.yarnpkg.com/conf/-/conf-10.2.0.tgz#838e757be963f1a2386dfe048a98f8f69f7b55d6" + resolved "https://registry.npmmirror.com/conf/-/conf-10.2.0.tgz#838e757be963f1a2386dfe048a98f8f69f7b55d6" integrity sha512-8fLl9F04EJqjSqH+QjITQfJF8BrOVaYr1jewVgSRAEWePfxT0sku4w2hrGQ60BC/TNLGQ2pgxNlTbWQmMPFvXg== dependencies: ajv "^8.6.3" @@ -3466,197 +1162,60 @@ conf@^10.2.0: config-file-ts@^0.2.4: version "0.2.4" - resolved "https://registry.yarnpkg.com/config-file-ts/-/config-file-ts-0.2.4.tgz#6c0741fbe118a7cf786c65f139030f0448a2cc99" + resolved "https://registry.npmmirror.com/config-file-ts/-/config-file-ts-0.2.4.tgz#6c0741fbe118a7cf786c65f139030f0448a2cc99" integrity sha512-cKSW0BfrSaAUnxpgvpXPLaaW/umg4bqg4k3GO1JqlRfpx+d5W0GDXznCMkWotJQek5Mmz1MJVChQnz3IVaeMZQ== dependencies: glob "^7.1.6" typescript "^4.0.2" -configstore@^5.0.1: - version "5.0.1" - resolved "https://registry.yarnpkg.com/configstore/-/configstore-5.0.1.tgz#d365021b5df4b98cdd187d6a3b0e3f6a7cc5ed96" - integrity sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA== +copy-anything@^2.0.1: + version "2.0.6" + resolved "https://registry.npmmirror.com/copy-anything/-/copy-anything-2.0.6.tgz#092454ea9584a7b7ad5573062b2a87f5900fc480" + integrity sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw== dependencies: - dot-prop "^5.2.0" - graceful-fs "^4.1.2" - make-dir "^3.0.0" - unique-string "^2.0.0" - write-file-atomic "^3.0.0" - xdg-basedir "^4.0.0" - -connect-history-api-fallback@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/connect-history-api-fallback/-/connect-history-api-fallback-2.0.0.tgz#647264845251a0daf25b97ce87834cace0f5f1c8" - integrity sha512-U73+6lQFmfiNPrYbXqr6kZ1i1wiRqXnp2nhMsINseWXO8lDau0LGEffJ8kQi4EjLZympVgRdvqjAgiZ1tgzDDA== - -console-control-strings@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" - integrity sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ== - -consolidate@^0.15.1: - version "0.15.1" - resolved "https://registry.yarnpkg.com/consolidate/-/consolidate-0.15.1.tgz#21ab043235c71a07d45d9aad98593b0dba56bab7" - integrity sha512-DW46nrsMJgy9kqAbPt5rKaCr7uFtpo4mSUvLHIUbJEjm0vo+aY5QLwBUq3FK4tRnJr/X0Psc0C4jf/h+HtXSMw== - dependencies: - bluebird "^3.1.1" - -content-disposition@0.5.4: - version "0.5.4" - resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.4.tgz#8b82b4efac82512a02bb0b1dcec9d2c5e8eb5bfe" - integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== - dependencies: - safe-buffer "5.2.1" - -content-type@~1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" - integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== - -convert-source-map@^1.7.0: - version "1.8.0" - resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.8.0.tgz#f3373c32d21b4d780dd8004514684fb791ca4369" - integrity sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA== - dependencies: - safe-buffer "~5.1.1" - -cookie-signature@1.0.6: - version "1.0.6" - resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" - integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== - -cookie@0.5.0: - version "0.5.0" - resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.5.0.tgz#d1f5d71adec6558c58f389987c366aa47e994f8b" - integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== - -copy-webpack-plugin@^9.0.1: - version "9.1.0" - resolved "https://registry.yarnpkg.com/copy-webpack-plugin/-/copy-webpack-plugin-9.1.0.tgz#2d2c460c4c4695ec0a58afb2801a1205256c4e6b" - integrity sha512-rxnR7PaGigJzhqETHGmAcxKnLZSR5u1Y3/bcIv/1FnqXedcL/E2ewK7ZCNrArJKCiSv8yVXhTqetJh8inDvfsA== - dependencies: - fast-glob "^3.2.7" - glob-parent "^6.0.1" - globby "^11.0.3" - normalize-path "^3.0.0" - schema-utils "^3.1.1" - serialize-javascript "^6.0.0" - -core-js-compat@^3.25.1, core-js-compat@^3.8.3: - version "3.25.2" - resolved "https://registry.yarnpkg.com/core-js-compat/-/core-js-compat-3.25.2.tgz#7875573586809909c69e03ef310810c1969ee138" - integrity sha512-TxfyECD4smdn3/CjWxczVtJqVLEEC2up7/82t7vC0AzNogr+4nQ8vyF7abxAuTXWvjTClSbvGhU0RgqA4ToQaQ== - dependencies: - browserslist "^4.21.4" - -core-js@^3.0.1: - version "3.25.3" - resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.25.3.tgz#cbc2be50b5ddfa7981837bd8c41639f27b166593" - integrity sha512-y1hvKXmPHvm5B7w4ln1S4uc9eV/O5+iFExSRUimnvIph11uaizFR8LFMdONN8hG3P2pipUfX4Y/fR8rAEtcHcQ== - -core-js@^3.8.3: - version "3.25.2" - resolved "https://registry.yarnpkg.com/core-js/-/core-js-3.25.2.tgz#2d3670c1455432b53fa780300a6fc1bd8304932c" - integrity sha512-YB4IAT1bjEfxTJ1XYy11hJAKskO+qmhuDBM8/guIfMz4JvdsAQAqvyb97zXX7JgSrfPLG5mRGFWJwJD39ruq2A== + is-what "^3.14.1" core-util-is@1.0.2: version "1.0.2" - resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" + resolved "https://registry.npmmirror.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" integrity sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ== -core-util-is@~1.0.0: - version "1.0.3" - resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.3.tgz#a6042d3634c2b27e9328f837b965fac83808db85" - integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== - -cosmiconfig@^7.0.0: - version "7.0.1" - resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-7.0.1.tgz#714d756522cace867867ccb4474c5d01bbae5d6d" - integrity sha512-a1YWNUV2HwGimB7dU2s1wUMurNKjpx60HxBB6xUM8Re+2s1g1IIfJvFR0/iCF+XHdE0GMTKTuLR32UQff4TEyQ== - dependencies: - "@types/parse-json" "^4.0.0" - import-fresh "^3.2.1" - parse-json "^5.0.0" - path-type "^4.0.0" - yaml "^1.10.0" - crc@^3.8.0: version "3.8.0" - resolved "https://registry.yarnpkg.com/crc/-/crc-3.8.0.tgz#ad60269c2c856f8c299e2c4cc0de4556914056c6" + resolved "https://registry.npmmirror.com/crc/-/crc-3.8.0.tgz#ad60269c2c856f8c299e2c4cc0de4556914056c6" integrity sha512-iX3mfgcTMIq3ZKLIsVFAbv7+Mc10kxabAGQb8HvjA1o3T1PIYprbakQ65d3I+2HGHt6nSKkM9PYjgoJO2KcFBQ== dependencies: buffer "^5.1.0" -cross-spawn@^6.0.0: - version "6.0.5" - resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-6.0.5.tgz#4a5ec7c64dfae22c3a14124dbacdee846d80cbc4" - integrity sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ== - dependencies: - nice-try "^1.0.4" - path-key "^2.0.1" - semver "^5.5.0" - shebang-command "^1.2.0" - which "^1.2.9" - cross-spawn@^7.0.1, cross-spawn@^7.0.3: version "7.0.3" - resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + resolved "https://registry.npmmirror.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== dependencies: path-key "^3.1.0" shebang-command "^2.0.0" which "^2.0.1" -crypto-random-string@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/crypto-random-string/-/crypto-random-string-2.0.0.tgz#ef2a7a966ec11083388369baa02ebead229b30d5" - integrity sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA== - -css-declaration-sorter@^6.3.0: - version "6.3.1" - resolved "https://registry.yarnpkg.com/css-declaration-sorter/-/css-declaration-sorter-6.3.1.tgz#be5e1d71b7a992433fb1c542c7a1b835e45682ec" - integrity sha512-fBffmak0bPAnyqc/HO8C3n2sHrp9wcqQz6ES9koRF2/mLOVAx9zIQ3Y7R29sYCteTPqMCwns4WYQoCX91Xl3+w== - -css-loader@^6.5.0: - version "6.7.1" - resolved "https://registry.yarnpkg.com/css-loader/-/css-loader-6.7.1.tgz#e98106f154f6e1baf3fc3bc455cb9981c1d5fd2e" - integrity sha512-yB5CNFa14MbPJcomwNh3wLThtkZgcNyI2bNMRt8iE5Z8Vwl7f8vQXFAzn2HDOJvtDq2NTZBUGMSUNNyrv3/+cw== +css-render@^0.13.2: + version "0.13.9" + resolved "https://registry.npmmirror.com/css-render/-/css-render-0.13.9.tgz#56f28c180a83a10ec610a12a9ad9fec087ac9dc1" + integrity sha512-n3C4ZH59rveBrUlAD7n0Ze9/gUMKa4dlH1C9CWKpGcIHR/xRcIVXzBGy1iw8WWq2ySmn2/ZqOpySQNAK5Pb6sw== dependencies: - icss-utils "^5.1.0" - postcss "^8.4.7" - postcss-modules-extract-imports "^3.0.0" - postcss-modules-local-by-default "^4.0.0" - postcss-modules-scope "^3.0.0" - postcss-modules-values "^4.0.0" - postcss-value-parser "^4.2.0" - semver "^7.3.5" + "@emotion/hash" "~0.8.0" + "@types/node" "~14.14.31" + csstype "~3.0.5" -css-minimizer-webpack-plugin@^3.0.2: - version "3.4.1" - resolved "https://registry.yarnpkg.com/css-minimizer-webpack-plugin/-/css-minimizer-webpack-plugin-3.4.1.tgz#ab78f781ced9181992fe7b6e4f3422e76429878f" - integrity sha512-1u6D71zeIfgngN2XNRJefc/hY7Ybsxd74Jm4qngIXyUEk7fss3VUzuHxLAq/R8NAba4QU9OUSaMZlbpRc7bM4Q== +css-render@^0.15.10, css-render@^0.15.12: + version "0.15.12" + resolved "https://registry.npmmirror.com/css-render/-/css-render-0.15.12.tgz#76be94066897bd3231a9b9412971ffc258ada66e" + integrity sha512-eWzS66patiGkTTik+ipO9qNGZ+uNuGyTmnz6/+EJIiFg8+3yZRpnMwgFo8YdXhQRsiePzehnusrxVvugNjXzbw== dependencies: - cssnano "^5.0.6" - jest-worker "^27.0.2" - postcss "^8.3.5" - schema-utils "^4.0.0" - serialize-javascript "^6.0.0" - source-map "^0.6.1" - -css-select@^4.1.3: - version "4.3.0" - resolved "https://registry.yarnpkg.com/css-select/-/css-select-4.3.0.tgz#db7129b2846662fd8628cfc496abb2b59e41529b" - integrity sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ== - dependencies: - boolbase "^1.0.0" - css-what "^6.0.1" - domhandler "^4.3.1" - domutils "^2.8.0" - nth-check "^2.0.1" + "@emotion/hash" "~0.8.0" + csstype "~3.0.5" css-select@^5.1.0: version "5.1.0" - resolved "https://registry.yarnpkg.com/css-select/-/css-select-5.1.0.tgz#b8ebd6554c3637ccc76688804ad3f6a6fdaea8a6" + resolved "https://registry.npmmirror.com/css-select/-/css-select-5.1.0.tgz#b8ebd6554c3637ccc76688804ad3f6a6fdaea8a6" integrity sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg== dependencies: boolbase "^1.0.0" @@ -3665,286 +1224,146 @@ css-select@^5.1.0: domutils "^3.0.1" nth-check "^2.0.1" -css-tree@^1.1.2, css-tree@^1.1.3: - version "1.1.3" - resolved "https://registry.yarnpkg.com/css-tree/-/css-tree-1.1.3.tgz#eb4870fb6fd7707327ec95c2ff2ab09b5e8db91d" - integrity sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q== - dependencies: - mdn-data "2.0.14" - source-map "^0.6.1" - -css-what@^6.0.1, css-what@^6.1.0: +css-what@^6.1.0: version "6.1.0" - resolved "https://registry.yarnpkg.com/css-what/-/css-what-6.1.0.tgz#fb5effcf76f1ddea2c81bdfaa4de44e79bac70f4" + resolved "https://registry.npmmirror.com/css-what/-/css-what-6.1.0.tgz#fb5effcf76f1ddea2c81bdfaa4de44e79bac70f4" integrity sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw== cssesc@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/cssesc/-/cssesc-3.0.0.tgz#37741919903b868565e1c09ea747445cd18983ee" + resolved "https://registry.npmmirror.com/cssesc/-/cssesc-3.0.0.tgz#37741919903b868565e1c09ea747445cd18983ee" integrity sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg== -cssnano-preset-default@^5.2.12: - version "5.2.12" - resolved "https://registry.yarnpkg.com/cssnano-preset-default/-/cssnano-preset-default-5.2.12.tgz#ebe6596ec7030e62c3eb2b3c09f533c0644a9a97" - integrity sha512-OyCBTZi+PXgylz9HAA5kHyoYhfGcYdwFmyaJzWnzxuGRtnMw/kR6ilW9XzlzlRAtB6PLT/r+prYgkef7hngFew== - dependencies: - css-declaration-sorter "^6.3.0" - cssnano-utils "^3.1.0" - postcss-calc "^8.2.3" - postcss-colormin "^5.3.0" - postcss-convert-values "^5.1.2" - postcss-discard-comments "^5.1.2" - postcss-discard-duplicates "^5.1.0" - postcss-discard-empty "^5.1.1" - postcss-discard-overridden "^5.1.0" - postcss-merge-longhand "^5.1.6" - postcss-merge-rules "^5.1.2" - postcss-minify-font-values "^5.1.0" - postcss-minify-gradients "^5.1.1" - postcss-minify-params "^5.1.3" - postcss-minify-selectors "^5.2.1" - postcss-normalize-charset "^5.1.0" - postcss-normalize-display-values "^5.1.0" - postcss-normalize-positions "^5.1.1" - postcss-normalize-repeat-style "^5.1.1" - postcss-normalize-string "^5.1.0" - postcss-normalize-timing-functions "^5.1.0" - postcss-normalize-unicode "^5.1.0" - postcss-normalize-url "^5.1.0" - postcss-normalize-whitespace "^5.1.1" - postcss-ordered-values "^5.1.3" - postcss-reduce-initial "^5.1.0" - postcss-reduce-transforms "^5.1.0" - postcss-svgo "^5.1.0" - postcss-unique-selectors "^5.1.1" - -cssnano-utils@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/cssnano-utils/-/cssnano-utils-3.1.0.tgz#95684d08c91511edfc70d2636338ca37ef3a6861" - integrity sha512-JQNR19/YZhz4psLX/rQ9M83e3z2Wf/HdJbryzte4a3NSuafyp9w/I4U+hx5C2S9g41qlstH7DEWnZaaj83OuEA== - -cssnano@^5.0.0, cssnano@^5.0.6: - version "5.1.13" - resolved "https://registry.yarnpkg.com/cssnano/-/cssnano-5.1.13.tgz#83d0926e72955332dc4802a7070296e6258efc0a" - integrity sha512-S2SL2ekdEz6w6a2epXn4CmMKU4K3KpcyXLKfAYc9UQQqJRkD/2eLUG0vJ3Db/9OvO5GuAdgXw3pFbR6abqghDQ== - dependencies: - cssnano-preset-default "^5.2.12" - lilconfig "^2.0.3" - yaml "^1.10.2" - -csso@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/csso/-/csso-4.2.0.tgz#ea3a561346e8dc9f546d6febedd50187cf389529" - integrity sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA== - dependencies: - css-tree "^1.1.2" - -csstype@^3.1.1: +csstype@^3.1.2: version "3.1.2" - resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.1.2.tgz#1d4bf9d572f11c14031f0436e1c10bc1f571f50b" + resolved "https://registry.npmmirror.com/csstype/-/csstype-3.1.2.tgz#1d4bf9d572f11c14031f0436e1c10bc1f571f50b" integrity sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ== +csstype@~3.0.5: + version "3.0.11" + resolved "https://registry.npmmirror.com/csstype/-/csstype-3.0.11.tgz#d66700c5eacfac1940deb4e3ee5642792d85cd33" + integrity sha512-sa6P2wJ+CAbgyy4KFssIb/JNMLxFvKF1pCYCSXS8ZMuqZnMsrxqI2E5sPyoTpxoPU/gVZMzr2zjOfg8GIZOMsw== + dashdash@^1.12.0: version "1.14.1" - resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0" + resolved "https://registry.npmmirror.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0" integrity sha512-jRFi8UDGo6j+odZiEpjazZaWqEal3w/basFjQHQEwVtZJGDpxbH1MeYluwCS8Xq5wmLJooDlMgvVarmWfGM44g== dependencies: assert-plus "^1.0.0" +date-fns-tz@^2.0.0: + version "2.0.0" + resolved "https://registry.npmmirror.com/date-fns-tz/-/date-fns-tz-2.0.0.tgz#1b14c386cb8bc16fc56fe333d4fc34ae1d1099d5" + integrity sha512-OAtcLdB9vxSXTWHdT8b398ARImVwQMyjfYGkKD2zaGpHseG2UPHbHjXELReErZFxWdSLph3c2zOaaTyHfOhERQ== + +date-fns@^2.30.0: + version "2.30.0" + resolved "https://registry.npmmirror.com/date-fns/-/date-fns-2.30.0.tgz#f367e644839ff57894ec6ac480de40cae4b0f4d0" + integrity sha512-fnULvOpxnC5/Vg3NCiWelDsLiUc9bRwAPs/+LfTLNvetFCtCTN+yQz15C/fs4AwX1R9K5GLtLfn8QW+dWisaAw== + dependencies: + "@babel/runtime" "^7.21.0" + +de-indent@^1.0.2: + version "1.0.2" + resolved "https://registry.npmmirror.com/de-indent/-/de-indent-1.0.2.tgz#b2038e846dc33baa5796128d0804b455b8c1e21d" + integrity sha512-e/1zu3xH5MQryN2zdVaF0OrdNLUbvWxzMbi+iNA6Bky7l1RoP8a2fIbRocyHclXt/arDrrR6lL3TqFD9pMQTsg== + debounce-fn@^4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/debounce-fn/-/debounce-fn-4.0.0.tgz#ed76d206d8a50e60de0dd66d494d82835ffe61c7" + resolved "https://registry.npmmirror.com/debounce-fn/-/debounce-fn-4.0.0.tgz#ed76d206d8a50e60de0dd66d494d82835ffe61c7" integrity sha512-8pYCQiL9Xdcg0UPSD3d+0KMlOjp+KGU5EPwYddgzQ7DATsg4fuUDjQtsYLmWjnk2obnNHgV3vE2Y4jejSOJVBQ== dependencies: mimic-fn "^3.0.0" -debug@2.6.9, debug@^2.6.8: - version "2.6.9" - resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" - integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== - dependencies: - ms "2.0.0" - -debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2, debug@^4.3.3, debug@^4.3.4: +debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.4: version "4.3.4" - resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" + resolved "https://registry.npmmirror.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== dependencies: ms "2.1.2" -debug@^3.2.7: +debug@^3.2.6: version "3.2.7" - resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" + resolved "https://registry.npmmirror.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" integrity sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ== dependencies: ms "^2.1.1" -decompress-response@^3.3.0: - version "3.3.0" - resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-3.3.0.tgz#80a4dd323748384bfa248083622aedec982adff3" - integrity sha512-BzRPQuY1ip+qDonAOz42gRm/pg9F768C+npV/4JOsxRC2sq+Rlk+Q4ZCAsOhnIaMrgarILY+RMUIvMmmX1qAEA== - dependencies: - mimic-response "^1.0.0" - decompress-response@^6.0.0: version "6.0.0" - resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-6.0.0.tgz#ca387612ddb7e104bd16d85aab00d5ecf09c66fc" + resolved "https://registry.npmmirror.com/decompress-response/-/decompress-response-6.0.0.tgz#ca387612ddb7e104bd16d85aab00d5ecf09c66fc" integrity sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ== dependencies: mimic-response "^3.1.0" deep-extend@^0.6.0: version "0.6.0" - resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" + resolved "https://registry.npmmirror.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" integrity sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA== -deepmerge@^1.5.2: - version "1.5.2" - resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-1.5.2.tgz#10499d868844cdad4fee0842df8c7f6f0c95a753" - integrity sha512-95k0GDqvBjZavkuvzx/YqVLv/6YYa17fz6ILMSf7neqQITCPbnfEnQvEgMPNjH4kgobe7+WIL0yJEHku+H3qtQ== - -default-gateway@^6.0.3: - version "6.0.3" - resolved "https://registry.yarnpkg.com/default-gateway/-/default-gateway-6.0.3.tgz#819494c888053bdb743edbf343d6cdf7f2943a71" - integrity sha512-fwSOJsbbNzZ/CUFpqFBqYfYNLj1NbMPm8MMCIzHjC83iSJRBEGmDUxU+WP661BaBQImeC2yHwXtz+P/O9o+XEg== - dependencies: - execa "^5.0.0" - -defaults@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/defaults/-/defaults-1.0.3.tgz#c656051e9817d9ff08ed881477f3fe4019f3ef7d" - integrity sha512-s82itHOnYrN0Ib8r+z7laQz3sdE+4FP3d9Q7VLO7U+KRT+CR0GsWuyHxzdAY82I7cXv0G/twrqomTJLOssO5HA== - dependencies: - clone "^1.0.2" - -defer-to-connect@^1.0.1: - version "1.1.3" - resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-1.1.3.tgz#331ae050c08dcf789f8c83a7b81f0ed94f4ac591" - integrity sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ== - defer-to-connect@^2.0.0: version "2.0.1" - resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-2.0.1.tgz#8016bdb4143e4632b77a3449c6236277de520587" + resolved "https://registry.npmmirror.com/defer-to-connect/-/defer-to-connect-2.0.1.tgz#8016bdb4143e4632b77a3449c6236277de520587" integrity sha512-4tvttepXG1VaYGrRibk5EwJd1t4udunSOVMdLSAL6mId1ix438oPwPZMALY41FCijukO1L0twNcGsdzS7dHgDg== -define-lazy-prop@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz#3f7ae421129bcaaac9bc74905c98a0009ec9ee7f" - integrity sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og== - -define-properties@^1.1.3, define-properties@^1.1.4: - version "1.1.4" - resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.4.tgz#0b14d7bd7fbeb2f3572c3a7eda80ea5d57fb05b1" - integrity sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA== +define-data-property@^1.0.1: + version "1.1.1" + resolved "https://registry.npmmirror.com/define-data-property/-/define-data-property-1.1.1.tgz#c35f7cd0ab09883480d12ac5cb213715587800b3" + integrity sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ== dependencies: + get-intrinsic "^1.2.1" + gopd "^1.0.1" + has-property-descriptors "^1.0.0" + +define-properties@^1.1.3: + version "1.2.1" + resolved "https://registry.npmmirror.com/define-properties/-/define-properties-1.2.1.tgz#10781cc616eb951a80a034bafcaa7377f6af2b6c" + integrity sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg== + dependencies: + define-data-property "^1.0.1" has-property-descriptors "^1.0.0" object-keys "^1.1.1" -defined@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/defined/-/defined-1.0.0.tgz#c98d9bcef75674188e110969151199e39b1fa693" - integrity sha512-Y2caI5+ZwS5c3RiNDJ6u53VhQHv+hHKwhkI1iHvceKUHw9Df6EK2zRLfjejRgMuCuxK7PfSWIMwWecceVvThjQ== - delayed-stream@~1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" + resolved "https://registry.npmmirror.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== -delegates@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" - integrity sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ== - -depd@2.0.0, depd@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" - integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== - -depd@~1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" - integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== - -destroy@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.2.0.tgz#4803735509ad8be552934c67df614f94e66fa015" - integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== - -detect-libc@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-2.0.1.tgz#e1897aa88fa6ad197862937fbc0441ef352ee0cd" - integrity sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w== +detect-libc@^2.0.0: + version "2.0.2" + resolved "https://registry.npmmirror.com/detect-libc/-/detect-libc-2.0.2.tgz#8ccf2ba9315350e1241b88d0ac3b0e1fbd99605d" + integrity sha512-UX6sGumvvqSaXgdKGUsgZWqcUyIXZ/vZTrlRT/iobiKhGL0zL4d3osHj3uqllWJK+i+sixDS/3COVEOFbupFyw== detect-node@^2.0.4: version "2.1.0" - resolved "https://registry.yarnpkg.com/detect-node/-/detect-node-2.1.0.tgz#c9c70775a49c3d03bc2c06d9a73be550f978f8b1" + resolved "https://registry.npmmirror.com/detect-node/-/detect-node-2.1.0.tgz#c9c70775a49c3d03bc2c06d9a73be550f978f8b1" integrity sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g== -detective@^5.2.1: - version "5.2.1" - resolved "https://registry.yarnpkg.com/detective/-/detective-5.2.1.tgz#6af01eeda11015acb0e73f933242b70f24f91034" - integrity sha512-v9XE1zRnz1wRtgurGu0Bs8uHKFSTdteYZNbIPFVhUZ39L/S79ppMpdmVOZAnoz1jfEFodc48n6MX483Xo3t1yw== - dependencies: - acorn-node "^1.8.2" - defined "^1.0.0" - minimist "^1.2.6" - didyoumean@^1.2.2: version "1.2.2" - resolved "https://registry.yarnpkg.com/didyoumean/-/didyoumean-1.2.2.tgz#989346ffe9e839b4555ecf5666edea0d3e8ad037" + resolved "https://registry.npmmirror.com/didyoumean/-/didyoumean-1.2.2.tgz#989346ffe9e839b4555ecf5666edea0d3e8ad037" integrity sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw== -dir-compare@^2.4.0: - version "2.4.0" - resolved "https://registry.yarnpkg.com/dir-compare/-/dir-compare-2.4.0.tgz#785c41dc5f645b34343a4eafc50b79bac7f11631" - integrity sha512-l9hmu8x/rjVC9Z2zmGzkhOEowZvW7pmYws5CWHutg8u1JgvsKWMx7Q/UODeu4djLZ4FgW5besw5yvMQnBHzuCA== - dependencies: - buffer-equal "1.0.0" - colors "1.0.3" - commander "2.9.0" - minimatch "3.0.4" - dir-compare@^3.0.0: version "3.3.0" - resolved "https://registry.yarnpkg.com/dir-compare/-/dir-compare-3.3.0.tgz#2c749f973b5c4b5d087f11edaae730db31788416" + resolved "https://registry.npmmirror.com/dir-compare/-/dir-compare-3.3.0.tgz#2c749f973b5c4b5d087f11edaae730db31788416" integrity sha512-J7/et3WlGUCxjdnD3HAAzQ6nsnc0WL6DD7WcwJb7c39iH1+AWfg+9OqzJNaI6PkBwBvm1mhZNL9iY/nRiZXlPg== dependencies: buffer-equal "^1.0.0" minimatch "^3.0.4" -dir-glob@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" - integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== - dependencies: - path-type "^4.0.0" - dlv@^1.1.3: version "1.1.3" - resolved "https://registry.yarnpkg.com/dlv/-/dlv-1.1.3.tgz#5c198a8a11453596e751494d49874bc7732f2e79" + resolved "https://registry.npmmirror.com/dlv/-/dlv-1.1.3.tgz#5c198a8a11453596e751494d49874bc7732f2e79" integrity sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA== -dmg-builder@22.14.13: - version "22.14.13" - resolved "https://registry.yarnpkg.com/dmg-builder/-/dmg-builder-22.14.13.tgz#cc613f3c18e889b8777d525991fd52f50a564f8c" - integrity sha512-xNOugB6AbIRETeU2uID15sUfjdZZcKdxK8xkFnwIggsM00PJ12JxpLNPTjcRoUnfwj3WrPjilrO64vRMwNItQg== +dmg-builder@24.6.4: + version "24.6.4" + resolved "https://registry.npmmirror.com/dmg-builder/-/dmg-builder-24.6.4.tgz#e19b8305f7e1ea0b4faaa30382c81b9d6de39863" + integrity sha512-BNcHRc9CWEuI9qt0E655bUBU/j/3wUCYBVKGu1kVpbN5lcUdEJJJeiO0NHK3dgKmra6LUUZlo+mWqc+OCbi0zw== dependencies: - app-builder-lib "22.14.13" - builder-util "22.14.13" - builder-util-runtime "8.9.2" - fs-extra "^10.0.0" - iconv-lite "^0.6.2" - js-yaml "^4.1.0" - optionalDependencies: - dmg-license "^1.0.9" - -dmg-builder@24.4.0: - version "24.4.0" - resolved "https://registry.yarnpkg.com/dmg-builder/-/dmg-builder-24.4.0.tgz#46c80f119465f6a7275766c72b4f3d514cc8013d" - integrity sha512-p5z9Cx539GSBYb+b09Z+hMhuBTh/BrI71VRg4rgF6f2xtIRK/YlTGVS/O08k5OojoyhZcpS7JXxDVSmQoWgiiQ== - dependencies: - app-builder-lib "24.4.0" - builder-util "24.4.0" + app-builder-lib "24.6.4" + builder-util "24.5.0" builder-util-runtime "9.2.1" fs-extra "^10.1.0" iconv-lite "^0.6.2" @@ -3952,9 +1371,9 @@ dmg-builder@24.4.0: optionalDependencies: dmg-license "^1.0.11" -dmg-license@^1.0.11, dmg-license@^1.0.9: +dmg-license@^1.0.11: version "1.0.11" - resolved "https://registry.yarnpkg.com/dmg-license/-/dmg-license-1.0.11.tgz#7b3bc3745d1b52be7506b4ee80cb61df6e4cd79a" + resolved "https://registry.npmmirror.com/dmg-license/-/dmg-license-1.0.11.tgz#7b3bc3745d1b52be7506b4ee80cb61df6e4cd79a" integrity sha512-ZdzmqwKmECOWJpqefloC5OJy1+WZBBse5+MR88z9g9Zn4VY+WYUkAyojmhzJckH5YbbZGcYIuGAkY5/Ys5OM2Q== dependencies: "@types/plist" "^3.0.1" @@ -3966,246 +1385,102 @@ dmg-license@^1.0.11, dmg-license@^1.0.9: smart-buffer "^4.0.2" verror "^1.10.0" -dns-equal@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/dns-equal/-/dns-equal-1.0.0.tgz#b39e7f1da6eb0a75ba9c17324b34753c47e0654d" - integrity sha512-z+paD6YUQsk+AbGCEM4PrOXSss5gd66QfcVBFTKR/HpFL9jCqikS94HYwKww6fQyO7IxrIIyUu+g0Ka9tUS2Cg== - -dns-packet@^5.2.2: - version "5.4.0" - resolved "https://registry.yarnpkg.com/dns-packet/-/dns-packet-5.4.0.tgz#1f88477cf9f27e78a213fb6d118ae38e759a879b" - integrity sha512-EgqGeaBB8hLiHLZtp/IbaDQTL8pZ0+IvwzSHA6d7VyMDM+B9hgddEMa9xjK5oYnw0ci0JQ6g2XCD7/f6cafU6g== - dependencies: - "@leichtgewicht/ip-codec" "^2.0.1" - -dom-converter@^0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/dom-converter/-/dom-converter-0.2.0.tgz#6721a9daee2e293682955b6afe416771627bb768" - integrity sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA== - dependencies: - utila "~0.4" - -dom-serializer@^1.0.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-1.4.1.tgz#de5d41b1aea290215dc45a6dae8adcf1d32e2d30" - integrity sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag== - dependencies: - domelementtype "^2.0.1" - domhandler "^4.2.0" - entities "^2.0.0" - dom-serializer@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-2.0.0.tgz#e41b802e1eedf9f6cae183ce5e622d789d7d8e53" + resolved "https://registry.npmmirror.com/dom-serializer/-/dom-serializer-2.0.0.tgz#e41b802e1eedf9f6cae183ce5e622d789d7d8e53" integrity sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg== dependencies: domelementtype "^2.3.0" domhandler "^5.0.2" entities "^4.2.0" -dom-walk@^0.1.0: - version "0.1.2" - resolved "https://registry.yarnpkg.com/dom-walk/-/dom-walk-0.1.2.tgz#0c548bef048f4d1f2a97249002236060daa3fd84" - integrity sha512-6QvTW9mrGeIegrFXdtQi9pk7O/nSK6lSdXW2eqUspN5LWD7UTji2Fqw5V2YLjBpHEoU9Xl/eUWNpDeZvoyOv2w== - -domelementtype@^2.0.1, domelementtype@^2.2.0, domelementtype@^2.3.0: +domelementtype@^2.3.0: version "2.3.0" - resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-2.3.0.tgz#5c45e8e869952626331d7aab326d01daf65d589d" + resolved "https://registry.npmmirror.com/domelementtype/-/domelementtype-2.3.0.tgz#5c45e8e869952626331d7aab326d01daf65d589d" integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw== -domhandler@^4.0.0, domhandler@^4.2.0, domhandler@^4.3.1: - version "4.3.1" - resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-4.3.1.tgz#8d792033416f59d68bc03a5aa7b018c1ca89279c" - integrity sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ== - dependencies: - domelementtype "^2.2.0" - -domhandler@^5.0.1, domhandler@^5.0.2, domhandler@^5.0.3: +domhandler@^5.0.2, domhandler@^5.0.3: version "5.0.3" - resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-5.0.3.tgz#cc385f7f751f1d1fc650c21374804254538c7d31" + resolved "https://registry.npmmirror.com/domhandler/-/domhandler-5.0.3.tgz#cc385f7f751f1d1fc650c21374804254538c7d31" integrity sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w== dependencies: domelementtype "^2.3.0" -dompurify@^3.0.3: - version "3.0.3" - resolved "https://registry.yarnpkg.com/dompurify/-/dompurify-3.0.3.tgz#4b115d15a091ddc96f232bcef668550a2f6f1430" - integrity sha512-axQ9zieHLnAnHh0sfAamKYiqXMJAVwu+LM/alQ7WDagoWessyWvMSFyW65CqF3owufNu8HBcE4cM2Vflu7YWcQ== - -domutils@^2.5.2, domutils@^2.8.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/domutils/-/domutils-2.8.0.tgz#4437def5db6e2d1f5d6ee859bd95ca7d02048135" - integrity sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A== - dependencies: - dom-serializer "^1.0.1" - domelementtype "^2.2.0" - domhandler "^4.2.0" +dompurify@^3.0.6: + version "3.0.6" + resolved "https://registry.npmmirror.com/dompurify/-/dompurify-3.0.6.tgz#925ebd576d54a9531b5d76f0a5bef32548351dae" + integrity sha512-ilkD8YEnnGh1zJ240uJsW7AzE+2qpbOUYjacomn3AvJ6J4JhKGSZ2nh4wUIXPZrEPppaCLx5jFe8T89Rk8tQ7w== domutils@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/domutils/-/domutils-3.0.1.tgz#696b3875238338cb186b6c0612bd4901c89a4f1c" - integrity sha512-z08c1l761iKhDFtfXO04C7kTdPBLi41zwOZl00WS8b5eiaebNpY00HKbztwBq+e3vyqWNwWF3mP9YLUeqIrF+Q== + version "3.1.0" + resolved "https://registry.npmmirror.com/domutils/-/domutils-3.1.0.tgz#c47f551278d3dc4b0b1ab8cbb42d751a6f0d824e" + integrity sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA== dependencies: dom-serializer "^2.0.0" domelementtype "^2.3.0" - domhandler "^5.0.1" - -dot-case@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/dot-case/-/dot-case-3.0.4.tgz#9b2b670d00a431667a8a75ba29cd1b98809ce751" - integrity sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w== - dependencies: - no-case "^3.0.4" - tslib "^2.0.3" - -dot-prop@^5.2.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-5.3.0.tgz#90ccce708cd9cd82cc4dc8c3ddd9abdd55b20e88" - integrity sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q== - dependencies: - is-obj "^2.0.0" + domhandler "^5.0.3" dot-prop@^6.0.1: version "6.0.1" - resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-6.0.1.tgz#fc26b3cf142b9e59b74dbd39ed66ce620c681083" + resolved "https://registry.npmmirror.com/dot-prop/-/dot-prop-6.0.1.tgz#fc26b3cf142b9e59b74dbd39ed66ce620c681083" integrity sha512-tE7ztYzXHIeyvc7N+hR3oi7FIbf/NIjVP9hmAt3yMXzrQ072/fpjGLx2GxNxGxUl5V73MEqYzioOMoVhGMJ5cA== dependencies: is-obj "^2.0.0" dotenv-expand@^5.1.0: version "5.1.0" - resolved "https://registry.yarnpkg.com/dotenv-expand/-/dotenv-expand-5.1.0.tgz#3fbaf020bfd794884072ea26b1e9791d45a629f0" + resolved "https://registry.npmmirror.com/dotenv-expand/-/dotenv-expand-5.1.0.tgz#3fbaf020bfd794884072ea26b1e9791d45a629f0" integrity sha512-YXQl1DSa4/PQyRfgrv6aoNjhasp/p4qs9FjJ4q4cQk+8m4r6k4ZSiEyytKG8f8W9gi8WsQtIObNmKd+tMzNTmA== -dotenv@^10.0.0: - version "10.0.0" - resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-10.0.0.tgz#3d4227b8fb95f81096cdd2b66653fb2c7085ba81" - integrity sha512-rlBi9d8jpv9Sf1klPjNfFAuWDjKLwTIJJ/VxtoTwIR6hnZxcEOQCZg2oIL3MWBYw5GpUDKOEnND7LXTbIpQ03Q== - dotenv@^9.0.2: version "9.0.2" - resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-9.0.2.tgz#dacc20160935a37dea6364aa1bef819fb9b6ab05" + resolved "https://registry.npmmirror.com/dotenv/-/dotenv-9.0.2.tgz#dacc20160935a37dea6364aa1bef819fb9b6ab05" integrity sha512-I9OvvrHp4pIARv4+x9iuewrWycX6CcZtoAu1XrzPxc5UygMJXJZYmBsynku8IkrJwgypE5DGNjDPmPRhDCptUg== -duplexer3@^0.1.4: - version "0.1.5" - resolved "https://registry.yarnpkg.com/duplexer3/-/duplexer3-0.1.5.tgz#0b5e4d7bad5de8901ea4440624c8e1d20099217e" - integrity sha512-1A8za6ws41LQgv9HrE/66jyC5yuSjQ3L/KOpFtoBilsAK2iA2wuS5rTt1OCzIvtS2V7nVmedsUU+DGRcjBmOYA== - -duplexer@^0.1.2: - version "0.1.2" - resolved "https://registry.yarnpkg.com/duplexer/-/duplexer-0.1.2.tgz#3abe43aef3835f8ae077d136ddce0f276b0400e6" - integrity sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg== - -easy-stack@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/easy-stack/-/easy-stack-1.0.1.tgz#8afe4264626988cabb11f3c704ccd0c835411066" - integrity sha512-wK2sCs4feiiJeFXn3zvY0p41mdU5VUgbgs1rNsc/y5ngFUijdWd+iIN8eoyuZHKB8xN6BL4PdWmzqFmxNg6V2w== - ecc-jsbn@~0.1.1: version "0.1.2" - resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz#3a83a904e54353287874c564b7549386849a98c9" + resolved "https://registry.npmmirror.com/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz#3a83a904e54353287874c564b7549386849a98c9" integrity sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw== dependencies: jsbn "~0.1.0" safer-buffer "^2.1.0" -ee-first@1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" - integrity sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow== - -ejs@^3.1.6: - version "3.1.8" - resolved "https://registry.yarnpkg.com/ejs/-/ejs-3.1.8.tgz#758d32910c78047585c7ef1f92f9ee041c1c190b" - integrity sha512-/sXZeMlhS0ArkfX2Aw780gJzXSMPnKjtspYZv+f3NiKLlubezAHDU5+9xz6gd3/NhG3txQCo6xlglmTS+oTGEQ== - dependencies: - jake "^10.8.5" - ejs@^3.1.8: version "3.1.9" - resolved "https://registry.yarnpkg.com/ejs/-/ejs-3.1.9.tgz#03c9e8777fe12686a9effcef22303ca3d8eeb361" + resolved "https://registry.npmmirror.com/ejs/-/ejs-3.1.9.tgz#03c9e8777fe12686a9effcef22303ca3d8eeb361" integrity sha512-rC+QVNMJWv+MtPgkt0y+0rVEIdbtxVADApW9JXrUVlzHetgcyczP/E7DJmWJ4fJCZF2cPcBk0laWO9ZHMG3DmQ== dependencies: jake "^10.8.5" -electron-builder@^22.2.0: - version "22.14.13" - resolved "https://registry.yarnpkg.com/electron-builder/-/electron-builder-22.14.13.tgz#fd40564685cf5422a8f8d667940af3d3776f4fb8" - integrity sha512-3fgLxqF2TXVKiUPeg74O4V3l0l3j7ERLazo8sUbRkApw0+4iVAf2BJkHsHMaXiigsgCoEzK/F4/rB5rne/VAnw== +electron-builder@^24.6.4: + version "24.6.4" + resolved "https://registry.npmmirror.com/electron-builder/-/electron-builder-24.6.4.tgz#c51271e49b9a02c9a3ec444f866b6008c4d98a1d" + integrity sha512-uNWQoU7pE7qOaIQ6CJHpBi44RJFVG8OHRBIadUxrsDJVwLLo8Nma3K/EEtx5/UyWAQYdcK4nVPYKoRqBb20hbA== dependencies: - "@types/yargs" "^17.0.1" - app-builder-lib "22.14.13" - builder-util "22.14.13" - builder-util-runtime "8.9.2" - chalk "^4.1.1" - dmg-builder "22.14.13" - fs-extra "^10.0.0" - is-ci "^3.0.0" - lazy-val "^1.0.5" - read-config-file "6.2.0" - update-notifier "^5.1.0" - yargs "^17.0.1" - -electron-builder@^24.4.0: - version "24.4.0" - resolved "https://registry.yarnpkg.com/electron-builder/-/electron-builder-24.4.0.tgz#8846efa45bac8f6b9afc181abf71a4e12530f045" - integrity sha512-D5INxodxaUIJgEX6p/fqBd8wQNS8XRAToNIJ9SQC+taNS5D73ZsjLuXiRraFGCB0cVk9KeKhEkdEOH5AaVya4g== - dependencies: - app-builder-lib "24.4.0" - builder-util "24.4.0" + app-builder-lib "24.6.4" + builder-util "24.5.0" builder-util-runtime "9.2.1" chalk "^4.1.2" - dmg-builder "24.4.0" + dmg-builder "24.6.4" fs-extra "^10.1.0" is-ci "^3.0.0" lazy-val "^1.0.5" read-config-file "6.3.2" - simple-update-notifier "^1.1.0" + simple-update-notifier "2.0.0" yargs "^17.6.2" -electron-devtools-installer@^3.2.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/electron-devtools-installer/-/electron-devtools-installer-3.2.0.tgz#acc48d24eb7033fe5af284a19667e73b78d406d0" - integrity sha512-t3UczsYugm4OAbqvdImMCImIMVdFzJAHgbwHpkl5jmfu1izVgUcP/mnrPqJIpEeCK1uZGpt+yHgWEN+9EwoYhQ== - dependencies: - rimraf "^3.0.2" - semver "^7.2.1" - tslib "^2.1.0" - unzip-crx-3 "^0.2.0" +electron-log@^5.0.0: + version "5.0.0" + resolved "https://registry.npmmirror.com/electron-log/-/electron-log-5.0.0.tgz#b5fab83500fce1c61ec7493701f5e228b752d2e2" + integrity sha512-vB3akupmQvA8jAyNL9rULZtf6WoP8vsabjXsRtiqXS6/D37SwN/4LEyj4JD+9Bv6xoTcx/LrVnsIKEEWdq5ClQ== -electron-osx-sign@^0.5.0: - version "0.5.0" - resolved "https://registry.yarnpkg.com/electron-osx-sign/-/electron-osx-sign-0.5.0.tgz#fc258c5e896859904bbe3d01da06902c04b51c3a" - integrity sha512-icoRLHzFz/qxzDh/N4Pi2z4yVHurlsCAYQvsCSG7fCedJ4UJXBS6PoQyGH71IfcqKupcKeK7HX/NkyfG+v6vlQ== - dependencies: - bluebird "^3.5.0" - compare-version "^0.1.2" - debug "^2.6.8" - isbinaryfile "^3.0.2" - minimist "^1.2.0" - plist "^3.0.1" - -electron-publish@22.14.13: - version "22.14.13" - resolved "https://registry.yarnpkg.com/electron-publish/-/electron-publish-22.14.13.tgz#8b71e6975af8cc6ac5b21f293ade23f8704047c7" - integrity sha512-0oP3QiNj3e8ewOaEpEJV/o6Zrmy2VarVvZ/bH7kyO/S/aJf9x8vQsKVWpsdmSiZ5DJEHgarFIXrnO0ZQf0P9iQ== +electron-publish@24.5.0: + version "24.5.0" + resolved "https://registry.npmmirror.com/electron-publish/-/electron-publish-24.5.0.tgz#492a4d7caa232e88ee3c18f5c3b4dc637e5e1b3a" + integrity sha512-zwo70suH15L15B4ZWNDoEg27HIYoPsGJUF7xevLJLSI7JUPC8l2yLBdLGwqueJ5XkDL7ucYyRZzxJVR8ElV9BA== dependencies: "@types/fs-extra" "^9.0.11" - builder-util "22.14.13" - builder-util-runtime "8.9.2" - chalk "^4.1.1" - fs-extra "^10.0.0" - lazy-val "^1.0.5" - mime "^2.5.2" - -electron-publish@24.4.0: - version "24.4.0" - resolved "https://registry.yarnpkg.com/electron-publish/-/electron-publish-24.4.0.tgz#a58f49ecd727620f65372881788ebb1a9b853284" - integrity sha512-U3mnVSxIfNrLW7ZnwiedFhcLf6ExPFXgAsx89WpfQFsV4gFAt/LG+H74p0m9NSvsLXiZuF82yXoxi7Ou8GHq4Q== - dependencies: - "@types/fs-extra" "^9.0.11" - builder-util "24.4.0" + builder-util "24.5.0" builder-util-runtime "9.2.1" chalk "^4.1.2" fs-extra "^10.1.0" @@ -4214,275 +1489,126 @@ electron-publish@24.4.0: electron-store@^8.1.0: version "8.1.0" - resolved "https://registry.yarnpkg.com/electron-store/-/electron-store-8.1.0.tgz#46a398f2bd9aa83c4a9daaae28380e2b3b9c7597" + resolved "https://registry.npmmirror.com/electron-store/-/electron-store-8.1.0.tgz#46a398f2bd9aa83c4a9daaae28380e2b3b9c7597" integrity sha512-2clHg/juMjOH0GT9cQ6qtmIvK183B39ZXR0bUoPwKwYHJsEF3quqyDzMFUAu+0OP8ijmN2CbPRAelhNbWUbzwA== dependencies: conf "^10.2.0" type-fest "^2.17.0" -electron-to-chromium@^1.4.251: - version "1.4.256" - resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.256.tgz#c735032f412505e8e0482f147a8ff10cfca45bf4" - integrity sha512-x+JnqyluoJv8I0U9gVe+Sk2st8vF0CzMt78SXxuoWCooLLY2k5VerIBdpvG7ql6GKI4dzNnPjmqgDJ76EdaAKw== +electron-to-chromium@^1.4.535: + version "1.4.569" + resolved "https://registry.npmmirror.com/electron-to-chromium/-/electron-to-chromium-1.4.569.tgz#1298b67727187ffbaac005a7425490d157f3ad03" + integrity sha512-LsrJjZ0IbVy12ApW3gpYpcmHS3iRxH4bkKOW98y1/D+3cvDUWGcbzbsFinfUS8knpcZk/PG/2p/RnkMCYN7PVg== -electron@^22.3.17: - version "22.3.17" - resolved "https://registry.yarnpkg.com/electron/-/electron-22.3.17.tgz#90a75f78cc761ed536d8210dd001e142fca78691" - integrity sha512-mo9qD1pOkiibvH+pgETsq9RZF0p3O5ACwxzjk3E2ozMYb9cnJenZyE3jxbs4WqzDCFi+rsm6WWahw3hlPhANXw== +electron@^26.4.2: + version "26.4.2" + resolved "https://registry.npmmirror.com/electron/-/electron-26.4.2.tgz#2f976a3c30558f09ced3f5876862b4c21172c02c" + integrity sha512-BOfQUOIvsq5NnssWOMqcZnA5M0ull620wvQoJq3WhXN1wJAsWu+cdjHvREyxnHbArPkV+F+x3YAi5Dt+UKoqhw== dependencies: "@electron/get" "^2.0.0" - "@types/node" "^16.11.26" + "@types/node" "^18.11.18" extract-zip "^2.0.1" emoji-regex@^8.0.0: version "8.0.0" - resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" + resolved "https://registry.npmmirror.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== -emojis-list@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-3.0.0.tgz#5570662046ad29e2e916e71aae260abdff4f6a78" - integrity sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q== - -empty-dir@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/empty-dir/-/empty-dir-1.0.0.tgz#be3ea41ca6798dc27bb9407f035888150e4c2995" - integrity sha512-97qcDM6mUA1jAeX6cktw7akc5awIGA+VIkA5MygKOKA+c2Vseo/xwKN0JNJTUhZUtPwZboKVD2p1xu+sV/F4xA== - -encodeurl@~1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" - integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w== - -encoding@^0.1.13: - version "0.1.13" - resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.13.tgz#56574afdd791f54a8e9b2785c0582a2d26210fa9" - integrity sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A== - dependencies: - iconv-lite "^0.6.2" - -end-of-stream@^1.1.0: +end-of-stream@^1.1.0, end-of-stream@^1.4.1: version "1.4.4" - resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" + resolved "https://registry.npmmirror.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== dependencies: once "^1.4.0" -enhanced-resolve@^5.10.0: - version "5.10.0" - resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.10.0.tgz#0dc579c3bb2a1032e357ac45b8f3a6f3ad4fb1e6" - integrity sha512-T0yTFjdpldGY8PmuXXR0PyQ1ufZpEGiHVrp7zHKB7jdR4qlmZHhONVM5AQOAWXuF/w3dnHbEQVrNptJgt7F+cQ== - dependencies: - graceful-fs "^4.2.4" - tapable "^2.2.0" - -entities@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55" - integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== - -entities@^4.2.0, entities@^4.3.0, entities@^4.4.0: - version "4.4.0" - resolved "https://registry.yarnpkg.com/entities/-/entities-4.4.0.tgz#97bdaba170339446495e653cfd2db78962900174" - integrity sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA== +entities@^4.2.0, entities@^4.4.0: + version "4.5.0" + resolved "https://registry.npmmirror.com/entities/-/entities-4.5.0.tgz#5d268ea5e7113ec74c4d033b79ea5a35a488fb48" + integrity sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw== env-paths@^2.2.0, env-paths@^2.2.1: version "2.2.1" - resolved "https://registry.yarnpkg.com/env-paths/-/env-paths-2.2.1.tgz#420399d416ce1fbe9bc0a07c62fa68d67fd0f8f2" + resolved "https://registry.npmmirror.com/env-paths/-/env-paths-2.2.1.tgz#420399d416ce1fbe9bc0a07c62fa68d67fd0f8f2" integrity sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A== err-code@^2.0.2: version "2.0.3" - resolved "https://registry.yarnpkg.com/err-code/-/err-code-2.0.3.tgz#23c2f3b756ffdfc608d30e27c9a941024807e7f9" + resolved "https://registry.npmmirror.com/err-code/-/err-code-2.0.3.tgz#23c2f3b756ffdfc608d30e27c9a941024807e7f9" integrity sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA== -error-ex@^1.3.1: - version "1.3.2" - resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" - integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== +errno@^0.1.1: + version "0.1.8" + resolved "https://registry.npmmirror.com/errno/-/errno-0.1.8.tgz#8bb3e9c7d463be4976ff888f76b4809ebc2e811f" + integrity sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A== dependencies: - is-arrayish "^0.2.1" - -error-stack-parser@^2.0.6: - version "2.1.4" - resolved "https://registry.yarnpkg.com/error-stack-parser/-/error-stack-parser-2.1.4.tgz#229cb01cdbfa84440bfa91876285b94680188286" - integrity sha512-Sk5V6wVazPhq5MhpO+AUxJn5x7XSXGl1R93Vn7i+zS15KDVxQijejNCrz8340/2bgLBjR9GtEG8ZVKONDjcqGQ== - dependencies: - stackframe "^1.3.4" - -es-module-lexer@^0.9.0: - version "0.9.3" - resolved "https://registry.yarnpkg.com/es-module-lexer/-/es-module-lexer-0.9.3.tgz#6f13db00cc38417137daf74366f535c8eb438f19" - integrity sha512-1HQ2M2sPtxwnvOvT1ZClHyQDiggdNjURWpY2we6aMKCQiUVxTmVs2UYPLIrD84sS+kMdUwfBSylbJPwNnBrnHQ== + prr "~1.0.1" es6-error@^4.1.1: version "4.1.1" - resolved "https://registry.yarnpkg.com/es6-error/-/es6-error-4.1.1.tgz#9e3af407459deed47e9a91f9b885a84eb05c561d" + resolved "https://registry.npmmirror.com/es6-error/-/es6-error-4.1.1.tgz#9e3af407459deed47e9a91f9b885a84eb05c561d" integrity sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg== -es6-promise@^3.0.2: - version "3.3.1" - resolved "https://registry.yarnpkg.com/es6-promise/-/es6-promise-3.3.1.tgz#a08cdde84ccdbf34d027a1451bc91d4bcd28a613" - integrity sha512-SOp9Phqvqn7jtEUxPWdWfWoLmyt2VaJ6MpvP9Comy1MceMXqE6bxvaTu4iaxpYYPzhny28Lc+M87/c2cPK6lDg== +esbuild@^0.18.10: + version "0.18.20" + resolved "https://registry.npmmirror.com/esbuild/-/esbuild-0.18.20.tgz#4709f5a34801b43b799ab7d6d82f7284a9b7a7a6" + integrity sha512-ceqxoedUrcayh7Y7ZX6NdbbDzGROiyVBgC4PriJThBKSVPWnnFHZAkfI1lJT8QFkOwH4qOS2SJkS4wvpGl8BpA== + optionalDependencies: + "@esbuild/android-arm" "0.18.20" + "@esbuild/android-arm64" "0.18.20" + "@esbuild/android-x64" "0.18.20" + "@esbuild/darwin-arm64" "0.18.20" + "@esbuild/darwin-x64" "0.18.20" + "@esbuild/freebsd-arm64" "0.18.20" + "@esbuild/freebsd-x64" "0.18.20" + "@esbuild/linux-arm" "0.18.20" + "@esbuild/linux-arm64" "0.18.20" + "@esbuild/linux-ia32" "0.18.20" + "@esbuild/linux-loong64" "0.18.20" + "@esbuild/linux-mips64el" "0.18.20" + "@esbuild/linux-ppc64" "0.18.20" + "@esbuild/linux-riscv64" "0.18.20" + "@esbuild/linux-s390x" "0.18.20" + "@esbuild/linux-x64" "0.18.20" + "@esbuild/netbsd-x64" "0.18.20" + "@esbuild/openbsd-x64" "0.18.20" + "@esbuild/sunos-x64" "0.18.20" + "@esbuild/win32-arm64" "0.18.20" + "@esbuild/win32-ia32" "0.18.20" + "@esbuild/win32-x64" "0.18.20" escalade@^3.1.1: version "3.1.1" - resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" + resolved "https://registry.npmmirror.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40" integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== -escape-goat@^2.0.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/escape-goat/-/escape-goat-2.1.1.tgz#1b2dc77003676c457ec760b2dc68edb648188675" - integrity sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q== - -escape-html@~1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" - integrity sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow== - -escape-string-regexp@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" - integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== - escape-string-regexp@^4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + resolved "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== -eslint-scope@5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" - integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== - dependencies: - esrecurse "^4.3.0" - estraverse "^4.1.1" - -esrecurse@^4.3.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" - integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== - dependencies: - estraverse "^5.2.0" - -estraverse@^4.1.1: - version "4.3.0" - resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" - integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== - -estraverse@^5.2.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" - integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== - estree-walker@^2.0.2: version "2.0.2" - resolved "https://registry.yarnpkg.com/estree-walker/-/estree-walker-2.0.2.tgz#52f010178c2a4c117a7757cfe942adb7d2da4cac" + resolved "https://registry.npmmirror.com/estree-walker/-/estree-walker-2.0.2.tgz#52f010178c2a4c117a7757cfe942adb7d2da4cac" integrity sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w== -esutils@^2.0.2: +evtd@^0.2.2, evtd@^0.2.4: + version "0.2.4" + resolved "https://registry.npmmirror.com/evtd/-/evtd-0.2.4.tgz#0aac39ba44d6926e6668948ac27618e0795b9d07" + integrity sha512-qaeGN5bx63s/AXgQo8gj6fBkxge+OoLddLniox5qtLAEY5HSnuSlISXVPxnSae1dWblvTh4/HoMIB+mbMsvZzw== + +expand-template@^2.0.3: version "2.0.3" - resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" - integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== - -etag@~1.8.1: - version "1.8.1" - resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" - integrity sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg== - -event-pubsub@4.3.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/event-pubsub/-/event-pubsub-4.3.0.tgz#f68d816bc29f1ec02c539dc58c8dd40ce72cb36e" - integrity sha512-z7IyloorXvKbFx9Bpie2+vMJKKx1fH1EN5yiTfp8CiLOTptSYy1g8H4yDpGlEdshL1PBiFtBHepF2cNsqeEeFQ== - -eventemitter3@^4.0.0: - version "4.0.7" - resolved "https://registry.yarnpkg.com/eventemitter3/-/eventemitter3-4.0.7.tgz#2de9b68f6528d5644ef5c59526a1b4a07306169f" - integrity sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw== - -events@^3.2.0: - version "3.3.0" - resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" - integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== - -execa@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/execa/-/execa-1.0.0.tgz#c6236a5bb4df6d6f15e88e7f017798216749ddd8" - integrity sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA== - dependencies: - cross-spawn "^6.0.0" - get-stream "^4.0.0" - is-stream "^1.1.0" - npm-run-path "^2.0.0" - p-finally "^1.0.0" - signal-exit "^3.0.0" - strip-eof "^1.0.0" - -execa@^5.0.0: - version "5.1.1" - resolved "https://registry.yarnpkg.com/execa/-/execa-5.1.1.tgz#f80ad9cbf4298f7bd1d4c9555c21e93741c411dd" - integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== - dependencies: - cross-spawn "^7.0.3" - get-stream "^6.0.0" - human-signals "^2.1.0" - is-stream "^2.0.0" - merge-stream "^2.0.0" - npm-run-path "^4.0.1" - onetime "^5.1.2" - signal-exit "^3.0.3" - strip-final-newline "^2.0.0" - -exif-parser@^0.1.12: - version "0.1.12" - resolved "https://registry.yarnpkg.com/exif-parser/-/exif-parser-0.1.12.tgz#58a9d2d72c02c1f6f02a0ef4a9166272b7760922" - integrity sha512-c2bQfLNbMzLPmzQuOr8fy0csy84WmwnER81W88DzTp9CYNPJ6yzOj2EZAh9pywYpqHnshVLHQJ8WzldAyfY+Iw== - -express@^4.17.3: - version "4.18.1" - resolved "https://registry.yarnpkg.com/express/-/express-4.18.1.tgz#7797de8b9c72c857b9cd0e14a5eea80666267caf" - integrity sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q== - dependencies: - accepts "~1.3.8" - array-flatten "1.1.1" - body-parser "1.20.0" - content-disposition "0.5.4" - content-type "~1.0.4" - cookie "0.5.0" - cookie-signature "1.0.6" - debug "2.6.9" - depd "2.0.0" - encodeurl "~1.0.2" - escape-html "~1.0.3" - etag "~1.8.1" - finalhandler "1.2.0" - fresh "0.5.2" - http-errors "2.0.0" - merge-descriptors "1.0.1" - methods "~1.1.2" - on-finished "2.4.1" - parseurl "~1.3.3" - path-to-regexp "0.1.7" - proxy-addr "~2.0.7" - qs "6.10.3" - range-parser "~1.2.1" - safe-buffer "5.2.1" - send "0.18.0" - serve-static "1.15.0" - setprototypeof "1.2.0" - statuses "2.0.1" - type-is "~1.6.18" - utils-merge "1.0.1" - vary "~1.1.2" + resolved "https://registry.npmmirror.com/expand-template/-/expand-template-2.0.3.tgz#6e14b3fcee0f3a6340ecb57d2e8918692052a47c" + integrity sha512-XYfuKMvj4O35f/pOXLObndIRvyQ+/+6AhODh+OKWj9S9498pHHn/IMszH+gt0fBCRWMNfk1ZSp5x3AifmnI2vg== extend@~3.0.2: version "3.0.2" - resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" + resolved "https://registry.npmmirror.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" integrity sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g== extract-zip@^2.0.1: version "2.0.1" - resolved "https://registry.yarnpkg.com/extract-zip/-/extract-zip-2.0.1.tgz#663dca56fe46df890d5f131ef4a06d22bb8ba13a" + resolved "https://registry.npmmirror.com/extract-zip/-/extract-zip-2.0.1.tgz#663dca56fe46df890d5f131ef4a06d22bb8ba13a" integrity sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg== dependencies: debug "^4.1.1" @@ -4493,23 +1619,23 @@ extract-zip@^2.0.1: extsprintf@1.3.0: version "1.3.0" - resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05" + resolved "https://registry.npmmirror.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05" integrity sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g== extsprintf@^1.2.0: version "1.4.1" - resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.4.1.tgz#8d172c064867f235c0c84a596806d279bf4bcc07" + resolved "https://registry.npmmirror.com/extsprintf/-/extsprintf-1.4.1.tgz#8d172c064867f235c0c84a596806d279bf4bcc07" integrity sha512-Wrk35e8ydCKDj/ArClo1VrPVmN8zph5V4AtHwIuHhvMXsKf73UT3BOD+azBIW+3wOJ4FhEH7zyaJCFvChjYvMA== -fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: +fast-deep-equal@^3.1.1: version "3.1.3" - resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" + resolved "https://registry.npmmirror.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== -fast-glob@^3.2.11, fast-glob@^3.2.7, fast-glob@^3.2.9: - version "3.2.12" - resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.12.tgz#7f39ec99c2e6ab030337142da9e0c18f37afae80" - integrity sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w== +fast-glob@^3.3.0: + version "3.3.1" + resolved "https://registry.npmmirror.com/fast-glob/-/fast-glob-3.3.1.tgz#784b4e897340f3dbbef17413b3f11acf03c874c4" + integrity sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg== dependencies: "@nodelib/fs.stat" "^2.0.2" "@nodelib/fs.walk" "^1.2.3" @@ -4519,115 +1645,66 @@ fast-glob@^3.2.11, fast-glob@^3.2.7, fast-glob@^3.2.9: fast-json-stable-stringify@^2.0.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" + resolved "https://registry.npmmirror.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== fastq@^1.6.0: - version "1.13.0" - resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.13.0.tgz#616760f88a7526bdfc596b7cab8c18938c36b98c" - integrity sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw== + version "1.15.0" + resolved "https://registry.npmmirror.com/fastq/-/fastq-1.15.0.tgz#d04d07c6a2a68fe4599fea8d2e103a937fae6b3a" + integrity sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw== dependencies: reusify "^1.0.4" -faye-websocket@^0.11.3: - version "0.11.4" - resolved "https://registry.yarnpkg.com/faye-websocket/-/faye-websocket-0.11.4.tgz#7f0d9275cfdd86a1c963dc8b65fcc451edcbb1da" - integrity sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g== - dependencies: - websocket-driver ">=0.5.1" - fd-slicer@~1.1.0: version "1.1.0" - resolved "https://registry.yarnpkg.com/fd-slicer/-/fd-slicer-1.1.0.tgz#25c7c89cb1f9077f8891bbe61d8f390eae256f1e" + resolved "https://registry.npmmirror.com/fd-slicer/-/fd-slicer-1.1.0.tgz#25c7c89cb1f9077f8891bbe61d8f390eae256f1e" integrity sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g== dependencies: pend "~1.2.0" -figures@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/figures/-/figures-2.0.0.tgz#3ab1a2d2a62c8bfb431a0c94cb797a2fce27c962" - integrity sha512-Oa2M9atig69ZkfwiApY8F2Yy+tzMbazyvqv21R0NsSC8floSOC09BbT1ITWAdoMGQvJ/aZnR1KMwdx9tvHnTNA== - dependencies: - escape-string-regexp "^1.0.5" - -file-type@^16.5.4: - version "16.5.4" - resolved "https://registry.yarnpkg.com/file-type/-/file-type-16.5.4.tgz#474fb4f704bee427681f98dd390058a172a6c2fd" - integrity sha512-/yFHK0aGjFEgDJjEKP0pWCplsPFPhwyfwevf/pVxiN0tmE4L9LmwWxWukdJSHdoCli4VgQLehjJtwQBnqmsKcw== - dependencies: - readable-web-to-node-stream "^3.0.0" - strtok3 "^6.2.4" - token-types "^4.1.1" - file-uri-to-path@1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd" + resolved "https://registry.npmmirror.com/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz#553a7b8446ff6f684359c445f1e37a05dacc33dd" integrity sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw== -filelist@^1.0.1: +filelist@^1.0.4: version "1.0.4" - resolved "https://registry.yarnpkg.com/filelist/-/filelist-1.0.4.tgz#f78978a1e944775ff9e62e744424f215e58352b5" + resolved "https://registry.npmmirror.com/filelist/-/filelist-1.0.4.tgz#f78978a1e944775ff9e62e744424f215e58352b5" integrity sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q== dependencies: minimatch "^5.0.1" fill-range@^7.0.1: version "7.0.1" - resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" + resolved "https://registry.npmmirror.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== dependencies: to-regex-range "^5.0.1" -finalhandler@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.2.0.tgz#7d23fe5731b207b4640e4fcd00aec1f9207a7b32" - integrity sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg== - dependencies: - debug "2.6.9" - encodeurl "~1.0.2" - escape-html "~1.0.3" - on-finished "2.4.1" - parseurl "~1.3.3" - statuses "2.0.1" - unpipe "~1.0.0" - -find-cache-dir@^3.3.1: - version "3.3.2" - resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-3.3.2.tgz#b30c5b6eff0730731aea9bbd9dbecbd80256d64b" - integrity sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig== - dependencies: - commondir "^1.0.1" - make-dir "^3.0.2" - pkg-dir "^4.1.0" - find-up@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" + resolved "https://registry.npmmirror.com/find-up/-/find-up-3.0.0.tgz#49169f1d7993430646da61ecc5ae355c21c97b73" integrity sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg== dependencies: locate-path "^3.0.0" -find-up@^4.0.0, find-up@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" - integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== - dependencies: - locate-path "^5.0.0" - path-exists "^4.0.0" - -follow-redirects@^1.0.0: - version "1.15.2" - resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.2.tgz#b460864144ba63f2681096f274c4e57026da2c13" - integrity sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA== - forever-agent@~0.6.1: version "0.6.1" - resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" + resolved "https://registry.npmmirror.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91" integrity sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw== +form-data@^2.5.0: + version "2.5.1" + resolved "https://registry.npmmirror.com/form-data/-/form-data-2.5.1.tgz#f2cbec57b5e59e23716e128fe44d4e5dd23895f4" + integrity sha512-m21N3WOmEEURgk6B9GLOE4RuWOFf28Lhh9qGYeNlGq4VDXUlJy2th2slBNU8Gp8EzloYZOibZJ7t5ecIrFSjVA== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.6" + mime-types "^2.1.12" + form-data@^4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" + resolved "https://registry.npmmirror.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== dependencies: asynckit "^0.4.0" @@ -4636,31 +1713,26 @@ form-data@^4.0.0: form-data@~2.3.2: version "2.3.3" - resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.3.3.tgz#dcce52c05f644f298c6a7ab936bd724ceffbf3a6" + resolved "https://registry.npmmirror.com/form-data/-/form-data-2.3.3.tgz#dcce52c05f644f298c6a7ab936bd724ceffbf3a6" integrity sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ== dependencies: asynckit "^0.4.0" combined-stream "^1.0.6" mime-types "^2.1.12" -forwarded@0.2.0: - version "0.2.0" - resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" - integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== +fraction.js@^4.3.6: + version "4.3.7" + resolved "https://registry.npmmirror.com/fraction.js/-/fraction.js-4.3.7.tgz#06ca0085157e42fda7f9e726e79fefc4068840f7" + integrity sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew== -fraction.js@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/fraction.js/-/fraction.js-4.2.0.tgz#448e5109a313a3527f5a3ab2119ec4cf0e0e2950" - integrity sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA== - -fresh@0.5.2: - version "0.5.2" - resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" - integrity sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q== +fs-constants@^1.0.0: + version "1.0.0" + resolved "https://registry.npmmirror.com/fs-constants/-/fs-constants-1.0.0.tgz#6be0de9be998ce16af8afc24497b9ee9b7ccd9ad" + integrity sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow== fs-extra@^10.0.0, fs-extra@^10.1.0: version "10.1.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-10.1.0.tgz#02873cfbc4084dde127eaa5f9905eef2325d1abf" + resolved "https://registry.npmmirror.com/fs-extra/-/fs-extra-10.1.0.tgz#02873cfbc4084dde127eaa5f9905eef2325d1abf" integrity sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ== dependencies: graceful-fs "^4.2.0" @@ -4669,16 +1741,16 @@ fs-extra@^10.0.0, fs-extra@^10.1.0: fs-extra@^8.1.0: version "8.1.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-8.1.0.tgz#49d43c45a88cd9677668cb7be1b46efdb8d2e1c0" + resolved "https://registry.npmmirror.com/fs-extra/-/fs-extra-8.1.0.tgz#49d43c45a88cd9677668cb7be1b46efdb8d2e1c0" integrity sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g== dependencies: graceful-fs "^4.2.0" jsonfile "^4.0.0" universalify "^0.1.0" -fs-extra@^9.0.0, fs-extra@^9.0.1, fs-extra@^9.1.0: +fs-extra@^9.0.0, fs-extra@^9.0.1: version "9.1.0" - resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-9.1.0.tgz#5954460c764a8da2094ba3554bf839e6b9a7c86d" + resolved "https://registry.npmmirror.com/fs-extra/-/fs-extra-9.1.0.tgz#5954460c764a8da2094ba3554bf839e6b9a7c86d" integrity sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ== dependencies: at-least-node "^1.0.0" @@ -4686,122 +1758,91 @@ fs-extra@^9.0.0, fs-extra@^9.0.1, fs-extra@^9.1.0: jsonfile "^6.0.1" universalify "^2.0.0" -fs-minipass@^2.0.0, fs-minipass@^2.1.0: +fs-minipass@^2.0.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" + resolved "https://registry.npmmirror.com/fs-minipass/-/fs-minipass-2.1.0.tgz#7f5036fdbf12c63c169190cbe4199c852271f9fb" integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== dependencies: minipass "^3.0.0" -fs-monkey@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/fs-monkey/-/fs-monkey-1.0.3.tgz#ae3ac92d53bb328efe0e9a1d9541f6ad8d48e2d3" - integrity sha512-cybjIfiiE+pTWicSCLFHSrXZ6EilF30oh91FDP9S2B051prEa7QWfrVTQm10/dDpswBDXZugPa1Ogu8Yh+HV0Q== - fs.realpath@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" + resolved "https://registry.npmmirror.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== fsevents@~2.3.2: - version "2.3.2" - resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" - integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== + version "2.3.3" + resolved "https://registry.npmmirror.com/fsevents/-/fsevents-2.3.3.tgz#cac6407785d03675a2a5e1a5305c697b347d90d6" + integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw== -function-bind@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" - integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== - -gauge@^4.0.3: - version "4.0.4" - resolved "https://registry.yarnpkg.com/gauge/-/gauge-4.0.4.tgz#52ff0652f2bbf607a989793d53b751bef2328dce" - integrity sha512-f9m+BEN5jkg6a0fZjleidjN51VE1X+mPFQ2DJ0uv1V39oCLCbsGe6yjbBnp7eK7z/+GAon99a3nHuqbuuthyPg== - dependencies: - aproba "^1.0.3 || ^2.0.0" - color-support "^1.1.3" - console-control-strings "^1.1.0" - has-unicode "^2.0.1" - signal-exit "^3.0.7" - string-width "^4.2.3" - strip-ansi "^6.0.1" - wide-align "^1.1.5" - -gensync@^1.0.0-beta.2: - version "1.0.0-beta.2" - resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0" - integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg== +function-bind@^1.1.2: + version "1.1.2" + resolved "https://registry.npmmirror.com/function-bind/-/function-bind-1.1.2.tgz#2c02d864d97f3ea6c8830c464cbd11ab6eab7a1c" + integrity sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA== get-caller-file@^2.0.5: version "2.0.5" - resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" + resolved "https://registry.npmmirror.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== -get-intrinsic@^1.0.2, get-intrinsic@^1.1.1: - version "1.1.3" - resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.1.3.tgz#063c84329ad93e83893c7f4f243ef63ffa351385" - integrity sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A== +get-intrinsic@^1.1.3, get-intrinsic@^1.2.1, get-intrinsic@^1.2.2: + version "1.2.2" + resolved "https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.2.2.tgz#281b7622971123e1ef4b3c90fd7539306da93f3b" + integrity sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA== dependencies: - function-bind "^1.1.1" - has "^1.0.3" + function-bind "^1.1.2" + has-proto "^1.0.1" has-symbols "^1.0.3" - -get-stream@^4.0.0, get-stream@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-4.1.0.tgz#c1b255575f3dc21d59bfc79cd3d2b46b1c3a54b5" - integrity sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w== - dependencies: - pump "^3.0.0" + hasown "^2.0.0" get-stream@^5.1.0: version "5.2.0" - resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-5.2.0.tgz#4966a1795ee5ace65e706c4b7beb71257d6e22d3" + resolved "https://registry.npmmirror.com/get-stream/-/get-stream-5.2.0.tgz#4966a1795ee5ace65e706c4b7beb71257d6e22d3" integrity sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA== dependencies: pump "^3.0.0" -get-stream@^6.0.0: - version "6.0.1" - resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" - integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== - getpass@^0.1.1: version "0.1.7" - resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa" + resolved "https://registry.npmmirror.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa" integrity sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng== dependencies: assert-plus "^1.0.0" -gifwrap@^0.9.2: - version "0.9.4" - resolved "https://registry.yarnpkg.com/gifwrap/-/gifwrap-0.9.4.tgz#f4eb6169ba027d61df64aafbdcb1f8ae58ccc0c5" - integrity sha512-MDMwbhASQuVeD4JKd1fKgNgCRL3fGqMM4WaqpNhWO0JiMOAjbQdumbs4BbBZEy9/M00EHEjKN3HieVhCUlwjeQ== - dependencies: - image-q "^4.0.0" - omggif "^1.0.10" +github-from-package@0.0.0: + version "0.0.0" + resolved "https://registry.npmmirror.com/github-from-package/-/github-from-package-0.0.0.tgz#97fb5d96bfde8973313f20e8288ef9a167fa64ce" + integrity sha512-SyHy3T1v2NUXn29OsWdxmK6RwHD+vkj3v8en8AOBZ1wBQ/hCAQ5bAQTD02kW4W9tUp/3Qh6J8r9EvntiyCmOOw== glob-parent@^5.1.2, glob-parent@~5.1.2: version "5.1.2" - resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" + resolved "https://registry.npmmirror.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== dependencies: is-glob "^4.0.1" -glob-parent@^6.0.1, glob-parent@^6.0.2: +glob-parent@^6.0.2: version "6.0.2" - resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + resolved "https://registry.npmmirror.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== dependencies: is-glob "^4.0.3" -glob-to-regexp@^0.4.1: - version "0.4.1" - resolved "https://registry.yarnpkg.com/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz#c75297087c851b9a578bd217dd59a92f59fe546e" - integrity sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw== +glob@7.1.6: + version "7.1.6" + resolved "https://registry.npmmirror.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6" + integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.0.4" + once "^1.3.0" + path-is-absolute "^1.0.0" -glob@^7.1.2, glob@^7.1.3, glob@^7.1.4, glob@^7.1.6: +glob@^7.1.3, glob@^7.1.6: version "7.2.3" - resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" + resolved "https://registry.npmmirror.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== dependencies: fs.realpath "^1.0.0" @@ -4811,20 +1852,9 @@ glob@^7.1.2, glob@^7.1.3, glob@^7.1.4, glob@^7.1.6: once "^1.3.0" path-is-absolute "^1.0.0" -glob@^8.0.1: - version "8.1.0" - resolved "https://registry.yarnpkg.com/glob/-/glob-8.1.0.tgz#d388f656593ef708ee3e34640fdfb99a9fd1c33e" - integrity sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ== - dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^5.0.1" - once "^1.3.0" - global-agent@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/global-agent/-/global-agent-3.0.0.tgz#ae7cd31bd3583b93c5a16437a1afe27cc33a1ab6" + resolved "https://registry.npmmirror.com/global-agent/-/global-agent-3.0.0.tgz#ae7cd31bd3583b93c5a16437a1afe27cc33a1ab6" integrity sha512-PT6XReJ+D07JvGoxQMkT6qji/jVNfX/h364XHZOWeRzy64sSFr+xJ5OX7LI3b4MPQzdL4H8Y8M0xzPpsVMwA8Q== dependencies: boolean "^3.0.1" @@ -4834,48 +1864,23 @@ global-agent@^3.0.0: semver "^7.3.2" serialize-error "^7.0.1" -global-dirs@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/global-dirs/-/global-dirs-3.0.0.tgz#70a76fe84ea315ab37b1f5576cbde7d48ef72686" - integrity sha512-v8ho2DS5RiCjftj1nD9NmnfaOzTdud7RRnVd9kFNOjqZbISlx5DQ+OrTkywgd0dIt7oFCvKetZSHoHcP3sDdiA== - dependencies: - ini "2.0.0" - -global@~4.4.0: - version "4.4.0" - resolved "https://registry.yarnpkg.com/global/-/global-4.4.0.tgz#3e7b105179006a323ed71aafca3e9c57a5cc6406" - integrity sha512-wv/LAoHdRE3BeTGz53FAamhGlPLhlssK45usmGFThIi4XqnBmjKQ16u+RNbP7WvigRZDxUsM0J3gcQ5yicaL0w== - dependencies: - min-document "^2.19.0" - process "^0.11.10" - -globals@^11.1.0: - version "11.12.0" - resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" - integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== - globalthis@^1.0.1: version "1.0.3" - resolved "https://registry.yarnpkg.com/globalthis/-/globalthis-1.0.3.tgz#5852882a52b80dc301b0660273e1ed082f0b6ccf" + resolved "https://registry.npmmirror.com/globalthis/-/globalthis-1.0.3.tgz#5852882a52b80dc301b0660273e1ed082f0b6ccf" integrity sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA== dependencies: define-properties "^1.1.3" -globby@^11.0.2, globby@^11.0.3: - version "11.1.0" - resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" - integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== +gopd@^1.0.1: + version "1.0.1" + resolved "https://registry.npmmirror.com/gopd/-/gopd-1.0.1.tgz#29ff76de69dac7489b7c0918a5788e56477c332c" + integrity sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA== dependencies: - array-union "^2.1.0" - dir-glob "^3.0.1" - fast-glob "^3.2.9" - ignore "^5.2.0" - merge2 "^1.4.1" - slash "^3.0.0" + get-intrinsic "^1.1.3" -got@^11.7.0, got@^11.8.5: +got@^11.8.5: version "11.8.6" - resolved "https://registry.yarnpkg.com/got/-/got-11.8.6.tgz#276e827ead8772eddbcfc97170590b841823233a" + resolved "https://registry.npmmirror.com/got/-/got-11.8.6.tgz#276e827ead8772eddbcfc97170590b841823233a" integrity sha512-6tfZ91bOr7bOXnK7PRDCGBLa1H4U080YHNaAQ2KsMGlLEzRbk44nsZF2E1IeRc3vtJHPVbKCYgdFbaGO2ljd8g== dependencies: "@sindresorhus/is" "^4.0.0" @@ -4890,271 +1895,97 @@ got@^11.7.0, got@^11.8.5: p-cancelable "^2.0.0" responselike "^2.0.0" -got@^9.6.0: - version "9.6.0" - resolved "https://registry.yarnpkg.com/got/-/got-9.6.0.tgz#edf45e7d67f99545705de1f7bbeeeb121765ed85" - integrity sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q== - dependencies: - "@sindresorhus/is" "^0.14.0" - "@szmarczak/http-timer" "^1.1.2" - cacheable-request "^6.0.0" - decompress-response "^3.3.0" - duplexer3 "^0.1.4" - get-stream "^4.1.0" - lowercase-keys "^1.0.1" - mimic-response "^1.0.1" - p-cancelable "^1.0.0" - to-readable-stream "^1.0.0" - url-parse-lax "^3.0.0" - -graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.4, graceful-fs@^4.2.6, graceful-fs@^4.2.9: - version "4.2.10" - resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.10.tgz#147d3a006da4ca3ce14728c7aefc287c367d7a6c" - integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA== - -"graceful-readlink@>= 1.0.0": - version "1.0.1" - resolved "https://registry.yarnpkg.com/graceful-readlink/-/graceful-readlink-1.0.1.tgz#4cafad76bc62f02fa039b2f94e9a3dd3a391a725" - integrity sha512-8tLu60LgxF6XpdbK8OW3FA+IfTNBn1ZHGHKF4KQbEeSkajYw5PlYJcKluntgegDPTg8UkHjpet1T82vk6TQ68w== - -gzip-size@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/gzip-size/-/gzip-size-6.0.0.tgz#065367fd50c239c0671cbcbad5be3e2eeb10e462" - integrity sha512-ax7ZYomf6jqPTQ4+XCpUGyXKHk5WweS+e05MBO4/y3WJ5RkmPXNKvX+bx1behVILVwr6JSQvZAku021CHPXG3Q== - dependencies: - duplexer "^0.1.2" - -handle-thing@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/handle-thing/-/handle-thing-2.0.1.tgz#857f79ce359580c340d43081cc648970d0bb234e" - integrity sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg== +graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0: + version "4.2.11" + resolved "https://registry.npmmirror.com/graceful-fs/-/graceful-fs-4.2.11.tgz#4183e4e8bf08bb6e05bbb2f7d2e0c8f712ca40e3" + integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ== har-schema@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92" + resolved "https://registry.npmmirror.com/har-schema/-/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92" integrity sha512-Oqluz6zhGX8cyRaTQlFMPw80bSJVG2x/cFb8ZPhUILGgHka9SsokCCOQgpveePerqidZOrT14ipqfJb7ILcW5Q== har-validator@~5.1.3: version "5.1.5" - resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-5.1.5.tgz#1f0803b9f8cb20c0fa13822df1ecddb36bde1efd" + resolved "https://registry.npmmirror.com/har-validator/-/har-validator-5.1.5.tgz#1f0803b9f8cb20c0fa13822df1ecddb36bde1efd" integrity sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w== dependencies: ajv "^6.12.3" har-schema "^2.0.0" -has-flag@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" - integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== - has-flag@^4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" + resolved "https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== has-property-descriptors@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz#610708600606d36961ed04c196193b6a607fa861" - integrity sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ== + version "1.0.1" + resolved "https://registry.npmmirror.com/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz#52ba30b6c5ec87fd89fa574bc1c39125c6f65340" + integrity sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg== dependencies: - get-intrinsic "^1.1.1" + get-intrinsic "^1.2.2" + +has-proto@^1.0.1: + version "1.0.1" + resolved "https://registry.npmmirror.com/has-proto/-/has-proto-1.0.1.tgz#1885c1305538958aff469fef37937c22795408e0" + integrity sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg== has-symbols@^1.0.3: version "1.0.3" - resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" + resolved "https://registry.npmmirror.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== -has-unicode@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" - integrity sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ== - -has-yarn@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/has-yarn/-/has-yarn-2.1.0.tgz#137e11354a7b5bf11aa5cb649cf0c6f3ff2b2e77" - integrity sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw== - -has@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" - integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== - dependencies: - function-bind "^1.1.1" - -hash-sum@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/hash-sum/-/hash-sum-1.0.2.tgz#33b40777754c6432573c120cc3808bbd10d47f04" - integrity sha512-fUs4B4L+mlt8/XAtSOGMUO1TXmAelItBPtJG7CyHJfYTdDjwisntGO2JQz7oUsatOY9o68+57eziUVNw/mRHmA== - -hash-sum@^2.0.0: +hasown@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/hash-sum/-/hash-sum-2.0.0.tgz#81d01bb5de8ea4a214ad5d6ead1b523460b0b45a" - integrity sha512-WdZTbAByD+pHfl/g9QSsBIIwy8IT+EsPiKDs0KNX+zSHhdDLFKdZu0BQHljvO+0QI/BasbMSUa8wYNCZTvhslg== + resolved "https://registry.npmmirror.com/hasown/-/hasown-2.0.0.tgz#f4c513d454a57b7c7e1650778de226b11700546c" + integrity sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA== + dependencies: + function-bind "^1.1.2" he@^1.2.0: version "1.2.0" - resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" + resolved "https://registry.npmmirror.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== -highlight.js@^10.7.1: - version "10.7.3" - resolved "https://registry.yarnpkg.com/highlight.js/-/highlight.js-10.7.3.tgz#697272e3991356e40c3cac566a74eef681756531" - integrity sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A== +highlight.js@^11.8.0: + version "11.9.0" + resolved "https://registry.npmmirror.com/highlight.js/-/highlight.js-11.9.0.tgz#04ab9ee43b52a41a047432c8103e2158a1b8b5b0" + integrity sha512-fJ7cW7fQGCYAkgv4CPfwFHrfd/cLS4Hau96JuJ+ZTOWhjnhoeN1ub1tFmALm/+lW5z4WCAuAV9bm05AP0mS6Gw== -hosted-git-info@^2.1.4: - version "2.8.9" - resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.9.tgz#dffc0bf9a21c02209090f2aa69429e1414daf3f9" - integrity sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw== - -hosted-git-info@^4.0.2, hosted-git-info@^4.1.0: +hosted-git-info@^4.1.0: version "4.1.0" - resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-4.1.0.tgz#827b82867e9ff1c8d0c4d9d53880397d2c86d224" + resolved "https://registry.npmmirror.com/hosted-git-info/-/hosted-git-info-4.1.0.tgz#827b82867e9ff1c8d0c4d9d53880397d2c86d224" integrity sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA== dependencies: lru-cache "^6.0.0" -hpack.js@^2.1.6: - version "2.1.6" - resolved "https://registry.yarnpkg.com/hpack.js/-/hpack.js-2.1.6.tgz#87774c0949e513f42e84575b3c45681fade2a0b2" - integrity sha512-zJxVehUdMGIKsRaNt7apO2Gqp0BdqW5yaiGHXXmbpvxgBYVZnAql+BJb4RO5ad2MgpbZKn5G6nMnegrH1FcNYQ== - dependencies: - inherits "^2.0.1" - obuf "^1.0.0" - readable-stream "^2.0.1" - wbuf "^1.1.0" - -html-entities@^2.3.2: - version "2.3.3" - resolved "https://registry.yarnpkg.com/html-entities/-/html-entities-2.3.3.tgz#117d7626bece327fc8baace8868fa6f5ef856e46" - integrity sha512-DV5Ln36z34NNTDgnz0EWGBLZENelNAtkiFA4kyNOG2tDI6Mz1uSWiq1wAKdyjnJwyDiDO7Fa2SO1CTxPXL8VxA== - -html-minifier-terser@^6.0.2: - version "6.1.0" - resolved "https://registry.yarnpkg.com/html-minifier-terser/-/html-minifier-terser-6.1.0.tgz#bfc818934cc07918f6b3669f5774ecdfd48f32ab" - integrity sha512-YXxSlJBZTP7RS3tWnQw74ooKa6L9b9i9QYXY21eUEvhZ3u9XLfv6OnFsQq6RxkhHygsaUMvYsZRV5rU/OVNZxw== - dependencies: - camel-case "^4.1.2" - clean-css "^5.2.2" - commander "^8.3.0" - he "^1.2.0" - param-case "^3.0.4" - relateurl "^0.2.7" - terser "^5.10.0" - -html-tags@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/html-tags/-/html-tags-2.0.0.tgz#10b30a386085f43cede353cc8fa7cb0deeea668b" - integrity sha512-+Il6N8cCo2wB/Vd3gqy/8TZhTD3QvcVeQLCnZiGkGCH3JP28IgGAY41giccp2W4R3jfyJPAP318FQTa1yU7K7g== - -html-tags@^3.1.0: - version "3.2.0" - resolved "https://registry.yarnpkg.com/html-tags/-/html-tags-3.2.0.tgz#dbb3518d20b726524e4dd43de397eb0a95726961" - integrity sha512-vy7ClnArOZwCnqZgvv+ddgHgJiAFXe3Ge9ML5/mBctVJoUoYPCdxVucOywjDARn6CVoh3dRSFdPHy2sX80L0Wg== - -html-webpack-plugin@^5.1.0: - version "5.5.0" - resolved "https://registry.yarnpkg.com/html-webpack-plugin/-/html-webpack-plugin-5.5.0.tgz#c3911936f57681c1f9f4d8b68c158cd9dfe52f50" - integrity sha512-sy88PC2cRTVxvETRgUHFrL4No3UxvcH8G1NepGhqaTT+GXN2kTamqasot0inS5hXeg1cMbFDt27zzo9p35lZVw== - dependencies: - "@types/html-minifier-terser" "^6.0.0" - html-minifier-terser "^6.0.2" - lodash "^4.17.21" - pretty-error "^4.0.0" - tapable "^2.0.0" - -htmlparser2@^6.1.0: - version "6.1.0" - resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-6.1.0.tgz#c4d762b6c3371a05dbe65e94ae43a9f845fb8fb7" - integrity sha512-gyyPk6rgonLFEDGoeRgQNaEUvdJ4ktTmmUh/h2t7s+M8oPpIPxgNACWa+6ESR57kXstwqPiCut0V8NRpcwgU7A== - dependencies: - domelementtype "^2.0.1" - domhandler "^4.0.0" - domutils "^2.5.2" - entities "^2.0.0" - htmlparser2@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-8.0.1.tgz#abaa985474fcefe269bc761a779b544d7196d010" - integrity sha512-4lVbmc1diZC7GUJQtRQ5yBAeUCL1exyMwmForWkRLnwyzWBFxN633SALPMGYaWZvKe9j1pRZJpauvmxENSp/EA== + version "8.0.2" + resolved "https://registry.npmmirror.com/htmlparser2/-/htmlparser2-8.0.2.tgz#f002151705b383e62433b5cf466f5b716edaec21" + integrity sha512-GYdjWKDkbRLkZ5geuHs5NY1puJ+PXwP7+fHPRz06Eirsb9ugf6d8kkXav6ADhcODhFFPMIXyxkxSuMf3D6NCFA== dependencies: domelementtype "^2.3.0" - domhandler "^5.0.2" + domhandler "^5.0.3" domutils "^3.0.1" - entities "^4.3.0" + entities "^4.4.0" http-cache-semantics@^4.0.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz#49e91c5cbf36c9b94bcfcd71c23d5249ec74e390" - integrity sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ== - -http-cache-semantics@^4.1.0: version "4.1.1" - resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz#abe02fcb2985460bf0323be664436ec3476a6d5a" + resolved "https://registry.npmmirror.com/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz#abe02fcb2985460bf0323be664436ec3476a6d5a" integrity sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ== -http-deceiver@^1.2.7: - version "1.2.7" - resolved "https://registry.yarnpkg.com/http-deceiver/-/http-deceiver-1.2.7.tgz#fa7168944ab9a519d337cb0bec7284dc3e723d87" - integrity sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw== - -http-errors@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" - integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== - dependencies: - depd "2.0.0" - inherits "2.0.4" - setprototypeof "1.2.0" - statuses "2.0.1" - toidentifier "1.0.1" - -http-errors@~1.6.2: - version "1.6.3" - resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.6.3.tgz#8b55680bb4be283a0b5bf4ea2e38580be1d9320d" - integrity sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A== - dependencies: - depd "~1.1.2" - inherits "2.0.3" - setprototypeof "1.1.0" - statuses ">= 1.4.0 < 2" - -http-parser-js@>=0.5.1: - version "0.5.8" - resolved "https://registry.yarnpkg.com/http-parser-js/-/http-parser-js-0.5.8.tgz#af23090d9ac4e24573de6f6aecc9d84a48bf20e3" - integrity sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q== - http-proxy-agent@^5.0.0: version "5.0.0" - resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz#5129800203520d434f142bc78ff3c170800f2b43" + resolved "https://registry.npmmirror.com/http-proxy-agent/-/http-proxy-agent-5.0.0.tgz#5129800203520d434f142bc78ff3c170800f2b43" integrity sha512-n2hY8YdoRE1i7r6M0w9DIw5GgZN0G25P8zLCRQ8rjXtTU3vsNFBI/vWK/UIeE6g5MUUz6avwAPXmL6Fy9D/90w== dependencies: "@tootallnate/once" "2" agent-base "6" debug "4" -http-proxy-middleware@^2.0.3: - version "2.0.6" - resolved "https://registry.yarnpkg.com/http-proxy-middleware/-/http-proxy-middleware-2.0.6.tgz#e1a4dd6979572c7ab5a4e4b55095d1f32a74963f" - integrity sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw== - dependencies: - "@types/http-proxy" "^1.17.8" - http-proxy "^1.18.1" - is-glob "^4.0.1" - is-plain-obj "^3.0.0" - micromatch "^4.0.2" - -http-proxy@^1.18.1: - version "1.18.1" - resolved "https://registry.yarnpkg.com/http-proxy/-/http-proxy-1.18.1.tgz#401541f0534884bbf95260334e72f88ee3976549" - integrity sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ== - dependencies: - eventemitter3 "^4.0.0" - follow-redirects "^1.0.0" - requires-port "^1.0.0" - http-signature@~1.2.0: version "1.2.0" - resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.2.0.tgz#9aecd925114772f3d95b65a60abb8f7c18fbace1" + resolved "https://registry.npmmirror.com/http-signature/-/http-signature-1.2.0.tgz#9aecd925114772f3d95b65a60abb8f7c18fbace1" integrity sha512-CAbnr6Rz4CYQkLYUtSNXxQPUH2gK8f3iWexVlsnMeD+GjlsQ0Xsy1cOX+mN3dtxYomRy21CiOzU8Uhw6OwncEQ== dependencies: assert-plus "^1.0.0" @@ -5163,500 +1994,213 @@ http-signature@~1.2.0: http2-wrapper@^1.0.0-beta.5.2: version "1.0.3" - resolved "https://registry.yarnpkg.com/http2-wrapper/-/http2-wrapper-1.0.3.tgz#b8f55e0c1f25d4ebd08b3b0c2c079f9590800b3d" + resolved "https://registry.npmmirror.com/http2-wrapper/-/http2-wrapper-1.0.3.tgz#b8f55e0c1f25d4ebd08b3b0c2c079f9590800b3d" integrity sha512-V+23sDMr12Wnz7iTcDeJr3O6AIxlnvT/bmaAAAP/Xda35C90p9599p0F1eHR/N1KILWSoWVAiOMFjBBXaXSMxg== dependencies: quick-lru "^5.1.1" resolve-alpn "^1.0.0" -https-proxy-agent@^5.0.0, https-proxy-agent@^5.0.1: +https-proxy-agent@^5.0.1: version "5.0.1" - resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz#c59ef224a04fe8b754f3db0063a25ea30d0005d6" + resolved "https://registry.npmmirror.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz#c59ef224a04fe8b754f3db0063a25ea30d0005d6" integrity sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA== dependencies: agent-base "6" debug "4" -human-signals@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-2.1.0.tgz#dc91fcba42e4d06e4abaed33b3e7a3c02f514ea0" - integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== - -humanize-ms@^1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/humanize-ms/-/humanize-ms-1.2.1.tgz#c46e3159a293f6b896da29316d8b6fe8bb79bbed" - integrity sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ== - dependencies: - ms "^2.0.0" - iconv-corefoundation@^1.1.7: version "1.1.7" - resolved "https://registry.yarnpkg.com/iconv-corefoundation/-/iconv-corefoundation-1.1.7.tgz#31065e6ab2c9272154c8b0821151e2c88f1b002a" + resolved "https://registry.npmmirror.com/iconv-corefoundation/-/iconv-corefoundation-1.1.7.tgz#31065e6ab2c9272154c8b0821151e2c88f1b002a" integrity sha512-T10qvkw0zz4wnm560lOEg0PovVqUXuOFhhHAkixw8/sycy7TJt7v/RrkEKEQnAw2viPSJu6iAkErxnzR0g8PpQ== dependencies: cli-truncate "^2.1.0" node-addon-api "^1.6.3" -iconv-lite@0.4.24: - version "0.4.24" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" - integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== - dependencies: - safer-buffer ">= 2.1.2 < 3" - -iconv-lite@^0.6.2: +iconv-lite@^0.6.2, iconv-lite@^0.6.3: version "0.6.3" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" + resolved "https://registry.npmmirror.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== dependencies: safer-buffer ">= 2.1.2 < 3.0.0" -icss-utils@^5.0.0, icss-utils@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/icss-utils/-/icss-utils-5.1.0.tgz#c6be6858abd013d768e98366ae47e25d5887b1ae" - integrity sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA== - -ieee754@^1.1.13, ieee754@^1.2.1: +ieee754@^1.1.13: version "1.2.1" - resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" + resolved "https://registry.npmmirror.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== -ignore@^5.2.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.0.tgz#6d3bac8fa7fe0d45d9f9be7bac2fc279577e345a" - integrity sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ== - -image-q@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/image-q/-/image-q-4.0.0.tgz#31e075be7bae3c1f42a85c469b4732c358981776" - integrity sha512-PfJGVgIfKQJuq3s0tTDOKtztksibuUEbJQIYT3by6wctQo+Rdlh7ef4evJ5NCdxY4CfMbvFkocEwbl4BF8RlJw== - dependencies: - "@types/node" "16.9.1" - -immediate@~3.0.5: - version "3.0.6" - resolved "https://registry.npmmirror.com/immediate/-/immediate-3.0.6.tgz#9db1dbd0faf8de6fbe0f5dd5e56bb606280de69b" - integrity sha512-XXOFtyqDjNDAQxVfYxuF7g9Il/IbWmmlQg2MYKOH8ExIT1qg6xc4zyS3HaEEATgs1btfzxq15ciUiY7gjSXRGQ== - -import-fresh@^3.2.1: - version "3.3.0" - resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" - integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== - dependencies: - parent-module "^1.0.0" - resolve-from "^4.0.0" - -import-lazy@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/import-lazy/-/import-lazy-2.1.0.tgz#05698e3d45c88e8d7e9d92cb0584e77f096f3e43" - integrity sha512-m7ZEHgtw69qOGw+jwxXkHlrlIPdTGkyh66zXZ1ajZbxkDBNjSY/LGbmjc7h0s2ELsUDTAhFr55TrPSSqJGPG0A== - -imurmurhash@^0.1.4: - version "0.1.4" - resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" - integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== - -indent-string@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" - integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== - -infer-owner@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/infer-owner/-/infer-owner-1.0.4.tgz#c4cefcaa8e51051c2a40ba2ce8a3d27295af9467" - integrity sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A== +image-size@~0.5.0: + version "0.5.5" + resolved "https://registry.npmmirror.com/image-size/-/image-size-0.5.5.tgz#09dfd4ab9d20e29eb1c3e80b8990378df9e3cb9c" + integrity sha512-6TDAlDPZxUFCv+fuOkIoXT/V/f3Qbq8e37p+YOiYrUv3v9cc3/6x78VdfPgFVaB9dZYeLUfKgHRebpkm/oP2VQ== inflight@^1.0.4: version "1.0.6" - resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" + resolved "https://registry.npmmirror.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== dependencies: once "^1.3.0" wrappy "1" -inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@^2.0.4, inherits@~2.0.3: +inherits@2, inherits@^2.0.3, inherits@^2.0.4: version "2.0.4" - resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + resolved "https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== -inherits@2.0.3: - version "2.0.3" - resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" - integrity sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw== - -ini@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ini/-/ini-2.0.0.tgz#e5fd556ecdd5726be978fa1001862eacb0a94bc5" - integrity sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA== - ini@~1.3.0: version "1.3.8" - resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.8.tgz#a29da425b48806f34767a4efce397269af28432c" + resolved "https://registry.npmmirror.com/ini/-/ini-1.3.8.tgz#a29da425b48806f34767a4efce397269af28432c" integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== -ip@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ip/-/ip-2.0.0.tgz#4cf4ab182fee2314c75ede1276f8c80b479936da" - integrity sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ== - -ipaddr.js@1.9.1: - version "1.9.1" - resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" - integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== - -ipaddr.js@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-2.0.1.tgz#eca256a7a877e917aeb368b0a7497ddf42ef81c0" - integrity sha512-1qTgH9NG+IIJ4yfKs2e6Pp1bZg8wbDbKHT21HrLIeYBTRLgMYKnMTPAuI3Lcs61nfx5h1xlXnbJtH1kX5/d/ng== - -is-arrayish@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" - integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg== - is-binary-path@~2.1.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" + resolved "https://registry.npmmirror.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== dependencies: binary-extensions "^2.0.0" -is-ci@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-2.0.0.tgz#6bc6334181810e04b5c22b3d589fdca55026404c" - integrity sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w== - dependencies: - ci-info "^2.0.0" - is-ci@^3.0.0: version "3.0.1" - resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-3.0.1.tgz#db6ecbed1bd659c43dac0f45661e7674103d1867" + resolved "https://registry.npmmirror.com/is-ci/-/is-ci-3.0.1.tgz#db6ecbed1bd659c43dac0f45661e7674103d1867" integrity sha512-ZYvCgrefwqoQ6yTyYUbQu64HsITZ3NfKX1lzaEYdkTDcfKzzCI/wthRRYKkdjHKFVgNiXKAKm65Zo1pk2as/QQ== dependencies: ci-info "^3.2.0" -is-core-module@^2.9.0: - version "2.10.0" - resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.10.0.tgz#9012ede0a91c69587e647514e1d5277019e728ed" - integrity sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg== +is-core-module@^2.13.0: + version "2.13.1" + resolved "https://registry.npmmirror.com/is-core-module/-/is-core-module-2.13.1.tgz#ad0d7532c6fea9da1ebdc82742d74525c6273384" + integrity sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw== dependencies: - has "^1.0.3" - -is-docker@^2.0.0, is-docker@^2.1.1: - version "2.2.1" - resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-2.2.1.tgz#33eeabe23cfe86f14bde4408a02c0cfb853acdaa" - integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ== + hasown "^2.0.0" is-extglob@^2.1.1: version "2.1.1" - resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + resolved "https://registry.npmmirror.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== -is-file-esm@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-file-esm/-/is-file-esm-1.0.0.tgz#987086b0f5a5318179e9d30f4f2f8d37321e1b5f" - integrity sha512-rZlaNKb4Mr8WlRu2A9XdeoKgnO5aA53XdPHgCKVyCrQ/rWi89RET1+bq37Ru46obaQXeiX4vmFIm1vks41hoSA== - dependencies: - read-pkg-up "^7.0.1" - -is-fullwidth-code-point@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" - integrity sha512-VHskAKYM8RfSFXwee5t5cbN5PZeq1Wrh6qd5bkyiXIf6UQcN6w/A0eXM9r6t8d+GYOh+o6ZhiEnb88LN/Y8m2w== - is-fullwidth-code-point@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" + resolved "https://registry.npmmirror.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== -is-function@^1.0.1: - version "1.0.2" - resolved "https://registry.yarnpkg.com/is-function/-/is-function-1.0.2.tgz#4f097f30abf6efadac9833b17ca5dc03f8144e08" - integrity sha512-lw7DUp0aWXYg+CBCN+JKkcE0Q2RayZnSvnZBlwgxHBQhqt5pZNVy4Ri7H9GmmXkdu7LUthszM+Tor1u/2iBcpQ== - is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1: version "4.0.3" - resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" + resolved "https://registry.npmmirror.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== dependencies: is-extglob "^2.1.1" -is-installed-globally@^0.4.0: - version "0.4.0" - resolved "https://registry.yarnpkg.com/is-installed-globally/-/is-installed-globally-0.4.0.tgz#9a0fd407949c30f86eb6959ef1b7994ed0b7b520" - integrity sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ== - dependencies: - global-dirs "^3.0.0" - is-path-inside "^3.0.2" - -is-interactive@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/is-interactive/-/is-interactive-1.0.0.tgz#cea6e6ae5c870a7b0a0004070b7b587e0252912e" - integrity sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w== - -is-lambda@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/is-lambda/-/is-lambda-1.0.1.tgz#3d9877899e6a53efc0160504cde15f82e6f061d5" - integrity sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ== - -is-npm@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/is-npm/-/is-npm-5.0.0.tgz#43e8d65cc56e1b67f8d47262cf667099193f45a8" - integrity sha512-WW/rQLOazUq+ST/bCAVBp/2oMERWLsR7OrKyt052dNDk4DHcDE0/7QSXITlmi+VBcV13DfIbysG3tZJm5RfdBA== - is-number@^7.0.0: version "7.0.0" - resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" + resolved "https://registry.npmmirror.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== is-obj@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" + resolved "https://registry.npmmirror.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" integrity sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w== -is-path-inside@^3.0.2: - version "3.0.3" - resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" - integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== - -is-plain-obj@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-3.0.0.tgz#af6f2ea14ac5a646183a5bbdb5baabbc156ad9d7" - integrity sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA== - -is-plain-object@^2.0.4: - version "2.0.4" - resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677" - integrity sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og== - dependencies: - isobject "^3.0.1" - -is-stream@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44" - integrity sha512-uQPm8kcs47jx38atAcWTVxyltQYoPT68y9aWYdV6yWXSyW8mzSat0TL6CiWdZeCdF3KrAvpVtnHbTv4RN+rqdQ== - -is-stream@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" - integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== - -is-typedarray@^1.0.0, is-typedarray@~1.0.0: +is-typedarray@~1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" + resolved "https://registry.npmmirror.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" integrity sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA== -is-unicode-supported@^0.1.0: - version "0.1.0" - resolved "https://registry.yarnpkg.com/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz#3f26c76a809593b52bfa2ecb5710ed2779b522a7" - integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== - -is-wsl@^2.1.1, is-wsl@^2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/is-wsl/-/is-wsl-2.2.0.tgz#74a4c76e77ca9fd3f932f290c17ea326cd157271" - integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww== - dependencies: - is-docker "^2.0.0" - -is-yarn-global@^0.3.0: - version "0.3.0" - resolved "https://registry.yarnpkg.com/is-yarn-global/-/is-yarn-global-0.3.0.tgz#d502d3382590ea3004893746754c89139973e232" - integrity sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw== - -isarray@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" - integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== - -isbinaryfile@^3.0.2: - version "3.0.3" - resolved "https://registry.yarnpkg.com/isbinaryfile/-/isbinaryfile-3.0.3.tgz#5d6def3edebf6e8ca8cae9c30183a804b5f8be80" - integrity sha512-8cJBL5tTd2OS0dM4jz07wQd5g0dCCqIhUxPIGtZfa5L6hWlvV5MHTITy/DBAsF+Oe2LS1X3krBUhNwaGUWpWxw== - dependencies: - buffer-alloc "^1.2.0" +is-what@^3.14.1: + version "3.14.1" + resolved "https://registry.npmmirror.com/is-what/-/is-what-3.14.1.tgz#e1222f46ddda85dead0fd1c9df131760e77755c1" + integrity sha512-sNxgpk9793nzSs7bA6JQJGeIuRBQhAaNGG77kzYQgMkrID+lS6SlK07K5LaptscDlSaIgH+GPFzf+d75FVxozA== isbinaryfile@^4.0.8: version "4.0.10" - resolved "https://registry.yarnpkg.com/isbinaryfile/-/isbinaryfile-4.0.10.tgz#0c5b5e30c2557a2f06febd37b7322946aaee42b3" + resolved "https://registry.npmmirror.com/isbinaryfile/-/isbinaryfile-4.0.10.tgz#0c5b5e30c2557a2f06febd37b7322946aaee42b3" integrity sha512-iHrqe5shvBUcFbmZq9zOQHBoeOhZJu6RQGrDpBgenUm/Am+F3JM2MgQj+rK3Z601fzrL5gLZWtAPH2OBaSVcyw== isbinaryfile@^5.0.0: version "5.0.0" - resolved "https://registry.yarnpkg.com/isbinaryfile/-/isbinaryfile-5.0.0.tgz#034b7e54989dab8986598cbcea41f66663c65234" + resolved "https://registry.npmmirror.com/isbinaryfile/-/isbinaryfile-5.0.0.tgz#034b7e54989dab8986598cbcea41f66663c65234" integrity sha512-UDdnyGvMajJUWCkib7Cei/dvyJrrvo4FIrsvSFWdPpXSUorzXrDJ0S+X5Q4ZlasfPjca4yqCNNsjbCeiy8FFeg== isexe@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" + resolved "https://registry.npmmirror.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== -isobject@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df" - integrity sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg== - -isomorphic-fetch@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/isomorphic-fetch/-/isomorphic-fetch-3.0.0.tgz#0267b005049046d2421207215d45d6a262b8b8b4" - integrity sha512-qvUtwJ3j6qwsF3jLxkZ72qCgjMysPzDfeV240JHiGZsANBYd+EEuu35v7dfrJ9Up0Ak07D7GGSkGhCHTqg/5wA== - dependencies: - node-fetch "^2.6.1" - whatwg-fetch "^3.4.1" - isstream@~0.1.2: version "0.1.2" - resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" + resolved "https://registry.npmmirror.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" integrity sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g== jake@^10.8.5: - version "10.8.5" - resolved "https://registry.yarnpkg.com/jake/-/jake-10.8.5.tgz#f2183d2c59382cb274226034543b9c03b8164c46" - integrity sha512-sVpxYeuAhWt0OTWITwT98oyV0GsXyMlXCF+3L1SuafBVUIr/uILGRB+NqwkzhgXKvoJpDIpQvqkUALgdmQsQxw== + version "10.8.7" + resolved "https://registry.npmmirror.com/jake/-/jake-10.8.7.tgz#63a32821177940c33f356e0ba44ff9d34e1c7d8f" + integrity sha512-ZDi3aP+fG/LchyBzUM804VjddnwfSfsdeYkwt8NcbKRvo4rFkjhs456iLFn3k2ZUWvNe4i48WACDbza8fhq2+w== dependencies: async "^3.2.3" chalk "^4.0.2" - filelist "^1.0.1" - minimatch "^3.0.4" + filelist "^1.0.4" + minimatch "^3.1.2" -javascript-stringify@^2.0.1: - version "2.1.0" - resolved "https://registry.yarnpkg.com/javascript-stringify/-/javascript-stringify-2.1.0.tgz#27c76539be14d8bd128219a2d731b09337904e79" - integrity sha512-JVAfqNPTvNq3sB/VHQJAFxN/sPgKnsKrCwyRt15zwNCdrMMJDdcEOdubuy+DuJYYdm0ox1J4uzEuYKkN+9yhVg== - -jest-worker@^27.0.2, jest-worker@^27.4.5: - version "27.5.1" - resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.5.1.tgz#8d146f0900e8973b106b6f73cc1e9a8cb86f8db0" - integrity sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg== - dependencies: - "@types/node" "*" - merge-stream "^2.0.0" - supports-color "^8.0.0" - -jimp@^0.22.7: - version "0.22.7" - resolved "https://registry.yarnpkg.com/jimp/-/jimp-0.22.7.tgz#5b1625f61a4f6ba50f85008cdf1929ae911c684b" - integrity sha512-TJCTJ4ZcFUw6W8XZnR6ajdEu8vSyPi3AuoChs+zLHalXnhAPZgwkzwcXnxey4LNjh1p9dfIUkg8YSQ+q8pBW0A== - dependencies: - "@jimp/custom" "^0.22.7" - "@jimp/plugins" "^0.22.7" - "@jimp/types" "^0.22.7" - regenerator-runtime "^0.13.3" - -joi@^17.4.0: - version "17.6.0" - resolved "https://registry.yarnpkg.com/joi/-/joi-17.6.0.tgz#0bb54f2f006c09a96e75ce687957bd04290054b2" - integrity sha512-OX5dG6DTbcr/kbMFj0KGYxuew69HPcAE3K/sZpEV2nP6e/j/C0HV+HNiBPCASxdx5T7DMoa0s8UeHWMnb6n2zw== - dependencies: - "@hapi/hoek" "^9.0.0" - "@hapi/topo" "^5.0.0" - "@sideway/address" "^4.1.3" - "@sideway/formula" "^3.0.0" - "@sideway/pinpoint" "^2.0.0" - -jpeg-js@^0.4.4: - version "0.4.4" - resolved "https://registry.yarnpkg.com/jpeg-js/-/jpeg-js-0.4.4.tgz#a9f1c6f1f9f0fa80cdb3484ed9635054d28936aa" - integrity sha512-WZzeDOEtTOBK4Mdsar0IqEU5sMr3vSV2RqkAIzUEV2BHnUfKGyswWFPFwK5EeDo93K3FohSHbLAjj0s1Wzd+dg== - -js-message@1.0.7: - version "1.0.7" - resolved "https://registry.yarnpkg.com/js-message/-/js-message-1.0.7.tgz#fbddd053c7a47021871bb8b2c95397cc17c20e47" - integrity sha512-efJLHhLjIyKRewNS9EGZ4UpI8NguuL6fKkhRxVuMmrGV2xN/0APGdQYwLFky5w9naebSZ0OwAGp0G6/2Cg90rA== - -js-tokens@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" - integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== +jiti@^1.19.1: + version "1.20.0" + resolved "https://registry.npmmirror.com/jiti/-/jiti-1.20.0.tgz#2d823b5852ee8963585c8dd8b7992ffc1ae83b42" + integrity sha512-3TV69ZbrvV6U5DfQimop50jE9Dl6J8O1ja1dvBbMba/sZ3YBEQqJ2VZRoQPVnhlzjNtU1vaXRZVrVjU4qtm8yA== js-yaml@^4.1.0: version "4.1.0" - resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + resolved "https://registry.npmmirror.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== dependencies: argparse "^2.0.1" jsbn@~0.1.0: version "0.1.1" - resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" + resolved "https://registry.npmmirror.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513" integrity sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg== -jsesc@^2.5.1: - version "2.5.2" - resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" - integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== - -jsesc@~0.5.0: - version "0.5.0" - resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" - integrity sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA== - -json-buffer@3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.0.tgz#5b1f397afc75d677bde8bcfc0e47e1f9a3d9a898" - integrity sha512-CuUqjv0FUZIdXkHPI8MezCnFCdaTAacej1TZYulLoAg1h/PhwkdXFN4V/gzY4g+fMBCOV2xF+rp7t2XD2ns/NQ== - json-buffer@3.0.1: version "3.0.1" - resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13" + resolved "https://registry.npmmirror.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13" integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ== -json-parse-better-errors@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz#bb867cfb3450e69107c131d1c514bab3dc8bcaa9" - integrity sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw== - -json-parse-even-better-errors@^2.3.0, json-parse-even-better-errors@^2.3.1: - version "2.3.1" - resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" - integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== - json-schema-traverse@^0.4.1: version "0.4.1" - resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" + resolved "https://registry.npmmirror.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== json-schema-traverse@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" + resolved "https://registry.npmmirror.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== json-schema-typed@^7.0.3: version "7.0.3" - resolved "https://registry.yarnpkg.com/json-schema-typed/-/json-schema-typed-7.0.3.tgz#23ff481b8b4eebcd2ca123b4fa0409e66469a2d9" + resolved "https://registry.npmmirror.com/json-schema-typed/-/json-schema-typed-7.0.3.tgz#23ff481b8b4eebcd2ca123b4fa0409e66469a2d9" integrity sha512-7DE8mpG+/fVw+dTpjbxnx47TaMnDfOI1jwft9g1VybltZCduyRQPJPvc+zzKY9WPHxhPWczyFuYa6I8Mw4iU5A== json-schema@0.4.0: version "0.4.0" - resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.4.0.tgz#f7de4cf6efab838ebaeb3236474cbba5a1930ab5" + resolved "https://registry.npmmirror.com/json-schema/-/json-schema-0.4.0.tgz#f7de4cf6efab838ebaeb3236474cbba5a1930ab5" integrity sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA== json-stringify-safe@^5.0.1, json-stringify-safe@~5.0.1: version "5.0.1" - resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" + resolved "https://registry.npmmirror.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb" integrity sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA== -json5@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.1.tgz#779fb0018604fa854eacbf6252180d83543e3dbe" - integrity sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow== - dependencies: - minimist "^1.2.0" - -json5@^2.1.2, json5@^2.2.0, json5@^2.2.1: - version "2.2.1" - resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.1.tgz#655d50ed1e6f95ad1a3caababd2b0efda10b395c" - integrity sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA== +json5@^2.2.0: + version "2.2.3" + resolved "https://registry.npmmirror.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283" + integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg== jsonfile@^4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-4.0.0.tgz#8771aae0799b64076b76640fca058f9c10e33ecb" + resolved "https://registry.npmmirror.com/jsonfile/-/jsonfile-4.0.0.tgz#8771aae0799b64076b76640fca058f9c10e33ecb" integrity sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg== optionalDependencies: graceful-fs "^4.1.6" jsonfile@^6.0.1: version "6.1.0" - resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae" + resolved "https://registry.npmmirror.com/jsonfile/-/jsonfile-6.1.0.tgz#bc55b2634793c679ec6403094eb13698a6ec0aae" integrity sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ== dependencies: universalify "^2.0.0" @@ -5665,7 +2209,7 @@ jsonfile@^6.0.1: jsprim@^1.2.2: version "1.4.2" - resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.4.2.tgz#712c65533a15c878ba59e9ed5f0e26d5b77c5feb" + resolved "https://registry.npmmirror.com/jsprim/-/jsprim-1.4.2.tgz#712c65533a15c878ba59e9ed5f0e26d5b77c5feb" integrity sha512-P2bSOMAc/ciLz6DzgjVlGJP9+BrJWu5UDGK70C2iweC5QBIeFf0ZXRvGjEj2uYgrY2MkAAhsSWHDWlFtEroZWw== dependencies: assert-plus "1.0.0" @@ -5673,1619 +2217,616 @@ jsprim@^1.2.2: json-schema "0.4.0" verror "1.10.0" -jszip@^3.1.0: - version "3.10.1" - resolved "https://registry.npmmirror.com/jszip/-/jszip-3.10.1.tgz#34aee70eb18ea1faec2f589208a157d1feb091c2" - integrity sha512-xXDvecyTpGLrqFrvkrUSoxxfJI5AH7U8zxxtVclpsUtMCq4JQ290LY8AW5c7Ggnr/Y/oK+bQMbqK2qmtk3pN4g== - dependencies: - lie "~3.3.0" - pako "~1.0.2" - readable-stream "~2.3.6" - setimmediate "^1.0.5" - -keyv@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/keyv/-/keyv-3.1.0.tgz#ecc228486f69991e49e9476485a5be1e8fc5c4d9" - integrity sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA== - dependencies: - json-buffer "3.0.0" - keyv@^4.0.0: - version "4.5.2" - resolved "https://registry.yarnpkg.com/keyv/-/keyv-4.5.2.tgz#0e310ce73bf7851ec702f2eaf46ec4e3805cce56" - integrity sha512-5MHbFaKn8cNSmVW7BYnijeAVlE4cYA/SVkifVgrh7yotnfhKmjuXpDKjrABLnT0SfHWV21P8ow07OGfRrNDg8g== + version "4.5.4" + resolved "https://registry.npmmirror.com/keyv/-/keyv-4.5.4.tgz#a879a99e29452f942439f2a405e3af8b31d4de93" + integrity sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw== dependencies: json-buffer "3.0.1" -kind-of@^6.0.2: - version "6.0.3" - resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.3.tgz#07c05034a6c349fa06e24fa35aa76db4580ce4dd" - integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== - -klona@^2.0.5: - version "2.0.5" - resolved "https://registry.yarnpkg.com/klona/-/klona-2.0.5.tgz#d166574d90076395d9963aa7a928fabb8d76afbc" - integrity sha512-pJiBpiXMbt7dkzXe8Ghj/u4FfXOOa98fPW+bihOJ4SjnoijweJrNThJfd3ifXpXhREjpoF2mZVH1GfS9LV3kHQ== - -latest-version@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/latest-version/-/latest-version-5.1.0.tgz#119dfe908fe38d15dfa43ecd13fa12ec8832face" - integrity sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA== - dependencies: - package-json "^6.3.0" - -launch-editor-middleware@^2.2.1: - version "2.6.0" - resolved "https://registry.yarnpkg.com/launch-editor-middleware/-/launch-editor-middleware-2.6.0.tgz#2ba4fe4b695d7fe3d44dee86b6d46d57b8332dfd" - integrity sha512-K2yxgljj5TdCeRN1lBtO3/J26+AIDDDw+04y6VAiZbWcTdBwsYN6RrZBnW5DN/QiSIdKNjKdATLUUluWWFYTIA== - dependencies: - launch-editor "^2.6.0" - -launch-editor@^2.2.1, launch-editor@^2.6.0: - version "2.6.0" - resolved "https://registry.yarnpkg.com/launch-editor/-/launch-editor-2.6.0.tgz#4c0c1a6ac126c572bd9ff9a30da1d2cae66defd7" - integrity sha512-JpDCcQnyAAzZZaZ7vEiSqL690w7dAEyLao+KC96zBplnYbJS7TYNjvM3M7y3dGz+v7aIsJk3hllWuc0kWAjyRQ== - dependencies: - picocolors "^1.0.0" - shell-quote "^1.7.3" - lazy-val@^1.0.4, lazy-val@^1.0.5: version "1.0.5" - resolved "https://registry.yarnpkg.com/lazy-val/-/lazy-val-1.0.5.tgz#6cf3b9f5bc31cee7ee3e369c0832b7583dcd923d" + resolved "https://registry.npmmirror.com/lazy-val/-/lazy-val-1.0.5.tgz#6cf3b9f5bc31cee7ee3e369c0832b7583dcd923d" integrity sha512-0/BnGCCfyUMkBpeDgWihanIAF9JmZhHBgUhEqzvf+adhNGLoP6TaiI5oF8oyb3I45P+PcnrqihSf01M0l0G5+Q== -lie@~3.3.0: - version "3.3.0" - resolved "https://registry.npmmirror.com/lie/-/lie-3.3.0.tgz#dcf82dee545f46074daf200c7c1c5a08e0f40f6a" - integrity sha512-UaiMJzeWRlEujzAuw5LokY1L5ecNQYZKfmyZ9L7wDHb/p5etKaxXhohBcrw0EYby+G/NA52vRSN4N39dxHAIwQ== - dependencies: - immediate "~3.0.5" +less-loader@^11.1.3: + version "11.1.3" + resolved "https://registry.npmmirror.com/less-loader/-/less-loader-11.1.3.tgz#1bb62d6ca9bf00a177c02793b54baac40f9be694" + integrity sha512-A5b7O8dH9xpxvkosNrP0dFp2i/dISOJa9WwGF3WJflfqIERE2ybxh1BFDj5CovC2+jCE4M354mk90hN6ziXlVw== -lilconfig@^2.0.3, lilconfig@^2.0.5, lilconfig@^2.0.6: - version "2.0.6" - resolved "https://registry.yarnpkg.com/lilconfig/-/lilconfig-2.0.6.tgz#32a384558bd58af3d4c6e077dd1ad1d397bc69d4" - integrity sha512-9JROoBW7pobfsx+Sq2JsASvCo6Pfo6WWoUW79HuB1BCoBXD4PLWJPqDF6fNj67pqBYTbAHkE57M1kS/+L1neOg== +less@^4.2.0: + version "4.2.0" + resolved "https://registry.npmmirror.com/less/-/less-4.2.0.tgz#cbefbfaa14a4cd388e2099b2b51f956e1465c450" + integrity sha512-P3b3HJDBtSzsXUl0im2L7gTO5Ubg8mEN6G8qoTS77iXxXX4Hvu4Qj540PZDvQ8V6DmX6iXo98k7Md0Cm1PrLaA== + dependencies: + copy-anything "^2.0.1" + parse-node-version "^1.0.1" + tslib "^2.3.0" + optionalDependencies: + errno "^0.1.1" + graceful-fs "^4.1.2" + image-size "~0.5.0" + make-dir "^2.1.0" + mime "^1.4.1" + needle "^3.1.0" + source-map "~0.6.0" + +lilconfig@^2.0.5, lilconfig@^2.1.0: + version "2.1.0" + resolved "https://registry.npmmirror.com/lilconfig/-/lilconfig-2.1.0.tgz#78e23ac89ebb7e1bfbf25b18043de756548e7f52" + integrity sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ== lines-and-columns@^1.1.6: version "1.2.4" - resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632" + resolved "https://registry.npmmirror.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632" integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg== -load-bmfont@^1.4.1: - version "1.4.1" - resolved "https://registry.yarnpkg.com/load-bmfont/-/load-bmfont-1.4.1.tgz#c0f5f4711a1e2ccff725a7b6078087ccfcddd3e9" - integrity sha512-8UyQoYmdRDy81Brz6aLAUhfZLwr5zV0L3taTQ4hju7m6biuwiWiJXjPhBJxbUQJA8PrkvJ/7Enqmwk2sM14soA== - dependencies: - buffer-equal "0.0.1" - mime "^1.3.4" - parse-bmfont-ascii "^1.0.3" - parse-bmfont-binary "^1.0.5" - parse-bmfont-xml "^1.1.4" - phin "^2.9.1" - xhr "^2.0.1" - xtend "^4.0.0" - -loader-runner@^4.1.0, loader-runner@^4.2.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-4.3.0.tgz#c1b4a163b99f614830353b16755e7149ac2314e1" - integrity sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg== - -loader-utils@^1.0.2, loader-utils@^1.1.0: - version "1.4.0" - resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-1.4.0.tgz#c579b5e34cb34b1a74edc6c1fb36bfa371d5a613" - integrity sha512-qH0WSMBtn/oHuwjy/NucEgbx5dbxxnxup9s4PVXJUDHZBQY+s0NWA9rJf53RBnQZxfch7euUui7hpoAPvALZdA== - dependencies: - big.js "^5.2.2" - emojis-list "^3.0.0" - json5 "^1.0.1" - -loader-utils@^2.0.0: - version "2.0.2" - resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-2.0.2.tgz#d6e3b4fb81870721ae4e0868ab11dd638368c129" - integrity sha512-TM57VeHptv569d/GKh6TAYdzKblwDNiumOdkFnejjD0XwTH87K90w3O7AiJRqdQoXygvi1VQTJTLGhJl7WqA7A== - dependencies: - big.js "^5.2.2" - emojis-list "^3.0.0" - json5 "^2.1.2" - locate-path@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" + resolved "https://registry.npmmirror.com/locate-path/-/locate-path-3.0.0.tgz#dbec3b3ab759758071b58fe59fc41871af21400e" integrity sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A== dependencies: p-locate "^3.0.0" path-exists "^3.0.0" -locate-path@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-5.0.0.tgz#1afba396afd676a6d42504d0a67a3a7eb9f62aa0" - integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g== - dependencies: - p-locate "^4.1.0" - -lodash.debounce@^4.0.8: - version "4.0.8" - resolved "https://registry.yarnpkg.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz#82d79bff30a67c4005ffd5e2515300ad9ca4d7af" - integrity sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow== - -lodash.defaultsdeep@^4.6.1: - version "4.6.1" - resolved "https://registry.yarnpkg.com/lodash.defaultsdeep/-/lodash.defaultsdeep-4.6.1.tgz#512e9bd721d272d94e3d3a63653fa17516741ca6" - integrity sha512-3j8wdDzYuWO3lM3Reg03MuQR957t287Rpcxp1njpEa8oDrikb+FwGdW3n+FELh/A6qib6yPit0j/pv9G/yeAqA== - -lodash.kebabcase@^4.1.1: - version "4.1.1" - resolved "https://registry.yarnpkg.com/lodash.kebabcase/-/lodash.kebabcase-4.1.1.tgz#8489b1cb0d29ff88195cceca448ff6d6cc295c36" - integrity sha512-N8XRTIMMqqDgSy4VLKPnJ/+hpGZN+PHQiJnSenYqPaVV/NCqEogTnAdZLQiGKhxX+JCs8waWq2t1XHWKOmlY8g== - -lodash.mapvalues@^4.6.0: - version "4.6.0" - resolved "https://registry.yarnpkg.com/lodash.mapvalues/-/lodash.mapvalues-4.6.0.tgz#1bafa5005de9dd6f4f26668c30ca37230cc9689c" - integrity sha512-JPFqXFeZQ7BfS00H58kClY7SPVeHertPE0lNuCyZ26/XlN8TvakYD7b9bGyNmXbT/D3BbtPAAmq90gPWqLkxlQ== - -lodash.memoize@^4.1.2: - version "4.1.2" - resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe" - integrity sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag== - -lodash.merge@^4.6.1: - version "4.6.2" - resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" - integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== - -lodash.throttle@^4.1.1: - version "4.1.1" - resolved "https://registry.yarnpkg.com/lodash.throttle/-/lodash.throttle-4.1.1.tgz#c23e91b710242ac70c37f1e1cda9274cc39bf2f4" - integrity sha512-wIkUCfVKpVsWo3JSZlc+8MB5it+2AN5W8J7YVMST30UrvcQNZ1Okbj+rbVniijTWE6FGYy4XJq/rHkas8qJMLQ== - -lodash.uniq@^4.5.0: - version "4.5.0" - resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773" - integrity sha512-xfBaXQd9ryd9dlSDvnvI0lvxfLJlYAZzXomUYzLKtUeOQvOP5piqAWuGtrhWeqaXK9hhoM/iyJc5AV+XfsX3HQ== - -lodash@^4.17.14, lodash@^4.17.15, lodash@^4.17.20, lodash@^4.17.21: +lodash-es@^4.17.21: version "4.17.21" - resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" + resolved "https://registry.npmmirror.com/lodash-es/-/lodash-es-4.17.21.tgz#43e626c46e6591b7750beb2b50117390c609e3ee" + integrity sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw== + +lodash@^4.17.15, lodash@^4.17.21: + version "4.17.21" + resolved "https://registry.npmmirror.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== -log-symbols@^2.2.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/log-symbols/-/log-symbols-2.2.0.tgz#5740e1c5d6f0dfda4ad9323b5332107ef6b4c40a" - integrity sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg== - dependencies: - chalk "^2.0.1" - -log-symbols@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/log-symbols/-/log-symbols-4.1.0.tgz#3fbdbb95b4683ac9fc785111e792e558d4abd503" - integrity sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg== - dependencies: - chalk "^4.1.0" - is-unicode-supported "^0.1.0" - -log-update@^2.3.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/log-update/-/log-update-2.3.0.tgz#88328fd7d1ce7938b29283746f0b1bc126b24708" - integrity sha512-vlP11XfFGyeNQlmEn9tJ66rEW1coA/79m5z6BCkudjbAGE83uhAcGYrBFwfs3AdLiLzGRusRPAbSPK9xZteCmg== - dependencies: - ansi-escapes "^3.0.0" - cli-cursor "^2.0.0" - wrap-ansi "^3.0.1" - -lower-case@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/lower-case/-/lower-case-2.0.2.tgz#6fa237c63dbdc4a82ca0fd882e4722dc5e634e28" - integrity sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg== - dependencies: - tslib "^2.0.3" - -lowercase-keys@^1.0.0, lowercase-keys@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-1.0.1.tgz#6f9e30b47084d971a7c820ff15a6c5167b74c26f" - integrity sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA== - lowercase-keys@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-2.0.0.tgz#2603e78b7b4b0006cbca2fbcc8a3202558ac9479" + resolved "https://registry.npmmirror.com/lowercase-keys/-/lowercase-keys-2.0.0.tgz#2603e78b7b4b0006cbca2fbcc8a3202558ac9479" integrity sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA== -lru-cache@^4.1.2: - version "4.1.5" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-4.1.5.tgz#8bbe50ea85bed59bc9e33dcab8235ee9bcf443cd" - integrity sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g== - dependencies: - pseudomap "^1.0.2" - yallist "^2.1.2" - lru-cache@^6.0.0: version "6.0.0" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + resolved "https://registry.npmmirror.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== dependencies: yallist "^4.0.0" -lru-cache@^7.7.1: - version "7.18.3" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-7.18.3.tgz#f793896e0fd0e954a59dfdd82f0773808df6aa89" - integrity sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA== - -magic-string@^0.30.0: - version "0.30.0" - resolved "https://registry.yarnpkg.com/magic-string/-/magic-string-0.30.0.tgz#fd58a4748c5c4547338a424e90fa5dd17f4de529" - integrity sha512-LA+31JYDJLs82r2ScLrlz1GjSgu66ZV518eyWT+S8VhyQn/JL0u9MeBOvQMGYiPk1DBiSN9DDMOcXvigJZaViQ== +magic-string@^0.30.5: + version "0.30.5" + resolved "https://registry.npmmirror.com/magic-string/-/magic-string-0.30.5.tgz#1994d980bd1c8835dc6e78db7cbd4ae4f24746f9" + integrity sha512-7xlpfBaQaP/T6Vh8MO/EqXSW5En6INHEvEXQiuff7Gku0PWjU3uf6w/j9o7O+SpB5fOAkrI5HeoNgwjEO0pFsA== dependencies: - "@jridgewell/sourcemap-codec" "^1.4.13" + "@jridgewell/sourcemap-codec" "^1.4.15" -make-dir@^3.0.0, make-dir@^3.0.2, make-dir@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" - integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== +make-dir@^2.1.0: + version "2.1.0" + resolved "https://registry.npmmirror.com/make-dir/-/make-dir-2.1.0.tgz#5f0310e18b8be898cc07009295a30ae41e91e6f5" + integrity sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA== dependencies: - semver "^6.0.0" - -make-fetch-happen@^10.0.3: - version "10.2.1" - resolved "https://registry.yarnpkg.com/make-fetch-happen/-/make-fetch-happen-10.2.1.tgz#f5e3835c5e9817b617f2770870d9492d28678164" - integrity sha512-NgOPbRiaQM10DYXvN3/hhGVI2M5MtITFryzBGxHM5p4wnFxsVCbxkrBrDsk+EZ5OB4jEOT7AjDxtdF+KVEFT7w== - dependencies: - agentkeepalive "^4.2.1" - cacache "^16.1.0" - http-cache-semantics "^4.1.0" - http-proxy-agent "^5.0.0" - https-proxy-agent "^5.0.0" - is-lambda "^1.0.1" - lru-cache "^7.7.1" - minipass "^3.1.6" - minipass-collect "^1.0.2" - minipass-fetch "^2.0.3" - minipass-flush "^1.0.5" - minipass-pipeline "^1.2.4" - negotiator "^0.6.3" - promise-retry "^2.0.1" - socks-proxy-agent "^7.0.0" - ssri "^9.0.0" + pify "^4.0.1" + semver "^5.6.0" matcher@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/matcher/-/matcher-3.0.0.tgz#bd9060f4c5b70aa8041ccc6f80368760994f30ca" + resolved "https://registry.npmmirror.com/matcher/-/matcher-3.0.0.tgz#bd9060f4c5b70aa8041ccc6f80368760994f30ca" integrity sha512-OkeDaAZ/bQCxeFAozM55PKcKU0yJMPGifLwV4Qgjitu+5MoAfSQN4lsLJeXZ1b8w0x+/Emda6MZgXS1jvsapng== dependencies: escape-string-regexp "^4.0.0" -material-colors@^1.2.6: - version "1.2.6" - resolved "https://registry.yarnpkg.com/material-colors/-/material-colors-1.2.6.tgz#6d1958871126992ceecc72f4bcc4d8f010865f46" - integrity sha512-6qE4B9deFBIa9YSpOc9O0Sgc43zTeVYbgDT5veRKSlB2+ZuHNoVVxA1L/ckMUayV9Ay9y7Z/SZCLcGteW9i7bg== - -mdn-data@2.0.14: - version "2.0.14" - resolved "https://registry.yarnpkg.com/mdn-data/-/mdn-data-2.0.14.tgz#7113fc4281917d63ce29b43446f701e68c25ba50" - integrity sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow== - -media-typer@0.3.0: - version "0.3.0" - resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" - integrity sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ== - -memfs@^3.4.3: - version "3.4.7" - resolved "https://registry.yarnpkg.com/memfs/-/memfs-3.4.7.tgz#e5252ad2242a724f938cb937e3c4f7ceb1f70e5a" - integrity sha512-ygaiUSNalBX85388uskeCyhSAoOSgzBbtVCr9jA2RROssFL9Q19/ZXFqS+2Th2sr1ewNIWgFdLzLC3Yl1Zv+lw== - dependencies: - fs-monkey "^1.0.3" - -merge-descriptors@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" - integrity sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w== - -merge-source-map@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/merge-source-map/-/merge-source-map-1.1.0.tgz#2fdde7e6020939f70906a68f2d7ae685e4c8c646" - integrity sha512-Qkcp7P2ygktpMPh2mCQZaf3jhN6D3Z/qVZHSdWvQ+2Ef5HgRAPBO57A77+ENm0CPx2+1Ce/MYKi3ymqdfuqibw== - dependencies: - source-map "^0.6.1" - -merge-stream@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" - integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== - -merge2@^1.3.0, merge2@^1.4.1: +merge2@^1.3.0: version "1.4.1" - resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + resolved "https://registry.npmmirror.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== -methods@~1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" - integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== - -micromatch@^4.0.2, micromatch@^4.0.4: +micromatch@^4.0.4, micromatch@^4.0.5: version "4.0.5" - resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" + resolved "https://registry.npmmirror.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== dependencies: braces "^3.0.2" picomatch "^2.3.1" -mime-db@1.52.0, "mime-db@>= 1.43.0 < 2": +mime-db@1.52.0: version "1.52.0" - resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" + resolved "https://registry.npmmirror.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== -mime-types@^2.1.12, mime-types@^2.1.27, mime-types@^2.1.31, mime-types@~2.1.17, mime-types@~2.1.19, mime-types@~2.1.24, mime-types@~2.1.34: +mime-types@^2.1.12, mime-types@~2.1.19: version "2.1.35" - resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" + resolved "https://registry.npmmirror.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== dependencies: mime-db "1.52.0" -mime@1.6.0, mime@^1.3.4: +mime@^1.4.1: version "1.6.0" - resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" + resolved "https://registry.npmmirror.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== mime@^2.5.2: version "2.6.0" - resolved "https://registry.yarnpkg.com/mime/-/mime-2.6.0.tgz#a2a682a95cd4d0cb1d6257e28f83da7e35800367" + resolved "https://registry.npmmirror.com/mime/-/mime-2.6.0.tgz#a2a682a95cd4d0cb1d6257e28f83da7e35800367" integrity sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg== mime@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/mime/-/mime-3.0.0.tgz#b374550dca3a0c18443b0c950a6a58f1931cf7a7" + resolved "https://registry.npmmirror.com/mime/-/mime-3.0.0.tgz#b374550dca3a0c18443b0c950a6a58f1931cf7a7" integrity sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A== -mimic-fn@^1.0.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-1.2.0.tgz#820c86a39334640e99516928bd03fca88057d022" - integrity sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ== - mimic-fn@^2.1.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" + resolved "https://registry.npmmirror.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== mimic-fn@^3.0.0: version "3.1.0" - resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-3.1.0.tgz#65755145bbf3e36954b949c16450427451d5ca74" + resolved "https://registry.npmmirror.com/mimic-fn/-/mimic-fn-3.1.0.tgz#65755145bbf3e36954b949c16450427451d5ca74" integrity sha512-Ysbi9uYW9hFyfrThdDEQuykN4Ey6BuwPD2kpI5ES/nFTDn/98yxYNLZJcgUAKPT/mcrLLKaGzJR9YVxJrIdASQ== -mimic-response@^1.0.0, mimic-response@^1.0.1: +mimic-response@^1.0.0: version "1.0.1" - resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-1.0.1.tgz#4923538878eef42063cb8a3e3b0798781487ab1b" + resolved "https://registry.npmmirror.com/mimic-response/-/mimic-response-1.0.1.tgz#4923538878eef42063cb8a3e3b0798781487ab1b" integrity sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ== mimic-response@^3.1.0: version "3.1.0" - resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-3.1.0.tgz#2d1d59af9c1b129815accc2c46a022a5ce1fa3c9" + resolved "https://registry.npmmirror.com/mimic-response/-/mimic-response-3.1.0.tgz#2d1d59af9c1b129815accc2c46a022a5ce1fa3c9" integrity sha512-z0yWI+4FDrrweS8Zmt4Ej5HdJmky15+L2e6Wgn3+iK5fWzb6T3fhNFq2+MeTRb064c6Wr4N/wv0DzQTjNzHNGQ== -min-document@^2.19.0: - version "2.19.0" - resolved "https://registry.yarnpkg.com/min-document/-/min-document-2.19.0.tgz#7bd282e3f5842ed295bb748cdd9f1ffa2c824685" - integrity sha512-9Wy1B3m3f66bPPmU5hdA4DR4PB2OfDU/+GS3yAB7IQozE3tqXaVv2zOjgla7MEGSRv95+ILmOuvhLkOK6wJtCQ== - dependencies: - dom-walk "^0.1.0" - -mini-css-extract-plugin@^2.5.3: - version "2.6.1" - resolved "https://registry.yarnpkg.com/mini-css-extract-plugin/-/mini-css-extract-plugin-2.6.1.tgz#9a1251d15f2035c342d99a468ab9da7a0451b71e" - integrity sha512-wd+SD57/K6DiV7jIR34P+s3uckTRuQvx0tKPcvjFlrEylk6P4mQ2KSWk1hblj1Kxaqok7LogKOieygXqBczNlg== - dependencies: - schema-utils "^4.0.0" - -mini-svg-data-uri@^1.2.3: - version "1.4.4" - resolved "https://registry.yarnpkg.com/mini-svg-data-uri/-/mini-svg-data-uri-1.4.4.tgz#8ab0aabcdf8c29ad5693ca595af19dd2ead09939" - integrity sha512-r9deDe9p5FJUPZAk3A59wGH7Ii9YrjjWw0jmw/liSbHl2CHiyXj6FcDXDu2K3TjVAXqiJdaw3xxwlZZr9E6nHg== - -minimalistic-assert@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" - integrity sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A== - -minimatch@3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" - integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== - dependencies: - brace-expansion "^1.1.7" - -minimatch@^3.0.4, minimatch@^3.1.1: +minimatch@^3.0.4, minimatch@^3.1.1, minimatch@^3.1.2: version "3.1.2" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" + resolved "https://registry.npmmirror.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== dependencies: brace-expansion "^1.1.7" -minimatch@^5.0.1: - version "5.1.0" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.0.tgz#1717b464f4971b144f6aabe8f2d0b8e4511e09c7" - integrity sha512-9TPBGGak4nHfGZsPBohm9AWg6NoT7QTCehS3BIJABslyZbzxfV78QM2Y6+i741OPZIafFAaiiEMh5OyIrJPgtg== - dependencies: - brace-expansion "^2.0.1" - -minimatch@^5.1.1: +minimatch@^5.0.1, minimatch@^5.1.1: version "5.1.6" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.6.tgz#1cfcb8cf5522ea69952cd2af95ae09477f122a96" + resolved "https://registry.npmmirror.com/minimatch/-/minimatch-5.1.6.tgz#1cfcb8cf5522ea69952cd2af95ae09477f122a96" integrity sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g== dependencies: brace-expansion "^2.0.1" -minimist@^1.2.0, minimist@^1.2.5, minimist@^1.2.6: - version "1.2.6" - resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" - integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== - -minipass-collect@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/minipass-collect/-/minipass-collect-1.0.2.tgz#22b813bf745dc6edba2576b940022ad6edc8c617" - integrity sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA== +minimatch@^9.0.3: + version "9.0.3" + resolved "https://registry.npmmirror.com/minimatch/-/minimatch-9.0.3.tgz#a6e00c3de44c3a542bfaae70abfc22420a6da825" + integrity sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg== dependencies: - minipass "^3.0.0" + brace-expansion "^2.0.1" -minipass-fetch@^2.0.3: - version "2.1.2" - resolved "https://registry.yarnpkg.com/minipass-fetch/-/minipass-fetch-2.1.2.tgz#95560b50c472d81a3bc76f20ede80eaed76d8add" - integrity sha512-LT49Zi2/WMROHYoqGgdlQIZh8mLPZmOrN2NdJjMXxYe4nkN6FUyuPuOAOedNJDrx0IRGg9+4guZewtp8hE6TxA== - dependencies: - minipass "^3.1.6" - minipass-sized "^1.0.3" - minizlib "^2.1.2" - optionalDependencies: - encoding "^0.1.13" +minimist@^1.2.0, minimist@^1.2.3, minimist@^1.2.6: + version "1.2.8" + resolved "https://registry.npmmirror.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" + integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== -minipass-flush@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/minipass-flush/-/minipass-flush-1.0.5.tgz#82e7135d7e89a50ffe64610a787953c4c4cbb373" - integrity sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw== - dependencies: - minipass "^3.0.0" - -minipass-pipeline@^1.2.4: - version "1.2.4" - resolved "https://registry.yarnpkg.com/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz#68472f79711c084657c067c5c6ad93cddea8214c" - integrity sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A== - dependencies: - minipass "^3.0.0" - -minipass-sized@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/minipass-sized/-/minipass-sized-1.0.3.tgz#70ee5a7c5052070afacfbc22977ea79def353b70" - integrity sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g== - dependencies: - minipass "^3.0.0" - -minipass@^3.0.0, minipass@^3.1.1: - version "3.3.4" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.3.4.tgz#ca99f95dd77c43c7a76bf51e6d200025eee0ffae" - integrity sha512-I9WPbWHCGu8W+6k1ZiGpPu0GkoKBeorkfKNuAFBNS1HNFJvke82sxvI5bzcCNpWPorkOO5QQ+zomzzwRxejXiw== - dependencies: - yallist "^4.0.0" - -minipass@^3.1.6: +minipass@^3.0.0: version "3.3.6" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-3.3.6.tgz#7bba384db3a1520d18c9c0e5251c3444e95dd94a" + resolved "https://registry.npmmirror.com/minipass/-/minipass-3.3.6.tgz#7bba384db3a1520d18c9c0e5251c3444e95dd94a" integrity sha512-DxiNidxSEK+tHG6zOIklvNOwm3hvCrbUrdtzY74U6HKTJxvIDfOUL5W5P2Ghd3DTkhhKPYGqeNUIh5qcM4YBfw== dependencies: yallist "^4.0.0" minipass@^5.0.0: version "5.0.0" - resolved "https://registry.yarnpkg.com/minipass/-/minipass-5.0.0.tgz#3e9788ffb90b694a5d0ec94479a45b5d8738133d" + resolved "https://registry.npmmirror.com/minipass/-/minipass-5.0.0.tgz#3e9788ffb90b694a5d0ec94479a45b5d8738133d" integrity sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ== -minizlib@^2.1.1, minizlib@^2.1.2: +minizlib@^2.1.1: version "2.1.2" - resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" + resolved "https://registry.npmmirror.com/minizlib/-/minizlib-2.1.2.tgz#e90d3466ba209b932451508a11ce3d3632145931" integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== dependencies: minipass "^3.0.0" yallist "^4.0.0" -mkdirp@^0.5.1, mkdirp@^0.5.6: - version "0.5.6" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.6.tgz#7def03d2432dcae4ba1d611445c48396062255f6" - integrity sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw== - dependencies: - minimist "^1.2.6" +mkdirp-classic@^0.5.2, mkdirp-classic@^0.5.3: + version "0.5.3" + resolved "https://registry.npmmirror.com/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz#fa10c9115cc6d8865be221ba47ee9bed78601113" + integrity sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A== -mkdirp@^1.0.3, mkdirp@^1.0.4: +mkdirp@^1.0.3: version "1.0.4" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" + resolved "https://registry.npmmirror.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== -mkdirp@^2.1.3: - version "2.1.6" - resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-2.1.6.tgz#964fbcb12b2d8c5d6fbc62a963ac95a273e2cc19" - integrity sha512-+hEnITedc8LAtIP9u3HJDFIdcLV2vXP33sqLLIzkv1Db1zO/1OxbvYf0Y1OC/S/Qo5dxHXepofhmxL02PsKe+A== - -modclean-patterns-default@latest: - version "1.1.2" - resolved "https://registry.yarnpkg.com/modclean-patterns-default/-/modclean-patterns-default-1.1.2.tgz#9b2d53e3abd707edcf0c1501b4d5ac04c947a283" - integrity sha512-h2+ES3SKl+JOtfptJjwJz5fdogFI0byYssw3lXoESNkOcXCnjCvvW6IbMagAKFmfWOx+n9esyomxWP1w4edZjg== - -modclean@^3.0.0-beta.1: - version "3.0.0-beta.1" - resolved "https://registry.yarnpkg.com/modclean/-/modclean-3.0.0-beta.1.tgz#34acdd610f130c2a833dc254486e2a260006d5bf" - integrity sha512-NyJpuqXMUI190sZePU+dBcwlGaqhfFC+UL5WyNSxmNLOHATg9cVSgRpbY+mUbwUj7t5trb4vYscgXArKevYsdA== - dependencies: - await-handler "^1.1.0" - chalk "^2.4.1" - commander "^2.9.0" - empty-dir "^1.0.0" - glob "^7.1.2" - lodash.uniq "^4.5.0" - modclean-patterns-default latest - ora "^2.1.0" - progress "^2.0.0" - rimraf "^2.5.4" - subdirs "^1.0.1" - -module-alias@^2.2.2: - version "2.2.2" - resolved "https://registry.yarnpkg.com/module-alias/-/module-alias-2.2.2.tgz#151cdcecc24e25739ff0aa6e51e1c5716974c0e0" - integrity sha512-A/78XjoX2EmNvppVWEhM2oGk3x4lLxnkEA4jTbaK97QKSDjkIoOsKQlfylt/d3kKKi596Qy3NP5XrXJ6fZIC9Q== - -mrmime@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/mrmime/-/mrmime-1.0.1.tgz#5f90c825fad4bdd41dc914eff5d1a8cfdaf24f27" - integrity sha512-hzzEagAgDyoU1Q6yg5uI+AorQgdvMCur3FcKf7NhMKWsaYg+RnbTyHRa/9IlLF9rf455MOCtcqqrQQ83pPP7Uw== - -ms@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" - integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== - ms@2.1.2: version "2.1.2" - resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" + resolved "https://registry.npmmirror.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== -ms@2.1.3, ms@^2.0.0, ms@^2.1.1: +ms@^2.1.1: version "2.1.3" - resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" + resolved "https://registry.npmmirror.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== -multicast-dns@^7.2.5: - version "7.2.5" - resolved "https://registry.yarnpkg.com/multicast-dns/-/multicast-dns-7.2.5.tgz#77eb46057f4d7adbd16d9290fa7299f6fa64cced" - integrity sha512-2eznPJP8z2BFLX50tf0LuODrpINqP1RVIm/CObbTcBRITQgmC/TjcREF1NeTBzIcR5XO/ukWo+YHOjBbFwIupg== - dependencies: - dns-packet "^5.2.2" - thunky "^1.0.2" +muggle-string@^0.3.1: + version "0.3.1" + resolved "https://registry.npmmirror.com/muggle-string/-/muggle-string-0.3.1.tgz#e524312eb1728c63dd0b2ac49e3282e6ed85963a" + integrity sha512-ckmWDJjphvd/FvZawgygcUeQCxzvohjFO5RxTjj4eq8kw359gFF3E1brjfI+viLMxss5JrHTDRHZvu2/tuy0Qg== -mz@^2.4.0: +mz@^2.7.0: version "2.7.0" - resolved "https://registry.yarnpkg.com/mz/-/mz-2.7.0.tgz#95008057a56cafadc2bc63dde7f9ff6955948e32" + resolved "https://registry.npmmirror.com/mz/-/mz-2.7.0.tgz#95008057a56cafadc2bc63dde7f9ff6955948e32" integrity sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q== dependencies: any-promise "^1.0.0" object-assign "^4.0.1" thenify-all "^1.0.0" -nanoid@^3.3.4: - version "3.3.4" - resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.4.tgz#730b67e3cd09e2deacf03c027c81c9d9dbc5e8ab" - integrity sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw== - -negotiator@0.6.3, negotiator@^0.6.3: - version "0.6.3" - resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" - integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== - -neo-async@^2.6.2: - version "2.6.2" - resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.6.2.tgz#b4aafb93e3aeb2d8174ca53cf163ab7d7308305f" - integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw== - -nice-try@^1.0.4: - version "1.0.5" - resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366" - integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== - -no-case@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/no-case/-/no-case-3.0.4.tgz#d361fd5c9800f558551a8369fc0dcd4662b6124d" - integrity sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg== +naive-ui@^2.35.0: + version "2.35.0" + resolved "https://registry.npmmirror.com/naive-ui/-/naive-ui-2.35.0.tgz#fe1fc2404694b4114486fa31e609e35714e8ed25" + integrity sha512-PdnLpOip1LQaKs5+rXLZoPDPQkTq26TnHWeABvUA2eOQjtHxE4+TQvj0Jq/W8clM2On/7jptoGmenLt48G3Bhg== dependencies: - lower-case "^2.0.2" - tslib "^2.0.3" + "@css-render/plugin-bem" "^0.15.12" + "@css-render/vue3-ssr" "^0.15.12" + "@types/katex" "^0.16.2" + "@types/lodash" "^4.14.198" + "@types/lodash-es" "^4.17.9" + async-validator "^4.2.5" + css-render "^0.15.12" + date-fns "^2.30.0" + date-fns-tz "^2.0.0" + evtd "^0.2.4" + highlight.js "^11.8.0" + lodash "^4.17.21" + lodash-es "^4.17.21" + seemly "^0.3.6" + treemate "^0.3.11" + vdirs "^0.1.8" + vooks "^0.2.12" + vueuc "^0.4.51" -node-abi@^3.0.0: - version "3.40.0" - resolved "https://registry.yarnpkg.com/node-abi/-/node-abi-3.40.0.tgz#51d8ed44534f70ff1357dfbc3a89717b1ceac1b4" - integrity sha512-zNy02qivjjRosswoYmPi8hIKJRr8MpQyeKT6qlcq/OnOgA3Rhoae+IYOqsM9V5+JnHWmxKnWOT2GxvtqdtOCXA== +nanoid@^3.3.6: + version "3.3.6" + resolved "https://registry.npmmirror.com/nanoid/-/nanoid-3.3.6.tgz#443380c856d6e9f9824267d960b4236ad583ea4c" + integrity sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA== + +napi-build-utils@^1.0.1: + version "1.0.2" + resolved "https://registry.npmmirror.com/napi-build-utils/-/napi-build-utils-1.0.2.tgz#b1fddc0b2c46e380a0b7a76f984dd47c41a13806" + integrity sha512-ONmRUqK7zj7DWX0D9ADe03wbwOBZxNAfF20PlGfCWQcD3+/MakShIHrMqx9YwPTfxDdF1zLeL+RGZiR9kGMLdg== + +needle@^3.1.0: + version "3.2.0" + resolved "https://registry.npmmirror.com/needle/-/needle-3.2.0.tgz#07d240ebcabfd65c76c03afae7f6defe6469df44" + integrity sha512-oUvzXnyLiVyVGoianLijF9O/RecZUf7TkBfimjGrLM4eQhXyeJwM6GeAWccwfQ9aa4gMCZKqhAOuLaMIcQxajQ== + dependencies: + debug "^3.2.6" + iconv-lite "^0.6.3" + sax "^1.2.4" + +node-abi@^3.3.0: + version "3.51.0" + resolved "https://registry.npmmirror.com/node-abi/-/node-abi-3.51.0.tgz#970bf595ef5a26a271307f8a4befa02823d4e87d" + integrity sha512-SQkEP4hmNWjlniS5zdnfIXTk1x7Ome85RDzHlTbBtzE97Gfwz/Ipw4v/Ryk20DWIy3yCNVLVlGKApCnmvYoJbA== dependencies: semver "^7.3.5" node-addon-api@^1.6.3: version "1.7.2" - resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-1.7.2.tgz#3df30b95720b53c24e59948b49532b662444f54d" + resolved "https://registry.npmmirror.com/node-addon-api/-/node-addon-api-1.7.2.tgz#3df30b95720b53c24e59948b49532b662444f54d" integrity sha512-ibPK3iA+vaY1eEjESkQkM0BbCqFOaZMiXRTtdB0u7b4djtY6JnsjvPdUHVMg6xQt3B8fpTTWHI9A+ADjM9frzg== -node-addon-api@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-5.0.0.tgz#7d7e6f9ef89043befdb20c1989c905ebde18c501" - integrity sha512-CvkDw2OEnme7ybCykJpVcKH+uAOLV2qLqiyla128dN9TkEWfrYmxG6C2boDe5KcNQqZF3orkqzGgOMvZ/JNekA== - -node-api-version@^0.1.4: - version "0.1.4" - resolved "https://registry.yarnpkg.com/node-api-version/-/node-api-version-0.1.4.tgz#1ed46a485e462d55d66b5aa1fe2821720dedf080" - integrity sha512-KGXihXdUChwJAOHO53bv9/vXcLmdUsZ6jIptbvYvkpKfth+r7jw44JkVxQFA3kX5nQjzjmGu1uAu/xNNLNlI5g== - dependencies: - semver "^7.3.5" - -node-fetch@^2.6.1: - version "2.6.9" - resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.9.tgz#7c7f744b5cc6eb5fd404e0c7a9fec630a55657e6" - integrity sha512-DJm/CJkZkRjKKj4Zi4BsKVZh3ValV5IR5s7LVZnW+6YMh0W1BfNA8XSs6DLMGYlId5F3KnA70uu2qepcR08Qqg== - dependencies: - whatwg-url "^5.0.0" - -node-fetch@^2.6.7: - version "2.6.7" - resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.7.tgz#24de9fba827e3b4ae44dc8b20256a379160052ad" - integrity sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ== - dependencies: - whatwg-url "^5.0.0" - -node-forge@^1: - version "1.3.1" - resolved "https://registry.yarnpkg.com/node-forge/-/node-forge-1.3.1.tgz#be8da2af243b2417d5f646a770663a92b7e9ded3" - integrity sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA== - -node-gyp@^9.0.0: - version "9.3.1" - resolved "https://registry.yarnpkg.com/node-gyp/-/node-gyp-9.3.1.tgz#1e19f5f290afcc9c46973d68700cbd21a96192e4" - integrity sha512-4Q16ZCqq3g8awk6UplT7AuxQ35XN4R/yf/+wSAwcBUAjg7l58RTactWaP8fIDTi0FzI7YcVLujwExakZlfWkXg== - dependencies: - env-paths "^2.2.0" - glob "^7.1.4" - graceful-fs "^4.2.6" - make-fetch-happen "^10.0.3" - nopt "^6.0.0" - npmlog "^6.0.0" - rimraf "^3.0.2" - semver "^7.3.5" - tar "^6.1.2" - which "^2.0.2" - -node-releases@^2.0.6: - version "2.0.6" - resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.6.tgz#8a7088c63a55e493845683ebf3c828d8c51c5503" - integrity sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg== - -nopt@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/nopt/-/nopt-6.0.0.tgz#245801d8ebf409c6df22ab9d95b65e1309cdb16d" - integrity sha512-ZwLpbTgdhuZUnZzjd7nb1ZV+4DoiC6/sfiVKok72ym/4Tlf+DFdlHYmT2JPmcNNWV6Pi3SDf1kT+A4r9RTuT9g== - dependencies: - abbrev "^1.0.0" - -normalize-package-data@^2.5.0: - version "2.5.0" - resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8" - integrity sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA== - dependencies: - hosted-git-info "^2.1.4" - resolve "^1.10.0" - semver "2 || 3 || 4 || 5" - validate-npm-package-license "^3.0.1" +node-releases@^2.0.13: + version "2.0.13" + resolved "https://registry.npmmirror.com/node-releases/-/node-releases-2.0.13.tgz#d5ed1627c23e3461e819b02e57b75e4899b1c81d" + integrity sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ== normalize-path@^3.0.0, normalize-path@~3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" + resolved "https://registry.npmmirror.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== normalize-range@^0.1.2: version "0.1.2" - resolved "https://registry.yarnpkg.com/normalize-range/-/normalize-range-0.1.2.tgz#2d10c06bdfd312ea9777695a4d28439456b75942" + resolved "https://registry.npmmirror.com/normalize-range/-/normalize-range-0.1.2.tgz#2d10c06bdfd312ea9777695a4d28439456b75942" integrity sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA== -normalize-url@^4.1.0: - version "4.5.1" - resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-4.5.1.tgz#0dd90cf1288ee1d1313b87081c9a5932ee48518a" - integrity sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA== - normalize-url@^6.0.1: version "6.1.0" - resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-6.1.0.tgz#40d0885b535deffe3f3147bec877d05fe4c5668a" + resolved "https://registry.npmmirror.com/normalize-url/-/normalize-url-6.1.0.tgz#40d0885b535deffe3f3147bec877d05fe4c5668a" integrity sha512-DlL+XwOy3NxAQ8xuC0okPgK46iuVNAK01YN7RueYBqqFeGsBjV9XmCAzAdgt+667bCl5kPh9EqKKDwnaPG1I7A== -npm-run-path@^2.0.0: - version "2.0.2" - resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz#35a9232dfa35d7067b4cb2ddf2357b1871536c5f" - integrity sha512-lJxZYlT4DW/bRUtFh1MQIWqmLwQfAxnqWG4HhEdjMlkrJYnJn0Jrr2u3mgxqaWsdiBc76TYkTG/mhrnYTuzfHw== - dependencies: - path-key "^2.0.0" - -npm-run-path@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-4.0.1.tgz#b7ecd1e5ed53da8e37a55e1c2269e0b97ed748ea" - integrity sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw== - dependencies: - path-key "^3.0.0" - -npmlog@^6.0.0: - version "6.0.2" - resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-6.0.2.tgz#c8166017a42f2dea92d6453168dd865186a70830" - integrity sha512-/vBvz5Jfr9dT/aFWd0FIRf+T/Q2WBsLENygUaFUqstqsycmZAP/t5BvFJTK0viFmSUxiUKTUplWy5vt+rvKIxg== - dependencies: - are-we-there-yet "^3.0.0" - console-control-strings "^1.1.0" - gauge "^4.0.3" - set-blocking "^2.0.0" - nth-check@^2.0.1: version "2.1.1" - resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-2.1.1.tgz#c9eab428effce36cd6b92c924bdb000ef1f1ed1d" + resolved "https://registry.npmmirror.com/nth-check/-/nth-check-2.1.1.tgz#c9eab428effce36cd6b92c924bdb000ef1f1ed1d" integrity sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w== dependencies: boolbase "^1.0.0" oauth-sign@~0.9.0: version "0.9.0" - resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.9.0.tgz#47a7b016baa68b5fa0ecf3dee08a85c679ac6455" + resolved "https://registry.npmmirror.com/oauth-sign/-/oauth-sign-0.9.0.tgz#47a7b016baa68b5fa0ecf3dee08a85c679ac6455" integrity sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ== object-assign@^4.0.1: version "4.1.1" - resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + resolved "https://registry.npmmirror.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== object-hash@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/object-hash/-/object-hash-3.0.0.tgz#73f97f753e7baffc0e2cc9d6e079079744ac82e9" + resolved "https://registry.npmmirror.com/object-hash/-/object-hash-3.0.0.tgz#73f97f753e7baffc0e2cc9d6e079079744ac82e9" integrity sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw== -object-inspect@^1.9.0: - version "1.12.2" - resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.12.2.tgz#c0641f26394532f28ab8d796ab954e43c009a8ea" - integrity sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ== - object-keys@^1.1.1: version "1.1.1" - resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" + resolved "https://registry.npmmirror.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== -object.assign@^4.1.0: - version "4.1.4" - resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.4.tgz#9673c7c7c351ab8c4d0b516f4343ebf4dfb7799f" - integrity sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ== - dependencies: - call-bind "^1.0.2" - define-properties "^1.1.4" - has-symbols "^1.0.3" - object-keys "^1.1.1" - -obuf@^1.0.0, obuf@^1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/obuf/-/obuf-1.1.2.tgz#09bea3343d41859ebd446292d11c9d4db619084e" - integrity sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg== - -omggif@^1.0.10, omggif@^1.0.9: - version "1.0.10" - resolved "https://registry.yarnpkg.com/omggif/-/omggif-1.0.10.tgz#ddaaf90d4a42f532e9e7cb3a95ecdd47f17c7b19" - integrity sha512-LMJTtvgc/nugXj0Vcrrs68Mn2D1r0zf630VNtqtpI1FEO7e+O9FP4gqs9AcnBaSEeoHIPm28u6qgPR0oyEpGSw== - -on-finished@2.4.1: - version "2.4.1" - resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.4.1.tgz#58c8c44116e54845ad57f14ab10b03533184ac3f" - integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== - dependencies: - ee-first "1.1.1" - -on-headers@~1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/on-headers/-/on-headers-1.0.2.tgz#772b0ae6aaa525c399e489adfad90c403eb3c28f" - integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== - once@^1.3.0, once@^1.3.1, once@^1.4.0: version "1.4.0" - resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" + resolved "https://registry.npmmirror.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== dependencies: wrappy "1" -onetime@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/onetime/-/onetime-2.0.1.tgz#067428230fd67443b2794b22bba528b6867962d4" - integrity sha512-oyyPpiMaKARvvcgip+JV+7zci5L8D1W9RZIz2l1o08AM3pfspitVWnPt3mzHcBPp12oYMTy0pqrFs/C+m3EwsQ== - dependencies: - mimic-fn "^1.0.0" - -onetime@^5.1.0, onetime@^5.1.2: +onetime@^5.1.2: version "5.1.2" - resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" + resolved "https://registry.npmmirror.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== dependencies: mimic-fn "^2.1.0" -open@^8.0.2, open@^8.0.9: - version "8.4.0" - resolved "https://registry.yarnpkg.com/open/-/open-8.4.0.tgz#345321ae18f8138f82565a910fdc6b39e8c244f8" - integrity sha512-XgFPPM+B28FtCCgSb9I+s9szOC1vZRSwgWsRUA5ylIxRTgKozqjOCrVOqGsYABPYK5qnfqClxZTFBa8PKt2v6Q== - dependencies: - define-lazy-prop "^2.0.0" - is-docker "^2.1.1" - is-wsl "^2.2.0" - -opener@^1.5.2: - version "1.5.2" - resolved "https://registry.yarnpkg.com/opener/-/opener-1.5.2.tgz#5d37e1f35077b9dcac4301372271afdeb2a13598" - integrity sha512-ur5UIdyw5Y7yEj9wLzhqXiy6GZ3Mwx0yGI+5sMn2r0N0v3cKJvUmFH5yPP+WXh9e0xfyzyJX95D8l088DNFj7A== - -ora@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/ora/-/ora-2.1.0.tgz#6caf2830eb924941861ec53a173799e008b51e5b" - integrity sha512-hNNlAd3gfv/iPmsNxYoAPLvxg7HuPozww7fFonMZvL84tP6Ox5igfk5j/+a9rtJJwqMgKK+JgWsAQik5o0HTLA== - dependencies: - chalk "^2.3.1" - cli-cursor "^2.1.0" - cli-spinners "^1.1.0" - log-symbols "^2.2.0" - strip-ansi "^4.0.0" - wcwidth "^1.0.1" - -ora@^5.1.0, ora@^5.3.0: - version "5.4.1" - resolved "https://registry.yarnpkg.com/ora/-/ora-5.4.1.tgz#1b2678426af4ac4a509008e5e4ac9e9959db9e18" - integrity sha512-5b6Y85tPxZZ7QytO+BQzysW31HJku27cRIlkbAXaNx+BdcVi+LlRFmVXzeF6a7JCwJpyw5c4b+YSVImQIrBpuQ== - dependencies: - bl "^4.1.0" - chalk "^4.1.0" - cli-cursor "^3.1.0" - cli-spinners "^2.5.0" - is-interactive "^1.0.0" - is-unicode-supported "^0.1.0" - log-symbols "^4.1.0" - strip-ansi "^6.0.0" - wcwidth "^1.0.1" - -p-cancelable@^1.0.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-1.1.0.tgz#d078d15a3af409220c886f1d9a0ca2e441ab26cc" - integrity sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw== - p-cancelable@^2.0.0: version "2.1.1" - resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-2.1.1.tgz#aab7fbd416582fa32a3db49859c122487c5ed2cf" + resolved "https://registry.npmmirror.com/p-cancelable/-/p-cancelable-2.1.1.tgz#aab7fbd416582fa32a3db49859c122487c5ed2cf" integrity sha512-BZOr3nRQHOntUjTrH8+Lh54smKHoHyur8We1V8DSMVrl5A2malOOwuJRnKRDjSnkoeBh4at6BwEnb5I7Jl31wg== -p-finally@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/p-finally/-/p-finally-1.0.0.tgz#3fbcfb15b899a44123b34b6dcc18b724336a2cae" - integrity sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow== - -p-limit@^2.0.0, p-limit@^2.2.0: +p-limit@^2.0.0: version "2.3.0" - resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" + resolved "https://registry.npmmirror.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== dependencies: p-try "^2.0.0" p-locate@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" + resolved "https://registry.npmmirror.com/p-locate/-/p-locate-3.0.0.tgz#322d69a05c0264b25997d9f40cd8a891ab0064a4" integrity sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ== dependencies: p-limit "^2.0.0" -p-locate@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07" - integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A== - dependencies: - p-limit "^2.2.0" - -p-map@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" - integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== - dependencies: - aggregate-error "^3.0.0" - -p-retry@^4.5.0: - version "4.6.2" - resolved "https://registry.yarnpkg.com/p-retry/-/p-retry-4.6.2.tgz#9baae7184057edd4e17231cee04264106e092a16" - integrity sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ== - dependencies: - "@types/retry" "0.12.0" - retry "^0.13.1" - p-try@^2.0.0: version "2.2.0" - resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" + resolved "https://registry.npmmirror.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== -package-json@^6.3.0: - version "6.5.0" - resolved "https://registry.yarnpkg.com/package-json/-/package-json-6.5.0.tgz#6feedaca35e75725876d0b0e64974697fed145b0" - integrity sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ== - dependencies: - got "^9.6.0" - registry-auth-token "^4.0.0" - registry-url "^5.0.0" - semver "^6.2.0" - -pako@^1.0.11, pako@~1.0.2: - version "1.0.11" - resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.11.tgz#6c9599d340d54dfd3946380252a35705a6b992bf" - integrity sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw== - -param-case@^3.0.4: - version "3.0.4" - resolved "https://registry.yarnpkg.com/param-case/-/param-case-3.0.4.tgz#7d17fe4aa12bde34d4a77d91acfb6219caad01c5" - integrity sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A== - dependencies: - dot-case "^3.0.4" - tslib "^2.0.3" - -parent-module@^1.0.0: +parse-node-version@^1.0.1: version "1.0.1" - resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" - integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== - dependencies: - callsites "^3.0.0" - -parse-bmfont-ascii@^1.0.3: - version "1.0.6" - resolved "https://registry.yarnpkg.com/parse-bmfont-ascii/-/parse-bmfont-ascii-1.0.6.tgz#11ac3c3ff58f7c2020ab22769079108d4dfa0285" - integrity sha512-U4RrVsUFCleIOBsIGYOMKjn9PavsGOXxbvYGtMOEfnId0SVNsgehXh1DxUdVPLoxd5mvcEtvmKs2Mmf0Mpa1ZA== - -parse-bmfont-binary@^1.0.5: - version "1.0.6" - resolved "https://registry.yarnpkg.com/parse-bmfont-binary/-/parse-bmfont-binary-1.0.6.tgz#d038b476d3e9dd9db1e11a0b0e53a22792b69006" - integrity sha512-GxmsRea0wdGdYthjuUeWTMWPqm2+FAd4GI8vCvhgJsFnoGhTrLhXDDupwTo7rXVAgaLIGoVHDZS9p/5XbSqeWA== - -parse-bmfont-xml@^1.1.4: - version "1.1.4" - resolved "https://registry.yarnpkg.com/parse-bmfont-xml/-/parse-bmfont-xml-1.1.4.tgz#015319797e3e12f9e739c4d513872cd2fa35f389" - integrity sha512-bjnliEOmGv3y1aMEfREMBJ9tfL3WR0i0CKPj61DnSLaoxWR3nLrsQrEbCId/8rF4NyRF0cCqisSVXyQYWM+mCQ== - dependencies: - xml-parse-from-string "^1.0.0" - xml2js "^0.4.5" - -parse-headers@^2.0.0: - version "2.0.5" - resolved "https://registry.yarnpkg.com/parse-headers/-/parse-headers-2.0.5.tgz#069793f9356a54008571eb7f9761153e6c770da9" - integrity sha512-ft3iAoLOB/MlwbNXgzy43SWGP6sQki2jQvAyBg/zDFAgr9bfNWZIUj42Kw2eJIl8kEi4PbgE6U1Zau/HwI75HA== - -parse-json@^5.0.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd" - integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== - dependencies: - "@babel/code-frame" "^7.0.0" - error-ex "^1.3.1" - json-parse-even-better-errors "^2.3.0" - lines-and-columns "^1.1.6" - -parse5-htmlparser2-tree-adapter@^6.0.0: - version "6.0.1" - resolved "https://registry.yarnpkg.com/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-6.0.1.tgz#2cdf9ad823321140370d4dbf5d3e92c7c8ddc6e6" - integrity sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA== - dependencies: - parse5 "^6.0.1" + resolved "https://registry.npmmirror.com/parse-node-version/-/parse-node-version-1.0.1.tgz#e2b5dbede00e7fa9bc363607f53327e8b073189b" + integrity sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA== parse5-htmlparser2-tree-adapter@^7.0.0: version "7.0.0" - resolved "https://registry.yarnpkg.com/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz#23c2cc233bcf09bb7beba8b8a69d46b08c62c2f1" + resolved "https://registry.npmmirror.com/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz#23c2cc233bcf09bb7beba8b8a69d46b08c62c2f1" integrity sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g== dependencies: domhandler "^5.0.2" parse5 "^7.0.0" -parse5@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/parse5/-/parse5-5.1.1.tgz#f68e4e5ba1852ac2cadc00f4555fff6c2abb6178" - integrity sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug== - -parse5@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/parse5/-/parse5-6.0.1.tgz#e1a1c085c569b3dc08321184f19a39cc27f7c30b" - integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw== - parse5@^7.0.0: - version "7.1.1" - resolved "https://registry.yarnpkg.com/parse5/-/parse5-7.1.1.tgz#4649f940ccfb95d8754f37f73078ea20afe0c746" - integrity sha512-kwpuwzB+px5WUg9pyK0IcK/shltJN5/OVhQagxhCQNtT9Y9QRZqNY2e1cmbu/paRh5LMnz/oVTVLBpjFmMZhSg== + version "7.1.2" + resolved "https://registry.npmmirror.com/parse5/-/parse5-7.1.2.tgz#0736bebbfd77793823240a23b7fc5e010b7f8e32" + integrity sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw== dependencies: entities "^4.4.0" -parseurl@~1.3.2, parseurl@~1.3.3: - version "1.3.3" - resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" - integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== - -pascal-case@^3.1.2: - version "3.1.2" - resolved "https://registry.yarnpkg.com/pascal-case/-/pascal-case-3.1.2.tgz#b48e0ef2b98e205e7c1dae747d0b1508237660eb" - integrity sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g== - dependencies: - no-case "^3.0.4" - tslib "^2.0.3" +path-browserify@^1.0.1: + version "1.0.1" + resolved "https://registry.npmmirror.com/path-browserify/-/path-browserify-1.0.1.tgz#d98454a9c3753d5790860f16f68867b9e46be1fd" + integrity sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g== path-exists@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" + resolved "https://registry.npmmirror.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515" integrity sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ== -path-exists@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" - integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== - path-is-absolute@^1.0.0: version "1.0.1" - resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" + resolved "https://registry.npmmirror.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== -path-key@^2.0.0, path-key@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz#411cadb574c5a140d3a4b1910d40d80cc9f40b40" - integrity sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw== - -path-key@^3.0.0, path-key@^3.1.0: +path-key@^3.1.0: version "3.1.1" - resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + resolved "https://registry.npmmirror.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== path-parse@^1.0.7: version "1.0.7" - resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" + resolved "https://registry.npmmirror.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== -path-to-regexp@0.1.7: - version "0.1.7" - resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" - integrity sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ== - -path-type@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" - integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== - -peek-readable@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/peek-readable/-/peek-readable-4.1.0.tgz#4ece1111bf5c2ad8867c314c81356847e8a62e72" - integrity sha512-ZI3LnwUv5nOGbQzD9c2iDG6toheuXSZP5esSHBjopsXH4dg19soufvpUGA3uohi5anFtGb2lhAVdHzH6R/Evvg== - pend@~1.2.0: version "1.2.0" - resolved "https://registry.yarnpkg.com/pend/-/pend-1.2.0.tgz#7a57eb550a6783f9115331fcf4663d5c8e007a50" + resolved "https://registry.npmmirror.com/pend/-/pend-1.2.0.tgz#7a57eb550a6783f9115331fcf4663d5c8e007a50" integrity sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg== performance-now@^2.1.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" + resolved "https://registry.npmmirror.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" integrity sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow== -phin@^2.9.1: - version "2.9.3" - resolved "https://registry.yarnpkg.com/phin/-/phin-2.9.3.tgz#f9b6ac10a035636fb65dfc576aaaa17b8743125c" - integrity sha512-CzFr90qM24ju5f88quFC/6qohjC144rehe5n6DH900lgXmUe86+xCKc10ev56gRKC4/BkHUoG4uSiQgBiIXwDA== - -picocolors@^0.2.1: - version "0.2.1" - resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-0.2.1.tgz#570670f793646851d1ba135996962abad587859f" - integrity sha512-cMlDqaLEqfSaW8Z7N5Jw+lyIW869EzT73/F5lhtY9cLGoVxSXznfgfXMO0Z5K0o0Q2TkTXq+0KFsdnSe3jDViA== - picocolors@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" + resolved "https://registry.npmmirror.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: version "2.3.1" - resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" + resolved "https://registry.npmmirror.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== pify@^2.3.0: version "2.3.0" - resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" + resolved "https://registry.npmmirror.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" integrity sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog== -pinyin-match@^1.2.4: - version "1.2.4" - resolved "https://registry.yarnpkg.com/pinyin-match/-/pinyin-match-1.2.4.tgz#94381bb6501cfd3c24f923fe36c81710d8c49bcc" - integrity sha512-HpUiaSxcG3rrpKAMZXq/rMHbEp7wvfu9B64lHJBy+63xAr/hVdBC8xqkWWPnNyjSb19ihdh8FnXo+9m6jAr9Mg== +pify@^4.0.1: + version "4.0.1" + resolved "https://registry.npmmirror.com/pify/-/pify-4.0.1.tgz#4b2cd25c50d598735c50292224fd8c6df41e3231" + integrity sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g== -pixelmatch@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/pixelmatch/-/pixelmatch-4.0.2.tgz#8f47dcec5011b477b67db03c243bc1f3085e8854" - integrity sha512-J8B6xqiO37sU/gkcMglv6h5Jbd9xNER7aHzpfRdNmV4IbQBzBpe4l9XmbG+xPF/znacgu2jfEw+wHffaq/YkXA== +pinia@^2.1.7: + version "2.1.7" + resolved "https://registry.npmmirror.com/pinia/-/pinia-2.1.7.tgz#4cf5420d9324ca00b7b4984d3fbf693222115bbc" + integrity sha512-+C2AHFtcFqjPih0zpYuvof37SFxMQ7OEG2zV9jRI12i9BOy3YQVAHwdKtyyc8pDcDyIc33WCIsZaCFWU7WWxGQ== dependencies: - pngjs "^3.0.0" + "@vue/devtools-api" "^6.5.0" + vue-demi ">=0.14.5" -pkg-dir@^4.1.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" - integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== - dependencies: - find-up "^4.0.0" +pinyin-pro@^3.17.0: + version "3.17.0" + resolved "https://registry.npmmirror.com/pinyin-pro/-/pinyin-pro-3.17.0.tgz#33c9f8306b875d1f0314539b150c29f28dc98654" + integrity sha512-0R+K1kDl2Fb21nqKjb9hxKHya/fWuOJCSElWqdh17THSL/cgq95PP/QrJINFezFooepCiP+pbUenV2pRloAHHQ== + +pirates@^4.0.1: + version "4.0.6" + resolved "https://registry.npmmirror.com/pirates/-/pirates-4.0.6.tgz#3018ae32ecfcff6c29ba2267cbf21166ac1f36b9" + integrity sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg== pkg-up@^3.1.0: version "3.1.0" - resolved "https://registry.yarnpkg.com/pkg-up/-/pkg-up-3.1.0.tgz#100ec235cc150e4fd42519412596a28512a0def5" + resolved "https://registry.npmmirror.com/pkg-up/-/pkg-up-3.1.0.tgz#100ec235cc150e4fd42519412596a28512a0def5" integrity sha512-nDywThFk1i4BQK4twPQ6TA4RT8bDY96yeuCVBWL3ePARCiEKDRSrNGbFIgUJpLp+XeIR65v8ra7WuJOFUBtkMA== dependencies: find-up "^3.0.0" -playwright-core@^1.17.1: - version "1.26.0" - resolved "https://registry.npmmirror.com/playwright-core/-/playwright-core-1.26.0.tgz#850228f0638d410a5cdd69800d552f60e4d295cd" - integrity sha512-p8huU8eU4gD3VkJd3DA1nA7R3XA6rFvFL+1RYS96cSljCF2yJE9CWEHTPF4LqX8KN9MoWCrAfVKP5381X3CZqg== - -plist@^3.0.1, plist@^3.0.4, plist@^3.0.5: - version "3.0.6" - resolved "https://registry.yarnpkg.com/plist/-/plist-3.0.6.tgz#7cfb68a856a7834bca6dbfe3218eb9c7740145d3" - integrity sha512-WiIVYyrp8TD4w8yCvyeIr+lkmrGRd5u0VbRnU+tP/aRLxP/YadJUYOMZJ/6hIa3oUyVCsycXvtNRgd5XBJIbiA== +plist@^3.0.4, plist@^3.0.5: + version "3.1.0" + resolved "https://registry.npmmirror.com/plist/-/plist-3.1.0.tgz#797a516a93e62f5bde55e0b9cc9c967f860893c9" + integrity sha512-uysumyrvkUX0rX/dEVqt8gC3sTBzd4zoWfLeS29nb53imdaXVvLINYXTI2GNqzaMuvacNx4uJQ8+b3zXR0pkgQ== dependencies: + "@xmldom/xmldom" "^0.8.8" base64-js "^1.5.1" xmlbuilder "^15.1.1" -pngjs@^3.0.0: - version "3.4.0" - resolved "https://registry.yarnpkg.com/pngjs/-/pngjs-3.4.0.tgz#99ca7d725965fb655814eaf65f38f12bbdbf555f" - integrity sha512-NCrCHhWmnQklfH4MtJMRjZ2a8c80qXeMlQMv2uVp9ISJMTt562SbGd6n2oq0PaPgKm7Z6pL9E2UlLIhC+SHL3w== - -pngjs@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/pngjs/-/pngjs-6.0.0.tgz#ca9e5d2aa48db0228a52c419c3308e87720da821" - integrity sha512-TRzzuFRRmEoSW/p1KVAmiOgPco2Irlah+bGFCeNfJXxxYGwSw7YwAOAcd7X28K/m5bjBWKsC29KyoMfHbypayg== - -portfinder@^1.0.26: - version "1.0.32" - resolved "https://registry.yarnpkg.com/portfinder/-/portfinder-1.0.32.tgz#2fe1b9e58389712429dc2bea5beb2146146c7f81" - integrity sha512-on2ZJVVDXRADWE6jnQaX0ioEylzgBpQk8r55NE4wjXW1ZxO+BgDlY6DXwj20i0V8eB4SenDQ00WEaxfiIQPcxg== - dependencies: - async "^2.6.4" - debug "^3.2.7" - mkdirp "^0.5.6" - -postcss-calc@^8.2.3: - version "8.2.4" - resolved "https://registry.yarnpkg.com/postcss-calc/-/postcss-calc-8.2.4.tgz#77b9c29bfcbe8a07ff6693dc87050828889739a5" - integrity sha512-SmWMSJmB8MRnnULldx0lQIyhSNvuDl9HfrZkaqqE/WHAhToYsAvDq+yAsA/kIyINDszOp3Rh0GFoNuH5Ypsm3Q== - dependencies: - postcss-selector-parser "^6.0.9" - postcss-value-parser "^4.2.0" - -postcss-colormin@^5.3.0: - version "5.3.0" - resolved "https://registry.yarnpkg.com/postcss-colormin/-/postcss-colormin-5.3.0.tgz#3cee9e5ca62b2c27e84fce63affc0cfb5901956a" - integrity sha512-WdDO4gOFG2Z8n4P8TWBpshnL3JpmNmJwdnfP2gbk2qBA8PWwOYcmjmI/t3CmMeL72a7Hkd+x/Mg9O2/0rD54Pg== - dependencies: - browserslist "^4.16.6" - caniuse-api "^3.0.0" - colord "^2.9.1" - postcss-value-parser "^4.2.0" - -postcss-convert-values@^5.1.2: - version "5.1.2" - resolved "https://registry.yarnpkg.com/postcss-convert-values/-/postcss-convert-values-5.1.2.tgz#31586df4e184c2e8890e8b34a0b9355313f503ab" - integrity sha512-c6Hzc4GAv95B7suy4udszX9Zy4ETyMCgFPUDtWjdFTKH1SE9eFY/jEpHSwTH1QPuwxHpWslhckUQWbNRM4ho5g== - dependencies: - browserslist "^4.20.3" - postcss-value-parser "^4.2.0" - -postcss-discard-comments@^5.1.2: - version "5.1.2" - resolved "https://registry.yarnpkg.com/postcss-discard-comments/-/postcss-discard-comments-5.1.2.tgz#8df5e81d2925af2780075840c1526f0660e53696" - integrity sha512-+L8208OVbHVF2UQf1iDmRcbdjJkuBF6IS29yBDSiWUIzpYaAhtNl6JYnYm12FnkeCwQqF5LeklOu6rAqgfBZqQ== - -postcss-discard-duplicates@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-discard-duplicates/-/postcss-discard-duplicates-5.1.0.tgz#9eb4fe8456706a4eebd6d3b7b777d07bad03e848" - integrity sha512-zmX3IoSI2aoenxHV6C7plngHWWhUOV3sP1T8y2ifzxzbtnuhk1EdPwm0S1bIUNaJ2eNbWeGLEwzw8huPD67aQw== - -postcss-discard-empty@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/postcss-discard-empty/-/postcss-discard-empty-5.1.1.tgz#e57762343ff7f503fe53fca553d18d7f0c369c6c" - integrity sha512-zPz4WljiSuLWsI0ir4Mcnr4qQQ5e1Ukc3i7UfE2XcrwKK2LIPIqE5jxMRxO6GbI3cv//ztXDsXwEWT3BHOGh3A== - -postcss-discard-overridden@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-discard-overridden/-/postcss-discard-overridden-5.1.0.tgz#7e8c5b53325747e9d90131bb88635282fb4a276e" - integrity sha512-21nOL7RqWR1kasIVdKs8HNqQJhFxLsyRfAnUDm4Fe4t4mCWL9OJiHvlHPjcd8zc5Myu89b/7wZDnOSjFgeWRtw== - -postcss-import@^14.1.0: - version "14.1.0" - resolved "https://registry.yarnpkg.com/postcss-import/-/postcss-import-14.1.0.tgz#a7333ffe32f0b8795303ee9e40215dac922781f0" - integrity sha512-flwI+Vgm4SElObFVPpTIT7SU7R3qk2L7PyduMcokiaVKuWv9d/U+Gm/QAd8NDLuykTWTkcrjOeD2Pp1rMeBTGw== +postcss-import@^15.1.0: + version "15.1.0" + resolved "https://registry.npmmirror.com/postcss-import/-/postcss-import-15.1.0.tgz#41c64ed8cc0e23735a9698b3249ffdbf704adc70" + integrity sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew== dependencies: postcss-value-parser "^4.0.0" read-cache "^1.0.0" resolve "^1.1.7" -postcss-js@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/postcss-js/-/postcss-js-4.0.0.tgz#31db79889531b80dc7bc9b0ad283e418dce0ac00" - integrity sha512-77QESFBwgX4irogGVPgQ5s07vLvFqWr228qZY+w6lW599cRlK/HmnlivnnVUxkjHnCu4J16PDMHcH+e+2HbvTQ== +postcss-js@^4.0.1: + version "4.0.1" + resolved "https://registry.npmmirror.com/postcss-js/-/postcss-js-4.0.1.tgz#61598186f3703bab052f1c4f7d805f3991bee9d2" + integrity sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw== dependencies: camelcase-css "^2.0.1" -postcss-load-config@^3.1.4: - version "3.1.4" - resolved "https://registry.yarnpkg.com/postcss-load-config/-/postcss-load-config-3.1.4.tgz#1ab2571faf84bb078877e1d07905eabe9ebda855" - integrity sha512-6DiM4E7v4coTE4uzA8U//WhtPwyhiim3eyjEMFCnUpzbrkK9wJHgKDT2mR+HbtSrd/NubVaYTOpSpjUl8NQeRg== +postcss-load-config@^4.0.1: + version "4.0.1" + resolved "https://registry.npmmirror.com/postcss-load-config/-/postcss-load-config-4.0.1.tgz#152383f481c2758274404e4962743191d73875bd" + integrity sha512-vEJIc8RdiBRu3oRAI0ymerOn+7rPuMvRXslTvZUKZonDHFIczxztIyJ1urxM1x9JXEikvpWWTUUqal5j/8QgvA== dependencies: lilconfig "^2.0.5" - yaml "^1.10.2" + yaml "^2.1.1" -postcss-loader@^6.1.1: - version "6.2.1" - resolved "https://registry.yarnpkg.com/postcss-loader/-/postcss-loader-6.2.1.tgz#0895f7346b1702103d30fdc66e4d494a93c008ef" - integrity sha512-WbbYpmAaKcux/P66bZ40bpWsBucjx/TTgVVzRZ9yUO8yQfVBlameJ0ZGVaPfH64hNSBh63a+ICP5nqOpBA0w+Q== +postcss-nested@^6.0.1: + version "6.0.1" + resolved "https://registry.npmmirror.com/postcss-nested/-/postcss-nested-6.0.1.tgz#f83dc9846ca16d2f4fa864f16e9d9f7d0961662c" + integrity sha512-mEp4xPMi5bSWiMbsgoPfcP74lsWLHkQbZc3sY+jWYd65CUwXrUaTp0fmNpa01ZcETKlIgUdFN/MpS2xZtqL9dQ== dependencies: - cosmiconfig "^7.0.0" - klona "^2.0.5" - semver "^7.3.5" + postcss-selector-parser "^6.0.11" -postcss-merge-longhand@^5.1.6: - version "5.1.6" - resolved "https://registry.yarnpkg.com/postcss-merge-longhand/-/postcss-merge-longhand-5.1.6.tgz#f378a8a7e55766b7b644f48e5d8c789ed7ed51ce" - integrity sha512-6C/UGF/3T5OE2CEbOuX7iNO63dnvqhGZeUnKkDeifebY0XqkkvrctYSZurpNE902LDf2yKwwPFgotnfSoPhQiw== - dependencies: - postcss-value-parser "^4.2.0" - stylehacks "^5.1.0" - -postcss-merge-rules@^5.1.2: - version "5.1.2" - resolved "https://registry.yarnpkg.com/postcss-merge-rules/-/postcss-merge-rules-5.1.2.tgz#7049a14d4211045412116d79b751def4484473a5" - integrity sha512-zKMUlnw+zYCWoPN6yhPjtcEdlJaMUZ0WyVcxTAmw3lkkN/NDMRkOkiuctQEoWAOvH7twaxUUdvBWl0d4+hifRQ== - dependencies: - browserslist "^4.16.6" - caniuse-api "^3.0.0" - cssnano-utils "^3.1.0" - postcss-selector-parser "^6.0.5" - -postcss-minify-font-values@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-minify-font-values/-/postcss-minify-font-values-5.1.0.tgz#f1df0014a726083d260d3bd85d7385fb89d1f01b" - integrity sha512-el3mYTgx13ZAPPirSVsHqFzl+BBBDrXvbySvPGFnQcTI4iNslrPaFq4muTkLZmKlGk4gyFAYUBMH30+HurREyA== - dependencies: - postcss-value-parser "^4.2.0" - -postcss-minify-gradients@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/postcss-minify-gradients/-/postcss-minify-gradients-5.1.1.tgz#f1fe1b4f498134a5068240c2f25d46fcd236ba2c" - integrity sha512-VGvXMTpCEo4qHTNSa9A0a3D+dxGFZCYwR6Jokk+/3oB6flu2/PnPXAh2x7x52EkY5xlIHLm+Le8tJxe/7TNhzw== - dependencies: - colord "^2.9.1" - cssnano-utils "^3.1.0" - postcss-value-parser "^4.2.0" - -postcss-minify-params@^5.1.3: - version "5.1.3" - resolved "https://registry.yarnpkg.com/postcss-minify-params/-/postcss-minify-params-5.1.3.tgz#ac41a6465be2db735099bbd1798d85079a6dc1f9" - integrity sha512-bkzpWcjykkqIujNL+EVEPOlLYi/eZ050oImVtHU7b4lFS82jPnsCb44gvC6pxaNt38Els3jWYDHTjHKf0koTgg== - dependencies: - browserslist "^4.16.6" - cssnano-utils "^3.1.0" - postcss-value-parser "^4.2.0" - -postcss-minify-selectors@^5.2.1: - version "5.2.1" - resolved "https://registry.yarnpkg.com/postcss-minify-selectors/-/postcss-minify-selectors-5.2.1.tgz#d4e7e6b46147b8117ea9325a915a801d5fe656c6" - integrity sha512-nPJu7OjZJTsVUmPdm2TcaiohIwxP+v8ha9NehQ2ye9szv4orirRU3SDdtUmKH+10nzn0bAyOXZ0UEr7OpvLehg== - dependencies: - postcss-selector-parser "^6.0.5" - -postcss-modules-extract-imports@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz#cda1f047c0ae80c97dbe28c3e76a43b88025741d" - integrity sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw== - -postcss-modules-local-by-default@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.0.tgz#ebbb54fae1598eecfdf691a02b3ff3b390a5a51c" - integrity sha512-sT7ihtmGSF9yhm6ggikHdV0hlziDTX7oFoXtuVWeDd3hHObNkcHRo9V3yg7vCAY7cONyxJC/XXCmmiHHcvX7bQ== - dependencies: - icss-utils "^5.0.0" - postcss-selector-parser "^6.0.2" - postcss-value-parser "^4.1.0" - -postcss-modules-scope@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz#9ef3151456d3bbfa120ca44898dfca6f2fa01f06" - integrity sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg== - dependencies: - postcss-selector-parser "^6.0.4" - -postcss-modules-values@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz#d7c5e7e68c3bb3c9b27cbf48ca0bb3ffb4602c9c" - integrity sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ== - dependencies: - icss-utils "^5.0.0" - -postcss-nested@5.0.6: - version "5.0.6" - resolved "https://registry.yarnpkg.com/postcss-nested/-/postcss-nested-5.0.6.tgz#466343f7fc8d3d46af3e7dba3fcd47d052a945bc" - integrity sha512-rKqm2Fk0KbA8Vt3AdGN0FB9OBOMDVajMG6ZCf/GoHgdxUJ4sBFp0A/uMIRm+MJUdo33YXEtjqIz8u7DAp8B7DA== - dependencies: - postcss-selector-parser "^6.0.6" - -postcss-normalize-charset@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-normalize-charset/-/postcss-normalize-charset-5.1.0.tgz#9302de0b29094b52c259e9b2cf8dc0879879f0ed" - integrity sha512-mSgUJ+pd/ldRGVx26p2wz9dNZ7ji6Pn8VWBajMXFf8jk7vUoSrZ2lt/wZR7DtlZYKesmZI680qjr2CeFF2fbUg== - -postcss-normalize-display-values@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-normalize-display-values/-/postcss-normalize-display-values-5.1.0.tgz#72abbae58081960e9edd7200fcf21ab8325c3da8" - integrity sha512-WP4KIM4o2dazQXWmFaqMmcvsKmhdINFblgSeRgn8BJ6vxaMyaJkwAzpPpuvSIoG/rmX3M+IrRZEz2H0glrQNEA== - dependencies: - postcss-value-parser "^4.2.0" - -postcss-normalize-positions@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/postcss-normalize-positions/-/postcss-normalize-positions-5.1.1.tgz#ef97279d894087b59325b45c47f1e863daefbb92" - integrity sha512-6UpCb0G4eofTCQLFVuI3EVNZzBNPiIKcA1AKVka+31fTVySphr3VUgAIULBhxZkKgwLImhzMR2Bw1ORK+37INg== - dependencies: - postcss-value-parser "^4.2.0" - -postcss-normalize-repeat-style@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-5.1.1.tgz#e9eb96805204f4766df66fd09ed2e13545420fb2" - integrity sha512-mFpLspGWkQtBcWIRFLmewo8aC3ImN2i/J3v8YCFUwDnPu3Xz4rLohDO26lGjwNsQxB3YF0KKRwspGzE2JEuS0g== - dependencies: - postcss-value-parser "^4.2.0" - -postcss-normalize-string@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-normalize-string/-/postcss-normalize-string-5.1.0.tgz#411961169e07308c82c1f8c55f3e8a337757e228" - integrity sha512-oYiIJOf4T9T1N4i+abeIc7Vgm/xPCGih4bZz5Nm0/ARVJ7K6xrDlLwvwqOydvyL3RHNf8qZk6vo3aatiw/go3w== - dependencies: - postcss-value-parser "^4.2.0" - -postcss-normalize-timing-functions@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-5.1.0.tgz#d5614410f8f0b2388e9f240aa6011ba6f52dafbb" - integrity sha512-DOEkzJ4SAXv5xkHl0Wa9cZLF3WCBhF3o1SKVxKQAa+0pYKlueTpCgvkFAHfk+Y64ezX9+nITGrDZeVGgITJXjg== - dependencies: - postcss-value-parser "^4.2.0" - -postcss-normalize-unicode@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-normalize-unicode/-/postcss-normalize-unicode-5.1.0.tgz#3d23aede35e160089a285e27bf715de11dc9db75" - integrity sha512-J6M3MizAAZ2dOdSjy2caayJLQT8E8K9XjLce8AUQMwOrCvjCHv24aLC/Lps1R1ylOfol5VIDMaM/Lo9NGlk1SQ== - dependencies: - browserslist "^4.16.6" - postcss-value-parser "^4.2.0" - -postcss-normalize-url@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-normalize-url/-/postcss-normalize-url-5.1.0.tgz#ed9d88ca82e21abef99f743457d3729a042adcdc" - integrity sha512-5upGeDO+PVthOxSmds43ZeMeZfKH+/DKgGRD7TElkkyS46JXAUhMzIKiCa7BabPeIy3AQcTkXwVVN7DbqsiCew== - dependencies: - normalize-url "^6.0.1" - postcss-value-parser "^4.2.0" - -postcss-normalize-whitespace@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/postcss-normalize-whitespace/-/postcss-normalize-whitespace-5.1.1.tgz#08a1a0d1ffa17a7cc6efe1e6c9da969cc4493cfa" - integrity sha512-83ZJ4t3NUDETIHTa3uEg6asWjSBYL5EdkVB0sDncx9ERzOKBVJIUeDO9RyA9Zwtig8El1d79HBp0JEi8wvGQnA== - dependencies: - postcss-value-parser "^4.2.0" - -postcss-ordered-values@^5.1.3: - version "5.1.3" - resolved "https://registry.yarnpkg.com/postcss-ordered-values/-/postcss-ordered-values-5.1.3.tgz#b6fd2bd10f937b23d86bc829c69e7732ce76ea38" - integrity sha512-9UO79VUhPwEkzbb3RNpqqghc6lcYej1aveQteWY+4POIwlqkYE21HKWaLDF6lWNuqCobEAyTovVhtI32Rbv2RQ== - dependencies: - cssnano-utils "^3.1.0" - postcss-value-parser "^4.2.0" - -postcss-reduce-initial@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-reduce-initial/-/postcss-reduce-initial-5.1.0.tgz#fc31659ea6e85c492fb2a7b545370c215822c5d6" - integrity sha512-5OgTUviz0aeH6MtBjHfbr57tml13PuedK/Ecg8szzd4XRMbYxH4572JFG067z+FqBIf6Zp/d+0581glkvvWMFw== - dependencies: - browserslist "^4.16.6" - caniuse-api "^3.0.0" - -postcss-reduce-transforms@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-reduce-transforms/-/postcss-reduce-transforms-5.1.0.tgz#333b70e7758b802f3dd0ddfe98bb1ccfef96b6e9" - integrity sha512-2fbdbmgir5AvpW9RLtdONx1QoYG2/EtqpNQbFASDlixBbAYuTcJ0dECwlqNqH7VbaUnEnh8SrxOe2sRIn24XyQ== - dependencies: - postcss-value-parser "^4.2.0" - -postcss-selector-parser@^6.0.10, postcss-selector-parser@^6.0.2, postcss-selector-parser@^6.0.4, postcss-selector-parser@^6.0.5, postcss-selector-parser@^6.0.6, postcss-selector-parser@^6.0.9: - version "6.0.10" - resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-6.0.10.tgz#79b61e2c0d1bfc2602d549e11d0876256f8df88d" - integrity sha512-IQ7TZdoaqbT+LCpShg46jnZVlhWD2w6iQYAcYXfHARZ7X1t/UGhhceQDs5X0cGqKvYlHNOuv7Oa1xmb0oQuA3w== +postcss-selector-parser@^6.0.11: + version "6.0.13" + resolved "https://registry.npmmirror.com/postcss-selector-parser/-/postcss-selector-parser-6.0.13.tgz#d05d8d76b1e8e173257ef9d60b706a8e5e99bf1b" + integrity sha512-EaV1Gl4mUEV4ddhDnv/xtj7sxwrwxdetHdWUGnT4VJQf+4d05v6lHYZr8N573k5Z0BViss7BDhfWtKS3+sfAqQ== dependencies: cssesc "^3.0.0" util-deprecate "^1.0.2" -postcss-svgo@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/postcss-svgo/-/postcss-svgo-5.1.0.tgz#0a317400ced789f233a28826e77523f15857d80d" - integrity sha512-D75KsH1zm5ZrHyxPakAxJWtkyXew5qwS70v56exwvw542d9CRtTo78K0WeFxZB4G7JXKKMbEZtZayTGdIky/eA== - dependencies: - postcss-value-parser "^4.2.0" - svgo "^2.7.0" - -postcss-unique-selectors@^5.1.1: - version "5.1.1" - resolved "https://registry.yarnpkg.com/postcss-unique-selectors/-/postcss-unique-selectors-5.1.1.tgz#a9f273d1eacd09e9aa6088f4b0507b18b1b541b6" - integrity sha512-5JiODlELrz8L2HwxfPnhOWZYWDxVHWL83ufOv84NrcgipI7TaeRsatAhK4Tr2/ZiYldpK/wBvw5BD3qfaK96GA== - dependencies: - postcss-selector-parser "^6.0.5" - -postcss-value-parser@^4.0.0, postcss-value-parser@^4.1.0, postcss-value-parser@^4.2.0: +postcss-value-parser@^4.0.0, postcss-value-parser@^4.2.0: version "4.2.0" - resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz#723c09920836ba6d3e5af019f92bc0971c02e514" + resolved "https://registry.npmmirror.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz#723c09920836ba6d3e5af019f92bc0971c02e514" integrity sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ== -postcss@^7.0.36: - version "7.0.39" - resolved "https://registry.yarnpkg.com/postcss/-/postcss-7.0.39.tgz#9624375d965630e2e1f2c02a935c82a59cb48309" - integrity sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA== +postcss@^8.4.23, postcss@^8.4.27, postcss@^8.4.31: + version "8.4.31" + resolved "https://registry.npmmirror.com/postcss/-/postcss-8.4.31.tgz#92b451050a9f914da6755af352bdc0192508656d" + integrity sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ== dependencies: - picocolors "^0.2.1" - source-map "^0.6.1" - -postcss@^8.1.10, postcss@^8.2.6, postcss@^8.3.5, postcss@^8.4.14, postcss@^8.4.16, postcss@^8.4.7: - version "8.4.16" - resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.16.tgz#33a1d675fac39941f5f445db0de4db2b6e01d43c" - integrity sha512-ipHE1XBvKzm5xI7hiHCZJCSugxvsdq2mPnsq5+UF+VHCjiBvtDrlxJfMBToWaP9D5XlgNmcFGqoHmUn0EYEaRQ== - dependencies: - nanoid "^3.3.4" + nanoid "^3.3.6" picocolors "^1.0.0" source-map-js "^1.0.2" -prepend-http@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-2.0.0.tgz#e92434bfa5ea8c19f41cdfd401d741a3c819d897" - integrity sha512-ravE6m9Atw9Z/jjttRUZ+clIXogdghyZAuWJ3qEzjT+jI/dL1ifAqhZeC5VHzQp1MSt1+jxKkFNemj/iO7tVUA== - -"prettier@^1.18.2 || ^2.0.0", prettier@^2.7.1: - version "2.7.1" - resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.7.1.tgz#e235806850d057f97bb08368a4f7d899f7760c64" - integrity sha512-ujppO+MkdPqoVINuDFDRLClm7D78qbDt0/NR+wp5FqEZOoTNAjPHWj17QRhu7geIHJfcNhRk1XVQmF8Bp3ye+g== - -pretty-error@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/pretty-error/-/pretty-error-4.0.0.tgz#90a703f46dd7234adb46d0f84823e9d1cb8f10d6" - integrity sha512-AoJ5YMAcXKYxKhuJGdcvse+Voc6v1RgnsR3nWcYU7q4t6z0Q6T86sv5Zq8VIRbOWWFpvdGE83LtdSMNd+6Y0xw== +prebuild-install@^7.1.1: + version "7.1.1" + resolved "https://registry.npmmirror.com/prebuild-install/-/prebuild-install-7.1.1.tgz#de97d5b34a70a0c81334fd24641f2a1702352e45" + integrity sha512-jAXscXWMcCK8GgCoHOfIr0ODh5ai8mj63L2nWrjuAgXE6tDyYGnx4/8o/rCgU+B4JSyZBKbeZqzhtwtC3ovxjw== dependencies: - lodash "^4.17.20" - renderkid "^3.0.0" + detect-libc "^2.0.0" + expand-template "^2.0.3" + github-from-package "0.0.0" + minimist "^1.2.3" + mkdirp-classic "^0.5.3" + napi-build-utils "^1.0.1" + node-abi "^3.3.0" + pump "^3.0.0" + rc "^1.2.7" + simple-get "^4.0.0" + tar-fs "^2.0.0" + tunnel-agent "^0.6.0" -process-nextick-args@~2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" - integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== - -process@^0.11.10: - version "0.11.10" - resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" - integrity sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A== - -progress-webpack-plugin@^1.0.12: - version "1.0.16" - resolved "https://registry.yarnpkg.com/progress-webpack-plugin/-/progress-webpack-plugin-1.0.16.tgz#278f5c1afd21af783aad72c5ec95241520230fe5" - integrity sha512-sdiHuuKOzELcBANHfrupYo+r99iPRyOnw15qX+rNlVUqXGfjXdH4IgxriKwG1kNJwVswKQHMdj1hYZMcb9jFaA== - dependencies: - chalk "^2.1.0" - figures "^2.0.0" - log-update "^2.3.0" - -progress@^2.0.0, progress@^2.0.3: +progress@^2.0.3: version "2.0.3" - resolved "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" + resolved "https://registry.npmmirror.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" integrity sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA== -promise-inflight@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3" - integrity sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g== - promise-retry@^2.0.1: version "2.0.1" - resolved "https://registry.yarnpkg.com/promise-retry/-/promise-retry-2.0.1.tgz#ff747a13620ab57ba688f5fc67855410c370da22" + resolved "https://registry.npmmirror.com/promise-retry/-/promise-retry-2.0.1.tgz#ff747a13620ab57ba688f5fc67855410c370da22" integrity sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g== dependencies: err-code "^2.0.2" retry "^0.12.0" -proxy-addr@~2.0.7: - version "2.0.7" - resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" - integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== - dependencies: - forwarded "0.2.0" - ipaddr.js "1.9.1" - -pseudomap@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3" - integrity sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ== +prr@~1.0.1: + version "1.0.1" + resolved "https://registry.npmmirror.com/prr/-/prr-1.0.1.tgz#d3fc114ba06995a45ec6893f484ceb1d78f5f476" + integrity sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw== psl@^1.1.28: version "1.9.0" - resolved "https://registry.yarnpkg.com/psl/-/psl-1.9.0.tgz#d0df2a137f00794565fcaf3b2c00cd09f8d5a5a7" + resolved "https://registry.npmmirror.com/psl/-/psl-1.9.0.tgz#d0df2a137f00794565fcaf3b2c00cd09f8d5a5a7" integrity sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag== pump@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" + resolved "https://registry.npmmirror.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" integrity sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww== dependencies: end-of-stream "^1.1.0" once "^1.3.1" -punycode@^2.1.0: - version "2.1.1" - resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" - integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== - -punycode@^2.1.1: +punycode@^2.1.0, punycode@^2.1.1: version "2.3.0" - resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.0.tgz#f67fa67c94da8f4d0cfff981aee4118064199b8f" + resolved "https://registry.npmmirror.com/punycode/-/punycode-2.3.0.tgz#f67fa67c94da8f4d0cfff981aee4118064199b8f" integrity sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA== -pupa@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/pupa/-/pupa-2.1.1.tgz#f5e8fd4afc2c5d97828faa523549ed8744a20d62" - integrity sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A== - dependencies: - escape-goat "^2.0.0" - -qs@6.10.3: - version "6.10.3" - resolved "https://registry.yarnpkg.com/qs/-/qs-6.10.3.tgz#d6cde1b2ffca87b5aa57889816c5f81535e22e8e" - integrity sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ== - dependencies: - side-channel "^1.0.4" - qs@~6.5.2: version "6.5.3" - resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.3.tgz#3aeeffc91967ef6e35c0e488ef46fb296ab76aad" + resolved "https://registry.npmmirror.com/qs/-/qs-6.5.3.tgz#3aeeffc91967ef6e35c0e488ef46fb296ab76aad" integrity sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA== queue-microtask@^1.2.2: version "1.2.3" - resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + resolved "https://registry.npmmirror.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== quick-lru@^5.1.1: version "5.1.1" - resolved "https://registry.yarnpkg.com/quick-lru/-/quick-lru-5.1.1.tgz#366493e6b3e42a3a6885e2e99d18f80fb7a8c932" + resolved "https://registry.npmmirror.com/quick-lru/-/quick-lru-5.1.1.tgz#366493e6b3e42a3a6885e2e99d18f80fb7a8c932" integrity sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA== -randombytes@^2.1.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.1.0.tgz#df6f84372f0270dc65cdf6291349ab7a473d4f2a" - integrity sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ== - dependencies: - safe-buffer "^5.1.0" - -range-parser@^1.2.1, range-parser@~1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" - integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== - -raw-body@2.5.1: - version "2.5.1" - resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.1.tgz#fe1b1628b181b700215e5fd42389f98b71392857" - integrity sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig== - dependencies: - bytes "3.1.2" - http-errors "2.0.0" - iconv-lite "0.4.24" - unpipe "1.0.0" - -rc@1.2.8, rc@^1.2.8: +rc@^1.2.7: version "1.2.8" - resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.8.tgz#cd924bf5200a075b83c188cd6b9e211b7fc0d3ed" + resolved "https://registry.npmmirror.com/rc/-/rc-1.2.8.tgz#cd924bf5200a075b83c188cd6b9e211b7fc0d3ed" integrity sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw== dependencies: deep-extend "^0.6.0" @@ -7295,25 +2836,14 @@ rc@1.2.8, rc@^1.2.8: read-cache@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/read-cache/-/read-cache-1.0.0.tgz#e664ef31161166c9751cdbe8dbcf86b5fb58f774" + resolved "https://registry.npmmirror.com/read-cache/-/read-cache-1.0.0.tgz#e664ef31161166c9751cdbe8dbcf86b5fb58f774" integrity sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA== dependencies: pify "^2.3.0" -read-config-file@6.2.0: - version "6.2.0" - resolved "https://registry.yarnpkg.com/read-config-file/-/read-config-file-6.2.0.tgz#71536072330bcd62ba814f91458b12add9fc7ade" - integrity sha512-gx7Pgr5I56JtYz+WuqEbQHj/xWo+5Vwua2jhb1VwM4Wid5PqYmZ4i00ZB0YEGIfkVBsCv9UrjgyqCiQfS/Oosg== - dependencies: - dotenv "^9.0.2" - dotenv-expand "^5.1.0" - js-yaml "^4.1.0" - json5 "^2.2.0" - lazy-val "^1.0.4" - read-config-file@6.3.2: version "6.3.2" - resolved "https://registry.yarnpkg.com/read-config-file/-/read-config-file-6.3.2.tgz#556891aa6ffabced916ed57457cb192e61880411" + resolved "https://registry.npmmirror.com/read-config-file/-/read-config-file-6.3.2.tgz#556891aa6ffabced916ed57457cb192e61880411" integrity sha512-M80lpCjnE6Wt6zb98DoW8WHR09nzMSpu8XHtPkiTHrJ5Az9CybfeQhTJ8D7saeBHpGhLPIVyA8lcL6ZmdKwY6Q== dependencies: config-file-ts "^0.2.4" @@ -7323,156 +2853,30 @@ read-config-file@6.3.2: json5 "^2.2.0" lazy-val "^1.0.4" -read-pkg-up@^7.0.1: - version "7.0.1" - resolved "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-7.0.1.tgz#f3a6135758459733ae2b95638056e1854e7ef507" - integrity sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg== - dependencies: - find-up "^4.1.0" - read-pkg "^5.2.0" - type-fest "^0.8.1" - -read-pkg@^5.1.1, read-pkg@^5.2.0: - version "5.2.0" - resolved "https://registry.yarnpkg.com/read-pkg/-/read-pkg-5.2.0.tgz#7bf295438ca5a33e56cd30e053b34ee7250c93cc" - integrity sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg== - dependencies: - "@types/normalize-package-data" "^2.4.0" - normalize-package-data "^2.5.0" - parse-json "^5.0.0" - type-fest "^0.6.0" - -readable-stream@^2.0.1, readable-stream@~2.3.6: - version "2.3.7" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" - integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== - dependencies: - core-util-is "~1.0.0" - inherits "~2.0.3" - isarray "~1.0.0" - process-nextick-args "~2.0.0" - safe-buffer "~5.1.1" - string_decoder "~1.1.1" - util-deprecate "~1.0.1" - -readable-stream@^3.0.6, readable-stream@^3.4.0: - version "3.6.0" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" - integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== - dependencies: - inherits "^2.0.3" - string_decoder "^1.1.1" - util-deprecate "^1.0.1" - -readable-stream@^3.6.0: +readable-stream@^3.1.1, readable-stream@^3.4.0: version "3.6.2" - resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" + resolved "https://registry.npmmirror.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== dependencies: inherits "^2.0.3" string_decoder "^1.1.1" util-deprecate "^1.0.1" -readable-web-to-node-stream@^3.0.0: - version "3.0.2" - resolved "https://registry.yarnpkg.com/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.2.tgz#5d52bb5df7b54861fd48d015e93a2cb87b3ee0bb" - integrity sha512-ePeK6cc1EcKLEhJFt/AebMCLL+GgSKhuygrZ/GLaKZYEecIgIECf4UaUuaByiGtzckwR4ain9VzUh95T1exYGw== - dependencies: - readable-stream "^3.6.0" - readdirp@~3.6.0: version "3.6.0" - resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" + resolved "https://registry.npmmirror.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== dependencies: picomatch "^2.2.1" -regenerate-unicode-properties@^10.1.0: - version "10.1.0" - resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz#7c3192cab6dd24e21cb4461e5ddd7dd24fa8374c" - integrity sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ== - dependencies: - regenerate "^1.4.2" - -regenerate@^1.4.2: - version "1.4.2" - resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.4.2.tgz#b9346d8827e8f5a32f7ba29637d398b69014848a" - integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== - -regenerator-runtime@^0.13.3: - version "0.13.11" - resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz#f6dca3e7ceec20590d07ada785636a90cdca17f9" - integrity sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg== - -regenerator-runtime@^0.13.4: - version "0.13.9" - resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz#8925742a98ffd90814988d7566ad30ca3b263b52" - integrity sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA== - -regenerator-transform@^0.15.0: - version "0.15.0" - resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.15.0.tgz#cbd9ead5d77fae1a48d957cf889ad0586adb6537" - integrity sha512-LsrGtPmbYg19bcPHwdtmXwbW+TqNvtY4riE3P83foeHRroMbH6/2ddFBfab3t7kbzc7v7p4wbkIecHImqt0QNg== - dependencies: - "@babel/runtime" "^7.8.4" - -regexpu-core@^5.1.0: - version "5.2.1" - resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-5.2.1.tgz#a69c26f324c1e962e9ffd0b88b055caba8089139" - integrity sha512-HrnlNtpvqP1Xkb28tMhBUO2EbyUHdQlsnlAhzWcwHy8WJR53UWr7/MAvqrsQKMbV4qdpv03oTMG8iIhfsPFktQ== - dependencies: - regenerate "^1.4.2" - regenerate-unicode-properties "^10.1.0" - regjsgen "^0.7.1" - regjsparser "^0.9.1" - unicode-match-property-ecmascript "^2.0.0" - unicode-match-property-value-ecmascript "^2.0.0" - -registry-auth-token@^4.0.0: - version "4.2.2" - resolved "https://registry.yarnpkg.com/registry-auth-token/-/registry-auth-token-4.2.2.tgz#f02d49c3668884612ca031419491a13539e21fac" - integrity sha512-PC5ZysNb42zpFME6D/XlIgtNGdTl8bBOCw90xQLVMpzuuubJKYDWFAEuUNc+Cn8Z8724tg2SDhDRrkVEsqfDMg== - dependencies: - rc "1.2.8" - -registry-url@^5.0.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/registry-url/-/registry-url-5.1.0.tgz#e98334b50d5434b81136b44ec638d9c2009c5009" - integrity sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw== - dependencies: - rc "^1.2.8" - -regjsgen@^0.7.1: - version "0.7.1" - resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.7.1.tgz#ee5ef30e18d3f09b7c369b76e7c2373ed25546f6" - integrity sha512-RAt+8H2ZEzHeYWxZ3H2z6tF18zyyOnlcdaafLrm21Bguj7uZy6ULibiAFdXEtKQY4Sy7wDTwDiOazasMLc4KPA== - -regjsparser@^0.9.1: - version "0.9.1" - resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.9.1.tgz#272d05aa10c7c1f67095b1ff0addae8442fc5709" - integrity sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ== - dependencies: - jsesc "~0.5.0" - -relateurl@^0.2.7: - version "0.2.7" - resolved "https://registry.yarnpkg.com/relateurl/-/relateurl-0.2.7.tgz#54dbf377e51440aca90a4cd274600d3ff2d888a9" - integrity sha512-G08Dxvm4iDN3MLM0EsP62EDV9IuhXPR6blNz6Utcp7zyV3tr4HVNINt6MpaRWbxoOHT3Q7YN2P+jaHX8vUbgog== - -renderkid@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/renderkid/-/renderkid-3.0.0.tgz#5fd823e4d6951d37358ecc9a58b1f06836b6268a" - integrity sha512-q/7VIQA8lmM1hF+jn+sFSPWGlMkSAeNYcPLmDQx2zzuiDfaLrOmumR8iaUKlenFgh0XRPIUeSPlH3A+AW3Z5pg== - dependencies: - css-select "^4.1.3" - dom-converter "^0.2.0" - htmlparser2 "^6.1.0" - lodash "^4.17.21" - strip-ansi "^6.0.1" +regenerator-runtime@^0.14.0: + version "0.14.0" + resolved "https://registry.npmmirror.com/regenerator-runtime/-/regenerator-runtime-0.14.0.tgz#5e19d68eb12d486f797e15a3c6a918f7cec5eb45" + integrity sha512-srw17NI0TUWHuGa5CFGGmhfNIeja30WMBfbslPNhf6JrqQlLN5gcrvig1oqPxiVaXb0oW0XRKtH6Nngs5lKCIA== request@^2.88.2: version "2.88.2" - resolved "https://registry.yarnpkg.com/request/-/request-2.88.2.tgz#d73c918731cb5a87da047e207234146f664d12b3" + resolved "https://registry.npmmirror.com/request/-/request-2.88.2.tgz#d73c918731cb5a87da047e207234146f664d12b3" integrity sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw== dependencies: aws-sign2 "~0.7.0" @@ -7498,100 +2902,60 @@ request@^2.88.2: require-directory@^2.1.1: version "2.1.1" - resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" + resolved "https://registry.npmmirror.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" integrity sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q== require-from-string@^2.0.2: version "2.0.2" - resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" + resolved "https://registry.npmmirror.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== -requires-port@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/requires-port/-/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff" - integrity sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ== - resolve-alpn@^1.0.0: version "1.2.1" - resolved "https://registry.yarnpkg.com/resolve-alpn/-/resolve-alpn-1.2.1.tgz#b7adbdac3546aaaec20b45e7d8265927072726f9" + resolved "https://registry.npmmirror.com/resolve-alpn/-/resolve-alpn-1.2.1.tgz#b7adbdac3546aaaec20b45e7d8265927072726f9" integrity sha512-0a1F4l73/ZFZOakJnQ3FvkJ2+gSTQWz/r2KE5OdDY0TxPm5h4GkqkWWfM47T7HsbnOtcJVEF4epCVy6u7Q3K+g== -resolve-from@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" - integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== - -resolve@^1.1.7, resolve@^1.10.0, resolve@^1.14.2, resolve@^1.22.1: - version "1.22.1" - resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.1.tgz#27cb2ebb53f91abb49470a928bba7558066ac177" - integrity sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw== +resolve@^1.1.7, resolve@^1.22.2: + version "1.22.8" + resolved "https://registry.npmmirror.com/resolve/-/resolve-1.22.8.tgz#b6c87a9f2aa06dfab52e3d70ac8cde321fa5a48d" + integrity sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw== dependencies: - is-core-module "^2.9.0" + is-core-module "^2.13.0" path-parse "^1.0.7" supports-preserve-symlinks-flag "^1.0.0" -responselike@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/responselike/-/responselike-1.0.2.tgz#918720ef3b631c5642be068f15ade5a46f4ba1e7" - integrity sha512-/Fpe5guzJk1gPqdJLJR5u7eG/gNY4nImjbRDaVWVMRhne55TCmj2i9Q+54PBRfatRC8v/rIiv9BN0pMd9OV5EQ== - dependencies: - lowercase-keys "^1.0.0" - responselike@^2.0.0: version "2.0.1" - resolved "https://registry.yarnpkg.com/responselike/-/responselike-2.0.1.tgz#9a0bc8fdc252f3fb1cca68b016591059ba1422bc" + resolved "https://registry.npmmirror.com/responselike/-/responselike-2.0.1.tgz#9a0bc8fdc252f3fb1cca68b016591059ba1422bc" integrity sha512-4gl03wn3hj1HP3yzgdI7d3lCkF95F21Pz4BPGvKHinyQzALR5CapwC8yIi0Rh58DEMQ/SguC03wFj2k0M/mHhw== dependencies: lowercase-keys "^2.0.0" -restore-cursor@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-2.0.0.tgz#9f7ee287f82fd326d4fd162923d62129eee0dfaf" - integrity sha512-6IzJLuGi4+R14vwagDHX+JrXmPVtPpn4mffDJ1UdR7/Edm87fl6yi8mMBIVvFtJaNTUvjughmW4hwLhRG7gC1Q== - dependencies: - onetime "^2.0.0" - signal-exit "^3.0.2" - -restore-cursor@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/restore-cursor/-/restore-cursor-3.1.0.tgz#39f67c54b3a7a58cea5236d95cf0034239631f7e" - integrity sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA== - dependencies: - onetime "^5.1.0" - signal-exit "^3.0.2" - retry@^0.12.0: version "0.12.0" - resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" + resolved "https://registry.npmmirror.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" integrity sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow== retry@^0.13.1: version "0.13.1" - resolved "https://registry.yarnpkg.com/retry/-/retry-0.13.1.tgz#185b1587acf67919d63b357349e03537b2484658" + resolved "https://registry.npmmirror.com/retry/-/retry-0.13.1.tgz#185b1587acf67919d63b357349e03537b2484658" integrity sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg== reusify@^1.0.4: version "1.0.4" - resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + resolved "https://registry.npmmirror.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== -rimraf@^2.5.4: - version "2.7.1" - resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" - integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== - dependencies: - glob "^7.1.3" - -rimraf@^3.0.0, rimraf@^3.0.2: +rimraf@^3.0.0: version "3.0.2" - resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" + resolved "https://registry.npmmirror.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== dependencies: glob "^7.1.3" roarr@^2.15.3: version "2.15.4" - resolved "https://registry.yarnpkg.com/roarr/-/roarr-2.15.4.tgz#f5fe795b7b838ccfe35dc608e0282b9eba2e7afd" + resolved "https://registry.npmmirror.com/roarr/-/roarr-2.15.4.tgz#f5fe795b7b838ccfe35dc608e0282b9eba2e7afd" integrity sha512-CHhPh+UNHD2GTXNYhPWLnU8ONHdI+5DI+4EYIAOaiD63rHeYlZvyh8P+in5999TTSFgUYuKUAjzRI4mdh/p+2A== dependencies: boolean "^3.0.1" @@ -7601,413 +2965,173 @@ roarr@^2.15.3: semver-compare "^1.0.0" sprintf-js "^1.1.2" +rollup@^3.27.1: + version "3.29.4" + resolved "https://registry.npmmirror.com/rollup/-/rollup-3.29.4.tgz#4d70c0f9834146df8705bfb69a9a19c9e1109981" + integrity sha512-oWzmBZwvYrU0iJHtDmhsm662rC15FRXmcjCk1xD771dFDx5jJ02ufAQQTn0etB2emNk4J9EZg/yWKpsn9BWGRw== + optionalDependencies: + fsevents "~2.3.2" + run-parallel@^1.1.9: version "1.2.0" - resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + resolved "https://registry.npmmirror.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== dependencies: queue-microtask "^1.2.2" -safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: - version "5.1.2" - resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" - integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== - -safe-buffer@5.2.1, safe-buffer@>=5.1.0, safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.2, safe-buffer@~5.2.0: +safe-buffer@^5.0.1, safe-buffer@^5.1.2, safe-buffer@~5.2.0: version "5.2.1" - resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" + resolved "https://registry.npmmirror.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== -"safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0", safer-buffer@^2.0.2, safer-buffer@^2.1.0, safer-buffer@~2.1.0: +"safer-buffer@>= 2.1.2 < 3.0.0", safer-buffer@^2.0.2, safer-buffer@^2.1.0, safer-buffer@~2.1.0: version "2.1.2" - resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" + resolved "https://registry.npmmirror.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== sanitize-filename@^1.6.3: version "1.6.3" - resolved "https://registry.yarnpkg.com/sanitize-filename/-/sanitize-filename-1.6.3.tgz#755ebd752045931977e30b2025d340d7c9090378" + resolved "https://registry.npmmirror.com/sanitize-filename/-/sanitize-filename-1.6.3.tgz#755ebd752045931977e30b2025d340d7c9090378" integrity sha512-y/52Mcy7aw3gRm7IrcGDFx/bCk4AhRh2eI9luHOQM86nZsqwiRkkq2GekHXBBD+SmPidc8i2PqtYZl+pWJ8Oeg== dependencies: truncate-utf8-bytes "^1.0.0" sax@>=0.6.0, sax@^1.2.4: - version "1.2.4" - resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" - integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== + version "1.3.0" + resolved "https://registry.npmmirror.com/sax/-/sax-1.3.0.tgz#a5dbe77db3be05c9d1ee7785dbd3ea9de51593d0" + integrity sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA== -schema-utils@^2.6.5: - version "2.7.1" - resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-2.7.1.tgz#1ca4f32d1b24c590c203b8e7a50bf0ea4cd394d7" - integrity sha512-SHiNtMOUGWBQJwzISiVYKu82GiV4QYGePp3odlY1tuKO7gPtphAT5R/py0fA6xtbgLL/RvtJZnU9b8s0F1q0Xg== - dependencies: - "@types/json-schema" "^7.0.5" - ajv "^6.12.4" - ajv-keywords "^3.5.2" - -schema-utils@^3.0.0, schema-utils@^3.1.0, schema-utils@^3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-3.1.1.tgz#bc74c4b6b6995c1d88f76a8b77bea7219e0c8281" - integrity sha512-Y5PQxS4ITlC+EahLuXaY86TXfR7Dc5lw294alXOq86JAHCihAIZfqv8nNCWvaEJvaC51uN9hbLGeV0cFBdH+Fw== - dependencies: - "@types/json-schema" "^7.0.8" - ajv "^6.12.5" - ajv-keywords "^3.5.2" - -schema-utils@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-4.0.0.tgz#60331e9e3ae78ec5d16353c467c34b3a0a1d3df7" - integrity sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg== - dependencies: - "@types/json-schema" "^7.0.9" - ajv "^8.8.0" - ajv-formats "^2.1.1" - ajv-keywords "^5.0.0" - -select-hose@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/select-hose/-/select-hose-2.0.0.tgz#625d8658f865af43ec962bfc376a37359a4994ca" - integrity sha512-mEugaLK+YfkijB4fx0e6kImuJdCIt2LxCRcbEYPqRGCs4F2ogyfZU5IAZRdjCP8JPq2AtdNoC/Dux63d9Kiryg== - -selfsigned@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/selfsigned/-/selfsigned-2.1.1.tgz#18a7613d714c0cd3385c48af0075abf3f266af61" - integrity sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ== - dependencies: - node-forge "^1" +seemly@^0.3.6: + version "0.3.6" + resolved "https://registry.npmmirror.com/seemly/-/seemly-0.3.6.tgz#7ef97e8083dea00804965e2662f572a5df9cb18e" + integrity sha512-lEV5VB8BUKTo/AfktXJcy+JeXns26ylbMkIUco8CYREsQijuz4mrXres2Q+vMLdwkuLxJdIPQ8IlCIxLYm71Yw== semver-compare@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/semver-compare/-/semver-compare-1.0.0.tgz#0dee216a1c941ab37e9efb1788f6afc5ff5537fc" + resolved "https://registry.npmmirror.com/semver-compare/-/semver-compare-1.0.0.tgz#0dee216a1c941ab37e9efb1788f6afc5ff5537fc" integrity sha512-YM3/ITh2MJ5MtzaM429anh+x2jiLVjqILF4m4oyQB18W7Ggea7BfqdH/wGMK7dDiMghv/6WG7znWMwUDzJiXow== -semver-diff@^3.1.1: - version "3.1.1" - resolved "https://registry.yarnpkg.com/semver-diff/-/semver-diff-3.1.1.tgz#05f77ce59f325e00e2706afd67bb506ddb1ca32b" - integrity sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg== - dependencies: - semver "^6.3.0" +semver@^5.6.0: + version "5.7.2" + resolved "https://registry.npmmirror.com/semver/-/semver-5.7.2.tgz#48d55db737c3287cd4835e17fa13feace1c41ef8" + integrity sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g== -"semver@2 || 3 || 4 || 5", semver@^5.5.0: - version "5.7.1" - resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" - integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== +semver@^6.2.0: + version "6.3.1" + resolved "https://registry.npmmirror.com/semver/-/semver-6.3.1.tgz#556d2ef8689146e46dcea4bfdd095f3434dffcb4" + integrity sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA== -semver@^6.0.0, semver@^6.1.1, semver@^6.1.2, semver@^6.2.0, semver@^6.3.0: - version "6.3.0" - resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" - integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== - -semver@^7.2.1, semver@^7.3.2, semver@^7.3.4, semver@^7.3.5: - version "7.3.7" - resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.7.tgz#12c5b649afdbf9049707796e22a4028814ce523f" - integrity sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g== +semver@^7.3.2, semver@^7.3.5, semver@^7.3.8, semver@^7.5.3, semver@^7.5.4: + version "7.5.4" + resolved "https://registry.npmmirror.com/semver/-/semver-7.5.4.tgz#483986ec4ed38e1c6c48c34894a9182dbff68a6e" + integrity sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA== dependencies: lru-cache "^6.0.0" -semver@^7.3.8: - version "7.5.1" - resolved "https://registry.yarnpkg.com/semver/-/semver-7.5.1.tgz#c90c4d631cf74720e46b21c1d37ea07edfab91ec" - integrity sha512-Wvss5ivl8TMRZXXESstBA4uR5iXgEN/VC5/sOcuXdVLzcdkz4HWetIoRfG5gb5X+ij/G9rw9YoGn3QoQ8OCSpw== - dependencies: - lru-cache "^6.0.0" - -semver@~7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/semver/-/semver-7.0.0.tgz#5f3ca35761e47e05b206c6daff2cf814f0316b8e" - integrity sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A== - -send@0.18.0: - version "0.18.0" - resolved "https://registry.yarnpkg.com/send/-/send-0.18.0.tgz#670167cc654b05f5aa4a767f9113bb371bc706be" - integrity sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg== - dependencies: - debug "2.6.9" - depd "2.0.0" - destroy "1.2.0" - encodeurl "~1.0.2" - escape-html "~1.0.3" - etag "~1.8.1" - fresh "0.5.2" - http-errors "2.0.0" - mime "1.6.0" - ms "2.1.3" - on-finished "2.4.1" - range-parser "~1.2.1" - statuses "2.0.1" - serialize-error@^7.0.1: version "7.0.1" - resolved "https://registry.yarnpkg.com/serialize-error/-/serialize-error-7.0.1.tgz#f1360b0447f61ffb483ec4157c737fab7d778e18" + resolved "https://registry.npmmirror.com/serialize-error/-/serialize-error-7.0.1.tgz#f1360b0447f61ffb483ec4157c737fab7d778e18" integrity sha512-8I8TjW5KMOKsZQTvoxjuSIa7foAwPWGOts+6o7sgjz41/qMD9VQHEDxi6PBvK2l0MXUmqZyNpUK+T2tQaaElvw== dependencies: type-fest "^0.13.1" -serialize-javascript@^6.0.0: - version "6.0.0" - resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.0.tgz#efae5d88f45d7924141da8b5c3a7a7e663fefeb8" - integrity sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag== - dependencies: - randombytes "^2.1.0" - -serialize-javascript@^6.0.1: - version "6.0.1" - resolved "https://registry.yarnpkg.com/serialize-javascript/-/serialize-javascript-6.0.1.tgz#b206efb27c3da0b0ab6b52f48d170b7996458e5c" - integrity sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w== - dependencies: - randombytes "^2.1.0" - -serve-index@^1.9.1: - version "1.9.1" - resolved "https://registry.yarnpkg.com/serve-index/-/serve-index-1.9.1.tgz#d3768d69b1e7d82e5ce050fff5b453bea12a9239" - integrity sha512-pXHfKNP4qujrtteMrSBb0rc8HJ9Ms/GrXwcUtUtD5s4ewDJI8bT3Cz2zTVRMKtri49pLx2e0Ya8ziP5Ya2pZZw== - dependencies: - accepts "~1.3.4" - batch "0.6.1" - debug "2.6.9" - escape-html "~1.0.3" - http-errors "~1.6.2" - mime-types "~2.1.17" - parseurl "~1.3.2" - -serve-static@1.15.0: - version "1.15.0" - resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.15.0.tgz#faaef08cffe0a1a62f60cad0c4e513cff0ac9540" - integrity sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g== - dependencies: - encodeurl "~1.0.2" - escape-html "~1.0.3" - parseurl "~1.3.3" - send "0.18.0" - -set-blocking@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" - integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw== - -setimmediate@^1.0.5: - version "1.0.5" - resolved "https://registry.npmmirror.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285" - integrity sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA== - -setprototypeof@1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.0.tgz#d0bd85536887b6fe7c0d818cb962d9d91c54e656" - integrity sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ== - -setprototypeof@1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424" - integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== - -shallow-clone@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/shallow-clone/-/shallow-clone-3.0.1.tgz#8f2981ad92531f55035b01fb230769a40e02efa3" - integrity sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA== - dependencies: - kind-of "^6.0.2" - -shebang-command@^1.2.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz#44aac65b695b03398968c39f363fee5deafdf1ea" - integrity sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg== - dependencies: - shebang-regex "^1.0.0" - shebang-command@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + resolved "https://registry.npmmirror.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== dependencies: shebang-regex "^3.0.0" -shebang-loader@^0.0.1: - version "0.0.1" - resolved "https://registry.yarnpkg.com/shebang-loader/-/shebang-loader-0.0.1.tgz#a4000495d44cceefbec63435e7b1698569fa52ec" - integrity sha512-nQvhUHvKyzGK5aqPxHfHB5nlAN2EZ2U61S2G0YrxAuCRU5iGhFcxxRiaAdb18UoRS1zVMhRz4gdQ1xFEg3AOyA== - -shebang-regex@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz#da42f49740c0b42db2ca9728571cb190c98efea3" - integrity sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ== - shebang-regex@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + resolved "https://registry.npmmirror.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== -shell-quote@^1.7.3: - version "1.7.3" - resolved "https://registry.yarnpkg.com/shell-quote/-/shell-quote-1.7.3.tgz#aa40edac170445b9a431e17bb62c0b881b9c4123" - integrity sha512-Vpfqwm4EnqGdlsBFNmHhxhElJYrdfcxPThu+ryKS5J8L/fhAwLazFZtq+S+TWZ9ANj2piSQLGj6NQg+lKPmxrw== +simple-concat@^1.0.0: + version "1.0.1" + resolved "https://registry.npmmirror.com/simple-concat/-/simple-concat-1.0.1.tgz#f46976082ba35c2263f1c8ab5edfe26c41c9552f" + integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q== -side-channel@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" - integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== +simple-get@^4.0.0: + version "4.0.1" + resolved "https://registry.npmmirror.com/simple-get/-/simple-get-4.0.1.tgz#4a39db549287c979d352112fa03fd99fd6bc3543" + integrity sha512-brv7p5WgH0jmQJr1ZDDfKDOSeWWg+OVypG99A/5vYGPqJ6pxiaHLy8nxtFjBA7oMa01ebA9gfh1uMCFqOuXxvA== dependencies: - call-bind "^1.0.0" - get-intrinsic "^1.0.2" - object-inspect "^1.9.0" + decompress-response "^6.0.0" + once "^1.3.1" + simple-concat "^1.0.0" -signal-exit@^3.0.0, signal-exit@^3.0.2, signal-exit@^3.0.3, signal-exit@^3.0.7: - version "3.0.7" - resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" - integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== - -simple-update-notifier@^1.1.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/simple-update-notifier/-/simple-update-notifier-1.1.0.tgz#67694c121de354af592b347cdba798463ed49c82" - integrity sha512-VpsrsJSUcJEseSbMHkrsrAVSdvVS5I96Qo1QAQ4FxQ9wXFcB+pjj7FB7/us9+GcgfW4ziHtYMc1J0PLczb55mg== +simple-update-notifier@2.0.0: + version "2.0.0" + resolved "https://registry.npmmirror.com/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz#d70b92bdab7d6d90dfd73931195a30b6e3d7cebb" + integrity sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w== dependencies: - semver "~7.0.0" + semver "^7.5.3" -simplebar@^5.3.8: - version "5.3.9" - resolved "https://registry.yarnpkg.com/simplebar/-/simplebar-5.3.9.tgz#168ea0eb6d52f29f03960e40d9b69a1b28cf6318" - integrity sha512-1vIIpjDvY9sVH14e0LGeiCiTFU3ILqAghzO6OI9axeG+mvU/vMSrvXeAXkBolqFFz3XYaY8n5ahH9MeP3sp2Ag== +simplebar-core@^1.2.4: + version "1.2.4" + resolved "https://registry.npmmirror.com/simplebar-core/-/simplebar-core-1.2.4.tgz#1fe965716a426f812c1a112ce28d98b9a643797b" + integrity sha512-P+Sqshef4fq3++gQ82TgNYcgl3qZFSCP5jS2/8NMmw18oagXOijMzs1G+vm6RUY3oMvpwH3wGoqh9u6SyDjHfQ== dependencies: - "@juggle/resize-observer" "^3.3.1" + "@types/lodash-es" "^4.17.6" can-use-dom "^0.1.0" - core-js "^3.0.1" - lodash.debounce "^4.0.8" - lodash.memoize "^4.1.2" - lodash.throttle "^4.1.1" + lodash "^4.17.21" + lodash-es "^4.17.21" -sirv@^1.0.7: - version "1.0.19" - resolved "https://registry.yarnpkg.com/sirv/-/sirv-1.0.19.tgz#1d73979b38c7fe91fcba49c85280daa9c2363b49" - integrity sha512-JuLThK3TnZG1TAKDwNIqNq6QA2afLOCcm+iE8D1Kj3GA40pSPsxQjjJl0J8X3tsR7T+CP1GavpzLwYkgVLWrZQ== +simplebar@^6.2.5: + version "6.2.5" + resolved "https://registry.npmmirror.com/simplebar/-/simplebar-6.2.5.tgz#9d7cdf9f9a57b28f2497d165caf60f1bc644913e" + integrity sha512-vfxKR6KNBsPx7+sZnqO7T8VuCvi4px6OlycrrkNgyjvoHhRW7LIyVkHhUfXxbz33Gw99Wb9UMMsnEZv35wtLSw== dependencies: - "@polka/url" "^1.0.0-next.20" - mrmime "^1.0.0" - totalist "^1.0.0" - -slash@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" - integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + can-use-dom "^0.1.0" + simplebar-core "^1.2.4" slice-ansi@^3.0.0: version "3.0.0" - resolved "https://registry.yarnpkg.com/slice-ansi/-/slice-ansi-3.0.0.tgz#31ddc10930a1b7e0b67b08c96c2f49b77a789787" + resolved "https://registry.npmmirror.com/slice-ansi/-/slice-ansi-3.0.0.tgz#31ddc10930a1b7e0b67b08c96c2f49b77a789787" integrity sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ== dependencies: ansi-styles "^4.0.0" astral-regex "^2.0.0" is-fullwidth-code-point "^3.0.0" -smart-buffer@^4.0.2, smart-buffer@^4.2.0: +smart-buffer@^4.0.2: version "4.2.0" - resolved "https://registry.yarnpkg.com/smart-buffer/-/smart-buffer-4.2.0.tgz#6e1d71fa4f18c05f7d0ff216dd16a481d0e8d9ae" + resolved "https://registry.npmmirror.com/smart-buffer/-/smart-buffer-4.2.0.tgz#6e1d71fa4f18c05f7d0ff216dd16a481d0e8d9ae" integrity sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg== -sockjs@^0.3.24: - version "0.3.24" - resolved "https://registry.yarnpkg.com/sockjs/-/sockjs-0.3.24.tgz#c9bc8995f33a111bea0395ec30aa3206bdb5ccce" - integrity sha512-GJgLTZ7vYb/JtPSSZ10hsOYIvEYsjbNU+zPdIHcUaWVNUEPivzxku31865sSSud0Da0W4lEeOPlmw93zLQchuQ== - dependencies: - faye-websocket "^0.11.3" - uuid "^8.3.2" - websocket-driver "^0.7.4" - -socks-proxy-agent@^7.0.0: - version "7.0.0" - resolved "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-7.0.0.tgz#dc069ecf34436621acb41e3efa66ca1b5fed15b6" - integrity sha512-Fgl0YPZ902wEsAyiQ+idGd1A7rSFx/ayC1CQVMw5P+EQx2V0SgpGtf6OKFhVjPflPUl9YMmEOnmfjCdMUsygww== - dependencies: - agent-base "^6.0.2" - debug "^4.3.3" - socks "^2.6.2" - -socks@^2.6.2: - version "2.7.1" - resolved "https://registry.yarnpkg.com/socks/-/socks-2.7.1.tgz#d8e651247178fde79c0663043e07240196857d55" - integrity sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ== - dependencies: - ip "^2.0.0" - smart-buffer "^4.2.0" - sortablejs@^1.15.0: version "1.15.0" - resolved "https://registry.yarnpkg.com/sortablejs/-/sortablejs-1.15.0.tgz#53230b8aa3502bb77a29e2005808ffdb4a5f7e2a" + resolved "https://registry.npmmirror.com/sortablejs/-/sortablejs-1.15.0.tgz#53230b8aa3502bb77a29e2005808ffdb4a5f7e2a" integrity sha512-bv9qgVMjUMf89wAvM6AxVvS/4MX3sPeN0+agqShejLU5z5GX4C75ow1O2e5k4L6XItUyAK3gH6AxSbXrOM5e8w== source-map-js@^1.0.2: version "1.0.2" - resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c" + resolved "https://registry.npmmirror.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c" integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw== -source-map-support@^0.5.19, source-map-support@~0.5.20: +source-map-support@^0.5.19: version "0.5.21" - resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" + resolved "https://registry.npmmirror.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== dependencies: buffer-from "^1.0.0" source-map "^0.6.0" -source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.0, source-map@~0.6.1: +source-map@^0.6.0, source-map@~0.6.0: version "0.6.1" - resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" + resolved "https://registry.npmmirror.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== -spdx-correct@^3.0.0: - version "3.1.1" - resolved "https://registry.yarnpkg.com/spdx-correct/-/spdx-correct-3.1.1.tgz#dece81ac9c1e6713e5f7d1b6f17d468fa53d89a9" - integrity sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w== - dependencies: - spdx-expression-parse "^3.0.0" - spdx-license-ids "^3.0.0" - -spdx-exceptions@^2.1.0: - version "2.3.0" - resolved "https://registry.yarnpkg.com/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz#3f28ce1a77a00372683eade4a433183527a2163d" - integrity sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A== - -spdx-expression-parse@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz#cf70f50482eefdc98e3ce0a6833e4a53ceeba679" - integrity sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q== - dependencies: - spdx-exceptions "^2.1.0" - spdx-license-ids "^3.0.0" - -spdx-license-ids@^3.0.0: - version "3.0.12" - resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.12.tgz#69077835abe2710b65f03969898b6637b505a779" - integrity sha512-rr+VVSXtRhO4OHbXUiAF7xW3Bo9DuuF6C5jH+q/x15j2jniycgKbxU09Hr0WqlSLUs4i4ltHGXqTe7VHclYWyA== - -spdy-transport@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/spdy-transport/-/spdy-transport-3.0.0.tgz#00d4863a6400ad75df93361a1608605e5dcdcf31" - integrity sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw== - dependencies: - debug "^4.1.0" - detect-node "^2.0.4" - hpack.js "^2.1.6" - obuf "^1.1.2" - readable-stream "^3.0.6" - wbuf "^1.7.3" - -spdy@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/spdy/-/spdy-4.0.2.tgz#b74f466203a3eda452c02492b91fb9e84a27677b" - integrity sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA== - dependencies: - debug "^4.1.0" - handle-thing "^2.0.0" - http-deceiver "^1.2.7" - select-hose "^2.0.0" - spdy-transport "^3.0.0" - sprintf-js@^1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.1.2.tgz#da1765262bf8c0f571749f2ad6c26300207ae673" - integrity sha512-VE0SOVEHCk7Qc8ulkWw3ntAzXuqf7S2lvwQaDLRnUeIEaKNQJzV6BwmLKhOqT61aGhfUMrXeaBk+oDGCzvhcug== + version "1.1.3" + resolved "https://registry.npmmirror.com/sprintf-js/-/sprintf-js-1.1.3.tgz#4914b903a2f8b685d17fdf78a70e917e872e444a" + integrity sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA== sshpk@^1.7.0: - version "1.17.0" - resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.17.0.tgz#578082d92d4fe612b13007496e543fa0fbcbe4c5" - integrity sha512-/9HIEs1ZXGhSPE8X6Ccm7Nam1z8KcoCqPdI7ecm1N33EzAetWahvQWVqLZtaZQ+IDKX4IyA2o0gBzqIMkAagHQ== + version "1.18.0" + resolved "https://registry.npmmirror.com/sshpk/-/sshpk-1.18.0.tgz#1663e55cddf4d688b86a46b77f0d5fe363aba028" + integrity sha512-2p2KJZTSqQ/I3+HX42EpYOa2l3f8Erv8MWKsy2I9uf4wA7yFIkXRffYdsx86y6z4vHtV8u7g+pPlr8/4ouAxsQ== dependencies: asn1 "~0.2.3" assert-plus "^1.0.0" @@ -8019,216 +3143,124 @@ sshpk@^1.7.0: safer-buffer "^2.0.2" tweetnacl "~0.14.0" -ssri@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/ssri/-/ssri-8.0.1.tgz#638e4e439e2ffbd2cd289776d5ca457c4f51a2af" - integrity sha512-97qShzy1AiyxvPNIkLWoGua7xoQzzPjQ0HAH4B0rWKo7SZ6USuPcrUiAFrws0UH8RrbWmgq3LMTObhPIHbbBeQ== - dependencies: - minipass "^3.1.1" - -ssri@^9.0.0: - version "9.0.1" - resolved "https://registry.yarnpkg.com/ssri/-/ssri-9.0.1.tgz#544d4c357a8d7b71a19700074b6883fcb4eae057" - integrity sha512-o57Wcn66jMQvfHG1FlYbWeZWW/dHZhJXjpIcTfXldXEk5nz5lStPo3mK0OJQfGR3RbZUlbISexbljkJzuEj/8Q== - dependencies: - minipass "^3.1.1" - -stable@^0.1.8: - version "0.1.8" - resolved "https://registry.yarnpkg.com/stable/-/stable-0.1.8.tgz#836eb3c8382fe2936feaf544631017ce7d47a3cf" - integrity sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w== - -stackframe@^1.3.4: - version "1.3.4" - resolved "https://registry.yarnpkg.com/stackframe/-/stackframe-1.3.4.tgz#b881a004c8c149a5e8efef37d51b16e412943310" - integrity sha512-oeVtt7eWQS+Na6F//S4kJ2K2VbRlS9D43mAlMyVpVWovy9o+jfgH8O9agzANzaiLjclA0oYzUXEM4PurhSUChw== - stat-mode@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/stat-mode/-/stat-mode-1.0.0.tgz#68b55cb61ea639ff57136f36b216a291800d1465" + resolved "https://registry.npmmirror.com/stat-mode/-/stat-mode-1.0.0.tgz#68b55cb61ea639ff57136f36b216a291800d1465" integrity sha512-jH9EhtKIjuXZ2cWxmXS8ZP80XyC3iasQxMDV8jzhNJpfDb7VbQLVW4Wvsxz9QZvzV+G4YoSfBUVKDOyxLzi/sg== -statuses@2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" - integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== - -"statuses@>= 1.4.0 < 2": - version "1.5.0" - resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" - integrity sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA== - -"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.0.0, string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.2, string-width@^4.2.3: +string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: version "4.2.3" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" + resolved "https://registry.npmmirror.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== dependencies: emoji-regex "^8.0.0" is-fullwidth-code-point "^3.0.0" strip-ansi "^6.0.1" -string-width@^2.1.1: - version "2.1.1" - resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" - integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== - dependencies: - is-fullwidth-code-point "^2.0.0" - strip-ansi "^4.0.0" - string_decoder@^1.1.1: version "1.3.0" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" + resolved "https://registry.npmmirror.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== dependencies: safe-buffer "~5.2.0" -string_decoder@~1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" - integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== - dependencies: - safe-buffer "~5.1.0" - -strip-ansi@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f" - integrity sha512-4XaJ2zQdCzROZDivEVIDPkcQn8LMFSa8kj8Gxb/Lnwzv9A8VctNZ+lfivC/sV3ivW8ElJTERXZoPBRrZKkNKow== - dependencies: - ansi-regex "^3.0.0" - strip-ansi@^6.0.0, strip-ansi@^6.0.1: version "6.0.1" - resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + resolved "https://registry.npmmirror.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== dependencies: ansi-regex "^5.0.1" -strip-eof@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf" - integrity sha512-7FCwGGmx8mD5xQd3RPUvnSpUXHM3BWuzjtpD4TXsfcZ9EL4azvVVUscFYwD9nx8Kh+uCBC00XBtAykoMHwTh8Q== - -strip-final-newline@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-2.0.0.tgz#89b852fb2fcbe936f6f4b3187afb0a12c1ab58ad" - integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== - strip-json-comments@~2.0.1: version "2.0.1" - resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" + resolved "https://registry.npmmirror.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" integrity sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ== -strtok3@^6.2.4: - version "6.3.0" - resolved "https://registry.yarnpkg.com/strtok3/-/strtok3-6.3.0.tgz#358b80ffe6d5d5620e19a073aa78ce947a90f9a0" - integrity sha512-fZtbhtvI9I48xDSywd/somNqgUHl2L2cstmXCCif0itOf96jeW18MBSyrLuNicYQVkvpOxkZtkzujiTJ9LW5Jw== +sucrase@^3.32.0: + version "3.34.0" + resolved "https://registry.npmmirror.com/sucrase/-/sucrase-3.34.0.tgz#1e0e2d8fcf07f8b9c3569067d92fbd8690fb576f" + integrity sha512-70/LQEZ07TEcxiU2dz51FKaE6hCTWC6vr7FOk3Gr0U60C3shtAN+H+BFr9XlYe5xqf3RA8nrc+VIwzCfnxuXJw== dependencies: - "@tokenizer/token" "^0.3.0" - peek-readable "^4.1.0" - -stylehacks@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/stylehacks/-/stylehacks-5.1.0.tgz#a40066490ca0caca04e96c6b02153ddc39913520" - integrity sha512-SzLmvHQTrIWfSgljkQCw2++C9+Ne91d/6Sp92I8c5uHTcy/PgeHamwITIbBW9wnFTY/3ZfSXR9HIL6Ikqmcu6Q== - dependencies: - browserslist "^4.16.6" - postcss-selector-parser "^6.0.4" - -subdirs@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/subdirs/-/subdirs-1.0.1.tgz#d65264787476e4caf7efc5498fb740c69f626d48" - integrity sha512-KSbUKpwQIRcb5Th+l4EzxEZYpCwV/g0pQ348EV7CIM5YEEgzz2L1KJD8FCeTckTiE/TKn2u09DCxpdAL6/iFbg== - dependencies: - es6-promise "^3.0.2" + "@jridgewell/gen-mapping" "^0.3.2" + commander "^4.0.0" + glob "7.1.6" + lines-and-columns "^1.1.6" + mz "^2.7.0" + pirates "^4.0.1" + ts-interface-checker "^0.1.9" sumchecker@^3.0.1: version "3.0.1" - resolved "https://registry.yarnpkg.com/sumchecker/-/sumchecker-3.0.1.tgz#6377e996795abb0b6d348e9b3e1dfb24345a8e42" + resolved "https://registry.npmmirror.com/sumchecker/-/sumchecker-3.0.1.tgz#6377e996795abb0b6d348e9b3e1dfb24345a8e42" integrity sha512-MvjXzkz/BOfyVDkG0oFOtBxHX2u3gKbMHIF/dXblZsgD3BWOFLmHovIpZY7BykJdAjcqRCBi1WYBNdEC9yI7vg== dependencies: debug "^4.1.0" -supports-color@^5.3.0: - version "5.5.0" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" - integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== - dependencies: - has-flag "^3.0.0" - supports-color@^7.1.0: version "7.2.0" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" + resolved "https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== dependencies: has-flag "^4.0.0" -supports-color@^8.0.0: - version "8.1.1" - resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" - integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== - dependencies: - has-flag "^4.0.0" - supports-preserve-symlinks-flag@^1.0.0: version "1.0.0" - resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" + resolved "https://registry.npmmirror.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== -svg-tags@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/svg-tags/-/svg-tags-1.0.0.tgz#58f71cee3bd519b59d4b2a843b6c7de64ac04764" - integrity sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA== - -svgo@^2.7.0: - version "2.8.0" - resolved "https://registry.yarnpkg.com/svgo/-/svgo-2.8.0.tgz#4ff80cce6710dc2795f0c7c74101e6764cfccd24" - integrity sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg== - dependencies: - "@trysound/sax" "0.2.0" - commander "^7.2.0" - css-select "^4.1.3" - css-tree "^1.1.3" - csso "^4.2.0" - picocolors "^1.0.0" - stable "^0.1.8" - -tailwindcss@^3.1.8: - version "3.1.8" - resolved "https://registry.yarnpkg.com/tailwindcss/-/tailwindcss-3.1.8.tgz#4f8520550d67a835d32f2f4021580f9fddb7b741" - integrity sha512-YSneUCZSFDYMwk+TGq8qYFdCA3yfBRdBlS7txSq0LUmzyeqRe3a8fBQzbz9M3WS/iFT4BNf/nmw9mEzrnSaC0g== +tailwindcss@^3.3.5: + version "3.3.5" + resolved "https://registry.npmmirror.com/tailwindcss/-/tailwindcss-3.3.5.tgz#22a59e2fbe0ecb6660809d9cc5f3976b077be3b8" + integrity sha512-5SEZU4J7pxZgSkv7FP1zY8i2TIAOooNZ1e/OGtxIEv6GltpoiXUqWvLy89+a10qYTB1N5Ifkuw9lqQkN9sscvA== dependencies: + "@alloc/quick-lru" "^5.2.0" arg "^5.0.2" chokidar "^3.5.3" - color-name "^1.1.4" - detective "^5.2.1" didyoumean "^1.2.2" dlv "^1.1.3" - fast-glob "^3.2.11" + fast-glob "^3.3.0" glob-parent "^6.0.2" is-glob "^4.0.3" - lilconfig "^2.0.6" + jiti "^1.19.1" + lilconfig "^2.1.0" + micromatch "^4.0.5" normalize-path "^3.0.0" object-hash "^3.0.0" picocolors "^1.0.0" - postcss "^8.4.14" - postcss-import "^14.1.0" - postcss-js "^4.0.0" - postcss-load-config "^3.1.4" - postcss-nested "5.0.6" - postcss-selector-parser "^6.0.10" - postcss-value-parser "^4.2.0" - quick-lru "^5.1.1" - resolve "^1.22.1" + postcss "^8.4.23" + postcss-import "^15.1.0" + postcss-js "^4.0.1" + postcss-load-config "^4.0.1" + postcss-nested "^6.0.1" + postcss-selector-parser "^6.0.11" + resolve "^1.22.2" + sucrase "^3.32.0" -tapable@^2.0.0, tapable@^2.1.1, tapable@^2.2.0: - version "2.2.1" - resolved "https://registry.yarnpkg.com/tapable/-/tapable-2.2.1.tgz#1967a73ef4060a82f12ab96af86d52fdb76eeca0" - integrity sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ== +tar-fs@^2.0.0: + version "2.1.1" + resolved "https://registry.npmmirror.com/tar-fs/-/tar-fs-2.1.1.tgz#489a15ab85f1f0befabb370b7de4f9eb5cbe8784" + integrity sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng== + dependencies: + chownr "^1.1.1" + mkdirp-classic "^0.5.2" + pump "^3.0.0" + tar-stream "^2.1.4" -tar@^6.0.5, tar@^6.1.12, tar@^6.1.2: - version "6.1.14" - resolved "https://registry.yarnpkg.com/tar/-/tar-6.1.14.tgz#e87926bec1cfe7c9e783a77a79f3e81c1cfa3b66" - integrity sha512-piERznXu0U7/pW7cdSn7hjqySIVTYT6F76icmFk7ptU7dDYlXTm5r9A6K04R2vU3olYgoKeo1Cg3eeu5nhftAw== +tar-stream@^2.1.4: + version "2.2.0" + resolved "https://registry.npmmirror.com/tar-stream/-/tar-stream-2.2.0.tgz#acad84c284136b060dc3faa64474aa9aebd77287" + integrity sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ== + dependencies: + bl "^4.0.3" + end-of-stream "^1.4.1" + fs-constants "^1.0.0" + inherits "^2.0.3" + readable-stream "^3.1.1" + +tar@^6.1.12: + version "6.2.0" + resolved "https://registry.npmmirror.com/tar/-/tar-6.2.0.tgz#b14ce49a79cb1cd23bc9b016302dea5474493f73" + integrity sha512-/Wo7DcT0u5HUV486xg675HtjNd3BXZ6xDbzsCUZPt5iw8bTQ63bP0Raut3mvro9u+CUyq7YQd8Cx55fsZXxqLQ== dependencies: chownr "^2.0.0" fs-minipass "^2.0.0" @@ -8237,412 +3269,171 @@ tar@^6.0.5, tar@^6.1.12, tar@^6.1.2: mkdirp "^1.0.3" yallist "^4.0.0" -tar@^6.1.11: - version "6.1.11" - resolved "https://registry.yarnpkg.com/tar/-/tar-6.1.11.tgz#6760a38f003afa1b2ffd0ffe9e9abbd0eab3d621" - integrity sha512-an/KZQzQUkZCkuoAA64hM92X0Urb6VpRhAFllDzz44U2mcD5scmT3zBc4VgVpkugF580+DQn8eAFSyoQt0tznA== - dependencies: - chownr "^2.0.0" - fs-minipass "^2.0.0" - minipass "^3.0.0" - minizlib "^2.1.1" - mkdirp "^1.0.3" - yallist "^4.0.0" - temp-file@^3.4.0: version "3.4.0" - resolved "https://registry.yarnpkg.com/temp-file/-/temp-file-3.4.0.tgz#766ea28911c683996c248ef1a20eea04d51652c7" + resolved "https://registry.npmmirror.com/temp-file/-/temp-file-3.4.0.tgz#766ea28911c683996c248ef1a20eea04d51652c7" integrity sha512-C5tjlC/HCtVUOi3KWVokd4vHVViOmGjtLwIh4MuzPo/nMYTV/p1urt3RnMz2IWXDdKEGJH3k5+KPxtqRsUYGtg== dependencies: async-exit-hook "^2.0.1" fs-extra "^10.0.0" -terser-webpack-plugin@^5.1.1, terser-webpack-plugin@^5.1.3, terser-webpack-plugin@^5.3.0: - version "5.3.6" - resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.6.tgz#5590aec31aa3c6f771ce1b1acca60639eab3195c" - integrity sha512-kfLFk+PoLUQIbLmB1+PZDMRSZS99Mp+/MHqDNmMA6tOItzRt+Npe3E+fsMs5mfcM0wCtrrdU387UnV+vnSffXQ== - dependencies: - "@jridgewell/trace-mapping" "^0.3.14" - jest-worker "^27.4.5" - schema-utils "^3.1.1" - serialize-javascript "^6.0.0" - terser "^5.14.1" - -terser-webpack-plugin@^5.3.8: - version "5.3.8" - resolved "https://registry.yarnpkg.com/terser-webpack-plugin/-/terser-webpack-plugin-5.3.8.tgz#415e03d2508f7de63d59eca85c5d102838f06610" - integrity sha512-WiHL3ElchZMsK27P8uIUh4604IgJyAW47LVXGbEoB21DbQcZ+OuMpGjVYnEUaqcWM6dO8uS2qUbA7LSCWqvsbg== - dependencies: - "@jridgewell/trace-mapping" "^0.3.17" - jest-worker "^27.4.5" - schema-utils "^3.1.1" - serialize-javascript "^6.0.1" - terser "^5.16.8" - -terser@^5.10.0, terser@^5.14.1: - version "5.15.0" - resolved "https://registry.yarnpkg.com/terser/-/terser-5.15.0.tgz#e16967894eeba6e1091509ec83f0c60e179f2425" - integrity sha512-L1BJiXVmheAQQy+as0oF3Pwtlo4s3Wi1X2zNZ2NxOB4wx9bdS9Vk67XQENLFdLYGCK/Z2di53mTj/hBafR+dTA== - dependencies: - "@jridgewell/source-map" "^0.3.2" - acorn "^8.5.0" - commander "^2.20.0" - source-map-support "~0.5.20" - -terser@^5.16.8: - version "5.17.2" - resolved "https://registry.yarnpkg.com/terser/-/terser-5.17.2.tgz#06c9818ae998066234b985abeb57bb7bff29d449" - integrity sha512-1D1aGbOF1Mnayq5PvfMc0amAR1y5Z1nrZaGCvI5xsdEfZEVte8okonk02OiaK5fw5hG1GWuuVsakOnpZW8y25A== - dependencies: - "@jridgewell/source-map" "^0.3.2" - acorn "^8.5.0" - commander "^2.20.0" - source-map-support "~0.5.20" - thenify-all@^1.0.0: version "1.6.0" - resolved "https://registry.yarnpkg.com/thenify-all/-/thenify-all-1.6.0.tgz#1a1918d402d8fc3f98fbf234db0bcc8cc10e9726" + resolved "https://registry.npmmirror.com/thenify-all/-/thenify-all-1.6.0.tgz#1a1918d402d8fc3f98fbf234db0bcc8cc10e9726" integrity sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA== dependencies: thenify ">= 3.1.0 < 4" "thenify@>= 3.1.0 < 4": version "3.3.1" - resolved "https://registry.yarnpkg.com/thenify/-/thenify-3.3.1.tgz#8932e686a4066038a016dd9e2ca46add9838a95f" + resolved "https://registry.npmmirror.com/thenify/-/thenify-3.3.1.tgz#8932e686a4066038a016dd9e2ca46add9838a95f" integrity sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw== dependencies: any-promise "^1.0.0" -thread-loader@^3.0.0: - version "3.0.4" - resolved "https://registry.yarnpkg.com/thread-loader/-/thread-loader-3.0.4.tgz#c392e4c0241fbc80430eb680e4886819b504a31b" - integrity sha512-ByaL2TPb+m6yArpqQUZvP+5S1mZtXsEP7nWKKlAUTm7fCml8kB5s1uI3+eHRP2bk5mVYfRSBI7FFf+tWEyLZwA== - dependencies: - json-parse-better-errors "^1.0.2" - loader-runner "^4.1.0" - loader-utils "^2.0.0" - neo-async "^2.6.2" - schema-utils "^3.0.0" - -thunky@^1.0.2: - version "1.1.0" - resolved "https://registry.yarnpkg.com/thunky/-/thunky-1.1.0.tgz#5abaf714a9405db0504732bbccd2cedd9ef9537d" - integrity sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA== - -timm@^1.6.1: - version "1.7.1" - resolved "https://registry.yarnpkg.com/timm/-/timm-1.7.1.tgz#96bab60c7d45b5a10a8a4d0f0117c6b7e5aff76f" - integrity sha512-IjZc9KIotudix8bMaBW6QvMuq64BrJWFs1+4V0lXwWGQZwH+LnX87doAYhem4caOEusRP9/g6jVDQmZ8XOk1nw== - -tinycolor2@^1.6.0: - version "1.6.0" - resolved "https://registry.yarnpkg.com/tinycolor2/-/tinycolor2-1.6.0.tgz#f98007460169b0263b97072c5ae92484ce02d09e" - integrity sha512-XPaBkWQJdsf3pLKJV9p4qN/S+fm2Oj8AIPo1BTUhg5oxkvm9+SVEGFdhyOz7tTdUTfvxMiAs4sp6/eZO2Ew+pw== - tmp-promise@^3.0.2: version "3.0.3" - resolved "https://registry.yarnpkg.com/tmp-promise/-/tmp-promise-3.0.3.tgz#60a1a1cc98c988674fcbfd23b6e3367bdeac4ce7" + resolved "https://registry.npmmirror.com/tmp-promise/-/tmp-promise-3.0.3.tgz#60a1a1cc98c988674fcbfd23b6e3367bdeac4ce7" integrity sha512-RwM7MoPojPxsOBYnyd2hy0bxtIlVrihNs9pj5SUvY8Zz1sQcQG2tG1hSr8PDxfgEB8RNKDhqbIlroIarSNDNsQ== dependencies: tmp "^0.2.0" tmp@^0.2.0: version "0.2.1" - resolved "https://registry.yarnpkg.com/tmp/-/tmp-0.2.1.tgz#8457fc3037dcf4719c251367a1af6500ee1ccf14" + resolved "https://registry.npmmirror.com/tmp/-/tmp-0.2.1.tgz#8457fc3037dcf4719c251367a1af6500ee1ccf14" integrity sha512-76SUhtfqR2Ijn+xllcI5P1oyannHNHByD80W1q447gU3mp9G9PSpGdWmjUOHRDPiHYacIk66W7ubDTuPF3BEtQ== dependencies: rimraf "^3.0.0" -to-fast-properties@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" - integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== - -to-readable-stream@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/to-readable-stream/-/to-readable-stream-1.0.0.tgz#ce0aa0c2f3df6adf852efb404a783e77c0475771" - integrity sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q== - to-regex-range@^5.0.1: version "5.0.1" - resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" + resolved "https://registry.npmmirror.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== dependencies: is-number "^7.0.0" -toidentifier@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" - integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== - -token-types@^4.1.1: - version "4.2.1" - resolved "https://registry.yarnpkg.com/token-types/-/token-types-4.2.1.tgz#0f897f03665846982806e138977dbe72d44df753" - integrity sha512-6udB24Q737UD/SDsKAHI9FCRP7Bqc9D/MQUV02ORQg5iskjtLJlZJNdN4kKtcdtwCeWIwIHDGaUsTsCCAa8sFQ== - dependencies: - "@tokenizer/token" "^0.3.0" - ieee754 "^1.2.1" - -totalist@^1.0.0: - version "1.1.0" - resolved "https://registry.yarnpkg.com/totalist/-/totalist-1.1.0.tgz#a4d65a3e546517701e3e5c37a47a70ac97fe56df" - integrity sha512-gduQwd1rOdDMGxFG1gEvhV88Oirdo2p+KjoYFU7k2g+i7n6AFFbDQ5kMPUsW0pNbfQsB/cwXvT1i4Bue0s9g5g== - tough-cookie@~2.5.0: version "2.5.0" - resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.5.0.tgz#cd9fb2a0aa1d5a12b473bd9fb96fa3dcff65ade2" + resolved "https://registry.npmmirror.com/tough-cookie/-/tough-cookie-2.5.0.tgz#cd9fb2a0aa1d5a12b473bd9fb96fa3dcff65ade2" integrity sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g== dependencies: psl "^1.1.28" punycode "^2.1.1" -tr46@~0.0.3: - version "0.0.3" - resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" - integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== +treemate@^0.3.11: + version "0.3.11" + resolved "https://registry.npmmirror.com/treemate/-/treemate-0.3.11.tgz#7d52f8f69ab9ce326f8d139e0a3d1ffb25e48222" + integrity sha512-M8RGFoKtZ8dF+iwJfAJTOH/SM4KluKOKRJpjCMhI8bG3qB74zrFoArKZ62ll0Fr3mqkMJiQOmWYkdYgDeITYQg== truncate-utf8-bytes@^1.0.0: version "1.0.2" - resolved "https://registry.yarnpkg.com/truncate-utf8-bytes/-/truncate-utf8-bytes-1.0.2.tgz#405923909592d56f78a5818434b0b78489ca5f2b" + resolved "https://registry.npmmirror.com/truncate-utf8-bytes/-/truncate-utf8-bytes-1.0.2.tgz#405923909592d56f78a5818434b0b78489ca5f2b" integrity sha512-95Pu1QXQvruGEhv62XCMO3Mm90GscOCClvrIUwCM0PYOXK3kaF3l3sIHxx71ThJfcbM2O5Au6SO3AWCSEfW4mQ== dependencies: utf8-byte-length "^1.0.1" -tslib@^2.0.3, tslib@^2.1.0: - version "2.4.0" - resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.4.0.tgz#7cecaa7f073ce680a05847aa77be941098f36dc3" - integrity sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ== +ts-interface-checker@^0.1.9: + version "0.1.13" + resolved "https://registry.npmmirror.com/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz#784fd3d679722bc103b1b4b8030bcddb5db2a699" + integrity sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA== + +tslib@^2.3.0: + version "2.6.2" + resolved "https://registry.npmmirror.com/tslib/-/tslib-2.6.2.tgz#703ac29425e7b37cd6fd456e92404d46d1f3e4ae" + integrity sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q== tunnel-agent@^0.6.0: version "0.6.0" - resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" + resolved "https://registry.npmmirror.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" integrity sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w== dependencies: safe-buffer "^5.0.1" tweetnacl@^0.14.3, tweetnacl@~0.14.0: version "0.14.5" - resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" + resolved "https://registry.npmmirror.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64" integrity sha512-KXXFFdAbFXY4geFIwoyNK+f5Z1b7swfXABfL7HXCmoIWMKU3dmS26672A4EeQtDzLKy7SXmfBu51JolvEKwtGA== type-fest@^0.13.1: version "0.13.1" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.13.1.tgz#0172cb5bce80b0bd542ea348db50c7e21834d934" + resolved "https://registry.npmmirror.com/type-fest/-/type-fest-0.13.1.tgz#0172cb5bce80b0bd542ea348db50c7e21834d934" integrity sha512-34R7HTnG0XIJcBSn5XhDd7nNFPRcXYRZrBB2O2jdKqYODldSzBAqzsWoZYYvduky73toYS/ESqxPvkDf/F0XMg== -type-fest@^0.20.2: - version "0.20.2" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" - integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== - -type-fest@^0.6.0: - version "0.6.0" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.6.0.tgz#8d2a2370d3df886eb5c90ada1c5bf6188acf838b" - integrity sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg== - -type-fest@^0.8.1: - version "0.8.1" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.8.1.tgz#09e249ebde851d3b1e48d27c105444667f17b83d" - integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA== - type-fest@^2.17.0: version "2.19.0" - resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-2.19.0.tgz#88068015bb33036a598b952e55e9311a60fd3a9b" + resolved "https://registry.npmmirror.com/type-fest/-/type-fest-2.19.0.tgz#88068015bb33036a598b952e55e9311a60fd3a9b" integrity sha512-RAH822pAdBgcNMAfWnCBU3CFZcfZ/i1eZjwFU/dsLKumyuuP3niueg2UAukXYF0E2AAoc82ZSSf9J0WQBinzHA== -type-is@~1.6.18: - version "1.6.18" - resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" - integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== - dependencies: - media-typer "0.3.0" - mime-types "~2.1.24" - -typedarray-to-buffer@^3.1.5: - version "3.1.5" - resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" - integrity sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q== - dependencies: - is-typedarray "^1.0.0" - typescript@^4.0.2: version "4.9.5" - resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" + resolved "https://registry.npmmirror.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" integrity sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g== -unicode-canonical-property-names-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz#301acdc525631670d39f6146e0e77ff6bbdebddc" - integrity sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ== +typescript@^5.2.2: + version "5.2.2" + resolved "https://registry.npmmirror.com/typescript/-/typescript-5.2.2.tgz#5ebb5e5a5b75f085f22bc3f8460fba308310fa78" + integrity sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w== -unicode-match-property-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz#54fd16e0ecb167cf04cf1f756bdcc92eba7976c3" - integrity sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q== - dependencies: - unicode-canonical-property-names-ecmascript "^2.0.0" - unicode-property-aliases-ecmascript "^2.0.0" - -unicode-match-property-value-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.0.0.tgz#1a01aa57247c14c568b89775a54938788189a714" - integrity sha512-7Yhkc0Ye+t4PNYzOGKedDhXbYIBe1XEQYQxOPyhcXNMJ0WCABqqj6ckydd6pWRZTHV4GuCPKdBAUiMc60tsKVw== - -unicode-property-aliases-ecmascript@^2.0.0: - version "2.1.0" - resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz#43d41e3be698bd493ef911077c9b131f827e8ccd" - integrity sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w== - -unique-filename@^2.0.0: - version "2.0.1" - resolved "https://registry.yarnpkg.com/unique-filename/-/unique-filename-2.0.1.tgz#e785f8675a9a7589e0ac77e0b5c34d2eaeac6da2" - integrity sha512-ODWHtkkdx3IAR+veKxFV+VBkUMcN+FaqzUUd7IZzt+0zhDZFPFxhlqwPF3YQvMHx1TD0tdgYl+kuPnJ8E6ql7A== - dependencies: - unique-slug "^3.0.0" - -unique-slug@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/unique-slug/-/unique-slug-3.0.0.tgz#6d347cf57c8a7a7a6044aabd0e2d74e4d76dc7c9" - integrity sha512-8EyMynh679x/0gqE9fT9oilG+qEt+ibFyqjuVTsZn1+CMxH+XLlpvr2UZx4nVcCwTpx81nICr2JQFkM+HPLq4w== - dependencies: - imurmurhash "^0.1.4" - -unique-string@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-2.0.0.tgz#39c6451f81afb2749de2b233e3f7c5e8843bd89d" - integrity sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg== - dependencies: - crypto-random-string "^2.0.0" +undici-types@~5.26.4: + version "5.26.5" + resolved "https://registry.npmmirror.com/undici-types/-/undici-types-5.26.5.tgz#bcd539893d00b56e964fd2657a4866b221a65617" + integrity sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA== universalify@^0.1.0: version "0.1.2" - resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" + resolved "https://registry.npmmirror.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66" integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== universalify@^2.0.0: version "2.0.0" - resolved "https://registry.yarnpkg.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" + resolved "https://registry.npmmirror.com/universalify/-/universalify-2.0.0.tgz#75a4984efedc4b08975c5aeb73f530d02df25717" integrity sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ== -unpipe@1.0.0, unpipe@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" - integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== - -unzip-crx-3@^0.2.0: - version "0.2.0" - resolved "https://registry.npmmirror.com/unzip-crx-3/-/unzip-crx-3-0.2.0.tgz#d5324147b104a8aed9ae8639c95521f6f7cda292" - integrity sha512-0+JiUq/z7faJ6oifVB5nSwt589v1KCduqIJupNVDoWSXZtWDmjDGO3RAEOvwJ07w90aoXoP4enKsR7ecMrJtWQ== - dependencies: - jszip "^3.1.0" - mkdirp "^0.5.1" - yaku "^0.16.6" - -update-browserslist-db@^1.0.9: - version "1.0.9" - resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.0.9.tgz#2924d3927367a38d5c555413a7ce138fc95fcb18" - integrity sha512-/xsqn21EGVdXI3EXSum1Yckj3ZVZugqyOZQ/CxYPBD/R+ko9NSUScf8tFF4dOKY+2pvSSJA/S+5B8s4Zr4kyvg== +update-browserslist-db@^1.0.13: + version "1.0.13" + resolved "https://registry.npmmirror.com/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz#3c5e4f5c083661bd38ef64b6328c26ed6c8248c4" + integrity sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg== dependencies: escalade "^3.1.1" picocolors "^1.0.0" -update-notifier@^5.1.0: - version "5.1.0" - resolved "https://registry.yarnpkg.com/update-notifier/-/update-notifier-5.1.0.tgz#4ab0d7c7f36a231dd7316cf7729313f0214d9ad9" - integrity sha512-ItnICHbeMh9GqUy31hFPrD1kcuZ3rpxDZbf4KUDavXwS0bW5m7SLbDQpGX3UYr072cbrF5hFUs3r5tUsPwjfHw== - dependencies: - boxen "^5.0.0" - chalk "^4.1.0" - configstore "^5.0.1" - has-yarn "^2.1.0" - import-lazy "^2.1.0" - is-ci "^2.0.0" - is-installed-globally "^0.4.0" - is-npm "^5.0.0" - is-yarn-global "^0.3.0" - latest-version "^5.1.0" - pupa "^2.1.1" - semver "^7.3.4" - semver-diff "^3.1.1" - xdg-basedir "^4.0.0" - uri-js@^4.2.2: version "4.4.1" - resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" + resolved "https://registry.npmmirror.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== dependencies: punycode "^2.1.0" urijs@^1.19.11: version "1.19.11" - resolved "https://registry.yarnpkg.com/urijs/-/urijs-1.19.11.tgz#204b0d6b605ae80bea54bea39280cdb7c9f923cc" + resolved "https://registry.npmmirror.com/urijs/-/urijs-1.19.11.tgz#204b0d6b605ae80bea54bea39280cdb7c9f923cc" integrity sha512-HXgFDgDommxn5/bIv0cnQZsPhHDA90NPHD6+c/v21U5+Sx5hoP8+dP9IZXBU1gIfvdRfhG8cel9QNPeionfcCQ== -url-parse-lax@^3.0.0: - version "3.0.0" - resolved "https://registry.yarnpkg.com/url-parse-lax/-/url-parse-lax-3.0.0.tgz#16b5cafc07dbe3676c1b1999177823d6503acb0c" - integrity sha512-NjFKA0DidqPa5ciFcSrXnAltTtzz84ogy+NebPvfEgAck0+TNg4UJ4IN+fB7zRZfbgUf0syOo9MDxFkDSMuFaQ== - dependencies: - prepend-http "^2.0.0" - utf8-byte-length@^1.0.1: version "1.0.4" - resolved "https://registry.yarnpkg.com/utf8-byte-length/-/utf8-byte-length-1.0.4.tgz#f45f150c4c66eee968186505ab93fcbb8ad6bf61" + resolved "https://registry.npmmirror.com/utf8-byte-length/-/utf8-byte-length-1.0.4.tgz#f45f150c4c66eee968186505ab93fcbb8ad6bf61" integrity sha512-4+wkEYLBbWxqTahEsWrhxepcoVOJ+1z5PGIjPZxRkytcdSUaNjIjBM7Xn8E+pdSuV7SzvWovBFA54FO0JSoqhA== -utif2@^4.0.1: - version "4.0.1" - resolved "https://registry.yarnpkg.com/utif2/-/utif2-4.0.1.tgz#562433ef58d76b16d85638f052b2d8486122062c" - integrity sha512-KMaD76dbzK1VjbwsckHJiqDjhP3pbpwyV+FdqkY6XFQenc2o/HS6pjPSYdu4+NQMHf2NLTW+nVP/eFP1CvOYQQ== - dependencies: - pako "^1.0.11" - -util-deprecate@^1.0.1, util-deprecate@^1.0.2, util-deprecate@~1.0.1: +util-deprecate@^1.0.1, util-deprecate@^1.0.2: version "1.0.2" - resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" + resolved "https://registry.npmmirror.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== -utila@~0.4: - version "0.4.0" - resolved "https://registry.yarnpkg.com/utila/-/utila-0.4.0.tgz#8a16a05d445657a3aea5eecc5b12a4fa5379772c" - integrity sha512-Z0DbgELS9/L/75wZbro8xAnT50pBVFQZ+hUEueGDU5FN51YSCYM+jdxsfCiHjwNP/4LCDD0i/graKpeBnOXKRA== - -utils-merge@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" - integrity sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA== - uuid@^3.3.2: version "3.4.0" - resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.4.0.tgz#b23e4358afa8a202fe7a100af1f5f883f02007ee" + resolved "https://registry.npmmirror.com/uuid/-/uuid-3.4.0.tgz#b23e4358afa8a202fe7a100af1f5f883f02007ee" integrity sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A== -uuid@^8.3.2: - version "8.3.2" - resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" - integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== - -uuid@^9.0.0: - version "9.0.0" - resolved "https://registry.yarnpkg.com/uuid/-/uuid-9.0.0.tgz#592f550650024a38ceb0c562f2f6aa435761efb5" - integrity sha512-MXcSTerfPa4uqyzStbRoTgt5XIe3x5+42+q1sDuy3R5MDk66URdLMOZe5aPX/SQd+kuYAh0FdP/pO28IkQyTeg== - -validate-npm-package-license@^3.0.1: - version "3.0.4" - resolved "https://registry.yarnpkg.com/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz#fc91f6b9c7ba15c857f4cb2c5defeec39d4f410a" - integrity sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew== +vdirs@^0.1.4, vdirs@^0.1.8: + version "0.1.8" + resolved "https://registry.npmmirror.com/vdirs/-/vdirs-0.1.8.tgz#a103bc43baca738f8dea912a7e9737154a19dbc2" + integrity sha512-H9V1zGRLQZg9b+GdMk8MXDN2Lva0zx72MPahDKc30v+DtwKjfyOSXWRIX4t2mhDubM1H09gPhWeth/BJWPHGUw== dependencies: - spdx-correct "^3.0.0" - spdx-expression-parse "^3.0.0" - -vary@~1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" - integrity sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg== + evtd "^0.2.2" verror@1.10.0: version "1.10.0" - resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400" + resolved "https://registry.npmmirror.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400" integrity sha512-ZZKSmDAEFOijERBLkmYfJ+vmk3w+7hOLYDNkRCuRuMJGEmqYNCNLyBBFwWKVMhfwaEF3WOd0Zlw86U/WC/+nYw== dependencies: assert-plus "^1.0.0" @@ -8651,300 +3442,99 @@ verror@1.10.0: verror@^1.10.0: version "1.10.1" - resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.1.tgz#4bf09eeccf4563b109ed4b3d458380c972b0cdeb" + resolved "https://registry.npmmirror.com/verror/-/verror-1.10.1.tgz#4bf09eeccf4563b109ed4b3d458380c972b0cdeb" integrity sha512-veufcmxri4e3XSrT0xwfUR7kguIkaxBeosDg00yDWhk49wdwkSUrvvsm7nc75e1PUyvIeZj6nS8VQRYz2/S4Xg== dependencies: assert-plus "^1.0.0" core-util-is "1.0.2" extsprintf "^1.2.0" -vue-cli-plugin-electron-builder@^3.0.0-alpha.4: - version "3.0.0-alpha.4" - resolved "https://registry.npmmirror.com/vue-cli-plugin-electron-builder/-/vue-cli-plugin-electron-builder-3.0.0-alpha.4.tgz#3a3aae23c593bf8a8ebaf681e3f4e614b83e6aeb" - integrity sha512-YHt0w3onxE6F5OJJTkArm2gIpJi0QW8QEp7uMV+vg+Ze8C3To/Qt8K5eIPkVs72uxqjiBhmE2Xapl3rHz9kEJg== +vite-plugin-electron@^0.14.1: + version "0.14.1" + resolved "https://registry.npmmirror.com/vite-plugin-electron/-/vite-plugin-electron-0.14.1.tgz#faad1e26d853ea7960b812272c19521c7f180482" + integrity sha512-QGQ2nJ4wjMf1FaDSkdoC/UskQGiYGcAToATJqJXvqrL4Jmt0CFaZqoDjh1xLicUWEo/X7urHYjhKTqwEeP7F7g== + +vite@^4.4.11: + version "4.5.0" + resolved "https://registry.npmmirror.com/vite/-/vite-4.5.0.tgz#ec406295b4167ac3bc23e26f9c8ff559287cff26" + integrity sha512-ulr8rNLA6rkyFAlVWw2q5YJ91v098AFQ2R0PRFwPzREXOUJQPtFUG0t+/ZikhaOCDqFoDhN6/v8Sq0o4araFAw== dependencies: - "@soda/friendly-errors-webpack-plugin" "^1.8.1" - "@vue/cli-shared-utils" "^5.0.0-rc.1" - chokidar "^3.0.2" - electron-builder "^22.2.0" - execa "^5.0.0" - fs-extra "^10.0.0" - lodash.merge "^4.6.1" - playwright-core "^1.17.1" - shebang-loader "^0.0.1" - terser-webpack-plugin "^5.3.0" - webpack "^5.65.0" - webpack-chain "^6.0.0" - webpack-merge "^5.8.0" - yargs "^16.2.0" + esbuild "^0.18.10" + postcss "^8.4.27" + rollup "^3.27.1" + optionalDependencies: + fsevents "~2.3.2" -vue-hot-reload-api@^2.3.0: - version "2.3.4" - resolved "https://registry.yarnpkg.com/vue-hot-reload-api/-/vue-hot-reload-api-2.3.4.tgz#532955cc1eb208a3d990b3a9f9a70574657e08f2" - integrity sha512-BXq3jwIagosjgNVae6tkHzzIk6a8MHFtzAdwhnV5VlvPTFxDCvIttgSiHWjdGoTJvXtmRu5HacExfdarRcFhog== - -vue-loader@^17.0.0: - version "17.0.0" - resolved "https://registry.yarnpkg.com/vue-loader/-/vue-loader-17.0.0.tgz#2eaa80aab125b19f00faa794b5bd867b17f85acb" - integrity sha512-OWSXjrzIvbF2LtOUmxT3HYgwwubbfFelN8PAP9R9dwpIkj48TVioHhWWSx7W7fk+iF5cgg3CBJRxwTdtLU4Ecg== +vooks@^0.2.12, vooks@^0.2.4: + version "0.2.12" + resolved "https://registry.npmmirror.com/vooks/-/vooks-0.2.12.tgz#2b6e23330b77bac81c7f7a344c4ca3e9f4f6c373" + integrity sha512-iox0I3RZzxtKlcgYaStQYKEzWWGAduMmq+jS7OrNdQo1FgGfPMubGL3uGHOU9n97NIvfFDBGnpSvkWyb/NSn/Q== dependencies: - chalk "^4.1.0" - hash-sum "^2.0.0" - loader-utils "^2.0.0" + evtd "^0.2.2" -vue-router@^4.2.0: - version "4.2.0" - resolved "https://registry.yarnpkg.com/vue-router/-/vue-router-4.2.0.tgz#558f31978a21ce3accf5122ffdf2cec34a5d2517" - integrity sha512-c+usESa6ZoWsm4PPdzRSyenp5A4dsUtnDJnrI03fY1IpIihA9TK3x5ffgkFDpjhLJZewsXoKURapNLFdZjuqTg== +vue-demi@>=0.14.5: + version "0.14.6" + resolved "https://registry.npmmirror.com/vue-demi/-/vue-demi-0.14.6.tgz#dc706582851dc1cdc17a0054f4fec2eb6df74c92" + integrity sha512-8QA7wrYSHKaYgUxDA5ZC24w+eHm3sYCbp0EzcDwKqN3p6HqtTCGR/GVsPyZW92unff4UlcSh++lmqDWN3ZIq4w== + +vue-router@^4.2.5: + version "4.2.5" + resolved "https://registry.npmmirror.com/vue-router/-/vue-router-4.2.5.tgz#b9e3e08f1bd9ea363fdd173032620bc50cf0e98a" + integrity sha512-DIUpKcyg4+PTQKfFPX88UWhlagBEBEfJ5A8XDXRJLUnZOvcpMF8o/dnL90vpVkGaPbjvXazV/rC1qBKrZlFugw== dependencies: "@vue/devtools-api" "^6.5.0" -vue-style-loader@^4.1.0, vue-style-loader@^4.1.3: - version "4.1.3" - resolved "https://registry.yarnpkg.com/vue-style-loader/-/vue-style-loader-4.1.3.tgz#6d55863a51fa757ab24e89d9371465072aa7bc35" - integrity sha512-sFuh0xfbtpRlKfm39ss/ikqs9AbKCoXZBpHeVZ8Tx650o0k0q/YCM7FRvigtxpACezfq6af+a7JeqVTWvncqDg== +vue-template-compiler@^2.7.14: + version "2.7.15" + resolved "https://registry.npmmirror.com/vue-template-compiler/-/vue-template-compiler-2.7.15.tgz#ec88ba8ceafe0f17a528b89c57e01e02da92b0de" + integrity sha512-yQxjxMptBL7UAog00O8sANud99C6wJF+7kgbcwqkvA38vCGF7HWE66w0ZFnS/kX5gSoJr/PQ4/oS3Ne2pW37Og== dependencies: - hash-sum "^1.0.2" - loader-utils "^1.0.2" + de-indent "^1.0.2" + he "^1.2.0" -vue-template-es2015-compiler@^1.9.0: - version "1.9.1" - resolved "https://registry.yarnpkg.com/vue-template-es2015-compiler/-/vue-template-es2015-compiler-1.9.1.tgz#1ee3bc9a16ecbf5118be334bb15f9c46f82f5825" - integrity sha512-4gDntzrifFnCEvyoO8PqyJDmguXgVPxKiIxrBKjIowvL9l+N66196+72XVYR8BBf1Uv1Fgt3bGevJ+sEmxfZzw== - -vue@^3.3.4: - version "3.3.4" - resolved "https://registry.yarnpkg.com/vue/-/vue-3.3.4.tgz#8ed945d3873667df1d0fcf3b2463ada028f88bd6" - integrity sha512-VTyEYn3yvIeY1Py0WaYGZsXnz3y5UnGi62GjVEqvEGPl6nxbOrCXbVOTQWBEJUqAyTUk2uJ5JLVnYJ6ZzGbrSw== +vue-tsc@^1.8.22: + version "1.8.22" + resolved "https://registry.npmmirror.com/vue-tsc/-/vue-tsc-1.8.22.tgz#421e73c38b50802a6716ca32ed87b5970c867323" + integrity sha512-j9P4kHtW6eEE08aS5McFZE/ivmipXy0JzrnTgbomfABMaVKx37kNBw//irL3+LlE3kOo63XpnRigyPC3w7+z+A== dependencies: - "@vue/compiler-dom" "3.3.4" - "@vue/compiler-sfc" "3.3.4" - "@vue/runtime-dom" "3.3.4" - "@vue/server-renderer" "3.3.4" - "@vue/shared" "3.3.4" + "@volar/typescript" "~1.10.5" + "@vue/language-core" "1.8.22" + semver "^7.5.4" -vuex@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/vuex/-/vuex-4.1.0.tgz#aa1b3ea5c7385812b074c86faeeec2217872e36c" - integrity sha512-hmV6UerDrPcgbSy9ORAtNXDr9M4wlNP4pEFKye4ujJF8oqgFFuxDCdOLS3eNoRTtq5O3hoBDh9Doj1bQMYHRbQ== +vue@^3.3.7: + version "3.3.7" + resolved "https://registry.npmmirror.com/vue/-/vue-3.3.7.tgz#972a218682443a3819d121261b2bff914417f4f0" + integrity sha512-YEMDia1ZTv1TeBbnu6VybatmSteGOS3A3YgfINOfraCbf85wdKHzscD6HSS/vB4GAtI7sa1XPX7HcQaJ1l24zA== dependencies: - "@vue/devtools-api" "^6.0.0-beta.11" + "@vue/compiler-dom" "3.3.7" + "@vue/compiler-sfc" "3.3.7" + "@vue/runtime-dom" "3.3.7" + "@vue/server-renderer" "3.3.7" + "@vue/shared" "3.3.7" -watchpack@^2.4.0: - version "2.4.0" - resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-2.4.0.tgz#fa33032374962c78113f93c7f2fb4c54c9862a5d" - integrity sha512-Lcvm7MGST/4fup+ifyKi2hjyIAwcdI4HRgtvTpIUxBRhB+RFtUh8XtDOxUfctVCnhVi+QQj49i91OyvzkJl6cg== +vueuc@^0.4.51: + version "0.4.51" + resolved "https://registry.npmmirror.com/vueuc/-/vueuc-0.4.51.tgz#35cd5364db4b71fc791a9823748711b91d910d49" + integrity sha512-pLiMChM4f+W8czlIClGvGBYo656lc2Y0/mXFSCydcSmnCR1izlKPGMgiYBGjbY9FDkFG8a2HEVz7t0DNzBWbDw== dependencies: - glob-to-regexp "^0.4.1" - graceful-fs "^4.1.2" + "@css-render/vue3-ssr" "^0.15.10" + "@juggle/resize-observer" "^3.3.1" + css-render "^0.15.10" + evtd "^0.2.4" + seemly "^0.3.6" + vdirs "^0.1.4" + vooks "^0.2.4" -wbuf@^1.1.0, wbuf@^1.7.3: - version "1.7.3" - resolved "https://registry.yarnpkg.com/wbuf/-/wbuf-1.7.3.tgz#c1d8d149316d3ea852848895cb6a0bfe887b87df" - integrity sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA== - dependencies: - minimalistic-assert "^1.0.0" - -wcwidth@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/wcwidth/-/wcwidth-1.0.1.tgz#f0b0dcf915bc5ff1528afadb2c0e17b532da2fe8" - integrity sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg== - dependencies: - defaults "^1.0.3" - -webidl-conversions@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" - integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== - -webpack-bundle-analyzer@^4.4.0: - version "4.6.1" - resolved "https://registry.yarnpkg.com/webpack-bundle-analyzer/-/webpack-bundle-analyzer-4.6.1.tgz#bee2ee05f4ba4ed430e4831a319126bb4ed9f5a6" - integrity sha512-oKz9Oz9j3rUciLNfpGFjOb49/jEpXNmWdVH8Ls//zNcnLlQdTGXQQMsBbb/gR7Zl8WNLxVCq+0Hqbx3zv6twBw== - dependencies: - acorn "^8.0.4" - acorn-walk "^8.0.0" - chalk "^4.1.0" - commander "^7.2.0" - gzip-size "^6.0.0" - lodash "^4.17.20" - opener "^1.5.2" - sirv "^1.0.7" - ws "^7.3.1" - -webpack-chain@^6.0.0, webpack-chain@^6.5.1: - version "6.5.1" - resolved "https://registry.yarnpkg.com/webpack-chain/-/webpack-chain-6.5.1.tgz#4f27284cbbb637e3c8fbdef43eef588d4d861206" - integrity sha512-7doO/SRtLu8q5WM0s7vPKPWX580qhi0/yBHkOxNkv50f6qB76Zy9o2wRTrrPULqYTvQlVHuvbA8v+G5ayuUDsA== - dependencies: - deepmerge "^1.5.2" - javascript-stringify "^2.0.1" - -webpack-dev-middleware@^5.3.1: - version "5.3.3" - resolved "https://registry.yarnpkg.com/webpack-dev-middleware/-/webpack-dev-middleware-5.3.3.tgz#efae67c2793908e7311f1d9b06f2a08dcc97e51f" - integrity sha512-hj5CYrY0bZLB+eTO+x/j67Pkrquiy7kWepMHmUMoPsmcUaeEnQJqFzHJOyxgWlq746/wUuA64p9ta34Kyb01pA== - dependencies: - colorette "^2.0.10" - memfs "^3.4.3" - mime-types "^2.1.31" - range-parser "^1.2.1" - schema-utils "^4.0.0" - -webpack-dev-server@^4.7.3: - version "4.11.1" - resolved "https://registry.yarnpkg.com/webpack-dev-server/-/webpack-dev-server-4.11.1.tgz#ae07f0d71ca0438cf88446f09029b92ce81380b5" - integrity sha512-lILVz9tAUy1zGFwieuaQtYiadImb5M3d+H+L1zDYalYoDl0cksAB1UNyuE5MMWJrG6zR1tXkCP2fitl7yoUJiw== - dependencies: - "@types/bonjour" "^3.5.9" - "@types/connect-history-api-fallback" "^1.3.5" - "@types/express" "^4.17.13" - "@types/serve-index" "^1.9.1" - "@types/serve-static" "^1.13.10" - "@types/sockjs" "^0.3.33" - "@types/ws" "^8.5.1" - ansi-html-community "^0.0.8" - bonjour-service "^1.0.11" - chokidar "^3.5.3" - colorette "^2.0.10" - compression "^1.7.4" - connect-history-api-fallback "^2.0.0" - default-gateway "^6.0.3" - express "^4.17.3" - graceful-fs "^4.2.6" - html-entities "^2.3.2" - http-proxy-middleware "^2.0.3" - ipaddr.js "^2.0.1" - open "^8.0.9" - p-retry "^4.5.0" - rimraf "^3.0.2" - schema-utils "^4.0.0" - selfsigned "^2.1.1" - serve-index "^1.9.1" - sockjs "^0.3.24" - spdy "^4.0.2" - webpack-dev-middleware "^5.3.1" - ws "^8.4.2" - -webpack-merge@^5.7.3, webpack-merge@^5.8.0: - version "5.8.0" - resolved "https://registry.yarnpkg.com/webpack-merge/-/webpack-merge-5.8.0.tgz#2b39dbf22af87776ad744c390223731d30a68f61" - integrity sha512-/SaI7xY0831XwP6kzuwhKWVKDP9t1QY1h65lAFLbZqMPIuYcD9QAW4u9STIbU9kaJbPBB/geU/gLr1wDjOhQ+Q== - dependencies: - clone-deep "^4.0.1" - wildcard "^2.0.0" - -webpack-sources@^3.2.3: - version "3.2.3" - resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-3.2.3.tgz#2d4daab8451fd4b240cc27055ff6a0c2ccea0cde" - integrity sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w== - -webpack-virtual-modules@^0.4.2: - version "0.4.5" - resolved "https://registry.yarnpkg.com/webpack-virtual-modules/-/webpack-virtual-modules-0.4.5.tgz#e476842dab5eafb7beb844aa2f747fc12ebbf6ec" - integrity sha512-8bWq0Iluiv9lVf9YaqWQ9+liNgXSHICm+rg544yRgGYaR8yXZTVBaHZkINZSB2yZSWo4b0F6MIxqJezVfOEAlg== - -webpack@^5.54.0, webpack@^5.65.0: - version "5.74.0" - resolved "https://registry.yarnpkg.com/webpack/-/webpack-5.74.0.tgz#02a5dac19a17e0bb47093f2be67c695102a55980" - integrity sha512-A2InDwnhhGN4LYctJj6M1JEaGL7Luj6LOmyBHjcI8529cm5p6VXiTIW2sn6ffvEAKmveLzvu4jrihwXtPojlAA== - dependencies: - "@types/eslint-scope" "^3.7.3" - "@types/estree" "^0.0.51" - "@webassemblyjs/ast" "1.11.1" - "@webassemblyjs/wasm-edit" "1.11.1" - "@webassemblyjs/wasm-parser" "1.11.1" - acorn "^8.7.1" - acorn-import-assertions "^1.7.6" - browserslist "^4.14.5" - chrome-trace-event "^1.0.2" - enhanced-resolve "^5.10.0" - es-module-lexer "^0.9.0" - eslint-scope "5.1.1" - events "^3.2.0" - glob-to-regexp "^0.4.1" - graceful-fs "^4.2.9" - json-parse-even-better-errors "^2.3.1" - loader-runner "^4.2.0" - mime-types "^2.1.27" - neo-async "^2.6.2" - schema-utils "^3.1.0" - tapable "^2.1.1" - terser-webpack-plugin "^5.1.3" - watchpack "^2.4.0" - webpack-sources "^3.2.3" - -websocket-driver@>=0.5.1, websocket-driver@^0.7.4: - version "0.7.4" - resolved "https://registry.yarnpkg.com/websocket-driver/-/websocket-driver-0.7.4.tgz#89ad5295bbf64b480abcba31e4953aca706f5760" - integrity sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg== - dependencies: - http-parser-js ">=0.5.1" - safe-buffer ">=5.1.0" - websocket-extensions ">=0.1.1" - -websocket-extensions@>=0.1.1: - version "0.1.4" - resolved "https://registry.yarnpkg.com/websocket-extensions/-/websocket-extensions-0.1.4.tgz#7f8473bc839dfd87608adb95d7eb075211578a42" - integrity sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg== - -whatwg-fetch@^3.4.1, whatwg-fetch@^3.6.2: - version "3.6.2" - resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-3.6.2.tgz#dced24f37f2624ed0281725d51d0e2e3fe677f8c" - integrity sha512-bJlen0FcuU/0EMLrdbJ7zOnW6ITZLrZMIarMUVmdKtsGvZna8vxKYaexICWPfZ8qwf9fzNq+UEIZrnSaApt6RA== - -whatwg-url@^5.0.0: - version "5.0.0" - resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" - integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== - dependencies: - tr46 "~0.0.3" - webidl-conversions "^3.0.0" - -which@^1.2.9: - version "1.3.1" - resolved "https://registry.yarnpkg.com/which/-/which-1.3.1.tgz#a45043d54f5805316da8d62f9f50918d3da70b0a" - integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== - dependencies: - isexe "^2.0.0" - -which@^2.0.1, which@^2.0.2: +which@^2.0.1: version "2.0.2" - resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + resolved "https://registry.npmmirror.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== dependencies: isexe "^2.0.0" -wide-align@^1.1.5: - version "1.1.5" - resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.5.tgz#df1d4c206854369ecf3c9a4898f1b23fbd9d15d3" - integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg== - dependencies: - string-width "^1.0.2 || 2 || 3 || 4" - -widest-line@^3.1.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/widest-line/-/widest-line-3.1.0.tgz#8292333bbf66cb45ff0de1603b136b7ae1496eca" - integrity sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg== - dependencies: - string-width "^4.0.0" - -wildcard@^2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/wildcard/-/wildcard-2.0.0.tgz#a77d20e5200c6faaac979e4b3aadc7b3dd7f8fec" - integrity sha512-JcKqAHLPxcdb9KM49dufGXn2x3ssnfjbcaQdLlfZsL9rH9wgDQjUtDxbo8NE0F6SFvydeu1VhZe7hZuHsB2/pw== - -wrap-ansi@^3.0.1: - version "3.0.1" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-3.0.1.tgz#288a04d87eda5c286e060dfe8f135ce8d007f8ba" - integrity sha512-iXR3tDXpbnTpzjKSylUJRkLuOrEC7hwEB221cgn6wtF8wpmz28puFXAEfPT5zrjM3wahygB//VuWEr1vTkDcNQ== - dependencies: - string-width "^2.1.1" - strip-ansi "^4.0.0" - wrap-ansi@^7.0.0: version "7.0.0" - resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" + resolved "https://registry.npmmirror.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== dependencies: ansi-styles "^4.0.0" @@ -8953,144 +3543,50 @@ wrap-ansi@^7.0.0: wrappy@1: version "1.0.2" - resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" + resolved "https://registry.npmmirror.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== -write-file-atomic@^3.0.0: - version "3.0.3" - resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-3.0.3.tgz#56bd5c5a5c70481cd19c571bd39ab965a5de56e8" - integrity sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q== - dependencies: - imurmurhash "^0.1.4" - is-typedarray "^1.0.0" - signal-exit "^3.0.2" - typedarray-to-buffer "^3.1.5" - -ws@^7.3.1: - version "7.5.9" - resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.9.tgz#54fa7db29f4c7cec68b1ddd3a89de099942bb591" - integrity sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q== - -ws@^8.4.2: - version "8.8.1" - resolved "https://registry.yarnpkg.com/ws/-/ws-8.8.1.tgz#5dbad0feb7ade8ecc99b830c1d77c913d4955ff0" - integrity sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA== - -xdg-basedir@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/xdg-basedir/-/xdg-basedir-4.0.0.tgz#4bc8d9984403696225ef83a1573cbbcb4e79db13" - integrity sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q== - -xhr@^2.0.1: - version "2.6.0" - resolved "https://registry.yarnpkg.com/xhr/-/xhr-2.6.0.tgz#b69d4395e792b4173d6b7df077f0fc5e4e2b249d" - integrity sha512-/eCGLb5rxjx5e3mF1A7s+pLlR6CGyqWN91fv1JgER5mVWg1MZmlhBvy9kjcsOdRk8RrIujotWyJamfyrp+WIcA== - dependencies: - global "~4.4.0" - is-function "^1.0.1" - parse-headers "^2.0.0" - xtend "^4.0.0" - -xml-parse-from-string@^1.0.0: - version "1.0.1" - resolved "https://registry.yarnpkg.com/xml-parse-from-string/-/xml-parse-from-string-1.0.1.tgz#a9029e929d3dbcded169f3c6e28238d95a5d5a28" - integrity sha512-ErcKwJTF54uRzzNMXq2X5sMIy88zJvfN2DmdoQvy7PAFJ+tPRU6ydWuOKNMyfmOjdyBQTFREi60s0Y0SyI0G0g== - -xml2js@^0.4.5: - version "0.4.23" - resolved "https://registry.yarnpkg.com/xml2js/-/xml2js-0.4.23.tgz#a0c69516752421eb2ac758ee4d4ccf58843eac66" - integrity sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug== - dependencies: - sax ">=0.6.0" - xmlbuilder "~11.0.0" - -xml2js@^0.5.0: - version "0.5.0" - resolved "https://registry.yarnpkg.com/xml2js/-/xml2js-0.5.0.tgz#d9440631fbb2ed800203fad106f2724f62c493b7" - integrity sha512-drPFnkQJik/O+uPKpqSgr22mpuFHqKdbS835iAQrUC73L2F5WkboIRd63ai/2Yg6I1jzifPFKH2NTK+cfglkIA== +xml2js@^0.6.2: + version "0.6.2" + resolved "https://registry.npmmirror.com/xml2js/-/xml2js-0.6.2.tgz#dd0b630083aa09c161e25a4d0901e2b2a929b499" + integrity sha512-T4rieHaC1EXcES0Kxxj4JWgaUQHDk+qwHcYOCFHfiwKz7tOVPLq7Hjq9dM1WCMhylqMEfP7hMcOIChvotiZegA== dependencies: sax ">=0.6.0" xmlbuilder "~11.0.0" xmlbuilder@>=11.0.1, xmlbuilder@^15.1.1: version "15.1.1" - resolved "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-15.1.1.tgz#9dcdce49eea66d8d10b42cae94a79c3c8d0c2ec5" + resolved "https://registry.npmmirror.com/xmlbuilder/-/xmlbuilder-15.1.1.tgz#9dcdce49eea66d8d10b42cae94a79c3c8d0c2ec5" integrity sha512-yMqGBqtXyeN1e3TGYvgNgDVZ3j84W4cwkOXQswghol6APgZWaff9lnbvN7MHYJOiXsvGPXtjTYJEiC9J2wv9Eg== xmlbuilder@~11.0.0: version "11.0.1" - resolved "https://registry.yarnpkg.com/xmlbuilder/-/xmlbuilder-11.0.1.tgz#be9bae1c8a046e76b31127726347d0ad7002beb3" + resolved "https://registry.npmmirror.com/xmlbuilder/-/xmlbuilder-11.0.1.tgz#be9bae1c8a046e76b31127726347d0ad7002beb3" integrity sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA== -xtend@^4.0.0, xtend@^4.0.2: - version "4.0.2" - resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" - integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== - y18n@^5.0.5: version "5.0.8" - resolved "https://registry.yarnpkg.com/y18n/-/y18n-5.0.8.tgz#7f4934d0f7ca8c56f95314939ddcd2dd91ce1d55" + resolved "https://registry.npmmirror.com/y18n/-/y18n-5.0.8.tgz#7f4934d0f7ca8c56f95314939ddcd2dd91ce1d55" integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA== -yaku@^0.16.6: - version "0.16.7" - resolved "https://registry.npmmirror.com/yaku/-/yaku-0.16.7.tgz#1d195c78aa9b5bf8479c895b9504fd4f0847984e" - integrity sha512-Syu3IB3rZvKvYk7yTiyl1bo/jiEFaaStrgv1V2TIJTqYPStSMQVO8EQjg/z+DRzLq/4LIIharNT3iH1hylEIRw== - -yallist@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52" - integrity sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A== - yallist@^4.0.0: version "4.0.0" - resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + resolved "https://registry.npmmirror.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== -yaml@^1.10.0, yaml@^1.10.2: - version "1.10.2" - resolved "https://registry.yarnpkg.com/yaml/-/yaml-1.10.2.tgz#2301c5ffbf12b467de8da2333a459e29e7920e4b" - integrity sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg== +yaml@^2.1.1: + version "2.3.3" + resolved "https://registry.npmmirror.com/yaml/-/yaml-2.3.3.tgz#01f6d18ef036446340007db8e016810e5d64aad9" + integrity sha512-zw0VAJxgeZ6+++/su5AFoqBbZbrEakwu+X0M5HmcwUiBL7AzcuPKjj5we4xfQLp78LkEMpD0cOnUhmgOVy3KdQ== -yargs-parser@^20.2.2: - version "20.2.9" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.9.tgz#2eb7dc3b0289718fc295f362753845c41a0c94ee" - integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w== - -yargs-parser@^21.0.0, yargs-parser@^21.1.1: +yargs-parser@^21.1.1: version "21.1.1" - resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-21.1.1.tgz#9096bceebf990d21bb31fa9516e0ede294a77d35" + resolved "https://registry.npmmirror.com/yargs-parser/-/yargs-parser-21.1.1.tgz#9096bceebf990d21bb31fa9516e0ede294a77d35" integrity sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw== -yargs@^16.0.0, yargs@^16.2.0: - version "16.2.0" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-16.2.0.tgz#1c82bf0f6b6a66eafce7ef30e376f49a12477f66" - integrity sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw== - dependencies: - cliui "^7.0.2" - escalade "^3.1.1" - get-caller-file "^2.0.5" - require-directory "^2.1.1" - string-width "^4.2.0" - y18n "^5.0.5" - yargs-parser "^20.2.2" - -yargs@^17.0.1: - version "17.5.1" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.5.1.tgz#e109900cab6fcb7fd44b1d8249166feb0b36e58e" - integrity sha512-t6YAJcxDkNX7NFYiVtKvWUz8l+PaKTLiL63mJYWR2GnHq2gjEWISzsLp9wg3aY36dY1j+gfIEL3pIF+XlJJfbA== - dependencies: - cliui "^7.0.2" - escalade "^3.1.1" - get-caller-file "^2.0.5" - require-directory "^2.1.1" - string-width "^4.2.3" - y18n "^5.0.5" - yargs-parser "^21.0.0" - yargs@^17.6.2: version "17.7.2" - resolved "https://registry.yarnpkg.com/yargs/-/yargs-17.7.2.tgz#991df39aca675a192b816e1e0363f9d75d2aa269" + resolved "https://registry.npmmirror.com/yargs/-/yargs-17.7.2.tgz#991df39aca675a192b816e1e0363f9d75d2aa269" integrity sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w== dependencies: cliui "^8.0.1" @@ -9103,7 +3599,7 @@ yargs@^17.6.2: yauzl@^2.10.0: version "2.10.0" - resolved "https://registry.yarnpkg.com/yauzl/-/yauzl-2.10.0.tgz#c7eb17c93e112cb1086fa6d8e51fb0667b79a5f9" + resolved "https://registry.npmmirror.com/yauzl/-/yauzl-2.10.0.tgz#c7eb17c93e112cb1086fa6d8e51fb0667b79a5f9" integrity sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g== dependencies: buffer-crc32 "~0.2.3"