1. POSTBonus in/out
2. POSTPresale in/out
3. Переработана форма гостя
This commit is contained in:
miroman-afk
2022-12-14 12:42:39 +03:00
parent 4d3ad7727d
commit d24bba305f
49 changed files with 2525 additions and 772 deletions

View File

@@ -1,353 +1,364 @@
(function() {
'use strict';
angular
.module('app')
.controller('ClientsCtrl', ClientsCtrl);
(function () {
'use strict';
angular
.module('app')
.controller('ClientsCtrl', ClientsCtrl);
ClientsCtrl.$inject = ['$scope', 'smartRequest', 'Notification', '$rootScope', '$timeout'];
function ClientsCtrl($scope, smartRequest, Notification, $rootScope, $timeout) {
$scope.clients = [];
$scope.groups = [];
$scope.statuses = [];
$scope.filedate = '';
$scope.currentGroupId = 0;
$scope.currentClientId = 0;
ClientsCtrl.$inject = ['$scope', 'smartRequest', 'Notification', '$rootScope', '$timeout'];
$scope.currentClient = {};
$scope.orders = [];
$scope.order = {};
function ClientsCtrl($scope, smartRequest, Notification, $rootScope, $timeout) {
$scope.clients = [];
$scope.groups = [];
$scope.statuses = [];
$scope.filedate = '';
$scope.currentGroupId = 0;
$scope.currentClientId = 0;
$scope.isCreateNewGroup = false;
$scope.newGroup = {};
$scope.newBarcode = {};
$scope.currentClient = {};
$scope.isCreateNewClient = false;
$scope.newClient = {};
$scope.orders = [];
$scope.order = {};
$scope.search = {
query: ''
};
var promise = 0;
$scope.isCreateNewGroup = false;
$scope.newGroup = {};
$scope.newBarcode = {};
$scope.clientsSearch = function() {
}
$scope.isCreateNewClient = false;
$scope.newClient = {};
$scope.update = function() {
smartRequest.get('client/list?page=' + $scope.currentPage, function(data) {
$scope.clients = data.clients;
$scope.countOfPages = data.pages;
$scope.pages = $scope.makePages();
});
};
$scope.search = {
query: ''
};
$scope.getGroups = function() {
smartRequest.get('v1/clientgroup', function(data) {
$scope.groups = data.groups;
$scope.filedate = data.filedate;
$scope.openGroup({id: 0});
});
};
var promise = 0;
$scope.openGroup = function(group) {
if (typeof group === 'object') {
$scope.currentGroup = group.id;
} else {
$scope.currentGroup = group;
}
$scope.currentPage = 1;
smartRequest.get('v1/clients?group_id=' + $scope.currentGroup + '&page=' + $scope.currentPage, function(data) {
$scope.clients = data.clients;
$scope.pages = data.pages;
$scope.currentGroup = data.currentGroup;
$scope.total = data.total;
});
$scope.clientsSearch = function () {
};
$scope.editGroup = function (group) {
$scope.contextElement = group;
}
$('#edit-group').modal('toggle');
console.log(group);
};
$scope.update = function () {
smartRequest.get('client/list?page=' + $scope.currentPage, function (data) {
$scope.clients = data.clients;
$scope.countOfPages = data.pages;
$scope.pages = $scope.makePages();
});
};
$scope.updateGroup = function () {
$('#edit-group').modal('toggle');
$scope.getGroups = function () {
smartRequest.get('v1/clientgroup', function (data) {
$scope.groups = data.groups;
$scope.filedate = data.filedate;
$scope.openGroup({id: 0});
});
};
smartRequest.post('v1/clientgroup', {
id: $scope.contextElement.id,
name: $scope.contextElement.name,
task: 'update'
}, function (data) {
if (data.status == 'success') {
Notification.success(data.message);
}
if (data.error_message) {
Notification.error(data.error_message);
}
});
};
$scope.removeGroup = function () {
$('#group-confirm-delete').modal('toggle');
$('#edit-group').modal('toggle');
$scope.openGroup = function (group) {
if (typeof group === 'object') {
$scope.currentGroup = group.id;
} else {
$scope.currentGroup = group;
}
$scope.currentPage = 1;
smartRequest.get('v1/clients?group_id=' + $scope.currentGroup + '&page=' + $scope.currentPage, function (data) {
$scope.clients = data.clients;
$scope.pages = data.pages;
$scope.currentGroup = data.currentGroup;
$scope.total = data.total;
$scope.closeCard();
$scope.orders = [];
$scope.currentClient = [];
$scope.clientLogs = [];
});
smartRequest.post('v1/clientgroup', {
id: $scope.contextElement.id,
task: 'delete'
}, function (data) {
$scope.getGroups();
if (data.message) {
Notification.success(data.message);
}
if (data.error_message) {
Notification.error(data.error_message);
}
});
};
$scope.editClient = function (client, group) {
$scope.contextElement = client;
$scope.contextGroup = group;
$('#edit-client').modal('toggle');
console.log(client);
console.log($scope.contextGroup);
};
};
$scope.updateClient = function (group) {
$('#edit-client').modal('toggle');
$scope.editGroup = function (group) {
$scope.contextElement = group;
smartRequest.post('v1/client', {
id: $scope.contextElement.id,
name: $scope.contextElement.name,
group_id: group,
phone: $scope.contextElement.phone,
address: $scope.contextElement.address,
email: $scope.contextElement.email,
barcode: $scope.contextElement.barcode,
task: 'update'
}, function (data) {
if (data.status == 'success') {
Notification.success(data.message);
$scope.openGroup(group);
}
if (data.error_message) {
Notification.error(data.error_message);
}
});
};
$('#edit-group').modal('toggle');
console.log(group);
};
$scope.removeClient = function () {
$('#client-confirm-delete').modal('toggle');
$('#edit-client').modal('toggle');
$scope.updateGroup = function () {
$('#edit-group').modal('toggle');
smartRequest.post('v1/client', {
id: $scope.contextElement.id,
task: 'delete'
}, function (data) {
$scope.getGroups();
$scope.openGroup($scope.currentGroup);
if (data.message) {
Notification.success(data.message);
}
if (data.error_message) {
Notification.error(data.error_message);
}
});
};
smartRequest.post('v1/clientgroup', {
id: $scope.contextElement.id,
name: $scope.contextElement.name,
task: 'update'
}, function (data) {
if (data.status == 'success') {
Notification.success(data.message);
}
if (data.error_message) {
Notification.error(data.error_message);
}
});
};
$scope.pager = function(currentPage) {
smartRequest.get('v1/clients?group_id=' + $scope.currentGroup + '&page=' + $scope.currentPage, function(data) {
$scope.clients = data.clients;
$scope.pages = data.pages;
$scope.currentGroup = data.currentGroup;
$scope.total = data.total;
});
};
$scope.removeGroup = function () {
$('#group-confirm-delete').modal('toggle');
$('#edit-group').modal('toggle');
$scope.getClients = function() {
if ($scope.search.query.length === 0) {
$scope.openGroup({id: $scope.currentGroupId});
}
else {
smartRequest.post('client/search', {
name: $scope.search.query
},
function (data) {
$scope.clients = data.clients;
});
}
};
smartRequest.post('v1/clientgroup', {
id: $scope.contextElement.id,
task: 'delete'
}, function (data) {
$scope.getGroups();
if (data.message) {
Notification.success(data.message);
}
if (data.error_message) {
Notification.error(data.error_message);
}
});
};
$scope.openFormCreateGroup = function() {
$scope.currentClientId = 0;
$scope.isCreateNewClient = false;
$scope.isCreateNewBarcode = false;
$scope.isCreateNewGroup = !$scope.isCreateNewGroup;
};
$scope.editClient = function (client, group) {
$scope.openFormCreateClient = function() {
$scope.currentClientId = 0;
$scope.isCreateNewGroup = false;
$scope.isCreateNewBarcode = false;
$scope.isCreateNewClient = !$scope.isCreateNewClient;
};
$scope.contextElement = client;
$scope.contextGroup = group;
$('#edit-client').modal('toggle');
console.log(client);
console.log($scope.contextGroup);
};
$scope.openFormCreateBarcode = function() {
$scope.currentClientId = 0;
$scope.isCreateNewGroup = false;
$scope.isCreateNewClient = false;
$scope.isCreateNewBarcode = !$scope.isCreateNewBarcode;
smartRequest.get('v1/clientgroup', function(data) {
$scope.groups = data.groups;
});
};
$scope.updateClient = function (group) {
$('#edit-client').modal('toggle');
$scope.createGroup = function() {
smartRequest.post('client/group/create', {
name: $scope.newGroup.name
}, function (data) {
$scope.getGroups();
$scope.closeCard();
});
};
smartRequest.post('v1/client', {
id: $scope.contextElement.id,
name: $scope.contextElement.name,
group_id: group,
phone: $scope.contextElement.phone,
address: $scope.contextElement.address,
email: $scope.contextElement.email,
barcode: $scope.contextElement.barcode,
task: 'update'
}, function (data) {
if (data.status == 'success') {
Notification.success(data.message);
$scope.openGroup(group);
}
if (data.error_message) {
Notification.error(data.error_message);
}
});
};
$scope.createClient = function() {
smartRequest.post('v1/createclient/', {
name: $scope.newClient.name,
group_id: $scope.currentGroup,
phone: $scope.newClient.phone,
address: $scope.newClient.address,
email: $scope.newClient.email,
barcode: $scope.newClient.barcode,
is_special_price: $scope.newClient.special_price
}, function(data) {
$scope.pager($scope.currentGroup);
$scope.closeCard();
});
};
$scope.removeClient = function () {
$('#client-confirm-delete').modal('toggle');
$('#edit-client').modal('toggle');
$scope.createBarcode = function() {
console.log($scope.newBarcode.group_id);
smartRequest.post('v1/createbarcode/', {
group_id: $scope.newBarcode.group_id,
start: $scope.newBarcode.start,
end: $scope.newBarcode.end,
}, function(data) {
$scope.getGroups();
$scope.closeCard();
});
};
smartRequest.post('v1/client', {
id: $scope.contextElement.id,
task: 'delete'
}, function (data) {
$scope.getGroups();
$scope.openGroup($scope.currentGroup);
if (data.message) {
Notification.success(data.message);
}
if (data.error_message) {
Notification.error(data.error_message);
}
});
};
$scope.closeCard = function() {
$scope.isCreateNewGroup = false;
$scope.isCreateNewClient = false;
$scope.isCreateNewBarcode = false;
$scope.currentClientId = 0;
};
$scope.pager = function (currentPage) {
smartRequest.get('v1/clients?group_id=' + $scope.currentGroup + '&page=' + $scope.currentPage, function (data) {
$scope.clients = data.clients;
$scope.pages = data.pages;
$scope.currentGroup = data.currentGroup;
$scope.total = data.total;
});
};
$scope.openClientInfo = function(client) {
$scope.currentClientId = client.id;
$scope.isCreateNewGroup = false;
$scope.isCreateNewClient = false;
$scope.isCreateNewBarcode = false;
$scope.getClients = function () {
if ($scope.search.query.length === 0) {
$scope.openGroup({id: $scope.currentGroupId});
} else {
smartRequest.post('client/search', {
name: $scope.search.query
},
function (data) {
$scope.clients = data.clients;
});
}
};
smartRequest.get('client/client/info?id=' + $scope.currentClientId, function(data) {
$scope.currentClient = data.client;
$scope.openFormCreateGroup = function () {
$scope.currentClientId = 0;
$scope.isCreateNewClient = false;
$scope.isCreateNewBarcode = false;
$scope.isCreateNewGroup = !$scope.isCreateNewGroup;
};
smartRequest.get('client/orders?client_id=' + $scope.currentClient.id, function(data) {
$scope.orders = data.orders;
});
});
};
$scope.openFormCreateClient = function () {
$scope.currentClientId = 0;
$scope.isCreateNewGroup = false;
$scope.isCreateNewBarcode = false;
$scope.isCreateNewClient = !$scope.isCreateNewClient;
};
$scope.getItems = function(order) {
smartRequest.get('client/order?order_id=' + order.id, function(data) {
$scope.order = data;
$('#order').modal('toggle');
});
};
var mergeFiles = function (statuses) {
if (statuses == 4) {
smartRequest.get('v1/clientfile?complete=1', function(data) {
$scope.filedate = data.filedate;
$scope.filename = data.filename;
$scope.terminalkey = data.terminalKey;
$scope.downloadClientFile();
$scope.statuses = [];
});
}
};
$scope.createClientFile = function(count) {
smartRequest.get('v1/clientfile?th=1', function(data) {
if(data.status == 'success') {
$scope.statuses.push(data.status);
console.log($scope.statuses);
$scope.statusCount = $scope.statuses.length;
mergeFiles($scope.statusCount);
}
});
smartRequest.get('v1/clientfile?th=2', function(data) {
if(data.status == 'success') {
$scope.statuses.push(data.status);
console.log($scope.statuses);
$scope.statusCount = $scope.statuses.length;
mergeFiles($scope.statusCount);
}
});
smartRequest.get('v1/clientfile?th=3', function(data) {
if(data.status == 'success') {
$scope.statuses.push(data.status);
console.log($scope.statuses);
$scope.statusCount = $scope.statuses.length;
mergeFiles($scope.statusCount);
}
});
smartRequest.get('v1/clientfile?th=4', function(data) {
if(data.status == 'success') {
$scope.statuses.push(data.status);
console.log($scope.statuses);
$scope.statusCount = $scope.statuses.length;
mergeFiles($scope.statusCount);
}
});
};
$scope.downloadClientFile = function() {
smartRequest.get('v1/clientgroup', function(data) {
window.open(window.location.protocol + '//' + window.location.hostname + '/Exchange/' + $scope.terminalkey +'/'+ $scope.filename);
});
};
$scope.clientsSearch = function () {
if (promise) {
$timeout.cancel(promise);
}
promise = $timeout(function () {
if ($scope.search.query.length === 0) {
$scope.getGroups();
}
else {
$scope.groups = [];
}
$scope.openFormCreateBarcode = function () {
$scope.currentClientId = 0;
$scope.isCreateNewGroup = false;
$scope.isCreateNewClient = false;
$scope.isCreateNewBarcode = !$scope.isCreateNewBarcode;
smartRequest.get('v1/clientgroup', function (data) {
$scope.groups = data.groups;
});
};
$scope.getClients();
}, 300);
};
$scope.clearSearchInput = function () {
$scope.search.query = '';
$scope.clientsSearch();
};
$scope.createGroup = function () {
smartRequest.post('client/group/create', {
name: $scope.newGroup.name
}, function (data) {
$scope.getGroups();
$scope.closeCard();
});
};
$scope.getGroups();
}
}
$scope.createClient = function () {
smartRequest.post('v1/createclient/', {
name: $scope.newClient.name,
group_id: $scope.currentGroup,
phone: $scope.newClient.phone,
address: $scope.newClient.address,
email: $scope.newClient.email,
barcode: $scope.newClient.barcode,
is_special_price: $scope.newClient.special_price
}, function (data) {
$scope.pager($scope.currentGroup);
$scope.closeCard();
});
};
$scope.createBarcode = function () {
console.log($scope.newBarcode.group_id);
smartRequest.post('v1/createbarcode/', {
group_id: $scope.newBarcode.group_id,
start: $scope.newBarcode.start,
end: $scope.newBarcode.end,
}, function (data) {
$scope.getGroups();
$scope.closeCard();
});
};
$scope.closeCard = function () {
$scope.isCreateNewGroup = false;
$scope.isCreateNewClient = false;
$scope.isCreateNewBarcode = false;
$scope.currentClientId = 0;
};
$scope.openClientInfo = function (client) {
$scope.currentClientId = client.id;
$scope.isCreateNewGroup = false;
$scope.isCreateNewClient = false;
$scope.isCreateNewBarcode = false;
$scope.orders = [];
$scope.currentClient = [];
$scope.clientLogs = [];
smartRequest.get('v1/clientinfo?id=' + $scope.currentClientId, function (data) {
$scope.currentClient = data.client;
smartRequest.get('v1/clientlog?id=' + $scope.currentClient.id, function (data) {
$scope.clientLogs = data.client.info;
});
});
};
$scope.getOrders = function (client_id) {
smartRequest.get('v1/clientorders?id=' + client_id, function (data) {
$scope.orders = data.orders;
});
};
$scope.getItems = function (order_id, opened, closed) {
smartRequest.get('v1/clientorderinfo?order_id=' + order_id + '&opened=' + opened + '&closed=' + closed, function (data) {
$scope.order = data.info;
$('#order').modal('toggle');
});
};
var mergeFiles = function (statuses) {
if (statuses == 4) {
smartRequest.get('v1/clientfile?complete=1', function (data) {
$scope.filedate = data.filedate;
$scope.filename = data.filename;
$scope.terminalkey = data.terminalKey;
$scope.downloadClientFile();
$scope.statuses = [];
});
}
};
$scope.createClientFile = function (count) {
smartRequest.get('v1/clientfile?th=1', function (data) {
if (data.status == 'success') {
$scope.statuses.push(data.status);
console.log($scope.statuses);
$scope.statusCount = $scope.statuses.length;
mergeFiles($scope.statusCount);
}
});
smartRequest.get('v1/clientfile?th=2', function (data) {
if (data.status == 'success') {
$scope.statuses.push(data.status);
console.log($scope.statuses);
$scope.statusCount = $scope.statuses.length;
mergeFiles($scope.statusCount);
}
});
smartRequest.get('v1/clientfile?th=3', function (data) {
if (data.status == 'success') {
$scope.statuses.push(data.status);
console.log($scope.statuses);
$scope.statusCount = $scope.statuses.length;
mergeFiles($scope.statusCount);
}
});
smartRequest.get('v1/clientfile?th=4', function (data) {
if (data.status == 'success') {
$scope.statuses.push(data.status);
console.log($scope.statuses);
$scope.statusCount = $scope.statuses.length;
mergeFiles($scope.statusCount);
}
});
};
$scope.downloadClientFile = function () {
smartRequest.get('v1/clientgroup', function (data) {
window.open(window.location.protocol + '//' + window.location.hostname + '/Exchange/' + $scope.terminalkey + '/' + $scope.filename);
});
};
$scope.clientsSearch = function () {
if (promise) {
$timeout.cancel(promise);
}
promise = $timeout(function () {
if ($scope.search.query.length === 0) {
$scope.getGroups();
} else {
$scope.groups = [];
}
$scope.getClients();
}, 300);
};
$scope.clearSearchInput = function () {
$scope.search.query = '';
$scope.clientsSearch();
};
$scope.getGroups();
}
}
)();

340
web/controllers/loyalty.js Normal file
View File

@@ -0,0 +1,340 @@
(function() {
'use strict';
angular
.module('app')
.controller('LoyaltyCtrl', LoyaltyCtrl);
LoyaltyCtrl.$inject = ['$scope', 'smartRequest', 'Notification'];
function LoyaltyCtrl($scope, smartRequest, Notification) {
$scope.discounts = [];
$scope.currentDiscount = {};
$scope.terms = [];
$scope.defaultTerm = 0;
$scope.currentTerms = [];
$scope.readonlyMode = false;
$scope.selectedElement = {
type: '',
value: 0,
currentModal: '',
param: {},
info: '',
subtype: ''
};
$scope.navigationStack = [];
$scope.update = function() {
smartRequest.get('discount/list', function(data) {
for(var i = 0; i < data.discounts.length; i++) {
if(data.discounts[i].start_date === '0') {
data.discounts[i].start_date = '';
}
if(data.discounts[i].end_date === '0') {
data.discounts[i].end_date = '';
}
data.discounts[i].is_enable = data.discounts[i].is_enable === '1';
data.discounts[i].is_check_all = data.discounts[i].is_check_all === '1';
}
$scope.discounts = data.discounts;
});
};
$scope.delete = function() {
$('#edit-discount-confirm-delete').modal('toggle');
$('#edit-discount').modal('toggle');
smartRequest.post('discount/delete', {
id: $scope.currentDiscount.id
}, function(data) {
$scope.update();
});
};
$scope.add = function() {
$scope.currentDiscount = {};
$scope.currentDiscount.value_type = '0';
$('#new-discount').modal();
};
$scope.create = function() {
$('#new-discount').modal('toggle');
smartRequest.post('discount/store', {
name: $scope.currentDiscount.name,
value_type: $scope.currentDiscount.value_type,
value: $scope.currentDiscount.value
}, function(data) {
$scope.update();
});
};
$scope.edit = function(discount) {
$scope.currentDiscount = discount;
$scope.currentDiscount.new_term_type = $scope.defaultTerm;
$scope.updateTerms();
$('#edit-discount').modal();
};
$scope.save = function() {
$('#edit-discount').modal('toggle');
smartRequest.post('discount/update', {
id: $scope.currentDiscount.id,
name: $scope.currentDiscount.name,
value_type: $scope.currentDiscount.value_type,
value: $scope.currentDiscount.value,
is_enable: $scope.currentDiscount.is_enable,
start_date: $scope.currentDiscount.start_date,
end_date: $scope.currentDiscount.end_date,
is_check_all: $scope.currentDiscount.is_check_all
}, function(data) {
for(var i = 0; i < $scope.currentTerms.length; i++) {
var params = [];
for(var j = 0; j < $scope.currentTerms[i].params.length; j++) {
params.push({
code: $scope.currentTerms[i].params[j].code,
value: $scope.currentTerms[i].params[j].value,
subtype: $scope.currentTerms[i].params[j].subtype
});
}
smartRequest.post('discount/term/update', {
id: $scope.currentTerms[i].id,
is_term: $scope.currentTerms[i].is_term === false,
value: JSON.stringify(params)
});
}
Notification.success('Скидка сохранена');
$scope.update();
});
};
$scope.updateTerms = function() {
smartRequest.get('discount/term/list?discount_code=' + $scope.currentDiscount.code, function(data) {
for(var i = 0; i < data.discount_terms.length; i++) {
data.discount_terms[i].is_term = data.discount_terms[i].is_term === '0';
}
$scope.currentTerms = data.discount_terms;
});
};
$scope.addTerm = function() {
smartRequest.post('discount/term/store', {
discount_code: $scope.currentDiscount.code,
discount_type: $scope.currentDiscount.new_term_type
}, function(data) {
$scope.update();
$scope.updateTerms();
});
};
$scope.askDeleteTerm = function(term) {
$scope.currentTerm = term;
$('#edit-term-confirm-delete').modal();
};
$scope.deleteTerm = function() {
$('#edit-term-confirm-delete').modal('toggle');
smartRequest.post('discount/term/delete', {
id: $scope.currentTerm.id
}, function(data) {
$scope.updateTerms();
});
};
/* MENU BLOCK */
$scope.selectMenuItemParams = {
currentMenu: 0,
currentFolder: 0,
menus: [],
folders: [],
items: []
};
$scope.selectedMenuElement = {};
$scope.selectMenuNavigationStack = [];
$scope.selectMenuItem = function() {
$scope.selectMenuItemParams = {
currentMenu: 0,
currentFolder: 0,
menus: [],
folders: [],
items: []
};
smartRequest.get('menu/list', function (data) {
$scope.selectMenuItemParams.menus = data.menus;
});
};
$scope.openMenuItem = function(menu) {
$scope.selectMenuItemParams.currentMenu = menu.id;
$scope.selectMenuNavigationStack.push({
type: 'menu',
value: menu
});
smartRequest.get('menu/folder/list?menu_id=' + $scope.selectMenuItemParams.currentMenu + '&parent_id=0', function (data) {
$scope.selectMenuItemParams.folders = data.folders;
});
smartRequest.get('menu/dish/list?menu_id=' + $scope.selectMenuItemParams.currentMenu + '&parent_id=0', function (data) {
$scope.selectMenuItemParams.items = data.dishes;
});
};
$scope.openFolderItem = function(folder) {
$scope.selectMenuItemParams.currentFolder = folder.id;
$scope.selectMenuNavigationStack.push({
type: 'folder',
value: folder
});
smartRequest.get('menu/folder/list?menu_id=' + $scope.selectMenuItemParams.currentMenu + '&parent_id=' + $scope.selectMenuItemParams.currentFolder, function (data) {
$scope.selectMenuItemParams.folders = data.folders;
});
smartRequest.get('menu/dish/list?menu_id=' + $scope.selectMenuItemParams.currentMenu + '&parent_id=' + $scope.selectMenuItemParams.currentFolder, function (data) {
$scope.selectMenuItemParams.items = data.dishes;
});
};
$scope.upMenuItem = function() {
if($scope.selectMenuNavigationStack.length > 1) {
$scope.selectMenuNavigationStack.pop();
var page = $scope.selectMenuNavigationStack.pop();
if(page.type === 'menu') {
$scope.openMenuItem(page.value);
}
if(page.type === 'folder') {
$scope.openFolderItem(page.value);
}
}
else {
$scope.selectMenuItem();
}
};
/* END MENU BLOCK */
/* CLIENT BLOCK */
$scope.selectClientItemParams = {
clients: [],
groups: [],
isParent: true
};
$scope.selectClientItem = function() {
$scope.selectClientItemParams = {
clients: [],
groups: [],
isParent: true
};
$scope.currentPage = 1;
$scope.pages = 1;
smartRequest.get('v1/clientgroup', function(data) {
$scope.selectClientItemParams.groups = data.groups;
});
};
$scope.openGroup = function(group) {
$scope.selectClientItemParams.isParent = false;
$scope.currentGroup = group.id;
$scope.currentPage = 1;
$scope.selectClientItemParams.groups = [];
$scope.selectClientItemParams.clients = [];
smartRequest.get('v1/clients?group_id=' + $scope.currentGroup + '&page=' + $scope.currentPage, function(data) {
$scope.selectClientItemParams.clients = data.clients;
$scope.pages = data.pages;
$scope.currentGroup = data.currentGroup;
});
};
$scope.pager = function(currentPage) {
$scope.selectClientItemParams.isParent = false;
$scope.selectClientItemParams.groups = [];
$scope.selectClientItemParams.clients = [];
smartRequest.get('v1/clients?group_id=' + $scope.currentGroup + '&page=' + $scope.currentPage, function(data) {
$scope.selectClientItemParams.clients = data.clients;
$scope.pages = data.pages;
$scope.currentGroup = data.currentGroup;
});
};
$scope.upGroup = function() {
$scope.selectClientItemParams = {
clients: [],
groups: [],
isParent: true
};
smartRequest.get('v1/clientgroup', function(data) {
$scope.selectClientItemParams.groups = data.groups;
});
};
/* END CLIENT BLOCK */
$scope.selectItem = function(value, type, info) {
$scope.selectedElement.value = value;
$scope.selectedElement.type = type;
$scope.selectedElement.info = info;
};
$scope.editTermParam = function(param) {
$scope.$eval(param.type[0].toLowerCase() + param.type.slice(1) + '()');
$scope.selectedElement = {
type: param.type,
value: param.value,
currentModal: '#edit-' + param.type.toLowerCase(),
param: param,
info: param.info,
subtype: param.subtype
};
$($scope.selectedElement.currentModal).modal();
};
$scope.confirmSelect = function() {
$($scope.selectedElement.currentModal).modal('toggle');
$scope.selectedElement.param.value = $scope.selectedElement.value;
$scope.selectedElement.param.info = $scope.selectedElement.info;
$scope.selectedElement.param.subtype = $scope.selectedElement.type;
};
$scope.update();
smartRequest.get('discount/type/list', function(data) {
$scope.terms = data.discount_types;
$scope.defaultTerm = data.default.code;
});
smartRequest.get('menu/readonly', function (data) {
$scope.readonlyMode = data.readonly;
if (data.readonly) {
Notification.error('Режим просмотра!');
}
});
}
})();

View File

@@ -20,6 +20,13 @@ item: [
icon: 'dashboard',
order: 0
},
{
name: 'Loyalty (dev)',
acl: 'loyalty',
url: 'app.loyalty',
icon: 'dashboard',
order: 0
},
{
name: 'Гости',
acl: 'clients',

View File

@@ -30,6 +30,14 @@
controller: 'RoommapCtrl',
resolve: ['scripts/controllers/roommap.js']
},
{
code: 'app.loyalty',
url: '/v1/loyalty',
templateUrl: '../views/loyalty/index.html',
data: { title : 'Loyalty' },
controller: 'LoyaltyCtrl',
resolve: ['scripts/controllers/loyalty.js']
},
{
code: 'app.clients',
url: '/clients',

Binary file not shown.

After

Width:  |  Height:  |  Size: 146 KiB

View File

@@ -1,8 +1,10 @@
<div id="container-floating">
<div class="nd1 nds" data-toggle="tooltip" data-placement="left" title="Сформировать файл" ng-click="createClientFile()" style="background-color: #3c80f6" onmouseenter="$(this).tooltip('show')">
<div class="nd1 nds" data-toggle="tooltip" data-placement="left" title="Сформировать файл"
ng-click="createClientFile()" style="background-color: #3c80f6" onmouseenter="$(this).tooltip('show')">
<i class="material-icons">cloud_download</i>
</div>
<div id="floating-button" data-toggle="tooltip" data-placement="left" title="Действия" onmouseenter="$(this).tooltip('show')">
<div id="floating-button" data-toggle="tooltip" data-placement="left" title="Действия"
onmouseenter="$(this).tooltip('show')">
<p class="plus"><i class="material-icons">&#xE5D2;</i></p>
<p class="edit"><i class="material-icons">&#xE5CD;</i></p>
</div>
@@ -17,8 +19,9 @@
<div class="row-body scrollable hover">
<div class="row-inner">
<div class="nav nav-pills nav-stacked m-t-sm menus">
<a class="nav-link no_selection" ng-repeat="group in groups" sglclick="openGroup(group)" ios-dblclick="editGroup(group)"
ng-class="group.id == currentGroup ? 'bold-line' : ''">
<a class="nav-link no_selection" ng-repeat="group in groups" sglclick="openGroup(group)"
ios-dblclick="editGroup(group)"
ng-class="group.id == currentGroup ? 'bold-line' : ''">
<span ng-class="group.id == currentGroup ? 'bold' : ''">{{ group.name }}</span>
</a>
</div>
@@ -29,8 +32,8 @@
<a class="btn btn-md btn-outline rounded b-info text-info" ng-click="openFormCreateGroup()">
<i class="fa fa-plus fa-fw m-r-xs"></i>Группа
</a>
<p></p>
<a class="btn btn-md btn-outline rounded b-info text-info" ng-click="openFormCreateBarcode()">
<p></p>
<a class="btn btn-md btn-outline rounded b-info text-info" ng-click="openFormCreateBarcode()">
<i class="fa fa-plus fa-fw m-r-xs"></i>Дисконтные карты
</a>
</div>
@@ -44,8 +47,9 @@
<span class="input-group-addon no-border no-bg">
<i class="fa fa-search"></i>
</span>
<input type="text" class="form-control no-border no-bg" placeholder="Поиск гостей..." ng-keyup="clientsSearch()"
ng-model="search.query">
<input type="text" class="form-control no-border no-bg" placeholder="Поиск гостей..."
ng-keyup="clientsSearch()"
ng-model="search.query">
<span class="input-group-addon no-border no-bg search-clear" ng-click="clearSearchInput()">
<i class="fa fa-times"></i>
</span>
@@ -57,8 +61,8 @@
<div class="row-inner">
<div class="list">
<div class="list-item pointer no_selection" ng-repeat="client in clients"
sglclick="openClientInfo(client)" ios-dblclick="editClient(client, currentGroup)"
ng-class="client.id == currentClientId ? 'active' : ''">
sglclick="openClientInfo(client)" ios-dblclick="editClient(client, currentGroup)"
ng-class="client.id == currentClientId ? 'active' : ''">
<div class="list-left">
<span class="w-30">
<i class="material-icons" style="font-size: 30px;">person</i>
@@ -74,18 +78,20 @@
</div>
</div>
</div>
<div class="p-a text-center">
<div class="btn-group" role="group">
<a class="btn btn-md btn-outline rounded b-info text-info" ng-class="{disabled:currentPage === 1}" ng-click="pager(currentPage=currentPage-1)"><</a>
<a class="btn btn-md btn-outline rounded b-info text-info" ng-class="{disabled:currentPage}">{{currentPage}}/{{pages}}</a>
<a class="btn btn-md btn-outline rounded b-info text-info" ng-class="{disabled:currentPage === pages}" ng-click="pager(currentPage=currentPage+1)">></a>
</div>
</div>
<div class="p-a text-center">
<div class="btn-group" role="group">
<a class="btn btn-md btn-outline rounded b-info text-info"
ng-class="{disabled:currentPage === 1}" ng-click="pager(currentPage=currentPage-1)"><</a>
<a class="btn btn-md btn-outline rounded b-info text-info" ng-class="{disabled:currentPage}">{{currentPage}}/{{pages}}</a>
<a class="btn btn-md btn-outline rounded b-info text-info"
ng-class="{disabled:currentPage === pages}" ng-click="pager(currentPage=currentPage+1)">></a>
</div>
</div>
<div class="text-center">
<a class="btn btn-md btn-outline rounded b-info text-info" ng-click="openFormCreateClient()">
<i class="fa fa-plus fa-fw m-r-xs"></i>Гость
</a>
<p></p>
<p></p>
</div>
</div>
</div>
@@ -93,203 +99,335 @@
<div class="col-sm-7">
<div class="padding" ng-if="currentClientId > 0">
<div class="box">
<div class="box-header">
<h2 class="text-center">{{currentClient.name}}</h2>
<h3 class="text-muted m-t">
<div class="col-sm-4 text-center">{{currentClient.info.address}}</div>
<div class="col-sm-4 text-center">{{currentClient.info.phone}}</div>
<div class="col-sm-4 text-center">{{currentClient.info.email}}</div>
</h3>
</div>
<div class="box-body b-t m-t">
{{currentClient.info.order_count}} заказов на сумму {{currentClient.info.order_sum}}
<hr>
<div class="table-responsive" ng-if="orders.length > 0">
<table class="table table-bordered table-hover">
<thead>
<tr>
<th>Открыт</th>
<th>Закрыт</th>
<th class="text-right">Сумма заказа</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="order in orders" ng-click="getItems(order)">
<td>{{ order.opened }}</td>
<td>{{ order.closed }}</td>
<td class="text-right">{{ order.sum }} BYN</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
</div>
<div class="padding" ng-if="isCreateNewGroup">
<div class="box">
<div class="box-header">
<h3>Создание новой группы</h3>
</div>
<div class="box-tool">
<div class="pull-right">
<a class="btn btn-sm white" ng-click="closeCard()">
<i class="material-icons">clear</i>
</a>
</div>
</div>
<form name="createGroupForm" ng-submit="createGroup()">
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Название</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newGroup.name" required>
</div>
</div>
</div>
<div class="dker p-a">
<div class="row">
<div class="item">
<div class="p-a-md">
<div class="row m-t">
<div class="col-sm-12">
<button type="submit" class="btn success p-x-md pull-right" ng-disabled="createGroupForm.$invalid">Создать</button>
<a href="" class="pull-left m-r-md">
<span class="avatar w-96">
<img src="../views/clients/images/client.png">
<i class="on b-white"></i>
</span>
</a>
<div class="clear m-b">
<h3 class="m-0 m-b-xs">{{currentClient.name}}</h3>
<p class="text-muted">
<span class="m-r">
<i class="fa fa-phone m-r-sm text-muted"></i>{{currentClient.info.phone}}
</span>
<small>
<i class="fa fa-map-marker m-r-xs"></i>{{currentClient.info.address}}
</small>
</p>
</div>
<div class="p-y text-center text-sm-center col-sm-12">
<a href="" class="inline p-x text-center">
<span class="h5 block m-0">{{currentClient.info.order_sum}} BYN</span>
<small class="text-xs text-muted">Сумма заказов</small>
</a>
<a href="" class="inline p-x b-l text-center">
<span class="h5 block m-0">{{currentClient.info.order_count}}</span>
<small class="text-xs text-muted">Кол-во заказов</small>
</a>
<a href="" class="inline p-x b-l b-r text-center"
ng-if="currentClient.info.presale > 0">
<span class="h5 block m-0">{{currentClient.info.presale}} BYN</span>
<small class="text-xs text-muted">Аванс</small>
</a>
<a href="" class="inline p-x text-center" ng-if="currentClient.info.bonus > 0">
<span class="h5 block m-0">{{currentClient.info.bonus}}</span>
<small class="text-xs text-muted">Бонусы</small>
</a>
</div>
</div>
</div>
</div>
</form>
</div>
</div>
<div class="padding" ng-if="isCreateNewBarcode">
<div class="box">
<div class="box-header">
<h3>Создание дисконтных карт</h3>
</div>
<div class="box-tool">
<div class="pull-right">
<a class="btn btn-sm white" ng-click="closeCard()">
<i class="material-icons">clear</i>
</a>
</div>
</div>
<form name="createBarcodeForm" ng-submit="createBarcode()">
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Выберите группу</label>
<div class="col-sm-9">
<select ng-model="newBarcode.group_id" class="form-control" ng-required="true">
<option ng-repeat="group in groups" value="{{ group.id }}">{{group.name}}</option>
</select>
</div>
</div>
</div>
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Первый штрих код</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newBarcode.start" placeholder="200000000001" required>
<div class="dker p-x">
<div class="row">
<div class="col-lg-12 col-sm-9">
<div class="p-y-md clearfix nav-active-primary">
<ul class="nav nav-pills nav-sm">
<li class="nav-item">
<a class="nav-link active" href="" data-toggle="tab" data-target="#tab_1"
aria-expanded="true">Журнал действий</a>
</li>
<li class="nav-item">
<a class="nav-link" href="" data-toggle="tab" data-target="#tab_2"
aria-expanded="false" ng-click="getOrders(currentClient.id)">Заказы</a>
</li>
<li class="nav-item">
<a class="nav-link" href="" data-toggle="tab" data-target="#tab_3"
aria-expanded="false">Информация</a>
</li>
</ul>
</div>
</div>
</div>
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Последний штрих код</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newBarcode.end" placeholder="200000000999" required>
</div>
</div>
</div>
<div class="dker p-a">
<div class="row">
<div class="col-sm-12">
<button type="submit" class="btn success p-x-md pull-right" ng-disabled="createBarcodeForm.$invalid">Создать</button>
</div>
</div>
</div>
</form>
</div>
</div>
<div class="padding" ng-if="isCreateNewClient">
<div class="box">
<div class="box-header">
<h3>Создание нового гостя</h3>
</div>
<div class="box-tool">
<div class="pull-right">
<a class="btn btn-sm white" ng-click="">
<i class="material-icons">clear</i>
</a>
</div>
</div>
<div class="padding">
<div class="row">
<div class="col-sm-8 col-lg-12">
<div class="tab-content">
<div class="tab-pane p-v-sm active" id="tab_1" aria-expanded="true">
<div class="streamline b-l m-b m-l"
style="width:auto;max-height:350px;overflow-y: auto;" ng-if="clientLogs.length > 0">
<div class="sl-item b-success" ng-repeat="clientLog in clientLogs">
<div class="sl-content" ng-if="clientLog.type == 2">
<div class="sl-date text-muted">{{clientLog.time}}</div>
<p>{{clientLog.action}} на сумму {{clientLog.value | curr}} BYN
пользователем {{clientLog.who}}</p>
</div>
<div class="sl-content" ng-if="clientLog.type == 1">
<div class="sl-date text-muted">{{clientLog.time}}</div>
<p>{{clientLog.action}} в количестве {{clientLog.value}} шт</p>
</div>
</div>
</div>
<div class="streamline b-l m-b m-l"
style="width:auto;overflow-y: auto;" ng-if="clientLogs.length == 0">
<div class="sl-item">
<div class="sl-content">
<p>Действия отсутствуют</p>
</div>
</div>
</div>
</div>
<div class="tab-pane p-v-sm" id="tab_2" aria-expanded="true">
<div class="streamline b-l m-b m-l"
style="width:auto;max-height:350px;overflow-y: auto;" ng-if="orders.length > 0">
<div class="sl-item b-success" ng-repeat="order in orders">
<div class="row align-items-center" style="margin-right: 0px;">
<div class="sl-content">
<div class="col-lg-12 col-sm-6">
<a ng-click="getItems(order.id, order.opened, order.closed)">
<div class="sl-date text-muted">Заказ открыт:
{{order.opened}}
</div>
<div class="sl-date text-muted">Заказ закрыт:
{{order.closed}}
</div>
<p>Сумма заказа: {{order.sum | curr}} BYN <span ng-if="order.discount > 0">(Скидка: {{order.discount | curr}} BYN)</span></p>
</a>
</div>
<form name="createClientForm" ng-submit="createClient()">
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Имя</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.name" required>
</div>
</div>
<div class="form-group row">
<label class="col-sm-3 form-control-label">Телефон</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.phone" ui-mask="+375 (99) 999-99-99">
</div>
</div>
<div class="form-group row">
<label class="col-sm-3 form-control-label">Адрес</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.address">
</div>
</div>
<div class="form-group row">
<label class="col-sm-3 form-control-label">Email</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.email">
</div>
</div>
<div class="form-group row">
<label class="col-sm-3 form-control-label">Штрих код</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.barcode">
</div>
</div>
<div class="form-group form-group-inline row">
<label class="col-sm-3 form-group-label" for="specialPriceCheck">Скидка по себестоимости </label>
<div class="col-sm-9">
<input class="form-group-input" type="checkbox" value="" id="specialPriceCheck" ng-model="newClient.special_price">
</div>
</div>
</div>
<div class="dker p-a">
<div class="row">
<div class="col-sm-12">
<button type="submit" class="btn success p-x-md pull-right" ng-disabled="createClientForm.$invalid">Создать</button>
</div>
</div>
</div>
</div>
<div class="streamline b-l m-b m-l"
style="width:auto;overflow-y: auto;" ng-if="orders.length == 0">
<div class="sl-item">
<div class="sl-content">
<p>Заказы отсутствуют</p>
</div>
</div>
</div>
</div>
<div class="tab-pane p-v-sm" id="tab_3">
<div class="row m-b">
<div class="col-xs-10">
<small class="text-muted">Телефон:</small>
<p>{{currentClient.info.phone}}</p>
</div>
</div>
<div class="row m-b">
<div class="col-xs-10">
<small class="text-muted">Адрес:</small>
<p>{{currentClient.info.address}}</p>
</div>
</div>
<div class="row m-b">
<div class="col-xs-10">
<small class="text-muted">Email:</small>
<p>{{currentClient.info.email}}</p>
</div>
</div>
</div>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
<div class="padding" ng-if="isCreateNewGroup">
<div class="box">
<div class="box-header">
<h3>Создание новой группы</h3>
</div>
<div class="box-tool">
<div class="pull-right">
<a class="btn btn-sm white" ng-click="closeCard()">
<i class="material-icons">clear</i>
</a>
</div>
</div>
<form name="createGroupForm" ng-submit="createGroup()">
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Название</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newGroup.name" required>
</div>
</div>
</div>
<div class="dker p-a">
<div class="row">
<div class="col-sm-12">
<button type="submit" class="btn success p-x-md pull-right"
ng-disabled="createGroupForm.$invalid">Создать
</button>
</div>
</div>
</div>
</form>
</div>
</div>
<div class="padding" ng-if="isCreateNewBarcode">
<div class="box">
<div class="box-header">
<h3>Создание дисконтных карт</h3>
</div>
<div class="box-tool">
<div class="pull-right">
<a class="btn btn-sm white" ng-click="closeCard()">
<i class="material-icons">clear</i>
</a>
</div>
</div>
<form name="createBarcodeForm" ng-submit="createBarcode()">
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Выберите группу</label>
<div class="col-sm-9">
<select ng-model="newBarcode.group_id" class="form-control" ng-required="true">
<option ng-repeat="group in groups" value="{{ group.id }}">{{group.name}}</option>
</select>
</div>
</div>
</div>
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Первый штрих код</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newBarcode.start"
placeholder="200000000001" required>
</div>
</div>
</div>
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Последний штрих код</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newBarcode.end"
placeholder="200000000999" required>
</div>
</div>
</div>
<div class="dker p-a">
<div class="row">
<div class="col-sm-12">
<button type="submit" class="btn success p-x-md pull-right"
ng-disabled="createBarcodeForm.$invalid">Создать
</button>
</div>
</div>
</div>
</form>
</div>
</div>
<div class="padding" ng-if="isCreateNewClient">
<div class="box">
<div class="box-header">
<h3>Создание нового гостя</h3>
</div>
<div class="box-tool">
<div class="pull-right">
<a class="btn btn-sm white" ng-click="">
<i class="material-icons">clear</i>
</a>
</div>
</div>
<form name="createClientForm" ng-submit="createClient()">
<div class="box-body">
<div class="form-group row">
<label class="col-sm-3 form-control-label">Имя</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.name" required>
</div>
</div>
<div class="form-group row">
<label class="col-sm-3 form-control-label">Телефон</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.phone"
ui-mask="+375 (99) 999-99-99">
</div>
</div>
<div class="form-group row">
<label class="col-sm-3 form-control-label">Адрес</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.address">
</div>
</div>
<div class="form-group row">
<label class="col-sm-3 form-control-label">Email</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.email">
</div>
</div>
<div class="form-group row">
<label class="col-sm-3 form-control-label">Штрих код</label>
<div class="col-sm-9">
<input type="text" class="form-control" ng-model="newClient.barcode">
</div>
</div>
<div class="form-group form-group-inline row">
<label class="col-sm-3 form-group-label" for="specialPriceCheck">Скидка по
себестоимости </label>
<div class="col-sm-9">
<input class="form-group-input" type="checkbox" value="" id="specialPriceCheck"
ng-model="newClient.special_price">
</div>
</div>
</div>
<div class="dker p-a">
<div class="row">
<div class="col-sm-12">
<button type="submit" class="btn success p-x-md pull-right"
ng-disabled="createClientForm.$invalid">Создать
</button>
</div>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
<div class="modal fade" id="edit-client" data-backdrop="true" ng-if="!readonlyMode">
<div ui-include="'../views/clients/edit_client.html'"></div>

View File

@@ -2,33 +2,68 @@
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">&times;</button>
<h5 class="modal-title">История заказа</h5>
<span class="text-muted">{{order.opened}} - {{order.closed}}</span>
<p>
Номер заказа: <strong>#{{order.order_id}}</strong><br>
Время закрытия: <strong>{{order.closed}}</strong><br>
Персонал: <strong>{{order.who_close}}</strong><br>
Статус заказа: <span class="label success">{{order.order_status}}</span><br>
</p>
</div>
<div class="modal-body p-lg">
<div class="table-responsive">
<table class="table table-bordered">
<table class="table table-striped white b-a">
<thead>
<tr>
<th>Блюдо</th>
<th>Количество</th>
<th class="text-right">Сумма, BYN</th>
</tr>
<tr>
<th>ID</th>
<th>Блюдо</th>
<th style="width: 80px">Кол-во</th>
<th style="width: 140px">Стоимость</th>
<th style="width: 180px">Итог</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="item in order.items">
<td>{{item.name}}</td>
<td>{{item.count}}</td>
<td class="text-right">{{item.amount}}</td>
</tr>
<tr ng-repeat="item in order.items">
<td>{{item.id}}</td>
<td>{{item.name}}</td>
<td>{{item.count * item.cof}}</td>
<td>{{item.price | curr}} BYN</td>
<td>{{item.amount | curr}} BYN <p ng-if="item.discount > 0">
<span>(Скидка: {{item.discount}}%)</span></p></td>
</tr>
<tr>
<td colspan="4" class="text-right"><strong>Итого</strong></td>
<td>{{order.amount | curr}} BYN</td>
</tr>
<tr>
<td colspan="4" class="text-right no-border" ng-if="order.full_price - order.amount > 0">
<strong>Сумма скидки</strong></td>
<td ng-if="order.full_price - order.amount > 0">{{order.full_price - order.amount | curr}} BYN
</td>
</tr>
<tr>
<td colspan="4" class="text-right no-border"><strong>Оплачено:</strong></td>
</tr>
<tr ng-if="order.cash > 0">
<td colspan="5" class="text-right no-border">Наличные: <strong>{{order.cash
| curr}} BYN</strong></td>
</tr>
<tr ng-if="order.credit > 0">
<td colspan="5" class="text-right no-border">Кред. карта: <strong>{{order.credit | curr}}
BYN</strong></td>
</tr>
<tr ng-if="order.clearing > 0">
<td colspan="5" class="text-right no-border">Питание штата: <strong>{{order.clearing | curr}}
BYN</strong>
</tr>
<tr ng-if="order.presale > 0">
<td colspan="5" class="text-right no-border">Зачтен аванс: <strong>{{order.presale | curr}}
BYN</strong></td>
</tr>
<tr ng-if="order.self > 0">
<td colspan="5" class="text-right no-border">Безнал: <strong>{{order.self | curr}} BYN</strong>
</td>
</tr>
</tbody>
<thead>
<tr>
<th colspan="2"></th>
<th class="text-right">Итого: {{ order.amount | curr }} BYN</th>
</tr>
</thead>
</table>
</div>
</div>

View File

@@ -107,7 +107,7 @@
<div class="col-sm-6 col-md-4 one-height">
<div class="box">
<div class="box-header danger">
<h3>Удаления</h3>
<h3>Удаления: {{deleted}}</h3>
</div>
<div class="box-tool box-tool-white">
@@ -123,11 +123,10 @@
<div class="box-body b-t">
<h4 class="m-a-0 text-md" ng-if="deleted > 0">
<a>
{{deleted}}
<span class="text-sm">на сумму</span> {{deleted_sum | curr}}
<span class="text-sm lead"><strong>Сумма: {{deleted_sum | curr}} BYN</strong></span>
</a>
</h4>
<span class="text-muted" ng-if="deleted == 0">Удаленных позиций нет</h4>
<span class="text-muted" ng-if="deleted == 0">Удаленных позиций нет</span>
</div>
</div>
</div>
@@ -136,7 +135,7 @@
<div class="box">
<div class="box-header primary">
<h3>
Заказы со скидками
Заказы со скидками: {{discounts}}
</h3>
</div>
@@ -153,11 +152,10 @@
<div class="box-body b-t">
<h4 class="m-a-0 text-md" ng-if="discounts > 0">
<a>
{{discounts}}
<span class="text-sm">на сумму </span> {{tot_disc_sum | curr}}
<span class="text-sm lead"><strong>Сумма: {{tot_disc_sum | curr}} BYN</strong></span>
</a>
</h4>
<span class="text-muted" ng-if="discounts == 0">Заказов со скидками нет</h4>
<span class="text-muted" ng-if="discounts == 0">Заказов со скидками нет</span>
</div>
</div>
</div>
@@ -185,10 +183,9 @@
<h4 class="m-a-0 text-md" ng-if="namedGuests > 0">
<a>
<span class="text-sm lead"><strong>Сумма заказов: {{sumNamedGuests | curr}} BYN</strong></span>
</a>
</h4>
<span class="text-muted" ng-if="namedGuests == 0">Именованных гостей нет</h4>
<span class="text-muted" ng-if="namedGuests == 0">Именованных гостей нет</span>
</div>
</div>
</div>

View File

@@ -0,0 +1,32 @@
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">Создание скидки</h5>
</div>
<div class="modal-body text-center p-lg">
<form role="form" class="ng-pristine ng-valid container">
<div class="form-group row">
<div class="col-sm-12"><input class="form-control" placeholder="Название" type="text" ng-model="currentDiscount.name"></div>
</div>
<div class="form-group row">
<div class="col-sm-6">
<select class="form-control" ng-model="currentDiscount.value_type">
<option value="0">Процент</option>
<option value="1">Сумма</option>
</select>
</div>
<div class="col-sm-6">
<input class="form-control" placeholder="Значение" type="text" ng-model="currentDiscount.value">
</div>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn dark-white p-x-md" data-dismiss="modal">Отмена</button>
<button type="button" class="btn success p-x-md" ng-click="create()">Создать</button>
</div>
</div>
</div>

234
web/views/loyalty/edit.html Normal file
View File

@@ -0,0 +1,234 @@
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">Редактирование скидки</h5>
</div>
<div class="modal-body text-center p-lg">
<form role="form" class="ng-pristine ng-valid container">
<div class="form-group row">
<div class="col-sm-12">
<input class="form-control" placeholder="Название" type="text" ng-model="currentDiscount.name">
</div>
</div>
<div class="form-group row">
<div class="col-sm-6">
<select class="form-control" ng-model="currentDiscount.value_type">
<option value="0">Процент</option>
<option value="1">Сумма</option>
</select>
</div>
<div class="col-sm-6">
<input class="form-control" placeholder="Значение" type="text" ng-model="currentDiscount.value">
</div>
</div>
<div class="form-group row" style="text-align: left">
<div class="col-sm-12">
<div class="checkbox-group" style="display: inline-block; width: auto; margin-right: 50px">
<label class="ui-switch ui-switch-md m-t-xs">
<input type="checkbox" ng-model="currentDiscount.is_enable">
<i></i>
</label>
<label class="ui-switch-info">Активна</label>
</div>
<div class="checkbox-group" style="display: inline-block; width: auto">
<label class="ui-switch ui-switch-md m-t-xs">
<input type="checkbox" ng-model="currentDiscount.is_check_all">
<i></i>
</label>
<label class="ui-switch-info">Проверять все условия</label>
</div>
</div>
</div>
<hr/>
<div class="form-group row">
<div class="col-sm-12">
<label>Время действия скидки</label>
</div>
</div>
<div class="form-group row">
<div class="col-sm-6">
<div class='input-group date' ui-jp="datetimepicker" ui-options="{
format: 'DD.MM.YYYY',
icons: {
time: 'fa fa-clock-o',
date: 'fa fa-calendar',
up: 'fa fa-chevron-up',
down: 'fa fa-chevron-down',
previous: 'fa fa-chevron-left',
next: 'fa fa-chevron-right',
today: 'fa fa-screenshot',
clear: 'fa fa-trash',
close: 'fa fa-remove'
}
}">
<input type='text' class="form-control" placeholder="С" ng-model="currentDiscount.start_date" />
<span class="input-group-addon">
<i class="material-icons">&#xE916;</i>
</span>
</div>
</div>
<div class="col-sm-6">
<div class='input-group date' ui-jp="datetimepicker" ui-options="{
format: 'DD.MM.YYYY',
icons: {
time: 'fa fa-clock-o',
date: 'fa fa-calendar',
up: 'fa fa-chevron-up',
down: 'fa fa-chevron-down',
previous: 'fa fa-chevron-left',
next: 'fa fa-chevron-right',
today: 'fa fa-screenshot',
clear: 'fa fa-trash',
close: 'fa fa-remove'
}
}">
<input type='text' class="form-control" placeholder="По" ng-model="currentDiscount.end_date" />
<span class="input-group-addon">
<i class="material-icons">&#xE916;</i>
</span>
</div>
</div>
</div>
<hr/>
<div class="form-group row">
<label>Условия</label>
</div>
<div class="form-group row">
<div class="col-sm-9">
<select ng-model="currentDiscount.new_term_type" class="form-control">
<option ng-repeat="term in terms" value="{{ term.code }}">{{ term.name }}</option>
</select>
</div>
<div class="col-sm-3">
<button class="btn" style="width: 100%" ng-click="addTerm()">Добавить</button>
</div>
</div>
<div class="form-group row" ng-repeat="term in currentTerms">
<div class="col-sm-12">
<div class="term-item">
<div style="height: 30px" class="term-header" onclick="toggleTerm(this)">
<strong>
<i class="material-icons term-icon">&#xE313;</i> {{ term.discount_type_name }}</strong>
<button class="btn btn-xs btn-danger pull-right" ng-click="askDeleteTerm(term)" onclick="event.stopPropagation()">
<i class="material-icons">&#xE872;</i>
</button>
</div>
<div class="term-content">
<div class="form-group row">
<div class="col-sm-{{ 12 / term.params.length }}" ng-repeat="param in term.params">
<label>{{ param.name }}</label>
<input type="text" class="form-control" ng-model="param.value" ng-if="param.type == 'Integer'" />
<select class="form-control" ng-model="param.value" ng-if="param.type == 'Select'">
<option value="">Выбрать</option>
<option ng-repeat="option in param.options" value="{{ option.code }}">{{ option.name }}
</option>
</select>
<div ng-if="param.type == 'Time'" class='input-group date' ui-jp="datetimepicker" style="border-right: 1px solid rgba(120, 130, 140, 0.2)"
ui-options="{
format: 'LT',
icons: {
time: 'fa fa-clock-o',
date: 'fa fa-calendar',
up: 'fa fa-chevron-up',
down: 'fa fa-chevron-down',
previous: 'fa fa-chevron-left',
next: 'fa fa-chevron-right',
today: 'fa fa-screenshot',
clear: 'fa fa-trash',
close: 'fa fa-remove'
}
}">
<input type='text' class="form-control" ng-model="param.value" />
<span class="input-group-addon">
<i class="material-icons">&#xE916;</i>
</span>
<script type="text/javascript">
$('.date').on('dp.change', function () {
$(this).find('input').trigger('change');
});
</script>
</div>
<div ng-if="param.type == 'SelectMenuItem' || param.type == 'SelectClientItem'">
<div class="row">
<div class="col-sm-9" style="padding-right: 0">
<div style="border: 1px solid #efefef; min-height: 38px" class="form-control">
{{ param.info }}
</div>
</div>
<div class="col-sm-3" style="padding-left: 0">
<button class="btn" style="width: 100%" ng-click="editTermParam(param)">
<i class="material-icons">&#xE254;</i>
</button>
</div>
</div>
</div>
</div>
</div>
<hr/>
<div class="form-group" style="text-align: left">
<div class="checkbox-group">
<label class="ui-switch danger ui-switch-md m-t-xs">
<input type="checkbox" ng-model="term.is_term">
<i></i>
</label>
<label class="ui-switch-info">Исключающее условие</label>
</div>
</div>
</div>
</div>
</div>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn danger p-x-md pull-left" data-toggle="modal" data-target="#edit-discount-confirm-delete">
<i class="material-icons">&#xE872;</i>
</button>
<button type="button" class="btn dark-white p-x-md" data-dismiss="modal">Отмена</button>
<button type="button" class="btn success p-x-md" ng-click="save()">Сохранить</button>
</div>
</div>
</div>
<script type="text/javascript" src="/libs/js/moment/locale/ru.js"></script>
<script type="text/javascript">
function toggleTerm(el) {
var content = $(el).parent().find('.term-content');
if (content.css('display') !== 'block') {
content.slideDown('normal');
}
else {
content.slideUp('fast');
}
}
</script>

