Sin duda, es el control más complejo de los controles personalizados.


Cuando definimos una grid lo hacemos indicando un origen de datos (vista, tabla o colección de objetos) y definiendo sus columnas.

Hay varias maneras de trabajar con este control, veremos unos cuantos ejemplos de cómo utilizarlo, pero antes, es importante tener en cuenta:

  • Utilizan una array de tipo XArrayDB para manejarse. Se puede referenciar mediante [NombreGrid].ArrayDB.
  • Si queremos utilizar el grid sólo como un Array, sin que los cambios se vean reflejados en tablas, debemos poner sus propiedades SoloArray = true y Refresca = false.
  • Si la propiedad Refresca = true el grid se refrescará siempre que se actualice un campo.
  • Si el grid permite insertar filas recuerde que puede controlar el valor de los campos a insertar mediante la propiedad Default del campo. Se utiliza frecuentemente para controlar la inserción de campos clave o campos incrementales.
  • Puede definir asistentes para los campos, de modo que al pulsar F3 en una celda con asistente le saldrá una pantalla de búsqueda.
  • Si la grid tiene la propiedad CargaObjeto=False, cuando actualizamos un registro significa que NO estamos actualizando el objeto. La grid no podrá contener los campos de la tabla configurables del objeto.
  • Si la grid tiene la propiedad CargaObjeto=True, cuando actualizamos un registro significa que estamos actualizando el objeto. Si el objeto tiene campos configurables (por lo tanto una tabla Conf_[Objeto]) y éstos se actualizarán si están reflejados en la grid.

Debido a la magnitud de este control, los ejemplos se desarrollan todos juntos al final de la sección, aunque cada propiedad o método muestre en una línea como usarlo.

 


GridUsuario


EditarPorObjeto


Descripción: Los datos son editados mediante objetos. La grid instancia el objeto y lo actualiza con los datos insertados y llama al método update del objeto. Con esta opción activada, permite guardar datos configurables del objeto. No se recomienda el uso de esta propiedad cuando la grid deba cargar un número elevado de registros, ya que ralentiza tanto la carga como el refresco de la grid.

Tipo: true/ false.


Código en VB6:

Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .EditarPorObjeto = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{		
     if (aGrid.Name == "grdCopias") 
     {
         aGrid.EditarPorObjetoYVista = true;
     }
}



EditarPorObjetoyVista


Descripción: Si , tanto esta propiedad como la anterior, están a True, la lectura de los campos se hará de la vista que pone en el campo EdicionGrid de la tabla Objetos en el registro de la colección. Si no se ha configurado esta vista se leerá de la tabla o vista que especifique el código (From). No se recomienda el uso de esta propiedad cuando la grid deba cargar un número elevado de registros, ya que ralentiza tanto la carga como el refresco de la grid.

Tipo: true/false.


Código en VB6:

Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .EditarPorObjeto = True
       .EditarPorObjetoyVista = True
     End With
   End If
 End Sub

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{		
     if (aGrid.Name == "grdCopias") 
     {
         aGrid.EditarPorObjeto = true;
         aGrid.EditarPorObjetoYVista = true;
     }
}



MuestraCaption


Descripción: Indica si se mostrará o no el caption de la grid

Tipo: true/ false


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .MuestraCaption = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
	if (aGrid.Name == "grdCopias") 
	{
		aGrid.MuestraCaption = true;
	}
}


CaptionBase


Descripción: Es el texto que se mostrará sobre las columnas de la grid. Si no se especifica, mostrará el total de registros.  Si, por el contrario, se especifica y la propiedad ConcatenaCaption = true, se concatena al total de registros, por lo que deberemos dejar un espacio en blanco al final de la cadena.

Tipo: Cadena.


Código en VB6:

Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .CaptionBase = "Copias realizadas "

     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.ConcatenaCaption = true;
    aGrid.CaptionBase = "Copias realizadas: ";
  }
}



ConcatenaCaption


Descripción: Le añade al caption base el número de registros.

Tipo: true / false.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .ConcatenaCaption = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.ConcatenaCaption = true;
  }
}



Agregar


Descripción: Indica si la grid permite agregar registros.

Tipo: true / false.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .Agregar = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.Agregar = true;
  }
}


Editar


Descripción: Indica si la grid permite editar registros.

Tipo: true / false.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .Editar = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.Editar = true;
  }
}



Eliminar


Descripción: Indica si la grid permite eliminar registros.

Tipo: True / False.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .Eliminar = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.Eliminar = true;
  }
}



CargaObjetos


Descripción: Si CargaObjetos = True el origen de datos es las colección, si no, los datos se leen del FROM.

Tipo: True / False.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .CargaObjetos = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.CargaObjetos = true;
  }
}



Colección


Descripción: Le pasaremos la colección de objetos como origen de datos. Para esto necesitamos EditarPorObjeto = True.

Tipo: Colección


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .EditarPorObjeto= True
       .Coleccion = "copias"
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.EditarPorObjeto = true;
    aGrid.Coleccion = gCn.Obj.DameColeccion("Copias", "");
  }
}



From


Descripción: Indica la tabla, vista o consulta que se utilizará como origen de datos. Intente siempre utilizar vistas o tablas directamente. Si desea emplear una consulta combinando tablas, debe especificar un Alias. Cuente con que el control hace un "SELECT columnas FROM XXX". Especifique sólo el origen de datos.

Tipo: String.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .From = "VPers_Copias"
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.From = "VPers_Copias";
  }
}



Alias


Descripción: Si especificamos un FROM de tipo consulta empleando tablas combinadas, ésta propiedad indicará a las columnas del grid el Alias de tabla por defecto.

Tipo: String. Ver ejemplo de grid usando alias.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .Alias = "VistaPers"
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.Alias = "VistaPers";
  }
}



FetchRowStyle


Descripción: Indica que cuando se refresque la grid, se activará el evento GridFetchRowStyle. Se utiliza generalmente cuando necesitamos pintar las filas del grid de acuerdo a algún valor dado.

Tipo: true/false.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .Grid.FetchRowStyle = True
     End With
   End If
 End Sub 'Para configurar las reglas de color, debe hacerse desde la configuración de la grid.

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.FetchRowStyle = true;
  }
}



TablaObjeto


Descripción: Especifica la tabla en la que se van a guardar los datos del grid. Un grid puede tener un origen de datos distinto a la tabla donde se almacena. Guardará todos los datos que coincidan con los campos de la grid.

Tipo: String


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .TablaObjeto = "Pers_Copias"
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.TablaObjeto = "Pers_Copias";
  }
}


Where


Descripción: Cláusula WHERE completa para filtrar el origen de datos.

Tipo: String


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .Where = "WHERE liquidada=False "
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.Where = "WHERE Liquidada = False";
  }
}


OrdenMultiple


Descripción: Nombre de las columnas por las que queremos filtrar separadas por ",". Si se quiere en orden descendente añadir "DESC" tras la columna.

Tipo: String


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .OrdenMultiple = "IdEmpleado, FechaAlta"
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.OrdenMultiple = "IdEmpleado, FechaAlta";
  }
}


Preparada


Descripción: Devuelve True cuando tiene columnas creadas. Se utiliza para saber si la grid ya ha sido inicializada.

Tipo: Boolean.


