Update PelayananPasienServiceImpl.java
Penerapan aturan persentase operasi non-jkn 1 dokter di 1 waktu
This commit is contained in:
parent
c43e6fb74a
commit
9119900a20
@ -657,6 +657,153 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
rawDataBpjs3.add(d);
|
rawDataBpjs3.add(d);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
* Dapatkan semua pendaftaran non-jkn
|
||||||
|
*/
|
||||||
|
List<Map<String, Object>> listEpisode = new ArrayList<>();
|
||||||
|
for (Map<String, Object> d : listData) {
|
||||||
|
if (!Arrays.asList(Master.KelompokPasien.KELOMPOK_BPJS).contains(d.get("idKelompokPasien"))
|
||||||
|
&& Master.Departemen.BEDAH_SENTRAL.equals(d.get("idDepartemen"))) {
|
||||||
|
if (!listEpisode.contains(d.get("idPasienDaftar"))) {
|
||||||
|
Map<String, Object> episode = new HashMap<>();
|
||||||
|
episode.put("id", d.get("idPasienDaftar"));
|
||||||
|
episode.put("count", 1);
|
||||||
|
listEpisode.add(episode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* Filter tindakan operasi non-jkn, persen jasa tereduksi seiring
|
||||||
|
* banyaknya operasi yang dilakukan di satu episode pasien yang sama
|
||||||
|
*/
|
||||||
|
for (Map<String, Object> d : listData) {
|
||||||
|
for (Map<String, Object> e : listEpisode) {
|
||||||
|
if (!Arrays.asList(Master.KelompokPasien.KELOMPOK_BPJS).contains(d.get("idKelompokPasien"))
|
||||||
|
&& Master.Departemen.BEDAH_SENTRAL.equals(d.get("idDepartemen"))
|
||||||
|
&& d.get("idPasienDaftar").equals(e.get("id"))) {
|
||||||
|
if (e.get("count").equals(1)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 100% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
1.0 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
1.0 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
1.0 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(2)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 50% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.5 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.5 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.5 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(3)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 40% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.4 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.4 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.4 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(4)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 30% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.3 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.3 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.3 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(5)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 20% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.2 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.2 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.2 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(6)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 10% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.1 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.1 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.1 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 0% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.0 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.0 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.0 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* Alokasi data diurutkan dulu untuk jam kerja. Asumsi jam kerja dokter
|
* Alokasi data diurutkan dulu untuk jam kerja. Asumsi jam kerja dokter
|
||||||
* nonshift
|
* nonshift
|
||||||
@ -999,6 +1146,7 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
List<Map<String, Object>> dataTanggal = new ArrayList<>();
|
List<Map<String, Object>> dataTanggal = new ArrayList<>();
|
||||||
List<Integer> listIdProduk = new ArrayList<>();
|
List<Integer> listIdProduk = new ArrayList<>();
|
||||||
List<String> listPersenJasa = new ArrayList<>();
|
List<String> listPersenJasa = new ArrayList<>();
|
||||||
|
List<Double> listHargaJasa = new ArrayList<>();
|
||||||
List<Double> listHargaJual = new ArrayList<>();
|
List<Double> listHargaJual = new ArrayList<>();
|
||||||
List<Integer> listIdKelompokPasien = new ArrayList<>();
|
List<Integer> listIdKelompokPasien = new ArrayList<>();
|
||||||
List<String> listTanggal = new ArrayList<>();
|
List<String> listTanggal = new ArrayList<>();
|
||||||
@ -1108,6 +1256,8 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
listIdProduk.add(Integer.valueOf(d.get("idProduk").toString()));
|
listIdProduk.add(Integer.valueOf(d.get("idProduk").toString()));
|
||||||
if (!listPersenJasa.contains(d.get("persenJasa")))
|
if (!listPersenJasa.contains(d.get("persenJasa")))
|
||||||
listPersenJasa.add(d.get("persenJasa").toString());
|
listPersenJasa.add(d.get("persenJasa").toString());
|
||||||
|
if (!listHargaJasa.contains(d.get("hargaJasa")))
|
||||||
|
listHargaJasa.add(Double.valueOf(d.get("hargaJasa").toString()));
|
||||||
if (!listHargaJual.contains(d.get("hargaJual")))
|
if (!listHargaJual.contains(d.get("hargaJual")))
|
||||||
listHargaJual.add(Double.valueOf(d.get("hargaJual").toString()));
|
listHargaJual.add(Double.valueOf(d.get("hargaJual").toString()));
|
||||||
if (!listIdKelompokPasien.contains(d.get("idKelompokPasien")))
|
if (!listIdKelompokPasien.contains(d.get("idKelompokPasien")))
|
||||||
@ -1120,29 +1270,32 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
*/
|
*/
|
||||||
for (Integer idProduk : listIdProduk) {
|
for (Integer idProduk : listIdProduk) {
|
||||||
for (String persenJasa : listPersenJasa) {
|
for (String persenJasa : listPersenJasa) {
|
||||||
for (Double hargaJual : listHargaJual) {
|
for (Double hargaJasa : listHargaJasa) {
|
||||||
for (Integer idKelompokPasien : listIdKelompokPasien) {
|
for (Double hargaJual : listHargaJual) {
|
||||||
for (String tanggal : listTanggal) {
|
for (Integer idKelompokPasien : listIdKelompokPasien) {
|
||||||
Map<String, Object> mapData = new HashMap<>();
|
for (String tanggal : listTanggal) {
|
||||||
double jumlah = 0.0;
|
Map<String, Object> mapData = new HashMap<>();
|
||||||
List<String> norecs = new ArrayList<>();
|
double jumlah = 0.0;
|
||||||
int dataHitungKe = 0;
|
List<String> norecs = new ArrayList<>();
|
||||||
for (Map<String, Object> map : listData) {
|
int dataHitungKe = 0;
|
||||||
if (idProduk.equals(map.get("idProduk")) && persenJasa.equals(map.get("persenJasa"))
|
for (Map<String, Object> map : listData) {
|
||||||
&& hargaJual.equals(map.get("hargaJual"))
|
if (idProduk.equals(map.get("idProduk")) && persenJasa.equals(map.get("persenJasa"))
|
||||||
&& idKelompokPasien.equals(map.get("idKelompokPasien"))
|
&& hargaJasa.equals(map.get("hargaJasa"))
|
||||||
&& tanggal.equals(map.get("tanggal"))) {
|
&& hargaJual.equals(map.get("hargaJual"))
|
||||||
jumlah += Double.parseDouble(map.get("jumlah").toString());
|
&& idKelompokPasien.equals(map.get("idKelompokPasien"))
|
||||||
norecs.add(map.get("idPelayananPasien").toString());
|
&& tanggal.equals(map.get("tanggal"))) {
|
||||||
dataHitungKe++;
|
jumlah += Double.parseDouble(map.get("jumlah").toString());
|
||||||
if (dataHitungKe == 1)
|
norecs.add(map.get("idPelayananPasien").toString());
|
||||||
mapData.putAll(map);
|
dataHitungKe++;
|
||||||
|
if (dataHitungKe == 1)
|
||||||
|
mapData.putAll(map);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (CommonUtil.isNotNullOrEmpty(mapData.get("jumlah"))) {
|
||||||
|
mapData.put("jumlah", jumlah);
|
||||||
|
mapData.put("norecs", norecs);
|
||||||
|
dataTanggal.add(mapData);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if (CommonUtil.isNotNullOrEmpty(mapData.get("jumlah"))) {
|
|
||||||
mapData.put("jumlah", jumlah);
|
|
||||||
mapData.put("norecs", norecs);
|
|
||||||
dataTanggal.add(mapData);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1154,41 +1307,44 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
*/
|
*/
|
||||||
for (Integer idProduk : listIdProduk) {
|
for (Integer idProduk : listIdProduk) {
|
||||||
for (String persenJasa : listPersenJasa) {
|
for (String persenJasa : listPersenJasa) {
|
||||||
for (Double hargaJual : listHargaJual) {
|
for (Double hargaJasa : listHargaJasa) {
|
||||||
for (Integer idKelompokPasien : listIdKelompokPasien) {
|
for (Double hargaJual : listHargaJual) {
|
||||||
Map<String, Object> mapResult = new HashMap<>();
|
for (Integer idKelompokPasien : listIdKelompokPasien) {
|
||||||
List<Map<String, Object>> detail = new ArrayList<>();
|
Map<String, Object> mapResult = new HashMap<>();
|
||||||
int counter = 0;
|
List<Map<String, Object>> detail = new ArrayList<>();
|
||||||
double jumlah = 0.0;
|
int counter = 0;
|
||||||
double jumlahHargaJasa = 0.0;
|
double jumlah = 0.0;
|
||||||
for (Map<String, Object> map : dataTanggal) {
|
double jumlahHargaJasa = 0.0;
|
||||||
Map<String, Object> mapCount = new HashMap<>();
|
for (Map<String, Object> map : dataTanggal) {
|
||||||
if (idProduk.equals(map.get("idProduk")) && persenJasa.equals(map.get("persenJasa"))
|
Map<String, Object> mapCount = new HashMap<>();
|
||||||
&& hargaJual.equals(map.get("hargaJual"))
|
if (idProduk.equals(map.get("idProduk")) && persenJasa.equals(map.get("persenJasa"))
|
||||||
&& idKelompokPasien.equals(map.get("idKelompokPasien"))) {
|
&& hargaJasa.equals(map.get("hargaJasa"))
|
||||||
mapCount.put("jumlah", map.get("jumlah"));
|
&& hargaJual.equals(map.get("hargaJual"))
|
||||||
mapCount.put("norecs", map.get("norecs"));
|
&& idKelompokPasien.equals(map.get("idKelompokPasien"))) {
|
||||||
mapCount.put("tanggal", map.get("tanggal"));
|
mapCount.put("jumlah", map.get("jumlah"));
|
||||||
detail.add(mapCount);
|
mapCount.put("norecs", map.get("norecs"));
|
||||||
counter++;
|
mapCount.put("tanggal", map.get("tanggal"));
|
||||||
jumlah += Double.parseDouble(map.get("jumlah").toString());
|
detail.add(mapCount);
|
||||||
if (counter == 1)
|
counter++;
|
||||||
mapResult.putAll(map);
|
jumlah += Double.parseDouble(map.get("jumlah").toString());
|
||||||
|
if (counter == 1)
|
||||||
|
mapResult.putAll(map);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
if (CommonUtil.isNotNullOrEmpty(mapResult.get("jumlah"))) {
|
||||||
if (CommonUtil.isNotNullOrEmpty(mapResult.get("jumlah"))) {
|
/*
|
||||||
/*
|
* Tambahkan data total
|
||||||
* Tambahkan data total
|
*/
|
||||||
*/
|
jumlahHargaJasa = jumlah * Double.parseDouble(mapResult.get("hargaJasa").toString());
|
||||||
jumlahHargaJasa = jumlah * Double.parseDouble(mapResult.get("hargaJasa").toString());
|
mapResult.put("jumlah", jumlah);
|
||||||
mapResult.put("jumlah", jumlah);
|
mapResult.put("jumlahHargaJasa", jumlahHargaJasa);
|
||||||
mapResult.put("jumlahHargaJasa", jumlahHargaJasa);
|
/*
|
||||||
/*
|
* Tambahkan data detail
|
||||||
* Tambahkan data detail
|
*/
|
||||||
*/
|
mapResult.put("detail", detail);
|
||||||
mapResult.put("detail", detail);
|
|
||||||
|
|
||||||
dataResult.add(mapResult);
|
dataResult.add(mapResult);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1237,6 +1393,7 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
List<Map<String, Object>> dataTanggal = new ArrayList<>();
|
List<Map<String, Object>> dataTanggal = new ArrayList<>();
|
||||||
List<Integer> listIdProduk = new ArrayList<>();
|
List<Integer> listIdProduk = new ArrayList<>();
|
||||||
List<String> listPersenJasa = new ArrayList<>();
|
List<String> listPersenJasa = new ArrayList<>();
|
||||||
|
List<Double> listHargaJasa = new ArrayList<>();
|
||||||
List<Double> listHargaJual = new ArrayList<>();
|
List<Double> listHargaJual = new ArrayList<>();
|
||||||
List<Integer> listIdKelompokPasien = new ArrayList<>();
|
List<Integer> listIdKelompokPasien = new ArrayList<>();
|
||||||
List<String> listTanggal = new ArrayList<>();
|
List<String> listTanggal = new ArrayList<>();
|
||||||
@ -1314,6 +1471,153 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
d.put("hargaJasa", persenTindakan / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
d.put("hargaJasa", persenTindakan / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
* Dapatkan semua pendaftaran non-jkn
|
||||||
|
*/
|
||||||
|
List<Map<String, Object>> listEpisode = new ArrayList<>();
|
||||||
|
for (Map<String, Object> d : listData) {
|
||||||
|
if (!Arrays.asList(Master.KelompokPasien.KELOMPOK_BPJS).contains(d.get("idKelompokPasien"))
|
||||||
|
&& Master.Departemen.BEDAH_SENTRAL.equals(d.get("idDepartemen"))) {
|
||||||
|
if (!listEpisode.contains(d.get("idPasienDaftar"))) {
|
||||||
|
Map<String, Object> episode = new HashMap<>();
|
||||||
|
episode.put("id", d.get("idPasienDaftar"));
|
||||||
|
episode.put("count", 1);
|
||||||
|
listEpisode.add(episode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* Filter tindakan operasi non-jkn, persen jasa tereduksi seiring
|
||||||
|
* banyaknya operasi yang dilakukan di satu episode pasien yang sama
|
||||||
|
*/
|
||||||
|
for (Map<String, Object> d : listData) {
|
||||||
|
for (Map<String, Object> e : listEpisode) {
|
||||||
|
if (!Arrays.asList(Master.KelompokPasien.KELOMPOK_BPJS).contains(d.get("idKelompokPasien"))
|
||||||
|
&& Master.Departemen.BEDAH_SENTRAL.equals(d.get("idDepartemen"))
|
||||||
|
&& d.get("idPasienDaftar").equals(e.get("id"))) {
|
||||||
|
if (e.get("count").equals(1)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 100% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
1.0 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
1.0 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
1.0 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(2)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 50% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.5 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.5 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.5 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(3)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 40% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.4 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.4 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.4 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(4)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 30% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.3 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.3 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.3 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(5)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 20% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.2 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.2 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.2 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else if (e.get("count").equals(6)) {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 10% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.1 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.1 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.1 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* Mendapatkan 0% dari tarif
|
||||||
|
*/
|
||||||
|
if (Master.JenisPetugasPelaksana.DOKTER_PEMERIKSA.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.0 * persenOperatorIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.ASISTEN_SPESIALIS.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.0 * persenAsistenIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
} else if (Master.JenisPetugasPelaksana.DOKTER_ANASTESI.equals(d.get("idJenisPelaksana"))) {
|
||||||
|
d.put("hargaJasa",
|
||||||
|
0.0 * persenAnestesiIBS / 100 * Double.parseDouble(d.get("hargaJual").toString()));
|
||||||
|
}
|
||||||
|
int count = Integer.parseInt(e.get("count").toString());
|
||||||
|
e.put("count", ++count);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* Populate data filter
|
* Populate data filter
|
||||||
*/
|
*/
|
||||||
@ -1322,6 +1626,8 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
listIdProduk.add(Integer.valueOf(d.get("idProduk").toString()));
|
listIdProduk.add(Integer.valueOf(d.get("idProduk").toString()));
|
||||||
if (!listPersenJasa.contains(d.get("persenJasa")))
|
if (!listPersenJasa.contains(d.get("persenJasa")))
|
||||||
listPersenJasa.add(d.get("persenJasa").toString());
|
listPersenJasa.add(d.get("persenJasa").toString());
|
||||||
|
if (!listHargaJasa.contains(d.get("hargaJasa")))
|
||||||
|
listHargaJasa.add(Double.valueOf(d.get("hargaJasa").toString()));
|
||||||
if (!listHargaJual.contains(d.get("hargaJual")))
|
if (!listHargaJual.contains(d.get("hargaJual")))
|
||||||
listHargaJual.add(Double.valueOf(d.get("hargaJual").toString()));
|
listHargaJual.add(Double.valueOf(d.get("hargaJual").toString()));
|
||||||
if (!listIdKelompokPasien.contains(d.get("idKelompokPasien")))
|
if (!listIdKelompokPasien.contains(d.get("idKelompokPasien")))
|
||||||
@ -1336,31 +1642,35 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
*/
|
*/
|
||||||
for (Integer idProduk : listIdProduk) {
|
for (Integer idProduk : listIdProduk) {
|
||||||
for (String persenJasa : listPersenJasa) {
|
for (String persenJasa : listPersenJasa) {
|
||||||
for (Double hargaJual : listHargaJual) {
|
for (Double hargaJasa : listHargaJasa) {
|
||||||
for (Integer idKelompokPasien : listIdKelompokPasien) {
|
for (Double hargaJual : listHargaJual) {
|
||||||
for (String jenisRuangan : listJenisRuangan) {
|
for (Integer idKelompokPasien : listIdKelompokPasien) {
|
||||||
for (String tanggal : listTanggal) {
|
for (String jenisRuangan : listJenisRuangan) {
|
||||||
Map<String, Object> mapData = new HashMap<>();
|
for (String tanggal : listTanggal) {
|
||||||
double jumlah = 0.0;
|
Map<String, Object> mapData = new HashMap<>();
|
||||||
List<String> norecs = new ArrayList<>();
|
double jumlah = 0.0;
|
||||||
int dataHitungKe = 0;
|
List<String> norecs = new ArrayList<>();
|
||||||
for (Map<String, Object> map : listData) {
|
int dataHitungKe = 0;
|
||||||
if (idProduk.equals(map.get("idProduk")) && persenJasa.equals(map.get("persenJasa"))
|
for (Map<String, Object> map : listData) {
|
||||||
&& hargaJual.equals(map.get("hargaJual"))
|
if (idProduk.equals(map.get("idProduk"))
|
||||||
&& idKelompokPasien.equals(map.get("idKelompokPasien"))
|
&& persenJasa.equals(map.get("persenJasa"))
|
||||||
&& jenisRuangan.equals(map.get("jenisRuangan"))
|
&& hargaJasa.equals(map.get("hargaJasa"))
|
||||||
&& tanggal.equals(map.get("tanggal"))) {
|
&& hargaJual.equals(map.get("hargaJual"))
|
||||||
jumlah += Double.parseDouble(map.get("jumlah").toString());
|
&& idKelompokPasien.equals(map.get("idKelompokPasien"))
|
||||||
norecs.add(map.get("idPelayananPasien").toString());
|
&& jenisRuangan.equals(map.get("jenisRuangan"))
|
||||||
dataHitungKe++;
|
&& tanggal.equals(map.get("tanggal"))) {
|
||||||
if (dataHitungKe == 1)
|
jumlah += Double.parseDouble(map.get("jumlah").toString());
|
||||||
mapData.putAll(map);
|
norecs.add(map.get("idPelayananPasien").toString());
|
||||||
|
dataHitungKe++;
|
||||||
|
if (dataHitungKe == 1)
|
||||||
|
mapData.putAll(map);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (CommonUtil.isNotNullOrEmpty(mapData.get("jumlah"))) {
|
||||||
|
mapData.put("jumlah", jumlah);
|
||||||
|
mapData.put("norecs", norecs);
|
||||||
|
dataTanggal.add(mapData);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if (CommonUtil.isNotNullOrEmpty(mapData.get("jumlah"))) {
|
|
||||||
mapData.put("jumlah", jumlah);
|
|
||||||
mapData.put("norecs", norecs);
|
|
||||||
dataTanggal.add(mapData);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1373,42 +1683,46 @@ public class PelayananPasienServiceImpl extends BaseVoServiceImpl implements Pel
|
|||||||
*/
|
*/
|
||||||
for (Integer idProduk : listIdProduk) {
|
for (Integer idProduk : listIdProduk) {
|
||||||
for (String persenJasa : listPersenJasa) {
|
for (String persenJasa : listPersenJasa) {
|
||||||
for (Double hargaJual : listHargaJual) {
|
for (Double hargaJasa : listHargaJasa) {
|
||||||
for (Integer idKelompokPasien : listIdKelompokPasien) {
|
for (Double hargaJual : listHargaJual) {
|
||||||
for (String jenisRuangan : listJenisRuangan) {
|
for (Integer idKelompokPasien : listIdKelompokPasien) {
|
||||||
Map<String, Object> mapResult = new HashMap<>();
|
for (String jenisRuangan : listJenisRuangan) {
|
||||||
List<Map<String, Object>> detail = new ArrayList<>();
|
Map<String, Object> mapResult = new HashMap<>();
|
||||||
int counter = 0;
|
List<Map<String, Object>> detail = new ArrayList<>();
|
||||||
double jumlah = 0.0;
|
int counter = 0;
|
||||||
double jumlahHargaJasa = 0.0;
|
double jumlah = 0.0;
|
||||||
for (Map<String, Object> map : dataTanggal) {
|
double jumlahHargaJasa = 0.0;
|
||||||
Map<String, Object> mapCount = new HashMap<>();
|
for (Map<String, Object> map : dataTanggal) {
|
||||||
if (idProduk.equals(map.get("idProduk")) && persenJasa.equals(map.get("persenJasa"))
|
Map<String, Object> mapCount = new HashMap<>();
|
||||||
&& hargaJual.equals(map.get("hargaJual"))
|
if (idProduk.equals(map.get("idProduk")) && persenJasa.equals(map.get("persenJasa"))
|
||||||
&& idKelompokPasien.equals(map.get("idKelompokPasien"))
|
&& hargaJasa.equals(map.get("hargaJasa"))
|
||||||
&& jenisRuangan.equals(map.get("jenisRuangan"))) {
|
&& hargaJual.equals(map.get("hargaJual"))
|
||||||
mapCount.put("jumlah", map.get("jumlah"));
|
&& idKelompokPasien.equals(map.get("idKelompokPasien"))
|
||||||
mapCount.put("norecs", map.get("norecs"));
|
&& jenisRuangan.equals(map.get("jenisRuangan"))) {
|
||||||
mapCount.put("tanggal", map.get("tanggal"));
|
mapCount.put("jumlah", map.get("jumlah"));
|
||||||
detail.add(mapCount);
|
mapCount.put("norecs", map.get("norecs"));
|
||||||
counter++;
|
mapCount.put("tanggal", map.get("tanggal"));
|
||||||
jumlah += Double.parseDouble(map.get("jumlah").toString());
|
detail.add(mapCount);
|
||||||
if (counter == 1)
|
counter++;
|
||||||
mapResult.putAll(map);
|
jumlah += Double.parseDouble(map.get("jumlah").toString());
|
||||||
|
if (counter == 1)
|
||||||
|
mapResult.putAll(map);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (CommonUtil.isNotNullOrEmpty(mapResult.get("jumlah"))) {
|
||||||
|
/*
|
||||||
|
* Tambahkan data total
|
||||||
|
*/
|
||||||
|
jumlahHargaJasa = jumlah
|
||||||
|
* Double.parseDouble(mapResult.get("hargaJasa").toString());
|
||||||
|
mapResult.put("jumlah", jumlah);
|
||||||
|
mapResult.put("jumlahHargaJasa", jumlahHargaJasa);
|
||||||
|
/*
|
||||||
|
* Tambahkan data detail
|
||||||
|
*/
|
||||||
|
mapResult.put("detail", detail);
|
||||||
|
result.add(mapResult);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if (CommonUtil.isNotNullOrEmpty(mapResult.get("jumlah"))) {
|
|
||||||
/*
|
|
||||||
* Tambahkan data total
|
|
||||||
*/
|
|
||||||
jumlahHargaJasa = jumlah * Double.parseDouble(mapResult.get("hargaJasa").toString());
|
|
||||||
mapResult.put("jumlah", jumlah);
|
|
||||||
mapResult.put("jumlahHargaJasa", jumlahHargaJasa);
|
|
||||||
/*
|
|
||||||
* Tambahkan data detail
|
|
||||||
*/
|
|
||||||
mapResult.put("detail", detail);
|
|
||||||
result.add(mapResult);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user