===========================
The developers of this module are in no way endorsed by or affiliated with Bring! Labs AG, or any associated subsidiaries, logos or trademarks.
For a description of the created states, see below.
-
info.connection
Data type Permission boolean R Read-only boolean indicator. If your broker is logged in on bring, the state is true otherwise false.
-
info.user
Data type Permission string R Read only string. Contains the name of the logged-in user.
For every shopping list a channel with the following states will be created:
-
list.content / list.contentHtml/NoHead
Data type Permission string R Read only json/html string formatted as a list or html table. Contains the items which are currently on your shopping list. The NoHead Html tables are w/o table headers. The content is translated via the dictionary to allow usage in visualization adapters.
-
list.recentContent / list.recentContentHtml/NoHead
Data type Permission string R Read only json/html string formatted as a list or html table. Contains the items which were recently on your shopping list. The NoHead Html tables are w/o table headers. The content is translated via the dictionary to allow usage in visualization adapters.
-
list.removeItem/Translated
Data type Permission string R/W Select an item which should be removed from the shopping list and recent content list. The state will be acknowledged when the command is acknowledged by the Bring! API. Note, that the translated states are using the dictionary before interacting with the API.
-
list.moveToRecentContent/Translated
Data type Permission string R/W Select an item which should be moved or added to recent content list. The state will be acknowledged when the command is acknowledged by the Bring! API. Note, that the translated states are using the dictionary before interacting with the API.
-
list.saveItem/Translated
Data type Permission string R/W Select an item which should be added to the shopping list. You can also specify additional information of the item, by setting the state by the following schema:
Apple, 2.50 $, the green ones
Note, that everything behind the comma describes the specification. The state will be acknowledged when the command is acknowledged by the Bring! API. Note, that the translated states are using the dictionary before interacting with the API.
-
list.users / list.usersHtml/NoHead
Data type Permission string R Read only json/html string formatted as a list or html table. Contains the users which are part of the shopping list, as well as their email address. The NoHead Html tables are w/o table headers.
-
list.count
Data type Permission number R Read only number, which represents the number of contained items of the list.
-
list.messageTrigger
Data type Permission button R/W If you press this button, the shopping list will be sent to the configured instances, e. g. Pushover, Telegram or/and E-Mail.
-
list.enumSentence
Data type Permission string R Read only string, which contains an enumeration of the shopping list items in a speakable form. This can be used e. g. for voice output via smart assistants.
-
list.translation
Data type Permission string R Read only json string, which contains a dictionary to translate the swiss item names to the list language.
- (@foxriver76) fixed issue on token expiration
- (@foxriver76) updated
bring-shopping
module (get rid of deprecatedrequest
module) - (@foxriver76) dropped support for Node.js 16 (it is EOL)
- (foxriver76) fixed setting
undefined
state when no name specified
- (foxriver76) Improve error messages
- (foxriver76) do not crash on invalid
setState
calls (closes #211)
- (foxriver76) implemented a minor fix for acknowledgment of
translated
objects
- (foxriver76) introduced new states for
save/remove/movetoRecentContent
which translates the article before passing it to the API (closes #149)
- (foxriver76) we now ensure that all states which can be used directly are translated (closes #149)
- (foxriver76) widget: fixed
margin-top
calculation of item name
- (foxriver76) log the error message instead of object, if we catch errors in the widget
- (foxriver76) fixed the onclick handler if someone added just a number
- (foxriver76) fixed infinity loop in some browsers, if the fallback image of an article cannot be recevied (closes #109)
- (foxriver76) fixed telegram user selection
- (foxriver76) we fixed default value of
count
state beeing an empty string
- (foxriver76) widget: fix blue border on input text field in Safari when focussing
- (foxriver76) fix potential crash on
pollAllLists
function
- (foxriver76) we now use a unique name for widget rendering function to avoid conflicts
- (foxriver76) if we cannot render widget immediately we try again after one second (see #57)
- (foxriver76) we now render the widget immediately
- (foxriver76) bring module now returns real errors instead of strings, handle them correct
- (foxriver76) fixed potential issue on rendering widget
- (foxriver76) we are now using AES-256-CBC as encryption
- (foxriver76) ensure compatibility with older browsers
- (foxriver76) improved error handling in widget
- (foxriver76) re-auth when bearer token is no longer valid
- (foxriver76) fixed bug which only allowed one registered event handler
- (foxriver76) by using obj with wid instead of var because vis handles global variables of widgets global
- (foxriver76) now more bring widgets can be used in one vis project
- (foxriver76) bump version of textFit to 2.3.1 -> 2.4.0 and use minified version
- (foxriver76) also use translations for enumSentence and notifiations (e. g. email)
- (foxriver76) fixed bug, that prevent html states and other from being set
- (foxriver76) get translations according to list language
- (foxriver76) translations will be stored in datapoint
- (foxriver76) use bring-node-api at least 1.2.1
- (foxriver76) widget now uses configured language
- (foxriver76) bugfixes and optimizations in front- and backend
- (foxriver76) use textFit to fit text to one line in widget
- (foxriver76) internal reworks on widget
- (foxriver76) add possibility to use this widget multiple times on same page
- (foxriver76) also change height and div sizes according to users specification
- (foxriver76) when item is on recent list and added by text input it is now instantly removed from recent list
- (foxriver76) enable configuration of width for items in widget
- (foxriver76) api module outsourced
- (foxriver76) added widget
- (foxriver76) add possibility to move items to recentContent
- (foxriver76) uri encode login request because it can contain special character
- (foxriver76) added state which contains a speakable enumeration of each shopping list
- (foxriver76) add possibility to send messages
- (foxriver76) respect in app list renaming / recreate channel on name change
- (foxriver76) stable release
- (foxriver76) set info.connection state to false, when cannot get data
- (foxriver76) also update no head states on normal polling
- (foxriver76) fix bug where polling could grow exponentially
- (foxriver76) fix unhandled error when no internet connection
- (foxriver76) add html states w/o header
- (foxriver76) minor fixes
- (foxriver76) fixed a potential memory leak by setTimeout functions
- (foxriver76) add equivalent html states for json states
- (foxriver76) add counter for every list
- (foxriver76) fix when login fails
- (foxriver76) initial release
The MIT License (MIT)
Copyright (c) 2019-2025 Moritz Heusinger [email protected]
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.