Skip to content

Commit

Permalink
Resolved conflicts from main
Browse files Browse the repository at this point in the history
  • Loading branch information
abhishek-01k committed Mar 6, 2024
2 parents fc062c7 + b5f4076 commit 561f126
Show file tree
Hide file tree
Showing 14 changed files with 703 additions and 434 deletions.
6 changes: 3 additions & 3 deletions src/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -347,7 +347,7 @@ const HeaderContainer = styled.header`
width: 100%;
position: fixed;
top: 0;
z-index: 99999;
z-index: 999;
`;

const ParentContainer = styled.div`
Expand All @@ -370,8 +370,8 @@ const LeftBarContainer = styled.div`
top: 0;
bottom: 0;
width: ${(props) => props.leftBarWidth}px;
// position: fixed;
position: absolute;
position: fixed;
// position: absolute;
@media (max-width: 992px) {
display: none;
Expand Down
181 changes: 181 additions & 0 deletions src/components/PushSnap/EnableSnoozeModal.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,181 @@
// React + Web3 Essentials
import React, { useState } from 'react';

// External Packages
import styled, { useTheme } from 'styled-components';

// Internal Compoonents
import { ItemHV2, ItemVV2, ButtonV2 } from 'components/reusables/SharedStylingV2';

// Internal Configs
import { device } from 'config/Globals';
import { AppContext } from 'contexts/AppContext';
import { SnoozeDurationType } from 'types';
import { updateSnoozeDuration } from 'helpers';
import { defaultSnapOrigin } from 'config';

const EnableSnoozeModal = ({
setSnoozeDuration
}:
{setSnoozeDuration: (snoozeDuration: SnoozeDurationType) => void}
) => {
const { setSnapState } = React.useContext(AppContext);
const theme = useTheme();

const [snoozeDurationInput, setSnoozeDurationInput] = useState<number>(1);

const handleChange = async () => {
const duration = snoozeDurationInput;

if (duration >= 1 && duration <= 72) {
await window.ethereum?.request({
method: 'wallet_invokeSnap',
params: {
snapId: defaultSnapOrigin,
request: {
method: 'pushproto_setsnoozeduration',
params: { snoozeDuration: snoozeDurationInput.toString()},
},
},
})

setSnapState(3);
} else {
// Display an error message if the input is invalid
console.error('Invalid input. Please enter a number between 1 and 72.');
}
await updateSnoozeDuration(setSnoozeDuration);
};

const handleCancel = async () => {
setSnapState(3); // go back to step one
};

return (
<Container>
<ItemHV2
alignItems="baseline"
margin="24px 0 0 0"
padding="0 9px 0 0"
Gap="8px"
justifyContent="flex-start"
>
<PrimaryText>Set Snooze Duration</PrimaryText>
<SecondaryText>
How long would you like to snooze notifications? You can snooze for 1 to 72 hours.
</SecondaryText>
<Input
type="number"
min="1"
max="72"
value={snoozeDurationInput}
onChange={(e) => {
const duration = parseInt(e.target.value);
if (!isNaN(duration) && duration >= 1 && duration <= 72) {
setSnoozeDurationInput(duration);
}
}}
placeholder="Snooze duration in Hours (e.g. 6)"
/>

</ItemHV2>

<ItemHV2
margin="24px 0 0 0"
>
<EnptyButton onClick={handleCancel}>Cancel </EnptyButton>

<FilledButton onClick={handleChange}> Enable Snooze </FilledButton>
</ItemHV2>
</Container>
);
};

export default EnableSnoozeModal;

const Container = styled(ItemVV2)`
padding: 0px 0px 12px 9px;
`;

const PrimaryText = styled.p`
margin: 0px;
font-size: 18px;
font-weight: 500;
align-self: baseline;
color: ${(props) => props.theme.modalMessageColor};
`;

const SecondaryText = styled.p`
margin: 0px;
font-size: 12px;
font-weight: 400;
line-height: 24px;
text-align: left;
overflow: hidden;
text-overflow: ellipsis; // Show ellipsis (...) when text overflows
color: ${(props) => props.theme.snapSecondaryText};
`;

const SnapButton = styled(ButtonV2)`
align-self: end;
height: 36px;
z-index: 0;
font-family: 'Strawford';
font-style: normal;
font-weight: 500;
font-size: 14px;
line-height: normal;
border-radius: 8px;
`;

const FilledButton = styled(SnapButton)`
min-width: 79px;
padding: 14px;
background: #d53a94;
height: 48px;
radius: 12px;
padding: 0px 24px 0px 24px;
color: #fff;
white-space: nowrap;
`;

const EnptyButton = styled(SnapButton)`
flex-direction: row;
text-align: center;
height: 48px;
padding: 0px 24px 0px 24px;
margin-right: 8px;
border: 1px solid #bac4d6;
color: ${(props) => props.theme.default.color};
background: ${(props) => props.theme.default.bg};
gap: 4px;
`;

const Input = styled.input`
box-sizing: border-box;
display: flex;
flex: 1;
width: 240px;
height: 48px;
padding: 13px 16px 13px 16px;
margin: 10px 3px 0px;
background: ${(props) => props.theme.modalSearchBarBackground};
border-radius: 12px;
border: 1px solid #bac4d6;
color: ${(props) => props.theme.default.secondaryColor || '#000'};
&:focus {
outline: none;
background-origin: border;
border: 1px solid #bac4d6 !important;
background-clip: padding-box, border-box;
}
&::placeholder {
color: ${(props) => props.theme.default.secondaryColor || '#000'};
}
@media ${device.mobileL} {
min-width: 300px;
}
`;
Loading

0 comments on commit 561f126

Please sign in to comment.