Develop and Download Open Source Software

Browse Subversion Repository

Diff of /Unit1.pas

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1 by yamat0jp, Sun Nov 22 11:18:44 2015 UTC revision 11 by yamat0jp, Fri Jul 22 23:40:03 2016 UTC
# Line 3  unit Unit1; Line 3  unit Unit1;
3  interface  interface
4    
5  uses  uses
6    Classes, SysUtils, IWAppForm, IWApplication, IWColor, IWTypes, IWHTMLControls,    Classes, SysUtils, IWAppForm, IWApplication, IWColor, IWTypes, IWVCLComponent,
   IWVCLBaseControl, IWBaseControl, IWBaseHTMLControl, IWControl, IWCompLabel,  
   Vcl.Controls, Vcl.Forms, IWVCLBaseContainer, IWContainer, IWHTMLContainer,  
   IWHTML40Container, IWRegion, FireDAC.Stan.Intf, FireDAC.Stan.Option,  
   FireDAC.Stan.Error, FireDAC.UI.Intf, FireDAC.Phys.Intf, FireDAC.Stan.Def,  
   FireDAC.Stan.Pool, FireDAC.Stan.Async, FireDAC.Phys, FireDAC.Phys.IB,  
   FireDAC.Phys.IBDef, Data.DB, FireDAC.Comp.Client, Datasnap.DBClient,  
   Datasnap.Provider, FireDAC.Stan.Param, FireDAC.DatS, FireDAC.DApt.Intf,  
   FireDAC.DApt, FireDAC.Comp.DataSet, IWCompGrids, IWDBGrids, IWCompEdit,  
   IWDBStdCtrls, IWCompExtCtrls, IWDBExtCtrls, Unit3, IWVCLComponent,  
7    IWBaseLayoutComponent, IWBaseContainerLayout, IWContainerLayout,    IWBaseLayoutComponent, IWBaseContainerLayout, IWContainerLayout,
8    IWTemplateProcessorHTML, Data.Bind.EngExt, Vcl.Bind.DBEngExt, System.Rtti,    IWTemplateProcessorHTML, Vcl.Controls, Vcl.Forms, Unit2, IWVCLBaseContainer,
9    System.Bindings.Outputs, Vcl.Bind.Editors, Data.Bind.Components,    IWContainer, IWHTMLContainer, IWHTML40Container, IWRegion, IWDBStdCtrls,
10    Data.Bind.DBScope, IWCompListbox, IWCompButton, Web.HTTPApp, Web.HTTPProd,    IWVCLBaseControl, IWBaseControl, IWBaseHTMLControl, IWControl, IWCompLabel,
11    Vcl.ImgList, IWImageList, PngImage, IWCompTabControl, IWCompMemo, IWCompText,    IWCompGrids, IWCompText, IWCompTabControl, IWCompButton, IWCompEdit,
12    UserSessionUnit;    IWHTMLControls, IWCompExtCtrls, PngImage, Data.DB,
13      IWCompListbox, IWBaseComponent, IWBaseHTMLComponent, IWBaseHTML40Component,
14      IWCompMenu, Vcl.Menus, System.Variants, Vcl.Dialogs, System.UITypes, Unit8;
15    
16  type  type
17    TTopForm = class(TIWAppForm)    TIWForm1 = class(TIWAppForm)
18      IWRegion1: TIWRegion;      IWTemplateProcessorHTML1: TIWTemplateProcessorHTML;
19      IWLabel1: TIWLabel;      IWLabel1: TIWLabel;
     IWList1: TIWList;  
     IWLink1: TIWLink;  
     IWLabel2: TIWLabel;  
20      IWDBLabel1: TIWDBLabel;      IWDBLabel1: TIWDBLabel;
21      IWFrame1: TIWFrame1;      IWRegion1: TIWRegion;
22        IWRegion2: TIWRegion;
23        IWText1: TIWText;
24        IWGrid1: TIWGrid;
25      IWRegion3: TIWRegion;      IWRegion3: TIWRegion;
     IWLabel3: TIWLabel;  
     IWLabel4: TIWLabel;  
