diff --git a/apps/maarch_entreprise/js/angular/app/administration/groups-administration.component.js b/apps/maarch_entreprise/js/angular/app/administration/groups-administration.component.js index 8a4888360825640f385949813b0a65cb0178860f..766bf7b17aae71c2a8bddbf1cf2676948a9531d4 100644 --- a/apps/maarch_entreprise/js/angular/app/administration/groups-administration.component.js +++ b/apps/maarch_entreprise/js/angular/app/administration/groups-administration.component.js @@ -56,7 +56,6 @@ var GroupsAdministrationComponent = (function () { }); } } - console.log(this.groupsForAssign); }; GroupsAdministrationComponent.prototype.reassignUsers = function (group, groupId) { var _this = this; diff --git a/apps/maarch_entreprise/js/angular/app/administration/notification-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/notification-administration.component.ts index 1981f8b61c73144437bb4a378bebfac809d008f6..368072511f184667a4700ace9cc5354f75f3881c 100644 --- a/apps/maarch_entreprise/js/angular/app/administration/notification-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/notification-administration.component.ts @@ -5,8 +5,6 @@ import { ActivatedRoute, Router } from '@angular/router'; import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; @@ -18,127 +16,104 @@ declare var angularGlobals : any; export class NotificationAdministrationComponent implements OnInit { coreUrl : string; - notificationId : string; - creationMode : boolean; - notification : any = { - diffusionType_label : null - }; - loading : boolean = false; - lang : any = LANG; + + creationMode : boolean; + notification : any = { + diffusionType_label : null + }; + loading : boolean = false; + lang : any = LANG; constructor(public http: HttpClient, private route: ActivatedRoute, private router: Router, private notify: NotificationService) { } + updateBreadcrumb(applicationName: string){ + if ($j('#ariane')[0]) { + $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > <a onclick='location.hash = \"/administration/notifications\"' style='cursor: pointer'>notifications</a>"; + } + } + ngOnInit(): void { - this.prepareNotifications(); + this.updateBreadcrumb(angularGlobals.applicationName); this.loading = true; this.coreUrl = angularGlobals.coreUrl; - this.updateBreadcrumb(angularGlobals.applicationName); + this.route.params.subscribe(params => { - console.log(params['identifier']); - if(typeof params['identifier']== "undefined"){ - //if(params['identifier']== "new"){ + if (typeof params['identifier'] == "undefined") { this.creationMode = true; this.http.get(this.coreUrl + 'rest/administration/notifications/new') .subscribe((data : any) => { this.notification = data.notification; this.loading = false; - // setTimeout(() => { - // $j("select").chosen({width:"100%",disable_search_threshold: 10, search_contains: true}); - // }, 0); }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(err.error.errors); }); - }else { + } else { this.creationMode = false; this.http.get(this.coreUrl + 'rest/administration/notifications/' + params['identifier']) - .subscribe((data : any) => { + .subscribe((data : any) => { - this.notification = data.notification; - console.log(data.notification); - this.loading = false; - setTimeout(() => { - $j("select").chosen({width:"100%",disable_search_threshold: 10, search_contains: true}); - }, 0); - }); - + this.notification = data.notification; + this.loading = false; + }, (err) => { + this.notify.error(err.error.errors); + }); } }); } - selectAll(event:any){ + selectAll(event: any) { var target = event.target.getAttribute("data-target"); $j('#' + target + ' option').prop('selected', true); $j('#' + target).trigger('chosen:updated'); - } - unselectAll(event:any){ + unselectAll(event: any) { var target = event.target.getAttribute("data-target"); $j('#' + target + ' option').prop('selected', false); $j('#' + target).trigger('chosen:updated'); } onSubmit() { - //affect value of select - if($j("#groupslist").chosen().val()){ - this.notification.diffusion_properties = $j("#groupslist").chosen().val(); - }else if($j("#entitieslist").chosen().val()){ - this.notification.diffusion_properties = $j("#entitieslist").chosen().val(); - }else if($j("#statuseslist").chosen().val()){ - this.notification.diffusion_properties = $j("#statuseslist").chosen().val(); - }else if($j("#userslist").chosen().val()){ - this.notification.diffusion_properties = $j("#userslist").chosen().val(); + if ($j("#groupslist").val()) { + this.notification.diffusion_properties = $j("#groupslist").val(); + } else if($j("#entitieslist").val()) { + this.notification.diffusion_properties = $j("#entitieslist").val(); + } else if($j("#statuseslist").val()) { + this.notification.diffusion_properties = $j("#statuseslist").val(); + } else if($j("#userslist").val()) { + this.notification.diffusion_properties = $j("#userslist").val(); } - console.log($j("#groupslistJd").chosen().val()); - console.log($j("#entitieslistJd").chosen().val()); - console.log($j("#statuseslistJd").chosen().val()); - console.log($j("#userslistJd").chosen().val()); - console.log($j("#joinDocJd").chosen().val()); - if($j("#joinDocJd").chosen().val() == null){ + if ($j("#joinDocJd").val() == null) { this.notification.attachfor_properties = ''; - }else if($j("#groupslistJd").chosen().val()){ - this.notification.attachfor_properties = $j("#groupslistJd").chosen().val(); - }else if($j("#entitieslistJd").chosen().val()){ - console.log($j("#entitieslistJd").chosen().val()); - this.notification.attachfor_properties = $j("#entitieslistJd").chosen().val(); - }else if($j("#statuseslistJd").chosen().val()){ - this.notification.attachfor_properties = $j("#statuseslistJd").chosen().val(); - }else if($j("#userslistJd").chosen().val()){ - this.notification.attachfor_properties = $j("#userslistJd").chosen().val(); + } else if ($j("#groupslistJd").val()) { + this.notification.attachfor_properties = $j("#groupslistJd").val(); + } else if($j("#entitieslistJd").val()) { + this.notification.attachfor_properties = $j("#entitieslistJd").val(); + } else if($j("#statuseslistJd").val()) { + this.notification.attachfor_properties = $j("#statuseslistJd").val(); + } else if($j("#userslistJd").val()) { + this.notification.attachfor_properties = $j("#userslistJd").val(); } + if (this.creationMode) { - console.log(this.notification); this.http.post(this.coreUrl + 'rest/notifications', this.notification) - .subscribe((data : any) => { - this.router.navigate(['/administration/notifications']); - this.notify.success(this.lang.newNotificationAdded+' « '+this.notification.notification_id+' »'); - },(err) => { - this.notify.error(err.error.errors); - }); - }else{ + .subscribe((data : any) => { + this.router.navigate(['/administration/notifications']); + this.notify.success(this.lang.newNotificationAdded+' « '+this.notification.notification_id+' »'); + },(err) => { + this.notify.error(err.error.errors); + }); + } else { this.http.put(this.coreUrl + 'rest/notifications/' + this.notification.notification_sid, this.notification) - .subscribe((data : any) => { - this.router.navigate(['/administration/notifications']); - this.notify.success(this.lang.notificationUpdated+' « '+this.notification.notification_id+' »'); - },(err) => { - this.notify.error(err.error.errors); - }); - } - } - - - prepareNotifications() { - $j('#inner_content').remove(); - } - - updateBreadcrumb(applicationName: string){ - if ($j('#ariane')[0]) { - $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > <a onclick='location.hash = \"/administration\"' style='cursor: pointer'>Administration</a> > <a onclick='location.hash = \"/administration/notifications\"' style='cursor: pointer'>notifications</a>"; + .subscribe((data : any) => { + this.router.navigate(['/administration/notifications']); + this.notify.success(this.lang.notificationUpdated+' « '+this.notification.notification_id+' »'); + },(err) => { + this.notify.error(err.error.errors); + }); } } - - } diff --git a/apps/maarch_entreprise/js/angular/app/administration/notifications-administration.component.ts b/apps/maarch_entreprise/js/angular/app/administration/notifications-administration.component.ts index d9d10cfec8a5ed5e9257dbf2d53166d33cdf926b..23608487adb200577f5750a9b27f3fff221faa0e 100644 --- a/apps/maarch_entreprise/js/angular/app/administration/notifications-administration.component.ts +++ b/apps/maarch_entreprise/js/angular/app/administration/notifications-administration.component.ts @@ -4,8 +4,6 @@ import { LANG } from '../translate.component'; import { NotificationService } from '../notification.service'; declare function $j(selector: any) : any; -declare function successNotification(message: string) : void; -declare function errorNotification(message: string) : void; declare var angularGlobals : any; @@ -17,7 +15,8 @@ declare var angularGlobals : any; export class NotificationsAdministrationComponent implements OnInit { coreUrl : string; - notifications : any[] = []; + + notifications : any[] = []; loading : boolean = false; lang : any = LANG; @@ -26,42 +25,36 @@ export class NotificationsAdministrationComponent implements OnInit { } ngOnInit(): void { - this.coreUrl = angularGlobals.coreUrl; - - this.prepareNotifications(); + this.updateBreadcrumb(angularGlobals.applicationName); + this.coreUrl = angularGlobals.coreUrl; this.loading = true; this.http.get(this.coreUrl + 'rest/notifications') .subscribe((data : any) => { this.notifications = data.notifications; - this.updateBreadcrumb(angularGlobals.applicationName); this.loading = false; }, (err) => { - errorNotification(JSON.parse(err._body).errors); + this.notify.error(err.error.errors); }); } - prepareNotifications() { - $j('#inner_content').remove(); - } - - updateBreadcrumb(applicationName: string){ + updateBreadcrumb(applicationName: string) { $j('#ariane')[0].innerHTML = "<a href='index.php?reinit=true'>" + applicationName + "</a> > "+ "<a onclick='location.hash = \"/administration\"' style='cursor: pointer'>" + this.lang.administration + "</a> > " + this.lang.admin_notifications; } - deleteNotification(notification : any){ - var resp = confirm(this.lang.deleteMsg + " ?"); - if(resp){ - this.http.delete(this.coreUrl + 'rest/notifications/'+notification.notification_sid) + deleteNotification(notification : any) { + let r = confirm(this.lang.deleteMsg); + + if (r) { + this.http.delete(this.coreUrl + 'rest/notifications/' + notification.notification_sid) .subscribe((data : any) => { - this.notifications = data.notifications + this.notifications = data.notifications; this.notify.success(data.success); }, (err) => { this.notify.error(err.error.errors); }); } } - } diff --git a/apps/maarch_entreprise/js/angular/app/profile.component.js b/apps/maarch_entreprise/js/angular/app/profile.component.js index a23a45903052710ca625be1ef6cffb1052a327ca..b68831156973044040cfee7760635cbab7283ad7 100755 --- a/apps/maarch_entreprise/js/angular/app/profile.component.js +++ b/apps/maarch_entreprise/js/angular/app/profile.component.js @@ -40,6 +40,7 @@ var ProfileComponent = (function () { title: "", }; this.userAbsenceModel = []; + this.basketsToRedirect = []; this.showPassword = false; this.selectedSignature = -1; this.selectedSignatureLabel = ""; diff --git a/apps/maarch_entreprise/js/angular/app/profile.component.ts b/apps/maarch_entreprise/js/angular/app/profile.component.ts index a6240c5d9c5aff5e64f5157dd602268c979335da..c475cd84fc09e309266b2da85baaac49fbe5eb09 100755 --- a/apps/maarch_entreprise/js/angular/app/profile.component.ts +++ b/apps/maarch_entreprise/js/angular/app/profile.component.ts @@ -41,6 +41,7 @@ export class ProfileComponent implements OnInit { title : "", }; userAbsenceModel : any[] = []; + basketsToRedirect : string[] = []; showPassword : boolean = false; selectedSignature : number = -1; diff --git a/apps/maarch_entreprise/template/header.html b/apps/maarch_entreprise/template/header.html index c97bb7886cb6dec288f4646eb3fa812517650dad..d4d0caf879e5b89a5ad23a28390dfa096ba469bf 100755 --- a/apps/maarch_entreprise/template/header.html +++ b/apps/maarch_entreprise/template/header.html @@ -9,20 +9,28 @@ require_once 'core/Models/UserModel.php'; $userGroups=\Core\Models\UserModel::getGroupsByUserId(['userId'=> $_SESSION['user']['UserId']]); if(!empty($userGroups)){ - $strUserInfos.=" ("; - for($i=0;$i<count($userGroups);$i++){ - if($i==count($userGroups)-1){ - $strUserInfos.=$userGroups[$i]['group_desc']; - } else { - $strUserInfos.=$userGroups[$i]['group_desc'].", "; - } + if(count($userGroups)>=2){ + $strGroupList=" "; + for($i=0;$i<count($userGroups);$i++){ + if($i==count($userGroups)-1){ + $strGroupList.=$userGroups[$i]['group_desc']; + } else { + $strGroupList.=$userGroups[$i]['group_desc']."<br><br>"; + } + } + $strUserInfos .= ' <div id="header_usergroups" class="header_usergroups" title="'.$strGroupList.'" style="display:inline-block;">('.count($userGroups).' groupes)</div>'; + }else{ + $strUserInfos .= ' ('.$userGroups[0]['group_desc'].')'; } - $strUserInfos.=")"; } echo $strUserInfos; ?> </div> + <script>$j(".header_usergroups").tooltipster({ + delay : 0, + contentAsHTML:true + });</script> <div id="menu" onmouseover="ShowHideMenu('menunav','on');" onmouseout="ShowHideMenu('menunav','off');" class="off"> <p> <span style="background:url('');background-position: 10px 0px;background-size:25%; diff --git a/core/Controllers/ResController.php b/core/Controllers/ResController.php index c40325dee5200b2799a15db79d1717e7bf786c88..009677baabd095b959e0a1bb5db428925f75b756 100755 --- a/core/Controllers/ResController.php +++ b/core/Controllers/ResController.php @@ -34,19 +34,22 @@ class ResController { public function create(RequestInterface $request, ResponseInterface $response, $aArgs) { - if(empty($aArgs)) { - - $aArgs = $request->getQueryParams(); - $aArgs['data'] = json_decode($aArgs['data']); + if (empty($aArgs)) { + $aArgs = $request->getParsedBody(); + } - $aArgs['data'] = $this->object2array($aArgs['data']); + // if(empty($aArgs)) { + // $aArgs = $request->getQueryParams(); + // $aArgs['data'] = json_decode($aArgs['data']); + // $aArgs['data'] = $this->object2array($aArgs['data']); + // //FIX pb if data has parent + // if (isset($aArgs['data']['data'])) { + // $aArgs['data'] = $aArgs['data']['data']; + // } + // } - //FIX pb if data has parent - if (isset($aArgs['data']['data'])) { - $aArgs['data'] = $aArgs['data']['data']; - } - } + $aArgs['data'] = $this->object2array($aArgs['data']); //***************************************************************************************** //LOG ONLY LOG FOR DEBUG @@ -641,13 +644,15 @@ class ResController if (strtoupper($data[$i]['column']) == strtoupper('custom_t10')) { $mail = array(); $theString = str_replace(">", "", $data[$i]['value']); + $mail = explode("<", $theString); $user = $userModel->getByEmail(['mail' => $mail[count($mail) -1]]); + $userIdFound = $user[0]['user_id']; if (!empty($userIdFound)) { $toAddressFound = true; $destUser = $userIdFound; - $entity = $entityModel->getByUserId(['user_id' => $destUser]); + $entity = $entityModel->getByUserId(['userId' => $destUser]); if (!empty($entity[0]['entity_id'])) { $userEntity = $entity[0]['entity_id']; $userPrimaryEntity = true; diff --git a/core/Controllers/ResExtController.php b/core/Controllers/ResExtController.php index 8bee0e0f90e9f05e8ab8ed50ed3a34e6378418cd..5159938eca57a274a154dbe877e4ba0fad4f7b1f 100755 --- a/core/Controllers/ResExtController.php +++ b/core/Controllers/ResExtController.php @@ -27,19 +27,25 @@ class ResExtController { public function create(RequestInterface $request, ResponseInterface $response, $aArgs) { - if(empty($aArgs)) { + if (empty($aArgs)) { + $aArgs = $request->getParsedBody(); + } + + $aArgs['data'] = $this->object2array($aArgs['data']); + + // if(empty($aArgs)) { - $aArgs = $request->getQueryParams(); + // $aArgs = $request->getQueryParams(); - $aArgs['data'] = json_decode($aArgs['data']); + // $aArgs['data'] = json_decode($aArgs['data']); - $aArgs['data'] = $this->object2array($aArgs['data']); + // $aArgs['data'] = $this->object2array($aArgs['data']); - //FIX pb if data has parent - if (isset($aArgs['data']['data'])) { - $aArgs['data'] = $aArgs['data']['data']; - } - } + // //FIX pb if data has parent + // if (isset($aArgs['data']['data'])) { + // $aArgs['data'] = $aArgs['data']['data']; + // } + // } //***************************************************************************************** //LOG ONLY LOG FOR DEBUG diff --git a/core/Controllers/UserController.php b/core/Controllers/UserController.php index 8ff46c8411d7582f1f8429eba172178c6bfabf0d..25b7f95536205a4a259f3c19cfea10046419e76c 100755 --- a/core/Controllers/UserController.php +++ b/core/Controllers/UserController.php @@ -42,7 +42,8 @@ class UserController $user['groups'] = UserModel::getGroupsByUserId(['userId' => $_SESSION['user']['UserId']]); $user['entities'] = UserModel::getEntitiesById(['userId' => $_SESSION['user']['UserId']]); $user['baskets'] = BasketsModel::getBasketsByUserId(['userId' => $_SESSION['user']['UserId']]); - + $user['redirectedBaskets'] = BasketsModel::getBasketsRedirectedByUserId(['userId' => $_SESSION['user']['UserId']]); + return $response->withJson($user); } @@ -214,7 +215,7 @@ class UserController return $response->withJson(['success' => _UPDATED_PASSWORD]); } - public function setBasketsRedirectionForAbsence(RequestInterface $request, ResponseInterface $response, $aArgs) { + public function setRedirectedBaskets(RequestInterface $request, ResponseInterface $response, $aArgs) { $error = $this->hasUsersRights(['id' => $aArgs['id'], 'himself' => true]); if (!empty($error['error'])) { return $response->withStatus($error['status'])->withJson(['errors' => $error['error']]); @@ -254,6 +255,19 @@ class UserController ]); } + public function deleteRedirectedBaskets(RequestInterface $request, ResponseInterface $response, $aArgs) { + $error = $this->hasUsersRights(['id' => $aArgs['id'], 'himself' => true]); + if (!empty($error['error'])) { + return $response->withStatus($error['status'])->withJson(['errors' => $error['error']]); + } + + $user = UserModel::getById(['id' => $aArgs['id'], 'select' => ['user_id']]); + + BasketsModel::deleteBasketRedirection(['userId' => $user['user_id'], 'basketId' => $aArgs['basketId']]); + + return $response->withJson(['redirectedBaskets' => BasketsModel::getRedirectedBasketsByUserId(['userId' => $user['user_id']])]); + } + public function updateStatus(RequestInterface $request, ResponseInterface $response, $aArgs) { $error = $this->hasUsersRights(['id' => $aArgs['id'], 'himself' => true]); if (!empty($error['error'])) { diff --git a/core/Test/ResControllerTest.php b/core/Test/ResControllerTest.php index 6ed1101d217785d738725e2085b8ac0d5a2a85d0..9539dcac7bbf098f6745e0a1e16b4ad4f53c66a0 100755 --- a/core/Test/ResControllerTest.php +++ b/core/Test/ResControllerTest.php @@ -226,7 +226,7 @@ class ResControllerTest extends TestCase $request = \Slim\Http\Request::createFromEnvironment($environment); $response = new \Slim\Http\Response(); $response = $action->create($request, $response, $aArgs); - //print_r($response);exit; + $this->assertGreaterThan(1, json_decode($response->getBody())->resId); } diff --git a/modules/basket/Models/BasketsModelAbstract.php b/modules/basket/Models/BasketsModelAbstract.php index 7d1f2edc4d189505c1d15a9b2eb01455dfea817e..7f1e48504c2d37999bdafe2dbde24a32625403b0 100755 --- a/modules/basket/Models/BasketsModelAbstract.php +++ b/modules/basket/Models/BasketsModelAbstract.php @@ -168,4 +168,40 @@ class BasketsModelAbstract return true; } + + public static function deleteBasketRedirection(array $aArgs) + { + ValidatorModel::notEmpty($aArgs, ['userId', 'basketId']); + ValidatorModel::stringType($aArgs, ['userId', 'basketId']); + + DatabaseModel::delete([ + 'table' => 'user_abs', + 'where' => ['(user_abs = ? OR basket_owner = ?)', 'basket_id = ?'], + 'data' => [$aArgs['userId'], $aArgs['userId'], $aArgs['basketId']] + ]); + + return true; + } + + public static function getRedirectedBasketsByUserId(array $aArgs) { + ValidatorModel::notEmpty($aArgs, ['userId']); + ValidatorModel::stringType($aArgs, ['userId']); + + $aBaskets = DatabaseModel::select([ + 'select' => ['ba.basket_id', 'ba.basket_name', 'ua.new_user', 'ua.basket_owner'], + 'table' => ['baskets ba, user_abs ua'], + 'where' => ['ua.user_abs = ?', 'ua.basket_id = ba.basket_id'], + 'data' => [$aArgs['userId']], + 'order_by' => ['ua.system_id'] + ]); + + foreach ($aBaskets as $key => $value) { + $user = UserModel::getById(['userId' => $value['new_user'], 'select' => ['firstname', 'lastname']]); + $aBaskets[$key]['userToDisplay'] = "{$user['firstname']} {$user['lastname']} ({$value['new_user']})"; + $aBaskets[$key]['user'] = "{$user['firstname']} {$user['lastname']}"; + } + + return $aBaskets; + } + } \ No newline at end of file diff --git a/modules/basket/class/class_admin_basket_Abstract.php b/modules/basket/class/class_admin_basket_Abstract.php index 35f72b161ef52404ce5ef7d43b7b30cb1a50d446..ab3446a746667a1dd872c6add8dabb84c4207dc0 100755 --- a/modules/basket/class/class_admin_basket_Abstract.php +++ b/modules/basket/class/class_admin_basket_Abstract.php @@ -132,6 +132,7 @@ abstract class admin_basket_Abstract extends Database if ($mode == "add") { $_SESSION['m_admin']['basket']['coll_id'] = $_SESSION['collections'][0]['id']; + $_SESSION['m_admin']['basket']['color'] = '#666666'; } // If mode "Up", Loading the informations of the basket in session @@ -154,6 +155,11 @@ abstract class admin_basket_Abstract extends Database $line = $stmt->fetchObject(); $_SESSION['m_admin']['basket']['desc'] = functions::show_string($line->basket_desc); $_SESSION['m_admin']['basket']['name'] = functions::show_string($line->basket_name); + if (empty($line->color)) { + $_SESSION['m_admin']['basket']['color'] = '#666666'; + } else { + $_SESSION['m_admin']['basket']['color'] = functions::show_string($line->color); + } $_SESSION['m_admin']['basket']['clause'] = functions::show_string($line->basket_clause); $_SESSION['m_admin']['basket']['is_generic'] = functions::show_string($line->is_generic); $_SESSION['m_admin']['basket']['is_visible'] = functions::show_string($line->is_visible); @@ -248,6 +254,11 @@ abstract class admin_basket_Abstract extends Database <label><?php echo _BASKET;?> : </label> <input name="basketname" type="text" id="basketname" value="<?php functions::xecho($_SESSION['m_admin']['basket']['name']);?>" /> </p> + <p> + <label>Couleur : </label> + <input name="color" type="color" id="color" style="width: 38%;" value="<?php functions::xecho($_SESSION['m_admin']['basket']['color']);?>" /> + <a title="Réinitialiser la couleur" style="cursor: pointer" onclick="$j('#color')[0].value = '#666666'"><i class="fa fa-magic"></i></a> + </p> <p> <label><?php echo _DESC;?> : </label> <textarea cols="30" rows="4" name="basketdesc" style="width:200px;" id="basketdesc" ><?php functions::xecho($_SESSION['m_admin']['basket']['desc']);?></textarea> @@ -446,6 +457,10 @@ abstract class admin_basket_Abstract extends Database { $_SESSION['m_admin']['basket']['name'] = $this->wash($_REQUEST['basketname'], "no", _THE_BASKET, 'yes', 0, 255); } + if(!empty($_REQUEST['color'])) + { + $_SESSION['m_admin']['basket']['color'] = $this->wash($_REQUEST['color'], "no", _THE_BASKET, 'yes', 0, 255); + } if (isset($_REQUEST['basketdesc']) && !empty($_REQUEST['basketdesc'])) { $_SESSION['m_admin']['basket']['desc'] = $this->wash($_REQUEST['basketdesc'], "no", _THE_DESC, 'yes', 0, 255); @@ -544,8 +559,8 @@ abstract class admin_basket_Abstract extends Database exit(); } $db->query( - "INSERT INTO ".$_SESSION['tablename']['bask_baskets']." ( coll_id, basket_id, basket_name, basket_desc , basket_clause, is_visible, is_folder_basket, flag_notif ) " - ."VALUES (?,?,?,?,?,?,?,?)", array($_SESSION['m_admin']['basket']['coll_id'],$_SESSION['m_admin']['basket']['basketId'],$_SESSION['m_admin']['basket']['name'],$_SESSION['m_admin']['basket']['desc'],$tmp,$_SESSION['m_admin']['basket']['is_visible'],$_SESSION['m_admin']['basket']['is_folder_basket'],$_SESSION['m_admin']['basket']['flag_notif'])); + "INSERT INTO ".$_SESSION['tablename']['bask_baskets']." ( coll_id, basket_id, basket_name, basket_desc , basket_clause, is_visible, is_folder_basket, flag_notif, color) " + ."VALUES (?,?,?,?,?,?,?,?,?)", array($_SESSION['m_admin']['basket']['coll_id'],$_SESSION['m_admin']['basket']['basketId'],$_SESSION['m_admin']['basket']['name'],$_SESSION['m_admin']['basket']['desc'],$tmp,$_SESSION['m_admin']['basket']['is_visible'],$_SESSION['m_admin']['basket']['is_folder_basket'],$_SESSION['m_admin']['basket']['flag_notif'], $_SESSION['m_admin']['basket']['color'])); $this->load_db(); // Log in database if required @@ -594,7 +609,7 @@ abstract class admin_basket_Abstract extends Database exit(); } - $db->query("UPDATE ".$_SESSION['tablename']['bask_baskets']." set basket_name = ? , coll_id = ? , basket_desc = ? ,basket_clause = ?, is_folder_basket = ?, is_visible = ?, flag_notif = ? where basket_id = ?",array($name,$_SESSION['m_admin']['basket']['coll_id'],$desc, $tmp, $_SESSION['m_admin']['basket']['is_folder_basket'], $_SESSION['m_admin']['basket']['is_visible'], $_SESSION['m_admin']['basket']['flag_notif'], $_SESSION['m_admin']['basket']['basketId'])); + $db->query("UPDATE baskets set basket_name = ? , coll_id = ? , basket_desc = ? ,basket_clause = ?, is_folder_basket = ?, is_visible = ?, flag_notif = ?, color = ? where basket_id = ?",array($name,$_SESSION['m_admin']['basket']['coll_id'],$desc, $tmp, $_SESSION['m_admin']['basket']['is_folder_basket'], $_SESSION['m_admin']['basket']['is_visible'], $_SESSION['m_admin']['basket']['flag_notif'], $_SESSION['m_admin']['basket']['color'], $_SESSION['m_admin']['basket']['basketId'])); $this->load_db(); // Log in database if required diff --git a/modules/basket/class/class_modules_tools_Abstract.php b/modules/basket/class/class_modules_tools_Abstract.php index 078743e28ca85022866acf2bd33eb90447e3db25..c1b05be7481cba463c78b4fdb80bc3b771abe623 100755 --- a/modules/basket/class/class_modules_tools_Abstract.php +++ b/modules/basket/class/class_modules_tools_Abstract.php @@ -795,7 +795,7 @@ abstract class basket_Abstract extends Database $secCtrl = new SecurityControler(); $stmt = $db->query( "select basket_id, coll_id, basket_name, basket_desc, " - . "basket_clause, is_visible, is_generic, is_folder_basket from " + . "basket_clause, is_visible, is_generic, is_folder_basket, color from " . BASKET_TABLE . " where basket_id = ? and enabled = 'Y'",array($basketId)); $res = $stmt->fetchObject(); $tab['id'] = $res->basket_id; @@ -811,6 +811,7 @@ abstract class basket_Abstract extends Database $tab['is_generic'] = $res->is_generic; $tab['desc'] = $this->show_string($res->basket_desc); $tab['name'] = $this->show_string($res->basket_name); + $tab['color'] = $this->show_string($res->color); $tab['clause'] = $res->basket_clause; $tab['is_visible'] = $res->is_visible; $tab['is_folder_basket'] = $res->is_folder_basket; diff --git a/modules/basket/display_basket_list.php b/modules/basket/display_basket_list.php index 1cbfbc3d25cff2f754f130461cd26042cc1e88ec..06dad9cc6270cb4fd5b846e27b175dfb4529ac76 100755 --- a/modules/basket/display_basket_list.php +++ b/modules/basket/display_basket_list.php @@ -75,6 +75,7 @@ if ($core_tools->test_service('display_basket_list','basket', false)) { <h2><?php echo _MY_BASKETS;?> : </h2> <?php + $redirectedBaskets = \Baskets\Models\BasketsModel::getRedirectedBasketsByUserId(['userId' => $_SESSION['user']['UserId']]); $countColl = count($collWithUserBaskets); $currentGroup = ''; for ($cpt=0;$cpt<$countColl;$cpt++) { @@ -132,7 +133,7 @@ if ($core_tools->test_service('display_basket_list','basket', false)) { . '" name="nb_' . $_SESSION['user']['baskets'][$i]['id'] . '"><i class="fa-li fa fa-spinner fa-spin" style="margin-left: -10px;position: inherit;margin-right: -7px;"></i>' . '</span></b> <i class="fa-li fa fa-folder" style="padding-top: 5px;padding-bottom: 5px;"></i>' - . functions::xssafe($_SESSION['user']['baskets'][$i]['name']) + . '<span style="color: ' .$_SESSION['user']['baskets'][$i]['color'] . '">' . functions::xssafe($_SESSION['user']['baskets'][$i]['name']) . '</span>' . ' </a></li>'; } else { echo '<li style="padding-top: 5px;padding-bottom: 5px;"><a title="'.$_SESSION['user']['baskets'][$i]['desc'].'" href="' @@ -143,7 +144,7 @@ if ($core_tools->test_service('display_basket_list','basket', false)) { . '" name="nb_' . $_SESSION['user']['baskets'][$i]['id'] . '"><i class="fa-li fa fa-spinner fa-spin" style=";margin-left: -10px;position: inherit;margin-right: -7px;"></i>' . '</span></b> <i class="fa-li fa fa-tasks" style="padding-top: 5px;padding-bottom: 5px;"></i> ' - . functions::xssafe($_SESSION['user']['baskets'][$i]['name']) + . '<span style="color: ' .$_SESSION['user']['baskets'][$i]['color'] . '">' . functions::xssafe($_SESSION['user']['baskets'][$i]['name']) . '</span>' . ' </a></li>'; } } diff --git a/modules/basket/xml/IVS/validation_rules.xml b/modules/basket/xml/IVS/validation_rules.xml index 61cc7445af06fc1f8d606762686f65655f68bf36..a7dd2a1c52fbcbc565b36c8970d203eaf042e8c9 100755 --- a/modules/basket/xml/IVS/validation_rules.xml +++ b/modules/basket/xml/IVS/validation_rules.xml @@ -18,6 +18,7 @@ <parameter name="collection" type="collection_list" /> <parameter name="basketId" type="identifier" /> <parameter name="basketname" type="string" /> + <parameter name="color" type="string" /> <parameter name="basketdesc" type="string" /> <parameter name="basketclause" type="string" /> <parameter name="Submit" type="string" /> diff --git a/modules/entities/class/class_manage_entities_Abstract.php b/modules/entities/class/class_manage_entities_Abstract.php index 286fbcbe3e04f9f7b8c95155d1e573f201c60a7c..6ca7714207fa58f951d77caf020dc4168f3039d3 100755 --- a/modules/entities/class/class_manage_entities_Abstract.php +++ b/modules/entities/class/class_manage_entities_Abstract.php @@ -52,6 +52,7 @@ abstract class entity_Abstract extends functions $line = $stmt->fetchObject(); $_SESSION['m_admin']['entity']['label'] = functions::show_string($line->entity_label); $_SESSION['m_admin']['entity']['short_label'] = functions::show_string($line->short_label); + $_SESSION['m_admin']['entity']['entity_full_name'] = functions::show_string($line->entity_full_name); $_SESSION['m_admin']['entity']['enabled'] = functions::show_string($line->enabled); $_SESSION['m_admin']['entity']['adrs1'] = functions::show_string($line->adrs_1); $_SESSION['m_admin']['entity']['adrs2'] = functions::show_string($line->adrs_2); @@ -155,6 +156,10 @@ abstract class entity_Abstract extends functions <label><?php echo _SHORT_LABEL;?> : </label> <input name="short_label" type="text" id="short_label" value="<?php if(isset($_SESSION['m_admin']['entity']['short_label'])){ functions::xecho($_SESSION['m_admin']['entity']['short_label']);} ?>" /><span class="red_asterisk"><i class="fa fa-star"></i></span> </p> + <p style="text-align:right;"> + <label><?php echo _ENTITY_FULL_NAME;?> : </label> + <textarea name="entity_full_name" style="margin-right: 7px" type="text" id="entity_full_name"><?php if(isset($_SESSION['m_admin']['entity']['entity_full_name'])){ functions::xecho($_SESSION['m_admin']['entity']['entity_full_name']);}?></textarea> + </p> <p style="text-align:right;"> <label><?php echo _ENTITY_ADR_1;?> : </label> <input name="adrs1" style="margin-right: 7px" type="text" id="adrs1" value="<?php if(isset( $_SESSION['m_admin']['entity']['adrs1'])){functions::xecho($_SESSION['m_admin']['entity']['adrs1']); }?>" /> @@ -736,10 +741,10 @@ abstract class entity_Abstract extends functions { $entities = array(); $db = new Database(); - $stmt = $db->query("select e.entity_id,e.entity_label,e.short_label, ue.primary_entity, ue.user_role from ".ENT_ENTITIES." e, ".ENT_USERS_ENTITIES." ue where ue.entity_id = e.entity_id and ue.user_id = ? order by e.entity_label",array(trim($user_id))); + $stmt = $db->query("select e.entity_id,e.entity_label,e.short_label,e.entity_full_name ue.primary_entity, ue.user_role from ".ENT_ENTITIES." e, ".ENT_USERS_ENTITIES." ue where ue.entity_id = e.entity_id and ue.user_id = ? order by e.entity_label",array(trim($user_id))); while($res = $stmt->fetchObject()) { - array_push($entities, array('ID' => $res->entity_id, 'LABEL' => $res->entity_label, 'SHORT_LABEL' => $res->short_label,'PRIMARY' => $res->entity_label, 'ROLE' => $res->user_role )); + array_push($entities, array('ID' => $res->entity_id, 'LABEL' => $res->entity_label, 'SHORT_LABEL' => $res->short_label,'ENTITY_FULL_NAME' => $res->entity_full_name, 'PRIMARY' => $res->entity_label, 'ROLE' => $res->user_role )); } return $entities; } @@ -941,6 +946,11 @@ abstract class entity_Abstract extends functions { $_SESSION['error'].= _SHORT_LABEL_MISSING."<br/>"; } + $_SESSION['m_admin']['entity']['entity_full_name'] = ''; + if(isset($_REQUEST['entity_full_name']) && !empty($_REQUEST['entity_full_name'])){ + $_SESSION['m_admin']['entity']['entity_full_name'] = functions::wash(utf8_decode($_REQUEST['entity_full_name']), "no", _FULL_NAME, 'yes', 0); + $_SESSION['m_admin']['entity']['entity_full_name'] = utf8_encode($_SESSION['m_admin']['entity']['entity_full_name']); + } $_SESSION['m_admin']['entity']['adrs1'] = ''; if(isset($_REQUEST['adrs1']) && !empty($_REQUEST['adrs1'])) { @@ -1097,7 +1107,7 @@ abstract class entity_Abstract extends functions $entityPath .= $entityIdForTree . '/' . $_SESSION['m_admin']['entity']['entityId']; } - $stmt = $db->query('INSERT INTO '.ENT_ENTITIES." (entity_id, entity_label, short_label, adrs_1, adrs_2, adrs_3, zipcode, city, country, email, business_id, parent_entity_id, entity_type, entity_path, archival_agency, archival_agreement) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",array($_SESSION['m_admin']['entity']['entityId'],$_SESSION['m_admin']['entity']['label'],$_SESSION['m_admin']['entity']['short_label'],$_SESSION['m_admin']['entity']['adrs1'],$_SESSION['m_admin']['entity']['adrs2'],$_SESSION['m_admin']['entity']['adrs3'],$_SESSION['m_admin']['entity']['zcode'],$_SESSION['m_admin']['entity']['city'],$_SESSION['m_admin']['entity']['country'],$_SESSION['m_admin']['entity']['email'],$_SESSION['m_admin']['entity']['business'],$_SESSION['m_admin']['entity']['parent'],$_SESSION['m_admin']['entity']['type'],$entityPath,$_SESSION['m_admin']['entity']['archival_agency'],$_SESSION['m_admin']['entity']['archival_agreement'])); + $stmt = $db->query('INSERT INTO '.ENT_ENTITIES." (entity_id, entity_label, short_label, adrs_1, adrs_2, adrs_3, zipcode, city, country, email, business_id, parent_entity_id, entity_type, entity_path, archival_agency, archival_agreement, entity_full_name) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",array($_SESSION['m_admin']['entity']['entityId'],$_SESSION['m_admin']['entity']['label'],$_SESSION['m_admin']['entity']['short_label'],$_SESSION['m_admin']['entity']['adrs1'],$_SESSION['m_admin']['entity']['adrs2'],$_SESSION['m_admin']['entity']['adrs3'],$_SESSION['m_admin']['entity']['zcode'],$_SESSION['m_admin']['entity']['city'],$_SESSION['m_admin']['entity']['country'],$_SESSION['m_admin']['entity']['email'],$_SESSION['m_admin']['entity']['business'],$_SESSION['m_admin']['entity']['parent'],$_SESSION['m_admin']['entity']['type'],$entityPath,$_SESSION['m_admin']['entity']['archival_agency'],$_SESSION['m_admin']['entity']['archival_agreement'],$_SESSION['m_admin']['entity']['entity_full_name'])); $_SESSION['service_tag'] = 'entity_add_db'; $core->execute_modules_services($_SESSION['modules_services'], 'entity_add_db', "include"); $core->execute_app_services($_SESSION['app_services'], 'entity_add_db', 'include'); @@ -1147,7 +1157,7 @@ abstract class entity_Abstract extends functions $entityPath .= $entityIdForTree . '/' . $_SESSION['m_admin']['entity']['entityId']; } - $stmt = $db->query('UPDATE '.ENT_ENTITIES." set entity_label = ? , short_label = ? , adrs_1 = ?, adrs_2 = ?, adrs_3 = ?, zipcode = ?, city = ?, country = ?, email = ?, business_id = ?, parent_entity_id = ?, entity_type = ?, entity_path = ?, archival_agency = ?, archival_agreement = ? where entity_id = ?",array($_SESSION['m_admin']['entity']['label'], $_SESSION['m_admin']['entity']['short_label'], $_SESSION['m_admin']['entity']['adrs1'], $_SESSION['m_admin']['entity']['adrs2'],$_SESSION['m_admin']['entity']['adrs3'], $_SESSION['m_admin']['entity']['zcode'], $_SESSION['m_admin']['entity']['city'], $_SESSION['m_admin']['entity']['country'], $_SESSION['m_admin']['entity']['email'], $_SESSION['m_admin']['entity']['business'], $_SESSION['m_admin']['entity']['parent'], $_SESSION['m_admin']['entity']['type'], $entityPath, $_SESSION['m_admin']['entity']['archival_agency'], $_SESSION['m_admin']['entity']['archival_agreement'],$_SESSION['m_admin']['entity']['entityId'])); + $stmt = $db->query('UPDATE '.ENT_ENTITIES." set entity_label = ? , short_label = ? , adrs_1 = ?, adrs_2 = ?, adrs_3 = ?, zipcode = ?, city = ?, country = ?, email = ?, business_id = ?, parent_entity_id = ?, entity_type = ?, entity_path = ?, archival_agency = ?, archival_agreement = ?, entity_full_name = ? where entity_id = ?",array($_SESSION['m_admin']['entity']['label'], $_SESSION['m_admin']['entity']['short_label'], $_SESSION['m_admin']['entity']['adrs1'], $_SESSION['m_admin']['entity']['adrs2'],$_SESSION['m_admin']['entity']['adrs3'], $_SESSION['m_admin']['entity']['zcode'], $_SESSION['m_admin']['entity']['city'], $_SESSION['m_admin']['entity']['country'], $_SESSION['m_admin']['entity']['email'], $_SESSION['m_admin']['entity']['business'], $_SESSION['m_admin']['entity']['parent'], $_SESSION['m_admin']['entity']['type'], $entityPath, $_SESSION['m_admin']['entity']['archival_agency'], $_SESSION['m_admin']['entity']['archival_agreement'], $_SESSION['m_admin']['entity']['entity_full_name'], $_SESSION['m_admin']['entity']['entityId'])); $_SESSION['service_tag'] = 'entity_up_db'; $core->execute_modules_services($_SESSION['modules_services'], 'entity_up_db', "include"); $core->execute_app_services($_SESSION['app_services'], 'entity_up_db', 'include'); diff --git a/modules/entities/difflist_display.php b/modules/entities/difflist_display.php index ee7a3f08293b757125781958ddb6c13966aa2893..c4193b6fb907c2e16e80948b05533a95df349c2e 100755 --- a/modules/entities/difflist_display.php +++ b/modules/entities/difflist_display.php @@ -39,7 +39,7 @@ if ($color == ' class="col"') $color = ' '; else $color = ' class="col"'; - if (preg_match("/[DEL]/", $difflist[$role_id]['users'][$i]['process_comment'])) { + if (preg_match("/\[DEL\]/", $difflist[$role_id]['users'][$i]['process_comment'])) { $styleMoved=" style='text-decoration: line-through;opacity:0.5;' "; $descMoved=$difflist[$role_id]['users'][$i]['process_comment']; } else { diff --git a/modules/entities/lang/en.php b/modules/entities/lang/en.php index af57e5a0b94b0df72263dde3363a57a1ee4be2de..49eafc29e003588a145e5ff30b6c86cfe38d768a 100755 --- a/modules/entities/lang/en.php +++ b/modules/entities/lang/en.php @@ -118,6 +118,8 @@ if (!defined("_ENTITY_LABEL")) define("_ENTITY_LABEL", "Name"); if (!defined("_SHORT_LABEL")) define("_SHORT_LABEL", "Short name"); +if (!defined("_ENTITY_FULL_NAME")) + define("_ENTITY_FULL_NAME", "Full name"); if (!defined("_ENTITY_ADR_1")) define("_ENTITY_ADR_1", "Address 1"); if (!defined("_ENTITY_ADR_2")) diff --git a/modules/entities/lang/fr.php b/modules/entities/lang/fr.php index f60df86a340195fd742674c85b10ede4f31f3154..100191e684557f4919601ed989f16abd8d13b117 100755 --- a/modules/entities/lang/fr.php +++ b/modules/entities/lang/fr.php @@ -118,6 +118,8 @@ if (!defined("_ENTITY_LABEL")) define("_ENTITY_LABEL", "Nom"); if (!defined("_SHORT_LABEL")) define("_SHORT_LABEL", "Nom court"); +if (!defined("_ENTITY_FULL_NAME")) + define("_ENTITY_FULL_NAME", "Nom complet"); if (!defined("_ENTITY_ADR_1")) define("_ENTITY_ADR_1", "Adresse 1"); if (!defined("_ENTITY_ADR_2")) diff --git a/modules/entities/xml/IVS/validation_rules.xml b/modules/entities/xml/IVS/validation_rules.xml index 0b94080959aea33d66f4a076c4c8b760cd9eeedd..82049567a0ded787cf29425e1d9db6d82e9eddde 100755 --- a/modules/entities/xml/IVS/validation_rules.xml +++ b/modules/entities/xml/IVS/validation_rules.xml @@ -70,6 +70,7 @@ <parameter name="mode" type="mode" /> <parameter name="parententity" type="identifier" /> <parameter name="short_label" type="string" /> + <parameter name="entity_full_name" type="string" /> <parameter name="type" type="string" /> <parameter name="archival_agreement" type="string" /> <parameter name="archival_agency" type="string" /> diff --git a/modules/notifications/Controllers/NotificationController.php b/modules/notifications/Controllers/NotificationController.php index 88ca6e3fd32e1f20ff3f8597cb090ab7983e90af..321b432a1eeefe76fb3be094ada21e3aba4a306d 100644 --- a/modules/notifications/Controllers/NotificationController.php +++ b/modules/notifications/Controllers/NotificationController.php @@ -21,7 +21,6 @@ use Psr\Http\Message\ResponseInterface; use Respect\Validation\Validator; use Notifications\Models\NotificationModel; use Core\Models\ServiceModel; -use Core\Models\LangModel; use Core\Controllers\HistoryController; @@ -43,6 +42,7 @@ class NotificationController if (!ServiceModel::hasService(['id' => 'admin_notif', 'userId' => $_SESSION['user']['UserId'], 'location' => 'notifications', 'type' => 'admin'])) { return $response->withStatus(403)->withJson(['errors' => 'Service forbidden']); } + $notification['notifications'] = NotificationModel::getByNotificationId(['notificationId' => $aArgs['id'], 'select' => ['notification_sid', 'notification_id', 'description', 'is_enabled', 'event_id', 'notification_mode', 'template_id', 'diffusion_type','diffusion_properties', 'attachfor_type','attachfor_properties']]); if (empty($notification['notifications'])) { return $response->withStatus(400)->withJson(['errors' => 'Notification not found']); @@ -65,44 +65,37 @@ class NotificationController $notificationInDb = NotificationModel::getByNotificationId(['notificationId' => $data['notification_id'], 'select' => ['notification_sid']]); if($data){ - if(is_int($notificationInDb['notification_sid'])){ + if(is_int($notificationInDb['notification_sid'])) { return $response->withStatus(400)->withJson(['errors' => _NOTIFICATIONS_ERROR.' '._NOTIF_ALREADY_EXIST]); - }elseif(strlen($data[description]) > 255){ + }elseif(strlen($data['description']) > 255) { return $response->withStatus(400)->withJson(['errors' => _NOTIFICATIONS_ERROR.' '._NOTIF_DESCRIPTION_TOO_LONG]); - }elseif(strlen($data[event_id]) > 255 && is_string($data[event_id])){ + }elseif(strlen($data['event_id']) > 255 && is_string($data['event_id'])) { return $response->withStatus(400)->withJson(['errors' => _NOTIFICATIONS_ERROR.' '._NOTIF_EVENT_TOO_LONG]); - }elseif(strlen($data[notification_mode]) > 30){ + }elseif(strlen($data['notification_mode']) > 30){ return $response->withStatus(400)->withJson(['errors' => _NOTIFICATIONS_ERROR.' '._NOTIF_MODE_TOO_LONG]); - }elseif(Validator::intType()->notEmpty()->validate($data[template_id])){ + }elseif(Validator::intType()->notEmpty()->validate($data['template_id'])){ return $response->withStatus(400)->withJson(['errors' => _NOTIFICATIONS_ERROR.' '._NOTIF_TEMPLATE_NOT_A_INT]); - }elseif(!is_string($data[diffusion_type])){ + }elseif(!is_string($data['diffusion_type'])){ return $response->withStatus(400)->withJson(['errors' => _NOTIFICATIONS_ERROR.' '._NOTIF_DIFFUSION_IS_A_INT]); } - // elseif(!is_array($data[diffusion_properties])){ - // return $response->withStatus(400)->withJson(['errors' => _NOTIFICATIONS_ERROR.' '._NOTIF_DIFFUSION_PROPERTIES_NOT_INT]); - // } - if($data[is_enabled] == true){ - $data[is_enabled] = 'Y'; + if($data['is_enabled'] == true){ + $data['is_enabled'] = 'Y'; }else{ - $data[is_enabled] = 'N'; + $data['is_enabled'] = 'N'; } - $data[notification_mode] = 'EMAIL'; + $data['notification_mode'] = 'EMAIL'; - if($data[diffusion_properties]){ - $data[diffusion_properties] = implode(",",$data[diffusion_properties]); + if($data['diffusion_properties']){ + $data['diffusion_properties'] = implode(",", $data['diffusion_properties']); } - if($data[attachfor_properties]){ - $data[attachfor_properties] = implode(",",$data[attachfor_properties]); + if($data['attachfor_properties']){ + $data['attachfor_properties'] = implode(",", $data['attachfor_properties']); }else{ - $data[attachfor_properties] = ''; + $data['attachfor_properties'] = ''; } - - // elseif(!is_string($data[rss_url_template])){ - // return $response->withStatus(400)->withJson(['errors' => 'Notification error : rss_url_template is not in good format ']); - // } if (NotificationModel::create($data)) { HistoryController::add([ @@ -129,33 +122,26 @@ class NotificationController $data = $request->getParams(); $data['notification_sid'] = $aArgs['id']; - $data[diffusion_properties] = implode(",",$data[diffusion_properties]); + $data['diffusion_properties'] = implode(",", $data['diffusion_properties']); - $data[attachfor_properties] = implode(",",$data[attachfor_properties]); - // var_dump($aArgs); - // var_dump($data); - - //$aArgs = self::manageValue($request); - //$errors = $this->control($aArgs, 'update'); - + $data['attachfor_properties'] = implode(",", $data['attachfor_properties']); if (!empty($errors)) { return $response->withStatus(500)->withJson(['errors' => $errors]); } NotificationModel::update($data); - $notification = NotificationModel::getById(['notificationId' => $data['notification_id']]); + $notification = NotificationModel::getById(['notificationId' => $data['notification_id']]); - HistoryController::add([ - 'table_name' => 'notifications', - 'record_id' => $data['notification_sid'], - 'event_type' => 'UP', - 'event_id' => 'notificationsup', - 'info' => _MODIFY_NOTIFICATIONS . ' : ' . $data['notification_sid'] - ]); + HistoryController::add([ + 'table_name' => 'notifications', + 'record_id' => $data['notification_sid'], + 'event_type' => 'UP', + 'event_id' => 'notificationsup', + 'info' => _MODIFY_NOTIFICATIONS . ' : ' . $data['notification_sid'] + ]); - return $response->withJson(['notification'=> $notification]); - + return $response->withJson(['notification'=> $notification]); } public function delete(RequestInterface $request, ResponseInterface $response, $aArgs) @@ -186,9 +172,10 @@ class NotificationController if (!ServiceModel::hasService(['id' => 'admin_notif', 'userId' => $_SESSION['user']['UserId'], 'location' => 'notifications', 'type' => 'admin'])) { return $response->withStatus(403)->withJson(['errors' => 'Service forbidden']); } + $notification = []; - $notification[diffusion_properties] = []; - $notification[attachfor_properties] = []; + $notification['diffusion_properties'] = []; + $notification['attachfor_properties'] = []; $data = []; $data['event'] = NotificationModel::getEvent(); @@ -209,9 +196,9 @@ class NotificationController if (!ServiceModel::hasService(['id' => 'admin_notif', 'userId' => $_SESSION['user']['UserId'], 'location' => 'notifications', 'type' => 'admin'])) { return $response->withStatus(403)->withJson(['errors' => 'Service forbidden']); } + $notification = NotificationModel::getById(['notification_sid' => $aArgs['id'], 'select' => ['notification_sid', 'notification_id', 'description', 'is_enabled', 'event_id', 'notification_mode', 'template_id', 'diffusion_type','diffusion_properties', 'attachfor_type','attachfor_properties']]); - - + $notification['diffusion_properties'] = explode(",",$notification['diffusion_properties']); foreach ($notification['diffusion_properties'] as $key => $value) { diff --git a/modules/notifications/Models/NotificationModelAbstract.php b/modules/notifications/Models/NotificationModelAbstract.php index 5c09dcaa3907ac0d250b1d5868569d47f4cbce35..22fd1ffd6d5a6a935a1b2bb743a49cab77d5acc7 100644 --- a/modules/notifications/Models/NotificationModelAbstract.php +++ b/modules/notifications/Models/NotificationModelAbstract.php @@ -25,7 +25,6 @@ class NotificationModelAbstract { public static function get(array $aArgs = []) { - ValidatorModel::notEmpty($aArgs, ['select']); $aNotifications = DatabaseModel::select([ 'select' => empty($aArgs['select']) ? ['*'] : $aArgs['select'], 'table' => ['notifications'] @@ -36,13 +35,15 @@ class NotificationModelAbstract public static function getById(array $aArgs = []) { - //ValidatorModel::notEmpty($aArgs, ['notification_sid']); + ValidatorModel::notEmpty($aArgs, ['notification_sid']); + $aNotification = DatabaseModel::select([ 'select' => empty($aArgs['select']) ? ['*'] : $aArgs['select'], 'table' => ['notifications'], 'where' => ['notification_sid = ?'], 'data' => [$aArgs['notification_sid']] ]); + if (empty($aNotification[0])) { return []; } @@ -52,13 +53,15 @@ class NotificationModelAbstract public static function getByNotificationId(array $aArgs = []) { - //ValidatorModel::notEmpty($aArgs, ['notificationId']); + ValidatorModel::notEmpty($aArgs, ['notificationId']); + $aNotification = DatabaseModel::select([ 'select' => empty($aArgs['select']) ? ['*'] : $aArgs['select'], 'table' => ['notifications'], 'where' => ['notification_id = ?'], 'data' => [$aArgs['notificationId']] ]); + if (empty($aNotification[0])) { return []; } @@ -70,6 +73,7 @@ class NotificationModelAbstract { ValidatorModel::notEmpty($aArgs, ['notification_sid']); ValidatorModel::intVal($aArgs, ['notification_sid']); + DatabaseModel::delete([ 'table' => 'notifications', 'where' => ['notification_sid = ?'], @@ -84,26 +88,25 @@ class NotificationModelAbstract ValidatorModel::notEmpty($aArgs, ['notification_id', 'description', 'is_enabled', 'event_id', 'notification_mode', 'template_id', 'diffusion_type', 'diffusion_properties']); ValidatorModel::intVal($aArgs, ['template_id']); ValidatorModel::stringType($aArgs, ['notification_id','description','is_enabled','event_id','notification_mode',]); - //var_dump($aArgs);exit; + DatabaseModel::insert([ 'table' => 'notifications', 'columnsValues' => [ - 'notification_id' => $aArgs['notification_id'], - 'description' => $aArgs['description'], - 'is_enabled' => $aArgs['is_enabled'], - 'event_id' => $aArgs['event_id'], - 'notification_mode' => $aArgs['notification_mode'], - 'template_id' => $aArgs['template_id'], - 'rss_url_template' => $aArgs['rss_url_template'], - 'diffusion_type' => $aArgs['diffusion_type'], - 'diffusion_properties' => $aArgs['diffusion_properties'], - 'attachfor_type' => $aArgs['attachfor_type'], - 'attachfor_properties' => $aArgs['attachfor_properties'] + 'notification_id' => $aArgs['notification_id'], + 'description' => $aArgs['description'], + 'is_enabled' => $aArgs['is_enabled'], + 'event_id' => $aArgs['event_id'], + 'notification_mode' => $aArgs['notification_mode'], + 'template_id' => $aArgs['template_id'], + 'rss_url_template' => $aArgs['rss_url_template'], + 'diffusion_type' => $aArgs['diffusion_type'], + 'diffusion_properties' => $aArgs['diffusion_properties'], + 'attachfor_type' => $aArgs['attachfor_type'], + 'attachfor_properties' => $aArgs['attachfor_properties'] ] ]); return true; - } public static function update(array $aArgs) @@ -111,7 +114,7 @@ class NotificationModelAbstract ValidatorModel::notEmpty($aArgs, ['notification_sid']); ValidatorModel::intVal($aArgs, ['notification_sid']); - $where['notification_sid'] = $aArgs['notification_sid']; + $notification_sid = $aArgs['notification_sid']; unset($aArgs['data']); unset($aArgs['notification_sid']); @@ -119,7 +122,7 @@ class NotificationModelAbstract 'table' => 'notifications', 'set' => $aArgs, 'where' => ['notification_sid = ?'], - 'data' => [$where['notification_sid']] + 'data' => [$notification_sid] ]); return $aReturn; @@ -127,7 +130,6 @@ class NotificationModelAbstract public static function getEvent() { - //get event action in the database $tabEvent_Type = DatabaseModel::select([ 'select' => ['id, label_action'], 'table' => ['actions'] @@ -152,7 +154,6 @@ class NotificationModelAbstract } } - return $tabEvent_Type; } @@ -162,8 +163,7 @@ class NotificationModelAbstract 'select' => ['template_id, template_label'], 'table' => ['templates'], 'where' => ['template_target = ?'], - 'data' => ['notifications'] - + 'data' => ['notifications'] ]); return $tabTemplate; diff --git a/modules/notifications/class/class_schedule_notifications_Abstract.php b/modules/notifications/class/class_schedule_notifications_Abstract.php index 073e02ed0f1aa4cd746c448d990722b512e0ee85..383a65443b09bafa96352c333c624efea5f29991 100755 --- a/modules/notifications/class/class_schedule_notifications_Abstract.php +++ b/modules/notifications/class/class_schedule_notifications_Abstract.php @@ -155,7 +155,13 @@ abstract class ScheduleNotifications_Abstract fwrite($file_open, "\n"); if ($notification_id == 'BASKETS') { fwrite($file_open, 'php \'basket_event_stack.php\' -c '.$ConfigNotif.' -n '.$notification_id); - } else { + } + else if ($notification_id == 'RELANCE1' || $notification_id == 'RELANCE2' || $notification_id == 'RET1' || $notification_id == 'RET2'){ + fwrite($file_open, 'php \'process_event_stack.php\' -c '.$ConfigNotif.' -n '.$notification_id); + fwrite($file_open, "\n"); + fwrite($file_open, 'php \'stack_letterbox_alerts.php\' -c '.$ConfigNotif); + } + else { fwrite($file_open, 'php \'process_event_stack.php\' -c '.$ConfigNotif.' -n '.$notification_id); } fwrite($file_open, "\n"); diff --git a/modules/visa/class/class_modules_tools_Abstract.php b/modules/visa/class/class_modules_tools_Abstract.php index 5b4c9966cb7be7348e9f1bb6edb8d7ce828fe7e6..230eedd2815a21b87b7d0599de0aee8b53c3e752 100755 --- a/modules/visa/class/class_modules_tools_Abstract.php +++ b/modules/visa/class/class_modules_tools_Abstract.php @@ -412,10 +412,10 @@ abstract class visa_Abstract extends Database users_entities.primary_entity = 'Y' and users.user_id = usergroup_content.user_id AND entities.entity_id = users_entities.entity_id AND group_id IN (SELECT group_id FROM usergroups_services WHERE service_id = ? AND group_id = ?) order by users.lastname", array('visa_documents',$group_id)); }else{ - $stmt = $db->query("SELECT users.user_id, users.firstname, users.lastname, usergroup_content.group_id,entities.entity_id, users.enabled from users, usergroup_content, users_entities,entities WHERE users_entities.user_id = users.user_id and users.status <> 'DEL' and + $stmt = $db->query("SELECT distinct on(users.user_id) users.user_id, users.firstname, users.lastname, usergroup_content.group_id,entities.entity_id, users.enabled from users, usergroup_content, users_entities,entities WHERE users_entities.user_id = users.user_id and users.status <> 'DEL' and users_entities.primary_entity = 'Y' and users.user_id = usergroup_content.user_id AND entities.entity_id = users_entities.entity_id AND group_id IN (SELECT group_id FROM usergroups_services WHERE service_id = ?) - order by users.lastname", array('visa_documents')); + order by users.user_id,users.lastname", array('visa_documents')); } $tab_users = array(); @@ -626,7 +626,7 @@ abstract class visa_Abstract extends Database $disabled = ' disabled="disabled"'; - if(preg_match("/[DEL]/", $info_userVis['process_comment'])){ + if(preg_match("/\[DEL\]/", $info_userVis['process_comment'])){ $info_vised = ''; $link_vis = 'times'; $vised = ' moved vised'; @@ -713,7 +713,7 @@ abstract class visa_Abstract extends Database }else{ $modif = 'false'; - if (preg_match("/[DEL]/", $info_userSign['process_comment'])) { + if (preg_match("/\[DEL\]/", $info_userSign['process_comment'])) { $info_vised = ''; $link_vis = 'times'; $vised = ' moved vised'; diff --git a/rest/index.php b/rest/index.php index 85089f5e5dccde38af3e529ac4ee93d29a796c0b..b8bf83a3586bbd311b1367e9efe0e9189cb47ec6 100755 --- a/rest/index.php +++ b/rest/index.php @@ -189,7 +189,9 @@ $app->put('/users/{id}/status', \Core\Controllers\UserController::class . ':upda $app->post('/users/{id}/signatures', \Core\Controllers\UserController::class . ':addSignature'); $app->put('/users/{id}/signatures/{signatureId}', \Core\Controllers\UserController::class . ':updateSignature'); $app->delete('/users/{id}/signatures/{signatureId}', \Core\Controllers\UserController::class . ':deleteSignature'); -$app->post('/users/{id}/baskets/absence', \Core\Controllers\UserController::class . ':setBasketsRedirectionForAbsence'); +$app->post('/users/{id}/baskets/absence', \Core\Controllers\UserController::class . ':setRedirectedBaskets'); //TODO penser à une meilleure route +$app->delete('/users/{id}/baskets/{basketId}/absence', \Core\Controllers\UserController::class . ':deleteRedirectedBaskets'); //TODO penser à une meilleure route + //CurrentUser $app->put('/currentUser/password', \Core\Controllers\UserController::class . ':updateCurrentUserPassword'); diff --git a/sql/17_xx.sql b/sql/17_xx.sql index d08837a236bc3c77b7ceb386a6b9d57b8847c560..17b476464a5cf9f9c8df069a3b075a6cae0b8462 100755 --- a/sql/17_xx.sql +++ b/sql/17_xx.sql @@ -102,4 +102,11 @@ ALTER TABLE sendmail ADD COLUMN res_version_att_id_list character varying(255); /*SALT*/ UPDATE users set password = '$2y$10$C.QSslBKD3yNMfRPuZfcaubFwPKiCkqqOUyAdOr5FSGKPaePwuEjG', change_password = 'Y' WHERE user_id != 'superadmin'; -UPDATE users set password = '$2y$10$Vq244c5s2zmldjblmMXEN./Q2qZrqtGVgrbz/l1WfsUJbLco4E.e.' where user_id = 'superadmin'; \ No newline at end of file +UPDATE users set password = '$2y$10$Vq244c5s2zmldjblmMXEN./Q2qZrqtGVgrbz/l1WfsUJbLco4E.e.' where user_id = 'superadmin'; + +/*BASKETS COLOR*/ +ALTER TABLE baskets DROP COLUMN IF EXISTS color; +ALTER TABLE baskets ADD color character varying(16); +/*ENTITIES FULL NAME*/ +ALTER TABLE entities DROP COLUMN IF EXISTS entity_full_name; +ALTER TABLE entities ADD entity_full_name text; diff --git a/sql/structure.sql b/sql/structure.sql index 37cfd797bd2f053f71e0709bf71f20522fb36bcf..0ae9896701acbf780675faca4d62a962842d7f90 100755 --- a/sql/structure.sql +++ b/sql/structure.sql @@ -633,6 +633,7 @@ CREATE TABLE entities entity_id character varying(32) NOT NULL, entity_label character varying(255), short_label character varying(50), + entity_full_name text, enabled character(1) NOT NULL DEFAULT 'Y'::bpchar, adrs_1 character varying(255), adrs_2 character varying(255),