2011-11-14 17:40:41 +00:00
|
|
|
|
unit uDataModuleAlbaranesProveedor;
|
|
|
|
|
|
|
|
|
|
|
|
interface
|
|
|
|
|
|
|
|
|
|
|
|
uses
|
|
|
|
|
|
DB, Classes, SysUtils, uDADesigntimeCall,
|
|
|
|
|
|
uRORemoteService, uROClient, uROBinMessage, uDAScriptingProvider,
|
|
|
|
|
|
uDACDSDataTable, uROWinInetHttpChannel, uDADataTable, uDABINAdapter,
|
|
|
|
|
|
uDAClientDataModule, uROTypes, uIDataModuleAlbaranesProveedorReport, uDataModuleBase,
|
|
|
|
|
|
uIDataModuleAlbaranesProveedor, uBizAlbaranesProveedor, uBizDetallesAlbaranProveedor,
|
|
|
|
|
|
uDARemoteDataAdapter, uDADataStreamer, uDABin2DataStreamer, uDAInterfaces,
|
|
|
|
|
|
uDAMemDataTable;
|
|
|
|
|
|
|
|
|
|
|
|
type
|
|
|
|
|
|
TDataModuleAlbaranesProveedor = class(TDataModuleBase, IDataModuleAlbaranesProveedor, IDataModuleAlbaranesProveedorReport)
|
|
|
|
|
|
RORemoteService: TRORemoteService;
|
|
|
|
|
|
Bin2DataStreamer: TDABin2DataStreamer;
|
|
|
|
|
|
rda_AlbaranesProveedor: TDARemoteDataAdapter;
|
|
|
|
|
|
tbl_AlbaranesProveedor: TDAMemDataTable;
|
|
|
|
|
|
ds_AlbaranesProveedor: TDADataSource;
|
|
|
|
|
|
tbl_AlbaranesProveedor_Detalles: TDAMemDataTable;
|
|
|
|
|
|
ds_AlbaranesProveedor_Detalles: TDADataSource;
|
2024-04-19 15:09:52 +00:00
|
|
|
|
tbl_ListaAnosAlbaranes: TDAMemDataTable;
|
|
|
|
|
|
ds_ListaAnosAlbaranes: TDADataSource;
|
2026-01-22 10:49:05 +00:00
|
|
|
|
tbl_AlbaranesProveedorConArticuloBuscado: TDAMemDataTable;
|
|
|
|
|
|
ds_AlbaranesProveedorConArticuloBuscado: TDADataSource;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
procedure DAClientDataModuleCreate(Sender: TObject);
|
|
|
|
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
function _GetDetalles : IBizDetallesAlbaranProveedor;
|
|
|
|
|
|
|
|
|
|
|
|
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 : IBizAlbaranProveedor; virtual;
|
|
|
|
|
|
function GetItem(const ID : Integer) : IBizAlbaranProveedor;
|
|
|
|
|
|
function NewItem : IBizAlbaranProveedor;
|
2026-01-22 10:49:05 +00:00
|
|
|
|
function GetAlbaranesConArticulo(const Concepto: String; const isEqual: Boolean = false): IBizAlbaranProveedor;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
|
|
|
|
|
|
// Report
|
|
|
|
|
|
function GetReport(const AID: String): Binary;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
implementation
|
|
|
|
|
|
|
|
|
|
|
|
{$R *.DFM}
|
|
|
|
|
|
|
|
|
|
|
|
uses
|
|
|
|
|
|
cxControls, FactuGES_Intf, uDataModuleConexion,
|
|
|
|
|
|
uDataTableUtils, schAlbaranesProveedorClient_Intf, uBizContactos;
|
|
|
|
|
|
|
|
|
|
|
|
{ TdmAlbaranesProveedor }
|
|
|
|
|
|
|
|
|
|
|
|
procedure TDataModuleAlbaranesProveedor.AsignarClaseNegocio(var APedido: TDAMemDataTable);
|
|
|
|
|
|
begin
|
|
|
|
|
|
APedido.BusinessRulesID := BIZ_CLIENT_ALBARAN_PROVEEDOR;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
procedure TDataModuleAlbaranesProveedor.DAClientDataModuleCreate(Sender: TObject);
|
|
|
|
|
|
begin
|
|
|
|
|
|
RORemoteService.Channel := dmConexion.Channel;
|
|
|
|
|
|
RORemoteService.Message := dmConexion.Message;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModuleAlbaranesProveedor.GetReport(const AID: String): Binary;
|
|
|
|
|
|
begin
|
2021-02-07 17:20:37 +00:00
|
|
|
|
Result := (RORemoteService as IsrvAlbaranesProveedor).GenerateReport(AID)
|
2011-11-14 17:40:41 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModuleAlbaranesProveedor.NewItem: IBizAlbaranProveedor;
|
|
|
|
|
|
begin
|
|
|
|
|
|
Result := GetItem(ID_NULO)
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModuleAlbaranesProveedor._GetDetalles: IBizDetallesAlbaranProveedor;
|
|
|
|
|
|
var
|
|
|
|
|
|
ADetalles : TDAMemDataTable;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
ADetalles := CloneDataTable(tbl_AlbaranesProveedor_Detalles);
|
|
|
|
|
|
with ADetalles do
|
|
|
|
|
|
begin
|
|
|
|
|
|
BusinessRulesID := BIZ_CLIENT_DETALLES_ALBARAN_PROVEEDOR;
|
|
|
|
|
|
DetailOptions := DetailOptions - [dtDisableLogOfCascadeDeletes, dtDisableLogOfCascadeUpdates];
|
|
|
|
|
|
end;
|
|
|
|
|
|
Result := (ADetalles as IBizDetallesAlbaranProveedor);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2026-01-22 10:49:05 +00:00
|
|
|
|
function TDataModuleAlbaranesProveedor.GetAlbaranesConArticulo(const Concepto: String; const isEqual: Boolean): IBizAlbaranProveedor;
|
|
|
|
|
|
var
|
|
|
|
|
|
AAlbaranes : 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_AlbaranesProveedorCONCEPTO_BUSQUEDA;
|
|
|
|
|
|
|
|
|
|
|
|
AAlbaranes := CloneDataTable(tbl_AlbaranesProveedorConArticuloBuscado);
|
|
|
|
|
|
AAlbaranes.BusinessRulesID := BIZ_CLIENT_ALBARAN_PROVEEDOR;
|
|
|
|
|
|
|
|
|
|
|
|
with AAlbaranes.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 := (AAlbaranes as IBizAlbaranProveedor);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2024-04-19 15:09:52 +00:00
|
|
|
|
function TDataModuleAlbaranesProveedor.GetAnosItems: TStringList;
|
|
|
|
|
|
var
|
|
|
|
|
|
AListaAnos: TStringList;
|
|
|
|
|
|
begin
|
|
|
|
|
|
AListaAnos := TStringList.Create;
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
with tbl_ListaAnosAlbaranes 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 TDataModuleAlbaranesProveedor.GetItem(const ID: Integer): IBizAlbaranProveedor;
|
|
|
|
|
|
var
|
|
|
|
|
|
Condicion: TDAWhereExpression;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
Result := Self.GetItems;
|
|
|
|
|
|
|
|
|
|
|
|
with Result.DataTable.DynamicWhere do
|
|
|
|
|
|
begin
|
|
|
|
|
|
// (ID = :ID)
|
|
|
|
|
|
Condicion := NewBinaryExpression(NewField('', fld_AlbaranesProveedorID), NewConstant(ID, datInteger), dboEqual);
|
|
|
|
|
|
|
|
|
|
|
|
if IsEmpty then
|
|
|
|
|
|
Expression := Condicion
|
|
|
|
|
|
else
|
|
|
|
|
|
Expression := NewBinaryExpression(Expression, Condicion, dboAnd);
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModuleAlbaranesProveedor.GetItems: IBizAlbaranProveedor;
|
|
|
|
|
|
var
|
|
|
|
|
|
AAlbaran : TDAMemDataTable;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
AAlbaran := CloneDataTable(tbl_AlbaranesProveedor);
|
|
|
|
|
|
AsignarClaseNegocio(AAlbaran);
|
|
|
|
|
|
|
|
|
|
|
|
// EL CAMPO REFERENCIA TIENE QUE SER AUTOREFRESH!!!!!
|
|
|
|
|
|
AAlbaran.FieldByName(fld_AlbaranesProveedorREFERENCIA).ServerAutoRefresh := TRUE;
|
|
|
|
|
|
|
|
|
|
|
|
with TBizAlbaranProveedor(AAlbaran.BusinessEventsObj) do
|
|
|
|
|
|
begin
|
|
|
|
|
|
Detalles := _GetDetalles;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
Result := (AAlbaran as IBizAlbaranProveedor);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
end.
|