@thx/controls 16.3.1 → 17.0.0-mantine.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/date/LocalDatePicker/LocalDatePicker.js +11 -54
- package/dist/esm/date/LocalDatePicker/LocalDatePicker.js.map +1 -1
- package/dist/esm/date/LocalMonthSelect/LocalMonthSelect.js +19 -23
- package/dist/esm/date/LocalMonthSelect/LocalMonthSelect.js.map +1 -1
- package/dist/esm/date/LocalTimePicker/LocalTimePicker.js +6 -55
- package/dist/esm/date/LocalTimePicker/LocalTimePicker.js.map +1 -1
- package/dist/esm/date/MonthDayPicker/MonthDayPicker.js +13 -69
- package/dist/esm/date/MonthDayPicker/MonthDayPicker.js.map +1 -1
- package/dist/esm/date/MonthYearPicker/MonthYearPicker.js +14 -57
- package/dist/esm/date/MonthYearPicker/MonthYearPicker.js.map +1 -1
- package/dist/esm/date/YearSelect/YearSelect.js +25 -39
- package/dist/esm/date/YearSelect/YearSelect.js.map +1 -1
- package/dist/esm/form/TForm/useTForm.js +12 -8
- package/dist/esm/form/TForm/useTForm.js.map +1 -1
- package/dist/esm/form/TMForm/TMForm.js +55 -0
- package/dist/esm/form/TMForm/TMForm.js.map +1 -0
- package/dist/esm/form/TMForm/errorMessages.js +39 -0
- package/dist/esm/form/TMForm/errorMessages.js.map +1 -0
- package/dist/esm/form/TMForm/graphqlErrorTypes.js +6 -0
- package/dist/esm/form/TMForm/graphqlErrorTypes.js.map +1 -0
- package/dist/esm/index.js +1 -23
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/inputs/MaskedInput/MaskedInput.js +5 -8
- package/dist/esm/inputs/MaskedInput/MaskedInput.js.map +1 -1
- package/dist/esm/inputs/MaskedInput/useMaskedInput.js +2 -3
- package/dist/esm/inputs/MaskedInput/useMaskedInput.js.map +1 -1
- package/dist/esm/inputs/PhoneInput/PhoneInput.js.map +1 -1
- package/dist/stats.html +1 -1
- package/dist/stats.txt +26 -86
- package/dist/types/commonTypes.d.ts +1 -0
- package/dist/types/date/LocalDatePicker/LocalDatePicker.d.ts +5 -7
- package/dist/types/date/LocalDatePicker/localdatepicker.stories.d.ts +6 -0
- package/dist/types/date/LocalMonthSelect/LocalMonthSelect.d.ts +2 -3
- package/dist/types/date/LocalMonthSelect/localmonthselect.stories.d.ts +5 -0
- package/dist/types/date/LocalTimePicker/LocalTimePicker.d.ts +2 -6
- package/dist/types/date/LocalTimePicker/localtimepicker.stories.d.ts +5 -0
- package/dist/types/date/MonthDayPicker/MonthDayPicker.d.ts +7 -6
- package/dist/types/date/MonthDayPicker/monthdaypicker.stories.d.ts +5 -0
- package/dist/types/date/MonthYearPicker/MonthYearPicker.d.ts +10 -11
- package/dist/types/date/MonthYearPicker/monthyearpicker.stories.d.ts +6 -0
- package/dist/types/date/YearSelect/YearSelect.d.ts +1 -3
- package/dist/types/date/YearSelect/yearselect.stories.d.ts +7 -0
- package/dist/types/form/TForm/tform.stories.d.ts +19 -0
- package/dist/types/form/TForm/useTForm.d.ts +4 -4
- package/dist/types/form/TMForm/TMForm.d.ts +8 -0
- package/dist/types/form/TMForm/errorMessages.d.ts +5 -0
- package/dist/types/form/TMForm/graphqlErrorTypes.d.ts +50 -0
- package/dist/types/form/TMForm/tmform.stories.d.ts +12 -0
- package/dist/types/index.d.ts +2 -19
- package/dist/types/inputs/CreditCardInput/CreditCardInput.d.ts +3 -2
- package/dist/types/inputs/CreditCardInput/CreditCardNumberInput.d.ts +2 -2
- package/dist/types/inputs/CreditCardInput/creditcardinput.stories.d.ts +5 -0
- package/dist/types/inputs/CreditCardInput/creditcardnumberinput.stories.d.ts +5 -0
- package/dist/types/inputs/MaskedInput/MaskedInput.d.ts +2 -3
- package/dist/types/inputs/MaskedInput/maskedinput.stories.d.ts +6 -0
- package/dist/types/inputs/MaskedInput/useMaskedInput.d.ts +2 -1
- package/dist/types/inputs/PhoneInput/PhoneInput.d.ts +1 -2
- package/dist/types/inputs/PhoneInput/phoneinput.stories.d.ts +5 -0
- package/dist/types/inputs/RadioGroup/radiogroup.stories.d.ts +5 -0
- package/dist/types/inputs/SinInput/SinInput.d.ts +0 -1
- package/dist/types/inputs/SinInput/sininput.stories.d.ts +5 -0
- package/dist/types/inputs/TableInput/DropdownCell.d.ts +2 -2
- package/dist/types/inputs/TableInput/HoverCell.d.ts +1 -2
- package/dist/types/inputs/TableInput/MoneyCell.d.ts +0 -1
- package/dist/types/inputs/TableInput/MoneyEditCell.d.ts +2 -1
- package/dist/types/inputs/TableInput/MoneySumFooter.d.ts +0 -1
- package/dist/types/inputs/TableInput/StringEditCell.d.ts +2 -3
- package/dist/types/inputs/TableInput/TableInput.d.ts +5 -2
- package/dist/types/inputs/TableInput/addRowOnTab.d.ts +1 -0
- package/dist/types/inputs/TableInput/main.story.d.ts +7 -0
- package/dist/types/inputs/TableInput/tableinput.stories.d.ts +5 -0
- package/dist/types/inputs/TableInput/withHover.story.d.ts +7 -0
- package/dist/types/money/MoneyCurrencyInput/MoneyCurrencyInput.d.ts +2 -4
- package/dist/types/money/MoneyCurrencyInput/moneycurrencyinput.stories.d.ts +5 -0
- package/dist/types/money/MoneyInput/MoneyInput.d.ts +4 -5
- package/dist/types/money/MoneyInput/moneyinput.stories.d.ts +6 -0
- package/dist/types/storyDecorator.d.ts +6 -0
- package/package.json +14 -11
- package/dist/esm/date/DatePicker/styles.css.js +0 -7
- package/dist/esm/date/DatePicker/styles.css.js.map +0 -1
- package/dist/esm/date/LocalDatePicker/MaskedDateInput.js +0 -22
- package/dist/esm/date/LocalDatePicker/MaskedDateInput.js.map +0 -1
- package/dist/esm/date/LocalTimePicker/MaskedTimeInput.js +0 -21
- package/dist/esm/date/LocalTimePicker/MaskedTimeInput.js.map +0 -1
- package/dist/esm/external/style-inject/dist/style-inject.es.js +0 -29
- package/dist/esm/external/style-inject/dist/style-inject.es.js.map +0 -1
- package/dist/esm/inputs/CreditCardInput/CreditCardInput.js +0 -71
- package/dist/esm/inputs/CreditCardInput/CreditCardInput.js.map +0 -1
- package/dist/esm/inputs/CreditCardInput/CreditCardNumberInput.js +0 -76
- package/dist/esm/inputs/CreditCardInput/CreditCardNumberInput.js.map +0 -1
- package/dist/esm/inputs/CreditCardInput/styles.css.js +0 -7
- package/dist/esm/inputs/CreditCardInput/styles.css.js.map +0 -1
- package/dist/esm/inputs/RadioGroup/RadioGroup.js +0 -25
- package/dist/esm/inputs/RadioGroup/RadioGroup.js.map +0 -1
- package/dist/esm/inputs/Scriptel/Scriptel.js +0 -52
- package/dist/esm/inputs/Scriptel/Scriptel.js.map +0 -1
- package/dist/esm/inputs/Scriptel/ScriptelContext.js +0 -6
- package/dist/esm/inputs/Scriptel/ScriptelContext.js.map +0 -1
- package/dist/esm/inputs/Scriptel/scriptel/enums.js +0 -21
- package/dist/esm/inputs/Scriptel/scriptel/enums.js.map +0 -1
- package/dist/esm/inputs/Scriptel/scriptel/index.js +0 -93
- package/dist/esm/inputs/Scriptel/scriptel/index.js.map +0 -1
- package/dist/esm/inputs/Scriptel/withScriptel.js +0 -15
- package/dist/esm/inputs/Scriptel/withScriptel.js.map +0 -1
- package/dist/esm/inputs/ScriptelInput/ScriptelInput.js +0 -67
- package/dist/esm/inputs/ScriptelInput/ScriptelInput.js.map +0 -1
- package/dist/esm/inputs/SinInput/SinInput.js +0 -54
- package/dist/esm/inputs/SinInput/SinInput.js.map +0 -1
- package/dist/esm/inputs/TableInput/DropdownCell.js +0 -26
- package/dist/esm/inputs/TableInput/DropdownCell.js.map +0 -1
- package/dist/esm/inputs/TableInput/HoverCell.js +0 -20
- package/dist/esm/inputs/TableInput/HoverCell.js.map +0 -1
- package/dist/esm/inputs/TableInput/LocalDateCell.js +0 -13
- package/dist/esm/inputs/TableInput/LocalDateCell.js.map +0 -1
- package/dist/esm/inputs/TableInput/LocalDateEditCell.js +0 -29
- package/dist/esm/inputs/TableInput/LocalDateEditCell.js.map +0 -1
- package/dist/esm/inputs/TableInput/MoneyCell.js +0 -13
- package/dist/esm/inputs/TableInput/MoneyCell.js.map +0 -1
- package/dist/esm/inputs/TableInput/MoneyEditCell.js +0 -30
- package/dist/esm/inputs/TableInput/MoneyEditCell.js.map +0 -1
- package/dist/esm/inputs/TableInput/MoneySumFooter.js +0 -15
- package/dist/esm/inputs/TableInput/MoneySumFooter.js.map +0 -1
- package/dist/esm/inputs/TableInput/StringEditCell.js +0 -34
- package/dist/esm/inputs/TableInput/StringEditCell.js.map +0 -1
- package/dist/esm/inputs/TableInput/TableInput.js +0 -75
- package/dist/esm/inputs/TableInput/TableInput.js.map +0 -1
- package/dist/esm/inputs/TableInput/addRowOnTab.js +0 -13
- package/dist/esm/inputs/TableInput/addRowOnTab.js.map +0 -1
- package/dist/esm/money/MoneyCurrencyInput/MoneyCurrencyInput.js +0 -51
- package/dist/esm/money/MoneyCurrencyInput/MoneyCurrencyInput.js.map +0 -1
- package/dist/esm/money/MoneyInput/MoneyInput.js +0 -31
- package/dist/esm/money/MoneyInput/MoneyInput.js.map +0 -1
- package/dist/esm/money/useMoneyInput.js +0 -75
- package/dist/esm/money/useMoneyInput.js.map +0 -1
- package/dist/esm/step/FormStep.js +0 -17
- package/dist/esm/step/FormStep.js.map +0 -1
- package/dist/esm/step/Step.js +0 -10
- package/dist/esm/step/Step.js.map +0 -1
- package/dist/esm/step/StepProvider.js +0 -95
- package/dist/esm/step/StepProvider.js.map +0 -1
- package/dist/esm/step/stepContext.js +0 -10
- package/dist/esm/step/stepContext.js.map +0 -1
- package/dist/esm/step/useStep.js +0 -10
- package/dist/esm/step/useStep.js.map +0 -1
- package/dist/types/date/DatePicker/index.d.ts +0 -3
- package/dist/types/date/LocalDatePicker/MaskedDateInput.d.ts +0 -12
- package/dist/types/date/LocalTimePicker/MaskedTimeInput.d.ts +0 -11
- package/dist/types/inputs/CreditCardInput/index.d.ts +0 -2
- package/dist/types/inputs/RadioGroup/RadioGroup.d.ts +0 -8
- package/dist/types/inputs/RadioGroup/index.d.ts +0 -2
- package/dist/types/inputs/Scriptel/Scriptel.d.ts +0 -11
- package/dist/types/inputs/Scriptel/ScriptelContext.d.ts +0 -9
- package/dist/types/inputs/Scriptel/index.d.ts +0 -4
- package/dist/types/inputs/Scriptel/scriptel/classes.d.ts +0 -144
- package/dist/types/inputs/Scriptel/scriptel/enums.d.ts +0 -16
- package/dist/types/inputs/Scriptel/scriptel/index.d.ts +0 -17
- package/dist/types/inputs/Scriptel/scriptel/messages.d.ts +0 -52
- package/dist/types/inputs/Scriptel/withScriptel.d.ts +0 -9
- package/dist/types/inputs/ScriptelInput/ScriptelInput.d.ts +0 -8
- package/dist/types/inputs/ScriptelInput/index.d.ts +0 -2
- package/dist/types/inputs/SinInput/index.d.ts +0 -2
- package/dist/types/inputs/TableInput/LocalDateCell.d.ts +0 -9
- package/dist/types/inputs/TableInput/LocalDateEditCell.d.ts +0 -4
- package/dist/types/inputs/TableInput/index.d.ts +0 -11
- package/dist/types/money/MoneyCurrencyInput/index.d.ts +0 -2
- package/dist/types/step/FormStep.d.ts +0 -9
- package/dist/types/step/Step.d.ts +0 -9
- package/dist/types/step/StepProvider.d.ts +0 -10
- package/dist/types/step/index.d.ts +0 -4
- package/dist/types/step/stepContext.d.ts +0 -5
- package/dist/types/step/useStep.d.ts +0 -1
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
import { InputProps } from 'semantic-ui-react';
|
|
1
|
+
import { TextInputProps } from '@mantine/core';
|
|
3
2
|
import type { TableCellProps } from './TableInput';
|
|
4
3
|
import type { AddRowOnTabIf } from './addRowOnTab';
|
|
5
4
|
interface StringEditCellOptions<D extends Record<string, unknown>> {
|
|
6
5
|
/** Override SemanticUI Input props */
|
|
7
|
-
inputProps?:
|
|
6
|
+
inputProps?: TextInputProps;
|
|
8
7
|
/** If function is present, and returns true, will add a new row if tab is pressed on the last row */
|
|
9
8
|
addRowOnTabIf?: AddRowOnTabIf<D, string>;
|
|
10
9
|
}
|
|
@@ -1,15 +1,18 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
+
import { TableProps } from '@mantine/core';
|
|
2
3
|
import { FieldArrayRenderProps } from 'formik';
|
|
3
4
|
import { CellPropGetter, CellProps, Column, FooterGroupPropGetter, FooterPropGetter, HeaderGroupPropGetter, HeaderPropGetter, RowPropGetter, TableBodyPropGetter } from 'react-table';
|
|
4
|
-
import { TableProps } from 'semantic-ui-react';
|
|
5
5
|
declare type DefaultTableType = Record<string, unknown>;
|
|
6
|
+
export interface CustomTableProps {
|
|
7
|
+
celled?: boolean;
|
|
8
|
+
}
|
|
6
9
|
interface TableInputProps<A extends DefaultTableType> {
|
|
7
10
|
name: string;
|
|
8
11
|
values: A[];
|
|
9
12
|
columns: Column<A>[];
|
|
10
13
|
setFieldValue: (field: string, value: any, shouldValidate?: boolean | undefined) => void;
|
|
11
14
|
createRow: () => A;
|
|
12
|
-
tableProps?: TableProps;
|
|
15
|
+
tableProps?: TableProps & CustomTableProps;
|
|
13
16
|
headerRowProps?: HeaderGroupPropGetter<A>;
|
|
14
17
|
headerCellProps?: HeaderPropGetter<A>;
|
|
15
18
|
footerRowProps?: FooterGroupPropGetter<A>;
|
|
@@ -1,11 +1,9 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
import { InputProps } from 'semantic-ui-react';
|
|
3
2
|
import type { MoneyInputProps } from '../MoneyInput';
|
|
4
3
|
export interface MoneyCurrencyInputProps extends MoneyInputProps {
|
|
5
4
|
currencies?: {
|
|
6
|
-
key: string;
|
|
7
5
|
value: string;
|
|
8
|
-
|
|
6
|
+
label: string;
|
|
9
7
|
}[];
|
|
10
8
|
}
|
|
11
|
-
export declare function MoneyCurrencyInput(props: MoneyCurrencyInputProps
|
|
9
|
+
export declare function MoneyCurrencyInput(props: MoneyCurrencyInputProps): JSX.Element;
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ComponentStory, Meta } from '@storybook/react';
|
|
2
|
+
import { MoneyCurrencyInput } from './MoneyCurrencyInput';
|
|
3
|
+
declare const _default: Meta<import("@storybook/react").Args>;
|
|
4
|
+
export default _default;
|
|
5
|
+
export declare const Main: ComponentStory<typeof MoneyCurrencyInput>;
|
|
@@ -1,15 +1,14 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
+
import type { TextInputProps } from '@mantine/core';
|
|
2
3
|
import Money, { Currency, MoneyObject } from 'js-money';
|
|
3
|
-
|
|
4
|
-
export interface MoneyInputProps {
|
|
5
|
-
name?: string;
|
|
4
|
+
export interface MoneyInputOnlyProps {
|
|
6
5
|
onChange?: (value: Money) => void;
|
|
7
6
|
value?: Money | MoneyObject;
|
|
8
7
|
defaultCurrency?: Currency;
|
|
9
|
-
onBlur?: (ev: any) => void;
|
|
10
8
|
prefix?: string;
|
|
11
9
|
showPrefix?: boolean;
|
|
12
10
|
locked?: boolean;
|
|
13
11
|
wholeNumber?: boolean;
|
|
14
12
|
}
|
|
15
|
-
export declare
|
|
13
|
+
export declare type MoneyInputProps = MoneyInputOnlyProps & Omit<TextInputProps, 'onChange' | 'value'>;
|
|
14
|
+
export declare function MoneyInput(props: MoneyInputProps): JSX.Element;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { ComponentStory, Meta } from '@storybook/react';
|
|
2
|
+
import { MoneyInput } from './MoneyInput';
|
|
3
|
+
declare const _default: Meta<import("@storybook/react").Args>;
|
|
4
|
+
export default _default;
|
|
5
|
+
export declare const Main: ComponentStory<typeof MoneyInput>;
|
|
6
|
+
export declare const MoreDecimals: ComponentStory<typeof MoneyInput>;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@thx/controls",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "17.0.0-mantine.0",
|
|
4
4
|
"description": "A collection of components designed with SemanticUI.",
|
|
5
5
|
"bugs": {
|
|
6
6
|
"url": "https://github.com/thr-consulting/thr-addons/issues"
|
|
@@ -21,7 +21,7 @@
|
|
|
21
21
|
"scripts": {
|
|
22
22
|
"build": "thx build.roll",
|
|
23
23
|
"clean": "thx clean",
|
|
24
|
-
"deps": "thx deps -p *.stories.tsx,*.story.tsx,*.cjs",
|
|
24
|
+
"deps": "thx deps -p *.stories.tsx,*.story.tsx,*.cjs,storyDecorator.tsx",
|
|
25
25
|
"docs.storybook": "build-storybook",
|
|
26
26
|
"lint": "thx lint",
|
|
27
27
|
"lint.fix": "thx lint.fix",
|
|
@@ -33,12 +33,9 @@
|
|
|
33
33
|
"@js-joda/core": "^5.1.0",
|
|
34
34
|
"@thx/date": "^16.0.1",
|
|
35
35
|
"@thx/money": "^16.0.0",
|
|
36
|
-
"@thx/yup-types": "^16.0.0",
|
|
37
36
|
"@types/inputmask": "^5.0.3",
|
|
38
|
-
"@types/react-datepicker": "^4.1.7",
|
|
39
37
|
"credit-card-type": "^9.1.0",
|
|
40
|
-
"debug": "^4.
|
|
41
|
-
"eventemitter3": "^4.0.0",
|
|
38
|
+
"debug": "^4.1.1",
|
|
42
39
|
"flat": "^5.0.0",
|
|
43
40
|
"formik": "^2.2.9",
|
|
44
41
|
"inputmask": "^5.0.6",
|
|
@@ -46,17 +43,19 @@
|
|
|
46
43
|
"lodash-es": "^4.17.15",
|
|
47
44
|
"luhn": "^2.4.1",
|
|
48
45
|
"react-credit-cards": "^0.8.3",
|
|
49
|
-
"react-datepicker": "^4.7.0",
|
|
50
46
|
"react-table": "^7.6.3",
|
|
51
47
|
"social-insurance-number": "^0.2.2",
|
|
52
|
-
"
|
|
48
|
+
"tabler-icons-react": "^1.48.1"
|
|
53
49
|
},
|
|
54
50
|
"peerDependencies": {
|
|
51
|
+
"@mantine/core": "4.x",
|
|
52
|
+
"@mantine/dates": "4.x",
|
|
53
|
+
"@mantine/form": "4.x",
|
|
54
|
+
"@mantine/hooks": "4.x",
|
|
55
55
|
"react": "17.x",
|
|
56
56
|
"react-dom": "17.x",
|
|
57
57
|
"react-router": "5.x",
|
|
58
|
-
"react-router-dom": "5.x"
|
|
59
|
-
"semantic-ui-react": "2.x"
|
|
58
|
+
"react-router-dom": "5.x"
|
|
60
59
|
},
|
|
61
60
|
"engines": {
|
|
62
61
|
"node": ">=16"
|
|
@@ -64,5 +63,9 @@
|
|
|
64
63
|
"publishConfig": {
|
|
65
64
|
"access": "public"
|
|
66
65
|
},
|
|
67
|
-
"gitHead": "
|
|
66
|
+
"gitHead": "2b8c34ade6e34716807c9cfc466001dd54e5be36",
|
|
67
|
+
"unusedDeps": {
|
|
68
|
+
"@thx/yup-types": "^16.0.0",
|
|
69
|
+
"eventemitter3": "^4.0.0"
|
|
70
|
+
}
|
|
68
71
|
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import styleInject from './../../external/style-inject/dist/style-inject.es.js';
|
|
2
|
-
|
|
3
|
-
var css_248z = ".rw-datetimepicker > input {\n\tborder: none !important;\n}\n\n.rw-datetimepicker .rw-calendar-grid.rw-nav-view .rw-btn {\n\tpadding: 0 !important;\n}\n\n.dateTimePickerAutoWidth {\n\twidth: auto;\n\tdisplay: inline-flex;\n}\n\n.dateTimePickerAutoWidth > input {\n\twidth: auto;\n}\n\n.react-datepicker-wrapper {\n\twidth: 100%;\n\tdisplay: inline !important;\n}\n\n.react-datepicker__input-container {\n\tdisplay: inline !important;\n}\n\n.react-datepicker-popper {\n\tz-index: 5 !important;\n}\n";
|
|
4
|
-
styleInject(css_248z);
|
|
5
|
-
|
|
6
|
-
export { css_248z as default };
|
|
7
|
-
//# sourceMappingURL=styles.css.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA,wBAAwB,uDAAyD;AACjF;AACA;AACA;AACA;AACA;"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import React, { forwardRef } from 'react';
|
|
2
|
-
import debug from 'debug';
|
|
3
|
-
import { MaskedInput } from '../../inputs/MaskedInput/MaskedInput.js';
|
|
4
|
-
import '../../inputs/MaskedInput/useMaskedInput.js';
|
|
5
|
-
|
|
6
|
-
debug("thx.controls.date.LocalDatePicker.MaskedDateInput");
|
|
7
|
-
function MaskedDateInputInner(props, ref) {
|
|
8
|
-
const { onChange, name, ...rest } = props;
|
|
9
|
-
return /* @__PURE__ */ React.createElement(MaskedInput, {
|
|
10
|
-
...rest,
|
|
11
|
-
name,
|
|
12
|
-
mask: { alias: "datetime", inputFormat: "mm/dd/yyyy" },
|
|
13
|
-
onChange: (value) => {
|
|
14
|
-
if (onChange)
|
|
15
|
-
onChange({ target: { value: value || "" } });
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
}
|
|
19
|
-
const MaskedDateInput = forwardRef(MaskedDateInputInner);
|
|
20
|
-
|
|
21
|
-
export { MaskedDateInput };
|
|
22
|
-
//# sourceMappingURL=MaskedDateInput.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MaskedDateInput.js","sources":["../../../../src/date/LocalDatePicker/MaskedDateInput.tsx"],"sourcesContent":["import debug from 'debug';\nimport {forwardRef} from 'react';\nimport {MaskedInput, MaskedInputProps} from '../../inputs/MaskedInput';\n\nconst d = debug('thx.controls.date.LocalDatePicker.MaskedDateInput');\n\nexport interface MaskedDateInputValue {\n\ttarget: {\n\t\tvalue: string;\n\t};\n}\n\nexport interface MaskedDateInputProps {\n\tname?: string;\n\tonChange?: (value: MaskedDateInputValue) => void;\n}\n\n// eslint-disable-next-line no-unused-vars,@typescript-eslint/no-unused-vars\nfunction MaskedDateInputInner(props: MaskedDateInputProps & Omit<MaskedInputProps, 'onChange'>, ref: any) {\n\tconst {onChange, name, ...rest} = props;\n\n\treturn (\n\t\t<MaskedInput\n\t\t\t{...rest}\n\t\t\tname={name}\n\t\t\tmask={{alias: 'datetime', inputFormat: 'mm/dd/yyyy'}}\n\t\t\tonChange={value => {\n\t\t\t\tif (onChange) onChange({target: {value: value || ''}});\n\t\t\t}}\n\t\t/>\n\t);\n}\n\nexport const MaskedDateInput = forwardRef(MaskedDateInputInner);\n"],"names":[],"mappings":";;;;;AAIU,MAAM,mDAAmD,EAAA;AAcnE,SAAA,oBAAA,CAA8B,OAAkE,GAAU,EAAA;AACzG,EAAM,MAAA,EAAC,QAAU,EAAA,IAAA,EAAA,GAAS,IAAQ,EAAA,GAAA,KAAA,CAAA;AAElC,EAAA,uBACE,KAAA,CAAA,aAAA,CAAA,WAAA,EAAA;AAAA,IACI,GAAA,IAAA;AAAA,IACJ,IAAA;AAAA,IACA,IAAM,EAAA,EAAC,KAAO,EAAA,UAAA,EAAY,aAAa,YAAY,EAAA;AAAA,IACnD,UAAU,CAAS,KAAA,KAAA;AAClB,MAAI,IAAA,QAAA;AAAU,QAAA,QAAA,CAAS,EAAC,MAAQ,EAAA,EAAC,OAAO,KAAS,IAAA,EAAA,IAAI,CAAA,CAAA;AAAA,KACtD;AAAA,GACD,CAAA,CAAA;AAEF,CAAA;AAEa,MAAA,eAAA,GAAkB,WAAW,oBAAoB;;;;"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import React, { forwardRef } from 'react';
|
|
2
|
-
import debug from 'debug';
|
|
3
|
-
import { MaskedInput } from '../../inputs/MaskedInput/MaskedInput.js';
|
|
4
|
-
import '../../inputs/MaskedInput/useMaskedInput.js';
|
|
5
|
-
|
|
6
|
-
debug("thx.controls.date.LocalTimePicker.MaskedTimeInput");
|
|
7
|
-
function MaskedTimeInputInner(props, ref) {
|
|
8
|
-
const { onChange, ...rest } = props;
|
|
9
|
-
return /* @__PURE__ */ React.createElement(MaskedInput, {
|
|
10
|
-
mask: { alias: "datetime", inputFormat: "hh:MM TT" },
|
|
11
|
-
onChange: (value) => {
|
|
12
|
-
if (onChange)
|
|
13
|
-
onChange({ target: { value: value || "" } });
|
|
14
|
-
},
|
|
15
|
-
...rest
|
|
16
|
-
});
|
|
17
|
-
}
|
|
18
|
-
const MaskedTimeInput = forwardRef(MaskedTimeInputInner);
|
|
19
|
-
|
|
20
|
-
export { MaskedTimeInput };
|
|
21
|
-
//# sourceMappingURL=MaskedTimeInput.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MaskedTimeInput.js","sources":["../../../../src/date/LocalTimePicker/MaskedTimeInput.tsx"],"sourcesContent":["import debug from 'debug';\nimport {forwardRef} from 'react';\nimport {MaskedInput, MaskedInputProps} from '../../inputs/MaskedInput';\n\nconst d = debug('thx.controls.date.LocalTimePicker.MaskedTimeInput');\n\nexport interface MaskedTimeInputValue {\n\ttarget: {\n\t\tvalue: string;\n\t};\n}\n\nexport interface MaskedTimeInputProps {\n\tonChange?: (value: MaskedTimeInputValue) => void;\n}\n\n// eslint-disable-next-line no-unused-vars,@typescript-eslint/no-unused-vars\nfunction MaskedTimeInputInner(props: MaskedTimeInputProps & Omit<MaskedInputProps, 'onChange'>, ref: any) {\n\tconst {onChange, ...rest} = props;\n\n\treturn (\n\t\t<MaskedInput\n\t\t\tmask={{alias: 'datetime', inputFormat: 'hh:MM TT'}}\n\t\t\tonChange={value => {\n\t\t\t\tif (onChange) onChange({target: {value: value || ''}});\n\t\t\t}}\n\t\t\t{...rest}\n\t\t/>\n\t);\n}\n\nexport const MaskedTimeInput = forwardRef(MaskedTimeInputInner);\n"],"names":[],"mappings":";;;;;AAIU,MAAM,mDAAmD,EAAA;AAanE,SAAA,oBAAA,CAA8B,OAAkE,GAAU,EAAA;AACzG,EAAM,MAAA,EAAC,aAAa,IAAQ,EAAA,GAAA,KAAA,CAAA;AAE5B,EAAA,uBACE,KAAA,CAAA,aAAA,CAAA,WAAA,EAAA;AAAA,IACA,IAAM,EAAA,EAAC,KAAO,EAAA,UAAA,EAAY,aAAa,UAAU,EAAA;AAAA,IACjD,UAAU,CAAS,KAAA,KAAA;AAClB,MAAI,IAAA,QAAA;AAAU,QAAA,QAAA,CAAS,EAAC,MAAQ,EAAA,EAAC,OAAO,KAAS,IAAA,EAAA,IAAI,CAAA,CAAA;AAAA,KACtD;AAAA,IACI,GAAA,IAAA;AAAA,GACL,CAAA,CAAA;AAEF,CAAA;AAEa,MAAA,eAAA,GAAkB,WAAW,oBAAoB;;;;"}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
function styleInject(css, ref) {
|
|
2
|
-
if ( ref === void 0 ) ref = {};
|
|
3
|
-
var insertAt = ref.insertAt;
|
|
4
|
-
|
|
5
|
-
if (!css || typeof document === 'undefined') { return; }
|
|
6
|
-
|
|
7
|
-
var head = document.head || document.getElementsByTagName('head')[0];
|
|
8
|
-
var style = document.createElement('style');
|
|
9
|
-
style.type = 'text/css';
|
|
10
|
-
|
|
11
|
-
if (insertAt === 'top') {
|
|
12
|
-
if (head.firstChild) {
|
|
13
|
-
head.insertBefore(style, head.firstChild);
|
|
14
|
-
} else {
|
|
15
|
-
head.appendChild(style);
|
|
16
|
-
}
|
|
17
|
-
} else {
|
|
18
|
-
head.appendChild(style);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
if (style.styleSheet) {
|
|
22
|
-
style.styleSheet.cssText = css;
|
|
23
|
-
} else {
|
|
24
|
-
style.appendChild(document.createTextNode(css));
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
export { styleInject as default };
|
|
29
|
-
//# sourceMappingURL=style-inject.es.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"style-inject.es.js","sources":["../../../../../../../node_modules/style-inject/dist/style-inject.es.js"],"sourcesContent":["function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n"],"names":[],"mappings":"AAAA,SAAS,WAAW,CAAC,GAAG,EAAE,GAAG,EAAE;AAC/B,EAAE,KAAK,GAAG,KAAK,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC;AACjC,EAAE,IAAI,QAAQ,GAAG,GAAG,CAAC,QAAQ,CAAC;AAC9B;AACA,EAAE,IAAI,CAAC,GAAG,IAAI,OAAO,QAAQ,KAAK,WAAW,EAAE,EAAE,OAAO,EAAE;AAC1D;AACA,EAAE,IAAI,IAAI,GAAG,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;AACvE,EAAE,IAAI,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;AAC9C,EAAE,KAAK,CAAC,IAAI,GAAG,UAAU,CAAC;AAC1B;AACA,EAAE,IAAI,QAAQ,KAAK,KAAK,EAAE;AAC1B,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;AACzB,MAAM,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;AAChD,KAAK,MAAM;AACX,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;AAC9B,KAAK;AACL,GAAG,MAAM;AACT,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;AAC5B,GAAG;AACH;AACA,EAAE,IAAI,KAAK,CAAC,UAAU,EAAE;AACxB,IAAI,KAAK,CAAC,UAAU,CAAC,OAAO,GAAG,GAAG,CAAC;AACnC,GAAG,MAAM;AACT,IAAI,KAAK,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC;AACpD,GAAG;AACH;;;;"}
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import React, { useState } from 'react';
|
|
2
|
-
import { formatDate } from '@thx/date';
|
|
3
|
-
import debug from 'debug';
|
|
4
|
-
import CreditCards from 'react-credit-cards';
|
|
5
|
-
import 'react-credit-cards/es/styles-compiled.css';
|
|
6
|
-
import { Grid, Form, Input } from 'semantic-ui-react';
|
|
7
|
-
import { MonthYearPicker } from '../../date/MonthYearPicker/MonthYearPicker.js';
|
|
8
|
-
import { CreditCardNumberInput } from './CreditCardNumberInput.js';
|
|
9
|
-
import './styles.css.js';
|
|
10
|
-
|
|
11
|
-
const d = debug("thx.controls.inputs.CreditCardInput");
|
|
12
|
-
function CreditCardInput(props) {
|
|
13
|
-
const { onBlur, disabled, onChange, value } = props;
|
|
14
|
-
const { name, number, cvc, expiry } = value || {};
|
|
15
|
-
const [focus, setFocus] = useState("number");
|
|
16
|
-
return /* @__PURE__ */ React.createElement(Grid, null, /* @__PURE__ */ React.createElement(Grid.Column, {
|
|
17
|
-
width: 4
|
|
18
|
-
}, /* @__PURE__ */ React.createElement(Form, null, /* @__PURE__ */ React.createElement(Form.Group, null, /* @__PURE__ */ React.createElement(Form.Field, {
|
|
19
|
-
width: 9
|
|
20
|
-
}, /* @__PURE__ */ React.createElement("label", null, "Number"), /* @__PURE__ */ React.createElement(CreditCardNumberInput, {
|
|
21
|
-
onFocus: () => setFocus("number"),
|
|
22
|
-
onBlur,
|
|
23
|
-
onChange: (v) => {
|
|
24
|
-
onChange && onChange({ name, number: v, cvc, expiry });
|
|
25
|
-
},
|
|
26
|
-
disabled
|
|
27
|
-
})), /* @__PURE__ */ React.createElement(Form.Field, {
|
|
28
|
-
width: 4
|
|
29
|
-
}, /* @__PURE__ */ React.createElement("label", null, "CVC"), /* @__PURE__ */ React.createElement(Input, {
|
|
30
|
-
value: cvc || "",
|
|
31
|
-
onChange: (ev, v) => {
|
|
32
|
-
onChange && onChange({ name, number, cvc: v.value, expiry });
|
|
33
|
-
},
|
|
34
|
-
onFocus: () => setFocus("cvc"),
|
|
35
|
-
onBlur: () => setFocus("name"),
|
|
36
|
-
disabled
|
|
37
|
-
}))), /* @__PURE__ */ React.createElement(Form.Group, null, /* @__PURE__ */ React.createElement(Form.Field, {
|
|
38
|
-
width: 9
|
|
39
|
-
}, /* @__PURE__ */ React.createElement("label", null, "Name"), /* @__PURE__ */ React.createElement(Input, {
|
|
40
|
-
value: name || "",
|
|
41
|
-
onChange: (ev, v) => {
|
|
42
|
-
onChange && onChange({ name: v.value, number, cvc, expiry });
|
|
43
|
-
},
|
|
44
|
-
onFocus: () => setFocus("name"),
|
|
45
|
-
disabled,
|
|
46
|
-
fluid: true
|
|
47
|
-
})), /* @__PURE__ */ React.createElement(Form.Field, {
|
|
48
|
-
width: 6
|
|
49
|
-
}, /* @__PURE__ */ React.createElement("label", null, "Expiry"), /* @__PURE__ */ React.createElement(MonthYearPicker, {
|
|
50
|
-
value: expiry,
|
|
51
|
-
onChange: (v) => {
|
|
52
|
-
onChange && onChange({ name, number, cvc, expiry: v });
|
|
53
|
-
},
|
|
54
|
-
onFocus: () => setFocus("expiry"),
|
|
55
|
-
disabled
|
|
56
|
-
}))))), /* @__PURE__ */ React.createElement(Grid.Column, {
|
|
57
|
-
width: 12
|
|
58
|
-
}, /* @__PURE__ */ React.createElement(CreditCards, {
|
|
59
|
-
cvc: cvc || "",
|
|
60
|
-
expiry: formatDate(expiry, { format: "MMuu" }) || "",
|
|
61
|
-
name: name || "",
|
|
62
|
-
number: number || "",
|
|
63
|
-
focused: focus,
|
|
64
|
-
callback: (a, b) => {
|
|
65
|
-
d(a, b);
|
|
66
|
-
}
|
|
67
|
-
})));
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
export { CreditCardInput };
|
|
71
|
-
//# sourceMappingURL=CreditCardInput.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CreditCardInput.js","sources":["../../../../src/inputs/CreditCardInput/CreditCardInput.tsx"],"sourcesContent":["import type {LocalDate} from '@js-joda/core';\nimport {formatDate} from '@thx/date';\nimport debug from 'debug';\nimport {useState} from 'react';\nimport CreditCards, {Focused} from 'react-credit-cards';\nimport 'react-credit-cards/es/styles-compiled.css';\nimport {Form, Grid, Input, InputProps} from 'semantic-ui-react';\nimport {MonthYearPicker} from '../../date/MonthYearPicker';\nimport {CreditCardNumberInput} from './CreditCardNumberInput';\nimport './styles.css';\n\nconst d = debug('thx.controls.inputs.CreditCardInput');\n\nexport interface CreditCardData {\n\tnumber?: string;\n\tname?: string;\n\tcvc?: string;\n\texpiry?: LocalDate;\n}\n\nexport type CreditCardInputProps = {\n\tvalue?: CreditCardData;\n\tonChange?: (data: CreditCardData) => void;\n} & Pick<InputProps, 'disabled' | 'onBlur'>;\n\nexport function CreditCardInput(props: CreditCardInputProps) {\n\tconst {onBlur, disabled, onChange, value} = props;\n\tconst {name, number, cvc, expiry} = value || {};\n\n\tconst [focus, setFocus] = useState<Focused>('number');\n\n\treturn (\n\t\t<Grid>\n\t\t\t<Grid.Column width={4}>\n\t\t\t\t<Form>\n\t\t\t\t\t<Form.Group>\n\t\t\t\t\t\t<Form.Field width={9}>\n\t\t\t\t\t\t\t<label>Number</label>\n\t\t\t\t\t\t\t<CreditCardNumberInput\n\t\t\t\t\t\t\t\tonFocus={() => setFocus('number')}\n\t\t\t\t\t\t\t\tonBlur={onBlur}\n\t\t\t\t\t\t\t\tonChange={v => {\n\t\t\t\t\t\t\t\t\tonChange && onChange({name, number: v, cvc, expiry});\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tdisabled={disabled}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</Form.Field>\n\t\t\t\t\t\t<Form.Field width={4}>\n\t\t\t\t\t\t\t<label>CVC</label>\n\t\t\t\t\t\t\t<Input\n\t\t\t\t\t\t\t\tvalue={cvc || ''}\n\t\t\t\t\t\t\t\tonChange={(ev, v) => {\n\t\t\t\t\t\t\t\t\tonChange && onChange({name, number, cvc: v.value, expiry});\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tonFocus={() => setFocus('cvc')}\n\t\t\t\t\t\t\t\tonBlur={() => setFocus('name')}\n\t\t\t\t\t\t\t\tdisabled={disabled}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</Form.Field>\n\t\t\t\t\t</Form.Group>\n\t\t\t\t\t<Form.Group>\n\t\t\t\t\t\t<Form.Field width={9}>\n\t\t\t\t\t\t\t<label>Name</label>\n\t\t\t\t\t\t\t<Input\n\t\t\t\t\t\t\t\tvalue={name || ''}\n\t\t\t\t\t\t\t\tonChange={(ev, v) => {\n\t\t\t\t\t\t\t\t\tonChange && onChange({name: v.value, number, cvc, expiry});\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tonFocus={() => setFocus('name')}\n\t\t\t\t\t\t\t\tdisabled={disabled}\n\t\t\t\t\t\t\t\tfluid\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</Form.Field>\n\t\t\t\t\t\t<Form.Field width={6}>\n\t\t\t\t\t\t\t<label>Expiry</label>\n\t\t\t\t\t\t\t<MonthYearPicker\n\t\t\t\t\t\t\t\tvalue={expiry}\n\t\t\t\t\t\t\t\tonChange={v => {\n\t\t\t\t\t\t\t\t\tonChange && onChange({name, number, cvc, expiry: v});\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tonFocus={() => setFocus('expiry')}\n\t\t\t\t\t\t\t\tdisabled={disabled}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</Form.Field>\n\t\t\t\t\t</Form.Group>\n\t\t\t\t</Form>\n\t\t\t</Grid.Column>\n\t\t\t<Grid.Column width={12}>\n\t\t\t\t<CreditCards\n\t\t\t\t\tcvc={cvc || ''}\n\t\t\t\t\texpiry={formatDate(expiry, {format: 'MMuu'}) || ''}\n\t\t\t\t\tname={name || ''}\n\t\t\t\t\tnumber={number || ''}\n\t\t\t\t\tfocused={focus}\n\t\t\t\t\tcallback={(a, b) => {\n\t\t\t\t\t\td(a, b);\n\t\t\t\t\t}}\n\t\t\t\t/>\n\t\t\t</Grid.Column>\n\t\t</Grid>\n\t);\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
import React, { useState, useCallback, useMemo } from 'react';
|
|
2
|
-
import creditCardType from 'credit-card-type';
|
|
3
|
-
import debug from 'debug';
|
|
4
|
-
import { validate } from 'luhn';
|
|
5
|
-
import { Input, Icon } from 'semantic-ui-react';
|
|
6
|
-
import { useMaskedInput } from '../MaskedInput/useMaskedInput.js';
|
|
7
|
-
|
|
8
|
-
const d = debug("thx.controls.inputs.CreditCardInput.CreditCardNumberInput");
|
|
9
|
-
function getIcon(type) {
|
|
10
|
-
switch (type) {
|
|
11
|
-
case "visa":
|
|
12
|
-
return "cc visa";
|
|
13
|
-
case "mastercard":
|
|
14
|
-
return "cc mastercard";
|
|
15
|
-
case "american-express":
|
|
16
|
-
return "cc amex";
|
|
17
|
-
case "diners-club":
|
|
18
|
-
return "cc diners club";
|
|
19
|
-
case "jcb":
|
|
20
|
-
return "cc jcb";
|
|
21
|
-
default:
|
|
22
|
-
return "credit card";
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
function CreditCardNumberInput(props) {
|
|
26
|
-
const { value, onChange, ...rest } = props;
|
|
27
|
-
const [icon, setIcon] = useState("credit card");
|
|
28
|
-
const [color, setColor] = useState("black");
|
|
29
|
-
const checkValidation = useCallback((valueArray) => {
|
|
30
|
-
const num = valueArray.join("").replaceAll(/(_|\s)/g, "");
|
|
31
|
-
const typ = creditCardType(num);
|
|
32
|
-
const isValid = validate(num);
|
|
33
|
-
if (typ.length === 1) {
|
|
34
|
-
setIcon(getIcon(typ[0].type));
|
|
35
|
-
} else {
|
|
36
|
-
setIcon("credit card");
|
|
37
|
-
}
|
|
38
|
-
if (num.length > 0) {
|
|
39
|
-
if (isValid) {
|
|
40
|
-
setColor("green");
|
|
41
|
-
} else {
|
|
42
|
-
setColor("red");
|
|
43
|
-
}
|
|
44
|
-
} else {
|
|
45
|
-
setColor("black");
|
|
46
|
-
}
|
|
47
|
-
return isValid;
|
|
48
|
-
}, []);
|
|
49
|
-
const creditCardMask = useMemo(() => ({
|
|
50
|
-
mask: "9999 9999 9999 9999",
|
|
51
|
-
isComplete: checkValidation,
|
|
52
|
-
autoUnmask: true
|
|
53
|
-
}), [checkValidation]);
|
|
54
|
-
const cardNumberRef = useMaskedInput({
|
|
55
|
-
mask: creditCardMask,
|
|
56
|
-
value,
|
|
57
|
-
onChange: (v) => {
|
|
58
|
-
const typ = creditCardType(v || "");
|
|
59
|
-
d(v, typ);
|
|
60
|
-
onChange && onChange(v);
|
|
61
|
-
}
|
|
62
|
-
});
|
|
63
|
-
return /* @__PURE__ */ React.createElement(Input, {
|
|
64
|
-
...rest,
|
|
65
|
-
icon: true
|
|
66
|
-
}, /* @__PURE__ */ React.createElement("input", {
|
|
67
|
-
ref: cardNumberRef
|
|
68
|
-
}), /* @__PURE__ */ React.createElement(Icon, {
|
|
69
|
-
name: icon,
|
|
70
|
-
color,
|
|
71
|
-
size: "large"
|
|
72
|
-
}));
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
export { CreditCardNumberInput };
|
|
76
|
-
//# sourceMappingURL=CreditCardNumberInput.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CreditCardNumberInput.js","sources":["../../../../src/inputs/CreditCardInput/CreditCardNumberInput.tsx"],"sourcesContent":["import creditCardType from 'credit-card-type';\nimport debug from 'debug';\nimport {validate} from 'luhn';\nimport {useCallback, useMemo, useState} from 'react';\nimport {Icon, Input, InputProps, SemanticICONS, SemanticCOLORS} from 'semantic-ui-react';\nimport type {MaskedInputProps} from '../MaskedInput';\nimport {useMaskedInput} from '../MaskedInput/useMaskedInput';\n\nconst d = debug('thx.controls.inputs.CreditCardInput.CreditCardNumberInput');\n\ninterface CreditCardNumberInputProps {\n\tonChange?: (value: string | undefined) => void;\n\tvalue?: string;\n}\n\nfunction getIcon(type: string): SemanticICONS {\n\tswitch (type) {\n\t\tcase 'visa':\n\t\t\treturn 'cc visa';\n\t\tcase 'mastercard':\n\t\t\treturn 'cc mastercard';\n\t\tcase 'american-express':\n\t\t\treturn 'cc amex';\n\t\tcase 'diners-club':\n\t\t\treturn 'cc diners club';\n\t\tcase 'jcb':\n\t\t\treturn 'cc jcb';\n\t\tdefault:\n\t\t\treturn 'credit card';\n\t}\n}\n\nexport function CreditCardNumberInput(props: CreditCardNumberInputProps & Omit<InputProps, 'onChange'>) {\n\tconst {value, onChange, ...rest} = props;\n\tconst [icon, setIcon] = useState<SemanticICONS>('credit card');\n\tconst [color, setColor] = useState<SemanticCOLORS>('black');\n\n\tconst checkValidation = useCallback((valueArray: string[]) => {\n\t\tconst num = valueArray.join('').replaceAll(/(_|\\s)/g, '');\n\t\tconst typ = creditCardType(num);\n\t\tconst isValid = validate(num);\n\n\t\tif (typ.length === 1) {\n\t\t\tsetIcon(getIcon(typ[0].type));\n\t\t} else {\n\t\t\tsetIcon('credit card');\n\t\t}\n\n\t\tif (num.length > 0) {\n\t\t\tif (isValid) {\n\t\t\t\tsetColor('green');\n\t\t\t} else {\n\t\t\t\tsetColor('red');\n\t\t\t}\n\t\t} else {\n\t\t\tsetColor('black');\n\t\t}\n\n\t\treturn isValid;\n\t}, []);\n\n\tconst creditCardMask: MaskedInputProps['mask'] = useMemo(\n\t\t() => ({\n\t\t\tmask: '9999 9999 9999 9999',\n\t\t\tisComplete: checkValidation,\n\t\t\tautoUnmask: true,\n\t\t}),\n\t\t[checkValidation],\n\t);\n\n\tconst cardNumberRef = useMaskedInput({\n\t\tmask: creditCardMask,\n\t\tvalue,\n\t\tonChange: v => {\n\t\t\tconst typ = creditCardType(v || '');\n\t\t\td(v, typ);\n\t\t\t// checkValidation([v || '']);\n\t\t\tonChange && onChange(v);\n\t\t},\n\t});\n\n\treturn (\n\t\t<Input {...rest} icon>\n\t\t\t<input ref={cardNumberRef} />\n\t\t\t<Icon name={icon} color={color} size=\"large\" />\n\t\t</Input>\n\t);\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA,wBAAwB,uDAAyD;AACjF;AACA;AACA;AACA;AACA;"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import React, { Children, cloneElement } from 'react';
|
|
2
|
-
import debug from 'debug';
|
|
3
|
-
import { Form, FormRadio, Radio } from 'semantic-ui-react';
|
|
4
|
-
|
|
5
|
-
debug("thx.controls.inputs.RadioGroup");
|
|
6
|
-
function RadioGroup(props) {
|
|
7
|
-
const { children, onChange, value, ...rest } = props;
|
|
8
|
-
return /* @__PURE__ */ React.createElement(Form.Group, {
|
|
9
|
-
...rest
|
|
10
|
-
}, Children.map(props.children, (child) => {
|
|
11
|
-
if (child?.type === FormRadio || child?.type === Radio || child?.type === Form.Radio) {
|
|
12
|
-
return cloneElement(child, {
|
|
13
|
-
onChange: (ev, args) => {
|
|
14
|
-
if (onChange)
|
|
15
|
-
onChange(args.value);
|
|
16
|
-
},
|
|
17
|
-
checked: value === child.props.value
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
return child;
|
|
21
|
-
}));
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export { RadioGroup };
|
|
25
|
-
//# sourceMappingURL=RadioGroup.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RadioGroup.js","sources":["../../../../src/inputs/RadioGroup/RadioGroup.tsx"],"sourcesContent":["import debug from 'debug';\nimport {Children, cloneElement} from 'react';\nimport {Form, Radio, FormRadio, FormGroupProps} from 'semantic-ui-react';\n\nconst d = debug('thx.controls.inputs.RadioGroup');\n\nexport interface RadioGroupProps {\n\tchildren?: JSX.Element[] | JSX.Element;\n\tonChange?: (value?: string | number) => void;\n\tvalue?: string | number;\n}\n\nexport function RadioGroup(props: RadioGroupProps & Omit<FormGroupProps, 'children'>) {\n\tconst {children, onChange, value, ...rest} = props;\n\n\treturn (\n\t\t<Form.Group {...rest}>\n\t\t\t{Children.map(props.children, child => {\n\t\t\t\tif (child?.type === FormRadio || child?.type === Radio || child?.type === Form.Radio) {\n\t\t\t\t\treturn cloneElement(child, {\n\t\t\t\t\t\tonChange: (ev: any, args: {value?: string | number}) => {\n\t\t\t\t\t\t\tif (onChange) onChange(args.value);\n\t\t\t\t\t\t},\n\t\t\t\t\t\tchecked: value === child.props.value,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\treturn child;\n\t\t\t})}\n\t\t</Form.Group>\n\t);\n}\n"],"names":[],"mappings":";;;;AAIU,MAAM,gCAAgC,EAAA;AAQzC,SAAA,UAAA,CAAoB,KAA2D,EAAA;AACrF,EAAA,MAAM,EAAC,QAAA,EAAU,QAAU,EAAA,KAAA,EAAA,GAAU,IAAQ,EAAA,GAAA,KAAA,CAAA;AAE7C,EACC,uBAAA,KAAA,CAAA,aAAA,CAAC,KAAK,KAAL,EAAA;AAAA,IAAe,GAAA,IAAA;AAAA,GAAA,EACd,QAAS,CAAA,GAAA,CAAI,KAAM,CAAA,QAAA,EAAU,CAAS,KAAA,KAAA;AACtC,IAAI,IAAA,KAAA,EAAO,SAAS,SAAa,IAAA,KAAA,EAAO,SAAS,KAAS,IAAA,KAAA,EAAO,IAAS,KAAA,IAAA,CAAK,KAAO,EAAA;AACrF,MAAA,OAAO,aAAa,KAAO,EAAA;AAAA,QAC1B,QAAA,EAAU,CAAC,EAAA,EAAS,IAAoC,KAAA;AACvD,UAAI,IAAA,QAAA;AAAU,YAAA,QAAA,CAAS,KAAK,KAAK,CAAA,CAAA;AAAA,SAClC;AAAA,QACA,OAAA,EAAS,KAAU,KAAA,KAAA,CAAM,KAAM,CAAA,KAAA;AAAA,OAC/B,CAAA,CAAA;AAAA,KACF;AACA,IAAO,OAAA,KAAA,CAAA;AAAA,GACP,CACF,CAAA,CAAA;AAEF;;;;"}
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import React, { useRef, useState, useEffect, useMemo } from 'react';
|
|
2
|
-
import debug from 'debug';
|
|
3
|
-
import { ScriptelContext } from './ScriptelContext.js';
|
|
4
|
-
import { ScriptelSocket } from './scriptel/index.js';
|
|
5
|
-
|
|
6
|
-
debug("thx.controls.inputs.Scriptel");
|
|
7
|
-
function Scriptel({ omniscriptUrl, imageType, scale, crop, penStyle, children }) {
|
|
8
|
-
const socket = useRef();
|
|
9
|
-
const [render, setRender] = useState();
|
|
10
|
-
const [loading, setLoading] = useState(false);
|
|
11
|
-
const [isSigning, setIsSigning] = useState(false);
|
|
12
|
-
useEffect(() => {
|
|
13
|
-
socket.current = new ScriptelSocket({
|
|
14
|
-
omniscriptUrl,
|
|
15
|
-
imageType,
|
|
16
|
-
scale,
|
|
17
|
-
crop,
|
|
18
|
-
penStyle
|
|
19
|
-
});
|
|
20
|
-
socket.current.on("render", (msg) => {
|
|
21
|
-
setRender(msg);
|
|
22
|
-
setLoading(false);
|
|
23
|
-
setRender(void 0);
|
|
24
|
-
});
|
|
25
|
-
socket.current.on("okButtonDown", () => {
|
|
26
|
-
setLoading(true);
|
|
27
|
-
});
|
|
28
|
-
socket.current.on("cancel", () => {
|
|
29
|
-
setLoading(false);
|
|
30
|
-
setRender(void 0);
|
|
31
|
-
});
|
|
32
|
-
socket.current.on("penMove", () => {
|
|
33
|
-
setIsSigning(true);
|
|
34
|
-
});
|
|
35
|
-
socket.current.on("penUp", () => {
|
|
36
|
-
setIsSigning(false);
|
|
37
|
-
});
|
|
38
|
-
return () => {
|
|
39
|
-
if (socket.current)
|
|
40
|
-
socket.current.close();
|
|
41
|
-
};
|
|
42
|
-
}, [omniscriptUrl, imageType, scale, crop, penStyle]);
|
|
43
|
-
const scriptel = useMemo(() => {
|
|
44
|
-
return { socket, renderImage: render, loading, isSigning };
|
|
45
|
-
}, [isSigning, loading, render]);
|
|
46
|
-
return /* @__PURE__ */ React.createElement(ScriptelContext.Provider, {
|
|
47
|
-
value: scriptel
|
|
48
|
-
}, children);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export { Scriptel };
|
|
52
|
-
//# sourceMappingURL=Scriptel.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Scriptel.js","sources":["../../../../src/inputs/Scriptel/Scriptel.tsx"],"sourcesContent":["import debug from 'debug';\nimport {useEffect, useMemo, useRef, useState} from 'react';\nimport {ScriptelContext} from './ScriptelContext';\nimport {ScriptelSocket} from './scriptel';\nimport type {ScriptelPenStyle} from './scriptel/enums';\nimport type {RenderedImage} from './scriptel/messages';\n\nconst d = debug('thx.controls.inputs.Scriptel');\n\nexport interface ScriptelProps {\n\tomniscriptUrl?: string; // Defaults to 'ws://localhost:8080'\n\timageType?: string; // Defaults to 'image/svg+xml'.\n\tscale?: number; // Defaults to 1\n\tcrop?: boolean; // Defaults to false\n\tpenStyle?: ScriptelPenStyle; // Defaults to 'PlainPenStyle'\n\tchildren: JSX.Element | JSX.Element[];\n}\n\nexport function Scriptel({omniscriptUrl, imageType, scale, crop, penStyle, children}: ScriptelProps) {\n\tconst socket = useRef<ScriptelSocket>();\n\tconst [render, setRender] = useState<RenderedImage>();\n\tconst [loading, setLoading] = useState<boolean>(false);\n\tconst [isSigning, setIsSigning] = useState<boolean>(false);\n\n\tuseEffect(() => {\n\t\tsocket.current = new ScriptelSocket({\n\t\t\tomniscriptUrl,\n\t\t\timageType,\n\t\t\tscale,\n\t\t\tcrop,\n\t\t\tpenStyle,\n\t\t});\n\n\t\tsocket.current.on('render', msg => {\n\t\t\tsetRender(msg);\n\t\t\tsetLoading(false);\n\t\t\tsetRender(undefined); // todo look at this in future\n\t\t});\n\t\tsocket.current.on('okButtonDown', () => {\n\t\t\tsetLoading(true);\n\t\t});\n\t\tsocket.current.on('cancel', () => {\n\t\t\tsetLoading(false);\n\t\t\tsetRender(undefined);\n\t\t});\n\t\tsocket.current.on('penMove', () => {\n\t\t\tsetIsSigning(true);\n\t\t});\n\t\tsocket.current.on('penUp', () => {\n\t\t\tsetIsSigning(false);\n\t\t});\n\n\t\treturn () => {\n\t\t\tif (socket.current) socket.current.close();\n\t\t};\n\t}, [omniscriptUrl, imageType, scale, crop, penStyle]);\n\n\tconst scriptel = useMemo(() => {\n\t\treturn {socket, renderImage: render, loading, isSigning};\n\t}, [isSigning, loading, render]);\n\n\treturn <ScriptelContext.Provider value={scriptel}>{children}</ScriptelContext.Provider>;\n}\n"],"names":[],"mappings":";;;;;AAOU,MAAM,8BAA8B,EAAA;AAWvC,SAAA,QAAA,CAAkB,EAAC,aAAe,EAAA,SAAA,EAAW,KAAO,EAAA,IAAA,EAAM,UAAU,QAA0B,EAAA,EAAA;AACpG,EAAA,MAAM,SAAS,MAAuB,EAAA,CAAA;AACtC,EAAM,MAAA,CAAC,MAAQ,EAAA,SAAA,CAAA,GAAa,QAAwB,EAAA,CAAA;AACpD,EAAA,MAAM,CAAC,OAAA,EAAS,UAAc,CAAA,GAAA,QAAA,CAAkB,KAAK,CAAA,CAAA;AACrD,EAAA,MAAM,CAAC,SAAA,EAAW,YAAgB,CAAA,GAAA,QAAA,CAAkB,KAAK,CAAA,CAAA;AAEzD,EAAA,SAAA,CAAU,MAAM;AACf,IAAO,MAAA,CAAA,OAAA,GAAU,IAAI,cAAe,CAAA;AAAA,MACnC,aAAA;AAAA,MACA,SAAA;AAAA,MACA,KAAA;AAAA,MACA,IAAA;AAAA,MACA,QAAA;AAAA,KACA,CAAA,CAAA;AAED,IAAO,MAAA,CAAA,OAAA,CAAQ,EAAG,CAAA,QAAA,EAAU,CAAO,GAAA,KAAA;AAClC,MAAA,SAAA,CAAU,GAAG,CAAA,CAAA;AACb,MAAA,UAAA,CAAW,KAAK,CAAA,CAAA;AAChB,MAAA,SAAA,CAAU,KAAS,CAAA,CAAA,CAAA;AAAA,KACnB,CAAA,CAAA;AACD,IAAO,MAAA,CAAA,OAAA,CAAQ,EAAG,CAAA,cAAA,EAAgB,MAAM;AACvC,MAAA,UAAA,CAAW,IAAI,CAAA,CAAA;AAAA,KACf,CAAA,CAAA;AACD,IAAO,MAAA,CAAA,OAAA,CAAQ,EAAG,CAAA,QAAA,EAAU,MAAM;AACjC,MAAA,UAAA,CAAW,KAAK,CAAA,CAAA;AAChB,MAAA,SAAA,CAAU,KAAS,CAAA,CAAA,CAAA;AAAA,KACnB,CAAA,CAAA;AACD,IAAO,MAAA,CAAA,OAAA,CAAQ,EAAG,CAAA,SAAA,EAAW,MAAM;AAClC,MAAA,YAAA,CAAa,IAAI,CAAA,CAAA;AAAA,KACjB,CAAA,CAAA;AACD,IAAO,MAAA,CAAA,OAAA,CAAQ,EAAG,CAAA,OAAA,EAAS,MAAM;AAChC,MAAA,YAAA,CAAa,KAAK,CAAA,CAAA;AAAA,KAClB,CAAA,CAAA;AAED,IAAA,OAAO,MAAM;AACZ,MAAA,IAAI,MAAO,CAAA,OAAA;AAAS,QAAA,MAAA,CAAO,QAAQ,KAAM,EAAA,CAAA;AAAA,KAC1C,CAAA;AAAA,KACE,CAAC,aAAA,EAAe,WAAW,KAAO,EAAA,IAAA,EAAM,QAAQ,CAAC,CAAA,CAAA;AAEpD,EAAM,MAAA,QAAA,GAAW,QAAQ,MAAM;AAC9B,IAAA,OAAO,EAAC,MAAA,EAAQ,WAAa,EAAA,MAAA,EAAQ,SAAS,SAAS,EAAA,CAAA;AAAA,GACrD,EAAA,CAAC,SAAW,EAAA,OAAA,EAAS,MAAM,CAAC,CAAA,CAAA;AAE/B,EAAO,uBAAA,KAAA,CAAA,aAAA,CAAC,gBAAgB,QAAhB,EAAA;AAAA,IAAyB,KAAO,EAAA,QAAA;AAAA,GAAA,EAAW,QAAS,CAAA,CAAA;AAC7D;;;;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ScriptelContext.js","sources":["../../../../src/inputs/Scriptel/ScriptelContext.ts"],"sourcesContent":["import {createContext, MutableRefObject} from 'react';\nimport type {ScriptelSocket} from './scriptel';\nimport type {RenderedImage} from './scriptel/messages';\n\nexport const ScriptelContext = createContext<\n\t{socket: MutableRefObject<ScriptelSocket | undefined>; renderImage: RenderedImage | undefined; loading: boolean; isSigning: boolean} | undefined\n>(undefined);\n"],"names":[],"mappings":";;AAIa,MAAA,eAAA,GAAkB,cAE7B,KAAS,CAAA;;;;"}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
var ScriptelPenStyle = /* @__PURE__ */ ((ScriptelPenStyle2) => {
|
|
2
|
-
ScriptelPenStyle2["Plain"] = "PlainPenStyle";
|
|
3
|
-
ScriptelPenStyle2["Chisel"] = "ChiselPenStyle";
|
|
4
|
-
ScriptelPenStyle2["Inkwell"] = "InkwellPenStyle";
|
|
5
|
-
return ScriptelPenStyle2;
|
|
6
|
-
})(ScriptelPenStyle || {});
|
|
7
|
-
var ScriptelMessageClass = /* @__PURE__ */ ((ScriptelMessageClass2) => {
|
|
8
|
-
ScriptelMessageClass2["ConnectionOpen"] = "ConnectionOpen";
|
|
9
|
-
ScriptelMessageClass2["DeviceOpenRequest"] = "DeviceOpenRequest";
|
|
10
|
-
ScriptelMessageClass2["DeviceOpenResponse"] = "DeviceOpenResponse";
|
|
11
|
-
ScriptelMessageClass2["RenderedImage"] = "RenderedImage";
|
|
12
|
-
ScriptelMessageClass2["ScriptelException"] = "ScriptelException";
|
|
13
|
-
ScriptelMessageClass2["ButtonDown"] = "ButtonDown";
|
|
14
|
-
ScriptelMessageClass2["ButtonPress"] = "ButtonPress";
|
|
15
|
-
ScriptelMessageClass2["PenMove"] = "PenMove";
|
|
16
|
-
ScriptelMessageClass2["PenUp"] = "PenUp";
|
|
17
|
-
return ScriptelMessageClass2;
|
|
18
|
-
})(ScriptelMessageClass || {});
|
|
19
|
-
|
|
20
|
-
export { ScriptelMessageClass, ScriptelPenStyle };
|
|
21
|
-
//# sourceMappingURL=enums.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"enums.js","sources":["../../../../../src/inputs/Scriptel/scriptel/enums.ts"],"sourcesContent":["export enum ScriptelPenStyle {\n\tPlain = 'PlainPenStyle',\n\tChisel = 'ChiselPenStyle',\n\tInkwell = 'InkwellPenStyle',\n}\n\nexport enum ScriptelMessageClass {\n\tConnectionOpen = 'ConnectionOpen',\n\tDeviceOpenRequest = 'DeviceOpenRequest',\n\tDeviceOpenResponse = 'DeviceOpenResponse',\n\tRenderedImage = 'RenderedImage',\n\tScriptelException = 'ScriptelException',\n\tButtonDown = 'ButtonDown',\n\tButtonPress = 'ButtonPress',\n\tPenMove = 'PenMove',\n\tPenUp = 'PenUp',\n}\n"],"names":[],"mappings":"AAAY,IAAA,gBAAA,qBAAA,iBAAL,KAAA;AACN,EAAQ,iBAAA,CAAA,OAAA,CAAA,GAAA,eAAA,CAAA;AACR,EAAS,iBAAA,CAAA,QAAA,CAAA,GAAA,gBAAA,CAAA;AACT,EAAU,iBAAA,CAAA,SAAA,CAAA,GAAA,iBAAA,CAAA;AAHC,EAAA,OAAA,iBAAA,CAAA;AAAA,CAAA,EAAA,gBAAA,IAAA,EAAA,EAAA;AAMA,IAAA,oBAAA,qBAAA,qBAAL,KAAA;AACN,EAAiB,qBAAA,CAAA,gBAAA,CAAA,GAAA,gBAAA,CAAA;AACjB,EAAoB,qBAAA,CAAA,mBAAA,CAAA,GAAA,mBAAA,CAAA;AACpB,EAAqB,qBAAA,CAAA,oBAAA,CAAA,GAAA,oBAAA,CAAA;AACrB,EAAgB,qBAAA,CAAA,eAAA,CAAA,GAAA,eAAA,CAAA;AAChB,EAAoB,qBAAA,CAAA,mBAAA,CAAA,GAAA,mBAAA,CAAA;AACpB,EAAa,qBAAA,CAAA,YAAA,CAAA,GAAA,YAAA,CAAA;AACb,EAAc,qBAAA,CAAA,aAAA,CAAA,GAAA,aAAA,CAAA;AACd,EAAU,qBAAA,CAAA,SAAA,CAAA,GAAA,SAAA,CAAA;AACV,EAAQ,qBAAA,CAAA,OAAA,CAAA,GAAA,OAAA,CAAA;AATG,EAAA,OAAA,qBAAA,CAAA;AAAA,CAAA,EAAA,oBAAA,IAAA,EAAA;;;;"}
|