26      IWRegion4: TIWRegion;      IWRegion4: TIWRegion;
27      IWLabel5: TIWLabel;      IWLink1: TIWLink;
28      IWList2: TIWList;      IWLabel2: TIWLabel;
29      IWTemplateProcessorHTML1: TIWTemplateProcessorHTML;      IWList1: TIWList;
30      IWRegion2: TIWRegion;      IWLabel3: TIWLabel;
     IWLabel6: TIWLabel;  
     IWRegion6: TIWRegion;  
31      IWEdit1: TIWEdit;      IWEdit1: TIWEdit;
32      IWButton1: TIWButton;      IWButton1: TIWButton;
     IWImageFile1: TIWImageFile;  
     IWRegion7: TIWRegion;  
     IWLabel8: TIWLabel;  
     IWGrid1: TIWGrid;  
     IWTabControl1: TIWTabControl;  
     IWTabControl1Page0: TIWTabPage;  
     IWTabControl1Page1: TIWTabPage;  
     IWText1: TIWText;  
     IWRegion8: TIWRegion;  
33      IWEdit2: TIWEdit;      IWEdit2: TIWEdit;
34      IWEdit3: TIWEdit;      IWEdit3: TIWEdit;
     IWLabel9: TIWLabel;  
     IWList3: TIWList;  
35      IWLink2: TIWLink;      IWLink2: TIWLink;
36        IWRegion5: TIWRegion;
37        IWLabel7: TIWLabel;
38        IWRegion6: TIWRegion;
39        IWLabel8: TIWLabel;
40        IWList2: TIWList;
41        IWLabel4: TIWLabel;
42        IWRegion7: TIWRegion;
43        IWLabel5: TIWLabel;
44        IWLabel6: TIWLabel;
45        IWList3: TIWList;
46        IWImage1: TIWImage;
47        IWFrame8: TIWFrame8;
48        IWLink4: TIWLink;
49        IWLink3: TIWLink;
50        IWLink5: TIWLink;
51        IWFrame1: TIWFrame1;
52        IWLink6: TIWLink;
53      procedure IWAppFormRender(Sender: TObject);      procedure IWAppFormRender(Sender: TObject);
54      procedure IWLink1Click(Sender: TObject);      procedure IWLink2Click(Sender: TObject);
55      procedure IWAppFormCreate(Sender: TObject);      procedure IWAppFormCreate(Sender: TObject);
56      procedure IWButton1Click(Sender: TObject);      procedure IWButton1Click(Sender: TObject);
57      procedure IWAppFormDestroy(Sender: TObject);      procedure IWLink1Click(Sender: TObject);
58      procedure IWLink2Click(Sender: TObject);      procedure IWGrid1CellClick(ASender: TObject; const ARow, AColumn: Integer);
59        procedure IWFrame8IWButton1Click(Sender: TObject);
60        procedure IWFrame8IWLink1Click(Sender: TObject);
61        procedure IWLink4Click(Sender: TObject);
62        procedure IWLink3Click(Sender: TObject);
63        procedure IWLink5Click(Sender: TObject);
64        procedure IWLink6Click(Sender: TObject);
65    private    private
66      procedure SetPage(const Value: TPage);      Filter: Boolean;
67      function GetPage: TPage;      function GetPage: Boolean;
68        procedure SetPage(const Value: Boolean);
69      procedure LoadImage;      procedure LoadImage;
70      procedure ClearImage;      procedure ClearImage;
71        function GetThumbnail: Boolean;
72        procedure CallBack(EventParams: TStringList);
73        procedure SetThumbnail(const Value: Boolean);
74    public    public
75      property Page: TPage read GetPage write SetPage;      property Page: Boolean read GetPage write SetPage;
76        property Thumbnail: Boolean read GetThumbnail write SetThumbnail;
77    end;    end;
78    
79    var
80      IWForm1: TIWForm1;
81    
82  implementation  implementation
83    
84  {$R *.dfm}  {$R *.dfm}
85    
86  uses Unit2, ServerController, Unit4, Unit6;  uses Unit3, ServerController, Unit6, Unit4, Unit9, Unit10, Unit5;
87    
88    procedure TIWForm1.CallBack(EventParams: TStringList);
89    begin
90      if SameText(EventParams.Values['RetValue'], 'true') = true then
91        TCartForm.Create(WebApplication).Show;
92      IWFrame8.IWEdit1.Text := '0';
93    end;
94    
95  procedure TTopForm.ClearImage;  procedure TIWForm1.ClearImage;
96  var  var
97    i, j: integer;    i: Integer;
98      j: Integer;
99  begin  begin
100    for i := 0 to IWGrid1.ColumnCount - 1 do    for i := 0 to IWGrid1.RowCount - 1 do
101      for j := 0 to IWGrid1.RowCount - 1 do      for j := 0 to IWGrid1.ColumnCount - 1 do
102      begin        IWGrid1.Cell[i, j].Control.Free;
103        IWGrid1.Cell[j, i].Control.Free;    IWGrid1.RowCount := 0;
       IWGrid1.Cell[j, i].Control := nil;  
     end;  
