]>
git.proxmox.com Git - pmg-gui.git/blob - js/RuleConfiguration.js
1 Ext
.define('pmg-rule-list', {
2 extend
: 'Ext.data.Model',
5 { name
: 'active', type
: 'boolean' },
6 { name
: 'direction', type
: 'integer' },
7 { name
: 'priority', type
: 'integer' },
12 Ext
.define('PMG.RulesConfiguration', {
13 extend
: 'Ext.container.Container',
14 xtype
: 'pmgRuleConfiguration',
23 xclass
: 'Ext.app.ViewController',
25 selectedRuleChange: function(grid
, selected
, eOpts
) {
27 var infoPanel
= me
.lookupReference('infopanel');
30 if (selected
.length
> 0) {
31 baseurl
= '/config/ruledb/rules/' + selected
[0].data
.id
;
34 infoPanel
.getController().setBaseUrl(baseurl
);
37 editIconClick: function(gridView
, rowindex
, colindex
, column
, e
, record
) {
39 me
.showEditWindow(gridView
, record
);
42 showEditWindow: function(gridView
, record
) {
44 var win
= Ext
.create('PMG.RuleEditor', {
45 url
: '/api2/extjs/config/ruledb/rules/' + record
.data
.id
+ '/config',
48 gridView
.getStore().load();
56 toggleIconClick: function(gridView
, rowindex
, colindex
, column
, e
, record
) {
58 Proxmox
.Utils
.API2Request({
59 url
: '/config/ruledb/rules/' + record
.data
.id
+ '/config',
61 active
: record
.data
.active
? 0 : 1,
64 callback: function() {
65 gridView
.getStore().load();
67 failure: function(response
, opts
) {
68 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
);
75 me
.lookupReference('rulegrid').getStore().load();
80 var win
= Ext
.create('PMG.RuleEditor', {
81 url
: '/api2/extjs/config/ruledb/rules/',
86 me
.lookupReference('rulegrid').getStore().load();
94 onFactoryDefaults: function() {
99 gettext('Reset rule database to factory defaults?'),
101 if (button
!== 'yes') {
104 var url
= '/config/ruledb';
105 Proxmox
.Utils
.API2Request({
106 url
: '/config/ruledb',
108 waitMsgTarget
: me
.getView(),
109 callback: function() {
112 failure: function(response
, opts
) {
113 Ext
.Msg
.alert(gettext('Error'), response
.htmlStatus
);
120 init: function(view
) {
121 var grid
= this.lookupReference('rulegrid');
122 Proxmox
.Utils
.monStoreErrors(grid
, grid
.getStore(), true);
126 'grid[reference=rulegrid]': {
127 itemdblclick
: 'showEditWindow',
128 selectionchange
: 'selectedRuleChange',
130 'button[reference=addButton]': {
138 selectedRule
: undefined,
139 baseUrl
: '/config/ruledb/rules',
148 reference
: 'rulegrid',
152 selection
: '{selectedRule}',
161 text
: gettext('Add'),
162 iconCls
: 'fa fa-plus-circle',
163 reference
: 'addButton',
166 xtype
: 'proxmoxStdRemoveButton',
167 text
: gettext('Remove'),
168 iconCls
: 'fa fa-minus-circle',
169 reference
: 'removeButton',
171 getRecordName: function(rec
) { return rec
.data
.name
; },
173 baseurl
: '{baseUrl}',
178 text
: gettext('Factory Defaults'),
179 handler
: 'onFactoryDefaults',
185 getRowClass: function(record
, rowIndex
) {
186 return record
.get('active') ? 'enabled' : 'disabled';
192 model
: 'pmg-rule-list',
193 reference
: 'rulesStore',
196 url
: '/api2/json/config/ruledb/rules',
200 property
: 'priority',
209 sortableColumns
: false,
223 dataIndex
: 'priority',
227 dataIndex
: 'direction',
228 renderer
: PMG
.Utils
.format_rule_direction
,
232 xtype
: 'actioncolumn',
237 iconCls
: 'fa fa-fw fa-pencil',
239 handler
: 'editIconClick',
242 getClass: function(val
, meta
, rec
) {
243 return 'fa fa-fw fa-' + (rec
.get('active') ? 'toggle-on' : 'toggle-off');
245 getTip: function(val
, meta
, rec
) {
246 return rec
.get('active') ? 'Deactivate' : 'Activate';
248 handler
: 'toggleIconClick',
256 reference
: 'infopanel',
257 xtype
: 'pmgRuleInfo',