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 */}
+
+
+
+
+
+
+
+
+
+ {skills.map(({ iconUrl, 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",
+ },
+ },
},
},
},