|
@@ -1,9 +1,11 @@
|
|
package views
|
|
package views
|
|
|
|
|
|
import (
|
|
import (
|
|
|
|
+ "errors"
|
|
"fmt"
|
|
"fmt"
|
|
"net/url"
|
|
"net/url"
|
|
"reflect"
|
|
"reflect"
|
|
|
|
+ "time"
|
|
|
|
|
|
"github.com/qor5/admin/activity"
|
|
"github.com/qor5/admin/activity"
|
|
"github.com/qor5/admin/l10n"
|
|
"github.com/qor5/admin/l10n"
|
|
@@ -31,6 +33,8 @@ func Configure(b *presets.Builder, db *gorm.DB, lb *l10n.Builder, ab *activity.A
|
|
l10nONModel.L10nON()
|
|
l10nONModel.L10nON()
|
|
}
|
|
}
|
|
m.Listing().Field("Locale")
|
|
m.Listing().Field("Locale")
|
|
|
|
+ m.Editing().Field("Locale")
|
|
|
|
+
|
|
searcher := m.Listing().Searcher
|
|
searcher := m.Listing().Searcher
|
|
m.Listing().SearchFunc(func(model interface{}, params *presets.SearchParams, ctx *web.EventContext) (r interface{}, totalCount int, err error) {
|
|
m.Listing().SearchFunc(func(model interface{}, params *presets.SearchParams, ctx *web.EventContext) (r interface{}, totalCount int, err error) {
|
|
if localeCode := ctx.R.Context().Value(l10n.LocaleCode); localeCode != nil {
|
|
if localeCode := ctx.R.Context().Value(l10n.LocaleCode); localeCode != nil {
|
|
@@ -58,6 +62,25 @@ func Configure(b *presets.Builder, db *gorm.DB, lb *l10n.Builder, ab *activity.A
|
|
}
|
|
}
|
|
})
|
|
})
|
|
|
|
|
|
|
|
+ deleter := m.Editing().Deleter
|
|
|
|
+ m.Editing().DeleteFunc(func(obj interface{}, id string, ctx *web.EventContext) (err error) {
|
|
|
|
+ if err = deleter(obj, id, ctx); err != nil {
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ locale := obj.(presets.SlugDecoder).PrimaryColumnValuesBySlug(id)["locale_code"]
|
|
|
|
+ locale = fmt.Sprintf("%s(del:%d)", locale, time.Now().UnixMilli())
|
|
|
|
+
|
|
|
|
+ withoutKeys := []string{}
|
|
|
|
+ if ctx.R.URL.Query().Get("all_versions") == "true" {
|
|
|
|
+ withoutKeys = append(withoutKeys, "version")
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if err = utils.PrimarySluggerWhere(db.Unscoped(), obj, id, withoutKeys...).Update("locale_code", locale).Error; err != nil {
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ return
|
|
|
|
+ })
|
|
|
|
+
|
|
rmb := m.Listing().RowMenu()
|
|
rmb := m.Listing().RowMenu()
|
|
rmb.RowMenuItem("Localize").ComponentFunc(localizeRowMenuItemFunc(m.Info(), "", url.Values{}))
|
|
rmb.RowMenuItem("Localize").ComponentFunc(localizeRowMenuItemFunc(m.Info(), "", url.Values{}))
|
|
|
|
|
|
@@ -70,9 +93,22 @@ func Configure(b *presets.Builder, db *gorm.DB, lb *l10n.Builder, ab *activity.A
|
|
b.FieldDefaults(presets.WRITE).
|
|
b.FieldDefaults(presets.WRITE).
|
|
FieldType(l10n.Locale{}).
|
|
FieldType(l10n.Locale{}).
|
|
ComponentFunc(func(obj interface{}, field *presets.FieldContext, ctx *web.EventContext) h.HTMLComponent {
|
|
ComponentFunc(func(obj interface{}, field *presets.FieldContext, ctx *web.EventContext) h.HTMLComponent {
|
|
- return nil
|
|
|
|
|
|
+ var value string
|
|
|
|
+ id, err := reflectutils.Get(obj, "ID")
|
|
|
|
+ if err == nil && len(fmt.Sprint(id)) > 0 && fmt.Sprint(id) != "0" {
|
|
|
|
+ value = field.Value(obj).(l10n.Locale).GetLocale()
|
|
|
|
+ } else {
|
|
|
|
+ value = lb.GetCorrectLocaleCode(ctx.R)
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return h.Input("").Type("hidden").Value(value).Attr(web.VFieldName("LocaleCode")...)
|
|
}).
|
|
}).
|
|
SetterFunc(func(obj interface{}, field *presets.FieldContext, ctx *web.EventContext) (err error) {
|
|
SetterFunc(func(obj interface{}, field *presets.FieldContext, ctx *web.EventContext) (err error) {
|
|
|
|
+ value := field.Value(obj).(l10n.Locale).GetLocale()
|
|
|
|
+ if !utils.Contains(lb.GetSupportLocaleCodesFromRequest(ctx.R), value) {
|
|
|
|
+ return errors.New("Incorrect locale.")
|
|
|
|
+ }
|
|
|
|
+
|
|
return nil
|
|
return nil
|
|
})
|
|
})
|
|
|
|
|