上传用户:zhpu1995
上传日期:2013-09-06
资源大小:61151k
文件大小:18k
源码类别:

企业管理

开发平台:

Visual Basic

  1. VERSION 5.00
  2. Begin VB.Form Gy_MaterialQuery 
  3.    BorderStyle     =   3  'Fixed Dialog
  4.    Caption         =   "物料档案查询条件"
  5.    ClientHeight    =   3525
  6.    ClientLeft      =   45
  7.    ClientTop       =   330
  8.    ClientWidth     =   4125
  9.    Icon            =   "公用_物料档案查询.frx":0000
  10.    KeyPreview      =   -1  'True
  11.    LinkTopic       =   "Form1"
  12.    MaxButton       =   0   'False
  13.    MinButton       =   0   'False
  14.    ScaleHeight     =   3525
  15.    ScaleWidth      =   4125
  16.    ShowInTaskbar   =   0   'False
  17.    StartUpPosition =   1  '所有者中心
  18.    Begin VB.Frame Frame1 
  19.       Height          =   3045
  20.       Left            =   45
  21.       TabIndex        =   12
  22.       Top             =   0
  23.       Width           =   4020
  24.       Begin VB.ComboBox Lrcomb 
  25.          Height          =   300
  26.          Index           =   1
  27.          ItemData        =   "公用_物料档案查询.frx":1042
  28.          Left            =   975
  29.          List            =   "公用_物料档案查询.frx":1052
  30.          Style           =   2  'Dropdown List
  31.          TabIndex        =   7
  32.          Top             =   2610
  33.          Width           =   2910
  34.       End
  35.       Begin VB.TextBox lrtext 
  36.          Height          =   300
  37.          Index           =   5
  38.          Left            =   975
  39.          TabIndex        =   5
  40.          Top             =   1905
  41.          Width           =   2610
  42.       End
  43.       Begin VB.TextBox lrtext 
  44.          Height          =   300
  45.          Index           =   2
  46.          Left            =   975
  47.          TabIndex        =   2
  48.          Top             =   870
  49.          Width           =   2910
  50.       End
  51.       Begin VB.TextBox lrtext 
  52.          Height          =   300
  53.          Index           =   1
  54.          Left            =   975
  55.          TabIndex        =   1
  56.          Top             =   525
  57.          Width           =   2910
  58.       End
  59.       Begin VB.TextBox lrtext 
  60.          Height          =   300
  61.          Index           =   0
  62.          Left            =   975
  63.          TabIndex        =   0
  64.          Top             =   180
  65.          Width           =   2910
  66.       End
  67.       Begin VB.ComboBox Lrcomb 
  68.          Height          =   300
  69.          Index           =   0
  70.          ItemData        =   "公用_物料档案查询.frx":1061
  71.          Left            =   975
  72.          List            =   "公用_物料档案查询.frx":106E
  73.          Style           =   2  'Dropdown List
  74.          TabIndex        =   6
  75.          Top             =   2250
  76.          Width           =   2910
  77.       End
  78.       Begin VB.TextBox lrtext 
  79.          Height          =   300
  80.          Index           =   3
  81.          Left            =   975
  82.          TabIndex        =   3
  83.          Top             =   1215
  84.          Width           =   2610
  85.       End
  86.       Begin VB.TextBox lrtext 
  87.          Height          =   300
  88.          Index           =   4
  89.          Left            =   975
  90.          TabIndex        =   4
  91.          Top             =   1560
  92.          Width           =   2610
  93.       End
  94.       Begin VB.CommandButton ydcommand1 
  95.          Height          =   300
  96.          Index           =   3
  97.          Left            =   3570
  98.          Picture         =   "公用_物料档案查询.frx":107C
  99.          Style           =   1  'Graphical
  100.          TabIndex        =   13
  101.          Top             =   1215
  102.          Width           =   300
  103.       End
  104.       Begin VB.CommandButton ydcommand1 
  105.          Height          =   300
  106.          Index           =   4
  107.          Left            =   3570
  108.          Picture         =   "公用_物料档案查询.frx":1406
  109.          Style           =   1  'Graphical
  110.          TabIndex        =   14
  111.          Top             =   1560
  112.          Width           =   300
  113.       End
  114.       Begin VB.CommandButton ydcommand1 
  115.          Height          =   300
  116.          Index           =   5
  117.          Left            =   3570
  118.          Picture         =   "公用_物料档案查询.frx":1790
  119.          Style           =   1  'Graphical
  120.          TabIndex        =   15
  121.          Top             =   1905
  122.          Width           =   300
  123.       End
  124.       Begin VB.Label Label1 
  125.          AutoSize        =   -1  'True
  126.          Caption         =   "ABC分类:"
  127.          Height          =   180
  128.          Index           =   9
  129.          Left            =   120
  130.          TabIndex        =   23
  131.          Top             =   2700
  132.          Width           =   720
  133.       End
  134.       Begin VB.Label Label1 
  135.          AutoSize        =   -1  'True
  136.          Caption         =   "所属仓库:"
  137.          Height          =   180
  138.          Index           =   8
  139.          Left            =   120
  140.          TabIndex        =   22
  141.          Top             =   1995
  142.          Width           =   810
  143.       End
  144.       Begin VB.Label Label1 
  145.          AutoSize        =   -1  'True
  146.          Caption         =   "采购分类:"
  147.          Height          =   180
  148.          Index           =   2
  149.          Left            =   120
  150.          TabIndex        =   21
  151.          Top             =   1305
  152.          Width           =   810
  153.       End
  154.       Begin VB.Label Label1 
  155.          AutoSize        =   -1  'True
  156.          Caption         =   "物料名称:"
  157.          Height          =   180
  158.          Index           =   0
  159.          Left            =   120
  160.          TabIndex        =   20
  161.          Top             =   615
  162.          Width           =   810
  163.       End
  164.       Begin VB.Label Label1 
  165.          AutoSize        =   -1  'True
  166.          Caption         =   "规格型号:"
  167.          Height          =   180
  168.          Index           =   1
  169.          Left            =   120
  170.          TabIndex        =   19
  171.          Top             =   960
  172.          Width           =   810
  173.       End
  174.       Begin VB.Label Label1 
  175.          AutoSize        =   -1  'True
  176.          Caption         =   "物料编码:"
  177.          Height          =   180
  178.          Index           =   6
  179.          Left            =   120
  180.          TabIndex        =   18
  181.          Top             =   270
  182.          Width           =   810
  183.       End
  184.       Begin VB.Label Label1 
  185.          AutoSize        =   -1  'True
  186.          Caption         =   "库存分类:"
  187.          Height          =   180
  188.          Index           =   7
  189.          Left            =   120
  190.          TabIndex        =   17
  191.          Top             =   1650
  192.          Width           =   810
  193.       End
  194.       Begin VB.Label Label2 
  195.          AutoSize        =   -1  'True
  196.          Caption         =   "停用标志:"
  197.          Height          =   180
  198.          Left            =   120
  199.          TabIndex        =   16
  200.          Top             =   2340
  201.          Width           =   810
  202.       End
  203.    End
  204.    Begin VB.CommandButton Cmd_Clear 
  205.       Caption         =   "全清"
  206.       Height          =   300
  207.       Left            =   45
  208.       TabIndex        =   10
  209.       Top             =   3165
  210.       Width           =   1120
  211.    End
  212.    Begin VB.CommandButton QxCommand 
  213.       Caption         =   "取消(&C)"
  214.       Height          =   300
  215.       Left            =   2970
  216.       TabIndex        =   9
  217.       Top             =   3165
  218.       Width           =   1120
  219.    End
  220.    Begin VB.CommandButton QdCommand 
  221.       Caption         =   "确定(&O)"
  222.       Height          =   300
  223.       Left            =   1770
  224.       TabIndex        =   8
  225.       Top             =   3165
  226.       Width           =   1120
  227.    End
  228.    Begin VB.CheckBox UnloadCheck 
  229.       Caption         =   "卸载窗体"
  230.       Height          =   615
  231.       Left            =   5160
  232.       TabIndex        =   11
  233.       Top             =   1110
  234.       Visible         =   0   'False
  235.       Width           =   825
  236.    End
  237. End
  238. Attribute VB_Name = "Gy_MaterialQuery"
  239. Attribute VB_GlobalNameSpace = False
  240. Attribute VB_Creatable = False
  241. Attribute VB_PredeclaredId = True
  242. Attribute VB_Exposed = False
  243. '******************************************************************
  244. '*    模 块 名 称 :物料档案查询条件
  245. '*    功 能 描 述 :
  246. '*    程序员姓名  :徐强
  247. '*    最后修改人  :徐强
  248. '*    最后修改时间:2001/09/20
  249. '*    备        注:程序中所有依实际情况自定义部分均用[>>  <<]括起
  250. '******************************************************************
  251. Dim Tsxx As String                       '系统信息提示
  252. '以下为固定使用变量(文本框)
  253. Dim Textvar() As Variant                 '存储变体型文本框信息
  254. Dim Textboolean() As Boolean             '存储布尔型文本框信息
  255. Dim Textint() As Integer                 '存储整型文本框信息
  256. Dim Textstr() As String                  '存储字符型文本框信息
  257. Dim Max_Text_Index As Integer            '最大录入文本框索引值
  258. Dim TextGroupCode As String              '文本框录入分组编码
  259. Dim TextValiLock As Boolean              '文本框失去焦点是否进行有效性控制判断
  260. Dim TextValiJudgeLock() As Boolean       '文本框录入有效性判断控制锁
  261. Dim CurTextIndex As Integer              '当前文本框索引值
  262. Dim TextChangeLock As Boolean            '文本框内容变换控制锁
  263. Dim Bln_Cancel As Boolean                '取消按钮信息传递
  264. Private Sub Form_KeyPress(KeyAscii As Integer)   '控 制 焦 点 转 移(Fixed)
  265.     Dim jdzygs As Integer                         '控件焦点转移个数
  266.     jdzygs = 10
  267.     Select Case KeyAscii
  268.         Case vbKeyReturn
  269.             If Kjjdzy(jdzygs) Then
  270.                 KeyAscii = 0
  271.             End If
  272.         Case 39           '屏蔽"'"
  273.             KeyAscii = 0
  274.     End Select
  275. End Sub
  276. Private Sub Form_Load()
  277.    
  278.     '以下为文本框处理程序(Fixed)
  279.     TextGroupCode = "Gy_MaterialQuery"
  280.     Call Drwbkxx(TextGroupCode, Textvar(), Textboolean(), Textint(), Textstr())  '读入文本框录入信息
  281.     Call Wbkcsh
  282.    
  283.     '[>>初始化查询条件默认值
  284.     '<<]
  285.    
  286. End Sub
  287. Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)          '查询条件窗体卸载
  288.     '查询条件窗体卸载时判断是否因为结果窗体卸载,如是则卸载,否则隐藏
  289.     If UnloadCheck.Value <> 1 Then
  290.         Cancel = 1
  291.         Me.Hide
  292.     End If
  293.     
  294. End Sub
  295. Private Sub QdCommand_Click()                                   '确 定
  296.     '录入条件有效性判断(Fixed)
  297.     If Not Lrtjyxxpd Then
  298.         Exit Sub
  299.     End If
  300.     Me.Hide
  301.         
  302.     '[>>激活查询过程结果窗体
  303.     
  304.     Gy_Material.Timer1.Enabled = True
  305.     Gy_Material.SetFocus
  306.     
  307.     '<<]
  308. End Sub
  309. Private Sub QxCommand_Click()                                    '取消(Fixed)
  310.     Me.Hide
  311. End Sub
  312. Private Function Lrtjyxxpd() As Boolean                          '用户录入条件有效性判断
  313.     Dim jsqte As Integer
  314.     Lrtjyxxpd = False
  315.  
  316.     '对需要进行事后判断的文本框录入内容进行有效性判断 (Fixed)
  317.     For jsqte = 0 To Max_Text_Index
  318.         If Textint(jsqte, 9) = 0 Or Textint(jsqte, 9) = 2 Then
  319.             If Not TextYxxpd(jsqte) Then
  320.                 Exit Function
  321.             End If
  322.         End If
  323.     Next jsqte
  324.    
  325.     '[>>以下为依据实际情况自定义部分
  326.  
  327.     '查询日期范围应由小到大
  328.   
  329.     '<<]以上为依据实际情况自定义部分
  330.  
  331.     Lrtjyxxpd = True
  332. End Function
  333. Private Sub Cmd_Clear_MouseDown(Button As Integer, Shift As Integer, x As Single, y As Single)    '将用户输入条件全部清除(可选)
  334.     '清除文本框(Fixed)
  335.     For jsqte = 0 To Max_Text_Index
  336.         LrText(jsqte).Tag = ""
  337.         LrText(jsqte).Text = ""
  338.     Next jsqte
  339.   
  340.     '[>>
  341.     '此处可以写入其他清除条件程序
  342.     Lrcomb(0).ListIndex = 0
  343.     Lrcomb(1).ListIndex = 0
  344.     '<<]
  345.   
  346. End Sub
  347. '*************以下为文本框录入处理程序(固定不变部分)*************'
  348. Private Sub Wbklrwbcl(Index As Integer)    '文本框录入事后处理程序
  349.   
  350.     '以下为依据实际情况自定义部分[
  351.     '在此填写文本框录入事后处理程序
  352.     ']以上为依据实际情况自定义部分
  353.   
  354. End Sub
  355. Private Sub LrText_Change(Index As Integer)
  356.    
  357.     '屏蔽程序改变控制
  358.     If TextChangeLock Then
  359.         Exit Sub
  360.     End If
  361.     
  362.     TextValiJudgeLock(Index) = False    '打开有效性判断锁
  363.     
  364.     '限制字段录入长度
  365.           
  366.     TextChangeLock = True  '加锁(防止执行Lrtext_Change)
  367.     Call TextChangeLimit(LrText(Index), Textint(Index, 1))  '去掉无效字符
  368.     Select Case Textint(Index, 1)
  369.         Case 8, 11      '金额型
  370.             Call Sjgskz(LrText(Index), Xtjezws - Xtjexsws - 1, Xtjexsws)
  371.         Case 9, 12      '数量型
  372.             Call Sjgskz(LrText(Index), Xtslzws - Xtslxsws - 1, Xtslxsws)
  373.         Case 10          '单价型
  374.             Call Sjgskz(LrText(Index), Xtdjzws - Xtdjxsws - 1, Xtdjxsws)
  375.         Case Else        '其他小数类型控制
  376.             If Textint(Index, 6) <> 0 Or Textint(Index, 7) <> 0 Then
  377.                 Call Sjgskz(LrText(Index), Textint(Index, 6), Textint(Index, 7))
  378.             End If
  379.     End Select
  380.         
  381.     TextChangeLock = False '解锁
  382. End Sub
  383. Private Sub LrText_GotFocus(Index As Integer)                                                 '文本框得到焦点,显示相应信息
  384.     Call TextShow(Index)
  385.     CurTextIndex = Index
  386.     LrText(Index).SelStart = Len(LrText(Index))
  387. End Sub
  388. Private Sub LrText_KeyDown(Index As Integer, KeyCode As Integer, Shift As Integer)            '字段按F2键提供帮助
  389.     
  390.     Select Case KeyCode
  391.         Case vbKeyF2
  392.             Call Text_Help(Index)
  393.     End Select
  394. End Sub
  395. Private Sub LrText_KeyPress(Index As Integer, KeyAscii As Integer)                            '文本框录入事中控制
  396.     Call InputFieldLimit(LrText(Index), Textint(Index, 1), KeyAscii)
  397. End Sub
  398. Private Sub LrText_LostFocus(Index As Integer)                                                '文本框失去焦点
  399.     '显示相应信息但不能进行有效性判断
  400.   
  401. End Sub
  402. Private Sub Ydcommand1_MouseDown(Index As Integer, Button As Integer, Shift As Integer, x As Single, y As Single)     '按钮提供帮助
  403.     Call Text_Help(Index)
  404. End Sub
  405. Private Sub Text_Help(Index As Integer)                                                       '录入字段帮助
  406.     If Not Textboolean(Index, 1) Then
  407.         Exit Sub
  408.     End If
  409.      
  410.     '调用帮助
  411.     If Textint(Index, 2) <> 1 Then
  412.         strHlpR = FunHlpR(Trim(Textstr(Index, 4)), "whcode", Trim(LrText(0).Tag))
  413.     End If
  414.     Call Drbmhelp(Textint(Index, 2), Textstr(Index, 4), Trim(LrText(Index).Text))
  415.   
  416.     '根据设置选择显示编码和名称,并进行存储
  417.     If Len(Xtfhcs) <> 0 Then
  418.         If Textint(Index, 3) = 1 Then
  419.             LrText(Index).Text = Xtfhcsfz
  420.             LrText(Index).Tag = Xtfhcs
  421.         Else
  422.             LrText(Index).Text = Xtfhcs
  423.             LrText(Index).Tag = Xtfhcsfz
  424.         End If
  425.     End If
  426.    
  427.     LrText(Index).SetFocus
  428. End Sub
  429. Private Sub TextShow(Index As Integer)        '文本框得到焦点,显示相应信息
  430.     '填写文本框得到焦点,进行相应信息处理程序
  431.    
  432. End Sub
  433. Private Sub Wbkcsh()                          '录入文本框初始化
  434.     
  435.     Dim jsqte As Integer
  436.   
  437.     '最大录入文本框索引值
  438.     Max_Text_Index = Textvar(1)
  439.   
  440.     ReDim TextValiJudgeLock(Max_Text_Index)
  441.     For jsqte = 0 To Max_Text_Index
  442.         If Len(Trim(Textstr(jsqte, 1))) <> 0 Then
  443.             If Textboolean(jsqte, 1) Then
  444.                 If jsqte <> 0 And Not Textboolean(jsqte, 3) Then
  445.                     Load Ydcommand1(jsqte)
  446.                 End If
  447.                 Ydcommand1(jsqte).Visible = True
  448.                 Ydcommand1(jsqte).Move LrText(jsqte).Left + LrText(jsqte).Width, LrText(jsqte).Top
  449.             End If
  450.             TextChangeLock = True
  451.             LrText(jsqte).Text = ""
  452.             LrText(jsqte).Tag = ""
  453.             If Textint(jsqte, 5) <> 0 Then
  454.                 LrText(jsqte).MaxLength = Textint(jsqte, 5)
  455.             End If
  456.             TextChangeLock = False
  457.         End If
  458.         TextValiJudgeLock(jsqte) = True
  459.     Next jsqte
  460. End Sub
  461. Private Function TextYxxpd(Index As Integer) As Boolean           '文本框有效性判断
  462.     
  463.     Dim Sqlstr As String
  464.     Dim Findrec As ADODB.Recordset
  465.   
  466.     '文本框内容未曾改变不进行有效性判断
  467.     If TextValiJudgeLock(Index) Then
  468.         TextYxxpd = True
  469.         Exit Function
  470.     End If
  471.   
  472.     '文本框内容为空认为有效,并清空其Tag值
  473.     If Trim(LrText(Index)) = "" Then
  474.         LrText(Index).Tag = ""
  475.         Call Wbklrwbcl(Index)
  476.         TextValiJudgeLock(Index) = True
  477.         TextYxxpd = True
  478.         Exit Function
  479.     End If
  480.   
  481.     '可在此加入不做有效性判断的理由
  482.   
  483.     Select Case Textint(Index, 4)
  484.         Case 1      '编码型
  485.             Sqlstr = Trim(Textstr(Index, 5))
  486.             Sqlstr = Replace(Sqlstr, "@", "'" + Trim(LrText(Index).Text) + "'")
  487.             Set Findrec = Cw_DataEnvi.DataConnect.Execute(Sqlstr)
  488.             If Findrec.EOF Then
  489.                 Call Xtxxts(Trim(Textstr(Index, 6)), 0, 1)
  490.                 LrText(Index).SetFocus
  491.                 Exit Function
  492.             Else
  493.                 Select Case Textint(Index, 3)
  494.                     Case 0
  495.                         If Len(Trim(Textstr(Index, 2))) <> 0 Then
  496.                             LrText(Index).Text = Trim(Findrec.Fields(Trim(Textstr(Index, 2))))
  497.                         End If
  498.                         If Len(Trim(Textstr(Index, 3) & "")) <> 0 Then
  499.                             LrText(Index).Tag = Trim(Findrec.Fields(Trim(Textstr(Index, 3))))
  500.                         End If
  501.                     Case 1
  502.                         If Len(Trim(Textstr(Index, 3) & "")) <> 0 Then
  503.                             LrText(Index).Text = Trim(Findrec.Fields(Trim(Textstr(Index, 3))))
  504.                         End If
  505.                         If Len(Trim(Textstr(Index, 2))) <> 0 Then
  506.                             LrText(Index).Tag = Trim(Findrec.Fields(Trim(Textstr(Index, 2))))
  507.                         End If
  508.                 End Select
  509.             End If
  510.         Case 2      '日期型
  511.             If IsDate(LrText(Index).Text) Then
  512.                 LrText(Index).Text = Format(LrText(Index).Text, "yyyy-mm-dd")
  513.                 If Val(Mid(LrText(Index), 1, 4)) < 1900 Then
  514.                     LrText(Index).Text = "1900" + Mid(LrText(Index), 5, 6)
  515.                 End If
  516.             Else
  517.                 Tsxx = "非法公历日期!(格式:" + Format(Date, "yyyy-mm-dd") + ")"
  518.                 Call Xtxxts(Tsxx, 0, 1)
  519.                 LrText(Index).SetFocus
  520.                 Exit Function
  521.             End If
  522.         Case 3      '其他类型
  523.     End Select
  524.     
  525.     '如果有效则加锁,用户不改变内容则不再进行有效性判断
  526.     TextValiJudgeLock(Index) = True
  527.     '调用文本框事后处理程序
  528.     Call Wbklrwbcl(Index)
  529.    
  530.     '有效性判断通过则返回True
  531.     TextYxxpd = True
  532.    
  533. End Function