initial commit

This commit is contained in:
leo 2024-07-19 01:11:13 +02:00
commit 84b0451db4
32 changed files with 5823 additions and 0 deletions

26
.gitignore vendored Normal file
View File

@ -0,0 +1,26 @@
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*
node_modules
dist
dist-ssr
*.local
# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?
.env

3
.vscode/extensions.json vendored Normal file
View File

@ -0,0 +1,3 @@
{
"recommendations": ["tauri-apps.tauri-vscode", "rust-lang.rust-analyzer"]
}

7
README.md Normal file
View File

@ -0,0 +1,7 @@
# Tauri + Vanilla TS
This template should help get you started developing with Tauri in vanilla HTML, CSS and Typescript.
## Recommended IDE Setup
- [VS Code](https://code.visualstudio.com/) + [Tauri](https://marketplace.visualstudio.com/items?itemName=tauri-apps.tauri-vscode) + [rust-analyzer](https://marketplace.visualstudio.com/items?itemName=rust-lang.rust-analyzer)

BIN
bun.lockb Normal file

Binary file not shown.

47
index.html Normal file
View File

@ -0,0 +1,47 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
#tauri-root {
width: 100vw;
height: 100vh;
background: black;
color: white;
overflow: hidden;
margin: 0;
padding: 0;
font-family: Arial, Helvetica, sans-serif;
}
#tauri-loading {
position: absolute;
display: inline;
z-index: 0;
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
text-align: center;
}
#tauri-frame {
position: absolute;
z-index: 1;
width: 100%;
height: 100%;
border: 0;
}
a, a:link, a:visited, a:hover, a:active {
color: white;
font-weight: bold;
}
</style>
<script type="module" src="/src/main.ts" defer></script>
</head>
<body id="tauri-root">
<div id="tauri-loading">Chargement...</div>
</body>
</html>

22
package.json Normal file
View File

@ -0,0 +1,22 @@
{
"name": "tbd-vc",
"private": true,
"version": "0.1.0",
"type": "module",
"scripts": {
"dev": "vite",
"build": "tsc && vite build",
"preview": "vite preview",
"tauri": "tauri"
},
"dependencies": {
"@tauri-apps/api": ">=2.0.0-beta.0",
"@tauri-apps/plugin-deep-link": "^2.0.0-beta.9",
"@tauri-apps/plugin-shell": ">=2.0.0-beta.0"
},
"devDependencies": {
"@tauri-apps/cli": ">=2.0.0-beta.0",
"vite": "^5.3.1",
"typescript": "^5.2.2"
}
}

7
src-tauri/.gitignore vendored Normal file
View File

@ -0,0 +1,7 @@
# Generated by Cargo
# will have compiled files and executables
/target/
# Generated by Tauri
# will have schema files for capabilities auto-completion
/gen/schemas

5302
src-tauri/Cargo.lock generated Normal file

File diff suppressed because it is too large Load Diff

23
src-tauri/Cargo.toml Normal file
View File

@ -0,0 +1,23 @@
[package]
name = "tbd-vc"
version = "0.1.0"
description = "Chat Vocal"
authors = ["Leo"]
edition = "2021"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[build-dependencies]
tauri-build = { version = "2.0.0-beta", features = [] }
[dependencies]
tauri = { version = "2.0.0-beta", features = ["devtools"] }
tauri-plugin-shell = "2.0.0-beta"
tauri-plugin-single-instance = "2.0.0-beta"
tauri-plugin-deep-link = "2.0.0-beta"
tauri-plugin-window-state = "2.0.0-beta"
serde = { version = "1", features = ["derive"] }
serde_json = "1"
[target."cfg(not(any(target_os = \"android\", target_os = \"ios\")))".dependencies]
tauri-plugin-updater = "2.0.0-beta.10"

3
src-tauri/build.rs Normal file
View File

@ -0,0 +1,3 @@
fn main() {
tauri_build::build()
}

View File

@ -0,0 +1,20 @@
{
"$schema": "../gen/schemas/desktop-schema.json",
"identifier": "default",
"description": "Capability for the main window",
"windows": [
"main"
],
"permissions": [
"path:default",
"event:default",
"window:default",
"app:default",
"image:default",
"resources:default",
"menu:default",
"tray:default",
"shell:allow-open",
"updater:default"
]
}

BIN
src-tauri/icons/128x128.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.9 KiB

BIN
src-tauri/icons/32x32.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 837 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 794 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

196
src-tauri/icons/icon.icns Normal file

File diff suppressed because one or more lines are too long

BIN
src-tauri/icons/icon.ico Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 288 KiB

BIN
src-tauri/icons/icon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.9 KiB

42
src-tauri/src/main.rs Normal file
View File

