diff --git a/models/user/user.go b/models/user/user.go index e375f3de0a..680bd61f50 100644 --- a/models/user/user.go +++ b/models/user/user.go @@ -94,6 +94,7 @@ type User struct { LoginName string Type UserType Location string + LocationCoordinate string Website string Rands string `xorm:"VARCHAR(32)"` Salt string `xorm:"VARCHAR(32)"` @@ -187,6 +188,7 @@ func (u *User) BeforeUpdate() { u.LowerName = strings.ToLower(u.Name) u.Location = base.TruncateString(u.Location, 255) + u.LocationCoordinate = base.TruncateString(u.LocationCoordinate, 255) u.Website = base.TruncateString(u.Website, 255) u.Description = base.TruncateString(u.Description, 255) } diff --git a/modules/convert/convert.go b/modules/convert/convert.go index 41a044c6d7..bbb89f97e6 100644 --- a/modules/convert/convert.go +++ b/modules/convert/convert.go @@ -289,6 +289,7 @@ func ToOrganization(org *models.Organization) *api.Organization { Description: org.Description, Website: org.Website, Location: org.Location, + LocationCoordinate: org.LocationCoordinate, Visibility: org.Visibility.String(), RepoAdminChangeTeamAccess: org.RepoAdminChangeTeamAccess, } diff --git a/modules/convert/user.go b/modules/convert/user.go index dc4a8c49c7..5f9ba9fc3d 100644 --- a/modules/convert/user.go +++ b/modules/convert/user.go @@ -55,6 +55,7 @@ func toUser(user *user_model.User, signed, authed bool) *api.User { Created: user.CreatedUnix.AsTime(), Restricted: user.IsRestricted, Location: user.Location, + LocationCoordinate: user.LocationCoordinate, Website: user.Website, Description: user.Description, // counter's @@ -87,6 +88,7 @@ func User2UserSettings(user *user_model.User) api.UserSettings { FullName: user.FullName, Website: user.Website, Location: user.Location, + LocationCoordinate: user.LocationCoordinate, Language: user.Language, Description: user.Description, Theme: user.Theme, diff --git a/modules/structs/admin_user.go b/modules/structs/admin_user.go index eccbf29a46..ea52caa64a 100644 --- a/modules/structs/admin_user.go +++ b/modules/structs/admin_user.go @@ -36,6 +36,7 @@ type EditUserOption struct { MustChangePassword *bool `json:"must_change_password"` Website *string `json:"website" binding:"OmitEmpty;ValidUrl;MaxSize(255)"` Location *string `json:"location" binding:"MaxSize(50)"` + LocationCoordinate *string `json:"location_coordinate" binding:"MaxSize(255)"` Description *string `json:"description" binding:"MaxSize(255)"` Active *bool `json:"active"` Admin *bool `json:"admin"` diff --git a/modules/structs/org.go b/modules/structs/org.go index d8bd59e1ec..7716465754 100644 --- a/modules/structs/org.go +++ b/modules/structs/org.go @@ -13,6 +13,7 @@ type Organization struct { Description string `json:"description"` Website string `json:"website"` Location string `json:"location"` + LocationCoordinate string `json:"location_coordinate"` Visibility string `json:"visibility"` RepoAdminChangeTeamAccess bool `json:"repo_admin_change_team_access"` } @@ -34,6 +35,7 @@ type CreateOrgOption struct { Description string `json:"description" binding:"MaxSize(255)"` Website string `json:"website" binding:"ValidUrl;MaxSize(255)"` Location string `json:"location" binding:"MaxSize(50)"` + LocationCoordinate string `json:"location_coordinate" binding:"MaxSize(255)"` // possible values are `public` (default), `limited` or `private` // enum: public,limited,private Visibility string `json:"visibility" binding:"In(,public,limited,private)"` @@ -48,6 +50,7 @@ type EditOrgOption struct { Description string `json:"description" binding:"MaxSize(255)"` Website string `json:"website" binding:"ValidUrl;MaxSize(255)"` Location string `json:"location" binding:"MaxSize(50)"` + LocationCoordinate string `json:"location_coordinate" binding:"MaxSize(255)"` // possible values are `public`, `limited` or `private` // enum: public,limited,private Visibility string `json:"visibility" binding:"In(,public,limited,private)"` diff --git a/modules/structs/user.go b/modules/structs/user.go index 431e230fac..2c50935265 100644 --- a/modules/structs/user.go +++ b/modules/structs/user.go @@ -39,6 +39,8 @@ type User struct { ProhibitLogin bool `json:"prohibit_login"` // the user's location Location string `json:"location"` + // the user's location coordinate + LocationCoordinate string `json:"location_coordinate"` // the user's website Website string `json:"website"` // the user's description @@ -69,6 +71,7 @@ type UserSettings struct { Website string `json:"website"` Description string `json:"description"` Location string `json:"location"` + LocationCoordinate string `json:"location_coordinate"` Language string `json:"language"` Theme string `json:"theme"` DiffViewStyle string `json:"diff_view_style"` @@ -84,6 +87,7 @@ type UserSettingsOptions struct { Website *string `json:"website" binding:"OmitEmpty;ValidUrl;MaxSize(255)"` Description *string `json:"description" binding:"MaxSize(255)"` Location *string `json:"location" binding:"MaxSize(50)"` + LocationCoordinate *string `json:"location_coordinate" binding:"MaxSize(255)"` Language *string `json:"language"` Theme *string `json:"theme"` DiffViewStyle *string `json:"diff_view_style"` diff --git a/options/locale/locale_ru-RU.ini b/options/locale/locale_ru-RU.ini index 0111dfe434..67d6b9bf94 100644 --- a/options/locale/locale_ru-RU.ini +++ b/options/locale/locale_ru-RU.ini @@ -524,6 +524,7 @@ password_username_disabled=Нелокальным пользователям з full_name=Имя и фамилия website=Веб-сайт location=Местоположение +locationcoordinate=Координаты update_theme=Обновить тему update_profile=Обновить профиль update_language=Обновить язык @@ -2188,6 +2189,7 @@ settings.options=Организация settings.full_name=Полное имя settings.website=Сайт settings.location=Местоположение +settings.locationcoordinate=Координаты settings.permission=Разрешения settings.repoadminchangeteam=Администратор репозитория может добавлять и удалять права доступа для команд settings.visibility=Видимость diff --git a/routers/api/v1/admin/org.go b/routers/api/v1/admin/org.go index bdfe87fd4e..40d67f5e62 100644 --- a/routers/api/v1/admin/org.go +++ b/routers/api/v1/admin/org.go @@ -62,6 +62,7 @@ func CreateOrg(ctx *context.APIContext) { Description: form.Description, Website: form.Website, Location: form.Location, + LocationCoordinate: form.LocationCoordinate, IsActive: true, Type: user_model.UserTypeOrganization, Visibility: visibility, diff --git a/routers/api/v1/admin/user.go b/routers/api/v1/admin/user.go index 7262073bbd..a987e59096 100644 --- a/routers/api/v1/admin/user.go +++ b/routers/api/v1/admin/user.go @@ -240,6 +240,9 @@ func EditUser(ctx *context.APIContext) { if form.Location != nil { u.Location = *form.Location } + if form.LocationCoordinate != nil { + u.LocationCoordinate = *form.LocationCoordinate + } if form.Description != nil { u.Description = *form.Description } diff --git a/routers/api/v1/org/org.go b/routers/api/v1/org/org.go index 133cce3416..817d6d5c98 100644 --- a/routers/api/v1/org/org.go +++ b/routers/api/v1/org/org.go @@ -267,6 +267,7 @@ func Create(ctx *context.APIContext) { Description: form.Description, Website: form.Website, Location: form.Location, + LocationCoordinate: form.LocationCoordinate, IsActive: true, Type: user_model.UserTypeOrganization, Visibility: visibility, @@ -340,6 +341,7 @@ func Edit(ctx *context.APIContext) { org.Description = form.Description org.Website = form.Website org.Location = form.Location + org.LocationCoordinate = form.LocationCoordinate if form.Visibility != "" { org.Visibility = api.VisibilityModes[form.Visibility] } diff --git a/routers/api/v1/user/settings.go b/routers/api/v1/user/settings.go index 5f4d76ed72..8f01da4543 100644 --- a/routers/api/v1/user/settings.go +++ b/routers/api/v1/user/settings.go @@ -57,6 +57,9 @@ func UpdateUserSettings(ctx *context.APIContext) { if form.Location != nil { ctx.User.Location = *form.Location } + if form.LocationCoordinate != nil { + ctx.User.LocationCoordinate = *form.LocationCoordinate + } if form.Language != nil { ctx.User.Language = *form.Language } diff --git a/routers/web/admin/users.go b/routers/web/admin/users.go index 1576f58b41..8aaa654a39 100644 --- a/routers/web/admin/users.go +++ b/routers/web/admin/users.go @@ -372,6 +372,7 @@ func EditUserPost(ctx *context.Context) { u.Email = form.Email u.Website = form.Website u.Location = form.Location + u.LocationCoordinate = form.LocationCoordinate u.MaxRepoCreation = form.MaxRepoCreation u.IsActive = form.Active u.IsAdmin = form.Admin diff --git a/routers/web/org/setting.go b/routers/web/org/setting.go index 081e103f79..16f83f8b80 100644 --- a/routers/web/org/setting.go +++ b/routers/web/org/setting.go @@ -100,6 +100,7 @@ func SettingsPost(ctx *context.Context) { org.Description = form.Description org.Website = form.Website org.Location = form.Location + org.LocationCoordinate = form.LocationCoordinate org.RepoAdminChangeTeamAccess = form.RepoAdminChangeTeamAccess visibilityChanged := form.Visibility != org.Visibility diff --git a/routers/web/user/setting/profile.go b/routers/web/user/setting/profile.go index ab156b43fc..ddc5a7c47d 100644 --- a/routers/web/user/setting/profile.go +++ b/routers/web/user/setting/profile.go @@ -119,6 +119,7 @@ func ProfilePost(ctx *context.Context) { ctx.User.KeepEmailPrivate = form.KeepEmailPrivate ctx.User.Website = form.Website ctx.User.Location = form.Location + ctx.User.LocationCoordinate = form.LocationCoordinate ctx.User.Description = form.Description ctx.User.KeepActivityPrivate = form.KeepActivityPrivate ctx.User.Visibility = form.Visibility diff --git a/services/forms/admin.go b/services/forms/admin.go index 5abef0550e..435e5d4c15 100644 --- a/services/forms/admin.go +++ b/services/forms/admin.go @@ -42,6 +42,7 @@ type AdminEditUserForm struct { Password string `binding:"MaxSize(255)"` Website string `binding:"ValidUrl;MaxSize(255)"` Location string `binding:"MaxSize(50)"` + LocationCoordinate string `binding:"MaxSize(255)"` MaxRepoCreation int Active bool Admin bool diff --git a/services/forms/org.go b/services/forms/org.go index dec2dbfa65..3239ee80fb 100644 --- a/services/forms/org.go +++ b/services/forms/org.go @@ -42,6 +42,7 @@ type UpdateOrgSettingForm struct { Description string `binding:"MaxSize(255)"` Website string `binding:"ValidUrl;MaxSize(255)"` Location string `binding:"MaxSize(50)"` + LocationCoordinate string `binding:"MaxSize(255)"` Visibility structs.VisibleType MaxRepoCreation int RepoAdminChangeTeamAccess bool diff --git a/services/forms/user_form.go b/services/forms/user_form.go index a886e89f87..40ef2c1c19 100644 --- a/services/forms/user_form.go +++ b/services/forms/user_form.go @@ -245,6 +245,7 @@ type UpdateProfileForm struct { KeepEmailPrivate bool Website string `binding:"ValidSiteUrl;MaxSize(255)"` Location string `binding:"MaxSize(50)"` + LocationCoordinate string `binding:"MaxSize(255)"` Description string `binding:"MaxSize(255)"` Visibility structs.VisibleType KeepActivityPrivate bool diff --git a/templates/admin/user/edit.tmpl b/templates/admin/user/edit.tmpl index 17bd2b936c..f88e2bbc56 100644 --- a/templates/admin/user/edit.tmpl +++ b/templates/admin/user/edit.tmpl @@ -81,6 +81,10 @@ +
{{$.RenderedDescription|Str2html}}
{{end}}