@strapi/content-manager 5.18.0 → 5.19.0

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 (83) hide show
  1. package/dist/admin/components/Widgets.js +253 -0
  2. package/dist/admin/components/Widgets.js.map +1 -1
  3. package/dist/admin/components/Widgets.mjs +236 -3
  4. package/dist/admin/components/Widgets.mjs.map +1 -1
  5. package/dist/admin/index.js +20 -2
  6. package/dist/admin/index.js.map +1 -1
  7. package/dist/admin/index.mjs +21 -3
  8. package/dist/admin/index.mjs.map +1 -1
  9. package/dist/admin/pages/EditView/EditViewPage.js +5 -0
  10. package/dist/admin/pages/EditView/EditViewPage.js.map +1 -1
  11. package/dist/admin/pages/EditView/EditViewPage.mjs +7 -2
  12. package/dist/admin/pages/EditView/EditViewPage.mjs.map +1 -1
  13. package/dist/admin/pages/ListView/ListViewPage.js +147 -138
  14. package/dist/admin/pages/ListView/ListViewPage.js.map +1 -1
  15. package/dist/admin/pages/ListView/ListViewPage.mjs +147 -138
  16. package/dist/admin/pages/ListView/ListViewPage.mjs.map +1 -1
  17. package/dist/admin/preview/pages/Preview.js +86 -33
  18. package/dist/admin/preview/pages/Preview.js.map +1 -1
  19. package/dist/admin/preview/pages/Preview.mjs +87 -34
  20. package/dist/admin/preview/pages/Preview.mjs.map +1 -1
  21. package/dist/admin/services/api.js +2 -1
  22. package/dist/admin/services/api.js.map +1 -1
  23. package/dist/admin/services/api.mjs +2 -1
  24. package/dist/admin/services/api.mjs.map +1 -1
  25. package/dist/admin/services/documents.js +30 -14
  26. package/dist/admin/services/documents.js.map +1 -1
  27. package/dist/admin/services/documents.mjs +30 -14
  28. package/dist/admin/services/documents.mjs.map +1 -1
  29. package/dist/admin/services/homepage.js +11 -2
  30. package/dist/admin/services/homepage.js.map +1 -1
  31. package/dist/admin/services/homepage.mjs +11 -3
  32. package/dist/admin/services/homepage.mjs.map +1 -1
  33. package/dist/admin/src/components/Widgets.d.ts +2 -1
  34. package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
  35. package/dist/admin/src/preview/services/preview.d.ts +1 -1
  36. package/dist/admin/src/services/api.d.ts +1 -1
  37. package/dist/admin/src/services/components.d.ts +2 -2
  38. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  39. package/dist/admin/src/services/documents.d.ts +16 -16
  40. package/dist/admin/src/services/homepage.d.ts +6 -2
  41. package/dist/admin/src/services/init.d.ts +1 -1
  42. package/dist/admin/src/services/relations.d.ts +2 -2
  43. package/dist/admin/src/services/uid.d.ts +3 -3
  44. package/dist/admin/translations/en.json.js +5 -0
  45. package/dist/admin/translations/en.json.js.map +1 -1
  46. package/dist/admin/translations/en.json.mjs +5 -0
  47. package/dist/admin/translations/en.json.mjs.map +1 -1
  48. package/dist/admin/translations/es.json.js +5 -2
  49. package/dist/admin/translations/es.json.js.map +1 -1
  50. package/dist/admin/translations/es.json.mjs +5 -2
  51. package/dist/admin/translations/es.json.mjs.map +1 -1
  52. package/dist/admin/translations/fr.json.js +4 -1
  53. package/dist/admin/translations/fr.json.js.map +1 -1
  54. package/dist/admin/translations/fr.json.mjs +4 -1
  55. package/dist/admin/translations/fr.json.mjs.map +1 -1
  56. package/dist/server/homepage/controllers/homepage.js +5 -0
  57. package/dist/server/homepage/controllers/homepage.js.map +1 -1
  58. package/dist/server/homepage/controllers/homepage.mjs +5 -0
  59. package/dist/server/homepage/controllers/homepage.mjs.map +1 -1
  60. package/dist/server/homepage/routes/homepage.js +11 -0
  61. package/dist/server/homepage/routes/homepage.js.map +1 -1
  62. package/dist/server/homepage/routes/homepage.mjs +11 -0
  63. package/dist/server/homepage/routes/homepage.mjs.map +1 -1
  64. package/dist/server/homepage/services/homepage.js +31 -0
  65. package/dist/server/homepage/services/homepage.js.map +1 -1
  66. package/dist/server/homepage/services/homepage.mjs +31 -0
  67. package/dist/server/homepage/services/homepage.mjs.map +1 -1
  68. package/dist/server/src/homepage/controllers/homepage.d.ts +2 -1
  69. package/dist/server/src/homepage/controllers/homepage.d.ts.map +1 -1
  70. package/dist/server/src/homepage/index.d.ts +5 -0
  71. package/dist/server/src/homepage/index.d.ts.map +1 -1
  72. package/dist/server/src/homepage/routes/homepage.d.ts.map +1 -1
  73. package/dist/server/src/homepage/services/homepage.d.ts +2 -1
  74. package/dist/server/src/homepage/services/homepage.d.ts.map +1 -1
  75. package/dist/server/src/homepage/services/index.d.ts +5 -0
  76. package/dist/server/src/homepage/services/index.d.ts.map +1 -1
  77. package/dist/server/src/index.d.ts +5 -0
  78. package/dist/server/src/index.d.ts.map +1 -1
  79. package/dist/server/src/services/index.d.ts +5 -0
  80. package/dist/server/src/services/index.d.ts.map +1 -1
  81. package/dist/shared/contracts/homepage.d.ts +13 -0
  82. package/dist/shared/contracts/homepage.d.ts.map +1 -1
  83. package/package.json +7 -7
