Configuración

Esta página describe las clases que se pueden utilizar para crear una vista de configuración de widget con campos de configuración personalizados. La vista de configuración del widget es la parte del widget que permite al usuario configurar los parámetros del widget para la presentación.

Widget

Clase principal del widget, extiende la clase base de todos los widgets del panel - CWidget. Requerido para sobrescribir el comportamiento predeterminado del widget.

La clase Widget debe ubicarse en el directorio raíz del widget (por ejemplo, zabbix/ui/modules/my_custom_widget).

Ejemplo de Widget.php

<?php

namespace Modules\MyCustomWidget;

use Zabbix\Core\CWidget;

class Widget extends CWidget {

    public const MY_CONSTANT = 0;

    public function getTranslationStrings(): array {
        return [
            'class.widget.js' => [
                'No data' => _('No data')
            ]
        ];
    }
}

WidgetForm

La clase WidgetForm extiende la clase por defecto CWidgetForm y contiene un conjunto de campos CWidgetField que son necesarios para definir la estructura de almacenamiento de la configuración del widget en la base de datos y gestionar la validación de entrada.

La clase WidgetForm debe ubicarse en el directorio includes. Si la clase tiene un nombre diferente, el nombre debe especificarse en el parámetro widget/form_class en el archivo manifest.json.

Ejemplo de includes/WidgetForm.php

<?php

namespace Modules\MyCustomWidget\Includes;

use Modules\MyCustomWidget\Widget;

use Zabbix\Widgets\{
    CWidgetField,
    CWidgetForm
};

use Zabbix\Widgets\Fields\{
    CWidgetFieldMultiSelectItem,
    CWidgetFieldTextBox,
    CWidgetFieldColor
};

class WidgetForm extends CWidgetForm {

    public const DEFAULT_COLOR_PALETTE = [
        'FF465C', 'B0AF07', '0EC9AC', '524BBC', 'ED1248', 'D1E754', '2AB5FF', '385CC7', 'EC1594', 'BAE37D',
        '6AC8FF', 'EE2B29', '3CA20D', '6F4BBC', '00A1FF', 'F3601B', '1CAE59', '45CFDB', '894BBC', '6D6D6D'
    ];

    public function addFields(): self {
        return $this
            ->addField(
                (new CWidgetFieldMultiSelectItem('itemid', _('Métrica')))
                    ->setFlags(CWidgetField::FLAG_NOT_EMPTY | CWidgetField::FLAG_LABEL_ASTERISK)
                    ->setMultiple(false)
            )
            ->addField(
                new CWidgetFieldTextBox('description', _('Descripción'))
            )
            ->addField(
                (new CWidgetFieldColor('chart_color', _('Color')))->setDefault('FF0000')
            );
    }
}

CWidgetFormView

La clase CWidgetFormView es necesaria para especificar la lógica de presentación de los campos definidos en la clase WidgetForm, determinando su apariencia y comportamiento cuando se representan en la vista de configuración.

La clase CWidgetFormView admite los siguientes métodos:

  • addField() - recibe una instancia de la clase CWidgetFieldView como parámetro; cada clase CWidgetField tiene una clase CWidgetFieldView respectiva para usar en la vista de configuración del widget.
  • addFieldset() - recibe una instancia de la clase CWidgetFieldsGroupView que combina campos en un contenedor colapsable.
  • addFieldsGroup() - recibe una instancia de CWidgetFormFieldsetCollapsibleView que combina visualmente (con un borde) los campos en un grupo.
  • includeJsFile() - permite añadir un archivo JavaScript a la vista de configuración del widget.
  • addJavaScript() - permite añadir JavaScript en línea que se ejecutará tan pronto como se cargue la vista de configuración del widget.

La clase CWidgetFormView debe ubicarse en el directorio views.

Ejemplo de views/widget.edit.php

<?php

/**
 * Mi vista de formulario de widget personalizada.
 *
 * @var CView $this
 * @var array $data
 */

use Modules\MyCustomWidget\Includes\WidgetForm;

(new CWidgetFormView($data))
    ->addField(
        (new CWidgetFieldMultiSelectItemView($data['fields']['itemid']))->setPopupParameter('numeric', true)
    )
    ->addFieldset(
        (new CWidgetFormFieldsetCollapsibleView(_('Configuración avanzada')))
            ->addField(
                new CWidgetFieldTextBoxView($data['fields']['description'])
            )
            ->addField(
                new CWidgetFieldColorView($data['fields']['chart_color'])
            )
    )
    ->includeJsFile('widget.edit.js.php')
    ->addJavaScript('my_custom_widget_form.init('.json_encode([
        'color_palette' => WidgetForm::DEFAULT_COLOR_PALETTE
    ]).');')
    ->show();

JavaScript

Se puede utilizar una clase JavaScript para añadir comportamiento dinámico e interactividad a la vista de configuración del widget. Por ejemplo, puede inicializar un selector de color, definido en la clase CWidgetFormView.

La clase JavaScript debe cargarse con el formulario, por lo tanto, debe ser referenciada en la clase CWidgetFormView utilizando los métodos includeJsFile() y addJavaScript().

En el siguiente ejemplo, se crea inmediatamente una instancia de clase singleton y se almacena bajo el nombre window.my_custom_widget_form. Así, al abrir el formulario por segunda vez, se volverá a crear la instancia.

La clase JavaScript debe ubicarse en el directorio views.

