Skip to content

Commit

Permalink
Merge branch 'newsroomTests' of https://github.com/vishvamsinh28/website
Browse files Browse the repository at this point in the history
 into newsroomTests
  • Loading branch information
anshgoyalevil committed Aug 25, 2024
2 parents ea45249 + 84bd83e commit 4ec489b
Show file tree
Hide file tree
Showing 11 changed files with 1,115 additions and 2,986 deletions.
52 changes: 52 additions & 0 deletions components/InputBox.stories.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
import { useArgs } from '@storybook/preview-api';
import type { Meta, StoryObj } from '@storybook/react';

import type { InputBoxProps } from '@/types/components/InputBoxPropsType';
import { InputTypes } from '@/types/components/InputBoxPropsType';

import InputBox from './InputBox';

const meta: Meta<typeof InputBox> = {
title: 'Components/InputBox',
component: InputBox
};

export default meta;

type Story = StoryObj<typeof InputBox>;

const Input: Story = {
args: {
inputValue: ''
},

render: (args: InputBoxProps) => {
const [{ inputValue }, updateArgs] = useArgs();

const setValue = (newValue: string) => {
updateArgs({ inputValue: newValue });
};

return <InputBox {...args} inputValue={inputValue} setInput={setValue} />;
}
};

export const TextInput: Story = {
...Input,

args: {
inputType: InputTypes.TEXT,
inputName: 'Name',
placeholder: 'AsyncAPI Initiative'
}
};

export const EmailInput: Story = {
...Input,

args: {
inputType: InputTypes.EMAIL,
inputName: 'Email',
placeholder: '[email protected]'
}
};
21 changes: 21 additions & 0 deletions components/InputBox.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import React from 'react';

import type { InputBoxProps } from '@/types/components/InputBoxPropsType';

/**
* This component renders input box.
*/
export default function InputBox({ inputType, inputName, placeholder, inputValue, setInput }: InputBoxProps) {
return (
<input
type={inputType}
name={inputName}
placeholder={placeholder}
value={inputValue}
onChange={(e) => setInput(e.target.value)}
className='form-input mt-2 block w-full rounded-md sm:text-sm sm:leading-5 md:mt-0 md:flex-1'
required
data-testid={`NewsletterSubscribe-${inputType}-input`}
/>
);
}
28 changes: 12 additions & 16 deletions components/NewsletterSubscribe.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,12 @@
import { useState } from 'react';

import { ButtonType } from '@/types/components/buttons/ButtonPropsType';
import { InputTypes } from '@/types/components/InputBoxPropsType';
import { HeadingLevel, HeadingTypeStyle } from '@/types/typography/Heading';

import { useTranslation } from '../utils/i18n';
import Button from './buttons/Button';
import InputBox from './InputBox';
import Loader from './Loader';
import Heading from './typography/Heading';
import Paragraph from './typography/Paragraph';
Expand Down Expand Up @@ -128,25 +130,19 @@ export default function NewsletterSubscribe({
<Loader dark={dark} />
) : (
<form className='flex flex-col gap-4 md:flex-row' onSubmit={handleSubmit}>
<input
type='text'
name='name'
<InputBox
inputType={InputTypes.TEXT}
inputName='name'
placeholder={t('newsletterCTA.nameInput')}
value={name}
onChange={(e) => setName(e.target.value)}
className='form-input block w-full rounded-md sm:text-sm sm:leading-5 md:mt-0 md:flex-1'
required
data-testid='NewsletterSubscribe-text-input'
inputValue={name}
setInput={setName}
/>
<input
type='email'
name='email'
<InputBox
inputType={InputTypes.EMAIL}
inputName='email'
placeholder={t('newsletterCTA.emailInput')}
value={email}
onChange={(e) => setEmail(e.target.value)}
className='form-input mt-2 block w-full rounded-md sm:text-sm sm:leading-5 md:mt-0 md:flex-1'
required
data-testid='NewsletterSubscribe-email-input'
inputValue={email}
setInput={setEmail}
/>
<Button
type={ButtonType.SUBMIT}
Expand Down
Loading

0 comments on commit 4ec489b

Please sign in to comment.