mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-08-05 01:45:22 +02:00
feat(ui): localize theme names (#7168)
Allow translating theme names. Not even for i18n reasons but because this way the menu is clearer and cleaner. The number of translated entries is kept minimal for now. It is easy to pollute locales with these names otherwise. Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7168 Reviewed-by: Gusted <gusted@noreply.codeberg.org>
This commit is contained in:
parent
f015c00ecb
commit
584c504e25
7 changed files with 35 additions and 9 deletions
|
@ -5,6 +5,7 @@ package integration
|
|||
|
||||
import (
|
||||
"net/http"
|
||||
"strings"
|
||||
"testing"
|
||||
|
||||
"code.gitea.io/gitea/tests"
|
||||
|
@ -16,15 +17,21 @@ func TestThemeChange(t *testing.T) {
|
|||
defer tests.PrepareTestEnv(t)()
|
||||
user := loginUser(t, "user2")
|
||||
|
||||
testSelectedTheme(t, user, "forgejo-auto")
|
||||
// Verify default theme
|
||||
testSelectedTheme(t, user, "forgejo-auto", "Forgejo (follow system theme)")
|
||||
|
||||
// Change theme to forgejo-dark and verify it works fine
|
||||
testChangeTheme(t, user, "forgejo-dark")
|
||||
testSelectedTheme(t, user, "forgejo-dark")
|
||||
testSelectedTheme(t, user, "forgejo-dark", "Forgejo dark")
|
||||
|
||||
// Change theme to gitea-dark and also verify that it's name is not translated
|
||||
testChangeTheme(t, user, "gitea-dark")
|
||||
testSelectedTheme(t, user, "gitea-dark", "gitea-dark")
|
||||
}
|
||||
|
||||
// testSelectedTheme checks that the expected theme is used in html[data-theme]
|
||||
// and is default on appearance page
|
||||
func testSelectedTheme(t *testing.T, session *TestSession, expectedTheme string) {
|
||||
func testSelectedTheme(t *testing.T, session *TestSession, expectedTheme, expectedName string) {
|
||||
t.Helper()
|
||||
response := session.MakeRequest(t, NewRequest(t, "GET", "/user/settings/appearance"), http.StatusOK)
|
||||
page := NewHTMLParser(t, response.Body)
|
||||
|
@ -33,9 +40,11 @@ func testSelectedTheme(t *testing.T, session *TestSession, expectedTheme string)
|
|||
assert.True(t, dataThemeExists)
|
||||
assert.EqualValues(t, expectedTheme, dataTheme)
|
||||
|
||||
selectorTheme, selectorThemeExists := page.Find("form[action='/user/settings/appearance/theme'] input[name='theme']").Attr("value")
|
||||
selectedTheme := page.Find("form[action='/user/settings/appearance/theme'] .menu .item.selected")
|
||||
selectorTheme, selectorThemeExists := selectedTheme.Attr("data-value")
|
||||
assert.True(t, selectorThemeExists)
|
||||
assert.EqualValues(t, expectedTheme, selectorTheme)
|
||||
assert.EqualValues(t, expectedName, strings.TrimSpace(selectedTheme.Text()))
|
||||
}
|
||||
|
||||
// testSelectedTheme changes user's theme
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue