generated from microverseinc/readme-template
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'profile' of https://github.com/ridabensalem/tour-trek i…
…nto profile test
- Loading branch information
Showing
6 changed files
with
908 additions
and
66 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,37 +1,169 @@ | ||
import React from 'react'; | ||
'use client' | ||
import { useState } from 'react'; | ||
import ProfileFrameElement from './profileFrame'; | ||
|
||
const Security = () => { | ||
return ( | ||
<ProfileFrameElement text="Security"> | ||
<div className="mx-auto px-8 bg-white"> | ||
<p className="text-black mb-4 pl-6"> | ||
Manage your security settings, set up secure authentication, or delete your account. | ||
</p> | ||
<div className="mb-6"> | ||
<div className="flex justify-between items-center mb-2"> | ||
<label className="text-gray-400 font-semibold">Password</label> | ||
<button className="bg-pink-500 text-white py-1 px-3 rounded">Reset</button> | ||
</div> | ||
<p className="text-zinc-500 text-sm mb-4 border-b-2 border-gray-300">Last updated on 1 day ago</p> | ||
<input type="password" placeholder="Current Password" className="w-full mb-2 p-2 border border-zinc-300 dark:border-zinc-700 rounded" /> | ||
<input type="password" placeholder="New Password" className="w-full mb-2 p-2 border border-zinc-300 dark:border-zinc-700 rounded" /> | ||
<input type="password" placeholder="Confirm New Password" className="w-full mb-2 p-2 border border-zinc-300 dark:border-zinc-700 rounded" /> | ||
</div> | ||
<div className="mb-6"> | ||
<div className="flex justify-between items-center mb-2"> | ||
<label className="text-zinc-900 font-semibold">Recovery Phone</label> | ||
<button className="bg-pink-500 text-white py-1 px-3 rounded">Add</button> | ||
|
||
const Security = () => { | ||
const [showPasswordInputs, setShowPasswordInputs] = useState(false); | ||
const [showRecoveryInput, setShowRecoveryInput] = useState(false); | ||
const [showDeleteAccountForm, setShowDeleteAccountForm] = useState(false); | ||
const [showFeedbackTextarea, setShowFeedbackTextarea] = useState(false); | ||
|
||
const togglePasswordInputs = () => { | ||
setShowPasswordInputs(prevState => !prevState); | ||
}; | ||
|
||
const toggleRecoveryInput = () => { | ||
setShowRecoveryInput(prevState => !prevState); | ||
}; | ||
|
||
const toggleDeleteAccountForm = () => { | ||
setShowDeleteAccountForm(prevState => !prevState); | ||
}; | ||
|
||
const handleContinue = (event: React.FormEvent<HTMLFormElement>) => { | ||
event.preventDefault(); | ||
setShowFeedbackTextarea(true); | ||
}; | ||
|
||
const handleBack = () => { | ||
setShowFeedbackTextarea(false); | ||
}; | ||
|
||
return ( | ||
<ProfileFrameElement text="Security"> | ||
|
||
<div className="py-2 w-full mx-auto bg-white space-y-6 mb-4 px-6"> | ||
<p className="text-base font-bold"> | ||
Manage your security settings, set up secure authentication, or delete your account. | ||
</p> | ||
|
||
<div className="space-y-2"> | ||
<div className="flex justify-between items-center"> | ||
<div> | ||
<h2 className="text-lg font-semibold mt-4">Password</h2> | ||
<p className="text-base text-zinc-500 dark:text-zinc-400 border-b-2 w-[360px]">Last updated on 1 day ago</p> | ||
</div> | ||
<button | ||
onClick={togglePasswordInputs} | ||
className="bg-pink-500 text-white px-4 py-2 rounded-md relative top-2 w-[70px]" | ||
> | ||
{showPasswordInputs ? 'Hide' : 'Reset'} | ||
</button> | ||
</div> | ||
|
||
{showPasswordInputs && ( | ||
<div className="space-y-2 w-[350px] mx-auto"> | ||
<input | ||
type="password" | ||
placeholder="Current Password" | ||
className="w-full px-4 py-2 border border-zinc-300 dark:border-zinc-600 rounded-md focus:border-pink-500 focus:outline-none" | ||
/> | ||
<input | ||
type="password" | ||
placeholder="New Password" | ||
className="w-full px-4 py-2 border border-zinc-300 dark:border-zinc-600 rounded-md focus:border-pink-500 focus:outline-none" | ||
/> | ||
<input | ||
type="password" | ||
placeholder="Confirm New Password" | ||
className="w-full px-4 py-2 border border-zinc-300 dark:border-zinc-600 rounded-md focus:border-pink-500 focus:outline-none" | ||
/> | ||
<button | ||
className="bg-[#162448] text-white px-4 py-2 rounded-md relative top-2" | ||
> | ||
Update password | ||
</button> | ||
</div> | ||
)} | ||
</div> | ||
|
||
<div className="space-y-2 mt-2"> | ||
<div className="flex justify-between items-center"> | ||
<div > | ||
<h2 className="text-lg font-semibold">Recovery Email</h2> | ||
<p className="text-base text-zinc-500 dark:text-zinc-400 border-b-2 w-[360px]">example@gmail.com</p> | ||
</div> | ||
<button | ||
onClick={toggleRecoveryInput} | ||
className="bg-pink-500 text-white px-4 py-2 rounded-md w-[70px]" | ||
> | ||
{showRecoveryInput ? 'Hide' : 'Add'} | ||
</button> | ||
</div> | ||
|
||
{showRecoveryInput && ( | ||
<div className="space-y-2 w-[350px] mx-auto"> | ||
<input | ||
type="text" | ||
placeholder="example@gmail.com" | ||
className="w-full px-4 py-2 border border-zinc-300 dark:border-zinc-600 rounded-md focus:border-pink-500 focus:outline-none" | ||
/> | ||
<button | ||
className="bg-[#2C63EB] text-white px-4 py-2 rounded-md " | ||
> | ||
Add | ||
</button> | ||
</div> | ||
)} | ||
</div> | ||
|
||
<div className="space-y-2 mt-2"> | ||
<div> | ||
<h2 className="text-lg font-semibold">Delete Account</h2> | ||
<p className="text-base text-zinc-500 dark:text-zinc-400 border-b-2 w-[358px]"> | ||
Permanently delete your tourTrek.com account | ||
<button | ||
onClick={toggleDeleteAccountForm} | ||
className="ml-2" | ||
> | ||
{showDeleteAccountForm ? '▼' : '▶'} | ||
</button> | ||
</p> | ||
</div> | ||
|
||
{showDeleteAccountForm && !showFeedbackTextarea && ( | ||
<div className="border-2 border-zinc-200 p-4 rounded-md"> | ||
<div className="flex items-center justify-between"> | ||
<p className="text-lg">Why do you want to delete your account?</p> | ||
</div> | ||
<form className="mt-4" onSubmit={handleContinue}> | ||
<div className="flex items-center mb-2"> | ||
<input id="option1" type="radio" name="reason" className="text-blue-600" /> | ||
<label className="ml-2 text-zinc-700">I get too many emails from TourTrek.com</label> | ||
</div> | ||
<div className="flex items-center mb-2"> | ||
<input id="option2" type="radio" name="reason" className="text-blue-600" /> | ||
<label className="ml-2 text-zinc-700">Privacy concerns</label> | ||
</div> | ||
<div className="flex items-center mb-4"> | ||
<input id="option3" type="radio" name="reason" className="text-blue-600" /> | ||
<label className="ml-2 text-zinc-700">I want to remove all my data</label> | ||
</div> | ||
<button type="submit" className="bg-blue-600 text-white px-4 py-2 rounded-md hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-opacity-50 relative left-[400px]">Continue</button> | ||
</form> | ||
</div> | ||
)} | ||
|
||
{showFeedbackTextarea && ( | ||
<div> | ||
<button onClick={handleBack} className="text-pink-500 mb-2 relative right-0">← Back</button> | ||
<div className="rounded-md flex flex-col items-end"> | ||
<textarea | ||
name="textarea" | ||
minLength={10} | ||
maxLength={30} | ||
className="w-full h-32 px-4 py-2 border border-zinc-300 dark:border-zinc-600 rounded-md focus:border-pink-500 focus:outline-none" | ||
placeholder="Do you have any feedback you'd like to share before you go? We'll use it to fix problems and improve our services..." | ||
/> | ||
<button type="submit" className="bg-blue-600 text-white px-4 py-2 rounded-md hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-opacity-50 mt-2">Delete your account</button> | ||
</div> | ||
</div> | ||
)} | ||
</div> | ||
</div> | ||
<p className="text-zinc-500 text-sm mb-4 border-b-2">example@gmail.com</p> | ||
</div> | ||
<div> | ||
<label className="text-zinc-900 font-semibold">Delete Account</label> | ||
<p className="text-zinc-500 text-sm mb-4 border-b-2 border-gray-300">Permanently delete your tourTrek.com account</p> | ||
</div> | ||
</div> | ||
</ProfileFrameElement> | ||
); | ||
}; | ||
</ProfileFrameElement> | ||
); | ||
}; | ||
|
||
export default Security; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.