@strapi/content-manager 0.0.0-next.9c7149630dabd4c43f44cf68ed4ce6d7562607e8 → 0.0.0-next.9ee35b96a156316b69719c0e5fec26bce796b251

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 (155) hide show
  1. package/dist/admin/components/Widgets.js +256 -4
  2. package/dist/admin/components/Widgets.js.map +1 -1
  3. package/dist/admin/components/Widgets.mjs +239 -7
  4. package/dist/admin/components/Widgets.mjs.map +1 -1
  5. package/dist/admin/hooks/useDocumentActions.js +0 -3
  6. package/dist/admin/hooks/useDocumentActions.js.map +1 -1
  7. package/dist/admin/hooks/useDocumentActions.mjs +1 -4
  8. package/dist/admin/hooks/useDocumentActions.mjs.map +1 -1
  9. package/dist/admin/index.js +47 -8
  10. package/dist/admin/index.js.map +1 -1
  11. package/dist/admin/index.mjs +47 -9
  12. package/dist/admin/index.mjs.map +1 -1
  13. package/dist/admin/layout.js +1 -27
  14. package/dist/admin/layout.js.map +1 -1
  15. package/dist/admin/layout.mjs +2 -9
  16. package/dist/admin/layout.mjs.map +1 -1
  17. package/dist/admin/pages/EditView/EditViewPage.js +6 -1
  18. package/dist/admin/pages/EditView/EditViewPage.js.map +1 -1
  19. package/dist/admin/pages/EditView/EditViewPage.mjs +8 -3
  20. package/dist/admin/pages/EditView/EditViewPage.mjs.map +1 -1
  21. package/dist/admin/pages/EditView/components/DocumentActions.js +2 -2
  22. package/dist/admin/pages/EditView/components/DocumentActions.js.map +1 -1
  23. package/dist/admin/pages/EditView/components/DocumentActions.mjs +3 -3
  24. package/dist/admin/pages/EditView/components/DocumentActions.mjs.map +1 -1
  25. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.js +1 -0
  26. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.js.map +1 -1
  27. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.mjs +1 -0
  28. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.mjs.map +1 -1
  29. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.js +4 -1
  30. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.js.map +1 -1
  31. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.mjs +4 -1
  32. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.mjs.map +1 -1
  33. package/dist/admin/pages/EditView/utils/data.js +7 -1
  34. package/dist/admin/pages/EditView/utils/data.js.map +1 -1
  35. package/dist/admin/pages/EditView/utils/data.mjs +7 -1
  36. package/dist/admin/pages/EditView/utils/data.mjs.map +1 -1
  37. package/dist/admin/pages/ListView/ListViewPage.js +148 -139
  38. package/dist/admin/pages/ListView/ListViewPage.js.map +1 -1
  39. package/dist/admin/pages/ListView/ListViewPage.mjs +149 -140
  40. package/dist/admin/pages/ListView/ListViewPage.mjs.map +1 -1
  41. package/dist/admin/pages/ListView/components/BulkActions/PublishAction.js +12 -2
  42. package/dist/admin/pages/ListView/components/BulkActions/PublishAction.js.map +1 -1
  43. package/dist/admin/pages/ListView/components/BulkActions/PublishAction.mjs +12 -2
  44. package/dist/admin/pages/ListView/components/BulkActions/PublishAction.mjs.map +1 -1
  45. package/dist/admin/pages/ListView/components/Filters.js +3 -1
  46. package/dist/admin/pages/ListView/components/Filters.js.map +1 -1
  47. package/dist/admin/pages/ListView/components/Filters.mjs +3 -1
  48. package/dist/admin/pages/ListView/components/Filters.mjs.map +1 -1
  49. package/dist/admin/preview/components/PreviewSidePanel.js +31 -4
  50. package/dist/admin/preview/components/PreviewSidePanel.js.map +1 -1
  51. package/dist/admin/preview/components/PreviewSidePanel.mjs +32 -5
  52. package/dist/admin/preview/components/PreviewSidePanel.mjs.map +1 -1
  53. package/dist/admin/preview/pages/Preview.js +136 -35
  54. package/dist/admin/preview/pages/Preview.js.map +1 -1
  55. package/dist/admin/preview/pages/Preview.mjs +137 -36
  56. package/dist/admin/preview/pages/Preview.mjs.map +1 -1
  57. package/dist/admin/preview/utils/constants.js +21 -0
  58. package/dist/admin/preview/utils/constants.js.map +1 -0
  59. package/dist/admin/preview/utils/constants.mjs +19 -0
  60. package/dist/admin/preview/utils/constants.mjs.map +1 -0
  61. package/dist/admin/preview/utils/previewScript.js +28 -0
  62. package/dist/admin/preview/utils/previewScript.js.map +1 -0
  63. package/dist/admin/preview/utils/previewScript.mjs +26 -0
  64. package/dist/admin/preview/utils/previewScript.mjs.map +1 -0
  65. package/dist/admin/services/api.js +3 -1
  66. package/dist/admin/services/api.js.map +1 -1
  67. package/dist/admin/services/api.mjs +3 -1
  68. package/dist/admin/services/api.mjs.map +1 -1
  69. package/dist/admin/services/documents.js +40 -14
  70. package/dist/admin/services/documents.js.map +1 -1
  71. package/dist/admin/services/documents.mjs +40 -14
  72. package/dist/admin/services/documents.mjs.map +1 -1
  73. package/dist/admin/src/components/Widgets.d.ts +2 -1
  74. package/dist/admin/src/exports.d.ts +1 -0
  75. package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
  76. package/dist/admin/src/preview/services/preview.d.ts +1 -1
  77. package/dist/admin/src/preview/utils/constants.d.ts +17 -0
  78. package/dist/admin/src/preview/utils/previewScript.d.ts +16 -0
  79. package/dist/admin/src/services/api.d.ts +1 -1
  80. package/dist/admin/src/services/components.d.ts +2 -2
  81. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  82. package/dist/admin/src/services/documents.d.ts +16 -16
  83. package/dist/admin/src/services/homepage.d.ts +1 -1
  84. package/dist/admin/src/services/init.d.ts +1 -1
  85. package/dist/admin/src/services/relations.d.ts +2 -2
  86. package/dist/admin/src/services/uid.d.ts +3 -3
  87. package/dist/admin/src/utils/api.d.ts +1 -1
  88. package/dist/admin/translations/en.json.js +6 -0
  89. package/dist/admin/translations/en.json.js.map +1 -1
  90. package/dist/admin/translations/en.json.mjs +6 -0
  91. package/dist/admin/translations/en.json.mjs.map +1 -1
  92. package/dist/admin/translations/es.json.js +5 -2
  93. package/dist/admin/translations/es.json.js.map +1 -1
  94. package/dist/admin/translations/es.json.mjs +5 -2
  95. package/dist/admin/translations/es.json.mjs.map +1 -1
  96. package/dist/admin/translations/fr.json.js +4 -1
  97. package/dist/admin/translations/fr.json.js.map +1 -1
  98. package/dist/admin/translations/fr.json.mjs +4 -1
  99. package/dist/admin/translations/fr.json.mjs.map +1 -1
  100. package/dist/admin/utils/api.js +1 -1
  101. package/dist/admin/utils/api.js.map +1 -1
  102. package/dist/admin/utils/api.mjs +1 -1
  103. package/dist/admin/utils/api.mjs.map +1 -1
  104. package/dist/admin/utils/validation.js +2 -1
  105. package/dist/admin/utils/validation.js.map +1 -1
  106. package/dist/admin/utils/validation.mjs +2 -1
  107. package/dist/admin/utils/validation.mjs.map +1 -1
  108. package/dist/server/history/services/lifecycles.js +20 -19
  109. package/dist/server/history/services/lifecycles.js.map +1 -1
  110. package/dist/server/history/services/lifecycles.mjs +20 -19
  111. package/dist/server/history/services/lifecycles.mjs.map +1 -1
  112. package/dist/server/homepage/controllers/homepage.js +5 -0
  113. package/dist/server/homepage/controllers/homepage.js.map +1 -1
  114. package/dist/server/homepage/controllers/homepage.mjs +5 -0
  115. package/dist/server/homepage/controllers/homepage.mjs.map +1 -1
  116. package/dist/server/homepage/routes/homepage.js +11 -0
  117. package/dist/server/homepage/routes/homepage.js.map +1 -1
  118. package/dist/server/homepage/routes/homepage.mjs +11 -0
  119. package/dist/server/homepage/routes/homepage.mjs.map +1 -1
  120. package/dist/server/homepage/services/homepage.js +86 -46
  121. package/dist/server/homepage/services/homepage.js.map +1 -1
  122. package/dist/server/homepage/services/homepage.mjs +86 -46
  123. package/dist/server/homepage/services/homepage.mjs.map +1 -1
  124. package/dist/server/preview/services/preview-config.js +5 -1
  125. package/dist/server/preview/services/preview-config.js.map +1 -1
  126. package/dist/server/preview/services/preview-config.mjs +5 -1
  127. package/dist/server/preview/services/preview-config.mjs.map +1 -1
  128. package/dist/server/preview/services/preview.js +4 -0
  129. package/dist/server/preview/services/preview.js.map +1 -1
  130. package/dist/server/preview/services/preview.mjs +4 -0
  131. package/dist/server/preview/services/preview.mjs.map +1 -1
  132. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
  133. package/dist/server/src/homepage/controllers/homepage.d.ts +2 -1
  134. package/dist/server/src/homepage/controllers/homepage.d.ts.map +1 -1
  135. package/dist/server/src/homepage/index.d.ts +7 -0
  136. package/dist/server/src/homepage/index.d.ts.map +1 -1
  137. package/dist/server/src/homepage/routes/homepage.d.ts.map +1 -1
  138. package/dist/server/src/homepage/services/homepage.d.ts +4 -1
  139. package/dist/server/src/homepage/services/homepage.d.ts.map +1 -1
  140. package/dist/server/src/homepage/services/index.d.ts +7 -0
  141. package/dist/server/src/homepage/services/index.d.ts.map +1 -1
  142. package/dist/server/src/index.d.ts +7 -0
  143. package/dist/server/src/index.d.ts.map +1 -1
  144. package/dist/server/src/preview/services/index.d.ts +1 -0
  145. package/dist/server/src/preview/services/index.d.ts.map +1 -1
  146. package/dist/server/src/preview/services/preview-config.d.ts +1 -0
  147. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -1
  148. package/dist/server/src/preview/services/preview.d.ts.map +1 -1
  149. package/dist/server/src/preview/utils.d.ts +1 -0
  150. package/dist/server/src/preview/utils.d.ts.map +1 -1
  151. package/dist/server/src/services/index.d.ts +7 -0
  152. package/dist/server/src/services/index.d.ts.map +1 -1
  153. package/dist/shared/contracts/homepage.d.ts +13 -0
  154. package/dist/shared/contracts/homepage.d.ts.map +1 -1
  155. package/package.json +7 -8
