mirror of https://github.com/go-gitea/gitea
Backport #30696 by @lunny # The problem The previous implementation will start multiple POST requests from the frontend when moving a column and another bug is moving the default column will never be remembered in fact. # What's changed - [x] This PR will allow the default column to move to a non-first position - [x] And it also uses one request instead of multiple requests when moving the columns - [x] Use a star instead of a pin as the icon for setting the default column action - [x] Inserted new column will be append to the end - [x] Fix #30701 the newly added issue will be append to the end of the default column - [x] Fix when deleting a column, all issues in it will be displayed from UI but database records exist. - [x] Add a limitation for columns in a project to 20. So the sorting will not be overflow because it's int8. Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>pull/30905/head
parent
271e8748a2
commit
084bec89ed
@ -0,0 +1,48 @@ |
|||||||
|
// Copyright 2024 The Gitea Authors. All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package project |
||||||
|
|
||||||
|
import ( |
||||||
|
project_model "code.gitea.io/gitea/models/project" |
||||||
|
"code.gitea.io/gitea/modules/json" |
||||||
|
"code.gitea.io/gitea/services/context" |
||||||
|
) |
||||||
|
|
||||||
|
// MoveColumns moves or keeps columns in a project and sorts them inside that project
|
||||||
|
func MoveColumns(ctx *context.Context) { |
||||||
|
project, err := project_model.GetProjectByID(ctx, ctx.ParamsInt64(":id")) |
||||||
|
if err != nil { |
||||||
|
ctx.NotFoundOrServerError("GetProjectByID", project_model.IsErrProjectNotExist, err) |
||||||
|
return |
||||||
|
} |
||||||
|
if !project.CanBeAccessedByOwnerRepo(ctx.ContextUser.ID, ctx.Repo.Repository) { |
||||||
|
ctx.NotFound("CanBeAccessedByOwnerRepo", nil) |
||||||
|
return |
||||||
|
} |
||||||
|
|
||||||
|
type movedColumnsForm struct { |
||||||
|
Columns []struct { |
||||||
|
ColumnID int64 `json:"columnID"` |
||||||
|
Sorting int64 `json:"sorting"` |
||||||
|
} `json:"columns"` |
||||||
|
} |
||||||
|
|
||||||
|
form := &movedColumnsForm{} |
||||||
|
if err = json.NewDecoder(ctx.Req.Body).Decode(&form); err != nil { |
||||||
|
ctx.ServerError("DecodeMovedColumnsForm", err) |
||||||
|
return |
||||||
|
} |
||||||
|
|
||||||
|
sortedColumnIDs := make(map[int64]int64) |
||||||
|
for _, column := range form.Columns { |
||||||
|
sortedColumnIDs[column.Sorting] = column.ColumnID |
||||||
|
} |
||||||
|
|
||||||
|
if err = project_model.MoveColumnsOnProject(ctx, project, sortedColumnIDs); err != nil { |
||||||
|
ctx.ServerError("MoveColumnsOnProject", err) |
||||||
|
return |
||||||
|
} |
||||||
|
|
||||||
|
ctx.JSONOK() |
||||||
|
} |
Loading…
Reference in new issue