This repository has been archived on 2024-11-28. You can view files and clone it, but cannot push or open issues or pull requests.
LuisLeon_FactuGES/Modulos/Facturas de cliente2/Controller/uDetallesFacturaClienteController.pas
2007-06-11 15:35:41 +00:00

112 lines
3.1 KiB
ObjectPascal

unit uDetallesFacturaClienteController;
interface
uses
uControllerDetallesBase, uBizDetallesFacturaCliente, uIDataModuleFacturasCliente;
type
IDetallesFacturaClienteController = interface(IControllerDetallesBase)
['{D3942A48-C55B-4A98-AC5B-B5E652ED393E}']
procedure AssignarID(ADetalles: IBizDetallesFacturaCliente; IDCabecera: Integer; EsModificacion:Boolean);
end;
TDetallesFacturaClienteController = class(TControllerDetallesBase, IDetallesFacturaClienteController)
private
FDataModule : IDataModuleFacturasCliente;
public
procedure AssignarID(ADetalles: IBizDetallesFacturaCliente; IDCabecera: Integer; EsModificacion:Boolean);
constructor Create; override;
destructor Destroy; override;
end;
implementation
{ TDetallesFacturaClienteController }
uses
uDataModuleFacturasCliente;
procedure TDetallesFacturaClienteController.AssignarID(
ADetalles: IBizDetallesFacturaCliente; IDCabecera: Integer;
EsModificacion: Boolean);
begin
with ADetalles do
begin
DataTable.DisableControls;
try
if not DataTable.Active then
DataTable.Active := True;
// AuxPosicion := POSICION;
{ ¡¡¡¡ OJO !!!!
Para asignar el ID en los detalles hay
que tener en cuenta una cosa:
Si se cambia el ID, ese detalle ya no
pertenece a esa cabecera porque ya no se
cumple la condición de la relacion:
Master.ID = Detail.ID_PRESUPUESTO.
Por esa razón no sirve hacer un recorrido
desde el principio hasta el final porque
las detalles van desapareciendo según asignamos
el valor al campo ID y nos mueve aleatoriamente
la posición del registro actual.
Es mejor hacer un bucle sencillo hasta que
"se gasten" todos los detalles. Cuando el
RecordCount llegue a 0 quiere decir que hemos
tratado todos los detalles.
El bucle cambia en el caso de ser llamada esta funcion desde modificar
un presupuesto ya que en ese caso si que hay que hacer un recorrido
total de las tuplas de detalle.
}
if not EsModificacion then
begin
while RecordCount > 0 do
begin
DataTable.First;
Edit;
ID := FDataModule.GetNextID(DataTable.LogicalName);
ID_FACTURA := IDCabecera;
Post
end
end
else
begin
DataTable.First;
while not DataTable.EOF do
begin
if ID < 0 then
begin
Edit;
ID := FDataModule.GetNextID(DataTable.LogicalName);
ID_FACTURA := IDCabecera;
Post
end;
DataTable.Next
end;
end;
finally
DataTable.EnableControls;
end;
end;
end;
constructor TDetallesFacturaClienteController.Create;
begin
inherited;
FDataModule := TDataModuleFacturasCliente.Create(Nil);
end;
destructor TDetallesFacturaClienteController.Destroy;
begin
FDataModule := Nil;
inherited;
end;
end.