@@ -1,6 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var jsxRuntime = require('react/jsx-runtime');
4
+ var React = require('react');
4
5
  var strapiAdmin = require('@strapi/admin/strapi-admin');
5
6
  var designSystem = require('@strapi/design-system');
6
7
  var Icons = require('@strapi/icons');
@@ -11,10 +12,28 @@ var DocumentStatus = require('../pages/EditView/components/DocumentStatus.js');
11
12
  var homepage = require('../services/homepage.js');
12
13
  var RelativeTime = require('./RelativeTime.js');
13
14
 
14
- const CellTypography = styledComponents.styled(designSystem.Typography).attrs({
15
- maxWidth: '14.4rem',
16
- display: 'block'
17
- })`
15
+ function _interopNamespaceDefault(e) {
16
+ var n = Object.create(null);
17
+ if (e) {
18
+ Object.keys(e).forEach(function (k) {
19
+ if (k !== 'default') {
20
+ var d = Object.getOwnPropertyDescriptor(e, k);
21
+ Object.defineProperty(n, k, d.get ? d : {
22
+ enumerable: true,
23
+ get: function () { return e[k]; }
24
+ });
25
+ }
26
+ });
27
+ }
28
+ n.default = e;
29
+ return Object.freeze(n);
30
+ }
31
+
32
+ var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
33
+
34
+ const CellTypography = styledComponents.styled(designSystem.Typography)`
35
+ display: block;
36
+ max-width: 14.4rem;
18
37
  overflow: hidden;
19
38
  text-overflow: ellipsis;
20
39
  white-space: nowrap;
@@ -155,7 +174,240 @@ const RecentDocumentsTable = ({ documents })=>{
155
174
  documents: data
156
175
  });
157
176
  };