Ejemplo de views/widget.edit.js.php

<?php

use Modules\MyCustomWidget\Widget;

?>

window.my_custom_widget_form = new class {

    init({color_palette}) {
        colorPalette.setThemeColors(color_palette);

        for (const colorpicker of jQuery('.<?= ZBX_STYLE_COLOR_PICKER ?> input')) {
            jQuery(colorpicker).colorpicker();
        }

        const overlay = overlays_stack.getById('widget_properties');

        for (const event of ['overlay.reload', 'overlay.close']) {
            overlay.$dialogue[0].addEventListener(event, () => { jQuery.colorpicker('hide'); });
        }
    }
};

CWidgetField

La clase CWidgetField es una clase base de la que heredan todas las clases de campos de formulario (CWidgetFieldCheckBox, CWidgetFieldTextArea, CWidgetFieldRadioButtonList, etc.). Las clases que extienden CWidgetField son responsables de recibir, guardar y validar los valores de configuración del widget.

Las siguientes clases CWidgetField están disponibles.

CWidgetField class Database field type Description
CWidgetFieldCheckBox int32 Casilla de verificación única.
CWidgetFieldCheckBoxList array of int32 Varias casillas de verificación bajo un único campo de configuración.
CWidgetFieldColor string Campo de selección de color.
CWidgetFieldDatePicker string Campo de selección de fecha.
CWidgetFieldIntegerBox int32 Campo para introducir un entero. Puede usarse para configurar valores mínimos y máximos.
CWidgetFieldLatLng string Cuadro de texto que permite introducir latitud, longitud y nivel de zoom del mapa separados por comas.
CWidgetFieldMultiSelect - Clase base para campos de selección múltiple, extendida por todas las clases CWidgetFieldMultiSelect*.
CWidgetFieldMultiSelectAction ID Campo de selección múltiple para elegir acciones de la lista de acciones definidas en Alerts → Actions.
CWidgetFieldMultiSelectGraph ID Campo de selección múltiple para elegir gráficos personalizados.
CWidgetFieldMultiSelectGraphPrototype ID Campo de selección múltiple para elegir prototipos de gráficos personalizados.
CWidgetFieldMultiSelectGroup ID Campo de selección múltiple para elegir grupos de hosts.
CWidgetFieldMultiSelectHost ID Campo de selección múltiple para elegir hosts.
CWidgetFieldMultiSelectHostInventory array of int32 Campo de selección múltiple para elegir campos de inventario de host.
CWidgetFieldMultiSelectItem ID Campo de selección múltiple para elegir items.
CWidgetFieldMultiSelectItemPrototype ID Campo de selección múltiple para elegir prototipos de items.
CWidgetFieldMultiSelectMap ID Campo de selección múltiple para elegir mapas.
CWidgetFieldMultiSelectMediaType ID Campo de selección múltiple para elegir tipos de medio.
CWidgetFieldMultiSelectOverrideHost ID Campo de selección múltiple para elegir una fuente de datos para hosts desde un dashboard u otro widget.
CWidgetFieldMultiSelectService ID Campo de selección múltiple para elegir servicios.
CWidgetFieldMultiSelectSla ID Campo de selección múltiple para elegir SLAs.
CWidgetFieldMultiSelectUser ID Campo de selección múltiple para elegir usuarios.
CWidgetFieldNavTree array of (multiple mixed) Almacena una estructura de árbol de navegación de mapas para su uso en el widget Map navigation tree.
CWidgetFieldNumericBox string Campo para introducir un número decimal.
CWidgetFieldPatternSelect - Clase base para campos de selección por patrón, extendida por todas las clases CWidgetPatternSelect*.
CWidgetFieldPatternSelectHost string Campo de selección múltiple para elegir hosts. Admite patrones de nombre de host.
CWidgetFieldPatternSelectItem string Campo de selección múltiple para elegir items. Admite patrones de nombre de item.
CWidgetFieldRadioButtonList int32 Grupo de botones de opción que consta de uno o más botones de opción.
CWidgetFieldRangeControl int32 Deslizador para seleccionar un valor de tipo entero.
CWidgetFieldReference string Almacena un identificador único para este widget en el dashboard; se usa para la comunicación entre widgets.
CWidgetFieldSelect int32 Cuadro desplegable de selección.
CWidgetFieldSeverities array of int32 CWidgetFieldCheckBoxList preconfigurado con severidades de trigger.
CWidgetFieldSparkline array of (multiple mixed) Permite configurar un gráfico sparkline.
CWidgetFieldTags array of (string, int32, string) Permite configurar una o más filas de filtro de etiquetas.
CWidgetFieldTextArea string Área de texto para introducir texto multilínea.
CWidgetFieldTextBox string Cuadro de texto para introducir texto de una sola línea.
CWidgetFieldThresholds array of (string, string) Permite configurar pares de color y número.
CWidgetFieldTimePeriod array of string Campo de selección de período de tiempo.
CWidgetFieldTimeZone string Lista desplegable con zonas horarias.
CWidgetFieldUrl string Cuadro de texto que permite introducir URL.

La longitud máxima para los campos int32 es de 10 caracteres, para los campos ID de 20 caracteres y para los campos string de 2048 caracteres. Para los tipos compuestos (por ejemplo, array of (string, int32, string)), el límite se aplica a cada elemento de forma individual. Las restricciones de longitud específicas de cada campo pueden establecerse mediante métodos como setMaxLength().