summaryrefslogtreecommitdiffstats
path: root/models
diff options
context:
space:
mode:
authorRomain <romdum@users.noreply.github.com>2021-02-11 17:32:27 +0100
committerGitHub <noreply@github.com>2021-02-11 17:32:27 +0100
commitc69c01d2b6b08a89448b5596fd2233fa4e802ac3 (patch)
tree16d461903abbd5bd29ae4905b8506a752d632619 /models
parentac97ea573c1b10d03e72775e8f74b9fe5453bfc8 (diff)
downloadgitea-c69c01d2b6b08a89448b5596fd2233fa4e802ac3.tar.gz
gitea-c69c01d2b6b08a89448b5596fd2233fa4e802ac3.zip
Sort / Move project boards (#14634)
Sort Project board (#14533)
Diffstat (limited to 'models')
-rw-r--r--models/project_board.go34
1 files changed, 29 insertions, 5 deletions
diff --git a/models/project_board.go b/models/project_board.go
index a9c0b3ed8b..e56bf8f819 100644
--- a/models/project_board.go
+++ b/models/project_board.go
@@ -36,6 +36,7 @@ type ProjectBoard struct {
ID int64 `xorm:"pk autoincr"`
Title string
Default bool `xorm:"NOT NULL DEFAULT false"` // issues not assigned to a specific board will be assigned to this board
+ Sorting int8 `xorm:"DEFAULT 0"`
ProjectID int64 `xorm:"INDEX NOT NULL"`
CreatorID int64 `xorm:"NOT NULL"`
@@ -157,15 +158,24 @@ func getProjectBoard(e Engine, boardID int64) (*ProjectBoard, error) {
return board, nil
}
-// UpdateProjectBoard updates the title of a project board
+// UpdateProjectBoard updates a project board
func UpdateProjectBoard(board *ProjectBoard) error {
return updateProjectBoard(x, board)
}
func updateProjectBoard(e Engine, board *ProjectBoard) error {
- _, err := e.ID(board.ID).Cols(
- "title",
- ).Update(board)
+ var fieldToUpdate []string
+
+ if board.Sorting != 0 {
+ fieldToUpdate = append(fieldToUpdate, "sorting")
+ }
+
+ if board.Title != "" {
+ fieldToUpdate = append(fieldToUpdate, "title")
+ }
+
+ _, err := e.ID(board.ID).Cols(fieldToUpdate...).Update(board)
+
return err
}
@@ -178,7 +188,7 @@ func GetProjectBoards(projectID int64) (ProjectBoardList, error) {
func getProjectBoards(e Engine, projectID int64) ([]*ProjectBoard, error) {
var boards = make([]*ProjectBoard, 0, 5)
- if err := e.Where("project_id=? AND `default`=?", projectID, false).Find(&boards); err != nil {
+ if err := e.Where("project_id=? AND `default`=?", projectID, false).OrderBy("Sorting").Find(&boards); err != nil {
return nil, err
}
@@ -277,3 +287,17 @@ func (bs ProjectBoardList) LoadIssues() (IssueList, error) {
}
return issues, nil
}
+
+// UpdateProjectBoardSorting update project board sorting
+func UpdateProjectBoardSorting(bs ProjectBoardList) error {
+ for i := range bs {
+ _, err := x.ID(bs[i].ID).Cols(
+ "sorting",
+ ).Update(bs[i])
+
+ if err != nil {
+ return err
+ }
+ }
+ return nil
+}