@ -0,0 +1,42 @@
// Prevents additional console window on Windows in release, DO NOT REMOVE!!
#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]
use tauri::{Emitter, Manager};
#[derive(Clone, serde::Serialize)]
struct Payload {
args: Vec<String>,
}
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_updater::Builder::new().build())
.plugin(tauri_plugin_shell::init())
.plugin(tauri_plugin_window_state::Builder::default().build())
.plugin(tauri_plugin_deep_link::init())
.plugin(tauri_plugin_single_instance::init(|app, argv, _cwd| {
let window = app.get_webview_window("main").expect("No window open");
if window.is_minimized().unwrap_or(true) {
let _ = window.maximize();
}
let _ = window.set_focus();
let args: Vec<String> = argv.into_iter().skip(1).collect();
if args.len() != 0 {
app.emit("open", Payload { args }).unwrap();
}
}))
.setup(|app| {
let window = app.get_webview_window("main").unwrap();
let argv: Vec<String> = std::env::args().collect();
let args: Vec<String> = argv.into_iter().skip(1).collect();
window.emit("open", Payload { args }).unwrap();
Ok(())
})
.run(tauri::generate_context!())
.expect("error while running tauri application");
}

49
src-tauri/tauri.conf.json Normal file
View File

@ -0,0 +1,49 @@
{
"productName": "tbd-vc",
"version": "0.1.0",
"identifier": "leo.tbd.vc",
"build": {
"beforeDevCommand": "bun run dev",
"devUrl": "http://localhost:1420",
"beforeBuildCommand": "bun run build",
"frontendDist": "../dist"
},
"app": {
"withGlobalTauri": true,
"windows": [
{
"title": "Chat Vocal",
"width": 800,
"height": 600,
"additionalBrowserArgs": "--autoplay-policy=no-user-gesture-required"
}
],
"security": {
"csp": null
}
},
"bundle": {
"active": true,
"targets": "all",
"icon": [
"icons/32x32.png",
"icons/128x128.png",
"icons/128x128@2x.png",
"icons/icon.icns",
"icons/icon.ico"
],
"createUpdaterArtifacts": true
},
"plugins": {
"deep-link": {
"mobile": [],
"desktop": {
"schemes": ["tbdvc"]
}
},
"updater": {
"pubkey": "dW50cnVzdGVkIGNvbW1lbnQ6IG1pbmlzaWduIHB1YmxpYyBrZXk6IEEyRkMxNzc1REUxMzE5NTkKUldSWkdSUGVkUmY4b3R0UCsra1lkanhzZldDVGZoTFFRRnpQTzBkRHplbmpkSXYvYkh6ekRBUy8K",
"endpoints": ["https://git.tarkacore.dev/mc-tbd/vc-app-metadata/raw/branch/main/version.json"]
}
}
}

34
src/main.ts Normal file
View File

@ -0,0 +1,34 @@
import { listen } from "@tauri-apps/api/event";
type OpenPayload = {
args: string[] // Never empty
};
listen("open", (ev) => {
// TODO move this to Rust
const payload = ev.payload as OpenPayload;
console.log(payload);
const link = payload.args.find((s) => s.startsWith("tbdvc:"));
if (!link) {
console.error("open called with no link");
return;
}
const url = new URL(link);
console.log(url.search)
window.location.href = `/${url.search}`
});
if (window.location.search === "") {
document.getElementById("tauri-loading")!.innerHTML = `Chat Vocal v0.1.0 par Leo
<br>
<br>
Connecte-toi au serveur Minecraft pour continuer.
<br>
Il est recommandé d'utiliser le <a href="https://git.tarkacore.dev/mc-tbd/vc-fabric/releases" target="_blank">Mod Fabric</a> pour automatiquement lancer cette application.`
} else {
const frame = document.createElement("iframe");
frame.id = "tauri-frame";
frame.src = "https://mc-audio.tarkacore.dev" + window.location.search;
frame.allow = "microphone;autoplay";
document.getElementById("tauri-root")!.append(frame)
}

23
tsconfig.json Normal file
View File

@ -0,0 +1,23 @@
{
"compilerOptions": {
"target": "ES2020",
"useDefineForClassFields": true,
"module": "ESNext",
"lib": ["ES2020", "DOM", "DOM.Iterable"],
"skipLibCheck": true,
/* Bundler mode */
"moduleResolution": "bundler",
"allowImportingTsExtensions": true,
"resolveJsonModule": true,
"isolatedModules": true,
"noEmit": true,
/* Linting */
"strict": true,
"noUnusedLocals": true,
"noUnusedParameters": true,
"noFallthroughCasesInSwitch": true
},
"include": ["src"]
}

19
vite.config.ts Normal file
View File

@ -0,0 +1,19 @@
import { defineConfig } from "vite";
// https://vitejs.dev/config/
export default defineConfig(async () => ({
// Vite options tailored for Tauri development and only applied in `tauri dev` or `tauri build`
//
// 1. prevent vite from obscuring rust errors
clearScreen: false,
// 2. tauri expects a fixed port, fail if that port is not available
server: {
port: 1420,
strictPort: true,
watch: {
// 3. tell vite to ignore watching `src-tauri`
ignored: ["**/src-tauri/**"],
},
},
}));