@@ -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,6 +12,25 @@ 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
 
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
+
14
34
  const CellTypography = styledComponents.styled(designSystem.Typography).attrs({
15
35
  maxWidth: '14.4rem',
16
36
  display: 'block'
@@ -155,7 +175,240 @@ const RecentDocumentsTable = ({ documents })=>{
155
175
  documents: data
156
176
  });
157
177
  };
178
+ /* -------------------------------------------------------------------------------------------------
179
+ * ChartEntriesWidget
180
+ * -----------------------------------------------------------------------------------------------*/ const RADIUS = 80;
181
+ const STROKE = 10;
182
+ const CIRCUMFERENCE = 2 * Math.PI * (RADIUS - STROKE / 2);
183
+ const ArcChart = styledComponents.styled.circle`
184
+ stroke: ${({ theme, $arcColor })=>theme.colors[$arcColor]};
185
+ `;
186
+ const TextChart = styledComponents.styled.tspan`
187
+ text-transform: lowercase;
188
+ fill: ${({ theme, $textColor })=>theme.colors[$textColor]};
189
+ `;
190
+ const KeyChartItem = styledComponents.styled(designSystem.Flex)`
191
+ width: 100%;
192
+
193
+ ${({ theme })=>theme.breakpoints.small} {
194
+ width: auto;
195
+ }
196
+ `;
197
+ const DonutChartSVG = ({ data })=>{
198
+ const { locale } = reactIntl.useIntl();
199
+ const { formatMessage } = reactIntl.useIntl();
200
+ const total = data.reduce((acc, curr)=>acc + curr.count, 0);
201
+ const [tooltip, setTooltip] = React__namespace.useState({
202
+ visible: false,
203
+ x: 0,
204
+ y: 0,
205
+ value: null
206
+ });
207
+ let cumulativePercent = 0;
208
+ const handleMouseOver = (e, value)=>{
209
+ setTooltip({
210
+ visible: true,
211
+ x: e.clientX,
212
+ y: e.clientY,
213
+ value
214
+ });
215
+ };
216
+ const handleMouseOut = ()=>{
217
+ setTooltip((t)=>({
218
+ ...t,
219
+ visible: false
220
+ }));
221
+ };
222
+ const handleFocus = (e, value)=>{
223
+ setTooltip({
224
+ visible: true,
225
+ x: e.currentTarget.getBoundingClientRect().width / 2 + e.currentTarget.getBoundingClientRect().left,
226
+ y: e.currentTarget.getBoundingClientRect().height + e.currentTarget.getBoundingClientRect().top,
227
+ value
228
+ });
229
+ };
230
+ return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
231
+ direction: "column",
232
+ gap: 6,
233
+ margin: "auto",
234
+ children: [
235
+ /*#__PURE__*/ jsxRuntime.jsxs("svg", {
236
+ width: RADIUS * 2,
237
+ height: RADIUS * 2,
238
+ viewBox: `0 0 ${RADIUS * 2} ${RADIUS * 2}`,
239
+ style: {
240
+ position: 'relative',
241
+ zIndex: 1
242
+ },
243
+ children: [
244
+ /*#__PURE__*/ jsxRuntime.jsx("g", {
245
+ transform: `rotate(-90 ${RADIUS} ${RADIUS})`,
246
+ children: data.map((value)=>{
247
+ const percent = value.count / total * 100;
248
+ const arcLength = percent / 100 * CIRCUMFERENCE;
249
+ const dashArray = `${arcLength} ${CIRCUMFERENCE - arcLength}`;
250
+ const dashOffset = CIRCUMFERENCE * (1 - cumulativePercent / 100);
251
+ const el = /*#__PURE__*/ jsxRuntime.jsx(ArcChart, {
252
+ cx: RADIUS,
253
+ cy: RADIUS,
254
+ r: RADIUS - STROKE / 2,
255
+ fill: "none",
256
+ strokeWidth: STROKE,
257
+ strokeDasharray: dashArray,
258
+ strokeDashoffset: dashOffset,
259
+ style: {
260
+ transition: 'stroke-dashoffset 0.3s',
261
+ cursor: 'pointer'
262
+ },
263
+ tabIndex: 0,
264
+ "aria-describedby": tooltip.visible ? 'chart-tooltip' : undefined,
265
+ onFocus: (e)=>handleFocus(e, value),
266
+ onBlur: handleMouseOut,
267
+ onMouseMove: (e)=>handleMouseOver(e, value),
268
+ onMouseLeave: handleMouseOut,
269
+ $arcColor: value.color
270
+ }, value.label);
271
+ cumulativePercent += percent;
272
+ return el;
273
+ })
274
+ }),
275
+ /*#__PURE__*/ jsxRuntime.jsxs("text", {
276
+ x: RADIUS,
277
+ y: RADIUS,
278
+ textAnchor: "middle",
279
+ fontSize: "2.4rem",
280
+ fontWeight: "bold",
281
+ children: [
282
+ /*#__PURE__*/ jsxRuntime.jsx(TextChart, {
283
+ x: RADIUS,
284
+ dy: "0",
285
+ $textColor: "neutral800",
286
+ children: new Intl.NumberFormat(locale, {
287
+ notation: 'compact',
288
+ maximumFractionDigits: 1
289
+ }).format(total)
290
+ }),
291
+ /*#__PURE__*/ jsxRuntime.jsx(TextChart, {
292
+ x: RADIUS,
293
+ dy: "1.4em",
294
+ fontSize: "1.4rem",
295
+ fontWeight: "normal",
296
+ $textColor: "neutral600",
297
+ children: formatMessage({
298
+ id: 'content-manager.widget.chart-entries.title',
299
+ defaultMessage: 'entries'
300
+ })
301
+ })
302
+ ]
303
+ })
304
+ ]
305
+ }),
306
+ tooltip.visible && tooltip.value && /*#__PURE__*/ jsxRuntime.jsx(designSystem.Portal, {
307
+ style: {
308
+ position: 'fixed',
309
+ left: 16,
310
+ top: 16,
311
+ zIndex: 2,
312
+ transform: `translate(${tooltip.x}px, ${tooltip.y}px)`
313
+ },
314
+ "data-testid": "entries-chart-tooltip",
315
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
316
+ background: "neutral900",
317
+ padding: 2,
318
+ borderRadius: 1,
319
+ textAlign: "center",
320
+ role: "tooltip",
321
+ "aria-live": "polite",
322
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
323
+ textColor: "neutral0",
324
+ children: formatMessage({
325
+ id: 'content-manager.widget.chart-entries.tooltip',
326
+ defaultMessage: '{count} items'
327
+ }, {
328
+ count: tooltip.value.count,
329
+ label: tooltip.value.label
330
+ })
331
+ })
332
+ })
333
+ }),
334
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
335
+ gap: 4,
336
+ wrap: "wrap",
337
+ children: data.map((value)=>value.count > 0 && /*#__PURE__*/ jsxRuntime.jsxs(KeyChartItem, {
338
+ gap: 1,
339
+ children: [
340
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Box, {
341
+ background: value.color,
342
+ padding: 2,
343
+ borderRadius: 1
344
+ }),
345
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
346
+ variant: "pi",
347
+ children: value.label
348
+ })
349
+ ]
350
+ }, value.label))
351
+ })
352
+ ]
353
+ });
354
+ };
355
+ const ChartEntriesWidget = ()=>{
356
+ const { formatMessage } = reactIntl.useIntl();
357
+ const { data: countDocuments, isLoading, error } = homepage.useGetCountDocumentsQuery();
358
+ if (isLoading) {
359
+ return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Widget.Loading, {});
360
+ }
361
+ if (error) {
362
+ return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Widget.Error, {});
363
+ }
364
+ const { draft, published, modified } = countDocuments ?? {
365
+ draft: 0,
366
+ published: 0,
367
+ modified: 0
368
+ };
369
+ const total = draft + published + modified;
370
+ if (!total) {
371
+ return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Widget.NoData, {
372
+ children: formatMessage({
373
+ id: 'content-manager.widget.last-published.no-data',
374
+ defaultMessage: 'No published entries'
375
+ })
376
+ });
377
+ }
378
+ return /*#__PURE__*/ jsxRuntime.jsx(designSystem.Flex, {
379
+ minHeight: "100%",
380
+ children: /*#__PURE__*/ jsxRuntime.jsx(DonutChartSVG, {
381
+ data: [
382
+ {
383
+ label: formatMessage({
384
+ id: 'content-manager.containers.List.draft',
385
+ defaultMessage: 'Draft'
386
+ }),
387
+ count: draft,
388
+ color: 'secondary500'
389
+ },
390
+ {
391
+ label: formatMessage({
392
+ id: 'content-manager.containers.List.modified',
393
+ defaultMessage: 'Modified'
394
+ }),
395
+ count: modified,
396
+ color: 'alternative500'
397
+ },
398
+ {
399
+ label: formatMessage({
400
+ id: 'content-manager.containers.List.published',
401
+ defaultMessage: 'Published'
402
+ }),
403
+ count: published,
404
+ color: 'success500'
405
+ }
406
+ ]
407
+ })
408
+ });
409
+ };
158
410
 
