} switch ($emanager->getAction()) { case $emanager->action->UPD: $item = json_decode($emanager->getItem()); $BILL->UpdateUrlCategoryMatch($item->u2cid, $item->url, $item->cid); break; case $emanager->action->DEL: $item = json_decode($emanager->getItem()); $BILL->DeleteUrlCategoryMatch($item->u2cid); break; case $emanager->action->ADD: $item = json_decode($emanager->getItem()); $BILL->AddUrlCategoryMatch($item->url, $item->cid); break; } $emanager->eraseAction(); } /** * Retrieve urls matchescategories from the database */ $url_cats = $BILL->GetUrlCategoriesMatch($url_cats_unmatched_grid_pager->get_curpage(), 10, $url_cats_unmatched_grid->get_sorting(), $url_cats_unmatched_grid->get_sort_direction(), array(0), array(), $url_cats_unmatched_grid->get_filterfield(), $url_cats_unmatched_grid->get_filtering()); foreach ($url_cats as $cat) { $url_cats_unmatched_ds->add_row(array($cat['u2cid'], $cat['url'], $cat['cid'], $cat)); } /** * Retrieve categories from the database */ $url_cats = $BILL->GetUrlCategoriesMatch($url_cats_matched_grid_pager->get_curpage(), 10, $url_cats_matched_grid->get_sorting(), $url_cats_matched_grid->get_sort_direction(), array(), array(0), $url_cats_matched_grid->get_filterfield(), $url_cats_matched_grid->get_filtering()); foreach ($url_cats as $cat) { $url_cats_matched_ds->add_row(array($cat['u2cid'], $cat['url'], $cat['cid'], $cat)); }
class conflicts_act_formatter extends grid_formatter { public function format($data, $type, $number = 0, $columns = null) { return '<input type="checkbox" name="selected_kwds[' . $data['keyword'] . '][]" />'; } } class conflicts_cat_formatter extends grid_formatter { protected $_cats = null; public function __construct($cats) { $this->_cats = $cats; } public function format($data, $type, $number = 0, $columns = null) { return !empty($this->_cats[$data]['title_ru']) ? $this->_cats[$data]['title_ru'] : $this->_cats[$data]['title']; } } $ajaxbuffer = new ajax_buffer("update_buffer"); $datasource = new grid_data_source(new grid_header_item_array(new grid_header_item('id', '', null, false, new conflicts_act_formatter()), new grid_header_item('url', 'URL', type::LINK_NEWWIN, true, null, true, true), new grid_header_item('keyword', 'Слово', type::STRING, true, null, true, true), new grid_header_item('forcid', 'Категория', type::STRING, true, new conflicts_cat_formatter($cats)), new grid_header_item('incid', 'Конфликт с', type::STRING, true, new conflicts_cat_formatter($cats)), new grid_header_item('date', 'Дата', type::STRING, true))); $grid = new ajax_grid('grid', $datasource, $ajaxbuffer); $grid->no_data_message = 'Нет записей'; $grid->render_pager_top(true); $grid->render_filter_bottom(true); $grid_pager = new ajax_grid_pager('grid_pager', $BILL->GetRowsCount('url_categories_conflicts', $grid->get_filterfield(), $grid->get_filtering()), COUNT_ON_PAGE); $grid->attach_pager($grid_pager); $conflicts = $BILL->GetUrlCategoriesConflicts($grid_pager->get_curpage(), $grid_pager->get_pagesize(), $grid->get_sorting(), $grid->get_sort_direction(), $grid->get_filterfield(), $grid->get_filtering()); foreach ($conflicts as $conflict) { $datasource->add_row(array($conflict, $conflict['url'], $conflict['keyword'], $conflict['forcid'], $conflict['incid'], $conflict['date'])); }
break; case $emanager->action->UPD: $item = json_decode($emanager->getItem()); $item->keywords = explode(',', $item->keywords); for ($i = 0; $i < count($item->keywords); ++$i) { $item->keywords[$i] = rtrim(ltrim($item->keywords[$i])); if (strlen($item->keywords[$i]) < 4 || empty($item->keywords[$i])) { array_splice($item->keywords, $i, 1); $i = 0; } } $BILL->UpdateUrlCategoryKeywords($item->cid, $item->keywords); $BILL->UpdateUrlCategory($item->cid, array('title' => $item->title, 'title_ru' => $item->title_ru)); break; case $emanager->action->DEL: $item = json_decode($emanager->getItem()); if ($item->cid > 0) { $BILL->DeleteUrlCategory($item->cid); } break; } $emanager->eraseAction(); } /** * Retrieve categories from the database */ $cats = $BILL->GetUrlCategories($cats_grid_pager->get_curpage(), $cats_grid_pager->get_pagesize(), $cats_grid->get_sorting(), $cats_grid->get_sort_direction(), $cats_grid->get_filterfield(), $cats_grid->get_filtering()); foreach ($cats as $cat) { $cat['keywords'] = implode(", ", $BILL->GetUrlCategoryKeywords($cat['cid'])); $cats_ds->add_row(array($cat['cid'], $cat['title'], $cat['title_ru'], $cat)); }