diff --git a/package.json b/package.json index 4194a6f..1323cd8 100644 --- a/package.json +++ b/package.json @@ -16,6 +16,7 @@ "@astrojs/tailwind": "^5.0.1", "@emotion/react": "^11.11.1", "@emotion/styled": "^11.11.0", + "@material-tailwind/react": "^2.1.10", "@mui/material": "^5.14.18", "@types/react": "^18.0.21", "@types/react-dom": "^18.0.6", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 99e1326..f01e484 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -23,6 +23,9 @@ importers: '@emotion/styled': specifier: ^11.11.0 version: 11.11.0(@emotion/react@11.11.1(@types/react@18.2.33)(react@18.2.0))(@types/react@18.2.33)(react@18.2.0) + '@material-tailwind/react': + specifier: ^2.1.10 + version: 2.1.10(react-dom@18.2.0(react@18.2.0))(react@18.2.0) '@mui/material': specifier: ^5.14.18 version: 5.14.18(@emotion/react@11.11.1(@types/react@18.2.33)(react@18.2.0))(@emotion/styled@11.11.0(@emotion/react@11.11.1(@types/react@18.2.33)(react@18.2.0))(@types/react@18.2.33)(react@18.2.0))(@types/react@18.2.33)(react-dom@18.2.0(react@18.2.0))(react@18.2.0) @@ -260,9 +263,15 @@ packages: '@emotion/hash@0.9.1': resolution: {integrity: sha512-gJB6HLm5rYwSLI6PQa+X1t5CFGrv1J1TWG+sOyMCeKz2ojaj6Fnl/rZEspogG+cvqbt4AE/2eIyD2QfLKTBNlQ==} + '@emotion/is-prop-valid@0.8.8': + resolution: {integrity: sha512-u5WtneEAr5IDG2Wv65yhunPSMLIpuKsbuOktRojfrEiEvRyC85LgPMZI63cr7NUqT8ZIGdSVg8ZKGxIug4lXcA==} + '@emotion/is-prop-valid@1.2.1': resolution: {integrity: sha512-61Mf7Ufx4aDxx1xlDeOm8aFFigGHE4z+0sKCa+IHCeZKiyP9RLD0Mmx7m8b9/Cf37f7NAvQOOJAbQQGVr5uERw==} + '@emotion/memoize@0.7.4': + resolution: {integrity: sha512-Ja/Vfqe3HpuzRsG1oBtWTHk2PGZ7GR+2Vz5iYGelAw8dx32K0y7PjVuxK6z1nMpZOqAFsRUPCkK1YjJ56qJlgw==} + '@emotion/memoize@0.8.1': resolution: {integrity: sha512-W2P2c/VRW1/1tLox0mVUalvnWXxavmv/Oum2aPsRcoDJuob75FC3Y8FbpfLwUegRcxINtGUMPq0tFCvYNTBXNA==} @@ -575,12 +584,24 @@ packages: '@floating-ui/dom@1.5.3': resolution: {integrity: sha512-ClAbQnEqJAKCJOEbbLo5IUlZHkNszqhuxS4fHAVxRPXPya6Ysf2G8KypnYcOTpx6I8xcgF9bbHb6g/2KpbV8qA==} + '@floating-ui/react-dom@1.3.0': + resolution: {integrity: sha512-htwHm67Ji5E/pROEAr7f8IKFShuiCKHwUC/UY4vC3I5jiSvGFAYnSYiZO5MlGmads+QqvUkR9ANHEguGrDv72g==} + peerDependencies: + react: '>=16.8.0' + react-dom: '>=16.8.0' + '@floating-ui/react-dom@2.0.4': resolution: {integrity: sha512-CF8k2rgKeh/49UrnIBs4BdxPUV6vize/Db1d/YbCLyp9GiVZ0BEwf5AiDSxJRCr6yOkGqTFHtmrULxkEfYZ7dQ==} peerDependencies: react: '>=16.8.0' react-dom: '>=16.8.0' + '@floating-ui/react@0.19.0': + resolution: {integrity: sha512-fgYvN4ksCi5OvmPXkyOT8o5a8PSKHMzPHt+9mR6KYWdF16IAjWRLZPAAziI2sznaWT23drRFrYw64wdvYqqaQw==} + peerDependencies: + react: '>=16.8.0' + react-dom: '>=16.8.0' + '@floating-ui/utils@0.1.6': resolution: {integrity: sha512-OfX7E2oUDYxtBvsuS4e/jSn4Q9Qb6DzgeYtsAdkPZ47znpoNsMgZw0+tVijiv3uGNR6dgNlty6r9rzIzHjtd/A==} @@ -715,6 +736,30 @@ packages: '@jridgewell/trace-mapping@0.3.19': resolution: {integrity: sha512-kf37QtfW+Hwx/buWGMPcR60iF9ziHa6r/CZJIHbmcm4+0qrXiVdxegAH0F6yddEVQ7zdkjcGCgCzUu+BcbhQxw==} + '@material-tailwind/react@2.1.10': + resolution: {integrity: sha512-xGU/mLDKDBp/qZ8Dp2XR7fKcTpDuFeZEBqoL9Bk/29kakKxNxjUGYSRHEFLsyOFf4VIhU6WGHdIS7tOA3QGJHA==} + peerDependencies: + react: ^16 || ^17 || ^18 + react-dom: ^16 || ^17 || ^18 + + '@motionone/animation@10.18.0': + resolution: {integrity: sha512-9z2p5GFGCm0gBsZbi8rVMOAJCtw1WqBTIPw3ozk06gDvZInBPIsQcHgYogEJ4yuHJ+akuW8g1SEIOpTOvYs8hw==} + + '@motionone/dom@10.12.0': + resolution: {integrity: sha512-UdPTtLMAktHiqV0atOczNYyDd/d8Cf5fFsd1tua03PqTwwCe/6lwhLSQ8a7TbnQ5SN0gm44N1slBfj+ORIhrqw==} + + '@motionone/easing@10.18.0': + resolution: {integrity: sha512-VcjByo7XpdLS4o9T8t99JtgxkdMcNWD3yHU/n6CLEz3bkmKDRZyYQ/wmSf6daum8ZXqfUAgFeCZSpJZIMxaCzg==} + + '@motionone/generators@10.18.0': + resolution: {integrity: sha512-+qfkC2DtkDj4tHPu+AFKVfR/C30O1vYdvsGYaR13W/1cczPrrcjdvYCj0VLFuRMN+lP1xvpNZHCRNM4fBzn1jg==} + + '@motionone/types@10.17.1': + resolution: {integrity: sha512-KaC4kgiODDz8hswCrS0btrVrzyU2CSQKO7Ps90ibBVSQmjkrt2teqta6/sOG59v7+dPnKMAg13jyqtMKV2yJ7A==} + + '@motionone/utils@10.18.0': + resolution: {integrity: sha512-3XVF7sgyTSI2KWvTf6uLlBJ5iAgRgmvp3bpuOiQJvInd4nZ19ET8lX5unn30SlmRH7hXbBbH+Gxd0m0klJ3Xtw==} + '@mui/base@5.0.0-beta.24': resolution: {integrity: sha512-bKt2pUADHGQtqWDZ8nvL2Lvg2GNJyd/ZUgZAJoYzRgmnxBL9j36MSlS3+exEdYkikcnvVafcBtD904RypFKb0w==} engines: {node: '>=12.0.0'} @@ -936,6 +981,10 @@ packages: argparse@2.0.1: resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==} + aria-hidden@1.2.4: + resolution: {integrity: sha512-y+CcFFwelSXpLZk/7fMB2mUbGtX9lKycf1MWJ7CaTIERyitVlyQx6C+sxcROU2BAJ24OiZyK+8wj2i8AlBoS3A==} + engines: {node: '>=10'} + array-iterate@2.0.1: resolution: {integrity: sha512-I1jXZMjAgCMmxT4qxXfPXa6SthSoE8h6gkSI9BGGNv8mP8G/v0blc+qFnZu6K42vTOiuME596QaLO0TP3Lk0xg==} @@ -1051,6 +1100,9 @@ packages: resolution: {integrity: sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==} engines: {node: '>=8'} + classnames@2.3.2: + resolution: {integrity: sha512-CSbhY4cFEJRe6/GQzIk5qXZ4Jeg5pcsP7b5peFSDpffpe1cqjASH/n9UTjBwOp6XpMSTwQ8Za2K5V02ueA7Tmw==} + cli-boxes@3.0.0: resolution: {integrity: sha512-/lzGpEWL/8PfI0BmBOPRwp0c/wFNX1RdUML3jK/RcSBA9T8mZDdQpqYBKtCFTOfQbwPqWEOpjqW+Fnayc0969g==} engines: {node: '>=10'} @@ -1166,6 +1218,10 @@ packages: resolution: {integrity: sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==} engines: {node: '>=4.0.0'} + deepmerge@4.2.2: + resolution: {integrity: sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==} + engines: {node: '>=0.10.0'} + delayed-stream@1.0.0: resolution: {integrity: sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==} engines: {node: '>=0.4.0'} @@ -1318,6 +1374,15 @@ packages: fraction.js@4.3.6: resolution: {integrity: sha512-n2aZ9tNfYDwaHhvFTkhFErqOMIb8uyzSQ+vGJBjZyanAKZVbGUQ1sngfk9FdkBw7G26O7AgNjLcecLffD1c7eg==} + framer-motion@6.5.1: + resolution: {integrity: sha512-o1BGqqposwi7cgDrtg0dNONhkmPsUFDaLcKXigzuTFC5x58mE8iyTazxSudFzmT6MEyJKfjjU8ItoMe3W+3fiw==} + peerDependencies: + react: '>=16.8 || ^17.0.0 || ^18.0.0' + react-dom: '>=16.8 || ^17.0.0 || ^18.0.0' + + framesync@6.0.1: + resolution: {integrity: sha512-fUY88kXvGiIItgNC7wcTOl0SNRCVXMKSWW2Yzfmn7EKNc+MpCzcz9DhdHcdjbrtN3c6R4H5dTY2jiCpPdysEjA==} + fs-constants@1.0.0: resolution: {integrity: sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==} @@ -1394,6 +1459,9 @@ packages: hastscript@7.2.0: resolution: {integrity: sha512-TtYPq24IldU8iKoJQqvZOuhi5CyCQRAbvDOX0x1eW6rsHSxa/1i2CCiptNTotGHJ3VoHRGmqiv6/D3q113ikkw==} + hey-listen@1.0.8: + resolution: {integrity: sha512-COpmrF2NOg4TBWUJ5UVyaCU2A88wEMkUPK4hNqyCkqHbxT92BbvfjoSozkAIIm6XhicGlJHhFdullInrdhwU8Q==} + hoist-non-react-statics@3.3.2: resolution: {integrity: sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==} @@ -1593,6 +1661,9 @@ packages: markdown-table@3.0.3: resolution: {integrity: sha512-Z1NL3Tb1M9wH4XESsCDEksWoKTdlUafKc4pt0GRwjUyXaCFZ+dc3g2erqB6zm3szA2IUSi7VnPI+o/9jnxh9hw==} + material-ripple-effects@2.0.1: + resolution: {integrity: sha512-hHlUkZAuXbP94lu02VgrPidbZ3hBtgXBtjlwR8APNqOIgDZMV8MCIcsclL8FmGJQHvnORyvoQgC965vPsiyXLQ==} + mdast-util-definitions@5.1.2: resolution: {integrity: sha512-8SVPMuHqlPME/z3gqVwWY4zVXn8lqKv/pAhC57FuJ40ImXyBpmO5ukh98zB2v7Blql2FiHjHv9LVztSIqjY+MA==} @@ -1932,6 +2003,9 @@ packages: resolution: {integrity: sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==} engines: {node: '>=8'} + popmotion@11.0.3: + resolution: {integrity: sha512-Y55FLdj3UxkR7Vl3s7Qr4e9m0onSnP8W7d/xQLsoJM40vs6UKHFdygs6SWryasTZYqugMjm3BepCF4CWXDiHgA==} + postcss-import@15.1.0: resolution: {integrity: sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==} engines: {node: '>=14.0.0'} @@ -2343,6 +2417,9 @@ packages: resolution: {integrity: sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ==} engines: {node: '>=0.10.0'} + style-value-types@5.0.0: + resolution: {integrity: sha512-08yq36Ikn4kx4YU6RD7jWEv27v4V+PUsOGa4n/as8Et3CuODMJQ00ENeAVXAeydX4Z2j1XHZF1K2sX4mGl18fA==} + stylis@4.2.0: resolution: {integrity: sha512-Orov6g6BB1sDfYgzWfTHDOxamtX1bE/zo104Dh9e6fqJ3PooipYyfJ0pUmrZO2wAvO8YbEyeFrkV91XTsGMSrw==} @@ -2366,6 +2443,12 @@ packages: resolution: {integrity: sha512-cDfglW1B6uSmB6eB6pNmzDTNLmZtu5bWWa1vak0RU7fOI9qHjMzl7gVBvYSl34b0RU2N11HxxETJqQ5LeqI1cA==} engines: {node: '>= 4.7.0'} + tabbable@6.2.0: + resolution: {integrity: sha512-Cat63mxsVJlzYvN51JmVXIgNoUokrIaT2zLclCXjRd8boZ0004U4KCs/sToJ75C6sdlByWxpYnb5Boif1VSFew==} + + tailwind-merge@1.8.1: + resolution: {integrity: sha512-+fflfPxvHFr81hTJpQ3MIwtqgvefHZFUHFiIHpVIRXvG/nX9+gu2P7JNlFu2bfDMJ+uHhi/pUgzaYacMoXv+Ww==} + tailwindcss@3.3.3: resolution: {integrity: sha512-A0KgSkef7eE4Mf+nKJ83i75TMyq8HqY3qmFIJSWy8bNt0v1lG7jUcpGpoTFxAwYcWOphcTBLPPJg+bDfhDf52w==} engines: {node: '>=14.0.0'} @@ -2866,10 +2949,18 @@ snapshots: '@emotion/hash@0.9.1': {} + '@emotion/is-prop-valid@0.8.8': + dependencies: + '@emotion/memoize': 0.7.4 + optional: true + '@emotion/is-prop-valid@1.2.1': dependencies: '@emotion/memoize': 0.8.1 + '@emotion/memoize@0.7.4': + optional: true + '@emotion/memoize@0.8.1': {} '@emotion/react@11.11.1(@types/react@18.2.33)(react@18.2.0)': @@ -3060,12 +3151,26 @@ snapshots: '@floating-ui/core': 1.5.0 '@floating-ui/utils': 0.1.6 + '@floating-ui/react-dom@1.3.0(react-dom@18.2.0(react@18.2.0))(react@18.2.0)': + dependencies: + '@floating-ui/dom': 1.5.3 + react: 18.2.0 + react-dom: 18.2.0(react@18.2.0) + '@floating-ui/react-dom@2.0.4(react-dom@18.2.0(react@18.2.0))(react@18.2.0)': dependencies: '@floating-ui/dom': 1.5.3 react: 18.2.0 react-dom: 18.2.0(react@18.2.0) + '@floating-ui/react@0.19.0(react-dom@18.2.0(react@18.2.0))(react@18.2.0)': + dependencies: + '@floating-ui/react-dom': 1.3.0(react-dom@18.2.0(react@18.2.0))(react@18.2.0) + aria-hidden: 1.2.4 + react: 18.2.0 + react-dom: 18.2.0(react@18.2.0) + tabbable: 6.2.0 + '@floating-ui/utils@0.1.6': {} '@img/sharp-darwin-arm64@0.33.0': @@ -3160,6 +3265,53 @@ snapshots: '@jridgewell/resolve-uri': 3.1.1 '@jridgewell/sourcemap-codec': 1.4.15 + '@material-tailwind/react@2.1.10(react-dom@18.2.0(react@18.2.0))(react@18.2.0)': + dependencies: + '@floating-ui/react': 0.19.0(react-dom@18.2.0(react@18.2.0))(react@18.2.0) + classnames: 2.3.2 + deepmerge: 4.2.2 + framer-motion: 6.5.1(react-dom@18.2.0(react@18.2.0))(react@18.2.0) + material-ripple-effects: 2.0.1 + prop-types: 15.8.1 + react: 18.2.0 + react-dom: 18.2.0(react@18.2.0) + tailwind-merge: 1.8.1 + + '@motionone/animation@10.18.0': + dependencies: + '@motionone/easing': 10.18.0 + '@motionone/types': 10.17.1 + '@motionone/utils': 10.18.0 + tslib: 2.6.2 + + '@motionone/dom@10.12.0': + dependencies: + '@motionone/animation': 10.18.0 + '@motionone/generators': 10.18.0 + '@motionone/types': 10.17.1 + '@motionone/utils': 10.18.0 + hey-listen: 1.0.8 + tslib: 2.6.2 + + '@motionone/easing@10.18.0': + dependencies: + '@motionone/utils': 10.18.0 + tslib: 2.6.2 + + '@motionone/generators@10.18.0': + dependencies: + '@motionone/types': 10.17.1 + '@motionone/utils': 10.18.0 + tslib: 2.6.2 + + '@motionone/types@10.17.1': {} + + '@motionone/utils@10.18.0': + dependencies: + '@motionone/types': 10.17.1 + hey-listen: 1.0.8 + tslib: 2.6.2 + '@mui/base@5.0.0-beta.24(@types/react@18.2.33)(react-dom@18.2.0(react@18.2.0))(react@18.2.0)': dependencies: '@babel/runtime': 7.23.4 @@ -3382,6 +3534,10 @@ snapshots: argparse@2.0.1: {} + aria-hidden@1.2.4: + dependencies: + tslib: 2.6.2 + array-iterate@2.0.1: {} astro@3.2.3: @@ -3582,6 +3738,8 @@ snapshots: ci-info@3.9.0: {} + classnames@2.3.2: {} + cli-boxes@3.0.0: {} cli-cursor@4.0.0: @@ -3674,6 +3832,8 @@ snapshots: deep-extend@0.6.0: optional: true + deepmerge@4.2.2: {} + delayed-stream@1.0.0: {} dequal@2.0.3: {} @@ -3849,6 +4009,23 @@ snapshots: fraction.js@4.3.6: {} + framer-motion@6.5.1(react-dom@18.2.0(react@18.2.0))(react@18.2.0): + dependencies: + '@motionone/dom': 10.12.0 + framesync: 6.0.1 + hey-listen: 1.0.8 + popmotion: 11.0.3 + react: 18.2.0 + react-dom: 18.2.0(react@18.2.0) + style-value-types: 5.0.0 + tslib: 2.6.2 + optionalDependencies: + '@emotion/is-prop-valid': 0.8.8 + + framesync@6.0.1: + dependencies: + tslib: 2.6.2 + fs-constants@1.0.0: optional: true @@ -3959,6 +4136,8 @@ snapshots: property-information: 6.3.0 space-separated-tokens: 2.0.2 + hey-listen@1.0.8: {} + hoist-non-react-statics@3.3.2: dependencies: react-is: 16.13.1 @@ -4113,6 +4292,8 @@ snapshots: markdown-table@3.0.3: {} + material-ripple-effects@2.0.1: {} + mdast-util-definitions@5.1.2: dependencies: '@types/mdast': 3.0.13 @@ -4597,6 +4778,13 @@ snapshots: dependencies: find-up: 4.1.0 + popmotion@11.0.3: + dependencies: + framesync: 6.0.1 + hey-listen: 1.0.8 + style-value-types: 5.0.0 + tslib: 2.6.2 + postcss-import@15.1.0(postcss@8.4.31): dependencies: postcss: 8.4.31 @@ -5058,6 +5246,11 @@ snapshots: strip-json-comments@2.0.1: optional: true + style-value-types@5.0.0: + dependencies: + hey-listen: 1.0.8 + tslib: 2.6.2 + stylis@4.2.0: {} sucrase@3.34.0: @@ -5082,6 +5275,10 @@ snapshots: swiper@11.0.7: {} + tabbable@6.2.0: {} + + tailwind-merge@1.8.1: {} + tailwindcss@3.3.3: dependencies: '@alloc/quick-lru': 5.2.0 @@ -5169,8 +5366,7 @@ snapshots: strip-bom: 4.0.0 type-fest: 0.13.1 - tslib@2.6.2: - optional: true + tslib@2.6.2: {} tunnel-agent@0.6.0: dependencies: diff --git a/public/home/Vector.png b/public/home/Vector.png new file mode 100644 index 0000000..bf02b32 Binary files /dev/null and b/public/home/Vector.png differ diff --git a/public/home/logo.png b/public/home/logo.png new file mode 100644 index 0000000..5bc67b3 Binary files /dev/null and b/public/home/logo.png differ diff --git a/src/components/bitspace/CollabWithUs.astro b/src/components/bitspace/CollabWithUs.astro index 72d4db0..c804152 100644 --- a/src/components/bitspace/CollabWithUs.astro +++ b/src/components/bitspace/CollabWithUs.astro @@ -1,7 +1,9 @@

