Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
{
"i18n-ally.localesPaths": ["src/i18n/locales"],
"i18n-ally.keystyle": "nested"
"i18n-ally.keystyle": "nested",
"cSpell.words": ["Omnibar"]
}
175 changes: 59 additions & 116 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,136 +1,72 @@
<h1 align="center">Files Website • <a href="https://files.community">files.community</a></h1>

<p align="center">
<a href="#overview">Overview</a> |
<a href="#development">Development</a> |
<a href="#contributors">Contributors</a>
</p>

<p align="center">
<img alt="Files website preview" src="https://i.imgur.com/U0iIVcf.png"/>
<br/>
The starting page for everything related to <a href="https://github.com/files-community/files">Files</a> — documentation and news included!
<br/>
<br/>
<a href="https://github.com/files-community/Website/blob/main/LICENSE" target="_blank">
<img src="https://img.shields.io/github/license/files-community/website?labelColor=17141f&color=6441a4&style=for-the-badge&logo=" alt="License"/>
</a>
<a href="https://discord.com/invite/files/" target="_blank">
<img src="https://img.shields.io/discord/725513575971684472?label=Discord&labelColor=202225&color=5865f2&style=for-the-badge&logo=" alt="Chat"/>
</a>
</p>
<p align="center">This repository contains the source code for the <a href="https://files.community">https://files.community</a>, written using <a href="https://svelte.dev">SvelteKit</a>, <a href="https://typescriptlang.org">TypeScript</a> and <a href="https://sass-lang.com">SCSS</a>, and deployed with Cloudflare.</p>

---

# Overview