177
+ /* -------------------------------------------------------------------------------------------------
178
+ * ChartEntriesWidget
179
+ * -----------------------------------------------------------------------------------------------*/ const RADIUS = 80;
180
+ const STROKE = 10;
181
+ const CIRCUMFERENCE = 2 * Math.PI * (RADIUS - STROKE / 2);
182
+ const ArcChart = styledComponents.styled.circle`
183
+ stroke: ${({ theme, $arcColor })=>theme.colors[$arcColor]};
184
+ `;
185
+ const TextChart = styledComponents.styled.tspan`
186
+ text-transform: lowercase;
187
+ fill: ${({ theme, $textColor })=>theme.colors[$textColor]};
188
+ `;
189
+ const KeyChartItem = styledComponents.styled(designSystem.Flex)`
190
+ width: 100%;
191
+
192
+ ${({ theme })=>theme.breakpoints.small} {
193
+ width: auto;
194
+ }
195
+ `;
196
+ const DonutChartSVG = ({ data })=>{
197
+ const { locale } = reactIntl.useIntl();
198
+ const { formatMessage } = reactIntl.useIntl();
199
+ const total = data.reduce((acc, curr)=>acc + curr.count, 0);
200
+ const [tooltip, setTooltip] = React__namespace.useState({
201
+ visible: false,
202
+ x: 0,
203
+ y: 0,
204
+ value: null
205
+ });
206
+ let cumulativePercent = 0;
207
+ const handleMouseOver = (e, value)=>{
208
+ setTooltip({
209
+ visible: true,
210
+ x: e.clientX,
211
+ y: e.clientY,
212
+ value
213
+ });
214
+ };
215
+ const handleMouseOut = ()=>{
216
+ setTooltip((t)=>({
217
+ ...t,
218
+ visible: false
219
+ }));
220
+ };
221
+ const handleFocus = (e, value)=>{
222
+ setTooltip({
223
+ visible: true,
224
+ x: e.currentTarget.getBoundingClientRect().width / 2 + e.currentTarget.getBoundingClientRect().left,
225
+ y: e.currentTarget.getBoundingClientRect().height + e.currentTarget.getBoundingClientRect().top,
226
+ value
227
+ });
228
+ };
229
+ return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
230
+ direction: "column",
231
+ gap: 6,
232
+ margin: "auto",
233
+ children: [
234
+ /*#__PURE__*/ jsxRuntime.jsxs("svg", {
235
+ width: RADIUS * 2,
236
+ height: RADIUS * 2,
237
+ viewBox: `0 0 ${RADIUS * 2} ${RADIUS * 2}`,
238
+ style: {
239
+ position: 'relative',
240
+ zIndex: 1
241
+ },
242
+ children: [
243
+ /*#__PURE__*/ jsxRuntime.jsx("g", {
244
+ transform: `rotate(-90 ${RADIUS} ${RADIUS})`,
245
+ children: data.map((value)=>{
246
+ const percent = value.count / total * 100;
247
+ const arcLength = percent / 100 * CIRCUMFERENCE;
248
+ const dashArray = `${arcLength} ${CIRCUMFERENCE - arcLength}`;
249
+ const dashOffset = CIRCUMFERENCE * (1 - cumulativePercent / 100);
250
+ const el = /*#__PURE__*/ jsxRuntime.jsx(ArcChart, {
251
+ cx: RADIUS,
252
+ cy: RADIUS,
253
+ r: RADIUS - STROKE / 2,
254
+ fill: "none",
255
+ strokeWidth: STROKE,
256
+ strokeDasharray: dashArray,
257
+ strokeDashoffset: dashOffset,
258
+ style: {
259
+ transition: 'stroke-dashoffset 0.3s',
260
+ cursor: 'pointer'
261
+ },
262
+ tabIndex: 0,
263
+ "aria-describedby": tooltip.visible ? 'chart-tooltip' : undefined,
264
+ onFocus: (e)=>handleFocus(e, value),
265
+ onBlur: handleMouseOut,
266
+ onMouseMove: (e)=>handleMouseOver(e, value),
267
+ onMouseLeave: handleMouseOut,
268
+ $arcColor: value.color
269
+ }, value.label);
270
+ cumulativePercent += percent;
271
+ return el;
272
+ })
273
+ }),
274
+ /*#__PURE__*/ jsxRuntime.jsxs("text", {
275
+ x: RADIUS,
276
+ y: RADIUS,
277
+ textAnchor: "middle",
278
+ fontSize: "2.4rem",
279
+ fontWeight: "bold",
280
+ children: [
281
+ /*#__PURE__*/ jsxRuntime.jsx(TextChart, {
282
+ x: RADIUS,
283
+ dy: "0",
284
+ $textColor: "neutral800",
285
+ children: new Intl.NumberFormat(locale, {
286
+ notation: 'compact',
287
+ maximumFractionDigits: 1
288
+ }).format(total)
289
+ }),
290
+ /*#__PURE__*/ jsxRuntime.jsx(TextChart, {
291
+ x: RADIUS,
292
+ dy: "1.4em",
293
+ fontSize: "1.4rem",
294
+ fontWeight: "normal",
295
+ $textColor: "neutral600",
296
+ children: formatMessage({
297
+ id: 'content-manager.widget.chart-entries.title',
298
+ defaultMessage: 'entries'
299
+ })
300
+ })
301
+ ]
302
+ })
303
+ ]
304
+ }),
305
+ tooltip.visible && tooltip.value && /*#__PURE__*/ jsxRuntime.jsx(designSystem.Portal, {
306
+ style: {
307
+ position: 'fixed',
308
+ left: 16,
309
+ top: 16,
310
+ zIndex: 2,
311
+ transform: `translate(${tooltip.x}px, ${tooltip.y}px)`
312
+ },
313
+ "data-testid": "entries-chart-tooltip",
314
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
315
+ background: "neutral900",
316
+ padding: 2,
317
+ borderRadius: 1,
318
+ textAlign: "center",
319
+ role: "tooltip",
320
+ "aria-live": "polite",
321
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
322
+ textColor: "neutral0",
323
+ children: formatMessage({
324
+ id: 'content-manager.widget.chart-entries.tooltip',
325
+ defaultMessage: '{count} items'
326
+ }, {
327
+ count: tooltip.value.count,
328
+ label: tooltip.value.label
329
+ })
330
+ })
331
+ })
332
+ }),
333
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
334
+ gap: 4,
335
+ wrap: "wrap",
336
+ children: data.map((value)=>value.count > 0 && /*#__PURE__*/ jsxRuntime.jsxs(KeyChartItem, {
337
+ gap: 1,
338
+ children: [
339
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
340
+ background: value.color,
341
+ padding: 2,
342
+ borderRadius: 1
343
+ }),
344
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
345
+ variant: "pi",
346
+ children: value.label
347
+ })
348
+ ]
349
+ }, value.label))
350
+ })
351
+ ]
352
+ });
353
+ };
354
+ const ChartEntriesWidget = ()=>{
355
+ const { formatMessage } = reactIntl.useIntl();
356
+ const { data: countDocuments, isLoading, error } = strapiAdmin.useGetCountDocumentsQuery();
357
+ if (isLoading) {
358
+ return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Widget.Loading, {});
359
+ }
360
+ if (error) {
361
+ return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Widget.Error, {});
362
+ }
363
+ const { draft, published, modified } = countDocuments ?? {
364
+ draft: 0,
365
+ published: 0,
366
+ modified: 0
367
+ };
368
+ const total = draft + published + modified;
369
+ if (!total) {
370
+ return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Widget.NoData, {
371
+ children: formatMessage({
372
+ id: 'content-manager.widget.last-published.no-data',
373
+ defaultMessage: 'No published entries'
374
+ })
375
+ });
376
+ }
377
+ return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
378
+ minHeight: "100%",
379
+ children: /*#__PURE__*/ jsxRuntime.jsx(DonutChartSVG, {
380
+ data: [
381
+ {
382
+ label: formatMessage({
383
+ id: 'content-manager.containers.List.draft',
384
+ defaultMessage: 'Draft'
385
+ }),
386
+ count: draft,
387
+ color: 'secondary500'
388
+ },
389
+ {
390
+ label: formatMessage({
391
+ id: 'content-manager.containers.List.modified',
392
+ defaultMessage: 'Modified'
393
+ }),
394
+ count: modified,
395
+ color: 'alternative500'
396
+ },
397
+ {
398
+ label: formatMessage({
399
+ id: 'content-manager.containers.List.published',
400
+ defaultMessage: 'Published'
401
+ }),
402
+ count: published,
403
+ color: 'success500'
404
+ }
405
+ ]
406
+ })
407
+ });
408
+ };
158
409
 
