2014-06-27 16:38:49 +02:00
|
|
|
unit MainFormU;
|
|
|
|
|
|
|
|
interface
|
|
|
|
|
|
|
|
uses
|
|
|
|
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
|
|
|
|
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, FireDAC.Stan.Intf, FireDAC.Stan.Option,
|
|
|
|
FireDAC.Stan.Param, FireDAC.Stan.Error, FireDAC.DatS, FireDAC.Phys.Intf,
|
|
|
|
FireDAC.DApt.Intf, Data.DB, FireDAC.Comp.DataSet, FireDAC.Comp.Client,
|
2020-09-24 21:30:45 +02:00
|
|
|
Vcl.Grids, Vcl.DBGrids, Vcl.ExtCtrls, Vcl.StdCtrls, MVCFramework.RESTClient.Intf, MVCFramework.RESTClient,
|
2020-09-02 19:43:34 +02:00
|
|
|
Vcl.DBCtrls;
|
2014-06-27 16:38:49 +02:00
|
|
|
|
|
|
|
type
|
2017-02-04 23:43:06 +01:00
|
|
|
TMainForm = class(TForm)
|
2014-06-27 16:38:49 +02:00
|
|
|
Panel1: TPanel;
|
|
|
|
DBGrid1: TDBGrid;
|
2017-02-04 23:43:06 +01:00
|
|
|
dsArticles: TFDMemTable;
|
|
|
|
dsArticlesid: TIntegerField;
|
|
|
|
dsArticlescode: TStringField;
|
|
|
|
dsArticlesdescription: TStringField;
|
|
|
|
dsArticlesprice: TCurrencyField;
|
|
|
|
dsrcArticles: TDataSource;
|
2014-06-30 12:32:43 +02:00
|
|
|
DBNavigator1: TDBNavigator;
|
2017-02-04 23:43:06 +01:00
|
|
|
btnOpen: TButton;
|
2017-02-06 14:10:04 +01:00
|
|
|
btnRefreshRecord: TButton;
|
|
|
|
Button1: TButton;
|
2020-04-23 17:20:53 +02:00
|
|
|
Panel2: TPanel;
|
|
|
|
EditFilter: TEdit;
|
|
|
|
Label1: TLabel;
|
|
|
|
btnFilter: TButton;
|
2014-06-27 16:38:49 +02:00
|
|
|
procedure FormCreate(Sender: TObject);
|
2017-02-04 23:43:06 +01:00
|
|
|
procedure dsArticlesBeforePost(DataSet: TDataSet);
|
|
|
|
procedure dsArticlesBeforeDelete(DataSet: TDataSet);
|
2020-09-02 19:43:34 +02:00
|
|
|
procedure FormClose(Sender: TObject; var Action: TCloseAction);
|
2017-02-04 23:43:06 +01:00
|
|
|
procedure dsArticlesBeforeRefresh(DataSet: TDataSet);
|
|
|
|
procedure dsArticlesAfterOpen(DataSet: TDataSet);
|
|
|
|
procedure btnOpenClick(Sender: TObject);
|
|
|
|
procedure btnCloseClick(Sender: TObject);
|
2017-02-06 12:42:17 +01:00
|
|
|
procedure dsArticlesBeforeRowRequest(DataSet: TFDDataSet);
|
2017-02-06 14:10:04 +01:00
|
|
|
procedure btnRefreshRecordClick(Sender: TObject);
|
2020-04-23 17:20:53 +02:00
|
|
|
procedure btnFilterClick(Sender: TObject);
|
2014-06-27 16:38:49 +02:00
|
|
|
private
|
2020-04-23 17:20:53 +02:00
|
|
|
fFilter: string;
|
2020-02-05 23:46:38 +01:00
|
|
|
fLoading: Boolean;
|
2020-09-24 21:30:45 +02:00
|
|
|
fRESTClient: IMVCRESTClient;
|
2014-06-27 16:38:49 +02:00
|
|
|
{ Private declarations }
|
2020-09-24 21:30:45 +02:00
|
|
|
procedure ShowError(const AResponse: IMVCRESTResponse);
|
2020-04-23 17:20:53 +02:00
|
|
|
procedure SetFilter(const Value: string);
|
|
|
|
public
|
|
|
|
property Filter: string read fFilter write SetFilter;
|
2014-06-27 16:38:49 +02:00
|
|
|
end;
|
|
|
|
|
|
|
|
var
|
2017-02-04 23:43:06 +01:00
|
|
|
MainForm: TMainForm;
|
2014-06-27 16:38:49 +02:00
|
|
|
|
|
|
|
implementation
|
|
|
|
|
|
|
|
uses
|
2017-04-24 00:19:53 +02:00
|
|
|
System.UITypes, MVCFramework.DataSet.Utils;
|
2014-06-27 16:38:49 +02:00
|
|
|
|
|
|
|
{$R *.dfm}
|
|
|
|
|
|
|
|
|
2017-02-04 23:43:06 +01:00
|
|
|
procedure TMainForm.btnCloseClick(Sender: TObject);
|
2014-06-27 16:38:49 +02:00
|
|
|
begin
|
2017-02-04 23:43:06 +01:00
|
|
|
dsArticles.Close;
|
2014-06-27 16:38:49 +02:00
|
|
|
end;
|
|
|
|
|
2020-04-23 17:20:53 +02:00
|
|
|
procedure TMainForm.btnFilterClick(Sender: TObject);
|
|
|
|
begin
|
|
|
|
dsArticles.Close;
|
|
|
|
Filter := EditFilter.Text;;
|
|
|
|
dsArticles.Open;
|
|
|
|
end;
|
|
|
|
|
2017-02-04 23:43:06 +01:00
|
|
|
procedure TMainForm.btnOpenClick(Sender: TObject);
|
2014-06-30 12:32:43 +02:00
|
|
|
begin
|
2020-04-23 17:20:53 +02:00
|
|
|
dsArticles.Close;
|
|
|
|
Filter := '';
|
2017-02-04 23:43:06 +01:00
|
|
|
dsArticles.Open;
|
2014-06-30 12:32:43 +02:00
|
|
|
end;
|
|
|
|
|
2017-02-06 14:10:04 +01:00
|
|
|
procedure TMainForm.btnRefreshRecordClick(Sender: TObject);
|
|
|
|
begin
|
|
|
|
dsArticles.RefreshRecord;
|
|
|
|
end;
|
|
|
|
|
2017-02-04 23:43:06 +01:00
|
|
|
procedure TMainForm.dsArticlesAfterOpen(DataSet: TDataSet);
|
2014-06-27 16:38:49 +02:00
|
|
|
var
|
2020-09-24 21:30:45 +02:00
|
|
|
Res: IMVCRESTResponse;
|
2014-06-27 16:38:49 +02:00
|
|
|
begin
|
2020-04-23 17:20:53 +02:00
|
|
|
if fFilter.IsEmpty then
|
|
|
|
begin
|
|
|
|
// this a simple sychronous request...
|
2020-09-24 21:30:45 +02:00
|
|
|
Res := fRESTClient.Get('/articles');
|
2020-04-23 17:20:53 +02:00
|
|
|
end
|
|
|
|
else
|
|
|
|
begin
|
2020-09-24 21:30:45 +02:00
|
|
|
Res := fRESTClient
|
|
|
|
.AddQueryStringParam('q', fFilter)
|
|
|
|
.Get('/articles/searches');
|
2020-04-23 17:20:53 +02:00
|
|
|
end;
|
|
|
|
|
2020-09-24 21:30:45 +02:00
|
|
|
if not Res.Success then
|
2017-04-29 23:56:56 +02:00
|
|
|
begin
|
|
|
|
ShowError(Res);
|
|
|
|
Exit;
|
|
|
|
end;
|
|
|
|
|
2017-02-04 23:43:06 +01:00
|
|
|
DataSet.DisableControls;
|
|
|
|
try
|
2020-02-05 23:46:38 +01:00
|
|
|
fLoading := true;
|
2020-09-24 21:30:45 +02:00
|
|
|
dsArticles.LoadJSONArrayFromJSONObjectProperty('data', Res.Content);
|
2020-02-05 23:46:38 +01:00
|
|
|
fLoading := false;
|
2017-02-04 23:43:06 +01:00
|
|
|
dsArticles.First;
|
|
|
|
finally
|
|
|
|
DataSet.EnableControls;
|
|
|
|
end;
|
|
|
|
end;
|
|
|
|
|
|
|
|
procedure TMainForm.dsArticlesBeforeDelete(DataSet: TDataSet);
|
|
|
|
var
|
2020-09-24 21:30:45 +02:00
|
|
|
Res: IMVCRESTResponse;
|
2017-02-04 23:43:06 +01:00
|
|
|
begin
|
|
|
|
if dsArticles.State = dsBrowse then
|
2020-02-05 23:46:38 +01:00
|
|
|
Res := fRESTClient.DataSetDelete('/articles', dsArticlesid.AsString);
|
2020-09-24 21:30:45 +02:00
|
|
|
if not(Res.StatusCode in [200]) then
|
2014-06-30 12:32:43 +02:00
|
|
|
begin
|
|
|
|
ShowError(Res);
|
|
|
|
Abort;
|
2017-02-04 23:43:06 +01:00
|
|
|
end;
|
2014-06-30 12:32:43 +02:00
|
|
|
end;
|
|
|
|
|
2017-02-04 23:43:06 +01:00
|
|
|
procedure TMainForm.dsArticlesBeforePost(DataSet: TDataSet);
|
2014-06-30 12:32:43 +02:00
|
|
|
var
|
2020-09-24 21:30:45 +02:00
|
|
|
Res: IMVCRESTResponse;
|
2014-06-30 12:32:43 +02:00
|
|
|
begin
|
2020-02-05 23:46:38 +01:00
|
|
|
if not fLoading then
|
2014-06-30 12:32:43 +02:00
|
|
|
begin
|
2017-02-04 23:43:06 +01:00
|
|
|
if dsArticles.State = dsInsert then
|
2020-02-05 23:46:38 +01:00
|
|
|
Res := fRESTClient.DataSetInsert('/articles', dsArticles)
|
2014-06-30 12:32:43 +02:00
|
|
|
else
|
2020-09-24 21:30:45 +02:00
|
|
|
Res := fRESTClient.DataSetUpdate('/articles', dsArticlesid.AsString, dsArticles);
|
|
|
|
if not(Res.StatusCode in [200, 201]) then
|
2014-06-30 12:32:43 +02:00
|
|
|
begin
|
|
|
|
ShowError(Res);
|
|
|
|
Abort;
|
|
|
|
end
|
|
|
|
else
|
2020-02-05 23:46:38 +01:00
|
|
|
begin
|
2017-02-04 23:43:06 +01:00
|
|
|
DataSet.Refresh;
|
2020-02-05 23:46:38 +01:00
|
|
|
end;
|
2014-06-27 16:38:49 +02:00
|
|
|
end;
|
|
|
|
end;
|
|
|
|
|
2017-02-04 23:43:06 +01:00
|
|
|
procedure TMainForm.dsArticlesBeforeRefresh(DataSet: TDataSet);
|
2017-02-06 12:42:17 +01:00
|
|
|
begin
|
|
|
|
DataSet.Close;
|
|
|
|
DataSet.Open;
|
|
|
|
end;
|
|
|
|
|
|
|
|
procedure TMainForm.dsArticlesBeforeRowRequest(DataSet: TFDDataSet);
|
2017-02-06 14:10:04 +01:00
|
|
|
var
|
2020-09-24 21:30:45 +02:00
|
|
|
Res: IMVCRESTResponse;
|
2014-06-30 12:32:43 +02:00
|
|
|
begin
|
2020-09-24 21:30:45 +02:00
|
|
|
Res := fRESTClient
|
|
|
|
.AddPathParam('param1', DataSet.FieldByName('id').AsString)
|
|
|
|
.Get('/articles/{param1}');
|
2020-02-05 23:46:38 +01:00
|
|
|
fLoading := true;
|
2020-09-24 21:30:45 +02:00
|
|
|
DataSet.LoadJSONObjectFromJSONObjectProperty('data', Res.Content);
|
2020-02-05 23:46:38 +01:00
|
|
|
fLoading := false;
|
2014-06-30 12:32:43 +02:00
|
|
|
end;
|
|
|
|
|
2020-09-02 19:43:34 +02:00
|
|
|
procedure TMainForm.FormClose(Sender: TObject; var Action: TCloseAction);
|
|
|
|
begin
|
2020-09-24 21:30:45 +02:00
|
|
|
fRESTClient := nil;
|
2020-09-02 19:43:34 +02:00
|
|
|
end;
|
|
|
|
|
2017-02-04 23:43:06 +01:00
|
|
|
procedure TMainForm.FormCreate(Sender: TObject);
|
2014-06-30 12:32:43 +02:00
|
|
|
begin
|
2020-09-24 21:30:45 +02:00
|
|
|
fRESTClient := TMVCRESTClient.New.BaseURL('localhost', 8080);
|
2014-06-30 12:32:43 +02:00
|
|
|
end;
|
|
|
|
|
2020-04-23 17:20:53 +02:00
|
|
|
procedure TMainForm.SetFilter(const Value: string);
|
|
|
|
begin
|
|
|
|
fFilter := Value;
|
|
|
|
EditFilter.Text := Value;
|
|
|
|
end;
|
|
|
|
|
2020-09-24 21:30:45 +02:00
|
|
|
procedure TMainForm.ShowError(const AResponse: IMVCRESTResponse);
|
2014-06-30 12:32:43 +02:00
|
|
|
begin
|
2020-09-24 21:30:45 +02:00
|
|
|
if not AResponse.Success then
|
2017-05-12 00:25:46 +02:00
|
|
|
MessageDlg(
|
2020-09-24 21:30:45 +02:00
|
|
|
AResponse.StatusCode.ToString + ': ' + AResponse.StatusText + sLineBreak +
|
|
|
|
'[' + AResponse.Content + ']',
|
2017-05-12 00:25:46 +02:00
|
|
|
mtError, [mbOK], 0)
|
|
|
|
else
|
|
|
|
MessageDlg(
|
2020-09-24 21:30:45 +02:00
|
|
|
AResponse.StatusCode.ToString + ': ' + AResponse.StatusText + sLineBreak +
|
|
|
|
AResponse.Content,
|
2017-05-12 00:25:46 +02:00
|
|
|
mtError, [mbOK], 0);
|
2014-06-30 12:32:43 +02:00
|
|
|
end;
|
|
|
|
|
2014-06-27 16:38:49 +02:00
|
|
|
end.
|