- Vue 3 + TypeScript + Element Plus 前端界面 - Pinia 状态管理 - Vue Router 4 路由管理 - Axios HTTP 客户端 - MSW (Mock Service Worker) 开发环境模拟 - 账户管理界面 (列表、详情、三科目余额展示) - 交易管理界面 (列表、详情) - 对账管理界面 (三账校验) - 完善的 API 客户端封装 - Docker 容器化配置 - Nginx 配置用于生产环境
45 lines
1.2 KiB
JavaScript
45 lines
1.2 KiB
JavaScript
import { groupBy } from '../../jsutils/groupBy.mjs';
|
|
import { GraphQLError } from '../../error/GraphQLError.mjs';
|
|
|
|
/**
|
|
* Unique argument names
|
|
*
|
|
* A GraphQL field or directive is only valid if all supplied arguments are
|
|
* uniquely named.
|
|
*
|
|
* See https://spec.graphql.org/draft/#sec-Argument-Names
|
|
*/
|
|
export function UniqueArgumentNamesRule(context) {
|
|
return {
|
|
Field: checkArgUniqueness,
|
|
Directive: checkArgUniqueness,
|
|
};
|
|
|
|
function checkArgUniqueness(parentNode) {
|
|
var _parentNode$arguments;
|
|
|
|
// FIXME: https://github.com/graphql/graphql-js/issues/2203
|
|
|
|
/* c8 ignore next */
|
|
const argumentNodes =
|
|
(_parentNode$arguments = parentNode.arguments) !== null &&
|
|
_parentNode$arguments !== void 0
|
|
? _parentNode$arguments
|
|
: [];
|
|
const seenArgs = groupBy(argumentNodes, (arg) => arg.name.value);
|
|
|
|
for (const [argName, argNodes] of seenArgs) {
|
|
if (argNodes.length > 1) {
|
|
context.reportError(
|
|
new GraphQLError(
|
|
`There can be only one argument named "${argName}".`,
|
|
{
|
|
nodes: argNodes.map((node) => node.name),
|
|
},
|
|
),
|
|
);
|
|
}
|
|
}
|
|
}
|
|
}
|