Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > OOP
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 19-01-2024
Avatar de jafera
jafera jafera is offline
Miembro
 
Registrado: may 2007
Ubicación: Llagostera (Girona)
Posts: 582
Poder: 17
jafera Va por buen camino
Foco en un campo del Grid

Buenas tardes a todos.


He estado mirando en el foro por si había un caso similar al mio y no he visto nada.
Tengo este código en el OnColExit del JVDBGrid


Código Delphi [-]
procedure TF_Vendes.JvDBUltimGrid1ColExit(Sender: TObject);
begin
        If F_ModulDades.LVentas.State in [dsEdit, dsInsert] then
                begin
                if JvDBUltimGrid1.SelectedField.Fieldname='UNIDADES' then
                begin
                        F_ModulDades.Stock_Unidades.Close;
                        F_ModulDades.Stock_Unidades.ParamByName('REFERENCIA').AsString:=F_ModulDades.LVentasREFERENCIA.Value  ;
                        F_ModulDades.Stock_Unidades.Open;
                        iF F_ModulDades.LVentasUNIDADES.Value > F_ModulDades.Stock_UnidadesSTOCK.Value then
                        begin
                                Showmessage ('Estas vendiendo más unidades que el stock, Sólo puedes vender '+IntToStr(F_ModulDades.Stock_UnidadesSTOCK.Value)+' unidades.');
                                F_ModulDades.LVentas.Edit;
                                F_ModulDades.LVentasUNIDADES.Clear;
                                F_ModulDades.LVentas.Post;
                                JvDBUltimGrid1.SelectedField:=F_ModulDades.LVentasUNIDADES;
                        end;
                end;
        end;
end;


Lo que me pasa es que la linea


JvDBUltimGrid1.SelectedField:=F_ModulDades.LVentasUNIDADES;


es como si no estuviera.


Tambien he probado con


JvDBUltimGrid1.SelectedIndex:=1;


Y tampoco consigo que al hacer el clear, el foco vuelva al campo Unidades para entrar la nueva cantidad.


Como siempre agradezo vuestro tiempo y si alguien tiene una ayudita, pues bien recibida.


Saludos


Josep
Responder Con Cita
  #2  
Antiguo 19-01-2024
Garada Garada is offline
Miembro
 
Registrado: jul 2004
Posts: 66
Poder: 20
Garada Va por buen camino
Thumbs up

Una opción es cambiar la línea por un
Código Delphi [-]
Abort;
Eso pararía el resto de procesamiento del Grid.
Pero también puede que cancele otro código que sí te puede interesar.


La opción más correcta para mí es usar una variable privada para controlar la entrada y salida de las celdas.
Sería como esto:

Código Delphi [-]
  TF_Vendes = class(TForm)
...
  private
    FLastCol: Integer; // Declara la variable de control
...
...
procedure TF_Vendes.FormCreate(Sender: TObject);
begin
  FLastCol := -1; // Inicializar la variable
end;

procedure TF_Vendes.JvDBUltimGrid1ColExit(Sender: TObject);
begin
  If F_ModulDades.LVentas.State in dsEditModes then
   begin
    if JvDBUltimGrid1.SelectedField=F_ModulDades.LVentasUNIDADES then
    begin
      F_ModulDades.Stock_Unidades.Close;
      F_ModulDades.Stock_Unidades.ParamByName('REFERENCIA').AsString:=F_ModulDades.LVentasREFERENCIA.Value  ;
      F_ModulDades.Stock_Unidades.Open;
      iF F_ModulDades.LVentasUNIDADES.Value > F_ModulDades.Stock_UnidadesSTOCK.Value then
      begin
        Showmessage ('Estas vendiendo más unidades que el stock, Sólo puedes vender'+
                              IntToStr(F_ModulDades.Stock_UnidadesSTOCK.Value)+' unidades.');
        F_ModulDades.LVentas.Edit;
        F_ModulDades.LVentasUNIDADES.Clear;
        F_ModulDades.LVentas.Post;

       // JvDBUltimGrid1.SelectedField:=F_ModulDades.LVentasUNIDADES;
       // este es el cambio, asignar a la variable la columna a volver
       FLastCol := JvDBUltimGrid1.SelectedIndex;
      end;
    end;
  end;
end;

procedure TF_Vendes.JvDBUltimGrid1ColEnter(Sender: TObject);
begin
  // Al entrar en la celda, si la variable de control tiene un valor <> -1 volver a esa celda
  if FLastCol > -1 then
    JvDBUltimGrid1.SelectedIndex := FLastCol;

  // reiniciar la variable
  FLastCol := -1;
end;
Responder Con Cita
  #3  
Antiguo 21-01-2024
Delphi01 Delphi01 is offline
Miembro
 
Registrado: nov 2015
Ubicación: Barcelona,España
Posts: 68
Poder: 9
Delphi01 Va por buen camino
Cita:
Empezado por jafera Ver Mensaje
Buenas tardes a todos.


