2007-06-11 15:29:06 +00:00
unit uDetallesAlbaranProveedorController;
interface
uses
uDADataTable, uControllerDetallesArticulos, uBizDetallesAlbaranProveedor, uIDataModuleAlbaranesProveedor,
uBizArticulos, uBizContactos;
type
IDetallesAlbaranProveedorController = interface( IControllerDetallesArticulos)
[ '{6E35D49A-C78D-481D-93E9-859CD27EB79F}' ]
procedure AnadirArticulos( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ; overload ;
procedure ActualizarDetalles( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ; overload ;
end ;
TDetallesAlbaranProveedorController = class( TControllerDetallesArticulos, IDetallesAlbaranProveedorController)
private
FDataModule : IDataModuleAlbaranesProveedor;
protected
procedure AsignarDatos( ADetalles: IDAStronglyTypedDataTable; IDCabecera: Integer ) ; override ;
procedure RellenarDescuentos( ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo) ; override ;
procedure RellenarImportes( ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo) ; override ;
procedure AsignarController; override ;
public
procedure AnadirArticulos( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ; overload ;
procedure ActualizarDetalles( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ; overload ;
constructor Create; override ;
destructor Destroy; override ;
end ;
implementation
2007-06-19 10:59:58 +00:00
uses Variants, uDialogUtils, uControllerDetallesBase, uControllerDetallesDTO, uDataModuleAlbaranesProveedor, uArticulosAlbaranProveedorController;
2007-06-11 15:29:06 +00:00
{ TDetallesAlbaranProveedorController }
procedure TDetallesAlbaranProveedorController. ActualizarDetalles( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ;
var
AArticulos : IBizArticulo;
begin
if Assigned( ADetalles) then
begin
try
AArticulos : = ( FArticulosController. BuscarTodos( AProveedor) as IBizArticulo) ;
ActualizarDetalles( ADetalles, AArticulos) ;
EliminarArticulosProveedor( ADetalles) ;
2007-06-19 10:59:58 +00:00
ShowInfoMessage( 'Se han eliminado todos los art<72> culos que no pertenecen al nuevo proveedor seleccionado, y los que pertenecen sus descuentos han sido adaptados al proveedor seleccionado' ) ;
2007-06-11 15:29:06 +00:00
finally
AArticulos : = Nil ;
end ;
end ;
end ;
procedure TDetallesAlbaranProveedorController. AnadirArticulos( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ;
var
AArticulos: IBizArticulo;
begin
if Assigned( ADetalles) then
begin
try
2007-06-19 10:59:58 +00:00
AArticulos : = ( FArticulosController. BuscarTodos as IBizArticulo) ;
AArticulos : = ( FArticulosController as IArticulosAlbaranProveedorController) . ElegirArticulos( AArticulos, 'Elija los art<72> culos que desea a<> adir a este albar<61> n de proveedor' , True , AProveedor) ;
2007-06-11 15:29:06 +00:00
Add( ADetalles, AArticulos) ;
finally
AArticulos : = Nil ;
end ;
end ;
end ;
procedure TDetallesAlbaranProveedorController. AsignarController;
begin
FArticulosController : = TArticulosAlbaranProveedorController. Create;
end ;
procedure TDetallesAlbaranProveedorController. AsignarDatos( ADetalles: IDAStronglyTypedDataTable; IDCabecera: Integer ) ;
begin
inherited ;
with ( ADetalles as IBizDetallesAlbaranProveedor) do
begin
Edit;
ID : = FDataModule. GetNextID( DataTable. LogicalName) ;
ID_ALBARAN : = IDCabecera;
Post
end ;
end ;
constructor TDetallesAlbaranProveedorController. Create;
begin
inherited ;
FDataModule : = TDataModuleAlbaranesProveedor. Create( Nil ) ;
end ;
destructor TDetallesAlbaranProveedorController. Destroy;
begin
FDataModule : = Nil ;
inherited ;
end ;
procedure TDetallesAlbaranProveedorController. RellenarDescuentos( ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo) ;
begin
if Assigned( AArticulos) then
RellenarDescuento( ADetalles, AArticulos. DESCUENTO)
else
RellenarDescuento( ADetalles, 0 )
end ;
procedure TDetallesAlbaranProveedorController. RellenarImportes( ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo) ;
begin
if Assigned( AArticulos) then
begin
ADetalles. DataTable. FieldByName( CAMPO_IMPORTE_UNIDAD) . AsVariant : = AArticulos. PRECIO_COSTE;
ADetalles. DataTable. FieldByName( CAMPO_IMPORTE_PORTE) . AsVariant : = AArticulos. PRECIO_PORTE;
end
else
begin
ADetalles. DataTable. FieldByName( CAMPO_IMPORTE_UNIDAD) . AsVariant : = Null;
ADetalles. DataTable. FieldByName( CAMPO_IMPORTE_PORTE) . AsVariant : = Null;
end ;
end ;
end .