From 95eb7ceabeaafae71dede13e7bec007228ab7548 Mon Sep 17 00:00:00 2001 From: Miles Malerba Date: Tue, 21 Mar 2017 10:24:07 -0700 Subject: [PATCH] fix(input): make sure injected NgControl belongs to the input --- src/lib/input/input-container.ts | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/src/lib/input/input-container.ts b/src/lib/input/input-container.ts index bbc7c0a15b91..d11b5a67f207 100644 --- a/src/lib/input/input-container.ts +++ b/src/lib/input/input-container.ts @@ -1,26 +1,27 @@ import { - Component, - Input, - Directive, AfterContentInit, + Component, ContentChild, ContentChildren, + Directive, ElementRef, - QueryList, - ViewEncapsulation, + EventEmitter, + Input, Optional, Output, - EventEmitter, - Renderer + QueryList, + Renderer, + Self, + ViewEncapsulation } from '@angular/core'; import {coerceBooleanProperty} from '../core'; import {NgControl} from '@angular/forms'; import {getSupportedInputTypes} from '../core/platform/features'; import { - MdInputContainerUnsupportedTypeError, - MdInputContainerPlaceholderConflictError, MdInputContainerDuplicatedHintError, - MdInputContainerMissingMdInputError + MdInputContainerMissingMdInputError, + MdInputContainerPlaceholderConflictError, + MdInputContainerUnsupportedTypeError } from './input-container-errors'; @@ -181,7 +182,7 @@ export class MdInputDirective { constructor(private _elementRef: ElementRef, private _renderer: Renderer, - @Optional() public _ngControl: NgControl) { + @Optional() @Self() public _ngControl: NgControl) { // Force setter to be called in case id was not specified. this.id = this.id;