1 //<script type="text/javascript">
3 // Auto generated file - created by app.Builder.js- do not edit directly (at present!)
5 Roo.namespace('Editor.Roo');
7 Editor.Roo.LayoutDialog = new Roo.XComponent({
10 'b021df6aac4654c454f46c77646e745f' :"Label",
11 '793548e77e782c209a78ed67f255b5e2' :"Display Field",
12 '0b6519e9da7898cdc668f6016026e71d' :"To JSON",
13 '4ce58cbe362a5d7b156992a496d55bf3' :"Database Column",
14 '189efd19c4153526994a6d7ea5f6f068' :"Field Type",
15 '2f616612593df62aeed112de4f03110e' :"Edit a Grid",
16 '0ccc2bf3fb98387c23b6ca5500244d6e' :"Use ",
17 'c671c787b49f50a3ace9fdc5bd597825' :"core_enum",
18 '32954654ac8fe66a1d09be19001de2d4' :"Width",
19 'a1fa27779242b4902f7ae3bdd5c6d508' :"Type",
20 '6e7376dca68a2386a8737944196ab491' :"Create / Edit Grid",
21 'f541774a08fc687f6e2016c77a6ebca5' :"Load Data"
24 part : ["Editors", "LayoutDialog" ],
25 order : '001-Editor.Roo.LayoutDialog',
28 name : "unnamed module",
40 [ 1, 'test', 'test', 110 ]
66 '|xns' : 'Roo.Toolbar',
67 text : _this._strings['2f616612593df62aeed112de4f03110e'],
72 '|xns' : 'Roo.Toolbar',
77 '|xns' : 'Roo.Toolbar',
78 text : _this._strings['f541774a08fc687f6e2016c77a6ebca5'],
82 click : function (_self, e)
84 Roo.log(_this.ftype_combo);
87 "Field": "manage_scale_id",
93 "relates_to_table": "core_enum",
94 "relates_to_col": "id",
95 "relates_to_schema": {
102 "Extra": "auto_increment"
106 "Type": "varchar(32)",
114 "Type": "varchar(255)",
145 "Field": "display_name",
153 "Field": "is_system_enum",
163 "Field": "person_type",
171 "Field": "employer_name",
179 "Field": "birth_date",
183 "Default": "0000-00-00",
186 "employ_start_date": {
187 "Field": "employ_start_date",
191 "Default": "0000-00-00",
195 "Field": "employ_end_date",
199 "Default": "0000-00-00",
202 "hide_same_employer": {
203 "Field": "hide_same_employer",
211 "Field": "salary_currency",
212 "Type": "varchar(256)",
219 "Field": "quota_currency",
220 "Type": "varchar(256)",
227 "Field": "created_dt",
231 "Default": "0000-00-00 00:00:00",
235 "Field": "updated_dt",
239 "Default": "0000-00-00 00:00:00",
244 Roo.log('debuging...');
245 _this.panel.loadData(data);
251 '|xns' : 'Roo.Toolbar',
252 text : _this._strings['0b6519e9da7898cdc668f6016026e71d'],
256 click : function (_self, e)
259 Roo.log('Converting to JSON...');
260 _this.panel.toJson();
269 autoExpandColumn : 'title',
273 xtype : 'EditorGrid',
277 dataIndex : 'active',
278 header : _this._strings['0ccc2bf3fb98387c23b6ca5500244d6e'],
279 renderer : function(v) {
280 var state = v *1 > 0 ? '-checked' : '';
282 return '<img class="x-grid-check-icon' + state + '" src="' + Roo.BLANK_IMAGE_URL + '"/>';
287 xtype : 'ColumnModel'
291 dataIndex : 'dataIndex',
292 header : _this._strings['4ce58cbe362a5d7b156992a496d55bf3'],
293 renderer : function(v) { return String.format('{0}', v); },
296 xtype : 'ColumnModel'
301 header : _this._strings['a1fa27779242b4902f7ae3bdd5c6d508'],
302 renderer : function(v) { return String.format('{0}', v); },
305 xtype : 'ColumnModel'
316 xtype : 'GridEditor',
324 header : _this._strings['b021df6aac4654c454f46c77646e745f'],
325 renderer : function(v) { return String.format('{0}', v); },
328 xtype : 'ColumnModel',
340 [ 'ComboBox', "ComboBox"],
341 [ 'TextField' , "TextField"],
342 [ 'NumberField', "NumberField"],
343 [ 'TextArea', "TextArea"],
344 [ 'HtmlEditor', "HtmlEditor"],
345 [ 'Hidden', "Hidden"],
346 [ 'DateField', "DateField"],
347 [ 'Checkbox', "Checkbox"]
350 fields : [ 'ftype', 'fname'],
352 xtype : 'SimpleStore'
356 displayField : 'fname',
358 hiddenName : 'status',
362 triggerAction : 'all',
363 valueField : 'ftype',
374 xtype : 'GridEditor',
382 header : _this._strings['189efd19c4153526994a6d7ea5f6f068'],
383 renderer : function(v) { return String.format('{0}', v); },
386 xtype : 'ColumnModel',
400 fields : [ 'dfield'],
402 xtype : 'SimpleStore'
406 displayField : 'dfield',
408 hiddenName : 'status',
411 name : 'display_field',
412 triggerAction : 'all',
413 valueField : 'dfield',
424 xtype : 'GridEditor',
431 dataIndex : 'display_field',
432 header : _this._strings['793548e77e782c209a78ed67f255b5e2'],
433 renderer : function(v) { return String.format('{0}', v); },
436 xtype : 'ColumnModel',
446 decimalPrecision : 0,
448 xtype : 'NumberField'
452 xtype : 'GridEditor',
460 header : _this._strings['32954654ac8fe66a1d09be19001de2d4'],
461 renderer : function(v) { return String.format('{0}', v); },
464 xtype : 'ColumnModel',
472 beforeedit : function (e)
474 Roo.log('before edit!!!');
477 if(e.field != 'display_field'){
481 _this.grid.colModel.getCellEditor(e.column, e.row).field.store.loadData(e.record.data.relates_to_schema);
483 cellclick : function (_self, rowIndex, columnIndex, e)
486 var di = this.colModel.getDataIndex(columnIndex);
487 if (di != 'active') {
491 var rec = _this.grid.ds.getAt(rowIndex);
493 rec.set('active', rec.data.active * 1 ? 0 : 1);
501 //_this.dialog = Pman.Dialog.FILL_IN
504 rowdblclick : function (_self, rowIndex, e)
506 if (!_this.dialog) return;
519 loadData : function(data) {
521 //alert("IPC:TEST:" + JSON.stringify(data,null,4));
523 var fields = _this.grid.dataSource.reader.recordType.prototype.fields;
528 for (var k in data) {
530 var has_s = typeof(r.relates_to_schema) != 'undefined';
532 var rt = '', rc = '', rs = [];
535 for (var kk in r.relates_to_schema) {
536 var rr = r.relates_to_schema[kk];
538 rt = r.relates_to_table;
539 rc = r.relates_to_col;
553 display_field : rc, //r.Field + '_display_name',
554 relates_to_table : rt,
556 relates_to_schema : rs
565 for (var kk in r.relates_to_schema) {
566 var rr = r.relates_to_schema[kk];
567 if (rr.Field == r.relates_to_col) {
573 dataIndex : r.Field + '_'+ rr.Field,
585 Roo.each(d, function(dd){
589 for(var j = 0; j < fields.length; j++){
590 var f = fields.items[j];
592 if(dd.hasOwnProperty(f.name)){
604 //alert("IPC:TEST:" + JSON.stringify(ar));
605 this.grid.dataSource.loadData(ar);
608 tableName : 'core_enum',
609 title : _this._strings['c671c787b49f50a3ace9fdc5bd597825'],
610 title : _this._strings['c671c787b49f50a3ace9fdc5bd597825'],
613 // convert the selected cells into a BJS data ready to send back to the UI..
616 this.firstTxtCol = "XXX";
621 var formElements = [];
622 this.grid.dataSource.each(function(rec) {
623 if (!rec.data.active) {
628 fieldLabel : rec.data.title,
629 name : rec.data.dataIndex,
630 width : r.data.width,
632 xtype : rec.data.ftype
634 if (xtype == 'DateField') {
640 if (xtype == 'TextArea') {
644 if (xtype == 'Hidden') {
645 delete el.fieldLabel;
648 if (xtype == 'Combobox') {
651 el.queryParam = 'query[' + rec.data.display_field + ']';// SET WHEN USED
653 el.hiddenName = rec.data.dataIndex // SET WHEN USED eg. project_id
654 el.name = rec.data.dataIndex + '_' + rec.data.display_field; // SET WHEN USED eg. project_id_name
656 el.displayField = rec.data.display_field // SET WHEN USED eg. project_id
657 el.valueField = rec.data.relates_to_col
659 el.tpl = '<div class="x-grid-cell-text x-btn button"><b>{' + rec.data.display_field +'}</b> </div>'; // SET WHEN USED
669 '|sortInfo' : '{ direction : \'ASC\', field: \'id\' }',
671 '|beforeload' : 'function (_self, o)' +
673 " o.params = o.params || {};\n" +
674 " // set more here\n" +
680 'xtype' : 'HttpProxy',
683 '|url' : "baseURL + '/Roo/" + rec.data.relates_to_table + ".php'",
688 'xtype' : 'JsonReader',
692 'totalProperty' : 'total'
702 if (xtype == 'HtmlEditor') {
707 '|xns' : 'Roo.form.HtmlEditor',
708 'xtype' : 'ToolbarContext'
711 '|xns' : 'Roo.form.HtmlEditor',
712 'xtype' : 'ToolbarStandard'
718 formElements.push(el);
720 formHeight += rec.data.ftype == 'TextArea' ? 100 : 30;
735 "|actioncomplete" : "function(_self,action)\n"+
737 " if (action.type == 'setdata') {\n"+
738 " //this.load({ method: 'GET', params: { '_id' : _this.data.id }});\n"+
741 " if (action.type == 'load') {\n"+
744 " if (action.type =='submit') {\n"+
746 " _this.dialog.hide();\n"+
748 " if (_this.callback) {\n"+
749 " _this.callback.call(_this, action.result.data);\n"+
751 " _this.form.reset();\n"+
756 "|rendered" : "function (form)\n"+
758 " _this.form= form;\n"+
762 style : "margin:10px;",
763 "|url" : "baseURL + '/Roo/" + this.table + "'",
768 alert("IPC:OUT:" + JSON.stringify({
770 "collapsible": false,
771 "height": formHeight,
773 "title": "Edit / Create " + this.table,
776 "xtype": "LayoutDialog",
781 "xtype": "LayoutRegion",
786 "xtype": "ContentPanel",
795 "click": "function (_self, e)\n{\n _this.dialog.hide();\n}"
797 "*prop": "buttons[]",
804 "click": "function (_self, e)\n{\n // do some checks?\n \n \n _this.dialog.el.mask(\"Saving\");\n _this.form.doAction(\"submit\");\n\n}"
806 "*prop": "buttons[]",
821 activate : function() {
824 _this.grid.footer.onClick('first');