-
Notifications
You must be signed in to change notification settings - Fork 69
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #956 from Amberroseweeks/amberroseweeks-917-data-d…
…isclaimer amberroseweeks-917-data-disclaimer
- Loading branch information
Showing
2 changed files
with
82 additions
and
0 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
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 |
---|---|---|
@@ -0,0 +1,79 @@ | ||
import { | ||
Modal, | ||
ModalContent, | ||
ModalHeader, | ||
ModalBody, | ||
ModalFooter, | ||
useDisclosure, | ||
} from '@nextui-org/react'; | ||
import { ThemeButton } from './ThemeButton'; | ||
import { PiX } from 'react-icons/pi'; | ||
import { useEffect, useState } from 'react'; | ||
|
||
export default function DataDisclaimerModal() { | ||
const { isOpen, onOpen, onClose } = useDisclosure(); | ||
const [isClientSide, setIsClientSide] = useState(false); | ||
|
||
// Use useEffect to check if modal has been shown and open it if not | ||
useEffect(() => { | ||
setIsClientSide(true); // Ensure client-side rendering | ||
|
||
const hasSeenModal = localStorage.getItem('hasSeenModal'); // Check localStorage | ||
|
||
if (!hasSeenModal) { | ||
onOpen(); // Open modal if not seen before | ||
} | ||
}, [onOpen]); | ||
|
||
const closeHandler = () => { | ||
localStorage.setItem('hasSeenModal', 'true'); // Set flag so modal doesn't show again | ||
onClose(); // Close modal | ||
}; | ||
|
||
if (!isClientSide) return null; | ||
|
||
return ( | ||
<> | ||
<Modal | ||
isOpen={isOpen} | ||
onOpenChange={onClose} | ||
size={'3xl'} | ||
hideCloseButton={true} | ||
className="items-center" | ||
> | ||
<ModalContent> | ||
<ModalHeader className="flex flex-col gap-1 text-green-600 text-4xl text-center"> | ||
<h2>Disclaimer</h2> | ||
<ThemeButton | ||
color="tertiary" | ||
className="right-4 lg:right-[24px] absolute top-4 min-w-[3rem]" | ||
aria-label="Close" | ||
startContent={<PiX />} | ||
onPress={closeHandler} // Close modal and set flag | ||
/> | ||
</ModalHeader> | ||
|
||
<ModalBody className="p-10"> | ||
<p> | ||
The City of Philadelphia recently stopped collecting key | ||
information used in determining which properties in the city are | ||
likely vacant. We are currently in conversations with relevant | ||
partners about how to address this challenge. In the meantime, | ||
please be advised that the vacancy data that we are showing here | ||
have not been updated since July of 2024. | ||
</p> | ||
</ModalBody> | ||
<ModalFooter> | ||
<ThemeButton | ||
color="primary" | ||
className="" | ||
aria-label="Close" | ||
label="I understand" | ||
onPress={closeHandler} // Close modal and set flag | ||
/> | ||
</ModalFooter> | ||
</ModalContent> | ||
</Modal> | ||
</> | ||
); | ||
} |