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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? invquery.pas

?? 文件包含程序源原文件
?? PAS
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
unit InvQuery;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, ExtCtrls, Buttons, ComCtrls, EnhLV, GLLV, InvDef,
  ImgList, xlsConst, ComObj, ClipBrd, dpConst, Math, StrUtils;

type
  TfrmBalance = class(TForm)
    Panel1: TPanel;
    Panel3: TPanel;
    btnReView: TSpeedButton;
    btnFilterQuery: TSpeedButton;
    ListView: TGradLineListView;
    lblCompute: TLabel;
    Image1: TImage;
    ImageList: TImageList;
    Panel5: TPanel;
    Panel6: TPanel;
    btnExcel: TBitBtn;
    chkboxchkQty: TCheckBox;
    Panel7: TPanel;
    btnClose: TBitBtn;
    chkPCS: TCheckBox;
    chkStkLess0: TCheckBox;
    stsBarCnt: TStatusBar;
    pnlBalance: TLabel;
    procedure FormCreate(Sender: TObject);
    procedure FormActivate(Sender: TObject);
    procedure FormShow(Sender: TObject);
    procedure FormClose(Sender: TObject; var Action: TCloseAction);
    procedure btnFilterQueryClick(Sender: TObject);
    procedure btnReViewClick(Sender: TObject);
    procedure btnCloseClick(Sender: TObject);
    procedure btnExcelClick(Sender: TObject);
    procedure ListViewColumnClick(Sender: TObject; Column: TListColumn);

  private
    { Private declarations }
    procedure SetListColumn;
    procedure SetListView;
    procedure MakeItemCaption(Item: TListItem);
    Procedure DrawSafeStockImage;
    
    procedure SetBalanceList(RID: LongInt; List: TList; DT: TDateTime);

    Procedure SetMultilingual;
  public
    { Public declarations }
    procedure ReViewProc;
    Procedure PrintProc;
    function  CopyToClipBoard(var RecCnt, ColCnt: Integer): string;

  end;

var
  frmBalance: TfrmBalance;
  BalanceList, FList: TList;
  FColumnCount: Integer;
  ListSortKey: Integer;

implementation

uses Main, InvDM, InvCondQry;

{$R *.dfm}

/////////////////////////////////////////////////////////
// TListSortCompare --
function ListSortCompare(Item1, Item2: Pointer): Longint;
var DataType: Integer;
    Str1, Str2: string;
    Int1, Int2: Integer;
    Dbl1, Dbl2: Double;
    Dat1, Dat2: TDateTime;
begin
  Result := 0;
  Str1 := ''; Str2 := '';
  Int1 := 0;  Int2 := 0;
  Dbl1 := 0;  Dbl2 := 0;
  Dat1 := 0;  Dat2 := 0;
  case Abs(ListSortKey) of
    1: begin //--
        Str1 := TBALANCE(Item1^).STK_ID;
        Str2 := TBALANCE(Item2^).STK_ID;
        DataType := 0;
       end;
    2: begin //--
        Str1 := dm_inventory.GetMaterialCode(TBALANCE(Item1^).CODE)+RightStr(('0000000'+InttoStr(TBALANCE(Item1^).GUAGE_ID)),6);
        Str2 := dm_inventory.GetMaterialCode(TBALANCE(Item2^).CODE)+RightStr(('0000000'+InttoStr(TBALANCE(Item2^).GUAGE_ID)),6);
        DataType := 0;
       end;
    3: begin //--
        Str1 := TBALANCE(Item1^).NAME;
        Str2 := TBALANCE(Item2^).NAME;
        DataType := 0;
       end;
    4: begin //--
        Str1 := dm_inventory.GetMaterialCode(TBALANCE(Item1^).CODE)+RightStr(('0000000'+InttoStr(TBALANCE(Item1^).GUAGE_ID)),6);
        Str2 := dm_inventory.GetMaterialCode(TBALANCE(Item2^).CODE)+RightStr(('0000000'+InttoStr(TBALANCE(Item2^).GUAGE_ID)),6);
        DataType := 0;
       end;
    6: begin //--
        Str1 := dm_inventory.GetUnitTypeName(TBALANCE(Item1^).CODE);
        Str2 := dm_inventory.GetUnitTypeName(TBALANCE(Item2^).CODE);
        DataType := 0;
       end;
    7: begin //--
        Dbl1 := TBALANCE(Item1^).U_PRICE;
        Dbl2 := TBALANCE(Item2^).U_PRICE;
        DataType := 2;
       end;
    8: begin //--
        Dbl1 := TBALANCE(Item1^).QUANTITY;
        Dbl2 := TBALANCE(Item2^).QUANTITY;
        DataType := 2;
       end;
    9: begin //--
        Dbl1 := TBALANCE(Item1^).T_PRICE;
        Dbl2 := TBALANCE(Item2^).T_PRICE;
        DataType := 2;
       end;
  else Exit;
  end;
  case DataType of
    0: if Str1 < Str2 then  Result := -1
       else if Str1 > Str2 then Result := 1
       else Result := 0;
    1: if Int1 < Int2 then  Result := -1
       else if Int1 > Int2 then Result := 1
       else Result := 0;
    2: if Dbl1 < Dbl2 then  Result := -1
       else if Dbl1 > Dbl2 then Result := 1
       else Result := 0;
    3: if Dat1 < Dat2 then  Result := -1
       else if Dat1 > Dat2 then Result := 1
       else Result := 0;
  else Result := 0;
  end;
  if ListSortKey < 0 then Result := Result * -1;
