diff --git a/frontend/components/cards/SourceRsd.tsx b/frontend/components/cards/SourceRsd.tsx new file mode 100644 index 000000000..bbded3882 --- /dev/null +++ b/frontend/components/cards/SourceRsd.tsx @@ -0,0 +1,18 @@ +// SPDX-FileCopyrightText: 2024 Dusan Mijatovic (Netherlands eScience Center) +// SPDX-FileCopyrightText: 2024 Netherlands eScience Center +// +// SPDX-License-Identifier: Apache-2.0 + +export default function SourceRsd({source,domain}:{source?:string|null,domain?:string|null}){ + + if (!source) return null + + return ( +
+ {source} +
+ ) +} diff --git a/frontend/components/organisation/software/list/AdminSoftwareListItem.tsx b/frontend/components/organisation/software/list/AdminSoftwareListItem.tsx index 671cd0a32..8e271151f 100644 --- a/frontend/components/organisation/software/list/AdminSoftwareListItem.tsx +++ b/frontend/components/organisation/software/list/AdminSoftwareListItem.tsx @@ -1,15 +1,15 @@ -// SPDX-FileCopyrightText: 2023 Dusan Mijatovic (Netherlands eScience Center) -// SPDX-FileCopyrightText: 2023 Netherlands eScience Center +// SPDX-FileCopyrightText: 2023 - 2024 Dusan Mijatovic (Netherlands eScience Center) +// SPDX-FileCopyrightText: 2023 - 2024 Netherlands eScience Center // // SPDX-License-Identifier: Apache-2.0 import Link from 'next/link' import {SoftwareOfOrganisation} from '~/types/Organisation' -import {useSoftwareCardActions} from '../card/useSoftwareCardActions' -import SoftwareListItemContent from '~/components/software/overview/list/SoftwareListItemContent' import IconBtnMenuOnAction from '~/components/menu/IconBtnMenuOnAction' -import OverviewListItem from '~/components/software/overview/list/OverviewListItem' import StatusBanner from '~/components/cards/StatusBanner' +import SoftwareListItemContent from '~/components/software/overview/list/SoftwareListItemContent' +import OverviewListItem from '~/components/software/overview/list/OverviewListItem' +import {useSoftwareCardActions} from '~/components/organisation/software/card/useSoftwareCardActions' type AdminSoftwareListItem = { item: SoftwareOfOrganisation diff --git a/frontend/components/software/overview/SoftwareOverviewContent.tsx b/frontend/components/software/overview/SoftwareOverviewContent.tsx index 8449e6f96..f360be011 100644 --- a/frontend/components/software/overview/SoftwareOverviewContent.tsx +++ b/frontend/components/software/overview/SoftwareOverviewContent.tsx @@ -1,6 +1,6 @@ -// SPDX-FileCopyrightText: 2023 Dusan Mijatovic (Netherlands eScience Center) +// SPDX-FileCopyrightText: 2023 - 2024 Dusan Mijatovic (Netherlands eScience Center) +// SPDX-FileCopyrightText: 2023 - 2024 Netherlands eScience Center // SPDX-FileCopyrightText: 2023 Dusan Mijatovic (dv4all) -// SPDX-FileCopyrightText: 2023 Netherlands eScience Center // SPDX-FileCopyrightText: 2023 dv4all // // SPDX-License-Identifier: Apache-2.0 @@ -9,6 +9,7 @@ import Link from 'next/link' import {SoftwareOverviewItemProps} from '~/types/SoftwareTypes' import NoContent from '~/components/layout/NoContent' +import SourceRsd from '~/components/cards/SourceRsd' import {LayoutType} from './search/ViewToggleGroup' import SoftwareOverviewList from './list/SoftwareOverviewList' import SoftwareOverviewMasonry from './cards/SoftwareOverviewMasonry' @@ -17,6 +18,7 @@ import SoftwareGridCard from './cards/SoftwareGridCard' import SoftwareMasonryCard from './cards/SoftwareMasonryCard' import SoftwareListItemContent from './list/SoftwareListItemContent' import OverviewListItem from './list/OverviewListItem' +import {getItemKey, getPageUrl} from './useSoftwareOverviewProps' type SoftwareOverviewContentProps = { layout: LayoutType @@ -33,11 +35,14 @@ export default function SoftwareOverviewContent({layout, software}: SoftwareOver // Masonry layout (software only) return ( - {software.map((item) => ( -
- -
- ))} + {software.map((item) => { + const cardKey = getItemKey({id:item.id,domain:item.domain}) + return ( +
+ +
+ ) + })}
) } @@ -46,16 +51,30 @@ export default function SoftwareOverviewContent({layout, software}: SoftwareOver return ( {software.map(item => { + const listKey = getItemKey({id:item.id,domain:item.domain}) + const pageUrl = getPageUrl({domain:item.domain,slug:item.slug}) return ( - - + + + + + } + {...item} + /> ) @@ -67,9 +86,10 @@ export default function SoftwareOverviewContent({layout, software}: SoftwareOver // GRID as default return ( - {software.map((item) => ( - - ))} + {software.map((item) => { + const cardKey = getItemKey({id:item.id,domain:item.domain}) + return + })} ) } diff --git a/frontend/components/software/overview/cards/SoftwareCardContent.tsx b/frontend/components/software/overview/cards/SoftwareCardContent.tsx index ded6343aa..165e53956 100644 --- a/frontend/components/software/overview/cards/SoftwareCardContent.tsx +++ b/frontend/components/software/overview/cards/SoftwareCardContent.tsx @@ -1,19 +1,19 @@ -// SPDX-FileCopyrightText: 2023 Dusan Mijatovic (Netherlands eScience Center) -// SPDX-FileCopyrightText: 2023 Netherlands eScience Center +// SPDX-FileCopyrightText: 2023 - 2024 Dusan Mijatovic (Netherlands eScience Center) +// SPDX-FileCopyrightText: 2023 - 2024 Netherlands eScience Center // // SPDX-License-Identifier: Apache-2.0 -import {getImageUrl} from '~/utils/editImage' import KeywordList from '~/components/cards/KeywordList' import CardTitleSubtitle from '~/components/cards/CardTitleSubtitle' import ImageWithPlaceholder from '~/components/layout/ImageWithPlaceholder' import CardContentFrame from '~/components/cards/CardContentFrame' import CardImageFrame from '~/components/cards/CardImageFrame' +import SourceRsd from '~/components/cards/SourceRsd' import ProgrammingLanguageList from './ProgrammingLanguageList' import SoftwareMetrics from './SoftwareMetrics' +import {getImgUrl} from '../useSoftwareOverviewProps' type SoftwareCardContentProps = { - // slug:string brand_name: string short_statement: string image_id: string | null @@ -24,10 +24,12 @@ type SoftwareCardContentProps = { downloads?: number visibleKeywords?: number visibleProgLang?: number + domain?: string|null + source?: string|null } export default function SoftwareCardContent(item:SoftwareCardContentProps) { - + const imgUrl = getImgUrl({domain:item.domain,image_id:item.image_id}) return (
+ - {/* keywords */}
diff --git a/frontend/components/software/overview/cards/SoftwareMasonryCard.tsx b/frontend/components/software/overview/cards/SoftwareMasonryCard.tsx index e3189c117..92e42f7d6 100644 --- a/frontend/components/software/overview/cards/SoftwareMasonryCard.tsx +++ b/frontend/components/software/overview/cards/SoftwareMasonryCard.tsx @@ -1,36 +1,40 @@ -// SPDX-FileCopyrightText: 2023 Dusan Mijatovic (Netherlands eScience Center) +// SPDX-FileCopyrightText: 2023 - 2024 Dusan Mijatovic (Netherlands eScience Center) +// SPDX-FileCopyrightText: 2023 - 2024 Netherlands eScience Center // SPDX-FileCopyrightText: 2023 Dusan Mijatovic (dv4all) // SPDX-FileCopyrightText: 2023 Dusan Mijatovic (dv4all) (dv4all) -// SPDX-FileCopyrightText: 2023 Netherlands eScience Center // SPDX-FileCopyrightText: 2023 dv4all // // SPDX-License-Identifier: Apache-2.0 import Link from 'next/link' import {SoftwareOverviewItemProps} from '~/types/SoftwareTypes' -import {getImageUrl} from '~/utils/editImage' -import useValidateImageSrc from '~/utils/useValidateImageSrc' import KeywordList from '~/components/cards/KeywordList' import CardTitleSubtitle from '~/components/cards/CardTitleSubtitle' +import SourceRsd from '~/components/cards/SourceRsd' import ProgrammingLanguageList from './ProgrammingLanguageList' import SoftwareMetrics from './SoftwareMetrics' +import useSoftwareOverviewProps from '../useSoftwareOverviewProps' type SoftwareCardProps = { item: SoftwareOverviewItemProps } export default function SoftwareMasonryCard({item}:SoftwareCardProps){ - const imgSrc = getImageUrl(item.image_id ?? null) - const validImg = useValidateImageSrc(imgSrc) - - const visibleNumberOfKeywords: number = 3 - const visibleNumberOfProgLang: number = 3 + const { + imgUrl,pageUrl, + validImg,visibleNumberOfKeywords, + visibleNumberOfProgLang + } = useSoftwareOverviewProps({ + id: item.id, + domain:item.domain, + image_id: item.image_id, + slug: item.slug + }) return (
{/* Cover image, show only if valid image link */} @@ -38,9 +42,9 @@ export default function SoftwareMasonryCard({item}:SoftwareCardProps){ : {`Cover +
diff --git a/frontend/components/software/overview/useSoftwareOverviewProps.tsx b/frontend/components/software/overview/useSoftwareOverviewProps.tsx new file mode 100644 index 000000000..5cccfd497 --- /dev/null +++ b/frontend/components/software/overview/useSoftwareOverviewProps.tsx @@ -0,0 +1,57 @@ +// SPDX-FileCopyrightText: 2024 Dusan Mijatovic (Netherlands eScience Center) +// SPDX-FileCopyrightText: 2024 Netherlands eScience Center +// +// SPDX-License-Identifier: Apache-2.0 + +import {getImageUrl} from '~/utils/editImage' +import useValidateImageSrc from '~/utils/useValidateImageSrc' + +type useSoftwareOverviewLinksProps={ + id: string, + domain: string | null + image_id: string | null + slug: string | null +} + +export function getImgUrl({image_id,domain}:{image_id:string|null,domain?:string|null}){ + const imgSrc = getImageUrl(image_id ?? null) + if (domain && image_id){ + return `${domain}${imgSrc}` + } + return imgSrc +} + +export function getPageUrl({slug,domain}:{slug:string|null,domain?:string|null}){ + if (domain && domain?.endsWith('/')===true){ + return `${domain}software/${slug}` + } + if (domain && domain?.endsWith('/')===false){ + return `${domain}/software/${slug}` + } + return `/software/${slug}` +} + +export function getItemKey({id,domain}:{id:string,domain?:string|null}){ + if (domain) return `${domain}${id}` + return id +} + +export const visibleNumberOfKeywords: number = 3 +export const visibleNumberOfProgLang: number = 3 + + +export default function useSoftwareOverviewProps({id,domain,image_id,slug}:useSoftwareOverviewLinksProps) { + const imgUrl = getImgUrl({domain,image_id}) + const validImg = useValidateImageSrc(imgUrl) + const pageUrl = getPageUrl({domain,slug}) + const cardKey = getItemKey({id,domain}) + + return { + cardKey, + imgUrl, + pageUrl, + validImg, + visibleNumberOfKeywords, + visibleNumberOfProgLang + } +} diff --git a/frontend/types/SoftwareTypes.ts b/frontend/types/SoftwareTypes.ts index 8c27c2635..475728651 100644 --- a/frontend/types/SoftwareTypes.ts +++ b/frontend/types/SoftwareTypes.ts @@ -77,6 +77,8 @@ export type SoftwareItemFromDB = SoftwareTableItem & { export type SoftwareOverviewItemProps = { id:string + domain: string | null + source: string | null slug:string brand_name: string short_statement: string @@ -85,9 +87,9 @@ export type SoftwareOverviewItemProps = { mention_cnt: number | null is_published: boolean image_id: string | null - keywords: string[], - prog_lang: string[], - licenses: string, + keywords: string[] + prog_lang: string[] + licenses: string downloads?: number } diff --git a/frontend/utils/postgrestUrl.ts b/frontend/utils/postgrestUrl.ts index 42db00fe1..1171d5bee 100644 --- a/frontend/utils/postgrestUrl.ts +++ b/frontend/utils/postgrestUrl.ts @@ -308,12 +308,12 @@ export function softwareListUrl(props: PostgrestParams) { // check rpc in 105-project-views.sql for exact filtering query += `&search=${encodedSearch}` - const url = `${baseUrl}/rpc/software_search?${query}` + const url = `${baseUrl}/rpc/aggregated_software_search?${query}` // console.log('softwareListUrl...', url) return url } - const url = `${baseUrl}/rpc/software_overview?${query}` + const url = `${baseUrl}/rpc/aggregated_software_overview?${query}` // console.log('softwareListUrl...', url) return url }