Vercel-like style portfolio template for developers.
For a reference, check out my personal protfolio, slightly changed, but uses this template.
The main libraries used here are :
shadcn-svelte
: component library.tailwindcss
: css styling.unocss
: fonts and icons.- using
carbon
(and thus the icon namesi-carbon-*
) icons that could be browsed here
- using
mode-watcher
: color mode utility.prismjs
: markdown parsing in combination withmarked
,marked-mangle
,marked-gfm-heading-id
anddompurify
.
You can either clone or fork this repository :
You can fork the project, maintaining a link to the original repo using the fork
button, make sure the check the Copy the master branch only
checkbox.
- using
git
:
# ssh
git clone [email protected]:RiadhAdrani/slick-portfolio-svelte-5.git protfolio
# https
git clone https://github.com/RiadhAdrani/slick-portfolio-svelte-5.git protfolio
- using
degit
npm executable :
npx degit RiadhAdrani/slick-portfolio-svelte-5 portfolio
if you don't have degit
, it will prompt you to accept, enter y
.
You can add the main repo as another remote repo to maintain updates in the future.
# ssh git remote add main [email protected]:RiadhAdrani/slick-portfolio-svelte-5.git
Before deploying to GitHub Pages
:
If you forked the repo, go to the Actions
tab in the newly generated repository, and enable workflows, click on the green button I understand my workflows, go ahead and enable them
:
Allow GitHub Pages
in your repo settings with correct permissions:
- go to your repo
Settings
>Actions
>General
- in
Actions permissions
: make sure thatAllow all actions and reusable workflows
checkbox is checked
Depending on the name of your repository, you would like to set the base
variable to that, starting with a leading slash like this:
const base = '/slick-portfolio-svelte';
But if your repository name is the same as your Github domain name; my Github name is RiadhAdrani
so my domain name is riadhadrani.github.io
(lower cased), and so the special repository name is also riadhadrani.github.io
: if that is the case, you need to set the base to an empty string
const base = '';
If you didn't commit and push the changes in the svelte.config.js
yet, you can do that now, otherwise you can create an empty commit:
git commit --allow-empty -m "chore: trigger workflow"
and push it to your master
or main
branch.
In the Actions
tab, make sure that the Build and Deploy
workflow is successful (wait for it to complete): you should have at least one successfull workflow run:
- go to your repo's
Settings
>Pages
- in Source section, select
Deploy from a branch
. - in Branch section, select
gh-pages
and/ (root)
and click on save
Again in the Actions
tab, make sure that the pages-build-deployment
workflow is successful (wait for it to complete): you should have at least one successfull workflow run:
If for some reason no action was launched, try pushing empty commit.
That's it, you can click on the latest deployment and visit it.
If you want to use the template as it is, you can :
-
update files in
src/lib/data
with your data. -
update
src/lib/index.css
for custom styling. -
update
src/lib/index.css
for custom markdown styling. -
update
static/favicon.png
to customize the tab's icon. -
You can find
shadcn-svelte
component insrc/lib/components/ui
, other components are arranged by their page, or in thecommon
folder.
But feel free to explore and hack the template to your needs if you feel like it.
- Svelte no longer support
node 14
, use a newer version instead.