예제 #1
0
 /**
  * Action - audio
  * upload/download/ordering audio
  * 
  * Access to the action is possible in the following paths:
  * - /blogmanager/audio
  *
  * @return void
  */
 public function audioAction()
 {
     $json = array();
     $filterSanitize = new Default_Form_Filter_Sanitize();
     //-----------------------
     // Получим обьект записи
     $request = $this->getRequest();
     $post_id = (int) $request->getPost('id');
     if (!$post_id) {
         $post_id = (int) $request->getParam('id');
     }
     $post = new Default_Model_DbTable_BlogPost($this->db);
     // Если конкретной записи нет, то перейдем к странице по умолчанию
     if (!$post->loadForUser($this->_identity->user_id, $post_id)) {
         $this->_redirect('/blogmanager');
     }
     // Определим тип операции над аудио: 'upload', 'reorder', 'delete'
     // Загрузка файла с помощью - FileUploader
     if (Default_Plugin_FileUploader::isFileUploader()) {
         // Получим вид загрузчика - Iframe или Xhr
         $fileUploader = Default_Plugin_FileUploader::isFileUploader();
         // list of valid extensions, ex. array("jpeg", "xml", "bmp")
         $allowedExtensions = explode(';', $request->getParam('allowedExtensions'));
         // max file size in bytes
         $sizeLimit = (int) $request->getParam('sizeLimit');
         // Получим обьект загрузчика файлов
         try {
             $uploader = new Default_Plugin_FileUploader($allowedExtensions, $sizeLimit);
             // Определим путь загрузки файлов
             $path = Default_Model_DbTable_BlogPostAudio::GetUploadPath();
             $path .= '/';
             //Загрузим файлы
             $result = $uploader->handleUpload($path);
         } catch (Exception $e) {
             $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка загрузки файла') . '</em>', Default_Plugin_SysBox::getMessageError($e)));
             if ($fileUploader == 'Iframe') {
                 $this->sendJson_Html($json);
             } else {
                 $this->sendJson($json);
             }
             return;
         }
         if (isset($result['success'])) {
             // OK
             // Создадим обьект изображения
             try {
                 $audio = new Default_Model_DbTable_BlogPostAudio($post->getDb());
                 $audio->post_id = $post->getId();
                 $filename = $path . $uploader->file->getName();
                 $audio->uploadFile($filename);
                 $audio->filename = basename($filename);
                 if (!$audio->save()) {
                     $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка при сохранении данных') . '</em>'));
                     if ($fileUploader == 'Iframe') {
                         $this->sendJson_Html($json);
                     } else {
                         $this->sendJson($json);
                     }
                     return;
                 }
                 $json['success'] = $result['success'];
                 $json['audio_id'] = $audio->getId();
                 $json['filename'] = $audio->filename;
                 $json['post_id'] = $audio->post_id;
                 $json['url_image'] = $this->getUrlRes('images/media/thumbs/file-mp3.png') . '?id=' . $audio->getId();
                 $json['form_action'] = $this->getUrl('audio', 'blogmanager');
             } catch (Exception $e) {
                 $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка загрузки файла') . '</em>', Default_Plugin_SysBox::getMessageError($e)));
                 if ($fileUploader == 'Iframe') {
                     $this->sendJson_Html($json);
                 } else {
                     $this->sendJson($json);
                 }
                 return;
             }
         } else {
             // Error
             $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка загрузки файла') . '</em>', $result['error']));
             if ($fileUploader == 'Iframe') {
                 $this->sendJson_Html($json);
             } else {
                 $this->sendJson($json);
             }
             return;
         }
     } else {
         if ($request->getPost('reorder')) {
             $order = $request->getPost('preview-audio');
             $post->setAudioOrder($order);
         } else {
             if ($request->getPost('delete')) {
                 $audio_id = (int) $request->getPost('image');
                 $audio = new Default_Model_DbTable_BlogPostAudio($this->db);
                 if ($audio->loadForPost($post->getId(), $audio_id)) {
                     $audio->delete();
                     // Определим кол. оставшихся изображений
                     $count_audios = count($post->audio) - 1;
                     $json = array('deleted' => true, 'image_id' => $audio_id, 'count_images' => $count_audios);
                 }
             } else {
                 if ($request->getPost('comment_update')) {
                     $audio_id = (int) $request->getPost('image');
                     $audio = new Default_Model_DbTable_BlogPostAudio($this->db);
                     if ($audio->loadForPost($post->getId(), $audio_id)) {
                         $comment = $request->getPost('comment');
                         $comment = $filterSanitize->filter($comment);
                         $arrComment = explode('#', $comment);
                         if (count($arrComment) > 1) {
                             $audio->name = $arrComment[0];
                             $audio->comment = $arrComment[1];
                         } else {
                             $audio->name = $arrComment[0];
                         }
                         if (!$audio->save()) {
                             $json = array('class_message' => 'warning', 'messages' => array('<em>' . $this->Translate('Ошибка при сохранении данных') . '</em>'));
                             $this->sendJson($json);
                             return;
                         }
                         $json = array('commented' => true, 'title' => $audio->name, 'comment' => $audio->comment);
                     }
                 } else {
                     if ($request->getPost('download_images')) {
                         // Загрузим изображения в виде HTML на страницу
                         // Получим файлы музыки для статьи
                         $audios = Default_Model_DbTable_BlogPostAudio::GetAudio($this->db, array('post_id' => $post_id));
                         // Создадим обьект шаблона
                         $templater = Default_Plugin_SysBox::createViewSmarty();
                         //Установим параметры шаблона
                         $templater->audios = $audios;
                         $templater->post_id = $post_id;
                         // Получим результат шаблона
                         $html = $templater->render('blogmanager/lib/download-audio.tpl');
                         $json = array('downloaded' => true, 'html' => $html);
                     }
                 }
             }
         }
     }
     if ($this->_isAjaxRequest) {
         $this->sendJson($json);
     } else {
         $this->sendJson_Html($json);
     }
 }
