git-svn-id: https://192.168.0.254/svn/Proyectos.AbetoDesign_FactuGES/trunk@159 93f398dd-4eb6-7a46-baf6-13f46f578da2
193 lines
7.4 KiB
ObjectPascal
193 lines
7.4 KiB
ObjectPascal
unit uDetallesAlbaranClienteController;
|
|
|
|
interface
|
|
|
|
uses
|
|
uDADataTable, uControllerDetallesArticulos, uBizDetallesAlbaranCliente, uIDataModuleAlbaranesCliente,
|
|
uBizArticulos, uBizContactos;
|
|
|
|
type
|
|
IDetallesAlbaranClienteController = interface(IControllerDetallesArticulos)
|
|
['{6AD99D47-2856-47B1-9620-DD115726B0E1}']
|
|
procedure AnadirArticulos(ADetalles: IDAStronglyTypedDataTable; ACliente: IBizCliente; const ANuevaFila :Boolean = True; const ACantidad: Integer = 1); overload;
|
|
procedure ActualizarDetalles(ADetalles: IDAStronglyTypedDataTable; ACliente: IBizCliente); overload;
|
|
procedure DesglosarPorteDetalles(ImportePorte: Currency; ADetalles: IDAStronglyTypedDataTable);
|
|
function DarTotalPorteTotal(ADetalles: IDAStronglyTypedDataTable): Double;
|
|
|
|
procedure SetPrecioPunto (const AValue: Currency);
|
|
function GetPrecioPunto: Currency;
|
|
property PrecioPunto : Currency read GetPrecioPunto write SetPrecioPunto;
|
|
end;
|
|
|
|
TDetallesAlbaranClienteController = class(TControllerDetallesArticulos, IDetallesAlbaranClienteController)
|
|
private
|
|
FDataModule : IDataModuleAlbaranesCliente;
|
|
FPrecioPunto: Currency;
|
|
|
|
protected
|
|
// procedure AsignarDatos(ADetalles: IDAStronglyTypedDataTable; IDCabecera: Integer); override;
|
|
procedure RellenarOtros(ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo); override;
|
|
procedure RellenarImportes(ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo); override;
|
|
|
|
procedure AsignarController; override;
|
|
//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;
|
|
procedure DesglosarPorteDetalles(ImportePorte: Currency; ADetalles: IDAStronglyTypedDataTable);
|
|
function DarTotalPorteTotal(ADetalles: IDAStronglyTypedDataTable): Double;
|
|
|
|
function GetPrecioPunto: Currency;
|
|
procedure SetPrecioPunto(const Value: Currency);
|
|
|
|
public
|
|
procedure AnadirArticulos(ADetalles: IDAStronglyTypedDataTable; ACliente: IBizCliente; const ANuevaFila :Boolean = True; const ACantidad: Integer = 1); overload;
|
|
procedure ActualizarDetalles(ADetalles: IDAStronglyTypedDataTable; ACliente: IBizCliente); overload;
|
|
constructor Create; override;
|
|
destructor Destroy; override;
|
|
property PrecioPunto : Currency read GetPrecioPunto write SetPrecioPunto;
|
|
end;
|
|
|
|
implementation
|
|
|
|
uses Dialogs, uDialogUtils, Variants, uControllerDetallesBase, uFactuGES_App, uNumUtils,
|
|
uCalculosUtils, uDataModuleAlbaranesCliente, uArticulosAlbaranClienteController;
|
|
|
|
{ TDetallesAlbaranClienteController }
|
|
|
|
procedure TDetallesAlbaranClienteController.ActualizarDetalles(ADetalles: IDAStronglyTypedDataTable; ACliente: IBizCliente);
|
|
var
|
|
AArticulos : IBizArticulo;
|
|
begin
|
|
if Assigned(ADetalles) then
|
|
begin
|
|
try
|
|
// AArticulos := (FArticulosController.BuscarTodos(ACliente) as IBizArticulo);
|
|
// ActualizarDetalles(ADetalles, AArticulos);
|
|
ActualizarDetalles(ADetalles, ACliente.DESCUENTO_LINEA);
|
|
ShowInfoMessage('Se han actualizado los descuentos para el cliente seleccionado');
|
|
finally
|
|
AArticulos := Nil;
|
|
end;
|
|
end;
|
|
end;
|
|
|
|
procedure TDetallesAlbaranClienteController.AnadirArticulos(ADetalles: IDAStronglyTypedDataTable; ACliente: IBizCliente; const ANuevaFila :Boolean; const ACantidad: Integer);
|
|
var
|
|
AArticulos: IBizArticulo;
|
|
begin
|
|
if Assigned(ADetalles) then
|
|
begin
|
|
try
|
|
AArticulos := (FArticulosController.BuscarTodos(ACliente) as IBizArticulo);
|
|
|
|
//Si nueva fila es false, quiere decir que se sustituye un determinado artículo, por ello la lista a seleccionar no debe ser multiselect
|
|
if ANuevaFila then
|
|
begin
|
|
AArticulos := (FArticulosController as IArticulosAlbaranClienteController).ElegirArticulos(AArticulos, 'Elija los artículos que desea añadir a este albarán de cliente', True);
|
|
Add(ADetalles, AArticulos, ACantidad)
|
|
end
|
|
else
|
|
begin
|
|
AArticulos := (FArticulosController as IArticulosAlbaranClienteController).ElegirArticulos(AArticulos, 'Elija el artículo que desea añadir a este albarán de cliente', False);
|
|
RellenarDetalle(ADetalles, AArticulos, ACantidad);
|
|
end;
|
|
finally
|
|
AArticulos := Nil;
|
|
end;
|
|
end;
|
|
end;
|
|
|
|
procedure TDetallesAlbaranClienteController.AsignarController;
|
|
begin
|
|
FArticulosController := TArticulosAlbaranClienteController.Create;
|
|
end;
|
|
|
|
{procedure TDetallesAlbaranClienteController.AsignarDatos(ADetalles: IDAStronglyTypedDataTable; IDCabecera: Integer);
|
|
begin
|
|
inherited;
|
|
|
|
with (ADetalles as IBizDetallesAlbaranCliente) do
|
|
begin
|
|
Edit;
|
|
// ID := FDataModule.GetNextID(DataTable.LogicalName);
|
|
ID_ALBARAN := IDCabecera;
|
|
Post
|
|
end;
|
|
end;}
|
|
|
|
function TDetallesAlbaranClienteController.CalcularImporteTotalConcepto(DataTable: TDADataTable): Double;
|
|
begin
|
|
Result := CalcularLineaConcepto(DataTable);
|
|
end;
|
|
|
|
constructor TDetallesAlbaranClienteController.Create;
|
|
begin
|
|
inherited;
|
|
FDataModule := TDataModuleAlbaranesCliente.Create(Nil);
|
|
FPrecioPunto:= AppFactuGES.EmpresaActiva.PRECIO_PUNTO;
|
|
end;
|
|
|
|
function TDetallesAlbaranClienteController.DarTotalPorteTotal(ADetalles: IDAStronglyTypedDataTable): Double;
|
|
begin
|
|
Result := DarTotalPorte(ADetalles);
|
|
end;
|
|
|
|
procedure TDetallesAlbaranClienteController.DesglosarPorteDetalles(ImportePorte: Currency; ADetalles: IDAStronglyTypedDataTable);
|
|
begin
|
|
DesglosarPorte(ImportePorte, ADetalles);
|
|
ActualizarTotales(ADetalles);
|
|
end;
|
|
|
|
destructor TDetallesAlbaranClienteController.Destroy;
|
|
begin
|
|
FDataModule := Nil;
|
|
inherited;
|
|
end;
|
|
|
|
|
|
function TDetallesAlbaranClienteController.GetPrecioPunto: Currency;
|
|
begin
|
|
Result := FPrecioPunto;
|
|
end;
|
|
|
|
procedure TDetallesAlbaranClienteController.RellenarOtros(ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo);
|
|
var
|
|
ACadena : String;
|
|
begin
|
|
ACadena := ADetalles.DataTable.FieldByName('CONCEPTO').AsString;
|
|
if (AArticulos.REFERENCIA_PROV <> '') then
|
|
ACadena := AArticulos.REFERENCIA_PROV + ' ' + ACadena;
|
|
if (AArticulos.FAMILIA <> '') then
|
|
ACadena := AArticulos.FAMILIA + ' ' + ACadena;
|
|
ADetalles.DataTable.FieldByName('CONCEPTO').AsString := ACadena;
|
|
|
|
//El descuento que hemos puesto a la vista de articulos es el del cliente seleccionado en el documento
|
|
if Assigned(AArticulos) then
|
|
ADetalles.DataTable.FieldByName(CAMPO_DESCUENTO).AsFloat := AArticulos.DESCUENTO
|
|
else
|
|
ADetalles.DataTable.FieldByName(CAMPO_DESCUENTO).AsFloat := 0;
|
|
end;
|
|
|
|
procedure TDetallesAlbaranClienteController.SetPrecioPunto(const Value: Currency);
|
|
begin
|
|
FPrecioPunto := Value;
|
|
FArticulosController.PrecioPunto := FPrecioPunto;
|
|
end;
|
|
|
|
procedure TDetallesAlbaranClienteController.ValidarCampos(DataTable: TDADataTable);
|
|
begin
|
|
inherited;
|
|
ValidarCamposLineaConcepto(DataTable);
|
|
end;
|
|
|
|
procedure TDetallesAlbaranClienteController.RellenarImportes(ADetalles: IDAStronglyTypedDataTable; AArticulos: IBizArticulo);
|
|
begin
|
|
if ADetalles.DataTable.FieldByName(CAMPO_IMPORTE_UNIDAD).IsNull then
|
|
if Assigned(AArticulos) then
|
|
ADetalles.DataTable.FieldByName(CAMPO_IMPORTE_UNIDAD).AsVariant := RoundCurrency(AArticulos.PRECIO_COSTE * FPrecioPunto)
|
|
else
|
|
ADetalles.DataTable.FieldByName(CAMPO_IMPORTE_UNIDAD).AsVariant := Null;
|
|
end;
|
|
|
|
end.
|