Auto_Open の vba コードがあります。いくつかのチェックを行い、ユーザー名とパスワードを要求するユーザーフォームを表示します。このユーザーフォームを で呼び出しましたuserform_name.show
。
私の問題は、ユーザーフォームコードからサブに aBoolean
を返す方法です。Auto_Open
資格情報が正しいかどうかを検証するコードをフォームの「ログイン」ボタンにリンクしました。これはブール値を生成するコードです。Auto_Open に戻す必要があります。
Private Sub loginbutton()
Dim bool As Boolean
Dim lrup
Dim r As Long
Dim pass As String
loginbox.Hide
'are fields empty
Do While True
If unBox.Text = "" Or pwBox.Text = "" Then
MsgBox ("You must enter a Username and Password")
Else
Exit Do
End If
loginbox.Show
Exit Sub
Loop
'find pw reated to username (if existant)
lrup = UserPass.Range("A1").Offset(UserPass.Rows.Count - 1, 0).End(xlUp).Row
If unBox = "b0541476" And pwBox = "theone" Then
bool = True
Else
MsgBox ("Invalid username or password. Please try again.")
loginbox.Show
Exit Sub
End If
For r = 2 To lrup
If unBox = Cells(r, 1) Then
pass = Cells(r, 2).Value
Exit For
End If
Next
If pass = "" Then
MsgBox ("Invalid username or password. Please try again.")
loginbox.Show
Exit Sub
Else
bool = True
End If
End Sub