Código en VB6:

 Private Sub CargarLineas()
   On Error GoTo Error_    
   With gForm.Controls("grdCopias")
     If not Preparada then
        'Acciones a hacer la primera vez que se carga la grid     
     End If
   End With
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    if (!aGrid.Preparada) 
    {
      // Acciones a hacer la primera vez que se carga la grid    
    }
  }
}

SoloArray


Descripción: Si el valor es True especifica que queremos trabajar sin que el grid actualice los datos en la tabla.

Tipo: Boolean.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .SoloArray = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.SoloArray = true;
  }
}



Refresca


Descripción: Si el valor es True especifica que se refresque el grid cada vez que se inserte, modifique o elimine un registro.

Tipo: Boolean.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .Refresca = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.Refresca = true;
  }
}


NoUsarIdDocs


Descripción: Cuando utilizamos un origen de datos que carece del campo IdDoc pondremos ésta propiedad a True para que no dé error al actualizar, ya que el control necesita de un campo Identidad para realizar las actualizaciones. Use esta propiedad cuando quiera una grid en casos especiales de sólo consulta o sólo array.

Tipo: Boolean.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .NoUsarIdDocs = True
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.NoUsarIdDocs = true;
  }
}



ColumnaEscalada


Descripción: Establece la columna que debe crecer al maximizar el grid.

Tipo: String.


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)
   If agrid.name = "grdCopias" Then
     With gForm.Controls("grdCopias")
       .ColumnaEscalada = "Descrip"
     End With
   End If
 End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias") 
  {
    aGrid.ColumnaEscalada = "Descrip";
  }
}



ArrayDB


Descripción: Array en el que se basa la grid.

Tipo: XArrayDB.


Código en VB6:

 Sub ejArrayDB 
    Set lArray = gform.Controls("grdCopias").ArrayDb 
    For i = lArray.LowerBound(1) To lArray.UpperBound(1)  
        MsgBox lArray(i, 1) 
    Next 
End Sub 

Código en C#:

private void EjArrayDB()
{
  IXArrayDB lArray = (gForm.Controls["grdCopias"] as ICntGridUsuario).ArrayDb;
  for (int i = lArray.LowerBound(1); i <= lArray.UpperBound(1); i++)
  {
    AhoraCore.VBA.Interaction.MsgBox(lArray[i, 1].ToString());
  }
}



ArrayValue (fila,columna)


Descripción: Devuelve o establece un valor dentro del array del grid, donde la fila es un Long y la columna String. En C# esta propiedad se ha convertido en la propiedad por defecto de ICntGridUsuario lo que nos ha permitido indizarla directamente. En el ejemplo adjunto pueden ver como se usa en este lenguaje.

Tipo: Valor.


Código en VB6:

 Private Sub SumarTotal()
   With grdCopias
     For i = 0 To .Grid.ApproxCount - 1
       lTotal = lTotal + .ArrayValue(i, "Total")
   End With
 End Sub 

Código en C#:

private int SumarTotal()
{
  int lTotal = 0;
  ICntGridUsuario grdCopias = (gForm.Controls["grdCopias"] as ICntGridUsuario);
  if (grdCopias != null)
  {
    for (int i = 0; i < grdCopias.ApproxCount -1; i++)
    {
      lTotal = lTotal + CInt(grdCopias[i, "Total"]);
    }
  }
  return lTotal;
}



SQLSelect


Descripción: Instrucción SQL completa que toma el grid como origen de datos. Es la unión final de todas las instrucciones dadas (Columnas, FROM, WHERE, UNION)

Tipo: String.


Código en VB6:

 Sub MostrarSelect()
   MsgBox gform.Controls("grdCopias").SQLSelect
 EndSub 

Código en C#:

private void MostrarSelect()
{
  ICntGridUsuario grdCopias = (gForm.Controls["grdCopias"] as ICntGridUsuario);
  AhoraCore.VBA.Interaction.MsgBox(grdCopias.SqlSelect());
}



ActivarScripts


Descripción: Activa/Desactiva la ejecución de scripts de de la grid. Si no se activa, la programación de pantalla que tienen los eventos de la grid, no se lanzará.

Tipo: True/False (por defecto, False).


Código en VB6:

Sub Show()
 gForm.Controls("grdLineas").ActivarScripts = True

End Sub

Código en C#:

private void Show()
{
  (gForm.Controls["grdCopias"] as ICntGridUsuario).ActivarScripts = true;
}


AgregaColumna


Descripción: Este método crea las columnas en el grid. Son objetos de tipo CampoGrid y accederemos a las columnas del grid mediante la estructura: [NombreGrid].Campo ("NombreDeCampo").


Parámetros de entrada:


Parámetros obligatorios:


-  Campo (String): Especifica el nombre del campo del origen de datos.

-  Ancho (LONG): Establece el ancho de la columna (en TWIPS).

-  Descripción (String): Especifica el nombre de la cabecera de la columna.


Parámetros Opcionales:


-  Locked (Boolean): Indica que el campo se bloquea y no se puede modificar.

-  Combo (String): Consulta SQL con los campos que queremos que muestre el combo. El primer campo es el que quedará en la celda al seleccionar el dato de la lista y los restantes los que desplegará el combo. Ejemplo: SELECT IdArticulo Art, IdArticulo, Descrip FROM Articulo         


Si queremos que se quede la descripción lo haremos de la siguiente manera: SELECT Descrip Desc, IdArticulo, Descrip FROM Aticulos    

   
La consulta también puede hacer referencia a un campo de la grid. Por ejemplo si en el grid tenemos un campo IdFamilia y queremos que el combo nos muestre solo los artículos de esa familia. Para hacer referencia a un campo de la grid, en la sentencia SELECT lo especificamos con "@nombrecampo". Ejemplo: SELECT IdArticulo Art, IdArticulo, Descrip FROM Articulos WHERE IdFamilia = @IdFamila


-  RowRefreshCombo (Boolean): Establece que se refresque el combo al cambiar de celda, siempre y cuando la consulta del combo dependa de otro campo (como en el ejemplo anterior).

-  Format (String): Indica el formato de visualización del campo. Ejemplo numérico con tres decimales: "#,##0.000". Ejemplos fecha: "mm/dd/yyyy", "yyyymmdd", etc.


-  Total (Boolean): Indica si debe agregar un campo al final con la suma de los campos la columna.

-  Valores (String): Sentencia SQL que especifica el valor del combo que queremos que se vea en la celda. Por ejemplo, si quiero seleccionar del combo el IdArticulo y que éste se almacene en tabla, pero mostrar en pantalla (y en la misma celda) la descripción.


El combo quedaría de ésta manera: SELECT IdArticulo Art, IdArticulo, Descrip FROM Articulos    
Mientras que el parámetro valores sería: SELECT IdArticulo, Descrip FROM Articulos
Así estaríamos guardando el IdArtículo seleccionado, pero en la celda se visualizaría la descripción.


-  EsResourceID (Boolean): Indica que el valor del campo será un Icono. Con lo cual cargará en la celda la imagen correspondiente. Siempre depende de la propiedad valor. Por ejemplo para cargar un Icono, la SELECT debería ser: SELECT Objeto Obj, Objeto, Icono1 FROM Objetos

-  ValorFiltro: OBSOLETO. NO USAR

-  Obligado (Boolean): Indica que el campo es obligatorio. Si el usuario no lo completa, saldrá un mensaje advirtiendo ésto.


Parámetros de salida: True/False, devuelve True si la columna se ha podido crear.


