imcp 0.1.4 → 0.1.5

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 (228) hide show
  1. package/README.md +21 -4
  2. package/dist/cli/commands/install.js.map +1 -0
  3. package/dist/cli/commands/list.js.map +1 -0
  4. package/dist/cli/commands/pull.js.map +1 -0
  5. package/dist/cli/commands/serve.js.map +1 -0
  6. package/dist/cli/commands/start.d.ts +2 -0
  7. package/dist/cli/commands/start.js +32 -0
  8. package/dist/cli/commands/start.js.map +1 -0
  9. package/dist/cli/commands/sync.d.ts +2 -0
  10. package/dist/cli/commands/sync.js +17 -0
  11. package/dist/cli/commands/sync.js.map +1 -0
  12. package/dist/cli/commands/uninstall.js.map +1 -0
  13. package/dist/cli/index.js +0 -0
  14. package/dist/cli/index.js.map +1 -0
  15. package/dist/core/ConfigurationLoader.d.ts +32 -0
  16. package/{src/core/loaders/ConfigurationLoader.ts → dist/core/ConfigurationLoader.js} +236 -298
  17. package/dist/core/ConfigurationLoader.js.map +1 -0
  18. package/dist/core/ConfigurationProvider.d.ts +35 -0
  19. package/{src/core/loaders/ConfigurationProvider.ts → dist/core/ConfigurationProvider.js} +375 -462
  20. package/dist/core/ConfigurationProvider.js.map +1 -0
  21. package/dist/core/InstallationService.d.ts +50 -0
  22. package/dist/core/InstallationService.js +350 -0
  23. package/dist/core/InstallationService.js.map +1 -0
  24. package/dist/core/MCPManager.d.ts +28 -0
  25. package/dist/core/MCPManager.js +188 -0
  26. package/dist/core/MCPManager.js.map +1 -0
  27. package/dist/core/RequirementService.d.ts +40 -0
  28. package/dist/core/RequirementService.js +110 -0
  29. package/dist/core/RequirementService.js.map +1 -0
  30. package/dist/core/ServerSchemaLoader.d.ts +11 -0
  31. package/dist/core/ServerSchemaLoader.js +43 -0
  32. package/dist/core/ServerSchemaLoader.js.map +1 -0
  33. package/dist/core/ServerSchemaProvider.d.ts +17 -0
  34. package/dist/core/ServerSchemaProvider.js +120 -0
  35. package/dist/core/ServerSchemaProvider.js.map +1 -0
  36. package/dist/core/constants.d.ts +47 -0
  37. package/dist/core/constants.js +94 -0
  38. package/dist/core/constants.js.map +1 -0
  39. package/dist/core/installers/BaseInstaller.d.ts +74 -0
  40. package/dist/core/installers/BaseInstaller.js +253 -0
  41. package/dist/core/installers/BaseInstaller.js.map +1 -0
  42. package/dist/core/installers/ClientInstaller.d.ts +23 -0
  43. package/dist/core/installers/ClientInstaller.js +564 -0
  44. package/dist/core/installers/ClientInstaller.js.map +1 -0
  45. package/dist/core/installers/CommandInstaller.d.ts +37 -0
  46. package/{src/core/installers/requirements/CommandInstaller.ts → dist/core/installers/CommandInstaller.js} +173 -231
  47. package/dist/core/installers/CommandInstaller.js.map +1 -0
  48. package/dist/core/installers/GeneralInstaller.d.ts +33 -0
  49. package/dist/core/installers/GeneralInstaller.js +85 -0
  50. package/dist/core/installers/GeneralInstaller.js.map +1 -0
  51. package/dist/core/installers/InstallerFactory.d.ts +54 -0
  52. package/{src/core/installers/requirements/InstallerFactory.ts → dist/core/installers/InstallerFactory.js} +97 -114
  53. package/dist/core/installers/InstallerFactory.js.map +1 -0
  54. package/dist/core/installers/NpmInstaller.d.ts +26 -0
  55. package/dist/core/installers/NpmInstaller.js +127 -0
  56. package/dist/core/installers/NpmInstaller.js.map +1 -0
  57. package/dist/core/installers/PipInstaller.d.ts +28 -0
  58. package/dist/core/installers/PipInstaller.js +127 -0
  59. package/dist/core/installers/PipInstaller.js.map +1 -0
  60. package/{src/core/installers/requirements/RequirementInstaller.ts → dist/core/installers/RequirementInstaller.d.ts} +33 -42
  61. package/dist/core/installers/RequirementInstaller.js +3 -0
  62. package/dist/core/installers/RequirementInstaller.js.map +1 -0
  63. package/dist/core/installers/clients/BaseClientInstaller.js.map +1 -0
  64. package/dist/core/installers/clients/ClientInstaller.js.map +1 -0
  65. package/dist/core/installers/clients/ClientInstallerFactory.js.map +1 -0
  66. package/dist/core/installers/clients/ClineInstaller.js.map +1 -0
  67. package/dist/core/installers/clients/ExtensionInstaller.js.map +1 -0
  68. package/dist/core/installers/clients/GithubCopilotInstaller.js.map +1 -0
  69. package/dist/core/installers/clients/MSRooCodeInstaller.js.map +1 -0
  70. package/dist/core/installers/index.js.map +1 -0
  71. package/dist/core/installers/requirements/BaseInstaller.js.map +1 -0
  72. package/dist/core/installers/requirements/CommandInstaller.js.map +1 -0
  73. package/dist/core/installers/requirements/GeneralInstaller.js.map +1 -0
  74. package/dist/core/installers/requirements/InstallerFactory.js.map +1 -0
  75. package/dist/core/installers/requirements/NpmInstaller.js.map +1 -0
  76. package/dist/core/installers/requirements/NugetInstaller.js.map +1 -0
  77. package/dist/core/installers/requirements/PipInstaller.js.map +1 -0
  78. package/dist/core/installers/requirements/RequirementInstaller.js.map +1 -0
  79. package/dist/core/loaders/ConfigurationLoader.js.map +1 -0
  80. package/dist/core/loaders/ConfigurationProvider.js.map +1 -0
  81. package/dist/core/loaders/InstallOperationManager.js.map +1 -0
  82. package/dist/core/loaders/ServerSchemaLoader.js.map +1 -0
  83. package/dist/core/loaders/ServerSchemaProvider.js.map +1 -0
  84. package/dist/core/loaders/SystemSettingsManager.js.map +1 -0
  85. package/dist/core/metadatas/constants.js.map +1 -0
  86. package/dist/core/metadatas/recordingConstants.js.map +1 -0
  87. package/dist/core/metadatas/types.js.map +1 -0
  88. package/dist/core/onboard/FeedOnboardService.js.map +1 -0
  89. package/dist/core/onboard/OnboardProcessor.js.map +1 -0
  90. package/dist/core/onboard/OnboardStatus.js.map +1 -0
  91. package/dist/core/onboard/OnboardStatusManager.js.map +1 -0
  92. package/dist/core/types.d.ts +166 -0
  93. package/dist/core/types.js +16 -0
  94. package/dist/core/types.js.map +1 -0
  95. package/dist/core/validators/FeedValidator.js.map +1 -0
  96. package/dist/core/validators/IServerValidator.js.map +1 -0
  97. package/dist/core/validators/SSEServerValidator.js.map +1 -0
  98. package/dist/core/validators/ServerValidatorFactory.js.map +1 -0
  99. package/dist/core/validators/StdioServerValidator.js.map +1 -0
  100. package/dist/index.js.map +1 -0
  101. package/dist/services/InstallRequestValidator.d.ts +21 -0
  102. package/dist/services/InstallRequestValidator.js +99 -0
  103. package/dist/services/InstallRequestValidator.js.map +1 -0
  104. package/dist/services/InstallationService.js.map +1 -0
  105. package/dist/services/MCPManager.js.map +1 -0
  106. package/dist/services/RequirementService.js.map +1 -0
  107. package/dist/services/ServerService.js.map +1 -0
  108. package/dist/services/TelemetryService.js.map +1 -0
  109. package/dist/utils/UpdateCheckTracker.js.map +1 -0
  110. package/dist/utils/adoUtils.js.map +1 -0
  111. package/dist/utils/clientUtils.js.map +1 -0
  112. package/dist/utils/feedUtils.js.map +1 -0
  113. package/dist/utils/githubAuth.js.map +1 -0
  114. package/dist/utils/githubUtils.js.map +1 -0
  115. package/dist/utils/logger.js.map +1 -0
  116. package/dist/utils/macroExpressionUtils.js.map +1 -0
  117. package/dist/utils/osUtils.js.map +1 -0
  118. package/dist/utils/versionUtils.js.map +1 -0
  119. package/dist/web/contract/serverContract.js.map +1 -0
  120. package/dist/web/public/index.html +1 -1
  121. package/dist/web/public/js/modal/installHandler.js +227 -0
  122. package/dist/web/public/js/modal/loadingUI.js +74 -0
  123. package/dist/web/public/js/modal/messageQueue.js +101 -45
  124. package/dist/web/public/js/modal/modalUI.js +214 -0
  125. package/{src/web/public/js/modal/versionUtils.js → dist/web/public/js/modal/version.js} +1 -1
  126. package/dist/web/public/onboard.html +4 -4
  127. package/dist/web/server.js.map +1 -0
  128. package/package.json +5 -1
  129. package/.github/ISSUE_TEMPLATE/JitAccess.yml +0 -28
  130. package/.github/acl/access.yml +0 -20
  131. package/.github/compliance/inventory.yml +0 -5
  132. package/.github/policies/jit.yml +0 -19
  133. package/.roo/rules-code/rules.md +0 -88
  134. package/dist/core/onboard/InstallOperationManager.d.ts +0 -23
  135. package/dist/core/onboard/InstallOperationManager.js +0 -144
  136. package/docs/ONBOARDING_PAGE_DESIGN.md +0 -260
  137. package/docs/Telemetry.md +0 -136
  138. package/memory-bank/activeContext.md +0 -26
  139. package/memory-bank/decisionLog.md +0 -91
  140. package/memory-bank/productContext.md +0 -41
  141. package/memory-bank/progress.md +0 -35
  142. package/memory-bank/systemPatterns.md +0 -10
  143. package/src/cli/commands/install.ts +0 -139
  144. package/src/cli/commands/list.ts +0 -113
  145. package/src/cli/commands/pull.ts +0 -16
  146. package/src/cli/commands/serve.ts +0 -39
  147. package/src/cli/commands/uninstall.ts +0 -64
  148. package/src/cli/index.ts +0 -82
  149. package/src/core/installers/clients/BaseClientInstaller.ts +0 -341
  150. package/src/core/installers/clients/ClientInstaller.ts +0 -222
  151. package/src/core/installers/clients/ClientInstallerFactory.ts +0 -43
  152. package/src/core/installers/clients/ClineInstaller.ts +0 -35
  153. package/src/core/installers/clients/ExtensionInstaller.ts +0 -165
  154. package/src/core/installers/clients/GithubCopilotInstaller.ts +0 -79
  155. package/src/core/installers/clients/MSRooCodeInstaller.ts +0 -32
  156. package/src/core/installers/index.ts +0 -11
  157. package/src/core/installers/requirements/BaseInstaller.ts +0 -85
  158. package/src/core/installers/requirements/GeneralInstaller.ts +0 -133
  159. package/src/core/installers/requirements/NpmInstaller.ts +0 -271
  160. package/src/core/installers/requirements/NugetInstaller.ts +0 -203
  161. package/src/core/installers/requirements/PipInstaller.ts +0 -207
  162. package/src/core/loaders/InstallOperationManager.ts +0 -367
  163. package/src/core/loaders/ServerSchemaLoader.ts +0 -117
  164. package/src/core/loaders/ServerSchemaProvider.ts +0 -99
  165. package/src/core/loaders/SystemSettingsManager.ts +0 -278
  166. package/src/core/metadatas/constants.ts +0 -122
  167. package/src/core/metadatas/recordingConstants.ts +0 -65
  168. package/src/core/metadatas/types.ts +0 -202
  169. package/src/core/onboard/FeedOnboardService.ts +0 -501
  170. package/src/core/onboard/OnboardProcessor.ts +0 -356
  171. package/src/core/onboard/OnboardStatus.ts +0 -60
  172. package/src/core/onboard/OnboardStatusManager.ts +0 -416
  173. package/src/core/validators/FeedValidator.ts +0 -135
  174. package/src/core/validators/IServerValidator.ts +0 -21
  175. package/src/core/validators/SSEServerValidator.ts +0 -43
  176. package/src/core/validators/ServerValidatorFactory.ts +0 -51
  177. package/src/core/validators/StdioServerValidator.ts +0 -313
  178. package/src/index.ts +0 -44
  179. package/src/services/InstallationService.ts +0 -102
  180. package/src/services/MCPManager.ts +0 -249
  181. package/src/services/RequirementService.ts +0 -627
  182. package/src/services/ServerService.ts +0 -161
  183. package/src/services/TelemetryService.ts +0 -59
  184. package/src/utils/UpdateCheckTracker.ts +0 -86
  185. package/src/utils/adoUtils.ts +0 -293
  186. package/src/utils/clientUtils.ts +0 -72
  187. package/src/utils/feedUtils.ts +0 -31
  188. package/src/utils/githubAuth.ts +0 -212
  189. package/src/utils/githubUtils.ts +0 -164
  190. package/src/utils/logger.ts +0 -195
  191. package/src/utils/macroExpressionUtils.ts +0 -104
  192. package/src/utils/osUtils.ts +0 -700
  193. package/src/utils/versionUtils.ts +0 -114
  194. package/src/web/contract/serverContract.ts +0 -74
  195. package/src/web/public/css/detailsWidget.css +0 -235
  196. package/src/web/public/css/modal.css +0 -757
  197. package/src/web/public/css/notifications.css +0 -101
  198. package/src/web/public/css/onboard.css +0 -107
  199. package/src/web/public/css/serverCategoryList.css +0 -120
  200. package/src/web/public/css/serverDetails.css +0 -139
  201. package/src/web/public/index.html +0 -359
  202. package/src/web/public/js/api.js +0 -132
  203. package/src/web/public/js/detailsWidget.js +0 -264
  204. package/src/web/public/js/flights/flights.js +0 -127
  205. package/src/web/public/js/modal/index.js +0 -52
  206. package/src/web/public/js/modal/installModal.js +0 -162
  207. package/src/web/public/js/modal/installation.js +0 -266
  208. package/src/web/public/js/modal/loadingModal.js +0 -182
  209. package/src/web/public/js/modal/modalSetup.js +0 -595
  210. package/src/web/public/js/modal/modalUtils.js +0 -37
  211. package/src/web/public/js/modal.js +0 -42
  212. package/src/web/public/js/notifications.js +0 -137
  213. package/src/web/public/js/onboard/formProcessor.js +0 -1037
  214. package/src/web/public/js/onboard/index.js +0 -374
  215. package/src/web/public/js/onboard/publishHandler.js +0 -172
  216. package/src/web/public/js/onboard/state.js +0 -76
  217. package/src/web/public/js/onboard/templates.js +0 -342
  218. package/src/web/public/js/onboard/uiHandlers.js +0 -1076
  219. package/src/web/public/js/onboard/validationHandlers.js +0 -493
  220. package/src/web/public/js/serverCategoryDetails.js +0 -364
  221. package/src/web/public/js/serverCategoryList.js +0 -241
  222. package/src/web/public/js/settings.js +0 -314
  223. package/src/web/public/modal.html +0 -84
  224. package/src/web/public/onboard.html +0 -296
  225. package/src/web/public/settings.html +0 -135
  226. package/src/web/public/styles.css +0 -277
  227. package/src/web/server.ts +0 -478
  228. package/tsconfig.json +0 -18
