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

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 (197) hide show
  1. package/README.md +226 -0
  2. package/css/index.css +5 -0
  3. package/dist/nextcloud-vue.cjs +67614 -0
  4. package/dist/nextcloud-vue.cjs.js +76311 -5905
  5. package/dist/nextcloud-vue.cjs.js.map +1 -1
  6. package/dist/nextcloud-vue.cjs.map +1 -0
  7. package/dist/nextcloud-vue.css +3279 -203
  8. package/dist/nextcloud-vue.esm.js +76240 -5882
  9. package/dist/nextcloud-vue.esm.js.map +1 -1
  10. package/package.json +89 -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 +569 -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 +23 -20
  22. package/src/components/CnCardGrid/index.js +1 -1
  23. package/src/components/CnCellRenderer/index.js +1 -1
  24. package/src/components/CnChartWidget/CnChartWidget.vue +318 -0
  25. package/src/components/CnChartWidget/index.js +1 -0
  26. package/src/components/CnConfigurationCard/index.js +1 -1
  27. package/src/components/CnContextMenu/CnContextMenu.vue +142 -0
  28. package/src/components/CnContextMenu/index.js +1 -0
  29. package/src/components/CnCopyDialog/CnCopyDialog.vue +257 -0
  30. package/src/components/CnCopyDialog/index.js +1 -0
  31. package/src/components/CnDashboardGrid/CnDashboardGrid.vue +229 -0
  32. package/src/components/CnDashboardGrid/index.js +1 -0
  33. package/src/components/CnDashboardPage/CnDashboardPage.vue +396 -0
  34. package/src/components/CnDashboardPage/index.js +1 -0
  35. package/src/components/CnDataTable/CnDataTable.vue +24 -16
  36. package/src/components/CnDataTable/index.js +1 -1
  37. package/src/components/CnDeleteDialog/CnDeleteDialog.vue +177 -0
  38. package/src/components/CnDeleteDialog/index.js +1 -0
  39. package/src/components/CnDetailCard/CnDetailCard.vue +225 -0
  40. package/src/components/CnDetailCard/index.js +1 -0
  41. package/src/components/CnDetailGrid/CnDetailGrid.vue +254 -0
  42. package/src/components/CnDetailGrid/index.js +1 -0
  43. package/src/components/CnDetailPage/CnDetailPage.vue +431 -0
  44. package/src/components/CnDetailPage/index.js +1 -0
  45. package/src/components/CnFacetSidebar/CnFacetSidebar.vue +12 -2
  46. package/src/components/CnFacetSidebar/index.js +1 -1
  47. package/src/components/CnFilterBar/index.js +1 -1
  48. package/src/components/CnFormDialog/CnFormDialog.vue +934 -0
  49. package/src/components/CnFormDialog/index.js +1 -0
  50. package/src/components/CnIcon/CnIcon.vue +89 -0
  51. package/src/components/CnIcon/index.js +1 -0
  52. package/src/components/CnIndexPage/CnIndexPage.vue +589 -291
  53. package/src/components/CnIndexPage/index.js +1 -1
  54. package/src/components/CnIndexSidebar/CnIndexSidebar.vue +535 -0
  55. package/src/components/CnIndexSidebar/index.js +1 -0
  56. package/src/components/CnInfoWidget/CnInfoWidget.vue +219 -0
  57. package/src/components/CnInfoWidget/index.js +1 -0
  58. package/src/components/CnItemCard/CnItemCard.vue +134 -0
  59. package/src/components/CnItemCard/index.js +1 -0
  60. package/src/components/CnJsonViewer/CnJsonViewer.vue +283 -0
  61. package/src/components/CnJsonViewer/index.js +1 -0
  62. package/src/components/CnKpiGrid/CnKpiGrid.vue +5 -1
  63. package/src/components/CnKpiGrid/index.js +1 -1
  64. package/src/components/CnMassActionBar/CnMassActionBar.vue +6 -5
  65. package/src/components/CnMassActionBar/index.js +1 -1
  66. package/src/components/CnMassCopyDialog/CnMassCopyDialog.vue +16 -9
  67. package/src/components/CnMassCopyDialog/index.js +1 -1
  68. package/src/components/CnMassDeleteDialog/CnMassDeleteDialog.vue +16 -9
  69. package/src/components/CnMassDeleteDialog/index.js +1 -1
  70. package/src/components/CnMassExportDialog/CnMassExportDialog.vue +8 -7
  71. package/src/components/CnMassExportDialog/index.js +1 -1
  72. package/src/components/CnMassImportDialog/CnMassImportDialog.vue +20 -17
  73. package/src/components/CnMassImportDialog/index.js +1 -1
  74. package/src/components/CnNoteCard/CnNoteCard.vue +149 -0
  75. package/src/components/CnNoteCard/index.js +1 -0
  76. package/src/components/CnNotesCard/CnNotesCard.vue +415 -0
  77. package/src/components/CnNotesCard/index.js +1 -0
  78. package/src/components/CnObjectCard/CnObjectCard.vue +3 -1
  79. package/src/components/CnObjectCard/index.js +1 -1
  80. package/src/components/CnObjectDataWidget/CnObjectDataWidget.vue +853 -0
  81. package/src/components/CnObjectDataWidget/index.js +1 -0
  82. package/src/components/CnObjectMetadataWidget/CnObjectMetadataWidget.vue +288 -0
  83. package/src/components/CnObjectMetadataWidget/index.js +1 -0
  84. package/src/components/CnObjectSidebar/CnAuditTrailTab.vue +368 -0
  85. package/src/components/CnObjectSidebar/CnFilesTab.vue +286 -0
  86. package/src/components/CnObjectSidebar/CnNotesTab.vue +249 -0
  87. package/src/components/CnObjectSidebar/CnObjectSidebar.vue +254 -0
  88. package/src/components/CnObjectSidebar/CnTagsTab.vue +258 -0
  89. package/src/components/CnObjectSidebar/CnTasksTab.vue +482 -0
  90. package/src/components/CnObjectSidebar/index.js +6 -0
  91. package/src/components/CnPageHeader/CnPageHeader.vue +61 -0
  92. package/src/components/CnPageHeader/index.js +1 -0
  93. package/src/components/CnPagination/CnPagination.vue +7 -6
  94. package/src/components/CnPagination/index.js +1 -1
  95. package/src/components/CnProgressBar/CnProgressBar.vue +262 -0
  96. package/src/components/CnProgressBar/index.js +1 -0
  97. package/src/components/CnRegisterMapping/CnRegisterMapping.vue +792 -0
  98. package/src/components/CnRegisterMapping/index.js +1 -0
  99. package/src/components/CnRowActions/CnRowActions.vue +25 -3
  100. package/src/components/CnRowActions/index.js +1 -1
  101. package/src/components/CnSchemaFormDialog/CnSchemaConfigurationTab.vue +226 -0
  102. package/src/components/CnSchemaFormDialog/CnSchemaFormDialog.vue +787 -0
  103. package/src/components/CnSchemaFormDialog/CnSchemaPropertiesTab.vue +305 -0
  104. package/src/components/CnSchemaFormDialog/CnSchemaPropertyActions.vue +1398 -0
  105. package/src/components/CnSchemaFormDialog/CnSchemaSecurityTab.vue +236 -0
  106. package/src/components/CnSchemaFormDialog/index.js +1 -0
  107. package/src/components/CnSettingsCard/index.js +1 -1
  108. package/src/components/CnSettingsSection/index.js +1 -1
  109. package/src/components/CnStatsBlock/CnStatsBlock.vue +89 -19
  110. package/src/components/CnStatsBlock/index.js +1 -1
  111. package/src/components/CnStatsPanel/CnStatsPanel.vue +320 -0
  112. package/src/components/CnStatsPanel/index.js +1 -0
  113. package/src/components/CnStatusBadge/CnStatusBadge.vue +15 -2
  114. package/src/components/CnStatusBadge/index.js +1 -1
  115. package/src/components/CnTabbedFormDialog/CnTabbedFormDialog.vue +544 -0
  116. package/src/components/CnTabbedFormDialog/index.js +1 -0
  117. package/src/components/CnTableWidget/CnTableWidget.vue +332 -0
  118. package/src/components/CnTableWidget/index.js +1 -0
  119. package/src/components/CnTasksCard/CnTasksCard.vue +373 -0
  120. package/src/components/CnTasksCard/index.js +1 -0
  121. package/src/components/CnTileWidget/CnTileWidget.vue +159 -0
  122. package/src/components/CnTileWidget/index.js +1 -0
  123. package/src/components/CnTimelineStages/CnTimelineStages.vue +292 -0
  124. package/src/components/CnTimelineStages/index.js +1 -0
  125. package/src/components/CnUserActionMenu/CnUserActionMenu.vue +435 -0
  126. package/src/components/CnUserActionMenu/index.js +1 -0
  127. package/src/components/CnVersionInfoCard/index.js +1 -1
  128. package/src/components/CnWidgetRenderer/CnWidgetRenderer.vue +180 -0
  129. package/src/components/CnWidgetRenderer/index.js +1 -0
  130. package/src/components/CnWidgetWrapper/CnWidgetWrapper.vue +246 -0
  131. package/src/components/CnWidgetWrapper/index.js +1 -0
  132. package/src/components/index.js +57 -25
  133. package/src/composables/index.js +5 -3
  134. package/src/composables/useContextMenu.js +126 -0
  135. package/src/composables/useDashboardView.js +286 -0
  136. package/src/composables/useDetailView.js +290 -132
  137. package/src/composables/useListView.js +364 -153
  138. package/src/composables/useSubResource.js +142 -142
  139. package/src/constants/metadata.js +30 -0
  140. package/src/css/CnSchemaFormDialog.css +546 -0
  141. package/src/css/__sample_nextcloud_tokens.css +110 -0
  142. package/src/css/actions-bar.css +54 -0
  143. package/src/css/badge.css +83 -51
  144. package/src/css/card.css +129 -128
  145. package/src/css/context-menu.css +20 -0
  146. package/src/css/dashboard.css +70 -0
  147. package/src/css/detail-page.css +235 -0
  148. package/src/css/detail.css +68 -68
  149. package/src/css/index-page.css +44 -0
  150. package/src/css/index-sidebar.css +193 -0
  151. package/src/css/index.css +17 -8
  152. package/src/css/layout.css +90 -90
  153. package/src/css/page-header.css +35 -0
  154. package/src/css/pagination.css +72 -72
  155. package/src/css/table.css +142 -143
  156. package/src/css/timeline-stages.css +220 -0
  157. package/src/css/utilities.css +46 -46
  158. package/src/index.js +91 -50
  159. package/src/mixins/gridLayout.js +118 -0
  160. package/src/store/createCrudStore.js +360 -0
  161. package/src/store/createSubResourcePlugin.js +125 -135
  162. package/src/store/index.js +4 -3
  163. package/src/store/plugins/auditTrails.js +357 -17
  164. package/src/store/plugins/files.js +250 -186
  165. package/src/store/plugins/index.js +7 -4
  166. package/src/store/plugins/lifecycle.js +180 -180
  167. package/src/store/plugins/registerMapping.js +195 -0
  168. package/src/store/plugins/relations.js +68 -68
  169. package/src/store/plugins/search.js +385 -0
  170. package/src/store/plugins/selection.js +104 -0
  171. package/src/store/useObjectStore.js +823 -625
  172. package/src/types/auditTrail.d.ts +32 -32
  173. package/src/types/file.d.ts +23 -23
  174. package/src/types/index.d.ts +35 -35
  175. package/src/types/notification.d.ts +36 -36
  176. package/src/types/object.d.ts +40 -40
  177. package/src/types/organisation.d.ts +41 -41
  178. package/src/types/register.d.ts +25 -25
  179. package/src/types/schema.d.ts +39 -39
  180. package/src/types/shared.d.ts +79 -79
  181. package/src/types/source.d.ts +14 -14
  182. package/src/types/task.d.ts +31 -31
  183. package/src/utils/errors.js +96 -96
  184. package/src/utils/getTheme.js +9 -0
  185. package/src/utils/headers.js +80 -44
  186. package/src/utils/id.js +13 -0
  187. package/src/utils/index.js +4 -3
  188. package/src/utils/schema.js +422 -287
  189. package/src/utils/widgetVisibility.js +162 -0
  190. package/src/components/CnDetailViewLayout/CnDetailViewLayout.vue +0 -88
  191. package/src/components/CnDetailViewLayout/index.js +0 -1
  192. package/src/components/CnEmptyState/CnEmptyState.vue +0 -78
  193. package/src/components/CnEmptyState/index.js +0 -1
  194. package/src/components/CnListViewLayout/CnListViewLayout.vue +0 -80
  195. package/src/components/CnListViewLayout/index.js +0 -1
  196. package/src/components/CnViewModeToggle/CnViewModeToggle.vue +0 -77
  197. package/src/components/CnViewModeToggle/index.js +0 -1
