]>
Commit | Line | Data |
---|---|---|
56b0691b DM |
1 | Ext.define('pmg-object-group', { |
2 | extend: 'Ext.data.Model', | |
c87d46fb TL |
3 | fields: ['id', 'name', 'info'], |
4 | idProperty: 'id', | |
56b0691b DM |
5 | }); |
6 | ||
7 | Ext.define('pmg-object-list', { | |
8 | extend: 'Ext.data.Model', | |
9 | fields: [ | |
10 | 'id', 'descr', | |
11 | { name: 'otype', type: 'integer' }, | |
c87d46fb | 12 | { name: 'receivertest', type: 'boolean' }, |
56b0691b | 13 | ], |
c87d46fb | 14 | idProperty: 'id', |
56b0691b DM |
15 | }); |
16 | ||
17 | ||
a43acf2e | 18 | Ext.define('PMG.ObjectGroupList', { |
56b0691b | 19 | extend: 'Ext.grid.GridPanel', |
a43acf2e | 20 | alias: ['widget.pmgObjectGroupList'], |
56b0691b | 21 | |
a43acf2e DM |
22 | ogclass: undefined, // 'who', 'when', 'what' |
23 | ||
24 | subject: 'Object Group List', // please overwrite | |
56b0691b | 25 | |
4475914f DM |
26 | baseurl: undefined, |
27 | ||
ad834b6f DM |
28 | enableButtons: true, |
29 | ||
4475914f DM |
30 | inputItems: [ |
31 | { | |
32 | xtype: 'textfield', | |
33 | name: 'name', | |
f5de8682 | 34 | allowBlank: false, |
c87d46fb | 35 | fieldLabel: gettext('Name'), |
4475914f DM |
36 | }, |
37 | { | |
38 | xtype: 'textareafield', | |
39 | name: 'info', | |
c87d46fb TL |
40 | fieldLabel: gettext("Description"), |
41 | }, | |
4475914f DM |
42 | ], |
43 | ||
44 | reload: function() { | |
45 | var me = this; | |
46 | ||
ad834b6f | 47 | me.store.load(); |
4475914f DM |
48 | }, |
49 | ||
50 | run_editor: function() { | |
51 | var me = this; | |
52 | ||
53 | var rec = me.selModel.getSelection()[0]; | |
54 | if (!rec) { | |
55 | return; | |
56 | } | |
57 | ||
58 | var config = { | |
59 | url: "/api2/extjs" + me.baseurl +'/' + rec.data.id + '/config', | |
573a6e8b | 60 | onlineHelp: 'chapter_mailfilter', |
4475914f DM |
61 | method: 'PUT', |
62 | subject: me.subject, | |
63 | width: 400, | |
c87d46fb | 64 | items: me.inputItems, |
4475914f DM |
65 | }; |
66 | ||
67 | var win = Ext.createWidget('proxmoxWindowEdit', config); | |
68 | ||
69 | win.load(); | |
70 | win.on('destroy', me.reload, me); | |
71 | win.show(); | |
72 | }, | |
73 | ||
c87d46fb | 74 | initComponent: function() { |
56b0691b DM |
75 | var me = this; |
76 | ||
a43acf2e DM |
77 | if (!me.ogclass) { |
78 | throw "ogclass not initialized"; | |
79 | } | |
80 | ||
4475914f DM |
81 | me.baseurl = "/config/ruledb/" + me.ogclass; |
82 | ||
83 | me.store = new Ext.data.Store({ | |
56b0691b DM |
84 | model: 'pmg-object-group', |
85 | proxy: { | |
86 | type: 'proxmox', | |
c87d46fb | 87 | url: "/api2/json" + me.baseurl, |
56b0691b DM |
88 | }, |
89 | sorters: { | |
90 | property: 'name', | |
18722987 | 91 | direction: 'ASC', |
c87d46fb | 92 | }, |
56b0691b DM |
93 | }); |
94 | ||
56b0691b DM |
95 | me.selModel = Ext.create('Ext.selection.RowModel', {}); |
96 | ||
56b0691b | 97 | var tbar = [ |
56b0691b DM |
98 | { |
99 | text: gettext('Create'), | |
100 | handler: function() { | |
ce33f608 | 101 | Ext.createWidget('proxmoxWindowEdit', { |
56b0691b | 102 | method: 'POST', |
ce33f608 | 103 | url: `/api2/extjs${me.baseurl}`, |
573a6e8b | 104 | onlineHelp: 'chapter_mailfilter', |
18b5b6ad | 105 | isCreate: true, |
a43acf2e | 106 | width: 400, |
56b0691b | 107 | subject: me.subject, |
c87d46fb | 108 | items: me.inputItems, |
ce33f608 TL |
109 | autoShow: true, |
110 | listeners: { | |
111 | destroy: () => me.reload(), | |
112 | }, | |
113 | }); | |
c87d46fb | 114 | }, |
56b0691b | 115 | }, |
ce33f608 TL |
116 | '-', |
117 | { | |
118 | xtype: 'proxmoxButton', | |
119 | text: gettext('Edit'), | |
120 | disabled: true, | |
121 | selModel: me.selModel, | |
122 | handler: () => me.run_editor(), | |
123 | }, | |
124 | { | |
125 | xtype: 'proxmoxStdRemoveButton', | |
126 | selModel: me.selModel, | |
127 | baseurl: me.baseurl, | |
128 | callback: () => me.reload(), | |
129 | getRecordName: rec => rec.data.name, | |
130 | waitMsgTarget: me, | |
131 | }, | |
56b0691b DM |
132 | ]; |
133 | ||
2f8fe1a3 | 134 | Proxmox.Utils.monStoreErrors(me, me.store, true); |
56b0691b | 135 | |
ad834b6f DM |
136 | if (me.enableButtons) { |
137 | me.tbar = tbar; | |
138 | } | |
139 | ||
56b0691b | 140 | Ext.apply(me, { |
56b0691b DM |
141 | columns: [ |
142 | { | |
143 | header: gettext('Name'), | |
144 | sortable: true, | |
145 | flex: 1, | |
146 | dataIndex: 'name', | |
c87d46fb TL |
147 | renderer: Ext.String.htmlEncode, |
148 | }, | |
56b0691b DM |
149 | ], |
150 | listeners: { | |
ad834b6f DM |
151 | itemdblclick: function() { |
152 | if (me.enableButtons) { | |
153 | me.run_editor(); | |
154 | } | |
155 | }, | |
c87d46fb TL |
156 | activate: function() { me.reload(); }, |
157 | }, | |
56b0691b DM |
158 | }); |
159 | ||
160 | me.callParent(); | |
161 | ||
4475914f | 162 | me.reload(); // initial load |
c87d46fb | 163 | }, |
56b0691b | 164 | }); |