Operaciones comunes con modelos

Ya nos ha quedado claro qué es un modelo, ahora vamos a ver lo que podemos hacer con él.

Utilizar un modelo

Recuerda que tenemos todo separado por espacios de nombres, si vamos a operar desde un controlador, por ejemplo, deberemos indicar arriba, justo debajo de namespace, que vamos a usar este modelo:

use FacturaScripts\Plugins\MyNewPlugin\Model\Project;

Aunque lo más recomendable es cargar los modelos siempre del dinamic, ya que estos llevan las extensiones cargadas:

use FacturaScripts\Dinamic\Model\Project;

Crear y guardar un registro

Siguiendo con nuestro ejemplo del modelo Project, vamos a crear un nuevo proyecto. Para guardar el registro en la base de datos llamaremos al método save() del modelo.

$newProject = new Project();
$newProject->codproject = 'test';
$newProject->name = 'test';
$newProject->save();

Obtener un registro del que conocemos su identificador o clave primaria:

Para cargar los datos de un registro almacenado en la base de datos llamaremos al método loadFromCode() del modelo.

// supongamos que es 'test'
$project = new Project();
if ($project->loadFromCode('test')) {
    // lo hemos encontrado
}

// también podemos usar get()
$modelProject = new Project();
$project = $modelProject->get('test');
if($project) {
    // existe
}

Eliminar un registro:

Para eliminar un registro de la base de datos llamaremos al método delete() del modelo.

// supongamos que es 'test'
$project = new Project();
if ($project->loadFromCode('test')) {
    // lo hemos encontrado
    $project->delete();
    // eliminado
}

Leer muchos registros

Podemos leer muchos registros de la base de datos, o todos, con el método all() del modelo. Este método permite filtros, ordenación y paginación.

foreach (Producto::all() as $producto) {
    // $producto es el producto que estamos consultando en este momento
}

Contar registros

También podemos obtener el número de registros en la base de datos llamando al método count() del modelo. Este método además permite pasar filtros para obtener el contador de aquellos registros que cumplan los filtros.

$producto = new Producto();
$total = $producto->count();

Crear presupuestos, pedidos, albaranes o facturas

Los documentos de compra o de venta son más complejos y van enlazados con un cliente o proveedor, tienen una o varias líneas y además hay que calcular sus totales. Aquí tienes un ejemplo de cómo crear un presupuesto de compra. Es lo mismo para pedidos, albaranes y facturas:

// cargamos el proveedor 1
$proveedor = new Proveedor();
if (false === $proveedor->loadFromCode('1')) {
    // no hemos encontrado el proveedor
}

// creamos el presupuesto (se le asigna empresa, almacén, serie, divisa, forma de pago y fecha predeterminada
$presupuesto = new PresupuestoProveedor();
$presupuesto->setSubject($proveedor); // asignamos el proveedor
if (false === $presupuesto->save()) {
    // no se ha podido guardar
}

// añadimos una línea con un producto al presupuesto
$newLinea1 = $presupuesto->getNewProductLine('referencia1'); // se asigna el producto, descripción, precio, etc
$newLinea1->cantidad = 1;
if (false === $newLinea1->save()) {
    // no se ha podido guardar la línea
}

// añadimos una línea de texto
$newLinea2 = $presupuesto->getNewLine();
$newLinea2->descripcion = 'Mano de obra';
$newLinea2->cantidad = 5;
$newLinea2->pvpunitario = 10;
if (false === $newLinea2->save()) {
    // no se ha podido guardar
}

// actualizamos los totales del presupuesto
$lineas = $presupuesto->getLines();
if (false === Calculator::calculate($presupuestos, $lineas, true)) {
    // no se ha podido actualizar el presupuesto
}

Asignamos el proveedor llamando al método setSubject(). Para las líneas llamamos al método getNewProductLine() para que nos devuelva una nueva línea enlazada al producto cuya referencia pasemos como parámetro. Para líneas sin producto llamamos al método getNewLine(). Por últimos llamamos a la clase Calculator para que actualice los totales del documento.

