Skip to content

Commit

Permalink
Merge pull request layer5io#531 from captain-Akshay/dynamicFeedback
Browse files Browse the repository at this point in the history
Dynamic feedback
  • Loading branch information
aabidsofi19 authored Mar 4, 2024
2 parents 1fb6018 + c46f7a8 commit 6797248
Show file tree
Hide file tree
Showing 4 changed files with 238 additions and 102 deletions.
12 changes: 12 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,18 @@ format-fix:
npm run format:write
```

To test the sistent component locally, you can run

```
build:
npm run build
```

```
attach sistent to your project:
npm install [path to sistent repo ]
```

> [!NOTE]
> Avoid using `type any` in your code. Always specify explicit types to ensure type safety and maintainability.
Expand Down
2 changes: 1 addition & 1 deletion src/custom/CustomTooltip/customTooltip.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import React from 'react';
import { CHARCOAL, WHITE } from '../../theme';

type CustomTooltipProps = {
title: string | React.ReactNode;
title: string | React.ReactNode | JSX.Element;
onClick?: (event: React.MouseEvent<HTMLElement>) => void;
children: React.ReactNode;
} & Omit<TooltipProps, 'title' | 'onClick'>;
Expand Down
195 changes: 103 additions & 92 deletions src/custom/Feedback/FeedbackButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -100,12 +100,20 @@ interface FeedbackComponentProps {
onSubmit: (data: { label: string; message: string }) => void;
containerStyles?: CSSProperties;
feedbackOptionStyles?: CSSProperties;
renderPosition:
| 'bottom-center'
| 'bottom-right'
| 'bottom-left'
| 'right-top'
| 'right-middle'
| 'right-bottom';
}

const FeedbackComponent: React.FC<FeedbackComponentProps> = ({
onSubmit,
containerStyles,
feedbackOptionStyles
feedbackOptionStyles,
renderPosition
}) => {
const [isOpen, setIsOpen] = useState<boolean>(false);
const [submitted, setSubmitted] = useState<boolean>(false);
Expand Down Expand Up @@ -139,98 +147,101 @@ const FeedbackComponent: React.FC<FeedbackComponentProps> = ({
};

return (
<Container isOpen={isOpen} style={containerStyles}>
{submitted ? (
<FeedbackMessage isOpen={isOpen}>
<SuccessIcon width={'32'} height={'32'} />
We got your concern. Thank you!
</FeedbackMessage>
) : (
<>
<FeedbackButton onClick={handleFeedback}>Feedback</FeedbackButton>

<ModalCard
onClose={() => {}}
open={true}
closeComponent={
<CloseButton onClick={() => setIsOpen(false)}>
<CloseIcon width={'30'} height={'30'} fill={CULTURED} />
</CloseButton>
}
actions={
<div
style={{
display: 'flex',
alignItems: 'center'
}}
>
<ActionWrapper>
<StyledCheckbox checked={isChecked} onChange={handleCheckboxChange} />
<Typography style={{ color: 'white', fontSize: '12px', height: '15px' }}>
We may email you for more information or updates
</Typography>
</ActionWrapper>
<FeedbackSubmitButton
type="submit"
disabled={!(messageValue && isChecked)}
isOpen={!(messageValue && isChecked)}
onClick={handleSubmit}
<>
<FeedbackButton onClick={handleFeedback} renderPosition={renderPosition}>
Feedback
</FeedbackButton>
<Container isOpen={isOpen} style={containerStyles} renderPosition={renderPosition}>
{submitted ? (
<FeedbackMessage isOpen={isOpen}>
<SuccessIcon width={'32'} height={'32'} />
We got your concern. Thank you!
</FeedbackMessage>
) : (
<>
<ModalCard
onClose={() => {}}
open={true}
closeComponent={
<CloseButton onClick={() => setIsOpen(false)}>
<CloseIcon width={'30'} height={'30'} fill={CULTURED} />
</CloseButton>
}
actions={
<div
style={{
display: 'flex',
alignItems: 'center'
}}
>
Send
</FeedbackSubmitButton>
</div>
}
leftHeaderIcon={<FeedbackIcon />}
title="Feedback"
helpArea={
<CustomTooltip placement="top" title={tooltipContent} arrow>
<HelperWrapper>
<QuestionIcon width={'30'} height={'30'} />
</HelperWrapper>
</CustomTooltip>
}
helpText={'Help'}
content={
<FeedbackForm>
<FeedbackOptions>
{feedbackData?.map((item) => (
<FeedbackOptionButton
key={item.label}
style={feedbackOptionStyles}
type="button"
onClick={() => {
setCategory(item);
}}
isOpen={category?.label === item.label}
>
<FeedbackMiniIcon>{item.icon}</FeedbackMiniIcon>
<Typography>{item.label}</Typography>
</FeedbackOptionButton>
))}
</FeedbackOptions>
{category?.isTextInput ? (
<FeedbackTextArea>
<StyledTextArea
value={messageValue || ''}
onChange={(e) => {
setMessageValue(e.target.value);
}}
ref={feedbackTextRef}
required
placeholder={category.placeholder}
rows={5}
cols={30}
/>
</FeedbackTextArea>
) : (
<InnerComponentWrapper>{category?.innerComponent}</InnerComponentWrapper>
)}
</FeedbackForm>
}
></ModalCard>
</>
)}
</Container>
<ActionWrapper>
<StyledCheckbox checked={isChecked} onChange={handleCheckboxChange} />
<Typography style={{ color: 'white', fontSize: '12px', height: '15px' }}>
We may email you for more information or updates
</Typography>
</ActionWrapper>
<FeedbackSubmitButton
type="submit"
disabled={!(messageValue && isChecked)}
isOpen={!(messageValue && isChecked)}
onClick={handleSubmit}
>
Send
</FeedbackSubmitButton>
</div>
}
leftHeaderIcon={<FeedbackIcon />}
title="Feedback"
helpArea={
<CustomTooltip placement="top" title={tooltipContent} arrow>
<HelperWrapper>
<QuestionIcon width={'30'} height={'30'} />
</HelperWrapper>
</CustomTooltip>
}
helpText={'Help'}
content={
<FeedbackForm>
<FeedbackOptions>
{feedbackData?.map((item) => (
<FeedbackOptionButton
key={item.label}
style={feedbackOptionStyles}
type="button"
onClick={() => {
setCategory(item);
}}
isOpen={category?.label === item.label}
>
<FeedbackMiniIcon>{item.icon}</FeedbackMiniIcon>
<Typography>{item.label}</Typography>
</FeedbackOptionButton>
))}
</FeedbackOptions>
{category?.isTextInput ? (
<FeedbackTextArea>
<StyledTextArea
value={messageValue || ''}
onChange={(e) => {
setMessageValue(e.target.value);
}}
ref={feedbackTextRef}
required
placeholder={category.placeholder}
rows={5}
cols={30}
/>
</FeedbackTextArea>
) : (
<InnerComponentWrapper>{category?.innerComponent}</InnerComponentWrapper>
)}
</FeedbackForm>
}
></ModalCard>
</>
)}
</Container>
</>
);
};

Expand Down
Loading

0 comments on commit 6797248

Please sign in to comment.