-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
12 changed files
with
352 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
26 changes: 26 additions & 0 deletions
26
packages/dnb-design-system-portal/src/docs/uilib/extensions/forms/Value/Upload.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
--- | ||
title: 'Upload' | ||
description: '`Value.Upload` will render the selected country.' | ||
componentType: 'feature-value' | ||
showTabs: true | ||
tabs: | ||
- title: Info | ||
key: '/info' | ||
- title: Demos | ||
key: '/demos' | ||
- title: Properties | ||
key: '/properties' | ||
breadcrumb: | ||
- text: Forms | ||
href: /uilib/extensions/forms/ | ||
- text: Value | ||
href: /uilib/extensions/forms/Value/ | ||
- text: Upload | ||
href: /uilib/extensions/forms/Value/Upload/ | ||
--- | ||
|
||
import Info from 'Docs/uilib/extensions/forms/Value/Upload/info' | ||
import Demos from 'Docs/uilib/extensions/forms/Value/Upload/demos' | ||
|
||
<Info /> | ||
<Demos /> |
91 changes: 91 additions & 0 deletions
91
packages/dnb-design-system-portal/src/docs/uilib/extensions/forms/Value/Upload/Examples.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
import ComponentBox from '../../../../../../shared/tags/ComponentBox' | ||
import { P } from '@dnb/eufemia/src' | ||
import { Form, Value } from '@dnb/eufemia/src/extensions/forms' | ||
|
||
function createMockFile(name: string, size: number, type: string) { | ||
const file = new File([], name, { type }) | ||
Object.defineProperty(file, 'size', { | ||
get() { | ||
return size | ||
}, | ||
}) | ||
return file | ||
} | ||
|
||
export const Placeholder = () => { | ||
return ( | ||
<ComponentBox> | ||
<Value.Upload placeholder="No values given" /> | ||
</ComponentBox> | ||
) | ||
} | ||
|
||
export const WithValue = () => { | ||
return ( | ||
<ComponentBox scope={{ createMockFile }}> | ||
<Value.Upload | ||
value={[ | ||
{ file: createMockFile('fileName-1.png', 100, 'image/png') }, | ||
{ file: createMockFile('fileName-2.png', 200, 'image/png') }, | ||
]} | ||
/> | ||
</ComponentBox> | ||
) | ||
} | ||
|
||
export const Label = () => { | ||
return ( | ||
<ComponentBox> | ||
<Value.Upload label="Label text" showEmpty /> | ||
</ComponentBox> | ||
) | ||
} | ||
|
||
export const LabelAndValue = () => { | ||
return ( | ||
<ComponentBox scope={{ createMockFile }}> | ||
<Value.Upload | ||
label="Label text" | ||
value={[ | ||
{ file: createMockFile('fileName-1.png', 100, 'image/png') }, | ||
{ file: createMockFile('fileName-2.png', 200, 'image/png') }, | ||
]} | ||
/> | ||
</ComponentBox> | ||
) | ||
} | ||
|
||
export const Inline = () => { | ||
return ( | ||
<ComponentBox scope={{ createMockFile }}> | ||
<P> | ||
This is before the component | ||
<Value.Upload | ||
value={[ | ||
{ file: createMockFile('fileName-1.png', 100, 'image/png') }, | ||
{ file: createMockFile('fileName-2.png', 200, 'image/png') }, | ||
]} | ||
inline | ||
/> | ||
This is after the component | ||
</P> | ||
</ComponentBox> | ||
) | ||
} | ||
|
||
export const WithPath = () => { | ||
return ( | ||
<ComponentBox scope={{ createMockFile }}> | ||
<Form.Handler | ||
data={{ | ||
myFiles: [ | ||
{ file: createMockFile('fileName-1.png', 100, 'image/png') }, | ||
{ file: createMockFile('fileName-2.png', 200, 'image/png') }, | ||
], | ||
}} | ||
> | ||
<Value.Upload path="/myFiles" /> | ||
</Form.Handler> | ||
</ComponentBox> | ||
) | ||
} |
31 changes: 31 additions & 0 deletions
31
...dnb-design-system-portal/src/docs/uilib/extensions/forms/Value/Upload/demos.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
--- | ||
showTabs: true | ||
--- | ||
|
||
import * as Examples from './Examples' | ||
|
||
## Demos | ||
|
||
### Placeholder | ||
|
||
<Examples.Placeholder /> | ||
|
||
### Value | ||
|
||
<Examples.WithValue /> | ||
|
||
### Label | ||
|
||
<Examples.Label /> | ||
|
||
### Label and value | ||
|
||
<Examples.LabelAndValue /> | ||
|
||
### With path | ||
|
||
<Examples.WithPath /> | ||
|
||
### Inline | ||
|
||
<Examples.Inline /> |
62 changes: 62 additions & 0 deletions
62
.../dnb-design-system-portal/src/docs/uilib/extensions/forms/Value/Upload/info.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
--- | ||
showTabs: true | ||
--- | ||
|
||
## Description | ||
|
||
`Value.SelectCountry` will render the selected country. | ||
|
||
```jsx | ||
import { Value } from '@dnb/eufemia/extensions/forms' | ||
render(<Value.SelectCountry path="/country" />) | ||
``` | ||
|
||
There is a corresponding [Field.SelectCountry](/uilib/extensions/forms/feature-fields/SelectCountry) component. | ||
|
||
### The `useCountry` hook | ||
|
||
You can use the `Value.SelectCountry.useCountry` hook to get the country name by ISO code. It returns the country name in the current locale. | ||
|
||
```tsx | ||
import { Value } from '@dnb/eufemia/extensions/forms' | ||
|
||
const MyComponent = () => { | ||
const { getCountryNameByIso } = Value.SelectCountry.useCountry('NO') | ||
} | ||
``` | ||
|
||
### TransformIn and TransformOut | ||
|
||
You can use the `transformIn` and `transformOut` to transform the value before it gets displayed in the field and before it gets sent to the form. The second parameter is the country object. You may have a look at the demo below to see how it works. | ||
|
||
```tsx | ||
const transformOut = (value, country) => { | ||
if (value) { | ||
return `${country.name} (${value})` | ||
} | ||
} | ||
const transformIn = (value) => { | ||
return String(value).match(/\((.*)\)/)?.[1] | ||
} | ||
``` | ||
|
||
### onFocus, onBlur, onChange | ||
|
||
These events have an additional parameter with the country object. | ||
|
||
```tsx | ||
const onFocus = (value, country) => {} | ||
``` | ||
|
||
## The country object | ||
|
||
```ts | ||
{ | ||
cdc: '47', | ||
iso: 'NO', | ||
name: 'Norge', | ||
i18n: { en: 'Norway', nb: 'Norge' }, | ||
regions: ['Scandinavia', 'Nordic'], | ||
continent: 'Europe', | ||
} | ||
``` |
15 changes: 15 additions & 0 deletions
15
...esign-system-portal/src/docs/uilib/extensions/forms/Value/Upload/properties.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
--- | ||
showTabs: true | ||
--- | ||
|
||
import TranslationsTable from 'dnb-design-system-portal/src/shared/parts/TranslationsTable' | ||
import PropertiesTable from 'dnb-design-system-portal/src/shared/parts/PropertiesTable' | ||
import { ValueProperties } from '@dnb/eufemia/src/extensions/forms/Value/ValueDocs' | ||
|
||
## Properties | ||
|
||
<PropertiesTable props={ValueProperties} /> | ||
|
||
## Translations | ||
|
||
<TranslationsTable localeKey={['Upload', 'Field']} /> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
23 changes: 23 additions & 0 deletions
23
packages/dnb-eufemia/src/extensions/forms/Value/Upload/Upload.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
import React from 'react' | ||
import classnames from 'classnames' | ||
import ValueBlock from '../../ValueBlock' | ||
import { useValueProps } from '../../hooks' | ||
import { ValueProps } from '../../types' | ||
|
||
export type Props = ValueProps<string> | ||
|
||
function Upload(props: Props) { | ||
const { value, className, ...rest } = useValueProps(props) | ||
console.log(value) | ||
return ( | ||
<ValueBlock | ||
className={classnames('dnb-forms-value-string', className)} | ||
{...rest} | ||
> | ||
{'value'} | ||
</ValueBlock> | ||
) | ||
} | ||
|
||
Upload._supportsSpacingProps = true | ||
export default Upload |
75 changes: 75 additions & 0 deletions
75
packages/dnb-eufemia/src/extensions/forms/Value/Upload/__tests__/Upload.test.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
import React from 'react' | ||
import { screen, render } from '@testing-library/react' | ||
import { Value, Form } from '../../..' | ||
|
||
describe('Value.SelectCountry', () => { | ||
it('renders string values', () => { | ||
render(<Value.SelectCountry value="NO" />) | ||
|
||
expect( | ||
document.querySelector( | ||
'.dnb-forms-value-select-country .dnb-forms-value-block__content' | ||
) | ||
).toHaveTextContent('Norge') | ||
}) | ||
|
||
it('renders label when showEmpty is true', () => { | ||
render(<Value.SelectCountry showEmpty label="My label" />) | ||
expect(document.querySelector('.dnb-form-label')).toHaveTextContent( | ||
'My label' | ||
) | ||
}) | ||
|
||
it('renders value and label', () => { | ||
render(<Value.SelectCountry label="My selections" value="NO" />) | ||
expect( | ||
document.querySelector( | ||
'.dnb-forms-value-select-country .dnb-forms-value-block__content' | ||
) | ||
).toHaveTextContent('Norge') | ||
|
||
expect(document.querySelector('.dnb-form-label')).toHaveTextContent( | ||
'My selections' | ||
) | ||
}) | ||
|
||
it('renders custom label', () => { | ||
render(<Value.SelectCountry label="Custom label" showEmpty />) | ||
expect(document.querySelector('.dnb-form-label')).toHaveTextContent( | ||
'Custom label' | ||
) | ||
}) | ||
|
||
it('renders placeholder', () => { | ||
render(<Value.SelectCountry placeholder="Please select a value" />) | ||
expect(screen.getByText('Please select a value')).toBeInTheDocument() | ||
}) | ||
|
||
it('renders value from path', () => { | ||
render( | ||
<Form.Handler data={{ myCountry: 'CH' }}> | ||
<Value.SelectCountry path="/myCountry" /> | ||
</Form.Handler> | ||
) | ||
|
||
expect( | ||
document.querySelector( | ||
'.dnb-forms-value-select-country .dnb-forms-value-block__content' | ||
) | ||
).toHaveTextContent('Sveits') | ||
}) | ||
|
||
it('formats value in different locale', () => { | ||
render( | ||
<Form.Handler locale="en-GB" data={{ myCountry: 'CH' }}> | ||
<Value.SelectCountry path="/myCountry" /> | ||
</Form.Handler> | ||
) | ||
|
||
expect( | ||
document.querySelector( | ||
'.dnb-forms-value-select-country .dnb-forms-value-block__content' | ||
) | ||
).toHaveTextContent('Switzerland') | ||
}) | ||
}) |
2 changes: 2 additions & 0 deletions
2
packages/dnb-eufemia/src/extensions/forms/Value/Upload/index.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
export { default } from './Upload' | ||
export * from './Upload' |
Oops, something went wrong.