Tarea #1334

CORE v2023

Rediseñar la clase Model para reemplazar a ModelClass. La nueva versión que se colocaría en la carpeta Template, de acuerdo a la nueva estructura de carpetas del Core. La versión original permanecería en Core/Model/Base para mantener compatibilidad durante unos meses.

Ejemplo de modelo

<?php
namespace FacturaScripts\Plugins\MyNewPlugin\Model;

use FacturaScripts\Core\Template\Model;
use FacturaScripts\Core\Template\ModelTrait;

class Project extends Model
{
    use ModelTrait;

    const ID_COLUMN = 'id';
    const TABLE_NAME = 'proyectos';
}

La clase Model incluye por defecto las columnas id, creation_date, nick, last_update y last_nick.

Ejemplo de uso

// cargamos el proyecto 23
$project = new Project();
if ($project->load(23) ) {
    // lo ha cargado de la base de datos

    // imprimimos su clave primaria
    echo $project->id(); // antes era con primaryColumnValue()
}

Para dar compatibilidad hacia atrás se implementarían los alias a las funciones correspondientes en el ModelClass anterior, es decir, añadirle una función loadFromCode() que internamente llame a load() y una primaryColumnValue() que llame a id().

Nueva función estática all()

Project::all(); // devuelve los primeros 50 proyectos, ya que sigue teniendo el límite de 50 predeterminado
Project::all([], [], 0, 0); // devuelve todos los proyectos
Project::all(['nick', 'pepe']); // devuelve los primeros 50 proyectos con nick = 'pepe'
Project::all(['nick', 'pepe'], ['name' => 'ASC'], 0, 0); // devuelve todos los proyectos con nick = 'pepe' y ordenados por name
Project::all([['nick', 'pepe'], ['total', 1000, '>']], ['name' => 'ASC'], 0, 0); // devuelve todos los proyectos con nick = 'pepe' y total > 1000 y ordenados por name

// con Where
$where = [
    Where::column('nick', 'pepe'),
    Where::and('total', 1000, '>')
];
Project::all($where, ['name' => 'ASC'], 0, 0); // devuelve todos los proyectos con nick = 'pepe' y total > 1000 y ordenados por name

Nuevas fuciones load() y derivados

$project = new Project();
$project->load(1); // carga el proyecto 1, carga y devuelve true si lo encuentra. clear() y devuelve false en caso contrario
$project->loadOrFail(1); // carga el proyecto 1, carga los datos si lo encuentra. Lanza una excepción en caso contrario
$project->loadWhere(['nick', 'pepe']); // carga el primer proyecto con nick = 'pepe' y devuelve true. clear() y devuelve false en caso contrario

$project->loadWhereOrNew(['nick', 'pepe']); // carga el primer proyecto con nick = 'pepe'. clear() y asigna esos valores en caso contrario
// la función anterior sirve para reemplazar a estructuras de este estilo
$where = [
    ['nick', 'jose'],
    ['codalmacen' => 'ALG']
];
if(false === $project->loadWhere($where)) {
    // no existe, lo creamos
    $project->nick = 'jose';
    $project->codalmacen = 'ALG'
}

Nuevas funciones find() y derivados