104  end;  end;
105    
106  function TTopForm.GetPage: TPage;  function TIWForm1.GetPage: Boolean;
107  begin  begin
108    result := UserSession.FPage;    result := UserSession.FPage;
109  end;  end;
110    
111  procedure TTopForm.IWAppFormCreate(Sender: TObject);  function TIWForm1.GetThumbnail: Boolean;
112    begin
113      result := UserSession.FThumbnail;
114    end;
115    
116    procedure TIWForm1.IWAppFormCreate(Sender: TObject);
117  const  const
118    i = 150;    i = 120;
119  var  var
120    s: integer;    s: Integer;
121  begin  begin
122    s:=DM.FDTable3.FieldByName('BGCOLOR').AsInteger;    IWForm1 := Self;
123    IWLabel1.BGColor := s;    Page := UserSession.FPage;
124      Thumbnail := UserSession.FThumbnail;
125      s := DM.FDTable3.FieldByName('BGCOLOR').AsInteger;
126      IWLabel2.BGColor := s;
127    IWLabel3.BGColor := s;    IWLabel3.BGColor := s;
128    IWLabel5.BGColor := s;    IWLabel5.BGColor := s;
129    IWLabel6.BGColor := s;    IWLabel7.BGColor := s;
130    IWLabel8.BGColor := s;    IWLabel8.BGColor := s;
131    IWRegion1.Width := i;    IWRegion1.Width := i;
132    IWRegion2.Width := i;    IWRegion2.Width := i;
   IWRegion3.Width := i;  
133    IWRegion4.Width := i;    IWRegion4.Width := i;
134      IWRegion5.Width := i;
135      IWRegion6.Width := i;
136    IWRegion7.Width := i;    IWRegion7.Width := i;
137    IWRegion8.Width := i;    WebApplication.RegisterCallBack('callback', CallBack);
   Page := UserSession.FPage;  
138  end;  end;
139    
140  procedure TTopForm.IWAppFormDestroy(Sender: TObject);  procedure TIWForm1.IWAppFormRender(Sender: TObject);
 begin  
   ClearImage;  
 end;  
   
 procedure TTopForm.IWAppFormRender(Sender: TObject);  
141  var  var
142    s: string;    s: string;
143    i, j: integer;    i, j: Integer;
   x: Boolean;  
