import { Component, Injector, ViewChild, ViewEncapsulation, LOCALE_ID, Inject, ɵDEFAULT_LOCALE_ID, ViewChildren, QueryList, Output, EventEmitter } from '@angular/core'; import { ActivatedRoute, Router } from '@angular/router'; import { appModuleAnimation } from '@shared/animations/routerTransition'; import { AppComponentBase } from '@shared/common/app-component-base'; import { OrderServiceProxy, OrderListDto, LocationServiceProxy, LocationListDto, OrderTypesServiceProxy, RoleListDto, GetOrderListDtoNew, NameValueDto, GetCreatorUsers, GetOrderInput } from '@shared/service-proxies/service-proxies'; import { LazyLoadEvent } from 'primeng/components/common/lazyloadevent'; import { Paginator } from 'primeng/components/paginator/paginator'; import { Table } from 'primeng/components/table/table'; import { finalize } from 'rxjs/operators'; import * as moment from 'moment'; import { CreateOrderModalComponent } from './create-order-modal.component'; import { PrimengTableHelper } from '@shared/helpers/PrimengTableHelper'; import { FileDownloadService } from '@shared/utils/file-download.service'; import { HttpClient } from '@angular/common/http'; import { AppConsts } from '@shared/AppConsts'; import { FileUpload } from 'primeng/fileupload'; import * as signalR from '@aspnet/signalr'; import { ImportOrderTrackingComponent } from './import-order-tracking.component'; import { LocalizationService } from 'abp-ng2-module/dist/src/localization/localization.service'; import { EntityTypeHistoryModalComponent } from '@app/shared/common/entityHistory/entity-type-history-modal.component'; import * as _ from 'lodash'; import { MovePendingOrder } from '@app/sprintship/controller/route-detail/move-order-modal.component'; import { HeaderNotificationsComponent } from '@app/shared/layout/notifications/header-notifications.component'; import { ProgressBarService } from '@app/shared/layout/progressbar/progressbar.service'; import { interval } from 'rxjs'; import { CreateNewRouteModalComponent } from '@app/sprintship/controller/routes/create-route-modal.component'; @Component({ templateUrl: './order.component.html', encapsulation: ViewEncapsulation.None, animations: [appModuleAnimation()], styleUrls: ['./order.component.less'] }) export class OrderComponent extends AppComponentBase { @ViewChild('movePendingOrder', { static: false }) movePendingOrder: MovePendingOrder; @ViewChild('dataTable', {static: true}) dataTable: Table; @ViewChild('paginator', {static: true}) paginator: Paginator; @ViewChild('createOrderModal', {static: false}) createOrderModal: CreateOrderModalComponent; @ViewChild('ExcelFileUpload', { static: true }) excelFileUpload: FileUpload; @ViewChild('importOrderTracking', {static: false}) importOrderTracking: ImportOrderTrackingComponent; @ViewChild('entityTypeHistoryModal', { static: true }) entityTypeHistoryModal: EntityTypeHistoryModalComponent; @ViewChild('routeList', { static: true }) routeList: CreateNewRouteModalComponent; @Output() passOrderIds: EventEmitter = new EventEmitter(); @Output() passOrderIdsForRoute: EventEmitter = new EventEmitter(); _entityTypeFullName = 'SprintTek.Shipping.Orders.Order'; entityHistoryEnabled = false; //Filters filterText = undefined; locationFilter: LocationListDto = new LocationListDto(); filterDate: moment.Moment; filterRouteDate: any; filterDateString: any; maxResultCount = 1000; filteredOrder: any; filteredLocation: any; filteredOrderTypes: any; advancedFiltersAreShown: false; TimeCreated: any; RouteDate: any; deliveryEta: any; orderId: string; locationId: number; orderTypeId: number; isActiveFilter = -1; uploadUrl: string; orderNumberFilter: string; trackingIdFilter: string; fullNameFilter: string; firstNameFilter: string lastNameFilter: string addressLine1Filter: string; cityFilter: string; stateFilter: string; postalCodeFilter: string; orderImporting: boolean = false; featurefbx: boolean = false; _ukLocale: boolean; _isLab: boolean; private hubConnection: signalR.HubConnection; unassigned: boolean; sprintIds: Array<{}> = new Array(); sprintIdsList: any[]; checkAll: boolean; records: any; creatorId: number = null; creatorUserIds: any; excludUserIds: any; orderusers: GetCreatorUsers[]; constructor( injector: Injector, private router: Router, private _orderAppService: OrderServiceProxy, private _locationAppService: LocationServiceProxy, private _fileDownloadService: FileDownloadService, private _orderTypeService: OrderTypesServiceProxy, private _httpClient: HttpClient, private _localization: LocalizationService, private _progressBar: ProgressBarService ) { super(injector); this.uploadUrl = AppConsts.remoteServiceBaseUrl + '/Import/ImportFromExcel'; this.orderImporting = abp.features.isEnabled('App.OrderImporting'); this.featurefbx = abp.features.isEnabled('App.FBXFeature'); } ngOnInit(){ this.setIsEntityHistoryEnabled(); $('.kt-select2').select2({ }); this._isLab = abp.features.isEnabled('App.RouteDetails'); this._ukLocale = abp.features.isEnabled('App.DateFormatFeature.UKLocale'); this.filterLocation(); // this.filterOrder(); this.filterOrderTypes() this.backgroundProcessListener(); this.getOrderUsers(); setTimeout(function(){ $('.kt-select2').select2(); }, 100); } private setIsEntityHistoryEnabled(): void { let customSettings = (abp as any).custom; this.entityHistoryEnabled = customSettings.EntityHistory && customSettings.EntityHistory.isEnabled && _.filter(customSettings.EntityHistory.enabledEntities, entityType => entityType === this._entityTypeFullName).length === 1; } showHistory(role: GetOrderListDtoNew): void { this.entityTypeHistoryModal.show({ entityId: role.id.toString(), entityTypeFullName: this._entityTypeFullName, entityTypeDescription: "Order - " +role.id.toString() }); } getOrders(event?: LazyLoadEvent) { $('#checkAll').prop('checked',false); this.sprintIds = []; // this.orderId = Number((document.getElementById('OrderId')).value) ? Number((document.getElementById('OrderId')).value) : undefined; this.locationId = Number((document.getElementById('locationSelectInput')).value) ? Number((document.getElementById('locationSelectInput')).value) : undefined; this.orderTypeId = Number((document.getElementById('orderType')).value) ? Number((document.getElementById('orderType')).value) : undefined; // this.creatorId = !this._isLab? undefined // : Number((document.getElementById('CreatedInput')).value) // ? Number((document.getElementById('CreatedInput')).value) // : undefined; if (this.primengTableHelper.shouldResetPaging(event)) { this.paginator.changePage(0); return; } this.spinnerService.show(); if (this.TimeCreated!=undefined){ this.filterDate = moment(this.TimeCreated); } if (this.TimeCreated!=undefined){ this.filterDateString = new Date(this.TimeCreated).toLocaleDateString('en-US'); } if (this.RouteDate!=undefined){ this.filterRouteDate = new Date(this.RouteDate).toLocaleDateString('en-US'); } this.creatorUserIds = $("#createdSelect").val()=='null'? [] : $("#createdSelect").val(); this.excludUserIds = $("#ExcludeInput").val()=='null'? [] : $("#ExcludeInput").val(); let x = new GetOrderInput(); x.id = undefined; x.filter = this.filterText; x.pickupDetailsId = undefined; x.deliveryDetailsId = undefined; x.locationId = this.locationId; x.noteId = undefined; x.creationTime = this.filterDate; x.sortOrder = undefined; x.orderTypeId = this.orderTypeId; x.orderId = this.orderId; x.customerOrderNumberFilter = this.orderNumberFilter; x.trackingIdFilter = this.trackingIdFilter; x.unassigned = this.unassigned; x.routeDate = this.filterRouteDate; x.creationTimeString = this.filterDateString; x.creator = this.creatorId; x.fullNameFilter = this.fullNameFilter; x.addressLine1Filter = this.addressLine1Filter; x.cityFilter = this.cityFilter; x.stateFilter = this.stateFilter; x.postalCodeFilter = this.postalCodeFilter; x.firstNameFilter = this.firstNameFilter; x.lastNameFilter = this.lastNameFilter; x.creatorUserIds = this.creatorUserIds == undefined ? [] : this.creatorUserIds; x.excludedUserIds = this.excludUserIds == undefined ? [] : this.excludUserIds; x.sorting = this.primengTableHelper.getSorting(this.dataTable); x.maxResultCount = this.primengTableHelper.getMaxResultCount(this.paginator, event); x.skipCount = this.primengTableHelper.getSkipCount(this.paginator, event); this._orderAppService.getOrders(x).subscribe(result => { this.primengTableHelper.totalRecordsCount = result.totalCount; // result.items.forEach(item => { // let total = 0; // item.orderPackages.forEach(orderPackage => { // total = total + orderPackage.quantity; // }); // item.totalPackages = total; // }); for (let index = 0; index < result.items.length; index++) { if(this._ukLocale){ result.items[index].createdString = result.items[index].createDate.utcOffset(moment.parseZone(result.items[index].createDate).utcOffset()).format('D/M/YYYY h:mm a'); // result.items[index].lastModifiedString = result.items[index].lastModifiedTime.utcOffset(moment.parseZone(result.items[index].lastModifiedTime).utcOffset()).format('D/M/YYYY h:mm a'); } else{ result.items[index].createdString = result.items[index].createDate.utcOffset(moment.parseZone(result.items[index].createDate).utcOffset()).format('M/D/YYYY h:mm a'); // result.items[index].lastModifiedString = result.items[index].lastModifiedTime.utcOffset(moment.parseZone(result.items[index].lastModifiedTime).utcOffset()).format('M/D/YYYY h:mm a'); } } this.primengTableHelper.records = result.items; this.spinnerService.hide(); }); } createOrder(): void { this.createOrderModal.show(); } reloadPage(): void { this.paginator.changePage(this.paginator.getPage()); } filterLocation(): void { this._locationAppService.getLocationNames( undefined, undefined, undefined, undefined, undefined, undefined ).subscribe(result => { this.filteredLocation = result; }); } filterOrderTypes(): void { this._orderTypeService.getOrderTypes().subscribe(result => { this.filteredOrderTypes = result; }); } deleteOrder(order: OrderListDto): void { this.message.confirm( this.l(''), '', (isConfirmed) => { if (isConfirmed) { this._orderAppService.deleteOrder(order.id) .subscribe(() => { this.reloadPage(); this.notify.success(this.l('SuccessfullyDeleted')); }); } } ); } createOrUpdate(url: any, id?: number){ if(id != null){ var myurl = `${url}/${id}`; }else{ var myurl = `${url}`; } this.router.navigateByUrl(myurl); } exportToExcel(event?: LazyLoadEvent): void { this.locationId = Number((document.getElementById('locationSelectInput')).value) ? Number((document.getElementById('locationSelectInput')).value) : undefined; this.orderTypeId = Number((document.getElementById('orderType')).value) ? Number((document.getElementById('orderType')).value) : undefined; // this.creatorId = !this._isLab? undefined // : Number((document.getElementById('CreatedInput')).value) // ? Number((document.getElementById('CreatedInput')).value) // : undefined; if (this.primengTableHelper.shouldResetPaging(event)) { this.paginator.changePage(0); return; } if (this.TimeCreated!=undefined){ this.filterDate = moment(this.TimeCreated); } if (this.TimeCreated!=undefined){ this.filterDateString = new Date(this.TimeCreated).toLocaleDateString('en-US'); } if (this.RouteDate!=undefined){ this.filterRouteDate = moment(this.RouteDate).format('MM-DD-YYYY'); } this.creatorUserIds = $("#createdSelect").val()=='null'? [] : $("#createdSelect").val(); this.excludUserIds = $("#ExcludeInput").val()=='null'? [] : $("#ExcludeInput").val(); this.spinnerService.show(); let x = new GetOrderInput(); x.id = undefined; x.filter = this.filterText; x.pickupDetailsId = undefined; x.deliveryDetailsId = undefined; x.locationId = this.locationId; x.noteId = undefined; x.creationTime = this.filterDate; x.sortOrder = undefined; x.orderTypeId = this.orderTypeId; x.orderId = this.orderId; x.customerOrderNumberFilter = this.orderNumberFilter; x.trackingIdFilter = this.trackingIdFilter; x.unassigned = this.unassigned; x.routeDate = this.filterRouteDate; x.creationTimeString = this.filterDateString; x.creator = this.creatorId; x.fullNameFilter = this.fullNameFilter; x.addressLine1Filter = this.addressLine1Filter; x.cityFilter = this.cityFilter; x.stateFilter = this.stateFilter; x.postalCodeFilter = this.postalCodeFilter; x.firstNameFilter = this.firstNameFilter; x.lastNameFilter = this.lastNameFilter; x.creatorUserIds = this.creatorUserIds == undefined ? [] : this.creatorUserIds; x.excludedUserIds = this.excludUserIds == undefined ? [] : this.excludUserIds; x.sorting = this.primengTableHelper.getSorting(this.dataTable); x.maxResultCount = this.primengTableHelper.getMaxResultCount(this.paginator, event); x.skipCount = this.primengTableHelper.getSkipCount(this.paginator, event); this._orderAppService.getOrdersForExcels(x) .subscribe(result => { if(result!=undefined){ if(result.fileUrl!=undefined){ this.router.navigate([]).then(result1 => { window.open(result.fileUrl, '_blank'); }); this.spinnerService.hide(); }else{ this.spinnerService.hide(); } }else{ this.message.warn('', "No data to export"); this.spinnerService.hide(); } }); } uploadExcel(data: { files: File }): void { //this.importOrderTracking.clearMessages(); //this.importOrderTracking.modal.show(); const formData: FormData = new FormData(); const file = data.files[0]; formData.append('file', file, file.name); formData.append('key','orders'); formData.append('locale', abp.localization.currentLanguage.name); // formData.append('entity','addresses','addresses'); // console.log(abp.localization.currentLanguage.name); this._httpClient .post(this.uploadUrl, formData) .subscribe(response => { if (response.success) { this.notify.info('Import process is queued. Please wait'); //this.l('ImportOrderStart') this.toggle(true); } else if (response.error != null) { this.toggle(false); this.notify.error(this.l('ImportOrderFailed')); } }); } onUploadExcelError(): void { this.notify.error(this.l('ImportOrderFailed')); } backgroundProcessListener() { this.hubConnection = new signalR.HubConnectionBuilder() .withUrl(AppConsts.remoteServiceBaseUrl + '/import') .build(); this.hubConnection .start() .then(() => console.log('Connection started')) .catch(err => { console.log('Error while starting connection: ' + err); this.toggle(false); }); this.hubConnection.on('BackgroundMessage', (message) => { // if(message.match(/Route created/) || message.match(/Order created/)) { // this.importOrderTracking.logMessage(message, true); // } // else { if (message.match(/End Importing/)) { this.importOrderTracking.importing = false; this.toggle(false); this.notify.success('Import process is complete'); this.getOrders(); } else { this.importOrderTracking.logMessage(message); } this.sendMessage(message); // } }); } createIncidents(url: any, id?: number){ if(id != null){ var myurl = `${url}/${id}`; }else{ var myurl = `${url}`; } //window.open(myurl, "_blank") this.router.navigateByUrl(myurl); } toggle (toggle: boolean){ this._progressBar.toggleProgressBar(toggle); } sendMessage(message: string) { this._progressBar.sendMessage(message); } selectAllOrders() { this.sprintIdsList = null; this.records = this.primengTableHelper.records for (var i = 0; i < this.records.length; i++) { if (this.checkAll == true) { this.sprintIds.push(this.records[i].id); this.records[i].selected = this.checkAll; } else { this.sprintIds.splice(this.sprintIds.indexOf(this.records[i].id), 1); this.records[i].selected = this.checkAll; } } // console.log(this.sprintIds) } moveOrders(id: number) { if (this.sprintIds.indexOf(id) == -1) { this.sprintIds.push(id); } else { this.sprintIds.splice(this.sprintIds.indexOf(id), 1); } // this.sprintIdsList = this.sprintIds; this.passOrderIds.emit(this.sprintIds) this.passOrderIdsForRoute.emit(this.sprintIds); } movePendingOrders(){ this.movePendingOrder.show(null, undefined, 0); this.movePendingOrder.orderIds = this.sprintIds; } refresh(){ this.sprintIdsList = []; this.sprintIds = []; this.getOrders(); } getOrderUsers(){ this._orderAppService.getOrderUsers().subscribe(result => { this.orderusers = result; }); } }