Para facilitar el desarrollo hemos creado un controlador para listados (ListController) y dos controladores para editar registros (EditController y PanelController). Utilice estos controladores siempre que sea posible. Reducirá el tiempo de desarrollo y conseguirá la mayor integración con el resto de FacturaScripts. Además las futuras mejoras que se implementen estarían disponibles automáticamente en su desarrollo.
La filosofía de diseño de interfaces de usuario de FacturaScripts es:
La ejecución del controlador se realiza en los pasos:
Esta manera de trabajar simplifica el entendimiento y seguimiento del código del controlador, y aunque no todos los controladores se ajustan a este patrón se anima a mantenerlo de cara a futuros mantenimientos del código.
Se ejecuta justo antes de la carga de datos y tiene la posibilidad de interrumpir la ejecución del controlador devolviendo false. Esto lo hace ideal para tareas especiales solicitadas desde la vista mediante AJAX o por los botones de acción incluidos en la vista. Algunas de las tareas que actualmente se gestionan son: autocomplete, save y delete.
Ejemplo: Adición de nuevas acciones
protected function execPreviousAction($action)
{
switch ($action) {
/// Boton de Accion: 'clone'
case 'clone':
$data = $this->request->request->all();
$result = $this->cloneDocument($data);
if (!empty($result)) {
$this->setTemplate(false);
$this->response->headers->set('Refresh', '0;' . $result);
return false; /// detiene la ejecucion del controlador
}
return true; /// continua con la ejecucion del controlador
default:
return parent::execPreviousAction($action);
}
}
Se ejecuta después de la carga de datos y antes de visualizar los datos al usuario. Como ya se han leido los datos de los modelos, cualquier cambio que se realice sobre los datos cargados, no se verán reflejados en la vista. Algunas de las tareas que actualmente se gestionan son: insert (permite establecer valores por defecto cuando es una alta), export, megasearch.
protected function execAfterAction($action)
{
switch ($action) {
case 'insert':
/// Load default values for new record
$this->views['EditRegularizacionImpuesto']->model->loadNextPeriod();
break;
default:
parent::execAfterAction($action);
}
}
Necesita identificarse para continuar con esta acción. Haga clic en iniciar sesión o cree una cuenta.
Iniciar sesiónFecha de creación | 05-07-2018 00:00:00 |
Última actualización | 30-12-2020 |
Contador de visitas | 2104 |