-
Notifications
You must be signed in to change notification settings - Fork 0
/
UKoszykDostep.pas
116 lines (96 loc) · 3.03 KB
/
UKoszykDostep.pas
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
unit UKoszykDostep;
{$mode objfpc}{$H+}
interface
uses
Classes, SysUtils, db, FileUtil, ZDataset, ZSqlUpdate, rxdbgrid, Forms,
Controls, Graphics, Dialogs, ExtCtrls, StdCtrls, DbCtrls, Buttons, datamodule;
type
{ TKoszykDostep }
TKoszykDostep = class(TForm)
btnUdostepnij: TBitBtn;
DBNazwaKoszyka: TDBText;
DSUzytkownicy: TDataSource;
DSKoszykDostep: TDataSource;
edWyszukaj: TEdit;
Image1: TImage;
Image2: TImage;
Image3: TImage;
Label1: TLabel;
Panel1: TPanel;
Panel2: TPanel;
Panel3: TPanel;
Panel4: TPanel;
Panel5: TPanel;
Panel6: TPanel;
Panel9: TPanel;
RxDBGrid1: TRxDBGrid;
RxDBGrid2: TRxDBGrid;
Splitter1: TSplitter;
ZQUzytkownicy: TZQuery;
ZQKoszykDostep: TZQuery;
ZUKoszykDostep: TZUpdateSQL;
procedure btnUdostepnijClick(Sender: TObject);
procedure edWyszukajChange(Sender: TObject);
private
SelectID: integer;
procedure WyslijKomunikat;
public
procedure SetID(aID: integer);
end;
//var
// KoszykDostep: TKoszykDostep;
implementation
uses UKomunikatorNowaWiad, rxdbutils;
{$R *.frm}
{ TKoszykDostep }
procedure TKoszykDostep.edWyszukajChange(Sender: TObject);
var s: string;
begin
s:= Trim(edWyszukaj.Text);
if s<>'' then s:= '%'+s+'%' else s:= '%';
ZQUzytkownicy.Close;
ZQUzytkownicy.ParamByName('nazwisko').AsString:= s;
ZQUzytkownicy.Open;
end;
procedure TKoszykDostep.WyslijKomunikat;
var user: TStringList;
tresc: string;
begin
user := TStringList.Create;
user.Add(ZQUzytkownicy.FieldByName('user').AsString);
tresc:= 'Użytkownik ('+DM.PelnaNazwa+') udostępnił Ci koszyk ('+DBNazwaKoszyka.Caption+');';
with TKomunikatorNowaWiad.Create(Self) do
begin
AutoKomunikat(user, 'Udostępniono koszyk', tresc);
Free;
end;
end;
procedure TKoszykDostep.btnUdostepnijClick(Sender: TObject);
begin
if ZQUzytkownicy.IsEmpty then exit;
if MessageDlg('Czy napewno chcesz udostępnić koszyk wybranemu użytkownikowi?', mtWarning, [mbOK, mbCancel], 0) = mrCancel then exit;
if ZQKoszykDostep.Locate('user', ZQUzytkownicy.FieldByName('user').AsString, []) then
begin
MessageDlg('Wybrany użytkownik ma już dostęp do tego koszyka.', mtInformation, [mbOK], 0);
exit;
end;
ZQKoszykDostep.Insert;
ZQKoszykDostep.FieldByName('user').AsString := ZQUzytkownicy.FieldByName('user').AsString;
ZQKoszykDostep.FieldByName('ID_koszyka').AsInteger := SelectID;
ZQKoszykDostep.FieldByName('data_dodania').AsDateTime:= Now();
ZQKoszykDostep.Post;
DM.KomunikatPopUp(Sender,'Koszyk','Udostępniono koszyk ('+DBNazwaKoszyka.Caption+') użytkownikowi ('+
ZQUzytkownicy.FieldByName('Full_name').AsString+')', nots_Info);
//wyślij komunikat do użytkownika o udostępnieniu mu koszyka
WyslijKomunikat;
RefreshQuery(ZQKoszykDostep);
end;
procedure TKoszykDostep.SetID(aID: integer);
begin
SelectID:= aID;
edWyszukajChange(Self);
ZQKoszykDostep.Close;
ZQKoszykDostep.ParamByName('id_koszyka').AsInteger:= SelectID;
ZQKoszykDostep.Open;
end;
end.