144  begin  begin
145    IWList1.Items.Clear;    IWList1.Items.Clear;
146    with DM.FDTable2 do    with DM.FDTable2 do
147      if RecordCount > 0 then    begin
148        if Filtered = true then
149      begin      begin
150        First;        FindFirst;
151        while Eof = false do        while Found = true do
152        begin        begin
153          s := FieldByName('CATEGORY').AsString;          s := FieldByName('CATEGORY').AsString;
154          if s = '' then          if s = '' then
155          begin          begin
156            Next;            FindNext;
157            continue;            continue;
158          end;          end;
159          if Filtered = true then          i := IWList1.Items.IndexOfName(s);
160          begin          if i = -1 then
161            i := IWList1.Items.IndexOfName(s);            IWList1.Items.Add(s + '=1')
           if i = -1 then  
             IWList1.Items.Add(s + '=1')  
           else  
           begin  
             j := IWList1.Items.ValueFromIndex[i].ToInteger + 1;  
             IWList1.Items[i] := s + '=' + j.ToString;  
           end;  
         end  
162          else          else
163          begin          begin
164            i := IWList1.Items.IndexOf(s);            j := IWList1.Items.ValueFromIndex[i].ToInteger + 1;
165            if i = -1 then            IWList1.Items[i] := s + '=' + j.ToString;
166              IWList1.Items.Add(s);          end;
167            FindNext;
168          end;
169        end
170        else
171        begin
172          First;
173          while Eof = false do
174          begin
175            s := FieldByName('CATEGORY').AsString;
176            if s = '' then
177            begin
178              Next;
179              continue;
180          end;          end;
181            i := IWList1.Items.IndexOf(s);
182            if i = -1 then
183              IWList1.Items.Add(s);
184          Next;          Next;
185        end;        end;
186      end;      end;
187      end;
188    if DM.FDTable2.Filtered = true then    if DM.FDTable2.Filtered = true then
189      for i := 0 to IWList1.Items.Count - 1 do      for i := 0 to IWList1.Items.Count - 1 do
190      begin      begin
# Line 167  begin Line 194  begin
194        else        else
195          IWList1.Items[i] := IWList1.Items.Names[i] + '(' + s + ')';          IWList1.Items[i] := IWList1.Items.Names[i] + '(' + s + ')';
196      end;      end;
197    IWList3.Items.Clear;    IWList2.Items.Clear;
198    if Page = Info then    with DM.FDQuery1 do
199    begin    begin
200      with DM.FDQuery1 do      SQL.Clear;
201        SQL.Add('select volume,name,price from cart_data join item_data');
202        SQL.Add(' on (cart_data.serial = item_data.serial)');
203        SQL.Add(' where number = :num;');
204        Params.ParamByName('num').AsInteger := UserSession.user_number;
205        Open;
206        First;
207        i := 0;
208        while Eof = false do
209      begin      begin
210        SQL.Clear;        s := Fields.Fields[0].AsString + 'x' + Fields.Fields[1].AsString;
211        SQL.Add('select volume,name,price from cart_data join item_data');        i := i + Fields.Fields[0].AsInteger * Fields.Fields[2].AsInteger;
212        SQL.Add(' on (cart_data.serial = item_data.serial)');        IWList2.Items.Add(s);
213        SQL.Add(' where number = :num;');        Next;
       Params.ParamByName('num').AsInteger := UserSession.user_number;  
       Open;  
       if RecordCount > 0 then  
       begin  
         First;  
         i := 0;  
         while Eof = false do  
         begin  
           s := Fields.Fields[0].AsString + 'x' + Fields.Fields[1].AsString;  
           inc(i, Fields.Fields[2].AsInteger);  
           IWList3.Items.Add(s);  
           Next;  
         end;  
         IWList3.Items.Add(i.ToString + '円');  
       end;  
       Close;  
214      end;      end;
215      IWList2.Items.Clear;      IWList2.Items.Add(i.ToString + '円');
216      with DM.FDQuery1 do      Close;
217        IWList3.Items.Clear;
218        SQL.Clear;
219        SQL.Add('select name from recent_data join item_data');
220        SQL.Add(' on (recent_data.serial = item_data.serial)');
221        SQL.Add(' where number = :num;');
222        Params.ParamByName('num').AsInteger := UserSession.user_number;
223        Open;
224        First;
225        while Eof = false do
226      begin      begin
227        SQL.Clear;        IWList3.Items.Add(Fields.Fields[0].AsString);
228        SQL.Add('select name from recent_data join item_data');        Next;
       SQL.Add(' on (recent_data.serial = item_data.serial)');  
       SQL.Add(' where number = :num;');  
       //Params.ParamByName('num').AsInteger:=UserSession.user_number;  
       Open;  
       if RecordCount > 0 then  
       begin  
         First;  
         while Eof = false do  
         begin  
           IWList2.Items.Add(Fields.Fields[0].AsString);  
           Next;  
         end;  
       end;  
       Close;  
