Prod Bonus Setup, report

This commit is contained in:
mashfiq 2024-10-24 12:51:22 +06:00
parent edd488a6b4
commit 114f4588ca
4 changed files with 88 additions and 54 deletions

View File

@ -246,6 +246,12 @@
</GroupExpressions>
</Group>
<SortExpressions>
<SortExpression>
<Value>=Year(Fields!Date.Value)</Value>
</SortExpression>
<SortExpression>
<Value>=Month(Fields!Date.Value)</Value>
</SortExpression>
<SortExpression>
<Value>=Fields!Date.Value</Value>
</SortExpression>

View File

@ -1,88 +1,88 @@
<app-loading-panel></app-loading-panel>
<!-- <form [formGroup]="productionBonousSetupForm"> -->
<div class="p-grid card">
<div class="p-col-1 label-ailgn">
<div class="p-col-12 p-lg-1 label-ailgn">
<input type="checkbox" kendoCheckBox id="disabled" (change)="OnclickCheckbox()" [checked]="isNewLayout"
style="margin-top: -3px ;" />
<label style="padding-left: 1%; margin: auto;" for="disabled">
New Layout</label>
</div>
<div class="p-col-1 label-ailgn" align="right">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>Salary Month</label>
</div>
<div class="p-col-2">
<div class="p-col-12 p-lg-2">
<kendo-datepicker [(ngModel)]="selectedSalaryDate" [format]="'dd MMMM yyyy'"
style="width:100%"></kendo-datepicker>
</div>
<div class="p-col-2" align="right">
<button icon="reload" kendoButton [primary]="true" style="width:60%" *ngIf="!isNewLayout" for="disabled"
<div class="p-col-12 p-lg-2">
<button icon="reload" kendoButton [primary]="true" style="width: fit-content" *ngIf="!isNewLayout" for="disabled"
(click)="Loadlayout()">Refresh</button>
</div>
<div class="p-col-1 label-ailgn" align="right">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>Layout No.</label>
</div>
<div class="p-col-3" align="right">
<div class="p-col-12 p-lg-3">
<kendo-dropdownlist [data]="filteredProdBSdata" [(ngModel)]="selectedProdBSdata" [filterable]="true"
textField="design" valueField="id" style="width:95%" (filterChange)="handleFilter($event)"
*ngIf="!isNewLayout" [defaultItem]="{ design: 'Select layout no..'}" [disabled]="prodBSdata===undefined">
textField="design" valueField="id" style="width:100%" (filterChange)="handleFilter($event)"
*ngIf="!isNewLayout" [defaultItem]="{ design: 'Select layout no..'}" [disabled]="prodBSdata===undefined"(valueChange)="LayoutDetails()">
</kendo-dropdownlist>
<input [(ngModel)]="layoutNo" type="text" style="width:95%" pInputText *ngIf="isNewLayout">
<input [(ngModel)]="layoutNo" type="text" style="width:100%" pInputText *ngIf="isNewLayout">
</div>
<div class="p-col-2" align="right">
<button icon="information" kendoButton [primary]="true" style="width:60%" *ngIf="selectedProdBSdata!==undefined"
(click)="LayoutDetails()" [disabled]="selectedProdBSdata===undefined">Details</button>
<div class="p-col-12 p-lg-2">
<!-- <button icon="information" kendoButton [primary]="true" style="width:60%" *ngIf="selectedProdBSdata!==undefined"
(click)="LayoutDetails()" [disabled]="selectedProdBSdata===undefined">Details</button> -->
</div>
<!-- <div class="p-col-3"></div> -->
<kendo-card class="p-col-12 p-md-12 p-lg-12" width="100%" *ngIf="isNewLayout || editDetails" for="disabled">
<!-- <div class="p-col-12 p-lg-3"></div> -->
<kendo-card class="p-col-12 p-lg-12 p-md-12 p-lg-12" width="100%" *ngIf="isNewLayout || editDetails" for="disabled">
<div class="p-grid">
<div class="p-col-1 label-ailgn">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>Program Name</label>
</div>
<div class="p-col-3">
<div class="p-col-12 p-lg-3">
<input [(ngModel)]="productionBonusSetup.programName" style="width:100%" type="text" pInputText>
</div>
<div class="p-col-1 label-ailgn" align="right">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>Max Persons</label>
</div>
<div class="p-col-3">
<div class="p-col-12 p-lg-3">
<kendo-numerictextbox [(ngModel)]="productionBonusSetup.maxPerson"
style="width:100%"></kendo-numerictextbox>
</div>
<div class="p-col-1 label-ailgn" align="right">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>Achieved %</label>
</div>
<div class="p-col-3">
<div class="p-col-12 p-lg-3">
<kendo-numerictextbox [(ngModel)]="productionBonusSetup.achivedPercent" [decimals]="2"
style="width:100%"></kendo-numerictextbox>
</div>
<div class="p-col-1 label-ailgn">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>Bonus Type</label>
</div>
<div class="p-col-2">
<div class="p-col-12 p-lg-2">
<kendo-dropdownlist [data]="bonusType" [(ngModel)]="selectedBonusType" [textField]="'label'"
[defaultItem]="{ label: 'Select Bonus Type...', value: null }" [valueField]="'value'" style="width:100%">
</kendo-dropdownlist>
</div>
<div class="p-col-1 label-ailgn" align="right">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>From Date</label>
</div>
<div class="p-col-2">
<div class="p-col-12 p-lg-2">
<kendo-datepicker [(ngModel)]="productionBonusSetup.fromDate" [format]="'dd MMMM yyyy'"
style="width:100%"></kendo-datepicker>
</div>
<div class="p-col-1 label-ailgn" align="right">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>To Date</label>
</div>
<div class="p-col-2">
<div class="p-col-12 p-lg-2">
<kendo-datepicker [(ngModel)]="productionBonusSetup.toDate" [format]="'dd MMMM yyyy'"
style="width:100%"></kendo-datepicker>
</div>
<div class="p-col-1 label-ailgn" align="right">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>Bonus Hours</label>
</div>
<div class="p-col-2">
<div class="p-col-12 p-lg-2">
<kendo-numerictextbox [(ngModel)]="productionBonusSetup.otHour" [decimals]="2"
style="width:100%"></kendo-numerictextbox>
</div>
@ -101,7 +101,7 @@
<kendo-grid [data]="productionBonusSetup.productionBonusLines" [pageable]="true" [sortable]="true"
[resizable]="true">
<ng-template kendoGridToolbarTemplate>
<button kendoButton icon="plus" [primary]="true" style="width: 10%; padding: 7px;"
<button kendoButton icon="plus" [primary]="true" style="width: fit-content"
(click)="onClickAddLine()">Add
Line</button>
<kendo-grid-spacer></kendo-grid-spacer>
@ -116,14 +116,14 @@
<ng-template kendoGridCellTemplate let-dataItem let-rowIndex="rowIndex">
<button kendoButton icon="gear" [primary]="true" (click)="onCellClickEdit(dataItem)"
style="width: 40%; margin-right: 5px;">Edit</button>
<button kendoButton icon="delete" [primary]="true" style="width: 40%;" (click)="onClickRemove(dataItem)">Remove</button>
<button type="button" kendoButton icon="delete" class="kt-delete" style="width: 40%;" (click)="onClickRemove(dataItem)">Remove</button>
</ng-template>
</kendo-grid-column>
</kendo-grid>
<div class="p-col-12" align="right">
<button kendoButton icon="save" [primary]="true" style="width: 10%; padding: 7px;" (click)="onClickSubmit()">Submit</button>
<div class="p-col-12 p-lg-12" align="right">
<button kendoButton icon="save" [primary]="true" style="width: fit-content" (click)="onClickSubmit()">Submit</button>
</div>
<div>
@ -134,49 +134,48 @@
</kendo-dialog-titlebar>
<kendo-dialog-content>
<app-hr-notification-list></app-hr-notification-list>
<div class="p-col-12 p-md-12">
<div class="p-col-12 p-lg-12 p-md-12">
<div class="p-grid">
<div class="p-col-1 label-ailgn">
<div class="p-col-12 p-lg-1 label-ailgn">
<label>Line Name</label>
</div>
<div class="p-col-5" *ngIf="isNewLine">
<div class="p-col-12 p-lg-5" *ngIf="isNewLine">
<app-dynamic-picker [dynamicPickerView]="_departmentPicker"></app-dynamic-picker>
</div>
<div class="p-col-5" *ngIf="!isNewLine">
<div class="p-col-12 p-lg-5" *ngIf="!isNewLine">
<input [(ngModel)]="selectedRow.lineName" [readonly]="!isNewLine" type="text"
style="width:100%" pInputText>
</div>
<div class="p-col-2">
<div class="p-col-12 p-lg-2">
</div>
<div class="p-col-2 label-ailgn">
<div class="p-col-12 p-lg-2 label-ailgn">
<label>Scheduled Hours</label>
</div>
<div class="p-col-2">
<kendo-numerictextbox [(ngModel)]="scheduledHours" [decimals]="2"
[readonly]="!isNewLine" style="width: 100%;"></kendo-numerictextbox>
<div class="p-col-12 p-lg-2">
<kendo-numerictextbox [(ngModel)]="selectedRow.scheduledHour" [decimals]="2" style="width: 100%;"(ngModelChange)="onScheduledHoursChange($event)"></kendo-numerictextbox>
</div>
</div>
<p-tabView>
<p-tabPanel header="Supervisor/Line Chief/Common Worker" leftIcon="pi pi-user">
<div class="p-grid">
<div class="p-col-3 label-ailgn">
<div class="p-col-12 p-lg-3 label-ailgn">
<label>Supervisor/Line Chief/Common Worker</label>
</div>
<div class="p-col-3">
<div class="p-col-12 p-lg-3">
<app-employee-picker (ItemSelected)="GetSelectedEmployee($event)"
[setSelectedEmp]="_pickerSelecteEmp"
[isActive]="empPickerActive"></app-employee-picker>
</div>
<div class="p-col-2 label-ailgn" align="right">
<div class="p-col-12 p-lg-2 label-ailgn" align="right">
<label>Bonus Percent</label>
</div>
<div class="p-col-2">
<div class="p-col-12 p-lg-2">
<kendo-numerictextbox [(ngModel)]="bonusPercent"
[decimals]="2"></kendo-numerictextbox>
</div>
<div class="p-col-2" align="right">
<div class="p-col-12 p-lg-2" align="right">
<button icon="plus" kendoButton [primary]="true" (click)="newLine()"
style="width:80%">Add</button>
</div>
@ -194,7 +193,7 @@
</kendo-grid-column>
<kendo-grid-column title="Actions" width="30%">
<ng-template kendoGridCellTemplate let-dataItem let-rowIndex="rowIndex">
<button kendoButton icon="delete" [primary]="true"
<button type="button" kendoButton icon="delete" class="kt-delete"
style="width: 40%;" (click)="onClickRemoveSupervisors(dataItem)">Remove</button>
</ng-template>
</kendo-grid-column>
@ -204,18 +203,30 @@
<kendo-grid [kendoGridBinding]="prodBonusLine.prodBonusWorkSchedules" [pageable]="true"
[sortable]="true" [reorderable]="true" [resizable]="true">
<kendo-grid-column field="startDateTime" title="Date" width="100%">
<kendo-grid-column field="startDateTime" title="Date" width="100">
<ng-template kendoGridCellTemplate let-dataItem let-rowIndex="rowIndex">
{{dataItem.startDateTime | date: 'dd MMMM yyyy'}}
</ng-template>
</kendo-grid-column>
<!-- <kendo-grid-column field="startDateTime" title="Start Time" width="100">
<ng-template kendoGridCellTemplate let-dataItem let-rowIndex="rowIndex">
{{dataItem.startDateTime | date: 'hh:mm a'}}
</ng-template>
</kendo-grid-column>
<kendo-grid-column field="endDateTime" title="End Time" width="100">
<ng-template kendoGridCellTemplate let-dataItem let-rowIndex="rowIndex">
{{dataItem.endDateTime | date: 'hh:mm a'}}
</ng-template>
</kendo-grid-column> -->
</kendo-grid>
</p-tabPanel>
</p-tabView>
</div>
</kendo-dialog-content>
<kendo-dialog-actions>
<div class="p-col-12" align="right">
<div class="p-col-12 p-lg-12" align="right">
<button kendoButton icon="save" (click)="onClickOk()" [primary]="true"
style="margin: 5px; width: 15%;">Ok</button>
<button kendoButton icon="close" (click)="close()" [primary]="true"

