El widget select, o WidgetSelect, permite mostrar valores que están relacionados con otras tablas (o con la misma). Un ejemplo muy sencillo es un selector de país.
<column name="country" numcolumns="2" order="150">
<widget type="select" fieldname="codpais" required="true">
<values source="paises" fieldcode="codpais" fieldtitle="nombre"/>
</widget>
</column>
Estas son las propiedades disponibles en la etiqueta widget:
Definición de la clase: puede ver la lista completa de propiedades y métodos del widget select en la documentación de la clase WidgetSelect.
Opciones de coloreado: recuerde que todos los widgets tienen una serie de propiedades y opciones comunes.
Podemos mostrar los valores de una tabla concreta, valores fijos o incluso podemos añadir valores manualmente desde el controlador.
<widget type="select" fieldname="codpais" required="true">
<values source="paises" fieldcode="codpais" fieldtitle="nombre"/>
</widget>
<widget type="select" fieldname="actualizastock" translate="true" required="true">
<values title="book">-2</values>
<values title="subtract">-1</values>
<values title="do-nothing">0</values>
<values title="add">1</values>
<values title="foresee">2</values>
</widget>
Si necesitamos cargar una lista muy concreta de valores en un widget select, podemos usar el método setValuesFromArray():
$column = $this->views[VIEW_NAME]->columnForName(NAME_DE_LA_COLUMNA_EN_EL_XMLVIEW);
if($column && $column->widget->getType() === 'select') {
$customValues = [
['value' => '1', 'title' => 'UNO'],
['value' => '2', 'title' => 'DOS'],
['value' => '3', 'title' => 'TRES'],
['value' => '14', 'title' => 'CATORCE'],
];
$column->widget->setValuesFromArray($customValues);
// si entre los valores quieres que esté null, mejor ejecuta eso
//$column->widget->setValuesFromArray($customValues, false, true);
}
¿El widget está en un modal? Si el select está en un modal, entonces hay que reemplazar la primera línea por esta:
$column = $this->views[VIEW_NAME]->columnModalForName(NAME_DE_LA_COLUMNA_EN_EL_XMLVIEW);
Sustituir VIEW_NAME por el nombre de la vista/pestaña que sea, y NAME_DE_LA_COLUMNA_EN_EL_XMLVIEW por el name de la columna que contiene el widget en el archivo xmlview.
También podemos usar la clase CodeModel para obtener los valores y cargarlos en el widget. Por ejemplo, vamos a cargar una lista con los clientes y su número de teléfono, y entonces usar el método setValuesFromCodeModel():
$column = $this->views[VIEW_NAME]->columnForName(NAME_DE_LA_COLUMNA_EN_EL_XMLVIEW);
if($column && $column->widget->getType() === 'select') {
$customValues = $this->codeModel->all('clientes', 'codcliente', 'telefono1');
$column->widget->setValuesFromCodeModel($customValues);
}
Necesita identificarse para continuar con esta acción. Haga clic en iniciar sesión o cree una cuenta.
Iniciar sesiónEspaña, 9 años, nivel 100
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 ;-)
OROCon este curso aprenderá cómo crear un plugin sencillo para FacturaScripts 2021: 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. ¿Qué incluye? 18 lecciones con 14 vídeos explicativos.
283 | 9,99 € |
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? 15 lecciones con 15 vídeos explicativos (más de 6 horas de vídeos) y el código fuente de los ejemplos. Novedades mensuales: Este curso se amplía cada mes con nuevas lecciones.
67 | 19,99 € |