2024-05-26 16:36:45 -04:00
2024-05-21 22:38:17 -04:00
2024-05-26 16:36:45 -04:00
2024-05-26 16:36:45 -04:00
2024-05-24 00:52:23 -04:00
2024-05-24 17:57:03 -04:00
2024-05-24 20:52:39 -04:00
2024-05-26 14:10:40 -04:00
2024-05-26 02:14:59 -04:00
2024-05-24 00:16:02 -04:00
2024-05-26 03:46:00 -04:00
2024-05-24 17:57:03 -04:00
2024-05-26 14:10:40 -04:00
2024-05-26 02:14:59 -04:00
2024-05-24 17:57:03 -04:00
2024-05-21 22:35:37 -04:00
2024-05-26 03:47:09 -04:00
2024-05-24 17:57:03 -04:00
2024-05-24 17:57:03 -04:00
2024-05-24 17:57:03 -04:00
2024-05-26 03:46:00 -04:00
2024-05-26 03:46:00 -04:00
2024-05-24 17:57:03 -04:00
2024-05-26 13:10:45 -04:00
2024-05-26 02:14:59 -04:00
2024-05-24 17:57:03 -04:00

Neroshitron

image

Documentation For Technical Stack

Running Backend

  1. Open your terminal and navigate to the root of the git repository.
  2. Make sure that docker and docker compose are installed.
  3. Run docker-compose --env-file ./docker.env up which will start up OwnCast, AppWrite, and the UI.

MailDev

http://localhost:1080 This is where all mail being sent shows up from the application for developers.

OwnCast

http://localhost:8080/ Configuration is done through the Owncast administration page located on your server under /admin. The login username is admin and the password is your stream key, the default being abc123.

Supabase

http://localhost:8000/ You will need to register and sign up, the first account on the appwrite instance will be the admin account.çConfiguration is done through the Owncast administration page located on your server under /admin. The login username is admin and the password is your stream key, the default being abc123.

Running UI

  1. Open your terminal and navigate to the root folder of the git repository.
  2. Run the command npm update.
  3. Once the depedencies are pulled and installed you can run the command npm run dev to run the application in development mode.
  4. Open http://localhost:3000/

React Components

The Gallery component is a React component used to display a gallery of images. It fetches images from an API and displays them in a Masonry layout.

Props

  • id (number): The ID of the gallery to fetch images from.
  • closeMenu (function): A function to close the menu.

State

  • isSingle (boolean): A state to check if only a single image is to be displayed.
  • loaded (object): A state to keep track of loaded images.
  • selectedImage (string | null): A state to keep track of the selected image.
  • images (string[]): A state to store the fetched images.
  • galleryId (number): A state to store the gallery ID.

Functions

  • getData: An async function to fetch images from the API.
  • generateRandomString: A function to generate a random string of a given length.
  • handleDownload: A function to handle the download of an image.

Usage

The example below will load the images of the the gallery with an ID of 58201557-b392-471e-ac55-dcf6171cd18d and will call the function for setIsOpen(false) when the back button is clicked.

    <Gallery id={"58201557-b392-471e-ac55-dcf6171cd18d"} closeMenu={() => setIsOpen(false)}></Gallery>

GalleryThumbnail Component

The GalleryThumbnail component is a React component used to display a thumbnail of a gallery. It fetches the thumbnail image from an API and displays it. When clicked, it triggers a callback function with the gallery ID.

Props

  • id (string): The ID of the gallery to fetch the thumbnail for.
  • onSelect (function): A function to be called when the thumbnail is clicked. The gallery ID is passed as an argument.

State

  • galleryId (string): A state to store the gallery ID.
  • thumbnailUrl (string): A state to store the fetched thumbnail URL.
  • isLoading (boolean): A state to keep track of the loading status.

Functions

  • openGallery: A function to call the onSelect prop with the gallery ID.
  • getData: An async function to fetch the thumbnail from the API.

Usage

This will render a thumbnail for the gallery with the ID of "1". When the thumbnail is clicked, it will log the gallery ID to the console.

<GalleryThumbnail id="1" onSelect={(id) => console.log(id)} />
Description
Prototyping for art sas platform #2
Readme 64 MiB
Languages
TypeScript 96.6%
JavaScript 1.5%
CSS 1.5%
Dockerfile 0.4%