package/package.json CHANGED
@@ -1,63 +1,89 @@
1
- {
2
- "name": "@conduction/nextcloud-vue",
3
- "version": "0.1.0-beta.1",
4
- "description": "Shared Vue component library for Conduction Nextcloud apps — complements @nextcloud/vue with higher-level components, OpenRegister integration, and NL Design System support",
5
- "license": "EUPL-1.2",
6
- "author": "Conduction B.V. <info@conduction.nl>",
7
- "main": "dist/nextcloud-vue.cjs.js",
8
- "module": "dist/nextcloud-vue.esm.js",
9
- "style": "dist/nextcloud-vue.css",
10
- "types": "src/types/index.d.ts",
11
- "files": [
12
- "dist/",
13
- "src/"
14
- ],
15
- "sideEffects": [
16
- "*.css"
17
- ],
18
- "scripts": {
19
- "build": "rollup -c",
20
- "dev": "rollup -c -w",
21
- "test": "jest",
22
- "lint": "eslint src/",
23
- "stylelint": "stylelint 'src/**/*.vue' 'src/**/*.css'",
24
- "prepare": "npm run build",
25
- "prepublishOnly": "npm run build"
26
- },
27
- "peerDependencies": {
28
- "@nextcloud/l10n": "^2.0.0 || ^3.0.0",
29
- "@nextcloud/vue": "^8.0.0",
30
- "pinia": "^2.0.0",
31
- "vue": "^2.7.0",
32
- "vue-material-design-icons": "^5.0.0"
33
- },
34
- "devDependencies": {
35
- "@babel/core": "^7.29.0",
36
- "@babel/preset-env": "^7.29.0",
37
- "@eslint/config-helpers": "^0.4.2",
38
- "@eslint/eslintrc": "^3.3.4",
39
- "@eslint/js": "^9.39.3",
40
- "@nextcloud/browserslist-config": "^3.1.2",
41
- "@nextcloud/eslint-config": "^8.4.2",
42
- "@nextcloud/vue": "^8.12.0",
43
- "@rollup/plugin-commonjs": "^25.0.0",
44
- "@rollup/plugin-node-resolve": "^15.0.0",
45
- "@vue/test-utils": "^1.3.6",
46
- "@vue/vue2-jest": "^29.2.6",
47
- "babel-jest": "^29.7.0",
48
- "eslint": "^8.56.0",
49
- "eslint-import-resolver-alias": "^1.1.2",
50
- "jest": "^29.7.0",
51
- "jest-environment-jsdom": "^29.7.0",
52
- "jest-transform-stub": "^2.0.0",
53
- "pinia": "^2.1.7",
54
- "rollup": "^3.29.0",
55
- "rollup-plugin-postcss": "^4.0.0",
56
- "rollup-plugin-vue": "^5.1.9",
57
- "stylelint": "^14.16.1",
58
- "stylelint-config-recommended": "^9.0.0",
59
- "stylelint-config-recommended-vue": "^1.5.0",
60
- "vue": "^2.7.16",
61
- "vue-material-design-icons": "^5.2.0"
62
- }
63
- }
1
+ {
2
+ "name": "@conduction/nextcloud-vue",
3
+ "version": "0.1.0-beta.10",
4
+ "description": "Shared Vue component library for Conduction Nextcloud apps — complements @nextcloud/vue with higher-level components, OpenRegister integration, and NL Design System support",
5
+ "license": "EUPL-1.2",
6
+ "author": "Conduction B.V. <info@conduction.nl>",
7
+ "main": "dist/nextcloud-vue.cjs.js",
8
+ "module": "dist/nextcloud-vue.esm.js",
9
+ "style": "dist/nextcloud-vue.css",
10
+ "types": "src/types/index.d.ts",
11
+ "files": [
12
+ "dist/",
13
+ "src/",
14
+ "css/"
15
+ ],
16
+ "sideEffects": true,
17
+ "scripts": {
18
+ "build": "rollup -c",
19
+ "dev": "rollup -c -w",
20
+ "test": "jest",
21
+ "lint": "eslint src/",
22
+ "lint-fix": "npm run lint -- --fix",
23
+ "stylelint": "stylelint 'src/**/*.vue' 'src/**/*.css'",
24
+ "check:docs": "node scripts/check-docs.js",
25
+ "prepublishOnly": "npm run build"
26
+ },
27
+ "dependencies": {
28
+ "@codemirror/lang-html": "^6.4.11",
29
+ "@codemirror/lang-json": "^6.0.2",
30
+ "@codemirror/lang-xml": "^6.1.0",
31
+ "@nextcloud/capabilities": "^1.2.1",
32
+ "@nextcloud/dialogs": "^7.3.0",
33
+ "@uiw/codemirror-theme-github": "^4.25.8",
34
+ "gridstack": "^10.3.1",
35
+ "vue-apexcharts": "^1.7.0",
36
+ "vue-codemirror6": "^1.4.3"
37
+ },
38
+ "peerDependencies": {
39
+ "@nextcloud/axios": "^2.0.0",
40
+ "@nextcloud/l10n": "^2.0.0 || ^3.0.0",
41
+ "@nextcloud/router": "^2.0.0 || ^3.0.0",
42
+ "@nextcloud/vue": "^8.0.0",
43
+ "bootstrap-vue": "^2.23.1",
44
+ "pinia": "^2.0.0",
45
+ "vue": "^2.7.0",
46
+ "vue-frag": "^1.4.3",
47
+ "vue-material-design-icons": "^5.0.0"
48
+ },
49
+ "overrides": {
50
+ "json5": "^2.2.3",
51
+ "loader-utils": "^1.4.2"
52
+ },
53
+ "devDependencies": {
54
+ "@babel/core": "^7.29.0",
55
+ "@babel/preset-env": "^7.29.0",
56
+ "@eslint/config-helpers": "^0.4.2",
57
+ "@eslint/eslintrc": "^3.3.4",
58
+ "@eslint/js": "^9.39.3",
59
+ "@nextcloud/browserslist-config": "^3.1.2",
60
+ "@nextcloud/eslint-config": "^8.4.2",
61
+ "@nextcloud/vue": "^8.12.0",
62
+ "@rollup/plugin-commonjs": "^25.0.0",
63
+ "@rollup/plugin-node-resolve": "^15.0.0",
64
+ "@semantic-release/git": "^10.0.1",
65
+ "@vue/test-utils": "^1.3.6",
66
+ "@vue/vue2-jest": "^29.2.6",
67
+ "babel-jest": "^29.7.0",
68
+ "bootstrap-vue": "^2.23.1",
69
+ "eslint": "^8.56.0",
70
+ "eslint-import-resolver-alias": "^1.1.2",
71
+ "eslint-plugin-import": "^2.29.1",
72
+ "eslint-plugin-n": "^16.6.2",
73
+ "eslint-plugin-promise": "^6.1.1",
74
+ "eslint-plugin-vue": "^9.21.1",
75
+ "eslint-webpack-plugin": "^4.0.1",
76
+ "jest": "^29.7.0",
77
+ "jest-environment-jsdom": "^29.7.0",
78
+ "jest-transform-stub": "^2.0.0",
79
+ "pinia": "^2.1.7",
80
+ "rollup": "^3.29.0",
81
+ "rollup-plugin-postcss": "^4.0.0",
82
+ "rollup-plugin-vue": "^5.1.9",
83
+ "stylelint": "^14.16.1",
84
+ "stylelint-config-recommended": "^9.0.0",
85
+ "stylelint-config-recommended-vue": "^1.5.0",
86
+ "vue": "^2.7.16",
87
+ "vue-material-design-icons": "^5.2.0"
88
+ }
89
+ }
@@ -0,0 +1,254 @@
1
+ <template>
2
+ <div class="cn-actions-bar">
3
+ <div class="cn-actions-bar__info">
4
+ <span v-if="pagination && pagination.total > 0" class="cn-actions-bar__count">
5
+ {{ countText }}
6
+ </span>
7
+ </div>
8
+ <div class="cn-actions-bar__actions">
9
+ <!-- View mode toggle (Cards / Table) -->
10
+ <div v-if="showViewToggle" class="cn-actions-bar__view-toggle">
11
+ <NcCheckboxRadioSwitch
12
+ :checked="viewMode"
13
+ :button-variant="true"
14
+ value="cards"
15
+ name="cn_view_mode"
16
+ type="radio"
17
+ button-variant-grouped="horizontal"
18
+ @update:checked="$emit('view-mode-change', 'cards')">
19
+ {{ t('nextcloud-vue', 'Cards') }}
20
+ </NcCheckboxRadioSwitch>
21
+ <NcCheckboxRadioSwitch
22
+ :checked="viewMode"
23
+ :button-variant="true"
24
+ value="table"
25
+ name="cn_view_mode"
26
+ type="radio"
27
+ button-variant-grouped="horizontal"
28
+ @update:checked="$emit('view-mode-change', 'table')">
29
+ {{ t('nextcloud-vue', 'Table') }}
30
+ </NcCheckboxRadioSwitch>
31
+ </div>
32
+
33
+ <!-- Add button (primary) -->
34
+ <NcButton v-if="showAdd"
35
+ type="primary"
36
+ :disabled="addDisabled"
37
+ @click="$emit('add')">
38
+ <template #icon>
39
+ <CnIcon v-if="addIcon" :name="addIcon" :size="20" />
40
+ <Plus v-else :size="20" />
41
+ </template>
42
+ {{ addLabel }}
43
+ </NcButton>
44
+
45
+ <slot name="actions" />
46
+
47
+ <!-- Actions menu (Refresh, Import, Export, mass actions) -->
48
+ <NcActions
49
+ :force-name="true"
50
+ :inline="0"
51
+ menu-name="Actions">
52
+ <NcActionButton :disabled="refreshing || refreshDisabled" @click="$emit('refresh')">
53
+ <template #icon>
54
+ <NcLoadingIcon v-if="refreshing" :size="20" />
55
+ <Refresh v-else :size="20" />
56
+ </template>
57
+ {{ refreshing ? t('nextcloud-vue', 'Refreshing...') : t('nextcloud-vue', 'Refresh') }}
58
+ </NcActionButton>
59
+
60
+ <!-- Custom primary action items (overflow) -->
61
+ <slot name="action-items" />
62
+
63
+ <!-- Separator between primary and mass actions -->
64
+ <NcActionSeparator v-if="hasMassActions" />
65
+
66
+ <!-- Mass actions (overflow) -->
67
+ <NcActionButton
68
+ v-if="showMassImport"
69
+ @click="$emit('show-import')">
70
+ <template #icon>
71
+ <Import :size="20" />
72
+ </template>
73
+ {{ t('nextcloud-vue', 'Import') }}
74
+ </NcActionButton>
75
+ <NcActionButton
76
+ v-if="showMassExport"
77
+ @click="$emit('show-export')">
78
+ <template #icon>
79
+ <Export :size="20" />
80
+ </template>
81
+ {{ t('nextcloud-vue', 'Export') }}
82
+ </NcActionButton>
83
+ <NcActionButton
84
+ v-if="showMassCopy"
85
+ :disabled="selectedIds.length < 1"
86
+ :title="selectedIds.length < 1 ? t('nextcloud-vue', 'Select 1 or more items to copy') : ''"
87
+ @click="$emit('show-copy')">
88
+ <template #icon>
89
+ <ContentCopy :size="20" />
90
+ </template>
91
+ {{ t('nextcloud-vue', 'Copy selected') }}
92
+ </NcActionButton>
93
+ <NcActionButton
94
+ v-if="showMassDelete"
95
+ :disabled="selectedIds.length < 1"
96
+ :title="selectedIds.length < 1 ? t('nextcloud-vue', 'Select 1 or more items to delete') : ''"
97
+ @click="$emit('show-delete')">
98
+ <template #icon>
99
+ <TrashCanOutline :size="20" />
100
+ </template>
101
+ {{ t('nextcloud-vue', 'Delete selected') }}
102
+ </NcActionButton>
103
+
104
+ <!-- Custom mass actions (overflow) -->
105
+ <slot name="mass-actions" :count="selectedIds.length" :selected-ids="selectedIds" />
106
+ </NcActions>
107
+ </div>
108
+ </div>
109
+ </template>
110
+
111
+ <script>
112
+ import { translate as t } from '@nextcloud/l10n'
113
+ import { NcActions, NcActionButton, NcActionSeparator, NcButton, NcCheckboxRadioSwitch, NcLoadingIcon } from '@nextcloud/vue'
114
+ import { CnIcon } from '../CnIcon/index.js'
115
+ import Plus from 'vue-material-design-icons/Plus.vue'
116
+ import Refresh from 'vue-material-design-icons/Refresh.vue'
117
+ import ContentCopy from 'vue-material-design-icons/ContentCopy.vue'
118
+ import TrashCanOutline from 'vue-material-design-icons/TrashCanOutline.vue'
119
+ import Import from 'vue-material-design-icons/Import.vue'
120
+ import Export from 'vue-material-design-icons/Export.vue'
121
+
122
+ /**
123
+ * CnActionsBar — Reusable actions toolbar with count, mass actions, and primary actions.
124
+ *
125
+ * @example
126
+ * <CnActionsBar
127
+ * :pagination="pagination"
128
+ * :object-count="items.length"
129
+ * add-label="Add Client"
130
+ * add-icon="AccountGroup"
131
+ * @add="createNew"
132
+ * @refresh="reload" />
133
+ */
134
+ export default {
135
+ name: 'CnActionsBar',
136
+
137
+ components: {
138
+ NcActions,
139
+ NcActionButton,
140
+ NcActionSeparator,
141
+ NcButton,
142
+ NcCheckboxRadioSwitch,
143
+ NcLoadingIcon,
144
+ CnIcon,
145
+ Plus,
146
+ Refresh,
147
+ ContentCopy,
148
+ TrashCanOutline,
149
+ Import,
150
+ Export,
151
+ },
152
+
153
+ props: {
154
+ /** Pagination state: { total, page, pages, limit } */
155
+ pagination: {
156
+ type: Object,
157
+ default: null,
158
+ },
159
+ /** Number of currently visible objects (for "Showing X of Y") */
160
+ objectCount: {
161
+ type: Number,
162
+ default: 0,
163
+ },
164
+ /** Whether rows/cards can be selected */
165
+ selectable: {
166
+ type: Boolean,
167
+ default: true,
168
+ },
169
+ /** Currently selected IDs */
170
+ selectedIds: {
171
+ type: Array,
172
+ default: () => [],
173
+ },
174
+ /** Label for the Add button */
175
+ addLabel: {
176
+ type: String,
177
+ default: () => t('nextcloud-vue', 'Add'),
178
+ },
179
+ /** MDI icon name for the Add button (e.g. 'AccountGroup'). Falls back to Plus icon. */
180
+ addIcon: {
181
+ type: String,
182
+ default: '',
183
+ },
184
+ /** How many action buttons to show inline (rest go in overflow dropdown) */
185
+ inlineActionCount: {
186
+ type: Number,
187
+ default: 2,
188
+ },
189
+ /** Whether to show the built-in mass Import action */
190
+ showMassImport: {
191
+ type: Boolean,
192
+ default: true,
193
+ },
194
+ /** Whether to show the built-in mass Export action */
195
+ showMassExport: {
196
+ type: Boolean,
197
+ default: true,
198
+ },
199
+ /** Whether to show the built-in mass Copy action */
200
+ showMassCopy: {
201
+ type: Boolean,
202
+ default: true,
203
+ },
204
+ /** Whether to show the built-in mass Delete action */
205
+ showMassDelete: {
206
+ type: Boolean,
207
+ default: true,
208
+ },
209
+ /** Current view mode: 'table' or 'cards' */
210
+ viewMode: {
211
+ type: String,
212
+ default: 'table',
213
+ validator: (v) => ['table', 'cards'].includes(v),
214
+ },
215
+ /** Whether to show the Cards/Table view toggle */
216
+ showViewToggle: {
217
+ type: Boolean,
218
+ default: true,
219
+ },
220
+ /** Whether the refresh action is currently in progress */
221
+ refreshing: {
222
+ type: Boolean,
223
+ default: false,
224
+ },
225
+ /** Whether the refresh action is disabled (e.g. when required selections are missing) */
226
+ refreshDisabled: {
227
+ type: Boolean,
228
+ default: false,
229
+ },
230
+ /** Whether the Add button is disabled (e.g. when required selections are missing) */
231
+ addDisabled: {
232
+ type: Boolean,
233
+ default: false,
234
+ },
235
+ /** Whether to show the Add button */
236
+ showAdd: {
237
+ type: Boolean,
238
+ default: true,
239
+ },
240
+ },
241
+
242
+ computed: {
243
+ countText() {
244
+ if (!this.pagination) return ''
245
+ return t('nextcloud-vue', 'Showing {count} of {total}', { count: this.objectCount, total: this.pagination.total })
246
+ },
247
+ hasMassActions() {
248
+ return this.showMassImport || this.showMassExport || this.showMassCopy || this.showMassDelete
249
+ },
250
+ },
251
+ }
252
+ </script>
253
+
254
+ <!-- Styles in css/actions-bar.css -->
@@ -0,0 +1 @@
1
+ export { default as CnActionsBar } from './CnActionsBar.vue'