Collaborate with us

diff --git a/src/components/common/Navbar.jsx b/src/components/common/Navbar.jsx new file mode 100644 index 0000000..d614c8a --- /dev/null +++ b/src/components/common/Navbar.jsx @@ -0,0 +1,126 @@ +import React from "react"; +import Hamburger from "./hamburger"; +import { MdKeyboardArrowDown } from "react-icons/md"; +import { FaDiscord } from "react-icons/fa"; + +const Navbar = () => { + const list = [ + { + name: "Org", + link: "/org", + subMenu: [ + { name: "About", link: "/about" }, + { + name: "Contact us ", + link: "/bitspace/#contact_us", + }, + ], + }, + { + name: "Bitcoin Career", + link: "/#bitcoin_career", + subMenu: [ + { name: "Study cohorts", link: "/cohorts" }, + { name: "Fellowship", link: "/fellowship" }, + ], + }, + { + name: "IRL Funzzz", + link: "/#irl_funzzz", + subMenu: [ + { name: "Bitspace", link: "/bitspace" }, + { name: "BITDEVS", link: "/meetup" }, + ], + }, + { + name: "Social Clubs ", + link: "/#social_clubs", + subMenu: [ + { + name: "Latest in Bitcoin Tech", + link: "/optech", + }, + { name: "Reading Club", link: "/readingClub" }, + { + name: "Bitcoin PR Review Club", + link: "/review", + }, + { + name: "Hands-on Lightning", + link: "/hands-on-lightning", + }, + { name: "Bitcoin Talks", link: "/talks" }, + ], + }, + // { + // name: "Join our community", + // link: "/#join_our_community", + // }, + ]; + + return ( +
+ +
+ ); +}; + +export default Navbar; diff --git a/src/components/common/hamburger.tsx b/src/components/common/hamburger.tsx index 4b4c8c6..33195a6 100644 --- a/src/components/common/hamburger.tsx +++ b/src/components/common/hamburger.tsx @@ -8,6 +8,15 @@ import { FaLinkedin, } from "react-icons/fa"; +import { MdKeyboardArrowDown } from "react-icons/md"; + +import { + Accordion, + AccordionHeader, + AccordionBody, +} from "@material-tailwind/react"; + + const Hamburger = () => { const [open, setOpen] = useState(false); const handleClick = () => { @@ -60,59 +69,61 @@ const Hamburger = () => { }; const SideMenu = () => { - const links = [ - { - name: "Home", - url: "/", - desc: "Back to the home page.", - }, - { - name: "Cohorts", - url: "/cohorts", - desc: "Learn Bitcoin Technicals via Self-Study Cohort Programs.", - }, - { - name: "Fellowship", - url: "/fellowship", - desc: "Bitshala's paid fellowship program.", - }, - { - name: "Meetups", - url: "/meetup", - desc: "Come, hang with us in the Meetups", - }, - { - name: "Reading Club", - url: "/readingClub", - desc: "Weekly reading club for Bitcoin learners", - }, - { - name: "Review Club", - url: "/review", - desc: "Deep-dive into Bitcoin Core via bi-weekly PR Review Clubs.", - }, + const [open, setOpen] = useState(true); + + const handleOpen = (value: boolean) => setOpen(value); + + const list = [ { - name: "Optech", - url: "/optech", - desc: "Bitcoin Optech Weekly Deep Dive Series", + name: "Org", + link: "/org", + subMenu: [ + { name: "About", link: "/org/about" }, + { + name: "Contact us ", + link: "/bitspace/#contact_us", + }, + ], }, { - name: "Talks", - url: "/talks", - desc: "Learn about Bitcoin through insightful conversations", + name: "Bitcoin Career", + link: "/#bitcoin_career", + subMenu: [ + { name: "Study cohorts", link: "/cohorts" }, + { name: "Fellowship", link: "/fellowship" }, + ], }, { - name: "Bitspace", - url: "/bitspace", - desc: "India’s Bitcoin-Only community hub for Bitcoin enthusiasts!", + name: "IRL Funzzz", + link: "/#irl_funzzz", + subMenu: [ + { name: "Bitspace", link: "/bitspace" }, + { name: "BITDEVS", link: "/meetup" }, + ], }, { - name: "Join our Discord!", - url: "https://discord.com/invite/STeQFVEWf9", - tar: "_blank", - desc: "Join our Discord and be a part of the biggest technical bitcoin community", + + name: "Social Clubs ", + link: "/#social_clubs", + subMenu: [ + { + name: "Latest in Bitcoin Tech", + link: "/optech", + }, + { name: "Reading Club", link: "/readingClub" }, + { + name: "Bitcoin PR Review Club", + link: "/review", + }, + { + name: "Hands-on Lightning", + link: "/hands-on-lightning", + }, + { name: "Bitcoin Talks", link: "/talks" }, + ], }, ]; + return (
@@ -146,22 +157,37 @@ const SideMenu = () => {
- + + {list.map((item, index) => { + return ( + + + handleOpen(open ? false : true) + } + > + {item.name} + + + + {item.subMenu.map((subItem) => { + return ( +
+ + - {subItem.name} + +
+ ); + })} +
+
+ ); + })} +
); }; diff --git a/src/components/common/notification.tsx b/src/components/common/notification.tsx index 371c468..bb5ff5f 100644 --- a/src/components/common/notification.tsx +++ b/src/components/common/notification.tsx @@ -2,7 +2,13 @@ import { Snackbar } from "@mui/material"; import { FaWindowClose } from "react-icons/fa"; import { useEffect, useState } from "react"; -const Notification = ({ message, url }: { message: string; url: string }) => { +const Notification = ({ + message, + url, +}: { + message: string; + url: string; +}) => { const [open, setOpen] = useState(false); const handleClose = () => { setOpen(false); @@ -18,7 +24,7 @@ const Notification = ({ message, url }: { message: string; url: string }) => { }} open={open} > -
+
{message} diff --git a/src/layouts/Layout.astro b/src/layouts/Layout.astro index 2c27fe7..61685fa 100644 --- a/src/layouts/Layout.astro +++ b/src/layouts/Layout.astro @@ -1,6 +1,7 @@ --- import Footer from "../components/common/Footer.astro"; import Header from "../components/common/Header.astro"; +import Navbar from "../components/common/Navbar"; import Hamburger from "../components/common/hamburger"; import Notification from "../components/common/notification"; // import Notification from "../components/common/notification"; @@ -92,17 +93,10 @@ const { title, headerProps, isVisible } = Astro.props; content="https://opengraph.b-cdn.net/production/documents/be8ca05b-5de1-4ab8-99b6-b064c8ad0b4c.png?token=Jriat_jsVklKiXah09FNuY3b8X2kT-Vv-3eN4Cgdyvg&height=675&width=1200&expires=33241899715" /> - - + + + +