410
+ exports.ChartEntriesWidget = ChartEntriesWidget;
159
411
  exports.LastEditedWidget = LastEditedWidget;
160
412
  exports.LastPublishedWidget = LastPublishedWidget;
161
413
  //# sourceMappingURL=Widgets.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Widgets.js","sources":["../../../admin/src/components/Widgets.tsx"],"sourcesContent":["import { Widget, useTracking } from '@strapi/admin/strapi-admin';\nimport { Box, IconButton, Table, Tbody, Td, Tr, Typography } from '@strapi/design-system';\nimport { Pencil } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport { Link, useNavigate } from 'react-router-dom';\nimport { styled } from 'styled-components';\n\nimport { DocumentStatus } from '../pages/EditView/components/DocumentStatus';\nimport { useGetRecentDocumentsQuery } from '../services/homepage';\n\nimport { RelativeTime } from './RelativeTime';\n\nimport type { RecentDocument } from '../../../shared/contracts/homepage';\n\nconst CellTypography = styled(Typography).attrs({ maxWidth: '14.4rem', display: 'block' })`\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n`;\n\nconst RecentDocumentsTable = ({ documents }: { documents: RecentDocument[] }) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const navigate = useNavigate();\n\n const getEditViewLink = (document: RecentDocument): string => {\n const isSingleType = document.kind === 'singleType';\n const kindPath = isSingleType ? 'single-types' : 'collection-types';\n const queryParams = document.locale ? `?plugins[i18n][locale]=${document.locale}` : '';\n\n return `/content-manager/${kindPath}/${document.contentTypeUid}${isSingleType ? '' : '/' + document.documentId}${queryParams}`;\n };\n\n const handleRowClick = (document: RecentDocument) => () => {\n trackUsage('willEditEntryFromHome');\n const link = getEditViewLink(document);\n navigate(link);\n };\n\n return (\n <Table colCount={5} rowCount={documents?.length ?? 0}>\n <Tbody>\n {documents?.map((document) => (\n <Tr onClick={handleRowClick(document)} cursor=\"pointer\" key={document.documentId}>\n <Td>\n <CellTypography title={document.title} variant=\"omega\" textColor=\"neutral800\">\n {document.title}\n </CellTypography>\n </Td>\n <Td>\n <CellTypography variant=\"omega\" textColor=\"neutral600\">\n {document.kind === 'singleType'\n ? formatMessage({\n id: 'content-manager.widget.last-edited.single-type',\n defaultMessage: 'Single-Type',\n })\n : formatMessage({\n id: document.contentTypeDisplayName,\n defaultMessage: document.contentTypeDisplayName,\n })}\n </CellTypography>\n </Td>\n <Td>\n <Box display=\"inline-block\">\n {document.status ? (\n <DocumentStatus status={document.status} />\n ) : (\n <Typography textColor=\"neutral600\" aria-hidden>\n -\n </Typography>\n )}\n </Box>\n </Td>\n <Td>\n <Typography textColor=\"neutral600\">\n <RelativeTime timestamp={new Date(document.updatedAt)} />\n </Typography>\n </Td>\n <Td onClick={(e) => e.stopPropagation()}>\n <Box display=\"inline-block\">\n <IconButton\n tag={Link}\n to={getEditViewLink(document)}\n onClick={() => trackUsage('willEditEntryFromHome')}\n label={formatMessage({\n id: 'content-manager.actions.edit.label',\n defaultMessage: 'Edit',\n })}\n variant=\"ghost\"\n >\n <Pencil />\n </IconButton>\n </Box>\n </Td>\n </Tr>\n ))}\n </Tbody>\n </Table>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * LastEditedWidget\n * -----------------------------------------------------------------------------------------------*/\n\nconst LastEditedWidget = () => {\n const { formatMessage } = useIntl();\n const { data, isLoading, error } = useGetRecentDocumentsQuery({ action: 'update' });\n\n if (isLoading) {\n return <Widget.Loading />;\n }\n\n if (error || !data) {\n return <Widget.Error />;\n }\n\n if (data.length === 0) {\n return (\n <Widget.NoData>\n {formatMessage({\n id: 'content-manager.widget.last-edited.no-data',\n defaultMessage: 'No edited entries',\n })}\n </Widget.NoData>\n );\n }\n\n return <RecentDocumentsTable documents={data} />;\n};\n\n/* -------------------------------------------------------------------------------------------------\n * LastPublishedWidget\n * -----------------------------------------------------------------------------------------------*/\n\nconst LastPublishedWidget = () => {\n const { formatMessage } = useIntl();\n const { data, isLoading, error } = useGetRecentDocumentsQuery({ action: 'publish' });\n\n if (isLoading) {\n return <Widget.Loading />;\n }\n\n if (error || !data) {\n return <Widget.Error />;\n }\n\n if (data.length === 0) {\n return (\n <Widget.NoData>\n {formatMessage({\n id: 'content-manager.widget.last-published.no-data',\n defaultMessage: 'No published entries',\n })}\n </Widget.NoData>\n );\n }\n\n return <RecentDocumentsTable documents={data} />;\n};\n\nexport { LastEditedWidget, LastPublishedWidget };\n"],"names":["CellTypography","styled","Typography","attrs","maxWidth","display","RecentDocumentsTable","documents","formatMessage","useIntl","trackUsage","useTracking","navigate","useNavigate","getEditViewLink","document","isSingleType","kind","kindPath","queryParams","locale","contentTypeUid","documentId","handleRowClick","link","_jsx","Table","colCount","rowCount","length","Tbody","map","_jsxs","Tr","onClick","cursor","Td","title","variant","textColor","id","defaultMessage","contentTypeDisplayName","Box","status","DocumentStatus","aria-hidden","RelativeTime","timestamp","Date","updatedAt","e","stopPropagation","IconButton","tag","Link","to","label","Pencil","LastEditedWidget","data","isLoading","error","useGetRecentDocumentsQuery","action","Widget","Loading","Error","NoData","LastPublishedWidget"],"mappings":"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"}
