#68 close button

This commit is contained in:
Eugenio Romano
2016-06-02 12:58:49 +01:00
parent 4f83354712
commit 7acc96c61c
7 changed files with 257 additions and 151 deletions

View File

@@ -133,7 +133,7 @@
[multipleFiles]="true" [multipleFiles]="true"
(onSuccess)="refreshDocumentList($event)"></alfresco-upload-button> (onSuccess)="refreshDocumentList($event)"></alfresco-upload-button>
<alfresco-viewer [urlFile]="(urlFile)" [overlayMode]="true" [hidden]="!fileShowed" > <alfresco-viewer [(showViewer)]="fileShowed" [urlFile]="urlFile" [overlayMode]="true">
<div class="mdl-spinner mdl-js-spinner is-active"></div> <div class="mdl-spinner mdl-js-spinner is-active"></div>
</alfresco-viewer> </alfresco-viewer>
<file-uploading-dialog></file-uploading-dialog> <file-uploading-dialog></file-uploading-dialog>

View File

@@ -108,6 +108,8 @@ Attribute | Options | Default | Description | Mandatory
--- | --- | --- | --- | --- --- | --- | --- | --- | ---
`urlFile` | *string* | | Url where to load the file | mandatory `urlFile` | *string* | | Url where to load the file | mandatory
`overlayMode` | *boolean* | `false` | if true Show the Viewer full page over the present content | `overlayMode` | *boolean* | `false` | if true Show the Viewer full page over the present content |
`showViewer` | *boolean* | `true` | Hide o show the viewer |
## Build from sources ## Build from sources

View File