View File

@@ -0,0 +1,79 @@
<div id="container-floating">
<div class="nd3 nds" data-toggle="tooltip" data-placement="left" title="Добавить" ng-click="add()" ng-if="!readonlyMode" style="background-color: #3c80f6" onmouseenter="$(this).tooltip('show')">
<i class="material-icons">&#xE145;</i>
</div>
<div class="nd1 nds" data-toggle="tooltip" data-placement="left" title="Обновить" ng-click="update()" style="background-color: #d3a411" onmouseenter="$(this).tooltip('show')">
<i class="material-icons">&#xE5D5;</i>
</div>
<div id="floating-button" data-toggle="tooltip" data-placement="left" title="Действия" onmouseenter="$(this).tooltip('show')">
<p class="plus"><i class="material-icons">&#xE5D2;</i></p>
<p class="edit"><i class="material-icons">&#xE5CD;</i></p>
</div>
</div>
<div class="padding">
<div class="box">
<div class="table-responsive">
<table class="table table-bordered m-a-0 table-hover">
<thead>
<tr>
<th>Название</th>
<th style="width: 120px; text-align: center">Значение</th>
<th style="width: 80px; text-align: center">Условия</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="discount in discounts" ng-click="edit(discount)">
<td>{{ discount.name }}</td>
<td style="text-align: center">{{ discount.value_type == 0 ? discount.value + '%' : discount.value + ' BYN' }}</td>
<td style="text-align: center">{{ discount.terms_count }}</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
<div class="modal fade" id="new-discount" data-backdrop="true" ng-if="!readonlyMode">
<div ui-include="'../views/discounts/create.html'"></div>
</div>
<div class="modal fade" id="edit-discount" data-backdrop="true" ng-if="!readonlyMode">
<div ui-include="'../views/discounts/edit.html'"></div>
</div>
<div id="edit-discount-confirm-delete" class="modal confirm-box" data-backdrop="true" style="z-index: 1052">
<div class="bottom white b-b" style="height: 90px">
<div class="confirm-box-body p-lg">
<p>Вы действительно хотите удалить скидку?</p>
</div>
<div class="confirm-box-footer">
<button type="button" class="btn dark-white p-x-md" data-dismiss="modal">Нет</button>
<button type="button" class="btn danger p-x-md" ng-click="delete()">Да</button>
</div>
</div>
</div>
<div id="edit-term-confirm-delete" class="modal confirm-box" data-backdrop="true" style="z-index: 1052">
<div class="bottom white b-b" style="height: 90px">
<div class="confirm-box-body p-lg">
<p>Вы действительно хотите удалить условие скидки?</p>
</div>
<div class="confirm-box-footer">
<button type="button" class="btn dark-white p-x-md" data-dismiss="modal">Нет</button>
<button type="button" class="btn danger p-x-md" ng-click="deleteTerm()">Да</button>
</div>
</div>
</div>
<div class="modal fade" id="edit-selectmenuitem" data-backdrop="true" style="z-index: 1052">
<div ui-include="'../views/discounts/terms/selectmenuitem.html'"></div>
</div>
<div class="modal fade" id="edit-selectclientitem" data-backdrop="true" style="z-index: 1052">
<div ui-include="'../views/discounts/terms/selectclientitem.html'"></div>
</div>

