/
authors.go
39 lines (30 loc) · 1.48 KB
/
authors.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
package datamodel
import (
"github.com/GoAdminGroup/go-admin/context"
"github.com/GoAdminGroup/go-admin/modules/db"
"github.com/GoAdminGroup/go-admin/plugins/admin/modules/table"
"github.com/GoAdminGroup/go-admin/template/types/form"
)
// GetAuthorsTable return the model of table author.
func GetAuthorsTable(ctx *context.Context) (authorsTable table.Table) {
authorsTable = table.NewDefaultTable(table.DefaultConfig())
// connect your custom connection
// authorsTable = table.NewDefaultTable(table.DefaultConfigWithDriverAndConnection("mysql", "admin"))
info := authorsTable.GetInfo()
info.AddField("ID", "id", db.Int).FieldSortable()
info.AddField("First Name", "first_name", db.Varchar)
info.AddField("Last Name", "last_name", db.Varchar)
info.AddField("Email", "email", db.Varchar)
info.AddField("Birthdate", "birthdate", db.Date)
info.AddField("Added", "added", db.Timestamp)
info.SetTable("authors").SetTitle("Authors").SetDescription("Authors")
formList := authorsTable.GetForm()
formList.AddField("ID", "id", db.Int, form.Default).FieldNotAllowEdit().FieldNotAllowAdd()
formList.AddField("First Name", "first_name", db.Varchar, form.Text)
formList.AddField("Last Name", "last_name", db.Varchar, form.Text)
formList.AddField("Email", "email", db.Varchar, form.Text)
formList.AddField("Birthdate", "birthdate", db.Date, form.Text)
formList.AddField("Added", "added", db.Timestamp, form.Text)
formList.SetTable("authors").SetTitle("Authors").SetDescription("Authors")
return
}