mirror of
https://github.com/dyiop/astute.git
synced 2025-04-05 21:10:16 -04:00
Fixed defects.
This commit is contained in:
parent
54bf16b42d
commit
d76671f0ca
|
@ -1,271 +1,273 @@
|
|||
<app-nav-bar [customerActive]="true"></app-nav-bar>
|
||||
<h1 align="center">Customers</h1>
|
||||
<div class="container-fluid">
|
||||
<div class="row">
|
||||
<div class="col-12">
|
||||
<ag-grid-angular
|
||||
#agGrid
|
||||
style="height: 500px;"
|
||||
class="ag-theme-balham"
|
||||
[enableSorting]="true"
|
||||
[enableFilter]="true"
|
||||
[rowData]="rowData | async"
|
||||
[columnDefs]="columnDefs"
|
||||
rowSelection="single"
|
||||
></ag-grid-angular>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row justify-content-center mt-2">
|
||||
<div class="col-6">
|
||||
<button class="btn btn-primary" style="width: 100%" (click)="open(edit)">Edit Customer</button>
|
||||
</div>
|
||||
<div class="col-6">
|
||||
<button class="btn btn-success" style="width: 100%" (click)="open(new)">Add Customer</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!--MODAL: new customer-->
|
||||
<app-modal-form [title]="'New Customer'" #new>
|
||||
<div class="modal-body">
|
||||
<table class="table table-borderless table-sm">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">ID*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="johndoe" #inId>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Name*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="John Doe" #inName>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Bill To Dept*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="Billing" #inBillToDept>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Address 1*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="13254 John Doe Rd." #inAdd1>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Address 2</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="Apt #, Unit, etc..." [value]="''" #inAdd2>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">City*</span>
|
||||
</td>
|
||||
<td>
|
||||
<input type="text" class="form-control" placeholder="New York City" #inCity>
|
||||
</td>
|
||||
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">State*</span>
|
||||
</td>
|
||||
<td>
|
||||
<select class="custom-select" #inState>
|
||||
<option selected>Choose...</option>
|
||||
<option *ngFor="let state of states" [value]="state">{{state}}</option>
|
||||
</select>
|
||||
</td>
|
||||
|
||||
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">ZIP*(+4)</span>
|
||||
</td>
|
||||
<td style="width: 25%">
|
||||
<div class="input-group">
|
||||
<input type="number" class="form-control" placeholder="12345" #inZIP>
|
||||
<input type="number" class="form-control" placeholder="(+4)" #inZIP4>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Email*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="email" class="form-control" placeholder="john@doe.com" #inEmail>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Phone*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="tel" class="form-control" placeholder="(123) 456-7890" [textMask]="{mask: usPhoneMask, guide: false}" #inPhone>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Fax*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="tel" class="form-control" placeholder="(123) 456-7890" [value]="''" [textMask]="{mask: usPhoneMask, guide: false}" #inFax>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!(inId.value && inName.value && inBillToDept.value && inAdd1.value && inCity.value && inState.value && inZIP.value && inEmail.value && inPhone.value && inFax.value)"
|
||||
(click)="addCustomer(inId.value, inName.value, inBillToDept.value, inAdd1.value, inAdd2.value, inCity.value, inState.value, inZIP.value, inZIP4.value, inEmail.value, inPhone.value, inFax.value, new)">
|
||||
+
|
||||
</button>
|
||||
<button type="button" class="btn btn-danger" (click)="close(new)">Cancel</button>
|
||||
</div>
|
||||
</app-modal-form>
|
||||
|
||||
<!--MODAL: edit customer-->
|
||||
<app-modal-form [title]="'Editing'" #edit>
|
||||
<div *ngIf="selected">
|
||||
<div class="modal-body">
|
||||
<table class="table table-borderless table-sm">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Name*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" #inName placeholder="John Doe" [value]="selected.customerName">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Bill To Dept*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="Billing" #inBillToDept [value]="selected.billToDept">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Address 1*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="13254 John Doe Rd." #inAdd1 [value]="selected.add1">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Address 2</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="Apt#, Unit, etc." #inAdd2 [value]="selected.add2">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">City*</span>
|
||||
</td>
|
||||
<td>
|
||||
<input type="text" class="form-control" placeholder="New York City" #inCity [value]="selected.city">
|
||||
</td>
|
||||
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">State*</span>
|
||||
</td>
|
||||
<td>
|
||||
<select class="custom-select" #inState [value]="selected.state">
|
||||
<option selected>Choose...</option>
|
||||
<option *ngFor="let state of states" [value]="state">{{state}}</option>
|
||||
</select>
|
||||
</td>
|
||||
|
||||
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">ZIP*(+4)</span>
|
||||
</td>
|
||||
<td style="width: 25%">
|
||||
<div class="input-group">
|
||||
<input type="number" class="form-control" placeholder="12345" #inZIP [value]="selected.zip">
|
||||
<input type="number" class="form-control" placeholder="(+4)" #inZIP4 [value]="selected.ziplast4">
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Email*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="email" class="form-control" placeholder="john@doe.com" #inEmail [value]="selected.email">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Phone*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="tel" class="form-control" placeholder="(123) 456-7890" [textMask]="{mask: usPhoneMask, guide: false}" #inPhone [value]="selected.phone">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Fax</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="tel" class="form-control" placeholder="(123) 456-7890" [textMask]="{mask: usPhoneMask, guide: false}" #inFax [value]="selected.fax">
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-warning" type="button"
|
||||
[disabled]="!(inName.value && inBillToDept.value && inAdd1.value && inCity.value && inState.value && inZIP.value && inEmail.value && inPhone.value)"
|
||||
(click)="editCustomer(selected.customerId ,inName.value, inBillToDept.value, inAdd1.value, inAdd2.value, inCity.value, inState.value, inZIP.value, inZIP4.value, inEmail.value, inPhone.value, inFax.value, edit)">
|
||||
Update
|
||||
</button>
|
||||
<button type="button" class="btn btn-danger" (click)="close(edit)">Cancel</button>
|
||||
</div>
|
||||
</div>
|
||||
<div *ngIf="!selected">
|
||||
<div class="modal-body">
|
||||
Choose a Customer First!
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-warning" type="button"
|
||||
[disabled]="true">
|
||||
Update
|
||||
</button>
|
||||
<button type="button" class="btn btn-danger" (click)="close(edit)">Cancel</button>
|
||||
</div>
|
||||
</div>
|
||||
</app-modal-form>
|
||||
<app-nav-bar [customerActive]="true"></app-nav-bar>
|
||||
<h1 align="center">Customers</h1>
|
||||
|
||||
<div class="container-fluid">
|
||||
<div class="row">
|
||||
<div class="col-12">
|
||||
<ag-grid-angular
|
||||
#agGrid
|
||||
style="height: 500px;"
|
||||
class="ag-theme-balham"
|
||||
[enableSorting]="true"
|
||||
[enableFilter]="true"
|
||||
[rowData]="rowData | async"
|
||||
[columnDefs]="columnDefs"
|
||||
rowSelection="single"
|
||||
rowDeselection="true"
|
||||
></ag-grid-angular>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row justify-content-center mt-2">
|
||||
<div class="col-6">
|
||||
<button class="btn btn-primary" style="width: 100%" (click)="open(edit)">Edit Customer</button>
|
||||
</div>
|
||||
<div class="col-6">
|
||||
<button class="btn btn-success" style="width: 100%" (click)="open(new)">Add Customer</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!--MODAL: new customer-->
|
||||
<app-modal-form [title]="'New Customer'" #new>
|
||||
<div class="modal-body">
|
||||
<table class="table table-borderless table-sm">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">ID*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="johndoe" #inId>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Name*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="John Doe" #inName>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Bill To Dept*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="Billing" #inBillToDept>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Address 1*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="13254 John Doe Rd." #inAdd1>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Address 2</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="Apt #, Unit, etc..." [value]="''" #inAdd2>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">City*</span>
|
||||
</td>
|
||||
<td>
|
||||
<input type="text" class="form-control" placeholder="New York City" #inCity>
|
||||
</td>
|
||||
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">State*</span>
|
||||
</td>
|
||||
<td>
|
||||
<select class="custom-select" #inState>
|
||||
<option selected>Choose...</option>
|
||||
<option *ngFor="let state of states" [value]="state">{{state}}</option>
|
||||
</select>
|
||||
</td>
|
||||
|
||||
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">ZIP*(+4)</span>
|
||||
</td>
|
||||
<td style="width: 25%">
|
||||
<div class="input-group">
|
||||
<input type="number" class="form-control" placeholder="12345" #inZIP>
|
||||
<input type="number" class="form-control" placeholder="(+4)" #inZIP4>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Email*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="email" class="form-control" placeholder="john@doe.com" #inEmail>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Phone*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="tel" class="form-control" placeholder="(123) 456-7890" [textMask]="{mask: usPhoneMask, guide: false}" #inPhone>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Fax*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="tel" class="form-control" placeholder="(123) 456-7890" [value]="''" [textMask]="{mask: usPhoneMask, guide: false}" #inFax>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!(inId.value && inName.value && inBillToDept.value && inAdd1.value && inCity.value && inState.value && inZIP.value && inEmail.value && inPhone.value && inFax.value)"
|
||||
(click)="addCustomer(inId.value, inName.value, inBillToDept.value, inAdd1.value, inAdd2.value, inCity.value, inState.value, inZIP.value, inZIP4.value, inEmail.value, inPhone.value, inFax.value, new)">
|
||||
Add
|
||||
</button>
|
||||
<button type="button" class="btn btn-danger" (click)="close(new)">Cancel</button>
|
||||
</div>
|
||||
</app-modal-form>
|
||||
|
||||
<!--MODAL: edit customer-->
|
||||
<app-modal-form [title]="'Editing'" #edit>
|
||||
<div *ngIf="selected">
|
||||
<div class="modal-body">
|
||||
<table class="table table-borderless table-sm">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Name*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" #inName placeholder="John Doe" [value]="selected.customerName">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Bill To Dept*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="Billing" #inBillToDept [value]="selected.billToDept">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Address 1*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="13254 John Doe Rd." #inAdd1 [value]="selected.add1">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Address 2</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="Apt#, Unit, etc." #inAdd2 [value]="selected.add2">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">City*</span>
|
||||
</td>
|
||||
<td>
|
||||
<input type="text" class="form-control" placeholder="New York City" #inCity [value]="selected.city">
|
||||
</td>
|
||||
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">State*</span>
|
||||
</td>
|
||||
<td>
|
||||
<select class="custom-select" #inState [value]="selected.state">
|
||||
<option selected>Choose...</option>
|
||||
<option *ngFor="let state of states" [value]="state">{{state}}</option>
|
||||
</select>
|
||||
</td>
|
||||
|
||||
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">ZIP*(+4)</span>
|
||||
</td>
|
||||
<td style="width: 25%">
|
||||
<div class="input-group">
|
||||
<input type="number" class="form-control" placeholder="12345" #inZIP [value]="selected.zip">
|
||||
<input type="number" class="form-control" placeholder="(+4)" #inZIP4 [value]="selected.ziplast4">
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Email*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="email" class="form-control" placeholder="john@doe.com" #inEmail [value]="selected.email">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Phone*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="tel" class="form-control" placeholder="(123) 456-7890" [textMask]="{mask: usPhoneMask, guide: false}" #inPhone [value]="selected.phone">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 1%">
|
||||
<span class="input-group-text">Fax</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="tel" class="form-control" placeholder="(123) 456-7890" [textMask]="{mask: usPhoneMask, guide: false}" #inFax [value]="selected.fax">
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-warning" type="button"
|
||||
[disabled]="!(inName.value && inBillToDept.value && inAdd1.value && inCity.value && inState.value && inZIP.value && inEmail.value && inPhone.value)"
|
||||
(click)="editCustomer(selected.customerId ,inName.value, inBillToDept.value, inAdd1.value, inAdd2.value, inCity.value, inState.value, inZIP.value, inZIP4.value, inEmail.value, inPhone.value, inFax.value, edit)">
|
||||
Update
|
||||
</button>
|
||||
<button type="button" class="btn btn-danger" (click)="close(edit)">Cancel</button>
|
||||
</div>
|
||||
</div>
|
||||
<div *ngIf="!selected">
|
||||
<div class="modal-body">
|
||||
Choose a Customer First!
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-warning" type="button"
|
||||
[disabled]="true">
|
||||
Update
|
||||
</button>
|
||||
<button type="button" class="btn btn-danger" (click)="close(edit)">Cancel</button>
|
||||
</div>
|
||||
</div>
|
||||
</app-modal-form>
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
/* Empty file */
|
|
@ -50,8 +50,8 @@
|
|||
<td style="width: 10%">
|
||||
<span class="input-group-text">Payment Received*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" placeholder="$00.00" #inPaymentReceived>
|
||||
<td class="p-0 m-0" colspan="7">
|
||||
<input type="text" class="form-control cell" [value]="0 | currency" #inPaymentReceived>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
|
@ -78,6 +78,15 @@
|
|||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Check# / ACH transaction#*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" #incheckTransactionNo>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
@ -85,8 +94,9 @@
|
|||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!(chosenInv && inPaymentReceived.value && chosenPaymentType && inDateReceived.value)"
|
||||
(click)="addInvoicePayment(chosenInv, null, chosenPaymentType, null, inDateReceived.value, inPaymentReceived.value, new)">
|
||||
+
|
||||
(click)="addInvoicePayment(chosenInv, null, chosenPaymentType, inDateReceived.value, inPaymentReceived.value.replace('$', '').replace(',', ''), incheckTransactionNo.value,new)">
|
||||
<!--(click)="addInvoicePayment(chosenInv, null, chosenPaymentType, null, inDateReceived.value, inPaymentReceived.value, new)">-->
|
||||
Add
|
||||
</button>
|
||||
<!--<input type="reset" (click)="close(new)">Cancel-->
|
||||
<button type="reset" class="btn btn-danger" (click)="close(new)">Cancel</button>
|
||||
|
@ -118,6 +128,21 @@
|
|||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Payment Type*</span>
|
||||
</td>
|
||||
<td>
|
||||
<input type="text" class="form-control" #paymentTypeSelect [value]="paymentTypes[selected.paymentTypeId-1].paymentTypeName">
|
||||
<!--<select class="custom-select" [value]={{paymentTypes[selected.paymentTypeId-1].paymentTypeName}} (change)="paymentTypeDropdownChange(paymentTypeSelect.value)"-->
|
||||
<!--#paymentTypeSelect>-->
|
||||
|
||||
<!--<option *ngFor="let paymentType of paymentTypes; let i = index;" [value]="i">{{paymentType.paymentTypeName}}-->
|
||||
<!--<!–{{paymentTypes[selected.paymentTypeId-1].paymentTypeName}}}–>-->
|
||||
<!--</option>-->
|
||||
<!--</select>-->
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Date Received*</span>
|
||||
|
@ -126,13 +151,23 @@
|
|||
<input type="date" class="form-control" #inDateReceived [value]="selected.paymentDate">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td style="width: 10%">
|
||||
<span class="input-group-text">Check# / ACH transaction#*</span>
|
||||
</td>
|
||||
<td colspan="7">
|
||||
<input type="text" class="form-control" #incheckTransactionNo [value]="selected.checkTransactionNo">
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-warning" type="button"
|
||||
[disabled]="!(invoiceSelect.value && inPaymentReceived.value && inDateReceived.value)"
|
||||
(click)="updateInvoicePayment(invoiceSelect.value, selected.invoicePaymentId, selected.paymentTypeId, selected.paymentType, inDateReceived.value, inPaymentReceived.value, edit)">
|
||||
[disabled]="!(invoiceSelect.value && inPaymentReceived.value && inDateReceived.value && incheckTransactionNo)"
|
||||
(click)="updateInvoicePayment(invoiceSelect.value, selected.invoicePaymentId, selected.paymentTypeId, inDateReceived.value, inPaymentReceived.value.substr(1).replace(',', ''), incheckTransactionNo.value, edit)">
|
||||
Update
|
||||
</button>
|
||||
<button type="button" class="btn btn-danger" (click)="close(edit)">Cancel</button>
|
||||
|
|
|
@ -21,7 +21,9 @@ export class InvoicePaymentComponent implements OnInit {
|
|||
{headerName: 'Invoice Number', field: 'invoiceNum'},
|
||||
{headerName: 'Payment Received', field: 'invoiceAmount'},
|
||||
{headerName: 'Date Received', field: 'paymentDate'},
|
||||
{headerName: 'Payment Type', field: 'paymentType'}
|
||||
{headerName: 'Payment Type', field: 'paymentType'},
|
||||
{headerName: 'Check / ACH Transaction #', field: 'checkTransactionNo'}
|
||||
|
||||
|
||||
];
|
||||
constructor(protected astuteClientService: AstuteClientService) {
|
||||
|
@ -48,14 +50,14 @@ export class InvoicePaymentComponent implements OnInit {
|
|||
}
|
||||
}
|
||||
|
||||
addInvoicePayment(invoiceNum, invoicePaymentId, paymentTypeId, paymentType, paymentDate, paymentReceived, ref) {
|
||||
addInvoicePayment(invoiceNum, invoicePaymentId, paymentTypeId, paymentDate, paymentReceived, checkTransactionNo, ref) {
|
||||
let invoicePaymentData = {
|
||||
"invoiceNum": invoiceNum,
|
||||
"invoicePaymentId":invoicePaymentId,
|
||||
"paymentTypeId":paymentTypeId,
|
||||
"paymentType": paymentType,
|
||||
"paymentDate": paymentDate,
|
||||
"invoiceAmount": paymentReceived
|
||||
"invoiceAmount": paymentReceived,
|
||||
"checkTransactionNo": checkTransactionNo
|
||||
};
|
||||
this.astuteClientService.addInvoicePayment(invoicePaymentData).then((data) => {
|
||||
if (data) {
|
||||
|
@ -69,14 +71,14 @@ export class InvoicePaymentComponent implements OnInit {
|
|||
});
|
||||
}
|
||||
|
||||
updateInvoicePayment(invoiceNum, invoicePaymentId, paymentTypeId, paymentType, dateReceived, paymentReceived, ref) {
|
||||
updateInvoicePayment(invoiceNum, invoicePaymentId, paymentTypeId, dateReceived, paymentReceived, checkTransactionNo, ref) {
|
||||
const invoicePaymentData = {
|
||||
"invoiceNum": invoiceNum,
|
||||
"invoicePaymentId": invoicePaymentId,
|
||||
"paymentTypeId": paymentTypeId,
|
||||
"paymentType": paymentType,
|
||||
"paymentDate": dateReceived,
|
||||
"invoiceAmount": paymentReceived
|
||||
"invoiceAmount": paymentReceived,
|
||||
"checkTransactionNo": checkTransactionNo
|
||||
};
|
||||
|
||||
this.astuteClientService.updateInvoicePayment(invoiceNum, invoicePaymentId, invoicePaymentData).then((data) => {
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,490 +1,492 @@
|
|||
import {Component, OnInit, ViewChild} from '@angular/core';
|
||||
import {AstuteClientService} from '../services/astute-client-service';
|
||||
import {formatCurrency} from "@angular/common";
|
||||
|
||||
declare var $: any;
|
||||
|
||||
@Component({
|
||||
selector: 'app-invoice',
|
||||
templateUrl: './invoice.component.html',
|
||||
styleUrls: ['./invoice.component.css']
|
||||
})
|
||||
export class InvoiceComponent implements OnInit {
|
||||
@ViewChild('agGrid') agGrid;
|
||||
chosenCustomerID: any = 0;
|
||||
chosenInv: any = 0;
|
||||
source;
|
||||
customers;
|
||||
pos = [];
|
||||
chosenPo;
|
||||
correspondingPos = [];
|
||||
generatedInvoiceNumber = '';
|
||||
feeTypes = ['Fixed Fee', 'Hourly'];
|
||||
serviceTypes = ['Study', 'Design', 'Peer Review', 'Cost Investigation', 'Forensic Investigation'];
|
||||
columnDefs = [
|
||||
{headerName: 'Invoice Number', field: 'invoiceNumber'},
|
||||
{headerName: 'Date', field: 'invoiceDate'},
|
||||
{headerName: 'Sales Order Number', field: 'poNum'},
|
||||
{headerName: 'Change Order Number', field: 'changeOrderNum'},
|
||||
{headerName: 'Paid', field: 'pmtStatus'},
|
||||
{headerName: 'Bll Amount', field: 'billAmt'}
|
||||
];
|
||||
newInDetails = [];
|
||||
newBillAmt = 0;
|
||||
selectedInDetails = [];
|
||||
selectedPO;
|
||||
selectedBillAmt = 0;
|
||||
poDetails = [];
|
||||
selectedPODetails = [];
|
||||
|
||||
gridOptions = {
|
||||
|
||||
// PROPERTIES - object properties, myRowData and myColDefs are created somewhere in your application
|
||||
rowData: this.source,
|
||||
columnDefs: this.columnDefs,
|
||||
|
||||
// PROPERTIES - simple boolean / string / number properties
|
||||
enableColResize: true,
|
||||
rowSelection: 'single',
|
||||
|
||||
// EVENTS - add event callback handlers
|
||||
onRowClicked: (event) => {
|
||||
this.getSelectedRows();
|
||||
},
|
||||
onColumnResized: function (event) {
|
||||
console.log('a column was resized');
|
||||
},
|
||||
onGridReady: (event) => {
|
||||
},
|
||||
// this.agGrid.sizeColumnsToFit();
|
||||
// 1: draft
|
||||
// 2: submitted
|
||||
// 3: void
|
||||
|
||||
// getRowStyle: function(params) {
|
||||
// if (params.data.invoiceStatus === 1) {
|
||||
// return { 'color': 'red' }
|
||||
// } else if (params.data.invoiceStatus === 3) {
|
||||
// return { 'text-decoration': 'line-through'}
|
||||
// }
|
||||
// }
|
||||
|
||||
rowClassRules: {
|
||||
// apply green to 2008
|
||||
// 'bg-red': true,
|
||||
|
||||
// apply amber 2004
|
||||
'text-danger': function (params) {
|
||||
return params.data.invoiceStatus === 1;
|
||||
},
|
||||
'text-primary': function (params) {
|
||||
return params.data.invoiceStatus === 2;
|
||||
},
|
||||
'text-warning': function (params) {
|
||||
return params.data.invoiceStatus === 3;
|
||||
},
|
||||
|
||||
// apply red to 2000
|
||||
// 'rag-red-outer': function(params) { return params.data.year === 2000}
|
||||
}
|
||||
}
|
||||
|
||||
constructor(protected astuteClientService: AstuteClientService) {
|
||||
}
|
||||
|
||||
customerDropdownChange(index) {
|
||||
this.chosenCustomerID = this.customers[index].customerId;
|
||||
this.setCorrespondingPos();
|
||||
}
|
||||
|
||||
poDropdownChange(ponum) {
|
||||
this.pos.forEach((po) => {
|
||||
if (po.ponum === ponum) {
|
||||
this.chosenPo = po;
|
||||
}
|
||||
})
|
||||
this.astuteClientService.getPODetail(ponum).then((data) => {
|
||||
if (data) {
|
||||
// fee
|
||||
// feeTypeId
|
||||
// lineItemNo
|
||||
// ponum
|
||||
// qty
|
||||
// remainingQty
|
||||
// serviceDesc
|
||||
// serviceTypeId
|
||||
|
||||
// lineItemNo, feeTypeId, serviceTypeId, serviceDesc, fee, remainingQty
|
||||
this.poDetails = data;
|
||||
this.poDetails[-1] = {
|
||||
'lineItemNo': -1,
|
||||
'feeTypeId': 1,
|
||||
'serviceTypeId': 1,
|
||||
'serviceDesc': 'Out of Pocket Expenses',
|
||||
'fee': 0,
|
||||
'remainingQty': 0
|
||||
};
|
||||
} else {
|
||||
alert("get PO detail failed!");
|
||||
}
|
||||
});
|
||||
this.astuteClientService.generateInvoiceNumber(ponum).then((data) => {
|
||||
if (data) {
|
||||
this.generatedInvoiceNumber = data;
|
||||
} else {
|
||||
alert('gen inv num failed!');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
ngOnInit() {
|
||||
this.refreshData();
|
||||
}
|
||||
|
||||
refreshData() {
|
||||
this.astuteClientService.getInvoices().then((data) => {
|
||||
this.source = data;
|
||||
this.source.forEach((row) => {
|
||||
row.billAmt = formatCurrency(row.billAmt, 'en-US', '$', 'USD');
|
||||
});
|
||||
});
|
||||
|
||||
this.astuteClientService.getCustomers().then((data) => {
|
||||
this.customers = data;
|
||||
});
|
||||
|
||||
this.astuteClientService.getPOs().then((data) => {
|
||||
this.pos = data;
|
||||
});
|
||||
}
|
||||
|
||||
getPODetails(poIndex) {
|
||||
let ponum = this.pos[poIndex].ponum;
|
||||
this.astuteClientService.getPODetail(ponum).then((data) => {
|
||||
this.selectedInDetails = data;
|
||||
console.log("inDetails:");
|
||||
console.log(this.selectedInDetails);
|
||||
});
|
||||
}
|
||||
|
||||
onSelectedCellChange(row: number, col: string, value) {
|
||||
this.selectedInDetails[row][col] = value;
|
||||
console.log(this.selectedInDetails);
|
||||
}
|
||||
|
||||
onNewCellChange(row: number, col: string, value) {
|
||||
this.newInDetails[row][col] = value;
|
||||
console.log(this.newInDetails);
|
||||
}
|
||||
|
||||
pushOntoSelectedDetail(invoiceNum, lineItemNum, poLineItemNum, serviceTypeId, desc, qty, fee) {
|
||||
this.selectedInDetails.push({
|
||||
'invoiceNum': invoiceNum,
|
||||
'lineItemNum': lineItemNum,
|
||||
'poLineItemNum': poLineItemNum,
|
||||
'serviceTypeId': serviceTypeId,
|
||||
'desc': desc,
|
||||
'qty': +qty,
|
||||
'fee': +fee
|
||||
});
|
||||
}
|
||||
|
||||
pushOntoNewDetail(invoiceNum, lineItemNum, poLineItemNum, feeTypeId, serviceTypeId, desc, qty, fee, remainingQty, poNum) {
|
||||
this.newInDetails.push({
|
||||
'invoiceNum': invoiceNum,
|
||||
'lineItemNum': lineItemNum,
|
||||
'poLineItemNum': poLineItemNum,
|
||||
'feeTypeId': feeTypeId,
|
||||
'serviceTypeId': serviceTypeId,
|
||||
'desc': desc,
|
||||
'qty': +qty,
|
||||
'fee': +fee,
|
||||
'remainingQty': +remainingQty,
|
||||
'poNum': poNum
|
||||
});
|
||||
console.log(this.newInDetails);
|
||||
}
|
||||
|
||||
updateNewBillAmt() {
|
||||
let tot = 0;
|
||||
this.newInDetails.forEach((d) => {
|
||||
tot += +d.qty * +d.fee;
|
||||
});
|
||||
this.newBillAmt = tot;
|
||||
}
|
||||
|
||||
updateSelectedBillAmt() {
|
||||
let tot = 0;
|
||||
this.selectedInDetails.forEach((d) => {
|
||||
tot += +d.qty * +d.fee;
|
||||
});
|
||||
this.selectedBillAmt = tot;
|
||||
}
|
||||
|
||||
assignActity(): void {
|
||||
window.open('/invoice-gen');
|
||||
}
|
||||
|
||||
getSelectedRows() {
|
||||
const selectedNodes = this.agGrid.api.getSelectedNodes();
|
||||
if (selectedNodes.length) {
|
||||
this.chosenInv = selectedNodes.map(node => node.data)[0];
|
||||
// console.log (this.chosenInv);
|
||||
this.selectedBillAmt = +(this.chosenInv.billAmt.replace(',', '').replace('$', ''));
|
||||
this.astuteClientService.getPODetail(this.chosenInv.poNum).then((poDetails) => {
|
||||
if (poDetails) {
|
||||
this.selectedPODetails = poDetails;
|
||||
this.astuteClientService.getInvoiceDetail(this.chosenInv.invoiceNumber).then((invoiceDetails) => {
|
||||
if (invoiceDetails) {
|
||||
this.selectedInDetails = invoiceDetails;
|
||||
this.selectedInDetails.forEach((invDetail) => {
|
||||
const tempPo = this.selectedPODetails.filter((po) => {
|
||||
// console.log (po.lineItemNo + " and " + invDetail.poLineItemNum);
|
||||
return po.lineItemNo === invDetail.poLineItemNum;
|
||||
})[0];
|
||||
if (tempPo) {
|
||||
invDetail.remainingQty = tempPo.remainingQty;
|
||||
}
|
||||
});
|
||||
} else {
|
||||
alert("get Inv detail failed!");
|
||||
}
|
||||
});
|
||||
} else {
|
||||
alert("get PO detail failed!")
|
||||
}
|
||||
});
|
||||
this.pos.forEach((po) => {
|
||||
if (po.ponum === this.chosenInv.poNum) {
|
||||
this.selectedPO = po;
|
||||
}
|
||||
});
|
||||
} else {
|
||||
this.chosenInv = null;
|
||||
this.selectedPODetails = [];
|
||||
}
|
||||
}
|
||||
|
||||
open(content, indexPO, indexINV) {
|
||||
content.open();
|
||||
// this.detailDescription = ViewChild('detailDescription');
|
||||
// this.detailAmount = ViewChild('detailAmount');
|
||||
// this.detailRate = ViewChild('detailRate');
|
||||
// this.detailTotal = ViewChild('detailTotal');
|
||||
// if (indexINV) {
|
||||
// this.chosenInv = indexINV;
|
||||
// }
|
||||
// if (indexPO) {
|
||||
// this.chosenPo = indexPO;
|
||||
// this.getPODetails(this.chosenPo);
|
||||
// }
|
||||
// this.modalService.open(content, { size: 'lg' }).result.then((result) => {
|
||||
// this.closeResult = `Closed with: ${result}`;
|
||||
// }, (reason) => {
|
||||
// this.closeResult = `Dismissed ${this.getDismissReason(reason)}`;
|
||||
// });
|
||||
}
|
||||
|
||||
close(content) {
|
||||
content.close();
|
||||
// this.newInDetails = [];
|
||||
}
|
||||
|
||||
getCurrDate() {
|
||||
let d = new Date(),
|
||||
month = '' + (d.getMonth() + 1),
|
||||
day = '' + d.getDate(),
|
||||
year = d.getFullYear();
|
||||
|
||||
if (month.length < 2) month = '0' + month;
|
||||
if (day.length < 2) day = '0' + day;
|
||||
|
||||
|
||||
return [year, month, day].join('-');
|
||||
}
|
||||
|
||||
formatDate(d: Date) {
|
||||
let month = '' + (d.getMonth() + 1),
|
||||
day = '' + d.getDate(),
|
||||
year = d.getFullYear();
|
||||
|
||||
if (month.length < 2) {
|
||||
month = '0' + month;
|
||||
}
|
||||
if (day.length < 2) {
|
||||
day = '0' + day;
|
||||
}
|
||||
return [year, month, day].join('-');
|
||||
}
|
||||
|
||||
deleteInvoice (invoiceNum) {
|
||||
if (confirm('Are you sure you want to delete invoice, ' + invoiceNum)) {
|
||||
this.astuteClientService.deleteInvoice(invoiceNum).then((data) => {
|
||||
if (data) {
|
||||
console.log('Invoice, ' + invoiceNum + ' successfully deleted');
|
||||
this.refreshData();
|
||||
} else {
|
||||
alert ('Error in deleting; Invoice, ' + invoiceNum + ' has not been deleted');
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
addInvoice(invoiceNumber, poNum, changeOrderNum, pmtStatus, billAmt, specialNotes, certification, status, ref) {
|
||||
// String invoiceNumber;
|
||||
// Date invoiceDate;
|
||||
// String poNum;
|
||||
// String changeOrderNum;
|
||||
// int pmtStatus;
|
||||
// Double billAmt;
|
||||
// String specialNotes;
|
||||
// String certification;
|
||||
// Date pmtReceivedDate;
|
||||
const invData = {
|
||||
"invoiceNumber": invoiceNumber,
|
||||
"invoiceDate": this.formatDate(new Date()),
|
||||
"poNum": poNum,
|
||||
"changeOrderNum": changeOrderNum,
|
||||
"pmtStatus": +pmtStatus,
|
||||
"billAmt": +billAmt,
|
||||
"specialNotes": specialNotes,
|
||||
"certification": certification,
|
||||
"pmtReceivedDate": this.formatDate(new Date()),
|
||||
'invoiceStatus': status
|
||||
};
|
||||
console.log(invData);
|
||||
|
||||
this.astuteClientService.createInvoice(invData)
|
||||
.catch((response) => {
|
||||
console.log("rejected: " + response);
|
||||
})
|
||||
.then((data) => {
|
||||
if (data) {
|
||||
this.refreshData();
|
||||
this.addInvoiceDetail(this.newInDetails);
|
||||
ref.close();
|
||||
} else {
|
||||
alert('Invoice Creation Failed, Check Input Fields');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
addInvoiceDetail(details) {
|
||||
if (details.length) {
|
||||
// console.log(details[0]);
|
||||
// if (details[0].poLineItemNum !== -1) {
|
||||
this.astuteClientService.createInvoiceDetail(details[0]).then((data) => {
|
||||
if (data) {
|
||||
details.splice(0, 1);
|
||||
this.addInvoiceDetail(details);
|
||||
} else {
|
||||
alert('add inv detail failed');
|
||||
}
|
||||
});
|
||||
// } else {
|
||||
// desc
|
||||
// fee
|
||||
// feeTypeId
|
||||
// invoiceNum
|
||||
// lineItemNum
|
||||
// poLineItemNum
|
||||
// qty
|
||||
// remainingQty
|
||||
// serviceTypeId
|
||||
// poNum
|
||||
|
||||
// const data = {
|
||||
// // 'lineItemNo': details[0].,
|
||||
// 'poNum': details[0].poNum,
|
||||
// 'serviceDesc': details[0].desc,
|
||||
// 'feeTypeId': details[0].feeTypeId,
|
||||
// 'serviceTypeId': details[0].serviceTypeId,
|
||||
// 'qty': +details[0].qty,
|
||||
// 'fee': +details[0].fee,
|
||||
// 'remainingQty': +details[0].fee * +details[0].qty
|
||||
// };
|
||||
// this.astuteClientService.createPODetail(data).then((d) => {
|
||||
// if (d) {
|
||||
// console.log (d);
|
||||
// } else {
|
||||
// alert('create custom PO failed.');
|
||||
// }
|
||||
// });
|
||||
// }
|
||||
} else {
|
||||
this.newInDetails = [];
|
||||
}
|
||||
}
|
||||
|
||||
editInvoice(invoiceNumber, poNum, changeOrderNum, pmtStatus, billAmt, specialNotes, certification) {
|
||||
// String invoiceNumber;
|
||||
// Date invoiceDate;
|
||||
// String poNum;
|
||||
// String changeOrderNum;
|
||||
// int pmtStatus;
|
||||
// Double billAmt;
|
||||
// String specialNotes;
|
||||
// String certification;
|
||||
// Date pmtReceivedDate;
|
||||
const invData = {
|
||||
"invoiceNumber": invoiceNumber,
|
||||
"invoiceDate": new Date(),
|
||||
"poNum": poNum,
|
||||
"changeOrderNum": changeOrderNum,
|
||||
"pmtStatus": +pmtStatus,
|
||||
"billAmt": +billAmt,
|
||||
"specialNotes": specialNotes,
|
||||
"certification": certification,
|
||||
"pmtReceivedDate": new Date()
|
||||
};
|
||||
|
||||
this.astuteClientService.updateInvoice(invoiceNumber, invData)
|
||||
.catch((response) => {
|
||||
console.log("rejected: " + response);
|
||||
})
|
||||
.then((data) => {
|
||||
if (data) {
|
||||
alert("invoice " + invoiceNumber + " updated!");
|
||||
console.log("fulfilled: " + data);
|
||||
// this.source[this.chosenInv] = invData;
|
||||
this.refreshData();
|
||||
} else {
|
||||
alert("Invoice Update Failed, Check Input Fields")
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
voidInvoice(invoiceNumber) {
|
||||
this.astuteClientService.voidInvoice(invoiceNumber).then((data) => {
|
||||
if (data) {
|
||||
this.refreshData();
|
||||
} else {
|
||||
alert('void invoice failed.');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
submitInvoice(invoiceNumber) {
|
||||
this.astuteClientService.submitInvoice(invoiceNumber).then((data) => {
|
||||
if (data) {
|
||||
this.refreshData();
|
||||
} else {
|
||||
alert('submit invoice failed.');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
getPerc(amt, total): number {
|
||||
return Math.floor(((amt) / total) * 100);
|
||||
}
|
||||
|
||||
getRangeMax(total, num) {
|
||||
return Math.floor(total / num);
|
||||
}
|
||||
|
||||
setCorrespondingPos() {
|
||||
this.correspondingPos = this.pos.filter((po, index, array) => {
|
||||
return po.customerId === this.chosenCustomerID;
|
||||
});
|
||||
}
|
||||
}
|
||||
import {Component, OnInit, ViewChild} from '@angular/core';
|
||||
import {AstuteClientService} from '../services/astute-client-service';
|
||||
import {formatCurrency} from "@angular/common";
|
||||
|
||||
declare var $: any;
|
||||
|
||||
@Component({
|
||||
selector: 'app-invoice',
|
||||
templateUrl: './invoice.component.html',
|
||||
styleUrls: ['./invoice.component.css']
|
||||
})
|
||||
export class InvoiceComponent implements OnInit {
|
||||
@ViewChild('agGrid') agGrid;
|
||||
chosenCustomerID: any = 0;
|
||||
chosenInv: any = 0;
|
||||
source;
|
||||
customers;
|
||||
pos = [];
|
||||
chosenPo;
|
||||
correspondingPos = [];
|
||||
generatedInvoiceNumber = '';
|
||||
feeTypes = ['Fixed Fee', 'Hourly'];
|
||||
serviceTypes = ['Study', 'Design', 'Peer Review', 'Cost Investigation', 'Forensic Investigation'];
|
||||
columnDefs = [
|
||||
{headerName: 'Invoice Number', field: 'invoiceNumber'},
|
||||
{headerName: 'Date', field: 'invoiceDate'},
|
||||
{headerName: 'Sales Order Number', field: 'poNum'},
|
||||
{headerName: 'Change Order Number', field: 'changeOrderNum'},
|
||||
{headerName: 'Payment', field: 'pmtStatusDesc'},
|
||||
{headerName: 'Bll Amount', field: 'billAmt'}
|
||||
];
|
||||
newInDetails = [];
|
||||
newBillAmt = 0;
|
||||
selectedInDetails = [];
|
||||
selectedPO;
|
||||
selectedBillAmt = 0;
|
||||
poDetails = [];
|
||||
selectedPODetails = [];
|
||||
|
||||
gridOptions = {
|
||||
|
||||
// PROPERTIES - object properties, myRowData and myColDefs are created somewhere in your application
|
||||
rowData: this.source,
|
||||
columnDefs: this.columnDefs,
|
||||
|
||||
// PROPERTIES - simple boolean / string / number properties
|
||||
enableColResize: true,
|
||||
rowSelection: 'single',
|
||||
|
||||
// EVENTS - add event callback handlers
|
||||
onRowClicked: (event) => {
|
||||
this.getSelectedRows();
|
||||
},
|
||||
onColumnResized: function (event) {
|
||||
console.log('a column was resized');
|
||||
},
|
||||
onGridReady: (event) => {
|
||||
},
|
||||
// this.agGrid.sizeColumnsToFit();
|
||||
// 1: draft
|
||||
// 2: submitted
|
||||
// 3: void
|
||||
|
||||
// getRowStyle: function(params) {
|
||||
// if (params.data.invoiceStatus === 1) {
|
||||
// return { 'color': 'red' }
|
||||
// } else if (params.data.invoiceStatus === 3) {
|
||||
// return { 'text-decoration': 'line-through'}
|
||||
// }
|
||||
// }
|
||||
|
||||
rowClassRules: {
|
||||
// apply green to 2008
|
||||
// 'bg-red': true,
|
||||
|
||||
// apply amber 2004
|
||||
'text-danger': function (params) {
|
||||
return params.data.invoiceStatus === 1;
|
||||
},
|
||||
'text-primary': function (params) {
|
||||
return params.data.invoiceStatus === 2;
|
||||
},
|
||||
'text-warning': function (params) {
|
||||
return params.data.invoiceStatus === 3;
|
||||
},
|
||||
|
||||
// apply red to 2000
|
||||
// 'rag-red-outer': function(params) { return params.data.year === 2000}
|
||||
}
|
||||
}
|
||||
|
||||
constructor(protected astuteClientService: AstuteClientService) {
|
||||
}
|
||||
|
||||
customerDropdownChange(index) {
|
||||
this.chosenCustomerID = this.customers[index].customerId;
|
||||
this.setCorrespondingPos();
|
||||
}
|
||||
|
||||
poDropdownChange(ponum) {
|
||||
this.pos.forEach((po) => {
|
||||
if (po.ponum === ponum) {
|
||||
this.chosenPo = po;
|
||||
}
|
||||
})
|
||||
this.astuteClientService.getPODetail(ponum).then((data) => {
|
||||
if (data) {
|
||||
// fee
|
||||
// feeTypeId
|
||||
// lineItemNo
|
||||
// ponum
|
||||
// qty
|
||||
// remainingQty
|
||||
// serviceDesc
|
||||
// serviceTypeId
|
||||
|
||||
// lineItemNo, feeTypeId, serviceTypeId, serviceDesc, fee, remainingQty
|
||||
this.poDetails = data;
|
||||
this.poDetails[-1] = {
|
||||
'lineItemNo': -1,
|
||||
'feeTypeId': 1,
|
||||
'serviceTypeId': 1,
|
||||
'serviceDesc': 'Out of Pocket Expenses',
|
||||
'fee': 0,
|
||||
'remainingQty': 0
|
||||
};
|
||||
} else {
|
||||
alert("get PO detail failed!");
|
||||
}
|
||||
});
|
||||
this.astuteClientService.generateInvoiceNumber(ponum).then((data) => {
|
||||
if (data) {
|
||||
this.generatedInvoiceNumber = data;
|
||||
} else {
|
||||
alert('gen inv num failed!');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
ngOnInit() {
|
||||
this.refreshData();
|
||||
}
|
||||
|
||||
refreshData() {
|
||||
this.astuteClientService.getInvoices().then((data) => {
|
||||
this.source = data;
|
||||
this.source.forEach((row) => {
|
||||
row.billAmt = formatCurrency(row.billAmt, 'en-US', '$', 'USD');
|
||||
});
|
||||
});
|
||||
|
||||
this.astuteClientService.getCustomers().then((data) => {
|
||||
this.customers = data;
|
||||
});
|
||||
|
||||
this.astuteClientService.getPOs().then((data) => {
|
||||
this.pos = data;
|
||||
});
|
||||
}
|
||||
|
||||
getPODetails(poIndex) {
|
||||
let ponum = this.pos[poIndex].ponum;
|
||||
this.astuteClientService.getPODetail(ponum).then((data) => {
|
||||
this.selectedInDetails = data;
|
||||
console.log("inDetails:");
|
||||
console.log(this.selectedInDetails);
|
||||
});
|
||||
}
|
||||
|
||||
onSelectedCellChange(row: number, col: string, value) {
|
||||
this.selectedInDetails[row][col] = value;
|
||||
console.log(this.selectedInDetails);
|
||||
}
|
||||
|
||||
onNewCellChange(row: number, col: string, value) {
|
||||
this.newInDetails[row][col] = value;
|
||||
console.log(this.newInDetails);
|
||||
}
|
||||
|
||||
pushOntoSelectedDetail(invoiceNum, lineItemNum, poLineItemNum, serviceTypeId, desc, qty, fee) {
|
||||
this.selectedInDetails.push({
|
||||
'invoiceNum': invoiceNum,
|
||||
'lineItemNum': lineItemNum,
|
||||
'poLineItemNum': poLineItemNum,
|
||||
'serviceTypeId': serviceTypeId,
|
||||
'desc': desc,
|
||||
'qty': +qty,
|
||||
'fee': +fee
|
||||
});
|
||||
}
|
||||
|
||||
pushOntoNewDetail(invoiceNum, lineItemNum, poLineItemNum, feeTypeId, serviceTypeId, desc, qty, fee, remainingQty, poNum) {
|
||||
this.newInDetails.push({
|
||||
'invoiceNum': invoiceNum,
|
||||
'lineItemNum': lineItemNum,
|
||||
'poLineItemNum': poLineItemNum,
|
||||
'feeTypeId': feeTypeId,
|
||||
'serviceTypeId': serviceTypeId,
|
||||
'desc': desc,
|
||||
'qty': +qty,
|
||||
'fee': +fee,
|
||||
'remainingQty': +remainingQty,
|
||||
'poNum': poNum
|
||||
});
|
||||
console.log(this.newInDetails);
|
||||
}
|
||||
|
||||
updateNewBillAmt() {
|
||||
let tot = 0;
|
||||
this.newInDetails.forEach((d) => {
|
||||
tot += +d.qty * +d.fee;
|
||||
});
|
||||
this.newBillAmt = tot;
|
||||
}
|
||||
|
||||
updateSelectedBillAmt() {
|
||||
let tot = 0;
|
||||
this.selectedInDetails.forEach((d) => {
|
||||
tot += +d.qty * +d.fee;
|
||||
});
|
||||
this.selectedBillAmt = tot;
|
||||
}
|
||||
|
||||
assignActity(): void {
|
||||
window.open('/invoice-gen');
|
||||
}
|
||||
|
||||
getSelectedRows() {
|
||||
const selectedNodes = this.agGrid.api.getSelectedNodes();
|
||||
if (selectedNodes.length) {
|
||||
this.chosenInv = selectedNodes.map(node => node.data)[0];
|
||||
// console.log (this.chosenInv);
|
||||
this.selectedBillAmt = +(this.chosenInv.billAmt.replace(',', '').replace('$', ''));
|
||||
this.astuteClientService.getPODetail(this.chosenInv.poNum).then((poDetails) => {
|
||||
if (poDetails) {
|
||||
this.selectedPODetails = poDetails;
|
||||
this.astuteClientService.getInvoiceDetail(this.chosenInv.invoiceNumber).then((invoiceDetails) => {
|
||||
if (invoiceDetails) {
|
||||
this.selectedInDetails = invoiceDetails;
|
||||
this.selectedInDetails.forEach((invDetail) => {
|
||||
const tempPo = this.selectedPODetails.filter((po) => {
|
||||
// console.log (po.lineItemNo + " and " + invDetail.poLineItemNum);
|
||||
return po.lineItemNo === invDetail.poLineItemNum;
|
||||
})[0];
|
||||
if (tempPo) {
|
||||
invDetail.remainingQty = tempPo.remainingQty;
|
||||
}
|
||||
});
|
||||
} else {
|
||||
alert("get Inv detail failed!");
|
||||
}
|
||||
});
|
||||
} else {
|
||||
alert("get PO detail failed!")
|
||||
}
|
||||
});
|
||||
this.pos.forEach((po) => {
|
||||
if (po.ponum === this.chosenInv.poNum) {
|
||||
this.selectedPO = po;
|
||||
}
|
||||
});
|
||||
} else {
|
||||
this.chosenInv = null;
|
||||
this.selectedPODetails = [];
|
||||
}
|
||||
}
|
||||
|
||||
open(content, indexPO, indexINV) {
|
||||
content.open();
|
||||
// this.detailDescription = ViewChild('detailDescription');
|
||||
// this.detailAmount = ViewChild('detailAmount');
|
||||
// this.detailRate = ViewChild('detailRate');
|
||||
// this.detailTotal = ViewChild('detailTotal');
|
||||
// if (indexINV) {
|
||||
// this.chosenInv = indexINV;
|
||||
// }
|
||||
// if (indexPO) {
|
||||
// this.chosenPo = indexPO;
|
||||
// this.getPODetails(this.chosenPo);
|
||||
// }
|
||||
// this.modalService.open(content, { size: 'lg' }).result.then((result) => {
|
||||
// this.closeResult = `Closed with: ${result}`;
|
||||
// }, (reason) => {
|
||||
// this.closeResult = `Dismissed ${this.getDismissReason(reason)}`;
|
||||
// });
|
||||
}
|
||||
|
||||
close(content) {
|
||||
content.close();
|
||||
// this.newInDetails = [];
|
||||
}
|
||||
|
||||
getCurrDate() {
|
||||
let d = new Date(),
|
||||
month = '' + (d.getMonth() + 1),
|
||||
day = '' + d.getDate(),
|
||||
year = d.getFullYear();
|
||||
|
||||
if (month.length < 2) month = '0' + month;
|
||||
if (day.length < 2) day = '0' + day;
|
||||
|
||||
|
||||
return [year, month, day].join('-');
|
||||
}
|
||||
|
||||
formatDate(d: Date) {
|
||||
let month = '' + (d.getMonth() + 1),
|
||||
day = '' + d.getDate(),
|
||||
year = d.getFullYear();
|
||||
|
||||
if (month.length < 2) {
|
||||
month = '0' + month;
|
||||
}
|
||||
if (day.length < 2) {
|
||||
day = '0' + day;
|
||||
}
|
||||
return [year, month, day].join('-');
|
||||
}
|
||||
|
||||
deleteInvoice (invoiceNum) {
|
||||
if (confirm('Are you sure you want to delete invoice, ' + invoiceNum)) {
|
||||
this.astuteClientService.deleteInvoice(invoiceNum).then((data) => {
|
||||
if (data) {
|
||||
console.log('Invoice, ' + invoiceNum + ' successfully deleted');
|
||||
this.refreshData();
|
||||
} else {
|
||||
alert ('Error in deleting; Invoice, ' + invoiceNum + ' has not been deleted');
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
addInvoice(invoiceNumber, poNum, changeOrderNum, pmtStatus, billAmt, specialNotes, certification, status, ref) {
|
||||
// String invoiceNumber;
|
||||
// Date invoiceDate;
|
||||
// String poNum;
|
||||
// String changeOrderNum;
|
||||
// int pmtStatus;
|
||||
// Double billAmt;
|
||||
// String specialNotes;
|
||||
// String certification;
|
||||
// Date pmtReceivedDate;
|
||||
const invData = {
|
||||
"invoiceNumber": invoiceNumber,
|
||||
"invoiceDate": this.formatDate(new Date()),
|
||||
"poNum": poNum,
|
||||
"changeOrderNum": changeOrderNum,
|
||||
"pmtStatus": +pmtStatus,
|
||||
"billAmt": +billAmt,
|
||||
"specialNotes": specialNotes,
|
||||
"certification": certification,
|
||||
"pmtReceivedDate": this.formatDate(new Date()),
|
||||
'invoiceStatus': status
|
||||
};
|
||||
console.log(invData);
|
||||
|
||||
this.astuteClientService.createInvoice(invData)
|
||||
.catch((response) => {
|
||||
console.log("rejected: " + response);
|
||||
})
|
||||
.then((data) => {
|
||||
if (data) {
|
||||
this.refreshData();
|
||||
this.addInvoiceDetail(this.newInDetails);
|
||||
ref.close();
|
||||
} else {
|
||||
alert('Invoice Creation Failed, Check Input Fields');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
addInvoiceDetail(details) {
|
||||
if (details.length) {
|
||||
// console.log(details[0]);
|
||||
// if (details[0].poLineItemNum !== -1) {
|
||||
this.astuteClientService.createInvoiceDetail(details[0]).then((data) => {
|
||||
if (data) {
|
||||
details.splice(0, 1);
|
||||
this.addInvoiceDetail(details);
|
||||
} else {
|
||||
alert('add inv detail failed');
|
||||
}
|
||||
});
|
||||
// } else {
|
||||
// desc
|
||||
// fee
|
||||
// feeTypeId
|
||||
// invoiceNum
|
||||
// lineItemNum
|
||||
// poLineItemNum
|
||||
// qty
|
||||
// remainingQty
|
||||
// serviceTypeId
|
||||
// poNum
|
||||
|
||||
// const data = {
|
||||
// // 'lineItemNo': details[0].,
|
||||
// 'poNum': details[0].poNum,
|
||||
// 'serviceDesc': details[0].desc,
|
||||
// 'feeTypeId': details[0].feeTypeId,
|
||||
// 'serviceTypeId': details[0].serviceTypeId,
|
||||
// 'qty': +details[0].qty,
|
||||
// 'fee': +details[0].fee,
|
||||
// 'remainingQty': +details[0].fee * +details[0].qty
|
||||
// };
|
||||
// this.astuteClientService.createPODetail(data).then((d) => {
|
||||
// if (d) {
|
||||
// console.log (d);
|
||||
// } else {
|
||||
// alert('create custom PO failed.');
|
||||
// }
|
||||
// });
|
||||
// }
|
||||
} else {
|
||||
this.newInDetails = [];
|
||||
}
|
||||
}
|
||||
|
||||
editInvoice(invoiceNumber, poNum, changeOrderNum, pmtStatus, billAmt, specialNotes, certification) {
|
||||
// String invoiceNumber;
|
||||
// Date invoiceDate;
|
||||
// String poNum;
|
||||
// String changeOrderNum;
|
||||
// int pmtStatus;
|
||||
// Double billAmt;
|
||||
// String specialNotes;
|
||||
// String certification;
|
||||
// Date pmtReceivedDate;
|
||||
const invData = {
|
||||
"invoiceNumber": invoiceNumber,
|
||||
"invoiceDate": new Date(),
|
||||
"poNum": poNum,
|
||||
"changeOrderNum": changeOrderNum,
|
||||
"pmtStatus": +pmtStatus,
|
||||
"billAmt": +billAmt,
|
||||
"specialNotes": specialNotes,
|
||||
"certification": certification,
|
||||
"pmtReceivedDate": new Date()
|
||||
};
|
||||
|
||||
this.astuteClientService.updateInvoice(invoiceNumber, invData)
|
||||
.catch((response) => {
|
||||
console.log("rejected: " + response);
|
||||
})
|
||||
.then((data) => {
|
||||
if (data) {
|
||||
alert("invoice " + invoiceNumber + " updated!");
|
||||
console.log("fulfilled: " + data);
|
||||
// this.source[this.chosenInv] = invData;
|
||||
this.refreshData();
|
||||
} else {
|
||||
alert("Invoice Update Failed, Check Input Fields")
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
voidInvoice(invoiceNumber) {
|
||||
if (confirm('Are you sure you want to void invoice, ' + invoiceNumber)) {
|
||||
this.astuteClientService.voidInvoice(invoiceNumber).then((data) => {
|
||||
if (data) {
|
||||
this.refreshData();
|
||||
} else {
|
||||
alert('void invoice failed.');
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
submitInvoice(invoiceNumber) {
|
||||
this.astuteClientService.submitInvoice(invoiceNumber).then((data) => {
|
||||
if (data) {
|
||||
this.refreshData();
|
||||
} else {
|
||||
alert('submit invoice failed.');
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
getPerc(amt, total): number {
|
||||
return Math.floor(((amt) / total) * 100);
|
||||
}
|
||||
|
||||
getRangeMax(total, num) {
|
||||
return Math.floor(total / num);
|
||||
}
|
||||
|
||||
setCorrespondingPos() {
|
||||
this.correspondingPos = this.pos.filter((po, index, array) => {
|
||||
return po.customerId === this.chosenCustomerID;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,382 +1,382 @@
|
|||
<app-nav-bar [salesOrderActive]="true"></app-nav-bar>
|
||||
<h1 align="center">Sales Orders</h1>
|
||||
<div class="container-fluid">
|
||||
<div class="row">
|
||||
<div class="col-12">
|
||||
<ag-grid-angular
|
||||
#agGrid
|
||||
style="height: 500px;"
|
||||
class="ag-theme-balham"
|
||||
[enableSorting]="true"
|
||||
[enableFilter]="true"
|
||||
[rowData]="rowData"
|
||||
[columnDefs]="columnDefs"
|
||||
rowSelection="single"
|
||||
></ag-grid-angular>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row justify-content-center mt-2">
|
||||
<div class="col-6">
|
||||
<button class="btn btn-primary" style="width: 100%" (click)="open(edit)">Edit Sales Order</button>
|
||||
</div>
|
||||
<div class="col-6">
|
||||
<button class="btn btn-success" style="width: 100%" (click)="open(new)">Add Sales Order</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!--MODAL: new po-->
|
||||
<app-modal-form [title]="'New Sales Order'" #new>
|
||||
<div class="modal-body">
|
||||
<p class="h4 text-right">General</p>
|
||||
<hr>
|
||||
<table class="table table-borderless table-sm">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td><span class="input-group-text">Astute Proj. No.</span></td>
|
||||
<td colspan="3"><input type="text" class="form-control" placeholder="Internal Project Number" #projNum></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><span class="input-group-text">Customer</span></td>
|
||||
<td colspan="3">
|
||||
<select class="form-control" #customerid>
|
||||
<option [value]="-1">Choose Customer...</option>
|
||||
<option *ngFor="let customer of customers" [value]="customer.customerId">{{customer.customerName}}</option>
|
||||
</select>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><span class="input-group-text">SO Title</span></td>
|
||||
<td colspan="3"><input type="text" class="form-control" placeholder="Distinctive title, will be use to identify later" #title></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 20%"><span class="input-group-text">SO Number</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="Internal SO Number" maxlength="40" #ponum></td>
|
||||
<td style="width: 20%"><span class="input-group-text">SO Date</span></td>
|
||||
<td style="width: 30%"><input type="date" class="form-control" [value]="getCurrDate()" (change)="printValue(podate.value)" #podate></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 20%"><span class="input-group-text">Contract Number</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="External Contract Number" #contractnum></td>
|
||||
<td style="width: 20%"><span class="input-group-text">Contract Amount</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="Derived From Details" [value]="newContractAmount | currency" #contractamt disabled></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<!--fee-->
|
||||
<!--feeTypeId-->
|
||||
<!--lineItemNo-->
|
||||
<!--ponum-->
|
||||
<!--qty-->
|
||||
<!--remainingQty-->
|
||||
<!--serviceDesc-->
|
||||
<!--serviceTypeId-->
|
||||
|
||||
<!--Detail-->
|
||||
<div class="modal-body">
|
||||
<p class="h4 text-right">Detail</p>
|
||||
<hr>
|
||||
<table class="table">
|
||||
<thead>
|
||||
<tr>
|
||||
<th scope="col"></th>
|
||||
<th scope="col" style="width: 50px">#</th>
|
||||
<th scope="col">Description</th>
|
||||
<th scope="col">Rate Type</th>
|
||||
<th scope="col">Service Type</th>
|
||||
<th scope="col" style="width: 75px">Qty(#)</th>
|
||||
<th scope="col" style="width: 100px">Rate($)</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody *ngFor="let poDetail of newPODetail; let i = index">
|
||||
<tr class="p-0 m-0">
|
||||
<td class="p-1 m-0">
|
||||
<button class="btn btn-outline-danger" type="button" (click)="newPODetail.splice(i, 1);">
|
||||
-
|
||||
</button>
|
||||
</td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="poDetail.lineItemNo" (change)="onNewCellChange(i, 'lineItemNo', lineItemNo.value)" #lineItemNo></td>
|
||||
<td class="p-0 m-0">
|
||||
<textarea style="height: 36px" class="form-control cell" [value]="poDetail.serviceDesc" (change)="onNewCellChange(i, 'serviceDesc', serviceDesc.value)" #serviceDesc></textarea>
|
||||
<!--<input type="text" class="form-control cell" [value]="poDetail.serviceDesc" (change)="onNewCellChange(i, 'serviceDesc', serviceDesc.value)" #serviceDesc>-->
|
||||
</td>
|
||||
<td class="p-0 m-0">
|
||||
<select class="form-control cell" [value]="poDetail.feeTypeId" (change)="onNewCellChange(i, 'feeTypeId', feeTypeId.value)" #feeTypeId>
|
||||
<option value="1">Fixed Fee</option>
|
||||
<option value="2">Hourly</option>
|
||||
</select>
|
||||
</td>
|
||||
<td class="p-0 m-0">
|
||||
<select class="form-control cell" [value]="poDetail.serviceTypeId" (change)="onNewCellChange(i, 'serviceTypeId', serviceTypeId.value)" #serviceTypeId>
|
||||
<option value="1">Study</option>
|
||||
<option value="2">Design</option>
|
||||
<option value="3">Peer Review</option>
|
||||
<option value="4">Cost Estimation</option>
|
||||
<option value="5">Forensic Investigation</option>
|
||||
</select>
|
||||
</td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="+poDetail.qty" (change)="onNewCellChange(i, 'qty', qty.value); onNewCellChange(i, 'remainingQty', qty.value * fee.value); updateNewContractAmt();" #qty></td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="+poDetail.fee" (change)="onNewCellChange(i, 'fee', fee.value); onNewCellChange(i, 'remainingQty', qty.value * fee.value); updateNewContractAmt();" #fee></td>
|
||||
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="poDetail.remainingQty" [id]="'remainingQty' + i"></td>-->
|
||||
</tr>
|
||||
</tbody>
|
||||
<tr class="p-0 m-0">
|
||||
<td class="p-1 m-0">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!ponum.value"
|
||||
(click)="pushOntoNewDetail(newPODetail.length + 1, ponum.value, '', '1', '1', 1, 0, 0)">
|
||||
<!--(click)="pushOntoNewDetail((lineItemNo) ? lineItemNo.value + 1: 1, ponum.value, serviceDesc.value,-->
|
||||
<!--feeTypeId.value, serviceTypeId.value, qty.value, fee.value, 0)">-->
|
||||
+</button>
|
||||
</td>
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<input type="number" class="form-control cell" [value]="(selectedPODetail.length) ? selectedPODetail[selectedPODetail.length-1].lineItemNo + 1: 1" #lineItemNo>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="''" #serviceDesc></td>-->
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<select class="form-control cell" [value]="1" #feeTypeId>-->
|
||||
<!--<option value="1">Fixed Fee</option>-->
|
||||
<!--<option value="2">Hourly</option>-->
|
||||
<!--</select>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<select class="form-control cell" [value]="1" #serviceTypeId>-->
|
||||
<!--<option value="1">Study</option>-->
|
||||
<!--<option value="2">Design</option>-->
|
||||
<!--<option value="3">Peer Review</option>-->
|
||||
<!--<option value="4">Cost Estimation</option>-->
|
||||
<!--<option value="5">Forensic Investigation</option>-->
|
||||
<!--</select>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="1" #qty></td>-->
|
||||
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="0" #fee></td>-->
|
||||
<!--<!–<td class="p-0 m-0"><input type="number" class="form-control cell" #remainingQty></td>–>-->
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!(ponum.value && podate.value && customerid.value && contractnum.value && contractamt.value)"
|
||||
(click)="addPo(projNum.value, ponum.value, podate.value, customerid.value, contractnum.value, contractamt.value.replace('$', '').replace(',', ''), title.value, new)"
|
||||
>
|
||||
Add
|
||||
</button>
|
||||
<button class="btn btn-outline-danger" (click)="close(new)">Cancel</button>
|
||||
</div>
|
||||
</app-modal-form>
|
||||
|
||||
<!--MODAL: edit po-->
|
||||
<app-modal-form [title]="'Edit Sales Order'" #edit>
|
||||
<div *ngIf="selected">
|
||||
<div class="modal-body">
|
||||
<p class="h4 text-right">General</p>
|
||||
<hr>
|
||||
<table class="table table-borderless table-sm">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td><span class="input-group-text">Astute Proj. No.</span></td>
|
||||
<td colspan="3"><input type="text" class="form-control" placeholder="Project Number" [value]="selected.astuteProjectNumber" #projNum></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><span class="input-group-text">Customer</span></td>
|
||||
<td colspan="3">
|
||||
<select class="form-control" [value]="selected.customerId" disabled="true" #customerid>
|
||||
<option [value]="-1">No Customer</option>
|
||||
<option *ngFor="let customer of customers" [value]="customer.customerId">{{customer.customerName}}</option>
|
||||
</select>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><span class="input-group-text">SO Title</span></td>
|
||||
<td colspan="3"><input type="text" class="form-control" placeholder="SO Title" [value]="selected.title" #title></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 20%"><span class="input-group-text">SO Number</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="SO Number" maxlength="40" [value]="selected.ponum" #ponum disabled></td>
|
||||
<td style="width: 20%"><span class="input-group-text">SO Date</span></td>
|
||||
<td style="width: 30%"><input type="date" class="form-control" [value]="selected.podate" #podate></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 20%"><span class="input-group-text">Contract Number</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="Contract Number" [value]="selected.contractNum" #contractnum></td>
|
||||
<td style="width: 20%"><span class="input-group-text">Contract Amount</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="Contract Amount" [value]="editContractAmount | currency" #contractamt disabled></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<!--<form>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">Astute Project Number</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" placeholder="Project Number" [value]="selected.astuteProjectNumber" #projNum>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">Customer Name</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<select class="form-control" [value]="selected.customerId" #customerid disabled>-->
|
||||
<!--<option *ngFor="let customer of customers" [value]="customer.customerId">{{customer.customerName}}-->
|
||||
<!--</option>-->
|
||||
<!--</select>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">SO Title</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" [value]="selected.title" #title>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">SO Number</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" placeholder="SO Number" [value]="selected.ponum" #ponum disabled>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">SO Date</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="date" class="form-control" [value]="selected.podate" #podate>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">Contract Number</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" placeholder="Contract Number" [value]="selected.contractNum"-->
|
||||
<!--#contractnum>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">Contract Amount</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" placeholder="Contract Amount" [value]="selected.contractAmt"-->
|
||||
<!--#contractamt>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--</form>-->
|
||||
</div>
|
||||
|
||||
|
||||
<!--fee-->
|
||||
<!--feeTypeId-->
|
||||
<!--lineItemNo-->
|
||||
<!--ponum-->
|
||||
<!--qty-->
|
||||
<!--remainingQty-->
|
||||
<!--serviceDesc-->
|
||||
<!--serviceTypeId-->
|
||||
|
||||
<!--Detail-->
|
||||
<div class="modal-body" *ngIf="selectedPODetail">
|
||||
<p class="h4 text-right">Detail</p>
|
||||
<hr>
|
||||
<table class="table">
|
||||
<thead>
|
||||
<tr>
|
||||
<th scope="col" style="width: 50px">#</th>
|
||||
<!--<th scope="col">Purchase Order Number</th>-->
|
||||
<th scope="col">Description</th>
|
||||
<th scope="col">Rate Type</th>
|
||||
<th scope="col">Service Type</th>
|
||||
<th scope="col" style="width: 75px">Qty(#)</th>
|
||||
<th scope="col" style="width: 100px">Rate($)</th>
|
||||
<!--<th scope="col">Remaining Quantity</th>-->
|
||||
</tr>
|
||||
</thead>
|
||||
<!--<tbody>-->
|
||||
<tbody *ngFor="let poDetail of selectedPODetail; let i = index">
|
||||
<tr class="p-0 m-0">
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<button class="btn btn-outline-danger" type="button" (click)="selectedPODetail.splice(i, 1);">-->
|
||||
<!-- - -->
|
||||
<!--</button>-->
|
||||
<!--</td>-->
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="poDetail.lineItemNo" (change)="onSelectedCellChange(i, 'lineItemNo', lineItemNo.value)" #lineItemNo></td>
|
||||
<!--<td class="p-0"><input type="text" class="form-control cell" [value]="poDetail.ponum"></td>-->
|
||||
<td class="p-0 m-0">
|
||||
<textarea style="height: 36px" class="form-control cell" [value]="poDetail.serviceDesc" (change)="onSelectedCellChange(i, 'serviceDesc', serviceDesc.value)" #serviceDesc></textarea>
|
||||
<!--<input type="text" class="form-control cell" [value]="poDetail.serviceDesc" (change)="onSelectedCellChange(i, 'serviceDesc', serviceDesc.value)" #serviceDesc>-->
|
||||
</td>
|
||||
<td class="p-0 m-0">
|
||||
<select class="form-control cell" [value]="poDetail.feeTypeId" (change)="onSelectedCellChange(i, 'feeTypeId', feeTypeId.value)" #feeTypeId>
|
||||
<option value="1">Fixed Fee</option>
|
||||
<option value="2">Hourly</option>
|
||||
</select>
|
||||
<!--<input type="number" class="form-control cell" [value]="poDetail.feeTypeId">-->
|
||||
</td>
|
||||
<td class="p-0 m-0">
|
||||
<select class="form-control cell" [value]="poDetail.serviceTypeId" (change)="onSelectedCellChange(i, 'serviceTypeId', serviceTypeId.value)" #serviceTypeId>
|
||||
<option [value]="serviceType.serviceTypeId" *ngFor="let serviceType of serviceTypes">{{serviceType.desc}}</option>
|
||||
<!--<option value="">Study</option>-->
|
||||
<!--<option value="2">Design</option>-->
|
||||
<!--<option value="3">Peer Review</option>-->
|
||||
<!--<option value="4">Cost Estimation</option>-->
|
||||
<!--<option value="5">Forensic Investigation</option>-->
|
||||
</select>
|
||||
<!--<input type="number" class="form-control cell" [value]="poDetail.serviceTypeId" #serviceTypeId>-->
|
||||
</td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="+poDetail.qty" (change)="onSelectedCellChange(i, 'qty', qty.value); onSelectedCellChange(i, 'remainingQty', qty.value * fee.value); updateEditContractAmt();" #qty></td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="+poDetail.fee" (change)="onSelectedCellChange(i, 'fee', fee.value); onSelectedCellChange(i, 'remainingQty', qty.value * fee.value); updateEditContractAmt();" #fee></td>
|
||||
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="poDetail.remainingQty" [id]="'remainingQty' + i"></td>-->
|
||||
</tr>
|
||||
</tbody>
|
||||
<tr class="p-0 m-0">
|
||||
<td class="p-1 m-0">
|
||||
<button class="btn btn-success" type="button"
|
||||
(click)="pushOntoSelectedDetail(selectedPODetail.length + 1, ponum.value, '', '1', '1', 1, 0, 0)">
|
||||
<!--(click)="pushOntoSelectedDetail(selectedPODetail[selectedPODetail.length-1].lineItemNo + 1, selected.ponum, serviceDesc.value,-->
|
||||
<!--feeTypeId.value, serviceTypeId.value, qty.value, fee.value, 0)">-->
|
||||
+</button>
|
||||
</td>
|
||||
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="''" #serviceDesc></td>-->
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<select class="form-control cell" [value]="1" #feeTypeId>-->
|
||||
<!--<option value="1">Fixed Fee</option>-->
|
||||
<!--<option value="2">Hourly</option>-->
|
||||
<!--</select>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<select class="form-control cell" [value]="1" #serviceTypeId>-->
|
||||
<!--<option value="1">Study</option>-->
|
||||
<!--<option value="2">Design</option>-->
|
||||
<!--<option value="3">Peer Review</option>-->
|
||||
<!--<option value="4">Cost Estimation</option>-->
|
||||
<!--<option value="5">Forensic Investigation</option>-->
|
||||
<!--</select>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="0" #qty></td>-->
|
||||
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" #remainingQty></td>-->
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!(ponum.value && podate.value && contractnum.value && contractamt.value)"
|
||||
(click)="editPo(projNum.value, ponum.value, podate.value, contractnum.value, contractamt.value.replace(',', '').replace('$', ''), title.value, edit)"
|
||||
>
|
||||
Update
|
||||
</button>
|
||||
<button class="btn btn-outline-danger" (click)="close(edit)">Cancel</button>
|
||||
</div>
|
||||
</div>
|
||||
<div *ngIf="!selected">
|
||||
<div class="modal-body">
|
||||
Choose a Sales Order First!
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="true"
|
||||
>
|
||||
Update
|
||||
</button>
|
||||
<button class="btn btn-outline-danger" (click)="close(edit)">Cancel</button>
|
||||
</div>
|
||||
</div>
|
||||
</app-modal-form>
|
||||
<app-nav-bar [salesOrderActive]="true"></app-nav-bar>
|
||||
<h1 align="center">Sales Orders</h1>
|
||||
<div class="container-fluid">
|
||||
<div class="row">
|
||||
<div class="col-12">
|
||||
<ag-grid-angular
|
||||
#agGrid
|
||||
style="height: 500px;"
|
||||
class="ag-theme-balham"
|
||||
[enableSorting]="true"
|
||||
[enableFilter]="true"
|
||||
[rowData]="rowData"
|
||||
[columnDefs]="columnDefs"
|
||||
rowSelection="single"
|
||||
></ag-grid-angular>
|
||||
</div>
|
||||
</div>
|
||||
<div class="row justify-content-center mt-2">
|
||||
<div class="col-6">
|
||||
<button class="btn btn-primary" style="width: 100%" (click)="open(edit)">Edit Sales Order</button>
|
||||
</div>
|
||||
<div class="col-6">
|
||||
<button class="btn btn-success" style="width: 100%" (click)="open(new)">Add Sales Order</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!--MODAL: new po-->
|
||||
<app-modal-form [title]="'New Sales Order'" #new>
|
||||
<div class="modal-body">
|
||||
<p class="h4 text-right">General</p>
|
||||
<hr>
|
||||
<table class="table table-borderless table-sm">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td><span class="input-group-text">Astute Proj. No.</span></td>
|
||||
<td colspan="3"><input type="text" class="form-control" placeholder="Internal Project Number" #projNum></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><span class="input-group-text">Customer</span></td>
|
||||
<td colspan="3">
|
||||
<select class="form-control" #customerid>
|
||||
<option [value]="-1">Choose Customer...</option>
|
||||
<option *ngFor="let customer of customers" [value]="customer.customerId">{{customer.customerName}}</option>
|
||||
</select>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><span class="input-group-text">SO Title</span></td>
|
||||
<td colspan="3"><input type="text" class="form-control" placeholder="Distinctive title, will be use to identify later" #title></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 20%"><span class="input-group-text">SO Number</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="Internal SO Number" maxlength="40" #ponum></td>
|
||||
<td style="width: 20%"><span class="input-group-text">SO Date</span></td>
|
||||
<td style="width: 30%"><input type="date" class="form-control" [value]="getCurrDate()" (change)="printValue(podate.value)" #podate></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 20%"><span class="input-group-text">Contract Number</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="External Contract Number" #contractnum></td>
|
||||
<td style="width: 20%"><span class="input-group-text">Contract Amount</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="Derived From Details" [value]="newContractAmount | currency" #contractamt disabled></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<!--fee-->
|
||||
<!--feeTypeId-->
|
||||
<!--lineItemNo-->
|
||||
<!--ponum-->
|
||||
<!--qty-->
|
||||
<!--remainingQty-->
|
||||
<!--serviceDesc-->
|
||||
<!--serviceTypeId-->
|
||||
|
||||
<!--Detail-->
|
||||
<div class="modal-body">
|
||||
<p class="h4 text-right">Detail</p>
|
||||
<hr>
|
||||
<table class="table">
|
||||
<thead>
|
||||
<tr>
|
||||
<th scope="col"></th>
|
||||
<th scope="col" style="width: 50px">#</th>
|
||||
<th scope="col">Description</th>
|
||||
<th scope="col">Rate Type</th>
|
||||
<th scope="col">Service Type</th>
|
||||
<th scope="col" style="width: 75px">Qty(#)</th>
|
||||
<th scope="col" style="width: 100px">Rate($)</th>
|
||||
</tr>
|
||||
</thead>
|
||||
|
||||
<tbody *ngFor="let poDetail of newPODetail; let i = index">
|
||||
<tr class="p-0 m-0">
|
||||
<td class="p-1 m-0">
|
||||
<button class="btn btn-outline-danger" type="button" (click)="newPODetail.splice(i, 1);">
|
||||
-
|
||||
</button>
|
||||
</td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="poDetail.lineItemNo" (change)="onNewCellChange(i, 'lineItemNo', lineItemNo.value)" #lineItemNo></td>
|
||||
<td class="p-0 m-0">
|
||||
<textarea style="height: 36px" class="form-control cell" [value]="poDetail.serviceDesc" (change)="onNewCellChange(i, 'serviceDesc', serviceDesc.value)" #serviceDesc></textarea>
|
||||
<!--<input type="text" class="form-control cell" [value]="poDetail.serviceDesc" (change)="onNewCellChange(i, 'serviceDesc', serviceDesc.value)" #serviceDesc>-->
|
||||
</td>
|
||||
<td class="p-0 m-0">
|
||||
<select class="form-control cell" [value]="poDetail.feeTypeId" (change)="onNewCellChange(i, 'feeTypeId', feeTypeId.value)" #feeTypeId>
|
||||
<option value="1">Fixed Fee</option>
|
||||
<option value="2">Hourly</option>
|
||||
</select>
|
||||
</td>
|
||||
<td class="p-0 m-0">
|
||||
<select class="form-control cell" [value]="poDetail.serviceTypeId" (change)="onNewCellChange(i, 'serviceTypeId', serviceTypeId.value)" #serviceTypeId>
|
||||
<option value="1">Study</option>
|
||||
<option value="2">Design</option>
|
||||
<option value="3">Peer Review</option>
|
||||
<option value="4">Cost Estimation</option>
|
||||
<option value="5">Forensic Investigation</option>
|
||||
</select>
|
||||
</td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="+poDetail.qty" (change)="onNewCellChange(i, 'qty', qty.value); onNewCellChange(i, 'remainingQty', qty.value * fee.value); updateNewContractAmt();" #qty></td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="+poDetail.fee" (change)="onNewCellChange(i, 'fee', fee.value); onNewCellChange(i, 'remainingQty', qty.value * fee.value); updateNewContractAmt();" #fee></td>
|
||||
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="poDetail.remainingQty" [id]="'remainingQty' + i"></td>-->
|
||||
</tr>
|
||||
</tbody>
|
||||
<tr class="p-0 m-0">
|
||||
<td class="p-1 m-0">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!ponum.value"
|
||||
(click)="pushOntoNewDetail(newPODetail.length + 1, ponum.value, '', '1', '1', 1, 0, 0)">
|
||||
<!--(click)="pushOntoNewDetail((lineItemNo) ? lineItemNo.value + 1: 1, ponum.value, serviceDesc.value,-->
|
||||
<!--feeTypeId.value, serviceTypeId.value, qty.value, fee.value, 0)">-->
|
||||
+</button>
|
||||
</td>
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<input type="number" class="form-control cell" [value]="(selectedPODetail.length) ? selectedPODetail[selectedPODetail.length-1].lineItemNo + 1: 1" #lineItemNo>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="''" #serviceDesc></td>-->
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<select class="form-control cell" [value]="1" #feeTypeId>-->
|
||||
<!--<option value="1">Fixed Fee</option>-->
|
||||
<!--<option value="2">Hourly</option>-->
|
||||
<!--</select>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<select class="form-control cell" [value]="1" #serviceTypeId>-->
|
||||
<!--<option value="1">Study</option>-->
|
||||
<!--<option value="2">Design</option>-->
|
||||
<!--<option value="3">Peer Review</option>-->
|
||||
<!--<option value="4">Cost Estimation</option>-->
|
||||
<!--<option value="5">Forensic Investigation</option>-->
|
||||
<!--</select>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="1" #qty></td>-->
|
||||
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="0" #fee></td>-->
|
||||
<!--<!–<td class="p-0 m-0"><input type="number" class="form-control cell" #remainingQty></td>–>-->
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!(ponum.value && podate.value && customerid.value && contractnum.value && contractamt.value && projNum.value)"
|
||||
(click)="addPo(projNum.value, ponum.value, podate.value, customerid.value, contractnum.value, contractamt.value.replace('$', '').replace(',', ''), title.value, new)"
|
||||
>
|
||||
Add
|
||||
</button>
|
||||
<button class="btn btn-outline-danger" (click)="close(new)">Cancel</button>
|
||||
</div>
|
||||
</app-modal-form>
|
||||
|
||||
<!--MODAL: edit po-->
|
||||
<app-modal-form [title]="'Edit Sales Order'" #edit>
|
||||
<div *ngIf="selected">
|
||||
<div class="modal-body">
|
||||
<p class="h4 text-right">General</p>
|
||||
<hr>
|
||||
<table class="table table-borderless table-sm">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td><span class="input-group-text">Astute Proj. No.</span></td>
|
||||
<td colspan="3"><input type="text" class="form-control" placeholder="Project Number" [value]="selected.astuteProjectNumber" #projNum></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><span class="input-group-text">Customer</span></td>
|
||||
<td colspan="3">
|
||||
<select class="form-control" [value]="selected.customerId" disabled="true" #customerid>
|
||||
<option [value]="-1">No Customer</option>
|
||||
<option *ngFor="let customer of customers" [value]="customer.customerId">{{customer.customerName}}</option>
|
||||
</select>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td><span class="input-group-text">SO Title</span></td>
|
||||
<td colspan="3"><input type="text" class="form-control" placeholder="SO Title" [value]="selected.title" #title></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 20%"><span class="input-group-text">SO Number</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="SO Number" maxlength="40" [value]="selected.ponum" #ponum disabled></td>
|
||||
<td style="width: 20%"><span class="input-group-text">SO Date</span></td>
|
||||
<td style="width: 30%"><input type="date" class="form-control" [value]="selected.podate" #podate></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="width: 20%"><span class="input-group-text">Contract Number</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="Contract Number" [value]="selected.contractNum" #contractnum></td>
|
||||
<td style="width: 20%"><span class="input-group-text">Contract Amount</span></td>
|
||||
<td style="width: 30%"><input type="text" class="form-control" placeholder="Contract Amount" [value]="editContractAmount | currency" #contractamt disabled></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<!--<form>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">Astute Project Number</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" placeholder="Project Number" [value]="selected.astuteProjectNumber" #projNum>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">Customer Name</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<select class="form-control" [value]="selected.customerId" #customerid disabled>-->
|
||||
<!--<option *ngFor="let customer of customers" [value]="customer.customerId">{{customer.customerName}}-->
|
||||
<!--</option>-->
|
||||
<!--</select>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">SO Title</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" [value]="selected.title" #title>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">SO Number</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" placeholder="SO Number" [value]="selected.ponum" #ponum disabled>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">SO Date</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="date" class="form-control" [value]="selected.podate" #podate>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">Contract Number</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" placeholder="Contract Number" [value]="selected.contractNum"-->
|
||||
<!--#contractnum>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--<div class="form-group row">-->
|
||||
<!--<label class="col-sm-2 col-form-label">Contract Amount</label>-->
|
||||
<!--<div class="col-sm-10">-->
|
||||
<!--<input type="text" class="form-control" placeholder="Contract Amount" [value]="selected.contractAmt"-->
|
||||
<!--#contractamt>-->
|
||||
<!--</div>-->
|
||||
<!--</div>-->
|
||||
<!--</form>-->
|
||||
</div>
|
||||
|
||||
|
||||
<!--fee-->
|
||||
<!--feeTypeId-->
|
||||
<!--lineItemNo-->
|
||||
<!--ponum-->
|
||||
<!--qty-->
|
||||
<!--remainingQty-->
|
||||
<!--serviceDesc-->
|
||||
<!--serviceTypeId-->
|
||||
|
||||
<!--Detail-->
|
||||
<div class="modal-body" *ngIf="selectedPODetail">
|
||||
<p class="h4 text-right">Detail</p>
|
||||
<hr>
|
||||
<table class="table">
|
||||
<thead>
|
||||
<tr>
|
||||
<th scope="col" style="width: 50px">#</th>
|
||||
<!--<th scope="col">Purchase Order Number</th>-->
|
||||
<th scope="col">Description</th>
|
||||
<th scope="col">Rate Type</th>
|
||||
<th scope="col">Service Type</th>
|
||||
<th scope="col" style="width: 75px">Quantity</th>
|
||||
<th scope="col" style="width: 100px">Rate</th>
|
||||
<!--<th scope="col">Remaining Quantity</th>-->
|
||||
</tr>
|
||||
</thead>
|
||||
<!--<tbody>-->
|
||||
<tbody *ngFor="let poDetail of selectedPODetail; let i = index">
|
||||
<tr class="p-0 m-0">
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<button class="btn btn-outline-danger" type="button" (click)="selectedPODetail.splice(i, 1);">-->
|
||||
<!-- - -->
|
||||
<!--</button>-->
|
||||
<!--</td>-->
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="poDetail.lineItemNo" (change)="onSelectedCellChange(i, 'lineItemNo', lineItemNo.value)" #lineItemNo></td>
|
||||
<!--<td class="p-0"><input type="text" class="form-control cell" [value]="poDetail.ponum"></td>-->
|
||||
<td class="p-0 m-0">
|
||||
<textarea style="height: 36px" class="form-control cell" [value]="poDetail.serviceDesc" (change)="onSelectedCellChange(i, 'serviceDesc', serviceDesc.value)" #serviceDesc></textarea>
|
||||
<!--<input type="text" class="form-control cell" [value]="poDetail.serviceDesc" (change)="onSelectedCellChange(i, 'serviceDesc', serviceDesc.value)" #serviceDesc>-->
|
||||
</td>
|
||||
<td class="p-0 m-0">
|
||||
<select class="form-control cell" [value]="poDetail.feeTypeId" (change)="onSelectedCellChange(i, 'feeTypeId', feeTypeId.value)" #feeTypeId>
|
||||
<option value="1">Fixed Fee</option>
|
||||
<option value="2">Hourly</option>
|
||||
</select>
|
||||
<!--<input type="number" class="form-control cell" [value]="poDetail.feeTypeId">-->
|
||||
</td>
|
||||
<td class="p-0 m-0">
|
||||
<select class="form-control cell" [value]="poDetail.serviceTypeId" (change)="onSelectedCellChange(i, 'serviceTypeId', serviceTypeId.value)" #serviceTypeId>
|
||||
<option [value]="serviceType.serviceTypeId" *ngFor="let serviceType of serviceTypes">{{serviceType.desc}}</option>
|
||||
<!--<option value="">Study</option>-->
|
||||
<!--<option value="2">Design</option>-->
|
||||
<!--<option value="3">Peer Review</option>-->
|
||||
<!--<option value="4">Cost Estimation</option>-->
|
||||
<!--<option value="5">Forensic Investigation</option>-->
|
||||
</select>
|
||||
<!--<input type="number" class="form-control cell" [value]="poDetail.serviceTypeId" #serviceTypeId>-->
|
||||
</td>
|
||||
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="+poDetail.qty" (change)="onSelectedCellChange(i, 'qty', qty.value); onSelectedCellChange(i, 'remainingQty', qty.value * fee.value); updateEditContractAmt();" #qty></td>
|
||||
<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="+poDetail.fee | currency" (change)="onSelectedCellChange(i, 'fee', fee.value); onSelectedCellChange(i, 'remainingQty', qty.value * fee.value); updateEditContractAmt();" #fee></td>
|
||||
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="poDetail.remainingQty" [id]="'remainingQty' + i"></td>-->
|
||||
</tr>
|
||||
</tbody>
|
||||
<tr class="p-0 m-0">
|
||||
<td class="p-1 m-0">
|
||||
<button class="btn btn-success" type="button"
|
||||
(click)="pushOntoSelectedDetail(selectedPODetail.length + 1, ponum.value, '', '1', '1', 1, 0, 0)">
|
||||
<!--(click)="pushOntoSelectedDetail(selectedPODetail[selectedPODetail.length-1].lineItemNo + 1, selected.ponum, serviceDesc.value,-->
|
||||
<!--feeTypeId.value, serviceTypeId.value, qty.value, fee.value, 0)">-->
|
||||
+</button>
|
||||
</td>
|
||||
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="''" #serviceDesc></td>-->
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<select class="form-control cell" [value]="1" #feeTypeId>-->
|
||||
<!--<option value="1">Fixed Fee</option>-->
|
||||
<!--<option value="2">Hourly</option>-->
|
||||
<!--</select>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0">-->
|
||||
<!--<select class="form-control cell" [value]="1" #serviceTypeId>-->
|
||||
<!--<option value="1">Study</option>-->
|
||||
<!--<option value="2">Design</option>-->
|
||||
<!--<option value="3">Peer Review</option>-->
|
||||
<!--<option value="4">Cost Estimation</option>-->
|
||||
<!--<option value="5">Forensic Investigation</option>-->
|
||||
<!--</select>-->
|
||||
<!--</td>-->
|
||||
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="0" #qty></td>-->
|
||||
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" #remainingQty></td>-->
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="!(ponum.value && podate.value && contractnum.value && contractamt.value && projNum.value)"
|
||||
(click)="editPo(projNum.value, ponum.value, podate.value, contractnum.value, contractamt.value.replace(',', '').replace('$', ''), title.value, edit)"
|
||||
>
|
||||
Update
|
||||
</button>
|
||||
<button class="btn btn-outline-danger" (click)="close(edit)">Cancel</button>
|
||||
</div>
|
||||
</div>
|
||||
<div *ngIf="!selected">
|
||||
<div class="modal-body">
|
||||
Choose a Sales Order First!
|
||||
</div>
|
||||
|
||||
<div class="modal-footer">
|
||||
<button class="btn btn-success" type="button"
|
||||
[disabled]="true"
|
||||
>
|
||||
Update
|
||||
</button>
|
||||
<button class="btn btn-outline-danger" (click)="close(edit)">Cancel</button>
|
||||
</div>
|
||||
</div>
|
||||
</app-modal-form>
|
||||
|
|
|
@ -17,7 +17,6 @@
|
|||
<output-test url="file://$MODULE_DIR$/target/test-classes" />
|
||||
<content url="file://$MODULE_DIR$">
|
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
|
||||
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
|
||||
<excludeFolder url="file://$MODULE_DIR$/target" />
|
||||
</content>
|
||||
<orderEntry type="inheritedJdk" />
|
||||
|
|
|
@ -1,6 +0,0 @@
|
|||
database=sql
|
||||
host=localhost
|
||||
port=3306
|
||||
username=root
|
||||
password=password
|
||||
schema=astute
|
File diff suppressed because it is too large
Load Diff
|
@ -46,13 +46,7 @@ public abstract class DAO {
|
|||
* @throws AstuteException
|
||||
*/
|
||||
public static void init() throws AstuteException {
|
||||
try {
|
||||
File configDir = new File(System.getProperty("catalina.base"), "conf");
|
||||
File configFile = new File(configDir, "db.config");
|
||||
InputStream stream = new FileInputStream(configFile);
|
||||
Properties props = new Properties();
|
||||
props.load(stream);
|
||||
|
||||
// try {
|
||||
// Properties props = new Properties();
|
||||
// InputStream input = new FileInputStream("db.config");
|
||||
|
||||
|
@ -60,12 +54,18 @@ public abstract class DAO {
|
|||
// props.load(input);
|
||||
|
||||
//get properties
|
||||
database = props.getProperty("database");
|
||||
host = props.getProperty("host");
|
||||
port = Integer.parseInt(props.getProperty("port"));
|
||||
schema = props.getProperty("schema");
|
||||
username = props.getProperty("username");
|
||||
password = props.getProperty("password");
|
||||
// database = props.getProperty("database");
|
||||
// host = props.getProperty("host");
|
||||
// port = Integer.parseInt(props.getProperty("port"));
|
||||
// schema = props.getProperty("schema");
|
||||
// username = props.getProperty("username");
|
||||
// password = props.getProperty("password");
|
||||
database = "sql";
|
||||
host = "localhost";
|
||||
port = 3306;
|
||||
schema = "astute";
|
||||
username = "root";
|
||||
password = "password";
|
||||
System.out.println("=============================================");
|
||||
System.out.println("host is " + host);
|
||||
System.out.println("port is " + port);
|
||||
|
@ -74,9 +74,9 @@ public abstract class DAO {
|
|||
System.out.println("password is " + password);
|
||||
System.out.println("=============================================");
|
||||
dao = new SqlDAO();
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
// } catch (IOException e) {
|
||||
// e.printStackTrace();
|
||||
// }
|
||||
}
|
||||
|
||||
public Connection conn;
|
||||
|
@ -166,9 +166,9 @@ public abstract class DAO {
|
|||
|
||||
public abstract List<InvoicePayment> getInvoicePayments(String invoiceNum) throws AstuteException;
|
||||
|
||||
public abstract void updateInvoicePayment(String invoiceNum, int invoicePaymentId, Double paymentAmount, Date paymentDate) throws AstuteException;
|
||||
public abstract void updateInvoicePayment(String invoiceNum, int invoicePaymentId, int InvoicePaymentTypeId, Double paymentAmount, Date paymentDate, String checkTransactionNo) throws AstuteException;
|
||||
|
||||
public abstract void createInvoicePayment(String invoiceNum, int invoicePaymentTypeId, Double paymentAmount, Date paymentDate) throws AstuteException;
|
||||
public abstract void createInvoicePayment(String invoiceNum, int invoicePaymentTypeId, Double paymentAmount, Date paymentDate, String checkTransactionNo) throws AstuteException;
|
||||
|
||||
public abstract List<PaymentType> getPaymentTypes() throws AstuteException;
|
||||
}
|
File diff suppressed because it is too large
Load Diff
|
@ -1,99 +1,117 @@
|
|||
package com.astute.model;
|
||||
|
||||
import java.util.Date;
|
||||
|
||||
public class Invoice {
|
||||
String invoiceNumber;
|
||||
String invoiceDate;
|
||||
String poNum;
|
||||
String changeOrderNum;
|
||||
int pmtStatus;
|
||||
Double billAmt;
|
||||
String specialNotes;
|
||||
String certification;
|
||||
int invoiceStatus;
|
||||
|
||||
public Invoice(String invoiceNumber, String invoiceDate, String poNum, int pmtStatus, Double billAmt, String specialNotes, String certification, int invoiceStatus) {
|
||||
this.invoiceNumber = invoiceNumber;
|
||||
this.invoiceDate = invoiceDate;
|
||||
this.poNum = poNum;
|
||||
this.pmtStatus = pmtStatus;
|
||||
this.billAmt = billAmt;
|
||||
this.specialNotes = specialNotes;
|
||||
this.certification = certification;
|
||||
this.invoiceStatus = invoiceStatus;
|
||||
}
|
||||
|
||||
public String getInvoiceNumber() {
|
||||
|
||||
return invoiceNumber;
|
||||
}
|
||||
|
||||
public void setInvoiceNumber(String invoiceNumber) {
|
||||
this.invoiceNumber = invoiceNumber;
|
||||
}
|
||||
|
||||
public String getInvoiceDate() {
|
||||
return invoiceDate;
|
||||
}
|
||||
|
||||
public void setInvoiceDate(String invoiceDate) {
|
||||
this.invoiceDate = invoiceDate;
|
||||
}
|
||||
|
||||
public String getPoNum() {
|
||||
return poNum;
|
||||
}
|
||||
|
||||
public void setPoNum(String poNum) {
|
||||
this.poNum = poNum;
|
||||
}
|
||||
|
||||
public String getChangeOrderNum() {
|
||||
return changeOrderNum;
|
||||
}
|
||||
|
||||
public void setChangeOrderNum(String changeOrderNum) {
|
||||
this.changeOrderNum = changeOrderNum;
|
||||
}
|
||||
|
||||
public int getPmtStatus() {
|
||||
return pmtStatus;
|
||||
}
|
||||
|
||||
public void setPmtStatus(int pmtStatus) {
|
||||
this.pmtStatus = pmtStatus;
|
||||
}
|
||||
|
||||
public Double getBillAmt() {
|
||||
return billAmt;
|
||||
}
|
||||
|
||||
public void setBillAmt(Double billAmt) {
|
||||
this.billAmt = billAmt;
|
||||
}
|
||||
|
||||
public String getSpecialNotes() {
|
||||
return specialNotes;
|
||||
}
|
||||
|
||||
public void setSpecialNotes(String specialNotes) {
|
||||
this.specialNotes = specialNotes;
|
||||
}
|
||||
|
||||
public String getCertification() {
|
||||
return certification;
|
||||
}
|
||||
|
||||
public void setCertification(String certification) {
|
||||
this.certification = certification;
|
||||
}
|
||||
|
||||
public int getInvoiceStatus() {
|
||||
return invoiceStatus;
|
||||
}
|
||||
|
||||
public void setInvoiceStatus(int invoiceStatus) {
|
||||
this.invoiceStatus = invoiceStatus;
|
||||
}
|
||||
}
|
||||
package com.astute.model;
|
||||
|
||||
public class Invoice {
|
||||
String invoiceNumber;
|
||||
String invoiceDate;
|
||||
String poNum;
|
||||
String changeOrderNum;
|
||||
String pmtStatusDesc;
|
||||
int pmtStatus;
|
||||
Double billAmt;
|
||||
String specialNotes;
|
||||
String certification;
|
||||
int invoiceStatus;
|
||||
String customerId;
|
||||
|
||||
public Invoice(String invoiceNumber, String invoiceDate, String poNum, int pmtStatus, Double billAmt, String specialNotes, String certification, int invoiceStatus, String pmtStatusDesc, String customerId) {
|
||||
this.invoiceNumber = invoiceNumber;
|
||||
this.invoiceDate = invoiceDate;
|
||||
this.poNum = poNum;
|
||||
this.pmtStatus = pmtStatus;
|
||||
this.billAmt = billAmt;
|
||||
this.specialNotes = specialNotes;
|
||||
this.certification = certification;
|
||||
this.invoiceStatus = invoiceStatus;
|
||||
this.pmtStatusDesc = pmtStatusDesc;
|
||||
this.customerId = customerId;
|
||||
}
|
||||
|
||||
public String getInvoiceNumber() {
|
||||
|
||||
return invoiceNumber;
|
||||
}
|
||||
|
||||
public void setInvoiceNumber(String invoiceNumber) {
|
||||
this.invoiceNumber = invoiceNumber;
|
||||
}
|
||||
|
||||
public String getInvoiceDate() {
|
||||
return invoiceDate;
|
||||
}
|
||||
|
||||
public void setInvoiceDate(String invoiceDate) {
|
||||
this.invoiceDate = invoiceDate;
|
||||
}
|
||||
|
||||
public String getPoNum() {
|
||||
return poNum;
|
||||
}
|
||||
|
||||
public void setPoNum(String poNum) {
|
||||
this.poNum = poNum;
|
||||
}
|
||||
|
||||
public String getChangeOrderNum() {
|
||||
return changeOrderNum;
|
||||
}
|
||||
|
||||
public void setChangeOrderNum(String changeOrderNum) {
|
||||
this.changeOrderNum = changeOrderNum;
|
||||
}
|
||||
|
||||
public String getPmtStatusDesc() {
|
||||
return pmtStatusDesc;
|
||||
}
|
||||
|
||||
public void setPmtStatusDesc(String pmtStatusDesc) {
|
||||
this.pmtStatusDesc = pmtStatusDesc;
|
||||
}
|
||||
|
||||
public int getPmtStatus() {
|
||||
return pmtStatus;
|
||||
}
|
||||
|
||||
public void setPmtStatus(int pmtStatus) {
|
||||
this.pmtStatus = pmtStatus;
|
||||
}
|
||||
|
||||
public Double getBillAmt() {
|
||||
return billAmt;
|
||||
}
|
||||
|
||||
public void setBillAmt(Double billAmt) {
|
||||
this.billAmt = billAmt;
|
||||
}
|
||||
|
||||
public String getSpecialNotes() {
|
||||
return specialNotes;
|
||||
}
|
||||
|
||||
public void setSpecialNotes(String specialNotes) {
|
||||
this.specialNotes = specialNotes;
|
||||
}
|
||||
|
||||
public String getCertification() {
|
||||
return certification;
|
||||
}
|
||||
|
||||
public void setCertification(String certification) {
|
||||
this.certification = certification;
|
||||
}
|
||||
|
||||
public int getInvoiceStatus() {
|
||||
return invoiceStatus;
|
||||
}
|
||||
|
||||
public void setInvoiceStatus(int invoiceStatus) {
|
||||
this.invoiceStatus = invoiceStatus;
|
||||
}
|
||||
|
||||
public String getCustomerId() {
|
||||
return customerId;
|
||||
}
|
||||
|
||||
public void setCustomerId(String customerId) {
|
||||
this.customerId = customerId;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,69 +1,78 @@
|
|||
package com.astute.model;
|
||||
|
||||
import java.sql.Date;
|
||||
|
||||
public class InvoicePayment {
|
||||
String invoiceNum;
|
||||
int invoicePaymentId;
|
||||
int paymentTypeId;
|
||||
String paymentType;
|
||||
Date paymentDate;
|
||||
Double invoiceAmount;
|
||||
|
||||
public InvoicePayment(String invoiceNum, int invoicePaymentId, int paymentTypeId, String paymentType, Date paymentDate, Double invoiceAmount) {
|
||||
this.invoiceNum = invoiceNum;
|
||||
this.invoicePaymentId = invoicePaymentId;
|
||||
this.paymentTypeId = paymentTypeId;
|
||||
this.paymentType = paymentType;
|
||||
this.paymentDate = paymentDate;
|
||||
this.invoiceAmount = invoiceAmount;
|
||||
}
|
||||
|
||||
public String getInvoiceNum() {
|
||||
return invoiceNum;
|
||||
}
|
||||
|
||||
public void setInvoiceNum(String invoiceNum) {
|
||||
this.invoiceNum = invoiceNum;
|
||||
}
|
||||
|
||||
public int getInvoicePaymentId() {
|
||||
return invoicePaymentId;
|
||||
}
|
||||
|
||||
public void setInvoicePaymentId(int invoicePaymentId) {
|
||||
this.invoicePaymentId = invoicePaymentId;
|
||||
}
|
||||
|
||||
public int getPaymentTypeId() {
|
||||
return paymentTypeId;
|
||||
}
|
||||
|
||||
public void setPaymentTypeId(int paymentTypeId) {
|
||||
this.paymentTypeId = paymentTypeId;
|
||||
}
|
||||
|
||||
public String getPaymentType() {
|
||||
return paymentType;
|
||||
}
|
||||
|
||||
public void setPaymentType(String paymentType) {
|
||||
this.paymentType = paymentType;
|
||||
}
|
||||
|
||||
public Date getPaymentDate() {
|
||||
return paymentDate;
|
||||
}
|
||||
|
||||
public void setPaymentDate(Date paymentDate) {
|
||||
this.paymentDate = paymentDate;
|
||||
}
|
||||
|
||||
public Double getInvoiceAmount() {
|
||||
return invoiceAmount;
|
||||
}
|
||||
|
||||
public void setInvoiceAmount(Double invoiceAmount) {
|
||||
this.invoiceAmount = invoiceAmount;
|
||||
}
|
||||
}
|
||||
package com.astute.model;
|
||||
|
||||
import java.sql.Date;
|
||||
|
||||
public class InvoicePayment {
|
||||
String invoiceNum;
|
||||
int invoicePaymentId;
|
||||
int paymentTypeId;
|
||||
String paymentType;
|
||||
Date paymentDate;
|
||||
Double invoiceAmount;
|
||||
String checkTransactionNo;
|
||||
public InvoicePayment(String invoiceNum, int invoicePaymentId, int paymentTypeId, String paymentType, Date paymentDate, Double invoiceAmount, String checkTransactionNo) {
|
||||
this.invoiceNum = invoiceNum;
|
||||
this.invoicePaymentId = invoicePaymentId;
|
||||
this.paymentTypeId = paymentTypeId;
|
||||
this.paymentType = paymentType;
|
||||
this.paymentDate = paymentDate;
|
||||
this.invoiceAmount = invoiceAmount;
|
||||
this.checkTransactionNo = checkTransactionNo;
|
||||
}
|
||||
|
||||
public String getInvoiceNum() {
|
||||
return invoiceNum;
|
||||
}
|
||||
|
||||
public void setInvoiceNum(String invoiceNum) {
|
||||
this.invoiceNum = invoiceNum;
|
||||
}
|
||||
|
||||
public int getInvoicePaymentId() {
|
||||
return invoicePaymentId;
|
||||
}
|
||||
|
||||
public void setInvoicePaymentId(int invoicePaymentId) {
|
||||
this.invoicePaymentId = invoicePaymentId;
|
||||
}
|
||||
|
||||
public int getPaymentTypeId() {
|
||||
return paymentTypeId;
|
||||
}
|
||||
|
||||
public void setPaymentTypeId(int paymentTypeId) {
|
||||
this.paymentTypeId = paymentTypeId;
|
||||
}
|
||||
|
||||
public String getPaymentType() {
|
||||
return paymentType;
|
||||
}
|
||||
|
||||
public void setPaymentType(String paymentType) {
|
||||
this.paymentType = paymentType;
|
||||
}
|
||||
|
||||
public Date getPaymentDate() {
|
||||
return paymentDate;
|
||||
}
|
||||
|
||||
public void setPaymentDate(Date paymentDate) {
|
||||
this.paymentDate = paymentDate;
|
||||
}
|
||||
|
||||
public Double getInvoiceAmount() {
|
||||
return invoiceAmount;
|
||||
}
|
||||
|
||||
public void setInvoiceAmount(Double invoiceAmount) {
|
||||
this.invoiceAmount = invoiceAmount;
|
||||
}
|
||||
|
||||
public String getCheckTransactionNo() {
|
||||
return checkTransactionNo;
|
||||
}
|
||||
|
||||
public void setCheckTransactionNo(String checkTransactionNo) {
|
||||
this.checkTransactionNo = checkTransactionNo;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,72 +1,82 @@
|
|||
package com.astute.requests;
|
||||
|
||||
|
||||
public class InvoicePaymentRequest {
|
||||
String invoiceNum;
|
||||
int invoicePaymentId;
|
||||
int paymentTypeId;
|
||||
String paymentType;
|
||||
String paymentDate;
|
||||
Double invoiceAmount;
|
||||
|
||||
public InvoicePaymentRequest(String invoiceNum, int invoicePaymentId, int paymentTypeId, String paymentType, String paymentDate, Double invoiceAmount) {
|
||||
this.invoiceNum = invoiceNum;
|
||||
this.invoicePaymentId = invoicePaymentId;
|
||||
this.paymentTypeId = paymentTypeId;
|
||||
this.paymentType = paymentType;
|
||||
this.paymentDate = paymentDate;
|
||||
this.invoiceAmount = invoiceAmount;
|
||||
}
|
||||
|
||||
public InvoicePaymentRequest() {
|
||||
|
||||
}
|
||||
|
||||
public String getInvoiceNum() {
|
||||
return invoiceNum;
|
||||
}
|
||||
|
||||
public void setInvoiceNum(String invoiceNum) {
|
||||
this.invoiceNum = invoiceNum;
|
||||
}
|
||||
|
||||
public int getInvoicePaymentId() {
|
||||
return invoicePaymentId;
|
||||
}
|
||||
|
||||
public void setInvoicePaymentId(int invoicePaymentId) {
|
||||
this.invoicePaymentId = invoicePaymentId;
|
||||
}
|
||||
|
||||
public int getPaymentTypeId() {
|
||||
return paymentTypeId;
|
||||
}
|
||||
|
||||
public void setPaymentTypeId(int paymentTypeId) {
|
||||
this.paymentTypeId = paymentTypeId;
|
||||
}
|
||||
|
||||
public String getPaymentType() {
|
||||
return paymentType;
|
||||
}
|
||||
|
||||
public void setPaymentType(String paymentType) {
|
||||
this.paymentType = paymentType;
|
||||
}
|
||||
|
||||
public String getPaymentDate() {
|
||||
return paymentDate;
|
||||
}
|
||||
|
||||
public void setPaymentDate(String paymentDate) {
|
||||
this.paymentDate = paymentDate;
|
||||
}
|
||||
|
||||
public Double getInvoiceAmount() {
|
||||
return invoiceAmount;
|
||||
}
|
||||
|
||||
public void setInvoiceAmount(Double invoiceAmount) {
|
||||
this.invoiceAmount = invoiceAmount;
|
||||
}
|
||||
}
|
||||
package com.astute.requests;
|
||||
|
||||
|
||||
public class InvoicePaymentRequest {
|
||||
String invoiceNum;
|
||||
int invoicePaymentId;
|
||||
int paymentTypeId;
|
||||
String paymentType;
|
||||
String paymentDate;
|
||||
Double invoiceAmount;
|
||||
String checkTransactionNo;
|
||||
|
||||
public InvoicePaymentRequest(String invoiceNum, int invoicePaymentId, int paymentTypeId, String paymentType, String paymentDate, Double invoiceAmount, String checkTransactionNo) {
|
||||
this.invoiceNum = invoiceNum;
|
||||
this.invoicePaymentId = invoicePaymentId;
|
||||
this.paymentTypeId = paymentTypeId;
|
||||
this.paymentType = paymentType;
|
||||
this.paymentDate = paymentDate;
|
||||
this.invoiceAmount = invoiceAmount;
|
||||
this.checkTransactionNo = checkTransactionNo;
|
||||
}
|
||||
|
||||
public InvoicePaymentRequest() {
|
||||
|
||||
}
|
||||
|
||||
public String getInvoiceNum() {
|
||||
return invoiceNum;
|
||||
}
|
||||
|
||||
public void setInvoiceNum(String invoiceNum) {
|
||||
this.invoiceNum = invoiceNum;
|
||||
}
|
||||
|
||||
public int getInvoicePaymentId() {
|
||||
return invoicePaymentId;
|
||||
}
|
||||
|
||||
public void setInvoicePaymentId(int invoicePaymentId) {
|
||||
this.invoicePaymentId = invoicePaymentId;
|
||||
}
|
||||
|
||||
public int getPaymentTypeId() {
|
||||
return paymentTypeId;
|
||||
}
|
||||
|
||||
public void setPaymentTypeId(int paymentTypeId) {
|
||||
this.paymentTypeId = paymentTypeId;
|
||||
}
|
||||
|
||||
public String getPaymentType() {
|
||||
return paymentType;
|
||||
}
|
||||
|
||||
public void setPaymentType(String paymentType) {
|
||||
this.paymentType = paymentType;
|
||||
}
|
||||
|
||||
public String getPaymentDate() {
|
||||
return paymentDate;
|
||||
}
|
||||
|
||||
public void setPaymentDate(String paymentDate) {
|
||||
this.paymentDate = paymentDate;
|
||||
}
|
||||
|
||||
public Double getInvoiceAmount() {
|
||||
return invoiceAmount;
|
||||
}
|
||||
|
||||
public void setInvoiceAmount(Double invoiceAmount) {
|
||||
this.invoiceAmount = invoiceAmount;
|
||||
}
|
||||
|
||||
public String getCheckTransactionNo() {
|
||||
return checkTransactionNo;
|
||||
}
|
||||
|
||||
public void setCheckTransactionNo(String checkTransactionNo) {
|
||||
this.checkTransactionNo = checkTransactionNo;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,59 +1,59 @@
|
|||
package com.astute.resources;
|
||||
|
||||
import com.astute.exceptions.AstuteException;
|
||||
import com.astute.requests.InvoicePaymentRequest;
|
||||
import com.astute.response.ApiResponse;
|
||||
import com.astute.service.InvoicePaymentService;
|
||||
|
||||
import javax.ws.rs.*;
|
||||
import javax.ws.rs.core.MediaType;
|
||||
import javax.ws.rs.core.Response;
|
||||
import java.sql.Date;
|
||||
import java.text.ParseException;
|
||||
import java.text.SimpleDateFormat;
|
||||
|
||||
@Path("/invoicePayment")
|
||||
@Consumes(MediaType.APPLICATION_JSON)
|
||||
@Produces(MediaType.APPLICATION_JSON)
|
||||
public class InvoicePaymentResource {
|
||||
|
||||
private com.astute.service.InvoicePaymentService service = new InvoicePaymentService();
|
||||
|
||||
public InvoicePaymentResource() {
|
||||
}
|
||||
|
||||
@GET
|
||||
public Response getInvoicePayments(@QueryParam("invoiceNum") String invoiceNum)
|
||||
throws AstuteException {
|
||||
return new ApiResponse(service.getInvoicePayments(invoiceNum)).toResponse();
|
||||
}
|
||||
|
||||
@Path("/{invoiceNum}/{invoicePaymentId}")
|
||||
@PUT
|
||||
public Response updateInvoicePayment(InvoicePaymentRequest request, @PathParam("invoiceNum") String invoiceNum, @PathParam("invoicePaymentId") int invoicePaymentId)
|
||||
throws AstuteException, ParseException {
|
||||
|
||||
String dateStr = request.getPaymentDate();
|
||||
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
|
||||
Date date = new java.sql.Date(df.parse(dateStr).getTime());
|
||||
service.updateInvoicePayment(invoiceNum,invoicePaymentId, request.getInvoiceAmount(), date);
|
||||
return new ApiResponse(ApiResponse.UPDATE_ACCESS_SUCESS).toResponse();
|
||||
}
|
||||
|
||||
@POST
|
||||
public Response createInvoicePayment(InvoicePaymentRequest request)
|
||||
throws AstuteException, ParseException {
|
||||
String dateStr = request.getPaymentDate();
|
||||
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
|
||||
Date date = new java.sql.Date(df.parse(dateStr).getTime());
|
||||
service.createInvoicePayment(request.getInvoiceNum(), request.getPaymentTypeId(), request.getInvoiceAmount(),date);
|
||||
return new ApiResponse(ApiResponse.UPDATE_ACCESS_SUCESS).toResponse();
|
||||
}
|
||||
|
||||
@GET
|
||||
@Path("/paymentTypes")
|
||||
public Response getInvoicePaymentTypes() throws AstuteException {
|
||||
return new ApiResponse(service.getPaymentTypes()).toResponse();
|
||||
}
|
||||
|
||||
}
|
||||
package com.astute.resources;
|
||||
|
||||
import com.astute.exceptions.AstuteException;
|
||||
import com.astute.requests.InvoicePaymentRequest;
|
||||
import com.astute.response.ApiResponse;
|
||||
import com.astute.service.InvoicePaymentService;
|
||||
|
||||
import javax.ws.rs.*;
|
||||
import javax.ws.rs.core.MediaType;
|
||||
import javax.ws.rs.core.Response;
|
||||
import java.sql.Date;
|
||||
import java.text.ParseException;
|
||||
import java.text.SimpleDateFormat;
|
||||
|
||||
@Path("/invoicePayment")
|
||||
@Consumes(MediaType.APPLICATION_JSON)
|
||||
@Produces(MediaType.APPLICATION_JSON)
|
||||
public class InvoicePaymentResource {
|
||||
|
||||
private com.astute.service.InvoicePaymentService service = new InvoicePaymentService();
|
||||
|
||||
public InvoicePaymentResource() {
|
||||
}
|
||||
|
||||
@GET
|
||||
public Response getInvoicePayments(@QueryParam("invoiceNum") String invoiceNum)
|
||||
throws AstuteException {
|
||||
return new ApiResponse(service.getInvoicePayments(invoiceNum)).toResponse();
|
||||
}
|
||||
|
||||
@Path("/{invoiceNum}/{invoicePaymentId}")
|
||||
@PUT
|
||||
public Response updateInvoicePayment(InvoicePaymentRequest request, @PathParam("invoiceNum") String invoiceNum, @PathParam("invoicePaymentId") int invoicePaymentId, @PathParam("checkTransactionNo")String checkTransactionNo)
|
||||
throws AstuteException, ParseException {
|
||||
|
||||
String dateStr = request.getPaymentDate();
|
||||
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
|
||||
Date date = new java.sql.Date(df.parse(dateStr).getTime());
|
||||
service.updateInvoicePayment(invoiceNum,invoicePaymentId, request.getPaymentTypeId(), request.getInvoiceAmount(), date, request.getCheckTransactionNo());
|
||||
return new ApiResponse(ApiResponse.UPDATE_ACCESS_SUCESS).toResponse();
|
||||
}
|
||||
|
||||
@POST
|
||||
public Response createInvoicePayment(InvoicePaymentRequest request)
|
||||
throws AstuteException, ParseException {
|
||||
String dateStr = request.getPaymentDate();
|
||||
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
|
||||
Date date = new java.sql.Date(df.parse(dateStr).getTime());
|
||||
service.createInvoicePayment(request.getInvoiceNum(), request.getPaymentTypeId(), request.getInvoiceAmount(),date,request.getCheckTransactionNo());
|
||||
return new ApiResponse(ApiResponse.UPDATE_ACCESS_SUCESS).toResponse();
|
||||
}
|
||||
|
||||
@GET
|
||||
@Path("/paymentTypes")
|
||||
public Response getInvoicePaymentTypes() throws AstuteException {
|
||||
return new ApiResponse(service.getPaymentTypes()).toResponse();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1,36 +1,36 @@
|
|||
package com.astute.service;
|
||||
|
||||
import com.astute.exceptions.AstuteException;
|
||||
import com.astute.model.InvoicePayment;
|
||||
import com.astute.model.PaymentType;
|
||||
|
||||
import java.sql.Date;
|
||||
import java.util.List;
|
||||
|
||||
import static com.astute.dao.DAO.getDao;
|
||||
|
||||
public class InvoicePaymentService extends Service{
|
||||
public InvoicePaymentService(){
|
||||
super();
|
||||
}
|
||||
|
||||
public List<InvoicePayment> getInvoicePayments(String invoiceNum)
|
||||
throws AstuteException {
|
||||
return getDao().getInvoicePayments(invoiceNum);
|
||||
}
|
||||
|
||||
public void updateInvoicePayment(String invoiceNum, int invoicePaymentId, Double paymentAmount, Date paymentDate)
|
||||
throws AstuteException {
|
||||
getDao().updateInvoicePayment(invoiceNum, invoicePaymentId, paymentAmount, paymentDate);
|
||||
}
|
||||
|
||||
|
||||
public void createInvoicePayment(String invoiceNum, int invoicePaymentTypeId, Double paymentAmount, Date paymentDate)
|
||||
throws AstuteException {
|
||||
getDao().createInvoicePayment(invoiceNum, invoicePaymentTypeId, paymentAmount, paymentDate);
|
||||
}
|
||||
|
||||
public List<PaymentType> getPaymentTypes() throws AstuteException {
|
||||
return getDao().getPaymentTypes();
|
||||
}
|
||||
}
|
||||
package com.astute.service;
|
||||
|
||||
import com.astute.exceptions.AstuteException;
|
||||
import com.astute.model.InvoicePayment;
|
||||
import com.astute.model.PaymentType;
|
||||
|
||||
import java.sql.Date;
|
||||
import java.util.List;
|
||||
|
||||
import static com.astute.dao.DAO.getDao;
|
||||
|
||||
public class InvoicePaymentService extends Service{
|
||||
public InvoicePaymentService(){
|
||||
super();
|
||||
}
|
||||
|
||||
public List<InvoicePayment> getInvoicePayments(String invoiceNum)
|
||||
throws AstuteException {
|
||||
return getDao().getInvoicePayments(invoiceNum);
|
||||
}
|
||||
|
||||
public void updateInvoicePayment(String invoiceNum, int invoicePaymentId, int InvoicePaymentTypeId, Double paymentAmount, Date paymentDate, String checkTransactionNo)
|
||||
throws AstuteException {
|
||||
getDao().updateInvoicePayment(invoiceNum, invoicePaymentId, InvoicePaymentTypeId, paymentAmount, paymentDate, checkTransactionNo);
|
||||
}
|
||||
|
||||
|
||||
public void createInvoicePayment(String invoiceNum, int invoicePaymentTypeId, Double paymentAmount, Date paymentDate, String checkTransactionNo)
|
||||
throws AstuteException {
|
||||
getDao().createInvoicePayment(invoiceNum, invoicePaymentTypeId, paymentAmount, paymentDate, checkTransactionNo);
|
||||
}
|
||||
|
||||
public List<PaymentType> getPaymentTypes() throws AstuteException {
|
||||
return getDao().getPaymentTypes();
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user