Los modelos

En FacturaScripts los modelos cumplen una doble función, no sólo representan un objeto (como un producto) y permiten su creación, manipulación o eliminación de la base de datos, sino que además permiten obtener y filtrar otros objetos de la misma clase (en este caso más productos).

Un modelo es una clase que debe ir en un archivo con el mismo nombre y dentro de la carpeta Model del plugin.

Ejemplo: Project.php

Siguiendo con el ejemplo del plugin MyNewPlugin, vamos a añadirle un modelo llamado Project para dar de alta proyectos.

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

use FacturaScripts\Core\Model\Base\ModelClass;
use FacturaScripts\Core\Model\Base\ModelTrait;

class Project extends ModelClass
{
    use ModelTrait;

    public $codproject;
    public $name;

    public static function primaryColumn(): string
    {
        return 'codproject';
    }

    public static function tableName(): string
    {
        return 'projects';
    }
}

namespace

Es importante recordar que nuestro plugin utiliza el espacio de nombres FacturaScripts\Plugins\MyNewPlugin, porque el plugin se llama MyNewPlugin. Si cambiamos este espacio de nombres dejará de funcionar. El espacio de nombres se debe corresponder con la carpeta donde está el archivo.

extends Base\ModelClass

Con esto estamos indicando que nuestra clase hereda de ModelClass, que es la clase base para los modelos de FacturaScripts. Podemos heredar de otra clase que no sea ModelClass, siempre y cuando esa otra clase herede de ModelClass.

use Base\ModelTrait

Esta línea es muy importante, indica que se use el trait ModelTrait, que es el que se encarga de leer los datos de la tabla y almacenar los campos en la variable fields. Es imprescindible que esta línea esté solamente en el modelo final, es decir, si va a heredar de otra clase que no sea ModelClass, no coloque el trait en esa clase, siempre debe ir en la última clase, en el modelo definitivo.

primaryColumn()

Esta función debe devolver el nombre de la columna de la clave primaria de la tabla.

tableName()

Debe devolver el nombre de la tabla de la base de datos que utiliza este modelo. FacturaScripts buscará a continuación el archivo con la definición de la estructura de la tabla. Puede ver más detalles en los enlaces más abajo.

Buenas prácticas para la elección de nombres

El nombre del modelo debe ser siempre en singular y el de la tabla en plural. Si necesita un modelo para edificios, el modelo se debería llamar Edificio y la tabla edificios.

Nombres de columna conflictivos

Evite usar en sus columnas nombres como: action y code.

Herencia de modelos

Puede heredar y personalizar cualquier modelo existente, pero recuerde que debe utilizar un alias antes de heredar. Aquí tiene un ejemplo:

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

use FacturaScripts\Core\Model\Cliente as ParentModel;

class Cliente extends ParentModel {
}

Fíjese en la línea 'use FacturaScripts\Core\Model\Cliente as ParentModel;'. Ese as es para utilizar Cliente con el alias de ParentModel. Si no usa un alias tendrá una colisión de nombres al definir la nueva clase, ya que esta se llama igual que la clase de la que deseea heredar.


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

Creación de plugins

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
aliksi_1525
ORO
soporte.fs_10883
ORO
roberto_1699
ORO
facturacion_11803
ORO
ursuslider_2562
ORO
wf_12852
ORO
asistecnicasoluciones_17043
ORO
garridoservers_19777
PLATA
acaselles_13670
PLATA
oguimera_10015
PLATA
jlgonzalezdiaz_12316
PLATA
atimicroson_10546
PLATA
v.delgado_14821
PLATA
luis_12743
PLATA
klikatu_19216
PLATA
rexmaris_12857
PLATA
s3rtec_4534
PLATA
josepmp_2501
PLATA
zapasoft_1521
PLATA
castor.agra_2284
PLATA
appzaragoza_20607
PLATA
raljopa_851
PLATA
sergicapella_17317
PLATA
manuel_9234
PLATA
jesusangel.hernandez_21803
PLATA
juanjoseprieto88_1282
PLATA
alexis_8932
PLATA
hfernandez9211_12051
BRONCE
fnusmas_5683
BRONCE
silentgrowonline_19393
PRO
neorazorx_1
PRO
yopli2000_5
PRO
mariano_6807
PRO
smartcuines_1378
PRO
daniel89fg_739
PRO
javi150985_4944
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.

24 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.

349 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.

123 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.22447s

Soporte