예제 #2
0
 /**
  * Get the array of records satisfying the criteria specified in the parameter $options using Zend_Paginator
  * 
  * @param Zend_Db_Adapter_Abstract $db
  * @param array $options
  * @return array  Default_Model_DbTable_BlogPost objects
  */
 public static function GetPaginatorPosts($db, $options = array())
 {
     $arrResult = array();
     $_config = Zend_Registry::get('config');
     $itemCountPerPage = (int) $_config['paginator']['itemCountPerPage'];
     $pagesInRange = (int) $_config['paginator']['pagesInRange'];
     //---------------------------------------------------------
     // инициализация опций
     $defaults = array('itemCountPerPage' => $itemCountPerPage, 'pagesInRange' => $pagesInRange, 'page' => 1, 'offset' => 0, 'limit' => 0, 'order' => 'p.ts_created', 'sort' => true);
     foreach ($defaults as $k => $v) {
         $options[$k] = array_key_exists($k, $options) ? $options[$k] : $v;
     }
     $select = self::_GetBaseQuery($db, $options);
     // установим поля таблицы для запроса
     $select->from(null, 'p.*');
     // set the offset, limit, and ordering of results
     if ($options['limit'] > 0) {
         $select->limit($options['limit'], $options['offset']);
     }
     // Установим параметры сортировки для таблицы
     if ($options['sort']) {
         $select = self::GetSelectForSort($select, $options);
     }
     //------ Создадим обьект Zend_Paginator ---------
     $strSelect = $select->__toString();
     $adapter = new Zend_Paginator_Adapter_DbSelect($select);
     $count = self::GetPostsCount($db, $options);
     $adapter->setRowCount($count);
     $paginator = new Zend_Paginator($adapter);
     // Установим максимальное количество отображаемых на странице элементов
     $paginator->setItemCountPerPage($options['itemCountPerPage']);
     // Установи массив страниц, возвращенный текущим стилем прокрутки
     $paginator->setPageRange($options['pagesInRange']);
     // Установим текущую страницу
     $paginator->setCurrentPageNumber($options['page']);
     //----- Конфигурирование кеша для Paginator -----
     $pgCache = Default_Plugin_SysBox::getCache('paginator');
     if ($pgCache->getOption('caching')) {
         // Установим кеш для Paginator
         Zend_Paginator::setCache($pgCache);
         // Очищение кеша
         if (Default_Plugin_SysBox::isCleanCache()) {
             $paginator->clearPageItemCache();
         }
     }
     // получим данные в виде массива обьектов Default_Model_DbTable_BlogPost
     $posts = self::BuildMultiple($db, __CLASS__, $paginator);
     $post_ids = array_keys($posts);
     if (count($post_ids) == 0) {
         return array();
     }
     // получим данные о загруженных сообщениях
     $profiles = Default_Model_Profile::BuildMultiple($db, 'Default_Model_DbTable_BlogPostProfile', array($post_ids));
     foreach ($posts as $post_id => $post) {
         if (array_key_exists($post_id, $profiles) && $profiles[$post_id] instanceof Default_Model_DbTable_BlogPostProfile) {
             $posts[$post_id]->profile = $profiles[$post_id];
         } else {
             $posts[$post_id]->profile->setPostId($post_id);
         }
         //!!!!------ Начало установки признака сортировки -----!!!!!
         if (isset($options['sortColumn'])) {
             $posts[$post_id]->sortColumn = $options['sortColumn'];
         }
         if (isset($options['ascDescFlg'])) {
             $posts[$post_id]->ascDescFlg = $options['ascDescFlg'];
         }
         //!!!!------ Конец установки признака сортировки -----!!!!!
     }
     // load the images for each post
     $options = array('post_id' => $post_ids);
     $images = Default_Model_DbTable_BlogPostImage::GetImages($db, $options);
     foreach ($images as $image) {
         $posts[$image->post_id]->images[$image->getId()] = $image;
     }
     // load the locations for each post
     $locations = Default_Model_DbTable_BlogPostLocation::GetLocations($db, $options);
     foreach ($locations as $l) {
         $posts[$l->post_id]->locations[$l->getId()] = $l;
     }
     // load the audio for each post
     $audios = Default_Model_DbTable_BlogPostAudio::GetAudio($db, $options);
     foreach ($audios as $audio) {
         $posts[$audio->post_id]->audio[$audio->getId()] = $audio;
     }
     // load the video for each post
     $videos = Default_Model_DbTable_BlogPostVideo::GetVideo($db, $options);
     foreach ($videos as $video) {
         $posts[$video->post_id]->video[$video->getId()] = $video;
     }
     // load the comments for each post
     $comments = Default_Model_DbTable_BlogPostComment::GetComments($db, $options);
     foreach ($comments as $comment) {
         $posts[$comment->post_id]->comments[$comment->getId()] = $comment;
     }
     $arrResult['pages'] = $paginator->getPages();
     $arrResult['items'] = $posts;
     return $arrResult;
 }
