Skip to content

BrianShenCC/brian.style

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

99 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

前不久在 GitHub 上看到一个很惊艳我的个人网站:

我也想要这样一个网站

我一直没有一个很满意的个人网站,主要原因是个人审美/设计能力不达标,做出来的网站总感觉差点意思。

直到我看到今天的主角:这不就是我的「梦中情网」吗?刚好技术栈我也感兴趣(基于 Next.js, TypeScript, Tailwind CSS 构建),一切都刚刚好。

于是乎,我基于 aulianza/aulianza.id(GPL-3.0 license) 修改了上百个文件诞生了这个项目:wencaizhang/webjam.cn · GitHub

项目使用 Vercel 部署:webjam.cn

为什么要修改这么多文件?

答案很简单:不修改没法儿用啊。

原仓库的一些特点:

  • 博客内容和评论都是通过 API 调用 dev.to 的数据
  • 实时在线留言,使用 Firebase 数据库
  • 支持 ChatGPT AI 对话
  • 显示 Spotify 实时信息
  • 通过 Cal.com 预约会议
  • 使用 Web3Forms 填写联系表单
  • 甚至一些本地数据(本地文件信息)都是以 API 接口形式调用
  • 个人信息/站点信息硬编码到项目中

所以这个项目没办法直接使用的,我修改了上百个文件,现在就好多了:

  • 博客文章是本地文件,评论可使用 giscus(可选择不用)
  • 关闭在线留言功能(Guestbook)功能
  • ChatGPT AI、Spotify、Cal.com、Web3Forms、Github 分析、wakatime 记录都改为可配置项,自由决定是否启用
  • 「Project」和 「learn」功能取消 API 层,直接在 getStaticProps 中完成数据获取
  • 所有个人信息/站点信息改为可配置项
  • 更容易扩展和定制(例如 menu 和技术栈)
  • 增加「周刊」功能
  • 一些优化:例如减少 getStaticProps 数据体积、链接代替 js 跳转等等
  • 更多小细节...

Roadmap

不过现在还是不够完美的,也就是能用,下一步我的计划是:

如何运行

克隆代码

git clone https://github.com/webjam.cn

安装依赖

cd webjam.cn && pnpm install

# 或者
cd webjam.cn && yarn

启动开发服务

pnpm run dev
# 或者
yarn dev

然后修改 src/contents/ 里面的内容即可。

如果你有一些想法或者建议

如果你有什么想法或者建议,可以通过 Issues 告诉我或者直接给我发邮件

当然如果你有能力对代码进行优化也欢迎直接 PR。

以下是原 readme


Personal Website

🔥 Personal website was built originally from scratch using Next.js, TypeScript, Tailwind CSS, SWR, Firebase and Prisma with MySQL


3-devices-black

Introduction

This website was meticulously crafted from the ground up using Next.js, along with various complementary technologies. Its inception dates back to June 2023.

Ongoing enhancements, encompassing both functionality and content, are in the pipeline. This website stands as a treasured repository of my acquired knowledge, also serving as a platform for me to disseminate insights.

Feel welcome to utilize this website as a point of reference, a wellspring of inspiration, or as a template, all in accordance with the provided license. The source code is at your disposal to suit your specific requirements.

Should you find value in this resource, your consideration of leaving a rating is greatly appreciated. 😎👍🏻

If you have any questions, suggestions, input or anything else, don't hesitate to contact me🧑‍💻

Features

On this website there are several features that will continue to be updated and added in the future.

🤖 ChatGPT AI

You can access this feature by opening the command palette [cmd+k], then typing whatever you want to search/ask for.

Note:

If you're using Chat Completions engine model of ChatGPT, please concern about this:

Due this site is using free cloud hosting services (Vercel) with certain limitations (Serverless Function Execution Timeout), sometimes an error will occur if the response from the open AI API is too long, but you can change it in the vercel.json file to upgrade memory and maxDuration to be bigger according to the capabilities of your vercel plan.

💻 JavaScript Playground

A no-fuss pure JavaScript playground with a live feedback loop.

💬 Realtime Guestbook

Realtime guestbook chat is powered by Firebase. Anyone can leave me a message in this website.

🎧 Spotify

Displays song information being played on spotify in real time using the Spotify API and SWR.

🕗 Wakatime

Data is retrieved using the Wakatime API and then displayed on the dashboard, built with Next.js API routes deployed as serverless functions.

📝 Blogs

The content on this blog is meticulously managed and sourced from a self-hosted headless CMS powered by WordPress, exemplifying our commitment to a streamlined and efficient content delivery system.

The data fetching technique used to retrieve articles from WordPress CMS API involves using Client-Side Rendering (CSR) for the blog list and Server-Side Rendering (SSR) for the blog details.

🗳 Projects

The data projects on this blog are taken from the MySQL database connected through the Prisma Client. The database for this application is hosted on PlanetScale DB.

The data fetching method used to retrieve data projects is Incremental Static Regeneration (ISR) with 1 second revalidation and Server-Side Rendering (SSR) for the project details..

Performance

PageSpeed Insights

Report URL: https://pagespeed.web.dev/analysis/https-aulianza-id/pk0y6xcz25?form_factor=desktop

image

GTmetrix

Report URL: https://pagespeed.web.dev/analysis/https-aulianza-id/pk0y6xcz25?form_factor=desktop

image

Getting Started

If you are interested in running this project on your local machine, you can do so in just 3 easy steps below. Additionally, remember to update the ".env.example" file to ".env" and replace the variables with your own in the ".env" file.

1. Clone this template using one of the three ways:

  1. Clone using git

    git clone https://github.com/aulianza/aulianza.id
  2. Using create-next-app

    npx create-next-app -e https://github.com/aulianza/aulianza.id project-name
  3. Using degit

    npx degit aulianza/aulianza.id YOUR_APP_NAME
  4. Deploy to Vercel or Netlify, etc

    Deploy with Vercel Deploy to Netlify

2. Install dependencies

It is encouraged to use yarn so the husky hooks can work properly.

yarn install

3. Run the development server

You can start the server using this command:

yarn dev

Open http://localhost:3000 with your browser to see the result. You can start editing the page by modifying src/pages/index.tsx.

License

Licensed under the GPL-3.0 license.

About

Personal website built with Next.js.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 68.2%
  • MDX 26.3%
  • CSS 4.0%
  • JavaScript 1.5%