2007-06-11 15:29:06 +00:00
unit uDetallesFacturaProveedorController;
interface
uses
uDADataTable, uControllerDetallesArticulos, uBizDetallesFacturaProveedor, uIDataModuleFacturasProveedor,
uBizContactos, uBizArticulos;
type
IDetallesFacturaProveedorController = interface( IControllerDetallesArticulos)
[ '{49F6199E-E031-42F5-AEA5-E70C3E3479A1}' ]
2008-07-15 18:09:26 +00:00
procedure AnadirArticulos( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor; const ANuevaFila : Boolean = True ; const ACantidad: Integer = 1 ) ; overload ;
2007-06-11 15:29:06 +00:00
procedure ActualizarDetalles( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ;
procedure AnadirDetalleFacturaAsociadaAbono( ADetalles: IBizDetallesFacturaProveedor; AReferencia: String ; AFecha: String ) ;
2007-09-27 17:39:23 +00:00
procedure DesglosarPorteDetalles( ImportePorte: Currency ; ADetalles: IDAStronglyTypedDataTable) ;
function DarTotalPorteTotal( ADetalles: IDAStronglyTypedDataTable) : Double ;
2007-06-11 15:29:06 +00:00
end ;
TDetallesFacturaProveedorController = class( TControllerDetallesArticulos, IDetallesFacturaProveedorController)
private
FDataModule : IDataModuleFacturasProveedor;
protected
procedure AsignarDatos( ADetalles: IDAStronglyTypedDataTable; IDCabecera: Integer ) ; override ;
2007-09-26 15:58:51 +00:00
procedure RellenarOtros( ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo) ; overload ; override ;
2007-06-11 15:29:06 +00:00
procedure RellenarImportes( ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo) ; override ;
procedure AsignarController; override ;
2007-09-26 15:58:51 +00:00
//Si sobreescribimos este m<> todo podremos tener en cuenta otras columnas para el calculo del importe total de un concepto
function CalcularImporteTotalConcepto( DataTable: TDADataTable) : Double ; override ;
procedure ValidarCampos( DataTable: TDADataTable) ; override ;
2007-09-27 17:39:23 +00:00
procedure DesglosarPorteDetalles( ImportePorte: Currency ; ADetalles: IDAStronglyTypedDataTable) ;
function DarTotalPorteTotal( ADetalles: IDAStronglyTypedDataTable) : Double ;
2007-06-11 15:29:06 +00:00
public
2008-07-15 18:09:26 +00:00
procedure AnadirArticulos( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor; const ANuevaFila : Boolean = True ; const ACantidad: Integer = 1 ) ; overload ;
2007-06-11 15:29:06 +00:00
procedure ActualizarDetalles( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ; overload ;
procedure AnadirDetalleFacturaAsociadaAbono( ADetalles: IBizDetallesFacturaProveedor; AReferencia: String ; AFecha: String ) ;
constructor Create; override ;
destructor Destroy; override ;
end ;
implementation
{ TDetallesFacturaProveedorController }
2007-09-26 15:58:51 +00:00
uses Variants, uDataModuleFacturasProveedor, uArticulosFacturaProveedorController,
uControllerDetallesBase, Dialogs, SysUtils, uDialogUtils, uCalculosUtils;
2007-06-11 15:29:06 +00:00
procedure TDetallesFacturaProveedorController. ActualizarDetalles( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor) ;
var
AArticulos : IBizArticulo;
begin
if Assigned( ADetalles) then
begin
try
AArticulos : = ( FArticulosController. BuscarTodos( AProveedor) as IBizArticulo) ;
ActualizarDetalles( ADetalles, AArticulos) ;
2007-06-19 10:59:58 +00:00
EliminarArticulosProveedor( ADetalles) ;
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 ;
2008-07-15 18:09:26 +00:00
procedure TDetallesFacturaProveedorController. AnadirArticulos( ADetalles: IDAStronglyTypedDataTable; AProveedor: IBizProveedor; const ANuevaFila : Boolean = True ; const ACantidad: Integer = 1 ) ;
2007-06-11 15:29:06 +00:00
var
AArticulos: IBizArticulo;
begin
if Assigned( ADetalles) then
begin
try
2008-07-15 18:09:26 +00:00
AArticulos : = ( FArticulosController. BuscarTodos as IBizArticulo) ;
//Si nueva fila es false, quiere decir que se sustituye un determinado art<72> culo, por ello la lista a seleccionar no debe ser multiselect
if ANuevaFila then
begin
AArticulos : = ( FArticulosController as IArticulosFacturaProveedorController) . ElegirArticulos( AArticulos, 'Elija los art<72> culos que desea a<> adir a esta factura de Proveedor' , True , AProveedor) ;
Add( ADetalles, AArticulos, ACantidad)
end
else
begin
AArticulos : = ( FArticulosController as IArticulosFacturaProveedorController) . ElegirArticulos( AArticulos, 'Elija el art<72> culo que desea a<> adir a esta factura de Proveedor' , False , AProveedor) ;
RellenarDetalle( ADetalles, AArticulos, ACantidad) ;
end ;
2007-06-11 15:29:06 +00:00
finally
AArticulos : = Nil ;
end ;
end ;
end ;
procedure TDetallesFacturaProveedorController. AnadirDetalleFacturaAsociadaAbono(
ADetalles: IBizDetallesFacturaProveedor; AReferencia, AFecha: String ) ;
begin
AnadirConceptoInicial( ADetalles, 'ABONO DE FACTURA ' + AReferencia + ' con fecha ' + AFecha) ;
end ;
procedure TDetallesFacturaProveedorController. AsignarController;
begin
FArticulosController : = TArticulosFacturaProveedorController. Create;
end ;
procedure TDetallesFacturaProveedorController. AsignarDatos( ADetalles: IDAStronglyTypedDataTable; IDCabecera: Integer ) ;
begin
inherited ;
with ( ADetalles as IBizDetallesFacturaProveedor) do
begin
Edit;
ID : = FDataModule. GetNextID( DataTable. LogicalName) ;
ID_FACTURA : = IDCabecera;
Post
end ;
end ;
2007-09-26 15:58:51 +00:00
function TDetallesFacturaProveedorController. CalcularImporteTotalConcepto( DataTable: TDADataTable) : Double ;
begin
Result : = CalcularLineaConcepto( DataTable) ;
end ;
2007-06-11 15:29:06 +00:00
constructor TDetallesFacturaProveedorController. Create;
begin
inherited ;
FDataModule : = TDataModuleFacturasProveedor. Create( Nil ) ;
end ;
2007-09-27 17:39:23 +00:00
function TDetallesFacturaProveedorController. DarTotalPorteTotal( ADetalles: IDAStronglyTypedDataTable) : Double ;
begin
Result : = DarTotalPorte( ADetalles) ;
end ;
procedure TDetallesFacturaProveedorController. DesglosarPorteDetalles( ImportePorte: Currency ; ADetalles: IDAStronglyTypedDataTable) ;
begin
DesglosarPorte( ImportePorte, ADetalles) ;
ActualizarTotales( ADetalles) ;
end ;
2007-06-11 15:29:06 +00:00
destructor TDetallesFacturaProveedorController. Destroy;
begin
FDataModule : = Nil ;
inherited ;
end ;
2007-09-26 15:58:51 +00:00
procedure TDetallesFacturaProveedorController. RellenarOtros( ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo) ;
2007-06-11 15:29:06 +00:00
begin
if Assigned( AArticulos) then
2007-09-26 15:58:51 +00:00
ADetalles. DataTable. FieldByName( CAMPO_DESCUENTO) . AsFloat : = AArticulos. DESCUENTO
2007-06-11 15:29:06 +00:00
else
2007-09-26 15:58:51 +00:00
ADetalles. DataTable. FieldByName( CAMPO_DESCUENTO) . AsFloat : = 0 ;
end ;
procedure TDetallesFacturaProveedorController. ValidarCampos( DataTable: TDADataTable) ;
begin
inherited ;
ValidarCamposLineaConcepto( DataTable) ;
2007-06-11 15:29:06 +00:00
end ;
procedure TDetallesFacturaProveedorController. 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 .