Commit 746f4aaa by Ravindra Kanojiya

conflict merge

2 parents 23e35806 c7d25ae4
Showing 51 changed files with 3160 additions and 148 deletions
import { signOut } from "next-auth/react";
import Image from "next/image";
import Link from "next/link";
import { useRouter } from "next/router";
import React, { Fragment, useEffect, useState } from "react";
import { renderImage } from "../../services/imageHandling";
const DropdownUserProfile = () => {
const router = useRouter();
const logoutHandler = () => {
signOut();
};
return (
<Fragment>
<div className="row">
<div className="col-12 col-lg-12">
<div>
<ul className="link-list">
<li>
<Link href="/personal-details">
<a>
Personal Info <i className="arrow-right"></i>
</a>
</Link>
</li>
</ul>
</div>
</div>
</div>
</Fragment>
);
};
export default DropdownUserProfile;
import React, { useState } from 'react';
import { Formik } from "formik";
import Image from "next/image";
import Link from "next/link";
import { Fragment } from "react";
import { Button, Form } from "react-bootstrap";
import * as Yup from "yup";
import { renderImage } from "../../services/imageHandling";
const Login = (props) => {
console.log(props.type)
const loginValidationSchema = Yup.object().shape({
email: Yup.string()
.required("Email Id is Required")
.email("Please Enter An Valid Email Id"),
password: Yup.string()
.required("Password is Required")
});
return (
<Fragment>
<div className="contaier-fluid login-banner-image">
<div className="row">
<div className="col-12 col-lg-4 login-div">
<div className="">
<h2>{props.type=="vendor" ? "Vendor Login" : "Login to Experience"}</h2>
<div className="form-container">
<Formik
initialValues={{
email: "",
password: ""
}}
validationSchema={loginValidationSchema}
// enableReinitialize={true}
onSubmit={values => {
console.log("login values",values)
}}
>
{({ values, errors, touched, handleChange, handleBlur, handleSubmit }) => (
<Form
onSubmit={e => {
e.preventDefault();
handleSubmit();
}}
>
<div className="input-group">
<label>Email Id</label>
<input
type="text"
name="email"
onChange={handleChange}
onBlur={handleBlur}
value={values.email}
placeholder="yourname@example.com"
/>
{errors.email && touched.email && (<span className="form-error">{errors.email}</span>)}
</div>
<div className="input-group">
<label>Password</label>
<input
type="text"
name="password"
onChange={handleChange}
onBlur={handleBlur}
value={values.password}
placeholder="#@$!%@#"
/>
{errors.password && touched.password && (<span className="form-error">{errors.password}</span>)}
</div>
<div className="input-group">
<Button type="submit" className="btn btn-primary btn-submit">
Login
</Button>
</div>
</Form>
)}
</Formik>
<div className="input-group justify-content-center">
<p className="text-center mb-0">or <Link href={`../signup/${props.type}`}>Create a new account</Link></p>
</div>
{props && props.type == "user" && (
<>
<div className="input-group mb-0">
<div className="btn-continue">
<span className="col-1 image-container">
<Image src={renderImage("/images/login/icon-google.png")} layout="fill" className="image" />
</span>
<span className="col-10 text-center">Continue with Google</span>
</div>
</div>
<div className="input-group mb-0">
<div className="btn-continue">
<span className="col-1 image-container">
<Image src={renderImage("/images/login/icon-fb1.png")} layout="fill" className="image" />
</span>
<span className="col-10 text-center">Continue with Facebook</span>
</div>
</div>
<div className="input-group mb-0">
<div className="btn-continue mb-0">
<span className="col-1 image-container">
<Image src={renderImage("/images/login/icon-apple.png")} layout="fill" className="image" />
</span>
<span className="col-10 text-center">Continue with Apple</span>
</div>
</div>
</>
)}
</div>
</div>
</div>
</div>
</div>
</Fragment>
)
}
export default Login;
\ No newline at end of file \ No newline at end of file
import React, { useState } from 'react';
import { Formik } from "formik";
import Link from "next/link";
import { Fragment } from "react";
import { Button, Form } from "react-bootstrap";
import * as Yup from "yup";
import OTPInput from 'react-otp-input';
import { renderImage } from '../../services/imageHandling';
import Image from 'next/image';
import { useRouter } from 'next/router';
const Signup = (props) => {
console.log(props.type)
const router = useRouter();
const [isFormTouched, setIsFormTouched] = useState(false);
const [Otp, setOtp] = useState("");
const [isTermsChecked, setTermsChecked] = useState(false)
const [fullName, setFullname] = useState("")
const [emailId, setEmailId] = useState("")
const [pwd, setPwd] = useState("")
const [confirmPwd, setConfirmPwd] = useState("")
const [countryCode, setCountryCode] = useState("+91")
const [mobileNo, setMobileNo] = useState("")
const [isOtpSent, setOtpSent] = useState(false)
const [otpVerified, setOtpVerified] = useState(false)
const handleOTPChange = (e) => {
setOtp(e);
};
const signupValidationSchema = Yup.object().shape({
fullname: Yup.string()
.required("Fullname is Required"),
email: Yup.string()
.required("Email Id is Required")
.email("Please Enter An Valid Email Id"),
password: Yup.string()
.required("Password is Required"),
confirm_password: Yup.string()
.oneOf([Yup.ref("password"), null], "Passwords must match")
.required("Confirm Password is Required"),
country_code: Yup.string()
.required("Country Code is Required"),
mobile: Yup.string()
.required("Mobile Number is Required")
.matches(/^[0-9\s]+$/, "Please Enter Correct Mobile No."),
is_terms_checked: Yup.bool().oneOf([true], "Please Accept Terms & Conditions"),
otp: Yup.string().when("isOtpSent", {
is: true,
then: Yup.string().required("Otp is Required")
.matches(/^[0-9\s]+$/, "Please Enter Correct OTP")
})
});
// Initial errors for required fields
const initialErrors = {
fullname: "Full Name is required",
email: "Email is required",
password: "Password is required",
confirm_password: "Confirm Password is required",
country_code: "Country Code is Required",
mobile: "Mobile Number is Required",
};
const handleSendOtp = (values) => {
setOtpSent(true);
}
const handleVerifyOtp = (values) => {
setOtpVerified(true);
if (props.type == "user") {
router.push("/");
}
}
return (
<Fragment>
<div className="contaier-fluid login-banner-image">
{(props?.type == "user" || (props?.type == "vendor" && !otpVerified)) && (
<div className="row">
<div className="col-12 col-lg-4 login-div signupdiv">
<div className="">
<h2>{props.type=="vendor" ? "Vendor Signup" : "Signup to get more out of the platform" }</h2>
<div className="form-container">
<Formik
initialValues={{
fullname: fullName ? fullName : "",
email: emailId ? emailId : "",
password: pwd ? pwd : "",
confirm_password: confirmPwd ? confirmPwd : "",
country_code: countryCode ? countryCode : "",
mobile: mobileNo ? mobileNo : "",
is_terms_checked: isTermsChecked,
otp: Otp ? Otp : "",
}}
// initialErrors={initialErrors}
validationSchema={signupValidationSchema}
enableReinitialize={true}
onSubmit={values => {
console.log("signup values", values)
if (!isOtpSent) {
handleSendOtp(values)
}
if (isOtpSent) {
handleVerifyOtp(values)
}
}}
>
{({ values, errors, touched, handleChange, handleBlur, handleSubmit, isValid, isSubmitting }) => (
<Form
onSubmit={e => {
e.preventDefault();
handleSubmit();
}}
>
<div className="input-group">
<label>Fullname</label>
<input
type="text"
name="fullname"
onChange={handleChange}
onBlur={(e) => {
handleBlur(e)
setFullname(e.target.value)
}}
value={values.fullname}
placeholder="Your name"
/>
{errors.fullname && touched.fullname && (<span className="form-error">{errors.fullname}</span>)}
</div>
<div className="input-group">
<label>Email Id</label>
<input
type="text"
name="email"
onChange={handleChange}
onBlur={(e) => {
handleBlur(e)
setEmailId(e.target.value)
}}
value={values.email}
placeholder="yourname@example.com"
/>
{errors.email && touched.email && (<span className="form-error">{errors.email}</span>)}
</div>
<div className="input-group">
<label>Password</label>
<input
type="text"
name="password"
onChange={handleChange}
onBlur={(e) => {
handleBlur(e)
setPwd(e.target.value)
}}
value={values.password}
placeholder="#@$!%@#"
/>
{errors.password && touched.password && (<span className="form-error">{errors.password}</span>)}
</div>
<div className="input-group">
<label>Confirm Password</label>
<input
type="text"
name="confirm_password"
onChange={handleChange}
onBlur={(e) => {
handleBlur(e)
setConfirmPwd(e.target.value)
if (pwd !== e.target.value) {
alert("Passwords do not Match")
}
}}
value={values.confirm_password}
placeholder="#@$!%@#"
/>
{errors.confirm_password && touched.confirm_password && (<span className="form-error">{errors.confirm_password}</span>)}
</div>
<div className="input-group">
<label>Mobile No.</label>
<div className="contact-number">
<select
id="country_code"
name="country_code"
onChange={handleChange}
onBlur={(e) => {
handleBlur(e)
setCountryCode(e.target.value)
}}
style={{ width: "80px" }}>
<option value="+91">+91</option>
<option value="+44">+44</option>
</select>
<input
type="text"
name="mobile"
onChange={handleChange}
onBlur={(e) => {
handleBlur(e)
setMobileNo(e.target.value)
}}
value={values.mobile}
placeholder="#@$!%@#"
style={{ flex: "0 100%" }}
/>
</div>
{errors.mobile && touched.mobile && (<span className="form-error">{errors.mobile}</span>)}
</div>
{isOtpSent && (
<>
<div className="input-group">
<label>OTP <span style={{ marginLeft: "190px" }}>00:30</span></label>
<div className="otp-input">
<OTPInput
value={Otp}
onChange={handleOTPChange}
numInputs={4}
separator={<span> </span>}
renderInput={props => <input {...props} />}
/>
</div>
{errors.otp && touched.otp && (<span className="form-error">{errors.otp}</span>)}
</div>
<div>
<p>4 digit OTP is been sent on your email address.</p>
<div className="d-flex align-items-center mb-4">
<p className="mb-0 me-5">Didnt Receive Yet?</p>
<div className="d-flex resend-otp">
<span className="image-container me-2">
<Image src={renderImage("/images/login/icon-resend.png")} layout="fill" className="image" />
</span>
<p className="mb-0">Resend</p>
</div>
</div>
</div>
</>
)}
<div className="input-group mb-3">
<label className="check-container mb-0 pt-1" htmlFor="is_terms_checked">
<input
type="checkbox"
id="is_terms_checked"
name="is_terms_checked"
className="check-box me-2"
checked={values.is_terms_checked}
onChange={e => {
handleChange(e);
setTermsChecked(e.target.checked)
}}
onBlur={handleBlur}
/>
<span className="checkmark"></span>I Agree to the <Link href="">terms & conditions*</Link>
</label>
{errors.is_terms_checked && touched.is_terms_checked && (<span className="form-error">{errors.is_terms_checked}</span>)}
</div>
<div className="input-group mb-0">
<Button type="submit" className="btn btn-primary btn-submit" disabled={Object.keys(errors).length}>
Sign Up Now
</Button>
</div>
</Form>
)}
</Formik>
</div>
</div>
</div>
</div>
)}
{props.type && props.type == "vendor" && otpVerified && (
<div className="row">
<div className="col-12 col-lg-4 login-div">
<div className="thankyou-div">
<span className="image-container">
<Image src={renderImage("/images/login/success.png")} layout="fill" className="image" />
</span>
<h2 className="mt-2 px-4 mb-0">Thank you for Signing Up with Us</h2>
<p className="mb-4">Your Profile is been created successfully</p>
</div>
<div className="form-container">
<div className="input-group mb-2">
<Button type="button" className="btn btn-primary btn-submit"
onClick={() => {
router.push("")
}}>
Proceed to Dashboard
</Button>
</div>
</div>
</div>
</div>
)}
</div>
</Fragment>
)
}
export default Signup;
\ No newline at end of file \ No newline at end of file
import Image from "next/image";
import React, { Fragment } from "react";
import { renderImage } from "../../services/imageHandling";
const MyBookings = () => {
const bookingsData = [
{
id: "0",
name: "City Climb",
start_date: "Jan 8, 2021",
end_date: "Jan 9, 2021",
price: "$200",
status: "Confirmed",
image: "/images/user/image1.png"
},
{
id: "1",
name: "City Climb",
start_date: "Jan 8, 2021",
end_date: "Jan 9, 2021",
price: "$200",
status: "Confirmed",
image: "/images/user/image1.png"
},
{
id: "2",
name: "City Climb",
start_date: "Jan 8, 2021",
end_date: "Jan 9, 2021",
price: "$200",
status: "Confirmed",
image: "/images/user/image1.png"
},
{
id: "3",
name: "City Climb",
start_date: "Jan 8, 2021",
end_date: "Jan 9, 2021",
price: "$200",
status: "Confirmed",
image: "/images/user/image1.png"
}
]
return (
<Fragment>
<div className="container">
<div className="row">
<div className="col-12 col-lg-12 form-container content-wraaper">
<h2>My Bookings</h2>
<div className="row">
{bookingsData?.length && bookingsData.map((data, index) => (
<div className="col-12 col-lg-3" key={`1${index}`}>
<div className="card-booking">
<div className="card-booking-img">
<span className="image-container">
<Image src={renderImage(data.image)} layout="fill" className="image" />
</span>
</div>
<div className="card-booking-content">
<p className="activity-name">{data.name}</p>
<p>{data.start_date} - {data.end_date}</p>
<p>{data.price}</p>
<p className="status">{data.status}</p>
</div>
<div className="hr-div" />
<div className="card-booking-footer">
<div className="d-flex align-items-center justify-content-between">
<div className="d-flex align-items-center">
<span className="image-container me-2">
<Image src={renderImage("/images/user/icon-rebook.svg")} layout="fill" className="image" />
</span>
<p className="duration mb-0">Rebook this booking</p>
</div>
<div className="image-container">
<Image src={renderImage("/images/user/arrow-right.svg")} layout="fill" className="image" />
</div>
</div>
</div>
</div>
</div>
))}
</div>
<div className="row">
{bookingsData?.length && bookingsData.map((data, index) => (
<div className="col-12 col-lg-3" key={`2${index}`}>
<div className="card-booking">
<div className="card-booking-img">
<span className="image-container">
<Image src={renderImage(data.image)} layout="fill" className="image" />
</span>
</div>
<div className="card-booking-content">
<p className="activity-name">{data.name}</p>
<p>{data.start_date} - {data.end_date}</p>
<p>{data.price}</p>
<p className="status">{data.status}</p>
</div>
<div className="hr-div" />
<div className="card-booking-footer">
<div className="d-flex align-items-center justify-content-between">
<div className="d-flex align-items-center">
<span className="image-container me-2">
<Image src={renderImage("/images/user/icon-rebook.svg")} layout="fill" className="image" />
</span>
<p className="duration mb-0">Rebook this booking</p>
</div>
<div className="image-container">
<Image src={renderImage("/images/user/arrow-right.svg")} layout="fill" className="image" />
</div>
</div>
</div>
</div>
</div>
))}
</div>
<div className="row">
{bookingsData?.length && bookingsData.map((data, index) => (
<div className="col-12 col-lg-3" key={`3${index}`}>
<div className="card-booking">
<div className="card-booking-img">
<span className="image-container">
<Image src={renderImage(data.image)} layout="fill" className="image" />
</span>
</div>
<div className="card-booking-content">
<p className="activity-name">{data.name}</p>
<p>{data.start_date} - {data.end_date}</p>
<p>{data.price}</p>
<p className="status">{data.status}</p>
</div>
<div className="hr-div" />
<div className="card-booking-footer">
<div className="d-flex align-items-center justify-content-between">
<div className="d-flex align-items-center">
<span className="image-container me-2">
<Image src={renderImage("/images/user/icon-rebook.svg")} layout="fill" className="image" />
</span>
<p className="duration mb-0">Rebook this booking</p>
</div>
<div className="image-container">
<Image src={renderImage("/images/user/arrow-right.svg")} layout="fill" className="image" />
</div>
</div>
</div>
</div>
</div>
))}
</div>
</div>
</div>
</div>
</Fragment>
)
}
export default MyBookings;
\ No newline at end of file \ No newline at end of file
import Image from "next/image";
import React, { Fragment } from "react";
import { Button } from "react-bootstrap";
import { renderImage } from "../../services/imageHandling";
const MyGiftCard = () => {
const giftCardData = [
{
id: "0",
sender_email: "John@gmail.com",
receiver_email: "martha@gmail.com",
gift_amount: "$750",
image: "/images/zango-logo.svg"
},
{
id: "1",
sender_email: "John@gmail.com",
receiver_email: "martha@gmail.com",
gift_amount: "$750",
image: "/images/zango-logo.svg"
},
{
id: "2",
sender_email: "John@gmail.com",
receiver_email: "martha@gmail.com",
gift_amount: "$750",
image: "/images/zango-logo.svg"
},
]
return (
<Fragment>
<div className="container">
<div className="row">
<div className="col-12 col-lg-12 form-container content-wraaper">
<h2>My Gift Card</h2>
<div className="row">
{giftCardData?.length && giftCardData.map((data, index) => (
<div className="col-12 col-lg-4" key={`1${index}`}>
<div className="card-booking">
<div className="card-booking-img bgGrey">
<span className="image-container">
<Image src={renderImage(data.image)} layout="fill" className="image" />
</span>
</div>
<div className="card-booking-content details-wrapper">
<p className="details">Details</p>
<div className="d-flex align-items-start justify-content-between">
<div className="details-div">
<p>Senders Email Id</p>
<p>{data.sender_email}</p>
</div>
<div className="details-div">
<p>Receivers Email Id</p>
<p>{data.receiver_email}</p>
</div>
</div>
<div className="details-div">
<p>Gift Amount</p>
<p>{data.gift_amount}</p>
</div>
</div>
</div>
</div>
))}
</div>
</div>
</div>
</div>
</Fragment>
)
}
export default MyGiftCard;
\ No newline at end of file \ No newline at end of file
import { Field, Formik } from 'formik';
import Image from 'next/image';
import React, { Fragment, useEffect, useRef, useState } from 'react';
import { Button, Form, Table } from 'react-bootstrap';
import * as Yup from "yup";
import { renderImage } from '../../services/imageHandling';
const MyProfile = () => {
let formikUploadImage;
const [readOnly, setReadOnly] = useState(true);
const profileValidationSchema = Yup.object().shape({
first_name: Yup.string()
.required("First Name is Required"),
last_name: Yup.string()
.required("Last Name is Required"),
email: Yup.string()
.required("Email Id is Required")
.email("Please Enter An Valid Email Id"),
country_code: Yup.string()
.required("Country Code is Required"),
mobile: Yup.string()
.required("Mobile Number is Required")
.matches(/^[0-9\s]+$/, "Please Enter Correct Mobile No."),
password: Yup.string()
});
const addressesValidationSchema = Yup.object().shape({
addresses: Yup.array().of(
Yup.object().shape({
pincode: Yup.string().required('Pincode is required'),
country: Yup.string().required('Country is required'),
state: Yup.string().required('State is required'),
city: Yup.string().required('City is required'),
address_line1: Yup.string().required('Address Line1 is required'),
address_line2: Yup.string().required('Adrress Line2 is required')
})
)
});
const profileInitialValue = {
first_name: "John",
last_name: "Doe",
email: "john@gmail.com",
country_code: "+1 (406)",
mobile: "785-9909",
password: "*********"
}
// Ref for the first input field
const firstFieldRef = useRef(null);
// Effect to focus on the first field when entering edit mode
useEffect(() => {
console.log("firstFieldRef", readOnly, firstFieldRef.current)
if (!readOnly && firstFieldRef.current) {
firstFieldRef.current.focus();
}
}, [readOnly]);
const handleProfileUploadChange = (event) => {
console.log(event)
console.log(event?.currentTarget?.files[0])
formikUploadImage.setFieldValue("profile_image", event.currentTarget.files[0]);
formikUploadImage.submitForm()
}
return (
<Fragment>
<div className="container">
<div className="row">
<div className="col-12 col-lg-12">
<div className="form-container content-wraaper">
<div className='px-5'>
<h2>My Profile</h2>
<Table className='abc'>
<thead>
<tr>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
</tr>
</thead>
<tbody>
<tr className='main'>
<td rowSpan={3}>1</td>
</tr>
<tr className='sub1'>
<td>11</td>
<td>22</td>
<td>33</td>
</tr>
<tr className='sub2'>
<td>11</td>
<td>22</td>
<td>33</td>
</tr>
<tr className='main'>
<td rowSpan={3}>1</td>
</tr>
<tr className='sub'>
<td>11</td>
<td>22</td>
<td>33</td>
</tr>
<tr className='sub'>
<td>11</td>
<td>22</td>
<td>33</td>
</tr>
</tbody>
</Table>
<div className="bg-white border-div">
<Formik
initialValues={{ profile_image: null }}
validationSchema={Yup.object().shape({
profile_image: Yup.mixed().required("Profile Image is Required")
})}
enableReinitialize={true}
onSubmit={values => {
console.log("profile image", values)
// onSubmit: async (values, { setSubmitting }) => {
// setSubmitting(true);
// try {
// const formData = new FormData();
// formData.append("file", values.file);
// // Use Axios to send the file data to the server
// const response = await axios.post("/upload", formData, {
// headers: {
// "Content-Type": "multipart/form-data"
// }
// });
// console.log("File uploaded successfully:", response.data);
// } catch (error) {
// console.error("Error uploading file:", error);
// }
// setSubmitting(false);
// }
}}
innerRef={formik => {
// Store Formik instance in a variable
formikUploadImage = formik;
}}
>
{({ values, errors, touched, handleChange, handleBlur, handleSubmit }) => (
<Form
onSubmit={e => {
e.preventDefault();
handleSubmit();
console.log(errors)
}}
>
<div className="d-flex align-items-center justify-content-between">
<div className="col-lg-8 d-flex align-items-center">
<img src="/images/user/user-big.jpg" layout="fill" className="image-fluid me-4" />
<p className="username">John Doe</p>
</div>
<div className="col-lg-2">
<label className="custom-file-input" htmlFor="file-upload">
<p className="mb-0">Upload</p>
<img src="/images/user/icon-upload.svg" layout="fill" className="image-fluid pb-1" />
</label>
<input
type="file"
id="file-upload"
name="profile_image"
onChange={handleProfileUploadChange}
// onBlur={handleBlur}
style={{ display: "none" }}
/>
{errors.profile_image && touched.profile_image && (<span className="form-error">{errors.profile_image}</span>)}
</div>
</div>
</Form>
)}
</Formik>
</div>
<div className="bg-white border-div">
<Formik
initialValues={profileInitialValue}
validationSchema={profileValidationSchema}
enableReinitialize={true}
onSubmit={values => {
console.log("profile personal details", values)
}}
>
{({ values, errors, touched, handleChange, handleBlur, handleSubmit }) => (
<Form
onSubmit={e => {
e.preventDefault();
handleSubmit();
}}
>
<>
<div className="d-flex justify-content-between mb-4">
<h2 className="mb-0">Personal Information</h2>
{/* onClick={() => setReadOnly(prevState => !prevState)} */}
{readOnly && (
<div className="btn-edit">
<span className="me-3">Edit</span>
<i className="fa fa-edit"></i>
</div>
)}
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Your First Name</label>
<Field
type="text"
name="first_name"
onChange={handleChange}
onBlur={handleBlur}
value={values.first_name}
readOnly={readOnly}
innerRef={firstFieldRef}
/>
{errors.first_name && touched.first_name && (<span className="form-error">{errors.first_name}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Your Last Name</label>
<Field
type="text"
name="last_name"
onChange={handleChange}
onBlur={handleBlur}
value={values.last_name}
readOnly={readOnly}
/>
{errors.last_name && touched.last_name && (<span className="form-error">{errors.last_name}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Email Id</label>
<Field
type="text"
name="email"
onChange={handleChange}
onBlur={handleBlur}
value={values.email}
readOnly={readOnly}
/>
{errors.email && touched.email && (<span className="form-error">{errors.email}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Mobile Number</label>
<div className="contact-number">
{readOnly && (
<Field
type="text"
name="country_code"
onChange={handleChange}
onBlur={handleBlur}
value={values.country_code}
readOnly={readOnly}
style={{ width: "80px" }}
/>
)}
{!readOnly && (
<select
id="country_code"
name="country_code"
onChange={handleChange}
onBlur={handleBlur}
style={{ width: "80px" }}
>
<option value="+91">+91</option>
<option value="+44">+44</option>
</select>
)}
<Field
type="text"
name="mobile"
onChange={handleChange}
onBlur={handleBlur}
value={values.mobile}
readOnly={readOnly}
/>
</div>
{errors.mobile && touched.mobile && (<span className="form-error">{errors.mobile}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Current Password</label>
<input
type="text"
name="password"
onChange={handleChange}
onBlur={handleBlur}
value={values.password}
readOnly={readOnly}
disabled={true}
/>
</div>
</div>
</div>
</>
</Form>
)}
</Formik>
</div>
<div className="bg-white border-div">
<Formik
initialValues={{
addresses: [
{
pincode: "",
}
]
}}
validationSchema={addressesValidationSchema}
// enableReinitialize={true}
onSubmit={values => {
console.log("profile address details", values)
}}
>
{({ values, errors, touched, handleChange, handleBlur, handleSubmit }) => (
<Form
onSubmit={e => {
e.preventDefault();
handleSubmit();
}}
>
<>
<div className="d-flex justify-content-between mb-4">
<h2 className='mb-0'>Address</h2>
<div className="btn-edit">
<span className="me-3">Add</span>
<i className="fa fa-plus"></i>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Pincode</label>
<input
type="text"
name="pincode"
onChange={handleChange}
onBlur={handleBlur}
value={values.pincode}
/>
{errors.pincode && touched.pincode && (<span className="form-error">{errors.pincode}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Country</label>
<select
id="country"
name="country"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="India">India</option>
<option value="America">America</option>
</select>
{errors.country && touched.country && (<span className="form-error">{errors.country}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>State</label>
<select
id="state"
name="state"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="India">India</option>
<option value="America">America</option>
</select>
{errors.state && touched.state && (<span className="form-error">{errors.state}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>City</label>
<select
id="city"
name="city"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="India">India</option>
<option value="America">America</option>
</select>
{errors.city && touched.city && (<span className="form-error">{errors.city}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Address Line 1</label>
<input
type="text"
name="address_line1"
onChange={handleChange}
onBlur={handleBlur}
value={values.address_line1}
/>
{errors.address_line1 && touched.address_line1 && (<span className="form-error">{errors.address_line1}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Address Line 2</label>
<input
type="text"
name="address_line2"
onChange={handleChange}
onBlur={handleBlur}
value={values.address_line2}
/>
{errors.address_line2 && touched.address_line2 && (<span className="form-error">{errors.address_line2}</span>)}
</div>
</div>
</div>
</>
</Form>
)}
</Formik>
</div>
</div>
</div>
</div>
</div>
</div>
</Fragment>
)
}
export default MyProfile;
\ No newline at end of file \ No newline at end of file
import Image from "next/image";
import React, { Fragment } from "react";
import { Button } from "react-bootstrap";
import { renderImage } from "../../services/imageHandling";
const MyWhishList = () => {
const whishListData = [
{
id: "0",
name: "City Climb",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit",
price: "$200",
discount: "40% OFF",
availablity: "For 1 Night",
other: "Includes taxes & Fees",
rating: "8.8",
type: "Top Rated",
image: "/images/user/image1.png"
},
{
id: "1",
name: "City Climb",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit",
price: "$200",
discount: "40% OFF",
availablity: "For 1 Night",
other: "Includes taxes & Fees",
rating: "8.8",
type: "Top Rated",
image: "/images/user/image2.png"
},
{
id: "2",
name: "City Climb",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit",
price: "$200",
discount: "40% OFF",
availablity: "For 1 Night",
other: "Includes taxes & Fees",
rating: "8.8",
type: "Top Rated",
image: "/images/user/image3.png"
},
{
id: "3",
name: "City Climb",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit",
price: "$200",
discount: "40% OFF",
availablity: "For 1 Night",
other: "Includes taxes & Fees",
rating: "8.8",
type: "Top Rated",
image: "/images/user/image4.png"
}
]
return (
<Fragment>
<div className="container">
<div className="row">
<div className="col-12 col-lg-12 form-container content-wraaper">
<h2>My Bookings</h2>
<div className="row">
{whishListData?.length && whishListData.map((data, index) => (
<div className="col-12 col-lg-3" key={`1${index}`}>
<div className="card-booking">
<div className="card-booking-img">
<span className="image-container">
<Image src={renderImage(data.image)} layout="fill" className="image" />
</span>
<p className="type">{data.type}</p>
</div>
<div className="card-booking-content">
<div className="d-flex align-items-start justify-content-between">
<p className="activity-name">{data.name}</p>
<div className="d-flex align-items-center">
<div className="rating">
<span className="me-1 pt-1">{data.rating}</span>
<span className="image-container">
<Image src={renderImage("/images/user/star.svg")} layout="fill" className="image" />
</span>
</div>
<span className="image-container">
<Image src={renderImage("/images/user/heart.svg")} layout="fill" className="image" />
</span>
</div>
</div>
<p className="description">Lorem ipsum dolor sit amet, consectetur adipiscing elit, <span>Read More</span></p>
<p className="price">{data.price} <span>{data.discount}</span></p>
<p className="other">{data.availablity}</p>
<p className="other">{data.other}</p>
</div>
<div className="card-booking-footer pt-0">
<Button type="button" className="btn btn-primary btn-explore">
Explore Now
</Button>
</div>
</div>
</div>
))}
</div>
</div>
</div>
</div>
</Fragment>
)
}
export default MyWhishList;
\ No newline at end of file \ No newline at end of file
import { Formik } from "formik";
import { Fragment } from "react";
import { Button, Form } from "react-bootstrap";
import * as Yup from "yup";
const ActivityDetails = () => {
const activityDetailsValidationSchema = Yup.object().shape({
category: Yup.string()
.required("Category is Required"),
subcategory: Yup.string()
.required("SubCategory is Required"),
activity_name: Yup.string()
.required("Activity Name is Required"),
activity_description: Yup.string()
.required("Activity Description is Required"),
location: Yup.string()
.required("Location is Required"),
address: Yup.string()
.required("Address is Required"),
price_per_person: Yup.string()
.required("Price Per Person is Required"),
gifting_to_someone: Yup.string()
.required("Gifting to someone is Required"),
place: Yup.string()
.required("Place is Required"),
contact_person_for_activity: Yup.string()
.required("City is Required"),
min_group_size: Yup.string()
.required("Address Line 1 is Required"),
max_group_size: Yup.string()
.required("Address Line 2 is Required"),
month: Yup.string()
.required("Month is Required"),
min_duration: Yup.string()
.required("Month is Required"),
max_duration: Yup.string()
.required("Month is Required"),
link_of_booking: Yup.string()
.required("Link of Booking is Required"),
activity_images: Yup.array(),
contact_person_for_booking: Yup.string(),
contact_number_for_booking: Yup.string(),
cancellation_policy_file: Yup.string(),
terms_conditions_file: Yup.string(),
});
return (
<Fragment>
<div className="container p-5">
<div className="row">
<div className="col-12 col-lg-8">
<div className="content-div business-details">
<h2>Activity Details</h2>
<hr />
<div className="form-container">
<Formik
initialValues={{
category: "",
subcategory: "",
activity_name: "",
activity_description: "",
location: "",
address: "",
price_per_person: "",
gifting_to_someone: "",
place: "",
contact_person_for_activity: "",
min_group_size: "",
max_group_size: "",
month: "",
min_duration: "",
max_duration: "",
link_of_booking: "",
activity_images: [],
contact_person_for_booking: "",
contact_number_for_booking: "",
cancellation_policy_file: "",
terms_conditions_file: "",
}}
validationSchema={activityDetailsValidationSchema}
// enableReinitialize={true}
onSubmit={values => {
console.log("activity details values", values)
}}
>
{({ values, errors, touched, handleChange, handleBlur, handleSubmit }) => (
<Form
onSubmit={e => {
e.preventDefault();
handleSubmit();
}}
>
<h4>Activity Name 1</h4>
<div>
<p>Basic Details</p>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Enter Business PAN No.</label>
<select
id="category"
name="category"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="">Select</option>
<option value="Category 1">Category 1</option>
<option value="Category 2">Category 2</option>
</select>
{errors.category && touched.category && (<span className="form-error">{errors.category}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>SubCategory</label>
<select
id="subcategory"
name="subcategory"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="">Select</option>
<option value="Sub Category 1">Sub Category 1</option>
<option value="Sub Category 2">Sub Category 2</option>
</select>
{errors.subcategory && touched.subcategory && (<span className="form-error">{errors.subcategory}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Activity Name</label>
<input
type="text"
name="activity_name"
onChange={handleChange}
onBlur={handleBlur}
value={values.activity_name}
/>
{errors.activity_name && touched.activity_name && (<span className="form-error">{errors.activity_name}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Activity Description</label>
<input
type="text"
name="activity_description"
onChange={handleChange}
onBlur={handleBlur}
value={values.activity_description}
/>
{errors.activity_description && touched.activity_description && (<span className="form-error">{errors.activity_description}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Location</label>
<select
id="location"
name="location"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="">Select</option>
<option value="Location 1">Location 1</option>
<option value="Location 2">Location 2</option>
</select>
{errors.location && touched.location && (<span className="form-error">{errors.location}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Address</label>
<input
type="text"
name="address"
onChange={handleChange}
onBlur={handleBlur}
value={values.address}
/>
{errors.address && touched.address && (<span className="form-error">{errors.address}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Price (per person)</label>
<input
type="text"
name="price_per_person"
onChange={handleChange}
onBlur={handleBlur}
value={values.price_per_person}
/>
{errors.price_per_person && touched.price_per_person && (<span className="form-error">{errors.price_per_person}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Gifting to Someone</label>
<div className="row">
<div className="col-6 col-lg-6">
<label htmlFor="gifting_allowed">
<input
type="radio"
id="gifting_allowed"
name="gifting_to_someone"
onChange={handleChange}
onBlur={handleBlur}
value="gifting_allowed"
/> Allowed
</label>
</div>
<div className="col-6 col-lg-6">
<label htmlFor="gifting_disallowed">
<input
type="radio"
id="gifting_disallowed"
name="gifting_to_someone"
onChange={handleChange}
onBlur={handleBlur}
value="gifting_disallowed"
/> Disallowed
</label>
</div>
</div>
{errors.gifting_to_someone && touched.gifting_to_someone && (<span className="form-error">{errors.gifting_to_someone}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Place</label>
<div className="row">
<div className="col-4 col-lg-4">
<label htmlFor="indoor">
<input
type="radio"
id="indoor"
name="place"
onChange={handleChange}
onBlur={handleBlur}
value="indoor"
/> Indoor
</label>
</div>
<div className="col-4 col-lg-4">
<label htmlFor="outdoor">
<input
type="radio"
id="outdoor"
name="place"
onChange={handleChange}
onBlur={handleBlur}
value="outdoor"
/> Outdoor
</label>
</div>
<div className="col-4 col-lg-4">
<label htmlFor="both">
<input
type="radio"
id="both"
name="place"
onChange={handleChange}
onBlur={handleBlur}
value="both"
/> Both
</label>
</div>
</div>
{errors.place && touched.place && (<span className="form-error">{errors.place}</span>)}
</div>
</div>
</div>
</div>
<hr />
<div>
<p>Group Information</p>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Contact Person for the Activity</label>
<input
type="text"
name="contact_person_for_activity"
onChange={handleChange}
onBlur={handleBlur}
value={values.contact_person_for_activity}
/>
{errors.contact_person_for_activity && touched.contact_person_for_activity && (<span className="form-error">{errors.contact_person_for_activity}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Size of the Group</label>
<div className="row">
<div className="col-6 col-lg-6">
<div className="input-group mb-0">
<input
type="text"
name="min_group_size"
onChange={handleChange}
onBlur={handleBlur}
value={values.min_group_size}
/>
{errors.min_group_size && touched.min_group_size && (<span className="form-error">{errors.min_group_size}</span>)}
</div>
</div>
<div className="col-6 col-lg-6">
<div className="input-group mb-0">
<input
type="text"
name="max_group_size"
onChange={handleChange}
onBlur={handleBlur}
value={values.max_group_size}
/>
{errors.max_group_size && touched.max_group_size && (<span className="form-error">{errors.max_group_size}</span>)}
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<hr />
<div>
<p>Availability</p>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Months</label>
<select
id="month"
name="month"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="">Select</option>
<option value="Location 1">Location 1</option>
<option value="Location 2">Location 2</option>
</select>
{errors.contact_person_for_activity && touched.contact_person_for_activity && (<span className="form-error">{errors.contact_person_for_activity}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Size of the Group</label>
<div className="row">
<div className="col-6 col-lg-6">
<div className="input-group mb-0">
<input
type="text"
name="min_group_size"
onChange={handleChange}
onBlur={handleBlur}
value={values.min_group_size}
/>
{errors.min_group_size && touched.min_group_size && (<span className="form-error">{errors.min_group_size}</span>)}
</div>
</div>
<div className="col-6 col-lg-6">
<div className="input-group mb-0">
<input
type="text"
name="max_group_size"
onChange={handleChange}
onBlur={handleBlur}
value={values.max_group_size}
/>
{errors.max_group_size && touched.max_group_size && (<span className="form-error">{errors.max_group_size}</span>)}
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div className="row mb-5">
<div className="col-12 col-lg-5">
<div className="input-group">
<Button type="submit" className="btn btn-primary btn-submit">
Send for Approval
</Button>
</div>
</div>
</div>
</Form>
)}
</Formik>
</div>
</div>
</div>
<div className="col-12 col-lg-4">
<div className="content-div help-center">
<h2>Help Center</h2>
<ul className="helplist">
<li>
<img src="/images/vendor/question.svg" className="img-fluid" />
<p>Lorem Ipsum Dolor Sit?</p>
</li>
<li>
<img src="/images/vendor/question.svg" className="img-fluid" />
<p>Lorem Ipsum Dolor Sit?</p>
</li>
<li>
<img src="/images/vendor/question.svg" className="img-fluid" />
<p>Lorem Ipsum Dolor Sit?</p>
</li>
<li>
<img src="/images/vendor/question.svg" className="img-fluid" />
<p>Lorem Ipsum Dolor Sit?</p>
</li>
<li>
<img src="/images/vendor/call.svg" className="img-fluid" />
<p>+1 (407) 8798 789</p>
</li>
</ul>
</div>
</div>
</div>
</div>
</Fragment >
)
}
export default ActivityDetails;
\ No newline at end of file \ No newline at end of file
import { Formik } from "formik";
import { Fragment } from "react";
import { Button, Form } from "react-bootstrap";
import * as Yup from "yup";
const BusinessDetails = () => {
const businessDetailsValidationSchema = Yup.object().shape({
pan_number: Yup.string()
.required("Pan Number is Required"),
pan_file: Yup.string()
.required("Pan Image is Required"),
gst_number: Yup.string()
.required("GST Number is Required"),
gst_certificate_file: Yup.string()
.required("GST Certificate is Required"),
business_name: Yup.string()
.required("Business Name is Required"),
brand_logo_file: Yup.string()
.required("Brand Logo is Required"),
pincode: Yup.string()
.required("Pincode is Required"),
country: Yup.string()
.required("Country is Required"),
state: Yup.string()
.required("State is Required"),
city: Yup.string()
.required("City is Required"),
address_line1: Yup.string()
.required("Address Line 1 is Required"),
address_line2: Yup.string()
.required("Address Line 2 is Required"),
});
return (
<Fragment>
<div className="container p-5">
<div className="row">
<div className="col-12 col-lg-8">
<div className="content-div business-details">
<h2>Tell us about your business</h2>
<p>Please have the following ready before you begin</p>
<p><i className="fa fa-arrow-right me-1"></i> Your bank account details for receiving payments from ZanGO</p>
<p><i className="fa fa-arrow-right me-1"></i> Tax (GST/PAN) details of your business.</p>
<hr />
<div className="form-container">
<Formik
initialValues={{
pan_number: "",
pan_file: "",
gst_number: "",
gst_certificate_file: "",
business_name: "",
brand_logo_file: "",
pincode: "",
country: "",
state: "",
city: "",
address_line1: "",
address_line2: ""
}}
validationSchema={businessDetailsValidationSchema}
// enableReinitialize={true}
onSubmit={values => {
console.log("business details values", values)
}}
>
{({ values, errors, touched, handleChange, handleBlur, handleSubmit }) => (
<Form
onSubmit={e => {
e.preventDefault();
handleSubmit();
}}
>
<h4>Vendor Business Information</h4>
<div>
<p>Business documents</p>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Enter Business PAN No.</label>
<input
type="text"
name="pan_number"
onChange={handleChange}
onBlur={handleBlur}
value={values.pan_number}
/>
{errors.pan_number && touched.pan_number && (<span className="form-error">{errors.pan_number}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Upload PAN</label>
<input
type="file"
name="pan_file"
onChange={handleChange}
onBlur={handleBlur}
value={values.pan_file}
/>
{errors.pan_file && touched.pan_file && (<span className="form-error">{errors.pan_file}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>GST Number</label>
<input
type="text"
name="gst_number"
onChange={handleChange}
onBlur={handleBlur}
value={values.gst_number}
/>
{errors.gst_number && touched.gst_number && (<span className="form-error">{errors.gst_number}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>GST Certificate</label>
<input
type="file"
name="gst_certificate_file"
onChange={handleChange}
onBlur={handleBlur}
value={values.gst_certificate_file}
/>
{errors.gst_certificate_file && touched.gst_certificate_file && (<span className="form-error">{errors.gst_certificate_file}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Business Name</label>
<input
type="text"
name="business_name"
onChange={handleChange}
onBlur={handleBlur}
value={values.business_name}
/>
{errors.business_name && touched.business_name && (<span className="form-error">{errors.business_name}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Brand Logo</label>
<input
type="file"
name="brand_logo_file"
onChange={handleChange}
onBlur={handleBlur}
value={values.brand_logo_file}
/>
{errors.brand_logo_file && touched.brand_logo_file && (<span className="form-error">{errors.brand_logo_file}</span>)}
</div>
</div>
</div>
</div>
<hr />
<div>
<p>Business Address</p>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Pincode</label>
<input
type="text"
name="pincode"
onChange={handleChange}
onBlur={handleBlur}
value={values.pincode}
/>
{errors.pincode && touched.pincode && (<span className="form-error">{errors.pincode}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Country</label>
<select
id="country"
name="country"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="India">India</option>
<option value="America">America</option>
</select>
{errors.country && touched.country && (<span className="form-error">{errors.country}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>State</label>
<select
id="state"
name="state"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="India">India</option>
<option value="America">America</option>
</select>
{errors.state && touched.state && (<span className="form-error">{errors.state}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>City</label>
<select
id="city"
name="city"
onChange={handleChange}
onBlur={handleBlur}
>
<option value="India">India</option>
<option value="America">America</option>
</select>
{errors.city && touched.city && (<span className="form-error">{errors.city}</span>)}
</div>
</div>
</div>
<div className="row">
<div className="col-12 col-lg-5">
<div className="input-group">
<label>Address Line 1</label>
<input
type="text"
name="address_line1"
onChange={handleChange}
onBlur={handleBlur}
value={values.address_line1}
/>
{errors.address_line1 && touched.address_line1 && (<span className="form-error">{errors.address_line1}</span>)}
</div>
</div>
<div className="col-12 offset-lg-1 col-lg-5">
<div className="input-group">
<label>Address Line 2</label>
<input
type="text"
name="address_line2"
onChange={handleChange}
onBlur={handleBlur}
value={values.address_line2}
/>
{errors.address_line2 && touched.address_line2 && (<span className="form-error">{errors.address_line2}</span>)}
</div>
</div>
</div>
</div>
<div className="row mb-5">
<div className="col-12 col-lg-5">
<div className="input-group">
<Button type="submit" className="btn btn-primary btn-submit">
Send for Approval
</Button>
</div>
</div>
</div>
</Form>
)}
</Formik>
</div>
</div>
</div>
<div className="col-12 col-lg-4">
<div className="content-div help-center">
<h2>Help Center</h2>
<ul className="helplist">
<li>
<img src="/images/vendor/question.svg" className="img-fluid" />
<p>Lorem Ipsum Dolor Sit?</p>
</li>
<li>
<img src="/images/vendor/question.svg" className="img-fluid" />
<p>Lorem Ipsum Dolor Sit?</p>
</li>
<li>
<img src="/images/vendor/question.svg" className="img-fluid" />
<p>Lorem Ipsum Dolor Sit?</p>
</li>
<li>
<img src="/images/vendor/question.svg" className="img-fluid" />
<p>Lorem Ipsum Dolor Sit?</p>
</li>
<li>
<img src="/images/vendor/call.svg" className="img-fluid" />
<p>+1 (407) 8798 789</p>
</li>
</ul>
</div>
</div>
</div>
</div>
</Fragment >
)
}
export default BusinessDetails;
\ No newline at end of file \ No newline at end of file
...@@ -25,12 +25,14 @@ ...@@ -25,12 +25,14 @@
"react-dom": "18.2.0", "react-dom": "18.2.0",
"react-js-pagination": "^3.0.3", "react-js-pagination": "^3.0.3",
"react-multi-carousel": "^2.8.2", "react-multi-carousel": "^2.8.2",
"react-otp-input": "^3.1.1",
"react-owl-carousel": "^2.3.3", "react-owl-carousel": "^2.3.3",
"react-phone-input-2": "^2.15.1", "react-phone-input-2": "^2.15.1",
"react-player": "^2.11.0", "react-player": "^2.11.0",
"react-rating": "^2.0.5", "react-rating": "^2.0.5",
"react-redux": "^8.0.2", "react-redux": "^8.0.2",
"react-toastify": "^9.0.8", "react-toastify": "^9.0.8",
"reactjs-otp-input": "^2.0.8",
"redux": "^4.2.0", "redux": "^4.2.0",
"redux-devtools-extension": "^2.13.9", "redux-devtools-extension": "^2.13.9",
"redux-thunk": "^2.4.1", "redux-thunk": "^2.4.1",
......
import { useRouter } from "next/router";
import { useEffect, useState } from "react";
import Layout from "../../../components/layout/Layout";
import Login from "../../../components/login/Login";
export default function LoginPage() {
const router = useRouter();
const [loginType, setLoginType] = useState("");
useEffect(() => {
setLoginType(router?.query?.type)
}, [router])
return (
<Layout>
<Login type={loginType} />
</Layout>
);
};
\ No newline at end of file \ No newline at end of file
import { useRouter } from "next/router";
import { useEffect, useState } from "react";
import Layout from "../../../components/layout/Layout";
import Signup from "../../../components/signup/Signup";
export default function SignupPage () {
const router = useRouter();
const [signupType, setSignupType] = useState("");
useEffect(() => {
setSignupType(router?.query?.type)
}, [router])
return (
<Layout>
<Signup type={signupType} />
</Layout>
);
};
\ No newline at end of file \ No newline at end of file
import React from "react";
import Layout from "../../../components/layout/Layout";
import MyBookings from "../../../components/user/MyBookings";
export default function UserBokkingsPage () {
return (
<Layout>
<MyBookings />
</Layout>
);
};
\ No newline at end of file \ No newline at end of file
import React from "react";
import Layout from "../../../components/layout/Layout";
import MyGiftCard from "../../../components/user/MyGiftCard";
export default function UserGiftCardPage () {
return (
<Layout>
<MyGiftCard />
</Layout>
);
};
\ No newline at end of file \ No newline at end of file
import React from "react";
import Layout from "../../../components/layout/Layout";
import MyProfile from "../../../components/user/MyProfile";
export default function UserProfilePage () {
return (
<Layout>
<MyProfile />
</Layout>
);
};
\ No newline at end of file \ No newline at end of file
import React from "react";
import Layout from "../../../components/layout/Layout";
import MyWhishList from "../../../components/user/MyWhishList";
export default function UserProfilePage () {
return (
<Layout>
<MyWhishList />
</Layout>
);
};
\ No newline at end of file \ No newline at end of file
import React from "react";
import Layout from "../../../components/layout/Layout";
import ActivityDetails from "../../../components/vendor/ActivityDetails";
export default function ActivityDetailsPage () {
return (
<Layout>
<ActivityDetails />
</Layout>
);
};
\ No newline at end of file \ No newline at end of file
import React from "react";
import Layout from "../../../components/layout/Layout";
import BusinessDetails from "../../../components/vendor/BusinessDetails";
export default function BusinessDetailsPage () {
return (
<Layout>
<BusinessDetails />
</Layout>
);
};
\ No newline at end of file \ No newline at end of file
import Image from "next/image";
import React, { Fragment, useRef, useState } from "react";
import { Badge, Button, Col, Container, Nav, Navbar, Overlay, OverlayTrigger, Popover, Row } from "react-bootstrap";
const VendorDashboard = () => {
const [show, setShow] = useState(false);
const [target, setTarget] = useState(null);
const ref = useRef(null);
const handleClick = (event) => {
setShow(!show);
setTarget(event.target);
};
const [collapsed, setCollapsed] = useState(false);
const toggleSidebar = () => {
setCollapsed(!collapsed);
};
return (
<>
<Navbar bg="dark" variant="dark">
<Navbar.Brand href="#">Your Logo</Navbar.Brand>
<Nav className="mr-auto">
<Nav.Link href="#">Home</Nav.Link>
<Nav.Link href="#">About</Nav.Link>
<Nav.Link href="#">Services</Nav.Link>
<Nav.Link href="#">Contact</Nav.Link>
</Nav>
<Nav>
<Nav.Link ref={ref}>
{/* <FaBell /> */}
<Badge variant="danger" onClick={handleClick}>5</Badge>
<Overlay
show={show}
target={target}
placement="bottom"
container={ref}
containerPadding={0}
className="bottom"
>
<Popover id="popover-contained">
<Popover.Header as="h3">Popover bottom</Popover.Header>
<Popover.Body>
<strong>Holy guacamole!</strong> Check this info.
</Popover.Body>
</Popover>
</Overlay>
</Nav.Link>
</Nav>
</Navbar>
<Fragment>
<header className="header_wrap">
<Navbar expand="lg" className="bg-body-tertiary">
<Container>
<Navbar.Brand href="#">
<span className="image-container">
<Image layout="fill" alt="" className="image img-fluid" src="/images/zango-logo.svg" />
</span>
</Navbar.Brand>
{/* <Navbar.Toggle aria-controls="navbarScroll" /> */}
{/* <Navbar.Collapse id="navbarScroll">
<Nav className=" my-2 my-lg-0" style={{ maxHeight: "100px" }} navbarScroll>
<Nav.Link href="#action1">Blogs</Nav.Link>
<Nav.Link href="#action2" className="gift-card">
Gift Card
<span className="image-container">
<Image layout="fill" className="image img-fluid" src="/images/icons/gift-card-icon.svg" alt="" />
</span>
</Nav.Link>
</Nav>
</Navbar.Collapse> */}
</Container>
</Navbar>
</header>
<Container fluid>
<Row>
<Col xs={12} md={3} lg={2} className={`sidebar ${collapsed ? 'collapsed' : ''}`}>
<ul>
<li><img src="/images/vendor/orders.svg" className="me-1 img-fluid" /> Orders</li>
<li><img src="/images/vendor/activities.svg" className="me-1 img-fluid" /> Activities</li>
</ul>
</Col>
<Col className="content">
{/* <Button onClick={toggleSidebar} className="toggle-btn">
{collapsed ? 'Expand Sidebar' : 'Collapse Sidebar'}
</Button> */}
</Col>
</Row>
</Container>
</Fragment>
</>
);
};
export default VendorDashboard;
\ No newline at end of file \ No newline at end of file
No preview for this file type
No preview for this file type
<svg width="18" height="12" viewBox="0 0 18 12" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M1.3291 2.2096L8.66437 9.54486L15.9996 2.2096" stroke="black" stroke-width="2.5" stroke-linecap="round"/>
</svg>
<svg width="8" height="12" viewBox="0 0 8 12" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M1.83215 10.317L6.36231 5.7868L1.83215 1.25665" stroke="black" stroke-width="2" stroke-linecap="round"/>
</svg>
<svg width="21" height="20" viewBox="0 0 21 20" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="0.75293" y="-0.00143433" width="19.4933" height="19.4933" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_707_2435" transform="scale(0.00195312)"/>
</pattern>
<image id="image0_707_2435" width="512" height="512" xlink:href=""/>
</defs>
</svg>
<svg width="22" height="21" viewBox="0 0 22 21" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M18.9055 14.5082C18.4772 14.6511 18.1016 14.7873 17.719 14.9009C17.3693 15.0047 17.024 14.8005 16.9359 14.4604C16.8592 14.1641 17.0052 13.8493 17.3122 13.7396C18.1797 13.4296 19.051 13.1291 19.9262 12.8408C20.2504 12.734 20.601 12.9221 20.6953 13.2485C20.9428 14.1056 21.1812 14.9653 21.4065 15.8282C21.5016 16.1922 21.291 16.5062 20.9393 16.5881C20.5915 16.669 20.2833 16.4773 20.1761 16.1092C20.0997 15.8471 20.0286 15.5836 19.9454 15.2857C19.786 15.5424 19.6518 15.7782 19.4989 16.0017C17.7011 18.631 15.2034 20.1535 11.9918 20.5141C7.0173 21.0725 2.26999 17.842 1.05536 13.0896C0.94609 12.6621 1.11372 12.3307 1.4882 12.2341C1.85058 12.1406 2.17082 12.3626 2.28661 12.787C2.89826 15.0286 4.20938 16.7726 6.20596 18.0087C7.8383 19.0192 9.63362 19.4596 11.5582 19.3031C14.7311 19.0452 17.1064 17.5298 18.7204 14.8505C18.7786 14.7539 18.828 14.6522 18.9055 14.5082Z" fill="black"/>
<path d="M2.96264 6.6387C3.37481 6.50112 3.75004 6.36256 4.13352 6.25138C4.57068 6.12464 4.97973 6.46275 4.93473 6.90163C4.90898 7.15277 4.76882 7.33497 4.52777 7.4194C3.67193 7.71914 2.81505 8.01633 1.9544 8.30244C1.60498 8.41861 1.25637 8.23592 1.15582 7.88568C0.913606 7.04196 0.679603 6.19585 0.454167 5.34768C0.357506 4.984 0.555926 4.65405 0.893909 4.56748C1.25236 4.47567 1.56582 4.66148 1.68027 5.04054C1.75921 5.30201 1.82934 5.56605 1.91007 5.85259C1.95002 5.79769 1.9808 5.76175 2.00459 5.72181C3.77013 2.75712 6.38313 1.03288 9.86571 0.640084C14.8446 0.0785135 19.557 3.28529 20.798 8.04191C20.9136 8.48505 20.75 8.81751 20.3676 8.91672C20.0056 9.01062 19.6875 8.78933 19.5702 8.36299C18.9049 5.94654 17.4514 4.12323 15.233 2.89944C10.9444 0.533632 5.34876 2.16549 3.05908 6.43526C3.02954 6.49035 3.00535 6.5482 2.96264 6.6387Z" fill="black"/>
</svg>
<svg width="19" height="18" viewBox="0 0 19 18" fill="none" xmlns="http://www.w3.org/2000/svg">
<g clip-path="url(#clip0_822_2426)">
<path d="M9.42095 17.9955C7.74795 17.9955 6.07482 18.0077 4.40196 17.9919C2.88299 17.9776 1.71997 17.3098 0.93939 16.0019C0.595308 15.4253 0.434052 14.7898 0.429198 14.1207C0.420861 12.9713 0.42386 11.8218 0.427347 10.6724C0.428578 10.2666 0.665323 9.94704 1.01872 9.84787C1.36379 9.75103 1.74455 9.87552 1.91918 10.1851C2.00554 10.3383 2.05602 10.5326 2.05799 10.7089C2.07025 11.8072 2.0636 12.9056 2.06433 14.0039C2.06524 15.3656 3.05837 16.3566 4.42382 16.3569C7.75706 16.3576 11.0903 16.3576 14.4235 16.3569C15.7883 16.3566 16.7792 15.3657 16.7805 14.0012C16.7816 12.8837 16.7792 11.7662 16.7818 10.6487C16.7827 10.2761 17.0027 9.97174 17.3386 9.85925C17.6642 9.7502 18.0322 9.8442 18.2285 10.1278C18.3254 10.2677 18.4083 10.4527 18.4093 10.6179C18.417 11.8882 18.4483 13.161 18.385 14.4286C18.2986 16.1571 16.8886 17.6592 15.1825 17.9274C14.9126 17.9698 14.6366 17.9917 14.3633 17.9926C12.7159 17.9985 11.0684 17.9956 9.42095 17.9955Z" fill="white"/>
<path d="M8.60829 2.8014C8.51582 2.88978 8.46464 2.93682 8.41551 2.98592C7.33132 4.06962 6.24638 5.15257 5.16413 6.2382C4.93684 6.46621 4.67918 6.58473 4.35323 6.51343C3.75759 6.38313 3.50952 5.67584 3.89462 5.20251C3.93479 5.15314 3.98126 5.10872 4.02638 5.06358C5.60243 3.48716 7.17861 1.91087 8.75493 0.334721C9.19952 -0.109824 9.64455 -0.111806 10.0867 0.330207C11.6723 1.91518 13.2567 3.50135 14.8433 5.0852C15.0778 5.31923 15.1922 5.58743 15.107 5.91663C14.9505 6.52134 14.2322 6.7394 13.7703 6.31924C13.5533 6.12172 13.352 5.90675 13.1442 5.69903C12.2363 4.79131 11.328 3.88402 10.4228 2.97362C10.3755 2.92596 10.3554 2.85116 10.3226 2.78899C10.2941 2.80928 10.2656 2.82956 10.2371 2.84984V3.07034C10.237 6.37897 10.2373 9.68759 10.2367 12.9962C10.2366 13.4664 10.0233 13.7694 9.62433 13.8757C9.13892 14.0049 8.64805 13.6568 8.61301 13.1567C8.60677 13.0676 8.60846 12.978 8.60846 12.8886C8.60826 9.61822 8.60829 6.34788 8.60829 3.07754C8.60829 3.00319 8.60829 2.92884 8.60829 2.8014Z" fill="white"/>
</g>
<defs>
<clipPath id="clip0_822_2426">
<rect width="18" height="18" fill="white" transform="translate(0.423828)"/>
</clipPath>
</defs>
</svg>
<svg width="14" height="14" viewBox="0 0 14 14" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M7.28289 0.452759L8.86537 5.32316H13.9864L9.84341 8.33323L11.4259 13.2036L7.28289 10.1936L3.13987 13.2036L4.72236 8.33323L0.579354 5.32316H5.7004L7.28289 0.452759Z" fill="#FFD600"/>
</svg>
<svg width="54" height="54" viewBox="0 0 54 54" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<circle cx="27.1287" cy="27.0604" r="26.3826" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_708_3413" transform="scale(0.00195312)"/>
</pattern>
<image id="image0_708_3413" width="512" height="512" xlink:href=""/>
</defs>
</svg>
<svg width="38" height="39" viewBox="0 0 38 39" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="0.631836" y="0.881287" width="37.2015" height="37.2015" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_822_2424" transform="scale(0.00195312)"/>
</pattern>
<image id="image0_822_2424" width="512" height="512" xlink:href=""/>
</defs>
</svg>
<svg width="18" height="18" viewBox="0 0 18 18" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M11 7V11H7V7H11ZM13 7H18V11H13V7ZM11 18H7V13H11V18ZM13 18V13H18V17C18 17.5523 17.5523 18 17 18H13ZM11 0V5H7V0H11ZM13 0H17C17.5523 0 18 0.44772 18 1V5H13V0ZM5 7V11H0V7H5ZM5 18H1C0.44772 18 0 17.5523 0 17V13H5V18ZM5 0V5H0V1C0 0.44772 0.44772 0 1 0H5Z" fill="white"/>
</svg>
<svg width="31" height="31" viewBox="0 0 31 31" fill="none" xmlns="http://www.w3.org/2000/svg">
<circle cx="15.5" cy="15.5" r="15.5" fill="#0070BD"/>
</svg>
<svg width="18" height="18" viewBox="0 0 18 18" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M5 14C5.28333 14 5.52083 13.9042 5.7125 13.7125C5.90417 13.5208 6 13.2833 6 13C6 12.7167 5.90417 12.4792 5.7125 12.2875C5.52083 12.0958 5.28333 12 5 12C4.71667 12 4.47917 12.0958 4.2875 12.2875C4.09583 12.4792 4 12.7167 4 13C4 13.2833 4.09583 13.5208 4.2875 13.7125C4.47917 13.9042 4.71667 14 5 14ZM5 10C5.28333 10 5.52083 9.90417 5.7125 9.7125C5.90417 9.52083 6 9.28333 6 9C6 8.71667 5.90417 8.47917 5.7125 8.2875C5.52083 8.09583 5.28333 8 5 8C4.71667 8 4.47917 8.09583 4.2875 8.2875C4.09583 8.47917 4 8.71667 4 9C4 9.28333 4.09583 9.52083 4.2875 9.7125C4.47917 9.90417 4.71667 10 5 10ZM5 6C5.28333 6 5.52083 5.90417 5.7125 5.7125C5.90417 5.52083 6 5.28333 6 5C6 4.71667 5.90417 4.47917 5.7125 4.2875C5.52083 4.09583 5.28333 4 5 4C4.71667 4 4.47917 4.09583 4.2875 4.2875C4.09583 4.47917 4 4.71667 4 5C4 5.28333 4.09583 5.52083 4.2875 5.7125C4.47917 5.90417 4.71667 6 5 6ZM8 14H14V12H8V14ZM8 10H14V8H8V10ZM8 6H14V4H8V6ZM2 18C1.45 18 0.979167 17.8042 0.5875 17.4125C0.195833 17.0208 0 16.55 0 16V2C0 1.45 0.195833 0.979167 0.5875 0.5875C0.979167 0.195833 1.45 0 2 0H16C16.55 0 17.0208 0.195833 17.4125 0.5875C17.8042 0.979167 18 1.45 18 2V16C18 16.55 17.8042 17.0208 17.4125 17.4125C17.0208 17.8042 16.55 18 16 18H2ZM2 16H16V2H2V16Z" fill="white"/>
</svg>
<svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M12 22C6.47715 22 2 17.5228 2 12C2 6.47715 6.47715 2 12 2C17.5228 2 22 6.47715 22 12C22 17.5228 17.5228 22 12 22ZM11 15V17H13V15H11ZM13 13.3551C14.4457 12.9248 15.5 11.5855 15.5 10C15.5 8.067 13.933 6.5 12 6.5C10.302 6.5 8.88637 7.70919 8.56731 9.31346L10.5288 9.70577C10.6656 9.01823 11.2723 8.5 12 8.5C12.8284 8.5 13.5 9.17157 13.5 10C13.5 10.8284 12.8284 11.5 12 11.5C11.4477 11.5 11 11.9477 11 12.5V14H13V13.3551Z" fill="#0070BD"/>
</svg>
<svg width="134" height="51" viewBox="0 0 134 51" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<path d="M9.01509 41.6372L8.18792 42.3689C7.70718 41.9094 7.13453 41.6796 6.46997 41.6796C5.74885 41.6796 5.13732 41.9412 4.63537 42.4644C4.14048 42.9875 3.89304 43.6203 3.89304 44.3626C3.89304 45.1049 4.14048 45.7377 4.63537 46.2608C5.13732 46.784 5.74885 47.0456 6.46997 47.0456C7.07797 47.0456 7.58699 46.883 7.99704 46.5578C8.41416 46.2255 8.63685 45.7907 8.66513 45.2534H6.61844V44.2884H9.9589C9.9589 45.5539 9.64783 46.5083 9.02569 47.1516C8.40355 47.7879 7.55165 48.106 6.46997 48.106C5.43778 48.106 4.56113 47.742 3.84002 47.0138C3.12597 46.2856 2.76895 45.4019 2.76895 44.3626C2.76895 43.3233 3.12597 42.4396 3.84002 41.7114C4.55406 40.9762 5.43072 40.6086 6.46997 40.6086C7.48095 40.6086 8.32932 40.9514 9.01509 41.6372ZM15.7478 45.5079C15.7478 45.7059 15.7443 45.8402 15.7372 45.9109H11.8029C11.8524 46.2927 12.015 46.5967 12.2907 46.8229C12.5735 47.042 12.9164 47.1516 13.3193 47.1516C13.6021 47.1516 13.8637 47.0915 14.1041 46.9713C14.3515 46.8441 14.5389 46.6673 14.6661 46.4411C14.7722 46.4906 14.9312 46.5648 15.1433 46.6638C15.3625 46.7557 15.5004 46.8123 15.5569 46.8335C15.3448 47.2506 15.0338 47.5687 14.6237 47.7879C14.2137 48 13.7612 48.106 13.2663 48.106C12.5452 48.106 11.9407 47.8657 11.4529 47.3849C10.9651 46.9042 10.7212 46.2785 10.7212 45.5079C10.7212 44.7373 10.9651 44.1187 11.4529 43.6521C11.9407 43.1784 12.5452 42.9416 13.2663 42.9416C13.9874 42.9416 14.5813 43.1784 15.0479 43.6521C15.5145 44.1187 15.7478 44.7373 15.7478 45.5079ZM11.8029 45.1155H14.6767C14.6272 44.7338 14.4717 44.4368 14.2101 44.2247C13.9556 44.0056 13.641 43.896 13.2663 43.896C12.8775 43.896 12.5487 44.0056 12.2801 44.2247C12.0114 44.4439 11.8524 44.7408 11.8029 45.1155ZM18.3855 41.1706V43.0476H19.4354V43.949H18.3855V48H17.2933V43.949H16.4025V43.0476H17.2933V41.1706H18.3855ZM20.3833 47.9046C20.2419 47.7702 20.1712 47.6006 20.1712 47.3955C20.1712 47.1905 20.2419 47.0208 20.3833 46.8865C20.5317 46.7451 20.7085 46.6744 20.9135 46.6744C21.1256 46.6744 21.3023 46.7451 21.4437 46.8865C21.5922 47.0208 21.6664 47.1905 21.6664 47.3955C21.6664 47.6006 21.5922 47.7702 21.4437 47.9046C21.3023 48.0389 21.1256 48.106 20.9135 48.106C20.7085 48.106 20.5317 48.0389 20.3833 47.9046ZM25.5428 45.8791H26.6669C26.681 46.1901 26.8224 46.4694 27.091 46.7168C27.3597 46.9572 27.7026 47.0774 28.1197 47.0774C28.5297 47.0774 28.8514 46.982 29.0847 46.7911C29.318 46.6002 29.4559 46.3633 29.4983 46.0806C29.5337 45.4796 29.1483 45.0837 28.3424 44.8928L27.4198 44.6595C26.2109 44.3343 25.6064 43.6804 25.6064 42.6977C25.6064 42.0897 25.8432 41.5913 26.3169 41.2024C26.7906 40.8065 27.3562 40.6086 28.0137 40.6086C28.6994 40.6086 29.265 40.8065 29.7104 41.2024C30.1629 41.5913 30.3891 42.1144 30.3891 42.7719H29.265C29.265 42.4396 29.1483 42.1745 28.915 41.9766C28.6817 41.7715 28.3742 41.669 27.9924 41.669C27.646 41.669 27.3491 41.7645 27.1017 41.9553C26.8542 42.1392 26.7305 42.3795 26.7305 42.6765C26.7305 43.1431 27.0557 43.4612 27.7061 43.6309L28.6393 43.8748C29.3604 44.0657 29.8836 44.3591 30.2088 44.755C30.534 45.1438 30.6683 45.6069 30.6118 46.1442C30.5552 46.7239 30.2972 47.1976 29.8377 47.5652C29.3852 47.9258 28.8125 48.106 28.1197 48.106C27.3774 48.106 26.7623 47.8869 26.2745 47.4486C25.7867 47.0102 25.5428 46.4871 25.5428 45.8791ZM36.5739 45.5079C36.5739 45.7059 36.5704 45.8402 36.5633 45.9109H32.629C32.6785 46.2927 32.8411 46.5967 33.1168 46.8229C33.3996 47.042 33.7425 47.1516 34.1455 47.1516C34.4283 47.1516 34.6898 47.0915 34.9302 46.9713C35.1776 46.8441 35.365 46.6673 35.4923 46.4411C35.5983 46.4906 35.7574 46.5648 35.9695 46.6638C36.1886 46.7557 36.3265 46.8123 36.383 46.8335C36.1709 47.2506 35.8599 47.5687 35.4498 47.7879C35.0398 48 34.5873 48.106 34.0924 48.106C33.3713 48.106 32.7669 47.8657 32.279 47.3849C31.7912 46.9042 31.5473 46.2785 31.5473 45.5079C31.5473 44.7373 31.7912 44.1187 32.279 43.6521C32.7669 43.1784 33.3713 42.9416 34.0924 42.9416C34.8136 42.9416 35.4074 43.1784 35.874 43.6521C36.3406 44.1187 36.5739 44.7373 36.5739 45.5079ZM32.629 45.1155H35.5029C35.4534 44.7338 35.2978 44.4368 35.0363 44.2247C34.7817 44.0056 34.4671 43.896 34.0924 43.896C33.7036 43.896 33.3749 44.0056 33.1062 44.2247C32.8376 44.4439 32.6785 44.7408 32.629 45.1155ZM39.2117 41.1706V43.0476H40.2615V43.949H39.2117V48H38.1194V43.949H37.2286V43.0476H38.1194V41.1706H39.2117ZM41.2094 47.9046C41.068 47.7702 40.9973 47.6006 40.9973 47.3955C40.9973 47.1905 41.068 47.0208 41.2094 46.8865C41.3579 46.7451 41.5346 46.6744 41.7396 46.6744C41.9517 46.6744 42.1285 46.7451 42.2699 46.8865C42.4183 47.0208 42.4926 47.1905 42.4926 47.3955C42.4926 47.6006 42.4183 47.7702 42.2699 47.9046C42.1285 48.0389 41.9517 48.106 41.7396 48.106C41.5346 48.106 41.3579 48.0389 41.2094 47.9046ZM52.5832 41.6372L51.7561 42.3689C51.2753 41.9094 50.7027 41.6796 50.0381 41.6796C49.317 41.6796 48.7055 41.9412 48.2035 42.4644C47.7086 42.9875 47.4612 43.6203 47.4612 44.3626C47.4612 45.1049 47.7086 45.7377 48.2035 46.2608C48.7055 46.784 49.317 47.0456 50.0381 47.0456C50.6461 47.0456 51.1551 46.883 51.5652 46.5578C51.9823 46.2255 52.205 45.7907 52.2333 45.2534H50.1866V44.2884H53.527C53.527 45.5539 53.216 46.5083 52.5938 47.1516C51.9717 47.7879 51.1198 48.106 50.0381 48.106C49.0059 48.106 48.1293 47.742 47.4081 47.0138C46.6941 46.2856 46.3371 45.4019 46.3371 44.3626C46.3371 43.3233 46.6941 42.4396 47.4081 41.7114C48.1222 40.9762 48.9988 40.6086 50.0381 40.6086C51.0491 40.6086 51.8975 40.9514 52.5832 41.6372ZM56.8663 47.0456C57.2904 47.0456 57.6475 46.9042 57.9373 46.6214C58.2272 46.3386 58.3721 45.9674 58.3721 45.5079C58.3721 45.0625 58.2272 44.702 57.9373 44.4262C57.6475 44.1505 57.2904 44.0127 56.8663 44.0127C56.4491 44.0127 56.0957 44.1505 55.8058 44.4262C55.5159 44.702 55.371 45.0625 55.371 45.5079C55.371 45.9604 55.5159 46.3315 55.8058 46.6214C56.0957 46.9042 56.4491 47.0456 56.8663 47.0456ZM58.7009 47.3849C58.1989 47.8657 57.5874 48.106 56.8663 48.106C56.1451 48.106 55.5336 47.8657 55.0317 47.3849C54.5368 46.8971 54.2893 46.2714 54.2893 45.5079C54.2893 44.7444 54.5368 44.1258 55.0317 43.6521C55.5336 43.1784 56.1451 42.9416 56.8663 42.9416C57.5944 42.9416 58.2095 43.1784 58.7115 43.6521C59.2134 44.1258 59.4644 44.7444 59.4644 45.5079C59.4644 46.2714 59.2099 46.8971 58.7009 47.3849ZM60.7928 47.9046C60.6514 47.7702 60.5807 47.6006 60.5807 47.3955C60.5807 47.1905 60.6514 47.0208 60.7928 46.8865C60.9413 46.7451 61.118 46.6744 61.323 46.6744C61.5351 46.6744 61.7119 46.7451 61.8533 46.8865C62.0017 47.0208 62.076 47.1905 62.076 47.3955C62.076 47.6006 62.0017 47.7702 61.8533 47.9046C61.7119 48.0389 61.5351 48.106 61.323 48.106C61.118 48.106 60.9413 48.0389 60.7928 47.9046Z" fill="black"/>
<rect x="0.550049" width="133" height="48" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0_58_242" transform="scale(0.0075188 0.0208333)"/>
</pattern>
<image id="image0_58_242" width="133" height="48" xlink:href=""/>
</defs>
</svg>
...@@ -13,3 +13,22 @@ export const cleanImage = originalImage => { ...@@ -13,3 +13,22 @@ export const cleanImage = originalImage => {
return imageUrl; return imageUrl;
}; };
export const renderImage = imagePath => {
let imageUrl = "/images/default.svg";
if (imagePath) {
/** When the AWS S3 plugin is activated, images are uploaded to S3 rather than local file system. */
if (imagePath.startsWith("http") || imagePath.startsWith("https")) {
imageUrl = imagePath;
} else if (process.env.NEXT_PUBLIC_IMAGE_URL) {
/** If now S3, then images are stored under the public/uploads directory of Strapi */
imageUrl = `${process.env.NEXT_PUBLIC_IMAGE_URL}${imagePath}`;
} else {
imageUrl = `http://localhost:3000${imagePath}`;
}
}
return imageUrl;
};
...@@ -189,3 +189,18 @@ ...@@ -189,3 +189,18 @@
font-weight: bold; font-weight: bold;
font-style: italic; font-style: italic;
} }
@font-face {
font-family: 'Sofia Pro Light';
font-style: normal;
font-weight: 300;
src: local('Sofia Pro Light'), url('../public/fonts/SofiaPro-Light.otf') format('opentype');
}
@font-face {
font-family: 'Sofia Pro Bold';
font-style: normal;
font-weight: 700;
src: local('Sofia Pro Bold'), url('../public/fonts/SofiaPro-Bold.ttf') format('truetype');
}
\ No newline at end of file \ No newline at end of file
@charset "UTF-8"; @charset "UTF-8";
@import "./fonts.css"; @import "./fonts.css";
/* @font-face { /* @font-face {
font-family: "Shelby"; font-family: "Shelby";
src: url("/fonts/Shelby.woff2") format("woff2"), url("/fonts/Shelby.woff") format("woff"); src: url("/fonts/Shelby.woff2") format("woff2"), url("/fonts/Shelby.woff") format("woff");
...@@ -256,29 +257,35 @@ h5, ...@@ -256,29 +257,35 @@ h5,
h6 { h6 {
font-weight: 600; font-weight: 600;
} }
/*ST Images*/ /*ST Images*/
.image-container { .image-container {
width: auto; width: auto;
position: relative; position: relative;
} }
.image-container > span {
.image-container>span {
position: unset !important; position: unset !important;
/* display: inline-block !important; */ /* display: inline-block !important; */
} }
.image-container.d-inblock > span {
.image-container.d-inblock>span {
position: unset !important; position: unset !important;
display: inline-block !important; display: inline-block !important;
} }
.image {
.image {
object-fit: contain; object-fit: contain;
width: 100% !important; width: 100% !important;
position: relative !important; position: relative !important;
height: unset !important; height: unset !important;
} }
header{
header {
position: relative; position: relative;
z-index: 99; z-index: 99;
} }
.header_wrap.stick .navbar { .header_wrap.stick .navbar {
position: fixed; position: fixed;
top: -100px; top: -100px;
...@@ -287,6 +294,7 @@ h6 { ...@@ -287,6 +294,7 @@ h6 {
background-color: #fff; background-color: #fff;
} }
.header_wrap .navbar { .header_wrap .navbar {
color: #fff; color: #fff;
position: relative; position: relative;
...@@ -299,158 +307,192 @@ h6 { ...@@ -299,158 +307,192 @@ h6 {
background: #FFF; background: #FFF;
box-shadow: 0px 4px 25px 2px rgba(0, 0, 0, 0.25); box-shadow: 0px 4px 25px 2px rgba(0, 0, 0, 0.25);
} }
.header_wrap.stick .navbar-expand-lg .navbar-nav .nav-link{
.header_wrap.stick .navbar-expand-lg .navbar-nav .nav-link {
color: #000; color: #000;
} }
.header_wrap .navbar-expand-lg .navbar-nav .nav-link .logo-icon{
.header_wrap .navbar-expand-lg .navbar-nav .nav-link .logo-icon {
margin: 0 3rem; margin: 0 3rem;
display: block; display: block;
} }
.header_wrap.stick .navbar-expand-lg .navbar-nav .nav-link .logo-icon{
.header_wrap.stick .navbar-expand-lg .navbar-nav .nav-link .logo-icon {
width: 50px; width: 50px;
display: block; display: block;
} }
.slider-item { .slider-item {
background-size: cover; background-size: cover;
background-position: 50%!important; background-position: 50% !important;
background-repeat: no-repeat!important; background-repeat: no-repeat !important;
/* height: 640px; */ /* height: 640px; */
height: 40vw; height: 40vw;
position: relative; position: relative;
border-radius: 0 0 138px 138px; border-radius: 0 0 138px 138px;
} }
.slider-item.slider-item-01 { .slider-item.slider-item-01 {
background: url(/images/home-banner/01.jpg) no-repeat; background: url(/images/home-banner/01.jpg) no-repeat;
} }
.slider-item.slider-item-02 { .slider-item.slider-item-02 {
background: url(/images/home-banner/02.jpg) no-repeat; background: url(/images/home-banner/02.jpg) no-repeat;
} }
.slider-item.slider-item-03 { .slider-item.slider-item-03 {
background: url(/images/home-banner/03.jpg) no-repeat; background: url(/images/home-banner/03.jpg) no-repeat;
} }
.slider-item.slider-item-04 { .slider-item.slider-item-04 {
background: url(/images/home-banner/04.jpg) no-repeat; background: url(/images/home-banner/04.jpg) no-repeat;
} }
.home-banner{
.home-banner {
padding-top: 119px; padding-top: 119px;
margin-top: -135px; margin-top: -135px;
} }
.container-fluid { .container-fluid {
max-width: 85vw; max-width: 85vw;
margin: 0 auto; margin: 0 auto;
} }
.navbar-brand{
.navbar-brand {
width: 133px; width: 133px;
} }
.header-search{
.header-search {
position: relative; position: relative;
} }
.header-search .search-icon{
.header-search .search-icon {
position: absolute; position: absolute;
right: 0; right: 0;
top: 3px; top: 3px;
border: 0; border: 0;
} }
.header-search .search-icon .image-container{
.header-search .search-icon .image-container {
width: 17px; width: 17px;
display: block; display: block;
} }
.btn-primary{
.btn-primary {
background: #0070BD !important; background: #0070BD !important;
font-size: 15px; font-size: 15px;
padding-left: 1rem; padding-left: 1rem;
padding-right: 1rem; padding-right: 1rem;
} }
.navbar-expand-lg .navbar-nav{
.navbar-expand-lg .navbar-nav {
margin-right: 2rem; margin-right: 2rem;
font-size: 15px; font-size: 15px;
} }
.d-table { .d-table {
width: 100%; width: 100%;
height: 100%; height: 100%;
} }
.d-table-cell { .d-table-cell {
vertical-align: middle; vertical-align: middle;
} }
.home-banner .banner-txt h1{
.home-banner .banner-txt h1 {
font-size: 24px; font-size: 24px;
line-height: 25px; line-height: 25px;
font-weight: 300; font-weight: 300;
margin-bottom: 1rem; margin-bottom: 1rem;
} }
.home-banner .banner-txt .title{
.home-banner .banner-txt .title {
font-size: 55px; font-size: 55px;
line-height: 56px; line-height: 56px;
font-weight: 300; font-weight: 300;
margin-bottom: 1rem; margin-bottom: 1rem;
} }
.home-banner .banner-txt .disc{
.home-banner .banner-txt .disc {
font-size: 16px; font-size: 16px;
line-height: 17px; line-height: 17px;
font-weight: 300; font-weight: 300;
margin-bottom: 1rem; margin-bottom: 1rem;
} }
.home-banner .slider-text{
.home-banner .slider-text {
color: #fff; color: #fff;
} }
.owl-custom01.owl-theme .owl-nav { .owl-custom01.owl-theme .owl-nav {
position: absolute; position: absolute;
left: 0; left: 0;
top: calc(33% + 0px); top: calc(33% + 0px);
margin: 0; margin: 0;
width: 100%; width: 100%;
} }
.owl-custom01.owl-theme .owl-nav [class*="owl-"]:hover {
.owl-custom01.owl-theme .owl-nav [class*="owl-"]:hover {
background: transparent !important; background: transparent !important;
} }
.owl-custom01.owl-carousel .owl-nav button {
.owl-custom01.owl-carousel .owl-nav button {
text-indent: -99999rem; text-indent: -99999rem;
position: relative; position: relative;
} }
.owl-custom01.owl-carousel .owl-nav button.owl-prev > span {
.owl-custom01.owl-carousel .owl-nav button.owl-prev>span {
background: url(/images/icons/arrow-left.svg) no-repeat center; background: url(/images/icons/arrow-left.svg) no-repeat center;
width: 14px; width: 14px;
height: 22px; height: 22px;
background-size: 100%; background-size: 100%;
display: block; display: block;
} }
.owl-custom01.owl-carousel .owl-nav button.owl-next > span {
.owl-custom01.owl-carousel .owl-nav button.owl-next>span {
background: url(/images/icons/arrow-right.svg) no-repeat center; background: url(/images/icons/arrow-right.svg) no-repeat center;
width: 14px; width: 14px;
height: 22px; height: 22px;
background-size: 100%; background-size: 100%;
display: block; display: block;
} }
.home-banner .owl-carousel.owl-drag .owl-item {
.home-banner .owl-carousel.owl-drag .owl-item {
/* max-height: 455px; */ /* max-height: 455px; */
} }
.owl-custom01.owl-carousel .owl-item img {
.owl-custom01.owl-carousel .owl-item img {
height: 100% !important; height: 100% !important;
} }
.owl-custom01.owl-carousel .owl-nav button.owl-prev {
.owl-custom01.owl-carousel .owl-nav button.owl-prev {
position: absolute; position: absolute;
left: calc(5% + 1px); left: calc(5% + 1px);
} }
.owl-custom01.owl-carousel .owl-nav button.owl-next {
.owl-custom01.owl-carousel .owl-nav button.owl-next {
position: absolute; position: absolute;
right: calc(5% + 1px); right: calc(5% + 1px);
} }
.owl-custom01.owl-theme .owl-dots {
.owl-custom01.owl-theme .owl-dots {
padding-top: 30px; padding-top: 30px;
} }
.owl-custom01.owl-theme .owl-dots .owl-dot.active span,
.owl-custom01.owl-theme .owl-dots .owl-dot:hover span { .owl-custom01.owl-theme .owl-dots .owl-dot.active span,
.owl-custom01.owl-theme .owl-dots .owl-dot:hover span {
background: #fff; background: #fff;
border: 3px solid #c9262b; border: 3px solid #c9262b;
} }
.owl-custom01.owl-theme .owl-dots .owl-dot span {
.owl-custom01.owl-theme .owl-dots .owl-dot span {
width: 15px; width: 15px;
height: 15px; height: 15px;
border: 3px solid #fff; border: 3px solid #fff;
background: #2a2a2a; background: #2a2a2a;
} }
.searchbar-h{
.searchbar-h {
position: relative; position: relative;
width: 100%; width: 100%;
border-radius: 73px; border-radius: 73px;
...@@ -459,100 +501,756 @@ h6 { ...@@ -459,100 +501,756 @@ h6 {
height: 90px; height: 90px;
padding: 2.2rem; padding: 2.2rem;
} }
.searchbar-h input{
.searchbar-h input {
width: 100%; width: 100%;
border: 0; border: 0;
font-size: 20px; font-size: 20px;
} }
.searchbar-h .search-icon{
.searchbar-h .search-icon {
position: absolute; position: absolute;
right: 35px; right: 35px;
top: 30px; top: 30px;
background: transparent !important; background: transparent !important;
border: 0; border: 0;
} }
.searchbar-h .search-icon .image-container { .searchbar-h .search-icon .image-container {
width: 17px; width: 17px;
display: block; display: block;
} }
input:focus-visible { input:focus-visible {
outline: none; outline: none;
} }
.searchbar-session{
.searchbar-session {
margin-top: -45px; margin-top: -45px;
position: relative; position: relative;
z-index: 1; z-index: 1;
} }
.head01 { .head01 {
color: #4B4B4B; color: #4B4B4B;
} }
.head01 .title { .head01 .title {
font-size: 1.25vw; font-size: 1.25vw;
line-height: 1.25vw; line-height: 1.25vw;
margin-bottom: 0.5rem; margin-bottom: 0.5rem;
} }
.head01 h2 { .head01 h2 {
font-size: 2.865vw; font-size: 2.865vw;
margin-bottom: 1rem; margin-bottom: 1rem;
color: #111111; color: #111111;
} }
.let-discover-session{
.let-discover-session {
padding: 5rem; padding: 5rem;
} }
.head-btn{
.head-btn {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: space-between; justify-content: space-between;
} }
.let-discover-carousal a{
/*-------- login page --------*/
p {
color: #000;
font-family: "Sofia Pro Light";
font-size: 15px;
line-height: normal;
}
span.form-error {
color: red;
font-size: 0.8rem;
font-family: "Sofia Pro Light";
}
/*ST Images*/
.image-container {
width: auto;
position: relative;
}
.image-container>span {
position: unset !important;
/* display: inline-block !important; */
}
.image-container.d-inblock>span {
position: unset !important;
display: inline-block !important;
}
.image {
object-fit: contain;
width: 100% !important;
position: relative !important;
height: unset !important;
}
.login-banner-image {
background-repeat: no-repeat;
background-position: center;
background-size: cover;
position: relative;
height: 95vh;
background-image: url("../public/images/login/banner-image.jpg");
}
.login-div {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
padding: 22px 32px;
border-radius: 20px;
background: #FFF;
box-shadow: 0px 20px 24px 0px rgba(166, 166, 166, 0.25);
}
.login-div a,
.login-div a:focus,
.login-div a:hover {
color: #000;
}
.login-div h2 {
color: #000;
font-family: "Sofia Pro Bold";
font-size: 28px;
line-height: normal;
margin-bottom: 20px;
}
.form-container .input-group {
margin-bottom: 28px;
}
.form-container label {
color: #000;
font-family: "Sofia Pro Light";
font-size: 15px;
line-height: normal;
margin-bottom: 10px;
}
.form-container input,
.form-container select {
width: 100%;
border-radius: 10px !important;
border: 0.814px solid #000;
box-shadow: 1.628px 3.255px 4.069px 0px rgba(255, 255, 255, 0.25) inset;
color: #000;
font-family: "Sofia Pro Light";
font-size: 15px;
font-weight: 400;
line-height: normal;
height: 45px;
padding: 16px 22px;
}
.form-container input:focus,
.form-container select:focus {
box-shadow: none;
outline: unset;
}
.form-container select {
padding: 12px 5px;
background-color: transparent;
}
.contact-number {
width: 100%;
display: flex;
border-radius: 10px !important;
border: 0.814px solid #000;
}
.contact-number select,
.contact-number input {
border: none !important;
border-radius: 0 !important;
box-shadow: unset !important;
}
.contact-number select {
border-radius: 10px 0 0 10px !important;
}
.contact-number input {
border-radius: 0 10px 10px 0 !important;
border-left: 0.814px solid #000 !important;
margin-left: 10px;
}
.form-container ::-webkit-input-placeholder {
color: #CCC;
font-family: "Sofia Pro Light";
font-size: 15px;
line-height: normal;
}
.form-container ::-moz-placeholder {
color: #CCC;
font-family: "Sofia Pro Light";
font-size: 15px;
line-height: normal;
}
.form-container :-ms-input-placeholder {
color: #CCC;
font-family: "Sofia Pro Light";
font-size: 15px;
line-height: normal;
}
.form-container ::-ms-input-placeholder {
color: #CCC;
font-family: "Sofia Pro Light";
font-size: 15px;
line-height: normal;
}
.form-container ::placeholder {
color: #CCC;
font-family: "Sofia Pro Light";
font-size: 15px;
line-height: normal;
}
.form-container .input-group button,
.btn-continue {
width: 100% !important;
outline: none;
padding: 1rem;
border-radius: 10px !important;
}
.btn-submit {
background: #0070BD;
color: #FFF;
font-family: "Sofia Pro Bold";
font-size: 15px;
line-height: normal;
}
.btn-submit:disabled {
background-color: #BACCD9;
border: none;
}
.btn-submit:hover {
background-color: #0070BD;
}
.btn-continue {
border: 1px solid #000 !important;
background: #FFF;
box-shadow: 1.628px 3.255px 4.069px 0px rgba(255, 255, 255, 0.25) inset;
color: #000; color: #000;
font-family: "Sofia Pro Bold";
font-size: 15px;
line-height: normal;
margin-bottom: 10px;
display: flex;
justify-content: center;
align-items: center;
padding: 12px 22px !important;
cursor: pointer;
}
.check-box {
width: 15px;
height: 15px;
}
.check-container {
display: block;
position: relative;
padding-left: 35px;
cursor: pointer;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;
}
.check-container input:checked~.checkmark:after {
display: block;
}
.check-container .checkmark:after {
left: 7px;
top: 0px;
width: 4px;
height: 11px;
border: solid #000;
border-width: 0 2px 2px 0;
transform: rotate(45deg);
}
.checkmark:after {
content: "";
position: absolute;
display: none;
}
.check-container input {
position: absolute;
opacity: 0;
cursor: pointer;
height: 0;
width: 0;
}
.check-container input:checked~.checkmark {
background-color: #FFF;
}
.checkmark {
position: absolute;
top: 0;
left: 0;
height: 20px;
width: 20px;
border: 2px solid #000;
border-radius: 4px;
background: #FFF;
}
.otp-input {
width: 100%;
}
.otp-input input {
width: 45px !important;
height: 45px !important;
margin: 0px 15px 5px 10px;
border-radius: 10px !important;
border: 0.814px solid #000 !important;
background: #FFF !important;
box-shadow: 1.628px 3.255px 4.069px 0px rgba(255, 255, 255, 0.25) inset;
text-align: center; text-align: center;
padding: 0;
}
.resend-otp {
cursor: pointer;
}
.resend-otp p {
color: #0070BD;
} }
.let-discover-carousal a .title{
.signupdiv {
min-height: 95%;
max-height: 95%;
overflow-y: scroll;
scrollbar-width: none;
/* Hide scrollbar for Firefox */
-ms-overflow-style: none;
/* Hide scrollbar for IE and Edge */
border: 1px solid #ccc;
/* Optional: Add a border for visual clarity */
}
.signupdiv::-webkit-scrollbar {
width: 0;
/* Hide scrollbar for WebKit (Chrome, Safari, Opera) */
}
.thankyou-div {
display: flex;
flex-direction: column;
align-items: center;
text-align: center !important;
}
.border-div {
border: 2px solid #E9F6FF;
border-radius: 30px;
padding: 3rem;
margin-bottom: 3rem;
}
/* custome file input for upload user image */
.custom-file-input {
padding: 8px 16px;
cursor: pointer;
background-color: #0070BD;
border: none;
border-radius: 6px;
display: flex;
align-items: center;
justify-content: space-between;
padding: 15px 20px;
width: 80%;
}
.custom-file-input p {
font-family: "Sofia Pro Bold";
font-size: 20px;
font-weight: 700;
line-height: 28px;
letter-spacing: 0em;
color: #fff;
}
/*-------- My Bookings ----------*/
.content-wraaper {
padding: 3rem 3rem 0;
}
.content-wraaper h2 {
color: #000;
font-family: "Sofia Pro Light";
font-size: 28px;
font-weight: 600;
line-height: normal;
margin-bottom: 30px;
}
.username {
font-family: "Sofia Pro Light";
font-size: 21px;
font-weight: 600;
line-height: 24px;
letter-spacing: 0em;
text-align: left;
color: #000;
margin-bottom: 0;
}
.btn-edit {
font-family: "Sofia Pro Light";
font-size: 18px;
font-weight: 600;
line-height: 28px;
letter-spacing: 0em;
text-align: center;
color: #808080;
border: 1px solid #808080;
border-radius: 6px;
padding: .5rem 1rem;
cursor: pointer;
}
.content-wraaper label {
color: #646464;
font-size: 18px;
margin-bottom: 5px;
}
.content-wraaper input {
font-size: 21px;
font-weight: 600;
padding: 16px 22px;
}
.content-wraaper input:read-only {
border: none;
padding: 0;
}
.content-wraaper .contact-number {
border-radius: 0 !important;
border: none;
}
.content-wraaper .contact-number select:read-only {
border-radius: 0 !important;
}
.content-wraaper .contact-number input:read-only {
border-radius: 0 !important;
border-left: 0 !important;
margin-left: 10px;
}
.card-booking {
/* border: 1px solid #D1D1D1; */
border-radius: 25px;
box-shadow: 0px 3.2603139877319336px 15.81252384185791px 0px #0000001A;
margin-bottom: 3rem;
}
.card-booking-img img {
border-radius: 27px 27px 0 0;
}
.card-booking-content {
padding: 1rem; padding: 1rem;
} }
.carousal-c{
.card-booking-content p {
font-family: "Sofia Pro Light";
font-size: 1rem;
font-weight: 500;
line-height: 1.2rem;
letter-spacing: 0em;
text-align: left;
color: #000;
margin-bottom: 0.8rem;
}
.card-booking-content .activity-name {
font-family: "Sofia Pro Light";
font-size: 1.5rem;
font-weight: 600;
line-height: normal;
margin-bottom: 1.2rem;
}
.card-booking-content .status {
color: #808080;
}
.card-booking-content>p:last-child {
margin-bottom: 0;
}
.hr-div {
border: 1px solid #D1D1D1;
margin: 0;
}
.card-booking-footer {
padding: 1.5rem 1rem;
}
.card-booking-img {
position: relative;
}
.card-booking-img .type {
position: absolute;
left: .8rem;
bottom: .8rem;
background: #F7F5F1;
border-radius: 5px;
font-weight: 600;
text-align: center;
padding: .7rem 1.5rem;
margin: 0;
}
.card-booking-content .rating {
border-radius: 4px 4px 4px 0;
background: #002C5F;
color: #FFF;
display: flex;
align-items: center;
padding: 0 .5rem;
margin-right: .8rem;
}
.card-booking-content .description {
color: #808080;
}
.card-booking-content .description>span {
color: #646464;
text-decoration: underline;
}
.card-booking-content .price {
font-size: 1.5rem;
font-weight: 600;
}
.card-booking-content .price>span {
font-size: .8rem;
color: #808080;
}
.card-booking-content .other {
font-size: .8rem;
margin-bottom: 0;
}
.btn-explore {
background: #0070BD;
border-radius: 7px;
padding: .7rem 2rem;
font-weight: 600;
}
.card-booking-img.bgGrey {
background: #F7F5F1;
border-radius: 13px 13px 0 0;
padding: 3rem;
}
.card-booking-content.details-wrapper {
padding: 1rem 1.7rem;
}
.card-booking-content .details {
font-size: 20px;
font-weight: 600;
}
.card-booking-content .details-div {
margin-bottom: 1rem;
}
.card-booking-content .details-div>p:first-child {
font-family: "Sofia Pro Light";
font-size: 14px;
line-height: 20px;
letter-spacing: 0em;
text-align: left;
color: #808080;
margin-bottom: 0;
}
.card-booking-content .details-div>p:last-child {
font-family: "Sofia Pro Light";
font-size: 16px;
line-height: 20px;
letter-spacing: 0em;
text-align: left;
color: #000000;
margin-bottom: 0;
}
/*----- vendor business details -------*/
.content-div {
padding: 2rem 3rem 1rem;
background: #FFFFFF;
border-radius: 8px;
box-shadow: 0px 4px 20px 0px #73737340;
position: relative;
}
.content-div h2 {
font-family: "Sofia Pro Bold";
font-size: 36px;
font-weight: 700;
line-height: 50px;
letter-spacing: 0em;
margin-bottom: 20px;
}
.business-details::before {
content: '';
border-left: 6px solid #0070BD;
position: absolute;
height: 80%;
left: 0;
top: 100px;
bottom: 100px;
}
.helplist {
list-style-type: none;
margin: 0;
padding: 0;
}
.helplist li {
display: flex;
align-items: center;
padding-bottom: 1rem;
margin: 1rem 0;
border-bottom: 1px solid #C9C9C9;
}
.helplist li:last-child {
border-bottom: none;
margin-bottom: 0;
}
.helplist li p {
font-family: "Sofia Pro Light";
font-size: 18px;
line-height: 20px;
letter-spacing: 0em;
text-align: left;
margin-bottom: 0;
margin-left: 1rem;
}
.let-discover-carousal a {
color: #000;
text-align: center;
}
.let-discover-carousal a .title {
padding: 1rem;
}
.carousal-c {
padding: 0 4rem; padding: 0 4rem;
} }
.carousal-c .owl-custom01.owl-carousel .owl-nav button.owl-prev { .carousal-c .owl-custom01.owl-carousel .owl-nav button.owl-prev {
left: calc(-5% + 1px); left: calc(-5% + 1px);
} }
.carousal-c .owl-custom01.owl-carousel .owl-nav button.owl-next { .carousal-c .owl-custom01.owl-carousel .owl-nav button.owl-next {
right: calc(-5% + 1px); right: calc(-5% + 1px);
} }
.browse-experiences-session{
.browse-experiences-session {
background: #F7F5F1; background: #F7F5F1;
padding: 2rem 0; padding: 2rem 0;
} }
.browse-experiences-item{
.browse-experiences-item {
border-radius: 1.6875rem; border-radius: 1.6875rem;
background: #FFF; background: #FFF;
box-shadow: 0px 3.26px 15.813px 0px rgba(0, 0, 0, 0.10); box-shadow: 0px 3.26px 15.813px 0px rgba(0, 0, 0, 0.10);
margin-bottom: 1rem; margin-bottom: 1rem;
} }
.browse-experiences-item .info{
.browse-experiences-item .info {
padding: 1rem; padding: 1rem;
} }
.info .top-name{
.info .top-name {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: space-between; justify-content: space-between;
margin-bottom: 10px; margin-bottom: 10px;
} }
.info .rating-wishlist{
.info .rating-wishlist {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
} }
.info .rating{
.info .rating {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
} }
.browse-experiences-item .img-wrapper{
.browse-experiences-item .img-wrapper {
position: relative; position: relative;
} }
.top-rated{
.top-rated {
position: absolute; position: absolute;
bottom: 10px; bottom: 10px;
left: 10px; left: 10px;
...@@ -561,10 +1259,12 @@ outline: none; ...@@ -561,10 +1259,12 @@ outline: none;
padding: 0.3rem 0.5rem; padding: 0.3rem 0.5rem;
font-size: 13px; font-size: 13px;
} }
.info .top-name .title{
.info .top-name .title {
font-size: 20px; font-size: 20px;
} }
.info .rating-wishlist .rating{
.info .rating-wishlist .rating {
background: #002C5F; background: #002C5F;
border-radius: 4px; border-radius: 4px;
color: #fff; color: #fff;
...@@ -572,139 +1272,167 @@ outline: none; ...@@ -572,139 +1272,167 @@ outline: none;
padding: 0.1rem 0.3rem; padding: 0.1rem 0.3rem;
margin-right: 10px; margin-right: 10px;
} }
.info .rating-wishlist .wishlist .image-container{
.info .rating-wishlist .wishlist .image-container {
width: 19px; width: 19px;
display: block; display: block;
} }
.info .rating-wishlist .rating .image-container{
.info .rating-wishlist .rating .image-container {
width: 14px; width: 14px;
margin-top: -4px; margin-top: -4px;
margin-left: 4px margin-left: 4px
} }
.browse-experiences-item .info .discription{
.browse-experiences-item .info .discription {
font-size: 13px; font-size: 13px;
line-height: 15px; line-height: 15px;
color: #808080; color: #808080;
margin-bottom: 10px; margin-bottom: 10px;
} }
.browse-experiences-item .info .discription a{
.browse-experiences-item .info .discription a {
color: #808080; color: #808080;
text-decoration: underline !important; text-decoration: underline !important;
} }
.browse-experiences-item .info .price{
.browse-experiences-item .info .price {
font-size: 20px; font-size: 20px;
line-height: 20px; line-height: 20px;
font-weight: 600; font-weight: 600;
margin-bottom: 10px; margin-bottom: 10px;
} }
.browse-experiences-item .info .price .off{
.browse-experiences-item .info .price .off {
font-size: 11px; font-size: 11px;
line-height: 11px; line-height: 11px;
color: #808080; color: #808080;
} }
.browse-experiences-item .info .detail{
.browse-experiences-item .info .detail {
font-size: 11px; font-size: 11px;
line-height: 11px; line-height: 11px;
margin-bottom: 10px; margin-bottom: 10px;
} }
.btn-outline-secondary{
.btn-outline-secondary {
border: 1px solid #000; border: 1px solid #000;
font-size: 16px; font-size: 16px;
color: #000; color: #000;
padding-left: 1rem; padding-left: 1rem;
padding-right: 1rem; padding-right: 1rem;
} }
.btn-center{
.btn-center {
text-align: center; text-align: center;
padding: 2rem 0; padding: 2rem 0;
} }
.gift-an-experience-inner{
.gift-an-experience-inner {
background: url(/images/gift-experience-bg.png) no-repeat; background: url(/images/gift-experience-bg.png) no-repeat;
margin: 5rem 0 0; margin: 5rem 0 0;
background-size: 100%; background-size: 100%;
object-fit: cover; object-fit: cover;
padding: 4rem; padding: 4rem;
} }
.gift-an-experience-inner .content .title{
.gift-an-experience-inner .content .title {
font-size: 40px; font-size: 40px;
line-height: 40px; line-height: 40px;
margin-bottom: 1rem; margin-bottom: 1rem;
} }
.gift-an-experience-inner .content .disc{
.gift-an-experience-inner .content .disc {
margin-bottom: 1rem; margin-bottom: 1rem;
} }
.testimonial-session{
.testimonial-session {
background: #F4F4F4; background: #F4F4F4;
padding: 5rem 0; padding: 5rem 0;
} }
.testimonial-item{
.testimonial-item {
text-align: center; text-align: center;
padding: 0 15rem; padding: 0 15rem;
} }
.testimonial-item .img{
.testimonial-item .img {
width: 144px; width: 144px;
height: 144px; height: 144px;
margin: 0 auto; margin: 0 auto;
} }
.testimonial-item .rating{
.testimonial-item .rating {
padding: 0.5rem 0; padding: 0.5rem 0;
} }
.testimonial-item .rating .fa-star:before { .testimonial-item .rating .fa-star:before {
content: "\f005"; content: "\f005";
color: #FFD600; color: #FFD600;
} }
.testimonial-item .rating a{
.testimonial-item .rating a {
width: 33px; width: 33px;
height: 33px; height: 33px;
display: inline-block; display: inline-block;
margin: 4px; margin: 4px;
} }
.testimonial-item .name{
.testimonial-item .name {
font-size: 24px; font-size: 24px;
line-height: 24px; line-height: 24px;
margin-top: 1rem; margin-top: 1rem;
} }
.signUp-to-experience-our-platform-session{
.signUp-to-experience-our-platform-session {
background: url(../public/images/sign-up-exp-bg.png) no-repeat; background: url(../public/images/sign-up-exp-bg.png) no-repeat;
background-size: 100%; background-size: 100%;
object-fit: cover; object-fit: cover;
padding: 4rem; padding: 4rem;
color: #fff; color: #fff;
} }
.signUp-to-experience-our-platform{
.signUp-to-experience-our-platform {
text-align: center; text-align: center;
} }
.signUp-to-experience-our-platform .title{
.signUp-to-experience-our-platform .title {
font-size: 40px; font-size: 40px;
line-height: 40px; line-height: 40px;
margin-bottom: 1rem; margin-bottom: 1rem;
} }
.signUp-to-experience-our-platform .disc{
.signUp-to-experience-our-platform .disc {
margin-bottom: 1rem; margin-bottom: 1rem;
} }
footer{
footer {
background: #020D1A; background: #020D1A;
padding: 3rem 0; padding: 3rem 0;
color: #fff; color: #fff;
} }
footer .footer-logo{
footer .footer-logo {
width: 133px; width: 133px;
margin-bottom: 10px; margin-bottom: 10px;
} }
.footer-link h3{
.footer-link h3 {
font-size: 24px; font-size: 24px;
line-height: 24px; line-height: 24px;
font-weight: 700; font-weight: 700;
text-transform: uppercase; text-transform: uppercase;
margin-bottom: 0.5rem; margin-bottom: 0.5rem;
} }
.footer-link ul li a{
.footer-link ul li a {
font-size: 15px; font-size: 15px;
line-height: 15px; line-height: 15px;
color: #fff; color: #fff;
padding: 0.4rem 0; padding: 0.4rem 0;
display: block; display: block;
} }
footer .icon-text .image-container { footer .icon-text .image-container {
width: 20px; width: 20px;
display: block; display: block;
...@@ -726,16 +1454,19 @@ footer .icon-text .text { ...@@ -726,16 +1454,19 @@ footer .icon-text .text {
footer .icon-text .text a { footer .icon-text .text a {
color: #fff color: #fff
} }
footer .social-icon a{
footer .social-icon a {
width: 32px; width: 32px;
height: 33px; height: 33px;
display: inline-block; display: inline-block;
margin-right: 0.5rem; margin-right: 0.5rem;
} }
footer .subscribe{
footer .subscribe {
padding: 1rem 0 0; padding: 1rem 0 0;
} }
footer .subscribe input{
footer .subscribe input {
border: 1px solid #fff; border: 1px solid #fff;
border-radius: 5px; border-radius: 5px;
background: transparent; background: transparent;
...@@ -745,11 +1476,13 @@ footer .subscribe input{ ...@@ -745,11 +1476,13 @@ footer .subscribe input{
color: #fff; color: #fff;
margin-right: 0.5rem; margin-right: 0.5rem;
} }
footer hr{
footer hr {
margin: 2.5rem 0; margin: 2.5rem 0;
opacity: inherit; opacity: inherit;
} }
.copyright{
.copyright {
background: #000; background: #000;
color: #fff; color: #fff;
font-size: 16px; font-size: 16px;
...@@ -758,27 +1491,19 @@ footer hr{ ...@@ -758,27 +1491,19 @@ footer hr{
} }
.box-01{ .box-01{
border-radius: 17px; border-radius: 17px;
border: 2px solid #D1D1D1; border: 1px solid #D1D1D1;
margin-bottom: 1rem;
}
.box-01 .p-all{
padding: 1rem;
} }
.box-01 .head{ .box-01 .head{
font-size: 20px; font-size: 20px;
line-height: 20px; line-height: 20px;
/* padding: 1rem; */ padding: 1rem;
}
.box-01 .reset a{
display: flex;
align-items: center;
} }
.box-01 .reset .image-container{ .box-01 .reset .image-container{
width: 22px; width: 22px;
display: inline-block; display: inline-block;
margin-left: 5px;
} }
.box-01 .reset a{
.box-01 .reset a {
color: #0070BD; color: #0070BD;
} }
.box-01 .inner{ .box-01 .inner{
...@@ -963,23 +1688,25 @@ footer hr{ ...@@ -963,23 +1688,25 @@ footer hr{
} }
@media (min-width: 992px) @media (min-width: 992px) {
{ .navbar-expand-lg .navbar-nav .nav-link {
.navbar-expand-lg .navbar-nav .nav-link{
margin: 0 2rem; margin: 0 2rem;
} }
.navbar-expand-lg .navbar-collapse { .navbar-expand-lg .navbar-collapse {
display: flex!important; display: flex !important;
flex-basis: auto; flex-basis: auto;
align-items: center; align-items: center;
justify-content: flex-end; justify-content: flex-end;
} }
.navbar-expand-lg .navbar-nav .nav-link.gift-card{
.navbar-expand-lg .navbar-nav .nav-link.gift-card {
display: flex; display: flex;
align-items: center; align-items: center;
position: relative; position: relative;
} }
.navbar-expand-lg .navbar-nav .nav-link.gift-card::after{
.navbar-expand-lg .navbar-nav .nav-link.gift-card::after {
content: ''; content: '';
background: #000; background: #000;
height: 2px; height: 2px;
...@@ -988,42 +1715,14 @@ footer hr{ ...@@ -988,42 +1715,14 @@ footer hr{
left: 0; left: 0;
position: absolute; position: absolute;
} }
.navbar-expand-lg .navbar-nav .nav-link.gift-card .image-container{
.navbar-expand-lg .navbar-nav .nav-link.gift-card .image-container {
width: 21px; width: 21px;
margin-left: 10px; margin-left: 10px;
} }
} }
@media (max-width: 767px) {
@keyframes slide-left { @media (max-width: 767px) {
0% {
max-width: 0px;
opacity: 0;
}
100% {
max-width: 100%;
opacity: 1;
}
}
.first-block-content {
animation-duration: 0.5s;
animation-name: slide-left;
animation-timing-function: ease-in-out;
animation-iteration-count: 1;
animation-fill-mode: forwards;
}
.filter-dd {
justify-content: space-between;
}
.filter-view{
display: block;
}
.grid-view{
display: none;
}
.browse-experiences-item .img-wrapper {
height: 235px;
}
footer .subscribe input { footer .subscribe input {
width: 67%; width: 67%;
} }
......
This diff could not be displayed because it is too large.
Styling with Markdown is supported
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!