1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-10 00:46:15 +01:00
fab-manager/app/assets/javascripts/controllers/admin/coupons.js

131 lines
4.0 KiB
JavaScript
Raw Normal View History

/* eslint-disable
no-return-assign,
no-undef,
*/
// TODO: This file was created by bulk-decaffeinate.
// Fix any style issues and re-enable lint.
/*
* decaffeinate suggestions:
* DS102: Remove unnecessary code created because of implicit returns
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
*/
/* COMMON CODE */
// The validity per user defines how many time a user may ba able to use the same coupon
// Here are the various options for this parameter
2018-11-21 11:08:53 +01:00
const userValidities = ['once', 'forever'];
/**
* Controller used in the coupon creation page
*/
Application.Controllers.controller('NewCouponController', ['$scope', '$state', 'Coupon', 'growl', '_t',
function ($scope, $state, Coupon, growl, _t) {
// Values for the coupon currently created
$scope.coupon = {
active: true,
type: 'percent_off'
2018-11-21 11:08:53 +01:00
};
2016-08-08 12:08:09 +02:00
// Options for the validity per user
2018-11-21 11:08:53 +01:00
$scope.validities = userValidities;
// Default parameters for AngularUI-Bootstrap datepicker (used for coupon validity limit selection)
$scope.datePicker = {
format: Fablab.uibDateFormat,
opened: false, // default: datePicker is not shown
minDate: moment().toDate(),
options: {
startingDay: Fablab.weekStartingDay
}
2018-11-21 11:08:53 +01:00
};
2016-08-08 12:08:09 +02:00
/**
* Shows/hides the validity limit datepicker
* @param $event {Object} jQuery event object
*/
$scope.toggleDatePicker = function ($event) {
2018-11-21 11:08:53 +01:00
$event.preventDefault();
$event.stopPropagation();
return $scope.datePicker.opened = !$scope.datePicker.opened;
};
2016-08-08 12:08:09 +02:00
/**
* Callback to save the new coupon in $scope.coupon and redirect the user to the listing page
*/
return $scope.saveCoupon = () =>
Coupon.save({ coupon: $scope.coupon }, coupon => $state.go('app.admin.pricing')
, function (err) {
2018-11-21 11:08:53 +01:00
growl.error(_t('unable_to_create_the_coupon_check_code_already_used'));
return console.error(err);
});
}
2018-11-21 11:08:53 +01:00
]);
/**
* Controller used in the coupon edition page
*/
Application.Controllers.controller('EditCouponController', ['$scope', '$state', 'Coupon', 'couponPromise', '_t', 'growl',
function ($scope, $state, Coupon, couponPromise, _t, growl) {
/* PUBLIC SCOPE */
2016-08-04 18:13:19 +02:00
// Used in the form to freeze unmodifiable fields
2018-11-21 11:08:53 +01:00
$scope.mode = 'EDIT';
2016-08-04 18:13:19 +02:00
// Coupon to edit
2018-11-21 11:08:53 +01:00
$scope.coupon = couponPromise;
2016-08-08 12:08:09 +02:00
// Options for the validity per user
2018-11-21 11:08:53 +01:00
$scope.validities = userValidities;
2016-08-08 12:08:09 +02:00
// Mapping for validation errors
2018-11-21 11:08:53 +01:00
$scope.errors = {};
// Default parameters for AngularUI-Bootstrap datepicker (used for coupon validity limit selection)
$scope.datePicker = {
format: Fablab.uibDateFormat,
opened: false, // default: datePicker is not shown
minDate: moment().toDate(),
options: {
startingDay: Fablab.weekStartingDay
}
2018-11-21 11:08:53 +01:00
};
2016-08-08 12:08:09 +02:00
/**
* Shows/hides the validity limit datepicker
* @param $event {Object} jQuery event object
*/
$scope.toggleDatePicker = function ($event) {
2018-11-21 11:08:53 +01:00
$event.preventDefault();
$event.stopPropagation();
return $scope.datePicker.opened = !$scope.datePicker.opened;
};
2016-08-08 12:08:09 +02:00
/**
* Callback to save the coupon's changes to the API
*/
$scope.updateCoupon = function () {
2018-11-21 11:08:53 +01:00
$scope.errors = {};
return Coupon.update({ id: $scope.coupon.id }, { coupon: $scope.coupon }, coupon => $state.go('app.admin.pricing')
, function (err) {
2018-11-21 11:08:53 +01:00
growl.error(_t('unable_to_update_the_coupon_an_error_occurred'));
return $scope.errors = err.data;
});
};
2016-08-08 12:08:09 +02:00
/* PRIVATE SCOPE */
2016-08-08 12:08:09 +02:00
/**
* Kind of constructor: these actions will be realized first when the controller is loaded
*/
const initialize = function () {
// parse the date if any
if (couponPromise.valid_until) {
2018-11-21 11:08:53 +01:00
return $scope.coupon.valid_until = moment(couponPromise.valid_until).toDate();
}
2018-11-21 11:08:53 +01:00
};
2016-08-08 12:08:09 +02:00
// !!! MUST BE CALLED AT THE END of the controller
2018-11-21 11:08:53 +01:00
return initialize();
}
2018-11-21 11:08:53 +01:00
]);