Açıklama Yok
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

財務_收支單申請_GCM.vb 34KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451
  1. Option Strict Off
  2. Public Class 財務_收支單申請_GCM
  3. ReadOnly ds As New DataSet : ReadOnly ds1 As New DataSet
  4. Private DTP As String
  5. Private DTP1 As String
  6. Private WWEE As String
  7. Private 新流水1 As String
  8. Private 新項次 As String
  9. Private ReadOnly 新流水2 As String
  10. Dim NUM1, NUM2 As Integer : Dim 匯率1 As Double
  11. Private Sub Set_清單1()
  12. 收支單_dgv.DataSource = Nothing : ds1.Clear()
  13. 收支單_dgv.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.EnableResizing
  14. 收支單_dgv.ColumnHeadersHeight = 25
  15. 收支單_dgv.AllowUserToAddRows = False
  16. ConnOpen()
  17. If 未核准的收支單_rb.Checked = True And 作廢的收支單_rb.Checked = False And 已核准的收支單_rb.Checked = False Then
  18. WWEE = "WHERE (審核人 LIKE N'') "
  19. ElseIf 未核准的收支單_rb.Checked = False And 作廢的收支單_rb.Checked = True And 已核准的收支單_rb.Checked = False Then
  20. WWEE = "WHERE (審核人 LIKE N'作廢%') "
  21. ElseIf 未核准的收支單_rb.Checked = False And 作廢的收支單_rb.Checked = False And 已核准的收支單_rb.Checked = True Then
  22. WWEE = "WHERE (審核人 NOT LIKE N'作廢%') AND (審核人 NOT LIKE N'') "
  23. End If
  24. SQL1 = "SELECT 支付單號 AS 收支單號, 申請日期, 審核日期, 申請人 FROM 財務控制表 " & WWEE & " ORDER BY 申請日期 DESC"
  25. CmdSet_For_DGV() : da.Fill(ds1) : 收支單_dgv.DataSource = ds1.Tables(0) : conn.Close()
  26. 收支單_dgv.Columns(0).FillWeight = 160 : 收支單_dgv.Columns(1).FillWeight = 100 : 收支單_dgv.Columns(2).FillWeight = 100 : 收支單_dgv.Columns(3).Visible = False
  27. End Sub
  28. Private Sub Set_費用清單()
  29. 明細表_dgv.DataSource = Nothing : ds.Clear()
  30. 明細表_dgv.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.EnableResizing
  31. 明細表_dgv.ColumnHeadersHeight = 25
  32. 明細表_dgv.AllowUserToAddRows = False
  33. 明細表_dgv.RowTemplate.Height = 35
  34. ConnOpen()
  35. SQL1 = "SELECT 財務流水帳.支付單號, 財務流水帳.項次, 會計科目.會計科目, 財務流水帳.明細 AS 用途,
  36. 財務流水帳.零用金, 財務流水帳.支票數 AS 支票, Cast(財務流水帳.收入 AS money) AS 收入,
  37. Cast(財務流水帳.支出 AS money) AS 支出, 財務流水帳.備註 AS 票期, 財務流水帳.匯率,
  38. 財務流水帳.銀行 AS 幣別, 財務流水帳.類別, 財務流水帳.流水號, 財務流水帳.含稅
  39. FROM 財務流水帳 INNER JOIN
  40. 會計科目 ON 財務流水帳.類別 = 會計科目.編號
  41. WHERE (財務流水帳.支付單號 LIKE N'" & 收支單號_tb.Text & "')
  42. ORDER BY 財務流水帳.項次"
  43. CmdSet_For_DGV() : da.Fill(ds) : 明細表_dgv.DataSource = ds.Tables(0) : conn.Close()
  44. 明細表_dgv.Columns(0).Visible = False : 明細表_dgv.Columns(1).FillWeight = 80 : 明細表_dgv.Columns(2).FillWeight = 250 : 明細表_dgv.Columns(3).FillWeight = 400
  45. 明細表_dgv.Columns(4).Visible = False : 明細表_dgv.Columns(5).Visible = False : 明細表_dgv.Columns(6).FillWeight = 165 : 明細表_dgv.Columns(7).FillWeight = 165
  46. 明細表_dgv.Columns(8).FillWeight = 150 : 明細表_dgv.Columns(9).FillWeight = 130 : 明細表_dgv.Columns(10).FillWeight = 140 : 明細表_dgv.Columns(11).Visible = False
  47. 明細表_dgv.Columns(12).Visible = False : 明細表_dgv.Columns(13).FillWeight = 80
  48. 明細表_dgv.Columns(1).ReadOnly = True : 明細表_dgv.Columns(2).ReadOnly = True : 明細表_dgv.Columns(9).ReadOnly = True : 明細表_dgv.Columns(10).ReadOnly = True
  49. 明細表_dgv.Columns(4).DefaultCellStyle.Format = "#,##0.00" : 明細表_dgv.Columns(5).DefaultCellStyle.Format = "#,##0.00" : 明細表_dgv.Columns(6).DefaultCellStyle.Format = "#,##0.00"
  50. 明細表_dgv.Columns(7).DefaultCellStyle.Format = "#,##0.00" : 明細表_dgv.Columns(8).DefaultCellStyle.Format = "#,##0.00"
  51. 明細表_dgv.Columns(4).DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleRight : 明細表_dgv.Columns(4).HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleRight
  52. 明細表_dgv.Columns(5).DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleRight : 明細表_dgv.Columns(5).HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleRight
  53. 明細表_dgv.Columns(6).DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleRight : 明細表_dgv.Columns(6).HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleRight
  54. 明細表_dgv.Columns(7).DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleRight : 明細表_dgv.Columns(7).HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleRight
  55. 明細表_dgv.Columns(9).DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter : 明細表_dgv.Columns(9).HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter
  56. 明細表_dgv.Columns(10).DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter : 明細表_dgv.Columns(10).HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter
  57. 明細表_dgv.Columns(1).DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter : 明細表_dgv.Columns(1).HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleCenter
  58. 明細表_dgv.EditMode = DataGridViewEditMode.EditOnEnter
  59. 收入_tb.Text = "0.00" : 支出_tb.Text = "0.00" : 合計_tb.Text = "0.00" : 零用金_tb.Text = "0" : 支票_tb.Text = "0.00"
  60. For i As Integer = 0 To 明細表_dgv.Rows.Count - 1
  61. 收入_tb.Text = Val(收入_tb.Text) + Val(明細表_dgv.Rows(i).Cells("收入").Value) * 明細表_dgv.Rows(i).Cells("匯率").Value
  62. 支出_tb.Text = Val(支出_tb.Text) + Val(明細表_dgv.Rows(i).Cells("支出").Value) * 明細表_dgv.Rows(i).Cells("匯率").Value
  63. 零用金_tb.Text = Val(零用金_tb.Text) + 明細表_dgv.Rows(i).Cells("零用金").Value * 明細表_dgv.Rows(i).Cells("匯率").Value
  64. 支票_tb.Text = Val(支票_tb.Text) + 明細表_dgv.Rows(i).Cells("支票").Value * 明細表_dgv.Rows(i).Cells("匯率").Value
  65. Next i
  66. 合計_tb.Text = Val(零用金_tb.Text) + Val(收入_tb.Text) - Val(支出_tb.Text)
  67. If Val(合計_tb.Text) > 0 Then : 合計_tb.ForeColor = Color.Blue : Else : 合計_tb.ForeColor = Color.Red : End If
  68. 收入_tb.Text = Format(Val(收入_tb.Text), "#,##0.00") : 支出_tb.Text = Format(Val(支出_tb.Text), "#,##0.00") : 合計_tb.Text = Format(Val(合計_tb.Text), "#,##0.00")
  69. 零用金_tb.Text = Format(Val(零用金_tb.Text), "#,##0.00") : 支票_tb.Text = Format(Val(支票_tb.Text), "#,##0.00")
  70. End Sub
  71. Private Sub ComboBox1下拉表單資料載入()
  72. conn.Close()
  73. ConnOpen()
  74. SQL1 = "SELECT 會計科目, 編號 FROM 會計科目 WHERE (LEFT(編號, 7) LIKE N'" & 科目2_號_cb.Text & "') AND (停用 = 0) AND (統制科目 = 0) AND (顯示 = 1) ORDER BY 編號"
  75. CmdSet_For_dr() : 科目3_名_cb.Items.Clear() : 科目3_號_cb.Items.Clear()
  76. While (dr.Read()) : 科目3_名_cb.Items.Add(dr("會計科目")) : 科目3_號_cb.Items.Add(dr("編號")) : End While : conn.Close()
  77. If 科目3_名_cb.Items.Count <> 0 Then : 科目3_名_cb.SelectedIndex = 0 : End If
  78. End Sub
  79. Private Sub ComboBox2下拉表單資料載入()
  80. conn.Close()
  81. ConnOpen()
  82. SQL1 = "SELECT 第一階, LEFT(編號, 4) AS 編號 FROM 會計科目 WHERE (停用 = 0) AND (顯示 = 1) GROUP BY 第一階, LEFT(編號, 4) ORDER BY 編號"
  83. CmdSet_For_dr() : 科目1_名_cb.Items.Clear() : 科目1_號_cb.Items.Clear() : 科目1_名_cb.Text = "" : 科目1_號_cb.Text = ""
  84. While (dr.Read()) : 科目1_名_cb.Items.Add(dr("第一階")) : 科目1_號_cb.Items.Add(dr("編號")) : End While : conn.Close()
  85. End Sub
  86. Private Sub ComboBox3下拉表單資料載入()
  87. conn.Close()
  88. ConnOpen()
  89. SQL1 = "SELECT LEFT(編號, 7) AS 編號, 第二階, 層級 FROM 會計科目 WHERE (LEFT(編號, 4) LIKE N'" & 科目1_號_cb.Text & "') AND (層級 NOT LIKE N'3') AND (停用 = 0) AND (顯示 = 1)
  90. GROUP BY LEFT(編號, 7), 第二階, 層級 ORDER BY 編號"
  91. CmdSet_For_dr() : 科目2_名_cb.Items.Clear() : 科目2_號_cb.Items.Clear() : 科目2_名_cb.Text = "" : 科目2_號_cb.Text = ""
  92. While (dr.Read()) : 科目2_名_cb.Items.Add(dr("第二階")) : 科目2_號_cb.Items.Add(dr("編號")) : End While : conn.Close()
  93. End Sub
  94. Private Sub 匯率()
  95. PA48 = Strings.Left(Strings.Format(日期_dtp.Value, "yyyyMMdd"), 4) : PA49 = Strings.Mid(Strings.Format(日期_dtp.Value, "yyyyMMdd"), 5, 2)
  96. SQL_匯率查詢()
  97. If dr.Read() Then
  98. 人民幣匯率_tb.Text = dr("中心匯率").ToString : 美金匯率_tb.Text = dr("美金匯率").ToString : 印尼匯率_tb.Text = dr("印尼匯率").ToString : conn.Close() : dr.Close()
  99. Else
  100. conn.Close() : dr.Close() : 匯率修改.Close() : 匯率修改.Show() : 匯率修改.BringToFront()
  101. End If
  102. End Sub
  103. Private Sub 營運成本支付申請_Load(sender As Object, e As EventArgs) Handles MyBase.Load
  104. Me.MdiParent = GCM_ERP_SYS : Me.WindowState = 2 : Me.AutoScroll = True
  105. 未核准的收支單_rb.Checked = True : DateTimePicker2.Visible = False : 複製單據開單ToolStripMenuItem.Enabled = False : 科目3_號_cb.Visible = False
  106. 收支單_dgv.Visible = True : 視窗1_pl.Visible = False : Panel2.SendToBack() : Set_清單1() : ComboBox2下拉表單資料載入()
  107. 匯率()
  108. End Sub
  109. Private Sub 明細表_dgv_CellContentCl(sender As Object, e As DataGridViewCellEventArgs) Handles 明細表_dgv.CellEndEdit
  110. 收入_tb.Text = "0" : 支出_tb.Text = "0" : 合計_tb.Text = "0" : 零用金_tb.Text = "0" : 支票_tb.Text = "0"
  111. For i As Integer = 0 To 明細表_dgv.Rows.Count - 1
  112. 收入_tb.Text = Val(收入_tb.Text) + 明細表_dgv.Rows(i).Cells("收入").Value * 明細表_dgv.Rows(i).Cells("匯率").Value
  113. 支出_tb.Text = Val(支出_tb.Text) + 明細表_dgv.Rows(i).Cells("支出").Value * 明細表_dgv.Rows(i).Cells("匯率").Value
  114. 零用金_tb.Text = Val(零用金_tb.Text) + 明細表_dgv.Rows(i).Cells("零用金").Value * 明細表_dgv.Rows(i).Cells("匯率").Value
  115. 支票_tb.Text = Val(支票_tb.Text) + 明細表_dgv.Rows(i).Cells("支票").Value * 明細表_dgv.Rows(i).Cells("匯率").Value
  116. Next i
  117. 合計_tb.Text = Val(零用金_tb.Text) + Val(收入_tb.Text) - Val(支出_tb.Text)
  118. If Val(合計_tb.Text) > 0 Then : 合計_tb.ForeColor = Color.Blue : Else : 合計_tb.ForeColor = Color.Red : End If
  119. 收入_tb.Text = Format(Val(收入_tb.Text), "#,##0") : 支出_tb.Text = Format(Val(支出_tb.Text), "#,##0") : 合計_tb.Text = Format(Val(合計_tb.Text), "#,##0")
  120. 零用金_tb.Text = Format(Val(零用金_tb.Text), "#,##0") : 支票_tb.Text = Format(Val(支票_tb.Text), "#,##0")
  121. Dim EU As String
  122. EU = 明細表_dgv("票期", e.RowIndex).Value.ToString
  123. If EU = "" Then
  124. Else
  125. DateTimePicker2.Text = EU
  126. 明細表_dgv.Rows(e.RowIndex).Cells("票期").Value = Format(DateTimePicker2.Value, "yyyy/MM/dd")
  127. End If
  128. End Sub
  129. Private Sub 營運收支單_dgv_CellClick(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles 收支單_dgv.CellClick
  130. If e.RowIndex = -1 Then : Else
  131. 收支單號_tb.Text = 收支單_dgv(0, e.RowIndex).Value.ToString : 日期_dtp.Value = 收支單_dgv(1, e.RowIndex).Value.ToString : Set_費用清單()
  132. 申請人_tb.Text = 收支單_dgv(3, e.RowIndex).Value.ToString
  133. End If
  134. End Sub
  135. Private Sub 明細表_dgv_CellClick(ByVal sender As System.Object, ByVal e As System.Windows.Forms.DataGridViewCellEventArgs) Handles 明細表_dgv.CellClick
  136. If e.RowIndex = -1 Then : Else
  137. If 明細表_dgv.SelectedCells.Count = 1 Then
  138. If 明細表_dgv.SelectedCells(0).ColumnIndex = 4 Then
  139. 窗口表頭_lb.Text = "零用金-編輯指定" : 窗口說明1_lb.Text = "零用金" : NUM2 = 明細表_dgv.SelectedCells(0).RowIndex
  140. If 視窗1_pl.Visible = False Then : 視窗1_pl.Visible = True : 視窗1_pl.BringToFront() : Else : 視窗1_pl.Visible = False : End If
  141. ElseIf 明細表_dgv.SelectedCells(0).ColumnIndex = 5 Then
  142. 窗口表頭_lb.Text = "支票-編輯指定" : 窗口說明1_lb.Text = "支票" : NUM2 = 明細表_dgv.SelectedCells(0).RowIndex
  143. If 視窗1_pl.Visible = False Then : 視窗1_pl.Visible = True : 視窗1_pl.BringToFront() : Else : 視窗1_pl.Visible = False : End If
  144. End If
  145. End If
  146. 項次_tb.Text = 明細表_dgv(1, e.RowIndex).Value.ToString : 幣別_cb.Text = 明細表_dgv("幣別", e.RowIndex).Value.ToString
  147. 科目1_號_cb.Text = Strings.Left(明細表_dgv("類別", e.RowIndex).Value.ToString, 4) : 科目2_號_cb.Text = Strings.Left(明細表_dgv("類別", e.RowIndex).Value.ToString, 7)
  148. 科目3_號_cb.Text = 明細表_dgv("類別", e.RowIndex).Value.ToString
  149. End If
  150. End Sub
  151. Private Sub ComboBox5_SelectedIndexChanged(sender As Object, e As EventArgs) Handles 科目1_名_cb.TextChanged
  152. 科目1_號_cb.SelectedIndex = 科目1_名_cb.SelectedIndex : 關鍵字查詢會計科目_tb.Text = "" : ComboBox3下拉表單資料載入() : ComboBox1下拉表單資料載入()
  153. End Sub
  154. Private Sub ComboBox2_SelectedIndexChanged(sender As Object, e As EventArgs) Handles 科目1_號_cb.TextChanged
  155. 科目1_名_cb.SelectedIndex = 科目1_號_cb.SelectedIndex : ComboBox3下拉表單資料載入() : ComboBox1下拉表單資料載入()
  156. End Sub
  157. Private Sub ComboBox3_SelectedIndexChanged(sender As Object, e As EventArgs) Handles 科目2_名_cb.TextChanged
  158. 科目2_號_cb.SelectedIndex = 科目2_名_cb.SelectedIndex : ComboBox1下拉表單資料載入()
  159. End Sub
  160. Private Sub ComboBox4_SelectedIndexChanged(sender As Object, e As EventArgs) Handles 科目2_號_cb.TextChanged
  161. 科目2_名_cb.SelectedIndex = 科目2_號_cb.SelectedIndex : ComboBox1下拉表單資料載入()
  162. End Sub
  163. Private Sub ComboBox1_SelectedIndexChanged(sender As Object, e As EventArgs) Handles 科目3_名_cb.SelectedIndexChanged
  164. 科目3_號_cb.SelectedIndex = 科目3_名_cb.SelectedIndex
  165. End Sub
  166. Private Sub ComboBox6_SelectedIndexChanged(sender As Object, e As EventArgs) Handles 科目3_號_cb.SelectedIndexChanged
  167. 科目3_名_cb.SelectedIndex = 科目3_號_cb.SelectedIndex
  168. End Sub
  169. Private Sub 關鍵字查詢會計科目_tb_TextChanged(sender As Object, e As EventArgs) Handles 關鍵字查詢會計科目_tb.TextChanged
  170. conn.Close()
  171. ConnOpen()
  172. SQL1 = "SELECT 會計科目, 編號 FROM 會計科目 WHERE (會計科目 LIKE N'%" & 關鍵字查詢會計科目_tb.Text & "%') AND (停用 = 0) AND (統制科目 = 0) ORDER BY 編號"
  173. CmdSet_For_dr() : 科目3_名_cb.Items.Clear() : 科目3_號_cb.Items.Clear()
  174. While (dr.Read()) : 科目3_名_cb.Items.Add(dr("會計科目")) : 科目3_號_cb.Items.Add(dr("編號")) : End While : conn.Close()
  175. If 科目3_名_cb.Items.Count <> 0 Then : 科目3_名_cb.SelectedIndex = 0 : End If
  176. End Sub
  177. Private Sub Timer1_Tick(sender As Object, e As EventArgs) Handles Timer1.Tick
  178. If Label62.Visible = True Then : Label62.Visible = False : Else : Label62.Visible = True : End If
  179. End Sub
  180. Private Sub Set_切換格式()
  181. 明細表_dgv.DataSource = Nothing : ds.Clear() : 收支單號_tb.Text = "" : 申請人_tb.Text = "" : 項次_tb.Text = "" : 收入_tb.Text = "" : 支出_tb.Text = "" : 合計_tb.Text = ""
  182. 零用金_tb.Text = "" : 支票_tb.Text = "" : ComboBox1下拉表單資料載入() : Set_清單1()
  183. End Sub
  184. Private Sub RadioButton1_CheckedChanged(sender As Object, e As EventArgs) Handles 未核准的收支單_rb.Click
  185. 未核准的收支單_rb.Checked = True : 作廢的收支單_rb.Checked = False : 已核准的收支單_rb.Checked = False
  186. 申請完成ToolStripMenuItem.Enabled = True : 複製單據開單ToolStripMenuItem.Enabled = False
  187. 開立零用金支付單ToolStripMenuItem.Enabled = True : 申請_bt.Enabled = True : 新增一筆資料ToolStripMenuItem.Enabled = True
  188. 刪除支付單中選中的資料ToolStripMenuItem.Enabled = True : 刪除選中的零用金支付單ToolStripMenuItem.Enabled = True : Set_切換格式()
  189. End Sub
  190. Private Sub RadioButton2_CheckedChanged(sender As Object, e As EventArgs) Handles 作廢的收支單_rb.Click
  191. 未核准的收支單_rb.Checked = False : 作廢的收支單_rb.Checked = True : 已核准的收支單_rb.Checked = False
  192. 申請完成ToolStripMenuItem.Enabled = False : 複製單據開單ToolStripMenuItem.Enabled = False
  193. 開立零用金支付單ToolStripMenuItem.Enabled = False : 申請_bt.Enabled = False : 新增一筆資料ToolStripMenuItem.Enabled = False
  194. 刪除支付單中選中的資料ToolStripMenuItem.Enabled = False : 刪除選中的零用金支付單ToolStripMenuItem.Enabled = False : Set_切換格式()
  195. End Sub
  196. Private Sub RadioButton3_CheckedChanged(sender As Object, e As EventArgs) Handles 已核准的收支單_rb.Click
  197. If CC(28) = False Then
  198. 未核准的收支單_rb.Checked = False : 作廢的收支單_rb.Checked = False : 已核准的收支單_rb.Checked = True
  199. 申請完成ToolStripMenuItem.Enabled = False : 複製單據開單ToolStripMenuItem.Enabled = True
  200. 開立零用金支付單ToolStripMenuItem.Enabled = False : 申請_bt.Enabled = False : 新增一筆資料ToolStripMenuItem.Enabled = False
  201. 刪除支付單中選中的資料ToolStripMenuItem.Enabled = False : 刪除選中的零用金支付單ToolStripMenuItem.Enabled = False : Set_切換格式()
  202. Else
  203. 未核准的收支單_rb.Checked = False : 作廢的收支單_rb.Checked = False : 已核准的收支單_rb.Checked = True
  204. 申請完成ToolStripMenuItem.Enabled = True : 複製單據開單ToolStripMenuItem.Enabled = True
  205. 開立零用金支付單ToolStripMenuItem.Enabled = True : 申請_bt.Enabled = True : 新增一筆資料ToolStripMenuItem.Enabled = True
  206. 刪除支付單中選中的資料ToolStripMenuItem.Enabled = True : 刪除選中的零用金支付單ToolStripMenuItem.Enabled = True : Set_切換格式()
  207. End If
  208. End Sub
  209. Private Sub 存檔()
  210. For i As Integer = 0 To 明細表_dgv.Rows.Count - 1
  211. ConnOpen()
  212. SQL1 = "UPDATE 財務流水帳 SET 明細 = N'" & 明細表_dgv.Rows(i).Cells("用途").Value & "', 支出 = N'" & 明細表_dgv.Rows(i).Cells("支出").Value &
  213. "', 備註 = N'" & 明細表_dgv.Rows(i).Cells("票期").Value & "' , 類別 = N'" & 明細表_dgv.Rows(i).Cells("類別").Value &
  214. "', 收入 = N'" & 明細表_dgv.Rows(i).Cells("收入").Value & "', 零用金 = N'" & 明細表_dgv.Rows(i).Cells("零用金").Value &
  215. "', 支票數 = N'" & 明細表_dgv.Rows(i).Cells("支票").Value & "', 匯率 = N'" & 明細表_dgv.Rows(i).Cells("匯率").Value &
  216. "', 含稅 = N'" & 明細表_dgv.Rows(i).Cells("含稅").Value & "'
  217. WHERE (支付單號 LIKE N'" & 收支單號_tb.Text & "' AND 項次 LIKE N'" & 明細表_dgv.Rows(i).Cells("項次").Value & "')"
  218. cmd.CommandText = SQL1 : cmd.ExecuteNonQuery() : conn.Close()
  219. Next
  220. End Sub
  221. Private Sub Button2_Click(sender As Object, e As EventArgs) Handles 申請_bt.Click
  222. Timer1.Enabled = False : Label62.Visible = False
  223. 開立零用金支付單ToolStripMenuItem.Enabled = True : 未核准的收支單_rb.Enabled = True : 作廢的收支單_rb.Enabled = True
  224. 收支單_dgv.Enabled = True : 已核准的收支單_rb.Enabled = True : 存檔() : Set_清單1() : MsgBox("申請完成,請通知主管審核。")
  225. End Sub
  226. Private Sub Set_日期格式轉換()
  227. If 補單_ch.Checked = False Then
  228. DTP = Format(Today(), "yyyy/MM/dd") : DTP1 = Format(Today(), "yyyyMMdd")
  229. Else
  230. DTP1 = Format(日期_dtp.Value, "yyyyMMdd") : DTP = Format(日期_dtp.Value, "yyyy/MM/dd")
  231. End If
  232. End Sub
  233. Private Sub Set_流水號()
  234. conn.Close() : dr.Close()
  235. Dim NUM1 As Integer
  236. For NUM1 = 0 To 99
  237. Dim d As String : Dim f As String : Dim g As Integer = 1
  238. If Month(Now) < 10 Then : d = "0" & CStr(Month(Now))
  239. Else : d = CStr(Month(Now))
  240. End If
  241. If Now.Day() < 10 Then : f = "0" & CStr(Now.Day())
  242. Else : f = CStr(Now.Day())
  243. End If
  244. If NUM1 < 10 Then : 新流水1 = "B" & Microsoft.VisualBasic.Right(CStr(Year(Now)), 2) & d & f & "0" & NUM1
  245. Else : 新流水1 = "B" & Microsoft.VisualBasic.Right(CStr(Year(Now)), 2) & d & f & NUM1
  246. End If
  247. ConnOpen()
  248. SQL1 = "SELECT 流水號 FROM 財務流水帳 WHERE (流水號 ='" & 新流水1 & "')"
  249. cmd.Connection = conn : cmd.CommandText = SQL1 : dr = cmd.ExecuteReader
  250. If dr.Read() Then : conn.Close() : Else : conn.Close() : NUM1 = 99 : End If
  251. Next
  252. End Sub
  253. Private Sub 開立零用金支付單()
  254. Dim NUM1 As Integer : Timer1.Enabled = True
  255. Set_日期格式轉換()
  256. For i As Integer = 1 To 999
  257. NUM1 = 0 + i
  258. If NUM1 < 10 Then : 收支單號_tb.Text = "OE-" & DTP1 & "-00" & NUM1
  259. ElseIf NUM1 > 9 And NUM1 < 100 Then : 收支單號_tb.Text = "OE-" & DTP1 & "-0" & NUM1
  260. ElseIf NUM1 > 99 Then : 收支單號_tb.Text = "OE-" & DTP1 & "-" & NUM1
  261. End If
  262. conn.Close()
  263. ConnOpen()
  264. SQL1 = "SELECT TOP (1) 支付單號 FROM 財務控制表 WHERE ( 支付單號 LIKE N'" & 收支單號_tb.Text & "')"
  265. cmd.Connection = conn : cmd.CommandText = SQL1 : dr = cmd.ExecuteReader
  266. If dr.Read() Then : Else : i = 999 : conn.Close() : End If : conn.Close()
  267. Next
  268. ConnOpen()
  269. SQL1 = "INSERT INTO 財務控制表 (支付單號, 申請人, 申請日期, 審核人, 審核日期, 會計, 作帳日期, 出納, 出納日期, 備註, 公司編號) " &
  270. "VALUES (N'" & 收支單號_tb.Text & "', N'" & gUserName & "', N'" & DTP & "', N'', N'', N'', N'', N'', N'', N'', N'工巧明')"
  271. CmdSet_For_dr()
  272. 申請人_tb.Text = gUserName
  273. End Sub
  274. Private Sub 複製歷史單據重新開立_bt_Click(sender As Object, e As EventArgs) Handles 複製歷史單據重新開立_bt.Click
  275. 開立零用金支付單() : 開立零用金支付單ToolStripMenuItem.Enabled = False : 未核准的收支單_rb.Enabled = False : 作廢的收支單_rb.Enabled = False
  276. 已核准的收支單_rb.Enabled = False
  277. 收支單_dgv.Enabled = False : 未核准的收支單_rb.Checked = True : 作廢的收支單_rb.Checked = False : 已核准的收支單_rb.Checked = False
  278. 申請完成ToolStripMenuItem.Enabled = True
  279. 複製單據開單ToolStripMenuItem.Enabled = False : 開立零用金支付單ToolStripMenuItem.Enabled = True : 申請_bt.Enabled = True : 新增一筆資料ToolStripMenuItem.Enabled = True
  280. 刪除支付單中選中的資料ToolStripMenuItem.Enabled = True : 刪除選中的零用金支付單ToolStripMenuItem.Enabled = True
  281. Set_清單1()
  282. For i As Integer = 0 To 明細表_dgv.Rows.Count - 1
  283. Set_流水號()
  284. ConnOpen()
  285. SQL1 = "INSERT INTO 財務流水帳 (流水號, 銀行, 日期, 類別, 收入, 支出, 明細, 人員, 支付單號, 項次, 會計, 出納, 現金, 備用金, 公帳, 支票,
  286. 出納日期, 零用金, 支票數, 匯率, 備註)
  287. VALUES (N'" & 新流水1 & "', N'" & 明細表_dgv.Rows(i).Cells("幣別").Value & "'', N'" & DTP & "', N'" & 明細表_dgv.Rows(i).Cells("類別").Value &
  288. "', N'" & 明細表_dgv.Rows(i).Cells("收入").Value & "', N'" & 明細表_dgv.Rows(i).Cells("支出").Value & "', N'" & 明細表_dgv.Rows(i).Cells("用途").Value &
  289. "', N'', N'" & gUserName & "', N'" & 收支單號_tb.Text & "', N'" & 明細表_dgv.Rows(i).Cells("項次").Value & "', N'1', N'0', N'0', N'0', N'0', N'0', N'" & DTP &
  290. "', N'" & 明細表_dgv.Rows(i).Cells("零用金").Value & "', N'" & 明細表_dgv.Rows(i).Cells("支票").Value & "', N'" & 明細表_dgv.Rows(i).Cells("匯率").Value &
  291. "', N'" & 明細表_dgv.Rows(i).Cells("票期").Value & "')"
  292. CmdSet_For_dr()
  293. Next
  294. Set_費用清單() : MsgBox("複製單據開立完成。")
  295. End Sub
  296. Private Sub DateTimePicker1_ValueChanged(sender As Object, e As EventArgs) Handles 日期_dtp.ValueChanged
  297. 匯率()
  298. End Sub
  299. Private Sub 開立營運成本收支單_bt_Click(sender As Object, e As EventArgs) Handles 開立營運成本收支單_bt.Click
  300. 開立零用金支付單() : 開立零用金支付單ToolStripMenuItem.Enabled = False
  301. 未核准的收支單_rb.Enabled = False : 作廢的收支單_rb.Enabled = False
  302. 已核准的收支單_rb.Enabled = False : 收支單_dgv.Enabled = False
  303. 明細表_dgv.DataSource = Nothing : ds.Clear() : conn.Close()
  304. Set_清單1()
  305. End Sub
  306. Private Sub 刪除選中的營運成本收支單_bt_Click(sender As Object, e As EventArgs) Handles 刪除選中的營運成本收支單_bt.Click
  307. Dim aa As MsgBoxResult
  308. aa = MsgBox("確定要刪除該筆資料?", MsgBoxStyle.OkCancel)
  309. If aa = MsgBoxResult.Ok Then
  310. ConnOpen()
  311. SQL1 = "DELETE FROM 財務控制表 WHERE (支付單號 LIKE N'" & 收支單號_tb.Text & "')"
  312. cmd.CommandText = SQL1 : cmd.Connection = conn : cmd.ExecuteNonQuery() : conn.Close()
  313. ConnOpen()
  314. SQL1 = "DELETE FROM 財務流水帳 WHERE (支付單號 LIKE N'" & 收支單號_tb.Text & "')"
  315. cmd.CommandText = SQL1 : cmd.Connection = conn : cmd.ExecuteNonQuery() : conn.Close()
  316. 收支單號_tb.Text = "" : 申請人_tb.Text = "" : 項次_tb.Text = ""
  317. 明細表_dgv.DataSource = Nothing : ds.Clear()
  318. Set_清單1()
  319. End If
  320. End Sub
  321. Private Sub 收支單中新增一筆空白資料_bt_Click(sender As Object, e As EventArgs) Handles 收支單中新增一筆空白資料_bt.Click
  322. If 科目3_號_cb.Text = "" Or 幣別_cb.Text = "" Then
  323. MsgBox("沒有選擇會計科目或幣別。")
  324. Else
  325. If 收支單號_tb.Text = "" Then
  326. 開立零用金支付單()
  327. End If
  328. Set_日期格式轉換() : Set_流水號()
  329. 存檔()
  330. ConnOpen()
  331. SQL1 = "SELECT TOP(1) 項次 FROM 財務流水帳 WHERE 支付單號 LIKE N'" & 收支單號_tb.Text & "' ORDER BY 項次 DESC"
  332. cmd.Connection = conn : cmd.CommandText = SQL1 : dr = cmd.ExecuteReader
  333. If dr.Read() Then : 新項次 = dr("項次") : Else : 新項次 = "00" : End If : conn.Close()
  334. NUM1 = Double.Parse(新項次) + 1
  335. If NUM1 < 10 Then : 新項次 = "0" & NUM1
  336. ElseIf NUM1 > 9 And NUM1 < 100 Then : 新項次 = NUM1
  337. End If
  338. ConnOpen()
  339. If 幣別_cb.Text = "台幣現金" Then : 匯率1 = 1
  340. ElseIf 幣別_cb.Text = "人民幣現金" Then : 匯率1 = 人民幣匯率_tb.Text
  341. ElseIf 幣別_cb.Text = "美金" Then : 匯率1 = 美金匯率_tb.Text
  342. ElseIf 幣別_cb.Text = "印尼盾" Then : 匯率1 = 印尼匯率_tb.Text
  343. End If
  344. SQL1 = "INSERT INTO 財務流水帳 (流水號, 銀行, 日期, 類別, 收入, 支出, 明細, 人員, 支付單號, 項次, 會計, 出納, 現金, 備用金, 公帳, 支票,
  345. 出納日期, 零用金, 支票數, 匯率, 備註) " &
  346. "VALUES (N'" & 新流水1 & "', N'" & 幣別_cb.Text & "', N'" & DTP & "', N'" & 科目3_號_cb.Text & "', N'0', N'0', N'', N'" & gUserName & "', N'" & 收支單號_tb.Text & "', N'" & 新項次 &
  347. "', N'0', N'0', N'0', N'0', N'0', N'0', N'" & DTP & "', N'0', N'0', N'" & 匯率1 & "', N'')"
  348. CmdSet_For_dr()
  349. Set_費用清單()
  350. End If
  351. End Sub
  352. Private Sub 刪除選中的一筆資料_bt_Click(sender As Object, e As EventArgs) Handles 刪除選中的一筆資料_bt.Click
  353. If 項次_tb.Text = "" Then
  354. MsgBox("未選擇需要刪除的資料。")
  355. Else
  356. 存檔()
  357. ConnOpen()
  358. SQL1 = "DELETE FROM 財務流水帳 WHERE (支付單號 LIKE N'" & 收支單號_tb.Text & "' AND 項次 LIKE N'" & 項次_tb.Text & "')"
  359. cmd.CommandText = SQL1 : cmd.Connection = conn : cmd.ExecuteNonQuery() : conn.Close()
  360. Set_費用清單()
  361. Dim NUM1 As Integer = 0
  362. For i As Integer = 0 To 明細表_dgv.Rows.Count - 1
  363. NUM1 += 1 : If NUM1 < 10 Then : 新項次 = "0" & NUM1 : ElseIf NUM1 > 9 And NUM1 < 100 Then : 新項次 = NUM1 : End If
  364. ConnOpen()
  365. SQL1 = "UPDATE 財務流水帳 SET 項次 = N'" & 新項次 & "' WHERE (支付單號 LIKE N'" & 收支單號_tb.Text & "' AND 項次 LIKE N'" & 明細表_dgv.Rows(i).Cells("項次").Value & "')"
  366. cmd.CommandText = SQL1 : cmd.ExecuteNonQuery()
  367. conn.Close()
  368. Next
  369. Set_費用清單()
  370. End If
  371. End Sub
  372. '----------------------滑鼠右鍵--------------------------------------------------------------------------------------------------------------------------------------------------------------------
  373. Private Sub 重新讀取ToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles 重新讀取ToolStripMenuItem.Click
  374. Set_清單1()
  375. End Sub
  376. Private Sub 開立零用金支付單ToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles 開立零用金支付單ToolStripMenuItem.Click
  377. 開立營運成本收支單_bt.PerformClick()
  378. End Sub
  379. Private Sub 刪除選中的零用金支付單ToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles 刪除選中的零用金支付單ToolStripMenuItem.Click
  380. 刪除選中的營運成本收支單_bt.PerformClick()
  381. End Sub
  382. Private Sub 刪除支付單中選中的資料ToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles 刪除支付單中選中的資料ToolStripMenuItem.Click
  383. 刪除選中的一筆資料_bt.PerformClick()
  384. End Sub
  385. Private Sub 新增一筆資料ToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles 新增一筆資料ToolStripMenuItem.Click
  386. 收支單中新增一筆空白資料_bt.PerformClick()
  387. End Sub
  388. Private Sub 申請完成ToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles 申請完成ToolStripMenuItem.Click
  389. 申請_bt.PerformClick()
  390. End Sub
  391. Private Sub 複製單據開單ToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles 複製單據開單ToolStripMenuItem.Click
  392. 複製歷史單據重新開立_bt.PerformClick()
  393. End Sub
  394. '----------------------自創視窗滑鼠拖曳功能---------------------------------------------------------------------------------------------------------
  395. Dim OldX, OldY As Long : Dim drag As Boolean
  396. Private Sub 收入_cb_CheckedChanged(sender As Object, e As EventArgs) Handles 收入_cb.Click
  397. If 收入_cb.Checked = True Then
  398. 收入_cb.Checked = True : 支出_cb.Checked = False
  399. Else
  400. 收入_cb.Checked = False : 支出_cb.Checked = True
  401. End If
  402. End Sub
  403. Private Sub 支出_cb_CheckedChanged(sender As Object, e As EventArgs) Handles 支出_cb.Click
  404. If 支出_cb.Checked = True Then
  405. 收入_cb.Checked = False : 支出_cb.Checked = True
  406. Else
  407. 收入_cb.Checked = True : 支出_cb.Checked = False
  408. End If
  409. End Sub
  410. Private Sub 確定_bt_Click(sender As Object, e As EventArgs) Handles 確定_bt.Click
  411. If 收入_cb.Checked = False And 支出_cb.Checked = False Then
  412. MsgBox("請先選擇這筆資料是收入還是支出!!!")
  413. Else
  414. If 收入_cb.Checked = True Then
  415. 明細表_dgv.Rows(NUM2).Cells("收入").Value = 指定_ndp.Value
  416. If 窗口說明1_lb.Text = "支票" Then
  417. 明細表_dgv.Rows(NUM2).Cells("支票").Value = 指定_ndp.Value
  418. ElseIf 窗口說明1_lb.Text = "零用金" Then
  419. 明細表_dgv.Rows(NUM2).Cells("零用金").Value = 指定_ndp.Value
  420. End If
  421. Else
  422. 明細表_dgv.Rows(NUM2).Cells("支出").Value = 指定_ndp.Value
  423. If 窗口說明1_lb.Text = "支票" Then
  424. 明細表_dgv.Rows(NUM2).Cells("支票").Value = 指定_ndp.Value
  425. ElseIf 窗口說明1_lb.Text = "零用金" Then
  426. 明細表_dgv.Rows(NUM2).Cells("零用金").Value = 指定_ndp.Value
  427. End If
  428. End If : 指定_ndp.Value = 0 : 收入_cb.Checked = False : 支出_cb.Checked = False : Cancel_bt.PerformClick()
  429. End If
  430. End Sub
  431. Private Sub Cancel_bt_Click(sender As Object, e As EventArgs) Handles Cancel_bt.Click
  432. If 視窗1_pl.Visible = False Then : 視窗1_pl.Visible = True : 視窗1_pl.BringToFront() : Else : 視窗1_pl.Visible = False : End If
  433. End Sub
  434. Private Sub 物料群組1_Panel_MouseDown(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles 視窗1_pl.MouseDown
  435. If e.Button = MouseButtons.Left Then : OldX = e.X : OldY = e.Y : drag = True : End If
  436. End Sub
  437. Private Sub 物料群組1_Panel_MouseMove(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles 視窗1_pl.MouseMove
  438. If drag Then : 視窗1_pl.Left = 視窗1_pl.Left + e.X - OldX : 視窗1_pl.Top = 視窗1_pl.Top + e.Y - OldY : End If
  439. End Sub
  440. Private Sub 物料群組1_Panel_MouseUp(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs) Handles 視窗1_pl.MouseUp
  441. drag = False
  442. End Sub
  443. End Class