301 lines
12 KiB
HTML
301 lines
12 KiB
HTML
<vn-crud-model auto-load="false"
|
|
vn-id="model"
|
|
url="/api/Tickets/{{$ctrl.$stateParams.id}}/getSales"
|
|
data="$ctrl.sales">
|
|
</vn-crud-model>
|
|
<vn-vertical>
|
|
<vn-card pad-large>
|
|
<vn-vertical>
|
|
<vn-horizontal class="header">
|
|
<vn-tool-bar margin-medium-bottom>
|
|
<vn-button
|
|
disabled="!$ctrl.isEditable"
|
|
label="Ok"
|
|
ng-click="$ctrl.onStateOkClick()"
|
|
vn-tooltip="Change ticket state to 'Ok'">
|
|
</vn-button>
|
|
<vn-button-menu
|
|
disabled="!$ctrl.isEditable"
|
|
label="State"
|
|
url="/ticket/api/States/alertLevelIs0"
|
|
on-change="$ctrl.onStateChange(value)">
|
|
</vn-button-menu>
|
|
<vn-button-menu
|
|
ng-show="$ctrl.isChecked"
|
|
vn-id="more-button"
|
|
label="More"
|
|
show-filter="false"
|
|
value-field="callback"
|
|
translate-fields="['name']"
|
|
on-change="$ctrl.onMoreChange(value)"
|
|
on-open="$ctrl.onMoreOpen()">
|
|
</vn-button-menu>
|
|
<vn-button
|
|
disabled="!$ctrl.isChecked || !$ctrl.isEditable"
|
|
ng-click="$ctrl.showRemoveLinesDialog()"
|
|
vn-tooltip="Remove lines"
|
|
tooltip-position="up"
|
|
icon="delete">
|
|
</vn-button>
|
|
<vn-button
|
|
disabled="!$ctrl.isChecked || !$ctrl.isEditable"
|
|
ng-click="$ctrl.showTransferPopover($event);"
|
|
vn-tooltip="Transfer lines"
|
|
tooltip-position="right"
|
|
icon="call_split">
|
|
</vn-button>
|
|
</vn-tool-bar>
|
|
<vn-one class="taxes" ng-if="$ctrl.sales.length > 0">
|
|
<p><vn-label translate>Subtotal</vn-label> {{$ctrl.subtotal | currency: 'EUR':2}}</p>
|
|
<p><vn-label translate>VAT</vn-label> {{$ctrl.VAT | currency: 'EUR':2}}</p>
|
|
<p><vn-label><strong>Total</strong></vn-label> <strong>{{$ctrl.total | currency: 'EUR':2}}</strong></p>
|
|
</vn-one>
|
|
</vn-horizontal>
|
|
<vn-table model="model">
|
|
<vn-thead>
|
|
<vn-tr>
|
|
<vn-th shrink>
|
|
<vn-multi-check
|
|
data="$ctrl.sales">
|
|
</vn-multi-check>
|
|
</vn-th>
|
|
<vn-th shrink></vn-th>
|
|
<vn-th shrink></vn-th>
|
|
<vn-th number>Id</vn-th>
|
|
<vn-th>Quantity</vn-th>
|
|
<vn-th>Item</vn-th>
|
|
<vn-th number>Price</vn-th>
|
|
<vn-th number>Disc</vn-th>
|
|
<vn-th number>Amount</vn-th>
|
|
</vn-tr>
|
|
</vn-thead>
|
|
<vn-tbody>
|
|
<vn-tr ng-repeat="sale in $ctrl.sales">
|
|
<vn-td shrink>
|
|
<vn-check
|
|
field="sale.checked">
|
|
</vn-check>
|
|
</vn-td>
|
|
<vn-td shrink>
|
|
<a ui-sref="claim.card.basicData({id: sale.claim.claimFk})">
|
|
<vn-icon
|
|
ng-show="sale.claim.claimFk"
|
|
icon="icon-claims"
|
|
vn-tooltip="{{::$ctrl.$translate.instant('Claim')}}: {{::sale.claim.claimFk}}">
|
|
</vn-icon>
|
|
</a>
|
|
<vn-icon
|
|
ng-show="sale.visible || sale.available"
|
|
color-main
|
|
icon="warning"
|
|
vn-tooltip="Visible: {{::sale.visible || 0}} <br> {{::$ctrl.$translate.instant('Available')}}: {{::sale.available || 0}}">
|
|
</vn-icon>
|
|
<vn-icon ng-show="sale.reserved"
|
|
icon="icon-reserve"
|
|
vn-tooltip="{{::$ctrl.$translate.instant('Reserved')}}"></vn-icon>
|
|
</vn-td>
|
|
<vn-td shrink>
|
|
<img
|
|
ng-src="{{::$ctrl.imagesPath}}/50x50/{{::sale.image}}"
|
|
zoom-image="{{::$ctrl.imagesPath}}/1600x900/{{::sale.image}}"
|
|
on-error-src/>
|
|
</vn-td>
|
|
<vn-td number>
|
|
<span
|
|
ng-click="$ctrl.showDescriptor($event, sale.itemFk)"
|
|
class="link">
|
|
{{::sale.itemFk | zeroFill:6}}
|
|
</span>
|
|
</vn-td>
|
|
<vn-td-editable editable="!$ctrl.isEditable">
|
|
<text>{{sale.quantity}}</text>
|
|
<field>
|
|
<vn-textfield
|
|
model="sale.quantity"
|
|
on-change="$ctrl.updateQuantity(sale.id, sale.quantity)"
|
|
type="text">
|
|
</vn-textfield>
|
|
</field>
|
|
</vn-td-editable>
|
|
<vn-td expand>
|
|
<vn-fetched-tags
|
|
max-length="6"
|
|
item="::sale.tags"
|
|
title="::sale.concept">
|
|
</vn-fetched-tags>
|
|
</vn-td>
|
|
<vn-td number ng-if="$ctrl.isEditable">
|
|
<span class="link"
|
|
vn-tooltip="Edit price"
|
|
ng-click="$ctrl.showEditPricePopover($event, sale)">
|
|
{{sale.price | currency: 'EUR':2}}
|
|
</span>
|
|
</vn-td>
|
|
<vn-td number ng-if="!$ctrl.isEditable">
|
|
{{sale.price | currency: 'EUR':2}}
|
|
</vn-td>
|
|
<vn-td number ng-if="$ctrl.isEditable">
|
|
<span class="link"
|
|
vn-tooltip="Edit discount"
|
|
ng-click="$ctrl.showEditPopover($event, sale)">
|
|
{{sale.discount}} %
|
|
</span>
|
|
</vn-td>
|
|
<vn-td number
|
|
ng-if="!$ctrl.isEditable">
|
|
{{sale.discount}} %
|
|
</vn-td>
|
|
<vn-td number>
|
|
{{$ctrl.getSaleTotal(sale) | currency: 'EUR':2}}
|
|
</vn-td>
|
|
</vn-tr>
|
|
</vn-tbody>
|
|
</vn-table>
|
|
</vn-vertical>
|
|
</vn-card>
|
|
<vn-item-descriptor-popover vn-id="descriptor"
|
|
quicklinks="$ctrl.quicklinks">
|
|
</vn-item-descriptor-popover>
|
|
|
|
<!-- Edit Price Popover -->
|
|
<vn-popover
|
|
class="edit dialog-summary"
|
|
vn-id="edit-price-popover"
|
|
on-open="$ctrl.getManaSalespersonMana()"
|
|
on-close="$ctrl.mana = null">
|
|
<vn-spinner
|
|
ng-if="$ctrl.mana == null"
|
|
style="padding: 1em;"
|
|
enable="true">
|
|
</vn-spinner>
|
|
<div ng-if="$ctrl.mana != null">
|
|
<vn-horizontal pad-medium class="header">
|
|
<h5>MANÁ: {{$ctrl.mana | currency: 'EUR':0}}</h5>
|
|
</vn-horizontal>
|
|
<div pad-medium>
|
|
<vn-textfield
|
|
vn-focus
|
|
label="Price"
|
|
model="$ctrl.editedPrice"
|
|
type="text"
|
|
on-change="$ctrl.updatePrice()">
|
|
<t-right-icons>
|
|
<span class="filter">€</span>
|
|
</t-right-icons>
|
|
</vn-textfield>
|
|
<div class="simulator">
|
|
<p class="simulatorTitle" translate>New price</p>
|
|
<p>{{($ctrl.sale.quantity * $ctrl.editedPrice)
|
|
- (($ctrl.sale.discount * ($ctrl.sale.quantity * $ctrl.editedPrice))/100)
|
|
| currency: 'EUR':2}}</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</vn-popover>
|
|
|
|
<!-- Edit Popover -->
|
|
<vn-popover
|
|
class="edit dialog-summary"
|
|
vn-id="edit-popover"
|
|
on-open="$ctrl.getManaSalespersonMana()"
|
|
on-close="$ctrl.mana = null">
|
|
<vn-spinner
|
|
ng-if="$ctrl.mana == null"
|
|
style="padding: 1em;"
|
|
enable="true">
|
|
</vn-spinner>
|
|
<vn-ticket-sale-edit-discount
|
|
ng-if="$ctrl.mana != null"
|
|
mana="$ctrl.mana"
|
|
bulk="false"
|
|
edit="$ctrl.edit"
|
|
on-hide="$ctrl.hideEditPopover()">
|
|
</vn-ticket-sale-edit-discount>
|
|
</vn-popover>
|
|
|
|
<!-- Edit Dialog -->
|
|
<vn-dialog
|
|
vn-id="editDialog"
|
|
class="edit"
|
|
on-open="$ctrl.getManaSalespersonMana()"
|
|
on-close="$ctrl.mana = null">
|
|
<tpl-body>
|
|
<vn-spinner
|
|
ng-if="$ctrl.mana == null"
|
|
style="padding: 1em;"
|
|
enable="true">
|
|
</vn-spinner>
|
|
<vn-ticket-sale-edit-discount
|
|
ng-if="$ctrl.mana != null"
|
|
mana="$ctrl.mana"
|
|
bulk="true"
|
|
edit="$ctrl.edit"
|
|
on-hide="$ctrl.hideEditDialog()">
|
|
</vn-ticket-sale-edit-discount>
|
|
</tpl-body>
|
|
</vn-dialog>
|
|
|
|
<!-- Transfer Popover -->
|
|
<vn-popover class="transfer" vn-id="transfer">
|
|
<div pad-medium>
|
|
<table class="vn-grid">
|
|
<thead>
|
|
<tr>
|
|
<th number translate>ID</th>
|
|
<th number translate>F. envio</th>
|
|
<th number translate>Agencia</th>
|
|
<th number translate>Almacen</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr ng-if="$ctrl.lastThreeTickets.length === 0" ><td colspan="4" style="text-align: center" translate>No results</td></tr>
|
|
<tr
|
|
class="clickable"
|
|
ng-repeat="ticket in $ctrl.lastThreeTickets track by ticket.id"
|
|
ng-click="$ctrl.moveLines(ticket.id)">
|
|
<td number>{{::ticket.id}}</td>
|
|
<td number>{{::ticket.shipped | dateTime: 'dd/MM/yyyy HH:mm'}}</td>
|
|
<td number>{{::ticket.agencyName}}</td>
|
|
<td number>{{::ticket.warehouseName}}</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
<vn-horizontal>
|
|
<vn-textfield
|
|
label="Move to ticket"
|
|
model="$ctrl.moveToTicketFk"
|
|
type="number">
|
|
</vn-textfield>
|
|
<vn-icon-button
|
|
icon="arrow_forward_ios"
|
|
ng-click="$ctrl.moveLines($ctrl.moveToTicketFk)">
|
|
</vn-icon-button>
|
|
</vn-horizontal>
|
|
<vn-horizontal>
|
|
<vn-button
|
|
label="New ticket"
|
|
ng-click="$ctrl.linesToNewTicket()">
|
|
</vn-button>
|
|
<vn-icon
|
|
color-secondary
|
|
vn-tooltip="You have to allow pop-ups in your web browser to use this functionality"
|
|
icon="info">
|
|
</vn-icon>
|
|
</vn-horizontal>
|
|
</div>
|
|
</vn-popover>
|
|
</vn-vertical>
|
|
<vn-confirm
|
|
vn-id="delete-lines"
|
|
question="You are going to delete lines of the ticket"
|
|
message="Continue anyway?"
|
|
on-response="$ctrl.onRemoveLinesClick(response)">
|
|
</vn-confirm>
|
|
<vn-float-button
|
|
ng-show="$ctrl.isEditable"
|
|
ng-click="$ctrl.newOrderFromTicket()"
|
|
icon="add"
|
|
vn-tooltip="New item"
|
|
vn-bind="+"
|
|
fixed-bottom-right>
|
|
</vn-float-button> |