end;


procedure TfrmBalance.FormCreate(Sender: TObject);
begin
  Top    := frmMain.Height;
  Left   := 0;
  Width  := Screen.Width;
  Height := Screen.Height-(frmMain.Height+stsBarCnt.Height+8);

  FList := TList.Create;
  FList.Clear;

  BalanceList := TList.Create;
  BalanceList.Clear;

  SetMultilingual;
  SetListColumn;
  ReViewProc;
end;

procedure TfrmBalance.FormActivate(Sender: TObject);
begin
  if frmMain.IniData.isCheckQty then begin
    chkboxchkQty.Visible := true;
    chkboxchkQty.Checked := true;
  end else begin
    chkboxchkQty.Visible := false;
    chkboxchkQty.Checked := false;
  end;
end;


procedure TfrmBalance.FormShow(Sender: TObject);
begin
  Top    := frmMain.Height;
  Left   := 0;
  Width  := Screen.Width;
  Height := Screen.Height-(frmMain.Height+stsBarCnt.Height+8);

  chkStkLess0.Checked := false;
  DrawSafeStockImage;
end;

procedure TfrmBalance.FormClose(Sender: TObject; var Action: TCloseAction);
begin
  dm_Inventory.Delete_NullMaterial;
  Action := caFree;
end;

procedure TfrmBalance.SetListColumn;
var Column: TListColumn;
begin
  FColumnCount := 0;
  ListView.Columns.Clear;

  Column := ListView.Columns.Add;
  Column.Width   := ListView.Font.Size * 6;
  Column.Caption := GetMultiLingalMsg(90027, 'Stock ID');
  Inc(FColumnCount);
  Column := ListView.Columns.Add;
  Column.Width   := ListView.Font.Size * 14;
  Column.Caption := GetMultiLingalMsg(90028, 'Material Code');
  Inc(FColumnCount);
  Column := ListView.Columns.Add;
  Column.Width   := ListView.Font.Size * 14;
  Column.Caption := GetMultiLingalMsg(90029, 'Material Name');
  Inc(FColumnCount);
  Column := ListView.Columns.Add;
  Column.Width   := ListView.Font.Size * 7;
  Column.Caption := GetMultiLingalMsg(90030, 'Guage ID');
  Inc(FColumnCount);
  Column := ListView.Columns.Add;
  Column.Width   := ListView.Font.Size * 18;
  Column.Caption := GetMultiLingalMsg(90031, 'Guage Name');
  Inc(FColumnCount);
  Column := ListView.Columns.Add;
  Column.Width   := ListView.Font.Size * 6;
  Column.Caption := GetMultiLingalMsg(90032, 'Unit Name');
  Inc(FColumnCount);
  Column := ListView.Columns.Add;
  Column.Width     := ListView.Font.Size * 8;
  Column.Alignment := taRightJustify;
  Column.Caption   := GetMultiLingalMsg(90033, 'Unit Price');
  Inc(FColumnCount);
  Column := ListView.Columns.Add;
  Column.Width     := ListView.Font.Size * 10;
  Column.Alignment := taRightJustify;
  Column.Caption   := GetMultiLingalMsg(90034, 'Inventory Quantity');
  Inc(FColumnCount);
  Column := ListView.Columns.Add;
  Column.Width     := ListView.Font.Size * 11;
  Column.Alignment := taRightJustify;
  Column.Caption   := GetMultiLingalMsg(90035, 'Inventory Amount');
  Inc(FColumnCount);
  //--
  Column := ListView.Columns.Add;
  Column.Width     := ListView.Font.Size * 8;
  Column.Alignment := taRightJustify;
  Column.Caption   := '';
  Inc(FColumnCount);
