From 9719d0b201e7f1d861062e18fd9748a3e9c50373 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?David=20D=C3=ADaz=20Gonz=C3=A1lez?= Date: Tue, 29 Oct 2024 10:30:56 +0000 Subject: [PATCH] refactor(web) migrate core/EptyState to TypeScript Since it has been touched in a previous commit, moves it to TypeScript although still being an unfinished component and its future is even unknown. --- .../core/{EmptyState.jsx => EmptyState.tsx} | 30 ++++++++----------- 1 file changed, 13 insertions(+), 17 deletions(-) rename web/src/components/core/{EmptyState.jsx => EmptyState.tsx} (77%) diff --git a/web/src/components/core/EmptyState.jsx b/web/src/components/core/EmptyState.tsx similarity index 77% rename from web/src/components/core/EmptyState.jsx rename to web/src/components/core/EmptyState.tsx index 72c69802ad..49451b9c1f 100644 --- a/web/src/components/core/EmptyState.jsx +++ b/web/src/components/core/EmptyState.tsx @@ -20,8 +20,6 @@ * find current contact information at www.suse.com. */ -// @ts-check - import React from "react"; import { EmptyState, @@ -30,14 +28,21 @@ import { Stack, EmptyStateFooter, EmptyStateActions, + EmptyStateProps, + EmptyStateHeaderProps, } from "@patternfly/react-core"; import { Icon } from "~/components/layout"; +import { IconProps } from "../layout/Icon"; -/** - * @typedef {import("~/components/layout/Icon").IconProps} IconProps - * @typedef {import("@patternfly/react-core").EmptyStateProps} EmptyStateProps - * @typedef {import("@patternfly/react-core").EmptyStateHeaderProps} EmptyStateHeaderProps - */ +type EmptyStateWrapperProps = { + title: string; + icon: IconProps["name"]; + color?: string; + headingLevel?: EmptyStateHeaderProps["headingLevel"]; + noPadding?: boolean; + actions?: React.ReactNode; + children?: React.ReactNode; +}; /** * Convenient wrapper for easing the use of PF/EmptyState component @@ -46,15 +51,6 @@ import { Icon } from "~/components/layout"; * directly when dealing with a very specific UI use case and more freedom is * needed. * - * @param {object} props - * @param {string} props.title - * @param {IconProps["name"]} props.icon - * @param {string} [props.color="color-100"] - * @param {EmptyStateHeaderProps["headingLevel"]} [props.headingLevel="h4"] - * @param {boolean} [props.noPadding=false] - * @param {React.ReactNode} [props.actions] - * @param {React.ReactNode} [props.children] - * @param {EmptyStateProps} [props.rest] * @todo write documentation */ export default function EmptyStateWrapper({ @@ -66,7 +62,7 @@ export default function EmptyStateWrapper({ actions, children, ...rest -}) { +}: Partial & EmptyStateWrapperProps) { // @ts-ignore if (noPadding) rest.className = [rest.className, "no-padding"].join(" ").trim();