Compare commits

..

28 commits
0.1.3 ... main

Author SHA1 Message Date
025ff6a42f Fix indenting 2024-01-01 20:51:22 +00:00
a54baf4b3d Setup registry for buildx + Update CI to current defaults 2024-01-01 20:42:26 +00:00
677b762a71
Merge remote-tracking branch 'origin/main' 2023-12-20 22:33:19 +01:00
a5e6c6fa3b
Release 0.1.8 2023-12-20 22:32:39 +01:00
8fda8a7309
Remove Gitlab CI & Fix Dockerfile 2023-12-20 22:32:28 +01:00
197b10cccf Update .forgejo/workflows/build+release.yml 2023-12-20 21:27:22 +00:00
46c5b39d6b
Release 0.1.7 2023-12-20 22:04:41 +01:00
929df2f3bb
Add Forgejo Actions 2023-12-20 22:03:36 +01:00
4bc9ef0804
Update .gitignore 2023-12-20 22:03:28 +01:00
9d7109d66c
Update Dockerfile 2023-12-20 22:03:04 +01:00
Neshura
4117477283
Update package.json 2023-03-06 19:07:52 +01:00
Neshura
12c7ef2a8e
Change Host to IPv6 2023-03-06 18:47:14 +01:00
Neshura
8a2e88e302
Changed Port for Production 2023-03-06 18:39:37 +01:00
Neshura
9406dbdc5d
Change Port to 8002 2023-03-06 18:29:59 +01:00
Neshura
098a4cad1d
URL-fix 2023-01-14 21:09:01 +01:00
Neshura
aaad32a51d
Renamed Sidebar component and updated Node Version 2022-12-14 18:39:39 +01:00
Neshura
ac25eb3708
Typo in Dockerfile 2022-12-09 22:02:27 +01:00
Neshura
086fa54a02 Merge branch 'feature/sidebar-transition' into 'main'
Added transition to the sidebar

See merge request 
2022-12-09 20:39:06 +00:00
Neshura
e767db6017
Added transition to the sidebar 2022-12-09 21:38:23 +01:00
Neshura
989b9e5ae9 Merge branch 'rework/sidebar' into 'main'
Small changes to the sidebar and repo

Closes 

See merge request 
2022-12-09 17:32:41 +00:00
Neshura
758cb6a9f0
Various changes
Removed debug logging, implemented Issue 
2022-12-09 18:29:47 +01:00
Neshura
fbc815e776
Moved Sidebarplaceholder to sidebar component
Potentially equal size to the sidebar in the future
2022-12-09 18:28:58 +01:00
Neshura
df0326f9ff
Added undefined Size state to useWindowsize 2022-12-09 18:28:23 +01:00
Neshura
9cba3c50c9
Changed Arrow color and added flipped verison 2022-12-04 16:43:10 +01:00
Neshura
8177802bb3
Extract windowsize function from map script 2022-12-04 16:42:49 +01:00
Neshura
6fa3d727b0
Add vscode folder to gitignore 2022-12-04 16:42:25 +01:00
Neshura
e63d696e49
Only run CI/CD when Tag is present
oops
2022-12-04 01:43:23 +01:00
Neshura
7406f311b1
Specify test branch using t in front 2022-12-04 01:42:28 +01:00
18 changed files with 255 additions and 141 deletions

View file

