Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: feedback form #16

Merged
merged 11 commits into from
Apr 23, 2024
6 changes: 3 additions & 3 deletions docusaurus/docusaurus.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@ const config = {
},

customFields: {
meilisearchURL: process.env.MEILISEARCH_URL || 'localhost:7700',
meilisearchApiKey: process.env.MEILISEARCH_API_KEY || 'masterKey',
meilisearchIndexUid: process.env.MEILISEARCH_INDEX_UID || 'dev'
meilisearchURL: process.env.MEILISEARCH_URL || "localhost:7700",
meilisearchApiKey: process.env.MEILISEARCH_API_KEY || "masterKey",
meilisearchIndexUid: process.env.MEILISEARCH_INDEX_UID || "dev",
},

scripts: [
Expand Down
113 changes: 113 additions & 0 deletions docusaurus/src/components/Feedback/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,113 @@
import React, { useState } from "react";

export default function Feedback() {
const [isOpen, setIsOpen] = useState(false);
const [isFormCallback, setIsFormCallback] = useState(false);
const toggle = (e) => {
e.preventDefault();
setIsOpen(!isOpen);
};

const [formData, setFormData] = useState({
email: "",
feedback: "",
});

const feedbackMsg = {
info: "Leave feedback",
callback: "Thank you for your feedback",
alexiscolin marked this conversation as resolved.
Show resolved Hide resolved
};

const handleInputChange = (event) => {
event.preventDefault();
const { name, value } = event.target;
setFormData((prevProps) => ({
...prevProps,
[name]: value,
}));
};

const sendData = async (e) => {
e.preventDefault();

if (formData.email === "" || formData.feedback === "") return;

const formURL = `https://docs.google.com/forms/d/188U6r1PL0zvwo5nrBwpIh8CVtgvOMdvst2YM3PWT7hw/formResponse`;
const inputsName = {
email: "entry.331557816",
feedback: "entry.1077515444",
pageId: "entry.420531539",
pageCommit: "entry.159427272",
};

const formParams = new URLSearchParams();
for (const field in inputsName) {
if (formData[field]) formParams.append(inputsName[field], formData[field]);
}

formParams.append(inputsName.pageId, window.location.pathname);

const editLink = document.querySelector(".theme-edit-this-page").getAttribute("href");
const filePath = editLink.split("master/")[1];

await fetch(`https://api.github.com/repos/gnolang/gno/commits?path=/${filePath}`)
.then((res) => res.json())
.then((data) => {
formParams.append(inputsName.pageCommit, data[0].sha);
})
.catch((error) => {
formParams.append(inputsName.pageCommit, `error: ${error}`);
console.error("Last page commit error :", error);
});

const url = formURL + "?" + formParams + "&submit=Submit";

fetch(url, {
method: "GET",
headers: {
"Content-Type": "application/x-www-form-urlencoded",
},
mode: "no-cors", // this line is required for CORS policy reasons -> no usefull response available
})
.then((_) => {
setFormData({ email: "", feedback: "" });
setIsOpen(false);

setIsFormCallback(true);
setTimeout(() => setIsFormCallback(false), 2000);
})
.catch((error) => {
console.error("Error submitting form data:", error);
});
};

return (
<div className="feedback">
<div className="footer__title">Was this page helpful?</div>
{isOpen ? (
<form className="feedback__form" onSubmit={sendData}>
<button className="feedback__inner-btn feedback__close" aria-label="Close" onClick={toggle}>
</button>
<div>
<div className="feedback__field">
<label htmlFor="feedback-email">Email</label>
<input type="email" name="email" id="feedback-email" placeholder="[email protected]" value={formData.email} onChange={handleInputChange} required />
alexiscolin marked this conversation as resolved.
Show resolved Hide resolved
</div>
<div className="feedback__field">
<label htmlFor="feedback-review">Review</label>
<textarea type="text" name="feedback" id="feedback-review" placeholder="Your review here" rows="6" value={formData.feedback} onChange={handleInputChange} required />
</div>
<button className="feedback__inner-btn feedback__send" type="submit">
Send Feedback
</button>
</div>
</form>
) : (
<button className="feedback__btn" onClick={toggle}>
{!isFormCallback ? feedbackMsg.info : feedbackMsg.callback}
</button>
)}
</div>
);
}
105 changes: 104 additions & 1 deletion docusaurus/src/css/custom.css
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
--ifm-links-hover-background-color: var(--ifm-color-primary-light);
--ifm-color-secondary: var(--ifm-color-primary-light);
--ifm-color-white: var(--ifm-color-primary);
--btn-background: var(--ifm-color-primary-lighter);

--ifm-menu-link-sublist-icon: url("");
--content-max-w: 50rem;
Expand All @@ -49,6 +50,8 @@
--docsearch-searchbox-shadow: var(--ifm-color-primary-light) !important;
--docsearch-searchbox-focus-background: var(--ifm-color-primary-lighter) !important;
--docsearch-hit-color: var(--ifm-color-primary) !important;
--docsearch-searchbox-background: var(--ifm-color-primary-lighter) !important;
--docsearch-muted-color: var(--ifm-color-primary-light);
}

