mirror of
				https://github.com/Alfresco/alfresco-ng2-components.git
				synced 2025-10-22 15:11:57 +00:00 
			
		
		
		
	fix no result and refactoring tests
This commit is contained in:
		| @@ -32,6 +32,7 @@ export class SearchBarComponent { | |||||||
|  |  | ||||||
|     fileNodeId: string; |     fileNodeId: string; | ||||||
|     fileShowed: boolean = false; |     fileShowed: boolean = false; | ||||||
|  |     searchTerm: string = ''; | ||||||
|  |  | ||||||
|     @Output() |     @Output() | ||||||
|     expand = new EventEmitter(); |     expand = new EventEmitter(); | ||||||
| @@ -50,6 +51,11 @@ export class SearchBarComponent { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     searchTermChange(event) { | ||||||
|  |         console.log('Search term changed', event); | ||||||
|  |         this.searchTerm = event.value; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     onExpandToggle(event) { |     onExpandToggle(event) { | ||||||
|         this.expand.emit(event); |         this.expand.emit(event); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -220,7 +220,7 @@ Also make sure you include these dependencies in your .html page: | |||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Example of an component that displays search results, using the Angular2 router to supply a 'q' parameter containing the | Example of an component that displays search results, using the Angular2 router to supply a 'q' parameter containing the | ||||||
| search term. If no ruter is present pon the page of if the router does not provide such a parameter then an empty  | search term. If no router is present pon the page of if the router does not provide such a parameter then an empty  | ||||||
| results page will be shown. | results page will be shown. | ||||||
|  |  | ||||||
| ```ts | ```ts | ||||||
|   | |||||||
| @@ -1,50 +0,0 @@ | |||||||
| /*! |  | ||||||
|  * @license |  | ||||||
|  * Copyright 2016 Alfresco Software, Ltd. |  | ||||||
|  * |  | ||||||
|  * Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
|  * you may not use this file except in compliance with the License. |  | ||||||
|  * You may obtain a copy of the License at |  | ||||||
|  * |  | ||||||
|  *     http://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
|  * |  | ||||||
|  * Unless required by applicable law or agreed to in writing, software |  | ||||||
|  * distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
|  * See the License for the specific language governing permissions and |  | ||||||
|  * limitations under the License. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| import { AlfrescoSearchService } from '../services/alfresco-search.service'; |  | ||||||
| import { Observable } from 'rxjs/Rx'; |  | ||||||
|  |  | ||||||
| export class SearchServiceMock extends AlfrescoSearchService { |  | ||||||
|  |  | ||||||
|     getLiveSearchResults(term: string): Observable<any> { |  | ||||||
|         if (term.length > 3) { |  | ||||||
|             return Observable.of({ |  | ||||||
|                 list: { |  | ||||||
|                     entries: [ |  | ||||||
|                         { |  | ||||||
|                             entry: { |  | ||||||
|                                 id: '123', |  | ||||||
|                                 name: 'MyDoc', |  | ||||||
|                                 content: { |  | ||||||
|                                     mimetype: 'text/plain' |  | ||||||
|                                 }, |  | ||||||
|                                 createdByUser: { |  | ||||||
|                                     displayName: 'John Doe' |  | ||||||
|                                 }, |  | ||||||
|                                 modifiedByUser: { |  | ||||||
|                                     displayName: 'John Doe' |  | ||||||
|                                 } |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
|                     ] |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|         } else { |  | ||||||
|             return Observable.throw('Fake server error'); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| @@ -1,10 +1,25 @@ | |||||||
| <table data-automation-id="autocomplete_results" *ngIf="results && results.length && searchTerm" class="mdl-data-table mdl-js-data-table mdl-shadow--2dp full-width"> | <table data-automation-id="autocomplete_results" *ngIf="results && results.length && searchTerm" | ||||||
|  |        class="mdl-data-table mdl-js-data-table mdl-shadow--2dp full-width"> | ||||||
|     <tbody> |     <tbody> | ||||||
|     <tr *ngFor="let result of results; let idx = index" (click)="onItemClick(result, $event)" |     <tr id="result_row_{{idx}}" *ngFor="let result of results; let idx = index" (click)="onItemClick(result, $event)" | ||||||
|         attr.data-automation-id="autocomplete_result_for_{{result.entry.name}}" > |         attr.data-automation-id="autocomplete_result_for_{{result.entry.name}}"> | ||||||
|         <td class="img-td"><img src="{{getMimeTypeIcon(result)}}" alt="{{getMimeTypeKey(result)|translate}}" /></td> |         <td class="img-td"><img src="{{getMimeTypeIcon(result)}}" alt="{{getMimeTypeKey(result)|translate}}"/></td> | ||||||
|         <td><div class="truncate" ><b>{{result.entry.name}}</b></div><div class="truncate">{{result.entry.createdByUser.displayName}}</div></td> |         <td> | ||||||
|  |             <div id="result_name_{{idx}}"  class="truncate"><b>{{result.entry.name}}</b></div> | ||||||
|  |             <div id="result_user_{{idx}}"  class="truncate">{{result.entry.createdByUser.displayName}}</div> | ||||||
|  |         </td> | ||||||
|     </tr> |     </tr> | ||||||
|     </tbody> |     </tbody> | ||||||
| </table> | </table> | ||||||
| <p data-automation-id="autocomplete_error_message" *ngIf="errorMessage">{{ 'SEARCH.RESULTS.ERROR' | translate:{errorMessage: errorMessage} }}</p> | <table id="search_no_result" data-automation-id="search_no_result_found" *ngIf="results && results.length === 0" | ||||||
|  |        class="mdl-data-table mdl-js-data-table mdl-shadow--2dp full-width"> | ||||||
|  |     <tbody> | ||||||
|  |     <tr> | ||||||
|  |         <td> | ||||||
|  |             <div class="truncate"><b> {{ 'SEARCH.RESULTS.NONE' | translate:{searchTerm: searchTerm} }}</b></div> | ||||||
|  |         </td> | ||||||
|  |     </tr> | ||||||
|  |     </tbody> | ||||||
|  | </table> | ||||||
|  | <p data-automation-id="autocomplete_error_message" *ngIf="errorMessage">{{ 'SEARCH.RESULTS.ERROR' | | ||||||
|  |     translate:{errorMessage: errorMessage} }}</p> | ||||||
|   | |||||||
| @@ -15,34 +15,81 @@ | |||||||
|  * limitations under the License. |  * limitations under the License. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| import { provide } from '@angular/core'; | import { it, describe, expect, inject, beforeEachProviders, beforeEach, afterEach } from '@angular/core/testing'; | ||||||
| import { it, describe, expect, inject, beforeEachProviders } from '@angular/core/testing'; |  | ||||||
| import { TestComponentBuilder } from '@angular/compiler/testing'; | import { TestComponentBuilder } from '@angular/compiler/testing'; | ||||||
| import { AlfrescoSearchAutocompleteComponent } from './alfresco-search-autocomplete.component'; | import { AlfrescoSearchAutocompleteComponent } from './alfresco-search-autocomplete.component'; | ||||||
| import { SearchServiceMock } from './../assets/alfresco-search.service.mock'; |  | ||||||
| import { AlfrescoThumbnailService } from './../services/alfresco-thumbnail.service'; | import { AlfrescoThumbnailService } from './../services/alfresco-thumbnail.service'; | ||||||
|  | import { TranslationMock } from './../assets/translation.service.mock'; | ||||||
| import { AlfrescoSearchService } from '../services/alfresco-search.service'; | import { AlfrescoSearchService } from '../services/alfresco-search.service'; | ||||||
| import { | import { | ||||||
|     AlfrescoSettingsService, |     AlfrescoSettingsService, | ||||||
|     AlfrescoAuthenticationService, |     AlfrescoAuthenticationService, | ||||||
|     AlfrescoContentService, |     AlfrescoContentService, | ||||||
|     AlfrescoTranslationService } from 'ng2-alfresco-core'; |     AlfrescoTranslationService | ||||||
|  | } from 'ng2-alfresco-core'; | ||||||
|  |  | ||||||
|  | declare let jasmine: any; | ||||||
|  |  | ||||||
| describe('AlfrescoSearchAutocompleteComponent', () => { | describe('AlfrescoSearchAutocompleteComponent', () => { | ||||||
|  |  | ||||||
|  |     let alfrescoSearchComponentFixture, element, component; | ||||||
|  |  | ||||||
|  |     let result = { | ||||||
|  |         list: { | ||||||
|  |             entries: [ | ||||||
|  |                 { | ||||||
|  |                     entry: { | ||||||
|  |                         id: '123', | ||||||
|  |                         name: 'MyDoc', | ||||||
|  |                         isFile : true, | ||||||
|  |                         content: { | ||||||
|  |                             mimetype: 'text/plain' | ||||||
|  |                         }, | ||||||
|  |                         createdByUser: { | ||||||
|  |                             displayName: 'John Doe' | ||||||
|  |                         }, | ||||||
|  |                         modifiedByUser: { | ||||||
|  |                             displayName: 'John Doe' | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             ] | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     let noResult = { | ||||||
|  |         list: { | ||||||
|  |             entries: [] | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  |  | ||||||
|     beforeEachProviders(() => { |     beforeEachProviders(() => { | ||||||
|         return [ |         return [ | ||||||
|             provide(AlfrescoSearchService, {useClass: SearchServiceMock}), |             {provide: AlfrescoTranslationService, useClass: TranslationMock}, | ||||||
|             provide(AlfrescoThumbnailService, {}), |             AlfrescoThumbnailService, | ||||||
|             provide(AlfrescoTranslationService, {}), |             AlfrescoSettingsService, | ||||||
|             provide(AlfrescoSettingsService, {}), |             AlfrescoAuthenticationService, | ||||||
|             provide(AlfrescoAuthenticationService, {}), |             AlfrescoContentService, | ||||||
|             provide(AlfrescoContentService, {}) |             AlfrescoSearchService | ||||||
|         ]; |         ]; | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     it('should setup i18n folder', () => { |     beforeEach(inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { | ||||||
|  |         return tcb | ||||||
|  |             .createAsync(AlfrescoSearchAutocompleteComponent) | ||||||
|  |             .then(fixture => { | ||||||
|  |                 jasmine.Ajax.install(); | ||||||
|  |                 alfrescoSearchComponentFixture = fixture; | ||||||
|  |                 element = alfrescoSearchComponentFixture.nativeElement; | ||||||
|  |                 component = alfrescoSearchComponentFixture.componentInstance; | ||||||
|  |             }); | ||||||
|  |     })); | ||||||
|  |  | ||||||
|  |     afterEach(() => { | ||||||
|  |         jasmine.Ajax.uninstall(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('should setup i18n folder', () => { | ||||||
|         let translation = jasmine.createSpyObj('AlfrescoTranslationService', [ |         let translation = jasmine.createSpyObj('AlfrescoTranslationService', [ | ||||||
|             'addTranslationFolder' |             'addTranslationFolder' | ||||||
|         ]); |         ]); | ||||||
| @@ -51,99 +98,87 @@ describe('AlfrescoSearchAutocompleteComponent', () => { | |||||||
|  |  | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     it('should display search results when a search term is provided', |     it('should display search results when a search term is provided', () => { | ||||||
|         inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |         let searchTerm = 'customSearchTerm'; | ||||||
|             return tcb |         spyOn(component, 'displaySearchResults').and.stub(); | ||||||
|                 .createAsync(AlfrescoSearchAutocompleteComponent) |         component.searchTerm = searchTerm; | ||||||
|                 .then((fixture) => { |         component.ngOnChanges({ | ||||||
|                     let componentInstance = fixture.componentInstance, |             searchTerm: searchTerm | ||||||
|                         searchTerm = 'customSearchTerm'; |         }); | ||||||
|                     spyOn(componentInstance, 'displaySearchResults').and.stub(); |         alfrescoSearchComponentFixture.detectChanges(); | ||||||
|                     componentInstance.searchTerm = searchTerm; |         expect(component.displaySearchResults).toHaveBeenCalledWith(searchTerm); | ||||||
|                     componentInstance.ngOnChanges({ |     }); | ||||||
|                         searchTerm: searchTerm |  | ||||||
|                     }); |  | ||||||
|                     fixture.detectChanges(); |  | ||||||
|                     expect(componentInstance.displaySearchResults).toHaveBeenCalledWith(searchTerm); |  | ||||||
|  |  | ||||||
|                 }); |     it('should display the returned search results', (done) => { | ||||||
|         })); |         component.resultsEmitter.subscribe(x => { | ||||||
|  |             alfrescoSearchComponentFixture.detectChanges(); | ||||||
|  |             expect( element.querySelector('#result_user_0').innerHTML).toBe('John Doe'); | ||||||
|  |             expect( element.querySelector('#result_name_0').innerHTML).toBe('<b _ngcontent-a-1="">MyDoc</b>'); | ||||||
|  |             done(); | ||||||
|  |         }); | ||||||
|  |  | ||||||
|     it('should display the returned search results', |         component.searchTerm = 'searchTerm'; | ||||||
|         inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |         component.ngOnChanges({searchTerm: component.searchTerm}); | ||||||
|             return tcb |  | ||||||
|                 .createAsync(AlfrescoSearchAutocompleteComponent) |  | ||||||
|                 .then((fixture) => { |  | ||||||
|                     let componentInstance = fixture.componentInstance; |  | ||||||
|                     componentInstance.results = [{ |  | ||||||
|                         entry: { |  | ||||||
|                             id: '123', |  | ||||||
|                             name: 'MyDoc', |  | ||||||
|                             content: { |  | ||||||
|                                 mimetype: 'text/plain' |  | ||||||
|                             }, |  | ||||||
|                             createdByUser: { |  | ||||||
|                                 displayName: 'John Doe' |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
|                     }]; |  | ||||||
|                     componentInstance.searchTerm = '<term>'; |  | ||||||
|                     fixture.detectChanges(); |  | ||||||
|  |  | ||||||
|                     let element = fixture.nativeElement; |         jasmine.Ajax.requests.mostRecent().respondWith({ | ||||||
|                     expect(element.querySelectorAll('table tr').length).toBe(1); |             status: 200, | ||||||
|  |             contentType: 'json', | ||||||
|  |             responseText: result | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|                 }); |     it('should display no result if no result are returned', (done) => { | ||||||
|         })); |         component.resultsEmitter.subscribe(x => { | ||||||
|  |             alfrescoSearchComponentFixture.detectChanges(); | ||||||
|  |             expect( element.querySelector('#search_no_result')).not.toBe(null); | ||||||
|  |             done(); | ||||||
|  |         }); | ||||||
|  |  | ||||||
|     it('should emit preview when file item clicked', |         component.searchTerm = 'searchTerm'; | ||||||
|         inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |         component.ngOnChanges({searchTerm: component.searchTerm}); | ||||||
|             return tcb |  | ||||||
|                 .createAsync(AlfrescoSearchAutocompleteComponent) |  | ||||||
|                 .then((fixture) => { |  | ||||||
|                     let componentInstance = fixture.componentInstance; |  | ||||||
|                     componentInstance.results = [{ |  | ||||||
|                         entry: { |  | ||||||
|                             id: '123', |  | ||||||
|                             name: 'MyDoc', |  | ||||||
|                             content: { |  | ||||||
|                                 mimetype: 'text/plain' |  | ||||||
|                             }, |  | ||||||
|                             isFile: true |  | ||||||
|                         } |  | ||||||
|                     }]; |  | ||||||
|                     fixture.detectChanges(componentInstance.results[0]); |  | ||||||
|                     componentInstance.preview.subscribe(e => { |  | ||||||
|                         expect(e.value).toBe(componentInstance.results[0]); |  | ||||||
|                     }); |  | ||||||
|                     componentInstance.onItemClick(); |  | ||||||
|  |  | ||||||
|                 }); |         jasmine.Ajax.requests.mostRecent().respondWith({ | ||||||
|         })); |             status: 200, | ||||||
|  |             contentType: 'json', | ||||||
|  |             responseText: noResult | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|     it('should not emit preview when non-file item clicked', |     it('should emit preview when file item clicked', (done) => { | ||||||
|         inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |         component.resultsEmitter.subscribe(x => { | ||||||
|             return tcb |             alfrescoSearchComponentFixture.detectChanges(); | ||||||
|                 .createAsync(AlfrescoSearchAutocompleteComponent) |             element.querySelector('#result_row_0').click(); | ||||||
|                 .then((fixture) => { |         }); | ||||||
|                     let componentInstance = fixture.componentInstance; |  | ||||||
|                     componentInstance.results = [{ |  | ||||||
|                         entry: { |  | ||||||
|                             id: '123', |  | ||||||
|                             name: 'MyDoc', |  | ||||||
|                             content: { |  | ||||||
|                                 mimetype: 'text/plain' |  | ||||||
|                             }, |  | ||||||
|                             isFile: true |  | ||||||
|                         } |  | ||||||
|                     }]; |  | ||||||
|                     fixture.detectChanges(componentInstance.results[0]); |  | ||||||
|                     componentInstance.preview.subscribe(e => { |  | ||||||
|                         expect(e.value).toBe(componentInstance.results[0]); |  | ||||||
|                     }); |  | ||||||
|                     componentInstance.onItemClick(); |  | ||||||
|  |  | ||||||
|                 }); |         component.searchTerm = 'searchTerm'; | ||||||
|         })); |         component.ngOnChanges({searchTerm: component.searchTerm}); | ||||||
|  |  | ||||||
|  |         jasmine.Ajax.requests.mostRecent().respondWith({ | ||||||
|  |             status: 200, | ||||||
|  |             contentType: 'json', | ||||||
|  |             responseText: result | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         component.preview.subscribe(e => { | ||||||
|  |            done(); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|  |     it('should not emit preview when non-file item is clicked', () => { | ||||||
|  |         spyOn(component, 'onItemClick').and.stub(); | ||||||
|  |  | ||||||
|  |         component.ngOnChanges({searchTerm: 'searchTerm'}); | ||||||
|  |  | ||||||
|  |         component.preview.subscribe(e => { | ||||||
|  |             expect(e.value).toBe(component.results[0]); | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         jasmine.Ajax.requests.mostRecent().respondWith({ | ||||||
|  |             status: 200, | ||||||
|  |             contentType: 'json', | ||||||
|  |             responseText: result | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         expect(component.onItemClick).not.toHaveBeenCalled(); | ||||||
|  |     }); | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -15,13 +15,7 @@ | |||||||
|  * limitations under the License. |  * limitations under the License. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| import { | import { Component, EventEmitter, Input, OnChanges, Output } from '@angular/core'; | ||||||
|     Component, |  | ||||||
|     EventEmitter, |  | ||||||
|     Input, |  | ||||||
|     OnChanges, |  | ||||||
|     Output |  | ||||||
| } from '@angular/core'; |  | ||||||
| import { AlfrescoSearchService } from './../services/alfresco-search.service'; | import { AlfrescoSearchService } from './../services/alfresco-search.service'; | ||||||
| import { AlfrescoThumbnailService } from './../services/alfresco-thumbnail.service'; | import { AlfrescoThumbnailService } from './../services/alfresco-thumbnail.service'; | ||||||
| import { AlfrescoPipeTranslate, AlfrescoTranslationService } from 'ng2-alfresco-core'; | import { AlfrescoPipeTranslate, AlfrescoTranslationService } from 'ng2-alfresco-core'; | ||||||
| @@ -53,6 +47,9 @@ export class AlfrescoSearchAutocompleteComponent implements OnChanges { | |||||||
|     @Output() |     @Output() | ||||||
|     preview: EventEmitter<any> = new EventEmitter(); |     preview: EventEmitter<any> = new EventEmitter(); | ||||||
|  |  | ||||||
|  |     @Output() | ||||||
|  |     resultsEmitter = new EventEmitter(); | ||||||
|  |  | ||||||
|     constructor(private alfrescoSearchService: AlfrescoSearchService, |     constructor(private alfrescoSearchService: AlfrescoSearchService, | ||||||
|                 private translate: AlfrescoTranslationService, |                 private translate: AlfrescoTranslationService, | ||||||
|                 private alfrescoThumbnailService: AlfrescoThumbnailService) { |                 private alfrescoThumbnailService: AlfrescoThumbnailService) { | ||||||
| @@ -62,9 +59,9 @@ export class AlfrescoSearchAutocompleteComponent implements OnChanges { | |||||||
|         this.results = null; |         this.results = null; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     ngOnChanges(changes): void { |     ngOnChanges(changes) { | ||||||
|         if (changes.searchTerm) { |         if (changes.searchTerm) { | ||||||
|             this.displaySearchResults(this.searchTerm); |             this.displaySearchResults(changes.searchTerm); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -80,6 +77,7 @@ export class AlfrescoSearchAutocompleteComponent implements OnChanges { | |||||||
|                     results => { |                     results => { | ||||||
|                         this.results = results.list.entries; |                         this.results = results.list.entries; | ||||||
|                         this.errorMessage = null; |                         this.errorMessage = null; | ||||||
|  |                         this.resultsEmitter.emit(this.results); | ||||||
|                     }, |                     }, | ||||||
|                     error => { |                     error => { | ||||||
|                         this.results = null; |                         this.results = null; | ||||||
|   | |||||||
| @@ -16,133 +16,97 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| import { provide } from '@angular/core'; | import { provide } from '@angular/core'; | ||||||
| import { it, describe, expect, inject, beforeEachProviders } from '@angular/core/testing'; | import { it, describe, expect, inject, beforeEachProviders, beforeEach } from '@angular/core/testing'; | ||||||
| import { TestComponentBuilder } from '@angular/compiler/testing'; | import { TestComponentBuilder } from '@angular/compiler/testing'; | ||||||
| import { AlfrescoSearchControlComponent } from './alfresco-search-control.component'; | import { AlfrescoSearchControlComponent } from './alfresco-search-control.component'; | ||||||
| import { SearchServiceMock } from './../assets/alfresco-search.service.mock'; |  | ||||||
| import { AlfrescoThumbnailService } from './../services/alfresco-thumbnail.service'; | import { AlfrescoThumbnailService } from './../services/alfresco-thumbnail.service'; | ||||||
| import { TranslationMock } from './../assets/translation.service.mock'; | import { TranslationMock } from './../assets/translation.service.mock'; | ||||||
| import { | import { AlfrescoSettingsService, AlfrescoAuthenticationService, AlfrescoContentService, AlfrescoTranslationService | ||||||
|     AlfrescoSettingsService, | } from 'ng2-alfresco-core'; | ||||||
|     AlfrescoAuthenticationService, |  | ||||||
|     AlfrescoContentService, |  | ||||||
|     AlfrescoTranslationService } from 'ng2-alfresco-core'; |  | ||||||
| import { AlfrescoSearchService } from '../services/alfresco-search.service'; | import { AlfrescoSearchService } from '../services/alfresco-search.service'; | ||||||
|  |  | ||||||
|  |  | ||||||
| describe('AlfrescoSearchControlComponent', () => { | describe('AlfrescoSearchControlComponent', () => { | ||||||
|  |  | ||||||
|  |     let alfrescoSearchControlComponentFixture, element, component; | ||||||
|  |  | ||||||
|     beforeEachProviders(() => { |     beforeEachProviders(() => { | ||||||
|         return [ |         return [ | ||||||
|             provide(AlfrescoSearchService, {useClass: SearchServiceMock}), |             AlfrescoSearchService, | ||||||
|             provide(AlfrescoThumbnailService, {}), |  | ||||||
|             provide(AlfrescoTranslationService, {useClass: TranslationMock}), |             provide(AlfrescoTranslationService, {useClass: TranslationMock}), | ||||||
|             provide(AlfrescoSettingsService, {}), |             AlfrescoThumbnailService, | ||||||
|             provide(AlfrescoAuthenticationService, {}), |             AlfrescoSettingsService, | ||||||
|             provide(AlfrescoContentService, {}) |             AlfrescoAuthenticationService, | ||||||
|  |             AlfrescoContentService | ||||||
|         ]; |         ]; | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     it('should setup i18n folder', () => { |     beforeEach(inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { | ||||||
|  |         return tcb | ||||||
|  |             .createAsync(AlfrescoSearchControlComponent) | ||||||
|  |             .then(fixture => { | ||||||
|  |                 alfrescoSearchControlComponentFixture = fixture; | ||||||
|  |                 element = alfrescoSearchControlComponentFixture.nativeElement; | ||||||
|  |                 component = alfrescoSearchControlComponentFixture.componentInstance; | ||||||
|  |             }); | ||||||
|  |     })); | ||||||
|  |  | ||||||
|  |     it('should setup i18n folder', () => { | ||||||
|         let translation = jasmine.createSpyObj('AlfrescoTranslationService', [ |         let translation = jasmine.createSpyObj('AlfrescoTranslationService', [ | ||||||
|             'addTranslationFolder' |             'addTranslationFolder' | ||||||
|         ]); |         ]); | ||||||
|  |  | ||||||
|         let alfrescoSearchControlComponent = new AlfrescoSearchControlComponent(translation); |         let alfrescoSearchControlComponent = new AlfrescoSearchControlComponent(translation); | ||||||
|         expect(alfrescoSearchControlComponent).toBeDefined(); |         expect(alfrescoSearchControlComponent).toBeDefined(); | ||||||
|  |  | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     it('should emit searchChange when search term changed', |     it('should emit searchChange when search term changed', () => { | ||||||
|         inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |         alfrescoSearchControlComponentFixture.componentInstance.searchTerm = 'customSearchTerm'; | ||||||
|             return tcb |         alfrescoSearchControlComponentFixture.detectChanges(); | ||||||
|                 .createAsync(AlfrescoSearchControlComponent) |         alfrescoSearchControlComponentFixture.componentInstance.searchChange.subscribe(e => { | ||||||
|                 .then((componentFixture) => { |             expect(e.value).toBe('customSearchTerm'); | ||||||
|                     componentFixture.componentInstance.searchTerm = 'customSearchTerm'; |         }); | ||||||
|                     componentFixture.detectChanges(); |     }); | ||||||
|                     componentFixture.componentInstance.searchChange.subscribe(e => { |  | ||||||
|                         expect(e.value).toBe('customSearchTerm'); |  | ||||||
|                     }); |  | ||||||
|                 }); |  | ||||||
|         })); |  | ||||||
|  |  | ||||||
|     describe('Component rendering', () => { |     describe('Component rendering', () => { | ||||||
|  |  | ||||||
|         it('should display a text input field by default', |         it('should display a text input field by default', () => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |             alfrescoSearchControlComponentFixture.detectChanges(); | ||||||
|                 return tcb |             expect(element.querySelectorAll('input[type="text"]').length).toBe(1); | ||||||
|                     .createAsync(AlfrescoSearchControlComponent) |         }); | ||||||
|                     .then((componentFixture) => { |  | ||||||
|                         const element = componentFixture.nativeElement; |  | ||||||
|                         componentFixture.detectChanges(); |  | ||||||
|                         expect(element.querySelectorAll('input[type="text"]').length).toBe(1); |  | ||||||
|                     }); |  | ||||||
|             }) |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         it('should display a search input field when specified', |         it('should display a search input field when specified', () => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |             alfrescoSearchControlComponentFixture.componentInstance.inputType = 'search'; | ||||||
|                 return tcb.createAsync(AlfrescoSearchControlComponent).then((componentFixture) => { |             alfrescoSearchControlComponentFixture.detectChanges(); | ||||||
|                     const element = componentFixture.nativeElement; |             expect(element.querySelectorAll('input[type="search"]').length).toBe(1); | ||||||
|                     componentFixture.componentInstance.inputType = 'search'; |         }); | ||||||
|                     componentFixture.detectChanges(); |  | ||||||
|                     expect(element.querySelectorAll('input[type="search"]').length).toBe(1); |  | ||||||
|                 }); |  | ||||||
|             })); |  | ||||||
|  |  | ||||||
|         it('should set browser autocomplete to off by default', |         it('should set browser autocomplete to off by default', () => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |             alfrescoSearchControlComponentFixture.detectChanges(); | ||||||
|                 return tcb |             let attr = element.querySelectorAll('input[type="text"]')[0].getAttribute('autocomplete'); | ||||||
|                     .createAsync(AlfrescoSearchControlComponent) |             expect(attr).toBe('off'); | ||||||
|                     .then((componentFixture) => { |         }); | ||||||
|                         const element = componentFixture.nativeElement; |  | ||||||
|                         componentFixture.detectChanges(); |  | ||||||
|                         let attr = element.querySelectorAll('input[type="text"]')[0].getAttribute('autocomplete'); |  | ||||||
|                         expect(attr).toBe('off'); |  | ||||||
|                 }); |  | ||||||
|             }) |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         it('should set browser autocomplete to on when configured', |         it('should set browser autocomplete to on when configured', () => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |             alfrescoSearchControlComponentFixture.componentInstance.autocomplete = true; | ||||||
|                 return tcb.createAsync(AlfrescoSearchControlComponent).then((componentFixture) => { |             alfrescoSearchControlComponentFixture.detectChanges(); | ||||||
|                     const element = componentFixture.nativeElement; |             expect(element.querySelectorAll('input[type="text"]')[0].getAttribute('autocomplete')).toBe('on'); | ||||||
|                     componentFixture.componentInstance.autocomplete = true; |         }); | ||||||
|                     componentFixture.detectChanges(); |  | ||||||
|                     expect(element.querySelectorAll('input[type="text"]')[0].getAttribute('autocomplete')) |  | ||||||
|                         .toBe('on'); |  | ||||||
|                 }); |  | ||||||
|             })); |  | ||||||
|  |  | ||||||
|         it('should show an expanding control by default', |         it('should show an expanding control by default', () => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |             alfrescoSearchControlComponentFixture.detectChanges(); | ||||||
|                 return tcb |             expect(element.querySelectorAll('div.mdl-textfield--expandable').length).toBe(1); | ||||||
|                     .createAsync(AlfrescoSearchControlComponent) |             expect(element.querySelectorAll('div.mdl-textfield__expandable-holder').length).toBe(1); | ||||||
|                     .then((componentFixture) => { |             expect(element.querySelectorAll('label.mdl-button--icon').length).toBe(1); | ||||||
|                         const element = componentFixture.nativeElement; |         }); | ||||||
|                         componentFixture.detectChanges(); |  | ||||||
|                         expect(element.querySelectorAll('div.mdl-textfield--expandable').length).toBe(1); |  | ||||||
|                         expect(element.querySelectorAll('div.mdl-textfield__expandable-holder').length).toBe(1); |  | ||||||
|                         expect(element.querySelectorAll('label.mdl-button--icon').length).toBe(1); |  | ||||||
|                 }); |  | ||||||
|             }) |  | ||||||
|         ); |  | ||||||
|  |  | ||||||
|         it('should show a normal non-expanding control when configured', |         it('should show a normal non-expanding control when configured', () => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |             alfrescoSearchControlComponentFixture.detectChanges(); | ||||||
|                 return tcb |             alfrescoSearchControlComponentFixture.componentInstance.expandable = false; | ||||||
|                     .createAsync(AlfrescoSearchControlComponent) |             alfrescoSearchControlComponentFixture.detectChanges(); | ||||||
|                     .then((componentFixture) => { |             expect(element.querySelectorAll('div.mdl-textfield--expandable').length).toBe(0); | ||||||
|                         const element = componentFixture.nativeElement; |             expect(element.querySelectorAll('div.mdl-textfield__expandable-holder').length).toBe(0); | ||||||
|                         componentFixture.detectChanges(); |             expect(element.querySelectorAll('label.mdl-button--icon').length).toBe(0); | ||||||
|                         componentFixture.componentInstance.expandable = false; |         }); | ||||||
|                         componentFixture.detectChanges(); |  | ||||||
|                         expect(element.querySelectorAll('div.mdl-textfield--expandable').length).toBe(0); |  | ||||||
|                         expect(element.querySelectorAll('div.mdl-textfield__expandable-holder').length).toBe(0); |  | ||||||
|                         expect(element.querySelectorAll('label.mdl-button--icon').length).toBe(0); |  | ||||||
|                 }); |  | ||||||
|             }) |  | ||||||
|         ); |  | ||||||
|     }); |     }); | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -0,0 +1,16 @@ | |||||||
|  | :host .mdl-data-table caption { | ||||||
|  |     margin: 0 0 16px 0; | ||||||
|  |     text-align: left; | ||||||
|  | } | ||||||
|  | :host .mdl-data-table td { | ||||||
|  |     max-width: 0; | ||||||
|  |     white-space: nowrap; | ||||||
|  | } | ||||||
|  | :host .mdl-data-table td.col-mimetype-icon { | ||||||
|  |     width: 24px; | ||||||
|  | } | ||||||
|  | :host .col-display-name { | ||||||
|  |     min-width: 250px; | ||||||
|  |     overflow: hidden; | ||||||
|  |     text-overflow: ellipsis; | ||||||
|  | } | ||||||
| @@ -1,4 +1,3 @@ | |||||||
| <p data-automation-id="search_no_result_found" *ngIf="results&& results.length == 0">{{ 'SEARCH.RESULTS.NONE' | translate:{searchTerm: searchTerm} }}</p> |  | ||||||
| <table data-automation-id="search_result_table" *ngIf="results && results.length && searchTerm" class="mdl-data-table mdl-js-data-table mdl-shadow--2dp full-width"> | <table data-automation-id="search_result_table" *ngIf="results && results.length && searchTerm" class="mdl-data-table mdl-js-data-table mdl-shadow--2dp full-width"> | ||||||
|     <caption data-automation-id="search_result_found">{{ 'SEARCH.RESULTS.SUMMARY' | translate:{numResults: results.length, searchTerm: searchTerm} }}</caption> |     <caption data-automation-id="search_result_found">{{ 'SEARCH.RESULTS.SUMMARY' | translate:{numResults: results.length, searchTerm: searchTerm} }}</caption> | ||||||
|     <thead> |     <thead> | ||||||
| @@ -17,16 +16,25 @@ | |||||||
|     </thead> |     </thead> | ||||||
|     <tbody> |     <tbody> | ||||||
|  |  | ||||||
|     <tr *ngFor="let result of results; let idx = index" (click)="onItemClick(result, $event)"> |     <tr  id="result_row_{{idx}}" *ngFor="let result of results; let idx = index" (click)="onItemClick(result, $event)"> | ||||||
|         <td class="col-mimetype-icon"><img src="{{getMimeTypeIcon(result)}}" alt="{{getMimeTypeKey(result)|translate}}" /></td> |         <td class="col-mimetype-icon"><img src="{{getMimeTypeIcon(result)}}" alt="{{getMimeTypeKey(result)|translate}}" /></td> | ||||||
|         <td class="mdl-data-table__cell--non-numeric col-display-name" |         <td id="result_name_{{idx}}" class="mdl-data-table__cell--non-numeric col-display-name" | ||||||
|             attr.data-automation-id=file_{{result.entry.name}} >{{result.entry.name}}</td> |             attr.data-automation-id=file_{{result.entry.name}} >{{result.entry.name}}</td> | ||||||
|         <td class="mdl-data-table__cell--non-numeric  col-modified-by" |         <td id="result_user_{{idx}}" class="mdl-data-table__cell--non-numeric  col-modified-by" | ||||||
|             attr.data-automation-id=file_{{result.entry.name}}_{{result.entry.modifiedByUser.displayName}}> |             attr.data-automation-id=file_{{result.entry.name}}_{{result.entry.modifiedByUser.displayName}}>{{result.entry.modifiedByUser.displayName}}</td> | ||||||
|             {{result.entry.modifiedByUser.displayName}}</td> |  | ||||||
|         <td class="col-modified-at">{{result.entry.modifiedAt | date}}</td> |         <td class="col-modified-at">{{result.entry.modifiedAt | date}}</td> | ||||||
|     </tr> |     </tr> | ||||||
|  |  | ||||||
|     </tbody> |     </tbody> | ||||||
| </table> | </table> | ||||||
|  | <table id="search_no_result" data-automation-id="search_no_result_found" *ngIf="results && results.length === 0" | ||||||
|  |        class="mdl-data-table mdl-js-data-table mdl-shadow--2dp full-width"> | ||||||
|  |     <tbody> | ||||||
|  |     <tr> | ||||||
|  |         <td> | ||||||
|  |             <div class="truncate"><b> {{ 'SEARCH.RESULTS.NONE' | translate:{searchTerm: searchTerm} }}</b></div> | ||||||
|  |         </td> | ||||||
|  |     </tr> | ||||||
|  |     </tbody> | ||||||
|  | </table> | ||||||
| <p data-automation-id="search_error_message" *ngIf="errorMessage">{{ 'SEARCH.RESULTS.ERROR' | translate:{errorMessage: errorMessage} }}</p> | <p data-automation-id="search_error_message" *ngIf="errorMessage">{{ 'SEARCH.RESULTS.ERROR' | translate:{errorMessage: errorMessage} }}</p> | ||||||
|   | |||||||
| @@ -15,11 +15,10 @@ | |||||||
|  * limitations under the License. |  * limitations under the License. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| import { it, describe, expect, inject, beforeEachProviders } from '@angular/core/testing'; | import { it, describe, expect, inject, beforeEachProviders, beforeEach } from '@angular/core/testing'; | ||||||
| import { TestComponentBuilder } from '@angular/compiler/testing'; | import { TestComponentBuilder } from '@angular/compiler/testing'; | ||||||
| import { RouteParams } from '@angular/router-deprecated'; | import { RouteParams } from '@angular/router-deprecated'; | ||||||
| import { AlfrescoSearchComponent } from './alfresco-search.component'; | import { AlfrescoSearchComponent } from './alfresco-search.component'; | ||||||
| import { SearchServiceMock } from './../assets/alfresco-search.service.mock'; |  | ||||||
| import { AlfrescoThumbnailService } from './../services/alfresco-thumbnail.service'; | import { AlfrescoThumbnailService } from './../services/alfresco-thumbnail.service'; | ||||||
| import { TranslationMock } from './../assets/translation.service.mock'; | import { TranslationMock } from './../assets/translation.service.mock'; | ||||||
| import { AlfrescoSearchService } from '../services/alfresco-search.service'; | import { AlfrescoSearchService } from '../services/alfresco-search.service'; | ||||||
| @@ -27,22 +26,70 @@ import { | |||||||
|     AlfrescoSettingsService, |     AlfrescoSettingsService, | ||||||
|     AlfrescoAuthenticationService, |     AlfrescoAuthenticationService, | ||||||
|     AlfrescoContentService, |     AlfrescoContentService, | ||||||
|     AlfrescoTranslationService } from 'ng2-alfresco-core'; |     AlfrescoTranslationService | ||||||
|  | } from 'ng2-alfresco-core'; | ||||||
|  |  | ||||||
|  | declare let jasmine: any; | ||||||
|  |  | ||||||
| describe('AlfrescoSearchComponent', () => { | describe('AlfrescoSearchComponent', () => { | ||||||
|  |  | ||||||
|     beforeEachProviders(() => { |     let alfrescoSearchComponentFixture, element, component; | ||||||
|  |  | ||||||
|  |     let result = { | ||||||
|  |         list: { | ||||||
|  |             entries: [ | ||||||
|  |                 { | ||||||
|  |                     entry: { | ||||||
|  |                         id: '123', | ||||||
|  |                         name: 'MyDoc', | ||||||
|  |                         isFile : true, | ||||||
|  |                         content: { | ||||||
|  |                             mimetype: 'text/plain' | ||||||
|  |                         }, | ||||||
|  |                         createdByUser: { | ||||||
|  |                             displayName: 'John Doe' | ||||||
|  |                         }, | ||||||
|  |                         modifiedByUser: { | ||||||
|  |                             displayName: 'John Doe' | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             ] | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     let noResult = { | ||||||
|  |         list: { | ||||||
|  |             entries: [] | ||||||
|  |         } | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     beforeEachProviders(() => { | ||||||
|         return [ |         return [ | ||||||
|             { provide: AlfrescoSearchService, useClass: SearchServiceMock }, |             AlfrescoSearchService, | ||||||
|             { provide: AlfrescoThumbnailService }, |             {provide: AlfrescoTranslationService, useClass: TranslationMock}, | ||||||
|             { provide: AlfrescoTranslationService, useClass: TranslationMock }, |             AlfrescoThumbnailService, | ||||||
|             { provide: AlfrescoSettingsService }, |             AlfrescoSettingsService, | ||||||
|             { provide: AlfrescoAuthenticationService }, |             AlfrescoAuthenticationService, | ||||||
|             { provide: AlfrescoContentService } |             AlfrescoContentService | ||||||
|         ]; |         ]; | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|  |     beforeEach(inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { | ||||||
|  |         return tcb | ||||||
|  |             .createAsync(AlfrescoSearchComponent) | ||||||
|  |             .then(fixture => { | ||||||
|  |                 jasmine.Ajax.install(); | ||||||
|  |                 alfrescoSearchComponentFixture = fixture; | ||||||
|  |                 element = alfrescoSearchComponentFixture.nativeElement; | ||||||
|  |                 component = alfrescoSearchComponentFixture.componentInstance; | ||||||
|  |             }); | ||||||
|  |     })); | ||||||
|  |  | ||||||
|  |     afterEach(() => { | ||||||
|  |         jasmine.Ajax.uninstall(); | ||||||
|  |     }); | ||||||
|  |  | ||||||
|     it('should not have a search term by default', () => { |     it('should not have a search term by default', () => { | ||||||
|         let search = new AlfrescoSearchComponent(null, null, null, null); |         let search = new AlfrescoSearchComponent(null, null, null, null); | ||||||
|         expect(search).toBeDefined(); |         expect(search).toBeDefined(); | ||||||
| @@ -50,7 +97,7 @@ describe('AlfrescoSearchComponent', () => { | |||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     it('should take the provided search term from query param provided via RouteParams', () => { |     it('should take the provided search term from query param provided via RouteParams', () => { | ||||||
|         let search = new AlfrescoSearchComponent(null, null, null, new RouteParams({ q: 'exampleTerm692' })); |         let search = new AlfrescoSearchComponent(null, null, null, new RouteParams({q: 'exampleTerm692'})); | ||||||
|         expect(search.searchTerm).toBe('exampleTerm692'); |         expect(search.searchTerm).toBe('exampleTerm692'); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
| @@ -72,72 +119,69 @@ describe('AlfrescoSearchComponent', () => { | |||||||
|  |  | ||||||
|     describe('Rendering search results', () => { |     describe('Rendering search results', () => { | ||||||
|  |  | ||||||
|         it('should display search results when a search term is provided', |         it('should display search results when a search term is provided', (done) => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |  | ||||||
|                 return tcb |  | ||||||
|                     .createAsync(AlfrescoSearchComponent) |  | ||||||
|                     .then((fixture) => { |  | ||||||
|                         let componentInstance = fixture.componentInstance, |  | ||||||
|                             searchTerm = 'customSearchTerm'; |  | ||||||
|                         spyOn(componentInstance, 'displaySearchResults').and.stub(); |  | ||||||
|                         componentInstance.searchTerm = searchTerm; |  | ||||||
|                         componentInstance.ngOnChanges(); |  | ||||||
|                         fixture.detectChanges(); |  | ||||||
|                         expect(componentInstance.displaySearchResults).toHaveBeenCalledWith(searchTerm); |  | ||||||
|  |  | ||||||
|                     }); |             component.searchTerm = 'searchTerm'; | ||||||
|             })); |             component.ngOnChanges({searchTerm: component.searchTerm}); | ||||||
|  |  | ||||||
|         it('should display the returned search results', |             component.resultsEmitter.subscribe(x => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |                 alfrescoSearchComponentFixture.detectChanges(); | ||||||
|                 return tcb |                 expect( element.querySelector('#result_user_0').innerHTML).toBe('John Doe'); | ||||||
|                     .overrideProviders(AlfrescoSearchComponent, [ |                 expect( element.querySelector('#result_name_0').innerHTML).toBe('MyDoc'); | ||||||
|                         { provide: AlfrescoSearchService, useClass: SearchServiceMock } |                 done(); | ||||||
|                     ]) |             }); | ||||||
|                     .createAsync(AlfrescoSearchComponent) |  | ||||||
|                     .then((fixture) => { |  | ||||||
|                         let componentInstance = fixture.componentInstance; |  | ||||||
|                         componentInstance.searchTerm = '<term>'; |  | ||||||
|                         componentInstance.ngOnChanges(); |  | ||||||
|                         fixture.detectChanges(); |  | ||||||
|  |  | ||||||
|                         let element = fixture.nativeElement; |             jasmine.Ajax.requests.mostRecent().respondWith({ | ||||||
|                         expect(element.querySelectorAll('table tbody tr').length).toBe(1); |                 status: 200, | ||||||
|  |                 contentType: 'json', | ||||||
|  |                 responseText: result | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|  |  | ||||||
|                     }); |  | ||||||
|             })); |  | ||||||
|  |  | ||||||
|  |         it('should display no result if no result are returned', (done) => { | ||||||
|  |             component.resultsEmitter.subscribe(x => { | ||||||
|  |                 alfrescoSearchComponentFixture.detectChanges(); | ||||||
|  |                 expect( element.querySelector('#search_no_result')).not.toBe(null); | ||||||
|  |                 done(); | ||||||
|  |             }); | ||||||
|  |  | ||||||
|  |             component.searchTerm = 'searchTerm'; | ||||||
|  |             component.ngOnChanges({searchTerm: component.searchTerm}); | ||||||
|  |  | ||||||
|  |             jasmine.Ajax.requests.mostRecent().respondWith({ | ||||||
|  |                 status: 200, | ||||||
|  |                 contentType: 'json', | ||||||
|  |                 responseText: noResult | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|     describe('search result actions', () => { |     describe('search result actions', () => { | ||||||
|  |  | ||||||
|         it('should emit preview when file item clicked', |         it('should emit preview when file item clicked', () => { | ||||||
|             inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { |             component.results = [{ | ||||||
|                 return tcb |                 entry: { | ||||||
|                     .overrideProviders(AlfrescoSearchComponent, [ |                     id: '123', | ||||||
|                         { provide: AlfrescoSearchService, useClass: SearchServiceMock } |                     name: 'MyDoc', | ||||||
|                     ]) |                     content: { | ||||||
|                     .createAsync(AlfrescoSearchComponent) |                         mimetype: 'text/plain' | ||||||
|                     .then((fixture) => { |                     }, | ||||||
|                         let componentInstance = fixture.componentInstance; |                     isFile: true | ||||||
|                         componentInstance.results = [{ |                 } | ||||||
|                             entry: { |             }]; | ||||||
|                                 id: '123', |  | ||||||
|                                 name: 'MyDoc', |  | ||||||
|                                 content: { |  | ||||||
|                                     mimetype: 'text/plain' |  | ||||||
|                                 }, |  | ||||||
|                                 isFile: true |  | ||||||
|                             } |  | ||||||
|                         }]; |  | ||||||
|                         fixture.detectChanges(componentInstance.results[0]); |  | ||||||
|                         componentInstance.preview.subscribe(e => { |  | ||||||
|                             expect(e.value).toBe(componentInstance.results[0]); |  | ||||||
|                         }); |  | ||||||
|                         componentInstance.onItemClick(); |  | ||||||
|  |  | ||||||
|                     }); |             alfrescoSearchComponentFixture.detectChanges(component.results[0]); | ||||||
|             })); |             component.preview.subscribe(e => { | ||||||
|  |                 expect(e.value).toBe(component.results[0]); | ||||||
|  |             }); | ||||||
|  |  | ||||||
|  |             jasmine.Ajax.requests.mostRecent().respondWith({ | ||||||
|  |                 status: 200, | ||||||
|  |                 contentType: 'text/plain', | ||||||
|  |                 responseText: '<div></div>' | ||||||
|  |             }); | ||||||
|  |         }); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -26,24 +26,7 @@ declare let __moduleName: string; | |||||||
| @Component({ | @Component({ | ||||||
|     moduleId: __moduleName, |     moduleId: __moduleName, | ||||||
|     selector: 'alfresco-search', |     selector: 'alfresco-search', | ||||||
|     styles: [` |     styleUrls: ['./alfresco-search.component.css'], | ||||||
|         :host .mdl-data-table caption { |  | ||||||
|             margin: 0 0 16px 0; |  | ||||||
|             text-align: left; |  | ||||||
|         } |  | ||||||
|         :host .mdl-data-table td { |  | ||||||
|             max-width: 0; |  | ||||||
|             white-space: nowrap; |  | ||||||
|         } |  | ||||||
|         :host .mdl-data-table td.col-mimetype-icon { |  | ||||||
|             width: 24px; |  | ||||||
|         } |  | ||||||
|         :host .col-display-name { |  | ||||||
|             min-width: 250px; |  | ||||||
|             overflow: hidden; |  | ||||||
|             text-overflow: ellipsis; |  | ||||||
|         } |  | ||||||
|     `], |  | ||||||
|     templateUrl: './alfresco-search.component.html', |     templateUrl: './alfresco-search.component.html', | ||||||
|     providers: [AlfrescoSearchService], |     providers: [AlfrescoSearchService], | ||||||
|     pipes: [AlfrescoPipeTranslate] |     pipes: [AlfrescoPipeTranslate] | ||||||
| @@ -58,6 +41,9 @@ export class AlfrescoSearchComponent implements OnChanges, OnInit { | |||||||
|     @Output() |     @Output() | ||||||
|     preview: EventEmitter<any> = new EventEmitter(); |     preview: EventEmitter<any> = new EventEmitter(); | ||||||
|  |  | ||||||
|  |     @Output() | ||||||
|  |     resultsEmitter = new EventEmitter(); | ||||||
|  |  | ||||||
|     results: any; |     results: any; | ||||||
|  |  | ||||||
|     errorMessage; |     errorMessage; | ||||||
| @@ -84,7 +70,9 @@ export class AlfrescoSearchComponent implements OnChanges, OnInit { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     ngOnChanges(changes): void { |     ngOnChanges(changes): void { | ||||||
|         this.displaySearchResults(this.searchTerm); |         if (changes.searchTerm) { | ||||||
|  |             this.displaySearchResults(changes.searchTerm); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -123,6 +111,7 @@ export class AlfrescoSearchComponent implements OnChanges, OnInit { | |||||||
|                 .subscribe( |                 .subscribe( | ||||||
|                     results => { |                     results => { | ||||||
|                         this.results = results.list.entries; |                         this.results = results.list.entries; | ||||||
|  |                         this.resultsEmitter.emit(this.results); | ||||||
|                         this.errorMessage = null; |                         this.errorMessage = null; | ||||||
|                     }, |                     }, | ||||||
|                     error => { |                     error => { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user