亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ehlibmte.pas

?? 一個功能強大的DBGRID控件
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
{*******************************************************}
{                                                       }
{                     EhLib v4.2                        }
{          Registers object that sort data in           }
{                  TCustomMemTableEh                    }
{                    (Build 4.2.03)                     }
{                                                       }
{    Copyright (c) 2003-2006 by Dmitry V. Bolshakov     }
{                                                       }
{*******************************************************}

{*******************************************************}
{ Add this unit to 'uses' clause of any unit of your    }
{ project to allow TDBGridEh to sort data in            }
{ TMemTableEh automatically after sorting markers       }
{ will be changed.                                      }
{ TMTEDatasetFeaturesEh determine if                    }
{ TDBGridEh.SortLocal = True then it will sort data     }
{ in memory using procedure SortByFields                }
{ else if SortLocal = False and MemTable connected to   }
{ other  DataSet via ProviderDataSet, it will try to    }
{ sord data in this DataSet using                       }
{ GetDatasetFeaturesForDataSet function                 }
{*******************************************************}

unit EhLibMTE;

{$I EhLib.Inc}

interface

uses
{$IFDEF EH_LIB_6} Variants, {$ENDIF}
  DbUtilsEh, DBGridEh, Db, MemTableEh, MemTableDataEh, DataDriverEh,
  SysUtils, ToolCtrlsEh;

type

  TMTEDatasetFeaturesEh = class(TSQLDatasetFeaturesEh)
  protected
    FBaseNode: TMemRecViewEh;
  public
    constructor Create; override;
    function LocateText(AGrid: TCustomDBGridEh; const FieldName: string;
      const Text: String; AOptions: TLocateTextOptionsEh; Direction: TLocateTextDirectionEh;
      Matching: TLocateTextMatchingEh; TreeFindRange: TLocateTextTreeFindRangeEh): Boolean; override;
    procedure ApplyFilter(Sender: TObject; DataSet: TDataSet; IsReopen: Boolean); override;
    procedure ApplySorting(Sender: TObject; DataSet: TDataSet; IsReopen: Boolean); override;
    procedure ExecuteFindDialog(Sender: TObject; Text, FieldName: String; Modal: Boolean); override;
  end;

var
  SortInView: Boolean;

implementation

uses Classes;

type
  TCustomDBGridEhCrack = class(TCustomDBGridEh) end;
  TDataDriverEhCrack = class(TDataDriverEh) end;

procedure ApplySortingForSQLDataDriver(Grid: TCustomDBGridEh; SQLDriver: TSQLDataDriverEh;
   UseFieldName: Boolean);

  function DeleteStr(str: String; sunstr: String): String;
  var
    i: Integer;
  begin
    i := Pos(sunstr, str);
    if i <> 0 then
      Delete(str, i, Length(sunstr));
    Result := str;
  end;

var
  i, OrderLine: Integer;
  s: String;
  SQL: TStrings;
begin

  SQL := TStringList.Create;
  try
    SQL.Text := SQLDriver.SelectSQL.Text;

    s := '';
    for i := 0 to Grid.SortMarkedColumns.Count - 1 do
    begin
      if UseFieldName
        then s := s + Grid.SortMarkedColumns[i].FieldName
        else s := s + IntToStr(Grid.SortMarkedColumns[i].Field.FieldNo);
      if Grid.SortMarkedColumns[i].Title.SortMarker = smUpEh
        then s := s + ' DESC, '
        else s := s + ', ';
    end;

    if s <> '' then
      s := 'ORDER BY ' + Copy(s, 1, Length(s) - 2);

    OrderLine := -1;
    for i := 0 to SQL.Count - 1 do
      if UpperCase(Copy(SQL[i], 1, Length('ORDER BY'))) = 'ORDER BY' then
      begin
        OrderLine := i;
        Break;
      end;
    if OrderLine = -1 then
    begin
      SQL.Add('');
      OrderLine := SQL.Count-1;
    end;

    SQL.Strings[OrderLine] := s;

    SQLDriver.SelectSQL := SQL;

  finally
    SQL.Free;
  end;
end;

procedure ApplyFilterForSQLDataDriver(Grid: TCustomDBGridEh; SQLDriver: TSQLDataDriverEh;
  DateValueToSQLString: TDateValueToSQLStringProcEh);
var
  i, OrderLine: Integer;
  s: String;
  SQL: TStrings;
