2021-08-10 04:58:26 +02:00
# 🔗 LittleLink-Server
This project is based on the great work from [littlelink ](https://github.com/sethcottle/littlelink )
2021-10-09 06:42:06 +02:00
It takes the same simple approach to a link page and hosts it within a NodeJS server with React Server Side Rendering, containerized for you to use. Now, customizing `LittleLink` with `littlelink-server` is as easy as passing in some environment variables. If you need help configuring this, please see [this video that explains everything ](https://www.youtube.com/watch?v=42SqfI_AjXU ) and a live example at [technotim.live ](https://technotim.live/ ).
2021-08-10 04:58:26 +02:00
2021-08-12 05:29:39 +02:00
# 🚀 Getting Started
2021-08-11 05:35:59 +02:00
2021-08-27 03:16:24 +02:00
## Supported Links
2021-08-26 06:16:20 +02:00
Check the [config ](https://github.com/techno-tim/littlelink-server/blob/master/src/config.js ) file for all supported buttons!
2021-10-06 05:00:18 +02:00
## Google Analytics Support
See [Getting Started with Analytics ](https://support.google.com/analytics/answer/1008015?hl=en ). After getting your GA Tracking Id, use your tracking Id as environment variable like `GA_TRACKING_ID=G-XXXXXXXXXX` (See the example below)
2021-10-09 07:17:14 +02:00
All buttons clicked will be tracked automatically if `GA_TRACKING_ID` exists.
Sample event for YouTube button.
javascript
```
window.gtag('event', 'click', {
event_category: 'social',
event_label: 'youtube',
value: 1,
});
```
2021-08-19 00:32:47 +02:00
## Docker
2021-08-27 03:16:24 +02:00
This container image is published on both [GitHub Container Registry ](https://github.com/techno-tim/littlelink-server/pkgs/container/littlelink-server ) and [DockerHub ](https://hub.docker.com/repository/docker/timothystewart6/littlelink-server ) choose whichever one works for you. They will both be updated during CI.
2021-08-11 05:35:59 +02:00
`docker-compose.yml`
```yml
---
2021-09-24 03:44:52 +02:00
version: "3.0"
2021-08-11 05:35:59 +02:00
services:
little-link:
image: ghcr.io/techno-tim/littlelink-server:latest
2021-08-27 03:16:24 +02:00
# dockerhub is also supported timothystewart6/littlelink-server
#image: timothystewart6/littlelink-server:latest
2021-08-11 05:35:59 +02:00
container_name: littlelink-server
2021-09-24 03:44:52 +02:00
build:
context: ./
dockerfile: Dockerfile
2021-08-11 05:35:59 +02:00
environment:
- META_TITLE=Techno Tim
- META_DESCRIPTION=Techno Tim Link page
- META_AUTHOR=Techno Tim
2021-10-09 06:38:21 +02:00
- LANG=en
2021-09-24 03:44:52 +02:00
- META_INDEX_STATUS=all
2021-10-09 07:17:14 +02:00
- GA_TRACKING_ID=G-XXXXXXXXXX
2021-08-11 05:35:59 +02:00
- THEME=Dark
2021-08-14 23:47:16 +02:00
- FAVICON_URL=https://pbs.twimg.com/profile_images/1286144221217316864/qIAsKOpB_200x200.jpg
- AVATAR_URL=https://pbs.twimg.com/profile_images/1286144221217316864/qIAsKOpB_200x200.jpg
- AVATAR_2X_URL=https://pbs.twimg.com/profile_images/1286144221217316864/qIAsKOpB_400x400.jpg
2021-08-11 05:35:59 +02:00
- AVATAR_ALT=Techno Tim Profile Pic
- NAME=TechnoTim
- BIO=Hey! Just a place where you can connect with me!
2021-08-26 02:54:23 +02:00
- FOOTER=Thanks for stopping by!
2021-08-11 05:35:59 +02:00
- GITHUB=https://github.com/timothystewart6
- TWITTER=https://twitter.com/TechnoTimLive
- INSTAGRAM=https://www.instagram.com/techno.tim
2021-08-14 18:39:45 +02:00
- YOUTUBE=https://www.youtube.com/channel/UCOk-gHyjcWZNj3Br4oxwh0A
2021-08-11 05:35:59 +02:00
- TWITCH=https://www.twitch.tv/technotim/
- DISCORD=https://discord.gg/DJKexrJ
2021-08-12 04:08:21 +02:00
- TIKTOK=https://www.tiktok.com/@technotim
2021-08-11 05:35:59 +02:00
- KIT=https://kit.co/TechnoTim
2021-08-26 02:54:23 +02:00
- FACEBOOK=https://facebook.com
- FACEBOOK_MESSENGER=https://facebook.com
- LINKED_IN=https://linkedin.com
- PRODUCT_HUNT=https://www.producthunt.com/
- SNAPCHAT=https://www.snapchat.com/
- SPOTIFY=https://www.spotify.com/
- REDDIT=https://www.reddit.com/
- MEDIUM=https://medium.com
- PINTEREST=https://www.pinterest.com/
- EMAIL=you@example.com
- EMAIL_TEXT=Email Me!
- EMAIL_ALT=you@example.com
2021-09-24 03:44:52 +02:00
- EMAIL_ALT_TEXT=Email me!
2021-08-26 02:54:23 +02:00
- SOUND_CLOUD=https://souncloud.com
- FIGMA=https://figma.com
- TELEGRAM=https://telegram.org/
- TUMBLR=https://www.tumblr.com/
- STEAM=https://steamcommunity.com/
- VIMEO=https://vimeo.com/
- WORDPRESS=https://wordpress.com/
- GOODREADS=https://www.goodreads.com/
- SKOOB=https://www.skoob.com.br/
- LETTERBOXD=https://letterboxd.com/
- MASTODON=https://mastodon.social/
- MICRO_BLOG=https://micro.blog/
2021-08-26 03:05:53 +02:00
- WHATSAPP=https://www.whatsapp.com/
2021-09-11 22:20:38 +02:00
- STRAVA=https://www.strava.com/
- BUYMEACOFFEE=https://www.buymeacoffee.com/
2021-10-06 05:45:40 +02:00
- GITLAB=https://www.gitlab.com/
2021-08-11 05:35:59 +02:00
ports:
- 8080:3000
restart: unless-stopped
security_opt:
- no-new-privileges:true
2021-08-12 04:08:21 +02:00
```
2021-08-14 18:39:45 +02:00
Docker command
```
docker run -d \
--name=littlelink-server \
-p 8080:3000 \
-e META_TITLE='Techno Tim' \
-e META_DESCRIPTION='Techno Tim Link page' \
-e META_AUTHOR='Techno Tim' \
2021-10-09 06:38:21 +02:00
-e LANG=en \
2021-09-24 03:44:52 +02:00
-e META_INDEX_STATUS='noindex' \
2021-10-09 07:17:14 +02:00
-e GA_TRACKING_ID='G-XXXXXXXXXX' \
2021-08-14 18:39:45 +02:00
-e THEME='Dark' \
2021-08-14 23:47:16 +02:00
-e FAVICON_URL='https://pbs.twimg.com/profile_images/1286144221217316864/qIAsKOpB_200x200.jpg' \
-e AVATAR_URL='https://pbs.twimg.com/profile_images/1286144221217316864/qIAsKOpB_200x200.jpg' \
-e AVATAR_2X_URL='https://pbs.twimg.com/profile_images/1286144221217316864/qIAsKOpB_400x400.jpg' \
2021-08-14 18:39:45 +02:00
-e AVATAR_ALT='Techno Tim Profile Pic' \
-e NAME='TechnoTim' \
-e BIO='Hey! Just a place where you can connect with me!' \
-e GITHUB='https://github.com/timothystewart6' \
-e TWITTER='https://twitter.com/TechnoTimLive' \
-e INSTAGRAM='https://www.instagram.com/techno.tim' \
-e YOUTUBE='https://www.youtube.com/channel/UCOk-gHyjcWZNj3Br4oxwh0A' \
-e TWITCH='https://www.twitch.tv/technotim' \
-e DISCORD='https://discord.gg/DJKexrJ' \
-e TIKTOK='https://www.tiktok.com/@technotim' \
-e KIT='https://kit.co/TechnoTim' \
2021-08-26 02:16:09 +02:00
-e EMAIL='someone@example.com' \
-e EMAIL_TEXT='Email me!' \
-e FOOTER=Thanks for stopping by! \
2021-08-14 18:39:45 +02:00
--restart unless-stopped \
ghcr.io/techno-tim/littlelink-server:latest
```
2021-08-19 00:32:47 +02:00
## Kubernetes
2021-08-26 02:16:09 +02:00
[Unofficial helm chart provided by k8s-at-home ](https://github.com/k8s-at-home/charts/tree/master/charts/stable/littlelink-server )
2021-08-19 00:32:47 +02:00
```
helm repo add k8s-at-home https://k8s-at-home.com/charts/
helm repo update
helm install littlelink-server \
--set env.TZ="America/New York" \
2021-08-26 02:16:09 +02:00
--set env.META_TITLE="TechnoTim"
2021-08-19 00:32:47 +02:00
k8s-at-home/littlelink-server
```
Or use a values.yaml files
`helm install littlelink-server k8s-at-home/littlelink-server -f values.yaml`
2021-08-14 18:39:45 +02:00
2021-08-12 05:29:39 +02:00
# 👇 What is LittleLink?
![LittleLink ](https://cdn.cottle.cloud/littlelink/social-circle.png )
LittleLink is a lightweight DIY alternative to services like [Linktree ](https://linktr.ee )
and [many.link ](https://www.google.com ). LittleLink was built using [Skeleton ](http://getskeleton.com/ ), a dead simple, responsive boilerplate—we just stripped out some additional code you wouldn't need and added in branded styles for popular services. 😊
![Themes ](https://cdn.cottle.cloud/littlelink/themes.png )
LittleLink has more than 20 company button styles you can use and we'll be throwing more in soon. You'll also find a light and dark theme ready to go. Not a fan of the colors? Update `skeleton-light.css` or `skeleton-dark.css` to the HEX values of your choosing.
![Performance ](https://cdn.cottle.cloud/littlelink/performance.png )
Using [Skeleton ](http://getskeleton.com/ ) let us build something that loads quickly & doesn't have any of the unnecessary bloat you would get from using a large framework for a page that requires nothing more than simplicity. LittleLink scored a 99/100 in performance when tested with [Google Lighthouse ](https://developers.google.com/web/tools/lighthouse ).