Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added a view basic translation functions and translation file #137

Merged
merged 36 commits into from
Aug 16, 2018
Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
62fc831
Added a view basic translation functions + tranlation file
mjarkk Aug 13, 2018
d9959eb
fixed @jesseduffield comment #137
mjarkk Aug 13, 2018
65eb378
fixed typo
mjarkk Aug 13, 2018
f2dfcb6
Added more messages and text issue: #137
mjarkk Aug 13, 2018
dfafb98
tried to update to latest master
mjarkk Aug 14, 2018
17dcfbc
Merge pull request #1 from jesseduffield/master
mjarkk Aug 14, 2018
5ad97ad
Added the translation to some words again
mjarkk Aug 14, 2018
f792f74
Merge remote-tracking branch 'origin/master'
mjarkk Aug 14, 2018
dd7e93a
Added all the missing translations from dutch.go
mjarkk Aug 14, 2018
0c39347
Added auto detection for the system language
mjarkk Aug 14, 2018
6e51814
added some commands
mjarkk Aug 14, 2018
0568b32
Added more translations
mjarkk Aug 14, 2018
5cbacb0
make local i18n package confirm to project structure
jesseduffield Aug 14, 2018
4d0702f
Merge branch 'master' of https://github.com/mjarkk/lazygit
jesseduffield Aug 14, 2018
8e22d56
Merge pull request #2 from jesseduffield/master
mjarkk Aug 14, 2018
73a1682
fixed package naming and added tr object to file_panel.go
mjarkk Aug 14, 2018
ba2b6fb
pull errors out of package scope and store sentinel errors on the gui…
jesseduffield Aug 14, 2018
d923796
Merge branch 'master' of https://github.com/mjarkk/lazygit
jesseduffield Aug 14, 2018
883f436
can't go any further because of an error
mjarkk Aug 14, 2018
9c97b75
Merge remote-tracking branch 'origin/master'
mjarkk Aug 14, 2018
38a1a00
Fixed comment from myself on issue: 137
mjarkk Aug 14, 2018
be3f584
Added more translations
mjarkk Aug 14, 2018
3dba246
Added translations for files_panel.go and fixed some typos
mjarkk Aug 14, 2018
8418fa1
Fully translated pkg/gui/commit_message_panel.go
mjarkk Aug 15, 2018
d12cc5a
Fully translated pkg/gui/commits_panel.go
mjarkk Aug 15, 2018
7e926cf
Added translation for pkg/gui/ confirmation_panel.go gui.go merge_pan…
mjarkk Aug 15, 2018
10c5316
Merge pull request #3 from jesseduffield/master
mjarkk Aug 15, 2018
295093a
Translated pkg/gui/stash_panel.go
mjarkk Aug 15, 2018
50b41bf
Translated pkg/gui/view_helpers.go
mjarkk Aug 15, 2018
d00c46a
Added all english translations to a file and fixed some typos
mjarkk Aug 15, 2018
9112278
Merge pull request #4 from jesseduffield/master
mjarkk Aug 15, 2018
9abbfe5
Fully translated pkg/gui/confirmation_panel.go
mjarkk Aug 15, 2018
88e1a81
Fixed comment on issue #137 from @jesseduffield
mjarkk Aug 16, 2018
9074650
Fixed comments from jesseduffield on issue #137
mjarkk Aug 16, 2018
faf218f
Fixed comments from jesseduffield on issue #137
mjarkk Aug 16, 2018
fcf616b
Fixed it
mjarkk Aug 16, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
29 changes: 15 additions & 14 deletions pkg/gui/files_panel.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package gui

