Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Validate date dd/mm/yyyy

I have a past date for a textbox, and when I want to validate the form submit if the date is greater than the current date and has the format dd/mm/yyyy.

in my form_validation.php:

'add_prod_serv_fact' => array(
    'quantidade_prod'           => array('field' => 'quantidade_prod',          'label' => 'Quantidade',        'rules' => 'required|trim|numeric|greater_than[0]|htmlspecialchars'),
    'desconto_prod'             => array('field' => 'desconto_prod',            'label' => 'Desconto',          'rules' => 'required|trim|numeric|greater_than[-1]|less_than[101]|htmlspecialchars'),
    'date'                      => array('field' => 'date',                     'label' => 'Date',              'rules' => 'required|trim|htmlspecialchars')
)

How do I validate the date?

like image 459
pc_oc Avatar asked Dec 20 '22 03:12

pc_oc


2 Answers

You can validate through regular expression first you should write a function like this

function validate_date_reg($input)
{
   if (preg_match('\d{1,2}/\d{1,2}/\d{4}', $input))
   {
      return true; // it matched, return true
   }
   else
   {
      return false;
   }
}

and call it like this:

if($this->validate_date_reg($this->input->post('some_data')))
{
    // true go ahead......
}

i hope that this will help you.

like image 70
MJ X Avatar answered Jan 08 '23 21:01

MJ X


1) How to validate a date with CI callbacks:

"The validation system supports callbacks to your own validation functions. This permits you to extend the validation class to meet your needs."

In your method:

$this->form_validation->set_rules('text_date', 'Date', 'trim|exact_length[10]|callback_validate_date');

Your own callback function:

public function validate_date($incoming_date)
{
    //If in dd/mm/yyyy format
    if (preg_match("^\d{2}/\d{2}/\d{4}^", $incoming_date))
    {
        //Extract date into array
        $date_array = explode('/', $incoming_date);

        //If it is not a date
        if(! checkdate($date_array[1], $date_array[0], $date_array[2]))
        {
            $this->form_validation->set_message('validate_date', 'Invalid date');
            return false;
        }
    }
    //If not in dd/mm/yyyy format
    else
    {
        $this->form_validation->set_message('validate_date', 'Invalid date');
        return false;
    }

    return true;
}

2) How to compare two dates:

$date_one = (int) strtotime(str_replace('/', '-', $this->input->post('date_one', true)));
$date_two = (int) strtotime(str_replace('/', '-', $this->input->post('date_two', true)));

if($date_one < $date_two)
{
    echo 'Message';
}
else
{
    echo 'Message';
}
like image 28
BentCoder Avatar answered Jan 08 '23 22:01

BentCoder