123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- // Copyright 2020 The Gitea Authors. All rights reserved.
- // SPDX-License-Identifier: MIT
-
- package repo
-
- import (
- "fmt"
- "strconv"
-
- system_model "code.gitea.io/gitea/models/system"
- user_model "code.gitea.io/gitea/models/user"
- "code.gitea.io/gitea/modules/context"
- "code.gitea.io/gitea/modules/git"
- )
-
- // SetEditorconfigIfExists set editor config as render variable
- func SetEditorconfigIfExists(ctx *context.Context) {
- if ctx.Repo.Repository.IsEmpty {
- ctx.Data["Editorconfig"] = nil
- return
- }
-
- ec, _, err := ctx.Repo.GetEditorconfig()
-
- if err != nil && !git.IsErrNotExist(err) {
- description := fmt.Sprintf("Error while getting .editorconfig file: %v", err)
- if err := system_model.CreateRepositoryNotice(description); err != nil {
- ctx.ServerError("ErrCreatingReporitoryNotice", err)
- }
- return
- }
-
- ctx.Data["Editorconfig"] = ec
- }
-
- // SetDiffViewStyle set diff style as render variable
- func SetDiffViewStyle(ctx *context.Context) {
- queryStyle := ctx.FormString("style")
-
- if !ctx.IsSigned {
- ctx.Data["IsSplitStyle"] = queryStyle == "split"
- return
- }
-
- var (
- userStyle = ctx.Doer.DiffViewStyle
- style string
- )
-
- if queryStyle == "unified" || queryStyle == "split" {
- style = queryStyle
- } else if userStyle == "unified" || userStyle == "split" {
- style = userStyle
- } else {
- style = "unified"
- }
-
- ctx.Data["IsSplitStyle"] = style == "split"
- if err := user_model.UpdateUserDiffViewStyle(ctx.Doer, style); err != nil {
- ctx.ServerError("ErrUpdateDiffViewStyle", err)
- }
- }
-
- // SetWhitespaceBehavior set whitespace behavior as render variable
- func SetWhitespaceBehavior(ctx *context.Context) {
- const defaultWhitespaceBehavior = "show-all"
- whitespaceBehavior := ctx.FormString("whitespace")
- switch whitespaceBehavior {
- case "", "ignore-all", "ignore-eol", "ignore-change":
- break
- default:
- whitespaceBehavior = defaultWhitespaceBehavior
- }
- if ctx.IsSigned {
- userWhitespaceBehavior, err := user_model.GetUserSetting(ctx.Doer.ID, user_model.SettingsKeyDiffWhitespaceBehavior, defaultWhitespaceBehavior)
- if err == nil {
- if whitespaceBehavior == "" {
- whitespaceBehavior = userWhitespaceBehavior
- } else if whitespaceBehavior != userWhitespaceBehavior {
- _ = user_model.SetUserSetting(ctx.Doer.ID, user_model.SettingsKeyDiffWhitespaceBehavior, whitespaceBehavior)
- }
- } // else: we can ignore the error safely
- }
-
- // these behaviors are for gitdiff.GetWhitespaceFlag
- if whitespaceBehavior == "" {
- ctx.Data["WhitespaceBehavior"] = defaultWhitespaceBehavior
- } else {
- ctx.Data["WhitespaceBehavior"] = whitespaceBehavior
- }
- }
-
- // SetShowOutdatedComments set the show outdated comments option as context variable
- func SetShowOutdatedComments(ctx *context.Context) {
- showOutdatedCommentsValue := ctx.FormString("show-outdated")
- // var showOutdatedCommentsValue string
-
- if showOutdatedCommentsValue != "true" && showOutdatedCommentsValue != "false" {
- // invalid or no value for this form string -> use default or stored user setting
- if ctx.IsSigned {
- showOutdatedCommentsValue, _ = user_model.GetUserSetting(ctx.Doer.ID, user_model.SettingsKeyShowOutdatedComments, "false")
- } else {
- // not logged in user -> use the default value
- showOutdatedCommentsValue = "false"
- }
- } else {
- // valid value -> update user setting if user is logged in
- if ctx.IsSigned {
- _ = user_model.SetUserSetting(ctx.Doer.ID, user_model.SettingsKeyShowOutdatedComments, showOutdatedCommentsValue)
- }
- }
-
- showOutdatedComments, _ := strconv.ParseBool(showOutdatedCommentsValue)
- ctx.Data["ShowOutdatedComments"] = showOutdatedComments
- }
|