Merge branch 'dev-defuj' of github.com:defuj/eis into dev-bagus
This commit is contained in:
commit
06f1ade438
@ -3,118 +3,77 @@
|
|||||||
<Type2 @update:filters="(value) => (filters = value)" />
|
<Type2 @update:filters="(value) => (filters = value)" />
|
||||||
</Filters>
|
</Filters>
|
||||||
<div id="data">
|
<div id="data">
|
||||||
<DxDataGrid
|
<DxDataGrid class="max-h-[calc(100vh-140px)] mb-10" :data-source="data" :show-column-lines="true"
|
||||||
class="max-h-[calc(100vh-140px)] mb-10"
|
:show-row-lines="false" :show-borders="true" :row-alternation-enabled="true" :hover-state-enabled="true"
|
||||||
:show-column-lines="true"
|
@selection-changed="onSelectionChanged" :column-width="100" @exporting="onExporting" :allow-column-resizing="true"
|
||||||
:show-row-lines="false"
|
column-resizing-mode="widget" :word-wrap-enabled="true">
|
||||||
:show-borders="true"
|
|
||||||
:row-alternation-enabled="true"
|
|
||||||
:hover-state-enabled="true"
|
|
||||||
@selection-changed="onSelectionChanged"
|
|
||||||
@exporting="onExporting"
|
|
||||||
:allow-column-resizing="true"
|
|
||||||
column-resizing-mode="widget"
|
|
||||||
:word-wrap-enabled="true"
|
|
||||||
>
|
|
||||||
<DxSelection mode="single" />
|
<DxSelection mode="single" />
|
||||||
<DxPaging :enabled="false" />
|
<DxPaging :enabled="false" />
|
||||||
<DxScrolling column-rendering-mode="virtual" mode="virtual" />
|
<DxScrolling column-rendering-mode="virtual" mode="virtual" />
|
||||||
<DxLoadPanel
|
<DxLoadPanel :position="position" :show-indicator="showIndicator" :show-pane="showPane" :shading="shading"
|
||||||
:position="position"
|
v-if="loading" v-model:visible="loading" :enabled="true" />
|
||||||
:show-indicator="showIndicator"
|
|
||||||
:show-pane="showPane"
|
|
||||||
:shading="shading"
|
|
||||||
v-if="loading"
|
|
||||||
v-model:visible="loading"
|
|
||||||
:enabled="true"
|
|
||||||
/>
|
|
||||||
<DxSearchPanel :visible="true" :highlight-case-sensitive="true" />
|
<DxSearchPanel :visible="true" :highlight-case-sensitive="true" />
|
||||||
<DxExport
|
<DxExport :enabled="true" :formats="['pdf', 'xlsx', 'document']" :allow-export-selected-data="false" />
|
||||||
:enabled="true"
|
|
||||||
:formats="['pdf', 'xlsx', 'document']"
|
|
||||||
:allow-export-selected-data="false"
|
|
||||||
/>
|
|
||||||
<DxColumnFixing :enabled="true" />
|
<DxColumnFixing :enabled="true" />
|
||||||
<DxColumn alignment="center" caption="Periode: Februari,2020" css-class="custom-table-column">
|
|
||||||
<DxColumn
|
<DxColumn :width="170" alignment="center" data-field="nama_ulp" caption="Nama Unit"
|
||||||
alignment="center"
|
css-class="custom-table-column" />
|
||||||
data-field="nama_posko"
|
|
||||||
caption="Nama Unit"
|
<DxColumn alignment="center" :caption="`s.d ${getMonthName(bulanSekarang - 1)} ${tahunLalu}`"
|
||||||
css-class="custom-table-column"
|
css-class="custom-table-column">
|
||||||
/>
|
<DxColumn :width="120" alignment="center" data-field="total_keluhan_tahun_sebelumnya" data-type="number"
|
||||||
</DxColumn>
|
caption="Keluhan" css-class="custom-table-column" name="keluhanBulanLalu" />
|
||||||
<DxColumn alignment="center" caption="Aging Complains" css-class="custom-table-column">
|
<DxColumn :width="120" alignment="center" data-field="total_gangguan_tahun_sebelumnya" data-type="number"
|
||||||
<DxColumn
|
caption="Gangguan" css-class="custom-table-column" />
|
||||||
alignment="center"
|
<DxColumn alignment="center" caption="Informasi" css-class="custom-table-column">
|
||||||
caption="Rata-Rata RCT Gangguan"
|
<DxColumn :width="120" alignment="center" data-field="total_keluhan_informasi_tahun_sebelumnya"
|
||||||
css-class="custom-table-column"
|
data-type="number" caption="Keluhan" css-class="custom-table-column" />
|
||||||
>
|
<DxColumn :width="120" alignment="center" data-field="total_gangguan_informasi_tahun_sebelumnya"
|
||||||
<DxColumn
|
data-type="number" caption="Gangguan" css-class="custom-table-column" />
|
||||||
:width="150"
|
<DxColumn :width="120" alignment="center" data-field="total_informasi_tahun_sebelumnya" data-type="number"
|
||||||
alignment="center"
|
caption="Total" css-class="custom-table-column" />
|
||||||
data-field="rata_rct_gangguan_bulan"
|
|
||||||
data-type="number"
|
|
||||||
caption="Feb 2020"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="150"
|
|
||||||
alignment="center"
|
|
||||||
data-field="rata_rct_gangguan_sla"
|
|
||||||
data-type="number"
|
|
||||||
caption="SLA (Menit)"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
</DxColumn>
|
</DxColumn>
|
||||||
<DxColumn
|
<DxColumn alignment="center" caption="Total Komplain" css-class="custom-table-column"
|
||||||
alignment="center"
|
data-field="total_tahun_sebelumnya" data-type="number" />
|
||||||
caption="Rata-Rata RCT Keluhan"
|
</DxColumn>
|
||||||
css-class="custom-table-column"
|
|
||||||
>
|
<DxColumn alignment="center" :caption="`s.d ${getMonthName(bulanSekarang - 1)} ${tahunSekarang}`"
|
||||||
<DxColumn
|
css-class="custom-table-column">
|
||||||
:width="150"
|
<DxColumn :width="120" alignment="center" data-field="total_keluhan_tahun_ini" data-type="number"
|
||||||
alignment="center"
|
caption="Keluhan" css-class="custom-table-column" />
|
||||||
data-field="rata_rct_keluhan_bulan"
|
<DxColumn :width="120" alignment="center" data-field="total_gangguan_tahun_ini" data-type="number"
|
||||||
data-type="number"
|
caption="Gangguan" css-class="custom-table-column" />
|
||||||
caption="Feb 2020"
|
<DxColumn alignment="center" caption="Informasi" css-class="custom-table-column">
|
||||||
css-class="custom-table-column"
|
<DxColumn :width="120" alignment="center" data-field="total_keluhan_informasi_tahun_ini" data-type="number"
|
||||||
/>
|
caption="Keluhan" css-class="custom-table-column" />
|
||||||
<DxColumn
|
<DxColumn :width="120" alignment="center" data-field="total_gangguan_informasi_tahun_ini" data-type="number"
|
||||||
:width="150"
|
caption="Gangguan" css-class="custom-table-column" />
|
||||||
alignment="center"
|
<DxColumn :width="120" alignment="center" data-field="total_informasi_tahun_ini" data-type="number"
|
||||||
data-field="rata_rct_keluhan_sla"
|
caption="Total" css-class="custom-table-column" />
|
||||||
data-type="number"
|
|
||||||
caption="SLA (Jam)"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
</DxColumn>
|
</DxColumn>
|
||||||
|
<DxColumn alignment="center" caption="Total Komplain" css-class="custom-table-column" data-field="total_tahun_ini"
|
||||||
|
data-type="number" />
|
||||||
</DxColumn>
|
</DxColumn>
|
||||||
<DxColumn alignment="center" caption="% Aging Complains" css-class="custom-table-column">
|
|
||||||
<DxColumn
|
<DxColumn alignment="center" caption="Delta Penurunan" css-class="custom-table-column">
|
||||||
:width="150"
|
<DxColumn :width="150" alignment="center" data-field="delta_keluhan" data-type="number" caption="Keluhan"
|
||||||
alignment="center"
|
css-class="custom-table-column" />
|
||||||
data-field="aging_komplain_gangguan"
|
<DxColumn :width="150" alignment="center" data-field="delta_gangguan" data-type="number" caption="Gangguan"
|
||||||
data-type="number"
|
css-class="custom-table-column" />
|
||||||
caption="G"
|
<DxColumn :width="150" alignment="center" data-field="delta_informasi" data-type="number" caption="Informasi"
|
||||||
css-class="custom-table-column"
|
css-class="custom-table-column" />
|
||||||
/>
|
</DxColumn>
|
||||||
<DxColumn
|
|
||||||
:width="150"
|
<DxColumn alignment="center" caption="% Penurunan YoY" css-class="custom-table-column">
|
||||||
alignment="center"
|
<DxColumn :width="150" alignment="center" data-field="persen_delta_keluhan" data-type="number" caption="Keluhan"
|
||||||
data-field="aging_komplain_keluhan"
|
css-class="custom-table-column" />
|
||||||
data-type="number"
|
<DxColumn :width="150" alignment="center" data-field="persen_delta_gangguan" data-type="number" caption="Gangguan"
|
||||||
caption="K"
|
css-class="custom-table-column" />
|
||||||
css-class="custom-table-column"
|
<DxColumn :width="150" alignment="center" data-field="persen_delta_informasi" data-type="number"
|
||||||
/>
|
caption="Informasi" css-class="custom-table-column" />
|
||||||
|
<DxColumn :width="150" alignment="center" data-field="persen_delta_total" data-type="number" caption="% Total"
|
||||||
|
css-class="custom-table-column" />
|
||||||
</DxColumn>
|
</DxColumn>
|
||||||
<DxColumn
|
|
||||||
:width="170"
|
|
||||||
alignment="center"
|
|
||||||
data-field="persen_rata_aging_komplain"
|
|
||||||
data-type="number"
|
|
||||||
caption="% Rata-Rata Aging Complains"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
</DxDataGrid>
|
</DxDataGrid>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -141,6 +100,7 @@ import { saveAs } from 'file-saver'
|
|||||||
import { Workbook } from 'exceljs'
|
import { Workbook } from 'exceljs'
|
||||||
import { useQuery } from '@vue/apollo-composable'
|
import { useQuery } from '@vue/apollo-composable'
|
||||||
import gql from 'graphql-tag'
|
import gql from 'graphql-tag'
|
||||||
|
import { getMonthName } from '@/utils/texts'
|
||||||
const position = { of: '#data' }
|
const position = { of: '#data' }
|
||||||
const showIndicator = ref(true)
|
const showIndicator = ref(true)
|
||||||
const shading = ref(true)
|
const shading = ref(true)
|
||||||
@ -148,6 +108,10 @@ const showPane = ref(true)
|
|||||||
const data = ref<any[]>([])
|
const data = ref<any[]>([])
|
||||||
const dataDetail = ref<any>()
|
const dataDetail = ref<any>()
|
||||||
const showDetail = ref(false)
|
const showDetail = ref(false)
|
||||||
|
const tahunSekarang = ref(new Date().getFullYear())
|
||||||
|
const bulanSekarang = ref(new Date().getMonth())
|
||||||
|
const tahunLalu = ref(tahunSekarang.value - 1)
|
||||||
|
|
||||||
const onExporting = (e: any) => {
|
const onExporting = (e: any) => {
|
||||||
if (e.format === 'pdf') {
|
if (e.format === 'pdf') {
|
||||||
const doc = new jsPDF()
|
const doc = new jsPDF()
|
||||||
@ -183,73 +147,75 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
|
|||||||
}
|
}
|
||||||
const penurunanJumlahKomplainKumulatif = gql`
|
const penurunanJumlahKomplainKumulatif = gql`
|
||||||
query DaftarpenurunanJumlahKomplainKumulatif(
|
query DaftarpenurunanJumlahKomplainKumulatif(
|
||||||
$regional: String
|
#$regional: String
|
||||||
$posko: Int
|
$idUlp: Int
|
||||||
$idUid: Int
|
$idUid: Int
|
||||||
$idUp3: Int
|
$idUp3: Int
|
||||||
$bulan: Int
|
$bulan: Int
|
||||||
$tahun: Int
|
$tahun: Int
|
||||||
) {
|
) {
|
||||||
penurunanJumlahKomplainKumulatif(
|
penurunanJumlahKomplainKumulatif(
|
||||||
regional: $regional
|
#regional: $regional
|
||||||
posko: $posko
|
idUlp: $idUlp
|
||||||
idUid: $idUid
|
idUid: $idUid
|
||||||
idUp3: $idUp3
|
idUp3: $idUp3
|
||||||
bulan: $bulan
|
bulan: $bulan
|
||||||
tahun: $tahun
|
tahun: $tahun
|
||||||
) {
|
) {
|
||||||
delta_penurunan_gangguan
|
nama_regional
|
||||||
delta_penurunan_informasi
|
id_uid
|
||||||
delta_penurunan_keluhan
|
nama_uid
|
||||||
gangguan_bulan_ini
|
id_up3
|
||||||
gangguan_bulan_lalu
|
nama_up3
|
||||||
informasi_gangguan_bulan_ini
|
id_ulp
|
||||||
informasi_gangguan_bulan_lalu
|
nama_ulp
|
||||||
informasi_keluhan_bulan_ini
|
total_gangguan_tahun_ini
|
||||||
informasi_keluhan_bulan_lalu
|
total_keluhan_tahun_ini
|
||||||
keluhan_bulan_ini
|
total_gangguan_informasi_tahun_ini
|
||||||
keluhan_bulan_lalu
|
total_keluhan_informasi_tahun_ini
|
||||||
nama_posko
|
total_informasi_tahun_ini
|
||||||
persen_penurunan_gangguan
|
total_tahun_ini
|
||||||
persen_penurunan_informasi
|
total_gangguan_tahun_sebelumnya
|
||||||
persen_penurunan_keluhan
|
total_keluhan_tahun_sebelumnya
|
||||||
persen_penurunan_total
|
total_gangguan_informasi_tahun_sebelumnya
|
||||||
total_bulan_ini
|
total_keluhan_informasi_tahun_sebelumnya
|
||||||
total_bulan_lalu
|
total_informasi_tahun_sebelumnya
|
||||||
total_komplain_bulan_ini
|
total_tahun_sebelumnya
|
||||||
total_komplain_bulan_lalu
|
delta_gangguan
|
||||||
|
delta_keluhan
|
||||||
|
delta_informasi
|
||||||
|
persen_delta_gangguan
|
||||||
|
persen_delta_keluhan
|
||||||
|
persen_delta_informasi
|
||||||
|
persen_delta_total
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
const { onResult, onError, loading, refetch } = useQuery(penurunanJumlahKomplainKumulatif, {
|
const { onResult, onError, loading, refetch } = useQuery(penurunanJumlahKomplainKumulatif, {
|
||||||
regional: '',
|
regional: '',
|
||||||
posko: '',
|
idUlp: 0,
|
||||||
idUid: 0,
|
idUid: 0,
|
||||||
idUp3: 0,
|
idUp3: 0,
|
||||||
bulan: 10,
|
bulan: 10,
|
||||||
tahun: 2023
|
tahun: 2023
|
||||||
})
|
})
|
||||||
const filterData = (params: any) => {
|
const filterData = (params: any) => {
|
||||||
const { regional, posko, idUid, idUp3, bulan, tahun } = params
|
const { regional, ulp, uid, up3, bulan, tahun } = params
|
||||||
|
tahunSekarang.value = tahun.id
|
||||||
|
bulanSekarang.value = bulan.id
|
||||||
|
tahunLalu.value = tahun.id - 1
|
||||||
|
|
||||||
refetch({
|
refetch({
|
||||||
regional: regional,
|
regional: regional,
|
||||||
posko: posko ? posko.id : 0,
|
idUlp: ulp ? ulp.id : 0,
|
||||||
idUid: idUid ? idUid.id : 0,
|
idUid: uid ? uid.id : 0,
|
||||||
idUp3: idUp3 ? idUp3.id : 0,
|
idUp3: up3 ? up3.id : 0,
|
||||||
bulan: bulan ? bulan.id : 10,
|
bulan: bulan ? bulan.id : 10,
|
||||||
tahun: bulan ? tahun.id : 2023
|
tahun: bulan ? tahun.id : 2023
|
||||||
})
|
})
|
||||||
onResult((queryResult) => {
|
onResult((queryResult) => {
|
||||||
if (queryResult.data != undefined) {
|
if (queryResult.data != undefined) {
|
||||||
queryResult.data.penurunanJumlahKomplainKumulatif.forEach((item: any) => {
|
data.value = queryResult.data.penurunanJumlahKomplainKumulatif
|
||||||
data.value = [
|
|
||||||
...data.value,
|
|
||||||
{
|
|
||||||
...item
|
|
||||||
}
|
|
||||||
]
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
console.log(queryResult.data)
|
console.log(queryResult.data)
|
||||||
console.log(queryResult.loading)
|
console.log(queryResult.loading)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user