@@ -21,7 +21,7 @@ import { VIEWERCOMPONENT } from 'ng2-alfresco-viewer/dist/ng2-alfresco-viewer';
@Component({ @Component({
selector: 'my-app', selector: 'my-app',
template: ` <alfresco-viewer [overlayMode]="true" [urlFile]="'localTestFile.pdf'"> template: ` <alfresco-viewer [showViewer]="true" [overlayMode]="true" [urlFile]="'localTestFile.pdf'">
<div class="mdl-spinner mdl-js-spinner is-active"></div> <div class="mdl-spinner mdl-js-spinner is-active"></div>
</alfresco-viewer>`, </alfresco-viewer>`,
directives: [VIEWERCOMPONENT] directives: [VIEWERCOMPONENT]

View File

@@ -1,7 +1,7 @@
{ {
"name": "ng2-alfresco-viewer", "name": "ng2-alfresco-viewer",
"description": "Alfresco documents viewer", "description": "Alfresco documents viewer",
"version": "0.1.7", "version": "0.1.8",
"author": "Eugenio Romano", "author": "Eugenio Romano",
"scripts": { "scripts": {
"typings": "typings install", "typings": "typings install",

View File

@@ -1,111 +1,100 @@
<div *ngIf="showViewer">
<div *ngIf="overlayMode"> <div *ngIf="overlayMode">
<div id="viewer-shadow-transparent" class="viewer-shadow-transparent"></div> <div id="viewer-shadow-transparent" class="viewer-shadow-transparent"></div>
</div> </div>
<div id="viewer-main-container" class="viewer-main-container" [ngClass]="{'viewer-overlay-view': overlayMode }"> <div id="viewer-main-container" class="viewer-main-container" [ngClass]="{'viewer-overlay-view': overlayMode }">
<!-- Start Layout --> <!-- Start Layout -->
<div mdl class="mdl-layout mdl-js-layout mdl-layout--fixed-header"> <div mdl class="mdl-layout mdl-js-layout mdl-layout--fixed-header">
<header class="mdl-layout__header"> <header class="mdl-layout__header">
<div class="mdl-layout__header-row"> <div class="mdl-layout__header-row">
<!-- File Title --> <!-- File Title -->
<span id="viewer-name-file" class="mdl-layout-title viewer-name-file">{{nameFile}}</span> <span id="viewer-name-file" class="mdl-layout-title viewer-name-file">{{nameFile}}</span>
<!-- Pagination toolbar start --> <!-- Pagination toolbar start -->
<div id="viewer-toolbar-pagination"> <div id="viewer-toolbar-pagination">
<div id="viewer-previous-page-page-button-input" class="left" (click)="previousPage()"> <div id="viewer-previous-page-button-input" class="left" (click)="previousPage()">
<i class="icon material-icons">keyboard_arrow_left</i> <i class="icon material-icons">keyboard_arrow_left</i>
</div> </div>
<input id="viewer-pagenumber-input" #page <input id="viewer-pagenumber-input" #page
(keyup.enter)="inputPage(page.value)" class="left" type="text" pattern="-?[0-9]*(\.[0-9]+)?" value="{{displayPage}}"> (keyup.enter)="inputPage(page.value)" class="left" type="text" pattern="-?[0-9]*(\.[0-9]+)?" value="{{displayPage}}">
<span id="viewer-total-pages" class="left">/ {{totalPages}}</span> <span id="viewer-total-pages" class="left">/ {{totalPages}}</span>
<div id="viewer-next-page-button-button-input" (click)="nextPage()" class="left"> <div id="viewer-next-page-button-button-input" (click)="nextPage()" class="left">
<i class="icon material-icons" >keyboard_arrow_right</i> <i class="icon material-icons" >keyboard_arrow_right</i>
</div> </div>
</div> </div>
<!-- Pagination toolbar end --> <!-- Pagination toolbar end -->
<span class="vertical-divider"></span> <span class="vertical-divider"></span>
<div class="mdl-layout-spacer"></div> <div class="mdl-layout-spacer"></div>
<!-- Start Navigation --> <!-- Start Navigation -->
<nav class="mdl-navigation"> <nav class="mdl-navigation">
<div class="button-container"> <div id="viewer-toolbar-view-options">
<button <div class="button-container">
class="mdl-button mdl-js-button mdl-button--fab mdl-button--mini-fab mdl-button--colored" (click)="cazzo()"> <button
<i id="viewer-print-button" class="icon material-icons">print</i> class="mdl-button mdl-js-button mdl-button--fab mdl-button--mini-fab mdl-button--colored" (click)="close()">
</button> <i id="viewer-close-button" class="icon material-icons">close</i>
</div> </button>
</div>
</div>
<div class="mdl-textfield mdl-js-textfield mdl-textfield--expandable </nav>
mdl-textfield--floating-label mdl-textfield--align-right"> <!-- End Navigation -->
<label class="mdl-button mdl-js-button mdl-button--icon" </div>
for="waterfall-exp"> </header>
<i class="material-icons">search</i> <div class="mdl-layout__drawer">
</label> <span class="mdl-layout-title">Thumbnail</span>
</div>
<div class="mdl-textfield__expandable-holder"> <main class="mdl-layout__content">
<input class="mdl-textfield__input" type="text" name="sample" id="waterfall-exp"> <div class="page-content">
</div>
</div> <div class="mdl-grid">
</nav> <div class="mdl-cell mdl-cell--2-col mdl-cell--hide-tablet mdl-cell--hide-phone"></div>
<!-- End Navigation --> <div
class="mdl-color--white mdl-shadow--4dp content mdl-color-text--grey-800 mdl-cell mdl-cell--8-col">
</div>
</header> <!-- Start Pdf Canvas -->
<div class="mdl-layout__drawer"> <div id="viewer-canvas-container" class="viewer-canvas-container">
<span class="mdl-layout-title">Thumbnail</span> <div id="viewer-the-canvas" style="border:1px solid black;"></div>
</div> </div>
<main class="mdl-layout__content"> <!-- End Pdf Canvas -->
<div class="page-content">
<div id="viewer-previous-page-button" class="previous-page-button">
<div class="mdl-grid"> <button
<div class="mdl-cell mdl-cell--2-col mdl-cell--hide-tablet mdl-cell--hide-phone"></div> class="mdl-button mdl-js-button mdl-button--fab mdl-button--mini-fab mdl-button--colored"
<div (click)="previousPage()">
class="mdl-color--white mdl-shadow--4dp content mdl-color-text--grey-800 mdl-cell mdl-cell--8-col"> <i class="icon material-icons">keyboard_arrow_left</i>
</button>
<!-- Start Pdf Canvas --> </div>
<div id="viewer-canvas-container" class="viewer-canvas-container">
<div id="viewer-the-canvas" style="border:1px solid black;"></div> <div id="viewer-next-page-button" class="next-page-button">
</div> <button
<!-- End Pdf Canvas --> class="mdl-button mdl-js-button mdl-button--fab mdl-button--mini-fab mdl-button--colored"
(click)="nextPage()">
<div id="viewer-previous-page-button" class="previous-page-button"> <i class="icon material-icons">keyboard_arrow_right</i>
<button </button>
class="mdl-button mdl-js-button mdl-button--fab mdl-button--mini-fab mdl-button--colored" </div>
(click)="previousPage()">
<i class="icon material-icons">keyboard_arrow_left</i> </div>
</button> </div>
</div> <footer class="mdl-mini-footer">
<div class="mdl-mini-footer--left-section">
<div id="viewer-next-page-button" class="next-page-button"> <ul class="mdl-mini-footer--link-list">
<button <li><a href="#">Footer link 1</a></li>
class="mdl-button mdl-js-button mdl-button--fab mdl-button--mini-fab mdl-button--colored" <li><a href="#">Footer link 2</a></li>
(click)="nextPage()"> <li><a href="#">Footer link 3</a></li>
<i class="icon material-icons">keyboard_arrow_right</i> </ul>
</button> </div>
</div> </footer>
</div> </div>
</div> </main>
<footer class="mdl-mini-footer"> </div>
<div class="mdl-mini-footer--left-section"> <!-- End Layout -->
<ul class="mdl-mini-footer--link-list">
<li><a href="#">Footer link 1</a></li>
<li><a href="#">Footer link 2</a></li>
<li><a href="#">Footer link 3</a></li>
</ul>
</div>
</footer>
</div>
</main>
</div> </div>
<!-- End Layout -->
</div> </div>

View File

@@ -15,7 +15,7 @@
* limitations under the License. * limitations under the License.
*/ */
import { describe, expect, it, injectAsync, TestComponentBuilder, setBaseTestProviders, beforeEach } from 'angular2/testing'; import { describe, expect, it, injectAsync, TestComponentBuilder, setBaseTestProviders } from 'angular2/testing';
import { TEST_BROWSER_PLATFORM_PROVIDERS, TEST_BROWSER_APPLICATION_PROVIDERS } from 'angular2/platform/testing/browser'; import { TEST_BROWSER_PLATFORM_PROVIDERS, TEST_BROWSER_APPLICATION_PROVIDERS } from 'angular2/platform/testing/browser';
import { ViewerComponent } from './viewer.component'; import { ViewerComponent } from './viewer.component';
import { PDFJSmock } from './assets/PDFJS.mock'; import { PDFJSmock } from './assets/PDFJS.mock';
@@ -31,8 +31,10 @@ describe('Ng2-alfresco-viewer', () => {
.then((fixture) => { .then((fixture) => {
let element = fixture.nativeElement; let element = fixture.nativeElement;
expect(element.querySelector('#viewer-the-canvas')).toBeDefined(); fixture.detectChanges();
expect(element.querySelector('#viewer-canvas-container')).toBeDefined();
expect(element.querySelector('#viewer-the-canvas')).not.toBeNull();
expect(element.querySelector('#viewer-canvas-container')).not.toBeNull();
}); });
})); }));
@@ -46,7 +48,8 @@ describe('Ng2-alfresco-viewer', () => {
component.overlayMode = true; component.overlayMode = true;
fixture.detectChanges(); fixture.detectChanges();
expect(element.querySelector('#viewer-shadow-transparent')).toBeDefined();
expect(element.querySelector('#viewer-shadow-transparent')).not.toBeNull();
}); });
})); }));
@@ -55,8 +58,11 @@ describe('Ng2-alfresco-viewer', () => {
.createAsync(ViewerComponent) .createAsync(ViewerComponent)
.then((fixture) => { .then((fixture) => {
let element = fixture.nativeElement; let element = fixture.nativeElement;
expect(element.querySelector('#viewer-previous-page-button')).toBeDefined();
expect(element.querySelector('#viewer-next-page-button')).toBeDefined(); fixture.detectChanges();
expect(element.querySelector('#viewer-previous-page-button')).not.toBeNull();
expect(element.querySelector('#viewer-next-page-button')).not.toBeNull();
}); });
})); }));
@@ -65,11 +71,14 @@ describe('Ng2-alfresco-viewer', () => {
.createAsync(ViewerComponent) .createAsync(ViewerComponent)
.then((fixture) => { .then((fixture) => {
let element = fixture.nativeElement; let element = fixture.nativeElement;
fixture.detectChanges();
expect(element.querySelector('#viewer-pagenumber-input')).toBeDefined(); expect(element.querySelector('#viewer-pagenumber-input')).toBeDefined();
expect(element.querySelector('#viewer-total-pages')).toBeDefined(); expect(element.querySelector('#viewer-total-pages')).toBeDefined();
expect(element.querySelector('#viewer-previous-page-page-button-input')).toBeDefined(); expect(element.querySelector('#viewer-previous-page-button')).not.toBeNull();
expect(element.querySelector('#viewer-next-page-page-button-input')).toBeDefined(); expect(element.querySelector('#viewer-next-page-button')).not.toBeNull();
}); });
})); }));
@@ -107,6 +116,37 @@ describe('Ng2-alfresco-viewer', () => {
}); });
}); });
})); }));
it('Close button should be present', injectAsync([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb
.createAsync(ViewerComponent)
.then((fixture) => {
let element = fixture.nativeElement;
let component = fixture.componentInstance;
spyOn(component, 'getPDFJS').and.returnValue(new PDFJSmock());
component.urlFile = 'fake-url-file';
fixture.detectChanges();
expect(element.querySelector('#viewer-close-button')).not.toBeNull();
});
}));
it('if showViewer is false the viewer should be hide', injectAsync([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb
.createAsync(ViewerComponent)
.then((fixture) => {
let element = fixture.nativeElement;
let component = fixture.componentInstance;
spyOn(component, 'getPDFJS').and.returnValue(new PDFJSmock());
component.showViewer = false;
fixture.detectChanges();
expect(element.querySelector('#viewer-the-canvas')).toBeNull();
expect(element.querySelector('#viewer-canvas-container')).toBeNull();
});
}));
}); });
describe('Attribute', () => { describe('Attribute', () => {
@@ -115,11 +155,57 @@ describe('Ng2-alfresco-viewer', () => {
.createAsync(ViewerComponent) .createAsync(ViewerComponent)
.then((fixture) => { .then((fixture) => {
let component = fixture.componentInstance; let component = fixture.componentInstance;
component.showViewer = true;
expect(() => { expect(() => {
component.urlFile = 'fake-url-file'; component.ngOnChanges();
}).toThrow(); }).toThrow();
}); });
})); }));
it('showViewer default value should be true', injectAsync([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb
.createAsync(ViewerComponent)
.then((fixture) => {
let component = fixture.componentInstance;
expect(component.showViewer).toBe(true);
});
}));
it('if showViewer value is false the viewer should be hide', injectAsync([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb
.createAsync(ViewerComponent)
.then((fixture) => {
let component = fixture.componentInstance;
let element = fixture.nativeElement;
component.urlFile = 'fake-url-file';
component.showViewer = false;
fixture.detectChanges();
expect(element.querySelector('#viewer-the-canvas')).toBeNull();
expect(element.querySelector('#viewer-canvas-container')).toBeNull();
});
}));
});
describe('User interaction', () => {
it('Click on close button should hide the viewer', injectAsync([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb
.createAsync(ViewerComponent)
.then((fixture) => {
let element = fixture.nativeElement;
let component = fixture.componentInstance;
spyOn(component, 'getPDFJS').and.returnValue(new PDFJSmock());
component.urlFile = 'fake-url-file';
fixture.detectChanges();
expect(element.querySelector('#viewer-canvas-container')).not.toBeNull();
element.querySelector('#viewer-close-button').click();
fixture.detectChanges();
expect(element.querySelector('#viewer-canvas-container')).toBeNull();
});
}));
}); });
}); });