229      end;      end;
230        Close;
231    end;    end;
   x := Page = Info;  
   IWRegion4.Visible := x;  
   IWLabel2.Visible := x;  
   IWDBLabel1.Visible := x;  
   IWLink2.Visible := not x;  
232    LoadImage;    LoadImage;
233      if IWGrid1.Visible = true then
234        IWLabel6.Visible := Filter;
235  end;  end;
236    
237  procedure TTopForm.IWButton1Click(Sender: TObject);  procedure TIWForm1.IWButton1Click(Sender: TObject);
238  const  var
239    filter = 'NAME LIKE ''%s''';    i: Integer;
240  begin  begin
241    if IWEdit1.Text = '' then    IWFrame8IWLink1Click(Sender);
242      DM.FDTable2.Filtered := false    if IWEdit1.Text <> '' then
   else  
243    begin    begin
244      DM.FDTable2.filter := Format(filter, ['%' + IWEdit1.Text + '%']);      DM.FDTable2.Filter := 'NAME like ' + QuotedStr('%' + IWEdit1.Text + '%');
245      DM.FDTable2.Filtered := true;      DM.FDTable2.Filtered := true;
246      IWLabel9.Text := IWEdit1.Text + 'を検索しています';      i := DM.FDTable2.RecordCount;
247        IWLabel6.Caption := Format(IWEdit1.Text + 'を検索しています:%d件', [i]);
248        if i = 0 then
249          DM.FDTable2.Filtered := false;
250        Filter := true;
251      end
252      else
253      begin
254        DM.FDTable2.Filtered := false;
255        Filter := false;
256    end;    end;
   IWLabel9.Visible := DM.FDTable2.Filtered;  
