mirror of
https://github.com/FoggedLens/deflock.git
synced 2026-02-12 15:02:45 +00:00
initial commit
This commit is contained in:
32
.gitignore
vendored
Normal file
32
.gitignore
vendored
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
# Logs
|
||||||
|
logs
|
||||||
|
*.log
|
||||||
|
npm-debug.log*
|
||||||
|
yarn-debug.log*
|
||||||
|
yarn-error.log*
|
||||||
|
pnpm-debug.log*
|
||||||
|
lerna-debug.log*
|
||||||
|
|
||||||
|
node_modules
|
||||||
|
.DS_Store
|
||||||
|
dist
|
||||||
|
dist-ssr
|
||||||
|
coverage
|
||||||
|
*.local
|
||||||
|
|
||||||
|
/cypress/videos/
|
||||||
|
/cypress/screenshots/
|
||||||
|
|
||||||
|
# Editor directories and files
|
||||||
|
.vscode/*
|
||||||
|
!.vscode/extensions.json
|
||||||
|
.idea
|
||||||
|
*.suo
|
||||||
|
*.ntvs*
|
||||||
|
*.njsproj
|
||||||
|
*.sln
|
||||||
|
*.sw?
|
||||||
|
|
||||||
|
*.tsbuildinfo
|
||||||
|
|
||||||
|
project/**/target/
|
||||||
3
.vscode/extensions.json
vendored
Normal file
3
.vscode/extensions.json
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"recommendations": ["Vue.volar"]
|
||||||
|
}
|
||||||
1
shotgun/.bsp/sbt.json
Normal file
1
shotgun/.bsp/sbt.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{"name":"sbt","version":"1.9.1","bspVersion":"2.1.0-M1","languages":["scala"],"argv":["/Users/willfreeman/Library/Caches/Coursier/arc/https/github.com/adoptium/temurin17-binaries/releases/download/jdk-17.0.10%252B7/OpenJDK17U-jdk_x64_mac_hotspot_17.0.10_7.tar.gz/jdk-17.0.10+7/Contents/Home/bin/java","-Xms100m","-Xmx100m","-classpath","/Users/willfreeman/Library/Caches/Coursier/arc/https/github.com/sbt/sbt/releases/download/v1.8.2/sbt-1.8.2.zip/sbt/bin/sbt-launch.jar","-Dsbt.script=/Users/willfreeman/Library/Caches/Coursier/arc/https/github.com/sbt/sbt/releases/download/v1.8.2/sbt-1.8.2.zip/sbt/bin/sbt","xsbt.boot.Boot","-bsp"]}
|
||||||
70
shotgun/.gitignore
vendored
Normal file
70
shotgun/.gitignore
vendored
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
#
|
||||||
|
# Are you tempted to edit this file?
|
||||||
|
#
|
||||||
|
# First consider if the changes make sense for all,
|
||||||
|
# or if they are specific to your workflow/system.
|
||||||
|
# If it is the latter, you can augment this list with
|
||||||
|
# entries in .git/info/excludes
|
||||||
|
#
|
||||||
|
# see also test/files/.gitignore
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# JARs aren't checked in, they are fetched by sbt
|
||||||
|
#
|
||||||
|
/lib/*.jar
|
||||||
|
/test/files/codelib/*.jar
|
||||||
|
/test/files/lib/*.jar
|
||||||
|
/test/files/speclib/instrumented.jar
|
||||||
|
/tools/*.jar
|
||||||
|
|
||||||
|
# Developer specific properties
|
||||||
|
/build.properties
|
||||||
|
/buildcharacter.properties
|
||||||
|
|
||||||
|
# might get generated when testing Jenkins scripts locally
|
||||||
|
/jenkins.properties
|
||||||
|
|
||||||
|
# target directory for build
|
||||||
|
/build/
|
||||||
|
|
||||||
|
# other
|
||||||
|
/out/
|
||||||
|
/bin/
|
||||||
|
/sandbox/
|
||||||
|
|
||||||
|
# intellij
|
||||||
|
/src/intellij*/*.iml
|
||||||
|
/src/intellij*/*.ipr
|
||||||
|
/src/intellij*/*.iws
|
||||||
|
**/.cache
|
||||||
|
/.idea
|
||||||
|
/.settings
|
||||||
|
|
||||||
|
# vscode
|
||||||
|
/.vscode
|
||||||
|
|
||||||
|
# Standard symbolic link to build/quick/bin
|
||||||
|
/qbin
|
||||||
|
|
||||||
|
# sbt's target directories
|
||||||
|
/target/
|
||||||
|
/project/**/target/
|
||||||
|
/test/macro-annot/target/
|
||||||
|
/test/files/target/
|
||||||
|
/test/target/
|
||||||
|
/build-sbt/
|
||||||
|
local.sbt
|
||||||
|
jitwatch.out
|
||||||
|
|
||||||
|
# Used by the restarr/restarrFull commands as target directories
|
||||||
|
/build-restarr/
|
||||||
|
/target-restarr/
|
||||||
|
|
||||||
|
# metals
|
||||||
|
.metals
|
||||||
|
.bloop
|
||||||
|
project/**/metals.sbt
|
||||||
|
|
||||||
|
.bsp
|
||||||
|
.history
|
||||||
20
shotgun/build.sbt
Normal file
20
shotgun/build.sbt
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
import Dependencies._
|
||||||
|
|
||||||
|
ThisBuild / scalaVersion := "2.12.8"
|
||||||
|
ThisBuild / version := "0.1.0-SNAPSHOT"
|
||||||
|
ThisBuild / organization := "me.deflock"
|
||||||
|
ThisBuild / organizationName := "DeFlock"
|
||||||
|
|
||||||
|
lazy val root = (project in file("."))
|
||||||
|
.settings(
|
||||||
|
name := "shotgun",
|
||||||
|
libraryDependencies += scalaTest % Test,
|
||||||
|
)
|
||||||
|
|
||||||
|
val PekkoVersion = "1.0.3"
|
||||||
|
val PekkoHttpVersion = "1.0.1"
|
||||||
|
libraryDependencies ++= Seq(
|
||||||
|
"org.apache.pekko" %% "pekko-actor-typed" % PekkoVersion,
|
||||||
|
"org.apache.pekko" %% "pekko-stream" % PekkoVersion,
|
||||||
|
"org.apache.pekko" %% "pekko-http" % PekkoHttpVersion
|
||||||
|
)
|
||||||
5
shotgun/project/Dependencies.scala
Normal file
5
shotgun/project/Dependencies.scala
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
import sbt._
|
||||||
|
|
||||||
|
object Dependencies {
|
||||||
|
lazy val scalaTest = "org.scalatest" %% "scalatest" % "3.0.5"
|
||||||
|
}
|
||||||
1
shotgun/project/build.properties
Normal file
1
shotgun/project/build.properties
Normal file
@@ -0,0 +1 @@
|
|||||||
|
sbt.version=1.9.1
|
||||||
@@ -0,0 +1,37 @@
|
|||||||
|
package me.deflock.shotgun
|
||||||
|
|
||||||
|
import org.apache.pekko
|
||||||
|
import pekko.actor.typed.ActorSystem
|
||||||
|
import pekko.actor.typed.scaladsl.Behaviors
|
||||||
|
import pekko.http.scaladsl.Http
|
||||||
|
import pekko.http.scaladsl.model._
|
||||||
|
import pekko.http.scaladsl.server.Directives._
|
||||||
|
|
||||||
|
import scala.concurrent.ExecutionContextExecutor
|
||||||
|
import scala.io.StdIn
|
||||||
|
|
||||||
|
object ShotgunServer {
|
||||||
|
|
||||||
|
def main(args: Array[String]): Unit = {
|
||||||
|
|
||||||
|
implicit val system: ActorSystem[Any] = ActorSystem(Behaviors.empty, "my-system")
|
||||||
|
implicit val executionContext: ExecutionContextExecutor = system.executionContext
|
||||||
|
|
||||||
|
val route =
|
||||||
|
path("oauth2" / "callback") {
|
||||||
|
get {
|
||||||
|
parameters(Symbol("code").?) { (code) =>
|
||||||
|
complete(HttpEntity(ContentTypes.`text/html(UTF-8)`, "<h1>Say hello to Pekko HTTP</h1><p><b>Code: " + code.getOrElse("None") + "</b></p>"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
val bindingFuture = Http().newServerAt("localhost", 8080).bind(route)
|
||||||
|
|
||||||
|
println(s"Server now online. Please navigate to http://localhost:8080\nPress RETURN to stop...")
|
||||||
|
StdIn.readLine() // let it run until user presses return
|
||||||
|
bindingFuture
|
||||||
|
.flatMap(_.unbind()) // trigger unbinding from the port
|
||||||
|
.onComplete(_ => system.terminate()) // and shutdown when done
|
||||||
|
}
|
||||||
|
}
|
||||||
9
shotgun/src/test/scala/example/HelloSpec.scala
Normal file
9
shotgun/src/test/scala/example/HelloSpec.scala
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
package example
|
||||||
|
|
||||||
|
import org.scalatest._
|
||||||
|
|
||||||
|
class HelloSpec extends FlatSpec with Matchers {
|
||||||
|
"The Hello object" should "say hello" in {
|
||||||
|
Hello.greeting shouldEqual "hello"
|
||||||
|
}
|
||||||
|
}
|
||||||
33
webapp/README.md
Normal file
33
webapp/README.md
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
# deflock
|
||||||
|
|
||||||
|
This template should help get you started developing with Vue 3 in Vite.
|
||||||
|
|
||||||
|
## Recommended IDE Setup
|
||||||
|
|
||||||
|
[VSCode](https://code.visualstudio.com/) + [Volar](https://marketplace.visualstudio.com/items?itemName=Vue.volar) (and disable Vetur).
|
||||||
|
|
||||||
|
## Type Support for `.vue` Imports in TS
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
## Customize configuration
|
||||||
|
|
||||||
|
See [Vite Configuration Reference](https://vitejs.dev/config/).
|
||||||
|
|
||||||
|
## Project Setup
|
||||||
|
|
||||||
|
```sh
|
||||||
|
npm install
|
||||||
|
```
|
||||||
|
|
||||||
|
### Compile and Hot-Reload for Development
|
||||||
|
|
||||||
|
```sh
|
||||||
|
npm run dev
|
||||||
|
```
|
||||||
|
|
||||||
|
### Type-Check, Compile and Minify for Production
|
||||||
|
|
||||||
|
```sh
|
||||||
|
npm run build
|
||||||
|
```
|
||||||
1
webapp/env.d.ts
vendored
Normal file
1
webapp/env.d.ts
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
/// <reference types="vite/client" />
|
||||||
13
webapp/index.html
Normal file
13
webapp/index.html
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<link rel="icon" href="/favicon.ico">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>Vite App</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div id="app"></div>
|
||||||
|
<script type="module" src="/src/main.ts"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
2323
webapp/package-lock.json
generated
Normal file
2323
webapp/package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
31
webapp/package.json
Normal file
31
webapp/package.json
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
{
|
||||||
|
"name": "deflock",
|
||||||
|
"version": "0.0.0",
|
||||||
|
"private": true,
|
||||||
|
"type": "module",
|
||||||
|
"scripts": {
|
||||||
|
"dev": "vite",
|
||||||
|
"build": "run-p type-check \"build-only {@}\" --",
|
||||||
|
"preview": "vite preview",
|
||||||
|
"build-only": "vite build",
|
||||||
|
"type-check": "vue-tsc --build --force"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"vue": "^3.4.29",
|
||||||
|
"vue-router": "^4.3.3",
|
||||||
|
"vuetify": "^3.7.2"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"@mdi/font": "^7.4.47",
|
||||||
|
"@tsconfig/node20": "^20.1.4",
|
||||||
|
"@types/node": "^20.14.5",
|
||||||
|
"@vitejs/plugin-vue": "^5.0.5",
|
||||||
|
"@vue-leaflet/vue-leaflet": "^0.10.1",
|
||||||
|
"@vue/tsconfig": "^0.5.1",
|
||||||
|
"leaflet": "^1.9.4",
|
||||||
|
"npm-run-all2": "^6.2.0",
|
||||||
|
"typescript": "~5.4.0",
|
||||||
|
"vite": "^5.3.1",
|
||||||
|
"vue-tsc": "^2.0.21"
|
||||||
|
}
|
||||||
|
}
|
||||||
BIN
webapp/public/deflock-logo.png
Normal file
BIN
webapp/public/deflock-logo.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 23 KiB |
BIN
webapp/public/favicon.ico
Normal file
BIN
webapp/public/favicon.ico
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 4.2 KiB |
53
webapp/src/App.vue
Normal file
53
webapp/src/App.vue
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import { RouterView } from 'vue-router'
|
||||||
|
import { ref } from 'vue'
|
||||||
|
|
||||||
|
const items = [
|
||||||
|
{ title: 'Home', icon: 'mdi-home', to: '/' },
|
||||||
|
{ title: 'About', icon: 'mdi-information', to: '/about' },
|
||||||
|
]
|
||||||
|
const drawer = ref(false)
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<v-app>
|
||||||
|
<v-app-bar
|
||||||
|
flat
|
||||||
|
prominent
|
||||||
|
>
|
||||||
|
<v-app-bar-nav-icon variant="text" @click.stop="drawer = !drawer"></v-app-bar-nav-icon>
|
||||||
|
|
||||||
|
<v-toolbar-title>
|
||||||
|
<v-img height="36" width="200" src="/deflock-logo.png" />
|
||||||
|
</v-toolbar-title>
|
||||||
|
|
||||||
|
<v-spacer></v-spacer>
|
||||||
|
|
||||||
|
<template v-if="$vuetify.display.mdAndUp">
|
||||||
|
<v-btn icon="mdi-magnify" variant="text"></v-btn>
|
||||||
|
|
||||||
|
<v-btn icon="mdi-filter" variant="text"></v-btn>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<v-btn icon="mdi-dots-vertical" variant="text"></v-btn>
|
||||||
|
</v-app-bar>
|
||||||
|
|
||||||
|
<v-navigation-drawer
|
||||||
|
v-model="drawer"
|
||||||
|
temporary
|
||||||
|
>
|
||||||
|
<v-list nav>
|
||||||
|
<v-list-item
|
||||||
|
v-for="item in items"
|
||||||
|
:key="item.title"
|
||||||
|
link
|
||||||
|
:to="item.to"
|
||||||
|
>{{ item.title }}</v-list-item>
|
||||||
|
</v-list>
|
||||||
|
</v-navigation-drawer>
|
||||||
|
|
||||||
|
<v-main>
|
||||||
|
<RouterView />
|
||||||
|
</v-main>
|
||||||
|
</v-app>
|
||||||
|
</template>
|
||||||
0
webapp/src/assets/main.css
Normal file
0
webapp/src/assets/main.css
Normal file
23
webapp/src/main.ts
Normal file
23
webapp/src/main.ts
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
import './assets/main.css'
|
||||||
|
|
||||||
|
import { createApp } from 'vue'
|
||||||
|
import App from './App.vue'
|
||||||
|
import router from './router'
|
||||||
|
|
||||||
|
import 'vuetify/styles'
|
||||||
|
import { createVuetify } from 'vuetify'
|
||||||
|
import * as components from 'vuetify/components'
|
||||||
|
import * as directives from 'vuetify/directives'
|
||||||
|
import '@mdi/font/css/materialdesignicons.css' // Ensure you are using css-loader
|
||||||
|
|
||||||
|
const vuetify = createVuetify({
|
||||||
|
components,
|
||||||
|
directives,
|
||||||
|
})
|
||||||
|
|
||||||
|
const app = createApp(App)
|
||||||
|
|
||||||
|
app.use(router)
|
||||||
|
app.use(vuetify)
|
||||||
|
|
||||||
|
app.mount('#app')
|
||||||
23
webapp/src/router/index.ts
Normal file
23
webapp/src/router/index.ts
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
import { createRouter, createWebHistory } from 'vue-router'
|
||||||
|
import HomeView from '../views/HomeView.vue'
|
||||||
|
|
||||||
|
const router = createRouter({
|
||||||
|
history: createWebHistory(import.meta.env.BASE_URL),
|
||||||
|
routes: [
|
||||||
|
{
|
||||||
|
path: '/',
|
||||||
|
name: 'home',
|
||||||
|
component: HomeView
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: '/about',
|
||||||
|
name: 'about',
|
||||||
|
// route level code-splitting
|
||||||
|
// this generates a separate chunk (About.[hash].js) for this route
|
||||||
|
// which is lazy-loaded when the route is visited.
|
||||||
|
component: () => import('../views/AboutView.vue')
|
||||||
|
}
|
||||||
|
]
|
||||||
|
})
|
||||||
|
|
||||||
|
export default router
|
||||||
15
webapp/src/views/AboutView.vue
Normal file
15
webapp/src/views/AboutView.vue
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
<template>
|
||||||
|
<div class="about">
|
||||||
|
<h1>This is an about page</h1>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
@media (min-width: 1024px) {
|
||||||
|
.about {
|
||||||
|
min-height: 100vh;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
62
webapp/src/views/HomeView.vue
Normal file
62
webapp/src/views/HomeView.vue
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
<template>
|
||||||
|
<div class="map-container">
|
||||||
|
<!-- use-global-leaflet=false is a workaround for a bug in current version of vue-leaflet -->
|
||||||
|
<l-map v-if="center" ref="map" v-model:zoom="zoom" :center="center" :use-global-leaflet="false">
|
||||||
|
<l-tile-layer
|
||||||
|
url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
|
||||||
|
layer-type="base"
|
||||||
|
name="OpenStreetMap"
|
||||||
|
></l-tile-layer>
|
||||||
|
</l-map>
|
||||||
|
<div v-else>
|
||||||
|
loading...
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
import 'leaflet/dist/leaflet.css';
|
||||||
|
import { LMap, LTileLayer, LMarker } from '@vue-leaflet/vue-leaflet';
|
||||||
|
import { ref, onMounted } from 'vue';
|
||||||
|
import type { Ref } from 'vue';
|
||||||
|
|
||||||
|
const zoom: Ref<number> = ref(12);
|
||||||
|
const center: Ref<[number, number]|null> = ref(null);
|
||||||
|
|
||||||
|
function getUserLocation(): Promise<[number, number]> {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
if (navigator.geolocation) {
|
||||||
|
navigator.geolocation.getCurrentPosition(
|
||||||
|
(position) => {
|
||||||
|
resolve([position.coords.latitude, position.coords.longitude]);
|
||||||
|
},
|
||||||
|
(error) => {
|
||||||
|
reject(error);
|
||||||
|
},
|
||||||
|
{
|
||||||
|
timeout: 10000,
|
||||||
|
enableHighAccuracy: true,
|
||||||
|
}
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
reject(new Error('Geolocation is not supported by this browser.'));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
getUserLocation()
|
||||||
|
.then(location => {
|
||||||
|
center.value = location;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.map-container {
|
||||||
|
width: 100%;
|
||||||
|
height: calc(100vh - 64px);
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
14
webapp/tsconfig.app.json
Normal file
14
webapp/tsconfig.app.json
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"extends": "@vue/tsconfig/tsconfig.dom.json",
|
||||||
|
"include": ["env.d.ts", "src/**/*", "src/**/*.vue"],
|
||||||
|
"exclude": ["src/**/__tests__/*"],
|
||||||
|
"compilerOptions": {
|
||||||
|
"composite": true,
|
||||||
|
"tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo",
|
||||||
|
|
||||||
|
"baseUrl": ".",
|
||||||
|
"paths": {
|
||||||
|
"@/*": ["./src/*"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
11
webapp/tsconfig.json
Normal file
11
webapp/tsconfig.json
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"files": [],
|
||||||
|
"references": [
|
||||||
|
{
|
||||||
|
"path": "./tsconfig.node.json"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "./tsconfig.app.json"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
19
webapp/tsconfig.node.json
Normal file
19
webapp/tsconfig.node.json
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
"extends": "@tsconfig/node20/tsconfig.json",
|
||||||
|
"include": [
|
||||||
|
"vite.config.*",
|
||||||
|
"vitest.config.*",
|
||||||
|
"cypress.config.*",
|
||||||
|
"nightwatch.conf.*",
|
||||||
|
"playwright.config.*"
|
||||||
|
],
|
||||||
|
"compilerOptions": {
|
||||||
|
"composite": true,
|
||||||
|
"noEmit": true,
|
||||||
|
"tsBuildInfoFile": "./node_modules/.tmp/tsconfig.node.tsbuildinfo",
|
||||||
|
|
||||||
|
"module": "ESNext",
|
||||||
|
"moduleResolution": "Bundler",
|
||||||
|
"types": ["node"]
|
||||||
|
}
|
||||||
|
}
|
||||||
16
webapp/vite.config.ts
Normal file
16
webapp/vite.config.ts
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
import { fileURLToPath, URL } from 'node:url'
|
||||||
|
|
||||||
|
import { defineConfig } from 'vite'
|
||||||
|
import vue from '@vitejs/plugin-vue'
|
||||||
|
|
||||||
|
// https://vitejs.dev/config/
|
||||||
|
export default defineConfig({
|
||||||
|
plugins: [
|
||||||
|
vue(),
|
||||||
|
],
|
||||||
|
resolve: {
|
||||||
|
alias: {
|
||||||
|
'@': fileURLToPath(new URL('./src', import.meta.url))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
Reference in New Issue
Block a user