Skip to content

Commit

Permalink
feat(ui): adds input element, ref #4810
Browse files Browse the repository at this point in the history
  • Loading branch information
kyranjamie committed Jan 16, 2024
1 parent 0930968 commit b795df3
Show file tree
Hide file tree
Showing 10 changed files with 531 additions and 201 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -242,7 +242,7 @@
"@leather-wallet/prettier-config": "0.0.1",
"@leather-wallet/tokens": "0.0.3",
"@ls-lint/ls-lint": "2.2.2",
"@pandacss/dev": "0.26.2",
"@pandacss/dev": "0.27.1",
"@playwright/test": "1.40.1",
"@pmmmwh/react-refresh-webpack-plugin": "0.5.11",
"@redux-devtools/cli": "4.0.0",
Expand Down
14 changes: 7 additions & 7 deletions src/app/common/hooks/use-event-listener.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,32 +43,32 @@ const isBrowser = checkIsBrowser();
*
* @param event the event name
* @param handler the event handler function to execute
* @param doc the dom environment to execute against (defaults to `document`)
* @param element the dom environment to execute against (defaults to `document`)
* @param options the event listener options
*/
export function useEventListener(
event: keyof WindowEventMap,
handler: (event: any) => void,
doc: Document | null = isBrowser ? document : null,
element: Document | null = isBrowser ? document : null,
options?: AddEventListener[2]
) {
const savedHandler = useLatestRef(handler);

useEffect(() => {
if (!doc) return;
if (!element) return;

const listener = (event: any) => {
savedHandler.current(event);
};

doc.addEventListener(event, listener, options);
element.addEventListener(event, listener, options);

return () => {
doc.removeEventListener(event, listener, options);
element.removeEventListener(event, listener, options);
};
}, [event, doc, options, savedHandler]);
}, [event, element, options, savedHandler]);

return () => {
doc?.removeEventListener(event, savedHandler.current, options);
element?.removeEventListener(event, savedHandler.current, options);
};
}
89 changes: 45 additions & 44 deletions src/app/features/add-network/add-network.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ import {
useNetworksActions,
} from '@app/store/networks/networks.hooks';
import { LeatherButton } from '@app/ui/components/button';
import { Input } from '@app/ui/components/input';
import { Input } from '@app/ui/components/input/input';
import { Title } from '@app/ui/components/typography/title';

