widgets-bundle.controller.js
Home
/
ui /
src /
app /
widget /
widgets-bundle.controller.js
import addWidgetsBundleTemplate from './add-widgets-bundle.tpl.html';
import widgetsBundleCard from './widgets-bundle-card.tpl.html';
export default function WidgetsBundleController(widgetService, userService, $state, $stateParams, $filter, $translate, types) {
var widgetsBundleActionsList = [
{
onAction: function ($event, item) {
vm.grid.openItem($event, item);
},
name: function() { return $translate.instant('widgets-bundle.details') },
details: function() { return $translate.instant('widgets-bundle.widgets-bundle-details') },
icon: "edit"
},
{
onAction: function ($event, item) {
vm.grid.deleteItem($event, item);
},
name: function() { return $translate.instant('action.delete') },
details: function() { return $translate.instant('widgets-bundle.delete') },
icon: "delete",
isEnabled: isWidgetsBundleEditable
}
];
var vm = this;
vm.types = types;
vm.widgetsBundleGridConfig = {
refreshParamsFunc: null,
deleteItemTitleFunc: deleteWidgetsBundleTitle,
deleteItemContentFunc: deleteWidgetsBundleText,
deleteItemsTitleFunc: deleteWidgetsBundlesTitle,
deleteItemsActionTitleFunc: deleteWidgetsBundlesActionTitle,
deleteItemsContentFunc: deleteWidgetsBundlesText,
fetchItemsFunc: fetchWidgetsBundles,
saveItemFunc: saveWidgetsBundle,
clickItemFunc: openWidgetsBundle,
deleteItemFunc: deleteWidgetsBundle,
getItemTitleFunc: getWidgetsBundleTitle,
itemCardTemplateUrl: widgetsBundleCard,
parentCtl: vm,
actionsList: widgetsBundleActionsList,
onGridInited: gridInited,
addItemTemplateUrl: addWidgetsBundleTemplate,
addItemText: function() { return $translate.instant('widgets-bundle.add-widgets-bundle-text') },
noItemsText: function() { return $translate.instant('widgets-bundle.no-widgets-bundles-text') },
itemDetailsText: function() { return $translate.instant('widgets-bundle.widgets-bundle-details') },
isSelectionEnabled: isWidgetsBundleEditable,
isDetailsReadOnly: function(widgetsBundle) {
return !isWidgetsBundleEditable(widgetsBundle);
}
};
if (angular.isDefined($stateParams.items) && $stateParams.items !== null) {
vm.widgetsBundleGridConfig.items = $stateParams.items;
}
if (angular.isDefined($stateParams.topIndex) && $stateParams.topIndex > 0) {
vm.widgetsBundleGridConfig.topIndex = $stateParams.topIndex;
}
function deleteWidgetsBundleTitle(widgetsBundle) {
return $translate.instant('widgets-bundle.delete-widgets-bundle-title', {widgetsBundleTitle: widgetsBundle.title});
}
function deleteWidgetsBundleText() {
return $translate.instant('widgets-bundle.delete-widgets-bundle-text');
}
function deleteWidgetsBundlesTitle(selectedCount) {
return $translate.instant('widgets-bundle.delete-widgets-bundles-title', {count: selectedCount}, 'messageformat');
}
function deleteWidgetsBundlesActionTitle(selectedCount) {
return $translate.instant('widgets-bundle.delete-widgets-bundles-action-title', {count: selectedCount}, 'messageformat');
}
function deleteWidgetsBundlesText() {
return $translate.instant('widgets-bundle.delete-widgets-bundles-text');
}
function gridInited(grid) {
vm.grid = grid;
}
function fetchWidgetsBundles(pageLink) {
return widgetService.getAllWidgetsBundlesByPageLink(pageLink);
}
function saveWidgetsBundle(widgetsBundle) {
return widgetService.saveWidgetsBundle(widgetsBundle);
}
function deleteWidgetsBundle(widgetsBundleId) {
return widgetService.deleteWidgetsBundle(widgetsBundleId);
}
function getWidgetsBundleTitle(widgetsBundle) {
return widgetsBundle ? widgetsBundle.title : '';
}
function isWidgetsBundleEditable(widgetsBundle) {
if (userService.getAuthority() === 'TENANT_ADMIN') {
return widgetsBundle && widgetsBundle.tenantId.id != types.id.nullUid;
} else {
return userService.getAuthority() === 'SYS_ADMIN';
}
}
function openWidgetsBundle($event, widgetsBundle) {
if ($event) {
$event.stopPropagation();
}
$state.go('home.widgets-bundles.widget-types', {widgetsBundleId: widgetsBundle.id.id});
}
}