2011-11-14 17:40:41 +00:00
|
|
|
|
unit uDataModuleArticulos;
|
|
|
|
|
|
|
|
|
|
|
|
interface
|
|
|
|
|
|
|
|
|
|
|
|
uses
|
|
|
|
|
|
SysUtils, Classes, DB, uDADataTable, uDABINAdapter,
|
|
|
|
|
|
uDAScriptingProvider, uROWinInetHttpChannel, uROTypes,
|
|
|
|
|
|
uRORemoteService, uROClient, uROBinMessage,
|
|
|
|
|
|
uDADesigntimeCall,
|
|
|
|
|
|
uIDataModuleArticulos, uBizArticulos, uDataModuleBase, uDARemoteDataAdapter,
|
2020-12-28 16:54:17 +00:00
|
|
|
|
uDADataStreamer, uDABin2DataStreamer, uDAInterfaces, uDAMemDataTable,
|
2024-02-05 10:15:29 +00:00
|
|
|
|
uBizArticulosProveedores, uBizArticulosIdiomas;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
|
|
|
|
|
|
type
|
|
|
|
|
|
TDataModuleArticulos = class(TDataModuleBase, IDataModuleArticulos)
|
|
|
|
|
|
RORemoteService: TRORemoteService;
|
|
|
|
|
|
Bin2DataStreamer: TDABin2DataStreamer;
|
|
|
|
|
|
rda_Articulos: TDARemoteDataAdapter;
|
|
|
|
|
|
tbl_Articulos: TDAMemDataTable;
|
|
|
|
|
|
ds_Articulos: TDADataSource;
|
|
|
|
|
|
tbl_ArticulosParaCliente: TDAMemDataTable;
|
|
|
|
|
|
ds_ArticulosParaCliente: TDADataSource;
|
2020-12-28 16:54:17 +00:00
|
|
|
|
tbl_Articulos_Proveedores: TDAMemDataTable;
|
|
|
|
|
|
ds_Articulos_Proveedores: TDADataSource;
|
2021-02-07 17:20:37 +00:00
|
|
|
|
tbl_ArticulosParaCompra: TDAMemDataTable;
|
|
|
|
|
|
ds_ArticulosParaCompra: TDADataSource;
|
2024-02-05 10:15:29 +00:00
|
|
|
|
tbl_Articulos_Idiomas: TDAMemDataTable;
|
|
|
|
|
|
ds_Articulos_Idiomas: TDADataSource;
|
2024-04-19 15:09:52 +00:00
|
|
|
|
tbl_ListaTarifasArticulos: TDAMemDataTable;
|
|
|
|
|
|
ds_ListaTarifasArticulos: TDADataSource;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
procedure DAClientDataModuleCreate(Sender: TObject);
|
2020-12-28 16:54:17 +00:00
|
|
|
|
private
|
|
|
|
|
|
function _GetProveedores : IBizArticulosProveedores;
|
2024-02-05 10:15:29 +00:00
|
|
|
|
function _GetIdiomas : IBizArticulosIdiomas;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
|
|
|
|
|
|
protected
|
|
|
|
|
|
procedure AsignarClaseNegocio(AArticulo: TDADataTable); virtual;
|
|
|
|
|
|
|
|
|
|
|
|
public
|
2020-12-28 16:54:17 +00:00
|
|
|
|
function GetItems (const Tipo: TEnumArticulos): IBizArticulo; overload;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
function GetItems (IDCliente: Integer) : IBizArticulo; overload;
|
|
|
|
|
|
function GetItem(const ID : Integer; AClienteID: Integer = -1) : IBizArticulo;
|
|
|
|
|
|
function NewItem : IBizArticulo;
|
2024-04-19 15:09:52 +00:00
|
|
|
|
function GetTarifasItems : TStringList;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
implementation
|
|
|
|
|
|
|
|
|
|
|
|
{$R *.DFM}
|
|
|
|
|
|
|
|
|
|
|
|
uses
|
|
|
|
|
|
FactuGES_Intf, uDataModuleConexion, uDataTableUtils, cxControls,
|
|
|
|
|
|
schArticulosClient_Intf;
|
|
|
|
|
|
|
|
|
|
|
|
{ TdmArticulos }
|
|
|
|
|
|
|
|
|
|
|
|
procedure TDataModuleArticulos.AsignarClaseNegocio(AArticulo: TDADataTable);
|
|
|
|
|
|
begin
|
|
|
|
|
|
AArticulo.BusinessRulesID := BIZ_CLIENT_ARTICULO;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
procedure TDataModuleArticulos.DAClientDataModuleCreate(Sender: TObject);
|
|
|
|
|
|
begin
|
|
|
|
|
|
RORemoteService.Channel := dmConexion.Channel;
|
|
|
|
|
|
RORemoteService.Message := dmConexion.Message;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModuleArticulos.NewItem: IBizArticulo;
|
|
|
|
|
|
begin
|
|
|
|
|
|
Result := GetItem(ID_NULO)
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2024-02-05 10:15:29 +00:00
|
|
|
|
function TDataModuleArticulos._GetIdiomas: IBizArticulosIdiomas;
|
|
|
|
|
|
var
|
|
|
|
|
|
AIdiomas : TDAMemDataTable;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
AIdiomas := CloneDataTable(tbl_Articulos_Idiomas);
|
|
|
|
|
|
with AIdiomas do
|
|
|
|
|
|
begin
|
|
|
|
|
|
BusinessRulesID := BIZ_CLIENT_ARTICULOS_IDIOMAS;
|
|
|
|
|
|
DetailOptions := DetailOptions - [dtDisableLogOfCascadeDeletes, dtDisableLogOfCascadeUpdates];
|
|
|
|
|
|
end;
|
|
|
|
|
|
Result := (AIdiomas as IBizArticulosIdiomas);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2020-12-28 16:54:17 +00:00
|
|
|
|
function TDataModuleArticulos._GetProveedores: IBizArticulosProveedores;
|
|
|
|
|
|
var
|
|
|
|
|
|
AProveedores : TDAMemDataTable;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
AProveedores := CloneDataTable(tbl_Articulos_Proveedores);
|
|
|
|
|
|
with AProveedores do
|
|
|
|
|
|
begin
|
|
|
|
|
|
BusinessRulesID := BIZ_CLIENT_ARTICULOS_PROVEEDORES;
|
|
|
|
|
|
DetailOptions := DetailOptions - [dtDisableLogOfCascadeDeletes, dtDisableLogOfCascadeUpdates];
|
|
|
|
|
|
end;
|
|
|
|
|
|
Result := (AProveedores as IBizArticulosProveedores);
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2011-11-14 17:40:41 +00:00
|
|
|
|
function TDataModuleArticulos.GetItem(const ID: Integer; AClienteID: Integer = -1): IBizArticulo;
|
|
|
|
|
|
var
|
|
|
|
|
|
Condicion: TDAWhereExpression;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
if (AClienteID = -1) then
|
2020-12-28 16:54:17 +00:00
|
|
|
|
Result := Self.GetItems(txArticulo)
|
2011-11-14 17:40:41 +00:00
|
|
|
|
else
|
|
|
|
|
|
Result := Self.GetItems(AClienteID);
|
|
|
|
|
|
|
|
|
|
|
|
with Result.DataTable.DynamicWhere do
|
|
|
|
|
|
begin
|
|
|
|
|
|
// (ID = :ID)
|
|
|
|
|
|
Condicion := NewBinaryExpression(NewField('', fld_ArticulosID), NewConstant(ID, datInteger), dboEqual);
|
|
|
|
|
|
|
|
|
|
|
|
if IsEmpty then
|
|
|
|
|
|
Expression := Condicion
|
|
|
|
|
|
else
|
|
|
|
|
|
Expression := NewBinaryExpression(Expression, Condicion, dboAnd);
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
function TDataModuleArticulos.GetItems(IDCliente: Integer): IBizArticulo;
|
|
|
|
|
|
var
|
|
|
|
|
|
AArticulo : TDAMemDataTable;
|
|
|
|
|
|
begin
|
|
|
|
|
|
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
AArticulo := CloneDataTable(tbl_ArticulosParaCliente);
|
|
|
|
|
|
AsignarClaseNegocio(AArticulo);
|
|
|
|
|
|
|
|
|
|
|
|
AArticulo.ParamByName('ID_CLIENTE').AsInteger := IdCliente;
|
|
|
|
|
|
|
|
|
|
|
|
Result := (AArticulo as IBizArticulo);
|
|
|
|
|
|
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2024-04-19 15:09:52 +00:00
|
|
|
|
function TDataModuleArticulos.GetTarifasItems: TStringList;
|
|
|
|
|
|
var
|
|
|
|
|
|
AListaTarifas: TStringList;
|
|
|
|
|
|
begin
|
|
|
|
|
|
AListaTarifas := TStringList.Create;
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
|
|
|
|
|
with tbl_ListaTarifasArticulos do
|
|
|
|
|
|
begin
|
|
|
|
|
|
Open;
|
|
|
|
|
|
First;
|
|
|
|
|
|
while not eof do
|
|
|
|
|
|
begin
|
|
|
|
|
|
AListaTarifas.Add(Format('%s=%s', [Fields[0].AsString, Fields[0].AsString]));
|
|
|
|
|
|
Next;
|
|
|
|
|
|
end;
|
|
|
|
|
|
Close;
|
|
|
|
|
|
end;
|
|
|
|
|
|
Result := AListaTarifas;
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2020-12-28 16:54:17 +00:00
|
|
|
|
function TDataModuleArticulos.GetItems (const Tipo: TEnumArticulos): IBizArticulo;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
var
|
|
|
|
|
|
AArticulo : TDAMemDataTable;
|
|
|
|
|
|
begin
|
|
|
|
|
|
ShowHourglassCursor;
|
|
|
|
|
|
try
|
2020-12-28 16:54:17 +00:00
|
|
|
|
case Tipo of
|
|
|
|
|
|
txArticulo: AArticulo := CloneDataTable(tbl_Articulos);
|
2021-02-07 17:20:37 +00:00
|
|
|
|
txProveedor: AArticulo := CloneDataTable(tbl_ArticulosParaCompra); //En el caso de tener varios proveedores para un mismo art<72>culo
|
|
|
|
|
|
// txProveedor: AArticulo := CloneDataTable(tbl_Articulos); //En el caso de tener solo un proveedor por articulo
|
2020-12-28 16:54:17 +00:00
|
|
|
|
end;
|
2011-11-14 17:40:41 +00:00
|
|
|
|
|
|
|
|
|
|
AsignarClaseNegocio(AArticulo);
|
|
|
|
|
|
|
2020-12-28 16:54:17 +00:00
|
|
|
|
case Tipo of
|
2024-02-05 10:15:29 +00:00
|
|
|
|
txArticulo: begin
|
|
|
|
|
|
TBizArticulo(AArticulo.BusinessEventsObj).Proveedores := _GetProveedores;
|
|
|
|
|
|
TBizArticulo(AArticulo.BusinessEventsObj).Idiomas := _GetIdiomas;
|
|
|
|
|
|
end;
|
2020-12-28 16:54:17 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
2011-11-14 17:40:41 +00:00
|
|
|
|
Result := (AArticulo as IBizArticulo);
|
|
|
|
|
|
|
|
|
|
|
|
finally
|
|
|
|
|
|
HideHourglassCursor;
|
|
|
|
|
|
end;
|
2020-12-28 16:54:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
2011-11-14 17:40:41 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
end.
|