@nex-ai/nex 0.1.25 → 0.1.26
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/README.md +8 -13
- package/dist/cli.d.ts +2 -1
- package/dist/commands/dispatch.js +18 -2
- package/dist/commands/dispatch.js.map +1 -1
- package/dist/commands/graph.d.ts +1 -0
- package/dist/commands/graph.js +7 -12
- package/dist/commands/graph.js.map +1 -1
- package/dist/index.d.ts +6 -23
- package/dist/index.js +41 -57
- package/dist/index.js.map +1 -1
- package/dist/lib/client.d.ts +1 -0
- package/dist/lib/client.js +33 -0
- package/dist/lib/client.js.map +1 -1
- package/dist/lib/config.d.ts +1 -1
- package/dist/lib/config.js +1 -1
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/file-scanner.js +45 -37
- package/dist/lib/file-scanner.js.map +1 -1
- package/dist/plugin/config.js +20 -4
- package/dist/plugin/config.js.map +1 -1
- package/dist/plugin/shared.js +2 -2
- package/dist/tui/app.d.ts +1 -2
- package/dist/tui/app.js +4 -26
- package/dist/tui/app.js.map +1 -1
- package/dist/tui/components/agent-card.js +2 -27
- package/dist/tui/components/agent-card.js.map +1 -1
- package/dist/tui/components/banner.js +6 -15
- package/dist/tui/components/banner.js.map +1 -1
- package/dist/tui/components/channel-message.js +11 -61
- package/dist/tui/components/channel-message.js.map +1 -1
- package/dist/tui/components/chat-input.js +3 -7
- package/dist/tui/components/chat-input.js.map +1 -1
- package/dist/tui/components/data-table.js +15 -37
- package/dist/tui/components/data-table.js.map +1 -1
- package/dist/tui/components/error-box.js +2 -21
- package/dist/tui/components/error-box.js.map +1 -1
- package/dist/tui/components/help-screen.js +2 -31
- package/dist/tui/components/help-screen.js.map +1 -1
- package/dist/tui/components/inline-confirm.js +2 -21
- package/dist/tui/components/inline-confirm.js.map +1 -1
- package/dist/tui/components/inline-select.js +2 -22
- package/dist/tui/components/inline-select.js.map +1 -1
- package/dist/tui/components/markdown.js +21 -59
- package/dist/tui/components/markdown.js.map +1 -1
- package/dist/tui/components/mention-autocomplete.js +14 -22
- package/dist/tui/components/mention-autocomplete.js.map +1 -1
- package/dist/tui/components/message-list.js +6 -19
- package/dist/tui/components/message-list.js.map +1 -1
- package/dist/tui/components/picker.js +9 -23
- package/dist/tui/components/picker.js.map +1 -1
- package/dist/tui/components/progress-steps.js +5 -12
- package/dist/tui/components/progress-steps.js.map +1 -1
- package/dist/tui/components/slack/compose.js +10 -34
- package/dist/tui/components/slack/compose.js.map +1 -1
- package/dist/tui/components/slack/layout.js +3 -37
- package/dist/tui/components/slack/layout.js.map +1 -1
- package/dist/tui/components/slack/messages.js +20 -73
- package/dist/tui/components/slack/messages.js.map +1 -1
- package/dist/tui/components/slack/quick-switcher.js +5 -42
- package/dist/tui/components/slack/quick-switcher.js.map +1 -1
- package/dist/tui/components/slack/sidebar.js +12 -57
- package/dist/tui/components/slack/sidebar.js.map +1 -1
- package/dist/tui/components/slack/thread-panel.js +7 -76
- package/dist/tui/components/slack/thread-panel.js.map +1 -1
- package/dist/tui/components/slash-autocomplete.js +13 -22
- package/dist/tui/components/slash-autocomplete.js.map +1 -1
- package/dist/tui/components/spinner.js +4 -6
- package/dist/tui/components/spinner.js.map +1 -1
- package/dist/tui/components/status-bar.js +4 -66
- package/dist/tui/components/status-bar.js.map +1 -1
- package/dist/tui/components/success-box.js +2 -13
- package/dist/tui/components/success-box.js.map +1 -1
- package/dist/tui/components/tool-indicator.js +4 -14
- package/dist/tui/components/tool-indicator.js.map +1 -1
- package/dist/tui/components/viewport.js +3 -11
- package/dist/tui/components/viewport.js.map +1 -1
- package/dist/tui/generative/renderer.js +25 -71
- package/dist/tui/generative/renderer.js.map +1 -1
- package/dist/tui/index.js +2 -5
- package/dist/tui/index.js.map +1 -1
- package/dist/tui/register-views.js +12 -11
- package/dist/tui/register-views.js.map +1 -1
- package/dist/tui/router.d.ts +1 -1
- package/dist/tui/router.js +10 -31
- package/dist/tui/router.js.map +1 -1
- package/dist/tui/theme.d.ts +1 -2
- package/dist/tui/theme.js +3 -4
- package/dist/tui/theme.js.map +1 -1
- package/dist/tui/views/agent-list.js +2 -21
- package/dist/tui/views/agent-list.js.map +1 -1
- package/dist/tui/views/ask-chat.js +3 -30
- package/dist/tui/views/ask-chat.js.map +1 -1
- package/dist/tui/views/calendar.js +5 -49
- package/dist/tui/views/calendar.js.map +1 -1
- package/dist/tui/views/chat.js +7 -45
- package/dist/tui/views/chat.js.map +1 -1
- package/dist/tui/views/generative.js +5 -49
- package/dist/tui/views/generative.js.map +1 -1
- package/dist/tui/views/help.js +2 -12
- package/dist/tui/views/help.js.map +1 -1
- package/dist/tui/views/home-screen.js +25 -140
- package/dist/tui/views/home-screen.js.map +1 -1
- package/dist/tui/views/home.js +8 -56
- package/dist/tui/views/home.js.map +1 -1
- package/dist/tui/views/insights.js +7 -49
- package/dist/tui/views/insights.js.map +1 -1
- package/dist/tui/views/orchestration.js +7 -63
- package/dist/tui/views/orchestration.js.map +1 -1
- package/dist/tui/views/record-detail.js +3 -28
- package/dist/tui/views/record-detail.js.map +1 -1
- package/dist/tui/views/record-list.js +3 -26
- package/dist/tui/views/record-list.js.map +1 -1
- package/dist/tui/views/slack-channel-header.js +4 -23
- package/dist/tui/views/slack-channel-header.js.map +1 -1
- package/dist/tui/views/slack-home.js +3 -14
- package/dist/tui/views/slack-home.js.map +1 -1
- package/dist/tui/views/task-board.js +5 -46
- package/dist/tui/views/task-board.js.map +1 -1
- package/dist/tui/views/timeline.js +9 -52
- package/dist/tui/views/timeline.js.map +1 -1
- package/package.json +14 -10
|
@@ -1,14 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
* SlackLayout — root 3-panel responsive layout.
|
|
3
|
-
*
|
|
4
|
-
* Arranges sidebar + main panel + optional thread panel side by side.
|
|
5
|
-
* Responsive breakpoints:
|
|
6
|
-
* < 60 cols: main only (no sidebar)
|
|
7
|
-
* 60–79 cols: narrow sidebar (20) + main
|
|
8
|
-
* 80–119 cols: sidebar (24) + main; thread replaces main if open
|
|
9
|
-
* ≥ 120 cols: sidebar (28) + main + thread (45)
|
|
10
|
-
*/
|
|
11
|
-
import React from "react";
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
12
2
|
import { Box, Text } from "ink";
|
|
13
3
|
export function computeLayout(cols, threadOpen) {
|
|
14
4
|
const SIDEBAR_WIDE = 28;
|
|
@@ -96,35 +86,11 @@ export function computeLayout(cols, threadOpen) {
|
|
|
96
86
|
function FocusBadge({ label, visible }) {
|
|
97
87
|
if (!visible)
|
|
98
88
|
return null;
|
|
99
|
-
return (
|
|
100
|
-
<Text color="black" backgroundColor="cyan" bold>{` ${label} `}</Text>
|
|
101
|
-
</Box>);
|
|
89
|
+
return (_jsx(Box, { children: _jsx(Text, { color: "black", backgroundColor: "cyan", bold: true, children: ` ${label} ` }) }));
|
|
102
90
|
}
|
|
103
91
|
export function SlackLayout({ cols, rows, threadOpen, focusSection, sidebar, main, thread, overlay, }) {
|
|
104
92
|
const layout = computeLayout(cols, threadOpen);
|
|
105
|
-
return (
|
|
106
|
-
<Box flexDirection="row" flexGrow={1}>
|
|
107
|
-
{/* Sidebar */}
|
|
108
|
-
{layout.showSidebar && (<Box width={layout.sidebarWidth} flexDirection="column" flexShrink={0} borderStyle="single" borderLeft={false} borderTop={false} borderBottom={false} borderRight={true} borderColor={focusSection === "sidebar" ? "cyan" : "gray"}>
|
|
109
|
-
<FocusBadge label="SIDEBAR" visible={focusSection === "sidebar"}/>
|
|
110
|
-
{sidebar}
|
|
111
|
-
</Box>)}
|
|
112
|
-
|
|
113
|
-
{/* Main panel */}
|
|
114
|
-
{layout.mainWidth > 0 && !layout.threadReplacesMain && (<Box width={layout.mainWidth} flexDirection="column" flexGrow={1}>
|
|
115
|
-
{main}
|
|
116
|
-
</Box>)}
|
|
117
|
-
|
|
118
|
-
{/* Thread panel */}
|
|
119
|
-
{layout.showThread && thread && (<Box width={layout.threadWidth} flexDirection="column" flexShrink={0} borderStyle="single" borderRight={false} borderTop={false} borderBottom={false} borderLeft={true} borderColor={focusSection === "thread" ? "cyan" : "gray"}>
|
|
120
|
-
<FocusBadge label="THREAD" visible={focusSection === "thread"}/>
|
|
121
|
-
{thread}
|
|
122
|
-
</Box>)}
|
|
123
|
-
</Box>
|
|
124
|
-
|
|
125
|
-
{/* Overlay (quick switcher, modals) */}
|
|
126
|
-
{overlay}
|
|
127
|
-
</Box>);
|
|
93
|
+
return (_jsxs(Box, { flexDirection: "column", width: cols, height: rows, children: [_jsxs(Box, { flexDirection: "row", flexGrow: 1, children: [layout.showSidebar && (_jsxs(Box, { width: layout.sidebarWidth, flexDirection: "column", flexShrink: 0, borderStyle: "single", borderLeft: false, borderTop: false, borderBottom: false, borderRight: true, borderColor: focusSection === "sidebar" ? "cyan" : "gray", children: [_jsx(FocusBadge, { label: "SIDEBAR", visible: focusSection === "sidebar" }), sidebar] })), layout.mainWidth > 0 && !layout.threadReplacesMain && (_jsx(Box, { width: layout.mainWidth, flexDirection: "column", flexGrow: 1, children: main })), layout.showThread && thread && (_jsxs(Box, { width: layout.threadWidth, flexDirection: "column", flexShrink: 0, borderStyle: "single", borderRight: false, borderTop: false, borderBottom: false, borderLeft: true, borderColor: focusSection === "thread" ? "cyan" : "gray", children: [_jsx(FocusBadge, { label: "THREAD", visible: focusSection === "thread" }), thread] }))] }), overlay] }));
|
|
128
94
|
}
|
|
129
95
|
export default SlackLayout;
|
|
130
96
|
//# sourceMappingURL=layout.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"layout.js","sourceRoot":"","sources":["../../../../src/tui/components/slack/layout.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"layout.js","sourceRoot":"","sources":["../../../../src/tui/components/slack/layout.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
1
2
|
/**
|
|
2
3
|
* Slack-style message rendering components.
|
|
3
4
|
*
|
|
4
5
|
* Includes message grouping logic, date separators, unread markers,
|
|
5
6
|
* thread indicators, system messages, and the scrollable message list.
|
|
6
7
|
*/
|
|
7
|
-
import
|
|
8
|
+
import { useMemo } from "react";
|
|
8
9
|
import { Box, Text } from "ink";
|
|
9
10
|
import { getAgentColor } from "../../agent-colors.js";
|
|
10
11
|
import { Markdown } from "../markdown.js";
|
|
@@ -115,9 +116,7 @@ export function DateSeparator({ label, width = 60, }) {
|
|
|
115
116
|
const left = Math.floor(remaining / 2);
|
|
116
117
|
const right = remaining - left;
|
|
117
118
|
const line = "─".repeat(left) + labelWithPad + "─".repeat(right);
|
|
118
|
-
return (
|
|
119
|
-
<Text color="gray">{line}</Text>
|
|
120
|
-
</Box>);
|
|
119
|
+
return (_jsx(Box, { justifyContent: "center", marginY: 0, children: _jsx(Text, { color: "gray", children: line }) }));
|
|
121
120
|
}
|
|
122
121
|
export function UnreadSeparator({ width = 60, }) {
|
|
123
122
|
const labelWithPad = " New ";
|
|
@@ -125,106 +124,54 @@ export function UnreadSeparator({ width = 60, }) {
|
|
|
125
124
|
const left = Math.floor(remaining / 2);
|
|
126
125
|
const right = remaining - left;
|
|
127
126
|
const line = "─".repeat(left) + labelWithPad + "─".repeat(right);
|
|
128
|
-
return (
|
|
129
|
-
<Text color="red" bold>
|
|
130
|
-
{line}
|
|
131
|
-
</Text>
|
|
132
|
-
</Box>);
|
|
127
|
+
return (_jsx(Box, { justifyContent: "center", marginY: 0, children: _jsx(Text, { color: "red", bold: true, children: line }) }));
|
|
133
128
|
}
|
|
134
129
|
export function SystemMessage({ content, timestamp, }) {
|
|
135
|
-
return (
|
|
136
|
-
<Text color="gray" dimColor italic>
|
|
137
|
-
{"✦ "}
|
|
138
|
-
{content}
|
|
139
|
-
</Text>
|
|
140
|
-
</Box>);
|
|
130
|
+
return (_jsx(Box, { justifyContent: "center", paddingX: 4, children: _jsxs(Text, { color: "gray", dimColor: true, italic: true, children: ["✦ ", content] }) }));
|
|
141
131
|
}
|
|
142
132
|
export function ThreadIndicator({ replyCount, lastReplyTimestamp, onClick, }) {
|
|
143
133
|
const replyText = replyCount === 1 ? "1 reply" : `${replyCount} replies`;
|
|
144
134
|
const lastReply = `Last reply ${formatTimeWithDate(lastReplyTimestamp)}`;
|
|
145
|
-
return (
|
|
146
|
-
<Text color="cyan">
|
|
147
|
-
{"↳ "}
|
|
148
|
-
{replyText}
|
|
149
|
-
{" "}
|
|
150
|
-
{lastReply}
|
|
151
|
-
</Text>
|
|
152
|
-
</Box>);
|
|
135
|
+
return (_jsx(Box, { paddingLeft: 6, children: _jsxs(Text, { color: "cyan", children: ["↳ ", replyText, " ", lastReply] }) }));
|
|
153
136
|
}
|
|
154
137
|
function FirstMessage({ message, onThreadOpen, }) {
|
|
155
138
|
const isHuman = message.senderType === "human";
|
|
156
139
|
const avatarChar = isHuman ? ">" : message.initials.charAt(0) || "?";
|
|
157
140
|
const nameColor = isHuman ? "white" : getAgentColor(message.sender);
|
|
158
141
|
const time = formatTimeWithDate(message.timestamp);
|
|
159
|
-
return (
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
{"["}
|
|
163
|
-
{avatarChar}
|
|
164
|
-
{"] "}
|
|
165
|
-
</Text>
|
|
166
|
-
<Text color={nameColor} bold>
|
|
167
|
-
{message.sender}
|
|
168
|
-
</Text>
|
|
169
|
-
<Text color="gray" dimColor>
|
|
170
|
-
{" "}
|
|
171
|
-
{time}
|
|
172
|
-
</Text>
|
|
173
|
-
</Box>
|
|
174
|
-
<Box paddingLeft={4}>
|
|
175
|
-
<Markdown content={message.content}/>
|
|
176
|
-
</Box>
|
|
177
|
-
{message.edited && (<Box paddingLeft={4}>
|
|
178
|
-
<Text color="gray" dimColor>
|
|
179
|
-
(edited)
|
|
180
|
-
</Text>
|
|
181
|
-
</Box>)}
|
|
182
|
-
{message.threadReplyCount != null &&
|
|
183
|
-
message.threadReplyCount > 0 &&
|
|
184
|
-
message.threadLastReply != null && (<ThreadIndicator replyCount={message.threadReplyCount} lastReplyTimestamp={message.threadLastReply} onClick={onThreadOpen ? () => onThreadOpen(message.id) : undefined}/>)}
|
|
185
|
-
</Box>);
|
|
142
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsxs(Box, { children: [_jsxs(Text, { color: nameColor, bold: true, children: ["[", avatarChar, "] "] }), _jsx(Text, { color: nameColor, bold: true, children: message.sender }), _jsxs(Text, { color: "gray", dimColor: true, children: [" ", time] })] }), _jsx(Box, { paddingLeft: 4, children: _jsx(Markdown, { content: message.content }) }), message.edited && (_jsx(Box, { paddingLeft: 4, children: _jsx(Text, { color: "gray", dimColor: true, children: "(edited)" }) })), message.threadReplyCount != null &&
|
|
143
|
+
message.threadReplyCount > 0 &&
|
|
144
|
+
message.threadLastReply != null && (_jsx(ThreadIndicator, { replyCount: message.threadReplyCount, lastReplyTimestamp: message.threadLastReply, onClick: onThreadOpen ? () => onThreadOpen(message.id) : undefined }))] }));
|
|
186
145
|
}
|
|
187
146
|
function ContinuationMessage({ message, onThreadOpen, }) {
|
|
188
|
-
return (
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
</Box>
|
|
192
|
-
{message.edited && (<Box paddingLeft={4}>
|
|
193
|
-
<Text color="gray" dimColor>
|
|
194
|
-
(edited)
|
|
195
|
-
</Text>
|
|
196
|
-
</Box>)}
|
|
197
|
-
{message.threadReplyCount != null &&
|
|
198
|
-
message.threadReplyCount > 0 &&
|
|
199
|
-
message.threadLastReply != null && (<ThreadIndicator replyCount={message.threadReplyCount} lastReplyTimestamp={message.threadLastReply} onClick={onThreadOpen ? () => onThreadOpen(message.id) : undefined}/>)}
|
|
200
|
-
</Box>);
|
|
147
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { paddingLeft: 4, children: _jsx(Markdown, { content: message.content }) }), message.edited && (_jsx(Box, { paddingLeft: 4, children: _jsx(Text, { color: "gray", dimColor: true, children: "(edited)" }) })), message.threadReplyCount != null &&
|
|
148
|
+
message.threadReplyCount > 0 &&
|
|
149
|
+
message.threadLastReply != null && (_jsx(ThreadIndicator, { replyCount: message.threadReplyCount, lastReplyTimestamp: message.threadLastReply, onClick: onThreadOpen ? () => onThreadOpen(message.id) : undefined }))] }));
|
|
201
150
|
}
|
|
202
151
|
export function SlackMessageList({ messages, unreadAfterTimestamp, onThreadOpen, width = 60, }) {
|
|
203
152
|
const grouped = useMemo(() => groupMessages(messages, unreadAfterTimestamp), [messages, unreadAfterTimestamp]);
|
|
204
|
-
return (
|
|
205
|
-
{grouped.map((msg) => {
|
|
153
|
+
return (_jsx(Box, { flexDirection: "column", flexGrow: 1, children: grouped.map((msg) => {
|
|
206
154
|
const elements = [];
|
|
207
155
|
// Date separator before this message
|
|
208
156
|
if (msg.dateSeparator) {
|
|
209
|
-
elements.push(
|
|
157
|
+
elements.push(_jsx(DateSeparator, { label: msg.dateSeparator, width: width }, `date-${msg.id}`));
|
|
210
158
|
}
|
|
211
159
|
// Unread marker before this message
|
|
212
160
|
if (msg.isUnreadMarker) {
|
|
213
|
-
elements.push(
|
|
161
|
+
elements.push(_jsx(UnreadSeparator, { width: width }, `unread-${msg.id}`));
|
|
214
162
|
}
|
|
215
163
|
// The message itself
|
|
216
164
|
if (msg.isSystem) {
|
|
217
|
-
elements.push(
|
|
165
|
+
elements.push(_jsx(SystemMessage, { content: msg.content, timestamp: msg.timestamp }, msg.id));
|
|
218
166
|
}
|
|
219
167
|
else if (msg.isFirstInGroup) {
|
|
220
|
-
elements.push(
|
|
168
|
+
elements.push(_jsx(FirstMessage, { message: msg, onThreadOpen: onThreadOpen }, msg.id));
|
|
221
169
|
}
|
|
222
170
|
else {
|
|
223
|
-
elements.push(
|
|
171
|
+
elements.push(_jsx(ContinuationMessage, { message: msg, onThreadOpen: onThreadOpen }, msg.id));
|
|
224
172
|
}
|
|
225
|
-
return
|
|
226
|
-
})}
|
|
227
|
-
</Box>);
|
|
173
|
+
return _jsx(Box, { flexDirection: "column", children: elements }, `row-${msg.id}`);
|
|
174
|
+
}) }));
|
|
228
175
|
}
|
|
229
176
|
export default SlackMessageList;
|
|
230
177
|
//# sourceMappingURL=messages.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../../src/tui/components/slack/messages.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,
|
|
1
|
+
{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../../src/tui/components/slack/messages.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
1
2
|
/**
|
|
2
3
|
* Quick Switcher (Ctrl+K) modal overlay.
|
|
3
4
|
*
|
|
@@ -39,23 +40,14 @@ export function filterItems(query, items) {
|
|
|
39
40
|
function SwitcherItem({ item, isSelected, }) {
|
|
40
41
|
let prefix;
|
|
41
42
|
if (item.type === "channel") {
|
|
42
|
-
prefix =
|
|
43
|
+
prefix = _jsx(Text, { color: "gray", children: "# " });
|
|
43
44
|
}
|
|
44
45
|
else {
|
|
45
46
|
const dotColor = item.online ? "green" : "gray";
|
|
46
47
|
const dot = item.online ? "●" : "○";
|
|
47
|
-
prefix =
|
|
48
|
+
prefix = _jsxs(Text, { color: dotColor, children: [dot, " "] });
|
|
48
49
|
}
|
|
49
|
-
return (
|
|
50
|
-
<Text color={isSelected ? "cyan" : undefined} bold={isSelected}>
|
|
51
|
-
{isSelected ? "> " : " "}
|
|
52
|
-
</Text>
|
|
53
|
-
{prefix}
|
|
54
|
-
<Text color={isSelected ? "cyan" : "white"} bold={isSelected}>
|
|
55
|
-
{item.name}
|
|
56
|
-
</Text>
|
|
57
|
-
{item.unread > 0 && <Text color="gray"> ({item.unread})</Text>}
|
|
58
|
-
</Box>);
|
|
50
|
+
return (_jsxs(Box, { children: [_jsx(Text, { color: isSelected ? "cyan" : undefined, bold: isSelected, children: isSelected ? "> " : " " }), prefix, _jsx(Text, { color: isSelected ? "cyan" : "white", bold: isSelected, children: item.name }), item.unread > 0 && _jsxs(Text, { color: "gray", children: [" (", item.unread, ")"] })] }));
|
|
59
51
|
}
|
|
60
52
|
// ── QuickSwitcher ───────────────────────────────────────────────────
|
|
61
53
|
export function QuickSwitcher({ open, items, onSelect, onClose, }) {
|
|
@@ -100,36 +92,7 @@ export function QuickSwitcher({ open, items, onSelect, onClose, }) {
|
|
|
100
92
|
}, [open]);
|
|
101
93
|
if (!open)
|
|
102
94
|
return null;
|
|
103
|
-
return (
|
|
104
|
-
{/* Header */}
|
|
105
|
-
<Box>
|
|
106
|
-
<Text bold color="cyan">Switch to...</Text>
|
|
107
|
-
</Box>
|
|
108
|
-
|
|
109
|
-
{/* Search input */}
|
|
110
|
-
<Box>
|
|
111
|
-
<Text color="gray">🔍 </Text>
|
|
112
|
-
<TextInput placeholder="Search channels and DMs" onChange={handleChange} onSubmit={handleSubmit}/>
|
|
113
|
-
</Box>
|
|
114
|
-
|
|
115
|
-
{/* Divider */}
|
|
116
|
-
<Box>
|
|
117
|
-
<Text color="gray">{"─".repeat(40)}</Text>
|
|
118
|
-
</Box>
|
|
119
|
-
|
|
120
|
-
{/* Results */}
|
|
121
|
-
<Box flexDirection="column">
|
|
122
|
-
{visibleItems.length === 0 && (<Box paddingX={1}>
|
|
123
|
-
<Text color="gray">No matches found</Text>
|
|
124
|
-
</Box>)}
|
|
125
|
-
{visibleItems.map((item, idx) => (<SwitcherItem key={item.id} item={item} isSelected={idx === selectedIndex}/>))}
|
|
126
|
-
</Box>
|
|
127
|
-
|
|
128
|
-
{/* Footer hint */}
|
|
129
|
-
<Box>
|
|
130
|
-
<Text color="gray">↑↓ navigate · Enter select · Esc close</Text>
|
|
131
|
-
</Box>
|
|
132
|
-
</Box>);
|
|
95
|
+
return (_jsxs(Box, { flexDirection: "column", borderStyle: "double", borderColor: "cyan", paddingX: 1, children: [_jsx(Box, { children: _jsx(Text, { bold: true, color: "cyan", children: "Switch to..." }) }), _jsxs(Box, { children: [_jsx(Text, { color: "gray", children: "\uD83D\uDD0D " }), _jsx(TextInput, { placeholder: "Search channels and DMs", onChange: handleChange, onSubmit: handleSubmit })] }), _jsx(Box, { children: _jsx(Text, { color: "gray", children: "─".repeat(40) }) }), _jsxs(Box, { flexDirection: "column", children: [visibleItems.length === 0 && (_jsx(Box, { paddingX: 1, children: _jsx(Text, { color: "gray", children: "No matches found" }) })), visibleItems.map((item, idx) => (_jsx(SwitcherItem, { item: item, isSelected: idx === selectedIndex }, item.id)))] }), _jsx(Box, { children: _jsx(Text, { color: "gray", children: "\u2191\u2193 navigate \u00B7 Enter select \u00B7 Esc close" }) })] }));
|
|
133
96
|
}
|
|
134
97
|
export default QuickSwitcher;
|
|
135
98
|
//# sourceMappingURL=quick-switcher.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"quick-switcher.js","sourceRoot":"","sources":["../../../../src/tui/components/slack/quick-switcher.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACzE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAqBtC,uEAAuE;AAEvE;;;GAGG;AACH,MAAM,UAAU,UAAU,CAAC,KAAa,EAAE,IAAY;IACpD,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IACxB,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;IAC9B,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IAE7B,mBAAmB;IACnB,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAAE,OAAO,IAAI,CAAC;IAE/B,4DAA4D;IAC5D,MAAM,MAAM,GAAG,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IACnC,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACxD,IAAI,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;QAAE,OAAO,IAAI,CAAC;IAEtC,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,WAAW,CACzB,KAAa,EACb,KAA0B;IAE1B,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACrE,sCAAsC;IACtC,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;AACnD,CAAC;AAED,uEAAuE;AAEvE,SAAS,YAAY,CAAC,EACpB,IAAI,EACJ,UAAU,GAIX;IACC,IAAI,MAAyB,CAAC;IAC9B,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC5B,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"quick-switcher.js","sourceRoot":"","sources":["../../../../src/tui/components/slack/quick-switcher.tsx"],"names":[],"mappings":";AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACzE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAqBtC,uEAAuE;AAEvE;;;GAGG;AACH,MAAM,UAAU,UAAU,CAAC,KAAa,EAAE,IAAY;IACpD,IAAI,CAAC,KAAK;QAAE,OAAO,IAAI,CAAC;IACxB,MAAM,CAAC,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;IAC9B,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IAE7B,mBAAmB;IACnB,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAAE,OAAO,IAAI,CAAC;IAE/B,4DAA4D;IAC5D,MAAM,MAAM,GAAG,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IACnC,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACxD,IAAI,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;QAAE,OAAO,IAAI,CAAC;IAEtC,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,WAAW,CACzB,KAAa,EACb,KAA0B;IAE1B,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACrE,sCAAsC;IACtC,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;AACnD,CAAC;AAED,uEAAuE;AAEvE,SAAS,YAAY,CAAC,EACpB,IAAI,EACJ,UAAU,GAIX;IACC,IAAI,MAAyB,CAAC;IAC9B,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC5B,MAAM,GAAG,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,mBAAU,CAAC;IACxC,CAAC;SAAM,CAAC;QACN,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;QAChD,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QACpC,MAAM,GAAG,MAAC,IAAI,IAAC,KAAK,EAAE,QAAQ,aAAG,GAAG,SAAS,CAAC;IAChD,CAAC;IAED,OAAO,CACL,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,EAAE,UAAU,YAC3D,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,GACpB,EACN,MAAM,EACP,KAAC,IAAI,IAAC,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,UAAU,YACzD,IAAI,CAAC,IAAI,GACL,EACN,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,mBAAI,IAAI,CAAC,MAAM,SAAS,IAC1D,CACP,CAAC;AACJ,CAAC;AAED,uEAAuE;AAEvE,MAAM,UAAU,aAAa,CAAC,EAC5B,IAAI,EACJ,KAAK,EACL,QAAQ,EACR,OAAO,GACY;IACnB,mEAAmE;IACnE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvC,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAEtD,MAAM,UAAU,GAAG,EAAE,CAAC;IACtB,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;IAC1E,MAAM,YAAY,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;IAEnD,kCAAkC;IAClC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,IAAI,EAAE,CAAC;YACT,QAAQ,CAAC,EAAE,CAAC,CAAC;YACb,gBAAgB,CAAC,CAAC,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAEX,MAAM,YAAY,GAAG,WAAW,CAAC,CAAC,QAAgB,EAAE,EAAE;QACpD,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACnB,gBAAgB,CAAC,CAAC,CAAC,CAAC;IACtB,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,YAAY,GAAG,WAAW,CAAC,GAAG,EAAE;QACpC,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,aAAa,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC;YAC3D,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,CAAC;QACvC,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC,CAAC;IAExC,mEAAmE;IACnE,MAAM,iBAAiB,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACxD,iBAAiB,CAAC,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC;IAC5C,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,IAAI;YAAE,OAAO;QAClB,MAAM,CAAC,GAAG,UAAqC,CAAC;QAChD,CAAC,CAAC,qBAAqB,GAAG,CAAC,SAAiB,EAAE,EAAE;YAC9C,gBAAgB,CAAC,CAAC,IAAI,EAAE,EAAE;gBACxB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;gBAC5D,IAAI,GAAG,KAAK,CAAC;oBAAE,OAAO,CAAC,CAAC;gBACxB,OAAO,CAAC,CAAC,IAAI,GAAG,SAAS,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC;YAChD,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;QACF,OAAO,GAAG,EAAE,GAAG,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAEX,IAAI,CAAC,IAAI;QAAE,OAAO,IAAI,CAAC;IAEvB,OAAO,CACL,MAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAC,MAAM,EAClB,QAAQ,EAAE,CAAC,aAGX,KAAC,GAAG,cACF,KAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAC,MAAM,6BAAoB,GACvC,EAGN,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,8BAAW,EAC7B,KAAC,SAAS,IACR,WAAW,EAAC,yBAAyB,EACrC,QAAQ,EAAE,YAAY,EACtB,QAAQ,EAAE,YAAY,GACtB,IACE,EAGN,KAAC,GAAG,cACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,YAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,GAAQ,GACtC,EAGN,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,aACxB,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,CAC5B,KAAC,GAAG,IAAC,QAAQ,EAAE,CAAC,YACd,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,iCAAwB,GACtC,CACP,EACA,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,CAC/B,KAAC,YAAY,IAAe,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,KAAK,aAAa,IAAtD,IAAI,CAAC,EAAE,CAAmD,CAC9E,CAAC,IACE,EAGN,KAAC,GAAG,cACF,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,2EAA8C,GAC5D,IACF,CACP,CAAC;AACJ,CAAC;AAED,eAAe,aAAa,CAAC"}
|
|
@@ -1,24 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
* Slack-style sidebar component.
|
|
3
|
-
*
|
|
4
|
-
* Contains workspace header, collapsible DM/channel sections,
|
|
5
|
-
* and individual sidebar items with online status, unread badges,
|
|
6
|
-
* and active/cursor indicators.
|
|
7
|
-
*/
|
|
8
|
-
import React from "react";
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
9
2
|
import { Box, Text } from "ink";
|
|
10
3
|
export function WorkspaceHeader({ name, width, focused, }) {
|
|
11
|
-
return (
|
|
12
|
-
<Box paddingLeft={1}>
|
|
13
|
-
{focused && <Text color="cyan">{"◆ "}</Text>}
|
|
14
|
-
<Text bold color={focused ? "cyan" : "white"}>
|
|
15
|
-
{name}
|
|
16
|
-
</Text>
|
|
17
|
-
</Box>
|
|
18
|
-
<Box paddingLeft={1}>
|
|
19
|
-
<Text dimColor>{"─".repeat(Math.max(width - 2, 1))}</Text>
|
|
20
|
-
</Box>
|
|
21
|
-
</Box>);
|
|
4
|
+
return (_jsxs(Box, { flexDirection: "column", width: width, children: [_jsxs(Box, { paddingLeft: 1, children: [focused && _jsx(Text, { color: "cyan", children: "◆ " }), _jsx(Text, { bold: true, color: focused ? "cyan" : "white", children: name })] }), _jsx(Box, { paddingLeft: 1, children: _jsx(Text, { dimColor: true, children: "─".repeat(Math.max(width - 2, 1)) }) })] }));
|
|
22
5
|
}
|
|
23
6
|
// ── SidebarItem ─────────────────────────────────────────────────────
|
|
24
7
|
export function SidebarItem({ item, isActive, isCursor, }) {
|
|
@@ -31,44 +14,25 @@ export function SidebarItem({ item, isActive, isCursor, }) {
|
|
|
31
14
|
if (item.type === "dm" || item.type === "group-dm") {
|
|
32
15
|
const dotColor = item.online ? "green" : "gray";
|
|
33
16
|
const dot = item.online ? "●" : "○";
|
|
34
|
-
indicator =
|
|
17
|
+
indicator = _jsxs(Text, { color: dotColor, children: [dot, " "] });
|
|
35
18
|
}
|
|
36
19
|
else {
|
|
37
|
-
indicator =
|
|
20
|
+
indicator = _jsx(Text, { color: "gray", children: "# " });
|
|
38
21
|
}
|
|
39
22
|
// Name color: active=cyan, unread=white bold, normal=white, muted=gray
|
|
40
23
|
const nameColor = isActive ? "cyan" : item.muted ? "gray" : "white";
|
|
41
24
|
// Unread badge
|
|
42
|
-
const badge = item.unread > 0 ? (
|
|
43
|
-
|
|
44
|
-
({item.unread})
|
|
45
|
-
</Text>) : null;
|
|
46
|
-
return (<Box>
|
|
47
|
-
<Text color={isActive ? "cyan" : isCursor ? "white" : "gray"}>
|
|
48
|
-
{prefix}
|
|
49
|
-
</Text>
|
|
50
|
-
{indicator}
|
|
51
|
-
<Text color={nameColor} bold={isBold}>
|
|
52
|
-
{item.name}
|
|
53
|
-
</Text>
|
|
54
|
-
{badge}
|
|
55
|
-
</Box>);
|
|
25
|
+
const badge = item.unread > 0 ? (_jsxs(Text, { color: "white", dimColor: !isActive, children: [" ", "(", item.unread, ")"] })) : null;
|
|
26
|
+
return (_jsxs(Box, { children: [_jsx(Text, { color: isActive ? "cyan" : isCursor ? "white" : "gray", children: prefix }), indicator, _jsx(Text, { color: nameColor, bold: isBold, children: item.name }), badge] }));
|
|
56
27
|
}
|
|
57
28
|
// ── SidebarSection ──────────────────────────────────────────────────
|
|
58
29
|
export function SidebarSection({ title, collapsed, items, activeChannelId, cursorIndex, startIndex, onToggle, onSelect, }) {
|
|
59
30
|
const triangle = collapsed ? "▸" : "▾";
|
|
60
|
-
return (
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
</Box>
|
|
66
|
-
{!collapsed &&
|
|
67
|
-
items.map((item, idx) => {
|
|
68
|
-
const flatIdx = startIndex + idx;
|
|
69
|
-
return (<SidebarItem key={item.id} item={item} isActive={item.id === activeChannelId} isCursor={cursorIndex === flatIdx}/>);
|
|
70
|
-
})}
|
|
71
|
-
</Box>);
|
|
31
|
+
return (_jsxs(Box, { flexDirection: "column", children: [_jsx(Box, { paddingLeft: 1, children: _jsxs(Text, { color: "gray", children: [triangle, " ", title] }) }), !collapsed &&
|
|
32
|
+
items.map((item, idx) => {
|
|
33
|
+
const flatIdx = startIndex + idx;
|
|
34
|
+
return (_jsx(SidebarItem, { item: item, isActive: item.id === activeChannelId, isCursor: cursorIndex === flatIdx }, item.id));
|
|
35
|
+
})] }));
|
|
72
36
|
}
|
|
73
37
|
// ── SlackSidebar (root) ─────────────────────────────────────────────
|
|
74
38
|
export function SlackSidebar({ width, focused, workspaceName, sections, collapsedSections, activeChannelId, cursor, onToggleSection, onSelectItem, }) {
|
|
@@ -82,16 +46,7 @@ export function SlackSidebar({ width, focused, workspaceName, sections, collapse
|
|
|
82
46
|
runningIndex += section.items.length;
|
|
83
47
|
}
|
|
84
48
|
}
|
|
85
|
-
return (
|
|
86
|
-
<WorkspaceHeader name={workspaceName} width={width} focused={focused}/>
|
|
87
|
-
<Box height={1}/>
|
|
88
|
-
{sections.map((section, sIdx) => (<SidebarSection key={section.title} title={section.title} collapsed={collapsedSections.includes(section.title)} items={section.items} activeChannelId={activeChannelId} cursorIndex={cursor} startIndex={sectionOffsets[sIdx]} onToggle={() => onToggleSection(section.title)} onSelect={onSelectItem}/>))}
|
|
89
|
-
<Box height={1}/>
|
|
90
|
-
<Box paddingLeft={1} gap={2}>
|
|
91
|
-
<Text color="gray">[n] channel</Text>
|
|
92
|
-
<Text color="gray">[a] agent</Text>
|
|
93
|
-
</Box>
|
|
94
|
-
</Box>);
|
|
49
|
+
return (_jsxs(Box, { flexDirection: "column", width: width, children: [_jsx(WorkspaceHeader, { name: workspaceName, width: width, focused: focused }), _jsx(Box, { height: 1 }), sections.map((section, sIdx) => (_jsx(SidebarSection, { title: section.title, collapsed: collapsedSections.includes(section.title), items: section.items, activeChannelId: activeChannelId, cursorIndex: cursor, startIndex: sectionOffsets[sIdx], onToggle: () => onToggleSection(section.title), onSelect: onSelectItem }, section.title))), _jsx(Box, { height: 1 }), _jsxs(Box, { paddingLeft: 1, gap: 2, children: [_jsx(Text, { color: "gray", children: "[n] channel" }), _jsx(Text, { color: "gray", children: "[a] agent" })] })] }));
|
|
95
50
|
}
|
|
96
51
|
export default SlackSidebar;
|
|
97
52
|
//# sourceMappingURL=sidebar.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sidebar.js","sourceRoot":"","sources":["../../../../src/tui/components/slack/sidebar.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"sidebar.js","sourceRoot":"","sources":["../../../../src/tui/components/slack/sidebar.tsx"],"names":[],"mappings":";AASA,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAqBhC,MAAM,UAAU,eAAe,CAAC,EAC9B,IAAI,EACJ,KAAK,EACL,OAAO,GACuB;IAC9B,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,KAAK,EAAE,KAAK,aACtC,MAAC,GAAG,IAAC,WAAW,EAAE,CAAC,aAChB,OAAO,IAAI,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,YAAE,IAAI,GAAQ,EAC5C,KAAC,IAAI,IAAC,IAAI,QAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,YACzC,IAAI,GACA,IACH,EACN,KAAC,GAAG,IAAC,WAAW,EAAE,CAAC,YACjB,KAAC,IAAI,IAAC,QAAQ,kBAAE,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAQ,GACtD,IACF,CACP,CAAC;AACJ,CAAC;AAED,uEAAuE;AAEvE,MAAM,UAAU,WAAW,CAAC,EAC1B,IAAI,EACJ,QAAQ,EACR,QAAQ,GAKT;IACC,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IACjC,MAAM,MAAM,GAAG,QAAQ,IAAI,QAAQ,CAAC;IAEpC,8DAA8D;IAC9D,MAAM,MAAM,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;IAEtC,qCAAqC;IACrC,IAAI,SAA4B,CAAC;IACjC,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;QACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;QAChD,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QACpC,SAAS,GAAG,MAAC,IAAI,IAAC,KAAK,EAAE,QAAQ,aAAG,GAAG,SAAS,CAAC;IACnD,CAAC;SAAM,CAAC;QACN,SAAS,GAAG,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,mBAAU,CAAC;IAC3C,CAAC;IAED,uEAAuE;IACvE,MAAM,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC;IAEpE,eAAe;IACf,MAAM,KAAK,GACT,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAChB,MAAC,IAAI,IAAC,KAAK,EAAC,OAAO,EAAC,QAAQ,EAAE,CAAC,QAAQ,aACpC,GAAG,OACF,IAAI,CAAC,MAAM,SACR,CACR,CAAC,CAAC,CAAC,IAAI,CAAC;IAEX,OAAO,CACL,MAAC,GAAG,eACF,KAAC,IAAI,IAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,YACzD,MAAM,GACF,EACN,SAAS,EACV,KAAC,IAAI,IAAC,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,YACjC,IAAI,CAAC,IAAI,GACL,EACN,KAAK,IACF,CACP,CAAC;AACJ,CAAC;AAED,uEAAuE;AAEvE,MAAM,UAAU,cAAc,CAAC,EAC7B,KAAK,EACL,SAAS,EACT,KAAK,EACL,eAAe,EACf,WAAW,EACX,UAAU,EACV,QAAQ,EACR,QAAQ,GAUT;IACC,MAAM,QAAQ,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;IAEvC,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,aACzB,KAAC,GAAG,IAAC,WAAW,EAAE,CAAC,YACjB,MAAC,IAAI,IAAC,KAAK,EAAC,MAAM,aACf,QAAQ,OAAG,KAAK,IACZ,GACH,EACL,CAAC,SAAS;gBACT,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE;oBACtB,MAAM,OAAO,GAAG,UAAU,GAAG,GAAG,CAAC;oBACjC,OAAO,CACL,KAAC,WAAW,IAEV,IAAI,EAAE,IAAI,EACV,QAAQ,EAAE,IAAI,CAAC,EAAE,KAAK,eAAe,EACrC,QAAQ,EAAE,WAAW,KAAK,OAAO,IAH5B,IAAI,CAAC,EAAE,CAIZ,CACH,CAAC;gBACJ,CAAC,CAAC,IACA,CACP,CAAC;AACJ,CAAC;AAED,uEAAuE;AAEvE,MAAM,UAAU,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,aAAa,EACb,QAAQ,EACR,iBAAiB,EACjB,eAAe,EACf,MAAM,EACN,eAAe,EACf,YAAY,GAWb;IACC,8CAA8C;IAC9C,IAAI,YAAY,GAAG,CAAC,CAAC;IACrB,MAAM,cAAc,GAAa,EAAE,CAAC;IACpC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAClC,MAAM,WAAW,GAAG,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC9D,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,YAAY,IAAI,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC;QACvC,CAAC;IACH,CAAC;IAED,OAAO,CACL,MAAC,GAAG,IACF,aAAa,EAAC,QAAQ,EACtB,KAAK,EAAE,KAAK,aAEZ,KAAC,eAAe,IAAC,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,GAAI,EACxE,KAAC,GAAG,IAAC,MAAM,EAAE,CAAC,GAAI,EACjB,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC,CAC/B,KAAC,cAAc,IAEb,KAAK,EAAE,OAAO,CAAC,KAAK,EACpB,SAAS,EAAE,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EACpD,KAAK,EAAE,OAAO,CAAC,KAAK,EACpB,eAAe,EAAE,eAAe,EAChC,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,cAAc,CAAC,IAAI,CAAC,EAChC,QAAQ,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC,OAAO,CAAC,KAAK,CAAC,EAC9C,QAAQ,EAAE,YAAY,IARjB,OAAO,CAAC,KAAK,CASlB,CACH,CAAC,EACF,KAAC,GAAG,IAAC,MAAM,EAAE,CAAC,GAAI,EAClB,MAAC,GAAG,IAAC,WAAW,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,aACzB,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,4BAAmB,EACrC,KAAC,IAAI,IAAC,KAAK,EAAC,MAAM,0BAAiB,IAC/B,IACF,CACP,CAAC;AACJ,CAAC;AAED,eAAe,YAAY,CAAC"}
|