opacacms 0.1.11 → 0.1.13

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 (246) hide show
  1. package/dist/admin/index.js +9464 -21
  2. package/dist/admin/webcomponent.d.ts +1 -1
  3. package/dist/admin/webcomponent.js +9620 -6
  4. package/dist/admin.css +1 -0
  5. package/dist/{chunk-6dhs73zq.js → chunk-0am1m47g.js} +1 -1
  6. package/dist/{chunk-0nf7fe26.js → chunk-0d9aqz6z.js} +1 -1
  7. package/dist/{chunk-cvdd4eqh.js → chunk-2kyhqvhc.js} +5 -1
  8. package/dist/{chunk-gjjcc4hm.js → chunk-2z8wxx9g.js} +21 -6
  9. package/dist/{chunk-xg35h5a3.js → chunk-7fyepksb.js} +1 -1
  10. package/dist/{chunk-njytmdb4.js → chunk-pxh5encs.js} +34 -24
  11. package/dist/{chunk-n8aekdnr.js → chunk-qkn1ykrj.js} +33 -23
  12. package/dist/{chunk-kwp83w8b.js → chunk-wmvjvn7b.js} +4 -4
  13. package/dist/{chunk-qrt22f6e.js → chunk-wq314kkx.js} +35 -25
  14. package/dist/{chunk-eqtsfyjf.js → chunk-x2ejaftz.js} +52 -28
  15. package/dist/{chunk-6ew02s0c.js → chunk-xtwc125q.js} +18 -18
  16. package/dist/cli/index.js +5 -5
  17. package/dist/db/better-sqlite.d.ts +1 -0
  18. package/dist/db/better-sqlite.js +3 -3
  19. package/dist/db/bun-sqlite.d.ts +1 -0
  20. package/dist/db/bun-sqlite.js +3 -3
  21. package/dist/db/d1.js +3 -3
  22. package/dist/db/index.d.ts +3 -0
  23. package/dist/db/index.js +17 -13
  24. package/dist/db/postgres.js +3 -3
  25. package/dist/db/sqlite.js +3 -3
  26. package/dist/runtimes/bun.js +2 -2
  27. package/dist/runtimes/cloudflare-workers.js +2 -2
  28. package/dist/runtimes/next.js +2 -2
  29. package/dist/runtimes/node.js +2 -2
  30. package/dist/server.js +2 -2
  31. package/package.json +8 -2
  32. package/bun.lock +0 -34
  33. package/dist/admin/index.css +0 -47
  34. package/dist/api.d.ts +0 -6
  35. package/dist/api.js +0 -27
  36. package/dist/chunk-2zm8cy1w.js +0 -9482
  37. package/global.d.ts +0 -11
  38. package/src/admin/api-client.ts +0 -63
  39. package/src/admin/auth-client.ts +0 -40
  40. package/src/admin/custom-field.ts +0 -179
  41. package/src/admin/index.ts +0 -15
  42. package/src/admin/react.tsx +0 -72
  43. package/src/admin/router.ts +0 -9
  44. package/src/admin/stores/admin-queries.ts +0 -121
  45. package/src/admin/stores/auth.ts +0 -61
  46. package/src/admin/stores/column-visibility.ts +0 -67
  47. package/src/admin/stores/config.ts +0 -15
  48. package/src/admin/stores/media.ts +0 -95
  49. package/src/admin/stores/query.ts +0 -13
  50. package/src/admin/stores/ui.ts +0 -29
  51. package/src/admin/ui/admin-client.tsx +0 -283
  52. package/src/admin/ui/admin-layout.tsx +0 -276
  53. package/src/admin/ui/components/ColumnVisibilityToggle.tsx +0 -141
  54. package/src/admin/ui/components/DataDetailSheet.tsx +0 -141
  55. package/src/admin/ui/components/DataDetailView.tsx +0 -175
  56. package/src/admin/ui/components/Table.tsx +0 -67
  57. package/src/admin/ui/components/fields/ArrayField.tsx +0 -166
  58. package/src/admin/ui/components/fields/BlocksField.tsx +0 -202
  59. package/src/admin/ui/components/fields/BooleanField.tsx +0 -50
  60. package/src/admin/ui/components/fields/CollapsibleField.tsx +0 -75
  61. package/src/admin/ui/components/fields/DateField.tsx +0 -45
  62. package/src/admin/ui/components/fields/FileField.tsx +0 -322
  63. package/src/admin/ui/components/fields/GroupField.tsx +0 -50
  64. package/src/admin/ui/components/fields/JoinField.tsx +0 -23
  65. package/src/admin/ui/components/fields/NumberField.tsx +0 -46
  66. package/src/admin/ui/components/fields/RadioField.tsx +0 -62
  67. package/src/admin/ui/components/fields/RelationshipField.tsx +0 -278
  68. package/src/admin/ui/components/fields/RowField.tsx +0 -40
  69. package/src/admin/ui/components/fields/SelectField.tsx +0 -59
  70. package/src/admin/ui/components/fields/TabsField.tsx +0 -101
  71. package/src/admin/ui/components/fields/TextAreaField.tsx +0 -54
  72. package/src/admin/ui/components/fields/TextField.tsx +0 -49
  73. package/src/admin/ui/components/fields/VirtualField.tsx +0 -53
  74. package/src/admin/ui/components/fields/index.tsx +0 -371
  75. package/src/admin/ui/components/fields/richtext-editor/index.tsx +0 -211
  76. package/src/admin/ui/components/fields/richtext-editor/nodes/ImageComponent.tsx +0 -142
  77. package/src/admin/ui/components/fields/richtext-editor/nodes/ImageNode.tsx +0 -95
  78. package/src/admin/ui/components/fields/richtext-editor/plugins/ComponentPickerPlugin.tsx +0 -226
  79. package/src/admin/ui/components/fields/richtext-editor/plugins/EditableSyncPlugin.tsx +0 -16
  80. package/src/admin/ui/components/fields/richtext-editor/plugins/NotionToolbarPlugin.tsx +0 -184
  81. package/src/admin/ui/components/fields/richtext-editor/plugins/SimpleToolbarPlugin.tsx +0 -240
  82. package/src/admin/ui/components/fields/richtext-editor/plugins/ValueSyncPlugin.tsx +0 -40
  83. package/src/admin/ui/components/fields/utils.ts +0 -1
  84. package/src/admin/ui/components/link.tsx +0 -41
  85. package/src/admin/ui/components/media/AssetManagerModal.tsx +0 -334
  86. package/src/admin/ui/components/toast.tsx +0 -72
  87. package/src/admin/ui/components/ui/accordion.tsx +0 -51
  88. package/src/admin/ui/components/ui/alert-dialog.tsx +0 -98
  89. package/src/admin/ui/components/ui/blocks.tsx +0 -32
  90. package/src/admin/ui/components/ui/breadcrumbs.tsx +0 -59
  91. package/src/admin/ui/components/ui/button.tsx +0 -26
  92. package/src/admin/ui/components/ui/collapsible.tsx +0 -124
  93. package/src/admin/ui/components/ui/dialog.tsx +0 -79
  94. package/src/admin/ui/components/ui/group.tsx +0 -20
  95. package/src/admin/ui/components/ui/index.ts +0 -17
  96. package/src/admin/ui/components/ui/input.tsx +0 -12
  97. package/src/admin/ui/components/ui/join.tsx +0 -53
  98. package/src/admin/ui/components/ui/label.tsx +0 -11
  99. package/src/admin/ui/components/ui/radio-group.tsx +0 -75
  100. package/src/admin/ui/components/ui/relationship-detail-sheet.tsx +0 -122
  101. package/src/admin/ui/components/ui/relationship.tsx +0 -58
  102. package/src/admin/ui/components/ui/scroll-area.tsx +0 -19
  103. package/src/admin/ui/components/ui/select.tsx +0 -187
  104. package/src/admin/ui/components/ui/separator.tsx +0 -21
  105. package/src/admin/ui/components/ui/sheet.tsx +0 -106
  106. package/src/admin/ui/components/ui/tabs.tsx +0 -116
  107. package/src/admin/ui/components/ui/utils.ts +0 -3
  108. package/src/admin/ui/hooks/use-debounce.ts +0 -15
  109. package/src/admin/ui/styles/_locale-switcher.scss +0 -33
  110. package/src/admin/ui/styles/accordion.scss +0 -60
  111. package/src/admin/ui/styles/animations.scss +0 -41
  112. package/src/admin/ui/styles/asset-manager.scss +0 -547
  113. package/src/admin/ui/styles/badge.scss +0 -13
  114. package/src/admin/ui/styles/base.scss +0 -22
  115. package/src/admin/ui/styles/button.scss +0 -161
  116. package/src/admin/ui/styles/card.scss +0 -13
  117. package/src/admin/ui/styles/collapsible.scss +0 -75
  118. package/src/admin/ui/styles/data-detail.scss +0 -92
  119. package/src/admin/ui/styles/dialog.scss +0 -102
  120. package/src/admin/ui/styles/empty-state.scss +0 -22
  121. package/src/admin/ui/styles/group.scss +0 -19
  122. package/src/admin/ui/styles/index.scss +0 -33
  123. package/src/admin/ui/styles/input.scss +0 -80
  124. package/src/admin/ui/styles/label.scss +0 -12
  125. package/src/admin/ui/styles/layout.scss +0 -56
  126. package/src/admin/ui/styles/lexical.scss +0 -469
  127. package/src/admin/ui/styles/loading.scss +0 -102
  128. package/src/admin/ui/styles/media-registry.scss +0 -597
  129. package/src/admin/ui/styles/pagination.scss +0 -20
  130. package/src/admin/ui/styles/radio-group.scss +0 -66
  131. package/src/admin/ui/styles/row.scss +0 -17
  132. package/src/admin/ui/styles/scrollbar.scss +0 -36
  133. package/src/admin/ui/styles/select.scss +0 -121
  134. package/src/admin/ui/styles/separator.scss +0 -14
  135. package/src/admin/ui/styles/sheet.scss +0 -152
  136. package/src/admin/ui/styles/sidebar.scss +0 -148
  137. package/src/admin/ui/styles/switch.scss +0 -59
  138. package/src/admin/ui/styles/table.scss +0 -207
  139. package/src/admin/ui/styles/tabs.scss +0 -62
  140. package/src/admin/ui/styles/toast.scss +0 -45
  141. package/src/admin/ui/styles/variables.scss +0 -24
  142. package/src/admin/ui/views/collection-list-view.tsx +0 -720
  143. package/src/admin/ui/views/dashboard-view.tsx +0 -263
  144. package/src/admin/ui/views/document-edit-view.tsx +0 -384
  145. package/src/admin/ui/views/global-edit-view.tsx +0 -226
  146. package/src/admin/ui/views/init-view.tsx +0 -182
  147. package/src/admin/ui/views/login-view.tsx +0 -123
  148. package/src/admin/ui/views/media-registry-view.tsx +0 -1104
  149. package/src/admin/ui/views/settings-view.tsx +0 -729
  150. package/src/admin/webcomponent.tsx +0 -15
  151. package/src/api.ts +0 -9
  152. package/src/auth/index.ts +0 -194
  153. package/src/auth/migrations.ts +0 -87
  154. package/src/auth/premissions.ts +0 -46
  155. package/src/cli/commands/generate-types.ts +0 -116
  156. package/src/cli/commands/init.ts +0 -95
  157. package/src/cli/commands/migrate-commands.ts +0 -160
  158. package/src/cli/commands/seed-command.ts +0 -11
  159. package/src/cli/d1-mock.ts +0 -101
  160. package/src/cli/index.test.ts +0 -84
  161. package/src/cli/index.ts +0 -183
  162. package/src/cli/r2-mock.ts +0 -217
  163. package/src/cli/seeding.ts +0 -409
  164. package/src/client.ts +0 -181
  165. package/src/config-utils.ts +0 -102
  166. package/src/config.ts +0 -49
  167. package/src/db/adapter.ts +0 -53
  168. package/src/db/better-sqlite.ts +0 -632
  169. package/src/db/bun-sqlite.ts +0 -646
  170. package/src/db/d1.ts +0 -711
  171. package/src/db/index.ts +0 -6
  172. package/src/db/kysely/data-mapper.ts +0 -142
  173. package/src/db/kysely/field-mapper.ts +0 -148
  174. package/src/db/kysely/migration-generator.ts +0 -223
  175. package/src/db/kysely/query-builder.ts +0 -92
  176. package/src/db/kysely/schema-builder.ts +0 -439
  177. package/src/db/kysely/sql-utils.ts +0 -13
  178. package/src/db/postgres.ts +0 -621
  179. package/src/db/sqlite.ts +0 -660
  180. package/src/db/system-schema.ts +0 -121
  181. package/src/index.ts +0 -13
  182. package/src/runtimes/README.md +0 -59
  183. package/src/runtimes/bun.ts +0 -49
  184. package/src/runtimes/cloudflare-workers.ts +0 -38
  185. package/src/runtimes/next.ts +0 -26
  186. package/src/runtimes/node.ts +0 -52
  187. package/src/schema/collection.ts +0 -184
  188. package/src/schema/fields/base.ts +0 -164
  189. package/src/schema/fields/index.ts +0 -427
  190. package/src/schema/global.ts +0 -145
  191. package/src/schema/index.ts +0 -4
  192. package/src/schema/infer.ts +0 -72
  193. package/src/server/admin-router.ts +0 -20
  194. package/src/server/admin.ts +0 -142
  195. package/src/server/assets.ts +0 -306
  196. package/src/server/collection-router.ts +0 -55
  197. package/src/server/handlers.ts +0 -722
  198. package/src/server/middlewares/admin.ts +0 -27
  199. package/src/server/middlewares/auth.ts +0 -89
  200. package/src/server/middlewares/context.ts +0 -17
  201. package/src/server/middlewares/cors.ts +0 -24
  202. package/src/server/middlewares/database-init.ts +0 -74
  203. package/src/server/middlewares/rate-limit.ts +0 -77
  204. package/src/server/router.ts +0 -47
  205. package/src/server/setup-middlewares.ts +0 -58
  206. package/src/server/system-router.ts +0 -35
  207. package/src/server.ts +0 -9
  208. package/src/storage/adapters/cloudflare-r2.ts +0 -136
  209. package/src/storage/adapters/local.ts +0 -146
  210. package/src/storage/adapters/s3.ts +0 -186
  211. package/src/storage/errors.ts +0 -46
  212. package/src/storage/index.ts +0 -5
  213. package/src/storage/types.ts +0 -39
  214. package/src/types.ts +0 -577
  215. package/src/utils/lexical.ts +0 -37
  216. package/src/utils/logger.ts +0 -73
  217. package/src/validation.ts +0 -429
  218. package/src/validator.ts +0 -179
  219. package/test/admin-custom-field.test.ts +0 -162
  220. package/test/admin-react-field.test.tsx +0 -134
  221. package/test/api-features.test.ts +0 -78
  222. package/test/api.test.ts +0 -178
  223. package/test/auth.test.ts +0 -62
  224. package/test/cli-integration.test.ts +0 -148
  225. package/test/cli.test.ts +0 -25
  226. package/test/db/postgres.test.ts +0 -95
  227. package/test/db/sqlite-filter.test.ts +0 -53
  228. package/test/db/sqlite.test.ts +0 -82
  229. package/test/engine-features.test.ts +0 -79
  230. package/test/globals.test.ts +0 -74
  231. package/test/integration-tmp/db-app/opacacms.config.ts +0 -15
  232. package/test/integration-tmp/my-sqlite-app/opacacms.config.ts +0 -25
  233. package/test/integration-tmp/my-test-app/index.ts +0 -8
  234. package/test/integration-tmp/my-test-app/opacacms.config.ts +0 -16
  235. package/test/integration-tmp/my-test-app/package.json +0 -12
  236. package/test/populate.test.ts +0 -79
  237. package/test/runtimes.test.ts +0 -43
  238. package/test/schema-builder.test.ts +0 -107
  239. package/test/schema-features.test.ts +0 -63
  240. package/test/seeding.test.ts +0 -68
  241. package/test/storage/local.test.ts +0 -72
  242. package/test/storage/s3.test.ts +0 -60
  243. package/test/structural-data.test.ts +0 -100
  244. package/test/test-setup.ts +0 -11
  245. package/test/validation.test.ts +0 -162
  246. package/tsconfig.json +0 -42
