PageRenderTime 54ms CodeModel.GetById 23ms RepoModel.GetById 1ms app.codeStats 0ms

/admin/controller/catalog/attribute.php

https://gitlab.com/hazelnuts23/unitedfoodstuff
PHP | 432 lines | 316 code | 116 blank | 0 comment | 62 complexity | 9def78a6c49ff40bb97fdf8797e2b572 MD5 | raw file
  1. <?php
  2. class ControllerCatalogAttribute extends Controller {
  3. private $error = array();
  4. public function index() {
  5. $this->load->language('catalog/attribute');
  6. $this->document->setTitle($this->language->get('heading_title'));
  7. $this->load->model('catalog/attribute');
  8. $this->getList();
  9. }
  10. public function add() {
  11. $this->load->language('catalog/attribute');
  12. $this->document->setTitle($this->language->get('heading_title'));
  13. $this->load->model('catalog/attribute');
  14. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) {
  15. $this->model_catalog_attribute->addAttribute($this->request->post);
  16. $this->session->data['success'] = $this->language->get('text_success');
  17. $url = '';
  18. if (isset($this->request->get['sort'])) {
  19. $url .= '&sort=' . $this->request->get['sort'];
  20. }
  21. if (isset($this->request->get['order'])) {
  22. $url .= '&order=' . $this->request->get['order'];
  23. }
  24. if (isset($this->request->get['page'])) {
  25. $url .= '&page=' . $this->request->get['page'];
  26. }
  27. $this->response->redirect($this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  28. }
  29. $this->getForm();
  30. }
  31. public function edit() {
  32. $this->load->language('catalog/attribute');
  33. $this->document->setTitle($this->language->get('heading_title'));
  34. $this->load->model('catalog/attribute');
  35. if (($this->request->server['REQUEST_METHOD'] == 'POST') && $this->validateForm()) {
  36. $this->model_catalog_attribute->editAttribute($this->request->get['attribute_id'], $this->request->post);
  37. $this->session->data['success'] = $this->language->get('text_success');
  38. $url = '';
  39. if (isset($this->request->get['sort'])) {
  40. $url .= '&sort=' . $this->request->get['sort'];
  41. }
  42. if (isset($this->request->get['order'])) {
  43. $url .= '&order=' . $this->request->get['order'];
  44. }
  45. if (isset($this->request->get['page'])) {
  46. $url .= '&page=' . $this->request->get['page'];
  47. }
  48. $this->response->redirect($this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  49. }
  50. $this->getForm();
  51. }
  52. public function delete() {
  53. $this->load->language('catalog/attribute');
  54. $this->document->setTitle($this->language->get('heading_title'));
  55. $this->load->model('catalog/attribute');
  56. if (isset($this->request->post['selected']) && $this->validateDelete()) {
  57. foreach ($this->request->post['selected'] as $attribute_id) {
  58. $this->model_catalog_attribute->deleteAttribute($attribute_id);
  59. }
  60. $this->session->data['success'] = $this->language->get('text_success');
  61. $url = '';
  62. if (isset($this->request->get['sort'])) {
  63. $url .= '&sort=' . $this->request->get['sort'];
  64. }
  65. if (isset($this->request->get['order'])) {
  66. $url .= '&order=' . $this->request->get['order'];
  67. }
  68. if (isset($this->request->get['page'])) {
  69. $url .= '&page=' . $this->request->get['page'];
  70. }
  71. $this->response->redirect($this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . $url, 'SSL'));
  72. }
  73. $this->getList();
  74. }
  75. protected function getList() {
  76. if (isset($this->request->get['sort'])) {
  77. $sort = $this->request->get['sort'];
  78. } else {
  79. $sort = 'ad.name';
  80. }
  81. if (isset($this->request->get['order'])) {
  82. $order = $this->request->get['order'];
  83. } else {
  84. $order = 'ASC';
  85. }
  86. if (isset($this->request->get['page'])) {
  87. $page = $this->request->get['page'];
  88. } else {
  89. $page = 1;
  90. }
  91. $url = '';
  92. if (isset($this->request->get['sort'])) {
  93. $url .= '&sort=' . $this->request->get['sort'];
  94. }
  95. if (isset($this->request->get['order'])) {
  96. $url .= '&order=' . $this->request->get['order'];
  97. }
  98. if (isset($this->request->get['page'])) {
  99. $url .= '&page=' . $this->request->get['page'];
  100. }
  101. $data['breadcrumbs'] = array();
  102. $data['breadcrumbs'][] = array(
  103. 'text' => $this->language->get('text_home'),
  104. 'href' => $this->url->link('common/dashboard', 'token=' . $this->session->data['token'], 'SSL')
  105. );
  106. $data['breadcrumbs'][] = array(
  107. 'text' => $this->language->get('heading_title'),
  108. 'href' => $this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . $url, 'SSL')
  109. );
  110. $data['add'] = $this->url->link('catalog/attribute/add', 'token=' . $this->session->data['token'] . $url, 'SSL');
  111. $data['delete'] = $this->url->link('catalog/attribute/delete', 'token=' . $this->session->data['token'] . $url, 'SSL');
  112. $data['attributes'] = array();
  113. $filter_data = array(
  114. 'sort' => $sort,
  115. 'order' => $order,
  116. 'start' => ($page - 1) * $this->config->get('config_limit_admin'),
  117. 'limit' => $this->config->get('config_limit_admin')
  118. );
  119. $attribute_total = $this->model_catalog_attribute->getTotalAttributes();
  120. $results = $this->model_catalog_attribute->getAttributes($filter_data);
  121. foreach ($results as $result) {
  122. $data['attributes'][] = array(
  123. 'attribute_id' => $result['attribute_id'],
  124. 'name' => $result['name'],
  125. 'attribute_group' => $result['attribute_group'],
  126. 'sort_order' => $result['sort_order'],
  127. 'edit' => $this->url->link('catalog/attribute/edit', 'token=' . $this->session->data['token'] . '&attribute_id=' . $result['attribute_id'] . $url, 'SSL')
  128. );
  129. }
  130. $data['heading_title'] = $this->language->get('heading_title');
  131. $data['text_list'] = $this->language->get('text_list');
  132. $data['text_no_results'] = $this->language->get('text_no_results');
  133. $data['text_confirm'] = $this->language->get('text_confirm');
  134. $data['column_name'] = $this->language->get('column_name');
  135. $data['column_attribute_group'] = $this->language->get('column_attribute_group');
  136. $data['column_sort_order'] = $this->language->get('column_sort_order');
  137. $data['column_action'] = $this->language->get('column_action');
  138. $data['button_add'] = $this->language->get('button_add');
  139. $data['button_edit'] = $this->language->get('button_edit');
  140. $data['button_delete'] = $this->language->get('button_delete');
  141. if (isset($this->error['warning'])) {
  142. $data['error_warning'] = $this->error['warning'];
  143. } else {
  144. $data['error_warning'] = '';
  145. }
  146. if (isset($this->session->data['success'])) {
  147. $data['success'] = $this->session->data['success'];
  148. unset($this->session->data['success']);
  149. } else {
  150. $data['success'] = '';
  151. }
  152. if (isset($this->request->post['selected'])) {
  153. $data['selected'] = (array)$this->request->post['selected'];
  154. } else {
  155. $data['selected'] = array();
  156. }
  157. $url = '';
  158. if ($order == 'ASC') {
  159. $url .= '&order=DESC';
  160. } else {
  161. $url .= '&order=ASC';
  162. }
  163. if (isset($this->request->get['page'])) {
  164. $url .= '&page=' . $this->request->get['page'];
  165. }
  166. $data['sort_name'] = $this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . '&sort=ad.name' . $url, 'SSL');
  167. $data['sort_attribute_group'] = $this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . '&sort=attribute_group' . $url, 'SSL');
  168. $data['sort_sort_order'] = $this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . '&sort=a.sort_order' . $url, 'SSL');
  169. $url = '';
  170. if (isset($this->request->get['sort'])) {
  171. $url .= '&sort=' . $this->request->get['sort'];
  172. }
  173. if (isset($this->request->get['order'])) {
  174. $url .= '&order=' . $this->request->get['order'];
  175. }
  176. $pagination = new Pagination();
  177. $pagination->total = $attribute_total;
  178. $pagination->page = $page;
  179. $pagination->limit = $this->config->get('config_limit_admin');
  180. $pagination->url = $this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . $url . '&page={page}', 'SSL');
  181. $data['pagination'] = $pagination->render();
  182. $data['results'] = sprintf($this->language->get('text_pagination'), ($attribute_total) ? (($page - 1) * $this->config->get('config_limit_admin')) + 1 : 0, ((($page - 1) * $this->config->get('config_limit_admin')) > ($attribute_total - $this->config->get('config_limit_admin'))) ? $attribute_total : ((($page - 1) * $this->config->get('config_limit_admin')) + $this->config->get('config_limit_admin')), $attribute_total, ceil($attribute_total / $this->config->get('config_limit_admin')));
  183. $data['sort'] = $sort;
  184. $data['order'] = $order;
  185. $data['header'] = $this->load->controller('common/header');
  186. $data['column_left'] = $this->load->controller('common/column_left');
  187. $data['footer'] = $this->load->controller('common/footer');
  188. $this->response->setOutput($this->load->view('catalog/attribute_list.tpl', $data));
  189. }
  190. protected function getForm() {
  191. $data['heading_title'] = $this->language->get('heading_title');
  192. $data['text_form'] = !isset($this->request->get['attribute_id']) ? $this->language->get('text_add') : $this->language->get('text_edit');
  193. $data['entry_name'] = $this->language->get('entry_name');
  194. $data['entry_attribute_group'] = $this->language->get('entry_attribute_group');
  195. $data['entry_sort_order'] = $this->language->get('entry_sort_order');
  196. $data['button_save'] = $this->language->get('button_save');
  197. $data['button_cancel'] = $this->language->get('button_cancel');
  198. if (isset($this->error['warning'])) {
  199. $data['error_warning'] = $this->error['warning'];
  200. } else {
  201. $data['error_warning'] = '';
  202. }
  203. if (isset($this->error['name'])) {
  204. $data['error_name'] = $this->error['name'];
  205. } else {
  206. $data['error_name'] = array();
  207. }
  208. $url = '';
  209. if (isset($this->request->get['sort'])) {
  210. $url .= '&sort=' . $this->request->get['sort'];
  211. }
  212. if (isset($this->request->get['order'])) {
  213. $url .= '&order=' . $this->request->get['order'];
  214. }
  215. if (isset($this->request->get['page'])) {
  216. $url .= '&page=' . $this->request->get['page'];
  217. }
  218. $data['breadcrumbs'] = array();
  219. $data['breadcrumbs'][] = array(
  220. 'text' => $this->language->get('text_home'),
  221. 'href' => $this->url->link('common/dashboard', 'token=' . $this->session->data['token'], 'SSL')
  222. );
  223. $data['breadcrumbs'][] = array(
  224. 'text' => $this->language->get('heading_title'),
  225. 'href' => $this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . $url, 'SSL')
  226. );
  227. if (!isset($this->request->get['attribute_id'])) {
  228. $data['action'] = $this->url->link('catalog/attribute/add', 'token=' . $this->session->data['token'] . $url, 'SSL');
  229. } else {
  230. $data['action'] = $this->url->link('catalog/attribute/edit', 'token=' . $this->session->data['token'] . '&attribute_id=' . $this->request->get['attribute_id'] . $url, 'SSL');
  231. }
  232. $data['cancel'] = $this->url->link('catalog/attribute', 'token=' . $this->session->data['token'] . $url, 'SSL');
  233. if (isset($this->request->get['attribute_id']) && ($this->request->server['REQUEST_METHOD'] != 'POST')) {
  234. $attribute_info = $this->model_catalog_attribute->getAttribute($this->request->get['attribute_id']);
  235. }
  236. $this->load->model('localisation/language');
  237. $data['languages'] = $this->model_localisation_language->getLanguages();
  238. if (isset($this->request->post['attribute_description'])) {
  239. $data['attribute_description'] = $this->request->post['attribute_description'];
  240. } elseif (isset($this->request->get['attribute_id'])) {
  241. $data['attribute_description'] = $this->model_catalog_attribute->getAttributeDescriptions($this->request->get['attribute_id']);
  242. } else {
  243. $data['attribute_description'] = array();
  244. }
  245. if (isset($this->request->post['attribute_group_id'])) {
  246. $data['attribute_group_id'] = $this->request->post['attribute_group_id'];
  247. } elseif (!empty($attribute_info)) {
  248. $data['attribute_group_id'] = $attribute_info['attribute_group_id'];
  249. } else {
  250. $data['attribute_group_id'] = '';
  251. }
  252. $this->load->model('catalog/attribute_group');
  253. $data['attribute_groups'] = $this->model_catalog_attribute_group->getAttributeGroups();
  254. if (isset($this->request->post['sort_order'])) {
  255. $data['sort_order'] = $this->request->post['sort_order'];
  256. } elseif (!empty($attribute_info)) {
  257. $data['sort_order'] = $attribute_info['sort_order'];
  258. } else {
  259. $data['sort_order'] = '';
  260. }
  261. $data['header'] = $this->load->controller('common/header');
  262. $data['column_left'] = $this->load->controller('common/column_left');
  263. $data['footer'] = $this->load->controller('common/footer');
  264. $this->response->setOutput($this->load->view('catalog/attribute_form.tpl', $data));
  265. }
  266. protected function validateForm() {
  267. if (!$this->user->hasPermission('modify', 'catalog/attribute')) {
  268. $this->error['warning'] = $this->language->get('error_permission');
  269. }
  270. foreach ($this->request->post['attribute_description'] as $language_id => $value) {
  271. if ((utf8_strlen($value['name']) < 3) || (utf8_strlen($value['name']) > 64)) {
  272. $this->error['name'][$language_id] = $this->language->get('error_name');
  273. }
  274. }
  275. return !$this->error;
  276. }
  277. protected function validateDelete() {
  278. if (!$this->user->hasPermission('modify', 'catalog/attribute')) {
  279. $this->error['warning'] = $this->language->get('error_permission');
  280. }
  281. $this->load->model('catalog/product');
  282. foreach ($this->request->post['selected'] as $attribute_id) {
  283. $product_total = $this->model_catalog_product->getTotalProductsByAttributeId($attribute_id);
  284. if ($product_total) {
  285. $this->error['warning'] = sprintf($this->language->get('error_product'), $product_total);
  286. }
  287. }
  288. return !$this->error;
  289. }
  290. public function autocomplete() {
  291. $json = array();
  292. if (isset($this->request->get['filter_name'])) {
  293. $this->load->model('catalog/attribute');
  294. $filter_data = array(
  295. 'filter_name' => $this->request->get['filter_name'],
  296. 'start' => 0,
  297. 'limit' => 5
  298. );
  299. $results = $this->model_catalog_attribute->getAttributes($filter_data);
  300. foreach ($results as $result) {
  301. $json[] = array(
  302. 'attribute_id' => $result['attribute_id'],
  303. 'name' => strip_tags(html_entity_decode($result['name'], ENT_QUOTES, 'UTF-8')),
  304. 'attribute_group' => $result['attribute_group']
  305. );
  306. }
  307. }
  308. $sort_order = array();
  309. foreach ($json as $key => $value) {
  310. $sort_order[$key] = $value['name'];
  311. }
  312. array_multisort($sort_order, SORT_ASC, $json);
  313. $this->response->addHeader('Content-Type: application/json');
  314. $this->response->setOutput(json_encode($json));
  315. }
  316. }