This repository contains the source code for the new [Files website](https://files.community). The site is written using [SvelteKit](https://svelte.dev), [TypeScript](https://typescriptlang.org/) and [SCSS](https://sass-lang.com), and deployed with Cloudflare.

## Codebase Structure

```
.
├──static // Contains static assets including branding, images, fonts, etc...
| ├──branding // Branding media (logos, banners, etc...)
| ├──fonts // Static font files loaded by the website.
| ├──preview-samples // Sample files used in the preview pane in the features section.
| ├──screenshots // Screenshots and renders of the app used in the website.
| └──ui // Images other than branding used in the website's user interface.
└──src // The website's source code.
├──lib // Re-usable Svelte components used within the website.
├──layout // Components responsible for defining page layout, such as headers, footers, page sections, etc...
├──routes // SvelteKit's filesystem-based routes. Anything in the folder is registered as a URL on build time.
| ├──docs // Documentation and associated files.
| └──blog // Blog page and associated files.
| └──posts // Folder containing blog posts in Markdown format.
├──data // Data storage used across various components and routes. NOT stores, just exported variables.
└──styles // SCSS styles that are NOT tied to components in /lib.
```

---

# Development

## GitHub Codespaces
## Translating

You can develop this project using GitHub Codespaces.
For this, click the button below. It will allow you to create a new Codespace with the configuration of your choice.

[![Open in GitHub Codespaces](https://github.com/codespaces/badge.svg)](https://github.com/codespaces/new/files-community/website?devcontainer_path=.devcontainer%2Fdevcontainer.json)

After the Codespace has initialized, you can run `pnpm dev` and you'll be ready to go!

## Local development

### Prerequisites

- [Git](https://git-scm.com)
- [Node.js](https://nodejs.org/en/) with `npm`.
- [`pnpm`](https://pnpm.io)
- Shell of your choice.

### Building

#### 1: Clone the repository.

```ps
git clone https://github.com/files-community/Website && cd Website
```

This will create a local copy of this repository and navigate you to the root folder of the repository.
Translation is done via Crowdin: https://crowdin.com/project/files-website

#### 2: Install Dependencies
## Building and running

Run this command at the root folder to install dependencies:
### GitHub Codespaces

```ps
pnpm i
```
You don't need to install any tools on GitHub Codespaces.
After the Codespace has initialized, you can run `pnpm dev` and ports will be listed for previewing.

#### 3: Run Build Script
### Local development

To build the site in development mode, simply run the following command:

```ps
pnpm run dev
```
1. Prerequisites
- [Git](https://git-scm.com)
- [Node.js](https://nodejs.org) with `npm`.
- [`pnpm`](https://pnpm.io)
2. Clone the repository.
```
git clone https://github.com/files-community/Website && cd Website
```
3. Install dependencies
```
pnpm i
```
4. Deploy the website locally
```
pnpm run dev
```

## Additional Scripts

### Linting
### Additional scripts

This project uses [prettier](https://prettier.io) and [eslint](https://eslint.org/). Run this command to lint your changes:

```ps
```
pnpm run lint
```

Additionally, we use [lint-staged](https://github.com/okonet/lint-staged) to automatically format all changed files before committing them, ensuring that all code is formatted consistently.

### Compiling & Distribution

We currently use [SvelteKit's cloudflare adapter](https://www.npmjs.com/package/@sveltejs/adapter-cloudflare) module, which allows us to deploy to cloudflare. To simply build a production bundle, use the following script:

```ps
```
pnpm run build
```

> Alternatively, to preview your changes in a production-like build, use `pnpm run preview`.
Alternatively, to preview your changes in a production-like build, use the following script:

## Contributing to Documentation
```
pnpm run preview
```

## Contributing

Our documentation system uses [mdsvex](https://mdsvex.pngwn.io/), a superset of markdown designed to work with [Svelte](htts://svelte.dev).
This uses [mdsvex](https://mdsvex.pngwn.io), a superset of markdown designed to work with [Svelte](htts://svelte.dev).

### Editing Existing Pages
### Editing existing pages

Documentation files are located at [`src/routes/docs`](https://github.com/files-community/Website/tree/main/src/routes/docs). SvelteKit uses a
filesystem-based router, meaning that the layout of page folders in the filesystem will reflect the URL path they are
assigned to.

To edit an existing page, find the corresponding folder in
the [`docs`](<(https://github.com/files-community/Website/tree/main/src/routes/docs)>) directory, and edit the `+page.md` file inside it.
To edit an existing page, find the corresponding folder in the [`docs`](<(https://github.com/files-community/Website/tree/main/src/routes/docs)>) directory, and edit the `+page.md` file inside it.

### Adding or Deleting a Page
### Adding or deleting a page

To create/delete a page, remove the corresponding folder for it, as long with the `+page.md` file inside it.

Expand All @@ -139,21 +75,19 @@ To create/delete a page, remove the corresponding folder for it, as long with th
Categories are sub-folders inside `src/routes/docs`, which contain a `category.md` file. This file marks a category directory, and contains metadata relating to it.
Categories can contain page folders (with a `+page.md` file in them), or other categories.

## Using the Blog
### Adding a blog

Similarly to docs pages, the blog also uses [mdsvex](https://mdsvex.pngwn.io/) for it's markdown. Blog posts are located
at [`src/routes/blog/posts`](https://github.com/files-community/Website/tree/main/src/routes/blog/posts) in `*.md` files.
Unlike the docs, a mapping of blog posts doesn't need to be kept.

### Publishing a Post

To publish a post, create a new folder in
the [`posts`](https://github.com/files-community/Website/tree/main/src/routes/blog/posts) folder, and in it place a file
named `+page.md`. It will contain your post's content.

At the top of the file, you'll need to include a few required things before typing the post.

```md
```yml
---
title: Title of the Post
author: author-github-handle
Expand All @@ -165,18 +99,27 @@ date: 2021-09-06

This metadata table is required for all posts, and gives the website some basic information about the post to work with. Below the table, you're free to use whatever markdown or components you want.

### Removing or Editing a Post
### Removing or editing a post

Since we don't need any mapping to be updated, posts can simply be deleted from the folder or edited without any hassle or extra steps.

## Translating the Site
## Codebase overview

Translation is done via Crowdin: https://crowdin.com/project/files-website

# Contributors

Want to contribute to this project? Feel free to open an [issue](/issues) or [pull request](/pulls).

<a href="https://github.com/files-community/Website/graphs/contributors">
<img src="https://contrib.rocks/image?repo=files-community/Website" />
</a>
```
.
├──static // Contains static assets including branding, images, fonts, etc...
| ├──branding // Branding media (logos, banners, etc...)
| ├──fonts // Static font files loaded by the website.
| ├──preview-samples // Sample files used in the preview pane in the features section.
| ├──screenshots // Screenshots and renders of the app used in the website.
| └──ui // Images other than branding used in the website's user interface.
└──src // The website's source code.
├──lib // Re-usable Svelte components used within the website.
├──layout // Components responsible for defining page layout, such as headers, footers, page sections, etc...
├──routes // SvelteKit's filesystem-based routes. Anything in the folder is registered as a URL on build time.
| ├──docs // Documentation and associated files.
| └──blog // Blog page and associated files.
| └──posts // Folder containing blog posts in Markdown format.
├──data // Data storage used across various components and routes. NOT stores, just exported variables.
└──styles // SCSS styles that are NOT tied to components in /lib.
```
Loading