257  end;  end;
258    
259  procedure TTopForm.IWLink1Click(Sender: TObject);  procedure TIWForm1.IWFrame8IWButton1Click(Sender: TObject);
260  const  var
261    filter = 'EMAIL = ''%s'' and PASSWORD = ''%s''';    i, j: Integer;
262      s: string;
263    begin
264      if TryStrToInt(IWFrame8.IWEdit1.Text, i) = false then
265      begin
266        WebApplication.ShowMessage('個数が不正です');
267        Exit;
268      end;
269      if i = 0 then
270      begin
271        WebApplication.ShowMessage('1個以上のご注文が必要です');
272        Exit;
273      end;
274      s := WebApplication.Request.CookieFields.Values['user_cookie'];
275      if s = '' then
276      begin
277        DM.FDTable1.Last;
278        j := DM.FDTable1.FieldByName('NUMBER').AsInteger + 1;
279        while DM.FDTable1.Lookup('NUMBER', j, 'NUMBER') = j do
280          inc(j);
281        UserSession.user_number := j;
282        DM.FDTable1.AppendRecord([nil, nil, nil, nil, nil,
283          UserSession.user_number, Date]);
284        WebApplication.Response.Cookies.AddCookie('user_cookie',
285          UserSession.user_number.ToString, '/', Date + 10);
286      end;
287      with DM.FDQuery1 do
288      begin
289        SQL.Clear;
290        SQL.Add('select * from cart_data;');
291        Open;
292        if Locate('NUMBER;SERIAL', VarArrayOf([UserSession.user_number,
293          UserSession.Serial]), []) = true then
294        begin
295          Edit;
296          FieldByName('VOLUME').AsInteger := FieldByName('VOLUME').AsInteger + i;
297          Post;
298        end
299        else
300          AppendRecord([nil, i, UserSession.user_number, UserSession.Serial]);
301      end;
302      WebApplication.ShowConfirm('カートに移動しますか', 'callback', '移動', 'はい', 'いいえ');
303    end;
304    
305    procedure TIWForm1.IWFrame8IWLink1Click(Sender: TObject);
306    begin
307      Thumbnail := true;
308    end;
309    
310    procedure TIWForm1.IWGrid1CellClick(ASender: TObject;
311      const ARow, AColumn: Integer);
312    begin
313      Thumbnail := false;
314      IWFrame8.IWEdit1.Text := '1';
315      UserSession.Serial := Integer(IWGrid1.Cell[ARow, AColumn].Tag);
316    end;
317    
318    procedure TIWForm1.IWLink1Click(Sender: TObject);
319    begin
320      TUserForm.Create(WebApplication).Show;
321    end;
322    
323    procedure TIWForm1.IWLink2Click(Sender: TObject);
324    var
325      i: Integer;
326  begin  begin
327    case Page of    if Page = true then
328      Main:    begin
329        i := UserSession.user_number;
330        if (DM.FDTable1.Locate('EMAIL;PASSWORD',
331          VarArrayOf([IWEdit2.Text, UserSession.hash(IWEdit3.Text)]),
332          [loCaseInsensitive]) = true) and
333          (DM.FDTable1.FieldByName('EMAIL').AsString <> '') then
334        begin
335          IWEdit2.Text := '';
336          UserSession.user_number := DM.FDTable1.FieldByName('NUMBER').AsInteger;
337          if i <> 0 then
338        begin        begin
339          DM.FDTable1.filter := Format(filter, [IWEdit2.Text, IWEdit3.Text]);          with DM.FDQuery1 do
         DM.FDTable1.Filtered := true;  
         if DM.FDTable1.RecordCount = 1 then  
340          begin          begin
341            IWLink1.Caption := 'ログアウト';            SQL.Clear;
342            Page := Info;            SQL.Add('select * from user_data where number = :num');
343            UserSession.user_number := DM.FDTable1.FieldByName('NUMBER')            Params.ParamByName('num').AsInteger := i;
344              .AsInteger;            Open;
345            IWEdit2.Text := '';            Delete;
346              SQL.Clear;
347              SQL.Add('select number from cart_data where number = :num;');
348              Params.ParamByName('num').AsInteger := i;
349              Open;
350              First;
351              while Eof = false do
352              begin
353                Edit;
354                FieldByName('number').AsInteger := UserSession.user_number;
355                Next;
356              end;
357          end;          end;
         IWEdit3.Text := '';  
       end;  
     Info:  
       begin  
         DM.FDTable1.Filtered := false;  
         IWLink1.Caption := 'ログイン';  
         Page := Main;  
         DM.FDQuery1.Params.ParamByName('num').AsInteger := 0;  
358        end;        end;
359          Page := false;
360        end;
361        IWEdit3.Text := '';
362      end
363      else
364        Page := true;
365    end;
366    
367    procedure TIWForm1.IWLink3Click(Sender: TObject);
368    begin
369      with TMyPage.Create(WebApplication) do
370      begin
371        Form := Self;
372        Show;
373    end;    end;
   IWLabel9.Visible := UserSession.user_number <> 0;  
