diff options
author | Romain <romdum@users.noreply.github.com> | 2021-02-11 17:32:27 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-02-11 17:32:27 +0100 |
commit | c69c01d2b6b08a89448b5596fd2233fa4e802ac3 (patch) | |
tree | 16d461903abbd5bd29ae4905b8506a752d632619 /models/project_board.go | |
parent | ac97ea573c1b10d03e72775e8f74b9fe5453bfc8 (diff) | |
download | gitea-c69c01d2b6b08a89448b5596fd2233fa4e802ac3.tar.gz gitea-c69c01d2b6b08a89448b5596fd2233fa4e802ac3.zip |
Sort / Move project boards (#14634)
Sort Project board (#14533)
Diffstat (limited to 'models/project_board.go')
-rw-r--r-- | models/project_board.go | 34 |
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 +} |