From 4bfcb75e02971182c9c46293787fec07407d3b8b Mon Sep 17 00:00:00 2001 From: Isaac Seessel Date: Mon, 26 Mar 2018 17:52:44 -0400 Subject: [PATCH 1/3] [MNOE-906] Refactor Org tables into one code --- .../mnoe-api/admin/organizations.svc.coffee | 5 +- .../mnoe-organizations-list.coffee | 21 +++-- .../mnoe-organizations-list.html | 3 +- .../mnoe-organizations-list.less | 6 ++ src/app/views/home/home.controller.coffee | 15 +++- src/app/views/home/home.html | 2 +- src/app/views/user/user.controller.coffee | 80 ++++++++++++++++++- src/app/views/user/user.html | 6 +- 8 files changed, 125 insertions(+), 13 deletions(-) create mode 100644 src/app/components/mnoe-organizations-list/mnoe-organizations-list.less diff --git a/src/app/components/mnoe-api/admin/organizations.svc.coffee b/src/app/components/mnoe-api/admin/organizations.svc.coffee index eddc61f1..373b7df7 100644 --- a/src/app/components/mnoe-api/admin/organizations.svc.coffee +++ b/src/app/components/mnoe-api/admin/organizations.svc.coffee @@ -29,8 +29,9 @@ params["offset"] = offset return MnoeAdminApiSvc.all("organizations").getList(params) - @search = (terms) -> - MnoeAdminApiSvc.all("organizations").getList({terms: terms}) + @search = (terms, params = {}) -> + params = angular.extend({}, params, {terms: terms}) + MnoeAdminApiSvc.all("organizations").getList(params) @inArrears = () -> MnoeAdminApiSvc.all('organizations').all('in_arrears').getList() diff --git a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee index 1135b0fc..947a53b3 100644 --- a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee +++ b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee @@ -4,7 +4,9 @@ @App.directive('mnoeOrganizationsList', ($filter, $translate, MnoeOrganizations, MnoeAdminConfig, MnoeCurrentUser) -> restrict: 'E' scope: { - list: '=' + list: '=', + user: '<', + customizations: '<' }, templateUrl: 'app/components/mnoe-organizations-list/mnoe-organizations-list.html', link: (scope, elem) -> @@ -46,7 +48,7 @@ mnoe_admin_panel.dashboard.organization.demo_account_state """, - scope: {organization: organization}} + scope: { organization: organization }} # organization creation date { header: locale["mnoe_admin_panel.dashboard.organization.widget.list.table.creation"], @@ -57,7 +59,7 @@ render: (organization) -> template: "{{::organization.created_at | date: 'dd/MM/yyyy'}}" - scope: {organization: organization}} + scope: { organization: organization }} ] # Add Finance columns if enabled @@ -71,6 +73,8 @@ # Currency { header: locale['mnoe_admin_panel.dashboard.organization.widget.list.table.currency'], attr:'financial_metrics.currency', doNotSort: true, style: width: '110px'}]) + + scope.organizations.fields = scope.organizations.fields.concat(scope.customizations.fields) if scope.customizations.fields ) # Smart table callback @@ -90,6 +94,7 @@ {sub_tenant_id: MnoeCurrentUser.user.mnoe_sub_tenant_id, account_manager_id: MnoeCurrentUser.user.id} else {} + params = angular.extend({}, params, scope.searchParams) if scope.searchParams return MnoeOrganizations.list(limit, offset, sort, params).then( (response) -> scope.organizations.totalItems = response.headers('x-total-count') @@ -123,12 +128,18 @@ delete scope.organizations.switchLinkTitle search = scope.organizations.search.toLowerCase() terms = {'name.like': "%#{search}%"} - MnoeOrganizations.search(terms).then( + # Custom search parameters are given to the directive. E.g. when we only want to search orgs of a particular user. + params = scope.customizations.searchParams || {} + MnoeOrganizations.search(terms, params).then( (response) -> scope.organizations.totalItems = response.headers('x-total-count') scope.organizations.list = $filter('orderBy')(response.data, 'name') ).finally(-> scope.organizations.loading = false) + init = () -> + scope.organizations.loading = true + setAllOrganizationsList() + # Initial call - displayCurrentState() + init() ) diff --git a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.html b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.html index f42ef76c..03bf33d8 100644 --- a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.html +++ b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.html @@ -9,7 +9,8 @@ row-collection="organizations.list" is-loading="organizations.loading" fields="organizations.fields" - pipe="pipe(tableState)"> + pipe="pipe(tableState)" + bindings="customizations.bindings"> diff --git a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.less b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.less new file mode 100644 index 00000000..ab08d04a --- /dev/null +++ b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.less @@ -0,0 +1,6 @@ +mnoe-organizations-list { + .role_edit_link { + display: inline; + cursor: pointer; + } +} diff --git a/src/app/views/home/home.controller.coffee b/src/app/views/home/home.controller.coffee index 4d9b755c..d5cc325e 100644 --- a/src/app/views/home/home.controller.coffee +++ b/src/app/views/home/home.controller.coffee @@ -1,4 +1,4 @@ -@App.controller 'HomeController', (moment, MnoeUsers, MnoeOrganizations, MnoeInvoices, MnoeAdminConfig) -> +@App.controller 'HomeController', (moment, MnoeUsers, MnoeOrganizations, MnoeInvoices, MnoeAdminConfig, MnoeCurrentUser) -> 'ngInject' vm = this @@ -33,4 +33,17 @@ vm.invoices.outstandingAmount = response.data ) if MnoeAdminConfig.isFinanceEnabled() + vm.orgTableCustomizations = { + getOrganizations: (limit, offset, sort = 'created_at') -> + MnoeCurrentUser.getUser().then( -> + params = {} + + if MnoeAdminConfig.isAccountManagerEnabled() + params['sub_tenant_id'] = MnoeCurrentUser.user.mnoe_sub_tenant_id + params['account_manager_id'] = MnoeCurrentUser.user.id + + MnoeOrganizations.list(limit, offset, sort, params) + ) + } + return diff --git a/src/app/views/home/home.html b/src/app/views/home/home.html index 55a115d1..2c49b754 100644 --- a/src/app/views/home/home.html +++ b/src/app/views/home/home.html @@ -38,7 +38,7 @@
- +
diff --git a/src/app/views/user/user.controller.coffee b/src/app/views/user/user.controller.coffee index f01daf7f..dde6b804 100644 --- a/src/app/views/user/user.controller.coffee +++ b/src/app/views/user/user.controller.coffee @@ -1,7 +1,8 @@ -@App.controller 'UserController', ($stateParams, MnoeUsers) -> +@App.controller 'UserController', ($stateParams, MnoeUsers, UserRoles, $translate, toastr, MnoErrorsHandler, MnoeOrganizations) -> 'ngInject' vm = this - + vm.user = {} + vm.orgTableCustomizations = {} # Get the user MnoeUsers.get($stateParams.userId).then( (response) -> @@ -10,5 +11,80 @@ phone = vm.user.phone if phone && countryCode vm.user.phone = '+' + countryCode + phone + + vm.orgTableCustomizations.searchParams = { 'where[users.id]': vm.user.id } + + # These bindings are so that we can add additional fields with functionality to the organization table. + vm.orgTableCustomizations.bindings = { + userRoles: UserRoles + user: vm.user + + editRole: (organization) -> + # Keep track of old roles when editing organization's roles. + organization.beforeEditRole = organization.role + organization.editMode = true + + exitEditRole: (organization) -> + organization.role = organization.beforeEditRole + organization.editMode = false + + updateUserRole: (organization, user) -> + user.isUpdatingRole = true + # The role must be set on the user for #updateUserRole. + user.role = organization.role + + MnoeUsers.updateUserRole(organization, user).then( + () -> + $translate(UserRoles.keyFromRole(user.role)).then((tls) -> + toastr.success('mnoe_admin_panel.dashboard.users.widget.local_list.role_update_success', {extraData: {user: "#{user.email}", role: tls}}) + ) + (error) -> + organization.role = organization.beforeEditRole + toastr.error('mnoe_admin_panel.dashboard.users.widget.local_list.role_update_error') + MnoErrorsHandler.processServerError(error) + ).finally(() -> + # So that the organization/user reverts back to non-editing view. + organization.beforeEditRole = null + organization.isUpdatingRole = false + organization.editMode = false + ) + } ) + + $translate('mnoe_admin_panel.dashboard.organization.widget.local_list.search_organizations.table.role') + .then((translation) -> + vm.orgTableCustomizations.fields = [ + { + header: translation + style: { + width: '130px' + } + skip_natural: false + render: (organization, bindings) -> + template: " + + + {{ userRoles.keyFromRole(organization.role) | translate }} + + + + + " + scope: { + organization: organization + user: bindings.user, + editRole: bindings.editRole + updateUserRole: bindings.updateUserRole + exitEditRole: bindings.exitEditRole + userRoles: bindings.userRoles + } + } + ] + ) + + vm.orgTableCustomizations.getOrganizations = (limit, offset, sort = 'created_at') -> + return unless vm.user['id'] + params = vm.orgTableCustomizations.searchParams + MnoeOrganizations.list(limit, offset, sort, params) + return diff --git a/src/app/views/user/user.html b/src/app/views/user/user.html index 2d58d7e4..249d10c2 100644 --- a/src/app/views/user/user.html +++ b/src/app/views/user/user.html @@ -83,7 +83,11 @@

{{'mnoe_admin_panel.dashboard.user.geo_information_title
- + +

From f7a63371b5ecf3dc3d65f138d33d5994cabc6728 Mon Sep 17 00:00:00 2001 From: Isaac Seessel Date: Tue, 27 Mar 2018 17:31:18 -0400 Subject: [PATCH 2/3] [MNOE-978] Remove edit role from local-list --- .../mnoe-organizations-list.coffee | 14 +++--- .../mnoe-organizations-list.html | 2 +- .../mnoe-organizations-local-list.coffee | 44 +++---------------- .../mnoe-organizations-local-list.html | 10 ----- src/app/views/home/home.controller.coffee | 15 +------ src/app/views/home/home.html | 2 +- src/app/views/user/user.controller.coffee | 16 +++---- src/app/views/user/user.html | 4 +- 8 files changed, 24 insertions(+), 83 deletions(-) diff --git a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee index 947a53b3..ea7eb09b 100644 --- a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee +++ b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee @@ -1,12 +1,14 @@ # -# Mnoe organizations List +# Mnoe Organizations Local List +# The organization-local-list is used for organizations that already exist on the frontend, e.g. when uploading a CSV file. +# Whereas organizations-list is used when organizations must be fetched. # @App.directive('mnoeOrganizationsList', ($filter, $translate, MnoeOrganizations, MnoeAdminConfig, MnoeCurrentUser) -> restrict: 'E' scope: { - list: '=', - user: '<', - customizations: '<' + fields: '<', + searchParams: '<', + bindings: '<' }, templateUrl: 'app/components/mnoe-organizations-list/mnoe-organizations-list.html', link: (scope, elem) -> @@ -74,7 +76,7 @@ { header: locale['mnoe_admin_panel.dashboard.organization.widget.list.table.currency'], attr:'financial_metrics.currency', doNotSort: true, style: width: '110px'}]) - scope.organizations.fields = scope.organizations.fields.concat(scope.customizations.fields) if scope.customizations.fields + scope.organizations.fields = scope.organizations.fields.concat(scope.fields) if scope.fields ) # Smart table callback @@ -129,7 +131,7 @@ search = scope.organizations.search.toLowerCase() terms = {'name.like': "%#{search}%"} # Custom search parameters are given to the directive. E.g. when we only want to search orgs of a particular user. - params = scope.customizations.searchParams || {} + params = scope.searchParams || {} MnoeOrganizations.search(terms, params).then( (response) -> scope.organizations.totalItems = response.headers('x-total-count') diff --git a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.html b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.html index 03bf33d8..ddde4fff 100644 --- a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.html +++ b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.html @@ -10,7 +10,7 @@ is-loading="organizations.loading" fields="organizations.fields" pipe="pipe(tableState)" - bindings="customizations.bindings"> + bindings="bindings"> diff --git a/src/app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.coffee b/src/app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.coffee index 075a2af1..18bf75f2 100644 --- a/src/app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.coffee +++ b/src/app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.coffee @@ -1,19 +1,16 @@ # -# Mnoe Organizations List -# The organization-local-list is on the user's info page and shows the organizations attached to a user, while -# the organizations-list is on the homepage and shows all the users. - -@App.directive('mnoeOrganizationsLocalList', ($translate, $filter, $log, toastr, UserRoles, MnoeUsers) -> +# Mnoe Organizations Local List +# The organization-local-list is used for organizations that already exist on the frontend, e.g. when uploading a CSV file. +# Whereas organizations-list is used when organizations must be fetched. +# +@App.directive('mnoeOrganizationsLocalList', ($filter, $log) -> restrict: 'E' scope: { list: '=', - user: '=' }, templateUrl: 'app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.html', link: (scope, elem, attrs) -> - # Only display some info in the context of an user - scope.userContext = attrs.user? - scope.userRoles = UserRoles + # Variables initialization scope.organizations = displayList: [] @@ -69,35 +66,6 @@ else setSearchOrganizationsList() - scope.editRole = (organization) -> - # Keep track of old roles when editing organization's roles. - organization.beforeEditRole = organization.role - organization.editMode = true - - scope.exitEditRole = (organization) -> - organization.role = organization.beforeEditRole - organization.editMode = false - - scope.updateUserRole = (organization, user) -> - user.isUpdatingRole = true - # The role must be set on the user for #updateUserRole. - user.role = organization.role - MnoeUsers.updateUserRole(organization, user).then( - () -> - $translate(UserRoles.keyFromRole(user.role)).then((tls) -> - toastr.success('mnoe_admin_panel.dashboard.users.widget.local_list.role_update_success', {extraData: {user: "#{user.email}", role: tls}}) - ) - (error) -> - organization.role = organization.beforeEditRole - toastr.error('mnoe_admin_panel.dashboard.users.widget.local_list.role_update_error') - MnoErrorsHandler.processServerError(error) - ).finally( () -> - # So that the organization/user reverts back to non-editing view. - organization.beforeEditRole = null - organization.isUpdatingRole = false - organization.editMode = false - ) - scope.$watch('list', (newVal) -> if newVal displayNormalState() diff --git a/src/app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.html b/src/app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.html index e5f07a35..55f4269b 100644 --- a/src/app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.html +++ b/src/app/components/mnoe-organizations-local-list/mnoe-organizations-local-list.html @@ -10,7 +10,6 @@ mnoe_admin_panel.dashboard.organization.widget.local_list.search_organizations.table.name mnoe_admin_panel.dashboard.organization.uid mnoe_admin_panel.dashboard.organization.widget.local_list.search_organizations.table.created_at - mnoe_admin_panel.dashboard.organization.widget.local_list.search_organizations.table.role @@ -24,15 +23,6 @@ {{organization.uid}} {{organization.created_at | date: 'dd/MM/yyyy'}} - - - - {{ userRoles.keyFromRole(organization.role) | translate }} - - - - - diff --git a/src/app/views/home/home.controller.coffee b/src/app/views/home/home.controller.coffee index d5cc325e..4d9b755c 100644 --- a/src/app/views/home/home.controller.coffee +++ b/src/app/views/home/home.controller.coffee @@ -1,4 +1,4 @@ -@App.controller 'HomeController', (moment, MnoeUsers, MnoeOrganizations, MnoeInvoices, MnoeAdminConfig, MnoeCurrentUser) -> +@App.controller 'HomeController', (moment, MnoeUsers, MnoeOrganizations, MnoeInvoices, MnoeAdminConfig) -> 'ngInject' vm = this @@ -33,17 +33,4 @@ vm.invoices.outstandingAmount = response.data ) if MnoeAdminConfig.isFinanceEnabled() - vm.orgTableCustomizations = { - getOrganizations: (limit, offset, sort = 'created_at') -> - MnoeCurrentUser.getUser().then( -> - params = {} - - if MnoeAdminConfig.isAccountManagerEnabled() - params['sub_tenant_id'] = MnoeCurrentUser.user.mnoe_sub_tenant_id - params['account_manager_id'] = MnoeCurrentUser.user.id - - MnoeOrganizations.list(limit, offset, sort, params) - ) - } - return diff --git a/src/app/views/home/home.html b/src/app/views/home/home.html index 2c49b754..55a115d1 100644 --- a/src/app/views/home/home.html +++ b/src/app/views/home/home.html @@ -38,7 +38,7 @@
- +
diff --git a/src/app/views/user/user.controller.coffee b/src/app/views/user/user.controller.coffee index dde6b804..9014518f 100644 --- a/src/app/views/user/user.controller.coffee +++ b/src/app/views/user/user.controller.coffee @@ -1,8 +1,9 @@ -@App.controller 'UserController', ($stateParams, MnoeUsers, UserRoles, $translate, toastr, MnoErrorsHandler, MnoeOrganizations) -> +@App.controller 'UserController', ($stateParams, MnoeUsers, UserRoles, $translate, toastr, MnoErrorsHandler) -> 'ngInject' vm = this vm.user = {} - vm.orgTableCustomizations = {} + vm.orgSearchParams = { 'where[users.id]': $stateParams.userId } + # Get the user MnoeUsers.get($stateParams.userId).then( (response) -> @@ -12,10 +13,8 @@ if phone && countryCode vm.user.phone = '+' + countryCode + phone - vm.orgTableCustomizations.searchParams = { 'where[users.id]': vm.user.id } - # These bindings are so that we can add additional fields with functionality to the organization table. - vm.orgTableCustomizations.bindings = { + vm.orgTableBindings = { userRoles: UserRoles user: vm.user @@ -53,7 +52,7 @@ $translate('mnoe_admin_panel.dashboard.organization.widget.local_list.search_organizations.table.role') .then((translation) -> - vm.orgTableCustomizations.fields = [ + vm.orgTableFields= [ { header: translation style: { @@ -82,9 +81,4 @@ ] ) - vm.orgTableCustomizations.getOrganizations = (limit, offset, sort = 'created_at') -> - return unless vm.user['id'] - params = vm.orgTableCustomizations.searchParams - MnoeOrganizations.list(limit, offset, sort, params) - return diff --git a/src/app/views/user/user.html b/src/app/views/user/user.html index 249d10c2..bc2e3bfc 100644 --- a/src/app/views/user/user.html +++ b/src/app/views/user/user.html @@ -84,9 +84,9 @@

{{'mnoe_admin_panel.dashboard.user.geo_information_title
+ search-params="vm.orgSearchParams" + bindings="vm.orgTableBindings"

From 3f3aa4299804ab86b484cdd0ff6efbf20a66c353 Mon Sep 17 00:00:00 2001 From: Isaac Seessel Date: Wed, 28 Mar 2018 16:30:30 -0400 Subject: [PATCH 3/3] [MNOE-978]Fix tables jumping bug --- .../mnoe-organizations-list/mnoe-organizations-list.coffee | 6 +++--- src/app/components/mnoe-users-list/mno-users-list.coffee | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee index ea7eb09b..531584ea 100644 --- a/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee +++ b/src/app/components/mnoe-organizations-list/mnoe-organizations-list.coffee @@ -1,5 +1,5 @@ # -# Mnoe Organizations Local List +# Mnoe Organizations List # The organization-local-list is used for organizations that already exist on the frontend, e.g. when uploading a CSV file. # Whereas organizations-list is used when organizations must be fetched. # @@ -16,7 +16,7 @@ # Variables initialization scope.organizations = search: '' - sortAttr: 'created_at' + sortAttr: 'created_at.desc' nbItems: 10 page: 1 pageChangedCb: (nbItems, page) -> @@ -89,7 +89,7 @@ fetchOrganizations(scope.organizations.nbItems, 0, scope.organizations.sortAttr) # Fetch organisations - fetchOrganizations = (limit, offset, sort = 'created_at') -> + fetchOrganizations = (limit, offset, sort = 'created_at.desc') -> scope.organizations.loading = true MnoeCurrentUser.getUser().then( -> params = if MnoeAdminConfig.isAccountManagerEnabled() diff --git a/src/app/components/mnoe-users-list/mno-users-list.coffee b/src/app/components/mnoe-users-list/mno-users-list.coffee index a84c9995..3be089d1 100644 --- a/src/app/components/mnoe-users-list/mno-users-list.coffee +++ b/src/app/components/mnoe-users-list/mno-users-list.coffee @@ -11,7 +11,7 @@ # Variables initialization scope.users = search: '' - sortAttr: 'created_at' + sortAttr: 'created_at.desc' nbItems: 10 page: 1 pageChangedCb: (nbItems, page) -> @@ -79,7 +79,7 @@ fetchUsers(scope.users.nbItems, 0, scope.users.sortAttr) # Fetch users - fetchUsers = (limit, offset, sort = 'surname') -> + fetchUsers = (limit, offset, sort = 'created_at.desc') -> scope.users.loading = true MnoeCurrentUser.getUser().then( -> params = if MnoeAdminConfig.isAccountManagerEnabled()