import (
"github.com/jesseduffield/lazygit/pkg/i18n"

// "io"
// "io/ioutil"
Expand Down Expand Up @@ -147,27 +148,27 @@ func (gui *Gui) handleIgnoreFile(g *gocui.Gui, v *gocui.View) error {

func (gui *Gui) renderfilesOptions(g *gocui.Gui, file *commands.File) error {
optionsMap := map[string]string{
"← → ↑ ↓": "navigate",
"S": "stash files",
"c": "commit changes",
"o": "open",
"i": "ignore",
"d": "delete",
"space": "toggle staged",
"R": "refresh",
"t": "add patch",
"e": "edit",
"PgUp/PgDn": "scroll",
"← → ↑ ↓": lang.SLocalize("navigate", "navigate"),
"S": lang.SLocalize("stashFiles", "stash files"),
"c": lang.SLocalize("CommitChanges", "commit changes"),
"o": lang.SLocalize("open", "open"),
"i": lang.SLocalize("ignore", "ignore"),
"d": lang.SLocalize("delete", "delete"),
"space": lang.SLocalize("toggleStaged", "toggle staged"),
"R": lang.SLocalize("refresh", "refresh"),
"t": lang.SLocalize("addPatch", "add patch"),
"e": lang.SLocalize("edit", "edit"),
"PgUp/PgDn": lang.SLocalize("scroll", "scroll"),
}
if gui.State.HasMergeConflicts {
optionsMap["a"] = "abort merge"
optionsMap["m"] = "resolve merge conflicts"
optionsMap["a"] = lang.SLocalize("abortMerge", "abort merge")
optionsMap["m"] = lang.SLocalize("resolveMergeConflicts", "resolve merge conflicts")
}
if file == nil {
return gui.renderOptionsMap(g, optionsMap)
}
if file.Tracked {
optionsMap["d"] = "checkout"
optionsMap["d"] = lang.SLocalize("checkout", "checkout")
}
return gui.renderOptionsMap(g, optionsMap)
}
Expand Down
17 changes: 9 additions & 8 deletions pkg/gui/gui.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import (
"github.com/golang-collections/collections/stack"
"github.com/jesseduffield/gocui"
"github.com/jesseduffield/lazygit/pkg/commands"
"github.com/jesseduffield/lazygit/pkg/i18n"
)

// OverlappingEdges determines if panel edges overlap
Expand Down Expand Up @@ -133,7 +134,7 @@ func (gui *Gui) layout(g *gocui.Gui) error {
if err != gocui.ErrUnknownView {
return err
}
v.Title = "Not enough space to render panels"
v.Title = lang.SLocalize("NotEnoughSpace", "Not enough space to render panels")
v.Wrap = true
}
return nil
Expand All @@ -152,7 +153,7 @@ func (gui *Gui) layout(g *gocui.Gui) error {
if err != gocui.ErrUnknownView {
return err
}
v.Title = "Diff"
v.Title = lang.SLocalize("DiffTitle", "Diff")
v.Wrap = true
v.FgColor = gocui.ColorWhite
}
Expand All @@ -161,7 +162,7 @@ func (gui *Gui) layout(g *gocui.Gui) error {
if err != gocui.ErrUnknownView {
return err
}
v.Title = "Status"
v.Title = lang.SLocalize("StatusTitle", "Status")
v.FgColor = gocui.ColorWhite
}

Expand All @@ -171,31 +172,31 @@ func (gui *Gui) layout(g *gocui.Gui) error {
return err
}
filesView.Highlight = true
filesView.Title = "Files"
filesView.Title = lang.SLocalize("FilesTitle", "Files")
v.FgColor = gocui.ColorWhite
}

if v, err := g.SetView("branches", 0, filesBranchesBoundary+panelSpacing, leftSideWidth, commitsBranchesBoundary, gocui.TOP|gocui.BOTTOM); err != nil {
if err != gocui.ErrUnknownView {
return err
}
v.Title = "Branches"
v.Title = lang.SLocalize("BranchesTitle", "Branches")
v.FgColor = gocui.ColorWhite
}

if v, err := g.SetView("commits", 0, commitsBranchesBoundary+panelSpacing, leftSideWidth, commitsStashBoundary, gocui.TOP|gocui.BOTTOM); err != nil {
if err != gocui.ErrUnknownView {
return err
}
v.Title = "Commits"
v.Title = lang.SLocalize("CommitsTitle", "Commits")
v.FgColor = gocui.ColorWhite
}

if v, err := g.SetView("stash", 0, commitsStashBoundary+panelSpacing, leftSideWidth, optionsTop, gocui.TOP|gocui.RIGHT); err != nil {
if err != gocui.ErrUnknownView {
return err
}
v.Title = "Stash"
v.Title = lang.SLocalize("StashTitle", "Stash")
v.FgColor = gocui.ColorWhite
}

Expand All @@ -214,7 +215,7 @@ func (gui *Gui) layout(g *gocui.Gui) error {
return err
}
g.SetViewOnBottom("commitMessage")
commitMessageView.Title = "Commit message"
commitMessageView.Title = lang.SLocalize("CommitMessage", "Commit message")
commitMessageView.FgColor = gocui.ColorWhite
commitMessageView.Editable = true
}
Expand Down
84 changes: 84 additions & 0 deletions pkg/i18n/dutch.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
package lang

