Documentation
¶
Index ¶
- Constants
- func Error(texts ...string) *err
- type AfterCreate
- type AfterDelete
- type AfterUpdate
- type BackendHandler
- type BootActions
- type BootResponse
- type CreateApi
- type CutData
- type CutResponse
- type DataBaseAdapter
- type DeleteApi
- type DomAdapter
- type Field
- type FileApi
- type FrontendBootActions
- type FrontendHandler
- type Icon
- type Input
- type Module
- type ModuleHandlers
- type Object
- func (o Object) Columns() (columns []string)
- func (o Object) DataDecode(cut_data ...CutData) ([]map[string]string, error)
- func (o Object) DataEncode(all_data ...map[string]string) (out []CutData)
- func (o Object) FieldExist(field_name string) (Field, bool)
- func (o Object) FilterFields(namesRequired ...string) (fielsOut []Field)
- func (o Object) FilterRemoveFields(namesToRemove ...string) (fielsOut []Field)
- func (o Object) GetFieldByName(required_name string) (Field, error)
- func (o Object) GetID(data_search map[string]string) string
- func (o Object) GetRepresentativeTextField(data_element map[string]string) (values string)
- func (o Object) MainName() string
- func (o Object) PrimaryKeyName() string
- func (o Object) RenderFields() (fielsOut []Field)
- func (o Object) RequiredFields() (fielsOut []Field)
- func (o *Object) Response(action, message string, data ...map[string]string) Response
- func (o Object) TestData(required_objects int, skip_id, wrong_data bool) ([]map[string]string, error)
- func (o Object) ValidateData(its_new, its_update_or_delete bool, all_data ...map[string]string) error
- type Package
- type Page
- type Path
- type Permission
- type ReadApi
- type Request
- type Response
- type SourceData
- type Tag
- type TestData
- type ThemeAdapter
- type TimeAdapter
- type UI
- type UpdateApi
- type User
- type Validate
Constants ¶
View Source
const INPUT_PATTERN = `input\.(\w+)\([^)]*\)`
View Source
const PREFIX_ID_NAME = "id_"
Variables ¶
This section is empty.
Functions ¶
Types ¶
type AfterCreate ¶ added in v0.0.46
type AfterDelete ¶ added in v0.0.46
type AfterUpdate ¶ added in v0.0.46
type BackendHandler ¶ added in v0.0.46
type BootActions ¶ added in v0.0.44
type BootActions struct {
JsonBootActions string
}
type BootResponse ¶ added in v0.0.45
type CutData ¶ added in v0.0.19
type CutData struct {
// ej Modelo Objeto: usuario := Object{Name: "Usuario",Fields: []Field{
// {Name: "name"}, //0
// {Name: "email"},//1
// {Name: "phone"},//2
// },}
// ej data normal con todos los campos: {"name":"John Doe","email":"johndoe@example.com","phone":"555"}
// version recortada Data: {"John Doe","johndoe@example.com","555"}
// Index Objeto al codificar = {"0:0","1:1","2:2"}
// ej no mail: {"marcel", "777"}
// Index al codificar = {"0:0","1:2"}
Index map[uint8]uint8 `json:"i"`
//Data ej en mapa: "Data":[{"id":"222","name":"manzana","valor":"1200"}]
// ahora: "Data":["222","manzana","1200"]
Data []string `json:"d"`
}
type CutResponse ¶ added in v0.0.19
type CutResponse struct {
//Action,Object,Module,Message
//ej: ["create","user","ModuleUsers","ok"]
CutOptions []string `json:"o"`
CutData []CutData `json:"d"`
}
func (*CutResponse) CutResponseDecode ¶ added in v0.0.21
func (cr *CutResponse) CutResponseDecode(data []map[string]string) (out Response)
type DataBaseAdapter ¶ added in v0.0.35
type DataBaseAdapter interface {
CreateObjectsInDB(table_name string, data ...map[string]string) error
// from_tables ej: "users,products" or: public.reservation, public.patient"
// data ... map[string]string ej:{
// LIMIT: 10, 5, 100. note: Postgres y MySQL: "LIMIT 10", SQLite: "LIMIT 10 OFFSET 0" OR "" no limit
// ORDER_BY: name,phone,address
// SELECT: "name, phone, address" default *
// WHERE: "patient.id_patient = reservation.id_patient AND reservation.id_staff = '2'"
// ARGS: "1,4,33"
// }
ReadObjectsInDB(from_tables string, data ...map[string]string) ([]map[string]string, error)
UpdateObjectsInDB(table_name string, data ...map[string]string) ([]map[string]string, error)
DeleteObjectsInDB(table_name string, data ...map[string]string) ([]map[string]string, error)
CreateTablesInDB(...*Object) error
}
type DomAdapter ¶ added in v0.0.47
type DomAdapter interface{}
type Field ¶
type Field struct {
// si el campo comienza com id_ se considera como único y perteneciente a una tabla específica ej: id_user su tabla es user
// otros ej: id_usuario, apellido, address, city etc
Name string
Legend string //como se mostrara al usuario el campo en el encabezado ej: "name" por "Nombre Usuario"
NotRenderHtml bool // si no se necesita en formulario html
*Input
SkipCompletionAllowed bool //se permite que el campo no este completado. por defecto siempre sera requerido
Unique bool //campo único e inalterable en db
NotRequiredInDB bool // campo no requerido en base de datos al crear tabla
Encrypted bool // si estará encriptado su almacenamiento o no
}
func (Field) IsPrimaryKey ¶ added in v0.0.35
type FrontendBootActions ¶ added in v0.0.45
type FrontendBootActions interface {
}
type FrontendHandler ¶ added in v0.0.46
type FrontendHandler struct {
AfterCreate
AfterUpdate
AfterDelete
}
type Module ¶
type Module struct {
//nombre modulo ej: chat,patient,user
ModuleName string
//Titulo que vera el usuario ej: "Modulo Fotografía"
Title string
// id icono para utilizar en sprite svg ej: icon-info
IconID string
//interfaz usuario modulo
UI
// ej: `<div class="target-module">
// <select name="select">
// <option value="value1">Value 1</option>
// <option value="value2" selected>Value 2</option>
// </select>
// </div>`
HeaderInputTarget string
//areas soportadas por el modulo ej: 'a','t','x'
Areas []byte
// objetos o componentes que contiene el modulo ej: patient,user,datalist,search....
Objects []*Object
*ModuleHandlers
}
type ModuleHandlers ¶ added in v0.0.47
type ModuleHandlers struct {
Theme ThemeAdapter
DBA DataBaseAdapter
Time TimeAdapter
DOM DomAdapter
}
type Object ¶
type Object struct {
// ej: client, search_footer,datalist
Name string
TextFieldNames []string //nombre de campos mas representativos ej: name, address, phone
Fields []Field //campos
*Module // módulo origen
BackendHandler
FrontendHandler
}
func (Object) DataDecode ¶ added in v0.0.19
func (Object) DataEncode ¶ added in v0.0.19
DataEncode quita los nombres de los campos de la data según modelo del objeto
func (Object) FieldExist ¶ added in v0.0.16
func (Object) FilterFields ¶
func (Object) FilterRemoveFields ¶
func (Object) GetRepresentativeTextField ¶
func (Object) RenderFields ¶
func (Object) RequiredFields ¶
type Package ¶ added in v0.0.35
type Package struct {
SkipMeInResponse bool `json:"-"` // saltarme al difundir
Recipients []string `json:"-"` // lista de ip, token o ids según app para el reenvió al finalizar solicitud
TargetArea bool `json:"-"` // si es falso el destino por defecto es publico de lo contrario sera para todos quines tengan la misma area del usuario solicitante
Response
}
type Page ¶ added in v0.0.33
type Page struct {
StyleSheet string // url ej style.css
AppName string
AppVersion string
SpriteIcons string
Menu string
UserName string
UserArea string
Message string
Modules string
Script string // ej main.js
JsonBootActions string //index ej <meta name="JsonBootActions" content="{{.JsonBootActions}}">
}
index.html ej: {{.StyleSheet}} {{.AppName}} {{.AppVersion}} {{.SpriteIcons}} {{.Menu}} {{.Message}} {{.UserName}} {{.UserArea}} {{.Modules}} {{.Script}} {{.Data}}
type Path ¶ added in v0.0.27
type Path interface {
FolderPath() string
}
FolderPath() string ej: func (Object) FolderPath() string { _, filename, _, _ := runtime.Caller(0) dir := filepath.Dir(filename) return filepath.ToSlash(dir) }
type Permission ¶
type Response ¶
type Response struct {
Action string `json:"a,omitempty"` //acción a realizar con la solicitud: create, read, update, delete o error
Object string `json:"o,omitempty"` //nombre de la tabla u objeto controlador hacia donde va la solicitud
Message string `json:"g,omitempty"` //mensaje para el usuario de la solicitud
Data []map[string]string `json:"d,omitempty"` //data entrada y respuesta json
}
type SourceData ¶ added in v0.0.44
type ThemeAdapter ¶ added in v0.0.47
type ThemeAdapter interface {
// MenuButtonTemplate ej: <li class="navbar-item"><a href="#` + module_name + `" tabindex="` + index + `" class="navbar-link" name="` + module_name + `">
// <svg aria-hidden="true" focusable="false" class="fa-primary"><use xlink:href="#` + icon_id + `" /></svg>
// <span class="link-text">` + title + `</span></a></li>
MenuButtonTemplate(module_name, index, icon_id, title string) string
MenuClassName() string // ej: .menu-container
MenuItemClass() string // ej: navbar-item
ModuleClassName() string //ej: slider_panel
ModuleTemplate(m *Module, form *Object, options ...string) string
FunctionMessageName() string // ej: ShowMessageToUser
}
type TimeAdapter ¶ added in v0.0.47
type User ¶
type User struct {
Token string // token de sesión solicitante
Id string // id usuario
Ip string
Name string
Area string //0 sin area.. un que byte y uint8 son lo mismo en go la idea que aca sea un valor de carácter ej: a,s,p...
AccessLevel string // aquí valor numérico 0 a 255
LastConnection string //time.Time
}
Source Files
¶
- adapter-api.go
- adapter-auth.go
- adapter-boot-actions.go
- adapter-data.go
- adapter-db.go
- adapter-dom.go
- adapter-folder-path.go
- adapter-theme.go
- adapter-time.go
- adapter-ui.go
- cut-decode.go
- cut-encode.go
- error.go
- field.go
- icon.go
- input.go
- module.go
- object-message.go
- object-test-data.go
- object-validate.go
- object.go
- object_methods.go
- page.go
- permission.go
- request.go
- response.go
- user.go
Click to show internal directories.
Click to hide internal directories.