import { Component, OnDestroy, ViewChild } from '@angular/core'; import { animate, state, style, transition, trigger } from '@angular/animations'; import { NgProgressComponent } from 'ngx-progressbar'; import { AppSettings, appSettings } from '@app/core/services/setting.service'; import { DialogService } from '@app/core/services/dialog.service'; import { EventService } from '@app/core/services/event.service' import { HttpService } from '@app/core/services/http.service'; import { I18nService, I18nItem } from '@app/core/services/i18n.service'; import { MediaService } from '@app/core/services/media.service'; import { RouterService, RouterItem } from '@app/core/services/router.service'; import { SignalrService } from '@app/core/services/signalr.service'; import { ThemeService, ThemeItem } from '@app/core/services/theme.service'; import { ToastService } from '@app/core/services/toast.service'; import { PasswordComponent } from './password/password.component'; import { ProfileComponent } from './profile/profile.component'; import * as screenfull from 'screenfull'; import { stringify } from 'querystring'; import { async } from '@angular/core/testing'; @Component({ selector: 'app-admin', templateUrl: './admin.component.html', styleUrls: ['./admin.component.scss'], animations: [ trigger('expand', [ state('collapsed', style({ height: '0', maxHeight: '0' })), state('expanded', style({ height: '*', maxHeight: 'unset' })), transition('expanded <=> collapsed', animate('200ms cubic-bezier(.4, 0, .2, 1)')), ]), ] }) export class AdminComponent implements OnDestroy { constructor( private _dialogService: DialogService, private _eventService: EventService, private _httpService: HttpService, private _i18nService: I18nService, private _mediaService: MediaService, private _routerService: RouterService, private _signalrService: SignalrService, private _themeService: ThemeService, private _toastService: ToastService, ) { this.init(); // this.online(); // this.message(); //条码扫描 异常标识信息方法 this.startTimer(); //条码异常报错信息 this.alertMessages.list =[]; this.alertMessages.count =this.alertMessages.list.length; this.layout.react(this._mediaService.current); this._mediaService.onchange.subscribe(this.layout.react); } ngOnDestroy(): void { this._alive = false; this._onlineHub?.stop(); this._messageHub?.stop(); } //进度条 @ViewChild('$progress', { static: true }) private _progress: NgProgressComponent; //条码扫描异常 private timer: any; //设置 public get settings(): AppSettings { return appSettings; } //布局 public layout: { media?: string, sidenavpos?: string, sidenavfold?: boolean, sidenavopen?: boolean, screenfull: any, react: (e: string) => void } = { screenfull: screenfull, react: e => { this.layout.sidenavpos = 'start'; switch (this.layout.media = e) { case 'mobile': //mobile默认布局:导航悬浮并收起 this.layout.sidenavfold = true; this.layout.sidenavopen = false; break; case 'tablet': //tablet默认布局:导航悬浮并打开 this.layout.sidenavfold = true; this.layout.sidenavopen = true; break; case 'monitor': //monitor默认布局:导航平铺 this.layout.sidenavfold = false; this.layout.sidenavopen = true; break; } } }; //账号 public avatar: string = appSettings.defaultAvatar = ''; public account: { name: string, avatar: string } = { name: '...', avatar: this.avatar }; //菜单 public menu: { items?: RouterItem[], toggle?: (item: any) => void } = {}; //语言 public get languages(): I18nItem[] { return this._i18nService.items; }; public get language(): string { return this._i18nService.current; }; public set language(value: string) { this._i18nService.current = value; }; //主题 public get themes(): ThemeItem[] { return this._themeService.items; }; public get theme(): string { return this._themeService.current; }; public set theme(value: string) { this._themeService.current = value; }; //条码扫描定异常查询时器 //初始化 const wareHouse:any=await this._httpService.get('applyrecord/wareHouse'); private async init(): Promise { const response = await this._httpService.join( this._httpService.get('users/current'), this._httpService.get('users/current/routes') ).catch(); if (response) { this.account.name = response[0].name; this.account.avatar = response[0].avatar || this.avatar; this.menu = { items: this._routerService.init(response[1]), toggle: item => this._routerService.focus(item) } // this.alertMessages.list ={ // this.alertMessages.list = (any)response[2].items; // this.alertMessages.count = response[2].total; // } // this.alertMessages.list =response[2]; // console.log(response[2]); // console.log(response[2].total) } } //上线 private _alive: boolean = true; private _onlineHub: any; private async online(): Promise { if (this._alive) { this._onlineHub = await this._signalrService.connect('identity', { conflict: async () => { this._onlineHub.stop(); await this._dialogService.alert(this._i18nService.translate('shared.notification.conflict')); this._routerService.navigate('/auth/login'); } }).catch(e => { if (e) { setTimeout(async () => await this.online(), 5000); } }); } } //消息 public messages: { count?: number, list?: { id: number, time: Date, subject: string, source: { name: string, avatar?: string } }[], open: (id?: number) => void } = { open: id => { //this._routerService.navigate('/message', { id }); } }; //条码扫描异常 刷新到界面 startTimer() { this.timer = setInterval(async()=> { // debugger //get 方法取WMS apply 表里的数据 const response: any = await this._httpService.get('applyrecord/wmsApply').catch(); if (response) { this.alertMessages.count = response.total; this.alertMessages.list = response.items; //console.log(response.items); //console.log(response.total); if(response.total != 0){ for(let i = 0; i < this.alertMessages.list.length; i++){ this.alertMessages.list[i].stockBarcode = response.items[i].stock_barcode; this.alertMessages.list[i].deviceCode = response.items[i].device_code; this.alertMessages.list[i].errorText = response.items[i].control_apply_remark; // console.log(response.items[i]); } } } // debugger // console.log(response.items); // console.log('---------'); // console.log(this.alertMessages.list[0].stockBarcode ); },1000);//10秒刷新一回 } //条码申请异常弹框 public alertMessages:{ count? :number, list?:{ stockBarcode?:string, deviceCode?:string, errorText?:string }[], operate: (deviceCode?:string) => void }= { operate: deviceCode => { //console.log(deviceCode); 不需要操作 } }; private _messageHub: any; private async message(): Promise { const refresh = async (): Promise => { const response: any = await this._httpService.get('users/current/messages?flag=false&limit=5').catch(); if (response) { this.messages.count = response.total; this.messages.list = response.items; } } refresh(); if (this._alive) { this._messageHub = await this._signalrService.connect('message', { notify: async () => { await refresh(); if (this.messages.count > 0) { this._toastService.show(this._i18nService.translate('layouts.admin.message.notify')); } } }).catch(e => { if (e) { //setTimeout(async () => await this.message(), 5000); } }); } this._eventService.on('openMessage', refresh); } //账号配置 public profile(e: any): void { const file = new FileReader(); if (e.path[0].files.length) { file.readAsDataURL(e.path[0].files[0]); file.onload = () => { this._dialogService.open(ProfileComponent, { width: '100vw', height: '100vh', maxWidth: '100vw', maxHeight: '100vh', restoreFocus: false, data: file.result }).then((result: string) => { e.path[0].value = null; if (result) { this.account.avatar = result; } }); } } } //修改密码 public password(): void { this._dialogService.open(PasswordComponent, { autoFocus: false }); } //注销 public logout(): void { this._progress.progressRef = null; this._httpService.delete('sessions', { reason: 'Logout' }); this._routerService.navigate('/auth/login'); } }