200 lines
6.5 KiB
ObjectPascal
200 lines
6.5 KiB
ObjectPascal
unit uDataModulePresupuestosCliente;
|
||
|
||
interface
|
||
|
||
uses
|
||
DB, Classes, SysUtils, uDADesigntimeCall, uROServiceComponent,
|
||
uRORemoteService, uROClient, uROBinMessage, uDAScriptingProvider,
|
||
uDACDSDataTable, uROWinInetHttpChannel, uDADataTable, uDABINAdapter,
|
||
|
||
uDAClientDataModule, uROTypes,
|
||
uIDataModulePresupuestosCliente, uBizPresupuestosCliente, uBizDetallesPresupuestoCliente,
|
||
uIDataModulePresupuestosClienteReport, uDataModuleBase, uDAInterfaces,
|
||
uRODynamicRequest, uDADataStreamer, uDARemoteDataAdapter, uDABin2DataStreamer;
|
||
|
||
type
|
||
TDataModulePresupuestosCliente = class(TDataModuleBase, IDataModulePresupuestosCliente, IDataModulePresupuestosClienteReport)
|
||
RORemoteService: TRORemoteService;
|
||
tbl_PresupuestosCliente: TDACDSDataTable;
|
||
ds_PedidosCliente: TDADataSource;
|
||
tbl_PresupuestosCliente_Detalles: TDACDSDataTable;
|
||
ds_PedidosCliente_Detalles: TDADataSource;
|
||
tbl_PresupuestoCliente_Articulos_Pendientes: TDACDSDataTable;
|
||
ds_PresupuestoCliente_Articulos_Pendientes: TDADataSource;
|
||
tbl_PresupuestoCliente_ArticulosPendientesPedirAProv: TDACDSDataTable;
|
||
ds_PresupuestoCliente_ArticulosPendientesPedirAProv: TDADataSource;
|
||
Bin2DataStreamer: TDABin2DataStreamer;
|
||
rda_PresupuestosCliente: TDARemoteDataAdapter;
|
||
procedure DAClientDataModuleCreate(Sender: TObject);
|
||
|
||
private
|
||
function _CloneDataTable (const ADataTable : TDACDSDataTable): TDACDSDataTable; overload;
|
||
function _GetDetalles : IBizDetallesPresupuestoCliente;
|
||
|
||
protected
|
||
procedure AsignarClaseNegocio(var APedido: TDACDSDataTable); virtual;
|
||
|
||
public
|
||
function GetArticulosPendientesPedirAProv(const IDPedido: Integer): IBizPresupuestoClienteArticulosPendientesPedirAProv;
|
||
function GetArticulosPendientes(const IDPedido: Integer): IBizPresupuestoClienteArticulosPend;
|
||
function GetItems : IBizPresupuestoCliente; virtual;
|
||
function GetItem(const ID : Integer) : IBizPresupuestoCliente;
|
||
function GetNextID(const DataSetName : String) : Integer;
|
||
function NewItem : IBizPresupuestoCliente;
|
||
|
||
// Report
|
||
function GetReport(const AID: String): Binary;
|
||
end;
|
||
|
||
implementation
|
||
|
||
{$R *.DFM}
|
||
|
||
uses
|
||
cxControls, FactuGES_Intf, uDataModuleConexion,
|
||
uDataTableUtils, schPedidosClienteClient_Intf, uBizContactos;
|
||
|
||
{ TdmPedidosCliente }
|
||
|
||
procedure TDataModulePresupuestosCliente.AsignarClaseNegocio(var APedido: TDACDSDataTable);
|
||
begin
|
||
APedido.BusinessRulesID := BIZ_CLIENT_PEDIDO_CLIENTE;
|
||
end;
|
||
|
||
procedure TDataModulePresupuestosCliente.DAClientDataModuleCreate(Sender: TObject);
|
||
begin
|
||
RORemoteService.Channel := dmConexion.Channel;
|
||
RORemoteService.Message := dmConexion.Message;
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente.GetNextID(const DataSetName: String): Integer;
|
||
var
|
||
aGeneratorName : String;
|
||
begin
|
||
{
|
||
if DataSetName = nme_PedidosCliente then
|
||
aGeneratorName := 'GEN_PEDIDOS_CLI_ID';
|
||
|
||
if DataSetName = nme_PedidosCliente_Detalles then
|
||
aGeneratorName := 'GEN_PEDIDOS_CLI_DETALLES_ID';
|
||
}
|
||
// Result := (RORemoteService as IsrvPresupuestosCliente).GetNextAutoInc(aGeneratorName)
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente.GetReport(const AID: String): Binary;
|
||
begin
|
||
Result := (RORemoteService as IsrvPresupuestosCliente).GenerateReport(AID)
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente.NewItem: IBizPresupuestoCliente;
|
||
begin
|
||
Result := GetItem(ID_NULO)
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente._CloneDataTable(const ADataTable : TDACDSDataTable): TDACDSDataTable;
|
||
begin
|
||
Result := NIL;
|
||
|
||
if not Assigned(ADataTable) then
|
||
raise Exception.Create ('No se ha asignado la tabla de origen (CloneDataTable)');
|
||
|
||
Result := TDACDSDataTable.Create(NIL);
|
||
CloneDataTable(ADataTable, Result);
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente._GetDetalles: IBizDetallesPresupuestoCliente;
|
||
var
|
||
ADetalles : TDACDSDataTable;
|
||
begin
|
||
ShowHourglassCursor;
|
||
try
|
||
ADetalles := _CloneDataTable(tbl_PresupuestosCliente_Detalles);
|
||
with ADetalles do
|
||
begin
|
||
BusinessRulesID := BIZ_CLIENT_DETALLES_PEDIDO_CLIENTE;
|
||
DetailOptions := DetailOptions -
|
||
[dtDisableLogOfCascadeDeletes, dtDisableLogOfCascadeUpdates];
|
||
end;
|
||
Result := (ADetalles as IBizDetallesPresupuestoCliente);
|
||
finally
|
||
HideHourglassCursor;
|
||
end;
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente.GetArticulosPendientes(
|
||
const IDPedido: Integer): IBizPresupuestoClienteArticulosPend;
|
||
var
|
||
AArticulos : TDACDSDataTable;
|
||
begin
|
||
ShowHourglassCursor;
|
||
try
|
||
AArticulos := _CloneDataTable(tbl_PresupuestoCliente_Articulos_Pendientes);
|
||
AArticulos.BusinessRulesID := BIZ_CLIENT_ARTICULOS_PEND_PEDIDO_CLIENTE;
|
||
AArticulos.ParamByName('ID_PEDIDO').AsInteger := IDPedido;
|
||
Result := (AArticulos as IBizPresupuestoClienteArticulosPend);
|
||
finally
|
||
HideHourglassCursor;
|
||
end;
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente.GetArticulosPendientesPedirAProv(
|
||
const IDPedido: Integer): IBizPresupuestoClienteArticulosPendientesPedirAProv;
|
||
var
|
||
AArticulos : TDACDSDataTable;
|
||
begin
|
||
ShowHourglassCursor;
|
||
try
|
||
AArticulos := _CloneDataTable(tbl_PresupuestoCliente_ArticulosPendientesPedirAProv);
|
||
AArticulos.BusinessRulesID := BIZ_CLIENT_PEDIDO_CLIENTE_ARTICULOS_PENDIENTES_PEDIR_A_PROV;
|
||
AArticulos.ParamByName('ID_PEDIDO').AsInteger := IDPedido;
|
||
Result := (AArticulos as IBizPresupuestoClienteArticulosPendientesPedirAProv);
|
||
finally
|
||
HideHourglassCursor;
|
||
end;
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente.GetItem(const ID: Integer): IBizPresupuestoCliente;
|
||
begin
|
||
ShowHourglassCursor;
|
||
try
|
||
Result := Self.GetItems;
|
||
with Result.DataTable.Where do
|
||
begin
|
||
if NotEmpty then
|
||
AddOperator(opAND);
|
||
OpenBraket;
|
||
AddText(fld_PedidosClienteID + ' = ' + IntToStr(ID));
|
||
CloseBraket;
|
||
end;
|
||
finally
|
||
HideHourglassCursor;
|
||
end;
|
||
end;
|
||
|
||
function TDataModulePresupuestosCliente.GetItems: IBizPresupuestoCliente;
|
||
var
|
||
APedido : TDACDSDataTable;
|
||
begin
|
||
ShowHourglassCursor;
|
||
try
|
||
APedido := _CloneDataTable(tbl_PresupuestosCliente);
|
||
|
||
// EL CAMPO REFERENCIA Y SITUACI<43>N TIENEN QUE SER AUTOREFRESH!!!!!
|
||
APedido.FieldByName(fld_PedidosClienteREFERENCIA).ServerAutoRefresh := TRUE;
|
||
APedido.FieldByName(fld_PedidosClienteSITUACION).ServerAutoRefresh := TRUE;
|
||
|
||
AsignarClaseNegocio(APedido);
|
||
|
||
with TBizPresupuestoCliente(APedido.BusinessEventsObj) do
|
||
begin
|
||
Detalles := _GetDetalles;
|
||
end;
|
||
|
||
Result := (APedido as IBizPresupuestoCliente);
|
||
finally
|
||
HideHourglassCursor;
|
||
end;
|
||
end;
|
||
|
||
end.
|