Edición de cuadrícula de árbol de Web Components
La característica de edición de celdas de Ignite UI for Web Components de la cuadrícula de árbol de Web Components proporciona una manera sencilla de realizar operaciones de manipulación de datos, como crear, actualizar y eliminar registros. Le IgcTreeGridComponent
proporciona una potente API pública que le permite personalizar la forma en que se realizan estas operaciones. Las fases de manipulación de datos son:
- Edición de celdas
- Edición de filas
- Edición por lotes (próximamente)
Setup
Para especificar qué modo de edición debe habilitarse, el IgcTreeGridComponent
expone las siguientes propiedades booleanas -editable
and rowEditable
.
La propiedad editable
le permite especificar las siguientes opciones:
- falso: se deshabilitará la edición de la columna correspondiente. Este es el valor predeterminado.
- verdadero: se habilitará la edición de la columna correspondiente.
Tenga en cuenta que si la columna no es editable, aún puede modificar su valor a través de la API pública expuesta por el
IgcTreeGridComponent
.
La propiedad rowEditable
le permite especificar las siguientes opciones:
- falso: se deshabilitará la edición de filas en la cuadrícula correspondiente. Este es el valor predeterminado.
- verdadero: se habilitará la edición de filas en la cuadrícula correspondiente.
En el IgcTreeGridComponent
caso de que establezca rowEditable
la propiedad en true y la propiedad no esté definida explícitamente para ninguna columna, la edición se habilitará para todas las columnas excepto la editable
clave principal.
- Edición de celdas y por lotes: en este escenario, cada modificación de cada celda se conserva por separado y las operaciones de deshacer/rehacer están disponibles a nivel de celda;
- Edición de filas y por lotes: en este escenario, las modificaciones se conservan a nivel de fila, por lo que las operaciones de deshacer/rehacer no funcionarán para cada celda que se modifique, sino para el grupo de celdas de cada fila.
Editing Templates
Si desea utilizar plantillas de edición específicas de un tipo de datos, debe especificar la propiedad dataType
de la columna. Entonces veamos ahora cuáles son las plantillas predeterminadas para cada tipo:
- Para el tipo de datos
string
, la plantilla predeterminada utilizaIgcInputComponent
. - Para el tipo de datos
number
, la plantilla predeterminada utilizaIgcInputComponent
tipo = "número", por lo que si intenta actualizar la celda a un valor que no se puede analizar como un número, su cambio se descartará y el valor en la celda será establecido en 0. - Para el tipo de datos
date
, la plantilla predeterminada utilizaIgcDatePickerComponent
- Para el tipo de datos
dateTime
, la plantilla predeterminada utilizaDateTimeEditor
. Este editor le dará instrucciones de máscara para los elementos de entrada que forman parte del objeto DateTime. - Para el tipo de datos
time
, la plantilla predeterminada utilizaTimePicker
. - Para el tipo de datos
boolean
, la plantilla predeterminada utilizaIgcCheckboxComponent
. - Para el tipo de datos
currency
, la plantilla predeterminada utilizaInputGroup
con configuración de prefijo/sufijo basada en la configuración regional de la aplicación o la cuadrícula. - Para el tipo de datos
percent
, la plantilla predeterminada utilizaInputGroup
con un elemento de sufijo que muestra una vista previa del valor editado en porcentajes.
Todos los tipos de datos de columna disponibles se pueden encontrar en el tema oficial Tipos de columna.
Event Arguments and Sequence
La cuadrícula expone una amplia gama de eventos que brindan un mayor control sobre la experiencia de edición. Estos eventos se activan durante el ciclo de vida de Edición de filas y Edición de celdas: al iniciar, confirmar o cancelar la acción de edición.
Evento | Descripción | Argumentos | Para interrumpir |
---|---|---|---|
RowEditEnter |
SiRowEditing está habilitado, se activa cuando una fila ingresa al modo de edición |
IgcGridEditEventArgs |
verdadero |
CellEditEnter |
Se activa cuando una celda ingresa al modo de edición (después deRowEditEnter ) |
IgcGridEditEventArgs |
verdadero |
CellEdit |
Si se cambia el valor, se activa justo antes de que se confirme el valor de una celda (por ejemplo, presionandoEnter ) |
IgcGridEditEventArgs |
verdadero |
CellEditDone |
Si se cambia el valor, se activa después de que se haya editado una celda y se haya confirmado el valor de la celda. | IgcGridEditDoneEventArgs |
FALSO |
CellEditExit |
Se activa cuando una celda sale del modo de edición | IgcGridEditDoneEventArgs |
FALSO |
RowEdit |
SiRowEditing está habilitado, se activa justo antes de que se confirme el valor de una fila en el modo de edición (por ejemplo, al hacer clic en el botónDone en la superposición de edición de filas) |
IgcGridEditEventArgs |
verdadero |
RowEditDone |
SiRowEditing está habilitado, se activa después de que se haya editado una fila y se haya confirmado el valor de la nueva fila. |
IgcGridEditDoneEventArgs |
FALSO |
RowEditExit |
SiRowEditing está habilitado, se activa cuando una fila sale del modo de edición |
IgcGridEditDoneEventArgs |
FALSO |
Event Cancelation
RowEditEnter
- NiRow
Cell
entrará en modo de edición.CellEditEnter
: evita ingresar a la edición de celdas. SirowEditable
está habilitado, se activará la edición de filas, aunque la edición de celdas seguirá prohibida.CellEdit
- PermitidoCell
y/oRow
editar, al presionar el botón Listo o Enter, no se confirmará la transacción de valor o fila. La edición de celdas y la edición de filas no se cerrarán hasta que se haga clic en el botón Cancelar.RowEdit
: es posible confirmar la celda, pero no toda la fila. La fila permanecerá en modo de edición y la transacción de la fila se considerará abierta. Al presionar Listo no se confirma ni se cierra la fila. El botón Cancelar cierra el proceso de edición y la transacción sin confirmar los cambios.
El siguiente ejemplo demuestra la secuencia de ejecución de edición en acción:
Features integration
Mientras una celda/fila está en modo de edición, un usuario puede interactuar con la cuadrícula de muchas maneras. La siguiente tabla especifica cómo una determinada interacción afecta la edición actual:
Cuadrícula de árbol | Filtración | Clasificación | Paginación | Moviente | Fijar | Ocultación | Agrupar por | Cambiar el tamaño | Escapar | Ingresar | F2 | Pestaña | Clic en la celda | Agregar nueva fila/Eliminar/Editar |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Mantener el modo de edición | ✔ | |||||||||||||
Salir del modo de edición | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | |
Comprometerse | ✔ | ✔ | ✔ | ✔ | ✔ | |||||||||
Desechar | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ |
Como se ve en la tabla, todas las interacciones, excepto cambiar el tamaño de una columna, finalizarán la edición y descartarán los nuevos valores. En caso de que se confirme el nuevo valor, el desarrollador puede hacerlo en el evento "-ing" de característica correspondiente.
Ejemplo de cómo confirmar nuevos valores, si el usuario intenta ordenar la columna mientras una celda/fila está en modo de edición:
<igc-tree-grid id="grid" primary-key="ProductID" >
</igc-tree-grid>
constructor() {
var grid = this.grid = document.getElementById('grid') as IgcTreeGridComponent;
grid.data = this.data;
grid.addEventListener("sorting", this.onSorting);
}
public onSorting(event: IgcSortingEventArgs) {
var grid = document.getElementById('grid') as IgcTreeGridComponent;
grid.endEdit(true);
}