@lambo-design/shared 1.0.0-beta.237 → 1.0.0-beta.239

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.
Files changed (182) hide show
  1. package/config/config.js +51 -51
  2. package/config/env.js +4 -4
  3. package/config/index.js +7 -7
  4. package/config/themes/atrovirens/atrovirens.css +575 -575
  5. package/config/themes/atrovirens/atrovirens.less +667 -667
  6. package/config/themes/atrovirens/var.less +674 -674
  7. package/config/themes/blue/blue.css +575 -575
  8. package/config/themes/blue/blue.less +669 -669
  9. package/config/themes/blue/var.less +677 -677
  10. package/config/themes/blue-white/blue-white.css +575 -575
  11. package/config/themes/blue-white/blue-white.less +669 -669
  12. package/config/themes/blue-white/var.less +676 -676
  13. package/config/themes/blue-white-tight/blue-white-tight.css +576 -576
  14. package/config/themes/blue-white-tight/blue-white-tight.less +672 -672
  15. package/config/themes/blue-white-tight/var.less +677 -677
  16. package/config/themes/danqing/danqing.css +576 -575
  17. package/config/themes/danqing/danqing.css.map +1 -1
  18. package/config/themes/danqing/danqing.less +668 -668
  19. package/config/themes/danqing/danqing.wxss +572 -572
  20. package/config/themes/danqing/var.less +679 -679
  21. package/config/themes/deep/deep.css +575 -575
  22. package/config/themes/deep/deep.less +669 -669
  23. package/config/themes/deep/var.less +677 -677
  24. package/config/themes/default/default.css +575 -575
  25. package/config/themes/default/default.less +671 -671
  26. package/config/themes/default/var.less +677 -677
  27. package/config/themes/eap/eap.css +575 -575
  28. package/config/themes/eap/eap.less +671 -671
  29. package/config/themes/eap/var.less +677 -677
  30. package/config/themes/gold/gold.css +575 -575
  31. package/config/themes/gold/gold.less +671 -671
  32. package/config/themes/gold/var.less +677 -677
  33. package/config/themes/index.js +28 -28
  34. package/config/themes/lime/lime.css +575 -575
  35. package/config/themes/lime/lime.less +671 -671
  36. package/config/themes/lime/var.less +678 -678
  37. package/config/themes/orange/orange.css +575 -575
  38. package/config/themes/orange/orange.less +671 -671
  39. package/config/themes/orange/var.less +678 -678
  40. package/config/themes/red/red.css +575 -575
  41. package/config/themes/red/red.less +671 -671
  42. package/config/themes/red/var.less +677 -677
  43. package/config/themes/theme-atrovirens.js +558 -558
  44. package/config/themes/theme-blue.js +558 -558
  45. package/config/themes/theme-bw.js +558 -558
  46. package/config/themes/theme-bwt.js +559 -559
  47. package/config/themes/theme-danqing.js +558 -558
  48. package/config/themes/theme-deep.js +558 -558
  49. package/config/themes/theme-default.js +558 -558
  50. package/config/themes/theme-eap.js +558 -558
  51. package/config/themes/theme-gold.js +558 -558
  52. package/config/themes/theme-lime.js +558 -558
  53. package/config/themes/theme-orange.js +559 -559
  54. package/config/themes/theme-red.js +558 -558
  55. package/config/themes/theme-white.js +557 -557
  56. package/config/themes/white/var.less +675 -675
  57. package/config/themes/white/white.css +575 -575
  58. package/config/themes/white/white.less +668 -668
  59. package/directives/index.js +23 -23
  60. package/directives/module/draggable.js +56 -56
  61. package/directives/module/permission.js +49 -49
  62. package/directives/module/print.js +1 -1
  63. package/directives/module/vue-print-nb/README.md +63 -63
  64. package/directives/module/vue-print-nb/print.js +94 -94
  65. package/directives/module/vue-print-nb/printarea.js +532 -532
  66. package/index.js +10 -10
  67. package/nstyles/common.less +197 -197
  68. package/nstyles/components/404.less +46 -46
  69. package/nstyles/components/button.less +34 -34
  70. package/nstyles/components/date-picker.less +37 -37
  71. package/nstyles/components/drawer.less +20 -20
  72. package/nstyles/components/dropdown.less +18 -18
  73. package/nstyles/components/excel-flow.less +72 -72
  74. package/nstyles/components/form.less +313 -303
  75. package/nstyles/components/index.less +23 -23
  76. package/nstyles/components/layout/collect.less +10 -10
  77. package/nstyles/components/layout/detail-view.less +107 -107
  78. package/nstyles/components/layout/full-screen.less +7 -7
  79. package/nstyles/components/layout/index.less +7 -7
  80. package/nstyles/components/layout/other-menu.less +142 -142
  81. package/nstyles/components/layout/page-view.less +101 -101
  82. package/nstyles/components/layout/sider-trigger.less +41 -41
  83. package/nstyles/components/layout/tags-nav.less +113 -113
  84. package/nstyles/components/modal.less +85 -85
  85. package/nstyles/components/n-button.less +131 -131
  86. package/nstyles/components/n-image-preview.less +131 -131
  87. package/nstyles/components/n-model/index.less +19 -19
  88. package/nstyles/components/n-model/report-index.less +43 -43
  89. package/nstyles/components/n-panel.less +40 -40
  90. package/nstyles/components/n-picker.less +37 -37
  91. package/nstyles/components/n-sign.less +17 -17
  92. package/nstyles/components/n-tooltip.less +10 -10
  93. package/nstyles/components/panel.less +31 -31
  94. package/nstyles/components/select.less +3 -3
  95. package/nstyles/components/sign.less +27 -27
  96. package/nstyles/components/table.less +315 -315
  97. package/nstyles/components/tree.less +158 -158
  98. package/nstyles/components/upload.less +164 -164
  99. package/nstyles/index.less +5 -5
  100. package/nstyles/reset.less +65 -65
  101. package/nstyles/third/ag.less +174 -174
  102. package/nstyles/third/index.less +11 -11
  103. package/nstyles/third/view-design.less +366 -366
  104. package/nstyles/variables/base.less +143 -143
  105. package/nstyles/variables/index.less +4 -4
  106. package/nstyles/variables/theme/default/button.less +7 -7
  107. package/nstyles/variables/theme/default/common.less +57 -57
  108. package/nstyles/variables/theme/default/index.less +7 -7
  109. package/nstyles/variables/theme/default/layout.less +40 -40
  110. package/nstyles/variables/theme/default/table.less +37 -37
  111. package/nstyles/variables/theme/default/tag.less +3 -3
  112. package/nstyles/variables/theme/default/upload.less +3 -3
  113. package/nstyles/variables/theme/index.less +13 -13
  114. package/nstyles/variables/theme/small/button.less +7 -7
  115. package/nstyles/variables/theme/small/common.less +39 -39
  116. package/nstyles/variables/theme/small/index.less +5 -5
  117. package/nstyles/variables/theme/small/layout.less +21 -21
  118. package/nstyles/variables/theme/small/table.less +17 -17
  119. package/nstyles/variables/theme/small/tag.less +3 -3
  120. package/package.json +1 -1
  121. package/plugin/index.js +12 -12
  122. package/plugin/module/date-format.js +30 -30
  123. package/plugin/module/loading.js +26 -26
  124. package/plugin/module/warn-handler.js +11 -11
  125. package/styles/variables.less +21 -21
  126. package/utils/ajax/cacheconf.js +19 -19
  127. package/utils/ajax/content-type.js +30 -30
  128. package/utils/ajax/index.js +12 -12
  129. package/utils/ajax/interceptors.js +97 -97
  130. package/utils/assist.js +147 -147
  131. package/utils/base64.js +126 -126
  132. package/utils/blob.js +47 -47
  133. package/utils/bus.js +3 -3
  134. package/utils/crypto/index.js +48 -48
  135. package/utils/crypto/md5.js +152 -152
  136. package/utils/crypto/sm3.js +235 -235
  137. package/utils/date.js +381 -381
  138. package/utils/dict/built-in-dict.js +20 -20
  139. package/utils/dict/index.js +167 -167
  140. package/utils/dom.js +38 -38
  141. package/utils/event.js +72 -72
  142. package/utils/excel.js +655 -655
  143. package/utils/file.js +19 -19
  144. package/utils/form/validate.js +29 -29
  145. package/utils/half-year.js +68 -68
  146. package/utils/index.js +41 -41
  147. package/utils/json.js +29 -29
  148. package/utils/lodop.js +165 -165
  149. package/utils/menu/before-close.js +17 -17
  150. package/utils/menu/index.js +395 -395
  151. package/utils/mime_type.js +67 -67
  152. package/utils/modelerUtil.js +227 -227
  153. package/utils/n/api.js +22 -22
  154. package/utils/n/date.js +57 -57
  155. package/utils/n/index.js +9 -9
  156. package/utils/n/is-type.js +176 -176
  157. package/utils/n/number.js +144 -144
  158. package/utils/n/permission-cache.js +11 -11
  159. package/utils/n/reuqest/axiosN.js +17 -17
  160. package/utils/n/reuqest/content-type.js +19 -19
  161. package/utils/n/reuqest/interceptors.js +95 -95
  162. package/utils/n/reuqest/url-params.js +12 -12
  163. package/utils/n/storage.js +51 -51
  164. package/utils/n/token.js +51 -51
  165. package/utils/n/user-cache.js +11 -11
  166. package/utils/n/user.js +34 -34
  167. package/utils/n/uuid.js +16 -16
  168. package/utils/n-generator-routers.js +208 -208
  169. package/utils/n-router.js +205 -205
  170. package/utils/n-theme.js +30 -30
  171. package/utils/number.js +180 -180
  172. package/utils/oss.js +57 -57
  173. package/utils/platform.js +1334 -1334
  174. package/utils/quarter.js +58 -58
  175. package/utils/storage.js +198 -198
  176. package/utils/theme.js +138 -138
  177. package/utils/transform.js +179 -0
  178. package/utils/type.js +102 -102
  179. package/utils/util.js +795 -795
  180. package/utils/validator.js +181 -181
  181. package/utils/vxetable/index.js +25 -25
  182. package/utils/zoomScroll.js +9 -9
