Show images from a template

im trying to display all images from a src but my template just display the last one, my template:

<img width="30" height="30" src= "{{msg.payload._value}}" alt='Image not found'  />

image

My debug show this:

Can someone help me ?

Possibly you have the "Reload last value on refresh" checked in ui_template node settings ?
Uncheck it and try again .. you may need to restart Node-red server to clear any cached values.

image

Test flow :

[{"id":"2cdd0d87130cd5c5","type":"inject","z":"54efb553244c241f","name":"image1","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"{\"_value\":\"data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==\"}","payloadType":"json","x":370,"y":1180,"wires":[["3a1854cd2e61fb33"]]},{"id":"3a1854cd2e61fb33","type":"ui_template","z":"54efb553244c241f","group":"780cfd9c93f7b572","name":"","order":0,"width":"5","height":"5","format":"<style>\n    .myImage {\n        height: 100px;\n        width: 100px;\n    }\n</style>\n\n<img class=\"myImage\" src=\"{{msg.payload._value}}\" alt='Image not found'  />","storeOutMessages":true,"fwdInMessages":true,"resendOnRefresh":false,"templateScope":"local","className":"","x":560,"y":1220,"wires":[[]]},{"id":"a7015d0ff437872d","type":"inject","z":"54efb553244c241f","name":"image2","props":[{"p":"payload._value","v":"","vt":"str"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","x":370,"y":1260,"wires":[["3a1854cd2e61fb33"]]},{"id":"780cfd9c93f7b572","type":"ui_group","name":"Test","tab":"0baea998ce75eabd","order":1,"disp":true,"width":"12","collapse":false,"className":""},{"id":"0baea998ce75eabd","type":"ui_tab","name":"Test Group","icon":"","disabled":false,"hidden":false}]

it did not work

well that's not very informative :wink:

can you explain to us what doesnt work and export/share a demo flow explaining in some more detail the problem ? sometimes its little difficult to understand with just screenshots

I simply i need to upload several photos to my database and then I want to go get them and show them on the dashboard

I'm an guessing this is related to your other thread: Node-red payload

If so, then I recommend you filter out the entries that are not images then send the array of data to a template node & use angularjs ngRepeat directive to build html & IMG tags with the IMG SRC set to the ._value field.

If you had stated your intention on the original thread you would have got this answer sooner.

Ok, but my data comes from influxdb in the same _value variable how I do that?

why this is not correct ?

this is the output of the function:

image

Here is a demo flow of how you can filter your array into data that have a _field description and to images

[{"id":"3487880915b921a8","type":"inject","z":"54efb553244c241f","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"","payloadType":"date","x":200,"y":1620,"wires":[["319f290522a46ad1"]]},{"id":"319f290522a46ad1","type":"template","z":"54efb553244c241f","name":"db data","field":"payload","fieldType":"msg","format":"json","syntax":"plain","template":"[\n    {\n        \"result\": \"last\",\n        \"table\": 0,\n        \"_start\": \"2022-06-05T13:44:43.9949941Z\",\n        \"_stop\": \"2022-06-05T14:44:43.9949941Z\",\n        \"_time\": \"2022-06-05T14:41:03.77Z\",\n        \"_value\": \"1\",\n        \"_field\": \"description\",\n        \"_measurement\": \"info\"\n    },\n    {\n        \"result\": \"last\",\n        \"table\": 0,\n        \"_start\": \"2022-06-05T13:44:43.9949941Z\",\n        \"_stop\": \"2022-06-05T14:44:43.9949941Z\",\n        \"_time\": \"2022-06-05T14:44:24.019Z\",\n        \"_value\": \"hi\",\n        \"_field\": \"description\",\n        \"_measurement\": \"info\"\n    },\n    {\n        \"result\": \"last\",\n        \"table\": 1,\n        \"_start\": \"2022-06-05T13:44:43.9949941Z\",\n        \"_stop\": \"2022-06-05T14:44:43.9949941Z\",\n        \"_time\": \"2022-06-05T14:41:03.77Z\",\n        \"_value\": \"...\",\n        \"_field\": \"image\",\n        \"_measurement\": \"info\"\n    },\n    {\n        \"result\": \"last\",\n        \"table\": 1,\n        \"_start\": \"2022-06-05T13:44:43.9949941Z\",\n        \"_stop\": \"2022-06-05T14:44:43.9949941Z\",\n        \"_time\": \"2022-06-05T14:44:24.019Z\",\n        \"_value\": \"...\",\n        \"_field\": \"image\",\n        \"_measurement\": \"info\"\n    }\n]","output":"json","x":360,"y":1620,"wires":[["5104f607df7f69f1"]]},{"id":"71c8d592186e0111","type":"switch","z":"54efb553244c241f","name":"","property":"payload._field","propertyType":"msg","rules":[{"t":"eq","v":"image","vt":"str"},{"t":"eq","v":"description","vt":"str"}],"checkall":"true","repair":true,"outputs":2,"x":690,"y":1620,"wires":[["c0c7998aa6e82305"],["9b8a9ab432b8139e"]]},{"id":"7238847bd9f0e0c4","type":"debug","z":"54efb553244c241f","name":"debug 1","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","targetType":"msg","statusVal":"","statusType":"auto","x":1020,"y":1560,"wires":[]},{"id":"5104f607df7f69f1","type":"split","z":"54efb553244c241f","name":"","splt":"\\n","spltType":"str","arraySplt":1,"arraySpltType":"len","stream":false,"addname":"","x":530,"y":1620,"wires":[["71c8d592186e0111"]]},{"id":"c0c7998aa6e82305","type":"join","z":"54efb553244c241f","name":"","mode":"auto","build":"object","property":"payload","propertyType":"msg","key":"topic","joiner":"\\n","joinerType":"str","accumulate":true,"timeout":"","count":"","reduceRight":false,"reduceExp":"","reduceInit":"","reduceInitType":"","reduceFixup":"","x":870,"y":1560,"wires":[["7238847bd9f0e0c4"]]},{"id":"eb1f63617eb61be2","type":"debug","z":"54efb553244c241f","name":"debug 2","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","targetType":"msg","statusVal":"","statusType":"auto","x":1020,"y":1660,"wires":[]},{"id":"9b8a9ab432b8139e","type":"join","z":"54efb553244c241f","name":"","mode":"auto","build":"object","property":"payload","propertyType":"msg","key":"topic","joiner":"\\n","joinerType":"str","accumulate":true,"timeout":"","count":"","reduceRight":false,"reduceExp":"","reduceInit":"","reduceInitType":"","reduceFixup":"","x":870,"y":1660,"wires":[["eb1f63617eb61be2"]]},{"id":"bcd4722ae550b040","type":"comment","z":"54efb553244c241f","name":"fliter data array","info":"","x":700,"y":1540,"wires":[]},{"id":"1d3eeaf7aaf5455c","type":"comment","z":"54efb553244c241f","name":"images","info":"","x":1010,"y":1500,"wires":[]},{"id":"fed09a2ded571e42","type":"comment","z":"54efb553244c241f","name":"descriptions","info":"","x":1030,"y":1720,"wires":[]}]

ps. i had to read a bit from your other Forum threads. It would be better if you continued the conversation in one place so people that already tried to help can do so.

Ok, thank you but know i have a template and when i try display all _values he just display the last one.

yes you mentioned that .. one step at a time :wink:
now that you have the data filtered you can try Steve's suggestion and use

The node-red Dashboard is based on the Angular front-end library and it has some useful directives to loop through the data.

For Example :

<div ng-repeat="x in msg.payload">
    <img class="myImage" src="{{x._value}}" alt='Image not found' />
</div>

Modified Flow:

[{"id":"3487880915b921a8","type":"inject","z":"54efb553244c241f","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"","payloadType":"date","x":200,"y":1620,"wires":[["319f290522a46ad1"]]},{"id":"319f290522a46ad1","type":"template","z":"54efb553244c241f","name":"db data","field":"payload","fieldType":"msg","format":"json","syntax":"plain","template":"[\n    {\n        \"result\": \"last\",\n        \"table\": 0,\n        \"_start\": \"2022-06-05T13:44:43.9949941Z\",\n        \"_stop\": \"2022-06-05T14:44:43.9949941Z\",\n        \"_time\": \"2022-06-05T14:41:03.77Z\",\n        \"_value\": \"1\",\n        \"_field\": \"description\",\n        \"_measurement\": \"info\"\n    },\n    {\n        \"result\": \"last\",\n        \"table\": 0,\n        \"_start\": \"2022-06-05T13:44:43.9949941Z\",\n        \"_stop\": \"2022-06-05T14:44:43.9949941Z\",\n        \"_time\": \"2022-06-05T14:44:24.019Z\",\n        \"_value\": \"hi\",\n        \"_field\": \"description\",\n        \"_measurement\": \"info\"\n    },\n    {\n        \"result\": \"last\",\n        \"table\": 1,\n        \"_start\": \"2022-06-05T13:44:43.9949941Z\",\n        \"_stop\": \"2022-06-05T14:44:43.9949941Z\",\n        \"_time\": \"2022-06-05T14:41:03.77Z\",\n        \"_value\": \"\",\n        \"_field\": \"image\",\n        \"_measurement\": \"info\"\n    },\n    {\n        \"result\": \"last\",\n        \"table\": 1,\n        \"_start\": \"2022-06-05T13:44:43.9949941Z\",\n        \"_stop\": \"2022-06-05T14:44:43.9949941Z\",\n        \"_time\": \"2022-06-05T14:44:24.019Z\",\n        \"_value\": \"\",\n        \"_field\": \"image\",\n        \"_measurement\": \"info\"\n    }\n]","output":"json","x":360,"y":1620,"wires":[["5104f607df7f69f1"]]},{"id":"71c8d592186e0111","type":"switch","z":"54efb553244c241f","name":"","property":"payload._field","propertyType":"msg","rules":[{"t":"eq","v":"image","vt":"str"},{"t":"eq","v":"description","vt":"str"}],"checkall":"true","repair":true,"outputs":2,"x":690,"y":1620,"wires":[["c0c7998aa6e82305"],["9b8a9ab432b8139e"]]},{"id":"7238847bd9f0e0c4","type":"debug","z":"54efb553244c241f","name":"debug 1","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","targetType":"msg","statusVal":"","statusType":"auto","x":960,"y":1540,"wires":[]},{"id":"5104f607df7f69f1","type":"split","z":"54efb553244c241f","name":"","splt":"\\n","spltType":"str","arraySplt":1,"arraySpltType":"len","stream":false,"addname":"","x":530,"y":1620,"wires":[["71c8d592186e0111"]]},{"id":"c0c7998aa6e82305","type":"join","z":"54efb553244c241f","name":"","mode":"auto","build":"object","property":"payload","propertyType":"msg","key":"topic","joiner":"\\n","joinerType":"str","accumulate":true,"timeout":"","count":"","reduceRight":false,"reduceExp":"","reduceInit":"","reduceInitType":"","reduceFixup":"","x":870,"y":1600,"wires":[["7238847bd9f0e0c4","5a467869265fcb5b"]]},{"id":"eb1f63617eb61be2","type":"debug","z":"54efb553244c241f","name":"debug 2","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","targetType":"msg","statusVal":"","statusType":"auto","x":980,"y":1720,"wires":[]},{"id":"9b8a9ab432b8139e","type":"join","z":"54efb553244c241f","name":"","mode":"auto","build":"object","property":"payload","propertyType":"msg","key":"topic","joiner":"\\n","joinerType":"str","accumulate":true,"timeout":"","count":"","reduceRight":false,"reduceExp":"","reduceInit":"","reduceInitType":"","reduceFixup":"","x":870,"y":1660,"wires":[["eb1f63617eb61be2"]]},{"id":"bcd4722ae550b040","type":"comment","z":"54efb553244c241f","name":"fliter array","info":"","x":700,"y":1560,"wires":[]},{"id":"5a467869265fcb5b","type":"ui_template","z":"54efb553244c241f","group":"780cfd9c93f7b572","name":"","order":0,"width":"5","height":"5","format":"<style>\n    .myImage {\n        height: 30px;\n        width: 30px;\n        padding: 10px;\n    }\n</style>\n\n<!-- <img class=\"myImage\" ng-repeat=\"x in msg.payload\" ng-src=\"{{x._value}}\" alt='Image not found' /> -->\n\n\n<div ng-repeat=\"x in msg.payload\">\n    <img class=\"myImage\" src=\"{{x._value}}\" alt='Image not found' />\n</div>","storeOutMessages":true,"fwdInMessages":true,"resendOnRefresh":false,"templateScope":"local","className":"","x":1060,"y":1600,"wires":[[]]},{"id":"780cfd9c93f7b572","type":"ui_group","name":"Test","tab":"0baea998ce75eabd","order":1,"disp":true,"width":"12","collapse":false,"className":""},{"id":"0baea998ce75eabd","type":"ui_tab","name":"Test Group","icon":"","disabled":false,"hidden":false}]
1 Like

thank you, i put you template in my project and he display this:

and if i put join node nothing work

I do it, thank you so much

It's possible i put the description in the same template with the output:

image                    image                      image 
description              description               description
```

It's possible i put the description in the same template with the output:

I was going to ask about that .. in order to do that, each element of the array of db data returned must have the description for each of the images in its object. So you have to review the way you return (or even save) your data from the db.

I was reading your two other Forum topics in order to understand more how your project works.
Maybe filtering and seperating the data to objects that have a _field description or image is the wrong approach.

When you save the data to the db, you send a msg with the image base64 value but do you send the description of the image along with it ? ( Im asking because from the result of your db query it seems that image and description are on seperate rows - array elements )

1 Like

This is my work:

I send my data like this:

I havent used influxdb before but i notice that your msg.payload is an array.
Does it need to be an array ?

I was reading the documenation of the node and i dont see an example where the payload is a single element array. There is an example of the payload being an object

msg.payload = {
    intValue: '10i',
    numValue: 123.0,
    strValue: "message",
    randomValue: Math.random()*10
}
return msg;

so in your case that would be

msg.payload = {
    image: msg.payload.image,
    description: msg.payload.Description

}
return msg;

can you make a backup of your db (if you have important data) re-test and see how the data is returned after the query ? we must get the image and description in the same array element

maybe someone more experienced with influx can advice you

1 Like