374  end;  end;
375    
376  procedure TTopForm.IWLink2Click(Sender: TObject);  procedure TIWForm1.IWLink4Click(Sender: TObject);
377  begin  begin
378    UserSession.FPage := Info;    TCartForm.Create(WebApplication).Show;
379    TUserForm.Create(WebApplication).Show;  end;
380    
381    procedure TIWForm1.IWLink5Click(Sender: TObject);
382    begin
383      TIWForm10.Create(WebApplication).Show;
384  end;  end;
385    
386  procedure TTopForm.LoadImage;  procedure TIWForm1.IWLink6Click(Sender: TObject);
387    begin
388      Page := true;
389      TIWForm3.Create(WebApplication).Show;
390    end;
391    
392    procedure TIWForm1.LoadImage;
393  var  var
394    i, j, k: integer;    s: TStream;
395    png: TPngImage;    png: TPngImage;
396    pic: TIWImageFile;    pic: TIWImage;
397    st: TStream;    i: Integer;
398      j: Integer;
399      x: Boolean;
400      t: string;
401  label label1;  label label1;
402  begin  begin
403    ClearImage;    ClearImage;
404    if DM.FDTable2.RecordCount > 0 then    png := TPngImage.Create;
405    begin    try
406      IWGrid1.RowCount := (DM.FDTable2.RecordCount div IWGrid1.ColumnCount) + 1;      if Thumbnail = true then
407      k := 1;      begin
408      DM.FDTable2.Last;        i := DM.FDTable2.RecordCount div IWGrid1.ColumnCount;
409      png := TPngImage.Create;        if DM.FDTable2.RecordCount mod IWGrid1.ColumnCount > 0 then
410      try          inc(i);
411          IWGrid1.RowCount := i;
412          if DM.FDTable2.Filtered = false then
413            DM.FDTable2.Last
414          else
415            DM.FDTable2.FindLast;
416        for i := 0 to IWGrid1.RowCount - 1 do        for i := 0 to IWGrid1.RowCount - 1 do
       begin  
417          for j := 0 to IWGrid1.ColumnCount - 1 do          for j := 0 to IWGrid1.ColumnCount - 1 do
418          begin          begin
419            st := DM.FDTable2.CreateBlobStream            if DM.FDTable2.Filtered = false then
420              (DM.FDTable2.FieldByName('THUMBNAIL'), bmRead);            begin
421            try              if DM.FDTable2.Bof = true then
422              png.LoadFromStream(st);                goto label1;
423              pic := TIWImageFile.Create(Self);            end
424              else if DM.FDTable2.Found = false then
425                goto label1;
426              if DM.FDTable2.FieldByName('THUMBNAIL').AsBytes <> nil then
427              begin
428                s := DM.FDTable2.CreateBlobStream
429                  (DM.FDTable2.FieldByName('THUMBNAIL'), bmRead);
430                try
431                  png.LoadFromStream(s);
432                finally
433                  s.Free;
434                end;
435                pic := TIWImage.Create(IWGrid1);
436              pic.Picture.Assign(png);              pic.Picture.Assign(png);
437              IWGrid1.Cell[i, j].Control := pic;              IWGrid1.Cell[i, j].Control := pic;
             IWGrid1.Cell[i, j].Text := k.ToString;  
             inc(k);  
             DM.FDTable2.Prior;  
           finally  
             st.Free;  
438            end;            end;
439            if DM.FDTable2.Bof = true then            t := DM.FDTable2.FieldByName('NAME').AsString;
440              goto label1;            if Length(t) > 10 then
441                t := Copy(t, 1, 8) + '..';
442              IWGrid1.Cell[i, j].Tag :=
443                Pointer(DM.FDTable2.FieldByName('SERIAL').AsInteger);
444              IWGrid1.Cell[i, j].Text := t;
445              IWGrid1.Cell[i, j].Alignment := taCenter;
446              IWGrid1.Cell[i, j].Clickable := true;
447              if DM.FDTable2.Filtered = false then
448                DM.FDTable2.Prior
449              else
450                DM.FDTable2.FindPrior;
451          end;          end;
       end;  
