#951 ticket.descriptor añadir polizon

This commit is contained in:
Gerard 2019-01-18 13:36:13 +01:00
parent e9bc3f00a1
commit 345acc1353
8 changed files with 210 additions and 6 deletions

View File

@ -8,6 +8,8 @@ import './card';
import './descriptor'; import './descriptor';
import './descriptor-popover'; import './descriptor-popover';
import './ticket-descriptor'; import './ticket-descriptor';
import './ticket-descriptor/addStowaway';
import './ticket-descriptor/removeStowaway';
import './ticket-descriptor-popover'; import './ticket-descriptor-popover';
import './data'; import './data';
import './tags'; import './tags';

View File

@ -0,0 +1,35 @@
<vn-dialog
vn-id="dialog"
class="modalForm"
on-open="$ctrl.getPossibleStowaways()">
<tpl-body>
<vn-horizontal pad-medium class="header">
<h5><span translate>Stowaways to add</span></h5>
</vn-horizontal>
<vn-horizontal pad-medium>
<vn-table>
<vn-thead>
<vn-tr>
<vn-th number>Ticket id</vn-th>
<vn-th number>Shipped</vn-th>
<vn-th number>Agency</vn-th>
<vn-th number>Warehouse</vn-th>
<vn-th number>State</vn-th>
</vn-tr>
</vn-thead>
<vn-tbody>
<vn-tr ng-repeat="ticket in $ctrl.possibleStowaways" class="clickable" ng-click="$ctrl.addStowaway($index)">
<vn-td number>{{ticket.id}}</vn-td>
<vn-td number>{{ticket.landed | dateTime: 'dd/MM/yyyy'}}</vn-td>
<vn-td number>{{ticket.agencyMode.name}}</vn-td>
<vn-td number>{{ticket.warehouse.name}}</vn-td>
<vn-td number>{{ticket.state.state.name}}</vn-td>
</vn-tr>
</vn-tbody>
<vn-empty-rows ng-if="$ctrl.possibleStowaways.length === 0" translate>
No results
</vn-empty-rows>
</vn-table>
</vn-horizontal>
</tpl-body>
</vn-dialog>

View File

@ -0,0 +1,46 @@
import ngModule from '../module';
class Controller {
constructor($state, $scope, $http) {
this.$scope = $scope;
this.$state = $state;
this.$http = $http;
}
getPossibleStowaways() {
this.$http.get(`/api/Tickets/${this.ticket.id}/getPossibleStowaways`)
.then(res => {
console.log(res);
this.possibleStowaways = res.data;
});
}
addStowaway(index) {
let params = {id: this.possibleStowaways[index].id, shipFk: this.ticket.id};
this.$http.post(`/api/Stowaways/`, params)
.then(() => {
this.card.reload();
});
}
show() {
this.$scope.dialog.show();
}
hide() {
this.$scope.dialog.hide();
}
}
Controller.$inject = ['$state', '$scope', '$http', 'vnApp', '$translate'];
ngModule.component('vnAddStowaway', {
template: require('./addStowaway.html'),
controller: Controller,
bindings: {
ticket: '<'
},
require: {
card: '^vnTicketCard'
}
});

View File

@ -91,6 +91,17 @@
icon="{{::$ctrl.quicklinks.btnThree.icon}}"> icon="{{::$ctrl.quicklinks.btnThree.icon}}">
</vn-icon> </vn-icon>
</a> </a>
<vn-button-menu
ng-if="$ctrl.ticket.ship.length > 1"
vn-id="stowaways-button"
icon="icon-polizon"
show-filter="false"
show-field="id"
value-field="id"
vn-tooltip="Ship stowaways"
data="$ctrl.ticket.ship"
on-change="$ctrl.goToTicket(value)">
</vn-button-menu>
</vn-horizontal> </vn-horizontal>
</vn-card> </vn-card>
<vn-dialog class="dialog-summary" <vn-dialog class="dialog-summary"
@ -139,3 +150,5 @@
question="You are going to delete this ticket" question="You are going to delete this ticket"
message="Continue anyway?"> message="Continue anyway?">
</vn-confirm> </vn-confirm>
<vn-add-stowaway vn-id="addStowaway" ticket="$ctrl.ticket"></vn-add-stowaway>
<vn-remove-stowaway vn-id="removeStowaway" ticket="$ctrl.ticket"></vn-remove-stowaway>

View File