Project::find(1); // devuelve el proyecto con id = 1, o null si no lo encuentra
Project::findOrFail(1); // devuelve el proyecto con id = 1, o lanza excepción si no lo encuentra
Project::findWhere(['nick', 'pepe]); // devuelve el primer proyecto con nick = 'pepe' o null en caso contrario
Project::findWhereOrNew(['nick', 'pepe]); // devuelve el primer proyecto con nick = 'pepe' o uno nuevo con nick = 'pepe'

deleteAll(array $where): bool

En ocasiones queremos eliminar muchos registros de una sola vez:

  • Podemos hacer un bucle, pero es lento.
  • Podemos ejecutar el SQL correspondiente, pero entonces no podemos añadir comprobaciones, como hacemos al eliminar facturas, asientos, etc.
// eliminamos todos los proyectos con total = 0
Project::deleteAll(['total', 0]);

Internamente el método puede construir y ejecutar el SQL para eliminar todos esos registros de una sola vez. Pero a la vez, como es un método y podemos añadirle extensiones, podemos ejecutar código antes para hacer ciertas cosas o impedir que suceda si se dan ciertas condiciones.

sum(string $column, array $where): float

En ocasiones queremos sumar todos los valores de una columna. Con esta función ahorramos mucho código.

Nuevas funciones relatedOne() y relatedAll()

$project = new Project();
$project->load(123);
$project->relatedOne('User'); // devuelve el usuario con nick = nick de la tabla, null si no lo encuentra
$project->relatedOne('User', 'author'); // devuelve el usuario con nick = author de la tabla, null si no lo encuentra
$project->relatedAll('Task', 'idproject'); // devuelve las primeras 50 tareas con idproject = id() del modelo
$project->relatedAll('Task', 'idproject', [], 0, 0); // devuelve todas las tareas con idproject = id() del modelo
$project->relatedAll('Task', 'idproject', ['creationdate' => 'ASC'], 0, 0); // devuelve todas las tareas, ordenadas por creationdate, con idproject = id() del modelo

Validación de tipos

En el método test(), que se llama al hacer save(), debe comprobar que todas las columnas tengan valores válidos, es decir, si el campo total está definido como float en el xml de la tabla, que no permita guardar una cadena de texto.

  • Tampoco deben permitir guardar null en columnas not null.
  • Si la columna es varchar(10), no debe permitir guardar cadenas de más de 10 caracteres.
  • Debe escapar automáticamente el HTML de las columnas string.

Otras validaciones

Podemos añadir al xml de la tabla validaciones adicionales antes de guardar los datos, por ejemplo, para los campos que son email, podemos añadir una regla de validación de email, de forma que sin hacer nada más, el modelo compruebe que si hay un email debe ser correcto:

<column>
   <name>name</name>
   <type>character varying(100)</type>
   <validation>valid_email,min_length[5]</validation>
</column>

¿Por qué poner la regla en el xml? De esta forma podemos añadir validaciones o cambiarlas mediante extensiones. Podríamos añadir mediante una extensión un campo email a un modelo y definir ahí la validación de email, con solamente poner el xml en la carpeta Extension/Table del plugin.

Algunas validaciones interesantes:

ModelOnChange

En lugar de tener una clase ModelOnChange y solamente aquellos modelos que hereden de esta clase tendrán posibilidad de reaccionar a cambios de valores en sus columnas, todos los modelos deberían soportar estas características. Para ello hay que implementar en la clase Modelo las funciones:

  • monitorChanges(string $column) : añade la columna a la lista de columnas cuyos valores previos hay que recordar. Función estática.
  • getOriginal(string $column) : devuelve el valor original de la columna.
  • onChange(string $column)
PRO
neorazorx_1

Asignado neorazorx_1

España, 11 años, nivel 100

Fecha de inicio: 06-11-2023, Puntos de soporte +25

Comentarios

daniel89fg_739

21-06-2023 14:13:24 daniel89fg_739

En codeigniter y laravel también existe la figura del cast() para definir el tipo de columna, eso ya lo tenemos en el xml, pero en el modelo en el test() se podría controlar/comprobar que el dato enviado corresponde con el tipo de columna. Si tengo una columna de tipo string y se pasa un int que salte el error, y así con todos los tipos.
Solamente autorizados y patrocinadores pueden comentar.

Tarea #3499

Modificar el widget select para ponerle un color warning o alguna advertencia cuando el valor guardado no está en la lista.

CORE - Pendiente 10-09-2024
Tarea #3494

(BUG) No se debe permitir crear un mismo producto de proveedor con la misma referencia del proveedor y el mismo proveedor en varias referencias de productos. Solo debe existir una referencia de proveedor vinculada con un producto y ese proveedor. Actualmente permite hacerlo y...

CORE - Pendiente 28-08-2024
Tarea #2173

Al crear un cliente o proveedor, si existe el Plan Contable, crear subcuenta automáticamente y relacionarla. Añadir también un botón a la pestaña de subcuentas, en la página del cliente o proveedor, para poder crear la subcuenta del cliente, si no existe.

CORE - Pendiente 14-02-2023
Tarea #3448

Al cambiar el estado de un documento, cuando ese nuevo estado genera otro documento (por ejemplo al marcar un albarán como facturado), debería mostrar un modal donde poder seleccionar la fecha del nuevo documento. De esta forma al aprobar un albarán de compra podemos...

CORE - Pendiente 03-07-2024
Tarea #3435

Hay que mover la clase PluginDeploy fuera de Core/Base, y reemplazar las llamadas a funciones obsoletas.

CORE - Pendiente 27-06-2024
Tarea #3447

(BUG) cuando tenemos una factura impagada y emitida, es decir, bloqueada. Si la marcamos como pagada nos aparece el modal donde seleccionar forma de pago y fecha, pero los campos aparecen bloqueados. Nunca deben estar bloqueados. Implementación Originalmente se usó...

CORE - Pendiente 03-07-2024
Tarea #3399

(BUG) al aprobar documentos de compra, no debería copiar el campo numproveedor al siguiente documento, ya que si apruebas el albarán 123, puede que la factura no sea la 123.

CORE - Pendiente 28-05-2024
Tarea #3425

Necesitamos poder filtrar por país, provincia y ciudad en los listados de venta (facturas, albaranes, pedidos y presupuestos). Para ello hay que añadir esos filtros: Selector de país. Autocomplete de provincia. Autocomplete de ciudad.

CORE - Pendiente 19-06-2024
Tarea #3423

Cuando la opción google_tag_manager no está activa en el panel de control, hay que añadir un card en el Updater para preguntar al usuario si la quiere activar.

CORE - Pendiente 19-06-2024
Tarea #3417

Ahora mismo para cada pantalla de error fatal se genera a su vez un archivo crash_XXX en la carpeta MyFiles. Necesitamos enviar esos archivos a facturascripts.com y eliminarlos. Para ello, en el actualizador, si hay archivos de crash debe aparecer una sección nueva (un card...

CORE - Pendiente 12-06-2024
Tarea #3389

Añadir las funciones necesarias a PDFExport para poder añadir texto, etc, en lugar de llamar a $this->pdf->ezText(). Así se puede reemplazar completamente en PlantillasPDF y otros plugins ganan compatibilidad.

CORE - Pendiente 24-05-2024
Tarea #3363

Tenemos textos traducibles para facturas, albaranes, pedidos y presupuestos, pero no para el resto. El controlador SendMail debería crear textos predeterminados para cualquier modelo, así los podemos personalizar.

CORE - Pendiente 08-05-2024
Tarea #3356

En la tabla de productosprov es posible añadir varios productos con la misma referencia del proveedor al mismo proveedor, y eso no se debería de poder hacer. Se debe añadir un restricción única sobre las columnas codproveedor y refproveedor.

CORE - Pendiente 06-05-2024
Tarea #3305

Necesitamos poder tener textos distintos para cada idioma en las notificaciones de email. Para ello hay que añadir la columna lang al modelo, y modificar la función para enviar las notificaciones de forma que podamos especificar un idioma (opcional). Prioridades Si...

CORE - Pendiente 09-04-2024
Tarea #3304

En las notificaciones de email tenemos unos parámetros disponibles siempre: fecha, nombre, etc. Y luego tenemos una serie de parámetros que son exclusivos de la notificación (instance_uuid, price...). Hay que añadirle la columna (param_list) al modelo para poder apuntar la...

CORE - Pendiente 09-04-2024
Tarea #3282

(BUG) al hacer un asiento de venta (pasa lo mismo en compras), en ocasiones tenemos líneas a 0 en la cuenta 700.0. Esto es porque en la instalación hay una 700.1 y todos los productos vinculados a ella, pero cuando hacemos una compra o venta y metemos alguna líne de texto,...

CORE - Pendiente 29-03-2024
Tarea #3285

Añadir la opción de generar un historial de cambios: tendremos un modelo de historial, un worker para rellenarlo, un trait para mostrar la pestaña de historial en los controladores que queramos, la pestaña de listado de ListLogMessages y el correspondiente EditController....

CORE - Pendiente 02-04-2024
Tarea #3155

En ocasiones tenemos documentos de compra que tienen ligeros cambios en la forma de calcular los impuestos, con variaciones de un céntimo en neto, IVA o ambos. Para estos casos la solución es modificar una de las líneas y añadirle o restarle medio céntimo hasta cuadrar...

CORE - Pendiente 21-02-2024
Tarea #3059

Modificar el instalador para poder leer los datos de configuración de variables de entorno. Issue relacionada https://github.com/truecharts/charts/issues/16824

CORE - Pendiente 20-01-2024
Tarea #3000

Necesitamos poder marcar una factura como pagada desde la API. Ahora mismo si desde la API modificamos el campo pagada a true, lo vuelve a dejar a false, ya que ese campo se actualiza al guardar, comprobando que los recibos de la factura estén pagados. Hay que añadir un...

CORE - Pendiente 11-01-2024
Tarea #2996

Añadir al ejercicio un botón para copiar las cuentas y subcuentas de otro ejercicio. Al hacer clic debe mostrar un modal para seleccionar el ejercicio del que copiar los datos.

CORE - Pendiente 10-01-2024
Tarea #2970

Añadir un worker para actualizar el número de productos de las familias, cuando se crea, modifica o elimina un producto.

CORE - Pendiente 19-12-2023
Tarea #2955

Añadir a los balances un botón imprimir para genera el PDF con la librería del core, en lugar de PlantillasPDF (si está activado). Implementación Llamar al exportManager del core en lugar del dinamic.

CORE - Pendiente 12-12-2023
Tarea #2962

Al enviar un email con la clase NewMail no se vacían las listas de direcciones de correos, por lo que si queremos enviar el mismo correo a miles de emails, nos toca hacerlo varias veces. Si añadimos funciones para vaciar las direcciones de correo, podemos reducir código....

CORE - Pendiente 19-12-2023
Tarea #2947

Necesitamos poder filtrar los asientos que no tienen un canal, es decir, que el canal es cero. Implementación Ahora mismo hay un filtro select, quizás es mejor un filtro select where donde pongamos que "ningún canal" o "canal 0" muestre efectivamente los...

CORE - Pendiente 12-12-2023
Tarea #2940

Añadir un cron para generar cada diario y almacenarlo en MyFiles. Así ver el diario, si tenemos este archivo ya generado, podemos descargar este archivo en lugar de generarlo al momento.

CORE - Pendiente 05-12-2023
Tarea #2937

En el nuevo TabCalendar hay que poder dar de alta varias fuentes de eventos, ya sean urls o calendarios de google. Requiere Este cambio requiere los nuevos controladores UI.

CORE - Pendiente 01-12-2023
Tarea #2934

Modificar la clases de Core/Base/AjaxForms para poner la mayoría de métodos estáticos como públicos, para poder llamarlos desde fuera en los mods (para cuando solamente queremos añadir algo después, o modificar levemente el html).

CORE - Pendiente 29-11-2023
Tarea #2932

En la página del plugin, en la pestaña de zips, añadir el campo observaciones a los zips, para poder anutar ahí algo, de cara al propio programador.

CORE - Pendiente 28-11-2023
Tarea #2933

(Posible bug) Parece que se puede hacer una devolución de la misma línea varias veces, es decir, tienes una línea con cantidad 1, haces la rectificativa de eso y vuelves a hacerla igual. Te deja.

CORE - Pendiente 28-11-2023
Tarea #2896

Añadir al asistente para agrupar o partir la opción de agrupar líneas (por referencia y descripción) de forma que si tienes 50 líneas del producto 1, te genere una sola línea con la cantidad sumada de las 50.

CORE - Pendiente 13-11-2023
Tarea #2749

Necesitamos poder añadir una imagen por familia de productos, para cuando es la misma imagen para todos los productos de la familia.

CORE - Pendiente 19-09-2023
Tarea #2762

Añadir la opción de evitar añadir la descripción de atributos al añadir una variante a un documento. Motivación En ocasiones usamos atributos que luego no queremos que se impriman sus nombres o valores.

CORE - Pendiente 25-09-2023
Tarea #2392

Al añadir líneas a un asiento, se coloca automáticamente en el debe o el haber el resto correspondiente, es decir, si has añadido una línea con 50 en el debe, al añadir la segunda línea colocará 50 en el haber. Problema: si estás añadiendo varias alíneas con debe,...

CORE - Pendiente 13-04-2023
Tarea #2370

En ocasiones es necesario hacer facturas a cero, por distintos motivos. El problema es que estas facturas no están generando asientos y por tanto no aparecen en los informes de impuestos, ni los modelos fiscales. Hay que dar soporte a este tipo de facturas para que si...

CORE - Pendiente 05-04-2023
Tarea #878

Modificar el actualizador para que la acción de actualizar, una vez se ha descargado el zip, sea una llamada ajax, al igual que la acción de actualizar el dinamic. Motivación Hay que mejorar la tolerancia a errores del actualizador. No puede ser que cada vez que hagamos un...

CORE - Pendiente 19-04-2022
Tarea #2273

Las miniaturas de imágenes de productos tienen mala resolución al incluirlas en los PDF (PlantillasPDF). Necesitamos aumentar la calidad de las miniaturas. Cliente interesado [email protected]

CORE - Pendiente 17-03-2023
Tarea #2233

Parece que hay un problema al calcular el importe del asiento de cierre del ejercicio. Issue relacionada https://facturascripts.com/issues/6286

CORE - Pendiente 07-03-2023
Tarea #2186

Necesitamos controlar cuando la devolución es por rotura y no queremos que se devuelva al stock.

CORE - Pendiente 20-02-2023
Tarea #1996

Modificar el informe de impuestos para incluir la columna País, para poder saber de qué país viene cada factura (para las ventas).

CORE - Pendiente 09-01-2023
Tarea #1892

Al pasar una factura de venta a emitida, ya no se debería volver a pasar a boceto, es decir, al pasar a emitida hay que marcar internamente la factura para no dejar cambiarla, ni eliminarla después.

CORE - Pendiente 13-12-2022
Tarea #1893

Hay que definir claramente en los modelos de documentos de compras y ventas qué campos son realmente no editables, para que no se permita modificar esos, peri el resto.

CORE - Pendiente 13-12-2022
Tarea #1676

Crear un test unitario para el modelo Impuesto. Comprobar Se puede crear un impuesto y borrarlo. Se pueden crear dos impuestos con el mismo iva. Si se crea un impuesto de tipo porcentaje y 10 de iva, al hacer una compra con una línea con ese impuesto, cantidad 2 y precio 50,...

CORE - Pendiente 10-10-2022
Tarea #1682

Modificar el modelo Partida para poder desactivar la comprobación de si el asiento o el ejercicio está bloqueado. Necesitamos poder modificar el saldo de una partida independientemente de si el asiento está bloqueado. Nota No es toy seguro de si el modelo está comprobando...

CORE - Pendiente 11-10-2022
Tarea #3374

En TPVneo, si añades una línea en negativo y otra en positivo, con el mismo importe. (Típico caso de cambio de producto). El botón de cobrar desaparece. Si lo haces a la inversa. Es decir, primero añades el positivo y luego negativo, funciona correctamente. Sería...

CORE - Pendiente 14-05-2024
Tarea #851

Modificar el formulario de devoluciones para poder indicar al crear si las 2 facturas (la rectificada y la nueva) se van a marcar como pagadas y con qué forma de pago. Motivación Cuando te devuelven una factura entera que no te han pagado, además de la rectificativa tienes...

CORE - Pendiente 12-04-2022
Tarea #2209

A la hora de visualizar una Factura rectificativa de una factura previa es muy facil confundirse ya que el titulo sigue llamándose Factura y debería llamarse Factura Rectificativa. Lo unico que la diferencia es que sale un boton en amarillo con dos << delante que no...

CORE - Pendiente 24-02-2023
Tarea #2724

En los asientos se está colocando un enlace para abrir el documento relacionado solamente cuando es factura, pero tenemos asientos que son de recibos, asientos que son de remesas, etc. En todos estos casos deberíamos poder ir igualmente al modelo original. Implementación...

CORE - Pendiente 28-08-2023
Tarea #2533

(BUG) al poner una fecha de pago para la cual todavía no existe ejercicio, se genera el pago, pero no se genera el asiento porque el ejercicio no existe. La única forma de solucionar esto es por sql. Necesitamos poder hacerlo desde la interfaz. Necesitamos Poder generar el...

CORE - Pendiente 05-06-2023
Tarea #2114

En las políticas de precio de coste no está teniendo en cuenta la divisa en los precios de proveedor, de forma que si vendemos en euros y compramos en rupias, nos va a leer los precios de compra del producto en rupias como si fuesen euros. Habría que hacer una conversión...

CORE - Pendiente 30-01-2023
Cookies
Usamos cookies en nuestro sitio web para brindarte la experiencia más relevante recordando tus preferencias y visitas repetidas. Al hacer clic en "Aceptar", aceptas el uso de TODAS las cookies necesarias.
Copyright (c) 2013-2024 FacturaScripts
0.15684s

Soporte