Example #1
0
 /**
  * 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;
 }
Example #2
0
 /**
  * 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;
 }
Example #3
0
 /**
  * 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;
 }