Skip to content
This repository has been archived by the owner on May 29, 2019. It is now read-only.

bug(datepicker): input manually -> invalid or day/month is switched #956

Closed
wemove opened this issue Sep 6, 2013 · 10 comments
Closed

bug(datepicker): input manually -> invalid or day/month is switched #956

wemove opened this issue Sep 6, 2013 · 10 comments

Comments

@wemove
Copy link

wemove commented Sep 6, 2013

Hello,

I want to be able to enter the date manually (to quickly set the year or paste some other date). This seems to work partially with Chrome, but not with Firefox as you can see with this fiddle (this fiddle only works with Firefox, since Chrome does not load all resources!):

http://jsfiddle.net/BVufZ/5/

Moreover in Chrome when I use an input field with the datepicker-popup and the option:

datepicker-popup="dd.MM.yyyy"

then the day and month value are interpreted wrong when changing the date manually in the input field. With the option:

datepicker-popup="dd.MMMM.yyyy"

everything works fine, but I don't want the name of the month!

Can you confirm this problem?
Thanks!

@bekos
Copy link
Contributor

bekos commented Sep 6, 2013

Hi @wemove. Have not played with your fiddle but you have to know that datepicker-popup format is used only to output values. When you want to manually alter the date then your value in the <input> is parsed from the standard Date object, so your requested format is not recognized.

To solve your problem you have to inject another $parser (with another directive) to transform from your format to a format that Date understands correctly. I hope I have helped, if your talking about something else, i will look into this one later.

@wemove
Copy link
Author

wemove commented Sep 6, 2013

Thanks for the quick answer! With a directive and doing something like this:

ngModel.$parsers.push(function(data) {
    // convert data from view format to model format
    var splitted = data.split('.');
    var convertedDate = splitted[1] + "/" + splitted[0] + "/" + splitted[2];
    return new Date(Date.parse(convertedDate)); // converted
});

I was able to fix my problem to enter a date manually.

Have a good day!

@wemove wemove closed this as completed Sep 6, 2013
@MattiJarvinen-BA
Copy link

So this would be open issue still. Since there is

      // TODO: reverse from dateFilter string to Date object
      function parseDate(viewValue) {

and this issue is unresolved.

Perhaps something can be used from http://momentjs.com/docs/#/parsing/string-format/

@bekos
Copy link
Contributor

bekos commented Sep 20, 2013

@MattiJarvinen This comment was left as a note to my future self or anyone reading the code and is willing to help. Everything works as supposed to. The "problem" is that we are missing a proper date parser, similar to the jQuery UI's parser that ui-date is using, and would make peoples lives easier.

You are right that we can borrow "ideas" for moment's parsing, and if you (or anyone) want to implement or help to implement a dateParser that reverses the work of dateFilter that would be really awesome, at least for me :-)

@Sjors
Copy link

Sjors commented Nov 29, 2013

@wemove can you explain a bit more how you did this? I tried this:

angular.module("MyAppName").directive('eudate', function() {
    return {
      restrict: 'A',
      require: '?ngModel',
      link: function(scope, element, attrs, ngModel) {
        if(!ngModel) return; 

        ngModel.$parsers.push(function(data) {
            // convert data from view format to model format
            var splitted = data.split('.');
            var convertedDate = splitted[1] + "/" + splitted[0] + "/" + splitted[2];
            return new Date(Date.parse(convertedDate)); // converted
        });
      }
    };
  });

I then added the attribute "eudate" to my date picker.

But when I modify the date I'm seeing:

TypeError: Object [object Date] has no method 'split'

@wemove
Copy link
Author

wemove commented Nov 29, 2013

@Sjors Please have a look at my blog, where I added a complete directive. I admit that it's not that beautiful, but it works well for me: http://developer.the-hideout.de/?p=119

@Sjors
Copy link

Sjors commented Nov 29, 2013

@wemove thanks, that works! In my case I'm using "dd/MM/yyyy" as the format, but that was just a matter of modifying the format === "dd.MM.yyyy" and newDate.split('/') lines.

@kasuparu
Copy link

kasuparu commented Dec 9, 2013

@wemove Thank you for the great fix (http://developer.the-hideout.de/?p=119). Just wanted to add that it requires jQuery to function properly, as element.on(...) makes use of eventData argument, not supported by jqLite.

@julienmeyer
Copy link

@bekos a dateParser exists : https://github.com/dnasir/angular-dateParser

@bekos
Copy link
Contributor

bekos commented Jan 15, 2014

@julienmeyer I know #1430. We can continue there if you want to share your opinion.

codedogfish pushed a commit to codedogfish/angular-ui-bootstrap that referenced this issue Sep 15, 2015
Protect against empty selection causing exception when getting placeHolder
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants