@ark-ui/solid 3.8.0 → 3.10.0

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 (58) hide show
  1. package/dist/cjs/index.js +200 -5
  2. package/dist/cjs/index.js.map +1 -1
  3. package/dist/esm/index.js +179 -6
  4. package/dist/esm/index.js.map +1 -1
  5. package/dist/source/components/checkbox/checkbox-group.jsx +1 -0
  6. package/dist/source/components/checkbox/use-checkbox-group.js +2 -0
  7. package/dist/source/components/editable/editable-root.jsx +3 -2
  8. package/dist/source/components/editable/index.js +1 -0
  9. package/dist/source/components/editable/use-editable.js +2 -0
  10. package/dist/source/components/index.js +1 -0
  11. package/dist/source/components/select/select-hidden-select.jsx +1 -1
  12. package/dist/source/components/steps/index.js +19 -0
  13. package/dist/source/components/steps/steps-completed-content.jsx +8 -0
  14. package/dist/source/components/steps/steps-content.jsx +10 -0
  15. package/dist/source/components/steps/steps-context.jsx +5 -0
  16. package/dist/source/components/steps/steps-indicator.jsx +10 -0
  17. package/dist/source/components/steps/steps-item-context.jsx +5 -0
  18. package/dist/source/components/steps/steps-item.jsx +18 -0
  19. package/dist/source/components/steps/steps-list.jsx +8 -0
  20. package/dist/source/components/steps/steps-next-trigger.jsx +8 -0
  21. package/dist/source/components/steps/steps-prev-trigger.jsx +8 -0
  22. package/dist/source/components/steps/steps-progress.jsx +8 -0
  23. package/dist/source/components/steps/steps-root-provider.jsx +11 -0
  24. package/dist/source/components/steps/steps-root.jsx +23 -0
  25. package/dist/source/components/steps/steps-separator.jsx +10 -0
  26. package/dist/source/components/steps/steps-trigger.jsx +10 -0
  27. package/dist/source/components/steps/steps.anatomy.js +1 -0
  28. package/dist/source/components/steps/steps.js +14 -0
  29. package/dist/source/components/steps/use-steps-context.js +5 -0
  30. package/dist/source/components/steps/use-steps-item-context.js +5 -0
  31. package/dist/source/components/steps/use-steps-item-props-context.js +5 -0
  32. package/dist/source/components/steps/use-steps.js +18 -0
  33. package/dist/types/components/checkbox/use-checkbox-group.d.ts +6 -0
  34. package/dist/types/components/editable/index.d.ts +3 -0
  35. package/dist/types/components/editable/use-editable.d.ts +6 -1
  36. package/dist/types/components/index.d.ts +1 -0
  37. package/dist/types/components/steps/index.d.ts +20 -0
  38. package/dist/types/components/steps/steps-completed-content.d.ts +6 -0
  39. package/dist/types/components/steps/steps-content.d.ts +7 -0
  40. package/dist/types/components/steps/steps-context.d.ts +6 -0
  41. package/dist/types/components/steps/steps-indicator.d.ts +6 -0
  42. package/dist/types/components/steps/steps-item-context.d.ts +9 -0
  43. package/dist/types/components/steps/steps-item.d.ts +7 -0
  44. package/dist/types/components/steps/steps-list.d.ts +6 -0
  45. package/dist/types/components/steps/steps-next-trigger.d.ts +6 -0
  46. package/dist/types/components/steps/steps-prev-trigger.d.ts +6 -0
  47. package/dist/types/components/steps/steps-progress.d.ts +6 -0
  48. package/dist/types/components/steps/steps-root-provider.d.ts +11 -0
  49. package/dist/types/components/steps/steps-root.d.ts +7 -0
  50. package/dist/types/components/steps/steps-separator.d.ts +6 -0
  51. package/dist/types/components/steps/steps-trigger.d.ts +6 -0
  52. package/dist/types/components/steps/steps.anatomy.d.ts +1 -0
  53. package/dist/types/components/steps/steps.d.ts +15 -0
  54. package/dist/types/components/steps/use-steps-context.d.ts +4 -0
  55. package/dist/types/components/steps/use-steps-item-context.d.ts +5 -0
  56. package/dist/types/components/steps/use-steps-item-props-context.d.ts +4 -0
  57. package/dist/types/components/steps/use-steps.d.ts +13 -0
  58. package/package.json +49 -49
