@iress-oss/ids-mcp-server 5.15.0 → 5.20.2

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.
Files changed (134) hide show
  1. package/generated/docs/components_components-alert-docs.md +496 -0
  2. package/generated/docs/components_components-autocomplete-docs.md +3429 -0
  3. package/generated/docs/{components-autocomplete-recipes-docs.md → components_components-autocomplete-recipes-docs.md} +39 -14
  4. package/generated/docs/{components-badge-docs.md → components_components-badge-docs.md} +222 -30
  5. package/generated/docs/components_components-button-docs.md +2078 -0
  6. package/generated/docs/components_components-button-recipes-docs.md +37 -0
  7. package/generated/docs/components_components-buttongroup-docs.md +1045 -0
  8. package/generated/docs/components_components-card-docs.md +2290 -0
  9. package/generated/docs/{components-card-recipes-docs.md → components_components-card-recipes-docs.md} +132 -15
  10. package/generated/docs/components_components-checkbox-docs.md +1040 -0
  11. package/generated/docs/{components-checkboxgroup-docs.md → components_components-checkboxgroup-docs.md} +1001 -82
  12. package/generated/docs/{components-checkboxgroup-recipes-docs.md → components_components-checkboxgroup-recipes-docs.md} +102 -12
  13. package/generated/docs/{components-col-docs.md → components_components-col-docs.md} +331 -58
  14. package/generated/docs/components_components-combobox-docs.md +3735 -0
  15. package/generated/docs/{components-container-docs.md → components_components-container-docs.md} +61 -24
  16. package/generated/docs/{components-divider-docs.md → components_components-divider-docs.md} +83 -24
  17. package/generated/docs/{components-expander-docs.md → components_components-expander-docs.md} +266 -33
  18. package/generated/docs/components_components-field-docs.md +1369 -0
  19. package/generated/docs/components_components-filter-docs.md +4080 -0
  20. package/generated/docs/{components-form-docs.md → components_components-form-docs.md} +1556 -360
  21. package/generated/docs/{components-form-recipes-docs.md → components_components-form-recipes-docs.md} +277 -60
  22. package/generated/docs/{components-hide-docs.md → components_components-hide-docs.md} +195 -124
  23. package/generated/docs/components_components-icon-docs.md +1337 -0
  24. package/generated/docs/{components-inline-docs.md → components_components-inline-docs.md} +462 -42
  25. package/generated/docs/components_components-input-docs.md +1468 -0
  26. package/generated/docs/components_components-input-recipes-docs.md +367 -0
  27. package/generated/docs/components_components-inputcurrency-docs.md +432 -0
  28. package/generated/docs/{components-inputcurrency-recipes-docs.md → components_components-inputcurrency-recipes-docs.md} +113 -17
  29. package/generated/docs/components_components-label-docs.md +323 -0
  30. package/generated/docs/components_components-menu-docs.md +2345 -0
  31. package/generated/docs/components_components-menu-menuitem-docs.md +633 -0
  32. package/generated/docs/{components-modal-docs.md → components_components-modal-docs.md} +1640 -231
  33. package/generated/docs/components_components-navbar-docs.md +1847 -0
  34. package/generated/docs/{components-navbar-recipes-docs.md → components_components-navbar-recipes-docs.md} +721 -40
  35. package/generated/docs/{components-panel-docs.md → components_components-panel-docs.md} +754 -57
  36. package/generated/docs/components_components-placeholder-docs.md +92 -0
  37. package/generated/docs/components_components-popover-docs.md +1643 -0
  38. package/generated/docs/components_components-popover-recipes-docs.md +491 -0
  39. package/generated/docs/components_components-progress-docs.md +115 -0
  40. package/generated/docs/{components-provider-docs.md → components_components-provider-docs.md} +42 -33
  41. package/generated/docs/components_components-radio-docs.md +491 -0
  42. package/generated/docs/{components-radiogroup-docs.md → components_components-radiogroup-docs.md} +927 -75
  43. package/generated/docs/components_components-readonly-docs.md +263 -0
  44. package/generated/docs/components_components-richselect-docs.md +6521 -0
  45. package/generated/docs/{components-row-docs.md → components_components-row-docs.md} +353 -43
  46. package/generated/docs/{components-select-docs.md → components_components-select-docs.md} +719 -61
  47. package/generated/docs/components_components-skeleton-docs.md +480 -0
  48. package/generated/docs/{components-skeleton-recipes-docs.md → components_components-skeleton-recipes-docs.md} +51 -11
  49. package/generated/docs/{components-skiplink-docs.md → components_components-skiplink-docs.md} +53 -14
  50. package/generated/docs/components_components-slideout-docs.md +2293 -0
  51. package/generated/docs/components_components-slider-docs.md +1276 -0
  52. package/generated/docs/components_components-spinner-docs.md +82 -0
  53. package/generated/docs/{components-stack-docs.md → components_components-stack-docs.md} +223 -40
  54. package/generated/docs/components_components-table-docs.md +3658 -0
  55. package/generated/docs/components_components-tabset-docs.md +772 -0
  56. package/generated/docs/components_components-tabset-tab-docs.md +262 -0
  57. package/generated/docs/components_components-tag-docs.md +257 -0
  58. package/generated/docs/{components-text-docs.md → components_components-text-docs.md} +491 -51
  59. package/generated/docs/{components-toaster-docs.md → components_components-toaster-docs.md} +187 -85
  60. package/generated/docs/components_components-toaster-toast-docs.md +634 -0
  61. package/generated/docs/components_components-toggle-docs.md +461 -0
  62. package/generated/docs/{components-tooltip-docs.md → components_components-tooltip-docs.md} +286 -41
  63. package/generated/docs/{components-validationmessage-docs.md → components_components-validationmessage-docs.md} +230 -61
  64. package/generated/docs/components_contact-us-docs.md +12 -0
  65. package/generated/docs/{foundations-accessibility-docs.md → components_foundations-accessibility-docs.md} +11 -21
  66. package/generated/docs/{foundations-colours-docs.md → components_foundations-colour-030-colours.md} +8 -15
  67. package/generated/docs/{foundations-consistency-docs.md → components_foundations-consistency-docs.md} +12 -20
  68. package/generated/docs/{foundations-content-docs.md → components_foundations-content-docs.md} +6 -11
  69. package/generated/docs/components_foundations-introduction-docs.md +15 -0
  70. package/generated/docs/{foundations-principles-docs.md → components_foundations-principles-docs.md} +14 -24
  71. package/generated/docs/components_foundations-typography-docs.md +608 -0
  72. package/generated/docs/{foundations-user-experience-docs.md → components_foundations-user-experience-docs.md} +16 -26
  73. package/generated/docs/{foundations-visual-design-docs.md → components_foundations-visual-design-docs.md} +10 -17
  74. package/generated/docs/{frequently-asked-questions-docs.md → components_frequently-asked-questions-docs.md} +14 -23
  75. package/generated/docs/components_get-started-develop-docs.md +84 -0
  76. package/generated/docs/components_get-started-using-storybook-docs.md +55 -0
  77. package/generated/docs/components_introduction-docs.md +15 -0
  78. package/generated/docs/{patterns-loading-docs.md → components_patterns-loading-docs.md} +798 -153
  79. package/generated/docs/components_resources-changelog-docs.md +4 -0
  80. package/generated/docs/{resources-code-katas-docs.md → components_resources-code-katas-docs.md} +5 -9
  81. package/generated/docs/{resources-migration-guides-from-v4-to-v5-docs.md → components_resources-migration-guides-from-v4-to-v5-docs.md} +54 -239
  82. package/generated/docs/components_sandbox-docs.md +4 -0
  83. package/generated/docs/{versions-docs.md → components_versions-docs.md} +5 -8
  84. package/generated/docs/guidelines.md +484 -200
  85. package/generated/docs/introduction-docs.md +19 -30
  86. package/package.json +41 -45
  87. package/generated/docs/components-alert-docs.md +0 -130
  88. package/generated/docs/components-autocomplete-docs.md +0 -754
  89. package/generated/docs/components-button-docs.md +0 -362
  90. package/generated/docs/components-button-recipes-docs.md +0 -76
  91. package/generated/docs/components-buttongroup-docs.md +0 -310
  92. package/generated/docs/components-card-docs.md +0 -494
  93. package/generated/docs/components-checkbox-docs.md +0 -193
  94. package/generated/docs/components-combobox-docs.md +0 -1016
  95. package/generated/docs/components-field-docs.md +0 -675
  96. package/generated/docs/components-filter-docs.md +0 -1109
  97. package/generated/docs/components-icon-docs.md +0 -553
  98. package/generated/docs/components-input-docs.md +0 -335
  99. package/generated/docs/components-input-recipes-docs.md +0 -140
  100. package/generated/docs/components-inputcurrency-docs.md +0 -157
  101. package/generated/docs/components-label-docs.md +0 -135
  102. package/generated/docs/components-menu-docs.md +0 -704
  103. package/generated/docs/components-menu-menuitem-docs.md +0 -193
  104. package/generated/docs/components-navbar-docs.md +0 -291
  105. package/generated/docs/components-placeholder-docs.md +0 -27
  106. package/generated/docs/components-popover-docs.md +0 -464
  107. package/generated/docs/components-popover-recipes-docs.md +0 -245
  108. package/generated/docs/components-progress-docs.md +0 -104
  109. package/generated/docs/components-radio-docs.md +0 -107
  110. package/generated/docs/components-readonly-docs.md +0 -89
  111. package/generated/docs/components-richselect-docs.md +0 -2433
  112. package/generated/docs/components-skeleton-docs.md +0 -214
  113. package/generated/docs/components-slideout-docs.md +0 -538
  114. package/generated/docs/components-slider-docs.md +0 -346
  115. package/generated/docs/components-spinner-docs.md +0 -59
  116. package/generated/docs/components-table-ag-grid-docs.md +0 -1074
  117. package/generated/docs/components-table-docs.md +0 -1305
  118. package/generated/docs/components-tabset-docs.md +0 -341
  119. package/generated/docs/components-tabset-tab-docs.md +0 -86
  120. package/generated/docs/components-tag-docs.md +0 -115
  121. package/generated/docs/components-toaster-toast-docs.md +0 -157
  122. package/generated/docs/components-toggle-docs.md +0 -158
  123. package/generated/docs/contact-us-docs.md +0 -27
  124. package/generated/docs/extensions-editor-docs.md +0 -288
  125. package/generated/docs/extensions-editor-recipes-docs.md +0 -39
  126. package/generated/docs/foundations-introduction-docs.md +0 -17
  127. package/generated/docs/foundations-typography-docs.md +0 -191
  128. package/generated/docs/get-started-develop-docs.md +0 -209
  129. package/generated/docs/get-started-using-storybook-docs.md +0 -68
  130. package/generated/docs/resources-changelog-docs.md +0 -6
  131. package/generated/docs/themes-available-themes-docs.md +0 -66
  132. package/generated/docs/themes-introduction-docs.md +0 -121
  133. package/generated/docs/themes-tokens-docs.md +0 -1200
  134. /package/{LICENSE.txt → LICENSE} +0 -0
