module-menu 0.3.26 → 0.3.27
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/config/config.js +3 -3
- package/package.json +1 -1
- package/src/.umi/.cache/babel-loader/00e686d9a9b52074d267c6c52238b773.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/0127a51a5419eb2e27c73aa088e69579.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/015fac2a75b744cc2159af7c26c21951.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/02255b2cf26f46683dee316d9345ec21.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/0428496446fb6c72cd57973c32e3811f.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/04b6caeb8c13675aa936771b82af2673.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/063d0666d554d0959adfc81c349cb83d.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/0673dd27f6e49f68739e9e4234717375.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/07612394a0a7d1cc3c8339cfeb9d9543.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/0bb421449911a6500d97130aa4bc6ab6.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/0e9227fe8deaaf9f92d607ebeddf2e7b.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/1075b73a6f294d9d839c54f5cf84c161.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/16656b2e25391c0d6961398e0b33438c.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/16c17249e992d0434dafaf1d4560a186.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/1746c639b45c30c5d8a78c07946d0b74.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/1aa2f2dde13c2e4f69c6d37745031eb7.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/1b71aa693473e9e8829aaaa28d422113.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/21f22e40241373502bfd7571e04fea2e.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/2cc003b4c1b0e279f69b8e132455a3d9.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/2dcd9f9ba91dfc9f38b2d0c978eee907.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/300a1be5241e31b486b141f651537a10.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/3012d9cdc7b6a235cf21f278c4ec7835.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/302198f4003d0d34b9556c19fa948900.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/35c4f67c72de39cfd076dbced4e079f4.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/38e47d65a5bf8cd9e77bd73aa5c290c0.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/3ac7df69254de4a22cbbf9f0f7b6a9a9.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/3b238bd1abbc45411c6a16fc7cce8eae.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/3f72b02a946dc8d01529f81e7bfc8f42.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/403268faeaec6e83fd0ea2d4120ebc51.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/405a6b386665537a9bf08a7edfd33332.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/4111c41fa143cbfaed56fc37c6466644.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/4179da9a8ab3bb04f30e0b06f9cc11ee.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/41b814b3d99119d46d63f63e1e3d10b2.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/41c023e02893c720f735e572cde94c38.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/42acb49276aee8bd58d5b0737999d835.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/437c5fe890ddcf411d4f887be40edec9.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/471ec8ced192fe840acc156049f26ca9.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/4a5cf648ae229a86e6b2a82d6f24e12c.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/4f9ac7c1b1b2147c44b469f178716189.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/508ae8dcf50046bd4d2bc60f88792614.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/539bd44ead73051b12bd1c842e5fb6d3.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/6011e581b95164060eef44796c798516.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/60aed7f90838268a2fa7fb1c1c6dc8cf.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/622748bb2b90b0add233840025966a66.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/637cd17e6bc06a7f5ece19af75fb17cd.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/66079e0bbb4bc3ff4669cde8c628648f.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/6904e512c40cfbaccaad703dba436d1f.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/6937c76f72a59be0a5d52eb9c9510d0c.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/6999aefb22402ec82755d06654ace0d9.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/6bd40652daf7c4a57f9872c14a88eb2c.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/7245725a3cd95dcc0b4d7d2cbdcaaa11.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/77bdd0610bbd64c3871a972069bdddff.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/77cb5dd1ece8cc1b4ca6a5be3ec16ea2.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/783d7fd96d1b122385119d6958f8adfd.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/7a0e9a71bd8b7c34b4d8b3067dea4344.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/7c6a72e92451d4c0b6fdd566af660aa0.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8340f0fb1da8d4309b06ed640a132cd7.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/84cfa40923943ec61595a989adb93219.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8640041a103122935a4d661c4ef72956.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8701c50caac6fbedde09900c67fea93d.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8875a1d14a82c56052f7eb66cbeff01b.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/89c9e8aff6aa19b508fcff8e465e38f1.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8a457c2917364ef3d6073254327a7116.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8b2f2e8aba549655e38edc8283db0856.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8b7a1c45337a405be6a367a7f7bd5231.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8cd10524226ebe1f82e6cdeeeff89025.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8d49604c6d4e330f69d9c0e0401604fc.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8e7597b563230a311ee35e06c49cce78.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/8e908f1298693111a8809261795a975e.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/90d13cd0b57dbf314fce1f3910748bf7.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/95869a797109c7929fad325445407a88.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/96356521717bd98f94bf570498e2bdac.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/96af6ac3ba3e55f503b92bc83ac79b69.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/9d9bd458b2f4acbe847d60a442b36aa7.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/9e27938b109e3215119a9b2e11aafa77.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/9e6993204322f47827edc4298b3ef726.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/a0f315da8305900e0ad315b3643f91b3.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/a68ea6147e3c31fee728549451ae37f6.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/a75815991eaf176d718a0206dce41d4b.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/a7d4f4188cc1eaefa7de230ac685608c.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/a9b737f8216dc68191aa6fa2277205fa.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/aad567af42c39a958d8f91f66f849622.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/abb05534e4a467eae54d2e4d5aa8303c.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ac73a889c509078f990bf0170dd0dd87.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ac990b48d75cbd7996a56c81c635d151.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ae97fdde4bcafc1ee12d3075a20315ed.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/afb2fe1a2b1d00dfad1d76c1eccc4305.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/b4841357e4d27452308979cfdbf1b7b8.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/b4a261ea2e90f4d433d42478a87118cf.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/b9f7c307e9576b1852ea0bb693af1394.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ba98ff71bfd35d178465c8ace5dcb41f.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/bb195aa468d79e16f3596168c6ff424b.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/be3434c9c19c0b9ef3ff78ba4b9ec6f7.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/c00ffa8322a3fe88202dcd5073c0098d.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/c0df5a1f4b445c57c061d0017fb21b98.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/c56b0fe9c1ec620656b1b06fce26af2b.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/c74bf94dcaa301c8dc622d7ec79f7646.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/c7778ab39b27fa3e82c950c7436eadd3.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ca3ee27a3dff18c1a2965d4beccec775.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/cd2ebb1f4ba05e8e5fb647389dd8809a.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/d427ef7f69d22902e40305ffb1df3f8d.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/d54081283a3ae9bd2d253bda2d98698d.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/d70e71e96ae16c0b6e2d810577e88e29.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/d9591ac5d4089029997c94bb178eed0e.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/d99f7c0e0ec7c0fe0ca974b925cf0310.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/dc6c744e93600cd81106dd6887d83caf.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/dfbf5a676dad168763561972b5fc729f.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/e0391f77820c95fb17b31ade3a997c50.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/e169629c75b12e1df75e1634e9280d00.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/e2162900b1048fcdcfdf9271f2f8afe3.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/e26571fca7759e10133524b84b83e979.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/e50bfb371c1694e6a3e3f736aa15ed17.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/e5f754595c3e79bac8d252dbe3c34b09.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/e74145422288c07e567aaad5f1705dbe.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ec0ed12c3cdcfbc55ae90755517ea781.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ec8d9e5802ab7a65a66ff2781e5f8ba4.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/eebeadc188fd0fd39be73ad0bd3e08d3.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/efae2f878897f192d48765ac41995275.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/f42098039755e3b66b94facca3360fb2.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/f567f85114ddf11b4a128cd461dad643.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/f69a1d64f0ed9c67f924517c67005601.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/f756541b483e7fc07ad1c8c15fe9b95d.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/fb30c0b07249302d3e0985c5d51ca3e7.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/feb60241cc84825b304ba829169c5f79.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ff5d37e28c04ae8014d2951d468cac13.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ff8b1b74c174f08c9bfff5953aa46174.json.gz +0 -0
- package/src/.umi/.cache/babel-loader/ffabba4a0fb3f0ca3e93fd96d3aa308a.json.gz +0 -0
- package/src/.umi/core/devScripts.ts +53 -0
- package/src/.umi/core/history.ts +21 -0
- package/src/.umi/core/plugin.ts +8 -0
- package/src/.umi/core/pluginConfig.d.ts +304 -0
- package/src/.umi/core/pluginRegister.ts +15 -0
- package/src/.umi/core/polyfill.ts +4 -0
- package/src/.umi/core/routes.ts +24 -0
- package/src/.umi/core/umiExports.ts +7 -0
- package/src/.umi/plugin-helmet/exports.ts +3 -0
- package/src/.umi/plugin-initial-state/Provider.tsx +37 -0
- package/src/.umi/plugin-initial-state/exports.ts +7 -0
- package/src/.umi/plugin-initial-state/models/initialState.ts +2 -0
- package/src/.umi/plugin-initial-state/runtime.tsx +13 -0
- package/src/.umi/plugin-model/Provider.tsx +39 -0
- package/src/.umi/plugin-model/helpers/constant.tsx +4 -0
- package/src/.umi/plugin-model/helpers/dispatcher.tsx +19 -0
- package/src/.umi/plugin-model/helpers/executor.tsx +83 -0
- package/src/.umi/plugin-model/runtime.tsx +12 -0
- package/src/.umi/plugin-model/useModel.tsx +71 -0
- package/src/.umi/plugin-request/request.ts +278 -0
- package/src/.umi/umi.ts +58 -0
- package/src/pages/ModuleUser/index.jsx +29 -2
- package/src/pages/util/axios.js +1 -1
|
@@ -0,0 +1,304 @@
|
|
|
1
|
+
// Created by Umi Plugin
|
|
2
|
+
|
|
3
|
+
export interface IConfigFromPlugins {
|
|
4
|
+
"404"?: boolean
|
|
5
|
+
routes?: {
|
|
6
|
+
/**
|
|
7
|
+
* Any valid URL path
|
|
8
|
+
*/
|
|
9
|
+
path?: string
|
|
10
|
+
/**
|
|
11
|
+
* A React component to render only when the location matches.
|
|
12
|
+
*/
|
|
13
|
+
component?: (string | (() => any))
|
|
14
|
+
wrappers?: string[]
|
|
15
|
+
/**
|
|
16
|
+
* navigate to a new location
|
|
17
|
+
*/
|
|
18
|
+
redirect?: string
|
|
19
|
+
/**
|
|
20
|
+
* When true, the active class/style will only be applied if the location is matched exactly.
|
|
21
|
+
*/
|
|
22
|
+
exact?: boolean
|
|
23
|
+
routes?: any[]
|
|
24
|
+
[k: string]: any
|
|
25
|
+
}[]
|
|
26
|
+
history?: {
|
|
27
|
+
type?: ("browser" | "hash" | "memory")
|
|
28
|
+
options?: {
|
|
29
|
+
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
polyfill?: {
|
|
33
|
+
imports?: string[]
|
|
34
|
+
}
|
|
35
|
+
alias?: {
|
|
36
|
+
|
|
37
|
+
}
|
|
38
|
+
analyze?: {
|
|
39
|
+
analyzerMode?: ("server" | "static" | "disabled")
|
|
40
|
+
analyzerHost?: string
|
|
41
|
+
analyzerPort?: any
|
|
42
|
+
openAnalyzer?: boolean
|
|
43
|
+
generateStatsFile?: boolean
|
|
44
|
+
statsFilename?: string
|
|
45
|
+
logLevel?: ("info" | "warn" | "error" | "silent")
|
|
46
|
+
defaultSizes?: ("stat" | "parsed" | "gzip")
|
|
47
|
+
[k: string]: any
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* postcss autoprefixer, default flexbox: no-2009
|
|
51
|
+
*/
|
|
52
|
+
autoprefixer?: {
|
|
53
|
+
|
|
54
|
+
}
|
|
55
|
+
base?: string
|
|
56
|
+
chainWebpack?: (() => any)
|
|
57
|
+
chunks?: string[]
|
|
58
|
+
/**
|
|
59
|
+
* more css-loader options see https://webpack.js.org/loaders/css-loader/#options
|
|
60
|
+
*/
|
|
61
|
+
cssLoader?: {
|
|
62
|
+
url?: (boolean | (() => any))
|
|
63
|
+
import?: (boolean | (() => any))
|
|
64
|
+
modules?: (boolean | string | {
|
|
65
|
+
|
|
66
|
+
})
|
|
67
|
+
sourceMap?: boolean
|
|
68
|
+
importLoaders?: number
|
|
69
|
+
onlyLocals?: boolean
|
|
70
|
+
esModule?: boolean
|
|
71
|
+
localsConvention?: ("asIs" | "camelCase" | "camelCaseOnly" | "dashes" | "dashesOnly")
|
|
72
|
+
}
|
|
73
|
+
cssModulesTypescriptLoader?: {
|
|
74
|
+
mode?: ("emit" | "verify")
|
|
75
|
+
}
|
|
76
|
+
cssnano?: {
|
|
77
|
+
|
|
78
|
+
}
|
|
79
|
+
copy?: any[]
|
|
80
|
+
define?: {
|
|
81
|
+
|
|
82
|
+
}
|
|
83
|
+
devScripts?: {
|
|
84
|
+
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* devServer configs
|
|
88
|
+
*/
|
|
89
|
+
devServer?: {
|
|
90
|
+
/**
|
|
91
|
+
* devServer port, default 8000
|
|
92
|
+
*/
|
|
93
|
+
port?: number
|
|
94
|
+
host?: string
|
|
95
|
+
https?: ({
|
|
96
|
+
key?: string
|
|
97
|
+
cert?: string
|
|
98
|
+
http2?: boolean
|
|
99
|
+
[k: string]: any
|
|
100
|
+
} | boolean)
|
|
101
|
+
headers?: {
|
|
102
|
+
|
|
103
|
+
}
|
|
104
|
+
writeToDisk?: (boolean | (() => any))
|
|
105
|
+
[k: string]: any
|
|
106
|
+
}
|
|
107
|
+
devtool?: string
|
|
108
|
+
/**
|
|
109
|
+
* Code splitting for performance optimization
|
|
110
|
+
*/
|
|
111
|
+
dynamicImport?: {
|
|
112
|
+
/**
|
|
113
|
+
* loading the component before loaded
|
|
114
|
+
*/
|
|
115
|
+
loading?: string
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Code splitting for import statement syntax
|
|
119
|
+
*/
|
|
120
|
+
dynamicImportSyntax?: {
|
|
121
|
+
|
|
122
|
+
}
|
|
123
|
+
exportStatic?: {
|
|
124
|
+
htmlSuffix?: boolean
|
|
125
|
+
dynamicRoot?: boolean
|
|
126
|
+
supportWin?: boolean
|
|
127
|
+
/**
|
|
128
|
+
* extra render paths only enable in ssr
|
|
129
|
+
*/
|
|
130
|
+
extraRoutePaths?: (() => any)
|
|
131
|
+
}
|
|
132
|
+
externals?: ({
|
|
133
|
+
|
|
134
|
+
} | string | (() => any))
|
|
135
|
+
extraBabelIncludes?: any[]
|
|
136
|
+
extraBabelPlugins?: any[]
|
|
137
|
+
extraBabelPresets?: any[]
|
|
138
|
+
extraPostCSSPlugins?: any[]
|
|
139
|
+
/**
|
|
140
|
+
* fork-ts-checker-webpack-plugin options see https://github.com/TypeStrong/fork-ts-checker-webpack-plugin#options
|
|
141
|
+
*/
|
|
142
|
+
forkTSChecker?: {
|
|
143
|
+
async?: boolean
|
|
144
|
+
typescript?: (boolean | {
|
|
145
|
+
|
|
146
|
+
})
|
|
147
|
+
eslint?: {
|
|
148
|
+
|
|
149
|
+
}
|
|
150
|
+
issue?: {
|
|
151
|
+
|
|
152
|
+
}
|
|
153
|
+
formatter?: (string | {
|
|
154
|
+
|
|
155
|
+
})
|
|
156
|
+
logger?: {
|
|
157
|
+
|
|
158
|
+
}
|
|
159
|
+
[k: string]: any
|
|
160
|
+
}
|
|
161
|
+
fastRefresh?: {
|
|
162
|
+
|
|
163
|
+
}
|
|
164
|
+
hash?: boolean
|
|
165
|
+
ignoreMomentLocale?: boolean
|
|
166
|
+
inlineLimit?: number
|
|
167
|
+
lessLoader?: {
|
|
168
|
+
|
|
169
|
+
}
|
|
170
|
+
manifest?: {
|
|
171
|
+
fileName?: string
|
|
172
|
+
publicPath?: ""
|
|
173
|
+
basePath?: string
|
|
174
|
+
writeToFileEmit?: boolean
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* open mfsu feature
|
|
178
|
+
*/
|
|
179
|
+
mfsu?: {
|
|
180
|
+
development?: {
|
|
181
|
+
output?: string
|
|
182
|
+
}
|
|
183
|
+
production?: {
|
|
184
|
+
output?: string
|
|
185
|
+
}
|
|
186
|
+
mfName?: string
|
|
187
|
+
exportAllMembers?: {
|
|
188
|
+
|
|
189
|
+
}
|
|
190
|
+
chunks?: string[]
|
|
191
|
+
ignoreNodeBuiltInModules?: boolean
|
|
192
|
+
}
|
|
193
|
+
mountElementId?: ""
|
|
194
|
+
mpa?: {
|
|
195
|
+
|
|
196
|
+
}
|
|
197
|
+
nodeModulesTransform?: {
|
|
198
|
+
type?: ("all" | "none")
|
|
199
|
+
exclude?: string[]
|
|
200
|
+
}
|
|
201
|
+
outputPath?: ""
|
|
202
|
+
plugins?: string[]
|
|
203
|
+
postcssLoader?: {
|
|
204
|
+
|
|
205
|
+
}
|
|
206
|
+
presets?: string[]
|
|
207
|
+
proxy?: {
|
|
208
|
+
|
|
209
|
+
}
|
|
210
|
+
publicPath?: string
|
|
211
|
+
runtimePublicPath?: boolean
|
|
212
|
+
ssr?: {
|
|
213
|
+
/**
|
|
214
|
+
* force execing Page getInitialProps functions
|
|
215
|
+
*/
|
|
216
|
+
forceInitial?: boolean
|
|
217
|
+
/**
|
|
218
|
+
* remove window.g_initialProps in html
|
|
219
|
+
*/
|
|
220
|
+
removeWindowInitialProps?: boolean
|
|
221
|
+
/**
|
|
222
|
+
* disable serve-side render in umi dev mode.
|
|
223
|
+
*/
|
|
224
|
+
devServerRender?: boolean
|
|
225
|
+
mode?: ("stream" | "string")
|
|
226
|
+
/**
|
|
227
|
+
* static markup in static site
|
|
228
|
+
*/
|
|
229
|
+
staticMarkup?: boolean
|
|
230
|
+
}
|
|
231
|
+
singular?: boolean
|
|
232
|
+
styleLoader?: {
|
|
233
|
+
|
|
234
|
+
}
|
|
235
|
+
targets?: {
|
|
236
|
+
|
|
237
|
+
}
|
|
238
|
+
terserOptions?: {
|
|
239
|
+
|
|
240
|
+
}
|
|
241
|
+
theme?: {
|
|
242
|
+
|
|
243
|
+
}
|
|
244
|
+
runtimeHistory?: {
|
|
245
|
+
|
|
246
|
+
}
|
|
247
|
+
webpack5?: {
|
|
248
|
+
lazyCompilation?: {
|
|
249
|
+
entries?: boolean
|
|
250
|
+
imports?: boolean
|
|
251
|
+
test?: any
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
workerLoader?: {
|
|
255
|
+
|
|
256
|
+
}
|
|
257
|
+
favicon?: string
|
|
258
|
+
headScripts?: any[]
|
|
259
|
+
links?: any[]
|
|
260
|
+
metas?: any[]
|
|
261
|
+
scripts?: any[]
|
|
262
|
+
styles?: any[]
|
|
263
|
+
title?: string
|
|
264
|
+
mock?: {
|
|
265
|
+
exclude?: string[]
|
|
266
|
+
}
|
|
267
|
+
antd?: {
|
|
268
|
+
dark?: boolean
|
|
269
|
+
compact?: boolean
|
|
270
|
+
mobile?: boolean
|
|
271
|
+
disableBabelPluginImport?: boolean
|
|
272
|
+
config?: {
|
|
273
|
+
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
dva?: {
|
|
277
|
+
disableModelsReExport?: boolean
|
|
278
|
+
/**
|
|
279
|
+
* lazy load dva model avoiding the import modules from umi undefined
|
|
280
|
+
*/
|
|
281
|
+
lazyLoad?: boolean
|
|
282
|
+
extraModels?: string[]
|
|
283
|
+
hmr?: boolean
|
|
284
|
+
immer?: (boolean | {
|
|
285
|
+
|
|
286
|
+
})
|
|
287
|
+
skipModelValidate?: boolean
|
|
288
|
+
}
|
|
289
|
+
locale?: {
|
|
290
|
+
default?: string
|
|
291
|
+
useLocalStorage?: boolean
|
|
292
|
+
baseNavigator?: boolean
|
|
293
|
+
title?: boolean
|
|
294
|
+
antd?: boolean
|
|
295
|
+
baseSeparator?: string
|
|
296
|
+
}
|
|
297
|
+
layout?: {
|
|
298
|
+
|
|
299
|
+
}
|
|
300
|
+
request?: {
|
|
301
|
+
dataField?: ""
|
|
302
|
+
}
|
|
303
|
+
[k: string]: any
|
|
304
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import { plugin } from './plugin';
|
|
3
|
+
import * as Plugin_0 from '../plugin-initial-state/runtime';
|
|
4
|
+
import * as Plugin_1 from '../plugin-model/runtime';
|
|
5
|
+
|
|
6
|
+
plugin.register({
|
|
7
|
+
apply: Plugin_0,
|
|
8
|
+
path: '../plugin-initial-state/runtime',
|
|
9
|
+
});
|
|
10
|
+
plugin.register({
|
|
11
|
+
apply: Plugin_1,
|
|
12
|
+
path: '../plugin-model/runtime',
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
export const __mfsu = 1;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { ApplyPluginsType } from '/Users/huarui/work/module-menu/node_modules/@umijs/runtime';
|
|
4
|
+
import * as umiExports from './umiExports';
|
|
5
|
+
import { plugin } from './plugin';
|
|
6
|
+
|
|
7
|
+
export function getRoutes() {
|
|
8
|
+
const routes = [
|
|
9
|
+
{
|
|
10
|
+
"path": "/",
|
|
11
|
+
"component": require('@/pages/index').default,
|
|
12
|
+
"exact": true
|
|
13
|
+
}
|
|
14
|
+
];
|
|
15
|
+
|
|
16
|
+
// allow user to extend routes
|
|
17
|
+
plugin.applyPlugins({
|
|
18
|
+
key: 'patchRoutes',
|
|
19
|
+
type: ApplyPluginsType.event,
|
|
20
|
+
args: { routes },
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
return routes;
|
|
24
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
export { history } from './history';
|
|
3
|
+
export { plugin } from './plugin';
|
|
4
|
+
export * from '../plugin-initial-state/exports';
|
|
5
|
+
export * from '../plugin-model/useModel';
|
|
6
|
+
export * from '../plugin-request/request';
|
|
7
|
+
export * from '../plugin-helmet/exports';
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
|
|
3
|
+
import React, { useRef, useEffect } from "react";
|
|
4
|
+
import { plugin } from "../core/umiExports";
|
|
5
|
+
import { ApplyPluginsType } from 'umi';
|
|
6
|
+
import { useModel } from "../plugin-model/useModel";
|
|
7
|
+
if (typeof useModel !== "function") {
|
|
8
|
+
throw new Error(
|
|
9
|
+
"[plugin-initial-state]: useModel is not a function, @umijs/plugin-model is required."
|
|
10
|
+
);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
interface Props {
|
|
14
|
+
children: React.ReactNode;
|
|
15
|
+
}
|
|
16
|
+
export default (props: Props) => {
|
|
17
|
+
const { children } = props;
|
|
18
|
+
const appLoaded = useRef(false);
|
|
19
|
+
// 获取用户的配置,暂时只支持 loading
|
|
20
|
+
const useRuntimeConfig =
|
|
21
|
+
plugin.applyPlugins({
|
|
22
|
+
key: "initialStateConfig",
|
|
23
|
+
type: ApplyPluginsType.modify,
|
|
24
|
+
initialValue: {},
|
|
25
|
+
}) || {};
|
|
26
|
+
const { loading = false } = useModel("@@initialState") || {};
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
if (!loading) {
|
|
29
|
+
appLoaded.current = true;
|
|
30
|
+
}
|
|
31
|
+
}, [loading]);
|
|
32
|
+
// initial state loading 时,阻塞渲染
|
|
33
|
+
if (loading && !appLoaded.current) {
|
|
34
|
+
return useRuntimeConfig.loading || null;
|
|
35
|
+
}
|
|
36
|
+
return children;
|
|
37
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import Provider from './Provider';
|
|
4
|
+
|
|
5
|
+
export function rootContainer(container: React.ReactNode) {
|
|
6
|
+
return React.createElement(
|
|
7
|
+
// 这里的 plugin-initial-state 不能从 constant 里取,里面有 path 依赖
|
|
8
|
+
// 但 webpack-5 没有 node 补丁(包括 path)
|
|
9
|
+
Provider,
|
|
10
|
+
null,
|
|
11
|
+
container,
|
|
12
|
+
);
|
|
13
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import initialState from '/Users/huarui/work/module-menu/src/.umi/plugin-initial-state/models/initialState';
|
|
4
|
+
|
|
5
|
+
// @ts-ignore
|
|
6
|
+
import Dispatcher from './helpers/dispatcher';
|
|
7
|
+
// @ts-ignore
|
|
8
|
+
import Executor from './helpers/executor';
|
|
9
|
+
// @ts-ignore
|
|
10
|
+
import { UmiContext } from './helpers/constant';
|
|
11
|
+
|
|
12
|
+
export const models = { '@@initialState': initialState, };
|
|
13
|
+
|
|
14
|
+
export type Model<T extends keyof typeof models> = {
|
|
15
|
+
[key in keyof typeof models]: ReturnType<typeof models[T]>;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export type Models<T extends keyof typeof models> = Model<T>[T]
|
|
19
|
+
|
|
20
|
+
const dispatcher = new Dispatcher!();
|
|
21
|
+
const Exe = Executor!;
|
|
22
|
+
|
|
23
|
+
export default ({ children }: { children: React.ReactNode }) => {
|
|
24
|
+
|
|
25
|
+
return (
|
|
26
|
+
<UmiContext.Provider value={dispatcher}>
|
|
27
|
+
{
|
|
28
|
+
Object.entries(models).map(pair => (
|
|
29
|
+
<Exe key={pair[0]} namespace={pair[0]} hook={pair[1] as any} onUpdate={(val: any) => {
|
|
30
|
+
const [ns] = pair as [keyof typeof models, any];
|
|
31
|
+
dispatcher.data[ns] = val;
|
|
32
|
+
dispatcher.update(ns);
|
|
33
|
+
}} />
|
|
34
|
+
))
|
|
35
|
+
}
|
|
36
|
+
{children}
|
|
37
|
+
</UmiContext.Provider>
|
|
38
|
+
)
|
|
39
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
export default class Dispatcher {
|
|
3
|
+
callbacks = {};
|
|
4
|
+
|
|
5
|
+
data = {};
|
|
6
|
+
|
|
7
|
+
update = (namespace: string) => {
|
|
8
|
+
(this.callbacks[namespace] || []).forEach(
|
|
9
|
+
(callback: (val: any) => void) => {
|
|
10
|
+
try {
|
|
11
|
+
const data = this.data[namespace];
|
|
12
|
+
callback(data);
|
|
13
|
+
} catch (e) {
|
|
14
|
+
callback(undefined);
|
|
15
|
+
}
|
|
16
|
+
},
|
|
17
|
+
);
|
|
18
|
+
};
|
|
19
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import React, { useEffect, useRef, useMemo } from 'react';
|
|
3
|
+
|
|
4
|
+
interface ExecutorProps {
|
|
5
|
+
hook: () => any;
|
|
6
|
+
onUpdate: (val: any) => void;
|
|
7
|
+
namespace: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export default (props: ExecutorProps) => {
|
|
11
|
+
const { hook, onUpdate, namespace } = props;
|
|
12
|
+
|
|
13
|
+
const updateRef = useRef(onUpdate);
|
|
14
|
+
updateRef.current = onUpdate;
|
|
15
|
+
const initialLoad = useRef(false);
|
|
16
|
+
|
|
17
|
+
let data: any;
|
|
18
|
+
try {
|
|
19
|
+
data = hook();
|
|
20
|
+
if (
|
|
21
|
+
process.env.NODE_ENV === 'development' &&
|
|
22
|
+
typeof document !== 'undefined'
|
|
23
|
+
) {
|
|
24
|
+
try {
|
|
25
|
+
let count = Object.keys(
|
|
26
|
+
((window as any)._umi_useModel_dev_tool_log || {})[namespace] || {},
|
|
27
|
+
).length;
|
|
28
|
+
(window as any)._umi_useModel_dev_tool = Object.assign(
|
|
29
|
+
(window as any)._umi_useModel_dev_tool || {},
|
|
30
|
+
{
|
|
31
|
+
[namespace]: data,
|
|
32
|
+
},
|
|
33
|
+
);
|
|
34
|
+
(window as any)._umi_useModel_dev_tool_log = Object.assign(
|
|
35
|
+
(window as any)._umi_useModel_dev_tool_log || {},
|
|
36
|
+
{
|
|
37
|
+
[namespace]: Object.assign(
|
|
38
|
+
((window as any)._umi_useModel_dev_tool_log || {})[namespace] ||
|
|
39
|
+
{},
|
|
40
|
+
{
|
|
41
|
+
[count]: data,
|
|
42
|
+
},
|
|
43
|
+
),
|
|
44
|
+
},
|
|
45
|
+
);
|
|
46
|
+
window.dispatchEvent(
|
|
47
|
+
new CustomEvent('_umi_useModel_update', {
|
|
48
|
+
detail: {
|
|
49
|
+
namespace,
|
|
50
|
+
time: Date.now(),
|
|
51
|
+
data,
|
|
52
|
+
index: count,
|
|
53
|
+
},
|
|
54
|
+
}),
|
|
55
|
+
);
|
|
56
|
+
} catch (e) {
|
|
57
|
+
// dev tool 记录失败、可能是低版本浏览器,忽略
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
} catch (e) {
|
|
61
|
+
console.error(
|
|
62
|
+
`plugin-model: Invoking '${namespace || 'unknown'}' model failed:`,
|
|
63
|
+
e,
|
|
64
|
+
);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// 首次执行时立刻返回初始值
|
|
68
|
+
useMemo(() => {
|
|
69
|
+
updateRef.current(data);
|
|
70
|
+
initialLoad.current = false;
|
|
71
|
+
}, []);
|
|
72
|
+
|
|
73
|
+
// React 16.13 后 update 函数用 useEffect 包裹
|
|
74
|
+
useEffect(() => {
|
|
75
|
+
if (initialLoad.current) {
|
|
76
|
+
updateRef.current(data);
|
|
77
|
+
} else {
|
|
78
|
+
initialLoad.current = true;
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
return <></>;
|
|
83
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
/* eslint-disable import/no-dynamic-require */
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import Provider from './Provider';
|
|
5
|
+
|
|
6
|
+
export function rootContainer(container: React.ReactNode) {
|
|
7
|
+
return React.createElement(
|
|
8
|
+
Provider,
|
|
9
|
+
null,
|
|
10
|
+
container,
|
|
11
|
+
);
|
|
12
|
+
}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import { useState, useEffect, useContext, useRef } from 'react';
|
|
3
|
+
// @ts-ignore
|
|
4
|
+
import isEqual from '/Users/huarui/work/module-menu/node_modules/@umijs/plugin-model/node_modules/fast-deep-equal/index.js';
|
|
5
|
+
// @ts-ignore
|
|
6
|
+
import { UmiContext } from './helpers/constant';
|
|
7
|
+
import { Model, models } from './Provider';
|
|
8
|
+
|
|
9
|
+
export type Models<T extends keyof typeof models> = Model<T>[T]
|
|
10
|
+
|
|
11
|
+
export function useModel<T extends keyof Model<T>>(model: T): Model<T>[T]
|
|
12
|
+
export function useModel<T extends keyof Model<T>, U>(model: T, selector: (model: Model<T>[T]) => U): U
|
|
13
|
+
|
|
14
|
+
export function useModel<T extends keyof Model<T>, U>(
|
|
15
|
+
namespace: T,
|
|
16
|
+
updater?: (model: Model<T>[T]) => U
|
|
17
|
+
) : typeof updater extends undefined ? Model<T>[T] : ReturnType<NonNullable<typeof updater>>{
|
|
18
|
+
|
|
19
|
+
type RetState = typeof updater extends undefined ? Model<T>[T] : ReturnType<NonNullable<typeof updater>>
|
|
20
|
+
const dispatcher = useContext<any>(UmiContext);
|
|
21
|
+
const updaterRef = useRef(updater);
|
|
22
|
+
updaterRef.current = updater;
|
|
23
|
+
const [state, setState] = useState<RetState>(
|
|
24
|
+
() => updaterRef.current ? updaterRef.current(dispatcher.data![namespace]) : dispatcher.data![namespace]
|
|
25
|
+
);
|
|
26
|
+
const stateRef = useRef<any>(state);
|
|
27
|
+
stateRef.current = state;
|
|
28
|
+
|
|
29
|
+
const isMount = useRef(false);
|
|
30
|
+
useEffect(() => {
|
|
31
|
+
isMount.current = true;
|
|
32
|
+
return () => {
|
|
33
|
+
isMount.current = false;
|
|
34
|
+
}
|
|
35
|
+
}, [])
|
|
36
|
+
|
|
37
|
+
useEffect(() => {
|
|
38
|
+
const handler = (e: any) => {
|
|
39
|
+
if(!isMount.current) {
|
|
40
|
+
// 如果 handler 执行过程中,组件被卸载了,则强制更新全局 data
|
|
41
|
+
setTimeout(() => {
|
|
42
|
+
dispatcher.data![namespace] = e;
|
|
43
|
+
dispatcher.update(namespace);
|
|
44
|
+
});
|
|
45
|
+
} else {
|
|
46
|
+
if(updater && updaterRef.current){
|
|
47
|
+
const currentState = updaterRef.current(e);
|
|
48
|
+
const previousState = stateRef.current
|
|
49
|
+
if(!isEqual(currentState, previousState)){
|
|
50
|
+
setState(currentState);
|
|
51
|
+
}
|
|
52
|
+
} else {
|
|
53
|
+
setState(e);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
try {
|
|
58
|
+
dispatcher.callbacks![namespace]!.add(handler);
|
|
59
|
+
dispatcher.update(namespace);
|
|
60
|
+
} catch (e) {
|
|
61
|
+
dispatcher.callbacks![namespace] = new Set();
|
|
62
|
+
dispatcher.callbacks![namespace]!.add(handler);
|
|
63
|
+
dispatcher.update(namespace);
|
|
64
|
+
}
|
|
65
|
+
return () => {
|
|
66
|
+
dispatcher.callbacks![namespace]!.delete(handler);
|
|
67
|
+
}
|
|
68
|
+
}, [namespace]);
|
|
69
|
+
|
|
70
|
+
return state;
|
|
71
|
+
};
|