{ =============================================================================== Copyright (©) 2001. Rodax Software. =============================================================================== Los contenidos de este fichero son propiedad de Rodax Software titular del copyright. Este fichero sólo podrá ser copiado, distribuido y utilizado, en su totalidad o en parte, con el permiso escrito de Rodax Software, o de acuerdo con los términos y condiciones establecidas en el acuerdo/contrato bajo el que se suministra. ----------------------------------------------------------------------------- Web: www.rodax-software.com =============================================================================== Fecha primera versión: 01-10-2001 Versión actual: 1.0.2 Fecha versión actual: 07-04-2002 =============================================================================== Modificaciones: Fecha Comentarios --------------------------------------------------------------------------- 07-04-2002 Se ha adaptado el frame para transacción única. 09-04-2002 Sustituir las constantes IDYES/IDNO por IDOK. 09-04-2002 En la función 'TratarCambios' cambiar .Modified por .UpdatesPending en las tablas que usen caché. =============================================================================== } unit RdxFrameClientes; {$I ..\COMPILE.INC} interface uses Consts, Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, RdxFrame, RdxDBFrame, IBCustomDataSet, IBDataBase, IB, DB, Tipos; type TRdxFrameClientes = class(TRdxDBFrame) private FTablaClientes : TIBDataSet; FTablaSucursales : TIBDataSet; protected FCodigoCliente : Variant; procedure SetTablaClientes (Value : TIBDataSet); procedure SetTablaSucursales (Value : TIBDataSet); procedure SetCodigoCliente (Value : Variant); virtual; procedure SetContenido (NuevoFrame : TRdxFrame); override; function TratarCambios : integer; override; procedure BuscarCliente; virtual; procedure CambiarModo(ModoAnterior, Modo : TRdxModo); override; public property TablaClientes: TIBDataSet read FTablaClientes write SetTablaClientes; property TablaSucursales: TIBDataSet read FTablaSucursales write SetTablaSucursales; property CodigoCliente : Variant read FCodigoCliente write SetCodigoCliente; constructor Create (AOwner : TComponent); override; published property BaseDatos; property Transaccion; end; implementation {$R *.DFM} uses Mensajes, StrFunc, Literales {$IFDEF RDX_D6}, Variants{$ENDIF}; { TRdxFrameClientes } constructor TRdxFrameClientes.Create(AOwner: TComponent); begin inherited Create(AOwner); FCodigoCliente := NULL; FTablaClientes := NIL; FTablaSucursales := NIL; end; function TRdxFrameClientes.TratarCambios : integer; begin if (TablaClientes.Modified = True) or ((TablaSucursales <> NIL) and (TablaSucursales.UpdatesPending = True)) then begin case VerMensajePregunta(msgGuardarCambios) of IDCANCEL : Result := IDCANCEL; IDYES : begin if (RealizarOperacion) then Result := IDOK else Result := IDCANCEL; end; IDNO : begin if (DescartarOperacion) then Result := IDOK else Result := IDCANCEL; end; end end else Result := IDOK; end; procedure TRdxFrameClientes.SetCodigoCliente(Value: Variant); begin if not EsCadenaVacia(Value) then begin FCodigoCliente := Value; BuscarCliente; end end; procedure TRdxFrameClientes.SetContenido(NuevoFrame: TRdxFrame); begin if (FContenido <> NIL) then if (Contenido.Name = NuevoFrame.ClassName) then begin NuevoFrame.Free; exit; end; inherited; if (TablaClientes <> NIL) then begin FCodigoCliente := TablaClientes.FieldByName('CODIGO').Value; if Contenido is TRdxFrameClientes then (Contenido as TRdxFrameClientes).CodigoCliente := FCodigoCliente; end; end; procedure TRdxFrameClientes.CambiarModo(ModoAnterior, Modo : TRdxModo); begin inherited; if (FModo in [Normal, Seleccionar]) then begin TablaClientes.Close; TablaClientes.Open; end else begin { Si estábamos en el modo Añadir y pasamos a cualquier otro modo SIEMPRE es necesario buscar el codigo de almacén que tiene el frame en CodigoCliente (al activar el modo Añadir NO se pisa este valor con el código de almacén nuevo), preguntamos si la tabla esta activa por si se ha cerrado al realizar algun cambio en modificar y ejecutar TratarCambios} if (not TablaClientes.Active) or (ModoAnterior = Anadir) then BuscarCliente; end; end; procedure TRdxFrameClientes.SetTablaClientes(Value: TIBDataSet); begin if (FTablaClientes <> Value) then FTablaClientes := Value; end; procedure TRdxFrameClientes.SetTablaSucursales(Value: TIBDataSet); begin if (FTablaSucursales <> Value) then FTablaSucursales := Value; end; procedure TRdxFrameClientes.BuscarCliente; begin // end; end.