diff --git a/content/profile/aungkoko.mdx b/content/profile/aungkoko.mdx new file mode 100644 index 0000000..6a092af --- /dev/null +++ b/content/profile/aungkoko.mdx @@ -0,0 +1,20 @@ +--- +name: Aung Ko Ko +description: I am a self-motivated frontend web developer. I am flexible and always eager to learn new technologies, which allows me to stay up-to-date with the latest trends in frontend development. +image: "https://avatars.githubusercontent.com/u/84788994?v=4" +tags: + - Frontend + - JavaScript + - TypeScript + - ReactJS + - NextJS + - Redux + - React Query + - MUI + - Tailwind CSS + - Bootstrap +--- + +import AungKoKo from "@/components/Contributors/AungKoKo/AungKoKo"; + + diff --git a/package.json b/package.json index 1e398e7..3f2e61f 100644 --- a/package.json +++ b/package.json @@ -27,6 +27,7 @@ } }, "dependencies": { + "@formkit/auto-animate": "^0.8.0", "@splinetool/react-spline": "^2.2.6", "@splinetool/runtime": "^0.9.488", "clsx": "^2.0.0", diff --git a/public/aungkoko/octagon.svg b/public/aungkoko/octagon.svg new file mode 100644 index 0000000..9fad949 --- /dev/null +++ b/public/aungkoko/octagon.svg @@ -0,0 +1,13 @@ + + + + + + + + + + diff --git a/public/aungkoko/thinking.png b/public/aungkoko/thinking.png new file mode 100644 index 0000000..a0b694c Binary files /dev/null and b/public/aungkoko/thinking.png differ diff --git a/src/components/Contributors/AungKoKo/AungKoKo.jsx b/src/components/Contributors/AungKoKo/AungKoKo.jsx new file mode 100644 index 0000000..a57b2b5 --- /dev/null +++ b/src/components/Contributors/AungKoKo/AungKoKo.jsx @@ -0,0 +1,78 @@ +"use client"; +import { useState, useEffect, useRef } from "react"; +import autoAnimate from "@formkit/auto-animate"; +import skillsData from "./skills"; + +const AungKoKo = () => { + const [skills, setSkills] = useState(skillsData); + const parent = useRef(null); + + useEffect(() => { + parent.current && autoAnimate(parent.current, { duration: 700 }); + }, [parent]); + + useEffect(() => { + setTimeout(() => { + const juggled = [...skills]; + juggled.push(juggled.shift()); + setSkills(juggled); + }, 1000); + }, [skills]); + + return ( +
+
+
+ + 👋I'm + +

Aung Ko Ko

+

+ A self-motivated frontend web developer +

+ + My Portfolio +
+ +
+
+ {/** Skills Octagon */} +
+
+
+ +
+
+ icon by lordicon +
+
+ {skills.map(({ iconUrl, name }) => ( +
+ {`${name} +
+ ))} +
+
+
+
+ ); +}; + +export default AungKoKo; diff --git a/src/components/Contributors/AungKoKo/skills.js b/src/components/Contributors/AungKoKo/skills.js new file mode 100644 index 0000000..e9c47f1 --- /dev/null +++ b/src/components/Contributors/AungKoKo/skills.js @@ -0,0 +1,18 @@ +export const getIconUrl = (iconId) => + `https://skillicons.dev/icons?i=${iconId}`; + +export const reactQueryIconUrl = + ""; + +const skillsData = [ + { iconUrl: getIconUrl("ts"), name: "TypeScript" }, + { iconUrl: getIconUrl("react"), name: "ReactJS" }, + { iconUrl: getIconUrl("nextjs"), name: "NextJS" }, + { iconUrl: getIconUrl("redux"), name: "Redux" }, + { iconUrl: reactQueryIconUrl, name: "React Query" }, + { iconUrl: getIconUrl("materialui"), name: "Material UI" }, + { iconUrl: getIconUrl("tailwind"), name: "Tailwind CSS" }, + { iconUrl: getIconUrl("bootstrap"), name: "Bootstrap" }, +]; + +export default skillsData; diff --git a/src/styles/globals.scss b/src/styles/globals.scss index 5639751..d779f9a 100644 --- a/src/styles/globals.scss +++ b/src/styles/globals.scss @@ -15,6 +15,4 @@ @import "profiles/lwinmoepaing"; @import "profiles/vince"; @import "profiles/aungmyatmoe"; - - - +@import "profiles/aungkoko"; diff --git a/src/styles/profiles/_aungkoko.scss b/src/styles/profiles/_aungkoko.scss new file mode 100644 index 0000000..b69c465 --- /dev/null +++ b/src/styles/profiles/_aungkoko.scss @@ -0,0 +1,59 @@ +.octagon { + width: 250px; + height: 250px; + + .corner { + width: 40px; + height: 40px; + position: absolute; + z-index: 10; + } + + /* top-left */ + .corner:nth-child(1) { + top: calc(0% - 20px); + left: calc(30% - 20px); + } + + /* top-right */ + .corner:nth-child(2) { + top: calc(0% - 20px); + left: calc(70% - 20px); + } + + /* right-top */ + .corner:nth-child(3) { + top: calc(30% - 20px); + right: calc(0% - 20px); + } + + /* right-bottom */ + .corner:nth-child(4) { + bottom: calc(30% - 20px); + right: calc(0% - 20px); + } + + /* bottom-right */ + .corner:nth-child(5) { + bottom: calc(0% - 20px); + left: calc(70% - 20px); + } + + /* bottom-left */ + .corner:nth-child(6) { + bottom: calc(0% - 20px); + left: calc(30% - 20px); + } + + /* left-bottom */ + .corner:nth-child(7) { + bottom: calc(30% - 20px); + left: calc(0% - 20px); + } + + /* left-top */ + .corner:nth-child(8) { + top: calc(30% - 20px); + left: calc(0% - 20px); + } +} diff --git a/tailwind.config.ts b/tailwind.config.ts index 06c35f3..1b7913c 100644 --- a/tailwind.config.ts +++ b/tailwind.config.ts @@ -15,6 +15,8 @@ const config: Config = { // that is animation class animation: { fadein: "fadeIn 0.5s ease-out forwards", + shine: "shine 1s", + infinite_shine: "infinite_shine 3s infinite", }, colors: { primary: "#923293", @@ -42,6 +44,21 @@ const config: Config = { opacity: "1", }, }, + shine: { + "100%": { left: "125%" }, + }, + infinite_shine: { + "40%, 100%": { + opacity: "0", + left: "125%", + }, + "0%": { + opacity: "0", + }, + "10%": { + opacity: "1", + }, + }, }, }, },