/** * Update a Eoi = 1 SharcEoiDesigner + 1 SharcEoiExperience * @param String $objEoi: a json object containing info of both Eois */ public static function updateEoi($objEoi) { $response = array(); try { $eoiDesigner = SharcEoiDesigner::find($objEoi['eoiDesigner']['id']); if ($eoiDesigner != null) { $eoiDesigner->name = $objEoi['eoiDesigner']['name']; $eoiDesigner->description = $objEoi['eoiDesigner']['description']; $result = $eoiDesigner->save(); if (!$result) { $response["status"] = ERROR; $response["data"] = INTERNAL_SERVER_ERROR; return $response; } } $eoiExperience = SharcEoiExperience::find($objEoi['id']); if ($eoiExperience != null) { $eoiExperience->note = $objEoi['note']; $eoiExperience->poiList = $objEoi['poiList']; $eoiExperience->routeList = $objEoi['routeList']; $result = $eoiExperience->save(); if ($result) { //= 1 success $response["status"] = SUCCESS; $response["data"] = $eoiExperience->toArray(); } else { //error $response["status"] = ERROR; $response["data"] = INTERNAL_SERVER_ERROR; } } //update other table e.g. route/event } catch (Exception $e) { $response["status"] = ERROR; $response["data"] = Utils::getExceptionMessage($e); } return $response; }
/** * Get content of an experience details - this function is called by two above funtions * @param String $experienceId: id of the SharcExperience * @param String $designerId: id of the designer */ public static function getExperienceSnapshotDetails($designerId, $experienceId) { $response = array(); $response["status"] = SUCCESS; //Get all POIs of the experience $objPois = SharcPoiExperience::where('experienceId', $experienceId)->get(); $tmpPois = $objPois->toArray(); $i = 0; for ($i; $i < $objPois->count(); $i++) { $rs = SharcPoiDesigner::where('id', $objPois[$i]->poiDesignerId)->where('designerId', $designerId)->get(); $tmpPois[$i]["poiDesigner"] = $rs[0]->toArray(); //Thumbnail $media = SharcMediaExperience::where('entityId', $objPois[$i]->id)->where('entityType', 'POI')->where('mainMedia', 1)->get(); if ($media->count() > 0) { $mediaDesigner = SharcMediaDesigner::where('id', $media[0]->mediaDesignerId)->where('designerId', $designerId)->get(); if ($mediaDesigner->count() > 0) { $tmpPois[$i]["thumbnail"] = $mediaDesigner[0]->content; } else { $tmpPois[$i]["thumbnail"] = ""; } } else { $tmpPois[$i]["thumbnail"] = ""; } //Media for POI $media = MediaService::getMediaForEntityServer($designerId, $experienceId, $objPois[$i]->id, "POI"); $tmpPois[$i]["media"] = $media->toArray(); //$tmpPois[$i]["media"] = $media->toArray(); if ($media != null) { $tmpPois[$i]["mediaCount"] = $media->count(); } else { $tmpPois[$i]["mediaCount"] = 0; } $tmpPois[$i]["responseCount"] = 0; } $response["data"]["allPois"] = $tmpPois; //Get all EOIs of the experience $objEois = SharcEoiExperience::where('experienceId', $experienceId)->get(); $tmpEois = $objEois->toArray(); $i = 0; for ($i; $i < $objEois->count(); $i++) { $rs = SharcEoiDesigner::where('id', $objEois[$i]->eoiDesignerId)->where('designerId', $designerId)->get(); $tmpEois[$i]["eoiDesigner"] = $rs[0]->toArray(); //Media for EOI $media = MediaService::getMediaForEntityServer($designerId, $experienceId, $objEois[$i]->id, "EOI"); //$tmpEois[$i]["media"] = $media->toArray(); if ($media != null) { $tmpEois[$i]["mediaCount"] = $media->count(); } else { $tmpEois[$i]["mediaCount"] = 0; } $tmpEois[$i]["responseCount"] = 0; } $response["data"]["allEois"] = $tmpEois; //Get all Routes of the experience $objRoutes = SharcRouteExperience::where('experienceId', $experienceId)->get(); $tmpRoutes = $objRoutes->toArray(); $i = 0; for ($i; $i < $objRoutes->count(); $i++) { $rs = SharcRouteDesigner::where('id', $objRoutes[$i]->routeDesignerId)->where('designerId', $designerId)->get(); $tmpRoutes[$i]["routeDesigner"] = $rs[0]->toArray(); //Media for EOI $media = MediaService::getMediaForEntityServer($designerId, $experienceId, $objRoutes[$i]->id, "ROUTE"); //$tmpRoutes[$i]["media"] = $media->toArray(); if ($media != null) { $tmpRoutes[$i]["mediaCount"] = $media->count(); } else { $tmpRoutes[$i]["mediaCount"] = 0; } $tmpRoutes[$i]["responseCount"] = 0; } $response["data"]["allRoutes"] = $tmpRoutes; //Get all Media of the experience $objMedia = SharcMediaExperience::where('experienceId', $experienceId)->get(); $tmpMedia = $objMedia->toArray(); $i = 0; for ($i; $i < $objMedia->count(); $i++) { $rs = SharcMediaDesigner::where('id', $objMedia[$i]->mediaDesignerId)->where('designerId', $designerId)->get(); $tmpMedia[$i]["mediaDesigner"] = $rs[0]->toArray(); //Response for media $media = SharcResponse::where('experienceId', $experienceId)->where('entityType', 'media')->where('entityId', $objMedia[$i]->id)->where('status', 'accepted')->get(); if ($media != null) { $tmpMedia[$i]["commentCount"] = $media->count(); } else { $tmpRoutes[$i]["commentCount"] = 0; } } $response["data"]["allMedia"] = $tmpMedia; //Get all responses $objResponses = SharcResponse::where('experienceId', $experienceId)->where('status', 'accepted')->get(); $tmpResponse = $objResponses->toArray(); $i = 0; for ($i; $i < $objResponses->count(); $i++) { $rs = SharcUser::find($objResponses[$i]->userId); if ($rs != null) { $tmpResponse[$i]["userId"] = $rs->username; } //get entity name as well } $response["data"]["allResponses"] = $tmpResponse; //Get all PoiType of the experience $objPoiTypes = SharcPoiType::where('designerId', $designerId)->get(); $response["data"]["allPoiTypes"] = $objPoiTypes->toArray(); return $response; }
/** * Get all responses of an experience * @param String $experienceId: id of the SharcExperience * @param String $designerId: id of the designer */ public static function getExperienceResponses($designerId, $experienceId) { $response = array(); try { //Check if the designerId owns the experience if ($designerId == ADMIN_ID) { //admin $ex = SharcExperience::find($experienceId); $designerId = $ex->designerId; } $rs = SharcExperience::where('id', $experienceId)->where('designerId', $designerId)->get(); if ($rs->count() == 0) { //Not exists $response["status"] = FAILED; $response["data"] = EXPERIENCE_NOT_EXIST; return $response; } else { $response["status"] = SUCCESS; //Get all responses $objResponses = SharcResponse::where('experienceId', $experienceId)->get(); $tmpResponse = $objResponses->toArray(); $i = 0; for ($i; $i < $objResponses->count(); $i++) { $rs = SharcUser::find($objResponses[$i]->userId); if ($rs != null) { $tmpResponse[$i]["userId"] = $rs->username; } //get entity name as well switch ($objResponses[$i]->entityType) { case "POI": $obj = SharcPoiExperience::find($objResponses[$i]->entityId); $tmpResponse[$i]["entityId"] = SharcPoiDesigner::find($obj->poiDesignerId)->name; break; case "EOI": $obj = SharcEoiExperience::find($objResponses[$i]->entityId); $tmpResponse[$i]["entityId"] = SharcEoiDesigner::find($obj->eoiDesignerId)->name; break; case "ROUTE": $obj = SharcRouteExperience::find($objResponses[$i]->entityId); $tmpResponse[$i]["entityId"] = SharcRouteDesigner::find($obj->routeDesignerId)->name; break; case "media": break; } } $response["data"] = $tmpResponse; return $response; } } catch (Exception $e) { $response["status"] = ERROR; $response["data"] = Utils::getExceptionMessage($e); } return $response; }