@ -1,4 +1,5 @@
import ngModule from '../module'; import ngModule from '../module';
import './style.scss';
class Controller { class Controller {
constructor($state, $scope, $http, vnApp, $translate) { constructor($state, $scope, $http, vnApp, $translate) {
@ -8,15 +9,34 @@ class Controller {
this.vnApp = vnApp; this.vnApp = vnApp;
this.$translate = $translate; this.$translate = $translate;
this.moreOptions = [ this.moreOptions = [
{callback: this.showAddTurnDialog, name: 'Add turn'}, {callback: this.showAddTurnDialog, name: 'Add turn', show: true},
{callback: this.showDeleteTicketDialog, name: 'Delete ticket'} {callback: this.showDeleteTicketDialog, name: 'Delete ticket', show: true},
{callback: this.showAddStowaway, name: 'Add stowaway', show: true},
{callback: this.showRemoveStowaway, name: 'Remove stowaway', show: () => this.shouldShowRemoveStowaway()}
]; ];
} }
shouldShowRemoveStowaway() {
if (!this._ticket)
return false;
return (this._ticket.stowaway || this._ticket.ship.length > 1);
}
onMoreChange(callback) { onMoreChange(callback) {
callback.call(this); callback.call(this);
} }
goToTicket(ticketID) {
this.$state.go('ticket.card.sale', {id: ticketID});
}
onMoreOpen() {
let options = this.moreOptions.filter(o => {
return o.show === true || typeof o.show === 'function' && o.show();
});
this.$scope.moreButton.data = options;
}
get isEditable() { get isEditable() {
try { try {
return !this.ticket.tracking.state.alertLevel; return !this.ticket.tracking.state.alertLevel;
@ -58,6 +78,15 @@ class Controller {
} }
} }
showAddStowaway() {
this.$scope.addStowaway.show();
console.log(this.$state.getCurrentPath());
}
showRemoveStowaway() {
this.$scope.removeStowaway.show();
}
get ticket() { get ticket() {
return this._ticket; return this._ticket;
} }
@ -67,14 +96,32 @@ class Controller {
if (!value) return; if (!value) return;
this._quicklinks = { let links = {
btnOne: { btnOne: {
icon: 'person', icon: 'person',
state: `client.card.summary({id: ${value.clientFk}})`, state: `client.card.summary({id: ${value.clientFk}})`,
tooltip: 'Client card' tooltip: 'Client card'
} }};
if (value.stowaway) {
links.btnTwo = {
icon: 'icon-polizon',
state: `ticket.card.summary({id: ${value.stowaway.shipFk}})`,
tooltip: 'Ship'
}; };
} }
console.log(value.ship);
if (value.ship.length == 1) {
links.btnThree = {
icon: 'icon-polizon',
state: `ticket.card.summary({id: ${value.ship[0].id}})`,
tooltip: 'Stowaway'
};
} else if (value.ship.length > 1)
this.shipStowaways = value.ship;
this._quicklinks = links;
}
set quicklinks(value = {}) { set quicklinks(value = {}) {
this._quicklinks = Object.assign(value, this._quicklinks); this._quicklinks = Object.assign(value, this._quicklinks);

View File

@ -0,0 +1,57 @@
module.exports = Self => {
Self.remoteMethod('getPossibleStowaways', {
description: 'Returns mana of a salesperson of a ticket',
accessType: 'READ',
accepts: [{
arg: 'id',
type: 'number',
required: true,
description: 'ticket id',
http: {source: 'path'}
}],
returns: {
root: true
},
http: {
path: `/:id/getPossibleStowaways`,
verb: 'GET'
}
});
Self.getPossibleStowaways = async ticketFk => {
let ship = await Self.app.models.Ticket.findById(ticketFk);
let lowestDate = new Date(ship.shipped.getTime());
lowestDate.setHours(0, 0, -1, 0);
let highestDate = new Date(ship.shipped.getTime());
highestDate.setHours(23, 59, 59);
let possibleStowaways = await Self.app.models.Ticket.find({
where: {
clientFk: ship.clientFk,
addressFk: ship.addressFk,
agencyModeFk: ship.agencyModeFk,
warehouse: {neq: ship.warehouseFk},
shipped: {
between: [lowestDate.toJSON(), highestDate.toJSON()]
}
},
include: [
{relation: 'agencyMode'},
{relation: 'warehouse'},
{relation: 'state',
scope: {
fields: ['stateFk'],
include: {
relation: 'state',
fields: ['id', 'name'],
}
},
},
]
});
return possibleStowaways;
};
};

View File

@ -32,6 +32,9 @@
"State":{ "State":{
"dataSource": "vn" "dataSource": "vn"
}, },
"Stowaway": {
"dataSource": "vn"
},
"Ticket": { "Ticket": {
"dataSource": "vn" "dataSource": "vn"
}, },

View File

@ -16,4 +16,5 @@ module.exports = Self => {
require('../methods/ticket/getShipped')(Self); require('../methods/ticket/getShipped')(Self);
require('../methods/ticket/getLanded')(Self); require('../methods/ticket/getLanded')(Self);
require('../methods/ticket/filter')(Self); require('../methods/ticket/filter')(Self);
require('../methods/ticket/getPossibleStowaways')(Self);
}; };