@xortex/xcode 3.0.8 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/INSTALLATION.md +285 -0
  2. package/QUICKSTART.md +151 -0
  3. package/SYSTEM_PROMPT.md +583 -0
  4. package/SYSTEM_PROMPT_EXTRACTED.md +1 -0
  5. package/Untitled +1 -0
  6. package/bin/xcode +33 -85
  7. package/bootstrap/state.ts +1758 -0
  8. package/bun.lock +645 -0
  9. package/context/QueuedMessageContext.tsx +63 -0
  10. package/context/fpsMetrics.tsx +30 -0
  11. package/context/mailbox.tsx +38 -0
  12. package/context/modalContext.tsx +58 -0
  13. package/context/notifications.tsx +240 -0
  14. package/context/overlayContext.tsx +151 -0
  15. package/context/promptOverlayContext.tsx +125 -0
  16. package/context/stats.tsx +220 -0
  17. package/context/voice.tsx +88 -0
  18. package/coordinator/coordinatorMode.ts +369 -0
  19. package/costHook.ts +22 -0
  20. package/dialogLaunchers.tsx +133 -0
  21. package/entrypoints/cli.tsx +1 -1
  22. package/extract_prompt.ts +304 -0
  23. package/ink.ts +85 -0
  24. package/install.sh +221 -0
  25. package/interactiveHelpers.tsx +366 -0
  26. package/macro.ts +1 -1
  27. package/memdir/findRelevantMemories.ts +141 -0
  28. package/memdir/memdir.ts +511 -0
  29. package/memdir/memoryAge.ts +53 -0
  30. package/memdir/memoryScan.ts +94 -0
  31. package/memdir/memoryTypes.ts +271 -0
  32. package/memdir/paths.ts +291 -0
  33. package/memdir/teamMemPaths.ts +292 -0
  34. package/memdir/teamMemPrompts.ts +100 -0
  35. package/moreright/useMoreRight.tsx +26 -0
  36. package/native-ts/color-diff/index.ts +999 -0
  37. package/native-ts/file-index/index.ts +370 -0
  38. package/native-ts/yoga-layout/enums.ts +134 -0
  39. package/native-ts/yoga-layout/index.ts +2578 -0
  40. package/outputStyles/loadOutputStylesDir.ts +98 -0
  41. package/package.json +3 -42
  42. package/plugins/builtinPlugins.ts +159 -0
  43. package/plugins/bundled/index.ts +23 -0
  44. package/projectOnboardingState.ts +83 -0
  45. package/public/claude-files.png +0 -0
  46. package/public/leak-tweet.png +0 -0
  47. package/query/config.ts +46 -0
  48. package/query/deps.ts +40 -0
  49. package/query/stopHooks.ts +470 -0
  50. package/query/tokenBudget.ts +93 -0
  51. package/replLauncher.tsx +27 -0
  52. package/schemas/hooks.ts +222 -0
  53. package/screens/Doctor.tsx +575 -0
  54. package/screens/REPL.tsx +7107 -0
  55. package/screens/ResumeConversation.tsx +399 -0
  56. package/scripts/postinstall.js +90 -0
  57. package/server/createDirectConnectSession.ts +88 -0
  58. package/server/directConnectManager.ts +213 -0
  59. package/server/types.ts +57 -0
  60. package/setup.ts +477 -0
  61. package/stub_types.sh +13 -0
  62. package/tasks.ts +39 -0
  63. package/tools.ts +396 -0
  64. package/upstreamproxy/relay.ts +455 -0
  65. package/upstreamproxy/upstreamproxy.ts +285 -0
  66. package/vim/motions.ts +82 -0
  67. package/vim/operators.ts +556 -0
  68. package/vim/textObjects.ts +186 -0
  69. package/vim/transitions.ts +490 -0
  70. package/vim/types.ts +199 -0
  71. package/voice/voiceModeEnabled.ts +54 -0