Código en VB6:

 Sub Initialize()
   With gForm.Controls("grdUserStock")
     .activarscripts = True
     .from = "Pers_VStockMinimos"
     .agregacolumna "IdProveedorPreferencial",1000,"Id. Prov"
     .agregacolumna "Proveedor",1000,"Proveedor"
     .campo("IdProveedorPreferencial").Column.Order = 2
     .campo("Proveedor").Column.Order = 3
     Set gForm.Controls("filStockMinimo").GridUsuario = 
         Form.Controls("grdUserStock")
     .SoloArray = False
     .refrescar
     .SoloArray = True    
   End With
 End Sub 

Código en C#:

private void Initialize()
{
  ICntGridUsuario grdUserStock = (gForm.Controls["grdUserStock"] as ICntGridUsuario);
  ICntFiltroUsuario filStockMinimo = (gForm.Controls["filStockMinimo"] as ICntFiltroUsuario);

  grdUserStock.ActivarScripts = true;
  grdUserStock.From = "Pers_VStocksMinimos";
  grdUserStock.AgregaColumna("IdProveedorPreferencial", 75, "Id.Prov.");
  grdUserStock.AgregaColumna("Proveedor", 250, "Proveedor");
  grdUserStock.Campo("IdProveedorPreferencial").Orden = 2;
  filStockMinimo.GridUsuario = grdUserStock;
  grdUserStock.SoloArray = false;
  grdUserStock.Refrescar();
  grdUserStock.SoloArray = true;
}


GetValue


Descripción: Devuelve el valor del campo dado de la fila activa

Parámetros de entrada: Nombre del campo (String)

Parámetros de salida: Valor del campo dado (Variant)


Código en VB6:

 Sub Grid_BeforeUpdate(aGrid,aCancel)
   If aGrid.GetValue("Bloqueado")=True Then
     MsgBox "No se puede actualizar una copia bloqueada",vbCritical
     aCancel=True   
   End If
 End Sub 

Código en C#:

//Para Activar este evento hay que configurar la grid. Poner en el void Initialize por ejemplo: (gForm.Controls["grdLineas"] as ICntGridUsuario).ActivarScripts = true;
public void Grid_BeforeUpdate(ICntGridUsuario aGrid, Valor aCancel)
{
	if (aGrid.GetValue("Bloqueado"))
	{
		AhoraCore.VBA.Interaction.MsgBox("No se puede actualizar una copia bloqueada", vbCritical);
		aCancel = true;
	}
}


GridClear


Descripción: Borra el contenido de la grid

Parámetros de entrada: si reestablece las columnas, encabezados y otras propiedades en función del datasource actual (Boolean, opcional, por defecto True)


Código en VB6:

 Sub LlamaGridClear()
   gForm.Controls("grdCopias").GridClear
 End Sub

Código en C#:

private void LlamaGridClear()
{
  (gForm.Controls["grdCopias"] as ICntGridUsuario).GridClear();
}



LimpiaGrid


Descripción: Borra el contenido de la grid y elimina las columnas creadas

Parámetros de salida:


Código en VB6:

 Sub LlamaLimpiaGrid()
   gForm.Controls("grdCopias").LimpiaGrid
 End Sub

Código en C#:

private void LlamaLimpiaGrid()
{
  (gForm.Controls["grdCopias"] as ICntGridUsuario).LimpiaGrid();
}


Imprimir


Descripción: Imprime la grid

Parámetros de entrada: Título de página(String, opcional),  si la grid tiene los parámetros de impresión configurados (Booleano, opcional, por defecto True). Si el segundo parámetro está a True, no hará caso al primero.

Parámetros de salida: True/False, devuelve True si la grid se ha mandado a la impresora correctamente.

Código en VB6:

 Sub LlamaImprimeGrid()
   gForm.Controls("grdCopias").Imprimir
 End Sub

Código en C#:

private void LlamaImprimeGrid()
{
  (gForm.Controls["grdCopias"] as ICntGridUsuario).Imprimir();
}


MenuItemAdd


Descripción: Inserta un botón en el menú popup de la grid. Es el mismo método de inserción de botones de menú y botonera. Cuando se presiona un botón popup de la grid, se activa el evento MenuClick. Hay que tener en cuenta que al añadir una opción de menú, también hay que implementar la acción de dicho menú.

Parámetros de entrada: : Caption del Botón(String), Id (String), Tipo de botón (String), Padre (Id del menú cuelga el botón, si no se especifica se entiende que es Padre), Nuevo Grupo (línea separadora que separará el botón de los anteriores) (Booleano), ResId (idIcono de la tabla Iconos_Recursos), Before (si queremos colocarlo antes de otro botón especificamos el nombre del botón).          
Los tipos de botones son:

  • eTipo_Menu_Boton (Botón convencional)
  • eTipo_Menu_Check (botón de tipo check)
  • eTipo_Menu_Combo (sólo para el control Botonera)
  • eTipo_Menu_Edit (Botón con caja de texto para edición)
  • eTipo_Menu_Menu (Botón de tipo menú de cabecera)

Parámetros de salida: El objeto AhoraTool creado


Código en VB6:

 Sub Grid_BeforeLoad(aGrid)  
    If aGrid.Name = "grdCopias" Then aGrid.MenuItemAdd "Duplicar copia",  "mnuDuplicar", 0 , ,True, False, 123 
End Sub  
Sub grid_MenuAfterExecute(aGrid, aMenuItem)  
    If amenuitem.Name ="mnuDuplicar" Then   
        Duplicar  
    End If 
End Sub 

Código en C#:

public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdCopias")
  {
    aGrid.MenuItemAdd("Duplicar copia", "mnuDuplicar", ETipo_Menu.eTipo_Menu_Boton, "", true, false, 123);
  }
}
//Para Activar este evento hay que configurar la grid. Poner en el void Initialize por ejemplo: (gForm.Controls["grdLineas"] as ICntGridUsuario).ActivarScripts = true;
public void Grid_MenuAfterExecute(ICntGridUsuario aGrid, IAhoraTool aMenuItem)
{
  if (aMenuItem.Name == "mnuDuplicar")
  {
    // Duplicar
  }
}


PasoExcel


Descripción: Exporta a Excel el contenido de la grid

Parámetros de salida: True/False, devuelve True si la exportación no da ningún error.


Código en VB6:

 Sub LlamaPasoExcel()
   gForm.Controls("grdCopias").PasoExcel
 End Sub 

Código en C#:

private void LlamaPasoExcel()
{
  (gForm.Controls["grdCopias"] as ICntGridUsuario).PasoExcel();
}


Refrescar


Descripción: Refresca la grid.

Código en VB6:

 gForm.Controls("grdCopias").Refrescar

Código en C#:

(gForm.Controls["grdCopias"] as ICntGridUsuario).Refrescar();


SetValue


Descripción: Modifica el campo por el valor dado en la fila activa.

Parámetros de entrada: Campo (String), Valor (Variant)

Parámetros de salida: True/False, devuelve True si se ha modificado el valor correctamente

Código en VB6:

 Sub ejSetValue
gForm.Controls("grdCopias").setvalue "FechaIni", "01/01/2015"
End Sub

Código en  C#:

private void EjSetValue()
{
(gForm.Controls["grdCopias"] as ICntGridUsuario).SetValue("FechaIni", "01/01/2015");
}


Eventos

