7 Commits

Author SHA1 Message Date
theis.gaedigk ab6ccdcc48 Merge branch 'development' into debian12 2026-03-26 23:32:25 +01:00
theis.gaedigk 1b83ed51cb changed logo 2026-03-26 23:31:52 +01:00
theis.gaedigk 2e6ea96fbb Merge branch 'development' into debian12 2026-03-26 23:06:58 +01:00
theis.gaedigk 6f839a67f4 added icon 2026-03-26 23:06:20 +01:00
theis.gaedigk bdb8f9bb64 updated conf 2026-01-27 10:49:59 +01:00
theis.gaedigk df3802ff50 changed container name 2025-11-29 17:28:47 +01:00
theis.gaedigk 388cff9368 changed back to old header 2025-11-26 19:39:58 +01:00
10 changed files with 20 additions and 24 deletions
+3 -1
View File
@@ -111,4 +111,6 @@ backend/public/uploads/
# API keys and secrets (additional protection) # API keys and secrets (additional protection)
config/ config/
secrets/ secrets/
keys/ keys/
icon/
-6
View File
@@ -1,6 +0,0 @@
#!/bin/bash
cd /pfad/zu/deinem/repo
while true; do
git pull || echo "git pull failed"
sleep 10
done
+1 -5
View File
@@ -4,17 +4,13 @@ services:
build: ./frontend build: ./frontend
networks: networks:
- proxynet - proxynet
ports:
- "7002:80"
restart: unless-stopped restart: unless-stopped
backend: backend:
container_name: backend container_name: weather-backend
build: ./backend build: ./backend
networks: networks:
- proxynet - proxynet
ports:
- "7001:7001"
volumes: volumes:
- ./backend:/bikelane-backend - ./backend:/bikelane-backend
restart: unless-stopped restart: unless-stopped
+2 -6
View File
@@ -1,12 +1,8 @@
<!DOCTYPE html> <!doctype html>
<html lang="en"> <html lang="en">
<head> <head>
<meta charset="UTF-8" /> <meta charset="UTF-8" />
<link <link rel="icon" type="image/png" href="/icon_weather-app_dark.png" />
rel="icon"
type="image/svg+xml"
href="./src/assets/cloud-sun-fill.png"
/>
<meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Weather App</title> <title>Weather App</title>
</head> </head>
+8
View File
@@ -9,6 +9,14 @@ server {
try_files $uri $uri/ /index.html; try_files $uri $uri/ /index.html;
} }
location = /backend {
return 301 /backend/;
}
location /backend/ {
proxy_pass http://weather-backend:7001/;
}
location ~* \.(?:js|mjs|css|png|jpg|jpeg|gif|ico|svg|woff2?)$ { location ~* \.(?:js|mjs|css|png|jpg|jpeg|gif|ico|svg|woff2?)$ {
expires 1y; expires 1y;
access_log off; access_log off;
Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 MiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 MiB

-1
View File
@@ -1 +0,0 @@
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="31.88" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 257"><defs><linearGradient id="IconifyId1813088fe1fbc01fb466" x1="-.828%" x2="57.636%" y1="7.652%" y2="78.411%"><stop offset="0%" stop-color="#41D1FF"></stop><stop offset="100%" stop-color="#BD34FE"></stop></linearGradient><linearGradient id="IconifyId1813088fe1fbc01fb467" x1="43.376%" x2="50.316%" y1="2.242%" y2="89.03%"><stop offset="0%" stop-color="#FFEA83"></stop><stop offset="8.333%" stop-color="#FFDD35"></stop><stop offset="100%" stop-color="#FFA800"></stop></linearGradient></defs><path fill="url(#IconifyId1813088fe1fbc01fb466)" d="M255.153 37.938L134.897 252.976c-2.483 4.44-8.862 4.466-11.382.048L.875 37.958c-2.746-4.814 1.371-10.646 6.827-9.67l120.385 21.517a6.537 6.537 0 0 0 2.322-.004l117.867-21.483c5.438-.991 9.574 4.796 6.877 9.62Z"></path><path fill="url(#IconifyId1813088fe1fbc01fb467)" d="M185.432.063L96.44 17.501a3.268 3.268 0 0 0-2.634 3.014l-5.474 92.456a3.268 3.268 0 0 0 3.997 3.378l24.777-5.718c2.318-.535 4.413 1.507 3.936 3.838l-7.361 36.047c-.495 2.426 1.782 4.5 4.151 3.78l15.304-4.649c2.372-.72 4.652 1.36 4.15 3.788l-11.698 56.621c-.732 3.542 3.979 5.473 5.943 2.437l1.313-2.028l72.516-144.72c1.215-2.423-.88-5.186-3.54-4.672l-25.505 4.922c-2.396.462-4.435-1.77-3.759-4.114l16.646-57.705c.677-2.35-1.37-4.583-3.769-4.113Z"></path></svg>

Before

Width:  |  Height:  |  Size: 1.5 KiB

+5 -4
View File
@@ -1,9 +1,10 @@
import React from "react"; import React from "react";
import ChangeAPI from "./ChangeAPI"; import ChangeAPI from "./ChangeAPI";
import ChangePreferences from "./ChangePreferences"; import ChangePreferences from "./ChangePreferences";
import { myToast } from "../utils/toastify";
import { useState } from "react"; import { useState } from "react";
import Cookies from "js-cookie"; import Cookies from "js-cookie";
import logo from "../assets/cloud-sun-fill.png"; import logo from "/icon_weather-app_default.png";
import { Github, KeyRound, Settings2 } from "lucide-react"; import { Github, KeyRound, Settings2 } from "lucide-react";
const Header: React.FC = () => { const Header: React.FC = () => {
@@ -21,15 +22,15 @@ const Header: React.FC = () => {
className="w-10 h-10 drop-shadow-lg" className="w-10 h-10 drop-shadow-lg"
/> />
<h1 className="text-4xl font-extrabold tracking-wide drop-shadow-lg"> <h1 className="text-4xl font-extrabold tracking-wide drop-shadow-lg">
Weather App - <strong>Local hosted</strong> Weather App - <strong>Web</strong>
</h1> </h1>
</div> </div>
<div className="flex items-center gap-4"> <div className="flex items-center gap-4">
{" "} {" "}
{/* Added container for buttons */} {/* Added container for buttons */}
<button <button
className="cursor-pointer bg-white text-blue-700 font-bold px-6 py-3 rounded-xl shadow-lg hover:bg-blue-100 transition-all border border-blue-200 flex items-center gap-2" className="bg-gray-200 text-gray-400 font-bold px-6 py-3 rounded-xl shadow-lg border border-gray-300 flex items-center gap-2 cursor-not-allowed opacity-60"
onClick={() => setApiCard(true)} onClick={() => myToast("You don't need to set an API Key!", "info")}
> >
<span className="flex items-center gap-2"> <span className="flex items-center gap-2">
<KeyRound /> <KeyRound />
+1 -1
View File
@@ -3,7 +3,7 @@ import { myToast } from "./toastify";
export const fetchWeather = async (city: string, units: string) => { export const fetchWeather = async (city: string, units: string) => {
try { try {
const response = await fetch( const response = await fetch(
`https://backend.weather.the1s.de/api/fetchWeather?city=${encodeURIComponent( `https://weather.the1s.de/backend/api/fetchWeather?city=${encodeURIComponent(
city city
)}&units=${encodeURIComponent(units)}`, )}&units=${encodeURIComponent(units)}`,
{ {