@@ -1,101 +0,0 @@
1
- /* Alert container */
2
- .alert-container {
3
- z-index: 999999; /* Extremely high to appear above modals */
4
- position: fixed;
5
- top: 20px; /* Adjusted for top-right positioning */
6
- right: 20px; /* Adjusted for top-right positioning */
7
- display: flex;
8
- flex-direction: column;
9
- align-items: flex-end; /* Align items to the right */
10
- gap: 10px;
11
- pointer-events: none; /* Allow clicking through the container */
12
- max-width: 350px; /* Max width for the container */
13
- }
14
-
15
- .alert {
16
- min-width: 300px; /* Adjusted min-width */
17
- max-width: 100%; /* Alert can take full width of container */
18
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15); /* Softer shadow */
19
- backdrop-filter: blur(8px);
20
- border-width: 1px; /* Thinner border */
21
- border-radius: 8px; /* Rounded corners */
22
- pointer-events: auto; /* Re-enable pointer events for alerts */
23
- padding: 12px 20px; /* Adjusted padding */
24
- font-size: 0.95rem; /* Slightly smaller font size */
25
- font-weight: 500;
26
- display: flex; /* For icon and text alignment */
27
- align-items: center; /* Vertically center icon and text */
28
- opacity: 0; /* Start hidden for animation */
29
- transform: translateX(100%); /* Start off-screen for slide-in */
30
- transition: opacity 0.3s ease-out, transform 0.3s ease-out; /* Smooth animation */
31
- }
32
-
33
- .alert.show {
34
- opacity: 1;
35
- transform: translateX(0);
36
- }
37
-
38
- .alert:first-child {
39
- margin-top: 0;
40
- }
41
-
42
- .alert-icon {
43
- margin-right: 10px; /* Space between icon and text */
44
- font-size: 1.2rem; /* Icon size */
45
- }
46
-
47
- .alert.alert-success {
48
- background-color: rgba(30, 136, 229, 0.9); /* Blue for success */
49
- border-color: #1e88e5;
50
- color: white;
51
- }
52
-
53
- .alert.alert-error {
54
- background-color: rgba(229, 57, 53, 0.9); /* Red for error */
55
- border-color: #e53935;
56
- color: white;
57
- }
58
-
59
- .alert.alert-info {
60
- background-color: rgba(2, 136, 209, 0.9); /* Light blue for info */
61
- border-color: #0288d1;
62
- color: white;
63
- }
64
-
65
- .alert.alert-warning {
66
- background-color: rgba(251, 192, 45, 0.9); /* Yellow for warning */
67
- border-color: #fbc02d;
68
- color: #333; /* Darker text for better contrast on yellow */
69
- }
70
-
71
- .alert .btn-close {
72
- filter: brightness(0) invert(1);
73
- opacity: 0.8;
74
- padding: 0.75rem;
75
- margin-left: auto; /* Push close button to the right */
76
- }
77
-
78
- .alert.alert-warning .btn-close {
79
- filter: none; /* No filter for warning close button for better visibility */
80
- }
81
-
82
-
83
- /* When modal is open, add backdrop to alerts */
84
- .modal.show ~ .alert-container .alert {
85
- box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
86
- backdrop-filter: blur(12px);
87
- }
88
-
89
- /* Modal customization */
90
- .modal-content {
91
- border: none;
92
- box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
93
- }
94
-
95
- .modal-header {
96
- border-bottom: 1px solid rgba(0, 0, 0, 0.05);
97
- }
98
-
99
- .modal-footer {
100
- border-top: 1px solid rgba(0, 0, 0, 0.05);
101
- }
@@ -1,107 +0,0 @@
1
- /* Onboarding form styles */
2
- .requirement-item,
3
- .server-item {
4
- background-color: #ffffff;
5
- transition: all 0.2s ease;
6
- }
7
-
8
- .requirement-item:hover,
9
- .server-item:hover {
10
- box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
11
- }
12
-
13
- .registry-config,
14
- .installation-config,
15
- .env-variables {
16
- background-color: #f9fafb;
17
- border-radius: 0.5rem;
18
- padding: 0.75rem; /* Reduced padding */
19
- margin-top: 0.75rem; /* Reduced margin-top */
20
- }
21
-
22
- .registry-github,
23
- .registry-artifacts {
24
- background-color: #ffffff;
25
- border-radius: 0.5rem;
26
- padding: 0.75rem; /* Reduced padding */
27
- }
28
-
29
- /* Order field styling */
30
- input[type="number"][name$=".order"] {
31
- -moz-appearance: textfield;
32
- }
33
-
34
- input[type="number"][name$=".order"]::-webkit-outer-spin-button,
35
- input[type="number"][name$=".order"]::-webkit-inner-spin-button {
36
- -webkit-appearance: none;
37
- margin: 0;
38
- }
39
-
40
- input[type="number"][name$=".order"]:focus {
41
- border-color: #3b82f6;
42
- outline: none;
43
- box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
44
- }
45
-
46
- /* Collapsible sections */
47
- .collapsible-content {
48
- overflow: hidden;
49
- transition: max-height 0.3s ease-out, opacity 0.3s ease-out, padding 0.3s ease-out, margin 0.3s ease-out;
50
- opacity: 1;
51
- max-height: 1000px; /* Adjust as needed, should be larger than the content */
52
- }
53
-
54
- .collapsible-content.hidden {
55
- max-height: 0;
56
- opacity: 0;
57
- padding-top: 0 !important; /* Use important to override potential inline styles or more specific selectors */
58
- padding-bottom: 0 !important;
59
- margin-top: 0 !important;
60
- margin-bottom: 0 !important; /* Ensure bottom margin also collapses */
61
- border-top-width: 0;
62
- border-bottom-width: 0;
63
- overflow: hidden; /* Ensure content is clipped during transition */
64
- }
65
-
66
- /* Styling for the clickable header of collapsible sections */
67
- .collapsible-header {
68
- cursor: pointer;
69
- display: flex;
70
- justify-content: space-between;
71
- align-items: center;
72
- }
73
-
74
- .collapsible-header i {
75
- transition: transform 0.3s ease;
76
- }
77
-
78
- .collapsible-content.hidden + .collapsible-header i {
79
- transform: rotate(-90deg);
80
- }
81
-
82
- /* Specific styling for scrollable server content */
83
- .server-content-scrollable {
84
- /* This max-height is for when the section is *expanded*.
85
- The .collapsible-content.hidden will still set max-height to 0 for collapse.
86
- The general .collapsible-content max-height is a fallback for other sections.
87
- */
88
- max-height: 60vh; /* Reduced max-height for compactness */
89
- overflow-y: auto; /* Add vertical scrollbar when content exceeds max-height */
90
- padding-right: 0.5rem; /* Add a little padding so scrollbar doesn't overlap content too much */
91
- /* Ensure it inherits or has its own transitions for smooth animation */
92
- transition: max-height 0.3s ease-out, opacity 0.3s ease-out, padding 0.3s ease-out, margin 0.3s ease-out;
93
- opacity: 1; /* Explicitly set opacity for visible state */
94
- }
95
-
96
- /* Ensure that when server-content-scrollable is hidden, its specific max-height is overridden */
97
- .server-content-scrollable.hidden {
98
- max-height: 0 !important; /* Override the 60vh for hidden state */
99
- opacity: 0 !important; /* Ensure opacity transition for hidden state */
100
- overflow-y: hidden; /* Hide scrollbar when collapsed */
101
- padding-top: 0 !important;
102
- padding-bottom: 0 !important;
103
- padding-left: 0 !important; /* Ensure all paddings are zeroed */
104
- padding-right: 0 !important;
105
- margin-top: 0 !important;
106
- margin-bottom: 0 !important;
107
- }
@@ -1,120 +0,0 @@
1
- /* Server Category List Styles */
2
- .category-toggle {
3
- cursor: pointer;
4
- display: flex;
5
- align-items: center;
6
- color: #4b5563; /* gray-600 */
7
- transition: all 0.2s;
8
- }
9
-
10
- .category-toggle:hover {
11
- color: #1e40af; /* blue-800 */
12
- }
13
-
14
- .category-toggle i {
15
- font-size: 1.25rem;
16
- transition: transform 0.2s;
17
- }
18
-
19
- .category-toggle.collapsed i {
20
- transform: rotate(-90deg);
21
- }
22
-
23
- .server-list-container {
24
- transition: height 0.3s ease, opacity 0.3s ease, margin 0.3s ease;
25
- overflow: hidden;
26
- }
27
-
28
- .server-list-container.collapsed {
29
- height: 0 !important;
30
- opacity: 0;
31
- margin-top: 0;
32
- margin-bottom: 0;
33
- }
34
-
35
- .category-section {
36
- margin-bottom: 1rem;
37
- border-bottom: 1px solid #e5e7eb; /* gray-200 */
38
- padding-bottom: 0.5rem;
39
- }
40
-
41
- .category-section:last-child {
42
- border-bottom: none;
43
- margin-bottom: 0;
44
- }
45
-
46
- .category-header {
47
- display: flex;
48
- justify-content: space-between;
49
- align-items: center;
50
- margin-bottom: 0.5rem;
51
- }
52
-
53
- /* Pin button styles */
54
- .pin-button {
55
- cursor: pointer;
56
- display: flex;
57
- align-items: center;
58
- color: #9ca3af; /* gray-400 */
59
- margin-right: 8px;
60
- transition: all 0.2s ease;
61
- }
62
-
63
- .pin-button:hover {
64
- color: #4b5563; /* gray-600 */
65
- }
66
-
67
- .pin-button.pinned {
68
- color: #2563eb; /* blue-600 */
69
- }
70
-
71
- .pin-button.pinned:hover {
72
- color: #1d4ed8; /* blue-700 */
73
- }
74
-
75
- /* Pinned server section */
76
- .server-item.pinned {
77
- border-left: 3px solid #2563eb; /* blue-600 */
78
- background-color: #f0f7ff; /* very light blue */
79
- position: relative;
80
- transition: all 0.2s ease-in-out;
81
- }
82
-
83
- /* Pin animation */
84
- .server-item {
85
- transition: transform 0.3s ease, border-left 0.2s ease, background-color 0.2s ease;
86
- }
87
-
88
- /* Visual indicator for pinned items at the top */
89
- .server-item.pinned::before {
90
- content: "";
91
- position: absolute;
92
- top: -3px;
93
- left: 0;
94
- right: 0;
95
- height: 3px;
96
- background-color: #2563eb; /* blue-600 */
97
- opacity: 0;
98
- transition: opacity 0.2s ease;
99
- }
100
-
101
- /* Show top indicator for the first pinned item */
102
- .server-item.pinned:first-child::before {
103
- opacity: 1;
104
- }
105
-
106
- /* Add hover effect to pinned items */
107
- .server-item.pinned:hover {
108
- background-color: #e6f0ff; /* slightly darker on hover */
109
- }
110
-
111
- /* Pin animation effect */
112
- @keyframes pin-animation {
113
- 0% { transform: scale(1); }
114
- 50% { transform: scale(1.03); }
115
- 100% { transform: scale(1); }
116
- }
117
-
118
- .pin-animation {
119
- animation: pin-animation 0.3s ease;
120
- }
@@ -1,139 +0,0 @@
1
- /* Server item container */
2
- .server-item-content {
3
- cursor: pointer;
4
- position: relative;
5
- transition: all 0.2s ease;
6
- border: 1px solid #e5e7eb;
7
- border-radius: 0.5rem;
8
- padding: 1rem;
9
- padding-right: calc(120px + 3rem); /* Button width + spacing */
10
- box-sizing: border-box;
11
- background-color: #ffffff;
12
- z-index: 1;
13
- margin-bottom: 1rem;
14
- width: 100%;
15
- max-width: 100%;
16
- overflow: visible;
17
- }
18
-
19
- .server-item-content:hover {
20
- border-color: transparent;
21
- box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
22
- transform: translateY(-1px);
23
- }
24
-
25
- /* Details widget */
26
- .details-widget {
27
- max-height: 0;
28
- overflow: hidden;
29
- transition: max-height 0.3s ease-out;
30
- background-color: #f8fafc;
31
- border-radius: 0 0 0.5rem 0.5rem;
32
- margin: -1px 0 0;
33
- border: 1px solid #e5e7eb;
34
- border-top: none;
35
- position: relative;
36
- z-index: 0;
37
- width: 100%;
38
- max-width: 100%;
39
- box-sizing: border-box;
40
- left: 0;
41
- right: 0;
42
- }
43
-
44
- .details-widget.expanded {
45
- max-height: 2000px; /* Increased height to accommodate more content */
46
- border-color: transparent;
47
- box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
48
- transition: max-height 0.3s ease-in-out, box-shadow 0.2s ease;
49
- width: 100%;
50
- margin-left: 0;
51
- margin-right: 0;
52
- display: block;
53
- }
54
-
55
- .details-widget-content {
56
- padding: 1rem;
57
- width: 100%;
58
- box-sizing: border-box;
59
- }
60
-
61
- .description-text {
62
- color: #4b5563;
63
- line-height: 1.5;
64
- font-size: 0.875rem;
65
- }
66
-
67
- /* Expand/collapse animation */
68
- .server-item-content.expanded {
69
- border-bottom: none;
70
- border-bottom-left-radius: 0;
71
- border-bottom-right-radius: 0;
72
- border-color: transparent;
73
- box-shadow: 0 -1px 8px rgba(0, 0, 0, 0.08);
74
- margin-bottom: 0;
75
- }
76
-
77
- /* Server item layout */
78
- .server-item-info {
79
- width: 100%;
80
- }
81
-
82
- .server-item-header {
83
- margin-bottom: 1rem;
84
- }
85
-
86
- .server-item-header h5 {
87
- margin-bottom: 0.5rem;
88
- }
89
-
90
- /* Client status section */
91
- .flex-wrap {
92
- margin: -0.25rem; /* Negative margin to offset badge spacing */
93
- }
94
-
95
- .flex-wrap > * {
96
- margin: 0.25rem; /* Even spacing between badges */
97
- }
98
-
99
- /* Install/Uninstall button section */
100
- .action-buttons {
101
- position: absolute;
102
- right: 1rem;
103
- top: calc(2rem + 0.5rem); /* Align with description text (header height + margin-bottom) */
104
- margin: 0;
105
- z-index: 2; /* Ensure buttons stay on top */
106
- }
107
-
108
- .action-buttons button {
109
- min-width: 100px;
110
- padding: 0.5rem 1.5rem;
111
- text-align: center;
112
- font-weight: 600;
113
- transition: none; /* No delay for hover effect */
114
- white-space: nowrap;
115
- }
116
-
117
- /* Update button (orange) */
118
- .btn-update {
119
- background-color: #fb923c; /* orange-400 */
120
- color: #fff;
121
- border: none;
122
- }
123
- .btn-update:hover, .btn-update:focus {
124
- background-color: #f97316; /* orange-500 */
125
- color: #fff;
126
- border: none;
127
- box-shadow: 0 0 0 2px #fed7aa;
128
- }
129
-
130
- /* Status badges */
131
- .server-item-info .flex-wrap span {
132
- display: inline-flex;
133
- align-items: center;
134
- padding: 0.375rem 0.75rem;
135
- border-radius: 9999px;
136
- font-size: 0.75rem;
137
- line-height: 1;
138
- white-space: nowrap;
139
- }