function f_pesan(nidu, nim) { var userpesan1 = ""; var cekjumlah=0, cekjumlahdb=0; var out = new Ext.form.DisplayField({ cls: 'x-form-text', autoScroll: true, height:100, id: 'out' }); var out2 = new Ext.form.DisplayField({ cls: 'x-form-text', autoScroll: true, height:100,id: 'out2' }); var text = new Ext.form.TextField({ width: 500, id: 'text', emptyText: 'Text...' }); var call = new Ext.Button({ text: 'Kirim', handler: function() { if (Ext.getCmp('text').getValue()) { Ext.Ajax.request({ url: BASE_URL + 'e_akademic/c_pesan/insert', method: 'POST', params: { kdstsemester: KDSTSEMESTER, pesan: Ext.getCmp('text').getValue(), nidu: nidu, nim: nim, idpengirim: USERID, nmpengirim: USERNAME, waktu: SYS_DATE }, success: function(response) { var r = Ext.decode(response.responseText); var success, nimz, niduz, pesanz, tglchatpoz; tglchatpoz = r.tglchatpo; success = r.success; if (success == true) { Ext.getCmp('text').setValue(''); // out.append(String.format('

{0} :

{1}terkirim pada {2}

', 'Saya', r.pesan, tglchatpoz)); // out.el.scroll('b', 50000, true); ds_nya.load({ scope: this, callback: function(records, operation, success) { Ext.getCmp('out').setValue(''); ds_nya.each(function(rec) { if (USERID === rec.get('idpengirim')) { userpesan1 = "Saya"; } else { userpesan1 = rec.get('nama'); } if (rec.get('success') == true) { // Ext.getCmp('out').setValue(''); out.append(String.format('

{0} :

{1}terkirim pada {2}

', userpesan1, rec.get('pesan'), rec.get('tglchatpo'))); out.el.scroll('b', 50000, true); } }); } }); } } }); } } }); text.on('specialkey', function(t, e) { if (e.getKey() == e.ENTER) { call.handler(); } }); var ds_nya = new Ext.data.JsonStore({ proxy: new Ext.data.HttpProxy({ url: BASE_URL + 'e_akademic/c_pesan/grid', method: 'POST' }), baseParams: { kdstsemester: KDSTSEMESTER, nidu: nidu, nim: nim }, root: 'data', totalProperty: 'results', fields: [{ name: "idchatpo", mapping: "idchatpo" },{ name: "nidu", mapping: "nidu" }, { name: "nim", mapping: "nim" }, { name: "tglchatpo", mapping: "tglchatpo" }, { name: "pesan", mapping: "pesan" }, { name: "success", mapping: "success" }, { name: "idpengirim", mapping: "idpengirim" }, { name: "jumlah", mapping: "jumlah" }, { name: "nama", mapping: "nama" }] }); //====================================================================== var cm = new Ext.grid.ColumnModel({ // specify any defaults for each column defaults: { sortable: true // columns are not sortable by default }, columns: [{ header: 'idchatpo', width: 50, dataIndex: 'idchatpo', sortable: true, hidden:true }, { header: 'Pesan', width: 560, dataIndex: 'pesan', sortable: true }] }); var vw = new Ext.grid.GridView({ emptyText: '< Pesan Masih Kosong >' }); var sm_nya = new Ext.grid.CheckboxSelectionModel({ listeners: { // rowselect: select_action, // rowdeselect: deselect_action } }); var cari_data = [new Ext.ux.grid.Search({ iconCls: 'btn_search', minChars: 1, autoFocus: true, autoHeight: true, position: 'top', mode: 'remote', width: 200 })]; var grid_nya = new Ext.grid.EditorGridPanel({ store: ds_nya, frame: true, //width: 1140, height: 595, plugins: cari_data, id: 'gridnya', buttonAlign: 'left', defaults: { anchor: '-10' }, forceFit: true, tbar: [ // { // text: 'Edit', // id: 'btn_edit', // iconCls: 'silk-edit', // handler: function() { // if (sm_nya.getCount() > 0) { // var module_id = sm_nya.getSelected().data['kdjadwalpmb']; // //form_gallery(gallery_id); // //alert(module_id); // //f_jadwalpmb_form(module_id, ds_nya); // } // } // }, '-', { text: 'Delete', id: 'btn_delete', iconCls: 'silk-delete', handler: function() { if (sm_nya.getCount() > 0) { var delete_id = sm_nya.getSelected().data['idchatpo']; Ext.MessageBox.show({ title: "Konfirmasi", msg: "Anda Yakin Untuk menghapus Data ini?", buttons: Ext.MessageBox.YESNO, fn: function(btn) { if (btn == 'yes') { Ext.Ajax.request({ url: BASE_URL + 'e_akademic/c_pesan/delete', method: 'POST', success: function() { //Ext.MessageBox.alert("Informasi", "Hapus Data Berhasil"); ds_nya.load(); }, failure: function(result) { //Ext.MessageBox.alert("Informasi", "Hapus Data Gagal"); }, params: { hapus_id: delete_id } }); } } }); } } }, '-', '->'], sm: sm_nya, vw: vw, autoScroll: true, cm: cm, //bbar: paging, //autoExpandColumn: 'common', clicksToEdit: 1, listeners: { rowdblclick: function rowdblClick(grid, rowIdx) { var rec = ds_nya.getAt(rowIdx); //alert(rec.data["kdmenu"] + ', ' + Ext.getCmp('combox').getValue()); } } }); // ================================================================================= var r = new Ext.Window({ title: 'Option', width: 600, height: 300, layout: 'fit', items: [grid_nya], bbar: [ '->', { text: 'Kembali', handler: function() { f_pesan(nidu, nim); r.close(); } }] }); var q = new Ext.Window({ title: 'Pesan', width: 600, height: 300, layout: 'fit', items: [out,out2], bbar: [ text, call, { text: 'Option', handler: function() { q.hide(); ds_nya.load(); r.show(); } }] }); q.show(); Ext.getCmp('out').setValue('

Silahkan Tulis Pesan Anda...

'); ds_nya.load({ scope: this, callback: function(records, operation, success) { Ext.getCmp('out').setValue(''); ds_nya.each(function(rec) { if (USERID === rec.get('idpengirim')) { userpesan1 = "Saya"; } else { userpesan1 = rec.get('nama'); } if (rec.get('success') == true) { out.append(String.format('

{0} :

{1}terkirim pada {2}

', userpesan1, rec.get('pesan'), rec.get('tglchatpo'))); out.el.scroll('b', 50000, true); } }); } }); var interval = setInterval(function() { cekjumlah=0; Ext.getCmp('out2').setValue(''); ds_nya.load({ scope: this, callback: function(records, operation, success) { ds_nya.each(function(rec) { if (USERID === rec.get('idpengirim')) { userpesan1 = "Saya"; } else { userpesan1 = rec.get('nama'); } if (rec.get('success') == true) { out2.append(String.format('

{0} :

{1}terkirim pada {2}

', userpesan1, rec.get('pesan'), rec.get('tglchatpo'))); out2.el.scroll('b', 50000, true); } cekjumlah += 1; // alert(rec.get('jumlah')+', '+cekjumlah); if(rec.get('jumlah') == cekjumlah){ Ext.getCmp('out').setValue(''); Ext.getCmp('out').setValue(Ext.getCmp('out2').getValue()); out.el.scroll('b', 50000, true); } }); } }); }, 4000); }