Skip to content

Commit a5e652a

Browse files
committed
Merge remote-tracking branch 'origin/MAGETWO-96443' into 2.2-develop-pr14
# Conflicts: # app/code/Magento/Checkout/Model/DefaultConfigProvider.php
2 parents 9db35fb + fc66fe4 commit a5e652a

File tree

7 files changed

+78
-1
lines changed

7 files changed

+78
-1
lines changed

app/code/Magento/Checkout/Model/DefaultConfigProvider.php

Lines changed: 23 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -281,10 +281,12 @@ public function getConfig()
281281
$quote = $this->checkoutSession->getQuote();
282282
$quoteId = $quote->getId();
283283
$email = $quote->getShippingAddress()->getEmail();
284+
$quoteItemData = $this->getQuoteItemData();
284285
$output['formKey'] = $this->formKey->getFormKey();
285286
$output['customerData'] = $this->getCustomerData();
286287
$output['quoteData'] = $this->getQuoteData();
287-
$output['quoteItemData'] = $this->getQuoteItemData();
288+
$output['quoteItemData'] = $quoteItemData;
289+
$output['quoteMessages'] = $this->getQuoteItemsMessages($quoteItemData);
288290
$output['isCustomerLoggedIn'] = $this->isCustomerLoggedIn();
289291
$output['selectedShippingMethod'] = $this->getSelectedShippingMethod();
290292
if ($email && !$this->isCustomerLoggedIn()) {
@@ -314,6 +316,7 @@ public function getConfig()
314316
);
315317
$output['postCodes'] = $this->postCodesConfig->getPostCodes();
316318
$output['imageData'] = $this->imageProvider->getImages($quoteId);
319+
317320
$output['totalsData'] = $this->getTotalsData();
318321
$output['shippingPolicy'] = [
319322
'isEnabled' => $this->scopeConfig->isSetFlag(
@@ -448,6 +451,7 @@ private function getQuoteItemData()
448451
$quoteItem->getProduct(),
449452
'product_thumbnail_image'
450453
)->getUrl();
454+
$quoteItemData[$index]['message'] = $quoteItem->getMessage();
451455
}
452456
}
453457
return $quoteItemData;
@@ -759,4 +763,22 @@ private function getAttributeLabels(array $customAttribute, string $customAttrib
759763

760764
return $attributeOptionLabels;
761765
}
766+
767+
/**
768+
* Get notification messages for the quote items
769+
*
770+
* @param array $quoteItemData
771+
* @return array
772+
*/
773+
private function getQuoteItemsMessages(array $quoteItemData): array
774+
{
775+
$quoteItemsMessages = [];
776+
if ($quoteItemData) {
777+
foreach ($quoteItemData as $item) {
778+
$quoteItemsMessages[$item['item_id']] = $item['message'];
779+
}
780+
}
781+
782+
return $quoteItemsMessages;
783+
}
762784
}

app/code/Magento/Checkout/Test/Mftf/Test/StorefrontCustomerCheckoutTest.xml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -77,6 +77,7 @@
7777
<see stepKey="s95" selector="{{OrderDetailsInformationSection.itemsOrdered}}" userInput="$$simpleproduct1.name$$" />
7878
<amOnPage stepKey="s96" url="{{AdminCustomerPage.url}}"/>
7979
<waitForPageLoad stepKey="s97"/>
80+
<waitForElementVisible selector="{{AdminCustomerFiltersSection.filtersButton}}" time="30" stepKey="waitFiltersButton"/>
8081
<click stepKey="s98" selector="{{AdminCustomerFiltersSection.filtersButton}}"/>
8182
<fillField stepKey="s99" selector="{{AdminCustomerFiltersSection.emailInput}}" userInput="$$simpleuscustomer.email$$"/>
8283
<click stepKey="s100" selector="{{AdminCustomerFiltersSection.apply}}"/>

app/code/Magento/Checkout/view/frontend/layout/checkout_index_index.xml

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -404,6 +404,10 @@
404404
<item name="component" xsi:type="string">Magento_Checkout/js/view/summary/item/details/subtotal</item>
405405
<item name="displayArea" xsi:type="string">after_details</item>
406406
</item>
407+
<item name="message" xsi:type="array">
408+
<item name="component" xsi:type="string">Magento_Checkout/js/view/summary/item/details/message</item>
409+
<item name="displayArea" xsi:type="string">item_message</item>
410+
</item>
407411
</item>
408412
</item>
409413
</item>
Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
/**
2+
* Copyright © Magento, Inc. All rights reserved.
3+
* See COPYING.txt for license details.
4+
*/
5+
6+
define(['uiComponent'], function (Component) {
7+
'use strict';
8+
9+
var quoteMessages = window.checkoutConfig.quoteMessages;
10+
11+
return Component.extend({
12+
defaults: {
13+
template: 'Magento_Checkout/summary/item/details/message'
14+
},
15+
displayArea: 'item_message',
16+
quoteMessages: quoteMessages,
17+
18+
/**
19+
* @param {Object} item
20+
* @return {null}
21+
*/
22+
getMessage: function (item) {
23+
if (this.quoteMessages[item['item_id']]) {
24+
return this.quoteMessages[item['item_id']];
25+
}
26+
27+
return null;
28+
}
29+
});
30+
});

app/code/Magento/Checkout/view/frontend/web/template/summary/item/details.html

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -43,3 +43,6 @@
4343
</div>
4444
<!-- /ko -->
4545
</div>
46+
<!-- ko foreach: getRegion('item_message') -->
47+
<!-- ko template: getTemplate() --><!-- /ko -->
48+
<!-- /ko -->
Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
<!--
2+
/**
3+
* Copyright © Magento, Inc. All rights reserved.
4+
* See COPYING.txt for license details.
5+
*/
6+
-->
7+
<div class="cart item message notice" if="getMessage($parents[1])">
8+
<div data-bind="text: getMessage($parents[1])"></div>
9+
</div>

app/design/frontend/Magento/luma/Magento_Checkout/web/css/source/module/checkout/_order-summary.less

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -137,6 +137,10 @@
137137
}
138138

139139
.product-item {
140+
.product-item-details {
141+
&:extend(.abs-add-clearfix all);
142+
}
143+
140144
.product-item-inner {
141145
display: table;
142146
margin: 0 0 @indent__s;
@@ -166,6 +170,10 @@
166170
}
167171
}
168172
}
173+
174+
.message {
175+
margin-top: 10px;
176+
}
169177
}
170178

171179
.actions-toolbar {

0 commit comments

Comments
 (0)