2007-10-26 18:19:55 +00:00
|
|
|
|
unit srvPresupuestosCliente_Impl;
|
|
|
|
|
|
|
|
|
|
|
|
{----------------------------------------------------------------------------}
|
|
|
|
|
|
{ This unit was automatically generated by the RemObjects SDK after reading }
|
|
|
|
|
|
{ the RODL file associated with this project . }
|
|
|
|
|
|
{ }
|
|
|
|
|
|
{ This is where you are supposed to code the implementation of your objects. }
|
|
|
|
|
|
{----------------------------------------------------------------------------}
|
|
|
|
|
|
|
|
|
|
|
|
interface
|
|
|
|
|
|
|
|
|
|
|
|
uses
|
|
|
|
|
|
{vcl:} Classes, SysUtils,
|
|
|
|
|
|
{RemObjects:} uROClientIntf, uROTypes, uROServer, uROServerIntf, uROSessions,
|
|
|
|
|
|
{Ancestor Implementation:} DataAbstractService_Impl,
|
|
|
|
|
|
{Used RODLs:} DataAbstract4_Intf,
|
2007-11-15 19:54:36 +00:00
|
|
|
|
{Generated:} uDABusinessProcessor, uDABin2DataStreamer, uDADataStreamer,
|
|
|
|
|
|
uDAScriptingProvider, uDAClasses,
|
|
|
|
|
|
FactuGES_Intf, uDAInterfaces;
|
2007-10-26 18:19:55 +00:00
|
|
|
|
|
|
|
|
|
|
type
|
2007-11-05 17:49:11 +00:00
|
|
|
|
{ TsrvPresupuestosCliente }
|
2007-10-26 18:19:55 +00:00
|
|
|
|
TsrvPresupuestosCliente = class(TDataAbstractService, IsrvPresupuestosCliente)
|
|
|
|
|
|
Bin2DataStreamer: TDABin2DataStreamer;
|
2007-11-05 17:49:11 +00:00
|
|
|
|
bpPresupuestosCliente: TDABusinessProcessor;
|
|
|
|
|
|
bpPresupuestosClienteDetalles: TDABusinessProcessor;
|
|
|
|
|
|
schPresupuestosCliente: TDASchema;
|
2007-10-26 18:19:55 +00:00
|
|
|
|
DADataDictionary: TDADataDictionary;
|
|
|
|
|
|
procedure DataAbstractServiceBeforeAcquireConnection(aSender: TObject;
|
|
|
|
|
|
var aConnectionName: string);
|
|
|
|
|
|
procedure DARemoteServiceBeforeGetDatasetData(const Dataset: IDADataset;
|
|
|
|
|
|
const IncludeSchema: Boolean; const MaxRecords: Integer);
|
|
|
|
|
|
procedure DARemoteServiceCreate(Sender: TObject);
|
|
|
|
|
|
protected
|
2007-11-05 17:49:11 +00:00
|
|
|
|
{ IsrvPresupuestosCliente methods }
|
2014-02-18 22:41:52 +00:00
|
|
|
|
function GenerarInforme(const ListaID: TIntegerArray; const VerSello: Integer): Binary;
|
|
|
|
|
|
function GenerarInformeEnWord(const ID: Integer; const VerSello: Integer): Binary;
|
|
|
|
|
|
function GenerarInformeEnPDF(const ListaID: TIntegerArray; const VerSello: Integer): Binary;
|
2008-08-06 18:18:27 +00:00
|
|
|
|
function GenerarCertificadoTrabajosEnWord(const ID: Integer): Binary;
|
2007-10-26 18:19:55 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
implementation
|
|
|
|
|
|
|
|
|
|
|
|
{$R *.dfm}
|
|
|
|
|
|
uses
|
2008-09-10 16:49:09 +00:00
|
|
|
|
Dialogs, uSistemaFunc, uROClasses,
|
2007-10-26 18:19:55 +00:00
|
|
|
|
{Generated:} FactuGES_Invk, uDataModuleServer, uDatabaseUtils,
|
2007-11-05 17:49:11 +00:00
|
|
|
|
schPresupuestosClienteClient_Intf, uRestriccionesUsuarioUtils,
|
2007-11-13 19:36:56 +00:00
|
|
|
|
uRptPresupuestosCliente_Server,
|
2008-08-06 18:18:27 +00:00
|
|
|
|
uBizPresupuestosClienteServer, uRptWordPresupuestoCliente,
|
|
|
|
|
|
uRptWordCertificadoTrabajo_Server;
|
2007-10-26 18:19:55 +00:00
|
|
|
|
|
|
|
|
|
|
procedure Create_srvPresupuestosCliente(out anInstance : IUnknown);
|
|
|
|
|
|
begin
|
|
|
|
|
|
anInstance := TsrvPresupuestosCliente.Create(NIL);
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2007-11-05 17:49:11 +00:00
|
|
|
|
{ srvPresupuestosCliente }
|
2007-10-26 18:19:55 +00:00
|
|
|
|
|
|
|
|
|
|
procedure TsrvPresupuestosCliente.DARemoteServiceBeforeGetDatasetData(
|
|
|
|
|
|
const Dataset: IDADataset; const IncludeSchema: Boolean;
|
|
|
|
|
|
const MaxRecords: Integer);
|
|
|
|
|
|
begin
|
2007-11-05 17:49:11 +00:00
|
|
|
|
if DataSet.Name = nme_PresupuestosCliente then
|
2007-10-26 18:19:55 +00:00
|
|
|
|
begin
|
2007-11-05 17:49:11 +00:00
|
|
|
|
{ Aqu<EFBFBD> se asegura que el usuario s<EFBFBD>lo accede a presupuestos
|
2007-10-26 18:19:55 +00:00
|
|
|
|
de las empresas a las que tiene permiso para acceder
|
|
|
|
|
|
filtrando DataSet por ID_EMPRESA. }
|
2007-11-05 17:49:11 +00:00
|
|
|
|
FiltrarAccesoUsuario(Session, Connection, schPresupuestosCliente, DataSet, fld_PresupuestosClienteID_EMPRESA);
|
2007-10-26 18:19:55 +00:00
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
procedure TsrvPresupuestosCliente.DARemoteServiceCreate(Sender: TObject);
|
|
|
|
|
|
begin
|
2009-03-05 12:18:48 +00:00
|
|
|
|
//SessionManager := dmServer.SessionManager;
|
2007-11-05 17:49:11 +00:00
|
|
|
|
bpPresupuestosCliente.BusinessRulesID := BIZ_SERVER_PRESUPUESTOS_CLIENTE;
|
2007-10-26 18:19:55 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
procedure TsrvPresupuestosCliente.DataAbstractServiceBeforeAcquireConnection(aSender: TObject; var aConnectionName: string);
|
|
|
|
|
|
begin
|
|
|
|
|
|
ConnectionName := dmServer.ConnectionName;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2008-08-06 18:18:27 +00:00
|
|
|
|
function TsrvPresupuestosCliente.GenerarCertificadoTrabajosEnWord(
|
|
|
|
|
|
const ID: Integer): Binary;
|
|
|
|
|
|
var
|
|
|
|
|
|
AReportGenerator : TRptWordCertificadoTrabajo;
|
|
|
|
|
|
AFicheroTMP : TFileName;
|
|
|
|
|
|
begin
|
|
|
|
|
|
Result := NIL;
|
|
|
|
|
|
AFicheroTMP := DarFicheroTemporal;
|
|
|
|
|
|
AReportGenerator := TRptWordCertificadoTrabajo.Create(nil);
|
|
|
|
|
|
try
|
|
|
|
|
|
if AReportGenerator.Exportar(ID, AFicheroTMP) then
|
|
|
|
|
|
begin
|
|
|
|
|
|
Result := Binary.Create;
|
|
|
|
|
|
Result.LoadFromFile(AFicheroTMP);
|
|
|
|
|
|
end;
|
|
|
|
|
|
finally
|
|
|
|
|
|
FreeAndNIL(AReportGenerator);
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2014-02-18 22:41:52 +00:00
|
|
|
|
function TsrvPresupuestosCliente.GenerarInforme(const ListaID: TIntegerArray; const VerSello: Integer): Binary;
|
2007-11-13 19:36:56 +00:00
|
|
|
|
var
|
|
|
|
|
|
AReportGenerator : TRptPresupuestosCliente;
|
2007-10-26 18:19:55 +00:00
|
|
|
|
begin
|
2007-11-13 19:36:56 +00:00
|
|
|
|
AReportGenerator := TRptPresupuestosCliente.Create(nil);
|
|
|
|
|
|
try
|
2014-02-18 22:41:52 +00:00
|
|
|
|
Result := AReportGenerator.GenerarPresupuesto(ListaID, VerSello);
|
2008-02-06 14:28:09 +00:00
|
|
|
|
finally
|
|
|
|
|
|
FreeAndNIL(AReportGenerator);
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2014-02-18 22:41:52 +00:00
|
|
|
|
function TsrvPresupuestosCliente.GenerarInformeEnPDF(const ListaID: TIntegerArray; const VerSello: Integer): Binary;
|
2008-08-21 17:01:02 +00:00
|
|
|
|
var
|
|
|
|
|
|
AReportGenerator : TRptPresupuestosCliente;
|
|
|
|
|
|
begin
|
|
|
|
|
|
AReportGenerator := TRptPresupuestosCliente.Create(nil);
|
|
|
|
|
|
try
|
2014-02-18 22:41:52 +00:00
|
|
|
|
Result := AReportGenerator.GenerarPresupuestoEnPDF(ListaID, VerSello);
|
2008-08-21 17:01:02 +00:00
|
|
|
|
finally
|
|
|
|
|
|
FreeAndNIL(AReportGenerator);
|
|
|
|
|
|
end;
|
|
|
|
|
|
end;
|
|
|
|
|
|
|
2014-02-18 22:41:52 +00:00
|
|
|
|
function TsrvPresupuestosCliente.GenerarInformeEnWord(const ID: Integer; const VerSello: Integer): Binary;
|
2008-02-06 14:28:09 +00:00
|
|
|
|
var
|
2008-03-23 10:52:22 +00:00
|
|
|
|
AReportGenerator : TRptWordPresupuestoCliente;
|
2008-02-06 14:28:09 +00:00
|
|
|
|
AFicheroTMP : TFileName;
|
|
|
|
|
|
begin
|
|
|
|
|
|
Result := NIL;
|
|
|
|
|
|
AFicheroTMP := DarFicheroTemporal;
|
2008-03-23 10:52:22 +00:00
|
|
|
|
AReportGenerator := TRptWordPresupuestoCliente.Create(nil);
|
2008-02-06 14:28:09 +00:00
|
|
|
|
try
|
2008-09-10 16:49:09 +00:00
|
|
|
|
try
|
2014-02-18 22:41:52 +00:00
|
|
|
|
if AReportGenerator.Exportar(IntToStr(ID), AFicheroTMP, VerSello) then
|
2008-09-10 16:49:09 +00:00
|
|
|
|
begin
|
|
|
|
|
|
Result := Binary.Create;
|
|
|
|
|
|
Result.LoadFromFile(AFicheroTMP);
|
|
|
|
|
|
end;
|
|
|
|
|
|
except
|
|
|
|
|
|
on E: Exception do
|
|
|
|
|
|
RaiseError(E.Message);
|
2008-02-06 14:28:09 +00:00
|
|
|
|
end;
|
2007-11-13 19:36:56 +00:00
|
|
|
|
finally
|
|
|
|
|
|
FreeAndNIL(AReportGenerator);
|
|
|
|
|
|
end;
|
2007-10-26 18:19:55 +00:00
|
|
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
initialization
|
|
|
|
|
|
TROClassFactory.Create('srvPresupuestosCliente', Create_srvPresupuestosCliente, TsrvPresupuestosCliente_Invoker);
|
|
|
|
|
|
|
|
|
|
|
|
finalization
|
|
|
|
|
|
|
|
|
|
|
|
end.
|