La mayoría de los eventos suelen tener un nombre autoexplicativo y, en su mayoría, son los que suelen tener las grids estándar.



MenuClick

Descripción: se dispara cuando hacemos clic en un botón del menú popup del grid


GridLoad

Descripción: se dispara cuando se refresca la grid, es decir, cuando llamamos al método refrescar o cuando actualizamos un registro.



Campo (NombreCampo)


Este objeto es el campo, propiamente dicho, del grid. En este objeto se guardan las propiedades mencionadas en el método AgregaColumna( ) del grid.

Tipo: CampoGrid.


Código en VB6:

gForm.Controls("grdCopias").Campo("IdCopia").Booleano = False

Código en C#:

(gForm.Controls["grdCopias"] as ICntGridUsuario).Campo("IdCopia").Booleano = false;




Sustitucion

Descripción: Valor que tomará el campo cuando se actualice una celda de la misma fila.

Tipo: String.


Código en VB6:

gForm.Controls("grdCopias").Campo("IdCopia").Sustitucion = "SELECT NuevoValor FROM Tabla"

Código en C#:

(gForm.Controls["grdCopias"] as ICntGridUsuario).Campo("IdCopia").Sustitucion = "SELECT NuevoValor FROM Tabla";


Booleano

Descripción: Dibuja un control CheckBox

Tipo: Boolean.


Código en VB6:

gForm.Controls("grdCopias").Campo("IdCopia").Booleano = False

Código en C#:

(gForm.Controls["grdCopias"] as ICntGridUsuario).Campo("IdCopia").Booleano = false;


CampoFecha

Descripción: Establece un control Fecha para el campo.

Tipo: String.


Código en VB6:

gForm.Controls("grdCopias").Campo("IdCopia").CampoFecha = False

Código en C#:

(gForm.Controls["grdCopias"] as ICntGridUsuario).Campo("IdCopia").CampoFecha = false;


Default

Descripción: Establece un valor por defecto para los registros nuevos.

Tipo: String.


Código en VB6:

gForm.Controls("grdCopias").Campo("IdCopia").Default = 0;

Código en C#:

(gForm.Controls["grdCopias"] as ICntGridUsuario).Campo("IdCopia").Default = 0;


AsignaAsistente

Descripción: Lanza un AhoraProceso llamado AhoraAsistente. Cuando se pulsa F3 despliega un formulario con filtro para buscar el dato. Este procedimiento sólo define el formulario y va acompañado del método AssistAddField ( ), que definirá las columnas de la grid del asistente.

Parámetros de entrada: Número de Icono que queremos que aparezca en el Form (Long), Instrucción SQL, origen de datos (String), Where, filtro SQL, puede ser una cadena vacía (String), Lista de campos a ordenar separados por comas (String),

Nombre del campo grid. Si queremos que aparezca en el campo del asistente (String, opcional), Ancho del formulario (Long, opcional), Alto del formulario (String, opcional)


Puede consultar información detallada sobre este método en el siguiente artículo.


AssistAddField

Descripción: Define los campos de la grid del asistente F3.

Parámetros de entrada: Nombre del campo que queremos que aparezca en el grid (String), Descripción del campo (String, opcional), Tipo de dato (si se mostrará un String, long, etc) (Long, opcional), Tamaño del campo (Long, opcional), Autosize (Boolean, opcional),Indica que es el campo que queremos que nos retorne. Si no se especifica el asistente nos devuelve el primero que declaremos (Boolean, opcional).


Puede consultar información detallada sobre este método en el siguiente artículo.


CampoNuevaFila

Descripción: Indica qué campo tendrá el foco cuando la grid crea una nieva fila. es decir, la primera vez que se carga o cuando se inserta una línea.

Tipo: cadena.


Código en VB6:

Sub Initialize()
     gform.Controls("Botonera").ActivarScripts = True
End Sub
 
Sub Botonera_AfterExecute(aBotonera, aBoton) 
     If aboton.name = "botGuardar" Then
         Establecefoco
     End If 
End Sub

Sub Establecefoco ()
     Dim g 'As AhoraOCX.cntGridUsuario
     Set g = gForm.Controls("grdlineas")
     If g.rowcount = 0 Then 
         g.CampoNuevaFila = "@CodigoBarras"
     End If
End Sub

Código en C#:

private void Initialize()
{
  (gForm.Controls["grdUserStock"] as ICntBotonera).ActivarScripts = true;
}

public void Botonera_AfterExecute(ICntBotonera aBotonera, IAhoraTool aBoton)
{
  if (aBoton.Name == "botGuardar")
  {
    EstableceFoco();
  }
}

private void EstableceFoco()
{
  AhoraOCX.Form gForm = new AhoraOCX.Form();
  ICntGridUsuario g = (gForm.Controls["grdLineas"] as ICntGridUsuario);
  if (g.RowCount == 0)
  {
    g.CampoNuevaFila = "@CodigoBarras";
  }

}


--------------------------------------------------------------------------------------------------------------


Ejemplo CampoGrid:


Código en VB6:

 Sub Initialize()  
    Set lPnlEjemplos = gForm.Controls.Add("AhoraOCX.cntPanel", "PnlEjemplos")
    lPnlEjemplos.Resized = True  
    lPnlEjemplos.ResizeEnabled = False  
    lPnlEjemplos.ResizeInterior = True  
    lPnlEjemplos.Estilo = 0   
    lPnlEjemplos.Visible = True   
    gForm.TabMain.InsertItem  110, "&Ejemplo", lPnlEjemplos.Hwnd, 1  
    Set lGrid = gForm.Controls.Add("AhoraOCX.cntGridUsuario", "Pers_GrdEjemplo", lPnlEjemplos)
End Sub  

Sub Show()  
    ejCargaGrid 
End Sub  

Sub ejCargaGrid()   
    If gform.eobjeto.objglobal.nuevo = False Then    
        With gForm.Controls("Pers_GrdEjemplo")      
            If Not .Preparada Then        
                .Activarscripts = True        
                .Agregar = True        
                .Editar = True        
                .Eliminar = True        
                .CargaObjetos = False 'al estar a False necesitamos indicar la tabla donde guarda        
                .EditarPorObjeto = False         
                Set .Coleccion = gcn.Obj.DameColeccion("Proveedores_Articulos","WHERE idProveedor = " & gForm.Controls("IdProveedor") ,True,True)       
                .From = "Vprov_Articulos"       
                .AgregaColumna "IdProveedor", 0, "IdProveedor"           
                .AgregaColumna "IdArticulo", 1000, "Id artículo", False, "SELECT IdArticulo, IdArticulo, Descrip FROM VCombo_Articulos"             
                .AgregaColumna "@Descrip", 1000, "Descripción" , True            .AgregaColumna "Precio", 1000, "Precio"        'valor por defecto para el campo IdProveedor y precio       
                .Campo("IdProveedor").Default = gForm.Controls("EObjeto").ObjGlobal.Propiedades("IdProveedor")       
                .Campo("Precio").Default = 0             'Sustituciones       
                .Campo("@Descrip").Sustitucion = "SELECT Descrip FROM VCombo_Articulos WHERE IdArticulo = @IdArticulo"        'Asistentes       
                With .Campo("IdArticulo")         
                    .AsignaAsistente gCn.Obj.Objetos("Articulos").Entorno.Icono1, "vCombo_Articulos", "", "IdArticulo", "IdArticulo", 8000, , False         'Campos del asistente        
                    .AssistAddField "IdArticulo", "Id Artículo", "String", 2000, , True         .AssistAddField "Descrip", "Descripción", "String", 4500       
                End With       
                .ColumnaEscalada = "@Descrip"     
            End If      
            .Visible = True     
            .Refresca = True    
        End With  
    End If 
