mirror of
https://github.com/NapNeko/NapCatQQ.git
synced 2026-02-05 23:19:37 +00:00
42 lines
1.3 KiB
TypeScript
42 lines
1.3 KiB
TypeScript
import { FromSchema, JSONSchema } from 'json-schema-to-ts';
|
|
import BaseAction from '../BaseAction';
|
|
import { ActionName } from '../types';
|
|
import { ChatType, Peer } from '@/core';
|
|
|
|
const SchemaData = {
|
|
type: 'object',
|
|
properties: {
|
|
eventType: { type: 'string' },
|
|
group_id: { type: 'string' },
|
|
user_id: { type: 'string' },
|
|
},
|
|
required: ['eventType'],
|
|
} as const satisfies JSONSchema;
|
|
|
|
type Payload = FromSchema<typeof SchemaData>;
|
|
|
|
export class SetInputStatus extends BaseAction<Payload, any> {
|
|
actionName = ActionName.SetInputStatus;
|
|
|
|
async _handle(payload: Payload) {
|
|
let peer: Peer;
|
|
if (payload.group_id) {
|
|
peer = {
|
|
chatType: ChatType.KCHATTYPEGROUP,
|
|
peerUid: payload.group_id,
|
|
};
|
|
} else if (payload.user_id) {
|
|
const uid = await this.core.apis.UserApi.getUidByUinV2(payload.user_id);
|
|
if (!uid) throw new Error('uid is empty');
|
|
peer = {
|
|
chatType: ChatType.KCHATTYPEC2C,
|
|
peerUid: uid,
|
|
};
|
|
} else {
|
|
throw new Error('请指定 group_id 或 user_id');
|
|
}
|
|
|
|
return await this.core.apis.MsgApi.sendShowInputStatusReq(peer, parseInt(payload.eventType));
|
|
}
|
|
}
|