1
+ {"version":3,"file":"Widgets.js","sources":["../../../admin/src/components/Widgets.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { Widget, useTracking, useGetCountDocumentsQuery } from '@strapi/admin/strapi-admin';\nimport {\n Box,\n Flex,\n IconButton,\n Table,\n Tbody,\n Td,\n Tr,\n Typography,\n Portal,\n} from '@strapi/design-system';\nimport { Pencil } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport { Link, useNavigate } from 'react-router-dom';\nimport { styled, DefaultTheme } from 'styled-components';\n\nimport { DocumentStatus } from '../pages/EditView/components/DocumentStatus';\nimport { useGetRecentDocumentsQuery } from '../services/homepage';\n\nimport { RelativeTime } from './RelativeTime';\n\nimport type { RecentDocument } from '../../../shared/contracts/homepage';\n\nconst CellTypography = styled(Typography)`\n display: block;\n max-width: 14.4rem;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n`;\n\nconst RecentDocumentsTable = ({ documents }: { documents: RecentDocument[] }) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const navigate = useNavigate();\n\n const getEditViewLink = (document: RecentDocument): string => {\n const isSingleType = document.kind === 'singleType';\n const kindPath = isSingleType ? 'single-types' : 'collection-types';\n const queryParams = document.locale ? `?plugins[i18n][locale]=${document.locale}` : '';\n\n return `/content-manager/${kindPath}/${document.contentTypeUid}${isSingleType ? '' : '/' + document.documentId}${queryParams}`;\n };\n\n const handleRowClick = (document: RecentDocument) => () => {\n trackUsage('willEditEntryFromHome');\n const link = getEditViewLink(document);\n navigate(link);\n };\n\n return (\n <Table colCount={5} rowCount={documents?.length ?? 0}>\n <Tbody>\n {documents?.map((document) => (\n <Tr onClick={handleRowClick(document)} cursor=\"pointer\" key={document.documentId}>\n <Td>\n <CellTypography title={document.title} variant=\"omega\" textColor=\"neutral800\">\n {document.title}\n </CellTypography>\n </Td>\n <Td>\n <CellTypography variant=\"omega\" textColor=\"neutral600\">\n {document.kind === 'singleType'\n ? formatMessage({\n id: 'content-manager.widget.last-edited.single-type',\n defaultMessage: 'Single-Type',\n })\n : formatMessage({\n id: document.contentTypeDisplayName,\n defaultMessage: document.contentTypeDisplayName,\n })}\n </CellTypography>\n </Td>\n <Td>\n <Box display=\"inline-block\">\n {document.status ? (\n <DocumentStatus status={document.status} />\n ) : (\n <Typography textColor=\"neutral600\" aria-hidden>\n -\n </Typography>\n )}\n </Box>\n </Td>\n <Td>\n <Typography textColor=\"neutral600\">\n <RelativeTime timestamp={new Date(document.updatedAt)} />\n </Typography>\n </Td>\n <Td onClick={(e) => e.stopPropagation()}>\n <Box display=\"inline-block\">\n <IconButton\n tag={Link}\n to={getEditViewLink(document)}\n onClick={() => trackUsage('willEditEntryFromHome')}\n label={formatMessage({\n id: 'content-manager.actions.edit.label',\n defaultMessage: 'Edit',\n })}\n variant=\"ghost\"\n >\n <Pencil />\n </IconButton>\n </Box>\n </Td>\n </Tr>\n ))}\n </Tbody>\n </Table>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * LastEditedWidget\n * -----------------------------------------------------------------------------------------------*/\n\nconst LastEditedWidget = () => {\n const { formatMessage } = useIntl();\n const { data, isLoading, error } = useGetRecentDocumentsQuery({ action: 'update' });\n\n if (isLoading) {\n return <Widget.Loading />;\n }\n\n if (error || !data) {\n return <Widget.Error />;\n }\n\n if (data.length === 0) {\n return (\n <Widget.NoData>\n {formatMessage({\n id: 'content-manager.widget.last-edited.no-data',\n defaultMessage: 'No edited entries',\n })}\n </Widget.NoData>\n );\n }\n\n return <RecentDocumentsTable documents={data} />;\n};\n\n/* -------------------------------------------------------------------------------------------------\n * LastPublishedWidget\n * -----------------------------------------------------------------------------------------------*/\n\nconst LastPublishedWidget = () => {\n const { formatMessage } = useIntl();\n const { data, isLoading, error } = useGetRecentDocumentsQuery({ action: 'publish' });\n\n if (isLoading) {\n return <Widget.Loading />;\n }\n\n if (error || !data) {\n return <Widget.Error />;\n }\n\n if (data.length === 0) {\n return (\n <Widget.NoData>\n {formatMessage({\n id: 'content-manager.widget.last-published.no-data',\n defaultMessage: 'No published entries',\n })}\n </Widget.NoData>\n );\n }\n\n return <RecentDocumentsTable documents={data} />;\n};\n\n/* -------------------------------------------------------------------------------------------------\n * ChartEntriesWidget\n * -----------------------------------------------------------------------------------------------*/\nconst RADIUS = 80;\nconst STROKE = 10;\nconst CIRCUMFERENCE = 2 * Math.PI * (RADIUS - STROKE / 2);\n\ntype ThemeColor = keyof DefaultTheme['colors'];\n\nconst ArcChart = styled.circle<{ $arcColor: ThemeColor }>`\n stroke: ${({ theme, $arcColor }) => theme.colors[$arcColor]};\n`;\n\nconst TextChart = styled.tspan<{ $textColor: ThemeColor }>`\n text-transform: lowercase;\n fill: ${({ theme, $textColor }) => theme.colors[$textColor]};\n`;\n\nconst KeyChartItem = styled(Flex)`\n width: 100%;\n\n ${({ theme }) => theme.breakpoints.small} {\n width: auto;\n }\n`;\n\ninterface ChartData {\n label: string;\n count: number;\n color: ThemeColor;\n}\n\nconst DonutChartSVG = ({ data }: { data: ChartData[] }) => {\n const { locale } = useIntl();\n const { formatMessage } = useIntl();\n const total = data.reduce((acc, curr) => acc + curr.count, 0);\n const [tooltip, setTooltip] = React.useState<{\n visible: boolean;\n x: number;\n y: number;\n value: ChartData | null;\n isTouch?: boolean;\n }>({ visible: false, x: 0, y: 0, value: null });\n\n let cumulativePercent = 0;\n\n const handleMouseOver = (e: React.MouseEvent<SVGCircleElement>, value: ChartData) => {\n setTooltip({\n visible: true,\n x: e.clientX,\n y: e.clientY,\n value,\n });\n };\n const handleMouseOut = () => {\n setTooltip((t) => ({ ...t, visible: false }));\n };\n\n const handleFocus = (e: React.FocusEvent<SVGCircleElement>, value: ChartData) => {\n setTooltip({\n visible: true,\n x:\n e.currentTarget.getBoundingClientRect().width / 2 +\n e.currentTarget.getBoundingClientRect().left,\n y:\n e.currentTarget.getBoundingClientRect().height +\n e.currentTarget.getBoundingClientRect().top,\n value,\n });\n };\n\n return (\n <Flex direction=\"column\" gap={6} margin=\"auto\">\n <svg\n width={RADIUS * 2}\n height={RADIUS * 2}\n viewBox={`0 0 ${RADIUS * 2} ${RADIUS * 2}`}\n style={{ position: 'relative', zIndex: 1 }}\n >\n <g transform={`rotate(-90 ${RADIUS} ${RADIUS})`}>\n {data.map((value) => {\n const percent = (value.count / total) * 100;\n const arcLength = (percent / 100) * CIRCUMFERENCE;\n const dashArray = `${arcLength} ${CIRCUMFERENCE - arcLength}`;\n const dashOffset = CIRCUMFERENCE * (1 - cumulativePercent / 100);\n const el = (\n <ArcChart\n key={value.label}\n cx={RADIUS}\n cy={RADIUS}\n r={RADIUS - STROKE / 2}\n fill=\"none\"\n strokeWidth={STROKE}\n strokeDasharray={dashArray}\n strokeDashoffset={dashOffset}\n style={{ transition: 'stroke-dashoffset 0.3s', cursor: 'pointer' }}\n tabIndex={0}\n aria-describedby={tooltip.visible ? 'chart-tooltip' : undefined}\n onFocus={(e) => handleFocus(e, value)}\n onBlur={handleMouseOut}\n onMouseMove={(e) => handleMouseOver(e, value)}\n onMouseLeave={handleMouseOut}\n $arcColor={value.color}\n />\n );\n cumulativePercent += percent;\n return el;\n })}\n </g>\n <text x={RADIUS} y={RADIUS} textAnchor=\"middle\" fontSize=\"2.4rem\" fontWeight=\"bold\">\n <TextChart x={RADIUS} dy=\"0\" $textColor=\"neutral800\">\n {new Intl.NumberFormat(locale, {\n notation: 'compact',\n maximumFractionDigits: 1,\n }).format(total)}\n </TextChart>\n <TextChart\n x={RADIUS}\n dy=\"1.4em\"\n fontSize=\"1.4rem\"\n fontWeight=\"normal\"\n $textColor=\"neutral600\"\n >\n {formatMessage({\n id: 'content-manager.widget.chart-entries.title',\n defaultMessage: 'entries',\n })}\n </TextChart>\n </text>\n </svg>\n {tooltip.visible && tooltip.value && (\n <Portal\n style={{\n position: 'fixed',\n left: 16,\n top: 16,\n zIndex: 2,\n transform: `translate(${tooltip.x}px, ${tooltip.y}px)`,\n }}\n data-testid=\"entries-chart-tooltip\"\n >\n <Box\n background=\"neutral900\"\n padding={2}\n borderRadius={1}\n textAlign=\"center\"\n role=\"tooltip\"\n aria-live=\"polite\"\n >\n <Typography textColor=\"neutral0\">\n {formatMessage(\n {\n id: 'content-manager.widget.chart-entries.tooltip',\n defaultMessage: '{count} items',\n },\n {\n count: tooltip.value.count,\n label: tooltip.value.label,\n }\n )}\n </Typography>\n </Box>\n </Portal>\n )}\n <Flex gap={4} wrap=\"wrap\">\n {data.map(\n (value) =>\n value.count > 0 && (\n <KeyChartItem gap={1} key={value.label}>\n <Box background={value.color} padding={2} borderRadius={1} />\n <Typography variant=\"pi\">{value.label}</Typography>\n </KeyChartItem>\n )\n )}\n </Flex>\n </Flex>\n );\n};\n\nconst ChartEntriesWidget = () => {\n const { formatMessage } = useIntl();\n const { data: countDocuments, isLoading, error } = useGetCountDocumentsQuery();\n\n if (isLoading) {\n return <Widget.Loading />;\n }\n\n if (error) {\n return <Widget.Error />;\n }\n\n const { draft, published, modified } = countDocuments ?? {\n draft: 0,\n published: 0,\n modified: 0,\n };\n\n const total = draft + published + modified;\n\n if (!total) {\n return (\n <Widget.NoData>\n {formatMessage({\n id: 'content-manager.widget.last-published.no-data',\n defaultMessage: 'No published entries',\n })}\n </Widget.NoData>\n );\n }\n\n return (\n <Flex minHeight=\"100%\">\n <DonutChartSVG\n data={[\n {\n label: formatMessage({\n id: 'content-manager.containers.List.draft',\n defaultMessage: 'Draft',\n }),\n count: draft,\n color: 'secondary500',\n },\n {\n label: formatMessage({\n id: 'content-manager.containers.List.modified',\n defaultMessage: 'Modified',\n }),\n count: modified,\n color: 'alternative500',\n },\n {\n label: formatMessage({\n id: 'content-manager.containers.List.published',\n defaultMessage: 'Published',\n }),\n count: published,\n color: 'success500',\n },\n ]}\n />\n </Flex>\n );\n};\n\nexport { ChartEntriesWidget, LastEditedWidget, LastPublishedWidget };\n"],"names":["CellTypography","styled","Typography","RecentDocumentsTable","documents","formatMessage","useIntl","trackUsage","useTracking","navigate","useNavigate","getEditViewLink","document","isSingleType","kind","kindPath","queryParams","locale","contentTypeUid","documentId","handleRowClick","link","_jsx","Table","colCount","rowCount","length","Tbody","map","_jsxs","Tr","onClick","cursor","Td","title","variant","textColor","id","defaultMessage","contentTypeDisplayName","Box","display","status","DocumentStatus","aria-hidden","RelativeTime","timestamp","Date","updatedAt","e","stopPropagation","IconButton","tag","Link","to","label","Pencil","LastEditedWidget","data","isLoading","error","useGetRecentDocumentsQuery","action","Widget","Loading","Error","NoData","LastPublishedWidget","RADIUS","STROKE","CIRCUMFERENCE","Math","PI","ArcChart","circle","theme","$arcColor","colors","TextChart","tspan","$textColor","KeyChartItem","Flex","breakpoints","small","DonutChartSVG","total","reduce","acc","curr","count","tooltip","setTooltip","React","useState","visible","x","y","value","cumulativePercent","handleMouseOver","clientX","clientY","handleMouseOut","t","handleFocus","currentTarget","getBoundingClientRect","width","left","height","top","direction","gap","margin","svg","viewBox","style","position","zIndex","g","transform","percent","arcLength","dashArray","dashOffset","el","cx","cy","r","fill","strokeWidth","strokeDasharray","strokeDashoffset","transition","tabIndex","aria-describedby","undefined","onFocus","onBlur","onMouseMove","onMouseLeave","color","text","textAnchor","fontSize","fontWeight","dy","Intl","NumberFormat","notation","maximumFractionDigits","format","Portal","data-testid","background","padding","borderRadius","textAlign","role","aria-live","wrap","ChartEntriesWidget","countDocuments","useGetCountDocumentsQuery","draft","published","modified","minHeight"],"mappings":"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"}
@@ -1,6 +1,7 @@
1
1
  import { jsx, jsxs } from 'react/jsx-runtime';
