mirror of
				https://github.com/ajnart/homarr.git
				synced 2025-10-31 02:25:57 +01:00 
			
		
		
		
	feat: Multiple QoL updates
This commit is contained in:
		
							
								
								
									
										52
									
								
								.github/ISSUE_TEMPLATE/bug.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								.github/ISSUE_TEMPLATE/bug.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | |||||||
|  | name: 🐛 Bug Report | ||||||
|  | description: Report something that's broken, or not working like intented! | ||||||
|  | title: '[🐛 Bug] <title>' | ||||||
|  | labels: ['🐛 Bug'] | ||||||
|  | assignees: | ||||||
|  |   - ajnart | ||||||
|  | body: | ||||||
|  |   - type: dropdown | ||||||
|  |     id: environment | ||||||
|  |     attributes: | ||||||
|  |       label: Environment | ||||||
|  |       description: How have you deployed Homarr? | ||||||
|  |       options: | ||||||
|  |         - Docker | ||||||
|  |         - NodeJS | ||||||
|  |         - Cloud Service (Static) | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
|  |   - type: input | ||||||
|  |     id: version | ||||||
|  |     attributes: | ||||||
|  |       label: Version | ||||||
|  |       description: What version of Homarr are you running? | ||||||
|  |       placeholder: 0.1.0 | ||||||
|  |     validations: | ||||||
|  |       required: false | ||||||
|  |   - type: textarea | ||||||
|  |     id: repro | ||||||
|  |     attributes: | ||||||
|  |       label: Describe the problem | ||||||
|  |       description: Please describe the problem exactly, how to reproduce it, actual results, and expected results. | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
|  |   - type: textarea | ||||||
|  |     id: logs | ||||||
|  |     attributes: | ||||||
|  |       label: Additional info | ||||||
|  |       description: Logs? Screenshots? More info? | ||||||
|  |     validations: | ||||||
|  |       required: false | ||||||
|  |   - type: checkboxes | ||||||
|  |     id: idiot-check | ||||||
|  |     attributes: | ||||||
|  |       label: Please tick the boxes | ||||||
|  |       description: Before submitting, please ensure that | ||||||
|  |       options: | ||||||
|  |         - label: You've read the [docs](https://github.com/ajnart/homarr#readme) | ||||||
|  |           required: true | ||||||
|  |         - label: You've checked for [duplicate issues](https://github.com/ajnart/homarr/issues) | ||||||
|  |           required: true | ||||||
|  |         - label: You've tried to debug yourself | ||||||
|  |           required: true | ||||||
							
								
								
									
										25
									
								
								.github/ISSUE_TEMPLATE/feature-request.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								.github/ISSUE_TEMPLATE/feature-request.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | |||||||
