mirror of
				https://github.com/Alfresco/alfresco-ng2-components.git
				synced 2025-10-22 15:11:57 +00:00 
			
		
		
		
	[ADF-3354] accordion-group closed behaviour (#3595)
* accordion-group closed fix * tests fixes * tests added * tests fixes * Fix failing unit test and revert deleted method
This commit is contained in:
		| @@ -1,7 +1,7 @@ | |||||||
| <mat-accordion class="adf-panel"> | <mat-accordion class="adf-panel"> | ||||||
|     <mat-expansion-panel #expansionPanel |     <mat-expansion-panel #expansionPanel | ||||||
|         id="adf-expansion-panel-id" |         id="adf-expansion-panel-id" | ||||||
|         (click)="isExpandable($event)" |         (click)="isExpandable()" | ||||||
|         [expanded]="toggleExpansion()" |         [expanded]="toggleExpansion()" | ||||||
|         (opened)="onHeaderClick()" |         (opened)="onHeaderClick()" | ||||||
|         [hideToggle]="!hasAccordionIcon"> |         [hideToggle]="!hasAccordionIcon"> | ||||||
|   | |||||||
| @@ -19,6 +19,10 @@ import { async, ComponentFixture, TestBed } from '@angular/core/testing'; | |||||||
| import { AccordionGroupComponent } from './accordion-group.component'; | import { AccordionGroupComponent } from './accordion-group.component'; | ||||||
| import { setupTestBed } from '../testing/setupTestBed'; | import { setupTestBed } from '../testing/setupTestBed'; | ||||||
| import { CoreTestingModule } from '../testing/core.testing.module'; | import { CoreTestingModule } from '../testing/core.testing.module'; | ||||||
|  | import { Component, ViewChild } from '@angular/core'; | ||||||
|  | import { CoreModule } from '../core.module'; | ||||||
|  | import { NoopAnimationsModule } from '@angular/platform-browser/animations'; | ||||||
|  | import { By } from '@angular/platform-browser'; | ||||||
|  |  | ||||||
| describe('AccordionGroupComponent', () => { | describe('AccordionGroupComponent', () => { | ||||||
|  |  | ||||||
| @@ -115,4 +119,106 @@ describe('AccordionGroupComponent', () => { | |||||||
|         header.click(); |         header.click(); | ||||||
|     })); |     })); | ||||||
|  |  | ||||||
|  |     it('should display icon if is present', (done) => { | ||||||
|  |         component.headingIcon = 'assignment'; | ||||||
|  |         fixture.detectChanges(); | ||||||
|  |         fixture.whenStable().then(() => { | ||||||
|  |             fixture.detectChanges(); | ||||||
|  |             expect(component.hasHeadingIcon()).toBe(true); | ||||||
|  |             let headerText = element.querySelector('.adf-panel-heading-icon'); | ||||||
|  |             expect(headerText).toBeDefined(); | ||||||
|  |             done(); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | @Component({ | ||||||
|  |     template: ` | ||||||
|  |     <adf-accordion-group [heading]="'My Header'" | ||||||
|  |                          [isSelected]="isSelected" | ||||||
|  |                          [isOpen]="isOpen" | ||||||
|  |                          [headingIcon]="headingIcon" #accordion> | ||||||
|  |         <div>My List</div> | ||||||
|  |     </adf-accordion-group> | ||||||
|  |        ` | ||||||
|  | }) | ||||||
|  | class CustomAccordionGroupComponent extends AccordionGroupComponent { | ||||||
|  |     isOpen: boolean; | ||||||
|  |     isSelected: boolean; | ||||||
|  |     headingIcon: string; | ||||||
|  |  | ||||||
|  |     @ViewChild('accordion') | ||||||
|  |     accordion: AccordionGroupComponent; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | describe('Custom AccordionGroup', () => { | ||||||
|  |     let fixture: ComponentFixture<CustomAccordionGroupComponent>; | ||||||
|  |     let component: CustomAccordionGroupComponent; | ||||||
|  |  | ||||||
|  |     setupTestBed({ | ||||||
|  |         imports: [ | ||||||
|  |             NoopAnimationsModule, | ||||||
|  |             CoreModule.forRoot() | ||||||
|  |         ], | ||||||
|  |         declarations: [ | ||||||
|  |             CustomAccordionGroupComponent | ||||||
|  |         ] | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     beforeEach(() => { | ||||||
|  |         fixture = TestBed.createComponent(CustomAccordionGroupComponent); | ||||||
|  |         component = fixture.componentInstance; | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     afterEach(() => { | ||||||
|  |         fixture.destroy(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('should render the title', () => { | ||||||
|  |         component.isOpen = true; | ||||||
|  |         component.isSelected = true; | ||||||
|  |         fixture.detectChanges(); | ||||||
|  |         let title: any = fixture.debugElement.queryAll(By.css('.adf-panel-heading-text')); | ||||||
|  |         expect(title.length).toBe(1); | ||||||
|  |         expect(title[0].nativeElement.innerText).toBe('My Header'); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('should render a tab with icon', () => { | ||||||
|  |         component.headingIcon = 'assignment'; | ||||||
|  |         fixture.detectChanges(); | ||||||
|  |         let tab: any = fixture.debugElement.queryAll(By.css('.material-icons')); | ||||||
|  |         expect(tab[0].nativeElement.innerText).toBe('assignment'); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('should expand the panel if has content and is selected', (done) => { | ||||||
|  |         spyOn(component.accordion, 'expandPanel').and.callThrough(); | ||||||
|  |         component.isOpen = false; | ||||||
|  |         component.isSelected = true; | ||||||
|  |         fixture.detectChanges(); | ||||||
|  |         fixture.whenStable().then(() => { | ||||||
|  |             fixture.detectChanges(); | ||||||
|  |             expect(component.accordion.expansionPanel.expanded).toBe(false); | ||||||
|  |             const selectElement = fixture.debugElement.nativeElement.querySelector('#adf-expansion-panel-id'); | ||||||
|  |             selectElement.click(); | ||||||
|  |             expect(component.accordion.expandPanel).toHaveBeenCalled(); | ||||||
|  |             expect(component.accordion.expansionPanel.expanded).toBe(true); | ||||||
|  |             done(); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('should close the expanded panel if has content and is selected', (done) => { | ||||||
|  |         spyOn(component.accordion, 'expandPanel').and.callThrough(); | ||||||
|  |         component.isOpen = true; | ||||||
|  |         component.isSelected = true; | ||||||
|  |         fixture.detectChanges(); | ||||||
|  |         fixture.whenStable().then(() => { | ||||||
|  |             fixture.detectChanges(); | ||||||
|  |             expect(component.accordion.expansionPanel.expanded).toBe(true); | ||||||
|  |             const selectElement = fixture.debugElement.nativeElement.querySelector('#adf-expansion-panel-id'); | ||||||
|  |             selectElement.click(); | ||||||
|  |             expect(component.accordion.expandPanel).toHaveBeenCalled(); | ||||||
|  |             expect(component.accordion.expansionPanel.expanded).toBe(false); | ||||||
|  |             done(); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -78,19 +78,19 @@ export class AccordionGroupComponent implements AfterViewInit { | |||||||
|     constructor() { } |     constructor() { } | ||||||
|  |  | ||||||
|     ngAfterViewInit() { |     ngAfterViewInit() { | ||||||
|         this.hasContent = this.contentWrapper.nativeElement && this.contentWrapper.nativeElement.children.length > 0; |         this.hasContent = this.contentWrapper ? this.contentWrapper.nativeElement && this.contentWrapper.nativeElement.children.length > 0 : false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     hasHeadingIcon() { |     hasHeadingIcon() { | ||||||
|         return this.headingIcon ? true : false; |         return !!this.headingIcon; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     onHeaderClick(): void { |     onHeaderClick(): void { | ||||||
|         this.headingClick.emit(this.heading); |         this.headingClick.emit(this.heading); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     isExpandable(event: any) { |     isExpandable() { | ||||||
|         if (!this.hasContent || !this.isOpen) { |         if (this.hasContent && this.isSelected) { | ||||||
|             this.expandPanel(); |             this.expandPanel(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user