adtec-core-package 0.0.0
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/.editorconfig +6 -0
- package/.prettierrc.json +7 -0
- package/.vscode/extensions.json +8 -0
- package/README.md +39 -0
- package/env.d.ts +1 -0
- package/eslint.config.js +19 -0
- package/index.html +13 -0
- package/package.json +41 -0
- package/public/favicon.ico +0 -0
- package/src/App.vue +85 -0
- package/src/assets/base.css +86 -0
- package/src/assets/logo.svg +1 -0
- package/src/assets/main.css +35 -0
- package/src/components/HelloWorld.vue +41 -0
- package/src/components/TheWelcome.vue +94 -0
- package/src/components/WelcomeItem.vue +87 -0
- package/src/components/icons/IconCommunity.vue +7 -0
- package/src/components/icons/IconDocumentation.vue +7 -0
- package/src/components/icons/IconEcosystem.vue +7 -0
- package/src/components/icons/IconSupport.vue +7 -0
- package/src/components/icons/IconTooling.vue +19 -0
- package/src/main.ts +14 -0
- package/src/packages/index.ts +8 -0
- package/src/packages/text.vue +13 -0
- package/src/router/index.ts +23 -0
- package/src/stores/counter.ts +12 -0
- package/src/views/AboutView.vue +15 -0
- package/src/views/HomeView.vue +9 -0
- package/tsconfig.app.json +12 -0
- package/tsconfig.json +11 -0
- package/tsconfig.node.json +18 -0
- package/vite.config.ts +94 -0
package/.editorconfig
ADDED
package/.prettierrc.json
ADDED
package/README.md
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
# adtec-core-package
|
|
2
|
+
|
|
3
|
+
This template should help get you started developing with Vue 3 in Vite.
|
|
4
|
+
|
|
5
|
+
## Recommended IDE Setup
|
|
6
|
+
|
|
7
|
+
[VSCode](https://code.visualstudio.com/) + [Volar](https://marketplace.visualstudio.com/items?itemName=Vue.volar) (and disable Vetur).
|
|
8
|
+
|
|
9
|
+
## Type Support for `.vue` Imports in TS
|
|
10
|
+
|
|
11
|
+
TypeScript cannot handle type information for `.vue` imports by default, so we replace the `tsc` CLI with `vue-tsc` for type checking. In editors, we need [Volar](https://marketplace.visualstudio.com/items?itemName=Vue.volar) to make the TypeScript language service aware of `.vue` types.
|
|
12
|
+
|
|
13
|
+
## Customize configuration
|
|
14
|
+
|
|
15
|
+
See [Vite Configuration Reference](https://vite.dev/config/).
|
|
16
|
+
|
|
17
|
+
## Project Setup
|
|
18
|
+
|
|
19
|
+
```sh
|
|
20
|
+
npm install
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
### Compile and Hot-Reload for Development
|
|
24
|
+
|
|
25
|
+
```sh
|
|
26
|
+
npm run dev
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
### Type-Check, Compile and Minify for Production
|
|
30
|
+
|
|
31
|
+
```sh
|
|
32
|
+
npm run build
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
### Lint with [ESLint](https://eslint.org/)
|
|
36
|
+
|
|
37
|
+
```sh
|
|
38
|
+
npm run lint
|
|
39
|
+
```
|
package/env.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
/// <reference types="vite/client" />
|
package/eslint.config.js
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import pluginVue from 'eslint-plugin-vue'
|
|
2
|
+
import vueTsEslintConfig from '@vue/eslint-config-typescript'
|
|
3
|
+
import skipFormatting from '@vue/eslint-config-prettier/skip-formatting'
|
|
4
|
+
|
|
5
|
+
export default [
|
|
6
|
+
{
|
|
7
|
+
name: 'app/files-to-lint',
|
|
8
|
+
files: ['**/*.{ts,mts,tsx,vue}'],
|
|
9
|
+
},
|
|
10
|
+
|
|
11
|
+
{
|
|
12
|
+
name: 'app/files-to-ignore',
|
|
13
|
+
ignores: ['**/dist/**', '**/dist-ssr/**', '**/coverage/**'],
|
|
14
|
+
},
|
|
15
|
+
|
|
16
|
+
...pluginVue.configs['flat/essential'],
|
|
17
|
+
...vueTsEslintConfig(),
|
|
18
|
+
skipFormatting,
|
|
19
|
+
]
|
package/index.html
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html lang="">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8">
|
|
5
|
+
<link rel="icon" href="/favicon.ico">
|
|
6
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
7
|
+
<title>Vite App</title>
|
|
8
|
+
</head>
|
|
9
|
+
<body>
|
|
10
|
+
<div id="app"></div>
|
|
11
|
+
<script type="module" src="/src/main.ts"></script>
|
|
12
|
+
</body>
|
|
13
|
+
</html>
|
package/package.json
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "adtec-core-package",
|
|
3
|
+
"version": "0.0.0",
|
|
4
|
+
"private": false,
|
|
5
|
+
"type": "module",
|
|
6
|
+
"scripts": {
|
|
7
|
+
"dev": "vite",
|
|
8
|
+
"build": "run-p type-check \"build-only {@}\" --",
|
|
9
|
+
"preview": "vite preview",
|
|
10
|
+
"build-only": "vite build",
|
|
11
|
+
"type-check": "vue-tsc --build",
|
|
12
|
+
"lint": "eslint . --fix",
|
|
13
|
+
"format": "prettier --write src/"
|
|
14
|
+
},
|
|
15
|
+
"dependencies": {
|
|
16
|
+
"pinia": "^2.3.0",
|
|
17
|
+
"vue": "^3.5.13",
|
|
18
|
+
"vue-router": "^4.5.0"
|
|
19
|
+
},
|
|
20
|
+
"devDependencies": {
|
|
21
|
+
"@tsconfig/node22": "^22.0.0",
|
|
22
|
+
"@types/node": "^22.10.2",
|
|
23
|
+
"@vitejs/plugin-vue": "^5.2.1",
|
|
24
|
+
"@vitejs/plugin-vue-jsx": "^4.1.1",
|
|
25
|
+
"@vue/eslint-config-prettier": "^10.1.0",
|
|
26
|
+
"@vue/eslint-config-typescript": "^14.1.3",
|
|
27
|
+
"@vue/tsconfig": "^0.7.0",
|
|
28
|
+
"eslint": "^9.14.0",
|
|
29
|
+
"eslint-plugin-vue": "^9.30.0",
|
|
30
|
+
"npm-run-all2": "^7.0.2",
|
|
31
|
+
"prettier": "^3.3.3",
|
|
32
|
+
"typescript": "~5.6.3",
|
|
33
|
+
"vite": "^6.0.5",
|
|
34
|
+
"vite-plugin-vue-devtools": "^7.6.8",
|
|
35
|
+
"vue-tsc": "^2.1.10"
|
|
36
|
+
},
|
|
37
|
+
"description": "This template should help get you started developing with Vue 3 in Vite.",
|
|
38
|
+
"main": "eslint.config.js",
|
|
39
|
+
"author": "",
|
|
40
|
+
"license": "ISC"
|
|
41
|
+
}
|
|
Binary file
|
package/src/App.vue
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import { RouterLink, RouterView } from 'vue-router'
|
|
3
|
+
import HelloWorld from './components/HelloWorld.vue'
|
|
4
|
+
</script>
|
|
5
|
+
|
|
6
|
+
<template>
|
|
7
|
+
<header>
|
|
8
|
+
<img alt="Vue logo" class="logo" src="@/assets/logo.svg" width="125" height="125" />
|
|
9
|
+
|
|
10
|
+
<div class="wrapper">
|
|
11
|
+
<HelloWorld msg="You did it!" />
|
|
12
|
+
|
|
13
|
+
<nav>
|
|
14
|
+
<RouterLink to="/">Home</RouterLink>
|
|
15
|
+
<RouterLink to="/about">About</RouterLink>
|
|
16
|
+
</nav>
|
|
17
|
+
</div>
|
|
18
|
+
</header>
|
|
19
|
+
|
|
20
|
+
<RouterView />
|
|
21
|
+
</template>
|
|
22
|
+
|
|
23
|
+
<style scoped>
|
|
24
|
+
header {
|
|
25
|
+
line-height: 1.5;
|
|
26
|
+
max-height: 100vh;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.logo {
|
|
30
|
+
display: block;
|
|
31
|
+
margin: 0 auto 2rem;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
nav {
|
|
35
|
+
width: 100%;
|
|
36
|
+
font-size: 12px;
|
|
37
|
+
text-align: center;
|
|
38
|
+
margin-top: 2rem;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
nav a.router-link-exact-active {
|
|
42
|
+
color: var(--color-text);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
nav a.router-link-exact-active:hover {
|
|
46
|
+
background-color: transparent;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
nav a {
|
|
50
|
+
display: inline-block;
|
|
51
|
+
padding: 0 1rem;
|
|
52
|
+
border-left: 1px solid var(--color-border);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
nav a:first-of-type {
|
|
56
|
+
border: 0;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
@media (min-width: 1024px) {
|
|
60
|
+
header {
|
|
61
|
+
display: flex;
|
|
62
|
+
place-items: center;
|
|
63
|
+
padding-right: calc(var(--section-gap) / 2);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.logo {
|
|
67
|
+
margin: 0 2rem 0 0;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
header .wrapper {
|
|
71
|
+
display: flex;
|
|
72
|
+
place-items: flex-start;
|
|
73
|
+
flex-wrap: wrap;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
nav {
|
|
77
|
+
text-align: left;
|
|
78
|
+
margin-left: -1rem;
|
|
79
|
+
font-size: 1rem;
|
|
80
|
+
|
|
81
|
+
padding: 1rem 0;
|
|
82
|
+
margin-top: 1rem;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
</style>
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
/* color palette from <https://github.com/vuejs/theme> */
|
|
2
|
+
:root {
|
|
3
|
+
--vt-c-white: #ffffff;
|
|
4
|
+
--vt-c-white-soft: #f8f8f8;
|
|
5
|
+
--vt-c-white-mute: #f2f2f2;
|
|
6
|
+
|
|
7
|
+
--vt-c-black: #181818;
|
|
8
|
+
--vt-c-black-soft: #222222;
|
|
9
|
+
--vt-c-black-mute: #282828;
|
|
10
|
+
|
|
11
|
+
--vt-c-indigo: #2c3e50;
|
|
12
|
+
|
|
13
|
+
--vt-c-divider-light-1: rgba(60, 60, 60, 0.29);
|
|
14
|
+
--vt-c-divider-light-2: rgba(60, 60, 60, 0.12);
|
|
15
|
+
--vt-c-divider-dark-1: rgba(84, 84, 84, 0.65);
|
|
16
|
+
--vt-c-divider-dark-2: rgba(84, 84, 84, 0.48);
|
|
17
|
+
|
|
18
|
+
--vt-c-text-light-1: var(--vt-c-indigo);
|
|
19
|
+
--vt-c-text-light-2: rgba(60, 60, 60, 0.66);
|
|
20
|
+
--vt-c-text-dark-1: var(--vt-c-white);
|
|
21
|
+
--vt-c-text-dark-2: rgba(235, 235, 235, 0.64);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/* semantic color variables for this project */
|
|
25
|
+
:root {
|
|
26
|
+
--color-background: var(--vt-c-white);
|
|
27
|
+
--color-background-soft: var(--vt-c-white-soft);
|
|
28
|
+
--color-background-mute: var(--vt-c-white-mute);
|
|
29
|
+
|
|
30
|
+
--color-border: var(--vt-c-divider-light-2);
|
|
31
|
+
--color-border-hover: var(--vt-c-divider-light-1);
|
|
32
|
+
|
|
33
|
+
--color-heading: var(--vt-c-text-light-1);
|
|
34
|
+
--color-text: var(--vt-c-text-light-1);
|
|
35
|
+
|
|
36
|
+
--section-gap: 160px;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
@media (prefers-color-scheme: dark) {
|
|
40
|
+
:root {
|
|
41
|
+
--color-background: var(--vt-c-black);
|
|
42
|
+
--color-background-soft: var(--vt-c-black-soft);
|
|
43
|
+
--color-background-mute: var(--vt-c-black-mute);
|
|
44
|
+
|
|
45
|
+
--color-border: var(--vt-c-divider-dark-2);
|
|
46
|
+
--color-border-hover: var(--vt-c-divider-dark-1);
|
|
47
|
+
|
|
48
|
+
--color-heading: var(--vt-c-text-dark-1);
|
|
49
|
+
--color-text: var(--vt-c-text-dark-2);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
*,
|
|
54
|
+
*::before,
|
|
55
|
+
*::after {
|
|
56
|
+
box-sizing: border-box;
|
|
57
|
+
margin: 0;
|
|
58
|
+
font-weight: normal;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
body {
|
|
62
|
+
min-height: 100vh;
|
|
63
|
+
color: var(--color-text);
|
|
64
|
+
background: var(--color-background);
|
|
65
|
+
transition:
|
|
66
|
+
color 0.5s,
|
|
67
|
+
background-color 0.5s;
|
|
68
|
+
line-height: 1.6;
|
|
69
|
+
font-family:
|
|
70
|
+
Inter,
|
|
71
|
+
-apple-system,
|
|
72
|
+
BlinkMacSystemFont,
|
|
73
|
+
'Segoe UI',
|
|
74
|
+
Roboto,
|
|
75
|
+
Oxygen,
|
|
76
|
+
Ubuntu,
|
|
77
|
+
Cantarell,
|
|
78
|
+
'Fira Sans',
|
|
79
|
+
'Droid Sans',
|
|
80
|
+
'Helvetica Neue',
|
|
81
|
+
sans-serif;
|
|
82
|
+
font-size: 15px;
|
|
83
|
+
text-rendering: optimizeLegibility;
|
|
84
|
+
-webkit-font-smoothing: antialiased;
|
|
85
|
+
-moz-osx-font-smoothing: grayscale;
|
|
86
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 261.76 226.69"><path d="M161.096.001l-30.225 52.351L100.647.001H-.005l130.877 226.688L261.749.001z" fill="#41b883"/><path d="M161.096.001l-30.225 52.351L100.647.001H52.346l78.526 136.01L209.398.001z" fill="#34495e"/></svg>
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
@import './base.css';
|
|
2
|
+
|
|
3
|
+
#app {
|
|
4
|
+
max-width: 1280px;
|
|
5
|
+
margin: 0 auto;
|
|
6
|
+
padding: 2rem;
|
|
7
|
+
font-weight: normal;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
a,
|
|
11
|
+
.green {
|
|
12
|
+
text-decoration: none;
|
|
13
|
+
color: hsla(160, 100%, 37%, 1);
|
|
14
|
+
transition: 0.4s;
|
|
15
|
+
padding: 3px;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
@media (hover: hover) {
|
|
19
|
+
a:hover {
|
|
20
|
+
background-color: hsla(160, 100%, 37%, 0.2);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
@media (min-width: 1024px) {
|
|
25
|
+
body {
|
|
26
|
+
display: flex;
|
|
27
|
+
place-items: center;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
#app {
|
|
31
|
+
display: grid;
|
|
32
|
+
grid-template-columns: 1fr 1fr;
|
|
33
|
+
padding: 0 2rem;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
defineProps<{
|
|
3
|
+
msg: string
|
|
4
|
+
}>()
|
|
5
|
+
</script>
|
|
6
|
+
|
|
7
|
+
<template>
|
|
8
|
+
<div class="greetings">
|
|
9
|
+
<h1 class="green">{{ msg }}</h1>
|
|
10
|
+
<h3>
|
|
11
|
+
You’ve successfully created a project with
|
|
12
|
+
<a href="https://vite.dev/" target="_blank" rel="noopener">Vite</a> +
|
|
13
|
+
<a href="https://vuejs.org/" target="_blank" rel="noopener">Vue 3</a>. What's next?
|
|
14
|
+
</h3>
|
|
15
|
+
</div>
|
|
16
|
+
</template>
|
|
17
|
+
|
|
18
|
+
<style scoped>
|
|
19
|
+
h1 {
|
|
20
|
+
font-weight: 500;
|
|
21
|
+
font-size: 2.6rem;
|
|
22
|
+
position: relative;
|
|
23
|
+
top: -10px;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
h3 {
|
|
27
|
+
font-size: 1.2rem;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
.greetings h1,
|
|
31
|
+
.greetings h3 {
|
|
32
|
+
text-align: center;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
@media (min-width: 1024px) {
|
|
36
|
+
.greetings h1,
|
|
37
|
+
.greetings h3 {
|
|
38
|
+
text-align: left;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
</style>
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import WelcomeItem from './WelcomeItem.vue'
|
|
3
|
+
import DocumentationIcon from './icons/IconDocumentation.vue'
|
|
4
|
+
import ToolingIcon from './icons/IconTooling.vue'
|
|
5
|
+
import EcosystemIcon from './icons/IconEcosystem.vue'
|
|
6
|
+
import CommunityIcon from './icons/IconCommunity.vue'
|
|
7
|
+
import SupportIcon from './icons/IconSupport.vue'
|
|
8
|
+
|
|
9
|
+
const openReadmeInEditor = () => fetch('/__open-in-editor?file=README.md')
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<template>
|
|
13
|
+
<WelcomeItem>
|
|
14
|
+
<template #icon>
|
|
15
|
+
<DocumentationIcon />
|
|
16
|
+
</template>
|
|
17
|
+
<template #heading>Documentation</template>
|
|
18
|
+
|
|
19
|
+
Vue’s
|
|
20
|
+
<a href="https://vuejs.org/" target="_blank" rel="noopener">official documentation</a>
|
|
21
|
+
provides you with all information you need to get started.
|
|
22
|
+
</WelcomeItem>
|
|
23
|
+
|
|
24
|
+
<WelcomeItem>
|
|
25
|
+
<template #icon>
|
|
26
|
+
<ToolingIcon />
|
|
27
|
+
</template>
|
|
28
|
+
<template #heading>Tooling</template>
|
|
29
|
+
|
|
30
|
+
This project is served and bundled with
|
|
31
|
+
<a href="https://vite.dev/guide/features.html" target="_blank" rel="noopener">Vite</a>. The
|
|
32
|
+
recommended IDE setup is
|
|
33
|
+
<a href="https://code.visualstudio.com/" target="_blank" rel="noopener">VSCode</a>
|
|
34
|
+
+
|
|
35
|
+
<a href="https://github.com/johnsoncodehk/volar" target="_blank" rel="noopener">Volar</a>. If
|
|
36
|
+
you need to test your components and web pages, check out
|
|
37
|
+
<a href="https://vitest.dev/" target="_blank" rel="noopener">Vite</a>
|
|
38
|
+
and
|
|
39
|
+
<a href="https://www.cypress.io/" target="_blank" rel="noopener">Cypress</a>
|
|
40
|
+
/
|
|
41
|
+
<a href="https://playwright.dev/" target="_blank" rel="noopener">Playwright</a>.
|
|
42
|
+
|
|
43
|
+
<br />
|
|
44
|
+
|
|
45
|
+
More instructions are available in
|
|
46
|
+
<a href="javascript:void(0)" @click="openReadmeInEditor"><code>README.md</code></a
|
|
47
|
+
>.
|
|
48
|
+
</WelcomeItem>
|
|
49
|
+
|
|
50
|
+
<WelcomeItem>
|
|
51
|
+
<template #icon>
|
|
52
|
+
<EcosystemIcon />
|
|
53
|
+
</template>
|
|
54
|
+
<template #heading>Ecosystem</template>
|
|
55
|
+
|
|
56
|
+
Get official tools and libraries for your project:
|
|
57
|
+
<a href="https://pinia.vuejs.org/" target="_blank" rel="noopener">Pinia</a>,
|
|
58
|
+
<a href="https://router.vuejs.org/" target="_blank" rel="noopener">Vue Router</a>,
|
|
59
|
+
<a href="https://test-utils.vuejs.org/" target="_blank" rel="noopener">Vue Test Utils</a>, and
|
|
60
|
+
<a href="https://github.com/vuejs/devtools" target="_blank" rel="noopener">Vue Dev Tools</a>. If
|
|
61
|
+
you need more resources, we suggest paying
|
|
62
|
+
<a href="https://github.com/vuejs/awesome-vue" target="_blank" rel="noopener">Awesome Vue</a>
|
|
63
|
+
a visit.
|
|
64
|
+
</WelcomeItem>
|
|
65
|
+
|
|
66
|
+
<WelcomeItem>
|
|
67
|
+
<template #icon>
|
|
68
|
+
<CommunityIcon />
|
|
69
|
+
</template>
|
|
70
|
+
<template #heading>Community</template>
|
|
71
|
+
|
|
72
|
+
Got stuck? Ask your question on
|
|
73
|
+
<a href="https://chat.vuejs.org" target="_blank" rel="noopener">Vue Land</a>
|
|
74
|
+
(our official Discord server), or
|
|
75
|
+
<a href="https://stackoverflow.com/questions/tagged/vue.js" target="_blank" rel="noopener"
|
|
76
|
+
>StackOverflow</a
|
|
77
|
+
>. You should also follow the official
|
|
78
|
+
<a href="https://bsky.app/profile/vuejs.org" target="_blank" rel="noopener">@vuejs.org</a>
|
|
79
|
+
Bluesky account or the
|
|
80
|
+
<a href="https://x.com/vuejs" target="_blank" rel="noopener">@vuejs</a>
|
|
81
|
+
X account for latest news in the Vue world.
|
|
82
|
+
</WelcomeItem>
|
|
83
|
+
|
|
84
|
+
<WelcomeItem>
|
|
85
|
+
<template #icon>
|
|
86
|
+
<SupportIcon />
|
|
87
|
+
</template>
|
|
88
|
+
<template #heading>Support Vue</template>
|
|
89
|
+
|
|
90
|
+
As an independent project, Vue relies on community backing for its sustainability. You can help
|
|
91
|
+
us by
|
|
92
|
+
<a href="https://vuejs.org/sponsor/" target="_blank" rel="noopener">becoming a sponsor</a>.
|
|
93
|
+
</WelcomeItem>
|
|
94
|
+
</template>
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="item">
|
|
3
|
+
<i>
|
|
4
|
+
<slot name="icon"></slot>
|
|
5
|
+
</i>
|
|
6
|
+
<div class="details">
|
|
7
|
+
<h3>
|
|
8
|
+
<slot name="heading"></slot>
|
|
9
|
+
</h3>
|
|
10
|
+
<slot></slot>
|
|
11
|
+
</div>
|
|
12
|
+
</div>
|
|
13
|
+
</template>
|
|
14
|
+
|
|
15
|
+
<style scoped>
|
|
16
|
+
.item {
|
|
17
|
+
margin-top: 2rem;
|
|
18
|
+
display: flex;
|
|
19
|
+
position: relative;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
.details {
|
|
23
|
+
flex: 1;
|
|
24
|
+
margin-left: 1rem;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
i {
|
|
28
|
+
display: flex;
|
|
29
|
+
place-items: center;
|
|
30
|
+
place-content: center;
|
|
31
|
+
width: 32px;
|
|
32
|
+
height: 32px;
|
|
33
|
+
|
|
34
|
+
color: var(--color-text);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
h3 {
|
|
38
|
+
font-size: 1.2rem;
|
|
39
|
+
font-weight: 500;
|
|
40
|
+
margin-bottom: 0.4rem;
|
|
41
|
+
color: var(--color-heading);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
@media (min-width: 1024px) {
|
|
45
|
+
.item {
|
|
46
|
+
margin-top: 0;
|
|
47
|
+
padding: 0.4rem 0 1rem calc(var(--section-gap) / 2);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
i {
|
|
51
|
+
top: calc(50% - 25px);
|
|
52
|
+
left: -26px;
|
|
53
|
+
position: absolute;
|
|
54
|
+
border: 1px solid var(--color-border);
|
|
55
|
+
background: var(--color-background);
|
|
56
|
+
border-radius: 8px;
|
|
57
|
+
width: 50px;
|
|
58
|
+
height: 50px;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
.item:before {
|
|
62
|
+
content: ' ';
|
|
63
|
+
border-left: 1px solid var(--color-border);
|
|
64
|
+
position: absolute;
|
|
65
|
+
left: 0;
|
|
66
|
+
bottom: calc(50% + 25px);
|
|
67
|
+
height: calc(50% - 25px);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
.item:after {
|
|
71
|
+
content: ' ';
|
|
72
|
+
border-left: 1px solid var(--color-border);
|
|
73
|
+
position: absolute;
|
|
74
|
+
left: 0;
|
|
75
|
+
top: calc(50% + 25px);
|
|
76
|
+
height: calc(50% - 25px);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
.item:first-of-type:before {
|
|
80
|
+
display: none;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
.item:last-of-type:after {
|
|
84
|
+
display: none;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
</style>
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor">
|
|
3
|
+
<path
|
|
4
|
+
d="M15 4a1 1 0 1 0 0 2V4zm0 11v-1a1 1 0 0 0-1 1h1zm0 4l-.707.707A1 1 0 0 0 16 19h-1zm-4-4l.707-.707A1 1 0 0 0 11 14v1zm-4.707-1.293a1 1 0 0 0-1.414 1.414l1.414-1.414zm-.707.707l-.707-.707.707.707zM9 11v-1a1 1 0 0 0-.707.293L9 11zm-4 0h1a1 1 0 0 0-1-1v1zm0 4H4a1 1 0 0 0 1.707.707L5 15zm10-9h2V4h-2v2zm2 0a1 1 0 0 1 1 1h2a3 3 0 0 0-3-3v2zm1 1v6h2V7h-2zm0 6a1 1 0 0 1-1 1v2a3 3 0 0 0 3-3h-2zm-1 1h-2v2h2v-2zm-3 1v4h2v-4h-2zm1.707 3.293l-4-4-1.414 1.414 4 4 1.414-1.414zM11 14H7v2h4v-2zm-4 0c-.276 0-.525-.111-.707-.293l-1.414 1.414C5.42 15.663 6.172 16 7 16v-2zm-.707 1.121l3.414-3.414-1.414-1.414-3.414 3.414 1.414 1.414zM9 12h4v-2H9v2zm4 0a3 3 0 0 0 3-3h-2a1 1 0 0 1-1 1v2zm3-3V3h-2v6h2zm0-6a3 3 0 0 0-3-3v2a1 1 0 0 1 1 1h2zm-3-3H3v2h10V0zM3 0a3 3 0 0 0-3 3h2a1 1 0 0 1 1-1V0zM0 3v6h2V3H0zm0 6a3 3 0 0 0 3 3v-2a1 1 0 0 1-1-1H0zm3 3h2v-2H3v2zm1-1v4h2v-4H4zm1.707 4.707l.586-.586-1.414-1.414-.586.586 1.414 1.414z"
|
|
5
|
+
/>
|
|
6
|
+
</svg>
|
|
7
|
+
</template>
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="17" fill="currentColor">
|
|
3
|
+
<path
|
|
4
|
+
d="M11 2.253a1 1 0 1 0-2 0h2zm-2 13a1 1 0 1 0 2 0H9zm.447-12.167a1 1 0 1 0 1.107-1.666L9.447 3.086zM1 2.253L.447 1.42A1 1 0 0 0 0 2.253h1zm0 13H0a1 1 0 0 0 1.553.833L1 15.253zm8.447.833a1 1 0 1 0 1.107-1.666l-1.107 1.666zm0-14.666a1 1 0 1 0 1.107 1.666L9.447 1.42zM19 2.253h1a1 1 0 0 0-.447-.833L19 2.253zm0 13l-.553.833A1 1 0 0 0 20 15.253h-1zm-9.553-.833a1 1 0 1 0 1.107 1.666L9.447 14.42zM9 2.253v13h2v-13H9zm1.553-.833C9.203.523 7.42 0 5.5 0v2c1.572 0 2.961.431 3.947 1.086l1.107-1.666zM5.5 0C3.58 0 1.797.523.447 1.42l1.107 1.666C2.539 2.431 3.928 2 5.5 2V0zM0 2.253v13h2v-13H0zm1.553 13.833C2.539 15.431 3.928 15 5.5 15v-2c-1.92 0-3.703.523-5.053 1.42l1.107 1.666zM5.5 15c1.572 0 2.961.431 3.947 1.086l1.107-1.666C9.203 13.523 7.42 13 5.5 13v2zm5.053-11.914C11.539 2.431 12.928 2 14.5 2V0c-1.92 0-3.703.523-5.053 1.42l1.107 1.666zM14.5 2c1.573 0 2.961.431 3.947 1.086l1.107-1.666C18.203.523 16.421 0 14.5 0v2zm3.5.253v13h2v-13h-2zm1.553 12.167C18.203 13.523 16.421 13 14.5 13v2c1.573 0 2.961.431 3.947 1.086l1.107-1.666zM14.5 13c-1.92 0-3.703.523-5.053 1.42l1.107 1.666C11.539 15.431 12.928 15 14.5 15v-2z"
|
|
5
|
+
/>
|
|
6
|
+
</svg>
|
|
7
|
+
</template>
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="18" height="20" fill="currentColor">
|
|
3
|
+
<path
|
|
4
|
+
d="M11.447 8.894a1 1 0 1 0-.894-1.789l.894 1.789zm-2.894-.789a1 1 0 1 0 .894 1.789l-.894-1.789zm0 1.789a1 1 0 1 0 .894-1.789l-.894 1.789zM7.447 7.106a1 1 0 1 0-.894 1.789l.894-1.789zM10 9a1 1 0 1 0-2 0h2zm-2 2.5a1 1 0 1 0 2 0H8zm9.447-5.606a1 1 0 1 0-.894-1.789l.894 1.789zm-2.894-.789a1 1 0 1 0 .894 1.789l-.894-1.789zm2 .789a1 1 0 1 0 .894-1.789l-.894 1.789zm-1.106-2.789a1 1 0 1 0-.894 1.789l.894-1.789zM18 5a1 1 0 1 0-2 0h2zm-2 2.5a1 1 0 1 0 2 0h-2zm-5.447-4.606a1 1 0 1 0 .894-1.789l-.894 1.789zM9 1l.447-.894a1 1 0 0 0-.894 0L9 1zm-2.447.106a1 1 0 1 0 .894 1.789l-.894-1.789zm-6 3a1 1 0 1 0 .894 1.789L.553 4.106zm2.894.789a1 1 0 1 0-.894-1.789l.894 1.789zm-2-.789a1 1 0 1 0-.894 1.789l.894-1.789zm1.106 2.789a1 1 0 1 0 .894-1.789l-.894 1.789zM2 5a1 1 0 1 0-2 0h2zM0 7.5a1 1 0 1 0 2 0H0zm8.553 12.394a1 1 0 1 0 .894-1.789l-.894 1.789zm-1.106-2.789a1 1 0 1 0-.894 1.789l.894-1.789zm1.106 1a1 1 0 1 0 .894 1.789l-.894-1.789zm2.894.789a1 1 0 1 0-.894-1.789l.894 1.789zM8 19a1 1 0 1 0 2 0H8zm2-2.5a1 1 0 1 0-2 0h2zm-7.447.394a1 1 0 1 0 .894-1.789l-.894 1.789zM1 15H0a1 1 0 0 0 .553.894L1 15zm1-2.5a1 1 0 1 0-2 0h2zm12.553 2.606a1 1 0 1 0 .894 1.789l-.894-1.789zM17 15l.447.894A1 1 0 0 0 18 15h-1zm1-2.5a1 1 0 1 0-2 0h2zm-7.447-5.394l-2 1 .894 1.789 2-1-.894-1.789zm-1.106 1l-2-1-.894 1.789 2 1 .894-1.789zM8 9v2.5h2V9H8zm8.553-4.894l-2 1 .894 1.789 2-1-.894-1.789zm.894 0l-2-1-.894 1.789 2 1 .894-1.789zM16 5v2.5h2V5h-2zm-4.553-3.894l-2-1-.894 1.789 2 1 .894-1.789zm-2.894-1l-2 1 .894 1.789 2-1L8.553.106zM1.447 5.894l2-1-.894-1.789-2 1 .894 1.789zm-.894 0l2 1 .894-1.789-2-1-.894 1.789zM0 5v2.5h2V5H0zm9.447 13.106l-2-1-.894 1.789 2 1 .894-1.789zm0 1.789l2-1-.894-1.789-2 1 .894 1.789zM10 19v-2.5H8V19h2zm-6.553-3.894l-2-1-.894 1.789 2 1 .894-1.789zM2 15v-2.5H0V15h2zm13.447 1.894l2-1-.894-1.789-2 1 .894 1.789zM18 15v-2.5h-2V15h2z"
|
|
5
|
+
/>
|
|
6
|
+
</svg>
|
|
7
|
+
</template>
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor">
|
|
3
|
+
<path
|
|
4
|
+
d="M10 3.22l-.61-.6a5.5 5.5 0 0 0-7.666.105 5.5 5.5 0 0 0-.114 7.665L10 18.78l8.39-8.4a5.5 5.5 0 0 0-.114-7.665 5.5 5.5 0 0 0-7.666-.105l-.61.61z"
|
|
5
|
+
/>
|
|
6
|
+
</svg>
|
|
7
|
+
</template>
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<!-- This icon is from <https://github.com/Templarian/MaterialDesign>, distributed under Apache 2.0 (https://www.apache.org/licenses/LICENSE-2.0) license-->
|
|
2
|
+
<template>
|
|
3
|
+
<svg
|
|
4
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
5
|
+
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
6
|
+
aria-hidden="true"
|
|
7
|
+
role="img"
|
|
8
|
+
class="iconify iconify--mdi"
|
|
9
|
+
width="24"
|
|
10
|
+
height="24"
|
|
11
|
+
preserveAspectRatio="xMidYMid meet"
|
|
12
|
+
viewBox="0 0 24 24"
|
|
13
|
+
>
|
|
14
|
+
<path
|
|
15
|
+
d="M20 18v-4h-3v1h-2v-1H9v1H7v-1H4v4h16M6.33 8l-1.74 4H7v-1h2v1h6v-1h2v1h2.41l-1.74-4H6.33M9 5v1h6V5H9m12.84 7.61c.1.22.16.48.16.8V18c0 .53-.21 1-.6 1.41c-.4.4-.85.59-1.4.59H4c-.55 0-1-.19-1.4-.59C2.21 19 2 18.53 2 18v-4.59c0-.32.06-.58.16-.8L4.5 7.22C4.84 6.41 5.45 6 6.33 6H7V5c0-.55.18-1 .57-1.41C7.96 3.2 8.44 3 9 3h6c.56 0 1.04.2 1.43.59c.39.41.57.86.57 1.41v1h.67c.88 0 1.49.41 1.83 1.22l2.34 5.39z"
|
|
16
|
+
fill="currentColor"
|
|
17
|
+
></path>
|
|
18
|
+
</svg>
|
|
19
|
+
</template>
|
package/src/main.ts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import './assets/main.css'
|
|
2
|
+
|
|
3
|
+
import { createApp } from 'vue'
|
|
4
|
+
import { createPinia } from 'pinia'
|
|
5
|
+
|
|
6
|
+
import App from './App.vue'
|
|
7
|
+
import router from './router'
|
|
8
|
+
|
|
9
|
+
const app = createApp(App)
|
|
10
|
+
|
|
11
|
+
app.use(createPinia())
|
|
12
|
+
app.use(router)
|
|
13
|
+
|
|
14
|
+
app.mount('#app')
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { createRouter, createWebHistory } from 'vue-router'
|
|
2
|
+
import HomeView from '../views/HomeView.vue'
|
|
3
|
+
|
|
4
|
+
const router = createRouter({
|
|
5
|
+
history: createWebHistory(import.meta.env.BASE_URL),
|
|
6
|
+
routes: [
|
|
7
|
+
{
|
|
8
|
+
path: '/',
|
|
9
|
+
name: 'home',
|
|
10
|
+
component: HomeView,
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
path: '/about',
|
|
14
|
+
name: 'about',
|
|
15
|
+
// route level code-splitting
|
|
16
|
+
// this generates a separate chunk (About.[hash].js) for this route
|
|
17
|
+
// which is lazy-loaded when the route is visited.
|
|
18
|
+
component: () => import('../views/AboutView.vue'),
|
|
19
|
+
},
|
|
20
|
+
],
|
|
21
|
+
})
|
|
22
|
+
|
|
23
|
+
export default router
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ref, computed } from 'vue'
|
|
2
|
+
import { defineStore } from 'pinia'
|
|
3
|
+
|
|
4
|
+
export const useCounterStore = defineStore('counter', () => {
|
|
5
|
+
const count = ref(0)
|
|
6
|
+
const doubleCount = computed(() => count.value * 2)
|
|
7
|
+
function increment() {
|
|
8
|
+
count.value++
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
return { count, doubleCount, increment }
|
|
12
|
+
})
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "@vue/tsconfig/tsconfig.dom.json",
|
|
3
|
+
"include": ["env.d.ts", "src/**/*", "src/**/*.vue"],
|
|
4
|
+
"exclude": ["src/**/__tests__/*"],
|
|
5
|
+
"compilerOptions": {
|
|
6
|
+
"tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo",
|
|
7
|
+
|
|
8
|
+
"paths": {
|
|
9
|
+
"@/*": ["./src/*"]
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
}
|
package/tsconfig.json
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
{
|
|
2
|
+
"extends": "@tsconfig/node22/tsconfig.json",
|
|
3
|
+
"include": [
|
|
4
|
+
"vite.config.*",
|
|
5
|
+
"vitest.config.*",
|
|
6
|
+
"cypress.config.*",
|
|
7
|
+
"nightwatch.conf.*",
|
|
8
|
+
"playwright.config.*"
|
|
9
|
+
],
|
|
10
|
+
"compilerOptions": {
|
|
11
|
+
"noEmit": true,
|
|
12
|
+
"tsBuildInfoFile": "./node_modules/.tmp/tsconfig.node.tsbuildinfo",
|
|
13
|
+
|
|
14
|
+
"module": "ESNext",
|
|
15
|
+
"moduleResolution": "Bundler",
|
|
16
|
+
"types": ["node"]
|
|
17
|
+
}
|
|
18
|
+
}
|
package/vite.config.ts
ADDED
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { fileURLToPath, URL } from 'node:url'
|
|
2
|
+
import { defineConfig } from 'vite'
|
|
3
|
+
import vue from '@vitejs/plugin-vue'
|
|
4
|
+
import vueJsx from '@vitejs/plugin-vue-jsx'
|
|
5
|
+
import vueDevTools from 'vite-plugin-vue-devtools'
|
|
6
|
+
import { resolve } from 'path';
|
|
7
|
+
// https://vite.dev/config/
|
|
8
|
+
export default defineConfig({
|
|
9
|
+
plugins: [
|
|
10
|
+
vue(),
|
|
11
|
+
vueJsx(),
|
|
12
|
+
vueDevTools(),
|
|
13
|
+
],
|
|
14
|
+
build:{
|
|
15
|
+
outDir: "dist", //输出文件名称
|
|
16
|
+
lib:{
|
|
17
|
+
entry: resolve(__dirname, './src/packages/index.ts'), //指定组件编译入口文件
|
|
18
|
+
name: 'sadtec-core-package',
|
|
19
|
+
fileName: 'adtec-core-package'
|
|
20
|
+
},//库编译模式配置
|
|
21
|
+
},
|
|
22
|
+
resolve: {
|
|
23
|
+
alias: {
|
|
24
|
+
'@': fileURLToPath(new URL('./src', import.meta.url))
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
})
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
// import { defineConfig } from 'vite'
|
|
32
|
+
// import vue from '@vitejs/plugin-vue'
|
|
33
|
+
// import { resolve } from 'path';
|
|
34
|
+
//
|
|
35
|
+
// const pathResolve = (dir: string) => {
|
|
36
|
+
// return resolve(__dirname, '.', dir);
|
|
37
|
+
// };
|
|
38
|
+
// const alias: Record<string, string> = {
|
|
39
|
+
// '@': pathResolve('./src'),
|
|
40
|
+
// };
|
|
41
|
+
//
|
|
42
|
+
// // https://vitejs.dev/config/
|
|
43
|
+
// export default defineConfig({
|
|
44
|
+
// plugins: [vue()],
|
|
45
|
+
// base:'./',
|
|
46
|
+
// build:{
|
|
47
|
+
// outDir: 'sos-map-ui/dist', //输出文件名称
|
|
48
|
+
// lib:{
|
|
49
|
+
// entry: resolve(__dirname, './src/components/index.ts'), //指定组件编译入口文件
|
|
50
|
+
// name: 'sosVue3TsMapUi',
|
|
51
|
+
// fileName: 'sos-map-ui'
|
|
52
|
+
// },//库编译模式配置
|
|
53
|
+
// rollupOptions: {
|
|
54
|
+
// external: ['vue', 'swiper', '@vuepic/vue-datepicker', 'qrcode'],
|
|
55
|
+
// output: {
|
|
56
|
+
// // format: 'es', // 默认es,可选 'amd' 'cjs' 'es' 'iife' 'umd' 'system'
|
|
57
|
+
// exports: 'named',
|
|
58
|
+
// globals: { //在UMD构建模式下为这些外部化的依赖提供一个全局变量
|
|
59
|
+
// vue:'Vue',
|
|
60
|
+
// // 'vue-router': 'VueRouter', // 引入vue-router全局变量,否则router.push将无法使用
|
|
61
|
+
// swiper: 'Swiper',
|
|
62
|
+
// '@vuepic/vue-datepicker': 'VueDatePicker',
|
|
63
|
+
// qrcode: 'qrcode'
|
|
64
|
+
// }
|
|
65
|
+
// }
|
|
66
|
+
// },
|
|
67
|
+
// /** 设置为 false 可以禁用最小化混淆,或是用来指定使用哪种混淆器。
|
|
68
|
+
// 默认为 Esbuild,它比 terser 快 20-40 倍,压缩率只差 1%-2%。
|
|
69
|
+
// 注意,在 lib 模式下使用 'es' 时,build.minify 选项不会缩减空格,因为会移除掉 pure 标注,导致破坏 tree-shaking。
|
|
70
|
+
// 当设置为 'terser' 时必须先安装 Terser。(yarn add terser -D)
|
|
71
|
+
// */
|
|
72
|
+
// minify: 'terser', // Vite 2.6.x 以上需要配置 minify: "terser", terserOptions 才能生效
|
|
73
|
+
// terserOptions: { // 在打包代码时移除 console、debugger 和 注释
|
|
74
|
+
// compress: {
|
|
75
|
+
// /* (default: false) -- Pass true to discard calls to console.* functions.
|
|
76
|
+
// If you wish to drop a specific function call such as console.info and/or
|
|
77
|
+
// retain side effects from function arguments after dropping the function
|
|
78
|
+
// call then use pure_funcs instead
|
|
79
|
+
// */
|
|
80
|
+
// drop_console: true, // 生产环境时移除console
|
|
81
|
+
// drop_debugger: true // 生产环境时移除debugger
|
|
82
|
+
// },
|
|
83
|
+
// format: {
|
|
84
|
+
// comments: false // 删除注释comments
|
|
85
|
+
// }
|
|
86
|
+
// }
|
|
87
|
+
// },
|
|
88
|
+
// resolve: {
|
|
89
|
+
// alias,
|
|
90
|
+
// }
|
|
91
|
+
// })
|
|
92
|
+
//
|
|
93
|
+
//
|
|
94
|
+
//
|