-
Notifications
You must be signed in to change notification settings - Fork 90
/
Copy pathtoolbar-component.js
106 lines (89 loc) · 3.06 KB
/
toolbar-component.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
angular.module('patternfly.toolbars').component('pfToolbar', {
bindings: {
config: '='
},
transclude: {
'actions': '?'
},
templateUrl: 'toolbars/toolbar.html',
controller: function () {
'use strict';
var ctrl = this;
var prevConfig;
ctrl.$onInit = function () {
if (angular.isDefined(ctrl.config.sortConfig) && angular.isUndefined(ctrl.config.sortConfig.show)) {
// default to true
ctrl.config.sortConfig.show = true;
}
angular.extend(ctrl, {
viewSelected: viewSelected,
isViewSelected: isViewSelected,
isTableViewSelected: isTableViewSelected,
checkViewDisabled: checkViewDisabled,
addFilter: addFilter,
handleAction: handleAction
});
};
ctrl.$onChanges = function () {
setupConfig ();
};
ctrl.$doCheck = function () {
// do a deep compare on config
if (!angular.equals(ctrl.config, prevConfig)) {
setupConfig();
}
};
function setupConfig () {
prevConfig = angular.copy(ctrl.config);
if (ctrl.config && ctrl.config.viewsConfig && ctrl.config.viewsConfig.views) {
ctrl.config.viewsConfig.viewsList = angular.copy(ctrl.config.viewsConfig.views);
if (!ctrl.config.viewsConfig.currentView) {
ctrl.config.viewsConfig.currentView = ctrl.config.viewsConfig.viewsList[0].id;
}
}
}
function viewSelected (viewId) {
ctrl.config.viewsConfig.currentView = viewId;
if (ctrl.config.viewsConfig.onViewSelect && !ctrl.checkViewDisabled(viewId)) {
ctrl.config.viewsConfig.onViewSelect(viewId);
}
}
function isViewSelected (viewId) {
return ctrl.config.viewsConfig && (ctrl.config.viewsConfig.currentView === viewId);
}
function isTableViewSelected () {
return ctrl.config.viewsConfig ? (ctrl.config.viewsConfig.currentView === 'tableView') : ctrl.config.isTableView;
}
function checkViewDisabled (view) {
return ctrl.config.viewsConfig.checkViewDisabled && ctrl.config.viewsConfig.checkViewDisabled(view);
}
function filterExists (filter) {
var foundFilter = _.find(ctrl.config.filterConfig.appliedFilters, {title: filter.title, value: filter.value});
return foundFilter !== undefined;
}
function enforceSingleSelect (filter) {
_.remove(ctrl.config.filterConfig.appliedFilters, {title: filter.title});
}
function addFilter (field, value) {
var newFilter = {
id: field.id,
title: field.title,
value: value
};
if (!filterExists(newFilter)) {
if (field.filterType === 'select') {
enforceSingleSelect(newFilter);
}
ctrl.config.filterConfig.appliedFilters.push(newFilter);
if (ctrl.config.filterConfig.onFilterChange) {
ctrl.config.filterConfig.onFilterChange(ctrl.config.filterConfig.appliedFilters);
}
}
}
function handleAction (action) {
if (action && action.actionFn && (action.isDisabled !== true)) {
action.actionFn(action);
}
}
}
});