-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
22 changed files
with
396 additions
and
45 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,26 @@ | ||
# Cerify | ||
|
||
|
||
## Score | ||
|
||
### PEP3 | ||
``` | ||
------------------------------------------------------------------ | ||
Your code has been rated at 9.41/10 (previous run: 9.30/10, +0.11) | ||
``` | ||
|
||
## Screenshots | ||
|
||
data:image/s3,"s3://crabby-images/7ce16/7ce1648499db75b9491394852b8e582ea927d259" alt="API" | ||
|
||
data:image/s3,"s3://crabby-images/3d4ee/3d4eeaa2d9a30932615d435443d783a50187a67f" alt="Template" | ||
|
||
data:image/s3,"s3://crabby-images/4b4a5/4b4a5d6abb2693d083c09c5afe2e1693bf22af0d" alt="Template Done" | ||
|
||
data:image/s3,"s3://crabby-images/5fa38/5fa38e1a40e1311594377c9ad431bff7a47e514b" alt="Create Certificate" | ||
|
||
data:image/s3,"s3://crabby-images/afec1/afec1a4deb43c60130430a318d192930b4ce13fb" alt="Certificate Done" | ||
|
||
|
||
## Contributor | ||
|
||
``` |
Empty file.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
BASE_URL=http://localhost:8000 |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,124 @@ | ||
"use client"; | ||
|
||
import { useState } from "react"; | ||
// import dotenv from "dotenv"; | ||
// dotenv.config(); | ||
require('dotenv').config(); | ||
|
||
const base_url = process.env.BASE_URL; | ||
|
||
export default function Home() { | ||
const [certificate, setCertificate] = useState(null); | ||
|
||
async function copyCertificate() { | ||
if (!certificate) { | ||
alert("No link to copy"); | ||
return; | ||
} | ||
navigator.clipboard.writeText(certificate) | ||
.then(() => { | ||
alert('Copied to clipboard!'); | ||
}) | ||
.catch((err) => { | ||
console.error('Failed to copy: ', err); | ||
}); | ||
} | ||
|
||
async function uploadCertificate(e: any) { | ||
if (!e.target.files[0]) { | ||
alert("Please upload a file"); | ||
return; | ||
} | ||
const formData = new FormData(); | ||
formData.append("file", e.target.files[0], e.target.files[0].name); | ||
const res = await fetch(`http://localhost:8000/api/v1/template`, { | ||
method: 'POST', | ||
body: formData, | ||
}); | ||
const data = await res.json(); | ||
if (!data.success) { | ||
alert(data.message); | ||
} else { | ||
setCertificate(data.dl); | ||
} | ||
} | ||
|
||
return ( | ||
<div className="h-full"> | ||
<div className="flex items-center justify-between"> | ||
<div className="container pt-4 md:pt-8 mx-auto m-4 flex flex-wrap flex-col md:flex-row items-center"> | ||
<div className="flex flex-col w-full justify-center overflow-y-hidden"> | ||
<h1 className="mb-3 text-3xl md:text-5xl text-white opacity-75 font-bold leading-tight text-center"> | ||
Welcome To | ||
<a href="/" className="pl-3 bg-clip-text text-transparent bg-gradient-to-r from-green-400 via-pink-500 to-purple-500 hover:text-transparent hover:no-underline hover:no-underline"> | ||
Certify | ||
</a>, Explore Effectively! | ||
</h1> | ||
{certificate ?( | ||
<div className="flex items-end justify-center w-full pt-20 px-20"> | ||
<div className="relative w-3/5 mr-4 text-left md:w-full lg:w-full xl:w-1/2"> | ||
<div className="relative"> | ||
<input className="w-full px-4 py-3 text-xl font-medium leading-8 text-white transition duration-200 ease-in-out bg-gray-700 border-transparent rounded-md shadow-2xl outline-none border-y border-t-gray-600 focus:border focus:border-blue-600 focus:bg-transparent focus:ring-2 focus:ring-blue-600" readOnly={true} value={certificate} /> | ||
<a href={certificate} target="_blank" rel="noreferrer"> | ||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" className="absolute w-6 h-6 text-orange-600 transform -translate-y-1/2 right-3 top-1/2"> | ||
<path stroke-linecap="round" stroke-linejoin="round" d="M13.5 6H5.25A2.25 2.25 0 003 8.25v10.5A2.25 2.25 0 005.25 21h10.5A2.25 2.25 0 0018 18.75V10.5m-10.5 6L21 3m0 0h-5.25M21 3v5.25"></path> | ||
</svg> | ||
</a> | ||
</div> | ||
</div> | ||
<button onClick={copyCertificate} type="button" className="inline-flex flex-shrink-0 px-6 py-3 text-lg font-semibold text-white transition bg-orange-600 border-0 rounded hover:bg-orange-600 hover:brightness-50 focus:outline-none"> | ||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" className="w-6 h-6 transition"><path stroke-linecap="round" stroke-linejoin="round" d="M15.75 17.25v3.375c0 .621-.504 1.125-1.125 1.125h-9.75a1.125 1.125 0 01-1.125-1.125V7.875c0-.621.504-1.125 1.125-1.125H6.75a9.06 9.06 0 011.5.124m7.5 10.376h3.375c.621 0 1.125-.504 1.125-1.125V11.25c0-4.46-3.243-8.161-7.5-8.876a9.06 9.06 0 00-1.5-.124H9.375c-.621 0-1.125.504-1.125 1.125v3.5m7.5 10.375H9.375a1.125 1.125 0 01-1.125-1.125v-9.25m12 6.625v-1.875a3.375 3.375 0 00-3.375-3.375h-1.5a1.125 1.125 0 01-1.125-1.125v-1.5a3.375 3.375 0 00-3.375-3.375H9.75"></path></svg> | ||
<span id="copyBtn">COPY</span> | ||
</button> | ||
</div> | ||
):( | ||
<> | ||
<p className="leading-normal text-base md:text-2xl mb-8 text-center"> | ||
Upload your certificate template! | ||
</p> | ||
<div className="relative text-left w-full"> | ||
<div className="relative flex items-center justify-center px-4 pt-12 pb-8 bg-no-repeat bg-cover sm:px-6 lg:px-8"> | ||
<div className="z-10 w-full p-5 bg-gray-700 bg-opacity-70 sm:max-w-lg rounded-xl"> | ||
<div className="text-center"> | ||
<h2 className="mt-2 text-3xl font-bold text-gray-200">Certificate Template Upload!</h2> | ||
<p className="mt-2 text-sm text-gray-200">Store the template.</p> | ||
</div> | ||
<form className="space-y-3"> | ||
<div className="grid grid-cols-1 space-y-2"> | ||
<label className="text-sm font-bold tracking-wide text-gray-200">Attach .PPTX</label> | ||
<div className="flex items-center justify-center w-full"> | ||
<label className="flex flex-col items-center justify-center w-full h-64 border-2 border-gray-200 border-dashed rounded-lg cursor-pointer hover:bg-white hover:bg-opacity-20"> | ||
<div className="flex flex-col items-center justify-center pt-5 pb-6"> | ||
<div className="flex flex-auto"> | ||
<img className="object-center h-36" src="/assets/upload.svg" alt="upload" /> | ||
</div> | ||
<p className="text-center text-gray-200 pointer-none p-2"> | ||
<span className="text-sm">Drag and drop</span> pptx file here <br /> or <span className="font-bold text-orange-600">Click to upload</span> from your computer | ||
</p> | ||
</div> | ||
<input id="file" name="file" type="file" className="hidden" accept=".pptx" required={true} onChange={uploadCertificate} /> | ||
</label> | ||
</div> | ||
<p className="text-sm text-gray-200 pointer-none"> | ||
<span>File type: pptx only.</span> | ||
</p> | ||
</div> | ||
</form> | ||
</div> | ||
</div> | ||
</div> | ||
</> | ||
)} | ||
</div> | ||
</div> | ||
</div> | ||
{/* <!--<div className="flex space-x-2 justify-end"> | ||
<div> | ||
<button type="button" className="inline-block rounded-full bg-blue-500 hover:bg-blue-700 border-blue-600 hover:border-blue-800 leading-normal uppercase text-white bg-color shadow-md hover:shadow-lg focus:shadow-lg focus:outline-none focus:ring-0 active:shadow-lg transform hover:scale-125 duration-300 ease-in-out transition w-9 h-9"> | ||
<img alt="Telegram" src="https://www.svgrepo.com/show/299513/telegram.svg"> | ||
</button> | ||
</div> | ||
</div>--> */} | ||
</div> | ||
); | ||
} |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,8 @@ | ||
import type { Metadata } from "next"; | ||
import "bootstrap/dist/css/bootstrap.min.css" | ||
import "./globals.css"; | ||
import Footer from "@/component/footer"; | ||
import Headers from "@/component/header"; | ||
|
||
export const metadata: Metadata = { | ||
title: "Certify", | ||
|
@@ -13,9 +16,13 @@ export default function RootLayout({ | |
}>) { | ||
return ( | ||
<html lang="en"> | ||
<body | ||
className="antialiased"> | ||
<body className="leading-normal tracking-normal text-indigo-400 m-6 bg-cover bg-fixed" style={{backgroundImage: `url('https://picdb.vercel.app/assets/home.jpg')`}}> | ||
<Headers /> | ||
{children} | ||
<Footer /> | ||
{/* <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.slim.min.js" integrity="sha256-pasqAKBDmFT4eHoN2ndd6lN370kFiGUFyTiUHWhU7k8=" crossOrigin="anonymous"></script> | ||
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo" crossOrigin="anonymous"></script> | ||
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.min.js" integrity="sha256-WqU1JavFxSAMcLP2WIOI+GB2zWmShMI82mTpLDcqFUg=" crossOrigin="anonymous"></script> */} | ||
</body> | ||
</html> | ||
); | ||
|
Oops, something went wrong.