diff --git a/ci4/app/Config/Routes.php b/ci4/app/Config/Routes.php index 58388208..b35b2887 100644 --- a/ci4/app/Config/Routes.php +++ b/ci4/app/Config/Routes.php @@ -65,17 +65,18 @@ $routes->group('paises', ['namespace' => 'App\Controllers\Configuracion'], funct }); $routes->group('tarifaacabado', ['namespace' => 'App\Controllers\Tarifas'], function ($routes) { - $routes->get('', 'Tarifaacabado::index', ['as' => 'tarifaacabadoList']); - $routes->get('index', 'Tarifaacabado::index', ['as' => 'tarifaacabadoIndex']); - $routes->get('list', 'Tarifaacabado::index', ['as' => 'tarifaacabadoList2']); - $routes->get('add', 'Tarifaacabado::add', ['as' => 'newTarifaacabado']); - $routes->post('add', 'Tarifaacabado::add', ['as' => 'createTarifaacabado']); - $routes->get('edit/(:num)', 'Tarifaacabado::edit/$1', ['as' => 'editTarifaacabado']); - $routes->post('edit/(:num)', 'Tarifaacabado::edit/$1', ['as' => 'updateTarifaacabado']); - $routes->get('delete/(:num)', 'Tarifaacabado::delete/$1', ['as' => 'deleteTarifaacabado']); - $routes->post('allmenuitems', 'Tarifaacabado::allItemsSelect', ['as' => 'select2ItemsOfTarifasacabado']); - $routes->post('menuitems', 'Tarifaacabado::menuItems', ['as' => 'menuItemsOfTarifasacabado']); + $routes->get('', 'Tarifaacabado::index', ['as' => 'tarifaAcabadoList']); + $routes->get('add', 'Tarifaacabado::add', ['as' => 'newTarifaAcabado']); + $routes->post('add', 'Tarifaacabado::add', ['as' => 'createTarifaAcabado']); + $routes->post('create', 'Tarifaacabado::create', ['as' => 'ajaxCreateTarifaAcabado']); + $routes->put('(:num)/update', 'Tarifaacabado::update/$1', ['as' => 'ajaxUpdateTarifaAcabado']); + $routes->post('(:num)/edit', 'Tarifaacabado::edit/$1', ['as' => 'updateTarifaAcabado']); + $routes->post('datatable', 'Tarifaacabado::datatable', ['as' => 'dataTableOfTarifasAcabado']); + $routes->post('allmenuitems', 'Tarifaacabado::allItemsSelect', ['as' => 'select2ItemsOfTarifasAcabado']); + $routes->post('menuitems', 'Tarifaacabado::menuItems', ['as' => 'menuItemsOfTarifasAcabado']); }); +$routes->resource('tarifaacabado', ['namespace' => 'App\Controllers\Tarifas', 'controller' => 'Tarifaacabado', 'except' => 'show,new,create,update']); + $routes->group('users', ['namespace' => 'App\Controllers\Configuracion'], function ($routes) { $routes->get('', 'Users::index', ['as' => 'userList']); diff --git a/ci4/app/Controllers/Tarifas/Tarifaacabado.php b/ci4/app/Controllers/Tarifas/Tarifaacabado.php index 52713db3..bc0d7224 100644 --- a/ci4/app/Controllers/Tarifas/Tarifaacabado.php +++ b/ci4/app/Controllers/Tarifas/Tarifaacabado.php @@ -1,46 +1,58 @@ -viewData['pageTitle'] = lang('Tarifaacabado.moduleTitle'); - // Se indica que este controlador trabaja con soft_delete - $this->soft_delete = true; - // Se indica el flag para los ficheros borrados - $this->delete_flag = 1; + $this->viewData['usingSweetAlert'] = true; parent::initController($request, $response, $logger); - } + public function index() { - $this->viewData['usingClientSideDataTable'] = true; - - $this->viewData['pageSubTitle'] = lang('Basic.global.ManageAllRecords', [lang('Tarifaacabado.tarifaacabado')]); - parent::index(); + $viewData = [ + 'currentModule' => static::$controllerSlug, + 'pageSubTitle' => lang('Basic.global.ManageAllRecords', [lang('Tarifaacabado.tarifaacabado')]), + 'tarifaacabadoEntity' => new TarifaacabadoEntity(), + 'usingServerSideDataTable' => true, + + ]; + $viewData = array_merge($this->viewData, $viewData); // merge any possible values from the parent controller class + + return view(static::$viewPath.'viewTarifaAcabadoList', $viewData); } + public function add() { - $session = session(); + $requestMethod = $this->request->getMethod(); @@ -49,13 +61,13 @@ class Tarifaacabado extends \App\Controllers\GoBaseController { $nullIfEmpty = true; // !(phpversion() >= '8.1'); $postData = $this->request->getPost(); - $sanitizedData = $this->sanitized($postData, $nullIfEmpty); - $sanitizedData['user_created_id'] = $session->id_user; - $sanitizedData['user_update_id'] = $session->id_user; + + $sanitizedData = $this->sanitized($postData, $nullIfEmpty); + $noException = true; if ($successfulResult = $this->canValidate()) : // if ($successfulResult = $this->validate($this->formValidationRules) ) : - + if ($this->canValidate()) : try { @@ -76,47 +88,44 @@ class Tarifaacabado extends \App\Controllers\GoBaseController { $id = $this->model->db->insertID(); $message = lang('Basic.global.saveSuccess', [mb_strtolower(lang('Tarifaacabado.tarifaacabado'))]).'.'; - $message .= anchor(route_to('editTarifaacabado', $id), lang('Basic.global.continueEditing').'?'); + $message .= anchor( "tarifasacabado/{$id}/edit" , lang('Basic.global.continueEditing').'?'); $message = ucfirst(str_replace("'", "\'", $message)); if ($thenRedirect) : if (!empty($this->indexRoute)) : - return redirect()->to(route_to($this->indexRoute))->with('successMessage', $message); + return redirect()->to(route_to($this->indexRoute))->with('sweet-success', $message); else: - return $this->redirect2listView('successMessage', $message); + return $this->redirect2listView('sweet-success', $message); endif; else: - $this->viewData['successMessage'] = $message; + $this->session->setFlashData('sweet-success', $message); endif; endif; // $noException && $successfulResult endif; // ($requestMethod === 'post') - $this->viewData['tarifaacabado_'] = isset($sanitizedData) ? new TarifaacabadoEntity($sanitizedData) : new TarifaacabadoEntity(); + $this->viewData['tarifaacabadoEntity'] = isset($sanitizedData) ? new TarifaacabadoEntity($sanitizedData) : new TarifaacabadoEntity(); - $this->viewData['formAction'] = route_to('createTarifaacabado'); + $this->viewData['formAction'] = route_to('createTarifaAcabado'); - $this->viewData['boxTitle'] = lang('Basic.global.addNew').' '.lang('Tarifaacabado.tarifaacabado').' '.lang('Basic.global.addNewSuffix'); + $this->viewData['boxTitle'] = lang('Basic.global.addNew').' '.lang('Tarifaacabado.moduleTitle').' '.lang('Basic.global.addNewSuffix'); return $this->displayForm(__METHOD__); } // end function add() public function edit($requestedId = null) { - - // JJO - $session = session(); if ($requestedId == null) : return $this->redirect2listView(); endif; $id = filter_var($requestedId, FILTER_SANITIZE_URL); - $tarifaacabado_ = $this->model->find($id); + $tarifaacabadoEntity = $this->model->find($id); - if ($tarifaacabado_ == false) : + if ($tarifaacabadoEntity == false) : $message = lang('Basic.global.notFoundWithIdErr', [mb_strtolower(lang('Tarifaacabado.tarifaacabado')), $id]); - return $this->redirect2listView('errorMessage', $message); + return $this->redirect2listView('sweet-error', $message); endif; $requestMethod = $this->request->getMethod(); @@ -126,13 +135,10 @@ class Tarifaacabado extends \App\Controllers\GoBaseController { $nullIfEmpty = true; // !(phpversion() >= '8.1'); $postData = $this->request->getPost(); - $sanitizedData = $this->sanitized($postData, $nullIfEmpty); - - // JJO - if(isset($this->model->user_update_id)){ - $sanitizedData['user_update_id'] = $session->id_user; - } + $sanitizedData = $this->sanitized($postData, $nullIfEmpty); + + $noException = true; if ($successfulResult = $this->canValidate()) : // if ($successfulResult = $this->validate($this->formValidationRules) ) : @@ -152,49 +158,76 @@ class Tarifaacabado extends \App\Controllers\GoBaseController { endif; - $tarifaacabado_->fill($sanitizedData); + $tarifaacabadoEntity->fill($sanitizedData); $thenRedirect = true; endif; if ($noException && $successfulResult) : - $id = $tarifaacabado_->id ?? $id; + $id = $tarifaacabadoEntity->id ?? $id; $message = lang('Basic.global.updateSuccess', [mb_strtolower(lang('Tarifaacabado.tarifaacabado'))]).'.'; - $message .= anchor(route_to('editTarifaacabado', $id), lang('Basic.global.continueEditing').'?'); + $message .= anchor( "tarifasacabado/{$id}/edit" , lang('Basic.global.continueEditing').'?'); $message = ucfirst(str_replace("'", "\'", $message)); if ($thenRedirect) : if (!empty($this->indexRoute)) : - return redirect()->to(route_to($this->indexRoute))->with('successMessage', $message); + return redirect()->to(route_to($this->indexRoute))->with('sweet-success', $message); else: - return $this->redirect2listView('successMessage', $message); + return $this->redirect2listView('sweet-success', $message); endif; else: - $this->viewData['successMessage'] = $message; + $this->session->setFlashData('sweet-success', $message); endif; endif; // $noException && $successfulResult endif; // ($requestMethod === 'post') - $this->viewData['tarifaacabado_'] = $tarifaacabado_; + $this->viewData['tarifaacabadoEntity'] = $tarifaacabadoEntity; - $this->viewData['formAction'] = route_to('updateTarifaacabado', $id); + $this->viewData['formAction'] = route_to('updateTarifaAcabado', $id); - $this->viewData['boxTitle'] = lang('Basic.global.edit2').' '.lang('Tarifaacabado.tarifaacabado').' '.lang('Basic.global.edit3'); + $this->viewData['boxTitle'] = lang('Basic.global.edit2').' '.lang('Tarifaacabado.moduleTitle').' '.lang('Basic.global.edit3'); return $this->displayForm(__METHOD__, $id); } // end function edit(...) - + + + public function datatable() { + if ($this->request->isAJAX()) { + $reqData = $this->request->getPost(); + if (!isset($reqData['draw']) || !isset($reqData['columns']) ) { + $errstr = 'No data available in response to this specific request.'; + $response = $this->respond(Collection::datatable( [], 0, 0, $errstr ), 400, $errstr); + return $response; + } + $start = $reqData['start'] ?? 0; + $length = $reqData['length'] ?? 5; + $search = $reqData['search']['value']; + $requestedOrder = $reqData['order']['0']['column'] ?? 1; + $order = TarifaacabadoModel::SORTABLE[$requestedOrder >= 0 ? $requestedOrder : 1]; + $dir = $reqData['order']['0']['dir'] ?? 'asc'; + + $resourceData = $this->model->getResource($search)->orderBy($order, $dir)->limit($length, $start)->get()->getResultObject(); + + return $this->respond(Collection::datatable( + $resourceData, + $this->model->getResource()->countAllResults(), + $this->model->getResource($search)->countAllResults() + )); + } else { + return $this->failUnauthorized('Invalid request', 403); + } + } public function allItemsSelect() { if ($this->request->isAJAX()) { $onlyActiveOnes = true; $reqVal = $this->request->getPost('val') ?? 'id'; - $menu = $this->model->getAllForMenu($reqVal.', Select a field...', 'Select a field...', $onlyActiveOnes, false); + $menu = $this->model->getAllForMenu($reqVal.', nombre', 'nombre', $onlyActiveOnes, false); $nonItem = new \stdClass; $nonItem->id = ''; - $nonItem->Selectafield = '- '.lang('Basic.global.None').' -'; + $nonItem->nombre = '- '.lang('Basic.global.None').' -'; array_unshift($menu , $nonItem); $newTokenHash = csrf_hash(); @@ -208,14 +241,14 @@ class Tarifaacabado extends \App\Controllers\GoBaseController { return $this->failUnauthorized('Invalid request', 403); } } - + public function menuItems() { if ($this->request->isAJAX()) { $searchStr = goSanitize($this->request->getPost('searchTerm'))[0]; $reqId = goSanitize($this->request->getPost('id'))[0]; $reqText = goSanitize($this->request->getPost('text'))[0]; $onlyActiveOnes = false; - $columns2select = [$reqId ?? 'id', $reqText ?? 'Select a field...']; + $columns2select = [$reqId ?? 'id', $reqText ?? 'nombre']; $onlyActiveOnes = false; $menu = $this->model->getSelect2MenuItems($columns2select, $columns2select[1], $onlyActiveOnes, $searchStr); $nonItem = new \stdClass; @@ -233,5 +266,6 @@ class Tarifaacabado extends \App\Controllers\GoBaseController { } else { return $this->failUnauthorized('Invalid request', 403); } - } + } + } diff --git a/ci4/app/Controllers/Tarifas/Tarifaacabadolineas.php b/ci4/app/Controllers/Tarifas/Tarifaacabadolineas.php new file mode 100644 index 00000000..59f175ad --- /dev/null +++ b/ci4/app/Controllers/Tarifas/Tarifaacabadolineas.php @@ -0,0 +1,289 @@ +viewData['pageTitle'] = lang('TarifaAcabadoLineas.moduleTitle'); + $this->viewData['usingSweetAlert'] = true; + parent::initController($request, $response, $logger); + } + + + public function index() { + + $viewData = [ + 'currentModule' => static::$controllerSlug, + 'pageSubTitle' => lang('Basic.global.ManageAllRecords', [lang('TarifaAcabadoLineas.tarifaAcabadoLinea')]), + 'tarifaAcabadoLinea' => new TarifaAcabadoLinea(), + 'usingServerSideDataTable' => true, + + ]; + + $viewData = array_merge($this->viewData, $viewData); // merge any possible values from the parent controller class + + return view(static::$viewPath.'viewTarifaAcabadoLineaList', $viewData); + } + + + public function add() { + + + + $requestMethod = $this->request->getMethod(); + + if ($requestMethod === 'post') : + + $nullIfEmpty = true; // !(phpversion() >= '8.1'); + + $postData = $this->request->getPost(); + + $sanitizedData = $this->sanitized($postData, $nullIfEmpty); + + + $noException = true; + if ($successfulResult = $this->canValidate()) : // if ($successfulResult = $this->validate($this->formValidationRules) ) : + + + if ($this->canValidate()) : + try { + $successfulResult = $this->model->skipValidation(true)->save($sanitizedData); + } catch (\Exception $e) { + $noException = false; + $this->dealWithException($e); + } + else: + $this->viewData['errorMessage'] = lang('Basic.global.formErr1', [mb_strtolower(lang('TarifaAcabadoLineas.tarifaAcabadoLinea'))]); + $this->session->setFlashdata('formErrors', $this->model->errors()); + endif; + + $thenRedirect = true; // Change this to false if you want your user to stay on the form after submission + endif; + if ($noException && $successfulResult) : + + $id = $this->model->db->insertID(); + + $message = lang('Basic.global.saveSuccess', [mb_strtolower(lang('TarifaAcabadoLineas.tarifaAcabadoLinea'))]).'.'; + $message .= anchor( "tarifa-acabado-lineas/{$id}/edit" , lang('Basic.global.continueEditing').'?'); + $message = ucfirst(str_replace("'", "\'", $message)); + + if ($thenRedirect) : + if (!empty($this->indexRoute)) : + return redirect()->to(route_to($this->indexRoute))->with('sweet-success', $message); + else: + return $this->redirect2listView('sweet-success', $message); + endif; + else: + $this->session->setFlashData('sweet-success', $message); + endif; + + endif; // $noException && $successfulResult + + endif; // ($requestMethod === 'post') + + $this->viewData['tarifaAcabadoLinea'] = isset($sanitizedData) ? new TarifaAcabadoLinea($sanitizedData) : new TarifaAcabadoLinea(); + $this->viewData['tarifaAcabadoList'] = $this->getTarifaAcabadoListItems($tarifaAcabadoLinea->tarifa_acabado_id ?? null); + + $this->viewData['formAction'] = route_to('createTarifaAcabadoLinea'); + + $this->viewData['boxTitle'] = lang('Basic.global.addNew').' '.lang('TarifaAcabadoLineas.moduleTitle').' '.lang('Basic.global.addNewSuffix'); + + + return $this->displayForm(__METHOD__); + } // end function add() + + public function edit($requestedId = null) { + + if ($requestedId == null) : + return $this->redirect2listView(); + endif; + $id = filter_var($requestedId, FILTER_SANITIZE_URL); + $tarifaAcabadoLinea = $this->model->find($id); + + if ($tarifaAcabadoLinea == false) : + $message = lang('Basic.global.notFoundWithIdErr', [mb_strtolower(lang('TarifaAcabadoLineas.tarifaAcabadoLinea')), $id]); + return $this->redirect2listView('sweet-error', $message); + endif; + + $requestMethod = $this->request->getMethod(); + + if ($requestMethod === 'post') : + + $nullIfEmpty = true; // !(phpversion() >= '8.1'); + + $postData = $this->request->getPost(); + + $sanitizedData = $this->sanitized($postData, $nullIfEmpty); + + + + $noException = true; + if ($successfulResult = $this->canValidate()) : // if ($successfulResult = $this->validate($this->formValidationRules) ) : + + + + if ($this->canValidate()) : + try { + $successfulResult = $this->model->skipValidation(true)->update($id, $sanitizedData); + } catch (\Exception $e) { + $noException = false; + $this->dealWithException($e); + } + else: + $this->viewData['warningMessage'] = lang('Basic.global.formErr1', [mb_strtolower(lang('TarifaAcabadoLineas.tarifaAcabadoLinea'))]); + $this->session->setFlashdata('formErrors', $this->model->errors()); + + endif; + + $tarifaAcabadoLinea->fill($sanitizedData); + + $thenRedirect = true; + endif; + if ($noException && $successfulResult) : + $id = $tarifaAcabadoLinea->id ?? $id; + $message = lang('Basic.global.updateSuccess', [mb_strtolower(lang('TarifaAcabadoLineas.tarifaAcabadoLinea'))]).'.'; + $message .= anchor( "tarifa-acabado-lineas/{$id}/edit" , lang('Basic.global.continueEditing').'?'); + $message = ucfirst(str_replace("'", "\'", $message)); + + if ($thenRedirect) : + if (!empty($this->indexRoute)) : + return redirect()->to(route_to($this->indexRoute))->with('sweet-success', $message); + else: + return $this->redirect2listView('sweet-success', $message); + endif; + else: + $this->session->setFlashData('sweet-success', $message); + endif; + + endif; // $noException && $successfulResult + endif; // ($requestMethod === 'post') + + $this->viewData['tarifaAcabadoLinea'] = $tarifaAcabadoLinea; + $this->viewData['tarifaAcabadoList'] = $this->getTarifaAcabadoListItems($tarifaAcabadoLinea->tarifa_acabado_id ?? null); + + $this->viewData['formAction'] = route_to('updateTarifaAcabadoLinea', $id); + + $this->viewData['boxTitle'] = lang('Basic.global.edit2').' '.lang('TarifaAcabadoLineas.moduleTitle').' '.lang('Basic.global.edit3'); + + + return $this->displayForm(__METHOD__, $id); + } // end function edit(...) + + + + public function datatable() { + if ($this->request->isAJAX()) { + $reqData = $this->request->getPost(); + if (!isset($reqData['draw']) || !isset($reqData['columns']) ) { + $errstr = 'No data available in response to this specific request.'; + $response = $this->respond(Collection::datatable( [], 0, 0, $errstr ), 400, $errstr); + return $response; + } + $start = $reqData['start'] ?? 0; + $length = $reqData['length'] ?? 5; + $search = $reqData['search']['value']; + $requestedOrder = $reqData['order']['0']['column'] ?? 1; + $order = TarifaAcabadoLineaModel::SORTABLE[$requestedOrder > 0 ? $requestedOrder : 1]; + $dir = $reqData['order']['0']['dir'] ?? 'asc'; + + $resourceData = $this->model->getResource($search)->orderBy($order, $dir)->limit($length, $start)->get()->getResultObject(); + + return $this->respond(Collection::datatable( + $resourceData, + $this->model->getResource()->countAllResults(), + $this->model->getResource($search)->countAllResults() + )); + } else { + return $this->failUnauthorized('Invalid request', 403); + } + } + + public function allItemsSelect() { + if ($this->request->isAJAX()) { + $onlyActiveOnes = true; + $reqVal = $this->request->getPost('val') ?? 'id'; + $menu = $this->model->getAllForMenu($reqVal.', tarifa_acabado_id', 'tarifa_acabado_id', $onlyActiveOnes, false); + $nonItem = new \stdClass; + $nonItem->id = ''; + $nonItem->tarifa_acabado_id = '- '.lang('Basic.global.None').' -'; + array_unshift($menu , $nonItem); + + $newTokenHash = csrf_hash(); + $csrfTokenName = csrf_token(); + $data = [ + 'menu' => $menu, + $csrfTokenName => $newTokenHash + ]; + return $this->respond($data); + } else { + return $this->failUnauthorized('Invalid request', 403); + } + } + + public function menuItems() { + if ($this->request->isAJAX()) { + $searchStr = goSanitize($this->request->getPost('searchTerm'))[0]; + $reqId = goSanitize($this->request->getPost('id'))[0]; + $reqText = goSanitize($this->request->getPost('text'))[0]; + $onlyActiveOnes = false; + $columns2select = [$reqId ?? 'id', $reqText ?? 'tarifa_acabado_id']; + $onlyActiveOnes = false; + $menu = $this->model->getSelect2MenuItems($columns2select, $columns2select[1], $onlyActiveOnes, $searchStr); + $nonItem = new \stdClass; + $nonItem->id = ''; + $nonItem->text = '- '.lang('Basic.global.None').' -'; + array_unshift($menu , $nonItem); + + $newTokenHash = csrf_hash(); + $csrfTokenName = csrf_token(); + $data = [ + 'menu' => $menu, + $csrfTokenName => $newTokenHash + ]; + return $this->respond($data); + } else { + return $this->failUnauthorized('Invalid request', 403); + } + } + + + protected function getTarifaAcabadoListItems($selId = null) { + $data = [''=>lang('Basic.global.pleaseSelectA', [mb_strtolower(lang('Tarifaacabado.tarifaAcabado'))])]; + if (!empty($selId)) : + $tarifaacabadoModel = model('App\Models\tarifas\TarifaacabadoModel'); + + $selOption = $tarifaacabadoModel->where('id', $selId)->findColumn('id'); + if (!empty($selOption)) : + $data[$selId] = $selOption[0]; + endif; + endif; + return $data; + } + +} diff --git a/ci4/app/Entities/Tarifas/TarifaAcabadoLinea.php b/ci4/app/Entities/Tarifas/TarifaAcabadoLinea.php new file mode 100644 index 00000000..7a8dbf13 --- /dev/null +++ b/ci4/app/Entities/Tarifas/TarifaAcabadoLinea.php @@ -0,0 +1,33 @@ + null, + "tarifa_acabado_id" => 0, + "tirada_min" => 0, + "tirada_max" => 0, + "precio_min" => 0, + "precio_max" => 0, + "precio_unidad" => 0, + "user_created_id" => 0, + "user_updated_id" => 0, + "is_deleted" => 0, + "created_at" => null, + "updated_at" => null, + ]; + protected $casts = [ + "tarifa_acabado_id" => "int", + "tirada_min" => "int", + "tirada_max" => "int", + "precio_min" => "float", + "precio_max" => "float", + "precio_unidad" => "float", + "user_created_id" => "int", + "user_updated_id" => "int", + "is_deleted" => "int", + ]; +} diff --git a/ci4/app/Entities/Tarifas/TarifaacabadoEntity.php b/ci4/app/Entities/Tarifas/TarifaacabadoEntity.php index 93e46dbc..0ad59298 100644 --- a/ci4/app/Entities/Tarifas/TarifaacabadoEntity.php +++ b/ci4/app/Entities/Tarifas/TarifaacabadoEntity.php @@ -1,33 +1,22 @@ null, "nombre" => null, - "tirada_min" => 0, - "precio_min" => 0, - "tirada_max" => 0, - "precio_max" => null, - "ajuste" => 0, - "formula_price" => null, "user_created_id" => 1, "user_update_id" => 1, - "deleted_at" => null, "is_deleted" => 0, "created_at" => null, "updated_at" => null, ]; protected $casts = [ - "tirada_min" => "int", - "precio_min" => "float", - "tirada_max" => "int", - "precio_max" => "float", - "ajuste" => "float", "user_created_id" => "int", "user_update_id" => "int", + "is_deleted" => "int", ]; } diff --git a/ci4/app/Models/Tarifas/TarifaAcabadoLineaModel.php b/ci4/app/Models/Tarifas/TarifaAcabadoLineaModel.php new file mode 100644 index 00000000..09b9fb44 --- /dev/null +++ b/ci4/app/Models/Tarifas/TarifaAcabadoLineaModel.php @@ -0,0 +1,176 @@ + "t1.tirada_min", + 2 => "t1.tirada_max", + 3 => "t1.precio_min", + 4 => "t1.precio_max", + 5 => "t1.precio_unidad", + 6 => "t1.user_created_id", + 7 => "t1.user_updated_id", + 8 => "t1.is_deleted", + 9 => "t1.created_at", + 10 => "t1.updated_at", + 11 => "t2.id", + ]; + + protected $allowedFields = [ + "tirada_min", + "tirada_max", + "precio_min", + "precio_max", + "precio_unidad", + "user_created_id", + "is_deleted", + ]; + protected $returnType = "App\Entities\Tarifas\TarifaAcabadoLinea"; + + protected $useTimestamps = true; + protected $useSoftDeletes = false; + + protected $createdField = "created_at"; + + protected $updatedField = "updated_at"; + + public static $labelField = "tarifa_acabado_id"; + + protected $validationRules = [ + "is_deleted" => [ + "label" => "TarifaAcabadoLineas.isDeleted", + "rules" => "required|integer", + ], + "precio_max" => [ + "label" => "TarifaAcabadoLineas.precioMax", + "rules" => "required|decimal", + ], + "precio_min" => [ + "label" => "TarifaAcabadoLineas.precioMin", + "rules" => "required|decimal", + ], + "precio_unidad" => [ + "label" => "TarifaAcabadoLineas.precioUnidad", + "rules" => "required|decimal", + ], + "tirada_max" => [ + "label" => "TarifaAcabadoLineas.tiradaMax", + "rules" => "required|integer", + ], + "tirada_min" => [ + "label" => "TarifaAcabadoLineas.tiradaMin", + "rules" => "required|integer", + ], + "user_created_id" => [ + "label" => "TarifaAcabadoLineas.userCreatedId", + "rules" => "required|integer", + ], + ]; + + protected $validationMessages = [ + "is_deleted" => [ + "integer" => "TarifaAcabadoLineas.validation.is_deleted.integer", + "required" => "TarifaAcabadoLineas.validation.is_deleted.required", + ], + "precio_max" => [ + "decimal" => "TarifaAcabadoLineas.validation.precio_max.decimal", + "required" => "TarifaAcabadoLineas.validation.precio_max.required", + ], + "precio_min" => [ + "decimal" => "TarifaAcabadoLineas.validation.precio_min.decimal", + "required" => "TarifaAcabadoLineas.validation.precio_min.required", + ], + "precio_unidad" => [ + "decimal" => "TarifaAcabadoLineas.validation.precio_unidad.decimal", + "required" => "TarifaAcabadoLineas.validation.precio_unidad.required", + ], + "tirada_max" => [ + "integer" => "TarifaAcabadoLineas.validation.tirada_max.integer", + "required" => "TarifaAcabadoLineas.validation.tirada_max.required", + ], + "tirada_min" => [ + "integer" => "TarifaAcabadoLineas.validation.tirada_min.integer", + "required" => "TarifaAcabadoLineas.validation.tirada_min.required", + ], + "user_created_id" => [ + "integer" => "TarifaAcabadoLineas.validation.user_created_id.integer", + "required" => "TarifaAcabadoLineas.validation.user_created_id.required", + ], + ]; + + public function findAllWithTarifaAcabado(string $selcols = "*", int $limit = null, int $offset = 0) + { + $sql = + "SELECT t1." . + $selcols . + ", t2.id AS tarifa_acabado FROM " . + $this->table . + " t1 LEFT JOIN lg_tarifa_acabado t2 ON t1.tarifa_acabado_id = t2.id"; + if (!is_null($limit) && intval($limit) > 0) { + $sql .= " LIMIT " . $limit; + } + + if (!is_null($offset) && intval($offset) > 0) { + $sql .= " OFFSET " . $offset; + } + + $query = $this->db->query($sql); + $result = $query->getResultObject(); + return $result; + } + + /** + * Get resource data. + * + * @param string $search + * + * @return \CodeIgniter\Database\BaseBuilder + */ + public function getResource(string $search = "") + { + $builder = $this->db + ->table($this->table . " t1") + ->select( + "t1.tirada_min AS tirada_min, t1.tirada_max AS tirada_max, t1.precio_min AS precio_min, t1.precio_max AS precio_max, t1.precio_unidad AS precio_unidad, t1.user_created_id AS user_created_id, t1.user_updated_id AS user_updated_id, t1.is_deleted AS is_deleted, t1.created_at AS created_at, t1.updated_at AS updated_at, t2.id AS tarifa_acabado" + ); + $builder->join("lg_tarifa_acabado t2", "t1.tarifa_acabado_id = t2.id", "left"); + + return empty($search) + ? $builder + : $builder + ->groupStart() + ->like("t1.tirada_min", $search) + ->orLike("t1.tirada_max", $search) + ->orLike("t1.precio_min", $search) + ->orLike("t1.precio_max", $search) + ->orLike("t1.precio_unidad", $search) + ->orLike("t1.user_created_id", $search) + ->orLike("t1.user_updated_id", $search) + ->orLike("t1.is_deleted", $search) + ->orLike("t1.created_at", $search) + ->orLike("t1.updated_at", $search) + ->orLike("t2.id", $search) + ->orLike("t1.tirada_min", $search) + ->orLike("t1.tirada_max", $search) + ->orLike("t1.precio_min", $search) + ->orLike("t1.precio_max", $search) + ->orLike("t1.precio_unidad", $search) + ->orLike("t1.user_created_id", $search) + ->orLike("t1.user_updated_id", $search) + ->orLike("t1.is_deleted", $search) + ->orLike("t1.created_at", $search) + ->orLike("t1.updated_at", $search) + ->orLike("t2.id", $search) + ->groupEnd(); + } +} diff --git a/ci4/app/Models/Tarifas/TarifaacabadoModel.php b/ci4/app/Models/Tarifas/TarifaacabadoModel.php index 73a359a2..478b40a2 100644 --- a/ci4/app/Models/Tarifas/TarifaacabadoModel.php +++ b/ci4/app/Models/Tarifas/TarifaacabadoModel.php @@ -1,5 +1,5 @@ "t1.nombre", ]; - protected $returnType = "App\Entities\Tarifas\TarifaacabadoEntity"; + + protected $allowedFields = ["nombre"]; + protected $returnType = 'App\Entities\Tarifas\TarifaacabadoEntity'; + + protected $useTimestamps = true; + protected $useSoftDeletes = false; + + protected $createdField = "created_at"; + + protected $updatedField = "updated_at"; public static $labelField = "nombre"; protected $validationRules = [ - "ajuste" => [ - "label" => "Acabadoes.ajuste", - "rules" => "required|decimal", - ], - "formula_price" => [ - "label" => "Acabadoes.formulaPrice", - "rules" => "trim|required|max_length[1073241]", - ], "nombre" => [ "label" => "Acabadoes.nombre", "rules" => "trim|required|max_length[255]", ], - "precio_max" => [ - "label" => "Acabadoes.precioMax", - "rules" => "required|decimal", - ], - "precio_min" => [ - "label" => "Acabadoes.precioMin", - "rules" => "required|decimal", - ], - "tirada_max" => [ - "label" => "Acabadoes.tiradaMax", - "rules" => "required|integer", - ], - "tirada_min" => [ - "label" => "Acabadoes.tiradaMin", - "rules" => "required|integer", - ] ]; protected $validationMessages = [ - "ajuste" => [ - "decimal" => "Acabadoes.validation.ajuste.decimal", - "required" => "Acabadoes.validation.ajuste.required", - ], - "formula_price" => [ - "max_length" => "Acabadoes.validation.formula_price.max_length", - "required" => "Acabadoes.validation.formula_price.required", - ], "nombre" => [ "max_length" => "Acabadoes.validation.nombre.max_length", "required" => "Acabadoes.validation.nombre.required", ], - "precio_max" => [ - "decimal" => "Acabadoes.validation.precio_max.decimal", - "required" => "Acabadoes.validation.precio_max.required", - ], - "precio_min" => [ - "decimal" => "Acabadoes.validation.precio_min.decimal", - "required" => "Acabadoes.validation.precio_min.required", - ], - "tirada_max" => [ - "integer" => "Acabadoes.validation.tirada_max.integer", - "required" => "Acabadoes.validation.tirada_max.required", - ], - "tirada_min" => [ - "integer" => "Acabadoes.validation.tirada_min.integer", - "required" => "Acabadoes.validation.tirada_min.required", - ] ]; + + /** + * Get resource data. + * + * @param string $search + * + * @return \CodeIgniter\Database\BaseBuilder + */ + public function getResource(string $search = "") + { + $builder = $this->db->table($this->table . " t1")->select("t1.id AS id, t1.nombre AS nombre"); + + return empty($search) + ? $builder + : $builder + ->groupStart() + ->like("t1.nombre", $search) + ->orLike("t1.nombre", $search) + ->groupEnd(); + } } diff --git a/ci4/app/Views/themes/backend/vuexy/form/tarifas/acabado/_tarifaAcabadoFormItems.php b/ci4/app/Views/themes/backend/vuexy/form/tarifas/acabado/_tarifaAcabadoFormItems.php new file mode 100644 index 00000000..5f83a198 --- /dev/null +++ b/ci4/app/Views/themes/backend/vuexy/form/tarifas/acabado/_tarifaAcabadoFormItems.php @@ -0,0 +1,12 @@ +
| = lang('Tarifaacabado.nombre') ?> | -= lang('Tarifaacabado.tiradaMin') ?> | -= lang('Tarifaacabado.tiradaMax') ?> | -= lang('Tarifaacabado.precioMin') ?> | -= lang('Tarifaacabado.precioMax') ?> | -= lang('Tarifaacabado.ajuste') ?> | -= lang('Tarifaacabado.formulaPrice') ?> | - - = lang('Tarifaacabado.userCreatedId') ?> -= lang('Tarifaacabado.userUpdateId') ?> | -= lang('Tarifaacabado.deletedAt') ?> | -= lang('Tarifaacabado.createdAt') ?> | -= lang('Tarifaacabado.updatedAt') ?> | - */ ?>= lang('Basic.global.Action') ?> |
|---|---|---|---|---|---|---|---|---|---|---|---|
| - = empty($item->nombre) || strlen($item->nombre) < 51 ? esc($item->nombre) : character_limiter(esc($item->nombre), 50) ?> - | -- = esc($item->tirada_min) ?> - | -- = esc($item->tirada_max) ?> - | -- = esc($item->precio_min) ?> - | -- = esc($item->precio_max) ?> - | -- = esc($item->ajuste) ?> - | -- = empty($item->formula_price) || strlen($item->formula_price) < 51 ? esc($item->formula_price) : character_limiter(esc($item->formula_price), 50) ?> - | - - = esc($item->user_created_id) ?> - -- = esc($item->user_update_id) ?> - | -- = empty($item->deleted_at) ? '' : date('d/m/Y H:m:s', strtotime($item->deleted_at)) ?> - | -- = empty($item->created_at) ? '' : date('d/m/Y H:m:s', strtotime($item->created_at)) ?> - | -- = empty($item->updated_at) ? '' : date('d/m/Y H:m:s', strtotime($item->updated_at)) ?> - | - */ ?> -- =anchor(route_to('editTarifaacabado', $item->id), "", ['class'=>'text-body', 'data-id'=>$item->id,]); ?> - =anchor('#confirm2delete', "", ['class'=>'text-body', 'data-href'=>route_to('deleteTarifaacabado', $item->id), 'data-bs-toggle'=>'modal', 'data-bs-target'=>'#confirm2delete']); ?> - | -