@ -0,0 +1,95 @@
name: 'Build and Release Docker Image'
author: 'Neshura'
on:
push:
tags:
- '[0-9]+.[0-9]+.[0-9]+'
- '[0-9]+.[0-9]+.[0-9]+-rc.[0-9]+'
jobs:
test:
runs-on: docker
steps:
-
name: Checking Out Repository Code
uses: https://code.forgejo.org/actions/checkout@v3
-
name: Get Yarn Cache Directory
id: yarn-cache-dir-path
run: echo "dir=$(yarn cache dir)" >> $GITHUB_OUTPUT
-
name: Set Up Yarn Cache
uses: actions/cache@v3
id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`)
with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
-
name: Install Dependencies
run: yarn install
-
name: Run Linter
run: yarn lint
-
name: Check if Version in package.json matches Tag
run: |
VERSION=$(cat package.json | grep "version" | sed 's/.*://' | tr -d , | tr -d \" | tr -d " " )
if test $VERSION != "${{ github.ref_name }}"; then
echo "Expected Version is: '${{ github.ref_name }}' actual Version is: '$VERSION'";
exit 1
else
echo "Version is: '$VERSION'";
fi
build:
needs: test
if: success()
runs-on: dind
steps:
-
name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
with:
config-inline: |
[registry."docker.io"]
mirrors = ["https://docker-cache.neshweb.net"]
-
name: Login to Docker Hub
uses: docker/login-action@v3
with:
registry: forgejo.neshweb.net
username: ${{ secrets.FORGEJO_USERNAME }}
password: ${{ secrets.FORGEJO_TOKEN }}
-
name: Determine Docker tags
id: tags
run: |
if echo ${{ github.ref_name }} | grep -qi '\-rc' ; then
echo latest=forgejo.neshweb.net/neshweb-sites/${{ github.event.repository.name }}:preview >> $GITHUB_OUTPUT;
else
echo latest=forgejo.neshweb.net/neshweb-sites/${{ github.event.repository.name }}:latest >> $GITHUB_OUTPUT;
fi
echo version=forgejo.neshweb.net/neshweb-sites/${{ github.event.repository.name }}:${{ github.ref_name }} >> $GITHUB_OUTPUT;
-
name: Push to Package Registry
uses: docker/build-push-action@v5
with:
push: true
tags: ${{ steps.tags.outputs.version }}, ${{ steps.tags.outputs.latest }}
release:
needs: build
if: success()
runs-on: docker
steps:
-
name: Release New Version
uses: actions/forgejo-release@v1
with:
direction: upload
url: https://forgejo.neshweb.net
release-dir: release
token: ${{ secrets.FORGEJO_TOKEN }}
tag: ${{ github.ref_name }}

View file

@ -0,0 +1,35 @@
name: 'Run Tests on Code'
author: 'Neshura'
on:
push:
tags-ignore:
- '**'
branches:
- '**'
jobs:
test:
runs-on: docker
steps:
-
name: Checking Out Repository Code
uses: https://code.forgejo.org/actions/checkout@v3
-
name: Get Yarn Cache Directory
id: yarn-cache-dir-path
run: echo "dir=$(yarn cache dir)" >> $GITHUB_OUTPUT
-
name: Set Up Yarn Cache
uses: actions/cache@v3
id: yarn-cache # use this to check for `cache-hit` (`steps.yarn-cache.outputs.cache-hit != 'true'`)
with:
path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
-
name: Install Dependencies
run: yarn install
-
name: Run Linter
run: yarn lint

13
.gitignore vendored
View file

@ -1,8 +1,9 @@
# do not track installed modules
/node_modules
node_modules/
# do not track built files
/.next
.vscode/
.next/
*.tsbuildinfo
next-env.d.ts
@ -13,6 +14,8 @@ yarn-error.log*
.pnpm-debug.log*
# production
/build
/data
/confs
build/
data/
confs/
.idea/

View file

@ -1,70 +0,0 @@
# avoids unecessary repulling of node modules
cache:
paths:
- node_modules/
stages:
- lint
#- test
- build
- deploy
variables:
IMAGE_TAG: $CI_REGISTRY_IMAGE:$CI_COMMIT_TAG
IMAGE_LATEST: $CI_REGISTRY_IMAGE:develop
.node:
image: ${CI_DEPENDENCY_PROXY_GROUP_IMAGE_PREFIX}/node:latest
.docker:
image: ${CI_DEPENDENCY_PROXY_GROUP_IMAGE_PREFIX}/docker:20
rules:
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH && $CI_COMMIT_TAG
variables:
IMAGE_LATEST: $CI_REGISTRY_IMAGE:latest
- if: $CI_COMMIT_TAG
linter:
image: !reference [.node, image]
stage: lint
before_script:
- yarn install
script:
- yarn lint
build:
image: !reference [.docker, image]
stage: build
before_script:
- docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
script:
- docker build -t $IMAGE_TAG .
after_script:
- docker save $IMAGE_TAG > docker.tar
artifacts:
expire_in: 30 mins
paths:
- docker.tar
rules:
- !reference [.docker, rules]
push:
image: !reference [.docker, image]
stage: deploy
needs:
- job: build
artifacts: true
before_script:
- docker login -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY
- docker load -i docker.tar
script:
- docker tag $IMAGE_TAG $IMAGE_LATEST
- docker push $IMAGE_TAG
- docker push $IMAGE_LATEST
rules:
- !reference [.docker, rules]

View file

@ -1,17 +1,18 @@
## INIT STEP
# Install dependencies only when needed
FROM node:16-alpine AS deps
FROM node:18-alpine AS deps
RUN apk add --no-cache libc6-compat
WORKDIR /app
# Copy the files needed to install deps
COPY package.json yarn.lock ./
RUN yarn add sharp
RUN yarn install --frozen-lockfile
## BUILD STEP
# Rebuild the source code only when needed
FROM node:16-alpine AS builder
FROM node:18-alpine AS builder
WORKDIR /app
@ -23,10 +24,10 @@ COPY . .
RUN yarn build
## RUN STEP
FROM node:16-alpine AS runner
FROM node:18-alpine AS runner
LABEL author="neshura@proton.me"
WORKDIR /usr/src/ap
LABEL author="neshura@neshweb.net"
WORKDIR /usr/src/app
ENV NODE_ENV production

View file

@ -11,12 +11,12 @@ const LayoutReadyOrNot = ({ children }: { children: React.ReactNode }) => {
var _paq = window._paq = window._paq || [];
/* tracker methods like "setCustomDimension" should be called before "trackPageView" */
_paq.push(["setDocumentTitle", document.domain + "/" + document.title]);
_paq.push(["setCookieDomain", "readyornot.neshura-server.net"]);
_paq.push(["setCookieDomain", "readyornot.neshweb.net"]);
_paq.push(["disableCookies"]);
_paq.push(['trackPageView']);
_paq.push(['enableLinkTracking']);
(function() {
var u="//temp.neshura-server.net/";
var u="//tracking.neshweb.net/";
_paq.push(['setTrackerUrl', u+'matomo.php']);
_paq.push(['setSiteId', '2']);
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
@ -26,7 +26,6 @@ const LayoutReadyOrNot = ({ children }: { children: React.ReactNode }) => {
</Script>
<Sidebar />
<div className={styles.sidebarPlaceholder}></div>
<main className={styles.main}>
{children}
</main>

View file

@ -4,7 +4,8 @@ import { useRouter } from 'next/router'
import useSWR from 'swr';
import ReadyOrNotMap from '../interfaces/ReadyOrNot';
import React, { useState } from 'react';
import Image from 'next/image'
import Image from 'next/image';
import useWindowSize from '../components/windowsize';
const fetcher = (url: string) => fetch(url).then((res) => res.json())
@ -12,37 +13,55 @@ function stopPropagation(e: any) {
e.stopPropagation();
}
const Sidebar = () => {
const isMobile = useWindowSize();
const router = useRouter();
const [active, setActive] = useState(true);
const { maps, isLoading, isError } = useNavbar();
const [active, setActive] = useState(isMobile);
const { maps, isLoading, isError }: { maps: ReadyOrNotMap[], isLoading: boolean, isError: boolean } = useNavbar();
if (isError) { return (<div><nav><a>Error loading Sidemenu</a></nav></div>) }
if (typeof (isMobile) === "boolean" && typeof (active) === "undefined") {
setActive(!isMobile);
}
if (isError) {
return (
<>
<div><nav><a>Error loading Sidemenu</a></nav></div>
<div className={styles.sidebarPlaceholder}></div>
</>
)
}
else if (isLoading) {
return (
<div>
<nav>
<a>Loading...</a>
</nav>
</div>
<>
<div>
<nav>
<a>Loading...</a>
</nav>
</div>
<div className={styles.sidebarPlaceholder}></div>
</>
)
}
else {
// > is a placeholder
return (
<div className={styles.sidebar} onClick={() => setActive(!active)}>
<nav className={[styles.sidebarList, (active ? styles.sl_active : styles.sl_inactive)].join(" ")}>
{maps.map((item: ReadyOrNotMap) => (
<Link key={item.name} href={item.href}>
<a className={[styles.navElem, (router.query.map == item.href ? styles.ne_active: styles.ne_inactive)].join(" ")} onClick={stopPropagation}>{item.name}</a>
</Link>
))}
</nav>
<div className={styles.sidebarArrow}>
<Image src="/sidebar_arrow.webp" width={32} height={96} alt=">"/>
<>
<div className={styles.sidebar} onClick={() => setActive(!active)}>
<div className={[styles.sl_wrapper, (active ? styles.sl_active : styles.sl_inactive)].join(" ")}>
<nav className={styles.sidebarList}>
{maps.map((item) => (
<Link key={item.name} href={item.href}>
<a className={[styles.navElem, (router.query.map == item.href ? styles.ne_active : styles.ne_inactive)].join(" ")} onClick={stopPropagation}>{item.name}</a>
</Link>
))}
</nav>
</div>
<div className={styles.sidebarArrow}>
<Image src={active ? "/sidebar_arrow_flipped.webp" : "/sidebar_arrow.webp"} width={32} height={96} alt={active ? ">" : "<"} />
</div>
</div>
</div>
<div className={styles.sidebarPlaceholder}></div>
</>
);
}
}

34
components/windowsize.tsx Normal file
View file

@ -0,0 +1,34 @@
import { useEffect, useState } from "react";
interface ScreenSize {
width: number | undefined;
height: number | undefined;
}
export default function useWindowSize(): boolean | undefined {
const [windowSize, setWindowSize] = useState<ScreenSize>({
width: undefined,
height: undefined,
});
useEffect(() => {
function handleResize() {
setWindowSize({
width: window.innerWidth,
height: window.innerHeight,
});
}
window.addEventListener("resize", handleResize);
handleResize();
return () => window.removeEventListener("resize", handleResize);
}, []);
if(typeof(windowSize.width) === "number") {
return windowSize.width <= 1080;
}
else {
return undefined;
}
}

View file

@ -1,12 +1,12 @@
{
"name": "readyornot",
"version": "0.1.0",
"version": "0.1.8",
"private": true,
"scripts": {
"dev:debug": "NODE_OPTIONS='--inspect' next dev -p 4042",
"dev": "next dev",
"dev:debug": "NODE_OPTIONS='--inspect' next dev -H :: -p 8002",
"dev": "next dev -H :: -p 8002",
"build": "next build",
"start": "next start",
"start": "next start -H :: -p 8002",
"lint": "next lint"
},
"dependencies": {
@ -17,9 +17,10 @@
"swr": "^1.3.0"
},
"devDependencies": {
"@types/node": "18.14.6",
"@types/react": "^18.0.14",
"eslint": "^8.23.1",
"eslint-config-next": "12.2.0",
"@types/react": "^18.0.14",
"typescript": "4.9.3"
}
}

View file

@ -6,34 +6,12 @@ import { NextPageWithLayout } from './_app';
import React from 'react';
import useSWR, { KeyedMutator, mutate } from 'swr';
import { useRouter } from 'next/router';
import Image from 'next/image'
import Image from 'next/image';
import ReadyOrNotMap from '../interfaces/ReadyOrNot';
import useWindowSize from '../components/windowsize';
const fetcher = (url: string) => fetch(url).then((res) => res.json())
function useWindowSize() {
const [windowSize, setWindowSize] = useState({
width: 0,
height: 0,
});
useEffect(() => {
function handleResize() {
setWindowSize({
width: window.innerWidth,
height: window.innerHeight,
});
}
window.addEventListener("resize", handleResize);
handleResize();
return () => window.removeEventListener("resize", handleResize);
}, []);
return windowSize.width <= 1080;
}
const ReadyOrNotMaps: NextPageWithLayout = () => {
const [floor, setFloor] = useState(0);
const { mapInfo, isLoadingInfo, isErrorInfo } = useMap(useRouter().query.map?.toString() || "a_lethal_obsession")

View file

@ -3,7 +3,7 @@ import fsPromises from 'fs/promises'
import path from 'path'
import ReadyOrNotMap from '../../interfaces/ReadyOrNot'
export default async function TobarApi(req: any, res: any) {
export default async function SidebarAPI(req: any, res: any) {
try {
// get list of all folders(maps) in the readyornot folder - maybe there is a cleaner way to do this?
var fs = require('fs')

Binary file not shown.

Before

(image error) Size: 532 B

After

(image error) Size: 704 B

Binary file not shown.

After

(image error) Size: 696 B

View file

@ -28,8 +28,8 @@
inkscape:document-units="px"
showgrid="true"
inkscape:zoom="11.313709"
inkscape:cx="-3.1819805"
inkscape:cy="35.974057"
inkscape:cx="-3.1819804"
inkscape:cy="36.062444"
inkscape:window-width="2560"
inkscape:window-height="1391"
inkscape:window-x="0"
@ -52,7 +52,7 @@
id="layer1">
<path
id="path1211"
style="fill:#000000;fill-opacity:1;stroke:#000000;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
style="fill:#999999;fill-opacity:1;stroke:#999999;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
d="M 8,3.9708715 V 19.970872 c 3.449498,11.952732 9.599609,28.000391 9.599609,28.000391 L 8,75.970872 v 16 L 24,47.971263 C 18.666759,33.304433 13.333375,18.637654 8,3.9708715 Z"
sodipodi:nodetypes="ccccccc" />
</g>

Before

(image error) Size: 1.9 KiB

After

(image error) Size: 1.9 KiB

Binary file not shown.

Before

(image error) Size: 532 B

After

(image error) Size: 704 B

Binary file not shown.

After

(image error) Size: 696 B

View file

@ -174,15 +174,16 @@
.sidebarList {
overflow-y: scroll;
overflow-x: hidden;
scrollbar-width: none;
height: 100%;
display: flex;
flex-direction: column;
padding: 2rem;
flex-wrap: nowrap;
justify-content: flex-start;
align-items: flex-start;
background-color: var(--background_grey_opaque);
padding: 2rem;
}
.sidebar::-webkit-scrollbar {
@ -190,15 +191,28 @@
background: transparent;
}
.sl_wrapper {
height: 100%;
overflow: hidden;
transition-property: width, visibility;
transition-timing-function: ease-in-out, linear;
transition-duration: 0.3s, 0s;
}
.sl_active {
display: flex;
visibility: visible;
width: 97%;
transition-delay: 0s, 0s;
}
.sl_inactive {
display: none;
visibility: hidden;
width: 0;
transition-delay: 0s, 0.3s;
}
.navElem {
white-space:nowrap;
font-size: 14pt;
width: auto;
border-radius: 5px;

View file

@ -166,6 +166,11 @@
resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee"
integrity sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==
"@types/node@18.14.6":
version "18.14.6"
resolved "https://registry.yarnpkg.com/@types/node/-/node-18.14.6.tgz#ae1973dd2b1eeb1825695bb11ebfb746d27e3e93"
integrity sha512-93+VvleD3mXwlLI/xASjw0FzKcwzl3OdTCzm1LaRfqgS21gfFtK3zDXM5Op9TeeMsJVOaJ2VRDpT9q4Y3d0AvA==
"@types/prop-types@*":
version "15.7.5"
resolved "https://registry.yarnpkg.com/@types/prop-types/-/prop-types-15.7.5.tgz#5f19d2b85a98e9558036f6a3cacc8819420f05cf"