He estado mirando en el foro por si había un caso similar al mio y no he visto nada.
Tengo este código en el OnColExit del JVDBGrid


Código Delphi [-]
procedure TF_Vendes.JvDBUltimGrid1ColExit(Sender: TObject);
begin
        If F_ModulDades.LVentas.State in [dsEdit, dsInsert] then
                begin
                if JvDBUltimGrid1.SelectedField.Fieldname='UNIDADES' then
                begin
                        F_ModulDades.Stock_Unidades.Close;
                        F_ModulDades.Stock_Unidades.ParamByName('REFERENCIA').AsString:=F_ModulDades.LVentasREFERENCIA.Value  ;
                        F_ModulDades.Stock_Unidades.Open;
                        iF F_ModulDades.LVentasUNIDADES.Value > F_ModulDades.Stock_UnidadesSTOCK.Value then
                        begin
                                Showmessage ('Estas vendiendo más unidades que el stock, Sólo puedes vender '+IntToStr(F_ModulDades.Stock_UnidadesSTOCK.Value)+' unidades.');
                                F_ModulDades.LVentas.Edit;
                                F_ModulDades.LVentasUNIDADES.Clear;
                                F_ModulDades.LVentas.Post;
                                JvDBUltimGrid1.SelectedField:=F_ModulDades.LVentasUNIDADES;
                        end;
                end;
        end;
end;


Lo que me pasa es que la linea


JvDBUltimGrid1.SelectedField:=F_ModulDades.LVentasUNIDADES;


es como si no estuviera.


Tambien he probado con


JvDBUltimGrid1.SelectedIndex:=1;


Y tampoco consigo que al hacer el clear, el foco vuelva al campo Unidades para entrar la nueva cantidad.


Como siempre agradezo vuestro tiempo y si alguien tiene una ayudita, pues bien recibida.


Saludos


Josep
Código:
procedure TF_Vendes.JvDBUltimGrid1ColExit(Sender: TObject);
begin
  if F_ModulDades.LVentas.State in [dsEdit, dsInsert] then
  begin
    if JvDBUltimGrid1.SelectedField.FieldName = 'UNIDADES' then
    begin
      F_ModulDades.Stock_Unidades.Close;
      F_ModulDades.Stock_Unidades.ParamByName('REFERENCIA').AsString := F_ModulDades.LVentasREFERENCIA.Value;
      F_ModulDades.Stock_Unidades.Open;
      
      if F_ModulDades.LVentasUNIDADES.Value > F_ModulDades.Stock_UnidadesSTOCK.Value then
      begin
        ShowMessage('Estás vendiendo más unidades de las que hay en stock, solo puedes vender ' + IntToStr(F_ModulDades.Stock_UnidadesSTOCK.Value) + ' unidades.');
        
        F_ModulDades.LVentas.Edit;
        F_ModulDades.LVentasUNIDADES.Clear;
        F_ModulDades.LVentas.Post;
        
        JvDBUltimGrid1.SetFocus; // Establecer foco en JvDBUltimGrid1 (puedes intentar utilizar JvDBUltimGrid1.SetFocusCell(ACol, ARow) si es necesario)
        JvDBUltimGrid1.SelectedIndex := JvDBUltimGrid1.Columns.IndexOf('UNIDADES'); // Establecer el índice de columna seleccionada
        
        // Desactivar y reactivar el control JvDBUltimGrid1
        JvDBUltimGrid1.Enabled := False;
        JvDBUltimGrid1.Enabled := True;
      end;
    end;
  end;
end;
Responder Con Cita
  #4  
Antiguo 22-01-2024
Avatar de jafera
jafera jafera is offline
Miembro
 
Registrado: may 2007
Ubicación: Llagostera (Girona)
Posts: 582
Poder: 17
jafera Va por buen camino
Muchas gracias Garada y Delphi01


Perdonad el retraso en responder, pues por motivos laborales hasta ahora no he podido hacer pruebas.


La solución de Garada ha funcionado a la perfección.
La de Delphi01 no ha funcionado pues me da error de que la propiedad IndexOf en la línea



JvDBUltimGrid1.Columns.IndexOf('UNIDADES');


dice no está declarada, he mirado propiedades de JvDBUltimGrid1.Columns. y no veo ninguna que se pueda aprovechar.
Posiblemente desconocimiento mio de todas las propiedades de este componente.


Saludos


Josep
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
campo en memoria para grid Rofocale Varios 11 22-05-2011 09:36:43
Campo Calculado en JvDBUltim Grid mantraxer21 Varios 1 27-08-2010 17:52:35
Como dar foco en un campo del registro activo TDBGrilla kikodelphi MS SQL Server 1 19-05-2005 15:58:39
Mostrar un campo clob en un grid Lix Oracle 5 27-02-2004 20:48:57
problema con string grid (desparece el contenido de la celda al perder el foco) sase Varios 0 20-08-2003 18:37:59


La franja horaria es GMT +2. Ahora son las 00:03:54.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi