function pRptDPKrektor(){
/** COMMON STORES */
var ds_years = store_tahun();
var ds_prodi = store_prodireg();
var ds_stsmt = store_stsmt();
var ds_jkls = store_klsmhsplusall();
/** ==============================*/
var ds_rptDPKper = new Ext.data.JsonStore({
proxy: new Ext.data.HttpProxy({
url: BASE_URL + 'rptkeu_controller/get_DpkPerangkatan',
method: 'POST',
}),
//baseParams: { kdprodi:'' },
totalProperty: 'results',
autoLoad : true,
root: 'data',
fields: [
{ name: 'nim' }
, { name: 'nmmhs' }
, { name: 'smt1' }
, { name: 'smt2' }
, { name: 'smt3' }
, { name: 'smt4' }
, { name: 'smt5' }
, { name: 'jmltotal' }
, { name: 'stlunas' }
, { name: 'biaya' }
, { name: 'sisa' }
, { name: "nmstawalmhs" }
, { name: "nmstaktivitasmhs" }
, { name: "nmklsmhs" }
, { name: "nmthnakademik" }
]
});
var ds_smtskrgbrjln = new Ext.data.JsonStore({
proxy: new Ext.data.HttpProxy({
url: BASE_URL + 'rptkeu_controller/get_smtskrgberjalan',
method: 'POST',
}),
baseParams: { smtskrgbrjln:KDSTSEMESTER },
totalProperty: 'results',
autoLoad : true,
root: 'data',
fields: [
{ name: 'nmthnakademik' }
]
});
ds_smtskrgbrjln.load({
scope : this,
callback: function(records, operation, success) {
ds_smtskrgbrjln.each(function (rec) {
smtskrgbrjln = rec.data['nmthnakademik'];
});
Ext.getCmp('tf.thnakasmtskrg-dpk').setValue(smtskrgbrjln);
}
});
var cari_data_nya = [new Ext.ux.grid.Search({
iconCls: 'btn_search',
minChars: 1,
autoFocus: true,
autoHeight: true,
position: 'top',
mode: 'local',
width: 200
})];
var cm_rptDPKper = new Ext.grid.ColumnModel({
columns: [
new Ext.grid.RowNumberer({width: 30}),
{
header: 'NPM', width: 100,
dataIndex: 'nim', sortable: true
}, {
header: 'Nama Mahasiswa', width: 150,
dataIndex: 'nmmhs', sortable: true
}, {
header: 'Th.Masuk', width: 110,
dataIndex: 'nmthnakademik', sortable: true
},{
header: 'St.Masuk', width: 65,
dataIndex: 'nmstawalmhs', sortable: true
}, {
header: 'Kelas', width: 80,
dataIndex: 'nmklsmhs', sortable: true
},{
header: 'St.Mahasiswa', width: 80,
dataIndex: 'nmstaktivitasmhs', sortable: true
}, {
//header: 'Biaya Tagihan', width: 90,
header: 'Biaya Tagihan', width: 90,
dataIndex: 'biaya', sortable: true,
xtype: 'numbercolumn', format:'0,000', align:'right',
}, {
header: '', width: 110,
dataIndex: 'smt1', sortable: true,
xtype: 'numbercolumn', format:'0,000', align:'right'
}, {
header: '', width: 110,
dataIndex: 'smt2', sortable: true,
xtype: 'numbercolumn', format:'0,000', align:'right'
}, {
header: '', width: 110,
dataIndex: 'smt3', sortable: true,
xtype: 'numbercolumn', format:'0,000', align:'right'
}, {
header: '', width: 110,
dataIndex: 'smt4', sortable: true,
xtype: 'numbercolumn', format:'0,000', align:'right'
}, {
header: '', width: 110,
dataIndex: 'smt5', sortable: true,
xtype: 'numbercolumn', format:'0,000', align:'right'
}, {
//header: 'Bayar', width: 90,
header: 'Bayar', width: 90,
dataIndex: 'jmltotal', sortable: true,
xtype: 'numbercolumn', format:'0,000', align:'right'
}, {
//header: 'Tunggakan', width: 90,
header: 'Tunggakan', width: 90,
dataIndex: 'sisa', sortable: true,
xtype: 'numbercolumn', format:'0,000', align:'right'
}, {
header: 'St.Bayar', width: 80,
dataIndex: 'stlunas', sortable: true,
}]
});
var gp_rptDPKper = new Ext.grid.GridPanel({
id: 'gp.dpk-rpt',
plugins: cari_data_nya,
ds: ds_rptDPKper,
cm: cm_rptDPKper,
sm: new Ext.grid.RowSelectionModel({ singleSelect: true}),
view: new Ext.grid.GridView({ emptyText: '< Belum ada Data >'}),
forceFit: true, //autoHeight: true, width: 720,
tbar: [{hidden:false,
text: 'Print',
iconCls: 'silk-printer',
handler: function(){ fnPrintDpkper(); }
}, '-',
{
xtype: 'button',
id: 'btn_excel_dpkrek',
iconCls: 'silk-save',
text: ' Export To Excel',
handler: function() {
exportdpkrek();
}
},'->'],
frame:false,
autoScroll: true,
autoSizeColumns: true,
enableColumnResize: true,
enableColumnHide: false,
enableColumnMove: false,
enableHdaccess: false,
columnLines: true,
loadMask: true,
layout: 'anchor',
bbar: [{
xtype: 'form', border: false,
items:[{
xtype: 'numericfield', fieldLabel: 'Tot.Biaya Tagihan',
id:'nf.to-biayatag-dpkdet', readOnly: true, disabled: false, width:100,
decimalSeparator: ',', decimalPrecision: 0, alwaysDisplayDecimals: true,
useThousandSeparator: true, thousandSeparator: '.',
style : {
//background : '#6699FF',
fontSize : '13px',
color : 'black',
textAlign: 'right',
}
}]
}, {
xtype: 'form', border: false,
items:[{
xtype: 'numericfield', fieldLabel: 'Tot.Bayar',
id:'nf.to-bayar-dpkdet', readOnly: true, disabled: false, width:100,
decimalSeparator: ',', decimalPrecision: 0, alwaysDisplayDecimals: true,
useThousandSeparator: true, thousandSeparator: '.',
style : {
//background : '#6699FF',
fontSize : '13px',
color : 'black',
textAlign: 'right',
}
}]
}, {
xtype: 'form', border: false,
items:[{
xtype: 'numericfield', fieldLabel: 'Tot.Tunggakan',
id:'nf.to-sisa-dpkdet', readOnly: true, disabled: false, width:100,
decimalSeparator: ',', decimalPrecision: 0, alwaysDisplayDecimals: true,
useThousandSeparator: true, thousandSeparator: '.',
style : {
//background : '#6699FF',
fontSize : '13px',
color : 'black',
textAlign: 'right',
}
}]
}, {
xtype: 'form', border: false,
items:[{
xtype: 'textfield', fieldLabel: 'Tot.Lunas',
id:'tf.to-lunas-bayar', readOnly: true, disabled: false, width:50,
style : {
//background : '#6699FF',
fontSize : '13px',
color : 'black',
textAlign: 'right',
}
}]
}, {
xtype: 'form', border: false,
items:[{
xtype: 'textfield', fieldLabel: 'Tot.Blm Lunas',
id:'tf.to-mhs-bayar', readOnly: true, disabled: false, width:50,
style : {
//background : '#6699FF',
fontSize : '13px',
color : 'black',
textAlign: 'right',
}
}]
}, {
xtype: 'form', border: false,
items:[{
xtype: 'textfield', fieldLabel: 'Tot.Yg Sdh Byr',
id:'tf.to-totmhs-bayar', readOnly: true, disabled: false, width:50,
style : {
//background : '#6699FF',
fontSize : '13px',
color : 'black',
textAlign: 'right',
}
}]
}],
});
//THE FORM PANEL//
var fpRptDPKper = new Ext.Panel({
autoWidth: true,
title: 'Laporan Keuangan DPK Per Angkatan',
id: 'fp.RptDPK',
layout: 'form',
forceFit: true,
autoScroll: true,
margin: '0 0 10',
frame: true,
defaults: { labelWidth: 200, labelAlign: 'right'},
items: [
{
xtype: 'fieldset', flex: 1, region:'north', layout:'column', autoHeight:true,
items: [
{
columnWidth:.3,
layout: 'form',
items: [
{
xtype:'compositefield', id:'cmpopt',
items:[{
xtype: 'combo',
id: 'cb.thmasuk-dpk', fieldLabel: 'Th.Msk/Angkatan',
store: ds_years, triggerAction: 'all', width: 100,
valueField: 'kode', displayField: 'nama',
forceSelection: true, submitValue: true, mode: 'local',
emptyText:'Pilih...', //selectOnFocus:true,
listeners:{
scope: this,
'select': function(){
var angkatan = parseInt(RH.getCompValue('cb.thmasuk-dpk')); //merubah ke int
var tambah1 = angkatan + 1; //menjumlahkan bilangan int
var tambah2 = angkatan + 2; //menjumlahkan bilangan int
//---masukkan ke header kolom 8---//
var plus1 = RH.getCompValue('cb.thmasuk-dpk') + 1;
var thnsmster1 = RH.getRecordFieldValue(ds_stsmt, 'nmthnakademik', 'kdstsemester', plus1);
var thnsmster2 = RH.getRecordFieldValue(ds_stsmt, 'nmjnssemester', 'kdstsemester', plus1);
gp_rptDPKper.getColumnModel().setColumnHeader(8,thnsmster1 + ' ' + thnsmster2);
//--------------------------------//
//---masukkan ke header kolom 9---//
var plus2 = RH.getCompValue('cb.thmasuk-dpk') + 2;
var thnsmster3 = RH.getRecordFieldValue(ds_stsmt, 'nmthnakademik', 'kdstsemester', plus2);
var thnsmster4 = RH.getRecordFieldValue(ds_stsmt, 'nmjnssemester', 'kdstsemester', plus2);
gp_rptDPKper.getColumnModel().setColumnHeader(9,thnsmster3 + ' ' + thnsmster4);
//--------------------------------//
//---masukkan ke header kolom 10---//
var plus3 = String(tambah1) + 1; //merubah ke string
var thnsmster5 = RH.getRecordFieldValue(ds_stsmt, 'nmthnakademik', 'kdstsemester', plus3);
var thnsmster6 = RH.getRecordFieldValue(ds_stsmt, 'nmjnssemester', 'kdstsemester', plus3);
gp_rptDPKper.getColumnModel().setColumnHeader(10,thnsmster5 + ' ' + thnsmster6);
//--------------------------------//
//---masukkan ke header kolom 11---//
var plus4 = String(tambah1) + 2; //merubah ke string
var thnsmster7 = RH.getRecordFieldValue(ds_stsmt, 'nmthnakademik', 'kdstsemester', plus4);
var thnsmster8 = RH.getRecordFieldValue(ds_stsmt, 'nmjnssemester', 'kdstsemester', plus4);
gp_rptDPKper.getColumnModel().setColumnHeader(11,thnsmster7 + ' ' + thnsmster8);
//--------------------------------//
//---masukkan ke header kolom 12---//
var plus5 = String(tambah2) + 1; //merubah ke string
var thnsmster9 = RH.getRecordFieldValue(ds_stsmt, 'nmthnakademik', 'kdstsemester', plus5);
var thnsmster10 = RH.getRecordFieldValue(ds_stsmt, 'nmjnssemester', 'kdstsemester', plus5);
gp_rptDPKper.getColumnModel().setColumnHeader(12,thnsmster9 + ' ' + thnsmster10);
//--------------------------------//
var angkatan = parseInt(RH.getCompValue('cb.thmasuk-dpk')); //merubah ke int
var tambah = angkatan + 1;
var thnakademik = angkatan + '/' + tambah;
RH.setCompValue('tf.thnaka-dpk',thnakademik);
setGridDPKper();
smtskrg();
jmlthp();
jmlmhs();
}
}
},{
xtype: 'textfield', disabled:false, readOnly:true,
id: 'tf.thnaka-dpk', width: 85, //fieldLabel: 'Th.Akademik-Smt',
}]
}, {
xtype: 'combo',
id: 'cb.prodi-dpk', fieldLabel: 'Program Studi',
store: ds_prodi, valueField: 'kdprodi', displayField: 'lnmprodi',
triggerAction: 'all',editable: false, width: 220,
forceSelection: true, submitValue: true, mode: 'local',
emptyText:'Pilih...', //selectOnFocus:true,
listeners:{
scope: this, 'select': function(){ setGridDPKper(); jmlmhs(); }
}
}, {
xtype: 'combo', width: 170,
id: 'cb.jkelas-dpk', fieldLabel: 'Jenis Kelas',
store: ds_jkls, valueField: 'idklsmhs', displayField: 'kdnm',
triggerAction: 'all',editable: false,
forceSelection: true, submitValue: true, mode: 'local',
emptyText:'Pilih...', //selectOnFocus:true,
listeners:{
scope: this, 'select': function(){ setGridDPKper();}
}
}
]
},{
columnWidth:.3,
layout: 'form',
items: [{
xtype: 'textfield', disabled:false, readOnly:true, width: 150,
id: 'tf.thnakasmtskrg-dpk', fieldLabel: 'Th.Aka-Smt Skrg',
}, {
xtype: 'textfield', disabled:false, readOnly:true, width: 50,
id: 'tf.smts-skrg', fieldLabel: 'Semester',
}, {
xtype: 'textfield', width:50, disabled:false, readOnly:true,
id: 'tf.jml-mhs-dpk', fieldLabel: 'Jml.Mahasiswa',
}]
},{
columnWidth:.3,
layout: 'form',
items: [{
xtype: 'textfield', disabled:false, readOnly:true, width: 50,
id: 'tf.jml-thp', fieldLabel: 'Jml.Tahapan',
}, {
xtype: 'numericfield', fieldLabel: 'Jml.Biaya Thpn',
id:'tf.jml-biaya-perthp', readOnly: true, disabled: false, width:150,
decimalSeparator: ',', decimalPrecision: 0, alwaysDisplayDecimals: true,
useThousandSeparator: true, thousandSeparator: '.',
}]
}
]
},
{
region: 'center', layout:'form', autoScroll:true,
items:[{
xtype: 'panel', layout:'fit', height:435, //width: 1300,
title:'Laporan Per Mahasiswa', id:'fp.dpk-permahasiswa', frame:true,
items: [gp_rptDPKper]
}]
}, RH.vSpacer(10),
]
}); SET_PAGE_CONTENT(fpRptDPKper);
function setGridDPKper(){
if(RH.isEmpty('cb.thmasuk-dpk')) return;
if(RH.isEmpty('cb.prodi-dpk')) return;
if(RH.isEmpty('cb.jkelas-dpk')) return;
RH.setCompValue('tf.to-mhs-bayar', 0);
RH.setCompValue('nf.to-bayar-dpkdet', 0);
RH.setCompValue('nf.to-sisa-dpkdet', 0);
var thmasuk = RH.getCompValue('cb.thmasuk-dpk');
var kdprodi = RH.getCompValue('cb.prodi-dpk');
var idklsmhs = RH.getCompValue('cb.jkelas-dpk');
//Ext.Msg.alert("DEBUG", thmasuk + '-' + idklsmhs);return;
ds_rptDPKper.reload({
params: {
thmasuk: thmasuk,
kdprodi: kdprodi,
idklsmhs: idklsmhs,
},
callback: function(results){
var count = 0;
var count2 = 0;
var count3 = 0;
ds_rptDPKper.each(function (rec) {
if (rec.data['stlunas'] == 'Lunas') {
count = count + 1;
}
if (rec.data['stlunas'] == 'Belum Lunas') {
count2 = count2 + 1;
}
if (rec.data['jmltotal'] > 0) {
count3 = count3 + 1;
}
});
RH.setCompValue('tf.to-lunas-bayar', count);
RH.setCompValue('tf.to-mhs-bayar', count2);
RH.setCompValue('tf.to-totmhs-bayar', count3);
RH.setCompValue('nf.to-biayatag-dpkdet', RH.sumRecVal(ds_rptDPKper, 'biaya'));
RH.setCompValue('nf.to-bayar-dpkdet', RH.sumRecVal(ds_rptDPKper, 'jmltotal'));
RH.setCompValue('nf.to-sisa-dpkdet', RH.sumRecVal(ds_rptDPKper, 'sisa'));
}
});
}
function smtskrg(){
var thnmsk = Ext.getCmp('cb.thmasuk-dpk').getValue() + 1;
Ext.Ajax.request({
url: BASE_URL + 'rptkeu_controller/get_smstskrg',
method: 'POST',
params :{
tahunangkatan: thnmsk
},
scope: this, async:false,
success: function(result){
var jsonData = Ext.decode(result.responseText); //bisa utk Ext3 dan Ext4
var dataArray = jsonData.data;
var data = dataArray[0];
RH.setCompValue('tf.smts-skrg', data.semester);
}
});
}
function jmlthp(){
var thnmsk = Ext.getCmp('cb.thmasuk-dpk').getValue();
Ext.Ajax.request({
url: BASE_URL + 'rptkeu_controller/get_jmlthp',
method: 'POST',
params :{
tahunangkatan: thnmsk
},
scope: this, async:false,
success: function(result){
var jsonData = Ext.decode(result.responseText); //bisa utk Ext3 dan Ext4
var dataArray = jsonData.data;
var data = dataArray[0];
RH.setCompValue('tf.jml-thp', data.jmlthpn);
RH.setCompValue('tf.jml-biaya-perthp', data.jmlbiaya);
}
});
}
function jmlmhs(){
var thnmsk = Ext.getCmp('cb.thmasuk-dpk').getValue();
var kdprodi = Ext.getCmp('cb.prodi-dpk').getValue();
Ext.Ajax.request({
url: BASE_URL + 'rptkeu_controller/get_jmlmhsdpk',
method: 'POST',
params :{
tahunangkatan: thnmsk,
kdprodi: kdprodi
},
scope: this, async:false,
success: function(result){
var jsonData = Ext.decode(result.responseText); //bisa utk Ext3 dan Ext4
var dataArray = jsonData.data;
var data = dataArray[0];
RH.setCompValue('tf.jml-mhs-dpk', data.jummhsdpk);
}
});
}
function fnPrintDpkper(){
var thnmasuk = RH.getCompValue('cb.thmasuk-dpk');
var kdprodi = RH.getCompValue('cb.prodi-dpk');
var idklsmhs = RH.getCompValue('cb.jkelas-dpk');
if(thnmasuk && kdprodi && idklsmhs)
{
RH.ShowReport(BASE_URL + 'rpt/rpt_det_dpk_perangkatan/get_dpk_perangkatan/'+thnmasuk+'/'+kdprodi+'/'+idklsmhs);
} else
{}
}
//excel
function exportdpkrek(){
var tablename = 'excel_dpk_perangkatan';
var waitmsgexport = Ext.MessageBox.wait('Exporting Data...', 'Info');
var thmasuk = RH.getCompValue('cb.thmasuk-dpk');
var kdprodi = RH.getCompValue('cb.prodi-dpk');
var idklsmhs = RH.getCompValue('cb.jkelas-dpk');
if(thmasuk && kdprodi && idklsmhs){
Ext.Ajax.request({
url: BASE_URL + 'rptkeu_controller/get_DpkPerangkatanExcel',
params: {
thmasuk: thmasuk,
kdprodi: kdprodi,
idklsmhs: idklsmhs,
},
success: function() {
waitmsgexport.hide();
window.location = BASE_URL + 'rptkeu_controller/export_excel/'+tablename;
},
failure: function() {
waitmsgexport.hide();
Ext.MessageBox.alert("Info", "Export Data Gagal");
}
});
}else{
Ext.MessageBox.alert("Info", "Thn.Masuk atau Prodi atau Jenis Kelas kosong");
}
}
}