test(mobile): stallion intergration starts

This commit is contained in:
2025-11-16 20:21:08 -06:00
parent 75c0659658
commit 20fc286069
7 changed files with 7667 additions and 80 deletions

View File

@@ -1,3 +1,4 @@
import * as Updates from "expo-updates";
import React, { useState } from "react"; import React, { useState } from "react";
import { import {
Button, Button,
@@ -8,14 +9,13 @@ import {
TextInput, TextInput,
View, View,
} from "react-native"; } from "react-native";
import * as Updates from 'expo-updates';
export default function App() { export default function App() {
const [buffer, setBuffer] = useState(""); const [buffer, setBuffer] = useState("");
const [items, setItems] = useState<string[]>([]); const [items, setItems] = useState<string[]>([]);
const [status, setStatus] = useState(""); const [status, setStatus] = useState("");
const [updates, setUpdates] = useState("") const [updates, setUpdates] = useState("");
const handleChange = (text: string) => { const handleChange = (text: string) => {
// Scanner "types" characters then appends Enter (\n) // Scanner "types" characters then appends Enter (\n)
@@ -29,33 +29,32 @@ export default function App() {
}; };
async function checkServerUpdate() { async function checkServerUpdate() {
setUpdates('Checking for updates...'); setUpdates("Checking for updates...");
try { try {
const cacheBuster = `?t=${Date.now()}`; const cacheBuster = `?t=${Date.now()}`;
const res = await Updates.checkForUpdateAsync(); const res = await Updates.checkForUpdateAsync();
console.log('Update check result:', res); console.log("Update check result:", res);
if (res.isAvailable) { if (res.isAvailable) {
setUpdates('Update available! Downloading...'); setUpdates("Update available! Downloading...");
const fetchResult = await Updates.fetchUpdateAsync(); const fetchResult = await Updates.fetchUpdateAsync();
console.log('Fetch result:', fetchResult); console.log("Fetch result:", fetchResult);
if (fetchResult.isNew) { if (fetchResult.isNew) {
setUpdates('Update downloaded! Reloading app...'); setUpdates("Update downloaded! Reloading app...");
// Add a small delay to ensure everything is ready // Add a small delay to ensure everything is ready
setTimeout(() => { setTimeout(() => {
Updates.reloadAsync(); Updates.reloadAsync();
}, 1000); }, 1000);
} else { } else {
setUpdates('Update download completed but no new bundle?'); setUpdates("Update download completed but no new bundle?");
} }
} else { } else {
setUpdates('No new update available.'); setUpdates("No new update available.");
} }
} catch (e: any) { } catch (e: any) {
console.error('Update error:', e); console.error("Update error:", e);
setUpdates(`Update failed: ${e.message}`); setUpdates(`Update failed: ${e.message}`);
} }
} }
@@ -87,7 +86,6 @@ async function checkServerUpdate() {
return ( return (
<View style={styles.container}> <View style={styles.container}>
<Text>But maybe later i will be </Text> <Text>But maybe later i will be </Text>
<Button <Button
@@ -112,12 +110,15 @@ async function checkServerUpdate() {
width: 0, width: 0,
}} }}
/> />
<Pressable onPress={checkServerUpdate}style={{ <Pressable
onPress={checkServerUpdate}
style={{
marginVertical: 12, marginVertical: 12,
padding: 12, padding: 12,
backgroundColor: '#007AFF', backgroundColor: "#007AFF",
borderRadius: 6, borderRadius: 6,
}}> }}
>
<Text>Check Update</Text> <Text>Check Update</Text>
</Pressable> </Pressable>
<Text>Update Data</Text> <Text>Update Data</Text>
@@ -129,9 +130,7 @@ async function checkServerUpdate() {
/> />
<Text style={styles.status}>{status}</Text> <Text style={styles.status}>{status}</Text>
</View> </View>
); );
} }

17
mobileLst/babel.config.js Normal file
View File

@@ -0,0 +1,17 @@
module.exports = function (api) {
api.cache(true);
return {
presets: ["babel-preset-expo"],
plugins: [
[
"module-resolver",
{
root: ["./"],
alias: {
"@": "./",
},
},
],
],
};
};

12
mobileLst/metro.config.ts Normal file
View File

@@ -0,0 +1,12 @@
const { getDefaultConfig } = require("@expo/metro-config");
const path = require("path");
const projectRoot = __dirname;
const config = getDefaultConfig(projectRoot);
config.resolver.alias = {
...config.resolver.alias,
"@": path.resolve(projectRoot),
};
module.exports = config;

File diff suppressed because it is too large Load Diff

View File

@@ -49,7 +49,11 @@
"react-native-worklets": "0.5.1" "react-native-worklets": "0.5.1"
}, },
"devDependencies": { "devDependencies": {
"@react-native-community/cli": "^20.0.2",
"@react-native/metro-config": "^0.82.1",
"@types/react": "~19.1.0", "@types/react": "~19.1.0",
"babel-plugin-module-resolver": "^5.0.2",
"babel-preset-expo": "^54.0.7",
"eslint": "^9.25.0", "eslint": "^9.25.0",
"eslint-config-expo": "~10.0.0", "eslint-config-expo": "~10.0.0",
"typescript": "~5.9.2" "typescript": "~5.9.2"

5757
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -73,6 +73,8 @@
}, },
"devDependencies": { "devDependencies": {
"@biomejs/biome": "2.2.6", "@biomejs/biome": "2.2.6",
"@react-native-community/cli": "^20.0.2",
"@react-native/metro-config": "^0.82.1",
"@types/express": "^5.0.3", "@types/express": "^5.0.3",
"@types/morgan": "^1.9.10", "@types/morgan": "^1.9.10",
"@types/mssql": "^9.1.8", "@types/mssql": "^9.1.8",
@@ -82,6 +84,8 @@
"@types/pg": "^8.15.5", "@types/pg": "^8.15.5",
"@types/swagger-jsdoc": "^6.0.4", "@types/swagger-jsdoc": "^6.0.4",
"@types/swagger-ui-express": "^4.1.8", "@types/swagger-ui-express": "^4.1.8",
"babel-plugin-module-resolver": "^5.0.2",
"babel-preset-expo": "^54.0.7",
"concurrently": "^9.2.1", "concurrently": "^9.2.1",
"cz-conventional-changelog": "^3.3.0", "cz-conventional-changelog": "^3.3.0",
"standard-version": "^9.5.0", "standard-version": "^9.5.0",