End Sub 

Código en C#:

using AhoraCl;
using AhoraCore;
using AhoraOCX;
using AhoraSistema;
using static AhoraCore.VBA.Conversion;
using System;

namespace AhoraScriptsPantalla
{
    public class AhoraCl_frmProveedores : AhoraOCX.AhoraBaseScript

    {

    public void Initialize()
    {
      IControl lGrid = null;
      ICntPanel lPnlEjemplos = null;
      try {
        lPnlEjemplos = (ICntPanel)gForm.Controls.Add("AhoraOCX.CntPanel", "PnlEjemplos", null);
        lPnlEjemplos.Resized = true;
        ((IControlResizable) lPnlEjemplos).ResizeEnabled = false;
        ((ICntPanel) lPnlEjemplos).ResizeInterior = true;
        lPnlEjemplos.Estilo = 0;
        lPnlEjemplos.Visible = true;
        ((ICntTab) gForm.Controls["TabMain"]).InsertItem(110, "&Ejemplo", lPnlEjemplos, 1);
        lGrid = gForm.Controls.Add("AhoraOCX.cntGridUsuario", "Pers_GrdEjemplo", lPnlEjemplos);
      } catch (Exception) {
        throw;
      }
    }


    public void Show()
    {
      try {
        ejCargaGrid();
      } catch (Exception) {
        throw;
      }
    }


    public void ejCargaGrid()
    {
      try {
        if (((IEnlaceObjetos) gForm.FindControl("EObjeto")).ObjGlobal.Nuevo == false) {
          if (!((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Preparada) {
            ((IControlScriptable) gForm.Controls["Pers_GrdEjemplo"]).ActivarScripts = true;
                        ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Agregar = true;
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Editar = true;
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Eliminar = true;
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).CargaObjetos = false;
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).EditarPorObjeto = false;
                        ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Coleccion = gCn.Obj.DameColeccion("Proveedores_Articulos", "WHERE idProveedor = " + (gForm.Controls["IdProveedor"] as ITextoUsuario).Text, true, true);
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).From = "Vprov_Articulos";
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).AgregaColumna("IdProveedor", 0, "IdProveedor");
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).AgregaColumna("IdArticulo", 67, "Id artículo", false, "SELECT IdArticulo, IdArticulo, Descrip FROM VCombo_Articulos");
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).AgregaColumna("@Descrip", 67, "Descripción", true);
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).AgregaColumna("Precio", 67, "Precio");
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Campo("IdProveedor").Default = ((IEnlaceObjetos) gForm.Controls["EObjeto"]).ObjGlobal["IdProveedor"];
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Campo("Precio").Default = 0;
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Campo("@Descrip").Sustitucion = "SELECT Descrip FROM VCombo_Articulos WHERE IdArticulo = @IdArticulo";
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Campo("IdArticulo").AsignaAsistente(CStr(gCn.Obj.Objetos["Articulos"].Entorno.Icono1), "vCombo_Articulos", "", "IdArticulo", "IdArticulo", 8000, 0, false);
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Campo("IdArticulo").AssistAddField("IdArticulo", "Id Artículo", ETipoDato.String, 2000, false, true);
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Campo("IdArticulo").AssistAddField("Descrip", "Descripción", ETipoDato.String, 4500);
          
            ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).ColumnaEscalada = "@Descrip";
          }
          gForm.Controls["Pers_GrdEjemplo"].Visible = true;
          ((ICntGridUsuario) gForm.Controls["Pers_GrdEjemplo"]).Refresca = true;
        
        }
      } catch (Exception) {
        throw;
      }
    }

    }

}


Ejemplo Control Grid


Con este código al hacer doble clic sobre una columna ejecutamos una instrucción SQL.

Podemos ver como se piden parámetros para que introduzca el usuario, como se realizan consultas a la base de datos y como se obtienen los valores de una grid:


Código en VB6:

 Sub Initialize()  
    gForm.Controls("grdLineas").ActivarScripts = True 
End Sub  'Para Activar este evento hay que configurar la grid. Poner en el sub Initialize por ejemplo: gForm.grdLineas.ActivarScripts = True  

Sub Grid_DblClick(aGrid)  
    columna    = aGrid.CampoActual  
    idDoc      = aGrid.GetValue("idDoc")   
    If (columna = "Precio") Then   
        NuevoPrecio = InputBox("Nuevo precio: ","Nuevo precio ")    
        If Not IsNumeric(NuevoPrecio) Then     
            MsgBox "El precio introducido no es válido"    
        Else     
            If Not (gcn.executeSql("UPDATE Listas_Precios_Prov_Art SET precio =  " & NuevoPrecio & "  WHERE idDoc = "& idDoc )) Then      
                MsgBox "No se ha modificado correctamente"     
            Else      
                MsgBox "Se ha modificado correctamente"     
            End If   
        End If  
    End If 
End Sub

Código en C#:

public void Initialize()
{
  (gForm.Controls["grdLineas"] as ICntGridUsuario).ActivarScripts = true;
}

//Para Activar este evento hay que configurar la grid. Poner en el void Initialize por ejemplo: (gForm.Controls["grdLineas"] as ICntGridUsuario).ActivarScripts = true;
public void Grid_DblClick(ICntGridUsuario aGrid)
{
  string lColumna = aGrid.CampoActual;
  Valor lIdDoc = aGrid.GetValue("IdDoc");
  if (lColumna == "Precio")
  {
    Valor lNuevoPrecio = AhoraCore.VBA.Interaction.InputBox("Nuevo precio: ", "Nuevo precio ");
    if (!IsNumeric(lNuevoPrecio))
    {
      AhoraCore.VBA.Interaction.MsgBox("El precio introducido no es válido");
    }
    else
    {
      if (!gCn.ExecuteSql("UPDATE Listas_Precios_Prov_Art SET Precio = " + lNuevoPrecio + " WHERE IdDoc = " & lIdDoc))
      {
        AhoraCore.VBA.Interaction.MsgBox("No se ha modificado correctamente");
      }
      else
      {
        AhoraCore.VBA.Interaction.MsgBox("Se ha modificado correctamente");
      }
    }
  }
}


Éste es el evento antes de actualizar la columna del grid, advertimos al usuario que la máquina es genérica. Formulario de inicio de un contrato (frmContratos_Inicio)

Código en VB6:

 Sub Initialize()     
    gForm.grdLineas.ActivarScripts = True   
End Sub  'Para Activar este evento hay que configurar la grid. Poner en el sub Initialize por ejemplo: gForm.grdLineas.ActivarScripts = True  

Sub Grid_BeforeColUpdate(aGrid,aColIndex,aOldValue,aCancel)    
    If agrid.columns("Descrip2").colindex = acolindex Then    'comprobar que la descripción2  no es igual que la descripción y si es genérica avisar y  quitar la descripción2.         
        If agrid.columns("Descrip2").Value = agrid.columns("Descrip").Value Then         
            MsgBox "No puede enviar duplicar descipciones. Cambie una de las dos descripciones."          
            acancel = True      
        End If     
    End If   
End Sub 

