@julianpedro/plugin-dev-ai-hub 0.1.6

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 (30) hide show
  1. package/dist/api/DevAiHubClient.esm.js +76 -0
  2. package/dist/api/DevAiHubClient.esm.js.map +1 -0
  3. package/dist/components/AssetCard/AssetCard.esm.js +200 -0
  4. package/dist/components/AssetCard/AssetCard.esm.js.map +1 -0
  5. package/dist/components/AssetDetailPanel/AssetDetailPanel.esm.js +327 -0
  6. package/dist/components/AssetDetailPanel/AssetDetailPanel.esm.js.map +1 -0
  7. package/dist/components/AssetFilters/AssetFilters.esm.js +216 -0
  8. package/dist/components/AssetFilters/AssetFilters.esm.js.map +1 -0
  9. package/dist/components/AssetInstallDialog/AssetInstallDialog.esm.js +194 -0
  10. package/dist/components/AssetInstallDialog/AssetInstallDialog.esm.js.map +1 -0
  11. package/dist/components/DevAiHubPage/DevAiHubPage.esm.js +320 -0
  12. package/dist/components/DevAiHubPage/DevAiHubPage.esm.js.map +1 -0
  13. package/dist/components/DevAiHubPage/index.esm.js +6 -0
  14. package/dist/components/DevAiHubPage/index.esm.js.map +1 -0
  15. package/dist/components/McpConfigDialog/McpConfigDialog.esm.js +314 -0
  16. package/dist/components/McpConfigDialog/McpConfigDialog.esm.js.map +1 -0
  17. package/dist/components/ToolIcon/ToolIcon.esm.js +41 -0
  18. package/dist/components/ToolIcon/ToolIcon.esm.js.map +1 -0
  19. package/dist/hooks/index.esm.js +114 -0
  20. package/dist/hooks/index.esm.js.map +1 -0
  21. package/dist/index.d.ts +104 -0
  22. package/dist/index.esm.js +5 -0
  23. package/dist/index.esm.js.map +1 -0
  24. package/dist/plugin.esm.js +40 -0
  25. package/dist/plugin.esm.js.map +1 -0
  26. package/dist/pluginLegacy.esm.js +27 -0
  27. package/dist/pluginLegacy.esm.js.map +1 -0
  28. package/dist/routes.esm.js +6 -0
  29. package/dist/routes.esm.js.map +1 -0
  30. package/package.json +89 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssetDetailPanel.esm.js","sources":["../../../src/components/AssetDetailPanel/AssetDetailPanel.tsx"],"sourcesContent":["import { useState } from 'react';\nimport { useTheme } from '@mui/material/styles';\nimport ReactMarkdown from 'react-markdown';\nimport remarkGfm from 'remark-gfm';\nimport Alert from '@mui/material/Alert';\nimport Box from '@mui/material/Box';\nimport Button from '@mui/material/Button';\nimport Chip from '@mui/material/Chip';\nimport CircularProgress from '@mui/material/CircularProgress';\nimport Divider from '@mui/material/Divider';\nimport Drawer from '@mui/material/Drawer';\nimport IconButton from '@mui/material/IconButton';\nimport Link from '@mui/material/Link';\nimport Snackbar from '@mui/material/Snackbar';\nimport Tab from '@mui/material/Tab';\nimport Tabs from '@mui/material/Tabs';\nimport Typography from '@mui/material/Typography';\nimport CloseIcon from '@mui/icons-material/Close';\nimport ContentCopyIcon from '@mui/icons-material/ContentCopy';\nimport FolderZipIcon from '@mui/icons-material/FolderZip';\nimport OpenInNewIcon from '@mui/icons-material/OpenInNew';\nimport type { AssetType } from '@julianpedro/plugin-dev-ai-hub-common';\nimport { useAssetDetail } from '../../hooks';\n\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst SyntaxHighlighter = require('react-syntax-highlighter/dist/esm/prism').default;\n// eslint-disable-next-line @typescript-eslint/no-require-imports\nconst { oneLight, oneDark } = require('react-syntax-highlighter/dist/esm/styles/prism');\n\nconst TYPE_COLORS: Record<AssetType, string> = {\n instruction: '#1976d2',\n agent: '#7b1fa2',\n skill: '#388e3c',\n workflow: '#f57c00',\n};\n\ninterface AssetDetailPanelProps {\n assetId: string | null;\n onClose: () => void;\n}\n\nexport function AssetDetailPanel({ assetId, onClose }: AssetDetailPanelProps) {\n const [tab, setTab] = useState(0);\n const [snackbar, setSnackbar] = useState<string | null>(null);\n const { asset, loading } = useAssetDetail(assetId);\n const theme = useTheme();\n const syntaxTheme = theme.palette.mode === 'dark' ? oneDark : oneLight;\n\n const handleCopy = () => {\n if (!asset) return;\n navigator.clipboard.writeText(asset.content).then(() =>\n setSnackbar('Markdown copied to clipboard!'),\n );\n };\n\n return (\n <>\n <Drawer\n anchor=\"right\"\n open={!!assetId}\n onClose={onClose}\n PaperProps={{ sx: { width: { xs: '100vw', md: 640 } } }}\n >\n <Box sx={{ display: 'flex', flexDirection: 'column', height: '100%' }}>\n {/* Header */}\n <Box\n sx={{\n p: 2,\n display: 'flex',\n alignItems: 'flex-start',\n gap: 2,\n borderBottom: 1,\n borderColor: 'divider',\n }}\n >\n <Box sx={{ flex: 1 }}>\n {loading || !asset ? (\n <Box sx={{ display: 'flex', alignItems: 'center', gap: 1 }}>\n <CircularProgress size={16} />\n <Typography variant=\"body2\" color=\"text.secondary\">\n Loading...\n </Typography>\n </Box>\n ) : (\n <>\n <Box sx={{ display: 'flex', alignItems: 'center', gap: 1, mb: 0.5 }}>\n <Typography variant=\"h6\" fontWeight={700}>\n {asset.name}\n </Typography>\n <Chip\n label={asset.type}\n size=\"small\"\n sx={{\n backgroundColor: `${TYPE_COLORS[asset.type]}20`,\n color: TYPE_COLORS[asset.type],\n fontWeight: 600,\n }}\n />\n </Box>\n <Typography variant=\"body2\" color=\"text.secondary\">\n {asset.description}\n </Typography>\n </>\n )}\n </Box>\n <IconButton onClick={onClose} size=\"small\">\n <CloseIcon />\n </IconButton>\n </Box>\n\n {/* Tabs */}\n <Tabs\n value={tab}\n onChange={(_, v) => setTab(v)}\n sx={{ borderBottom: 1, borderColor: 'divider', px: 2 }}\n >\n <Tab label=\"Preview\" />\n <Tab label=\"Metadata\" />\n <Tab label=\"Raw YAML\" />\n </Tabs>\n\n {/* Content */}\n <Box sx={{ flex: 1, overflow: 'auto', p: 2 }}>\n {loading && (\n <Box sx={{ display: 'flex', justifyContent: 'center', pt: 4 }}>\n <CircularProgress />\n </Box>\n )}\n\n {!loading && asset && (\n <>\n {tab === 0 && (\n <Box\n sx={{\n '& h1,h2,h3,h4,h5,h6': { mt: 2, mb: 1, fontWeight: 700 },\n '& p': { mb: 1, lineHeight: 1.7 },\n '& ul, & ol': { pl: 2.5, mb: 1 },\n '& li': { mb: 0.5 },\n '& blockquote': {\n borderLeft: '3px solid',\n borderColor: 'primary.main',\n pl: 1.5,\n color: 'text.secondary',\n my: 1,\n ml: 0,\n },\n '& table': { width: '100%', borderCollapse: 'collapse', mb: 1 },\n '& th, & td': {\n border: '1px solid',\n borderColor: 'divider',\n px: 1.5,\n py: 0.75,\n fontSize: '0.875rem',\n },\n '& th': { backgroundColor: 'action.hover', fontWeight: 700 },\n '& code': {\n bgcolor: 'action.hover',\n px: 0.5,\n py: 0.2,\n borderRadius: 0.5,\n fontFamily: 'monospace',\n fontSize: '0.875em',\n },\n '& pre code': { bgcolor: 'transparent', px: 0, py: 0 },\n }}\n >\n <ReactMarkdown\n remarkPlugins={[remarkGfm]}\n components={{\n pre: ({ children }) => <Box sx={{ my: 1 }}>{children}</Box>,\n code({ className, children }) {\n const match = /language-(\\w+)/.exec(className || '');\n const code = String(children).replace(/\\n$/, '');\n const isBlock = code.includes('\\n') || !!match;\n return isBlock ? (\n <SyntaxHighlighter\n style={syntaxTheme}\n language={match?.[1] ?? 'text'}\n PreTag=\"div\"\n customStyle={{\n borderRadius: 8,\n fontSize: '0.8rem',\n margin: 0,\n border: `1px solid ${theme.palette.divider}`,\n }}\n >\n {code}\n </SyntaxHighlighter>\n ) : (\n <code className={className}>{children}</code>\n );\n },\n }}\n >\n {asset.content}\n </ReactMarkdown>\n </Box>\n )}\n\n {tab === 1 && (\n <Box sx={{ display: 'flex', flexDirection: 'column', gap: 2 }}>\n <MetaRow label=\"Author\" value={asset.author} />\n <MetaRow label=\"Version\" value={asset.version} />\n <MetaRow label=\"Provider\" value={asset.providerId} />\n {asset.commitSha && (\n <MetaRow label=\"Commit\" value={asset.commitSha.slice(0, 8)} />\n )}\n <MetaRow label=\"Last synced\" value={new Date(asset.syncedAt).toLocaleString()} />\n <MetaRow label=\"Branch\" value={asset.branch} />\n\n <Divider />\n\n <Box>\n <Typography variant=\"caption\" color=\"text.secondary\">\n Compatible tools\n </Typography>\n <Box sx={{ display: 'flex', gap: 1, mt: 0.5 }}>\n {asset.tools.map(t => (\n <Chip key={t} label={t} size=\"small\" />\n ))}\n </Box>\n </Box>\n\n {asset.tags.length > 0 && (\n <Box>\n <Typography variant=\"caption\" color=\"text.secondary\">\n Tags\n </Typography>\n <Box sx={{ display: 'flex', gap: 0.5, flexWrap: 'wrap', mt: 0.5 }}>\n {asset.tags.map(t => (\n <Chip key={t} label={t} size=\"small\" variant=\"outlined\" />\n ))}\n </Box>\n </Box>\n )}\n\n {asset.type === 'skill' && (\n <>\n <Divider />\n <Box>\n <Box sx={{ display: 'flex', alignItems: 'center', gap: 0.75, mb: 0.5 }}>\n <FolderZipIcon sx={{ fontSize: '0.85rem', color: 'text.secondary' }} />\n <Typography variant=\"caption\" color=\"text.secondary\">\n Bundled files\n </Typography>\n </Box>\n {asset.resourcesContent && Object.keys(asset.resourcesContent).length > 0 ? (\n <Box sx={{ display: 'flex', flexDirection: 'column', gap: 0.5, mt: 0.5 }}>\n <Box sx={{ display: 'flex', gap: 0.5, flexWrap: 'wrap' }}>\n <Chip\n label=\"SKILL.md\"\n size=\"small\"\n sx={{ fontFamily: 'monospace', fontSize: '0.7rem', height: 20 }}\n />\n {Object.keys(asset.resourcesContent).map(p => (\n <Chip\n key={p}\n label={p}\n size=\"small\"\n variant=\"outlined\"\n sx={{ fontFamily: 'monospace', fontSize: '0.7rem', height: 20 }}\n />\n ))}\n </Box>\n <Typography variant=\"caption\" color=\"text.disabled\">\n Downloads as .zip containing all files above.\n </Typography>\n </Box>\n ) : (\n <Box sx={{ display: 'flex', gap: 0.5, flexWrap: 'wrap', mt: 0.5 }}>\n <Chip\n label=\"SKILL.md\"\n size=\"small\"\n sx={{ fontFamily: 'monospace', fontSize: '0.7rem', height: 20 }}\n />\n </Box>\n )}\n </Box>\n </>\n )}\n\n <Divider />\n\n <Box>\n <Typography variant=\"caption\" color=\"text.secondary\">\n Repository\n </Typography>\n <Box>\n <Link\n href={asset.repoUrl}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n variant=\"body2\"\n >\n {asset.repoUrl} <OpenInNewIcon sx={{ fontSize: 12 }} />\n </Link>\n </Box>\n </Box>\n </Box>\n )}\n\n {tab === 2 && (\n <Box\n component=\"pre\"\n sx={{\n bgcolor: 'action.hover',\n p: 2,\n borderRadius: 1,\n overflow: 'auto',\n fontSize: '0.8rem',\n fontFamily: 'monospace',\n whiteSpace: 'pre-wrap',\n wordBreak: 'break-word',\n border: '1px solid',\n borderColor: 'divider',\n }}\n >\n {asset.yamlRaw}\n </Box>\n )}\n </>\n )}\n </Box>\n\n {/* Actions */}\n <Box\n sx={{\n p: 2,\n borderTop: 1,\n borderColor: 'divider',\n display: 'flex',\n gap: 1,\n flexWrap: 'wrap',\n }}\n >\n <Button\n variant=\"contained\"\n startIcon={<ContentCopyIcon />}\n onClick={handleCopy}\n disabled={!asset}\n >\n Copy Markdown\n </Button>\n\n <Button\n variant=\"outlined\"\n startIcon={<OpenInNewIcon />}\n onClick={() => asset && window.open(asset.repoUrl, '_blank')}\n disabled={!asset}\n >\n Open in Repo\n </Button>\n </Box>\n </Box>\n </Drawer>\n\n <Snackbar\n open={!!snackbar}\n autoHideDuration={2500}\n onClose={() => setSnackbar(null)}\n anchorOrigin={{ vertical: 'bottom', horizontal: 'center' }}\n >\n <Alert severity=\"success\" onClose={() => setSnackbar(null)}>\n {snackbar}\n </Alert>\n </Snackbar>\n </>\n );\n}\n\nfunction MetaRow({ label, value }: { label: string; value: string }) {\n return (\n <Box>\n <Typography variant=\"caption\" color=\"text.secondary\">\n {label}\n </Typography>\n <Typography variant=\"body2\">{value}</Typography>\n </Box>\n );\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,216 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import Box from '@mui/material/Box';