View File

@@ -0,0 +1,65 @@
<div class="modal-dialog modal-list">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">Выбор клиента</h5>
</div>
<div class="modal-body p-lg">
<div ng-if="selectClientItemParams.isParent == false">
<div class="list-item pointer no_selection" ios-dblclick="upGroup()">
<div class="list-left">
<span class="w-30">
<i class="material-icons" style="font-size: 30px;">&#xE2C7;</i>
</span>
</div>
<div class="list-body" style="line-height: 30px">...</div>
</div>
</div>
<div class="list inset" ng-repeat="group in selectClientItemParams.groups">
<div class="list-item pointer no_selection" sglclick="selectItem(group.id, 'client_group', group.name)"
ios-dblclick="openGroup(group)"
ng-class="group.id == selectedElement.value && selectedElement.type == 'client_group' ? 'active' : ''">
<div class="list-left">
<span class="w-30">
<i class="material-icons" style="font-size: 30px;">&#xE2C7;</i>
</span>
</div>
<div class="list-body" style="line-height: 30px">
{{ group.name }}
</div>
</div>
</div>
<div class="list inset" ng-repeat="client in selectClientItemParams.clients">
<div class="list-item pointer no_selection" ng-click="selectItem(client.id, 'client', client.name)"
ng-class="client.id == selectedElement.value && selectedElement.type == 'client' ? 'active' : ''">
<div class="list-left">
<span class="w-30">
<i class="material-icons" style="font-size: 30px;">&#xE893;</i>
</span>
</div>
<div class="list-body" style="line-height: 30px">
{{ client.name }}
</div>
</div>
</div>
</div>
<div class="p-a text-center">
<div class="btn-group" role="group">
<a class="btn btn-md btn-outline rounded b-info text-info" ng-class="{disabled:currentPage === 1}" ng-click="pager(currentPage=currentPage-1)"><</a>
<a class="btn btn-md btn-outline rounded b-info text-info" ng-class="{disabled:currentPage}">{{currentPage}}/{{pages}}</a>
<a class="btn btn-md btn-outline rounded b-info text-info" ng-class="{disabled:currentPage === pages}" ng-click="pager(currentPage=currentPage+1)">></a>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn dark-white p-x-md" data-dismiss="modal">Отмена</button>
<button type="button" class="btn success p-x-md" ng-disabled="selectedElement.value == 0"
ng-click="confirmSelect()">Выбрать
</button>
</div>
</div>
</div>