Código en C#:

public void Initialize()
{
  (gForm.Controls["grdLineas"] as ICntGridUsuario).ActivarScripts = true;
}

//Para Activar este evento hay que configurar la grid. Poner en el void Initialize por ejemplo: (gForm.Controls["grdLineas"] as ICntGridUsuario).ActivarScripts = true;
public void Grid_BeforeColUpdate(ICntGridUsuario aGrid, int aColIndex, Valor aOldValue, bool aCancel)
{
  // Comprobar que la descripción2  no es igual que la descripción y si es genérica avisar y quitar la descripción2.
  if (aGrid.Columns["Descrip2"].ColIndex == aColIndex)
  {
    if (aGrid.Columns["Descrip2"].Value == aGrid.Columns["Descrip"].Value)
    {
      AhoraCore.VBA.Interaction.MsgBox("No puede enviar duplicar descipciones. Cambie una de las dos descripciones.");
      aCancel = true;
    }
  }

}


Este evento se ejecuta antes de cargar la grid. En él modificamos el origen de datos de ésta.


De esta forma, si tenemos configurada la grid con campos configurables los podemos mostrar. Este evento estaba en el formulario de listas de precios de clientes.

Código en VB6:

 Sub Initialize()
   gForm.Controls("grdLineas").ActivarScripts=True
 End Sub
 'Para Activar este evento hay que configurar la grid. Poner en el sub Initialize por ejemplo: gForm.grdLineas.ActivarScripts = True 
 'Este evento sólo se ejecuta cuando se obtiene la configuración de la grid,es decir, si no se cambia la config. sólo una vez. 
 Sub Grid_BeforeLoad(aGrid) 
   If aGrid.name = "grdLineas" Then   
     aGrid.From = "VCLIENTE_Listas_Precios_Cli_SinAjenas" 
   End If 
 End Sub 

Código en C#:

public void Initialize()
{
  (gForm.Controls["grdLineas"] as ICntGridUsuario).ActivarScripts = true;
}

//Para Activar este evento hay que configurar la grid. Poner en el void Initialize por ejemplo: (gForm.Controls["grdLineas"] as ICntGridUsuario).ActivarScripts = true;
public void Grid_BeforeLoad(ICntGridUsuario aGrid)
{
  if (aGrid.Name == "grdLineas")
  {
    aGrid.From = "VCLIENTE_Listas_Precios_Cli_SinAjenas";
  }
}


Ejemplo Control Grid: Array sin origen de datos y campos sustitución

  • Cuando no se desea cargar datos en el grid, simplemente que el usuario los introduzca, no es necesario poner un origen de datos.
  • Utilizaremos sustitución cuando se selecciona un artículo y queremos que se actualice el campo Descripción, y viceversa.
  • Al insertar un nuevo registro queremos que el campo cantidad por defecto sea 1.

Código en VB6:

 Sub Initialize()  
    Set lPnlArtics = gForm.Controls.Add("AhoraOCX.cntPanel", "PnlArtics")
    lPnlArtics.Resized = True  
    lPnlArtics.ResizeEnabled = False  
    lPnlArtics.ResizeInterior = True  
    lPnlArtics.Estilo = 0   
    lPnlArtics.Visible = True      
    gForm.TabMain.InsertItem  110, "&Articulos", lPnlArtics.Hwnd, 1       
    Set lGrid = gForm.Controls.Add("AhoraOCX.cntGridUsuario", "Pers_GrdArtics", PnlArtics) 
    CargaGrdArticulosConSust    
End Sub 

Sub CargaGrdArticulosConSust() 
    'Crearemos un grid de sólo array para introducir artículos y cantidades 
    'Seleccionaremos los artículos de un combo 
    'Al seleccionar el artículo se actualzará la descripción y viceversa 
    With gForm.Controls("Pers_GrdArtics") 
        Set .Container = gForm.Controls("PnlArtics")    
        .Visible = True      
        If Not .Preparada Then      
            .Agregar = True      
            .Editar = True      
            .Eliminar = True      
            .CargaObjetos = False      
            .EditarPorObjeto = False      
            .Grid.FetchRowStyle = False      'Agregamos columna con formato numérico (Ver lib Ahora_Constantes)      
            .AgregaColumna "Cantidad", 1000, "Cantidad", , , , "#,##0"      
            .AgregaColumna "IdArticulo", 1500, "Articulo", , "Select IdArticulo, IdArticulo, Descrip From Articulos"      
            .AgregaColumna "Descrip", 2500, "Descripcion", , "Select Descrip, Descrip, IdArticulo From Articulos"            
            .From = "" 'sin origen de datos porque los introducirá el usuario      
            .Where = ""      
            .OrdenMultiple = ""       'Sustituciones      
            .Campo("IdArticulo").Sustitucion = "SELECT IdArticulo FROM Articulos WHERE Descrip = @Descrip"      
            .Campo("Descrip").Sustitucion = "SELECT Descrip FROM Articulos WHERE IdArticulo = @IdArticulo"      
            .Campo("Cantidad").Default = 1      
            .SoloArray = False      
            .Refresca = True    
        End If    
        .SoloArray = True    
        .Refresca = False  
    End With 
End Sub

Código en C#:

using AhoraCl;
using AhoraCore;
using AhoraOCX;
using AhoraSistema;
using System;
using System.Windows.Forms;

namespace AhoraScriptsPantalla
{
    public class AhoraCl_frmArticulos : AhoraOCX.AhoraBaseScript

    {

    public void Initialize()
    {
      IControl lGrid = null;
      ICntPanel lPnlArtics = null;
      try {
        lPnlArtics = (ICntPanel)gForm.Controls.Add("AhoraOCX.CntPanel", "PnlArtics", null);
        lPnlArtics.Resized = true;
        ((IControlResizable) lPnlArtics).ResizeEnabled = false;
        ((ICntPanel) lPnlArtics).ResizeInterior = true;
        lPnlArtics.Estilo = 0;
        lPnlArtics.Visible = true;
        ((ICntTab) gForm.FindControl("TabPrincipal")).InsertItem(110, "&Articulos M", lPnlArtics, 1);
        lGrid = gForm.Controls.Add("AhoraOCX.CntGridUsuario", "Pers_GrdArtics", lPnlArtics);
        CargaGrdArticulosConSust();
      } catch (Exception) {
        throw;
      }
    }


    public void CargaGrdArticulosConSust()
    {
      try {
        //Crearemos un grid de sólo array para introducir artículos y cantidades 
        //Seleccionaremos los artículos de un combo 
        //Al seleccionar el artículo se actualzará la descripción y viceversa 
        gForm.Controls["Pers_GrdArtics"].Parent = (Control) gForm.Controls["PnlArtics"];
        gForm.Controls["Pers_GrdArtics"].Visible = true;
        if (!((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Preparada) {
                    ((ICntGridUsuario)gForm.Controls["Pers_GrdArtics"]).Agregar = true;
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Editar = true;
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Eliminar = true;
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).CargaObjetos = false;
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).EditarPorObjeto = false;
                    ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).FetchRowStyle = false;
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).AgregaColumna("Cantidad", 67, "Cantidad", false, "", false, "#,##0");
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).AgregaColumna("IdArticulo", 100, "Articulo", false, "Select IdArticulo, IdArticulo, Descrip From Articulos");
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).AgregaColumna("Descrip", 167, "Descripcion", false, "Select Descrip, Descrip, IdArticulo From Articulos");
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).From = "";
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Where = "";
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).OrdenMultiple = "";
          //Sustituciones      
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Campo("IdArticulo").Sustitucion = "SELECT IdArticulo FROM Articulos WHERE Descrip = @Descrip";
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Campo("Descrip").Sustitucion = "SELECT Descrip FROM Articulos WHERE IdArticulo = @IdArticulo";
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Campo("Cantidad").Default = 1;
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).SoloArray = false;
          ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Refresca = true;
        }
        ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).SoloArray = true;
        ((ICntGridUsuario) gForm.Controls["Pers_GrdArtics"]).Refresca = false;
      
      } catch (Exception) {
        throw;
      }
    }

    }

}


