zmp-cli 3.15.7 → 3.15.9

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 (184) hide show
  1. package/README.md +97 -1
  2. package/build/index.js +1 -1
  3. package/config/index.js +1 -1
  4. package/create/index.js +1 -1
  5. package/create/utils/generate-app-config.js +1 -1
  6. package/create/utils/generate-npm-scripts.js +1 -1
  7. package/create/utils/get-options.js +1 -1
  8. package/create/utils/npm-scripts.js +1 -1
  9. package/deploy/index.js +1 -1
  10. package/deploy/utils/get-options.js +1 -1
  11. package/deploy/utils/request-upload.js +1 -1
  12. package/deploy/utils/upload-app.js +1 -1
  13. package/index.js +1 -1
  14. package/login/index.js +1 -1
  15. package/login/utils/get-options.js +1 -1
  16. package/login/utils/zalo-login.js +1 -1
  17. package/migrate/icons/update-icon-v3.js +1 -1
  18. package/migrate/index.js +1 -1
  19. package/migrate/utils/get-options.js +1 -1
  20. package/migrate/utils/migrate-react.js +1 -1
  21. package/package.json +3 -2
  22. package/start/frame/index.html +264 -254
  23. package/start/index.js +1 -1
  24. package/sync/index-to-app-config.js +1 -1
  25. package/sync/index.js +1 -1
  26. package/utils/axios.js +1 -1
  27. package/utils/check-update.js +1 -1
  28. package/utils/constants.js +1 -1
  29. package/utils/env.js +1 -1
  30. package/utils/error.js +1 -1
  31. package/utils/find-files-by-ext.js +1 -1
  32. package/utils/find-free-port.js +1 -1
  33. package/utils/fs-extra.js +1 -1
  34. package/utils/generate-pages-map.js +1 -1
  35. package/utils/get-app-info.js +1 -1
  36. package/utils/get-current-project.js +1 -1
  37. package/utils/get-ip.js +1 -1
  38. package/utils/log.js +1 -1
  39. package/utils/node-blob.js +1 -1
  40. package/utils/resumable.d.js +1 -1
  41. package/utils/resumable.js +1 -1
  42. package/utils/spinner.js +1 -1
  43. package/utils/tunnel.js +1 -1
  44. package/create/init-zmp-ui.js +0 -1
  45. package/create/templates/app-parameters.js +0 -17
  46. package/create/templates/common/css/icons.css +0 -60
  47. package/create/templates/common/icons/512x512.png +0 -0
  48. package/create/templates/common/icons/apple-touch-icon.png +0 -0
  49. package/create/templates/common/icons/favicon.png +0 -0
  50. package/create/templates/common/postcss.config.js +0 -5
  51. package/create/templates/common/splash-2732x2732.png +0 -0
  52. package/create/templates/common/tailwind/postcss.config.js +0 -5
  53. package/create/templates/common/tailwind/tailwind.config.js +0 -9
  54. package/create/templates/common/tailwind/tailwind.css +0 -3
  55. package/create/templates/common/webpack/build.js +0 -3
  56. package/create/templates/copy-assets.js +0 -1
  57. package/create/templates/core/babel.config.js +0 -11
  58. package/create/templates/core/copy-assets.js +0 -15
  59. package/create/templates/core/generate-home-page.js +0 -121
  60. package/create/templates/core/generate-root.js +0 -248
  61. package/create/templates/core/generate-routes.js +0 -129
  62. package/create/templates/core/generate-scripts.js +0 -45
  63. package/create/templates/core/pages/404.html +0 -20
  64. package/create/templates/core/pages/about.html +0 -26
  65. package/create/templates/core/pages/catalog.html +0 -40
  66. package/create/templates/core/pages/dynamic-route.html +0 -115
  67. package/create/templates/core/pages/form.html +0 -258
  68. package/create/templates/core/pages/left-page-1.html +0 -24
  69. package/create/templates/core/pages/left-page-2.html +0 -23
  70. package/create/templates/core/pages/product.html +0 -36
  71. package/create/templates/core/pages/request-and-load.html +0 -35
  72. package/create/templates/core/pages/settings.html +0 -252
  73. package/create/templates/create-folders.js +0 -1
  74. package/create/templates/generate-config-xml.js +0 -11
  75. package/create/templates/generate-index.js +0 -24
  76. package/create/templates/generate-manifest.js +0 -1
  77. package/create/templates/generate-recoil.js +0 -44
  78. package/create/templates/generate-routes.js +0 -1
  79. package/create/templates/generate-scripts.js +0 -1
  80. package/create/templates/generate-service-worker.js +0 -120
  81. package/create/templates/generate-store.js +0 -77
  82. package/create/templates/generate-styles.js +0 -56
  83. package/create/templates/generate-webpack-config.js +0 -253
  84. package/create/templates/generate-zmp-custom.js +0 -23
  85. package/create/templates/react/babel.config.js +0 -12
  86. package/create/templates/react/components/app-items.jsx +0 -44
  87. package/create/templates/react/components/navbar-back.jsx +0 -25
  88. package/create/templates/react/components/user-card.jsx +0 -18
  89. package/create/templates/react/copy-assets.js +0 -1
  90. package/create/templates/react/generate-home-page.js +0 -81
  91. package/create/templates/react/generate-root.js +0 -55
  92. package/create/templates/react/generate-routes.js +0 -1
  93. package/create/templates/react/generate-scripts.js +0 -42
  94. package/create/templates/react/pages/404.js +0 -19
  95. package/create/templates/react/pages/about.js +0 -44
  96. package/create/templates/react/pages/catalog.js +0 -98
  97. package/create/templates/react/pages/dynamic-route.js +0 -72
  98. package/create/templates/react/pages/form.js +0 -132
  99. package/create/templates/react/pages/index copy.js +0 -1
  100. package/create/templates/react/pages/index.js +0 -1
  101. package/create/templates/react/pages/settings.js +0 -62
  102. package/create/templates/react/pages/user.js +0 -37
  103. package/create/templates/react/vite.config.js +0 -11
  104. package/create/templates/react-typescript/_tsconfig.json +0 -33
  105. package/create/templates/react-typescript/components/app-items.js +0 -46
  106. package/create/templates/react-typescript/components/index.js +0 -1
  107. package/create/templates/react-typescript/components/navbar-back.js +0 -33
  108. package/create/templates/react-typescript/components/user-card.js +0 -25
  109. package/create/templates/react-typescript/copy-assets.js +0 -1
  110. package/create/templates/react-typescript/generate-home-page.js +0 -81
  111. package/create/templates/react-typescript/generate-root.js +0 -50
  112. package/create/templates/react-typescript/generate-routes.js +0 -1
  113. package/create/templates/react-typescript/generate-scripts.js +0 -42
  114. package/create/templates/react-typescript/pages/404.js +0 -19
  115. package/create/templates/react-typescript/pages/about.js +0 -44
  116. package/create/templates/react-typescript/pages/catalog.js +0 -98
  117. package/create/templates/react-typescript/pages/dynamic-route.js +0 -72
  118. package/create/templates/react-typescript/pages/form.js +0 -132
  119. package/create/templates/react-typescript/pages/index.js +0 -1
  120. package/create/templates/react-typescript/pages/settings.js +0 -62
  121. package/create/templates/react-typescript/pages/user.js +0 -37
  122. package/create/templates/react-typescript/vite.config.js +0 -21
  123. package/create/templates/svelte/babel.config.js +0 -10
  124. package/create/templates/svelte/copy-assets.js +0 -1
  125. package/create/templates/svelte/generate-home-page.js +0 -122
  126. package/create/templates/svelte/generate-root.js +0 -177
  127. package/create/templates/svelte/generate-routes.js +0 -76
  128. package/create/templates/svelte/generate-scripts.js +0 -31
  129. package/create/templates/svelte/pages/404.svelte +0 -10
  130. package/create/templates/svelte/pages/about.svelte +0 -16
  131. package/create/templates/svelte/pages/catalog.svelte +0 -31
  132. package/create/templates/svelte/pages/dynamic-route.svelte +0 -34
  133. package/create/templates/svelte/pages/form.svelte +0 -175
  134. package/create/templates/svelte/pages/left-page-1.svelte +0 -13
  135. package/create/templates/svelte/pages/left-page-2.svelte +0 -12
  136. package/create/templates/svelte/pages/product.svelte +0 -21
  137. package/create/templates/svelte/pages/request-and-load.svelte +0 -21
  138. package/create/templates/svelte/pages/settings.svelte +0 -175
  139. package/create/templates/vue/babel.config.js +0 -10
  140. package/create/templates/vue/components/header.vue +0 -28
  141. package/create/templates/vue/components/sun-and-moon.vue +0 -34
  142. package/create/templates/vue/copy-assets.js +0 -1
  143. package/create/templates/vue/generate-home-page.js +0 -50
  144. package/create/templates/vue/generate-root.js +0 -40
  145. package/create/templates/vue/generate-routes.js +0 -1
  146. package/create/templates/vue/generate-scripts.js +0 -46
  147. package/create/templates/vue/global-components.d.js +0 -1
  148. package/create/templates/vue/global-components.d.ts +0 -121
  149. package/create/templates/vue/icons/moon.svg +0 -3
  150. package/create/templates/vue/icons/sun.svg +0 -3
  151. package/create/templates/vue/pages/404.vue +0 -12
  152. package/create/templates/vue/pages/about.vue +0 -15
  153. package/create/templates/vue/pages/catalog.vue +0 -39
  154. package/create/templates/vue/pages/dynamic-route.vue +0 -34
  155. package/create/templates/vue/pages/form.vue +0 -162
  156. package/create/templates/vue/pages/left-page-1.vue +0 -14
  157. package/create/templates/vue/pages/left-page-2.vue +0 -11
  158. package/create/templates/vue/pages/product.vue +0 -31
  159. package/create/templates/vue/pages/request-and-load.vue +0 -25
  160. package/create/templates/vue/pages/settings.vue +0 -18
  161. package/create/templates/vue/vite.config.js +0 -11
  162. package/create/templates/zaui/_tsconfig.json +0 -33
  163. package/create/templates/zaui/babel.config.js +0 -12
  164. package/create/templates/zaui/components/user-card.jsx +0 -16
  165. package/create/templates/zaui/copy-assets.js +0 -1
  166. package/create/templates/zaui/generate-home-page.js +0 -91
  167. package/create/templates/zaui/generate-root.js +0 -33
  168. package/create/templates/zaui/generate-routes.js +0 -1
  169. package/create/templates/zaui/generate-scripts.js +0 -25
  170. package/create/templates/zaui/generate-user-card.js +0 -40
  171. package/create/templates/zaui/pages/about.js +0 -112
  172. package/create/templates/zaui/pages/form.js +0 -106
  173. package/create/templates/zaui/pages/index.js +0 -1
  174. package/create/templates/zaui/pages/user.js +0 -92
  175. package/create/templates/zaui/vite.config.js +0 -11
  176. package/create/utils/colors.js +0 -1
  177. package/create/utils/generate-gitignore.js +0 -1
  178. package/create/utils/generate-package-json.js +0 -1
  179. package/create/utils/generate-readme.js +0 -1
  180. package/create/utils/indent.js +0 -1
  181. package/create/utils/string.js +0 -1
  182. package/create/utils/styles-extension.js +0 -1
  183. package/create/utils/template-if.js +0 -1
  184. package/start/generate-hr-config.js +0 -1
