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 || {};
77 sortInfo : { field : 'metric_name', direction: 'ASC' },
83 url : baseURL + '/Xtuple/Roo/Poitem.php'
90 totalProperty : 'total',
109 var status = _this.form.findField('pohead_status').getValue();
112 Roo.MessageBox.alert("Error", "This PO has been closed");
116 var ct = _this.grid.ds.getCount();
118 var last = ct ? _this.grid.ds.getAt(ct-1).data.poitem_linenumber * 1 + 1 : 1;
120 var dt = _this.form.findField('pohead_orderdate').getValue();
122 var nr = _this.grid.ds.reader.newRow({
124 poitem_linenumber : last,
128 poitem_qty_ordered : 1,
132 _this.grid.stopEditing();
133 _this.grid.ds.insert(_this.grid.ds.getCount(), nr);
134 _this.grid.startEditing(_this.grid.ds.getCount()-1, 1);
137 cls : 'x-btn-text-icon',
139 icon : Roo.rootURL + 'images/default/dd/drop-add.gif'
147 var status = _this.form.findField('pohead_status').getValue();
150 Roo.MessageBox.alert("Error", "This PO has been closed");
154 var cs = _this.grid.getSelectionModel().getSelectedCell();
156 Roo.MessageBox.alert("Error", "Select a cell");
159 _this.grid.stopEditing();
160 var r = _this.grid.ds.getAt(cs[0]);
162 if(r.data.poitem_qty_received * 1 > 0){
163 Roo.MessageBox.alert("Error", "This item has been receipted");
168 _this.grid.ds.remove(r);
172 cls : 'x-btn-text-icon',
174 icon : rootURL + '/Pman/templates/images/trash.gif'
179 xtype: 'PagingToolbar',
182 emptyMsg : "No Item found",
184 updateSummary : function() {
188 url : baseURL + '/Xtuple/Roo/Poitem',
\r
191 _roo_office : _this.data.office ? _this.data.office : baseURL.split('/').pop().substr(0,2),
\r
193 poitem_pohead_id : _this.form.findField('pohead_id').getValue()
\r
195 success : function(d) {
197 f.displayEl.update(String.format(
\r
198 "{0} items | Total : {1} {2}",
\r
199 d.data[0].count_item,
\r
200 _this.form.findField('pohead_curr_id').el.dom.value,
\r
211 xtype: 'ColumnModel',
214 dataIndex : 'poitem_linenumber',
217 renderer : function(v) { return String.format('{0}', v); }
220 xtype: 'ColumnModel',
222 dataIndex : 'item_number',
223 header : 'Item code',
225 renderer : function(v) { return String.format('{0}', v); },
233 beforeselect : function (combo, record, index)
235 var ar = _this.grid.activeEditor.record;
238 ar.set('item_descrip1', record.data.itemsite_item_id_item_descrip1);
239 ar.set('poitem_itemsite_id', record.data.itemsite_id);
245 displayField : 'itemsite_item_id_item_number',
247 emptyText : "Select item",
248 forceSelection : true,
249 hiddenName : 'itemsite_item_id_item_number',
251 loadingText : "Searching...",
253 name : 'item_number',
255 qtip : "Select item",
256 queryParam : 'query[number]',
257 selectOnFocus : true,
258 tpl : '<div class="x-grid-cell-text x-btn button"><b>{itemsite_item_id_item_number}</b> - {itemsite_item_id_item_descrip1} </div>',
259 triggerAction : 'all',
261 valueField : 'item_number',
266 beforeload : function (_self, o){
267 o.params = o.params || {};
268 o.params.itemsite_posupply = 1;
272 sortInfo : { direction : 'ASC', field: 'item_number' },
277 url : baseURL + '/Roo/itemsite.php'
284 totalProperty : 'total',
285 fields : [{"name":"item_id","type":"int"},"item_number"]
292 xtype: 'ColumnModel',
294 dataIndex : 'item_descrip1',
295 header : 'Item description',
297 renderer : function(v) { return String.format('{0}', v); }
300 xtype: 'ColumnModel',
302 dataIndex : 'poitem_duedate',
305 renderer : function(v) { return String.format('{0}', v ? v.format('Y-m-d') : ''); }
308 xtype: 'ColumnModel',
311 dataIndex : 'poitem_qty_ordered',
314 renderer : function(v) { return String.format('{0}', v); },
319 xtype: 'NumberField',
321 allowDecimals : false,
322 decimalPrecision : 0,
324 style : 'text-align:right'
329 xtype: 'ColumnModel',
332 dataIndex : 'poitem_qty_received',
335 renderer : function(v,x,r) {
336 return String.format(
337 r.data.poitem_qty_ordered != (v-r.data.poitem_qty_returned) ? '<span style="color:red">{0}</span>': '{0}',
338 v - r.data.poitem_qty_returned);
342 xtype: 'ColumnModel',
345 dataIndex : 'poitem_qty_vouchered',
346 header : 'Vouchered',
348 renderer : function(v,x,r) {
349 return String.format(
350 r.data.poitem_qty_ordered != v ? '<span style="color:red">{0}</span>': '{0}',
355 xtype: 'ColumnModel',
358 dataIndex : 'poitem_unitprice',
359 header : 'Unit price',
361 renderer : function(v) { return String.format('{0}', (v || v == 0) ? parseFloat(v).toFixed(3) : ''); },
366 xtype: 'NumberField',
369 allowDecimals : false,
370 decimalPrecision : 0,
372 style : 'text-align:right'