@@ -1,235 +1,235 @@
1
- /**
2
- * 左补0到指定长度
3
- */
4
- function leftPad(input, num) {
5
- if (input.length >= num) return input;
6
-
7
- return (new Array(num - input.length + 1)).join('0') + input
8
- }
9
-
10
- /**
11
- * 二进制转化为十六进制
12
- */
13
- function binary2hex(binary) {
14
- const binaryLength = 8;
15
- let hex = '';
16
- for (let i = 0; i < binary.length / binaryLength; i++) {
17
- hex += leftPad(parseInt(binary.substr(i * binaryLength, binaryLength), 2).toString(16), 2);
18
- }
19
- return hex;
20
- }
21
-
22
- /**
23
- * 十六进制转化为二进制
24
- */
25
- function hex2binary(hex) {
26
- const hexLength = 2;
27
- let binary = '';
28
- for (let i = 0; i < hex.length / hexLength; i++) {
29
- binary += leftPad(parseInt(hex.substr(i * hexLength, hexLength), 16).toString(2), 8);
30
- }
31
- return binary;
32
- }
33
-
34
- /**
35
- * 普通字符串转化为二进制
36
- */
37
- function str2binary(str) {
38
- let binary = '';
39
- for (const ch of str) {
40
- binary += leftPad(ch.codePointAt(0).toString(2), 8);
41
- }
42
- return binary;
43
- }
44
-
45
- /**
46
- * 循环左移
47
- */
48
- function rol(str, n) {
49
- return str.substring(n % str.length) + str.substr(0, n % str.length);
50
- }
51
-
52
- /**
53
- * 二进制运算
54
- */
55
- function binaryCal(x, y, method) {
56
- const a = x || '';
57
- const b = y || '';
58
- const result = [];
59
- let prevResult;
60
-
61
- for (let i = a.length - 1; i >= 0; i--) { // 大端
62
- prevResult = method(a[i], b[i], prevResult);
63
- result[i] = prevResult[0];
64
- }
65
- return result.join('');
66
- }
67
-
68
- /**
69
- * 二进制异或运算
70
- */
71
- function xor(x, y) {
72
- return binaryCal(x, y, (a, b) => [(a === b ? '0' : '1')]);
73
- }
74
-
75
- /**
76
- * 二进制与运算
77
- */
78
- function and(x, y) {
79
- return binaryCal(x, y, (a, b) => [(a === '1' && b === '1' ? '1' : '0')]);
80
- }
81
-
82
- /**
83
- * 二进制或运算
84
- */
85
- function or(x, y) {
86
- return binaryCal(x, y, (a, b) => [(a === '1' || b === '1' ? '1' : '0')]); // a === '0' && b === '0' ? '0' : '1'
87
- }
88
-
89
- /**
90
- * 二进制与运算
91
- */
92
- function add(x, y) {
93
- const result = binaryCal(x, y, (a, b, prevResult) => {
94
- const carry = prevResult ? prevResult[1] : '0' || '0';
95
-
96
- // a,b不等时,carry不变,结果与carry相反
97
- // a,b相等时,结果等于原carry,新carry等于a
98
- if (a !== b) return [carry === '0' ? '1' : '0', carry];
99
-
100
- return [carry, a];
101
- });
102
-
103
- return result;
104
- }
105
-
106
- /**
107
- * 二进制非运算
108
- */
109
- function not(x) {
110
- return binaryCal(x, undefined, a => [a === '1' ? '0' : '1']);
111
- }
112
-
113
- function calMulti(method) {
114
- return (...arr) => arr.reduce((prev, curr) => method(prev, curr));
115
- }
116
-
117
- /**
118
- * 压缩函数中的置换函数 P1(X) = X xor (X <<< 9) xor (X <<< 17)
119
- */
120
- function P0(X) {
121
- return calMulti(xor)(X, rol(X, 9), rol(X, 17));
122
- }
123
-
124
- /**
125
- * 消息扩展中的置换函数 P1(X) = X xor (X <<< 15) xor (X <<< 23)
126
- */
127
- function P1(X) {
128
- return calMulti(xor)(X, rol(X, 15), rol(X, 23));
129
- }
130
-
131
- function FF(X, Y, Z, j) {
132
- return j >= 0 && j <= 15 ? calMulti(xor)(X, Y, Z) : calMulti(or)(and(X, Y), and(X, Z), and(Y, Z));
133
- }
134
-
135
- function GG(X, Y, Z, j) {
136
- return j >= 0 && j <= 15 ? calMulti(xor)(X, Y, Z) : or(and(X, Y), and(not(X), Z));
137
- }
138
-
139
- function T(j) {
140
- return j >= 0 && j <= 15 ? hex2binary('79cc4519') : hex2binary('7a879d8a');
141
- }
142
-
143
- /**
144
- * 压缩函数
145
- */
146
- function CF(V, Bi) {
147
- // 消息扩展
148
- const wordLength = 32;
149
- const W = [];
150
- const M = []; // W'
151
-
152
- // 将消息分组B划分为16个字W0, W1,…… ,W15 (字为长度为32的比特串)
153
- for (let i = 0; i < 16; i++) {
154
- W.push(Bi.substr(i * wordLength, wordLength));
155
- }
156
-
157
- // W[j] <- P1(W[j−16] xor W[j−9] xor (W[j−3] <<< 15)) xor (W[j−13] <<< 7) xor W[j−6]
158
- for (let j = 16; j < 68; j++) {
159
- W.push(calMulti(xor)(
160
- P1(calMulti(xor)(W[j - 16], W[j - 9], rol(W[j - 3], 15))),
161
- rol(W[j - 13], 7),
162
- W[j - 6]
163
- ));
164
- }
165
-
166
- // W′[j] = W[j] xor W[j+4]
167
- for (let j = 0; j < 64; j++) {
168
- M.push(xor(W[j], W[j + 4]));
169
- }
170
-
171
- // 压缩
172
- const wordRegister = []; // 字寄存器
173
- for (let j = 0; j < 8; j++) {
174
- wordRegister.push(V.substr(j * wordLength, wordLength));
175
- }
176
-
177
- let A = wordRegister[0];
178
- let B = wordRegister[1];
179
- let C = wordRegister[2];
180
- let D = wordRegister[3];
181
- let E = wordRegister[4];
182
- let F = wordRegister[5];
183
- let G = wordRegister[6];
184
- let H = wordRegister[7];
185
-
186
- // 中间变量
187
- let SS1;
188
- let SS2;
189
- let TT1;
190
- let TT2;
191
- for (let j = 0; j < 64; j++) {
192
- SS1 = rol(calMulti(add)(rol(A, 12), E, rol(T(j), j)), 7);
193
- SS2 = xor(SS1, rol(A, 12));
194
-
195
- TT1 = calMulti(add)(FF(A, B, C, j), D, SS2, M[j]);
196
- TT2 = calMulti(add)(GG(E, F, G, j), H, SS1, W[j]);
197
-
198
- D = C;
199
- C = rol(B, 9);
200
- B = A;
201
- A = TT1;
202
- H = G;
203
- G = rol(F, 19);
204
- F = E;
205
- E = P0(TT2);
206
- }
207
-
208
- return xor([A, B, C, D, E, F, G, H].join(''), V);
209
- }
210
-
211
- function sm3(str) {
212
- const binary = str2binary(str);
213
-
214
- // 填充
215
- const len = binary.length;
216
-
217
- // k是满足len + 1 + k = 448mod512的最小的非负整数
218
- let k = len % 512;
219
-
220
- // 如果 448 <= (512 % len) < 512,需要多补充 (len % 448) 比特'0'以满足总比特长度为512的倍数
221
- k = k >= 448 ? 512 - (k % 448) - 1 : 448 - k - 1;
222
-
223
- const m = `${binary}1${leftPad('', k)}${leftPad(len.toString(2), 64)}`.toString(); // k个0
224
-
225
- // 迭代压缩
226
- const n = (len + k + 65) / 512;
227
-
228
- let V = hex2binary('7380166f4914b2b9172442d7da8a0600a96f30bc163138aae38dee4db0fb0e4e');
229
- for (let i = 0; i <= n - 1; i++) {
230
- const B = m.substr(512 * i, 512);
231
- V = CF(V, B);
232
- }
233
- return binary2hex(V);
234
- };
235
- export default sm3;
1
+ /**
2
+ * 左补0到指定长度
3
+ */
4
+ function leftPad(input, num) {
5
+ if (input.length >= num) return input;
6
+
7
+ return (new Array(num - input.length + 1)).join('0') + input
8
+ }
9
+
10
+ /**
11
+ * 二进制转化为十六进制
12
+ */
13
+ function binary2hex(binary) {
14
+ const binaryLength = 8;
15
+ let hex = '';
16
+ for (let i = 0; i < binary.length / binaryLength; i++) {
17
+ hex += leftPad(parseInt(binary.substr(i * binaryLength, binaryLength), 2).toString(16), 2);
18
+ }
19
+ return hex;
20
+ }
21
+
22
+ /**
23
+ * 十六进制转化为二进制
24
+ */
25
+ function hex2binary(hex) {
26
+ const hexLength = 2;
27
+ let binary = '';
28
+ for (let i = 0; i < hex.length / hexLength; i++) {
29
+ binary += leftPad(parseInt(hex.substr(i * hexLength, hexLength), 16).toString(2), 8);
30
+ }
31
+ return binary;
32
+ }
33
+
34
+ /**
35
+ * 普通字符串转化为二进制
36
+ */
37
+ function str2binary(str) {
38
+ let binary = '';
39
+ for (const ch of str) {
40
+ binary += leftPad(ch.codePointAt(0).toString(2), 8);
41
+ }
42
+ return binary;
43
+ }
44
+
45
+ /**
46
+ * 循环左移
47
+ */
48
+ function rol(str, n) {
49
+ return str.substring(n % str.length) + str.substr(0, n % str.length);
50
+ }
51
+
52
+ /**
53
+ * 二进制运算
54
+ */
55
+ function binaryCal(x, y, method) {
56
+ const a = x || '';
57
+ const b = y || '';
58
+ const result = [];
59
+ let prevResult;
60
+
61
+ for (let i = a.length - 1; i >= 0; i--) { // 大端
62
+ prevResult = method(a[i], b[i], prevResult);
63
+ result[i] = prevResult[0];
64
+ }
65
+ return result.join('');
66
+ }
67
+
68
+ /**
69
+ * 二进制异或运算
70
+ */
71
+ function xor(x, y) {
72
+ return binaryCal(x, y, (a, b) => [(a === b ? '0' : '1')]);
73
+ }
74
+
75
+ /**
76
+ * 二进制与运算
77
+ */
78
+ function and(x, y) {
79
+ return binaryCal(x, y, (a, b) => [(a === '1' && b === '1' ? '1' : '0')]);
80
+ }
81
+
82
+ /**
83
+ * 二进制或运算
84
+ */
85
+ function or(x, y) {
86
+ return binaryCal(x, y, (a, b) => [(a === '1' || b === '1' ? '1' : '0')]); // a === '0' && b === '0' ? '0' : '1'
87
+ }
88
+
89
+ /**
90
+ * 二进制与运算
91
+ */
92
+ function add(x, y) {
93
+ const result = binaryCal(x, y, (a, b, prevResult) => {
94
+ const carry = prevResult ? prevResult[1] : '0' || '0';
95
+
96
+ // a,b不等时,carry不变,结果与carry相反
97
+ // a,b相等时,结果等于原carry,新carry等于a
98
+ if (a !== b) return [carry === '0' ? '1' : '0', carry];
99
+
100
+ return [carry, a];
101
+ });
102
+
103
+ return result;
104
+ }
105
+
106
+ /**
107
+ * 二进制非运算
108
+ */
109
+ function not(x) {
110
+ return binaryCal(x, undefined, a => [a === '1' ? '0' : '1']);
111
+ }
112
+
113
+ function calMulti(method) {
114
+ return (...arr) => arr.reduce((prev, curr) => method(prev, curr));
115
+ }
116
+
117
+ /**
118
+ * 压缩函数中的置换函数 P1(X) = X xor (X <<< 9) xor (X <<< 17)
119
+ */
120
+ function P0(X) {
121
+ return calMulti(xor)(X, rol(X, 9), rol(X, 17));
122
+ }
123
+
124
+ /**
125
+ * 消息扩展中的置换函数 P1(X) = X xor (X <<< 15) xor (X <<< 23)
126
+ */
127
+ function P1(X) {
128
+ return calMulti(xor)(X, rol(X, 15), rol(X, 23));
129
+ }
130
+
131
+ function FF(X, Y, Z, j) {
132
+ return j >= 0 && j <= 15 ? calMulti(xor)(X, Y, Z) : calMulti(or)(and(X, Y), and(X, Z), and(Y, Z));
133
+ }
134
+
135
+ function GG(X, Y, Z, j) {
136
+ return j >= 0 && j <= 15 ? calMulti(xor)(X, Y, Z) : or(and(X, Y), and(not(X), Z));
137
+ }
138
+
139
+ function T(j) {
140
+ return j >= 0 && j <= 15 ? hex2binary('79cc4519') : hex2binary('7a879d8a');
141
+ }
142
+
143
+ /**
144
+ * 压缩函数
145
+ */
146
+ function CF(V, Bi) {
147
+ // 消息扩展
148
+ const wordLength = 32;
149
+ const W = [];
150
+ const M = []; // W'
151
+
152
+ // 将消息分组B划分为16个字W0, W1,…… ,W15 (字为长度为32的比特串)
153
+ for (let i = 0; i < 16; i++) {
154
+ W.push(Bi.substr(i * wordLength, wordLength));
155
+ }
156
+
157
+ // W[j] <- P1(W[j−16] xor W[j−9] xor (W[j−3] <<< 15)) xor (W[j−13] <<< 7) xor W[j−6]
158
+ for (let j = 16; j < 68; j++) {
159
+ W.push(calMulti(xor)(
160
+ P1(calMulti(xor)(W[j - 16], W[j - 9], rol(W[j - 3], 15))),
161
+ rol(W[j - 13], 7),
162
+ W[j - 6]
163
+ ));
164
+ }
165
+
166
+ // W′[j] = W[j] xor W[j+4]
167
+ for (let j = 0; j < 64; j++) {
168
+ M.push(xor(W[j], W[j + 4]));
169
+ }
170
+
171
+ // 压缩
172
+ const wordRegister = []; // 字寄存器
173
+ for (let j = 0; j < 8; j++) {
174
+ wordRegister.push(V.substr(j * wordLength, wordLength));
175
+ }
176
+
177
+ let A = wordRegister[0];
178
+ let B = wordRegister[1];
179
+ let C = wordRegister[2];
180
+ let D = wordRegister[3];
181
+ let E = wordRegister[4];
182
+ let F = wordRegister[5];
183
+ let G = wordRegister[6];
184
+ let H = wordRegister[7];
185
+
186
+ // 中间变量
187
+ let SS1;
188
+ let SS2;
189
+ let TT1;
190
+ let TT2;
191
+ for (let j = 0; j < 64; j++) {
192
+ SS1 = rol(calMulti(add)(rol(A, 12), E, rol(T(j), j)), 7);
193
+ SS2 = xor(SS1, rol(A, 12));
194
+
195
+ TT1 = calMulti(add)(FF(A, B, C, j), D, SS2, M[j]);
196
+ TT2 = calMulti(add)(GG(E, F, G, j), H, SS1, W[j]);
197
+
198
+ D = C;
199
+ C = rol(B, 9);
200
+ B = A;
201
+ A = TT1;
202
+ H = G;
203
+ G = rol(F, 19);
204
+ F = E;
205
+ E = P0(TT2);
206
+ }
207
+
208
+ return xor([A, B, C, D, E, F, G, H].join(''), V);
209
+ }
210
+
211
+ function sm3(str) {
212
+ const binary = str2binary(str);
213
+
214
+ // 填充
215
+ const len = binary.length;
216
+
217
+ // k是满足len + 1 + k = 448mod512的最小的非负整数
218
+ let k = len % 512;
219
+
220
+ // 如果 448 <= (512 % len) < 512,需要多补充 (len % 448) 比特'0'以满足总比特长度为512的倍数
221
+ k = k >= 448 ? 512 - (k % 448) - 1 : 448 - k - 1;
222
+
223
+ const m = `${binary}1${leftPad('', k)}${leftPad(len.toString(2), 64)}`.toString(); // k个0
224
+
225
+ // 迭代压缩
226
+ const n = (len + k + 65) / 512;
227
+
228
+ let V = hex2binary('7380166f4914b2b9172442d7da8a0600a96f30bc163138aae38dee4db0fb0e4e');
229
+ for (let i = 0; i <= n - 1; i++) {
230
+ const B = m.substr(512 * i, 512);
231
+ V = CF(V, B);
232
+ }
233
+ return binary2hex(V);
234
+ };
235
+ export default sm3;