@@ -1,121 +0,0 @@
1
- .opaca-ui-select {
2
- position: relative;
3
- width: 100%;
4
- }
5
-
6
- .opaca-ui-select-trigger {
7
- display: flex;
8
- align-items: center;
9
- justify-content: space-between;
10
- width: 100%;
11
- min-width: 160px;
12
- padding: 0.5rem 0.75rem;
13
- font-size: 0.8125rem;
14
- background-color: var(--opaca-surface);
15
- border: 1px solid var(--opaca-border);
16
- border-radius: var(--opaca-radius);
17
- color: var(--opaca-text);
18
- cursor: pointer;
19
- transition: all var(--opaca-transition);
20
- text-align: left;
21
- outline: none;
22
-
23
- &:hover {
24
- border-color: var(--opaca-border-hover);
25
- background-color: rgba(255, 255, 255, 0.02);
26
- }
27
-
28
- &:focus {
29
- border-color: var(--opaca-primary);
30
- box-shadow: 0 0 0 1px var(--opaca-primary-glow);
31
- }
32
-
33
- &:disabled {
34
- opacity: 0.5;
35
- cursor: not-allowed;
36
- }
37
-
38
- .trigger-placeholder {
39
- color: var(--opaca-text-dim);
40
- }
41
-
42
- .trigger-icon {
43
- color: var(--opaca-text-dim);
44
- transition: transform var(--opaca-transition);
45
- }
46
-
47
- &[data-state="open"] .trigger-icon {
48
- transform: rotate(180deg);
49
- }
50
- }
51
-
52
- .opaca-ui-select-portal {
53
- position: fixed;
54
- z-index: 1000;
55
- pointer-events: none;
56
- }
57
-
58
- .opaca-ui-select-content {
59
- pointer-events: auto;
60
- min-width: 8rem;
61
- overflow: hidden;
62
- background-color: var(--opaca-card-bg);
63
- border: 1px solid var(--opaca-border);
64
- border-radius: var(--opaca-radius-lg);
65
- box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4);
66
- padding: 0.25rem;
67
- animation: opaca-select-in 150ms cubic-bezier(0.16, 1, 0.3, 1);
68
- transform-origin: top;
69
- }
70
-
71
- @keyframes opaca-select-in {
72
- from {
73
- opacity: 0;
74
- transform: scale(0.95) translateY(-4px);
75
- }
76
- to {
77
- opacity: 1;
78
- transform: scale(1) translateY(0);
79
- }
80
- }
81
-
82
- .opaca-ui-select-item {
83
- display: flex;
84
- align-items: center;
85
- width: 100%;
86
- padding: 0.375rem 0.5rem;
87
- font-size: 0.8125rem;
88
- color: var(--opaca-text-muted);
89
- border-radius: var(--opaca-radius);
90
- cursor: pointer;
91
- transition: all var(--opaca-transition);
92
- border: none;
93
- background: transparent;
94
- text-align: left;
95
-
96
- &:hover {
97
- background-color: rgba(255, 255, 255, 0.05);
98
- color: var(--opaca-text);
99
- }
100
-
101
- &[data-selected="true"] {
102
- background-color: var(--opaca-primary-glow);
103
- color: var(--opaca-accent);
104
- font-weight: 500;
105
- }
106
- }
107
-
108
- .opaca-ui-select-label {
109
- padding: 0.375rem 0.5rem;
110
- font-size: 0.75rem;
111
- font-weight: 600;
112
- color: var(--opaca-text-dim);
113
- text-transform: uppercase;
114
- letter-spacing: 0.05em;
115
- }
116
-
117
- .opaca-ui-select-separator {
118
- height: 1px;
119
- background-color: var(--opaca-border);
120
- margin: 0.25rem -0.25rem;
121
- }
@@ -1,14 +0,0 @@
1
- .opaca-separator {
2
- flex-shrink: 0;
3
- background-color: var(--opaca-border);
4
-
5
- &.horizontal {
6
- height: 1px;
7
- width: 100%;
8
- }
9
-
10
- &.vertical {
11
- width: 1px;
12
- height: 100%;
13
- }
14
- }
@@ -1,152 +0,0 @@
1
- .opaca-ui-sheet-portal {
2
- position: fixed;
3
- inset: 0;
4
- z-index: 9999;
5
- display: flex;
6
- justify-content: flex-end;
7
- }
8
-
9
- .opaca-ui-sheet-overlay {
10
- position: fixed;
11
- inset: 0;
12
- background-color: rgba(0, 0, 0, 0.8);
13
- backdrop-filter: blur(4px);
14
- transition: opacity 0.2s;
15
- border: none;
16
- padding: 0;
17
- margin: 0;
18
- cursor: default;
19
- width: 100%;
20
- height: 100%;
21
- }
22
-
23
- .opaca-ui-sheet-wrapper {
24
- position: relative;
25
- z-index: 10000;
26
- height: 100%;
27
- pointer-events: none;
28
- display: flex;
29
- justify-content: flex-end;
30
- width: 100%;
31
- }
32
-
33
- .opaca-ui-sheet-content {
34
- pointer-events: auto;
35
- position: relative;
36
- z-index: 50;
37
- display: flex;
38
- height: 100%;
39
- width: 100%;
40
- flex-direction: column;
41
- border-left: 1px solid var(--opaca-border);
42
- background-color: var(--opaca-card-bg);
43
- padding: 1.5rem;
44
- box-shadow: -10px 0 25px -5px rgba(0, 0, 0, 0.2);
45
- overflow-y: auto;
46
- animation: opacaSlideInRight 0.3s cubic-bezier(0.16, 1, 0.3, 1);
47
- color: var(--opaca-text);
48
-
49
- @media (min-width: 640px) {
50
- width: 400px;
51
- max-width: 100vw;
52
- }
53
-
54
- @media (min-width: 1024px) {
55
- width: 500px;
56
- }
57
- }
58
-
59
- .opaca-ui-sheet-close {
60
- position: absolute;
61
- right: 1rem;
62
- top: 1rem;
63
- border-radius: 50%;
64
- opacity: 0.7;
65
- transition: all 0.2s ease;
66
- background: transparent;
67
- border: none;
68
- cursor: pointer;
69
- display: flex;
70
- align-items: center;
71
- justify-content: center;
72
- padding: 0.5rem;
73
-
74
- &:hover {
75
- opacity: 1;
76
- background-color: rgba(255, 255, 255, 0.05);
77
- color: var(--opaca-text);
78
- }
79
-
80
- &:focus-visible {
81
- outline: none;
82
- box-shadow: 0 0 0 2px var(--opaca-primary);
83
- }
84
- }
85
-
86
- .opaca-ui-sheet-close-icon {
87
- height: 1rem;
88
- width: 1rem;
89
- color: var(--opaca-text-muted);
90
- }
91
-
92
- .opaca-ui-sheet-header {
93
- display: flex;
94
- flex-direction: column;
95
- gap: 0.5rem;
96
- margin-bottom: 1.5rem;
97
- text-align: center;
98
-
99
- @media (min-width: 640px) {
100
- text-align: left;
101
- }
102
- }
103
-
104
- .opaca-ui-sheet-title {
105
- font-size: 1.125rem;
106
- font-weight: 600;
107
- color: var(--opaca-text);
108
- margin: 0;
109
- }
110
-
111
- .opaca-ui-sheet-description {
112
- font-size: 0.875rem;
113
- color: var(--opaca-text-muted);
114
- margin: 0;
115
- }
116
-
117
- .opaca-ui-sheet-footer {
118
- display: flex;
119
- flex-direction: column-reverse;
120
- margin-top: auto;
121
- padding-top: 1.5rem;
122
- border-top: 1px solid var(--opaca-border);
123
- gap: 0.75rem;
124
-
125
- @media (min-width: 640px) {
126
- flex-direction: row;
127
- justify-content: flex-end;
128
- gap: 0.5rem;
129
- }
130
- }
131
-
132
- .opaca-ui-sr-only {
133
- position: absolute;
134
- width: 1px;
135
- height: 1px;
136
- padding: 0;
137
- margin: -1px;
138
- overflow: hidden;
139
- clip: rect(0, 0, 0, 0);
140
- white-space: nowrap;
141
- border-width: 0;
142
- }
143
-
144
- @keyframes opacaSlideInRight {
145
- from {
146
- transform: translateX(100%);
147
- }
148
-
149
- to {
150
- transform: translateX(0);
151
- }
152
- }
@@ -1,148 +0,0 @@
1
- @use './variables';
2
-
3
- .opaca-sidebar {
4
- width: var(--opaca-sidebar-width);
5
- background-color: var(--opaca-sidebar-bg);
6
- border-right: 1px solid var(--opaca-border);
7
- height: 100%;
8
- display: flex;
9
- flex-direction: column;
10
- transition: width var(--opaca-transition), padding var(--opaca-transition);
11
- z-index: 100;
12
- overflow: visible;
13
- backdrop-filter: blur(10px);
14
-
15
- &.collapsed {
16
- width: var(--opaca-sidebar-collapsed-width);
17
-
18
- .opaca-sidebar-inner {
19
- padding-left: 0.5rem;
20
- padding-right: 0.5rem;
21
- }
22
-
23
- .opaca-nav-item {
24
- padding-left: 0;
25
- padding-right: 0;
26
- justify-content: center;
27
- gap: 0;
28
- }
29
-
30
- .opaca-nav-label {
31
- opacity: 0;
32
- width: 0;
33
- }
34
-
35
- .opaca-sidebar-toggle {
36
- right: -12px;
37
- }
38
- }
39
- }
40
-
41
- .opaca-sidebar-inner {
42
- display: flex;
43
- flex-direction: column;
44
- height: 100%;
45
- overflow: hidden;
46
- padding: 1.25rem 0.75rem;
47
- }
48
-
49
- .opaca-logo {
50
- font-size: 0.875rem;
51
- font-weight: 600;
52
- letter-spacing: -0.01em;
53
- padding: 0 0.75rem;
54
- margin-bottom: 2rem;
55
- color: var(--opaca-accent);
56
- transition: all var(--opaca-transition);
57
- white-space: nowrap;
58
- display: flex;
59
- align-items: center;
60
- min-height: 32px;
61
- }
62
-
63
- .opaca-logo-mini {
64
- width: 32px;
65
- height: 32px;
66
- background-color: rgba(124, 58, 237, 0.1);
67
- border: 1px solid rgba(124, 58, 237, 0.2);
68
- color: var(--opaca-accent);
69
- display: flex;
70
- align-items: center;
71
- justify-content: center;
72
- border-radius: var(--opaca-radius);
73
- font-size: 0.875rem;
74
- font-weight: 700;
75
- }
76
-
77
- .opaca-nav {
78
- flex: 1;
79
- display: flex;
80
- flex-direction: column;
81
- min-height: 0; // Crucial for flex scrolling
82
- }
83
-
84
- .opaca-nav-item {
85
- display: flex;
86
- align-items: center;
87
- gap: 0.625rem;
88
- padding: 0.5rem 0.75rem;
89
- color: var(--opaca-text-muted);
90
- text-decoration: none;
91
- border-radius: var(--opaca-radius);
92
- transition: all var(--opaca-transition);
93
- margin-bottom: 1px;
94
- font-size: 0.8125rem;
95
- font-weight: 400;
96
- white-space: nowrap;
97
- overflow: hidden;
98
- border: 1px solid transparent;
99
-
100
- &:hover {
101
- background-color: rgba(255, 255, 255, 0.05);
102
- border-color: rgba(255, 255, 255, 0.05);
103
- color: var(--opaca-text);
104
- }
105
-
106
- &.active {
107
- background-color: var(--opaca-primary-glow);
108
- color: var(--opaca-accent);
109
- font-weight: 600;
110
- box-shadow: inset 2px 0 0 0 var(--opaca-primary);
111
- }
112
- }
113
-
114
- .opaca-nav-label {
115
- transition: opacity var(--opaca-transition);
116
- }
117
-
118
- .opaca-nav-footer {
119
- border-top: 1px solid var(--opaca-border);
120
- padding-top: 0.75rem;
121
- margin-top: auto;
122
- padding-bottom: 0.5rem;
123
- }
124
-
125
- .opaca-sidebar-toggle {
126
- position: absolute;
127
- top: 25px;
128
- right: -12px;
129
- width: 24px;
130
- height: 24px;
131
- background-color: var(--opaca-card-bg);
132
- border: 1px solid var(--opaca-border);
133
- border-radius: 50%;
134
- color: var(--opaca-text-dim);
135
- display: flex;
136
- align-items: center;
137
- justify-content: center;
138
- cursor: pointer;
139
- z-index: 101;
140
- transition: all var(--opaca-transition);
141
- box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
142
-
143
- &:hover {
144
- border-color: var(--opaca-accent);
145
- color: var(--opaca-accent);
146
- background-color: var(--opaca-surface);
147
- }
148
- }
@@ -1,59 +0,0 @@
1
- @use './variables';
2
-
3
- .opaca-switch {
4
- position: relative;
5
- display: inline-flex;
6
- align-items: center;
7
- cursor: pointer;
8
- user-select: none;
9
- gap: 0.75rem;
10
-
11
- input {
12
- position: absolute;
13
- opacity: 0;
14
- width: 0;
15
- height: 0;
16
-
17
- &:checked + .opaca-switch-track {
18
- background-color: var(--opaca-accent);
19
- border-color: var(--opaca-accent);
20
-
21
- .opaca-switch-thumb {
22
- left: 18px;
23
- }
24
- }
25
-
26
- &:disabled + .opaca-switch-track {
27
- background: var(--opaca-border);
28
- cursor: not-allowed;
29
- opacity: 0.6;
30
- }
31
- }
32
- }
33
-
34
- .opaca-switch-track {
35
- width: 36px;
36
- height: 20px;
37
- background-color: var(--opaca-surface);
38
- border: 1px solid var(--opaca-border);
39
- border-radius: 20px;
40
- position: relative;
41
- transition: all var(--opaca-transition);
42
- }
43
-
44
- .opaca-switch-thumb {
45
- width: 14px;
46
- height: 14px;
47
- background-color: white;
48
- border-radius: 50%;
49
- position: absolute;
50
- top: 2px;
51
- left: 2px;
52
- transition: all var(--opaca-transition);
53
- box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
54
- }
55
-
56
- .opaca-switch-label {
57
- font-size: 0.8125rem;
58
- font-weight: 500;
59
- }
@@ -1,207 +0,0 @@
1
- @use './variables';
2
-
3
- .opaca-table-container {
4
- background-color: var(--opaca-card-bg);
5
- border: 1px solid var(--opaca-border);
6
- border-radius: var(--opaca-radius-lg);
7
- overflow: hidden;
8
- position: relative;
9
- }
10
-
11
- .opaca-loading-overlay {
12
- position: absolute;
13
- top: 0;
14
- left: 0;
15
- right: 0;
16
- bottom: 0;
17
- background-color: rgba(9, 9, 11, 0.6);
18
- backdrop-filter: blur(2px);
19
- display: flex;
20
- align-items: center;
21
- justify-content: center;
22
- z-index: 10;
23
- animation: opaca-fade-in 200ms ease-out;
24
- }
25
-
26
- .opaca-table {
27
- width: 100%;
28
- border-collapse: collapse;
29
-
30
- th {
31
- text-align: left;
32
- padding: 0.625rem 1rem;
33
- background-color: var(--opaca-surface);
34
- color: var(--opaca-text-dim);
35
- font-weight: 500;
36
- font-size: 0.6875rem;
37
- text-transform: uppercase;
38
- letter-spacing: 0.05em;
39
- border-bottom: 1px solid var(--opaca-border);
40
- }
41
-
42
- td {
43
- padding: 0.625rem 1rem;
44
- border-bottom: 1px solid var(--opaca-border);
45
- font-size: 0.8125rem;
46
- color: var(--opaca-text);
47
- }
48
-
49
- tr:last-child td {
50
- border-bottom: none;
51
- }
52
-
53
- tr:hover td {
54
- background-color: rgba(255, 255, 255, 0.01);
55
- }
56
- }
57
-
58
- /* Premium Table Component (Shadcn-inspired) */
59
- .opaca-table-wrapper {
60
- position: relative;
61
- width: 100%;
62
- overflow: auto;
63
- border-radius: var(--opaca-radius-lg);
64
- border: 1px solid var(--opaca-border);
65
- background: var(--opaca-card-bg);
66
- box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
67
-
68
- /* Premium scrollbar */
69
- &::-webkit-scrollbar {
70
- height: 8px;
71
- width: 8px;
72
- }
73
- &::-webkit-scrollbar-track {
74
- background: transparent;
75
- }
76
- &::-webkit-scrollbar-thumb {
77
- background: var(--opaca-border);
78
- border-radius: 10px;
79
- &:hover {
80
- background: var(--opaca-text-dim);
81
- }
82
- }
83
- }
84
-
85
- .opaca-new-table {
86
- width: 100%;
87
- caption-side: bottom;
88
- font-size: 0.875rem;
89
- border-collapse: collapse;
90
-
91
- .opaca-badge {
92
- padding: 0.2rem 0.5rem;
93
- font-size: 0.7rem;
94
- border-radius: 4px;
95
- background: var(--opaca-surface);
96
- color: var(--opaca-text-muted);
97
- border: 1px solid var(--opaca-border);
98
- }
99
-
100
- .opaca-btn-outline {
101
- background: transparent;
102
- border-color: var(--opaca-border);
103
- color: var(--opaca-text-muted);
104
-
105
- &:hover {
106
- border-color: var(--opaca-primary);
107
- color: var(--opaca-primary);
108
- }
109
- }
110
- }
111
-
112
- .opaca-table-header {
113
- background-color: rgba(255, 255, 255, 0.02);
114
- border-bottom: 1px solid var(--opaca-border);
115
- }
116
-
117
- .opaca-table-head {
118
- position: sticky;
119
- top: 0;
120
- z-index: 10;
121
- background-color: var(--opaca-card-bg);
122
- height: 3.5rem;
123
- padding: 0 1rem;
124
- text-align: left;
125
- vertical-align: middle;
126
- font-weight: 600;
127
- color: var(--opaca-text-muted);
128
- font-size: 0.75rem;
129
- text-transform: uppercase;
130
- letter-spacing: 0.05em;
131
- white-space: nowrap;
132
- min-width: 120px;
133
- transition: color 0.2s ease;
134
- box-shadow: inset 0 -1px 0 var(--opaca-border);
135
-
136
- &:hover {
137
- color: var(--opaca-text);
138
- }
139
-
140
- & > div {
141
- display: flex;
142
- align-items: center;
143
- white-space: nowrap;
144
- gap: 0.5rem;
145
- }
146
- }
147
-
148
- .opaca-table-row {
149
- border-bottom: 1px solid var(--opaca-border);
150
- transition: background-color var(--opaca-transition);
151
-
152
- &:last-child {
153
- border-bottom: 0;
154
- }
155
-
156
- &:hover {
157
- background-color: var(--opaca-surface);
158
- }
159
- }
160
-
161
- .opaca-table-cell {
162
- padding: 1rem;
163
- vertical-align: middle;
164
- color: var(--opaca-text);
165
- font-size: 0.875rem;
166
- border-bottom: 1px solid var(--opaca-border);
167
- max-width: 300px;
168
- overflow: hidden;
169
- text-overflow: ellipsis;
170
- white-space: nowrap;
171
-
172
- &.opaca-cell-interactive {
173
- cursor: pointer;
174
- transition: all 0.2s ease;
175
- border-bottom: 2px solid transparent;
176
-
177
- &:hover {
178
- background-color: rgba(255, 255, 255, 0.04);
179
- color: var(--opaca-primary);
180
- border-bottom-color: var(--opaca-primary);
181
- }
182
- }
183
- }
184
-
185
- .opaca-table-footer {
186
- background-color: rgba(255, 255, 255, 0.02);
187
- font-weight: 500;
188
- }
189
-
190
- .opaca-table-caption {
191
- margin-top: 1rem;
192
- font-size: 0.875rem;
193
- color: var(--opaca-text-muted);
194
- }
195
-
196
- .opaca-item-button {
197
- &:hover {
198
- background-color: rgba(255, 255, 255, 0.05) !important;
199
- border-color: var(--opaca-primary) !important;
200
- }
201
-
202
- &.active {
203
- background-color: rgba(var(--opaca-primary-rgb), 0.1) !important;
204
- border-color: var(--opaca-primary) !important;
205
- color: var(--opaca-primary);
206
- }
207
- }