Aquí tienes otro ejemplo de cómo crear una factura de venta. Comprobarás que es prácticamente idéntico. Lo único que cambia es el nombre de la clase.

// cargamos el cliente 1
$cliente = new Cliente();
if (false === $cliente->loadFromCode('1')) {
    // no hemos encontrado el cliente
}

// creamos la factura (se le asigna empresa, almacén, serie, divisa, forma de pago y fecha predeterminada
$factura = new PresupuestoProveedor();
$factura->setSubject($cliente); // asignamos el cliente
if (false === $factura->save()) {
    // no se ha podido guardar
}

// añadimos una línea con un producto a la factura
$newLinea1 = $factura->getNewProductLine('referencia1'); // se asigna el producto, descripción, precio, etc
$newLinea1->cantidad = 1;
if (false === $newLinea1->save()) {
    // no se ha podido guardar la línea
}

// añadimos una línea de texto
$newLinea2 = $factura->getNewLine();
$newLinea2->descripcion = 'Mano de obra';
$newLinea2->cantidad = 5;
$newLinea2->pvpunitario = 10;
if (false === $newLinea2->save()) {
    // no se ha podido guardar
}

// actualizamos los totales de la factura
$lineas = $factura->getLines();
if (false === Calculator::calculate($factura, $lineas, true)) {
    // no se ha podido actualizar la factura
}

Siguiente

Necesita identificarse para continuar con esta acción. Haga clic en iniciar sesión o cree una cuenta.

Iniciar sesión
PRO
neorazorx_1
neorazorx_1

España, 11 años, nivel 100

Los modelos

Patrocinadores

FacturaScripts avanza más rápido gracias al apoyo financiero de los patrocinadores, que contribuyen a que podamos dedicar más tiempo al desarrollo, testeo y documentación. Usted también puede poner su granito de arena y convertirse en patrocinador ;-)

ORO
elurk_3992
ORO
manel_11440
ORO
soporte.fs_10883
ORO
aliksi_1525
ORO
roberto_1699
ORO
decontado_22161
PLATA
rexmaris_12857
PLATA
acaselles_13670
PLATA
atimicroson_10546
PLATA
oguimera_10015
PLATA
jlgonzalezdiaz_12316
PLATA
v.delgado_14821
PLATA
luis_12743
PLATA
vicente.villar.elizondo_22278
PLATA
raljopa_851
PLATA
creabolsas_22110
PLATA
danyarranz_14804
BRONCE
silentgrowonline_19393
BRONCE
abanpinde.sl_22536
PRO
neorazorx_1
PRO
jmoreno_2610
PRO
mariano_6807
PRO
smartcuines_1378
PRO
josopu_20925
Patrocinar

Amplíe sus conocimientos con los cursos oficiales

Curso básico de PHP

¡Aprende a programar en PHP de manera fácil y divertida con nuestro curso básico! En este curso, te enseñaremos los conceptos fundamentales de la programación en PHP, incluyendo la sintaxis básica, el manejo de variables, estructuras de control de flujo y mucho más. Al terminar estarás listo para comenzar con el curso de creación de plugins para FacturaScripts.

28 9,99 €
Curso básico de programación

Con este curso aprenderá cómo crear un plugin sencillo para FacturaScripts: añadir nuevas páginas, tablas y columnas. Para entender este curso no se necesita mucha experiencia en programación, le enseñaremos los básico para modelar problemas sencillos. ¿A quién va dirigido? A cualquier persona con unos conocimientos muy básicos de programación o que ya han completado el curso de PHP. ¿Qué incluye? 18 lecciones con 14 vídeos explicativos.

355 9,99 €
Sesiones de programación

Esta es una recopilación de vídeos y documentación de pequeños desarrollos sobre FacturaScripts y sus plugins. Perfecto para expandir tus conocimientos de programación. ¿A quién va dirigido? A personas que ya hayan superado el curso básico de programación y busquen ampliar sus conocimientos. ¿Qué incluye? 22 lecciones con 22 vídeos explicativos (más de 11 horas de vídeos) y el código fuente de los ejemplos.

129 19,99 €
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.27162s

Soporte