yup date validation - Start Date must not be same as end date
Asked Answered
F

2

5

I am currently stuck on how to do validation with yup for same date.

Currently I am able to validate if endDate is not before startDate using :

schema = yup.object().shape({
  startDate: yup.date().min(new Date(),'Please choose future date'),
  endDate: yup
          .date()
          .min(
             yup.ref("startDate"),
             "End date has to be more than start date"
          ),
})

But it is not checking for same date. I am well aware of this thread : Date range validation - Start Date must not be same as End Date in jquense / yup , but it is not solved yet and using momentjs. My company is strictly using dayjs for this project.

I hope you can help me with solution using JS or dayjs.

Thanks !

Frequentative answered 16/11, 2021 at 7:12 Comment(0)
A
7

You can use this:

schema = yup.object().shape({
  startDate: yup.date().min(new Date(),'Please choose future date'),    
  endDate: yup
              .date()    
              .when('startDate',
                            (startDate, schema) => {
                                if (startDate) {
                                const dayAfter = new Date(startDate.getTime() + 86400000);
                              
                                    return schema.min(dayAfter, 'End date has to be after than start date');
                                  }
                              
                                  return schema;
                                
                            }),
})
Atrophied answered 30/11, 2021 at 11:23 Comment(2)
this does not consider the same day time. How to include it?Rsfsr
"const dayAfter = new Date(startDate.getTime());" this will solve the usage issueAtrophied
G
6

Here is a solution that worked for me.


const validationSchema = Yup.object({
  startDate: Yup.date().required(),
  endDate: Yup.date().test(
    "same_dates_test",
    "Start and end dates must not be equal.",
    function (value) {
      const { startDate } = this.parent;
      return value.getTime() !== startDate.getTime();
    }
  ),
});

Grenoble answered 23/4, 2022 at 16:55 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.