3
+ import Chip from '@mui/material/Chip';
4
+ import InputAdornment from '@mui/material/InputAdornment';
5
+ import TextField from '@mui/material/TextField';
6
+ import Typography from '@mui/material/Typography';
7
+ import SearchIcon from '@mui/icons-material/Search';
8
+ import StorageIcon from '@mui/icons-material/Storage';
9
+ import ArticleIcon from '@mui/icons-material/Article';
10
+ import SmartToyIcon from '@mui/icons-material/SmartToy';
11
+ import BuildIcon from '@mui/icons-material/Build';
12
+ import AccountTreeIcon from '@mui/icons-material/AccountTree';
13
+ import AppsIcon from '@mui/icons-material/Apps';
14
+ import { ToolIcon } from '../ToolIcon/ToolIcon.esm.js';
15
+
16
+ const ASSET_TYPES = [
17
+ { value: "all", label: "All", color: "#64748b", Icon: AppsIcon },
18
+ { value: "instruction", label: "Instructions", color: "#2563EB", Icon: ArticleIcon },
19
+ { value: "agent", label: "Agents", color: "#7C3AED", Icon: SmartToyIcon },
20
+ { value: "skill", label: "Skills", color: "#059669", Icon: BuildIcon },
21
+ { value: "workflow", label: "Workflows", color: "#D97706", Icon: AccountTreeIcon }
22
+ ];
23
+ const AI_TOOLS = [
24
+ { value: "all", label: "All Tools" },
25
+ { value: "claude-code", label: "Claude Code" },
26
+ { value: "github-copilot", label: "GitHub Copilot" },
27
+ { value: "google-gemini", label: "Google Gemini" },
28
+ { value: "cursor", label: "Cursor" }
29
+ ];
30
+ function AssetFilters({ value, onChange, availableTags = [], providers }) {
31
+ const selectedType = value.types.length === 1 ? value.types[0] : "all";
32
+ const selectedTool = value.tools.length === 1 ? value.tools[0] : "all";
33
+ const showProviderFilter = providers && providers.length > 1;
34
+ const handleTypeClick = (type) => {
35
+ onChange({ ...value, types: type === "all" ? [] : [type] });
36
+ };
37
+ const handleToolClick = (tool) => {
38
+ onChange({ ...value, tools: tool === "all" ? [] : [tool] });
39
+ };
40
+ const handleTagToggle = (tag) => {
41
+ const next = value.tags.includes(tag) ? value.tags.filter((t) => t !== tag) : [...value.tags, tag];
42
+ onChange({ ...value, tags: next });
43
+ };
44
+ const handleProviderClick = (id) => {
45
+ onChange({ ...value, providerId: id });
46
+ };
47
+ return /* @__PURE__ */ jsxs(Box, { sx: { display: "flex", flexDirection: "column", gap: 2, mb: 3 }, children: [
48
+ /* @__PURE__ */ jsx(
49
+ TextField,
50
+ {
51
+ fullWidth: true,
52
+ size: "small",
53
+ placeholder: "Search assets by name, description or content\u2026",
54
+ value: value.search,
55
+ onChange: (e) => onChange({ ...value, search: e.target.value }),
56
+ InputProps: {
57
+ startAdornment: /* @__PURE__ */ jsx(InputAdornment, { position: "start", children: /* @__PURE__ */ jsx(SearchIcon, { fontSize: "small" }) })
58
+ },
59
+ sx: {
60
+ "& .MuiOutlinedInput-root": {
61
+ borderRadius: 2
62
+ }
63
+ }
64
+ }
65
+ ),
66
+ /* @__PURE__ */ jsxs(Box, { sx: { display: "flex", gap: 3, flexWrap: "wrap", alignItems: "flex-start" }, children: [
67
+ /* @__PURE__ */ jsxs(Box, { children: [
68
+ /* @__PURE__ */ jsx(Typography, { variant: "caption", fontWeight: 600, color: "text.secondary", sx: { mb: 1, display: "block", textTransform: "uppercase", letterSpacing: 0.5 }, children: "Type" }),
69
+ /* @__PURE__ */ jsx(Box, { sx: { display: "flex", gap: 0.75, flexWrap: "wrap" }, children: ASSET_TYPES.map((t) => {
70
+ const isSelected = selectedType === t.value;
71
+ const TypeIcon = t.Icon;
72
+ return /* @__PURE__ */ jsx(
73
+ Chip,
74
+ {
75
+ icon: /* @__PURE__ */ jsx(TypeIcon, { sx: { fontSize: "0.9rem !important", color: isSelected ? "#fff !important" : t.color } }),
76
+ label: t.label,
77
+ size: "small",
78
+ clickable: true,
79
+ onClick: () => handleTypeClick(t.value),
80
+ sx: {
81
+ fontWeight: 600,
82
+ fontSize: "0.75rem",
83
+ borderRadius: 2,
84
+ border: "1.5px solid",
85
+ borderColor: isSelected ? t.color : `${t.color}60`,
86
+ backgroundColor: isSelected ? t.color : "transparent",
87
+ color: isSelected ? "#fff" : t.color,
88
+ transition: "all 0.15s ease",
89
+ "&:hover": {
90
+ backgroundColor: isSelected ? t.color : `${t.color}18`,
91
+ borderColor: t.color
92
+ }
93
+ }
94
+ },
95
+ t.value
96
+ );
97
+ }) })
98
+ ] }),
99
+ /* @__PURE__ */ jsxs(Box, { children: [
100
+ /* @__PURE__ */ jsx(Typography, { variant: "caption", fontWeight: 600, color: "text.secondary", sx: { mb: 1, display: "block", textTransform: "uppercase", letterSpacing: 0.5 }, children: "AI Tool" }),
101
+ /* @__PURE__ */ jsx(Box, { sx: { display: "flex", gap: 0.75, flexWrap: "wrap" }, children: AI_TOOLS.map((t) => {
102
+ const isSelected = selectedTool === t.value;
103
+ const iconEl = t.value !== "all" ? /* @__PURE__ */ jsx(ToolIcon, { tool: t.value, branded: !isSelected, sx: { fontSize: "0.85rem !important", color: isSelected ? "background.paper" : "inherit" } }) : void 0;
104
+ return /* @__PURE__ */ jsx(
105
+ Chip,
106
+ {
107
+ icon: iconEl,
108
+ label: t.label,
109
+ size: "small",
110
+ clickable: true,
111
+ onClick: () => handleToolClick(t.value),
112
+ sx: {
113
+ fontWeight: 600,
114
+ fontSize: "0.75rem",
115
+ borderRadius: 2,
116
+ border: "1.5px solid",
117
+ borderColor: isSelected ? "text.primary" : "divider",
118
+ backgroundColor: isSelected ? "text.primary" : "transparent",
119
+ color: isSelected ? "background.paper" : "text.secondary",
120
+ transition: "all 0.15s ease",
121
+ "&:hover": {
122
+ borderColor: "text.primary",
123
+ backgroundColor: isSelected ? "text.primary" : "action.hover"
124
+ }
125
+ }
126
+ },
127
+ t.value
128
+ );
129
+ }) })
130
+ ] }),
131
+ showProviderFilter && /* @__PURE__ */ jsxs(Box, { children: [
132
+ /* @__PURE__ */ jsx(Typography, { variant: "caption", fontWeight: 600, color: "text.secondary", sx: { mb: 1, display: "block", textTransform: "uppercase", letterSpacing: 0.5 }, children: "Provider" }),
133
+ /* @__PURE__ */ jsxs(Box, { sx: { display: "flex", gap: 0.75, flexWrap: "wrap" }, children: [
134
+ /* @__PURE__ */ jsx(
135
+ Chip,
136
+ {
137
+ icon: /* @__PURE__ */ jsx(AppsIcon, { sx: { fontSize: "0.9rem !important" } }),
138
+ label: "All",
139
+ size: "small",
140
+ clickable: true,
141
+ onClick: () => handleProviderClick(void 0),
142
+ sx: {
143
+ fontWeight: 600,
144
+ fontSize: "0.75rem",
145
+ borderRadius: 2,
146
+ border: "1.5px solid",
147
+ borderColor: !value.providerId ? "text.primary" : "divider",
148
+ backgroundColor: !value.providerId ? "text.primary" : "transparent",
149
+ color: !value.providerId ? "background.paper" : "text.secondary",
150
+ transition: "all 0.15s ease",
151
+ "&:hover": {
152
+ borderColor: "text.primary",
153
+ backgroundColor: !value.providerId ? "text.primary" : "action.hover"
154
+ }
155
+ }
156
+ }
157
+ ),
158
+ providers.map((p) => {
159
+ const isSelected = value.providerId === p.id;
160
+ const label = p.target.split("/").slice(-1)[0]?.replace(/\.git$/, "") ?? p.id;
161
+ return /* @__PURE__ */ jsx(
162
+ Chip,
163
+ {
164
+ icon: /* @__PURE__ */ jsx(StorageIcon, { sx: { fontSize: "0.85rem !important", color: isSelected ? "background.paper" : "inherit" } }),
165
+ label,
166
+ size: "small",
167
+ clickable: true,
168
+ onClick: () => handleProviderClick(p.id),
169
+ sx: {
170
+ fontWeight: 600,
171
+ fontSize: "0.75rem",
172
+ borderRadius: 2,
173
+ border: "1.5px solid",
174
+ borderColor: isSelected ? "text.primary" : "divider",
175
+ backgroundColor: isSelected ? "text.primary" : "transparent",
176
+ color: isSelected ? "background.paper" : "text.secondary",
177
+ transition: "all 0.15s ease",
178
+ "&:hover": {
179
+ borderColor: "text.primary",
180
+ backgroundColor: isSelected ? "text.primary" : "action.hover"
181
+ }
182
+ }
183
+ },
184
+ p.id
185
+ );
186
+ })
187
+ ] })
188
+ ] })
189
+ ] }),
190
+ availableTags.length > 0 && /* @__PURE__ */ jsxs(Box, { children: [
191
+ /* @__PURE__ */ jsx(Typography, { variant: "caption", fontWeight: 600, color: "text.secondary", sx: { mb: 1, display: "block", textTransform: "uppercase", letterSpacing: 0.5 }, children: "Tags" }),
192
+ /* @__PURE__ */ jsx(Box, { sx: { display: "flex", gap: 0.75, flexWrap: "wrap" }, children: availableTags.map((tag) => /* @__PURE__ */ jsx(
193
+ Chip,
194
+ {
195
+ label: `#${tag}`,
196
+ size: "small",
197
+ clickable: true,
198
+ onClick: () => handleTagToggle(tag),
199
+ sx: {
200
+ fontSize: "0.7rem",
201
+ fontWeight: value.tags.includes(tag) ? 700 : 400,
202
+ borderRadius: 1.5,
203
+ backgroundColor: value.tags.includes(tag) ? "primary.main" : "transparent",
204
+ color: value.tags.includes(tag) ? "#fff" : "text.secondary",
205
+ border: "1px solid",
206
+ borderColor: value.tags.includes(tag) ? "primary.main" : "divider"
207
+ }
208
+ },
209
+ tag
210
+ )) })
211
+ ] })
212
+ ] });
213
+ }
214
+
215
+ export { AssetFilters };
216
+ //# sourceMappingURL=AssetFilters.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssetFilters.esm.js","sources":["../../../src/components/AssetFilters/AssetFilters.tsx"],"sourcesContent":["import type { ElementType } from 'react';\nimport Box from '@mui/material/Box';\nimport Chip from '@mui/material/Chip';\nimport InputAdornment from '@mui/material/InputAdornment';\nimport TextField from '@mui/material/TextField';\nimport Typography from '@mui/material/Typography';\nimport SearchIcon from '@mui/icons-material/Search';\nimport StorageIcon from '@mui/icons-material/Storage';\nimport ArticleIcon from '@mui/icons-material/Article';\nimport SmartToyIcon from '@mui/icons-material/SmartToy';\nimport BuildIcon from '@mui/icons-material/Build';\nimport AccountTreeIcon from '@mui/icons-material/AccountTree';\nimport AppsIcon from '@mui/icons-material/Apps';\nimport type { AssetType, AiTool, AiHubProvider } from '@julianpedro/plugin-dev-ai-hub-common';\nimport { ToolIcon } from '../ToolIcon';\n\nconst ASSET_TYPES: { value: AssetType | 'all'; label: string; color: string; Icon: ElementType }[] = [\n { value: 'all', label: 'All', color: '#64748b', Icon: AppsIcon },\n { value: 'instruction', label: 'Instructions', color: '#2563EB', Icon: ArticleIcon },\n { value: 'agent', label: 'Agents', color: '#7C3AED', Icon: SmartToyIcon },\n { value: 'skill', label: 'Skills', color: '#059669', Icon: BuildIcon },\n { value: 'workflow', label: 'Workflows', color: '#D97706', Icon: AccountTreeIcon },\n];\n\nconst AI_TOOLS: { value: AiTool | 'all'; label: string }[] = [\n { value: 'all', label: 'All Tools' },\n { value: 'claude-code', label: 'Claude Code' },\n { value: 'github-copilot', label: 'GitHub Copilot' },\n { value: 'google-gemini', label: 'Google Gemini' },\n { value: 'cursor', label: 'Cursor' },\n];\n\nexport interface AssetFiltersValue {\n types: AssetType[];\n tools: AiTool[];\n search: string;\n tags: string[];\n providerId?: string;\n}\n\ninterface AssetFiltersProps {\n value: AssetFiltersValue;\n onChange: (value: AssetFiltersValue) => void;\n availableTags?: string[];\n providers?: AiHubProvider[];\n}\n\nexport function AssetFilters({ value, onChange, availableTags = [], providers }: AssetFiltersProps) {\n const selectedType = value.types.length === 1 ? value.types[0] : 'all';\n const selectedTool = value.tools.length === 1 ? value.tools[0] : 'all';\n const showProviderFilter = providers && providers.length > 1;\n\n const handleTypeClick = (type: AssetType | 'all') => {\n onChange({ ...value, types: type === 'all' ? [] : [type] });\n };\n\n const handleToolClick = (tool: AiTool | 'all') => {\n onChange({ ...value, tools: tool === 'all' ? [] : [tool] });\n };\n\n const handleTagToggle = (tag: string) => {\n const next = value.tags.includes(tag)\n ? value.tags.filter(t => t !== tag)\n : [...value.tags, tag];\n onChange({ ...value, tags: next });\n };\n\n const handleProviderClick = (id: string | undefined) => {\n onChange({ ...value, providerId: id });\n };\n\n return (\n <Box sx={{ display: 'flex', flexDirection: 'column', gap: 2, mb: 3 }}>\n <TextField\n fullWidth\n size=\"small\"\n placeholder=\"Search assets by name, description or content…\"\n value={value.search}\n onChange={e => onChange({ ...value, search: e.target.value })}\n InputProps={{\n startAdornment: (\n <InputAdornment position=\"start\">\n <SearchIcon fontSize=\"small\" />\n </InputAdornment>\n ),\n }}\n sx={{\n '& .MuiOutlinedInput-root': {\n borderRadius: 2,\n },\n }}\n />\n\n <Box sx={{ display: 'flex', gap: 3, flexWrap: 'wrap', alignItems: 'flex-start' }}>\n {/* Type filter */}\n <Box>\n <Typography variant=\"caption\" fontWeight={600} color=\"text.secondary\" sx={{ mb: 1, display: 'block', textTransform: 'uppercase', letterSpacing: 0.5 }}>\n Type\n </Typography>\n <Box sx={{ display: 'flex', gap: 0.75, flexWrap: 'wrap' }}>\n {ASSET_TYPES.map(t => {\n const isSelected = selectedType === t.value;\n const TypeIcon = t.Icon;\n return (\n <Chip\n key={t.value}\n icon={<TypeIcon sx={{ fontSize: '0.9rem !important', color: isSelected ? '#fff !important' : t.color }} />}\n label={t.label}\n size=\"small\"\n clickable\n onClick={() => handleTypeClick(t.value as AssetType | 'all')}\n sx={{\n fontWeight: 600,\n fontSize: '0.75rem',\n borderRadius: 2,\n border: '1.5px solid',\n borderColor: isSelected ? t.color : `${t.color}60`,\n backgroundColor: isSelected ? t.color : 'transparent',\n color: isSelected ? '#fff' : t.color,\n transition: 'all 0.15s ease',\n '&:hover': {\n backgroundColor: isSelected ? t.color : `${t.color}18`,\n borderColor: t.color,\n },\n }}\n />\n );\n })}\n </Box>\n </Box>\n\n {/* AI Tool filter */}\n <Box>\n <Typography variant=\"caption\" fontWeight={600} color=\"text.secondary\" sx={{ mb: 1, display: 'block', textTransform: 'uppercase', letterSpacing: 0.5 }}>\n AI Tool\n </Typography>\n <Box sx={{ display: 'flex', gap: 0.75, flexWrap: 'wrap' }}>\n {AI_TOOLS.map(t => {\n const isSelected = selectedTool === t.value;\n const iconEl = t.value !== 'all'\n ? <ToolIcon tool={t.value as AiTool} branded={!isSelected} sx={{ fontSize: '0.85rem !important', color: isSelected ? 'background.paper' : 'inherit' }} />\n : undefined;\n return (\n <Chip\n key={t.value}\n icon={iconEl}\n label={t.label}\n size=\"small\"\n clickable\n onClick={() => handleToolClick(t.value as AiTool | 'all')}\n sx={{\n fontWeight: 600,\n fontSize: '0.75rem',\n borderRadius: 2,\n border: '1.5px solid',\n borderColor: isSelected ? 'text.primary' : 'divider',\n backgroundColor: isSelected ? 'text.primary' : 'transparent',\n color: isSelected ? 'background.paper' : 'text.secondary',\n transition: 'all 0.15s ease',\n '&:hover': {\n borderColor: 'text.primary',\n backgroundColor: isSelected ? 'text.primary' : 'action.hover',\n },\n }}\n />\n );\n })}\n </Box>\n </Box>\n\n {/* Provider filter — only shown when there are 2+ providers */}\n {showProviderFilter && (\n <Box>\n <Typography variant=\"caption\" fontWeight={600} color=\"text.secondary\" sx={{ mb: 1, display: 'block', textTransform: 'uppercase', letterSpacing: 0.5 }}>\n Provider\n </Typography>\n <Box sx={{ display: 'flex', gap: 0.75, flexWrap: 'wrap' }}>\n <Chip\n icon={<AppsIcon sx={{ fontSize: '0.9rem !important' }} />}\n label=\"All\"\n size=\"small\"\n clickable\n onClick={() => handleProviderClick(undefined)}\n sx={{\n fontWeight: 600,\n fontSize: '0.75rem',\n borderRadius: 2,\n border: '1.5px solid',\n borderColor: !value.providerId ? 'text.primary' : 'divider',\n backgroundColor: !value.providerId ? 'text.primary' : 'transparent',\n color: !value.providerId ? 'background.paper' : 'text.secondary',\n transition: 'all 0.15s ease',\n '&:hover': {\n borderColor: 'text.primary',\n backgroundColor: !value.providerId ? 'text.primary' : 'action.hover',\n },\n }}\n />\n {providers.map(p => {\n const isSelected = value.providerId === p.id;\n const label = p.target.split('/').slice(-1)[0]?.replace(/\\.git$/, '') ?? p.id;\n return (\n <Chip\n key={p.id}\n icon={<StorageIcon sx={{ fontSize: '0.85rem !important', color: isSelected ? 'background.paper' : 'inherit' }} />}\n label={label}\n size=\"small\"\n clickable\n onClick={() => handleProviderClick(p.id)}\n sx={{\n fontWeight: 600,\n fontSize: '0.75rem',\n borderRadius: 2,\n border: '1.5px solid',\n borderColor: isSelected ? 'text.primary' : 'divider',\n backgroundColor: isSelected ? 'text.primary' : 'transparent',\n color: isSelected ? 'background.paper' : 'text.secondary',\n transition: 'all 0.15s ease',\n '&:hover': {\n borderColor: 'text.primary',\n backgroundColor: isSelected ? 'text.primary' : 'action.hover',\n },\n }}\n />\n );\n })}\n </Box>\n </Box>\n )}\n </Box>\n\n {availableTags.length > 0 && (\n <Box>\n <Typography variant=\"caption\" fontWeight={600} color=\"text.secondary\" sx={{ mb: 1, display: 'block', textTransform: 'uppercase', letterSpacing: 0.5 }}>\n Tags\n </Typography>\n <Box sx={{ display: 'flex', gap: 0.75, flexWrap: 'wrap' }}>\n {availableTags.map(tag => (\n <Chip\n key={tag}\n label={`#${tag}`}\n size=\"small\"\n clickable\n onClick={() => handleTagToggle(tag)}\n sx={{\n fontSize: '0.7rem',\n fontWeight: value.tags.includes(tag) ? 700 : 400,\n borderRadius: 1.5,\n backgroundColor: value.tags.includes(tag) ? 'primary.main' : 'transparent',\n color: value.tags.includes(tag) ? '#fff' : 'text.secondary',\n border: '1px solid',\n borderColor: value.tags.includes(tag) ? 'primary.main' : 'divider',\n }}\n />\n ))}\n </Box>\n </Box>\n )}\n </Box>\n );\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,194 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useState } from 'react';
3
+ import Box from '@mui/material/Box';
4
+ import Chip from '@mui/material/Chip';
5
+ import Button from '@mui/material/Button';
6
+ import CircularProgress from '@mui/material/CircularProgress';
7
+ import Dialog from '@mui/material/Dialog';
8
+ import DialogActions from '@mui/material/DialogActions';
9
+ import DialogContent from '@mui/material/DialogContent';
10
+ import DialogTitle from '@mui/material/DialogTitle';
11
+ import Tooltip from '@mui/material/Tooltip';
12
+ import Typography from '@mui/material/Typography';
13
+ import ContentCopyIcon from '@mui/icons-material/ContentCopy';
14
+ import DownloadIcon from '@mui/icons-material/Download';
15
+ import CheckIcon from '@mui/icons-material/Check';
16
+ import FolderZipIcon from '@mui/icons-material/FolderZip';
17
+ import { getInstallPathsForAsset } from '@julianpedro/plugin-dev-ai-hub-common';
18
+ import { useApi } from '@backstage/core-plugin-api';
19
+ import { devAiHubApiRef } from '../../api/DevAiHubClient.esm.js';
20
+ import { useAssetDetail } from '../../hooks/index.esm.js';
21
+ import { ToolIcon } from '../ToolIcon/ToolIcon.esm.js';
22
+
23
+ const TOOL_LABELS = {
24
+ "claude-code": "Claude Code",
25
+ "github-copilot": "GitHub Copilot",
26
+ "google-gemini": "Google Gemini",
27
+ "cursor": "Cursor"
28
+ };
29
+ function AssetInstallDialog({ assetId, onClose }) {
30
+ const [copiedTool, setCopiedTool] = useState(null);
31
+ const api = useApi(devAiHubApiRef);
32
+ const { asset, loading } = useAssetDetail(assetId);
33
+ const handleClose = () => {
34
+ onClose();
35
+ setCopiedTool(null);
36
+ };
37
+ const handleCopy = (tool) => {
38
+ if (!asset) return;
39
+ navigator.clipboard.writeText(asset.content).then(() => {
40
+ setCopiedTool(tool);
41
+ setTimeout(() => setCopiedTool(null), 2e3);
42
+ });
43
+ api.trackInstall(asset.id).catch(() => {
44
+ });
45
+ };
46
+ const resourcePaths = asset?.resourcesContent ? Object.keys(asset.resourcesContent) : [];
47
+ const isZipSkill = asset?.type === "skill" && resourcePaths.length > 0;
48
+ const handleDownload = async (_tool, installPath) => {
49
+ if (!asset) return;
50
+ if (isZipSkill) {
51
+ const url = await api.getDownloadUrl(asset.id);
52
+ const a = document.createElement("a");
53
+ a.href = url;
54
+ a.download = `${asset.name.replace(/\s+/g, "-").toLowerCase()}.zip`;
55
+ a.click();
56
+ } else {
57
+ const filename = installPath.split("/").pop() ?? `${asset.name}.md`;
58
+ const blob = new Blob([asset.content], { type: "text/markdown" });
59
+ const url = URL.createObjectURL(blob);
60
+ const a = document.createElement("a");
61
+ a.href = url;
62
+ a.download = filename;
63
+ a.click();
64
+ URL.revokeObjectURL(url);
65
+ }
66
+ api.trackInstall(asset.id).catch(() => {
67
+ });
68
+ };
69
+ const installPaths = asset ? getInstallPathsForAsset(asset.type, asset.tools, asset.name, {
70
+ installPath: asset.installPath,
71
+ installPaths: asset.installPaths
72
+ }) : {};
73
+ return /* @__PURE__ */ jsxs(Dialog, { open: !!assetId, onClose: handleClose, maxWidth: "sm", fullWidth: true, children: [
74
+ /* @__PURE__ */ jsxs(DialogTitle, { sx: { pb: 1 }, children: [
75
+ asset ? `Install: ${asset.name}` : "Install",
76
+ /* @__PURE__ */ jsx(Typography, { variant: "body2", color: "text.secondary", sx: { mt: 0.5, fontWeight: 400 }, children: "Copy the content and place the file at the path shown for your tool." })
77
+ ] }),
78
+ /* @__PURE__ */ jsxs(DialogContent, { sx: { display: "flex", flexDirection: "column", gap: 1.5, pt: "8px !important" }, children: [
79
+ loading && /* @__PURE__ */ jsx(Box, { sx: { display: "flex", justifyContent: "center", py: 3 }, children: /* @__PURE__ */ jsx(CircularProgress, {}) }),
80
+ !loading && asset && isZipSkill && /* @__PURE__ */ jsxs(
81
+ Box,
82
+ {
83
+ sx: {
84
+ border: "1px solid",
85
+ borderColor: "info.main",
86
+ borderRadius: 2,
87
+ p: 1.5,
88
+ backgroundColor: "info.main",
89
+ backgroundImage: "none",
90
+ bgcolor: (theme) => `${theme.palette.info.main}12`
91
+ },
92
+ children: [
93
+ /* @__PURE__ */ jsxs(Box, { sx: { display: "flex", alignItems: "center", gap: 1, mb: 1 }, children: [
94
+ /* @__PURE__ */ jsx(FolderZipIcon, { sx: { fontSize: "1rem", color: "info.main" } }),
95
+ /* @__PURE__ */ jsx(Typography, { variant: "subtitle2", fontWeight: 700, color: "info.main", children: "Bundled skill \u2014 downloads as .zip" })
96
+ ] }),
97
+ /* @__PURE__ */ jsxs(Typography, { variant: "caption", color: "text.secondary", sx: { display: "block", mb: 1 }, children: [
98
+ "This skill includes resource files alongside ",
99
+ /* @__PURE__ */ jsx("code", { children: "SKILL.md" }),
100
+ ". Extract the zip and place all files in the skill directory."
101
+ ] }),
102
+ /* @__PURE__ */ jsxs(Box, { sx: { display: "flex", gap: 0.5, flexWrap: "wrap" }, children: [
103
+ /* @__PURE__ */ jsx(
104
+ Chip,
105
+ {
106
+ label: "SKILL.md",
107
+ size: "small",
108
+ sx: { fontFamily: "monospace", fontSize: "0.7rem", height: 20 }
109
+ }
110
+ ),
111
+ resourcePaths.map((p) => /* @__PURE__ */ jsx(
112
+ Chip,
113
+ {
114
+ label: p,
115
+ size: "small",
116
+ variant: "outlined",
117
+ sx: { fontFamily: "monospace", fontSize: "0.7rem", height: 20 }
118
+ },
119
+ p
120
+ ))
121
+ ] })
122
+ ]
123
+ }
124
+ ),
125
+ !loading && asset && Object.entries(installPaths).map(([tool, installPath]) => /* @__PURE__ */ jsxs(
126
+ Box,
127
+ {
128
+ sx: {
129
+ border: "1px solid",
130
+ borderColor: "divider",
131
+ borderRadius: 2,
132
+ p: 1.5
133
+ },
134
+ children: [
135
+ /* @__PURE__ */ jsxs(Box, { sx: { display: "flex", alignItems: "center", gap: 1, mb: 1 }, children: [
136
+ /* @__PURE__ */ jsx(ToolIcon, { tool, sx: { fontSize: "1rem" } }),
137
+ /* @__PURE__ */ jsx(Typography, { variant: "subtitle2", fontWeight: 700, children: TOOL_LABELS[tool] ?? tool })
138
+ ] }),
139
+ /* @__PURE__ */ jsx(Typography, { variant: "caption", color: "text.secondary", sx: { display: "block", mb: 0.5 }, children: "Install path" }),
140
+ /* @__PURE__ */ jsx(
141
+ Box,
142
+ {
143
+ sx: {
144
+ bgcolor: "action.hover",
145
+ border: "1px solid",
146
+ borderColor: "divider",
147
+ borderRadius: 1,
148
+ px: 1.5,
149
+ py: 0.75,
150
+ fontFamily: "monospace",
151
+ fontSize: "0.78rem",
152
+ color: "text.primary",
153
+ wordBreak: "break-all",
154
+ mb: 1.25
155
+ },
156
+ children: installPath
157
+ }
158
+ ),
159
+ /* @__PURE__ */ jsxs(Box, { sx: { display: "flex", gap: 1 }, children: [
160
+ /* @__PURE__ */ jsx(Tooltip, { title: copiedTool === tool ? "Copied!" : "Copy markdown content", children: /* @__PURE__ */ jsx(
161
+ Button,
162
+ {
163
+ size: "small",
164
+ variant: "outlined",
165
+ startIcon: copiedTool === tool ? /* @__PURE__ */ jsx(CheckIcon, {}) : /* @__PURE__ */ jsx(ContentCopyIcon, {}),
166
+ onClick: () => handleCopy(tool),
167
+ color: copiedTool === tool ? "success" : "primary",
168
+ sx: { flex: 1 },
169
+ children: copiedTool === tool ? "Copied!" : "Copy Content"
170
+ }
171
+ ) }),
172
+ /* @__PURE__ */ jsx(Tooltip, { title: isZipSkill ? "Download as .zip with all bundled files" : "Download file with correct name", children: /* @__PURE__ */ jsx(
173
+ Button,
174
+ {
175
+ size: "small",
176
+ variant: "outlined",
177
+ startIcon: isZipSkill ? /* @__PURE__ */ jsx(FolderZipIcon, {}) : /* @__PURE__ */ jsx(DownloadIcon, {}),
178
+ onClick: () => handleDownload(tool, installPath),
179
+ sx: { flex: 1 },
180
+ children: isZipSkill ? "Download .zip" : "Download"
181
+ }
182
+ ) })
183
+ ] })
184
+ ]
185
+ },
186
+ tool
187
+ ))
188
+ ] }),
189
+ /* @__PURE__ */ jsx(DialogActions, { children: /* @__PURE__ */ jsx(Button, { onClick: handleClose, children: "Close" }) })
190
+ ] });
191
+ }
192
+
193
+ export { AssetInstallDialog };
194
+ //# sourceMappingURL=AssetInstallDialog.esm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AssetInstallDialog.esm.js","sources":["../../../src/components/AssetInstallDialog/AssetInstallDialog.tsx"],"sourcesContent":["import { useState } from 'react';\nimport Box from '@mui/material/Box';\nimport Chip from '@mui/material/Chip';\nimport Button from '@mui/material/Button';\nimport CircularProgress from '@mui/material/CircularProgress';\nimport Dialog from '@mui/material/Dialog';\nimport DialogActions from '@mui/material/DialogActions';\nimport DialogContent from '@mui/material/DialogContent';\nimport DialogTitle from '@mui/material/DialogTitle';\nimport Tooltip from '@mui/material/Tooltip';\nimport Typography from '@mui/material/Typography';\nimport ContentCopyIcon from '@mui/icons-material/ContentCopy';\nimport DownloadIcon from '@mui/icons-material/Download';\nimport CheckIcon from '@mui/icons-material/Check';\nimport FolderZipIcon from '@mui/icons-material/FolderZip';\nimport type { AiTool } from '@julianpedro/plugin-dev-ai-hub-common';\nimport { getInstallPathsForAsset } from '@julianpedro/plugin-dev-ai-hub-common';\nimport { useApi } from '@backstage/core-plugin-api';\nimport { devAiHubApiRef } from '../../api/DevAiHubClient';\nimport { useAssetDetail } from '../../hooks';\nimport { ToolIcon } from '../ToolIcon';\n\nconst TOOL_LABELS: Record<string, string> = {\n 'claude-code': 'Claude Code',\n 'github-copilot': 'GitHub Copilot',\n 'google-gemini': 'Google Gemini',\n 'cursor': 'Cursor',\n};\n\ninterface AssetInstallDialogProps {\n assetId: string | null;\n onClose: () => void;\n}\n\nexport function AssetInstallDialog({ assetId, onClose }: AssetInstallDialogProps) {\n const [copiedTool, setCopiedTool] = useState<string | null>(null);\n const api = useApi(devAiHubApiRef);\n const { asset, loading } = useAssetDetail(assetId);\n\n const handleClose = () => {\n onClose();\n setCopiedTool(null);\n };\n\n const handleCopy = (tool: string) => {\n if (!asset) return;\n navigator.clipboard.writeText(asset.content).then(() => {\n setCopiedTool(tool);\n setTimeout(() => setCopiedTool(null), 2000);\n });\n api.trackInstall(asset.id).catch(() => {});\n };\n\n const resourcePaths = asset?.resourcesContent\n ? Object.keys(asset.resourcesContent)\n : [];\n const isZipSkill = asset?.type === 'skill' && resourcePaths.length > 0;\n\n const handleDownload = async (_tool: string, installPath: string) => {\n if (!asset) return;\n if (isZipSkill) {\n const url = await api.getDownloadUrl(asset.id);\n const a = document.createElement('a');\n a.href = url;\n a.download = `${asset.name.replace(/\\s+/g, '-').toLowerCase()}.zip`;\n a.click();\n } else {\n const filename = installPath.split('/').pop() ?? `${asset.name}.md`;\n const blob = new Blob([asset.content], { type: 'text/markdown' });\n const url = URL.createObjectURL(blob);\n const a = document.createElement('a');\n a.href = url;\n a.download = filename;\n a.click();\n URL.revokeObjectURL(url);\n }\n api.trackInstall(asset.id).catch(() => {});\n };\n\n const installPaths = asset\n ? getInstallPathsForAsset(asset.type, asset.tools, asset.name, {\n installPath: asset.installPath,\n installPaths: asset.installPaths,\n })\n : {};\n\n return (\n <Dialog open={!!assetId} onClose={handleClose} maxWidth=\"sm\" fullWidth>\n <DialogTitle sx={{ pb: 1 }}>\n {asset ? `Install: ${asset.name}` : 'Install'}\n <Typography variant=\"body2\" color=\"text.secondary\" sx={{ mt: 0.5, fontWeight: 400 }}>\n Copy the content and place the file at the path shown for your tool.\n </Typography>\n </DialogTitle>\n\n <DialogContent sx={{ display: 'flex', flexDirection: 'column', gap: 1.5, pt: '8px !important' }}>\n {loading && (\n <Box sx={{ display: 'flex', justifyContent: 'center', py: 3 }}>\n <CircularProgress />\n </Box>\n )}\n\n {!loading && asset && isZipSkill && (\n <Box\n sx={{\n border: '1px solid',\n borderColor: 'info.main',\n borderRadius: 2,\n p: 1.5,\n backgroundColor: 'info.main',\n backgroundImage: 'none',\n bgcolor: theme => `${theme.palette.info.main}12`,\n }}\n >\n <Box sx={{ display: 'flex', alignItems: 'center', gap: 1, mb: 1 }}>\n <FolderZipIcon sx={{ fontSize: '1rem', color: 'info.main' }} />\n <Typography variant=\"subtitle2\" fontWeight={700} color=\"info.main\">\n Bundled skill — downloads as .zip\n </Typography>\n </Box>\n <Typography variant=\"caption\" color=\"text.secondary\" sx={{ display: 'block', mb: 1 }}>\n This skill includes resource files alongside <code>SKILL.md</code>.\n Extract the zip and place all files in the skill directory.\n </Typography>\n <Box sx={{ display: 'flex', gap: 0.5, flexWrap: 'wrap' }}>\n <Chip\n label=\"SKILL.md\"\n size=\"small\"\n sx={{ fontFamily: 'monospace', fontSize: '0.7rem', height: 20 }}\n />\n {resourcePaths.map(p => (\n <Chip\n key={p}\n label={p}\n size=\"small\"\n variant=\"outlined\"\n sx={{ fontFamily: 'monospace', fontSize: '0.7rem', height: 20 }}\n />\n ))}\n </Box>\n </Box>\n )}\n\n {!loading && asset && Object.entries(installPaths).map(([tool, installPath]) => (\n <Box\n key={tool}\n sx={{\n border: '1px solid',\n borderColor: 'divider',\n borderRadius: 2,\n p: 1.5,\n }}\n >\n <Box sx={{ display: 'flex', alignItems: 'center', gap: 1, mb: 1 }}>\n <ToolIcon tool={tool as AiTool} sx={{ fontSize: '1rem' }} />\n <Typography variant=\"subtitle2\" fontWeight={700}>\n {TOOL_LABELS[tool] ?? tool}\n </Typography>\n </Box>\n\n <Typography variant=\"caption\" color=\"text.secondary\" sx={{ display: 'block', mb: 0.5 }}>\n Install path\n </Typography>\n <Box\n sx={{\n bgcolor: 'action.hover',\n border: '1px solid',\n borderColor: 'divider',\n borderRadius: 1,\n px: 1.5,\n py: 0.75,\n fontFamily: 'monospace',\n fontSize: '0.78rem',\n color: 'text.primary',\n wordBreak: 'break-all',\n mb: 1.25,\n }}\n >\n {installPath}\n </Box>\n\n <Box sx={{ display: 'flex', gap: 1 }}>\n <Tooltip title={copiedTool === tool ? 'Copied!' : 'Copy markdown content'}>\n <Button\n size=\"small\"\n variant=\"outlined\"\n startIcon={copiedTool === tool ? <CheckIcon /> : <ContentCopyIcon />}\n onClick={() => handleCopy(tool)}\n color={copiedTool === tool ? 'success' : 'primary'}\n sx={{ flex: 1 }}\n >\n {copiedTool === tool ? 'Copied!' : 'Copy Content'}\n </Button>\n </Tooltip>\n <Tooltip title={isZipSkill ? 'Download as .zip with all bundled files' : 'Download file with correct name'}>\n <Button\n size=\"small\"\n variant=\"outlined\"\n startIcon={isZipSkill ? <FolderZipIcon /> : <DownloadIcon />}\n onClick={() => handleDownload(tool, installPath)}\n sx={{ flex: 1 }}\n >\n {isZipSkill ? 'Download .zip' : 'Download'}\n </Button>\n </Tooltip>\n </Box>\n </Box>\n ))}\n </DialogContent>\n\n <DialogActions>\n <Button onClick={handleClose}>Close</Button>\n </DialogActions>\n </Dialog>\n );\n}\n"],"names":[],"mappings":"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"}