1 //<script type="text/javascript">
3 // Auto generated file - created by app.Builder.js- do not edit directly (at present!)
5 Pman.Tab.XtupleMetric = new Roo.XComponent({
6 part : ["Xtuple","Metric"],
7 order : '900-Pman.Tab.XtupleMetric',
10 name : "unnamed module",
21 activate : function() {
24 _this.grid.footer.onClick('first');
41 if (_this.panel.active) {
42 this.footer.onClick('first');
45 beforeedit : function (e)
47 var r = e.record.data.poitem_qty_received * 1;
50 Roo.MessageBox.alert("Error", "This item has been receipted");
54 var status = _this.form.findField('pohead_status').getValue();
57 Roo.MessageBox.alert("Error", "This PO has been closed");
64 autoExpandColumn : 'metric_value',
71 beforeload : function (_self, o){
72 o.params = o.params || {};
75 load : function (_self, records, options)
77 _this.grid.footer.updateSummary();
81 sortInfo : { field : 'poitem_linenumber', direction: 'ASC' },
87 url : baseURL + '/Xtuple/Roo/Poitem.php'
94 totalProperty : 'total',
113 var status = _this.form.findField('pohead_status').getValue();
116 Roo.MessageBox.alert("Error", "This PO has been closed");
120 var ct = _this.grid.ds.getCount();
122 var last = ct ? _this.grid.ds.getAt(ct-1).data.poitem_linenumber * 1 + 1 : 1;
124 var dt = _this.form.findField('pohead_orderdate').getValue();
126 var nr = _this.grid.ds.reader.newRow({
128 poitem_linenumber : last,
132 poitem_qty_ordered : 1,
136 _this.grid.stopEditing();
137 _this.grid.ds.insert(_this.grid.ds.getCount(), nr);
138 _this.grid.startEditing(_this.grid.ds.getCount()-1, 1);
141 cls : 'x-btn-text-icon',
143 icon : Roo.rootURL + 'images/default/dd/drop-add.gif'
151 var status = _this.form.findField('pohead_status').getValue();
154 Roo.MessageBox.alert("Error", "This PO has been closed");
158 var cs = _this.grid.getSelectionModel().getSelectedCell();
160 Roo.MessageBox.alert("Error", "Select a cell");
163 _this.grid.stopEditing();
164 var r = _this.grid.ds.getAt(cs[0]);
166 if(r.data.poitem_qty_received * 1 > 0){
167 Roo.MessageBox.alert("Error", "This item has been receipted");
172 _this.grid.ds.remove(r);
176 cls : 'x-btn-text-icon',
178 icon : rootURL + '/Pman/templates/images/trash.gif'
183 xtype: 'PagingToolbar',
186 emptyMsg : "No Item found",
188 updateSummary : function() {
192 url : baseURL + '/Xtuple/Roo/Poitem',
\r
195 _roo_office : _this.data.office ? _this.data.office : baseURL.split('/').pop().substr(0,2),
\r
197 poitem_pohead_id : _this.form.findField('pohead_id').getValue()
\r
199 success : function(d) {
201 f.displayEl.update(String.format(
\r
202 "{0} items | Total : {1} {2}",
\r
203 d.data[0].count_item,
\r
204 _this.form.findField('pohead_curr_id').el.dom.value,
\r
215 xtype: 'ColumnModel',
218 dataIndex : 'poitem_linenumber',
221 renderer : function(v) { return String.format('{0}', v); }
224 xtype: 'ColumnModel',
226 dataIndex : 'item_number',
227 header : 'Item code',
229 renderer : function(v) { return String.format('{0}', v); },
237 beforeselect : function (combo, record, index)
239 var ar = _this.grid.activeEditor.record;
242 ar.set('item_descrip1', record.data.itemsite_item_id_item_descrip1);
243 ar.set('poitem_itemsite_id', record.data.itemsite_id);
249 displayField : 'itemsite_item_id_item_number',
251 emptyText : "Select item",
252 forceSelection : true,
253 hiddenName : 'itemsite_item_id_item_number',
255 loadingText : "Searching...",
257 name : 'item_number',
259 qtip : "Select item",
260 queryParam : 'query[number]',
261 selectOnFocus : true,
262 tpl : '<div class="x-grid-cell-text x-btn button"><b>{itemsite_item_id_item_number}</b> - {itemsite_item_id_item_descrip1} </div>',
263 triggerAction : 'all',
265 valueField : 'item_number',
270 beforeload : function (_self, o){
271 o.params = o.params || {};
272 o.params.itemsite_posupply = 1;
276 sortInfo : { direction : 'ASC', field: 'item_number' },
281 url : baseURL + '/Roo/itemsite.php'
288 totalProperty : 'total',
289 fields : [{"name":"item_id","type":"int"},"item_number"]
296 xtype: 'ColumnModel',
298 dataIndex : 'item_descrip1',
299 header : 'Item description',
301 renderer : function(v) { return String.format('{0}', v); }
304 xtype: 'ColumnModel',
306 dataIndex : 'poitem_duedate',
309 renderer : function(v) { return String.format('{0}', v ? v.format('Y-m-d') : ''); }
312 xtype: 'ColumnModel',
315 dataIndex : 'poitem_qty_ordered',
318 renderer : function(v) { return String.format('{0}', v); },
323 xtype: 'NumberField',
325 allowDecimals : false,
326 decimalPrecision : 0,
328 style : 'text-align:right'
333 xtype: 'ColumnModel',
336 dataIndex : 'poitem_qty_received',
339 renderer : function(v,x,r) {
340 return String.format(
341 r.data.poitem_qty_ordered != (v-r.data.poitem_qty_returned) ? '<span style="color:red">{0}</span>': '{0}',
342 v - r.data.poitem_qty_returned);
346 xtype: 'ColumnModel',
349 dataIndex : 'poitem_qty_vouchered',
350 header : 'Vouchered',
352 renderer : function(v,x,r) {
353 return String.format(
354 r.data.poitem_qty_ordered != v ? '<span style="color:red">{0}</span>': '{0}',
359 xtype: 'ColumnModel',
362 dataIndex : 'poitem_unitprice',
363 header : 'Unit price',
365 renderer : function(v) { return String.format('{0}', (v || v == 0) ? parseFloat(v).toFixed(3) : ''); },
370 xtype: 'NumberField',
373 allowDecimals : false,
374 decimalPrecision : 0,
376 style : 'text-align:right'