View File

@@ -0,0 +1,82 @@
<div class="modal-dialog modal-list">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title">Выбор элемента меню</h5>
</div>
<div class="modal-body p-lg">
<div ng-if="selectMenuItemParams.currentMenu > 0">
<div class="list-item pointer no_selection" ios-dblclick="upMenuItem()">
<div class="list-left">
<span class="w-30">
<i class="material-icons" style="font-size: 30px;">&#xE2C7;</i>
</span>
</div>
<div class="list-body" style="line-height: 30px">...</div>
</div>
</div>
<div ng-if="selectMenuItemParams.currentMenu == 0">
<div class="list inset" ng-repeat="menu in selectMenuItemParams.menus">
<div class="list-item pointer no_selection" ios-dblclick="openMenuItem(menu)"
sglclick="selectItem(menu.id, 'menu', menu.name)"
ng-class="menu.id == selectedElement.value && selectedElement.type == 'menu' ? 'active' : ''">
<div class="list-left">
<span class="w-30">
<i class="material-icons" style="font-size: 30px;">&#xE2C7;</i>
</span>
</div>
<div class="list-body" style="line-height: 30px">
{{ menu.name }}
</div>
</div>
</div>
</div>
<div ng-if="selectMenuItemParams.currentMenu > 0">
<div class="list inset" ng-repeat="folder in selectMenuItemParams.folders">
<div class="list-item pointer no_selection" ios-dblclick="openFolderItem(folder)"
sglclick="selectItem(folder.id, 'folder', folder.name)"
ng-class="folder.id == selectedElement.value && selectedElement.type == 'folder' ? 'active' : ''">
<div class="list-left">
<span class="w-30">
<i class="material-icons" style="font-size: 30px;">&#xE2C7;</i>
</span>
</div>
<div class="list-body" style="line-height: 30px">
{{ folder.name }}
</div>
</div>
</div>
</div>
<div ng-if="selectMenuItemParams.currentMenu > 0">
<div class="list inset" ng-repeat="item in selectMenuItemParams.items">
<li class="list-item pointer no_selection" ng-click="selectItem(item.id, 'item', item.name)"
ng-class="item.id == selectedElement.value && selectedElement.type == 'item' ? 'active' : ''">
<div class="list-left">
<span class="w-30">
<i class="material-icons" style="font-size: 30px;">&#xE893;</i>
</span>
</div>
<div class="list-body">
{{ item.name }} <span class="text-muted">#{{ item.code }}</span>
<small class="block text-muted">{{ item.cosht | curr }} BYN</small>
</div>
</li>
</div>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn dark-white p-x-md" data-dismiss="modal">Отмена</button>
<button type="button" class="btn success p-x-md" ng-disabled="selectedElement.value == 0"
ng-click="confirmSelect()">Выбрать
</button>
</div>
</div>
</div>