@bdlite/domains 1.1.31 → 1.1.33
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/system-config/index.js +17 -16
- package/es/user/channel.js +7 -0
- package/es/user/constants.js +11 -0
- package/es/user/images.js +3 -0
- package/es/user/index.js +118 -0
- package/package.json +2 -2
|
@@ -18,7 +18,6 @@ const { getData, subscribe, publish } = createObservableKit({
|
|
|
18
18
|
useragreement: DEFAULT_USERAGREEMENT,
|
|
19
19
|
app: DEEFAULT_APP,
|
|
20
20
|
}, null, { channelName: CHANNEL_NAME })
|
|
21
|
-
const _systemConfig = getData()
|
|
22
21
|
|
|
23
22
|
|
|
24
23
|
/**
|
|
@@ -38,17 +37,17 @@ export function getSysConfig() {
|
|
|
38
37
|
app = DEEFAULT_APP
|
|
39
38
|
} = storage.getObject(CHANNEL_NAME)
|
|
40
39
|
|
|
41
|
-
|
|
40
|
+
return {
|
|
41
|
+
...getData(),
|
|
42
42
|
contactorId, contractName,
|
|
43
43
|
favicon, logo, loginLogo,
|
|
44
44
|
title: title.trim(),
|
|
45
45
|
copyright: copyright.trim(),
|
|
46
46
|
useragreement: useragreement.trim(),
|
|
47
47
|
app
|
|
48
|
-
}
|
|
49
|
-
return { ..._systemConfig }
|
|
48
|
+
}
|
|
50
49
|
} catch (e) {
|
|
51
|
-
return { ...
|
|
50
|
+
return { ...getData() }
|
|
52
51
|
}
|
|
53
52
|
}
|
|
54
53
|
|
|
@@ -60,14 +59,15 @@ export function storeSysConfig(systemConfig) {
|
|
|
60
59
|
if (!systemConfig) return
|
|
61
60
|
const { mainLogo, copyright, eula, preload = {}, contactor, contactorInfo = {} } = systemConfig
|
|
62
61
|
const { title, favicon, loginLogo, appRunning } = preload
|
|
63
|
-
|
|
64
|
-
|
|
62
|
+
const nextConfig = {
|
|
63
|
+
...getData(),
|
|
64
|
+
contactorId: contactor, contractName: contactorInfo?.display || '',
|
|
65
65
|
favicon, loginLogo, logo: mainLogo,
|
|
66
66
|
title: title?.trim(), copyright: copyright?.trim(), useragreement: eula?.trim(),
|
|
67
67
|
app: appRunning
|
|
68
|
-
}
|
|
69
|
-
storage.appendObject(CHANNEL_NAME,
|
|
70
|
-
publish(
|
|
68
|
+
}
|
|
69
|
+
storage.appendObject(CHANNEL_NAME, nextConfig)
|
|
70
|
+
publish(nextConfig)
|
|
71
71
|
}
|
|
72
72
|
|
|
73
73
|
/**
|
|
@@ -77,12 +77,13 @@ export function storeSysConfig(systemConfig) {
|
|
|
77
77
|
export function storePreload(config) {
|
|
78
78
|
if (!config) return
|
|
79
79
|
const { title, favicon, loginLogo, copyright, eula, appRunning } = config
|
|
80
|
-
|
|
80
|
+
const nextConfig = {
|
|
81
|
+
...getData(),
|
|
81
82
|
favicon, loginLogo, app: appRunning,
|
|
82
83
|
title: title?.trim(), copyright: copyright?.trim(), useragreement: eula?.trim()
|
|
83
|
-
}
|
|
84
|
-
storage.appendObject(CHANNEL_NAME,
|
|
85
|
-
publish(
|
|
84
|
+
}
|
|
85
|
+
storage.appendObject(CHANNEL_NAME, nextConfig)
|
|
86
|
+
publish(nextConfig)
|
|
86
87
|
}
|
|
87
88
|
|
|
88
89
|
/**
|
|
@@ -92,11 +93,11 @@ export function storePreload(config) {
|
|
|
92
93
|
export function publishPreload(config) {
|
|
93
94
|
if (!config) return
|
|
94
95
|
const { title, favicon, loginLogo, copyright, eula } = config
|
|
95
|
-
|
|
96
|
+
publish({
|
|
97
|
+
...getData(),
|
|
96
98
|
favicon, loginLogo,
|
|
97
99
|
title: title?.trim(), copyright: copyright?.trim(), useragreement: eula?.trim()
|
|
98
100
|
})
|
|
99
|
-
publish(_systemConfig)
|
|
100
101
|
}
|
|
101
102
|
|
|
102
103
|
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { createSubChannelKit } from '@bdlite/observable/es/create-observable-kit'
|
|
2
|
+
import { CHANNEL_NAME } from './constants'
|
|
3
|
+
|
|
4
|
+
// 登录用户信息
|
|
5
|
+
const { subscribe } = createSubChannelKit({ channelName: CHANNEL_NAME }, { relay: 1 })
|
|
6
|
+
|
|
7
|
+
export const subscribeUser = subscribe
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { avatar_boy, avatar_girl } from './images'
|
|
2
|
+
|
|
3
|
+
export const CHANNEL_NAME = 'user'
|
|
4
|
+
|
|
5
|
+
export const PLACEHOLDER = '---'
|
|
6
|
+
|
|
7
|
+
export const DEFAULT_GENDER = '1'
|
|
8
|
+
|
|
9
|
+
export const AVATAR_BOY_IMG = avatar_boy
|
|
10
|
+
export const AVATAR_GIRL_IMG = avatar_girl
|
|
11
|
+
export const DEFAULT_AVATAR_PATH = AVATAR_BOY_IMG
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export const avatar_boy = '';
|
|
2
|
+
|
|
3
|
+
export const avatar_girl = '';
|
package/es/user/index.js
ADDED
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
|
|
2
|
+
import { createObservableKit } from '@bdlite/observable/es/create-observable-kit'
|
|
3
|
+
|
|
4
|
+
import { isUndefined } from '@bdlite/strategy'
|
|
5
|
+
import { checkImgExists } from '@bdlite/helpers/es/check-img-exists'
|
|
6
|
+
|
|
7
|
+
import { CHANNEL_NAME, PLACEHOLDER, DEFAULT_GENDER, AVATAR_BOY_IMG, AVATAR_GIRL_IMG, DEFAULT_AVATAR_PATH } from './constants'
|
|
8
|
+
|
|
9
|
+
// 登录用户信息
|
|
10
|
+
const { getData, subscribe, publish } = createObservableKit({ id: null, name: '', account: '', email: '' }, null, { channelName: CHANNEL_NAME })
|
|
11
|
+
const avatarOb = createObservableKit({ avatar: DEFAULT_AVATAR_PATH, gender: DEFAULT_GENDER })
|
|
12
|
+
const userShowOb = createObservableKit({ showName: PLACEHOLDER, showEmail: PLACEHOLDER })
|
|
13
|
+
|
|
14
|
+
const _userInfo = getData()
|
|
15
|
+
|
|
16
|
+
export const subscribeUser = subscribe
|
|
17
|
+
export const subscribeUserShow = userShowOb.subscribe
|
|
18
|
+
|
|
19
|
+
export const subscribeAvatar = avatarOb.subscribe
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* @function showRules
|
|
23
|
+
* @param {?string} defaultName
|
|
24
|
+
* @param {?string} defaultEmail
|
|
25
|
+
* @returns {object} { showName, showEmail }
|
|
26
|
+
*/
|
|
27
|
+
export const getShowRules = userInfo => (defaultName = PLACEHOLDER, defaultEmail = PLACEHOLDER) => {
|
|
28
|
+
const { email, account, name, mobile, username } = userInfo
|
|
29
|
+
const showEmail = email || defaultEmail
|
|
30
|
+
const showName = name || mobile || username || account || defaultName
|
|
31
|
+
return { showName, showEmail }
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
async function getAvatar(expandInfo = []) {
|
|
35
|
+
let avatar
|
|
36
|
+
let gender = DEFAULT_GENDER
|
|
37
|
+
|
|
38
|
+
expandInfo.forEach(item => {
|
|
39
|
+
const { infoItem, infoValue } = item || {}
|
|
40
|
+
|
|
41
|
+
if (infoItem === 'avatar') {
|
|
42
|
+
avatar = infoValue
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
if (infoItem === 'gender') {
|
|
46
|
+
gender = isUndefined(infoValue) ? DEFAULT_GENDER : infoValue
|
|
47
|
+
}
|
|
48
|
+
})
|
|
49
|
+
|
|
50
|
+
try {
|
|
51
|
+
await checkImgExists(avatar)
|
|
52
|
+
} catch (e) {
|
|
53
|
+
avatar = gender === '0' ? AVATAR_GIRL_IMG : AVATAR_BOY_IMG
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return { avatar, gender }
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* @function storeUser
|
|
61
|
+
* @param {?object} user
|
|
62
|
+
*/
|
|
63
|
+
export async function storeUser(user) {
|
|
64
|
+
if (!user) return
|
|
65
|
+
|
|
66
|
+
const {
|
|
67
|
+
username = '', mobile = '', name = '', account = '', email = '',
|
|
68
|
+
expandInfo, ...rest
|
|
69
|
+
} = user
|
|
70
|
+
|
|
71
|
+
Object.assign(_userInfo, { username, mobile, name, account, email, expandInfo, ...rest })
|
|
72
|
+
publish({ ..._userInfo })
|
|
73
|
+
|
|
74
|
+
const showData = getShowRules(_userInfo)()
|
|
75
|
+
userShowOb.publish(showData)
|
|
76
|
+
|
|
77
|
+
if (expandInfo) {
|
|
78
|
+
const avatarData = await getAvatar(expandInfo)
|
|
79
|
+
avatarOb.publish(avatarData)
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
export function publishUser(user) {
|
|
84
|
+
const { username = '', mobile = '', name = '', account = '', email = '', ...rest } = user
|
|
85
|
+
Object.assign(_userInfo, { username, mobile, name, account, email, ...rest })
|
|
86
|
+
publish({ ..._userInfo })
|
|
87
|
+
|
|
88
|
+
const showData = getShowRules(_userInfo)()
|
|
89
|
+
userShowOb.publish(showData)
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export async function publishAvatar(user) {
|
|
93
|
+
const { expandInfo } = user
|
|
94
|
+
|
|
95
|
+
if (!expandInfo) return
|
|
96
|
+
|
|
97
|
+
Object.assign(_userInfo, { expandInfo })
|
|
98
|
+
publish({ ..._userInfo })
|
|
99
|
+
|
|
100
|
+
const avatarData = await getAvatar(expandInfo)
|
|
101
|
+
avatarOb.publish(avatarData)
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
/**
|
|
105
|
+
* @function getUser
|
|
106
|
+
* @returns {object} userInfo
|
|
107
|
+
*/
|
|
108
|
+
export function getUser() {
|
|
109
|
+
return { ..._userInfo }
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
/**
|
|
113
|
+
* @function getUserId
|
|
114
|
+
* @returns {?number} id
|
|
115
|
+
*/
|
|
116
|
+
export function getUserId() {
|
|
117
|
+
return _userInfo.id
|
|
118
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bdlite/domains",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.33",
|
|
4
4
|
"description": "A domains entity collection library driven by @bdlite/observable",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"DDD",
|
|
@@ -25,7 +25,7 @@
|
|
|
25
25
|
"@bdlite/strategy": "^1.1.25"
|
|
26
26
|
},
|
|
27
27
|
"dependencies": {
|
|
28
|
-
"@bdlite/helpers": "^1.1.
|
|
28
|
+
"@bdlite/helpers": "^1.1.27",
|
|
29
29
|
"@bdlite/observable": "^1.1.25",
|
|
30
30
|
"@bdlite/strategy": "^1.1.25"
|
|
31
31
|
},
|