agent-relay-server 0.32.3 → 0.33.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.
- package/package.json +2 -2
- package/public/assets/{activity-DT1JGHnp.js → activity-B0_uE6Yh.js} +2 -2
- package/public/assets/{activity-DT1JGHnp.js.map → activity-B0_uE6Yh.js.map} +1 -1
- package/public/assets/{agent-profiles-CrMemMkZ.js → agent-profiles-Rwxrcf9F.js} +2 -2
- package/public/assets/{agent-profiles-CrMemMkZ.js.map → agent-profiles-Rwxrcf9F.js.map} +1 -1
- package/public/assets/{agents-Bl-rrgOy.js → agents-Dp1EXJc8.js} +2 -2
- package/public/assets/{agents-Bl-rrgOy.js.map → agents-Dp1EXJc8.js.map} +1 -1
- package/public/assets/{analytics-a663ak56.js → analytics-D5OT5ajj.js} +2 -2
- package/public/assets/{analytics-a663ak56.js.map → analytics-D5OT5ajj.js.map} +1 -1
- package/public/assets/automation-Dm6rXNxK.js +2 -0
- package/public/assets/{automation-CiaLThdO.js.map → automation-Dm6rXNxK.js.map} +1 -1
- package/public/assets/{branch-state-badge-D4ur3m3_.js → branch-state-badge-FX5Yww2s.js} +2 -2
- package/public/assets/{branch-state-badge-D4ur3m3_.js.map → branch-state-badge-FX5Yww2s.js.map} +1 -1
- package/public/assets/{channels-o9KLTHoK.js → channels--rdAiX17.js} +2 -2
- package/public/assets/{channels-o9KLTHoK.js.map → channels--rdAiX17.js.map} +1 -1
- package/public/assets/chat-JZAEDGfX.js +2 -0
- package/public/assets/chat-JZAEDGfX.js.map +1 -0
- package/public/assets/{connectors-CdC806mA.js → connectors-Bx4gzvNf.js} +2 -2
- package/public/assets/{connectors-CdC806mA.js.map → connectors-Bx4gzvNf.js.map} +1 -1
- package/public/assets/display-Bebqs1qu.js +3 -0
- package/public/assets/display-Bebqs1qu.js.map +1 -0
- package/public/assets/{formatted-body-impl-Ca74OAEH.js → formatted-body-impl-CVq4qHix.js} +2 -2
- package/public/assets/{formatted-body-impl-Ca74OAEH.js.map → formatted-body-impl-CVq4qHix.js.map} +1 -1
- package/public/assets/{index-C_33ymaw.js → index-BHRtR4q7.js} +8 -8
- package/public/assets/{index-C_33ymaw.js.map → index-BHRtR4q7.js.map} +1 -1
- package/public/assets/{insights-ClI68s39.js → insights-yJFgCa3o.js} +2 -2
- package/public/assets/{insights-ClI68s39.js.map → insights-yJFgCa3o.js.map} +1 -1
- package/public/assets/{integrations-1nxMizDY.js → integrations-k1HIONjo.js} +2 -2
- package/public/assets/{integrations-1nxMizDY.js.map → integrations-k1HIONjo.js.map} +1 -1
- package/public/assets/maintenance-CsoOFBXx.js +2 -0
- package/public/assets/{maintenance-DiFNzNPN.js.map → maintenance-CsoOFBXx.js.map} +1 -1
- package/public/assets/{managed-agents-Do3dKvfj.js → managed-agents-Q3HuVjGg.js} +2 -2
- package/public/assets/{managed-agents-Do3dKvfj.js.map → managed-agents-Q3HuVjGg.js.map} +1 -1
- package/public/assets/{markdown-preview-impl-CLA0J255.js → markdown-preview-impl-CnsMjrnu.js} +2 -2
- package/public/assets/{markdown-preview-impl-CLA0J255.js.map → markdown-preview-impl-CnsMjrnu.js.map} +1 -1
- package/public/assets/{memory-IjwqFzBd.js → memory-D3-K5eJS.js} +2 -2
- package/public/assets/{memory-IjwqFzBd.js.map → memory-D3-K5eJS.js.map} +1 -1
- package/public/assets/{messages-DjvWqHyn.js → messages-B4lCP5rS.js} +2 -2
- package/public/assets/{messages-DjvWqHyn.js.map → messages-B4lCP5rS.js.map} +1 -1
- package/public/assets/{orchestrators-D2IqDxDT.js → orchestrators-CRoZtLeQ.js} +2 -2
- package/public/assets/{orchestrators-D2IqDxDT.js.map → orchestrators-CRoZtLeQ.js.map} +1 -1
- package/public/assets/{overview-DKC3TbAh.js → overview-CxCU2fOF.js} +2 -2
- package/public/assets/{overview-DKC3TbAh.js.map → overview-CxCU2fOF.js.map} +1 -1
- package/public/assets/pairs-unqjPlmq.js +2 -0
- package/public/assets/{pairs-WpKCPE1n.js.map → pairs-unqjPlmq.js.map} +1 -1
- package/public/assets/{security-BF7ZtPQe.js → security-B7HhSYNy.js} +2 -2
- package/public/assets/{security-BF7ZtPQe.js.map → security-B7HhSYNy.js.map} +1 -1
- package/public/assets/{settings-CQnjrTa-.js → settings-B9NDhsAb.js} +2 -2
- package/public/assets/{settings-CQnjrTa-.js.map → settings-B9NDhsAb.js.map} +1 -1
- package/public/assets/store-DiSzYHj9.js +9 -0
- package/public/assets/{store-C9VcSo05.js.map → store-DiSzYHj9.js.map} +1 -1
- package/public/assets/{tasks-CbN_GSSb.js → tasks-CIQolvNm.js} +2 -2
- package/public/assets/{tasks-CbN_GSSb.js.map → tasks-CIQolvNm.js.map} +1 -1
- package/public/assets/{terminal-viewer-impl-BJRohThT.js → terminal-viewer-impl-DCifVqFR.js} +2 -2
- package/public/assets/{terminal-viewer-impl-BJRohThT.js.map → terminal-viewer-impl-DCifVqFR.js.map} +1 -1
- package/public/assets/{work-queue-C5xLBLmm.js → work-queue-Dr3c1V6O.js} +2 -2
- package/public/assets/{work-queue-C5xLBLmm.js.map → work-queue-Dr3c1V6O.js.map} +1 -1
- package/public/assets/{workspaces-D91H3wDX.js → workspaces-B1Jxop7h.js} +3 -3
- package/public/assets/{workspaces-D91H3wDX.js.map → workspaces-B1Jxop7h.js.map} +1 -1
- package/public/index.html +3 -3
- package/runner/src/adapter.ts +1 -1
- package/src/agent-lifecycle-events.ts +137 -0
- package/src/artifact-storage.ts +3 -5
- package/src/branch-landed.ts +38 -2
- package/src/cli/_shared.ts +80 -0
- package/src/cli/agent-detect.ts +188 -0
- package/src/cli/agent-meta.ts +95 -0
- package/src/cli/context-probe.ts +88 -0
- package/src/cli/daemon.ts +111 -0
- package/src/cli/dev.ts +173 -0
- package/src/cli/index.ts +361 -0
- package/src/cli/introspect.ts +73 -0
- package/src/cli/memory.ts +37 -0
- package/src/cli/message.ts +201 -0
- package/src/cli/orchestrator.ts +227 -0
- package/src/cli/pair.ts +125 -0
- package/src/cli/provider.ts +209 -0
- package/src/cli/recipe.ts +110 -0
- package/src/cli/reply.ts +141 -0
- package/src/cli/setup.ts +57 -0
- package/src/cli/steward.ts +59 -0
- package/src/cli/token.ts +81 -0
- package/src/cli/upgrade.ts +193 -0
- package/src/cli/workspace.ts +215 -0
- package/src/cli.ts +4 -2718
- package/src/config-store.ts +10 -6
- package/src/maintenance.ts +25 -21
- package/src/mcp-errors.ts +7 -0
- package/src/mcp.ts +34 -36
- package/src/routes/agents-spawn.ts +9 -1
- package/src/routes/agents.ts +5 -0
- package/src/routes/commands.ts +15 -0
- package/src/routes/workspaces.ts +13 -4
- package/src/spawn-targets.ts +159 -0
- package/src/utils.ts +16 -1
- package/src/workspace-actions.ts +7 -1
- package/src/workspace-merge.ts +12 -1
- package/public/assets/automation-CiaLThdO.js +0 -2
- package/public/assets/chat-5hvHZcAe.js +0 -2
- package/public/assets/chat-5hvHZcAe.js.map +0 -1
- package/public/assets/display-JI19Vc7L.js +0 -3
- package/public/assets/display-JI19Vc7L.js.map +0 -1
- package/public/assets/maintenance-DiFNzNPN.js +0 -2
- package/public/assets/pairs-WpKCPE1n.js +0 -2
- package/public/assets/store-C9VcSo05.js +0 -9
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"settings-CQnjrTa-.js","names":["Select","PopperPrimitive.Root","SelectTrigger","PopperPrimitive.Anchor","SelectValue","Fragment","PortalPrimitive","SelectContent","RemoveScroll","PopperPrimitive.Content","SelectItem","SelectScrollUpButton","SelectScrollDownButton","PopperPrimitive.Arrow"],"sources":["../../dashboard/node_modules/@radix-ui/react-select/dist/index.mjs","../../dashboard/src/components/ui/select.tsx","../../dashboard/src/components/views/settings.tsx"],"sourcesContent":["\"use client\";\n\n// src/select.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { clamp } from \"@radix-ui/number\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { useFocusGuards } from \"@radix-ui/react-focus-guards\";\nimport { FocusScope } from \"@radix-ui/react-focus-scope\";\nimport { useId } from \"@radix-ui/react-id\";\nimport * as PopperPrimitive from \"@radix-ui/react-popper\";\nimport { createPopperScope } from \"@radix-ui/react-popper\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { usePrevious } from \"@radix-ui/react-use-previous\";\nimport { VISUALLY_HIDDEN_STYLES } from \"@radix-ui/react-visually-hidden\";\nimport { hideOthers } from \"aria-hidden\";\nimport { RemoveScroll } from \"react-remove-scroll\";\nimport { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nvar OPEN_KEYS = [\" \", \"Enter\", \"ArrowUp\", \"ArrowDown\"];\nvar SELECTION_KEYS = [\" \", \"Enter\"];\nvar SELECT_NAME = \"Select\";\nvar [Collection, useCollection, createCollectionScope] = createCollection(SELECT_NAME);\nvar [createSelectContext, createSelectScope] = createContextScope(SELECT_NAME, [\n createCollectionScope,\n createPopperScope\n]);\nvar usePopperScope = createPopperScope();\nvar [SelectProvider, useSelectContext] = createSelectContext(SELECT_NAME);\nvar [SelectNativeOptionsProvider, useSelectNativeOptionsContext] = createSelectContext(SELECT_NAME);\nvar Select = (props) => {\n const {\n __scopeSelect,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n value: valueProp,\n defaultValue,\n onValueChange,\n dir,\n name,\n autoComplete,\n disabled,\n required,\n form\n } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const [trigger, setTrigger] = React.useState(null);\n const [valueNode, setValueNode] = React.useState(null);\n const [valueNodeHasChildren, setValueNodeHasChildren] = React.useState(false);\n const direction = useDirection(dir);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: SELECT_NAME\n });\n const [value, setValue] = useControllableState({\n prop: valueProp,\n defaultProp: defaultValue,\n onChange: onValueChange,\n caller: SELECT_NAME\n });\n const triggerPointerDownPosRef = React.useRef(null);\n const isFormControl = trigger ? form || !!trigger.closest(\"form\") : true;\n const [nativeOptionsSet, setNativeOptionsSet] = React.useState(/* @__PURE__ */ new Set());\n const nativeSelectKey = Array.from(nativeOptionsSet).map((option) => option.props.value).join(\";\");\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsxs(\n SelectProvider,\n {\n required,\n scope: __scopeSelect,\n trigger,\n onTriggerChange: setTrigger,\n valueNode,\n onValueNodeChange: setValueNode,\n valueNodeHasChildren,\n onValueNodeHasChildrenChange: setValueNodeHasChildren,\n contentId: useId(),\n value,\n onValueChange: setValue,\n open,\n onOpenChange: setOpen,\n dir: direction,\n triggerPointerDownPosRef,\n disabled,\n children: [\n /* @__PURE__ */ jsx(Collection.Provider, { scope: __scopeSelect, children: /* @__PURE__ */ jsx(\n SelectNativeOptionsProvider,\n {\n scope: props.__scopeSelect,\n onNativeOptionAdd: React.useCallback((option) => {\n setNativeOptionsSet((prev) => new Set(prev).add(option));\n }, []),\n onNativeOptionRemove: React.useCallback((option) => {\n setNativeOptionsSet((prev) => {\n const optionsSet = new Set(prev);\n optionsSet.delete(option);\n return optionsSet;\n });\n }, []),\n children\n }\n ) }),\n isFormControl ? /* @__PURE__ */ jsxs(\n SelectBubbleInput,\n {\n \"aria-hidden\": true,\n required,\n tabIndex: -1,\n name,\n autoComplete,\n value,\n onChange: (event) => setValue(event.target.value),\n disabled,\n form,\n children: [\n value === void 0 ? /* @__PURE__ */ jsx(\"option\", { value: \"\" }) : null,\n Array.from(nativeOptionsSet)\n ]\n },\n nativeSelectKey\n ) : null\n ]\n }\n ) });\n};\nSelect.displayName = SELECT_NAME;\nvar TRIGGER_NAME = \"SelectTrigger\";\nvar SelectTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, disabled = false, ...triggerProps } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const context = useSelectContext(TRIGGER_NAME, __scopeSelect);\n const isDisabled = context.disabled || disabled;\n const composedRefs = useComposedRefs(forwardedRef, context.onTriggerChange);\n const getItems = useCollection(__scopeSelect);\n const pointerTypeRef = React.useRef(\"touch\");\n const [searchRef, handleTypeaheadSearch, resetTypeahead] = useTypeaheadSearch((search) => {\n const enabledItems = getItems().filter((item) => !item.disabled);\n const currentItem = enabledItems.find((item) => item.value === context.value);\n const nextItem = findNextItem(enabledItems, search, currentItem);\n if (nextItem !== void 0) {\n context.onValueChange(nextItem.value);\n }\n });\n const handleOpen = (pointerEvent) => {\n if (!isDisabled) {\n context.onOpenChange(true);\n resetTypeahead();\n }\n if (pointerEvent) {\n context.triggerPointerDownPosRef.current = {\n x: Math.round(pointerEvent.pageX),\n y: Math.round(pointerEvent.pageY)\n };\n }\n };\n return /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { asChild: true, ...popperScope, children: /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n role: \"combobox\",\n \"aria-controls\": context.contentId,\n \"aria-expanded\": context.open,\n \"aria-required\": context.required,\n \"aria-autocomplete\": \"none\",\n dir: context.dir,\n \"data-state\": context.open ? \"open\" : \"closed\",\n disabled: isDisabled,\n \"data-disabled\": isDisabled ? \"\" : void 0,\n \"data-placeholder\": shouldShowPlaceholder(context.value) ? \"\" : void 0,\n ...triggerProps,\n ref: composedRefs,\n onClick: composeEventHandlers(triggerProps.onClick, (event) => {\n event.currentTarget.focus();\n if (pointerTypeRef.current !== \"mouse\") {\n handleOpen(event);\n }\n }),\n onPointerDown: composeEventHandlers(triggerProps.onPointerDown, (event) => {\n pointerTypeRef.current = event.pointerType;\n const target = event.target;\n if (target.hasPointerCapture(event.pointerId)) {\n target.releasePointerCapture(event.pointerId);\n }\n if (event.button === 0 && event.ctrlKey === false && event.pointerType === \"mouse\") {\n handleOpen(event);\n event.preventDefault();\n }\n }),\n onKeyDown: composeEventHandlers(triggerProps.onKeyDown, (event) => {\n const isTypingAhead = searchRef.current !== \"\";\n const isModifierKey = event.ctrlKey || event.altKey || event.metaKey;\n if (!isModifierKey && event.key.length === 1) handleTypeaheadSearch(event.key);\n if (isTypingAhead && event.key === \" \") return;\n if (OPEN_KEYS.includes(event.key)) {\n handleOpen();\n event.preventDefault();\n }\n })\n }\n ) });\n }\n);\nSelectTrigger.displayName = TRIGGER_NAME;\nvar VALUE_NAME = \"SelectValue\";\nvar SelectValue = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, className, style, children, placeholder = \"\", ...valueProps } = props;\n const context = useSelectContext(VALUE_NAME, __scopeSelect);\n const { onValueNodeHasChildrenChange } = context;\n const hasChildren = children !== void 0;\n const composedRefs = useComposedRefs(forwardedRef, context.onValueNodeChange);\n useLayoutEffect(() => {\n onValueNodeHasChildrenChange(hasChildren);\n }, [onValueNodeHasChildrenChange, hasChildren]);\n return /* @__PURE__ */ jsx(\n Primitive.span,\n {\n ...valueProps,\n ref: composedRefs,\n style: { pointerEvents: \"none\" },\n children: shouldShowPlaceholder(context.value) ? /* @__PURE__ */ jsx(Fragment, { children: placeholder }) : children\n }\n );\n }\n);\nSelectValue.displayName = VALUE_NAME;\nvar ICON_NAME = \"SelectIcon\";\nvar SelectIcon = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, children, ...iconProps } = props;\n return /* @__PURE__ */ jsx(Primitive.span, { \"aria-hidden\": true, ...iconProps, ref: forwardedRef, children: children || \"\\u25BC\" });\n }\n);\nSelectIcon.displayName = ICON_NAME;\nvar PORTAL_NAME = \"SelectPortal\";\nvar SelectPortal = (props) => {\n return /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, ...props });\n};\nSelectPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"SelectContent\";\nvar SelectContent = React.forwardRef(\n (props, forwardedRef) => {\n const context = useSelectContext(CONTENT_NAME, props.__scopeSelect);\n const [fragment, setFragment] = React.useState();\n useLayoutEffect(() => {\n setFragment(new DocumentFragment());\n }, []);\n if (!context.open) {\n const frag = fragment;\n return frag ? ReactDOM.createPortal(\n /* @__PURE__ */ jsx(SelectContentProvider, { scope: props.__scopeSelect, children: /* @__PURE__ */ jsx(Collection.Slot, { scope: props.__scopeSelect, children: /* @__PURE__ */ jsx(\"div\", { children: props.children }) }) }),\n frag\n ) : null;\n }\n return /* @__PURE__ */ jsx(SelectContentImpl, { ...props, ref: forwardedRef });\n }\n);\nSelectContent.displayName = CONTENT_NAME;\nvar CONTENT_MARGIN = 10;\nvar [SelectContentProvider, useSelectContentContext] = createSelectContext(CONTENT_NAME);\nvar CONTENT_IMPL_NAME = \"SelectContentImpl\";\nvar Slot = createSlot(\"SelectContent.RemoveScroll\");\nvar SelectContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeSelect,\n position = \"item-aligned\",\n onCloseAutoFocus,\n onEscapeKeyDown,\n onPointerDownOutside,\n //\n // PopperContent props\n side,\n sideOffset,\n align,\n alignOffset,\n arrowPadding,\n collisionBoundary,\n collisionPadding,\n sticky,\n hideWhenDetached,\n avoidCollisions,\n //\n ...contentProps\n } = props;\n const context = useSelectContext(CONTENT_NAME, __scopeSelect);\n const [content, setContent] = React.useState(null);\n const [viewport, setViewport] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContent(node));\n const [selectedItem, setSelectedItem] = React.useState(null);\n const [selectedItemText, setSelectedItemText] = React.useState(\n null\n );\n const getItems = useCollection(__scopeSelect);\n const [isPositioned, setIsPositioned] = React.useState(false);\n const firstValidItemFoundRef = React.useRef(false);\n React.useEffect(() => {\n if (content) return hideOthers(content);\n }, [content]);\n useFocusGuards();\n const focusFirst = React.useCallback(\n (candidates) => {\n const [firstItem, ...restItems] = getItems().map((item) => item.ref.current);\n const [lastItem] = restItems.slice(-1);\n const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;\n for (const candidate of candidates) {\n if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;\n candidate?.scrollIntoView({ block: \"nearest\" });\n if (candidate === firstItem && viewport) viewport.scrollTop = 0;\n if (candidate === lastItem && viewport) viewport.scrollTop = viewport.scrollHeight;\n candidate?.focus();\n if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;\n }\n },\n [getItems, viewport]\n );\n const focusSelectedItem = React.useCallback(\n () => focusFirst([selectedItem, content]),\n [focusFirst, selectedItem, content]\n );\n React.useEffect(() => {\n if (isPositioned) {\n focusSelectedItem();\n }\n }, [isPositioned, focusSelectedItem]);\n const { onOpenChange, triggerPointerDownPosRef } = context;\n React.useEffect(() => {\n if (content) {\n let pointerMoveDelta = { x: 0, y: 0 };\n const handlePointerMove = (event) => {\n pointerMoveDelta = {\n x: Math.abs(Math.round(event.pageX) - (triggerPointerDownPosRef.current?.x ?? 0)),\n y: Math.abs(Math.round(event.pageY) - (triggerPointerDownPosRef.current?.y ?? 0))\n };\n };\n const handlePointerUp = (event) => {\n if (pointerMoveDelta.x <= 10 && pointerMoveDelta.y <= 10) {\n event.preventDefault();\n } else {\n if (!content.contains(event.target)) {\n onOpenChange(false);\n }\n }\n document.removeEventListener(\"pointermove\", handlePointerMove);\n triggerPointerDownPosRef.current = null;\n };\n if (triggerPointerDownPosRef.current !== null) {\n document.addEventListener(\"pointermove\", handlePointerMove);\n document.addEventListener(\"pointerup\", handlePointerUp, { capture: true, once: true });\n }\n return () => {\n document.removeEventListener(\"pointermove\", handlePointerMove);\n document.removeEventListener(\"pointerup\", handlePointerUp, { capture: true });\n };\n }\n }, [content, onOpenChange, triggerPointerDownPosRef]);\n React.useEffect(() => {\n const close = () => onOpenChange(false);\n window.addEventListener(\"blur\", close);\n window.addEventListener(\"resize\", close);\n return () => {\n window.removeEventListener(\"blur\", close);\n window.removeEventListener(\"resize\", close);\n };\n }, [onOpenChange]);\n const [searchRef, handleTypeaheadSearch] = useTypeaheadSearch((search) => {\n const enabledItems = getItems().filter((item) => !item.disabled);\n const currentItem = enabledItems.find((item) => item.ref.current === document.activeElement);\n const nextItem = findNextItem(enabledItems, search, currentItem);\n if (nextItem) {\n setTimeout(() => nextItem.ref.current.focus());\n }\n });\n const itemRefCallback = React.useCallback(\n (node, value, disabled) => {\n const isFirstValidItem = !firstValidItemFoundRef.current && !disabled;\n const isSelectedItem = context.value !== void 0 && context.value === value;\n if (isSelectedItem || isFirstValidItem) {\n setSelectedItem(node);\n if (isFirstValidItem) firstValidItemFoundRef.current = true;\n }\n },\n [context.value]\n );\n const handleItemLeave = React.useCallback(() => content?.focus(), [content]);\n const itemTextRefCallback = React.useCallback(\n (node, value, disabled) => {\n const isFirstValidItem = !firstValidItemFoundRef.current && !disabled;\n const isSelectedItem = context.value !== void 0 && context.value === value;\n if (isSelectedItem || isFirstValidItem) {\n setSelectedItemText(node);\n }\n },\n [context.value]\n );\n const SelectPosition = position === \"popper\" ? SelectPopperPosition : SelectItemAlignedPosition;\n const popperContentProps = SelectPosition === SelectPopperPosition ? {\n side,\n sideOffset,\n align,\n alignOffset,\n arrowPadding,\n collisionBoundary,\n collisionPadding,\n sticky,\n hideWhenDetached,\n avoidCollisions\n } : {};\n return /* @__PURE__ */ jsx(\n SelectContentProvider,\n {\n scope: __scopeSelect,\n content,\n viewport,\n onViewportChange: setViewport,\n itemRefCallback,\n selectedItem,\n onItemLeave: handleItemLeave,\n itemTextRefCallback,\n focusSelectedItem,\n selectedItemText,\n position,\n isPositioned,\n searchRef,\n children: /* @__PURE__ */ jsx(RemoveScroll, { as: Slot, allowPinchZoom: true, children: /* @__PURE__ */ jsx(\n FocusScope,\n {\n asChild: true,\n trapped: context.open,\n onMountAutoFocus: (event) => {\n event.preventDefault();\n },\n onUnmountAutoFocus: composeEventHandlers(onCloseAutoFocus, (event) => {\n context.trigger?.focus({ preventScroll: true });\n event.preventDefault();\n }),\n children: /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n asChild: true,\n disableOutsidePointerEvents: true,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside: (event) => event.preventDefault(),\n onDismiss: () => context.onOpenChange(false),\n children: /* @__PURE__ */ jsx(\n SelectPosition,\n {\n role: \"listbox\",\n id: context.contentId,\n \"data-state\": context.open ? \"open\" : \"closed\",\n dir: context.dir,\n onContextMenu: (event) => event.preventDefault(),\n ...contentProps,\n ...popperContentProps,\n onPlaced: () => setIsPositioned(true),\n ref: composedRefs,\n style: {\n // flex layout so we can place the scroll buttons properly\n display: \"flex\",\n flexDirection: \"column\",\n // reset the outline by default as the content MAY get focused\n outline: \"none\",\n ...contentProps.style\n },\n onKeyDown: composeEventHandlers(contentProps.onKeyDown, (event) => {\n const isModifierKey = event.ctrlKey || event.altKey || event.metaKey;\n if (event.key === \"Tab\") event.preventDefault();\n if (!isModifierKey && event.key.length === 1) handleTypeaheadSearch(event.key);\n if ([\"ArrowUp\", \"ArrowDown\", \"Home\", \"End\"].includes(event.key)) {\n const items = getItems().filter((item) => !item.disabled);\n let candidateNodes = items.map((item) => item.ref.current);\n if ([\"ArrowUp\", \"End\"].includes(event.key)) {\n candidateNodes = candidateNodes.slice().reverse();\n }\n if ([\"ArrowUp\", \"ArrowDown\"].includes(event.key)) {\n const currentElement = event.target;\n const currentIndex = candidateNodes.indexOf(currentElement);\n candidateNodes = candidateNodes.slice(currentIndex + 1);\n }\n setTimeout(() => focusFirst(candidateNodes));\n event.preventDefault();\n }\n })\n }\n )\n }\n )\n }\n ) })\n }\n );\n }\n);\nSelectContentImpl.displayName = CONTENT_IMPL_NAME;\nvar ITEM_ALIGNED_POSITION_NAME = \"SelectItemAlignedPosition\";\nvar SelectItemAlignedPosition = React.forwardRef((props, forwardedRef) => {\n const { __scopeSelect, onPlaced, ...popperProps } = props;\n const context = useSelectContext(CONTENT_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(CONTENT_NAME, __scopeSelect);\n const [contentWrapper, setContentWrapper] = React.useState(null);\n const [content, setContent] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContent(node));\n const getItems = useCollection(__scopeSelect);\n const shouldExpandOnScrollRef = React.useRef(false);\n const shouldRepositionRef = React.useRef(true);\n const { viewport, selectedItem, selectedItemText, focusSelectedItem } = contentContext;\n const position = React.useCallback(() => {\n if (context.trigger && context.valueNode && contentWrapper && content && viewport && selectedItem && selectedItemText) {\n const triggerRect = context.trigger.getBoundingClientRect();\n const contentRect = content.getBoundingClientRect();\n const valueNodeRect = context.valueNode.getBoundingClientRect();\n const itemTextRect = selectedItemText.getBoundingClientRect();\n if (context.dir !== \"rtl\") {\n const itemTextOffset = itemTextRect.left - contentRect.left;\n const left = valueNodeRect.left - itemTextOffset;\n const leftDelta = triggerRect.left - left;\n const minContentWidth = triggerRect.width + leftDelta;\n const contentWidth = Math.max(minContentWidth, contentRect.width);\n const rightEdge = window.innerWidth - CONTENT_MARGIN;\n const clampedLeft = clamp(left, [\n CONTENT_MARGIN,\n // Prevents the content from going off the starting edge of the\n // viewport. It may still go off the ending edge, but this can be\n // controlled by the user since they may want to manage overflow in a\n // specific way.\n // https://github.com/radix-ui/primitives/issues/2049\n Math.max(CONTENT_MARGIN, rightEdge - contentWidth)\n ]);\n contentWrapper.style.minWidth = minContentWidth + \"px\";\n contentWrapper.style.left = clampedLeft + \"px\";\n } else {\n const itemTextOffset = contentRect.right - itemTextRect.right;\n const right = window.innerWidth - valueNodeRect.right - itemTextOffset;\n const rightDelta = window.innerWidth - triggerRect.right - right;\n const minContentWidth = triggerRect.width + rightDelta;\n const contentWidth = Math.max(minContentWidth, contentRect.width);\n const leftEdge = window.innerWidth - CONTENT_MARGIN;\n const clampedRight = clamp(right, [\n CONTENT_MARGIN,\n Math.max(CONTENT_MARGIN, leftEdge - contentWidth)\n ]);\n contentWrapper.style.minWidth = minContentWidth + \"px\";\n contentWrapper.style.right = clampedRight + \"px\";\n }\n const items = getItems();\n const availableHeight = window.innerHeight - CONTENT_MARGIN * 2;\n const itemsHeight = viewport.scrollHeight;\n const contentStyles = window.getComputedStyle(content);\n const contentBorderTopWidth = parseInt(contentStyles.borderTopWidth, 10);\n const contentPaddingTop = parseInt(contentStyles.paddingTop, 10);\n const contentBorderBottomWidth = parseInt(contentStyles.borderBottomWidth, 10);\n const contentPaddingBottom = parseInt(contentStyles.paddingBottom, 10);\n const fullContentHeight = contentBorderTopWidth + contentPaddingTop + itemsHeight + contentPaddingBottom + contentBorderBottomWidth;\n const minContentHeight = Math.min(selectedItem.offsetHeight * 5, fullContentHeight);\n const viewportStyles = window.getComputedStyle(viewport);\n const viewportPaddingTop = parseInt(viewportStyles.paddingTop, 10);\n const viewportPaddingBottom = parseInt(viewportStyles.paddingBottom, 10);\n const topEdgeToTriggerMiddle = triggerRect.top + triggerRect.height / 2 - CONTENT_MARGIN;\n const triggerMiddleToBottomEdge = availableHeight - topEdgeToTriggerMiddle;\n const selectedItemHalfHeight = selectedItem.offsetHeight / 2;\n const itemOffsetMiddle = selectedItem.offsetTop + selectedItemHalfHeight;\n const contentTopToItemMiddle = contentBorderTopWidth + contentPaddingTop + itemOffsetMiddle;\n const itemMiddleToContentBottom = fullContentHeight - contentTopToItemMiddle;\n const willAlignWithoutTopOverflow = contentTopToItemMiddle <= topEdgeToTriggerMiddle;\n if (willAlignWithoutTopOverflow) {\n const isLastItem = items.length > 0 && selectedItem === items[items.length - 1].ref.current;\n contentWrapper.style.bottom = \"0px\";\n const viewportOffsetBottom = content.clientHeight - viewport.offsetTop - viewport.offsetHeight;\n const clampedTriggerMiddleToBottomEdge = Math.max(\n triggerMiddleToBottomEdge,\n selectedItemHalfHeight + // viewport might have padding bottom, include it to avoid a scrollable viewport\n (isLastItem ? viewportPaddingBottom : 0) + viewportOffsetBottom + contentBorderBottomWidth\n );\n const height = contentTopToItemMiddle + clampedTriggerMiddleToBottomEdge;\n contentWrapper.style.height = height + \"px\";\n } else {\n const isFirstItem = items.length > 0 && selectedItem === items[0].ref.current;\n contentWrapper.style.top = \"0px\";\n const clampedTopEdgeToTriggerMiddle = Math.max(\n topEdgeToTriggerMiddle,\n contentBorderTopWidth + viewport.offsetTop + // viewport might have padding top, include it to avoid a scrollable viewport\n (isFirstItem ? viewportPaddingTop : 0) + selectedItemHalfHeight\n );\n const height = clampedTopEdgeToTriggerMiddle + itemMiddleToContentBottom;\n contentWrapper.style.height = height + \"px\";\n viewport.scrollTop = contentTopToItemMiddle - topEdgeToTriggerMiddle + viewport.offsetTop;\n }\n contentWrapper.style.margin = `${CONTENT_MARGIN}px 0`;\n contentWrapper.style.minHeight = minContentHeight + \"px\";\n contentWrapper.style.maxHeight = availableHeight + \"px\";\n onPlaced?.();\n requestAnimationFrame(() => shouldExpandOnScrollRef.current = true);\n }\n }, [\n getItems,\n context.trigger,\n context.valueNode,\n contentWrapper,\n content,\n viewport,\n selectedItem,\n selectedItemText,\n context.dir,\n onPlaced\n ]);\n useLayoutEffect(() => position(), [position]);\n const [contentZIndex, setContentZIndex] = React.useState();\n useLayoutEffect(() => {\n if (content) setContentZIndex(window.getComputedStyle(content).zIndex);\n }, [content]);\n const handleScrollButtonChange = React.useCallback(\n (node) => {\n if (node && shouldRepositionRef.current === true) {\n position();\n focusSelectedItem?.();\n shouldRepositionRef.current = false;\n }\n },\n [position, focusSelectedItem]\n );\n return /* @__PURE__ */ jsx(\n SelectViewportProvider,\n {\n scope: __scopeSelect,\n contentWrapper,\n shouldExpandOnScrollRef,\n onScrollButtonChange: handleScrollButtonChange,\n children: /* @__PURE__ */ jsx(\n \"div\",\n {\n ref: setContentWrapper,\n style: {\n display: \"flex\",\n flexDirection: \"column\",\n position: \"fixed\",\n zIndex: contentZIndex\n },\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n ...popperProps,\n ref: composedRefs,\n style: {\n // When we get the height of the content, it includes borders. If we were to set\n // the height without having `boxSizing: 'border-box'` it would be too big.\n boxSizing: \"border-box\",\n // We need to ensure the content doesn't get taller than the wrapper\n maxHeight: \"100%\",\n ...popperProps.style\n }\n }\n )\n }\n )\n }\n );\n});\nSelectItemAlignedPosition.displayName = ITEM_ALIGNED_POSITION_NAME;\nvar POPPER_POSITION_NAME = \"SelectPopperPosition\";\nvar SelectPopperPosition = React.forwardRef((props, forwardedRef) => {\n const {\n __scopeSelect,\n align = \"start\",\n collisionPadding = CONTENT_MARGIN,\n ...popperProps\n } = props;\n const popperScope = usePopperScope(__scopeSelect);\n return /* @__PURE__ */ jsx(\n PopperPrimitive.Content,\n {\n ...popperScope,\n ...popperProps,\n ref: forwardedRef,\n align,\n collisionPadding,\n style: {\n // Ensure border-box for floating-ui calculations\n boxSizing: \"border-box\",\n ...popperProps.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-select-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-select-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-select-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-select-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-select-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n }\n }\n );\n});\nSelectPopperPosition.displayName = POPPER_POSITION_NAME;\nvar [SelectViewportProvider, useSelectViewportContext] = createSelectContext(CONTENT_NAME, {});\nvar VIEWPORT_NAME = \"SelectViewport\";\nvar SelectViewport = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, nonce, ...viewportProps } = props;\n const contentContext = useSelectContentContext(VIEWPORT_NAME, __scopeSelect);\n const viewportContext = useSelectViewportContext(VIEWPORT_NAME, __scopeSelect);\n const composedRefs = useComposedRefs(forwardedRef, contentContext.onViewportChange);\n const prevScrollTopRef = React.useRef(0);\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(\n \"style\",\n {\n dangerouslySetInnerHTML: {\n __html: `[data-radix-select-viewport]{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;}[data-radix-select-viewport]::-webkit-scrollbar{display:none}`\n },\n nonce\n }\n ),\n /* @__PURE__ */ jsx(Collection.Slot, { scope: __scopeSelect, children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-radix-select-viewport\": \"\",\n role: \"presentation\",\n ...viewportProps,\n ref: composedRefs,\n style: {\n // we use position: 'relative' here on the `viewport` so that when we call\n // `selectedItem.offsetTop` in calculations, the offset is relative to the viewport\n // (independent of the scrollUpButton).\n position: \"relative\",\n flex: 1,\n // Viewport should only be scrollable in the vertical direction.\n // This won't work in vertical writing modes, so we'll need to\n // revisit this if/when that is supported\n // https://developer.chrome.com/blog/vertical-form-controls\n overflow: \"hidden auto\",\n ...viewportProps.style\n },\n onScroll: composeEventHandlers(viewportProps.onScroll, (event) => {\n const viewport = event.currentTarget;\n const { contentWrapper, shouldExpandOnScrollRef } = viewportContext;\n if (shouldExpandOnScrollRef?.current && contentWrapper) {\n const scrolledBy = Math.abs(prevScrollTopRef.current - viewport.scrollTop);\n if (scrolledBy > 0) {\n const availableHeight = window.innerHeight - CONTENT_MARGIN * 2;\n const cssMinHeight = parseFloat(contentWrapper.style.minHeight);\n const cssHeight = parseFloat(contentWrapper.style.height);\n const prevHeight = Math.max(cssMinHeight, cssHeight);\n if (prevHeight < availableHeight) {\n const nextHeight = prevHeight + scrolledBy;\n const clampedNextHeight = Math.min(availableHeight, nextHeight);\n const heightDiff = nextHeight - clampedNextHeight;\n contentWrapper.style.height = clampedNextHeight + \"px\";\n if (contentWrapper.style.bottom === \"0px\") {\n viewport.scrollTop = heightDiff > 0 ? heightDiff : 0;\n contentWrapper.style.justifyContent = \"flex-end\";\n }\n }\n }\n }\n prevScrollTopRef.current = viewport.scrollTop;\n })\n }\n ) })\n ] });\n }\n);\nSelectViewport.displayName = VIEWPORT_NAME;\nvar GROUP_NAME = \"SelectGroup\";\nvar [SelectGroupContextProvider, useSelectGroupContext] = createSelectContext(GROUP_NAME);\nvar SelectGroup = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...groupProps } = props;\n const groupId = useId();\n return /* @__PURE__ */ jsx(SelectGroupContextProvider, { scope: __scopeSelect, id: groupId, children: /* @__PURE__ */ jsx(Primitive.div, { role: \"group\", \"aria-labelledby\": groupId, ...groupProps, ref: forwardedRef }) });\n }\n);\nSelectGroup.displayName = GROUP_NAME;\nvar LABEL_NAME = \"SelectLabel\";\nvar SelectLabel = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...labelProps } = props;\n const groupContext = useSelectGroupContext(LABEL_NAME, __scopeSelect);\n return /* @__PURE__ */ jsx(Primitive.div, { id: groupContext.id, ...labelProps, ref: forwardedRef });\n }\n);\nSelectLabel.displayName = LABEL_NAME;\nvar ITEM_NAME = \"SelectItem\";\nvar [SelectItemContextProvider, useSelectItemContext] = createSelectContext(ITEM_NAME);\nvar SelectItem = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeSelect,\n value,\n disabled = false,\n textValue: textValueProp,\n ...itemProps\n } = props;\n const context = useSelectContext(ITEM_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ITEM_NAME, __scopeSelect);\n const isSelected = context.value === value;\n const [textValue, setTextValue] = React.useState(textValueProp ?? \"\");\n const [isFocused, setIsFocused] = React.useState(false);\n const composedRefs = useComposedRefs(\n forwardedRef,\n (node) => contentContext.itemRefCallback?.(node, value, disabled)\n );\n const textId = useId();\n const pointerTypeRef = React.useRef(\"touch\");\n const handleSelect = () => {\n if (!disabled) {\n context.onValueChange(value);\n context.onOpenChange(false);\n }\n };\n if (value === \"\") {\n throw new Error(\n \"A <Select.Item /> must have a value prop that is not an empty string. This is because the Select value can be set to an empty string to clear the selection and show the placeholder.\"\n );\n }\n return /* @__PURE__ */ jsx(\n SelectItemContextProvider,\n {\n scope: __scopeSelect,\n value,\n disabled,\n textId,\n isSelected,\n onItemTextChange: React.useCallback((node) => {\n setTextValue((prevTextValue) => prevTextValue || (node?.textContent ?? \"\").trim());\n }, []),\n children: /* @__PURE__ */ jsx(\n Collection.ItemSlot,\n {\n scope: __scopeSelect,\n value,\n disabled,\n textValue,\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n role: \"option\",\n \"aria-labelledby\": textId,\n \"data-highlighted\": isFocused ? \"\" : void 0,\n \"aria-selected\": isSelected && isFocused,\n \"data-state\": isSelected ? \"checked\" : \"unchecked\",\n \"aria-disabled\": disabled || void 0,\n \"data-disabled\": disabled ? \"\" : void 0,\n tabIndex: disabled ? void 0 : -1,\n ...itemProps,\n ref: composedRefs,\n onFocus: composeEventHandlers(itemProps.onFocus, () => setIsFocused(true)),\n onBlur: composeEventHandlers(itemProps.onBlur, () => setIsFocused(false)),\n onClick: composeEventHandlers(itemProps.onClick, () => {\n if (pointerTypeRef.current !== \"mouse\") handleSelect();\n }),\n onPointerUp: composeEventHandlers(itemProps.onPointerUp, () => {\n if (pointerTypeRef.current === \"mouse\") handleSelect();\n }),\n onPointerDown: composeEventHandlers(itemProps.onPointerDown, (event) => {\n pointerTypeRef.current = event.pointerType;\n }),\n onPointerMove: composeEventHandlers(itemProps.onPointerMove, (event) => {\n pointerTypeRef.current = event.pointerType;\n if (disabled) {\n contentContext.onItemLeave?.();\n } else if (pointerTypeRef.current === \"mouse\") {\n event.currentTarget.focus({ preventScroll: true });\n }\n }),\n onPointerLeave: composeEventHandlers(itemProps.onPointerLeave, (event) => {\n if (event.currentTarget === document.activeElement) {\n contentContext.onItemLeave?.();\n }\n }),\n onKeyDown: composeEventHandlers(itemProps.onKeyDown, (event) => {\n const isTypingAhead = contentContext.searchRef?.current !== \"\";\n if (isTypingAhead && event.key === \" \") return;\n if (SELECTION_KEYS.includes(event.key)) handleSelect();\n if (event.key === \" \") event.preventDefault();\n })\n }\n )\n }\n )\n }\n );\n }\n);\nSelectItem.displayName = ITEM_NAME;\nvar ITEM_TEXT_NAME = \"SelectItemText\";\nvar SelectItemText = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, className, style, ...itemTextProps } = props;\n const context = useSelectContext(ITEM_TEXT_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ITEM_TEXT_NAME, __scopeSelect);\n const itemContext = useSelectItemContext(ITEM_TEXT_NAME, __scopeSelect);\n const nativeOptionsContext = useSelectNativeOptionsContext(ITEM_TEXT_NAME, __scopeSelect);\n const [itemTextNode, setItemTextNode] = React.useState(null);\n const composedRefs = useComposedRefs(\n forwardedRef,\n (node) => setItemTextNode(node),\n itemContext.onItemTextChange,\n (node) => contentContext.itemTextRefCallback?.(node, itemContext.value, itemContext.disabled)\n );\n const textContent = itemTextNode?.textContent;\n const nativeOption = React.useMemo(\n () => /* @__PURE__ */ jsx(\"option\", { value: itemContext.value, disabled: itemContext.disabled, children: textContent }, itemContext.value),\n [itemContext.disabled, itemContext.value, textContent]\n );\n const { onNativeOptionAdd, onNativeOptionRemove } = nativeOptionsContext;\n useLayoutEffect(() => {\n onNativeOptionAdd(nativeOption);\n return () => onNativeOptionRemove(nativeOption);\n }, [onNativeOptionAdd, onNativeOptionRemove, nativeOption]);\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(Primitive.span, { id: itemContext.textId, ...itemTextProps, ref: composedRefs }),\n itemContext.isSelected && context.valueNode && !context.valueNodeHasChildren ? ReactDOM.createPortal(itemTextProps.children, context.valueNode) : null\n ] });\n }\n);\nSelectItemText.displayName = ITEM_TEXT_NAME;\nvar ITEM_INDICATOR_NAME = \"SelectItemIndicator\";\nvar SelectItemIndicator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...itemIndicatorProps } = props;\n const itemContext = useSelectItemContext(ITEM_INDICATOR_NAME, __scopeSelect);\n return itemContext.isSelected ? /* @__PURE__ */ jsx(Primitive.span, { \"aria-hidden\": true, ...itemIndicatorProps, ref: forwardedRef }) : null;\n }\n);\nSelectItemIndicator.displayName = ITEM_INDICATOR_NAME;\nvar SCROLL_UP_BUTTON_NAME = \"SelectScrollUpButton\";\nvar SelectScrollUpButton = React.forwardRef((props, forwardedRef) => {\n const contentContext = useSelectContentContext(SCROLL_UP_BUTTON_NAME, props.__scopeSelect);\n const viewportContext = useSelectViewportContext(SCROLL_UP_BUTTON_NAME, props.__scopeSelect);\n const [canScrollUp, setCanScrollUp] = React.useState(false);\n const composedRefs = useComposedRefs(forwardedRef, viewportContext.onScrollButtonChange);\n useLayoutEffect(() => {\n if (contentContext.viewport && contentContext.isPositioned) {\n let handleScroll2 = function() {\n const canScrollUp2 = viewport.scrollTop > 0;\n setCanScrollUp(canScrollUp2);\n };\n var handleScroll = handleScroll2;\n const viewport = contentContext.viewport;\n handleScroll2();\n viewport.addEventListener(\"scroll\", handleScroll2);\n return () => viewport.removeEventListener(\"scroll\", handleScroll2);\n }\n }, [contentContext.viewport, contentContext.isPositioned]);\n return canScrollUp ? /* @__PURE__ */ jsx(\n SelectScrollButtonImpl,\n {\n ...props,\n ref: composedRefs,\n onAutoScroll: () => {\n const { viewport, selectedItem } = contentContext;\n if (viewport && selectedItem) {\n viewport.scrollTop = viewport.scrollTop - selectedItem.offsetHeight;\n }\n }\n }\n ) : null;\n});\nSelectScrollUpButton.displayName = SCROLL_UP_BUTTON_NAME;\nvar SCROLL_DOWN_BUTTON_NAME = \"SelectScrollDownButton\";\nvar SelectScrollDownButton = React.forwardRef((props, forwardedRef) => {\n const contentContext = useSelectContentContext(SCROLL_DOWN_BUTTON_NAME, props.__scopeSelect);\n const viewportContext = useSelectViewportContext(SCROLL_DOWN_BUTTON_NAME, props.__scopeSelect);\n const [canScrollDown, setCanScrollDown] = React.useState(false);\n const composedRefs = useComposedRefs(forwardedRef, viewportContext.onScrollButtonChange);\n useLayoutEffect(() => {\n if (contentContext.viewport && contentContext.isPositioned) {\n let handleScroll2 = function() {\n const maxScroll = viewport.scrollHeight - viewport.clientHeight;\n const canScrollDown2 = Math.ceil(viewport.scrollTop) < maxScroll;\n setCanScrollDown(canScrollDown2);\n };\n var handleScroll = handleScroll2;\n const viewport = contentContext.viewport;\n handleScroll2();\n viewport.addEventListener(\"scroll\", handleScroll2);\n return () => viewport.removeEventListener(\"scroll\", handleScroll2);\n }\n }, [contentContext.viewport, contentContext.isPositioned]);\n return canScrollDown ? /* @__PURE__ */ jsx(\n SelectScrollButtonImpl,\n {\n ...props,\n ref: composedRefs,\n onAutoScroll: () => {\n const { viewport, selectedItem } = contentContext;\n if (viewport && selectedItem) {\n viewport.scrollTop = viewport.scrollTop + selectedItem.offsetHeight;\n }\n }\n }\n ) : null;\n});\nSelectScrollDownButton.displayName = SCROLL_DOWN_BUTTON_NAME;\nvar SelectScrollButtonImpl = React.forwardRef((props, forwardedRef) => {\n const { __scopeSelect, onAutoScroll, ...scrollIndicatorProps } = props;\n const contentContext = useSelectContentContext(\"SelectScrollButton\", __scopeSelect);\n const autoScrollTimerRef = React.useRef(null);\n const getItems = useCollection(__scopeSelect);\n const clearAutoScrollTimer = React.useCallback(() => {\n if (autoScrollTimerRef.current !== null) {\n window.clearInterval(autoScrollTimerRef.current);\n autoScrollTimerRef.current = null;\n }\n }, []);\n React.useEffect(() => {\n return () => clearAutoScrollTimer();\n }, [clearAutoScrollTimer]);\n useLayoutEffect(() => {\n const activeItem = getItems().find((item) => item.ref.current === document.activeElement);\n activeItem?.ref.current?.scrollIntoView({ block: \"nearest\" });\n }, [getItems]);\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"aria-hidden\": true,\n ...scrollIndicatorProps,\n ref: forwardedRef,\n style: { flexShrink: 0, ...scrollIndicatorProps.style },\n onPointerDown: composeEventHandlers(scrollIndicatorProps.onPointerDown, () => {\n if (autoScrollTimerRef.current === null) {\n autoScrollTimerRef.current = window.setInterval(onAutoScroll, 50);\n }\n }),\n onPointerMove: composeEventHandlers(scrollIndicatorProps.onPointerMove, () => {\n contentContext.onItemLeave?.();\n if (autoScrollTimerRef.current === null) {\n autoScrollTimerRef.current = window.setInterval(onAutoScroll, 50);\n }\n }),\n onPointerLeave: composeEventHandlers(scrollIndicatorProps.onPointerLeave, () => {\n clearAutoScrollTimer();\n })\n }\n );\n});\nvar SEPARATOR_NAME = \"SelectSeparator\";\nvar SelectSeparator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...separatorProps } = props;\n return /* @__PURE__ */ jsx(Primitive.div, { \"aria-hidden\": true, ...separatorProps, ref: forwardedRef });\n }\n);\nSelectSeparator.displayName = SEPARATOR_NAME;\nvar ARROW_NAME = \"SelectArrow\";\nvar SelectArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const context = useSelectContext(ARROW_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ARROW_NAME, __scopeSelect);\n return context.open && contentContext.position === \"popper\" ? /* @__PURE__ */ jsx(PopperPrimitive.Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef }) : null;\n }\n);\nSelectArrow.displayName = ARROW_NAME;\nvar BUBBLE_INPUT_NAME = \"SelectBubbleInput\";\nvar SelectBubbleInput = React.forwardRef(\n ({ __scopeSelect, value, ...props }, forwardedRef) => {\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const prevValue = usePrevious(value);\n React.useEffect(() => {\n const select = ref.current;\n if (!select) return;\n const selectProto = window.HTMLSelectElement.prototype;\n const descriptor = Object.getOwnPropertyDescriptor(\n selectProto,\n \"value\"\n );\n const setValue = descriptor.set;\n if (prevValue !== value && setValue) {\n const event = new Event(\"change\", { bubbles: true });\n setValue.call(select, value);\n select.dispatchEvent(event);\n }\n }, [prevValue, value]);\n return /* @__PURE__ */ jsx(\n Primitive.select,\n {\n ...props,\n style: { ...VISUALLY_HIDDEN_STYLES, ...props.style },\n ref: composedRefs,\n defaultValue: value\n }\n );\n }\n);\nSelectBubbleInput.displayName = BUBBLE_INPUT_NAME;\nfunction shouldShowPlaceholder(value) {\n return value === \"\" || value === void 0;\n}\nfunction useTypeaheadSearch(onSearchChange) {\n const handleSearchChange = useCallbackRef(onSearchChange);\n const searchRef = React.useRef(\"\");\n const timerRef = React.useRef(0);\n const handleTypeaheadSearch = React.useCallback(\n (key) => {\n const search = searchRef.current + key;\n handleSearchChange(search);\n (function updateSearch(value) {\n searchRef.current = value;\n window.clearTimeout(timerRef.current);\n if (value !== \"\") timerRef.current = window.setTimeout(() => updateSearch(\"\"), 1e3);\n })(search);\n },\n [handleSearchChange]\n );\n const resetTypeahead = React.useCallback(() => {\n searchRef.current = \"\";\n window.clearTimeout(timerRef.current);\n }, []);\n React.useEffect(() => {\n return () => window.clearTimeout(timerRef.current);\n }, []);\n return [searchRef, handleTypeaheadSearch, resetTypeahead];\n}\nfunction findNextItem(items, search, currentItem) {\n const isRepeated = search.length > 1 && Array.from(search).every((char) => char === search[0]);\n const normalizedSearch = isRepeated ? search[0] : search;\n const currentItemIndex = currentItem ? items.indexOf(currentItem) : -1;\n let wrappedItems = wrapArray(items, Math.max(currentItemIndex, 0));\n const excludeCurrentItem = normalizedSearch.length === 1;\n if (excludeCurrentItem) wrappedItems = wrappedItems.filter((v) => v !== currentItem);\n const nextItem = wrappedItems.find(\n (item) => item.textValue.toLowerCase().startsWith(normalizedSearch.toLowerCase())\n );\n return nextItem !== currentItem ? nextItem : void 0;\n}\nfunction wrapArray(array, startIndex) {\n return array.map((_, index) => array[(startIndex + index) % array.length]);\n}\nvar Root2 = Select;\nvar Trigger = SelectTrigger;\nvar Value = SelectValue;\nvar Icon = SelectIcon;\nvar Portal = SelectPortal;\nvar Content2 = SelectContent;\nvar Viewport = SelectViewport;\nvar Group = SelectGroup;\nvar Label = SelectLabel;\nvar Item = SelectItem;\nvar ItemText = SelectItemText;\nvar ItemIndicator = SelectItemIndicator;\nvar ScrollUpButton = SelectScrollUpButton;\nvar ScrollDownButton = SelectScrollDownButton;\nvar Separator = SelectSeparator;\nvar Arrow2 = SelectArrow;\nexport {\n Arrow2 as Arrow,\n Content2 as Content,\n Group,\n Icon,\n Item,\n ItemIndicator,\n ItemText,\n Label,\n Portal,\n Root2 as Root,\n ScrollDownButton,\n ScrollUpButton,\n Select,\n SelectArrow,\n SelectContent,\n SelectGroup,\n SelectIcon,\n SelectItem,\n SelectItemIndicator,\n SelectItemText,\n SelectLabel,\n SelectPortal,\n SelectScrollDownButton,\n SelectScrollUpButton,\n SelectSeparator,\n SelectTrigger,\n SelectValue,\n SelectViewport,\n Separator,\n Trigger,\n Value,\n Viewport,\n createSelectScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from \"react\"\nimport { Select as SelectPrimitive } from \"radix-ui\"\n\nimport { cn } from \"@/lib/utils\"\nimport { ChevronDownIcon, CheckIcon, ChevronUpIcon } from \"lucide-react\"\n\nfunction Select({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Root>) {\n return <SelectPrimitive.Root data-slot=\"select\" {...props} />\n}\n\nfunction SelectGroup({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Group>) {\n return (\n <SelectPrimitive.Group\n data-slot=\"select-group\"\n className={cn(\"scroll-my-1 p-1\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectValue({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Value>) {\n return <SelectPrimitive.Value data-slot=\"select-value\" {...props} />\n}\n\nfunction SelectTrigger({\n className,\n size = \"default\",\n children,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Trigger> & {\n size?: \"sm\" | \"default\"\n}) {\n return (\n <SelectPrimitive.Trigger\n data-slot=\"select-trigger\"\n data-size={size}\n className={cn(\n \"flex w-fit items-center justify-between gap-1.5 rounded-lg border border-input bg-transparent py-2 pr-2 pl-2.5 text-sm whitespace-nowrap transition-colors outline-none select-none focus-visible:border-ring focus-visible:ring-3 focus-visible:ring-ring/50 disabled:cursor-not-allowed disabled:opacity-50 aria-invalid:border-destructive aria-invalid:ring-3 aria-invalid:ring-destructive/20 data-placeholder:text-muted-foreground data-[size=default]:h-8 data-[size=sm]:h-7 data-[size=sm]:rounded-[min(var(--radius-md),10px)] *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-1.5 dark:bg-input/30 dark:hover:bg-input/50 dark:aria-invalid:border-destructive/50 dark:aria-invalid:ring-destructive/40 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n >\n {children}\n <SelectPrimitive.Icon asChild>\n <ChevronDownIcon className=\"pointer-events-none size-4 text-muted-foreground\" />\n </SelectPrimitive.Icon>\n </SelectPrimitive.Trigger>\n )\n}\n\nfunction SelectContent({\n className,\n children,\n position = \"item-aligned\",\n align = \"center\",\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Content>) {\n return (\n <SelectPrimitive.Portal>\n <SelectPrimitive.Content\n data-slot=\"select-content\"\n data-align-trigger={position === \"item-aligned\"}\n className={cn(\"relative z-50 max-h-(--radix-select-content-available-height) min-w-36 origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-lg bg-popover text-popover-foreground shadow-md ring-1 ring-foreground/10 duration-100 data-[align-trigger=true]:animate-none data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 data-open:animate-in data-open:fade-in-0 data-open:zoom-in-95 data-closed:animate-out data-closed:fade-out-0 data-closed:zoom-out-95\", position ===\"popper\"&&\"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1\", className )}\n position={position}\n align={align}\n {...props}\n >\n <SelectScrollUpButton />\n <SelectPrimitive.Viewport\n data-position={position}\n className={cn(\n \"data-[position=popper]:h-(--radix-select-trigger-height) data-[position=popper]:w-full data-[position=popper]:min-w-(--radix-select-trigger-width)\",\n position === \"popper\" && \"\"\n )}\n >\n {children}\n </SelectPrimitive.Viewport>\n <SelectScrollDownButton />\n </SelectPrimitive.Content>\n </SelectPrimitive.Portal>\n )\n}\n\nfunction SelectLabel({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Label>) {\n return (\n <SelectPrimitive.Label\n data-slot=\"select-label\"\n className={cn(\"px-1.5 py-1 text-xs text-muted-foreground\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectItem({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Item>) {\n return (\n <SelectPrimitive.Item\n data-slot=\"select-item\"\n className={cn(\n \"relative flex w-full cursor-default items-center gap-1.5 rounded-md py-1 pr-8 pl-1.5 text-sm outline-hidden select-none focus:bg-accent focus:text-accent-foreground not-data-[variant=destructive]:focus:**:text-accent-foreground data-disabled:pointer-events-none data-disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2\",\n className\n )}\n {...props}\n >\n <span className=\"pointer-events-none absolute right-2 flex size-4 items-center justify-center\">\n <SelectPrimitive.ItemIndicator>\n <CheckIcon className=\"pointer-events-none\" />\n </SelectPrimitive.ItemIndicator>\n </span>\n <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n </SelectPrimitive.Item>\n )\n}\n\nfunction SelectSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Separator>) {\n return (\n <SelectPrimitive.Separator\n data-slot=\"select-separator\"\n className={cn(\"pointer-events-none -mx-1 my-1 h-px bg-border\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectScrollUpButton({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollUpButton>) {\n return (\n <SelectPrimitive.ScrollUpButton\n data-slot=\"select-scroll-up-button\"\n className={cn(\n \"z-10 flex cursor-default items-center justify-center bg-popover py-1 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n >\n <ChevronUpIcon\n />\n </SelectPrimitive.ScrollUpButton>\n )\n}\n\nfunction SelectScrollDownButton({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollDownButton>) {\n return (\n <SelectPrimitive.ScrollDownButton\n data-slot=\"select-scroll-down-button\"\n className={cn(\n \"z-10 flex cursor-default items-center justify-center bg-popover py-1 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n >\n <ChevronDownIcon\n />\n </SelectPrimitive.ScrollDownButton>\n )\n}\n\nexport {\n Select,\n SelectContent,\n SelectGroup,\n SelectItem,\n SelectLabel,\n SelectScrollDownButton,\n SelectScrollUpButton,\n SelectSeparator,\n SelectTrigger,\n SelectValue,\n}\n","import { useEffect, useState } from 'react'\nimport { api } from '@/lib/api'\nimport { useRelayStore } from '@/store'\nimport { Button } from '@/components/ui/button'\nimport { Input } from '@/components/ui/input'\nimport { Textarea } from '@/components/ui/textarea'\nimport { Switch } from '@/components/ui/switch'\nimport { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select'\nimport { KOKORO_VOICES, availableSpeechVoices } from '@/lib/voice'\nimport { Brain, FolderSymlink, GitMerge, Save, Terminal, TestTube2, Volume2 } from 'lucide-react'\n\ntype ProviderName = 'claude' | 'codex'\n\ninterface ProviderConfig {\n command: string\n defaultArgs: string[]\n env: Record<string, string>\n pluginDirs: string[]\n defaultCapabilities: string[]\n defaultApprovalMode: string\n defaultTags: string[]\n chatCaptureMode: 'final' | 'full'\n headless: {\n tmuxPrefix: string\n shutdownTimeoutMs: number\n }\n}\n\nconst providers: ProviderName[] = ['claude', 'codex']\n\nexport function SettingsView() {\n const [configs, setConfigs] = useState<Record<string, ProviderConfig>>({})\n const [selected, setSelected] = useState<ProviderName>('claude')\n const [status, setStatus] = useState('')\n\n useEffect(() => {\n api<Record<string, ProviderConfig>>('GET', '/providers/config')\n .then(setConfigs)\n .catch((e) => setStatus((e as Error).message))\n }, [])\n\n const config = configs[selected]\n const update = (patch: Partial<ProviderConfig>) => {\n if (!config) return\n setConfigs({ ...configs, [selected]: { ...config, ...patch } })\n }\n\n async function save() {\n if (!config) return\n const saved = await api<ProviderConfig>('PUT', `/providers/${selected}/config`, config)\n setConfigs({ ...configs, [selected]: saved })\n setStatus(`${selected} saved`)\n }\n\n async function test() {\n const result = await api<{ ok: boolean; path?: string; error?: string }>('POST', `/providers/${selected}/config/test`)\n setStatus(result.ok ? `${selected} command: ${result.path || 'found'}` : result.error || 'command not found')\n }\n\n return (\n <div className=\"space-y-4\">\n <div className=\"flex items-center justify-between gap-3\">\n <div>\n <h1 className=\"text-xl font-semibold\">Settings</h1>\n <p className=\"text-sm text-muted-foreground\">Provider runner configuration</p>\n </div>\n <div className=\"flex gap-2\">\n {providers.map((provider) => (\n <Button key={provider} variant={selected === provider ? 'default' : 'outline'} onClick={() => setSelected(provider)}>\n <Terminal className=\"w-4 h-4\" />{provider}\n </Button>\n ))}\n </div>\n </div>\n\n {config && (\n <div className=\"grid gap-4 lg:grid-cols-[minmax(0,1fr)_minmax(280px,360px)]\">\n <section className=\"space-y-3\">\n <Field label=\"Command\">\n <Input value={config.command} onChange={(e) => update({ command: e.target.value })} />\n </Field>\n <Field label=\"Default arguments\">\n <Textarea rows={3} value={config.defaultArgs.join('\\n')} onChange={(e) => update({ defaultArgs: lines(e.target.value) })} />\n </Field>\n <Field label=\"Plugin directories\">\n <Textarea rows={3} value={config.pluginDirs.join('\\n')} onChange={(e) => update({ pluginDirs: lines(e.target.value) })} />\n </Field>\n <Field label=\"Environment\">\n <Textarea rows={5} value={recordLines(config.env)} onChange={(e) => update({ env: parseRecordLines(e.target.value) })} />\n </Field>\n </section>\n\n <section className=\"space-y-3\">\n <Field label=\"Capabilities\">\n <Textarea rows={3} value={config.defaultCapabilities.join('\\n')} onChange={(e) => update({ defaultCapabilities: lines(e.target.value) })} />\n </Field>\n <Field label=\"Tags\">\n <Textarea rows={3} value={config.defaultTags.join('\\n')} onChange={(e) => update({ defaultTags: lines(e.target.value) })} />\n </Field>\n <Field label=\"Approval mode\">\n <Input value={config.defaultApprovalMode} onChange={(e) => update({ defaultApprovalMode: e.target.value })} />\n </Field>\n <Field label=\"Chat capture mode\">\n <Select value={config.chatCaptureMode ?? 'final'} onValueChange={(v) => update({ chatCaptureMode: v as 'final' | 'full' })}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"final\">Final response only</SelectItem>\n <SelectItem value=\"full\">Full turn (intermediate messages)</SelectItem>\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"tmux prefix\">\n <Input value={config.headless.tmuxPrefix} onChange={(e) => update({ headless: { ...config.headless, tmuxPrefix: e.target.value } })} />\n </Field>\n <Field label=\"Shutdown timeout\">\n <Input type=\"number\" value={config.headless.shutdownTimeoutMs} onChange={(e) => update({ headless: { ...config.headless, shutdownTimeoutMs: Number(e.target.value) || 10000 } })} />\n </Field>\n <div className=\"flex gap-2 pt-2\">\n <Button onClick={save}><Save className=\"w-4 h-4\" />Save</Button>\n <Button variant=\"outline\" onClick={test}><TestTube2 className=\"w-4 h-4\" />Test</Button>\n </div>\n {status && <p className=\"text-sm text-muted-foreground\">{status}</p>}\n </section>\n </div>\n )}\n\n <ChatDisplaySettings />\n\n <WorkspaceSettings />\n\n <StewardSettings />\n\n <VoiceSettings />\n </div>\n )\n}\n\ninterface WorkspaceConfig {\n symlinkPaths: string[]\n}\n\nconst DEFAULT_WORKSPACE: WorkspaceConfig = { symlinkPaths: [] }\n\n// Global isolated-worktree provisioning (#159 follow-up). A fresh git worktree only has\n// git-tracked files; node_modules are symlinked automatically and these extra untracked\n// paths are too. Only links what actually exists in main — missing entries are ignored.\nfunction WorkspaceSettings() {\n const [config, setConfig] = useState<WorkspaceConfig>(DEFAULT_WORKSPACE)\n const [status, setStatus] = useState('')\n\n useEffect(() => {\n api<{ value: WorkspaceConfig }>('GET', '/workspace-config')\n .then((entry) => setConfig({ ...DEFAULT_WORKSPACE, ...entry.value }))\n .catch((e) => setStatus((e as Error).message))\n }, [])\n\n async function save() {\n try {\n const saved = await api<{ value: WorkspaceConfig }>('PUT', '/workspace-config', config)\n setConfig({ ...DEFAULT_WORKSPACE, ...saved.value })\n setStatus('Workspace config saved')\n } catch (e) {\n setStatus((e as Error).message)\n }\n }\n\n return (\n <section className=\"space-y-3 rounded-lg border p-4\">\n <div className=\"flex items-center gap-2\">\n <FolderSymlink className=\"w-4 h-4\" />\n <div>\n <h2 className=\"text-sm font-semibold\">Isolated worktree symlinks</h2>\n <p className=\"text-xs text-muted-foreground\">\n Untracked files or filename patterns symlinked from main into each isolated worktree (the "Workspace" spawn option), one per line. Plain names like <code>AGENTS.md</code> or <code>.claude-rig</code> match files and directories; entries with <code>*?[]{'{}'}</code> are expanded as globs. A path is only linked if it exists in main.\n </p>\n </div>\n </div>\n <Field label=\"Paths / patterns\">\n <Textarea\n rows={5}\n placeholder={'AGENTS.md\\n.claude-rig'}\n value={config.symlinkPaths.join('\\n')}\n onChange={(e) => setConfig({ ...config, symlinkPaths: lines(e.target.value) })}\n />\n </Field>\n <div className=\"flex items-center gap-2 pt-1\">\n <Button onClick={save}><Save className=\"w-4 h-4\" />Save</Button>\n {status && <p className=\"text-sm text-muted-foreground\">{status}</p>}\n </div>\n </section>\n )\n}\n\n// Chat display: per-viewer rendering preferences for the Chat panel. These are\n// client-side (persisted in the browser), not provider config — toggling is instant\n// and retroactive. Reasoning steps are still captured by the runner; this only\n// controls whether they're shown. The agent's narration (the terminal's `●` lines)\n// is always shown.\nfunction ChatDisplaySettings() {\n const showReasoning = useRelayStore((s) => s.showReasoning)\n const set = useRelayStore((s) => s.set)\n return (\n <section className=\"space-y-3 rounded-lg border p-4\">\n <div className=\"flex items-center justify-between gap-2\">\n <div className=\"flex items-center gap-2\">\n <Brain className=\"w-4 h-4\" />\n <div>\n <h2 className=\"text-sm font-semibold\">Show reasoning details</h2>\n <p className=\"text-xs text-muted-foreground\">Show the agent's internal thinking inline in chat, alongside its narration and tool steps. Off by default — narration is always shown either way.</p>\n </div>\n </div>\n <Switch checked={showReasoning} onCheckedChange={(v) => set({ showReasoning: v })} />\n </div>\n </section>\n )\n}\n\n// Voice settings: TTS output (speak agent responses — engine + per-engine voice)\n// and the push-to-talk mic-input behaviour. TTS config used to live inline in the\n// chat header; it moved here to declutter the header (especially on mobile). The\n// header keeps only the speaker on/off toggle for quick muting.\nfunction VoiceSettings() {\n const voiceTtsEnabled = useRelayStore((s) => s.voiceTtsEnabled)\n const setVoiceTtsEnabled = useRelayStore((s) => s.setVoiceTtsEnabled)\n const voiceTtsMode = useRelayStore((s) => s.voiceTtsMode)\n const setVoiceTtsMode = useRelayStore((s) => s.setVoiceTtsMode)\n const voiceTtsKokoroVoice = useRelayStore((s) => s.voiceTtsKokoroVoice)\n const setVoiceTtsKokoroVoice = useRelayStore((s) => s.setVoiceTtsKokoroVoice)\n const voiceTtsBrowserVoice = useRelayStore((s) => s.voiceTtsBrowserVoice)\n const setVoiceTtsBrowserVoice = useRelayStore((s) => s.setVoiceTtsBrowserVoice)\n const voiceInputMode = useRelayStore((s) => s.voiceInputMode)\n const setVoiceInputMode = useRelayStore((s) => s.setVoiceInputMode)\n\n // External sync: the browser loads its speech voices asynchronously, so\n // re-read them when the engine signals the list changed.\n const [browserVoices, setBrowserVoices] = useState(() => availableSpeechVoices())\n useEffect(() => {\n if (typeof window === 'undefined' || !('speechSynthesis' in window)) return\n const refresh = () => setBrowserVoices(availableSpeechVoices())\n refresh()\n window.speechSynthesis.addEventListener?.('voiceschanged', refresh)\n return () => window.speechSynthesis.removeEventListener?.('voiceschanged', refresh)\n }, [])\n\n const kokoroOptions = KOKORO_VOICES.some((v) => v.id === voiceTtsKokoroVoice)\n ? KOKORO_VOICES\n : [...KOKORO_VOICES, { id: voiceTtsKokoroVoice, label: voiceTtsKokoroVoice }]\n\n return (\n <section className=\"space-y-3 rounded-lg border p-4\">\n <div className=\"flex items-center justify-between gap-2\">\n <div className=\"flex items-center gap-2\">\n <Volume2 className=\"w-4 h-4\" />\n <div>\n <h2 className=\"text-sm font-semibold\">Voice</h2>\n <p className=\"text-xs text-muted-foreground\">Speak agent responses aloud in the active chat, and how push-to-talk behaves.</p>\n </div>\n </div>\n <Switch checked={voiceTtsEnabled} onCheckedChange={setVoiceTtsEnabled} />\n </div>\n <Field label=\"Speech engine\">\n <Select value={voiceTtsMode} onValueChange={(v) => setVoiceTtsMode(v as 'kokoro' | 'browser')}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"kokoro\">Kokoro (server, natural — falls back to browser)</SelectItem>\n <SelectItem value=\"browser\">Browser (Web Speech API)</SelectItem>\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Kokoro voice\">\n <Select value={voiceTtsKokoroVoice} onValueChange={setVoiceTtsKokoroVoice}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n {kokoroOptions.map((v) => <SelectItem key={v.id} value={v.id}>{v.label}</SelectItem>)}\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Browser voice\">\n <Select value={voiceTtsBrowserVoice || '__default__'} onValueChange={(v) => setVoiceTtsBrowserVoice(v === '__default__' ? '' : v)}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"__default__\">System default</SelectItem>\n {browserVoices.map((v) => <SelectItem key={v.uri} value={v.uri}>{v.label}</SelectItem>)}\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Push-to-talk input\">\n <Select value={voiceInputMode} onValueChange={(v) => setVoiceInputMode(v as 'compose' | 'autosend' | 'handsfree')}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"compose\">Fill the message box (review, then Enter)</SelectItem>\n <SelectItem value=\"autosend\">Send immediately (speak-and-send)</SelectItem>\n </SelectContent>\n </Select>\n </Field>\n </section>\n )\n}\n\ninterface StewardConfig {\n enabled: boolean\n provider: ProviderName\n model?: string\n effort?: 'low' | 'medium' | 'high' | 'xhigh' | 'max'\n permissionMode: string\n keepaliveSeconds: number\n}\n\nconst EFFORTS = ['low', 'medium', 'high', 'xhigh', 'max'] as const\nconst DEFAULT_STEWARD: StewardConfig = { enabled: false, provider: 'claude', permissionMode: 'open', keepaliveSeconds: 300 }\n\n// Global, provider-independent steward config (issue #167). Stewards are\n// auto-provisioned per repo from these settings to resolve conflicts / diverged\n// bases that can't auto-merge. External system: the /steward-config API.\nfunction StewardSettings() {\n const [config, setConfig] = useState<StewardConfig>(DEFAULT_STEWARD)\n const [status, setStatus] = useState('')\n\n useEffect(() => {\n api<{ value: StewardConfig }>('GET', '/steward-config')\n .then((entry) => setConfig({ ...DEFAULT_STEWARD, ...entry.value }))\n .catch((e) => setStatus((e as Error).message))\n }, [])\n\n const update = (patch: Partial<StewardConfig>) => setConfig((c) => ({ ...c, ...patch }))\n\n async function save() {\n try {\n const saved = await api<{ value: StewardConfig }>('PUT', '/steward-config', config)\n setConfig({ ...DEFAULT_STEWARD, ...saved.value })\n setStatus('Steward config saved')\n } catch (e) {\n setStatus((e as Error).message)\n }\n }\n\n return (\n <section className=\"space-y-3 rounded-lg border p-4\">\n <div className=\"flex items-center justify-between\">\n <div className=\"flex items-center gap-2\">\n <GitMerge className=\"w-4 h-4\" />\n <div>\n <h2 className=\"text-sm font-semibold\">Stewards</h2>\n <p className=\"text-xs text-muted-foreground\">Auto-resolve merge conflicts & diverged branches across all repos. Provider-independent — applies to every repo's steward.</p>\n </div>\n </div>\n <Switch checked={config.enabled} onCheckedChange={(v) => update({ enabled: v })} />\n </div>\n\n <div className=\"grid gap-3 sm:grid-cols-2\">\n <Field label=\"Provider\">\n <Select value={config.provider} onValueChange={(v) => update({ provider: v as ProviderName })}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n {providers.map((p) => <SelectItem key={p} value={p}>{p}</SelectItem>)}\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Model (optional)\">\n <Input value={config.model ?? ''} placeholder=\"e.g. gpt-5.5\" onChange={(e) => update({ model: e.target.value.trim() || undefined })} />\n </Field>\n <Field label=\"Effort\">\n <Select value={config.effort ?? 'default'} onValueChange={(v) => update({ effort: v === 'default' ? undefined : v as StewardConfig['effort'] })}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"default\">Provider default</SelectItem>\n {EFFORTS.map((e) => <SelectItem key={e} value={e}>{e}</SelectItem>)}\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Idle timeout (seconds)\">\n <Input type=\"number\" value={config.keepaliveSeconds} onChange={(e) => update({ keepaliveSeconds: Number(e.target.value) || 300 })} />\n </Field>\n </div>\n\n <div className=\"flex items-center gap-2 pt-1\">\n <Button onClick={save}><Save className=\"w-4 h-4\" />Save</Button>\n {status && <p className=\"text-sm text-muted-foreground\">{status}</p>}\n </div>\n </section>\n )\n}\n\nfunction Field({ label, children }: { label: string; children: React.ReactNode }) {\n return <label className=\"block space-y-1.5 text-sm\"><span className=\"text-muted-foreground\">{label}</span>{children}</label>\n}\n\nfunction lines(value: string): string[] {\n return value.split('\\n').map((line) => line.trim()).filter(Boolean)\n}\n\nfunction recordLines(value: Record<string, string>): string {\n return Object.entries(value).map(([key, item]) => `${key}=${item}`).join('\\n')\n}\n\nfunction parseRecordLines(value: string): Record<string, string> {\n return Object.fromEntries(lines(value).map((line) => {\n const idx = line.indexOf('=')\n return idx >= 0 ? [line.slice(0, idx).trim(), line.slice(idx + 1)] : [line, '']\n }))\n}\n"],"x_google_ignoreList":[0],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"settings-B9NDhsAb.js","names":["Select","PopperPrimitive.Root","SelectTrigger","PopperPrimitive.Anchor","SelectValue","Fragment","PortalPrimitive","SelectContent","RemoveScroll","PopperPrimitive.Content","SelectItem","SelectScrollUpButton","SelectScrollDownButton","PopperPrimitive.Arrow"],"sources":["../../dashboard/node_modules/@radix-ui/react-select/dist/index.mjs","../../dashboard/src/components/ui/select.tsx","../../dashboard/src/components/views/settings.tsx"],"sourcesContent":["\"use client\";\n\n// src/select.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { clamp } from \"@radix-ui/number\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { useFocusGuards } from \"@radix-ui/react-focus-guards\";\nimport { FocusScope } from \"@radix-ui/react-focus-scope\";\nimport { useId } from \"@radix-ui/react-id\";\nimport * as PopperPrimitive from \"@radix-ui/react-popper\";\nimport { createPopperScope } from \"@radix-ui/react-popper\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { usePrevious } from \"@radix-ui/react-use-previous\";\nimport { VISUALLY_HIDDEN_STYLES } from \"@radix-ui/react-visually-hidden\";\nimport { hideOthers } from \"aria-hidden\";\nimport { RemoveScroll } from \"react-remove-scroll\";\nimport { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nvar OPEN_KEYS = [\" \", \"Enter\", \"ArrowUp\", \"ArrowDown\"];\nvar SELECTION_KEYS = [\" \", \"Enter\"];\nvar SELECT_NAME = \"Select\";\nvar [Collection, useCollection, createCollectionScope] = createCollection(SELECT_NAME);\nvar [createSelectContext, createSelectScope] = createContextScope(SELECT_NAME, [\n createCollectionScope,\n createPopperScope\n]);\nvar usePopperScope = createPopperScope();\nvar [SelectProvider, useSelectContext] = createSelectContext(SELECT_NAME);\nvar [SelectNativeOptionsProvider, useSelectNativeOptionsContext] = createSelectContext(SELECT_NAME);\nvar Select = (props) => {\n const {\n __scopeSelect,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n value: valueProp,\n defaultValue,\n onValueChange,\n dir,\n name,\n autoComplete,\n disabled,\n required,\n form\n } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const [trigger, setTrigger] = React.useState(null);\n const [valueNode, setValueNode] = React.useState(null);\n const [valueNodeHasChildren, setValueNodeHasChildren] = React.useState(false);\n const direction = useDirection(dir);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: SELECT_NAME\n });\n const [value, setValue] = useControllableState({\n prop: valueProp,\n defaultProp: defaultValue,\n onChange: onValueChange,\n caller: SELECT_NAME\n });\n const triggerPointerDownPosRef = React.useRef(null);\n const isFormControl = trigger ? form || !!trigger.closest(\"form\") : true;\n const [nativeOptionsSet, setNativeOptionsSet] = React.useState(/* @__PURE__ */ new Set());\n const nativeSelectKey = Array.from(nativeOptionsSet).map((option) => option.props.value).join(\";\");\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsxs(\n SelectProvider,\n {\n required,\n scope: __scopeSelect,\n trigger,\n onTriggerChange: setTrigger,\n valueNode,\n onValueNodeChange: setValueNode,\n valueNodeHasChildren,\n onValueNodeHasChildrenChange: setValueNodeHasChildren,\n contentId: useId(),\n value,\n onValueChange: setValue,\n open,\n onOpenChange: setOpen,\n dir: direction,\n triggerPointerDownPosRef,\n disabled,\n children: [\n /* @__PURE__ */ jsx(Collection.Provider, { scope: __scopeSelect, children: /* @__PURE__ */ jsx(\n SelectNativeOptionsProvider,\n {\n scope: props.__scopeSelect,\n onNativeOptionAdd: React.useCallback((option) => {\n setNativeOptionsSet((prev) => new Set(prev).add(option));\n }, []),\n onNativeOptionRemove: React.useCallback((option) => {\n setNativeOptionsSet((prev) => {\n const optionsSet = new Set(prev);\n optionsSet.delete(option);\n return optionsSet;\n });\n }, []),\n children\n }\n ) }),\n isFormControl ? /* @__PURE__ */ jsxs(\n SelectBubbleInput,\n {\n \"aria-hidden\": true,\n required,\n tabIndex: -1,\n name,\n autoComplete,\n value,\n onChange: (event) => setValue(event.target.value),\n disabled,\n form,\n children: [\n value === void 0 ? /* @__PURE__ */ jsx(\"option\", { value: \"\" }) : null,\n Array.from(nativeOptionsSet)\n ]\n },\n nativeSelectKey\n ) : null\n ]\n }\n ) });\n};\nSelect.displayName = SELECT_NAME;\nvar TRIGGER_NAME = \"SelectTrigger\";\nvar SelectTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, disabled = false, ...triggerProps } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const context = useSelectContext(TRIGGER_NAME, __scopeSelect);\n const isDisabled = context.disabled || disabled;\n const composedRefs = useComposedRefs(forwardedRef, context.onTriggerChange);\n const getItems = useCollection(__scopeSelect);\n const pointerTypeRef = React.useRef(\"touch\");\n const [searchRef, handleTypeaheadSearch, resetTypeahead] = useTypeaheadSearch((search) => {\n const enabledItems = getItems().filter((item) => !item.disabled);\n const currentItem = enabledItems.find((item) => item.value === context.value);\n const nextItem = findNextItem(enabledItems, search, currentItem);\n if (nextItem !== void 0) {\n context.onValueChange(nextItem.value);\n }\n });\n const handleOpen = (pointerEvent) => {\n if (!isDisabled) {\n context.onOpenChange(true);\n resetTypeahead();\n }\n if (pointerEvent) {\n context.triggerPointerDownPosRef.current = {\n x: Math.round(pointerEvent.pageX),\n y: Math.round(pointerEvent.pageY)\n };\n }\n };\n return /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { asChild: true, ...popperScope, children: /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n role: \"combobox\",\n \"aria-controls\": context.contentId,\n \"aria-expanded\": context.open,\n \"aria-required\": context.required,\n \"aria-autocomplete\": \"none\",\n dir: context.dir,\n \"data-state\": context.open ? \"open\" : \"closed\",\n disabled: isDisabled,\n \"data-disabled\": isDisabled ? \"\" : void 0,\n \"data-placeholder\": shouldShowPlaceholder(context.value) ? \"\" : void 0,\n ...triggerProps,\n ref: composedRefs,\n onClick: composeEventHandlers(triggerProps.onClick, (event) => {\n event.currentTarget.focus();\n if (pointerTypeRef.current !== \"mouse\") {\n handleOpen(event);\n }\n }),\n onPointerDown: composeEventHandlers(triggerProps.onPointerDown, (event) => {\n pointerTypeRef.current = event.pointerType;\n const target = event.target;\n if (target.hasPointerCapture(event.pointerId)) {\n target.releasePointerCapture(event.pointerId);\n }\n if (event.button === 0 && event.ctrlKey === false && event.pointerType === \"mouse\") {\n handleOpen(event);\n event.preventDefault();\n }\n }),\n onKeyDown: composeEventHandlers(triggerProps.onKeyDown, (event) => {\n const isTypingAhead = searchRef.current !== \"\";\n const isModifierKey = event.ctrlKey || event.altKey || event.metaKey;\n if (!isModifierKey && event.key.length === 1) handleTypeaheadSearch(event.key);\n if (isTypingAhead && event.key === \" \") return;\n if (OPEN_KEYS.includes(event.key)) {\n handleOpen();\n event.preventDefault();\n }\n })\n }\n ) });\n }\n);\nSelectTrigger.displayName = TRIGGER_NAME;\nvar VALUE_NAME = \"SelectValue\";\nvar SelectValue = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, className, style, children, placeholder = \"\", ...valueProps } = props;\n const context = useSelectContext(VALUE_NAME, __scopeSelect);\n const { onValueNodeHasChildrenChange } = context;\n const hasChildren = children !== void 0;\n const composedRefs = useComposedRefs(forwardedRef, context.onValueNodeChange);\n useLayoutEffect(() => {\n onValueNodeHasChildrenChange(hasChildren);\n }, [onValueNodeHasChildrenChange, hasChildren]);\n return /* @__PURE__ */ jsx(\n Primitive.span,\n {\n ...valueProps,\n ref: composedRefs,\n style: { pointerEvents: \"none\" },\n children: shouldShowPlaceholder(context.value) ? /* @__PURE__ */ jsx(Fragment, { children: placeholder }) : children\n }\n );\n }\n);\nSelectValue.displayName = VALUE_NAME;\nvar ICON_NAME = \"SelectIcon\";\nvar SelectIcon = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, children, ...iconProps } = props;\n return /* @__PURE__ */ jsx(Primitive.span, { \"aria-hidden\": true, ...iconProps, ref: forwardedRef, children: children || \"\\u25BC\" });\n }\n);\nSelectIcon.displayName = ICON_NAME;\nvar PORTAL_NAME = \"SelectPortal\";\nvar SelectPortal = (props) => {\n return /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, ...props });\n};\nSelectPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"SelectContent\";\nvar SelectContent = React.forwardRef(\n (props, forwardedRef) => {\n const context = useSelectContext(CONTENT_NAME, props.__scopeSelect);\n const [fragment, setFragment] = React.useState();\n useLayoutEffect(() => {\n setFragment(new DocumentFragment());\n }, []);\n if (!context.open) {\n const frag = fragment;\n return frag ? ReactDOM.createPortal(\n /* @__PURE__ */ jsx(SelectContentProvider, { scope: props.__scopeSelect, children: /* @__PURE__ */ jsx(Collection.Slot, { scope: props.__scopeSelect, children: /* @__PURE__ */ jsx(\"div\", { children: props.children }) }) }),\n frag\n ) : null;\n }\n return /* @__PURE__ */ jsx(SelectContentImpl, { ...props, ref: forwardedRef });\n }\n);\nSelectContent.displayName = CONTENT_NAME;\nvar CONTENT_MARGIN = 10;\nvar [SelectContentProvider, useSelectContentContext] = createSelectContext(CONTENT_NAME);\nvar CONTENT_IMPL_NAME = \"SelectContentImpl\";\nvar Slot = createSlot(\"SelectContent.RemoveScroll\");\nvar SelectContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeSelect,\n position = \"item-aligned\",\n onCloseAutoFocus,\n onEscapeKeyDown,\n onPointerDownOutside,\n //\n // PopperContent props\n side,\n sideOffset,\n align,\n alignOffset,\n arrowPadding,\n collisionBoundary,\n collisionPadding,\n sticky,\n hideWhenDetached,\n avoidCollisions,\n //\n ...contentProps\n } = props;\n const context = useSelectContext(CONTENT_NAME, __scopeSelect);\n const [content, setContent] = React.useState(null);\n const [viewport, setViewport] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContent(node));\n const [selectedItem, setSelectedItem] = React.useState(null);\n const [selectedItemText, setSelectedItemText] = React.useState(\n null\n );\n const getItems = useCollection(__scopeSelect);\n const [isPositioned, setIsPositioned] = React.useState(false);\n const firstValidItemFoundRef = React.useRef(false);\n React.useEffect(() => {\n if (content) return hideOthers(content);\n }, [content]);\n useFocusGuards();\n const focusFirst = React.useCallback(\n (candidates) => {\n const [firstItem, ...restItems] = getItems().map((item) => item.ref.current);\n const [lastItem] = restItems.slice(-1);\n const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;\n for (const candidate of candidates) {\n if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;\n candidate?.scrollIntoView({ block: \"nearest\" });\n if (candidate === firstItem && viewport) viewport.scrollTop = 0;\n if (candidate === lastItem && viewport) viewport.scrollTop = viewport.scrollHeight;\n candidate?.focus();\n if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;\n }\n },\n [getItems, viewport]\n );\n const focusSelectedItem = React.useCallback(\n () => focusFirst([selectedItem, content]),\n [focusFirst, selectedItem, content]\n );\n React.useEffect(() => {\n if (isPositioned) {\n focusSelectedItem();\n }\n }, [isPositioned, focusSelectedItem]);\n const { onOpenChange, triggerPointerDownPosRef } = context;\n React.useEffect(() => {\n if (content) {\n let pointerMoveDelta = { x: 0, y: 0 };\n const handlePointerMove = (event) => {\n pointerMoveDelta = {\n x: Math.abs(Math.round(event.pageX) - (triggerPointerDownPosRef.current?.x ?? 0)),\n y: Math.abs(Math.round(event.pageY) - (triggerPointerDownPosRef.current?.y ?? 0))\n };\n };\n const handlePointerUp = (event) => {\n if (pointerMoveDelta.x <= 10 && pointerMoveDelta.y <= 10) {\n event.preventDefault();\n } else {\n if (!content.contains(event.target)) {\n onOpenChange(false);\n }\n }\n document.removeEventListener(\"pointermove\", handlePointerMove);\n triggerPointerDownPosRef.current = null;\n };\n if (triggerPointerDownPosRef.current !== null) {\n document.addEventListener(\"pointermove\", handlePointerMove);\n document.addEventListener(\"pointerup\", handlePointerUp, { capture: true, once: true });\n }\n return () => {\n document.removeEventListener(\"pointermove\", handlePointerMove);\n document.removeEventListener(\"pointerup\", handlePointerUp, { capture: true });\n };\n }\n }, [content, onOpenChange, triggerPointerDownPosRef]);\n React.useEffect(() => {\n const close = () => onOpenChange(false);\n window.addEventListener(\"blur\", close);\n window.addEventListener(\"resize\", close);\n return () => {\n window.removeEventListener(\"blur\", close);\n window.removeEventListener(\"resize\", close);\n };\n }, [onOpenChange]);\n const [searchRef, handleTypeaheadSearch] = useTypeaheadSearch((search) => {\n const enabledItems = getItems().filter((item) => !item.disabled);\n const currentItem = enabledItems.find((item) => item.ref.current === document.activeElement);\n const nextItem = findNextItem(enabledItems, search, currentItem);\n if (nextItem) {\n setTimeout(() => nextItem.ref.current.focus());\n }\n });\n const itemRefCallback = React.useCallback(\n (node, value, disabled) => {\n const isFirstValidItem = !firstValidItemFoundRef.current && !disabled;\n const isSelectedItem = context.value !== void 0 && context.value === value;\n if (isSelectedItem || isFirstValidItem) {\n setSelectedItem(node);\n if (isFirstValidItem) firstValidItemFoundRef.current = true;\n }\n },\n [context.value]\n );\n const handleItemLeave = React.useCallback(() => content?.focus(), [content]);\n const itemTextRefCallback = React.useCallback(\n (node, value, disabled) => {\n const isFirstValidItem = !firstValidItemFoundRef.current && !disabled;\n const isSelectedItem = context.value !== void 0 && context.value === value;\n if (isSelectedItem || isFirstValidItem) {\n setSelectedItemText(node);\n }\n },\n [context.value]\n );\n const SelectPosition = position === \"popper\" ? SelectPopperPosition : SelectItemAlignedPosition;\n const popperContentProps = SelectPosition === SelectPopperPosition ? {\n side,\n sideOffset,\n align,\n alignOffset,\n arrowPadding,\n collisionBoundary,\n collisionPadding,\n sticky,\n hideWhenDetached,\n avoidCollisions\n } : {};\n return /* @__PURE__ */ jsx(\n SelectContentProvider,\n {\n scope: __scopeSelect,\n content,\n viewport,\n onViewportChange: setViewport,\n itemRefCallback,\n selectedItem,\n onItemLeave: handleItemLeave,\n itemTextRefCallback,\n focusSelectedItem,\n selectedItemText,\n position,\n isPositioned,\n searchRef,\n children: /* @__PURE__ */ jsx(RemoveScroll, { as: Slot, allowPinchZoom: true, children: /* @__PURE__ */ jsx(\n FocusScope,\n {\n asChild: true,\n trapped: context.open,\n onMountAutoFocus: (event) => {\n event.preventDefault();\n },\n onUnmountAutoFocus: composeEventHandlers(onCloseAutoFocus, (event) => {\n context.trigger?.focus({ preventScroll: true });\n event.preventDefault();\n }),\n children: /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n asChild: true,\n disableOutsidePointerEvents: true,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside: (event) => event.preventDefault(),\n onDismiss: () => context.onOpenChange(false),\n children: /* @__PURE__ */ jsx(\n SelectPosition,\n {\n role: \"listbox\",\n id: context.contentId,\n \"data-state\": context.open ? \"open\" : \"closed\",\n dir: context.dir,\n onContextMenu: (event) => event.preventDefault(),\n ...contentProps,\n ...popperContentProps,\n onPlaced: () => setIsPositioned(true),\n ref: composedRefs,\n style: {\n // flex layout so we can place the scroll buttons properly\n display: \"flex\",\n flexDirection: \"column\",\n // reset the outline by default as the content MAY get focused\n outline: \"none\",\n ...contentProps.style\n },\n onKeyDown: composeEventHandlers(contentProps.onKeyDown, (event) => {\n const isModifierKey = event.ctrlKey || event.altKey || event.metaKey;\n if (event.key === \"Tab\") event.preventDefault();\n if (!isModifierKey && event.key.length === 1) handleTypeaheadSearch(event.key);\n if ([\"ArrowUp\", \"ArrowDown\", \"Home\", \"End\"].includes(event.key)) {\n const items = getItems().filter((item) => !item.disabled);\n let candidateNodes = items.map((item) => item.ref.current);\n if ([\"ArrowUp\", \"End\"].includes(event.key)) {\n candidateNodes = candidateNodes.slice().reverse();\n }\n if ([\"ArrowUp\", \"ArrowDown\"].includes(event.key)) {\n const currentElement = event.target;\n const currentIndex = candidateNodes.indexOf(currentElement);\n candidateNodes = candidateNodes.slice(currentIndex + 1);\n }\n setTimeout(() => focusFirst(candidateNodes));\n event.preventDefault();\n }\n })\n }\n )\n }\n )\n }\n ) })\n }\n );\n }\n);\nSelectContentImpl.displayName = CONTENT_IMPL_NAME;\nvar ITEM_ALIGNED_POSITION_NAME = \"SelectItemAlignedPosition\";\nvar SelectItemAlignedPosition = React.forwardRef((props, forwardedRef) => {\n const { __scopeSelect, onPlaced, ...popperProps } = props;\n const context = useSelectContext(CONTENT_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(CONTENT_NAME, __scopeSelect);\n const [contentWrapper, setContentWrapper] = React.useState(null);\n const [content, setContent] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContent(node));\n const getItems = useCollection(__scopeSelect);\n const shouldExpandOnScrollRef = React.useRef(false);\n const shouldRepositionRef = React.useRef(true);\n const { viewport, selectedItem, selectedItemText, focusSelectedItem } = contentContext;\n const position = React.useCallback(() => {\n if (context.trigger && context.valueNode && contentWrapper && content && viewport && selectedItem && selectedItemText) {\n const triggerRect = context.trigger.getBoundingClientRect();\n const contentRect = content.getBoundingClientRect();\n const valueNodeRect = context.valueNode.getBoundingClientRect();\n const itemTextRect = selectedItemText.getBoundingClientRect();\n if (context.dir !== \"rtl\") {\n const itemTextOffset = itemTextRect.left - contentRect.left;\n const left = valueNodeRect.left - itemTextOffset;\n const leftDelta = triggerRect.left - left;\n const minContentWidth = triggerRect.width + leftDelta;\n const contentWidth = Math.max(minContentWidth, contentRect.width);\n const rightEdge = window.innerWidth - CONTENT_MARGIN;\n const clampedLeft = clamp(left, [\n CONTENT_MARGIN,\n // Prevents the content from going off the starting edge of the\n // viewport. It may still go off the ending edge, but this can be\n // controlled by the user since they may want to manage overflow in a\n // specific way.\n // https://github.com/radix-ui/primitives/issues/2049\n Math.max(CONTENT_MARGIN, rightEdge - contentWidth)\n ]);\n contentWrapper.style.minWidth = minContentWidth + \"px\";\n contentWrapper.style.left = clampedLeft + \"px\";\n } else {\n const itemTextOffset = contentRect.right - itemTextRect.right;\n const right = window.innerWidth - valueNodeRect.right - itemTextOffset;\n const rightDelta = window.innerWidth - triggerRect.right - right;\n const minContentWidth = triggerRect.width + rightDelta;\n const contentWidth = Math.max(minContentWidth, contentRect.width);\n const leftEdge = window.innerWidth - CONTENT_MARGIN;\n const clampedRight = clamp(right, [\n CONTENT_MARGIN,\n Math.max(CONTENT_MARGIN, leftEdge - contentWidth)\n ]);\n contentWrapper.style.minWidth = minContentWidth + \"px\";\n contentWrapper.style.right = clampedRight + \"px\";\n }\n const items = getItems();\n const availableHeight = window.innerHeight - CONTENT_MARGIN * 2;\n const itemsHeight = viewport.scrollHeight;\n const contentStyles = window.getComputedStyle(content);\n const contentBorderTopWidth = parseInt(contentStyles.borderTopWidth, 10);\n const contentPaddingTop = parseInt(contentStyles.paddingTop, 10);\n const contentBorderBottomWidth = parseInt(contentStyles.borderBottomWidth, 10);\n const contentPaddingBottom = parseInt(contentStyles.paddingBottom, 10);\n const fullContentHeight = contentBorderTopWidth + contentPaddingTop + itemsHeight + contentPaddingBottom + contentBorderBottomWidth;\n const minContentHeight = Math.min(selectedItem.offsetHeight * 5, fullContentHeight);\n const viewportStyles = window.getComputedStyle(viewport);\n const viewportPaddingTop = parseInt(viewportStyles.paddingTop, 10);\n const viewportPaddingBottom = parseInt(viewportStyles.paddingBottom, 10);\n const topEdgeToTriggerMiddle = triggerRect.top + triggerRect.height / 2 - CONTENT_MARGIN;\n const triggerMiddleToBottomEdge = availableHeight - topEdgeToTriggerMiddle;\n const selectedItemHalfHeight = selectedItem.offsetHeight / 2;\n const itemOffsetMiddle = selectedItem.offsetTop + selectedItemHalfHeight;\n const contentTopToItemMiddle = contentBorderTopWidth + contentPaddingTop + itemOffsetMiddle;\n const itemMiddleToContentBottom = fullContentHeight - contentTopToItemMiddle;\n const willAlignWithoutTopOverflow = contentTopToItemMiddle <= topEdgeToTriggerMiddle;\n if (willAlignWithoutTopOverflow) {\n const isLastItem = items.length > 0 && selectedItem === items[items.length - 1].ref.current;\n contentWrapper.style.bottom = \"0px\";\n const viewportOffsetBottom = content.clientHeight - viewport.offsetTop - viewport.offsetHeight;\n const clampedTriggerMiddleToBottomEdge = Math.max(\n triggerMiddleToBottomEdge,\n selectedItemHalfHeight + // viewport might have padding bottom, include it to avoid a scrollable viewport\n (isLastItem ? viewportPaddingBottom : 0) + viewportOffsetBottom + contentBorderBottomWidth\n );\n const height = contentTopToItemMiddle + clampedTriggerMiddleToBottomEdge;\n contentWrapper.style.height = height + \"px\";\n } else {\n const isFirstItem = items.length > 0 && selectedItem === items[0].ref.current;\n contentWrapper.style.top = \"0px\";\n const clampedTopEdgeToTriggerMiddle = Math.max(\n topEdgeToTriggerMiddle,\n contentBorderTopWidth + viewport.offsetTop + // viewport might have padding top, include it to avoid a scrollable viewport\n (isFirstItem ? viewportPaddingTop : 0) + selectedItemHalfHeight\n );\n const height = clampedTopEdgeToTriggerMiddle + itemMiddleToContentBottom;\n contentWrapper.style.height = height + \"px\";\n viewport.scrollTop = contentTopToItemMiddle - topEdgeToTriggerMiddle + viewport.offsetTop;\n }\n contentWrapper.style.margin = `${CONTENT_MARGIN}px 0`;\n contentWrapper.style.minHeight = minContentHeight + \"px\";\n contentWrapper.style.maxHeight = availableHeight + \"px\";\n onPlaced?.();\n requestAnimationFrame(() => shouldExpandOnScrollRef.current = true);\n }\n }, [\n getItems,\n context.trigger,\n context.valueNode,\n contentWrapper,\n content,\n viewport,\n selectedItem,\n selectedItemText,\n context.dir,\n onPlaced\n ]);\n useLayoutEffect(() => position(), [position]);\n const [contentZIndex, setContentZIndex] = React.useState();\n useLayoutEffect(() => {\n if (content) setContentZIndex(window.getComputedStyle(content).zIndex);\n }, [content]);\n const handleScrollButtonChange = React.useCallback(\n (node) => {\n if (node && shouldRepositionRef.current === true) {\n position();\n focusSelectedItem?.();\n shouldRepositionRef.current = false;\n }\n },\n [position, focusSelectedItem]\n );\n return /* @__PURE__ */ jsx(\n SelectViewportProvider,\n {\n scope: __scopeSelect,\n contentWrapper,\n shouldExpandOnScrollRef,\n onScrollButtonChange: handleScrollButtonChange,\n children: /* @__PURE__ */ jsx(\n \"div\",\n {\n ref: setContentWrapper,\n style: {\n display: \"flex\",\n flexDirection: \"column\",\n position: \"fixed\",\n zIndex: contentZIndex\n },\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n ...popperProps,\n ref: composedRefs,\n style: {\n // When we get the height of the content, it includes borders. If we were to set\n // the height without having `boxSizing: 'border-box'` it would be too big.\n boxSizing: \"border-box\",\n // We need to ensure the content doesn't get taller than the wrapper\n maxHeight: \"100%\",\n ...popperProps.style\n }\n }\n )\n }\n )\n }\n );\n});\nSelectItemAlignedPosition.displayName = ITEM_ALIGNED_POSITION_NAME;\nvar POPPER_POSITION_NAME = \"SelectPopperPosition\";\nvar SelectPopperPosition = React.forwardRef((props, forwardedRef) => {\n const {\n __scopeSelect,\n align = \"start\",\n collisionPadding = CONTENT_MARGIN,\n ...popperProps\n } = props;\n const popperScope = usePopperScope(__scopeSelect);\n return /* @__PURE__ */ jsx(\n PopperPrimitive.Content,\n {\n ...popperScope,\n ...popperProps,\n ref: forwardedRef,\n align,\n collisionPadding,\n style: {\n // Ensure border-box for floating-ui calculations\n boxSizing: \"border-box\",\n ...popperProps.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-select-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-select-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-select-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-select-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-select-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n }\n }\n );\n});\nSelectPopperPosition.displayName = POPPER_POSITION_NAME;\nvar [SelectViewportProvider, useSelectViewportContext] = createSelectContext(CONTENT_NAME, {});\nvar VIEWPORT_NAME = \"SelectViewport\";\nvar SelectViewport = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, nonce, ...viewportProps } = props;\n const contentContext = useSelectContentContext(VIEWPORT_NAME, __scopeSelect);\n const viewportContext = useSelectViewportContext(VIEWPORT_NAME, __scopeSelect);\n const composedRefs = useComposedRefs(forwardedRef, contentContext.onViewportChange);\n const prevScrollTopRef = React.useRef(0);\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(\n \"style\",\n {\n dangerouslySetInnerHTML: {\n __html: `[data-radix-select-viewport]{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;}[data-radix-select-viewport]::-webkit-scrollbar{display:none}`\n },\n nonce\n }\n ),\n /* @__PURE__ */ jsx(Collection.Slot, { scope: __scopeSelect, children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-radix-select-viewport\": \"\",\n role: \"presentation\",\n ...viewportProps,\n ref: composedRefs,\n style: {\n // we use position: 'relative' here on the `viewport` so that when we call\n // `selectedItem.offsetTop` in calculations, the offset is relative to the viewport\n // (independent of the scrollUpButton).\n position: \"relative\",\n flex: 1,\n // Viewport should only be scrollable in the vertical direction.\n // This won't work in vertical writing modes, so we'll need to\n // revisit this if/when that is supported\n // https://developer.chrome.com/blog/vertical-form-controls\n overflow: \"hidden auto\",\n ...viewportProps.style\n },\n onScroll: composeEventHandlers(viewportProps.onScroll, (event) => {\n const viewport = event.currentTarget;\n const { contentWrapper, shouldExpandOnScrollRef } = viewportContext;\n if (shouldExpandOnScrollRef?.current && contentWrapper) {\n const scrolledBy = Math.abs(prevScrollTopRef.current - viewport.scrollTop);\n if (scrolledBy > 0) {\n const availableHeight = window.innerHeight - CONTENT_MARGIN * 2;\n const cssMinHeight = parseFloat(contentWrapper.style.minHeight);\n const cssHeight = parseFloat(contentWrapper.style.height);\n const prevHeight = Math.max(cssMinHeight, cssHeight);\n if (prevHeight < availableHeight) {\n const nextHeight = prevHeight + scrolledBy;\n const clampedNextHeight = Math.min(availableHeight, nextHeight);\n const heightDiff = nextHeight - clampedNextHeight;\n contentWrapper.style.height = clampedNextHeight + \"px\";\n if (contentWrapper.style.bottom === \"0px\") {\n viewport.scrollTop = heightDiff > 0 ? heightDiff : 0;\n contentWrapper.style.justifyContent = \"flex-end\";\n }\n }\n }\n }\n prevScrollTopRef.current = viewport.scrollTop;\n })\n }\n ) })\n ] });\n }\n);\nSelectViewport.displayName = VIEWPORT_NAME;\nvar GROUP_NAME = \"SelectGroup\";\nvar [SelectGroupContextProvider, useSelectGroupContext] = createSelectContext(GROUP_NAME);\nvar SelectGroup = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...groupProps } = props;\n const groupId = useId();\n return /* @__PURE__ */ jsx(SelectGroupContextProvider, { scope: __scopeSelect, id: groupId, children: /* @__PURE__ */ jsx(Primitive.div, { role: \"group\", \"aria-labelledby\": groupId, ...groupProps, ref: forwardedRef }) });\n }\n);\nSelectGroup.displayName = GROUP_NAME;\nvar LABEL_NAME = \"SelectLabel\";\nvar SelectLabel = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...labelProps } = props;\n const groupContext = useSelectGroupContext(LABEL_NAME, __scopeSelect);\n return /* @__PURE__ */ jsx(Primitive.div, { id: groupContext.id, ...labelProps, ref: forwardedRef });\n }\n);\nSelectLabel.displayName = LABEL_NAME;\nvar ITEM_NAME = \"SelectItem\";\nvar [SelectItemContextProvider, useSelectItemContext] = createSelectContext(ITEM_NAME);\nvar SelectItem = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeSelect,\n value,\n disabled = false,\n textValue: textValueProp,\n ...itemProps\n } = props;\n const context = useSelectContext(ITEM_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ITEM_NAME, __scopeSelect);\n const isSelected = context.value === value;\n const [textValue, setTextValue] = React.useState(textValueProp ?? \"\");\n const [isFocused, setIsFocused] = React.useState(false);\n const composedRefs = useComposedRefs(\n forwardedRef,\n (node) => contentContext.itemRefCallback?.(node, value, disabled)\n );\n const textId = useId();\n const pointerTypeRef = React.useRef(\"touch\");\n const handleSelect = () => {\n if (!disabled) {\n context.onValueChange(value);\n context.onOpenChange(false);\n }\n };\n if (value === \"\") {\n throw new Error(\n \"A <Select.Item /> must have a value prop that is not an empty string. This is because the Select value can be set to an empty string to clear the selection and show the placeholder.\"\n );\n }\n return /* @__PURE__ */ jsx(\n SelectItemContextProvider,\n {\n scope: __scopeSelect,\n value,\n disabled,\n textId,\n isSelected,\n onItemTextChange: React.useCallback((node) => {\n setTextValue((prevTextValue) => prevTextValue || (node?.textContent ?? \"\").trim());\n }, []),\n children: /* @__PURE__ */ jsx(\n Collection.ItemSlot,\n {\n scope: __scopeSelect,\n value,\n disabled,\n textValue,\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n role: \"option\",\n \"aria-labelledby\": textId,\n \"data-highlighted\": isFocused ? \"\" : void 0,\n \"aria-selected\": isSelected && isFocused,\n \"data-state\": isSelected ? \"checked\" : \"unchecked\",\n \"aria-disabled\": disabled || void 0,\n \"data-disabled\": disabled ? \"\" : void 0,\n tabIndex: disabled ? void 0 : -1,\n ...itemProps,\n ref: composedRefs,\n onFocus: composeEventHandlers(itemProps.onFocus, () => setIsFocused(true)),\n onBlur: composeEventHandlers(itemProps.onBlur, () => setIsFocused(false)),\n onClick: composeEventHandlers(itemProps.onClick, () => {\n if (pointerTypeRef.current !== \"mouse\") handleSelect();\n }),\n onPointerUp: composeEventHandlers(itemProps.onPointerUp, () => {\n if (pointerTypeRef.current === \"mouse\") handleSelect();\n }),\n onPointerDown: composeEventHandlers(itemProps.onPointerDown, (event) => {\n pointerTypeRef.current = event.pointerType;\n }),\n onPointerMove: composeEventHandlers(itemProps.onPointerMove, (event) => {\n pointerTypeRef.current = event.pointerType;\n if (disabled) {\n contentContext.onItemLeave?.();\n } else if (pointerTypeRef.current === \"mouse\") {\n event.currentTarget.focus({ preventScroll: true });\n }\n }),\n onPointerLeave: composeEventHandlers(itemProps.onPointerLeave, (event) => {\n if (event.currentTarget === document.activeElement) {\n contentContext.onItemLeave?.();\n }\n }),\n onKeyDown: composeEventHandlers(itemProps.onKeyDown, (event) => {\n const isTypingAhead = contentContext.searchRef?.current !== \"\";\n if (isTypingAhead && event.key === \" \") return;\n if (SELECTION_KEYS.includes(event.key)) handleSelect();\n if (event.key === \" \") event.preventDefault();\n })\n }\n )\n }\n )\n }\n );\n }\n);\nSelectItem.displayName = ITEM_NAME;\nvar ITEM_TEXT_NAME = \"SelectItemText\";\nvar SelectItemText = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, className, style, ...itemTextProps } = props;\n const context = useSelectContext(ITEM_TEXT_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ITEM_TEXT_NAME, __scopeSelect);\n const itemContext = useSelectItemContext(ITEM_TEXT_NAME, __scopeSelect);\n const nativeOptionsContext = useSelectNativeOptionsContext(ITEM_TEXT_NAME, __scopeSelect);\n const [itemTextNode, setItemTextNode] = React.useState(null);\n const composedRefs = useComposedRefs(\n forwardedRef,\n (node) => setItemTextNode(node),\n itemContext.onItemTextChange,\n (node) => contentContext.itemTextRefCallback?.(node, itemContext.value, itemContext.disabled)\n );\n const textContent = itemTextNode?.textContent;\n const nativeOption = React.useMemo(\n () => /* @__PURE__ */ jsx(\"option\", { value: itemContext.value, disabled: itemContext.disabled, children: textContent }, itemContext.value),\n [itemContext.disabled, itemContext.value, textContent]\n );\n const { onNativeOptionAdd, onNativeOptionRemove } = nativeOptionsContext;\n useLayoutEffect(() => {\n onNativeOptionAdd(nativeOption);\n return () => onNativeOptionRemove(nativeOption);\n }, [onNativeOptionAdd, onNativeOptionRemove, nativeOption]);\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(Primitive.span, { id: itemContext.textId, ...itemTextProps, ref: composedRefs }),\n itemContext.isSelected && context.valueNode && !context.valueNodeHasChildren ? ReactDOM.createPortal(itemTextProps.children, context.valueNode) : null\n ] });\n }\n);\nSelectItemText.displayName = ITEM_TEXT_NAME;\nvar ITEM_INDICATOR_NAME = \"SelectItemIndicator\";\nvar SelectItemIndicator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...itemIndicatorProps } = props;\n const itemContext = useSelectItemContext(ITEM_INDICATOR_NAME, __scopeSelect);\n return itemContext.isSelected ? /* @__PURE__ */ jsx(Primitive.span, { \"aria-hidden\": true, ...itemIndicatorProps, ref: forwardedRef }) : null;\n }\n);\nSelectItemIndicator.displayName = ITEM_INDICATOR_NAME;\nvar SCROLL_UP_BUTTON_NAME = \"SelectScrollUpButton\";\nvar SelectScrollUpButton = React.forwardRef((props, forwardedRef) => {\n const contentContext = useSelectContentContext(SCROLL_UP_BUTTON_NAME, props.__scopeSelect);\n const viewportContext = useSelectViewportContext(SCROLL_UP_BUTTON_NAME, props.__scopeSelect);\n const [canScrollUp, setCanScrollUp] = React.useState(false);\n const composedRefs = useComposedRefs(forwardedRef, viewportContext.onScrollButtonChange);\n useLayoutEffect(() => {\n if (contentContext.viewport && contentContext.isPositioned) {\n let handleScroll2 = function() {\n const canScrollUp2 = viewport.scrollTop > 0;\n setCanScrollUp(canScrollUp2);\n };\n var handleScroll = handleScroll2;\n const viewport = contentContext.viewport;\n handleScroll2();\n viewport.addEventListener(\"scroll\", handleScroll2);\n return () => viewport.removeEventListener(\"scroll\", handleScroll2);\n }\n }, [contentContext.viewport, contentContext.isPositioned]);\n return canScrollUp ? /* @__PURE__ */ jsx(\n SelectScrollButtonImpl,\n {\n ...props,\n ref: composedRefs,\n onAutoScroll: () => {\n const { viewport, selectedItem } = contentContext;\n if (viewport && selectedItem) {\n viewport.scrollTop = viewport.scrollTop - selectedItem.offsetHeight;\n }\n }\n }\n ) : null;\n});\nSelectScrollUpButton.displayName = SCROLL_UP_BUTTON_NAME;\nvar SCROLL_DOWN_BUTTON_NAME = \"SelectScrollDownButton\";\nvar SelectScrollDownButton = React.forwardRef((props, forwardedRef) => {\n const contentContext = useSelectContentContext(SCROLL_DOWN_BUTTON_NAME, props.__scopeSelect);\n const viewportContext = useSelectViewportContext(SCROLL_DOWN_BUTTON_NAME, props.__scopeSelect);\n const [canScrollDown, setCanScrollDown] = React.useState(false);\n const composedRefs = useComposedRefs(forwardedRef, viewportContext.onScrollButtonChange);\n useLayoutEffect(() => {\n if (contentContext.viewport && contentContext.isPositioned) {\n let handleScroll2 = function() {\n const maxScroll = viewport.scrollHeight - viewport.clientHeight;\n const canScrollDown2 = Math.ceil(viewport.scrollTop) < maxScroll;\n setCanScrollDown(canScrollDown2);\n };\n var handleScroll = handleScroll2;\n const viewport = contentContext.viewport;\n handleScroll2();\n viewport.addEventListener(\"scroll\", handleScroll2);\n return () => viewport.removeEventListener(\"scroll\", handleScroll2);\n }\n }, [contentContext.viewport, contentContext.isPositioned]);\n return canScrollDown ? /* @__PURE__ */ jsx(\n SelectScrollButtonImpl,\n {\n ...props,\n ref: composedRefs,\n onAutoScroll: () => {\n const { viewport, selectedItem } = contentContext;\n if (viewport && selectedItem) {\n viewport.scrollTop = viewport.scrollTop + selectedItem.offsetHeight;\n }\n }\n }\n ) : null;\n});\nSelectScrollDownButton.displayName = SCROLL_DOWN_BUTTON_NAME;\nvar SelectScrollButtonImpl = React.forwardRef((props, forwardedRef) => {\n const { __scopeSelect, onAutoScroll, ...scrollIndicatorProps } = props;\n const contentContext = useSelectContentContext(\"SelectScrollButton\", __scopeSelect);\n const autoScrollTimerRef = React.useRef(null);\n const getItems = useCollection(__scopeSelect);\n const clearAutoScrollTimer = React.useCallback(() => {\n if (autoScrollTimerRef.current !== null) {\n window.clearInterval(autoScrollTimerRef.current);\n autoScrollTimerRef.current = null;\n }\n }, []);\n React.useEffect(() => {\n return () => clearAutoScrollTimer();\n }, [clearAutoScrollTimer]);\n useLayoutEffect(() => {\n const activeItem = getItems().find((item) => item.ref.current === document.activeElement);\n activeItem?.ref.current?.scrollIntoView({ block: \"nearest\" });\n }, [getItems]);\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"aria-hidden\": true,\n ...scrollIndicatorProps,\n ref: forwardedRef,\n style: { flexShrink: 0, ...scrollIndicatorProps.style },\n onPointerDown: composeEventHandlers(scrollIndicatorProps.onPointerDown, () => {\n if (autoScrollTimerRef.current === null) {\n autoScrollTimerRef.current = window.setInterval(onAutoScroll, 50);\n }\n }),\n onPointerMove: composeEventHandlers(scrollIndicatorProps.onPointerMove, () => {\n contentContext.onItemLeave?.();\n if (autoScrollTimerRef.current === null) {\n autoScrollTimerRef.current = window.setInterval(onAutoScroll, 50);\n }\n }),\n onPointerLeave: composeEventHandlers(scrollIndicatorProps.onPointerLeave, () => {\n clearAutoScrollTimer();\n })\n }\n );\n});\nvar SEPARATOR_NAME = \"SelectSeparator\";\nvar SelectSeparator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...separatorProps } = props;\n return /* @__PURE__ */ jsx(Primitive.div, { \"aria-hidden\": true, ...separatorProps, ref: forwardedRef });\n }\n);\nSelectSeparator.displayName = SEPARATOR_NAME;\nvar ARROW_NAME = \"SelectArrow\";\nvar SelectArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const context = useSelectContext(ARROW_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ARROW_NAME, __scopeSelect);\n return context.open && contentContext.position === \"popper\" ? /* @__PURE__ */ jsx(PopperPrimitive.Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef }) : null;\n }\n);\nSelectArrow.displayName = ARROW_NAME;\nvar BUBBLE_INPUT_NAME = \"SelectBubbleInput\";\nvar SelectBubbleInput = React.forwardRef(\n ({ __scopeSelect, value, ...props }, forwardedRef) => {\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const prevValue = usePrevious(value);\n React.useEffect(() => {\n const select = ref.current;\n if (!select) return;\n const selectProto = window.HTMLSelectElement.prototype;\n const descriptor = Object.getOwnPropertyDescriptor(\n selectProto,\n \"value\"\n );\n const setValue = descriptor.set;\n if (prevValue !== value && setValue) {\n const event = new Event(\"change\", { bubbles: true });\n setValue.call(select, value);\n select.dispatchEvent(event);\n }\n }, [prevValue, value]);\n return /* @__PURE__ */ jsx(\n Primitive.select,\n {\n ...props,\n style: { ...VISUALLY_HIDDEN_STYLES, ...props.style },\n ref: composedRefs,\n defaultValue: value\n }\n );\n }\n);\nSelectBubbleInput.displayName = BUBBLE_INPUT_NAME;\nfunction shouldShowPlaceholder(value) {\n return value === \"\" || value === void 0;\n}\nfunction useTypeaheadSearch(onSearchChange) {\n const handleSearchChange = useCallbackRef(onSearchChange);\n const searchRef = React.useRef(\"\");\n const timerRef = React.useRef(0);\n const handleTypeaheadSearch = React.useCallback(\n (key) => {\n const search = searchRef.current + key;\n handleSearchChange(search);\n (function updateSearch(value) {\n searchRef.current = value;\n window.clearTimeout(timerRef.current);\n if (value !== \"\") timerRef.current = window.setTimeout(() => updateSearch(\"\"), 1e3);\n })(search);\n },\n [handleSearchChange]\n );\n const resetTypeahead = React.useCallback(() => {\n searchRef.current = \"\";\n window.clearTimeout(timerRef.current);\n }, []);\n React.useEffect(() => {\n return () => window.clearTimeout(timerRef.current);\n }, []);\n return [searchRef, handleTypeaheadSearch, resetTypeahead];\n}\nfunction findNextItem(items, search, currentItem) {\n const isRepeated = search.length > 1 && Array.from(search).every((char) => char === search[0]);\n const normalizedSearch = isRepeated ? search[0] : search;\n const currentItemIndex = currentItem ? items.indexOf(currentItem) : -1;\n let wrappedItems = wrapArray(items, Math.max(currentItemIndex, 0));\n const excludeCurrentItem = normalizedSearch.length === 1;\n if (excludeCurrentItem) wrappedItems = wrappedItems.filter((v) => v !== currentItem);\n const nextItem = wrappedItems.find(\n (item) => item.textValue.toLowerCase().startsWith(normalizedSearch.toLowerCase())\n );\n return nextItem !== currentItem ? nextItem : void 0;\n}\nfunction wrapArray(array, startIndex) {\n return array.map((_, index) => array[(startIndex + index) % array.length]);\n}\nvar Root2 = Select;\nvar Trigger = SelectTrigger;\nvar Value = SelectValue;\nvar Icon = SelectIcon;\nvar Portal = SelectPortal;\nvar Content2 = SelectContent;\nvar Viewport = SelectViewport;\nvar Group = SelectGroup;\nvar Label = SelectLabel;\nvar Item = SelectItem;\nvar ItemText = SelectItemText;\nvar ItemIndicator = SelectItemIndicator;\nvar ScrollUpButton = SelectScrollUpButton;\nvar ScrollDownButton = SelectScrollDownButton;\nvar Separator = SelectSeparator;\nvar Arrow2 = SelectArrow;\nexport {\n Arrow2 as Arrow,\n Content2 as Content,\n Group,\n Icon,\n Item,\n ItemIndicator,\n ItemText,\n Label,\n Portal,\n Root2 as Root,\n ScrollDownButton,\n ScrollUpButton,\n Select,\n SelectArrow,\n SelectContent,\n SelectGroup,\n SelectIcon,\n SelectItem,\n SelectItemIndicator,\n SelectItemText,\n SelectLabel,\n SelectPortal,\n SelectScrollDownButton,\n SelectScrollUpButton,\n SelectSeparator,\n SelectTrigger,\n SelectValue,\n SelectViewport,\n Separator,\n Trigger,\n Value,\n Viewport,\n createSelectScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from \"react\"\nimport { Select as SelectPrimitive } from \"radix-ui\"\n\nimport { cn } from \"@/lib/utils\"\nimport { ChevronDownIcon, CheckIcon, ChevronUpIcon } from \"lucide-react\"\n\nfunction Select({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Root>) {\n return <SelectPrimitive.Root data-slot=\"select\" {...props} />\n}\n\nfunction SelectGroup({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Group>) {\n return (\n <SelectPrimitive.Group\n data-slot=\"select-group\"\n className={cn(\"scroll-my-1 p-1\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectValue({\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Value>) {\n return <SelectPrimitive.Value data-slot=\"select-value\" {...props} />\n}\n\nfunction SelectTrigger({\n className,\n size = \"default\",\n children,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Trigger> & {\n size?: \"sm\" | \"default\"\n}) {\n return (\n <SelectPrimitive.Trigger\n data-slot=\"select-trigger\"\n data-size={size}\n className={cn(\n \"flex w-fit items-center justify-between gap-1.5 rounded-lg border border-input bg-transparent py-2 pr-2 pl-2.5 text-sm whitespace-nowrap transition-colors outline-none select-none focus-visible:border-ring focus-visible:ring-3 focus-visible:ring-ring/50 disabled:cursor-not-allowed disabled:opacity-50 aria-invalid:border-destructive aria-invalid:ring-3 aria-invalid:ring-destructive/20 data-placeholder:text-muted-foreground data-[size=default]:h-8 data-[size=sm]:h-7 data-[size=sm]:rounded-[min(var(--radius-md),10px)] *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-1.5 dark:bg-input/30 dark:hover:bg-input/50 dark:aria-invalid:border-destructive/50 dark:aria-invalid:ring-destructive/40 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n >\n {children}\n <SelectPrimitive.Icon asChild>\n <ChevronDownIcon className=\"pointer-events-none size-4 text-muted-foreground\" />\n </SelectPrimitive.Icon>\n </SelectPrimitive.Trigger>\n )\n}\n\nfunction SelectContent({\n className,\n children,\n position = \"item-aligned\",\n align = \"center\",\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Content>) {\n return (\n <SelectPrimitive.Portal>\n <SelectPrimitive.Content\n data-slot=\"select-content\"\n data-align-trigger={position === \"item-aligned\"}\n className={cn(\"relative z-50 max-h-(--radix-select-content-available-height) min-w-36 origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-lg bg-popover text-popover-foreground shadow-md ring-1 ring-foreground/10 duration-100 data-[align-trigger=true]:animate-none data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 data-open:animate-in data-open:fade-in-0 data-open:zoom-in-95 data-closed:animate-out data-closed:fade-out-0 data-closed:zoom-out-95\", position ===\"popper\"&&\"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1\", className )}\n position={position}\n align={align}\n {...props}\n >\n <SelectScrollUpButton />\n <SelectPrimitive.Viewport\n data-position={position}\n className={cn(\n \"data-[position=popper]:h-(--radix-select-trigger-height) data-[position=popper]:w-full data-[position=popper]:min-w-(--radix-select-trigger-width)\",\n position === \"popper\" && \"\"\n )}\n >\n {children}\n </SelectPrimitive.Viewport>\n <SelectScrollDownButton />\n </SelectPrimitive.Content>\n </SelectPrimitive.Portal>\n )\n}\n\nfunction SelectLabel({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Label>) {\n return (\n <SelectPrimitive.Label\n data-slot=\"select-label\"\n className={cn(\"px-1.5 py-1 text-xs text-muted-foreground\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectItem({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Item>) {\n return (\n <SelectPrimitive.Item\n data-slot=\"select-item\"\n className={cn(\n \"relative flex w-full cursor-default items-center gap-1.5 rounded-md py-1 pr-8 pl-1.5 text-sm outline-hidden select-none focus:bg-accent focus:text-accent-foreground not-data-[variant=destructive]:focus:**:text-accent-foreground data-disabled:pointer-events-none data-disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2\",\n className\n )}\n {...props}\n >\n <span className=\"pointer-events-none absolute right-2 flex size-4 items-center justify-center\">\n <SelectPrimitive.ItemIndicator>\n <CheckIcon className=\"pointer-events-none\" />\n </SelectPrimitive.ItemIndicator>\n </span>\n <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n </SelectPrimitive.Item>\n )\n}\n\nfunction SelectSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.Separator>) {\n return (\n <SelectPrimitive.Separator\n data-slot=\"select-separator\"\n className={cn(\"pointer-events-none -mx-1 my-1 h-px bg-border\", className)}\n {...props}\n />\n )\n}\n\nfunction SelectScrollUpButton({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollUpButton>) {\n return (\n <SelectPrimitive.ScrollUpButton\n data-slot=\"select-scroll-up-button\"\n className={cn(\n \"z-10 flex cursor-default items-center justify-center bg-popover py-1 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n >\n <ChevronUpIcon\n />\n </SelectPrimitive.ScrollUpButton>\n )\n}\n\nfunction SelectScrollDownButton({\n className,\n ...props\n}: React.ComponentProps<typeof SelectPrimitive.ScrollDownButton>) {\n return (\n <SelectPrimitive.ScrollDownButton\n data-slot=\"select-scroll-down-button\"\n className={cn(\n \"z-10 flex cursor-default items-center justify-center bg-popover py-1 [&_svg:not([class*='size-'])]:size-4\",\n className\n )}\n {...props}\n >\n <ChevronDownIcon\n />\n </SelectPrimitive.ScrollDownButton>\n )\n}\n\nexport {\n Select,\n SelectContent,\n SelectGroup,\n SelectItem,\n SelectLabel,\n SelectScrollDownButton,\n SelectScrollUpButton,\n SelectSeparator,\n SelectTrigger,\n SelectValue,\n}\n","import { useEffect, useState } from 'react'\nimport { api } from '@/lib/api'\nimport { useRelayStore } from '@/store'\nimport { Button } from '@/components/ui/button'\nimport { Input } from '@/components/ui/input'\nimport { Textarea } from '@/components/ui/textarea'\nimport { Switch } from '@/components/ui/switch'\nimport { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@/components/ui/select'\nimport { KOKORO_VOICES, availableSpeechVoices } from '@/lib/voice'\nimport { Brain, FolderSymlink, GitMerge, Save, Terminal, TestTube2, Volume2 } from 'lucide-react'\n\ntype ProviderName = 'claude' | 'codex'\n\ninterface ProviderConfig {\n command: string\n defaultArgs: string[]\n env: Record<string, string>\n pluginDirs: string[]\n defaultCapabilities: string[]\n defaultApprovalMode: string\n defaultTags: string[]\n chatCaptureMode: 'final' | 'full'\n headless: {\n tmuxPrefix: string\n shutdownTimeoutMs: number\n }\n}\n\nconst providers: ProviderName[] = ['claude', 'codex']\n\nexport function SettingsView() {\n const [configs, setConfigs] = useState<Record<string, ProviderConfig>>({})\n const [selected, setSelected] = useState<ProviderName>('claude')\n const [status, setStatus] = useState('')\n\n useEffect(() => {\n api<Record<string, ProviderConfig>>('GET', '/providers/config')\n .then(setConfigs)\n .catch((e) => setStatus((e as Error).message))\n }, [])\n\n const config = configs[selected]\n const update = (patch: Partial<ProviderConfig>) => {\n if (!config) return\n setConfigs({ ...configs, [selected]: { ...config, ...patch } })\n }\n\n async function save() {\n if (!config) return\n const saved = await api<ProviderConfig>('PUT', `/providers/${selected}/config`, config)\n setConfigs({ ...configs, [selected]: saved })\n setStatus(`${selected} saved`)\n }\n\n async function test() {\n const result = await api<{ ok: boolean; path?: string; error?: string }>('POST', `/providers/${selected}/config/test`)\n setStatus(result.ok ? `${selected} command: ${result.path || 'found'}` : result.error || 'command not found')\n }\n\n return (\n <div className=\"space-y-4\">\n <div className=\"flex items-center justify-between gap-3\">\n <div>\n <h1 className=\"text-xl font-semibold\">Settings</h1>\n <p className=\"text-sm text-muted-foreground\">Provider runner configuration</p>\n </div>\n <div className=\"flex gap-2\">\n {providers.map((provider) => (\n <Button key={provider} variant={selected === provider ? 'default' : 'outline'} onClick={() => setSelected(provider)}>\n <Terminal className=\"w-4 h-4\" />{provider}\n </Button>\n ))}\n </div>\n </div>\n\n {config && (\n <div className=\"grid gap-4 lg:grid-cols-[minmax(0,1fr)_minmax(280px,360px)]\">\n <section className=\"space-y-3\">\n <Field label=\"Command\">\n <Input value={config.command} onChange={(e) => update({ command: e.target.value })} />\n </Field>\n <Field label=\"Default arguments\">\n <Textarea rows={3} value={config.defaultArgs.join('\\n')} onChange={(e) => update({ defaultArgs: lines(e.target.value) })} />\n </Field>\n <Field label=\"Plugin directories\">\n <Textarea rows={3} value={config.pluginDirs.join('\\n')} onChange={(e) => update({ pluginDirs: lines(e.target.value) })} />\n </Field>\n <Field label=\"Environment\">\n <Textarea rows={5} value={recordLines(config.env)} onChange={(e) => update({ env: parseRecordLines(e.target.value) })} />\n </Field>\n </section>\n\n <section className=\"space-y-3\">\n <Field label=\"Capabilities\">\n <Textarea rows={3} value={config.defaultCapabilities.join('\\n')} onChange={(e) => update({ defaultCapabilities: lines(e.target.value) })} />\n </Field>\n <Field label=\"Tags\">\n <Textarea rows={3} value={config.defaultTags.join('\\n')} onChange={(e) => update({ defaultTags: lines(e.target.value) })} />\n </Field>\n <Field label=\"Approval mode\">\n <Input value={config.defaultApprovalMode} onChange={(e) => update({ defaultApprovalMode: e.target.value })} />\n </Field>\n <Field label=\"Chat capture mode\">\n <Select value={config.chatCaptureMode ?? 'final'} onValueChange={(v) => update({ chatCaptureMode: v as 'final' | 'full' })}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"final\">Final response only</SelectItem>\n <SelectItem value=\"full\">Full turn (intermediate messages)</SelectItem>\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"tmux prefix\">\n <Input value={config.headless.tmuxPrefix} onChange={(e) => update({ headless: { ...config.headless, tmuxPrefix: e.target.value } })} />\n </Field>\n <Field label=\"Shutdown timeout\">\n <Input type=\"number\" value={config.headless.shutdownTimeoutMs} onChange={(e) => update({ headless: { ...config.headless, shutdownTimeoutMs: Number(e.target.value) || 10000 } })} />\n </Field>\n <div className=\"flex gap-2 pt-2\">\n <Button onClick={save}><Save className=\"w-4 h-4\" />Save</Button>\n <Button variant=\"outline\" onClick={test}><TestTube2 className=\"w-4 h-4\" />Test</Button>\n </div>\n {status && <p className=\"text-sm text-muted-foreground\">{status}</p>}\n </section>\n </div>\n )}\n\n <ChatDisplaySettings />\n\n <WorkspaceSettings />\n\n <StewardSettings />\n\n <VoiceSettings />\n </div>\n )\n}\n\ninterface WorkspaceConfig {\n symlinkPaths: string[]\n}\n\nconst DEFAULT_WORKSPACE: WorkspaceConfig = { symlinkPaths: [] }\n\n// Global isolated-worktree provisioning (#159 follow-up). A fresh git worktree only has\n// git-tracked files; node_modules are symlinked automatically and these extra untracked\n// paths are too. Only links what actually exists in main — missing entries are ignored.\nfunction WorkspaceSettings() {\n const [config, setConfig] = useState<WorkspaceConfig>(DEFAULT_WORKSPACE)\n const [status, setStatus] = useState('')\n\n useEffect(() => {\n api<{ value: WorkspaceConfig }>('GET', '/workspace-config')\n .then((entry) => setConfig({ ...DEFAULT_WORKSPACE, ...entry.value }))\n .catch((e) => setStatus((e as Error).message))\n }, [])\n\n async function save() {\n try {\n const saved = await api<{ value: WorkspaceConfig }>('PUT', '/workspace-config', config)\n setConfig({ ...DEFAULT_WORKSPACE, ...saved.value })\n setStatus('Workspace config saved')\n } catch (e) {\n setStatus((e as Error).message)\n }\n }\n\n return (\n <section className=\"space-y-3 rounded-lg border p-4\">\n <div className=\"flex items-center gap-2\">\n <FolderSymlink className=\"w-4 h-4\" />\n <div>\n <h2 className=\"text-sm font-semibold\">Isolated worktree symlinks</h2>\n <p className=\"text-xs text-muted-foreground\">\n Untracked files or filename patterns symlinked from main into each isolated worktree (the "Workspace" spawn option), one per line. Plain names like <code>AGENTS.md</code> or <code>.claude-rig</code> match files and directories; entries with <code>*?[]{'{}'}</code> are expanded as globs. A path is only linked if it exists in main.\n </p>\n </div>\n </div>\n <Field label=\"Paths / patterns\">\n <Textarea\n rows={5}\n placeholder={'AGENTS.md\\n.claude-rig'}\n value={config.symlinkPaths.join('\\n')}\n onChange={(e) => setConfig({ ...config, symlinkPaths: lines(e.target.value) })}\n />\n </Field>\n <div className=\"flex items-center gap-2 pt-1\">\n <Button onClick={save}><Save className=\"w-4 h-4\" />Save</Button>\n {status && <p className=\"text-sm text-muted-foreground\">{status}</p>}\n </div>\n </section>\n )\n}\n\n// Chat display: per-viewer rendering preferences for the Chat panel. These are\n// client-side (persisted in the browser), not provider config — toggling is instant\n// and retroactive. Reasoning steps are still captured by the runner; this only\n// controls whether they're shown. The agent's narration (the terminal's `●` lines)\n// is always shown.\nfunction ChatDisplaySettings() {\n const showReasoning = useRelayStore((s) => s.showReasoning)\n const set = useRelayStore((s) => s.set)\n return (\n <section className=\"space-y-3 rounded-lg border p-4\">\n <div className=\"flex items-center justify-between gap-2\">\n <div className=\"flex items-center gap-2\">\n <Brain className=\"w-4 h-4\" />\n <div>\n <h2 className=\"text-sm font-semibold\">Show reasoning details</h2>\n <p className=\"text-xs text-muted-foreground\">Show the agent's internal thinking inline in chat, alongside its narration and tool steps. Off by default — narration is always shown either way.</p>\n </div>\n </div>\n <Switch checked={showReasoning} onCheckedChange={(v) => set({ showReasoning: v })} />\n </div>\n </section>\n )\n}\n\n// Voice settings: TTS output (speak agent responses — engine + per-engine voice)\n// and the push-to-talk mic-input behaviour. TTS config used to live inline in the\n// chat header; it moved here to declutter the header (especially on mobile). The\n// header keeps only the speaker on/off toggle for quick muting.\nfunction VoiceSettings() {\n const voiceTtsEnabled = useRelayStore((s) => s.voiceTtsEnabled)\n const setVoiceTtsEnabled = useRelayStore((s) => s.setVoiceTtsEnabled)\n const voiceTtsMode = useRelayStore((s) => s.voiceTtsMode)\n const setVoiceTtsMode = useRelayStore((s) => s.setVoiceTtsMode)\n const voiceTtsKokoroVoice = useRelayStore((s) => s.voiceTtsKokoroVoice)\n const setVoiceTtsKokoroVoice = useRelayStore((s) => s.setVoiceTtsKokoroVoice)\n const voiceTtsBrowserVoice = useRelayStore((s) => s.voiceTtsBrowserVoice)\n const setVoiceTtsBrowserVoice = useRelayStore((s) => s.setVoiceTtsBrowserVoice)\n const voiceInputMode = useRelayStore((s) => s.voiceInputMode)\n const setVoiceInputMode = useRelayStore((s) => s.setVoiceInputMode)\n\n // External sync: the browser loads its speech voices asynchronously, so\n // re-read them when the engine signals the list changed.\n const [browserVoices, setBrowserVoices] = useState(() => availableSpeechVoices())\n useEffect(() => {\n if (typeof window === 'undefined' || !('speechSynthesis' in window)) return\n const refresh = () => setBrowserVoices(availableSpeechVoices())\n refresh()\n window.speechSynthesis.addEventListener?.('voiceschanged', refresh)\n return () => window.speechSynthesis.removeEventListener?.('voiceschanged', refresh)\n }, [])\n\n const kokoroOptions = KOKORO_VOICES.some((v) => v.id === voiceTtsKokoroVoice)\n ? KOKORO_VOICES\n : [...KOKORO_VOICES, { id: voiceTtsKokoroVoice, label: voiceTtsKokoroVoice }]\n\n return (\n <section className=\"space-y-3 rounded-lg border p-4\">\n <div className=\"flex items-center justify-between gap-2\">\n <div className=\"flex items-center gap-2\">\n <Volume2 className=\"w-4 h-4\" />\n <div>\n <h2 className=\"text-sm font-semibold\">Voice</h2>\n <p className=\"text-xs text-muted-foreground\">Speak agent responses aloud in the active chat, and how push-to-talk behaves.</p>\n </div>\n </div>\n <Switch checked={voiceTtsEnabled} onCheckedChange={setVoiceTtsEnabled} />\n </div>\n <Field label=\"Speech engine\">\n <Select value={voiceTtsMode} onValueChange={(v) => setVoiceTtsMode(v as 'kokoro' | 'browser')}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"kokoro\">Kokoro (server, natural — falls back to browser)</SelectItem>\n <SelectItem value=\"browser\">Browser (Web Speech API)</SelectItem>\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Kokoro voice\">\n <Select value={voiceTtsKokoroVoice} onValueChange={setVoiceTtsKokoroVoice}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n {kokoroOptions.map((v) => <SelectItem key={v.id} value={v.id}>{v.label}</SelectItem>)}\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Browser voice\">\n <Select value={voiceTtsBrowserVoice || '__default__'} onValueChange={(v) => setVoiceTtsBrowserVoice(v === '__default__' ? '' : v)}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"__default__\">System default</SelectItem>\n {browserVoices.map((v) => <SelectItem key={v.uri} value={v.uri}>{v.label}</SelectItem>)}\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Push-to-talk input\">\n <Select value={voiceInputMode} onValueChange={(v) => setVoiceInputMode(v as 'compose' | 'autosend' | 'handsfree')}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"compose\">Fill the message box (review, then Enter)</SelectItem>\n <SelectItem value=\"autosend\">Send immediately (speak-and-send)</SelectItem>\n </SelectContent>\n </Select>\n </Field>\n </section>\n )\n}\n\ninterface StewardConfig {\n enabled: boolean\n provider: ProviderName\n model?: string\n effort?: 'low' | 'medium' | 'high' | 'xhigh' | 'max'\n permissionMode: string\n keepaliveSeconds: number\n}\n\nconst EFFORTS = ['low', 'medium', 'high', 'xhigh', 'max'] as const\nconst DEFAULT_STEWARD: StewardConfig = { enabled: false, provider: 'claude', permissionMode: 'open', keepaliveSeconds: 300 }\n\n// Global, provider-independent steward config (issue #167). Stewards are\n// auto-provisioned per repo from these settings to resolve conflicts / diverged\n// bases that can't auto-merge. External system: the /steward-config API.\nfunction StewardSettings() {\n const [config, setConfig] = useState<StewardConfig>(DEFAULT_STEWARD)\n const [status, setStatus] = useState('')\n\n useEffect(() => {\n api<{ value: StewardConfig }>('GET', '/steward-config')\n .then((entry) => setConfig({ ...DEFAULT_STEWARD, ...entry.value }))\n .catch((e) => setStatus((e as Error).message))\n }, [])\n\n const update = (patch: Partial<StewardConfig>) => setConfig((c) => ({ ...c, ...patch }))\n\n async function save() {\n try {\n const saved = await api<{ value: StewardConfig }>('PUT', '/steward-config', config)\n setConfig({ ...DEFAULT_STEWARD, ...saved.value })\n setStatus('Steward config saved')\n } catch (e) {\n setStatus((e as Error).message)\n }\n }\n\n return (\n <section className=\"space-y-3 rounded-lg border p-4\">\n <div className=\"flex items-center justify-between\">\n <div className=\"flex items-center gap-2\">\n <GitMerge className=\"w-4 h-4\" />\n <div>\n <h2 className=\"text-sm font-semibold\">Stewards</h2>\n <p className=\"text-xs text-muted-foreground\">Auto-resolve merge conflicts & diverged branches across all repos. Provider-independent — applies to every repo's steward.</p>\n </div>\n </div>\n <Switch checked={config.enabled} onCheckedChange={(v) => update({ enabled: v })} />\n </div>\n\n <div className=\"grid gap-3 sm:grid-cols-2\">\n <Field label=\"Provider\">\n <Select value={config.provider} onValueChange={(v) => update({ provider: v as ProviderName })}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n {providers.map((p) => <SelectItem key={p} value={p}>{p}</SelectItem>)}\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Model (optional)\">\n <Input value={config.model ?? ''} placeholder=\"e.g. gpt-5.5\" onChange={(e) => update({ model: e.target.value.trim() || undefined })} />\n </Field>\n <Field label=\"Effort\">\n <Select value={config.effort ?? 'default'} onValueChange={(v) => update({ effort: v === 'default' ? undefined : v as StewardConfig['effort'] })}>\n <SelectTrigger><SelectValue /></SelectTrigger>\n <SelectContent>\n <SelectItem value=\"default\">Provider default</SelectItem>\n {EFFORTS.map((e) => <SelectItem key={e} value={e}>{e}</SelectItem>)}\n </SelectContent>\n </Select>\n </Field>\n <Field label=\"Idle timeout (seconds)\">\n <Input type=\"number\" value={config.keepaliveSeconds} onChange={(e) => update({ keepaliveSeconds: Number(e.target.value) || 300 })} />\n </Field>\n </div>\n\n <div className=\"flex items-center gap-2 pt-1\">\n <Button onClick={save}><Save className=\"w-4 h-4\" />Save</Button>\n {status && <p className=\"text-sm text-muted-foreground\">{status}</p>}\n </div>\n </section>\n )\n}\n\nfunction Field({ label, children }: { label: string; children: React.ReactNode }) {\n return <label className=\"block space-y-1.5 text-sm\"><span className=\"text-muted-foreground\">{label}</span>{children}</label>\n}\n\nfunction lines(value: string): string[] {\n return value.split('\\n').map((line) => line.trim()).filter(Boolean)\n}\n\nfunction recordLines(value: Record<string, string>): string {\n return Object.entries(value).map(([key, item]) => `${key}=${item}`).join('\\n')\n}\n\nfunction parseRecordLines(value: string): Record<string, string> {\n return Object.fromEntries(lines(value).map((line) => {\n const idx = line.indexOf('=')\n return idx >= 0 ? [line.slice(0, idx).trim(), line.slice(idx + 1)] : [line, '']\n }))\n}\n"],"x_google_ignoreList":[0],"mappings":"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"}
|