begin

  SQL := TStringList.Create;
  try
    SQL.Text := SQLDriver.SelectSQL.Text;

    OrderLine := -1;
    for i := 0 to SQL.Count - 1 do
      if UpperCase(Copy(SQL[i], 1, Length(SQLFilterMarker))) = UpperCase(SQLFilterMarker) then
      begin
        OrderLine := i;
        Break;
      end;
    s := GetExpressionAsFilterString(Grid, GetOneExpressionAsSQLWhereString, DateValueToSQLString, True);
    if s = '' then
      s := '1=1';
    if OrderLine = -1 then
      Exit;

    SQL.Strings[OrderLine] := SQLFilterMarker + ' (' + s + ')';
    SQLDriver.SelectSQL := SQL;

  finally
    SQL.Free;
  end;
end;

function LocateTextInTree(AGrid: TCustomDBGridEh;
  const FieldName, Text: String; AOptions: TLocateTextOptionsEh;
  Direction: TLocateTextDirectionEh; Matching: TLocateTextMatchingEh;
  TreeFindRange: TLocateTextTreeFindRangeEh; BaseNode: TMemRecViewEh): Boolean;
var
  FCurInListColIndex: Integer;
  TreeListPos: Integer;
  MemTable: TCustomMemTableEh;
  TreeList: TMemoryTreeListEh;
  RootNode, NextNode: TMemRecViewEh;

  function CheckEofBof: Boolean;
  begin
    if (Direction = ltdUpEh)