2
- import { Widget, useTracking } from '@strapi/admin/strapi-admin';
3
- import { Typography, Table, Tbody, Tr, Td, Box, IconButton } from '@strapi/design-system';
2
+ import * as React from 'react';
3
+ import { Widget, useGetCountDocumentsQuery, useTracking } from '@strapi/admin/strapi-admin';
4
+ import { Typography, Flex, Table, Tbody, Tr, Td, Box, IconButton, Portal } from '@strapi/design-system';
4
5
  import { Pencil } from '@strapi/icons';
5
6
  import { useIntl } from 'react-intl';
6
7
  import { useNavigate, Link } from 'react-router-dom';
@@ -9,10 +10,9 @@ import { DocumentStatus } from '../pages/EditView/components/DocumentStatus.mjs'
9
10
  import { useGetRecentDocumentsQuery } from '../services/homepage.mjs';
10
11
  import { RelativeTime } from './RelativeTime.mjs';
11
12
 
12
- const CellTypography = styled(Typography).attrs({
13
- maxWidth: '14.4rem',
14
- display: 'block'
15
- })`
13
+ const CellTypography = styled(Typography)`
14
+ display: block;
15
+ max-width: 14.4rem;
16
16
  overflow: hidden;
17
17
  text-overflow: ellipsis;
