git-svn-id: https://192.168.0.254/svn/Proyectos.LuisLeon_FactuGES2/trunk@60 b2cfbe5a-eba1-4a0c-8b32-7feea0a119f2
162 lines
4.6 KiB
ObjectPascal
162 lines
4.6 KiB
ObjectPascal
unit uDataModuleArticulos;
|
||
|
||
interface
|
||
|
||
uses
|
||
SysUtils, Classes, DB, uDADataTable, uDABINAdapter,
|
||
uDAScriptingProvider, uROWinInetHttpChannel, uROTypes,
|
||
uRORemoteService, uROClient, uROBinMessage,
|
||
uDADesigntimeCall,
|
||
uIDataModuleArticulos, uBizArticulos, uDataModuleBase, uDARemoteDataAdapter,
|
||
uDADataStreamer, uDABin2DataStreamer, uDAInterfaces, uDAMemDataTable,
|
||
uBizArticulosProveedores;
|
||
|
||
type
|
||
TDataModuleArticulos = class(TDataModuleBase, IDataModuleArticulos)
|
||
RORemoteService: TRORemoteService;
|
||
Bin2DataStreamer: TDABin2DataStreamer;
|
||
rda_Articulos: TDARemoteDataAdapter;
|
||
tbl_Articulos: TDAMemDataTable;
|
||
ds_Articulos: TDADataSource;
|
||
tbl_ProveedoresConArticulos: TDAMemDataTable;
|
||
ds_ProveedoresConArticulos: TDADataSource;
|
||
tbl_Articulos_Proveedores: TDAMemDataTable;
|
||
ds_Articulos_Proveedores: TDADataSource;
|
||
tbl_ArticulosParaCompra: TDAMemDataTable;
|
||
ds_ArticulosParaCompra: TDADataSource;
|
||
tbl_ArticulosParaCliente: TDAMemDataTable;
|
||
ds_ArticulosParaCliente: TDADataSource;
|
||
procedure DAClientDataModuleCreate(Sender: TObject);
|
||
private
|
||
function _GetProveedores : IBizArticulosProveedores;
|
||
|
||
protected
|
||
procedure AsignarClaseNegocio(AArticulo: TDADataTable); virtual;
|
||
|
||
public
|
||
function GetItems (const Tipo: TEnumArticulos) : IBizArticulo; overload;
|
||
function GetItems (IDCliente: Integer) : IBizArticulo; overload;
|
||
function GetItem(const ID : Integer) : IBizArticulo;
|
||
function NewItem : IBizArticulo;
|
||
function DarListaProveedoresConArticulos(const IDEmpresa: Integer) : TStringList;
|
||
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.DarListaProveedoresConArticulos(const IDEmpresa: Integer): TStringList;
|
||
begin
|
||
Result := TStringList.Create;
|
||
Result.LoadFromStream((RORemoteService as IsrvArticulos).DarListaProveedoresConArticulos(IDEmpresa));
|
||
end;
|
||
|
||
function TDataModuleArticulos.NewItem: IBizArticulo;
|
||
begin
|
||
Result := GetItem(ID_NULO)
|
||
end;
|
||
|
||
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;
|
||
|
||
function TDataModuleArticulos.GetItem(const ID: Integer): IBizArticulo;
|
||
var
|
||
Condicion: TDAWhereExpression;
|
||
begin
|
||
ShowHourglassCursor;
|
||
try
|
||
Result := Self.GetItems(txArticulo);
|
||
|
||
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;
|
||
|
||
function TDataModuleArticulos.GetItems(const Tipo: TEnumArticulos): IBizArticulo;
|
||
var
|
||
AArticulo : TDAMemDataTable;
|
||
begin
|
||
ShowHourglassCursor;
|
||
try
|
||
case Tipo of
|
||
txArticulo: AArticulo := CloneDataTable(tbl_Articulos);
|
||
// txProveedor: AArticulo := CloneDataTable(tbl_ArticulosParaCompra); En el caso de tener varios proveedores para un mismo art<72>culo
|
||
txProveedor: AArticulo := CloneDataTable(tbl_Articulos);
|
||
end;
|
||
|
||
AsignarClaseNegocio(AArticulo);
|
||
|
||
case Tipo of
|
||
txArticulo: TBizArticulo(AArticulo.BusinessEventsObj).Proveedores := _GetProveedores;
|
||
end;
|
||
|
||
Result := (AArticulo as IBizArticulo);
|
||
|
||
finally
|
||
HideHourglassCursor;
|
||
end;
|
||
end;
|
||
|
||
end.
|