Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fastrodev/replix

Social Q&A Platform
https://github.com/fastrodev/replix

Last synced: about 2 months ago
JSON representation

Social Q&A Platform

Awesome Lists containing this project

README

        

# Replix

Before running the application, it is recommended that you use either Linux or
macOS. If you are a Windows user, please utilize the Windows Subsystem for Linux
(WSL) to run Linux.

It is also recommended that you use Microsoft Visual Studio Code to create and
update all files.

## How to run

```
deno task start
```

During the first run, the application will create the `.fastro`, `node_modules`,
and `static/js` folders. Do not modify these folders, as they are essential for
the application's modules to function correctly.

## Application Structure

This is the application structure generated by `tree -I 'node_modules'` command.

In this initial setup, the application consists of two modules: `index`, `user`
and `markdown` modules.

- `index` is for SSR page module.
- `user` is for API module that provide data.
- `markdown` is for handling readme file.

You can modify or add new one as your need.

```
.
├── components
│   ├── footer.tsx
│   └── header.tsx
├── deno.json
├── main.ts
├── modules
│   ├── index
│   │   ├── index.handler.ts
│   │   ├── index.layout.tsx
│   │   ├── index.mod.ts
│   │   ├── index.page.tsx
│   │   └── index.service.ts
│   ├── markdown
│   │   ├── markdown.mod.ts
│   │   └── readme.layout.tsx
│   └── user
│   ├── user.handler.ts
│   ├── user.mod.ts
│   ├── user.service.ts
│   └── user.types.ts
├── readme.md
├── static
│   ├── js
│   │   └── index.js
│   └── tailwind.css
├── tailwind.config.ts
└── utils
└── db.ts
```

## Files and Folders Descriptions

| Folder / File | Description |
| --------------------- | ---------------------------------------------------------------------------------------------------------------------------------------- |
| deno.json | The deno configuration file. It defines how the application behave and the shortcut of deno task command. For example: `deno task start` |
| tailwind.config.ts | The tailwind configuration file. See: https://tailwindcss.com/docs/configuration |
| main.ts | The application entry point. Modify it to add a new module or application-level middleware. |
| utils/ | The folder that contains all library needed. Put your custom helpers here. |
| utils/db.ts | The files that needed to load Deno.Kv |
| modules/ | The application modules. It contains folders of modules. |
| modules/index/ | The index modules. It contains page, layout, handler and SSR service. |
| modules/user/ | The user modules. It contains user API endpoint and service that connected to Deno.Kv |
| modules/markdown/ | The markdown modules. It contains markdown layout and middleware initiation. |
| *.mod.ts | The index file for a module. Modify it to add new endpoints (API), middlewares, or pages |
| *.handler.ts | The handler file for a module. It handles the request from endpoints. |
| *.service.ts | The service file for a module. It functions is to provide data consumed by the handler. |
| *.types.ts | The types file for a module. Place all types and interfaces here. |
| *.page.tsx | The page file for a module. Create your new page with this extension. |
| *.layout.tsx | The layout file for a module. Wrap your page with this layout. |
| components/ | The folder that contains all components |
| components/header.tsx | The file for a Header component |
| components/footer.tsx | The file for a Footer component |
| static/ | The folder that contains all static files needed by html files |
| static/js/index.js | The SSR JS bundled files generated by fastro framework |
| static/tailwind.css | The CSS file that needed by tailwind css |