From e89d5ecfbd29468401541f39921dec1b9c037b39 Mon Sep 17 00:00:00 2001 From: oradchenko Date: Mon, 11 Apr 2016 14:36:00 +0300 Subject: [PATCH 1/8] MAGETWO-51681: Missing Translations in Sales Menu - Added regexp pattern for translate attribute. --- app/code/Magento/Translation/etc/di.xml | 1 + 1 file changed, 1 insertion(+) diff --git a/app/code/Magento/Translation/etc/di.xml b/app/code/Magento/Translation/etc/di.xml index d842a137e99f2..644c835256288 100644 --- a/app/code/Magento/Translation/etc/di.xml +++ b/app/code/Magento/Translation/etc/di.xml @@ -58,6 +58,7 @@ + ~\$\.mage\.__\((['"])(.+?)\1\)~ ~\$t\((["'])(.+?)\1\)~ From 3fabfa520e8d89ae92589bf2ac9cefc5d1e35794 Mon Sep 17 00:00:00 2001 From: "Partica, Cristian" Date: Tue, 24 May 2016 13:40:42 -0500 Subject: [PATCH 2/8] MAGETWO-50636: [API] For all the appropriate Rest calls with SearchCriteria filters, validate if response for search_criteria key is NOT null. - adding search criteria for the missing search action repositories --- app/code/Magento/Sales/Model/Order/AddressRepository.php | 2 +- app/code/Magento/Sales/Model/Order/CreditmemoRepository.php | 1 + app/code/Magento/Sales/Model/Order/InvoiceRepository.php | 1 + app/code/Magento/Sales/Model/Order/Payment/Repository.php | 1 + .../Sales/Model/Order/Payment/Transaction/Repository.php | 1 + app/code/Magento/Sales/Model/Order/ShipmentRepository.php | 2 +- 6 files changed, 6 insertions(+), 2 deletions(-) diff --git a/app/code/Magento/Sales/Model/Order/AddressRepository.php b/app/code/Magento/Sales/Model/Order/AddressRepository.php index d314a08c10b72..8ca6285ca2c65 100644 --- a/app/code/Magento/Sales/Model/Order/AddressRepository.php +++ b/app/code/Magento/Sales/Model/Order/AddressRepository.php @@ -91,7 +91,7 @@ public function getList(\Magento\Framework\Api\SearchCriteria $searchCriteria) $searchResult->addFieldToFilter($filter->getField(), [$condition => $filter->getValue()]); } } - + $searchResult->setSearchCriteria($searchCriteria); $searchResult->setCurPage($searchCriteria->getCurrentPage()); $searchResult->setPageSize($searchCriteria->getPageSize()); diff --git a/app/code/Magento/Sales/Model/Order/CreditmemoRepository.php b/app/code/Magento/Sales/Model/Order/CreditmemoRepository.php index 439483fd65ba0..fb13153330312 100644 --- a/app/code/Magento/Sales/Model/Order/CreditmemoRepository.php +++ b/app/code/Magento/Sales/Model/Order/CreditmemoRepository.php @@ -99,6 +99,7 @@ public function getList(\Magento\Framework\Api\SearchCriteria $searchCriteria) $searchResult->addFieldToFilter($filter->getField(), [$condition => $filter->getValue()]); } } + $searchResult->setSearchCriteria($searchCriteria); $searchResult->setCurPage($searchCriteria->getCurrentPage()); $searchResult->setPageSize($searchCriteria->getPageSize()); return $searchResult; diff --git a/app/code/Magento/Sales/Model/Order/InvoiceRepository.php b/app/code/Magento/Sales/Model/Order/InvoiceRepository.php index 87f28c39bb050..38cd7bdc97f0f 100644 --- a/app/code/Magento/Sales/Model/Order/InvoiceRepository.php +++ b/app/code/Magento/Sales/Model/Order/InvoiceRepository.php @@ -95,6 +95,7 @@ public function getList(\Magento\Framework\Api\SearchCriteria $searchCriteria) $collection->addFieldToFilter($filter->getField(), [$condition => $filter->getValue()]); } } + $collection->setSearchCriteria($searchCriteria); $collection->setCurPage($searchCriteria->getCurrentPage()); $collection->setPageSize($searchCriteria->getPageSize()); return $collection; diff --git a/app/code/Magento/Sales/Model/Order/Payment/Repository.php b/app/code/Magento/Sales/Model/Order/Payment/Repository.php index c4a1cea24da6d..e3dd51e14132f 100644 --- a/app/code/Magento/Sales/Model/Order/Payment/Repository.php +++ b/app/code/Magento/Sales/Model/Order/Payment/Repository.php @@ -60,6 +60,7 @@ public function getList(\Magento\Framework\Api\SearchCriteria $searchCriteria) $collection->addFieldToFilter($filter->getField(), [$condition => $filter->getValue()]); } } + $collection->setSearchCriteria($searchCriteria); $collection->setCurPage($searchCriteria->getCurrentPage()); $collection->setPageSize($searchCriteria->getPageSize()); return $collection; diff --git a/app/code/Magento/Sales/Model/Order/Payment/Transaction/Repository.php b/app/code/Magento/Sales/Model/Order/Payment/Transaction/Repository.php index a9b66e71bf468..687260cb185cc 100644 --- a/app/code/Magento/Sales/Model/Order/Payment/Transaction/Repository.php +++ b/app/code/Magento/Sales/Model/Order/Payment/Transaction/Repository.php @@ -193,6 +193,7 @@ public function getList(\Magento\Framework\Api\SearchCriteria $searchCriteria) $collection->addFieldToFilter($filter->getField(), [$condition => $filter->getValue()]); } } + $collection->setSearchCriteria($searchCriteria); $collection->setCurPage($searchCriteria->getCurrentPage()); $collection->setPageSize($searchCriteria->getPageSize()); $collection->addPaymentInformation(['method']); diff --git a/app/code/Magento/Sales/Model/Order/ShipmentRepository.php b/app/code/Magento/Sales/Model/Order/ShipmentRepository.php index b1dce96d6a215..d32a5f83f2d41 100644 --- a/app/code/Magento/Sales/Model/Order/ShipmentRepository.php +++ b/app/code/Magento/Sales/Model/Order/ShipmentRepository.php @@ -91,7 +91,7 @@ public function getList(\Magento\Framework\Api\SearchCriteria $searchCriteria) $searchResult->addFieldToFilter($filter->getField(), [$condition => $filter->getValue()]); } } - + $searchResult->setSearchCriteria($searchCriteria); $searchResult->setCurPage($searchCriteria->getCurrentPage()); $searchResult->setPageSize($searchCriteria->getPageSize()); From c2264e26a69c89d32f826392c837cd5b6d7e5961 Mon Sep 17 00:00:00 2001 From: "Partica, Cristian" Date: Tue, 24 May 2016 16:09:52 -0500 Subject: [PATCH 3/8] MAGETWO-50636: [API] For all the appropriate Rest calls with SearchCriteria filters, validate if response for search_criteria key is NOT null. - adding functional api assertion for modified repo - removing un-needed search criteria echo because it's only needed for exposed apis defined in webapi.xml --- app/code/Magento/Sales/Model/Order/AddressRepository.php | 1 - app/code/Magento/Sales/Model/Order/Payment/Repository.php | 1 - .../testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php | 2 ++ .../testsuite/Magento/Sales/Service/V1/InvoiceListTest.php | 2 ++ .../testsuite/Magento/Sales/Service/V1/ShipmentListTest.php | 2 ++ .../testsuite/Magento/Sales/Service/V1/TransactionTest.php | 2 ++ 6 files changed, 8 insertions(+), 2 deletions(-) diff --git a/app/code/Magento/Sales/Model/Order/AddressRepository.php b/app/code/Magento/Sales/Model/Order/AddressRepository.php index 8ca6285ca2c65..e075d4afdcd34 100644 --- a/app/code/Magento/Sales/Model/Order/AddressRepository.php +++ b/app/code/Magento/Sales/Model/Order/AddressRepository.php @@ -91,7 +91,6 @@ public function getList(\Magento\Framework\Api\SearchCriteria $searchCriteria) $searchResult->addFieldToFilter($filter->getField(), [$condition => $filter->getValue()]); } } - $searchResult->setSearchCriteria($searchCriteria); $searchResult->setCurPage($searchCriteria->getCurrentPage()); $searchResult->setPageSize($searchCriteria->getPageSize()); diff --git a/app/code/Magento/Sales/Model/Order/Payment/Repository.php b/app/code/Magento/Sales/Model/Order/Payment/Repository.php index e3dd51e14132f..c4a1cea24da6d 100644 --- a/app/code/Magento/Sales/Model/Order/Payment/Repository.php +++ b/app/code/Magento/Sales/Model/Order/Payment/Repository.php @@ -60,7 +60,6 @@ public function getList(\Magento\Framework\Api\SearchCriteria $searchCriteria) $collection->addFieldToFilter($filter->getField(), [$condition => $filter->getValue()]); } } - $collection->setSearchCriteria($searchCriteria); $collection->setCurPage($searchCriteria->getCurrentPage()); $collection->setPageSize($searchCriteria->getPageSize()); return $collection; diff --git a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php index 34cd077c4620c..b6157c36a3766 100644 --- a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php +++ b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php @@ -85,5 +85,7 @@ public function testCreditmemoList() // TODO Test fails, due to the inability of the framework API to handle data collection $this->assertArrayHasKey('items', $result); $this->assertCount(1, $result['items']); + $this->assertArrayHasKey('search_criteria', $result); + $this->assertEquals($searchData, $result['search_criteria']); } } diff --git a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/InvoiceListTest.php b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/InvoiceListTest.php index 06b5856230b52..daad3c442ea7f 100644 --- a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/InvoiceListTest.php +++ b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/InvoiceListTest.php @@ -70,5 +70,7 @@ public function testInvoiceList() // TODO Test fails, due to the inability of the framework API to handle data collection $this->assertArrayHasKey('items', $result); $this->assertCount(1, $result['items']); + $this->assertArrayHasKey('search_criteria', $result); + $this->assertEquals($searchData, $result['search_criteria']); } } diff --git a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/ShipmentListTest.php b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/ShipmentListTest.php index f4cd591bba56b..6123d1a112a6d 100644 --- a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/ShipmentListTest.php +++ b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/ShipmentListTest.php @@ -63,5 +63,7 @@ public function testShipmentList() // TODO Test fails, due to the inability of the framework API to handle data collection $this->assertArrayHasKey('items', $result); $this->assertCount(1, $result['items']); + $this->assertArrayHasKey('search_criteria', $result); + $this->assertEquals($searchData, $result['search_criteria']); } } diff --git a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/TransactionTest.php b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/TransactionTest.php index b85ef9e08ce46..d88775f46f00c 100644 --- a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/TransactionTest.php +++ b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/TransactionTest.php @@ -141,6 +141,8 @@ public function testTransactionList($filters) $expectedData = [$transactionData, $childTransactionData]; $this->assertEquals($expectedData, $result['items']); + $this->assertArrayHasKey('search_criteria', $result); + $this->assertEquals($searchData, $result['search_criteria']); } /** From f58a49880106d00353be6666870b770bc017605e Mon Sep 17 00:00:00 2001 From: "Partica, Cristian" Date: Wed, 25 May 2016 10:53:11 -0500 Subject: [PATCH 4/8] MAGETWO-50636: [API] For all the appropriate Rest calls with SearchCriteria filters, validate if response for search_criteria key is NOT null. - fixing search criteria assertion --- .../Magento/Sales/Service/V1/CreditmemoListTest.php | 3 ++- .../Magento/Sales/Service/V1/InvoiceListTest.php | 3 ++- .../Magento/Sales/Service/V1/ShipmentListTest.php | 10 +++++++++- 3 files changed, 13 insertions(+), 3 deletions(-) diff --git a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php index b6157c36a3766..18cababd5998c 100644 --- a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php +++ b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/CreditmemoListTest.php @@ -62,7 +62,8 @@ public function testCreditmemoList() [ $filterBuilder ->setField('state') - ->setValue(\Magento\Sales\Model\Order\Creditmemo::STATE_OPEN) + ->setValue((string)\Magento\Sales\Model\Order\Creditmemo::STATE_OPEN) + ->setConditionType('eq') ->create(), ] ); diff --git a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/InvoiceListTest.php b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/InvoiceListTest.php index daad3c442ea7f..d19b9f53d9496 100644 --- a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/InvoiceListTest.php +++ b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/InvoiceListTest.php @@ -47,7 +47,8 @@ public function testInvoiceList() [ $filterBuilder ->setField('state') - ->setValue(2) + ->setValue((string)\Magento\Sales\Model\Order\Invoice::STATE_PAID) + ->setConditionType('eq') ->create(), ] ); diff --git a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/ShipmentListTest.php b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/ShipmentListTest.php index 6123d1a112a6d..89d377fb2aceb 100644 --- a/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/ShipmentListTest.php +++ b/dev/tests/api-functional/testsuite/Magento/Sales/Service/V1/ShipmentListTest.php @@ -43,7 +43,15 @@ public function testShipmentList() 'Magento\Framework\Api\FilterBuilder' ); - $searchCriteriaBuilder->addFilters([$filterBuilder->setField('shipment_status')->setValue(1)->create()]); + $searchCriteriaBuilder->addFilters( + [ + $filterBuilder + ->setField('shipment_status') + ->setValue((string)\Magento\Sales\Model\Order\Shipment::STATUS_NEW) + ->setConditionType('eq') + ->create() + ] + ); $searchData = $searchCriteriaBuilder->create()->__toArray(); $requestData = ['searchCriteria' => $searchData]; From 10fce7022132ee8d78a131a8d12c06c34b0e03ed Mon Sep 17 00:00:00 2001 From: Dmytro Voskoboinikov Date: Mon, 30 May 2016 11:30:05 +0300 Subject: [PATCH 5/8] MAGETWO-52486: Order can be placed when order placing is not allowed --- lib/internal/Magento/Framework/Url.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/internal/Magento/Framework/Url.php b/lib/internal/Magento/Framework/Url.php index a1e047e23fe80..7068efcf037a5 100644 --- a/lib/internal/Magento/Framework/Url.php +++ b/lib/internal/Magento/Framework/Url.php @@ -232,7 +232,7 @@ protected function _parseUrl($url) 'user' => 'setUser', 'pass' => 'setPassword', 'path' => 'setPath', - 'query' => 'setQuery', + 'query' => '_setQuery', 'fragment' => 'setFragment', ]; From 32cf6892e4ed35eb943b35cb9140f1cc9327a94e Mon Sep 17 00:00:00 2001 From: Oleksandr Radchenko Date: Mon, 6 Jun 2016 18:13:50 +0300 Subject: [PATCH 6/8] MAGETWO-51681: Missing Translations in Sales Menu --- app/code/Magento/Translation/etc/di.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/code/Magento/Translation/etc/di.xml b/app/code/Magento/Translation/etc/di.xml index 644c835256288..f207e13f23c28 100644 --- a/app/code/Magento/Translation/etc/di.xml +++ b/app/code/Magento/Translation/etc/di.xml @@ -58,7 +58,7 @@ - + ~\$\.mage\.__\((['"])(.+?)\1\)~ ~\$t\((["'])(.+?)\1\)~ From af128fe6359a326cbe089affc2317985de0f0e77 Mon Sep 17 00:00:00 2001 From: Sergii Kovalenko Date: Tue, 7 Jun 2016 14:10:30 +0300 Subject: [PATCH 7/8] MAGETWO-53940: Unnecessary redirect to checkout page after Sign-in --- app/code/Magento/Checkout/Controller/Index/Index.php | 2 -- 1 file changed, 2 deletions(-) diff --git a/app/code/Magento/Checkout/Controller/Index/Index.php b/app/code/Magento/Checkout/Controller/Index/Index.php index 6d8c3951b8cb7..f15f4259923f8 100644 --- a/app/code/Magento/Checkout/Controller/Index/Index.php +++ b/app/code/Magento/Checkout/Controller/Index/Index.php @@ -34,8 +34,6 @@ public function execute() $this->_customerSession->regenerateId(); $this->_objectManager->get('Magento\Checkout\Model\Session')->setCartWasUpdated(false); - $currentUrl = $this->_url->getUrl('*/*/*', ['_secure' => true]); - $this->_objectManager->get('Magento\Customer\Model\Session')->setBeforeAuthUrl($currentUrl); $this->getOnepage()->initCheckout(); $resultPage = $this->resultPageFactory->create(); $resultPage->getConfig()->getTitle()->set(__('Checkout')); From aeaac1d437261540c068a910ac1b867424b75335 Mon Sep 17 00:00:00 2001 From: Oleksandr Miroshnichenko Date: Wed, 8 Jun 2016 12:25:39 +0300 Subject: [PATCH 8/8] MAGETWO-53034: DnD in Dynamic Rows is not work --- .../Ui/view/base/web/js/dynamic-rows/dnd.js | 32 +++++++++++++++++-- 1 file changed, 30 insertions(+), 2 deletions(-) diff --git a/app/code/Magento/Ui/view/base/web/js/dynamic-rows/dnd.js b/app/code/Magento/Ui/view/base/web/js/dynamic-rows/dnd.js index e52177f74e461..d76fb433106ef 100644 --- a/app/code/Magento/Ui/view/base/web/js/dynamic-rows/dnd.js +++ b/app/code/Magento/Ui/view/base/web/js/dynamic-rows/dnd.js @@ -58,8 +58,12 @@ define([ recordsCache: [], draggableElement: {}, draggableElementClass: '_dragged', + elemPositions: [], listens: { '${ $.recordsProvider }:elems': 'setCacheRecords' + }, + modules: { + parentComponent: '${ $.recordsProvider }' } }, @@ -189,7 +193,9 @@ define([ pageY = isTouchDevice ? event.originalEvent.touches[0].pageY : event.pageY, positionY = pageY - drEl.eventMousedownY; - drEl.depElement = this.getDepElement(drEl.instance, positionY); + drEl.depElement = this.getDepElement(drEl.instance, positionY, this.draggableElement.originRow); + + drEl.instance.remove(); if (drEl.depElement) { depElementCtx = this.getRecord(drEl.depElement.elem[0]); @@ -210,7 +216,6 @@ define([ this.body.unbind('mouseup', this.mouseupHandler); } - drEl.instance.remove(); this.draggableElement = {}; }, @@ -224,11 +229,34 @@ define([ setPosition: function (depElem, depElementCtx, dragData) { var depElemPosition = ~~depElementCtx.position; + this.cacheElementsPosition(); + if (dragData.depElement.insert === 'after') { dragData.instanceCtx.position = depElemPosition + 1; } else if (dragData.depElement.insert === 'before') { dragData.instanceCtx.position = depElemPosition; } + + this.normalizePositions(); + }, + + /** + * Saves elements position from current elements + */ + cacheElementsPosition: function () { + this.elemPositions = []; + this.parentComponent().elems.each(function (elem) { + this.elemPositions.push(elem.position); + }, this); + }, + + /** + * Normalize position, uses start elements position + */ + normalizePositions: function () { + this.parentComponent().elems.each(function (item, index) { + item.position = this.elemPositions[index]; + }, this); }, /**