Skip to content

Commit

Permalink
fix: passing unknown props to DOM
Browse files Browse the repository at this point in the history
  • Loading branch information
joonatank committed Jan 20, 2025
1 parent 8bb47f9 commit f15ff74
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 32 deletions.
5 changes: 1 addition & 4 deletions apps/ui/components/common/PageWrapper.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,10 +35,7 @@ function PageWrapper({
<meta name="version" content={version} />
</Head>
<Navigation apiBaseUrl={apiBaseUrl} profileLink={profileLink} />
<BannerNotificationsList
centered
target={BannerNotificationTarget.User}
/>
<BannerNotificationsList target={BannerNotificationTarget.User} />
<InProgressReservationNotification />
<Main id="main">{children}</Main>
<Footer feedbackUrl={feedbackUrl} />
Expand Down
10 changes: 2 additions & 8 deletions packages/common/src/components/BannerNotificationsList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,12 @@ import { filterNonNullable } from "../helpers";
type BannerNotificationListProps = {
target: BannerNotificationTarget;
displayAmount?: number;
centered?: boolean;
};

type BannerNotificationItemProps = {
type NotificationsListItemProps = {
notification: BannerNotificationCommonFragment;
closeFn: React.Dispatch<React.SetStateAction<string[] | undefined>>;
closedArray: string[];
centered?: boolean;
};

const PositionWrapper = styled.div`
Expand Down Expand Up @@ -63,8 +61,7 @@ function NotificationsListItem({
notification,
closeFn,
closedArray,
centered,
}: BannerNotificationItemProps) {
}: NotificationsListItemProps) {
let notificationType: NotificationType;
switch (notification.level) {
case "EXCEPTION":
Expand All @@ -80,7 +77,6 @@ function NotificationsListItem({
<BannerNotificationBackground>
<NotificationWrapper
type={notificationType}
centered={centered}
dismissible
closeButtonLabelText={t("common:close")}
data-testid="BannerNotificationList__Notitification"
Expand Down Expand Up @@ -115,7 +111,6 @@ function NotificationsListItem({
const BannerNotificationsList = ({
target,
displayAmount = 2,
centered,
}: BannerNotificationListProps) => {
// no-cache is required because admin is caching bannerNotifications query and
// there is no key setup for this so this query returns garbage from the admin cache.
Expand Down Expand Up @@ -174,7 +169,6 @@ const BannerNotificationsList = ({
notification={notification}
closedArray={closedNotificationsList ?? []}
closeFn={setClosedNotificationsList}
centered={centered}
/>
))}
</PositionWrapper>
Expand Down
34 changes: 14 additions & 20 deletions packages/common/src/components/NotificationWrapper.tsx
Original file line number Diff line number Diff line change
@@ -1,41 +1,35 @@
import React from "react";
import React, { useState } from "react";
import styled from "styled-components";
import { Notification, NotificationProps } from "hds-react";
import { breakpoints } from "../common/style";

type NotificationPropsWithCentering = NotificationProps & {
centered?: boolean;
"data-testid"?: string;
};

const Wrapper = styled.div<{ $centerContent?: boolean }>`
> section > div {
max-width: calc(${breakpoints.xl} - (2 * var(--spacing-m)));
margin: 0 ${(props) => (props.$centerContent ? "auto" : "0")} !important;
const StyledNotification = styled(Notification)<{ $centerContent?: boolean }>`
> div {
max-width: var(--tilavaraus-page-max-width);
margin: 0 ${(props) => (props.$centerContent ? "auto" : "0")};
}
`;

function NotificationWrapper(
props: NotificationPropsWithCentering
): JSX.Element | null {
const [isVisible, setIsVisible] = React.useState(true);
const [isVisible, setIsVisible] = useState(true);

// data-testid passed to the HDS component is not passed to the DOM
// pass it to the div wrapper instead
const testId = props["data-testid"];
if (!isVisible) {
return null;
}
return (
<Wrapper $centerContent={props.centered} data-testid={testId}>
<Notification
{...props}
onClose={() => {
setIsVisible(false);
props.onClose?.();
}}
/>
</Wrapper>
<StyledNotification
{...props}
$centerContent
onClose={() => {
setIsVisible(false);
props.onClose?.();
}}
/>
);
}

Expand Down

0 comments on commit f15ff74

Please sign in to comment.