View File

@@ -15,7 +15,8 @@
* limitations under the License. * limitations under the License.
*/ */
import { Component, Input, SimpleChange } from 'angular2/core'; import { Component, Input, Output } from 'angular2/core';
import { EventEmitter } from 'angular2/src/facade/async';
declare let PDFJS: any; declare let PDFJS: any;
declare let __moduleName: string; declare let __moduleName: string;
@@ -34,31 +35,44 @@ export class ViewerComponent {
@Input() @Input()
overlayMode: boolean = false; overlayMode: boolean = false;
@Input()
showViewer: boolean = true;
@Output()
showViewerChange: EventEmitter<boolean> = new EventEmitter<boolean>();
nameFile: string; nameFile: string;
currentPdfDocument: any; currentPdfDocument: any;
currentPage: number; page: number;
displayPage: number; displayPage: number;
totalPages: number; totalPages: number;
ngOnInit() { pdfViewer: any;
if (!this.urlFile) {
throw new Error('Attribute urlFile is required');
}
}
ngOnChanges(changes: {[urlFile: string]: SimpleChange}) { renderingStates = {
if (this.urlFile) { FINISHED: 3 as number
this.nameFile = this.getPDFJS().getFilenameFromUrl(this.urlFile); };
this.urlFile = this.addAlfrescoTicket(this.urlFile); ngOnChanges(changes) {
console.log(changes);
return this.getPDFJS().getDocument(this.urlFile, null, null).then((pdfDocument) => { if (this.showViewer) {
this.currentPdfDocument = pdfDocument; if (!this.urlFile) {
this.totalPages = pdfDocument.numPages; throw new Error('Attribute urlFile is required');
this.currentPage = 1; }
this.displayPage = 1;
this.loadPage(this.currentPdfDocument); if (this.urlFile) {
}); this.nameFile = this.getPDFJS().getFilenameFromUrl(this.urlFile);
let urlFileTicket = this.addAlfrescoTicket(this.urlFile);
return this.getPDFJS().getDocument(urlFileTicket, null, null).then((pdfDocument) => {
this.currentPdfDocument = pdfDocument;
this.totalPages = pdfDocument.numPages;
this.page = 1;
this.displayPage = 1;
this.loadPage(this.currentPdfDocument);
});
}
} }
} }
@@ -76,21 +90,28 @@ export class ViewerComponent {
let documentContainer: any = document.getElementById('viewer-canvas-container'); let documentContainer: any = document.getElementById('viewer-canvas-container');
let pdfViewer = new PDFJS.PDFViewer({ this.pdfViewer = new PDFJS.PDFViewer({
container: documentContainer container: documentContainer
}); });
pdfViewer.setDocument(pdfDocument); this.pdfViewer.setDocument(pdfDocument);
} }
/** /**
* load the previous page * load the previous page
*/ */
previousPage() { previousPage() {
if (this.currentPage > 1) { if (this.page > 1) {
this.currentPage--; this.page--;
this.displayPage = this.currentPage; this.displayPage = this.page;
this.loadPage(this.currentPdfDocument);
let currentPage = this.pdfViewer.getPageView(this.page - 1);
if (currentPage.renderingState === this.renderingStates.FINISHED) {
// remove loader
} else {
// add loader
}
} }
} }
@@ -98,10 +119,10 @@ export class ViewerComponent {
* load the next page * load the next page
*/ */
nextPage() { nextPage() {
if (this.currentPage < this.totalPages) { if (this.page < this.totalPages) {
this.currentPage++; this.page++;
this.displayPage = this.currentPage; this.displayPage = this.page;
this.loadPage(this.currentPdfDocument); this.pdfViewer.getPageView(this.page - 1);
} }
} }
@@ -114,10 +135,10 @@ export class ViewerComponent {
let pageInput = parseInt(page, 10); let pageInput = parseInt(page, 10);
if (!isNaN(pageInput) && pageInput > 0 && pageInput <= this.totalPages) { if (!isNaN(pageInput) && pageInput > 0 && pageInput <= this.totalPages) {
this.currentPage = pageInput; this.page = pageInput;
this.loadPage(this.currentPdfDocument); this.loadPage(this.currentPdfDocument);
} else { } else {
this.displayPage = this.currentPage; this.displayPage = this.page;
} }
} }
@@ -129,6 +150,14 @@ export class ViewerComponent {
return url + '?alf_ticket=' + this.getAlfrescoTicket(); return url + '?alf_ticket=' + this.getAlfrescoTicket();
} }
/**
* close the viewer
*/
close() {
this.showViewer = false;
this.showViewerChange.emit(this.showViewer);
}
/** /**
* Get the token from the local storage * Get the token from the local storage
* @returns {string} * @returns {string}