View File

@ -272,6 +272,8 @@ export class ProductionBonusSetupComponent implements OnInit {
debugger;
// this.onEdit = false;
this.isNewLine = true;
this.selectedRow = new ProdBonusLine();
this._departmentPicker = new DynamicPicker(EnumDynamicpickerType.Department, false);
this.prodBonusLine = new ProdBonusLine();
this.prodBonusWork = new ProdBonusWorkSchedule();
@ -369,7 +371,6 @@ export class ProductionBonusSetupComponent implements OnInit {
}
newLine() {
debugger;
if ((this._departmentPicker.selectedID === undefined || this._departmentPicker.selectedID === 0) &&
(this.prodBonusLine.lineName === '' || this.prodBonusLine.lineName === undefined)) {
this.notificationService.showWarning('Please Select a Line');
@ -389,6 +390,13 @@ export class ProductionBonusSetupComponent implements OnInit {
// this.notificationService.showWarning('Please Select Bonus Percentage');
// return;
// }
debugger;
this._employee;
this.prodBonusLine.prodBonusSupervisors;
if (this.scheduledHours < 0 || this.bonusPercent < 0) {
this.notificationService.showWarning('Scheduled Hours and Bonus Percentage can\'t be negative');
return;
@ -399,6 +407,10 @@ export class ProductionBonusSetupComponent implements OnInit {
var newlineParameter: ProdBonusParameter = new ProdBonusParameter();
// var newLayoutWork: ProdBonusWorkSchedule = new ProdBonusWorkSchedule();
const index = this.prodBonusLine.prodBonusSupervisors.findIndex(sv=> sv.employeeID == this._employee.id);
if (index !== -1) {
this.prodBonusLine.prodBonusSupervisors.splice(index, 1);
}
//Supervisor
newlineSupervisor.employeeID = this._employee.id;
newlineSupervisor.employeeNo = this._employee.employeeNo;
@ -406,8 +418,6 @@ export class ProductionBonusSetupComponent implements OnInit {
newlineSupervisor.bonusPercent = this.bonusPercent;
newlineSupervisor.prodBonusSetupID = this.productionBonusSetup.id;
if (this.isNewLine) {
newlineParameter.itemID = this._departmentPicker.selectedID;
newlineParameter.itemType = 0;
@ -464,7 +474,6 @@ export class ProductionBonusSetupComponent implements OnInit {
this.prodBonusLine.id = this.selectedRow.id;
this.prodBonusLine.lineName = this.selectedRow.lineName;
this.prodBonusLine.scheduledHour = this.selectedRow.scheduledHours;
this.prodBonusLine.prodBonusSupervisors.push(newlineSupervisor);
// this.prodBonusLine.prodBonusParameters.push(newlineParameter);
@ -487,6 +496,7 @@ export class ProductionBonusSetupComponent implements OnInit {
}
onClickOk() {
debugger;
if (this.isNewLine) {
this.productionBonusSetup.productionBonusLines.push(this.prodBonusLine); // for new
this.notificationService.showSuccess('New Line added');
@ -565,4 +575,10 @@ export class ProductionBonusSetupComponent implements OnInit {
this.editDetails = false;
this.prodBSdata = undefined;
}
onScheduledHoursChange(value: number){
debugger;
this.prodBonusLine.scheduledHour = value;
this.scheduledHours;
this.productionBonusSetup.productionBonusLines
}
}

View File

@ -230,6 +230,7 @@ export class ProductionBonusReportsComponent implements OnInit {
this.showDate = true;
this.showDesign = true;
this.salaryMonth = new Date();
this.Loadlayout(this.salaryMonth);
}
else {
this.showDate = false;