This commit is contained in:
Wang Kejun 2023-10-13 19:28:20 +08:00
parent 2fd4b31f68
commit 49ef53ae59
173 changed files with 2435 additions and 5952 deletions

View File

@ -1,6 +1,6 @@
import { EntityDict } from "../oak-app-domain";
import { AppType } from "../oak-app-domain/Application/Schema";
import { BackendRuntimeContext } from "../context/BackendRuntimeContext";
import { EntityDict } from '../oak-app-domain';
import { AppType } from '../oak-app-domain/Application/Schema';
import { BackendRuntimeContext } from '../context/BackendRuntimeContext';
import { WechatPublicEventData, WechatMpEventData } from 'oak-external-sdk';
export declare function createSession<ED extends EntityDict, Cxt extends BackendRuntimeContext<ED>>(params: {
data?: WechatPublicEventData | WechatMpEventData;

View File

@ -3,137 +3,143 @@ import { assert } from 'oak-domain/lib/utils/assert';
export async function createSession(params, context) {
const { data, type, entity, entityId } = params;
const userId = context.getCurrentUserId(true);
let session;
let sessionMessage$session;
switch (type) {
case 'web': {
const systemId = context.getSystemId();
let entity2 = entity;
let entityId2 = entityId;
if (!entity) {
// 默认
const [application] = await context.select('application', {
const closeRootMode = context.openRootMode();
try {
let session;
let sessionMessage$session;
switch (type) {
case 'web': {
const systemId = context.getSystemId();
let entity2 = entity;
let entityId2 = entityId;
if (!entity) {
// 默认
const [application] = await context.select('application', {
data: {
id: 1,
systemId: 1,
type: 1,
},
filter: {
systemId,
type: 'web',
},
}, {});
entity2 = 'application';
entityId2 = application?.id;
}
assert(entity2 && entityId2);
const result = await context.select('session', {
data: {
id: 1,
systemId: 1,
type: 1,
entity: 1,
entityId: 1,
userId: 1,
lmts: 1,
},
filter: {
systemId,
type: 'web',
entity: entity2,
entityId: entityId2,
userId,
},
}, {});
entity2 = 'application';
entityId2 = application?.id;
session = result[0];
break;
}
assert(entity2 && entityId2);
const result = await context.select('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
lmts: 1,
},
filter: {
entity: entity2,
entityId: entityId2,
userId,
},
}, {});
session = result[0];
break;
}
case 'wechatMp':
case 'wechatPublic': {
assert(data);
assert(entity === 'application' && entityId);
const { ToUserName, FromUserName, CreateTime, MsgType,
// Event,
Content,
// EventKey,
} = data;
const [wechatUser] = await context.select('wechatUser', {
data: {
id: 1,
openId: 1,
applicationId: 1,
},
filter: {
openId: FromUserName,
}
}, {});
const result = await context.select('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
lmts: 1,
openId: 1,
},
filter: {
entity: entity,
entityId: entityId,
openId: FromUserName,
}
}, {});
session = result[0];
sessionMessage$session = [
{
id: await generateNewIdAsync(),
action: 'create',
case 'wechatMp':
case 'wechatPublic': {
assert(data);
assert(entity === 'application' && entityId);
const { ToUserName, FromUserName, CreateTime, MsgType, Content, } = data;
const [wechatUser] = await context.select('wechatUser', {
data: {
id: await generateNewIdAsync(),
applicationId: wechatUser?.applicationId,
wechatUserId: wechatUser?.id,
createTime: Number(CreateTime) * 1000,
type: MsgType,
text: Content,
aaoe: false,
id: 1,
openId: 1,
applicationId: 1,
},
filter: {
openId: FromUserName,
},
}, {});
const result = await context.select('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
lmts: 1,
openId: 1,
},
filter: {
entity: entity,
entityId: entityId,
openId: FromUserName,
},
}, {});
session = result[0];
sessionMessage$session = [
{
id: await generateNewIdAsync(),
action: 'create',
data: {
id: await generateNewIdAsync(),
applicationId: wechatUser?.applicationId,
wechatUserId: wechatUser?.id,
createTime: Number(CreateTime) * 1000,
type: MsgType,
text: Content,
aaoe: false,
},
},
];
break;
}
default: {
assert(false, `传入不支持的type: ${type}`);
}
}
if (session) {
if (!sessionMessage$session) {
closeRootMode();
return session.id;
}
await context.operate('session', {
id: await generateNewIdAsync(),
action: 'update',
data: {
sessionMessage$session,
},
];
break;
}
default: {
assert(false, `传入不支持的type: ${type}`);
}
}
if (session) {
if (!sessionMessage$session) {
filter: {
id: session.id,
},
}, {
dontCollect: true,
});
closeRootMode();
return session.id;
}
await context.operate('session', {
id: await generateNewIdAsync(),
action: 'update',
data: {
sessionMessage$session,
},
filter: {
id: session.id,
},
}, {
dontCollect: true,
});
return session.id;
else {
const sessionId = await generateNewIdAsync();
await context.operate('session', {
id: await generateNewIdAsync(),
action: 'create',
data: Object.assign({
id: sessionId,
entity,
entityId,
userId,
lmts: Date.now(),
openId: data?.FromUserName,
}, sessionMessage$session && { sessionMessage$session }),
}, {
dontCollect: true,
});
closeRootMode();
return sessionId;
}
}
else {
const sessionId = await generateNewIdAsync();
await context.operate('session', {
id: await generateNewIdAsync(),
action: 'create',
data: Object.assign({
id: sessionId,
entity,
entityId,
userId,
lmts: Date.now(),
openId: data?.FromUserName,
}, sessionMessage$session && { sessionMessage$session }),
}, {
dontCollect: true,
});
return sessionId;
catch (e) {
closeRootMode();
throw e;
}
}

View File

@ -2,8 +2,7 @@
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<import("../../../oak-app-domain").EntityDict, "session", false, {
selectedId: string;
onSelect: (id: string) => void;
key: string;
entityFilter: {};
name: undefined;
isEntity: boolean;
name: string;
}>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -40,6 +40,29 @@ export default OakComponent({
},
},
},
sessionMessage$session: {
$entity: 'sessionMessage',
data: {
id: 1,
text: 1,
type: 1,
userId: 1,
wechatUserId: 1,
createTime: 1,
$$createAt$$: 1,
aaoe: 1,
},
sorter: [
{
$attr: {
$$createAt$$: 1,
},
$direction: 'desc',
},
],
indexFrom: 0,
count: 1,
},
},
isList: false,
formData({ data, features }) {
@ -50,10 +73,7 @@ export default OakComponent({
});
if (session?.sessionMessage$session) {
Object.assign(session, {
wechatMessages: session?.sessionMessage$session,
// unreadLength: session?.sessionMessage$session?.filter(
// (ele: any) => ele.isRead === false
// )?.length,
sessionMessages: session?.sessionMessage$session,
});
}
return session;
@ -63,74 +83,78 @@ export default OakComponent({
const { oakId } = this.props;
const { session } = this.state;
const userId = this.features.token.getUserId(true);
const { data: readRemark } = await this.features.cache.refresh('readRemark', {
data: {
id: 1,
sessionId: 1,
userId: 1,
$$createAt$$: 1,
},
filter: {
session: {
id: oakId
},
userId,
},
sorter: [
{
$attr: {
$$createAt$$: 1,
},
$direction: 'desc',
},
],
count: 1,
});
const { data: sessionMessage } = await this.features.cache.refresh('sessionMessage', {
data: {
id: 1,
sessionId: 1,
userId: 1,
$$createAt$$: 1,
},
filter: {
session: {
id: oakId
},
},
sorter: [
{
$attr: {
$$createAt$$: 1,
},
$direction: 'desc',
},
],
count: 1,
});
if (readRemark && readRemark?.length > 0) {
if (session?.lmst > readRemark && sessionMessage[0]?.userId !== userId) {
}
}
else {
if (sessionMessage[0]?.userId !== userId) {
}
}
// TODO readRemark未实现
// const { data: readRemark } = await this.features.cache.refresh(
// 'readRemark',
// {
// data: {
// id: 1,
// sessionId: 1,
// userId: 1,
// $$createAt$$: 1,
// },
// filter: {
// sessionId: oakId,
// userId,
// },
// sorter: [
// {
// $attr: {
// $$createAt$$: 1,
// },
// $direction: 'desc',
// },
// ],
// count: 1,
// }
// );
// const { data: sessionMessage } = await this.features.cache.refresh(
// 'sessionMessage',
// {
// data: {
// id: 1,
// sessionId: 1,
// userId: 1,
// $$createAt$$: 1,
// },
// filter: {
// sessionId: oakId,
// },
// sorter: [
// {
// $attr: {
// $$createAt$$: 1,
// },
// $direction: 'desc',
// },
// ],
// count: 1,
// }
// );
// if (readRemark && readRemark?.length > 0) {
// if (
// session?.lmst > readRemark &&
// sessionMessage[0]?.userId !== userId
// ) {
// }
// } else {
// if (sessionMessage[0]?.userId !== userId) {
// }
// }
},
},
properties: {
selectedId: '',
onSelect: (id) => { },
key: '',
entityFilter: {},
name: undefined,
isEntity: false,
name: '',
},
methods: {
getAvatarUrl() {
const { userUrl, entity } = this.state;
const { entityFilter } = this.props;
const defaultUrl = 'http://qiniu.gecomebox.com/static/defaultAvatar.png';
if (entityFilter) {
const { isEntity } = this.props;
const defaultUrl = '';
if (isEntity) {
return userUrl || defaultUrl;
}
else {
@ -139,12 +163,11 @@ export default OakComponent({
},
getName() {
const { user, entity, openId } = this.state;
const { entityFilter } = this.props;
if (entityFilter) {
const { isEntity } = this.props;
if (isEntity) {
const userName = user?.name;
const userNickname = user?.name || user?.nickname;
const userMobile = user?.mobile$user &&
user?.mobile$user[0]?.mobile;
const userMobile = user?.mobile$user && user?.mobile$user[0]?.mobile;
if (userName) {
return userName;
}

View File

@ -3,7 +3,7 @@ import { EntityDict } from '../../../oak-app-domain';
export default function render(props: WebComponentProps<EntityDict, 'session', false, {
id: string;
unreadLength: number;
sessiontMessages: EntityDict['sessionMessage']['Schema'][];
sessionMessages: EntityDict['sessionMessage']['Schema'][];
userType: string;
selectedId: string;
onSelect: (id: string) => void;

View File

@ -5,22 +5,22 @@ import classNames from 'classnames';
import Style from './web.module.less';
export default function render(props) {
const { methods, data } = props;
const { selectedId, onSelect, userType, id, unreadLength, sessiontMessages = [], name, lmts, } = data;
const { selectedId, onSelect, id, unreadLength, sessionMessages = [], name, lmts, } = data;
const { t, getName, getAvatarUrl } = methods;
const sessiontMessage = sessiontMessages && sessiontMessages[0];
const type = sessiontMessage?.type;
const text = sessiontMessage?.text;
const sessionMessage = sessionMessages && sessionMessages[0];
const type = sessionMessage?.type;
const text = sessionMessage?.text;
const today = dayjs().startOf('day').valueOf();
const createAt2 = lmts && dayjs(lmts).startOf('day').valueOf();
const lastCreateAt = lmts && dayjs(lmts).startOf('day').valueOf();
return (_jsxs("div", { className: classNames(Style.cell, {
[Style.cell_selected]: id === selectedId,
}), onClick: () => {
onSelect(id);
}, children: [_jsx(Badge, { dot: id === selectedId ? false : true, count: unreadLength || 0, children: _jsx(Image, { className: Style.avatar, src: getAvatarUrl(), preview: false }) }), _jsxs("div", { className: Style.inner, children: [_jsxs("div", { className: Style.top, children: [_jsx("div", { className: Style.title, children: name || getName() }), _jsx("div", { className: Style.date, children: lmts &&
(today === createAt2
}, children: [_jsx(Badge, { dot: id !== selectedId, count: unreadLength || 0, children: _jsx(Image, { className: Style.avatar, src: getAvatarUrl(), preview: false }) }), _jsxs("div", { className: Style.inner, children: [_jsxs("div", { className: Style.top, children: [_jsx("div", { className: Style.title, children: name || getName() }), _jsx("div", { className: Style.date, children: lmts &&
(today === lastCreateAt
? dayjs(lmts).format('HH:mm')
: dayjs(lmts).format('YYYY-MM-DD')) })] }), _jsx("div", { className: Style.message, children: type &&
(type === 'text'
? `${text}`
: `[${t(`sessiontMessage:v.type.${type}`)}消息]`) })] })] }));
: `[${t(`sessionMessage:v.type.${type}`)}消息]`) })] })] }));
}

View File

@ -1,45 +1,4 @@
export default OakComponent({
// entity: 'session',
// projection: {
// id: 1,
// userId: 1,
// entity: 1,
// entityId: 1,
// lmts: 1,
// user: {
// id: 1,
// name: 1,
// nickname: 1,
// mobile$user: {
// $entity: 'mobile',
// data: {
// id: 1,
// mobile: 1,
// userId: 1,
// },
// },
// extraFile$entity: {
// $entity: 'extraFile',
// data: {
// id: 1,
// tag1: 1,
// origin: 1,
// bucket: 1,
// objectId: 1,
// filename: 1,
// extra1: 1,
// extension: 1,
// type: 1,
// entity: 1,
// },
// filter: {
// tag1: {
// $in: ['avatar'],
// },
// },
// },
// },
// },
isList: false,
formData({ data, features }) {
const { sessionId } = this.props;
@ -48,25 +7,8 @@ export default OakComponent({
}
return {};
},
// filters: [
// {
// filter() {
// const { sessionId } = this.props;
// if (sessionId) {
// return {
// id: sessionId,
// };
// }
// },
// },
// ],
lifetimes: {
ready() {
const { sessionId } = this.props;
// if (sessionId) {
// this.getSession(sessionId)
// }
},
ready() { },
},
listeners: {
sessionId(prev, next) {
@ -79,7 +21,7 @@ export default OakComponent({
sessionId: '',
isEntity: false,
entityDisplay: (data) => [],
entityProjection: {}, // user端指示需要取哪些entity的属性来显示entityDisplay
entityProjection: null, // user端指示需要取哪些entity的属性来显示entityDisplay
},
methods: {
getSession(sessionId) {
@ -131,7 +73,7 @@ export default OakComponent({
getAvatarUrl() {
const { userUrl, entity } = this.state;
const { isEntity } = this.props;
const defaultUrl = 'http://qiniu.gecomebox.com/static/defaultAvatar.png';
const defaultUrl = '';
if (isEntity) {
return userUrl || defaultUrl;
}

View File

@ -5,7 +5,7 @@
align-items: center;
position: fixed;
width: 100%;
z-index: 20;
z-index: 1;
height: 50px;
position: absolute;

View File

@ -1,10 +1,9 @@
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import { Avatar } from 'antd';
// import { UserOutlined } from '@ant-design/icons';
import Style from './web.module.less';
export default function render(props) {
const { methods, data } = props;
const { nickname, avatarUrl, name } = data;
const defaultUrl = 'http://qiniu.gecomebox.com/static/defaultAvatar.png';
const defaultUrl = '';
return (_jsxs("div", { className: Style.header, children: [_jsx(Avatar, { shape: "square", className: Style.avatar, src: avatarUrl || defaultUrl }), _jsx("div", { className: Style.nickname, children: nickname || name })] }));
}

View File

@ -1,8 +1,10 @@
/// <reference types="react" />
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<import("../../../oak-app-domain").EntityDict, "session", true, {
import { EntityDict } from '../../../oak-app-domain';
import { RowWithActions } from 'oak-frontend-base';
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<EntityDict, "session", true, {
entity: string;
entityFilter: any;
entityDisplay: (data: any) => any[];
entityDisplay: (data: EntityDict['session']['Schema'][] | RowWithActions<EntityDict, 'session'>[]) => any[];
entityProjection: any;
sessionId: string;
dialog: boolean;

View File

@ -81,14 +81,11 @@ export default OakComponent({
entityDisplay &&
sessions &&
sessions.length > 0) {
const sessions1 = entityDisplay(sessions);
const newSessions = entityDisplay(sessions);
return {
sessions: sessions1,
sessions: newSessions,
};
}
// const unReadLength = wechatSessions?.filter(
// (ele) => ele.isRead
// )
//排序待框架实现
return {
sessions: sessions?.sort((a, b) => b.lmts - a.lmts),
@ -131,9 +128,9 @@ export default OakComponent({
},
properties: {
entity: '',
entityFilter: undefined,
entityFilter: null,
entityDisplay: (data) => [],
entityProjection: {},
entityProjection: null,
sessionId: '',
dialog: false,
onItemClick: null,

View File

@ -1,10 +1,14 @@
import { WebComponentProps } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
type Session = EntityDict['session']['Schema'];
export default function Render(props: WebComponentProps<EntityDict, 'session', true, {
sessions: EntityDict['session']['Schema'][];
sessions: Partial<Session & {
name: string;
}>[];
selectedSessionId: string;
entityFilter: object;
}, {
setSelectedSessionId: (sessionId: string) => void;
navigateToMessage: (sessionId: string) => void;
}>): import("react/jsx-runtime").JSX.Element;
export {};

View File

@ -4,10 +4,10 @@ import Header from '../../../components/session/header';
import SessionCell from '../../../components/session/cell';
export default function Render(props) {
const { data, methods } = props;
const { sessions, selectedSessionId, oakFullpath, entityFilter, } = data;
const { sessions, selectedSessionId, oakFullpath, entityFilter } = data;
const { navigateToMessage, setSelectedSessionId } = methods;
return (_jsx("div", { className: Style.container, children: _jsxs("div", { className: Style.conversationContainer, children: [_jsx(Header, {}), sessions?.map((session, index) => {
return (_jsx(SessionCell, { entityFilter: entityFilter, selectedId: selectedSessionId, name: session?.name, onSelect: (id) => {
return (_jsx(SessionCell, { isEntity: entityFilter ? true : false, selectedId: selectedSessionId, name: session?.name, onSelect: (id) => {
navigateToMessage(id);
}, oakId: session.id, oakPath: oakFullpath
? `${oakFullpath}.${session.id}`

View File

@ -1,13 +1,17 @@
import { WebComponentProps } from 'oak-frontend-base';
import { WebComponentProps, RowWithActions } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
type Session = EntityDict['session']['Schema'];
export default function Render(props: WebComponentProps<EntityDict, 'session', true, {
sessions: any;
sessions: Partial<Session & {
name: string;
}>[];
selectedSessionId: string;
className: string;
dialog: boolean;
entityFilter: object;
entityDisplay: (data: any) => any[];
entityDisplay: (data: EntityDict['session']['Schema'][] | RowWithActions<EntityDict, 'session'>[]) => any[];
entityProjection: object;
}, {
setSelectedSessionId: (sessionId: string) => void;
}>): import("react/jsx-runtime").JSX.Element;
export {};

View File

@ -1,5 +1,5 @@
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import MessageList from '../../sessionMessage/list';
import SessionMessageList from '../../sessionMessage/list';
import Header from '../../../components/session/header';
import SessionCell from '../../../components/session/cell';
import classNames from 'classnames';
@ -11,12 +11,10 @@ export default function Render(props) {
return (_jsx("div", { className: Style.container, children: _jsxs("div", { className: classNames(Style.bothContainer, className, {
[Style.dialogContainer]: dialog,
}), children: [_jsxs("div", { className: Style.conversationContainer, children: [_jsx(Header, {}), _jsx("div", { className: Style.inner, children: sessions?.map((session, index) => {
return (_jsx(SessionCell, { entityFilter: entityFilter, name: session?.name, selectedId: selectedSessionId, onSelect: (id) => {
return (_jsx(SessionCell, { isEntity: entityFilter ? true : false, name: session?.name, selectedId: selectedSessionId, onSelect: (id) => {
setSelectedSessionId(id);
}, oakId: session.id, oakPath: oakFullpath
? `${oakFullpath}.${session.id}`
: '' }, session.id));
}) })] }), selectedSessionId && (_jsx(MessageList, { sessionId: selectedSessionId, isEntity: entityFilter ? true : false, oakAutoUnmount: true, entityDisplay: entityDisplay, entityProjection: entityProjection, oakPath: oakFullpath
? `$$sessionMessage/list`
: undefined }))] }) }));
}) })] }), selectedSessionId && (_jsx(SessionMessageList, { sessionId: selectedSessionId, isEntity: entityFilter ? true : false, oakAutoUnmount: true, entityDisplay: entityDisplay, entityProjection: entityProjection, oakPath: oakFullpath ? `$$sessionMessage/list` : undefined }))] }) }));
}

View File

@ -72,12 +72,10 @@ export default OakComponent({
},
formData({ data: sessionMessage, features }) {
const type = sessionMessage?.type;
// const data = wechatMessage?.data;
const session = sessionMessage?.session;
const newSessionMessage = {
type,
aaoe: sessionMessage?.aaoe,
// data,
text: sessionMessage?.text,
id: sessionMessage?.id,
$$createAt$$: sessionMessage?.$$createAt$$,
@ -85,13 +83,13 @@ export default OakComponent({
userId: session?.userId,
userMobile: session?.user?.mobile$user &&
session?.user?.mobile$user[0]?.mobile,
userAvatar: this.features.extraFile.getUrl(session?.user?.extraFile$entity &&
userAvatar: features.extraFile2.getUrl(session?.user?.extraFile$entity &&
session?.user?.extraFile$entity[0]),
};
if (type === 'image') {
const extraFile$entity = sessionMessage?.extraFile$entity;
Object.assign(newSessionMessage, {
picUrl: features.extraFile.getUrl(extraFile$entity && extraFile$entity[0]),
picUrl: features.extraFile2.getUrl(extraFile$entity && extraFile$entity[0]),
});
}
return newSessionMessage;
@ -101,8 +99,8 @@ export default OakComponent({
},
methods: {
getAvatarUrl(aaoe) {
const defaultUrl = 'http://qiniu.gecomebox.com/static/defaultAvatar.png';
const { companyLogoUrl, userAvatar, parkLogoUrl } = this.state;
const defaultUrl = '';
const { userAvatar } = this.state;
if (aaoe) {
return defaultUrl;
}

View File

@ -1,12 +1,13 @@
/// <reference types="react" />
import { EntityDict } from '../../../oak-app-domain';
import { RowWithActions } from 'oak-frontend-base';
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<EntityDict, "sessionMessage", true, {
sessionId: string;
isEntity: boolean;
dialog: boolean;
entity: string;
entityId: string;
entityDisplay: (data: any) => any[];
entityDisplay: (data: EntityDict['session']['Schema'][] | RowWithActions<EntityDict, 'session'>[]) => any[];
entityProjection: any;
}>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -57,7 +57,7 @@ export default OakComponent({
await this.pageScroll('comment');
});
this.createItem();
this.getConversationInfo();
this.getSessionInfo();
},
detached() {
if (this.timer) {
@ -80,7 +80,7 @@ export default OakComponent({
if (prev.sessionId !== next.sessionId) {
if (next.sessionId) {
const { sessionMessageId } = this.state;
this.getConversationInfo();
this.getSessionInfo();
// 如果sessionId变了需要重新刷新下
this.refresh();
this.removeItem(sessionMessageId);
@ -110,7 +110,7 @@ export default OakComponent({
entity: '',
entityId: '',
entityDisplay: (data) => [],
entityProjection: {}, // user端指示需要取哪些entity的属性来显示entityDisplay
entityProjection: null, // user端指示需要取哪些entity的属性来显示entityDisplay
},
filters: [
{
@ -135,7 +135,6 @@ export default OakComponent({
data: {
content: '',
buttonHidden: true,
selectedTradeId: '',
newSessionId: '',
},
methods: {
@ -173,20 +172,12 @@ export default OakComponent({
},
setContent(text) {
const { sessionMessageId } = this.state;
this.setState({
text,
});
this.updateItem({
text,
type: 'text',
}, sessionMessageId);
},
setButtonHidden(isHidden) {
this.setState({
buttonHidden: isHidden,
});
},
async getConversationInfo() {
async getSessionInfo() {
const { sessionId } = this.props;
if (!sessionId) {
return;
@ -236,10 +227,6 @@ export default OakComponent({
id: sessionId,
},
});
this.setState({
entity: session?.entity,
entityId: session?.entityId,
});
},
pageScroll(id) {
const doc = window.document.getElementById(id);
@ -262,23 +249,16 @@ export default OakComponent({
});
},
async createMessage() {
const { text, wechatUserId, newSessionId, sessionMessageId } = this.state;
const { text, wechatUserId, sessionMessageId } = this.state;
const { sessionId, isEntity } = this.props;
const userId = this.features.token.getUserId();
const applicationId = this.features.application.getApplicationId();
if (!this.state.text) {
this.setMessage({
type: 'warning',
content: '请输入内容',
});
return;
}
// this.addItem({
// applicationId,
// text,
// userId,
// wechatUserId,
// sessionId: sessionId || newSessionId,
// sessionId: sessionId,
// type: 'text',
// createTime: Date.now(),
// aaoe: isEntity,
@ -287,9 +267,6 @@ export default OakComponent({
createTime: Date.now(),
}, sessionMessageId);
await this.execute(undefined, false);
this.setState({
text: '',
});
this.pageScroll('comment');
this.createItem();
},

View File

@ -14,15 +14,7 @@
flex-direction: column;
margin-top: 50px;
overflow-x: hidden;
height: 100%;
}
.bottomSku {
width: calc(100% - 16px);
// position: fixed;
bottom: 176px;
z-index: 1000;
position: absolute;
height: calc(100% - 50px - 190px);
}
.bottom {
@ -35,7 +27,7 @@
bottom: 0;
margin: 0px;
position: absolute;
z-index: 100;
z-index: 1;
// resize: both;
// cursor: nwse-resize;

View File

@ -1,4 +1,4 @@
import { WebComponentProps } from 'oak-frontend-base';
import { WebComponentProps, RowWithActions } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
interface customFile {
name: string;
@ -12,15 +12,11 @@ export default function Render(props: WebComponentProps<EntityDict, 'sessionMess
buttonHidden: boolean;
sessionId: string;
isEntity: boolean;
isUser: boolean;
employerId: string;
sessionMessageType: string;
sessionMessageId: string;
entityDisplay: (data: any) => any[];
entityDisplay: (data: EntityDict['session']['Schema'][] | RowWithActions<EntityDict, 'session'>[]) => any[];
entityProjection: object;
isWeChat: boolean;
}, {
setButtonHidden: (isHidden: boolean) => void;
customUpload: (file: customFile) => void;
setContent: (text: string) => void;
pageScroll: (id: string) => void;

View File

@ -1,57 +1,25 @@
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import { useState, useEffect, useRef } from 'react';
import { Button, Input, Upload } from 'antd';
import { PictureOutlined } from '@ant-design/icons';
import MessageCell from '../../../components/sessionMessage/cell';
import SessionMessageCell from '../../../components/sessionMessage/cell';
import MessageUpsert from '../../../components/sessionMessage/upsert';
import Header from '../../../components/session/forMessage';
import Style from './web.module.less';
export default function Render(props) {
const { data, methods } = props;
const { sessionId, isEntity, sessionMessageList, oakFullpath, text, buttonHidden, sessionMessageType, sessionMessageId, entityDisplay, entityProjection, isWeChat, } = data;
const { setButtonHidden, customUpload, setContent, pageScroll, createMessage, } = methods;
const [bottomHeight, setBottomHeight] = useState(0);
const textareaRef = useRef(null);
useEffect(() => {
if (buttonHidden) {
const newBottomHeight = window.document.getElementById('bottom')?.offsetHeight;
setBottomHeight(newBottomHeight);
}
else {
setBottomHeight(0);
}
}, [buttonHidden]);
const handleKeyDown = (event) => {
if (event.key === "Enter" && !event.shiftKey) {
event.preventDefault();
createMessage();
pageScroll('comment');
}
};
return (_jsxs("div", { className: Style.container, children: [_jsx(Header, { sessionId: sessionId, isEntity: isEntity, oakPath: 'session:header1', oakAutoUnmount: true, entityDisplay: entityDisplay, entityProjection: entityProjection }), _jsx("div", { className: Style.inner, style: {
marginBottom: bottomHeight ? `${bottomHeight}px` : '168px',
}, id: "comment", onClick: () => setButtonHidden(true), children: sessionMessageList
const { sessionId, isEntity, sessionMessageList, oakFullpath, text, buttonHidden, sessionMessageId, entityDisplay, entityProjection, isWeChat, } = data;
const { customUpload, setContent, pageScroll, createMessage, } = methods;
return (_jsxs("div", { className: Style.container, children: [_jsx(Header, { sessionId: sessionId, isEntity: isEntity, oakPath: '$$sessionMessage/list-session/header', oakAutoUnmount: true, entityDisplay: entityDisplay, entityProjection: entityProjection }), _jsx("div", { className: Style.inner, id: "comment", children: sessionMessageList
?.sort((a, b) => a.$$createAt$$ -
b.$$createAt$$)
.map((sessionMessage, index) => {
return (_jsx(MessageCell, { oakId: sessionMessage.id, oakPath: oakFullpath
return (_jsx(SessionMessageCell, { oakId: sessionMessage.id, oakPath: oakFullpath
? `${oakFullpath}.${sessionMessage.id}`
: '', isEntity: isEntity }, sessionMessage.id));
}) }), _jsxs("div", { className: Style.bottom, id: "bottom", children: [_jsx("div", { className: Style.toolbar, children: isWeChat ? (
//微信资源库
_jsx(PictureOutlined, { className: Style.icon })) : (_jsx(Upload, { accept: 'image/*', multiple: false, showUploadList: false, customRequest: () => { }, onChange: ({ file }) => {
customUpload(file);
}, children: _jsx(PictureOutlined, { className: Style.icon }) })) }), _jsxs("div", { className: Style.textareaBox, children: [_jsx(Input.TextArea, { ref: textareaRef, className: Style.textarea, maxLength: 500, placeholder: "Enter \u53D1\u9001\uFF0CShift + Enter\u6362\u884C", rows: 5, onChange: (e) => {
setContent(e.target.value);
}, onFocus: () => {
setButtonHidden(true);
},
// onPressEnter={(e) => {
// e.preventDefault();
// createMessage();
// pageScroll('comment');
// }}
onKeyDown: handleKeyDown, value: text }), _jsx("div", { className: Style.btn, children: _jsx(Button, { type: "primary", disabled: !text, onClick: () => {
createMessage();
pageScroll('comment');
}, children: "\u53D1\u9001" }) })] })] })] }));
}) }), _jsx("div", { className: Style.bottom, id: "bottom", children: sessionMessageId && (_jsx(MessageUpsert, { isEntity: isEntity, oakId: sessionMessageId, oakPath: oakFullpath
? `${oakFullpath}.${sessionMessageId}`
: '', oakAutoUnmount: true, send: () => {
createMessage();
}, setText: (text) => {
setContent(text);
}, customUpload: (file) => {
} }, `MessageUpsert_${sessionMessageId}`)) })] }));
}

View File

@ -1,8 +1,10 @@
/// <reference types="react" />
import { UploadFile } from 'antd/es/upload/interface';
import { EntityDict } from '../../../oak-app-domain';
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<EntityDict, "sessionMessage", true, {
sessionId: string;
userType: string;
dialog: boolean;
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<EntityDict, "sessionMessage", false, {
isEntity: boolean;
customUpload: (file: UploadFile) => void;
send: () => void;
setText: (text: string) => void;
}>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -0,0 +1,131 @@
export default OakComponent({
entity: 'sessionMessage',
isList: false,
projection: {
id: 1,
text: 1,
type: 1,
createTime: 1,
userId: 1,
wechatUserId: 1,
$$createAt$$: 1,
sessionId: 1,
session: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
user: {
id: 1,
name: 1,
mobile$user: {
$entity: 'mobile',
data: {
id: 1,
mobile: 1,
},
},
extraFile$entity: {
$entity: 'extraFile',
data: {
id: 1,
tag1: 1,
origin: 1,
bucket: 1,
objectId: 1,
filename: 1,
extra1: 1,
extension: 1,
type: 1,
entity: 1,
},
filter: {
tag1: {
$in: ['avatar'],
},
},
},
},
},
aaoe: 1,
extraFile$entity: {
$entity: 'extraFile',
data: {
id: 1,
tag1: 1,
tag2: 1,
origin: 1,
bucket: 1,
objectId: 1,
filename: 1,
extra1: 1,
extension: 1,
type: 1,
entity: 1,
},
filter: {
tag1: {
$in: ['image'],
},
},
},
},
formData({ data: sessionMessage, features }) {
const type = sessionMessage?.type;
const session = sessionMessage?.session;
const newSessionMessage = {
type,
aaoe: sessionMessage?.aaoe,
text: sessionMessage?.text,
id: sessionMessage?.id,
$$createAt$$: sessionMessage?.$$createAt$$,
sessionId: sessionMessage?.sessionId,
userId: session?.userId,
userMobile: session?.user?.mobile$user &&
session?.user?.mobile$user[0]?.mobile,
userAvatar: this.features.extraFile.getUrl(session?.user?.extraFile$entity &&
session?.user?.extraFile$entity[0]),
};
if (type === 'image') {
const extraFile$entity = sessionMessage?.extraFile$entity;
Object.assign(newSessionMessage, {
picUrl: features.extraFile.getUrl(extraFile$entity && extraFile$entity[0]),
});
}
return newSessionMessage;
},
properties: {
isEntity: false,
customUpload: (file) => { },
send: () => { },
setText: (text) => { },
},
methods: {
setContent(text) {
const { setText } = this.props;
if (typeof setText === 'function') {
setText(text);
}
},
async upload(file) {
const { customUpload } = this.props;
if (typeof customUpload === 'function') {
customUpload(file);
}
},
async sendData() {
const { send } = this.props;
const { text } = this.state;
if (!text) {
this.setMessage({
type: 'warning',
content: this.t('enterContent'),
});
return;
}
if (typeof send === 'function') {
send();
}
},
},
});

View File

@ -0,0 +1,5 @@
{
"placeholder": "Enter 发送Shift + Enter换行",
"send": "发送",
"enterContent": "请输入内容"
}

View File

@ -0,0 +1,19 @@
import { WebComponentProps } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
import { UploadFile } from 'antd/es/upload/interface';
export default function render(props: WebComponentProps<EntityDict, 'sessionMessage', false, {
isEntity: boolean;
isUser: boolean;
$$createAt$$: number;
text: string;
type: string;
aaoe: boolean;
picUrl: string;
sessionId: string;
oakId: string;
isWeChat: string;
}, {
setContent: (str: string) => void;
sendData: () => void;
upload: (file: UploadFile) => void;
}>): import("react/jsx-runtime").JSX.Element;

View File

@ -0,0 +1,24 @@
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
import { useRef } from 'react';
import { Button, Input, Upload } from 'antd';
import { PictureOutlined } from '@ant-design/icons';
import Style from './web.module.less';
export default function render(props) {
const { data, methods } = props;
const { $$createAt$$, text, type, picUrl, isEntity, aaoe, sessionId, isWeChat, } = data;
const { t, setContent, sendData, upload } = methods;
const textareaRef = useRef(null);
const handleKeyDown = (event) => {
if (event.key === 'Enter' && !event.shiftKey) {
event.preventDefault();
sendData();
}
};
return (_jsxs(_Fragment, { children: [_jsx("div", { className: Style.toolbar, children: _jsx(Upload, { accept: 'image/*', multiple: false, showUploadList: false, customRequest: () => { }, onChange: ({ file }) => {
upload(file);
}, children: _jsx(PictureOutlined, { className: Style.icon }) }) }), _jsxs("div", { className: Style.textareaBox, children: [_jsx(Input.TextArea, { ref: textareaRef, className: Style.textarea, maxLength: 500, placeholder: t('placeholder'), rows: 5, onChange: (e) => {
setContent(e.target.value);
}, onFocus: () => { }, onKeyDown: handleKeyDown, value: text }), _jsx("div", { className: Style.btn, children: _jsx(Button, { type: "primary", disabled: !text, onClick: () => {
sendData();
}, children: t('send') }) })] })] }));
}

View File

@ -0,0 +1,41 @@
.toolbar {
display: flex;
flex-direction: row;
align-items: center;
height: 30px;
.icon {
margin: 0 6px;
font-size: 20px;
color: var(--oak-text-color-secondary);
}
}
.textareaBox {
display: flex;
flex-direction: column;
padding: 0 10px;
.textarea {
border: none;
outline: none;
resize: none;
}
.textarea:focus {
border: none;
box-shadow: none;
resize: none;
}
.btn {
display: flex;
flex-direction: row;
justify-content: flex-end;
margin: 5px 0;
}
}

View File

@ -257,6 +257,18 @@ const i18ns = [
"confirmToRemove": "您确定要删除系统吗?"
}
},
{
id: "7c6300b665cdc65858a529c9d4c46d24",
namespace: "oak-general-business-c-sessionMessage-upsert",
language: "zh-CN",
module: "oak-general-business",
position: "src/components/sessionMessage/upsert",
data: {
"placeholder": "Enter 发送Shift + Enter换行",
"send": "发送",
"enterContent": "请输入内容"
}
},
{
id: "ded171ed67640a148a4a2cc51470cf69",
namespace: "oak-general-business-c-system-application",

View File

@ -12,11 +12,11 @@ import * as Notification from "../Notification/Schema";
import * as SessionMessage from "../SessionMessage/Schema";
import * as Token from "../Token/Schema";
import * as WechatMenu from "../WechatMenu/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
import * as WechatPublicTag from "../WechatPublicTag/Schema";
import * as WechatPublicTemplate from "../WechatPublicTemplate/Schema";
import * as WechatQrCode from "../WechatQrCode/Schema";
import * as WechatUser from "../WechatUser/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
import * as Session from "../Session/Schema";
export type Passport = 'email' | 'mobile' | 'wechat' | 'wechatPublic';
export type AppType = 'web' | 'wechatMp' | 'wechatPublic';
@ -93,8 +93,6 @@ export type Schema = EntityShape & {
token$application$$aggr?: AggregationResult<Token.Schema>;
wechatMenu$application?: Array<WechatMenu.Schema>;
wechatMenu$application$$aggr?: AggregationResult<WechatMenu.Schema>;
wechatPublicAutoReply$application?: Array<wechatPublicAutoReply.Schema>;
wechatPublicAutoReply$application$$aggr?: AggregationResult<wechatPublicAutoReply.Schema>;
wechatPublicTag$application?: Array<WechatPublicTag.Schema>;
wechatPublicTag$application$$aggr?: AggregationResult<WechatPublicTag.Schema>;
wechatPublicTemplate$application?: Array<WechatPublicTemplate.Schema>;
@ -103,6 +101,8 @@ export type Schema = EntityShape & {
wechatQrCode$application$$aggr?: AggregationResult<WechatQrCode.Schema>;
wechatUser$application?: Array<WechatUser.Schema>;
wechatUser$application$$aggr?: AggregationResult<WechatUser.Schema>;
wechatPublicAutoReply$application?: Array<wechatPublicAutoReply.Schema>;
wechatPublicAutoReply$application$$aggr?: AggregationResult<wechatPublicAutoReply.Schema>;
session$entity?: Array<Session.Schema>;
session$entity$$aggr?: AggregationResult<Session.Schema>;
} & {
@ -125,11 +125,11 @@ type AttrFilter = {
sessionMessage$application: SessionMessage.Filter & SubQueryPredicateMetadata;
token$application: Token.Filter & SubQueryPredicateMetadata;
wechatMenu$application: WechatMenu.Filter & SubQueryPredicateMetadata;
wechatPublicAutoReply$application: wechatPublicAutoReply.Filter & SubQueryPredicateMetadata;
wechatPublicTag$application: WechatPublicTag.Filter & SubQueryPredicateMetadata;
wechatPublicTemplate$application: WechatPublicTemplate.Filter & SubQueryPredicateMetadata;
wechatQrCode$application: WechatQrCode.Filter & SubQueryPredicateMetadata;
wechatUser$application: WechatUser.Filter & SubQueryPredicateMetadata;
wechatPublicAutoReply$application: wechatPublicAutoReply.Filter & SubQueryPredicateMetadata;
session$entity: Session.Filter & SubQueryPredicateMetadata;
};
export type Filter = MakeFilter<AttrFilter & ExprOp<OpAttr | string>>;
@ -177,12 +177,6 @@ export type Projection = {
wechatMenu$application$$aggr?: WechatMenu.Aggregation & {
$entity: "wechatMenu";
};
wechatPublicAutoReply$application?: wechatPublicAutoReply.Selection & {
$entity: "wechatPublicAutoReply";
};
wechatPublicAutoReply$application$$aggr?: wechatPublicAutoReply.Aggregation & {
$entity: "wechatPublicAutoReply";
};
wechatPublicTag$application?: WechatPublicTag.Selection & {
$entity: "wechatPublicTag";
};
@ -207,6 +201,12 @@ export type Projection = {
wechatUser$application$$aggr?: WechatUser.Aggregation & {
$entity: "wechatUser";
};
wechatPublicAutoReply$application?: wechatPublicAutoReply.Selection & {
$entity: "wechatPublicAutoReply";
};
wechatPublicAutoReply$application$$aggr?: wechatPublicAutoReply.Aggregation & {
$entity: "wechatPublicAutoReply";
};
session$entity?: Session.Selection & {
$entity: "session";
};
@ -265,11 +265,11 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "systemId">> & (
sessionMessage$application?: OakOperation<SessionMessage.UpdateOperation["action"], Omit<SessionMessage.UpdateOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<SessionMessage.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<SessionMessage.CreateOperationData, "application" | "applicationId">> | OakOperation<SessionMessage.UpdateOperation["action"], Omit<SessionMessage.UpdateOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">>>;
token$application?: OakOperation<Token.UpdateOperation["action"], Omit<Token.UpdateOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<Token.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<Token.CreateOperationData, "application" | "applicationId">> | OakOperation<Token.UpdateOperation["action"], Omit<Token.UpdateOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">>>;
wechatMenu$application?: OakOperation<WechatMenu.UpdateOperation["action"], Omit<WechatMenu.UpdateOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatMenu.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatMenu.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatMenu.UpdateOperation["action"], Omit<WechatMenu.UpdateOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">>>;
wechatPublicAutoReply$application?: OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">>>;
wechatPublicTag$application?: OakOperation<WechatPublicTag.UpdateOperation["action"], Omit<WechatPublicTag.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatPublicTag.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatPublicTag.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatPublicTag.UpdateOperation["action"], Omit<WechatPublicTag.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">>>;
wechatPublicTemplate$application?: OakOperation<WechatPublicTemplate.UpdateOperation["action"], Omit<WechatPublicTemplate.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatPublicTemplate.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatPublicTemplate.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatPublicTemplate.UpdateOperation["action"], Omit<WechatPublicTemplate.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">>>;
wechatQrCode$application?: OakOperation<WechatQrCode.UpdateOperation["action"], Omit<WechatQrCode.UpdateOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatQrCode.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatQrCode.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatQrCode.UpdateOperation["action"], Omit<WechatQrCode.UpdateOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">>>;
wechatUser$application?: OakOperation<WechatUser.UpdateOperation["action"], Omit<WechatUser.UpdateOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatUser.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatUser.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatUser.UpdateOperation["action"], Omit<WechatUser.UpdateOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">>>;
wechatPublicAutoReply$application?: OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">>>;
session$entity?: OakOperation<Session.UpdateOperation["action"], Omit<Session.UpdateOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">> | OakOperation<"create", Omit<Session.CreateOperationData, "entity" | "entityId">[]> | Array<OakOperation<"create", Omit<Session.CreateOperationData, "entity" | "entityId">> | OakOperation<Session.UpdateOperation["action"], Omit<Session.UpdateOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">>>;
};
export type CreateSingleOperation = OakOperation<"create", CreateOperationData>;
@ -294,11 +294,11 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "systemId">> & (
sessionMessage$application?: OakOperation<SessionMessage.UpdateOperation["action"], Omit<SessionMessage.UpdateOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">> | OakOperation<SessionMessage.RemoveOperation["action"], Omit<SessionMessage.RemoveOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<SessionMessage.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<SessionMessage.CreateOperationData, "application" | "applicationId">> | OakOperation<SessionMessage.UpdateOperation["action"], Omit<SessionMessage.UpdateOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">> | OakOperation<SessionMessage.RemoveOperation["action"], Omit<SessionMessage.RemoveOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">>>;
token$application?: OakOperation<Token.UpdateOperation["action"], Omit<Token.UpdateOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">> | OakOperation<Token.RemoveOperation["action"], Omit<Token.RemoveOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<Token.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<Token.CreateOperationData, "application" | "applicationId">> | OakOperation<Token.UpdateOperation["action"], Omit<Token.UpdateOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">> | OakOperation<Token.RemoveOperation["action"], Omit<Token.RemoveOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">>>;
wechatMenu$application?: OakOperation<WechatMenu.UpdateOperation["action"], Omit<WechatMenu.UpdateOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">> | OakOperation<WechatMenu.RemoveOperation["action"], Omit<WechatMenu.RemoveOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatMenu.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatMenu.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatMenu.UpdateOperation["action"], Omit<WechatMenu.UpdateOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">> | OakOperation<WechatMenu.RemoveOperation["action"], Omit<WechatMenu.RemoveOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">>>;
wechatPublicAutoReply$application?: OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.RemoveOperation["action"], Omit<wechatPublicAutoReply.RemoveOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.RemoveOperation["action"], Omit<wechatPublicAutoReply.RemoveOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">>>;
wechatPublicTag$application?: OakOperation<WechatPublicTag.UpdateOperation["action"], Omit<WechatPublicTag.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">> | OakOperation<WechatPublicTag.RemoveOperation["action"], Omit<WechatPublicTag.RemoveOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatPublicTag.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatPublicTag.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatPublicTag.UpdateOperation["action"], Omit<WechatPublicTag.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">> | OakOperation<WechatPublicTag.RemoveOperation["action"], Omit<WechatPublicTag.RemoveOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">>>;
wechatPublicTemplate$application?: OakOperation<WechatPublicTemplate.UpdateOperation["action"], Omit<WechatPublicTemplate.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">> | OakOperation<WechatPublicTemplate.RemoveOperation["action"], Omit<WechatPublicTemplate.RemoveOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatPublicTemplate.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatPublicTemplate.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatPublicTemplate.UpdateOperation["action"], Omit<WechatPublicTemplate.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">> | OakOperation<WechatPublicTemplate.RemoveOperation["action"], Omit<WechatPublicTemplate.RemoveOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">>>;
wechatQrCode$application?: OakOperation<WechatQrCode.UpdateOperation["action"], Omit<WechatQrCode.UpdateOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">> | OakOperation<WechatQrCode.RemoveOperation["action"], Omit<WechatQrCode.RemoveOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatQrCode.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatQrCode.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatQrCode.UpdateOperation["action"], Omit<WechatQrCode.UpdateOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">> | OakOperation<WechatQrCode.RemoveOperation["action"], Omit<WechatQrCode.RemoveOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">>>;
wechatUser$application?: OakOperation<WechatUser.UpdateOperation["action"], Omit<WechatUser.UpdateOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">> | OakOperation<WechatUser.RemoveOperation["action"], Omit<WechatUser.RemoveOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatUser.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatUser.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatUser.UpdateOperation["action"], Omit<WechatUser.UpdateOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">> | OakOperation<WechatUser.RemoveOperation["action"], Omit<WechatUser.RemoveOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">>>;
wechatPublicAutoReply$application?: OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.RemoveOperation["action"], Omit<wechatPublicAutoReply.RemoveOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.RemoveOperation["action"], Omit<wechatPublicAutoReply.RemoveOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">>>;
session$entity?: OakOperation<Session.UpdateOperation["action"], Omit<Session.UpdateOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">> | OakOperation<Session.RemoveOperation["action"], Omit<Session.RemoveOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">> | OakOperation<"create", Omit<Session.CreateOperationData, "entity" | "entityId">[]> | Array<OakOperation<"create", Omit<Session.CreateOperationData, "entity" | "entityId">> | OakOperation<Session.UpdateOperation["action"], Omit<Session.UpdateOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">> | OakOperation<Session.RemoveOperation["action"], Omit<Session.RemoveOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">>>;
};
export type UpdateOperation = OakOperation<"update" | string, UpdateOperationData, Filter, Sorter>;

View File

@ -42,11 +42,11 @@ import { EntityDef as UserSystem } from "./UserSystem/Schema";
import { EntityDef as UserWechatPublicTag } from "./UserWechatPublicTag/Schema";
import { EntityDef as WechatLogin } from "./WechatLogin/Schema";
import { EntityDef as WechatMenu } from "./WechatMenu/Schema";
import { EntityDef as wechatPublicAutoReply } from "./wechatPublicAutoReply/Schema";
import { EntityDef as WechatPublicTag } from "./WechatPublicTag/Schema";
import { EntityDef as WechatPublicTemplate } from "./WechatPublicTemplate/Schema";
import { EntityDef as WechatQrCode } from "./WechatQrCode/Schema";
import { EntityDef as WechatUser } from "./WechatUser/Schema";
import { EntityDef as wechatPublicAutoReply } from "./wechatPublicAutoReply/Schema";
export type EntityDict = {
actionAuth: ActionAuth;
i18n: I18n;
@ -92,9 +92,9 @@ export type EntityDict = {
userWechatPublicTag: UserWechatPublicTag;
wechatLogin: WechatLogin;
wechatMenu: WechatMenu;
wechatPublicAutoReply: wechatPublicAutoReply;
wechatPublicTag: WechatPublicTag;
wechatPublicTemplate: WechatPublicTemplate;
wechatQrCode: WechatQrCode;
wechatUser: WechatUser;
wechatPublicAutoReply: wechatPublicAutoReply;
};

View File

@ -12,20 +12,20 @@ import * as UserSystem from "../UserSystem/Schema";
import * as UserWechatPublicTag from "../UserWechatPublicTag/Schema";
import * as WechatLogin from "../WechatLogin/Schema";
import * as WechatMenu from "../WechatMenu/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
import * as WechatPublicTag from "../WechatPublicTag/Schema";
import * as WechatPublicTemplate from "../WechatPublicTemplate/Schema";
import * as WechatQrCode from "../WechatQrCode/Schema";
import * as WechatUser from "../WechatUser/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
export type OpSchema = EntityShape & {
modiId: ForeignKey<"modi">;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string;
entityId: String<64>;
};
export type OpAttr = keyof OpSchema;
export type Schema = EntityShape & {
modiId: ForeignKey<"modi">;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string;
entityId: String<64>;
modi: Modi.Schema;
user?: User.Schema;
@ -34,11 +34,11 @@ export type Schema = EntityShape & {
userWechatPublicTag?: UserWechatPublicTag.Schema;
wechatLogin?: WechatLogin.Schema;
wechatMenu?: WechatMenu.Schema;
wechatPublicAutoReply?: wechatPublicAutoReply.Schema;
wechatPublicTag?: WechatPublicTag.Schema;
wechatPublicTemplate?: WechatPublicTemplate.Schema;
wechatQrCode?: WechatQrCode.Schema;
wechatUser?: WechatUser.Schema;
wechatPublicAutoReply?: wechatPublicAutoReply.Schema;
} & {
[A in ExpressionKey]?: any;
};
@ -49,7 +49,7 @@ type AttrFilter = {
$$updateAt$$: Q_DateValue;
modiId: Q_StringValue;
modi: Modi.Filter;
entity: Q_EnumValue<"user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string>;
entity: Q_EnumValue<"user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string>;
entityId: Q_StringValue;
user: User.Filter;
userEntityGrant: UserEntityGrant.Filter;
@ -57,11 +57,11 @@ type AttrFilter = {
userWechatPublicTag: UserWechatPublicTag.Filter;
wechatLogin: WechatLogin.Filter;
wechatMenu: WechatMenu.Filter;
wechatPublicAutoReply: wechatPublicAutoReply.Filter;
wechatPublicTag: WechatPublicTag.Filter;
wechatPublicTemplate: WechatPublicTemplate.Filter;
wechatQrCode: WechatQrCode.Filter;
wechatUser: WechatUser.Filter;
wechatPublicAutoReply: wechatPublicAutoReply.Filter;
};
export type Filter = MakeFilter<AttrFilter & ExprOp<OpAttr | string>>;
export type Projection = {
@ -81,11 +81,11 @@ export type Projection = {
userWechatPublicTag?: UserWechatPublicTag.Projection;
wechatLogin?: WechatLogin.Projection;
wechatMenu?: WechatMenu.Projection;
wechatPublicAutoReply?: wechatPublicAutoReply.Projection;
wechatPublicTag?: WechatPublicTag.Projection;
wechatPublicTemplate?: WechatPublicTemplate.Projection;
wechatQrCode?: WechatQrCode.Projection;
wechatUser?: WechatUser.Projection;
wechatPublicAutoReply?: wechatPublicAutoReply.Projection;
} & Partial<ExprOp<OpAttr | string>>;
type ModiEntityIdProjection = OneOf<{
id: number;
@ -111,9 +111,6 @@ type WechatLoginIdProjection = OneOf<{
type WechatMenuIdProjection = OneOf<{
entityId: number;
}>;
type wechatPublicAutoReplyIdProjection = OneOf<{
entityId: number;
}>;
type WechatPublicTagIdProjection = OneOf<{
entityId: number;
}>;
@ -126,6 +123,9 @@ type WechatQrCodeIdProjection = OneOf<{
type WechatUserIdProjection = OneOf<{
entityId: number;
}>;
type wechatPublicAutoReplyIdProjection = OneOf<{
entityId: number;
}>;
export type SortAttr = {
id: number;
} | {
@ -154,8 +154,6 @@ export type SortAttr = {
wechatLogin: WechatLogin.SortAttr;
} | {
wechatMenu: WechatMenu.SortAttr;
} | {
wechatPublicAutoReply: wechatPublicAutoReply.SortAttr;
} | {
wechatPublicTag: WechatPublicTag.SortAttr;
} | {
@ -164,6 +162,8 @@ export type SortAttr = {
wechatQrCode: WechatQrCode.SortAttr;
} | {
wechatUser: WechatUser.SortAttr;
} | {
wechatPublicAutoReply: wechatPublicAutoReply.SortAttr;
} | {
[k: string]: any;
} | OneOf<ExprOp<OpAttr | string>>;
@ -249,17 +249,6 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "entity" | "enti
} | {
entity: "wechatMenu";
entityId: ForeignKey<"WechatMenu">;
} | {
entity?: never;
entityId?: never;
wechatPublicAutoReply: wechatPublicAutoReply.CreateSingleOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
wechatPublicAutoReply: wechatPublicAutoReply.UpdateOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
} | {
entity?: never;
entityId?: never;
@ -304,6 +293,17 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "entity" | "enti
} | {
entity: "wechatUser";
entityId: ForeignKey<"WechatUser">;
} | {
entity?: never;
entityId?: never;
wechatPublicAutoReply: wechatPublicAutoReply.CreateSingleOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
wechatPublicAutoReply: wechatPublicAutoReply.UpdateOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
} | {
entity?: string;
entityId?: string;
@ -348,10 +348,6 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "entity" | "enti
wechatMenu?: WechatMenu.CreateSingleOperation | WechatMenu.UpdateOperation | WechatMenu.RemoveOperation;
entityId?: never;
entity?: never;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.CreateSingleOperation | wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
entityId?: never;
entity?: never;
} | {
wechatPublicTag?: WechatPublicTag.CreateSingleOperation | WechatPublicTag.UpdateOperation | WechatPublicTag.RemoveOperation;
entityId?: never;
@ -369,8 +365,12 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "entity" | "enti
entityId?: never;
entity?: never;
} | {
entity?: ("user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string) | null;
entityId?: ForeignKey<"User" | "UserEntityGrant" | "UserSystem" | "UserWechatPublicTag" | "WechatLogin" | "WechatMenu" | "wechatPublicAutoReply" | "WechatPublicTag" | "WechatPublicTemplate" | "WechatQrCode" | "WechatUser"> | null;
wechatPublicAutoReply?: wechatPublicAutoReply.CreateSingleOperation | wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
entityId?: never;
entity?: never;
} | {
entity?: ("user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string) | null;
entityId?: ForeignKey<"User" | "UserEntityGrant" | "UserSystem" | "UserWechatPublicTag" | "WechatLogin" | "WechatMenu" | "WechatPublicTag" | "WechatPublicTemplate" | "WechatQrCode" | "WechatUser" | "wechatPublicAutoReply"> | null;
}) & {
[k: string]: any;
};
@ -389,8 +389,6 @@ export type RemoveOperationData = {} & (({
wechatLogin?: WechatLogin.UpdateOperation | WechatLogin.RemoveOperation;
} | {
wechatMenu?: WechatMenu.UpdateOperation | WechatMenu.RemoveOperation;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
} | {
wechatPublicTag?: WechatPublicTag.UpdateOperation | WechatPublicTag.RemoveOperation;
} | {
@ -399,6 +397,8 @@ export type RemoveOperationData = {} & (({
wechatQrCode?: WechatQrCode.UpdateOperation | WechatQrCode.RemoveOperation;
} | {
wechatUser?: WechatUser.UpdateOperation | WechatUser.RemoveOperation;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
} | {
[k: string]: any;
});
@ -411,11 +411,11 @@ export type UserSystemIdSubQuery = Selection<UserSystemIdProjection>;
export type UserWechatPublicTagIdSubQuery = Selection<UserWechatPublicTagIdProjection>;
export type WechatLoginIdSubQuery = Selection<WechatLoginIdProjection>;
export type WechatMenuIdSubQuery = Selection<WechatMenuIdProjection>;
export type wechatPublicAutoReplyIdSubQuery = Selection<wechatPublicAutoReplyIdProjection>;
export type WechatPublicTagIdSubQuery = Selection<WechatPublicTagIdProjection>;
export type WechatPublicTemplateIdSubQuery = Selection<WechatPublicTemplateIdProjection>;
export type WechatQrCodeIdSubQuery = Selection<WechatQrCodeIdProjection>;
export type WechatUserIdSubQuery = Selection<WechatUserIdProjection>;
export type wechatPublicAutoReplyIdSubQuery = Selection<wechatPublicAutoReplyIdProjection>;
export type ModiEntityIdSubQuery = Selection<ModiEntityIdProjection>;
export type EntityDef = {
Schema: Schema;

View File

@ -12,7 +12,7 @@ export const desc = {
params: {
length: 32
},
ref: ["user", "userEntityGrant", "userSystem", "userWechatPublicTag", "wechatLogin", "wechatMenu", "wechatPublicAutoReply", "wechatPublicTag", "wechatPublicTemplate", "wechatQrCode", "wechatUser"]
ref: ["user", "userEntityGrant", "userSystem", "userWechatPublicTag", "wechatLogin", "wechatMenu", "wechatPublicTag", "wechatPublicTemplate", "wechatQrCode", "wechatUser", "wechatPublicAutoReply"]
},
entityId: {
notNull: true,

View File

@ -12,20 +12,20 @@ import * as UserSystem from "../UserSystem/Schema";
import * as UserWechatPublicTag from "../UserWechatPublicTag/Schema";
import * as WechatLogin from "../WechatLogin/Schema";
import * as WechatMenu from "../WechatMenu/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
import * as WechatPublicTag from "../WechatPublicTag/Schema";
import * as WechatPublicTemplate from "../WechatPublicTemplate/Schema";
import * as WechatQrCode from "../WechatQrCode/Schema";
import * as WechatUser from "../WechatUser/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
export type OpSchema = EntityShape & {
operId: ForeignKey<"oper">;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string;
entityId: String<64>;
};
export type OpAttr = keyof OpSchema;
export type Schema = EntityShape & {
operId: ForeignKey<"oper">;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string;
entityId: String<64>;
oper: Oper.Schema;
user?: User.Schema;
@ -34,11 +34,11 @@ export type Schema = EntityShape & {
userWechatPublicTag?: UserWechatPublicTag.Schema;
wechatLogin?: WechatLogin.Schema;
wechatMenu?: WechatMenu.Schema;
wechatPublicAutoReply?: wechatPublicAutoReply.Schema;
wechatPublicTag?: WechatPublicTag.Schema;
wechatPublicTemplate?: WechatPublicTemplate.Schema;
wechatQrCode?: WechatQrCode.Schema;
wechatUser?: WechatUser.Schema;
wechatPublicAutoReply?: wechatPublicAutoReply.Schema;
} & {
[A in ExpressionKey]?: any;
};
@ -49,7 +49,7 @@ type AttrFilter = {
$$updateAt$$: Q_DateValue;
operId: Q_StringValue;
oper: Oper.Filter;
entity: Q_EnumValue<"user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string>;
entity: Q_EnumValue<"user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string>;
entityId: Q_StringValue;
user: User.Filter;
userEntityGrant: UserEntityGrant.Filter;
@ -57,11 +57,11 @@ type AttrFilter = {
userWechatPublicTag: UserWechatPublicTag.Filter;
wechatLogin: WechatLogin.Filter;
wechatMenu: WechatMenu.Filter;
wechatPublicAutoReply: wechatPublicAutoReply.Filter;
wechatPublicTag: WechatPublicTag.Filter;
wechatPublicTemplate: WechatPublicTemplate.Filter;
wechatQrCode: WechatQrCode.Filter;
wechatUser: WechatUser.Filter;
wechatPublicAutoReply: wechatPublicAutoReply.Filter;
};
export type Filter = MakeFilter<AttrFilter & ExprOp<OpAttr | string>>;
export type Projection = {
@ -81,11 +81,11 @@ export type Projection = {
userWechatPublicTag?: UserWechatPublicTag.Projection;
wechatLogin?: WechatLogin.Projection;
wechatMenu?: WechatMenu.Projection;
wechatPublicAutoReply?: wechatPublicAutoReply.Projection;
wechatPublicTag?: WechatPublicTag.Projection;
wechatPublicTemplate?: WechatPublicTemplate.Projection;
wechatQrCode?: WechatQrCode.Projection;
wechatUser?: WechatUser.Projection;
wechatPublicAutoReply?: wechatPublicAutoReply.Projection;
} & Partial<ExprOp<OpAttr | string>>;
type OperEntityIdProjection = OneOf<{
id: number;
@ -111,9 +111,6 @@ type WechatLoginIdProjection = OneOf<{
type WechatMenuIdProjection = OneOf<{
entityId: number;
}>;
type wechatPublicAutoReplyIdProjection = OneOf<{
entityId: number;
}>;
type WechatPublicTagIdProjection = OneOf<{
entityId: number;
}>;
@ -126,6 +123,9 @@ type WechatQrCodeIdProjection = OneOf<{
type WechatUserIdProjection = OneOf<{
entityId: number;
}>;
type wechatPublicAutoReplyIdProjection = OneOf<{
entityId: number;
}>;
export type SortAttr = {
id: number;
} | {
@ -154,8 +154,6 @@ export type SortAttr = {
wechatLogin: WechatLogin.SortAttr;
} | {
wechatMenu: WechatMenu.SortAttr;
} | {
wechatPublicAutoReply: wechatPublicAutoReply.SortAttr;
} | {
wechatPublicTag: WechatPublicTag.SortAttr;
} | {
@ -164,6 +162,8 @@ export type SortAttr = {
wechatQrCode: WechatQrCode.SortAttr;
} | {
wechatUser: WechatUser.SortAttr;
} | {
wechatPublicAutoReply: wechatPublicAutoReply.SortAttr;
} | {
[k: string]: any;
} | OneOf<ExprOp<OpAttr | string>>;
@ -246,17 +246,6 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "entity" | "enti
} | {
entity: "wechatMenu";
entityId: ForeignKey<"WechatMenu">;
} | {
entity?: never;
entityId?: never;
wechatPublicAutoReply: wechatPublicAutoReply.CreateSingleOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
wechatPublicAutoReply: wechatPublicAutoReply.UpdateOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
} | {
entity?: never;
entityId?: never;
@ -301,6 +290,17 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "entity" | "enti
} | {
entity: "wechatUser";
entityId: ForeignKey<"WechatUser">;
} | {
entity?: never;
entityId?: never;
wechatPublicAutoReply: wechatPublicAutoReply.CreateSingleOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
wechatPublicAutoReply: wechatPublicAutoReply.UpdateOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
} | {
entity?: string;
entityId?: string;
@ -339,10 +339,6 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "entity" | "enti
wechatMenu?: WechatMenu.CreateSingleOperation | WechatMenu.UpdateOperation | WechatMenu.RemoveOperation;
entityId?: never;
entity?: never;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.CreateSingleOperation | wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
entityId?: never;
entity?: never;
} | {
wechatPublicTag?: WechatPublicTag.CreateSingleOperation | WechatPublicTag.UpdateOperation | WechatPublicTag.RemoveOperation;
entityId?: never;
@ -360,8 +356,12 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "entity" | "enti
entityId?: never;
entity?: never;
} | {
entity?: ("user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string) | null;
entityId?: ForeignKey<"User" | "UserEntityGrant" | "UserSystem" | "UserWechatPublicTag" | "WechatLogin" | "WechatMenu" | "wechatPublicAutoReply" | "WechatPublicTag" | "WechatPublicTemplate" | "WechatQrCode" | "WechatUser"> | null;
wechatPublicAutoReply?: wechatPublicAutoReply.CreateSingleOperation | wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
entityId?: never;
entity?: never;
} | {
entity?: ("user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string) | null;
entityId?: ForeignKey<"User" | "UserEntityGrant" | "UserSystem" | "UserWechatPublicTag" | "WechatLogin" | "WechatMenu" | "WechatPublicTag" | "WechatPublicTemplate" | "WechatQrCode" | "WechatUser" | "wechatPublicAutoReply"> | null;
}) & {
[k: string]: any;
};
@ -378,8 +378,6 @@ export type RemoveOperationData = {} & ({
wechatLogin?: WechatLogin.UpdateOperation | WechatLogin.RemoveOperation;
} | {
wechatMenu?: WechatMenu.UpdateOperation | WechatMenu.RemoveOperation;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
} | {
wechatPublicTag?: WechatPublicTag.UpdateOperation | WechatPublicTag.RemoveOperation;
} | {
@ -388,6 +386,8 @@ export type RemoveOperationData = {} & ({
wechatQrCode?: WechatQrCode.UpdateOperation | WechatQrCode.RemoveOperation;
} | {
wechatUser?: WechatUser.UpdateOperation | WechatUser.RemoveOperation;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
} | {
[k: string]: any;
});
@ -400,11 +400,11 @@ export type UserSystemIdSubQuery = Selection<UserSystemIdProjection>;
export type UserWechatPublicTagIdSubQuery = Selection<UserWechatPublicTagIdProjection>;
export type WechatLoginIdSubQuery = Selection<WechatLoginIdProjection>;
export type WechatMenuIdSubQuery = Selection<WechatMenuIdProjection>;
export type wechatPublicAutoReplyIdSubQuery = Selection<wechatPublicAutoReplyIdProjection>;
export type WechatPublicTagIdSubQuery = Selection<WechatPublicTagIdProjection>;
export type WechatPublicTemplateIdSubQuery = Selection<WechatPublicTemplateIdProjection>;
export type WechatQrCodeIdSubQuery = Selection<WechatQrCodeIdProjection>;
export type WechatUserIdSubQuery = Selection<WechatUserIdProjection>;
export type wechatPublicAutoReplyIdSubQuery = Selection<wechatPublicAutoReplyIdProjection>;
export type OperEntityIdSubQuery = Selection<OperEntityIdProjection>;
export type EntityDef = {
Schema: Schema;

View File

@ -12,7 +12,7 @@ export const desc = {
params: {
length: 32
},
ref: ["user", "userEntityGrant", "userSystem", "userWechatPublicTag", "wechatLogin", "wechatMenu", "wechatPublicAutoReply", "wechatPublicTag", "wechatPublicTemplate", "wechatQrCode", "wechatUser"]
ref: ["user", "userEntityGrant", "userSystem", "userWechatPublicTag", "wechatLogin", "wechatMenu", "wechatPublicTag", "wechatPublicTemplate", "wechatQrCode", "wechatUser", "wechatPublicAutoReply"]
},
entityId: {
notNull: true,

View File

@ -42,11 +42,11 @@ import { desc as userSystemDesc } from "./UserSystem/Storage";
import { desc as userWechatPublicTagDesc } from "./UserWechatPublicTag/Storage";
import { desc as wechatLoginDesc } from "./WechatLogin/Storage";
import { desc as wechatMenuDesc } from "./WechatMenu/Storage";
import { desc as wechatPublicAutoReplyDesc } from "./wechatPublicAutoReply/Storage";
import { desc as wechatPublicTagDesc } from "./WechatPublicTag/Storage";
import { desc as wechatPublicTemplateDesc } from "./WechatPublicTemplate/Storage";
import { desc as wechatQrCodeDesc } from "./WechatQrCode/Storage";
import { desc as wechatUserDesc } from "./WechatUser/Storage";
import { desc as wechatPublicAutoReplyDesc } from "./wechatPublicAutoReply/Storage";
export const storageSchema = {
actionAuth: actionAuthDesc,
i18n: i18nDesc,
@ -92,9 +92,9 @@ export const storageSchema = {
userWechatPublicTag: userWechatPublicTagDesc,
wechatLogin: wechatLoginDesc,
wechatMenu: wechatMenuDesc,
wechatPublicAutoReply: wechatPublicAutoReplyDesc,
wechatPublicTag: wechatPublicTagDesc,
wechatPublicTemplate: wechatPublicTemplateDesc,
wechatQrCode: wechatQrCodeDesc,
wechatUser: wechatUserDesc
wechatUser: wechatUserDesc,
wechatPublicAutoReply: wechatPublicAutoReplyDesc
};

View File

@ -42,11 +42,11 @@ import * as UserSystem from "./UserSystem/Schema";
import * as UserWechatPublicTag from "./UserWechatPublicTag/Schema";
import * as WechatLogin from "./WechatLogin/Schema";
import * as WechatMenu from "./WechatMenu/Schema";
import * as wechatPublicAutoReply from "./wechatPublicAutoReply/Schema";
import * as WechatPublicTag from "./WechatPublicTag/Schema";
import * as WechatPublicTemplate from "./WechatPublicTemplate/Schema";
import * as WechatQrCode from "./WechatQrCode/Schema";
import * as WechatUser from "./WechatUser/Schema";
import * as wechatPublicAutoReply from "./wechatPublicAutoReply/Schema";
export type ActionAuthIdSubQuery = {
[K in "$in" | "$nin"]?: (ActionAuth.ActionAuthIdSubQuery & {
entity: "actionAuth";
@ -189,8 +189,6 @@ export type ApplicationIdSubQuery = {
entity: "token";
}) | (WechatMenu.ApplicationIdSubQuery & {
entity: "wechatMenu";
}) | (wechatPublicAutoReply.ApplicationIdSubQuery & {
entity: "wechatPublicAutoReply";
}) | (WechatPublicTag.ApplicationIdSubQuery & {
entity: "wechatPublicTag";
}) | (WechatPublicTemplate.ApplicationIdSubQuery & {
@ -199,6 +197,8 @@ export type ApplicationIdSubQuery = {
entity: "wechatQrCode";
}) | (WechatUser.ApplicationIdSubQuery & {
entity: "wechatUser";
}) | (wechatPublicAutoReply.ApplicationIdSubQuery & {
entity: "wechatPublicAutoReply";
}) | (Session.ApplicationIdSubQuery & {
entity: "session";
}) | (Application.ApplicationIdSubQuery & {
@ -427,15 +427,6 @@ export type WechatMenuIdSubQuery = {
entity: "wechatMenu";
}) | any;
};
export type wechatPublicAutoReplyIdSubQuery = {
[K in "$in" | "$nin"]?: (ModiEntity.wechatPublicAutoReplyIdSubQuery & {
entity: "modiEntity";
}) | (OperEntity.wechatPublicAutoReplyIdSubQuery & {
entity: "operEntity";
}) | (wechatPublicAutoReply.wechatPublicAutoReplyIdSubQuery & {
entity: "wechatPublicAutoReply";
}) | any;
};
export type WechatPublicTagIdSubQuery = {
[K in "$in" | "$nin"]?: (UserWechatPublicTag.WechatPublicTagIdSubQuery & {
entity: "userWechatPublicTag";
@ -484,3 +475,12 @@ export type WechatUserIdSubQuery = {
entity: "wechatUser";
}) | any;
};
export type wechatPublicAutoReplyIdSubQuery = {
[K in "$in" | "$nin"]?: (ModiEntity.wechatPublicAutoReplyIdSubQuery & {
entity: "modiEntity";
}) | (OperEntity.wechatPublicAutoReplyIdSubQuery & {
entity: "operEntity";
}) | (wechatPublicAutoReply.wechatPublicAutoReplyIdSubQuery & {
entity: "wechatPublicAutoReply";
}) | any;
};

View File

@ -1,4 +0,0 @@
/// <reference types="wechat-miniprogram" />
/// <reference types="react" />
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<import("../../../oak-app-domain").EntityDict, keyof import("../../../oak-app-domain").EntityDict, false, WechatMiniprogram.Component.DataOption>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -1,3 +0,0 @@
export default OakComponent({
isList: false,
});

View File

@ -1,4 +0,0 @@
{
"navigationBarTitleText": "会话列表",
"usingComponents": {}
}

View File

@ -1,3 +0,0 @@
import { WebComponentProps } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
export default function Render(props: WebComponentProps<EntityDict, 'session', false, {}, {}>): import("react/jsx-runtime").JSX.Element;

View File

@ -1,7 +0,0 @@
import { jsx as _jsx } from "react/jsx-runtime";
import SessionList from '../list';
export default function Render(props) {
const { data } = props;
const { oakFullpath } = data;
return (_jsx(SessionList, { oakAutoUnmount: true, oakPath: oakFullpath ? `$$session-byEntity/list` : undefined, entity: "", entityFilter: "" }));
}

View File

@ -1,4 +0,0 @@
/// <reference types="wechat-miniprogram" />
/// <reference types="react" />
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<import("../../../oak-app-domain").EntityDict, keyof import("../../../oak-app-domain").EntityDict, false, WechatMiniprogram.Component.DataOption>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -1,3 +0,0 @@
export default OakComponent({
isList: false,
});

View File

@ -1,4 +0,0 @@
{
"navigationBarTitleText": "会话列表",
"usingComponents": {}
}

View File

@ -1,3 +0,0 @@
import { WebComponentProps } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
export default function Render(props: WebComponentProps<EntityDict, 'session', false, {}, {}>): import("react/jsx-runtime").JSX.Element;

View File

@ -1,7 +0,0 @@
import { jsx as _jsx } from "react/jsx-runtime";
import SessionList from '../list';
export default function Render(props) {
const { data } = props;
const { oakFullpath } = data;
return (_jsx(SessionList, { oakAutoUnmount: true, oakPath: oakFullpath ? `$$session-byUser/list` : undefined }));
}

View File

@ -1,10 +0,0 @@
/// <reference types="react" />
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<import("../../../oak-app-domain").EntityDict, "session", true, {
entity: string;
entityFilter: any;
entityDisplay: (entity: string, entityId: string) => "";
entityProjection: any;
sessionId: string;
dialog: boolean;
}>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -1,211 +0,0 @@
export default OakComponent({
entity: 'session',
projection: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
user: {
id: 1,
name: 1,
nickname: 1,
mobile$user: {
$entity: 'mobile',
data: {
id: 1,
mobile: 1,
userId: 1,
},
},
extraFile$entity: {
$entity: 'extraFile',
data: {
id: 1,
tag1: 1,
origin: 1,
bucket: 1,
objectId: 1,
filename: 1,
extra1: 1,
extension: 1,
type: 1,
entity: 1,
entityId: 1,
},
filter: {
tag1: {
$in: ['avatar'],
},
},
},
},
sessionMessage$session: {
$entity: 'sessionMessage',
data: {
id: 1,
applicationId: 1,
userId: 1,
wechatUserId: 1,
text: 1,
createTime: 1,
type: 1,
},
sorter: [
{
$attr: {
$$createAt$$: 1,
},
$direction: 'desc',
},
],
indexFrom: 0,
count: 1,
},
$$createAt$$: 1,
},
isList: true,
formData: function ({ data: sessions, features, props }) {
// const unReadLength = wechatSessions?.filter(
// (ele) => ele.isRead
// )
return {
sessions,
};
},
lifetimes: {
async attached() {
const userId = this.features.token.getUserId(true);
if (!userId) {
this.redirectTo({
url: '/login',
backUrl: encodeURIComponent(window.location.href),
}, undefined, true);
return;
}
const { sessionId } = this.props;
// 父层传入conversationId 默认聊天
if (sessionId) {
this.setSelectedSessionId(sessionId);
}
},
},
data: {
unReadLength: 0,
selectedSessionId: '',
},
properties: {
entity: '',
entityFilter: {},
entityDisplay: (entity, entityId) => '',
entityProjection: {},
sessionId: '',
dialog: false,
},
filters: [
{
filter() {
const { entityFilter, sessionId } = this.props;
if (entityFilter) {
// 说明来源于entity
return {
...entityFilter,
/* $or: [
{
userId: {
$exists: false,
},
},
{
'#id': 'node-1',
user: {
session$user: {
'#sqp': 'not in',
'$expr1': {
$ne: [
{
'#refAttr': 'id',
},
{
'#refId': 'node-1',
'#refAttr': 'id',
}
]
},
$expr2: {
$eq: [
{
'#refAttr': 'userId',
'#refId': 'node-1',
},
{
'#refAttr': 'userId',
}
]
}
}
}
}
], */
};
}
const userId = this.features.token.getUserId();
return {
userId,
};
},
'#name': 'propsQuery',
},
],
sorters: [
{
sorter: {
$attr: {
$$updateAt$$: 1,
},
$direction: 'desc',
},
},
],
methods: {
setSelectedSessionId(sessionId) {
this.setState({
selectedSessionId: sessionId,
});
},
getFilter() {
const { entity, sessionId } = this.props;
// 当外层upsert传入id时走这里
if (sessionId) {
return {
id: sessionId,
};
}
// bypark,byCompany,byplatform走这里
const userId = this.features.token.getUserId();
},
async clearUnRead() {
// =框架支持
// const filter = getFilter();
// await this.execute({
// action: 'update',
// data:
// this.props.userType === 'employer'
// ? {
// isEmployerRead: true,
// }
// : {
// isEntityRead: true,
// },
// filter,
// });
// await this.refresh();
},
// mobile独有
navigateToMessage(sessionId) {
this.navigateTo({
url: '/sessionMessage/list',
sessionId,
}, undefined, true);
},
},
});

View File

@ -1,4 +0,0 @@
{
"navigationBarTitleText": "会话列表",
"usingComponents": {}
}

View File

@ -1,39 +0,0 @@
/** index.wxss **/
.container {
display: flex;
flex-direction: row;
background: var(--oak-bg-color-page);
}
.conversationContainer {
display: flex;
flex-direction: column;
width: 100%;
.messageNumberBox {
display: flex;
flex-direction: row;
align-items: center;
padding: 0 10px;
height: 40px;
justify-content: space-between;
border-top: 1px solid var(--oak-border-color);
border-bottom: 1px solid var(--oak-border-color);
.messageText {
font-size: 16px;
color: var(--oak-text-color-primary);
}
.numberText {
font-size: 16px;
color: var(--oak-text-color-primary);
}
.clearIcon {
font-size: 16px;
color: var(--oak-text-color-secondary);
}
}
}

View File

View File

@ -1,69 +0,0 @@
"use strict";
// import React from 'react';
// import Style from './mobile.module.less';
// import ConversationHeader from '@project/components/conversation/header';
// import ConversationCell from '@project/components/conversation/cell';
// import ConversationMessageNumber from '@project/components/conversation/messageNumber';
// import { WebComponentProps } from 'oak-frontend-base';
// import { EntityDict } from '@oak-app-domain';
// export default function Render(
// props: WebComponentProps<
// EntityDict,
// 'conversation',
// false,
// {
// conversations: EntityDict['conversation']['Schema'][];
// selectedConversationId: string;
// unReadConversation: number;
// userType: string;
// },
// {
// clearUnRead: () => void;
// setSelectedConversationId: (conversationId: string) => void;
// navigateToConversationMessage: (conversationId: string) => void;
// }
// >
// ) {
// const { data, methods } = props;
// const {
// conversations,
// selectedConversationId,
// oakFullpath,
// unReadConversation,
// userType,
// } = data;
// const {
// clearUnRead,
// setSelectedConversationId,
// navigateToConversationMessage,
// } = methods;
// return (
// <div className={Style.container}>
// <div className={Style.conversationContainer}>
// <ConversationHeader />
// <ConversationMessageNumber
// number={unReadConversation}
// clear={clearUnRead}
// />
// {conversations?.map((conversation: any, index: number) => {
// return (
// <ConversationCell
// userType={userType}
// selectedId={selectedConversationId}
// onSelect={(id: string) => {
// navigateToConversationMessage(conversation.id);
// }}
// oakId={conversation.id}
// key={conversation.id}
// oakPath={
// oakFullpath
// ? `${oakFullpath}.${conversation.id}`
// : ''
// }
// />
// );
// })}
// </div>
// </div>
// );
// }

View File

@ -1,66 +0,0 @@
/** index.wxss **/
.container {
overflow: hidden;
height: 100%;
}
.bothContainer {
margin: 0 auto;
margin-top: 5vh;
width: 90%;
min-width: 600px;
height: 80vh;
display: flex;
flex-direction: row;
background-color: #fff;
box-shadow: 0 11px 20px 0 rgb(0 0 0 / 30%);
}
.dialogContainer {
margin-top: unset;
width: 100%;
height: 80vh;
}
.inner {
display: flex;
overflow: scroll;
flex-direction: column;
// margin-top: 50px;
overflow-x: hidden;
height: 100%;
}
.conversationContainer {
display: flex;
flex-direction: column;
width: 300px;
border-right: 1px solid var(--oak-border-color);
.messageNumberBox {
display: flex;
flex-direction: row;
align-items: center;
padding: 0 10px;
height: 40px;
justify-content: space-between;
border-top: 1px solid var(--oak-border-color);
border-bottom: 1px solid var(--oak-border-color);
.messageText {
font-size: 16px;
color: var(--oak-text-color-primary);
}
.numberText {
font-size: 16px;
color: var(--oak-text-color-primary);
}
.clearIcon {
font-size: 16px;
color: var(--oak-text-color-secondary);
}
}
}

View File

@ -1,11 +0,0 @@
import { WebComponentProps } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
export default function Render(props: WebComponentProps<EntityDict, 'session', false, {
sessions: EntityDict['session']['Schema'][];
selectedSessionId: string;
className: string;
dialog: boolean;
entityFilter: object;
}, {
setSelectedSessionId: (conversationId: string) => void;
}>): import("react/jsx-runtime").JSX.Element;

View File

@ -1,27 +0,0 @@
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import MessageList from '../../sessionMessage/list';
import Header from '../../../components/session/header';
import SessionCell from '../../../components/session/cell';
import classNames from 'classnames';
import Style from './web.module.less';
export default function Render(props) {
const { data, methods } = props;
const { sessions, selectedSessionId, oakFullpath,
// unReadConversation = 0,
entityFilter, dialog = false, className, } = data;
const { setSelectedSessionId } = methods;
return (_jsx("div", { className: Style.container, children: _jsxs("div", { className: classNames(Style.bothContainer, className, {
[Style.dialogContainer]: dialog,
}), children: [_jsxs("div", { className: Style.conversationContainer, children: [_jsx(Header, {}), _jsx("div", { className: Style.inner, children: sessions?.map((session, index) => {
return (_jsx(SessionCell, { entityFilter: entityFilter, selectedId: selectedSessionId, onSelect: (id) => {
setSelectedSessionId(id);
}, oakId: session.id, oakPath: oakFullpath
? `${oakFullpath}.${session.id}`
: '' }, session.id));
}) })] }), selectedSessionId && (_jsx(MessageList, { sessionId: selectedSessionId,
// userType={userType || 'employer'}
// isCombine={true}
oakAutoUnmount: true, oakPath: oakFullpath
? `$$session-base/sessionMessage`
: undefined }))] }) }));
}

View File

@ -1,250 +0,0 @@
import { generateNewId } from 'oak-domain/lib/utils/uuid';
export default OakComponent({
entity: 'sessionMessage',
projection: {
id: 1,
text: 1,
type: 1,
userId: 1,
wechatUserId: 1,
createTime: 1,
$$createAt$$: 1,
extraFile$entity: {
$entity: 'extraFile',
data: {
id: 1,
tag1: 1,
origin: 1,
bucket: 1,
objectId: 1,
filename: 1,
extra1: 1,
extension: 1,
type: 1,
entity: 1,
entityId: 1,
},
// filter: {
// tag1: {
// $in: ['image'],
// },
// },
},
sessionId: 1,
session: {
id: 1,
entity: 1,
entityId: 1,
},
},
isList: true,
lifetimes: {
async ready() {
const { sessionId } = this.props;
const userId = this.features.token.getUserId(true);
const applicationId = this.features.application.getApplicationId();
if (!sessionId) {
const entity = 'application';
const entityId = applicationId;
const type = 'web';
const { result: newSessionId } = await this.features.cache.exec('createSession', { type, entity, entityId });
this.setState({
newSessionId,
});
}
// if (!userId) {
// this.redirectTo(
// {
// url: '/login',
// backUrl: encodeURIComponent(window.location.href),
// },
// undefined,
// true
// );
// return;
// }
// (this as any).timer = setInterval(() => {
// this.refresh();
// }, 2000);
// this.getConversationInfo();
},
detached() {
if (this.timer) {
clearInterval(this.timer);
}
},
},
listeners: {
num(prev, next) {
if (prev.num !== next.num) {
if (next.num > 0 && next.num <= 20) {
this.pageScroll('comment');
}
}
},
sessionId(prev, next) {
if (this.state.oakFullpath) {
if (prev.sessionId !== next.sessionId) {
if (next.sessionId) {
this.getConversationInfo();
// 如果sessionId变了需要重新刷新下
this.refresh();
}
}
}
},
},
formData({ data: sessionMessageList = [], features }) {
return {
sessionMessageList,
num: sessionMessageList?.length,
};
},
properties: {
sessionId: '',
userType: '',
dialog: false,
},
filters: [
{
filter() {
const { sessionId } = this.props;
return {
sessionId,
type: {
$exists: true,
},
};
},
},
],
sorters: [
{
sorter: {
$attr: {
$$createAt$$: 1,
},
$direction: 'desc',
},
},
],
data: {
content: '',
buttonHidden: true,
selectedTradeId: '',
newSessionId: '',
},
methods: {
setContent(text) {
this.setState({
text,
});
},
setSelectedTradeId(tradeId) {
this.setState({
selectedTradeId: tradeId,
});
},
setButtonHidden(isHidden) {
this.setState({
buttonHidden: isHidden,
});
},
async getConversationInfo() {
const { sessionId } = this.props;
if (!sessionId) {
return;
}
const { data: [session], } = await this.features.cache.refresh('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
},
filter: {
id: sessionId,
},
});
this.setState({
entity: session?.entity,
entityId: session?.entityId,
});
},
pageScroll(id) {
const doc = window.document.getElementById(id);
// setTimeout(() => doc.scrollTo(0, 10000), 500);
},
async createMessage() {
const { text, wechatUserId, newSessionId } = this.state;
const { sessionId } = this.props;
const userId = this.features.token.getUserId();
const applicationId = this.features.application.getApplicationId();
if (!this.state.text) {
this.setMessage({
type: 'warning',
content: '请输入内容',
});
return;
}
this.addItem({
applicationId,
text,
userId,
wechatUserId,
sessionId: sessionId || newSessionId,
type: 'text',
createTime: Date.now(),
});
await this.execute(undefined, false);
this.setState({
text: '',
});
},
async customUpload(file) {
const { sessionId } = this.props;
// TS 语法
// file 即选中的文件
const { name, size, type, originFileObj } = file;
const extension = name.substring(name.lastIndexOf('.') + 1);
const filename = name.substring(0, name.lastIndexOf('.'));
const extraFile = {
extra1: originFileObj,
origin: 'qiniu',
type: 'image',
tag1: 'image',
objectId: generateNewId(),
filename,
fileType: type,
size,
extension,
entity: 'wechatMessage',
bucket: '',
id: generateNewId(),
};
// try {
// // 自己实现上传,并得到图片 url alt href
// const { url, bucket } = await this.features.extraFile.upload(
// extraFile
// );
// extraFile.bucket = bucket;
// extraFile.extra1 = null;
// const userId = this.features.token.getUserId();
// this.addItem({
// id: generateNewId(),
// sessionId,
// type: 'image',
// extraFile$entity: [
// {
// id: generateNewId(),
// action: 'create',
// data: extraFile,
// },
// ],
// } as EntityDict['sessionMessage']['CreateSingle']['data']);
// await this.execute(undefined, false);
// } catch (err) {
// throw err;
// }
},
},
});

View File

@ -1,5 +0,0 @@
{
"navigationBarTitleText": "消息",
"enablePullDownRefresh": false,
"usingComponents": {}
}

View File

@ -1,114 +0,0 @@
/** index.wxss **/
.container {
display: flex;
flex-direction: column;
height: 100vh;
width: 100%;
position: relative;
background: var(--oak-bg-color-page);
.inner {
display: flex;
overflow: scroll;
flex-direction: column;
margin-top: 50px;
overflow-x: hidden;
}
.bottom {
background: var(--oak-bg-color-page);
display: flex;
width: 100%;
flex-direction: column;
position: fixed;
bottom: 0;
margin: 0px;
position: absolute;
z-index: 100;
.textareaBox {
border-top: 1px solid var(--oak-border-color);
border-bottom: 1px solid var(--oak-border-color);
display: flex;
// background: var(--oak-bg-color-container);
flex-direction: row;
align-items: center;
min-height: 45px;
.plusIcon {
font-size: 24px;
}
.textarea {
margin: 5px;
border: none;
outline: none;
}
.textarea:focus {
border: none;
box-shadow: none;
}
.action {
display: flex;
flex-direction: row-reverse;
margin: 5px;
}
}
.toolbar {
display: flex;
flex-direction: row;
align-items: center;
padding: 10px;
.button {
display: flex;
flex-direction: column;
align-items: center;
margin: 5px;
.iconBox {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
background-color: #fff;
border-radius: 4px;
height: 50px;
width: 50px;
.icon {
font-size: 24px;
color: var(--oak-text-color-primary);
}
}
.text {
margin-top: 4px;
font-size: 12px;
color: var(--oak-text-color-primary);
}
}
}
}
}
.popup_title {
height: 50px;
display: flex;
flex-direction: column;
padding: 0 10px;
justify-content: center;
.title {
font-size: 16px;
}
}

View File

@ -1,288 +0,0 @@
"use strict";
// import React, { useState, useEffect } from 'react';
// import { Button, Image, Popup } from 'antd-mobile';
// import { Input, Upload, Popover, Tag } from 'antd';
// import {
// PlusCircleOutlined,
// PictureFilled,
// BookFilled,
// CloseOutlined,
// } from '@ant-design/icons';
// import ConversationMessageCell from '@project/components/conversationMessage/cell';
// import ConversationHeader from '@project/components/conversation/forConversationMessage';
// import SendTradeCard from '@project/components/trade/detail/sendCard';
// import SendSkuCard from '@project/components/sku/sendSkuCard';
// import TradeList from '@project/pages/trade/byConversation/list';
// import Style from './mobile.module.less';
// import { WebComponentProps } from 'oak-frontend-base';
// import { EntityDict } from '@oak-app-domain';
// interface CustomFile {
// name: string;
// size: number;
// type: string;
// originFileObj: File;
// }
// export default function Render(
// props: WebComponentProps<
// EntityDict,
// 'conversationMessage',
// true,
// {
// conversationMessageList: EntityDict['conversationMessage']['Schema'][];
// content: string;
// buttonHidden: boolean;
// selectedTradeId: string;
// conversationId: string;
// userType: string;
// isCombine: boolean;
// companyId: string;
// employerId: string;
// tradeId: string;
// skuId: string;
// },
// {
// setButtonHidden: (isHidden: boolean) => void;
// customUpload: (file: CustomFile) => void;
// createTradeMessage: (id: string) => void;
// createSkuMessage: (id: string) => void;
// setContent: (content: string) => void;
// pageScroll: (id: string) => void;
// createMessage: () => void;
// }
// >
// ) {
// const { data, methods } = props;
// const {
// oakFullpath,
// oakPagination,
// oakLoading,
// oakExecuting,
// conversationId,
// userType,
// conversationMessageList,
// selectedTradeId,
// content,
// isCombine,
// buttonHidden,
// companyId,
// employerId,
// tradeId,
// skuId,
// } = data;
// const {
// setButtonHidden,
// customUpload,
// createTradeMessage,
// createSkuMessage,
// setContent,
// pageScroll,
// createMessage,
// } = methods;
// const { pageSize, total, currentPage } = oakPagination || {};
// const [bottomHeight, setBottomHeight] = useState(0);
// const [tradeListVisible, setTradeListVisible] = useState(false);
// const [sendTdOpen, setSendTdOpen] = useState(true);
// const [showCard, setShowCard] = useState(true);
// const [showCard1, setShowCard1] = useState(true);
// useEffect(() => {
// if (buttonHidden) {
// const dom = window.document.getElementById('bottom');
// const newBottomHeight = dom && dom.offsetHeight || 0;
// setBottomHeight(newBottomHeight);
// } else {
// setBottomHeight(0);
// }
// }, [buttonHidden]);
// return conversationId ? (
// <div className={Style.container}>
// <ConversationHeader
// showBack={!isCombine}
// userType={userType}
// conversationId={conversationId}
// userId={employerId}
// />
// <div
// className={Style.inner}
// style={{
// marginBottom: bottomHeight ? `${bottomHeight}px` : '45px',
// }}
// id="comment"
// onClick={() => setButtonHidden(true)}
// >
// {conversationMessageList
// ?.sort(
// (a, b) =>
// (a.$$createAt$$ as number) -
// (b.$$createAt$$ as number)
// )
// .map((conversationMessage, index: number) => {
// return (
// <ConversationMessageCell
// key={conversationMessage.id}
// oakId={conversationMessage.id}
// oakPath={
// oakFullpath
// ? `${oakFullpath}.${conversationMessage.id}`
// : undefined
// }
// userType={userType}
// />
// );
// })}
// </div>
// <div className={Style.bottom} id="bottom">
// {tradeId && showCard && (
// <SendTradeCard
// conversationId={conversationId}
// userType={userType}
// setShowCard={() => {
// setShowCard(false);
// }}
// setBottomHeight={() => {
// setBottomHeight(0);
// }}
// oakId={tradeId}
// oakAutoUnmount={true}
// oakPath={
// data.oakFullpath
// ? `conversationMessage/list/trade/detail/sendCard`
// : undefined
// }
// createTradeMessage={() => {
// createTradeMessage(tradeId);
// }}
// />
// )}
// {skuId && showCard1 && (
// <SendSkuCard
// conversationId={conversationId}
// userType={userType}
// setShowCard1={() => {
// setShowCard1(false);
// }}
// setBottomHeight={() => {
// setBottomHeight(0);
// }}
// oakId={skuId}
// oakAutoUnmount={true}
// oakPath={
// data.oakFullpath
// ? `conversationMessage/list/sku/sendSkuCard`
// : undefined
// }
// createSkuMessage={() => {
// createSkuMessage(skuId);
// }}
// />
// )}
// <div className={Style.textareaBox}>
// <Input.TextArea
// className={Style.textarea}
// rows={1}
// onChange={({ target: { value } }) => {
// setContent(value);
// }}
// onFocus={() => {
// setButtonHidden(true);
// setShowCard(false);
// setBottomHeight(0);
// }}
// value={content}
// />
// <div className={Style.action}>
// {content && (
// <Button
// color="primary"
// fill="solid"
// size="middle"
// disabled={!content}
// onClick={() => {
// createMessage();
// pageScroll('comment');
// }}
// style={{ width: '56px', fontSize: '14px' }}
// >
// 发送
// </Button>
// )}
// {!content && (
// <PlusCircleOutlined
// className={Style.plusIcon}
// onClick={() => {
// setButtonHidden(false);
// setShowCard(false);
// }}
// />
// )}
// </div>
// </div>
// {!buttonHidden && (
// <div className={Style.toolbar}>
// <div className={Style.button}>
// <Upload
// accept={'image/*'}
// multiple={false}
// showUploadList={false}
// onChange={({ file }) => {
// customUpload(file as CustomFile);
// }}
// >
// <div className={Style.iconBox}>
// <PictureFilled className={Style.icon} />
// </div>
// </Upload>
// <div className={Style.text}>图片</div>
// </div>
// {['company', 'employer'].includes(userType) && (
// <>
// <div
// className={Style.button}
// onClick={() => {
// setTradeListVisible(true);
// }}
// >
// <div className={Style.iconBox}>
// <BookFilled className={Style.icon} />
// </div>
// <div className={Style.text}>订单</div>
// </div>
// <Popup
// visible={tradeListVisible}
// showCloseButton={true}
// onMaskClick={() => {
// setTradeListVisible(false);
// }}
// onClose={() => {
// setTradeListVisible(false);
// }}
// >
// <div className={Style.popup_title}>
// <span className={Style.title}>
// 选择订单
// </span>
// </div>
// <TradeList
// companyId={companyId}
// userId={employerId}
// oakAutoUnmount={true}
// oakPath={
// oakFullpath
// ? '$$conversation-message/trade'
// : ''
// }
// setTradeId={(id: string) => {
// setTradeListVisible(false);
// createTradeMessage(id);
// }}
// />
// </Popup>
// </>
// )}
// </div>
// )}
// </div>
// </div>
// ) : (
// <div className={Style.background}></div>
// );
// }

View File

@ -1,77 +0,0 @@
/** index.wxss **/
.container {
display: flex;
flex: 1;
height: 100%;
// width: 100%;
flex-direction: column;
position: relative;
background: var(--oak-bg-color-page);
.inner {
display: flex;
overflow: scroll;
flex-direction: column;
margin-top: 50px;
overflow-x: hidden;
height: 100%;
}
.bottomSku {
width: calc(100% - 16px);
// position: fixed;
bottom: 176px;
z-index: 1000;
position: absolute;
}
.bottom {
border-top: 1px solid var(--oak-border-color);
background: var(--oak-bg-color-container);
display: flex;
width: 100%;
flex-direction: column;
position: fixed;
bottom: 0;
margin: 0px;
position: absolute;
z-index: 100;
.toolbar {
display: flex;
flex-direction: row;
align-items: center;
height: 30px;
.icon {
margin: 0 6px;
font-size: 20px;
color: var(--oak-text-color-secondary);
}
}
.textareaBox {
display: flex;
flex-direction: column;
padding: 0 10px;
.textarea {
border: none;
outline: none;
}
.textarea:focus {
border: none;
box-shadow: none;
}
.btn {
display: flex;
flex-direction: row;
justify-content: flex-end;
margin: 5px 0;
}
}
}
}

View File

@ -1,23 +0,0 @@
import { WebComponentProps } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
interface customFile {
name: string;
size: number;
type: string;
originFileObj: File;
}
export default function Render(props: WebComponentProps<EntityDict, 'sessionMessage', true, {
sessionMessageList: EntityDict['sessionMessage']['Schema'][];
text: string;
buttonHidden: boolean;
sessionId: string;
userType: string;
employerId: string;
}, {
setButtonHidden: (isHidden: boolean) => void;
customUpload: (file: customFile) => void;
setContent: (text: string) => void;
pageScroll: (id: string) => void;
createMessage: () => void;
}>): import("react/jsx-runtime").JSX.Element;
export {};

View File

@ -1,45 +0,0 @@
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import { useState, useEffect } from 'react';
import { Button, Input, Upload } from 'antd';
import { PictureOutlined } from '@ant-design/icons';
import MessageCell from '../../../components/sessionMessage/cell';
// import Header from '../../../components/session/forMessage';
import Style from './web.module.less';
export default function Render(props) {
const { data, methods } = props;
const { sessionId, userType, sessionMessageList, oakFullpath, text, employerId, buttonHidden, } = data;
const { setButtonHidden, customUpload, setContent, pageScroll, createMessage, } = methods;
const [bottomHeight, setBottomHeight] = useState(0);
useEffect(() => {
if (buttonHidden) {
const newBottomHeight = window.document.getElementById('bottom')?.offsetHeight;
setBottomHeight(newBottomHeight);
}
else {
setBottomHeight(0);
}
}, [buttonHidden]);
return (_jsxs("div", { className: Style.container, children: [_jsx("div", { className: Style.inner, style: {
marginBottom: bottomHeight ? `${bottomHeight}px` : '168px',
}, id: "comment", onClick: () => setButtonHidden(true), children: sessionMessageList
?.sort((a, b) => a.$$createAt$$ -
b.$$createAt$$)
.map((sessionMessage, index) => {
return (_jsx(MessageCell, { oakId: sessionMessage.id, oakPath: oakFullpath
? `${oakFullpath}.${sessionMessage.id}`
: '' }, sessionMessage.id));
}) }), _jsxs("div", { className: Style.bottom, id: "bottom", children: [_jsx("div", { className: Style.toolbar, children: _jsx(Upload, { accept: 'image/*', multiple: false, showUploadList: false, customRequest: () => { }, onChange: ({ file }) => {
customUpload(file);
}, children: _jsx(PictureOutlined, { className: Style.icon }) }) }), _jsxs("div", { className: Style.textareaBox, children: [_jsx(Input.TextArea, { className: Style.textarea, rows: 5, onChange: (e) => {
setContent(e.target.value);
}, onFocus: () => {
setButtonHidden(true);
}, onPressEnter: (e) => {
e.preventDefault();
createMessage();
pageScroll('comment');
}, value: text }), _jsx("div", { className: Style.btn, children: _jsx(Button, { type: "primary", disabled: text ? false : true, onClick: () => {
createMessage();
pageScroll('comment');
}, children: "\u53D1\u9001" }) })] })] })] }));
}

View File

@ -9,9 +9,8 @@ const triggers = [
when: 'after',
fn: async (event, context) => {
const { operation: { data }, } = event;
const { sessionId, type, text, } = data;
const { sessionId } = data;
const closeRootMode = context.openRootMode();
const messageType = type;
try {
await context.operate('session', {
id: await generateNewIdAsync(),
@ -23,100 +22,6 @@ const triggers = [
id: sessionId,
},
}, {});
const [sessionMessage] = await context.select('sessionMessage', {
data: {
id: 1,
sessionId: 1,
text: 1,
type: 1,
userId: 1,
wechatUserId: 1,
wechatUser: {
id: 1,
openId: 1,
},
applicationId: 1,
createTime: 1,
$$createAt$$: 1,
aaoe: 1,
},
filter: {
sessionId,
aaoe: false,
createTime: {
$gt: Date.now() -
(48 * 60 * 60 * 1000 - 5 * 60 * 1000),
},
},
sorter: [
{
$attr: {
createTime: 1,
},
$direction: 'desc',
},
],
count: 1,
indexFrom: 0,
}, {});
if (sessionMessage && sessionMessage.wechatUserId) {
const [session] = await context.select('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
openId: 1,
},
filter: {
id: sessionId,
},
}, {});
const [application] = await context.select('application', {
data: {
id: 1,
type: 1,
config: 1,
systemId: 1,
},
filter: {
id: session.entityId,
},
}, {});
const { type, config } = application;
assert(type === 'wechatPublic' || type === 'wechatMp');
let wechatInstance;
if (type === 'wechatMp') {
const { appId, appSecret } = config;
wechatInstance = WechatSDK.getInstance(appId, type, appSecret);
}
else {
const { appId, appSecret } = config;
wechatInstance = WechatSDK.getInstance(appId, type, appSecret);
}
//微信发送客服消息
switch (messageType) {
case 'text': {
wechatInstance.sendServeMessage({
openId: sessionMessage.wechatUser?.openId,
type: messageType,
content: text,
});
break;
}
// case 'image' :{
// wechatInstance.sendServeMessage({
// openId: sessionMessage.wechatUser?.openId!,
// type: messageType,
// mediaId: '',
// });
// break;
// }
default: {
assert(false, `消息类型「${messageType}」尚未支持`);
}
}
}
}
catch (err) {
closeRootMode();
@ -126,5 +31,125 @@ const triggers = [
return 1;
},
},
{
name: '当创建sessionMessage后业务提交后再进行推送',
entity: 'sessionMessage',
action: 'create',
when: 'commit',
strict: 'takeEasy',
fn: async ({ rows }, context) => {
const closeRootMode = context.openRootMode();
try {
for (const row of rows) {
const { sessionId, aaoe, type, text } = row;
if (aaoe) {
const msgType = type;
const [sessionMessage] = await context.select('sessionMessage', {
data: {
id: 1,
sessionId: 1,
text: 1,
type: 1,
userId: 1,
wechatUserId: 1,
wechatUser: {
id: 1,
openId: 1,
},
applicationId: 1,
createTime: 1,
$$createAt$$: 1,
aaoe: 1,
},
filter: {
sessionId,
aaoe: false,
createTime: {
$gt: Date.now() -
(48 * 60 * 60 * 1000 -
5 * 60 * 1000),
},
},
sorter: [
{
$attr: {
createTime: 1,
},
$direction: 'desc',
},
],
count: 1,
indexFrom: 0,
}, {});
if (sessionMessage && sessionMessage.wechatUserId) {
const [session] = await context.select('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
openId: 1,
},
filter: {
id: sessionId,
},
}, {});
const [application] = await context.select('application', {
data: {
id: 1,
type: 1,
config: 1,
systemId: 1,
},
filter: {
id: session.entityId,
},
}, {});
const { type, config } = application;
assert(type === 'wechatPublic' || type === 'wechatMp');
let wechatInstance;
if (type === 'wechatMp') {
const { appId, appSecret } = config;
wechatInstance = WechatSDK.getInstance(appId, type, appSecret);
}
else {
const { appId, appSecret } = config;
wechatInstance = WechatSDK.getInstance(appId, type, appSecret);
}
//微信发送客服消息
switch (msgType) {
case 'text': {
wechatInstance.sendServeMessage({
openId: sessionMessage.wechatUser
?.openId,
type: msgType,
content: text,
});
break;
}
// case 'image' :{
// wechatInstance.sendServeMessage({
// openId: sessionMessage.wechatUser?.openId!,
// type: msgType,
// mediaId: '',
// });
// break;
// }
default: {
assert(false, `消息类型「${msgType}」尚未支持`);
}
}
}
}
}
}
catch (err) {
closeRootMode();
throw err;
}
closeRootMode();
return 0;
},
},
];
export default triggers;

View File

@ -1,6 +1,6 @@
import { EntityDict } from "../oak-app-domain";
import { AppType } from "../oak-app-domain/Application/Schema";
import { BackendRuntimeContext } from "../context/BackendRuntimeContext";
import { EntityDict } from '../oak-app-domain';
import { AppType } from '../oak-app-domain/Application/Schema';
import { BackendRuntimeContext } from '../context/BackendRuntimeContext';
import { WechatPublicEventData, WechatMpEventData } from 'oak-external-sdk';
export declare function createSession<ED extends EntityDict, Cxt extends BackendRuntimeContext<ED>>(params: {
data?: WechatPublicEventData | WechatMpEventData;

View File

@ -6,138 +6,144 @@ const assert_1 = require("oak-domain/lib/utils/assert");
async function createSession(params, context) {
const { data, type, entity, entityId } = params;
const userId = context.getCurrentUserId(true);
let session;
let sessionMessage$session;
switch (type) {
case 'web': {
const systemId = context.getSystemId();
let entity2 = entity;
let entityId2 = entityId;
if (!entity) {
// 默认
const [application] = await context.select('application', {
const closeRootMode = context.openRootMode();
try {
let session;
let sessionMessage$session;
switch (type) {
case 'web': {
const systemId = context.getSystemId();
let entity2 = entity;
let entityId2 = entityId;
if (!entity) {
// 默认
const [application] = await context.select('application', {
data: {
id: 1,
systemId: 1,
type: 1,
},
filter: {
systemId,
type: 'web',
},
}, {});
entity2 = 'application';
entityId2 = application?.id;
}
(0, assert_1.assert)(entity2 && entityId2);
const result = await context.select('session', {
data: {
id: 1,
systemId: 1,
type: 1,
entity: 1,
entityId: 1,
userId: 1,
lmts: 1,
},
filter: {
systemId,
type: 'web',
entity: entity2,
entityId: entityId2,
userId,
},
}, {});
entity2 = 'application';
entityId2 = application?.id;
session = result[0];
break;
}
(0, assert_1.assert)(entity2 && entityId2);
const result = await context.select('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
lmts: 1,
},
filter: {
entity: entity2,
entityId: entityId2,
userId,
},
}, {});
session = result[0];
break;
}
case 'wechatMp':
case 'wechatPublic': {
(0, assert_1.assert)(data);
(0, assert_1.assert)(entity === 'application' && entityId);
const { ToUserName, FromUserName, CreateTime, MsgType,
// Event,
Content,
// EventKey,
} = data;
const [wechatUser] = await context.select('wechatUser', {
data: {
id: 1,
openId: 1,
applicationId: 1,
},
filter: {
openId: FromUserName,
}
}, {});
const result = await context.select('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
lmts: 1,
openId: 1,
},
filter: {
entity: entity,
entityId: entityId,
openId: FromUserName,
}
}, {});
session = result[0];
sessionMessage$session = [
{
id: await (0, uuid_1.generateNewIdAsync)(),
action: 'create',
case 'wechatMp':
case 'wechatPublic': {
(0, assert_1.assert)(data);
(0, assert_1.assert)(entity === 'application' && entityId);
const { ToUserName, FromUserName, CreateTime, MsgType, Content, } = data;
const [wechatUser] = await context.select('wechatUser', {
data: {
id: await (0, uuid_1.generateNewIdAsync)(),
applicationId: wechatUser?.applicationId,
wechatUserId: wechatUser?.id,
createTime: Number(CreateTime) * 1000,
type: MsgType,
text: Content,
aaoe: false,
id: 1,
openId: 1,
applicationId: 1,
},
filter: {
openId: FromUserName,
},
}, {});
const result = await context.select('session', {
data: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
lmts: 1,
openId: 1,
},
filter: {
entity: entity,
entityId: entityId,
openId: FromUserName,
},
}, {});
session = result[0];
sessionMessage$session = [
{
id: await (0, uuid_1.generateNewIdAsync)(),
action: 'create',
data: {
id: await (0, uuid_1.generateNewIdAsync)(),
applicationId: wechatUser?.applicationId,
wechatUserId: wechatUser?.id,
createTime: Number(CreateTime) * 1000,
type: MsgType,
text: Content,
aaoe: false,
},
},
];
break;
}
default: {
(0, assert_1.assert)(false, `传入不支持的type: ${type}`);
}
}
if (session) {
if (!sessionMessage$session) {
closeRootMode();
return session.id;
}
await context.operate('session', {
id: await (0, uuid_1.generateNewIdAsync)(),
action: 'update',
data: {
sessionMessage$session,
},
];
break;
}
default: {
(0, assert_1.assert)(false, `传入不支持的type: ${type}`);
}
}
if (session) {
if (!sessionMessage$session) {
filter: {
id: session.id,
},
}, {
dontCollect: true,
});
closeRootMode();
return session.id;
}
await context.operate('session', {
id: await (0, uuid_1.generateNewIdAsync)(),
action: 'update',
data: {
sessionMessage$session,
},
filter: {
id: session.id,
},
}, {
dontCollect: true,
});
return session.id;
else {
const sessionId = await (0, uuid_1.generateNewIdAsync)();
await context.operate('session', {
id: await (0, uuid_1.generateNewIdAsync)(),
action: 'create',
data: Object.assign({
id: sessionId,
entity,
entityId,
userId,
lmts: Date.now(),
openId: data?.FromUserName,
}, sessionMessage$session && { sessionMessage$session }),
}, {
dontCollect: true,
});
closeRootMode();
return sessionId;
}
}
else {
const sessionId = await (0, uuid_1.generateNewIdAsync)();
await context.operate('session', {
id: await (0, uuid_1.generateNewIdAsync)(),
action: 'create',
data: Object.assign({
id: sessionId,
entity,
entityId,
userId,
lmts: Date.now(),
openId: data?.FromUserName,
}, sessionMessage$session && { sessionMessage$session }),
}, {
dontCollect: true,
});
return sessionId;
catch (e) {
closeRootMode();
throw e;
}
}
exports.createSession = createSession;

View File

@ -2,8 +2,7 @@
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<import("../../../oak-app-domain").EntityDict, "session", false, {
selectedId: string;
onSelect: (id: string) => void;
key: string;
entityFilter: {};
name: undefined;
isEntity: boolean;
name: string;
}>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -42,6 +42,29 @@ exports.default = OakComponent({
},
},
},
sessionMessage$session: {
$entity: 'sessionMessage',
data: {
id: 1,
text: 1,
type: 1,
userId: 1,
wechatUserId: 1,
createTime: 1,
$$createAt$$: 1,
aaoe: 1,
},
sorter: [
{
$attr: {
$$createAt$$: 1,
},
$direction: 'desc',
},
],
indexFrom: 0,
count: 1,
},
},
isList: false,
formData({ data, features }) {
@ -52,10 +75,7 @@ exports.default = OakComponent({
});
if (session?.sessionMessage$session) {
Object.assign(session, {
wechatMessages: session?.sessionMessage$session,
// unreadLength: session?.sessionMessage$session?.filter(
// (ele: any) => ele.isRead === false
// )?.length,
sessionMessages: session?.sessionMessage$session,
});
}
return session;
@ -65,74 +85,78 @@ exports.default = OakComponent({
const { oakId } = this.props;
const { session } = this.state;
const userId = this.features.token.getUserId(true);
const { data: readRemark } = await this.features.cache.refresh('readRemark', {
data: {
id: 1,
sessionId: 1,
userId: 1,
$$createAt$$: 1,
},
filter: {
session: {
id: oakId
},
userId,
},
sorter: [
{
$attr: {
$$createAt$$: 1,
},
$direction: 'desc',
},
],
count: 1,
});
const { data: sessionMessage } = await this.features.cache.refresh('sessionMessage', {
data: {
id: 1,
sessionId: 1,
userId: 1,
$$createAt$$: 1,
},
filter: {
session: {
id: oakId
},
},
sorter: [
{
$attr: {
$$createAt$$: 1,
},
$direction: 'desc',
},
],
count: 1,
});
if (readRemark && readRemark?.length > 0) {
if (session?.lmst > readRemark && sessionMessage[0]?.userId !== userId) {
}
}
else {
if (sessionMessage[0]?.userId !== userId) {
}
}
// TODO readRemark未实现
// const { data: readRemark } = await this.features.cache.refresh(
// 'readRemark',
// {
// data: {
// id: 1,
// sessionId: 1,
// userId: 1,
// $$createAt$$: 1,
// },
// filter: {
// sessionId: oakId,
// userId,
// },
// sorter: [
// {
// $attr: {
// $$createAt$$: 1,
// },
// $direction: 'desc',
// },
// ],
// count: 1,
// }
// );
// const { data: sessionMessage } = await this.features.cache.refresh(
// 'sessionMessage',
// {
// data: {
// id: 1,
// sessionId: 1,
// userId: 1,
// $$createAt$$: 1,
// },
// filter: {
// sessionId: oakId,
// },
// sorter: [
// {
// $attr: {
// $$createAt$$: 1,
// },
// $direction: 'desc',
// },
// ],
// count: 1,
// }
// );
// if (readRemark && readRemark?.length > 0) {
// if (
// session?.lmst > readRemark &&
// sessionMessage[0]?.userId !== userId
// ) {
// }
// } else {
// if (sessionMessage[0]?.userId !== userId) {
// }
// }
},
},
properties: {
selectedId: '',
onSelect: (id) => { },
key: '',
entityFilter: {},
name: undefined,
isEntity: false,
name: '',
},
methods: {
getAvatarUrl() {
const { userUrl, entity } = this.state;
const { entityFilter } = this.props;
const defaultUrl = 'http://qiniu.gecomebox.com/static/defaultAvatar.png';
if (entityFilter) {
const { isEntity } = this.props;
const defaultUrl = '';
if (isEntity) {
return userUrl || defaultUrl;
}
else {
@ -141,12 +165,11 @@ exports.default = OakComponent({
},
getName() {
const { user, entity, openId } = this.state;
const { entityFilter } = this.props;
if (entityFilter) {
const { isEntity } = this.props;
if (isEntity) {
const userName = user?.name;
const userNickname = user?.name || user?.nickname;
const userMobile = user?.mobile$user &&
user?.mobile$user[0]?.mobile;
const userMobile = user?.mobile$user && user?.mobile$user[0]?.mobile;
if (userName) {
return userName;
}

View File

@ -3,7 +3,7 @@ import { EntityDict } from '../../../oak-app-domain';
export default function render(props: WebComponentProps<EntityDict, 'session', false, {
id: string;
unreadLength: number;
sessiontMessages: EntityDict['sessionMessage']['Schema'][];
sessionMessages: EntityDict['sessionMessage']['Schema'][];
userType: string;
selectedId: string;
onSelect: (id: string) => void;

View File

@ -8,23 +8,23 @@ const classnames_1 = tslib_1.__importDefault(require("classnames"));
const web_module_less_1 = tslib_1.__importDefault(require("./web.module.less"));
function render(props) {
const { methods, data } = props;
const { selectedId, onSelect, userType, id, unreadLength, sessiontMessages = [], name, lmts, } = data;
const { selectedId, onSelect, id, unreadLength, sessionMessages = [], name, lmts, } = data;
const { t, getName, getAvatarUrl } = methods;
const sessiontMessage = sessiontMessages && sessiontMessages[0];
const type = sessiontMessage?.type;
const text = sessiontMessage?.text;
const sessionMessage = sessionMessages && sessionMessages[0];
const type = sessionMessage?.type;
const text = sessionMessage?.text;
const today = (0, dayjs_1.default)().startOf('day').valueOf();
const createAt2 = lmts && (0, dayjs_1.default)(lmts).startOf('day').valueOf();
const lastCreateAt = lmts && (0, dayjs_1.default)(lmts).startOf('day').valueOf();
return ((0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(web_module_less_1.default.cell, {
[web_module_less_1.default.cell_selected]: id === selectedId,
}), onClick: () => {
onSelect(id);
}, children: [(0, jsx_runtime_1.jsx)(antd_1.Badge, { dot: id === selectedId ? false : true, count: unreadLength || 0, children: (0, jsx_runtime_1.jsx)(antd_1.Image, { className: web_module_less_1.default.avatar, src: getAvatarUrl(), preview: false }) }), (0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.inner, children: [(0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.top, children: [(0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.title, children: name || getName() }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.date, children: lmts &&
(today === createAt2
}, children: [(0, jsx_runtime_1.jsx)(antd_1.Badge, { dot: id !== selectedId, count: unreadLength || 0, children: (0, jsx_runtime_1.jsx)(antd_1.Image, { className: web_module_less_1.default.avatar, src: getAvatarUrl(), preview: false }) }), (0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.inner, children: [(0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.top, children: [(0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.title, children: name || getName() }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.date, children: lmts &&
(today === lastCreateAt
? (0, dayjs_1.default)(lmts).format('HH:mm')
: (0, dayjs_1.default)(lmts).format('YYYY-MM-DD')) })] }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.message, children: type &&
(type === 'text'
? `${text}`
: `[${t(`sessiontMessage:v.type.${type}`)}消息]`) })] })] }));
: `[${t(`sessionMessage:v.type.${type}`)}消息]`) })] })] }));
}
exports.default = render;

View File

@ -1,47 +1,6 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.default = OakComponent({
// entity: 'session',
// projection: {
// id: 1,
// userId: 1,
// entity: 1,
// entityId: 1,
// lmts: 1,
// user: {
// id: 1,
// name: 1,
// nickname: 1,
// mobile$user: {
// $entity: 'mobile',
// data: {
// id: 1,
// mobile: 1,
// userId: 1,
// },
// },
// extraFile$entity: {
// $entity: 'extraFile',
// data: {
// id: 1,
// tag1: 1,
// origin: 1,
// bucket: 1,
// objectId: 1,
// filename: 1,
// extra1: 1,
// extension: 1,
// type: 1,
// entity: 1,
// },
// filter: {
// tag1: {
// $in: ['avatar'],
// },
// },
// },
// },
// },
isList: false,
formData({ data, features }) {
const { sessionId } = this.props;
@ -50,25 +9,8 @@ exports.default = OakComponent({
}
return {};
},
// filters: [
// {
// filter() {
// const { sessionId } = this.props;
// if (sessionId) {
// return {
// id: sessionId,
// };
// }
// },
// },
// ],
lifetimes: {
ready() {
const { sessionId } = this.props;
// if (sessionId) {
// this.getSession(sessionId)
// }
},
ready() { },
},
listeners: {
sessionId(prev, next) {
@ -81,7 +23,7 @@ exports.default = OakComponent({
sessionId: '',
isEntity: false,
entityDisplay: (data) => [],
entityProjection: {}, // user端指示需要取哪些entity的属性来显示entityDisplay
entityProjection: null, // user端指示需要取哪些entity的属性来显示entityDisplay
},
methods: {
getSession(sessionId) {
@ -133,7 +75,7 @@ exports.default = OakComponent({
getAvatarUrl() {
const { userUrl, entity } = this.state;
const { isEntity } = this.props;
const defaultUrl = 'http://qiniu.gecomebox.com/static/defaultAvatar.png';
const defaultUrl = '';
if (isEntity) {
return userUrl || defaultUrl;
}

View File

@ -5,7 +5,7 @@
align-items: center;
position: fixed;
width: 100%;
z-index: 20;
z-index: 1;
height: 50px;
position: absolute;

View File

@ -3,12 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const jsx_runtime_1 = require("react/jsx-runtime");
const antd_1 = require("antd");
// import { UserOutlined } from '@ant-design/icons';
const web_module_less_1 = tslib_1.__importDefault(require("./web.module.less"));
function render(props) {
const { methods, data } = props;
const { nickname, avatarUrl, name } = data;
const defaultUrl = 'http://qiniu.gecomebox.com/static/defaultAvatar.png';
const defaultUrl = '';
return ((0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.header, children: [(0, jsx_runtime_1.jsx)(antd_1.Avatar, { shape: "square", className: web_module_less_1.default.avatar, src: avatarUrl || defaultUrl }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.nickname, children: nickname || name })] }));
}
exports.default = render;

View File

@ -1,8 +1,10 @@
/// <reference types="react" />
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<import("../../../oak-app-domain").EntityDict, "session", true, {
import { EntityDict } from '../../../oak-app-domain';
import { RowWithActions } from 'oak-frontend-base';
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<EntityDict, "session", true, {
entity: string;
entityFilter: any;
entityDisplay: (data: any) => any[];
entityDisplay: (data: EntityDict['session']['Schema'][] | RowWithActions<EntityDict, 'session'>[]) => any[];
entityProjection: any;
sessionId: string;
dialog: boolean;

View File

@ -83,14 +83,11 @@ exports.default = OakComponent({
entityDisplay &&
sessions &&
sessions.length > 0) {
const sessions1 = entityDisplay(sessions);
const newSessions = entityDisplay(sessions);
return {
sessions: sessions1,
sessions: newSessions,
};
}
// const unReadLength = wechatSessions?.filter(
// (ele) => ele.isRead
// )
//排序待框架实现
return {
sessions: sessions?.sort((a, b) => b.lmts - a.lmts),
@ -133,9 +130,9 @@ exports.default = OakComponent({
},
properties: {
entity: '',
entityFilter: undefined,
entityFilter: null,
entityDisplay: (data) => [],
entityProjection: {},
entityProjection: null,
sessionId: '',
dialog: false,
onItemClick: null,

View File

@ -1,10 +1,14 @@
import { WebComponentProps } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
type Session = EntityDict['session']['Schema'];
export default function Render(props: WebComponentProps<EntityDict, 'session', true, {
sessions: EntityDict['session']['Schema'][];
sessions: Partial<Session & {
name: string;
}>[];
selectedSessionId: string;
entityFilter: object;
}, {
setSelectedSessionId: (sessionId: string) => void;
navigateToMessage: (sessionId: string) => void;
}>): import("react/jsx-runtime").JSX.Element;
export {};

View File

@ -7,10 +7,10 @@ const header_1 = tslib_1.__importDefault(require("../../../components/session/he
const cell_1 = tslib_1.__importDefault(require("../../../components/session/cell"));
function Render(props) {
const { data, methods } = props;
const { sessions, selectedSessionId, oakFullpath, entityFilter, } = data;
const { sessions, selectedSessionId, oakFullpath, entityFilter } = data;
const { navigateToMessage, setSelectedSessionId } = methods;
return ((0, jsx_runtime_1.jsx)("div", { className: mobile_module_less_1.default.container, children: (0, jsx_runtime_1.jsxs)("div", { className: mobile_module_less_1.default.conversationContainer, children: [(0, jsx_runtime_1.jsx)(header_1.default, {}), sessions?.map((session, index) => {
return ((0, jsx_runtime_1.jsx)(cell_1.default, { entityFilter: entityFilter, selectedId: selectedSessionId, name: session?.name, onSelect: (id) => {
return ((0, jsx_runtime_1.jsx)(cell_1.default, { isEntity: entityFilter ? true : false, selectedId: selectedSessionId, name: session?.name, onSelect: (id) => {
navigateToMessage(id);
}, oakId: session.id, oakPath: oakFullpath
? `${oakFullpath}.${session.id}`

View File

@ -1,13 +1,17 @@
import { WebComponentProps } from 'oak-frontend-base';
import { WebComponentProps, RowWithActions } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
type Session = EntityDict['session']['Schema'];
export default function Render(props: WebComponentProps<EntityDict, 'session', true, {
sessions: any;
sessions: Partial<Session & {
name: string;
}>[];
selectedSessionId: string;
className: string;
dialog: boolean;
entityFilter: object;
entityDisplay: (data: any) => any[];
entityDisplay: (data: EntityDict['session']['Schema'][] | RowWithActions<EntityDict, 'session'>[]) => any[];
entityProjection: object;
}, {
setSelectedSessionId: (sessionId: string) => void;
}>): import("react/jsx-runtime").JSX.Element;
export {};

View File

@ -14,13 +14,11 @@ function Render(props) {
return ((0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.container, children: (0, jsx_runtime_1.jsxs)("div", { className: (0, classnames_1.default)(web_module_less_1.default.bothContainer, className, {
[web_module_less_1.default.dialogContainer]: dialog,
}), children: [(0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.conversationContainer, children: [(0, jsx_runtime_1.jsx)(header_1.default, {}), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.inner, children: sessions?.map((session, index) => {
return ((0, jsx_runtime_1.jsx)(cell_1.default, { entityFilter: entityFilter, name: session?.name, selectedId: selectedSessionId, onSelect: (id) => {
return ((0, jsx_runtime_1.jsx)(cell_1.default, { isEntity: entityFilter ? true : false, name: session?.name, selectedId: selectedSessionId, onSelect: (id) => {
setSelectedSessionId(id);
}, oakId: session.id, oakPath: oakFullpath
? `${oakFullpath}.${session.id}`
: '' }, session.id));
}) })] }), selectedSessionId && ((0, jsx_runtime_1.jsx)(list_1.default, { sessionId: selectedSessionId, isEntity: entityFilter ? true : false, oakAutoUnmount: true, entityDisplay: entityDisplay, entityProjection: entityProjection, oakPath: oakFullpath
? `$$sessionMessage/list`
: undefined }))] }) }));
}) })] }), selectedSessionId && ((0, jsx_runtime_1.jsx)(list_1.default, { sessionId: selectedSessionId, isEntity: entityFilter ? true : false, oakAutoUnmount: true, entityDisplay: entityDisplay, entityProjection: entityProjection, oakPath: oakFullpath ? `$$sessionMessage/list` : undefined }))] }) }));
}
exports.default = Render;

View File

@ -74,12 +74,10 @@ exports.default = OakComponent({
},
formData({ data: sessionMessage, features }) {
const type = sessionMessage?.type;
// const data = wechatMessage?.data;
const session = sessionMessage?.session;
const newSessionMessage = {
type,
aaoe: sessionMessage?.aaoe,
// data,
text: sessionMessage?.text,
id: sessionMessage?.id,
$$createAt$$: sessionMessage?.$$createAt$$,
@ -87,13 +85,13 @@ exports.default = OakComponent({
userId: session?.userId,
userMobile: session?.user?.mobile$user &&
session?.user?.mobile$user[0]?.mobile,
userAvatar: this.features.extraFile.getUrl(session?.user?.extraFile$entity &&
userAvatar: features.extraFile2.getUrl(session?.user?.extraFile$entity &&
session?.user?.extraFile$entity[0]),
};
if (type === 'image') {
const extraFile$entity = sessionMessage?.extraFile$entity;
Object.assign(newSessionMessage, {
picUrl: features.extraFile.getUrl(extraFile$entity && extraFile$entity[0]),
picUrl: features.extraFile2.getUrl(extraFile$entity && extraFile$entity[0]),
});
}
return newSessionMessage;
@ -103,8 +101,8 @@ exports.default = OakComponent({
},
methods: {
getAvatarUrl(aaoe) {
const defaultUrl = 'http://qiniu.gecomebox.com/static/defaultAvatar.png';
const { companyLogoUrl, userAvatar, parkLogoUrl } = this.state;
const defaultUrl = '';
const { userAvatar } = this.state;
if (aaoe) {
return defaultUrl;
}

View File

@ -1,12 +1,13 @@
/// <reference types="react" />
import { EntityDict } from '../../../oak-app-domain';
import { RowWithActions } from 'oak-frontend-base';
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<EntityDict, "sessionMessage", true, {
sessionId: string;
isEntity: boolean;
dialog: boolean;
entity: string;
entityId: string;
entityDisplay: (data: any) => any[];
entityDisplay: (data: EntityDict['session']['Schema'][] | RowWithActions<EntityDict, 'session'>[]) => any[];
entityProjection: any;
}>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -59,7 +59,7 @@ exports.default = OakComponent({
await this.pageScroll('comment');
});
this.createItem();
this.getConversationInfo();
this.getSessionInfo();
},
detached() {
if (this.timer) {
@ -82,7 +82,7 @@ exports.default = OakComponent({
if (prev.sessionId !== next.sessionId) {
if (next.sessionId) {
const { sessionMessageId } = this.state;
this.getConversationInfo();
this.getSessionInfo();
// 如果sessionId变了需要重新刷新下
this.refresh();
this.removeItem(sessionMessageId);
@ -112,7 +112,7 @@ exports.default = OakComponent({
entity: '',
entityId: '',
entityDisplay: (data) => [],
entityProjection: {}, // user端指示需要取哪些entity的属性来显示entityDisplay
entityProjection: null, // user端指示需要取哪些entity的属性来显示entityDisplay
},
filters: [
{
@ -137,7 +137,6 @@ exports.default = OakComponent({
data: {
content: '',
buttonHidden: true,
selectedTradeId: '',
newSessionId: '',
},
methods: {
@ -175,20 +174,12 @@ exports.default = OakComponent({
},
setContent(text) {
const { sessionMessageId } = this.state;
this.setState({
text,
});
this.updateItem({
text,
type: 'text',
}, sessionMessageId);
},
setButtonHidden(isHidden) {
this.setState({
buttonHidden: isHidden,
});
},
async getConversationInfo() {
async getSessionInfo() {
const { sessionId } = this.props;
if (!sessionId) {
return;
@ -238,10 +229,6 @@ exports.default = OakComponent({
id: sessionId,
},
});
this.setState({
entity: session?.entity,
entityId: session?.entityId,
});
},
pageScroll(id) {
const doc = window.document.getElementById(id);
@ -264,23 +251,16 @@ exports.default = OakComponent({
});
},
async createMessage() {
const { text, wechatUserId, newSessionId, sessionMessageId } = this.state;
const { text, wechatUserId, sessionMessageId } = this.state;
const { sessionId, isEntity } = this.props;
const userId = this.features.token.getUserId();
const applicationId = this.features.application.getApplicationId();
if (!this.state.text) {
this.setMessage({
type: 'warning',
content: '请输入内容',
});
return;
}
// this.addItem({
// applicationId,
// text,
// userId,
// wechatUserId,
// sessionId: sessionId || newSessionId,
// sessionId: sessionId,
// type: 'text',
// createTime: Date.now(),
// aaoe: isEntity,
@ -289,9 +269,6 @@ exports.default = OakComponent({
createTime: Date.now(),
}, sessionMessageId);
await this.execute(undefined, false);
this.setState({
text: '',
});
this.pageScroll('comment');
this.createItem();
},

View File

@ -14,15 +14,7 @@
flex-direction: column;
margin-top: 50px;
overflow-x: hidden;
height: 100%;
}
.bottomSku {
width: calc(100% - 16px);
// position: fixed;
bottom: 176px;
z-index: 1000;
position: absolute;
height: calc(100% - 50px - 190px);
}
.bottom {
@ -35,7 +27,7 @@
bottom: 0;
margin: 0px;
position: absolute;
z-index: 100;
z-index: 1;
// resize: both;
// cursor: nwse-resize;

View File

@ -1,4 +1,4 @@
import { WebComponentProps } from 'oak-frontend-base';
import { WebComponentProps, RowWithActions } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
interface customFile {
name: string;
@ -12,15 +12,11 @@ export default function Render(props: WebComponentProps<EntityDict, 'sessionMess
buttonHidden: boolean;
sessionId: string;
isEntity: boolean;
isUser: boolean;
employerId: string;
sessionMessageType: string;
sessionMessageId: string;
entityDisplay: (data: any) => any[];
entityDisplay: (data: EntityDict['session']['Schema'][] | RowWithActions<EntityDict, 'session'>[]) => any[];
entityProjection: object;
isWeChat: boolean;
}, {
setButtonHidden: (isHidden: boolean) => void;
customUpload: (file: customFile) => void;
setContent: (text: string) => void;
pageScroll: (id: string) => void;

View File

@ -2,60 +2,28 @@
Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const jsx_runtime_1 = require("react/jsx-runtime");
const react_1 = require("react");
const antd_1 = require("antd");
const icons_1 = require("@ant-design/icons");
const cell_1 = tslib_1.__importDefault(require("../../../components/sessionMessage/cell"));
const upsert_1 = tslib_1.__importDefault(require("../../../components/sessionMessage/upsert"));
const forMessage_1 = tslib_1.__importDefault(require("../../../components/session/forMessage"));
const web_module_less_1 = tslib_1.__importDefault(require("./web.module.less"));
function Render(props) {
const { data, methods } = props;
const { sessionId, isEntity, sessionMessageList, oakFullpath, text, buttonHidden, sessionMessageType, sessionMessageId, entityDisplay, entityProjection, isWeChat, } = data;
const { setButtonHidden, customUpload, setContent, pageScroll, createMessage, } = methods;
const [bottomHeight, setBottomHeight] = (0, react_1.useState)(0);
const textareaRef = (0, react_1.useRef)(null);
(0, react_1.useEffect)(() => {
if (buttonHidden) {
const newBottomHeight = window.document.getElementById('bottom')?.offsetHeight;
setBottomHeight(newBottomHeight);
}
else {
setBottomHeight(0);
}
}, [buttonHidden]);
const handleKeyDown = (event) => {
if (event.key === "Enter" && !event.shiftKey) {
event.preventDefault();
createMessage();
pageScroll('comment');
}
};
return ((0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.container, children: [(0, jsx_runtime_1.jsx)(forMessage_1.default, { sessionId: sessionId, isEntity: isEntity, oakPath: 'session:header1', oakAutoUnmount: true, entityDisplay: entityDisplay, entityProjection: entityProjection }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.inner, style: {
marginBottom: bottomHeight ? `${bottomHeight}px` : '168px',
}, id: "comment", onClick: () => setButtonHidden(true), children: sessionMessageList
const { sessionId, isEntity, sessionMessageList, oakFullpath, text, buttonHidden, sessionMessageId, entityDisplay, entityProjection, isWeChat, } = data;
const { customUpload, setContent, pageScroll, createMessage, } = methods;
return ((0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.container, children: [(0, jsx_runtime_1.jsx)(forMessage_1.default, { sessionId: sessionId, isEntity: isEntity, oakPath: '$$sessionMessage/list-session/header', oakAutoUnmount: true, entityDisplay: entityDisplay, entityProjection: entityProjection }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.inner, id: "comment", children: sessionMessageList
?.sort((a, b) => a.$$createAt$$ -
b.$$createAt$$)
.map((sessionMessage, index) => {
return ((0, jsx_runtime_1.jsx)(cell_1.default, { oakId: sessionMessage.id, oakPath: oakFullpath
? `${oakFullpath}.${sessionMessage.id}`
: '', isEntity: isEntity }, sessionMessage.id));
}) }), (0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.bottom, id: "bottom", children: [(0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.toolbar, children: isWeChat ? (
//微信资源库
(0, jsx_runtime_1.jsx)(icons_1.PictureOutlined, { className: web_module_less_1.default.icon })) : ((0, jsx_runtime_1.jsx)(antd_1.Upload, { accept: 'image/*', multiple: false, showUploadList: false, customRequest: () => { }, onChange: ({ file }) => {
customUpload(file);
}, children: (0, jsx_runtime_1.jsx)(icons_1.PictureOutlined, { className: web_module_less_1.default.icon }) })) }), (0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.textareaBox, children: [(0, jsx_runtime_1.jsx)(antd_1.Input.TextArea, { ref: textareaRef, className: web_module_less_1.default.textarea, maxLength: 500, placeholder: "Enter \u53D1\u9001\uFF0CShift + Enter\u6362\u884C", rows: 5, onChange: (e) => {
setContent(e.target.value);
}, onFocus: () => {
setButtonHidden(true);
},
// onPressEnter={(e) => {
// e.preventDefault();
// createMessage();
// pageScroll('comment');
// }}
onKeyDown: handleKeyDown, value: text }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.btn, children: (0, jsx_runtime_1.jsx)(antd_1.Button, { type: "primary", disabled: !text, onClick: () => {
createMessage();
pageScroll('comment');
}, children: "\u53D1\u9001" }) })] })] })] }));
}) }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.bottom, id: "bottom", children: sessionMessageId && ((0, jsx_runtime_1.jsx)(upsert_1.default, { isEntity: isEntity, oakId: sessionMessageId, oakPath: oakFullpath
? `${oakFullpath}.${sessionMessageId}`
: '', oakAutoUnmount: true, send: () => {
createMessage();
}, setText: (text) => {
setContent(text);
}, customUpload: (file) => {
} }, `MessageUpsert_${sessionMessageId}`)) })] }));
}
exports.default = Render;

View File

@ -1,8 +1,10 @@
/// <reference types="react" />
import { UploadFile } from 'antd/es/upload/interface';
import { EntityDict } from '../../../oak-app-domain';
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<EntityDict, "sessionMessage", true, {
sessionId: string;
userType: string;
dialog: boolean;
declare const _default: (props: import("oak-frontend-base").ReactComponentProps<EntityDict, "sessionMessage", false, {
isEntity: boolean;
customUpload: (file: UploadFile) => void;
send: () => void;
setText: (text: string) => void;
}>) => import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
export default _default;

View File

@ -0,0 +1,133 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.default = OakComponent({
entity: 'sessionMessage',
isList: false,
projection: {
id: 1,
text: 1,
type: 1,
createTime: 1,
userId: 1,
wechatUserId: 1,
$$createAt$$: 1,
sessionId: 1,
session: {
id: 1,
entity: 1,
entityId: 1,
userId: 1,
user: {
id: 1,
name: 1,
mobile$user: {
$entity: 'mobile',
data: {
id: 1,
mobile: 1,
},
},
extraFile$entity: {
$entity: 'extraFile',
data: {
id: 1,
tag1: 1,
origin: 1,
bucket: 1,
objectId: 1,
filename: 1,
extra1: 1,
extension: 1,
type: 1,
entity: 1,
},
filter: {
tag1: {
$in: ['avatar'],
},
},
},
},
},
aaoe: 1,
extraFile$entity: {
$entity: 'extraFile',
data: {
id: 1,
tag1: 1,
tag2: 1,
origin: 1,
bucket: 1,
objectId: 1,
filename: 1,
extra1: 1,
extension: 1,
type: 1,
entity: 1,
},
filter: {
tag1: {
$in: ['image'],
},
},
},
},
formData({ data: sessionMessage, features }) {
const type = sessionMessage?.type;
const session = sessionMessage?.session;
const newSessionMessage = {
type,
aaoe: sessionMessage?.aaoe,
text: sessionMessage?.text,
id: sessionMessage?.id,
$$createAt$$: sessionMessage?.$$createAt$$,
sessionId: sessionMessage?.sessionId,
userId: session?.userId,
userMobile: session?.user?.mobile$user &&
session?.user?.mobile$user[0]?.mobile,
userAvatar: this.features.extraFile.getUrl(session?.user?.extraFile$entity &&
session?.user?.extraFile$entity[0]),
};
if (type === 'image') {
const extraFile$entity = sessionMessage?.extraFile$entity;
Object.assign(newSessionMessage, {
picUrl: features.extraFile.getUrl(extraFile$entity && extraFile$entity[0]),
});
}
return newSessionMessage;
},
properties: {
isEntity: false,
customUpload: (file) => { },
send: () => { },
setText: (text) => { },
},
methods: {
setContent(text) {
const { setText } = this.props;
if (typeof setText === 'function') {
setText(text);
}
},
async upload(file) {
const { customUpload } = this.props;
if (typeof customUpload === 'function') {
customUpload(file);
}
},
async sendData() {
const { send } = this.props;
const { text } = this.state;
if (!text) {
this.setMessage({
type: 'warning',
content: this.t('enterContent'),
});
return;
}
if (typeof send === 'function') {
send();
}
},
},
});

View File

@ -0,0 +1,5 @@
{
"placeholder": "Enter 发送Shift + Enter换行",
"send": "发送",
"enterContent": "请输入内容"
}

View File

@ -0,0 +1,19 @@
import { WebComponentProps } from 'oak-frontend-base';
import { EntityDict } from '../../../oak-app-domain';
import { UploadFile } from 'antd/es/upload/interface';
export default function render(props: WebComponentProps<EntityDict, 'sessionMessage', false, {
isEntity: boolean;
isUser: boolean;
$$createAt$$: number;
text: string;
type: string;
aaoe: boolean;
picUrl: string;
sessionId: string;
oakId: string;
isWeChat: string;
}, {
setContent: (str: string) => void;
sendData: () => void;
upload: (file: UploadFile) => void;
}>): import("react/jsx-runtime").JSX.Element;

View File

@ -0,0 +1,28 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const jsx_runtime_1 = require("react/jsx-runtime");
const react_1 = require("react");
const antd_1 = require("antd");
const icons_1 = require("@ant-design/icons");
const web_module_less_1 = tslib_1.__importDefault(require("./web.module.less"));
function render(props) {
const { data, methods } = props;
const { $$createAt$$, text, type, picUrl, isEntity, aaoe, sessionId, isWeChat, } = data;
const { t, setContent, sendData, upload } = methods;
const textareaRef = (0, react_1.useRef)(null);
const handleKeyDown = (event) => {
if (event.key === 'Enter' && !event.shiftKey) {
event.preventDefault();
sendData();
}
};
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.toolbar, children: (0, jsx_runtime_1.jsx)(antd_1.Upload, { accept: 'image/*', multiple: false, showUploadList: false, customRequest: () => { }, onChange: ({ file }) => {
upload(file);
}, children: (0, jsx_runtime_1.jsx)(icons_1.PictureOutlined, { className: web_module_less_1.default.icon }) }) }), (0, jsx_runtime_1.jsxs)("div", { className: web_module_less_1.default.textareaBox, children: [(0, jsx_runtime_1.jsx)(antd_1.Input.TextArea, { ref: textareaRef, className: web_module_less_1.default.textarea, maxLength: 500, placeholder: t('placeholder'), rows: 5, onChange: (e) => {
setContent(e.target.value);
}, onFocus: () => { }, onKeyDown: handleKeyDown, value: text }), (0, jsx_runtime_1.jsx)("div", { className: web_module_less_1.default.btn, children: (0, jsx_runtime_1.jsx)(antd_1.Button, { type: "primary", disabled: !text, onClick: () => {
sendData();
}, children: t('send') }) })] })] }));
}
exports.default = render;

View File

@ -0,0 +1,41 @@
.toolbar {
display: flex;
flex-direction: row;
align-items: center;
height: 30px;
.icon {
margin: 0 6px;
font-size: 20px;
color: var(--oak-text-color-secondary);
}
}
.textareaBox {
display: flex;
flex-direction: column;
padding: 0 10px;
.textarea {
border: none;
outline: none;
resize: none;
}
.textarea:focus {
border: none;
box-shadow: none;
resize: none;
}
.btn {
display: flex;
flex-direction: row;
justify-content: flex-end;
margin: 5px 0;
}
}

View File

@ -259,6 +259,18 @@ const i18ns = [
"confirmToRemove": "您确定要删除系统吗?"
}
},
{
id: "7c6300b665cdc65858a529c9d4c46d24",
namespace: "oak-general-business-c-sessionMessage-upsert",
language: "zh-CN",
module: "oak-general-business",
position: "src/components/sessionMessage/upsert",
data: {
"placeholder": "Enter 发送Shift + Enter换行",
"send": "发送",
"enterContent": "请输入内容"
}
},
{
id: "ded171ed67640a148a4a2cc51470cf69",
namespace: "oak-general-business-c-system-application",

View File

@ -12,11 +12,11 @@ import * as Notification from "../Notification/Schema";
import * as SessionMessage from "../SessionMessage/Schema";
import * as Token from "../Token/Schema";
import * as WechatMenu from "../WechatMenu/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
import * as WechatPublicTag from "../WechatPublicTag/Schema";
import * as WechatPublicTemplate from "../WechatPublicTemplate/Schema";
import * as WechatQrCode from "../WechatQrCode/Schema";
import * as WechatUser from "../WechatUser/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
import * as Session from "../Session/Schema";
export type Passport = 'email' | 'mobile' | 'wechat' | 'wechatPublic';
export type AppType = 'web' | 'wechatMp' | 'wechatPublic';
@ -93,8 +93,6 @@ export type Schema = EntityShape & {
token$application$$aggr?: AggregationResult<Token.Schema>;
wechatMenu$application?: Array<WechatMenu.Schema>;
wechatMenu$application$$aggr?: AggregationResult<WechatMenu.Schema>;
wechatPublicAutoReply$application?: Array<wechatPublicAutoReply.Schema>;
wechatPublicAutoReply$application$$aggr?: AggregationResult<wechatPublicAutoReply.Schema>;
wechatPublicTag$application?: Array<WechatPublicTag.Schema>;
wechatPublicTag$application$$aggr?: AggregationResult<WechatPublicTag.Schema>;
wechatPublicTemplate$application?: Array<WechatPublicTemplate.Schema>;
@ -103,6 +101,8 @@ export type Schema = EntityShape & {
wechatQrCode$application$$aggr?: AggregationResult<WechatQrCode.Schema>;
wechatUser$application?: Array<WechatUser.Schema>;
wechatUser$application$$aggr?: AggregationResult<WechatUser.Schema>;
wechatPublicAutoReply$application?: Array<wechatPublicAutoReply.Schema>;
wechatPublicAutoReply$application$$aggr?: AggregationResult<wechatPublicAutoReply.Schema>;
session$entity?: Array<Session.Schema>;
session$entity$$aggr?: AggregationResult<Session.Schema>;
} & {
@ -125,11 +125,11 @@ type AttrFilter = {
sessionMessage$application: SessionMessage.Filter & SubQueryPredicateMetadata;
token$application: Token.Filter & SubQueryPredicateMetadata;
wechatMenu$application: WechatMenu.Filter & SubQueryPredicateMetadata;
wechatPublicAutoReply$application: wechatPublicAutoReply.Filter & SubQueryPredicateMetadata;
wechatPublicTag$application: WechatPublicTag.Filter & SubQueryPredicateMetadata;
wechatPublicTemplate$application: WechatPublicTemplate.Filter & SubQueryPredicateMetadata;
wechatQrCode$application: WechatQrCode.Filter & SubQueryPredicateMetadata;
wechatUser$application: WechatUser.Filter & SubQueryPredicateMetadata;
wechatPublicAutoReply$application: wechatPublicAutoReply.Filter & SubQueryPredicateMetadata;
session$entity: Session.Filter & SubQueryPredicateMetadata;
};
export type Filter = MakeFilter<AttrFilter & ExprOp<OpAttr | string>>;
@ -177,12 +177,6 @@ export type Projection = {
wechatMenu$application$$aggr?: WechatMenu.Aggregation & {
$entity: "wechatMenu";
};
wechatPublicAutoReply$application?: wechatPublicAutoReply.Selection & {
$entity: "wechatPublicAutoReply";
};
wechatPublicAutoReply$application$$aggr?: wechatPublicAutoReply.Aggregation & {
$entity: "wechatPublicAutoReply";
};
wechatPublicTag$application?: WechatPublicTag.Selection & {
$entity: "wechatPublicTag";
};
@ -207,6 +201,12 @@ export type Projection = {
wechatUser$application$$aggr?: WechatUser.Aggregation & {
$entity: "wechatUser";
};
wechatPublicAutoReply$application?: wechatPublicAutoReply.Selection & {
$entity: "wechatPublicAutoReply";
};
wechatPublicAutoReply$application$$aggr?: wechatPublicAutoReply.Aggregation & {
$entity: "wechatPublicAutoReply";
};
session$entity?: Session.Selection & {
$entity: "session";
};
@ -265,11 +265,11 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "systemId">> & (
sessionMessage$application?: OakOperation<SessionMessage.UpdateOperation["action"], Omit<SessionMessage.UpdateOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<SessionMessage.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<SessionMessage.CreateOperationData, "application" | "applicationId">> | OakOperation<SessionMessage.UpdateOperation["action"], Omit<SessionMessage.UpdateOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">>>;
token$application?: OakOperation<Token.UpdateOperation["action"], Omit<Token.UpdateOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<Token.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<Token.CreateOperationData, "application" | "applicationId">> | OakOperation<Token.UpdateOperation["action"], Omit<Token.UpdateOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">>>;
wechatMenu$application?: OakOperation<WechatMenu.UpdateOperation["action"], Omit<WechatMenu.UpdateOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatMenu.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatMenu.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatMenu.UpdateOperation["action"], Omit<WechatMenu.UpdateOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">>>;
wechatPublicAutoReply$application?: OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">>>;
wechatPublicTag$application?: OakOperation<WechatPublicTag.UpdateOperation["action"], Omit<WechatPublicTag.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatPublicTag.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatPublicTag.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatPublicTag.UpdateOperation["action"], Omit<WechatPublicTag.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">>>;
wechatPublicTemplate$application?: OakOperation<WechatPublicTemplate.UpdateOperation["action"], Omit<WechatPublicTemplate.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatPublicTemplate.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatPublicTemplate.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatPublicTemplate.UpdateOperation["action"], Omit<WechatPublicTemplate.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">>>;
wechatQrCode$application?: OakOperation<WechatQrCode.UpdateOperation["action"], Omit<WechatQrCode.UpdateOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatQrCode.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatQrCode.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatQrCode.UpdateOperation["action"], Omit<WechatQrCode.UpdateOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">>>;
wechatUser$application?: OakOperation<WechatUser.UpdateOperation["action"], Omit<WechatUser.UpdateOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatUser.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatUser.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatUser.UpdateOperation["action"], Omit<WechatUser.UpdateOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">>>;
wechatPublicAutoReply$application?: OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">>>;
session$entity?: OakOperation<Session.UpdateOperation["action"], Omit<Session.UpdateOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">> | OakOperation<"create", Omit<Session.CreateOperationData, "entity" | "entityId">[]> | Array<OakOperation<"create", Omit<Session.CreateOperationData, "entity" | "entityId">> | OakOperation<Session.UpdateOperation["action"], Omit<Session.UpdateOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">>>;
};
export type CreateSingleOperation = OakOperation<"create", CreateOperationData>;
@ -294,11 +294,11 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "systemId">> & (
sessionMessage$application?: OakOperation<SessionMessage.UpdateOperation["action"], Omit<SessionMessage.UpdateOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">> | OakOperation<SessionMessage.RemoveOperation["action"], Omit<SessionMessage.RemoveOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<SessionMessage.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<SessionMessage.CreateOperationData, "application" | "applicationId">> | OakOperation<SessionMessage.UpdateOperation["action"], Omit<SessionMessage.UpdateOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">> | OakOperation<SessionMessage.RemoveOperation["action"], Omit<SessionMessage.RemoveOperationData, "application" | "applicationId">, Omit<SessionMessage.Filter, "application" | "applicationId">>>;
token$application?: OakOperation<Token.UpdateOperation["action"], Omit<Token.UpdateOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">> | OakOperation<Token.RemoveOperation["action"], Omit<Token.RemoveOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<Token.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<Token.CreateOperationData, "application" | "applicationId">> | OakOperation<Token.UpdateOperation["action"], Omit<Token.UpdateOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">> | OakOperation<Token.RemoveOperation["action"], Omit<Token.RemoveOperationData, "application" | "applicationId">, Omit<Token.Filter, "application" | "applicationId">>>;
wechatMenu$application?: OakOperation<WechatMenu.UpdateOperation["action"], Omit<WechatMenu.UpdateOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">> | OakOperation<WechatMenu.RemoveOperation["action"], Omit<WechatMenu.RemoveOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatMenu.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatMenu.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatMenu.UpdateOperation["action"], Omit<WechatMenu.UpdateOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">> | OakOperation<WechatMenu.RemoveOperation["action"], Omit<WechatMenu.RemoveOperationData, "application" | "applicationId">, Omit<WechatMenu.Filter, "application" | "applicationId">>>;
wechatPublicAutoReply$application?: OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.RemoveOperation["action"], Omit<wechatPublicAutoReply.RemoveOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.RemoveOperation["action"], Omit<wechatPublicAutoReply.RemoveOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">>>;
wechatPublicTag$application?: OakOperation<WechatPublicTag.UpdateOperation["action"], Omit<WechatPublicTag.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">> | OakOperation<WechatPublicTag.RemoveOperation["action"], Omit<WechatPublicTag.RemoveOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatPublicTag.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatPublicTag.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatPublicTag.UpdateOperation["action"], Omit<WechatPublicTag.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">> | OakOperation<WechatPublicTag.RemoveOperation["action"], Omit<WechatPublicTag.RemoveOperationData, "application" | "applicationId">, Omit<WechatPublicTag.Filter, "application" | "applicationId">>>;
wechatPublicTemplate$application?: OakOperation<WechatPublicTemplate.UpdateOperation["action"], Omit<WechatPublicTemplate.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">> | OakOperation<WechatPublicTemplate.RemoveOperation["action"], Omit<WechatPublicTemplate.RemoveOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatPublicTemplate.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatPublicTemplate.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatPublicTemplate.UpdateOperation["action"], Omit<WechatPublicTemplate.UpdateOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">> | OakOperation<WechatPublicTemplate.RemoveOperation["action"], Omit<WechatPublicTemplate.RemoveOperationData, "application" | "applicationId">, Omit<WechatPublicTemplate.Filter, "application" | "applicationId">>>;
wechatQrCode$application?: OakOperation<WechatQrCode.UpdateOperation["action"], Omit<WechatQrCode.UpdateOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">> | OakOperation<WechatQrCode.RemoveOperation["action"], Omit<WechatQrCode.RemoveOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatQrCode.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatQrCode.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatQrCode.UpdateOperation["action"], Omit<WechatQrCode.UpdateOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">> | OakOperation<WechatQrCode.RemoveOperation["action"], Omit<WechatQrCode.RemoveOperationData, "application" | "applicationId">, Omit<WechatQrCode.Filter, "application" | "applicationId">>>;
wechatUser$application?: OakOperation<WechatUser.UpdateOperation["action"], Omit<WechatUser.UpdateOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">> | OakOperation<WechatUser.RemoveOperation["action"], Omit<WechatUser.RemoveOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<WechatUser.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<WechatUser.CreateOperationData, "application" | "applicationId">> | OakOperation<WechatUser.UpdateOperation["action"], Omit<WechatUser.UpdateOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">> | OakOperation<WechatUser.RemoveOperation["action"], Omit<WechatUser.RemoveOperationData, "application" | "applicationId">, Omit<WechatUser.Filter, "application" | "applicationId">>>;
wechatPublicAutoReply$application?: OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.RemoveOperation["action"], Omit<wechatPublicAutoReply.RemoveOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">[]> | Array<OakOperation<"create", Omit<wechatPublicAutoReply.CreateOperationData, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.UpdateOperation["action"], Omit<wechatPublicAutoReply.UpdateOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">> | OakOperation<wechatPublicAutoReply.RemoveOperation["action"], Omit<wechatPublicAutoReply.RemoveOperationData, "application" | "applicationId">, Omit<wechatPublicAutoReply.Filter, "application" | "applicationId">>>;
session$entity?: OakOperation<Session.UpdateOperation["action"], Omit<Session.UpdateOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">> | OakOperation<Session.RemoveOperation["action"], Omit<Session.RemoveOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">> | OakOperation<"create", Omit<Session.CreateOperationData, "entity" | "entityId">[]> | Array<OakOperation<"create", Omit<Session.CreateOperationData, "entity" | "entityId">> | OakOperation<Session.UpdateOperation["action"], Omit<Session.UpdateOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">> | OakOperation<Session.RemoveOperation["action"], Omit<Session.RemoveOperationData, "entity" | "entityId">, Omit<Session.Filter, "entity" | "entityId">>>;
};
export type UpdateOperation = OakOperation<"update" | string, UpdateOperationData, Filter, Sorter>;

View File

@ -42,11 +42,11 @@ import { EntityDef as UserSystem } from "./UserSystem/Schema";
import { EntityDef as UserWechatPublicTag } from "./UserWechatPublicTag/Schema";
import { EntityDef as WechatLogin } from "./WechatLogin/Schema";
import { EntityDef as WechatMenu } from "./WechatMenu/Schema";
import { EntityDef as wechatPublicAutoReply } from "./wechatPublicAutoReply/Schema";
import { EntityDef as WechatPublicTag } from "./WechatPublicTag/Schema";
import { EntityDef as WechatPublicTemplate } from "./WechatPublicTemplate/Schema";
import { EntityDef as WechatQrCode } from "./WechatQrCode/Schema";
import { EntityDef as WechatUser } from "./WechatUser/Schema";
import { EntityDef as wechatPublicAutoReply } from "./wechatPublicAutoReply/Schema";
export type EntityDict = {
actionAuth: ActionAuth;
i18n: I18n;
@ -92,9 +92,9 @@ export type EntityDict = {
userWechatPublicTag: UserWechatPublicTag;
wechatLogin: WechatLogin;
wechatMenu: WechatMenu;
wechatPublicAutoReply: wechatPublicAutoReply;
wechatPublicTag: WechatPublicTag;
wechatPublicTemplate: WechatPublicTemplate;
wechatQrCode: WechatQrCode;
wechatUser: WechatUser;
wechatPublicAutoReply: wechatPublicAutoReply;
};

View File

@ -12,20 +12,20 @@ import * as UserSystem from "../UserSystem/Schema";
import * as UserWechatPublicTag from "../UserWechatPublicTag/Schema";
import * as WechatLogin from "../WechatLogin/Schema";
import * as WechatMenu from "../WechatMenu/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
import * as WechatPublicTag from "../WechatPublicTag/Schema";
import * as WechatPublicTemplate from "../WechatPublicTemplate/Schema";
import * as WechatQrCode from "../WechatQrCode/Schema";
import * as WechatUser from "../WechatUser/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
export type OpSchema = EntityShape & {
modiId: ForeignKey<"modi">;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string;
entityId: String<64>;
};
export type OpAttr = keyof OpSchema;
export type Schema = EntityShape & {
modiId: ForeignKey<"modi">;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string;
entityId: String<64>;
modi: Modi.Schema;
user?: User.Schema;
@ -34,11 +34,11 @@ export type Schema = EntityShape & {
userWechatPublicTag?: UserWechatPublicTag.Schema;
wechatLogin?: WechatLogin.Schema;
wechatMenu?: WechatMenu.Schema;
wechatPublicAutoReply?: wechatPublicAutoReply.Schema;
wechatPublicTag?: WechatPublicTag.Schema;
wechatPublicTemplate?: WechatPublicTemplate.Schema;
wechatQrCode?: WechatQrCode.Schema;
wechatUser?: WechatUser.Schema;
wechatPublicAutoReply?: wechatPublicAutoReply.Schema;
} & {
[A in ExpressionKey]?: any;
};
@ -49,7 +49,7 @@ type AttrFilter = {
$$updateAt$$: Q_DateValue;
modiId: Q_StringValue;
modi: Modi.Filter;
entity: Q_EnumValue<"user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string>;
entity: Q_EnumValue<"user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string>;
entityId: Q_StringValue;
user: User.Filter;
userEntityGrant: UserEntityGrant.Filter;
@ -57,11 +57,11 @@ type AttrFilter = {
userWechatPublicTag: UserWechatPublicTag.Filter;
wechatLogin: WechatLogin.Filter;
wechatMenu: WechatMenu.Filter;
wechatPublicAutoReply: wechatPublicAutoReply.Filter;
wechatPublicTag: WechatPublicTag.Filter;
wechatPublicTemplate: WechatPublicTemplate.Filter;
wechatQrCode: WechatQrCode.Filter;
wechatUser: WechatUser.Filter;
wechatPublicAutoReply: wechatPublicAutoReply.Filter;
};
export type Filter = MakeFilter<AttrFilter & ExprOp<OpAttr | string>>;
export type Projection = {
@ -81,11 +81,11 @@ export type Projection = {
userWechatPublicTag?: UserWechatPublicTag.Projection;
wechatLogin?: WechatLogin.Projection;
wechatMenu?: WechatMenu.Projection;
wechatPublicAutoReply?: wechatPublicAutoReply.Projection;
wechatPublicTag?: WechatPublicTag.Projection;
wechatPublicTemplate?: WechatPublicTemplate.Projection;
wechatQrCode?: WechatQrCode.Projection;
wechatUser?: WechatUser.Projection;
wechatPublicAutoReply?: wechatPublicAutoReply.Projection;
} & Partial<ExprOp<OpAttr | string>>;
type ModiEntityIdProjection = OneOf<{
id: number;
@ -111,9 +111,6 @@ type WechatLoginIdProjection = OneOf<{
type WechatMenuIdProjection = OneOf<{
entityId: number;
}>;
type wechatPublicAutoReplyIdProjection = OneOf<{
entityId: number;
}>;
type WechatPublicTagIdProjection = OneOf<{
entityId: number;
}>;
@ -126,6 +123,9 @@ type WechatQrCodeIdProjection = OneOf<{
type WechatUserIdProjection = OneOf<{
entityId: number;
}>;
type wechatPublicAutoReplyIdProjection = OneOf<{
entityId: number;
}>;
export type SortAttr = {
id: number;
} | {
@ -154,8 +154,6 @@ export type SortAttr = {
wechatLogin: WechatLogin.SortAttr;
} | {
wechatMenu: WechatMenu.SortAttr;
} | {
wechatPublicAutoReply: wechatPublicAutoReply.SortAttr;
} | {
wechatPublicTag: WechatPublicTag.SortAttr;
} | {
@ -164,6 +162,8 @@ export type SortAttr = {
wechatQrCode: WechatQrCode.SortAttr;
} | {
wechatUser: WechatUser.SortAttr;
} | {
wechatPublicAutoReply: wechatPublicAutoReply.SortAttr;
} | {
[k: string]: any;
} | OneOf<ExprOp<OpAttr | string>>;
@ -249,17 +249,6 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "entity" | "enti
} | {
entity: "wechatMenu";
entityId: ForeignKey<"WechatMenu">;
} | {
entity?: never;
entityId?: never;
wechatPublicAutoReply: wechatPublicAutoReply.CreateSingleOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
wechatPublicAutoReply: wechatPublicAutoReply.UpdateOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
} | {
entity?: never;
entityId?: never;
@ -304,6 +293,17 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "entity" | "enti
} | {
entity: "wechatUser";
entityId: ForeignKey<"WechatUser">;
} | {
entity?: never;
entityId?: never;
wechatPublicAutoReply: wechatPublicAutoReply.CreateSingleOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
wechatPublicAutoReply: wechatPublicAutoReply.UpdateOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
} | {
entity?: string;
entityId?: string;
@ -348,10 +348,6 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "entity" | "enti
wechatMenu?: WechatMenu.CreateSingleOperation | WechatMenu.UpdateOperation | WechatMenu.RemoveOperation;
entityId?: never;
entity?: never;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.CreateSingleOperation | wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
entityId?: never;
entity?: never;
} | {
wechatPublicTag?: WechatPublicTag.CreateSingleOperation | WechatPublicTag.UpdateOperation | WechatPublicTag.RemoveOperation;
entityId?: never;
@ -369,8 +365,12 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "entity" | "enti
entityId?: never;
entity?: never;
} | {
entity?: ("user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string) | null;
entityId?: ForeignKey<"User" | "UserEntityGrant" | "UserSystem" | "UserWechatPublicTag" | "WechatLogin" | "WechatMenu" | "wechatPublicAutoReply" | "WechatPublicTag" | "WechatPublicTemplate" | "WechatQrCode" | "WechatUser"> | null;
wechatPublicAutoReply?: wechatPublicAutoReply.CreateSingleOperation | wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
entityId?: never;
entity?: never;
} | {
entity?: ("user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string) | null;
entityId?: ForeignKey<"User" | "UserEntityGrant" | "UserSystem" | "UserWechatPublicTag" | "WechatLogin" | "WechatMenu" | "WechatPublicTag" | "WechatPublicTemplate" | "WechatQrCode" | "WechatUser" | "wechatPublicAutoReply"> | null;
}) & {
[k: string]: any;
};
@ -389,8 +389,6 @@ export type RemoveOperationData = {} & (({
wechatLogin?: WechatLogin.UpdateOperation | WechatLogin.RemoveOperation;
} | {
wechatMenu?: WechatMenu.UpdateOperation | WechatMenu.RemoveOperation;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
} | {
wechatPublicTag?: WechatPublicTag.UpdateOperation | WechatPublicTag.RemoveOperation;
} | {
@ -399,6 +397,8 @@ export type RemoveOperationData = {} & (({
wechatQrCode?: WechatQrCode.UpdateOperation | WechatQrCode.RemoveOperation;
} | {
wechatUser?: WechatUser.UpdateOperation | WechatUser.RemoveOperation;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
} | {
[k: string]: any;
});
@ -411,11 +411,11 @@ export type UserSystemIdSubQuery = Selection<UserSystemIdProjection>;
export type UserWechatPublicTagIdSubQuery = Selection<UserWechatPublicTagIdProjection>;
export type WechatLoginIdSubQuery = Selection<WechatLoginIdProjection>;
export type WechatMenuIdSubQuery = Selection<WechatMenuIdProjection>;
export type wechatPublicAutoReplyIdSubQuery = Selection<wechatPublicAutoReplyIdProjection>;
export type WechatPublicTagIdSubQuery = Selection<WechatPublicTagIdProjection>;
export type WechatPublicTemplateIdSubQuery = Selection<WechatPublicTemplateIdProjection>;
export type WechatQrCodeIdSubQuery = Selection<WechatQrCodeIdProjection>;
export type WechatUserIdSubQuery = Selection<WechatUserIdProjection>;
export type wechatPublicAutoReplyIdSubQuery = Selection<wechatPublicAutoReplyIdProjection>;
export type ModiEntityIdSubQuery = Selection<ModiEntityIdProjection>;
export type EntityDef = {
Schema: Schema;

View File

@ -15,7 +15,7 @@ exports.desc = {
params: {
length: 32
},
ref: ["user", "userEntityGrant", "userSystem", "userWechatPublicTag", "wechatLogin", "wechatMenu", "wechatPublicAutoReply", "wechatPublicTag", "wechatPublicTemplate", "wechatQrCode", "wechatUser"]
ref: ["user", "userEntityGrant", "userSystem", "userWechatPublicTag", "wechatLogin", "wechatMenu", "wechatPublicTag", "wechatPublicTemplate", "wechatQrCode", "wechatUser", "wechatPublicAutoReply"]
},
entityId: {
notNull: true,

View File

@ -12,20 +12,20 @@ import * as UserSystem from "../UserSystem/Schema";
import * as UserWechatPublicTag from "../UserWechatPublicTag/Schema";
import * as WechatLogin from "../WechatLogin/Schema";
import * as WechatMenu from "../WechatMenu/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
import * as WechatPublicTag from "../WechatPublicTag/Schema";
import * as WechatPublicTemplate from "../WechatPublicTemplate/Schema";
import * as WechatQrCode from "../WechatQrCode/Schema";
import * as WechatUser from "../WechatUser/Schema";
import * as wechatPublicAutoReply from "../wechatPublicAutoReply/Schema";
export type OpSchema = EntityShape & {
operId: ForeignKey<"oper">;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string;
entityId: String<64>;
};
export type OpAttr = keyof OpSchema;
export type Schema = EntityShape & {
operId: ForeignKey<"oper">;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string;
entity: "user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string;
entityId: String<64>;
oper: Oper.Schema;
user?: User.Schema;
@ -34,11 +34,11 @@ export type Schema = EntityShape & {
userWechatPublicTag?: UserWechatPublicTag.Schema;
wechatLogin?: WechatLogin.Schema;
wechatMenu?: WechatMenu.Schema;
wechatPublicAutoReply?: wechatPublicAutoReply.Schema;
wechatPublicTag?: WechatPublicTag.Schema;
wechatPublicTemplate?: WechatPublicTemplate.Schema;
wechatQrCode?: WechatQrCode.Schema;
wechatUser?: WechatUser.Schema;
wechatPublicAutoReply?: wechatPublicAutoReply.Schema;
} & {
[A in ExpressionKey]?: any;
};
@ -49,7 +49,7 @@ type AttrFilter = {
$$updateAt$$: Q_DateValue;
operId: Q_StringValue;
oper: Oper.Filter;
entity: Q_EnumValue<"user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string>;
entity: Q_EnumValue<"user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string>;
entityId: Q_StringValue;
user: User.Filter;
userEntityGrant: UserEntityGrant.Filter;
@ -57,11 +57,11 @@ type AttrFilter = {
userWechatPublicTag: UserWechatPublicTag.Filter;
wechatLogin: WechatLogin.Filter;
wechatMenu: WechatMenu.Filter;
wechatPublicAutoReply: wechatPublicAutoReply.Filter;
wechatPublicTag: WechatPublicTag.Filter;
wechatPublicTemplate: WechatPublicTemplate.Filter;
wechatQrCode: WechatQrCode.Filter;
wechatUser: WechatUser.Filter;
wechatPublicAutoReply: wechatPublicAutoReply.Filter;
};
export type Filter = MakeFilter<AttrFilter & ExprOp<OpAttr | string>>;
export type Projection = {
@ -81,11 +81,11 @@ export type Projection = {
userWechatPublicTag?: UserWechatPublicTag.Projection;
wechatLogin?: WechatLogin.Projection;
wechatMenu?: WechatMenu.Projection;
wechatPublicAutoReply?: wechatPublicAutoReply.Projection;
wechatPublicTag?: WechatPublicTag.Projection;
wechatPublicTemplate?: WechatPublicTemplate.Projection;
wechatQrCode?: WechatQrCode.Projection;
wechatUser?: WechatUser.Projection;
wechatPublicAutoReply?: wechatPublicAutoReply.Projection;
} & Partial<ExprOp<OpAttr | string>>;
type OperEntityIdProjection = OneOf<{
id: number;
@ -111,9 +111,6 @@ type WechatLoginIdProjection = OneOf<{
type WechatMenuIdProjection = OneOf<{
entityId: number;
}>;
type wechatPublicAutoReplyIdProjection = OneOf<{
entityId: number;
}>;
type WechatPublicTagIdProjection = OneOf<{
entityId: number;
}>;
@ -126,6 +123,9 @@ type WechatQrCodeIdProjection = OneOf<{
type WechatUserIdProjection = OneOf<{
entityId: number;
}>;
type wechatPublicAutoReplyIdProjection = OneOf<{
entityId: number;
}>;
export type SortAttr = {
id: number;
} | {
@ -154,8 +154,6 @@ export type SortAttr = {
wechatLogin: WechatLogin.SortAttr;
} | {
wechatMenu: WechatMenu.SortAttr;
} | {
wechatPublicAutoReply: wechatPublicAutoReply.SortAttr;
} | {
wechatPublicTag: WechatPublicTag.SortAttr;
} | {
@ -164,6 +162,8 @@ export type SortAttr = {
wechatQrCode: WechatQrCode.SortAttr;
} | {
wechatUser: WechatUser.SortAttr;
} | {
wechatPublicAutoReply: wechatPublicAutoReply.SortAttr;
} | {
[k: string]: any;
} | OneOf<ExprOp<OpAttr | string>>;
@ -246,17 +246,6 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "entity" | "enti
} | {
entity: "wechatMenu";
entityId: ForeignKey<"WechatMenu">;
} | {
entity?: never;
entityId?: never;
wechatPublicAutoReply: wechatPublicAutoReply.CreateSingleOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
wechatPublicAutoReply: wechatPublicAutoReply.UpdateOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
} | {
entity?: never;
entityId?: never;
@ -301,6 +290,17 @@ export type CreateOperationData = FormCreateData<Omit<OpSchema, "entity" | "enti
} | {
entity: "wechatUser";
entityId: ForeignKey<"WechatUser">;
} | {
entity?: never;
entityId?: never;
wechatPublicAutoReply: wechatPublicAutoReply.CreateSingleOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
wechatPublicAutoReply: wechatPublicAutoReply.UpdateOperation;
} | {
entity: "wechatPublicAutoReply";
entityId: ForeignKey<"wechatPublicAutoReply">;
} | {
entity?: string;
entityId?: string;
@ -339,10 +339,6 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "entity" | "enti
wechatMenu?: WechatMenu.CreateSingleOperation | WechatMenu.UpdateOperation | WechatMenu.RemoveOperation;
entityId?: never;
entity?: never;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.CreateSingleOperation | wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
entityId?: never;
entity?: never;
} | {
wechatPublicTag?: WechatPublicTag.CreateSingleOperation | WechatPublicTag.UpdateOperation | WechatPublicTag.RemoveOperation;
entityId?: never;
@ -360,8 +356,12 @@ export type UpdateOperationData = FormUpdateData<Omit<OpSchema, "entity" | "enti
entityId?: never;
entity?: never;
} | {
entity?: ("user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicAutoReply" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | string) | null;
entityId?: ForeignKey<"User" | "UserEntityGrant" | "UserSystem" | "UserWechatPublicTag" | "WechatLogin" | "WechatMenu" | "wechatPublicAutoReply" | "WechatPublicTag" | "WechatPublicTemplate" | "WechatQrCode" | "WechatUser"> | null;
wechatPublicAutoReply?: wechatPublicAutoReply.CreateSingleOperation | wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
entityId?: never;
entity?: never;
} | {
entity?: ("user" | "userEntityGrant" | "userSystem" | "userWechatPublicTag" | "wechatLogin" | "wechatMenu" | "wechatPublicTag" | "wechatPublicTemplate" | "wechatQrCode" | "wechatUser" | "wechatPublicAutoReply" | string) | null;
entityId?: ForeignKey<"User" | "UserEntityGrant" | "UserSystem" | "UserWechatPublicTag" | "WechatLogin" | "WechatMenu" | "WechatPublicTag" | "WechatPublicTemplate" | "WechatQrCode" | "WechatUser" | "wechatPublicAutoReply"> | null;
}) & {
[k: string]: any;
};
@ -378,8 +378,6 @@ export type RemoveOperationData = {} & ({
wechatLogin?: WechatLogin.UpdateOperation | WechatLogin.RemoveOperation;
} | {
wechatMenu?: WechatMenu.UpdateOperation | WechatMenu.RemoveOperation;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
} | {
wechatPublicTag?: WechatPublicTag.UpdateOperation | WechatPublicTag.RemoveOperation;
} | {
@ -388,6 +386,8 @@ export type RemoveOperationData = {} & ({
wechatQrCode?: WechatQrCode.UpdateOperation | WechatQrCode.RemoveOperation;
} | {
wechatUser?: WechatUser.UpdateOperation | WechatUser.RemoveOperation;
} | {
wechatPublicAutoReply?: wechatPublicAutoReply.UpdateOperation | wechatPublicAutoReply.RemoveOperation;
} | {
[k: string]: any;
});
@ -400,11 +400,11 @@ export type UserSystemIdSubQuery = Selection<UserSystemIdProjection>;
export type UserWechatPublicTagIdSubQuery = Selection<UserWechatPublicTagIdProjection>;
export type WechatLoginIdSubQuery = Selection<WechatLoginIdProjection>;
export type WechatMenuIdSubQuery = Selection<WechatMenuIdProjection>;
export type wechatPublicAutoReplyIdSubQuery = Selection<wechatPublicAutoReplyIdProjection>;
export type WechatPublicTagIdSubQuery = Selection<WechatPublicTagIdProjection>;
export type WechatPublicTemplateIdSubQuery = Selection<WechatPublicTemplateIdProjection>;
export type WechatQrCodeIdSubQuery = Selection<WechatQrCodeIdProjection>;
export type WechatUserIdSubQuery = Selection<WechatUserIdProjection>;
export type wechatPublicAutoReplyIdSubQuery = Selection<wechatPublicAutoReplyIdProjection>;
export type OperEntityIdSubQuery = Selection<OperEntityIdProjection>;
export type EntityDef = {
Schema: Schema;

View File

@ -15,7 +15,7 @@ exports.desc = {
params: {
length: 32
},
ref: ["user", "userEntityGrant", "userSystem", "userWechatPublicTag", "wechatLogin", "wechatMenu", "wechatPublicAutoReply", "wechatPublicTag", "wechatPublicTemplate", "wechatQrCode", "wechatUser"]
ref: ["user", "userEntityGrant", "userSystem", "userWechatPublicTag", "wechatLogin", "wechatMenu", "wechatPublicTag", "wechatPublicTemplate", "wechatQrCode", "wechatUser", "wechatPublicAutoReply"]
},
entityId: {
notNull: true,

View File

@ -45,11 +45,11 @@ const Storage_41 = require("./UserSystem/Storage");
const Storage_42 = require("./UserWechatPublicTag/Storage");
const Storage_43 = require("./WechatLogin/Storage");
const Storage_44 = require("./WechatMenu/Storage");
const Storage_45 = require("./wechatPublicAutoReply/Storage");
const Storage_46 = require("./WechatPublicTag/Storage");
const Storage_47 = require("./WechatPublicTemplate/Storage");
const Storage_48 = require("./WechatQrCode/Storage");
const Storage_49 = require("./WechatUser/Storage");
const Storage_45 = require("./WechatPublicTag/Storage");
const Storage_46 = require("./WechatPublicTemplate/Storage");
const Storage_47 = require("./WechatQrCode/Storage");
const Storage_48 = require("./WechatUser/Storage");
const Storage_49 = require("./wechatPublicAutoReply/Storage");
exports.storageSchema = {
actionAuth: Storage_1.desc,
i18n: Storage_2.desc,
@ -95,9 +95,9 @@ exports.storageSchema = {
userWechatPublicTag: Storage_42.desc,
wechatLogin: Storage_43.desc,
wechatMenu: Storage_44.desc,
wechatPublicAutoReply: Storage_45.desc,
wechatPublicTag: Storage_46.desc,
wechatPublicTemplate: Storage_47.desc,
wechatQrCode: Storage_48.desc,
wechatUser: Storage_49.desc
wechatPublicTag: Storage_45.desc,
wechatPublicTemplate: Storage_46.desc,
wechatQrCode: Storage_47.desc,
wechatUser: Storage_48.desc,
wechatPublicAutoReply: Storage_49.desc
};

View File

@ -42,11 +42,11 @@ import * as UserSystem from "./UserSystem/Schema";
import * as UserWechatPublicTag from "./UserWechatPublicTag/Schema";
import * as WechatLogin from "./WechatLogin/Schema";
import * as WechatMenu from "./WechatMenu/Schema";
import * as wechatPublicAutoReply from "./wechatPublicAutoReply/Schema";
import * as WechatPublicTag from "./WechatPublicTag/Schema";
import * as WechatPublicTemplate from "./WechatPublicTemplate/Schema";
import * as WechatQrCode from "./WechatQrCode/Schema";
import * as WechatUser from "./WechatUser/Schema";
import * as wechatPublicAutoReply from "./wechatPublicAutoReply/Schema";
export type ActionAuthIdSubQuery = {
[K in "$in" | "$nin"]?: (ActionAuth.ActionAuthIdSubQuery & {
entity: "actionAuth";
@ -189,8 +189,6 @@ export type ApplicationIdSubQuery = {
entity: "token";
}) | (WechatMenu.ApplicationIdSubQuery & {
entity: "wechatMenu";
}) | (wechatPublicAutoReply.ApplicationIdSubQuery & {
entity: "wechatPublicAutoReply";
}) | (WechatPublicTag.ApplicationIdSubQuery & {
entity: "wechatPublicTag";
}) | (WechatPublicTemplate.ApplicationIdSubQuery & {
@ -199,6 +197,8 @@ export type ApplicationIdSubQuery = {
entity: "wechatQrCode";
}) | (WechatUser.ApplicationIdSubQuery & {
entity: "wechatUser";
}) | (wechatPublicAutoReply.ApplicationIdSubQuery & {
entity: "wechatPublicAutoReply";
}) | (Session.ApplicationIdSubQuery & {
entity: "session";
}) | (Application.ApplicationIdSubQuery & {
@ -427,15 +427,6 @@ export type WechatMenuIdSubQuery = {
entity: "wechatMenu";
}) | any;
};
export type wechatPublicAutoReplyIdSubQuery = {
[K in "$in" | "$nin"]?: (ModiEntity.wechatPublicAutoReplyIdSubQuery & {
entity: "modiEntity";
}) | (OperEntity.wechatPublicAutoReplyIdSubQuery & {
entity: "operEntity";
}) | (wechatPublicAutoReply.wechatPublicAutoReplyIdSubQuery & {
entity: "wechatPublicAutoReply";
}) | any;
};
export type WechatPublicTagIdSubQuery = {
[K in "$in" | "$nin"]?: (UserWechatPublicTag.WechatPublicTagIdSubQuery & {
entity: "userWechatPublicTag";
@ -484,3 +475,12 @@ export type WechatUserIdSubQuery = {
entity: "wechatUser";
}) | any;
};
export type wechatPublicAutoReplyIdSubQuery = {
[K in "$in" | "$nin"]?: (ModiEntity.wechatPublicAutoReplyIdSubQuery & {
entity: "modiEntity";
}) | (OperEntity.wechatPublicAutoReplyIdSubQuery & {
entity: "operEntity";
}) | (wechatPublicAutoReply.wechatPublicAutoReplyIdSubQuery & {
entity: "wechatPublicAutoReply";
}) | any;
};

Some files were not shown because too many files have changed in this diff Show More