UPGRADE NOTE:
Do not edit or add to this file if you wish to upgrade AbanteCart to newer
versions in the future. If you wish to customize AbanteCart for your
needs please refer to http://www.AbanteCart.com for more information.
------------------------------------------------------------------------------*/
if (! defined ( 'DIR_CORE' ) || !IS_ADMIN) {
header ( 'Location: static_pages/' );
}
class ControllerResponsesListingGridCategory extends AController {
public function main() {
//init controller data
$this->extensions->hk_InitData($this,__FUNCTION__);
$this->loadLanguage('catalog/category');
$this->loadModel('catalog/category');
$this->loadModel('catalog/product');
$this->loadModel('tool/image');
//Prepare filter config
$grid_filter_params = array('name');
$filter = new AFilter( array( 'method' => 'post', 'grid_filter_params' => $grid_filter_params ) );
$filter_data = $filter->getFilterData();
//Add custom params
$filter_data['parent_id'] = ( isset( $this->request->get['parent_id'] ) ? $this->request->get['parent_id'] : 0 );
$new_level = 0;
//get all leave categories
$leafnodes = $this->model_catalog_category->getLeafCategories();
if ($this->request->post['nodeid'] ) {
$sort = $filter_data['sort'];
$order = $filter_data['order'];
//reset filter to get only parent category
$filter_data = array();
$filter_data['sort'] = $sort;
$filter_data['order'] = $order;
$filter_data['parent_id'] = (integer)$this->request->post['nodeid'];
$new_level = (integer)$this->request->post["n_level"] + 1;
}
$total = $this->model_catalog_category->getTotalCategories($filter_data);
$response = new stdClass();
$response->page = $filter->getParam('page');
$response->total = $filter->calcTotalPages( $total );
$response->records = $total;
$response->userdata = new stdClass();
$results = $this->model_catalog_category->getCategoriesData($filter_data);
$i = 0;
$resource = new AResource('image');
foreach ($results as $result) {
$thumbnail = $resource->getMainThumb('categories',
$result['category_id'],
(int)$this->config->get('config_image_grid_width'),
(int)$this->config->get('config_image_grid_height'),true);
$response->rows[$i]['id'] = $result['category_id'];
$cnt = $this->model_catalog_category->getCategoriesData(array('parent_id'=>$result['category_id']),'total_only');
if(!$result['products_count']){
$products_count = 0;
}else{
$products_count = (string)$this->html->buildElement(array(
'type' => 'button',
'name' => 'view products',
'text' => $result[ 'products_count' ],
'href'=> $this->html->getSecureURL('catalog/product','&category='.$result['category_id']),
'title' => $this->language->get('text_view').' '.$this->language->get('tab_product')
));
}
//tree grid structure
if ( $this->config->get('config_show_tree_data') ) {
$name_lable = '';
} else {
$name_lable = ''
.$this->html->buildInput(array(
'name' => 'category_description['.$result['category_id'].']['.$this->session->data['content_language_id'].'][name]',
'value' => $result['basename'],
'attr' => ' maxlength="32" '
));
}
$response->rows[$i]['cell'] = array(
$thumbnail['thumb_html'],
$name_lable,
$this->html->buildInput(array(
'name' => 'sort_order['.$result['category_id'].']',
'value' => $result['sort_order'],
)),
$this->html->buildCheckbox(array(
'name' => 'status['.$result['category_id'].']',
'value' => $result['status'],
'style' => 'btn_switch',
)),
$products_count,
$cnt
.($cnt ?
' '.
''
:''),
'action',
$new_level,
( $filter_data['parent_id'] ? $filter_data['parent_id'] : NULL ),
( $result['category_id'] == $leafnodes[$result['category_id']] ? true : false ),
false
);
$i++;
}
//update controller data
$this->extensions->hk_UpdateData($this,__FUNCTION__);
$this->load->library('json');
$this->response->setOutput(AJson::encode($response));
}
public function update() {
//init controller data
$this->extensions->hk_InitData($this,__FUNCTION__);
$this->loadModel('catalog/product');
$this->loadModel('catalog/category');
$this->loadLanguage('catalog/category');
if (!$this->user->canModify('listing_grid/category')) {
$error = new AError('');
return $error->toJSONResponse('NO_PERMISSIONS_402',
array( 'error_text' => sprintf($this->language->get('error_permission_modify'), 'listing_grid/category'),
'reset_value' => true
) );
}
switch ($this->request->post['oper']) {
case 'del':
$ids = explode(',', $this->request->post['id']);
if ( !empty($ids) )
foreach( $ids as $id ) {
$this->model_catalog_category->deleteCategory($id);
}
break;
case 'save':
$allowedFields = array('category_description', 'sort_order', 'status',);
$ids = explode(',', $this->request->post['id']);
if ( !empty($ids) ) {
//resort required.
if( $this->request->post['resort'] == 'yes' ) {
//get only ids we need
foreach($ids as $id){
$array[$id] = $this->request->post['sort_order'][$id];
}
$new_sort = build_sort_order($ids, min($array), max($array), $this->request->post['sort_direction']);
$this->request->post['sort_order'] = $new_sort;
}
foreach( $ids as $id ) {
foreach ( $allowedFields as $field ) {
$this->model_catalog_category->editCategory($id, array($field => $this->request->post[$field][$id]) );
}
}
}
break;
default:
}
//update controller data
$this->extensions->hk_UpdateData($this,__FUNCTION__);
}
/**
* update only one field
*
* @return void
*/
public function update_field() {
//init controller data
$this->extensions->hk_InitData($this,__FUNCTION__);
$this->loadLanguage('catalog/category');
if (!$this->user->canModify('listing_grid/category')) {
$error = new AError('');
return $error->toJSONResponse('NO_PERMISSIONS_402',
array( 'error_text' => sprintf($this->language->get('error_permission_modify'), 'listing_grid/category'),
'reset_value' => true
) );
}
$this->loadModel('catalog/category');
if ( isset( $this->request->get['id'] ) ) {
//request sent from edit form. ID in url
foreach ($this->request->post as $field => $value ) {
if($field=='keyword'){
if($err = $this->html->isSEOkeywordExists('category_id='.$this->request->get['id'], $value)){
$error = new AError('');
return $error->toJSONResponse('VALIDATION_ERROR_406', array( 'error_text' => $err ));
}
}
$err = $this->_validateField($field, $value);
if (!empty($err)) {
$error = new AError('');
return $error->toJSONResponse('VALIDATION_ERROR_406', array( 'error_text' => $err ));
}
$this->model_catalog_category->editCategory($this->request->get['id'], array($field => $value) );
}
return null;
}
$language_id = $this->language->getContentLanguageID();
//request sent from jGrid. ID is key of array
foreach ($this->request->post as $field => $value ) {
foreach ( $value as $k => $v ) {
if($field=='category_description'){
if ( mb_strlen($v[$language_id]['name']) < 2 || mb_strlen($v[$language_id]['name']) > 32 ) {
$err = $this->language->get('error_name');
$error = new AError('');
return $error->toJSONResponse('VALIDATION_ERROR_406', array( 'error_text' => $err ));
}
}
$this->model_catalog_category->editCategory($k, array($field => $v) );
}
}
//update controller data
$this->extensions->hk_UpdateData($this,__FUNCTION__);
}
private function _validateField($field, $value) {
$err = '';
switch ($field) {
case 'category_description' :
$language_id = $this->language->getContentLanguageID();
if (isset($value[$language_id][ 'name' ]) && ( mb_strlen($value[$language_id][ 'name' ]) < 1 || mb_strlen($value[$language_id][ 'name' ]) > 255 )) {
$err = $this->language->get('error_name');
}
break;
case 'model' :
if ( mb_strlen($value) > 64 ) {
$err = $this->language->get('error_model');
}
break;
case 'keyword' :
$err = $this->html->isSEOkeywordExists('product_id='.$this->request->get['id'], $value);
break;
}
return $err;
}
public function categories() {
$output = array();
//init controller data
$this->extensions->hk_InitData($this, __FUNCTION__);
$this->loadModel('catalog/category');
if (isset($this->request->post['term'])) {
$filter = array('limit' => 20,
'language_id' => $this->language->getContentLanguageID(),
'subsql_filter' => "cd.name LIKE '%".$this->request->post['term']."%'
OR cd.description LIKE '%".$this->request->post['term']."%'
OR cd.meta_keywords LIKE '%".$this->request->post['term']."%'"
);
$results = $this->model_catalog_category->getCategoriesData($filter);
$resource = new AResource('image');
foreach ($results as $item) {
$thumbnail = $resource->getMainThumb('categories',
$item['category_id'],
(int)$this->config->get('config_image_grid_width'),
(int)$this->config->get('config_image_grid_height'),
true);
$output[ ] = array(
'image' => $icon = $thumbnail['thumb_html'] ? $thumbnail['thumb_html'] : ' ',
'id' => $item['category_id'],
'name' => $item['name'],
'meta' => '',
'sort_order' => (int)$item['sort_order'],
);
}
}
//update controller data
$this->extensions->hk_UpdateData($this, __FUNCTION__);
$this->load->library('json');
$this->response->addJSONHeader();
$this->response->setOutput(AJson::encode($output));
}
}