diff options
Diffstat (limited to 'ecomp-portal-FE-common/client/app/views')
8 files changed, 739 insertions, 611 deletions
diff --git a/ecomp-portal-FE-common/client/app/views/errors/error.controller.js b/ecomp-portal-FE-common/client/app/views/errors/error.controller.js new file mode 100644 index 00000000..5f4f410d --- /dev/null +++ b/ecomp-portal-FE-common/client/app/views/errors/error.controller.js @@ -0,0 +1,20 @@ +'use strict'; +(function () { + class ErrorCtrl { + constructor($log, $scope,$state) { + $scope.errorState = $state.current.name; + if($scope.errorState=='root.error404'){ + $scope.errorTitle="Page Not Found"; + $scope.errorMsg="The page you are looking for cannot be found"; + }else if($scope.errorState=='noUserError'){ + $scope.errorTitle="Authorization denied"; + $scope.errorMsg= "Please Contact Your Administrator for the page access"; + }else { + $scope.errorTitle="Something went wrong"; + $scope.errorMsg= "Please go back to the previous page"; + } + } + } + ErrorCtrl.$inject = ['$log','$scope','$state']; + angular.module('ecompApp').controller('ErrorCtrl', ErrorCtrl); +})();
\ No newline at end of file diff --git a/ecomp-portal-FE-common/client/app/views/errors/error.tpl.html b/ecomp-portal-FE-common/client/app/views/errors/error.tpl.html new file mode 100644 index 00000000..44b43ce4 --- /dev/null +++ b/ecomp-portal-FE-common/client/app/views/errors/error.tpl.html @@ -0,0 +1,31 @@ +<!-- + ================================================================================ + ECOMP Portal + ================================================================================ + Copyright (C) 2017 AT&T Intellectual Property + ================================================================================ + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. + ================================================================================ + --> +<div class="w-ecomp-admins-page-main"> + <div id="page-content"> + <div id="title" class="w-ecomp-main-view-title"> + <h1 class="heading-page">{{errorTitle}}</h1> + </div> + <div class="errorContent"> + <p>{{errorMsg}}</p> + </div> + + </div> + +</div> diff --git a/ecomp-portal-FE-common/client/app/views/role/role.html b/ecomp-portal-FE-common/client/app/views/role/role.html index 9febc978..63073aeb 100644 --- a/ecomp-portal-FE-common/client/app/views/role/role.html +++ b/ecomp-portal-FE-common/client/app/views/role/role.html @@ -94,30 +94,7 @@ </div> <a id="manage-role" href="roleFunctions">Manage Role Functions</a><br><br> - - <div id="page-title-child" class="pageTitle"> - <label>Child Roles</label> - <a id="add-child-role" ng-click="addNewChildRoleModalPopup();" ng-style="{'cursor':'pointer'}" class="icon-primary-accordion-plus" size="small"></a> - </div> - - <div b2b-table table-data="role.childRoles" ng-hide="users.isLoadingTable" search-string="users.searchString" class="b2b-table-div"> - <table> - <thead b2b-table-row type="header"> - <tr > - <th id="table-header-name" b2b-table-header key="firstName" sortable="true" >Name</th> - <th id="table-header-remove" b2b-table-header key="lastName" sortable="true" >Remove</th> - </tr> - </thead> - <tbody b2b-table-row type="body" row-repeat="role in role.childRoles"> - <tr > - <td id="role-function-{{role.name}}" b2b-table-body id="rowheader_t1_{{$index}}" headers="col1" ng-bind="role.name"></td> - <td b2b-table-body headers="rowheader_t1_{{$index}} col4" id="{{$index}}-button-remove-role" > - <div ng-click="removeChildRole(role);" ><a href="javascript:void(0)" class="icon-misc-trash"></a></div> - </td> - </tr> - </tbody> - </table> - </div> + </div> </div> </div> diff --git a/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.controller.js b/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.controller.js index 48f7d9df..366fb215 100644 --- a/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.controller.js +++ b/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.controller.js @@ -19,11 +19,11 @@ */ 'use strict'; -(function () { +(function() { class userNotificationsModalCtrl { - constructor($scope, $log, functionalMenuService, confirmBoxService, notificationService, $modal, ngDialog, $state, $filter,items) { - this.debug = false; + constructor($scope, $log, functionalMenuService, confirmBoxService, notificationService, $modal, ngDialog, $state, $filter, items) { + this.debug = false; $scope.newNotifModel = { 'isOnlineUsersOnly': null, 'isForAllRolesOptions': null, @@ -34,10 +34,12 @@ 'msgHeader': null, 'msgDescription': null, 'roleIds': null, - 'anyTreeItemSelected':false, - 'roleObj': {notificationRoleIds:null} + 'anyTreeItemSelected': false, + 'roleObj': { + notificationRoleIds: null + } }; - + $scope.notificationId = null; $scope.selectedCat = null; $scope.selectedEcompFunc = null; @@ -45,42 +47,72 @@ "Y": 0, "N": 1 } - - $scope.onlineAllUsersOptions = [ - { "index": 0, "value": "Y", "title": "Online Users Only" }, - { "index": 1, "value": "N", "title": "Online & Offline Users" } - + + $scope.onlineAllUsersOptions = [{ + "index": 0, + "value": "Y", + "title": "Online Users Only" + }, + { + "index": 1, + "value": "N", + "title": "Online & Offline Users" + } + ]; - $scope.isForAllRolesOptions = [ - { "index": 0, "value": "Y", "title": "Yes" }, - { "index": 1, "value": "N", "title": "No" } + $scope.isForAllRolesOptions = [{ + "index": 0, + "value": "Y", + "title": "Yes" + }, + { + "index": 1, + "value": "N", + "title": "No" + } ]; - $scope.priorityOptions = [ - { "index": 0, "value": 1, "title": "Normal" }, - { "index": 1, "value": 2, "title": "Important" } + $scope.priorityOptions = [{ + "index": 0, + "value": 1, + "title": "Normal" + }, + { + "index": 1, + "value": 2, + "title": "Important" + } ]; - $scope.isActiveOptions = [ - { "index": 0, "value": "Y", "title": "Yes" }, - { "index": 1, "value": "N", "title": "No" } + $scope.isActiveOptions = [{ + "index": 0, + "value": "Y", + "title": "Yes" + }, + { + "index": 1, + "value": "N", + "title": "No" + } ]; $scope.newNotifModel.isActive = $scope.isActiveOptions[0]; $scope.newNotifModel.selectPriority = $scope.priorityOptions[0]; $scope.newNotifModel.isOnlineUsersOnly = $scope.onlineAllUsersOptions[1]; - $scope.newNotifModel.isForAllRoles=$scope.isForAllRolesOptions[0].value; - $scope.newNotifModel.isFunctionalMenu ="Y"; - - $scope.newNotifModel.selectedPriority=$scope.priorityOptions[0].value; - $scope.newNotifModel.msgHeader = ''; - $scope.newNotifModel.msgDescription = ''; - $scope.newNotifModel.treeTitle="Functional Menu"; - $scope.newNotifModel.notifObj= {isCategoriesFunctionalMenu:true}; + $scope.newNotifModel.isForAllRoles = $scope.isForAllRolesOptions[0].value; + $scope.newNotifModel.isFunctionalMenu = "Y"; + + $scope.newNotifModel.selectedPriority = $scope.priorityOptions[0].value; + $scope.newNotifModel.msgHeader = ''; + $scope.newNotifModel.msgDescription = ''; + $scope.newNotifModel.treeTitle = "Functional Menu"; + $scope.newNotifModel.notifObj = { + isCategoriesFunctionalMenu: true + }; let init = () => { - if(this.debug) - $log.debug('userNotificationsModalCtrl::init'); + if (this.debug) + $log.debug('userNotificationsModalCtrl::init'); this.isSaving = false; var today = new Date(); $scope.minDate = today.toISOString().substring(0, 10); @@ -88,10 +120,12 @@ threeMonthsFromNow.setMonth(threeMonthsFromNow.getMonth() + 3); $scope.maxDate = threeMonthsFromNow.toISOString().substring(0, 10); if (items && items.notif) { - if(this.debug) - $log.debug('userNotificationsModalCtrl:init:: Edit notification mode for', items.notif); + if (this.debug) + $log.debug('userNotificationsModalCtrl:init:: Edit notification mode for', items.notif); $scope.isEditMode = true; - $scope.editModeObj = {isEditMode: true}; + $scope.editModeObj = { + isEditMode: true + }; this.notif = _.clone(items.notif); $scope.modalPgTitle = 'View Notification' $scope.newNotifModel.isOnlineUsersOnly = $scope.onlineAllUsersOptions[this.YN_index_mapping[this.notif.isForOnlineUsers]]; @@ -104,24 +138,30 @@ $scope.newNotifModel.msgDescription = this.notif.msgDescription; $scope.notificationId = this.notif.notificationId; $scope.newNotifModel.notificationRoleIds = this.notif.roleIds; - $scope.roleObj = {notificationRoleIds:this.notif.roleIds}; + $scope.roleObj = { + notificationRoleIds: this.notif.roleIds + }; } else { - if(this.debug) - $log.debug('AppDetailsModalCtrl:init:: New app mode'); + if (this.debug) + $log.debug('AppDetailsModalCtrl:init:: New app mode'); $scope.isEditMode = false; - $scope.editModeObj = {isEditMode: false}; + $scope.editModeObj = { + isEditMode: false + }; $scope.modalPgTitle = 'Add a New Notification' this.notif = _.clone($scope.newNotifModel); - $scope.roleObj = {notificationRoleIds:null}; + $scope.roleObj = { + notificationRoleIds: null + }; } }; this.conflictMessages = {}; this.scrollApi = {}; let handleConflictErrors = err => { - if(!err.data){ + if (!err.data) { return; } - if(!err.data.length){ // support objects + if (!err.data.length) { // support objects err.data = [err.data] } _.forEach(err.data, item => { @@ -139,42 +179,66 @@ let resetConflict = fieldName => { delete this.conflictMessages[fieldName]; - if($scope.appForm[fieldName]){ + if ($scope.appForm[fieldName]) { $scope.appForm[fieldName].$setValidity('conflict', true); } }; - $scope.addUserNotificationValidation = function () { - // // pre-processing - if (!($scope.isEditMode)) { - var validation=false; - if($scope.isDateValid($scope.newNotifModel.startTime) && $scope.isDateValid($scope.newNotifModel.endTime) && $scope.newNotifModel.msgHeader != '' && $scope.newNotifModel.msgDescription != '' && ($scope.newNotifModel.startTime<$scope.newNotifModel.endTime)){ - validation=true; - if( $scope.newNotifModel.isForAllRoles=='N'){ - validation = $scope.checkTreeSelect(); - } - } - else{ - validation=false; - } - return !validation; - } - } - + $scope.addUserNotificationValidation = function() { + // // pre-processing + if (!($scope.isEditMode)) { + var validation = false; + if ($scope.isStartDateValidFromToday($scope.newNotifModel.startTime)&&$scope.isStartDateValidFromToday($scope.newNotifModel.endTime)&&$scope.isDateValid($scope.newNotifModel.startTime) && $scope.isDateValid($scope.newNotifModel.endTime) && $scope.newNotifModel.msgHeader != '' && $scope.newNotifModel.msgDescription != '' && ($scope.newNotifModel.startTime < $scope.newNotifModel.endTime)) { + validation = true; + if ($scope.newNotifModel.isForAllRoles == 'N') { + validation = $scope.checkTreeSelect(); + } + } else { + validation = false; + } + return !validation; + } + } + /* format the value for viewing a notification */ - $scope.formatStartDate = function () { - if ($scope.newNotifModel.startTime) { - $scope.newNotifModel.startTime = $filter('date')($scope.startTime, 'medium'); - } + $scope.formatStartDate = function() { + if ($scope.newNotifModel.startTime) { + $scope.newNotifModel.startTime = $filter('date')($scope.startTime, 'medium'); + } } - + /* format the value for viewing a notification */ - $scope.formatEndDate = function () { - if($scope.newNotifModel.endTime){ - $scope.newNotifModel.endTime = $filter('date')($scope.endTime, 'medium'); - } + $scope.formatEndDate = function() { + if ($scope.newNotifModel.endTime) { + $scope.newNotifModel.endTime = $filter('date')($scope.endTime, 'medium'); + } } - $scope.isDateValid = function (time) { + /*To validate the manual entry of date in MM/DD/YYYY Format*/ + + $scope.isDateValid = function(time) { + if (time == undefined) { + return false; + } + if (typeof time == 'object') { + return true; + } + var startDateformat = time.split('/'); + if (startDateformat.length != 3) return false; + var day = startDateformat[1]; + var month = startDateformat[0]; + month = parseInt(month) - 1; + var year = startDateformat[2]; + if (year.length != 4) return false; + var composedDate = new Date(year, month, day); + return composedDate.getDate() == day && + composedDate.getMonth() == month && + composedDate.getFullYear() == year; + }; + + /*The manual and drop down calendar should be consistent. + Start date must be greater than or equal to current date.The end dates are not allowed after the 3 months from current dates*/ + + $scope.isStartDateValidFromToday = function (time) { if(time == undefined){ return false; } @@ -182,309 +246,317 @@ return true; } var startDateformat =time.split('/'); - if (startDateformat.length != 3) return false; + if (startDateformat.length != 3) return true; var day = startDateformat[1]; var month = startDateformat[0]; month= parseInt(month)-1; var year = startDateformat[2]; - if(year.length!=4) return false; + if(year.length!=4) return true; var composedDate = new Date(year, month, day); - return composedDate.getDate() == day && - composedDate.getMonth() == month && - composedDate.getFullYear() == year; - + /* As end dates are not allowed after the 3 months from current dates*/ + var x = 3; //or whatever offset + var CurrentDate = new Date(); + /*If composed date is less than the current date,error message should display*/ + if(composedDate<CurrentDate) + return false; + CurrentDate.setMonth(CurrentDate.getMonth() + x); + if(composedDate>CurrentDate) + return false; + return true; }; - - - $scope.addUserNotification = function () { - $scope.notificationRoleIds = []; - // pre-processing - - for(var fi=0;fi<$scope.treedata.length;fi++){ - var fLevel = $scope.treedata[fi]; - if(fLevel){ - var fLevelChild = fLevel.child; - for(var si=0;si<fLevelChild.length;si++){ - var sLevel = fLevelChild[si]; - if(sLevel){ - var sLevelChild = sLevel.child; - if(sLevelChild){ - for(var ti=0;ti< sLevelChild.length;ti++){ - var tLevel = sLevelChild[ti]; - if(tLevel.isSelected && tLevel.roleId){ - $scope.newNotifModel.anyTreeItemSelected=true; - for(var i in tLevel.roleId) - $scope.notificationRoleIds.push(tLevel.roleId[i]); - } - } - } - } - if(sLevel.isSelected && sLevel.roleId){ - for(var i in sLevel.roleId) - $scope.notificationRoleIds.push(sLevel.roleId[i]); - } - } - } - } - - $scope.notificationRoleIds.sort(); - if (($scope.newNotifModel.isOnlineUsersOnly) && ($scope.newNotifModel.isForAllRoles) && ($scope.newNotifModel.selectedPriority) && ($scope.newNotifModel.isActive) - && ($scope.newNotifModel.startTime) && ($scope.newNotifModel.endTime) && ($scope.newNotifModel.msgHeader != '') && ($scope.newNotifModel.msgDescription != '')) { - this.newUserNotification = - { - 'notificationId':$scope.notificationId, - 'isForOnlineUsers': $scope.newNotifModel.isOnlineUsersOnly.value, - 'isForAllRoles': $scope.newNotifModel.isForAllRoles, - 'priority': $scope.newNotifModel.selectedPriority, - 'activeYn': $scope.newNotifModel.isActive.value, - 'startTime': $scope.newNotifModel.startTime, - 'endTime': $scope.newNotifModel.endTime, - 'msgHeader': $scope.newNotifModel.msgHeader, - 'msgDescription': $scope.newNotifModel.msgDescription, - 'roleIds': $scope.notificationRoleIds, - 'createdDate': new Date() - }; - - // POST ajax call here; - if ($scope.isEditMode) { - notificationService.updateAdminNotification(this.newUserNotification) - .then(() => { - if(this.debug) - $log.debug('NotificationService:updateAdminNotification:: Admin notification update succeeded!'); - $scope.closeThisDialog(true); - }).catch(err => { - $log.error('notificationService.updateAdminNotfication failed: ' + JSON.stringify(err)); - switch (err.status) { - case '409': // Conflict - // handleConflictErrors(err); - break; - case '500': // Internal Server Error - confirmBoxService.showInformation('There was a problem updating the notification. ' + - 'Please try again later. Error: ' + err.status).then(isConfirmed => { }); - break; - case '403': // Forbidden... possible - // webjunction error to - // try again - confirmBoxService.showInformation('There was a problem updating the notification. ' + - 'Please try again. If the problem persists, then try again later. Error: ' + err.status).then(isConfirmed => { }); - break; - default: - confirmBoxService.showInformation('There was a problem updating the notification. ' + - 'Please try again. If the problem persists, then try again later. Error: ' + err.status).then(isConfirmed => { }); - } - }).finally(() => { - // for bug in IE 11 - var objOffsetVersion = objAgent.indexOf("MSIE"); - if (objOffsetVersion != -1) { - if(this.debug) - $log.debug('AppDetailsModalCtrl:updateOnboardingApp:: Browser is IE, forcing Refresh'); - $window.location.reload(); - } - // for bug in IE 11 - }); - - } else { - notificationService.addAdminNotification(this.newUserNotification) - .then((res) => { - if(this.debug) - $log.debug('notificationService:addAdminNotification:: Admin notification creation succeeded!,',res); - if(res.status=='ERROR'){ - confirmBoxService.showInformation('There was a problem adding the notification. ' + - ' Error: ' + res.response).then(isConfirmed => { }); - - - } - else{ - //$scope.closeThisDialog(true); - $scope.$dismiss('cancel'); - } - - // emptyCookies(); - }).catch(err => { - switch (err.status) { - case '409': // Conflict - // handleConflictErrors(err); - break; - case '500': // Internal Server Error - confirmBoxService.showInformation('There was a problem adding the notification. ' + - 'Please try again later. Error: ' + err.status).then(isConfirmed => { }); - break; - default: - confirmBoxService.showInformation('There was a problem adding the notification. ' + - 'Please try again. If the problem persists, then try again later. Error: ' + - err.status).then(isConfirmed => { }); - } - $log.error('notificationService:addAdminNotification error:: ' + JSON.stringify(err)); - }) - } - - - } else { - $log.warn('please fill in all required fields'); - confirmBoxService.showInformation('Please fill in all required fields').then(isConfirmed => { }); - } + + + $scope.addUserNotification = function() { + $scope.notificationRoleIds = []; + // pre-processing + + for (var fi = 0; fi < $scope.treedata.length; fi++) { + var fLevel = $scope.treedata[fi]; + if (fLevel) { + var fLevelChild = fLevel.child; + if (fLevelChild) { + for (var si = 0; si < fLevelChild.length; si++) { + var sLevel = fLevelChild[si]; + if (sLevel) { + var sLevelChild = sLevel.child; + if (sLevelChild) { + for (var ti = 0; ti < sLevelChild.length; ti++) { + var tLevel = sLevelChild[ti]; + if (tLevel.isSelected && tLevel.roleId) { + $scope.newNotifModel.anyTreeItemSelected = true; + for (var i in tLevel.roleId) + $scope.notificationRoleIds.push(tLevel.roleId[i]); + } + } + } + } + if (sLevel.isSelected && sLevel.roleId) { + for (var i in sLevel.roleId) + $scope.notificationRoleIds.push(sLevel.roleId[i]); + } + } + } + } + } + + $scope.notificationRoleIds.sort(); + if (($scope.newNotifModel.isOnlineUsersOnly) && ($scope.newNotifModel.isForAllRoles) && ($scope.newNotifModel.selectedPriority) && ($scope.newNotifModel.isActive) && + ($scope.newNotifModel.startTime) && ($scope.newNotifModel.endTime) && ($scope.newNotifModel.msgHeader != '') && ($scope.newNotifModel.msgDescription != '')) { + this.newUserNotification = { + 'notificationId': $scope.notificationId, + 'isForOnlineUsers': $scope.newNotifModel.isOnlineUsersOnly.value, + 'isForAllRoles': $scope.newNotifModel.isForAllRoles, + 'priority': $scope.newNotifModel.selectedPriority, + 'activeYn': $scope.newNotifModel.isActive.value, + 'startTime': $scope.newNotifModel.startTime, + 'endTime': $scope.newNotifModel.endTime, + 'msgHeader': $scope.newNotifModel.msgHeader, + 'msgDescription': $scope.newNotifModel.msgDescription, + 'roleIds': $scope.notificationRoleIds, + 'createdDate': new Date() + }; + + // POST ajax call here; + if ($scope.isEditMode) { + notificationService.updateAdminNotification(this.newUserNotification) + .then(() => { + if (this.debug) + $log.debug('NotificationService:updateAdminNotification:: Admin notification update succeeded!'); + $scope.closeThisDialog(true); + }).catch(err => { + $log.error('notificationService.updateAdminNotfication failed: ' + JSON.stringify(err)); + switch (err.status) { + case '409': // Conflict + // handleConflictErrors(err); + break; + case '500': // Internal Server Error + confirmBoxService.showInformation('There was a problem updating the notification. ' + + 'Please try again later. Error: ' + err.status).then(isConfirmed => {}); + break; + case '403': // Forbidden... possible + // webjunction error to + // try again + confirmBoxService.showInformation('There was a problem updating the notification. ' + + 'Please try again. If the problem persists, then try again later. Error: ' + err.status).then(isConfirmed => {}); + break; + default: + confirmBoxService.showInformation('There was a problem updating the notification. ' + + 'Please try again. If the problem persists, then try again later. Error: ' + err.status).then(isConfirmed => {}); + } + }).finally(() => { + // for bug in IE 11 + var objOffsetVersion = objAgent.indexOf("MSIE"); + if (objOffsetVersion != -1) { + if (this.debug) + $log.debug('AppDetailsModalCtrl:updateOnboardingApp:: Browser is IE, forcing Refresh'); + $window.location.reload(); + } + // for bug in IE 11 + }); + + } else { + notificationService.addAdminNotification(this.newUserNotification) + .then((res) => { + if (this.debug) + $log.debug('notificationService:addAdminNotification:: Admin notification creation succeeded!,', res); + if (res.status == 'ERROR') { + confirmBoxService.showInformation('There was a problem adding the notification. ' + + ' Error: ' + res.response).then(isConfirmed => {}); + + + } else { + // $scope.closeThisDialog(true); + $scope.$dismiss('cancel'); + } + + // emptyCookies(); + }).catch(err => { + switch (err.status) { + case '409': // Conflict + // handleConflictErrors(err); + break; + case '500': // Internal Server Error + confirmBoxService.showInformation('There was a problem adding the notification. ' + + 'Please try again later. Error: ' + err.status).then(isConfirmed => {}); + break; + default: + confirmBoxService.showInformation('There was a problem adding the notification. ' + + 'Please try again. If the problem persists, then try again later. Error: ' + + err.status).then(isConfirmed => {}); + } + $log.error('notificationService:addAdminNotification error:: ' + JSON.stringify(err)); + }) + } + + + } else { + $log.warn('please fill in all required fields'); + confirmBoxService.showInformation('Please fill in all required fields').then(isConfirmed => {}); + } + } + $scope.functionalMenuRes = {}; + $scope.checkTreeSelect = function() { + if ($scope.treedata) { + for (var fi = 0; fi < $scope.treedata.length; fi++) { + var fLevel = $scope.treedata[fi]; + if (fLevel.isSelected) { + return true; + } + var sLevel = fLevel.child; + if (sLevel) { + for (var si = 0; si < sLevel.length; si++) { + if (sLevel[si].isSelected) { + return true; + } + var tLevel = sLevel[si].child; + if (tLevel) { + for (var ti = 0; ti < tLevel.length; ti++) { + if (tLevel[ti].isSelected) { + return true; + } + } + } + } + } + } + } + return false; } - $scope.functionalMenuRes={}; - $scope.checkTreeSelect = function(){ - if($scope.treedata){ - for(var fi=0; fi<$scope.treedata.length;fi++){ - var fLevel = $scope.treedata[fi]; - if(fLevel.isSelected){ - return true; - } - var sLevel = fLevel.child; - if(sLevel){ - for(var si=0;si<sLevel.length;si++){ - if(sLevel[si].isSelected){ - return true; - } - var tLevel = sLevel[si].child; - if(tLevel){ - for(var ti=0;ti<tLevel.length;ti++){ - if(tLevel[ti].isSelected){ - return true; - } - } - } - } - } - } - } - return false; - } // Populate the category list for category dropdown list let getFunctionalMenu = () => { - this.isLoadingTable = true; - if(this.debug) - $log.debug('getFunctionalMenu:init'); - - functionalMenuService.getFunctionalMenuRole().then(role_res => { - var menu_role_dict = {}; - if(this.debug) - $log.debug('functionalMenuService:getFunctionalMenuRole:: getting result', role_res); - - for (var i in role_res) { - // if first time appear in menu_role_dict - if (!(role_res[i].menuId in menu_role_dict)) { - menu_role_dict[role_res[i].menuId] = [role_res[i].roleId]; - } else { - menu_role_dict[role_res[i].menuId].push(role_res[i].roleId); - } - } - - functionalMenuService.getManagedFunctionalMenuForNotificationTree().then(res => { - if(this.debug) - $log.debug('functionalMenuService:getManagedFunctionalMenuForNotificationTree:: getting result', res); - var exclude_list = ['Favorites']; - let actualData=[]; - $scope.functionalMenuRes=res; - - //Adding children and label attribute to all objects in res - for(let i = 0; i < res.length; i++){ - res[i].child=[]; - res[i].name=res[i].text; - res[i].id=res[i].text; - res[i].displayCheckbox= true; - $scope.checkBoxObj = {isAnyRoleSelected:false}; - res[i].roleId = menu_role_dict[res[i].menuId]; - res[i].onSelect = function () { - $scope.$apply(function () { - $scope.newNotifModel.anyTreeItemSelected=$scope.checkTreeSelect(); - }) - }; - - if (res[i].roleId && res[i].roleId.length==_.intersection(res[i].roleId, $scope.roleObj.notificationRoleIds).length){ - res[i].isSelected= true; - res[i].selected= true; - res[i].indeterminate= false; - }else{ - /*default*/ - res[i].isSelected= false; - res[i].selected= false; - res[i].indeterminate= false; - } - } - - // Adding actual child items to children array in res - // objects - $scope.parentChildDict ={}; - $scope.parentChildRoleIdDict ={}; - for (let i = 0; i < res.length; i++) { - let parentId = res[i].menuId; - $scope.parentChildDict[parentId] = []; - $scope.parentChildRoleIdDict[parentId]=[]; - for (let j = 0; j < res.length; j++) { - let childId = res[j].parentMenuId; - if (parentId === childId) { - res[i].child.push(res[j]); - $scope.parentChildDict[parentId].push(res[j].menuId); - //if res[j].roleId is defined - if (res[j].roleId) { - for (let k in res[j].roleId) { - $scope.parentChildRoleIdDict[parentId].push(res[j].roleId[k]); - } - - } - } - } - } - //check if grand children exist - for (var key in $scope.parentChildDict){ - var child = $scope.parentChildDict[key]; - var isGrandParent = false; - if (child.length>0) { - for (var i in child) { - if ($scope.parentChildDict[child[i]].length>0){ - isGrandParent = true; - break; - } - } - } - if (isGrandParent) { - for (var i in child) { - // if the child has children - if ($scope.parentChildDict[child[i]].length>0) { - for (var j in $scope.parentChildRoleIdDict[child[i]]) { - if ($scope.parentChildRoleIdDict[key].indexOf($scope.parentChildRoleIdDict[child[i]][j]) === -1) { - $scope.parentChildRoleIdDict[key].push($scope.parentChildRoleIdDict[child[i]][j]); - } - } - } - } - } - - }; - - // Sort the top-level menu items in order based on the column - res.sort(function(a, b) { - return a.column-b.column; - }); - - // Sort all the child in order based on the column - for(let i = 0; i < res.length; i++){ - res[i].child.sort(function(a, b){ - return a.column-b.column; - }); - } - - //Forming actual parent items - for(let i = 0; i < res.length; i++){ - let parentId=res[i].parentMenuId; - if(parentId===null){ - actualData.push(res[i]); - } - } - var treedata = actualData[0].child; - $scope.treedata = []; - - /*Remove favorite from the list */ - for (var i in treedata) { - if (!(treedata[i].name.indexOf(exclude_list) > -1)) { - $scope.treedata.push(treedata[i]) - } - } - //setting b2b tree parameter - $scope.settingTreeParam(); + this.isLoadingTable = true; + if (this.debug) + $log.debug('getFunctionalMenu:init'); + + functionalMenuService.getFunctionalMenuRole().then(role_res => { + var menu_role_dict = {}; + if (this.debug) + $log.debug('functionalMenuService:getFunctionalMenuRole:: getting result', role_res); + + for (var i in role_res) { + // if first time appear in menu_role_dict + if (!(role_res[i].menuId in menu_role_dict)) { + menu_role_dict[role_res[i].menuId] = [role_res[i].roleId]; + } else { + menu_role_dict[role_res[i].menuId].push(role_res[i].roleId); + } + } + + functionalMenuService.getManagedFunctionalMenuForNotificationTree().then(res => { + if (this.debug) + $log.debug('functionalMenuService:getManagedFunctionalMenuForNotificationTree:: getting result', res); + var exclude_list = ['Favorites']; + let actualData = []; + $scope.functionalMenuRes = res; + + //Adding children and label attribute to all objects in res + for (let i = 0; i < res.length; i++) { + res[i].child = []; + res[i].name = res[i].text; + res[i].id = res[i].text; + res[i].displayCheckbox = true; + $scope.checkBoxObj = { + isAnyRoleSelected: false + }; + res[i].roleId = menu_role_dict[res[i].menuId]; + res[i].onSelect = function() { + $scope.$apply(function() { + $scope.newNotifModel.anyTreeItemSelected = $scope.checkTreeSelect(); + }) + }; + + if (res[i].roleId && res[i].roleId.length == _.intersection(res[i].roleId, $scope.roleObj.notificationRoleIds).length) { + res[i].isSelected = true; + res[i].selected = true; + res[i].indeterminate = false; + } else { + /*default*/ + res[i].isSelected = false; + res[i].selected = false; + res[i].indeterminate = false; + } + } + + // Adding actual child items to children array in res + // objects + $scope.parentChildDict = {}; + $scope.parentChildRoleIdDict = {}; + for (let i = 0; i < res.length; i++) { + let parentId = res[i].menuId; + $scope.parentChildDict[parentId] = []; + $scope.parentChildRoleIdDict[parentId] = []; + for (let j = 0; j < res.length; j++) { + let childId = res[j].parentMenuId; + if (parentId === childId) { + res[i].child.push(res[j]); + $scope.parentChildDict[parentId].push(res[j].menuId); + //if res[j].roleId is defined + if (res[j].roleId) { + for (let k in res[j].roleId) { + $scope.parentChildRoleIdDict[parentId].push(res[j].roleId[k]); + } + + } + } + } + } + //check if grand children exist + for (var key in $scope.parentChildDict) { + var child = $scope.parentChildDict[key]; + var isGrandParent = false; + if (child.length > 0) { + for (var i in child) { + if ($scope.parentChildDict[child[i]].length > 0) { + isGrandParent = true; + break; + } + } + } + if (isGrandParent) { + for (var i in child) { + // if the child has children + if ($scope.parentChildDict[child[i]].length > 0) { + for (var j in $scope.parentChildRoleIdDict[child[i]]) { + if ($scope.parentChildRoleIdDict[key].indexOf($scope.parentChildRoleIdDict[child[i]][j]) === -1) { + $scope.parentChildRoleIdDict[key].push($scope.parentChildRoleIdDict[child[i]][j]); + } + } + } + } + } + + }; + + // Sort the top-level menu items in order based on the column + res.sort(function(a, b) { + return a.column - b.column; + }); + + // Sort all the child in order based on the column + for (let i = 0; i < res.length; i++) { + res[i].child.sort(function(a, b) { + return a.column - b.column; + }); + } + + //Forming actual parent items + for (let i = 0; i < res.length; i++) { + let parentId = res[i].parentMenuId; + if (parentId === null) { + actualData.push(res[i]); + } + } + var treedata = actualData[0].child; + $scope.treedata = []; + + /*Remove favorite from the list */ + for (var i in treedata) { + if (!(treedata[i].name.indexOf(exclude_list) > -1)) { + $scope.treedata.push(treedata[i]) + } + } + //setting b2b tree parameter + $scope.settingTreeParam(); }).catch(err => { $log.error('FunctionalMenuCtrl:getFunctionalMenu:: error ', err); @@ -494,244 +566,247 @@ }).catch(err => { $log.error('FunctionalMenuCtrl:getFunctionalMenu:: error ', err); - }) - ; + }); } - - + + let getAppRoleIds = () => { - $scope.notifObj= {isCategoriesFunctionalMenu:false}; - notificationService.getAppRoleIds().then(res => { - if(this.debug) - $log.debug('notificationService:getAppRoleIds:: getting result', res); - res = res.data; - let actualData = []; - var app_id_name_list = {}; - $scope.checkBoxObj = {isAnyRoleSelected:false}; - for (let i = 0; i < res.length; i++) { - if (!(res[i].appId in app_id_name_list)) { - app_id_name_list[res[i].appId] = res[i].appName; - } - res[i].child=[]; - res[i].name=res[i].roleName; - res[i].displayCheckbox= true; - res[i].id = res[i].roleId; - res[i].menuId = res[i].roleId; - res[i].parentMenuId = res[i].appId; - res[i].can_check = true; - res[i].roleId = [res[i].roleId]; - res[i].onSelect = function () { - $scope.$apply(function () { - $scope.newNotifModel.anyTreeItemSelected=$scope.checkTreeSelect(); - }) - }; - /*assigning selected value*/ - if (res[i].roleId && res[i].roleId.length==_.intersection(res[i].roleId, $scope.roleObj.notificationRoleIds).length){ - res[i].isSelected= true; - res[i].selected= true; - res[i].indeterminate= false; - }else{ - /*default*/ - res[i].isSelected= false; - res[i].selected= false; - res[i].indeterminate= false; - } - } - - for (var app_id in app_id_name_list) { - var new_res = {}; - new_res.child = []; - new_res.name = app_id_name_list[app_id]; - new_res.id = app_id; - new_res.displayCheckbox= true; - new_res.menuId = app_id; - new_res.parentMenuId = null; - new_res.appId = null; - new_res.can_check = true; - new_res.roleId = null; - new_res.onSelect = function () { - $scope.$apply(function () { - $scope.newNotifModel.anyTreeItemSelected=$scope.checkTreeSelect(); - }) - }; - res.push(new_res); - } - $scope.parentChildRoleIdDict ={}; - //Adding actual child items to child array in res objects - for (let i = 0; i < res.length; i++) { - let parentId = res[i].menuId; - $scope.parentChildRoleIdDict[parentId]=[]; - for (let j = 0; j < res.length; j++) { - let childId = res[j].parentMenuId; - if (parentId == childId) { - res[i].child.push(res[j]); - if (res[j].roleId) { - for (let k in res[j].roleId) { - $scope.parentChildRoleIdDict[parentId].push(res[j].roleId[k]); - } - - } - } - } - } - //Forming actual parent items - for (let i = 0; i < res.length; i++) { - let parentId = res[i].parentMenuId; - if (parentId === null) { - actualData.push(res[i]); - } - } - - $scope.treedata = actualData; - //setting correct parameters for b2b tree - $scope.settingTreeParam(); + $scope.notifObj = { + isCategoriesFunctionalMenu: false + }; + notificationService.getAppRoleIds().then(res => { + if (this.debug) + $log.debug('notificationService:getAppRoleIds:: getting result', res); + res = res.data; + let actualData = []; + var app_id_name_list = {}; + $scope.checkBoxObj = { + isAnyRoleSelected: false + }; + for (let i = 0; i < res.length; i++) { + if (!(res[i].appId in app_id_name_list)) { + app_id_name_list[res[i].appId] = res[i].appName; + } + res[i].child = []; + res[i].name = res[i].roleName; + res[i].displayCheckbox = true; + res[i].id = res[i].roleId; + res[i].menuId = res[i].roleId; + res[i].parentMenuId = res[i].appId; + res[i].can_check = true; + res[i].roleId = [res[i].roleId]; + res[i].onSelect = function() { + $scope.$apply(function() { + $scope.newNotifModel.anyTreeItemSelected = $scope.checkTreeSelect(); + }) + }; + /*assigning selected value*/ + if (res[i].roleId && res[i].roleId.length == _.intersection(res[i].roleId, $scope.roleObj.notificationRoleIds).length) { + res[i].isSelected = true; + res[i].selected = true; + res[i].indeterminate = false; + } else { + /*default*/ + res[i].isSelected = false; + res[i].selected = false; + res[i].indeterminate = false; + } + } + + for (var app_id in app_id_name_list) { + var new_res = {}; + new_res.child = []; + new_res.name = app_id_name_list[app_id]; + new_res.id = app_id; + new_res.displayCheckbox = true; + new_res.menuId = app_id; + new_res.parentMenuId = null; + new_res.appId = null; + new_res.can_check = true; + new_res.roleId = null; + new_res.onSelect = function() { + $scope.$apply(function() { + $scope.newNotifModel.anyTreeItemSelected = $scope.checkTreeSelect(); + }) + }; + res.push(new_res); + } + $scope.parentChildRoleIdDict = {}; + //Adding actual child items to child array in res objects + for (let i = 0; i < res.length; i++) { + let parentId = res[i].menuId; + $scope.parentChildRoleIdDict[parentId] = []; + for (let j = 0; j < res.length; j++) { + let childId = res[j].parentMenuId; + if (parentId == childId) { + res[i].child.push(res[j]); + if (res[j].roleId) { + for (let k in res[j].roleId) { + $scope.parentChildRoleIdDict[parentId].push(res[j].roleId[k]); + } + + } + } + } + } + //Forming actual parent items + for (let i = 0; i < res.length; i++) { + let parentId = res[i].parentMenuId; + if (parentId === null) { + actualData.push(res[i]); + } + } + + $scope.treedata = actualData; + //setting correct parameters for b2b tree + $scope.settingTreeParam(); }).catch(err => { $log.error('FunctionalMenuCtrl:getFunctionalMenu:: error ', err); }).finally(() => { this.isLoadingTable = false; }) } - $scope.getFunctionalMenu= function() { - $scope.treeTitle="Functional Menu"; - getFunctionalMenu(); + $scope.getFunctionalMenu = function() { + $scope.treeTitle = "Functional Menu"; + getFunctionalMenu(); } $scope.getAppRoleIds = function() { - $scope.treeTitle="Applications/Roles"; + $scope.treeTitle = "Applications/Roles"; getAppRoleIds(); } - - - - $scope.settingTreeParam = function(){ - /**************first level****************/ - for(var fi=0; fi<$scope.treedata.length;fi++){ - var fLevel = $scope.treedata[fi]; - var sLevel = $scope.treedata[fi].child; - var sLevelSelectedCount =0; - var sLevelChildNumber =0 - if(fLevel.child.length==0 && fLevel.roleId==null){ - delete fLevel.child; - }else if(sLevel){ - /**************Second level****************/ - var sLevelDelArray=[]; - for(var si=0;si<sLevel.length;si++){ - var deletThisSLev= false; - if(sLevel[si].child.length==0 && sLevel[si].roleId==null){ - sLevel[si].displayCheckbox=false; - sLevelDelArray.push(sLevel[si].name); - sLevel[si].name = ''; - sLevel[si].active=false; - delete sLevel[si].child; - } else if(sLevel[si].child.length==0){ - delete sLevel[si].child; - }else{ - /**************Third level****************/ - var tLevel = sLevel[si].child; - var tLevelSelectedCount =0; - var tLevelChildNumber =0; - if(tLevel){ - var tLevelDelArray=[]; - var tLevelLen = tLevel.length; - var tLevelRoleIdUndefined =0; - for(var ti=0;ti<tLevel.length;ti++){ - delete tLevel[ti].child; - if(tLevel[ti].roleId==null){ - tLevel[ti].displayCheckbox=false; - tLevelDelArray.push(tLevel[ti].name); - tLevel[ti].name = ''; - tLevel[ti].active=false; - tLevelRoleIdUndefined++ - }else{ - if(tLevel[ti].isSelected) - tLevelSelectedCount++; - - if(tLevel[ti].displayCheckbox) - tLevelChildNumber++; - } - } - if(tLevelRoleIdUndefined==tLevelLen) - deletThisSLev=true; - if(tLevelSelectedCount==tLevelChildNumber){ - sLevel[si].isSelected=true; - sLevel[si].indeterminate=false; - sLevel[si].active=true; - }else if(tLevelSelectedCount>0){ - sLevel[si].indeterminate=true; - sLevel[si].active=true; - } - - /*Cleanup unused third level items*/ - for(var i=0;i<tLevelDelArray.length;i++){ - var name = tLevelDelArray[i]; - for(var ti=0;ti<tLevel.length;ti++){ - if(name==tLevel[ti].text){ - tLevel.splice(ti,1); - break; - } - } - } - } - } - if(deletThisSLev){ //remove the whole second level item if all it's child has no roleId - sLevel[si].displayCheckbox=false; - sLevelDelArray.push(sLevel[si].name); - sLevel[si].name = ''; - sLevel[si].active=false; - }else{ - if(sLevel[si].isSelected) - sLevelSelectedCount++; - if(sLevel[si].displayCheckbox) - sLevelChildNumber++; - } - } - if(sLevelSelectedCount==sLevelChildNumber && sLevelChildNumber!=0){ - fLevel.isSelected=true; - fLevel.indeterminate=false; - fLevel.active=true; - }else if(sLevelSelectedCount>0){ - fLevel.indeterminate=true; - fLevel.active=true; - }else{ - //fLevel.active=false; - fLevel.indeterminate=false; - } - /*Cleanup unused second level items*/ - for(var i=0;i<sLevelDelArray.length;i++){ - var name = sLevelDelArray[i]; - for(var si=0;si<sLevel.length;si++){ - if(name==sLevel[si].text){ - sLevel.splice(si,1); - break; - } - } - } - } - } + + + + $scope.settingTreeParam = function() { + /**************first level****************/ + for (var fi = 0; fi < $scope.treedata.length; fi++) { + var fLevel = $scope.treedata[fi]; + var sLevel = $scope.treedata[fi].child; + var sLevelSelectedCount = 0; + var sLevelChildNumber = 0 + if (fLevel.child.length == 0 && fLevel.roleId == null) { + delete fLevel.child; + } else if (sLevel) { + /**************Second level****************/ + var sLevelDelArray = []; + for (var si = 0; si < sLevel.length; si++) { + var deletThisSLev = false; + if (sLevel[si].child.length == 0 && sLevel[si].roleId == null) { + sLevel[si].displayCheckbox = false; + sLevelDelArray.push(sLevel[si].name); + sLevel[si].name = ''; + sLevel[si].active = false; + delete sLevel[si].child; + } else if (sLevel[si].child.length == 0) { + delete sLevel[si].child; + } else { + /**************Third level****************/ + var tLevel = sLevel[si].child; + var tLevelSelectedCount = 0; + var tLevelChildNumber = 0; + if (tLevel) { + var tLevelDelArray = []; + var tLevelLen = tLevel.length; + var tLevelRoleIdUndefined = 0; + for (var ti = 0; ti < tLevel.length; ti++) { + delete tLevel[ti].child; + if (tLevel[ti].roleId == null) { + tLevel[ti].displayCheckbox = false; + tLevelDelArray.push(tLevel[ti].name); + tLevel[ti].name = ''; + tLevel[ti].active = false; + tLevelRoleIdUndefined++ + } else { + if (tLevel[ti].isSelected) + tLevelSelectedCount++; + + if (tLevel[ti].displayCheckbox) + tLevelChildNumber++; + } + } + if (tLevelRoleIdUndefined == tLevelLen) + deletThisSLev = true; + if (tLevelSelectedCount == tLevelChildNumber) { + sLevel[si].isSelected = true; + sLevel[si].indeterminate = false; + sLevel[si].active = true; + } else if (tLevelSelectedCount > 0) { + sLevel[si].indeterminate = true; + sLevel[si].active = true; + } + + /*Cleanup unused third level items*/ + for (var i = 0; i < tLevelDelArray.length; i++) { + var name = tLevelDelArray[i]; + for (var ti = 0; ti < tLevel.length; ti++) { + if (name == tLevel[ti].text) { + tLevel.splice(ti, 1); + break; + } + } + } + } + } + if (deletThisSLev) { //remove the whole second level item if all it's child has no roleId + sLevel[si].displayCheckbox = false; + sLevelDelArray.push(sLevel[si].name); + sLevel[si].name = ''; + sLevel[si].active = false; + } else { + if (sLevel[si].isSelected) + sLevelSelectedCount++; + if (sLevel[si].displayCheckbox) + sLevelChildNumber++; + } + } + if (sLevelSelectedCount == sLevelChildNumber && sLevelChildNumber != 0) { + fLevel.isSelected = true; + fLevel.indeterminate = false; + fLevel.active = true; + } else if (sLevelSelectedCount > 0) { + fLevel.indeterminate = true; + fLevel.active = true; + } else { + //fLevel.active=false; + fLevel.indeterminate = false; + } + /*Cleanup unused second level items*/ + for (var i = 0; i < sLevelDelArray.length; i++) { + var name = sLevelDelArray[i]; + for (var si = 0; si < sLevel.length; si++) { + if (name == sLevel[si].text) { + sLevel.splice(si, 1); + break; + } + } + } + } + } } init(); getFunctionalMenu(); } - + } - - userNotificationsModalCtrl.$inject = ['$scope', '$log', 'functionalMenuService', 'confirmBoxService', 'notificationService', '$modal', 'ngDialog', '$state', '$filter','items']; + + userNotificationsModalCtrl.$inject = ['$scope', '$log', 'functionalMenuService', 'confirmBoxService', 'notificationService', '$modal', 'ngDialog', '$state', '$filter', 'items']; angular.module('ecompApp').controller('userNotificationsModalCtrl', userNotificationsModalCtrl); - + angular.module('ecompApp').directive('attDatepickerCustom', ['$log', function($log) { return { restrict: 'A', - require: 'ngModel', + require: 'ngModel', scope: {}, - + controller: ['$scope', '$element', '$attrs', '$compile', 'datepickerConfig', 'datepickerService', function($scope, $element, $attrs, $compile, datepickerConfig, datepickerService) { - var dateFormatString = angular.isDefined($attrs.dateFormat) ? $scope.$parent.$eval($attrs.dateFormat) : datepickerConfig.dateFormat; - var selectedDateMessage = '<div class="sr-focus hidden-spoken" tabindex="-1">the date you selected is {{$parent.current | date : \'' + dateFormatString + '\'}}</div>'; - $element.removeAttr('att-datepicker-custom'); + var dateFormatString = angular.isDefined($attrs.dateFormat) ? $scope.$parent.$eval($attrs.dateFormat) : datepickerConfig.dateFormat; + var selectedDateMessage = '<div class="sr-focus hidden-spoken" tabindex="-1">the date you selected is {{$parent.current | date : \'' + dateFormatString + '\'}}</div>'; + $element.removeAttr('att-datepicker-custom'); $element.removeAttr('ng-model'); $element.attr('ng-value', '$parent.current | date:"EEEE, MMMM d, y"'); $element.attr('aria-describedby', 'datepicker'); - + $element.attr('maxlength', 10); var wrapperElement = angular.element('<div></div>'); @@ -763,10 +838,10 @@ ctrl.$render = function() { scope.current = ctrl.$viewValue; }; - + } }; }]); - -})(); + +})();
\ No newline at end of file diff --git a/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.less b/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.less index 79c2bae2..17bbdab8 100644 --- a/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.less +++ b/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.less @@ -169,3 +169,16 @@ right: 10px; top: 8px; } + +.date-validation{ + top:185px; + color: #cf2a2a; + font-size: 10px; + position:absolute; +} +.endDate-validation{ + top:270px; + color: #cf2a2a; + font-size: 10px; + position:absolute; +}
\ No newline at end of file diff --git a/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.page.html b/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.page.html index 57433c1c..5d1698e5 100644 --- a/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.page.html +++ b/ecomp-portal-FE-common/client/app/views/user-notifications-admin/user.notifications.modal.page.html @@ -131,10 +131,14 @@ ng-model="newNotifModel.startTime" b2b-datepicker min="minDate" max="maxDate" required /> </div> - <div id="user-startdate-required" ng-show="!isDateValid(newNotifModel.startTime)"> - <small class="mandatory-categories">Please enter valid date in MM/DD/YYYY format!</small> + <div style="{{( isEditMode )? 'opacity : 0; pointer-events: none;':' '}}"> + <div id="user-startdate-required" ng-show="!isDateValid(newNotifModel.startTime)"> + <small class="mandatory-categories">Please enter valid date in MM/DD/YYYY format!</small> + </div> + <div id="user-startdate-required" ng-show="!isStartDateValidFromToday(newNotifModel.startTime)"> + <small class="date-validation">Date should be greater than or equal to current date!</small> + </div> </div> - </div> <div ng-show="!isEditMode" ng-init="formatStartDate()"></div> </div> @@ -142,18 +146,23 @@ <div id="add-user-notif-enddate" class="add-widget-field" style="padding-bottom: 12px; width: 301px !important; {{( isEditMode )? 'opacity : 0.6; pointer-events: none;':' '}}"> <div id="user-notification-enddate-label" class="user-notif-label"> - <span runat="server" ID="required" class="notifcation-label-user-requiredId">*</span> End Date (Local Time) + <span runat="server" ID="required" class="notifcation-label-user-requiredId">*</span> EndDate (Local Time) </div> <div class="datepicker-container"> <input class="notif-input-calendar" type="text" id="datepicker-end" ng-model="newNotifModel.endTime" b2b-datepicker min="minDate" max="maxDate" required /> </div> - <div id="user-endDate-required" ng-show="!isDateValid(newNotifModel.endTime)"> + <div style="{{( isEditMode )? 'opacity : 0; pointer-events: none;':' '}}"> + <div id="user-endDate-required" ng-show="!isDateValid(newNotifModel.endTime)"> <small class="mandatory-categories">Please enter valid date in MM/DD/YYYY format!</small> </div> - <div id="user-enddate-error" ng-show="newNotifModel.endTime&&newNotifModel.startTime&&newNotifModel.startTime.getTime()>=newNotifModel.endTime.getTime()" class="user-enddate-error-txt"> - <small class="mandatory-categories">End Date must be greater than start Date</small> + <div id="user-startdate-required" ng-show="!isStartDateValidFromToday(newNotifModel.endTime)"> + <small class="endDate-validation">Date should be greater than or equal to current date!</small> + </div> + <div id="user-enddate-error" ng-show="newNotifModel.endTime&&newNotifModel.startTime&&newNotifModel.startTime.getTime()>=newNotifModel.endTime.getTime()" class="user-enddate-error-txt"> + <small class="mandatory-categories">End Date must be greater than start Date</small> + </div> </div> <div ng-show="!isEditMode" ng-init="formatEndDate()" ></div> </div> @@ -181,7 +190,7 @@ ng-model="newNotifModel.msgDescription" name="content"> </textarea> <div id="user-notif-message-required" ng-show="newNotifModel.msgDescription.length ==0 "> - <small class="mandatory-categories">Message is Required</small> + <small class="mandatory-categories">Message is Required</small> </div> </div> diff --git a/ecomp-portal-FE-common/client/app/views/widget-onboarding/widget-onboarding.less b/ecomp-portal-FE-common/client/app/views/widget-onboarding/widget-onboarding.less index 6085a908..7be0d470 100644 --- a/ecomp-portal-FE-common/client/app/views/widget-onboarding/widget-onboarding.less +++ b/ecomp-portal-FE-common/client/app/views/widget-onboarding/widget-onboarding.less @@ -34,5 +34,8 @@ font-style: italic; { margin-bottom: 8px; } +input.table-search{ + font-style: normal; +} } diff --git a/ecomp-portal-FE-common/client/app/views/widget-onboarding/widget-onboarding.tpl.html b/ecomp-portal-FE-common/client/app/views/widget-onboarding/widget-onboarding.tpl.html index aae0fd7c..aeb4468c 100644 --- a/ecomp-portal-FE-common/client/app/views/widget-onboarding/widget-onboarding.tpl.html +++ b/ecomp-portal-FE-common/client/app/views/widget-onboarding/widget-onboarding.tpl.html @@ -36,10 +36,10 @@ </select> </div> </div> - <input class="table-search" type="text" + <input class="table-search" type="text" id="widget-onboarding-table-search" placeholder="Search in entire table" - ng-model="widgetOnboarding.searchString" /> + data-ng-model="widgetOnboarding.searchString" /> <button id="widget-onboarding-button-add" class="btn btn-alt btn-small" @@ -55,7 +55,7 @@ <div ng-hide="widgetOnboarding.isCommError"> <div b2b-table table-data="portalAdmin.portalAdminsTableData" ng-hide="widgetOnboarding.isLoadingTable" - search-string="portalAdmin.searchString" class="b2b-table-div"> + search-string="widgetOnboarding.searchString" class="b2b-table-div"> <table> <thead b2b-table-row type="header"> <tr> |