db = &$db; $this->tpl = &$tpl; $this->error = &$error; } function viewAdvicesLast($limit = 3){ $sql = "select advices.* from advices order by advices.mktime desc limit $limit"; $row = $this->db->getAll($sql,array(),DB_FETCHMODE_ASSOC); $this->tpl->assign('advices_last',$row); } function viewAllAdvices($param = array(),$lang='ru'){ $search = array(); $sql = "select *"; if($lang=='ukr')$sql .= ", title_ukr as title,text_ukr as text"; $sql .= " from advices where 1=1 "; if(count($search))$sql .= "AND " . implode(" AND ",$search)." "; $sql .= "order by mktime desc"; $pagerOptions = Array( 'mode' => 'Sliding', 'delta' => 6, 'perPage' => 10, 'spacesBeforeSeparator' => 1, 'spacesAfterSeparator' => 1 ); $this->tpl->assign('advicesAllData', Pager_Wrapper_DB($this->db, $sql, $pagerOptions, false, DB_FETCHMODE_ASSOC, array())); } function getAdvices($limit = 10,$firm_id = "all"){ $sql = "select articles.*,rss_rubrics.name as rss_rubric_name from articles left join rss_rubrics on rss_rubrics.id=articles.rss_rubric "; if($firm_id!="all")$sql .= "where articles.firm_id=$firm_id "; $sql .= "order by articles.mktime desc limit $limit"; return $this->db->getAll($sql,array(),DB_FETCHMODE_ASSOC); } function viewOneAdvices($id,&$row,$lang = "ru"){ $sql = "select *"; if($lang=='ukr')$sql .= ", title_ukr as title,text_ukr as text,meta_title_ukr as meta_title,meta_description_ukr as meta_description"; $sql .= " from advices where id=? limit 1"; $row = $this->db->getRow($sql,array($id),DB_FETCHMODE_ASSOC); $this->tpl->assign('advices',$row); } function infoEditAdvicesOne($id,$firm_id){ $sql = "select * from advices where firm_id=? and id=? limit 1"; $row = $this->db->getRow($sql,array($firm_id,$id),DB_FETCHMODE_ASSOC); $this->tpl->assign('advices',$row); } function admin_infoEditAdvicesOne($id){ $sql = "select * from advices where id=? limit 1"; $row = $this->db->getRow($sql,array($id),DB_FETCHMODE_ASSOC); $this->tpl->assign('advices',$row); } function Click($id){ $sql = "update advices set view=view+1 where id=? limit 1"; $this->db->query($sql,$id); } function trim(&$data){ foreach($data as $key=>$value){ if(!is_array($data[$key]))$data[$key] = trim($value); } } function valid($data,$upload = null){ if(isset($data['rss_rubric'])){ if( !preg_match("/^([0-9]+)$/",$data['rss_rubric']) ) $this->error[] = "Îøèáêà ââîäà ïîëÿ Ðóáðèêà."; } if(isset($data['title'])){ if( !preg_match("/.{1,150}/i",$data['title']) ) $this->error[] = "Îøèáêà ââîäà ïîëÿ Çàãëàâèå, îò 1-150 ñèìâîëîâ."; } if(isset($data['text'])){ if( !preg_match("/.+/is",$data['text']) ) $this->error[] = "Îøèáêà ââîäà ïîëÿ Îïèñàíèå."; } if(isset($upload['pic']['name']) && $upload['pic']['name']!=null){ $type = substr(strrchr($upload['pic']['name'],"."),1); if( !preg_match("/^(jpeg|jpg|gif|png)$/i",$type) ) $this->error[] = "Îøèáêà ââîäà ïîëÿ Èçîáðàæåíèÿ, òîëüêî jpg,png,gif."; } return ( count($this->error) ) ? true : false; } function SaveAdvices($data,$upload = null){ $table_name = "advices"; if($data['update_id']>0){$DB_AUTOQUERY = DB_AUTOQUERY_UPDATE;$id = $data['update_id'];$where = "id=$id";}else{$DB_AUTOQUERY = DB_AUTOQUERY_INSERT;$id = $this->db->nextId('mySequenceAdvices');$where = null;} $fields_values = array("id"=>$id,"title"=>$data['title'],"title_ukr"=>$data['title_ukr'],"text"=>$data['text'],"text_ukr"=>$data['text_ukr'],"youtube"=>$data['youtube'],"meta_title"=>$data['meta_title'],"meta_title_ukr"=>$data['meta_title_ukr'],"meta_description"=>$data['meta_description'],"meta_description"=>$data['meta_description'],"meta_description_ukr"=>$data['meta_description_ukr'],"meta_keywords"=>$data['meta_keywords'],"meta_keywords_ukr"=>$data['meta_keywords_ukr'],"meta_about"=>$data['meta_about'],"meta_about_ukr"=>$data['meta_about_ukr']); if(!$data['update_id']){$fields_values['mktime'] = mktime();} if(isset($data['delete_pic']) && $data['delete_pic']==1){ $this->deletePic($id); $fields_values['pic'] = null; $fields_values['pic_big'] = null; } if($upload['pic']['tmp_name']){ $this->deletePic($id); $fields_values['pic'] = upload_ImageResize($upload['pic'],array('width'=>"200",'height'=>"200",'upload_path'=>"./uploaded/pic/advices/")); $fields_values['pic_big'] = upload_ImageResize($upload['pic'],array('width'=>"300",'height'=>"300",'upload_path'=>"./uploaded/pic/advices/big/")); } $this->db->autoExecute($table_name, $fields_values, $DB_AUTOQUERY,$where); return $id; } function deletePic($id){ $sql = "select pic,pic_big from advices where id=?"; $advices = $this->db->getRow($sql,array($id),DB_FETCHMODE_ASSOC); @unlink("./uploaded/pic/advices/{$advices['pic']}"); @unlink("./uploaded/pic/advices/big/{$advices['pic_big']}"); } function admin_deleteAdvicesOne($id){ $this->deletePic($id); $sql = "delete from advices where id=?"; $this->db->query($sql,array($id)); } function rssRubcrics(){ $sql = "select * from rss_rubrics"; $rubrics = $this->db->getAll($sql,array(),DB_FETCHMODE_ASSOC); $this->tpl->assign('articles_rubrics',$rubrics); } function displayServieAdvices(){ $this->tpl->assign("service_tpl","advices.tpl"); } function displayServieAdvicesSave(){ $this->rssRubcrics(); $this->tpl->assign("service_tpl","advices_save.tpl"); } function displayAdvicesSave(){ $this->tpl->assign("tpl","advices_save.tpl"); } function displayAdvices(){ $this->tpl->assign("tpl","advices.tpl"); } function displayAdvicesOne(){ $this->tpl->assign("tpl","advices_one.tpl"); } } ?>