@5minds/node-red-dashboard-2-ui-webcam 1.3.0 → 7.6.0-develop-51b534-mjy5e42q
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +78 -77
- package/resources/ui-webcam.umd.js +1 -1
package/package.json
CHANGED
|
@@ -1,79 +1,80 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
"
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
"
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
"
|
|
56
|
-
|
|
57
|
-
"@rollup/rollup-darwin-x64": "^4.0.0",
|
|
58
|
-
"@rollup/rollup-linux-x64": "^4.0.0",
|
|
59
|
-
"@rollup/rollup-win32-x64": "^4.0.0"
|
|
60
|
-
},
|
|
61
|
-
"engines": {
|
|
62
|
-
"node": ">=14"
|
|
63
|
-
},
|
|
64
|
-
"node-red": {
|
|
65
|
-
"version": ">=3.0.0",
|
|
66
|
-
"nodes": {
|
|
67
|
-
"ui-webcam": "nodes/ui-webcam.js"
|
|
68
|
-
}
|
|
69
|
-
},
|
|
70
|
-
"node-red-dashboard-2": {
|
|
71
|
-
"version": "1.0.0",
|
|
72
|
-
"widgets": {
|
|
73
|
-
"ui-webcam": {
|
|
74
|
-
"output": "ui-webcam.umd.js",
|
|
75
|
-
"component": "UIWebcam"
|
|
76
|
-
}
|
|
77
|
-
}
|
|
2
|
+
"name": "@5minds/node-red-dashboard-2-ui-webcam",
|
|
3
|
+
"version": "7.6.0-develop-51b534-mjy5e42q",
|
|
4
|
+
"description": "The ui-webcam node for Node-RED Dashboard 2.0 enables users to integrate webcam functionality into Node-RED Dashboard 2.0. It allows users to capture images, select different cameras, and control webcam features through an intuitive user interface within the Node-RED Dashboard.",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"node-red",
|
|
7
|
+
"node-red-dashboard-2"
|
|
8
|
+
],
|
|
9
|
+
"repository": {
|
|
10
|
+
"type": "git",
|
|
11
|
+
"url": "https://github.com/5minds/ProcessCube.LowCode.git",
|
|
12
|
+
"directory": "packages/node-red-dashboard-2-ui-webcam"
|
|
13
|
+
},
|
|
14
|
+
"license": "Apache-2.0",
|
|
15
|
+
"author": "Sumit Shinde",
|
|
16
|
+
"contributors": [
|
|
17
|
+
"Joe Pavitt",
|
|
18
|
+
"Robin Lenz"
|
|
19
|
+
],
|
|
20
|
+
"exports": {
|
|
21
|
+
"import": "./resources/ui-webcam.esm.js",
|
|
22
|
+
"require": "./resources/ui-webcam.umd.js"
|
|
23
|
+
},
|
|
24
|
+
"files": [
|
|
25
|
+
"dist/*",
|
|
26
|
+
"nodes/*",
|
|
27
|
+
"ui/*",
|
|
28
|
+
"resources/*"
|
|
29
|
+
],
|
|
30
|
+
"dependencies": {
|
|
31
|
+
"vue": "^3.3.8",
|
|
32
|
+
"vuex": "^4.1.0"
|
|
33
|
+
},
|
|
34
|
+
"devDependencies": {
|
|
35
|
+
"@vitejs/plugin-vue": "^4.5.0",
|
|
36
|
+
"eslint": "^8.53.0",
|
|
37
|
+
"eslint-config-standard": "^17.1.0",
|
|
38
|
+
"eslint-plugin-import": "^2.29.0",
|
|
39
|
+
"eslint-plugin-n": "^16.3.1",
|
|
40
|
+
"eslint-plugin-vue": "^9.18.1",
|
|
41
|
+
"vite": "^5.0.12",
|
|
42
|
+
"vite-plugin-css-injected-by-js": "^3.3.0"
|
|
43
|
+
},
|
|
44
|
+
"optionalDependencies": {
|
|
45
|
+
"@rollup/rollup-darwin-arm64": "^4.0.0",
|
|
46
|
+
"@rollup/rollup-darwin-x64": "^4.0.0",
|
|
47
|
+
"@rollup/rollup-linux-x64": "^4.0.0",
|
|
48
|
+
"@rollup/rollup-win32-x64": "^4.0.0"
|
|
49
|
+
},
|
|
50
|
+
"engines": {
|
|
51
|
+
"node": ">=14"
|
|
52
|
+
},
|
|
53
|
+
"node-red": {
|
|
54
|
+
"version": ">=3.0.0",
|
|
55
|
+
"nodes": {
|
|
56
|
+
"ui-webcam": "nodes/ui-webcam.js"
|
|
78
57
|
}
|
|
79
|
-
}
|
|
58
|
+
},
|
|
59
|
+
"node-red-dashboard-2": {
|
|
60
|
+
"version": "1.0.0",
|
|
61
|
+
"widgets": {
|
|
62
|
+
"ui-webcam": {
|
|
63
|
+
"output": "ui-webcam.umd.js",
|
|
64
|
+
"component": "UIWebcam"
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
"scripts": {
|
|
69
|
+
"build": "vite build",
|
|
70
|
+
"build:dev": "NODE_ENV=development vite build",
|
|
71
|
+
"dev": "NODE_ENV=development vite build --watch",
|
|
72
|
+
"dev:prod": "vite build --watch",
|
|
73
|
+
"lint": "npm run lint:js && npm run lint:package",
|
|
74
|
+
"lint:fix": "npm run lint:js:fix && npm run lint:package:fix",
|
|
75
|
+
"lint:js": "eslint --ext .js,.vue,.cjs,.mjs .",
|
|
76
|
+
"lint:js:fix": "yarn lint:js --fix",
|
|
77
|
+
"lint:package": "sort-package-json --check 'package.json'",
|
|
78
|
+
"lint:package:fix": "sort-package-json 'package.json'"
|
|
79
|
+
}
|
|
80
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
(function(){"use strict";try{if(typeof document<"u"){var o=document.createElement("style");o.appendChild(document.createTextNode('.ui-webcam-wrapper[data-v-13bec4ab]{position:relative;border-radius:5px;box-shadow:#000000e6 0 2px 4px}.video-wrapper[data-v-13bec4ab]{background:#000;width:auto;height:100%;border-radius:5px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;-webkit-transform:scaleX(-1);transform:scaleX(-1)}.canvas[data-v-13bec4ab]{z-index:1;position:absolute;width:100%;height:100%}.button[data-v-13bec4ab]{position:absolute;margin-left:auto;width:35px;height:35px;display:flex;align-items:center;justify-content:center;z-index:2;right:auto;background:#fff;border:none;padding:10px;border-radius:50%;cursor:pointer;box-shadow:#0000001a 0 2px 4px}.dropdown ul li.group-label[data-v-13bec4ab]{padding:5px 10px;cursor:default;font-weight:700;color:#555;font-size:.75rem;display:flex;position:relative;white-space:nowrap;gap:12px;background-color:rgb(var(--v-theme-background))}.dropdown ul li.group-label[data-v-13bec4ab]:after{content:" ";display:block;height:2px;flex-grow:1;width:100%;margin-top:9px;background:rgb(var(--v-theme-group-outline))}.dropdown ul li.group-label[data-v-13bec4ab]:hover{background-color:#fff;padding:5px 10px;cursor:default;font-weight:700;color:#555}.icon .capture-button[data-v-13bec4ab]{width:30px;height:30px}.button[data-v-13bec4ab]:hover{background-color:rgb(var(--v-theme-primary))}.capture-button[data-v-13bec4ab]{margin-top:60%}.ellipsis[data-v-13bec4ab]{position:absolute;left:10px;top:10px;cursor:pointer;z-index:2;padding:5px;box-shadow:#0000001a 0 2px 4px}.ellipsis span[data-v-13bec4ab]{display:block;width:4px;height:4px;background-color:#fff;border-radius:50%;margin-bottom:3px}.dropdown[data-v-13bec4ab]{position:absolute;top:40px;right:10px;background-color:#fff;border:1px solid #ccc;border-radius:5px;z-index:2;display:none}.dropdown ul[data-v-13bec4ab]{list-style:none;padding:0;margin:0}.dropdown ul li[data-v-13bec4ab]{padding:5px 10px;cursor:pointer}.dropdown ul li[data-v-13bec4ab]:hover{background-color:rgb(var(--v-theme-primary));color:#fff}.dropdown.open[data-v-13bec4ab]{display:block}')),document.head.appendChild(o)}}catch(a){console.error("vite-plugin-css-injected-by-js",a)}})();
|
|
2
|
-
(function(m,g){typeof exports=="object"&&typeof module<"u"?g(exports,require("vuex"),require("vue")):typeof define=="function"&&define.amd?define(["exports","vuex","vue"],g):(m=typeof globalThis<"u"?globalThis:m||self,g(m["ui-webcam"]={},m.vuex,m.Vue))})(this,function(m,g,s){"use strict";const C="",c="",n=(A,e)=>{const o=A.__vccOpts||A;for(const[t,a]of e)o[t]=a;return o},B={name:"UIWebcam",inject:["$socket"],props:{id:{type:String,required:!0},props:{type:Object,default:()=>({})},state:{type:Object,default:()=>({enabled:!1,visible:!1})}},data(){return{imageData:null,cameraDevices:[],selectedDevice:null,cameraIsOn:!1,dropdownOpen:!1}},computed:{...g.mapState("data",["messages"]),value:{get(){var A;return(A=this.messages[this.id])==null?void 0:A.payload}}},mounted(){this.$socket.on("msg-input:"+this.id,async A=>{await this.init(A)}),this.$socket.emit("widget-load",this.id)},beforeUnmount(){var A,e;(A=this.$socket)==null||A.off("widget-load:"+this.id),(e=this.$socket)==null||e.off("msg-input:"+this.id),this.stopWebcam()},methods:{async init(A){this.msg=A,console.log(A.payload),A.payload==="start"?await this.startWebcam():A.payload==="capture"&&(await this.startWebcam(),await this.captureImage())},async startWebcam(){var A;if(!this.cameraIsOn)try{let e=[];for(await navigator.mediaDevices.getUserMedia({video:!0,audio:!1});e.length==0;)e=await navigator.mediaDevices.enumerateDevices(),console.log(JSON.stringify(e)),e=e.filter(t=>t.kind==="videoinput"&&t.label!=""),console.log(JSON.stringify(e)),await new Promise(t=>setTimeout(t,500));const o=e;o.length>0?(this.cameraDevices=o,this.selectedDevice=((A=o.find(t=>/back|rear|environment|rück/i.test(t.label)))==null?void 0:A.deviceId)??o[0].deviceId,await this.openCamera()):console.error("No video input devices found.")}catch(e){console.error("Error accessing media devices:",e)}},async openCamera(){if(this.selectedDevice==="off")this.stopWebcam(),this.cameraIsOn=!1;else{const A=this.$refs.video,e={video:{deviceId:this.selectedDevice}};try{const o=await navigator.mediaDevices.getUserMedia(e);A&&A instanceof HTMLVideoElement?(A.srcObject=o,A.play(),this.cameraIsOn=!0):console.error("Video element not found or not an instance of HTMLVideoElement.")}catch(o){console.error("Error accessing webcam:",o)}}},stopWebcam(){var e;const A=(e=this.$refs.video.srcObject)==null?void 0:e.getTracks();A&&A.forEach(o=>o.stop())},captureImage(){const A=this.$refs.video,e=this.$refs.canvas,o=e.getContext("2d");if(A&&A.readyState===A.HAVE_ENOUGH_DATA){const t=A.videoWidth,a=A.videoHeight;e.width=t,e.height=a,o.translate(t,0),o.scale(-1,1),o.drawImage(A,0,0,t,a),this.imageData=e.toDataURL("image/png"),this.send(this.imageData),setTimeout(()=>{o.clearRect(0,0,t,a)},500)}else console.error("Video element not ready or not found.")},send(A){const e=this.msg??{};e.payload=A,this.$socket.emit("widget-action",this.id,e)},async changeCamera(){this.stopWebcam(),await this.openCamera()},toggleDropdown(){this.dropdownOpen=!this.dropdownOpen},selectCamera(A){this.selectedDevice=A,this.toggleDropdown(),this.changeCamera()}}},r=A=>(s.pushScopeId("data-v-13bec4ab"),A=A(),s.popScopeId(),A),F={class:"ui-webcam-wrapper"},J={class:"video-wrapper"},U={ref:"video",width:"100%",height:"100%",style:{transform:"scaleX(-1)"},playsinline:"","webkit-playsinline":"",muted:""},w={ref:"canvas",class:"canvas"},K=[r(()=>s.createElementVNode("img",{class:"icon",src:c,height:"25px",width:"25px",alt:"Capture Image"},null,-1))],Q=[r(()=>s.createElementVNode("span",null,null,-1)),r(()=>s.createElementVNode("span",null,null,-1)),r(()=>s.createElementVNode("span",null,null,-1))],d=r(()=>s.createElementVNode("li",{class:"group-label"},"Select camera",-1)),W=["onClick"];function y(A,e,o,t,a,i){return s.openBlock(),s.createElementBlock("div",F,[s.createElementVNode("div",J,[s.createElementVNode("video",U,null,512),s.createElementVNode("canvas",w,null,512),a.cameraIsOn===!1?(s.openBlock(),s.createElementBlock("button",{key:0,class:"button power-button",onClick:e[1]||(e[1]=(...l)=>i.startWebcam&&i.startWebcam(...l))},[s.createElementVNode("img",{class:"icon",src:C,height:"30px",width:"30px",alt:"Capture Image",onClick:e[0]||(e[0]=(...l)=>i.startWebcam&&i.startWebcam(...l))})])):s.createCommentVNode("",!0),a.cameraIsOn?(s.openBlock(),s.createElementBlock("button",{key:1,class:"button capture-button",onClick:e[2]||(e[2]=(...l)=>i.captureImage&&i.captureImage(...l))},K)):s.createCommentVNode("",!0),a.cameraIsOn?(s.openBlock(),s.createElementBlock("div",{key:2,class:"ellipsis",onClick:e[3]||(e[3]=(...l)=>i.toggleDropdown&&i.toggleDropdown(...l))},Q)):s.createCommentVNode("",!0)]),a.cameraIsOn?(s.openBlock(),s.createElementBlock("div",{key:0,class:s.normalizeClass(["dropdown",{open:a.dropdownOpen}])},[s.createElementVNode("ul",null,[s.createElementVNode("li",{onClick:e[4]||(e[4]=l=>i.selectCamera("off"))},"Turn Camera Off"),d,(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(a.cameraDevices,l=>(s.openBlock(),s.createElementBlock("li",{key:l.deviceId,onClick:N=>i.selectCamera(l.deviceId)},s.toDisplayString(l.label),9,W))),128))])],2)):s.createCommentVNode("",!0)])}const k=n(B,[["render",y],["__scopeId","data-v-13bec4ab"]]);m.UIWebcam=k,Object.defineProperty(m,Symbol.toStringTag,{value:"Module"})});
|
|
2
|
+
(function(g,i){typeof exports=="object"&&typeof module<"u"?i(exports,require("vuex"),require("vue")):typeof define=="function"&&define.amd?define(["exports","vuex","vue"],i):(g=typeof globalThis<"u"?globalThis:g||self,i(g["ui-webcam"]={},g.vuex,g.Vue))})(this,function(g,i,s){"use strict";const r="",C="",n=(e,A)=>{const o=e.__vccOpts||e;for(const[t,a]of A)o[t]=a;return o},B={name:"UIWebcam",inject:["$socket"],props:{id:{type:String,required:!0},props:{type:Object,default:()=>({})},state:{type:Object,default:()=>({enabled:!1,visible:!1})}},data(){return{imageData:null,cameraDevices:[],selectedDevice:null,cameraIsOn:!1,dropdownOpen:!1}},computed:{...i.mapState("data",["messages"]),value:{get(){var e;return(e=this.messages[this.id])==null?void 0:e.payload}}},mounted(){this.$socket.on("msg-input:"+this.id,async e=>{await this.init(e)}),this.$socket.emit("widget-load",this.id)},beforeUnmount(){var e,A;(e=this.$socket)==null||e.off("widget-load:"+this.id),(A=this.$socket)==null||A.off("msg-input:"+this.id),this.stopWebcam()},methods:{async init(e){this.msg=e,console.log(e.payload),e.payload==="start"?await this.startWebcam():e.payload==="capture"&&(await this.startWebcam(),await this.captureImage())},async startWebcam(){var e;if(!this.cameraIsOn)try{let A=[];for(await navigator.mediaDevices.getUserMedia({video:!0,audio:!1});A.length==0;)A=await navigator.mediaDevices.enumerateDevices(),console.log(JSON.stringify(A)),A=A.filter(t=>t.kind==="videoinput"&&t.label!=""),console.log(JSON.stringify(A)),await new Promise(t=>setTimeout(t,500));const o=A;o.length>0?(this.cameraDevices=o,this.selectedDevice=((e=o.find(t=>/back|rear|environment|rück/i.test(t.label)))==null?void 0:e.deviceId)??o[0].deviceId,await this.openCamera()):console.error("No video input devices found.")}catch(A){console.error("Error accessing media devices:",A)}},async openCamera(){if(this.selectedDevice==="off")this.stopWebcam(),this.cameraIsOn=!1;else{const e=this.$refs.video,A={video:{deviceId:this.selectedDevice}};try{const o=await navigator.mediaDevices.getUserMedia(A);e&&e instanceof HTMLVideoElement?(e.srcObject=o,e.play(),this.cameraIsOn=!0):console.error("Video element not found or not an instance of HTMLVideoElement.")}catch(o){console.error("Error accessing webcam:",o)}}},stopWebcam(){var A;const e=(A=this.$refs.video.srcObject)==null?void 0:A.getTracks();e&&e.forEach(o=>o.stop())},captureImage(){const e=this.$refs.video,A=this.$refs.canvas,o=A.getContext("2d");if(e&&e.readyState===e.HAVE_ENOUGH_DATA){const t=e.videoWidth,a=e.videoHeight;A.width=t,A.height=a,o.translate(t,0),o.scale(-1,1),o.drawImage(e,0,0,t,a),this.imageData=A.toDataURL("image/png"),this.send(this.imageData),setTimeout(()=>{o.clearRect(0,0,t,a)},500)}else console.error("Video element not ready or not found.")},send(e){const A=this.msg??{};A.payload=e,this.$socket.emit("widget-action",this.id,A)},async changeCamera(){this.stopWebcam(),await this.openCamera()},toggleDropdown(){this.dropdownOpen=!this.dropdownOpen},selectCamera(e){this.selectedDevice=e,this.toggleDropdown(),this.changeCamera()}}},F={class:"ui-webcam-wrapper"},c={class:"video-wrapper"},J={ref:"video",width:"100%",height:"100%",style:{transform:"scaleX(-1)"},playsinline:"","webkit-playsinline":"",muted:""},U={ref:"canvas",class:"canvas"},w=["onClick"];function K(e,A,o,t,a,m){return s.openBlock(),s.createElementBlock("div",F,[s.createElementVNode("div",c,[s.createElementVNode("video",J,null,512),s.createElementVNode("canvas",U,null,512),a.cameraIsOn===!1?(s.openBlock(),s.createElementBlock("button",{key:0,class:"button power-button",onClick:A[1]||(A[1]=(...l)=>m.startWebcam&&m.startWebcam(...l))},[s.createElementVNode("img",{class:"icon",src:r,height:"30px",width:"30px",alt:"Capture Image",onClick:A[0]||(A[0]=(...l)=>m.startWebcam&&m.startWebcam(...l))})])):s.createCommentVNode("",!0),a.cameraIsOn?(s.openBlock(),s.createElementBlock("button",{key:1,class:"button capture-button",onClick:A[2]||(A[2]=(...l)=>m.captureImage&&m.captureImage(...l))},[...A[5]||(A[5]=[s.createElementVNode("img",{class:"icon",src:C,height:"25px",width:"25px",alt:"Capture Image"},null,-1)])])):s.createCommentVNode("",!0),a.cameraIsOn?(s.openBlock(),s.createElementBlock("div",{key:2,class:"ellipsis",onClick:A[3]||(A[3]=(...l)=>m.toggleDropdown&&m.toggleDropdown(...l))},[...A[6]||(A[6]=[s.createElementVNode("span",null,null,-1),s.createElementVNode("span",null,null,-1),s.createElementVNode("span",null,null,-1)])])):s.createCommentVNode("",!0)]),a.cameraIsOn?(s.openBlock(),s.createElementBlock("div",{key:0,class:s.normalizeClass(["dropdown",{open:a.dropdownOpen}])},[s.createElementVNode("ul",null,[s.createElementVNode("li",{onClick:A[4]||(A[4]=l=>m.selectCamera("off"))},"Turn Camera Off"),A[7]||(A[7]=s.createElementVNode("li",{class:"group-label"},"Select camera",-1)),(s.openBlock(!0),s.createElementBlock(s.Fragment,null,s.renderList(a.cameraDevices,l=>(s.openBlock(),s.createElementBlock("li",{key:l.deviceId,onClick:W=>m.selectCamera(l.deviceId)},s.toDisplayString(l.label),9,w))),128))])],2)):s.createCommentVNode("",!0)])}const Q=n(B,[["render",K],["__scopeId","data-v-13bec4ab"]]);g.UIWebcam=Q,Object.defineProperty(g,Symbol.toStringTag,{value:"Module"})});
|