end;

procedure TfrmBalance.SetListView;
var IX_1, IX_2: Integer;
    lcP: PBALANCE;
    Item: TListItem;
    Tmp: string;
begin
  Screen.Cursor  := crHourGlass;
  Tmp := GetMultiLingalMsg(90036, 'Caculate Mode of Inventory Material');

  case StrToIntDef(frmMain.IniData.OutPrice, 0) of
    0: lblCompute.Caption := Tmp + ': ' + GetMultiLingalMsg(90037, 'Avg Price');
    1: lblCompute.Caption := Tmp + ': ' + GetMultiLingalMsg(90038, 'FILO');
    2: lblCompute.Caption := Tmp + ': ' + GetMultiLingalMsg(90039, 'FIFO');
    3: lblCompute.Caption := Tmp + ': ' + GetMultiLingalMsg(90040, 'Standard Price');
  else lblCompute.Caption := '';
  end;
  with ListView.Items do begin
    BeginUpdate;
    Clear;
    EndUpdate;
  end;

  //////////////////////////////////
  ListView.Items.BeginUpdate;
  try
    for IX_1:=0 to BalanceList.Count-1 do begin
      lcP  := BalanceList.Items[IX_1];

      if chkStkLess0.Checked then
      begin
        if (RoundTo(lcp^.QUANTITY,-2)<=0.00) then continue;
      end;

      Item := ListView.Items.Add;
      for IX_2:=0 to FColumnCount-2 do Item.Subitems.Add('');
      Item.Data := lcP;
      MakeItemCaption(Item);
    end;
  finally
    ListView.Items.EndUpdate;
    ListView.Items.EndUpdate;
    if ListView.Items.Count > 0 then
    begin
      ListView.TopItem.Selected := True;
      ListView.Selected.Selected := true;
    end;
    stsBarCnt.Panels[0].Text := '符合條件的記錄有:'+ IntToStr(ListView.Items.Count)+' 條';
    Screen.Cursor := crDefault;
  end;
end;

procedure TfrmBalance.MakeItemCaption(Item: TListItem);
var lcP: PBALANCE;
begin
  if Item = nil then Exit;
  if Item.Data = nil then Exit;
  lcP := Item.Data;

  Item.ImageIndex   := lcP^.IS_SAFETY;
  Item.Caption      := lcp^.STK_ID;
  Item.SubItems[00] := dm_inventory.GetMaterialCode(lcP^.CODE);
  Item.SubItems[01] := lcP^.NAME;
  Item.SubItems[02] := IntToStr(lcp^.GUAGE_ID);
  Item.SubItems[03] := lcp^.GUAGE_NAME;
  Item.SubItems[04] := dm_inventory.GetUnitTypeName(lcP^.CODE);
  Item.SubItems[05] := FormatFloat('#,##0.00', lcP^.U_PRICE);
  Item.SubItems[06] := FormatFloat('#,##0.00', lcP^.QUANTITY);
  Item.SubItems[07] := FormatFloat('#,##0.00', lcP^.T_PRICE);
  if chkPCS.Checked then begin
    ListView.Column[9].Caption := GetMultiLingalMsg(90275, '->PCS');
    Item.SubItems[08] := FormatFloat('#,##0.00', Ceil(lcp^.QUANTITY/dm_inventory.Get_MatGuageWgtPcs(lcp^.CODE,lcp^.GUAGE_ID)));
  end
  else begin
    ListView.Column[9].Caption := '';
    Item.SubItems[08] := '';
  end;
