]> git.proxmox.com Git - pmg-gui.git/blame - js/ObjectGroupList.js
object groups: consistent add/edit/remove button
[pmg-gui.git] / js / ObjectGroupList.js
CommitLineData
56b0691b
DM
1Ext.define('pmg-object-group', {
2 extend: 'Ext.data.Model',
c87d46fb
TL
3 fields: ['id', 'name', 'info'],
4 idProperty: 'id',
56b0691b
DM
5});
6
7Ext.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 18Ext.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});