411
+ exports.ChartEntriesWidget = ChartEntriesWidget;
159
412
  exports.LastEditedWidget = LastEditedWidget;
160
413
  exports.LastPublishedWidget = LastPublishedWidget;
161
414
  //# 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 } 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, useGetCountDocumentsQuery } 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\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","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","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,12 +1,13 @@
1
1
  import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import * as React from 'react';
2
3
  import { Widget, useTracking } from '@strapi/admin/strapi-admin';
3
- import { Typography, Table, Tbody, Tr, Td, Box, IconButton } from '@strapi/design-system';
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';
7
8
  import { styled } from 'styled-components';
8
9
  import { DocumentStatus } from '../pages/EditView/components/DocumentStatus.mjs';
9
- import { useGetRecentDocumentsQuery } from '../services/homepage.mjs';
10
+ import { useGetRecentDocumentsQuery, useGetCountDocumentsQuery } from '../services/homepage.mjs';
10
11
  import { RelativeTime } from './RelativeTime.mjs';
11
12
 
12
13
  const CellTypography = styled(Typography).attrs({
@@ -153,6 +154,238 @@ const RecentDocumentsTable = ({ documents })=>{
153
154
  documents: data
154
155
  });
155
156
  };
157
+ /* -------------------------------------------------------------------------------------------------
158
+ * ChartEntriesWidget
159
+ * -----------------------------------------------------------------------------------------------*/ const RADIUS = 80;
160
+ const STROKE = 10;
161
+ const CIRCUMFERENCE = 2 * Math.PI * (RADIUS - STROKE / 2);
162
+ const ArcChart = styled.circle`
163
+ stroke: ${({ theme, $arcColor })=>theme.colors[$arcColor]};
164
+ `;
165
+ const TextChart = styled.tspan`
166
+ text-transform: lowercase;
167
+ fill: ${({ theme, $textColor })=>theme.colors[$textColor]};
168
+ `;
169
+ const KeyChartItem = styled(Flex)`
170
+ width: 100%;
171
+
172
+ ${({ theme })=>theme.breakpoints.small} {
173
+ width: auto;
174
+ }
175
+ `;
176
+ const DonutChartSVG = ({ data })=>{
177
+ const { locale } = useIntl();
178
+ const { formatMessage } = useIntl();
179
+ const total = data.reduce((acc, curr)=>acc + curr.count, 0);
180
+ const [tooltip, setTooltip] = React.useState({
181
+ visible: false,
182
+ x: 0,
183
+ y: 0,
184
+ value: null
185
+ });
186
+ let cumulativePercent = 0;
187
+ const handleMouseOver = (e, value)=>{
188
+ setTooltip({
189
+ visible: true,
190
+ x: e.clientX,
191
+ y: e.clientY,
192
+ value
193
+ });
194
+ };
195
+ const handleMouseOut = ()=>{
196
+ setTooltip((t)=>({
197
+ ...t,
198
+ visible: false
199
+ }));
200
+ };
201
+ const handleFocus = (e, value)=>{
202
+ setTooltip({
203
+ visible: true,
204
+ x: e.currentTarget.getBoundingClientRect().width / 2 + e.currentTarget.getBoundingClientRect().left,
205
+ y: e.currentTarget.getBoundingClientRect().height + e.currentTarget.getBoundingClientRect().top,
206
+ value
207
+ });
208
+ };
209
+ return /*#__PURE__*/ jsxs(Flex, {
210
+ direction: "column",
211
+ gap: 6,
212
+ margin: "auto",
213
+ children: [
214
+ /*#__PURE__*/ jsxs("svg", {
215
+ width: RADIUS * 2,
216
+ height: RADIUS * 2,
217
+ viewBox: `0 0 ${RADIUS * 2} ${RADIUS * 2}`,
218
+ style: {
219
+ position: 'relative',
220
+ zIndex: 1
221
+ },
222
+ children: [
223
+ /*#__PURE__*/ jsx("g", {
224
+ transform: `rotate(-90 ${RADIUS} ${RADIUS})`,
225
+ children: data.map((value)=>{
226
+ const percent = value.count / total * 100;
227
+ const arcLength = percent / 100 * CIRCUMFERENCE;
228
+ const dashArray = `${arcLength} ${CIRCUMFERENCE - arcLength}`;
229
+ const dashOffset = CIRCUMFERENCE * (1 - cumulativePercent / 100);
230
+ const el = /*#__PURE__*/ jsx(ArcChart, {
231
+ cx: RADIUS,
232
+ cy: RADIUS,
233
+ r: RADIUS - STROKE / 2,
234
+ fill: "none",
235
+ strokeWidth: STROKE,
236
+ strokeDasharray: dashArray,
237
+ strokeDashoffset: dashOffset,
238
+ style: {
239
+ transition: 'stroke-dashoffset 0.3s',
240
+ cursor: 'pointer'
241
+ },
242
+ tabIndex: 0,
243
+ "aria-describedby": tooltip.visible ? 'chart-tooltip' : undefined,
244
+ onFocus: (e)=>handleFocus(e, value),
245
+ onBlur: handleMouseOut,
246
+ onMouseMove: (e)=>handleMouseOver(e, value),
247
+ onMouseLeave: handleMouseOut,
248
+ $arcColor: value.color
249
+ }, value.label);
250
+ cumulativePercent += percent;
251
+ return el;
252
+ })
253
+ }),
254
+ /*#__PURE__*/ jsxs("text", {
255
+ x: RADIUS,
256
+ y: RADIUS,
257
+ textAnchor: "middle",
258
+ fontSize: "2.4rem",
259
+ fontWeight: "bold",
260
+ children: [
261
+ /*#__PURE__*/ jsx(TextChart, {
262
+ x: RADIUS,
263
+ dy: "0",
264
+ $textColor: "neutral800",
265
+ children: new Intl.NumberFormat(locale, {
266
+ notation: 'compact',
267
+ maximumFractionDigits: 1
268
+ }).format(total)
269
+ }),
270
+ /*#__PURE__*/ jsx(TextChart, {
271
+ x: RADIUS,
272
+ dy: "1.4em",
273
+ fontSize: "1.4rem",
274
+ fontWeight: "normal",
275
+ $textColor: "neutral600",
276
+ children: formatMessage({
277
+ id: 'content-manager.widget.chart-entries.title',
278
+ defaultMessage: 'entries'
279
+ })
280
+ })
281
+ ]
282
+ })
283
+ ]
284
+ }),
285
+ tooltip.visible && tooltip.value && /*#__PURE__*/ jsx(Portal, {
286
+ style: {
287
+ position: 'fixed',
288
+ left: 16,
289
+ top: 16,
290
+ zIndex: 2,
291
+ transform: `translate(${tooltip.x}px, ${tooltip.y}px)`
292
+ },
293
+ "data-testid": "entries-chart-tooltip",
294
+ children: /*#__PURE__*/ jsx(Box, {
295
+ background: "neutral900",
296
+ padding: 2,
297
+ borderRadius: 1,
298
+ textAlign: "center",
299
+ role: "tooltip",
300
+ "aria-live": "polite",
301
+ children: /*#__PURE__*/ jsx(Typography, {
302
+ textColor: "neutral0",
303
+ children: formatMessage({
304
+ id: 'content-manager.widget.chart-entries.tooltip',
305
+ defaultMessage: '{count} items'
306
+ }, {
307
+ count: tooltip.value.count,
308
+ label: tooltip.value.label
309
+ })
310
+ })
311
+ })
312
+ }),
313
+ /*#__PURE__*/ jsx(Flex, {
314
+ gap: 4,
315
+ wrap: "wrap",
316
+ children: data.map((value)=>value.count > 0 && /*#__PURE__*/ jsxs(KeyChartItem, {
317
+ gap: 1,
318
+ children: [
319
+ /*#__PURE__*/ jsx(Box, {
320
+ background: value.color,
321
+ padding: 2,
322
+ borderRadius: 1
323
+ }),
324
+ /*#__PURE__*/ jsx(Typography, {
325
+ variant: "pi",
326
+ children: value.label
327
+ })
328
+ ]
329
+ }, value.label))
330
+ })
331
+ ]
332
+ });
333
+ };
334
+ const ChartEntriesWidget = ()=>{
335
+ const { formatMessage } = useIntl();
336
+ const { data: countDocuments, isLoading, error } = useGetCountDocumentsQuery();
337
+ if (isLoading) {
338
+ return /*#__PURE__*/ jsx(Widget.Loading, {});
339
+ }
340
+ if (error) {
341
+ return /*#__PURE__*/ jsx(Widget.Error, {});
342
+ }
343
+ const { draft, published, modified } = countDocuments ?? {
344
+ draft: 0,
345
+ published: 0,
346
+ modified: 0
347
+ };
348
+ const total = draft + published + modified;
349
+ if (!total) {
350
+ return /*#__PURE__*/ jsx(Widget.NoData, {
351
+ children: formatMessage({
352
+ id: 'content-manager.widget.last-published.no-data',
353
+ defaultMessage: 'No published entries'
354
+ })
355
+ });
356
+ }
357
+ return /*#__PURE__*/ jsx(Flex, {
358
+ minHeight: "100%",
359
+ children: /*#__PURE__*/ jsx(DonutChartSVG, {
360
+ data: [
361
+ {
362
+ label: formatMessage({
363
+ id: 'content-manager.containers.List.draft',
364
+ defaultMessage: 'Draft'
365
+ }),
366
+ count: draft,
367
+ color: 'secondary500'
368
+ },
369
+ {
370
+ label: formatMessage({
371
+ id: 'content-manager.containers.List.modified',
372
+ defaultMessage: 'Modified'
373
+ }),
374
+ count: modified,
375
+ color: 'alternative500'
376
+ },
377
+ {
378
+ label: formatMessage({
379
+ id: 'content-manager.containers.List.published',
380
+ defaultMessage: 'Published'
381
+ }),
382
+ count: published,
383
+ color: 'success500'
384
+ }
385
+ ]
386
+ })
387
+ });
388
+ };
156
389
 
157
- export { LastEditedWidget, LastPublishedWidget };
390
+ export { ChartEntriesWidget, LastEditedWidget, LastPublishedWidget };
158
391
  //# sourceMappingURL=Widgets.mjs.map