npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

yao-app-ts-types

v1.1.1

Published

typescript types for yao application

Downloads

508

Readme

YAO 应用 JSON-SCHEMA

开发 yao 应用需要频繁的编写 json 格式的配置文件。文件的配置项又特别的多,如果没有辅助工具,写起来比较累。而目前想到比较好的方法是使用 json-schema 文件帮助校验 json 语法,并且在 vscode 中使用 json-schema 也可以进行语法提示与自动完成。

本项目整理了 yao 应用中常用配置文件的 typescript 类型,并使用工具生成对应的 json-schema 文件。配置好 vscode 编辑器后测试使用效果还是不错的。

测试效果:

  • 检验 json 配置文件的有效性

  • 编辑器自动完成与代码提示

演示效果

此项目非官方文档,有可能部分信息不准确,仅供参考学习

yao 应用引擎目前有 3 个发行版本:0.10.2/0.10.1/0.9.1,还有正在开发中的开发版本 0.10.3。

注意:0.10.3 与 0.10.2 在 dsl 配置文件的语法格式上存在差异。这里的 json-schema并不适用于目前官方发布的 0.10.2 版本,只适用于 0.10.3 版本的开发版本

发行版本可以在官方上下载,开发版本需要从 github 的 action 中下载。

发行版本地址:https://yaoapps.com/release

开发版本:https://github.com/YaoApp/yao/actions

如何确定当前使用的是哪一个版本的 yao,请执行命令 yao version

yao version

0.10.3

使用方法

需要使用 vscode 编辑器

在线配置文件

直接使用 github 上的文件,优点是不需要下载 json-schema 文件,但是前提是电脑的网络能够直接连接到 github。

切换到 yao 应用目录执行以下命令。

mkdir .vscode
wget https://raw.githubusercontent.com/wwsheng009/yao-app-ts-types/main/.vscode/settings-online.json -O .vscode/settings.json

yao 应用引擎目前有多个发行版本,vscode默认使用最新版本。

本地 json-schema 文件

  • 下载项目中的 json-schema 文件夹中所有的配置文件到本地
  • 下载项目中.vscode/settings.json 到本地目录.vscode/settings.json,这会对项目内所有的配置文件生效
  • 如果只是效验单个文件,也可以在需要编辑的 json 文件中加入字段 "$schema"引用对应的 json-schema 文件
    {
      "$schema": "../../../json-schemas/0.10.4/flow.json"
    }

目前支持的 yao DSL 列表

  • 表单: form 文件
  • 表格: table 文件
  • 模型: model 文件
  • HTTP API: http api 文件
  • 流程: flow 文件
  • Chart: 图表文件
  • Dashboard: 大屏文件
  • Connector: 数据库连接器
  • Store: 存储
  • List: 列表
  • Login: 用户登录配置
  • App: 应用信息
  • Service
  • Web socket
  • Socket 官方还没支持
  • Task: 并发任务
  • Widget: 自定义 widget
  • Pipe: 管道

如何增加自定义的类型或是进行扩展

项目提供了一些内置处理器的 ts 类型定义与语法提示,方便用户理解 yao 的特有对象。

在目录 src/types/dsl 下包含了 yao 的各种 dsl 类型定义,每一个文件都包含了一种 DSL 类型的定义。用户可以根据自己的需要自行调整。

生成 json-schema 文件

完成 ts 类型定义后,可以使用工具生成对应的 json-schema 文件。生成的方式分两种:一个是单个生成会比较快,另外一个是批量生成,省事,但是会慢一点。

单个生成

利用工具 ts-json-schema-generator 生成 json-schema。

npx ts-json-schema-generator --path 'src/types/dsl/**/*.ts' --type 'YaoPipe.Pipe' >./json-schemas/0.10.4/pipe.json

批量生成

项目中提供了一个简单的批量生成的 bash 脚本,执行后会把所有的 ts 类型定义都转换成 json-schema 定义文件。

pnpm run build-schema

其它

如果需要 vscode 支持后缀名为.yao 的配置文件

  • 使用 vscode 命令:更改语言模型/Change Language Mode,再修改文件类型关联。
  • 直接编辑 setting.json 配置
 "files.associations": {
   "*.yao": "jsonc"
},

如果需要直接修改 json-schema,配置额外的配置,请参考:https://code.visualstudio.com/docs/languages/json