unit uDataModulePedidosProveedor; interface uses DB, Classes, SysUtils, uDADesigntimeCall, uROServiceComponent, uRORemoteService, uROClient, uROBinMessage, uDAScriptingProvider, uDACDSDataTable, uROWinInetHttpChannel, uDADataTable, uDABINAdapter, uDAClientDataModule, uROTypes, uIDataModulePedidosProveedor, uIDataModulePedidosProveedorReport, uBizPedidosProveedor, uBizDetallesPedidoProveedor; type TDataModulePedidosProveedor = class(TDAClientDataModule, IDataModulePedidosProveedor, IDataModulePedidosProveedorReport) ROChannel: TROWinInetHTTPChannel; ROMessage: TROBinMessage; RORemoteService: TRORemoteService; DABinAdapter: TDABINAdapter; tbl_PedidosProveedor: TDACDSDataTable; ds_PedidosProveedor: TDADataSource; tbl_PedidosProveedor_Detalles: TDACDSDataTable; ds_PedidosProveedor_Detalles: TDADataSource; DADesigntimeCall1: TDADesigntimeCall; LoginRemoteService: TRORemoteService; tbl_PedidosProveedor_Articulos_Pendientes: TDACDSDataTable; ds_PedidosProveedor_Articulos_Pendientes: TDADataSource; tbl_ListaAnosPedidos: TDACDSDataTable; ds_ListaAnosPedidos: TDADataSource; procedure DAClientDataModuleCreate(Sender: TObject); private function _CloneDataTable (const ADataTable : TDACDSDataTable): TDACDSDataTable; overload; function _GetDetalles : IBizDetallesPedidoProveedor; protected procedure AsignarClaseNegocio(var APedido: TDACDSDataTable); virtual; public function GetItems : IBizPedidoProveedor; virtual; function GetItem(const ID : Integer) : IBizPedidoProveedor; function GetNextID(const DataSetName : String) : Integer; function NewItem : IBizPedidoProveedor; function GetArticulosPendientes(const IDPedido: Integer): IBizDetallesPedidoProveedorPend; // Report function GetReport(const AID: String): Binary; function GetRptPDF(const AID: Integer; const ShowLogotipo: Boolean = False): Binary; function GetAnosItems : TStringList; end; implementation {$R *.DFM} uses cxControls, FactuGES_Intf, uDAInterfaces, uDataModuleConexion, uDataTableUtils, schPedidosProveedorClient_Intf, uBizContactos; { TdmPedidosProveedor } procedure TDataModulePedidosProveedor.AsignarClaseNegocio(var APedido: TDACDSDataTable); begin APedido.BusinessRulesID := BIZ_CLIENT_PEDIDO_PROVEEDOR; end; procedure TDataModulePedidosProveedor.DAClientDataModuleCreate(Sender: TObject); begin RORemoteService.Channel := dmConexion.Channel; RORemoteService.Message := dmConexion.Message; end; function TDataModulePedidosProveedor.GetNextID(const DataSetName: String): Integer; var aGeneratorName : String; begin if DataSetName = nme_PedidosProveedor then aGeneratorName := 'GEN_PEDIDOS_PROV_ID'; if DataSetName = nme_PedidosProveedor_Detalles then aGeneratorName := 'GEN_PEDIDOS_PROV_DETALLES_ID'; Result := (RORemoteService as IsrvPedidosProveedor).GetNextAutoInc(aGeneratorName) end; function TDataModulePedidosProveedor.GetReport(const AID: String): Binary; begin Result := (RORemoteService as IsrvPedidosProveedor).GenerateReport(AID) end; function TDataModulePedidosProveedor.GetRptPDF(const AID: Integer; const ShowLogotipo: Boolean): Binary; var AParam : TIntegerArray; begin AParam := TIntegerArray.Create; try AParam.Add(AID); Result := (RORemoteService as IsrvPedidosProveedor).GenerarReportPDF(AParam, ShowLogotipo) finally FreeANDNIL(AParam) end; end; function TDataModulePedidosProveedor.NewItem: IBizPedidoProveedor; begin Result := GetItem(ID_NULO) end; function TDataModulePedidosProveedor._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 TDataModulePedidosProveedor._GetDetalles: IBizDetallesPedidoProveedor; var ADetalles : TDACDSDataTable; 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; 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; function TDataModulePedidosProveedor.GetArticulosPendientes(const IDPedido: Integer): IBizDetallesPedidoProveedorPend; var AArticulos : TDACDSDataTable; begin ShowHourglassCursor; try AArticulos := _CloneDataTable(tbl_PedidosProveedor_Articulos_Pendientes); AArticulos.BusinessRulesID := BIZ_CLIENT_DETALLES_PEDIDO_PROVEEDOR_PEND; AArticulos.ParamByName('ID').AsInteger := IDPedido; Result := (AArticulos as IBizDetallesPedidoProveedorPend); finally HideHourglassCursor; end; end; function TDataModulePedidosProveedor.GetItem(const ID: Integer): IBizPedidoProveedor; begin ShowHourglassCursor; try Result := Self.GetItems; with Result.DataTable.Where do begin if NotEmpty then AddOperator(opAND); OpenBraket; AddText(fld_PedidosProveedorID + ' = ' + IntToStr(ID)); CloseBraket; end; finally HideHourglassCursor; end; end; function TDataModulePedidosProveedor.GetItems: IBizPedidoProveedor; var APedido : TDACDSDataTable; begin ShowHourglassCursor; try APedido := _CloneDataTable(tbl_PedidosProveedor); // EL CAMPO REFERENCIA TIENE QUE SER AUTOREFRESH!!!!! APedido.FieldByName(fld_PedidosProveedorREFERENCIA).ServerAutoRefresh := TRUE; AsignarClaseNegocio(APedido); with TBizPedidoProveedor(APedido.BusinessEventsObj) do begin Detalles := _GetDetalles; end; Result := (APedido as IBizPedidoProveedor); finally HideHourglassCursor; end; end; end.