import addRuleTemplate from './add-rule.tpl.html';
import ruleCard from './rule-card.tpl.html';
export default function RuleController(ruleService, userService, $state, $stateParams, $filter, $translate, types) {
var ruleActionsList = [
{
onAction: function ($event, item) {
activateRule($event, item);
},
name: function() { return $translate.instant('action.activate') },
details: function() { return $translate.instant('rule.activate') },
icon: "play_arrow",
isEnabled: function(rule) {
return isRuleEditable(rule) && rule && rule.state === 'SUSPENDED';
}
},
{
onAction: function ($event, item) {
suspendRule($event, item);
},
name: function() { return $translate.instant('action.suspend') },
details: function() { return $translate.instant('rule.suspend') },
icon: "pause",
isEnabled: function(rule) {
return isRuleEditable(rule) && rule.state === 'ACTIVE';
}
},
{
onAction: function ($event, item) {
vm.grid.deleteItem($event, item);
},
name: function() { return $translate.instant('action.delete') },
details: function() { return $translate.instant('rule.delete') },
icon: "delete",
isEnabled: isRuleEditable
}
];
var vm = this;
vm.types = types;
vm.ruleGridConfig = {
refreshParamsFunc: null,
deleteItemTitleFunc: deleteRuleTitle,
deleteItemContentFunc: deleteRuleText,
deleteItemsTitleFunc: deleteRulesTitle,
deleteItemsActionTitleFunc: deleteRulesActionTitle,
deleteItemsContentFunc: deleteRulesText,
fetchItemsFunc: fetchRules,
saveItemFunc: saveRule,
deleteItemFunc: deleteRule,
getItemTitleFunc: getRuleTitle,
itemCardTemplateUrl: ruleCard,
parentCtl: vm,
actionsList: ruleActionsList,
onGridInited: gridInited,
addItemTemplateUrl: addRuleTemplate,
addItemText: function() { return $translate.instant('rule.add-rule-text') },
noItemsText: function() { return $translate.instant('rule.no-rules-text') },
itemDetailsText: function() { return $translate.instant('rule.rule-details') },
isSelectionEnabled: isRuleEditable,
isDetailsReadOnly: function(rule) {
return !isRuleEditable(rule);
}
};
if (angular.isDefined($stateParams.items) && $stateParams.items !== null) {
vm.ruleGridConfig.items = $stateParams.items;
}
if (angular.isDefined($stateParams.topIndex) && $stateParams.topIndex > 0) {
vm.ruleGridConfig.topIndex = $stateParams.topIndex;
}
vm.activateRule = activateRule;
vm.suspendRule = suspendRule;
function deleteRuleTitle(rule) {
return $translate.instant('rule.delete-rule-title', {ruleName: rule.name});
}
function deleteRuleText() {
return $translate.instant('rule.delete-rule-text');
}
function deleteRulesTitle(selectedCount) {
return $translate.instant('rule.delete-rules-title', {count: selectedCount}, 'messageformat');
}
function deleteRulesActionTitle(selectedCount) {
return $translate.instant('rule.delete-rules-action-title', {count: selectedCount}, 'messageformat');
}
function deleteRulesText() {
return $translate.instant('rule.delete-rules-text');
}
function gridInited(grid) {
vm.grid = grid;
}
function fetchRules(pageLink) {
return ruleService.getAllRules(pageLink);
}
function saveRule(rule) {
return ruleService.saveRule(rule);
}
function deleteRule(ruleId) {
return ruleService.deleteRule(ruleId);
}
function getRuleTitle(rule) {
return rule ? rule.name : '';
}
function isRuleEditable(rule) {
if (userService.getAuthority() === 'TENANT_ADMIN') {
return rule && rule.tenantId.id != types.id.nullUid;
} else {
return userService.getAuthority() === 'SYS_ADMIN';
}
}
function activateRule(event, rule) {
ruleService.activateRule(rule.id.id).then(function () {
vm.grid.refreshList();
}, function () {
});
}
function suspendRule(event, rule) {
ruleService.suspendRule(rule.id.id).then(function () {
vm.grid.refreshList();
}, function () {
});
}
}