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'