Skip to content

Latest commit

 

History

History
244 lines (153 loc) · 8.96 KB

README.md

File metadata and controls

244 lines (153 loc) · 8.96 KB

Yao-amis-admin

介绍

本项目的目标是快速开发管理后台项目。

  • 使用 Yao项目 作为项目后端的执行引擎。yao引擎提供了丰富的后台功能,但是上手会比较费力,需要手动编写很多的json配置文件。这个项目降低了yao的上手难度,快速的搭建一个数据管理后台。这个平台的使用步骤如下:

    • 系统安装,这个项目已提供了打包好的容器影像。
    • 创建模型,模型是驱动api,后台页面的基础。使用这个平台的第一步是创建业务模型,模型创建可以使用图形化的界面进行操作。
    • 数据维护,当创建好模型后,就可以维护数据,平台会根据模型配置动态生成数据维护界面。
    • 定制开发,当熟悉这个平台或是Yao开发引擎后,可以进行自定义的开发您的API,后台处理接口,增强处理数据插件等等,也可以使用新的前台处理界面,所有一切都可以扩展。
  • 使用 amis-sdk 作为项目前端的解决方案,快速的使用 json 配置出 crud 界面。amis 框架是一个前端低代码解决方案,可以通过 json 文件配置出页面,包含表单、表格、图表等丰富组件,amis 可以通过前端图形化配置出页面,同时也支持通过代码配置,管理后台 99%的页面都是使用 amis-json 标准配置。

  • 使用 Amis 编辑器作表单配置工具。

  • 使用 soybean-admin 作为自定义开发前端的解决方案,把amis-sdk嵌入到页签里。

利用 amis 的前端优势与 yao 的后端优势,我们可以开发出一个页面可随意定制的前后端分离的中后台管理系统。

更详细的说明与教程

安装

使用容器运行,已打包编辑器与 soy-admin。

docker run -d -p 5099:5099 wwsheng009/yao-amis-admin-amd64:latest

在浏览器里访问地址:http://localhost:5099/, 进行初始化安装,选择数据库的类型并输入数据库的相关信息后确定安装。

管理员用户名:xiang@iqka.com 密码:A123456p+

使用已有的配置文件:

# for manual config
touch .env
# for upload files
mkdir upload

mkdir logs

docker run -d --name=yao-amis-admin \
    -v ./.env:/data/app/.env \
    -v ./upload:/data/app/data/upload \
    -v ./logs:/data/app/logs \
    -p 5099:5099 \
    wwsheng009/yao-amis-admin-amd64:latest

# for ipv6
docker network create --ipv6 ip6net

docker run -d --name=yao-amis-admin \
    --network ip6net \
    -v ./.env:/data/app/.env \
    -v ./upload:/data/app/data/upload \
    -v ./logs:/data/app/logs \
    -p 5099:5099 \
    wwsheng009/yao-amis-admin-amd64:latest

演示地址:

演示地址:demo,用户名:xiang@iqka.com 密码:A123456p+

entry model_create

特性列表

基础功能

  • 图形化 Yao 模型管理,不需要写代码即可配置出业务数据模型定义。
  • 模型 API 自动生成,模型定义后,对应的外部 CRUD 接口直接可用,无须额外配置。
  • Amis 页面代码生成,预览,生成标准格式的 amis 页面配置,快速开发 CRUD 页面。
  • 集成了 Amis 页面编辑器,在页面编辑器创建页面后管理后台直接可以使用,页面编辑器可直接使用后台的 API,无须额外配置。
  • 文件管理,支持个人文件管理,公共文件管理,项目文件管理。非公共文件管理支持权限管控。
  • Xgen 登录集成/Amis 页面编辑器集成/Soy-Admin 管理后台集成。
  • 菜单管理配置。
  • 集成了XGEN的AI聊天功能。

业务功能

  • 支持用户注册/管理,支持用户角色权限配置。
  • 动态表数据维护,支持子表,关联表数据显示/维护。
  • 开箱即用的博客功能,博客功能支持 MetaWeblog Api,可以使用外部编辑器发布文章到管理后台。
  • 支持 Odata 数据读取接口,可以在 excel 中同步模型数据。
  • 文件管理支持文档预览。包括 PDF/WORD/EXCEL/PPT/音频/视频。
  • 集成了 yao xgen 管理后台,可使用 neo 助手生成代码。

功能扩展

功能介绍

模型创建

Yao 模型是整个系统的核心组件,在这里,可以使用界面创建 Yao 的模型定义,也可以导入其它的格式的模型。或是导入数据库表结构作为模型定义。创建模型后,模型对应的 amis 界面定义与操作的 api 接口就会自动的生成。

  • 模型创建中支持直接配置文件/图片/视频的类型。
  • 模型字段支持配置关联表查询。
  • 模型支持模型关联关系配置,一对一/一对多。
  • 支持AI生成模型定义并导入。

model_import

AMIS 界面编辑器集成

实现了 AMIS 界面编辑器的集成,可以直接在编辑器中使用 api 接口读取数据。

API 接口测试

基于 amis-sdk,实现了在线的 yao api 接口测试功能。

api_test

表数据维护

基于模型定义,可以推断出整个 crud 界面的定义。在表数据维护的入口可以查看或是更新表数据。

table_maintain

代码生成

基于模型定义,也可以自己创建不同的代码生成功能。

code_generate

Soybean-admin 集成

amis-sdk 可以与 react 或是 vue 作集成开发,这里是把 amis-sdk 作为 vue 组件,嵌入到第三方的 admin 框架。

soy-admin-integrate

已经实现了 soybean 的菜单管理功能。

menu_manager

yao ai 集成

yao 本身有一个 xgen 的管理后端,已经实现了 AI 的功能,这里也是把 xgen 的AI功能利用起来。

支持使用deepseek的模型与豆包的模型。

需要在环境变量文本中配置

# 配置deepseek的key与豆包的key
DEEPSEEK_KEY="sk-"

# 豆包的key
# 豆包还需要修改connectors目录下的连接配置中模型。
DOUBAO_KEY=""

其中豆包对函数调用比较完善。

ai_chat

本地安装

下载并安装 Yao 程序:https://github.com/wwsheng009/yao/releases

修改.env 文件中数据库配置

git clone https://github.com/wwsheng009/yao-amis-admin

cd yao-amis-admin

#如果需要配置默认配置
cp .sqlite.env .env

yao migrate

yao start

本应用可以使用三个登录入口,

Yao 本身的 Xgen 登录入口:http://localhost:5099/admin/login/admin

soy-admin 登录入口:http://localhost:5099/soy-admin

默认的登录入中:http://localhost:5099/amis-admin/login.html

登录用户名:xiang@iqka.com 密码:A123456p+

登录成功后会跳转到测试页面,

跨域

在使用 amis 编辑器时,编辑器项目一般会放在单独的项目时,这时编辑器访问地址的域名跟 yao 服务器的域名不一样。为了让编辑器可以直接访问 yao api 地址,可以在 yao 项目的.env 文件里配置上参数 YAO_ALLOW_FROM,允许跨域访问。

YAO_ALLOW_FROM="localhost"# 如果多个地址,使用|进行分隔
YAO_ALLOW_FROM="localhost|localhost:5099"

项目结构说明

yao引擎内置了js脚本解析功能,专门用于数据处理,所有的js脚本文件保存在目录/scripts/下。

amis相关的页面配置目录保存在目录/data/pages目录下。

其它的目录请参考Yao引擎的文档说明。

Scripts Doc

生成typescript文档。

pnpm add -g typedoc;

typedoc --out ./dist/docs ./scripts/**/*

参考

amis 框架地址:https://github.com/baidu/amis

amis 文档地址:https://aisuda.bce.baidu.com/amis/zh-CN/docs/index

yao 处理器列表:https://yaoapps.com/doc/%E6%89%8B%E5%86%8C/%E5%A4%84%E7%90%86%E5%99%A8/Model

许可

MIT