70 lines
2.0 KiB
JavaScript
Raw Normal View History

2023-07-24 13:35:05 -05:00
import Dropdown from 'react-bootstrap/Dropdown'
2022-12-19 16:27:52 -06:00
import ShareIcon from '../svgs/share-fill.svg'
import copy from 'clipboard-copy'
import { useMe } from './me'
export default function Share ({ item }) {
const me = useMe()
const url = `https://stacker.news/items/${item.id}${me ? `/r/${me.name}` : ''}`
return typeof window !== 'undefined' && navigator?.share
? (
2023-07-24 13:35:05 -05:00
<div className='ms-auto pointer d-flex align-items-center'>
2022-12-19 16:27:52 -06:00
<ShareIcon
2023-05-01 15:58:30 -05:00
width={20} height={20}
2022-12-19 17:37:31 -06:00
className='mx-2 fill-grey theme'
2022-12-19 16:27:52 -06:00
onClick={() => {
if (navigator.share) {
navigator.share({
title: item.title || '',
text: '',
url
}).then(() => console.log('Successful share'))
.catch((error) => console.log('Error sharing', error))
} else {
console.log('no navigator.share')
}
}}
/>
</div>)
: (
2023-07-24 13:35:05 -05:00
<Dropdown align='end' className='ms-auto pointer d-flex align-items-center' as='span'>
2022-12-19 16:27:52 -06:00
<Dropdown.Toggle variant='success' id='dropdown-basic' as='a'>
2023-05-01 15:58:30 -05:00
<ShareIcon width={20} height={20} className='mx-2 fill-grey theme' />
2022-12-19 16:27:52 -06:00
</Dropdown.Toggle>
<Dropdown.Menu>
<Dropdown.Item
onClick={async () => {
copy(url)
}}
>
copy link
</Dropdown.Item>
</Dropdown.Menu>
</Dropdown>)
}
export function CopyLinkDropdownItem ({ item }) {
const me = useMe()
const url = `https://stacker.news/items/${item.id}${me ? `/r/${me.name}` : ''}`
return (
<Dropdown.Item
onClick={async () => {
if (navigator.share) {
navigator.share({
title: item.title || '',
text: '',
url
}).then(() => console.log('Successful share'))
.catch((error) => console.log('Error sharing', error))
} else {
copy(url)
}
}}
>
copy link
</Dropdown.Item>
)
}