React Hierarchical Grid Column Hiding

    El Ignite UI for React tiene una interfaz de usuario de ocultación de columnas integrada, que se puede usar a través de la barra de herramientas de cuadrícula jerárquica React para cambiar el estado visible de las columnas. Los desarrolladores tienen la flexibilidad de definir la interfaz de usuario de ocultación de columnas en cualquier lugar de la página según sea necesario. La función de ocultación de columnas de cuadrícula jerárquica React es especialmente útil cuando se desea disminuir el tamaño de la cuadrícula y eliminar la necesidad de tabular a través de campos redundantes.

    React Hierarchical Grid Column Hiding Example

    Hierarchical Grid Setup

    Empecemos creando nuestroIgrHierarchicalGrid y vinculándolo a nuestros datos. También activaremos tanto el filtrado como la ordenación de las columnas.

    <IgrHierarchicalGrid autoGenerate={false} data={singersData} primaryKey="ID" allowFiltering={true} ref={hierarchicalGrid1Ref}>
        <IgrColumn field="Artist" header="Artist" dataType="string" sortable={true}></IgrColumn>
        <IgrColumn field="Photo" header="Photo" dataType="image"></IgrColumn>
        <IgrColumn field="Debut" header="Debut" dataType="number" hidden={true}></IgrColumn>
        <IgrColumn field="GrammyNominations" header="Grammy Nominations" dataType="number" sortable={true} hidden={true}></IgrColumn>
        <IgrColumn field="GrammyAwards" header="Grammy Awards" dataType="number" sortable={true}></IgrColumn>
    </IgrHierarchicalGrid>
    

    Toolbar's Column Hiding UI

    La interfaz integrada de ocultación de columnas está situada dentro de unaDropDown barra de herramientas de laIgrHierarchicalGrid zona. Podemos mostrar/ocultar la interfaz de ocultación de columnas usando exactamente este desplegable.

    Para este propósito, todo lo que tenemos que hacer es establecer tanto elIgrGridToolbarActions como elIgrGridToolbarHiding interior de elIgrHierarchicalGrid.

    <IgrHierarchicalGrid>
        <IgrGridToolbar>
            <IgrGridToolbarActions>
                <IgrGridToolbarHiding></IgrGridToolbarHiding>
            </IgrGridToolbarActions>
        </IgrGridToolbar>
    </IgrHierarchicalGrid>
    

    NosIgrHierarchicalGrid proporciona algunas propiedades útiles para usar la interfaz de ocultación de columnas de la barra de herramientas.

    Usando latitle propiedad, estableceremos el título que se muestra dentro del botón desplegable de la barra de herramientas.

    <IgrHierarchicalGrid>
        <IgrGridToolbar>
            <IgrGridToolbarActions>
                <IgrGridToolbarHiding title="Column Hiding"></IgrGridToolbarHiding>
            </IgrGridToolbarActions>
        </IgrGridToolbar>
    </IgrHierarchicalGrid>
    

    Puede ver el resultado del código de arriba al principio de este artículo en la sección Ejemplo de ocultación de columna React.

    Disable hiding of a column

    Podemos evitar fácilmente que el usuario pueda ocultar columnas a través de la interfaz de ocultación de columnas simplemente configurando sudisableHiding propiedad como true.

    <IgrHierarchicalGrid>
        <IgrColumn field="Artist" dataType="string" sortable={true} disableHiding={true}></IgrColumn>
        <IgrColumn field="GrammyAwards" dataType="string" sortable={true} disableHiding={true}></IgrColumn>
    
        <IgrRowIsland>
            <IgrColumn field="Album" dataType="string" sortable={true} disableHiding={true}></IgrColumn>
        </IgrRowIsland>
    </IgrHierarchicalGrid>
    

    Styling

    La cuadrícula se puede personalizar aún más configurando algunas de las variables CSS disponibles. Para lograrlo usaremos una clase que primero asignaremos al grid:

    <IgrHierarchicalGrid className="hierarchical-grid"></IgrHierarchicalGrid>
    

    Luego establece las variables CSS relacionadas para los componentes relacionados. Aplicaremos los estilos también solo en eligx-column-actions, para que el resto de la cuadrícula no se vea afectado:

    .hierarchical-grid {
        /* Main Column Actions styles */
        --ig-column-actions-background-color: #292826;
        --ig-column-actions-title-color: #ffcd0f;
    
        /* Checkbox styles */
        --ig-checkbox-tick-color: #292826;
        --ig-checkbox-label-color: #ffcd0f;
        --ig-checkbox-empty-color: #ffcd0f;
        --ig-checkbox-fill-color: #ffcd0f;
    
        /* Input styles */
        --ig-input-group-idle-text-color: white;
        --ig-input-group-filled-text-color: #ffcd0f;
        --ig-input-group-focused-text-color: #ffcd0f;
        --ig-input-group-focused-border-color: #ffcd0f;
        --ig-input-group-focused-secondary-color: #ffcd0f;
    
        /* Buttons styles */
        --ig-button-foreground: #292826;
        --ig-button-background: #ffcd0f;
        --ig-button-hover-background: #404040;
        --ig-button-hover-foreground: #ffcd0f;
        --ig-button-focus-background: #ffcd0f;
        --ig-button-focus-foreground: black;
        --ig-button-focus-visible-background: #ffcd0f;
        --ig-button-focus-visible-foreground: black;
        --ig-button-disabled-foreground: #ffcd0f;
    }
    

    Demo

    API References

    En este artículo hemos aprendido a usar la interfaz de ocultación de columnas integrada en laIgrHierarchicalGrid barra de herramientas. La columna que oculta la interfaz tiene algunas APIs más por explorar, que se enumeran a continuación.

    • ColumnActionsComponent

    Componentes adicionales con API relativas que se utilizaron:

    IgrColumn properties:

    IgrGridToolbar properties:

    • showProgress

    IgrGridToolbar methods:

    IgrHierarchicalGrid events:

    • ColumnVisibilityChanged

    Additional Resources

    Nuestra comunidad es activa y siempre da la bienvenida a nuevas ideas.