Skip to content
This repository was archived by the owner on Apr 12, 2024. It is now read-only.

fix(input): remove $$invalidModelValue and always set $modelValue to the... #9002

Closed
wants to merge 1 commit into from

Conversation

Narretz
Copy link
Contributor

@Narretz Narretz commented Sep 9, 2014

... parser result

BREAKING CHANGE:

$modelValue is now always set to the result of $parsers, even if
validation fails. Setting it to undefined was a remnant of the old parsers-for-validation behavior. The new behavior is more consistent: if you modify the validity state of the control, the $modelValue itself is not changed.

If you relied on $modelValue becoming undefined when invalid, e.g. in
a $watch, you must now use the $valid property of ngModelController.

…the parser result

BREAKING CHANGE:

$modelValue is now always set to the result of $parsers, even if
validation fails. Setting it to undefined was a remnant of the old
parsers-for-validation behavior. The new behavior is more consistent.

If you relied on $modelValue becoming undefined when invalid, e.g. in
a $watch, you must now use the $valid property of ngModelController.
@Narretz
Copy link
Contributor Author

Narretz commented Sep 9, 2014

@shahata Can you have a look? Unfortunately, @tbosch has decided that always setting $modelValue to parser result is a bad idea (#8357 (comment))

@shahata
Copy link
Contributor

shahata commented Sep 9, 2014

@Narretz it seems @tbosch also took care of that in #9003

@tbosch tbosch closed this Sep 9, 2014
@tbosch tbosch reopened this Sep 9, 2014
@tbosch
Copy link
Contributor

tbosch commented Sep 9, 2014

Forget my previous comment...

@shahata I would like to keep the previous behavior of ctrl.$modelValue to always be the value that is present in the scope. If you need the invalid value, the ngOptions.allowInvalid of the PR from @shahata should do the trick.

Please post if there is a use case where this does not work.

@tbosch tbosch closed this Sep 9, 2014
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants