- Vue 3 + TypeScript + Element Plus 前端界面 - Pinia 状态管理 - Vue Router 4 路由管理 - Axios HTTP 客户端 - MSW (Mock Service Worker) 开发环境模拟 - 账户管理界面 (列表、详情、三科目余额展示) - 交易管理界面 (列表、详情) - 对账管理界面 (三账校验) - 完善的 API 客户端封装 - Docker 容器化配置 - Nginx 配置用于生产环境
32 lines
1.0 KiB
JavaScript
32 lines
1.0 KiB
JavaScript
import { invariant } from '../jsutils/invariant.mjs';
|
|
import { parse } from '../language/parser.mjs';
|
|
import { executeSync } from '../execution/execute.mjs';
|
|
import { getIntrospectionQuery } from './getIntrospectionQuery.mjs';
|
|
/**
|
|
* Build an IntrospectionQuery from a GraphQLSchema
|
|
*
|
|
* IntrospectionQuery is useful for utilities that care about type and field
|
|
* relationships, but do not need to traverse through those relationships.
|
|
*
|
|
* This is the inverse of buildClientSchema. The primary use case is outside
|
|
* of the server context, for instance when doing schema comparisons.
|
|
*/
|
|
|
|
export function introspectionFromSchema(schema, options) {
|
|
const optionsWithDefaults = {
|
|
specifiedByUrl: true,
|
|
directiveIsRepeatable: true,
|
|
schemaDescription: true,
|
|
inputValueDeprecation: true,
|
|
oneOf: true,
|
|
...options,
|
|
};
|
|
const document = parse(getIntrospectionQuery(optionsWithDefaults));
|
|
const result = executeSync({
|
|
schema,
|
|
document,
|
|
});
|
|
(!result.errors && result.data) || invariant(false);
|
|
return result.data;
|
|
}
|