mirror of
https://github.com/danieleteti/delphimvcframework.git
synced 2024-11-16 00:05:53 +01:00
Merged 2 SSV samples into one
This commit is contained in:
parent
1a2ec3889f
commit
1dcfc6b903
@ -36,12 +36,29 @@ type
|
|||||||
TPeople = class(TObjectList<TPerson>)
|
TPeople = class(TObjectList<TPerson>)
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
TDevice = class
|
||||||
|
private
|
||||||
|
fDeviceName: string;
|
||||||
|
fSelected: Boolean;
|
||||||
|
public
|
||||||
|
property DeviceName: string read fDeviceName write fDeviceName;
|
||||||
|
property Selected: Boolean read fSelected write fSelected;
|
||||||
|
constructor Create(aDeviceName: string; aSelected: Boolean);
|
||||||
|
end;
|
||||||
|
|
||||||
|
TDeviceList = class(TObjectList<TDevice>)
|
||||||
|
public
|
||||||
|
function Contains(const aDeviceName: string): Boolean;
|
||||||
|
function IndexOf(const aDeviceName: string): Integer;
|
||||||
|
end;
|
||||||
|
|
||||||
IPeopleDAL = interface
|
IPeopleDAL = interface
|
||||||
['{3E534A3E-EAEB-44ED-B74E-EFBBAAAE11B4}']
|
['{3E534A3E-EAEB-44ED-B74E-EFBBAAAE11B4}']
|
||||||
function GetPeople: TPeople;
|
function GetPeople: TPeople;
|
||||||
procedure AddPerson(FirstName, LastName: string; Age: Integer; Items: TArray<string>);
|
procedure AddPerson(FirstName, LastName: string; Age: Integer; Items: TArray<string>);
|
||||||
procedure DeleteByGUID(GUID: string);
|
procedure DeleteByGUID(GUID: string);
|
||||||
function GetPersonByGUID(GUID: string): TPerson;
|
function GetPersonByGUID(GUID: string): TPerson;
|
||||||
|
function GetDevicesList: TDeviceList;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
TPeopleDAL = class(TInterfacedObject, IPeopleDAL)
|
TPeopleDAL = class(TInterfacedObject, IPeopleDAL)
|
||||||
@ -52,6 +69,7 @@ type
|
|||||||
procedure AddPerson(FirstName, LastName: string; Age: Integer; Items: TArray<string>);
|
procedure AddPerson(FirstName, LastName: string; Age: Integer; Items: TArray<string>);
|
||||||
procedure DeleteByGUID(GUID: string);
|
procedure DeleteByGUID(GUID: string);
|
||||||
function GetPersonByGUID(GUID: string): TPerson;
|
function GetPersonByGUID(GUID: string): TPerson;
|
||||||
|
function GetDevicesList: TDeviceList;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
TServicesFactory = class sealed
|
TServicesFactory = class sealed
|
||||||
@ -128,6 +146,15 @@ begin
|
|||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
function TPeopleDAL.GetDevicesList: TDeviceList;
|
||||||
|
begin
|
||||||
|
Result := TDeviceList.Create(true);
|
||||||
|
Result.Add(TDevice.Create('smartphone', false));
|
||||||
|
Result.Add(TDevice.Create('dumbphone', false));
|
||||||
|
Result.Add(TDevice.Create('laptop', false));
|
||||||
|
Result.Add(TDevice.Create('desktop', false));
|
||||||
|
end;
|
||||||
|
|
||||||
function TPeopleDAL.GetPeople: TPeople;
|
function TPeopleDAL.GetPeople: TPeople;
|
||||||
var
|
var
|
||||||
LData: string;
|
LData: string;
|
||||||
@ -153,6 +180,7 @@ var
|
|||||||
begin
|
begin
|
||||||
Result := nil;
|
Result := nil;
|
||||||
lPeople := GetPeople;
|
lPeople := GetPeople;
|
||||||
|
try
|
||||||
for lPerson in lPeople do
|
for lPerson in lPeople do
|
||||||
begin
|
begin
|
||||||
if lPerson.GUID = GUID then
|
if lPerson.GUID = GUID then
|
||||||
@ -160,7 +188,9 @@ begin
|
|||||||
Result := lPeople.Extract(lPerson);
|
Result := lPeople.Extract(lPerson);
|
||||||
Break;
|
Break;
|
||||||
end;
|
end;
|
||||||
|
end;
|
||||||
|
finally
|
||||||
|
lPeople.Free;
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
@ -191,6 +221,34 @@ begin
|
|||||||
FLastName := Value;
|
FLastName := Value;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
{ TDevice }
|
||||||
|
|
||||||
|
constructor TDevice.Create(aDeviceName: string; aSelected: Boolean);
|
||||||
|
begin
|
||||||
|
inherited Create;
|
||||||
|
fDeviceName := aDeviceName;
|
||||||
|
fSelected := aSelected;
|
||||||
|
end;
|
||||||
|
|
||||||
|
{ TDeviceList }
|
||||||
|
|
||||||
|
function TDeviceList.Contains(const aDeviceName: string): Boolean;
|
||||||
|
begin
|
||||||
|
Result := IndexOf(aDeviceName) > -1;
|
||||||
|
end;
|
||||||
|
|
||||||
|
function TDeviceList.IndexOf(const aDeviceName: string): Integer;
|
||||||
|
var
|
||||||
|
I: Integer;
|
||||||
|
begin
|
||||||
|
Result := -1;
|
||||||
|
for I := 0 to Self.Count - 1 do
|
||||||
|
begin
|
||||||
|
if SameText(Self[i].DeviceName, aDeviceName) then
|
||||||
|
Exit(i);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
initialization
|
initialization
|
||||||
|
|
||||||
_CS := TCriticalSection.Create;
|
_CS := TCriticalSection.Create;
|
||||||
|
@ -1,57 +0,0 @@
|
|||||||
program ServerSideViewsEx;
|
|
||||||
|
|
||||||
{$APPTYPE CONSOLE}
|
|
||||||
|
|
||||||
|
|
||||||
uses
|
|
||||||
System.SysUtils,
|
|
||||||
{$IFDEF MSWINDOWS}
|
|
||||||
Winapi.ShellAPI,
|
|
||||||
Winapi.Windows,
|
|
||||||
{$ENDIF }
|
|
||||||
IdHTTPWebBrokerBridge,
|
|
||||||
Web.WebReq,
|
|
||||||
Web.WebBroker,
|
|
||||||
WebModuleU in 'WebModuleU.pas' {WebModule1: TWebModule},
|
|
||||||
WebSiteControllerU in 'WebSiteControllerU.pas',
|
|
||||||
DAL in 'DAL.pas',
|
|
||||||
MyDataModuleU in '..\renders\MyDataModuleU.pas' {MyDataModule: TDataModule};
|
|
||||||
|
|
||||||
{$R *.res}
|
|
||||||
|
|
||||||
|
|
||||||
procedure RunServer(APort: Integer);
|
|
||||||
var
|
|
||||||
LServer: TIdHTTPWebBrokerBridge;
|
|
||||||
begin
|
|
||||||
ReportMemoryLeaksOnShutdown := True;
|
|
||||||
Writeln(Format('Starting HTTP Server on port %d', [APort]));
|
|
||||||
LServer := TIdHTTPWebBrokerBridge.Create(nil);
|
|
||||||
try
|
|
||||||
LServer.DefaultPort := APort;
|
|
||||||
LServer.Active := True;
|
|
||||||
Writeln('Press RETURN to stop the server');
|
|
||||||
|
|
||||||
{$IFDEF MSWINDOWS}
|
|
||||||
|
|
||||||
ShellExecute(0, 'open', 'http://localhost:8080', nil, nil, SW_SHOW);
|
|
||||||
|
|
||||||
{$ENDIF}
|
|
||||||
|
|
||||||
ReadLn;
|
|
||||||
finally
|
|
||||||
LServer.Free;
|
|
||||||
end;
|
|
||||||
end;
|
|
||||||
|
|
||||||
begin
|
|
||||||
try
|
|
||||||
if WebRequestHandler <> nil then
|
|
||||||
WebRequestHandler.WebModuleClass := WebModuleClass;
|
|
||||||
RunServer(8080);
|
|
||||||
except
|
|
||||||
on E: Exception do
|
|
||||||
Writeln(E.ClassName, ': ', E.Message);
|
|
||||||
end;
|
|
||||||
|
|
||||||
end.
|
|
@ -1,502 +0,0 @@
|
|||||||
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
||||||
<PropertyGroup>
|
|
||||||
<ProjectGuid>{C829684B-145E-49F2-8C37-2562C6C5904E}</ProjectGuid>
|
|
||||||
<ProjectVersion>18.2</ProjectVersion>
|
|
||||||
<FrameworkType>VCL</FrameworkType>
|
|
||||||
<MainSource>ServerSideViewsEx.dpr</MainSource>
|
|
||||||
<Base>True</Base>
|
|
||||||
<Config Condition="'$(Config)'==''">Debug</Config>
|
|
||||||
<Platform Condition="'$(Platform)'==''">Win32</Platform>
|
|
||||||
<TargetedPlatforms>1</TargetedPlatforms>
|
|
||||||
<AppType>Console</AppType>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Config)'=='Base' or '$(Base)'!=''">
|
|
||||||
<Base>true</Base>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="('$(Platform)'=='Win32' and '$(Base)'=='true') or '$(Base_Win32)'!=''">
|
|
||||||
<Base_Win32>true</Base_Win32>
|
|
||||||
<CfgParent>Base</CfgParent>
|
|
||||||
<Base>true</Base>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="('$(Platform)'=='Win64' and '$(Base)'=='true') or '$(Base_Win64)'!=''">
|
|
||||||
<Base_Win64>true</Base_Win64>
|
|
||||||
<CfgParent>Base</CfgParent>
|
|
||||||
<Base>true</Base>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Config)'=='Debug' or '$(Cfg_1)'!=''">
|
|
||||||
<Cfg_1>true</Cfg_1>
|
|
||||||
<CfgParent>Base</CfgParent>
|
|
||||||
<Base>true</Base>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="('$(Platform)'=='Win32' and '$(Cfg_1)'=='true') or '$(Cfg_1_Win32)'!=''">
|
|
||||||
<Cfg_1_Win32>true</Cfg_1_Win32>
|
|
||||||
<CfgParent>Cfg_1</CfgParent>
|
|
||||||
<Cfg_1>true</Cfg_1>
|
|
||||||
<Base>true</Base>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Config)'=='Release' or '$(Cfg_2)'!=''">
|
|
||||||
<Cfg_2>true</Cfg_2>
|
|
||||||
<CfgParent>Base</CfgParent>
|
|
||||||
<Base>true</Base>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Base)'!=''">
|
|
||||||
<Icns_MainIcns>$(BDS)\bin\delphi_PROJECTICNS.icns</Icns_MainIcns>
|
|
||||||
<Icon_MainIcon>$(BDS)\bin\delphi_PROJECTICON.ico</Icon_MainIcon>
|
|
||||||
<DCC_Namespace>System;Xml;Data;Datasnap;Web;Soap;Vcl;Vcl.Imaging;Vcl.Touch;Vcl.Samples;Vcl.Shell;$(DCC_Namespace)</DCC_Namespace>
|
|
||||||
<SanitizedProjectName>ServerSideViewsEx</SanitizedProjectName>
|
|
||||||
<DCC_DcuOutput>.\$(Platform)\$(Config)</DCC_DcuOutput>
|
|
||||||
<DCC_ExeOutput>.\$(Platform)\$(Config)</DCC_ExeOutput>
|
|
||||||
<DCC_E>false</DCC_E>
|
|
||||||
<DCC_N>false</DCC_N>
|
|
||||||
<DCC_S>false</DCC_S>
|
|
||||||
<DCC_F>false</DCC_F>
|
|
||||||
<DCC_K>false</DCC_K>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Base_Win32)'!=''">
|
|
||||||
<DCC_Namespace>Winapi;System.Win;Data.Win;Datasnap.Win;Web.Win;Soap.Win;Xml.Win;Bde;$(DCC_Namespace)</DCC_Namespace>
|
|
||||||
<VerInfo_Locale>1033</VerInfo_Locale>
|
|
||||||
<DCC_ExeOutput>.\bin</DCC_ExeOutput>
|
|
||||||
<VerInfo_Keys>CompanyName=;FileVersion=1.0.0.0;InternalName=;LegalCopyright=;LegalTrademarks=;OriginalFilename=;ProductVersion=1.0.0.0;Comments=;ProgramID=com.embarcadero.$(ModuleName);FileDescription=$(ModuleName);ProductName=$(ModuleName)</VerInfo_Keys>
|
|
||||||
<Manifest_File>None</Manifest_File>
|
|
||||||
<DCC_UsePackage>DBXSqliteDriver;RESTComponents;DataSnapServerMidas;DBXDb2Driver;DBXInterBaseDriver;vclactnband;frxe23;vclFireDAC;emsclientfiredac;DataSnapFireDAC;svnui;tethering;FireDACADSDriver;DBXMSSQLDriver;DatasnapConnectorsFreePascal;FireDACMSSQLDriver;vcltouch;vcldb;bindcompfmx;svn;Intraweb;DBXOracleDriver;ipstudiowinwordxp;inetdb;FmxTeeUI;FireDACIBDriver;fmx;fmxdae;DelphiCookbookListViewAppearance;vclib;FireDACDBXDriver;dbexpress;IndyCore;vclx;dsnap;DataSnapCommon;emsclient;FireDACCommon;bdertl;RESTBackendComponents;DataSnapConnectors;VCLRESTComponents;soapserver;frxTee23;JclDeveloperTools;vclie;CPortLibDXE;bindengine;DBXMySQLDriver;FireDACOracleDriver;CloudService;FireDACMySQLDriver;DBXFirebirdDriver;FireDACCommonDriver;DataSnapClient;inet;bindcompdbx;IndyIPCommon;vcl;DBXSybaseASEDriver;IndyIPServer;IndySystem;FireDACDb2Driver;dsnapcon;FireDACMSAccDriver;fmxFireDAC;FireDACInfxDriver;vclimg;TeeDB;FireDAC;Jcl;FireDACSqliteDriver;FireDACPgDriver;ibmonitor;FireDACASADriver;DBXOdbcDriver;FireDACTDataDriver;FMXTee;ipstudiowinclient;soaprtl;DbxCommonDriver;ibxpress;Tee;DataSnapServer;xmlrtl;soapmidas;DataSnapNativeClient;fmxobj;vclwinx;ibxbindings;rtl;FireDACDSDriver;DbxClientDriver;DTKANPRPackage;DBXSybaseASADriver;CustomIPTransport;vcldsnap;CodeSiteExpressPkg;SampleListViewMultiDetailAppearancePackage;bindcomp;appanalytics;ipstudiowin;DBXInformixDriver;officeXPrt;IndyIPClient;bindcompvcl;frxDB23;vcldbx;TeeUI;vclribbon;dbxcds;VclSmp;adortl;FireDACODBCDriver;JclVcl;DataSnapIndy10ServerTransport;dsnapxml;DataSnapProviderClient;dbrtl;inetdbxpress;FireDACMongoDBDriver;IndyProtocols;frx23;JclContainers;fmxase;$(DCC_UsePackage)</DCC_UsePackage>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Base_Win64)'!=''">
|
|
||||||
<DCC_UsePackage>DBXSqliteDriver;RESTComponents;DataSnapServerMidas;DBXDb2Driver;DBXInterBaseDriver;vclactnband;vclFireDAC;emsclientfiredac;DataSnapFireDAC;tethering;FireDACADSDriver;DBXMSSQLDriver;DatasnapConnectorsFreePascal;FireDACMSSQLDriver;vcltouch;vcldb;bindcompfmx;Intraweb;DBXOracleDriver;inetdb;FmxTeeUI;FireDACIBDriver;fmx;fmxdae;vclib;FireDACDBXDriver;dbexpress;IndyCore;vclx;dsnap;DataSnapCommon;emsclient;FireDACCommon;RESTBackendComponents;DataSnapConnectors;VCLRESTComponents;soapserver;vclie;bindengine;DBXMySQLDriver;FireDACOracleDriver;CloudService;FireDACMySQLDriver;DBXFirebirdDriver;FireDACCommonDriver;DataSnapClient;inet;bindcompdbx;IndyIPCommon;vcl;DBXSybaseASEDriver;IndyIPServer;IndySystem;FireDACDb2Driver;dsnapcon;FireDACMSAccDriver;fmxFireDAC;FireDACInfxDriver;vclimg;TeeDB;FireDAC;FireDACSqliteDriver;FireDACPgDriver;ibmonitor;FireDACASADriver;DBXOdbcDriver;FireDACTDataDriver;FMXTee;ipstudiowinclient;soaprtl;DbxCommonDriver;ibxpress;Tee;DataSnapServer;xmlrtl;soapmidas;DataSnapNativeClient;fmxobj;vclwinx;ibxbindings;rtl;FireDACDSDriver;DbxClientDriver;DBXSybaseASADriver;CustomIPTransport;vcldsnap;bindcomp;appanalytics;ipstudiowin;DBXInformixDriver;officeXPrt;IndyIPClient;bindcompvcl;TeeUI;vclribbon;dbxcds;VclSmp;adortl;FireDACODBCDriver;DataSnapIndy10ServerTransport;dsnapxml;DataSnapProviderClient;dbrtl;inetdbxpress;FireDACMongoDBDriver;IndyProtocols;fmxase;$(DCC_UsePackage)</DCC_UsePackage>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Cfg_1)'!=''">
|
|
||||||
<DCC_Define>DEBUG;$(DCC_Define)</DCC_Define>
|
|
||||||
<DCC_DebugDCUs>true</DCC_DebugDCUs>
|
|
||||||
<DCC_Optimize>false</DCC_Optimize>
|
|
||||||
<DCC_GenerateStackFrames>true</DCC_GenerateStackFrames>
|
|
||||||
<DCC_DebugInfoInExe>true</DCC_DebugInfoInExe>
|
|
||||||
<DCC_RemoteDebug>true</DCC_RemoteDebug>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Cfg_1_Win32)'!=''">
|
|
||||||
<VerInfo_Locale>1033</VerInfo_Locale>
|
|
||||||
<Manifest_File>None</Manifest_File>
|
|
||||||
<DCC_RemoteDebug>false</DCC_RemoteDebug>
|
|
||||||
</PropertyGroup>
|
|
||||||
<PropertyGroup Condition="'$(Cfg_2)'!=''">
|
|
||||||
<DCC_LocalDebugSymbols>false</DCC_LocalDebugSymbols>
|
|
||||||
<DCC_Define>RELEASE;$(DCC_Define)</DCC_Define>
|
|
||||||
<DCC_SymbolReferenceInfo>0</DCC_SymbolReferenceInfo>
|
|
||||||
<DCC_DebugInformation>0</DCC_DebugInformation>
|
|
||||||
</PropertyGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<DelphiCompile Include="$(MainSource)">
|
|
||||||
<MainSource>MainSource</MainSource>
|
|
||||||
</DelphiCompile>
|
|
||||||
<DCCReference Include="WebModuleU.pas">
|
|
||||||
<Form>WebModule1</Form>
|
|
||||||
<DesignClass>TWebModule</DesignClass>
|
|
||||||
</DCCReference>
|
|
||||||
<DCCReference Include="WebSiteControllerU.pas"/>
|
|
||||||
<DCCReference Include="DAL.pas"/>
|
|
||||||
<DCCReference Include="..\renders\MyDataModuleU.pas">
|
|
||||||
<Form>MyDataModule</Form>
|
|
||||||
<FormType>dfm</FormType>
|
|
||||||
<DesignClass>TDataModule</DesignClass>
|
|
||||||
</DCCReference>
|
|
||||||
<BuildConfiguration Include="Release">
|
|
||||||
<Key>Cfg_2</Key>
|
|
||||||
<CfgParent>Base</CfgParent>
|
|
||||||
</BuildConfiguration>
|
|
||||||
<BuildConfiguration Include="Base">
|
|
||||||
<Key>Base</Key>
|
|
||||||
</BuildConfiguration>
|
|
||||||
<BuildConfiguration Include="Debug">
|
|
||||||
<Key>Cfg_1</Key>
|
|
||||||
<CfgParent>Base</CfgParent>
|
|
||||||
</BuildConfiguration>
|
|
||||||
</ItemGroup>
|
|
||||||
<ProjectExtensions>
|
|
||||||
<Borland.Personality>Delphi.Personality.12</Borland.Personality>
|
|
||||||
<Borland.ProjectType>Console</Borland.ProjectType>
|
|
||||||
<BorlandProject>
|
|
||||||
<Delphi.Personality>
|
|
||||||
<Source>
|
|
||||||
<Source Name="MainSource">ServerSideViewsEx.dpr</Source>
|
|
||||||
</Source>
|
|
||||||
<Excluded_Packages>
|
|
||||||
<Excluded_Packages Name="$(BDSBIN)\bcboffice2k230.bpl">Embarcadero C++Builder Office 2000 Servers Package</Excluded_Packages>
|
|
||||||
<Excluded_Packages Name="$(BDSBIN)\bcbofficexp230.bpl">Embarcadero C++Builder Office XP Servers Package</Excluded_Packages>
|
|
||||||
<Excluded_Packages Name="$(BDSBIN)\dcloffice2k230.bpl">Microsoft Office 2000 Sample Automation Server Wrapper Components</Excluded_Packages>
|
|
||||||
</Excluded_Packages>
|
|
||||||
</Delphi.Personality>
|
|
||||||
<Deployment Version="3">
|
|
||||||
<DeployFile LocalName="bin\ServerSideViewsEx.exe" Configuration="Debug" Class="ProjectOutput">
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<RemoteName>ServerSideViewsEx.exe</RemoteName>
|
|
||||||
<Overwrite>true</Overwrite>
|
|
||||||
</Platform>
|
|
||||||
</DeployFile>
|
|
||||||
<DeployClass Name="AdditionalDebugSymbols">
|
|
||||||
<Platform Name="OSX32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<RemoteDir>Contents\MacOS</RemoteDir>
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="AndroidClassesDexFile">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>classes</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="AndroidGDBServer">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="AndroidLibnativeArmeabiFile">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>library\lib\armeabi</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="AndroidLibnativeMipsFile">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>library\lib\mips</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="AndroidLibnativeX86File"/>
|
|
||||||
<DeployClass Name="AndroidServiceOutput">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="AndroidSplashImageDef">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="AndroidSplashStyles">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\values</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_DefaultAppIcon">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_LauncherIcon144">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-xxhdpi</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_LauncherIcon36">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-ldpi</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_LauncherIcon48">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-mdpi</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_LauncherIcon72">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-hdpi</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_LauncherIcon96">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-xhdpi</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_SplashImage426">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-small</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_SplashImage470">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-normal</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_SplashImage640">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-large</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="Android_SplashImage960">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>res\drawable-xlarge</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="DebugSymbols">
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="OSX32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="DependencyFramework">
|
|
||||||
<Platform Name="OSX32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
<Extensions>.framework</Extensions>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="DependencyModule">
|
|
||||||
<Platform Name="OSX32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
<Extensions>.dylib</Extensions>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
<Extensions>.dll;.bpl</Extensions>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Required="true" Name="DependencyPackage">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
<Extensions>.dylib</Extensions>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
<Extensions>.dylib</Extensions>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
<Extensions>.dylib</Extensions>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="OSX32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
<Extensions>.dylib</Extensions>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
<Extensions>.bpl</Extensions>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="File">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="OSX32">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="iPad_Launch1024">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="iPad_Launch1536">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="iPad_Launch2048">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="iPad_Launch768">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="iPhone_Launch320">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="iPhone_Launch640">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="iPhone_Launch640x1136">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="ProjectAndroidManifest">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="ProjectiOSDeviceDebug">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<RemoteDir>..\$(PROJECTNAME).app.dSYM\Contents\Resources\DWARF</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<RemoteDir>..\$(PROJECTNAME).app.dSYM\Contents\Resources\DWARF</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="ProjectiOSDeviceResourceRules"/>
|
|
||||||
<DeployClass Name="ProjectiOSEntitlements"/>
|
|
||||||
<DeployClass Name="ProjectiOSInfoPList"/>
|
|
||||||
<DeployClass Name="ProjectiOSResource">
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="ProjectOSXEntitlements"/>
|
|
||||||
<DeployClass Name="ProjectOSXInfoPList"/>
|
|
||||||
<DeployClass Name="ProjectOSXResource">
|
|
||||||
<Platform Name="OSX32">
|
|
||||||
<RemoteDir>Contents\Resources</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Required="true" Name="ProjectOutput">
|
|
||||||
<Platform Name="Android">
|
|
||||||
<RemoteDir>library\lib\armeabi-v7a</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSDevice64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="iOSSimulator">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Linux64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="OSX32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<Operation>0</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="ProjectUWPManifest">
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win64">
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="UWP_DelphiLogo150">
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<RemoteDir>Assets</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win64">
|
|
||||||
<RemoteDir>Assets</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<DeployClass Name="UWP_DelphiLogo44">
|
|
||||||
<Platform Name="Win32">
|
|
||||||
<RemoteDir>Assets</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
<Platform Name="Win64">
|
|
||||||
<RemoteDir>Assets</RemoteDir>
|
|
||||||
<Operation>1</Operation>
|
|
||||||
</Platform>
|
|
||||||
</DeployClass>
|
|
||||||
<ProjectRoot Platform="iOSDevice64" Name="$(PROJECTNAME).app"/>
|
|
||||||
<ProjectRoot Platform="Win64" Name="$(PROJECTNAME)"/>
|
|
||||||
<ProjectRoot Platform="iOSDevice32" Name="$(PROJECTNAME).app"/>
|
|
||||||
<ProjectRoot Platform="Win32" Name="$(PROJECTNAME)"/>
|
|
||||||
<ProjectRoot Platform="Linux64" Name="$(PROJECTNAME)"/>
|
|
||||||
<ProjectRoot Platform="OSX32" Name="$(PROJECTNAME)"/>
|
|
||||||
<ProjectRoot Platform="Android" Name="$(PROJECTNAME)"/>
|
|
||||||
<ProjectRoot Platform="iOSSimulator" Name="$(PROJECTNAME).app"/>
|
|
||||||
</Deployment>
|
|
||||||
<Platforms>
|
|
||||||
<Platform value="Win32">True</Platform>
|
|
||||||
<Platform value="Win64">False</Platform>
|
|
||||||
</Platforms>
|
|
||||||
</BorlandProject>
|
|
||||||
<ProjectFileVersion>12</ProjectFileVersion>
|
|
||||||
</ProjectExtensions>
|
|
||||||
<Import Project="$(BDS)\Bin\CodeGear.Delphi.Targets" Condition="Exists('$(BDS)\Bin\CodeGear.Delphi.Targets')"/>
|
|
||||||
<Import Project="$(APPDATA)\Embarcadero\$(BDSAPPDATABASEDIR)\$(PRODUCTVERSION)\UserTools.proj" Condition="Exists('$(APPDATA)\Embarcadero\$(BDSAPPDATABASEDIR)\$(PRODUCTVERSION)\UserTools.proj')"/>
|
|
||||||
<Import Project="$(MSBuildProjectName).deployproj" Condition="Exists('$(MSBuildProjectName).deployproj')"/>
|
|
||||||
</Project>
|
|
@ -6,20 +6,9 @@ uses
|
|||||||
MVCFramework, System.Diagnostics, System.JSON, MVCFramework.Commons;
|
MVCFramework, System.Diagnostics, System.JSON, MVCFramework.Commons;
|
||||||
|
|
||||||
type
|
type
|
||||||
TSpeedValue = class
|
|
||||||
private
|
|
||||||
FValue: string;
|
|
||||||
procedure SetValue(const Value: string);
|
|
||||||
public
|
|
||||||
property Value: string read FValue write SetValue;
|
|
||||||
constructor Create(const aValue: string);
|
|
||||||
end;
|
|
||||||
|
|
||||||
[MVCPath('/')]
|
[MVCPath('/')]
|
||||||
TWebSiteController = class(TMVCController)
|
TWebSiteController = class(TMVCController)
|
||||||
private
|
|
||||||
FStopWatch: TStopwatch;
|
|
||||||
function GetSpeed: TSpeedValue;
|
|
||||||
protected
|
protected
|
||||||
procedure OnBeforeAction(Context: TWebContext; const AActionNAme: string;
|
procedure OnBeforeAction(Context: TWebContext; const AActionNAme: string;
|
||||||
var Handled: Boolean); override;
|
var Handled: Boolean); override;
|
||||||
@ -89,13 +78,29 @@ procedure TWebSiteController.EditPerson(guid: string);
|
|||||||
var
|
var
|
||||||
LDAL: IPeopleDAL;
|
LDAL: IPeopleDAL;
|
||||||
lPerson: TPerson;
|
lPerson: TPerson;
|
||||||
|
lDevices: TDeviceList;
|
||||||
|
lItem: TDevice;
|
||||||
|
lIdx: Integer;
|
||||||
begin
|
begin
|
||||||
LDAL := TServicesFactory.GetPeopleDAL;
|
LDAL := TServicesFactory.GetPeopleDAL;
|
||||||
lPerson := LDAL.GetPersonByGUID(guid);
|
lPerson := LDAL.GetPersonByGUID(guid);
|
||||||
|
try
|
||||||
|
lDevices := LDAL.GetDevicesList;
|
||||||
|
try
|
||||||
ViewData['person'] := lPerson;
|
ViewData['person'] := lPerson;
|
||||||
ViewData['speed'] := GetSpeed;
|
for lItem in lDevices do
|
||||||
|
begin
|
||||||
|
lItem.Selected := lPerson.Items.Contains(lItem.DeviceName);
|
||||||
|
end;
|
||||||
|
ViewData['deviceslist'] := lDevices;
|
||||||
LoadView(['header', 'editperson', 'footer']);
|
LoadView(['header', 'editperson', 'footer']);
|
||||||
RenderResponseStream;
|
RenderResponseStream;
|
||||||
|
finally
|
||||||
|
lDevices.Free;
|
||||||
|
end;
|
||||||
|
finally
|
||||||
|
lPerson.Free;
|
||||||
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TWebSiteController.ExportPeopleListAsCSV;
|
procedure TWebSiteController.ExportPeopleListAsCSV;
|
||||||
@ -115,16 +120,17 @@ end;
|
|||||||
procedure TWebSiteController.GeneratePeopleListAsCSV;
|
procedure TWebSiteController.GeneratePeopleListAsCSV;
|
||||||
var
|
var
|
||||||
LDAL: IPeopleDAL;
|
LDAL: IPeopleDAL;
|
||||||
|
lPeople: TPeople;
|
||||||
begin
|
begin
|
||||||
LDAL := TServicesFactory.GetPeopleDAL;
|
LDAL := TServicesFactory.GetPeopleDAL;
|
||||||
ViewData['people'] := LDAL.GetPeople;
|
lPeople := LDAL.GetPeople;
|
||||||
|
try
|
||||||
|
ViewData['people'] := lPeople;
|
||||||
LoadView(['people_header.csv', 'people_list.csv']);
|
LoadView(['people_header.csv', 'people_list.csv']);
|
||||||
RenderResponseStream; // rember to call RenderResponseStream!!!
|
RenderResponseStream; // rember to call RenderResponseStream!!!
|
||||||
|
finally
|
||||||
|
lPeople.Free;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
function TWebSiteController.GetSpeed: TSpeedValue;
|
|
||||||
begin
|
|
||||||
Result := TSpeedValue.Create(FStopWatch.Elapsed.TotalMilliseconds.ToString);
|
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TWebSiteController.Index;
|
procedure TWebSiteController.Index;
|
||||||
@ -133,10 +139,19 @@ begin
|
|||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TWebSiteController.NewPerson;
|
procedure TWebSiteController.NewPerson;
|
||||||
|
var
|
||||||
|
lDAL: IPeopleDAL;
|
||||||
|
lDevices: TDeviceList;
|
||||||
begin
|
begin
|
||||||
ViewData['speed'] := GetSpeed;
|
lDAL := TServicesFactory.GetPeopleDAL;
|
||||||
|
lDevices := LDAL.GetDevicesList;
|
||||||
|
try
|
||||||
|
ViewData['deviceslist'] := lDevices;
|
||||||
LoadView(['header', 'editperson', 'footer']);
|
LoadView(['header', 'editperson', 'footer']);
|
||||||
RenderResponseStream;
|
RenderResponseStream;
|
||||||
|
finally
|
||||||
|
lDevices.Free;
|
||||||
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TWebSiteController.OnBeforeAction(Context: TWebContext;
|
procedure TWebSiteController.OnBeforeAction(Context: TWebContext;
|
||||||
@ -145,18 +160,23 @@ begin
|
|||||||
inherited;
|
inherited;
|
||||||
ContentType := 'text/html';
|
ContentType := 'text/html';
|
||||||
Handled := False;
|
Handled := False;
|
||||||
FStopWatch := TStopwatch.StartNew;
|
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TWebSiteController.PeopleList;
|
procedure TWebSiteController.PeopleList;
|
||||||
var
|
var
|
||||||
LDAL: IPeopleDAL;
|
LDAL: IPeopleDAL;
|
||||||
|
lPeople: TPeople;
|
||||||
begin
|
begin
|
||||||
LDAL := TServicesFactory.GetPeopleDAL;
|
LDAL := TServicesFactory.GetPeopleDAL;
|
||||||
ViewData['people'] := LDAL.GetPeople;
|
lPeople := LDAL.GetPeople;
|
||||||
ViewData['speed'] := GetSpeed;
|
try
|
||||||
|
ViewData['people'] := lPeople;
|
||||||
LoadView(['header', 'people_list', 'footer']);
|
LoadView(['header', 'people_list', 'footer']);
|
||||||
RenderResponseStream; // rember to call RenderResponseStream!!!
|
RenderResponseStream; // rember to call RenderResponseStream!!!
|
||||||
|
finally
|
||||||
|
lPeople.Free;
|
||||||
|
end;
|
||||||
|
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure TWebSiteController.SavePerson;
|
procedure TWebSiteController.SavePerson;
|
||||||
@ -165,10 +185,12 @@ var
|
|||||||
LLastName: string;
|
LLastName: string;
|
||||||
LAge: string;
|
LAge: string;
|
||||||
LPeopleDAL: IPeopleDAL;
|
LPeopleDAL: IPeopleDAL;
|
||||||
|
lDevices: TArray<string>;
|
||||||
begin
|
begin
|
||||||
LFirstName := Context.Request.Params['first_name'].Trim;
|
LFirstName := Context.Request.Params['first_name'].Trim;
|
||||||
LLastName := Context.Request.Params['last_name'].Trim;
|
LLastName := Context.Request.Params['last_name'].Trim;
|
||||||
LAge := Context.Request.Params['age'];
|
LAge := Context.Request.Params['age'];
|
||||||
|
lDevices := Context.Request.ParamsMulti['items'];
|
||||||
|
|
||||||
if LFirstName.IsEmpty or LLastName.IsEmpty or LAge.IsEmpty then
|
if LFirstName.IsEmpty or LLastName.IsEmpty or LAge.IsEmpty then
|
||||||
begin
|
begin
|
||||||
@ -178,22 +200,9 @@ begin
|
|||||||
end;
|
end;
|
||||||
|
|
||||||
LPeopleDAL := TServicesFactory.GetPeopleDAL;
|
LPeopleDAL := TServicesFactory.GetPeopleDAL;
|
||||||
LPeopleDAL.AddPerson(LFirstName, LLastName, LAge.ToInteger(), []);
|
LPeopleDAL.AddPerson(LFirstName, LLastName, LAge.ToInteger(), lDevices);
|
||||||
|
|
||||||
Redirect('/people');
|
Redirect('/people');
|
||||||
end;
|
end;
|
||||||
|
|
||||||
{ TSpeedValue }
|
|
||||||
|
|
||||||
constructor TSpeedValue.Create(const aValue: string);
|
|
||||||
begin
|
|
||||||
inherited Create;
|
|
||||||
FValue := aValue;
|
|
||||||
end;
|
|
||||||
|
|
||||||
procedure TSpeedValue.SetValue(const Value: string);
|
|
||||||
begin
|
|
||||||
FValue := Value;
|
|
||||||
end;
|
|
||||||
|
|
||||||
end.
|
end.
|
||||||
|
@ -49,6 +49,20 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="items" class="col-sm-2 control-label">Devices</label>
|
||||||
|
<div class="col-sm-4">
|
||||||
|
<select name="items" multiple class="form-control">
|
||||||
|
{{#deviceslist}}
|
||||||
|
<option value="{{devicename}}" {{#selected}}selected{{/selected}}>{{devicename}}</option>
|
||||||
|
{{/deviceslist}}
|
||||||
|
</select>
|
||||||
|
<span style="font-size: 80%">(Ctrl+Click to select multiple devices)</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="form-group">
|
<div class="form-group">
|
||||||
<div class="col-sm-offset-2 col-sm-2">
|
<div class="col-sm-offset-2 col-sm-2">
|
||||||
<button type="button" class="btn btn-default btn-block" onclick="history.back()">Return to the list</button>
|
<button type="button" class="btn btn-default btn-block" onclick="history.back()">Return to the list</button>
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
<span>Powered by DMVCFramework</span>
|
<span>Powered by DMVCFramework</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-sm-4 bg-success">
|
<div class="col-sm-4 bg-success">
|
||||||
<span>Page generated in {{speed.value}}ms</span>
|
<span>Server Side Views</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user