diff --git a/src/renderer/src/components/plugins/Plugin.jsx b/src/renderer/src/components/plugins/Plugin.jsx index 5c03472f..9d676381 100644 --- a/src/renderer/src/components/plugins/Plugin.jsx +++ b/src/renderer/src/components/plugins/Plugin.jsx @@ -9,7 +9,7 @@ import { Button, ModalDirectional } from '@platformatic/ui-components' import { useState } from 'react' import PluginDetail from './PluginDetail' -function Plugin ({ name, onClickCardPlugin, isSelected, description, tags, author, homepage }) { +function Plugin ({ name, onClickCardPlugin, isSelected, description, tags, author, homepage, downloads }) { const [showModalDetail, setShowModalDetail] = useState(false) let className = `${commonStyles.smallFlexBlock} ${styles.container} ` className += isSelected ? styles.selected : styles.unSelected @@ -59,6 +59,7 @@ function Plugin ({ name, onClickCardPlugin, isSelected, description, tags, autho tags={tags} author={author} homepage={homepage} + downloads={downloads} onClickSelectPlugin={() => handleClickSelectPluginDetail()} /> @@ -91,8 +92,14 @@ Plugin.propTypes = { /** * homepage */ - homepage: PropTypes.string - + homepage: PropTypes.string, + /** + * downloads + */ + downloads: PropTypes.oneOfType([ + PropTypes.string, + PropTypes.number + ]) } Plugin.defaultProps = { @@ -101,6 +108,7 @@ Plugin.defaultProps = { description: '', tags: [], author: '', + downloads: 0, homepage: '' } diff --git a/src/renderer/src/components/plugins/PluginDetail.jsx b/src/renderer/src/components/plugins/PluginDetail.jsx index c9a0ecfe..e2e91667 100644 --- a/src/renderer/src/components/plugins/PluginDetail.jsx +++ b/src/renderer/src/components/plugins/PluginDetail.jsx @@ -7,7 +7,7 @@ import Title from '~/components/ui/Title' import { Button, HorizontalSeparator, Icons, Tag, VerticalSeparator } from '@platformatic/ui-components' import { MARGIN_0, OPACITY_30, RICH_BLACK, SMALL, TERTIARY_BLUE, WHITE } from '@platformatic/ui-components/src/components/constants' -function PluginDetail ({ name, description, tags, author, homepage, onClickSelectPlugin }) { +function PluginDetail ({ name, description, tags, author, homepage, downloads, onClickSelectPlugin }) { return (
@@ -20,11 +20,24 @@ function PluginDetail ({ name, description, tags, author, homepage, onClickSelec />

{description}

+
+ + {downloads} +
+ + +
{author}
+ + +
+ Supported by: {author} +
+ {homepage && ( <> @@ -92,6 +105,13 @@ PluginDetail.propTypes = { * homepage */ homepage: PropTypes.string, + /** + * downloads + */ + downloads: PropTypes.oneOfType([ + PropTypes.string, + PropTypes.number + ]), /** * onClickSelectPlugin */ @@ -103,6 +123,7 @@ PluginDetail.defaultProps = { tags: [], author: '', homepage: '', + downloads: 0, onClickSelectPlugin: () => {} } diff --git a/src/renderer/src/components/templates/Template.jsx b/src/renderer/src/components/templates/Template.jsx index 028114dd..d2fc8357 100644 --- a/src/renderer/src/components/templates/Template.jsx +++ b/src/renderer/src/components/templates/Template.jsx @@ -17,6 +17,7 @@ function Template ({ tags, author, homepage, + downloads, onClickCardTemplate }) { const [showModalDetail, setShowModalDetail] = useState(false) @@ -66,6 +67,7 @@ function Template ({ description={description} tags={tags} author={author} + downloads={downloads} homepage={homepage} onClickSelectTemplate={() => handleClickSelectTemplateDetail()} /> @@ -105,6 +107,13 @@ Template.propTypes = { * author */ author: PropTypes.string, + /** + * downloads + */ + downloads: PropTypes.oneOfType([ + PropTypes.string, + PropTypes.number + ]), /** * homepage */ @@ -118,6 +127,7 @@ Template.defaultProps = { onClickCardTemplate: () => {}, description: '', author: '', + downloads: 0, homepage: '', tags: [] } diff --git a/src/renderer/src/components/templates/TemplateDetail.jsx b/src/renderer/src/components/templates/TemplateDetail.jsx index 3ed15199..e981e7af 100644 --- a/src/renderer/src/components/templates/TemplateDetail.jsx +++ b/src/renderer/src/components/templates/TemplateDetail.jsx @@ -7,7 +7,7 @@ import Title from '~/components/ui/Title' import { Button, HorizontalSeparator, Icons, Tag, VerticalSeparator } from '@platformatic/ui-components' import { MARGIN_0, OPACITY_30, RICH_BLACK, SMALL, TERTIARY_BLUE, WHITE } from '@platformatic/ui-components/src/components/constants' -function TemplateDetail ({ name, description, tags, author, homepage, onClickSelectTemplate }) { +function TemplateDetail ({ name, description, tags, author, homepage, downloads, onClickSelectTemplate }) { return (
@@ -20,11 +20,24 @@ function TemplateDetail ({ name, description, tags, author, homepage, onClickSel />

{description}

+
+ + {downloads} +
+ + +
{author}
+ + +
+ Supported by: {author} +
+ {homepage && ( <> @@ -87,6 +100,13 @@ TemplateDetail.propTypes = { * author */ author: PropTypes.string, + /** + * downloads + */ + downloads: PropTypes.oneOfType([ + PropTypes.string, + PropTypes.number + ]), /** * onClickSelectTemplate */ @@ -101,6 +121,7 @@ TemplateDetail.defaultProps = { description: '', tags: [], author: '', + downloads: 0, homepage: '', onClickSelectTemplate: () => {} }