//      then Result := (TreeListPos < 0)
//      else Result := (TreeListPos > TreeList.AccountableCount-1);
      then Result := (NextNode = nil)
      else Result := (NextNode = nil);
  end;

  procedure First;
  begin
    TreeListPos := 0;
    MemTable.InstantReadLeave;
    if TreeFindRange = lttInCurrentLevelEh then
    begin
      RootNode := BaseNode.NodeParent.VisibleNodeItems[0];
      NextNode := RootNode;
    end else if TreeFindRange = lttInCurrentNodeEh then
    begin
      RootNode := BaseNode;
      NextNode := RootNode;
    end else
      NextNode := TreeList.AccountableItem[TreeListPos];
    MemTable.InstantReadEnter(NextNode, -1);
  end;

  procedure Next;
  begin
    Inc(TreeListPos);
    if TreeFindRange = lttInCurrentLevelEh then
    begin
      if (NextNode.NodeParent.VisibleNodesCount-1 = NextNode.VisibleNodeIndex)
      then
        NextNode := nil
      else
        NextNode := NextNode.NodeParent.VisibleNodeItems[NextNode.VisibleNodeIndex + 1];
    end else if TreeFindRange = lttInCurrentNodeEh then
    begin
      if NextNode.VisibleNodesCount > 0 then
        NextNode := NextNode.VisibleNodeItems[0]
      else if (NextNode <> BaseNode) and
              (NextNode.NodeParent.VisibleNodesCount-1 > NextNode.VisibleNodeIndex) then
        NextNode := NextNode.NodeParent.VisibleNodeItems[NextNode.VisibleNodeIndex + 1]
      else
      begin
        while (NextNode <> BaseNode) and (NextNode.NodeParent.VisibleNodesCount-1 = NextNode.VisibleNodeIndex)  do
          NextNode := NextNode.NodeParent;
        if NextNode = BaseNode
          then NextNode := nil
          else NextNode := NextNode.NodeParent.VisibleNodeItems[NextNode.VisibleNodeIndex + 1];
      end;
    end else
    begin
      if TreeListPos <= TreeList.AccountableCount-1 then
        NextNode := TreeList.AccountableItem[TreeListPos]
      else
        NextNode := nil;
    end;
    if NextNode <> nil then
    begin
      MemTable.InstantReadLeave;
      MemTable.InstantReadEnter(NextNode, -1);
    end;
  end;

  procedure Prior;
  begin
    Dec(TreeListPos);
    if TreeFindRange = lttInCurrentLevelEh then
    begin
      if NextNode.VisibleNodeIndex = 0
      then
        NextNode := nil
      else
        NextNode := NextNode.NodeParent.VisibleNodeItems[NextNode.VisibleNodeIndex - 1];
    end else if TreeFindRange = lttInCurrentNodeEh then
    begin
{      if NextNode.VisibleNodeIndex > 0 then
      begin
        NextNode := NextNode.NodeParent.VisibleNodeItems[NextNode.VisibleNodeIndex - 1];
        if NextNode.VisibleNodesCount > 0 then
          NextNode := NextNode.VisibleNodeItems[NextNode.VisibleNodesCount-1];
      end else if (NextNode.NodeParent.NodeParent <> nil)
      then
        NextNode := NextNode.NodeParent
      else
        NextNode := nil;}
      if (TreeListPos >= 0) and
       ((TreeList.AccountableItem[TreeListPos].NodeLevel > BaseNode.NodeLevel) or
        (TreeList.AccountableItem[TreeListPos] = BaseNode)) then
        NextNode := TreeList.AccountableItem[TreeListPos]
      else
        NextNode := nil;
    end else
    begin
      if TreeListPos >= 0 then
        NextNode := TreeList.AccountableItem[TreeListPos]
      else
        NextNode := nil;
    end;
    if NextNode <> nil then
    begin
      MemTable.InstantReadLeave;
      MemTable.InstantReadEnter(NextNode, -1);
    end;
  end;

  procedure ToNextRec;
  begin
    if ltoAllFieldsEh in AOptions then
      if (Direction = ltdUpEh) then
      begin
        if FCurInListColIndex > 0 then
          Dec(FCurInListColIndex)
        else
        begin
          Prior;
          FCurInListColIndex := AGrid.VisibleColCount-1;
        end;
      end else
      begin
        if FCurInListColIndex < AGrid.VisibleColCount-1 then
          Inc(FCurInListColIndex)
        else
        begin
          Next;
          FCurInListColIndex := 0;
        end;
      end
    else if (Direction = ltdUpEh) then
      Prior
    else
      Next;
  end;

  function ColText(Col: TColumnEh): String;
  begin
    if ltoMatchFormatEh in AOptions then
      Result := Col.DisplayText
    else if Col.Field <> nil then
      Result := Col.Field.AsString

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品羞羞答答xxdd| 久久99精品国产.久久久久| 国产偷国产偷亚洲高清人白洁 | 久久这里只精品最新地址| 欧美日韩不卡在线| 正在播放一区二区| 欧美xxx久久| 国产色婷婷亚洲99精品小说| 2021国产精品久久精品| 精品国产乱码久久久久久蜜臀 | 91一区二区在线| 99re热这里只有精品免费视频| 成人99免费视频| 91在线观看一区二区| 欧美视频一区二区三区在线观看| 欧美在线视频你懂得| 欧美一级理论性理论a| 日韩欧美高清在线| 欧美国产97人人爽人人喊| 亚洲欧美日韩中文字幕一区二区三区| 亚洲欧洲综合另类在线| 亚洲午夜成aⅴ人片| 久久精品99久久久| 色综合一个色综合亚洲| 欧美剧在线免费观看网站| 久久午夜电影网| 亚洲欧美一区二区视频| 日韩精品久久理论片| 成人在线一区二区三区| 欧美日韩午夜在线视频| 国产亚洲污的网站| 亚洲一区二区在线播放相泽| 国产九九视频一区二区三区| 在线精品视频一区二区| 久久伊99综合婷婷久久伊| 中文字幕佐山爱一区二区免费| 天堂一区二区在线免费观看| 国产激情一区二区三区桃花岛亚洲| 一本色道久久综合亚洲aⅴ蜜桃| 欧美一级生活片| 国产精品久久毛片| 久久精品国产**网站演员| av在线一区二区三区| 欧美成人官网二区| 亚洲美女免费视频| 韩国av一区二区| 欧美日韩在线电影| 中文字幕一区二区三区四区不卡| 免费观看在线综合| 在线观看免费亚洲| 国产精品久久久久一区二区三区| 奇米精品一区二区三区在线观看| 91麻豆免费观看| 国产欧美日产一区| 国产一区二区美女| 91精品国产91久久久久久一区二区| 亚洲色图丝袜美腿| 高清av一区二区| 久久亚洲免费视频| 精品制服美女丁香| 欧美一区二区免费| 免费欧美在线视频| 欧美顶级少妇做爰| 午夜精品视频在线观看| 色综合色综合色综合色综合色综合| 国产日韩精品一区二区三区在线| 国模套图日韩精品一区二区| 欧美一级日韩不卡播放免费| 日韩二区在线观看| 欧美精品在线观看一区二区| 亚洲国产日韩精品| 777欧美精品| 日韩制服丝袜av| 欧美一级搡bbbb搡bbbb| 免费成人在线影院| 欧美大片一区二区三区| 久久国产欧美日韩精品| 精品成人一区二区三区四区| 美女久久久精品| 欧美大胆人体bbbb| 国产精品一二三区| 国产精品久久久久精k8| av在线一区二区三区| 怡红院av一区二区三区| 欧美午夜精品一区二区蜜桃| 视频一区在线视频| 欧美xxxxx牲另类人与| 国产中文字幕精品| 国产精品国产三级国产普通话99 | 精品一区二区日韩| 亚洲精品在线观| 国产 欧美在线| 亚洲柠檬福利资源导航| 欧美午夜在线一二页| 青青草成人在线观看| 久久久久久亚洲综合| 91一区二区三区在线观看| 午夜免费欧美电影| 久久影院视频免费| 91国内精品野花午夜精品| 首页综合国产亚洲丝袜| 日韩午夜在线观看视频| 国产高清成人在线| 一卡二卡三卡日韩欧美| 日韩午夜在线播放| 色综合激情五月| 99久久久精品| 亚洲资源中文字幕| 国产欧美在线观看一区| 欧美日韩成人一区| 成人免费视频app| 麻豆国产一区二区| 亚洲免费av网站| 国产日韩亚洲欧美综合| 欧美日韩www| 成人网男人的天堂| 精品一区二区三区在线播放| 亚洲免费色视频| 日本一区二区免费在线观看视频| 欧美男男青年gay1069videost| 国产91精品露脸国语对白| 日韩成人av影视| 一区二区三区在线观看欧美| 亚洲精品一区二区三区影院 | 91原创在线视频| 精彩视频一区二区三区| 亚洲第一久久影院| 亚洲欧洲色图综合| 国产精品网站在线| 久久综合色综合88| 日韩一区二区在线观看视频| 欧洲av一区二区嗯嗯嗯啊| 成人美女视频在线看| 国产一区二区三区久久悠悠色av| 首页亚洲欧美制服丝腿| 亚洲高清免费视频| 亚洲国产综合人成综合网站| 亚洲天堂免费在线观看视频| 中文字幕精品一区二区精品绿巨人 | 欧美tickle裸体挠脚心vk| 91精品国产一区二区三区| 欧美三区在线观看| 欧美伦理影视网| 欧美精选在线播放| 欧美日韩在线播放三区四区| 欧美视频一区二区在线观看| 在线观看不卡视频| 欧美色手机在线观看| 欧美色爱综合网| 欧美福利视频导航| 欧美一级一区二区| 日韩三级免费观看| 久久久久国产精品厨房| www国产精品av| 久久久久久免费| 国产精品电影院| 一区在线观看免费| 一二三区精品福利视频| 亚洲欧美日韩久久精品| 一区二区成人在线| 亚洲成人激情综合网| 蜜桃av一区二区在线观看| 老司机精品视频导航| 国产乱人伦偷精品视频免下载| 国产乱人伦偷精品视频不卡| 成人精品鲁一区一区二区| www.日韩大片| 欧美视频日韩视频| 精品国产伦一区二区三区免费 | 一区二区三区四区蜜桃| 26uuu亚洲综合色欧美 | 欧美国产精品v| 椎名由奈av一区二区三区| 国产精品国模大尺度视频| 99精品在线观看视频| 欧美日韩国产综合久久| 亚洲日本在线a| 国产99久久久精品| 日韩欧美在线观看一区二区三区| 亚洲精选视频免费看| 国产91丝袜在线观看| 日韩欧美中文字幕精品| 丝袜国产日韩另类美女| 在线免费观看成人短视频| 日韩理论在线观看| 成人久久视频在线观看| 欧美激情一区二区三区| 国内精品久久久久影院薰衣草| 91精品国产aⅴ一区二区| 成人中文字幕合集| 久久久久久久久97黄色工厂| 激情五月播播久久久精品| 欧美一级欧美三级在线观看| 亚洲一区二区欧美日韩| 在线视频亚洲一区| 国产精品成人免费| 99久久久国产精品免费蜜臀| 亚洲人快播电影网| 日本精品一区二区三区四区的功能| 日韩一区中文字幕|