@1024pix/pix-ui 24.2.0 → 24.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +7 -0
- package/app/stories/form.stories.mdx +2 -4
- package/app/stories/pix-background-header.stories.mdx +3 -8
- package/app/stories/pix-banner.stories.js +9 -11
- package/app/stories/pix-banner.stories.mdx +9 -32
- package/app/stories/pix-block.stories.js +3 -2
- package/app/stories/pix-block.stories.mdx +1 -1
- package/app/stories/pix-button-link.stories.js +0 -2
- package/app/stories/pix-button-link.stories.mdx +7 -15
- package/app/stories/pix-button-upload.stories.js +2 -3
- package/app/stories/pix-button-upload.stories.mdx +4 -12
- package/app/stories/pix-button.stories.mdx +7 -9
- package/app/stories/pix-checkbox.stories.js +8 -10
- package/app/stories/pix-checkbox.stories.mdx +12 -13
- package/app/stories/pix-collapsible.stories.js +7 -3
- package/app/stories/pix-collapsible.stories.mdx +6 -12
- package/app/stories/pix-dropdown.stories.mdx +10 -14
- package/app/stories/pix-filter-banner.stories.js +1 -4
- package/app/stories/pix-filter-banner.stories.mdx +5 -9
- package/app/stories/pix-filterable-and-searchable-select.stories.js +0 -2
- package/app/stories/pix-filterable-and-searchable-select.stories.mdx +25 -25
- package/app/stories/pix-icon-button.stories.js +7 -5
- package/app/stories/pix-icon-button.stories.mdx +2 -6
- package/app/stories/pix-indicator-card.stories.js +2 -2
- package/app/stories/pix-indicator-card.stories.mdx +2 -1
- package/app/stories/pix-input-code.stories.mdx +7 -16
- package/app/stories/pix-input-password.stories.js +1 -8
- package/app/stories/pix-input-password.stories.mdx +12 -16
- package/app/stories/pix-input.stories.js +4 -10
- package/app/stories/pix-input.stories.mdx +14 -26
- package/app/stories/pix-message.stories.js +4 -3
- package/app/stories/pix-message.stories.mdx +4 -9
- package/app/stories/pix-modal.stories.js +0 -2
- package/app/stories/pix-modal.stories.mdx +2 -6
- package/app/stories/pix-multi-select.stories.mdx +24 -21
- package/app/stories/pix-pagination.stories.js +2 -1
- package/app/stories/pix-pagination.stories.mdx +19 -18
- package/app/stories/pix-progress-gauge.stories.js +2 -1
- package/app/stories/pix-progress-gauge.stories.mdx +6 -9
- package/app/stories/pix-radio-button.stories.js +0 -3
- package/app/stories/pix-radio-button.stories.mdx +7 -16
- package/app/stories/pix-return-to.stories.js +3 -3
- package/app/stories/pix-return-to.stories.mdx +4 -10
- package/app/stories/pix-search-input.stories.mdx +14 -22
- package/app/stories/pix-select.stories.mdx +26 -31
- package/app/stories/pix-selectable-tag.stories.mdx +10 -20
- package/app/stories/pix-sidebar.stories.js +0 -5
- package/app/stories/pix-sidebar.stories.mdx +2 -6
- package/app/stories/pix-stars.stories.js +12 -6
- package/app/stories/pix-stars.stories.mdx +3 -12
- package/app/stories/pix-tag.stories.js +21 -25
- package/app/stories/pix-tag.stories.mdx +5 -15
- package/app/stories/pix-textarea.stories.js +7 -12
- package/app/stories/pix-textarea.stories.mdx +8 -11
- package/app/stories/pix-toggle.stories.mdx +7 -11
- package/app/stories/pix-tooltip.stories.js +11 -14
- package/app/stories/pix-tooltip.stories.mdx +2 -7
- package/docs/architecture.stories.mdx +3 -3
- package/docs/breaking-changes.stories.mdx +16 -14
- package/docs/changelog.stories.mdx +1 -1
- package/docs/create-component.stories.mdx +31 -29
- package/docs/design-system.stories.mdx +2 -2
- package/docs/design-tokens.stories.mdx +6 -2
- package/docs/good-practices-a11y.stories.mdx +4 -9
- package/docs/good-practices-design.stories.mdx +11 -20
- package/docs/good-practices-responsive.stories.mdx +3 -3
- package/docs/good-practices-style-css.stories.mdx +10 -10
- package/docs/good-practices-tests.stories.mdx +2 -2
- package/docs/make-a-release.stories.mdx +16 -13
- package/docs/pix-design-tokens-dev.stories.mdx +1 -1
- package/docs/storybook.stories.mdx +4 -3
- package/docs/test-component-without-release.stories.mdx +1 -1
- package/docs/use-component.stories.mdx +7 -6
- package/docs/use-install.stories.mdx +6 -6
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,12 @@
|
|
|
1
1
|
# Pix-UI Changelog
|
|
2
2
|
|
|
3
|
+
## v24.2.1 (31/01/2023)
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
### :building_construction: Tech
|
|
7
|
+
- [#323](https://github.com/1024pix/pix-ui/pull/323) [TECH] Supprime des warnings de deprecation Storybook
|
|
8
|
+
- [#327](https://github.com/1024pix/pix-ui/pull/327) [TECH] Remplacer les valeurs d'`id` par du kebab case
|
|
9
|
+
|
|
3
10
|
## v24.2.0 (31/01/2023)
|
|
4
11
|
|
|
5
12
|
|
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import { Meta, Story, Canvas } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas } from '@storybook/addon-docs';
|
|
2
2
|
import * as stories from './form.stories.js';
|
|
3
3
|
|
|
4
|
-
<Meta
|
|
5
|
-
title='Form/Example'
|
|
6
|
-
/>
|
|
4
|
+
<Meta title="Form/Example" />
|
|
7
5
|
|
|
8
6
|
# Formulaire avec les composants Pix UI
|
|
9
7
|
|
|
@@ -1,10 +1,7 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs';
|
|
2
2
|
import * as stories from './pix-background-header.stories.js';
|
|
3
3
|
|
|
4
|
-
<Meta
|
|
5
|
-
title='Layout/Background Header'
|
|
6
|
-
component='PixBackgroundHeader'
|
|
7
|
-
/>
|
|
4
|
+
<Meta title="Layout/Background Header" component="PixBackgroundHeader" />
|
|
8
5
|
|
|
9
6
|
# Pix Background Header
|
|
10
7
|
|
|
@@ -23,9 +20,7 @@ Les enfants de la bannière se mettrons en colonne.
|
|
|
23
20
|
|
|
24
21
|
```html
|
|
25
22
|
<PixBackgroundHeader>
|
|
26
|
-
<PixBlock>
|
|
27
|
-
Lorem ipsum
|
|
28
|
-
</PixBlock>
|
|
23
|
+
<PixBlock> Lorem ipsum </PixBlock>
|
|
29
24
|
</PixBackgroundHeader>
|
|
30
25
|
```
|
|
31
26
|
|
|
@@ -67,30 +67,28 @@ export const argsTypes = {
|
|
|
67
67
|
name: 'actionLabel',
|
|
68
68
|
description: 'Nom de l‘action',
|
|
69
69
|
type: { name: 'string', required: false },
|
|
70
|
-
defaultValue: '',
|
|
71
70
|
},
|
|
72
71
|
actionUrl: {
|
|
73
72
|
name: 'actionUrl',
|
|
74
73
|
description: 'Lien de l‘action',
|
|
75
74
|
type: { name: 'string', required: false },
|
|
76
|
-
defaultValue: '',
|
|
77
75
|
},
|
|
78
76
|
type: {
|
|
79
77
|
name: 'type',
|
|
80
78
|
description: 'Définit le type de bannière',
|
|
81
79
|
type: { name: 'string', required: false },
|
|
82
|
-
defaultValue: { summary: 'information' },
|
|
80
|
+
table: { defaultValue: { summary: 'information' } },
|
|
83
81
|
control: {
|
|
84
82
|
type: 'select',
|
|
85
|
-
options: [
|
|
86
|
-
'information',
|
|
87
|
-
'warning',
|
|
88
|
-
'error',
|
|
89
|
-
'communication',
|
|
90
|
-
'communication-orga',
|
|
91
|
-
'communication-certif',
|
|
92
|
-
],
|
|
93
83
|
},
|
|
84
|
+
options: [
|
|
85
|
+
'information',
|
|
86
|
+
'warning',
|
|
87
|
+
'error',
|
|
88
|
+
'communication',
|
|
89
|
+
'communication-orga',
|
|
90
|
+
'communication-certif',
|
|
91
|
+
],
|
|
94
92
|
},
|
|
95
93
|
canCloseBanner: {
|
|
96
94
|
name: 'canCloseBanner',
|
|
@@ -1,11 +1,7 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs';
|
|
2
2
|
import * as stories from './pix-banner.stories.js';
|
|
3
3
|
|
|
4
|
-
<Meta
|
|
5
|
-
title='Notification/Banner'
|
|
6
|
-
component='PixBanner'
|
|
7
|
-
argTypes={stories.argsTypes}
|
|
8
|
-
/>
|
|
4
|
+
<Meta title="Notification/Banner" component="PixBanner" argTypes={stories.argsTypes} />
|
|
9
5
|
|
|
10
6
|
# Pix Banner
|
|
11
7
|
|
|
@@ -13,7 +9,6 @@ Une `Banner` permet de mettre en avant une information importante.
|
|
|
13
9
|
|
|
14
10
|
> Il est possible de surcharger le style d'une `<PixBanner>` via l'attribut `class` ainsi que de passer n'importe quel attribut sur sa `div` wrapper (par exemple, un `aria-label`)
|
|
15
11
|
|
|
16
|
-
|
|
17
12
|
## Default
|
|
18
13
|
|
|
19
14
|
Bannière Information (par défaut).
|
|
@@ -76,43 +71,25 @@ Bannière contenant un bouton qui permet de fermer la bannière.
|
|
|
76
71
|
## Usage
|
|
77
72
|
|
|
78
73
|
```html
|
|
79
|
-
<PixBanner>
|
|
80
|
-
Bannière Info par défaut
|
|
81
|
-
</PixBanner>
|
|
74
|
+
<PixBanner> Bannière Info par défaut </PixBanner>
|
|
82
75
|
|
|
83
|
-
<PixBanner @type=
|
|
84
|
-
Bannière Communication pour Pix App
|
|
85
|
-
</PixBanner>
|
|
76
|
+
<PixBanner @type="communication"> Bannière Communication pour Pix App </PixBanner>
|
|
86
77
|
|
|
87
|
-
<PixBanner @type=
|
|
88
|
-
Bannière Warning
|
|
89
|
-
</PixBanner>
|
|
78
|
+
<PixBanner @type="warning"> Bannière Warning </PixBanner>
|
|
90
79
|
|
|
91
|
-
<PixBanner @type=
|
|
92
|
-
Bannière Error
|
|
93
|
-
</PixBanner>
|
|
80
|
+
<PixBanner @type="error"> Bannière Error </PixBanner>
|
|
94
81
|
|
|
95
|
-
<PixBanner
|
|
96
|
-
@actionLabel='Liste des campagnes'
|
|
97
|
-
@actionUrl='authenticated.campaigns'
|
|
98
|
-
>
|
|
82
|
+
<PixBanner @actionLabel="Liste des campagnes" @actionUrl="authenticated.campaigns">
|
|
99
83
|
Bannière avec une route pour lien
|
|
100
84
|
</PixBanner>
|
|
101
85
|
|
|
102
|
-
<PixBanner
|
|
103
|
-
@actionLabel='Ajouter des élèves'
|
|
104
|
-
@actionUrl='https://orga.pix.fr/eleves'
|
|
105
|
-
>
|
|
86
|
+
<PixBanner @actionLabel="Ajouter des élèves" @actionUrl="https://orga.pix.fr/eleves">
|
|
106
87
|
Bannière avec une route externe
|
|
107
88
|
</PixBanner>
|
|
108
89
|
|
|
109
|
-
<PixBanner
|
|
110
|
-
@type='warning'
|
|
111
|
-
@canCloseBanner=true
|
|
112
|
-
>
|
|
90
|
+
<PixBanner @type="warning" @canCloseBanner="true">
|
|
113
91
|
Bannière possédant un bouton de fermeture
|
|
114
92
|
</PixBanner>
|
|
115
|
-
|
|
116
93
|
```
|
|
117
94
|
|
|
118
95
|
## Arguments
|
|
@@ -12,7 +12,8 @@ export const argTypes = {
|
|
|
12
12
|
name: 'shadow',
|
|
13
13
|
description: 'Ombre sur le bloc',
|
|
14
14
|
type: { name: 'string', required: false },
|
|
15
|
-
defaultValue: 'light',
|
|
16
|
-
control: { type: 'select'
|
|
15
|
+
table: { defaultValue: { summary: 'light' } },
|
|
16
|
+
control: { type: 'select' },
|
|
17
|
+
options: ['light', 'heavy'],
|
|
17
18
|
},
|
|
18
19
|
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs';
|
|
2
2
|
import * as stories from './pix-block.stories.js';
|
|
3
3
|
|
|
4
4
|
<Meta title="Layout/Block" component="PixBlock" argTypes={stories.argTypes} />
|
|
@@ -44,14 +44,12 @@ export const argTypes = {
|
|
|
44
44
|
name: 'href',
|
|
45
45
|
description: 'Paramètre à renseigner pour utiliser lien HTML.',
|
|
46
46
|
type: { name: 'string', required: false },
|
|
47
|
-
defaultValue: null,
|
|
48
47
|
},
|
|
49
48
|
route: {
|
|
50
49
|
name: 'route',
|
|
51
50
|
description:
|
|
52
51
|
"Paramètre à renseigner pour utiliser un composant LinkTo à la place d'un lien classique. Il prend comme valeur la route de redirection",
|
|
53
52
|
type: { name: 'string', required: false },
|
|
54
|
-
defaultValue: null,
|
|
55
53
|
},
|
|
56
54
|
model: {
|
|
57
55
|
name: 'model',
|
|
@@ -1,12 +1,8 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs';
|
|
2
2
|
|
|
3
3
|
import * as stories from './pix-button-link.stories.js';
|
|
4
4
|
|
|
5
|
-
<Meta
|
|
6
|
-
title='Basics/ButtonLink'
|
|
7
|
-
component='PixButtonLink'
|
|
8
|
-
argTypes={stories.argTypes}
|
|
9
|
-
/>
|
|
5
|
+
<Meta title="Basics/ButtonLink" component="PixButtonLink" argTypes={stories.argTypes} />
|
|
10
6
|
|
|
11
7
|
# ButtonLink
|
|
12
8
|
|
|
@@ -22,13 +18,11 @@ Prend en entrée la propriété `@href`.
|
|
|
22
18
|
Redirige directement les attributs de la balise HTML `<a>` (eg. `target`...).
|
|
23
19
|
|
|
24
20
|
<Canvas>
|
|
25
|
-
<Story name=
|
|
21
|
+
<Story name="Lien HTML" story={stories.htmlLink} height={60} />
|
|
26
22
|
</Canvas>
|
|
27
23
|
|
|
28
24
|
```html
|
|
29
|
-
<PixButtonLink @href="https://pix.fr" target="_blank">
|
|
30
|
-
Libellé du lien
|
|
31
|
-
</PixButtonLink>
|
|
25
|
+
<PixButtonLink @href="https://pix.fr" target="_blank"> Libellé du lien </PixButtonLink>
|
|
32
26
|
```
|
|
33
27
|
|
|
34
28
|
## Route EmberJS
|
|
@@ -38,16 +32,14 @@ Equivalent au `<LinkTo />` de EmberJS avec le style d'un bouton Pix.
|
|
|
38
32
|
|
|
39
33
|
Prend en entrée la propriété `@route` et `@model`.
|
|
40
34
|
|
|
41
|
-
Un bouton de route EmberJS peut être désactivé via la propriété `@isDisabled`.
|
|
35
|
+
Un bouton de route EmberJS peut être désactivé via la propriété `@isDisabled`.
|
|
42
36
|
|
|
43
37
|
<Canvas>
|
|
44
|
-
<Story name=
|
|
38
|
+
<Story name="Route EmberJS" story={stories.emberLink} height={60} />
|
|
45
39
|
</Canvas>
|
|
46
40
|
|
|
47
41
|
```html
|
|
48
|
-
<PixButtonLink @route="ma.route.ember" @model="mon-model">
|
|
49
|
-
Libellé du lien
|
|
50
|
-
</PixButtonLink>
|
|
42
|
+
<PixButtonLink @route="ma.route.ember" @model="mon-model"> Libellé du lien </PixButtonLink>
|
|
51
43
|
```
|
|
52
44
|
|
|
53
45
|
## Arguments
|
|
@@ -4,7 +4,7 @@ import { action } from '@storybook/addon-actions';
|
|
|
4
4
|
export const buttonUpload = (args) => {
|
|
5
5
|
return {
|
|
6
6
|
template: hbs`<PixButtonUpload
|
|
7
|
-
@id=
|
|
7
|
+
@id={{this.id}}
|
|
8
8
|
@onChange={{this.onChange}}
|
|
9
9
|
@shape={{this.shape}}
|
|
10
10
|
@backgroundColor={{this.backgroundColor}}
|
|
@@ -18,6 +18,7 @@ export const buttonUpload = (args) => {
|
|
|
18
18
|
};
|
|
19
19
|
|
|
20
20
|
buttonUpload.args = {
|
|
21
|
+
id: 'file-upload',
|
|
21
22
|
onChange: action('onChange'),
|
|
22
23
|
};
|
|
23
24
|
|
|
@@ -26,14 +27,12 @@ export const argTypes = {
|
|
|
26
27
|
name: 'id',
|
|
27
28
|
description: "identifiant du bouton d'upload",
|
|
28
29
|
type: { name: 'string', required: true },
|
|
29
|
-
defaultValue: 'file-upload',
|
|
30
30
|
},
|
|
31
31
|
onChange: {
|
|
32
32
|
name: 'onChange',
|
|
33
33
|
description:
|
|
34
34
|
"fonction à exécuter au moment de l'upload du fichier, elle prend en entrée la liste des fichiers uploadés.",
|
|
35
35
|
type: { name: 'function', required: true },
|
|
36
|
-
defaultValue: null,
|
|
37
36
|
},
|
|
38
37
|
shape: {
|
|
39
38
|
name: 'shape',
|
|
@@ -1,12 +1,8 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs';
|
|
2
2
|
|
|
3
3
|
import * as stories from './pix-button-upload.stories.js';
|
|
4
4
|
|
|
5
|
-
<Meta
|
|
6
|
-
title='Basics/ButtonUpload'
|
|
7
|
-
component='PixButtonUpload'
|
|
8
|
-
argTypes={stories.argTypes}
|
|
9
|
-
/>
|
|
5
|
+
<Meta title="Basics/ButtonUpload" component="PixButtonUpload" argTypes={stories.argTypes} />
|
|
10
6
|
|
|
11
7
|
# PixButtonUpload
|
|
12
8
|
|
|
@@ -17,15 +13,11 @@ Hérite des styles de base de `PixButton` (`shape`, `backgroundColor`, `size`, `
|
|
|
17
13
|
Toutes les [propriétés HTML d'un input de type file](https://developer.mozilla.org/fr/docs/Web/HTML/Element/Input/file) sont supportées.
|
|
18
14
|
|
|
19
15
|
<Canvas>
|
|
20
|
-
<Story name=
|
|
16
|
+
<Story name="PixButtonUpload" story={stories.buttonUpload} height={60} />
|
|
21
17
|
</Canvas>
|
|
22
18
|
|
|
23
19
|
```html
|
|
24
|
-
<PixButtonUpload
|
|
25
|
-
@id="file-upload"
|
|
26
|
-
@onChange={{this.uploadFile}}
|
|
27
|
-
accept=".csv"
|
|
28
|
-
>
|
|
20
|
+
<PixButtonUpload @id="file-upload" @onChange="{{this.uploadFile}}" accept=".csv">
|
|
29
21
|
Libellé du bouton
|
|
30
22
|
</PixButtonUpload>
|
|
31
23
|
```
|
|
@@ -1,11 +1,7 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable, SourceContainer } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable, SourceContainer } from '@storybook/addon-docs';
|
|
2
2
|
import * as stories from './pix-button.stories.js';
|
|
3
3
|
|
|
4
|
-
<Meta
|
|
5
|
-
title='Basics/Button'
|
|
6
|
-
component='PixButton'
|
|
7
|
-
argTypes={stories.argsTypes}
|
|
8
|
-
/>
|
|
4
|
+
<Meta title="Basics/Button" component="PixButton" argTypes={stories.argsTypes} />
|
|
9
5
|
|
|
10
6
|
# Pix Button
|
|
11
7
|
|
|
@@ -51,6 +47,7 @@ Utiliser le composant `<PixButtonLink />` à la place.
|
|
|
51
47
|
|
|
52
48
|
Le bouton avec loader.
|
|
53
49
|
Le loader peut être affiché de deux façons :
|
|
50
|
+
|
|
54
51
|
- En passant une promesse dans l'attribut `@triggerAction`
|
|
55
52
|
- En passant directement l'attribut `@isLoading={{true}}`
|
|
56
53
|
|
|
@@ -80,13 +77,14 @@ Un petit bouton avec les bords arrondis en fond transparent avec une bordure
|
|
|
80
77
|
|
|
81
78
|
```html
|
|
82
79
|
<PixButton
|
|
83
|
-
@triggerAction={{action
|
|
80
|
+
@triggerAction="{{action"
|
|
81
|
+
triggerAction}}
|
|
84
82
|
@loadingColor="white"
|
|
85
83
|
@shape="squircle"
|
|
86
84
|
@backgroundColor="transparent-light"
|
|
87
|
-
@isDisabled={{false}}
|
|
85
|
+
@isDisabled="{{false}}"
|
|
88
86
|
@size="small"
|
|
89
|
-
@isBorderVisible={{true}}
|
|
87
|
+
@isBorderVisible="{{true}}"
|
|
90
88
|
>
|
|
91
89
|
Cliquez-moi
|
|
92
90
|
</PixButton>
|
|
@@ -17,27 +17,27 @@ export const Template = (args) => {
|
|
|
17
17
|
|
|
18
18
|
export const Default = Template.bind({});
|
|
19
19
|
Default.args = {
|
|
20
|
-
id: '
|
|
20
|
+
id: 'accept-newsletter',
|
|
21
21
|
label: 'Recevoir la newsletter',
|
|
22
22
|
};
|
|
23
23
|
|
|
24
24
|
export const indeterminateCheckbox = Template.bind({});
|
|
25
25
|
indeterminateCheckbox.args = {
|
|
26
|
-
id: '
|
|
26
|
+
id: 'accept-newsletter-2',
|
|
27
27
|
label: 'Recevoir la newsletter',
|
|
28
28
|
isIndeterminate: true,
|
|
29
29
|
};
|
|
30
30
|
|
|
31
31
|
export const checkboxWithSmallLabel = Template.bind({});
|
|
32
32
|
checkboxWithSmallLabel.args = {
|
|
33
|
-
id: '
|
|
33
|
+
id: 'accept-newsletter-2',
|
|
34
34
|
label: 'Recevoir la newsletter',
|
|
35
35
|
labelSize: 'small',
|
|
36
36
|
};
|
|
37
37
|
|
|
38
38
|
export const checkboxWithLargeLabel = Template.bind({});
|
|
39
39
|
checkboxWithLargeLabel.args = {
|
|
40
|
-
id: '
|
|
40
|
+
id: 'accept-newsletter-2',
|
|
41
41
|
label: 'Recevoir la newsletter',
|
|
42
42
|
labelSize: 'large',
|
|
43
43
|
};
|
|
@@ -47,12 +47,10 @@ export const argTypes = {
|
|
|
47
47
|
name: 'id',
|
|
48
48
|
description: 'Identifiant du champ permettant de lui attacher un label',
|
|
49
49
|
type: { name: 'string', required: true },
|
|
50
|
-
defaultValue: null,
|
|
51
50
|
},
|
|
52
51
|
label: {
|
|
53
52
|
name: 'label',
|
|
54
53
|
description: "Le label de l'input",
|
|
55
|
-
defaultValue: null,
|
|
56
54
|
},
|
|
57
55
|
screenReaderOnly: {
|
|
58
56
|
name: 'screenReaderOnly',
|
|
@@ -78,11 +76,11 @@ export const argTypes = {
|
|
|
78
76
|
name: 'labelSize',
|
|
79
77
|
description: 'Correspond à la taille de la police du label.',
|
|
80
78
|
type: { name: 'string', required: false },
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
type: 'select',
|
|
84
|
-
options: ['small', 'default', 'large'],
|
|
79
|
+
table: {
|
|
80
|
+
defaultValue: { summary: 'default' },
|
|
85
81
|
},
|
|
82
|
+
control: { type: 'select' },
|
|
83
|
+
options: ['small', 'default', 'large'],
|
|
86
84
|
},
|
|
87
85
|
checked: {
|
|
88
86
|
name: 'checked',
|
|
@@ -1,34 +1,33 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs';
|
|
2
2
|
|
|
3
3
|
import * as stories from './pix-checkbox.stories.js';
|
|
4
4
|
|
|
5
|
-
<Meta
|
|
6
|
-
title='Form/Checkbox'
|
|
7
|
-
component='PixCheckbox'
|
|
8
|
-
argTypes={stories.argTypes}
|
|
9
|
-
/>
|
|
5
|
+
<Meta title="Form/Checkbox" component="PixCheckbox" argTypes={stories.argTypes} />
|
|
10
6
|
|
|
11
7
|
# PixCheckbox
|
|
12
8
|
|
|
13
9
|
La PixCheckbox permet de créer des checkbox basiques ou des checkbox mixées (checkbox servant d'indicateur lors d'une sélection multiple).
|
|
14
10
|
|
|
15
11
|
<Canvas>
|
|
16
|
-
<Story name=
|
|
12
|
+
<Story name="Default" story={stories.Default} height={60} />
|
|
17
13
|
</Canvas>
|
|
18
14
|
|
|
19
15
|
## Checkbox indéterminée
|
|
16
|
+
|
|
20
17
|
<Canvas>
|
|
21
|
-
<Story name=
|
|
18
|
+
<Story name="Indeterminate" story={stories.indeterminateCheckbox} height={60} />
|
|
22
19
|
</Canvas>
|
|
23
20
|
|
|
24
21
|
## Checkbox avec un petit label
|
|
22
|
+
|
|
25
23
|
<Canvas>
|
|
26
|
-
<Story name=
|
|
24
|
+
<Story name="SmallLabel" story={stories.checkboxWithSmallLabel} height={60} />
|
|
27
25
|
</Canvas>
|
|
28
26
|
|
|
29
27
|
## Checkbox avec un grand label
|
|
28
|
+
|
|
30
29
|
<Canvas>
|
|
31
|
-
<Story name=
|
|
30
|
+
<Story name="LargeLabel" story={stories.checkboxWithLargeLabel} height={60} />
|
|
32
31
|
</Canvas>
|
|
33
32
|
|
|
34
33
|
## Usage
|
|
@@ -36,12 +35,12 @@ La PixCheckbox permet de créer des checkbox basiques ou des checkbox mixées (c
|
|
|
36
35
|
```html
|
|
37
36
|
<PixCheckbox
|
|
38
37
|
@id="superId"
|
|
39
|
-
@screenReaderOnly={{false}}
|
|
40
|
-
@isIndeterminate={{false}}
|
|
38
|
+
@screenReaderOnly="{{false}}"
|
|
39
|
+
@isIndeterminate="{{false}}"
|
|
41
40
|
@labelSize="small"
|
|
42
41
|
>
|
|
43
42
|
Recevoir la newsletter
|
|
44
|
-
</
|
|
43
|
+
</PixCheckbox>
|
|
45
44
|
```
|
|
46
45
|
|
|
47
46
|
## Arguments
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { hbs } from 'ember-cli-htmlbars';
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
const Template = (args) => {
|
|
4
4
|
return {
|
|
5
5
|
template: hbs`<PixCollapsible @title={{this.title}} @titleIcon={{this.titleIcon}}>
|
|
6
6
|
<div>Contenu du PixCollapsible</div>
|
|
@@ -9,6 +9,12 @@ export const collapsible = (args) => {
|
|
|
9
9
|
};
|
|
10
10
|
};
|
|
11
11
|
|
|
12
|
+
export const collapsible = Template.bind({});
|
|
13
|
+
collapsible.args = {
|
|
14
|
+
title: 'Titre du contenu à dérouler en cliquant',
|
|
15
|
+
titleIcon: 'user',
|
|
16
|
+
};
|
|
17
|
+
|
|
12
18
|
export const collapsibleWithBlockTitle = (args) => {
|
|
13
19
|
return {
|
|
14
20
|
template: hbs`<PixCollapsible @titleIcon={{this.titleIcon}}>
|
|
@@ -47,12 +53,10 @@ export const argTypes = {
|
|
|
47
53
|
name: 'title',
|
|
48
54
|
description: 'Intitulé du contenu du PixCollapsible',
|
|
49
55
|
type: { name: 'string', required: true },
|
|
50
|
-
defaultValue: 'Titre du contenu à dérouler en cliquant',
|
|
51
56
|
},
|
|
52
57
|
titleIcon: {
|
|
53
58
|
name: 'titleIcon',
|
|
54
59
|
description: "Ajoute l'icône donnée en paramètre avant le titre du PixCollapsible",
|
|
55
60
|
type: { name: 'string', required: false },
|
|
56
|
-
defaultValue: 'user',
|
|
57
61
|
},
|
|
58
62
|
};
|
|
@@ -1,12 +1,8 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs';
|
|
2
2
|
|
|
3
3
|
import * as stories from './pix-collapsible.stories.js';
|
|
4
4
|
|
|
5
|
-
<Meta
|
|
6
|
-
title='Others/Collapsible'
|
|
7
|
-
component='PixCollapsible'
|
|
8
|
-
argTypes={stories.argTypes}
|
|
9
|
-
/>
|
|
5
|
+
<Meta title="Others/Collapsible" component="PixCollapsible" argTypes={stories.argTypes} />
|
|
10
6
|
|
|
11
7
|
# PixCollapsible
|
|
12
8
|
|
|
@@ -16,23 +12,21 @@ Par défaut le contenu est masqué et cliquer sur le libellé permet de montrer
|
|
|
16
12
|
> Il est possible de cumuler les `PixCollapsible` de sorte à former un accordéon, il suffit de les mettre dans une même div parente.
|
|
17
13
|
|
|
18
14
|
<Canvas>
|
|
19
|
-
<Story name=
|
|
15
|
+
<Story name="PixCollapsible" story={stories.collapsible} height={150} />
|
|
20
16
|
</Canvas>
|
|
21
17
|
|
|
22
18
|
<Canvas>
|
|
23
|
-
<Story name=
|
|
19
|
+
<Story name="With block title" story={stories.collapsibleWithBlockTitle} height={150} />
|
|
24
20
|
</Canvas>
|
|
25
21
|
|
|
26
22
|
<Canvas>
|
|
27
|
-
<Story name=
|
|
23
|
+
<Story name="MultiplePixCollapsible" story={stories.multipleCollapsible} height={260} />
|
|
28
24
|
</Canvas>
|
|
29
25
|
|
|
30
26
|
## Usage
|
|
31
27
|
|
|
32
28
|
```html
|
|
33
|
-
<PixCollapsible
|
|
34
|
-
@title="Titre du contenu à dérouler en cliquant"
|
|
35
|
-
@iconTitle="user">
|
|
29
|
+
<PixCollapsible @title="Titre du contenu à dérouler en cliquant" @iconTitle="user">
|
|
36
30
|
<p>Contenu du PixCollapsible</p>
|
|
37
31
|
</PixCollapsible>
|
|
38
32
|
```
|
|
@@ -1,12 +1,8 @@
|
|
|
1
|
-
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs
|
|
1
|
+
import { Meta, Story, Canvas, ArgsTable } from '@storybook/addon-docs';
|
|
2
2
|
|
|
3
3
|
import * as stories from './pix-dropdown.stories.js';
|
|
4
4
|
|
|
5
|
-
<Meta
|
|
6
|
-
title='Form/Dropdown'
|
|
7
|
-
component='PixDropdown'
|
|
8
|
-
argTypes={stories.argTypes}
|
|
9
|
-
/>
|
|
5
|
+
<Meta title="Form/Dropdown" component="PixDropdown" argTypes={stories.argTypes} />
|
|
10
6
|
|
|
11
7
|
# Pix Dropdown
|
|
12
8
|
|
|
@@ -14,16 +10,16 @@ Affiche un menu déroulant avec la liste des options fournies.
|
|
|
14
10
|
|
|
15
11
|
Les options sont représentées par un tableau d'objet contenant les propriétés value et label.
|
|
16
12
|
|
|
17
|
-
> **⚠️**
|
|
13
|
+
> **⚠️** **Il est nécessaire d'avoir au moins un label ou un placeholder !**
|
|
18
14
|
|
|
19
|
-
> **⚠️**
|
|
15
|
+
> **⚠️** **N'oubliez pas de rajouter un searchLabel dans le cas ou le menu déroulant est cherchable pour le rendre accessible !**
|
|
20
16
|
|
|
21
17
|
> Pour aider l'utilisateur, rajoutez un placeholder cohérent !
|
|
22
18
|
|
|
23
19
|
## Default
|
|
24
20
|
|
|
25
21
|
<Canvas>
|
|
26
|
-
<Story name=
|
|
22
|
+
<Story name="Dropdown" story={stories.Default} height={200} />
|
|
27
23
|
</Canvas>
|
|
28
24
|
|
|
29
25
|
## With label
|
|
@@ -48,11 +44,11 @@ Les options sont représentées par un tableau d'objet contenant les propriété
|
|
|
48
44
|
|
|
49
45
|
```html
|
|
50
46
|
<PixDropdown
|
|
51
|
-
@id={{id}}
|
|
52
|
-
@options={{options}}
|
|
53
|
-
@onSelect={{onSelect}}
|
|
47
|
+
@id="{{id}}"
|
|
48
|
+
@options="{{options}}"
|
|
49
|
+
@onSelect="{{onSelect}}"
|
|
54
50
|
@selectedOption="1"
|
|
55
|
-
@isSearchable={{false}}
|
|
51
|
+
@isSearchable="{{false}}"
|
|
56
52
|
@placeholder="Choisissez une option"
|
|
57
53
|
@searchPlaceholder="Rechercher"
|
|
58
54
|
@label="Mon menu déroulant"
|
|
@@ -60,7 +56,7 @@ Les options sont représentées par un tableau d'objet contenant les propriété
|
|
|
60
56
|
@clearLabel="Supprimer la sélection"
|
|
61
57
|
@expandLabel="Ouvrir le menu déroulant"
|
|
62
58
|
@collapseLabel="Réduire le menu déroulant"
|
|
63
|
-
@pageSize={{10}}
|
|
59
|
+
@pageSize="{{10}}"
|
|
64
60
|
/>
|
|
65
61
|
```
|
|
66
62
|
|
|
@@ -25,6 +25,7 @@ filterBanner.args = {
|
|
|
25
25
|
{ value: '2', label: 'Mozza' },
|
|
26
26
|
],
|
|
27
27
|
onChange: action('select-onchange'),
|
|
28
|
+
onClearFilters: action('onClearFilters'),
|
|
28
29
|
};
|
|
29
30
|
|
|
30
31
|
export const argTypes = {
|
|
@@ -32,24 +33,20 @@ export const argTypes = {
|
|
|
32
33
|
name: 'title',
|
|
33
34
|
description: 'Titre du filtre',
|
|
34
35
|
type: { name: 'string', required: false },
|
|
35
|
-
defaultValue: null,
|
|
36
36
|
},
|
|
37
37
|
details: {
|
|
38
38
|
name: 'details',
|
|
39
39
|
description: 'Détails du filtre',
|
|
40
40
|
type: { name: 'string', required: false },
|
|
41
|
-
defaultValue: null,
|
|
42
41
|
},
|
|
43
42
|
clearFiltersLabel: {
|
|
44
43
|
name: 'clearFiltersLabel',
|
|
45
44
|
description: 'libellé du bouton',
|
|
46
45
|
type: { name: 'string', required: false },
|
|
47
|
-
defaultValue: null,
|
|
48
46
|
},
|
|
49
47
|
onClearFilters: {
|
|
50
48
|
name: 'onClearFilters',
|
|
51
49
|
description: 'fonction à appeler pour déclencher l’action de suppression des filtres',
|
|
52
50
|
type: { required: false },
|
|
53
|
-
defaultValue: action('onClearFilters'),
|
|
54
51
|
},
|
|
55
52
|
};
|