From d281aed51e1a743ef92da9836546526ae6908b12 Mon Sep 17 00:00:00 2001 From: Oleg Zhuk Date: Wed, 6 Mar 2024 10:55:27 +0200 Subject: [PATCH] VCST-630: Order Manager Role Improvements (#408) feat: Set of back office improvements to support Order Manager Role with limited permission. fix: OrganizationId not found error. fix: Extra padding on order details blade. fix: Eliminate usage of securityAccount service. fix: Eliminate requirement to add platform:security:read permission into Order Manager Role. --- .../VirtoCommerce.OrdersModule.Core.csproj | 2 +- .../Scripts/blades/customerOrder-detail.js | 19 +++++++++---------- .../blades/customerOrder-detail.tpl.html | 2 +- .../Scripts/blades/filter-detail.js | 12 +++++++----- .../Scripts/resources/securityAccounts.js | 4 ---- .../module.manifest | 2 +- 6 files changed, 19 insertions(+), 22 deletions(-) delete mode 100644 src/VirtoCommerce.OrdersModule.Web/Scripts/resources/securityAccounts.js diff --git a/src/VirtoCommerce.OrdersModule.Core/VirtoCommerce.OrdersModule.Core.csproj b/src/VirtoCommerce.OrdersModule.Core/VirtoCommerce.OrdersModule.Core.csproj index 21832245..630c2513 100644 --- a/src/VirtoCommerce.OrdersModule.Core/VirtoCommerce.OrdersModule.Core.csproj +++ b/src/VirtoCommerce.OrdersModule.Core/VirtoCommerce.OrdersModule.Core.csproj @@ -17,7 +17,7 @@ - + diff --git a/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/customerOrder-detail.js b/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/customerOrder-detail.js index 32fe3995..69832456 100644 --- a/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/customerOrder-detail.js +++ b/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/customerOrder-detail.js @@ -1,6 +1,8 @@ angular.module('virtoCommerce.orderModule') - .controller('virtoCommerce.orderModule.customerOrderDetailController', ['$scope', '$window', 'platformWebApp.bladeNavigationService', 'platformWebApp.dialogService', 'virtoCommerce.customerModule.members', 'virtoCommerce.customerModule.memberTypesResolverService', 'virtoCommerce.orderModule.securityAccounts', 'platformWebApp.authService', - function ($scope, $window, bladeNavigationService, dialogService, members, memberTypesResolverService, securityAccounts, authService) { + .controller('virtoCommerce.orderModule.customerOrderDetailController', ['$scope', '$window', 'platformWebApp.bladeNavigationService', + 'platformWebApp.dialogService', 'virtoCommerce.customerModule.members', 'virtoCommerce.customerModule.memberTypesResolverService', + 'platformWebApp.authService', + function ($scope, $window, bladeNavigationService, dialogService, members, memberTypesResolverService, authService) { var blade = $scope.blade; blade.currentEntityId = blade.customerOrder.id; @@ -42,20 +44,17 @@ angular.module('virtoCommerce.orderModule') blade.openCustomerDetails = function () { if (blade.customerOrder.customerId) { - securityAccounts.get({ id: blade.customerOrder.customerId }, function (account) { - var contactId = (account && account.memberId) ? account.memberId : blade.customerOrder.customerId; - members.get({ id: contactId }, function (member) { - if (member && member.id) { - showCustomerDetailBlade(member); - } - }); + members.getByUserId({ userId: blade.customerOrder.customerId }, function (member) { + if (member && member.id) { + showCustomerDetailBlade(member); + } }); } }; blade.openOrganizationDetails = function () { if (blade.customerOrder.organizationId) { - members.get({ id: organizationId }, function (member) { + members.get({ id: blade.customerOrder.organizationId }, function (member) { if (member && member.id) { showCustomerDetailBlade(member); } diff --git a/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/customerOrder-detail.tpl.html b/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/customerOrder-detail.tpl.html index ab677358..be0a87b2 100644 --- a/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/customerOrder-detail.tpl.html +++ b/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/customerOrder-detail.tpl.html @@ -5,7 +5,7 @@
-
+
diff --git a/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/filter-detail.js b/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/filter-detail.js index 38ded7c0..6aa90318 100644 --- a/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/filter-detail.js +++ b/src/VirtoCommerce.OrdersModule.Web/Scripts/blades/filter-detail.js @@ -1,6 +1,7 @@ angular.module('virtoCommerce.orderModule') - .controller('virtoCommerce.orderModule.filterDetailController', ['$scope', '$localStorage', 'virtoCommerce.customerModule.members', '$translate', 'platformWebApp.metaFormsService', 'platformWebApp.accounts', - function ($scope, $localStorage, members, $translate, metaFormsService, securityAccounts) { + .controller('virtoCommerce.orderModule.filterDetailController', ['$scope', '$localStorage', 'virtoCommerce.customerModule.members', + '$translate', 'platformWebApp.metaFormsService', + function ($scope, $localStorage, members, $translate, metaFormsService) { var blade = $scope.blade; blade.metaFields = blade.metaFields ? blade.metaFields : metaFormsService.getMetaFields('orderFilterDetail'); @@ -37,9 +38,10 @@ angular.module('virtoCommerce.orderModule') $scope.saveChanges = function () { if (blade.currentEntity.customerId) { - // Search for accounts by memberId (because customerID in order is an account) - securityAccounts.search({ MemberIds: [blade.currentEntity.customerId] }, function (data) { - blade.currentEntity.customerIds = _.pluck(data.users, 'id'); + members.get({ id: blade.currentEntity.customerId }, function (member) { + blade.currentEntity.customerIds = member.securityAccounts.map(function (account) { + return account.id; + }); $scope.applyCriteria(); }); } diff --git a/src/VirtoCommerce.OrdersModule.Web/Scripts/resources/securityAccounts.js b/src/VirtoCommerce.OrdersModule.Web/Scripts/resources/securityAccounts.js deleted file mode 100644 index 997ee88e..00000000 --- a/src/VirtoCommerce.OrdersModule.Web/Scripts/resources/securityAccounts.js +++ /dev/null @@ -1,4 +0,0 @@ -angular.module('virtoCommerce.orderModule') -.factory('virtoCommerce.orderModule.securityAccounts', ['$resource', function($resource) { - return $resource('api/platform/security/users/id/:id', { id: '@Id' }, {}); -}]); \ No newline at end of file diff --git a/src/VirtoCommerce.OrdersModule.Web/module.manifest b/src/VirtoCommerce.OrdersModule.Web/module.manifest index 2dc406b0..80adebf7 100644 --- a/src/VirtoCommerce.OrdersModule.Web/module.manifest +++ b/src/VirtoCommerce.OrdersModule.Web/module.manifest @@ -8,7 +8,7 @@ - +