From e880105600e068150d350379006e3eea9639ba9b Mon Sep 17 00:00:00 2001 From: Paul Crowder Date: Wed, 17 Jan 2018 16:12:09 -0500 Subject: [PATCH 1/3] Removed OnPush change detection from definition list value component MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This is so the template will re-evaluate the length of the value’s `innerText` element when changes occur to the parent component. Fixes #967 --- .../definition-list-value.component.ts | 4 +-- .../definition-list.component.spec.ts | 29 +++++++++++++++++++ 2 files changed, 30 insertions(+), 3 deletions(-) diff --git a/src/modules/definition-list/definition-list-value.component.ts b/src/modules/definition-list/definition-list-value.component.ts index d06cdd389..75dacd76f 100644 --- a/src/modules/definition-list/definition-list-value.component.ts +++ b/src/modules/definition-list/definition-list-value.component.ts @@ -1,5 +1,4 @@ import { - ChangeDetectionStrategy, Component } from '@angular/core'; @@ -8,8 +7,7 @@ import { SkyDefinitionListService } from './definition-list.service'; @Component({ selector: 'sky-definition-list-value', templateUrl: './definition-list-value.component.html', - styleUrls: ['./definition-list-value.component.scss'], - changeDetection: ChangeDetectionStrategy.OnPush + styleUrls: ['./definition-list-value.component.scss'] }) export class SkyDefinitionListValueComponent { public defaultValue: string; diff --git a/src/modules/definition-list/definition-list.component.spec.ts b/src/modules/definition-list/definition-list.component.spec.ts index ea0d21085..21a1a0958 100644 --- a/src/modules/definition-list/definition-list.component.spec.ts +++ b/src/modules/definition-list/definition-list.component.spec.ts @@ -28,6 +28,10 @@ describe('Definition list component', () => { return listEl.querySelectorAll('sky-definition-list-value .sky-definition-list-value'); } + function getDefaultValueEl(valueEl: Element): Element { + return valueEl.querySelector('.sky-deemphasized'); + } + it('should render the heading in the expected location', () => { let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); let el: Element = fixture.nativeElement; @@ -75,6 +79,31 @@ describe('Definition list component', () => { expect(defaultValueEl).toHaveText('None found'); }); + it('should display a susequent value no value is initially specified', () => { + let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); + let el: Element = fixture.nativeElement; + + fixture.detectChanges(); + + let list1El = getListEl(el, 1); + + let valueEls = getValueEls(list1El); + + let defaultValueEl = getDefaultValueEl(valueEls[2]); + + expect(defaultValueEl).toHaveText('None found'); + + fixture.componentInstance.personalInfo[2].value = 'test'; + + fixture.detectChanges(); + + defaultValueEl = getDefaultValueEl(valueEls[2]); + + expect(defaultValueEl).toBeNull(); + + expect(valueEls[2]).toHaveText('test'); + }); + it('should allow the default value to be specified', () => { let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); let el: Element = fixture.nativeElement; From f64a2be45c8920a00af7a4719eda95e303e2e9b0 Mon Sep 17 00:00:00 2001 From: Paul Crowder Date: Mon, 22 Jan 2018 13:11:48 -0500 Subject: [PATCH 2/3] Fixed typos in test name --- src/modules/definition-list/definition-list.component.spec.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/modules/definition-list/definition-list.component.spec.ts b/src/modules/definition-list/definition-list.component.spec.ts index 21a1a0958..8e84e5406 100644 --- a/src/modules/definition-list/definition-list.component.spec.ts +++ b/src/modules/definition-list/definition-list.component.spec.ts @@ -79,7 +79,7 @@ describe('Definition list component', () => { expect(defaultValueEl).toHaveText('None found'); }); - it('should display a susequent value no value is initially specified', () => { + it('should display a subsequent value when no value is initially specified', () => { let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); let el: Element = fixture.nativeElement; From b15ddc7c6ab1e190e4d8f41c0704d402f729b151 Mon Sep 17 00:00:00 2001 From: Paul Crowder Date: Mon, 22 Jan 2018 13:13:44 -0500 Subject: [PATCH 3/3] Fixed indentation --- .../definition-list.component.spec.ts | 156 +++++++++--------- 1 file changed, 78 insertions(+), 78 deletions(-) diff --git a/src/modules/definition-list/definition-list.component.spec.ts b/src/modules/definition-list/definition-list.component.spec.ts index 8e84e5406..503ca2155 100644 --- a/src/modules/definition-list/definition-list.component.spec.ts +++ b/src/modules/definition-list/definition-list.component.spec.ts @@ -8,125 +8,125 @@ import { SkyDefinitionListFixturesModule } from './fixtures/definition-list-fixt import { expect } from '../testing'; describe('Definition list component', () => { - beforeEach(() => { - TestBed.configureTestingModule({ - imports: [ - SkyDefinitionListFixturesModule - ] - }); + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [ + SkyDefinitionListFixturesModule + ] }); + }); - function getListEl(el: Element, listIndex: number): Element { - return el.querySelector('.sky-definition-list-test-' + listIndex); - } + function getListEl(el: Element, listIndex: number): Element { + return el.querySelector('.sky-definition-list-test-' + listIndex); + } - function getLabelEls(listEl: Element): NodeListOf { - return listEl.querySelectorAll('sky-definition-list-label .sky-definition-list-label'); - } + function getLabelEls(listEl: Element): NodeListOf { + return listEl.querySelectorAll('sky-definition-list-label .sky-definition-list-label'); + } - function getValueEls(listEl: Element): NodeListOf { - return listEl.querySelectorAll('sky-definition-list-value .sky-definition-list-value'); - } + function getValueEls(listEl: Element): NodeListOf { + return listEl.querySelectorAll('sky-definition-list-value .sky-definition-list-value'); + } - function getDefaultValueEl(valueEl: Element): Element { - return valueEl.querySelector('.sky-deemphasized'); - } + function getDefaultValueEl(valueEl: Element): Element { + return valueEl.querySelector('.sky-deemphasized'); + } - it('should render the heading in the expected location', () => { - let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); - let el: Element = fixture.nativeElement; + it('should render the heading in the expected location', () => { + let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); + let el: Element = fixture.nativeElement; - fixture.detectChanges(); + fixture.detectChanges(); - let list1El = getListEl(el, 1); + let list1El = getListEl(el, 1); - let headingEl = - list1El.querySelector('sky-definition-list-heading .sky-definition-list-heading'); + let headingEl = + list1El.querySelector('sky-definition-list-heading .sky-definition-list-heading'); - expect(headingEl).toHaveText('Personal information'); - expect(headingEl).toHaveCssClass('sky-subsection-heading'); - }); + expect(headingEl).toHaveText('Personal information'); + expect(headingEl).toHaveCssClass('sky-subsection-heading'); + }); - it('should render labels and values in the expected locations', () => { - let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); - let el: Element = fixture.nativeElement; + it('should render labels and values in the expected locations', () => { + let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); + let el: Element = fixture.nativeElement; - fixture.detectChanges(); + fixture.detectChanges(); - let list1El = getListEl(el, 1); + let list1El = getListEl(el, 1); - let labelEls = getLabelEls(list1El); - let valueEls = getValueEls(list1El); + let labelEls = getLabelEls(list1El); + let valueEls = getValueEls(list1El); - expect(labelEls[0]).toHaveCssClass('sky-field-label'); - expect(labelEls[0]).toHaveText('Job title'); + expect(labelEls[0]).toHaveCssClass('sky-field-label'); + expect(labelEls[0]).toHaveText('Job title'); - expect(valueEls[0]).toHaveText('Engineer'); - }); + expect(valueEls[0]).toHaveText('Engineer'); + }); - it('should display a default value when no value is specified', () => { - let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); - let el: Element = fixture.nativeElement; + it('should display a default value when no value is specified', () => { + let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); + let el: Element = fixture.nativeElement; - fixture.detectChanges(); + fixture.detectChanges(); - let list1El = getListEl(el, 1); + let list1El = getListEl(el, 1); - let valueEls = getValueEls(list1El); + let valueEls = getValueEls(list1El); - let defaultValueEl = valueEls[2].querySelector('.sky-deemphasized'); + let defaultValueEl = valueEls[2].querySelector('.sky-deemphasized'); - expect(defaultValueEl).toHaveText('None found'); - }); + expect(defaultValueEl).toHaveText('None found'); + }); - it('should display a subsequent value when no value is initially specified', () => { - let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); - let el: Element = fixture.nativeElement; + it('should display a subsequent value when no value is initially specified', () => { + let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); + let el: Element = fixture.nativeElement; - fixture.detectChanges(); + fixture.detectChanges(); - let list1El = getListEl(el, 1); + let list1El = getListEl(el, 1); - let valueEls = getValueEls(list1El); + let valueEls = getValueEls(list1El); - let defaultValueEl = getDefaultValueEl(valueEls[2]); + let defaultValueEl = getDefaultValueEl(valueEls[2]); - expect(defaultValueEl).toHaveText('None found'); + expect(defaultValueEl).toHaveText('None found'); - fixture.componentInstance.personalInfo[2].value = 'test'; + fixture.componentInstance.personalInfo[2].value = 'test'; - fixture.detectChanges(); + fixture.detectChanges(); - defaultValueEl = getDefaultValueEl(valueEls[2]); + defaultValueEl = getDefaultValueEl(valueEls[2]); - expect(defaultValueEl).toBeNull(); + expect(defaultValueEl).toBeNull(); - expect(valueEls[2]).toHaveText('test'); - }); + expect(valueEls[2]).toHaveText('test'); + }); - it('should allow the default value to be specified', () => { - let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); - let el: Element = fixture.nativeElement; + it('should allow the default value to be specified', () => { + let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); + let el: Element = fixture.nativeElement; - fixture.detectChanges(); + fixture.detectChanges(); - let list1El = getListEl(el, 2); + let list1El = getListEl(el, 2); - let valueEls = getValueEls(list1El); + let valueEls = getValueEls(list1El); - expect(valueEls[2]).toHaveText('No information found'); - }); + expect(valueEls[2]).toHaveText('No information found'); + }); - it('should allow the label width to be specified', () => { - let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); - let el: Element = fixture.nativeElement; + it('should allow the label width to be specified', () => { + let fixture = TestBed.createComponent(SkyDefinitionListTestComponent); + let el: Element = fixture.nativeElement; - fixture.detectChanges(); + fixture.detectChanges(); - let list1El = getListEl(el, 2); + let list1El = getListEl(el, 2); - let labelEls = getLabelEls(list1El); + let labelEls = getLabelEls(list1El); - expect(getComputedStyle(labelEls[0]).width).toBe('150px'); - }); + expect(getComputedStyle(labelEls[0]).width).toBe('150px'); + }); });