@arcblock/ux 1.16.16 → 1.16.20
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/lib/Blocklet/index.js +1 -1
- package/lib/NFTDisplay/index.js +45 -14
- package/package.json +4 -4
- package/src/Blocklet/index.js +34 -8
- package/src/NFTDisplay/index.js +36 -9
package/lib/Blocklet/index.js
CHANGED
|
@@ -44,7 +44,7 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
|
|
|
44
44
|
const Div = _styledComponents.default.div.withConfig({
|
|
45
45
|
displayName: "Blocklet__Div",
|
|
46
46
|
componentId: "sc-3dga5l-0"
|
|
47
|
-
})(["&.arcblock-blocklet{border:1px solid #f2f2f2;padding:0 16px;border-radius:12px;background
|
|
47
|
+
})(["&.arcblock-blocklet{border:1px solid #f2f2f2;padding:0 16px;border-radius:12px;background:", ";overflow:hidden;&:hover{filter:drop-shadow(0px 4px 12px rgba(92,92,92,0.04));}}.arcblock-blocklet__content{padding:16px 0;}.arcblock-blocklet__content--main{display:flex;align-items:center;cursor:pointer;}.arcblock-blocklet__content--body{overflow:hidden;flex:1;display:flex;align-items:flex-start;}.arcblock-blocklet__addons{padding:16px 0;border-top:1px solid #f2f2f2;}.arcblock-blocklet__cover{width:100px;height:100px;margin-right:16px;overflow:hidden;border-radius:12px;}.arcblock-blocklet__info{flex:1;overflow:hidden;.arcblock-blocklet__button{margin-top:16px;display:inline-block;}}.arcblock-blocklet__button{& > *:not(.Mui-disabled){position:relative;z-index:1;&::before{content:'';border-radius:100vw;position:absolute;height:100%;width:100%;left:0;top:0;transition:opacity 0.3s;}&:hover::before{opacity:0;}&::after{content:'';position:absolute;height:100%;width:100%;background-color:", ";transform:scale(0.1);opacity:0;z-index:-1;border-radius:100vw;transition:transform 0.3s,opacity 0.3s,background-color 0.3s;}&:hover::after{opacity:1;transform-origin:center;transform:scale(1);}}& > *:not(.Mui-disabled){background-color:rgba(79,106,246,0.06);color:", ";}&:hover > *:not(.Mui-disabled){color:", ";}}.arcblock-blocklet__title{margin:0;font-size:18px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.arcblock-blocklet__describe{margin:2px 0 0;color:#999;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}.arcblock-blocklet__addons{display:flex;justify-content:space-between;color:#999;font-size:14px;position:relative;}.arcblock-blocklet__addons--item{white-space:nowrap;}&.arcblock-blocklet--size-md{&:hover{position:relative;}.arcblock-blocklet__title{margin-bottom:3px;}.arcblock-blocklet__describe{white-space:normal;height:2.86em;}.arcblock-blocklet__button{margin-top:5px;}}&.arcblock-blocklet--size-sm,&.arcblock-blocklet--size-xs{.arcblock-blocklet__content{padding:12px 0;}.arcblock-blocklet__cover{width:48px;height:48px;border-radius:6px;}.arcblock-blocklet__addons{padding:8px 0;.arcblock-blocklet__addons--item{font-size:12px;}}}&.arcblock-blocklet--size-xs{.arcblock-blocklet__addons{display:none !important;}}"], props => props.theme.palette.common.white, props => props.theme.palette.primary.main, props => props.theme.palette.primary.main, props => props.theme.palette.common.white);
|
|
48
48
|
|
|
49
49
|
function BlockletIcon(_ref) {
|
|
50
50
|
let {
|
package/lib/NFTDisplay/index.js
CHANGED
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
+
exports.getNFTData = getNFTData;
|
|
6
7
|
exports.default = void 0;
|
|
7
8
|
|
|
8
9
|
var _react = _interopRequireWildcard(require("react"));
|
|
@@ -50,17 +51,27 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
|
|
|
50
51
|
|
|
51
52
|
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
|
52
53
|
|
|
54
|
+
/**
|
|
55
|
+
* 从 assetState 中获取 nft data, 兼容新旧两种类型的数据结构, 建议将该方法的返回值传入 NFTDisplay 组件的 data prop
|
|
56
|
+
* - 旧: assetState.data.value (.credentialSubject.display)
|
|
57
|
+
* - 新: assetState.display
|
|
58
|
+
*/
|
|
59
|
+
function getNFTData(assetState) {
|
|
60
|
+
var _assetState$data;
|
|
61
|
+
|
|
62
|
+
return (assetState === null || assetState === void 0 ? void 0 : assetState.display) || (assetState === null || assetState === void 0 ? void 0 : (_assetState$data = assetState.data) === null || _assetState$data === void 0 ? void 0 : _assetState$data.value);
|
|
63
|
+
}
|
|
64
|
+
|
|
53
65
|
function fromBase64(v) {
|
|
54
66
|
if (typeof v !== 'string') {
|
|
55
67
|
throw new Error('fromBase64 requires input to be a string');
|
|
56
68
|
}
|
|
57
69
|
|
|
58
70
|
return Buffer.from(_base64Url.default.unescape(v), 'base64');
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
}; // 仅针对非 url type 的情况
|
|
71
|
+
} // const isVC = type => {
|
|
72
|
+
// return String(type).includes('VerifiableCredential');
|
|
73
|
+
// };
|
|
74
|
+
// 仅针对非 url type 的情况
|
|
64
75
|
|
|
65
76
|
|
|
66
77
|
const getSvgEmbedder = preferredSvgEmbedder => {
|
|
@@ -111,10 +122,10 @@ function NFTDisplay(_ref) {
|
|
|
111
122
|
}
|
|
112
123
|
|
|
113
124
|
const {
|
|
114
|
-
vcId
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
const display = (0, _get.default)(parsed.current, 'credentialSubject.display');
|
|
125
|
+
vcId
|
|
126
|
+
} = parsed.current; // 需要兼容新旧两种类型的数据结构, nft data 有 credentialSubject 属性, 说明是旧 nft data, 否则是新 nft data
|
|
127
|
+
|
|
128
|
+
const display = parsed.current.credentialSubject ? (0, _get.default)(parsed.current, 'credentialSubject.display') : parsed.current;
|
|
118
129
|
const {
|
|
119
130
|
content,
|
|
120
131
|
type
|
|
@@ -142,10 +153,9 @@ function NFTDisplay(_ref) {
|
|
|
142
153
|
if (!state.loading && minimumLoadingReady || state.error) {
|
|
143
154
|
onCompleted();
|
|
144
155
|
}
|
|
145
|
-
}, [state, minimumLoadingReady]);
|
|
146
|
-
|
|
156
|
+
}, [state, minimumLoadingReady]);
|
|
147
157
|
|
|
148
|
-
if (state.error
|
|
158
|
+
if (state.error) {
|
|
149
159
|
throw new Error('Failed to render NFT Display.');
|
|
150
160
|
}
|
|
151
161
|
|
|
@@ -155,8 +165,15 @@ function NFTDisplay(_ref) {
|
|
|
155
165
|
case 'url':
|
|
156
166
|
{
|
|
157
167
|
const urlObj = new URL(content);
|
|
158
|
-
|
|
159
|
-
urlObj.searchParams.
|
|
168
|
+
|
|
169
|
+
if (!urlObj.searchParams.has('assetId')) {
|
|
170
|
+
urlObj.searchParams.append('assetId', address);
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
if (!urlObj.searchParams.has('vcId')) {
|
|
174
|
+
urlObj.searchParams.append('vcId', vcId);
|
|
175
|
+
}
|
|
176
|
+
|
|
160
177
|
const url = urlObj.href;
|
|
161
178
|
return /*#__PURE__*/_react.default.createElement("img", {
|
|
162
179
|
src: url,
|
|
@@ -170,6 +187,20 @@ function NFTDisplay(_ref) {
|
|
|
170
187
|
});
|
|
171
188
|
}
|
|
172
189
|
|
|
190
|
+
case 'uri':
|
|
191
|
+
{
|
|
192
|
+
return /*#__PURE__*/_react.default.createElement("img", {
|
|
193
|
+
src: content,
|
|
194
|
+
onError: () => setState(_objectSpread(_objectSpread({}, state), {}, {
|
|
195
|
+
error: true
|
|
196
|
+
})),
|
|
197
|
+
onLoad: () => setState(_objectSpread(_objectSpread({}, state), {}, {
|
|
198
|
+
loading: false
|
|
199
|
+
})),
|
|
200
|
+
alt: "NFT Display"
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
|
|
173
204
|
case 'svg_gzipped':
|
|
174
205
|
{
|
|
175
206
|
const buffer = _pako.default.ungzip(fromBase64(content), {});
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@arcblock/ux",
|
|
3
|
-
"version": "1.16.
|
|
3
|
+
"version": "1.16.20",
|
|
4
4
|
"description": "Common used react components for arcblock products",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"react",
|
|
@@ -53,10 +53,10 @@
|
|
|
53
53
|
"react": ">=16.12.0",
|
|
54
54
|
"react-ga": "^2.7.0"
|
|
55
55
|
},
|
|
56
|
-
"gitHead": "
|
|
56
|
+
"gitHead": "d24d15a8cb22c578484e9017b85c0cb2debd1f43",
|
|
57
57
|
"dependencies": {
|
|
58
|
-
"@arcblock/icons": "^1.16.
|
|
59
|
-
"@arcblock/react-hooks": "^1.16.
|
|
58
|
+
"@arcblock/icons": "^1.16.20",
|
|
59
|
+
"@arcblock/react-hooks": "^1.16.20",
|
|
60
60
|
"@babel/plugin-syntax-dynamic-import": "^7.8.3",
|
|
61
61
|
"@material-ui/core": "^4.12.3",
|
|
62
62
|
"@material-ui/icons": "4.11.2",
|
package/src/Blocklet/index.js
CHANGED
|
@@ -17,7 +17,7 @@ const Div = styled.div`
|
|
|
17
17
|
border: 1px solid #f2f2f2;
|
|
18
18
|
padding: 0 16px;
|
|
19
19
|
border-radius: 12px;
|
|
20
|
-
background:
|
|
20
|
+
background: ${props => props.theme.palette.common.white};
|
|
21
21
|
overflow: hidden;
|
|
22
22
|
&:hover {
|
|
23
23
|
filter: drop-shadow(0px 4px 12px rgba(92, 92, 92, 0.04));
|
|
@@ -58,24 +58,50 @@ const Div = styled.div`
|
|
|
58
58
|
display: inline-block;
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
|
+
// 这里想覆盖 mui-button 的样式 做成 blocklet-button 的专有样式
|
|
61
62
|
.arcblock-blocklet__button {
|
|
62
|
-
& >
|
|
63
|
+
& > *:not(.Mui-disabled) {
|
|
63
64
|
position: relative;
|
|
65
|
+
z-index: 1;
|
|
64
66
|
&::before {
|
|
67
|
+
content: '';
|
|
68
|
+
border-radius: 100vw;
|
|
69
|
+
position: absolute;
|
|
70
|
+
height: 100%;
|
|
71
|
+
width: 100%;
|
|
72
|
+
left: 0;
|
|
73
|
+
top: 0;
|
|
74
|
+
transition: opacity 0.3s;
|
|
75
|
+
}
|
|
76
|
+
&:hover::before {
|
|
77
|
+
opacity: 0;
|
|
78
|
+
}
|
|
79
|
+
&::after {
|
|
65
80
|
content: '';
|
|
66
81
|
position: absolute;
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
82
|
+
height: 100%;
|
|
83
|
+
width: 100%;
|
|
84
|
+
background-color: ${props => props.theme.palette.primary.main};
|
|
85
|
+
transform: scale(0.1);
|
|
86
|
+
opacity: 0;
|
|
87
|
+
z-index: -1;
|
|
88
|
+
border-radius: 100vw;
|
|
89
|
+
transition: transform 0.3s, opacity 0.3s, background-color 0.3s;
|
|
90
|
+
}
|
|
91
|
+
&:hover::after {
|
|
92
|
+
opacity: 1;
|
|
93
|
+
transform-origin: center;
|
|
94
|
+
transform: scale(1);
|
|
73
95
|
}
|
|
74
96
|
}
|
|
97
|
+
|
|
75
98
|
& > *:not(.Mui-disabled) {
|
|
76
99
|
background-color: rgba(79, 106, 246, 0.06);
|
|
77
100
|
color: ${props => props.theme.palette.primary.main};
|
|
78
101
|
}
|
|
102
|
+
&:hover > *:not(.Mui-disabled) {
|
|
103
|
+
color: ${props => props.theme.palette.common.white};
|
|
104
|
+
}
|
|
79
105
|
}
|
|
80
106
|
.arcblock-blocklet__title {
|
|
81
107
|
margin: 0;
|
package/src/NFTDisplay/index.js
CHANGED
|
@@ -12,6 +12,15 @@ import InlineSvgEmbedder from './svg-embedder/inline-svg';
|
|
|
12
12
|
import DefaultLoading from './loading';
|
|
13
13
|
import DefaultBrokenImage from './broken';
|
|
14
14
|
|
|
15
|
+
/**
|
|
16
|
+
* 从 assetState 中获取 nft data, 兼容新旧两种类型的数据结构, 建议将该方法的返回值传入 NFTDisplay 组件的 data prop
|
|
17
|
+
* - 旧: assetState.data.value (.credentialSubject.display)
|
|
18
|
+
* - 新: assetState.display
|
|
19
|
+
*/
|
|
20
|
+
export function getNFTData(assetState) {
|
|
21
|
+
return assetState?.display || assetState?.data?.value;
|
|
22
|
+
}
|
|
23
|
+
|
|
15
24
|
function fromBase64(v) {
|
|
16
25
|
if (typeof v !== 'string') {
|
|
17
26
|
throw new Error('fromBase64 requires input to be a string');
|
|
@@ -19,9 +28,9 @@ function fromBase64(v) {
|
|
|
19
28
|
return Buffer.from(base64.unescape(v), 'base64');
|
|
20
29
|
}
|
|
21
30
|
|
|
22
|
-
const isVC = type => {
|
|
23
|
-
|
|
24
|
-
};
|
|
31
|
+
// const isVC = type => {
|
|
32
|
+
// return String(type).includes('VerifiableCredential');
|
|
33
|
+
// };
|
|
25
34
|
|
|
26
35
|
// 仅针对非 url type 的情况
|
|
27
36
|
const getSvgEmbedder = preferredSvgEmbedder => {
|
|
@@ -65,8 +74,11 @@ function NFTDisplay({
|
|
|
65
74
|
parsed.current = JSON.parse(data);
|
|
66
75
|
// console.log('[debug] parse data')
|
|
67
76
|
}
|
|
68
|
-
const { vcId
|
|
69
|
-
|
|
77
|
+
const { vcId } = parsed.current;
|
|
78
|
+
// 需要兼容新旧两种类型的数据结构, nft data 有 credentialSubject 属性, 说明是旧 nft data, 否则是新 nft data
|
|
79
|
+
const display = parsed.current.credentialSubject
|
|
80
|
+
? get(parsed.current, 'credentialSubject.display')
|
|
81
|
+
: parsed.current;
|
|
70
82
|
const { content, type } = display;
|
|
71
83
|
const isUrlType = type === 'url';
|
|
72
84
|
|
|
@@ -90,8 +102,7 @@ function NFTDisplay({
|
|
|
90
102
|
}
|
|
91
103
|
}, [state, minimumLoadingReady]);
|
|
92
104
|
|
|
93
|
-
|
|
94
|
-
if (state.error || !isVC(assetType)) {
|
|
105
|
+
if (state.error) {
|
|
95
106
|
throw new Error('Failed to render NFT Display.');
|
|
96
107
|
}
|
|
97
108
|
|
|
@@ -100,8 +111,14 @@ function NFTDisplay({
|
|
|
100
111
|
switch (type) {
|
|
101
112
|
case 'url': {
|
|
102
113
|
const urlObj = new URL(content);
|
|
103
|
-
urlObj.searchParams.
|
|
104
|
-
|
|
114
|
+
if (!urlObj.searchParams.has('assetId')) {
|
|
115
|
+
urlObj.searchParams.append('assetId', address);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
if (!urlObj.searchParams.has('vcId')) {
|
|
119
|
+
urlObj.searchParams.append('vcId', vcId);
|
|
120
|
+
}
|
|
121
|
+
|
|
105
122
|
const url = urlObj.href;
|
|
106
123
|
return (
|
|
107
124
|
<img
|
|
@@ -112,6 +129,16 @@ function NFTDisplay({
|
|
|
112
129
|
/>
|
|
113
130
|
);
|
|
114
131
|
}
|
|
132
|
+
case 'uri': {
|
|
133
|
+
return (
|
|
134
|
+
<img
|
|
135
|
+
src={content}
|
|
136
|
+
onError={() => setState({ ...state, error: true })}
|
|
137
|
+
onLoad={() => setState({ ...state, loading: false })}
|
|
138
|
+
alt="NFT Display"
|
|
139
|
+
/>
|
|
140
|
+
);
|
|
141
|
+
}
|
|
115
142
|
case 'svg_gzipped': {
|
|
116
143
|
const buffer = pako.ungzip(fromBase64(content), {});
|
|
117
144
|
const svg = Buffer.from(buffer).toString('utf8');
|