2011-11-14 17:40:41 +00:00
|
|
|
|
unit uDataModulePedidosProveedor;
|
|
|
|
|
|
|
|
|
|
|
|
interface
|
|
|
|
|
|
|
|
|
|
|
|
uses
|
|
|
|
|
|
DB, Classes, SysUtils, uDADesigntimeCall,
|
|
|
|
|
|
uRORemoteService, uROClient, uROBinMessage, uDAScriptingProvider,
|
|
|
|
|
|
uDACDSDataTable, uROWinInetHttpChannel, uDADataTable, uDABINAdapter,
|
|
|
|
|
|
|
|
|
|
|
|
uDAClientDataModule, uROTypes, uDataModuleBase,
|
|
|
|
|
|
uIDataModulePedidosProveedor, uIDataModulePedidosProveedorReport,
|
|
|
|
|
|
uBizPedidosProveedor, uBizDetallesPedidoProveedor, uDARemoteDataAdapter,
|
|
|
|
|
|
uDADataStreamer, uDABin2DataStreamer, uDAInterfaces, uDAMemDataTable;
|
|
|
|
|
|
|
|
|
|
|
|
type
|
|
|
|
|
|
TDataModulePedidosProveedor = class(TDataModuleBase, IDataModulePedidosProveedor,
|
|
|
|
|
|
IDataModulePedidosProveedorReport)
|
|
|
|
|
|
RORemoteService: TRORemoteService;
|
|
|
|
|
|
Bin2DataStreamer: TDABin2DataStreamer;
|
|
|
|
|
|
rda_PedidosProveedor: TDARemoteDataAdapter;
|
|
|
|
|
|
tbl_PedidosProveedor: TDAMemDataTable;
|
|
|
|
|
|
ds_PedidosProveedor: TDADataSource;
|
|
|
|
|
|
tbl_PedidosProveedor_Articulos_Pendientes: TDAMemDataTable;
|
|
|
|
|
|
ds_PedidosProveedor_Articulos_Pendientes: TDADataSource;
|
|
|
|
|
|
tbl_PedidosProveedor_Detalles: TDAMemDataTable;
|
|
|
|
|
|
ds_PedidosProveedor_Detalles: TDADataSource;
|
2024-04-19 15:09:52 +00:00
|
|
|
|
tbl_ListaAnosPedidos: TDAMemDataTable;
|
|
|
|
|
|
ds_ListaAnosPedidos: TDADataSource;
|
2025-07-23 10:19:05 +00:00
|
|
|
|
tbl_PedidosProveedorConArticuloBuscado: TDAMemDataTable;
|
|
|
|
|
|
ds_PedidosProveedorConArticuloBuscado: TDADataSource;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
procedure DAClientDataModuleCreate(Sender: TObject);
|
|
|
|
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
function _GetDetalles : IBizDetallesPedidoProveedor;
|
|
|
|
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
procedure AsignarClaseNegocio(var APedido: TDAMemDataTable); virtual;
|
|
|
|
|
|
|
|
|
|
|
|
public
|
2024-04-19 15:09:52 +00:00
|
|
|
|
function GetAnosItems : TStringList;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
function GetItems : IBizPedidoProveedor; virtual;
|
|
|
|
|
|
function GetItem(const ID : Integer) : IBizPedidoProveedor;
|
|
|
|
|
|
function NewItem : IBizPedidoProveedor;
|
|
|
|
|
|
function GetArticulosPendientes(const IDPedido: Integer): IBizDetallesPedidoProveedorPend;
|
2025-07-23 10:19:05 +00:00
|
|
|
|
function GetPedidosConArticulo(const Concepto: String; const isEqual: Boolean = false): IBizPedidoProveedor;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
|
|
|
|
|
|
// Report
|
2022-03-12 10:40:36 +00:00
|
|
|
|
function GetReport(const AID: String; const VerPrecios: Boolean = false): Binary;
|
|
|
|
|
|
function GetRptPDFPedido(const AID: Integer; const VerPrecios: Boolean = false): Binary;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
implementation
|
|
|
|
|
|
|
|
|
|
|
|
{$R *.DFM}
|
|
|
|
|
|
|
|
|
|
|
|
uses
|
2025-07-23 10:19:05 +00:00
|
|
|
|
cxControls, FactuGES_Intf, uDataModuleConexion, uDialogUtils,
|
2011-11-14 17:40:41 +00:00
|
|
|
|
uDataTableUtils, schPedidosProveedorClient_Intf, uBizContactos;
|
|
|
|
|
|
|
|
|
|
|
|
{ TdmPedidosProveedor }
|
|
|
|
|
|
|
|
|
|
|
|
procedure TDataModulePedidosProveedor.AsignarClaseNegocio(var APedido: TDAMemDataTable);
|
|
|
|
|
|
begin
|
|
|
|
|
|
APedido.BusinessRulesID := BIZ_CLIENT_PEDIDO_PROVEEDOR;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
procedure TDataModulePedidosProveedor.DAClientDataModuleCreate(Sender: TObject);
|
|
|
|
|
|
begin
|
|
|
|
|
|
RORemoteService.Channel := dmConexion.Channel;
|
|
|
|
|
|
RORemoteService.Message := dmConexion.Message;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2022-03-12 10:40:36 +00:00
|
|
|
|
function TDataModulePedidosProveedor.GetReport(const AID: String; const VerPrecios: Boolean = false): Binary;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
begin
|
2022-03-12 10:40:36 +00:00
|
|
|
|
Result := (RORemoteService as IsrvPedidosProveedor).GenerateReport(AID, VerPrecios)
|
2021-02-07 17:20:37 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
2022-03-12 10:40:36 +00:00
|
|
|
|
function TDataModulePedidosProveedor.GetRptPDFPedido(const AID: Integer; const VerPrecios: Boolean = false): Binary;
|
2021-02-07 17:20:37 +00:00
|
|
|
|
var
|
|
|
|
|
|
AParam : TIntegerArray;
|
|
|
|
|
|
begin
|
|
|
|
|
|
AParam := TIntegerArray.Create;
|
|
|
|
|
|
try
|
|
|
|
|
|
AParam.Add(AID);
|
2022-03-12 10:40:36 +00:00
|
|
|
|
Result := (RORemoteService as IsrvPedidosProveedor).GenerarInformeEnPDF(AParam, VerPrecios)
|
2021-02-07 17:20:37 +00:00
|
|
|
|
finally
|
|
|
|
|
|
FreeANDNIL(AParam)
|
|
|
|
|
|
end;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModulePedidosProveedor.NewItem: IBizPedidoProveedor;
|
|
|
|
|
|
begin
|
|
|
|
|
|
Result := GetItem(ID_NULO)
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModulePedidosProveedor._GetDetalles: IBizDetallesPedidoProveedor;
|
|
|
|
|
|
var
|
|
|
|
|
|
ADetalles : TDAMemDataTable;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
ADetalles := CloneDataTable(tbl_PedidosProveedor_Detalles);
|
|
|
|
|
|
with ADetalles do
|
|
|
|
|
|
begin
|
|
|
|
|
|
BusinessRulesID := BIZ_CLIENT_DETALLES_PEDIDO_PROVEEDOR;
|
|
|
|
|
|
DetailOptions := DetailOptions - [dtDisableLogOfCascadeDeletes, dtDisableLogOfCascadeUpdates];
|
|
|
|
|
|
end;
|
|
|
|
|
|
Result := (ADetalles as IBizDetallesPedidoProveedor);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2024-04-19 15:09:52 +00:00
|
|
|
|
function TDataModulePedidosProveedor.GetAnosItems: TStringList;
|
|
|
|
|
|
var
|
|
|
|
|
|
AListaAnos: TStringList;
|
|
|
|
|
|
begin
|
|
|
|
|
|
AListaAnos := TStringList.Create;
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
with tbl_ListaAnosPedidos do
|
|
|
|
|
|
begin
|
|
|
|
|
|
Open;
|
|
|
|
|
|
First;
|
|
|
|
|
|
while not eof do
|
|
|
|
|
|
begin
|
|
|
|
|
|
AListaAnos.Add(Format('%s=%s', [Fields[0].AsString, Fields[0].AsString]));
|
|
|
|
|
|
Next;
|
|
|
|
|
|
end;
|
|
|
|
|
|
Close;
|
|
|
|
|
|
end;
|
|
|
|
|
|
Result := AListaAnos;
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2011-11-14 17:40:41 +00:00
|
|
|
|
function TDataModulePedidosProveedor.GetArticulosPendientes(const IDPedido: Integer): IBizDetallesPedidoProveedorPend;
|
|
|
|
|
|
var
|
|
|
|
|
|
AArticulos : TDAMemDataTable;
|
2021-02-07 17:20:37 +00:00
|
|
|
|
Condicion: TDAWhereExpression;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
AArticulos := CloneDataTable(tbl_PedidosProveedor_Articulos_Pendientes);
|
|
|
|
|
|
AArticulos.BusinessRulesID := BIZ_CLIENT_DETALLES_PEDIDO_PROVEEDOR_PEND;
|
2021-02-07 17:20:37 +00:00
|
|
|
|
|
|
|
|
|
|
with AArticulos.DynamicWhere do
|
|
|
|
|
|
begin
|
|
|
|
|
|
// (ID = :ID)
|
|
|
|
|
|
Condicion := NewBinaryExpression(NewField('', fld_PedidosProveedor_DetallesID_PEDIDO), NewConstant(IDPedido, datInteger), dboEqual);
|
|
|
|
|
|
|
|
|
|
|
|
if IsEmpty then
|
|
|
|
|
|
Expression := Condicion
|
|
|
|
|
|
else
|
|
|
|
|
|
Expression := NewBinaryExpression(Expression, Condicion, dboAnd);
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
// AArticulos.ParamByName(fld_PedidosProveedor_DetallesID_PEDIDO).AsInteger := IDPedido;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
Result := (AArticulos as IBizDetallesPedidoProveedorPend);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModulePedidosProveedor.GetItem(const ID: Integer): IBizPedidoProveedor;
|
|
|
|
|
|
var
|
|
|
|
|
|
Condicion: TDAWhereExpression;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
Result := Self.GetItems;
|
|
|
|
|
|
|
|
|
|
|
|
with Result.DataTable.DynamicWhere do
|
|
|
|
|
|
begin
|
|
|
|
|
|
// (ID = :ID)
|
|
|
|
|
|
Condicion := NewBinaryExpression(NewField('', fld_PedidosProveedorID), NewConstant(ID, datInteger), dboEqual);
|
|
|
|
|
|
|
|
|
|
|
|
if IsEmpty then
|
|
|
|
|
|
Expression := Condicion
|
|
|
|
|
|
else
|
|
|
|
|
|
Expression := NewBinaryExpression(Expression, Condicion, dboAnd);
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModulePedidosProveedor.GetItems: IBizPedidoProveedor;
|
|
|
|
|
|
var
|
|
|
|
|
|
APedido : TDAMemDataTable;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
APedido := CloneDataTable(tbl_PedidosProveedor);
|
|
|
|
|
|
AsignarClaseNegocio(APedido);
|
|
|
|
|
|
|
|
|
|
|
|
// EL CAMPO REFERENCIA TIENE QUE SER AUTOREFRESH!!!!!
|
|
|
|
|
|
APedido.FieldByName(fld_PedidosProveedorREFERENCIA).ServerAutoRefresh := TRUE;
|
|
|
|
|
|
|
|
|
|
|
|
with TBizPedidoProveedor(APedido.BusinessEventsObj) do
|
|
|
|
|
|
begin
|
|
|
|
|
|
Detalles := _GetDetalles;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
Result := (APedido as IBizPedidoProveedor);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2025-07-23 10:19:05 +00:00
|
|
|
|
function TDataModulePedidosProveedor.GetPedidosConArticulo(const Concepto: String; const isEqual: Boolean = false): IBizPedidoProveedor;
|
|
|
|
|
|
var
|
|
|
|
|
|
APedidos : TDAMemDataTable;
|
|
|
|
|
|
Condicion, Filtro: TDAWhereExpression;
|
|
|
|
|
|
ACadena: String;
|
|
|
|
|
|
Campos : array[0..0] of string;
|
|
|
|
|
|
I : Integer;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
// Convertimos el texto a MAY<41>SCULAS para compararlo con campos tambi<62>n en MAY<41>SCULAS
|
|
|
|
|
|
ACadena := '%' + UpperCase(Concepto) + '%';
|
|
|
|
|
|
|
|
|
|
|
|
Campos[0] := fld_PedidosProveedorCONCEPTO_BUSQUEDA;
|
|
|
|
|
|
|
|
|
|
|
|
APedidos := CloneDataTable(tbl_PedidosProveedorConArticuloBuscado);
|
|
|
|
|
|
APedidos.BusinessRulesID := BIZ_CLIENT_PEDIDO_PROVEEDOR;
|
|
|
|
|
|
|
|
|
|
|
|
with APedidos.DynamicWhere do
|
|
|
|
|
|
begin
|
|
|
|
|
|
|
|
|
|
|
|
Filtro := nil;
|
|
|
|
|
|
for I := Low(Campos) to High(Campos) do
|
|
|
|
|
|
begin
|
|
|
|
|
|
Condicion := NewBinaryExpression(
|
|
|
|
|
|
NewField('', Campos[I]),
|
|
|
|
|
|
NewConstant(ACadena, datString),
|
|
|
|
|
|
dboLike
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
if Filtro = nil then
|
|
|
|
|
|
Filtro := Condicion
|
|
|
|
|
|
else
|
|
|
|
|
|
Filtro := NewBinaryExpression(Filtro, Condicion, dboOr);
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
// Aplicar filtro
|
|
|
|
|
|
if IsEmpty then
|
|
|
|
|
|
Expression := Filtro
|
|
|
|
|
|
else
|
|
|
|
|
|
Expression := NewBinaryExpression(Expression, Filtro, dboAnd);
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
Result := (APedidos as IBizPedidoProveedor);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2011-11-14 17:40:41 +00:00
|
|
|
|
end.
|