npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

lighttalk_nodes

v1.0.4

Published

example

Downloads

24,218

Readme

lighttalk

라이트토크(주)에서 개발한 노드입니다.

해당 노드에서는 다음과 같은 기능을 지원합니다.

  • 라이트토크 기기의 mac 주소를 입력하면 주변의 이용가능한 기기와 노드가 연결됩니다. image

위의 사진의 칸에 MAC 주소값을 넣어 주시면 됩니다.

MAC 주소값을 얻는 방법은 다음과 같습니다.

image

클릭하면 다음 화면으로 넘어옵니다. 이 화면에서의 MAC 주소값 문자열을 노드 설정에 입력하시면 됩니다.

image

  • 입력으로 '{'startTime' : (시작 시간), 'endTime' : (끝나는 시간), 'outNo' : (제어하려고 하는 기기의 번호), 'value' : (1 또는 0) }' 와 같이 JSON 형태의 페이로드를 전달해 주면 startTime 부터 endTime 까지 기기를 value에 맞게 제어하는 스케쥴 하나를 형성합니다.
  • 출력으로는 현 기기들의 상태를 볼 수 있습니다.
  • 노드 설정에서 직접 스케쥴을 추가하실 수 있습니다.
  • 추가하신 스케쥴이 시작하고 끝날 때 이제 노드가 알림 메시지를 디버그 탭에 출력하게 되어, 기능을 눈 으로 확인하실 수 있습니다.

  • 쉽게 테스트해보실 수 있도록 처음에는 가상 MAC 주소 12345678 로 설정해주시면 됩니다. 제품이 없어도 테스트는 가능합니다. MQTT 서버 통신 특성상 다른 사람이 페이로드를 같은 서버에 보낼 수 있어 관련 부분은 추후 버전에서 개선될 예정입니다.

Node-RED 에서 실습해보실 수 있는 예제 코드입니다. 첫번째 코드는 Inject 노드를 통해 스케쥴과 원하는 제어 내용을 전달하는 내용입니다.

[
    {
        "id": "33a4af9d512f8b88",
        "type": "inject",
        "z": "b092e6dcb774259c",
        "name": "command (light off)",
        "props": [
            {
                "p": "payload"
            },
            {
                "p": "topic",
                "vt": "str"
            }
        ],
        "repeat": "",
        "crontab": "",
        "once": false,
        "onceDelay": 0.1,
        "topic": "",
        "payload": "{'startTime' : '2022-10-31 16:15', 'endTime' :'2022-10-31 16:16', 'outNo' : 2, 'value' : 1}",
        "payloadType": "str",
        "x": 203.2812042236328,
        "y": 428.97137451171875,
        "wires": [
            [
                "12345678"
            ]
        ]
    },
    {
        "id": "12345678",
        "type": "라이트토크",
        "z": "b092e6dcb774259c",
        "name": "라이트토크",
        "startTime": "",
        "endTime": "",
        "heat": false,
        "cool": false,
        "exha": false,
        "led": false,
        "x": 460.29290771484375,
        "y": 425.87894582748413,
        "wires": [
            [
                "60538344815ebbcf"
            ],
            [
                "d8bfeda96646b863"
            ],
            [
                "d235d30a10910cf7"
            ],
            [
                "6d82ed872131d9bc"
            ]
        ]
    },
    {
        "id": "60538344815ebbcf",
        "type": "ui_led",
        "z": "b092e6dcb774259c",
        "order": 0,
        "group": "e036ccde72136820",
        "width": 0,
        "height": 0,
        "label": "1",
        "labelPlacement": "left",
        "labelAlignment": "left",
        "colorForValue": [
            {
                "color": "#ff0000",
                "value": "0",
                "valueType": "num"
            },
            {
                "color": "#008000",
                "value": "1",
                "valueType": "num"
            }
        ],
        "allowColorForValueInMessage": false,
        "shape": "circle",
        "showGlow": true,
        "name": "",
        "x": 701.2840595245361,
        "y": 345.87072372436523,
        "wires": []
    },
    {
        "id": "d8bfeda96646b863",
        "type": "ui_led",
        "z": "b092e6dcb774259c",
        "order": 0,
        "group": "e036ccde72136820",
        "width": 0,
        "height": 0,
        "label": "2",
        "labelPlacement": "left",
        "labelAlignment": "left",
        "colorForValue": [
            {
                "color": "#ff0000",
                "value": "0",
                "valueType": "num"
            },
            {
                "color": "#008000",
                "value": "1",
                "valueType": "num"
            }
        ],
        "allowColorForValueInMessage": false,
        "shape": "circle",
        "showGlow": true,
        "name": "",
        "x": 708.0142288208008,
        "y": 386.00567626953125,
        "wires": []
    },
    {
        "id": "d235d30a10910cf7",
        "type": "ui_led",
        "z": "b092e6dcb774259c",
        "order": 0,
        "group": "e036ccde72136820",
        "width": 0,
        "height": 0,
        "label": "3",
        "labelPlacement": "left",
        "labelAlignment": "left",
        "colorForValue": [
            {
                "color": "#ff0000",
                "value": "0",
                "valueType": "num"
            },
            {
                "color": "#008000",
                "value": "1",
                "valueType": "num"
            }
        ],
        "allowColorForValueInMessage": false,
        "shape": "circle",
        "showGlow": true,
        "name": "",
        "x": 709.014217376709,
        "y": 432.00567626953125,
        "wires": []
    },
    {
        "id": "6d82ed872131d9bc",
        "type": "ui_led",
        "z": "b092e6dcb774259c",
        "order": 0,
        "group": "e036ccde72136820",
        "width": 0,
        "height": 0,
        "label": "4",
        "labelPlacement": "left",
        "labelAlignment": "left",
        "colorForValue": [
            {
                "color": "#ff0000",
                "value": "0",
                "valueType": "num"
            },
            {
                "color": "#008000",
                "value": "1",
                "valueType": "num"
            }
        ],
        "allowColorForValueInMessage": false,
        "shape": "circle",
        "showGlow": true,
        "name": "",
        "x": 698.014238357544,
        "y": 481.00563049316406,
        "wires": []
    },
    {
        "id": "e036ccde72136820",
        "type": "ui_group",
        "name": "Default",
        "tab": "52fedc0fc5facd8a",
        "order": 1,
        "disp": true,
        "width": "6",
        "collapse": false,
        "className": ""
    },
    {
        "id": "52fedc0fc5facd8a",
        "type": "ui_tab",
        "name": "Home",
        "icon": "dashboard",
        "disabled": false,
        "hidden": false
    }
]

