| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200 | define([ "require", "hbs!tmpl/graph/PropagationPropertyModalView_tmpl", "models/VRelationship", "models/VEntity", "modules/Modal", "utils/Utils", "utils/UrlLinks", "utils/Messages" ], function(require, PropagationPropertyModalViewTmpl, VRelationship, VEntity, Modal, Utils, UrlLinks, Messages) {    "use strict";    var PropogationPropertyModal = Backbone.Marionette.CompositeView.extend({        template: PropagationPropertyModalViewTmpl,        templateHelpers: function() {},        regions: {},        ui: {            propagationOptions: '[data-id="propagationOptions"]',            edgeDetailName: '[data-id="edgeDetailName"]',            propagationState: "[data-id='propagationState']",            entityClick: "[data-id='entityClick']",            editPropagationType: 'input[name="editPropagationType"]',            PropagatedClassificationTable: "[data-id='PropagatedClassificationTable']"        },        events: function() {            var events = {}, that = this;            return events["change " + this.ui.propagationOptions] = function() {                this.modalEdited = !0, this.modal.$el.find("button.ok").attr("disabled", !1);            }, events["click " + this.ui.editPropagationType] = function(e) {                this.modalEdited === !0 && (e.preventDefault(), that.notifyModal());            }, events["change " + this.ui.editPropagationType] = function(e) {                e.target.checked ? (this.showPropagatedClassificationTable(), this.viewType = "table") : (this.showEditPropagation(),                 this.viewType = "flow");            }, events["click " + this.ui.entityClick] = function(e) {                var that = this, url = "", notifyObj = {                    modal: !0,                    text: "Are you sure you want to navigate away from this page ?",                    ok: function(argument) {                        that.modal.trigger("cancel"), Utils.setUrl({                            url: url,                            mergeBrowserUrl: !1,                            trigger: !0                        });                    },                    cancel: function(argument) {}                }, $el = $(e.currentTarget), guid = $el.parents("tr").data("entityguid");                url = $el.hasClass("entityName") ? "#!/detailPage/" + guid + "?tabActive=lineage" : "#!/tag/tagAttribute/" + $el.data("name"),                 Utils.notifyConfirm(notifyObj);            }, events["change " + this.ui.propagationState] = function(e) {                this.modalEdited = !0, this.modal.$el.find("button.ok").attr("disabled", !1);                var $el = $(e.currentTarget).parents("tr"), entityguid = $el.data("entityguid"), classificationName = $el.find("[data-name]").data("name");                e.target.checked ? this.propagatedClassifications = _.reject(this.propagatedClassifications, function(val, key) {                    if (val.entityGuid == entityguid && classificationName == val.typeName) return that.blockedPropagatedClassifications.push(val),                     !0;                }) : this.blockedPropagatedClassifications = _.reject(this.blockedPropagatedClassifications, function(val, key) {                    if (val.entityGuid == entityguid && classificationName == val.typeName) return that.propagatedClassifications.push(val),                     !0;                });            }, events;        },        initialize: function(options) {            _.extend(this, _.pick(options, "edgeInfo", "relationshipId", "lineageData", "apiGuid", "detailPageFetchCollection")),             this.entityModel = new VRelationship(), this.VEntityModel = new VEntity(), this.modalEdited = !1,             this.viewType = "flow";            var that = this, modalObj = {                title: "Enable/Disable Propagation",                content: this,                okText: "Update",                okCloses: !1,                cancelText: "Cancel",                mainClass: "modal-lg",                allowCancel: !0            };            this.modal = new Modal(modalObj), this.modal.open(), this.modal.$el.find("button.ok").attr("disabled", !0),             this.on("ok", function() {                that.updateRelation();            }), this.on("closeModal", function() {                this.modal.trigger("cancel");            }), this.updateEdgeView(this.edgeInfo);        },        onRender: function() {},        updateEdgeView: function(options) {            var obj = options, fromEntity = this.lineageData.guidEntityMap[obj.fromEntityId], toEntity = this.lineageData.guidEntityMap[obj.toEntityId];            fromEntity && toEntity && this.ui.edgeDetailName.html(_.escape(fromEntity.displayText) + " <span class='navigation-font'><i class='fa fa-long-arrow-right fa-color'></i></span> " + _.escape(toEntity.displayText)),             obj && obj.relationshipId && (this.showLoader(), this.getEdgeEntity({                id: obj.relationshipId,                from: fromEntity,                to: toEntity            }));        },        getPropagationFlow: function(options) {            var relationshipData = options.relationshipData, graphData = options.graphData, propagateTags = relationshipData.propagateTags;            return relationshipData.end1 ? relationshipData.end1.guid == graphData.from.guid || "BOTH" == propagateTags || "NONE" == propagateTags ? propagateTags : "ONE_TO_TWO" == propagateTags ? "TWO_TO_ONE" : "ONE_TO_TWO" : propagateTags;        },        getEdgeEntity: function(options) {            var that = this, id = options.id, from = options.from, to = options.to, enableOtherFlow = function(relationshipObj) {                var isTwoToOne = !1;                "BOTH" == relationshipObj.propagateTags ? that.ui.propagationOptions.find(".both").show() : (that.ui.propagationOptions.find(".both").hide(),                 that.edgeInfo.fromEntityId != relationshipObj.end1.guid && "ONE_TO_TWO" == relationshipObj.propagateTags ? isTwoToOne = !0 : that.edgeInfo.fromEntityId == relationshipObj.end1.guid && "TWO_TO_ONE" == relationshipObj.propagateTags && (isTwoToOne = !0),                 isTwoToOne ? that.ui.propagationOptions.find(".TWO_TO_ONE").show() : that.ui.propagationOptions.find(".TWO_TO_ONE").hide());            }, updateValue = function(relationshipData) {                var relationshipObj = relationshipData.relationship;                relationshipObj && (that.$("input[name='propagateRelation'][value=" + that.getPropagationFlow({                    relationshipData: relationshipObj,                    graphData: options                }) + "]").prop("checked", !0), enableOtherFlow(relationshipObj), that.showBlockedClassificationTable(relationshipData),                 that.hideLoader({                    buttonDisabled: !0                }));            };            this.ui.propagationOptions.find("li label>span.fromName").text(from.typeName), this.ui.propagationOptions.find("li label>span.toName").text(to.typeName),             id !== this.ui.propagationOptions.attr("entity-id") && (this.ui.propagationOptions.attr("entity-id", id),             this.apiGuid[id] ? updateValue(this.apiGuid[id]) : (this.edgeCall && 4 != this.edgeCall.readyState && this.edgeCall.abort(),             this.edgeCall = this.entityModel.getRelationship(id, {                success: function(relationshipData) {                    that.apiGuid[relationshipData.relationship.guid] = relationshipData, updateValue(relationshipData);                },                cust_error: function() {                    that.hideLoader();                }            })));        },        updateRelation: function() {            var that = this, entityId = that.ui.propagationOptions.attr("entity-id"), PropagationValue = this.$("input[name='propagateRelation']:checked").val(), relationshipProp = {};            this.ui.propagationOptions.attr("propagation", PropagationValue), relationshipProp = "flow" == this.viewType ? {                propagateTags: that.getPropagationFlow({                    relationshipData: _.extend({}, this.apiGuid[entityId].relationship, {                        propagateTags: PropagationValue                    }),                    graphData: {                        from: {                            guid: this.edgeInfo.fromEntityId                        }                    }                })            } : {                blockedPropagatedClassifications: this.blockedPropagatedClassifications,                propagatedClassifications: this.propagatedClassifications            }, this.showLoader(), this.entityModel.saveRelationship({                data: JSON.stringify(_.extend({}, that.apiGuid[entityId].relationship, relationshipProp)),                success: function(relationshipData) {                    relationshipData && (that.hideLoader({                        buttonDisabled: !0                    }), that.modal.trigger("cancel"), that.apiGuid[relationshipData.guid] = relationshipData,                     that.detailPageFetchCollection(), Utils.notifySuccess({                        content: "Propagation flow updated succesfully."                    }));                },                cust_error: function() {                    that.hideLoader();                }            });        },        showBlockedClassificationTable: function(options) {            var propagationStringValue = "", classificationTableValue = "", relationship = options.relationship, referredEntities = options.referredEntities, getEntityName = function(guid) {                var entityObj = referredEntities[guid], name = guid;                return entityObj && (name = Utils.getName(entityObj) + " (" + entityObj.typeName + ")"),                 "<a class='entityName' data-id='entityClick'>" + name + "</a>";            }, getTableRow = function(options) {                var val = options.val, fromBlockClassification = options.fromBlockClassification;                return "<tr data-entityguid=" + val.entityGuid + "><td class='text-center w30'><a class='classificationName' data-id='entityClick' title='" + val.typeName + "' data-name='" + val.typeName + "''>" + val.typeName + "</a></td><td class='text-center'>" + getEntityName(val.entityGuid) + "</td><td class='text-center w30'><input type='checkbox' " + (fromBlockClassification ? "checked" : "") + " data-id='propagationState' class='input'></td></tr>";            };            this.blockedPropagatedClassifications = _.isUndefined(relationship.blockedPropagatedClassifications) ? [] : _.clone(relationship.blockedPropagatedClassifications),             this.propagatedClassifications = _.isUndefined(relationship.propagatedClassifications) ? [] : _.clone(relationship.propagatedClassifications),             _.each(this.blockedPropagatedClassifications, function(val, key) {                propagationStringValue += getTableRow({                    val: val,                    fromBlockClassification: !0                });            }), _.each(this.propagatedClassifications, function(val, key) {                propagationStringValue += getTableRow({                    val: val,                    fromBlockClassification: !1                });            }), classificationTableValue = "<table class='attriTable'><tr><th class='w30'>Classification</th><th>Entity Name</th><th class='w30'>Block Propagatation</th>" + propagationStringValue + "</table>",             this.ui.PropagatedClassificationTable.append(_.isEmpty(propagationStringValue) ? "No Records Found." : classificationTableValue);        },        showLoader: function() {            this.modal.$el.find("button.ok").showButtonLoader(), this.$(".overlay").removeClass("hide").addClass("show");        },        hideLoader: function(options) {            var buttonDisabled = options && options.buttonDisabled;            this.modal.$el.find("button.ok").hideButtonLoader(), this.modal.$el.find("button.ok").attr("disabled", !!buttonDisabled && buttonDisabled),             this.$(".overlay").removeClass("show").addClass("hide");        },        notifyModal: function(options) {            var that = this, notifyObj = {                modal: !0,                text: "It looks like you have edited something. If you leave before saving, your changes will be lost.",                ok: function(argument) {                    that.viewType = that.ui.editPropagationType.is(":checked") ? "flow" : "table", that.ui.editPropagationType.prop("checked", "flow" !== that.viewType).trigger("change"),                     that.modal.$el.find("button.ok").attr("disabled", !0);                },                cancel: function(argument) {                    that.viewType = that.ui.editPropagationType.is(":checked") ? "table" : "flow";                }            };            Utils.notifyConfirm(notifyObj);        },        showEditPropagation: function() {            this.$(".editPropagation").show(), this.$(".propagatedClassificationTable").hide(),             this.modal.$el.find(".modal-title").text("Enable/Disable Propagation");        },        showPropagatedClassificationTable: function() {            this.$(".editPropagation").hide(), this.$(".propagatedClassificationTable").show(),             this.modal.$el.find(".modal-title").text("Select Classifications to Block Propagation");        }    });    return PropogationPropertyModal;});
 |