/* For readability concerns, you should choose a lighter palette in dark mode. */
Expand All @@ -71,7 +74,9 @@
--ifm-links-background-color: var(--ifm-color-primary-darker);
--ifm-links-hover-background-color: var(--ifm-color-primary-light);
--docsearch-primary-color: var(--ifm-color-primary-light);

--btn-background: var(--ifm-color-primary-darker);
--docsearch-searchbox-background: var(--ifm-color-primary-dark) !important;
--docsearch-muted-color: var(--ifm-color-primary-light);
--docsearch-searchbox-focus-background: var(--docusaurus-highlighted-code-line-bg) !important;
}

Expand Down Expand Up @@ -313,19 +318,38 @@ a.footer__link-item > svg {

.footer .container {
max-width: 100%;
display: flex;
justify-content: space-between;
flex-direction: column;
}
@media (min-width: 580px) {
.footer .container {
flex-direction: row;
}
}

.footer__title {
margin-block-start: 1rem;
}

.footer__links {
width: 100%;
}
@media (min-width: 580px) {
.footer__links {
width: 50%;
}
}
@media (min-width: 997px) {
.footer .footer__col:first-child {
max-width: var(--doc-sidebar-width);
}
.footer .footer__col:nth-child(2) {
padding-inline-start: 3.75rem;
}
.footer__links {
width: 75%;
}
}

.gno-footer__socials {
Expand Down Expand Up @@ -368,3 +392,82 @@ html .docsearch-modal-search-input-form {
border-radius: 0.5rem;
margin-block: 3rem;
}

/* Feedback Form */
.feedback {
position: relative;
width: 100%;
}
@media (min-width: 580px) {
.feedback {
width: 50%;
}
}
@media (min-width: 997px) {
.feedback {
width: 25%;
}
}

.feedback__btn {
border: 0;
cursor: pointer;
color: var(--ifm-footer-link-color);
border-radius: 0.5rem;
padding: 0.5rem 0.8rem;
font-size: 1rem;
transition: 0.3s ease opacity;
box-shadow: var(--ring-offset-shadow, 0 0 #0000), var(--ring-shadow, 0 0 #0000), var(--shadow);
background-color: var(--btn-background);
}
.feedback__btn:hover {
opacity: 0.7;
}
.feedback__form {
position: relative;
font-size: 1rem;
border-radius: 1rem;
padding: 1.5rem 1rem;
background-color: var(--btn-background);
}
.feedback__field {
display: flex;
flex-direction: column;
margin-block: 0.8rem;
}
.feedback__field input,
.feedback__field textarea {
padding: 0.5rem 0.8rem;
border: none;
border-radius: 0.4rem;
outline: none;
font-family: inherit;
}
.feedback__inner-btn {
padding: 0.5rem;
cursor: pointer;
border: none;
border-radius: 0.4rem;
font-size: 1rem;
background-color: var(--ifm-background-color);
transition: 0.3s ease opacity;
}
.feedback__inner-btn:hover {
opacity: 0.7;
}
.feedback__close {
position: absolute;
display: flex;
justify-content: center;
align-items: center;
width: 1.4rem;
height: 1.4rem;
top: 1rem;
right: 1rem;
}

.feedback__send {
width: 100%;
margin-block-start: 1rem;
font-weight: bold;
}
12 changes: 12 additions & 0 deletions docusaurus/src/theme/Footer/Links/MultiColumn/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import React from "react";
import MultiColumn from "@theme-original/Footer/Links/MultiColumn";
import Feedback from "../../../../components/Feedback";

export default function MultiColumnWrapper(props) {
return (
<>
<MultiColumn {...props} />
<Feedback />
</>
);
}