Update router and data grid components
This commit is contained in:
parent
d8c5a956db
commit
e7d0af9329
@ -3,73 +3,30 @@
|
|||||||
<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"
|
||||||
:data-source="data"
|
@selection-changed="onSelectionChanged" @exporting="onExporting" :allow-column-resizing="true"
|
||||||
:show-column-lines="true"
|
column-resizing-mode="widget" :word-wrap-enabled="true">
|
||||||
:show-row-lines="false"
|
|
||||||
: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
|
<DxColumn :width="50" alignment="center" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1"
|
||||||
:width="50"
|
caption="NO" css-class="custom-table-column" />
|
||||||
alignment="center"
|
<DxColumn alignment="center" data-field="id_jenis_keluhan" caption="ID Keluhan" css-class="custom-table-column" />
|
||||||
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1"
|
<DxColumn alignment="center" data-field="nama_jenis_keluhan" caption="Jenis Keluhan"
|
||||||
caption="NO"
|
css-class="custom-table-column" />
|
||||||
css-class="custom-table-column"
|
<DxColumn :width="170" alignment="center" data-field="jumlah" caption="Jumlah" css-class="custom-table-column" />
|
||||||
/>
|
<DxColumn :width="120" alignment="center" data-field="persen" caption="%" css-class="custom-table-column"
|
||||||
<DxColumn
|
cell-template="percent" />
|
||||||
alignment="center"
|
<template #percent="{ data }">
|
||||||
data-field="id_keluhan"
|
{{ data.text }}%
|
||||||
caption="ID Keluhan"
|
</template>
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
alignment="center"
|
|
||||||
data-field="jenis_keluhan"
|
|
||||||
caption="Jenis Keluhan"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="170"
|
|
||||||
alignment="center"
|
|
||||||
data-field="jumlah"
|
|
||||||
caption="Jumlah"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="120"
|
|
||||||
alignment="center"
|
|
||||||
data-field="persen_keluhan"
|
|
||||||
caption="%"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
</DxDataGrid>
|
</DxDataGrid>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -137,59 +94,52 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
|
|||||||
const data = selectedRowsData[0]
|
const data = selectedRowsData[0]
|
||||||
console.log(data)
|
console.log(data)
|
||||||
}
|
}
|
||||||
const monalisaKeluhanPerJenisKeluhan = gql`
|
const monalisaGangguanPerJenisKeluhan = gql`
|
||||||
query DaftarmonalisaKeluhanPerJenisKeluhan(
|
query DaftarmonalisaGangguanPerJenisKeluhan(
|
||||||
$regional: String
|
#$regional: String
|
||||||
$posko: Int
|
$idUlp: Int
|
||||||
$idUid: Int
|
$idUid: Int
|
||||||
$idUp3: Int
|
$idUp3: Int
|
||||||
$bulan: Int
|
$bulan: Int
|
||||||
$tahun: Int
|
$tahun: Int
|
||||||
) {
|
) {
|
||||||
monalisaKeluhanPerJenisKeluhan(
|
monalisaGangguanPerJenisKeluhan(
|
||||||
regional: $regional
|
#regional: $regional
|
||||||
posko: $posko
|
idUlp: $idUlp
|
||||||
idUid: $idUid
|
idUid: $idUid
|
||||||
idUp3: $idUp3
|
idUp3: $idUp3
|
||||||
bulan: $bulan
|
bulan: $bulan
|
||||||
tahun: $tahun
|
tahun: $tahun
|
||||||
) {
|
) {
|
||||||
id_keluhan
|
id_jenis_keluhan
|
||||||
|
nama_jenis_keluhan
|
||||||
jumlah
|
jumlah
|
||||||
persen_keluhan
|
persen
|
||||||
tipe_permasalahan
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
const { onResult, onError, loading, refetch } = useQuery(monalisaKeluhanPerJenisKeluhan, {
|
const { onResult, onError, loading, refetch } = useQuery(monalisaGangguanPerJenisKeluhan, {
|
||||||
bulan: 10,
|
bulan: 10,
|
||||||
tahun: 2023,
|
tahun: 2023,
|
||||||
|
idUlp: 0,
|
||||||
regional: '',
|
regional: '',
|
||||||
posko: '',
|
|
||||||
idUid: 0,
|
idUid: 0,
|
||||||
idUp3: 0
|
idUp3: 0
|
||||||
})
|
})
|
||||||
const filterData = (params: any) => {
|
const filterData = (params: any) => {
|
||||||
const { regional, posko, idUid, idUp3, bulan, tahun } = params
|
const { regional, ulp, uid, up3, bulan, tahun } = params
|
||||||
|
|
||||||
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.monalisaKeluhanPerJenisKeluhan.forEach((item: any) => {
|
data.value = queryResult.data.monalisaGangguanPerJenisKeluhan
|
||||||
data.value = [
|
|
||||||
...data.value,
|
|
||||||
{
|
|
||||||
...item
|
|
||||||
}
|
|
||||||
]
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
console.log(queryResult.data)
|
console.log(queryResult.data)
|
||||||
console.log(queryResult.loading)
|
console.log(queryResult.loading)
|
||||||
|
@ -3,71 +3,27 @@
|
|||||||
<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"
|
||||||
:data-source="data"
|
@selection-changed="onSelectionChanged" @exporting="onExporting" :allow-column-resizing="true"
|
||||||
:show-column-lines="true"
|
column-resizing-mode="widget" :word-wrap-enabled="true">
|
||||||
:show-row-lines="false"
|
|
||||||
: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
|
<DxColumn alignment="center" data-field="nama_ulp" caption="Nama Unit" css-class="custom-table-column" />
|
||||||
alignment="center"
|
|
||||||
data-field="nama_posko"
|
|
||||||
caption="Nama Unit"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn alignment="center" caption="Tahun" css-class="custom-table-column">
|
<DxColumn alignment="center" caption="Tahun" css-class="custom-table-column">
|
||||||
<DxColumn
|
<DxColumn :width="150" alignment="center" data-field="jumlah_keluhan" data-type="number" caption="Keluhan"
|
||||||
:width="150"
|
css-class="custom-table-column" />
|
||||||
alignment="center"
|
<DxColumn :width="150" alignment="center" data-field="jumlah_informasi" data-type="number" caption="Informasi"
|
||||||
data-field="keluhan"
|
css-class="custom-table-column" />
|
||||||
data-type="number"
|
<DxColumn :width="150" alignment="center" data-field="total" data-type="number" caption="Total"
|
||||||
caption="Keluhan"
|
css-class="custom-table-column" />
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="150"
|
|
||||||
alignment="center"
|
|
||||||
data-field="informasi"
|
|
||||||
data-type="number"
|
|
||||||
caption="Informasi"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="150"
|
|
||||||
alignment="center"
|
|
||||||
data-field="total"
|
|
||||||
data-type="number"
|
|
||||||
caption="Total"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
</DxColumn>
|
</DxColumn>
|
||||||
</DxDataGrid>
|
</DxDataGrid>
|
||||||
</div>
|
</div>
|
||||||
@ -137,57 +93,56 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
|
|||||||
}
|
}
|
||||||
const monalisaRekapitulasiKeluhanBelumSelesai = gql`
|
const monalisaRekapitulasiKeluhanBelumSelesai = gql`
|
||||||
query DaftarmonalisaRekapitulasiKeluhanBelumSelesai(
|
query DaftarmonalisaRekapitulasiKeluhanBelumSelesai(
|
||||||
$regional: String
|
#$regional: String
|
||||||
$posko: Int
|
$idUlp: Int
|
||||||
$idUid: Int
|
$idUid: Int
|
||||||
$idUp3: Int
|
$idUp3: Int
|
||||||
$bulan: Int
|
$bulan: Int
|
||||||
$tahun: Int
|
$tahun: Int
|
||||||
) {
|
) {
|
||||||
monalisaRekapitulasiKeluhanBelumSelesai(
|
monalisaRekapitulasiKeluhanBelumSelesai(
|
||||||
regional: $regional
|
#regional: $regional
|
||||||
posko: $posko
|
idUlp: $idUlp
|
||||||
idUid: $idUid
|
idUid: $idUid
|
||||||
idUp3: $idUp3
|
idUp3: $idUp3
|
||||||
bulan: $bulan
|
bulan: $bulan
|
||||||
tahun: $tahun
|
tahun: $tahun
|
||||||
) {
|
) {
|
||||||
keluhan
|
nama_regional
|
||||||
informasi
|
id_uid
|
||||||
nama_posko
|
nama_uid
|
||||||
|
id_up3
|
||||||
|
nama_up3
|
||||||
|
id_ulp
|
||||||
|
nama_ulp
|
||||||
|
jumlah_keluhan
|
||||||
|
jumlah_informasi
|
||||||
total
|
total
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
const { onResult, onError, loading, refetch } = useQuery(monalisaRekapitulasiKeluhanBelumSelesai, {
|
const { onResult, onError, loading, refetch } = useQuery(monalisaRekapitulasiKeluhanBelumSelesai, {
|
||||||
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
|
||||||
|
|
||||||
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.monalisaRekapitulasiKeluhanBelumSelesai.forEach((item: any) => {
|
data.value = queryResult.data.monalisaRekapitulasiKeluhanBelumSelesai
|
||||||
data.value = [
|
|
||||||
...data.value,
|
|
||||||
{
|
|
||||||
...item
|
|
||||||
}
|
|
||||||
]
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
console.log(queryResult.data)
|
console.log(queryResult.data)
|
||||||
console.log(queryResult.loading)
|
console.log(queryResult.loading)
|
||||||
|
@ -3,100 +3,43 @@
|
|||||||
<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"
|
||||||
:data-source="data"
|
@selection-changed="onSelectionChanged" @exporting="onExporting" :allow-column-resizing="true"
|
||||||
:show-column-lines="true"
|
column-resizing-mode="widget" :word-wrap-enabled="true">
|
||||||
:show-row-lines="false"
|
|
||||||
: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
|
<DxColumn :width="200" alignment="center" data-field="nama_ulp" caption="Nama Unit"
|
||||||
alignment="center"
|
css-class="custom-table-column" />
|
||||||
data-field="nama_posko"
|
|
||||||
caption="Nama Unit"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn alignment="center" caption="Lapor Ulang Keluhan" css-class="custom-table-column">
|
<DxColumn alignment="center" caption="Lapor Ulang Keluhan" css-class="custom-table-column">
|
||||||
<DxColumn alignment="center" caption="MoM" css-class="custom-table-column">
|
<DxColumn alignment="center" caption="MoM" css-class="custom-table-column">
|
||||||
<DxColumn
|
<DxColumn :width="150" alignment="center" data-field="mom_bulan_kemarin" data-type="number"
|
||||||
:width="150"
|
:caption="`${getMonthName(currentMonth)} ${lastYear}`" css-class="custom-table-column" />
|
||||||
alignment="center"
|
<DxColumn :width="150" alignment="center" data-field="mom_bulan_ini" data-type="number"
|
||||||
data-field="jumlah_bulan"
|
:caption="`${getMonthName(currentMonth)} ${currentYear}`" css-class="custom-table-column" />
|
||||||
data-type="number"
|
<DxColumn :width="150" alignment="center" data-field="persen_mom" data-type="number" caption="%"
|
||||||
:caption="`${getMonthName(bulanSekarang)} ${tahunLalu}`"
|
css-class="custom-table-column" cell-template="percent" />
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="150"
|
|
||||||
alignment="center"
|
|
||||||
data-field="jumlah_bulan_n_1"
|
|
||||||
data-type="number"
|
|
||||||
:caption="`${getMonthName(bulanSekarang)} ${tahunSekarang}`"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="150"
|
|
||||||
alignment="center"
|
|
||||||
data-field="persen_bulan"
|
|
||||||
data-type="number"
|
|
||||||
caption="%"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
</DxColumn>
|
</DxColumn>
|
||||||
<DxColumn alignment="center" caption="YoY" css-class="custom-table-column">
|
<DxColumn alignment="center" caption="YoY" css-class="custom-table-column">
|
||||||
<DxColumn
|
<DxColumn :width="150" alignment="center" data-field="yoy_tahun_kemarin" data-type="number"
|
||||||
:width="150"
|
:caption="`s.d ${getMonthName(currentMonth)} ${lastYear}`" css-class="custom-table-column" />
|
||||||
alignment="center"
|
<DxColumn :width="150" alignment="center" data-field="yoy_tahun_ini" data-type="number"
|
||||||
data-field="jumlah_tahun"
|
:caption="`s.d ${getMonthName(currentMonth)} ${currentYear}`" css-class="custom-table-column" />
|
||||||
data-type="number"
|
<DxColumn :width="150" alignment="center" data-field="persen_yoy" data-type="number" caption="%"
|
||||||
:caption="`s.d ${getMonthName(bulanSekarang)} ${tahunLalu}`"
|
css-class="custom-table-column" cell-template="percent" />
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="150"
|
|
||||||
alignment="center"
|
|
||||||
data-field="jumlah_tahun_n_1"
|
|
||||||
data-type="number"
|
|
||||||
:caption="`s.d ${getMonthName(bulanSekarang)} ${tahunSekarang}`"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
<DxColumn
|
|
||||||
:width="150"
|
|
||||||
alignment="center"
|
|
||||||
data-field="persen_tahun"
|
|
||||||
data-type="number"
|
|
||||||
caption="%"
|
|
||||||
css-class="custom-table-column"
|
|
||||||
/>
|
|
||||||
</DxColumn>
|
</DxColumn>
|
||||||
</DxColumn>
|
</DxColumn>
|
||||||
|
|
||||||
|
<template #percent="{ data }">
|
||||||
|
{{ data.text }}%
|
||||||
|
</template>
|
||||||
</DxDataGrid>
|
</DxDataGrid>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -131,9 +74,9 @@ 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 currentYear = ref(new Date().getFullYear())
|
||||||
const bulanSekarang = ref(new Date().getMonth())
|
const currentMonth = ref(new Date().getMonth())
|
||||||
const tahunLalu = ref(tahunSekarang.value - 1)
|
const lastYear = ref(currentYear.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()
|
||||||
@ -169,28 +112,34 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
|
|||||||
}
|
}
|
||||||
const monalisaRekapitulasiLaporUlangKeluhan = gql`
|
const monalisaRekapitulasiLaporUlangKeluhan = gql`
|
||||||
query DaftarmonalisaRekapitulasiLaporUlangKeluhan(
|
query DaftarmonalisaRekapitulasiLaporUlangKeluhan(
|
||||||
$regional: String
|
#$regional: String
|
||||||
$posko: Int
|
$idUlp: Int
|
||||||
$idUid: Int
|
$idUid: Int
|
||||||
$idUp3: Int
|
$idUp3: Int
|
||||||
$bulan: Int
|
$bulan: Int
|
||||||
$tahun: Int
|
$tahun: Int
|
||||||
) {
|
) {
|
||||||
monalisaRekapitulasiLaporUlangKeluhan(
|
monalisaRekapitulasiLaporUlangKeluhan(
|
||||||
regional: $regional
|
#regional: $regional
|
||||||
posko: $posko
|
idUlp: $idUlp
|
||||||
idUid: $idUid
|
idUid: $idUid
|
||||||
idUp3: $idUp3
|
idUp3: $idUp3
|
||||||
bulan: $bulan
|
bulan: $bulan
|
||||||
tahun: $tahun
|
tahun: $tahun
|
||||||
) {
|
) {
|
||||||
jumlah_bulan
|
nama_regional
|
||||||
jumlah_bulan_n_1
|
id_uid
|
||||||
jumlah_tahun
|
nama_uid
|
||||||
jumlah_tahun_n_1
|
id_up3
|
||||||
nama_posko
|
nama_up3
|
||||||
persen_bulan
|
id_ulp
|
||||||
persen_tahun
|
nama_ulp
|
||||||
|
mom_bulan_ini
|
||||||
|
mom_bulan_kemarin
|
||||||
|
persen_mom
|
||||||
|
yoy_tahun_ini
|
||||||
|
yoy_tahun_kemarin
|
||||||
|
persen_yoy
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
@ -198,33 +147,26 @@ const { onResult, onError, loading, refetch } = useQuery(monalisaRekapitulasiLap
|
|||||||
bulan: 10,
|
bulan: 10,
|
||||||
tahun: 2023,
|
tahun: 2023,
|
||||||
regional: '',
|
regional: '',
|
||||||
posko: '',
|
idUlp: 0,
|
||||||
idUid: 0,
|
idUid: 0,
|
||||||
idUp3: 0
|
idUp3: 0
|
||||||
})
|
})
|
||||||
const filterData = (params: any) => {
|
const filterData = (params: any) => {
|
||||||
const { regional, posko, idUid, idUp3, bulan, tahun } = params
|
const { regional, ulp, uid, up3, bulan, tahun } = params
|
||||||
bulanSekarang.value = bulan.id
|
currentMonth.value = bulan.id
|
||||||
tahunSekarang.value = tahun.id
|
currentYear.value = tahun.id
|
||||||
tahunLalu.value = tahun.id - 1
|
lastYear.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.monalisaRekapitulasiLaporUlangKeluhan.forEach((item: any) => {
|
data.value = queryResult.data.monalisaRekapitulasiLaporUlangKeluhan
|
||||||
data.value = [
|
|
||||||
...data.value,
|
|
||||||
{
|
|
||||||
...item
|
|
||||||
}
|
|
||||||
]
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
console.log(queryResult.data)
|
console.log(queryResult.data)
|
||||||
console.log(queryResult.loading)
|
console.log(queryResult.loading)
|
||||||
|
@ -423,7 +423,7 @@ export const routes: RouteRecordRaw[] = [
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: '5',
|
path: '5',
|
||||||
name: 'Rekapitulasi Gangguan Per Jenis Keluhan',
|
name: 'Rekapitulasi Keluhan Per Jenis Keluhan',
|
||||||
component: MonalisaKRGangguanPerJenisKeluhan
|
component: MonalisaKRGangguanPerJenisKeluhan
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user