123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- module.exports = function (RED) {
- /**
- *
- * @param {*} config
- */
- function UIPageNode (config) {
- RED.nodes.createNode(this, config)
- const node = this
-
- node.on('close', function (removed, done) {
- node.deregister() // deregister self
- done()
- })
-
- // backward compatibility
- if (!('disabled' in config)) {
- // ensure we have a value
- config.disabled = false
- } else {
- // ensure we have a boolean
- config.disabled = (config.disabled === 'true' || config.disabled === true)
- }
- if (!('visible' in config)) {
- // ensure we have a value
- config.visible = true
- } else {
- // ensure we have a boolean
- config.visible = (config.visible === 'true' || config.visible === true)
- }
-
- const ui = RED.nodes.getNode(config.ui)
-
- // register self
- ui.register(config)
-
- /**
- * Function for widgets to register themselves with this page
- * Calls the parent UI Base "register" function and registers this page,
- * along with the widget
- * @param {*} widget
- */
- node.register = function (group, widgetNode, widgetConfig, widgetEvents) {
- const page = config
- if (ui) {
- ui.register(page, group, widgetNode, widgetConfig, widgetEvents)
- } else {
- node.error(`Error registering Widget - ${widgetNode.name || widgetNode.id}. No parent ui-base node found for ui-page node: ${(page.name || page.id)}`)
- }
- }
- node.deregister = function (group, widgetNode) {
- const page = config
- if (ui) {
- ui.deregister(page, group, widgetNode)
- }
- }
-
- // Return the UI Base Node this page lives in
- node.getBase = function () {
- return RED.nodes.getNode(config.ui)
- }
- }
- RED.nodes.registerType('ui-page', UIPageNode)
- }
|