feat: add fieldMapToTime prop to FormRenderProps (#4838)

pull/48/MERGE
huangxiaomin 2024-11-09 14:08:46 +08:00 committed by GitHub
parent 2c6edafeb2
commit 6b9acf09dc
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 90 additions and 2 deletions

View File

@ -52,20 +52,92 @@ async function handleSubmit(e: Event) {
if (!valid) { if (!valid) {
return; return;
} }
await unref(rootProps).handleSubmit?.(toRaw(form.values));
const values = handleRangeTimeValue(toRaw(form.values));
await unref(rootProps).handleSubmit?.(values);
} }
async function handleReset(e: Event) { async function handleReset(e: Event) {
e?.preventDefault(); e?.preventDefault();
e?.stopPropagation(); e?.stopPropagation();
const props = unref(rootProps); const props = unref(rootProps);
const values = toRaw(form.values);
//
props.fieldMapToTime &&
props.fieldMapToTime.forEach(([_, [startTimeKey, endTimeKey]]) => {
delete values[startTimeKey];
delete values[endTimeKey];
});
if (isFunction(props.handleReset)) { if (isFunction(props.handleReset)) {
await props.handleReset?.(form.values); await props.handleReset?.(values);
} else { } else {
form.resetForm(); form.resetForm();
} }
} }
function handleRangeTimeValue(values: Record<string, any>) {
const fieldMapToTime = unref(rootProps).fieldMapToTime;
if (!fieldMapToTime) return values;
if (!Array.isArray(fieldMapToTime)) {
return values;
}
fieldMapToTime.forEach(
([field, [startTimeKey, endTimeKey], format = 'YYYY-MM-DD']) => {
if (!values[field]) {
delete values[field];
return;
}
const [startTime, endTime] = values[field];
const [startTimeFormat, endTimeFormat] = Array.isArray(format)
? format
: [format, format];
values[startTimeKey] = startTime
? formatTime(startTime, startTimeFormat)
: undefined;
values[endTimeKey] = endTime
? formatTime(endTime, endTimeFormat)
: undefined;
delete values[field];
},
);
return values;
}
function formatTime(time: string, format: string): number | string {
const date = new Date(time);
const timestamp = (date: Date) => Math.floor(date.getTime() / 1000);
if (format === 'timestamp') return timestamp(date);
if (format === 'timestampStartDay')
return timestamp(
new Date(date.getFullYear(), date.getMonth(), date.getDate()),
);
const padZero = (num: number) => num.toString().padStart(2, '0');
const replacements: Record<string, string> = {
DD: padZero(date.getDate()),
HH: padZero(date.getHours()),
MM: padZero(date.getMonth() + 1),
mm: padZero(date.getMinutes()),
ss: padZero(date.getSeconds()),
YYYY: date.getFullYear().toString(),
};
return format.replaceAll(
/YYYY|MM|DD|HH|mm|ss/g,
(match) => replacements[match] || match,
);
}
watch( watch(
() => collapsed.value, () => collapsed.value,
() => { () => {

View File

@ -206,6 +206,12 @@ export type HandleResetFn = (
values: Record<string, any>, values: Record<string, any>,
) => Promise<void> | void; ) => Promise<void> | void;
export type FieldMapToTime = [
string,
[string, string],
([string, string] | string)?,
][];
export interface FormSchema< export interface FormSchema<
T extends BaseFormComponentType = BaseFormComponentType, T extends BaseFormComponentType = BaseFormComponentType,
> extends FormCommonConfig { > extends FormCommonConfig {
@ -266,6 +272,10 @@ export interface FormRenderProps<
* *
*/ */
componentMap: Record<BaseFormComponentType, Component>; componentMap: Record<BaseFormComponentType, Component>;
/**
*
*/
fieldMapToTime?: FieldMapToTime;
/** /**
* *
*/ */

View File

@ -21,6 +21,7 @@ interface RowType {
const formOptions: VbenFormProps = { const formOptions: VbenFormProps = {
// //
collapsed: false, collapsed: false,
fieldMapToTime: [['dateRangePicker', ['startTime', 'endTime'], 'YYYY-MM']],
schema: [ schema: [
{ {
component: 'Input', component: 'Input',
@ -62,6 +63,11 @@ const formOptions: VbenFormProps = {
fieldName: 'datePicker', fieldName: 'datePicker',
label: 'Date', label: 'Date',
}, },
{
component: 'RangePicker',
fieldName: 'dateRangePicker',
label: 'DateRange',
},
], ],
// //
showCollapseButton: true, showCollapseButton: true,