Merge remote-tracking branch 'origin/main' into feat/json-editor
This commit is contained in:
		
						commit
						d289c9b465
					
				
							
								
								
									
										8
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								components.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -72,6 +72,7 @@ declare module '@vue/runtime-core' { | |||||||
|     DockerRunToDockerComposeConverter: typeof import('./src/tools/docker-run-to-docker-compose-converter/docker-run-to-docker-compose-converter.vue')['default'] |     DockerRunToDockerComposeConverter: typeof import('./src/tools/docker-run-to-docker-compose-converter/docker-run-to-docker-compose-converter.vue')['default'] | ||||||
|     DynamicValues: typeof import('./src/tools/benchmark-builder/dynamic-values.vue')['default'] |     DynamicValues: typeof import('./src/tools/benchmark-builder/dynamic-values.vue')['default'] | ||||||
|     Editor: typeof import('./src/tools/html-wysiwyg-editor/editor/editor.vue')['default'] |     Editor: typeof import('./src/tools/html-wysiwyg-editor/editor/editor.vue')['default'] | ||||||
|  |     EmailNormalizer: typeof import('./src/tools/email-normalizer/email-normalizer.vue')['default'] | ||||||
|     EmojiCard: typeof import('./src/tools/emoji-picker/emoji-card.vue')['default'] |     EmojiCard: typeof import('./src/tools/emoji-picker/emoji-card.vue')['default'] | ||||||
|     EmojiGrid: typeof import('./src/tools/emoji-picker/emoji-grid.vue')['default'] |     EmojiGrid: typeof import('./src/tools/emoji-picker/emoji-grid.vue')['default'] | ||||||
|     EmojiPicker: typeof import('./src/tools/emoji-picker/emoji-picker.vue')['default'] |     EmojiPicker: typeof import('./src/tools/emoji-picker/emoji-picker.vue')['default'] | ||||||
| @ -111,6 +112,7 @@ declare module '@vue/runtime-core' { | |||||||
|     JsonMinify: typeof import('./src/tools/json-minify/json-minify.vue')['default'] |     JsonMinify: typeof import('./src/tools/json-minify/json-minify.vue')['default'] | ||||||
|     JsonToCsv: typeof import('./src/tools/json-to-csv/json-to-csv.vue')['default'] |     JsonToCsv: typeof import('./src/tools/json-to-csv/json-to-csv.vue')['default'] | ||||||
|     JsonToToml: typeof import('./src/tools/json-to-toml/json-to-toml.vue')['default'] |     JsonToToml: typeof import('./src/tools/json-to-toml/json-to-toml.vue')['default'] | ||||||
|  |     JsonToXml: typeof import('./src/tools/json-to-xml/json-to-xml.vue')['default'] | ||||||
|     JsonToYaml: typeof import('./src/tools/json-to-yaml-converter/json-to-yaml.vue')['default'] |     JsonToYaml: typeof import('./src/tools/json-to-yaml-converter/json-to-yaml.vue')['default'] | ||||||
|     JsonViewer: typeof import('./src/tools/json-viewer/json-viewer.vue')['default'] |     JsonViewer: typeof import('./src/tools/json-viewer/json-viewer.vue')['default'] | ||||||
|     JwtParser: typeof import('./src/tools/jwt-parser/jwt-parser.vue')['default'] |     JwtParser: typeof import('./src/tools/jwt-parser/jwt-parser.vue')['default'] | ||||||
| @ -131,17 +133,14 @@ declare module '@vue/runtime-core' { | |||||||
|     NCode: typeof import('naive-ui')['NCode'] |     NCode: typeof import('naive-ui')['NCode'] | ||||||
|     NCollapseTransition: typeof import('naive-ui')['NCollapseTransition'] |     NCollapseTransition: typeof import('naive-ui')['NCollapseTransition'] | ||||||
|     NConfigProvider: typeof import('naive-ui')['NConfigProvider'] |     NConfigProvider: typeof import('naive-ui')['NConfigProvider'] | ||||||
|     NDivider: typeof import('naive-ui')['NDivider'] |  | ||||||
|     NEllipsis: typeof import('naive-ui')['NEllipsis'] |     NEllipsis: typeof import('naive-ui')['NEllipsis'] | ||||||
|     NForm: typeof import('naive-ui')['NForm'] |     NForm: typeof import('naive-ui')['NForm'] | ||||||
|  |     NForm: typeof import('naive-ui')['NForm'] | ||||||
|     NFormItem: typeof import('naive-ui')['NFormItem'] |     NFormItem: typeof import('naive-ui')['NFormItem'] | ||||||
|     NGi: typeof import('naive-ui')['NGi'] |  | ||||||
|     NGrid: typeof import('naive-ui')['NGrid'] |  | ||||||
|     NH1: typeof import('naive-ui')['NH1'] |     NH1: typeof import('naive-ui')['NH1'] | ||||||
|     NH3: typeof import('naive-ui')['NH3'] |     NH3: typeof import('naive-ui')['NH3'] | ||||||
|     NIcon: typeof import('naive-ui')['NIcon'] |     NIcon: typeof import('naive-ui')['NIcon'] | ||||||
|     NInputNumber: typeof import('naive-ui')['NInputNumber'] |     NInputNumber: typeof import('naive-ui')['NInputNumber'] | ||||||
|     NLabel: typeof import('naive-ui')['NLabel'] |  | ||||||
|     NLayout: typeof import('naive-ui')['NLayout'] |     NLayout: typeof import('naive-ui')['NLayout'] | ||||||
|     NLayoutSider: typeof import('naive-ui')['NLayoutSider'] |     NLayoutSider: typeof import('naive-ui')['NLayoutSider'] | ||||||
|     NMenu: typeof import('naive-ui')['NMenu'] |     NMenu: typeof import('naive-ui')['NMenu'] | ||||||
| @ -190,6 +189,7 @@ declare module '@vue/runtime-core' { | |||||||
|     UuidGenerator: typeof import('./src/tools/uuid-generator/uuid-generator.vue')['default'] |     UuidGenerator: typeof import('./src/tools/uuid-generator/uuid-generator.vue')['default'] | ||||||
|     WifiQrCodeGenerator: typeof import('./src/tools/wifi-qr-code-generator/wifi-qr-code-generator.vue')['default'] |     WifiQrCodeGenerator: typeof import('./src/tools/wifi-qr-code-generator/wifi-qr-code-generator.vue')['default'] | ||||||
|     XmlFormatter: typeof import('./src/tools/xml-formatter/xml-formatter.vue')['default'] |     XmlFormatter: typeof import('./src/tools/xml-formatter/xml-formatter.vue')['default'] | ||||||
|  |     XmlToJson: typeof import('./src/tools/xml-to-json/xml-to-json.vue')['default'] | ||||||
|     YamlToJson: typeof import('./src/tools/yaml-to-json-converter/yaml-to-json.vue')['default'] |     YamlToJson: typeof import('./src/tools/yaml-to-json-converter/yaml-to-json.vue')['default'] | ||||||
|     YamlToToml: typeof import('./src/tools/yaml-to-toml/yaml-to-toml.vue')['default'] |     YamlToToml: typeof import('./src/tools/yaml-to-toml/yaml-to-toml.vue')['default'] | ||||||
|     YamlViewer: typeof import('./src/tools/yaml-viewer/yaml-viewer.vue')['default'] |     YamlViewer: typeof import('./src/tools/yaml-viewer/yaml-viewer.vue')['default'] | ||||||
|  | |||||||
							
								
								
									
										373
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										373
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							| @ -98,9 +98,6 @@ dependencies: | |||||||
|   js-base64: |   js-base64: | ||||||
|     specifier: ^3.7.6 |     specifier: ^3.7.6 | ||||||
|     version: 3.7.7 |     version: 3.7.7 | ||||||
|   json-editor-vue: |  | ||||||
|     specifier: ^0.16.0 |  | ||||||
|     version: 0.16.0(@lezer/common@1.2.1)(vue@3.3.4) |  | ||||||
|   json5: |   json5: | ||||||
|     specifier: ^2.2.3 |     specifier: ^2.2.3 | ||||||
|     version: 2.2.3 |     version: 2.2.3 | ||||||
| @ -167,9 +164,6 @@ dependencies: | |||||||
|   uuid: |   uuid: | ||||||
|     specifier: ^9.0.0 |     specifier: ^9.0.0 | ||||||
|     version: 9.0.0 |     version: 9.0.0 | ||||||
|   vanilla-jsoneditor: |  | ||||||
|     specifier: ^0.23.8 |  | ||||||
|     version: 0.23.8(@lezer/common@1.2.1) |  | ||||||
|   vue: |   vue: | ||||||
|     specifier: ^3.3.4 |     specifier: ^3.3.4 | ||||||
|     version: 3.3.4 |     version: 3.3.4 | ||||||
| @ -447,13 +441,13 @@ packages: | |||||||
|     resolution: {integrity: sha512-pvFiLP2BeOKA/ZOS6jxx4XhKzdVLHDhGlFEaZ2flWWYf2xOqVniqpk38I04DFRyz+L0ASggl7SkItTc+ZLju4w==} |     resolution: {integrity: sha512-pvFiLP2BeOKA/ZOS6jxx4XhKzdVLHDhGlFEaZ2flWWYf2xOqVniqpk38I04DFRyz+L0ASggl7SkItTc+ZLju4w==} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /@apideck/better-ajv-errors@0.3.6(ajv@8.17.1): |   /@apideck/better-ajv-errors@0.3.6(ajv@8.12.0): | ||||||
|     resolution: {integrity: sha512-P+ZygBLZtkp0qqOAJJVX4oX/sFo5JR3eBWwwuqHHhK0GIgQOKWrAfiAaWX0aArHkRWHMuggFEgAZNxVPwPZYaA==} |     resolution: {integrity: sha512-P+ZygBLZtkp0qqOAJJVX4oX/sFo5JR3eBWwwuqHHhK0GIgQOKWrAfiAaWX0aArHkRWHMuggFEgAZNxVPwPZYaA==} | ||||||
|     engines: {node: '>=10'} |     engines: {node: '>=10'} | ||||||
|     peerDependencies: |     peerDependencies: | ||||||
|       ajv: '>=8' |       ajv: '>=8' | ||||||
|     dependencies: |     dependencies: | ||||||
|       ajv: 8.17.1 |       ajv: 8.12.0 | ||||||
|       json-schema: 0.4.0 |       json-schema: 0.4.0 | ||||||
|       jsonpointer: 5.0.1 |       jsonpointer: 5.0.1 | ||||||
|       leven: 3.1.0 |       leven: 3.1.0 | ||||||
| @ -1910,75 +1904,6 @@ packages: | |||||||
|       '@babel/helper-validator-identifier': 7.22.20 |       '@babel/helper-validator-identifier': 7.22.20 | ||||||
|       to-fast-properties: 2.0.0 |       to-fast-properties: 2.0.0 | ||||||
| 
 | 
 | ||||||
|   /@codemirror/autocomplete@6.18.1(@codemirror/language@6.10.3)(@codemirror/state@6.4.1)(@codemirror/view@6.33.0)(@lezer/common@1.2.1): |  | ||||||
|     resolution: {integrity: sha512-iWHdj/B1ethnHRTwZj+C1obmmuCzquH29EbcKr0qIjA9NfDeBDJ7vs+WOHsFeLeflE4o+dHfYndJloMKHUkWUA==} |  | ||||||
|     peerDependencies: |  | ||||||
|       '@codemirror/language': ^6.0.0 |  | ||||||
|       '@codemirror/state': ^6.0.0 |  | ||||||
|       '@codemirror/view': ^6.0.0 |  | ||||||
|       '@lezer/common': ^1.0.0 |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/language': 6.10.3 |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       '@codemirror/view': 6.33.0 |  | ||||||
|       '@lezer/common': 1.2.1 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@codemirror/commands@6.6.2: |  | ||||||
|     resolution: {integrity: sha512-Fq7eWOl1Rcbrfn6jD8FPCj9Auaxdm5nIK5RYOeW7ughnd/rY5AmPg6b+CfsG39ZHdwiwe8lde3q8uR7CF5S0yQ==} |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/language': 6.10.3 |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       '@codemirror/view': 6.33.0 |  | ||||||
|       '@lezer/common': 1.2.1 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@codemirror/lang-json@6.0.1: |  | ||||||
|     resolution: {integrity: sha512-+T1flHdgpqDDlJZ2Lkil/rLiRy684WMLc74xUnjJH48GQdfJo/pudlTRreZmKwzP8/tGdKf83wlbAdOCzlJOGQ==} |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/language': 6.10.3 |  | ||||||
|       '@lezer/json': 1.0.2 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@codemirror/language@6.10.3: |  | ||||||
|     resolution: {integrity: sha512-kDqEU5sCP55Oabl6E7m5N+vZRoc0iWqgDVhEKifcHzPzjqCegcO4amfrYVL9PmPZpl4G0yjkpTpUO/Ui8CzO8A==} |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       '@codemirror/view': 6.33.0 |  | ||||||
|       '@lezer/common': 1.2.1 |  | ||||||
|       '@lezer/highlight': 1.2.1 |  | ||||||
|       '@lezer/lr': 1.4.2 |  | ||||||
|       style-mod: 4.1.2 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@codemirror/lint@6.8.1: |  | ||||||
|     resolution: {integrity: sha512-IZ0Y7S4/bpaunwggW2jYqwLuHj0QtESf5xcROewY6+lDNwZ/NzvR4t+vpYgg9m7V8UXLPYqG+lu3DF470E5Oxg==} |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       '@codemirror/view': 6.33.0 |  | ||||||
|       crelt: 1.0.6 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@codemirror/search@6.5.6: |  | ||||||
|     resolution: {integrity: sha512-rpMgcsh7o0GuCDUXKPvww+muLA1pDJaFrpq/CCHtpQJYz8xopu4D1hPcKRoDD0YlF8gZaqTNIRa4VRBWyhyy7Q==} |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       '@codemirror/view': 6.33.0 |  | ||||||
|       crelt: 1.0.6 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@codemirror/state@6.4.1: |  | ||||||
|     resolution: {integrity: sha512-QkEyUiLhsJoZkbumGZlswmAhA7CBU02Wrz7zvH4SrcifbsqwlXShVXg65f3v/ts57W3dqyamEriMhij1Z3Zz4A==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@codemirror/view@6.33.0: |  | ||||||
|     resolution: {integrity: sha512-AroaR3BvnjRW8fiZBalAaK+ZzB5usGgI014YKElYZvQdNH5ZIidHlO+cyf/2rWzyBFRkvG6VhiXeAEbC53P2YQ==} |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       style-mod: 4.1.2 |  | ||||||
|       w3c-keyname: 2.2.8 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@css-render/plugin-bem@0.15.12(css-render@0.15.12): |   /@css-render/plugin-bem@0.15.12(css-render@0.15.12): | ||||||
|     resolution: {integrity: sha512-Lq2jSOZn+wYQtsyaFj6QRz2EzAnd3iW5fZeHO1WSXQdVYwvwGX0ZiH3X2JQgtgYLT1yeGtrwrqJdNdMEUD2xTw==} |     resolution: {integrity: sha512-Lq2jSOZn+wYQtsyaFj6QRz2EzAnd3iW5fZeHO1WSXQdVYwvwGX0ZiH3X2JQgtgYLT1yeGtrwrqJdNdMEUD2xTw==} | ||||||
|     peerDependencies: |     peerDependencies: | ||||||
| @ -2234,25 +2159,6 @@ packages: | |||||||
|     engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} |     engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /@fortawesome/fontawesome-common-types@6.6.0: |  | ||||||
|     resolution: {integrity: sha512-xyX0X9mc0kyz9plIyryrRbl7ngsA9jz77mCZJsUkLl+ZKs0KWObgaEBoSgQiYWAsSmjz/yjl0F++Got0Mdp4Rw==} |  | ||||||
|     engines: {node: '>=6'} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@fortawesome/free-regular-svg-icons@6.6.0: |  | ||||||
|     resolution: {integrity: sha512-Yv9hDzL4aI73BEwSEh20clrY8q/uLxawaQ98lekBx6t9dQKDHcDzzV1p2YtBGTtolYtNqcWdniOnhzB+JPnQEQ==} |  | ||||||
|     engines: {node: '>=6'} |  | ||||||
|     dependencies: |  | ||||||
|       '@fortawesome/fontawesome-common-types': 6.6.0 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@fortawesome/free-solid-svg-icons@6.6.0: |  | ||||||
|     resolution: {integrity: sha512-IYv/2skhEDFc2WGUcqvFJkeK39Q+HyPf5GHUrT/l2pKbtgEIv1al1TKd6qStR5OIwQdN1GZP54ci3y4mroJWjA==} |  | ||||||
|     engines: {node: '>=6'} |  | ||||||
|     dependencies: |  | ||||||
|       '@fortawesome/fontawesome-common-types': 6.6.0 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@humanwhocodes/config-array@0.11.10: |   /@humanwhocodes/config-array@0.11.10: | ||||||
|     resolution: {integrity: sha512-KVVjQmNUepDVGXNuoRRdmmEjruj0KfiGSbS8LVc12LMsWDQzRXJ0qdhN8L8uUigKpfEHRhlaQFY0ib1tnUbNeQ==} |     resolution: {integrity: sha512-KVVjQmNUepDVGXNuoRRdmmEjruj0KfiGSbS8LVc12LMsWDQzRXJ0qdhN8L8uUigKpfEHRhlaQFY0ib1tnUbNeQ==} | ||||||
|     engines: {node: '>=10.10.0'} |     engines: {node: '>=10.10.0'} | ||||||
| @ -2452,30 +2358,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-dfLbk+PwWvFzSxwk3n5ySL0hfBog779o8h68wK/7/APo/7cgyWp5jcXockbxdk5kFRkbeXWm4Fbi9FrdN381sA==} |     resolution: {integrity: sha512-dfLbk+PwWvFzSxwk3n5ySL0hfBog779o8h68wK/7/APo/7cgyWp5jcXockbxdk5kFRkbeXWm4Fbi9FrdN381sA==} | ||||||
|     dev: false |     dev: false | ||||||
| 
 | 
 | ||||||
|   /@lezer/common@1.2.1: |  | ||||||
|     resolution: {integrity: sha512-yemX0ZD2xS/73llMZIK6KplkjIjf2EvAHcinDi/TfJ9hS25G0388+ClHt6/3but0oOxinTcQHJLDXh6w1crzFQ==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@lezer/highlight@1.2.1: |  | ||||||
|     resolution: {integrity: sha512-Z5duk4RN/3zuVO7Jq0pGLJ3qynpxUVsh7IbUbGj88+uV2ApSAn6kWg2au3iJb+0Zi7kKtqffIESgNcRXWZWmSA==} |  | ||||||
|     dependencies: |  | ||||||
|       '@lezer/common': 1.2.1 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@lezer/json@1.0.2: |  | ||||||
|     resolution: {integrity: sha512-xHT2P4S5eeCYECyKNPhr4cbEL9tc8w83SPwRC373o9uEdrvGKTZoJVAGxpOsZckMlEh9W23Pc72ew918RWQOBQ==} |  | ||||||
|     dependencies: |  | ||||||
|       '@lezer/common': 1.2.1 |  | ||||||
|       '@lezer/highlight': 1.2.1 |  | ||||||
|       '@lezer/lr': 1.4.2 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@lezer/lr@1.4.2: |  | ||||||
|     resolution: {integrity: sha512-pu0K1jCIdnQ12aWNaAVU5bzi7Bd1w54J3ECgANPmYLtQKP0HBj2cE/5coBD66MT10xbtIuUr7tg0Shbsvk0mDA==} |  | ||||||
|     dependencies: |  | ||||||
|       '@lezer/common': 1.2.1 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@linaria/core@4.2.9: |   /@linaria/core@4.2.9: | ||||||
|     resolution: {integrity: sha512-ELcu37VNVOT/PU0L6WDIN+aLzNFyJrqoBYT0CucGOCAmODbojUMCv8oJYRbWzA3N34w1t199dN4UFdfRWFG2rg==} |     resolution: {integrity: sha512-ELcu37VNVOT/PU0L6WDIN+aLzNFyJrqoBYT0CucGOCAmODbojUMCv8oJYRbWzA3N34w1t199dN4UFdfRWFG2rg==} | ||||||
|     engines: {node: ^12.16.0 || >=13.7.0} |     engines: {node: ^12.16.0 || >=13.7.0} | ||||||
| @ -2626,18 +2508,6 @@ packages: | |||||||
|       type-fest: 2.19.0 |       type-fest: 2.19.0 | ||||||
|     dev: false |     dev: false | ||||||
| 
 | 
 | ||||||
|   /@replit/codemirror-indentation-markers@6.5.3(@codemirror/language@6.10.3)(@codemirror/state@6.4.1)(@codemirror/view@6.33.0): |  | ||||||
|     resolution: {integrity: sha512-hL5Sfvw3C1vgg7GolLe/uxX5T3tmgOA3ZzqlMv47zjU1ON51pzNWiVbS22oh6crYhtVhv8b3gdXwoYp++2ilHw==} |  | ||||||
|     peerDependencies: |  | ||||||
|       '@codemirror/language': ^6.0.0 |  | ||||||
|       '@codemirror/state': ^6.0.0 |  | ||||||
|       '@codemirror/view': ^6.0.0 |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/language': 6.10.3 |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       '@codemirror/view': 6.33.0 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@rollup/plugin-babel@5.3.1(@babel/core@7.23.2)(rollup@2.79.1): |   /@rollup/plugin-babel@5.3.1(@babel/core@7.23.2)(rollup@2.79.1): | ||||||
|     resolution: {integrity: sha512-WFfdLWU/xVWKeRQnKmIAQULUI7Il0gZnBIH/ZFO069wYIfPu+8zrfp/KMW0atmELoRDq8FbiP3VCss9MhCut7Q==} |     resolution: {integrity: sha512-WFfdLWU/xVWKeRQnKmIAQULUI7Il0gZnBIH/ZFO069wYIfPu+8zrfp/KMW0atmELoRDq8FbiP3VCss9MhCut7Q==} | ||||||
|     engines: {node: '>= 10.0.0'} |     engines: {node: '>= 10.0.0'} | ||||||
| @ -2744,10 +2614,6 @@ packages: | |||||||
|       escape-string-regexp: 5.0.0 |       escape-string-regexp: 5.0.0 | ||||||
|     dev: false |     dev: false | ||||||
| 
 | 
 | ||||||
|   /@sphinxxxx/color-conversion@2.2.2: |  | ||||||
|     resolution: {integrity: sha512-XExJS3cLqgrmNBIP3bBw6+1oQ1ksGjFh0+oClDKFYpCCqx/hlqwWO5KO/S63fzUo67SxI9dMrF0y5T/Ey7h8Zw==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@surma/rollup-plugin-off-main-thread@2.2.3: |   /@surma/rollup-plugin-off-main-thread@2.2.3: | ||||||
|     resolution: {integrity: sha512-lR8q/9W7hZpMWweNiAKU7NQerBnzQQLvi8qnTDU/fxItPhtZVMbPV3lbCwjhIlNBe9Bbr5V+KHshvWmVSG9cxQ==} |     resolution: {integrity: sha512-lR8q/9W7hZpMWweNiAKU7NQerBnzQQLvi8qnTDU/fxItPhtZVMbPV3lbCwjhIlNBe9Bbr5V+KHshvWmVSG9cxQ==} | ||||||
|     dependencies: |     dependencies: | ||||||
| @ -3051,10 +2917,6 @@ packages: | |||||||
|   /@types/estree@1.0.0: |   /@types/estree@1.0.0: | ||||||
|     resolution: {integrity: sha512-WulqXMDUTYAXCjZnk6JtIHPigp55cVtDgDrO2gHRwhyJto21+1zbVCtOYB2L1F9w4qCQ0rOGWBnBe0FNTiEJIQ==} |     resolution: {integrity: sha512-WulqXMDUTYAXCjZnk6JtIHPigp55cVtDgDrO2gHRwhyJto21+1zbVCtOYB2L1F9w4qCQ0rOGWBnBe0FNTiEJIQ==} | ||||||
| 
 | 
 | ||||||
|   /@types/estree@1.0.6: |  | ||||||
|     resolution: {integrity: sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /@types/figlet@1.5.8: |   /@types/figlet@1.5.8: | ||||||
|     resolution: {integrity: sha512-G22AUvy4Tl95XLE7jmUM8s8mKcoz+Hr+Xm9W90gJsppJq9f9tHvOGkrpn4gRX0q/cLtBdNkWtWCKDg2UDZoZvQ==} |     resolution: {integrity: sha512-G22AUvy4Tl95XLE7jmUM8s8mKcoz+Hr+Xm9W90gJsppJq9f9tHvOGkrpn4gRX0q/cLtBdNkWtWCKDg2UDZoZvQ==} | ||||||
|     dev: false |     dev: false | ||||||
| @ -3498,7 +3360,7 @@ packages: | |||||||
|     dependencies: |     dependencies: | ||||||
|       '@unhead/dom': 0.5.1 |       '@unhead/dom': 0.5.1 | ||||||
|       '@unhead/schema': 0.5.1 |       '@unhead/schema': 0.5.1 | ||||||
|       '@vueuse/shared': 11.1.0(vue@3.3.4) |       '@vueuse/shared': 10.11.1(vue@3.3.4) | ||||||
|       unhead: 0.5.1 |       unhead: 0.5.1 | ||||||
|       vue: 3.3.4 |       vue: 3.3.4 | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
| @ -4131,19 +3993,19 @@ packages: | |||||||
|       - vue |       - vue | ||||||
|     dev: false |     dev: false | ||||||
| 
 | 
 | ||||||
|   /@vueuse/shared@10.3.0(vue@3.3.4): |   /@vueuse/shared@10.11.1(vue@3.3.4): | ||||||
|     resolution: {integrity: sha512-kGqCTEuFPMK4+fNWy6dUOiYmxGcUbtznMwBZLC1PubidF4VZY05B+Oht7Jh7/6x4VOWGpvu3R37WHi81cKpiqg==} |     resolution: {integrity: sha512-LHpC8711VFZlDaYUXEBbFBCQ7GS3dVU9mjOhhMhXP6txTV4EhYQg/KGnQuvt/sPAtoUKq7VVUnL6mVtFoL42sA==} | ||||||
|     dependencies: |     dependencies: | ||||||
|       vue-demi: 0.14.5(vue@3.3.4) |       vue-demi: 0.14.10(vue@3.3.4) | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - '@vue/composition-api' |       - '@vue/composition-api' | ||||||
|       - vue |       - vue | ||||||
|     dev: false |     dev: false | ||||||
| 
 | 
 | ||||||
|   /@vueuse/shared@11.1.0(vue@3.3.4): |   /@vueuse/shared@10.3.0(vue@3.3.4): | ||||||
|     resolution: {integrity: sha512-YUtIpY122q7osj+zsNMFAfMTubGz0sn5QzE5gPzAIiCmtt2ha3uQUY1+JPyL4gRCTsLPX82Y9brNbo/aqlA91w==} |     resolution: {integrity: sha512-kGqCTEuFPMK4+fNWy6dUOiYmxGcUbtznMwBZLC1PubidF4VZY05B+Oht7Jh7/6x4VOWGpvu3R37WHi81cKpiqg==} | ||||||
|     dependencies: |     dependencies: | ||||||
|       vue-demi: 0.14.10(vue@3.3.4) |       vue-demi: 0.14.5(vue@3.3.4) | ||||||
|     transitivePeerDependencies: |     transitivePeerDependencies: | ||||||
|       - '@vue/composition-api' |       - '@vue/composition-api' | ||||||
|       - vue |       - vue | ||||||
| @ -4207,13 +4069,14 @@ packages: | |||||||
|       uri-js: 4.4.1 |       uri-js: 4.4.1 | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /ajv@8.17.1: |   /ajv@8.12.0: | ||||||
|     resolution: {integrity: sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==} |     resolution: {integrity: sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==} | ||||||
|     dependencies: |     dependencies: | ||||||
|       fast-deep-equal: 3.1.3 |       fast-deep-equal: 3.1.3 | ||||||
|       fast-uri: 3.0.1 |  | ||||||
|       json-schema-traverse: 1.0.0 |       json-schema-traverse: 1.0.0 | ||||||
|       require-from-string: 2.0.2 |       require-from-string: 2.0.2 | ||||||
|  |       uri-js: 4.4.1 | ||||||
|  |     dev: true | ||||||
| 
 | 
 | ||||||
|   /ansi-colors@4.1.3: |   /ansi-colors@4.1.3: | ||||||
|     resolution: {integrity: sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==} |     resolution: {integrity: sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==} | ||||||
| @ -4256,11 +4119,6 @@ packages: | |||||||
|   /argparse@2.0.1: |   /argparse@2.0.1: | ||||||
|     resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==} |     resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==} | ||||||
| 
 | 
 | ||||||
|   /aria-query@5.3.2: |  | ||||||
|     resolution: {integrity: sha512-COROpnaoap1E2F000S62r6A60uHZnmlvomhfyT2DlTcrY1OrBKn2UhH7qn5wTC9zMvD0AY7csdPSNwKP+7WiQw==} |  | ||||||
|     engines: {node: '>= 0.4'} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /array-buffer-byte-length@1.0.0: |   /array-buffer-byte-length@1.0.0: | ||||||
|     resolution: {integrity: sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==} |     resolution: {integrity: sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==} | ||||||
|     dependencies: |     dependencies: | ||||||
| @ -4312,11 +4170,6 @@ packages: | |||||||
|     engines: {node: '>= 0.4'} |     engines: {node: '>= 0.4'} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /axobject-query@4.1.0: |  | ||||||
|     resolution: {integrity: sha512-qIj0G9wZbMGNLjLmg1PT6v2mE9AH2zlnADJD/2tC6E00hgmhUOfEB6greHPAfLRSufHqROIUTkw6E+M3lH0PTQ==} |  | ||||||
|     engines: {node: '>= 0.4'} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /babel-merge@3.0.0(@babel/core@7.23.2): |   /babel-merge@3.0.0(@babel/core@7.23.2): | ||||||
|     resolution: {integrity: sha512-eBOBtHnzt9xvnjpYNI5HmaPp/b2vMveE5XggzqHnQeHJ8mFIBrBv6WZEVIj5jJ2uwTItkqKo9gWzEEcBxEq0yw==} |     resolution: {integrity: sha512-eBOBtHnzt9xvnjpYNI5HmaPp/b2vMveE5XggzqHnQeHJ8mFIBrBv6WZEVIj5jJ2uwTItkqKo9gWzEEcBxEq0yw==} | ||||||
|     peerDependencies: |     peerDependencies: | ||||||
| @ -4614,13 +4467,6 @@ packages: | |||||||
|     optionalDependencies: |     optionalDependencies: | ||||||
|       fsevents: 2.3.3 |       fsevents: 2.3.3 | ||||||
| 
 | 
 | ||||||
|   /chokidar@4.0.1: |  | ||||||
|     resolution: {integrity: sha512-n8enUVCED/KVRQlab1hr3MVpcVMvxtZjmEa956u+4YijlmQED223XMSYj2tLuKvr4jcCTzNNMpQDUer72MMmzA==} |  | ||||||
|     engines: {node: '>= 14.16.0'} |  | ||||||
|     dependencies: |  | ||||||
|       readdirp: 4.0.1 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /ci-info@3.8.0: |   /ci-info@3.8.0: | ||||||
|     resolution: {integrity: sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==} |     resolution: {integrity: sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==} | ||||||
|     engines: {node: '>=8'} |     engines: {node: '>=8'} | ||||||
| @ -4658,28 +4504,6 @@ packages: | |||||||
|     engines: {node: '>=0.8'} |     engines: {node: '>=0.8'} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /code-red@1.0.4: |  | ||||||
|     resolution: {integrity: sha512-7qJWqItLA8/VPVlKJlFXU+NBlo/qyfs39aJcuMT/2ere32ZqvF5OSxgdM5xOfJJ7O429gg2HM47y8v9P+9wrNw==} |  | ||||||
|     dependencies: |  | ||||||
|       '@jridgewell/sourcemap-codec': 1.4.15 |  | ||||||
|       '@types/estree': 1.0.6 |  | ||||||
|       acorn: 8.11.2 |  | ||||||
|       estree-walker: 3.0.3 |  | ||||||
|       periscopic: 3.1.0 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /codemirror-wrapped-line-indent@1.0.8(@codemirror/language@6.10.3)(@codemirror/state@6.4.1)(@codemirror/view@6.33.0): |  | ||||||
|     resolution: {integrity: sha512-5UwuHCz4oAZuvot1DbfFxSxJacTESdNGa/KpJD7HfpVpDAJdgB1vV9OG4b4pkJqPWuOfIpFLTQEKS85kTpV+XA==} |  | ||||||
|     peerDependencies: |  | ||||||
|       '@codemirror/language': ^6.9.0 |  | ||||||
|       '@codemirror/state': ^6.2.1 |  | ||||||
|       '@codemirror/view': ^6.17.1 |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/language': 6.10.3 |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       '@codemirror/view': 6.33.0 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /color-convert@1.9.3: |   /color-convert@1.9.3: | ||||||
|     resolution: {integrity: sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==} |     resolution: {integrity: sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==} | ||||||
|     dependencies: |     dependencies: | ||||||
| @ -4863,6 +4687,7 @@ packages: | |||||||
|     dependencies: |     dependencies: | ||||||
|       mdn-data: 2.0.30 |       mdn-data: 2.0.30 | ||||||
|       source-map-js: 1.0.2 |       source-map-js: 1.0.2 | ||||||
|  |     dev: true | ||||||
| 
 | 
 | ||||||
|   /css-what@6.1.0: |   /css-what@6.1.0: | ||||||
|     resolution: {integrity: sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==} |     resolution: {integrity: sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==} | ||||||
| @ -5046,11 +4871,6 @@ packages: | |||||||
|     engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} |     engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /diff-sequences@29.6.3: |  | ||||||
|     resolution: {integrity: sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==} |  | ||||||
|     engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /dijkstrajs@1.0.2: |   /dijkstrajs@1.0.2: | ||||||
|     resolution: {integrity: sha512-QV6PMaHTCNmKSeP6QoXhVTw9snc9VD8MulTT0Bd99Pacp4SS1cjcrYPgBPmibqKVtMJJfqC6XvOXgPMEEPH/fg==} |     resolution: {integrity: sha512-QV6PMaHTCNmKSeP6QoXhVTw9snc9VD8MulTT0Bd99Pacp4SS1cjcrYPgBPmibqKVtMJJfqC6XvOXgPMEEPH/fg==} | ||||||
|     dev: false |     dev: false | ||||||
| @ -5162,7 +4982,7 @@ packages: | |||||||
|   /email-normalizer@1.0.0: |   /email-normalizer@1.0.0: | ||||||
|     resolution: {integrity: sha512-wZYuuMtL4kUOmg/TPtCrf9hAZjbFq+FcjWA85Z5nr2lGllRnWJPxCJw3gy4Cx+adMoyVw4VJfGGvt/OHgIW+qg==} |     resolution: {integrity: sha512-wZYuuMtL4kUOmg/TPtCrf9hAZjbFq+FcjWA85Z5nr2lGllRnWJPxCJw3gy4Cx+adMoyVw4VJfGGvt/OHgIW+qg==} | ||||||
|     dependencies: |     dependencies: | ||||||
|       typescript: 5.6.2 |       typescript: 5.5.4 | ||||||
|     dev: false |     dev: false | ||||||
| 
 | 
 | ||||||
|   /emitter-component@1.1.1: |   /emitter-component@1.1.1: | ||||||
| @ -5702,12 +5522,6 @@ packages: | |||||||
|   /estree-walker@2.0.2: |   /estree-walker@2.0.2: | ||||||
|     resolution: {integrity: sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==} |     resolution: {integrity: sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==} | ||||||
| 
 | 
 | ||||||
|   /estree-walker@3.0.3: |  | ||||||
|     resolution: {integrity: sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==} |  | ||||||
|     dependencies: |  | ||||||
|       '@types/estree': 1.0.6 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /esutils@2.0.3: |   /esutils@2.0.3: | ||||||
|     resolution: {integrity: sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==} |     resolution: {integrity: sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==} | ||||||
|     engines: {node: '>=0.10.0'} |     engines: {node: '>=0.10.0'} | ||||||
| @ -5783,9 +5597,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==} |     resolution: {integrity: sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /fast-uri@3.0.1: |  | ||||||
|     resolution: {integrity: sha512-MWipKbbYiYI0UC7cl8m/i/IWTqfC8YXsqjzybjddLsFjStroQzsHXkc73JutMvBiXmOvapk+axIl79ig5t55Bw==} |  | ||||||
| 
 |  | ||||||
|   /fastq@1.15.0: |   /fastq@1.15.0: | ||||||
|     resolution: {integrity: sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==} |     resolution: {integrity: sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==} | ||||||
|     dependencies: |     dependencies: | ||||||
| @ -6328,14 +6139,6 @@ packages: | |||||||
|     dev: true |     dev: true | ||||||
|     optional: true |     optional: true | ||||||
| 
 | 
 | ||||||
|   /immutable-json-patch@6.0.1: |  | ||||||
|     resolution: {integrity: sha512-BHL/cXMjwFZlTOffiWNdY8ZTvNyYLrutCnWxrcKPHr5FqpAb6vsO6WWSPnVSys3+DruFN6lhHJJPHi8uELQL5g==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /immutable@4.3.7: |  | ||||||
|     resolution: {integrity: sha512-1hqclzwYwjRDFLjcFxOM5AYkkG0rpFPpr1RLPMEuGczoS7YA8gLhy8SWXYRAA/XwfEHpfo3cw5JGioS32fnMRw==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /import-fresh@3.3.0: |   /import-fresh@3.3.0: | ||||||
|     resolution: {integrity: sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==} |     resolution: {integrity: sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==} | ||||||
|     engines: {node: '>=6'} |     engines: {node: '>=6'} | ||||||
| @ -6569,12 +6372,6 @@ packages: | |||||||
|     engines: {node: '>=0.10.0'} |     engines: {node: '>=0.10.0'} | ||||||
|     dev: false |     dev: false | ||||||
| 
 | 
 | ||||||
|   /is-reference@3.0.2: |  | ||||||
|     resolution: {integrity: sha512-v3rht/LgVcsdZa3O2Nqs+NMowLOxeOm7Ay9+/ARQ2F+qEoANRcqrjAZKGN0v8ymUetZGgkp26LTnGT7H0Qo9Pg==} |  | ||||||
|     dependencies: |  | ||||||
|       '@types/estree': 1.0.6 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /is-regex@1.1.4: |   /is-regex@1.1.4: | ||||||
|     resolution: {integrity: sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==} |     resolution: {integrity: sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==} | ||||||
|     engines: {node: '>= 0.4'} |     engines: {node: '>= 0.4'} | ||||||
| @ -6690,11 +6487,6 @@ packages: | |||||||
|     hasBin: true |     hasBin: true | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /jmespath@0.16.0: |  | ||||||
|     resolution: {integrity: sha512-9FzQjJ7MATs1tSpnco1K6ayiYE3figslrXA72G2HQ/n76RzvYlofyi5QM+iX4YRs/pu3yzxlVQSST23+dMDknw==} |  | ||||||
|     engines: {node: '>= 0.6.0'} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /js-base64@3.7.7: |   /js-base64@3.7.7: | ||||||
|     resolution: {integrity: sha512-7rCnleh0z2CkXhH67J8K1Ytz0b2Y+yxTPL+/KOJoa20hfnVQ/3/T6W/KflYI4bRHRagNeXeU2bkNGI3v1oS/lw==} |     resolution: {integrity: sha512-7rCnleh0z2CkXhH67J8K1Ytz0b2Y+yxTPL+/KOJoa20hfnVQ/3/T6W/KflYI4bRHRagNeXeU2bkNGI3v1oS/lw==} | ||||||
|     dev: false |     dev: false | ||||||
| @ -6788,23 +6580,6 @@ packages: | |||||||
|     hasBin: true |     hasBin: true | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /json-editor-vue@0.16.0(@lezer/common@1.2.1)(vue@3.3.4): |  | ||||||
|     resolution: {integrity: sha512-8axbIR1DD6cf/AAXDkEYkPHDbWzEQDP762j2GiX3fFnHmE5+RzkcCFV2J/TGr6Mlw9sdZpQVMPHtt+7qYJ8Xyg==} |  | ||||||
|     requiresBuild: true |  | ||||||
|     peerDependencies: |  | ||||||
|       '@vue/composition-api': '>=1' |  | ||||||
|       vue: 2||3 |  | ||||||
|     peerDependenciesMeta: |  | ||||||
|       '@vue/composition-api': |  | ||||||
|         optional: true |  | ||||||
|     dependencies: |  | ||||||
|       vanilla-jsoneditor: 0.23.8(@lezer/common@1.2.1) |  | ||||||
|       vue: 3.3.4 |  | ||||||
|       vue-demi: 0.14.10(vue@3.3.4) |  | ||||||
|     transitivePeerDependencies: |  | ||||||
|       - '@lezer/common' |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /json-parse-even-better-errors@2.3.1: |   /json-parse-even-better-errors@2.3.1: | ||||||
|     resolution: {integrity: sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==} |     resolution: {integrity: sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==} | ||||||
|     dev: true |     dev: true | ||||||
| @ -6815,15 +6590,12 @@ packages: | |||||||
| 
 | 
 | ||||||
|   /json-schema-traverse@1.0.0: |   /json-schema-traverse@1.0.0: | ||||||
|     resolution: {integrity: sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==} |     resolution: {integrity: sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==} | ||||||
|  |     dev: true | ||||||
| 
 | 
 | ||||||
|   /json-schema@0.4.0: |   /json-schema@0.4.0: | ||||||
|     resolution: {integrity: sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA==} |     resolution: {integrity: sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA==} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /json-source-map@0.6.1: |  | ||||||
|     resolution: {integrity: sha512-1QoztHPsMQqhDq0hlXY5ZqcEdUzxQEIxgFkKl4WUp2pgShObl+9ovi4kRh2TfvAfxAoHOJ9vIMEqk3k4iex7tg==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /json-stable-stringify-without-jsonify@1.0.1: |   /json-stable-stringify-without-jsonify@1.0.1: | ||||||
|     resolution: {integrity: sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==} |     resolution: {integrity: sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==} | ||||||
|     dev: true |     dev: true | ||||||
| @ -6858,11 +6630,6 @@ packages: | |||||||
|     engines: {node: '>=0.10.0'} |     engines: {node: '>=0.10.0'} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /jsonrepair@3.8.1: |  | ||||||
|     resolution: {integrity: sha512-5wnjaO53EJOhfLFY92nvBz2B9gqF9ql/D4HKUb1WOSBaqtVcAifFfmurblnhCJn/ySqKFA8U3n7nhGMAu/hEjQ==} |  | ||||||
|     hasBin: true |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /jwt-decode@3.1.2: |   /jwt-decode@3.1.2: | ||||||
|     resolution: {integrity: sha512-UfpWE/VZn0iP50d8cz9NrZLM9lSWhcJ+0Gt/nm4by88UL+J1SiKN8/5dkjMmbEzwL2CAe+67GsegCbIKtbp75A==} |     resolution: {integrity: sha512-UfpWE/VZn0iP50d8cz9NrZLM9lSWhcJ+0Gt/nm4by88UL+J1SiKN8/5dkjMmbEzwL2CAe+67GsegCbIKtbp75A==} | ||||||
|     dev: false |     dev: false | ||||||
| @ -6925,10 +6692,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==} |     resolution: {integrity: sha512-SFppqq5p42fe2qcZQqqEOiVRXl+WCP1MdT6k7BDEW1j++sp5fIY+/fdRQitvKgB5BrBcmrs5m/L0v2FrU5MY1g==} | ||||||
|     engines: {node: '>=14'} |     engines: {node: '>=14'} | ||||||
| 
 | 
 | ||||||
|   /locate-character@3.0.0: |  | ||||||
|     resolution: {integrity: sha512-SW13ws7BjaeJ6p7Q6CO2nchbYEc3X3J6WrmTTDto7yMPqVSZTUyY5Tjbid+Ab8gLnATtygYtiDIJGQRRn2ZOiA==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /locate-path@5.0.0: |   /locate-path@5.0.0: | ||||||
|     resolution: {integrity: sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==} |     resolution: {integrity: sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==} | ||||||
|     engines: {node: '>=8'} |     engines: {node: '>=8'} | ||||||
| @ -7032,6 +6795,7 @@ packages: | |||||||
|     engines: {node: '>=12'} |     engines: {node: '>=12'} | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@jridgewell/sourcemap-codec': 1.4.15 |       '@jridgewell/sourcemap-codec': 1.4.15 | ||||||
|  |     dev: true | ||||||
| 
 | 
 | ||||||
|   /make-dir@2.1.0: |   /make-dir@2.1.0: | ||||||
|     resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==} |     resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==} | ||||||
| @ -7104,14 +6868,11 @@ packages: | |||||||
| 
 | 
 | ||||||
|   /mdn-data@2.0.30: |   /mdn-data@2.0.30: | ||||||
|     resolution: {integrity: sha512-GaqWWShW4kv/G9IEucWScBx9G1/vsFZZJUO+tD26M8J8z3Kw5RDQjaoZe03YAClgeS/SWPOcb4nkFBTEi5DUEA==} |     resolution: {integrity: sha512-GaqWWShW4kv/G9IEucWScBx9G1/vsFZZJUO+tD26M8J8z3Kw5RDQjaoZe03YAClgeS/SWPOcb4nkFBTEi5DUEA==} | ||||||
|  |     dev: true | ||||||
| 
 | 
 | ||||||
|   /mdurl@1.0.1: |   /mdurl@1.0.1: | ||||||
|     resolution: {integrity: sha512-/sKlQJCBYVY9Ers9hqzKou4H6V5UWc/M59TH2dvkt+84itfnq7uFOMLpOiOS4ujvHP4etln18fmIxA5R5fll0g==} |     resolution: {integrity: sha512-/sKlQJCBYVY9Ers9hqzKou4H6V5UWc/M59TH2dvkt+84itfnq7uFOMLpOiOS4ujvHP4etln18fmIxA5R5fll0g==} | ||||||
| 
 | 
 | ||||||
|   /memoize-one@6.0.0: |  | ||||||
|     resolution: {integrity: sha512-rkpe71W0N0c0Xz6QD0eJETuWAJGnJ9afsl1srmwPrI+yBCkge5EycXXbYRyvL29zZVUWQCY7InPRCv3GDXuZNw==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /merge-stream@2.0.0: |   /merge-stream@2.0.0: | ||||||
|     resolution: {integrity: sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==} |     resolution: {integrity: sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==} | ||||||
|     dev: true |     dev: true | ||||||
| @ -7256,10 +7017,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==} |     resolution: {integrity: sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==} | ||||||
|     engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} |     engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} | ||||||
| 
 | 
 | ||||||
|   /natural-compare-lite@1.4.0: |  | ||||||
|     resolution: {integrity: sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /natural-compare@1.4.0: |   /natural-compare@1.4.0: | ||||||
|     resolution: {integrity: sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==} |     resolution: {integrity: sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==} | ||||||
|     dev: true |     dev: true | ||||||
| @ -7632,14 +7389,6 @@ packages: | |||||||
|     resolution: {integrity: sha512-xCy9V055GLEqoFaHoC1SoLIaLmWctgCUaBaWxDZ7/Zx4CTyX7cJQLJOok/orfjZAh9kEYpjJa4d0KcJmCbctZA==} |     resolution: {integrity: sha512-xCy9V055GLEqoFaHoC1SoLIaLmWctgCUaBaWxDZ7/Zx4CTyX7cJQLJOok/orfjZAh9kEYpjJa4d0KcJmCbctZA==} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /periscopic@3.1.0: |  | ||||||
|     resolution: {integrity: sha512-vKiQ8RRtkl9P+r/+oefh25C3fhybptkHKCZSPlcXiJux2tJF55GnEj3BVn4A5gKfq9NWWXXrxkHBwVPUfH0opw==} |  | ||||||
|     dependencies: |  | ||||||
|       '@types/estree': 1.0.6 |  | ||||||
|       estree-walker: 3.0.3 |  | ||||||
|       is-reference: 3.0.2 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /picocolors@1.0.0: |   /picocolors@1.0.0: | ||||||
|     resolution: {integrity: sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==} |     resolution: {integrity: sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==} | ||||||
| 
 | 
 | ||||||
| @ -8016,11 +7765,6 @@ packages: | |||||||
|     dependencies: |     dependencies: | ||||||
|       picomatch: 2.3.1 |       picomatch: 2.3.1 | ||||||
| 
 | 
 | ||||||
|   /readdirp@4.0.1: |  | ||||||
|     resolution: {integrity: sha512-GkMg9uOTpIWWKbSsgwb5fA4EavTR+SG/PMPoAY8hkhHfEEY0/vqljY+XHqtDf2cr2IJtoNRDbrrEpZUiZCkYRw==} |  | ||||||
|     engines: {node: '>= 14.16.0'} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /regenerate-unicode-properties@10.1.1: |   /regenerate-unicode-properties@10.1.1: | ||||||
|     resolution: {integrity: sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q==} |     resolution: {integrity: sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q==} | ||||||
|     engines: {node: '>=4'} |     engines: {node: '>=4'} | ||||||
| @ -8089,6 +7833,7 @@ packages: | |||||||
|   /require-from-string@2.0.2: |   /require-from-string@2.0.2: | ||||||
|     resolution: {integrity: sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==} |     resolution: {integrity: sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==} | ||||||
|     engines: {node: '>=0.10.0'} |     engines: {node: '>=0.10.0'} | ||||||
|  |     dev: true | ||||||
| 
 | 
 | ||||||
|   /require-main-filename@2.0.0: |   /require-main-filename@2.0.0: | ||||||
|     resolution: {integrity: sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==} |     resolution: {integrity: sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==} | ||||||
| @ -8223,16 +7968,6 @@ packages: | |||||||
|     requiresBuild: true |     requiresBuild: true | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /sass@1.79.3: |  | ||||||
|     resolution: {integrity: sha512-m7dZxh0W9EZ3cw50Me5GOuYm/tVAJAn91SUnohLRo9cXBixGUOdvmryN+dXpwR831bhoY3Zv7rEFt85PUwTmzA==} |  | ||||||
|     engines: {node: '>=14.0.0'} |  | ||||||
|     hasBin: true |  | ||||||
|     dependencies: |  | ||||||
|       chokidar: 4.0.1 |  | ||||||
|       immutable: 4.3.7 |  | ||||||
|       source-map-js: 1.0.2 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /sax@1.2.4: |   /sax@1.2.4: | ||||||
|     resolution: {integrity: sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==} |     resolution: {integrity: sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==} | ||||||
|     requiresBuild: true |     requiresBuild: true | ||||||
| @ -8595,10 +8330,6 @@ packages: | |||||||
|     dependencies: |     dependencies: | ||||||
|       acorn: 8.11.2 |       acorn: 8.11.2 | ||||||
| 
 | 
 | ||||||
|   /style-mod@4.1.2: |  | ||||||
|     resolution: {integrity: sha512-wnD1HyVqpJUI2+eKZ+eo1UwghftP6yuFheBqqe+bWCotBjC2K1YnteJILRMs3SM4V/0dLEW1SC27MWP5y+mwmw==} |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /supports-color@5.5.0: |   /supports-color@5.5.0: | ||||||
|     resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} |     resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} | ||||||
|     engines: {node: '>=4'} |     engines: {node: '>=4'} | ||||||
| @ -8617,26 +8348,6 @@ packages: | |||||||
|     engines: {node: '>= 0.4'} |     engines: {node: '>= 0.4'} | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /svelte@4.2.19: |  | ||||||
|     resolution: {integrity: sha512-IY1rnGr6izd10B0A8LqsBfmlT5OILVuZ7XsI0vdGPEvuonFV7NYEUK4dAkm9Zg2q0Um92kYjTpS1CAP3Nh/KWw==} |  | ||||||
|     engines: {node: '>=16'} |  | ||||||
|     dependencies: |  | ||||||
|       '@ampproject/remapping': 2.2.1 |  | ||||||
|       '@jridgewell/sourcemap-codec': 1.4.15 |  | ||||||
|       '@jridgewell/trace-mapping': 0.3.20 |  | ||||||
|       '@types/estree': 1.0.6 |  | ||||||
|       acorn: 8.11.2 |  | ||||||
|       aria-query: 5.3.2 |  | ||||||
|       axobject-query: 4.1.0 |  | ||||||
|       code-red: 1.0.4 |  | ||||||
|       css-tree: 2.3.1 |  | ||||||
|       estree-walker: 3.0.3 |  | ||||||
|       is-reference: 3.0.2 |  | ||||||
|       locate-character: 3.0.0 |  | ||||||
|       magic-string: 0.30.5 |  | ||||||
|       periscopic: 3.1.0 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /svg-tags@1.0.0: |   /svg-tags@1.0.0: | ||||||
|     resolution: {integrity: sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==} |     resolution: {integrity: sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==} | ||||||
|     dev: true |     dev: true | ||||||
| @ -8902,8 +8613,8 @@ packages: | |||||||
|     engines: {node: '>=14.17'} |     engines: {node: '>=14.17'} | ||||||
|     hasBin: true |     hasBin: true | ||||||
| 
 | 
 | ||||||
|   /typescript@5.6.2: |   /typescript@5.5.4: | ||||||
|     resolution: {integrity: sha512-NW8ByodCSNCwZeghjN3o+JX5OFH0Ojg6sadjEKY4huZ52TqbJTJnDo5+Tw98lSy63NZvi4n+ez5m2u5d4PkZyw==} |     resolution: {integrity: sha512-Mtq29sKDAEYP7aljRgtPOpTvOfbwRWlS6dPRzwjdE+C0R4brX/GUyhHSecbHMFLNBLcJIPt9nl9yG5TZ1weH+Q==} | ||||||
|     engines: {node: '>=14.17'} |     engines: {node: '>=14.17'} | ||||||
|     hasBin: true |     hasBin: true | ||||||
|     dev: false |     dev: false | ||||||
| @ -9249,44 +8960,6 @@ packages: | |||||||
|       spdx-expression-parse: 3.0.1 |       spdx-expression-parse: 3.0.1 | ||||||
|     dev: true |     dev: true | ||||||
| 
 | 
 | ||||||
|   /vanilla-jsoneditor@0.23.8(@lezer/common@1.2.1): |  | ||||||
|     resolution: {integrity: sha512-ly5wmhnICxYhLunBVKbe0jEkPLjDeEGWPV1Lpt7HzzsPCFOmpIs05Go2XgXErmID2nWRp2s5DkT2hBVE4B+rmA==} |  | ||||||
|     dependencies: |  | ||||||
|       '@codemirror/autocomplete': 6.18.1(@codemirror/language@6.10.3)(@codemirror/state@6.4.1)(@codemirror/view@6.33.0)(@lezer/common@1.2.1) |  | ||||||
|       '@codemirror/commands': 6.6.2 |  | ||||||
|       '@codemirror/lang-json': 6.0.1 |  | ||||||
|       '@codemirror/language': 6.10.3 |  | ||||||
|       '@codemirror/lint': 6.8.1 |  | ||||||
|       '@codemirror/search': 6.5.6 |  | ||||||
|       '@codemirror/state': 6.4.1 |  | ||||||
|       '@codemirror/view': 6.33.0 |  | ||||||
|       '@fortawesome/free-regular-svg-icons': 6.6.0 |  | ||||||
|       '@fortawesome/free-solid-svg-icons': 6.6.0 |  | ||||||
|       '@lezer/highlight': 1.2.1 |  | ||||||
|       '@replit/codemirror-indentation-markers': 6.5.3(@codemirror/language@6.10.3)(@codemirror/state@6.4.1)(@codemirror/view@6.33.0) |  | ||||||
|       ajv: 8.17.1 |  | ||||||
|       codemirror-wrapped-line-indent: 1.0.8(@codemirror/language@6.10.3)(@codemirror/state@6.4.1)(@codemirror/view@6.33.0) |  | ||||||
|       diff-sequences: 29.6.3 |  | ||||||
|       immutable-json-patch: 6.0.1 |  | ||||||
|       jmespath: 0.16.0 |  | ||||||
|       json-source-map: 0.6.1 |  | ||||||
|       jsonrepair: 3.8.1 |  | ||||||
|       lodash-es: 4.17.21 |  | ||||||
|       memoize-one: 6.0.0 |  | ||||||
|       natural-compare-lite: 1.4.0 |  | ||||||
|       sass: 1.79.3 |  | ||||||
|       svelte: 4.2.19 |  | ||||||
|       vanilla-picker: 2.12.3 |  | ||||||
|     transitivePeerDependencies: |  | ||||||
|       - '@lezer/common' |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /vanilla-picker@2.12.3: |  | ||||||
|     resolution: {integrity: sha512-qVkT1E7yMbUsB2mmJNFmaXMWE2hF8ffqzMMwe9zdAikd8u2VfnsVY2HQcOUi2F38bgbxzlJBEdS1UUhOXdF9GQ==} |  | ||||||
|     dependencies: |  | ||||||
|       '@sphinxxxx/color-conversion': 2.2.2 |  | ||||||
|     dev: false |  | ||||||
| 
 |  | ||||||
|   /vdirs@0.1.8(vue@3.3.4): |   /vdirs@0.1.8(vue@3.3.4): | ||||||
|     resolution: {integrity: sha512-H9V1zGRLQZg9b+GdMk8MXDN2Lva0zx72MPahDKc30v+DtwKjfyOSXWRIX4t2mhDubM1H09gPhWeth/BJWPHGUw==} |     resolution: {integrity: sha512-H9V1zGRLQZg9b+GdMk8MXDN2Lva0zx72MPahDKc30v+DtwKjfyOSXWRIX4t2mhDubM1H09gPhWeth/BJWPHGUw==} | ||||||
|     peerDependencies: |     peerDependencies: | ||||||
| @ -9731,7 +9404,7 @@ packages: | |||||||
|     resolution: {integrity: sha512-CttE7WCYW9sZC+nUYhQg3WzzGPr4IHmrPnjKiu3AMXsiNQKx+l4hHl63WTrnicLmKEKHScWDH8xsGBdrYgtBzg==} |     resolution: {integrity: sha512-CttE7WCYW9sZC+nUYhQg3WzzGPr4IHmrPnjKiu3AMXsiNQKx+l4hHl63WTrnicLmKEKHScWDH8xsGBdrYgtBzg==} | ||||||
|     engines: {node: '>=16.0.0'} |     engines: {node: '>=16.0.0'} | ||||||
|     dependencies: |     dependencies: | ||||||
|       '@apideck/better-ajv-errors': 0.3.6(ajv@8.17.1) |       '@apideck/better-ajv-errors': 0.3.6(ajv@8.12.0) | ||||||
|       '@babel/core': 7.23.2 |       '@babel/core': 7.23.2 | ||||||
|       '@babel/preset-env': 7.23.2(@babel/core@7.23.2) |       '@babel/preset-env': 7.23.2(@babel/core@7.23.2) | ||||||
|       '@babel/runtime': 7.23.2 |       '@babel/runtime': 7.23.2 | ||||||
| @ -9739,7 +9412,7 @@ packages: | |||||||
|       '@rollup/plugin-node-resolve': 11.2.1(rollup@2.79.1) |       '@rollup/plugin-node-resolve': 11.2.1(rollup@2.79.1) | ||||||
|       '@rollup/plugin-replace': 2.4.2(rollup@2.79.1) |       '@rollup/plugin-replace': 2.4.2(rollup@2.79.1) | ||||||
|       '@surma/rollup-plugin-off-main-thread': 2.2.3 |       '@surma/rollup-plugin-off-main-thread': 2.2.3 | ||||||
|       ajv: 8.17.1 |       ajv: 8.12.0 | ||||||
|       common-tags: 1.8.2 |       common-tags: 1.8.2 | ||||||
|       fast-json-stable-stringify: 2.1.0 |       fast-json-stable-stringify: 2.1.0 | ||||||
|       fs-extra: 9.1.0 |       fs-extra: 9.1.0 | ||||||
|  | |||||||
| @ -48,7 +48,7 @@ const output = computed(() => transformer.value(input.value)); | |||||||
|     monospace |     monospace | ||||||
|   /> |   /> | ||||||
| 
 | 
 | ||||||
|   <div> |   <div overflow-auto> | ||||||
|     <div mb-5px> |     <div mb-5px> | ||||||
|       {{ outputLabel }} |       {{ outputLabel }} | ||||||
|     </div> |     </div> | ||||||
|  | |||||||
							
								
								
									
										21
									
								
								src/composable/debouncedref.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								src/composable/debouncedref.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | import _ from 'lodash'; | ||||||
|  | 
 | ||||||
|  | function useDebouncedRef<T>(initialValue: T, delay: number, immediate: boolean = false) { | ||||||
|  |   const state = ref(initialValue); | ||||||
|  |   const debouncedRef = customRef((track, trigger) => ({ | ||||||
|  |     get() { | ||||||
|  |       track(); | ||||||
|  |       return state.value; | ||||||
|  |     }, | ||||||
|  |     set: _.debounce( | ||||||
|  |       (value) => { | ||||||
|  |         state.value = value; | ||||||
|  |         trigger(); | ||||||
|  |       }, | ||||||
|  |       delay, | ||||||
|  |       { leading: immediate }, | ||||||
|  |     ), | ||||||
|  |   })); | ||||||
|  |   return debouncedRef; | ||||||
|  | } | ||||||
|  | export default useDebouncedRef; | ||||||
| @ -1,8 +1,13 @@ | |||||||
| import { extension as getExtensionFromMime } from 'mime-types'; | import { extension as getExtensionFromMimeType, extension as getMimeTypeFromExtension } from 'mime-types'; | ||||||
| import type { Ref } from 'vue'; | import type { Ref } from 'vue'; | ||||||
| import _ from 'lodash'; | import _ from 'lodash'; | ||||||
| 
 | 
 | ||||||
| export { getMimeTypeFromBase64, useDownloadFileFromBase64 }; | export { | ||||||
|  |   getMimeTypeFromBase64, | ||||||
|  |   getMimeTypeFromExtension, getExtensionFromMimeType, | ||||||
|  |   useDownloadFileFromBase64, useDownloadFileFromBase64Refs, | ||||||
|  |   previewImageFromBase64, | ||||||
|  | }; | ||||||
| 
 | 
 | ||||||
| const commonMimeTypesSignatures = { | const commonMimeTypesSignatures = { | ||||||
|   'JVBERi0': 'application/pdf', |   'JVBERi0': 'application/pdf', | ||||||
| @ -36,30 +41,78 @@ function getFileExtensionFromMimeType({ | |||||||
|   defaultExtension?: string |   defaultExtension?: string | ||||||
| }) { | }) { | ||||||
|   if (mimeType) { |   if (mimeType) { | ||||||
|     return getExtensionFromMime(mimeType) ?? defaultExtension; |     return getExtensionFromMimeType(mimeType) ?? defaultExtension; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   return defaultExtension; |   return defaultExtension; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| function useDownloadFileFromBase64({ source, filename }: { source: Ref<string>; filename?: string }) { | function downloadFromBase64({ sourceValue, filename, extension, fileMimeType }: | ||||||
|  | { sourceValue: string; filename?: string; extension?: string; fileMimeType?: string }) { | ||||||
|  |   if (sourceValue === '') { | ||||||
|  |     throw new Error('Base64 string is empty'); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   const defaultExtension = extension ?? 'txt'; | ||||||
|  |   const { mimeType } = getMimeTypeFromBase64({ base64String: sourceValue }); | ||||||
|  |   let base64String = sourceValue; | ||||||
|  |   if (!mimeType) { | ||||||
|  |     const targetMimeType = fileMimeType ?? getMimeTypeFromExtension(defaultExtension); | ||||||
|  |     base64String = `data:${targetMimeType};base64,${sourceValue}`; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   const cleanExtension = extension ?? getFileExtensionFromMimeType( | ||||||
|  |     { mimeType, defaultExtension }); | ||||||
|  |   let cleanFileName = filename ?? `file.${cleanExtension}`; | ||||||
|  |   if (extension && !cleanFileName.endsWith(`.${extension}`)) { | ||||||
|  |     cleanFileName = `${cleanFileName}.${cleanExtension}`; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   const a = document.createElement('a'); | ||||||
|  |   a.href = base64String; | ||||||
|  |   a.download = cleanFileName; | ||||||
|  |   a.click(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function useDownloadFileFromBase64( | ||||||
|  |   { source, filename, extension, fileMimeType }: | ||||||
|  |   { source: Ref<string>; filename?: string; extension?: string; fileMimeType?: string }) { | ||||||
|   return { |   return { | ||||||
|     download() { |     download() { | ||||||
|       if (source.value === '') { |       downloadFromBase64({ sourceValue: source.value, filename, extension, fileMimeType }); | ||||||
|         throw new Error('Base64 string is empty'); |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
|       const { mimeType } = getMimeTypeFromBase64({ base64String: source.value }); |  | ||||||
|       const base64String = mimeType |  | ||||||
|         ? source.value |  | ||||||
|         : `data:text/plain;base64,${source.value}`; |  | ||||||
| 
 |  | ||||||
|       const cleanFileName = filename ?? `file.${getFileExtensionFromMimeType({ mimeType })}`; |  | ||||||
| 
 |  | ||||||
|       const a = document.createElement('a'); |  | ||||||
|       a.href = base64String; |  | ||||||
|       a.download = cleanFileName; |  | ||||||
|       a.click(); |  | ||||||
|     }, |     }, | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | function useDownloadFileFromBase64Refs( | ||||||
|  |   { source, filename, extension }: | ||||||
|  |   { source: Ref<string>; filename?: Ref<string>; extension?: Ref<string> }) { | ||||||
|  |   return { | ||||||
|  |     download() { | ||||||
|  |       downloadFromBase64({ sourceValue: source.value, filename: filename?.value, extension: extension?.value }); | ||||||
|  |     }, | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | function previewImageFromBase64(base64String: string): HTMLImageElement { | ||||||
|  |   if (base64String === '') { | ||||||
|  |     throw new Error('Base64 string is empty'); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   const img = document.createElement('img'); | ||||||
|  |   img.src = base64String; | ||||||
|  | 
 | ||||||
|  |   const container = document.createElement('div'); | ||||||
|  |   container.appendChild(img); | ||||||
|  | 
 | ||||||
|  |   const previewContainer = document.getElementById('previewContainer'); | ||||||
|  |   if (previewContainer) { | ||||||
|  |     previewContainer.innerHTML = ''; | ||||||
|  |     previewContainer.appendChild(container); | ||||||
|  |   } | ||||||
|  |   else { | ||||||
|  |     throw new Error('Preview container element not found'); | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return img; | ||||||
|  | } | ||||||
|  | |||||||
| @ -2,12 +2,19 @@ | |||||||
| import { useBase64 } from '@vueuse/core'; | import { useBase64 } from '@vueuse/core'; | ||||||
| import type { Ref } from 'vue'; | import type { Ref } from 'vue'; | ||||||
| import { useCopy } from '@/composable/copy'; | import { useCopy } from '@/composable/copy'; | ||||||
| import { useDownloadFileFromBase64 } from '@/composable/downloadBase64'; | import { getExtensionFromMimeType, getMimeTypeFromBase64, previewImageFromBase64, useDownloadFileFromBase64Refs } from '@/composable/downloadBase64'; | ||||||
| import { useValidation } from '@/composable/validation'; | import { useValidation } from '@/composable/validation'; | ||||||
| import { isValidBase64 } from '@/utils/base64'; | import { isValidBase64 } from '@/utils/base64'; | ||||||
| 
 | 
 | ||||||
|  | const fileName = ref('file'); | ||||||
|  | const fileExtension = ref(''); | ||||||
| const base64Input = ref(''); | const base64Input = ref(''); | ||||||
| const { download } = useDownloadFileFromBase64({ source: base64Input }); | const { download } = useDownloadFileFromBase64Refs( | ||||||
|  |   { | ||||||
|  |     source: base64Input, | ||||||
|  |     filename: fileName, | ||||||
|  |     extension: fileExtension, | ||||||
|  |   }); | ||||||
| const base64InputValidation = useValidation({ | const base64InputValidation = useValidation({ | ||||||
|   source: base64Input, |   source: base64Input, | ||||||
|   rules: [ |   rules: [ | ||||||
| @ -18,6 +25,35 @@ const base64InputValidation = useValidation({ | |||||||
|   ], |   ], | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | watch( | ||||||
|  |   base64Input, | ||||||
|  |   (newValue, _) => { | ||||||
|  |     const { mimeType } = getMimeTypeFromBase64({ base64String: newValue }); | ||||||
|  |     if (mimeType) { | ||||||
|  |       fileExtension.value = getExtensionFromMimeType(mimeType) || fileExtension.value; | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  | ); | ||||||
|  | 
 | ||||||
|  | function previewImage() { | ||||||
|  |   if (!base64InputValidation.isValid) { | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   try { | ||||||
|  |     const image = previewImageFromBase64(base64Input.value); | ||||||
|  |     image.style.maxWidth = '100%'; | ||||||
|  |     image.style.maxHeight = '400px'; | ||||||
|  |     const previewContainer = document.getElementById('previewContainer'); | ||||||
|  |     if (previewContainer) { | ||||||
|  |       previewContainer.innerHTML = ''; | ||||||
|  |       previewContainer.appendChild(image); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   catch (_) { | ||||||
|  |     // | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| function downloadFile() { | function downloadFile() { | ||||||
|   if (!base64InputValidation.isValid) { |   if (!base64InputValidation.isValid) { | ||||||
|     return; |     return; | ||||||
| @ -44,6 +80,24 @@ async function onUpload(file: File) { | |||||||
| 
 | 
 | ||||||
| <template> | <template> | ||||||
|   <c-card title="Base64 to file"> |   <c-card title="Base64 to file"> | ||||||
|  |     <n-grid cols="3" x-gap="12"> | ||||||
|  |       <n-gi span="2"> | ||||||
|  |         <c-input-text | ||||||
|  |           v-model:value="fileName" | ||||||
|  |           label="File Name" | ||||||
|  |           placeholder="Download filename" | ||||||
|  |           mb-2 | ||||||
|  |         /> | ||||||
|  |       </n-gi> | ||||||
|  |       <n-gi> | ||||||
|  |         <c-input-text | ||||||
|  |           v-model:value="fileExtension" | ||||||
|  |           label="Extension" | ||||||
|  |           placeholder="Extension" | ||||||
|  |           mb-2 | ||||||
|  |         /> | ||||||
|  |       </n-gi> | ||||||
|  |     </n-grid> | ||||||
|     <c-input-text |     <c-input-text | ||||||
|       v-model:value="base64Input" |       v-model:value="base64Input" | ||||||
|       multiline |       multiline | ||||||
| @ -53,7 +107,14 @@ async function onUpload(file: File) { | |||||||
|       mb-2 |       mb-2 | ||||||
|     /> |     /> | ||||||
| 
 | 
 | ||||||
|     <div flex justify-center> |     <div flex justify-center py-2> | ||||||
|  |       <div id="previewContainer" /> | ||||||
|  |     </div> | ||||||
|  | 
 | ||||||
|  |     <div flex justify-center gap-3> | ||||||
|  |       <c-button :disabled="base64Input === '' || !base64InputValidation.isValid" @click="previewImage()"> | ||||||
|  |         Preview image | ||||||
|  |       </c-button> | ||||||
|       <c-button :disabled="base64Input === '' || !base64InputValidation.isValid" @click="downloadFile()"> |       <c-button :disabled="base64Input === '' || !base64InputValidation.isValid" @click="downloadFile()"> | ||||||
|         Download file |         Download file | ||||||
|       </c-button> |       </c-button> | ||||||
|  | |||||||
							
								
								
									
										65
									
								
								src/tools/email-normalizer/email-normalizer.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/tools/email-normalizer/email-normalizer.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,65 @@ | |||||||
|  | <script setup lang="ts"> | ||||||
|  | import { normalizeEmail } from 'email-normalizer'; | ||||||
|  | import { withDefaultOnError } from '@/utils/defaults'; | ||||||
|  | import { useCopy } from '@/composable/copy'; | ||||||
|  | 
 | ||||||
|  | const emails = ref(''); | ||||||
|  | const normalizedEmails = computed(() => { | ||||||
|  |   if (!emails.value) { | ||||||
|  |     return ''; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   return emails.value | ||||||
|  |     .split('\n') | ||||||
|  |     .map((email) => { | ||||||
|  |       return withDefaultOnError(() => normalizeEmail({ email }), `Unable to parse email: ${email}`); | ||||||
|  |     }) | ||||||
|  |     .join('\n'); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | const { copy } = useCopy({ source: normalizedEmails, text: 'Normalized emails copied to the clipboard', createToast: true }); | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <div> | ||||||
|  |     <div class="mb-2"> | ||||||
|  |       Raw emails to normalize: | ||||||
|  |     </div> | ||||||
|  |     <c-input-text | ||||||
|  |       v-model:value="emails" | ||||||
|  |       placeholder="Put your emails here (one per line)..." | ||||||
|  |       rows="3" | ||||||
|  |       multiline | ||||||
|  |       autocomplete="off" | ||||||
|  |       autocorrect="off" | ||||||
|  |       autocapitalize="off" | ||||||
|  |       spellcheck="false" | ||||||
|  |       autofocus | ||||||
|  |       monospace | ||||||
|  |     /> | ||||||
|  | 
 | ||||||
|  |     <div class="mb-2 mt-4"> | ||||||
|  |       Normalized emails: | ||||||
|  |     </div> | ||||||
|  |     <c-input-text | ||||||
|  |       :value="normalizedEmails" | ||||||
|  |       placeholder="Normalized emails will appear here..." | ||||||
|  |       rows="3" | ||||||
|  |       autocomplete="off" | ||||||
|  |       autocorrect="off" | ||||||
|  |       autocapitalize="off" | ||||||
|  |       spellcheck="false" | ||||||
|  |       multiline | ||||||
|  |       readonly | ||||||
|  |       monospace | ||||||
|  |     /> | ||||||
|  |     <div class="mt-4 flex justify-center gap-2"> | ||||||
|  |       <c-button @click="emails = ''"> | ||||||
|  |         Clear emails | ||||||
|  |       </c-button> | ||||||
|  |       <c-button :disabled="!normalizedEmails" @click="copy()"> | ||||||
|  |         Copy normalized emails | ||||||
|  |       </c-button> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </template> | ||||||
							
								
								
									
										12
									
								
								src/tools/email-normalizer/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/tools/email-normalizer/index.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | |||||||
|  | import { Mail } from '@vicons/tabler'; | ||||||
|  | import { defineTool } from '../tool'; | ||||||
|  | 
 | ||||||
|  | export const tool = defineTool({ | ||||||
|  |   name: 'Email normalizer', | ||||||
|  |   path: '/email-normalizer', | ||||||
|  |   description: 'Normalize email addresses to a standard format for easier comparison. Useful for deduplication and data cleaning.', | ||||||
|  |   keywords: ['email', 'normalizer'], | ||||||
|  |   component: () => import('./email-normalizer.vue'), | ||||||
|  |   icon: Mail, | ||||||
|  |   createdAt: new Date('2024-08-15'), | ||||||
|  | }); | ||||||
| @ -4,6 +4,7 @@ import emojiKeywords from 'emojilib'; | |||||||
| import _ from 'lodash'; | import _ from 'lodash'; | ||||||
| import type { EmojiInfo } from './emoji.types'; | import type { EmojiInfo } from './emoji.types'; | ||||||
| import { useFuzzySearch } from '@/composable/fuzzySearch'; | import { useFuzzySearch } from '@/composable/fuzzySearch'; | ||||||
|  | import useDebouncedRef from '@/composable/debouncedref'; | ||||||
| 
 | 
 | ||||||
| const escapeUnicode = ({ emoji }: { emoji: string }) => emoji.split('').map(unit => `\\u${unit.charCodeAt(0).toString(16).padStart(4, '0')}`).join(''); | const escapeUnicode = ({ emoji }: { emoji: string }) => emoji.split('').map(unit => `\\u${unit.charCodeAt(0).toString(16).padStart(4, '0')}`).join(''); | ||||||
| const getEmojiCodePoints = ({ emoji }: { emoji: string }) => emoji.codePointAt(0) ? `0x${emoji.codePointAt(0)?.toString(16)}` : undefined; | const getEmojiCodePoints = ({ emoji }: { emoji: string }) => emoji.codePointAt(0) ? `0x${emoji.codePointAt(0)?.toString(16)}` : undefined; | ||||||
| @ -23,7 +24,7 @@ const emojisGroups: { emojiInfos: EmojiInfo[]; group: string }[] = _ | |||||||
|   .map((emojiInfos, group) => ({ group, emojiInfos })) |   .map((emojiInfos, group) => ({ group, emojiInfos })) | ||||||
|   .value(); |   .value(); | ||||||
| 
 | 
 | ||||||
| const searchQuery = ref(''); | const searchQuery = useDebouncedRef('', 500); | ||||||
| 
 | 
 | ||||||
| const { searchResult } = useFuzzySearch({ | const { searchResult } = useFuzzySearch({ | ||||||
|   search: searchQuery, |   search: searchQuery, | ||||||
|  | |||||||
| @ -2,11 +2,14 @@ import { tool as base64FileConverter } from './base64-file-converter'; | |||||||
| import { tool as base64StringConverter } from './base64-string-converter'; | import { tool as base64StringConverter } from './base64-string-converter'; | ||||||
| import { tool as basicAuthGenerator } from './basic-auth-generator'; | import { tool as basicAuthGenerator } from './basic-auth-generator'; | ||||||
| import { tool as jsonEditor } from './json-editor'; | import { tool as jsonEditor } from './json-editor'; | ||||||
|  | import { tool as emailNormalizer } from './email-normalizer'; | ||||||
| 
 | 
 | ||||||
| import { tool as asciiTextDrawer } from './ascii-text-drawer'; | import { tool as asciiTextDrawer } from './ascii-text-drawer'; | ||||||
| 
 | 
 | ||||||
| import { tool as textToUnicode } from './text-to-unicode'; | import { tool as textToUnicode } from './text-to-unicode'; | ||||||
| import { tool as safelinkDecoder } from './safelink-decoder'; | import { tool as safelinkDecoder } from './safelink-decoder'; | ||||||
|  | import { tool as xmlToJson } from './xml-to-json'; | ||||||
|  | import { tool as jsonToXml } from './json-to-xml'; | ||||||
| import { tool as pdfSignatureChecker } from './pdf-signature-checker'; | import { tool as pdfSignatureChecker } from './pdf-signature-checker'; | ||||||
| import { tool as numeronymGenerator } from './numeronym-generator'; | import { tool as numeronymGenerator } from './numeronym-generator'; | ||||||
| import { tool as macAddressGenerator } from './mac-address-generator'; | import { tool as macAddressGenerator } from './mac-address-generator'; | ||||||
| @ -108,6 +111,8 @@ export const toolsByCategory: ToolCategory[] = [ | |||||||
|       listConverter, |       listConverter, | ||||||
|       tomlToJson, |       tomlToJson, | ||||||
|       tomlToYaml, |       tomlToYaml, | ||||||
|  |       xmlToJson, | ||||||
|  |       jsonToXml, | ||||||
|     ], |     ], | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
| @ -150,6 +155,7 @@ export const toolsByCategory: ToolCategory[] = [ | |||||||
|       xmlFormatter, |       xmlFormatter, | ||||||
|       yamlViewer, |       yamlViewer, | ||||||
|       jsonEditor, |       jsonEditor, | ||||||
|  |       emailNormalizer, | ||||||
|     ], |     ], | ||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|  | |||||||
							
								
								
									
										12
									
								
								src/tools/json-to-xml/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/tools/json-to-xml/index.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | |||||||
|  | import { Braces } from '@vicons/tabler'; | ||||||
|  | import { defineTool } from '../tool'; | ||||||
|  | 
 | ||||||
|  | export const tool = defineTool({ | ||||||
|  |   name: 'JSON to XML', | ||||||
|  |   path: '/json-to-xml', | ||||||
|  |   description: 'Convert JSON to XML', | ||||||
|  |   keywords: ['json', 'xml'], | ||||||
|  |   component: () => import('./json-to-xml.vue'), | ||||||
|  |   icon: Braces, | ||||||
|  |   createdAt: new Date('2024-08-09'), | ||||||
|  | }); | ||||||
							
								
								
									
										32
									
								
								src/tools/json-to-xml/json-to-xml.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/tools/json-to-xml/json-to-xml.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,32 @@ | |||||||
|  | <script setup lang="ts"> | ||||||
|  | import convert from 'xml-js'; | ||||||
|  | import JSON5 from 'json5'; | ||||||
|  | import { withDefaultOnError } from '@/utils/defaults'; | ||||||
|  | import type { UseValidationRule } from '@/composable/validation'; | ||||||
|  | 
 | ||||||
|  | const defaultValue = '{"a":{"_attributes":{"x":"1.234","y":"It\'s"}}}'; | ||||||
|  | function transformer(value: string) { | ||||||
|  |   return withDefaultOnError(() => { | ||||||
|  |     return convert.js2xml(JSON5.parse(value), { compact: true }); | ||||||
|  |   }, ''); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const rules: UseValidationRule<string>[] = [ | ||||||
|  |   { | ||||||
|  |     validator: (v: string) => v === '' || JSON5.parse(v), | ||||||
|  |     message: 'Provided JSON is not valid.', | ||||||
|  |   }, | ||||||
|  | ]; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <format-transformer | ||||||
|  |     input-label="Your JSON content" | ||||||
|  |     :input-default="defaultValue" | ||||||
|  |     input-placeholder="Paste your JSON content here..." | ||||||
|  |     output-label="Converted XML" | ||||||
|  |     output-language="xml" | ||||||
|  |     :transformer="transformer" | ||||||
|  |     :input-validation-rules="rules" | ||||||
|  |   /> | ||||||
|  | </template> | ||||||
| @ -39,7 +39,7 @@ const validation = useValidation({ | |||||||
|             {{ section.title }} |             {{ section.title }} | ||||||
|           </th> |           </th> | ||||||
|           <tr v-for="{ claim, claimDescription, friendlyValue, value } in decodedJWT[section.key]" :key="claim + value"> |           <tr v-for="{ claim, claimDescription, friendlyValue, value } in decodedJWT[section.key]" :key="claim + value"> | ||||||
|             <td class="claims"> |             <td class="claims" style="vertical-align: top;"> | ||||||
|               <span font-bold> |               <span font-bold> | ||||||
|                 {{ claim }} |                 {{ claim }} | ||||||
|               </span> |               </span> | ||||||
| @ -47,7 +47,7 @@ const validation = useValidation({ | |||||||
|                 ({{ claimDescription }}) |                 ({{ claimDescription }}) | ||||||
|               </span> |               </span> | ||||||
|             </td> |             </td> | ||||||
|             <td> |             <td style="word-wrap: break-word;word-break: break-all;"> | ||||||
|               <span>{{ value }}</span> |               <span>{{ value }}</span> | ||||||
|               <span v-if="friendlyValue" ml-2 op-70> |               <span v-if="friendlyValue" ml-2 op-70> | ||||||
|                 ({{ friendlyValue }}) |                 ({{ friendlyValue }}) | ||||||
|  | |||||||
| @ -2,6 +2,7 @@ | |||||||
| import { generateLoremIpsum } from './lorem-ipsum-generator.service'; | import { generateLoremIpsum } from './lorem-ipsum-generator.service'; | ||||||
| import { useCopy } from '@/composable/copy'; | import { useCopy } from '@/composable/copy'; | ||||||
| import { randIntFromInterval } from '@/utils/random'; | import { randIntFromInterval } from '@/utils/random'; | ||||||
|  | import { computedRefreshable } from '@/composable/computedRefreshable'; | ||||||
| 
 | 
 | ||||||
| const paragraphs = ref(1); | const paragraphs = ref(1); | ||||||
| const sentences = ref([3, 8]); | const sentences = ref([3, 8]); | ||||||
| @ -9,7 +10,7 @@ const words = ref([8, 15]); | |||||||
| const startWithLoremIpsum = ref(true); | const startWithLoremIpsum = ref(true); | ||||||
| const asHTML = ref(false); | const asHTML = ref(false); | ||||||
| 
 | 
 | ||||||
| const loremIpsumText = computed(() => | const [loremIpsumText, refreshLoremIpsum] = computedRefreshable(() => | ||||||
|   generateLoremIpsum({ |   generateLoremIpsum({ | ||||||
|     paragraphCount: paragraphs.value, |     paragraphCount: paragraphs.value, | ||||||
|     asHTML: asHTML.value, |     asHTML: asHTML.value, | ||||||
| @ -18,6 +19,7 @@ const loremIpsumText = computed(() => | |||||||
|     startWithLoremIpsum: startWithLoremIpsum.value, |     startWithLoremIpsum: startWithLoremIpsum.value, | ||||||
|   }), |   }), | ||||||
| ); | ); | ||||||
|  | 
 | ||||||
| const { copy } = useCopy({ source: loremIpsumText, text: 'Lorem ipsum copied to the clipboard' }); | const { copy } = useCopy({ source: loremIpsumText, text: 'Lorem ipsum copied to the clipboard' }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| @ -41,10 +43,13 @@ const { copy } = useCopy({ source: loremIpsumText, text: 'Lorem ipsum copied to | |||||||
| 
 | 
 | ||||||
|     <c-input-text :value="loremIpsumText" multiline placeholder="Your lorem ipsum..." readonly mt-5 rows="5" /> |     <c-input-text :value="loremIpsumText" multiline placeholder="Your lorem ipsum..." readonly mt-5 rows="5" /> | ||||||
| 
 | 
 | ||||||
|     <div mt-5 flex justify-center> |     <div mt-5 flex justify-center gap-3> | ||||||
|       <c-button autofocus @click="copy()"> |       <c-button autofocus @click="copy()"> | ||||||
|         Copy |         Copy | ||||||
|       </c-button> |       </c-button> | ||||||
|  |       <c-button @click="refreshLoremIpsum"> | ||||||
|  |         Refresh | ||||||
|  |       </c-button> | ||||||
|     </div> |     </div> | ||||||
|   </c-card> |   </c-card> | ||||||
| </template> | </template> | ||||||
|  | |||||||
							
								
								
									
										12
									
								
								src/tools/xml-to-json/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/tools/xml-to-json/index.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | |||||||
|  | import { Braces } from '@vicons/tabler'; | ||||||
|  | import { defineTool } from '../tool'; | ||||||
|  | 
 | ||||||
|  | export const tool = defineTool({ | ||||||
|  |   name: 'XML to JSON', | ||||||
|  |   path: '/xml-to-json', | ||||||
|  |   description: 'Convert XML to JSON', | ||||||
|  |   keywords: ['xml', 'json'], | ||||||
|  |   component: () => import('./xml-to-json.vue'), | ||||||
|  |   icon: Braces, | ||||||
|  |   createdAt: new Date('2024-08-09'), | ||||||
|  | }); | ||||||
							
								
								
									
										32
									
								
								src/tools/xml-to-json/xml-to-json.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/tools/xml-to-json/xml-to-json.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,32 @@ | |||||||
|  | <script setup lang="ts"> | ||||||
|  | import convert from 'xml-js'; | ||||||
|  | import { isValidXML } from '../xml-formatter/xml-formatter.service'; | ||||||
|  | import { withDefaultOnError } from '@/utils/defaults'; | ||||||
|  | import type { UseValidationRule } from '@/composable/validation'; | ||||||
|  | 
 | ||||||
|  | const defaultValue = '<a x="1.234" y="It\'s"/>'; | ||||||
|  | function transformer(value: string) { | ||||||
|  |   return withDefaultOnError(() => { | ||||||
|  |     return JSON.stringify(convert.xml2js(value, { compact: true }), null, 2); | ||||||
|  |   }, ''); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const rules: UseValidationRule<string>[] = [ | ||||||
|  |   { | ||||||
|  |     validator: isValidXML, | ||||||
|  |     message: 'Provided XML is not valid.', | ||||||
|  |   }, | ||||||
|  | ]; | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <template> | ||||||
|  |   <format-transformer | ||||||
|  |     input-label="Your XML content" | ||||||
|  |     :input-default="defaultValue" | ||||||
|  |     input-placeholder="Paste your XML content here..." | ||||||
|  |     output-label="Converted JSON" | ||||||
|  |     output-language="json" | ||||||
|  |     :transformer="transformer" | ||||||
|  |     :input-validation-rules="rules" | ||||||
|  |   /> | ||||||
|  | </template> | ||||||
| @ -38,7 +38,8 @@ describe('base64 utils', () => { | |||||||
| 
 | 
 | ||||||
|     it('should throw for incorrect base64 string', () => { |     it('should throw for incorrect base64 string', () => { | ||||||
|       expect(() => base64ToText('a')).to.throw('Incorrect base64 string'); |       expect(() => base64ToText('a')).to.throw('Incorrect base64 string'); | ||||||
|       expect(() => base64ToText(' ')).to.throw('Incorrect base64 string'); |       // should not really be false because trimming of space is now implied
 | ||||||
|  |       // expect(() => base64ToText(' ')).to.throw('Incorrect base64 string');
 | ||||||
|       expect(() => base64ToText('é')).to.throw('Incorrect base64 string'); |       expect(() => base64ToText('é')).to.throw('Incorrect base64 string'); | ||||||
|       // missing final '='
 |       // missing final '='
 | ||||||
|       expect(() => base64ToText('bG9yZW0gaXBzdW0')).to.throw('Incorrect base64 string'); |       expect(() => base64ToText('bG9yZW0gaXBzdW0')).to.throw('Incorrect base64 string'); | ||||||
| @ -56,17 +57,17 @@ describe('base64 utils', () => { | |||||||
| 
 | 
 | ||||||
|     it('should return false for incorrect base64 string', () => { |     it('should return false for incorrect base64 string', () => { | ||||||
|       expect(isValidBase64('a')).to.eql(false); |       expect(isValidBase64('a')).to.eql(false); | ||||||
|       expect(isValidBase64(' ')).to.eql(false); |  | ||||||
|       expect(isValidBase64('é')).to.eql(false); |       expect(isValidBase64('é')).to.eql(false); | ||||||
|       expect(isValidBase64('data:text/plain;notbase64,YQ==')).to.eql(false); |       expect(isValidBase64('data:text/plain;notbase64,YQ==')).to.eql(false); | ||||||
|       // missing final '='
 |       // missing final '='
 | ||||||
|       expect(isValidBase64('bG9yZW0gaXBzdW0')).to.eql(false); |       expect(isValidBase64('bG9yZW0gaXBzdW0')).to.eql(false); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     it('should return false for untrimmed correct base64 string', () => { |     it('should return true for untrimmed correct base64 string', () => { | ||||||
|       expect(isValidBase64('bG9yZW0gaXBzdW0= ')).to.eql(false); |       expect(isValidBase64('bG9yZW0gaXBzdW0= ')).to.eql(true); | ||||||
|       expect(isValidBase64(' LTE=')).to.eql(false); |       expect(isValidBase64(' LTE=')).to.eql(true); | ||||||
|       expect(isValidBase64(' YQ== ')).to.eql(false); |       expect(isValidBase64(' YQ== ')).to.eql(true); | ||||||
|  |       expect(isValidBase64(' ')).to.eql(true); | ||||||
|     }); |     }); | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,7 +1,9 @@ | |||||||
|  | import { Base64 } from 'js-base64'; | ||||||
|  | 
 | ||||||
| export { textToBase64, base64ToText, isValidBase64, removePotentialDataAndMimePrefix }; | export { textToBase64, base64ToText, isValidBase64, removePotentialDataAndMimePrefix }; | ||||||
| 
 | 
 | ||||||
| function textToBase64(str: string, { makeUrlSafe = false }: { makeUrlSafe?: boolean } = {}) { | function textToBase64(str: string, { makeUrlSafe = false }: { makeUrlSafe?: boolean } = {}) { | ||||||
|   const encoded = window.btoa(str); |   const encoded = Base64.encode(str); | ||||||
|   return makeUrlSafe ? makeUriSafe(encoded) : encoded; |   return makeUrlSafe ? makeUriSafe(encoded) : encoded; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -16,7 +18,7 @@ function base64ToText(str: string, { makeUrlSafe = false }: { makeUrlSafe?: bool | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   try { |   try { | ||||||
|     return window.atob(cleanStr); |     return Base64.decode(cleanStr); | ||||||
|   } |   } | ||||||
|   catch (_) { |   catch (_) { | ||||||
|     throw new Error('Incorrect base64 string'); |     throw new Error('Incorrect base64 string'); | ||||||
| @ -34,10 +36,11 @@ function isValidBase64(str: string, { makeUrlSafe = false }: { makeUrlSafe?: boo | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   try { |   try { | ||||||
|  |     const reEncodedBase64 = Base64.fromUint8Array(Base64.toUint8Array(cleanStr)); | ||||||
|     if (makeUrlSafe) { |     if (makeUrlSafe) { | ||||||
|       return removePotentialPadding(window.btoa(window.atob(cleanStr))) === cleanStr; |       return removePotentialPadding(reEncodedBase64) === cleanStr; | ||||||
|     } |     } | ||||||
|     return window.btoa(window.atob(cleanStr)) === cleanStr; |     return reEncodedBase64 === cleanStr.replace(/\s/g, ''); | ||||||
|   } |   } | ||||||
|   catch (err) { |   catch (err) { | ||||||
|     return false; |     return false; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user