Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

105 Zeilen
4.1KB

  1. <%
  2. Class cards_Repository_Class
  3. Private Function SelectBase()
  4. SelectBase = "SELECT [id],[board_id],[column_id],[swim_lane_id],[job_number],[job_name],[position],[created_at],[created_by],[updated_at],[updated_by] FROM [cards]"
  5. End Function
  6. Public Function FindByID(id)
  7. Dim sql : sql = SelectBase() & " WHERE [id] = ?"
  8. Dim rs : Set rs = DAL.Query(sql, Array(id))
  9. If rs.EOF Then
  10. Err.Raise 1, "cards_Repository_Class", "Card not found with id = " & id
  11. Else
  12. Set FindByID = Automapper.AutoMap(rs, "POBO_cards")
  13. End If
  14. Destroy rs
  15. End Function
  16. Public Function FindByBoardId(boardId)
  17. Dim sql : sql = SelectBase() & " WHERE [board_id] = ? ORDER BY [swim_lane_id] ASC, [column_id] ASC, [position] ASC"
  18. Dim rs : Set rs = DAL.Query(sql, Array(boardId))
  19. Dim list : Set list = New LinkedList_Class
  20. Do Until rs.EOF
  21. list.Push Automapper.AutoMap(rs, "POBO_cards")
  22. rs.MoveNext
  23. Loop
  24. Set FindByBoardId = list
  25. Destroy rs
  26. End Function
  27. Public Function FindByCell(columnId, swimLaneId)
  28. Dim sql : sql = SelectBase() & " WHERE [column_id] = ? AND [swim_lane_id] = ? ORDER BY [position] ASC"
  29. Dim rs : Set rs = DAL.Query(sql, Array(columnId, swimLaneId))
  30. Dim list : Set list = New LinkedList_Class
  31. Do Until rs.EOF
  32. list.Push Automapper.AutoMap(rs, "POBO_cards")
  33. rs.MoveNext
  34. Loop
  35. Set FindByCell = list
  36. Destroy rs
  37. End Function
  38. Public Function MaxPosition(columnId, swimLaneId)
  39. Dim sql : sql = "SELECT MAX([position]) FROM [cards] WHERE [column_id] = ? AND [swim_lane_id] = ?"
  40. Dim rs : Set rs = DAL.Query(sql, Array(columnId, swimLaneId))
  41. If rs.EOF Or IsNull(rs(0)) Then
  42. MaxPosition = -1
  43. Else
  44. MaxPosition = CLng(rs(0))
  45. End If
  46. Destroy rs
  47. End Function
  48. Public Sub AddNew(ByRef model)
  49. Dim sql : sql = "INSERT INTO [cards] ([board_id],[column_id],[swim_lane_id],[job_number],[job_name],[position],[created_at],[created_by],[updated_at],[updated_by]) VALUES (?,?,?,?,?,?,?,?,?,?)"
  50. DAL.Execute sql, Array(model.board_id, model.column_id, model.swim_lane_id, model.job_number, model.job_name, model.position, model.created_at, model.created_by, model.updated_at, model.updated_by)
  51. Dim rsId : Set rsId = DAL.Query("SELECT @@IDENTITY AS NewID", Empty)
  52. If Not rsId.EOF Then
  53. If Not IsNull(rsId(0)) Then model.id = rsId(0)
  54. End If
  55. Destroy rsId
  56. End Sub
  57. Public Sub Update(model)
  58. Dim sql : sql = "UPDATE [cards] SET [job_number]=?,[job_name]=?,[updated_at]=?,[updated_by]=? WHERE [id]=?"
  59. DAL.Execute sql, Array(model.job_number, model.job_name, model.updated_at, model.updated_by, model.id)
  60. End Sub
  61. Public Sub Move(id, columnId, swimLaneId, position, updatedAt, updatedBy)
  62. Dim sql : sql = "UPDATE [cards] SET [column_id]=?,[swim_lane_id]=?,[position]=?,[updated_at]=?,[updated_by]=? WHERE [id]=?"
  63. DAL.Execute sql, Array(columnId, swimLaneId, position, updatedAt, updatedBy, id)
  64. End Sub
  65. Public Sub UpdatePosition(id, position, updatedAt, updatedBy)
  66. Dim sql : sql = "UPDATE [cards] SET [position]=?,[updated_at]=?,[updated_by]=? WHERE [id]=?"
  67. DAL.Execute sql, Array(position, updatedAt, updatedBy, id)
  68. End Sub
  69. Public Sub Delete(id)
  70. DAL.Execute "DELETE FROM [cards] WHERE [id]=?", Array(id)
  71. End Sub
  72. Public Sub DeleteByBoardId(boardId)
  73. DAL.Execute "DELETE FROM [cards] WHERE [board_id]=?", Array(boardId)
  74. End Sub
  75. Public Sub DeleteByColumnId(columnId)
  76. DAL.Execute "DELETE FROM [cards] WHERE [column_id]=?", Array(columnId)
  77. End Sub
  78. Public Sub DeleteBySwimLaneId(swimLaneId)
  79. DAL.Execute "DELETE FROM [cards] WHERE [swim_lane_id]=?", Array(swimLaneId)
  80. End Sub
  81. End Class
  82. Dim cards_Repository__Singleton
  83. Function cards_Repository()
  84. If IsEmpty(cards_Repository__Singleton) Then
  85. Set cards_Repository__Singleton = New cards_Repository_Class
  86. End If
  87. Set cards_Repository = cards_Repository__Singleton
  88. End Function
  89. %>

Powered by TurnKey Linux.