mirror of
https://github.com/iib0011/omni-tools.git
synced 2025-11-05 03:54:04 +01:00
Merge pull request #171 from AshAnand34/xml-tools
feat(xml): add XML tools for validation, beautification, and viewing
This commit is contained in:
31
package-lock.json
generated
31
package-lock.json
generated
@@ -29,6 +29,7 @@
|
|||||||
"cron-validator": "^1.3.1",
|
"cron-validator": "^1.3.1",
|
||||||
"cronstrue": "^3.0.0",
|
"cronstrue": "^3.0.0",
|
||||||
"dayjs": "^1.11.13",
|
"dayjs": "^1.11.13",
|
||||||
|
"fast-xml-parser": "^5.2.5",
|
||||||
"formik": "^2.4.6",
|
"formik": "^2.4.6",
|
||||||
"jimp": "^0.22.12",
|
"jimp": "^0.22.12",
|
||||||
"js-quantities": "^1.8.0",
|
"js-quantities": "^1.8.0",
|
||||||
@@ -5893,6 +5894,24 @@
|
|||||||
"integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
|
"integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"node_modules/fast-xml-parser": {
|
||||||
|
"version": "5.2.5",
|
||||||
|
"resolved": "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-5.2.5.tgz",
|
||||||
|
"integrity": "sha512-pfX9uG9Ki0yekDHx2SiuRIyFdyAr1kMIMitPvb0YBo8SUfKvia7w7FIyd/l6av85pFYRhZscS75MwMnbvY+hcQ==",
|
||||||
|
"funding": [
|
||||||
|
{
|
||||||
|
"type": "github",
|
||||||
|
"url": "https://github.com/sponsors/NaturalIntelligence"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"license": "MIT",
|
||||||
|
"dependencies": {
|
||||||
|
"strnum": "^2.1.0"
|
||||||
|
},
|
||||||
|
"bin": {
|
||||||
|
"fxparser": "src/cli/cli.js"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/fastq": {
|
"node_modules/fastq": {
|
||||||
"version": "1.17.1",
|
"version": "1.17.1",
|
||||||
"resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz",
|
"resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz",
|
||||||
@@ -10502,6 +10521,18 @@
|
|||||||
"integrity": "sha512-WriZw1luRMlmV3LGJaR6QOJjWwgLUTf89OwT2lUOyjX2dJGBwgmIkbcz+7WFZjrZM635JOIR517++e/67CP9dQ==",
|
"integrity": "sha512-WriZw1luRMlmV3LGJaR6QOJjWwgLUTf89OwT2lUOyjX2dJGBwgmIkbcz+7WFZjrZM635JOIR517++e/67CP9dQ==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"node_modules/strnum": {
|
||||||
|
"version": "2.1.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/strnum/-/strnum-2.1.1.tgz",
|
||||||
|
"integrity": "sha512-7ZvoFTiCnGxBtDqJ//Cu6fWtZtc7Y3x+QOirG15wztbdngGSkht27o2pyGWrVy0b4WAy3jbKmnoK6g5VlVNUUw==",
|
||||||
|
"funding": [
|
||||||
|
{
|
||||||
|
"type": "github",
|
||||||
|
"url": "https://github.com/sponsors/NaturalIntelligence"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"license": "MIT"
|
||||||
|
},
|
||||||
"node_modules/strtok3": {
|
"node_modules/strtok3": {
|
||||||
"version": "6.3.0",
|
"version": "6.3.0",
|
||||||
"resolved": "https://registry.npmjs.org/strtok3/-/strtok3-6.3.0.tgz",
|
"resolved": "https://registry.npmjs.org/strtok3/-/strtok3-6.3.0.tgz",
|
||||||
|
|||||||
@@ -46,6 +46,7 @@
|
|||||||
"cron-validator": "^1.3.1",
|
"cron-validator": "^1.3.1",
|
||||||
"cronstrue": "^3.0.0",
|
"cronstrue": "^3.0.0",
|
||||||
"dayjs": "^1.11.13",
|
"dayjs": "^1.11.13",
|
||||||
|
"fast-xml-parser": "^5.2.5",
|
||||||
"formik": "^2.4.6",
|
"formik": "^2.4.6",
|
||||||
"jimp": "^0.22.12",
|
"jimp": "^0.22.12",
|
||||||
"js-quantities": "^1.8.0",
|
"js-quantities": "^1.8.0",
|
||||||
|
|||||||
4
src/pages/tools/xml/index.ts
Normal file
4
src/pages/tools/xml/index.ts
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
import { tool as xmlXmlValidator } from './xml-validator/meta';
|
||||||
|
import { tool as xmlXmlBeautifier } from './xml-beautifier/meta';
|
||||||
|
import { tool as xmlXmlViewer } from './xml-viewer/meta';
|
||||||
|
export const xmlTools = [xmlXmlViewer, xmlXmlBeautifier, xmlXmlValidator];
|
||||||
54
src/pages/tools/xml/xml-beautifier/index.tsx
Normal file
54
src/pages/tools/xml/xml-beautifier/index.tsx
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
import { Box } from '@mui/material';
|
||||||
|
import React, { useState } from 'react';
|
||||||
|
import ToolContent from '@components/ToolContent';
|
||||||
|
import { ToolComponentProps } from '@tools/defineTool';
|
||||||
|
import ToolTextInput from '@components/input/ToolTextInput';
|
||||||
|
import ToolTextResult from '@components/result/ToolTextResult';
|
||||||
|
import { CardExampleType } from '@components/examples/ToolExamples';
|
||||||
|
import { beautifyXml } from './service';
|
||||||
|
import { InitialValuesType } from './types';
|
||||||
|
|
||||||
|
const initialValues: InitialValuesType = {};
|
||||||
|
|
||||||
|
const exampleCards: CardExampleType<InitialValuesType>[] = [
|
||||||
|
{
|
||||||
|
title: 'Beautify XML',
|
||||||
|
description: 'Beautify a compact XML string for readability.',
|
||||||
|
sampleText: '<root><item>1</item><item>2</item></root>',
|
||||||
|
sampleResult: `<root>\n <item>1</item>\n <item>2</item>\n</root>`,
|
||||||
|
sampleOptions: {}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
export default function XmlBeautifier({
|
||||||
|
title,
|
||||||
|
longDescription
|
||||||
|
}: ToolComponentProps) {
|
||||||
|
const [input, setInput] = useState<string>('');
|
||||||
|
const [result, setResult] = useState<string>('');
|
||||||
|
|
||||||
|
const compute = (_values: InitialValuesType, input: string) => {
|
||||||
|
setResult(beautifyXml(input, {}));
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<ToolContent
|
||||||
|
title={title}
|
||||||
|
input={input}
|
||||||
|
inputComponent={
|
||||||
|
<ToolTextInput
|
||||||
|
value={input}
|
||||||
|
onChange={setInput}
|
||||||
|
placeholder="Paste or import XML here..."
|
||||||
|
/>
|
||||||
|
}
|
||||||
|
resultComponent={<ToolTextResult value={result} extension="xml" />}
|
||||||
|
initialValues={initialValues}
|
||||||
|
exampleCards={exampleCards}
|
||||||
|
getGroups={null}
|
||||||
|
setInput={setInput}
|
||||||
|
compute={compute}
|
||||||
|
toolInfo={{ title: `What is a ${title}?`, description: longDescription }}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
13
src/pages/tools/xml/xml-beautifier/meta.ts
Normal file
13
src/pages/tools/xml/xml-beautifier/meta.ts
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
import { defineTool } from '@tools/defineTool';
|
||||||
|
import { lazy } from 'react';
|
||||||
|
|
||||||
|
export const tool = defineTool('xml', {
|
||||||
|
name: 'XML Beautifier',
|
||||||
|
path: 'xml-beautifier',
|
||||||
|
icon: 'mdi:format-align-left',
|
||||||
|
description:
|
||||||
|
'Beautify and reformat XML for improved readability and structure.',
|
||||||
|
shortDescription: 'Beautify XML for readability.',
|
||||||
|
keywords: ['xml', 'beautify', 'format', 'pretty', 'indent'],
|
||||||
|
component: lazy(() => import('./index'))
|
||||||
|
});
|
||||||
23
src/pages/tools/xml/xml-beautifier/service.ts
Normal file
23
src/pages/tools/xml/xml-beautifier/service.ts
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
import { InitialValuesType } from './types';
|
||||||
|
import { XMLParser, XMLBuilder, XMLValidator } from 'fast-xml-parser';
|
||||||
|
|
||||||
|
export function beautifyXml(
|
||||||
|
input: string,
|
||||||
|
_options: InitialValuesType
|
||||||
|
): string {
|
||||||
|
const valid = XMLValidator.validate(input);
|
||||||
|
if (valid !== true) {
|
||||||
|
if (typeof valid === 'object' && valid.err) {
|
||||||
|
return `Invalid XML: ${valid.err.msg} (line ${valid.err.line}, col ${valid.err.col})`;
|
||||||
|
}
|
||||||
|
return 'Invalid XML';
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
const parser = new XMLParser();
|
||||||
|
const obj = parser.parse(input);
|
||||||
|
const builder = new XMLBuilder({ format: true, indentBy: ' ' });
|
||||||
|
return builder.build(obj);
|
||||||
|
} catch (e: any) {
|
||||||
|
return `Invalid XML: ${e.message}`;
|
||||||
|
}
|
||||||
|
}
|
||||||
3
src/pages/tools/xml/xml-beautifier/types.ts
Normal file
3
src/pages/tools/xml/xml-beautifier/types.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
export type InitialValuesType = {
|
||||||
|
// splitSeparator: string;
|
||||||
|
};
|
||||||
@@ -0,0 +1,18 @@
|
|||||||
|
import { expect, describe, it } from 'vitest';
|
||||||
|
import { beautifyXml } from './service';
|
||||||
|
|
||||||
|
describe('xml-beautifier', () => {
|
||||||
|
it('beautifies valid XML', () => {
|
||||||
|
const input = '<root><a>1</a><b>2</b></root>';
|
||||||
|
const result = beautifyXml(input, {});
|
||||||
|
expect(result).toContain('<root>');
|
||||||
|
expect(result).toContain(' <a>1</a>');
|
||||||
|
expect(result).toContain(' <b>2</b>');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns error for invalid XML', () => {
|
||||||
|
const input = '<root><a>1</b></root>';
|
||||||
|
const result = beautifyXml(input, {});
|
||||||
|
expect(result).toMatch(/Invalid XML/i);
|
||||||
|
});
|
||||||
|
});
|
||||||
61
src/pages/tools/xml/xml-validator/index.tsx
Normal file
61
src/pages/tools/xml/xml-validator/index.tsx
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
import { Box } from '@mui/material';
|
||||||
|
import React, { useState } from 'react';
|
||||||
|
import ToolContent from '@components/ToolContent';
|
||||||
|
import { ToolComponentProps } from '@tools/defineTool';
|
||||||
|
import ToolTextInput from '@components/input/ToolTextInput';
|
||||||
|
import ToolTextResult from '@components/result/ToolTextResult';
|
||||||
|
import { CardExampleType } from '@components/examples/ToolExamples';
|
||||||
|
import { validateXml } from './service';
|
||||||
|
import { InitialValuesType } from './types';
|
||||||
|
|
||||||
|
const initialValues: InitialValuesType = {};
|
||||||
|
|
||||||
|
const exampleCards: CardExampleType<InitialValuesType>[] = [
|
||||||
|
{
|
||||||
|
title: 'Validate XML',
|
||||||
|
description: 'Check if an XML string is well-formed.',
|
||||||
|
sampleText: '<root><item>1</item><item>2</item></root>',
|
||||||
|
sampleResult: 'Valid XML',
|
||||||
|
sampleOptions: {}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Invalid XML',
|
||||||
|
description: 'Example of malformed XML.',
|
||||||
|
sampleText: '<root><item>1</item><item>2</root>',
|
||||||
|
sampleResult: 'Invalid XML: ...',
|
||||||
|
sampleOptions: {}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
export default function XmlValidator({
|
||||||
|
title,
|
||||||
|
longDescription
|
||||||
|
}: ToolComponentProps) {
|
||||||
|
const [input, setInput] = useState<string>('');
|
||||||
|
const [result, setResult] = useState<string>('');
|
||||||
|
|
||||||
|
const compute = (_values: InitialValuesType, input: string) => {
|
||||||
|
setResult(validateXml(input, {}));
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<ToolContent
|
||||||
|
title={title}
|
||||||
|
input={input}
|
||||||
|
inputComponent={
|
||||||
|
<ToolTextInput
|
||||||
|
value={input}
|
||||||
|
onChange={setInput}
|
||||||
|
placeholder="Paste or import XML here..."
|
||||||
|
/>
|
||||||
|
}
|
||||||
|
resultComponent={<ToolTextResult value={result} extension="txt" />}
|
||||||
|
initialValues={initialValues}
|
||||||
|
exampleCards={exampleCards}
|
||||||
|
getGroups={null}
|
||||||
|
setInput={setInput}
|
||||||
|
compute={compute}
|
||||||
|
toolInfo={{ title: `What is a ${title}?`, description: longDescription }}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
13
src/pages/tools/xml/xml-validator/meta.ts
Normal file
13
src/pages/tools/xml/xml-validator/meta.ts
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
import { defineTool } from '@tools/defineTool';
|
||||||
|
import { lazy } from 'react';
|
||||||
|
|
||||||
|
export const tool = defineTool('xml', {
|
||||||
|
name: 'XML Validator',
|
||||||
|
path: 'xml-validator',
|
||||||
|
icon: 'mdi:check-decagram',
|
||||||
|
description:
|
||||||
|
'Validate XML files or strings to ensure they are well-formed and error-free.',
|
||||||
|
shortDescription: 'Validate XML for errors.',
|
||||||
|
keywords: ['xml', 'validate', 'check', 'syntax', 'error'],
|
||||||
|
component: lazy(() => import('./index'))
|
||||||
|
});
|
||||||
16
src/pages/tools/xml/xml-validator/service.ts
Normal file
16
src/pages/tools/xml/xml-validator/service.ts
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
import { InitialValuesType } from './types';
|
||||||
|
import { XMLValidator } from 'fast-xml-parser';
|
||||||
|
|
||||||
|
export function validateXml(
|
||||||
|
input: string,
|
||||||
|
_options: InitialValuesType
|
||||||
|
): string {
|
||||||
|
const result = XMLValidator.validate(input);
|
||||||
|
if (result === true) {
|
||||||
|
return 'Valid XML';
|
||||||
|
} else if (typeof result === 'object' && result.err) {
|
||||||
|
return `Invalid XML: ${result.err.msg} (line ${result.err.line}, col ${result.err.col})`;
|
||||||
|
} else {
|
||||||
|
return 'Invalid XML: Unknown error';
|
||||||
|
}
|
||||||
|
}
|
||||||
3
src/pages/tools/xml/xml-validator/types.ts
Normal file
3
src/pages/tools/xml/xml-validator/types.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
export type InitialValuesType = {
|
||||||
|
// splitSeparator: string;
|
||||||
|
};
|
||||||
@@ -0,0 +1,16 @@
|
|||||||
|
import { expect, describe, it } from 'vitest';
|
||||||
|
import { validateXml } from './service';
|
||||||
|
|
||||||
|
describe('xml-validator', () => {
|
||||||
|
it('returns Valid XML for well-formed XML', () => {
|
||||||
|
const input = '<root><a>1</a><b>2</b></root>';
|
||||||
|
const result = validateXml(input, {});
|
||||||
|
expect(result).toBe('Valid XML');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns error for invalid XML', () => {
|
||||||
|
const input = '<root><a>1</b></root>';
|
||||||
|
const result = validateXml(input, {});
|
||||||
|
expect(result).toMatch(/Invalid XML/i);
|
||||||
|
});
|
||||||
|
});
|
||||||
54
src/pages/tools/xml/xml-viewer/index.tsx
Normal file
54
src/pages/tools/xml/xml-viewer/index.tsx
Normal file
@@ -0,0 +1,54 @@
|
|||||||
|
import { Box } from '@mui/material';
|
||||||
|
import React, { useState } from 'react';
|
||||||
|
import ToolContent from '@components/ToolContent';
|
||||||
|
import { ToolComponentProps } from '@tools/defineTool';
|
||||||
|
import ToolTextInput from '@components/input/ToolTextInput';
|
||||||
|
import ToolTextResult from '@components/result/ToolTextResult';
|
||||||
|
import { CardExampleType } from '@components/examples/ToolExamples';
|
||||||
|
import { prettyPrintXml } from './service';
|
||||||
|
import { InitialValuesType } from './types';
|
||||||
|
|
||||||
|
const initialValues: InitialValuesType = {};
|
||||||
|
|
||||||
|
const exampleCards: CardExampleType<InitialValuesType>[] = [
|
||||||
|
{
|
||||||
|
title: 'Pretty Print XML',
|
||||||
|
description: 'View and pretty-print a compact XML string.',
|
||||||
|
sampleText: '<root><item>1</item><item>2</item></root>',
|
||||||
|
sampleResult: `<root>\n <item>1</item>\n <item>2</item>\n</root>`,
|
||||||
|
sampleOptions: {}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
export default function XmlViewer({
|
||||||
|
title,
|
||||||
|
longDescription
|
||||||
|
}: ToolComponentProps) {
|
||||||
|
const [input, setInput] = useState<string>('');
|
||||||
|
const [result, setResult] = useState<string>('');
|
||||||
|
|
||||||
|
const compute = (_values: InitialValuesType, input: string) => {
|
||||||
|
setResult(prettyPrintXml(input, {}));
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<ToolContent
|
||||||
|
title={title}
|
||||||
|
input={input}
|
||||||
|
inputComponent={
|
||||||
|
<ToolTextInput
|
||||||
|
value={input}
|
||||||
|
onChange={setInput}
|
||||||
|
placeholder="Paste or import XML here..."
|
||||||
|
/>
|
||||||
|
}
|
||||||
|
resultComponent={<ToolTextResult value={result} extension="xml" />}
|
||||||
|
initialValues={initialValues}
|
||||||
|
exampleCards={exampleCards}
|
||||||
|
getGroups={null}
|
||||||
|
setInput={setInput}
|
||||||
|
compute={compute}
|
||||||
|
toolInfo={{ title: `What is a ${title}?`, description: longDescription }}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
13
src/pages/tools/xml/xml-viewer/meta.ts
Normal file
13
src/pages/tools/xml/xml-viewer/meta.ts
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
import { defineTool } from '@tools/defineTool';
|
||||||
|
import { lazy } from 'react';
|
||||||
|
|
||||||
|
export const tool = defineTool('xml', {
|
||||||
|
name: 'XML Viewer',
|
||||||
|
path: 'xml-viewer',
|
||||||
|
icon: 'mdi:eye-outline',
|
||||||
|
description:
|
||||||
|
'View and pretty-print XML files or strings for easier reading and debugging.',
|
||||||
|
shortDescription: 'Pretty-print and view XML.',
|
||||||
|
keywords: ['xml', 'viewer', 'pretty print', 'format', 'inspect'],
|
||||||
|
component: lazy(() => import('./index'))
|
||||||
|
});
|
||||||
23
src/pages/tools/xml/xml-viewer/service.ts
Normal file
23
src/pages/tools/xml/xml-viewer/service.ts
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
import { InitialValuesType } from './types';
|
||||||
|
import { XMLParser, XMLBuilder, XMLValidator } from 'fast-xml-parser';
|
||||||
|
|
||||||
|
export function prettyPrintXml(
|
||||||
|
input: string,
|
||||||
|
_options: InitialValuesType
|
||||||
|
): string {
|
||||||
|
const valid = XMLValidator.validate(input);
|
||||||
|
if (valid !== true) {
|
||||||
|
if (typeof valid === 'object' && valid.err) {
|
||||||
|
return `Invalid XML: ${valid.err.msg} (line ${valid.err.line}, col ${valid.err.col})`;
|
||||||
|
}
|
||||||
|
return 'Invalid XML';
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
const parser = new XMLParser();
|
||||||
|
const obj = parser.parse(input);
|
||||||
|
const builder = new XMLBuilder({ format: true, indentBy: ' ' });
|
||||||
|
return builder.build(obj);
|
||||||
|
} catch (e: any) {
|
||||||
|
return `Invalid XML: ${e.message}`;
|
||||||
|
}
|
||||||
|
}
|
||||||
3
src/pages/tools/xml/xml-viewer/types.ts
Normal file
3
src/pages/tools/xml/xml-viewer/types.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
export type InitialValuesType = {
|
||||||
|
// splitSeparator: string;
|
||||||
|
};
|
||||||
18
src/pages/tools/xml/xml-viewer/xml-viewer.service.test.ts
Normal file
18
src/pages/tools/xml/xml-viewer/xml-viewer.service.test.ts
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
import { expect, describe, it } from 'vitest';
|
||||||
|
import { prettyPrintXml } from './service';
|
||||||
|
|
||||||
|
describe('xml-viewer', () => {
|
||||||
|
it('pretty prints valid XML', () => {
|
||||||
|
const input = '<root><a>1</a><b>2</b></root>';
|
||||||
|
const result = prettyPrintXml(input, {});
|
||||||
|
expect(result).toContain('<root>');
|
||||||
|
expect(result).toContain(' <a>1</a>');
|
||||||
|
expect(result).toContain(' <b>2</b>');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('returns error for invalid XML', () => {
|
||||||
|
const input = '<root><a>1</b></root>';
|
||||||
|
const result = prettyPrintXml(input, {});
|
||||||
|
expect(result).toMatch(/Invalid XML/i);
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -25,7 +25,8 @@ export type ToolCategory =
|
|||||||
| 'csv'
|
| 'csv'
|
||||||
| 'pdf'
|
| 'pdf'
|
||||||
| 'image-generic'
|
| 'image-generic'
|
||||||
| 'audio';
|
| 'audio'
|
||||||
|
| 'xml';
|
||||||
|
|
||||||
export interface DefinedTool {
|
export interface DefinedTool {
|
||||||
type: ToolCategory;
|
type: ToolCategory;
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ import { csvTools } from '../pages/tools/csv';
|
|||||||
import { timeTools } from '../pages/tools/time';
|
import { timeTools } from '../pages/tools/time';
|
||||||
import { IconifyIcon } from '@iconify/react';
|
import { IconifyIcon } from '@iconify/react';
|
||||||
import { pdfTools } from '../pages/tools/pdf';
|
import { pdfTools } from '../pages/tools/pdf';
|
||||||
|
import { xmlTools } from '../pages/tools/xml';
|
||||||
|
|
||||||
const toolCategoriesOrder: ToolCategory[] = [
|
const toolCategoriesOrder: ToolCategory[] = [
|
||||||
'image-generic',
|
'image-generic',
|
||||||
@@ -25,6 +26,8 @@ const toolCategoriesOrder: ToolCategory[] = [
|
|||||||
'csv',
|
'csv',
|
||||||
'number',
|
'number',
|
||||||
'png',
|
'png',
|
||||||
|
'time',
|
||||||
|
'xml',
|
||||||
'gif'
|
'gif'
|
||||||
];
|
];
|
||||||
export const tools: DefinedTool[] = [
|
export const tools: DefinedTool[] = [
|
||||||
@@ -37,7 +40,8 @@ export const tools: DefinedTool[] = [
|
|||||||
...videoTools,
|
...videoTools,
|
||||||
...numberTools,
|
...numberTools,
|
||||||
...timeTools,
|
...timeTools,
|
||||||
...audioTools
|
...audioTools,
|
||||||
|
...xmlTools
|
||||||
];
|
];
|
||||||
const categoriesConfig: {
|
const categoriesConfig: {
|
||||||
type: ToolCategory;
|
type: ToolCategory;
|
||||||
@@ -124,6 +128,12 @@ const categoriesConfig: {
|
|||||||
icon: 'ic:twotone-audiotrack',
|
icon: 'ic:twotone-audiotrack',
|
||||||
value:
|
value:
|
||||||
'Tools for working with audio – extract audio from video, adjusting audio speed, merging multiple audio files and much more.'
|
'Tools for working with audio – extract audio from video, adjusting audio speed, merging multiple audio files and much more.'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
type: 'xml',
|
||||||
|
icon: 'mdi-light:xml',
|
||||||
|
value:
|
||||||
|
'Tools for working with XML data structures - viewer, beautifier, validator and much more'
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
// use for changelogs
|
// use for changelogs
|
||||||
|
|||||||
Reference in New Issue
Block a user