|  | name: ✨ Feature Request | ||||||
|  | description: Request a feature to help improve Homarr! | ||||||
|  | title: '[✨ Feature] <title>' | ||||||
|  | labels: ['✨ Feature'] | ||||||
|  | assignees: | ||||||
|  |   - ajnart | ||||||
|  | body: | ||||||
|  |   - type: textarea | ||||||
|  |     id: feature | ||||||
|  |     attributes: | ||||||
|  |       label: Describe the feature you would like to see | ||||||
|  |       placeholder: An outline of the feature you would like to see implemented, include as much detail as possible! | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
|  |   - type: dropdown | ||||||
|  |     id: priority | ||||||
|  |     attributes: | ||||||
|  |       label: Priority | ||||||
|  |       description: How urgent is the development of this feature? | ||||||
|  |       options: | ||||||
|  |         - Low (Nice-to-have) | ||||||
|  |         - Medium (Would be very useful) | ||||||
|  |         - High (App breaking feature) | ||||||
|  |     validations: | ||||||
|  |       required: true | ||||||
| @@ -1,33 +0,0 @@ | |||||||
| # MyHomePage, a home page for your home server |  | ||||||
| ### Do not hesitate to star ⭐ this repo if you like the project !  |  | ||||||
| ### Join the discord ! : https://discord.gg/C2WTXkzkwK  |  | ||||||
| ## What is MyHomePage ? |  | ||||||
|  |  | ||||||
| HomePage is a web page for your home server, it provides a user friendly interface to access docker containers or other services. |  | ||||||
|  |  | ||||||
| ## Install |  | ||||||
| ### Docker installation |  | ||||||
| Required : Docker |  | ||||||
| #### Standard docker install |  | ||||||
| To install the MyHomePage docker image simply execute ``docker pull ghcr.io/ajnart/mhp``   |  | ||||||
| To run the docker file ``docker run --name my-home-page -p 7575:80 -d ghcr.io/ajnart/mhp``   |  | ||||||
|  |  | ||||||
| *Note: Currently the port used is 80 (Nginx default port) It will change to be 7575 by default*   |  | ||||||
| #### Docker compose |  | ||||||
| Here's a docker compose example on how to integrate MHP into your container stack |  | ||||||
| ```docker |  | ||||||
| services: |  | ||||||
|   mhp: |  | ||||||
|     image: ghcr.io/ajnart/mhp |  | ||||||
|     ports: |  | ||||||
|       - '7575:80' |  | ||||||
|     restart: always |  | ||||||
| ``` |  | ||||||
| ### Local installation |  | ||||||
| Required: Node (LTS) |  | ||||||
| #### Install using node |  | ||||||
| To install MyHomePage locally: |  | ||||||
| - Clone the source code or download it. |  | ||||||
| - Execute ``npm install`` or ``yarn install`` *(prefered)* to install the dependencies |  | ||||||
| - Execute ``yarn export`` to build the source code into the final HTML pages in the ``./out`` folder |  | ||||||
| - Run a web server to serve the content of the ``./out`` folder. Example: ``python -m http.server 7575 --directory out`` |  | ||||||
| @@ -5,6 +5,9 @@ | |||||||
|     A homepage for <i>your</i> server. |     A homepage for <i>your</i> server. | ||||||
|   <br/> |   <br/> | ||||||
|   <a href = "https://github.com/ajnart/homarr/deployments/activity_log?environment=Production" > <strong> Demo ↗️ </strong> </a> • <a href = "#install" > <strong> Install ➡️ </strong> </a> |   <a href = "https://github.com/ajnart/homarr/deployments/activity_log?environment=Production" > <strong> Demo ↗️ </strong> </a> • <a href = "#install" > <strong> Install ➡️ </strong> </a> | ||||||
|  |   <br /> | ||||||
|  |   <br /> | ||||||
|  |   <a href = "https://discord.gg/aCsmEV5RgA" > <img src="https://discordapp.com/api/guilds/972958686051962910/widget.png?style=shield" > </a> | ||||||
| </p> | </p> | ||||||
| </p> | </p> | ||||||
|  |  | ||||||
| @@ -15,6 +18,7 @@ | |||||||
|   - [⚡ Installation](#-installation) |   - [⚡ Installation](#-installation) | ||||||
|     - [Deploying from Docker Image 🐳](#deploying-from-docker-image-) |     - [Deploying from Docker Image 🐳](#deploying-from-docker-image-) | ||||||
|     - [Building from Source 🛠️](#building-from-source-️) |     - [Building from Source 🛠️](#building-from-source-️) | ||||||
|  | - [💖 Contributing](#-contributing) | ||||||
|  |  | ||||||
| <!-- Getting Started --> | <!-- Getting Started --> | ||||||
| # 🚀 Getting Started | # 🚀 Getting Started | ||||||
| @@ -62,10 +66,12 @@ _Requirements_: | |||||||
|  |  | ||||||
| **Installing** | **Installing** | ||||||
|  |  | ||||||
| - Clone the GitHub repo: `git clone https://github.com/ajnart/homarr.git` & `cd myhomepage` | - Clone the GitHub repo: `git clone https://github.com/ajnart/homarr.git` & `cd homarr` | ||||||
| - Install all dependencies: `yarn install` | - Install all dependencies: `yarn install` | ||||||
| - Build the source: `yarn export` | - Build the source: `yarn export` | ||||||
| - Start a web server (Any web server will work): | - Start a web server (Any web server will work): | ||||||
|   - _Examples:_ |   - _Examples:_ | ||||||
|     - NodeJS serve: `npm i -g serve` or `yarn global add serve` & `serve ./out` |     - NodeJS serve: `npm i -g serve` or `yarn global add serve` & `serve ./out` | ||||||
|     - python http.server: `python -m http.server 7474 --directory out` |     - python http.server: `python -m http.server 7474 --directory out` | ||||||
|  |  | ||||||
|  | # 💖 Contributing | ||||||
|   | |||||||
| @@ -82,11 +82,7 @@ function MatchIcon( | |||||||
|     apiKey: any; |     apiKey: any; | ||||||
|   }> |   }> | ||||||
| ) { | ) { | ||||||
|   // TODO: In order to avoid all the requests, we could fetch |   fetch(`https://cdn.jsdelivr.net/gh/walkxhub/dashboard-icons/png/${name.replace(/\s+/g, '-').toLowerCase()}.png`) | ||||||
|   // https://data.jsdelivr.com/v1/package/gh/IceWhaleTech/AppIcon@main |  | ||||||
|   // and then iterate over the files -> files -> name and then remove the extension (.png) |  | ||||||
|   // Compare it to the input and then fetch the icon |  | ||||||
|   fetch(`https://cdn.jsdelivr.net/gh/walkxhub/dashboard-icons/png/${name.toLowerCase()}.png`) |  | ||||||
|     .then((res) => { |     .then((res) => { | ||||||
|       if (res.status === 200) { |       if (res.status === 200) { | ||||||
|         form.setFieldValue('icon', res.url); |         form.setFieldValue('icon', res.url); | ||||||
|   | |||||||
| @@ -60,7 +60,7 @@ export function Footer({ links }: FooterCenteredProps) { | |||||||
|     > |     > | ||||||
|       <Group className={classes.links}>{items}</Group> |       <Group className={classes.links}>{items}</Group> | ||||||
|       <Group spacing="xs" position="right" noWrap> |       <Group spacing="xs" position="right" noWrap> | ||||||
|         <ActionIcon<'a'> component="a" href="https://github.com/ajnart/myhomepage" size="lg"> |         <ActionIcon<'a'> component="a" href="https://github.com/ajnart/homarr" size="lg"> | ||||||
|           <BrandGithub size={18} /> |           <BrandGithub size={18} /> | ||||||
|         </ActionIcon> |         </ActionIcon> | ||||||
|       </Group> |       </Group> | ||||||
|   | |||||||
| @@ -2,14 +2,9 @@ import { Text } from '@mantine/core'; | |||||||
| import * as React from 'react'; | import * as React from 'react'; | ||||||
|  |  | ||||||
| export function Logo({ style }: any) { | export function Logo({ style }: any) { | ||||||
|   return ( | 	return ( | ||||||
|     <Text | 		<Text sx={style} weight="bold" variant="gradient" gradient={{ from: 'red', to: 'orange', deg: 145 }}> | ||||||
|       sx={style} | 			Homarr | ||||||
|       weight="bold" | 		</Text> | ||||||
|       variant="gradient" | 	); | ||||||
|       gradient={{ from: 'red', to: 'orange', deg: 145 }} |  | ||||||
|     > |  | ||||||
|       MyHomePage |  | ||||||
|     </Text> |  | ||||||
|   ); |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										166
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										166
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,84 +1,84 @@ | |||||||
| { | { | ||||||
|   "name": "homarr", | 	"name": "homarr", | ||||||
|   "version": "0.0.1", | 	"version": "0.0.1", | ||||||
|   "private": "false", | 	"private": "false", | ||||||
|   "description": "Customizable browser's home page to interact with your homeserver's Docker containers (i.e. Sonarr/Radarr)", | 	"description": "Homarr -  A homepage for your server.", | ||||||
|   "repository": { | 	"repository": { | ||||||
|     "type": "git", | 		"type": "git", | ||||||
|     "url": "https://github.com/ajnart/myhomepage" | 		"url": "https://github.com/ajnart/homarr" | ||||||
|   }, | 	}, | ||||||
|   "scripts": { | 	"scripts": { | ||||||
|     "dev": "next dev", | 		"dev": "next dev", | ||||||
|     "build": "next build", | 		"build": "next build", | ||||||
|     "analyze": "ANALYZE=true next build", | 		"analyze": "ANALYZE=true next build", | ||||||
|     "start": "next start", | 		"start": "next start", | ||||||
|     "typecheck": "tsc --noEmit", | 		"typecheck": "tsc --noEmit", | ||||||
|     "export": "next build && next export", | 		"export": "next build && next export", | ||||||
|     "lint": "next lint", | 		"lint": "next lint", | ||||||
|     "jest": "jest", | 		"jest": "jest", | ||||||
|     "jest:watch": "jest --watch", | 		"jest:watch": "jest --watch", | ||||||
|     "prettier:check": "prettier --check \"**/*.{ts,tsx}\"", | 		"prettier:check": "prettier --check \"**/*.{ts,tsx}\"", | ||||||
|     "prettier:write": "prettier --write \"**/*.{ts,tsx}\"", | 		"prettier:write": "prettier --write \"**/*.{ts,tsx}\"", | ||||||
|     "test": "npm run prettier:check && npm run lint && npm run typecheck && npm run jest", | 		"test": "npm run prettier:check && npm run lint && npm run typecheck && npm run jest", | ||||||
|     "storybook": "start-storybook -p 7001", | 		"storybook": "start-storybook -p 7001", | ||||||
|     "storybook:build": "build-storybook" | 		"storybook:build": "build-storybook" | ||||||
|   }, | 	}, | ||||||
|   "dependencies": { | 	"dependencies": { | ||||||
|     "@mantine/core": "^4.2.1", | 		"@mantine/core": "^4.2.1", | ||||||
|     "@mantine/dates": "^4.2.1", | 		"@mantine/dates": "^4.2.1", | ||||||
|     "@mantine/dropzone": "^4.2.1", | 		"@mantine/dropzone": "^4.2.1", | ||||||
|     "@mantine/form": "^4.2.1", | 		"@mantine/form": "^4.2.1", | ||||||
|     "@mantine/hooks": "^4.2.1", | 		"@mantine/hooks": "^4.2.1", | ||||||
|     "@mantine/modals": "^4.2.1", | 		"@mantine/modals": "^4.2.1", | ||||||
|     "@mantine/next": "^4.2.1", | 		"@mantine/next": "^4.2.1", | ||||||
|     "@mantine/notifications": "^4.2.1", | 		"@mantine/notifications": "^4.2.1", | ||||||
|     "@mantine/prism": "^4.2.1", | 		"@mantine/prism": "^4.2.1", | ||||||
|     "@mantine/spotlight": "^4.2.1", | 		"@mantine/spotlight": "^4.2.1", | ||||||
|     "@modulz/radix-icons": "^4.0.0", | 		"@modulz/radix-icons": "^4.0.0", | ||||||
|     "cookies-next": "^2.0.4", | 		"cookies-next": "^2.0.4", | ||||||
|     "dayjs": "^1.11.1", | 		"dayjs": "^1.11.1", | ||||||
|     "framer-motion": "^6.3.1", | 		"framer-motion": "^6.3.1", | ||||||
|     "js-file-download": "^0.4.12", | 		"js-file-download": "^0.4.12", | ||||||
|     "next": "12.1.5-canary.4", | 		"next": "12.1.5-canary.4", | ||||||
|     "prism-react-renderer": "^1.3.1", | 		"prism-react-renderer": "^1.3.1", | ||||||
|     "react": "18.0.0", | 		"react": "18.0.0", | ||||||
|     "react-dom": "18.0.0", | 		"react-dom": "18.0.0", | ||||||
|     "tabler-icons-react": "^1.46.0" | 		"tabler-icons-react": "^1.46.0" | ||||||
|   }, | 	}, | ||||||
|   "devDependencies": { | 	"devDependencies": { | ||||||
|     "@babel/core": "^7.17.8", | 		"@babel/core": "^7.17.8", | ||||||
|     "@next/bundle-analyzer": "^12.1.4", | 		"@next/bundle-analyzer": "^12.1.4", | ||||||
|     "@next/eslint-plugin-next": "^12.1.4", | 		"@next/eslint-plugin-next": "^12.1.4", | ||||||
|     "@storybook/addon-essentials": "^6.4.22", | 		"@storybook/addon-essentials": "^6.4.22", | ||||||
|     "@storybook/addon-links": "^6.4.22", | 		"@storybook/addon-links": "^6.4.22", | ||||||
|     "@storybook/react": "^6.4.22", | 		"@storybook/react": "^6.4.22", | ||||||
|     "@testing-library/dom": "^8.12.0", | 		"@testing-library/dom": "^8.12.0", | ||||||
|     "@testing-library/jest-dom": "^5.16.3", | 		"@testing-library/jest-dom": "^5.16.3", | ||||||
|     "@testing-library/react": "^13.0.0", | 		"@testing-library/react": "^13.0.0", | ||||||
|     "@testing-library/user-event": "^14.0.4", | 		"@testing-library/user-event": "^14.0.4", | ||||||
|     "@types/jest": "^27.4.1", | 		"@types/jest": "^27.4.1", | ||||||
|     "@types/node": "^17.0.23", | 		"@types/node": "^17.0.23", | ||||||
|     "@types/react": "17.0.43", | 		"@types/react": "17.0.43", | ||||||
|     "@typescript-eslint/eslint-plugin": "^5.16.0", | 		"@typescript-eslint/eslint-plugin": "^5.16.0", | ||||||
|     "@typescript-eslint/parser": "^5.16.0", | 		"@typescript-eslint/parser": "^5.16.0", | ||||||
|     "babel-loader": "^8.2.4", | 		"babel-loader": "^8.2.4", | ||||||
|     "eslint": "^8.11.0", | 		"eslint": "^8.11.0", | ||||||
|     "eslint-config-airbnb": "19.0.4", | 		"eslint-config-airbnb": "19.0.4", | ||||||
|     "eslint-config-airbnb-typescript": "^16.1.4", | 		"eslint-config-airbnb-typescript": "^16.1.4", | ||||||
|     "eslint-config-mantine": "1.1.0", | 		"eslint-config-mantine": "1.1.0", | ||||||
|     "eslint-plugin-import": "^2.25.4", | 		"eslint-plugin-import": "^2.25.4", | ||||||
|     "eslint-plugin-jest": "^26.1.3", | 		"eslint-plugin-jest": "^26.1.3", | ||||||
|     "eslint-plugin-jsx-a11y": "^6.5.1", | 		"eslint-plugin-jsx-a11y": "^6.5.1", | ||||||
|     "eslint-plugin-react": "^7.29.4", | 		"eslint-plugin-react": "^7.29.4", | ||||||
|     "eslint-plugin-react-hooks": "^4.3.0", | 		"eslint-plugin-react-hooks": "^4.3.0", | ||||||
|     "eslint-plugin-storybook": "^0.5.11", | 		"eslint-plugin-storybook": "^0.5.11", | ||||||
|     "eslint-plugin-testing-library": "^5.2.0", | 		"eslint-plugin-testing-library": "^5.2.0", | ||||||
|     "eslint-plugin-unused-imports": "^2.0.0", | 		"eslint-plugin-unused-imports": "^2.0.0", | ||||||
|     "jest": "^27.5.1", | 		"jest": "^27.5.1", | ||||||
|     "prettier": "^2.6.2", | 		"prettier": "^2.6.2", | ||||||
|     "storybook-addon-turbo-build": "^1.1.0", | 		"storybook-addon-turbo-build": "^1.1.0", | ||||||
|     "storybook-dark-mode": "^1.0.9", | 		"storybook-dark-mode": "^1.0.9", | ||||||
|     "ts-jest": "^27.1.4", | 		"ts-jest": "^27.1.4", | ||||||
|     "typescript": "4.6.3" | 		"typescript": "4.6.3" | ||||||
|   } | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -22,7 +22,7 @@ export default function App(props: AppProps & { colorScheme: ColorScheme }) { | |||||||
|   return ( |   return ( | ||||||
|     <> |     <> | ||||||
|       <Head> |       <Head> | ||||||
|         <title>MyHomePage - Your new browser homepage!</title> |         <title>Homarr -  A homepage for your server!</title> | ||||||
|         <meta name="viewport" content="minimum-scale=1, initial-scale=1, width=device-width" /> |         <meta name="viewport" content="minimum-scale=1, initial-scale=1, width=device-width" /> | ||||||
|         <link rel="shortcut icon" href="/favicon.svg" /> |         <link rel="shortcut icon" href="/favicon.svg" /> | ||||||
|       </Head> |       </Head> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user