Files
omni-tools/src/pages/number/sum/index.tsx

115 lines
3.8 KiB
TypeScript
Raw Normal View History

2024-06-26 07:47:17 +01:00
import { Box } from '@mui/material';
import React, { useState } from 'react';
2024-06-25 03:11:48 +01:00
import ToolTextInput from '../../../components/input/ToolTextInput';
import ToolTextResult from '../../../components/result/ToolTextResult';
import * as Yup from 'yup';
import ToolOptions from '../../../components/options/ToolOptions';
import { compute, NumberExtractionType } from './service';
import RadioWithTextField from '../../../components/options/RadioWithTextField';
import SimpleRadio from '../../../components/options/SimpleRadio';
import CheckboxWithDesc from '../../../components/options/CheckboxWithDesc';
2024-06-25 07:15:42 +01:00
import ToolInputAndResult from '../../../components/ToolInputAndResult';
2024-06-25 03:11:48 +01:00
const initialValues = {
extractionType: 'smart' as NumberExtractionType,
separator: '\\n',
printRunningSum: false
};
const extractionTypes: {
title: string;
description: string;
type: NumberExtractionType;
withTextField: boolean;
textValueAccessor?: keyof typeof initialValues;
}[] = [
{
title: 'Smart sum',
description: 'Auto detect numbers in the input.',
type: 'smart',
withTextField: false
},
{
title: 'Number Delimiter',
type: 'delimiter',
description:
'Input SeparatorCustomize the number separator here. (By default a line break.)',
withTextField: true,
textValueAccessor: 'separator'
}
];
export default function SplitText() {
const [input, setInput] = useState<string>('');
const [result, setResult] = useState<string>('');
return (
<Box>
2024-06-25 07:15:42 +01:00
<ToolInputAndResult
input={<ToolTextInput value={input} onChange={setInput} />}
result={<ToolTextResult title={'Total'} value={result} />}
/>
2024-06-26 07:47:17 +01:00
<ToolOptions
2024-06-27 21:52:41 +01:00
getGroups={({ values, updateField }) => [
2024-06-26 07:47:17 +01:00
{
title: 'Number extraction',
component: extractionTypes.map(
({
title,
description,
type,
withTextField,
textValueAccessor
}) =>
withTextField ? (
<RadioWithTextField
key={type}
2024-06-27 20:27:03 +01:00
checked={type === values.extractionType}
2024-06-26 07:47:17 +01:00
title={title}
fieldName={'extractionType'}
description={description}
value={
textValueAccessor
? values[textValueAccessor].toString()
: ''
}
2024-06-27 21:52:41 +01:00
onRadioClick={() => updateField('extractionType', type)}
2024-06-26 07:47:17 +01:00
onTextChange={(val) =>
textValueAccessor
2024-06-27 21:52:41 +01:00
? updateField(textValueAccessor, val)
2024-06-26 07:47:17 +01:00
: null
}
/>
) : (
<SimpleRadio
key={title}
2024-06-27 21:52:41 +01:00
onClick={() => updateField('extractionType', type)}
2024-06-27 20:27:03 +01:00
checked={values.extractionType === type}
2024-06-26 07:47:17 +01:00
description={description}
title={title}
/>
)
)
},
{
title: 'Running Sum',
component: (
<CheckboxWithDesc
title={'Print Running Sum'}
description={"Display the sum as it's calculated step by step."}
checked={values.printRunningSum}
2024-06-27 21:52:41 +01:00
onChange={(value) => updateField('printRunningSum', value)}
2024-06-25 03:11:48 +01:00
/>
2024-06-26 07:47:17 +01:00
)
}
]}
compute={(optionsValues, input) => {
const { extractionType, printRunningSum, separator } = optionsValues;
setResult(compute(input, extractionType, printRunningSum, separator));
}}
initialValues={initialValues}
input={input}
/>
2024-06-25 03:11:48 +01:00
</Box>
);
}