@conduction/nextcloud-vue 0.1.0-beta.1 → 0.1.0-beta.11

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 (208) hide show
  1. package/README.md +226 -0
  2. package/css/index.css +5 -0
  3. package/dist/nextcloud-vue.cjs.js +79416 -7715
  4. package/dist/nextcloud-vue.cjs.js.map +1 -1
  5. package/dist/nextcloud-vue.css +3583 -504
  6. package/dist/nextcloud-vue.esm.js +79343 -7692
  7. package/dist/nextcloud-vue.esm.js.map +1 -1
  8. package/l10n/en.json +164 -0
  9. package/l10n/nl.json +164 -0
  10. package/package.json +104 -63
  11. package/src/components/CnActionsBar/CnActionsBar.vue +254 -0
  12. package/src/components/CnActionsBar/index.js +1 -0
  13. package/src/components/CnAdvancedFormDialog/CnAdvancedFormDialog.vue +570 -0
  14. package/src/components/CnAdvancedFormDialog/CnDataTab.vue +217 -0
  15. package/src/components/CnAdvancedFormDialog/CnMetadataTab.vue +121 -0
  16. package/src/components/CnAdvancedFormDialog/CnPropertiesTab.vue +422 -0
  17. package/src/components/CnAdvancedFormDialog/CnPropertyValueCell.vue +247 -0
  18. package/src/components/CnAdvancedFormDialog/index.js +1 -0
  19. package/src/components/CnCard/CnCard.vue +415 -0
  20. package/src/components/CnCard/index.js +1 -0
  21. package/src/components/CnCardGrid/CnCardGrid.vue +156 -152
  22. package/src/components/CnCardGrid/index.js +1 -1
  23. package/src/components/CnCellRenderer/CnCellRenderer.vue +132 -132
  24. package/src/components/CnCellRenderer/index.js +1 -1
  25. package/src/components/CnChartWidget/CnChartWidget.vue +346 -0
  26. package/src/components/CnChartWidget/index.js +1 -0
  27. package/src/components/CnConfigurationCard/CnConfigurationCard.vue +77 -77
  28. package/src/components/CnConfigurationCard/index.js +1 -1
  29. package/src/components/CnContextMenu/CnContextMenu.vue +142 -0
  30. package/src/components/CnContextMenu/index.js +1 -0
  31. package/src/components/CnCopyDialog/CnCopyDialog.vue +266 -0
  32. package/src/components/CnCopyDialog/index.js +1 -0
  33. package/src/components/CnDashboardGrid/CnDashboardGrid.vue +229 -0
  34. package/src/components/CnDashboardGrid/index.js +1 -0
  35. package/src/components/CnDashboardPage/CnDashboardPage.vue +397 -0
  36. package/src/components/CnDashboardPage/index.js +1 -0
  37. package/src/components/CnDataTable/CnDataTable.vue +362 -354
  38. package/src/components/CnDataTable/index.js +1 -1
  39. package/src/components/CnDeleteDialog/CnDeleteDialog.vue +177 -0
  40. package/src/components/CnDeleteDialog/index.js +1 -0
  41. package/src/components/CnDetailCard/CnDetailCard.vue +225 -0
  42. package/src/components/CnDetailCard/index.js +1 -0
  43. package/src/components/CnDetailGrid/CnDetailGrid.vue +256 -0
  44. package/src/components/CnDetailGrid/index.js +1 -0
  45. package/src/components/CnDetailPage/CnDetailPage.vue +432 -0
  46. package/src/components/CnDetailPage/index.js +1 -0
  47. package/src/components/CnFacetSidebar/CnFacetSidebar.vue +234 -223
  48. package/src/components/CnFacetSidebar/index.js +1 -1
  49. package/src/components/CnFilterBar/CnFilterBar.vue +153 -152
  50. package/src/components/CnFilterBar/index.js +1 -1
  51. package/src/components/CnFormDialog/CnFormDialog.vue +1047 -0
  52. package/src/components/CnFormDialog/index.js +1 -0
  53. package/src/components/CnIcon/CnIcon.vue +89 -0
  54. package/src/components/CnIcon/index.js +1 -0
  55. package/src/components/CnIndexPage/CnIndexPage.vue +980 -682
  56. package/src/components/CnIndexPage/index.js +1 -1
  57. package/src/components/CnIndexSidebar/CnIndexSidebar.vue +536 -0
  58. package/src/components/CnIndexSidebar/index.js +1 -0
  59. package/src/components/CnInfoWidget/CnInfoWidget.vue +219 -0
  60. package/src/components/CnInfoWidget/index.js +1 -0
  61. package/src/components/CnItemCard/CnItemCard.vue +134 -0
  62. package/src/components/CnItemCard/index.js +1 -0
  63. package/src/components/CnJsonViewer/CnJsonViewer.vue +312 -0
  64. package/src/components/CnJsonViewer/index.js +1 -0
  65. package/src/components/CnKpiGrid/CnKpiGrid.vue +93 -89
  66. package/src/components/CnKpiGrid/index.js +1 -1
  67. package/src/components/CnMassActionBar/CnMassActionBar.vue +161 -160
  68. package/src/components/CnMassActionBar/index.js +1 -1
  69. package/src/components/CnMassCopyDialog/CnMassCopyDialog.vue +327 -320
  70. package/src/components/CnMassCopyDialog/index.js +1 -1
  71. package/src/components/CnMassDeleteDialog/CnMassDeleteDialog.vue +245 -238
  72. package/src/components/CnMassDeleteDialog/index.js +1 -1
  73. package/src/components/CnMassExportDialog/CnMassExportDialog.vue +191 -190
  74. package/src/components/CnMassExportDialog/index.js +1 -1
  75. package/src/components/CnMassImportDialog/CnMassImportDialog.vue +494 -491
  76. package/src/components/CnMassImportDialog/index.js +1 -1
  77. package/src/components/CnNoteCard/CnNoteCard.vue +149 -0
  78. package/src/components/CnNoteCard/index.js +1 -0
  79. package/src/components/CnNotesCard/CnNotesCard.vue +416 -0
  80. package/src/components/CnNotesCard/index.js +1 -0
  81. package/src/components/CnObjectCard/CnObjectCard.vue +294 -292
  82. package/src/components/CnObjectCard/index.js +1 -1
  83. package/src/components/CnObjectDataWidget/CnObjectDataWidget.vue +854 -0
  84. package/src/components/CnObjectDataWidget/index.js +1 -0
  85. package/src/components/CnObjectMetadataWidget/CnObjectMetadataWidget.vue +289 -0
  86. package/src/components/CnObjectMetadataWidget/index.js +1 -0
  87. package/src/components/CnObjectSidebar/CnAuditTrailTab.vue +369 -0
  88. package/src/components/CnObjectSidebar/CnFilesTab.vue +287 -0
  89. package/src/components/CnObjectSidebar/CnNotesTab.vue +250 -0
  90. package/src/components/CnObjectSidebar/CnObjectSidebar.vue +255 -0
  91. package/src/components/CnObjectSidebar/CnTagsTab.vue +259 -0
  92. package/src/components/CnObjectSidebar/CnTasksTab.vue +483 -0
  93. package/src/components/CnObjectSidebar/index.js +6 -0
  94. package/src/components/CnPageHeader/CnPageHeader.vue +61 -0
  95. package/src/components/CnPageHeader/index.js +1 -0
  96. package/src/components/CnPagination/CnPagination.vue +253 -252
  97. package/src/components/CnPagination/index.js +1 -1
  98. package/src/components/CnProgressBar/CnProgressBar.vue +262 -0
  99. package/src/components/CnProgressBar/index.js +1 -0
  100. package/src/components/CnRegisterMapping/CnRegisterMapping.vue +793 -0
  101. package/src/components/CnRegisterMapping/index.js +1 -0
  102. package/src/components/CnRowActions/CnRowActions.vue +95 -73
  103. package/src/components/CnRowActions/index.js +1 -1
  104. package/src/components/CnSchemaFormDialog/CnSchemaConfigurationTab.vue +226 -0
  105. package/src/components/CnSchemaFormDialog/CnSchemaFormDialog.vue +788 -0
  106. package/src/components/CnSchemaFormDialog/CnSchemaPropertiesTab.vue +305 -0
  107. package/src/components/CnSchemaFormDialog/CnSchemaPropertyActions.vue +1398 -0
  108. package/src/components/CnSchemaFormDialog/CnSchemaSecurityTab.vue +236 -0
  109. package/src/components/CnSchemaFormDialog/index.js +1 -0
  110. package/src/components/CnSettingsCard/CnSettingsCard.vue +92 -92
  111. package/src/components/CnSettingsCard/index.js +1 -1
  112. package/src/components/CnSettingsSection/CnSettingsSection.vue +267 -266
  113. package/src/components/CnSettingsSection/index.js +1 -1
  114. package/src/components/CnStatsBlock/CnStatsBlock.vue +437 -366
  115. package/src/components/CnStatsBlock/index.js +1 -1
  116. package/src/components/CnStatsPanel/CnStatsPanel.vue +321 -0
  117. package/src/components/CnStatsPanel/index.js +1 -0
  118. package/src/components/CnStatusBadge/CnStatusBadge.vue +90 -77
  119. package/src/components/CnStatusBadge/index.js +1 -1
  120. package/src/components/CnTabbedFormDialog/CnTabbedFormDialog.vue +545 -0
  121. package/src/components/CnTabbedFormDialog/index.js +1 -0
  122. package/src/components/CnTableWidget/CnTableWidget.vue +333 -0
  123. package/src/components/CnTableWidget/index.js +1 -0
  124. package/src/components/CnTasksCard/CnTasksCard.vue +374 -0
  125. package/src/components/CnTasksCard/index.js +1 -0
  126. package/src/components/CnTileWidget/CnTileWidget.vue +159 -0
  127. package/src/components/CnTileWidget/index.js +1 -0
  128. package/src/components/CnTimelineStages/CnTimelineStages.vue +294 -0
  129. package/src/components/CnTimelineStages/index.js +1 -0
  130. package/src/components/CnUserActionMenu/CnUserActionMenu.vue +436 -0
  131. package/src/components/CnUserActionMenu/index.js +1 -0
  132. package/src/components/CnVersionInfoCard/CnVersionInfoCard.vue +313 -312
  133. package/src/components/CnVersionInfoCard/index.js +1 -1
  134. package/src/components/CnWidgetRenderer/CnWidgetRenderer.vue +180 -0
  135. package/src/components/CnWidgetRenderer/index.js +1 -0
  136. package/src/components/CnWidgetWrapper/CnWidgetWrapper.vue +248 -0
  137. package/src/components/CnWidgetWrapper/index.js +1 -0
  138. package/src/components/index.js +57 -25
  139. package/src/composables/index.js +5 -3
  140. package/src/composables/useContextMenu.js +126 -0
  141. package/src/composables/useDashboardView.js +286 -0
  142. package/src/composables/useDetailView.js +290 -132
  143. package/src/composables/useListView.js +364 -153
  144. package/src/composables/useSubResource.js +142 -142
  145. package/src/constants/metadata.js +30 -0
  146. package/src/css/CnSchemaFormDialog.css +546 -0
  147. package/src/css/__sample_nextcloud_tokens.css +110 -0
  148. package/src/css/actions-bar.css +54 -0
  149. package/src/css/badge.css +83 -51
  150. package/src/css/card.css +129 -128
  151. package/src/css/context-menu.css +20 -0
  152. package/src/css/dashboard.css +70 -0
  153. package/src/css/detail-page.css +235 -0
  154. package/src/css/detail.css +68 -68
  155. package/src/css/index-page.css +44 -0
  156. package/src/css/index-sidebar.css +193 -0
  157. package/src/css/index.css +17 -8
  158. package/src/css/layout.css +90 -90
  159. package/src/css/page-header.css +35 -0
  160. package/src/css/pagination.css +72 -72
  161. package/src/css/table.css +142 -143
  162. package/src/css/timeline-stages.css +220 -0
  163. package/src/css/utilities.css +46 -46
  164. package/src/index.js +95 -50
  165. package/src/l10n/index.js +12 -0
  166. package/src/mixins/gridLayout.js +118 -0
  167. package/src/store/createCrudStore.d.ts +350 -0
  168. package/src/store/createCrudStore.js +413 -0
  169. package/src/store/createSubResourcePlugin.js +125 -135
  170. package/src/store/index.js +4 -3
  171. package/src/store/pluginMerge.js +55 -0
  172. package/src/store/plugins/auditTrails.js +357 -17
  173. package/src/store/plugins/files.js +250 -186
  174. package/src/store/plugins/index.js +8 -4
  175. package/src/store/plugins/lifecycle.js +180 -180
  176. package/src/store/plugins/logs.d.ts +22 -0
  177. package/src/store/plugins/logs.js +172 -0
  178. package/src/store/plugins/registerMapping.js +195 -0
  179. package/src/store/plugins/relations.js +68 -68
  180. package/src/store/plugins/search.js +385 -0
  181. package/src/store/plugins/selection.js +104 -0
  182. package/src/store/useObjectStore.js +793 -625
  183. package/src/types/auditTrail.d.ts +32 -32
  184. package/src/types/file.d.ts +23 -23
  185. package/src/types/index.d.ts +67 -35
  186. package/src/types/notification.d.ts +36 -36
  187. package/src/types/object.d.ts +40 -40
  188. package/src/types/organisation.d.ts +41 -41
  189. package/src/types/register.d.ts +25 -25
  190. package/src/types/schema.d.ts +39 -39
  191. package/src/types/shared.d.ts +79 -79
  192. package/src/types/source.d.ts +14 -14
  193. package/src/types/task.d.ts +31 -31
  194. package/src/utils/errors.js +96 -96
  195. package/src/utils/getTheme.js +9 -0
  196. package/src/utils/headers.js +80 -44
  197. package/src/utils/id.js +13 -0
  198. package/src/utils/index.js +4 -3
  199. package/src/utils/schema.js +423 -287
  200. package/src/utils/widgetVisibility.js +162 -0
  201. package/src/components/CnDetailViewLayout/CnDetailViewLayout.vue +0 -88
  202. package/src/components/CnDetailViewLayout/index.js +0 -1
  203. package/src/components/CnEmptyState/CnEmptyState.vue +0 -78
  204. package/src/components/CnEmptyState/index.js +0 -1
  205. package/src/components/CnListViewLayout/CnListViewLayout.vue +0 -80
  206. package/src/components/CnListViewLayout/index.js +0 -1
  207. package/src/components/CnViewModeToggle/CnViewModeToggle.vue +0 -77
  208. package/src/components/CnViewModeToggle/index.js +0 -1
