adonis adminify
1.0.0
แอปพลิเคชันแดชบอร์ดผู้ดูแลระบบที่ใช้ AdonisJs และ Adminify (อิงจาก Vuetify) ดูเพิ่มเติมที่ Adonis China คำสำคัญ: NodeJs, VueJs, AdonisJs, ORM, ความสัมพันธ์, SQLite, MySQL, มิดเดิลแวร์, Restful, CRUD, การออกแบบวัสดุ
git clone https://github.com/adonis-china/adonis-admin.git
cd adonis-admin
cp .env.example .env
npm install && npm run serve:dev
เริ่มต้นเซิร์ฟเวอร์ api./ace migration:refresh --seed
ฐานข้อมูลเติม (ใช้ node ace
บน windows)git submodule update --recursive --remote --init
pull submodulecd adminify
cp src/config.sample.js src/config.js
ใช้ copy
บน windowsdebug.mock
เป็น false
ใน src/config.js
npm install && npm run dev
เริ่มต้นไคลเอนต์http://localhost:8080
(หรือพอร์ตอื่น) ในเบราว์เซอร์ของคุณใช้
cnpm
แทนnpm
ในประเทศจีน
./ace make:model -m Page
สร้างโมเดล Page
ด้วยการย้ายข้อมูลสำหรับการจัดการ เพจ/database/migrations/1496388160682_create_page_table.js
เพิ่มบางฟิลด์: table . increments ( )
table . integer ( 'type_id' ) . unsigned ( ) . nullable ( )
table . foreign ( 'type_id' ) . references ( 'types.id' )
table . string ( 'title' ) . notNullable ( )
table . text ( 'body' )
table . timestamps ( )
./ace migration:run
เพื่อสร้างตาราง/app/Model/Page.js
เพิ่มความสัมพันธ์ belongsTo
: class Page extends Lucid {
type ( ) {
return this . belongsTo ( 'App/Model/Type' )
}
}
/app/Http/Controllers/Admin/Api/EmptyController.js
ไปที่ PageController.js
และเปลี่ยนเป็น: 'use strict'
const RestController = require ( './RestController' )
const Page = use ( 'App/Model/Page' )
const Type = use ( 'App/Model/Type' )
class PageController extends RestController {
get resource ( ) {
return 'pages'
}
get expand ( ) {
return [ 'type' ]
}
* gridData ( ) {
//change the fields
return {
options : {
sort : 'id' , //or '-id' as desc
create : true ,
update : true ,
delete : true
} ,
// filters: false,
filters : {
model : {
title : '' ,
created_at : ''
} ,
fields : {
title : { label : 'Title' } ,
created_at : { label : t ( 'fields.Page.created_at' ) , Page : 'date' }
} ,
rules : { } ,
} ,
columns : [
{ text : t ( 'fields.Page.id' ) , value : 'id' } ,
{ text : t ( 'fields.Page.title' ) , value : 'title' }
]
}
}
* formData ( request , response ) {
let model = {
title : '' ,
type_id : null ,
body : '' ,
}
let id
if ( request ) {
id = request . input ( 'id' )
if ( id ) {
model = yield Page . query ( ) . where ( 'id' , id ) . first ( )
}
}
let typeOptions = yield Type . query ( ) . select ( 'id' , 'name' ) . fetch ( )
for ( let type of typeOptions ) {
type . text = type . name
type . value = type . id
}
return {
model : model ,
fields : {
title : { label : 'Title' , hint : 'Page Title' , required : true } ,
type_id : {
label : 'Type' , type : 'select' , options : typeOptions , required : true ,
} ,
body : { label : 'Body' , type : 'html' , required : false } ,
} ,
rules : model . rules ,
messages : model . messages
}
}
}
module . exports = PageController
/app/Http/routes.js:26
const resources = [ 'posts' , 'users' , 'types' , 'comments' , 'settings' , 'pages' ]
/adminify/src/menu.js
จากนั้นคุณจะเห็นว่ามันแสดงในเมนูด้านซ้าย { "href" : " /crud/pages " , "title" : " Pages " , "icon" : " view_list " },
http://localhost:8080/#/crud/pages
คุณจะได้รับมุมมองรายการตารางของทุกหน้าplus
เพื่อเพิ่มหน้า และคุณสามารถแก้ไขได้หลังจากเพิ่มแล้ว