mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-15 19:42:04 +00:00 
			
		
		
		
	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.
- [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: silverwind <me@silverwind.io>
Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
(cherry picked from commit a303c973e0264dab45a787c4afa200e183e0d953)
Conflicts:
	routers/web/web.go
	e91733468ef726fc9365aa4820cdd5f2ddfdaa23 Add missing database transaction for new issue (#29490) was not cherry-picked
	services/issue/issue.go
	fe6792dff3 Enable/disable owner and repo projects independently (#28805) was not cherry-picked
(cherry picked from commit 7d3ca90dfe)
(cherry picked from commit 084bec89ed7ae0816fc2d8db6784ad22523d1fc4)
		
	
			
		
			
				
	
	
		
			48 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // 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()
 | |
| }
 |