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,597 +0,0 @@
1
- .media-registry-view {
2
- display: flex;
3
- flex-direction: column;
4
- height: 100%;
5
- }
6
-
7
- .media-registry-header {
8
- margin-bottom: 2rem;
9
- flex-shrink: 0;
10
-
11
- .opaca-title {
12
- font-size: 1.5rem;
13
- font-weight: 600;
14
- letter-spacing: -0.025em;
15
- }
16
-
17
- .opaca-subtitle {
18
- font-size: 0.875rem;
19
- color: var(--opaca-text-muted);
20
- margin-top: 0.25rem;
21
- }
22
- }
23
-
24
- .media-registry-header-actions {
25
- display: flex;
26
- gap: 0.75rem;
27
- }
28
-
29
- .media-registry-icon-mr {
30
- margin-right: 0.5rem;
31
- }
32
-
33
- .media-registry-body {
34
- flex: 1;
35
- display: flex;
36
- flex-direction: column;
37
- padding: 0;
38
- overflow: visible;
39
- border: none;
40
- background: transparent;
41
- }
42
-
43
- .media-registry-toolbar {
44
- display: flex;
45
- justify-content: space-between;
46
- align-items: center;
47
- padding: 1rem;
48
- background: var(--opaca-card-bg);
49
- border: 1px solid var(--opaca-border);
50
- border-radius: var(--opaca-radius-lg, 0.5rem);
51
- margin-bottom: 1.5rem;
52
- box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
53
- }
54
-
55
- .media-registry-filters {
56
- display: flex;
57
- gap: 0.75rem;
58
- align-items: center;
59
- width: 100%;
60
- max-width: 600px;
61
- }
62
-
63
- .media-registry-search {
64
- position: relative;
65
- flex: 1;
66
- min-width: 320px;
67
-
68
- .search-icon {
69
- position: absolute;
70
- left: 0.75rem;
71
- top: 50%;
72
- transform: translateY(-50%);
73
- color: var(--opaca-text-dim);
74
- }
75
-
76
- .opaca-ui-input {
77
- padding-left: 2.5rem;
78
- }
79
- }
80
-
81
- .media-registry-select-trigger {
82
- width: 140px;
83
- flex-shrink: 0;
84
- }
85
-
86
- .media-registry-view-toggles {
87
- display: flex;
88
- gap: 0.25rem;
89
- background: var(--opaca-surface);
90
- padding: 0.25rem;
91
- border-radius: var(--opaca-radius-lg, 0.5rem);
92
- border: 1px solid var(--opaca-border);
93
- }
94
-
95
- .media-registry-toggle-btn {
96
- padding: 0.4rem;
97
- border-radius: var(--opaca-radius, 0.375rem);
98
- border: none;
99
- cursor: pointer;
100
- transition: all 0.2s;
101
- background: transparent;
102
- color: var(--opaca-text-dim);
103
- display: flex;
104
- align-items: center;
105
- justify-content: center;
106
-
107
- &:hover {
108
- color: white;
109
- }
110
-
111
- &.active {
112
- background-color: var(--opaca-primary);
113
- color: white;
114
- box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
115
- }
116
- }
117
-
118
- .media-registry-grid {
119
- display: grid;
120
- grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
121
- gap: 1.5rem;
122
- margin-top: 0.5rem;
123
- }
124
-
125
- .media-registry-card {
126
- position: relative;
127
- background: var(--opaca-card-bg);
128
- border-radius: 0.75rem;
129
- border: 1px solid var(--opaca-border);
130
- overflow: hidden;
131
- cursor: pointer;
132
- transition: all 0.2s;
133
- box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
134
-
135
- &:hover {
136
- border-color: var(--opaca-border-hover);
137
- }
138
-
139
- &.active {
140
- border-color: var(--opaca-primary);
141
- box-shadow: 0 0 0 1px var(--opaca-primary);
142
- }
143
- }
144
-
145
- .media-registry-card-thumb {
146
- height: 160px;
147
- background: var(--opaca-surface);
148
- display: flex;
149
- align-items: center;
150
- justify-content: center;
151
- border-bottom: 1px solid var(--opaca-border);
152
- position: relative;
153
- overflow: hidden;
154
-
155
- img {
156
- width: 100%;
157
- height: 100%;
158
- object-fit: cover;
159
- transition: transform 0.5s;
160
- }
161
-
162
- svg.folder-icon {
163
- color: #eab308;
164
- transition: transform 0.3s;
165
- }
166
-
167
- .media-registry-overlay {
168
- position: absolute;
169
- inset: 0;
170
- background: rgba(0, 0, 0, 0.4);
171
- opacity: 0;
172
- transition: opacity 0.2s;
173
- display: flex;
174
- align-items: center;
175
- justify-content: center;
176
- }
177
- }
178
-
179
- .media-registry-card:hover .media-registry-card-thumb img,
180
- .media-registry-card:hover .media-registry-card-thumb svg.folder-icon {
181
- transform: scale(1.05);
182
- }
183
-
184
- .media-registry-card:hover .media-registry-overlay {
185
- opacity: 1;
186
- }
187
-
188
- .media-registry-overlay-btn {
189
- border-radius: 9999px;
190
- background-color: rgba(255, 255, 255, 0.1);
191
- backdrop-filter: blur(12px);
192
- color: white;
193
- border: none;
194
- cursor: pointer;
195
- display: flex;
196
- align-items: center;
197
- justify-content: center;
198
- width: 2.5rem;
199
- height: 2.5rem;
200
- transition: all 0.2s;
201
-
202
- &:hover {
203
- background-color: white;
204
- color: black;
205
- }
206
- }
207
-
208
- .media-registry-card-body {
209
- padding: 1rem;
210
- }
211
-
212
- .media-registry-card-title {
213
- font-size: 0.875rem;
214
- font-weight: 500;
215
- white-space: nowrap;
216
- overflow: hidden;
217
- text-overflow: ellipsis;
218
- color: var(--opaca-text);
219
- }
220
-
221
- .media-registry-card-meta {
222
- font-size: 0.75rem;
223
- color: var(--opaca-text-dim);
224
- display: flex;
225
- justify-content: space-between;
226
- margin-top: 0.375rem;
227
-
228
- .meta-type {
229
- text-transform: uppercase;
230
- letter-spacing: 0.05em;
231
- font-size: 0.65rem;
232
- font-weight: 600;
233
- }
234
- }
235
-
236
- .media-registry-pagination {
237
- display: flex;
238
- align-items: center;
239
- justify-content: space-between;
240
- padding: 1rem;
241
- background: var(--opaca-surface);
242
- border: 1px solid var(--opaca-border);
243
- border-radius: var(--opaca-radius-lg, 0.5rem);
244
- margin-top: 2rem;
245
-
246
- .info {
247
- font-size: 0.875rem;
248
- color: var(--opaca-text-muted);
249
- }
250
-
251
- .actions {
252
- display: flex;
253
- gap: 0.5rem;
254
- }
255
- }
256
-
257
- /* Sheet Layout Elements */
258
- .media-sheet-flex {
259
- flex: 1;
260
- display: flex;
261
- flex-direction: column;
262
- }
263
-
264
- .media-sheet-body {
265
- flex: 1;
266
- overflow-y: auto;
267
- padding-right: 0.5rem;
268
- margin-right: -0.5rem;
269
- }
270
-
271
- .media-sheet-preview {
272
- height: 12rem;
273
- border-radius: var(--opaca-radius-lg, 0.5rem);
274
- background: var(--opaca-surface);
275
- border: 1px solid var(--opaca-border);
276
- display: flex;
277
- align-items: center;
278
- justify-content: center;
279
- overflow: hidden;
280
- margin-bottom: 1rem;
281
- position: relative;
282
-
283
- img {
284
- width: 100%;
285
- height: 100%;
286
- object-fit: contain;
287
- }
288
-
289
- .overlay {
290
- position: absolute;
291
- inset: 0;
292
- background: rgba(0, 0, 0, 0.4);
293
- opacity: 0;
294
- transition: opacity 0.2s;
295
- display: flex;
296
- align-items: center;
297
- justify-content: center;
298
- }
299
-
300
- &:hover .overlay {
301
- opacity: 1;
302
- }
303
- }
304
-
305
- .media-sheet-form {
306
- display: flex;
307
- flex-direction: column;
308
- gap: 1rem;
309
- }
310
-
311
- .media-sheet-group {
312
- display: flex;
313
- flex-direction: column;
314
- gap: 0.5rem;
315
- }
316
-
317
- .media-sheet-textarea {
318
- display: flex;
319
- min-height: 80px;
320
- width: 100%;
321
- border-radius: var(--opaca-radius, 0.375rem);
322
- border: 1px solid var(--opaca-border);
323
- background-color: var(--opaca-surface);
324
- padding: 0.5rem 0.75rem;
325
- font-size: 0.875rem;
326
- color: var(--opaca-text);
327
- outline: none;
328
- font-family: inherit;
329
-
330
- &::placeholder {
331
- color: var(--opaca-text-dim);
332
- }
333
-
334
- &:focus-visible {
335
- border-color: var(--opaca-primary);
336
- box-shadow: 0 0 0 1px var(--opaca-primary);
337
- }
338
- }
339
-
340
- .media-sheet-meta-box {
341
- background: rgba(255, 255, 255, 0.02);
342
- padding: 1rem;
343
- border-radius: var(--opaca-radius-lg, 0.5rem);
344
- border: 1px solid var(--opaca-border);
345
- display: flex;
346
- flex-direction: column;
347
- gap: 0.75rem;
348
- margin-top: 1.5rem;
349
- }
350
-
351
- .media-sheet-meta-row {
352
- display: flex;
353
- justify-content: space-between;
354
- align-items: center;
355
- font-size: 0.875rem;
356
-
357
- .label {
358
- color: var(--opaca-text-dim);
359
- }
360
-
361
- .value {
362
- color: white;
363
- font-weight: 500;
364
- }
365
-
366
- .value-mono {
367
- font-family: monospace;
368
- font-size: 0.75rem;
369
- max-width: 150px;
370
- overflow: hidden;
371
- text-overflow: ellipsis;
372
- white-space: nowrap;
373
- }
374
- }
375
-
376
- .media-sheet-actions {
377
- display: flex;
378
- gap: 0.75rem;
379
- padding-top: 1.5rem;
380
- margin-top: 1.5rem;
381
-
382
- button {
383
- flex: 1;
384
- }
385
- }
386
-
387
- /* Full Preview Layout */
388
- .media-preview-container {
389
- flex: 1;
390
- display: flex;
391
- flex-direction: column;
392
- padding: 1.5rem;
393
- background: rgba(15, 15, 15, 0.7);
394
- backdrop-filter: blur(24px) saturate(180%);
395
- border-radius: 0.5rem;
396
- overflow: hidden;
397
- border: 1px solid rgba(255, 255, 255, 0.1);
398
- box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
399
- max-width: 90vw;
400
- max-height: 90vh;
401
- animation: opaca-zoom-in 0.3s cubic-bezier(0.16, 1, 0.3, 1);
402
-
403
- @media (min-width: 640px) {
404
- padding: 1rem;
405
- }
406
- }
407
-
408
- @keyframes opaca-zoom-in {
409
- from {
410
- opacity: 0;
411
- transform: scale(0.95);
412
- }
413
-
414
- to {
415
- opacity: 1;
416
- transform: scale(1);
417
- }
418
- }
419
-
420
- .media-preview-header {
421
- display: flex;
422
- justify-content: space-between;
423
- align-items: center;
424
- margin-bottom: 1.5rem;
425
- flex-shrink: 0;
426
- z-index: 10;
427
- }
428
-
429
- .media-preview-title-group {
430
- display: flex;
431
- align-items: center;
432
- gap: 0.75rem;
433
-
434
- h2 {
435
- font-size: 1.25rem;
436
- font-weight: 600;
437
- color: white;
438
- margin: 0;
439
- }
440
-
441
- .badge {
442
- padding: 0.125rem 0.5rem;
443
- border-radius: 0.25rem;
444
- font-size: 0.75rem;
445
- font-family: monospace;
446
- background: rgba(255, 255, 255, 0.1);
447
- color: white;
448
- border: 1px solid rgba(255, 255, 255, 0.2);
449
- }
450
- }
451
-
452
- .media-preview-close-btn {
453
- color: white;
454
- background: transparent;
455
- border-radius: 9999px;
456
- height: 2.5rem;
457
- width: 2.5rem;
458
- display: flex;
459
- align-items: center;
460
- justify-content: center;
461
- border: none;
462
- cursor: pointer;
463
- transition: background 0.2s;
464
-
465
- &:hover {
466
- background: rgba(255, 255, 255, 0.1);
467
- }
468
- }
469
-
470
- .media-preview-body {
471
- flex: 1;
472
- display: flex;
473
- align-items: center;
474
- justify-content: center;
475
- min-height: 0;
476
- position: relative;
477
-
478
- img {
479
- max-width: 100%;
480
- max-height: 100%;
481
- object-fit: contain;
482
- filter: drop-shadow(0 25px 25px rgba(0, 0, 0, 0.5));
483
- }
484
- }
485
-
486
- .media-preview-no-rich {
487
- text-align: center;
488
- padding: 2rem;
489
- background: rgba(255, 255, 255, 0.05);
490
- border-radius: 1rem;
491
- border: 1px solid rgba(255, 255, 255, 0.1);
492
- backdrop-filter: blur(4px);
493
-
494
- .icon-wrapper {
495
- display: flex;
496
- justify-content: center;
497
- margin-bottom: 1.5rem;
498
- }
499
-
500
- p {
501
- color: var(--opaca-text-dim);
502
- margin-bottom: 1.5rem;
503
- }
504
- }
505
-
506
- .media-preview-footer {
507
- margin-top: 2rem;
508
- display: flex;
509
- justify-content: center;
510
- gap: 1rem;
511
- flex-shrink: 0;
512
- }
513
-
514
- .media-preview-stat {
515
- background: rgba(255, 255, 255, 0.03);
516
- backdrop-filter: blur(8px);
517
- padding: 0.75rem 1.5rem;
518
- border-radius: 1rem;
519
- border: 1px solid rgba(255, 255, 255, 0.05);
520
- text-align: center;
521
- transition: all 0.2s;
522
-
523
- &:hover {
524
- background: rgba(255, 255, 255, 0.06);
525
- transform: translateY(-2px);
526
- }
527
-
528
- .label {
529
- font-size: 0.75rem;
530
- color: var(--opaca-text-dim);
531
- text-transform: uppercase;
532
- letter-spacing: 0.05em;
533
- margin-bottom: 0.25rem;
534
- }
535
-
536
- .value {
537
- font-weight: 600;
538
- color: white;
539
- }
540
- }
541
-
542
- .media-dialog-create-body {
543
- padding: 1rem 0;
544
- }
545
-
546
- .media-bucket-settings {
547
- display: flex;
548
- flex-direction: column;
549
- gap: 1.5rem;
550
- padding: 1rem 0;
551
-
552
- .bucket-setting-row {
553
- display: flex;
554
- flex-direction: column;
555
- gap: 0.75rem;
556
-
557
- .bucket-name {
558
- font-size: 0.75rem;
559
- font-weight: 600;
560
- color: var(--opaca-text-dim);
561
- text-transform: uppercase;
562
- letter-spacing: 0.05em;
563
- }
564
-
565
- .color-presets {
566
- display: flex;
567
- flex-wrap: wrap;
568
- gap: 0.5rem;
569
-
570
- .color-bubble {
571
- width: 24px;
572
- height: 24px;
573
- border-radius: 50%;
574
- border: 2px solid transparent;
575
- cursor: pointer;
576
- transition: all var(--opaca-transition);
577
- padding: 0;
578
- display: flex;
579
- align-items: center;
580
- justify-content: center;
581
-
582
- &:hover {
583
- transform: scale(1.1);
584
- }
585
-
586
- &.active {
587
- border-color: white;
588
- box-shadow: 0 0 0 2px var(--opaca-primary);
589
- }
590
- }
591
- }
592
- }
593
- }
594
-
595
- .media-registry-dialog-sm {
596
- max-width: 400px;
597
- }
@@ -1,20 +0,0 @@
1
- @use './variables';
2
-
3
- .opaca-pagination {
4
- display: flex;
5
- align-items: center;
6
- justify-content: space-between;
7
- padding: 1rem;
8
- border-top: 1px solid var(--opaca-border);
9
- background-color: var(--opaca-sidebar-bg);
10
- }
11
-
12
- .opaca-pagination-info {
13
- font-size: 0.75rem;
14
- color: var(--opaca-text-dim);
15
- }
16
-
17
- .opaca-pagination-actions {
18
- display: flex;
19
- gap: 0.5rem;
20
- }
@@ -1,66 +0,0 @@
1
- .opaca-ui-radio-group {
2
- display: grid;
3
- gap: 0.75rem;
4
- }
5
-
6
- .opaca-ui-radio-item {
7
- display: flex;
8
- align-items: center;
9
- gap: 0.75rem;
10
-
11
- input[type="radio"] {
12
- appearance: none;
13
- margin: 0;
14
- width: 1.125rem;
15
- height: 1.125rem;
16
- border: 1px solid var(--opaca-border);
17
- border-radius: 50%;
18
- outline: none;
19
- cursor: pointer;
20
- position: relative;
21
- background-color: var(--opaca-surface);
22
- transition: all var(--opaca-transition);
23
-
24
- &:hover:not(:disabled) {
25
- border-color: var(--opaca-accent);
26
- }
27
-
28
- &:checked {
29
- border-color: var(--opaca-primary);
30
- background-color: var(--opaca-primary);
31
-
32
- &::after {
33
- content: "";
34
- position: absolute;
35
- top: 50%;
36
- left: 50%;
37
- transform: translate(-50%, -50%);
38
- width: 0.375rem;
39
- height: 0.375rem;
40
- border-radius: 50%;
41
- background-color: white;
42
- }
43
- }
44
-
45
- &:focus-visible {
46
- box-shadow: 0 0 0 2px var(--opaca-primary-glow);
47
- }
48
-
49
- &:disabled {
50
- cursor: not-allowed;
51
- opacity: 0.5;
52
- }
53
- }
54
-
55
- label {
56
- cursor: pointer;
57
- font-size: 0.8125rem;
58
- font-weight: 400;
59
- color: var(--opaca-text);
60
-
61
- &.disabled {
62
- cursor: not-allowed;
63
- opacity: 0.5;
64
- }
65
- }
66
- }
@@ -1,17 +0,0 @@
1
- .opaca-row-field {
2
- display: flex;
3
- flex-wrap: wrap;
4
- gap: 1rem;
5
- margin-bottom: 1.25rem;
6
-
7
- .row-item {
8
- flex: 1;
9
- min-width: 0;
10
-
11
- // Inside row items, we want to remove the standard margin-bottom
12
- // to keep the row compact
13
- .opaca-form-group {
14
- margin-bottom: 0;
15
- }
16
- }
17
- }
@@ -1,36 +0,0 @@
1
- @use './variables';
2
-
3
- .opaca-admin {
4
- ::-webkit-scrollbar {
5
- width: 6px;
6
- height: 6px;
7
- }
8
-
9
- ::-webkit-scrollbar-track {
10
- background: transparent;
11
- }
12
-
13
- ::-webkit-scrollbar-thumb {
14
- background: var(--opaca-border);
15
- border-radius: 10px;
16
-
17
- &:hover {
18
- background: var(--opaca-border-hover);
19
- }
20
- }
21
- }
22
-
23
- .opaca-scroll-area {
24
- &::-webkit-scrollbar {
25
- width: 4px;
26
- }
27
-
28
- &::-webkit-scrollbar-thumb {
29
- background: var(--opaca-border);
30
- border-radius: 10px;
31
-
32
- &:hover {
33
- background: var(--opaca-accent);
34
- }
35
- }
36
- }