@@ -0,0 +1,220 @@
1
+ /* =============================================
2
+ CnTimelineStages — Timeline / progress stages
3
+ ============================================= */
4
+
5
+ /* ---------- Root container ---------- */
6
+ .cn-timeline-stages {
7
+ display: flex;
8
+ align-items: flex-start;
9
+ gap: 0;
10
+ width: 100%;
11
+ }
12
+
13
+ /* Horizontal: left-to-right, scrollable overflow */
14
+ .cn-timeline-stages--horizontal {
15
+ flex-direction: row;
16
+ overflow-x: auto;
17
+ padding-bottom: calc(var(--default-grid-baseline, 4px) * 1);
18
+ }
19
+
20
+ /* Vertical: top-to-bottom */
21
+ .cn-timeline-stages--vertical {
22
+ flex-direction: column;
23
+ }
24
+
25
+ /* ---------- Stage node ---------- */
26
+ .cn-timeline-stages__stage {
27
+ display: flex;
28
+ flex-direction: column;
29
+ align-items: center;
30
+ position: relative;
31
+ flex: 1 1 0;
32
+ min-width: calc(var(--default-grid-baseline, 4px) * 20); /* 80px */
33
+ text-align: center;
34
+ padding: calc(var(--default-grid-baseline, 4px) * 1);
35
+ border-radius: var(--border-radius-large, 10px);
36
+ transition: background-color 0.15s ease;
37
+ }
38
+
39
+ /* Vertical stages: row layout */
40
+ .cn-timeline-stages--vertical .cn-timeline-stages__stage {
41
+ flex-direction: row;
42
+ align-items: center;
43
+ text-align: left;
44
+ min-width: 0;
45
+ gap: calc(var(--default-grid-baseline, 4px) * 3);
46
+ }
47
+
48
+ /* ---------- Track line (horizontal) ---------- */
49
+ .cn-timeline-stages--horizontal .cn-timeline-stages__stage + .cn-timeline-stages__stage::before {
50
+ content: '';
51
+ position: absolute;
52
+ top: 16px; /* half of 32px indicator */
53
+ right: calc(50% + 16px + 4px);
54
+ left: calc(-50% + 16px + 4px);
55
+ height: 2px;
56
+ background-color: var(--color-border, #ededed);
57
+ z-index: 0;
58
+ }
59
+
60
+ /* Completed + current track segments: filled */
61
+ .cn-timeline-stages--horizontal .cn-timeline-stages__stage--completed + .cn-timeline-stages__stage::before,
62
+ .cn-timeline-stages--horizontal .cn-timeline-stages__stage--completed + .cn-timeline-stages__stage--current::before {
63
+ background-color: var(--color-success-text, var(--color-success, #46ba61));
64
+ }
65
+
66
+ /* ---------- Track line (vertical) ---------- */
67
+ .cn-timeline-stages--vertical .cn-timeline-stages__stage + .cn-timeline-stages__stage::before {
68
+ content: '';
69
+ position: absolute;
70
+ left: 15px; /* center of 32px indicator */
71
+ top: -6px;
72
+ height: 6px;
73
+ width: 2px;
74
+ background-color: var(--color-border, #ededed);
75
+ z-index: 0;
76
+ }
77
+
78
+ /* Completed + current track segments: filled (vertical) */
79
+ .cn-timeline-stages--vertical .cn-timeline-stages__stage--completed + .cn-timeline-stages__stage::before,
80
+ .cn-timeline-stages--vertical .cn-timeline-stages__stage--completed + .cn-timeline-stages__stage--current::before {
81
+ background-color: var(--color-success-text, var(--color-success, #46ba61));
82
+ }
83
+
84
+ /* ---------- Indicator (circle) ---------- */
85
+ .cn-timeline-stages__indicator {
86
+ display: flex;
87
+ align-items: center;
88
+ justify-content: center;
89
+ width: 32px;
90
+ height: 32px;
91
+ border-radius: 50%;
92
+ flex-shrink: 0;
93
+ position: relative;
94
+ z-index: 1;
95
+ border: 2px solid var(--color-border, #ededed);
96
+ background-color: var(--color-main-background, #fff);
97
+ transition: background-color 0.15s ease, border-color 0.15s ease;
98
+ }
99
+
100
+ /* Completed indicator: success green with white icon */
101
+ .cn-timeline-stages__stage--completed .cn-timeline-stages__indicator {
102
+ background-color: var(--color-success-text, var(--color-success, #46ba61));
103
+ border-color: var(--color-success-text, var(--color-success, #46ba61));
104
+ color: #fff;
105
+ }
106
+
107
+ /* Current indicator: primary blue */
108
+ .cn-timeline-stages__stage--current .cn-timeline-stages__indicator {
109
+ background-color: var(--color-primary-element, #0082c9);
110
+ border-color: var(--color-primary-element, #0082c9);
111
+ color: var(--color-primary-element-text, #fff);
112
+ }
113
+
114
+ /* ---------- Checkmark SVG ---------- */
115
+ .cn-timeline-stages__checkmark {
116
+ width: 16px;
117
+ height: 16px;
118
+ }
119
+
120
+ /* ---------- Current dot ---------- */
121
+ .cn-timeline-stages__dot {
122
+ display: block;
123
+ width: 10px;
124
+ height: 10px;
125
+ border-radius: 50%;
126
+ background-color: currentColor;
127
+ }
128
+
129
+ /* ---------- Label ---------- */
130
+ .cn-timeline-stages__label {
131
+ display: block;
132
+ margin-top: calc(var(--default-grid-baseline, 4px) * 1);
133
+ font-size: 0.9em;
134
+ line-height: 1.3;
135
+ color: var(--color-text-maxcontrast, #767676);
136
+ word-break: break-word;
137
+ }
138
+
139
+ /* Vertical: label aligns with indicator center */
140
+ .cn-timeline-stages--vertical .cn-timeline-stages__label {
141
+ margin-top: 0;
142
+ }
143
+
144
+ /* Completed stage label */
145
+ .cn-timeline-stages__stage--completed .cn-timeline-stages__label {
146
+ color: var(--color-main-text, #222);
147
+ }
148
+
149
+ /* Current stage label: bold and prominent */
150
+ .cn-timeline-stages__stage--current .cn-timeline-stages__label {
151
+ color: var(--color-main-text, #222);
152
+ font-weight: bold;
153
+ }
154
+
155
+ /* ---------- Subtitle ---------- */
156
+ .cn-timeline-stages__subtitle {
157
+ display: block;
158
+ font-size: 0.8em;
159
+ line-height: 1.3;
160
+ color: var(--color-text-maxcontrast, #767676);
161
+ margin-top: 2px;
162
+ }
163
+
164
+ /* ---------- Small size variant ---------- */
165
+ .cn-timeline-stages--small .cn-timeline-stages__indicator {
166
+ width: 20px;
167
+ height: 20px;
168
+ }
169
+
170
+ .cn-timeline-stages--small .cn-timeline-stages__checkmark {
171
+ width: 12px;
172
+ height: 12px;
173
+ }
174
+
175
+ .cn-timeline-stages--small .cn-timeline-stages__dot {
176
+ width: 6px;
177
+ height: 6px;
178
+ }
179
+
180
+ .cn-timeline-stages--small .cn-timeline-stages__label {
181
+ font-size: 0.85em;
182
+ }
183
+
184
+ .cn-timeline-stages--small .cn-timeline-stages__stage {
185
+ min-width: calc(var(--default-grid-baseline, 4px) * 14); /* 56px */
186
+ }
187
+
188
+ /* Small horizontal track line offset */
189
+ .cn-timeline-stages--small.cn-timeline-stages--horizontal .cn-timeline-stages__stage + .cn-timeline-stages__stage::before {
190
+ top: 10px; /* half of 20px */
191
+ right: calc(50% + 10px + 4px);
192
+ left: calc(-50% + 10px + 4px);
193
+ }
194
+
195
+ /* Small vertical track line offset */
196
+ .cn-timeline-stages--small.cn-timeline-stages--vertical .cn-timeline-stages__stage + .cn-timeline-stages__stage::before {
197
+ left: 9px; /* center of 20px indicator */
198
+ top: -6px;
199
+ height: 6px;
200
+ }
201
+
202
+ /* ---------- Clickable mode ---------- */
203
+ .cn-timeline-stages--clickable .cn-timeline-stages__stage {
204
+ cursor: pointer;
205
+ }
206
+
207
+ .cn-timeline-stages--clickable .cn-timeline-stages__stage:hover {
208
+ background-color: var(--color-background-dark, #ededed);
209
+ }
210
+
211
+ /* Focus ring (keyboard only) */
212
+ .cn-timeline-stages--clickable .cn-timeline-stages__stage:focus-visible {
213
+ outline: 2px solid var(--color-primary-element, #0082c9);
214
+ outline-offset: 2px;
215
+ }
216
+
217
+ /* Remove default outline for mouse clicks */
218
+ .cn-timeline-stages--clickable .cn-timeline-stages__stage:focus:not(:focus-visible) {
219
+ outline: none;
220
+ }
@@ -1,46 +1,46 @@
1
- /* ========================================
2
- @conduction/nextcloud-vue — Utilities
3
- ======================================== */
4
-
5
- /* Text Utilities */
6
- .cn-text-ellipsis {
7
- overflow: hidden;
8
- text-overflow: ellipsis;
9
- white-space: nowrap;
10
- }
11
-
12
- .cn-text-description {
13
- font-size: 0.9em;
14
- color: var(--color-text-maxcontrast);
15
- }
16
-
17
- .cn-text-success { color: var(--color-success); }
18
- .cn-text-error { color: var(--color-error); }
19
- .cn-text-warning { color: var(--color-warning); }
20
- .cn-text-muted { color: var(--color-text-maxcontrast); }
21
-
22
- /* Vue Transition Animations */
23
- .cn-slide-fade-enter-active {
24
- transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
25
- }
26
-
27
- .cn-slide-fade-leave-active {
28
- transition: all 0.3s cubic-bezier(0.4, 0, 1, 1);
29
- }
30
-
31
- .cn-slide-fade-enter,
32
- .cn-slide-fade-enter-from {
33
- transform: translateY(-10px);
34
- opacity: 0;
35
- }
36
-
37
- .cn-slide-fade-leave-to {
38
- transform: translateY(-5px);
39
- opacity: 0;
40
- }
41
-
42
- /* Backwards compatibility aliases */
43
- .textEllipsis { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
44
- .textDescription { font-size: 0.9em; color: var(--color-text-maxcontrast); }
45
- .successMessage { color: var(--color-success); }
46
- .errorMessage { color: var(--color-error); }
1
+ /* ========================================
2
+ @conduction/nextcloud-vue — Utilities
3
+ ======================================== */
4
+
5
+ /* Text Utilities */
6
+ .cn-text-ellipsis {
7
+ overflow: hidden;
8
+ text-overflow: ellipsis;
9
+ white-space: nowrap;
10
+ }
11
+
12
+ .cn-text-description {
13
+ font-size: 0.9em;
14
+ color: var(--color-text-maxcontrast);
15
+ }
16
+
17
+ .cn-text-success { color: var(--color-success); }
18
+ .cn-text-error { color: var(--color-error); }
19
+ .cn-text-warning { color: var(--color-warning); }
20
+ .cn-text-muted { color: var(--color-text-maxcontrast); }
21
+
22
+ /* Vue Transition Animations */
23
+ .cn-slide-fade-enter-active {
24
+ transition: all var(--animation-slow) cubic-bezier(0.4, 0, 0.2, 1);
25
+ }
26
+
27
+ .cn-slide-fade-leave-active {
28
+ transition: all var(--animation-quick) cubic-bezier(0.4, 0, 1, 1);
29
+ }
30
+
31
+ .cn-slide-fade-enter,
32
+ .cn-slide-fade-enter-from {
33
+ transform: translateY(-10px);
34
+ opacity: 0;
35
+ }
36
+
37
+ .cn-slide-fade-leave-to {
38
+ transform: translateY(-5px);
39
+ opacity: 0;
40
+ }
41
+
42
+ /* Backwards compatibility aliases */
43
+ .textEllipsis { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
44
+ .textDescription { font-size: 0.9em; color: var(--color-text-maxcontrast); }
45
+ .successMessage { color: var(--color-success); }
46
+ .errorMessage { color: var(--color-error); }
package/src/index.js CHANGED
@@ -1,50 +1,95 @@
1
- // Components
2
- export {
3
- CnDataTable,
4
- CnFilterBar,
5
- CnListViewLayout,
6
- CnDetailViewLayout,
7
- CnStatusBadge,
8
- CnEmptyState,
9
- CnPagination,
10
- CnSettingsCard,
11
- CnSettingsSection,
12
- CnStatsBlock,
13
- CnConfigurationCard,
14
- CnVersionInfoCard,
15
- CnCellRenderer,
16
- CnObjectCard,
17
- CnCardGrid,
18
- CnFacetSidebar,
19
- CnViewModeToggle,
20
- CnRowActions,
21
- CnIndexPage,
22
- CnMassActionBar,
23
- CnMassDeleteDialog,
24
- CnMassCopyDialog,
25
- CnKpiGrid,
26
- CnMassExportDialog,
27
- CnMassImportDialog,
28
- } from './components/index.js'
29
-
30
- // Store
31
- export { useObjectStore, createObjectStore } from './store/index.js'
32
- export { createSubResourcePlugin, emptyPaginated } from './store/index.js'
33
-
34
- // Store plugins
35
- export {
36
- auditTrailsPlugin,
37
- relationsPlugin,
38
- filesPlugin,
39
- lifecyclePlugin,
40
- } from './store/plugins/index.js'
41
-
42
- // Composables
43
- export { useListView, useDetailView, useSubResource } from './composables/index.js'
44
-
45
- // Utilities
46
- export { buildHeaders, buildQueryString, parseResponseError, networkError, genericError } from './utils/index.js'
47
- export { columnsFromSchema, formatValue, filtersFromSchema } from './utils/index.js'
48
-
49
- // CSS (consumers should import separately)
50
- // import '@conduction/nextcloud-vue/src/css/index.css'
1
+ // CSS — auto-imported so consumers get styles with components
2
+ import './css/index.css'
3
+
4
+ // Components
5
+ export {
6
+ CnDataTable,
7
+ CnFilterBar,
8
+ CnStatusBadge,
9
+ CnPagination,
10
+ CnSettingsCard,
11
+ CnSettingsSection,
12
+ CnStatsBlock,
13
+ CnConfigurationCard,
14
+ CnVersionInfoCard,
15
+ CnCellRenderer,
16
+ CnObjectCard,
17
+ CnCardGrid,
18
+ CnFacetSidebar,
19
+ CnRowActions,
20
+ CnContextMenu,
21
+ CnIndexPage,
22
+ CnMassActionBar,
23
+ CnDeleteDialog,
24
+ CnCopyDialog,
25
+ CnFormDialog,
26
+ CnAdvancedFormDialog,
27
+ CnMassDeleteDialog,
28
+ CnMassCopyDialog,
29
+ CnKpiGrid,
30
+ CnMassExportDialog,
31
+ CnMassImportDialog,
32
+ CnIndexSidebar,
33
+ CnRegisterMapping,
34
+ CnDashboardPage,
35
+ CnDashboardGrid,
36
+ CnWidgetWrapper,
37
+ CnWidgetRenderer,
38
+ CnTileWidget,
39
+ CnItemCard,
40
+ CnSchemaFormDialog,
41
+ CnTabbedFormDialog,
42
+ CnTimelineStages,
43
+ CnUserActionMenu,
44
+ CnNotesCard,
45
+ CnTasksCard,
46
+ CnDetailCard,
47
+ CnDetailPage,
48
+ CnCard,
49
+ CnStatsPanel,
50
+ CnJsonViewer,
51
+ CnDetailGrid,
52
+ CnProgressBar,
53
+ CnChartWidget,
54
+ CnObjectSidebar,
55
+ CnInfoWidget,
56
+ CnTableWidget,
57
+ CnActionsBar,
58
+ CnIcon,
59
+ CnPageHeader,
60
+ CnNoteCard,
61
+ CnObjectDataWidget,
62
+ CnObjectMetadataWidget,
63
+ registerIcons,
64
+ } from './components/index.js'
65
+
66
+ // Store
67
+ export { useObjectStore, createObjectStore } from './store/index.js'
68
+ export { createCrudStore } from './store/index.js'
69
+ export { createSubResourcePlugin, emptyPaginated } from './store/index.js'
70
+
71
+ // Store plugins
72
+ export {
73
+ auditTrailsPlugin,
74
+ relationsPlugin,
75
+ filesPlugin,
76
+ lifecyclePlugin,
77
+ logsPlugin,
78
+ registerMappingPlugin,
79
+ selectionPlugin,
80
+ searchPlugin,
81
+ SEARCH_TYPE,
82
+ getRegisterApiUrl,
83
+ getSchemaApiUrl,
84
+ } from './store/plugins/index.js'
85
+
86
+ // Composables
87
+ export { useListView, useDetailView, useSubResource, useDashboardView, useContextMenu } from './composables/index.js'
88
+
89
+ // Localization
90
+ export { registerTranslations } from './l10n/index.js'
91
+
92
+ // Utilities
93
+ export { buildHeaders, buildQueryString, parseResponseError, networkError, genericError } from './utils/index.js'
94
+ export { columnsFromSchema, formatValue, filtersFromSchema, fieldsFromSchema } from './utils/index.js'
95
+ export { filterWidgetsByVisibility, isWidgetVisible, getCurrentUserId, getCurrentUserGroups, resetVisibilityCache } from './utils/index.js'
@@ -0,0 +1,12 @@
1
+ import { getLanguage, register } from '@nextcloud/l10n'
2
+ import en from '../../l10n/en.json'
3
+ import nl from '../../l10n/nl.json'
4
+
5
+ const BUNDLES = { en, nl }
6
+ const APP_NAME = 'nextcloud-vue'
7
+
8
+ export function registerTranslations() {
9
+ const lang = (getLanguage() || 'en').split(/[-_]/)[0]
10
+ const bundle = BUNDLES[lang] ?? BUNDLES.en
11
+ register(APP_NAME, bundle.translations)
12
+ }
@@ -0,0 +1,118 @@
1
+ /**
2
+ * Grid layout mixin for static 12-column CSS grid layouts.
3
+ *
4
+ * Provides a shared grid engine for components that render widget-based layouts
5
+ * using CSS Grid (as opposed to GridStack's absolute positioning). Used by
6
+ * CnDetailPage for static grid layout mode.
7
+ *
8
+ * @mixin gridLayout
9
+ *
10
+ * @example
11
+ * import { gridLayout } from '@conduction/nextcloud-vue/src/mixins/gridLayout.js'
12
+ *
13
+ * export default {
14
+ * mixins: [gridLayout],
15
+ * // Use this.sortedLayout and this.widgetGridStyle(item) in template
16
+ * }
17
+ */
18
+ export const gridLayout = {
19
+ props: {
20
+ /**
21
+ * Grid layout definition. Array of placement objects defining where each widget
22
+ * appears in the 12-column grid.
23
+ *
24
+ * @type {{ id: number, widgetId: string, gridX: number, gridY: number, gridWidth: number, gridHeight?: number, showTitle?: boolean }[]}
25
+ */
26
+ layout: {
27
+ type: Array,
28
+ default: () => [],
29
+ },
30
+ /**
31
+ * Widget definitions. Array of widget objects with id and title.
32
+ *
33
+ * @type {{ id: string, title: string, type?: string }[]}
34
+ */
35
+ widgets: {
36
+ type: Array,
37
+ default: () => [],
38
+ },
39
+ /**
40
+ * Number of grid columns.
41
+ *
42
+ * @type {number}
43
+ */
44
+ columns: {
45
+ type: Number,
46
+ default: 12,
47
+ },
48
+ },
49
+
50
+ computed: {
51
+ /**
52
+ * Layout items sorted by gridY (row) then gridX (column) for proper
53
+ * rendering order. Ensures DOM order matches visual order for
54
+ * accessibility (WCAG 2.4.3 Focus Order).
55
+ *
56
+ * @return {Array} Sorted copy of the layout array.
57
+ */
58
+ sortedLayout() {
59
+ if (!this.layout) return []
60
+ return [...this.layout].sort((a, b) => {
61
+ if (a.gridY !== b.gridY) {
62
+ return a.gridY - b.gridY
63
+ }
64
+ return a.gridX - b.gridX
65
+ })
66
+ },
67
+
68
+ /**
69
+ * Whether grid layout mode is active (layout array is provided and non-empty).
70
+ *
71
+ * @return {boolean}
72
+ */
73
+ hasGridLayout() {
74
+ return Array.isArray(this.layout) && this.layout.length > 0
75
+ },
76
+ },
77
+
78
+ methods: {
79
+ /**
80
+ * Compute CSS grid placement styles for a layout item.
81
+ *
82
+ * Maps the layout item's gridX and gridWidth to CSS grid-column values,
83
+ * and gridY + gridHeight to grid-row values.
84
+ *
85
+ * @param {{ gridX: number, gridWidth: number, gridY?: number, gridHeight?: number }} item - Layout item.
86
+ * @return {object} CSS style object for grid-column and grid-row placement.
87
+ */
88
+ widgetGridStyle(item) {
89
+ const colStart = (item.gridX || 0) + 1
90
+ const colEnd = colStart + (item.gridWidth || this.columns)
91
+
92
+ const style = {
93
+ gridColumn: `${colStart} / ${colEnd}`,
94
+ }
95
+
96
+ // Only set grid-row if explicit height is provided
97
+ if (item.gridY !== undefined && item.gridHeight) {
98
+ const rowStart = item.gridY + 1
99
+ const rowEnd = rowStart + item.gridHeight
100
+ style.gridRow = `${rowStart} / ${rowEnd}`
101
+ }
102
+
103
+ return style
104
+ },
105
+
106
+ /**
107
+ * Find the widget definition for a layout item.
108
+ *
109
+ * @param {{ widgetId: string }} item - Layout item with widgetId reference.
110
+ * @return {object|undefined} The matching widget definition.
111
+ */
112
+ findWidget(item) {
113
+ return this.widgets.find(w => w.id === item.widgetId)
114
+ },
115
+ },
116
+ }
117
+
118
+ export default gridLayout