]> git.evergreen-ils.org Git - working/Evergreen.git/blob - Open-ILS/web/js/dojo/openils/widget/EditPane.js
fixed table ref
[working/Evergreen.git] / Open-ILS / web / js / dojo / openils / widget / EditPane.js
1 if(!dojo._hasResource['openils.widget.EditPane']) {
2     dojo.provide('openils.widget.EditPane');
3     dojo.require('openils.widget.AutoWidget');
4     dojo.require('openils.widget.AutoFieldWidget');
5     dojo.require('fieldmapper.Fieldmapper');
6     dojo.require('dijit.layout.ContentPane');
7     dojo.require('openils.Util');
8     dojo.require('openils.PermaCrud');
9
10     dojo.declare(
11         'openils.widget.EditPane',
12         [dijit.layout.ContentPane, openils.widget.AutoWidget],
13         {
14             mode : 'update',
15             onPostSubmit : null, // apply callback
16             onCancel : null, // cancel callback
17             hideActionButtons : false,
18
19             constructor : function(args) {
20                 this.fieldList = [];
21                 for(var k in args)
22                     this[k] = args[k];
23             },
24
25             /**
26              * Builds a basic table of key / value pairs.  Keys are IDL display labels.
27              * Values are dijit's, when values set
28              */
29             startup : function() {
30                 this.inherited(arguments);
31                 this.initAutoEnv();
32                 if(this.readOnly)
33                     this.hideActionButtons = true;
34
35                 var table = this.table = document.createElement('table');
36                 var tbody = document.createElement('tbody');
37                 this.domNode.appendChild(table);
38                 table.appendChild(tbody);
39
40                 this.limitPerms = [];
41                 if(this.fmIDL.permacrud && this.fmIDL.permacrud[this.mode])
42                     this.limitPerms = this.fmIDL.permacrud[this.mode].perms;
43
44                 if(!this.overrideWidgets)
45                     this.overrideWidgets = {};
46
47                 for(var f in this.sortedFieldList) {
48                     var field = this.sortedFieldList[f];
49                     if(!field || field.virtual) continue;
50
51                     if(field.name == this.fmIDL.pkey && this.mode == 'create' && this.fmIDL.pkey_sequence)
52                         continue; /* don't show auto-generated fields on create */
53
54                     var row = document.createElement('tr');
55                     var nameTd = document.createElement('td');
56                     var valTd = document.createElement('td');
57                     var valSpan = document.createElement('span');
58                     valTd.appendChild(valSpan);
59
60
61                     nameTd.appendChild(document.createTextNode(field.label));
62                     row.setAttribute('fmfield', field.name);
63                     row.appendChild(nameTd);
64                     row.appendChild(valTd);
65                     tbody.appendChild(row);
66
67                     var widget = new openils.widget.AutoFieldWidget({
68                         idlField : field, 
69                         fmObject : this.fmObject,
70                         fmClass : this.fmClass,
71                         parentNode : valSpan,
72                         orgLimitPerms : this.limitPerms,
73                         readOnly : this.readOnly,
74                         widget : this.overrideWidgets[field.name]
75                     });
76
77                     widget.build();
78                     this.fieldList.push({name:field.name, widget:widget});
79                     //this.applySaveOnEnter(widget);
80                 }
81                 if(!this.hideActionButtons)
82                     this.buildActionButtons(tbody);
83
84                 openils.Util.addCSSClass(table, 'oils-fm-edit-pane');
85             },
86
87             applySaveOnEnter : function(widget) {
88                 var self = this;
89                 dojo.connect(this, 'onKeyDown',
90                     function(e) {
91                         if(e.keyCode == dojo.keys.ENTER) 
92                             self.performAutoEditAction();
93                     }
94                 );
95             },
96
97             buildActionButtons : function(tbody) {
98                 var row = document.createElement('tr');
99                 var cancelTd = document.createElement('td');
100                 var applyTd = document.createElement('td');
101                 var cancelSpan = document.createElement('span');
102                 var applySpan = document.createElement('span');
103                 row.appendChild(cancelTd);
104                 row.appendChild(applyTd);
105                 cancelTd.appendChild(cancelSpan);
106                 applyTd.appendChild(applySpan);
107                 tbody.appendChild(row);
108
109                 var self = this;
110                 new dijit.form.Button({
111                     label:'Cancel', // XXX
112                     onClick : this.onCancel
113                 }, cancelSpan);
114
115                 new dijit.form.Button({
116                     label:'Save',  // XXX
117                     onClick: function() {self.performAutoEditAction();}
118                 }, applySpan);
119             },
120
121             getFields : function() {
122                 return this.fieldList.map(function(a) { return a.name });
123             },
124
125             getFieldValue : function(field) {
126                 for(var i in this.fieldList) {
127                     if(field == this.fieldList[i].name)
128                         return this.fieldList[i].widget.getFormattedValue();
129                 }
130             },
131
132             performAutoEditAction : function() {
133                 var self = this;
134                 self.performEditAction({
135                     oncomplete:function(r) {
136                         if(self.onPostSubmit)
137                             self.onPostSubmit(r);
138                     }
139                 });
140             },
141
142             performEditAction : function(opts) {
143                 var pcrud = new openils.PermaCrud();
144                 var fields = this.getFields();
145                 if(this.mode == 'create')
146                     this.fmObject = new fieldmapper[this.fmClass]();
147                 for(var idx in fields)  
148                     this.fmObject[fields[idx]](this.getFieldValue(fields[idx]));
149                 if(this.mode == 'create' && this.fmIDL.pkey_sequence)
150                     this.fmObject[this.fmIDL.pkey](null);
151                 pcrud[this.mode](this.fmObject, opts);
152             }
153         }
154     );
155 }
156