Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/itbruno/linksforall
Linksforall its a link page with custom filters to keep all your links in one place, created with NextJS/Tailwind CSS
https://github.com/itbruno/linksforall
bio-link nextjs tailwindcss typescript
Last synced: 2 months ago
JSON representation
Linksforall its a link page with custom filters to keep all your links in one place, created with NextJS/Tailwind CSS
- Host: GitHub
- URL: https://github.com/itbruno/linksforall
- Owner: itbruno
- License: mit
- Created: 2020-08-21T01:59:14.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-09-10T03:56:31.000Z (5 months ago)
- Last Synced: 2024-09-10T06:16:59.883Z (5 months ago)
- Topics: bio-link, nextjs, tailwindcss, typescript
- Language: TypeScript
- Homepage: https://linksforall.vercel.app
- Size: 562 KB
- Stars: 73
- Watchers: 1
- Forks: 11
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# LinksforAll
Open source link page with custom filters to keep all your links in one place.
[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2Fitbruno%2Flinksforall)
![linksforall](https://user-images.githubusercontent.com/3206543/211458118-2a11815a-dc47-46d6-b466-f088de3bfecf.jpg)
### Demo
- [Alpha theme](https://linksforall.vercel.app/)
- [Dracula theme](https://links-dracula.vercel.app/) (_created using Deploy button above_)## Description
**Linksforall** is a all in one open-source links page with optionally categories filter to better link sort with infinite possibilities.
## Get started
This project was created on [NextJS](https://nextjs.org/) with Typescript and [Tailwind CSS](https://tailwindcss.com/).
Icons from [Phosphoricons](https://phosphoricons.com/) lib1. Begin installing all dependencies (_req. node >=18.0.0_):
```shell
npm run install
# or
yarn
```2. Run dev command to load nextjs
```shell
npm run dev
```3. Open local URL
```
http://localhost:3000
```## Base structure
### Content location
All content are located in:
```shell
./src/lib/links.json
./src/lib/categories.json
./src/lib/user.json
```#### Links
Links are array with the following structure:
| name | type | description |
| ---------- | ------ | ----------------------------- |
| label | string | label visible on page |
| categoryId | string | **optional** id from category |
| url | string | url from link |```json
[
{
"label": "Open-source link page",
"categoryId": "projects",
"url": "https://github.com/itbruno/linksforall"
}
]
```#### Categories (optional)
Categories are optional to filter links, keep the array empty if you don't use.
| name | type | description |
| ----- | ------ | --------------------- |
| label | string | label visible on page |
| id | string | category identifier |```json
[
{
"label": "Projects",
"id": "projects"
}
]
```#### User
The user file is all personal content from page, feel free to create/update new fields and use in your page.
| name | type | description |
| ----------- | ------ | ------------------------------ |
| fullname | string | Page name |
| website | string | **optional** website url |
| role | string | Your role |
| bio | string | short description about you |
| image | string | profile image |
| socialLinks | object | object with social media links |```json
[
"fullname": "Bruno Rodrigues",
"website": "https://itbruno.com.br",
"role": "UI Designer & Front-end dev",
"bio": "UI Designer and Front-end developer, based on Brazil and working at Nuvemshop",
"image": "https://avatars3.githubusercontent.com/u/3206543?s=400&u=10401f6bec19f1675f77a45ee9b40bfb1a293367&v=4","socialLinks": {
"twitter": "https://twitter.com/_brunoweb",
"linkedin": "https://linkedin.com/in/itbruno",
"github": "https://github.com/itbruno",
"medium": "https://medium.com/@itbruno",
"facebook": "",
"youtube": "",
"instagram": "",
"dribbble": "https://dribbble.com/itbruno"
}
]
```## Themes
Here is the best part, you can use the current themes or create your own.
Use your creativity and/or tech skill to generate awesome themes.We have 2 custom themes: **Alpha** e **Dracula** (based on [Dracula](https://draculatheme.com/contribute) dark theme from [Zeno Rocha](https://github.com/zenorocha))
Themes are located in:
```shell
./src/themes/[THEME_NAME]
```To use your theme, after created you can import in `./src/index.tsx`
```ts
...
import { Alpha } from '@themes/alpha';
import { DATA } from '@lib/data';export default function Home() {
const { user } = DATA;
return (
<>
...
>
);
}
```## Environment variables - SEO
We have **Google Analytics 4** pre-configured in the project. And you don't need touch in code to setup, it simple:
To use local, create `.env.local` file at root project directory with your GA4 id:```shell
# .env.local
NEXT_PUBLIC_GA4_ID=G-AAA0001112T
```## Design
Some themes are availbale with [Figma](https://tinu.be/uilinks)
## Current version
![GitHub tag (latest SemVer)](https://img.shields.io/github/package-json/v/itbruno/linksforall)