package/dist/cjs/index.js CHANGED
@@ -43,6 +43,7 @@ var toggleGroup$1 = require('@zag-js/toggle-group');
43
43
  var tooltip$1 = require('@zag-js/tooltip');
44
44
  var treeView$1 = require('@zag-js/tree-view');
45
45
  var timer$1 = require('@zag-js/timer');
46
+ var steps$1 = require('@zag-js/steps');
46
47
 
47
48
  function _interopNamespaceDefault(e) {
48
49
  var n = Object.create(null);
@@ -97,6 +98,7 @@ var toggleGroup__namespace = /*#__PURE__*/_interopNamespaceDefault(toggleGroup$1
97
98
  var tooltip__namespace = /*#__PURE__*/_interopNamespaceDefault(tooltip$1);
98
99
  var treeView__namespace = /*#__PURE__*/_interopNamespaceDefault(treeView$1);
99
100
  var timer__namespace = /*#__PURE__*/_interopNamespaceDefault(timer$1);
101
+ var steps__namespace = /*#__PURE__*/_interopNamespaceDefault(steps$1);
100
102
 
101
103
  function getErrorMessage(hook, provider) {
102
104
  return `${hook} returned \`undefined\`. Seems you forgot to wrap component within ${provider}`;
@@ -709,7 +711,8 @@ function useCheckboxGroup(props = {}) {
709
711
  },
710
712
  name: props.name,
711
713
  disabled: props.disabled,
712
- readOnly: props.readOnly
714
+ readOnly: props.readOnly,
715
+ invalid: props.invalid
713
716
  };
714
717
  };
715
718
  return {
@@ -718,6 +721,7 @@ function useCheckboxGroup(props = {}) {
718
721
  name: props.name,
719
722
  disabled: props.disabled,
720
723
  readOnly: props.readOnly,
724
+ invalid: props.invalid,
721
725
  setValue,
722
726
  addValue,
723
727
  toggleValue,
@@ -733,7 +737,7 @@ const [CheckboxGroupContextProvider, useCheckboxGroupContext] = createContext({
733
737
  });
734
738
 
735
739
  const CheckboxGroup = props => {
736
- const [checkboxGroupProps, localProps] = createSplitProps()(props, ['defaultValue', 'value', 'onValueChange', 'disabled', 'readOnly', 'name']);
740
+ const [checkboxGroupProps, localProps] = createSplitProps()(props, ['defaultValue', 'value', 'onValueChange', 'disabled', 'invalid', 'readOnly', 'name']);
737
741
  const checkboxGroup = useCheckboxGroup(checkboxGroupProps);
738
742
  return web.createComponent(CheckboxGroupContextProvider, {
739
743
  value: checkboxGroup,
@@ -2572,7 +2576,9 @@ const useEditable = props => {
2572
2576
  readOnly: field?.().readOnly,
2573
2577
  required: field?.().required,
2574
2578
  getRootNode: environment().getRootNode,
2579
+ edit: props.defaultEdit,
2575
2580
  value: props.defaultValue,
2581
+ 'edit.controlled': props.edit !== undefined,
2576
2582
  ...props
2577
2583
  }));
2578
2584
  const [state, send] = solid.useMachine(editable__namespace.machine(context()), {
@@ -2582,7 +2588,7 @@ const useEditable = props => {
2582
2588
  };
2583
2589
 
2584
2590
  const EditableRoot = props => {
2585
- const [useEditableProps, localProps] = createSplitProps()(props, ['activationMode', 'autoResize', 'defaultValue', 'disabled', 'finalFocusEl', 'form', 'id', 'ids', 'invalid', 'maxLength', 'name', 'onEdit', 'onFocusOutside', 'onInteractOutside', 'onPointerDownOutside', 'onValueChange', 'onValueCommit', 'onValueRevert', 'placeholder', 'readOnly', 'required', 'selectOnFocus', 'startWithEditView', 'submitMode', 'translations', 'value']);
2591
+ const [useEditableProps, localProps] = createSplitProps()(props, ['activationMode', 'autoResize', 'defaultEdit', 'defaultValue', 'disabled', 'edit', 'finalFocusEl', 'form', 'id', 'ids', 'invalid', 'maxLength', 'name', 'onEditChange', 'onFocusOutside', 'onInteractOutside', 'onPointerDownOutside', 'onValueChange', 'onValueCommit', 'onValueRevert', 'placeholder', 'readOnly', 'required', 'selectOnFocus', 'submitMode', 'translations', 'value']);
2586
2592
  const api = useEditable(useEditableProps);
2587
2593
  const mergedProps = solid.mergeProps(() => api().getRootProps(), localProps);
2588
2594
  return web.createComponent(EditableProvider, {
@@ -4452,8 +4458,8 @@ const SelectHiddenSelect = props => {
4452
4458
  },
4453
4459
  children: item => (() => {
4454
4460
  var _el$2 = _tmpl$2$1();
4455
- web.effect(() => _el$2.disabled = select().collection.getItemDisabled(item));
4456
- web.effect(() => _el$2.value = select().collection.getItemValue(item) ?? '');
4461
+ web.effect(() => _el$2.disabled = select().collection.getItemDisabled(item()));
4462
+ web.effect(() => _el$2.value = select().collection.getItemValue(item()) ?? '');
4457
4463
  return _el$2;
4458
4464
  })()
4459
4465
  })];
@@ -6171,6 +6177,173 @@ var timer = /*#__PURE__*/Object.freeze({
6171
6177
  Separator: TimerSeparator
6172
6178
  });
6173
6179
 
6180
+ const [StepsProvider, useStepsContext] = createContext({
6181
+ hookName: 'useStepsContext',
6182
+ providerName: '<StepsProvider />'
6183
+ });
6184
+
6185
+ const StepsCompletedContent = props => {
6186
+ const steps = useStepsContext();
6187
+ const mergedProps = solid.mergeProps(() => steps().getContentProps({
6188
+ index: steps().count
6189
+ }), props);
6190
+ return web.createComponent(ark.div, mergedProps);
6191
+ };
6192
+
6193
+ const StepsContent = props => {
6194
+ const [itemProps, localProps] = createSplitProps()(props, ['index']);
6195
+ const steps = useStepsContext();
6196
+ const mergedProps = solid.mergeProps(() => steps().getContentProps(itemProps), localProps);
6197
+ return web.createComponent(ark.div, mergedProps);
6198
+ };
6199
+
6200
+ const StepsContext = props => {
6201
+ const context = useStepsContext();
6202
+ return props.children(context);
6203
+ };
6204
+
6205
+ const [StepsItemPropsProvider, useStepsItemPropsContext] = createContext({
6206
+ hookName: 'useStepsItemPropsContext',
6207
+ providerName: '<StepsItemPropsProvider />'
6208
+ });
6209
+
6210
+ const StepsIndicator = props => {
6211
+ const steps = useStepsContext();
6212
+ const itemProps = useStepsItemPropsContext();
6213
+ const mergedProps = solid.mergeProps(() => steps().getIndicatorProps(itemProps), props);
6214
+ return web.createComponent(ark.div, mergedProps);
6215
+ };
6216
+
6217
+ const [StepsItemProvider, useStepsItemContext] = createContext({
6218
+ hookName: 'useStepsItemContext',
6219
+ providerName: '<StepsItem />'
6220
+ });
6221
+
6222
+ const StepsItem = props => {
6223
+ const [itemProps, localProps] = createSplitProps()(props, ['index']);
6224
+ const steps = useStepsContext();
6225
+ const mergedProps = solid.mergeProps(() => steps().getItemProps(itemProps), localProps);
6226
+ const itemState = solidJs.createMemo(() => steps().getItemState(itemProps));
6227
+ return web.createComponent(StepsItemPropsProvider, {
6228
+ value: itemProps,
6229
+ get children() {
6230
+ return web.createComponent(StepsItemProvider, {
6231
+ value: itemState,
6232
+ get children() {
6233
+ return web.createComponent(ark.li, mergedProps);
6234
+ }
6235
+ });
6236
+ }
6237
+ });
6238
+ };
6239
+
6240
+ const StepsItemContext = props => {
6241
+ return props.children(useStepsItemContext());
6242
+ };
6243
+ StepsItemContext.displayName = 'StepsItemContext';
6244
+
6245
+ const StepsList = props => {
6246
+ const steps = useStepsContext();
6247
+ const mergedProps = solid.mergeProps(() => steps().getListProps(), props);
6248
+ return web.createComponent(ark.ol, mergedProps);
6249
+ };
6250
+
6251
+ const StepsNextTrigger = props => {
6252
+ const steps = useStepsContext();
6253
+ const mergedProps = solid.mergeProps(() => steps().getNextTriggerProps(), props);
6254
+ return web.createComponent(ark.button, mergedProps);
6255
+ };
6256
+
6257
+ const StepsPrevTrigger = props => {
6258
+ const steps = useStepsContext();
6259
+ const mergedProps = solid.mergeProps(() => steps().getPrevTriggerProps(), props);
6260
+ return web.createComponent(ark.button, mergedProps);
6261
+ };
6262
+
6263
+ const StepsProgress = props => {
6264
+ const steps = useStepsContext();
6265
+ const mergedProps = solid.mergeProps(() => steps().getProgressProps(), props);
6266
+ return web.createComponent(ark.div, mergedProps);
6267
+ };
6268
+
6269
+ function useSteps(props = {}) {
6270
+ const environment = useEnvironmentContext();
6271
+ const locale = useLocaleContext();
6272
+ const id = solidJs.createUniqueId();
6273
+ const context = solidJs.createMemo(() => ({
6274
+ id,
6275
+ dir: locale().dir,
6276
+ getRootNode: environment().getRootNode,
6277
+ step: props.defaultStep,
6278
+ ...props
6279
+ }));
6280
+ const [state, send] = solid.useMachine(steps__namespace.machine(context()), {
6281
+ context
6282
+ });
6283
+ return solidJs.createMemo(() => steps__namespace.connect(state, send, solid.normalizeProps));
6284
+ }
6285
+
6286
+ const StepsRoot = props => {
6287
+ const [useStepsProps, localProps] = createSplitProps()(props, ['defaultStep', 'id', 'ids', 'count', 'linear', 'onStepChange', 'onStepComplete', 'orientation', 'step']);
6288
+ const steps = useSteps(useStepsProps);
6289
+ const mergedProps = solid.mergeProps(() => steps().getRootProps(), localProps);
6290
+ return web.createComponent(StepsProvider, {
6291
+ value: steps,
6292
+ get children() {
6293
+ return web.createComponent(ark.div, mergedProps);
6294
+ }
6295
+ });
6296
+ };
6297
+
6298
+ const StepsRootProvider = props => {
6299
+ const [{
6300
+ value: steps
6301
+ }, rootProps] = createSplitProps()(props, ['value']);
6302
+ const mergedProps = solid.mergeProps(() => steps().getRootProps(), rootProps);
6303
+ return web.createComponent(StepsProvider, {
6304
+ value: steps,
6305
+ get children() {
6306
+ return web.createComponent(ark.div, web.mergeProps(mergedProps, {
6307
+ get children() {
6308
+ return props.children;
6309
+ }
6310
+ }));
6311
+ }
6312
+ });
6313
+ };
6314
+
6315
+ const StepsSeparator = props => {
6316
+ const steps = useStepsContext();
6317
+ const itemProps = useStepsItemPropsContext();
6318
+ const mergedProps = solid.mergeProps(() => steps().getSeparatorProps(itemProps), props);
6319
+ return web.createComponent(ark.div, mergedProps);
6320
+ };
6321
+
6322
+ const StepsTrigger = props => {
6323
+ const steps = useStepsContext();
6324
+ const itemProps = useStepsItemPropsContext();
6325
+ const mergedProps = solid.mergeProps(() => steps().getTriggerProps(itemProps), props);
6326
+ return web.createComponent(ark.button, mergedProps);
6327
+ };
6328
+
6329
+ var steps = /*#__PURE__*/Object.freeze({
6330
+ __proto__: null,
6331
+ CompletedContent: StepsCompletedContent,
6332
+ Content: StepsContent,
6333
+ Context: StepsContext,
6334
+ Indicator: StepsIndicator,
6335
+ Item: StepsItem,
6336
+ ItemContext: StepsItemContext,
6337
+ List: StepsList,
6338
+ NextTrigger: StepsNextTrigger,
6339
+ PrevTrigger: StepsPrevTrigger,
6340
+ Progress: StepsProgress,
6341
+ Root: StepsRoot,
6342
+ RootProvider: StepsRootProvider,
6343
+ Separator: StepsSeparator,
6344
+ Trigger: StepsTrigger
6345
+ });
6346
+
6174
6347
  Object.defineProperty(exports, "collapsibleAnatomy", {
6175
6348
  enumerable: true,
6176
6349
  get: function () { return collapsible$1.anatomy; }
@@ -6287,6 +6460,10 @@ Object.defineProperty(exports, "treeViewAnatomy", {
6287
6460
  enumerable: true,
6288
6461
  get: function () { return treeView$1.anatomy; }
6289
6462
  });
6463
+ Object.defineProperty(exports, "stepsAnatomy", {
6464
+ enumerable: true,
6465
+ get: function () { return steps$1.anatomy; }
6466
+ });
6290
6467
  exports.Accordion = accordion;
6291
6468
  exports.AccordionContext = AccordionContext;
6292
6469
  exports.AccordionItem = AccordionItem;
@@ -6647,6 +6824,21 @@ exports.SplitterPanel = SplitterPanel;
6647
6824
  exports.SplitterResizeTrigger = SplitterResizeTrigger;
6648
6825
  exports.SplitterRoot = SplitterRoot;
6649
6826
  exports.SplitterRootProvider = SplitterRootProvider;
6827
+ exports.Steps = steps;
6828
+ exports.StepsCompletedContent = StepsCompletedContent;
6829
+ exports.StepsContent = StepsContent;
6830
+ exports.StepsContext = StepsContext;
6831
+ exports.StepsIndicator = StepsIndicator;
6832
+ exports.StepsItem = StepsItem;
6833
+ exports.StepsItemContext = StepsItemContext;
6834
+ exports.StepsList = StepsList;
6835
+ exports.StepsNextTrigger = StepsNextTrigger;
6836
+ exports.StepsPrevTrigger = StepsPrevTrigger;
6837
+ exports.StepsProgress = StepsProgress;
6838
+ exports.StepsRoot = StepsRoot;
6839
+ exports.StepsRootProvider = StepsRootProvider;
6840
+ exports.StepsSeparator = StepsSeparator;
6841
+ exports.StepsTrigger = StepsTrigger;
6650
6842
  exports.Switch = _switch;
6651
6843
  exports.SwitchContext = SwitchContext;
6652
6844
  exports.SwitchControl = SwitchControl;
@@ -6817,6 +7009,9 @@ exports.useSlider = useSlider;
6817
7009
  exports.useSliderContext = useSliderContext;
6818
7010
  exports.useSplitter = useSplitter;
6819
7011
  exports.useSplitterContext = useSplitterContext;
7012
+ exports.useSteps = useSteps;
7013
+ exports.useStepsContext = useStepsContext;
7014
+ exports.useStepsItemContext = useStepsItemContext;
6820
7015
  exports.useSwitch = useSwitch;
6821
7016
  exports.useSwitchContext = useSwitchContext;
6822
7017
  exports.useTabs = useTabs;