452      label1:      label1:
453      finally      end
454        png.Free;      else if (DM.FDTable2.Locate('SERIAL', UserSession.Serial, []) = true) and
455      end;        (DM.FDTable2.FieldByName('THUMBNAIL').AsBytes <> nil) then
456    end      begin
457    else        s := DM.FDTable2.CreateBlobStream
458      IWGrid1.RowCount := 0;          (DM.FDTable2.FieldByName('THUMBNAIL'), bmRead);
459    st := nil;        try
460            png.LoadFromStream(s);
461            IWFrame8.IWImage1.Picture.Assign(png);
462          finally
463            s.Free;
464          end;
465        end
466        else
467          IWFrame8.IWImage1.Picture.Assign(nil);
468      finally
469        png.Free;
470      end;
471    png := nil;    png := nil;
472      s := nil;
473    Randomize;    Randomize;
474      if DM.FDTable2.Filtered = true then
475      begin
476        x := true;
477        DM.FDTable2.Filtered := false;
478      end
479      else
480        x := false;
481    DM.FDTable2.Last;    DM.FDTable2.Last;
482      if DM.FDTable2.Bof = true then
483        Exit;
484    DM.FDTable2.MoveBy(-Random(DM.FDTable2.RecordCount div 5));    DM.FDTable2.MoveBy(-Random(DM.FDTable2.RecordCount div 5));
485    st := DM.FDTable2.CreateBlobStream    if DM.FDTable2.FieldByName('THUMBNAIL').AsBytes <> nil then
486      (DM.FDTable2.FieldByName('THUMBNAIL'), bmRead);    begin
487    png := TPngImage.Create;      s := DM.FDTable2.CreateBlobStream
488    try        (DM.FDTable2.FieldByName('THUMBNAIL'), bmRead);
489      png.LoadFromStream(st);      png := TPngImage.Create;
490      IWImageFile1.Picture.Assign(png);      try
491    finally        png.LoadFromStream(s);
492      st.Free;        IWImage1.Picture.Assign(png);
493      png.Free;      finally
494          png.Free;
495          s.Free;
496        end;
497    end;    end;
498      if x = true then
499        DM.FDTable2.Filtered := true;
500    IWLabel4.Caption := DM.FDTable2.FieldByName('NAME').AsString;    IWLabel4.Caption := DM.FDTable2.FieldByName('NAME').AsString;
501  end;  end;
502    
503  procedure TTopForm.SetPage(const Value: TPage);  procedure TIWForm1.SetPage(const Value: Boolean);
 var  
   s: string;  
504  begin  begin
505    UserSession.FPage := Value;    UserSession.FPage := Value;
506    case Value of    IWRegion7.Visible := not Value;
507      Main:    IWDBLabel1.Visible := not Value;
508        s := 'toppage.htm';    IWLink3.Visible := not Value;
509      Info:    IWLink1.Visible := Value;
510        s := 'mypage.htm';    IWText1.Visible := Value;
511      if Value = false then
512      begin
513        IWLabel1.Caption := 'ようこそ';
514        IWLink2.Caption := 'ログアウト';
515        WebApplication.Response.Cookies.AddCookie('user_cookie',
516          UserSession.user_number.ToString, '/', Date + 10);
517      end
518      else
519      begin
520        IWLabel1.Caption := 'ようこそゲスト様';
521        IWLink2.Caption := 'ログイン';
522        Thumbnail := true;
523        IWText1.Text := '';
524        DM.FDTable2.Filtered := false;
525        Filter := false;
526        if DM.FDTable1.FieldByName('EMAIL').AsString <> '' then
527        begin
528          WebApplication.Response.Cookies.AddCookie('user_cookie',
529            UserSession.user_number.ToString, '/', Date - 1);
530          UserSession.user_number := 0;
531        end;
532    end;    end;
533    IWTemplateProcessorHTML1.Templates.Default := s;  end;
534    
535    procedure TIWForm1.SetThumbnail(const Value: Boolean);
536    begin
537      UserSession.FThumbnail := Value;
538      IWGrid1.Visible := Value;
539      IWFrame8.Visible := not Value;
540  end;  end;
541    
542  initialization  initialization
543    
544  TTopForm.SetAsMainForm;  TIWForm1.SetAsMainForm;
545    
546  end.  end.

Legend:
Removed from v.1  
changed lines
  Added in v.11

Back to OSDN">Back to OSDN
ViewVC Help
Powered by ViewVC 1.1.26