110 lines
4.4 KiB
JavaScript
110 lines
4.4 KiB
JavaScript
export default OakComponent({
|
||
isList: false,
|
||
formData({ data, features }) {
|
||
const { sessionId } = this.props;
|
||
if (sessionId) {
|
||
this.getSession(sessionId);
|
||
}
|
||
return {};
|
||
},
|
||
lifetimes: {
|
||
ready() { },
|
||
},
|
||
listeners: {
|
||
sessionId(prev, next) {
|
||
if (prev.sessionId !== next.sessionId) {
|
||
this.getSession(next.sessionId);
|
||
}
|
||
},
|
||
},
|
||
properties: {
|
||
sessionId: '',
|
||
isEntity: false,
|
||
entityDisplay: (data) => [], // user端,指示如何显示entity对象名称
|
||
entityProjection: null, // user端,指示需要取哪些entity的属性来显示entityDisplay
|
||
},
|
||
methods: {
|
||
getSession(sessionId) {
|
||
const { entityProjection } = this.props;
|
||
const [session] = this.features.cache.get('session', {
|
||
data: {
|
||
id: 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'],
|
||
},
|
||
},
|
||
},
|
||
},
|
||
...entityProjection,
|
||
},
|
||
filter: {
|
||
id: sessionId
|
||
}
|
||
});
|
||
this.setState({ session });
|
||
},
|
||
getAvatarUrl() {
|
||
const { userUrl, entity } = this.state;
|
||
const { isEntity } = this.props;
|
||
const defaultUrl = '';
|
||
if (isEntity) {
|
||
return userUrl || defaultUrl;
|
||
}
|
||
else {
|
||
return defaultUrl;
|
||
}
|
||
},
|
||
getName() {
|
||
const { session, entity } = this.state;
|
||
const { isEntity, entityDisplay } = this.props;
|
||
if (isEntity) {
|
||
const userName = session?.user?.name;
|
||
const userNickname = session?.user?.name || session?.user?.nickname;
|
||
const userMobile = session?.user?.mobile$user &&
|
||
session?.user?.mobile$user[0]?.mobile;
|
||
if (userName) {
|
||
return userName;
|
||
}
|
||
if (userMobile) {
|
||
return '用户' + userMobile;
|
||
}
|
||
return userNickname;
|
||
}
|
||
else {
|
||
if (entityDisplay && session) {
|
||
const sessions = entityDisplay([session]);
|
||
return sessions[0]?.name;
|
||
}
|
||
return '未知';
|
||
}
|
||
},
|
||
},
|
||
});
|