@process.co/ui 0.0.8 → 0.0.10

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/dist/index.js CHANGED
@@ -157,11 +157,12 @@ function _unsupported_iterable_to_array(o, minLen) {
157
157
  if (n === "Map" || n === "Set") return Array.from(n);
158
158
  if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
159
159
  }
160
- import * as React3 from 'react';
161
- import { createContext, useContext } from 'react';
160
+ import * as React2 from 'react';
161
+ import React2__default, { createContext, useContext, useCallback } from 'react';
162
162
  import { Slot } from '@radix-ui/react-slot';
163
163
  import * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';
164
- import { CheckIcon, CircleIcon, ChevronRightIcon } from 'lucide-react';
164
+ import { CheckIcon, CircleIcon, ChevronRightIcon, ChevronDownIcon, ChevronUpIcon } from 'lucide-react';
165
+ import * as SelectPrimitive from '@radix-ui/react-select';
165
166
  var __defProp = Object.defineProperty;
166
167
  var __export = function(target, all) {
167
168
  for(var name in all)__defProp(target, name, {
@@ -4887,7 +4888,7 @@ function Button(_param) {
4887
4888
  "asChild"
4888
4889
  ]);
4889
4890
  var Comp = asChild ? Slot : "button";
4890
- return /* @__PURE__ */ React3.createElement(Comp, _object_spread({
4891
+ return /* @__PURE__ */ React2.createElement(Comp, _object_spread({
4891
4892
  "data-slot": "button",
4892
4893
  className: cn(buttonVariants({
4893
4894
  variant: variant,
@@ -4898,19 +4899,19 @@ function Button(_param) {
4898
4899
  }
4899
4900
  function DropdownMenu(_param) {
4900
4901
  var props = _extends({}, _object_destructuring_empty(_param));
4901
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Root, _object_spread({
4902
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Root, _object_spread({
4902
4903
  "data-slot": "dropdown-menu"
4903
4904
  }, props));
4904
4905
  }
4905
4906
  function DropdownMenuPortal(_param) {
4906
4907
  var props = _extends({}, _object_destructuring_empty(_param));
4907
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Portal, _object_spread({
4908
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Portal, _object_spread({
4908
4909
  "data-slot": "dropdown-menu-portal"
4909
4910
  }, props));
4910
4911
  }
4911
4912
  function DropdownMenuTrigger(_param) {
4912
4913
  var props = _extends({}, _object_destructuring_empty(_param));
4913
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Trigger, _object_spread({
4914
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Trigger, _object_spread({
4914
4915
  "data-slot": "dropdown-menu-trigger"
4915
4916
  }, props));
4916
4917
  }
@@ -4919,7 +4920,7 @@ function DropdownMenuContent(_param) {
4919
4920
  "className",
4920
4921
  "sideOffset"
4921
4922
  ]);
4922
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Portal, null, /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Content, _object_spread({
4923
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Portal, null, /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Content, _object_spread({
4923
4924
  "data-slot": "dropdown-menu-content",
4924
4925
  sideOffset: sideOffset,
4925
4926
  className: cn("uii:bg-popover uii:text-popover-foreground uii:data-[state=open]:animate-in uii:data-[state=closed]:animate-out uii:data-[state=closed]:fade-out-0 uii:data-[state=open]:fade-in-0 uii:data-[state=closed]:zoom-out-95 uii:data-[state=open]:zoom-in-95 uii:data-[side=bottom]:slide-in-from-top-2 uii:data-[side=left]:slide-in-from-right-2 uii:data-[side=right]:slide-in-from-left-2 uii:data-[side=top]:slide-in-from-bottom-2 uii:z-50 uii:min-w-[8rem] uii:overflow-hidden uii:rounded-md uii:border uii:p-1 uii:shadow-md", className)
@@ -4929,14 +4930,14 @@ function DropdownMenuClose(_param) {
4929
4930
  var className = _param.className, props = _object_without_properties(_param, [
4930
4931
  "className"
4931
4932
  ]);
4932
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Item, _object_spread({
4933
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Item, _object_spread({
4933
4934
  "data-slot": "dropdown-menu-close",
4934
4935
  className: "hidden"
4935
4936
  }, props));
4936
4937
  }
4937
4938
  function DropdownMenuGroup(_param) {
4938
4939
  var props = _extends({}, _object_destructuring_empty(_param));
4939
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Group, _object_spread({
4940
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Group, _object_spread({
4940
4941
  "data-slot": "dropdown-menu-group"
4941
4942
  }, props));
4942
4943
  }
@@ -4945,14 +4946,14 @@ function ConfirmationDropdownMenuItem(_param) {
4945
4946
  var originalOnClick = props.onClick, rest = _object_without_properties(props, [
4946
4947
  "onClick"
4947
4948
  ]);
4948
- var _React3_useState = _sliced_to_array(React3.useState(false), 2), isConfirming = _React3_useState[0], setIsConfirming = _React3_useState[1];
4949
- return !isConfirming ? /* @__PURE__ */ React3.createElement(DropdownMenuItem, _object_spread_props(_object_spread({}, rest), {
4949
+ var _React2_useState = _sliced_to_array(React2.useState(false), 2), isConfirming = _React2_useState[0], setIsConfirming = _React2_useState[1];
4950
+ return !isConfirming ? /* @__PURE__ */ React2.createElement(DropdownMenuItem, _object_spread_props(_object_spread({}, rest), {
4950
4951
  onClick: function(e) {
4951
4952
  setIsConfirming(true);
4952
4953
  e.preventDefault();
4953
4954
  e.stopPropagation();
4954
4955
  }
4955
- })) : /* @__PURE__ */ React3.createElement(DropdownMenuItem, _object_spread_props(_object_spread({}, rest), {
4956
+ })) : /* @__PURE__ */ React2.createElement(DropdownMenuItem, _object_spread_props(_object_spread({}, rest), {
4956
4957
  onClick: function(e) {
4957
4958
  if (originalOnClick) {
4958
4959
  setIsConfirming(false);
@@ -4961,9 +4962,9 @@ function ConfirmationDropdownMenuItem(_param) {
4961
4962
  e.stopPropagation();
4962
4963
  }
4963
4964
  }
4964
- }), /* @__PURE__ */ React3.createElement("div", {
4965
+ }), /* @__PURE__ */ React2.createElement("div", {
4965
4966
  className: "flex flex-row gap-2 items-center"
4966
- }, /* @__PURE__ */ React3.createElement("div", {
4967
+ }, /* @__PURE__ */ React2.createElement("div", {
4967
4968
  className: "text-destructive"
4968
4969
  }, "Are you sure ?")));
4969
4970
  }
@@ -4973,7 +4974,7 @@ function DropdownMenuItem(_param) {
4973
4974
  "inset",
4974
4975
  "variant"
4975
4976
  ]);
4976
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Item, _object_spread({
4977
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Item, _object_spread({
4977
4978
  "data-slot": "dropdown-menu-item",
4978
4979
  "data-inset": inset,
4979
4980
  "data-variant": variant,
@@ -4986,19 +4987,19 @@ function DropdownMenuCheckboxItem(_param) {
4986
4987
  "children",
4987
4988
  "checked"
4988
4989
  ]);
4989
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.CheckboxItem, _object_spread({
4990
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.CheckboxItem, _object_spread({
4990
4991
  "data-slot": "dropdown-menu-checkbox-item",
4991
4992
  className: cn("uii:focus:bg-accent uii:focus:text-accent-foreground uii:relative uii:flex uii:cursor-default uii:items-center uii:gap-2 uii:rounded-sm uii:py-1.5 uii:pr-2 uii:pl-8 uii:text-sm uii:outline-hidden uii:select-none uii:data-[disabled]:pointer-events-none uii:data-[disabled]:opacity-50 uii:[&_svg]:pointer-events-none uii:[&_svg]:shrink-0 uii:[&_svg:not([class*=size-])]:size-4", className),
4992
4993
  checked: checked
4993
- }, props), /* @__PURE__ */ React3.createElement("span", {
4994
+ }, props), /* @__PURE__ */ React2.createElement("span", {
4994
4995
  className: "uii:pointer-events-none uii:absolute uii:left-2 uii:flex uii:size-3.5 uii:items-center uii:justify-center"
4995
- }, /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.ItemIndicator, null, /* @__PURE__ */ React3.createElement(CheckIcon, {
4996
+ }, /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.ItemIndicator, null, /* @__PURE__ */ React2.createElement(CheckIcon, {
4996
4997
  className: "uii:size-4"
4997
4998
  }))), children);
4998
4999
  }
4999
5000
  function DropdownMenuRadioGroup(_param) {
5000
5001
  var props = _extends({}, _object_destructuring_empty(_param));
5001
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.RadioGroup, _object_spread({
5002
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.RadioGroup, _object_spread({
5002
5003
  "data-slot": "dropdown-menu-radio-group"
5003
5004
  }, props));
5004
5005
  }
@@ -5007,12 +5008,12 @@ function DropdownMenuRadioItem(_param) {
5007
5008
  "className",
5008
5009
  "children"
5009
5010
  ]);
5010
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.RadioItem, _object_spread({
5011
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.RadioItem, _object_spread({
5011
5012
  "data-slot": "dropdown-menu-radio-item",
5012
5013
  className: cn("uii:focus:bg-accent uii:focus:text-accent-foreground uii:relative uii:flex uii:cursor-default uii:items-center uii:gap-2 uii:rounded-sm uii:py-1.5 uii:pr-2 uii:pl-8 uii:text-sm uii:outline-hidden uii:select-none uii:data-[disabled]:pointer-events-none uii:data-[disabled]:opacity-50 uii:[&_svg]:pointer-events-none uii:[&_svg]:shrink-0 uii:[&_svg:not([class*=size-])]:size-4", className)
5013
- }, props), /* @__PURE__ */ React3.createElement("span", {
5014
+ }, props), /* @__PURE__ */ React2.createElement("span", {
5014
5015
  className: "uii:pointer-events-none uii:absolute uii:left-2 uii:flex uii:size-3.5 uii:items-center uii:justify-center"
5015
- }, /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.ItemIndicator, null, /* @__PURE__ */ React3.createElement(CircleIcon, {
5016
+ }, /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.ItemIndicator, null, /* @__PURE__ */ React2.createElement(CircleIcon, {
5016
5017
  className: "uii:size-2 uii:fill-current"
5017
5018
  }))), children);
5018
5019
  }
@@ -5021,7 +5022,7 @@ function DropdownMenuLabel(_param) {
5021
5022
  "className",
5022
5023
  "inset"
5023
5024
  ]);
5024
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Label, _object_spread({
5025
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Label, _object_spread({
5025
5026
  "data-slot": "dropdown-menu-label",
5026
5027
  "data-inset": inset,
5027
5028
  className: cn("uii:px-2 uii:py-1.5 uii:text-sm uii:font-medium uii:data-[inset]:pl-8", className)
@@ -5031,7 +5032,7 @@ function DropdownMenuSeparator(_param) {
5031
5032
  var className = _param.className, props = _object_without_properties(_param, [
5032
5033
  "className"
5033
5034
  ]);
5034
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Separator, _object_spread({
5035
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Separator, _object_spread({
5035
5036
  "data-slot": "dropdown-menu-separator",
5036
5037
  className: cn("uii:bg-border uii:-mx-1 uii:my-1 uii:h-px", className)
5037
5038
  }, props));
@@ -5040,14 +5041,14 @@ function DropdownMenuShortcut(_param) {
5040
5041
  var className = _param.className, props = _object_without_properties(_param, [
5041
5042
  "className"
5042
5043
  ]);
5043
- return /* @__PURE__ */ React3.createElement("span", _object_spread({
5044
+ return /* @__PURE__ */ React2.createElement("span", _object_spread({
5044
5045
  "data-slot": "dropdown-menu-shortcut",
5045
5046
  className: cn("uii:text-muted-foreground uii:ml-auto uii:text-xs uii:tracking-widest", className)
5046
5047
  }, props));
5047
5048
  }
5048
5049
  function DropdownMenuSub(_param) {
5049
5050
  var props = _extends({}, _object_destructuring_empty(_param));
5050
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.Sub, _object_spread({
5051
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.Sub, _object_spread({
5051
5052
  "data-slot": "dropdown-menu-sub"
5052
5053
  }, props));
5053
5054
  }
@@ -5057,11 +5058,11 @@ function DropdownMenuSubTrigger(_param) {
5057
5058
  "inset",
5058
5059
  "children"
5059
5060
  ]);
5060
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.SubTrigger, _object_spread({
5061
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.SubTrigger, _object_spread({
5061
5062
  "data-slot": "dropdown-menu-sub-trigger",
5062
5063
  "data-inset": inset,
5063
5064
  className: cn("uii:focus:bg-accent uii:focus:text-accent-foreground uii:data-[state=open]:bg-accent uii:data-[state=open]:text-accent-foreground uii:flex uii:cursor-default uii:items-center uii:rounded-sm uii:px-2 uii:py-1.5 uii:text-sm uii:outline-hidden uii:select-none uii:data-[inset]:pl-8", className)
5064
- }, props), children, /* @__PURE__ */ React3.createElement(ChevronRightIcon, {
5065
+ }, props), children, /* @__PURE__ */ React2.createElement(ChevronRightIcon, {
5065
5066
  className: "uii:ml-auto uii:size-4"
5066
5067
  }));
5067
5068
  }
@@ -5069,7 +5070,7 @@ function DropdownMenuSubContent(_param) {
5069
5070
  var className = _param.className, props = _object_without_properties(_param, [
5070
5071
  "className"
5071
5072
  ]);
5072
- return /* @__PURE__ */ React3.createElement(DropdownMenuPrimitive.SubContent, _object_spread({
5073
+ return /* @__PURE__ */ React2.createElement(DropdownMenuPrimitive.SubContent, _object_spread({
5073
5074
  "data-slot": "dropdown-menu-sub-content",
5074
5075
  className: cn("uii:bg-popover uii:text-popover-foreground uii:data-[state=open]:animate-in uii:data-[state=closed]:animate-out uii:data-[state=closed]:fade-out-0 uii:data-[state=open]:fade-in-0 uii:data-[state=closed]:zoom-out-95 uii:data-[state=open]:zoom-in-95 uii:data-[side=bottom]:slide-in-from-top-2 uii:data-[side=left]:slide-in-from-right-2 uii:data-[side=right]:slide-in-from-left-2 uii:data-[side=top]:slide-in-from-bottom-2 uii:z-50 uii:min-w-[8rem] uii:overflow-hidden uii:rounded-md uii:border uii:p-1 uii:shadow-lg", className)
5075
5076
  }, props));
@@ -5089,40 +5090,82 @@ __export(fields_exports, {
5089
5090
  NestedFieldProvider: function() {
5090
5091
  return NestedFieldProvider;
5091
5092
  },
5093
+ NodePropertyProvider: function() {
5094
+ return NodePropertyProvider;
5095
+ },
5092
5096
  OPERATORS_BY_TYPE: function() {
5093
5097
  return OPERATORS_BY_TYPE;
5094
5098
  },
5095
5099
  Select: function() {
5096
- return Select;
5100
+ return Select2;
5097
5101
  },
5098
5102
  TemplateFieldProvider: function() {
5099
5103
  return TemplateFieldProvider;
5100
5104
  },
5105
+ computeExtendedType: function() {
5106
+ return computeExtendedType;
5107
+ },
5108
+ filterOperatorsByType: function() {
5109
+ return filterOperatorsByType;
5110
+ },
5111
+ getNumberConstants: function() {
5112
+ return getNumberConstants;
5113
+ },
5101
5114
  getOperatorsForType: function() {
5102
5115
  return getOperatorsForType;
5103
5116
  },
5117
+ getStringConstants: function() {
5118
+ return getStringConstants;
5119
+ },
5104
5120
  intersectTypes: function() {
5105
5121
  return intersectTypes;
5106
5122
  },
5107
5123
  parseInferSyntax: function() {
5108
5124
  return parseInferSyntax;
5109
5125
  },
5126
+ parseInferredTypes: function() {
5127
+ return parseInferredTypes;
5128
+ },
5129
+ useAllInferredTypes: function() {
5130
+ return useAllInferredTypes;
5131
+ },
5110
5132
  useFieldPath: function() {
5111
5133
  return useFieldPath;
5112
5134
  },
5135
+ useFieldValidation: function() {
5136
+ return useFieldValidation;
5137
+ },
5138
+ useInferredType: function() {
5139
+ return useInferredType;
5140
+ },
5113
5141
  useInferredTypes: function() {
5114
5142
  return useInferredTypes;
5115
5143
  },
5144
+ useIsInNodePropertyProvider: function() {
5145
+ return useIsInNodePropertyProvider;
5146
+ },
5116
5147
  useIsInTemplateFieldProvider: function() {
5117
5148
  return useIsInTemplateFieldProvider;
5118
5149
  },
5150
+ useNodeProperties: function() {
5151
+ return useNodeProperties;
5152
+ },
5153
+ useNodeProperty: function() {
5154
+ return useNodeProperty;
5155
+ },
5156
+ useSetInferredType: function() {
5157
+ return useSetInferredType;
5158
+ },
5159
+ useSetProperty: function() {
5160
+ return useSetProperty;
5161
+ },
5119
5162
  useTemplateFieldContext: function() {
5120
5163
  return useTemplateFieldContext;
5121
5164
  }
5122
5165
  });
5123
5166
  function Input(param) {
5124
5167
  var fieldName = param.fieldName, label = param.label, value = param.value, onChange = param.onChange, _param_disabled = param.disabled, disabled = _param_disabled === void 0 ? false : _param_disabled, placeholder = param.placeholder, _param_expectedType = param.expectedType, expectedType = _param_expectedType === void 0 ? "string" : _param_expectedType, _param_required = param.required, required = _param_required === void 0 ? false : _param_required, _param_hasRequiredError = param.hasRequiredError, hasRequiredError = _param_hasRequiredError === void 0 ? false : _param_hasRequiredError, className = param.className, editorClassName = param.editorClassName;
5125
- var displayValue = React3.useMemo(function() {
5168
+ var displayValue = React2.useMemo(function() {
5126
5169
  if (value && (typeof value === "undefined" ? "undefined" : _type_of(value)) === "object" && "expression" in value) {
5127
5170
  return value.expression || "";
5128
5171
  }
@@ -5130,12 +5173,12 @@ function Input(param) {
5130
5173
  }, [
5131
5174
  value
5132
5175
  ]);
5133
- var isExpression = React3.useMemo(function() {
5176
+ var isExpression = React2.useMemo(function() {
5134
5177
  return value && (typeof value === "undefined" ? "undefined" : _type_of(value)) === "object" && "expression" in value;
5135
5178
  }, [
5136
5179
  value
5137
5180
  ]);
5138
- var handleChange = React3.useCallback(function(e) {
5181
+ var handleChange = React2.useCallback(function(e) {
5139
5182
  var newValue = e.target.value;
5140
5183
  if (newValue.includes("{{")) {
5141
5184
  onChange({
@@ -5149,20 +5192,20 @@ function Input(param) {
5149
5192
  onChange
5150
5193
  ]);
5151
5194
  var showError = hasRequiredError || required && !displayValue;
5152
- return /* @__PURE__ */ React3.createElement("div", {
5195
+ return /* @__PURE__ */ React2.createElement("div", {
5153
5196
  className: cn("uii:mb-2", className)
5154
- }, /* @__PURE__ */ React3.createElement("div", {
5197
+ }, /* @__PURE__ */ React2.createElement("div", {
5155
5198
  className: "uii:flex uii:items-center uii:gap-2 uii:mt-2"
5156
- }, /* @__PURE__ */ React3.createElement("label", {
5199
+ }, /* @__PURE__ */ React2.createElement("label", {
5157
5200
  htmlFor: fieldName,
5158
5201
  className: "uii:text-xs uii:font-bold uii:text-muted-foreground"
5159
- }, label, ":"), expectedType !== "$.interface.timer" && /* @__PURE__ */ React3.createElement("span", {
5202
+ }, label, ":"), expectedType !== "$.interface.timer" && /* @__PURE__ */ React2.createElement("span", {
5160
5203
  className: "uii:-mt-2 uii:inline-flex uii:px-1 uii:py-0.5 uii:bg-gray-200 uii:rounded-sm uii:text-[10px] uii:font-mono uii:text-muted-foreground uii:font-light"
5161
- }, expectedType), showError && /* @__PURE__ */ React3.createElement("span", {
5204
+ }, expectedType), showError && /* @__PURE__ */ React2.createElement("span", {
5162
5205
  className: "uii:-mt-2 uii:inline-flex uii:px-1 uii:py-0.5 uii:bg-red-100 uii:text-red-600 uii:rounded-sm uii:text-[10px] uii:font-medium"
5163
- }, "Required")), /* @__PURE__ */ React3.createElement("div", {
5206
+ }, "Required")), /* @__PURE__ */ React2.createElement("div", {
5164
5207
  className: "uii:mt-0.5"
5165
- }, /* @__PURE__ */ React3.createElement("input", {
5208
+ }, /* @__PURE__ */ React2.createElement("input", {
5166
5209
  id: fieldName,
5167
5210
  name: fieldName,
5168
5211
  type: "text",
@@ -5173,11 +5216,93 @@ function Input(param) {
5173
5216
  className: cn("uii:w-full uii:h-9 uii:px-3 uii:rounded-sm uii:border uii:bg-background uii:text-sm", "uii:outline-none uii:transition-all", "focus:uii:border-ring focus:uii:ring-ring/50 focus:uii:ring-[3px]", showError ? "uii:border-red-500 hover:uii:border-red-600" : "uii:border-input hover:uii:border-ring/50", isExpression && "uii:font-mono uii:text-amber-600", disabled && "uii:opacity-50 uii:cursor-not-allowed", editorClassName)
5174
5217
  })));
5175
5218
  }
5176
- function Select(param) {
5219
+ function Select(_param) {
5220
+ var props = _extends({}, _object_destructuring_empty(_param));
5221
+ return /* @__PURE__ */ React2.createElement(SelectPrimitive.Root, _object_spread({
5222
+ "data-slot": "select"
5223
+ }, props));
5224
+ }
5225
+ function SelectValue(_param) {
5226
+ var props = _extends({}, _object_destructuring_empty(_param));
5227
+ return /* @__PURE__ */ React2.createElement(SelectPrimitive.Value, _object_spread({
5228
+ "data-slot": "select-value"
5229
+ }, props));
5230
+ }
5231
+ function SelectTrigger(_param) {
5232
+ var className = _param.className, children = _param.children, props = _object_without_properties(_param, [
5233
+ "className",
5234
+ "children"
5235
+ ]);
5236
+ return /* @__PURE__ */ React2.createElement(SelectPrimitive.Trigger, _object_spread({
5237
+ "data-slot": "select-trigger",
5238
+ className: cn("uii:border-input uii:data-[placeholder]:text-muted-foreground uii:[&_svg:not([class*=text-])]:text-muted-foreground uii:focus-visible:border-ring uii:focus-visible:ring-ring/50 uii:aria-invalid:ring-destructive/20 uii:dark:aria-invalid:ring-destructive/40 uii:aria-invalid:border-destructive uii:flex uii:h-9 uii:w-full uii:items-center uii:justify-between uii:gap-2 uii:rounded-md uii:border uii:bg-transparent uii:px-3 uii:py-2 uii:text-sm uii:whitespace-nowrap uii:shadow-xs uii:transition-[color,box-shadow] uii:outline-none uii:focus-visible:ring-[3px] uii:disabled:cursor-not-allowed uii:disabled:opacity-50 uii:*:data-[slot=select-value]:line-clamp-1 uii:*:data-[slot=select-value]:flex uii:*:data-[slot=select-value]:items-center uii:*:data-[slot=select-value]:gap-2 uii:[&_svg]:pointer-events-none uii:[&_svg]:shrink-0 uii:[&_svg:not([class*=size-])]:size-4", className)
5239
+ }, props), children, /* @__PURE__ */ React2.createElement(SelectPrimitive.Icon, {
5240
+ asChild: true
5241
+ }, /* @__PURE__ */ React2.createElement(ChevronDownIcon, {
5242
+ className: "uii:size-4 uii:opacity-50"
5243
+ })));
5244
+ }
5245
+ function SelectContent(_param) {
5246
+ var className = _param.className, children = _param.children, _param_position = _param.position, position = _param_position === void 0 ? "popper" : _param_position, footer = _param.footer, _param_hideScrollUpButton = _param.hideScrollUpButton, hideScrollUpButton = _param_hideScrollUpButton === void 0 ? false : _param_hideScrollUpButton, _param_hideScrollDownButton = _param.hideScrollDownButton, hideScrollDownButton = _param_hideScrollDownButton === void 0 ? false : _param_hideScrollDownButton, props = _object_without_properties(_param, [
5247
+ "className",
5248
+ "children",
5249
+ "position",
5250
+ "footer",
5251
+ "hideScrollUpButton",
5252
+ "hideScrollDownButton"
5253
+ ]);
5254
+ return /* @__PURE__ */ React2.createElement(SelectPrimitive.Portal, null, /* @__PURE__ */ React2.createElement(SelectPrimitive.Content, _object_spread({
5255
+ "data-slot": "select-content",
5256
+ className: cn("uii:bg-popover uii:text-popover-foreground uii:data-[state=open]:animate-in uii:data-[state=closed]:animate-out uii:data-[state=closed]:fade-out-0 uii:data-[state=open]:fade-in-0 uii:data-[state=closed]:zoom-out-95 uii:data-[state=open]:zoom-in-95 uii:data-[side=bottom]:slide-in-from-top-2 uii:data-[side=left]:slide-in-from-right-2 uii:data-[side=right]:slide-in-from-left-2 uii:data-[side=top]:slide-in-from-bottom-2 uii:relative uii:z-50 uii:max-h-96 uii:min-w-[8rem] uii:overflow-hidden uii:rounded-md uii:border uii:shadow-md", position === "popper" && "uii:data-[side=bottom]:translate-y-1 uii:data-[side=left]:-translate-x-1 uii:data-[side=right]:translate-x-1 uii:data-[side=top]:-translate-y-1", "uii:slide-in-from-right-6", className),
5257
+ position: position
5258
+ }, props), !hideScrollUpButton && /* @__PURE__ */ React2.createElement(SelectScrollUpButton, null), /* @__PURE__ */ React2.createElement(SelectPrimitive.Viewport, {
5259
+ className: cn("uii:p-1", position === "popper" && "uii:h-[var(--radix-select-trigger-height)] uii:w-full uii:min-w-[var(--radix-select-trigger-width)] uii:scroll-my-1")
5260
+ }, children), footer ? /* @__PURE__ */ React2.createElement("div", {
5261
+ className: "uii:border-t uii:p-2 uii:bg-popover"
5262
+ }, footer) : null, !hideScrollDownButton && /* @__PURE__ */ React2.createElement(SelectScrollDownButton, null)));
5263
+ }
5264
+ function SelectItem(_param) {
5265
+ var className = _param.className, children = _param.children, props = _object_without_properties(_param, [
5266
+ "className",
5267
+ "children"
5268
+ ]);
5269
+ return /* @__PURE__ */ React2.createElement(SelectPrimitive.Item, _object_spread({
5270
+ "data-slot": "select-item",
5271
+ className: cn("uii:focus:bg-accent uii:focus:text-accent-foreground uii:[&_svg:not([class*=text-])]:text-muted-foreground uii:relative uii:flex uii:w-full uii:cursor-default uii:items-center uii:gap-2 uii:rounded-sm uii:py-1.5 uii:pr-8 uii:pl-2 uii:text-sm uii:outline-hidden uii:select-none uii:data-[disabled]:pointer-events-none uii:data-[disabled]:opacity-50 uii:[&_svg]:pointer-events-none uii:[&_svg]:shrink-0 uii:[&_svg:not([class*=size-])]:size-4 uii:*:[span]:last:flex uii:*:[span]:last:items-center uii:*:[span]:last:gap-2", className)
5272
+ }, props), /* @__PURE__ */ React2.createElement("span", {
5273
+ className: "uii:absolute uii:right-2 uii:flex uii:size-3.5 uii:items-center uii:justify-center"
5274
+ }, /* @__PURE__ */ React2.createElement(SelectPrimitive.ItemIndicator, null, /* @__PURE__ */ React2.createElement(CheckIcon, {
5275
+ className: "uii:size-4"
5276
+ }))), /* @__PURE__ */ React2.createElement(SelectPrimitive.ItemText, null, children));
5277
+ }
5278
+ function SelectScrollUpButton(_param) {
5279
+ var className = _param.className, props = _object_without_properties(_param, [
5280
+ "className"
5281
+ ]);
5282
+ return /* @__PURE__ */ React2.createElement(SelectPrimitive.ScrollUpButton, _object_spread({
5283
+ "data-slot": "select-scroll-up-button",
5284
+ className: cn("uii:flex uii:cursor-default uii:items-center uii:justify-center uii:py-1", className)
5285
+ }, props), /* @__PURE__ */ React2.createElement(ChevronUpIcon, {
5286
+ className: "uii:size-4"
5287
+ }));
5288
+ }
5289
+ function SelectScrollDownButton(_param) {
5290
+ var className = _param.className, props = _object_without_properties(_param, [
5291
+ "className"
5292
+ ]);
5293
+ return /* @__PURE__ */ React2.createElement(SelectPrimitive.ScrollDownButton, _object_spread({
5294
+ "data-slot": "select-scroll-down-button",
5295
+ className: cn("uii:flex uii:cursor-default uii:items-center uii:justify-center uii:py-1", className)
5296
+ }, props), /* @__PURE__ */ React2.createElement(ChevronDownIcon, {
5297
+ className: "uii:size-4"
5298
+ }));
5299
+ }
5300
+ // src/components/fields/Select.tsx
5301
+ function Select2(param) {
5177
5302
  var fieldName = param.fieldName, label = param.label, value = param.value, onChange = param.onChange, rawOptions = param.options, _param_disabled = param.disabled, disabled = _param_disabled === void 0 ? false : _param_disabled, placeholder = param.placeholder, _param_expectedType = param.expectedType, expectedType = _param_expectedType === void 0 ? "string" : _param_expectedType, _param_required = param.required, required = _param_required === void 0 ? false : _param_required, _param_hasRequiredError = param.hasRequiredError, hasRequiredError = _param_hasRequiredError === void 0 ? false : _param_hasRequiredError, className = param.className, children = param.children;
5178
- var _React3_useState = _sliced_to_array(React3.useState(false), 2), isExpressionMode = _React3_useState[0], setIsExpressionMode = _React3_useState[1];
5179
- var _React3_useState1 = _sliced_to_array(React3.useState(""), 2), expressionValue = _React3_useState1[0], setExpressionValue = _React3_useState1[1];
5180
- var options = React3.useMemo(function() {
5303
+ var _React2_useState = _sliced_to_array(React2.useState(false), 2), isExpressionMode = _React2_useState[0], setIsExpressionMode = _React2_useState[1];
5304
+ var _React2_useState1 = _sliced_to_array(React2.useState(""), 2), expressionValue = _React2_useState1[0], setExpressionValue = _React2_useState1[1];
5305
+ var options = React2.useMemo(function() {
5181
5306
  return rawOptions.map(function(opt) {
5182
5307
  return typeof opt === "string" ? {
5183
5308
  value: opt,
@@ -5187,7 +5312,7 @@ function Select(param) {
5187
5312
  }, [
5188
5313
  rawOptions
5189
5314
  ]);
5190
- var displayValue = React3.useMemo(function() {
5315
+ var displayValue = React2.useMemo(function() {
5191
5316
  if (value && (typeof value === "undefined" ? "undefined" : _type_of(value)) === "object" && "expression" in value) {
5192
5317
  return value.expression || "";
5193
5318
  }
@@ -5195,12 +5320,12 @@ function Select(param) {
5195
5320
  }, [
5196
5321
  value
5197
5322
  ]);
5198
- var isExpression = React3.useMemo(function() {
5323
+ var isExpression = React2.useMemo(function() {
5199
5324
  return value && (typeof value === "undefined" ? "undefined" : _type_of(value)) === "object" && "expression" in value;
5200
5325
  }, [
5201
5326
  value
5202
5327
  ]);
5203
- React3.useEffect(function() {
5328
+ React2.useEffect(function() {
5204
5329
  if (isExpression) {
5205
5330
  setIsExpressionMode(true);
5206
5331
  setExpressionValue(displayValue);
@@ -5209,7 +5334,7 @@ function Select(param) {
5209
5334
  isExpression,
5210
5335
  displayValue
5211
5336
  ]);
5212
- var handleSelectChange = React3.useCallback(function(newValue) {
5337
+ var handleSelectChange = React2.useCallback(function(newValue) {
5213
5338
  if (newValue === "__expression__") {
5214
5339
  setIsExpressionMode(true);
5215
5340
  return;
@@ -5218,7 +5343,7 @@ function Select(param) {
5218
5343
  }, [
5219
5344
  onChange
5220
5345
  ]);
5221
- var handleExpressionChange = React3.useCallback(function(e) {
5346
+ var handleExpressionChange = React2.useCallback(function(e) {
5222
5347
  var newValue = e.target.value;
5223
5348
  setExpressionValue(newValue);
5224
5349
  onChange({
@@ -5228,7 +5353,7 @@ function Select(param) {
5228
5353
  }, [
5229
5354
  onChange
5230
5355
  ]);
5231
- var handleSwitchToValue = React3.useCallback(function() {
5356
+ var handleSwitchToValue = React2.useCallback(function() {
5232
5357
  setIsExpressionMode(false);
5233
5358
  setExpressionValue("");
5234
5359
  onChange("");
@@ -5263,24 +5388,24 @@ function Select(param) {
5263
5388
  },
5264
5389
  hasError: showError
5265
5390
  };
5266
- return /* @__PURE__ */ React3.createElement("div", {
5391
+ return /* @__PURE__ */ React2.createElement("div", {
5267
5392
  className: cn("uii:mb-2", className)
5268
- }, /* @__PURE__ */ React3.createElement("div", {
5393
+ }, /* @__PURE__ */ React2.createElement("div", {
5269
5394
  className: "uii:flex uii:items-center uii:gap-2 uii:mt-2"
5270
- }, /* @__PURE__ */ React3.createElement("label", {
5395
+ }, /* @__PURE__ */ React2.createElement("label", {
5271
5396
  htmlFor: fieldName,
5272
5397
  className: "uii:text-xs uii:font-bold uii:text-muted-foreground"
5273
- }, label, ":"), expectedType !== "$.interface.timer" && /* @__PURE__ */ React3.createElement("span", {
5398
+ }, label, ":"), expectedType !== "$.interface.timer" && /* @__PURE__ */ React2.createElement("span", {
5274
5399
  className: "uii:-mt-2 uii:inline-flex uii:px-1 uii:py-0.5 uii:bg-gray-200 uii:rounded-sm uii:text-[10px] uii:font-mono uii:text-muted-foreground uii:font-light"
5275
- }, expectedType), showError && /* @__PURE__ */ React3.createElement("span", {
5400
+ }, expectedType), showError && /* @__PURE__ */ React2.createElement("span", {
5276
5401
  className: "uii:-mt-2 uii:inline-flex uii:px-1 uii:py-0.5 uii:bg-red-100 uii:text-red-600 uii:rounded-sm uii:text-[10px] uii:font-medium"
5277
- }, "Required")), /* @__PURE__ */ React3.createElement("div", {
5402
+ }, "Required")), /* @__PURE__ */ React2.createElement("div", {
5278
5403
  className: "uii:mt-0.5"
5279
5404
  }, children ? // Use custom render function
5280
5405
  children(renderProps) : isExpressionMode ? // Expression mode - show input with clear button
5281
- /* @__PURE__ */ React3.createElement("div", {
5406
+ /* @__PURE__ */ React2.createElement("div", {
5282
5407
  className: "uii:flex uii:items-center uii:h-9 uii:rounded-sm uii:border uii:border-amber-500/50 uii:bg-amber-500/5"
5283
- }, /* @__PURE__ */ React3.createElement("input", {
5408
+ }, /* @__PURE__ */ React2.createElement("input", {
5284
5409
  id: fieldName,
5285
5410
  name: fieldName,
5286
5411
  type: "text",
@@ -5289,32 +5414,183 @@ function Select(param) {
5289
5414
  disabled: disabled,
5290
5415
  placeholder: "Enter expression...",
5291
5416
  className: cn("uii:flex-1 uii:h-full uii:px-3 uii:bg-transparent uii:text-sm uii:font-mono uii:text-amber-600", "uii:outline-none uii:border-none", disabled && "uii:opacity-50 uii:cursor-not-allowed")
5292
- }), /* @__PURE__ */ React3.createElement("button", {
5417
+ }), /* @__PURE__ */ React2.createElement("button", {
5293
5418
  type: "button",
5294
5419
  onClick: handleSwitchToValue,
5295
5420
  className: "uii:flex uii:items-center uii:justify-center uii:h-full uii:px-2 uii:text-amber-600 hover:uii:text-red-600 uii:border-l uii:border-amber-500/30",
5296
5421
  title: "Clear and return to value mode"
5297
5422
  }, "\xD7")) : // Value mode - show select
5298
- /* @__PURE__ */ React3.createElement("select", {
5299
- id: fieldName,
5300
- name: fieldName,
5423
+ // <select
5424
+ // id={fieldName}
5425
+ // name={fieldName}
5426
+ // value={displayValue}
5427
+ // onChange={(e) => handleSelectChange(e.target.value)}
5428
+ // disabled={disabled}
5429
+ // className={cn(
5430
+ // 'uii:w-full uii:h-9 uii:px-3 uii:rounded-sm uii:border uii:bg-background uii:text-sm',
5431
+ // 'uii:outline-none uii:transition-all uii:cursor-pointer',
5432
+ // 'focus:uii:border-ring focus:uii:ring-ring/50 focus:uii:ring-[3px]',
5433
+ // showError
5434
+ // ? 'uii:border-red-500 hover:uii:border-red-600'
5435
+ // : 'uii:border-input hover:uii:border-ring/50',
5436
+ // disabled && 'uii:opacity-50 uii:cursor-not-allowed'
5437
+ // )}
5438
+ // >
5439
+ // {placeholder && (
5440
+ // <option value="" disabled>
5441
+ // {placeholder}
5442
+ // </option>
5443
+ // )}
5444
+ // {options.map(opt => (
5445
+ // <option key={opt.value} value={opt.value}>
5446
+ // {opt.label}
5447
+ // </option>
5448
+ // ))}
5449
+ // <option value="__expression__">
5450
+ // 📝 Custom Expression
5451
+ // </option>
5452
+ // </select>
5453
+ /* @__PURE__ */ React2.createElement(Select, {
5301
5454
  value: displayValue,
5302
- onChange: function(e) {
5303
- return handleSelectChange(e.target.value);
5455
+ onValueChange: function(e) {
5456
+ return handleSelectChange(e);
5304
5457
  },
5305
- disabled: disabled,
5306
- className: cn("uii:w-full uii:h-9 uii:px-3 uii:rounded-sm uii:border uii:bg-background uii:text-sm", "uii:outline-none uii:transition-all uii:cursor-pointer", "focus:uii:border-ring focus:uii:ring-ring/50 focus:uii:ring-[3px]", showError ? "uii:border-red-500 hover:uii:border-red-600" : "uii:border-input hover:uii:border-ring/50", disabled && "uii:opacity-50 uii:cursor-not-allowed")
5307
- }, placeholder && /* @__PURE__ */ React3.createElement("option", {
5308
- value: "",
5309
- disabled: true
5310
- }, placeholder), options.map(function(opt) {
5311
- return /* @__PURE__ */ React3.createElement("option", {
5458
+ disabled: disabled !== null && disabled !== void 0 ? disabled : disabled
5459
+ }, /* @__PURE__ */ React2.createElement(SelectTrigger, {
5460
+ className: "ui:w-full ui:h-9 ui:px-3 ui:border ui:border-input ui:rounded-sm ui:bg-background"
5461
+ }, /* @__PURE__ */ React2.createElement(SelectValue, {
5462
+ placeholder: placeholder
5463
+ })), /* @__PURE__ */ React2.createElement(SelectContent, null, options.map(function(opt) {
5464
+ return /* @__PURE__ */ React2.createElement(SelectItem, {
5312
5465
  key: opt.value,
5313
5466
  value: opt.value
5314
- }, opt.label);
5315
- }), /* @__PURE__ */ React3.createElement("option", {
5316
- value: "__expression__"
5317
- }, "\uD83D\uDCDD Custom Expression"))));
5467
+ }, opt.node ? opt.node : /* @__PURE__ */ React2.createElement(React2.Fragment, null, opt.label));
5468
+ })))));
5469
+ }
5470
+ // src/components/template-editor/operatorTypes.ts
5471
+ function parseInferredTypes(typeStr) {
5472
+ var result = {
5473
+ baseTypes: [],
5474
+ stringConstants: [],
5475
+ numberConstants: [],
5476
+ hasConstants: false,
5477
+ rawTypes: []
5478
+ };
5479
+ if (!typeStr || typeStr === "any" || typeStr === "unknown") {
5480
+ result.baseTypes = [
5481
+ "any"
5482
+ ];
5483
+ result.rawTypes = [
5484
+ "any"
5485
+ ];
5486
+ return result;
5487
+ }
5488
+ var types = typeStr.split("|").map(function(t) {
5489
+ return t.trim();
5490
+ }).filter(Boolean);
5491
+ var baseTypesSet = /* @__PURE__ */ new Set();
5492
+ var rawTypesSet = /* @__PURE__ */ new Set();
5493
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
5494
+ try {
5495
+ for(var _iterator = types[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
5496
+ var t = _step.value;
5497
+ rawTypesSet.add(t);
5498
+ var stringLiteralMatch = t.match(/^["'](.*)["']$/);
5499
+ if (stringLiteralMatch && stringLiteralMatch[1] !== void 0) {
5500
+ result.stringConstants.push(stringLiteralMatch[1]);
5501
+ baseTypesSet.add("string");
5502
+ result.hasConstants = true;
5503
+ continue;
5504
+ }
5505
+ if (/^-?\d+(\.\d+)?$/.test(t)) {
5506
+ result.numberConstants.push(parseFloat(t));
5507
+ baseTypesSet.add("number");
5508
+ result.hasConstants = true;
5509
+ continue;
5510
+ }
5511
+ if (t === "true" || t === "false") {
5512
+ baseTypesSet.add("boolean");
5513
+ result.hasConstants = true;
5514
+ continue;
5515
+ }
5516
+ baseTypesSet.add(t);
5517
+ }
5518
+ } catch (err) {
5519
+ _didIteratorError = true;
5520
+ _iteratorError = err;
5521
+ } finally{
5522
+ try {
5523
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
5524
+ _iterator.return();
5525
+ }
5526
+ } finally{
5527
+ if (_didIteratorError) {
5528
+ throw _iteratorError;
5529
+ }
5530
+ }
5531
+ }
5532
+ result.baseTypes = Array.from(baseTypesSet);
5533
+ result.rawTypes = Array.from(rawTypesSet);
5534
+ return result;
5535
+ }
5536
+ function computeExtendedType(inferredType, opDef) {
5537
+ if (!opDef.extendsWithBase || opDef.narrowsTo === "never") {
5538
+ return opDef.narrowsTo;
5539
+ }
5540
+ var parsed = parseInferredTypes(inferredType);
5541
+ var matchingTypes = [];
5542
+ var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;
5543
+ try {
5544
+ for(var _iterator = parsed.rawTypes[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){
5545
+ var t = _step.value;
5546
+ if (opDef.narrowsTo === "string") {
5547
+ if (t === "string" || /^["'].*["']$/.test(t)) {
5548
+ matchingTypes.push(t);
5549
+ }
5550
+ } else if (opDef.narrowsTo === "number") {
5551
+ if (t === "number" || /^-?\d+(\.\d+)?$/.test(t)) {
5552
+ matchingTypes.push(t);
5553
+ }
5554
+ } else if (opDef.narrowsTo === "boolean") {
5555
+ if (t === "boolean" || t === "true" || t === "false") {
5556
+ matchingTypes.push(t);
5557
+ }
5558
+ }
5559
+ }
5560
+ } catch (err) {
5561
+ _didIteratorError = true;
5562
+ _iteratorError = err;
5563
+ } finally{
5564
+ try {
5565
+ if (!_iteratorNormalCompletion && _iterator.return != null) {
5566
+ _iterator.return();
5567
+ }
5568
+ } finally{
5569
+ if (_didIteratorError) {
5570
+ throw _iteratorError;
5571
+ }
5572
+ }
5573
+ }
5574
+ if (opDef.extendsWithBase && !matchingTypes.includes(opDef.narrowsTo)) {
5575
+ matchingTypes.push(opDef.narrowsTo);
5576
+ }
5577
+ return matchingTypes.length > 0 ? matchingTypes.join(" | ") : opDef.narrowsTo;
5578
+ }
5579
+ function filterOperatorsByType(operators, inferredType) {
5580
+ var parsed = parseInferredTypes(inferredType);
5581
+ var baseTypes = parsed.baseTypes;
5582
+ return operators.filter(function(op) {
5583
+ if (op.types.includes("any")) return true;
5584
+ return op.types.some(function(t) {
5585
+ return baseTypes.includes(t) || baseTypes.includes("any");
5586
+ });
5587
+ });
5588
+ }
5589
+ function getStringConstants(inferredType) {
5590
+ return parseInferredTypes(inferredType).stringConstants;
5591
+ }
5592
+ function getNumberConstants(inferredType) {
5593
+ return parseInferredTypes(inferredType).numberConstants;
5318
5594
  }
5319
5595
  // src/components/fields/index.tsx
5320
5596
  function useTemplateFieldContext() {
@@ -5343,11 +5619,11 @@ function useFieldPath(fieldName) {
5343
5619
  }
5344
5620
  function TemplateFieldProvider(param) {
5345
5621
  var children = param.children;
5346
- return /* @__PURE__ */ React.createElement(React.Fragment, null, children);
5622
+ return /* @__PURE__ */ React2__default.createElement(React2__default.Fragment, null, children);
5347
5623
  }
5348
5624
  function NestedFieldProvider(param) {
5349
5625
  var children = param.children;
5350
- return /* @__PURE__ */ React.createElement(React.Fragment, null, children);
5626
+ return /* @__PURE__ */ React2__default.createElement(React2__default.Fragment, null, children);
5351
5627
  }
5352
5628
  var InferredTypesContext = createContext(null);
5353
5629
  function useInferredTypes() {
@@ -5355,7 +5631,7 @@ function useInferredTypes() {
5355
5631
  }
5356
5632
  function InferredTypesProvider(param) {
5357
5633
  var children = param.children;
5358
- return /* @__PURE__ */ React.createElement(React.Fragment, null, children);
5634
+ return /* @__PURE__ */ React2__default.createElement(React2__default.Fragment, null, children);
5359
5635
  }
5360
5636
  function intersectTypes(types) {
5361
5637
  var validTypes = types.filter(function(t) {
@@ -5476,5 +5752,76 @@ function getOperatorsForType(type) {
5476
5752
  }
5477
5753
  ];
5478
5754
  }
5755
+ function NodePropertyProvider(param) {
5756
+ var children = param.children;
5757
+ return /* @__PURE__ */ React2__default.createElement(React2__default.Fragment, null, children);
5758
+ }
5759
+ function useIsInNodePropertyProvider() {
5760
+ return false;
5761
+ }
5762
+ function useNodeProperty(key) {
5763
+ var noopSetter = useCallback(function() {
5764
+ console.warn('[useNodeProperty] Mock mode - cannot set "'.concat(key, '"'));
5765
+ }, [
5766
+ key
5767
+ ]);
5768
+ return [
5769
+ void 0,
5770
+ noopSetter
5771
+ ];
5772
+ }
5773
+ function useNodeProperties() {
5774
+ var noopSetter = useCallback(function() {
5775
+ console.warn("[useNodeProperties] Mock mode - cannot set properties");
5776
+ }, []);
5777
+ return [
5778
+ {},
5779
+ noopSetter
5780
+ ];
5781
+ }
5782
+ function useInferredType(fieldName) {
5783
+ return void 0;
5784
+ }
5785
+ function useSetInferredType() {
5786
+ return useCallback(function(fieldName, type) {
5787
+ console.warn('[useSetInferredType] Mock mode - cannot set "'.concat(fieldName, '" to "').concat(type, '"'));
5788
+ }, []);
5789
+ }
5790
+ function useAllInferredTypes() {
5791
+ return {};
5792
+ }
5793
+ function useSetProperty() {
5794
+ return useCallback(function(key, value) {
5795
+ console.warn('[useSetProperty] Mock mode - cannot set "'.concat(key, '"'));
5796
+ }, []);
5797
+ }
5798
+ function useFieldValidation() {
5799
+ var setFieldRequired = useCallback(function(fieldName, required) {
5800
+ console.warn('[useFieldValidation] Mock mode - cannot set required for "'.concat(fieldName, '"'));
5801
+ }, []);
5802
+ var setFieldRequiredIf = useCallback(function(fieldName, requiredIf) {
5803
+ console.warn('[useFieldValidation] Mock mode - cannot set requiredIf for "'.concat(fieldName, '"'));
5804
+ }, []);
5805
+ var setFieldValidation = useCallback(function(fieldName, customValidation) {
5806
+ console.warn('[useFieldValidation] Mock mode - cannot set validation for "'.concat(fieldName, '"'));
5807
+ }, []);
5808
+ var clearFieldValidation = useCallback(function(fieldName) {
5809
+ console.warn('[useFieldValidation] Mock mode - cannot clear validation for "'.concat(fieldName, '"'));
5810
+ }, []);
5811
+ var isFieldRequired = useCallback(function(fieldName) {
5812
+ return false;
5813
+ }, []);
5814
+ var validateField = useCallback(function(fieldName) {
5815
+ return null;
5816
+ }, []);
5817
+ return {
5818
+ setFieldRequired: setFieldRequired,
5819
+ setFieldRequiredIf: setFieldRequiredIf,
5820
+ setFieldValidation: setFieldValidation,
5821
+ clearFieldValidation: clearFieldValidation,
5822
+ isFieldRequired: isFieldRequired,
5823
+ validateField: validateField
5824
+ };
5825
+ }
5479
5826
  export { Button, ConfirmationDropdownMenuItem, DropdownMenu, DropdownMenuCheckboxItem, DropdownMenuClose, DropdownMenuContent, DropdownMenuGroup, DropdownMenuItem, DropdownMenuLabel, DropdownMenuPortal, DropdownMenuRadioGroup, DropdownMenuRadioItem, DropdownMenuSeparator, DropdownMenuShortcut, DropdownMenuSub, DropdownMenuSubContent, DropdownMenuSubTrigger, DropdownMenuTrigger, buttonVariants, fields_exports as fields }; //# sourceMappingURL=index.js.map
5480
5827
  //# sourceMappingURL=index.js.map