diff --git a/README.md b/README.md index b380503..cb7dcc9 100644 --- a/README.md +++ b/README.md @@ -29,6 +29,7 @@ Social media share buttons for your next React.js, Next.js apps. - Refind - Skype - Telegram + - Threads - Trello - Tumblr - Twitter @@ -512,6 +513,28 @@ import { TrelloShareBtn } from 'dv-social-share' --- +## ThreadsShare + +#### 👨‍💻 Code + + +```js copy +import { ThreadsShareBtn } from 'dv-social-share' + + +``` + +#### 📖 ThreadsShareBtn Props + +| Props | Type | Default | Description | Required | +| :----------- | :------ | :------ | :---------------------------------------------------------------------------------------------------------------------------- | :------- | +| url | string | | The URL of the to be page. | ✅ | +| title | string | | Description of the shared page. | ❌ | +| openInNewTab | boolean | false | Open share window in a new tab if set to `true`. | ❌ | +| imgConfig | object | | A imgConfig contains width (number; e.g. 32/64), height (number; e.g. 32/64) & bgColor (string; e.g. '#FF0000') for the Image | ❌ | + +--- + ## TumblrShare #### 👨‍💻 Code diff --git a/package-lock.json b/package-lock.json index 819059f..22bbb7b 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "dv-social-share", - "version": "0.0.5", + "version": "0.1.88", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "dv-social-share", - "version": "0.0.5", + "version": "0.1.88", "license": "MIT", "devDependencies": { "@babel/core": "^7.23.0", @@ -41,7 +41,7 @@ "npm": ">=6" }, "peerDependencies": { - "react": ">=17.0.2" + "react": ">=16.0.0" } }, "node_modules/@aashutoshrathi/word-wrap": { diff --git a/package.json b/package.json index ee1bfed..cac99ea 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "dv-social-share", - "version": "0.0.6-1", + "version": "0.0.7", "description": "Social media share buttons for your next apps like React, Next.js in TypeScript.", "author": "Dhaval Vira (https://github.com/dhavalveera)", "license": "MIT", diff --git a/rollup.config.mjs b/rollup.config.mjs index 7c7ad95..3571fd0 100644 --- a/rollup.config.mjs +++ b/rollup.config.mjs @@ -19,7 +19,7 @@ export default { }, ], // external: builtins, - external: ['react'], + external: ['react', 'react-dom'], plugins: [ resolve(), babel({ @@ -35,7 +35,7 @@ export default { // }), // nodeResolve(), commonjs({ - extensions: ['.js', '.ts', '.tsx'], + extensions: ['.js', '.jsx', '.ts', '.tsx'], }), terser(), ], diff --git a/src/Buttons/ThreadsShare/index.ts b/src/Buttons/ThreadsShare/index.ts new file mode 100644 index 0000000..7179f1b --- /dev/null +++ b/src/Buttons/ThreadsShare/index.ts @@ -0,0 +1,35 @@ +// UTILS +import { generateQueryParams } from '../../utils' + +// Make Share Button => Contains Main Logic +import MakeShareButton from '../../ShareButton' + +// Icon +import { ThreadsShareIcon } from '../../Icons' + +// CONSTANTS +import { defaultImgConfig, dontOpenShareDialogOnClick, THREADS_NAME } from '../../constants' + +type GenerateThreadsLinkType = { title?: string; separator?: string } + +type ThreadsShareBtnTypes = { + url: string + title?: string + separator?: string + openInNewTab?: boolean + imgConfig?: { + width?: number + height?: number + bgColor?: string + } +} + +const generateThreadsLink = (url: string, { title, separator = ' :: ' }: GenerateThreadsLinkType) => { + return `https://www.threads.net/intent/post${generateQueryParams({ text: title ? title + separator + url : url })}` +} + +const ThreadsShareBtn = ({ url, title, separator, openInNewTab, imgConfig }: ThreadsShareBtnTypes) => { + return MakeShareButton(THREADS_NAME, generateThreadsLink(url, { title, separator }), ThreadsShareIcon, openInNewTab || dontOpenShareDialogOnClick, imgConfig || defaultImgConfig) +} + +export default ThreadsShareBtn diff --git a/src/Buttons/WhatsAppShare/index.ts b/src/Buttons/WhatsAppShare/index.ts index 82bd734..9285134 100644 --- a/src/Buttons/WhatsAppShare/index.ts +++ b/src/Buttons/WhatsAppShare/index.ts @@ -1,5 +1,5 @@ // Utils -import { generateQueryParams, isMobileOrTablet } from '../../utils' +import { generateQueryParams } from '../../utils' // Make Share Button => Contains Main logic import MakeShareButton from '../../ShareButton' @@ -25,7 +25,7 @@ type WhatsAppShareBtnTypes = { } const generateWhatsAppLink = (url: string, { title, separator = ' :: ' }: GenerateWhatsAppLinkTypes) => { - return `https://${isMobileOrTablet() ? 'api' : 'web'}.whatsapp.com/send${generateQueryParams({ text: title ? title + separator + url : url })}` + return `https://api.whatsapp.com/send${generateQueryParams({ text: title ? title + separator + url : url })}` } const WhatsAppShareBtn = ({ url, title, separator, openInNewTab, imgConfig }: WhatsAppShareBtnTypes) => { diff --git a/src/Icons/ThreadsShareIcon/index.ts b/src/Icons/ThreadsShareIcon/index.ts new file mode 100644 index 0000000..5193198 --- /dev/null +++ b/src/Icons/ThreadsShareIcon/index.ts @@ -0,0 +1,3 @@ +const ThreadsShareIcon: string = '' + +export default ThreadsShareIcon \ No newline at end of file diff --git a/src/Icons/index.ts b/src/Icons/index.ts index 46a82a4..f369c9a 100644 --- a/src/Icons/index.ts +++ b/src/Icons/index.ts @@ -17,6 +17,7 @@ export { default as RedditShareIcon } from './RedditShareIcon' export { default as RefindShareIcon } from './RefindShareIcon' export { default as SkypeShareIcon } from './SkypeShare' export { default as TelegramShareIcon } from './TelegramShareIcon' +export { default as ThreadsShareIcon } from './ThreadsShareIcon' export { default as TrelloShareIcon } from './TrelloShareIcon' export { default as TumblrShareIcon } from './TumblrShareIcon' export { default as TwitterShareIcon } from './TwitterShareIcon' diff --git a/src/ShareButton/index.ts b/src/ShareButton/index.ts index 6864d18..074d404 100644 --- a/src/ShareButton/index.ts +++ b/src/ShareButton/index.ts @@ -21,8 +21,6 @@ const MakeShareButton = (name: string, url: string, Icon: string, openShareDialo CustomWindow(url, windowConfig, openShareDialogOnClick) } - console.log({ name, url, Icon, imgConfig }) - return createElement( 'button', { type: 'button', 'aria-label': `${name}-Share`, title: name, onClick: handleOnClick, className: ShareBtnCss }, diff --git a/src/constants/ButtonNames/index.ts b/src/constants/ButtonNames/index.ts index c523629..0e93857 100644 --- a/src/constants/ButtonNames/index.ts +++ b/src/constants/ButtonNames/index.ts @@ -17,6 +17,7 @@ export const REDDIT_NAME: string = 'Reddit' export const REFIND_NAME: string = 'Refind' export const SKYPE_NAME: string = 'Skype' export const TELEGRAM_NAME: string = 'Telegram' +export const THREADS_NAME:string = 'Threads' export const TRELLO_NAME: string = 'Trello' export const TUMBLR_NAME: string = 'Tumblr' export const TWITTER_NAME: string = 'Twitter' diff --git a/src/index.ts b/src/index.ts index f839278..08d92ef 100644 --- a/src/index.ts +++ b/src/index.ts @@ -17,6 +17,7 @@ export { default as RedditShareBtn } from './Buttons/RedditShare' export { default as RefindShareBtn } from './Buttons/RefindShare' export { default as SkypeShareBtn } from './Buttons/SkypeShare' export { default as TelegramShareBtn } from './Buttons/TelegramShare' +export { default as ThreadsShareBtn } from './Buttons/ThreadsShare' export { default as TrelloShareBtn } from './Buttons/TrelloShare' export { default as TumblrShareBtn } from './Buttons/TumblrShare' export { default as TwitterShareBtn } from './Buttons/TwitterShare'