@eventcatalog/core 3.5.2 → 3.6.1
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 +1 -1
- package/dist/analytics/analytics.cjs +1 -1
- package/dist/analytics/analytics.js +2 -2
- package/dist/analytics/log-build.cjs +1 -1
- package/dist/analytics/log-build.js +3 -3
- package/dist/{chunk-YVX5C6L3.js → chunk-FCIJEGOL.js} +1 -1
- package/dist/{chunk-WO3AKJVB.js → chunk-N2VBSHPU.js} +1 -1
- package/dist/{chunk-OKWCSRLE.js → chunk-OFHFRJ42.js} +1 -1
- package/dist/{chunk-YOFNY2RC.js → chunk-SI6IEUYS.js} +1 -1
- package/dist/{chunk-YTZSPYJN.js → chunk-XRLZZXIS.js} +1 -1
- package/dist/constants.cjs +1 -1
- package/dist/constants.js +1 -1
- package/dist/eventcatalog.cjs +1 -1
- package/dist/eventcatalog.js +5 -5
- package/dist/generate.cjs +1 -1
- package/dist/generate.js +3 -3
- package/dist/utils/cli-logger.cjs +1 -1
- package/dist/utils/cli-logger.js +2 -2
- package/eventcatalog/astro.config.mjs +2 -1
- package/eventcatalog/src/components/EnvironmentDropdown.tsx +1 -1
- package/eventcatalog/src/components/MDX/ResourceRef/ResourceRef.astro +477 -0
- package/eventcatalog/src/components/MDX/components.tsx +2 -0
- package/eventcatalog/src/components/Search/SearchDataLoader.astro +23 -11
- package/eventcatalog/src/components/Search/SearchModal.tsx +17 -2
- package/eventcatalog/src/components/SideNav/NestedSideBar/SearchBar.tsx +12 -6
- package/eventcatalog/src/components/SideNav/NestedSideBar/index.tsx +37 -16
- package/eventcatalog/src/components/Tables/Discover/DiscoverTable.tsx +816 -0
- package/eventcatalog/src/components/Tables/Discover/FilterComponents.tsx +161 -0
- package/eventcatalog/src/components/Tables/Discover/columns.tsx +565 -0
- package/eventcatalog/src/components/Tables/Discover/index.ts +4 -0
- package/eventcatalog/src/components/Tables/columns/ContainersTableColumns.tsx +1 -1
- package/eventcatalog/src/components/Tables/columns/DomainTableColumns.tsx +1 -1
- package/eventcatalog/src/components/Tables/columns/FlowTableColumns.tsx +1 -1
- package/eventcatalog/src/components/Tables/columns/MessageTableColumns.tsx +1 -1
- package/eventcatalog/src/components/Tables/columns/ServiceTableColumns.tsx +54 -64
- package/eventcatalog/src/components/Tables/columns/SharedColumns.tsx +15 -30
- package/eventcatalog/src/enterprise/plans/index.astro +125 -98
- package/eventcatalog/src/layouts/VerticalSideBarLayout.astro +1 -1
- package/eventcatalog/src/pages/api/sidebar-data.json.ts +22 -0
- package/eventcatalog/src/pages/discover/[type]/_index.data.ts +5 -1
- package/eventcatalog/src/pages/discover/[type]/index.astro +360 -41
- package/eventcatalog/src/pages/docs/custom/feature.astro +45 -39
- package/eventcatalog/src/remark-plugins/resource-ref.ts +51 -0
- package/eventcatalog/src/stores/sidebar-store/builders/shared.ts +1 -1
- package/eventcatalog/src/stores/sidebar-store/state.ts +25 -22
- package/package.json +3 -2
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { useState, useRef, useEffect } from 'react';
|
|
2
|
+
import { X, ChevronUp, ChevronDown } from 'lucide-react';
|
|
3
|
+
import { CheckIcon } from '@heroicons/react/24/outline';
|
|
4
|
+
|
|
5
|
+
// Filter Dropdown Component
|
|
6
|
+
export interface FilterDropdownProps {
|
|
7
|
+
label: string;
|
|
8
|
+
selectedItems: string[];
|
|
9
|
+
onClear: () => void;
|
|
10
|
+
onRemoveItem?: (item: string) => void;
|
|
11
|
+
children: React.ReactNode;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export const FilterDropdown = ({ label, selectedItems, onClear, onRemoveItem, children }: FilterDropdownProps) => {
|
|
15
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
16
|
+
const dropdownRef = useRef<HTMLDivElement>(null);
|
|
17
|
+
const hasSelection = selectedItems.length > 0;
|
|
18
|
+
|
|
19
|
+
// Close dropdown when clicking outside
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
const handleClickOutside = (event: MouseEvent) => {
|
|
22
|
+
if (dropdownRef.current && !dropdownRef.current.contains(event.target as Node)) {
|
|
23
|
+
setIsOpen(false);
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
if (isOpen) {
|
|
28
|
+
document.addEventListener('mousedown', handleClickOutside);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
return () => {
|
|
32
|
+
document.removeEventListener('mousedown', handleClickOutside);
|
|
33
|
+
};
|
|
34
|
+
}, [isOpen]);
|
|
35
|
+
|
|
36
|
+
return (
|
|
37
|
+
<div className="relative" ref={dropdownRef}>
|
|
38
|
+
<div
|
|
39
|
+
role="button"
|
|
40
|
+
tabIndex={0}
|
|
41
|
+
onClick={() => setIsOpen(!isOpen)}
|
|
42
|
+
onKeyDown={(e) => {
|
|
43
|
+
if (e.key === 'Enter' || e.key === ' ') {
|
|
44
|
+
e.preventDefault();
|
|
45
|
+
setIsOpen(!isOpen);
|
|
46
|
+
}
|
|
47
|
+
}}
|
|
48
|
+
className={`w-full flex items-center justify-between px-3 py-2 text-sm rounded-lg border transition-colors cursor-pointer ${
|
|
49
|
+
hasSelection || isOpen
|
|
50
|
+
? 'border-[rgb(var(--ec-accent))] bg-[rgb(var(--ec-accent)/0.05)]'
|
|
51
|
+
: 'border-[rgb(var(--ec-page-border))] bg-[rgb(var(--ec-input-bg))] hover:border-[rgb(var(--ec-icon-color))]'
|
|
52
|
+
}`}
|
|
53
|
+
>
|
|
54
|
+
<div className="flex items-center gap-2 flex-1 min-w-0 flex-wrap">
|
|
55
|
+
{hasSelection ? (
|
|
56
|
+
<div className="flex flex-wrap gap-1 items-center">
|
|
57
|
+
{selectedItems.map((item) => (
|
|
58
|
+
<span
|
|
59
|
+
key={item}
|
|
60
|
+
className="inline-flex items-center gap-1 px-2 py-0.5 text-xs bg-[rgb(var(--ec-accent)/0.15)] text-[rgb(var(--ec-accent))] rounded-full"
|
|
61
|
+
>
|
|
62
|
+
{item}
|
|
63
|
+
{onRemoveItem && (
|
|
64
|
+
<span
|
|
65
|
+
role="button"
|
|
66
|
+
tabIndex={0}
|
|
67
|
+
onClick={(e) => {
|
|
68
|
+
e.stopPropagation();
|
|
69
|
+
onRemoveItem(item);
|
|
70
|
+
}}
|
|
71
|
+
onKeyDown={(e) => {
|
|
72
|
+
if (e.key === 'Enter' || e.key === ' ') {
|
|
73
|
+
e.preventDefault();
|
|
74
|
+
e.stopPropagation();
|
|
75
|
+
onRemoveItem(item);
|
|
76
|
+
}
|
|
77
|
+
}}
|
|
78
|
+
className="hover:text-[rgb(var(--ec-page-text))] cursor-pointer"
|
|
79
|
+
>
|
|
80
|
+
<X className="w-3 h-3" />
|
|
81
|
+
</span>
|
|
82
|
+
)}
|
|
83
|
+
</span>
|
|
84
|
+
))}
|
|
85
|
+
</div>
|
|
86
|
+
) : (
|
|
87
|
+
<span className="text-[rgb(var(--ec-page-text-muted))]">{label}</span>
|
|
88
|
+
)}
|
|
89
|
+
</div>
|
|
90
|
+
<div className="flex items-center gap-1 flex-shrink-0 ml-2">
|
|
91
|
+
{hasSelection && (
|
|
92
|
+
<span
|
|
93
|
+
role="button"
|
|
94
|
+
tabIndex={0}
|
|
95
|
+
onClick={(e) => {
|
|
96
|
+
e.stopPropagation();
|
|
97
|
+
onClear();
|
|
98
|
+
}}
|
|
99
|
+
onKeyDown={(e) => {
|
|
100
|
+
if (e.key === 'Enter' || e.key === ' ') {
|
|
101
|
+
e.preventDefault();
|
|
102
|
+
e.stopPropagation();
|
|
103
|
+
onClear();
|
|
104
|
+
}
|
|
105
|
+
}}
|
|
106
|
+
className="p-0.5 hover:bg-[rgb(var(--ec-content-hover))] rounded cursor-pointer"
|
|
107
|
+
>
|
|
108
|
+
<X className="w-3.5 h-3.5 text-[rgb(var(--ec-icon-color))]" />
|
|
109
|
+
</span>
|
|
110
|
+
)}
|
|
111
|
+
{isOpen ? (
|
|
112
|
+
<ChevronUp className="w-4 h-4 text-[rgb(var(--ec-icon-color))]" />
|
|
113
|
+
) : (
|
|
114
|
+
<ChevronDown className="w-4 h-4 text-[rgb(var(--ec-icon-color))]" />
|
|
115
|
+
)}
|
|
116
|
+
</div>
|
|
117
|
+
</div>
|
|
118
|
+
|
|
119
|
+
{isOpen && (
|
|
120
|
+
<div className="absolute z-20 left-0 right-0 mt-1 bg-[rgb(var(--ec-card-bg,var(--ec-page-bg)))] border border-[rgb(var(--ec-page-border))] rounded-lg shadow-lg overflow-hidden">
|
|
121
|
+
<div className="max-h-64 overflow-y-auto p-2">{children}</div>
|
|
122
|
+
</div>
|
|
123
|
+
)}
|
|
124
|
+
</div>
|
|
125
|
+
);
|
|
126
|
+
};
|
|
127
|
+
|
|
128
|
+
// Checkbox Item Component
|
|
129
|
+
export interface CheckboxItemProps {
|
|
130
|
+
label: string;
|
|
131
|
+
checked: boolean;
|
|
132
|
+
onChange: () => void;
|
|
133
|
+
count?: number;
|
|
134
|
+
icon?: React.ReactNode;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
export const CheckboxItem = ({ label, checked, onChange, count, icon }: CheckboxItemProps) => (
|
|
138
|
+
<button
|
|
139
|
+
onClick={onChange}
|
|
140
|
+
className={`w-full flex items-center gap-2 px-2 py-1.5 rounded-md text-left transition-colors ${
|
|
141
|
+
checked ? 'bg-[rgb(var(--ec-accent)/0.1)]' : 'hover:bg-[rgb(var(--ec-content-hover))]'
|
|
142
|
+
}`}
|
|
143
|
+
>
|
|
144
|
+
<div
|
|
145
|
+
className={`w-4 h-4 flex-shrink-0 rounded border flex items-center justify-center transition-colors ${
|
|
146
|
+
checked
|
|
147
|
+
? 'bg-[rgb(var(--ec-accent))] border-[rgb(var(--ec-accent))]'
|
|
148
|
+
: 'border-[rgb(var(--ec-page-border))] bg-[rgb(var(--ec-input-bg))]'
|
|
149
|
+
}`}
|
|
150
|
+
>
|
|
151
|
+
{checked && <CheckIcon className="w-3 h-3 text-white" />}
|
|
152
|
+
</div>
|
|
153
|
+
{icon && <span className="flex-shrink-0 text-[rgb(var(--ec-icon-color))]">{icon}</span>}
|
|
154
|
+
<span
|
|
155
|
+
className={`text-sm flex-1 truncate ${checked ? 'font-medium text-[rgb(var(--ec-page-text))]' : 'text-[rgb(var(--ec-page-text))]'}`}
|
|
156
|
+
>
|
|
157
|
+
{label}
|
|
158
|
+
</span>
|
|
159
|
+
{count !== undefined && <span className="text-xs text-[rgb(var(--ec-page-text-muted))]">{count}</span>}
|
|
160
|
+
</button>
|
|
161
|
+
);
|