end;

Procedure TfrmBalance.DrawSafeStockImage;
var
  SExplains: array[0..1] of string;
  i, x, y, TextW: Integer;
begin
  SExplains[0] := GetMultiLingalMsg(90041, '< Safety Inventory');
  SExplains[1] := GetMultiLingalMsg(90042, '>=Safety Inventory');

  with Image1.Canvas do begin
    TextW := TextWidth(SExplains[0]);
    if TextW < TextWidth(SExplains[1]) then
      TextW := TextWidth(SExplains[1]);

    Pen.Color := clBlack;
    Brush.Color := clBtnFace;
    FillRect(ClientRect);
    y := 5;
    for i:= 0 to 1 do begin
      x := i * (ImageList.Width+4 + TextW);
      ImageList.Draw(Image1.Canvas, x, y, i);
      TextOut(x+17, y+2, SExplains[i]);
    end;
  end;
end;

procedure TfrmBalance.ReViewProc;
begin
  dm_inventory.ReadInventory(True, FList);

  SetBalanceList(-1, BalanceList, StrToDateTime('2999/12/31'));
  Screen.Cursor  := crHourGlass;
  try
    SetListView;
  finally
    Screen.Cursor := crDefault;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人在线直播| 一区二区三区色| 欧美日韩不卡一区二区| 国产真实乱偷精品视频免| 性做久久久久久免费观看 | av激情综合网| 极品美女销魂一区二区三区| 亚洲动漫第一页| 国产视频一区在线播放| 精品对白一区国产伦| 91麻豆精品国产无毒不卡在线观看 | 一区二区三区久久久| 日本一区二区三区免费乱视频| 精品播放一区二区| 日韩欧美久久久| 欧美mv日韩mv亚洲| 欧美成人高清电影在线| 日韩欧美亚洲另类制服综合在线 | 在线视频观看一区| 色素色在线综合| 99精品视频中文字幕| av亚洲产国偷v产偷v自拍| 国产盗摄精品一区二区三区在线| 精品无人码麻豆乱码1区2区| 九九精品一区二区| 国产综合久久久久影院| 免费在线成人网| 理论片日本一区| 国产一区二区三区国产| 国产精品综合一区二区三区| 国产白丝网站精品污在线入口| 国产精品一区不卡| 成人午夜短视频| 91视频一区二区| 在线一区二区三区做爰视频网站| 91久久国产综合久久| 欧美亚洲国产怡红院影院| 555夜色666亚洲国产免| 日韩欧美亚洲一区二区| 精品国产精品一区二区夜夜嗨| 久久综合av免费| 国产女人18毛片水真多成人如厕| 久久精品夜夜夜夜久久| 成人欧美一区二区三区1314| 有码一区二区三区| 日韩高清不卡在线| 国产一区二区三区不卡在线观看 | 五月天婷婷综合| 精品在线免费视频| 成人晚上爱看视频| 欧亚洲嫩模精品一区三区| 欧美一区二区在线不卡| 久久女同精品一区二区| 亚洲视频在线一区二区| 午夜亚洲国产au精品一区二区| 久久电影网电视剧免费观看| 波波电影院一区二区三区| 91黄视频在线观看| 日韩精品一区二区三区视频播放| 国产精品沙发午睡系列990531| 一区二区理论电影在线观看| 久久精品国产99| 91免费国产在线| 91精品国产综合久久久久久久| 久久久精品中文字幕麻豆发布| 亚洲三级在线观看| 韩国中文字幕2020精品| 色婷婷国产精品综合在线观看| 欧美美女bb生活片| 中文字幕欧美日韩一区| 亚洲精品成人天堂一二三| 久久国产乱子精品免费女| www.综合网.com| 制服丝袜av成人在线看| 国产精品美女久久久久久久久久久 | 久久亚区不卡日本| 亚洲男人都懂的| 久久精品国产999大香线蕉| 91在线国产福利| 欧美电视剧免费全集观看| 中文字幕一区二区在线观看| 日本一不卡视频| 色婷婷综合久久久中文一区二区| 精品国产网站在线观看| 亚洲国产sm捆绑调教视频 | 亚洲国产另类av| 国产丶欧美丶日本不卡视频| 欧美福利一区二区| 亚洲欧美日韩国产中文在线| 国产一区二区免费在线| 91麻豆精品国产无毒不卡在线观看 | 日韩精品一区二区在线| 亚洲最新视频在线观看| 精品一区二区三区香蕉蜜桃| 欧美日韩国产影片| 亚洲少妇最新在线视频| 成人一区二区视频| 精品国产亚洲一区二区三区在线观看| 亚洲高清免费一级二级三级| 91亚洲资源网| 亚洲欧洲精品天堂一级| 在线视频综合导航| 欧美经典一区二区| 国产激情一区二区三区四区| 久久精品视频一区二区三区| 国产精品一区二区黑丝| 国产女同性恋一区二区| 国产成人精品一区二区三区四区| 久久精品视频一区二区三区| 国产成人av自拍| 国产精品欧美一区二区三区| 成人av在线一区二区| 亚洲天堂2014| 欧美在线免费视屏| 日韩和欧美一区二区| 91精品国产高清一区二区三区 | 久久精品夜夜夜夜久久| 国产成人丝袜美腿| 国产精品传媒入口麻豆| 91在线视频播放地址| 亚洲丶国产丶欧美一区二区三区| 欧美日韩在线观看一区二区 | 91亚洲精品久久久蜜桃| 亚洲主播在线观看| 欧美二区乱c少妇| 韩国成人在线视频| 国产精品的网站| 欧美午夜精品一区二区蜜桃| 日韩av一区二区三区四区| 久久夜色精品国产噜噜av| 风间由美一区二区av101| 亚洲毛片av在线| 7777精品伊人久久久大香线蕉 | 亚洲福利视频一区二区| 7777精品伊人久久久大香线蕉完整版 | 91丨九色丨蝌蚪丨老版| 一区二区三区精品| 日韩欧美国产高清| 成人免费观看视频| 亚洲欧美精品午睡沙发| 欧美一区二区三区免费大片| 国产成人免费视频网站| 一区二区三区不卡在线观看| 日韩美女一区二区三区四区| 国产成人精品www牛牛影视| 亚洲人成精品久久久久| 亚洲一区二区av在线| 欧美一级日韩免费不卡| 粉嫩欧美一区二区三区高清影视 | 99久久99久久精品免费看蜜桃| 亚洲va欧美va人人爽| 久久精品亚洲精品国产欧美kt∨ | 久久九九久久九九| 在线一区二区视频| 九九在线精品视频| 一区二区高清视频在线观看| 久久综合色8888| 欧美性猛交xxxx黑人交| 国产精品亚洲视频| 亚洲国产精品嫩草影院| 中文字幕国产一区二区| 欧美一区二区三区视频在线 | 中文字幕欧美一区| 欧美电影精品一区二区| 在线精品视频一区二区| 国产美女精品一区二区三区| 午夜精品免费在线| 亚洲欧洲精品一区二区精品久久久| 日韩欧美国产系列| 欧美三区免费完整视频在线观看| 国产成人无遮挡在线视频| 美女在线观看视频一区二区| 亚洲夂夂婷婷色拍ww47| 亚洲国产精品国自产拍av| 欧美一区二区三区男人的天堂 | 亚洲愉拍自拍另类高清精品| 国产欧美日韩一区二区三区在线观看| 欧美久久高跟鞋激| 色94色欧美sute亚洲线路一久| 国产福利一区二区三区| 男男视频亚洲欧美| 亚洲成av人片| 一区二区三区日韩精品| 国产精品久久久久久久久久免费看| 欧美大度的电影原声| 欧美日韩激情一区| 欧洲av在线精品| 91麻豆精品在线观看| 国产成人亚洲精品狼色在线| 久久草av在线| 美腿丝袜亚洲色图| 石原莉奈在线亚洲二区| 亚洲一区二区视频在线观看| 亚洲欧美激情插 | 精品一区二区在线免费观看| 日本亚洲三级在线| 日韩精品一级中文字幕精品视频免费观看 | 国产精品久久久久久妇女6080| 精品不卡在线视频| 精品国产免费人成电影在线观看四季|