team-9/app/src/App.tsx

57 lines
1.6 KiB
TypeScript
Raw Normal View History

2025-08-02 04:50:15 +02:00
import "./App.css";
import "./theme/variables.css";
import "@ionic/react/css/core.css";
import "@ionic/react/css/display.css";
import "@ionic/react/css/flex-utils.css";
import "@ionic/react/css/float-elements.css";
import "@ionic/react/css/normalize.css";
import "@ionic/react/css/padding.css";
import "@ionic/react/css/palettes/dark.system.css";
import "@ionic/react/css/structure.css";
import "@ionic/react/css/text-alignment.css";
import "@ionic/react/css/text-transformation.css";
import "@ionic/react/css/typography.css";
import { IonApp, setupIonicReact } from "@ionic/react";
import { IonReactRouter } from "@ionic/react-router";
import { useAtom } from "jotai";
import { useEffect, useState } from "react";
import { currentTrackAtom } from "./atoms";
import { mocks } from "./mocks";
import Tab from "./pages/Tab3";
import LocationAccessChecker from "./hooks/GeoAccess";
2025-08-02 02:08:59 +02:00
/* Core CSS required for Ionic components to work properly */
/* Basic CSS for apps built with Ionic */
/* Optional CSS utils that can be commented out */
/* Dark mode */
/* Theme variables */
/* Custom CSS */
setupIonicReact();
const App: React.FC = () => {
2025-08-02 04:50:15 +02:00
const [current, setCurrent] = useAtom(currentTrackAtom);
const [accessGranted, setAccessGranted] = useState<boolean | null>(null);
2025-08-02 02:08:59 +02:00
useEffect(() => {
2025-08-02 04:50:15 +02:00
setCurrent(mocks.nowPlaying);
}, []);
// if (accessGranted === false) {
// console.log("access denied.");
// return null;
// }
2025-08-02 02:08:59 +02:00
return (
<IonApp>
2025-08-02 04:50:15 +02:00
<LocationAccessChecker onAccessChecked={setAccessGranted} />
2025-08-02 02:08:59 +02:00
<IonReactRouter>
<Tab />
</IonReactRouter>
</IonApp>
);
};
export default App;