Skip to content
Code-Schnipsel Gruppen Projekte
Bestätigt Commit 011cdabf erstellt von Henning Leutz's avatar Henning Leutz :martial_arts_uniform:
Dateien durchsuchen

feat: simple checkout support

Übergeordneter 13959a9e
No related branches found
No related tags found
2 Merge Requests!15Update 'next-3.x' with latest changes from 'main',!14Next 2.x
Pipeline #12428 mit Warnungen bestanden mit Phase
in 3 Minuten und 2 Sekunden
...@@ -29,3 +29,26 @@ div + .quiqqer-coupons-field { ...@@ -29,3 +29,26 @@ div + .quiqqer-coupons-field {
.quiqqer-coupons-remove .fa { .quiqqer-coupons-remove .fa {
margin-right: 0; margin-right: 0;
} }
/**
* Simple Checkout
*/
.quiqqer-coupons-field-simpleCheckout {
margin-top: 20px;
margin-left: 0 !important;
}
.quiqqer-coupons-field-simpleCheckout .quiqqer-coupons-couponcodeinput {
background: var(--_sectionBgColor);
display: flex;
padding: var(--_sectionPadding);
}
.quiqqer-coupons-field-simpleCheckout .quiqqer-coupons-couponcodeinput label {
flex-grow: 1;
}
.quiqqer-coupons-field-simpleCheckout .quiqqer-coupons-couponcodeinput-input {
width: calc(100% - 1rem);
}
\ No newline at end of file
...@@ -20,25 +20,25 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -20,25 +20,25 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
'text!package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput.html', 'text!package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput.html',
'css!package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput.css' 'css!package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput.css'
], function (QUI, QUIControl, QUILoader, Sessions, CouponCodes, QUIAjax, QUILocale, Mustache, template) { ], function(QUI, QUIControl, QUILoader, Sessions, CouponCodes, QUIAjax, QUILocale, Mustache, template) {
"use strict"; 'use strict';
var lg = 'quiqqer/coupons'; var lg = 'quiqqer/coupons';
return new Class({ return new Class({
Extends: QUIControl, Extends: QUIControl,
Type : 'package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', Type: 'package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput',
Binds: [ Binds: [
'$submit' '$submit'
], ],
initialize: function (options) { initialize: function(options) {
this.parent(options); this.parent(options);
this.$Input = null; this.$Input = null;
this.Loader = new QUILoader(); this.Loader = new QUILoader();
this.$running = false; this.$running = false;
this.addEvents({ this.addEvents({
...@@ -49,23 +49,27 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -49,23 +49,27 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
/** /**
* Event: onInject * Event: onInject
*/ */
$onInject: function () { $onInject: function() {
var self = this; var self = this;
var lgPrefix = 'controls.frontend.CouponCodeInput.template.'; var lgPrefix = 'controls.frontend.CouponCodeInput.template.';
this.$Elm.addClass('quiqqer-coupons-field'); this.$Elm.addClass('quiqqer-coupons-field');
if (this.$Elm.getParent('[data-name="quiqqer-simple-checkout"]')) {
this.$Elm.addClass('quiqqer-coupons-field-simpleCheckout');
}
this.$Elm.set('html', Mustache.render(template, { this.$Elm.set('html', Mustache.render(template, {
labelInput : QUILocale.get(lg, lgPrefix + 'labelInput'), labelInput: QUILocale.get(lg, lgPrefix + 'labelInput'),
labelInputPlaceholder: QUILocale.get(lg, lgPrefix + 'labelInputPlaceholder'), labelInputPlaceholder: QUILocale.get(lg, lgPrefix + 'labelInputPlaceholder'),
submitBtnText : QUILocale.get(lg, lgPrefix + 'submitBtnText') submitBtnText: QUILocale.get(lg, lgPrefix + 'submitBtnText')
})); }));
this.Loader.inject(this.$Elm); this.Loader.inject(this.$Elm);
this.$Input = this.$Elm.getElement('input[name="code"]'); this.$Input = this.$Elm.getElement('input[name="code"]');
this.$Input.addEvent('keyup', function (event) { this.$Input.addEvent('keyup', function(event) {
if (event.code === 13) { if (event.code === 13) {
self.$submit(); self.$submit();
} }
...@@ -73,7 +77,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -73,7 +77,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
this.$Elm.getElement( this.$Elm.getElement(
'button.quiqqer-coupons-couponcodeinput-btn' 'button.quiqqer-coupons-couponcodeinput-btn'
).addEvent('click', function (event) { ).addEvent('click', function(event) {
event.stop(); event.stop();
self.$submit(); self.$submit();
}); });
...@@ -81,23 +85,23 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -81,23 +85,23 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
if (this.isInOrder()) { if (this.isInOrder()) {
var OrderProcess = this.getOrderProcess(); var OrderProcess = this.getOrderProcess();
new Promise(function (resolve) { new Promise(function(resolve) {
if (!OrderProcess.isLoaded()) { if (!OrderProcess.isLoaded()) {
return OrderProcess.addEvent('onLoad', resolve); return OrderProcess.addEvent('onLoad', resolve);
} }
resolve(); resolve();
}).then(function () { }).then(function() {
if (OrderProcess.getAttribute('basketEditable') === false) { if (OrderProcess.getAttribute('basketEditable') === false) {
// remove coupon codes button // remove coupon codes button
new Element('button', { new Element('button', {
'class': 'quiqqer-coupons-remove', 'class': 'quiqqer-coupons-remove',
'html' : '<span class="fa fa-close"></span>', 'html': '<span class="fa fa-close"></span>',
title : QUILocale.get(lg, 'remove.coupons.button'), title: QUILocale.get(lg, 'remove.coupons.button'),
events : { events: {
click: function (e) { click: function(e) {
e.stop(); e.stop();
self.removeCouponsFromOrder().catch(function (e) { self.removeCouponsFromOrder().catch(function(e) {
console.error(e); console.error(e);
}); });
} }
...@@ -111,7 +115,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -111,7 +115,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
/** /**
* Submit a CouponCode * Submit a CouponCode
*/ */
$submit: function () { $submit: function() {
if (this.$running) { if (this.$running) {
return; return;
} }
...@@ -127,18 +131,51 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -127,18 +131,51 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
this.$running = true; this.$running = true;
this.Loader.show(); this.Loader.show();
// simple order
const SimpleCheckoutNode = this.getElm().getParent('[data-name="quiqqer-simple-checkout"]');
if (SimpleCheckoutNode) {
const SimpleCheckout = QUI.Controls.getById(SimpleCheckoutNode.get('data-quiid'));
QUIAjax.get('package_quiqqer_order-simple-checkout_ajax_frontend_getOrder', (response) => {
CouponCodes.addCouponCodeToBasket(code, response.order.uuid).then(() => {
if (SimpleCheckout) {
SimpleCheckout.$refreshBasket().then(() => {
this.$running = false;
this.Loader.hide();
});
return;
}
this.$running = false;
this.Loader.hide();
}).catch((err) => {
console.error(err);
this.$running = false;
this.Loader.hide();
});
}, {
'package': 'quiqqer/order-simple-checkout',
orderHash: window.location.hash.substring(1)
});
return;
}
// get order process // get order process
if (!this.isInOrder()) { if (!this.isInOrder()) {
QUIAjax.get('package_quiqqer_order_ajax_frontend_basket_getLastOrder', function (order) { QUIAjax.get('package_quiqqer_order_ajax_frontend_basket_getLastOrder', function(order) {
CouponCodes.addCouponCodeToBasket(code, order.hash).then(function (redeemed) { CouponCodes.addCouponCodeToBasket(code, order.hash).then(function(redeemed) {
if (!redeemed) { if (!redeemed) {
self.$running = false; self.$running = false;
self.Loader.hide(); self.Loader.hide();
return; return;
} }
self.$addCouponCodeToSession(code).then(function () { self.$addCouponCodeToSession(code).then(function() {
QUIAjax.get('package_quiqqer_order_ajax_frontend_basket_getOrderProcessUrl', function (url) { QUIAjax.get('package_quiqqer_order_ajax_frontend_basket_getOrderProcessUrl', function(url) {
window.location = url + '?coupon=' + code; window.location = url + '?coupon=' + code;
}, { }, {
'package': 'quiqqer/order' 'package': 'quiqqer/order'
...@@ -156,9 +193,9 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -156,9 +193,9 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
OrderProcess.Loader.show(); OrderProcess.Loader.show();
OrderProcess.getOrder().then(function (orderHash) { OrderProcess.getOrder().then(function(orderHash) {
return CouponCodes.addCouponCodeToBasket(code, orderHash); return CouponCodes.addCouponCodeToBasket(code, orderHash);
}).then(function (redeemed) { }).then(function(redeemed) {
self.$running = false; self.$running = false;
if (redeemed === false) { if (redeemed === false) {
...@@ -167,7 +204,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -167,7 +204,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
return; return;
} }
self.$addCouponCodeToSession(code).then(function () { self.$addCouponCodeToSession(code).then(function() {
OrderProcess.reload(); OrderProcess.reload();
}); });
}); });
...@@ -178,15 +215,15 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -178,15 +215,15 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
* @param code * @param code
* @return {Promise} * @return {Promise}
*/ */
$addCouponCodeToSession: function (code) { $addCouponCodeToSession: function(code) {
return Sessions.get('quiqqer-coupons').then(function (coupons) { return Sessions.get('quiqqer-coupons').then(function(coupons) {
if (!coupons || typeOf(coupons) !== 'array') { if (!coupons || typeOf(coupons) !== 'array') {
coupons = []; coupons = [];
} }
coupons.push(code); coupons.push(code);
coupons = coupons.filter(function (value, index, self) { coupons = coupons.filter(function(value, index, self) {
return self.indexOf(value) === index; return self.indexOf(value) === index;
}); });
...@@ -198,7 +235,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -198,7 +235,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
* Is the coupon in the order process? * Is the coupon in the order process?
* @return {boolean} * @return {boolean}
*/ */
isInOrder: function () { isInOrder: function() {
var OrderProcessNode = this.getElm().getParent( var OrderProcessNode = this.getElm().getParent(
'[data-qui="package/quiqqer/order/bin/frontend/controls/OrderProcess"]' '[data-qui="package/quiqqer/order/bin/frontend/controls/OrderProcess"]'
); );
...@@ -211,7 +248,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -211,7 +248,7 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
* *
* @return {Object} * @return {Object}
*/ */
getOrderProcess: function () { getOrderProcess: function() {
var OrderProcessNode = this.getElm().getParent( var OrderProcessNode = this.getElm().getParent(
'[data-qui="package/quiqqer/order/bin/frontend/controls/OrderProcess"]' '[data-qui="package/quiqqer/order/bin/frontend/controls/OrderProcess"]'
); );
...@@ -224,19 +261,19 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [ ...@@ -224,19 +261,19 @@ define('package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput', [
* *
* @return {Promise} * @return {Promise}
*/ */
removeCouponsFromOrder: function () { removeCouponsFromOrder: function() {
if (!this.isInOrder()) { if (!this.isInOrder()) {
return Promise.resolve(); return Promise.resolve();
} }
var self = this; var self = this;
return new Promise(function (resolve) { return new Promise(function(resolve) {
var OrderProcess = self.getOrderProcess(); var OrderProcess = self.getOrderProcess();
OrderProcess.Loader.show(); OrderProcess.Loader.show();
OrderProcess.getOrder().then(function (orderHash) { OrderProcess.getOrder().then(function(orderHash) {
QUIAjax.get('package_quiqqer_coupons_ajax_frontend_removeCoupons', function () { QUIAjax.get('package_quiqqer_coupons_ajax_frontend_removeCoupons', function() {
resolve(); resolve();
OrderProcess.reload(); OrderProcess.reload();
}, { }, {
......
...@@ -42,4 +42,7 @@ ...@@ -42,4 +42,7 @@
<event on="onQuiqqerOrderSuccessful" fire="\QUI\ERP\Coupons\Events::removeCouponsFromSession"/> <event on="onQuiqqerOrderSuccessful" fire="\QUI\ERP\Coupons\Events::removeCouponsFromSession"/>
<event on="onQuiqqer::order::orderProcessFinish" fire="\QUI\ERP\Coupons\Events::removeCouponsFromSession"/> <event on="onQuiqqer::order::orderProcessFinish" fire="\QUI\ERP\Coupons\Events::removeCouponsFromSession"/>
<event on="onQuiqqerMigrationV2" fire="\QUI\ERP\Coupons\Events::onQuiqqerMigrationV2"/> <event on="onQuiqqerMigrationV2" fire="\QUI\ERP\Coupons\Events::onQuiqqerMigrationV2"/>
<!-- simple order compatibility -->
<event on="onQuiqqer::simple::order::basket::middle" fire="\QUI\ERP\Coupons\Events::templateOrderSimpleOrder"/>
</events> </events>
...@@ -96,6 +96,26 @@ public static function templateOrderProcessBasketEnd( ...@@ -96,6 +96,26 @@ public static function templateOrderProcessBasketEnd(
); );
} }
public static function templateOrderSimpleOrder(
Collector $Collector,
AbstractOrder $Order
): void {
if ($Order instanceof QUI\ERP\Order\OrderInProcess && isset($_GET['coupon'])) {
try {
$code = Handler::sanitizeCode($_GET['coupon']);
$CouponCode = Handler::getCouponCodeByCode($code);
$CouponCode->checkRedemption(QUI::getUserBySession());
$CouponCode->addToOrder($Order);
} catch (Exception) {
}
}
$Collector->append(
'<div data-qui="package/quiqqer/coupons/bin/frontend/controls/CouponCodeInput"></div>'
);
}
/** /**
* @param QUI\ERP\Order\OrderProcess $OrderProcess * @param QUI\ERP\Order\OrderProcess $OrderProcess
* @throws QUI\ERP\Order\Exception * @throws QUI\ERP\Order\Exception
......
0% oder .
You are about to add 0 people to the discussion. Proceed with caution.
Bearbeitung dieser Nachricht zuerst beenden!
Bitte registrieren oder zum Kommentieren