Created
December 9, 2022 12:23
-
-
Save adrianhajdin/6e2ad3c9f383d77c369322476c228b73 to your computer and use it in GitHub Desktop.
Build and Deploy a Web3 Crowdfunding Platform (Kickstarter) As Your First Blockchain Application
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import { createCampaign, dashboard, logout, payment, profile, withdraw } from '../assets'; | |
export const navlinks = [ | |
{ | |
name: 'dashboard', | |
imgUrl: dashboard, | |
link: '/', | |
}, | |
{ | |
name: 'campaign', | |
imgUrl: createCampaign, | |
link: '/create-campaign', | |
}, | |
{ | |
name: 'payment', | |
imgUrl: payment, | |
link: '/', | |
disabled: true, | |
}, | |
{ | |
name: 'withdraw', | |
imgUrl: withdraw, | |
link: '/', | |
disabled: true, | |
}, | |
{ | |
name: 'profile', | |
imgUrl: profile, | |
link: '/profile', | |
}, | |
{ | |
name: 'logout', | |
imgUrl: logout, | |
link: '/', | |
disabled: true, | |
}, | |
]; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
@import url("https://fonts.googleapis.com/css2?family=Epilogue:wght@400;500;600;700&display=swap"); | |
@tailwind base; | |
@tailwind components; | |
@tailwind utilities; | |
.linear-gradient { | |
background: linear-gradient( | |
179.14deg, | |
rgba(32, 18, 63, 0) -7.14%, | |
#000000 87.01% | |
); | |
} | |
input[type="date"]::-webkit-calendar-picker-indicator { | |
cursor: pointer; | |
filter: invert(0.8); | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** @type {import('tailwindcss').Config} */ | |
module.exports = { | |
content: [ | |
"./index.html", | |
"./src/**/*.{js,ts,jsx,tsx}", | |
], | |
theme: { | |
extend: { | |
fontFamily: { | |
epilogue: ['Epilogue', 'sans-serif'], | |
}, | |
boxShadow: { | |
secondary: '10px 10px 20px rgba(2, 2, 2, 0.25)', | |
}, | |
}, | |
}, | |
plugins: [], | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
export const daysLeft = (deadline) => { | |
const difference = new Date(deadline).getTime() - Date.now(); | |
const remainingDays = difference / (1000 * 3600 * 24); | |
return remainingDays.toFixed(0); | |
}; | |
export const calculateBarPercentage = (goal, raisedAmount) => { | |
const percentage = Math.round((raisedAmount * 100) / goal); | |
return percentage; | |
}; | |
export const checkIfImage = (url, callback) => { | |
const img = new Image(); | |
img.src = url; | |
if (img.complete) callback(true); | |
img.onload = () => callback(true); | |
img.onerror = () => callback(false); | |
}; |
randomusert
make sure you have installed dotenv as a package in your package.json file e.g npm i dotenv
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
// SPDX-License-Identifier: UNLICENSED
//CrowdFunding.sol file
pragma solidity ^0.8.9;
contract CrowdFunding {
struct Campaign{
address owner;
string title;
string description;
uint256 target;
uint256 deadline;
uint256 amountCollected;
string image;
address[] donators;
uint256[] donations;
}
mapping(uint256 => Campaign ) public campaigns;
uint256 public numberOfCampaigns = 0;
function createCampaign(address _owner, string memory _title, string memory _description, uint256 _target, uint256 _deadline, string memory _image ) public returns (uint256){
}
function donateToCampaign(uint256 _id) public payable{
}
function getdonators(uint256 _id) view public returns (address[] memory, uint256[] memory){
return (campaigns[_id].donators, campaigns[_id].donations);
}
function getCampaigns() public view returns (Campaign[] memory) {
}
}