@@ -0,0 +1,151 @@
1
+ import { c as _c } from "react/compiler-runtime";
2
+ /**
3
+ * Overlay tracking for Escape key coordination.
4
+ *
5
+ * This solves the problem of escape key handling when overlays (like Select with onCancel)
6
+ * are open. The CancelRequestHandler needs to know when an overlay is active so it doesn't
7
+ * cancel requests when the user just wants to dismiss the overlay.
8
+ *
9
+ * Usage:
10
+ * 1. Call useRegisterOverlay() in any overlay component to automatically register it
11
+ * 2. Call useIsOverlayActive() to check if any overlay is currently active
12
+ *
13
+ * The hook automatically registers on mount and unregisters on unmount,
14
+ * so no manual cleanup or state management is needed.
15
+ */
16
+ import { useContext, useEffect, useLayoutEffect } from 'react';
17
+ import instances from '../ink/instances.js';
18
+ import { AppStoreContext, useAppState } from '../state/AppState.js';
19
+
20
+ // Non-modal overlays that shouldn't disable TextInput focus
21
+ const NON_MODAL_OVERLAYS = new Set(['autocomplete']);
22
+
23
+ /**
24
+ * Hook to register a component as an active overlay.
25
+ * Automatically registers on mount and unregisters on unmount.
26
+ *
27
+ * @param id - Unique identifier for this overlay (e.g., 'select', 'multi-select')
28
+ * @param enabled - Whether to register (default: true). Use this to conditionally register
29
+ * based on component props, e.g., only register when onCancel is provided.
30
+ *
31
+ * @example
32
+ * // Conditional registration based on whether cancel is supported
33
+ * function useSelectInput({ state }) {
34
+ * useRegisterOverlay('select', !!state.onCancel)
35
+ * // ...
36
+ * }
37
+ */
38
+ export function useRegisterOverlay(id, t0) {
39
+ const $ = _c(8);
40
+ const enabled = t0 === undefined ? true : t0;
41
+ const store = useContext(AppStoreContext);
42
+ const setAppState = store?.setState;
43
+ let t1;
44
+ let t2;
45
+ if ($[0] !== enabled || $[1] !== id || $[2] !== setAppState) {
46
+ t1 = () => {
47
+ if (!enabled || !setAppState) {
48
+ return;
49
+ }
50
+ setAppState(prev => {
51
+ if (prev.activeOverlays.has(id)) {
52
+ return prev;
53
+ }
54
+ const next = new Set(prev.activeOverlays);
55
+ next.add(id);
56
+ return {
57
+ ...prev,
58
+ activeOverlays: next
59
+ };
60
+ });
61
+ return () => {
62
+ setAppState(prev_0 => {
63
+ if (!prev_0.activeOverlays.has(id)) {
64
+ return prev_0;
65
+ }
66
+ const next_0 = new Set(prev_0.activeOverlays);
67
+ next_0.delete(id);
68
+ return {
69
+ ...prev_0,
70
+ activeOverlays: next_0
71
+ };
72
+ });
73
+ };
74
+ };
75
+ t2 = [id, enabled, setAppState];
76
+ $[0] = enabled;
77
+ $[1] = id;
78
+ $[2] = setAppState;
79
+ $[3] = t1;
80
+ $[4] = t2;
81
+ } else {
82
+ t1 = $[3];
83
+ t2 = $[4];
84
+ }
85
+ useEffect(t1, t2);
86
+ let t3;
87
+ let t4;
88
+ if ($[5] !== enabled) {
89
+ t3 = () => {
90
+ if (!enabled) {
91
+ return;
92
+ }
93
+ return _temp;
94
+ };
95
+ t4 = [enabled];
96
+ $[5] = enabled;
97
+ $[6] = t3;
98
+ $[7] = t4;
99
+ } else {
100
+ t3 = $[6];
101
+ t4 = $[7];
102
+ }
103
+ useLayoutEffect(t3, t4);
104
+ }
105
+
106
+ /**
107
+ * Hook to check if any overlay is currently active.
108
+ * This is reactive - the component will re-render when the overlay state changes.
109
+ *
110
+ * @returns true if any overlay is currently active
111
+ *
112
+ * @example
113
+ * function CancelRequestHandler() {
114
+ * const isOverlayActive = useIsOverlayActive()
115
+ * const isActive = !isOverlayActive && canCancelRunningTask
116
+ * useKeybinding('chat:cancel', handleCancel, { isActive })
117
+ * }
118
+ */
119
+ function _temp() {
120
+ return instances.get(process.stdout)?.invalidatePrevFrame();
121
+ }
122
+ export function useIsOverlayActive() {
123
+ return useAppState(_temp2);
124
+ }
125
+
126
+ /**
127
+ * Hook to check if any modal overlay is currently active.
128
+ * Modal overlays are overlays that should capture all input (like Select dialogs).
129
+ * Non-modal overlays (like autocomplete) don't disable TextInput focus.
130
+ *
131
+ * @returns true if any modal overlay is currently active
132
+ *
133
+ * @example
134
+ * // Use for TextInput focus - allows typing during autocomplete
135
+ * focus: !isSearchingHistory && !isModalOverlayActive
136
+ */
137
+ function _temp2(s) {
138
+ return s.activeOverlays.size > 0;
139
+ }
140
+ export function useIsModalOverlayActive() {
141
+ return useAppState(_temp3);
142
+ }
143
+ function _temp3(s) {
144
+ for (const id of s.activeOverlays) {
145
+ if (!NON_MODAL_OVERLAYS.has(id)) {
146
+ return true;
147
+ }
148
+ }
149
+ return false;
150
+ }
151
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ1c2VDb250ZXh0IiwidXNlRWZmZWN0IiwidXNlTGF5b3V0RWZmZWN0IiwiaW5zdGFuY2VzIiwiQXBwU3RvcmVDb250ZXh0IiwidXNlQXBwU3RhdGUiLCJOT05fTU9EQUxfT1ZFUkxBWVMiLCJTZXQiLCJ1c2VSZWdpc3Rlck92ZXJsYXkiLCJpZCIsInQwIiwiJCIsIl9jIiwiZW5hYmxlZCIsInVuZGVmaW5lZCIsInN0b3JlIiwic2V0QXBwU3RhdGUiLCJzZXRTdGF0ZSIsInQxIiwidDIiLCJwcmV2IiwiYWN0aXZlT3ZlcmxheXMiLCJoYXMiLCJuZXh0IiwiYWRkIiwicHJldl8wIiwibmV4dF8wIiwiZGVsZXRlIiwidDMiLCJ0NCIsIl90ZW1wIiwiZ2V0IiwicHJvY2VzcyIsInN0ZG91dCIsImludmFsaWRhdGVQcmV2RnJhbWUiLCJ1c2VJc092ZXJsYXlBY3RpdmUiLCJfdGVtcDIiLCJzIiwic2l6ZSIsInVzZUlzTW9kYWxPdmVybGF5QWN0aXZlIiwiX3RlbXAzIl0sInNvdXJjZXMiOlsib3ZlcmxheUNvbnRleHQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogT3ZlcmxheSB0cmFja2luZyBmb3IgRXNjYXBlIGtleSBjb29yZGluYXRpb24uXG4gKlxuICogVGhpcyBzb2x2ZXMgdGhlIHByb2JsZW0gb2YgZXNjYXBlIGtleSBoYW5kbGluZyB3aGVuIG92ZXJsYXlzIChsaWtlIFNlbGVjdCB3aXRoIG9uQ2FuY2VsKVxuICogYXJlIG9wZW4uIFRoZSBDYW5jZWxSZXF1ZXN0SGFuZGxlciBuZWVkcyB0byBrbm93IHdoZW4gYW4gb3ZlcmxheSBpcyBhY3RpdmUgc28gaXQgZG9lc24ndFxuICogY2FuY2VsIHJlcXVlc3RzIHdoZW4gdGhlIHVzZXIganVzdCB3YW50cyB0byBkaXNtaXNzIHRoZSBvdmVybGF5LlxuICpcbiAqIFVzYWdlOlxuICogMS4gQ2FsbCB1c2VSZWdpc3Rlck92ZXJsYXkoKSBpbiBhbnkgb3ZlcmxheSBjb21wb25lbnQgdG8gYXV0b21hdGljYWxseSByZWdpc3RlciBpdFxuICogMi4gQ2FsbCB1c2VJc092ZXJsYXlBY3RpdmUoKSB0byBjaGVjayBpZiBhbnkgb3ZlcmxheSBpcyBjdXJyZW50bHkgYWN0aXZlXG4gKlxuICogVGhlIGhvb2sgYXV0b21hdGljYWxseSByZWdpc3RlcnMgb24gbW91bnQgYW5kIHVucmVnaXN0ZXJzIG9uIHVubW91bnQsXG4gKiBzbyBubyBtYW51YWwgY2xlYW51cCBvciBzdGF0ZSBtYW5hZ2VtZW50IGlzIG5lZWRlZC5cbiAqL1xuaW1wb3J0IHsgdXNlQ29udGV4dCwgdXNlRWZmZWN0LCB1c2VMYXlvdXRFZmZlY3QgfSBmcm9tICdyZWFjdCdcbmltcG9ydCBpbnN0YW5jZXMgZnJvbSAnLi4vaW5rL2luc3RhbmNlcy5qcydcbmltcG9ydCB7IEFwcFN0b3JlQ29udGV4dCwgdXNlQXBwU3RhdGUgfSBmcm9tICcuLi9zdGF0ZS9BcHBTdGF0ZS5qcydcblxuLy8gTm9uLW1vZGFsIG92ZXJsYXlzIHRoYXQgc2hvdWxkbid0IGRpc2FibGUgVGV4dElucHV0IGZvY3VzXG5jb25zdCBOT05fTU9EQUxfT1ZFUkxBWVMgPSBuZXcgU2V0KFsnYXV0b2NvbXBsZXRlJ10pXG5cbi8qKlxuICogSG9vayB0byByZWdpc3RlciBhIGNvbXBvbmVudCBhcyBhbiBhY3RpdmUgb3ZlcmxheS5cbiAqIEF1dG9tYXRpY2FsbHkgcmVnaXN0ZXJzIG9uIG1vdW50IGFuZCB1bnJlZ2lzdGVycyBvbiB1bm1vdW50LlxuICpcbiAqIEBwYXJhbSBpZCAtIFVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGlzIG92ZXJsYXkgKGUuZy4sICdzZWxlY3QnLCAnbXVsdGktc2VsZWN0JylcbiAqIEBwYXJhbSBlbmFibGVkIC0gV2hldGhlciB0byByZWdpc3RlciAoZGVmYXVsdDogdHJ1ZSkuIFVzZSB0aGlzIHRvIGNvbmRpdGlvbmFsbHkgcmVnaXN0ZXJcbiAqICAgICAgICAgICAgICAgICAgYmFzZWQgb24gY29tcG9uZW50IHByb3BzLCBlLmcuLCBvbmx5IHJlZ2lzdGVyIHdoZW4gb25DYW5jZWwgaXMgcHJvdmlkZWQuXG4gKlxuICogQGV4YW1wbGVcbiAqIC8vIENvbmRpdGlvbmFsIHJlZ2lzdHJhdGlvbiBiYXNlZCBvbiB3aGV0aGVyIGNhbmNlbCBpcyBzdXBwb3J0ZWRcbiAqIGZ1bmN0aW9uIHVzZVNlbGVjdElucHV0KHsgc3RhdGUgfSkge1xuICogICB1c2VSZWdpc3Rlck92ZXJsYXkoJ3NlbGVjdCcsICEhc3RhdGUub25DYW5jZWwpXG4gKiAgIC8vIC4uLlxuICogfVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlUmVnaXN0ZXJPdmVybGF5KGlkOiBzdHJpbmcsIGVuYWJsZWQgPSB0cnVlKTogdm9pZCB7XG4gIC8vIFVzZSBjb250ZXh0IGRpcmVjdGx5IHNvIHRoaXMgaXMgYSBuby1vcCB3aGVuIHJlbmRlcmVkIG91dHNpZGUgQXBwU3RhdGVQcm92aWRlclxuICAvLyAoZS5nLiwgaW4gaXNvbGF0ZWQgY29tcG9uZW50IHRlc3RzIHRoYXQgZG9uJ3QgbmVlZCB0aGUgZnVsbCBhcHAgc3RhdGUgdHJlZSkuXG4gIGNvbnN0IHN0b3JlID0gdXNlQ29udGV4dChBcHBTdG9yZUNvbnRleHQpXG4gIGNvbnN0IHNldEFwcFN0YXRlID0gc3RvcmU/LnNldFN0YXRlXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKCFlbmFibGVkIHx8ICFzZXRBcHBTdGF0ZSkgcmV0dXJuXG4gICAgc2V0QXBwU3RhdGUocHJldiA9PiB7XG4gICAgICBpZiAocHJldi5hY3RpdmVPdmVybGF5cy5oYXMoaWQpKSByZXR1cm4gcHJldlxuICAgICAgY29uc3QgbmV4dCA9IG5ldyBTZXQocHJldi5hY3RpdmVPdmVybGF5cylcbiAgICAgIG5leHQuYWRkKGlkKVxuICAgICAgcmV0dXJuIHsgLi4ucHJldiwgYWN0aXZlT3ZlcmxheXM6IG5leHQgfVxuICAgIH0pXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHNldEFwcFN0YXRlKHByZXYgPT4ge1xuICAgICAgICBpZiAoIXByZXYuYWN0aXZlT3ZlcmxheXMuaGFzKGlkKSkgcmV0dXJuIHByZXZcbiAgICAgICAgY29uc3QgbmV4dCA9IG5ldyBTZXQocHJldi5hY3RpdmVPdmVybGF5cylcbiAgICAgICAgbmV4dC5kZWxldGUoaWQpXG4gICAgICAgIHJldHVybiB7IC4uLnByZXYsIGFjdGl2ZU92ZXJsYXlzOiBuZXh0IH1cbiAgICAgIH0pXG4gICAgfVxuICB9LCBbaWQsIGVuYWJsZWQsIHNldEFwcFN0YXRlXSlcblxuICAvLyBPbiBvdmVybGF5IGNsb3NlLCBmb3JjZSB0aGUgbmV4dCByZW5kZXIgdG8gZnVsbC1kYW1hZ2UgZGlmZiBpbnN0ZWFkXG4gIC8vIG9mIGJsaXQuIEEgdGFsbCBvdmVybGF5IChlLmcuIEZ1enp5UGlja2VyIHdpdGggYSAyMC1saW5lIHByZXZpZXcpXG4gIC8vIHNocmlua3MgdGhlIEluay1tYW5hZ2VkIHJlZ2lvbiBvbiB1bm1vdW50OyB0aGUgYmxpdCBmYXN0IHBhdGggY2FuXG4gIC8vIGNvcHkgc3RhbGUgY2VsbHMgZnJvbSB0aGUgb3ZlcmxheSdzIHByZXZpb3VzIGZyYW1lIGludG8gcm93cyB0aGVcbiAgLy8gc2hvcnRlciBsYXlvdXQgbm8gbG9uZ2VyIHJlYWNoZXMsIGxlYXZpbmcgYSBnaG9zdCB0aXRsZS9kaXZpZGVyLlxuICAvLyB1c2VMYXlvdXRFZmZlY3Qgc28gY2xlYW51cCBydW5zIHN5bmNocm9ub3VzbHkgYmVmb3JlIHRoZSBtaWNyb3Rhc2stXG4gIC8vIGRlZmVycmVkIG9uUmVuZGVyIChzY2hlZHVsZVJlbmRlciBxdWV1ZXMgYSBtaWNyb3Rhc2sgZnJvbVxuICAvLyByZXNldEFmdGVyQ29tbWl0OyBwYXNzaXZlLWVmZmVjdCBjbGVhbnVwIHdvdWxkIGxhbmQgYWZ0ZXIgaXQpLlxuICB1c2VMYXlvdXRFZmZlY3QoKCkgPT4ge1xuICAgIGlmICghZW5hYmxlZCkgcmV0dXJuXG4gICAgcmV0dXJuICgpID0+IGluc3RhbmNlcy5nZXQocHJvY2Vzcy5zdGRvdXQpPy5pbnZhbGlkYXRlUHJldkZyYW1lKClcbiAgfSwgW2VuYWJsZWRdKVxufVxuXG4vKipcbiAqIEhvb2sgdG8gY2hlY2sgaWYgYW55IG92ZXJsYXkgaXMgY3VycmVudGx5IGFjdGl2ZS5cbiAqIFRoaXMgaXMgcmVhY3RpdmUgLSB0aGUgY29tcG9uZW50IHdpbGwgcmUtcmVuZGVyIHdoZW4gdGhlIG92ZXJsYXkgc3RhdGUgY2hhbmdlcy5cbiAqXG4gKiBAcmV0dXJucyB0cnVlIGlmIGFueSBvdmVybGF5IGlzIGN1cnJlbnRseSBhY3RpdmVcbiAqXG4gKiBAZXhhbXBsZVxuICogZnVuY3Rpb24gQ2FuY2VsUmVxdWVzdEhhbmRsZXIoKSB7XG4gKiAgIGNvbnN0IGlzT3ZlcmxheUFjdGl2ZSA9IHVzZUlzT3ZlcmxheUFjdGl2ZSgpXG4gKiAgIGNvbnN0IGlzQWN0aXZlID0gIWlzT3ZlcmxheUFjdGl2ZSAmJiBjYW5DYW5jZWxSdW5uaW5nVGFza1xuICogICB1c2VLZXliaW5kaW5nKCdjaGF0OmNhbmNlbCcsIGhhbmRsZUNhbmNlbCwgeyBpc0FjdGl2ZSB9KVxuICogfVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlSXNPdmVybGF5QWN0aXZlKCk6IGJvb2xlYW4ge1xuICByZXR1cm4gdXNlQXBwU3RhdGUocyA9PiBzLmFjdGl2ZU92ZXJsYXlzLnNpemUgPiAwKVxufVxuXG4vKipcbiAqIEhvb2sgdG8gY2hlY2sgaWYgYW55IG1vZGFsIG92ZXJsYXkgaXMgY3VycmVudGx5IGFjdGl2ZS5cbiAqIE1vZGFsIG92ZXJsYXlzIGFyZSBvdmVybGF5cyB0aGF0IHNob3VsZCBjYXB0dXJlIGFsbCBpbnB1dCAobGlrZSBTZWxlY3QgZGlhbG9ncykuXG4gKiBOb24tbW9kYWwgb3ZlcmxheXMgKGxpa2UgYXV0b2NvbXBsZXRlKSBkb24ndCBkaXNhYmxlIFRleHRJbnB1dCBmb2N1cy5cbiAqXG4gKiBAcmV0dXJucyB0cnVlIGlmIGFueSBtb2RhbCBvdmVybGF5IGlzIGN1cnJlbnRseSBhY3RpdmVcbiAqXG4gKiBAZXhhbXBsZVxuICogLy8gVXNlIGZvciBUZXh0SW5wdXQgZm9jdXMgLSBhbGxvd3MgdHlwaW5nIGR1cmluZyBhdXRvY29tcGxldGVcbiAqIGZvY3VzOiAhaXNTZWFyY2hpbmdIaXN0b3J5ICYmICFpc01vZGFsT3ZlcmxheUFjdGl2ZVxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlSXNNb2RhbE92ZXJsYXlBY3RpdmUoKTogYm9vbGVhbiB7XG4gIHJldHVybiB1c2VBcHBTdGF0ZShzID0+IHtcbiAgICBmb3IgKGNvbnN0IGlkIG9mIHMuYWN0aXZlT3ZlcmxheXMpIHtcbiAgICAgIGlmICghTk9OX01PREFMX09WRVJMQVlTLmhhcyhpZCkpIHJldHVybiB0cnVlXG4gICAgfVxuICAgIHJldHVybiBmYWxzZVxuICB9KVxufVxuIl0sIm1hcHBpbmdzIjoiO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVNBLFVBQVUsRUFBRUMsU0FBUyxFQUFFQyxlQUFlLFFBQVEsT0FBTztBQUM5RCxPQUFPQyxTQUFTLE1BQU0scUJBQXFCO0FBQzNDLFNBQVNDLGVBQWUsRUFBRUMsV0FBVyxRQUFRLHNCQUFzQjs7QUFFbkU7QUFDQSxNQUFNQyxrQkFBa0IsR0FBRyxJQUFJQyxHQUFHLENBQUMsQ0FBQyxjQUFjLENBQUMsQ0FBQzs7QUFFcEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTyxTQUFBQyxtQkFBQUMsRUFBQSxFQUFBQyxFQUFBO0VBQUEsTUFBQUMsQ0FBQSxHQUFBQyxFQUFBO0VBQXdDLE1BQUFDLE9BQUEsR0FBQUgsRUFBYyxLQUFkSSxTQUFjLEdBQWQsSUFBYyxHQUFkSixFQUFjO0VBRzNELE1BQUFLLEtBQUEsR0FBY2YsVUFBVSxDQUFDSSxlQUFlLENBQUM7RUFDekMsTUFBQVksV0FBQSxHQUFvQkQsS0FBSyxFQUFBRSxRQUFVO0VBQUEsSUFBQUMsRUFBQTtFQUFBLElB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
@@ -0,0 +1,125 @@
1
+ import { c as _c } from "react/compiler-runtime";
2
+ /**
3
+ * Portal for content that floats above the prompt so it escapes
4
+ * FullscreenLayout's bottom-slot `overflowY:hidden` clip.
5
+ *
6
+ * The clip is load-bearing (CC-668: tall pastes squash the ScrollBox
7
+ * without it), but floating overlays use `position:absolute
8
+ * bottom="100%"` to float above the prompt — and Ink's clip stack
9
+ * intersects ALL descendants, so they were clipped to ~1 row.
10
+ *
11
+ * Two channels:
12
+ * - `useSetPromptOverlay` — slash-command suggestion data (structured,
13
+ * written by PromptInputFooter)
14
+ * - `useSetPromptOverlayDialog` — arbitrary dialog node (e.g.
15
+ * AutoModeOptInDialog, written by PromptInput)
16
+ *
17
+ * FullscreenLayout reads both and renders them outside the clipped slot.
18
+ *
19
+ * Split into data/setter context pairs so writers never re-render on
20
+ * their own writes — the setter contexts are stable.
21
+ */
22
+ import React, { createContext, type ReactNode, useContext, useEffect, useState } from 'react';
23
+ import type { SuggestionItem } from '../components/PromptInput/PromptInputFooterSuggestions.js';
24
+ export type PromptOverlayData = {
25
+ suggestions: SuggestionItem[];
26
+ selectedSuggestion: number;
27
+ maxColumnWidth?: number;
28
+ };
29
+ type Setter<T> = (d: T | null) => void;
30
+ const DataContext = createContext<PromptOverlayData | null>(null);
31
+ const SetContext = createContext<Setter<PromptOverlayData> | null>(null);
32
+ const DialogContext = createContext<ReactNode>(null);
33
+ const SetDialogContext = createContext<Setter<ReactNode> | null>(null);
34
+ export function PromptOverlayProvider(t0) {
35
+ const $ = _c(6);
36
+ const {
37
+ children
38
+ } = t0;
39
+ const [data, setData] = useState(null);
40
+ const [dialog, setDialog] = useState(null);
41
+ let t1;
42
+ if ($[0] !== children || $[1] !== dialog) {
43
+ t1 = <DialogContext.Provider value={dialog}>{children}</DialogContext.Provider>;
44
+ $[0] = children;
45
+ $[1] = dialog;
46
+ $[2] = t1;
47
+ } else {
48
+ t1 = $[2];
49
+ }
50
+ let t2;
51
+ if ($[3] !== data || $[4] !== t1) {
52
+ t2 = <SetContext.Provider value={setData}><SetDialogContext.Provider value={setDialog}><DataContext.Provider value={data}>{t1}</DataContext.Provider></SetDialogContext.Provider></SetContext.Provider>;
53
+ $[3] = data;
54
+ $[4] = t1;
55
+ $[5] = t2;
56
+ } else {
57
+ t2 = $[5];
58
+ }
59
+ return t2;
60
+ }
61
+ export function usePromptOverlay() {
62
+ return useContext(DataContext);
63
+ }
64
+ export function usePromptOverlayDialog() {
65
+ return useContext(DialogContext);
66
+ }
67
+
68
+ /**
69
+ * Register suggestion data for the floating overlay. Clears on unmount.
70
+ * No-op outside the provider (non-fullscreen renders inline instead).
71
+ */
72
+ export function useSetPromptOverlay(data) {
73
+ const $ = _c(4);
74
+ const set = useContext(SetContext);
75
+ let t0;
76
+ let t1;
77
+ if ($[0] !== data || $[1] !== set) {
78
+ t0 = () => {
79
+ if (!set) {
80
+ return;
81
+ }
82
+ set(data);
83
+ return () => set(null);
84
+ };
85
+ t1 = [set, data];
86
+ $[0] = data;
87
+ $[1] = set;
88
+ $[2] = t0;
89
+ $[3] = t1;
90
+ } else {
91
+ t0 = $[2];
92
+ t1 = $[3];
93
+ }
94
+ useEffect(t0, t1);
95
+ }
96
+
97
+ /**
98
+ * Register a dialog node to float above the prompt. Clears on unmount.
99
+ * No-op outside the provider (non-fullscreen renders inline instead).
100
+ */
101
+ export function useSetPromptOverlayDialog(node) {
102
+ const $ = _c(4);
103
+ const set = useContext(SetDialogContext);
104
+ let t0;
105
+ let t1;
106
+ if ($[0] !== node || $[1] !== set) {
107
+ t0 = () => {
108
+ if (!set) {
109
+ return;
110
+ }
111
+ set(node);
112
+ return () => set(null);
113
+ };
114
+ t1 = [set, node];
115
+ $[0] = node;
116
+ $[1] = set;
117
+ $[2] = t0;
118
+ $[3] = t1;
119
+ } else {
120
+ t0 = $[2];
121
+ t1 = $[3];
122
+ }
123
+ useEffect(t0, t1);
124
+ }
125
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImNyZWF0ZUNvbnRleHQiLCJSZWFjdE5vZGUiLCJ1c2VDb250ZXh0IiwidXNlRWZmZWN0IiwidXNlU3RhdGUiLCJTdWdnZXN0aW9uSXRlbSIsIlByb21wdE92ZXJsYXlEYXRhIiwic3VnZ2VzdGlvbnMiLCJzZWxlY3RlZFN1Z2dlc3Rpb24iLCJtYXhDb2x1bW5XaWR0aCIsIlNldHRlciIsImQiLCJUIiwiRGF0YUNvbnRleHQiLCJTZXRDb250ZXh0IiwiRGlhbG9nQ29udGV4dCIsIlNldERpYWxvZ0NvbnRleHQiLCJQcm9tcHRPdmVybGF5UHJvdmlkZXIiLCJ0MCIsIiQiLCJfYyIsImNoaWxkcmVuIiwiZGF0YSIsInNldERhdGEiLCJkaWFsb2ciLCJzZXREaWFsb2ciLCJ0MSIsInQyIiwidXNlUHJvbXB0T3ZlcmxheSIsInVzZVByb21wdE92ZXJsYXlEaWFsb2ciLCJ1c2VTZXRQcm9tcHRPdmVybGF5Iiwic2V0IiwidXNlU2V0UHJvbXB0T3ZlcmxheURpYWxvZyIsIm5vZGUiXSwic291cmNlcyI6WyJwcm9tcHRPdmVybGF5Q29udGV4dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBQb3J0YWwgZm9yIGNvbnRlbnQgdGhhdCBmbG9hdHMgYWJvdmUgdGhlIHByb21wdCBzbyBpdCBlc2NhcGVzXG4gKiBGdWxsc2NyZWVuTGF5b3V0J3MgYm90dG9tLXNsb3QgYG92ZXJmbG93WTpoaWRkZW5gIGNsaXAuXG4gKlxuICogVGhlIGNsaXAgaXMgbG9hZC1iZWFyaW5nIChDQy02Njg6IHRhbGwgcGFzdGVzIHNxdWFzaCB0aGUgU2Nyb2xsQm94XG4gKiB3aXRob3V0IGl0KSwgYnV0IGZsb2F0aW5nIG92ZXJsYXlzIHVzZSBgcG9zaXRpb246YWJzb2x1dGVcbiAqIGJvdHRvbT1cIjEwMCVcImAgdG8gZmxvYXQgYWJvdmUgdGhlIHByb21wdCDigJQgYW5kIEluaydzIGNsaXAgc3RhY2tcbiAqIGludGVyc2VjdHMgQUxMIGRlc2NlbmRhbnRzLCBzbyB0aGV5IHdlcmUgY2xpcHBlZCB0byB+MSByb3cuXG4gKlxuICogVHdvIGNoYW5uZWxzOlxuICogLSBgdXNlU2V0UHJvbXB0T3ZlcmxheWAg4oCUIHNsYXNoLWNvbW1hbmQgc3VnZ2VzdGlvbiBkYXRhIChzdHJ1Y3R1cmVkLFxuICogICB3cml0dGVuIGJ5IFByb21wdElucHV0Rm9vdGVyKVxuICogLSBgdXNlU2V0UHJvbXB0T3ZlcmxheURpYWxvZ2Ag4oCUIGFyYml0cmFyeSBkaWFsb2cgbm9kZSAoZS5nLlxuICogICBBdXRvTW9kZU9wdEluRGlhbG9nLCB3cml0dGVuIGJ5IFByb21wdElucHV0KVxuICpcbiAqIEZ1bGxzY3JlZW5MYXlvdXQgcmVhZHMgYm90aCBhbmQgcmVuZGVycyB0aGVtIG91dHNpZGUgdGhlIGNsaXBwZWQgc2xvdC5cbiAqXG4gKiBTcGxpdCBpbnRvIGRhdGEvc2V0dGVyIGNvbnRleHQgcGFpcnMgc28gd3JpdGVycyBuZXZlciByZS1yZW5kZXIgb25cbiAqIHRoZWlyIG93biB3cml0ZXMg4oCUIHRoZSBzZXR0ZXIgY29udGV4dHMgYXJlIHN0YWJsZS5cbiAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIGNyZWF0ZUNvbnRleHQsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB1c2VDb250ZXh0LFxuICB1c2VFZmZlY3QsXG4gIHVzZVN0YXRlLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgU3VnZ2VzdGlvbkl0ZW0gfSBmcm9tICcuLi9jb21wb25lbnRzL1Byb21wdElucHV0L1Byb21wdElucHV0Rm9vdGVyU3VnZ2VzdGlvbnMuanMnXG5cbmV4cG9ydCB0eXBlIFByb21wdE92ZXJsYXlEYXRhID0ge1xuICBzdWdnZXN0aW9uczogU3VnZ2VzdGlvbkl0ZW1bXVxuICBzZWxlY3RlZFN1Z2dlc3Rpb246IG51bWJlclxuICBtYXhDb2x1bW5XaWR0aD86IG51bWJlclxufVxuXG50eXBlIFNldHRlcjxUPiA9IChkOiBUIHwgbnVsbCkgPT4gdm9pZFxuXG5jb25zdCBEYXRhQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8UHJvbXB0T3ZlcmxheURhdGEgfCBudWxsPihudWxsKVxuY29uc3QgU2V0Q29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8U2V0dGVyPFByb21wdE92ZXJsYXlEYXRhPiB8IG51bGw+KG51bGwpXG5jb25zdCBEaWFsb2dDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxSZWFjdE5vZGU+KG51bGwpXG5jb25zdCBTZXREaWFsb2dDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxTZXR0ZXI8UmVhY3ROb2RlPiB8IG51bGw+KG51bGwpXG5cbmV4cG9ydCBmdW5jdGlvbiBQcm9tcHRPdmVybGF5UHJvdmlkZXIoe1xuICBjaGlsZHJlbixcbn06IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxufSk6IFJlYWN0Tm9kZSB7XG4gIGNvbnN0IFtkYXRhLCBzZXREYXRhXSA9IHVzZVN0YXRlPFByb21wdE92ZXJsYXlEYXRhIHwgbnVsbD4obnVsbClcbiAgY29uc3QgW2RpYWxvZywgc2V0RGlhbG9nXSA9IHVzZVN0YXRlPFJlYWN0Tm9kZT4obnVsbClcbiAgcmV0dXJuIChcbiAgICA8U2V0Q29udGV4dC5Qcm92aWRlciB2YWx1ZT17c2V0RGF0YX0+XG4gICAgICA8U2V0RGlhbG9nQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17c2V0RGlhbG9nfT5cbiAgICAgICAgPERhdGFDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtkYXRhfT5cbiAgICAgICAgICA8RGlhbG9nQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17ZGlhbG9nfT5cbiAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICA8L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICAgICAgIDwvRGF0YUNvbnRleHQuUHJvdmlkZXI+XG4gICAgICA8L1NldERpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICAgPC9TZXRDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VQcm9tcHRPdmVybGF5KCk6IFByb21wdE92ZXJsYXlEYXRhIHwgbnVsbCB7XG4gIHJldHVybiB1c2VDb250ZXh0KERhdGFDb250ZXh0KVxufVxuXG5leHBvcnQgZnVuY3Rpb24gdXNlUHJvbXB0T3ZlcmxheURpYWxvZygpOiBSZWFjdE5vZGUge1xuICByZXR1cm4gdXNlQ29udGV4dChEaWFsb2dDb250ZXh0KVxufVxuXG4vKipcbiAqIFJlZ2lzdGVyIHN1Z2dlc3Rpb24gZGF0YSBmb3IgdGhlIGZsb2F0aW5nIG92ZXJsYXkuIENsZWFycyBvbiB1bm1vdW50LlxuICogTm8tb3Agb3V0c2lkZSB0aGUgcHJvdmlkZXIgKG5vbi1mdWxsc2NyZWVuIHJlbmRlcnMgaW5saW5lIGluc3RlYWQpLlxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlU2V0UHJvbXB0T3ZlcmxheShkYXRhOiBQcm9tcHRPdmVybGF5RGF0YSB8IG51bGwpOiB2b2lkIHtcbiAgY29uc3Qgc2V0ID0gdXNlQ29udGV4dChTZXRDb250ZXh0KVxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmICghc2V0KSByZXR1cm5cbiAgICBzZXQoZGF0YSlcbiAgICByZXR1cm4gKCkgPT4gc2V0KG51bGwpXG4gIH0sIFtzZXQsIGRhdGFdKVxufVxuXG4vKipcbiAqIFJlZ2lzdGVyIGEgZGlhbG9nIG5vZGUgdG8gZmxvYXQgYWJvdmUgdGhlIHByb21wdC4gQ2xlYXJzIG9uIHVubW91bnQuXG4gKiBOby1vcCBvdXRzaWRlIHRoZSBwcm92aWRlciAobm9uLWZ1bGxzY3JlZW4gcmVuZGVycyBpbmxpbmUgaW5zdGVhZCkuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB1c2VTZXRQcm9tcHRPdmVybGF5RGlhbG9nKG5vZGU6IFJlYWN0Tm9kZSk6IHZvaWQge1xuICBjb25zdCBzZXQgPSB1c2VDb250ZXh0KFNldERpYWxvZ0NvbnRleHQpXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKCFzZXQpIHJldHVyblxuICAgIHNldChub2RlKVxuICAgIHJldHVybiAoKSA9PiBzZXQobnVsbClcbiAgfSwgW3NldCwgbm9kZV0pXG59XG4i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
@@ -0,0 +1,220 @@
1
+ import { c as _c } from "react/compiler-runtime";
2
+ import React, { createContext, useCallback, useContext, useEffect, useMemo } from 'react';
3
+ import { saveCurrentProjectConfig } from '../utils/config.js';
4
+ export type StatsStore = {
5
+ increment(name: string, value?: number): void;
6
+ set(name: string, value: number): void;
7
+ observe(name: string, value: number): void;
8
+ add(name: string, value: string): void;
9
+ getAll(): Record<string, number>;
10
+ };
11
+ function percentile(sorted: number[], p: number): number {
12
+ const index = p / 100 * (sorted.length - 1);
13
+ const lower = Math.floor(index);
14
+ const upper = Math.ceil(index);
15
+ if (lower === upper) {
16
+ return sorted[lower]!;
17
+ }
18
+ return sorted[lower]! + (sorted[upper]! - sorted[lower]!) * (index - lower);
19
+ }
20
+ const RESERVOIR_SIZE = 1024;
21
+ type Histogram = {
22
+ reservoir: number[];
23
+ count: number;
24
+ sum: number;
25
+ min: number;
26
+ max: number;
27
+ };
28
+ export function createStatsStore(): StatsStore {
29
+ const metrics = new Map<string, number>();
30
+ const histograms = new Map<string, Histogram>();
31
+ const sets = new Map<string, Set<string>>();
32
+ return {
33
+ increment(name: string, value = 1) {
34
+ metrics.set(name, (metrics.get(name) ?? 0) + value);
35
+ },
36
+ set(name: string, value: number) {
37
+ metrics.set(name, value);
38
+ },
39
+ observe(name: string, value: number) {
40
+ let h = histograms.get(name);
41
+ if (!h) {
42
+ h = {
43
+ reservoir: [],
44
+ count: 0,
45
+ sum: 0,
46
+ min: value,
47
+ max: value
48
+ };
49
+ histograms.set(name, h);
50
+ }
51
+ h.count++;
52
+ h.sum += value;
53
+ if (value < h.min) {
54
+ h.min = value;
55
+ }
56
+ if (value > h.max) {
57
+ h.max = value;
58
+ }
59
+ // Reservoir sampling (Algorithm R)
60
+ if (h.reservoir.length < RESERVOIR_SIZE) {
61
+ h.reservoir.push(value);
62
+ } else {
63
+ const j = Math.floor(Math.random() * h.count);
64
+ if (j < RESERVOIR_SIZE) {
65
+ h.reservoir[j] = value;
66
+ }
67
+ }
68
+ },
69
+ add(name: string, value: string) {
70
+ let s = sets.get(name);
71
+ if (!s) {
72
+ s = new Set();
73
+ sets.set(name, s);
74
+ }
75
+ s.add(value);
76
+ },
77
+ getAll() {
78
+ const result: Record<string, number> = Object.fromEntries(metrics);
79
+ for (const [name, h] of histograms) {
80
+ if (h.count === 0) {
81
+ continue;
82
+ }
83
+ result[`${name}_count`] = h.count;
84
+ result[`${name}_min`] = h.min;
85
+ result[`${name}_max`] = h.max;
86
+ result[`${name}_avg`] = h.sum / h.count;
87
+ const sorted = [...h.reservoir].sort((a, b) => a - b);
88
+ result[`${name}_p50`] = percentile(sorted, 50);
89
+ result[`${name}_p95`] = percentile(sorted, 95);
90
+ result[`${name}_p99`] = percentile(sorted, 99);
91
+ }
92
+ for (const [name, s] of sets) {
93
+ result[name] = s.size;
94
+ }
95
+ return result;
96
+ }
97
+ };
98
+ }
99
+ export const StatsContext = createContext<StatsStore | null>(null);
100
+ type Props = {
101
+ store?: StatsStore;
102
+ children: React.ReactNode;
103
+ };
104
+ export function StatsProvider(t0) {
105
+ const $ = _c(7);
106
+ const {
107
+ store: externalStore,
108
+ children
109
+ } = t0;
110
+ let t1;
111
+ if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
112
+ t1 = createStatsStore();
113
+ $[0] = t1;
114
+ } else {
115
+ t1 = $[0];
116
+ }
117
+ const internalStore = t1;
118
+ const store = externalStore ?? internalStore;
119
+ let t2;
120
+ let t3;
121
+ if ($[1] !== store) {
122
+ t2 = () => {
123
+ const flush = () => {
124
+ const metrics = store.getAll();
125
+ if (Object.keys(metrics).length > 0) {
126
+ saveCurrentProjectConfig(current => ({
127
+ ...current,
128
+ lastSessionMetrics: metrics
129
+ }));
130
+ }
131
+ };
132
+ process.on("exit", flush);
133
+ return () => {
134
+ process.off("exit", flush);
135
+ };
136
+ };
137
+ t3 = [store];
138
+ $[1] = store;
139
+ $[2] = t2;
140
+ $[3] = t3;
141
+ } else {
142
+ t2 = $[2];
143
+ t3 = $[3];
144
+ }
145
+ useEffect(t2, t3);
146
+ let t4;
147
+ if ($[4] !== children || $[5] !== store) {
148
+ t4 = <StatsContext.Provider value={store}>{children}</StatsContext.Provider>;
149
+ $[4] = children;
150
+ $[5] = store;
151
+ $[6] = t4;
152
+ } else {
153
+ t4 = $[6];
154
+ }
155
+ return t4;
156
+ }
157
+ export function useStats() {
158
+ const store = useContext(StatsContext);
159
+ if (!store) {
160
+ throw new Error("useStats must be used within a StatsProvider");
161
+ }
162
+ return store;
163
+ }
164
+ export function useCounter(name) {
165
+ const $ = _c(3);
166
+ const store = useStats();
167
+ let t0;
168
+ if ($[0] !== name || $[1] !== store) {
169
+ t0 = value => store.increment(name, value);
170
+ $[0] = name;
171
+ $[1] = store;
172
+ $[2] = t0;
173
+ } else {
174
+ t0 = $[2];
175
+ }
176
+ return t0;
177
+ }
178
+ export function useGauge(name) {
179
+ const $ = _c(3);
180
+ const store = useStats();
181
+ let t0;
182
+ if ($[0] !== name || $[1] !== store) {
183
+ t0 = value => store.set(name, value);
184
+ $[0] = name;
185
+ $[1] = store;
186
+ $[2] = t0;
187
+ } else {
188
+ t0 = $[2];
189
+ }
190
+ return t0;
191
+ }
192
+ export function useTimer(name) {
193
+ const $ = _c(3);
194
+ const store = useStats();
195
+ let t0;
196
+ if ($[0] !== name || $[1] !== store) {
197
+ t0 = value => store.observe(name, value);
198
+ $[0] = name;
199
+ $[1] = store;
200
+ $[2] = t0;
201
+ } else {
202
+ t0 = $[2];
203
+ }
204
+ return t0;
205
+ }
206
+ export function useSet(name) {
207
+ const $ = _c(3);
208
+ const store = useStats();
209
+ let t0;
210
+ if ($[0] !== name || $[1] !== store) {
211
+ t0 = value => store.add(name, value);
212
+ $[0] = name;
213
+ $[1] = store;
214
+ $[2] = t0;
215
+ } else {
216
+ t0 = $[2];
217
+ }
218
+ return t0;
219
+ }
220
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImNyZWF0ZUNvbnRleHQiLCJ1c2VDYWxsYmFjayIsInVzZUNvbnRleHQiLCJ1c2VFZmZlY3QiLCJ1c2VNZW1vIiwic2F2ZUN1cnJlbnRQcm9qZWN0Q29uZmlnIiwiU3RhdHNTdG9yZSIsImluY3JlbWVudCIsIm5hbWUiLCJ2YWx1ZSIsInNldCIsIm9ic2VydmUiLCJhZGQiLCJnZXRBbGwiLCJSZWNvcmQiLCJwZXJjZW50aWxlIiwic29ydGVkIiwicCIsImluZGV4IiwibGVuZ3RoIiwibG93ZXIiLCJNYXRoIiwiZmxvb3IiLCJ1cHBlciIsImNlaWwiLCJSRVNFUlZPSVJfU0laRSIsIkhpc3RvZ3JhbSIsInJlc2Vydm9pciIsImNvdW50Iiwic3VtIiwibWluIiwibWF4IiwiY3JlYXRlU3RhdHNTdG9yZSIsIm1ldHJpY3MiLCJNYXAiLCJoaXN0b2dyYW1zIiwic2V0cyIsIlNldCIsImdldCIsImgiLCJwdXNoIiwiaiIsInJhbmRvbSIsInMiLCJyZXN1bHQiLCJPYmplY3QiLCJmcm9tRW50cmllcyIsInNvcnQiLCJhIiwiYiIsInNpemUiLCJTdGF0c0NvbnRleHQiLCJQcm9wcyIsInN0b3JlIiwiY2hpbGRyZW4iLCJSZWFjdE5vZGUiLCJTdGF0c1Byb3ZpZGVyIiwidDAiLCIkIiwiX2MiLCJleHRlcm5hbFN0b3JlIiwidDEiLCJTeW1ib2wiLCJmb3IiLCJpbnRlcm5hbFN0b3JlIiwidDIiLCJ0MyIsImZsdXNoIiwia2V5cyIsImN1cnJlbnQiLCJsYXN0U2Vzc2lvbk1ldHJpY3MiLCJwcm9jZXNzIiwib24iLCJvZmYiLCJ0NCIsInVzZVN0YXRzIiwiRXJyb3IiLCJ1c2VDb3VudGVyIiwidXNlR2F1Z2UiLCJ1c2VUaW1lciIsInVzZVNldCJdLCJzb3VyY2VzIjpbInN0YXRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHtcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZUNvbnRleHQsXG4gIHVzZUVmZmVjdCxcbiAgdXNlTWVtbyxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBzYXZlQ3VycmVudFByb2plY3RDb25maWcgfSBmcm9tICcuLi91dGlscy9jb25maWcuanMnXG5cbmV4cG9ydCB0eXBlIFN0YXRzU3RvcmUgPSB7XG4gIGluY3JlbWVudChuYW1lOiBzdHJpbmcsIHZhbHVlPzogbnVtYmVyKTogdm9pZFxuICBzZXQobmFtZTogc3RyaW5nLCB2YWx1ZTogbnVtYmVyKTogdm9pZFxuICBvYnNlcnZlKG5hbWU6IHN0cmluZywgdmFsdWU6IG51bWJlcik6IHZvaWRcbiAgYWRkKG5hbWU6IHN0cmluZywgdmFsdWU6IHN0cmluZyk6IHZvaWRcbiAgZ2V0QWxsKCk6IFJlY29yZDxzdHJpbmcsIG51bWJlcj5cbn1cblxuZnVuY3Rpb24gcGVyY2VudGlsZShzb3J0ZWQ6IG51bWJlcltdLCBwOiBudW1iZXIpOiBudW1iZXIge1xuICBjb25zdCBpbmRleCA9IChwIC8gMTAwKSAqIChzb3J0ZWQubGVuZ3RoIC0gMSlcbiAgY29uc3QgbG93ZXIgPSBNYXRoLmZsb29yKGluZGV4KVxuICBjb25zdCB1cHBlciA9IE1hdGguY2VpbChpbmRleClcbiAgaWYgKGxvd2VyID09PSB1cHBlcikge1xuICAgIHJldHVybiBzb3J0ZWRbbG93ZXJdIVxuICB9XG4gIHJldHVybiBzb3J0ZWRbbG93ZXJdISArIChzb3J0ZWRbdXBwZXJdISAtIHNvcnRlZFtsb3dlcl0hKSAqIChpbmRleCAtIGxvd2VyKVxufVxuXG5jb25zdCBSRVNFUlZPSVJfU0laRSA9IDEwMjRcblxudHlwZSBIaXN0b2dyYW0gPSB7XG4gIHJlc2Vydm9pcjogbnVtYmVyW11cbiAgY291bnQ6IG51bWJlclxuICBzdW06IG51bWJlclxuICBtaW46IG51bWJlclxuICBtYXg6IG51bWJlclxufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU3RhdHNTdG9yZSgpOiBTdGF0c1N0b3JlIHtcbiAgY29uc3QgbWV0cmljcyA9IG5ldyBNYXA8c3RyaW5nLCBudW1iZXI+KClcbiAgY29uc3QgaGlzdG9ncmFtcyA9IG5ldyBNYXA8c3RyaW5nLCBIaXN0b2dyYW0+KClcbiAgY29uc3Qgc2V0cyA9IG5ldyBNYXA8c3RyaW5nLCBTZXQ8c3RyaW5nPj4oKVxuXG4gIHJldHVybiB7XG4gICAgaW5jcmVtZW50KG5hbWU6IHN0cmluZywgdmFsdWUgPSAxKSB7XG4gICAgICBtZXRyaWNzLnNldChuYW1lLCAobWV0cmljcy5nZXQobmFtZSkgPz8gMCkgKyB2YWx1ZSlcbiAgICB9LFxuICAgIHNldChuYW1lOiBzdHJpbmcsIHZhbHVlOiBudW1iZXIpIHtcbiAgICAgIG1ldHJpY3Muc2V0KG5hbWUsIHZhbHVlKVxuICAgIH0sXG4gICAgb2JzZXJ2ZShuYW1lOiBzdHJpbmcsIHZhbHVlOiBudW1iZXIpIHtcbiAgICAgIGxldCBoID0gaGlzdG9ncmFtcy5nZXQobmFtZSlcbiAgICAgIGlmICghaCkge1xuICAgICAgICBoID0geyByZXNlcnZvaXI6IFtdLCBjb3VudDogMCwgc3VtOiAwLCBtaW46IHZhbHVlLCBtYXg6IHZhbHVlIH1cbiAgICAgICAgaGlzdG9ncmFtcy5zZXQobmFtZSwgaClcbiAgICAgIH1cbiAgICAgIGguY291bnQrK1xuICAgICAgaC5zdW0gKz0gdmFsdWVcbiAgICAgIGlmICh2YWx1ZSA8IGgubWluKSB7XG4gICAgICAgIGgubWluID0gdmFsdWVcbiAgICAgIH1cbiAgICAgIGlmICh2YWx1ZSA+IGgubWF4KSB7XG4gICAgICAgIGgubWF4ID0gdmFsdWVcbiAgICAgIH1cbiAgICAgIC8vIFJlc2Vydm9pciBzYW1wbGluZyAoQWxnb3JpdGhtIFIpXG4gICAgICBpZiAoaC5yZXNlcnZvaXIubGVuZ3RoIDwgUkVTRVJWT0lSX1NJWkUpIHtcbiAgICAgICAgaC5yZXNlcnZvaXIucHVzaCh2YWx1ZSlcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnN0IGogPSBNYXRoLmZsb29yKE1hdGgucmFuZG9tKCkgKiBoLmNvdW50KVxuICAgICAgICBpZiAoaiA8IFJFU0VSVk9JUl9TSVpFKSB7XG4gICAgICAgICAgaC5yZXNlcnZvaXJbal0gPSB2YWx1ZVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfSxcbiAgICBhZGQobmFtZTogc3RyaW5nLCB2YWx1ZTogc3RyaW5nKSB7XG4gICAgICBsZXQgcyA9IHNldHMuZ2V0KG5hbWUpXG4gICAgICBpZiAoIXMpIHtcbiAgICAgICAgcyA9IG5ldyBTZXQoKVxuICAgICAgICBzZXRzLnNldChuYW1lLCBzKVxuICAgICAgfVxuICAgICAgcy5hZGQodmFsdWUpXG4gICAgfSxcbiAgICBnZXRBbGwoKSB7XG4gICAgICBjb25zdCByZXN1bHQ6IFJlY29yZDxzdHJpbmcsIG51bWJlcj4gPSBPYmplY3QuZnJvbUVudHJpZXMobWV0cmljcylcblxuICAgICAgZm9yIChjb25zdCBbbmFtZSwgaF0gb2YgaGlzdG9ncmFtcykge1xuICAgICAgICBpZiAoaC5jb3VudCA9PT0gMCkge1xuICAgICAgICAgIGNvbnRpbnVlXG4gICAgICAgIH1cbiAgICAgICAgcmVzdWx0W2Ake25hbWV9X2NvdW50YF0gPSBoLmNvdW50XG4gICAgICAgIHJlc3VsdFtgJHtuYW1lfV9taW5gXSA9IGgubWluXG4gICAgICAgIHJlc3VsdFtgJHtuYW1lfV9tYXhgXSA9IGgubWF4XG4gICAgICAgIHJlc3VsdFtgJHtuYW1lfV9hdmdgXSA9IGguc3VtIC8gaC5jb3VudFxuICAgICAgICBjb25zdCBzb3J0ZWQgPSBbLi4uaC5yZXNlcnZvaXJdLnNvcnQoKGEsIGIpID0+IGEgLSBiKVxuICAgICAgICByZXN1bHRbYCR7bmFtZX1fcDUwYF0gPSBwZXJjZW50aWxlKHNvcnRlZCwgNTApXG4gICAgICAgIHJlc3VsdFtgJHtuYW1lfV9wOTVgXSA9IHBlcmNlbnRpbGUoc29ydGVkLCA5NSlcbiAgICAgICAgcmVzdWx0W2Ake25hbWV9X3A5OWBdID0gcGVyY2VudGlsZShzb3J0ZWQsIDk5KVxuICAgICAgfVxuXG4gICAgICBmb3IgKGNvbnN0IFtuYW1lLCBzXSBvZiBzZXRzKSB7XG4gICAgICAgIHJlc3VsdFtuYW1lXSA9IHMuc2l6ZVxuICAgICAgfVxuXG4gICAgICByZXR1cm4gcmVzdWx0XG4gICAgfSxcbiAgfVxufVxuXG5leHBvcnQgY29uc3QgU3RhdHNDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxTdGF0c1N0b3JlIHwgbnVsbD4obnVsbClcblxudHlwZSBQcm9wcyA9IHtcbiAgc3RvcmU/OiBTdGF0c1N0b3JlXG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIFN0YXRzUHJvdmlkZXIoe1xuICBzdG9yZTogZXh0ZXJuYWxTdG9yZSxcbiAgY2hpbGRyZW4sXG59OiBQcm9wcyk6IFJlYWN0LlJlYWN0Tm9kZSB7XG4gIGNvbnN0IGludGVybmFsU3RvcmUgPSB1c2VNZW1vKCgpID0+IGNyZWF0ZVN0YXRzU3RvcmUoKSwgW10pXG4gIGNvbnN0IHN0b3JlID0gZXh0ZXJuYWxTdG9yZSA/PyBpbnRlcm5hbFN0b3JlXG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBmbHVzaCA9ICgpID0+IHtcbiAgICAgIGNvbnN0IG1ldHJpY3MgPSBzdG9yZS5nZXRBbGwoKVxuICAgICAgaWYgKE9iamVjdC5rZXlzKG1ldHJpY3MpLmxlbmd0aCA+IDApIHtcbiAgICAgICAgc2F2ZUN1cnJlbnRQcm9qZWN0Q29uZmlnKGN1cnJlbnQgPT4gKHtcbiAgICAgICAgICAuLi5jdXJyZW50LFxuICAgICAgICAgIGxhc3RTZXNzaW9uTWV0cmljczogbWV0cmljcyxcbiAgICAgICAgfSkpXG4gICAgICB9XG4gICAgfVxuICAgIHByb2Nlc3Mub24oJ2V4aXQnLCBmbHVzaClcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgcHJvY2Vzcy5vZmYoJ2V4aXQnLCBmbHVzaClcbiAgICB9XG4gIH0sIFtzdG9yZV0pXG5cbiAgcmV0dXJuIDxTdGF0c0NvbnRleHQuUHJvdmlkZXIgdmFsdWU9e3N0b3JlfT57Y2hpbGRyZW59PC9TdGF0c0NvbnRleHQuUHJvdmlkZXI+XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VTdGF0cygpOiBTdGF0c1N0b3JlIHtcbiAgY29uc3Qgc3RvcmUgPSB1c2VDb250ZXh0KFN0YXRzQ29udGV4dClcbiAgaWYgKCFzdG9yZSkge1xuICAgIHRocm93IG5ldyBFcnJvcigndXNlU3RhdHMgbXVzdCBiZSB1c2VkIHdpdGhpbiBhIFN0YXRzUHJvdmlkZXInKVxuICB9XG4gIHJldHVybiBzdG9yZVxufVxuXG5leHBvcnQgZnVuY3Rpb24gdXNlQ291bnRlcihuYW1lOiBzdHJpbmcpOiAodmFsdWU/OiBudW1iZXIpID0+IHZvaWQge1xuICBjb25zdCBzdG9yZSA9IHVzZVN0YXRzKClcbiAgcmV0dXJuIHVzZUNhbGxiYWNrKFxuICAgICh2YWx1ZT86IG51bWJlcikgPT4gc3RvcmUuaW5jcmVtZW50KG5hbWUsIHZhbHVlKSxcbiAgICBbc3RvcmUsIG5hbWVdLFxuICApXG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VHYXVnZShuYW1lOiBzdHJpbmcpOiAodmFsdWU6IG51bWJlcikgPT4gdm9pZCB7XG4gIGNvbnN0IHN0b3JlID0gdXNlU3RhdHMoKVxuICByZXR1cm4gdXNlQ2FsbGJhY2soKHZhbHVlOiBudW1iZXIpID0+IHN0b3JlLnNldChuYW1lLCB2YWx1ZSksIFtzdG9yZSwgbmFtZV0pXG59XG5cbmV4cG9ydCBmdW5jdGlvbiB1c2VUaW1lcihuYW1lOiBzdHJpbmcpOiAodmFsdWU6IG51bWJlcikgPT4gdm9pZCB7XG4gIGNvbnN0IHN0b3JlID0gdXNlU3RhdHMoKVxuICByZXR1cm4gdXNlQ2FsbGJhY2soXG4gICAgKHZhbHVlOiBudW1iZXIpID0+IHN0b3JlLm9ic2VydmUobmFtZSwgdmFsdWUpLFxuICAgIFtzdG9yZSwgbmFtZV0sXG4gIClcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHVzZVNldChuYW1lOiBzdHJpbmcpOiAodmFsdWU6IHN0cmluZykgPT4gdm9pZCB7XG4gIGNvbnN0IHN0b3JlID0gdXNlU3RhdHMoKVxuICByZXR1cm4gdXNlQ2FsbGJhY2soKHZhbHVlOiBz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
@@ -0,0 +1,88 @@
1
+ import { c as _c } from "react/compiler-runtime";
2
+ import React, { createContext, useContext, useState, useSyncExternalStore } from 'react';
3
+ import { createStore, type Store } from '../state/store.js';
4
+ export type VoiceState = {
5
+ voiceState: 'idle' | 'recording' | 'processing';
6
+ voiceError: string | null;
7
+ voiceInterimTranscript: string;
8
+ voiceAudioLevels: number[];
9
+ voiceWarmingUp: boolean;
10
+ };
11
+ const DEFAULT_STATE: VoiceState = {
12
+ voiceState: 'idle',
13
+ voiceError: null,
14
+ voiceInterimTranscript: '',
15
+ voiceAudioLevels: [],
16
+ voiceWarmingUp: false
17
+ };
18
+ type VoiceStore = Store<VoiceState>;
19
+ const VoiceContext = createContext<VoiceStore | null>(null);
20
+ type Props = {
21
+ children: React.ReactNode;
22
+ };
23
+ export function VoiceProvider(t0) {
24
+ const $ = _c(3);
25
+ const {
26
+ children
27
+ } = t0;
28
+ const [store] = useState(_temp);
29
+ let t1;
30
+ if ($[0] !== children || $[1] !== store) {
31
+ t1 = <VoiceContext.Provider value={store}>{children}</VoiceContext.Provider>;
32
+ $[0] = children;
33
+ $[1] = store;
34
+ $[2] = t1;
35
+ } else {
36
+ t1 = $[2];
37
+ }
38
+ return t1;
39
+ }
40
+ function _temp() {
41
+ return createStore(DEFAULT_STATE);
42
+ }
43
+ function useVoiceStore() {
44
+ const store = useContext(VoiceContext);
45
+ if (!store) {
46
+ throw new Error("useVoiceState must be used within a VoiceProvider");
47
+ }
48
+ return store;
49
+ }
50
+
51
+ /**
52
+ * Subscribe to a slice of voice state. Only re-renders when the selected
53
+ * value changes (compared via Object.is).
54
+ */
55
+ export function useVoiceState(selector) {
56
+ const $ = _c(3);
57
+ const store = useVoiceStore();
58
+ let t0;
59
+ if ($[0] !== selector || $[1] !== store) {
60
+ t0 = () => selector(store.getState());
61
+ $[0] = selector;
62
+ $[1] = store;
63
+ $[2] = t0;
64
+ } else {
65
+ t0 = $[2];
66
+ }
67
+ const get = t0;
68
+ return useSyncExternalStore(store.subscribe, get, get);
69
+ }
70
+
71
+ /**
72
+ * Get the voice state setter. Stable reference — never causes re-renders.
73
+ * store.setState is synchronous: callers can read getVoiceState() immediately
74
+ * after to observe the new value (VoiceKeybindingHandler relies on this).
75
+ */
76
+ export function useSetVoiceState() {
77
+ return useVoiceStore().setState;
78
+ }
79
+
80
+ /**
81
+ * Get a synchronous reader for fresh state inside callbacks. Unlike
82
+ * useVoiceState (which subscribes), this doesn't cause re-renders — use
83
+ * inside event handlers that need to read state set earlier in the same tick.
84
+ */
85
+ export function useGetVoiceState() {
86
+ return useVoiceStore().getState;
87
+ }
88
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImNyZWF0ZUNvbnRleHQiLCJ1c2VDb250ZXh0IiwidXNlU3RhdGUiLCJ1c2VTeW5jRXh0ZXJuYWxTdG9yZSIsImNyZWF0ZVN0b3JlIiwiU3RvcmUiLCJWb2ljZVN0YXRlIiwidm9pY2VTdGF0ZSIsInZvaWNlRXJyb3IiLCJ2b2ljZUludGVyaW1UcmFuc2NyaXB0Iiwidm9pY2VBdWRpb0xldmVscyIsInZvaWNlV2FybWluZ1VwIiwiREVGQVVMVF9TVEFURSIsIlZvaWNlU3RvcmUiLCJWb2ljZUNvbnRleHQiLCJQcm9wcyIsImNoaWxkcmVuIiwiUmVhY3ROb2RlIiwiVm9pY2VQcm92aWRlciIsInQwIiwiJCIsIl9jIiwic3RvcmUiLCJfdGVtcCIsInQxIiwidXNlVm9pY2VTdG9yZSIsIkVycm9yIiwidXNlVm9pY2VTdGF0ZSIsInNlbGVjdG9yIiwiZ2V0U3RhdGUiLCJnZXQiLCJzdWJzY3JpYmUiLCJ1c2VTZXRWb2ljZVN0YXRlIiwic2V0U3RhdGUiLCJ1c2VHZXRWb2ljZVN0YXRlIl0sInNvdXJjZXMiOlsidm9pY2UudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwge1xuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VTdGF0ZSxcbiAgdXNlU3luY0V4dGVybmFsU3RvcmUsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgY3JlYXRlU3RvcmUsIHR5cGUgU3RvcmUgfSBmcm9tICcuLi9zdGF0ZS9zdG9yZS5qcydcblxuZXhwb3J0IHR5cGUgVm9pY2VTdGF0ZSA9IHtcbiAgdm9pY2VTdGF0ZTogJ2lkbGUnIHwgJ3JlY29yZGluZycgfCAncHJvY2Vzc2luZydcbiAgdm9pY2VFcnJvcjogc3RyaW5nIHwgbnVsbFxuICB2b2ljZUludGVyaW1UcmFuc2NyaXB0OiBzdHJpbmdcbiAgdm9pY2VBdWRpb0xldmVsczogbnVtYmVyW11cbiAgdm9pY2VXYXJtaW5nVXA6IGJvb2xlYW5cbn1cblxuY29uc3QgREVGQVVMVF9TVEFURTogVm9pY2VTdGF0ZSA9IHtcbiAgdm9pY2VTdGF0ZTogJ2lkbGUnLFxuICB2b2ljZUVycm9yOiBudWxsLFxuICB2b2ljZUludGVyaW1UcmFuc2NyaXB0OiAnJyxcbiAgdm9pY2VBdWRpb0xldmVsczogW10sXG4gIHZvaWNlV2FybWluZ1VwOiBmYWxzZSxcbn1cblxudHlwZSBWb2ljZVN0b3JlID0gU3RvcmU8Vm9pY2VTdGF0ZT5cblxuY29uc3QgVm9pY2VDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxWb2ljZVN0b3JlIHwgbnVsbD4obnVsbClcblxudHlwZSBQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZVxufVxuXG5leHBvcnQgZnVuY3Rpb24gVm9pY2VQcm92aWRlcih7IGNoaWxkcmVuIH06IFByb3BzKTogUmVhY3QuUmVhY3ROb2RlIHtcbiAgLy8gU3RvcmUgaXMgY3JlYXRlZCBvbmNlIOKAlCBzdGFibGUgY29udGV4dCB2YWx1ZSBtZWFucyB0aGUgcHJvdmlkZXIgbmV2ZXJcbiAgLy8gdHJpZ2dlcnMgcmUtcmVuZGVycy4gQ29uc3VtZXJzIHN1YnNjcmliZSB0byBzbGljZXMgdmlhIHVzZVZvaWNlU3RhdGUuXG4gIGNvbnN0IFtzdG9yZV0gPSB1c2VTdGF0ZSgoKSA9PiBjcmVhdGVTdG9yZTxWb2ljZVN0YXRlPihERUZBVUxUX1NUQVRFKSlcbiAgcmV0dXJuIDxWb2ljZUNvbnRleHQuUHJvdmlkZXIgdmFsdWU9e3N0b3JlfT57Y2hpbGRyZW59PC9Wb2ljZUNvbnRleHQuUHJvdmlkZXI+XG59XG5cbmZ1bmN0aW9uIHVzZVZvaWNlU3RvcmUoKTogVm9pY2VTdG9yZSB7XG4gIGNvbnN0IHN0b3JlID0gdXNlQ29udGV4dChWb2ljZUNvbnRleHQpXG4gIGlmICghc3RvcmUpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3VzZVZvaWNlU3RhdGUgbXVzdCBiZSB1c2VkIHdpdGhpbiBhIFZvaWNlUHJvdmlkZXInKVxuICB9XG4gIHJldHVybiBzdG9yZVxufVxuXG4vKipcbiAqIFN1YnNjcmliZSB0byBhIHNsaWNlIG9mIHZvaWNlIHN0YXRlLiBPbmx5IHJlLXJlbmRlcnMgd2hlbiB0aGUgc2VsZWN0ZWRcbiAqIHZhbHVlIGNoYW5nZXMgKGNvbXBhcmVkIHZpYSBPYmplY3QuaXMpLlxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlVm9pY2VTdGF0ZTxUPihzZWxlY3RvcjogKHN0YXRlOiBWb2ljZVN0YXRlKSA9PiBUKTogVCB7XG4gIGNvbnN0IHN0b3JlID0gdXNlVm9pY2VTdG9yZSgpXG4gIGNvbnN0IGdldCA9ICgpID0+IHNlbGVjdG9yKHN0b3JlLmdldFN0YXRlKCkpXG4gIHJldHVybiB1c2VTeW5jRXh0ZXJuYWxTdG9yZShzdG9yZS5zdWJzY3JpYmUsIGdldCwgZ2V0KVxufVxuXG4vKipcbiAqIEdldCB0aGUgdm9pY2Ugc3RhdGUgc2V0dGVyLiBTdGFibGUgcmVmZXJlbmNlIOKAlCBuZXZlciBjYXVzZXMgcmUtcmVuZGVycy5cbiAqIHN0b3JlLnNldFN0YXRlIGlzIHN5bmNocm9ub3VzOiBjYWxsZXJzIGNhbiByZWFkIGdldFZvaWNlU3RhdGUoKSBpbW1lZGlhdGVseVxuICogYWZ0ZXIgdG8gb2JzZXJ2ZSB0aGUgbmV3IHZhbHVlIChWb2ljZUtleWJpbmRpbmdIYW5kbGVyIHJlbGllcyBvbiB0aGlzKS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHVzZVNldFZvaWNlU3RhdGUoKTogKFxuICB1cGRhdGVyOiAocHJldjogVm9pY2VTdGF0ZSkgPT4gVm9pY2VTdGF0ZSxcbikgPT4gdm9pZCB7XG4gIHJldHVybiB1c2VWb2ljZVN0b3JlKCkuc2V0U3RhdGVcbn1cblxuLyoqXG4gKiBHZXQgYSBzeW5jaHJvbm91cyByZWFkZXIgZm9yIGZyZXNoIHN0YXRlIGluc2lkZSBjYWxsYmFja3MuIFVubGlrZVxuICogdXNlVm9pY2VTdGF0ZSAod2hpY2ggc3Vic2NyaWJlcyksIHRoaXMgZG9lc24ndCBjYXVzZSByZS1yZW5kZXJzIOKAlCB1c2VcbiAqIGluc2lkZSBldmVudCBoYW5kbGVycyB0aGF0IG5lZWQgdG8gcmVhZCBzdGF0ZSBzZXQgZWFybGllciBpbiB0aGUgc2FtZSB0aWNrLlxuICovXG5leHBvcnQgZnVuY3Rpb24gdXNlR2V0Vm9pY2VTdGF0ZSgpOiAoKSA9PiBWb2ljZVN0YXRlIHtcbiAgcmV0dXJuIHVzZVZvaWNlU3RvcmUoKS5nZXRTdGF0ZVxufVxuIl0sIm1hcHBpbmdzIjoiO0FBQUEsT0FBT0EsS0FBSyxJQUNWQyxhQUFhLEVBQ2JDLFVBQVUsRUFDVkMsUUFBUSxFQUNSQyxvQkFBb0IsUUFDZixPQUFPO0FBQ2QsU0FBU0MsV0FBVyxFQUFFLEtBQUtDLEtBQUssUUFBUSxtQkFBbUI7QUFFM0QsT0FBTyxLQUFLQyxVQUFVLEdBQUc7RUFDdkJDLFVBQVUsRUFBRSxNQUFNLEdBQUcsV0FBVyxHQUFHLFlBQVk7RUFDL0NDLFVBQVUsRUFBRSxNQUFNLEdBQUcsSUFBSTtFQUN6QkMsc0JBQXNCLEVBQUUsTUFBTTtFQUM5QkMsZ0JBQWdCLEVBQUUsTUFBTSxFQUFFO0VBQzFCQyxjQUFjLEVBQUUsT0FBTztBQUN6QixDQUFDO0FBRUQsTUFBTUMsYUFBYSxFQUFFTixVQUFVLEdBQUc7RUFDaENDLFVBQVUsRUFBRSxNQUFNO0VBQ2xCQyxVQUFVLEVBQUUsSUFBSTtFQUNoQkMsc0JBQXNCLEVBQUUsRUFBRTtFQUMxQkMsZ0JBQWdCLEVBQUUsRUFBRTtFQUNwQkMsY0FBYyxFQUFFO0FBQ2xCLENBQUM7QUFFRCxLQUFLRSxVQUFVLEdBQUdSLEtBQUssQ0FBQ0MsVUFBVSxDQUFDO0FBRW5DLE1BQU1RLFlBQVksR0FBR2QsYUFBYSxDQUFDYSxVQUFVLEdBQUcsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDO0FBRTNELEtBQUtFLEtBQUssR0FBRztFQUNYQyxRQUFRLEVBQUVqQixLQUFLLENBQUNrQixTQUFTO0FBQzNCLENBQUM7QUFFRCxPQUFPLFNBQUFDLGNBQUFDLEVBQUE7RUFBQSxNQUFBQyxDQUFBLEdBQUFDLEVBQUE7RUFBdUI7SUFBQUw7RUFBQSxJQUFBRyxFQUFtQjtFQUcvQyxPQUFBRyxLQUFBLElBQWdCcEIsUUFBUSxDQUFDcUIsS0FBNEMsQ0FBQztFQUFBLElBQUFDLEVBQUE7RUFBQSxJQUFBSixDQUFBLFFBQUFKLFFBQUEsSUFBQUksQ0FBQSxRQUFBRSxLQUFBO0lBQy9ERSxFQUFBLDBCQUE4QkYsS0FBSyxDQUFMQSxNQUFJLENBQUMsQ0FBR04sU0FBTyxDQUFFLHdCQUF3QjtJQUFBSSxDQUFBLE1BQUFKLFFBQUE7SUFBQUksQ0FBQSxNQUFBRSxLQUFBO0lBQUFGLENBQUEsTUFBQUksRUFBQTtFQUFBO0lBQUFBLEVBQUEsR0FBQUosQ0FBQTtFQUFBO0VBQUEsT0FBdkVJLEVBQXVFO0FBQUE7QUFKekUsU0FBQUQsTUFBQTtFQUFBLE9BRzBCbkIsV0FBVyxDQUFhUSxhQUFhLENBQUM7QUFBQTtBQUl2RSxTQUFBYSxjQUFBO0VBQ0UsTUFBQUgsS0FBQSxHQUFjckIsVUFBVSxDQUFDYSxZQUFZLENBQUM7RUFDdEMsSUFBSSxDQUFDUSxLQUFLO0lBQ1IsTUFBTSxJQUFJSSxLQUFLLENBQUMsbURBQW1ELENBQUM7RUFBQTtFQUNyRSxPQUNNSixLQUFLO0FBQUE7O0FBR2Q7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQUFLLGNBQUFDLFFBQUE7RUFBQSxNQUFBUixDQUFBLEdBQUFDLEVBQUE7RUFDTCxNQUFBQyxLQUFBLEdBQWNHLGFBQWEsQ0FBQyxDQUFDO0VBQUEsSUFBQU4sRUFBQTtFQUFBLElBQUFDLENBQUEsUUFBQVEsUUFBQSxJQUFBUixDQUFBLFFBQUFFLEtBQUE7SUFDakJILEVBQUEsR0FBQUEsQ0FBQSxLQUFNUyxRQUFRLENBQUNOLEtBQUssQ0FBQU8sUUFBUyxDQUFDLENBQUMsQ0FBQztJQUFBVCxDQUFBLE1BQUFRLFFBQUE7SUFBQVIsQ0FBQSxNQUFBRSxLQUFBO0lBQUFGLENBQUEsTUFBQUQsRUFBQTtFQUFBO0lBQUFBLEVBQUEsR0FBQUMsQ0FBQTtFQUFBO0VBQTVDLE1BQUFVLEdBQUEsR0FBWVgsRUFBZ0M7RUFBQSxPQUNyQ2hCLG9CQUFvQixDQUFDbUIsS0FBSyxDQUFBUyxTQUFVLEVBQUVELEdBQUcsRUFBRUEsR0FBRyxDQUFDO0FBQUE7O0FBR3hEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQUFFLGlCQUFBO0VBQUEsT0FHRVAsYUFBYSxDQUFDLENBQUMsQ0FBQVEsUUFBUztBQUFBOztBQUdqQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTyxTQUFBQyxpQkFBQTtFQUFBLE9BQ0VULGFBQWEsQ0FBQyxDQUFDLENBQUFJLFFBQVM7QUFBQSIsImlnbm9yZUxpc3QiOltdfQ==