두번째 예제코드는 Inject 노드를 통해 스케쥴을 전달하지 않고 노드 설정을 함으로써 스케쥴을 만들고 그에 맞게 동작하게 하는 예제입니다.

[
    {
        "id": "12345678",
        "type": "라이트토크",
        "z": "b092e6dcb774259c",
        "name": "라이트토크",
        "startTime": "2022-10-31T16:19",
        "endTime": "2022-10-31T16:20",
        "heat": true,
        "cool": false,
        "exha": true,
        "led": false,
        "x": 460.29290771484375,
        "y": 425.87894582748413,
        "wires": [
            [
                "60538344815ebbcf"
            ],
            [
                "d8bfeda96646b863"
            ],
            [
                "d235d30a10910cf7"
            ],
            [
                "6d82ed872131d9bc"
            ]
        ]
    },
    {
        "id": "60538344815ebbcf",
        "type": "ui_led",
        "z": "b092e6dcb774259c",
        "order": 0,
        "group": "e036ccde72136820",
        "width": 0,
        "height": 0,
        "label": "1",
        "labelPlacement": "left",
        "labelAlignment": "left",
        "colorForValue": [
            {
                "color": "#ff0000",
                "value": "0",
                "valueType": "num"
            },
            {
                "color": "#008000",
                "value": "1",
                "valueType": "num"
            }
        ],
        "allowColorForValueInMessage": false,
        "shape": "circle",
        "showGlow": true,
        "name": "",
        "x": 701.2840595245361,
        "y": 345.87072372436523,
        "wires": []
    },
    {
        "id": "d8bfeda96646b863",
        "type": "ui_led",
        "z": "b092e6dcb774259c",
        "order": 0,
        "group": "e036ccde72136820",
        "width": 0,
        "height": 0,
        "label": "2",
        "labelPlacement": "left",
        "labelAlignment": "left",
        "colorForValue": [
            {
                "color": "#ff0000",
                "value": "0",
                "valueType": "num"
            },
            {
                "color": "#008000",
                "value": "1",
                "valueType": "num"
            }
        ],
        "allowColorForValueInMessage": false,
        "shape": "circle",
        "showGlow": true,
        "name": "",
        "x": 708.0142288208008,
        "y": 386.00567626953125,
        "wires": []
    },
    {
        "id": "d235d30a10910cf7",
        "type": "ui_led",
        "z": "b092e6dcb774259c",
        "order": 0,
        "group": "e036ccde72136820",
        "width": 0,
        "height": 0,
        "label": "3",
        "labelPlacement": "left",
        "labelAlignment": "left",
        "colorForValue": [
            {
                "color": "#ff0000",
                "value": "0",
                "valueType": "num"
            },
            {
                "color": "#008000",
                "value": "1",
                "valueType": "num"
            }
        ],
        "allowColorForValueInMessage": false,
        "shape": "circle",
        "showGlow": true,
        "name": "",
        "x": 709.014217376709,
        "y": 432.00567626953125,
        "wires": []
    },
    {
        "id": "6d82ed872131d9bc",
        "type": "ui_led",
        "z": "b092e6dcb774259c",
        "order": 0,
        "group": "e036ccde72136820",
        "width": 0,
        "height": 0,
        "label": "4",
        "labelPlacement": "left",
        "labelAlignment": "left",
        "colorForValue": [
            {
                "color": "#ff0000",
                "value": "0",
                "valueType": "num"
            },
            {
                "color": "#008000",
                "value": "1",
                "valueType": "num"
            }
        ],
        "allowColorForValueInMessage": false,
        "shape": "circle",
        "showGlow": true,
        "name": "",
        "x": 698.014238357544,
        "y": 481.00563049316406,
        "wires": []
    },
    {
        "id": "e036ccde72136820",
        "type": "ui_group",
        "name": "Default",
        "tab": "52fedc0fc5facd8a",
        "order": 1,
        "disp": true,
        "width": "6",
        "collapse": false,
        "className": ""
    },
    {
        "id": "52fedc0fc5facd8a",
        "type": "ui_tab",
        "name": "Home",
        "icon": "dashboard",
        "disabled": false,
        "hidden": false
    }
]

License

김동일 http://i2r.link

개발자 : 이재진