Federated forge client web app
Find a file
2023-05-03 17:41:33 +03:00
.vscode Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
src Create first-start page & add COPYING 2023-05-03 17:41:33 +03:00
static Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
tests Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
.eslintignore Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
.eslintrc.cjs Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
.gitignore Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
.node-version Update README and add .node-version 2023-05-03 17:37:18 +03:00
.npmrc Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
.prettierignore Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
.prettierrc Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
COPYING Create first-start page & add COPYING 2023-05-03 17:41:33 +03:00
package-lock.json Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
package.json Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
playwright.config.ts Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
postcss.config.cjs Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
README.md Create first-start page & add COPYING 2023-05-03 17:41:33 +03:00
svelte.config.js Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
tailwind.config.cjs Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
tsconfig.json Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00
vite.config.ts Initial commit, using the "Skeleton Welcome" template 2023-05-03 12:28:02 +03:00

Anvil

/!\ work in progress!

Kanban | Chat

Anvil is a web client app for interacting with federated forges. It's meant to allow you to:

  • Create an account of a federated forge
  • Browse software projects
  • Create and manage your software projects
  • Create and manage teams and organizations
  • Participate and interact with software projects: Repo, issues, PRs, CI, etc. etc.

It's meant to be deployed in 3 ways:

  1. Tauri app, packaged with Flatpak, that you can install on your desktop
  2. Independent fully-client-side hosted app you can access using a web browser and connect to any forge (we will probably host one on Anvil's website for convenient reachout, but anyone can host on their server)
  3. Hosted app served by federated forge servers as their default UI, in multi-page mode and pre-rendered pages

Status (May 2023): Implementation is in very early initial stages.

Tech stack:

  • SvelteKit
  • TypeScript
  • Tailwind
  • Skeleton.dev

Soon also:

  • Tauri
  • ActivityPub
  • ForgeFed

Developing

Install NodeJS. Recommended method: FNM.

Install dependencies:

npm install

Launch development server:

npm run dev

# or start the server and open the app in a new browser tab
npm run dev -- --open

Quick overview of the structure of the codebase:

This repo was started via npm create skeleton-app@latest with the "Welcome" template.

More components can be added using create-svelte.

Building

We haven't yet installed adapters for the target environments. Coming soon.

To create a production version of the app:

npm run build

To preview the production build:

npm run preview

Software freedoms (a.k.a license)

GNU AGPL v3 or later. For the legal detail, see COPYING.