Skip to content
Snippets Groups Projects
home.component.ts 3.58 KiB
Newer Older
  • Learn to ignore specific revisions
  • import { Component, OnInit, QueryList, ViewChildren } from '@angular/core';
    
    Florian Azizian's avatar
    Florian Azizian committed
    import { HttpClient } from '@angular/common/http';
    
    import { LANG } from '../translate.component';
    
    import { MatDialog } from '@angular/material/dialog';
    import { MatExpansionPanel } from '@angular/material/expansion';
    import { MatTableDataSource } from '@angular/material/table';
    
    import { NotificationService } from '../notification.service';
    
    import { HeaderService } from '../../service/header.service';
    
    import { DomSanitizer, SafeHtml } from '@angular/platform-browser';
    
    import { AppService } from '../../service/app.service';
    
    import { Router } from '@angular/router';
    
    Florian Azizian's avatar
    Florian Azizian committed
    
    
    Florian Azizian's avatar
    Florian Azizian committed
    
    @Component({
    
        templateUrl: 'home.component.html',
    
        styleUrls: ['home.component.scss'],
    
    Florian Azizian's avatar
    Florian Azizian committed
    })
    
    export class HomeComponent implements OnInit {
    
    Florian Azizian's avatar
    Florian Azizian committed
    
    
        lang: any = LANG;
        loading: boolean = false;
    
        thumbnailUrl: string;
        docUrl: string = '';
        homeData: any;
        homeMessage: string;
        dataSource: any;
        currentDate: string = '';
        nbMpDocs: number = 0;
    
        public innerHtml: SafeHtml;
        displayedColumns: string[] = ['res_id', 'subject', 'creation_date'];
    
    Florian Azizian's avatar
    Florian Azizian committed
    
        @ViewChildren(MatExpansionPanel) viewPanels: QueryList<MatExpansionPanel>;
    
            public http: HttpClient,
            public dialog: MatDialog,
            private sanitizer: DomSanitizer,
            private notify: NotificationService,
    
            private headerService: HeaderService,
    
            public appService: AppService,
            private router: Router
    
            (<any>window).pdfWorkerSrc = '../../node_modules/pdfjs-dist/build/pdf.worker.min.js';
    
    Florian Azizian's avatar
    Florian Azizian committed
        }
    
        ngOnInit(): void {
    
            this.loading = true;
    
            if (this.appService.getViewMode()) {
    
                this.displayedColumns = ['res_id', 'subject'];
            }
    
    Alex ORLUC's avatar
    Alex ORLUC committed
            this.headerService.setHeader(this.lang.home);
    
            const event = new Date();
            const options = { weekday: 'long', year: 'numeric', month: 'long', day: 'numeric' };
    
            this.currentDate = event.toLocaleDateString(this.lang.langISO, options);
    
    Florian Azizian's avatar
    Florian Azizian committed
    
    
            this.http.get('../../rest/home')
    
                .subscribe((data: any) => {
                    this.homeData = data;
    
        }
    
        ngAfterViewInit(): void {
    
            this.http.get('../../rest/home/lastRessources')
                .subscribe((data: any) => {
                    setTimeout(() => {
                        this.dataSource = new MatTableDataSource(data.lastResources);
                        this.loading = false;
                    }, 0);
                });
    
    Florian Azizian's avatar
    Florian Azizian committed
        }
    
    
        viewDocument(row: any) {
    
            window.open('../../rest/resources/' + row.res_id + '/content?mode=view', '_blank');
    
        viewThumbnail(row: any) {
            const timeStamp = +new Date();
    
            this.thumbnailUrl = '../../rest/resources/' + row.res_id + '/thumbnail?tsp=' + timeStamp;
    
            $('#viewThumbnail').show();
            $('#listContent').css({ 'overflow': 'hidden' });
    
        }
    
        closeThumbnail() {
    
            $('#viewThumbnail').hide();
            $('#listContent').css({ 'overflow': 'auto' });
    
        goToDetail(row: any) {
            this.http.get('../../rest/resources/' + row.res_id + '/isAllowed')
    
                .subscribe((data: any) => {
                    if (data['isAllowed']) {
    
                        this.router.navigate([`/resources/${row.res_id}`]);
    
                    } else {
                        this.notify.error(this.lang.documentOutOfPerimeter);
                    }
                }, () => {
                    this.notify.error(this.lang.errorOccured);
                });
    
    Damien's avatar
    Damien committed
    }