@eventcatalog/core 3.5.2 → 3.6.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 (39) hide show
  1. package/dist/analytics/analytics.cjs +1 -1
  2. package/dist/analytics/analytics.js +2 -2
  3. package/dist/analytics/log-build.cjs +1 -1
  4. package/dist/analytics/log-build.js +3 -3
  5. package/dist/{chunk-OKWCSRLE.js → chunk-2DSMO5BZ.js} +1 -1
  6. package/dist/{chunk-YTZSPYJN.js → chunk-O3LNFOFS.js} +1 -1
  7. package/dist/{chunk-YVX5C6L3.js → chunk-O7ZZX4CS.js} +1 -1
  8. package/dist/{chunk-WO3AKJVB.js → chunk-XTN3M6CM.js} +1 -1
  9. package/dist/{chunk-YOFNY2RC.js → chunk-YQ2LO4G6.js} +1 -1
  10. package/dist/constants.cjs +1 -1
  11. package/dist/constants.js +1 -1
  12. package/dist/eventcatalog.cjs +1 -1
  13. package/dist/eventcatalog.js +5 -5
  14. package/dist/generate.cjs +1 -1
  15. package/dist/generate.js +3 -3
  16. package/dist/utils/cli-logger.cjs +1 -1
  17. package/dist/utils/cli-logger.js +2 -2
  18. package/eventcatalog/src/components/EnvironmentDropdown.tsx +1 -1
  19. package/eventcatalog/src/components/Search/SearchDataLoader.astro +23 -11
  20. package/eventcatalog/src/components/Search/SearchModal.tsx +17 -2
  21. package/eventcatalog/src/components/SideNav/NestedSideBar/SearchBar.tsx +12 -6
  22. package/eventcatalog/src/components/SideNav/NestedSideBar/index.tsx +25 -14
  23. package/eventcatalog/src/components/Tables/Discover/DiscoverTable.tsx +816 -0
  24. package/eventcatalog/src/components/Tables/Discover/FilterComponents.tsx +161 -0
  25. package/eventcatalog/src/components/Tables/Discover/columns.tsx +565 -0
  26. package/eventcatalog/src/components/Tables/Discover/index.ts +4 -0
  27. package/eventcatalog/src/components/Tables/columns/ContainersTableColumns.tsx +1 -1
  28. package/eventcatalog/src/components/Tables/columns/DomainTableColumns.tsx +1 -1
  29. package/eventcatalog/src/components/Tables/columns/FlowTableColumns.tsx +1 -1
  30. package/eventcatalog/src/components/Tables/columns/MessageTableColumns.tsx +1 -1
  31. package/eventcatalog/src/components/Tables/columns/ServiceTableColumns.tsx +54 -64
  32. package/eventcatalog/src/components/Tables/columns/SharedColumns.tsx +15 -30
  33. package/eventcatalog/src/layouts/VerticalSideBarLayout.astro +1 -1
  34. package/eventcatalog/src/pages/api/sidebar-data.json.ts +22 -0
  35. package/eventcatalog/src/pages/discover/[type]/_index.data.ts +5 -1
  36. package/eventcatalog/src/pages/discover/[type]/index.astro +360 -41
  37. package/eventcatalog/src/stores/sidebar-store/builders/shared.ts +1 -1
  38. package/eventcatalog/src/stores/sidebar-store/state.ts +25 -22
  39. package/package.json +1 -1
@@ -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
+ );