@@ -0,0 +1,367 @@
1
+ Recipes
2
+ =======
3
+
4
+ Percentage formatting
5
+ ---------------------
6
+
7
+ You can use `IressInput` to display percentage formatting. When the field is focused, it can display the raw value, and when blurred, it can display the formatted percentage value.
8
+
9
+ [](./iframe.html?id=components-input-recipes--percentage)
10
+
11
+ Hide codedrawOpen in CodeSandbox
12
+
13
+ import { IressInput } from '@iress-oss/ids-components';
14
+ export const InputPercentage \= () \=> (
15
+ <IressInput<number | string\>
16
+ defaultValue\="0.5"
17
+ formatter\={(value \= '') \=> {
18
+ if (value \=== '') return '';
19
+ const numericValue \= Number(value);
20
+ if (Number.isNaN(numericValue)) {
21
+ return String(value) ?? '';
22
+ }
23
+ return new Intl.NumberFormat('en-AU', {
24
+ style: 'percent',
25
+ }).format(numericValue);
26
+ }}
27
+ type\="number"
28
+ /\>
29
+ );
30
+
31
+ ```
32
+
33
+ #### Props
34
+
35
+ | Name | Description | Default | Control |
36
+ | --- | --- | --- | --- |
37
+ | alignRight |
38
+ Set input content align to right.
39
+
40
+ boolean
41
+
42
+
43
+
44
+ | \- | Set boolean |
45
+ | append |
46
+
47
+ Content to append to the input field, usually a button or icon.
48
+
49
+ ReactReactNode
50
+
51
+
52
+
53
+ | \- | Set object |
54
+ | clearable |
55
+
56
+ If `true`, then user can clear the value of the input. Will be ignored if `rows` prop is in use.
57
+
58
+ boolean
59
+
60
+
61
+
62
+ | \- | Set boolean |
63
+ | defaultValue |
64
+
65
+ The value of the input. Can be a string or a number. Use for uncontrolled inputs.
66
+
67
+ T
68
+
69
+
70
+
71
+ | \- | Set object |
72
+ | formatter |
73
+
74
+ Bring your own formatter that will be used to format the value when the input is not focused, allowing you to display the value in a different format. e.g. User type in value="dsf 987kkk123" => result after formatter: $987,123 (string)
75
+
76
+ (value?: T) => string | number
77
+
78
+ | \- | \- |
79
+ | inline |
80
+
81
+ Make prepend/append element closer to the input content.
82
+
83
+ boolean
84
+
85
+
86
+
87
+ | \- | Set boolean |
88
+ | loading |
89
+
90
+ The loading states of the input field. If provided a string, will use that text as the loading message.
91
+
92
+ union
93
+
94
+
95
+
96
+ | \- | Set object |
97
+ | onChange |
98
+
99
+ Emitted when the input value changes with the new changed value.
100
+
101
+ (e: React.ChangeEvent<InputBaseElement>, value: T) => void
102
+
103
+ | \- | \- |
104
+ | onClear |
105
+
106
+ Emitted when the input is manually cleared.
107
+
108
+ (e: React.ChangeEvent<InputBaseElement>) => void
109
+
110
+ | \- | \- |
111
+ | prepend |
112
+
113
+ Content to prepended to the input field, usually an icon.
114
+
115
+ ReactReactNode
116
+
117
+
118
+
119
+ | \- | Set object |
120
+ | value |
121
+
122
+ The value of the input. Can be a string or a number. Use for controlled inputs.
123
+
124
+ T
125
+
126
+
127
+
128
+ | \- | Set object |
129
+ | watermark |
130
+
131
+ When set to `true` add ons will render with a different style. Will be ignored if `prepend` or `append` props are not being used.
132
+
133
+ boolean
134
+
135
+
136
+
137
+ | \- | Set boolean |
138
+ | width |
139
+
140
+ The width of the input.
141
+
142
+ union
143
+
144
+
145
+
146
+ | \- | Set object |
147
+
148
+ Using with React Hook Forms
149
+ ---------------------------
150
+
151
+ You can use `IressInput` with React Hook Forms quite easily. The recommended way is to use the [`Controller` component from react-hook-forms](https://www.react-hook-form.com/get-started/#IntegratingwithUIlibraries). However, you can use the `register` method directly, with a few customisations to cater for custom `ref` as seen in the code example here.
152
+
153
+ Where possible, please use `IressFormField` within an [`IressForm` component](/docs/components-form--docs).
154
+
155
+ [](./iframe.html?id=components-input-recipes--react-hook-forms)
156
+
157
+ Although you can use `IressInput` directly with React Hook Forms, we recommend using `IressFormField` within `IressForm` for a more integrated experience.
158
+
159
+ Input using `{ Controller } from 'react-hook-forms'`
160
+
161
+ Input using `{ register } = useForm()`
162
+
163
+ Submit
164
+
165
+ Hide codedrawOpen in CodeSandbox
166
+
167
+ import {
168
+ type InputRef,
169
+ IressAlert,
170
+ IressButton,
171
+ IressInline,
172
+ IressInput,
173
+ IressLabel,
174
+ IressModal,
175
+ IressStack,
176
+ IressTable,
177
+ } from '@/main';
178
+ import { useState } from 'react';
179
+ import {
180
+ Controller,
181
+ type UseFormRegisterReturn,
182
+ useForm,
183
+ } from 'react-hook-form';
184
+ const registerInnerElement \= (register: UseFormRegisterReturn) \=> {
185
+ return {
186
+ ...register,
187
+ onClear: register.onChange,
188
+ ref: (ref: InputRef | null) \=> {
189
+ if (ref) {
190
+ register.ref(ref.input);
191
+ }
192
+ },
193
+ };
194
+ };
195
+ export const ReactHookFormsInput \= () \=> {
196
+ const { register, handleSubmit, control } \= useForm();
197
+ const \[data, setData\] \= useState<Record<string, string\> | undefined\>();
198
+ return (
199
+ // eslint-disable-next-line sonarjs/void-use -- This is a mock form submission
200
+ <form onSubmit\={void handleSubmit(setData)}\>
201
+ <IressStack gutter\="md"\>
202
+ <IressAlert status\="info"\>
203
+ Although you can use <code\>IressInput</code\> directly with React Hook Forms, we recommend using <code\>IressFormField</code\> within{' '}
204
+ <code\>IressForm</code\> for a more integrated experience. </IressAlert\>
205
+ <IressInline gutter\="md" verticalAlign\="middle"\>
206
+ <IressLabel htmlFor\="Controller"\>
207
+ Input using <code\>{\`{ Controller } from 'react-hook-forms'\`}</code\>
208
+ </IressLabel\>
209
+ <Controller
210
+ name\="Controller"
211
+ control\={control}
212
+ render\={({ field }) \=> (
213
+ <IressInput
214
+ {...field}
215
+ clearable
216
+ onClear\={field.onChange}
217
+ id\="firstName"
218
+ />
219
+ )}
220
+ />
221
+ </IressInline\>
222
+ <IressInline gutter\="md" verticalAlign\="middle"\>
223
+ <IressLabel htmlFor\="register"\>
224
+ Input using <code\>{\`{ register } = useForm()\`}</code\>
225
+ </IressLabel\>
226
+ <IressInput
227
+ {...registerInnerElement(register('register'))}
228
+ clearable
229
+ id\="register"
230
+ />
231
+ </IressInline\>
232
+ <IressButton type\="submit"\>Submit</IressButton\>
233
+ </IressStack\>
234
+ {data && (
235
+ <IressModal
236
+ show\={!!data}
237
+ onShowChange\={(show) \=> !show && setData(undefined)}
238
+ \>
239
+ <IressTable
240
+ caption\="Submitted details"
241
+ rows\={Object.entries(data ?? {}).map((entry) \=> ({
242
+ name: entry\[0\],
243
+ value: JSON.stringify(entry\[1\], null, 2),
244
+ }))}
245
+ />
246
+ </IressModal\>
247
+ )}
248
+ </form\>
249
+ );
250
+ };
251
+
252
+ ```
253
+
254
+ #### Props
255
+
256
+ | Name | Description | Default | Control |
257
+ | --- | --- | --- | --- |
258
+ | alignRight |
259
+ Set input content align to right.
260
+
261
+ boolean
262
+
263
+
264
+
265
+ | \- | Set boolean |
266
+ | append |
267
+
268
+ Content to append to the input field, usually a button or icon.
269
+
270
+ ReactReactNode
271
+
272
+
273
+
274
+ | \- | Set object |
275
+ | clearable |
276
+
277
+ If `true`, then user can clear the value of the input. Will be ignored if `rows` prop is in use.
278
+
279
+ boolean
280
+
281
+
282
+
283
+ | \- | Set boolean |
284
+ | defaultValue |
285
+
286
+ The value of the input. Can be a string or a number. Use for uncontrolled inputs.
287
+
288
+ T
289
+
290
+
291
+
292
+ | \- | Set object |
293
+ | formatter |
294
+
295
+ Bring your own formatter that will be used to format the value when the input is not focused, allowing you to display the value in a different format. e.g. User type in value="dsf 987kkk123" => result after formatter: $987,123 (string)
296
+
297
+ (value?: T) => string | number
298
+
299
+ | \- | \- |
300
+ | inline |
301
+
302
+ Make prepend/append element closer to the input content.
303
+
304
+ boolean
305
+
306
+
307
+
308
+ | \- | Set boolean |
309
+ | loading |
310
+
311
+ The loading states of the input field. If provided a string, will use that text as the loading message.
312
+
313
+ union
314
+
315
+
316
+
317
+ | \- | Set object |
318
+ | onChange |
319
+
320
+ Emitted when the input value changes with the new changed value.
321
+
322
+ (e: React.ChangeEvent<InputBaseElement>, value: T) => void
323
+
324
+ | \- | \- |
325
+ | onClear |
326
+
327
+ Emitted when the input is manually cleared.
328
+
329
+ (e: React.ChangeEvent<InputBaseElement>) => void
330
+
331
+ | \- | \- |
332
+ | prepend |
333
+
334
+ Content to prepended to the input field, usually an icon.
335
+
336
+ ReactReactNode
337
+
338
+
339
+
340
+ | \- | Set object |
341
+ | value |
342
+
343
+ The value of the input. Can be a string or a number. Use for controlled inputs.
344
+
345
+ T
346
+
347
+
348
+
349
+ | \- | Set object |
350
+ | watermark |
351
+
352
+ When set to `true` add ons will render with a different style. Will be ignored if `prepend` or `append` props are not being used.
353
+
354
+ boolean
355
+
356
+
357
+
358
+ | \- | Set boolean |
359
+ | width |
360
+
361
+ The width of the input.
362
+
363
+ union
364
+
365
+
366
+
367
+ | \- | Set object |