mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-24 19:12:24 +00:00 
			
		
		
		
	* Add config option to hide issue events Adds a config option `HIDE_ISSUE_EVENTS` to hide most issue events (changed labels, milestones, projects...) on the issue detail page. If this is true, only the following events (comment types) are shown: * plain comments * closed/reopned/merged * reviews * Make configurable using a list * Add docs * Add missing newline * Fix merge issues * Allow changes per user settings * Fix lint * Rm old docs * Apply suggestions from code review * Use bitsets * Rm comment * fmt * Fix lint * Use variable/constant to provide key * fmt * fix lint * refactor * Add a prefix for user setting key * Add license comment * Add license comment * Update services/forms/user_form_hidden_comments.go Co-authored-by: Gusted <williamzijl7@hotmail.com> * check len == 0 Co-authored-by: wxiaoguang <wxiaoguang@gmail.com> Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: Gusted <williamzijl7@hotmail.com> Co-authored-by: 6543 <6543@obermui.de>
		
			
				
	
	
		
			68 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2021 The Gitea Authors. All rights reserved.
 | |
| // Use of this source code is governed by a MIT-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package context
 | |
| 
 | |
| import (
 | |
| 	"strconv"
 | |
| 	"strings"
 | |
| 
 | |
| 	"code.gitea.io/gitea/modules/util"
 | |
| )
 | |
| 
 | |
| // FormString returns the first value matching the provided key in the form as a string
 | |
| func (ctx *Context) FormString(key string) string {
 | |
| 	return ctx.Req.FormValue(key)
 | |
| }
 | |
| 
 | |
| // FormStrings returns a string slice for the provided key from the form
 | |
| func (ctx *Context) FormStrings(key string) []string {
 | |
| 	if ctx.Req.Form == nil {
 | |
| 		if err := ctx.Req.ParseMultipartForm(32 << 20); err != nil {
 | |
| 			return nil
 | |
| 		}
 | |
| 	}
 | |
| 	if v, ok := ctx.Req.Form[key]; ok {
 | |
| 		return v
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // FormTrim returns the first value for the provided key in the form as a space trimmed string
 | |
| func (ctx *Context) FormTrim(key string) string {
 | |
| 	return strings.TrimSpace(ctx.Req.FormValue(key))
 | |
| }
 | |
| 
 | |
| // FormInt returns the first value for the provided key in the form as an int
 | |
| func (ctx *Context) FormInt(key string) int {
 | |
| 	v, _ := strconv.Atoi(ctx.Req.FormValue(key))
 | |
| 	return v
 | |
| }
 | |
| 
 | |
| // FormInt64 returns the first value for the provided key in the form as an int64
 | |
| func (ctx *Context) FormInt64(key string) int64 {
 | |
| 	v, _ := strconv.ParseInt(ctx.Req.FormValue(key), 10, 64)
 | |
| 	return v
 | |
| }
 | |
| 
 | |
| // FormBool returns true if the value for the provided key in the form is "1", "true" or "on"
 | |
| func (ctx *Context) FormBool(key string) bool {
 | |
| 	s := ctx.Req.FormValue(key)
 | |
| 	v, _ := strconv.ParseBool(s)
 | |
| 	v = v || strings.EqualFold(s, "on")
 | |
| 	return v
 | |
| }
 | |
| 
 | |
| // FormOptionalBool returns an OptionalBoolTrue or OptionalBoolFalse if the value
 | |
| // for the provided key exists in the form else it returns OptionalBoolNone
 | |
| func (ctx *Context) FormOptionalBool(key string) util.OptionalBool {
 | |
| 	value := ctx.Req.FormValue(key)
 | |
| 	if len(value) == 0 {
 | |
| 		return util.OptionalBoolNone
 | |
| 	}
 | |
| 	s := ctx.Req.FormValue(key)
 | |
| 	v, _ := strconv.ParseBool(s)
 | |
| 	v = v || strings.EqualFold(s, "on")
 | |
| 	return util.OptionalBoolOf(v)
 | |
| }
 |