Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Toxblh/samsung-tv-control
📺 Remote control your TV via JS!
https://github.com/Toxblh/samsung-tv-control
Last synced: 2 months ago
JSON representation
📺 Remote control your TV via JS!
- Host: GitHub
- URL: https://github.com/Toxblh/samsung-tv-control
- Owner: Toxblh
- License: mit
- Created: 2018-11-30T00:50:15.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-12-23T00:35:07.000Z (about 1 year ago)
- Last Synced: 2024-10-06T19:08:22.204Z (3 months ago)
- Language: TypeScript
- Homepage: https://toxblh.github.io/samsung-tv-control/
- Size: 1.67 MB
- Stars: 178
- Watchers: 6
- Forks: 35
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-smart-tv - samsung-tv-control - Library for remote control Samsung TV in your Node.js (Platforms / Samsung Tizen)
README
## 📺 Library for remote control Samsung TV in your NodeJS application.
_Tested with Samsung UE43NU7400 and UN55NU7100_
[![Build Status](https://travis-ci.org/Toxblh/samsung-tv-control.svg?branch=master)](https://travis-ci.org/Toxblh/samsung-tv-control)
[![codecov](https://codecov.io/gh/Toxblh/samsung-tv-control/branch/master/graph/badge.svg)](https://codecov.io/gh/Toxblh/samsung-tv-control)
[![Latest Stable Version](https://img.shields.io/npm/v/samsung-tv-control.svg)](https://www.npmjs.com/package/samsung-tv-control)
[![Downloads total](https://img.shields.io/npm/dt/samsung-tv-control.svg)](https://www.npmjs.com/package/samsung-tv-control)
[![Downloads month](https://img.shields.io/npm/dm/samsung-tv-control.svg)](https://www.npmjs.com/package/samsung-tv-control)
[![License](https://img.shields.io/github/license/Toxblh/samsung-tv-control)](https://www.npmjs.com/package/samsung-tv-control) [![Paypal Donate](https://img.shields.io/badge/paypal-donate-blue.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=WUAAG2HH58WE4) [![Patreon](https://img.shields.io/badge/patreon-support-blue.svg)](https://www.patreon.com/toxblh)## [📖 Documentation](https://toxblh.github.io/samsung-tv-control/)
## Installation
Requires Node v9 or above.
`npm install samsung-tv-control --save`
## NODE-RED
Also you can use the lib in your Node-RED https://github.com/Toxblh/node-red-contrib-samsung-tv-control
## Usage
You can try [example code](example/index.js)
```js
// import Samsung, { APPS, KEYS } from 'samsung-tv-control'
const { Samsung, KEYS, APPS } = require('samsung-tv-control')const config = {
debug: true, // Default: false
ip: '192.168.1.2',
mac: '123456789ABC',
nameApp: 'NodeJS-Test', // Default: NodeJS
port: 8001, // Default: 8002
token: '12345678',
}const control = new Samsung(config)
control.turnOn()
control
.isAvailable()
.then(() => {
// Get token for API
control.getToken((token) => {
console.info('# Response getToken:', token)
})// Send key to TV
control.sendKey(KEYS.KEY_HOME, function (err, res) {
if (err) {
throw new Error(err)
} else {
console.log(res)
}
})// Get all installed apps from TV
control.getAppsFromTV((err, res) => {
if (!err) {
console.log('# Response getAppsFromTV', res)
}
})// Get app icon by iconPath which you can get from getAppsFromTV
control.getAppIcon(
`/opt/share/webappservice/apps_icon/FirstScreen/${APPS.YouTube}/250x250.png`,
(err, res) => {
if (!err) {
console.log('# Response getAppIcon', res)
}
},
)// Open app by appId which you can get from getAppsFromTV
control.openApp(APPS.YouTube, (err, res) => {
if (!err) {
console.log('# Response openApp', res)
}
})// Control will keep connection for next messages in 1 minute
// If you would like to close it immediately, you can use `closeConnection()`
control.closeConnection()
})
.catch((e) => console.error(e))
```## Commands List
All commands you can find [here](src/keys.ts)
All popular apps you can find [here](src/apps.ts)