Compare commits
3 commits
Author | SHA1 | Date | |
---|---|---|---|
|
dbfe8c2dc9 | ||
2b2545d348 | |||
698a631abb |
8 changed files with 96 additions and 63 deletions
|
@ -7,7 +7,7 @@
|
||||||
# https://www.sphinx-doc.org/en/master/usage/configuration.html#project-information
|
# https://www.sphinx-doc.org/en/master/usage/configuration.html#project-information
|
||||||
|
|
||||||
project = "shortenit"
|
project = "shortenit"
|
||||||
copyright = "2024, Elia el Lazkani"
|
copyright = "2025, Elia el Lazkani"
|
||||||
author = "Elia el Lazkani"
|
author = "Elia el Lazkani"
|
||||||
release = "0.0.0"
|
release = "0.0.0"
|
||||||
|
|
||||||
|
|
4
frontend/package-lock.json
generated
4
frontend/package-lock.json
generated
|
@ -1,11 +1,11 @@
|
||||||
{
|
{
|
||||||
"name": "frontend",
|
"name": "shortenit",
|
||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "frontend",
|
"name": "shortenit",
|
||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@testing-library/jest-dom": "^5.17.0",
|
"@testing-library/jest-dom": "^5.17.0",
|
||||||
|
|
|
@ -35,23 +35,66 @@ export default function URLShortener() {
|
||||||
const api_url = `${config.url}${api_endpoint}`;
|
const api_url = `${config.url}${api_endpoint}`;
|
||||||
|
|
||||||
// Send the POST request to the backend
|
// Send the POST request to the backend
|
||||||
await axios
|
const response = await axios.post(api_url , {url: url})
|
||||||
.post(api_url , {
|
if (response.data.url) {
|
||||||
url: url
|
|
||||||
})
|
|
||||||
.then((response) => {
|
|
||||||
if (response) {
|
|
||||||
const shortUrl: string = response.data.url;
|
const shortUrl: string = response.data.url;
|
||||||
setShortenedUrl(shortUrl);
|
setShortenedUrl(shortUrl);
|
||||||
setShowInput(true);
|
setShowInput(true);
|
||||||
}
|
toast.success("URL Shortened Successfully", {
|
||||||
|
position: "top-right",
|
||||||
|
autoClose: 5000,
|
||||||
|
hideProgressBar: false,
|
||||||
|
closeOnClick: true,
|
||||||
|
pauseOnHover: true,
|
||||||
|
draggable: true,
|
||||||
|
progress: undefined,
|
||||||
|
theme: "dark",
|
||||||
|
className: "custom-toast",
|
||||||
});
|
});
|
||||||
|
} else {
|
||||||
|
toast.error("Something went wrong while shortening the URL", {
|
||||||
|
position: "top-right",
|
||||||
|
autoClose: 5000,
|
||||||
|
hideProgressBar: false,
|
||||||
|
closeOnClick: true,
|
||||||
|
pauseOnHover: true,
|
||||||
|
draggable: true,
|
||||||
|
progress: undefined,
|
||||||
|
theme: "dark",
|
||||||
|
className: "custom-toast",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
setTimeout(() => {
|
setTimeout(() => {
|
||||||
setShowInput(false);
|
setShowInput(false);
|
||||||
}, 10000);
|
}, 900000);
|
||||||
} catch (error) {
|
} catch (error : any) {
|
||||||
console.log(error);
|
if (error.response) {
|
||||||
|
const errorMessage : string = error.response.data.msg || "An error occurred. Please try again.";
|
||||||
|
toast.error(errorMessage, {
|
||||||
|
position: "top-right",
|
||||||
|
autoClose: 5000,
|
||||||
|
hideProgressBar: false,
|
||||||
|
closeOnClick: true,
|
||||||
|
pauseOnHover: true,
|
||||||
|
draggable: true,
|
||||||
|
progress: undefined,
|
||||||
|
theme: "dark",
|
||||||
|
className: "custom-toast",
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
toast.error("Network error. Please check your connection and try again.", {
|
||||||
|
position: "top-right",
|
||||||
|
autoClose: 5000,
|
||||||
|
hideProgressBar: false,
|
||||||
|
closeOnClick: true,
|
||||||
|
pauseOnHover: true,
|
||||||
|
draggable: true,
|
||||||
|
progress: undefined,
|
||||||
|
theme: "dark",
|
||||||
|
className: "custom-toast",
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -76,13 +119,14 @@ export default function URLShortener() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
|
<>
|
||||||
<div className="URLShortener-component">
|
<div className="URLShortener-component">
|
||||||
<div className="left-side">
|
<div className="left-side">
|
||||||
<h1>Paste the URL</h1>
|
<h1>Paste the URL</h1>
|
||||||
<form className="url-input" onSubmit={ShortenIt}>
|
<form className="url-input" onSubmit={ShortenIt}>
|
||||||
<input
|
<input
|
||||||
type="text"
|
type="text"
|
||||||
placeholder="www.example.com"
|
placeholder="https://www.example.com"
|
||||||
aria-label="URL input field"
|
aria-label="URL input field"
|
||||||
value={url}
|
value={url}
|
||||||
onChange={(e) => setUrl(e.target.value)}
|
onChange={(e) => setUrl(e.target.value)}
|
||||||
|
@ -108,7 +152,9 @@ export default function URLShortener() {
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<ToastContainer />
|
|
||||||
</div>
|
</div>
|
||||||
|
<ToastContainer />
|
||||||
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
.footer {
|
.footer {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 200px;
|
height: 100px;
|
||||||
background-color: var(--color-secondary);
|
background-color: var(--color-secondary);
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
}
|
}
|
|
@ -1,13 +0,0 @@
|
||||||
import React from "react";
|
|
||||||
import { QRCodeSVG } from "qrcode.react";
|
|
||||||
import { qrCodeGeneratorProps } from "./qrCodeGeneratorProps";
|
|
||||||
|
|
||||||
const QRCodeGenerator: React.FC<qrCodeGeneratorProps> = ({ url }) => {
|
|
||||||
return (
|
|
||||||
<div>
|
|
||||||
<QRCodeSVG id="qrCodeSVG" value={url} />
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
export default QRCodeGenerator;
|
|
|
@ -1,3 +0,0 @@
|
||||||
export interface qrCodeGeneratorProps {
|
|
||||||
url: string;
|
|
||||||
}
|
|
|
@ -80,7 +80,7 @@ class SiteHandler:
|
||||||
data = self.shortenit_load_format(data)
|
data = self.shortenit_load_format(data)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
self.logger.error(e)
|
self.logger.error(e)
|
||||||
return {}, 400
|
return {"msg" : "Invalid URL format"}, 400
|
||||||
self.logger.error(e)
|
self.logger.error(e)
|
||||||
abort(400)
|
abort(400)
|
||||||
try:
|
try:
|
||||||
|
|
Loading…
Reference in a new issue