All Downloads are FREE. Search and download functionalities are using the official Maven repository.

resources.js.qpid.common.ContextVariablesEditor.js Maven / Gradle / Ivy

/*
 *
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 *
 */
define(["qpid/common/util",
        "dojo/_base/declare",
        "dojo/_base/array",
        "dojo/_base/connect",
        "dojo/_base/lang",
        "dojo/dom-construct",
        "dojo/parser",
        "dojo/query",
        "dojo/store/Memory",
        "dojo/data/ObjectStore",
        "dijit/_WidgetBase",
        "dijit/registry",
        "dojo/text!common/ContextVariablesEditor.html",
        "dijit/form/Button",
        "dojox/grid/EnhancedGrid",
        "dojox/grid/enhanced/_Plugin",
        "dojox/grid/enhanced/plugins/IndirectSelection",
        "dijit/form/Select",
        "dojox/validate/us",
        "dojox/validate/web",
        "dojo/domReady!"],
    function (util,
              declare,
              array,
              connect,
              lang,
              domConstruct,
              parser,
              query,
              Memory,
              ObjectStore,
              _WidgetBase,
              registry,
              template)
    {

        return declare("qpid.common.ContextVariablesEditor", [_WidgetBase], {

            value: null,
            effectiveValues: null,
            inheritedActualValues: null,
            domNode: null,
            _grid: null,
            _addButton: null,
            _deleteButton: null,
            _filterBox: null,
            _nextGridItemId: 0,
            _dynamicInheritedContext: {},

            constructor: function (args)
            {
                this._args = args;
            },

            buildRendering: function ()
            {
                this.domNode = domConstruct.create("div", {innerHTML: template});
                parser.parse(this.domNode);
            },

            postCreate: function ()
            {
                this.inherited(arguments);
                var that = this;
                var gridNode = query(".grid", this.domNode)[0];
                var addButtonNode = query(".addButton", this.domNode)[0];
                var deleteButtonNode = query(".deleteButton", this.domNode)[0];
                var addButton = registry.byNode(addButtonNode);
                var deleteButton = registry.byNode(deleteButtonNode);
                var layout = [[{
                    name: "Name",
                    field: "name",
                    width: "40%",
                    editable: true
                }, {
                    name: 'Actual Value',
                    field: 'actualValue',
                    width: '30%',
                    editable: true
                }, {
                    name: 'Effective Value',
                    field: 'effectiveValue',
                    width: '30%',
                    editable: false
                }]];
                var data = [];
                var objectStore = new dojo.data.ObjectStore({
                    objectStore: new Memory({
                        data: data,
                        idProperty: "id"
                    })
                });
                var grid = new dojox.grid.EnhancedGrid({
                    selectionMode: "multiple",
                    store: objectStore,
                    singleClickEdit: true,
                    structure: layout,
                    autoHeight: true,
                    sortFields: [{
                        attribute: 'name',
                        descending: false
                    }],
                    plugins: {indirectSelection: true}
                }, gridNode);
                grid.canEdit = function (inCell, inRowIndex)
                {
                    var item = grid.getItem(inRowIndex);
                    return inCell.field == "actualValue" || (inCell.field == "name" && item && item["inherited"]
                                                                                               == false);
                };

                this._grid = grid;
                this._deleteButton = deleteButton;
                this._addButtonNode = addButtonNode;

                var toggleGridButtons = function (index)
                {
                    var data = grid.selection.getSelected();
                    deleteButton.set("disabled", !data || data.length == 0);
                };

                connect.connect(grid.selection, 'onSelected', toggleGridButtons);
                connect.connect(grid.selection, 'onDeselected', toggleGridButtons);
                connect.connect(grid, 'onStyleRow', this, function (row)
                {
                    that._onStyleRow(row);
                });

                deleteButton.set("disabled", true);
                addButton.on("click", function (event)
                {
                    that._newItem();
                });
                deleteButton.on("click", function (event)
                {
                    that._deleteSelected();
                });
                grid.on("applyEdit", function (inRowIndex)
                {
                    that._onEdit(inRowIndex);
                });
                grid.startup();
                this._filterBox = registry.byNode(query(".filter", this.domNode)[0]);
                this._filterBox.on("change", function (value)
                {
                    if (value)
                    {
                        that._filter(value);
                    }
                });
            },
            resize: function ()
            {
                this._grid.render();
            },
            setData: function (actualValues, allEffectiveValues, inheritedActualValues)
            {
                this.value = actualValues;
                this.effectiveValues = allEffectiveValues;
                this.inheritedActualValues = inheritedActualValues;

                var values = this._mergeValues(actualValues, allEffectiveValues, inheritedActualValues);
                this._originalValues = values;

                var grid = this._grid;
                if (grid)
                {
                    // delete previous store data
                    grid.store.fetch({
                        onComplete: function (items, request)
                        {
                            if (items.length)
                            {
                                array.forEach(items, function (item)
                                {
                                    grid.store.deleteItem(item);
                                });
                            }
                        }
                    });

                    // add new data into grid store
                    this._nextGridItemId = 0;
                    for (var i = 0; i < values.length; i++)
                    {
                        var item = values[i];
                        var storeItem = {
                            id: this._nextId(),
                            name: item.name,
                            actualValue: item.actualValue,
                            effectiveValue: item.effectiveValue,
                            "inherited": item["inherited"],
                            changed: false
                        };
                        grid.store.newItem(storeItem);
                    }
                    grid.store.save();
                }
                this._filter(this._filterBox.value);
                this._handleOnChange(actualValues);
            },
            addInheritedContext: function (object)
            {
                if (object)
                {
                    var grid = this._grid;
                    for (key in object)
                    {
                        for (var i = 0; i < this._originalValues.length; i++)
                        {
                            var varExists = false;
                            if (this._originalValues[i].name == key)
                            {
                                varExists = true;
                                break;
                            }
                        }
                        if (!varExists && !(key in this._dynamicInheritedContext))
                        {
                            this._dynamicInheritedContext[key] = object[key];
                            var storeItem = {
                                id: this._nextId(),
                                name: key,
                                actualValue: object[key],
                                effectiveValue: "",
                                "inherited": true,
                                changed: false
                            };
                            grid.store.newItem(storeItem);
                            this._originalValues.push({
                                name: key,
                                actualValue: object[key],
                                effectiveValue: "",
                                "inherited": true,
                                changed: false
                            });
                        }
                    }
                    grid.store.save();
                    this._filter(this._filterBox.value);
                }
            },
            removeDynamicallyAddedInheritedContext: function ()
            {
                if (this._dynamicInheritedContext)
                {
                    var that = this;
                    var grid = this._grid;
                    grid.store.fetch({
                        onComplete: function (items, request)
                        {
                            if (items.length)
                            {
                                for (key in that._dynamicInheritedContext)
                                {
                                    var item = null;
                                    for (var i = 0; i < items.length; i++)
                                    {
                                        if (items[i].name == key)
                                        {
                                            item = items[i];
                                            break;
                                        }
                                    }
                                    if (item && !item.changed)
                                    {
                                        grid.store.deleteItem(item);
                                        that._deleteOriginalItem(item);
                                    }
                                }
                                grid.store.save();
                                that._dynamicInheritedContext = {};
                            }
                        }
                    });
                }
            },
            destroy: function ()
            {
                if (this._grid !== null)
                {
                    this._grid.destroyRecursive();
                    this._grid = null;
                }
                if (this._addButton !== null)
                {
                    this._addButton.destroyRecursive();
                    this._addButton = null;
                }
                if (this._deleteButton !== null)
                {
                    this._deleteButton.destroyRecursive();
                    this._deleteButton = null;
                }
                if (this._filterBox !== null)
                {
                    this._filterBox.destroyRecursive();
                    this._filterBox = null;
                }
                this.inherited(arguments);
                if (this.domNode)
                {
                    domConstruct.destroy(this.domNode );
                    this.domNode = null;
                }

            },
            onChange: function (newValue)
            {
            },
            _newItem: function ()
            {
                var newItem = {
                    id: this._nextId(),
                    name: "",
                    actualValue: "",
                    effectiveValue: "",
                    "inherited": false,
                    changed: true
                };
                var grid = this._grid;
                grid.store.newItem(newItem);
                grid.store.save();
                grid.store.fetch({
                    onComplete: function (items, request)
                    {
                        var rowIndex = items.length - 1;
                        window.setTimeout(function ()
                        {
                            grid.focus.setFocusIndex(rowIndex, 1);
                        }, 10);
                    }
                });
            },
            _deleteSelected: function ()
            {
                var that = this;
                var grid = this._grid;
                var data = grid.selection.getSelected();
                if (data.length > 0)
                {
                    array.forEach(data, function (selectedItem)
                    {
                        if (selectedItem !== null && !selectedItem["inherited"])
                        {
                            grid.store.deleteItem(selectedItem);
                            that._deleteOriginalItem(selectedItem.name);
                        }
                    });
                    grid.store.save();
                    grid.selection.deselectAll();
                    this._valueChanged();
                }
            },
            _deleteOriginalItem: function (key)
            {
                for (var i = 0; i < this._originalValues.length; i++)
                {
                    if (this._originalValues[i].name == key)
                    {
                        this._originalValues = this._originalValues.splice(i, 1);
                        break;
                    }
                }
            },
            _onEdit: function (inRowIndex)
            {
                var grid = this._grid;
                var item = grid.getItem(inRowIndex);
                var previousItems = this._originalValues;
                var previousItemActualValue = null;
                for (var i = 0; i < previousItems.length; i++)
                {
                    if (previousItems[i].name == item.name)
                    {
                        previousItemActualValue = previousItems[i].actualValue;
                        break;
                    }
                }

                if (item.actualValue != previousItemActualValue)
                {
                    if (!item.changed)
                    {
                        grid.store.setValue(item, "changed", true);
                        grid.store.save();
                    }
                }
                else
                {
                    if (item["inherited"] == true && item.changed)
                    {
                        grid.store.setValue(item, "changed", false);
                        grid.store.save();
                    }
                }
                this._valueChanged();
            },
            _onStyleRow: function (row)
            {
                var grid = this._grid;
                var inRowIndex = row.index;
                var item = grid.getItem(inRowIndex);
                if (item && (item["inherited"] == false || item.changed))
                {
                    row.customClasses += " highlightedText";
                }
                else
                {
                    row.customClasses += " normalText";
                }
                grid.focus.styleRow(row);
                grid.edit.styleRow(row);
            },
            _filter: function (value)
            {
                this._grid.filter({"inherited": value});
            },
            _nextId: function ()
            {
                this._nextGridItemId = this._nextGridItemId + 1;
                return this._nextGridItemId;
            },
            _valueChanged: function ()
            {
                if (this._grid)
                {
                    var value = {};
                    var grid = this._grid;
                    grid.store.fetch({
                        onComplete: function (items, request)
                        {
                            if (items.length > 0)
                            {
                                array.forEach(items, function (item)
                                {
                                    if (item !== null && item.name && ((item["inherited"] && item.changed)
                                                                       || !item["inherited"]))
                                    {
                                        value[item.name] = item.actualValue;
                                    }
                                });
                            }
                        }
                    });
                    if (!util.equals(this.value, value))
                    {
                        this.value = value;
                        this._handleOnChange(value);
                    }
                }
            },
            _setValueAttr: function (actualValues)
            {
                this.value = actualValues;
                if (this.inheritedActualValues != null && this.effectiveValues != null)
                {
                    this.setData(this.value, this.effectiveValues, this.inheritedActualValues);
                }
            },
            _setEffectiveValuesAttr: function (effectiveValues)
            {
                this.effectiveValues = effectiveValues;
                if (this.value != null && this.inheritedActualValues != null)
                {
                    this.setData(this.value, this.effectiveValues, this.inheritedActualValues);
                }
            },
            _setInheritedActualValues: function (inheritedActualValues)
            {
                this.inheritedActualValues = inheritedActualValues;
                if (this.value != null && this.effectiveValues != null)
                {
                    this.setData(this.value, this.effectiveValues, this.inheritedActualValues);
                }
            },
            _mergeValues: function (actualValues, allEffectiveValues, inheritedActualValues)
            {
                var fields = [];

                if (allEffectiveValues)
                {
                    for (var key in allEffectiveValues)
                    {
                        if (!actualValues || !(key in actualValues))
                        {
                            var actualValue = inheritedActualValues && key in inheritedActualValues
                                ? inheritedActualValues[key]
                                : allEffectiveValues[key];
                            fields.push({
                                name: key,
                                actualValue: actualValue,
                                effectiveValue: allEffectiveValues[key],
                                "inherited": true
                            });
                        }
                    }
                }

                if (actualValues)
                {
                    for (var key in actualValues)
                    {
                        var effectiveValue = allEffectiveValues && key in allEffectiveValues
                            ? allEffectiveValues[key]
                            : actualValues[key];
                        fields.push({
                            name: key,
                            actualValue: actualValues[key],
                            effectiveValue: effectiveValue,
                            "inherited": false
                        });
                    }
                }
                return fields;
            },
            _handleOnChange: function (newValue)
            {
                if (!util.equals(this._lastValueReported, newValue))
                {
                    this._lastValueReported = newValue;
                    if (this._onChangeHandle)
                    {
                        this._onChangeHandle.remove();
                    }
                    this._onChangeHandle = this.defer(function ()
                    {
                        this._onChangeHandle = null;
                        this.onChange(newValue);
                    });
                }
            }

        });
    });




© 2015 - 2025 Weber Informatics LLC | Privacy Policy