Ejemplo Control Grid: sólo ARRAY usando Alias y campos calculados.


En éste ejemplo el grid es de sólo edición y sólo queremos que se refresque cuando se llame al método cargaGridSelecTarifas. Le pondremos un FROM porque queremos que cargue datos por defecto.

Código en VB6:

 Sub cargaGridSelecTarifas()
    With grdSelecTarifas
     If Not .Preparada Then
      .Agregar = False
      .Editar = True
      .Eliminar = False
      .CargaObjetos = False
      .Alias = "a"
      '-Columna Marca (Columna Calculada) no existe en las tablas.
      '-Se especifica con @
      .AgregaColumna "@Marca", 700, "Marca"
      .AgregaColumna "IdDelegacion", 1000, "Delegacion", True
      .AgregaColumna "IdLista", 500, "Lista", True
      .AgregaColumna "Descrip", 1000, "Descripción", True
      '-Establecemos el tipo de datos y la sustitución
      .Campo("@Marca").Booleano = True
      .Campo("@Marca").Sustitucion = "Select 0"
  
      .From="(SELECT cc.IdDelegacion,lpc.IdLista,lpc.Descrip,lpc.IdDoc" & "FROM Listas_Precios_Cli lpc " & "INNER JOIN Ceesi_Configuracion cc ON " & "lpc.IdLista=cc.Valor WHERE cc.Parametro='LISTAPRECIOS_DEFECTO')a"
      '-Queremos que sólo cargue las tarifas para la delegación actual.
      '-GCN es el objeto conexión.
      .Where = " WHERE a.IdDelegacion = " & gCn.IdDelegacion
      .OrdenMultiple = " IdDelegacion, IdLista"
     End If
     '-Cuando es un grid de solo Array el orden de refresco es el siguiente: si se cambia el orden da error
     .SoloArray = False
     .Refresca = True '-Hacemos el refresco 1 vez.
     .SoloArray = True
     .Refresca = False '-Dejamos la grid como sólo array.
   End With
  End Sub 

Código en C#:

public void cargaGridSelecTarifas()
{
  IControl grdSelecTarifas = null;
  try
  {
    if (!((ICntGridUsuario)grdSelecTarifas).Preparada)
    {
      ((ICntGridUsuario)grdSelecTarifas).Agregar = false;
      ((ICntGridUsuario)grdSelecTarifas).Editar = true;
      ((ICntGridUsuario)grdSelecTarifas).Eliminar = false;
      ((ICntGridUsuario)grdSelecTarifas).CargaObjetos = false;
      ((ICntGridUsuario)grdSelecTarifas).Alias = "a";
      //-Columna Marca (Columna Calculada) no existe en las tablas.
      //-Se especifica con @
      ((ICntGridUsuario)grdSelecTarifas).AgregaColumna("@Marca", 47, "Marca");
      ((ICntGridUsuario)grdSelecTarifas).AgregaColumna("IdDelegacion", 67, "Delegacion", true);
      ((ICntGridUsuario)grdSelecTarifas).AgregaColumna("IdLista", 33, "Lista", true);
      ((ICntGridUsuario)grdSelecTarifas).AgregaColumna("Descrip", 67, "Descripción", true);
      //-Establecemos el tipo de datos y la sustitución
      ((ICntGridUsuario)grdSelecTarifas).Campo("@Marca").Booleano = true;
      ((ICntGridUsuario)grdSelecTarifas).Campo("@Marca").Sustitucion = "Select 0";

      ((ICntGridUsuario)grdSelecTarifas).From = "(SELECT cc.IdDelegacion,lpc.IdLista,lpc.Descrip,lpc.IdDoc" + "FROM Listas_Precios_Cli lpc " + "INNER JOIN Ceesi_Configuracion cc ON " + "lpc.IdLista=cc.Valor WHERE cc.Parametro='LISTAPRECIOS_DEFECTO')a";
      //-Queremos que sólo cargue las tarifas para la delegación actual.
      //-GCN es el objeto conexión.
      ((ICntGridUsuario)grdSelecTarifas).Where = " WHERE a.IdDelegacion = " + gCn.IdDelegacion;
      ((ICntGridUsuario)grdSelecTarifas).OrdenMultiple = " IdDelegacion, IdLista";
    }
    //-Cuando es un grid de solo Array el orden de refresco es el siguiente: si se cambia el orden da error
    ((ICntGridUsuario)grdSelecTarifas).SoloArray = false;
    ((ICntGridUsuario)grdSelecTarifas).Refresca = true;
    ((ICntGridUsuario)grdSelecTarifas).SoloArray = true;
    ((ICntGridUsuario)grdSelecTarifas).Refresca = false;

  }
  catch (Exception)
  {
    throw;
  }
}


Ejemplo Control Grid: grid de sólo lectura con Alias y filtro WHERE.

Código en VB6:

 Sub CargaGrdArticulosDeProv() '--Cuando se llame a éste procedimiento se aplicará el filtro WHERE '--Y mostrarán los artículos del proveedor especificado.  
    Dim lStrVista 'As String  
    lStrVista = "(SELECT pa.IdProveedor, pa.IdArticulo, a.Descrip, a.IdDoc " & "FROM Prov_Articulos pa " & "INNER Join Articulos a On " & "pa.IdArticulo = a.IdArticulo) Vista"  
    With gForm.Controls("Pers_GrdComisiones")  
        Set .Container = gForm.Controls("PnlComisiones")    
        .Visible = True     
        If Not .Preparada Then      
            .Agregar = False      
            .Editar = False      
            .Eliminar = False      
            .CargaObjetos = False      
            .EditarPorObjeto = False      
            .Grid.FetchRowStyle = False      
            .Alias = "Vista"      
            .AgregaColumna "IdArticulo", 1000, "IdArticulo"      
            .AgregaColumna "Descrip", 3000, "Descripción"      
            .From = lStrVista              
            .OrdenMultiple = ""    
         End If    
        .Where = "WHERE Vista.IdProveedor = " & gForm.Controls("IdProveedor").text     '--la func. sqlString me añade comillas   
        .Refresca = True   
    End With 
End Sub 

Código en C#:

public void CargaGrdArticulosDeProv()
{
  string lStrVista = "";
  try {
    lStrVista = "(SELECT pa.IdProveedor, pa.IdArticulo, a.Descrip, a.IdDoc " + "FROM Prov_Articulos pa " + "INNER Join Articulos a On " + "pa.IdArticulo = a.IdArticulo) Vista";
    gForm.Controls["Pers_GrdComisiones"].Parent = (Control) gForm.Controls["PnlComisiones"];
    gForm.Controls["Pers_GrdComisiones"].Visible = true;
    if (!((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).Preparada) {
      ((ICntGridUsuario)gForm.Controls["Pers_GrdComisiones"]).Agregar = false;
      ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).Editar = false;
      ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).Eliminar = false;
      ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).CargaObjetos = false;
      ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).EditarPorObjeto = false;
      ((ICntGridUsuario)gForm.Controls["Pers_GrdComisiones"]).FetchRowStyle = false;
      ((ICntGridUsuario)gForm.Controls["Pers_GrdComisiones"]).Alias = "Vista";
      ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).AgregaColumna("IdArticulo", 67, "IdArticulo");
      ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).AgregaColumna("Descrip", 200, "Descripción");
      ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).From = lStrVista;
      ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).OrdenMultiple = "";
    }
    ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).Where = "WHERE Vista.IdProveedor = " + ((IControlEnlazable) gForm.Controls["IdProveedor"]).Text;
    ((ICntGridUsuario) gForm.Controls["Pers_GrdComisiones"]).Refresca = true;
  
  } catch (Exception) {
    throw;
  }
}


Ejemplo Control Grid: grid con colecciones y asistentes F3.


Cuando la grid tiene la propiedad CargaObjeto=False, cuando actualizamos un registro significa que NO estamos actualizando el objeto. La grid no podrá contener los campos de la tabla configurables del objeto.

Código en VB6:

 Private Sub gridLoad()
 On Error GoTo Error_
   With GrdLineas
     If Not .Preparada Then
       .Agregar = True
       .Editar = True
       .Eliminar = True
       .CargaObjetos = False 'al estar a False necesitamos indicar la tabla donde guarda
       .EditarPorObjeto = True
       Set .Coleccion = EObjeto.ObjGlobal.Objetos("Trans_Prod_Lineas")
       .From = "Transformac_Lineas"
  
       .AgregaColumna "IdCodigo", 0, "IdCodigo"
       .AgregaColumna "IdLinea", 0, "IdLinea"
  
       .AgregaColumna "IdArticulo", 1875, "Id artículo", False, _
              "SELECT IdArticulo, IdArticulo, Descrip FROM VCombo_Articulos Order By IdArticulo"
       .AgregaColumna "@Descrip", 1875, gCn.Traducir(734, "Descripción"), False, _
              "SELECT Descrip, Descrip, IdArticulo FROM VCombo_Articulos Order By Descrip"
       .AgregaColumna "Unidades", 1000, "Unidades", , , , cFmt_Num2
       .AgregaColumna "Precio", 1000, "Precio", , , , cFmt_Eur, , , , , True
       'Sustituciones
       .Campo("IdArticulo").Sustitucion = _
 "SELECT IdArticulo FROM VCombo_Articulos WHERE Descrip = @@Descrip"
  
       .Campo("@Descrip").Sustitucion = _
 "SELECT Descrip FROM VCombo_Articulos WHERE IdArticulo = @IdArticulo"
       'Asistentes
       With .Campo("IdArticulo")
         .AsignaAsistente gCn.Obj.Objetos("Articulos").Entorno.Icono1, "vCombo_Articulos", "", "IdArticulo", "IdArticulo", 8000, , False
 'Campos del asistente
         .AssistAddField "IdArticulo", "Id Artículo", "String", 2000, , True
         .AssistAddField "Descrip", gCn.Traducir(734, "Descripción"), "String", 4500
       End With
       With .Campo("@Descrip")
         .AsignaAsistente gCn.Obj.Objetos("Articulos").Entorno.Icono1, "vCombo_Articulos", "", "Descrip", "Descrip", 8000, , False
         'Campos del asistente
         .AssistAddField "Descrip", gCn.Traducir(734, "Descripción"), "String", 4500
         .AssistAddField "IdArticulo", "Id Artículo", "String", 2000, , True
       End With
       .ColumnaEscalada = "@Descrip"
     End If
     Set .Coleccion = EObjeto.ObjGlobal.Objetos("Trans_Prod_Lineas")
     .Where = "WHERE 1 = 0"
     .Refresca = True
   End With
 End_:
   Exit Sub
 Error_:
   GCn.Tr.Trace TError, cModuleName, " gridLoad", , Err.Description
   Resume End_
 End Sub 

Código en C#:

private void gridLoad()
{
  ICntGridUsuario grdLineas = (gForm.Controls["grdLineas"] as ICntGridUsuario);
  if (!grdLineas.Preparada)
  {
    grdLineas.Agregar = true;
    grdLineas.Editar = true;
    grdLineas.Eliminar = true;
    grdLineas.CargaObjetos = false;
    grdLineas.EditarPorObjeto = true;
    grdLineas.Coleccion = (IColecciones)EObjeto.ObjGlobal.Objetos["Trans_Prod_Lineas"];
    grdLineas.From = "Transformac_Lineas";

    grdLineas.AgregaColumna("IdCodigo", 0, "IdCodigo");
    grdLineas.AgregaColumna("IdLinea", 0, "IdLinea");

    grdLineas.AgregaColumna("IdArticulo", 1875, "Id artículo", false, "SELECT IdArticulo, IdArticulo, Descrip FROM VCombo_Articulos Order By IdArticulo");
    grdLineas.AgregaColumna("@Descrip", 1875, gCn.Traducir(734, "Descripción"), false, "SELECT Descrip, Descrip, IdArticulo FROM VCombo_Articulos Order By Descrip");
    grdLineas.AgregaColumna("Unidades", 1000, "Unidades", false, null,false, cFmt_Num2);
    grdLineas.AgregaColumna("Precio", 1000, "Precio", false, null, false, cFmt_Eur, false, null, false, null, true);
    // Sustituciones

    grdLineas.Campo("IdArticulo").Sustitucion = "SELECT IdArticulo FROM VCombo_Articulos WHERE Descrip = @@Descrip";

    grdLineas.Campo("@Descrip").Sustitucion = "SELECT Descrip FROM VCombo_Articulos WHERE IdArticulo = @IdArticulo";
    // Asistentes

    grdLineas.Campo("IdArticulo").AsignaAsistente(gCn.Obj.Objetos["Articulos"].Entorno.Icono1.ToString(), "vCombo_Articulos", "", "IdArticulo", "IdArticulo", 8000, 0, false);
    // Campos del asistente

    grdLineas.Campo("IdArticulo").AssistAddField("IdArticulo", "Id Artículo", ETipoDato.String, 2000, false, true);
    grdLineas.Campo("IdArticulo").AssistAddField("Descrip", gCn.Traducir(734, "Descripción"), ETipoDato.String, 4500);

    grdLineas.Campo("@Descrip").AsignaAsistente(gCn.Obj.Objetos["Articulos"].Entorno.Icono1.ToString(), "vCombo_Articulos", "", "Descrip", "Descrip", 8000, 0, false);
    // Campos del asistente

    grdLineas.Campo("@Descrip").AssistAddField("Descrip", gCn.Traducir(734, "Descripción"), ETipoDato.String, 4500);
    grdLineas.Campo("@Descrip").AssistAddField("IdArticulo", "Id Artículo", ETipoDato.String, 2000, false, true);

    grdLineas.ColumnaEscalada = "@Descrip";
  }
  grdLineas.Coleccion = (IColecciones)EObjeto.ObjGlobal.Objetos["Trans_Prod_Lineas"];
  grdLineas.Where = "WHERE 1 = 0";
  grdLineas.Refresca = true;
}