unit uDataModuleAlbaranesCliente; interface uses DB, Classes, SysUtils, uDADesigntimeCall, uROTypes, uRORemoteService, uROClient, uROBinMessage, uDAScriptingProvider, uDACDSDataTable, uROWinInetHttpChannel, uDADataTable, uDABINAdapter, uIDataModuleAlbaranesCliente, uBizAlbaranesCliente, uBizDetallesAlbaranCliente, uIDataModuleAlbaranesClienteReport, uDataModuleBase, uDABin2DataStreamer, uDAMemDataTable, uDAInterfaces, uDADataStreamer, uDARemoteDataAdapter, uIntegerListUtils; type TDataModuleAlbaranesCliente = class(TDataModuleBase, IDataModuleAlbaranesCliente, IDataModuleAlbaranesClienteReport) RORemoteService: TRORemoteService; rda_AlbaranesCliente: TDARemoteDataAdapter; Bin2DataStreamer: TDABin2DataStreamer; tbl_AlbaranesCliente: TDAMemDataTable; ds_AlbaranesCliente: TDADataSource; tbl_AlbaranesCliente_Detalles: TDAMemDataTable; ds_AlbaranesCliente_Detalles: TDADataSource; tbl_ListaAnosAlbaranes: TDAMemDataTable; ds_ListaAnosAlbaranes: TDADataSource; procedure DAClientDataModuleCreate(Sender: TObject); private function _GetDetalles : IBizDetallesAlbaranCliente; protected procedure AsignarClaseNegocio(AAlbaran: TDADataTable); virtual; public function GetItems : IBizAlbaranCliente; virtual; function GetItem(const ID : Integer) : IBizAlbaranCliente; function NewItem : IBizAlbaranCliente; // Report function GetRptAlbaranes(const AListaID: TIntegerList; const ImprimirPrecio: Boolean = True; const ImprimirRef: Boolean = True): Binary; function GetRptWordAlbaran(const AID: Integer; const ImprimirPrecio: Boolean = True; const ImprimirRef: Boolean = True): Binary; function GetRptPDFAlbaran(const AID: Integer; const ImprimirPrecio: Boolean = True; const ImprimirRef: Boolean = True): Binary; function GetEtiquetas(const AID: Integer; withRefCliente: Boolean): Binary; function GetAnosItems : TStringList; end; implementation {$R *.DFM} uses cxControls, FactuGES_Intf, uDataModuleConexion, uDataTableUtils, schAlbaranesClienteClient_Intf, uBizContactos; { TdmAlbaranesCliente } procedure TDataModuleAlbaranesCliente.AsignarClaseNegocio(AAlbaran: TDADataTable); begin AAlbaran.BusinessRulesID := BIZ_CLIENT_ALBARAN_CLIENTE; end; procedure TDataModuleAlbaranesCliente.DAClientDataModuleCreate(Sender: TObject); begin RORemoteService.Channel := dmConexion.Channel; RORemoteService.Message := dmConexion.Message; end; function TDataModuleAlbaranesCliente.GetRptAlbaranes( const AListaID: TIntegerList; const ImprimirPrecio, ImprimirRef: Boolean): Binary; var AParam : TIntegerArray; begin AParam := AListaID.ToIntegerArray; try Result := (RORemoteService as IsrvAlbaranesCliente).GenerarInforme(AParam, ImprimirPrecio, ImprimirRef); finally FreeAndNil(AParam); end; end; function TDataModuleAlbaranesCliente.GetRptPDFAlbaran(const AID: Integer; const ImprimirPrecio: Boolean = True; const ImprimirRef: Boolean = True): Binary; var AParam : TIntegerArray; begin AParam := TIntegerArray.Create; try AParam.Add(AID); Result := (RORemoteService as IsrvAlbaranesCliente).GenerarInforme(AParam, ImprimirPrecio, ImprimirRef); finally FreeAndNil(AParam); end; end; function TDataModuleAlbaranesCliente.GetRptWordAlbaran(const AID: Integer; const ImprimirPrecio: Boolean = True; const ImprimirRef: Boolean = True): Binary; begin Result := (RORemoteService as IsrvAlbaranesCliente).GenerarInformeEnWord(AID, ImprimirPrecio, ImprimirRef) end; function TDataModuleAlbaranesCliente.NewItem: IBizAlbaranCliente; begin Result := GetItem(ID_NULO) end; function TDataModuleAlbaranesCliente._GetDetalles: IBizDetallesAlbaranCliente; var ADetalles : TDAMemDataTable; begin ShowHourglassCursor; try ADetalles := CloneDataTable(tbl_AlbaranesCliente_Detalles); with ADetalles do begin BusinessRulesID := BIZ_CLIENT_DETALLES_ALBARAN_CLIENTE; DetailOptions := DetailOptions - [dtDisableLogOfCascadeDeletes, dtDisableLogOfCascadeUpdates]; end; Result := (ADetalles as IBizDetallesAlbaranCliente); finally HideHourglassCursor; end; end; function TDataModuleAlbaranesCliente.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; function TDataModuleAlbaranesCliente.GetEtiquetas(const AID: Integer; withRefCliente: Boolean): Binary; begin Result := (RORemoteService as IsrvAlbaranesCliente).GenerarInformeEtiquetas(AID, withRefCliente) end; function TDataModuleAlbaranesCliente.GetItem(const ID: Integer): IBizAlbaranCliente; var Condicion: TDAWhereExpression; begin ShowHourglassCursor; try Result := Self.GetItems; with Result.DataTable.DynamicWhere do begin // (ID = :ID) Condicion := NewBinaryExpression(NewField('', fld_AlbaranesClienteID), NewConstant(ID, datInteger), dboEqual); if IsEmpty then Expression := Condicion else Expression := NewBinaryExpression(Expression, Condicion, dboAnd); end; finally HideHourglassCursor; end; end; function TDataModuleAlbaranesCliente.GetItems: IBizAlbaranCliente; var AAlbaran : TDAMemDataTable; begin ShowHourglassCursor; try AAlbaran := CloneDataTable(tbl_AlbaranesCliente); AsignarClaseNegocio(AAlbaran); // EL CAMPO REFERENCIA TIENE QUE SER AUTOREFRESH!!!!! AAlbaran.FieldByName(fld_AlbaranesClienteREFERENCIA).ServerAutoRefresh := TRUE; with TBizAlbaranCliente(AAlbaran.BusinessEventsObj) do begin Detalles := _GetDetalles; end; Result := (AAlbaran as IBizAlbaranCliente); finally HideHourglassCursor; end; end; end.