Propagating View's Dirty State To The Containing Form
Solution 1:
Quote from Angular documentation on the form directive:
In Angular, forms can be nested. This means that the outer form is valid when all of the child forms are valid as well. However, browsers do not allow nesting of elements, so Angular provides the ngForm directive which behaves identically to but can be nested. This allows you to have nested forms, which is very useful when using Angular validation directives in forms that are dynamically generated using the ngRepeat directive. Since you cannot dynamically generate the name attribute of input elements using interpolation, you have to wrap each set of repeated inputs in an ngForm directive and nest these in an outer form element.
Maybe this also works for the $dirty
state so that if a child form is $dirty
the parent form will also be $dirty
. I'm not sure that in your case you'll be able to nest the forms. I don't have enough context to visualise what you want to achieve.
Alternatively, you can manually set the main form to dirty when one of those other forms becomes dirty. Because you added the code from your main form, I can see you're not using the built in dirty checker from angular. Maybe you have a good reason for this, but perhaps you didn't know of it's existence. You'll have to use the angular form directive then. The FormController
has the following method: $setDirty();
.
Post a Comment for "Propagating View's Dirty State To The Containing Form"