define([ "require", "backbone", "hbs!tmpl/search/SearchLayoutView_tmpl", "utils/Utils", "utils/UrlLinks", "utils/Globals", "utils/Enums", "collection/VSearchList", "utils/CommonViewFunction", "jstree" ], function(require, Backbone, SearchLayoutViewTmpl, Utils, UrlLinks, Globals, Enums, VSearchList, CommonViewFunction) {
"use strict";
var SearchLayoutView = Backbone.Marionette.LayoutView.extend({
_viewName: "SearchLayoutView",
template: SearchLayoutViewTmpl,
regions: {},
ui: {
searchInput: '[data-id="searchInput"]',
searchType: 'input[name="queryType"]',
searchBtn: '[data-id="searchBtn"]',
clearSearch: '[data-id="clearSearch"]',
typeLov: '[data-id="typeLOV"]',
tagLov: '[data-id="tagLOV"]',
termLov: '[data-id="termLOV"]',
refreshBtn: '[data-id="refreshBtn"]',
advancedInfoBtn: '[data-id="advancedInfo"]',
typeAttrFilter: '[data-id="typeAttrFilter"]',
tagAttrFilter: '[data-id="tagAttrFilter"]'
},
events: function() {
var events = {}, that = this;
return events["keyup " + this.ui.searchInput] = function(e) {
var code = e.which;
this.value.query = e.currentTarget.value, this.query[this.type].query = this.value.query,
13 == code && that.findSearchResult(), this.checkForButtonVisiblity();
}, events["change " + this.ui.searchType] = "dslFulltextToggle", events["click " + this.ui.searchBtn] = "findSearchResult",
events["click " + this.ui.clearSearch] = "clearSearchData", events["change " + this.ui.typeLov] = "checkForButtonVisiblity",
events["change " + this.ui.tagLov] = "checkForButtonVisiblity", events["change " + this.ui.termLov] = "checkForButtonVisiblity",
events["click " + this.ui.refreshBtn] = "onRefreshButton", events["click " + this.ui.advancedInfoBtn] = "advancedInfo",
events["click " + this.ui.typeAttrFilter] = function() {
this.openAttrFilter("type");
}, events["click " + this.ui.tagAttrFilter] = function() {
this.openAttrFilter("tag");
}, events;
},
initialize: function(options) {
_.extend(this, _.pick(options, "value", "typeHeaders", "searchVent", "entityDefCollection", "enumDefCollection", "classificationDefCollection", "searchTableColumns", "searchTableFilters", "metricCollection", "onSubmit")),
this.type = "dsl", this.entityCountObj = _.first(this.metricCollection.toJSON()) || {
entity: {
entityActive: {},
entityDeleted: {}
},
tag: {
tagEntities: {}
}
}, this.filterTypeSelected = [];
var param = Utils.getUrlState.getQueryParams();
this.query = {
dsl: {
query: null,
type: null,
pageOffset: null,
pageLimit: null
},
basic: {
query: null,
type: null,
tag: null,
term: null,
attributes: null,
tagFilters: null,
pageOffset: null,
pageLimit: null,
entityFilters: null,
includeDE: null,
excludeST: null,
excludeSC: null
}
}, this.value || (this.value = {}), this.dsl = !1, param && param.searchType && (this.type = param.searchType,
this.updateQueryObject(param)), this.bindEvents();
},
bindEvents: function(param) {
this.listenTo(this.typeHeaders, "reset", function(value) {
this.initializeValues();
}, this);
},
onRender: function() {
"basic" === this.type && this.$(".searchByText").hide(), this.initializeValues(),
this.dslFulltextToggle(!0, !1);
},
initializeValues: function() {
this.renderTypeTagList(), this.renderTermList(), this.setValues(), this.checkForButtonVisiblity();
},
makeFilterButtonActive: function(filtertypeParam) {
var filtertype = [ "entityFilters", "tagFilters" ], that = this;
filtertypeParam && (_.isArray(filtertypeParam) ? filtertype = filtertypeParam : _.isString(filtertypeParam) && (filtertype = [ filtertypeParam ]));
var typeCheck = function(filterObj, type) {
that.value.type ? (filterObj && filterObj.length ? that.ui.typeAttrFilter.addClass("active") : that.ui.typeAttrFilter.removeClass("active"),
that.ui.typeAttrFilter.prop("disabled", !1)) : (that.ui.typeAttrFilter.removeClass("active"),
that.ui.typeAttrFilter.prop("disabled", !0));
}, tagCheck = function(filterObj, type) {
that.value.tag && !_.contains(Enums.addOnClassification, that.value.tag) ? (that.ui.tagAttrFilter.prop("disabled", !1),
filterObj && filterObj.length ? that.ui.tagAttrFilter.addClass("active") : that.ui.tagAttrFilter.removeClass("active")) : (that.ui.tagAttrFilter.removeClass("active"),
that.ui.tagAttrFilter.prop("disabled", !0));
};
_.each(filtertype, function(type) {
var filterObj = that.searchTableFilters[type];
"entityFilters" == type && typeCheck(filterObj[that.value.type], type), "tagFilters" == type && tagCheck(filterObj[that.value.tag], type);
});
},
checkForButtonVisiblity: function(e, options) {
var that = this, isBasicSearch = "basic" == this.type;
if (e && e.currentTarget) {
var $el = $(e.currentTarget), isTagEl = "tagLOV" == $el.data("id"), isTermEl = "termLOV" == $el.data("id"), isTypeEl = "typeLOV" == $el.data("id"), select2Data = $el.select2("data");
if ("change" == e.type && select2Data) {
var value = _.isEmpty(select2Data) ? select2Data : _.first(select2Data).id, key = "tag", filterType = isBasicSearch ? "tagFilters" : null, value = value && value.length ? value : null;
if (isTagEl || (key = isTermEl ? "term" : "type", isBasicSearch && (filterType = isTypeEl ? "entityFilters" : null)),
this.value) {
if (this.value[key] !== value || !value && !this.value[key]) {
var temp = {};
temp[key] = value, _.extend(this.value, temp), _.isUndefined(options) && (this.value.pageOffset = 0),
_.extend(this.query[this.type], temp);
} else if (isBasicSearch && this.value.type) if (this.value.attributes) {
var attributes = _.sortBy(this.value.attributes.split(",")), tableColumn = this.searchTableColumns[this.value.type];
_.isEmpty(this.searchTableColumns) || !tableColumn ? this.searchTableColumns[this.value.type] = attributes : tableColumn.join(",") !== attributes.join(",") && (this.searchTableColumns[this.value.type] = attributes);
} else this.searchTableColumns[this.value.type] && (this.searchTableColumns[this.value.type] = void 0);
isBasicSearch && filterType && this.makeFilterButtonActive(filterType);
} else isBasicSearch && (this.ui.tagAttrFilter.prop("disabled", !0), this.ui.typeAttrFilter.prop("disabled", !0));
}
}
var value = this.ui.searchInput.val() || _.first($(this.ui.typeLov).select2("data")).id;
if (!this.dsl && _.isEmpty(value)) {
var termData = _.first($(this.ui.termLov).select2("data"));
value = _.first($(this.ui.tagLov).select2("data")).id || (termData ? termData.id : "");
}
value && value.length ? (this.ui.searchBtn.removeAttr("disabled"), setTimeout(function() {
!that.isDestroyed && that.ui.searchInput.focus();
}, 0)) : this.ui.searchBtn.attr("disabled", "true");
},
updateQueryObject: function(param) {
param && param.searchType && (this.type = param.searchType), _.extend(this.query[this.type], "dsl" == this.type ? {
query: null,
type: null,
pageOffset: null,
pageLimit: null
} : {
query: null,
type: null,
tag: null,
term: null,
attributes: null,
tagFilters: null,
pageOffset: null,
pageLimit: null,
entityFilters: null,
includeDE: null
}, param);
},
fetchCollection: function(value) {
this.typeHeaders.fetch({
reset: !0
});
},
onRefreshButton: function() {
this.fetchCollection();
var checkURLValue = Utils.getUrlState.getQueryParams(this.url);
this.searchVent && (_.has(checkURLValue, "tag") || _.has(checkURLValue, "type") || _.has(checkURLValue, "query")) && this.searchVent.trigger("search:refresh");
},
advancedInfo: function(e) {
require([ "views/search/AdvancedSearchInfoView", "modules/Modal" ], function(AdvancedSearchInfoView, Modal) {
var view = new AdvancedSearchInfoView(), modal = new Modal({
title: "高级搜索查询",
content: view,
okCloses: !0,
showFooter: !0,
allowCancel: !1
}).open();
view.on("closeModal", function() {
modal.trigger("cancel");
});
});
},
openAttrFilter: function(filterType) {
var that = this;
require([ "views/search/SearchQueryView" ], function(SearchQueryView) {
that.attrModal = new SearchQueryView({
value: that.value,
tag: "tag" === filterType,
type: "type" === filterType,
searchVent: that.searchVent,
typeHeaders: that.typeHeaders,
entityDefCollection: that.entityDefCollection,
enumDefCollection: that.enumDefCollection,
classificationDefCollection: that.classificationDefCollection,
searchTableFilters: that.searchTableFilters
}), that.attrModal.on("ok", function(scope, e) {
that.okAttrFilterButton(e);
});
});
},
okAttrFilterButton: function(e) {
function getIdFromRuleObject(rule) {
return _.map(rule.rules, function(obj, key) {
return _.has(obj, "condition") ? getIdFromRuleObject(obj) : col.push(obj.id);
}), col;
}
var isTag = !!this.attrModal.tag, filtertype = isTag ? "tagFilters" : "entityFilters", queryBuilderRef = this.attrModal.RQueryBuilder.currentView.ui.builder, col = [];
if (queryBuilderRef.data("queryBuilder")) var rule = queryBuilderRef.queryBuilder("getRules");
if (rule) {
var ruleUrl = CommonViewFunction.attributeFilter.generateUrl({
value: rule,
formatedDateToLong: !0
});
this.searchTableFilters[filtertype][isTag ? this.value.tag : this.value.type] = ruleUrl,
this.makeFilterButtonActive(filtertype), !isTag && this.value && this.value.type && this.searchTableColumns && (this.searchTableColumns[this.value.type] || (this.searchTableColumns[this.value.type] = [ "selected", "name", "owner", "description", "tag", "typeName" ]),
this.searchTableColumns[this.value.type] = _.sortBy(_.union(this.searchTableColumns[this.value.type], getIdFromRuleObject(rule)))),
this.attrModal.modal.close(), $(e.currentTarget).hasClass("search") && this.findSearchResult();
}
},
manualRender: function(paramObj) {
this.updateQueryObject(paramObj), this.setValues(paramObj);
},
getFilterBox: function() {
var serviceStr = "", serviceArr = [], that = this;
this.typeHeaders.fullCollection.each(function(model) {
var serviceType = model.toJSON().serviceType;
serviceType && serviceArr.push(serviceType);
}), _.each(_.uniq(serviceArr), function(service) {
serviceStr += '
";
});
var templt = serviceStr + '
';
return templt;
},
setValues: function(paramObj) {
var that = this;
paramObj && (this.value = paramObj), this.value && (this.ui.searchInput.val(this.value.query || ""),
"true" == this.value.dslChecked ? this.ui.searchType.prop("checked") || this.ui.searchType.prop("checked", !0).trigger("change") : this.ui.searchType.prop("checked") && this.ui.searchType.prop("checked", !1).trigger("change"),
this.ui.typeLov.val(this.value.type), this.ui.typeLov.data("select2") && (this.ui.typeLov.val() !== this.value.type ? (this.value.type = null,
this.ui.typeLov.val("").trigger("change", {
manual: !0
})) : this.ui.typeLov.trigger("change", {
manual: !0
})), this.dsl || (this.ui.tagLov.val(this.value.tag), this.ui.tagLov.data("select2") && (this.ui.tagLov.val() !== this.value.tag ? (this.value.tag = null,
this.ui.tagLov.val("").trigger("change", {
manual: !0
})) : this.ui.tagLov.trigger("change", {
manual: !0
})), this.value.term && this.ui.termLov.append('"),
this.ui.termLov.data("select2") && (this.ui.termLov.val() !== this.value.term ? (this.value.term = null,
this.ui.termLov.val("").trigger("change", {
manual: !0
})) : this.ui.termLov.trigger("change", {
manual: !0
}))), setTimeout(function() {
!that.isDestroyed && that.ui.searchInput.focus();
}, 0));
},
renderTypeTagList: function(options) {
var that = this, serviceTypeToBefiltered = options && options.filterList, isTypeOnly = options && options.isTypeOnly;
this.ui.typeLov.empty();
var typeStr = "", tagStr = typeStr;
this.typeHeaders.fullCollection.each(function(model) {
var name = Utils.getName(model.toJSON(), "name");
if ("ENTITY" == model.get("category") && (!serviceTypeToBefiltered || !serviceTypeToBefiltered.length || _.contains(serviceTypeToBefiltered, model.get("serviceType")))) {
var entityCount = that.entityCountObj.entity.entityActive[name] + (that.entityCountObj.entity.entityDeleted[name] ? that.entityCountObj.entity.entityDeleted[name] : 0);
typeStr += '";
}
if (void 0 == isTypeOnly && "CLASSIFICATION" == model.get("category")) {
var tagEntityCount = that.entityCountObj.tag.tagEntities[name];
tagStr += '";
}
}), _.isUndefined(isTypeOnly) && (_.each(Enums.addOnClassification, function(classificationName) {
tagStr += '";
}), that.ui.tagLov.html(tagStr), this.ui.tagLov.select2({
placeholder: "Select Classification",
allowClear: !0
})), that.ui.typeLov.html(typeStr);
var typeLovSelect2 = this.ui.typeLov.select2({
placeholder: "请选择类型",
dropdownAdapter: $.fn.select2.amd.require("ServiceTypeFilterDropdownAdapter"),
allowClear: !0,
dropdownCssClass: "searchLayoutView",
getFilterBox: this.getFilterBox.bind(this),
onFilterSubmit: function(options) {
that.filterTypeSelected = options.filterVal, that.renderTypeTagList({
filterList: options.filterVal,
isTypeOnly: !0
});
}
});
typeLovSelect2.on("select2:close", function() {
typeLovSelect2.trigger("hideFilter");
}), typeLovSelect2 && serviceTypeToBefiltered && typeLovSelect2.select2("open").trigger("change", {
manual: !0
});
},
renderTermList: function() {
var getTypeAheadData = function(data, params) {
var dataList = data.entities, foundOptions = [];
return _.each(dataList, function(obj) {
obj && (obj.guid && (obj.id = Utils.getName(obj, "qualifiedName")), foundOptions.push(obj));
}), foundOptions;
};
this.ui.termLov.select2({
placeholder: "Search Term",
allowClear: !0,
ajax: {
url: UrlLinks.searchApiUrl("attribute"),
dataType: "json",
delay: 250,
data: function(params) {
return {
attrValuePrefix: params.term,
typeName: "AtlasGlossaryTerm",
limit: 10,
offset: 0
};
},
processResults: function(data, params) {
return {
results: getTypeAheadData(data, params)
};
},
cache: !0
},
templateResult: function(option) {
var name = Utils.getName(option, "qualifiedName");
return "-" === name ? option.text : name;
},
templateSelection: function(option) {
var name = Utils.getName(option, "qualifiedName");
return "-" === name ? option.text : name;
},
escapeMarkup: function(markup) {
return markup;
},
minimumInputLength: 1
});
},
renderSaveSearch: function() {
var that = this;
require([ "views/search/save/SaveSearchView" ], function(SaveSearchView) {
function fetchSaveSearchCollection() {
saveSearchCollection.fetch({
success: function(collection, data) {
saveSearchAdvanceCollection.fullCollection.reset(_.where(data, {
searchType: "ADVANCED"
})), saveSearchBaiscCollection.fullCollection.reset(_.where(data, {
searchType: "BASIC"
}));
},
silent: !0
});
}
function getModelName(model) {
if (model.get("name")) return model.get("name").toLowerCase();
}
var saveSearchBaiscCollection = new VSearchList(), saveSearchAdvanceCollection = new VSearchList(), saveSearchCollection = new VSearchList();
saveSearchCollection.url = UrlLinks.saveSearchApiUrl(), saveSearchBaiscCollection.fullCollection.comparator = function(model) {
return getModelName(model);
}, saveSearchAdvanceCollection.fullCollection.comparator = function(model) {
return getModelName(model);
};
var obj = {
value: that.value,
searchVent: that.searchVent,
typeHeaders: that.typeHeaders,
fetchCollection: fetchSaveSearchCollection,
classificationDefCollection: that.classificationDefCollection,
entityDefCollection: that.entityDefCollection,
getValue: function() {
var queryObj = that.query[that.type], entityObj = that.searchTableFilters.entityFilters, tagObj = that.searchTableFilters.tagFilters, urlObj = Utils.getUrlState.getQueryParams();
return urlObj && (urlObj.includeDE = "true" == urlObj.includeDE, urlObj.excludeSC = "true" == urlObj.excludeSC,
urlObj.excludeST = "true" == urlObj.excludeST), _.extend({}, queryObj, urlObj, {
entityFilters: entityObj ? entityObj[queryObj.type] : null,
tagFilters: tagObj ? tagObj[queryObj.tag] : null,
type: queryObj.type,
query: queryObj.query,
term: queryObj.term,
tag: queryObj.tag
});
},
applyValue: function(model, searchType) {
that.manualRender(_.extend(searchType, CommonViewFunction.generateUrlFromSaveSearchObject({
value: {
searchParameters: model.get("searchParameters"),
uiParameters: model.get("uiParameters")
},
classificationDefCollection: that.classificationDefCollection,
entityDefCollection: that.entityDefCollection
})));
}
};
that.RSaveSearchBasic.show(new SaveSearchView(_.extend(obj, {
isBasic: !0,
collection: saveSearchBaiscCollection.fullCollection
}))), that.RSaveSearchAdvance.show(new SaveSearchView(_.extend(obj, {
isBasic: !1,
collection: saveSearchAdvanceCollection.fullCollection
}))), fetchSaveSearchCollection();
});
},
findSearchResult: function() {
this.triggerSearch(this.ui.searchInput.val());
},
triggerSearch: function(value) {
var params = {
searchType: this.type,
dslChecked: this.ui.searchType.is(":checked"),
tagFilters: null,
entityFilters: null
}, typeLovValue = this.ui.typeLov.find(":selected").data("name"), tagLovValue = this.ui.tagLov.find(":selected").data("name"), termLovValue = this.ui.termLov.select2("val");
if (params.type = typeLovValue || null, !this.dsl) {
params.tag = tagLovValue || null, params.term = termLovValue || null;
var entityFilterObj = this.searchTableFilters.entityFilters, tagFilterObj = this.searchTableFilters.tagFilters;
this.value.tag && (params.tagFilters = tagFilterObj[this.value.tag]), this.value.type && (params.entityFilters = entityFilterObj[this.value.type]);
var columnList = this.value && this.value.type && this.searchTableColumns ? this.searchTableColumns[this.value.type] : null;
columnList && (params.attributes = columnList.join(",")), params.includeDE = !_.isUndefinedNull(this.value.includeDE) && this.value.includeDE,
params.excludeST = !_.isUndefinedNull(this.value.excludeST) && this.value.excludeST,
params.excludeSC = !_.isUndefinedNull(this.value.excludeSC) && this.value.excludeSC;
}
_.isUndefinedNull(this.value.pageLimit) || (params.pageLimit = this.value.pageLimit),
_.isUndefinedNull(this.value.pageOffset) || (_.isUndefinedNull(this.query[this.type]) || this.query[this.type].query == value ? params.pageOffset = this.value.pageOffset : params.pageOffset = 0),
params.query = value || null, _.extend(this.query[this.type], params), this.onSubmit && this.onSubmit(this.query[this.type]),
Utils.setUrl({
url: "#!/search/searchResult",
urlParams: _.extend({}, this.query[this.type]),
mergeBrowserUrl: !1,
trigger: !0,
updateTabState: !0
});
},
dslFulltextToggle: function(e, triggerUrl) {
var paramObj = Utils.getUrlState.getQueryParams();
paramObj && this.type == paramObj.searchType && this.updateQueryObject(paramObj),
e ? (this.type = "dsl", this.dsl = !0, this.$(".typeFilterBtn,.tagBox,.termBox,.basicSaveSearch").hide(),
this.$(".advanceSaveSearch,.searchByText").show(), this.$(".searchText").text("Search By Query"),
this.ui.searchInput.attr("placeholder", 'Search By Query eg. where name="sales_fact"')) : (this.$(".typeFilterBtn,.tagBox,.termBox,.basicSaveSearch").show(),
this.$(".advanceSaveSearch,.searchByText").hide(), this.dsl = !1, this.type = "basic",
this.ui.searchInput.attr("placeholder", "Search By Text")), triggerUrl !== !1 && Utils.getUrlState.isSearchTab() && Utils.setUrl({
url: "#!/search/searchResult",
urlParams: _.extend(this.query[this.type], {
searchType: this.type,
dslChecked: this.ui.searchType.is(":checked")
}),
mergeBrowserUrl: !1,
trigger: !0,
updateTabState: !0
});
},
clearSearchData: function() {
this.filterTypeSelected = [], this.renderTypeTagList(), this.updateQueryObject(),
this.ui.typeLov.val("").trigger("change"), this.ui.tagLov.val("").trigger("change"),
this.ui.searchInput.val("");
var type = "basicSaveSearch";
"dsl" == this.type && (type = "advanceSaveSearch"), this.$("." + type + " .saveSearchList").find("li.active").removeClass("active"),
this.$("." + type + ' [data-id="saveBtn"]').attr("disabled", !0), this.dsl || (this.searchTableFilters.tagFilters = {},
this.searchTableFilters.entityFilters = {}), this.checkForButtonVisiblity();
}
});
return SearchLayoutView;
});