diff --git a/Week-1/Task-1/r3f/src/App.jsx b/Week-1/Task-1/r3f/src/App.jsx index e69de29..e3242ed 100644 --- a/Week-1/Task-1/r3f/src/App.jsx +++ b/Week-1/Task-1/r3f/src/App.jsx @@ -0,0 +1,16 @@ +import { Canvas } from '@react-three/fiber' +import Box from './components/Box' + +function App() { + return ( +
+ + + + + +
+ ) +} + +export default App; \ No newline at end of file diff --git a/Week-1/Task-1/r3f/src/components/Box.jsx b/Week-1/Task-1/r3f/src/components/Box.jsx new file mode 100644 index 0000000..742eef9 --- /dev/null +++ b/Week-1/Task-1/r3f/src/components/Box.jsx @@ -0,0 +1,24 @@ +import { useRef, useState } from 'react' +import { useFrame } from '@react-three/fiber' + +function Box() { + const meshRef = useRef() + const [color, setColor] = useState('red') + useFrame(() => { + meshRef.current.rotation.x += 0.01 + meshRef.current.rotation.y += 0.01 + }) + + return ( + setColor(prev => (prev === 'pink' ? 'yellow' : 'pink'))} + rotation={[0.4, 0.4, 0]} + > + + + + ) +} + +export default Box diff --git a/Week-1/Task-1/r3f/src/index.css b/Week-1/Task-1/r3f/src/index.css index 2c84af0..e60751d 100644 --- a/Week-1/Task-1/r3f/src/index.css +++ b/Week-1/Task-1/r3f/src/index.css @@ -1,111 +1,12 @@ -:root { - --text: #6b6375; - --text-h: #08060d; - --bg: #fff; - --border: #e5e4e7; - --code-bg: #f4f3ec; - --accent: #aa3bff; - --accent-bg: rgba(170, 59, 255, 0.1); - --accent-border: rgba(170, 59, 255, 0.5); - --social-bg: rgba(244, 243, 236, 0.5); - --shadow: - rgba(0, 0, 0, 0.1) 0 10px 15px -3px, rgba(0, 0, 0, 0.05) 0 4px 6px -2px; - - --sans: system-ui, 'Segoe UI', Roboto, sans-serif; - --heading: system-ui, 'Segoe UI', Roboto, sans-serif; - --mono: ui-monospace, Consolas, monospace; - - font: 18px/145% var(--sans); - letter-spacing: 0.18px; - color-scheme: light dark; - color: var(--text); - background: var(--bg); - font-synthesis: none; - text-rendering: optimizeLegibility; - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; - - @media (max-width: 1024px) { - font-size: 16px; - } -} - -@media (prefers-color-scheme: dark) { - :root { - --text: #9ca3af; - --text-h: #f3f4f6; - --bg: #16171d; - --border: #2e303a; - --code-bg: #1f2028; - --accent: #c084fc; - --accent-bg: rgba(192, 132, 252, 0.15); - --accent-border: rgba(192, 132, 252, 0.5); - --social-bg: rgba(47, 48, 58, 0.5); - --shadow: - rgba(0, 0, 0, 0.4) 0 10px 15px -3px, rgba(0, 0, 0, 0.25) 0 4px 6px -2px; - } - - #social .button-icon { - filter: invert(1) brightness(2); - } -} - -body { - margin: 0; -} - -#root { - width: 1126px; - max-width: 100%; - margin: 0 auto; - text-align: center; - border-inline: 1px solid var(--border); - min-height: 100svh; - display: flex; - flex-direction: column; +* { box-sizing: border-box; } -h1, -h2 { - font-family: var(--heading); - font-weight: 500; - color: var(--text-h); -} - -h1 { - font-size: 56px; - letter-spacing: -1.68px; - margin: 32px 0; - @media (max-width: 1024px) { - font-size: 36px; - margin: 20px 0; - } -} -h2 { - font-size: 24px; - line-height: 118%; - letter-spacing: -0.24px; - margin: 0 0 8px; - @media (max-width: 1024px) { - font-size: 20px; - } -} -p { +body, html, #root { margin: 0; -} - -code, -.counter { - font-family: var(--mono); - display: inline-flex; - border-radius: 4px; - color: var(--text-h); -} - -code { - font-size: 15px; - line-height: 135%; - padding: 4px 8px; - background: var(--code-bg); + padding: 0; + width: 100%; + height: 100%; + overflow: hidden; + background-color: #111; }