/**
Expand Down Expand Up @@ -70,14 +70,14 @@ export function AddNetwork() {

const setStacksUrl = useCallback(
(value: string) => {
setFieldValue('stacksUrl', value);
void setFieldValue('stacksUrl', value);
},
[setFieldValue]
);

const setBitcoinUrl = useCallback(
(value: string) => {
setFieldValue('bitcoinUrl', value);
void setFieldValue('bitcoinUrl', value);
},
[setFieldValue]
);
Expand Down Expand Up @@ -219,17 +219,17 @@ export function AddNetwork() {
</a>
. Make sure you review and trust the host before you add it.
</styled.span>
<Input
autoFocus
borderRadius="sm"
height="64px"
onChange={formikProps.handleChange}
name="name"
placeholder="Name"
value={formikProps.values.name}
width="100%"
data-testid={NetworkSelectors.NetworkName}
/>
<Input.Root>
<Input.Label>Name</Input.Label>
<Input.Field
autoFocus
onChange={formikProps.handleChange}
name="name"
value={formikProps.values.name}
width="100%"
data-testid={NetworkSelectors.NetworkName}
/>
</Input.Root>
<Title>Bitcoin API</Title>
{/* TODO: Replace with new Select */}
<SelectRoot onValueChange={handleApiChange} defaultValue="mainnet">
Expand Down Expand Up @@ -264,37 +264,38 @@ export function AddNetwork() {
</SelectContent>
</SelectRoot>
<Title>Stacks API URL</Title>
<Input
borderRadius="sm"
height="64px"
onChange={formikProps.handleChange}
name="stacksUrl"
placeholder="Stacks Address"
value={formikProps.values.stacksUrl}
width="100%"
data-testid={NetworkSelectors.NetworkStacksAddress}
/>
<Input.Root>
<Input.Label>Name</Input.Label>
<Input.Field
height="64px"
onChange={formikProps.handleChange}
name="stacksUrl"
value={formikProps.values.stacksUrl}
width="100%"
data-testid={NetworkSelectors.NetworkStacksAddress}
/>
</Input.Root>
<Title>Bitcoin API URL</Title>
<Input
borderRadius="sm"
height="64px"
onChange={formikProps.handleChange}
name="bitcoinUrl"
placeholder="Bitcoin Address"
value={formikProps.values.bitcoinUrl}
width="100%"
data-testid={NetworkSelectors.NetworkBitcoinAddress}
/>
<Input
borderRadius="sm"
height="64px"
onChange={formikProps.handleChange}
name="key"
placeholder="Key"
value={formikProps.values.key}
width="100%"
data-testid={NetworkSelectors.NetworkKey}
/>
<Input.Root>
<Input.Label>Bitcoin API URL</Input.Label>
<Input.Field
onChange={formikProps.handleChange}
name="bitcoinUrl"
value={formikProps.values.bitcoinUrl}
width="100%"
data-testid={NetworkSelectors.NetworkBitcoinAddress}
/>
</Input.Root>
<Input.Root>
<Input.Label>Network key</Input.Label>
<Input.Field
onChange={formikProps.handleChange}
name="key"
value={formikProps.values.key}
width="100%"
data-testid={NetworkSelectors.NetworkKey}
/>
</Input.Root>
{error ? (
<ErrorLabel data-testid={NetworkSelectors.ErrorText}>{error}</ErrorLabel>
) : null}
Expand Down
20 changes: 11 additions & 9 deletions src/app/features/edit-nonce-drawer/components/edit-nonce-field.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { useField } from 'formik';
import { Stack, StackProps } from 'leather-styles/jsx';

import { ErrorLabel } from '@app/components/error-label';
import { Input } from '@app/ui/components/input';
import { Input } from '@app/ui/components/input/input';

interface EditNonceFieldProps extends StackProps {
onBlur(): void;
Expand All @@ -15,14 +15,16 @@ export const EditNonceField = memo((props: EditNonceFieldProps) => {

return (
<Stack width="100%" {...props}>
<Input
onBlur={onBlur}
onChange={async (evt: FormEvent<HTMLInputElement>) => {
await helpers.setValue(evt.currentTarget.value);
}}
placeholder="Enter a custom nonce"
value={field.value}
/>
<Input.Root data-has-error={meta.error}>
<Input.Label>Custom nonce</Input.Label>
<Input.Field
onBlur={onBlur}
value={field.value}
onChange={async (evt: FormEvent<HTMLInputElement>) => {
await helpers.setValue(evt.currentTarget.value);
}}
/>
</Input.Root>
{meta.error && <ErrorLabel>{meta.error}</ErrorLabel>}
</Stack>
);
Expand Down
11 changes: 11 additions & 0 deletions src/app/pages/home/home.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import { FeedbackButton } from '@app/features/feedback-button/feedback-button';
import { InAppMessages } from '@app/features/hiro-messages/in-app-messages';
import { homePageModalRoutes } from '@app/routes/app-routes';
import { ModalBackgroundWrapper } from '@app/routes/components/modal-background-wrapper';
import { Input } from '@app/ui/components/input/input';

import { CurrentAccount } from './components/account-area';
import { HomeTabs } from './components/home-tabs';
Expand All @@ -37,6 +38,16 @@ export function Home() {
<HomeLayout currentAccount={<CurrentAccount />}>
<FeedbackButton />
<HomeTabs>
<Input.Root>
<Input.Field type="text" />
<Input.Label>Label</Input.Label>
</Input.Root>
<br />
<Input.Root data-has-error="true">
<Input.Field type="text" />
<Input.Label>Label</Input.Label>
</Input.Root>

<ModalBackgroundWrapper>
<Route index element={<AssetsList />} />
<Route path={RouteUrls.Activity} element={<ActivityList />}>
Expand Down
19 changes: 0 additions & 19 deletions src/app/ui/components/input.tsx

This file was deleted.

39 changes: 39 additions & 0 deletions src/app/ui/components/input/input.stories.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
import type { Meta, StoryObj } from '@storybook/react';

import { Input } from './input';

const meta: Meta<typeof Input.Root> = {
component: Input.Root,
tags: ['autodocs'],
title: 'Input',
};

export default meta;
type Story = StoryObj<typeof Input.Root>;

export const Default: Story = {
render: () => (
<Input.Root>
<Input.Label>Label</Input.Label>
<Input.Field type="text" />
</Input.Root>
),
};

export const Error: Story = {
render: () => (
<Input.Root data-has-error="true">
<Input.Label>Error field</Input.Label>
<Input.Field type="text" />
</Input.Root>
),
};

export const DefaultValue: Story = {
render: () => (
<Input.Root>
<Input.Label>Error field</Input.Label>
<Input.Field value="This is a default value" type="text" />
</Input.Root>
),
};
Loading

0 comments on commit b795df3

Please sign in to comment.