-
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit a6e0b61
Showing
15 changed files
with
1,054 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
node_modules | ||
dist |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
{ | ||
"parser": "@typescript-eslint/parser", | ||
"parserOptions": { | ||
"project": "tsconfig.json", | ||
"sourceType": "module" | ||
}, | ||
"plugins": ["@typescript-eslint/eslint-plugin"], | ||
"extends": [ | ||
"plugin:@typescript-eslint/eslint-recommended", | ||
"plugin:@typescript-eslint/recommended", | ||
"prettier", | ||
"prettier/@typescript-eslint" | ||
], | ||
"root": true, | ||
"env": { | ||
"node": true | ||
}, | ||
"rules": { | ||
"@typescript-eslint/interface-name-prefix": "off", | ||
"@typescript-eslint/explicit-function-return-type": "off", | ||
"@typescript-eslint/explicit-module-boundary-types": "off", | ||
"@typescript-eslint/no-explicit-any": "off" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
node_modules | ||
dist | ||
yarn.lock |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
assets | ||
node_modules | ||
src | ||
.eslintignore | ||
.eslintrc | ||
.gitignore | ||
.npmignore | ||
.prettierignore | ||
.prettierrc | ||
yarn.lock |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
node_modules | ||
dist |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
{ | ||
"tabWidth": 4, | ||
"useTabs": true, | ||
"bracketSpacing": true, | ||
"singleQuote": false, | ||
"endOfLine": "crlf", | ||
"trailingComma": "all", | ||
"semi": true | ||
} |
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,108 @@ | ||
[data:image/s3,"s3://crabby-images/b1a0e/b1a0e2914bb3379eee647ca50c6120352180a9e9" alt="stars"](https://github.com/barbarbar338/react-use-lanyard) | ||
[data:image/s3,"s3://crabby-images/3bd32/3bd32e10490d9ba35cc3d447d8cb7d1074db5135" alt="license"](https://github.com/barbarbar338/react-use-lanyard) | ||
[data:image/s3,"s3://crabby-images/361b8/361b80ba66b78862087751f5cd2710bd41ca5a4b" alt="supportServer"](https://discord.gg/BjEJFwh) | ||
[data:image/s3,"s3://crabby-images/049a7/049a7c4151d13d233f198ae74105e2bb9da4b821" alt="forks"](https://github.com/barbarbar338/react-use-lanyard) | ||
[data:image/s3,"s3://crabby-images/d2314/d23149b3020c0d056e988504364243c3bec957dd" alt="issues"](https://github.com/barbarbar338/react-use-lanyard) | ||
|
||
<p align="center"> | ||
<img src="https://raw.githubusercontent.com/barbarbar338/react-use-lanyard/main/assets/readme.png" alt="Logo" /> | ||
<h3 align="center">React Use Lanyard</h3> | ||
|
||
<p align="center"> | ||
Use Lanyard API easily in you React app! | ||
<br /> | ||
<a href="https://discord.gg/BjEJFwh"><strong>Get support Β»</strong></a> | ||
<br /> | ||
<br /> | ||
<a href="https://github.com/barbarbar338/react-use-lanyard/issues">Report Bug</a> | ||
Β· | ||
<a href="https://github.com/barbarbar338/react-use-lanyard/issues">Request Feature</a> | ||
Β· | ||
<a href="https://github.com/Phineas/lanyard">What Is Lanyard</a> | ||
</p> | ||
</p> | ||
|
||
# π¦ Installation | ||
|
||
- Using yarn: `yarn add react-use-lanyard` | ||
- Using npm: `npm i react-use-lanyard` | ||
|
||
# π€ Usage | ||
|
||
Using without websocket: | ||
|
||
```js | ||
import { useLanyard } from "react-use-lanyard"; | ||
|
||
function App() { | ||
const lanyard = useLanyard({ | ||
userId: "331846231514939392", | ||
}); | ||
|
||
return ( | ||
<pre>{!lanyard.isValidating && JSON.stringify(lanyard, null, 4)}</pre> | ||
); | ||
} | ||
|
||
export default App; | ||
``` | ||
|
||
Using with websocket: | ||
|
||
```js | ||
import { useEffect, useState } from "react"; | ||
import { useLanyard } from "react-use-lanyard"; | ||
|
||
function App() { | ||
const [state, setState] = useState(); | ||
const lanyard = useLanyard({ | ||
userId: "331846231514939392", | ||
socket: true, | ||
}); | ||
|
||
useEffect(() => { | ||
lanyard.addEventListener("message", ({ data }) => { | ||
const { d: status } = JSON.parse(data); | ||
setState(status); | ||
}); | ||
|
||
return () => lanyard.close(); | ||
}, []); | ||
|
||
return <pre>{JSON.stringify(state, null, 4)}</pre>; | ||
} | ||
|
||
export default App; | ||
``` | ||
|
||
# π License | ||
|
||
Copyright Β© 2021 [BarΔ±Ε DEMΔ°RCΔ°](https://github.com/barbarbar338). | ||
|
||
Distributed under the [GPL-3.0](https://www.gnu.org/licenses/gpl-3.0.html) License. See `LICENSE` for more information. | ||
|
||
# 𧦠Contributing | ||
|
||
Fell free to use GitHub's features. | ||
|
||
1. Fork the Project | ||
2. Create your Feature Branch (`git checkout -b feature/my-feature`) | ||
3. Run prettier and eslint (`npm run format && npm run lint`) | ||
4. Commit your Changes (`git commit -m 'my awesome feature my-feature'`) | ||
5. Push to the Branch (`git push origin feature/my-feature`) | ||
6. Open a Pull Request | ||
|
||
# π₯ Show your support | ||
|
||
Give a βοΈ if this project helped you! | ||
|
||
# π Contact | ||
|
||
- Mail: [email protected] | ||
- Discord: https://discord.gg/BjEJFwh | ||
- Instagram: https://www.instagram.com/ben_baris.d/ | ||
|
||
# β¨ Special Thanks | ||
|
||
- [Phineas](https://github.com/Phineas) - Creator of [Lanyard API](https://github.com/Phineas/lanyard) | ||
- [Eggsy](https://github.com/eggsy) - Creator of [vue-lanyard](https://www.npmjs.com/package/@eggsydev/vue-lanyard) |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
{ | ||
"name": "react-use-lanyard", | ||
"version": "0.0.3", | ||
"main": "dist", | ||
"typings": "dist", | ||
"repository": { | ||
"type": "git", | ||
"url": "https://github.com/barbarbar338/react-use-lanyard" | ||
}, | ||
"author": { | ||
"email": "[email protected]", | ||
"name": "BarΔ±Ε DEMΔ°RCΔ°", | ||
"url": "https://bariscodes.me/" | ||
}, | ||
"license": "GPL-3.0", | ||
"description": "π Use Lanyard API easily in you React app!", | ||
"scripts": { | ||
"prebuild": "rimraf dist", | ||
"build": "tsc", | ||
"format": "prettier --write .", | ||
"format:watch": "onchange . -- prettier --write {{changed}}", | ||
"lint": "eslint --fix .", | ||
"lint:watch": "onchange . -- eslint --fix {{changed}}" | ||
}, | ||
"devDependencies": { | ||
"@types/node": "^14.14.16", | ||
"@types/react": "^17.0.5", | ||
"@types/react-dom": "^17.0.3", | ||
"@typescript-eslint/eslint-plugin": "^4.11.1", | ||
"@typescript-eslint/parser": "^4.11.1", | ||
"eslint": "^7.16.0", | ||
"eslint-config-prettier": "^7.1.0", | ||
"eslint-plugin-import": "^2.22.1", | ||
"onchange": "^7.1.0", | ||
"prettier": "^2.2.1", | ||
"react": "^17.0.2", | ||
"react-dom": "^17.0.2", | ||
"ts-node": "^9.1.1", | ||
"typescript": "^4.1.3" | ||
}, | ||
"peerDependencies": { | ||
"react": ">=16" | ||
}, | ||
"dependencies": { | ||
"swr": "^0.5.6" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
export const API_URL = "https://api.lanyard.rest/v1"; | ||
export const WEBSOCKET_URL = "wss://api.lanyard.rest/socket"; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
export * from "./types"; | ||
export * from "./constants"; | ||
export * from "./lanyard"; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
import { API_URL, WEBSOCKET_URL } from "./constants"; | ||
import { LanyardOptions, LanyardResponse } from "./types"; | ||
import useSWR from "swr"; | ||
|
||
export const useLanyard = (options: LanyardOptions) => { | ||
const supportsWebSocket = "WebSocket" in window || "MozWebSocket" in window; | ||
if (options.socket && !supportsWebSocket) | ||
throw new Error("Browser doesn't support WebSocket connections."); | ||
|
||
if (options.socket) { | ||
const socket = new WebSocket(WEBSOCKET_URL); | ||
let key = "subscribe_to_id"; | ||
if (typeof options.userId === "object") key = "subscribe_to_ids"; | ||
|
||
socket.addEventListener("open", () => { | ||
socket.send( | ||
JSON.stringify({ | ||
op: 2, | ||
d: { | ||
[key]: options.userId, | ||
}, | ||
}), | ||
); | ||
|
||
setInterval(() => { | ||
socket.send( | ||
JSON.stringify({ | ||
op: 3, | ||
}), | ||
); | ||
}, 30000); | ||
}); | ||
|
||
return socket; | ||
} else { | ||
if (typeof options.userId === "string") { | ||
return useSWR<LanyardResponse>( | ||
`lanyard:${options.userId}`, | ||
async () => { | ||
const req = await fetch( | ||
`${API_URL}/users/${options.userId}`, | ||
); | ||
|
||
const body = (await req.json()) as LanyardResponse; | ||
if (body.error) throw new Error(body.error.message); | ||
|
||
return body; | ||
}, | ||
); | ||
} else { | ||
return useSWR<LanyardResponse[]>( | ||
`lanyard:${options.userId.join(":")}`, | ||
async () => { | ||
const responseArray = []; | ||
|
||
for (const id of options.userId) { | ||
const req = await fetch(`${API_URL}/users/${id}`); | ||
|
||
const body = (await req.json()) as LanyardResponse; | ||
if (body.error) throw new Error(body.error.message); | ||
|
||
responseArray.push(body); | ||
} | ||
|
||
return responseArray; | ||
}, | ||
); | ||
} | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
/** | ||
* Special thanks to @eggsy | ||
* https://github.com/eggsy/vue-lanyard/blob/main/%40types/lanyard.d.ts | ||
*/ | ||
|
||
export interface LanyardOptions { | ||
userId: string | string[]; | ||
socket?: boolean; | ||
} | ||
|
||
export interface LanyardResponse { | ||
success: boolean; | ||
data: LanyardData; | ||
error?: { | ||
message: string; | ||
code: string; | ||
}; | ||
} | ||
|
||
export interface LanyardData { | ||
spotify?: Spotify; | ||
listening_to_spotify: boolean; | ||
discord_user: Discorduser; | ||
discord_status: string; | ||
activities: Activity[]; | ||
active_on_discord_mobile: boolean; | ||
active_on_discord_desktop: boolean; | ||
} | ||
|
||
export interface Spotify { | ||
track_id: string; | ||
timestamps: Timestamps; | ||
song: string; | ||
artist: string; | ||
album_art_url: string; | ||
album: string; | ||
} | ||
|
||
export interface Timestamps { | ||
start: number; | ||
end: number; | ||
} | ||
|
||
export interface Activity { | ||
type: number; | ||
state: string; | ||
name: string; | ||
id: string; | ||
emoji?: Emoji; | ||
created_at: number; | ||
application_id?: string; | ||
timestamps?: Timestamps; | ||
session_id?: string; | ||
details?: string; | ||
buttons?: string[]; | ||
assets?: Assets; | ||
} | ||
|
||
export interface Assets { | ||
small_text: string; | ||
small_image: string; | ||
large_text: string; | ||
large_image: string; | ||
} | ||
|
||
export interface Timestamps { | ||
start: number; | ||
} | ||
|
||
export interface Emoji { | ||
name: string; | ||
} | ||
|
||
export interface Discorduser { | ||
username: string; | ||
public_flags: number; | ||
id: string; | ||
discriminator: string; | ||
avatar: string; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
{ | ||
"compilerOptions": { | ||
"module": "esnext", | ||
"lib": ["dom", "esnext"], | ||
"declaration": true, | ||
"sourceMap": true, | ||
"removeComments": false, | ||
"allowSyntheticDefaultImports": true, | ||
"target": "es6", | ||
"outDir": "./dist", | ||
"baseUrl": "./", | ||
"incremental": true, | ||
"moduleResolution": "node", | ||
"esModuleInterop": true, | ||
"strict": true, | ||
"jsx": "react", | ||
"forceConsistentCasingInFileNames": true | ||
}, | ||
"exclude": ["node_modules", "dist"] | ||
} |