2018-04-04 16:25:25 +02:00
|
|
|
console.log('hello console for main.js');
|
2018-04-05 14:21:32 +02:00
|
|
|
var stuff = ['initialstuff'];
|
|
|
|
angular
|
|
|
|
.module('caisse', [])
|
|
|
|
.controller('CaisseCtrl', ['$scope', '$http', function ($scope, $http, stuff) {
|
2018-04-06 15:54:59 +02:00
|
|
|
$scope.productsFromDB = []; // loaded products
|
|
|
|
$scope.categories = []; // product categories
|
2018-04-17 15:08:30 +02:00
|
|
|
$scope.sellingComment = ""; // comment about the client or the current selling
|
2018-04-06 15:54:59 +02:00
|
|
|
$scope.initLoadDone = false; // becames true after first init of product loading
|
2018-04-05 16:40:40 +02:00
|
|
|
$scope.recentSellings = [];
|
2018-04-17 12:10:21 +02:00
|
|
|
$scope.lesParams = {};
|
2018-04-17 15:08:30 +02:00
|
|
|
$scope.paidAmount = 0;
|
2018-04-05 14:21:32 +02:00
|
|
|
$scope.pausedSelling = [];
|
2018-04-17 15:08:30 +02:00
|
|
|
$scope.activeItemsSold = []; // list of products ID to sell
|
2018-04-06 15:54:59 +02:00
|
|
|
$scope.activeSelling = []; // list of products to sell
|
|
|
|
$scope.activeFestival = { // an event where selling take place
|
2018-04-05 16:40:40 +02:00
|
|
|
name : "le festival",
|
|
|
|
dateCreation: new Date(),
|
2018-04-17 15:08:30 +02:00
|
|
|
commentaire : ""
|
2018-04-05 16:40:40 +02:00
|
|
|
};
|
2018-04-05 17:01:36 +02:00
|
|
|
/**
|
|
|
|
* get the sum of products prices
|
|
|
|
* @param list
|
|
|
|
* @returns {number}
|
|
|
|
*/
|
|
|
|
$scope.sumOfList = function (list) {
|
|
|
|
let counter = 0;
|
|
|
|
for (let i = 0; i < list.length; i++) {
|
|
|
|
counter += list[i].price;
|
|
|
|
}
|
|
|
|
return counter;
|
|
|
|
};
|
|
|
|
/**
|
|
|
|
* sum of current selling list prices
|
|
|
|
* @returns {number}
|
|
|
|
* @constructor
|
|
|
|
*/
|
|
|
|
$scope.CurrentSellingTotal = function () {
|
|
|
|
return $scope.sumOfList($scope.activeSelling);
|
|
|
|
};
|
2018-04-05 14:21:32 +02:00
|
|
|
|
2018-04-17 15:08:30 +02:00
|
|
|
$scope.regenActiveSellingIds = function () {
|
|
|
|
$scope.activeItemsSold = [];
|
|
|
|
for (let obj in $scope.activeSelling) {
|
|
|
|
$scope.activeItemsSold.push(obj.id);
|
|
|
|
}
|
|
|
|
};
|
2018-04-05 14:21:32 +02:00
|
|
|
$scope.stuff = stuff;
|
|
|
|
$scope.setActiveSelling = function (selling) {
|
|
|
|
$scope.activeSelling = selling;
|
|
|
|
};
|
|
|
|
$scope.pauseSelling = function (selling) {
|
|
|
|
$scope.pausedSelling.push(selling);
|
|
|
|
};
|
2018-04-05 16:40:40 +02:00
|
|
|
$scope.addProduct = function (product) {
|
|
|
|
$scope.activeSelling.push(product);
|
2018-04-17 15:08:30 +02:00
|
|
|
$scope.activeItemsSold.push(product.id);
|
2018-04-05 14:21:32 +02:00
|
|
|
};
|
2018-04-05 17:01:36 +02:00
|
|
|
$scope.pauseSelling = function () {
|
|
|
|
$scope.pausedSelling.push(angular.copy($scope.activeSelling));
|
|
|
|
$scope.activeSelling = [];
|
|
|
|
};
|
|
|
|
$scope.setBackPausedSelling = function (sellingList, index) {
|
|
|
|
$scope.activeSelling = angular.copy(sellingList);
|
|
|
|
$scope.pausedSelling.splice(index, 1);
|
2018-04-05 14:21:32 +02:00
|
|
|
};
|
2018-04-06 15:54:59 +02:00
|
|
|
$scope.clearCurrentSelling = function () {
|
2018-04-06 16:39:41 +02:00
|
|
|
$scope.paidAmount = 0;
|
2018-04-17 12:10:21 +02:00
|
|
|
$scope.sellingComment = "";
|
2018-04-06 15:54:59 +02:00
|
|
|
$scope.activeSelling = [];
|
|
|
|
};
|
2018-04-17 15:08:30 +02:00
|
|
|
|
|
|
|
// http related calls
|
|
|
|
$scope.fetchProductsFromDB = function () {
|
|
|
|
console.log('fetch products...');
|
|
|
|
$http.get('get-my-products').then((rep) => {
|
|
|
|
|
|
|
|
console.log('ok', rep);
|
|
|
|
$scope.categories = rep.data.categories;
|
|
|
|
$scope.productsFromDB = rep.data.categories;
|
|
|
|
$scope.recentSellings = rep.data.history;
|
|
|
|
$scope.initLoadDone = true;
|
|
|
|
}, (err) => {
|
|
|
|
console.log(err);
|
|
|
|
$scope.initLoadDone = true;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2018-04-05 14:21:32 +02:00
|
|
|
$scope.sendForm = function () {
|
2018-04-05 16:40:40 +02:00
|
|
|
let lesParams = {
|
2018-04-06 16:39:41 +02:00
|
|
|
paidByClient : $scope.paidAmount,
|
2018-04-17 12:10:21 +02:00
|
|
|
sellingComment: $scope.sellingComment,
|
2018-04-05 16:40:40 +02:00
|
|
|
activeSelling : $scope.activeSelling,
|
|
|
|
activeFestival: $scope.activeFestival
|
|
|
|
};
|
2018-04-17 12:10:21 +02:00
|
|
|
$scope.lesParams = lesParams;
|
2018-04-05 14:21:32 +02:00
|
|
|
$http({
|
2018-04-06 16:39:41 +02:00
|
|
|
method : 'POST',
|
|
|
|
url : 'add-selling',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json'
|
|
|
|
},
|
|
|
|
data : lesParams // pass in data as strings
|
2018-04-05 14:21:32 +02:00
|
|
|
}).then(function (rep) {
|
2018-04-17 12:10:21 +02:00
|
|
|
$scope.clearCurrentSelling();
|
2018-04-05 14:21:32 +02:00
|
|
|
console.log(rep);
|
|
|
|
if (!rep.success) {
|
|
|
|
// if not successful, bind errors to error variables
|
|
|
|
$scope.errors = rep.errors;
|
|
|
|
} else {
|
|
|
|
// if successful, bind success message to message
|
|
|
|
$scope.successMessage = rep.data.message;
|
|
|
|
// changer le type de bout de phrase demandé
|
|
|
|
$scope.formData["tykayn_portfoliobundle_cadexqphrasepart[type]"]["$viewValue"] = 'nouveauType';
|
|
|
|
}
|
|
|
|
}, function (rep) {
|
|
|
|
console.log('nope! ', rep.data);
|
|
|
|
})
|
|
|
|
;
|
|
|
|
};
|
2018-04-05 17:01:36 +02:00
|
|
|
|
|
|
|
$scope.init = (function () {
|
|
|
|
$scope.fetchProductsFromDB();
|
|
|
|
})();
|
2018-04-05 14:21:32 +02:00
|
|
|
}]);
|
2018-04-04 16:25:25 +02:00
|
|
|
|