예제 #3
0
 /**
  * Action - audios
  * Actions with the audios. Get a list of mp3 files and their descriptions
  *
  * Access to the action is possible in the following paths:
  * router pattern - user/:username/post/:post_id/audios/*
  * 
  * - /user/user1/post/27/audios
  *
  * @return void
  */
 public function audiosAction()
 {
     $json = array();
     $caption = '';
     $file = '';
     $comment = '';
     //-----------------------
     // Получим обьект запроса
     $request = $this->getRequest();
     $username = trim($request->getUserParam('username'));
     $post_id = (int) $request->getUserParam('post_id');
     // Получим файлы музыки для статьи
     $audios = Default_Model_DbTable_BlogPostAudio::GetAudio($this->db, array('post_id' => $post_id));
     // Получим путь где находяться файлы музыка автора статьи
     foreach ($audios as $audio) {
         $arrFilename = explode('.', $audio->filename);
         $caption = $arrFilename[0];
         $comment = $audio->comment;
         $file = $audio->getFullUrl_Res($username);
         //Default_Plugin_SysBox::getFullURL_Res($audio->getFullUrl($username));
         $json[] = array('caption' => $caption, 'file' => $file, 'comment' => $comment);
     }
     if ($this->_isAjaxRequest) {
         $this->sendJson($json);
     }
 }