import (
"github.com/nicksnyder/go-i18n/v2/i18n"
"golang.org/x/text/language"
)

// addDutch will add all the translations
func addDutch(i18nObject *i18n.Bundle) *i18n.Bundle {

// add the translations
i18nObject.AddMessages(language.Dutch,
&i18n.Message{
ID: "NotEnoughSpace",
Other: "Niet genoeg ruimte om de panelen te renderen",
}, &i18n.Message{
ID: "DiffTitle",
Other: "Diff",
}, &i18n.Message{
ID: "FilesTitle",
Other: "Bestanden",
}, &i18n.Message{
ID: "BranchesTitle",
Other: "Branches",
}, &i18n.Message{
ID: "CommitsTitle",
Other: "Commits",
}, &i18n.Message{
ID: "StashTitle",
Other: "Stash",
}, &i18n.Message{
ID: "CommitMessage",
Other: "Commit Bericht",
}, &i18n.Message{
ID: "CommitChanges",
Other: "Commit Veranderingen",
}, &i18n.Message{
ID: "StatusTitle",
Other: "Status",
}, &i18n.Message{
ID: "navigate",
Other: "navigeer",
}, &i18n.Message{
ID: "stashFiles",
Other: "stash-bestanden",
}, &i18n.Message{
ID: "open",
Other: "open",
}, &i18n.Message{
ID: "ignore",
Other: "negeren",
}, &i18n.Message{
ID: "delete",
Other: "verwijderen",
}, &i18n.Message{
ID: "toggleStaged",
Other: "toggle staged",
}, &i18n.Message{
ID: "refresh",
Other: "verversen",
}, &i18n.Message{
ID: "addPatch",
Other: "verandering toevoegen",
}, &i18n.Message{
ID: "edit",
Other: "veranderen",
}, &i18n.Message{
ID: "scroll",
Other: "scroll",
}, &i18n.Message{
ID: "abortMerge",
Other: "samenvoegen afbreken",
}, &i18n.Message{
ID: "resolveMergeConflicts",
Other: "verhelp samenvoegen fouten",
}, &i18n.Message{
ID: "checkout",
Other: "uitchecken",
},
)

// return the new i18nObject
return i18nObject
}
45 changes: 45 additions & 0 deletions pkg/i18n/i18n.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
package lang

import (
"github.com/cloudfoundry/jibber_jabber"
"github.com/nicksnyder/go-i18n/v2/i18n"
"golang.org/x/text/language"
)

// the function to setup the localizer
func getlocalizer() *i18n.Localizer {

// detect the user's language
userLang, _ := jibber_jabber.DetectLanguage()
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

NIIIICE!


// create a i18n bundle that can be used to add translations and other things
var i18nObject = &i18n.Bundle{DefaultLanguage: language.English}

// add translation file(s)
i18nObject = addDutch(i18nObject)

// return the new localizer that can be used to translate text
return i18n.NewLocalizer(i18nObject, userLang)
}

// setup the localizer for later use
var localizer = getlocalizer()

// Localize handels the translations
// expects i18n.LocalizeConfig as input: https://godoc.org/github.com/nicksnyder/go-i18n/v2/i18n#Localizer.MustLocalize
// output: translated string
func Localize(config *i18n.LocalizeConfig) string {
return localizer.MustLocalize(config)
}

// SLocalize (short localize) is for 1 line localizations
// ID: The id that is used in the .toml translation files
// Other: the default message it needs to return if there is no translation found or the system is english
func SLocalize(ID string, Other string) string {
return Localize(&i18n.LocalizeConfig{
DefaultMessage: &i18n.Message{
ID: ID,
Other: Other,
},
})
}