Skip to content
Toggle navigation
Toggle navigation
This project
Loading...
Sign in
Jay Mehta
/
zango-frontend
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Registry
Graphs
Issues
0
Merge Requests
0
Wiki
Network
Create a new issue
Jobs
Commits
Issue Boards
Files
Commits
Network
Compare
Branches
Tags
Commit 25eaa001
authored
2024-05-27 16:12:54 +0530
by
Ravindra Kanojiya
Browse Files
Options
Browse Files
Tag
Download
Email Patches
Plain Diff
updated
1 parent
6fa6545c
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
75 additions
and
6 deletions
components/layout/Footer.js
redux/actions/newsletterAction.js
components/layout/Footer.js
View file @
25eaa00
import
Image
from
"next/image"
;
import
React
from
"react"
;
import
React
,
{
useState
}
from
"react"
;
import
{
Button
}
from
"react-bootstrap"
;
import
{
newsletter
}
from
"../../redux/actions/newsletterAction"
;
import
{
toast
}
from
"react-toastify"
;
const
Footer
=
()
=>
{
const
[
email
,
setEmail
]
=
useState
(
''
);
const
[
isValidEmail
,
setIsValidEmail
]
=
useState
(
true
);
const
validateEmail
=
()
=>
{
// Regular expression for email validation
const
regex
=
/^
[^\s
@
]
+@
[^\s
@
]
+
\.[^\s
@
]
+$/
;
return
regex
.
test
(
email
);
};
const
handleSubmit
=
async
(
e
)
=>
{
e
.
preventDefault
();
if
(
validateEmail
())
{
// Email is valid, perform your action (e.g., subscribe)
const
res
=
await
newsletter
(
email
);
console
.
log
(
"res"
,
res
.
data
);
// Reset email input field after successful submission
setEmail
(
''
);
setIsValidEmail
(
true
);
toast
.
success
(
"Subscribed successful!"
);
}
else
{
// Email is not valid, show error message or handle as you wish
setIsValidEmail
(
false
);
}
};
return
(
<>
<
footer
>
...
...
@@ -20,8 +46,12 @@ const Footer = () => {
<
div
className
=
"footer-link"
>
<
h3
>
VENDOR
SIGN
UP
<
/h3
>
<
div
className
=
""
>
<
Button
href
=
"/login/vendor"
variant
=
"light me-3"
>
Log
In
<
/Button
>
<
Button
href
=
"/signup/vendor"
variant
=
"primary"
>
Sign
Up
<
/Button
>
<
Button
href
=
"/login/vendor"
variant
=
"light me-3"
>
Log
In
<
/Button
>
<
Button
href
=
"/signup/vendor"
variant
=
"primary"
>
Sign
Up
<
/Button
>
<
/div
>
<
/div
>
<
/div
>
...
...
@@ -130,11 +160,26 @@ const Footer = () => {
<
h3
>
JOIN
OUR
COMMUNITY
<
/h3
>
<
div
>
Subscribe
to
gt
information
,
latest
news
and
other
interesting
offers
<
/div
>
<
div
className
=
"subscribe"
>
<
form
action
=
""
>
<
form
onSubmit
=
{
handleSubmit
}
>
<
div
className
=
"row"
>
<
div
className
=
"col-12"
>
<
input
id
=
"subscribe"
type
=
"text"
placeholder
=
"Email Address"
/>
<
label
htmlFor
=
"subscribe"
><
Button
variable
=
"primary"
>
Subscribe
<
/Button></
label
>
<
input
id
=
"subscribe"
onChange
=
{
e
=>
{
setEmail
(
e
.
target
.
value
);
setIsValidEmail
(
true
);
}}
type
=
"text"
value
=
{
email
}
placeholder
=
"Email Address"
/>
<
label
htmlFor
=
"subscribe"
>
<
Button
variable
=
"primary"
type
=
"submit"
>
Subscribe
<
/Button
>
<
/label
>
{
!
isValidEmail
&&
(
<
span
style
=
{{
color
:
'red'
}}
>
Please
enter
a
valid
email
address
.
<
/span
>
)}
<
/div
>
<
/div
>
<
/form
>
...
...
redux/actions/newsletterAction.js
0 → 100644
View file @
25eaa00
import
axios
from
"axios"
;
import
qs
from
"qs"
;
import
{
GET_TESTIMONIAL_FAIL
,
GET_TESTIMONIAL_REQUEST
,
GET_TESTIMONIAL_SUCCESS
}
from
"../constants/testimonialConstants"
;
export
const
newsletter
=
async
email
=>
{
try
{
console
.
log
(
"email"
,
email
);
const
config
=
{
headers
:
{
"Content-Type"
:
"application/json"
}
};
const
data
=
{
data
:
{
email
:
email
}
};
const
response
=
await
axios
.
post
(
`
${
process
.
env
.
NEXT_PUBLIC_BACKEND_API_URL
}
/api/newsletters`
,
data
,
config
);
console
.
log
(
"response > "
,
response
.
data
);
return
response
.
data
;
}
catch
(
error
)
{}
};
Write
Preview
Styling with
Markdown
is supported
Attach a file
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to post a comment