mirror of
https://github.com/dyiop/astute.git
synced 2025-04-05 21:10:16 -04:00
663 lines
34 KiB
HTML
663 lines
34 KiB
HTML
<app-nav-bar [invoiceActive]="true"></app-nav-bar>
|
|
<h1 align="center">Invoices</h1>
|
|
<div class="container-fluid">
|
|
<!--Table-->
|
|
<div class="row">
|
|
<div class="col-12">
|
|
<ag-grid-angular
|
|
#agGrid
|
|
style="height: 500px;"
|
|
class="ag-theme-balham"
|
|
[gridOptions]="gridOptions"
|
|
[enableSorting]="true"
|
|
[enableFilter]="true"
|
|
[rowData]="source"
|
|
[columnDefs]="columnDefs"
|
|
rowSelection="single"
|
|
rowDeselection="true"
|
|
></ag-grid-angular>
|
|
</div>
|
|
</div>
|
|
|
|
<!--Buttons-->
|
|
<div class="row justify-content-center mt-2">
|
|
<div class="col-2">
|
|
<button class="btn btn-success" style="width: 100%" (click)="open(new,null,null)">
|
|
Add
|
|
</button>
|
|
</div>
|
|
<div class="col-2">
|
|
<button class="btn btn-info" style="width: 100%" (click)="open(edit,null,null)" [disabled]="!chosenInv">
|
|
Edit
|
|
</button>
|
|
</div>
|
|
<div class="col-2">
|
|
<button class="btn btn-primary" style="width: 100%" (click)="submitInvoice(chosenInv.invoiceNumber)" [disabled]="!(chosenInv && chosenInv.invoiceStatus === 1)">
|
|
Submit
|
|
</button>
|
|
</div>
|
|
<div class="col-2">
|
|
<button class="btn btn-danger" style="width: 100%" (click)="deleteInvoice(chosenInv.invoiceNumber)" [disabled]="!(chosenInv && chosenInv.invoiceStatus === 1)">
|
|
Delete
|
|
</button>
|
|
</div>
|
|
<div class="col-2">
|
|
<button class="btn btn-warning" style="width: 100%" (click)="voidInvoice(chosenInv.invoiceNumber)" [disabled]="!(chosenInv && chosenInv.invoiceStatus === 2)">
|
|
Void
|
|
</button>
|
|
</div>
|
|
<div class="col-2">
|
|
<!--<button class="btn btn-light" style="width: 100%" (click)="assignActity()" [disabled]="!chosenInv">-->
|
|
<button class="btn btn-light" style="width: 100%" (click)="printInvoice()" [disabled]="!(chosenInv)">
|
|
Print
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!--MODAL: edit Invoice-->
|
|
<app-modal-form [title]="'Edit Invoice'" #edit>
|
|
<!--General-->
|
|
<div class="modal-body" *ngIf="chosenInv">
|
|
<p class="h4 text-right">General</p>
|
|
<hr>
|
|
<table class="table table-borderless table-sm">
|
|
<tbody>
|
|
<tr>
|
|
<td style="width: 1%">
|
|
<span class="input-group-text">Customer</span>
|
|
</td>
|
|
<td>
|
|
<input type="text" class="form-control" [value]=chosenInv.customerId disabled>
|
|
<!--<select class="custom-select" (change)="customerDropdownChange(chosenInv.customerId)"-->
|
|
<!--#test>-->
|
|
<!--[value]="chosenInv.customerId"-->
|
|
<!--<option [value]="-1">Choose Customer...</option>-->
|
|
<!--<option *ngFor="let customer of customers; let i = index;" [value]="i">{{customer.customerName}}-->
|
|
<!--</option>-->
|
|
<!--</select>-->
|
|
</td>
|
|
<td style="width: 5%"></td>
|
|
<td style="width: 10%">
|
|
<span class="input-group-text">SO Number*</span>
|
|
</td>
|
|
<td>
|
|
<input type="text" class="form-control" [value]="chosenInv.poNum" #poNumIn disabled>
|
|
<!--<select class="custom-select" (change)="poDropdownChange(poNumIn.value)"-->
|
|
<!--[value]="chosenInv.poNum" #poNumIn disabled>-->
|
|
<!--<option>Choose Sales Order...</option>-->
|
|
<!--<option *ngFor="let po of correspondingPos;" [value]="po.ponum">{{po.ponum}}</option>-->
|
|
<!--</select>-->
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="2">
|
|
<p *ngIf="chosenInv.customerId" class="p-0 m-0 mt-2">
|
|
<!--To, {{correspondingCustomer[0].billToDept}}-->
|
|
</p>
|
|
</td>
|
|
<td></td>
|
|
<td>
|
|
<span class="input-group-text">Invoice Number*</span>
|
|
</td>
|
|
<td>
|
|
<input type="text" class="form-control" [value]="chosenInv.invoiceNumber" #inNumIn disabled>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="2">
|
|
<p *ngIf="chosenInv.customerId" class="p-0 m-0 mt-2">
|
|
<!--{{correspondingCustomer[0].add1}} {{correspondingCustomer[0].add2}}-->
|
|
</p>
|
|
</td>
|
|
<td></td>
|
|
<td>
|
|
<span class="input-group-text">Change Order Num</span>
|
|
</td>
|
|
<td>
|
|
<input type="text" class="form-control" [value]="chosenInv.changeOrderNum" #coNumIn>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="2">
|
|
<p *ngIf="chosenInv.customerId" class="p-0 m-0 mt-2">
|
|
<!--{{correspondingCustomer[0].city}} {{correspondingCustomer[0].state}} {{correspondingCustomer[0].zip}}{{(correspondingCustomer[0].ziplast4 == 0) ? '':'-' + correspondingCustomer[0].ziplast4}}-->
|
|
</p>
|
|
</td>
|
|
<td></td>
|
|
<td>
|
|
<span class="input-group-text">Payment Status*</span>
|
|
</td>
|
|
<td>
|
|
<input type="text" class="form-control" [value]=chosenInv.pmtStatusDesc disabled>
|
|
<!--<select class="custom-select" [value]="chosenInv.pmtStatus" #pmtStatusIn disabled>-->
|
|
<!--<option value="Outstanding">"Outstanding"</option>-->
|
|
<!--<option value="Paid">"Paid"</option>-->
|
|
<!--</select>-->
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
<!--<div class="input-group mb-3">-->
|
|
<!--<div class="input-group-prepend">-->
|
|
<!--<span class="input-group-text">Invoice Number*</span>-->
|
|
<!--</div>-->
|
|
<!--<input type="text" class="form-control" #inNumIn [value]="chosenInv.invoiceNumber">-->
|
|
<!--<div class="input-group-prepend">-->
|
|
<!--<span class="input-group-text">PO Number*</span>-->
|
|
<!--</div>-->
|
|
<!--<input type="text" class="form-control" [disabled]="true" #poNumIn [value]="chosenInv.poNum">-->
|
|
<!--<div class="input-group-prepend">-->
|
|
<!--<span class="input-group-text">Change Order Num</span>-->
|
|
<!--</div>-->
|
|
<!--<input type="text" class="form-control" #coNumIn [value]="chosenInv.changeOrderNum">-->
|
|
<!--</div>-->
|
|
|
|
<!--<div class="input-group mb-3">-->
|
|
<!--<div class="input-group-prepend">-->
|
|
<!--<span class="input-group-text">Payment Status*</span>-->
|
|
<!--</div>-->
|
|
<!--<select class="custom-select" [value]="chosenInv.pmtStatus" #pmtStatusIn>-->
|
|
<!--<option value=0>Outstanding</option>-->
|
|
<!--<option value=1>Paid</option>-->
|
|
<!--</select>-->
|
|
<!--</div>-->
|
|
</div>
|
|
|
|
<!--Detials-->
|
|
<div class="modal-body" *ngIf="chosenInv">
|
|
<p class="h4 text-right">Detail</p>
|
|
|
|
<table class="table">
|
|
<thead>
|
|
<tr>
|
|
<th scope="col" style="width: 50px">#</th>
|
|
<th scope="col">Description</th>
|
|
<th scope="col" style="width: 150px">Rate Type</th>
|
|
<th scope="col" style="width: 100px">Rate</th>
|
|
<th scope="col" style="width: 100px">Quantity</th>
|
|
</tr>
|
|
</thead>
|
|
<!--<tbody>-->
|
|
<tbody *ngFor="let inDet of selectedInDetails; let i = index">
|
|
<tr class="p-0 m-0">
|
|
<!--INV Detail Items: invoiceNum, lineItemNum, poLineItemNum, serviceTypeId, desc, qty, fee-->
|
|
<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="inDet.lineItemNum" disabled>
|
|
</td>
|
|
<td class="p-0 m-0"><textarea style="height: 36px" class="form-control text cell" [value]="inDet.desc"
|
|
(change)="onSelectedCellChange(i, 'desc', desc.value)" #desc [disabled]="chosenInv.invoiceStatus !== 1"></textarea>
|
|
<!--<input type="text" class="form-control cell" [value]="inDet.desc"-->
|
|
<!--(change)="onSelectedCellChange(i, 'desc', desc.value)" #desc>-->
|
|
</td>
|
|
<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="feeTypes[inDet.feeTypeId - 1]"
|
|
disabled></td>
|
|
<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="inDet.fee | currency" #fee [disabled]="chosenInv.invoiceStatus !== 1"
|
|
(change)="onSelectedCellChange(i, 'fee', fee.value.substr(1)); updateSelectedBillAmt()">
|
|
</td>
|
|
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="inDet.qty"
|
|
[step]="inDet.remainingQty / 100"
|
|
(change)="onSelectedCellChange(i, 'qty', qty.value); updateSelectedBillAmt()" #qty [disabled]="chosenInv.invoiceStatus !== 1">
|
|
</td>
|
|
</tr>
|
|
<tr class="p-0 m-0" *ngIf="inDet.poLineItemNum != -1">
|
|
<th class="align-content-center">
|
|
<p>{{getPerc(qty.value, inDet.remainingQty)}}%</p>
|
|
</th>
|
|
<td colspan="4">
|
|
<div class="progress" style="height: 25px;">
|
|
<div class="progress-bar bg-success" role="progressbar"
|
|
[ngStyle]="{'width': getPerc(qty.value, inDet.remainingQty) + '%'}">
|
|
{{qty.value}}
|
|
</div>
|
|
<div class="progress-bar bg-danger" role="progressbar"
|
|
[ngStyle]="{'width': (100 - getPerc(qty.value, inDet.remainingQty)) + '%'}">
|
|
{{inDet.remainingQty - (qty.value)}}
|
|
</div>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
<!--<tr class="p-0 m-0">-->
|
|
<!--<!–INV Detail Items: invoiceNum, lineItemNum, poLineItemNum, serviceTypeId, desc, qty, fee–>-->
|
|
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="inDet.lineItemNum" disabled>-->
|
|
<!--</td>-->
|
|
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="inDet.desc"-->
|
|
<!--(change)="onNewCellChange(i, 'desc', desc.value)" #desc></td>-->
|
|
<!--<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="feeTypes[inDet.feeTypeId - 1]"-->
|
|
<!--disabled></td>-->
|
|
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="inDet.fee"-->
|
|
<!--(change)="onNewCellChange(i, 'fee', fee.value); updateNewBillAmt();" #fee>-->
|
|
<!--</td>-->
|
|
<!--<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="inDet.qty"-->
|
|
<!--(change)="onNewCellChange(i, 'qty', qty.value); updateNewBillAmt();" #qty>-->
|
|
<!--</td>-->
|
|
<!--</tr>-->
|
|
<!--<tr class="p-0 m-0">-->
|
|
<!--<th class="align-content-center">-->
|
|
<!--<p>{{getPerc(fee.value * qty.value, inDet.remainingQty)}}%</p>-->
|
|
<!--</th>-->
|
|
<!--<td colspan="4">-->
|
|
<!--<div class="progress" style="height: 25px;">-->
|
|
<!--<div class="progress-bar bg-success" role="progressbar"-->
|
|
<!--[ngStyle]="{'width': getPerc(fee.value * qty.value, inDet.remainingQty) + '%'}">-->
|
|
<!--${{fee.value * qty.value}}-->
|
|
<!--</div>-->
|
|
<!--<div class="progress-bar bg-danger" role="progressbar"-->
|
|
<!--[ngStyle]="{'width': (100 - getPerc(fee.value * qty.value, inDet.remainingQty)) + '%'}">-->
|
|
<!--${{inDet.remainingQty - (fee.value * qty.value)}}-->
|
|
<!--</div>-->
|
|
<!--</div>-->
|
|
<!--</td>-->
|
|
<!--</tr>-->
|
|
<!--<tr class="p-0 m-0" *ngIf="inDet.poLineItemNum !== -1">-->
|
|
<!--<th class="align-content-center">-->
|
|
<!--<p>{{getPerc(qty.value, inDet.remainingQty)}}%</p>-->
|
|
<!--</th>-->
|
|
<!--<td colspan="5">-->
|
|
<!--<div class="progress" style="height: 25px;">-->
|
|
<!--<div class="progress-bar bg-success" role="progressbar"-->
|
|
<!--[ngStyle]="{'width': getPerc(qty.value, inDet.remainingQty) + '%'}">-->
|
|
<!--Qty - {{(qty.value)}} / Amount - {{(qty.value * inDet.fee) | currency}}-->
|
|
<!--</div>-->
|
|
<!--<div class="progress-bar bg-danger" role="progressbar"-->
|
|
<!--[ngStyle]="{'width': (100 - getPerc(qty.value, inDet.remainingQty)) + '%'}">-->
|
|
<!--Qty - {{(inDet.remainingQty - qty.value)}} / Amount - {{(inDet.remainingQty - qty.value) * inDet.fee | currency}}-->
|
|
<!--</div>-->
|
|
<!--</div>-->
|
|
<!--</td>-->
|
|
<!--</tr>-->
|
|
</tbody>
|
|
<tbody>
|
|
<!--<tr >-->
|
|
<!--<td colspan="5" >-->
|
|
<!--<p *ngIf="chosenInv.invoiceStatus == 1">-->
|
|
<!--<select class="custom-select"-->
|
|
<!--(change)="pushOntoSelectedDetail(inNumIn.value, newInDetails.length + 1, selectedPODetails[poDetSelec.value].lineItemNo,-->
|
|
<!--selectedPODetails[poDetSelec.value].feeTypeId,-->
|
|
<!--selectedPODetails[poDetSelec.value].serviceDesc, 0, selectedPODetails[poDetSelec.value].fee)"-->
|
|
<!--[disabled]="!selectedPODetails.length && chosenInv.invoiceStatus !== 1"-->
|
|
<!--#poDetSelec>-->
|
|
<!--<option>Add new line item...</option>-->
|
|
<!--<option *ngFor="let po of selectedPODetails; let i = index;" [value]="i">{{po.serviceDesc}}-->
|
|
<!--</option>-->
|
|
<!--<option [value]="-1">Out of Pocket Expenses</option>-->
|
|
<!--</select>-->
|
|
<!--</p>-->
|
|
<!--</td>-->
|
|
<!--</tr>-->
|
|
</tbody>
|
|
</table>
|
|
<table class="table table-borderless table-sm">
|
|
<tbody>
|
|
<tr>
|
|
<td style="width: 40%" class="text-right"><b>Original Contract Amount</b></td>
|
|
<td style="width: 10%" class="text-right">
|
|
<div *ngIf="selectedPO">{{selectedPO.contractAmt | currency}}</div>
|
|
</td>
|
|
<td style="width: 30%" class="text-right"> </td>
|
|
<td style="width: 20%" class="text-right"> </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-right"><b>Net Changes by Change Orders</b></td>
|
|
<td class="text-right">
|
|
<div *ngIf="selectedPO">{{0 | currency}}</div>
|
|
</td>
|
|
<td class="text-right"> </td>
|
|
<td class="text-right"> </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-right"><b>Total Contract Amount</b></td>
|
|
<td class="text-right"><div *ngIf="selectedPO">{{selectedPO.contractAmt | currency}}</div></td>
|
|
<td class="text-right"> </td>
|
|
<td class="text-right"> </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-right"><b>Previously Billed</b></td>
|
|
<td class="text-right"><div *ngIf="selectedPO">{{selectedPO.previouslyBilledAmount | currency}}</div></td>
|
|
<td class="text-right"> </td>
|
|
<td class="text-right"> </td>
|
|
</tr>
|
|
<!--<tr>-->
|
|
<!--<td class="text-right"><b>Amount This Invoice</b></td>-->
|
|
<!--<td>{{newBillAmt}}</td>-->
|
|
<!--<td class="text-right"> </td>-->
|
|
<!--<td> </td>-->
|
|
<!--</tr>-->
|
|
<tr>
|
|
<td class="text-right"><b>Balance to be Billed</b></td>
|
|
<td class="text-right"><div *ngIf="selectedPO">{{(selectedPO.contractAmt - selectedPO.previouslyBilledAmount - selectedBillAmt) | currency}}</div></td>
|
|
<!--<td>-->
|
|
<!--<div class="input-group mb-3">-->
|
|
<!--<div class="input-group-prepend">-->
|
|
<!--<span class="input-group-text"><b>Total</b></span>-->
|
|
<!--<span class="input-group-text">$</span>-->
|
|
<!--</div>-->
|
|
<!--<input type="number" class="form-control" [value]="newBillAmt" #billAmtIn disabled>-->
|
|
<!--<div class="input-group-append">-->
|
|
<!--<span class="input-group-text">.00</span>-->
|
|
<!--</div>-->
|
|
<!--</div>-->
|
|
<!--</td>-->
|
|
<td class="text-right"><b>Total due this invoice</b></td>
|
|
<td>{{selectedBillAmt | currency}}</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
<!--<div class="input-group mb-3">-->
|
|
<!--<div class="input-group-prepend">-->
|
|
<!--<span class="input-group-text">Bill Amount*</span>-->
|
|
<!--<span class="input-group-text">$</span>-->
|
|
<!--</div>-->
|
|
<!--<input type="number" class="form-control" [value]="selectedBillAmt" #billAmtIn>-->
|
|
<!--<div class="input-group-append">-->
|
|
<!--<span class="input-group-text">.00</span>-->
|
|
<!--</div>-->
|
|
<!--</div>-->
|
|
</div>
|
|
|
|
<!--Invoice Footer-->
|
|
<div class="modal-body" *ngIf="chosenInv">
|
|
<hr>
|
|
<div class="input-group mb-3">
|
|
<div class="input-group-prepend">
|
|
<span class="input-group-text">Special Notes*</span>
|
|
</div>
|
|
<textarea class="form-control" [value]="chosenInv.specialNotes" #notesIn [disabled]="chosenInv.invoiceStatus !== 1"></textarea>
|
|
</div>
|
|
|
|
<div class="input-group mb-3">
|
|
<div class="input-group-prepend">
|
|
<span class="input-group-text">Certification*</span>
|
|
</div>
|
|
<textarea class="form-control" [value]="chosenInv.certification" #certIn [disabled]="chosenInv.invoiceStatus !== 1"></textarea>
|
|
</div>
|
|
</div>
|
|
|
|
<!--Select Invoice Message-->
|
|
<div class="modal-body" *ngIf="!chosenInv">
|
|
<p>Choose an Invoice First!</p>
|
|
</div>
|
|
|
|
<!--Modal Footer-->
|
|
<div class="modal-footer" >
|
|
<p *ngIf="chosenInv.invoiceStatus == 1">
|
|
<button type="button" class="btn btn-success"
|
|
(click)="editInvoice(inNumIn.value, poNumIn.value, coNumIn.value, pmtStatusIn.value, notesIn.value, certIn.value)">
|
|
<!--[disabled]="(chosenInv.invoiceStatus !== 1)">-->
|
|
Confirm
|
|
</button>
|
|
</p>
|
|
<p>
|
|
<button type="button" class="btn btn-danger" (click)="close(edit)">Cancel</button>
|
|
</p>
|
|
</div>
|
|
</app-modal-form>
|
|
|
|
<!--MODAL: new invoice-->
|
|
<app-modal-form [title]="'New Invoice'" #new>
|
|
<!--<form>-->
|
|
<!--General-->
|
|
<div class="modal-body">
|
|
<p class="h4 text-right">General</p>
|
|
<hr>
|
|
<table class="table table-borderless table-sm">
|
|
<tbody>
|
|
<tr>
|
|
<td style="width: 1%">
|
|
<span class="input-group-text">Customer </span>
|
|
</td>
|
|
<td>
|
|
<select class="custom-select" (change)="customerDropdownChange(customerSelec.value)" #customerSelec>
|
|
<option [value]="-1">Choose Customer...</option>
|
|
<option *ngFor="let customer of customers; let i = index;" [value]="i">{{customer.customerName}}
|
|
</option>
|
|
</select>
|
|
</td>
|
|
<td style="width: 5%"></td>
|
|
<td style="width: 10%">
|
|
<span class="input-group-text">SO Number*</span>
|
|
</td>
|
|
<td>
|
|
<select class="custom-select" (change)="poDropdownChange(poNumIn.value)"
|
|
[disabled]="!correspondingPos.length" #poNumIn>
|
|
<option>Choose Sales Order...</option>
|
|
<option *ngFor="let po of correspondingPos;" [value]="po.ponum">{{po.ponum}}</option>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
<!--add1, add2, billToDept, city, customerId, customerName, email, fax, phone, state, zip, ziplast4-->
|
|
<tr>
|
|
<td colspan="2">{{customerSelec.value}}
|
|
<p *ngIf="customerSelec.value >= 0" class="p-0 m-0 mt-2">
|
|
{{customers[customerSelec.value].billToDept}}
|
|
</p>
|
|
</td>
|
|
<td></td>
|
|
<td>
|
|
<span class="input-group-text">Invoice Number*</span>
|
|
</td>
|
|
<td>
|
|
<input type="text" class="form-control" [value]="generatedInvoiceNumber" #inNumIn>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="2">
|
|
<p *ngIf="customerSelec.value >= 0" class="p-0 m-0 mt-2">
|
|
{{customers[customerSelec.value].add1}} {{customers[customerSelec.value].add2}}
|
|
</p>
|
|
</td>
|
|
<td></td>
|
|
<td>
|
|
<span class="input-group-text">Change Order Num</span>
|
|
</td>
|
|
<td>
|
|
<input type="text" class="form-control" #coNumIn>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td colspan="2">
|
|
<p *ngIf="customerSelec.value >= 0" class="p-0 m-0 mt-2">
|
|
{{customers[customerSelec.value].city}} {{customers[customerSelec.value].state}} {{customers[customerSelec.value].zip}}{{(customers[customerSelec.value].ziplast4 == 0) ? '':'-' + customers[customerSelec.value].ziplast4}}
|
|
</p>
|
|
</td>
|
|
<td></td>
|
|
<td>
|
|
<span class="input-group-text">Payment Status*</span>
|
|
</td>
|
|
<td>
|
|
<!--<input type="text" value="Outstanding" class="form-control" #pmtStatusIn disabled>-->
|
|
|
|
<select class="custom-select" #pmtStatusIn disabled>
|
|
<option value="1">Outstanding</option>
|
|
<!--<!–<option value=2>Paid</option>–>-->
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
|
|
<!--Detail-->
|
|
<div class="modal-body">
|
|
<p class="h4 text-right">Detail</p>
|
|
<table class="table">
|
|
<thead>
|
|
<tr>
|
|
<th scope="col" style="width: 30px"></th>
|
|
<th scope="col" style="width: 50px">#</th>
|
|
<th scope="col">Description</th>
|
|
<th scope="col" style="width: 150px">Rate Type</th>
|
|
<th scope="col" style="width: 100px">Rate</th>
|
|
<th scope="col" style="width: 100px">Quantity</th>
|
|
</tr>
|
|
</thead>
|
|
<!--<tbody>-->
|
|
<tbody *ngFor="let inDet of newInDetails; let i = index">
|
|
<tr class="p-0 m-0">
|
|
<!--INV Detail Items: invoiceNum, lineItemNum, poLineItemNum, serviceTypeId, desc, qty, fee-->
|
|
<td class="p-0 m-0">
|
|
<button class="btn btn-outline-danger w-100" (click)="newInDetails.splice(0, 1)">-</button>
|
|
</td>
|
|
<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="inDet.lineItemNum" disabled>
|
|
</td>
|
|
<td class="p-0 m-0"><textarea style="height: 36px" class="form-control cell" [value]="inDet.desc"
|
|
(change)="onNewCellChange(i, 'desc', desc.value)" #desc></textarea>
|
|
<!--<input type="text" class="form-control cell" [value]="inDet.desc"-->
|
|
<!--(change)="onNewCellChange(i, 'desc', desc.value)" #desc>-->
|
|
</td>
|
|
<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="feeTypes[inDet.feeTypeId - 1]"
|
|
disabled></td>
|
|
<td class="p-0 m-0"><input type="text" class="form-control cell" [value]="inDet.fee | currency" #fee [disabled] = "poDetails[poDetSelec.value].lineItemNo!==-1"
|
|
(change)="onNewCellChange(i, 'fee', fee.value.substr(1)); updateNewBillAmt();">
|
|
</td>
|
|
<td class="p-0 m-0"><input type="number" class="form-control cell" [value]="inDet.qty"
|
|
[step]="inDet.remainingQty / 100"
|
|
(change)="onNewCellChange(i, 'qty', qty.value); updateNewBillAmt();" #qty>
|
|
</td>
|
|
</tr>
|
|
<tr class="p-0 m-0" *ngIf="inDet.poLineItemNum !== -1">
|
|
<th class="align-content-center">
|
|
<p>{{getPerc(qty.value, inDet.remainingQty)}}%</p>
|
|
</th>
|
|
<td colspan="5">
|
|
<div class="progress" style="height: 25px;">
|
|
<div class="progress-bar bg-success" role="progressbar"
|
|
[ngStyle]="{'width': getPerc(qty.value, inDet.remainingQty) + '%'}">
|
|
Qty - {{(qty.value)}} / Amount - {{(qty.value * inDet.fee) | currency}}
|
|
</div>
|
|
<div class="progress-bar bg-danger" role="progressbar"
|
|
[ngStyle]="{'width': (100 - getPerc(qty.value, inDet.remainingQty)) + '%'}">
|
|
Qty - {{(inDet.remainingQty - qty.value)}} / Amount - {{(inDet.remainingQty - qty.value) * inDet.fee | currency}}
|
|
</div>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
<tr class="p-0 m-0" *ngIf="inDet.poLineItemNum == -1">
|
|
<th class="align-content-center">
|
|
<p>{{getPerc(qty.value, inDet.remainingQty)}}%</p>
|
|
</th>
|
|
</tr>
|
|
</tbody>
|
|
<tbody>
|
|
<tr>
|
|
<td colspan="6">
|
|
<select class="custom-select"
|
|
(change)="pushOntoNewDetail(inNumIn.value, newInDetails.length + 1, poDetails[poDetSelec.value].lineItemNo,
|
|
poDetails[poDetSelec.value].feeTypeId, poDetails[poDetSelec.value].serviceTypeId,
|
|
poDetails[poDetSelec.value].serviceDesc, 0, poDetails[poDetSelec.value].fee, poDetails[poDetSelec.value].remainingQty,
|
|
poNumIn.value)"
|
|
[disabled]="!poDetails.length"
|
|
#poDetSelec>
|
|
<option>Add line item...</option>
|
|
<option *ngFor="let po of poDetails; let i = index;" [value]="i">{{po.serviceDesc}}</option>
|
|
<option [value]="-1">Out of Pocket Expenses</option>
|
|
</select>
|
|
</td>
|
|
</tr>
|
|
|
|
<!--<tr>-->
|
|
<!--<td colspan="6">-->
|
|
<!--<select class="custom-select"-->
|
|
<!--(change)="pushOntoNewDetail(inNumIn.value, newInDetails.length + 1, poDetails[poDetSelec.value].lineItemNo,-->
|
|
<!--poDetails[poDetSelec.value].feeTypeId, poDetails[poDetSelec.value].serviceTypeId,-->
|
|
<!--poDetails[poDetSelec.value].serviceDesc, 0, poDetails[poDetSelec.value].fee, poDetails[poDetSelec.value].remainingQty,-->
|
|
<!--poNumIn.value)"-->
|
|
<!--[disabled]="!poDetails.length"-->
|
|
<!--#poDetSelec>-->
|
|
<!--<option>Add line item...</option>-->
|
|
<!--<option *ngFor="let po of poDetails; let i = index;" [value]="i">{{po.serviceDesc}}</option>-->
|
|
<!--<option [value]="-1">Out of Pocket Expenses</option>-->
|
|
<!--</select>-->
|
|
<!--</td>-->
|
|
<!--</tr>-->
|
|
</tbody>
|
|
</table>
|
|
|
|
<table class="table table-borderless table-sm">
|
|
<tbody>
|
|
<tr>
|
|
<td class="text-right" style="width: 40%" class="text-right"><b>Original Contract Amount</b></td>
|
|
<td class="text-right" style="width: 10%">
|
|
<div *ngIf="chosenPo">{{chosenPo.contractAmt | currency}}</div>
|
|
</td>
|
|
<td class="text-right" style="width: 30%" class="text-right"> </td>
|
|
<td class="text-right" style="width: 20%" > </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-right"><b>Net Changes by Change Orders</b></td>
|
|
<td class="text-right"><div *ngIf="chosenPo">{{0 | currency}}</div></td>
|
|
<td class="text-right"> </td>
|
|
<td class="text-right"> </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-right"><b>Total Contract Amount</b></td>
|
|
<td class="text-right"><div *ngIf="chosenPo">{{chosenPo.contractAmt | currency}}</div></td>
|
|
<td class="text-right"> </td>
|
|
<td class="text-right"> </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="text-right"><b>Previously Billed</b></td>
|
|
<td class="text-right"><div *ngIf="chosenPo">{{chosenPo.previouslyBilledAmount | currency}}</div></td>
|
|
<td class="text-right"> </td>
|
|
<td class="text-right"> </td>
|
|
</tr>
|
|
<!--<tr>-->
|
|
<!--<td class="text-right"><b>Amount This Invoice</b></td>-->
|
|
<!--<td>{{newBillAmt}}</td>-->
|
|
<!--<td class="text-right"> </td>-->
|
|
<!--<td> </td>-->
|
|
<!--</tr>-->
|
|
<tr>
|
|
<td class="text-right"><b>Balance to be Billed</b></td>
|
|
<td class="text-right"><div *ngIf="chosenPo">{{(chosenPo.contractAmt - chosenPo.previouslyBilledAmount - newBillAmt) | currency}}</div></td>
|
|
<!--<td>-->
|
|
<!--<div class="input-group mb-3">-->
|
|
<!--<div class="input-group-prepend">-->
|
|
<!--<span class="input-group-text"><b>Total</b></span>-->
|
|
<!--<span class="input-group-text">$</span>-->
|
|
<!--</div>-->
|
|
<!--<input type="number" class="form-control" [value]="newBillAmt" #billAmtIn disabled>-->
|
|
<!--<div class="input-group-append">-->
|
|
<!--<span class="input-group-text">.00</span>-->
|
|
<!--</div>-->
|
|
<!--</div>-->
|
|
<!--</td>-->
|
|
<td class="text-right"><b>Total due this invoice</b></td>
|
|
<td>{{newBillAmt | currency}}</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
|
|
<!--Invoice Footer-->
|
|
<div class="modal-body">
|
|
<hr>
|
|
<div class="input-group mb-3">
|
|
<div class="input-group-prepend">
|
|
<span class="input-group-text">Notes:</span>
|
|
</div>
|
|
<textarea class="form-control" #notesIn></textarea>
|
|
</div>
|
|
|
|
<div class="input-group mb-3">
|
|
<div class="input-group-prepend">
|
|
<span class="input-group-text">Certification:</span>
|
|
</div>
|
|
<textarea class="form-control"
|
|
[value]="'Certified that the above items and rates are in accordance with the contractual agreement as verified by the undersigned'"
|
|
#certIn>
|
|
</textarea>
|
|
</div>
|
|
</div>
|
|
|
|
<!--Modal Footer-->
|
|
<div class="modal-footer">
|
|
<button type="button" class="btn btn-success"
|
|
(click)="addInvoice(inNumIn.value, poNumIn.value, coNumIn.value, pmtStatusIn.value, newBillAmt, notesIn.value, certIn.value, 1, new)"
|
|
[disabled]="!(inNumIn.value && poNumIn.value && newBillAmt && certIn.value)">
|
|
Confirm
|
|
</button>
|
|
<button type="reset" class="btn btn-danger" (click)="close(new)">Cancel</button>
|
|
</div>
|
|
<!--</form>-->
|
|
</app-modal-form>
|