@@ -1,91 +0,0 @@
1
- "use strict";const{projectFramework:e}=require("../../../utils/constants"),t=require("../../utils/indent");module.exports=i=>{let{name:r,template:a,framework:o,stateManagement:s}=i;return o===e.REACT_TYPESCRIPT?t(0,`
2
- import React from 'react';
3
- ${"blank"===a?`
4
- import { Page } from 'zmp-ui';
5
- `.trim():`
6
- import {
7
- List,
8
- Page,
9
- Icon,
10
- useNavigate
11
- } from 'zmp-ui';${"recoil"===s?`
12
- import { useRecoilValue } from 'recoil';
13
- import { userInfo } from "zmp-sdk";
14
- import { userState } from '../state';`:""}
15
- ${"blank"!==a?`
16
- import UserCard from '../components/user-card';
17
- `:""}
18
- `.trim()}
19
-
20
- const HomePage:React.FunctionComponent = () => {
21
- ${"blank"!==a?"recoil"===s?"const user = useRecoilValue<userInfo>(userState);":"const user = useStore('user');":""}
22
- ${"blank"!==a?"const navigate = useNavigate()":""}
23
- return (
24
- ${"blank"===a?`<Page className="page">
25
- Hello Zalo Mini App
26
- </Page> `.trim():`
27
- <Page className="page">
28
- <div className="section-container">
29
- <UserCard user={user}/>
30
- </div>
31
- <div className="section-container">
32
- <List >
33
- <List.Item suffix={<Icon icon="zi-arrow-right"/>}>
34
- <div onClick={()=>navigate('/about')}>About</div>
35
- </List.Item>
36
- <List.Item suffix={<Icon icon="zi-arrow-right"/>}>
37
- <div onClick={()=>navigate('/user')}>User</div>
38
- </List.Item>
39
- </List>
40
- </div>
41
- </Page>`.trim()}
42
- );
43
- }
44
-
45
- export default HomePage;
46
- `).trim():t(0,`
47
- import React from 'react';
48
- ${"blank"===a?`
49
- import {
50
- Page
51
- } from 'zmp-ui';
52
- `.trim():`
53
- import {
54
- List,
55
- Page,
56
- Icon,useNavigate
57
- } from 'zmp-ui';${"recoil"===s?`
58
- import { useRecoilValue } from 'recoil';
59
- import { userState } from '../state';`:""}
60
- ${"blank"!==a?`
61
- import UserCard from '../components/user-card';
62
- `:""}
63
- `.trim()}
64
-
65
- const HomePage = () => {
66
- ${"blank"!==a?"recoil"===s?"const user = useRecoilValue(userState);":"const user = useStore('user');":""}
67
- ${"blank"!==a?"const navigate = useNavigate()":""}
68
- return (
69
- ${"blank"===a?`<Page className="page">
70
- Hello Zalo Mini App
71
- </Page> `.trim():`
72
- <Page className="page">
73
- <div className="section-container">
74
- <UserCard user={user}/>
75
- </div>
76
- <div className="section-container">
77
- <List >
78
- <List.Item suffix={<Icon icon="zi-arrow-right"/>}>
79
- <div onClick={()=>navigate('/about')}>About</div>
80
- </List.Item>
81
- <List.Item suffix={<Icon icon="zi-arrow-right"/>}>
82
- <div onClick={()=>navigate('/user')}>User</div>
83
- </List.Item>
84
- </List>
85
- </div>
86
- </Page>`.trim()}
87
- );
88
- }
89
-
90
- export default HomePage;
91
- `).trim()};
@@ -1,33 +0,0 @@
1
- "use strict";const e=require("../../utils/template-if"),r=require("../../utils/indent"),{capitalize:t}=require("../../utils/string");module.exports=o=>{let{template:i,theming:m,stateManagement:u}=o,a=[];return"single-view"===i&&a.push("about","form","user"),r(0,`
2
- import React from 'react';
3
- import { Route} from 'react-router-dom'
4
- ${["blank","single-view"].indexOf(i)>=0?`
5
- import { App, ZMPRouter, AnimationRoutes, SnackbarProvider } from 'zmp-ui';
6
- `.trim():""}
7
- ${e("recoil"===u,()=>"import { RecoilRoot } from 'recoil';","")}
8
- import HomePage from '../pages';
9
- ${a.length>0?a.map(e=>` import ${t(e)} from '../pages/${e}';
10
- `).join("").trim():""}
11
-
12
-
13
- const MyApp = () => {
14
- ${`
15
- return (${"recoil"===u?`
16
- <RecoilRoot>`:""}
17
- ${r("recoil"===u?2:0,`<App ${m.darkTheme?"themeDark":""}>`)}
18
- <SnackbarProvider>
19
- <ZMPRouter>
20
- <AnimationRoutes>
21
- <Route path="/" element={<HomePage></HomePage>}></Route>
22
- ${a.length>0?a.map(e=>{let r=t(e);return` <Route path="/${e}" element={<${r}></${r}>}></Route>
23
- `}).join("").trim():""}
24
- </AnimationRoutes>
25
- </ZMPRouter>
26
- </SnackbarProvider>
27
- ${r("recoil"===u?2:0,"</App>")}${"recoil"===u?`
28
- </RecoilRoot>`:""}
29
- );
30
- `.trim()}
31
- }
32
- export default MyApp;
33
- `).trim()};
@@ -1 +0,0 @@
1
- "use strict";module.exports=e=>{let{template:r}=e;return"blank"===r?[]:["/user","/form","/dynamic-route","/about","/404"]};
@@ -1,25 +0,0 @@
1
- "use strict";const t=require("../../utils/indent"),e=require("../../utils/styles-extension");module.exports=o=>{let{cssPreProcessor:p,includeTailwind:r,framework:i}=o,n="";return(n+=t(0,`
2
- // Import React and ReactDOM
3
- import React from 'react';
4
- import { createRoot } from 'react-dom/client';
5
- ${r?`
6
-
7
- // Import tailwind styles
8
- import './css/tailwind.css';`:""}
9
-
10
- import 'zmp-ui/zaui.css';
11
-
12
- import './css/app.${e(p)}';
13
-
14
- // Import App Component
15
- import App from './components/app';
16
- import appConfig from '../app-config.json';
17
-
18
- if (!window.APP_CONFIG) {
19
- window.APP_CONFIG = appConfig;
20
- }
21
-
22
- // Mount React App
23
- ${"react-typescript"===i?"const root = createRoot(document.getElementById('app')!);":"const root = createRoot(document.getElementById('app'));"}
24
- root.render(React.createElement(App));
25
- `)).trim()};
@@ -1,40 +0,0 @@
1
- "use strict";const r=require("../../utils/indent"),{projectFramework:t}=require("../../../utils/constants");module.exports=e=>{let{framework:a}=e;return a===t.REACT_TYPESCRIPT?r(0,`
2
- import React from 'react';
3
- import { Avatar, Box, Text } from 'zmp-ui';
4
- import { userInfo } from 'zmp-sdk';
5
-
6
- interface UserProps{
7
- user: userInfo
8
- }
9
-
10
- const UserCard: React.FunctionComponent<UserProps> = ({ user }) => {
11
- return (
12
- <Box flex>
13
- <Avatar story='default' online src={user.avatar.startsWith('http') ? user.avatar : undefined}>{user.avatar}</Avatar>
14
- <Box ml={4}>
15
- <Text.Title>{user.name}</Text.Title>
16
- <Text>{user.id}</Text>
17
- </Box>
18
- </Box>
19
- )
20
- };
21
-
22
- export default UserCard;
23
- `).trim():r(0,`
24
- import React from 'react';
25
- import { Avatar, Box, Text } from 'zmp-ui';
26
-
27
- const UserCard = ({ user }) => {
28
- return (
29
- <Box flex>
30
- <Avatar story='default' online src={user.avatar.startsWith('http') ? user.avatar : null}>{user.avatar}</Avatar>
31
- <Box ml={4}>
32
- <Text.Title>{user.name}</Text.Title>
33
- <Text>{user.id}</Text>
34
- </Box>
35
- </Box>
36
- )
37
- };
38
-
39
- export default UserCard;
40
- `).trim()};
@@ -1,112 +0,0 @@
1
- "use strict";const e=require("../../../utils/indent"),{projectFramework:t}=require("../../../../utils/constants");module.exports=n=>{let{framework:o}=n;return o===t.REACT_TYPESCRIPT?e(0,`
2
- import React from "react";
3
- import { Sheet, Button, Page, Text, useNavigate } from "zmp-ui";
4
-
5
- const AboutPage: React.FunctionComponent = (props) => {
6
- const [actionSheetOpened, setActionSheetOpened] = React.useState(false);
7
- const navigate = useNavigate()
8
- return (
9
- <Page className="page">
10
- <div className="section-container">
11
- <Text>This mini app was generated by zmp-cli</Text>
12
- </div>
13
- <div>
14
- <Button
15
- variant='secondary'
16
- fullWidth
17
- onClick={() => setActionSheetOpened(true)}
18
- >
19
- Back
20
- </Button>
21
- </div>
22
- <Sheet.Actions
23
- visible={actionSheetOpened}
24
- onClose={() => setActionSheetOpened(false)}
25
- actions={[
26
- [
27
- {
28
- text: "Go back",
29
- onClick: () => {
30
- navigate(-1);
31
- },
32
- },
33
- {
34
- text: "Action 1",
35
- close: true,
36
- },
37
- {
38
- text: "Action 2",
39
- close: true,
40
- },
41
- ],
42
- [
43
- {
44
- text: "Close",
45
- close: true,
46
- danger: true,
47
- },
48
- ],
49
- ]}
50
- ></Sheet.Actions>
51
- </Page>
52
- );
53
- };
54
-
55
- export default AboutPage;
56
- `).trim():e(0,`
57
- import React from "react";
58
- import { Sheet, Button, Page, Text, useNavigate } from "zmp-ui";
59
-
60
- const AboutPage = (props) => {
61
- const [actionSheetOpened, setActionSheetOpened] = React.useState(false);
62
- const navigate = useNavigate()
63
- return (
64
- <Page className="page">
65
- <div className="section-container">
66
- <Text>This mini app was generated by zmp-cli</Text>
67
- </div>
68
- <div>
69
- <Button
70
- variant='secondary'
71
- fullWidth
72
- onClick={() => setActionSheetOpened(true)}
73
- >
74
- Back
75
- </Button>
76
- </div>
77
- <Sheet.Actions
78
- visible={actionSheetOpened}
79
- onClose={() => setActionSheetOpened(false)}
80
- actions={[
81
- [
82
- {
83
- text: "Go back",
84
- onClick: () => {
85
- navigate(-1);
86
- },
87
- },
88
- {
89
- text: "Action 1",
90
- close: true,
91
- },
92
- {
93
- text: "Action 2",
94
- close: true,
95
- },
96
- ],
97
- [
98
- {
99
- text: "Close",
100
- close: true,
101
- danger: true,
102
- },
103
- ],
104
- ]}
105
- ></Sheet.Actions>
106
- </Page>
107
- );
108
- };
109
-
110
- export default AboutPage;
111
-
112
- `).trim()};
@@ -1,106 +0,0 @@
1
- "use strict";const e=require("../../../utils/indent"),{projectFramework:t}=require("../../../../utils/constants");module.exports=a=>{let{framework:r}=a;return r===t.REACT_TYPESCRIPT?e(0,`
2
- import React from 'react';
3
- import { Button, Input, Box, Page, useSnackbar } from 'zmp-ui';
4
- import { useRecoilState } from 'recoil';
5
- import { userInfo } from 'zmp-sdk';
6
- import { userState } from '../state';
7
-
8
- type UserForm = Omit<userInfo, "id">
9
-
10
- const FormPage: React.FunctionComponent = () => {
11
- const [user, setUser] = useRecoilState<userInfo>(userState)
12
- const [form, setForm] = React.useState<UserForm>({ name: user.name, avatar: user.avatar, birthday: user.birthday, gender: user.gender });
13
- const snackbar = useSnackbar()
14
-
15
- const handleChangeInput = (field, value) => {
16
- setForm({ ...form, [field]: value })
17
- }
18
-
19
- const handleSubmit = () => {
20
- snackbar.openSnackbar({duration: 3000, text: 'saved', type: 'success'});
21
- setUser((user) => ({ ...user, ...form }));
22
- }
23
-
24
- return (
25
- <Page className="page">
26
- <div className='section-container'>
27
- <Box >
28
- <Input
29
- id="name"
30
- label="Name"
31
- type="text"
32
- placeholder="Zalo"
33
- value={form?.name}
34
- onChange={(e) => handleChangeInput('name', e.target.value)}
35
- />
36
- <Input
37
- label="Avatar"
38
- type="text"
39
- placeholder="zalo@zalo.me"
40
- value={form?.avatar}
41
- onChange={(e) => handleChangeInput('avatar', e.target.value)}
42
- />
43
- <Box mt={4}>
44
- <Button fullWidth variant='primary' onClick={handleSubmit}>
45
- Submit
46
- </Button>
47
- </Box>
48
- </Box>
49
- </div>
50
- </Page>
51
- )
52
- }
53
-
54
- export default FormPage;
55
- `).trim():e(0,`
56
- import React from 'react';
57
- import { Button,Input, Box, Page, useSnackbar } from 'zmp-ui';
58
- import { useRecoilState } from 'recoil';
59
- import { userState } from '../state';
60
-
61
- const FormPage = () => {
62
- const [user, setUser] = useRecoilState(userState)
63
- const [form, setForm] = React.useState({ ...user });
64
- const snackbar = useSnackbar()
65
-
66
- const handleChangeInput = (field, value) => {
67
- setForm({ ...form, [field]: value })
68
- }
69
-
70
- const handleSubmit = () => {
71
- snackbar.openSnackbar({duration: 3000, text: 'saved', type: 'success'})
72
- setUser(form);
73
- }
74
-
75
- return (
76
- <Page className="page">
77
- <div className='section-container'>
78
- <Box >
79
- <Input
80
- id="name"
81
- label="Name"
82
- type="text"
83
- placeholder="Zalo"
84
- value={form?.name}
85
- onChange={(e) => handleChangeInput('name', e.target.value)}
86
- />
87
- <Input
88
- label="Avatar"
89
- type="text"
90
- placeholder="zalo@zalo.me"
91
- value={form?.avatar}
92
- onChange={(e) => handleChangeInput('avatar', e.target.value)}
93
- />
94
- <Box mt={4}>
95
- <Button fullWidth variant='primary' onClick={handleSubmit}>
96
- Submit
97
- </Button>
98
- </Box>
99
- </Box>
100
- </div>
101
- </Page>
102
- )
103
- }
104
-
105
- export default FormPage;
106
- `).trim()};
@@ -1 +0,0 @@
1
- "use strict";const e=require("./user"),r=require("./form"),u=require("./about");module.exports={copyUser:e,copyForm:r,copyAbout:u};
@@ -1,92 +0,0 @@
1
- "use strict";const e=require("../../../utils/indent"),{projectFramework:t}=require("../../../../utils/constants");module.exports=a=>{let{framework:i}=a;return i===t.REACT_TYPESCRIPT?e(0,`
2
- import React from "react";
3
- import { Avatar, List, Text, Box, Page, Button, Icon, useNavigate } from "zmp-ui";
4
- import { useRecoilValue } from "recoil";
5
- import { userState } from "../state";
6
- import { userInfo } from "zmp-sdk";
7
-
8
- const UserPage = () => {
9
- const user = useRecoilValue<userInfo>(userState);
10
- const navigate = useNavigate()
11
- return (
12
- <Page className="page">
13
- <Box flex flexDirection="column" justifyContent="center" alignItems="center">
14
- <Box>
15
- <Avatar
16
- story='default'
17
- size={96}
18
- online
19
- src={user.avatar.startsWith("http") ? user.avatar : undefined}
20
- >
21
- {user.avatar}
22
- </Avatar>
23
- </Box>
24
- <Box flex flexDirection="row" alignItems="center" ml={8}>
25
- <Box>
26
- <Text.Title >{user.name}</Text.Title>
27
- </Box>
28
- <Box ml={4}>
29
- <Button onClick={()=>{navigate('/form')}} size='small' icon={<Icon icon="zi-edit"/>}/>
30
- </Box>
31
- </Box>
32
- </Box>
33
- <Box m={0} p={0} mt={4}>
34
- <div className="section-container">
35
- <List>
36
- <List.Item title="Display name" subTitle={user.name} />
37
- <List.Item title="ID" subTitle={user.id} />
38
- </List>
39
- </div>
40
- </Box>
41
-
42
- </Page>
43
- );
44
- };
45
-
46
- export default UserPage;
47
- `).trim():e(0,`
48
- import React from "react";
49
- import { Avatar, List, Text, Box, Page, Button, Icon, useNavigate } from "zmp-ui";
50
- import { useRecoilValue } from "recoil";
51
- import { userState } from "../state";
52
-
53
- const UserPage = () => {
54
- const user = useRecoilValue(userState);
55
- const navigate = useNavigate()
56
- return (
57
- <Page className="page">
58
- <Box flex flexDirection="column" justifyContent="center" alignItems="center">
59
- <Box>
60
- <Avatar
61
- story
62
- size={96}
63
- online
64
- src={user.avatar.startsWith("http") ? user.avatar : null}
65
- >
66
- {user.avatar}
67
- </Avatar>
68
- </Box>
69
- <Box flex flexDirection="row" alignItems="center" ml={8}>
70
- <Box>
71
- <Text.Title >{user.name}</Text.Title>
72
- </Box>
73
- <Box ml={4}>
74
- <Button onClick={()=>{navigate('/form')}} size='small' icon={<Icon icon="zi-edit"/>}/>
75
- </Box>
76
- </Box>
77
- </Box>
78
- <Box m={0} p={0} mt={4}>
79
- <div className="section-container">
80
- <List>
81
- <List.Item title="Display name" subTitle={user.name} />
82
- <List.Item title="ID" subTitle={user.id} />
83
- </List>
84
- </div>
85
- </Box>
86
-
87
- </Page>
88
- );
89
- };
90
-
91
- export default UserPage;
92
- `).trim()};
@@ -1,11 +0,0 @@
1
- import { defineConfig } from 'vite'
2
- import reactRefresh from '@vitejs/plugin-react-refresh'
3
-
4
- // https://vitejs.dev/config/
5
- export default () => {
6
- return defineConfig({
7
- root: './src',
8
- base: '',
9
- plugins: [reactRefresh()],
10
- })
11
- }
@@ -1 +0,0 @@
1
- 'use strict';const _0x307902=_0x50ab;(function(_0xd90c6b,_0x5c32cf){const _0x4bdec3=_0x50ab,_0x47c88f=_0xd90c6b();while(!![]){try{const _0x533694=parseInt(_0x4bdec3(0xc6))/0x1*(parseInt(_0x4bdec3(0xc9))/0x2)+parseInt(_0x4bdec3(0xce))/0x3*(-parseInt(_0x4bdec3(0xcd))/0x4)+parseInt(_0x4bdec3(0xd2))/0x5*(-parseInt(_0x4bdec3(0xd9))/0x6)+-parseInt(_0x4bdec3(0xcb))/0x7+-parseInt(_0x4bdec3(0xd3))/0x8*(parseInt(_0x4bdec3(0xcc))/0x9)+-parseInt(_0x4bdec3(0xdc))/0xa+-parseInt(_0x4bdec3(0xc4))/0xb*(-parseInt(_0x4bdec3(0xd1))/0xc);if(_0x533694===_0x5c32cf)break;else _0x47c88f['push'](_0x47c88f['shift']());}catch(_0x448ee7){_0x47c88f['push'](_0x47c88f['shift']());}}}(_0x1934,0xe8ff0));function e(_0x4f0570){const _0xa7ba8b=_0x50ab;let _0x5d5ac5=_0x4f0570[_0xa7ba8b(0xc7)](/^#?([a-f\d])([a-f\d])([a-f\d])$/i,(_0x490c64,_0x16424b,_0x5b2060,_0x5073cf)=>_0x16424b+_0x16424b+_0x5b2060+_0x5b2060+_0x5073cf+_0x5073cf),_0x2090dd=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i[_0xa7ba8b(0xdb)](_0x5d5ac5);return _0x2090dd?_0x2090dd['slice'](0x1)['map'](_0x2f318e=>parseInt(_0x2f318e,0x10)):null;}function _0x1934(){const _0x414c39=['var(--zmp-theme-color)','24oxVLbW','max','exec','16713920aDDcPa','isNaN','3724391hYGLsn','min','2deVIWi','replace','round','1504686qyiNdw','length','10575229jigGcp','1773945GZheGb','3620LbmEyg','1245wpBQsw','abs','exports','204Gctxpb','1218190kWYOSv','72skxJEs','toString','join','map','var(--zmp-theme-color-shade)'];_0x1934=function(){return _0x414c39;};return _0x1934();}function o(_0x3db529,_0x5287b4,_0x953243){const _0x3806e6=_0x50ab;let _0x337dcb=[_0x3db529,_0x5287b4,_0x953243][_0x3806e6(0xd6)](_0x5c12fb=>{const _0xea9188=_0x3806e6;let _0x55fb9a=_0x5c12fb[_0xea9188(0xd4)](0x10);return 0x1===_0x55fb9a['length']?'0'+_0x55fb9a:_0x55fb9a;})['join']('');return'#'+_0x337dcb;}function t(_0x28c9c3,_0x582f6b,_0x47e73b){const _0x563226=_0x50ab;let _0x1cb975,_0x1a63e3=Math['max'](_0x28c9c3/=0xff,_0x582f6b/=0xff,_0x47e73b/=0xff),_0x232193=Math[_0x563226(0xc5)](_0x28c9c3,_0x582f6b,_0x47e73b),_0xf31fd9=_0x1a63e3-_0x232193;0x0===_0xf31fd9?_0x1cb975=0x0:_0x1a63e3===_0x28c9c3?_0x1cb975=(_0x582f6b-_0x47e73b)/_0xf31fd9%0x6:_0x1a63e3===_0x582f6b?_0x1cb975=(_0x47e73b-_0x28c9c3)/_0xf31fd9+0x2:_0x1a63e3===_0x47e73b&&(_0x1cb975=(_0x28c9c3-_0x582f6b)/_0xf31fd9+0x4);let _0x4695d6=(_0x232193+_0x1a63e3)/0x2;return[0x3c*_0x1cb975,0x0===_0xf31fd9?0x0:_0xf31fd9/(0x1-Math[_0x563226(0xcf)](0x2*_0x4695d6-0x1)),_0x4695d6];}function _0x50ab(_0x35a9dc,_0x278118){const _0x1934ef=_0x1934();return _0x50ab=function(_0x50ab4f,_0x4b1f41){_0x50ab4f=_0x50ab4f-0xc4;let _0x1498df=_0x1934ef[_0x50ab4f];return _0x1498df;},_0x50ab(_0x35a9dc,_0x278118);}function r(_0x224ea6,_0x59cf00,_0x4ebf60){const _0xea1888=_0x50ab;let _0x250703,_0x25b642=(0x1-Math[_0xea1888(0xcf)](0x2*_0x4ebf60-0x1))*_0x59cf00,_0xa19f0c=_0x224ea6/0x3c,_0x393541=_0x25b642*(0x1-Math['abs'](_0xa19f0c%0x2-0x1));Number[_0xea1888(0xdd)](_0x224ea6)||void 0x0===_0x224ea6?_0x250703=[0x0,0x0,0x0]:_0xa19f0c<=0x1?_0x250703=[_0x25b642,_0x393541,0x0]:_0xa19f0c<=0x2?_0x250703=[_0x393541,_0x25b642,0x0]:_0xa19f0c<=0x3?_0x250703=[0x0,_0x25b642,_0x393541]:_0xa19f0c<=0x4?_0x250703=[0x0,_0x393541,_0x25b642]:_0xa19f0c<=0x5?_0x250703=[_0x393541,0x0,_0x25b642]:_0xa19f0c<=0x6&&(_0x250703=[_0x25b642,0x0,_0x393541]);let _0x4e0ef9=_0x4ebf60-_0x25b642/0x2;return _0x250703[_0xea1888(0xd6)](_0x2acd3c=>Math[_0xea1888(0xda)](0x0,Math[_0xea1888(0xc5)](0xff,Math[_0xea1888(0xc8)](0xff*(_0x2acd3c+_0x4e0ef9)))));}module[_0x307902(0xd0)]={'colorHexToRgb':e,'colorHslToRgb':r,'colorRgbToHex':o,'colorRgbToHsl':t,'colorThemeCSSProperties':function(..._0x51f3bd){const _0x41fc22=_0x307902;let _0x414ebc,_0x12fae4;if(0x1===_0x51f3bd[_0x41fc22(0xca)]?([_0x414ebc]=_0x51f3bd,_0x12fae4=e(_0x414ebc)):0x3===_0x51f3bd[_0x41fc22(0xca)]&&(_0x414ebc=o(..._0x12fae4=_0x51f3bd)),!_0x12fae4)return{};let _0x9a65db=t(..._0x12fae4),_0x5321fd=[_0x9a65db[0x0],_0x9a65db[0x1],Math[_0x41fc22(0xda)](0x0,_0x9a65db[0x2]-0.08)],_0x2217b2=[_0x9a65db[0x0],_0x9a65db[0x1],Math[_0x41fc22(0xda)](0x0,_0x9a65db[0x2]+0.08)],_0x237851=o(...r(..._0x5321fd)),_0x58ce37=o(...r(..._0x2217b2)),_0x16569a=o(...r(_0x9a65db[0x0],_0x9a65db[0x1],Math[_0x41fc22(0xda)](0x0,_0x9a65db[0x2]+0.6)));return{'--zmp-theme-color':_0x414ebc,'--zmp-theme-color-rgb':_0x12fae4[_0x41fc22(0xd5)](',\x20'),'--zmp-theme-color-shade':_0x237851,'--zmp-theme-color-tint':_0x58ce37,'--zmp-checkbox-active-color-disabled':_0x41fc22(0xd7),'--zmp-radio-active-color-disabled':_0x41fc22(0xd7),'--zmp-toggle-active-color-disabled':'var(--zmp-theme-color-shade)','--zmp-picker-action-button-hover-bg-color':_0x41fc22(0xd7),'--zmp-button-pressed-bg-color-primary':_0x41fc22(0xd7),'\x20--zmp-button-bg-color-secondary':_0x16569a,'--zmp-button-pressed-bg-color-secondary':_0x16569a,'--zmp-button-pressed-color-secondary':'var(--zmp-theme-color)','--zmp-button-border-color-secondary':'var(--zmp-theme-color)','--zmp-tabbar-fill-link-active-color':_0x41fc22(0xd8),'--zmp-tabbar-fill-link-active-border-color':_0x41fc22(0xd8),'--zmp-fab-pressed-bg-color':_0x41fc22(0xd7)};}};
@@ -1 +0,0 @@
1
- 'use strict';var _0x44d735=_0x30d2;(function(_0xb6abe9,_0x1da4dc){var _0x332e31=_0x30d2,_0x34dfe6=_0xb6abe9();while(!![]){try{var _0x39940c=parseInt(_0x332e31(0xd7))/0x1+-parseInt(_0x332e31(0xd6))/0x2+parseInt(_0x332e31(0xe1))/0x3+-parseInt(_0x332e31(0xdd))/0x4*(-parseInt(_0x332e31(0xe0))/0x5)+parseInt(_0x332e31(0xdb))/0x6*(parseInt(_0x332e31(0xd9))/0x7)+parseInt(_0x332e31(0xd5))/0x8+parseInt(_0x332e31(0xdc))/0x9*(-parseInt(_0x332e31(0xda))/0xa);if(_0x39940c===_0x1da4dc)break;else _0x34dfe6['push'](_0x34dfe6['shift']());}catch(_0x296647){_0x34dfe6['push'](_0x34dfe6['shift']());}}}(_0x492f,0x83cff));function _0x492f(){var _0x1d8a1c=['523490ttdLhH','6153702XbUdoi','414HCdmYO','1752vhqefr','exports','./template-if','11075uoHYpG','2311500tkYlZF','6603056PeEQiD','2060700eCcjkP','386638omLCbt','\x0a#\x20Logs\x0alogs\x0a*.log\x0anpm-debug.log*\x0ayarn-debug.log*\x0ayarn-error.log*\x0a\x0a#\x20Runtime\x20data\x0apids\x0a*.pid\x0a*.seed\x0a*.pid.lock\x0a\x0a#\x20Dependency\x20directories\x0anode_modules/\x0a\x0a#\x20Optional\x20npm\x20cache\x20directory\x0a.npm\x0a\x0a#\x20Optional\x20eslint\x20cache\x0a.eslintcache\x0a\x0a#\x20Optional\x20REPL\x20history\x0a.node_repl_history\x0a\x0a#\x20Yarn\x20Integrity\x20file\x0a.yarn-integrity\x0a\x0a#\x20dotenv\x20environment\x20variables\x20file\x0a.env\x0a\x0a#\x20Misc\x0a.DS_Store\x0aThumbs.db\x0a\x0a#\x20Production\x20build\x0awww/\x0a','7xqRxXn'];_0x492f=function(){return _0x1d8a1c;};return _0x492f();}function _0x30d2(_0x4c35ee,_0x2b19fa){var _0x492f44=_0x492f();return _0x30d2=function(_0x30d2a4,_0x24a607){_0x30d2a4=_0x30d2a4-0xd5;var _0x3306d7=_0x492f44[_0x30d2a4];return _0x3306d7;},_0x30d2(_0x4c35ee,_0x2b19fa);}require(_0x44d735(0xdf)),module[_0x44d735(0xde)]=_0x2b77c4=>_0x44d735(0xd8);
@@ -1 +0,0 @@
1
- 'use strict';function _0xd020(_0xf72d51,_0x9756b0){const _0xb7a9c4=_0xb7a9();return _0xd020=function(_0xd020e1,_0x33e4d3){_0xd020e1=_0xd020e1-0x1f4;let _0x39e8ca=_0xb7a9c4[_0xd020e1];return _0x39e8ca;},_0xd020(_0xf72d51,_0x9756b0);}const _0x5a466a=_0xd020;function _0xb7a9(){const _0x226914=['react-router-dom','exports','1220fHwCxH','recoil','postcss-cli@^8','cross-env','zmp-framework','postcss@^8','swiper','1crLLfV','less','vue','postinstall','./generate-npm-scripts','1219799GnqpSr','1100LzGDkb','react-typescript','@vitejs/plugin-react-refresh','\x22,\x0a\x20\x20\x22private\x22:\x20true,\x0a\x20\x20\x22version\x22:\x20\x221.0.0\x22,\x0a\x20\x20\x22description\x22:\x20\x22','6774JVftHP','\x20&&\x20','@vue/compiler-sfc','core','join','stringify','script','25762ZVcYCV','name','stylus','@types/react','zmp-ui','\x0a{\x0a\x20\x20\x22name\x22:\x20\x22','react-dom','@types/react-router-dom','vite@2.6.14',',\x0a\x20\x20\x22dependencies\x22:\x20{},\x0a\x20\x20\x22devDependencies\x22:\x20{}\x0a}\x0a','length','1063376nwEhjJ','package','replace','@types/react-dom','4OSrzHG','sass','prop-types','1398951LvKIWG','vue@3','forEach','258728OXbWnv','push','react','731316pZGbJl'];_0xb7a9=function(){return _0x226914;};return _0xb7a9();}(function(_0x1a0df0,_0x5506a4){const _0x43c00f=_0xd020,_0x2fdbf2=_0x1a0df0();while(!![]){try{const _0x53c11f=parseInt(_0x43c00f(0x216))/0x1*(-parseInt(_0x43c00f(0x209))/0x2)+parseInt(_0x43c00f(0x20c))/0x3*(-parseInt(_0x43c00f(0x203))/0x4)+-parseInt(_0x43c00f(0x21c))/0x5*(parseInt(_0x43c00f(0x220))/0x6)+parseInt(_0x43c00f(0x21b))/0x7+parseInt(_0x43c00f(0x1ff))/0x8+parseInt(_0x43c00f(0x206))/0x9+-parseInt(_0x43c00f(0x20f))/0xa*(-parseInt(_0x43c00f(0x1f4))/0xb);if(_0x53c11f===_0x5506a4)break;else _0x2fdbf2['push'](_0x2fdbf2['shift']());}catch(_0x1b6b2b){_0x2fdbf2['push'](_0x2fdbf2['shift']());}}}(_0xb7a9,0x1ef6a));const e=require('./generate-npm-scripts'),{generateTailWindScripts:s}=require(_0x5a466a(0x21a));module[_0x5a466a(0x20e)]=function(_0x3fc912){const _0x3657da=_0x5a466a;let {name:_0x12fcd3,framework:_0x434a0b,cssPreProcessor:_0x39baeb,includeTailwind:_0x16735b,stateManagement:_0x475122}=_0x3fc912,_0x3635a9=_0x3657da(0x1f8)===_0x3fc912[_0x3657da(0x200)]?[_0x3657da(0x1f8),'zmp-sdk',_0x3657da(0x20d)]:[_0x3657da(0x213),'zmp-sdk',_0x3657da(0x215)],_0x3187bd=[_0x3657da(0x20b),_0x3657da(0x1fa),_0x3657da(0x205)],_0x503322=['autoprefixer','tailwindcss',_0x3657da(0x214),_0x3657da(0x211)];_0x3657da(0x218)===_0x434a0b?_0x3635a9['push'](_0x3657da(0x207),_0x3657da(0x213)):(_0x3657da(0x20b)===_0x434a0b||_0x3657da(0x21d)===_0x434a0b)&&(_0x3635a9[_0x3657da(0x20a)](..._0x3187bd),'recoil'===_0x475122&&_0x3635a9['push'](_0x3657da(0x210)));let _0x85fa67=[_0x3657da(0x212),'postcss-preset-env@6.7.0',_0x3657da(0x1fc)];_0x3657da(0x21d)===_0x434a0b&&(_0x85fa67[_0x3657da(0x20a)](_0x3657da(0x1f7),_0x3657da(0x202)),_0x3657da(0x1f8)===_0x3fc912[_0x3657da(0x200)]&&_0x85fa67[_0x3657da(0x20a)](_0x3657da(0x1fb))),_0x3657da(0x1f6)===_0x39baeb?_0x85fa67['push'](_0x3657da(0x1f6)):_0x3657da(0x217)===_0x39baeb?_0x85fa67[_0x3657da(0x20a)]('less'):'scss'===_0x39baeb&&_0x85fa67['push'](_0x3657da(0x204));let _0x4bf425=[_0x3657da(0x21e)];_0x3657da(0x20b)===_0x434a0b||_0x3657da(0x21d)===_0x434a0b?_0x85fa67['push'](_0x4bf425,..._0x16735b?_0x503322:[]):_0x3657da(0x218)===_0x434a0b?_0x85fa67[_0x3657da(0x20a)]('@vitejs/plugin-vue@2.3.3',_0x3657da(0x222),..._0x16735b?_0x503322:[]):_0x3657da(0x223)===_0x434a0b&&_0x85fa67['push']('zmp-loader',..._0x16735b?_0x503322:[]),_0x3657da(0x1f8)===_0x3fc912[_0x3657da(0x200)]&&(_0x3635a9[_0x3657da(0x20a)]('recoil'),_0x3635a9['push'](..._0x3187bd),_0x85fa67[_0x3657da(0x20a)](_0x4bf425,..._0x16735b?_0x503322:[]));let _0x223e5c={};e()[_0x3657da(0x208)](_0x201624=>{const _0x3d7c85=_0x3657da;_0x223e5c[_0x201624[_0x3d7c85(0x1f5)]]=_0x201624['script'];}),_0x16735b&&s()[_0x3657da(0x208)](_0x31c588=>{const _0x169467=_0x3657da;_0x223e5c[_0x31c588[_0x169467(0x1f5)]]=_0x31c588[_0x169467(0x226)];});let _0x4ae491=[];return _0x4ae491[_0x3657da(0x1fe)]&&(_0x223e5c[_0x3657da(0x219)]=_0x4ae491[_0x3657da(0x224)](_0x3657da(0x221))),{'content':(_0x3657da(0x1f9)+_0x12fcd3['toLowerCase']()[_0x3657da(0x201)](/[ ]{2,}/,'\x20')[_0x3657da(0x201)](/ /g,'-')+_0x3657da(0x21f)+_0x12fcd3+'\x22,\x0a\x20\x20\x22repository\x22\x20:\x20\x22\x22,\x0a\x20\x20\x22license\x22\x20:\x20\x22UNLICENSED\x22,\x0a\x20\x20\x22browserslist\x22:\x20[\x0a\x20\x20\x20\x20\x22Android\x20>=\x205\x22,\x0a\x20\x20\x20\x20\x22IOS\x20>=\x209.3\x22,\x0a\x20\x20\x20\x20\x22Edge\x20>=\x2015\x22,\x0a\x20\x20\x20\x20\x22Safari\x20>=\x209.1\x22,\x0a\x20\x20\x20\x20\x22Chrome\x20>=\x2049\x22,\x0a\x20\x20\x20\x20\x22Firefox\x20>=\x2031\x22,\x0a\x20\x20\x20\x20\x22Samsung\x20>=\x205\x22\x0a\x20\x20],\x0a\x20\x20\x22scripts\x22\x20:\x20'+JSON[_0x3657da(0x225)](_0x223e5c)+_0x3657da(0x1fd))['trim'](),'dependencies':_0x3635a9,'devDependencies':_0x85fa67,'postInstall':_0x4ae491};};
@@ -1 +0,0 @@
1
- 'use strict';const _0x2dd897=_0x5591;(function(_0x3b2c35,_0x4b741e){const _0x4ea957=_0x5591,_0x259907=_0x3b2c35();while(!![]){try{const _0x1dae80=parseInt(_0x4ea957(0x10f))/0x1+parseInt(_0x4ea957(0x10d))/0x2+parseInt(_0x4ea957(0x10e))/0x3+-parseInt(_0x4ea957(0x113))/0x4+parseInt(_0x4ea957(0x10b))/0x5+-parseInt(_0x4ea957(0x10a))/0x6*(parseInt(_0x4ea957(0x114))/0x7)+parseInt(_0x4ea957(0x10c))/0x8*(-parseInt(_0x4ea957(0x109))/0x9);if(_0x1dae80===_0x4b741e)break;else _0x259907['push'](_0x259907['shift']());}catch(_0x10eedb){_0x259907['push'](_0x259907['shift']());}}}(_0x573c,0x819a6));function _0x5591(_0x355333,_0x58165b){const _0x573cfb=_0x573c();return _0x5591=function(_0x559148,_0x42e5df){_0x559148=_0x559148-0x107;let _0x549cb3=_0x573cfb[_0x559148];return _0x549cb3;},_0x5591(_0x355333,_0x58165b);}function _0x573c(){const _0x5bf889=['249578NaRfNz','\x0a```\x0a\x0a##\x20NPM\x20Scripts\x0a\x0a','description','icon','./generate-npm-scripts','trim','exports','replace','map','531gxQrel','54eGwbXE','1698810DENeRH','63864oPvOxE','102996leiqBt','2722848OIbESU','837690bBrXPu','name','\x0a\x0a#\x20','join','3255316thQQGc'];_0x573c=function(){return _0x5bf889;};return _0x573c();}const e=require(_0x2dd897(0x118));module[_0x2dd897(0x11a)]=_0x277362=>{const _0x368955=_0x2dd897;let {name:_0x44eb9b}=_0x277362,_0x2202ba=e()[_0x368955(0x108)](_0x4aa347=>'*\x20'+_0x4aa347[_0x368955(0x117)]+'\x20`'+_0x4aa347[_0x368955(0x110)]+'`\x20-\x20'+_0x4aa347[_0x368955(0x116)]);return(_0x368955(0x111)+_0x44eb9b+'\x0a\x0a##\x20ZMP\x20CLI\x20Options\x0a\x0aZMP\x20app\x20created\x20with\x20following\x20options:\x0a\x0a```\x0a'+JSON['stringify'](_0x277362,null,0x2)+_0x368955(0x115)+_0x2202ba[_0x368955(0x112)]('\x0a')+'\x0a')[_0x368955(0x119)]()[_0x368955(0x107)](/[\n]{3,}/,'\x0a');};
@@ -1 +0,0 @@
1
- 'use strict';function _0x2b64(_0xdb4cb0,_0x34071d){const _0x2d7f95=_0x2d7f();return _0x2b64=function(_0x2b644c,_0x26e701){_0x2b644c=_0x2b644c-0x183;let _0x268982=_0x2d7f95[_0x2b644c];return _0x268982;},_0x2b64(_0xdb4cb0,_0x34071d);}const _0x3216f5=_0x2b64;function _0x2d7f(){const _0x27b2a6=['4122045YWToXJ','length','repeat','1889490fGTThw','293228tdxBip','map','1NLIAKH','14rNgswj','12802190srxdPI','3619995HIFoyh','filter','max','forEach','split','543124HgUsBr','exports','2413312ZVqowN','trim','match','15xiSyvX','min','replace'];_0x2d7f=function(){return _0x27b2a6;};return _0x2d7f();}(function(_0x5ae674,_0x1e6aa9){const _0x36293c=_0x2b64,_0x3355a0=_0x5ae674();while(!![]){try{const _0x2dcdcb=parseInt(_0x36293c(0x189))/0x1*(parseInt(_0x36293c(0x187))/0x2)+-parseInt(_0x36293c(0x196))/0x3*(-parseInt(_0x36293c(0x191))/0x4)+parseInt(_0x36293c(0x18c))/0x5+-parseInt(_0x36293c(0x186))/0x6*(parseInt(_0x36293c(0x18a))/0x7)+parseInt(_0x36293c(0x193))/0x8+parseInt(_0x36293c(0x183))/0x9+-parseInt(_0x36293c(0x18b))/0xa;if(_0x2dcdcb===_0x1e6aa9)break;else _0x3355a0['push'](_0x3355a0['shift']());}catch(_0x34580a){_0x3355a0['push'](_0x3355a0['shift']());}}}(_0x2d7f,0x61722));module[_0x3216f5(0x192)]=(_0x5b6066,_0xe85355)=>{const _0x297881=_0x3216f5;let _0x48360b;return void 0x0===_0x5b6066?_0xe85355[_0x297881(0x194)]():(_0xe85355[_0x297881(0x190)]('\x0a')[_0x297881(0x18f)](_0xe4bcc7=>{const _0xb7b9b5=_0x297881;let _0x263739=_0xe4bcc7[_0xb7b9b5(0x195)](/[ ]*/);if(_0x263739){if(_0x263739[0x0][_0xb7b9b5(0x184)]===_0xe4bcc7['length'])return;_0x48360b=void 0x0===_0x48360b?_0x263739[0x0]['length']:Math[_0xb7b9b5(0x197)](_0x48360b,_0x263739[0x0][_0xb7b9b5(0x184)]);}}),void 0x0===_0x48360b)?_0xe85355[_0x297881(0x194)]():_0xe85355[_0x297881(0x190)]('\x0a')[_0x297881(0x188)](_0x2b7cdd=>{const _0x24b1df=_0x297881;let _0x32dfd9=_0x2b7cdd[_0x24b1df(0x195)](/[ ]*/),_0x6bca92=0x0;return _0x32dfd9&&(_0x6bca92=Math[_0x24b1df(0x18e)](_0x32dfd9[0x0][_0x24b1df(0x184)]-_0x48360b,0x0)),''+'\x20'[_0x24b1df(0x185)](_0x5b6066+_0x6bca92)+_0x2b7cdd[_0x24b1df(0x198)](/^\s+/,'');})[_0x297881(0x188)](_0xd2e103=>!_0xd2e103[_0x297881(0x194)]()[_0x297881(0x184)]&&_0xd2e103[_0x297881(0x184)]?_0xd2e103['trim']():_0xd2e103)[_0x297881(0x18d)]((_0x500660,_0x41908e,_0x1d7450)=>(0x0!==_0x41908e||!!_0x500660[_0x297881(0x194)]()['length']||!_0x500660['length'])&&(_0x41908e!==_0x1d7450['length']-0x1||!!_0x500660[_0x297881(0x194)]()[_0x297881(0x184)]||!_0x500660[_0x297881(0x184)]))['join']('\x0a');};
@@ -1 +0,0 @@
1
- 'use strict';var _0x1f7beb=_0x1638;(function(_0x4b5a07,_0x141cd5){var _0xa28e98=_0x1638,_0x529223=_0x4b5a07();while(!![]){try{var _0x266f94=parseInt(_0xa28e98(0x1d2))/0x1+-parseInt(_0xa28e98(0x1d5))/0x2*(-parseInt(_0xa28e98(0x1cd))/0x3)+parseInt(_0xa28e98(0x1c7))/0x4*(-parseInt(_0xa28e98(0x1d4))/0x5)+-parseInt(_0xa28e98(0x1c8))/0x6*(parseInt(_0xa28e98(0x1ce))/0x7)+-parseInt(_0xa28e98(0x1c9))/0x8*(-parseInt(_0xa28e98(0x1d1))/0x9)+-parseInt(_0xa28e98(0x1d7))/0xa+parseInt(_0xa28e98(0x1cf))/0xb;if(_0x266f94===_0x141cd5)break;else _0x529223['push'](_0x529223['shift']());}catch(_0x47f82e){_0x529223['push'](_0x529223['shift']());}}}(_0x5cda,0x67bcd));function _0x5cda(){var _0x57ee38=['116374OPcZpE','map','49085GjQbRr','20926lcXCDR','exports','1844840yAHTUi','332BLymVr','6BNJDSG','64vyFdBa','toUpperCase','split','join','105hHnZrN','236922vxuine','4897277LdcgzP','substring','596547ldZpHB'];_0x5cda=function(){return _0x57ee38;};return _0x5cda();}function _0x1638(_0x314575,_0x506781){var _0x5cda3c=_0x5cda();return _0x1638=function(_0x163852,_0x21c498){_0x163852=_0x163852-0x1c7;var _0x11b68a=_0x5cda3c[_0x163852];return _0x11b68a;},_0x1638(_0x314575,_0x506781);}module[_0x1f7beb(0x1d6)]={'capitalize':_0x421247=>_0x421247?_0x421247[_0x1f7beb(0x1cb)](/[,.\-_\s]/)[_0x1f7beb(0x1d3)](_0x61d413=>_0x61d413[0x0][_0x1f7beb(0x1ca)]()+_0x61d413[_0x1f7beb(0x1d0)](0x1))[_0x1f7beb(0x1cc)](''):''};
@@ -1 +0,0 @@
1
- 'use strict';var _0x4ef40a=_0x218e;(function(_0x22d5ed,_0xab1ab5){var _0x1d7239=_0x218e,_0x21a5bb=_0x22d5ed();while(!![]){try{var _0x51a03f=parseInt(_0x1d7239(0xe0))/0x1+-parseInt(_0x1d7239(0xd9))/0x2*(-parseInt(_0x1d7239(0xe3))/0x3)+-parseInt(_0x1d7239(0xe1))/0x4+parseInt(_0x1d7239(0xda))/0x5*(parseInt(_0x1d7239(0xd7))/0x6)+-parseInt(_0x1d7239(0xde))/0x7*(-parseInt(_0x1d7239(0xd8))/0x8)+parseInt(_0x1d7239(0xdc))/0x9*(parseInt(_0x1d7239(0xe4))/0xa)+-parseInt(_0x1d7239(0xdf))/0xb*(parseInt(_0x1d7239(0xdd))/0xc);if(_0x51a03f===_0xab1ab5)break;else _0x21a5bb['push'](_0x21a5bb['shift']());}catch(_0x284772){_0x21a5bb['push'](_0x21a5bb['shift']());}}}(_0x4c4a,0x32b17));module[_0x4ef40a(0xe2)]=_0x440c71=>_0x440c71?{'less':'less','stylus':_0x4ef40a(0xe5),'scss':_0x4ef40a(0xdb)}[_0x440c71]:'css';function _0x218e(_0x5a7019,_0x1e428a){var _0x4c4ac7=_0x4c4a();return _0x218e=function(_0x218e45,_0x4045b3){_0x218e45=_0x218e45-0xd7;var _0x4a8502=_0x4c4ac7[_0x218e45];return _0x4a8502;},_0x218e(_0x5a7019,_0x1e428a);}function _0x4c4a(){var _0x34b9a3=['2050edJdjt','styl','10902BoXTjK','654392hnHRnb','202646ExWWWg','120rILtcg','scss','1008PdtreR','1116TYHYJw','14kdDOjJ','4829rxwiiQ','118771FTzELg','1212468MEtijN','exports','6wbjWds'];_0x4c4a=function(){return _0x34b9a3;};return _0x4c4a();}
@@ -1 +0,0 @@
1
- 'use strict';function _0x5f4f(_0x1ee042,_0x3256bd){var _0x3107cb=_0x3107();return _0x5f4f=function(_0x5f4fa4,_0x1ed903){_0x5f4fa4=_0x5f4fa4-0x1d5;var _0x5d3f6c=_0x3107cb[_0x5f4fa4];return _0x5d3f6c;},_0x5f4f(_0x1ee042,_0x3256bd);}var _0x26045d=_0x5f4f;(function(_0x59a474,_0x55ca28){var _0x421211=_0x5f4f,_0x3ace20=_0x59a474();while(!![]){try{var _0x5885c1=parseInt(_0x421211(0x1d7))/0x1*(parseInt(_0x421211(0x1db))/0x2)+-parseInt(_0x421211(0x1d8))/0x3+parseInt(_0x421211(0x1de))/0x4+-parseInt(_0x421211(0x1da))/0x5*(-parseInt(_0x421211(0x1d6))/0x6)+parseInt(_0x421211(0x1d9))/0x7+-parseInt(_0x421211(0x1df))/0x8+parseInt(_0x421211(0x1dd))/0x9*(parseInt(_0x421211(0x1dc))/0xa);if(_0x5885c1===_0x55ca28)break;else _0x3ace20['push'](_0x3ace20['shift']());}catch(_0x5dff19){_0x3ace20['push'](_0x3ace20['shift']());}}}(_0x3107,0xd1568));function _0x3107(){var _0x43fada=['32989RbUAxm','5030619wOPXhb','1667582FxPRWn','5HMMBSw','36SyloYm','170dbjZDP','759915WyNZwv','2425748FGLnLK','6611688MSksKd','trim','2921532JJdQyA'];_0x3107=function(){return _0x43fada;};return _0x3107();}module['exports']=(_0x23be30,_0x339762,_0x15a739)=>_0x23be30?_0x339762()[_0x26045d(0x1d5)]():_0x15a739?_0x15a739()['trim']():'';
@@ -1 +0,0 @@
1
- 'use strict';const _0x12773b=_0xc2fe;(function(_0x24571b,_0x4bc0e3){const _0x27ac62=_0xc2fe,_0x2542c1=_0x24571b();while(!![]){try{const _0x17a757=-parseInt(_0x27ac62(0xfd))/0x1*(parseInt(_0x27ac62(0xfa))/0x2)+parseInt(_0x27ac62(0xf8))/0x3+-parseInt(_0x27ac62(0xff))/0x4+parseInt(_0x27ac62(0xed))/0x5+parseInt(_0x27ac62(0xe6))/0x6*(-parseInt(_0x27ac62(0xeb))/0x7)+-parseInt(_0x27ac62(0xf7))/0x8*(-parseInt(_0x27ac62(0xf3))/0x9)+parseInt(_0x27ac62(0xfb))/0xa;if(_0x17a757===_0x4bc0e3)break;else _0x2542c1['push'](_0x2542c1['shift']());}catch(_0x4b5d1c){_0x2542c1['push'](_0x2542c1['shift']());}}}(_0x34ed,0xd920c));const {default:t}=require('axios'),e=require(_0x12773b(0xf1));function _0xc2fe(_0x52d737,_0x220988){const _0x34edb8=_0x34ed();return _0xc2fe=function(_0xc2fe60,_0x2401bc){_0xc2fe60=_0xc2fe60-0xe0;let _0x4b5046=_0x34edb8[_0xc2fe60];return _0x4b5046;},_0xc2fe(_0x52d737,_0x220988);}async function r(_0x168091,_0x3a932b={}){const _0x49ab0e=_0x12773b;let _0x5361c3=[];try{let _0x189df6=(await t({'url':_0x168091,'headers':{'Accept':_0x49ab0e(0xe0)}}))[_0x49ab0e(0xea)];new e()[_0x49ab0e(0xe8)](_0x189df6,_0x49ab0e(0xe3))[_0x49ab0e(0xe5)]('script')[_0x49ab0e(0xf0)](_0x3f0743=>{const _0x146985=_0x49ab0e;let _0x10286e=_0x3f0743[_0x146985(0xfc)](_0x146985(0xe7)),_0x229cf8=_0x3f0743[_0x146985(0xfc)]('type'),_0x3f878c=_0x3f0743[_0x146985(0xfc)]('data-skip-hr-config'),_0x3b8cd4=_0x3f0743['innerHTML'];null===_0x3f878c&&_0x5361c3[_0x146985(0xf2)]({'src':_0x10286e,'type':_0x229cf8,'innerHTML':_0x3b8cd4?_0x3b8cd4[_0x146985(0xf4)](_0x146985(0xfe),'from\x20\x22'+_0x3a932b['exposedUrl']+'/')['replaceAll'](_0x146985(0xec),_0x146985(0xf5)+_0x3a932b[_0x146985(0xe1)]+'/'):void 0x0});}),_0x5361c3[_0x49ab0e(0xf2)]({'src':_0x49ab0e(0xef),'type':'module'}),_0x5361c3[_0x49ab0e(0xf2)]({'id':_0x49ab0e(0xe4),'innerHTML':_0x49ab0e(0xe9)+_0x3a932b[_0x49ab0e(0xf9)]+'/target.js\x27;\x0a\x20\x20\x20\x20\x20\x20\x20\x20document.head.appendChild(script);\x0a\x20\x20\x20\x20\x20\x20\x20\x20window.BACKUP_URL\x20=\x20window.location.href;\x0a\x20\x20\x20\x20\x20\x20})()','type':_0x49ab0e(0xf6)});}catch(_0x3b03f0){console[_0x49ab0e(0xe2)](_0x3b03f0);}return{'listCSS':[],'listJS':_0x5361c3};}module[_0x12773b(0xee)]={'generateHrFromIndex':r};function _0x34ed(){const _0x19b991=['8244315qGoxZH','exports','/studio.module.js','forEach','dom-parser','push','7173lXwtrS','replaceAll','from\x20\x27','text/javascript','2264vSpJBh','4870074wqjArX','chiiUrl','800RzAlah','2150570AaKzNu','getAttribute','2879zMrirS','from\x20\x22/','5091184RcqYOW','text/html,application/xhtml+xml,application/xml','exposedUrl','warn','text/html','remote-debug-script','getElementsByTagName','42MFStOz','src','parseFromString','(function\x20()\x20{\x0a\x20\x20\x20\x20\x20\x20\x20\x20var\x20script\x20=\x20document.createElement(\x27script\x27);\x0a\x20\x20\x20\x20\x20\x20\x20\x20script.src=\x27','data','399077rJESRq','from\x20\x27/'];_0x34ed=function(){return _0x19b991;};return _0x34ed();}