18
18
  white-space: nowrap;
@@ -153,6 +153,238 @@ const RecentDocumentsTable = ({ documents })=>{
153
153
  documents: data
154
154
  });
155
155
  };
156
+ /* -------------------------------------------------------------------------------------------------
157
+ * ChartEntriesWidget
158
+ * -----------------------------------------------------------------------------------------------*/ const RADIUS = 80;
159
+ const STROKE = 10;
160
+ const CIRCUMFERENCE = 2 * Math.PI * (RADIUS - STROKE / 2);
161
+ const ArcChart = styled.circle`
162
+ stroke: ${({ theme, $arcColor })=>theme.colors[$arcColor]};
163
+ `;
164
+ const TextChart = styled.tspan`
165
+ text-transform: lowercase;
166
+ fill: ${({ theme, $textColor })=>theme.colors[$textColor]};
167
+ `;
168
+ const KeyChartItem = styled(Flex)`
169
+ width: 100%;
170
+
171
+ ${({ theme })=>theme.breakpoints.small} {
172
+ width: auto;
173
+ }
174
+ `;
175
+ const DonutChartSVG = ({ data })=>{
176
+ const { locale } = useIntl();
177
+ const { formatMessage } = useIntl();
178
+ const total = data.reduce((acc, curr)=>acc + curr.count, 0);
179
+ const [tooltip, setTooltip] = React.useState({
180
+ visible: false,
181
+ x: 0,
182
+ y: 0,
183
+ value: null
184
+ });
185
+ let cumulativePercent = 0;
186
+ const handleMouseOver = (e, value)=>{
187
+ setTooltip({
188
+ visible: true,
189
+ x: e.clientX,
190
+ y: e.clientY,
191
+ value
192
+ });
193
+ };
194
+ const handleMouseOut = ()=>{
195
+ setTooltip((t)=>({
196
+ ...t,
197
+ visible: false
198
+ }));
199
+ };
200
+ const handleFocus = (e, value)=>{
201
+ setTooltip({
202
+ visible: true,
203
+ x: e.currentTarget.getBoundingClientRect().width / 2 + e.currentTarget.getBoundingClientRect().left,
204
+ y: e.currentTarget.getBoundingClientRect().height + e.currentTarget.getBoundingClientRect().top,
205
+ value
206
+ });
207
+ };
208
+ return /*#__PURE__*/ jsxs(Flex, {
209
+ direction: "column",
210
+ gap: 6,
211
+ margin: "auto",
212
+ children: [
213
+ /*#__PURE__*/ jsxs("svg", {
214
+ width: RADIUS * 2,
215
+ height: RADIUS * 2,
216
+ viewBox: `0 0 ${RADIUS * 2} ${RADIUS * 2}`,
217
+ style: {
218
+ position: 'relative',
219
+ zIndex: 1
220
+ },
221
+ children: [
222
+ /*#__PURE__*/ jsx("g", {
223
+ transform: `rotate(-90 ${RADIUS} ${RADIUS})`,
224
+ children: data.map((value)=>{
225
+ const percent = value.count / total * 100;
226
+ const arcLength = percent / 100 * CIRCUMFERENCE;
227
+ const dashArray = `${arcLength} ${CIRCUMFERENCE - arcLength}`;
228
+ const dashOffset = CIRCUMFERENCE * (1 - cumulativePercent / 100);
229
+ const el = /*#__PURE__*/ jsx(ArcChart, {
230
+ cx: RADIUS,
231
+ cy: RADIUS,
232
+ r: RADIUS - STROKE / 2,
233
+ fill: "none",
234
+ strokeWidth: STROKE,
235
+ strokeDasharray: dashArray,
236
+ strokeDashoffset: dashOffset,
237
+ style: {
238
+ transition: 'stroke-dashoffset 0.3s',
239
+ cursor: 'pointer'
240
+ },
241
+ tabIndex: 0,
242
+ "aria-describedby": tooltip.visible ? 'chart-tooltip' : undefined,
243
+ onFocus: (e)=>handleFocus(e, value),
244
+ onBlur: handleMouseOut,
245
+ onMouseMove: (e)=>handleMouseOver(e, value),
246
+ onMouseLeave: handleMouseOut,
247
+ $arcColor: value.color
248
+ }, value.label);
249
+ cumulativePercent += percent;
250
+ return el;
251
+ })
252
+ }),
253
+ /*#__PURE__*/ jsxs("text", {
254
+ x: RADIUS,
255
+ y: RADIUS,
256
+ textAnchor: "middle",
257
+ fontSize: "2.4rem",
258
+ fontWeight: "bold",
259
+ children: [
260
+ /*#__PURE__*/ jsx(TextChart, {
261
+ x: RADIUS,
262
+ dy: "0",
263
+ $textColor: "neutral800",
264
+ children: new Intl.NumberFormat(locale, {
265
+ notation: 'compact',
266
+ maximumFractionDigits: 1
267
+ }).format(total)
268
+ }),
269
+ /*#__PURE__*/ jsx(TextChart, {
270
+ x: RADIUS,
271
+ dy: "1.4em",
272
+ fontSize: "1.4rem",
273
+ fontWeight: "normal",
274
+ $textColor: "neutral600",
275
+ children: formatMessage({
276
+ id: 'content-manager.widget.chart-entries.title',
277
+ defaultMessage: 'entries'
278
+ })
279
+ })
280
+ ]
281
+ })
282
+ ]
283
+ }),
284
+ tooltip.visible && tooltip.value && /*#__PURE__*/ jsx(Portal, {
285
+ style: {
286
+ position: 'fixed',
287
+ left: 16,
288
+ top: 16,
289
+ zIndex: 2,
290
+ transform: `translate(${tooltip.x}px, ${tooltip.y}px)`
291
+ },
292
+ "data-testid": "entries-chart-tooltip",
293
+ children: /*#__PURE__*/ jsx(Box, {
294
+ background: "neutral900",
295
+ padding: 2,
296
+ borderRadius: 1,
297
+ textAlign: "center",
298
+ role: "tooltip",
299
+ "aria-live": "polite",
300
+ children: /*#__PURE__*/ jsx(Typography, {
301
+ textColor: "neutral0",
302
+ children: formatMessage({
303
+ id: 'content-manager.widget.chart-entries.tooltip',
304
+ defaultMessage: '{count} items'
305
+ }, {
306
+ count: tooltip.value.count,
307
+ label: tooltip.value.label
308
+ })
309
+ })
310
+ })
311
+ }),
312
+ /*#__PURE__*/ jsx(Flex, {
313
+ gap: 4,
314
+ wrap: "wrap",
315
+ children: data.map((value)=>value.count > 0 && /*#__PURE__*/ jsxs(KeyChartItem, {
316
+ gap: 1,
317
+ children: [
318
+ /*#__PURE__*/ jsx(Box, {
319
+ background: value.color,
320
+ padding: 2,
321
+ borderRadius: 1
322
+ }),
323
+ /*#__PURE__*/ jsx(Typography, {
324
+ variant: "pi",
325
+ children: value.label
326
+ })
327
+ ]
328
+ }, value.label))
329
+ })
330
+ ]
331
+ });
332
+ };
333
+ const ChartEntriesWidget = ()=>{
334
+ const { formatMessage } = useIntl();
335
+ const { data: countDocuments, isLoading, error } = useGetCountDocumentsQuery();
336
+ if (isLoading) {
337
+ return /*#__PURE__*/ jsx(Widget.Loading, {});
338
+ }
339
+ if (error) {
340
+ return /*#__PURE__*/ jsx(Widget.Error, {});
341
+ }
342
+ const { draft, published, modified } = countDocuments ?? {
343
+ draft: 0,
344
+ published: 0,
345
+ modified: 0
346
+ };
347
+ const total = draft + published + modified;
348
+ if (!total) {
349
+ return /*#__PURE__*/ jsx(Widget.NoData, {
350
+ children: formatMessage({
351
+ id: 'content-manager.widget.last-published.no-data',
352
+ defaultMessage: 'No published entries'
353
+ })
354
+ });
355
+ }
356
+ return /*#__PURE__*/ jsx(Flex, {
357
+ minHeight: "100%",
358
+ children: /*#__PURE__*/ jsx(DonutChartSVG, {
359
+ data: [
360
+ {
361
+ label: formatMessage({
362
+ id: 'content-manager.containers.List.draft',
363
+ defaultMessage: 'Draft'
364
+ }),
365
+ count: draft,
366
+ color: 'secondary500'
367
+ },
368
+ {
369
+ label: formatMessage({
370
+ id: 'content-manager.containers.List.modified',
371
+ defaultMessage: 'Modified'
372
+ }),
373
+ count: modified,
374
+ color: 'alternative500'
375
+ },
376
+ {
377
+ label: formatMessage({
378
+ id: 'content-manager.containers.List.published',
379
+ defaultMessage: 'Published'
380
+ }),
381
+ count: published,
382
+ color: 'success500'
383
+ }
384
+ ]
385
+ })
386
+ });
387
+ };
156
388
 
157
- export { LastEditedWidget, LastPublishedWidget };
389
+ export { ChartEntriesWidget, LastEditedWidget, LastPublishedWidget };
158
390
  //# sourceMappingURL=Widgets.mjs.map