2021-07-07 19:15:27 -05:00
import { NextSeo } from 'next-seo'
import { useRouter } from 'next/router'
2023-07-24 19:50:55 -05:00
import removeMd from 'remove-markdown'
2023-08-08 17:04:06 -04:00
import { numWithUnits } from '../lib/format'
2021-07-07 19:15:27 -05:00
2022-02-17 11:23:43 -06:00
export function SeoSearch ( { sub } ) {
2022-02-05 11:29:41 -06:00
const router = useRouter ( )
2022-02-17 11:23:43 -06:00
const subStr = sub ? ` ~ ${ sub } ` : ''
2022-05-18 16:09:44 -05:00
const title = ` ${ router . query . q || 'search' } \\ stacker news ${ subStr } `
const desc = ` SN ${ subStr } search: ${ router . query . q || '' } `
2022-02-05 11:29:41 -06:00
return (
< NextSeo
title = { title }
description = { desc }
openGraph = { {
2023-07-25 09:14:45 -05:00
title ,
2022-02-05 11:29:41 -06:00
description : desc ,
images : [
{
url : 'https://stacker.news/api/capture' + router . asPath
}
] ,
site _name : 'Stacker News'
} }
twitter = { {
site : '@stacker_news' ,
cardType : 'summary_large_image'
} }
/ >
)
}
2022-02-17 11:23:43 -06:00
// for a sub we need
// item seo
// index page seo
// recent page seo
export default function Seo ( { sub , item , user } ) {
2021-07-07 19:15:27 -05:00
const router = useRouter ( )
const pathNoQuery = router . asPath . split ( '?' ) [ 0 ]
const defaultTitle = pathNoQuery . slice ( 1 )
2022-02-17 11:23:43 -06:00
const snStr = ` stacker news ${ sub ? ` ~ ${ sub } ` : '' } `
2021-07-07 19:15:27 -05:00
let fullTitle = ` ${ defaultTitle && ` ${ defaultTitle } \\ ` } stacker news `
2021-08-17 13:15:24 -05:00
let desc = "It's like Hacker News but we pay you Bitcoin."
2021-07-07 19:15:27 -05:00
if ( item ) {
if ( item . title ) {
2022-02-17 11:23:43 -06:00
fullTitle = ` ${ item . title } \\ ${ snStr } `
2021-07-07 19:15:27 -05:00
} else if ( item . root ) {
2022-02-17 11:23:43 -06:00
fullTitle = ` reply on: ${ item . root . title } \\ ${ snStr } `
2021-07-07 19:15:27 -05:00
}
2022-02-17 11:23:43 -06:00
// at least for now subs (ie the only one is jobs) will always have text
2021-07-07 19:15:27 -05:00
if ( item . text ) {
2023-07-24 19:50:55 -05:00
desc = removeMd ( item . text )
2021-07-07 19:15:27 -05:00
if ( desc ) {
desc = desc . replace ( /\s+/g , ' ' )
}
} else {
2023-08-08 17:04:06 -04:00
desc = ` @ ${ item . user . name } stacked ${ numWithUnits ( item . sats ) } ${ item . url ? ` posting ${ item . url } ` : 'with this discussion' } `
2021-09-10 16:13:52 -05:00
}
if ( item . ncomments ) {
2023-08-08 16:31:43 -05:00
desc += ` [ ${ numWithUnits ( item . ncomments , { unitSingular : 'comment' , unitPlural : 'comments' } )} `
2021-09-10 16:13:52 -05:00
if ( item . boost ) {
desc += ` , ${ item . boost } boost `
}
desc += ']'
} else if ( item . boost ) {
desc += ` [ ${ item . boost } boost] `
2021-07-07 19:15:27 -05:00
}
}
if ( user ) {
2023-11-09 19:05:35 -06:00
desc = ` @ ${ user . name } has [ ${ user . optional . stacked ? ` ${ user . optional . stacked } stacked, ` : '' } ${ numWithUnits ( user . nitems , { unitSingular : 'item' , unitPlural : 'items' } )}] `
2021-07-07 19:15:27 -05:00
}
return (
< NextSeo
title = { fullTitle }
description = { desc }
openGraph = { {
title : fullTitle ,
description : desc ,
images : [
{
url : 'https://stacker.news/api/capture' + pathNoQuery
}
] ,
site _name : 'Stacker News'
} }
twitter = { {
site : '@stacker_news' ,
cardType : 'summary_large_image'
} }
/ >
)
}