change file name and directory network.ts n graphql

This commit is contained in:
Dede Fuji Abdul 2024-03-07 22:01:44 +07:00
parent b99be65200
commit ce38a5711c
59 changed files with 1182 additions and 3137 deletions

View File

@ -1,6 +1,6 @@
import { usePostsStore } from '@/stores/posts' import { usePostsStore } from '@/stores/posts'
import { useUlpStore } from '@/stores/ulp' import { useUlpStore } from '@/stores/ulp'
import { getUid, getUp3, getPosko, getUlp, getRegional, getUidRegional } from '@/utils/network' import { getUid, getUp3, getPosko, getUlp, getRegional, getUidRegional } from '@/utils/api/api.rest'
import { ref } from 'vue' import { ref } from 'vue'
interface Item { interface Item {
id: any id: any

View File

@ -55,10 +55,9 @@ import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs'
import { Type1 } from '@/components/Form/FiltersType'
import Filters from '@/components/Form/Filters.vue' import Filters from '@/components/Form/Filters.vue'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -139,3 +138,4 @@ const { onResult, onError, loading, refetch } = useQuery(queries.cico.laporanChe
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -85,7 +85,6 @@ import {
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
const position = { of: '#data' } const position = { of: '#data' }
@ -94,7 +93,7 @@ const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const data = ref<any[]>([]) const data = ref<any[]>([])
const { onResult, onError, loading, refetch } = useQuery(queries.gangguan.daftar.berdasarkanMedia, { const { onResult, onErr or, loading, refetch } = useQuery(qu eries.gangguan.daftar.berdasarkanMedia, {
dateFrom: new Date().toISOString().slice(0, 10), dateFrom: new Date().toISOString().slice(0, 10),
dateTo: new Date().toISOString().slice(0, 10), dateTo: new Date().toISOString().slice(0, 10),
posko: 0, posko: 0,
@ -136,3 +135,4 @@ onMounted(() => {
data.value = dummyData.gangguan.daftar.daftarGangguanBerdasarkanMedia data.value = dummyData.gangguan.daftar.daftarGangguanBerdasarkanMedia
}) })
</script> </script>
@/utils/api/graphql

View File

@ -196,14 +196,14 @@ import { formatWaktu } from '@/components/Form/FiltersType/reference'
import { onMounted, ref } from 'vue' import { onMounted, ref } from 'vue'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import autoTable from 'jspdf-autotable' import autoTable from 'jspdf-autotable'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs'
import DetailDialog from '@/components/Dialogs/DetailDialog.vue' import DetailDialog from '@/components/Dialogs/DetailDialog.vue'
import InputText from '@/components/InputText.vue' import InputText from '@/components/InputText.vue'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
impo rt { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
const position = { of: '#dataTable' } const position = { of: '#dataTable' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -355,3 +355,4 @@ onMounted(() => {
data.value = dummyData.gangguan.daftar.dialihkanKePoskoLain data.value = dummyData.gangguan.daftar.dialihkanKePoskoLain
}) })
</script> </script>
@/utils/api/graphql

View File

@ -85,17 +85,16 @@ import {
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const data = ref<any[]>([]) const data = ref < a ny[]> ([])
const { onResult, onError, loading, refetch } = useQuery( const { onResult, onError, loading, refetch } = useQuery(
queries.gangguan.daftar.diselesaikanMobileAPKT, q ueries.gangguan.daftar.diselesaikanMobileAPKT,
{ {
dateFrom: new Date('2023-10-01').toISOString().slice(0, 10), dateFrom: new Date('2023-10-01').toISOString().slice(0, 10),
dateTo: new Date('2023-10-01').toISOString().slice(0, 10), dateTo: new Date('2023-10-01').toISOString().slice(0, 10),
@ -138,3 +137,4 @@ onMounted(() => {
data.value = dummyData.gangguan.daftar.daftarGangguanDiselesaikanMobileAPKT data.value = dummyData.gangguan.daftar.daftarGangguanDiselesaikanMobileAPKT
}) })
</script> </script>
@/utils/api/graphql

View File

@ -179,7 +179,7 @@ import {
import DetailDialog from '@/components/Dialogs/DetailDialog.vue' import DetailDialog from '@/components/Dialogs/DetailDialog.vue'
import InputText from '@/components/InputText.vue' import InputText from '@/components/InputText.vue'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
import { formatNumber, isNumber } from '@/utils/numbers' import { formatNumber, isNumber } from '@/utils/numbers'
@ -244,3 +244,4 @@ onMounted(() => {
data.value = dummyData.gangguan.daftar.melaporLebihDariSatuKali data.value = dummyData.gangguan.daftar.melaporLebihDariSatuKali
}) })
</script> </script>
@/utils/api/graphql

View File

@ -192,11 +192,11 @@ import {
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) cons t showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const data = ref<any[]>([]) const data = ref<any[]>([])
@ -213,33 +213,31 @@ const showData = () => showDetail.value = true
const closeDetail = () => showDetail.value = false const closeDetail = () => showDetail.value = false
const filterData = (params: any) => { const filterData = (params: any) => {
const { minTime, maxTime, posko, uid, up3 } = params const { minT maxTime, posko, uid, up3 } = params
console.table(params); console.t(param
const dateValue = params.periode.split(' s/d ') const dateValue = params.periode.split(' s/d ')
refetch({ refetch(dateFrom: dateValue[0]
dateFrom: dateValue[0] ? dateValue[0].sp '-').r se().join('-')
? dateValue[0].split('-').reverse().join('-')
: new Date().toISOString().slice(0, 10),
dateTo: dateValue[1]
? dateValue[1].split('-').reverse().join('-')
: new Date().toISOString().slice(0, 10), : new Date().toISOString().slice(0, 10),
dateTo: dateValue[1]
? dateValue[1].split('-').reverse().join('-')
: new Date().toISOString().slice(0, 10),
minDurasiRecoveryTime: minTime ? minTime : 0, minDurasiRecoveryTime: minTime ? minTime : 0,
maxDurasiRecoveryTime: maxTime ? maxTime : 1, maxDurasiRecoveryTime: maxTime ? maxTime : 1,
posko: posko ? posko.id : 0, posko: posko ? posko.id : 0,
idUid: uid ? uid.id : 0, idUid: uid ? uid.id : 0,
idUp3: up3 ? up3.id : 0 idUp3: up3 ? up3.id : 0
})
onResult((queryResult) => {
if (queryResult.data != undefined) {
data.value = queryResult.data.daftarGangguanRecoveryTime
}
console.log(queryResult.loading)
console.log(queryResult.networkStatus)
})
onError((error) => {
console.log(error)
}) })
onResult((queryResult) => {
if (queryResult.data != undefined) {
data.value = queryResult.data.daftarGangguanRecoveryTime
}
console.log(queryResult.loading)
console.log(queryResult.networkStatus)
})
onError((error) => {
console.log(error)
})
} }
@ -258,3 +256,4 @@ onMounted(() => {
data.value = dummyData.gangguan.daftar.gangguanRecoveryTime data.value = dummyData.gangguan.daftar.gangguanRecoveryTime
}) })
</script> </script>
@/utils/api/graphql

View File

@ -178,18 +178,18 @@ import {
import DetailDialog from '@/components/Dialogs/DetailDialog.vue' import DetailDialog from '@/components/Dialogs/DetailDialog.vue'
import InputText from '@/components/InputText.vue' import InputText from '@/components/InputText.vue'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) cons t showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) 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 onSelectionChanged = ({ selectedRowsData }: any) => { const onSelectionChanged = ({ selected RowsData }: any) => {
const data = selectedRowsData[0] const data = selectedRowsData[0]
dataDetail.value = data dataDetail.value = data
} }
@ -203,27 +203,27 @@ const filterData = (params: any) => {
const dateValue = params.periode.split(' s/d ') const dateValue = params.periode.split(' s/d ')
refetch({ refetch({
dateFrom: dateValue[0] dateFrom: dateValue[0]
? dateValue[0].split('-').reverse().join('-') ? dateVa 0].split('-').reverse().join('-')
: new Date().toISOString().slice(0, 10), : new Da.toISO ng().slice(0, 10),
dateTo: dateValue[1] dateTo: dateValue[1]
? dateValue[1].split('-').reverse().join('-') ? dateValue split('-').reverse().join('-')
: new Date().toISOString().slice(0, 10), : new Date(ISOStr).slice(0, 10),
minDurasiResponseTime: minTime ? minTime : 0, minDurasiResponseTime: minTime ? minTime : 0,
maxDurasiResponseTime: maxTime ? maxTime : 1, maxDurasiResponseTime: maxTime ? maxTime : 1,
posko: posko ? posko.id : 0, posko: posko ? posko.id : 0,
idUid: uid ? uid.id : 0, idUid: uid ? uid.id : 0,
idUp3: up3 ? up3.id : 0 idUp3: up3 ? up3.id : 0
})
onResult((queryResult) => {
if (queryResult.data != undefined) {
data.value = queryResult.data.daftarGangguanResponseTime
}
console.log(queryResult.loading)
console.log(queryResult.networkStatus)
})
onError((error) => {
console.log(error)
}) })
onResult((queryResult) => {
if (queryResult.data != undefined) {
data.value = queryResult.data.daftarGangguanResponseTime
}
console.log(queryResult.loading)
console.log(queryResult.networkStatus)
})
onError((error) => {
console.log(error)
})
} }
const { onResult, onError, loading, refetch } = useQuery(queries.gangguan.daftar.responseTime, { const { onResult, onError, loading, refetch } = useQuery(queries.gangguan.daftar.responseTime, {
@ -241,3 +241,4 @@ onMounted(() => {
data.value = dummyData.gangguan.daftar.gangguanResponseTime data.value = dummyData.gangguan.daftar.gangguanResponseTime
}) })
</script> </script>
@/utils/api/graphql

View File

@ -70,13 +70,14 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import Filters from '@/components/Form/Filters.vue' import Filters from '@/components/Form/Filters.vue';
import Type1 from '@/components/Form/FiltersType/Type1.vue' import { useQuery } from '@vue/apollo-composable';
import { formatWaktu } from '@/components/Form/FiltersType/reference' import { queries } from '@/utils/api/api.graphql';
import { onMounted, ref } from 'vue' import { dummyData } from '@/utils/dummy';
import { DxDataGrid } from 'devextreme-vue' i t from '@ nents/Form/FiltersType/Type1.vue'
import { m / F rs eferenc ort { onMounted, ref } from 'vue rt { DxDataG from 'devextreme - vue'
DxColumn, impo
xColumn,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPager, DxPager,
@ -84,9 +85,6 @@ import {
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql'
import { dummyData } from '@/utils/dummy'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -102,7 +100,7 @@ const { onResult, onError, loading, refetch } = useQuery(queries.gangguan.daftar
idUp3: 0 idUp3: 0
}) })
const filterData = (params: any) => { c onst filterData = (params: any) => {
const { posko, uid, up3 } = params const { posko, uid, up3 } = params
const dateValue = params.periode.split(' s/d ') const dateValue = params.periode.split(' s/d ')
refetch({ refetch({
@ -116,14 +114,14 @@ const filterData = (params: any) => {
idUid: uid ? uid.id : 0, idUid: uid ? uid.id : 0,
idUp3: up3 ? up3.id : 0 idUp3: up3 ? up3.id : 0
}) })
onResult((queryResult) => { onResult((queryRe) => {
if (queryResult.data != undefined) { if (queryResult.data != undefined) {
data.value = queryResult.data.daftarGangguanSelesaiTanpaIdPelanggan data.value = quer ult.data.daftarGangguanSelesaiTanpaIdPelanggan
}
console.log(queryResult.data) c le.log(queryResult.data)
console.log(queryResult.loading) console.log(queryResult.loading)
console.log(queryResult.networkStatus) console.log(queryResult.networkStatus)
}) })
onError((error) => { onError((error) => {
console.log(error) console.log(error)
}) })
@ -134,3 +132,4 @@ onMounted(() => {
data.value = dummyData.gangguan.daftar.daftarGangguanSelesaiTanpaIdPelanggan data.value = dummyData.gangguan.daftar.daftarGangguanSelesaiTanpaIdPelanggan
}) })
</script> </script>
@/utils/api/graphql

View File

@ -352,7 +352,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers'
import DetailDialog from '@/components/Dialogs/DetailDialog.vue' import DetailDialog from '@/components/Dialogs/DetailDialog.vue'
@ -449,4 +449,4 @@ const filters = ref()
onMounted(() => { onMounted(() => {
data.value = dummyData.gangguan.rekap.rekapitulasiAllGangguan data.value = dummyData.gangguan.rekap.rekapitulasiAllGangguan
}) })
</script> </script>@/utils/api/graphql

View File

@ -85,10 +85,10 @@ import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apoll o-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from "@/ut "
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatNumber, isNumber } from '@/utils /numbers'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -170,3 +170,4 @@ onMounted(() => {
data.value = dummyData.gangguan.rekap.rekapitulasiGangguanAlihPosko data.value = dummyData.gangguan.rekap.rekapitulasiGangguanAlihPosko
}) })
</script> </script>
@/utils/api/graphql

View File

@ -90,15 +90,13 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatPercentage, isNumber } from '@/utils/numbers'
import { dummyData } from '@/utils/dummy'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator =
const shading = ref(true) const shading = ref(true) wPane = ref(true)
const showPane = ref(true) const onExpo rting = (e: any) => {
const onExporting = (e: any) => {
if (e.format === 'pdf') { if (e.format === 'pdf') {
const doc = new jsPDF() const doc = new jsPDF()
@ -175,3 +173,4 @@ onMounted(() => {
data.value = dummyData.gangguan.rekap.rekapitulasiGangguanBerdasarkanMedia data.value = dummyData.gangguan.rekap.rekapitulasiGangguanBerdasarkanMedia
}) })
</script> </script>
@/utils/api/graphql

View File

@ -69,7 +69,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -144,3 +144,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -180,85 +180,86 @@ import {
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-save r'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs '
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apo llo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = {
const showIndicator = ref(true) of: '#data showIndicator = ref(true)
const shading = ref(true) ing = ref(true)
const showPane = ref(true) const showPane = ref(true)
const onExporting = (e: any) => { const onExporting = (e: any) => {
if (e.format === 'pdf') { if (e.format === 'pdf') {
const doc = new jsPDF() const doc = new jsPDF()
exportToPdf({ exportToPdf({
jsPDFDocument: doc, jsPDFDocument: doc,
component: e.component, component: e.component,
indent: 5 indent: 5
}).then(() => { }).then(() => {
doc.save(`.pdf`) doc.save(`.pdf`)
})
} else {
const workbook = new Workbook()
const worksheet = workbook.addWorksheet('Employees')
exportToExcel({
component: e.component,
worksheet,
autoFilterEnabled: true
}).then(() => {
workbook.xlsx.writeBuffer().then((buffer: any) => {
saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx')
}) })
}) } else {
const workbook = new Workbook()
const worksheet = workbook.addWorksheet('Employees')
e.cancel = true exportToExcel({
component: e.component,
worksheet,
autoFilterEnabled: true
}).then(() => {
workbook.xlsx.writeBuffer().then((buffer: any) => {
saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx')
})
})
e.cancel = true
}
} }
}
const onSelectionChanged = ({ selectedRowsData }: any) => { const onSelectionChanged = ({ selectedRowsData }: any) => {
const data = selectedRowsData[0] const data = selectedRowsData[0]
console.log(data) console.log(data)
} }
const data = ref<any[]>([]) const data = ref<any[]>([])
const { onResult, onError, loading, refetch } = useQuery( const { onResult, onError, loading, refetch } = useQuery(
queries.gangguan.rekap.gangguanDiselesaikanMobileAPKT, queries.gangguan.rekap.gangguanDiselesaikanMobileAPKT,
{ {
dateFrom: new Date('2023-10-01').toISOString().slice(0, 10), dateFrom: new Date('2023-10-01').toISOString().slice(0, 10),
dateTo: new Date('2023-10-01').toISOString().slice(0, 10), dateTo: new Date('2023-10-01').toISOString().slice(0, 10),
posko: 0, posko: 0,
idUid: 0, idUid: 0,
idUp3: 0 idUp3: 0
}
)
const filterData = (params: any) => {
const dateValue = params.periode.split(' s/d ')
const { posko, uid, up3 } = params
refetch({
dateFrom: dateValue[0]
? dateValue[0].split('-').reverse().join('-')
: new Date().toISOString().slice(0, 10),
dateTo: dateValue[1]
? dateValue[1].split('-').reverse().join('-')
: new Date().toISOString().slice(0, 10),
posko: posko ? posko.id : 0,
idUid: uid ? uid.id : 0,
idUp3: up3 ? up3.id : 0
})
const filters = useFiltersStore()
onResult((queryResult) => {
if (queryResult.data != undefined) {
data.value = queryResult.data.rekapitulasiGangguanDiselesaikanMobileAPKT
} }
console.log(queryResult.data) )
console.log(queryResult.loading) const filterData = (params: any) => {
console.log(queryResult.networkStatus) const dateValue = params.periode.split(' s/d ')
}) const { posko, uid, up3 } = params
onError((error) => { refetch({
console.log(error) dateFrom: dateValue[0]
}) ? dateValue[0].split('-').reverse().join('-')
} : new Date().toISOString().slice(0, 10),
dateTo: dateValue[1]
? dateValue[1].split('-').reverse().join('-')
: new Date().toISOString().slice(0, 10),
posko: posko ? posko.id : 0,
idUid: uid ? uid.id : 0,
idUp3: up3 ? up3.id : 0
})
const filters = useFiltersStore()
onResult((queryResult) => {
if (queryResult.data != undefined) {
data.value = queryResult.data.rekapitulasiGangguanDiselesaikanMobileAPKT
}
console.log(queryResult.data)
console.log(queryResult.loading)
console.log(queryResult.networkStatus)
})
onError((error) => {
console.log(error)
})
}
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -172,10 +172,7 @@ import {
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { queries } from '@/utils/api/api.graphql'
import { Workbook } from 'exceljs'
import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers'
@ -347,3 +344,4 @@ onMounted(() => {
) )
}) })
</script> </script>
@/utils/api/graphql

View File

@ -124,25 +124,24 @@ import {
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatNumber, formatPercentage, isNumber } from '@/utils/n umbers'
const position = { of: '#data' } const position = { of: '#dat a' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const data = ref<any[]>([]) const data = ref<any[]>([])
const onExporting = (e: any) => { cons ing = (e: any) => {
if (e.format === 'pdf') { if ( == 'pdf') {
const doc = new jsPDF() const doc = ne w jsPDF()
exportToPdf({ exportToPdf({
jsPDFDocument: doc, jsPDFDocument: doc,
@ -213,3 +212,4 @@ onMounted(() => {
data.value = dummyData.gangguan.rekap.rekapitulasiJenisGangguanSE004 data.value = dummyData.gangguan.rekap.rekapitulasiJenisGangguanSE004
}) })
</script> </script>
@/utils/api/graphql

View File

@ -69,7 +69,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
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,3 +148,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -205,11 +205,12 @@ import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs '
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apo llo-composable'
import { queries } from '@/utils/graphql' import { queries } from f
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatNumber, isNumber } from '@ bers'
om '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -371,3 +372,4 @@ onMounted(() => {
}) })
}) })
</script> </script>
@/utils/api/graphql

View File

@ -206,7 +206,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
@ -291,8 +291,8 @@ const filterData = (params: any) => {
} }
}, },
responseTime: { responseTime: {
menit: { it: {
total: item.total_durasi_response, total: l_durasi_response,
rataRata: item.avg_durasi_response, rataRata: item.avg_durasi_response,
max: item.max_durasi_response, max: item.max_durasi_response,
min: item.min_durasi_response min: item.min_durasi_response
@ -375,3 +375,4 @@ onMounted(() => {
}) })
}) })
</script> </script>
@/utils/api/graphql

View File

@ -129,7 +129,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers'
@ -212,3 +212,4 @@ onMounted(() => {
data.value = dummyData.gangguan.rekap.rekapitulasiGangguanPerTanggal data.value = dummyData.gangguan.rekap.rekapitulasiGangguanPerTanggal
}) })
</script> </script>
@/utils/api/graphql

View File

@ -87,7 +87,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -196,3 +196,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -87,7 +87,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -162,3 +162,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -4,170 +4,52 @@
</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" :column-width="100" @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"
:column-width="100"
@exporting="onExporting"
:allow-column-resizing="true"
column-resizing-mode="widget"
:word-wrap-enabled="true"
>
<DxSelection mode="single" /> <DxSelection mode="single" />
<DxPaging :page-size="5" :enabled="true" /> <DxPaging :page-size="5" :enabled="true" />
<DxPager <DxPager :visible="true" :allowed-page-sizes="[5, 10, 20]" display-mode="full" :show-page-size-selector="true"
:visible="true" :show-info="true" :show-navigation-buttons="true" />
:allowed-page-sizes="[5, 10, 20]" <DxLoadPanel :position="position" :show-indicator="showIndicator" :show-pane="showPane" :shading="shading"
display-mode="full" v-if="loading" v-model:visible="loading" :enabled="true" />
:show-page-size-selector="true"
:show-info="true"
:show-navigation-buttons="true"
/>
<DxLoadPanel
:position="position"
: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 css-class="custom-table-column" :width="50" alignment="center"
css-class="custom-table-column" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" data-type="number" caption="No" />
:width="50" <DxColumn :width="170" alignment="center" data-field="no_laporan" caption="No Laporan"
alignment="center" css-class="custom-table-column" cell-template="data" />
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" <DxColumn :width="170" alignment="center" data-field="nama_pelapor" caption="Nama Pelapor"
data-type="number" css-class="custom-table-column" cell-template="data" />
caption="No" <DxColumn :width="170" alignment="center" data-field="alamat_pelapor" caption="Alamat Pelapor"
/> css-class="custom-table-column" cell-template="data" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="no_telp_pelapor" caption="No Telp Pelapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="keterangan_pelapor" caption="Keterangan Pelapor"
data-field="no_laporan" css-class="custom-table-column" cell-template="data" />
caption="No Laporan" <DxColumn :width="120" alignment="center" data-field="status_akhir" caption="Status"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_pelapor"
caption="Nama Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="alamat_pelapor"
caption="Alamat Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="no_telp_pelapor"
caption="No Telp Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="keterangan_pelapor"
caption="Keterangan Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="120"
alignment="center"
data-field="status_akhir"
caption="Status"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn <DxColumn :width="170" alignment="center" data-field="waktu_lapor" caption="Tgl Lapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center"
data-field="waktu_lapor"
caption="Tgl Lapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn <DxColumn :width="170" alignment="center" data-field="waktu_response" caption="Tgl Response"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="waktu_recovery" caption="Tgl Recovery"
data-field="waktu_response" css-class="custom-table-column" cell-template="data" />
caption="Tgl Response" <DxColumn :width="150" alignment="center" data-field="durasi_response_time" caption="Response Time"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data-waktu" />
cell-template="data" <DxColumn :width="150" alignment="center" data-field="durasi_recovery_time" caption="Recovery Time"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn <DxColumn :width="150" alignment="center" data-field="media" caption="Sumber Lapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="waktu_media" caption="Tgl Media"
data-field="waktu_recovery" css-class="custom-table-column" cell-template="data" />
caption="Tgl Recovery" <DxColumn :width="170" alignment="center" data-field="keterangan_media" caption="Keterangan Media"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data"
/>
<DxColumn
:width="150"
alignment="center"
data-field="durasi_response_time"
caption="Response Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="durasi_recovery_time"
caption="Recovery Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="media"
caption="Sumber Lapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="150"
alignment="center"
data-field="waktu_media"
caption="Tgl Media"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="keterangan_media"
caption="Keterangan Media"
css-class="custom-table-column"
cell-template="data"
/>
<template #data="{ data }"> <template #data="{ data }">
<p class="cursor-pointer" @click="showData()"> <p class="cursor-pointer" @click="showData()">
@ -202,22 +84,13 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.alamat_pelapor" class-name="flex-1 h-[56px]" />
:readonly="true"
type="textarea"
:value="dataDetail?.alamat_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.keterangan_pelapor"
:readonly="true" class-name="flex-1 h-[56px]" />
type="textarea"
:value="dataDetail?.keterangan_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -242,28 +115,18 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_response_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_response_time)
:value=" : '-'
parseInt(dataDetail?.durasi_response_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_response_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_recovery_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_recovery_time)
:value=" : '-'
parseInt(dataDetail?.durasi_recovery_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_recovery_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -278,12 +141,8 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Media:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Media:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.keterangan_media"
:readonly="true" class-name="flex-1 h-[56px]" />
type="textarea"
:value="dataDetail?.keterangan_media"
class-name="flex-1 h-[56px]"
/>
</div> </div>
</div> </div>
</DetailDialog> </DetailDialog>
@ -298,22 +157,22 @@ import { formatWaktu } from '@/components/Form/FiltersType/reference'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPager, DxPager,
DxPaging, DxPaging,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from f
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs'
import { useQuery } from '@vue/apollo-composable' import { queries } from '@/utils/api/api.graphql'
import { queries } from '@/utils/graphql' om 'file-saver'
im port { useQuery } from '@vue/apollo-composable'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -323,23 +182,18 @@ const dataDetail = ref<any>()
const showDetail = ref(false) const showDetail = ref(false)
const closeDetail = () => { const closeDetail = () => {
showDetail.value = false value = false
} }
const showData = () => { const showData = () => {
showDetail.value = true lue = true
} }
const onSelectionChanged = ({ selectedRowsData }: any) => { const onSelectionChanged = ({ sele : any) taDetail.value = sta[0]
dataDetail.value = selectedRowsData[0]
console.log(selectedRowsData[0]) console.log(selectedRowsData[0])
} }
ting = (e: any) => {
const onExporting = (e: any) => { if (e.format === 'pdf') { = new exportToPdf({
if (e.format === 'pdf') {
const doc = new jsPDF()
exportToPdf({
jsPDFDocument: doc, jsPDFDocument: doc,
component: e.component, component: e.component,
indent: 5 indent: 5
@ -404,3 +258,4 @@ const filterData = (params: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -88,14 +88,14 @@ import { formatWaktu } from '@/components/Form/FiltersType/reference'
import { onMounted, ref } from 'vue' import { onMounted, ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPager, DxPager,
DxPaging, DxPaging,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
@ -103,7 +103,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
import { dummyData } from '@/utils/dummy' import { dummyData } from '@/utils/dummy'
import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers' import { formatNumber, formatPercentage, isNumber } from '@/utils/numbers'
@ -193,3 +193,4 @@ onMounted(() => {
data.value = dummyData.keluhan.daftar.daftarKeluhanDialihkanKeUnitLain data.value = dummyData.keluhan.daftar.daftarKeluhanDialihkanKeUnitLain
}) })
</script> </script>
@/utils/api/graphql

View File

@ -4,176 +4,52 @@
</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" :column-width="100" @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"
:column-width="100"
@exporting="onExporting"
:allow-column-resizing="true"
column-resizing-mode="widget"
:word-wrap-enabled="true"
>
<DxSelection mode="single" /> <DxSelection mode="single" />
<DxPaging :page-size="5" :enabled="true" /> <DxPaging :page-size="5" :enabled="true" />
<DxPager <DxPager :visible="true" :allowed-page-sizes="[5, 10, 20]" display-mode="full" :show-page-size-selector="true"
:visible="true" :show-info="true" :show-navigation-buttons="true" />
:allowed-page-sizes="[5, 10, 20]" <DxLoadPanel :position="position" :show-indicator="showIndicator" :show-pane="showPane" :shading="shading"
display-mode="full" v-if="loading" v-model:visible="loading" :enabled="true" />
:show-page-size-selector="true"
:show-info="true"
:show-navigation-buttons="true"
/>
<DxLoadPanel
:position="position"
: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 css-class="custom-table-column" :width="50" alignment="center"
css-class="custom-table-column" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" data-type="number" caption="No" />
:width="50" <DxColumn :width="170" alignment="center" data-field="no_laporan" caption="No Laporan"
alignment="center" css-class="custom-table-column" cell-template="data" />
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" <DxColumn :width="170" alignment="center" data-field="waktu_lapor" caption="Tgl Lapor"
data-type="number" css-class="custom-table-column" cell-template="data" />
caption="No" <DxColumn :width="170" alignment="center" data-field="waktu_response" caption="Tgl Response"
/> css-class="custom-table-column" cell-template="data" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="waktu_recovery" caption="Tgl Recovery"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="120" alignment="center" data-field="jumlah_lapor" caption="Jml Lapor"
data-field="no_laporan" css-class="custom-table-column" cell-template="data" />
caption="No Laporan" <DxColumn :width="170" alignment="center" data-field="durasi_response_time" caption="Durasi Response Time"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data-waktu" />
cell-template="data" <DxColumn :width="170" alignment="center" data-field="durasi_recovery_time" caption="Durasi Recovery Time"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn <DxColumn :width="120" alignment="center" data-field="status_akhir" caption="Status"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="idpel_nometer" caption="IDPEL/NO METER"
data-field="waktu_lapor" css-class="custom-table-column" cell-template="data" />
caption="Tgl Lapor" <DxColumn :width="170" alignment="center" data-field="nama_pelapor" caption="Nama Pelapor"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="170" alignment="center" data-field="alamat_pelapor" caption="Alamat Pelapor"
/> css-class="custom-table-column" cell-template="data" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="no_telp_pelapor" caption="No Telp Pelapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="keterangan_pelapor" caption="Keterangan Pelapor"
data-field="waktu_response" css-class="custom-table-column" cell-template="data" />
caption="Tgl Response" <DxColumn :width="150" alignment="center" data-field="media" caption="Sumber Lapor"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="150" alignment="center" data-field="nama_ulp" caption="Nama ULP" css-class="custom-table-column"
/> cell-template="data" />
<DxColumn
:width="170"
alignment="center"
data-field="waktu_recovery"
caption="Tgl Recovery"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="120"
alignment="center"
data-field="jumlah_lapor"
caption="Jml Lapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="durasi_response_time"
caption="Durasi Response Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="170"
alignment="center"
data-field="durasi_recovery_time"
caption="Durasi Recovery Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="120"
alignment="center"
data-field="status_akhir"
caption="Status"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="idpel_nometer"
caption="IDPEL/NO METER"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_pelapor"
caption="Nama Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="alamat_pelapor"
caption="Alamat Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="no_telp_pelapor"
caption="No Telp Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="keterangan_pelapor"
caption="Keterangan Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="150"
alignment="center"
data-field="media"
caption="Sumber Lapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="150"
alignment="center"
data-field="nama_ulp"
caption="Nama ULP"
css-class="custom-table-column"
cell-template="data"
/>
<template #data="{ data }"> <template #data="{ data }">
<p class="cursor-pointer" @click="showData()"> <p class="cursor-pointer" @click="showData()">
@ -218,28 +94,18 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_response_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_response_time)
:value=" : '-'
parseInt(dataDetail?.durasi_response_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_response_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_recovery_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_recovery_time)
:value=" : '-'
parseInt(dataDetail?.durasi_recovery_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_recovery_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -259,12 +125,7 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.alamat_pelapor" class-name="flex-1 h-[56px]" />
:readonly="true"
type="textarea"
:value="dataDetail?.alamat_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -274,12 +135,8 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.keterangan_pelapor"
:readonly="true" class-name="flex-1 h-[56px]" />
type="textarea"
:value="dataDetail?.keterangan_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -304,27 +161,26 @@ import { formatWaktu } from '@/components/Form/FiltersType/reference'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPager, DxPager,
DxPaging, DxPaging,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'fil e-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'e xceljs'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@v ue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of:
const showIndicator = ref(true) const showIndicator = ref st shading = ref(true)
const shading = ref(true) const s howPane = ref(true)
const showPane = ref(true)
const dataDetail = ref<any>() const dataDetail = ref<any>()
const showDetail = ref(false) const showDetail = ref(false)
@ -415,3 +271,4 @@ const filterData = (params: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -4,161 +4,49 @@
</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" :column-width="100" @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"
:column-width="100"
@exporting="onExporting"
:allow-column-resizing="true"
column-resizing-mode="widget"
:word-wrap-enabled="true"
>
<DxSelection mode="single" /> <DxSelection mode="single" />
<DxPaging :page-size="5" :enabled="true" /> <DxPaging :page-size="5" :enabled="true" />
<DxPager <DxPager :visible="true" :allowed-page-sizes="[5, 10, 20]" display-mode="full" :show-page-size-selector="true"
:visible="true" :show-info="true" :show-navigation-buttons="true" />
:allowed-page-sizes="[5, 10, 20]" <DxLoadPanel :position="position" :show-indicator="showIndicator" :show-pane="showPane" :shading="shading"
display-mode="full" v-if="loading" v-model:visible="loading" :enabled="true" />
:show-page-size-selector="true"
:show-info="true"
:show-navigation-buttons="true"
/>
<DxLoadPanel
:position="position"
: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 css-class="custom-table-column" :width="50" alignment="center"
css-class="custom-table-column" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" data-type="number" caption="No" />
:width="50" <DxColumn :width="170" alignment="center" data-field="no_laporan" caption="No Laporan"
alignment="center" css-class="custom-table-column" cell-template="data" />
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1"
data-type="number"
caption="No"
/>
<DxColumn
:width="170"
alignment="center"
data-field="no_laporan"
caption="No Laporan"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn <DxColumn :width="170" alignment="center" data-field="waktu_lapor" caption="Tgl Lapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="waktu_response" caption="Tgl Response"
data-field="waktu_lapor" css-class="custom-table-column" cell-template="data" />
caption="Tgl Lapor" <DxColumn :width="170" alignment="center" data-field="waktu_recovery" caption="Tgl Recovery"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="170" alignment="center" data-field="durasi_response_time" caption="Durasi Response Time"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="durasi_recovery_time" caption="Durasi Recovery Time"
:width="170" css-class="custom-table-column" cell-template="data-waktu" />
alignment="center" <DxColumn :width="120" alignment="center" data-field="status_akhir" caption="Status"
data-field="waktu_response" css-class="custom-table-column" cell-template="data" />
caption="Tgl Response" <DxColumn :width="170" alignment="center" data-field="idpel_nometer" caption="IDPEL/NO METER"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="170" alignment="center" data-field="nama_pelapor" caption="Nama Pelapor"
/> css-class="custom-table-column" cell-template="data" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="alamat_pelapor" caption="Alamat Pelapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="no_telp_pelapor" caption="No Telp Pelapor"
data-field="waktu_recovery" css-class="custom-table-column" cell-template="data" />
caption="Tgl Recovery" <DxColumn :width="170" alignment="center" data-field="keterangan_pelapor" caption="Keterangan Pelapor"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="150" alignment="center" data-field="nama_ulp" caption="Nama ULP" css-class="custom-table-column"
/> cell-template="data" />
<DxColumn
:width="170"
alignment="center"
data-field="durasi_response_time"
caption="Durasi Response Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="170"
alignment="center"
data-field="durasi_recovery_time"
caption="Durasi Recovery Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="120"
alignment="center"
data-field="status_akhir"
caption="Status"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="idpel_nometer"
caption="IDPEL/NO METER"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_pelapor"
caption="Nama Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="alamat_pelapor"
caption="Alamat Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="no_telp_pelapor"
caption="No Telp Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="keterangan_pelapor"
caption="Keterangan Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="150"
alignment="center"
data-field="nama_ulp"
caption="Nama ULP"
css-class="custom-table-column"
cell-template="data"
/>
<template #data="{ data }"> <template #data="{ data }">
<p class="cursor-pointer" @click="showData()"> <p class="cursor-pointer" @click="showData()">
@ -198,28 +86,18 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_response_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_response_time)
:value=" : '-'
parseInt(dataDetail?.durasi_response_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_response_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_recovery_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_recovery_time)
:value=" : '-'
parseInt(dataDetail?.durasi_recovery_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_recovery_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -239,12 +117,7 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.alamat_pelapor" class-name="flex-1 h-[56px]" />
:readonly="true"
type="textarea"
:value="dataDetail?.alamat_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -254,12 +127,8 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.keterangan_pelapor"
:readonly="true" class-name="flex-1 h-[56px]" />
type="textarea"
:value="dataDetail?.keterangan_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -295,11 +164,10 @@ import {
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -308,22 +176,16 @@ const showPane = ref(true)
const dataDetail = ref<any>() const dataDetail = ref<any>()
const showDetail = ref(false) const showDetail = ref(false)
const closeDetail = () => { const closeDetai showDetail.value = false
showDetail.value = false
} }
const showData = () => { const showData howDetail.value = true
showDetail.value = true
} }
const onSelectionChanged = ({ selectedRowsData }: any) => { const onSelectionChang edRows y) => {
dataDetail.value = selectedRowsData[0] dataDetalectedRowsData[0]
console.log(selectedRowsData[0]) console.log(selectedRow onst onExporting = (e: any) => {
} if (e.format con ew jsPDF()
const onExporting = (e: any) => {
if (e.format === 'pdf') {
const doc = new jsPDF()
exportToPdf({ exportToPdf({
jsPDFDocument: doc, jsPDFDocument: doc,
@ -338,16 +200,16 @@ const onExporting = (e: any) => {
exportToExcel({ exportToExcel({
component: e.component, component: e.component,
worksheet, worksheet,
autoFilterEnabled: true autoFilterEnabled: true
}).then(() => { }).then(() => {
workbook.xlsx.writeBuffer().then((buffer: any) => { workbook.xlsx.writeBuffer().then((buffer: any) => {
saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx') saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx')
})
}) })
})
e.cancel = true e.cancel = true
} }
} }
const data = ref<any[]>([]) const data = ref<any[]>([])
@ -393,3 +255,4 @@ const filterData = (params: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -4,161 +4,49 @@
</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" :column-width="100" @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"
:column-width="100"
@exporting="onExporting"
:allow-column-resizing="true"
column-resizing-mode="widget"
:word-wrap-enabled="true"
>
<DxSelection mode="single" /> <DxSelection mode="single" />
<DxPaging :page-size="5" :enabled="true" /> <DxPaging :page-size="5" :enabled="true" />
<DxPager <DxPager :visible="true" :allowed-page-sizes="[5, 10, 20]" display-mode="full" :show-page-size-selector="true"
:visible="true" :show-info="true" :show-navigation-buttons="true" />
:allowed-page-sizes="[5, 10, 20]" <DxLoadPanel :position="position" :show-indicator="showIndicator" :show-pane="showPane" :shading="shading"
display-mode="full" v-if="loading" v-model:visible="loading" :enabled="true" />
:show-page-size-selector="true"
:show-info="true"
:show-navigation-buttons="true"
/>
<DxLoadPanel
:position="position"
: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 css-class="custom-table-column" :width="50" alignment="center"
css-class="custom-table-column" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" data-type="number" caption="No" />
:width="50" <DxColumn :width="170" alignment="center" data-field="no_laporan" caption="No Laporan"
alignment="center" css-class="custom-table-column" cell-template="data" />
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1"
data-type="number"
caption="No"
/>
<DxColumn
:width="170"
alignment="center"
data-field="no_laporan"
caption="No Laporan"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn <DxColumn :width="170" alignment="center" data-field="waktu_lapor" caption="Tgl Lapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="waktu_response" caption="Tgl Response"
data-field="waktu_lapor" css-class="custom-table-column" cell-template="data" />
caption="Tgl Lapor" <DxColumn :width="170" alignment="center" data-field="waktu_recovery" caption="Tgl Recovery"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="170" alignment="center" data-field="durasi_response_time" caption="Durasi Response Time"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="durasi_recovery_time" caption="Durasi Recovery Time"
:width="170" css-class="custom-table-column" cell-template="data-waktu" />
alignment="center" <DxColumn :width="120" alignment="center" data-field="status_akhir" caption="Status"
data-field="waktu_response" css-class="custom-table-column" cell-template="data" />
caption="Tgl Response" <DxColumn :width="170" alignment="center" data-field="idpel_nometer" caption="IDPEL/NO METER"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="170" alignment="center" data-field="nama_pelapor" caption="Nama Pelapor"
/> css-class="custom-table-column" cell-template="data" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="alamat_pelapor" caption="Alamat Pelapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="no_telp_pelapor" caption="No Telp Pelapor"
data-field="waktu_recovery" css-class="custom-table-column" cell-template="data" />
caption="Tgl Recovery" <DxColumn :width="170" alignment="center" data-field="keterangan_pelapor" caption="Keterangan Pelapor"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="150" alignment="center" data-field="nama_ulp" caption="Nama ULP" css-class="custom-table-column"
/> cell-template="data" />
<DxColumn
:width="170"
alignment="center"
data-field="durasi_response_time"
caption="Durasi Response Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="170"
alignment="center"
data-field="durasi_recovery_time"
caption="Durasi Recovery Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="120"
alignment="center"
data-field="status_akhir"
caption="Status"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="idpel_nometer"
caption="IDPEL/NO METER"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_pelapor"
caption="Nama Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="alamat_pelapor"
caption="Alamat Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="no_telp_pelapor"
caption="No Telp Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="keterangan_pelapor"
caption="Keterangan Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="150"
alignment="center"
data-field="nama_ulp"
caption="Nama ULP"
css-class="custom-table-column"
cell-template="data"
/>
<template #data="{ data }"> <template #data="{ data }">
<p class="cursor-pointer" @click="showData()"> <p class="cursor-pointer" @click="showData()">
@ -198,28 +86,18 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_response_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_response_time)
:value=" : '-'
parseInt(dataDetail?.durasi_response_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_response_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_recovery_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_recovery_time)
:value=" : '-'
parseInt(dataDetail?.durasi_recovery_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_recovery_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -239,12 +117,7 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.alamat_pelapor" class-name="flex-1 h-[56px]" />
:readonly="true"
type="textarea"
:value="dataDetail?.alamat_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -254,12 +127,8 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.keterangan_pelapor"
:readonly="true" class-name="flex-1 h-[56px]" />
type="textarea"
:value="dataDetail?.keterangan_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -295,11 +164,9 @@ import {
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { saveAs } from 'fil e-saver'
import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs'
import { useQuery } from '@vue/apollo-composable' import { queries } from '@/utils/api/api.graphql'
import { queries } from '@/utils/graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -312,22 +179,16 @@ const closeDetail = () => {
showDetail.value = false showDetail.value = false
} }
const showData = () => { const showData = () tail.value = true
showDetail.value = true
} }
const onSelectionChanged = ({ selectedRowsData }: any) => { const onSelectionChang edRowsData }: any) => {
dataDetail.value = selectedRowsData[0] dataDetail.value = sel 0]
console.log(selectedRowsData[0]) c(selectedRowsData[onExporting = (e: any) => {
} if (e.format const doc = new jsPDF()
const onExporting = (e: any) => {
if (e.format === 'pdf') {
const doc = new jsPDF()
exportToPdf({ exportToPdf({
jsPDFDocument: doc, ent: d component: e.component,
component: e.component,
indent: 5 indent: 5
}).then(() => { }).then(() => {
doc.save(`.pdf`) doc.save(`.pdf`)
@ -338,16 +199,16 @@ const onExporting = (e: any) => {
exportToExcel({ exportToExcel({
component: e.component, component: e.component,
worksheet, worksheet,
autoFilterEnabled: true autoFilterEnabled: true
}).then(() => { }).then(() => {
workbook.xlsx.writeBuffer().then((buffer: any) => { workbook.xlsx.writeBuffer().then((buffer: any) => {
saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx') saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx')
})
}) })
})
e.cancel = true e.cancel = true
} }
} }
const data = ref<any[]>([]) const data = ref<any[]>([])
@ -394,3 +255,4 @@ const filterData = (params: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -4,168 +4,50 @@
</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" :column-width="100" @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"
:column-width="100"
@exporting="onExporting"
:allow-column-resizing="true"
column-resizing-mode="widget"
:word-wrap-enabled="true"
>
<DxSelection mode="single" /> <DxSelection mode="single" />
<DxPaging :page-size="5" :enabled="true" /> <DxPaging :page-size="5" :enabled="true" />
<DxPager <DxPager :visible="true" :allowed-page-sizes="[5, 10, 20]" display-mode="full" :show-page-size-selector="true"
:visible="true" :show-info="true" :show-navigation-buttons="true" />
:allowed-page-sizes="[5, 10, 20]" <DxLoadPanel :position="position" :show-indicator="showIndicator" :show-pane="showPane" :shading="shading"
display-mode="full" v-if="loading" v-model:visible="loading" :enabled="true" />
:show-page-size-selector="true"
:show-info="true"
:show-navigation-buttons="true"
/>
<DxLoadPanel
:position="position"
: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 css-class="custom-table-column" :width="50" alignment="center"
css-class="custom-table-column" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" data-type="number" caption="No" />
:width="50" <DxColumn :width="170" alignment="center" data-field="no_laporan" caption="No Laporan"
alignment="center" css-class="custom-table-column" cell-template="data" />
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" <DxColumn :width="170" alignment="center" data-field="waktu_lapor" caption="Tgl Lapor"
data-type="number" css-class="custom-table-column" cell-template="data" />
caption="No" <DxColumn :width="170" alignment="center" data-field="waktu_response" caption="Tgl Response"
/> css-class="custom-table-column" cell-template="data" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="waktu_recovery" caption="Tgl Recovery"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="durasi_response_time" caption="Durasi Response Time"
data-field="no_laporan" css-class="custom-table-column" cell-template="data-waktu" />
caption="No Laporan" <DxColumn :width="170" alignment="center" data-field="durasi_recovery_time" caption="Durasi Recovery Time"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data-waktu" />
cell-template="data" <DxColumn :width="120" alignment="center" data-field="status_akhir" caption="Status"
/> css-class="custom-table-column" cell-template="data" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="idpel_nometer" caption="IDPEL/NO METER"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="nama_pelapor" caption="Nama Pelapor"
data-field="waktu_lapor" css-class="custom-table-column" cell-template="data" />
caption="Tgl Lapor" <DxColumn :width="170" alignment="center" data-field="alamat_pelapor" caption="Alamat Pelapor"
css-class="custom-table-column" css-class="custom-table-column" cell-template="data" />
cell-template="data" <DxColumn :width="170" alignment="center" data-field="no_telp_pelapor" caption="No Telp Pelapor"
/> css-class="custom-table-column" cell-template="data" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="keterangan_pelapor" caption="Keterangan Pelapor"
:width="170" css-class="custom-table-column" cell-template="data" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="media" caption="Sumber Lapor"
data-field="waktu_response" css-class="custom-table-column" cell-template="data" />
caption="Tgl Response" <DxColumn :width="150" alignment="center" data-field="nama_ulp" caption="Nama ULP" css-class="custom-table-column"
css-class="custom-table-column" cell-template="data" />
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="waktu_recovery"
caption="Tgl Recovery"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="durasi_response_time"
caption="Durasi Response Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="170"
alignment="center"
data-field="durasi_recovery_time"
caption="Durasi Recovery Time"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="120"
alignment="center"
data-field="status_akhir"
caption="Status"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="idpel_nometer"
caption="IDPEL/NO METER"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_pelapor"
caption="Nama Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="alamat_pelapor"
caption="Alamat Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="no_telp_pelapor"
caption="No Telp Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="170"
alignment="center"
data-field="keterangan_pelapor"
caption="Keterangan Pelapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="150"
alignment="center"
data-field="media"
caption="Sumber Lapor"
css-class="custom-table-column"
cell-template="data"
/>
<DxColumn
:width="150"
alignment="center"
data-field="nama_ulp"
caption="Nama ULP"
css-class="custom-table-column"
cell-template="data"
/>
<template #data="{ data }"> <template #data="{ data }">
<p class="cursor-pointer" @click="showData()"> <p class="cursor-pointer" @click="showData()">
@ -205,28 +87,18 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Response Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_response_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_response_time)
:value=" : '-'
parseInt(dataDetail?.durasi_response_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_response_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Recovery Time:</h3>
<InputText <InputText :readonly="true" :value="parseInt(dataDetail?.durasi_recovery_time)
:readonly="true" ? formatWaktu(dataDetail?.durasi_recovery_time)
:value=" : '-'
parseInt(dataDetail?.durasi_recovery_time) " class-name="flex-1" />
? formatWaktu(dataDetail?.durasi_recovery_time)
: '-'
"
class-name="flex-1"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -246,12 +118,7 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Alamat Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.alamat_pelapor" class-name="flex-1 h-[56px]" />
:readonly="true"
type="textarea"
:value="dataDetail?.alamat_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -261,12 +128,8 @@
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
<h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3> <h3 class="text-sm font-medium w-[170px] text-gray-800">Keterangan Pelapor:</h3>
<InputText <InputText :readonly="true" type="textarea" :value="dataDetail?.keterangan_pelapor"
:readonly="true" class-name="flex-1 h-[56px]" />
type="textarea"
:value="dataDetail?.keterangan_pelapor"
class-name="flex-1 h-[56px]"
/>
</div> </div>
<div class="flex flex-row items-center justify-between w-full"> <div class="flex flex-row items-center justify-between w-full">
@ -291,22 +154,20 @@ import { formatWaktu } from '@/components/Form/FiltersType/reference'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPager, DxPager,
DxPaging, DxPaging,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'e xceljs'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -315,22 +176,16 @@ const showPane = ref(true)
const dataDetail = ref<any>() const dataDetail = ref<any>()
const showDetail = ref(false) const showDetail = ref(false)
const closeDetail = () => { const closeDetail howDetail.value = false
showDetail.value = false
} }
const showData = () => { const showData = wDetail.value = true
showDetail.value = true
} }
const onSelectionChanged = ({ selectedRowsData }: any) => { const onSelectionChanged RowsDa => {
dataDetail.value = selectedRowsData[0] dataDetailctedRowsData[0]
console.log(selectedRowsData[0]) console.log(selectedRowsD st onExporting = (e: any) => {
} if (e.format == const jsPDF()
const onExporting = (e: any) => {
if (e.format === 'pdf') {
const doc = new jsPDF()
exportToPdf({ exportToPdf({
jsPDFDocument: doc, jsPDFDocument: doc,
@ -397,3 +252,4 @@ const filterData = (params: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -4,170 +4,55 @@
</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" :column-width="100" @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"
:column-width="100"
@exporting="onExporting"
:allow-column-resizing="true"
column-resizing-mode="widget"
:word-wrap-enabled="true"
>
<DxSelection mode="single" /> <DxSelection mode="single" />
<DxPaging :page-size="5" :enabled="true" /> <DxPaging :page-size="5" :enabled="true" />
<DxPager <DxPager :visible="true" :allowed-page-sizes="[5, 10, 20]" display-mode="full" :show-page-size-selector="true"
:visible="true" :show-info="true" :show-navigation-buttons="true" />
:allowed-page-sizes="[5, 10, 20]" <DxLoadPanel :position="position" :show-indicator="showIndicator" :show-pane="showPane" :shading="shading"
display-mode="full" v-if="loading" v-model:visible="loading" :enabled="true" />
:show-page-size-selector="true"
:show-info="true"
:show-navigation-buttons="true"
/>
<DxLoadPanel
:position="position"
: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 css-class="custom-table-column" :width="50" alignment="center"
css-class="custom-table-column" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" data-type="number" caption="No" />
:width="50" <DxColumn :width="170" alignment="center" data-field="no_laporan" caption="No Laporan"
alignment="center" css-class="custom-table-column" />
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" <DxColumn :width="170" alignment="center" data-field="nama_ulp" caption="Contact Center"
data-type="number" css-class="custom-table-column" />
caption="No" <DxColumn :width="170" alignment="center" data-field="nama_uid" caption="UI Dist."
/> css-class="custom-table-column" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="nama_ulp" caption="ULP" css-class="custom-table-column" />
:width="170" <DxColumn :width="170" alignment="center" data-field="idpel_nometer" caption="IDPEL/NO METER"
alignment="center" css-class="custom-table-column" />
data-field="no_laporan" <DxColumn :width="170" alignment="center" data-field="nama_pelapor" caption="Nama Pelapor"
caption="No Laporan" css-class="custom-table-column" />
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_ulp"
caption="Contact Center"
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_uid"
caption="UI Dist."
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_ulp"
caption="ULP"
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="idpel_nometer"
caption="IDPEL/NO METER"
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_pelapor"
caption="Nama Pelapor"
css-class="custom-table-column"
/>
<DxColumn <DxColumn :width="170" alignment="center" data-field="alamat_pelapor" caption="Alamat Pelapor"
:width="170" css-class="custom-table-column" />
alignment="center"
data-field="alamat_pelapor"
caption="Alamat Pelapor"
css-class="custom-table-column"
/>
<DxColumn <DxColumn :width="170" alignment="center" data-field="no_telp_pelapor" caption="No Tlp Pelapor"
:width="170" css-class="custom-table-column" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="keterangan_pelapor" caption="Keterangan Pelapor"
data-field="no_telp_pelapor" css-class="custom-table-column" />
caption="No Tlp Pelapor" <DxColumn :width="150" alignment="center" data-field="status_akhir" caption="APKT Status"
css-class="custom-table-column" css-class="custom-table-column" />
/> <DxColumn :width="150" alignment="center" data-field="nama_pelapor" caption="Created By"
<DxColumn css-class="custom-table-column" />
:width="170" <DxColumn :width="170" alignment="center" data-field="waktu_recovery" caption="Tgl Penyelesaian"
alignment="center" css-class="custom-table-column" />
data-field="keterangan_pelapor" <DxColumn :width="170" alignment="center" data-field="jumlah_lapor" caption="Lapor Ulang"
caption="Keterangan Pelapor" css-class="custom-table-column" />
css-class="custom-table-column" <DxColumn :width="170" alignment="center" data-field="media" caption="Sumber Lapor"
/> css-class="custom-table-column" />
<DxColumn <DxColumn :width="170" alignment="center" data-field="nama_issuetype" caption="Issue Type"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="170" alignment="center" data-field="nama_subissuetype" caption="Sub Issue Type"
data-field="status_akhir" css-class="custom-table-column" />
caption="APKT Status"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="nama_pelapor"
caption="Created By"
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="waktu_recovery"
caption="Tgl Penyelesaian"
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="jumlah_lapor"
caption="Lapor Ulang"
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="media"
caption="Sumber Lapor"
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_issuetype"
caption="Issue Type"
css-class="custom-table-column"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_subissuetype"
caption="Sub Issue Type"
css-class="custom-table-column"
/>
</DxDataGrid> </DxDataGrid>
</div> </div>
</template> </template>
@ -178,27 +63,26 @@ import Type3 from '@/components/Form/FiltersType/Type3.vue'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPager, DxPager,
DxPaging, DxPaging,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const sh owIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) cons t showPane = ref(true)
const onExporting = (e: any) => { const onExporting = (e: any) => {
if (e.format === 'pdf') { if (e.format === 'pdf') {
const doc = new jsPDF() const doc = new jsPDF()
@ -219,23 +103,16 @@ const onExporting = (e: any) => {
worksheet, worksheet,
autoFilterEnabled: true autoFilterEnabled: true
}).then(() => { }).then(() => {
workbook.xlsx.writeBuffer().then((buffer: any) => { workbook.xlsx.writeBuffer().then((buf{
saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx') saveAs(new Blob([buffer], { type: octet-stream' }), 'DataGrid.xlsx')
}) })
}) el = t
const onSelectionselectedRowsData }: any) => {
e.cancel = true const data Data[0]
}
}
const onSelectionChanged = ({ selectedRowsData }: any) => {
const data = selectedRowsData[0]
console.log(data) console.log(data)
} }
const data = ref<any[]>([]) const data = ref< nst { onError, loading, refetch } = useQuery(queries.keluhan.daftar.keluhanDiselesaikanCC123, {
const { onResult, onError, loading, refetch } = useQuery(queries.keluhan.daftar.keluhanDiselesaikanCC123, {
dateFrom: new Date('2023-10-01').toISOString().slice(0, 10), dateFrom: new Date('2023-10-01').toISOString().slice(0, 10),
dateTo: new Date('2023-10-01').toISOString().slice(0, 10), dateTo: new Date('2023-10-01').toISOString().slice(0, 10),
idUlp: 0, idUlp: 0,
@ -273,3 +150,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -1,200 +1,61 @@
<template> <template>
<Filters <Filters @reset-form="data = []" @run-search="() => filterData(filters)" :report-button="true" class="mb-4">
@reset-form="data = []"
@run-search="() => filterData(filters)"
:report-button="true"
class="mb-4"
>
<Type3 @update:filters="(value) => filters = value" /> <Type3 @update:filters="(value) => filters = value" />
</Filters> </Filters>
<div> <div>
<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="onDataSelectionChanged" :column-width="100" @exporting="onExporting"
:show-column-lines="true" :allow-column-resizing="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="onDataSelectionChanged"
:column-width="100"
@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" :width="170" data-field="nama_ulp" caption="Nama Unit"
alignment="center" css-class="custom-table-column" cell-template="unitName" header-cell-template="title-header" />
:width="170"
data-field="nama_ulp"
caption="Nama Unit"
css-class="custom-table-column"
cell-template="unitName"
header-cell-template="title-header"
/>
<template #unitName="{ data }"> <template #unitName="{ data }">
<p class="text-left cursor-pointer" @click="showDialog()"> <p class="text-left cursor-pointer" @click="showDialog()">
{{ data.text }} {{ data.text }}
</p> </p>
</template> </template>
<DxColumn alignment="center" caption="Response Time" css-class="custom-table-column"> <DxColumn alignment="center" caption="Response Time" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total" data-type="number" caption="Total"
:width="150" css-class="custom-table-column" cell-template="defaults" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_selesai" data-type="number" caption="Selesai"
data-field="total" css-class="custom-table-column" cell-template="defaults" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="persen_selesai" data-type="number" caption="%"
caption="Total" css-class="custom-table-column" cell-template="percent" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="total_inproses" data-type="number" caption="InProgress"
cell-template="defaults" css-class="custom-table-column" cell-template="defaults" />
/> <DxColumn :width="150" alignment="center" data-field="persen_inproses" data-type="number" caption="%"
<DxColumn css-class="custom-table-column" cell-template="percent" />
:width="150" <DxColumn :width="150" alignment="center" data-field="avg_durasi_response" data-type="number"
alignment="center" caption="Rata-Rata" css-class="custom-table-column" cell-template="defaults" />
data-field="total_selesai" <DxColumn :width="150" alignment="center" data-field="max_durasi_response" data-type="number" caption="Max"
data-type="number" css-class="custom-table-column" cell-template="formatTime" />
caption="Selesai" <DxColumn :width="150" alignment="center" data-field="min_durasi_response" data-type="number" caption="Min"
css-class="custom-table-column" css-class="custom-table-column" cell-template="formatTime" />
cell-template="defaults" <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_response" data-type="number"
/> caption="> SLA" css-class="custom-table-column" cell-template="defaults" />
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_response" data-type="number"
:width="150" caption="≤ SLA" css-class="custom-table-column" cell-template="defaults" />
alignment="center"
data-field="persen_selesai"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-template="percent"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_inproses"
data-type="number"
caption="InProgress"
css-class="custom-table-column"
cell-template="defaults"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_inproses"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-template="percent"
/>
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_response"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
cell-template="defaults"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_response"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-template="formatTime"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_response"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-template="formatTime"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_diatas_sla_response"
data-type="number"
caption="> SLA"
css-class="custom-table-column"
cell-template="defaults"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_response"
data-type="number"
caption="≤ SLA"
css-class="custom-table-column"
cell-template="defaults"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column"> <DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="avg_durasi_recovery" data-type="number"
:width="150" caption="Rata-Rata" css-class="custom-table-column" cell-template="defaults" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="max_durasi_recovery" data-type="number" caption="Max"
data-field="avg_durasi_recovery" css-class="custom-table-column" cell-template="formatTime" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="min_durasi_recovery" data-type="number" caption="Min"
caption="Rata-Rata" css-class="custom-table-column" cell-template="formatTime" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_recovery" data-type="number"
cell-template="defaults" caption="> SLA" css-class="custom-table-column" cell-template="defaults" />
/> <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_recovery" data-type="number"
<DxColumn caption="≤ SLA" css-class="custom-table-column" cell-template="defaults" />
:width="150"
alignment="center"
data-field="max_durasi_recovery"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-template="formatTime"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_recovery"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-template="formatTime"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_diatas_sla_recovery"
data-type="number"
caption="> SLA"
css-class="custom-table-column"
cell-template="defaults"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_recovery"
data-type="number"
caption="≤ SLA"
css-class="custom-table-column"
cell-template="defaults"
/>
</DxColumn> </DxColumn>
<template #formatTime="{ data }"> <template #formatTime="{ data }">
@ -202,9 +63,11 @@
{{ parseInt(data.text) ? formatWaktu(data.text) : '-' }} {{ parseInt(data.text) ? formatWaktu(data.text) : '-' }}
</p> </p>
</template> </template>
<template #percent="{ data }"> <template #percent="{ data }">
<p class="cursor-pointer" @click="showDialog()">{{ data.text }}%</p> <p class="cursor-pointer" @click="showDialog()">{{ data.text }}%</p>
</template> </template>
<template #defaults="{ data }"> <template #defaults="{ data }">
<p class="cursor-pointer" @click="showDialog()"> <p class="cursor-pointer" @click="showDialog()">
{{ data.text }} {{ data.text }}
@ -213,12 +76,8 @@
</DxDataGrid> </DxDataGrid>
</div> </div>
<DetailDialog <DetailDialog :open="showDialogDetail" :full-width="true" title="Detail Rekapitulasi Keluhan All"
:open="showDialogDetail" @on-close="closeDetailDialog">
:full-width="true"
title="Detail Rekapitulasi Keluhan All"
@on-close="closeDetailDialog"
>
<div class="flex flex-col w-full space-y-2 lg:space-x-4 lg:flex-row lg:justify-between"> <div class="flex flex-col w-full space-y-2 lg:space-x-4 lg:flex-row lg:justify-between">
<div class="flex flex-1 p-4 bg-white rounded-xl"> <div class="flex flex-1 p-4 bg-white rounded-xl">
<div class="w-full"> <div class="w-full">
@ -346,13 +205,13 @@ import Type3 from '@/components/Form/FiltersType/Type3.vue'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxPaging, DxLoadPanel, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
@ -361,7 +220,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 { formatWaktu } from '@/components/Form/FiltersType/reference' import { formatWaktu } from '@/components/Form/FiltersType/reference'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -457,3 +316,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -66,14 +66,14 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const onExporting = (e: any) => { const onExporting = (e: any) => {
if (e.format === 'pdf') { if (e.format === 'pdf') {
const doc = new jsPDF() const d oc = new jsPDF()
exportToPdf({ exportToPdf({
jsPDFDocument: doc, jsPDFDocument: doc,
@ -143,3 +143,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -1,58 +1,25 @@
<template> <template>
<Filters <Filters @reset-form="data = []" @run-search="() => filterData(filters)" :report-button="true" class="mb-4">
@reset-form="data = []"
@run-search="() => filterData(filters)"
:report-button="true"
class="mb-4"
>
<Type13 @update:filters="(value) => filters = value" /> <Type13 @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" :column-width="100" @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"
:column-width="100"
@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 css-class="custom-table-column" :width="100" alignment="center"
css-class="custom-table-column" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" data-type="number" data-field="no"
:width="100" caption="No" />
alignment="center"
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1"
data-type="number"
data-field="no"
caption="No"
/>
<!-- <DxColumn <!-- <DxColumn
:width="120" :width="120"
alignment="center" alignment="center"
@ -63,284 +30,84 @@
name="NamaUID" name="NamaUID"
v-if="filters.groupBy" v-if="filters.groupBy"
/> --> /> -->
<DxColumn <DxColumn :width="170" alignment="center" data-field="fungsi_bidang" caption="Fungsi Bidang"
:width="170" css-class="custom-table-column" cell-template="cell-left" />
alignment="center"
data-field="fungsi_bidang"
caption="Fungsi Bidang"
css-class="custom-table-column"
cell-template="cell-left"
/>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total" data-type="number" caption="Total"
:width="150" css-class="custom-table-column" />
alignment="center"
data-field="total"
data-type="number"
caption="Total"
css-class="custom-table-column"
/>
<DxColumn alignment="center" caption="Sudah Selesai" css-class="custom-table-column"> <DxColumn alignment="center" caption="Sudah Selesai" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_selesai" data-type="number" caption="Jml"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="persen_selesai" data-type="number" caption="%"
data-field="total_selesai" css-class="custom-table-column" cell-template="percent" />
data-type="number"
caption="Jml"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_selesai"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-template="percent"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Belum Selesai" css-class="custom-table-column"> <DxColumn alignment="center" caption="Belum Selesai" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_inproses" data-type="number" caption="Jml"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="persen_inproses" data-type="number" caption="%"
data-field="total_inproses" css-class="custom-table-column" cell-template="percent" />
data-type="number"
caption="Jml"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_inproses"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-template="percent"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Response Time" css-class="custom-table-column"> <DxColumn alignment="center" caption="Response Time" css-class="custom-table-column">
<DxColumn alignment="center" caption="Hari" css-class="custom-table-column"> <DxColumn alignment="center" caption="Hari" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_durasi_response" data-type="number"
:width="150" caption="Total" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="avg_durasi_response" data-type="number"
data-field="total_durasi_response" caption="Rata-Rata" css-class="custom-table-column" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="min_durasi_response" data-type="number" caption="Max"
caption="Total" css-class="custom-table-column" cell-template="data-waktu" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="max_durasi_response" data-type="number" caption="Min"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_response"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_response"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_response"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-template="data-waktu"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_response" data-type="number"
:width="150" caption=">SLA" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_response" data-type="number"
data-field="total_diatas_sla_response" caption="≤SLA" css-class="custom-table-column" />
data-type="number"
caption=">SLA"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_response"
data-type="number"
caption="≤SLA"
css-class="custom-table-column"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column"> <DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column">
<DxColumn alignment="center" caption="Hari" css-class="custom-table-column"> <DxColumn alignment="center" caption="Hari" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_durasi_recovery" data-type="number"
:width="150" caption="Total" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="avg_durasi_recovery" data-type="number"
data-field="total_durasi_recovery" caption="Rata-Rata" css-class="custom-table-column" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="max_durasi_recovery" data-type="number" caption="Max"
caption="Total" css-class="custom-table-column" cell-template="data-waktu" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="min_durasi_recovery" data-type="number" caption="Min"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_recovery"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_recovery"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_recovery"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-template="data-waktu"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_recovery" data-type="number"
:width="150" caption=">SLA" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_recovery" data-type="number"
data-field="total_diatas_sla_recovery" caption="≤SLA" css-class="custom-table-column" />
data-type="number"
caption=">SLA"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_recovery"
data-type="number"
caption="≤SLA"
css-class="custom-table-column"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxSummary> <DxSummary>
<DxTotalItem <DxTotalItem summary-type="sum" display-format="Total" show-in-column="no" css-class="text-white" />
summary-type="sum" <DxTotalItem summary-type="sum" display-format="{0}" column="total" css-class="text-white" />
display-format="Total" <DxTotalItem summary-type="sum" display-format="{0}" column="total_selesai" css-class="text-white" />
show-in-column="no" <DxTotalItem summary-type="sum" display-format="{0}%" column="persen_selesai" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="total_inproses" css-class="text-white" />
/> <DxTotalItem summary-type="sum" display-format="{0}%" column="persen_inproses" css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_durasi_response" css-class="text-white" />
summary-type="sum" <DxTotalItem summary-type="sum" display-format="{0}" column="avg_durasi_response" css-class="text-white" />
display-format="{0}" <DxTotalItem summary-type="sum" display-format="{0}" column="min_durasi_response" css-class="text-white" />
column="total" <DxTotalItem summary-type="sum" display-format="{0}" column="max_durasi_response" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="total_diatas_sla_response"
/> css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_response"
summary-type="sum" css-class="text-white" />
display-format="{0}" <DxTotalItem summary-type="sum" display-format="{0}" column="total_durasi_recovery" css-class="text-white" />
column="total_selesai" <DxTotalItem summary-type="sum" display-format="{0}" column="avg_durasi_recovery" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="min_durasi_recovery" css-class="text-white" />
/> <DxTotalItem summary-type="sum" display-format="{0}" column="max_durasi_recovery" css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_diatas_sla_recovery"
summary-type="sum" css-class="text-white" />
display-format="{0}%" <DxTotalItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_recovery"
column="persen_selesai" css-class="text-white" />
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_inproses"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}%"
column="persen_inproses"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="min_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="max_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="min_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="max_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_recovery"
css-class="text-white"
/>
</DxSummary> </DxSummary>
<template #data-waktu="{ data }"> <template #data-waktu="{ data }">
@ -348,9 +115,11 @@
{{ parseInt(data.text) ? formatWaktu(data.text) : '-' }} {{ parseInt(data.text) ? formatWaktu(data.text) : '-' }}
</p> </p>
</template> </template>
<template #percent="{ data }"> <template #percent="{ data }">
<p>{{ data.text }}%</p> <p>{{ data.text }}%</p>
</template> </template>
<template #cell-left="{ data }"> <template #cell-left="{ data }">
<p class="text-left"> <p class="text-left">
{{ data.text }} {{ data.text }}
@ -378,15 +147,15 @@ import {
DxSummary, DxSummary,
DxTotalItem DxTotalItem
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf '
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils /graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showInd icator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
@ -500,3 +269,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -151,9 +151,11 @@
{{ parseInt(data.text) ? formatWaktu(data.text) : '-' }} {{ parseInt(data.text) ? formatWaktu(data.text) : '-' }}
</p> </p>
</template> </template>
<template #percent="{ data }"> <template #percent="{ data }">
<p>{{ data.text }}%</p> <p>{{ data.text }}%</p>
</template> </template>
<template #cell-left="{ data }"> <template #cell-left="{ data }">
<p class="text-left"> <p class="text-left">
{{ data.text }} {{ data.text }}
@ -187,9 +189,9 @@ import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/ utils/graphql'
const position = { of: '#data' } const position = { of : '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
@ -266,3 +268,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -1,58 +1,25 @@
<template> <template>
<Filters <Filters @reset-form="data = []" @run-search="() => filterData(filters)" :report-button="true" class="mb-4">
@reset-form="data = []"
@run-search="() => filterData(filters)"
:report-button="true"
class="mb-4"
>
<Type13 @update:filters="(value) => filters = value" /> <Type13 @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" :column-width="100" @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"
:column-width="100"
@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 css-class="custom-table-column" :width="100" alignment="center"
css-class="custom-table-column" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" data-type="number" data-field="no"
:width="100" caption="No" />
alignment="center"
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1"
data-type="number"
data-field="no"
caption="No"
/>
<!-- <DxColumn <!-- <DxColumn
:width="120" :width="120"
alignment="center" alignment="center"
@ -63,284 +30,84 @@
name="NamaUID" name="NamaUID"
v-if="filters.groupBy" v-if="filters.groupBy"
/> --> /> -->
<DxColumn <DxColumn :width="170" alignment="center" data-field="kelompok" caption="Kelompok Keluhan"
:width="170" css-class="custom-table-column" cell-template="cell-left" />
alignment="center"
data-field="kelompok"
caption="Kelompok Keluhan"
css-class="custom-table-column"
cell-template="cell-left"
/>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total" data-type="number" caption="Total"
:width="150" css-class="custom-table-column" />
alignment="center"
data-field="total"
data-type="number"
caption="Total"
css-class="custom-table-column"
/>
<DxColumn alignment="center" caption="Sudah Selesai" css-class="custom-table-column"> <DxColumn alignment="center" caption="Sudah Selesai" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_selesai" data-type="number" caption="Jml"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="persen_selesai" data-type="number" caption="%"
data-field="total_selesai" css-class="custom-table-column" cell-template="percent" />
data-type="number"
caption="Jml"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_selesai"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-template="percent"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Belum Selesai" css-class="custom-table-column"> <DxColumn alignment="center" caption="Belum Selesai" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_inproses" data-type="number" caption="Jml"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="persen_inproses" data-type="number" caption="%"
data-field="total_inproses" css-class="custom-table-column" cell-template="percent" />
data-type="number"
caption="Jml"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_inproses"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-template="percent"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Response Time" css-class="custom-table-column"> <DxColumn alignment="center" caption="Response Time" css-class="custom-table-column">
<DxColumn alignment="center" caption="Hari" css-class="custom-table-column"> <DxColumn alignment="center" caption="Hari" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_durasi_response" data-type="number"
:width="150" caption="Total" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="avg_durasi_response" data-type="number"
data-field="total_durasi_response" caption="Rata-Rata" css-class="custom-table-column" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="max_durasi_response" data-type="number" caption="Max"
caption="Total" css-class="custom-table-column" cell-template="data-waktu" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="min_durasi_response" data-type="number" caption="Min"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_response"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_response"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_response"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-template="data-waktu"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_response" data-type="number"
:width="150" caption=">SLA" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_response" data-type="number"
data-field="total_diatas_sla_response" caption="≤SLA" css-class="custom-table-column" />
data-type="number"
caption=">SLA"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_response"
data-type="number"
caption="≤SLA"
css-class="custom-table-column"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column"> <DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column">
<DxColumn alignment="center" caption="Hari" css-class="custom-table-column"> <DxColumn alignment="center" caption="Hari" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_durasi_recovery" data-type="number"
:width="150" caption="Total" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="avg_durasi_recovery" data-type="number"
data-field="total_durasi_recovery" caption="Rata-Rata" css-class="custom-table-column" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="max_durasi_recovery" data-type="number" caption="Max"
caption="Total" css-class="custom-table-column" cell-template="data-waktu" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="min_durasi_recovery" data-type="number" caption="Min"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_recovery"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_recovery"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_recovery"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-template="data-waktu"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_recovery" data-type="number"
:width="150" caption=">SLA" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_recovery" data-type="number"
data-field="total_diatas_sla_recovery" caption="≤SLA" css-class="custom-table-column" />
data-type="number"
caption=">SLA"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_recovery"
data-type="number"
caption="≤SLA"
css-class="custom-table-column"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxSummary> <DxSummary>
<DxTotalItem <DxTotalItem summary-type="sum" display-format="Total" show-in-column="no" css-class="text-white" />
summary-type="sum" <DxTotalItem summary-type="sum" display-format="{0}" column="total" css-class="text-white" />
display-format="Total" <DxTotalItem summary-type="sum" display-format="{0}" column="total_selesai" css-class="text-white" />
show-in-column="no" <DxTotalItem summary-type="sum" display-format="{0}%" column="persen_selesai" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="total_inproses" css-class="text-white" />
/> <DxTotalItem summary-type="sum" display-format="{0}%" column="persen_inproses" css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_durasi_response" css-class="text-white" />
summary-type="sum" <DxTotalItem summary-type="sum" display-format="{0}" column="avg_durasi_response" css-class="text-white" />
display-format="{0}" <DxTotalItem summary-type="sum" display-format="{0}" column="min_durasi_response" css-class="text-white" />
column="total" <DxTotalItem summary-type="sum" display-format="{0}" column="max_durasi_response" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="total_diatas_sla_response"
/> css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_response"
summary-type="sum" css-class="text-white" />
display-format="{0}" <DxTotalItem summary-type="sum" display-format="{0}" column="total_durasi_recovery" css-class="text-white" />
column="total_selesai" <DxTotalItem summary-type="sum" display-format="{0}" column="avg_durasi_recovery" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="min_durasi_recovery" css-class="text-white" />
/> <DxTotalItem summary-type="sum" display-format="{0}" column="max_durasi_recovery" css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_diatas_sla_recovery"
summary-type="sum" css-class="text-white" />
display-format="{0}%" <DxTotalItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_recovery"
column="persen_selesai" css-class="text-white" />
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_inproses"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}%"
column="persen_inproses"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="min_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="max_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="min_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="max_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_recovery"
css-class="text-white"
/>
</DxSummary> </DxSummary>
<template #data-waktu="{ data }"> <template #data-waktu="{ data }">
@ -348,9 +115,11 @@
{{ parseInt(data.text) ? formatWaktu(data.text) : '-' }} {{ parseInt(data.text) ? formatWaktu(data.text) : '-' }}
</p> </p>
</template> </template>
<template #percent="{ data }"> <template #percent="{ data }">
<p>{{ data.text }}%</p> <p>{{ data.text }}%</p>
</template> </template>
<template #cell-left="{ data }"> <template #cell-left="{ data }">
<p class="text-left"> <p class="text-left">
{{ data.text }} {{ data.text }}
@ -367,16 +136,16 @@ import { formatWaktu } from '@/components/Form/FiltersType/reference'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection, DxSelection,
DxSummary, DxSummary,
DxTotalItem DxTotalItem
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
@ -384,17 +153,17 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const onExporting = (e: any) => { c onst onExporting = (e: any) => {
if (e.format === 'pdf') { if (e.format === 'pdf') {
const doc = new jsPDF() const doc = new jsPDF()
exportToPdf({ exportToPdf({
jsPDFDocument: doc, jsPDFDocument: doc,
component: e.component, component: e.component,
indent: 5 indent: 5
}).then(() => { }).then(() => {
@ -499,3 +268,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -1,345 +1,105 @@
<template> <template>
<Filters <Filters @reset-form="data = []" @run-search="() => filterData(filters)" :report-button="true" class="mb-4">
@reset-form="data = []"
@run-search="() => filterData(filters)"
:report-button="true"
class="mb-4"
>
<Type13 @update:filters="(value) => filters = value" /> <Type13 @update:filters="(value) => filters = value" />
</Filters> </Filters>
<div> <div>
<DxDataGrid <DxDataGrid class="max-h-[calc(100vh-140px)] mb-10" :show-column-lines="true" :show-row-lines="false"
class="max-h-[calc(100vh-140px)] mb-10" :show-borders="true" :data-source="data" :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"
:data-source="data"
:row-alternation-enabled="true"
:hover-state-enabled="true"
@selection-changed="onSelectionChanged"
:column-width="100"
@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="100" alignment="center"
:width="100" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" caption="NO"
alignment="center" css-class="custom-table-column" data-type="number" data-field="no" />
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" <DxColumn :width="170" alignment="center" data-field="tanggal_lapor" caption="Tanggal Lapor"
caption="NO" css-class="custom-table-column" cell-template="cell-left" />
css-class="custom-table-column" <DxColumn :width="170" alignment="center" data-field="nama_uid" caption="Nama UID" css-class="custom-table-column"
data-type="number" :group-index="0" v-if="filters.groupBy" />
data-field="no"
/>
<DxColumn
:width="170"
alignment="center"
data-field="tanggal_lapor"
caption="Tanggal Lapor"
css-class="custom-table-column"
cell-template="cell-left"
/>
<DxColumn
:width="170"
alignment="center"
data-field="nama_uid"
caption="Nama UID"
css-class="custom-table-column"
:group-index="0"
v-if="filters.groupBy"
/>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total" data-type="number" caption="Total"
:width="150" css-class="custom-table-column" />
alignment="center"
data-field="total"
data-type="number"
caption="Total"
css-class="custom-table-column"
/>
<DxColumn alignment="center" caption="Sudah Selesai" css-class="custom-table-column"> <DxColumn alignment="center" caption="Sudah Selesai" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_selesai" data-type="number" caption="Jml"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="persen_selesai" data-type="number" caption="%"
data-field="total_selesai" css-class="custom-table-column" cell-template="percent" />
data-type="number"
caption="Jml"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_selesai"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-template="percent"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Belum Selesai" css-class="custom-table-column"> <DxColumn alignment="center" caption="Belum Selesai" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_inproses" data-type="number" caption="Jml"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="persen_inproses" data-type="number" caption="%"
data-field="total_inproses" css-class="custom-table-column" cell-template="percent" />
data-type="number"
caption="Jml"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_inproses"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-template="percent"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Response Time" css-class="custom-table-column"> <DxColumn alignment="center" caption="Response Time" css-class="custom-table-column">
<DxColumn alignment="center" caption="Hari" css-class="custom-table-column"> <DxColumn alignment="center" caption="Hari" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_durasi_response" data-type="number"
:width="150" caption="Total" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="avg_durasi_response" data-type="number"
data-field="total_durasi_response" caption="Rata-Rata" css-class="custom-table-column" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="max_durasi_response" data-type="number" caption="Max"
caption="Total" css-class="custom-table-column" cell-template="data-waktu" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="min_durasi_response" data-type="number" caption="Min"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_response"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_response"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_response"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-template="data-waktu"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_response" data-type="number"
:width="150" caption=">SLA" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_response" data-type="number"
data-field="total_diatas_sla_response" caption="≤SLA" css-class="custom-table-column" />
data-type="number"
caption=">SLA"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_response"
data-type="number"
caption="≤SLA"
css-class="custom-table-column"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column"> <DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column">
<DxColumn alignment="center" caption="Hari" css-class="custom-table-column"> <DxColumn alignment="center" caption="Hari" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_durasi_recovery" data-type="number"
:width="150" caption="Total" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="avg_durasi_recovery" data-type="number"
data-field="total_durasi_recovery" caption="Rata-Rata" css-class="custom-table-column" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="max_durasi_recovery" data-type="number" caption="Max"
caption="Total" css-class="custom-table-column" cell-template="data-waktu" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="min_durasi_recovery" data-type="number" caption="Min"
/> css-class="custom-table-column" cell-template="data-waktu" />
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_recovery"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_recovery"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-template="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_recovery"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-template="data-waktu"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_recovery" data-type="number"
:width="150" caption=">SLA" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_recovery" data-type="number"
data-field="total_diatas_sla_recovery" caption="≤SLA" css-class="custom-table-column" />
data-type="number"
caption=">SLA"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_recovery"
data-type="number"
caption="≤SLA"
css-class="custom-table-column"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxSummary> <DxSummary>
<DxTotalItem <DxTotalItem summary-type="sum" display-format="Total" show-in-column="no" css-class="text-white" />
summary-type="sum" <DxTotalItem summary-type="sum" display-format="{0}" column="total" css-class="text-white" />
display-format="Total" <DxTotalItem summary-type="sum" display-format="{0}" column="total_selesai" css-class="text-white" />
show-in-column="no" <DxTotalItem summary-type="sum" display-format="{0}%" column="persen_selesai" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="total_inproses" css-class="text-white" />
/> <DxTotalItem summary-type="sum" display-format="{0}%" column="persen_inproses" css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_durasi_response" css-class="text-white" />
summary-type="sum" <DxTotalItem summary-type="sum" display-format="{0}" column="avg_durasi_response" css-class="text-white" />
display-format="{0}" <DxTotalItem summary-type="sum" display-format="{0}" column="min_durasi_response" css-class="text-white" />
column="total" <DxTotalItem summary-type="sum" display-format="{0}" column="max_durasi_response" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="total_diatas_sla_response"
/> css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_response"
summary-type="sum" css-class="text-white" />
display-format="{0}" <DxTotalItem summary-type="sum" display-format="{0}" column="total_durasi_recovery" css-class="text-white" />
column="total_selesai" <DxTotalItem summary-type="sum" display-format="{0}" column="avg_durasi_recovery" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="min_durasi_recovery" css-class="text-white" />
/> <DxTotalItem summary-type="sum" display-format="{0}" column="max_durasi_recovery" css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_diatas_sla_recovery"
summary-type="sum" css-class="text-white" />
display-format="{0}%" <DxTotalItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_recovery"
column="persen_selesai" css-class="text-white" />
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_inproses"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}%"
column="persen_inproses"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="min_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="max_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="min_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="max_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_recovery"
css-class="text-white"
/>
</DxSummary> </DxSummary>
<template #data-waktu="{ data }"> <template #data-waktu="{ data }">
@ -347,9 +107,11 @@
{{ parseInt(data.text) ? formatWaktu(data.text) : '-' }} {{ parseInt(data.text) ? formatWaktu(data.text) : '-' }}
</p> </p>
</template> </template>
<template #percent="{ data }"> <template #percent="{ data }">
<p>{{ data.text }}%</p> <p>{{ data.text }}%</p>
</template> </template>
<template #cell-left="{ data }"> <template #cell-left="{ data }">
<p class="text-left"> <p class="text-left">
{{ data.text }} {{ data.text }}
@ -382,11 +144,11 @@ import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs'
import { useQuery } from '@vue/apollo-composable' import { useQ uery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/graphql '
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const onExporting = (e: any) => { const onExporting = (e: any) => {
@ -461,3 +223,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -1,58 +1,25 @@
<template> <template>
<Filters <Filters @reset-form="data = []" @run-search="() => filterData(filters)" :report-button="true" class="mb-4">
@reset-form="data = []"
@run-search="() => filterData(filters)"
:report-button="true"
class="mb-4"
>
<Type8 @update:filters="(value) => filters = value" /> <Type8 @update:filters="(value) => filters = value" />
</Filters> </Filters>
<div> <div>
<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" :column-width="100" @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"
:column-width="100"
@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="100" alignment="center"
:width="100" :calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1" caption="NO"
alignment="center" css-class="custom-table-column" data-type="number" data-field="no" />
:calculateCellValue="(item: any) => data.findIndex((i) => i == item) + 1"
caption="NO"
css-class="custom-table-column"
data-type="number"
data-field="no"
/>
<!-- <DxColumn <!-- <DxColumn
:width="120" :width="120"
@ -63,411 +30,121 @@
:group-index="0" :group-index="0"
/> --> /> -->
<DxColumn <DxColumn :width="170" alignment="center" data-field="nama_ulp" caption="Unit" css-class="custom-table-column"
:width="170" cell-templete="cell-left" />
alignment="center"
data-field="nama_ulp"
caption="Unit"
css-class="custom-table-column"
cell-templete="cell-left"
/>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total" data-type="number" caption="Total"
:width="150" css-class="custom-table-column" />
alignment="center"
data-field="total"
data-type="number"
caption="Total"
css-class="custom-table-column"
/>
<DxColumn alignment="center" caption="Sudah Selesai" css-class="custom-table-column"> <DxColumn alignment="center" caption="Sudah Selesai" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_selesai" data-type="number" caption="Jml"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="persen_selesai" data-type="number" caption="%"
data-field="total_selesai" css-class="custom-table-column" cell-templete="percent" />
data-type="number"
caption="Jml"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_selesai"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-templete="percent"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Belum Selesai" css-class="custom-table-column"> <DxColumn alignment="center" caption="Belum Selesai" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_inproses" data-type="number" caption="Jml"
:width="150" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="persen_inproses" data-type="number" caption="%"
data-field="total_inproses" css-class="custom-table-column" cell-templete="percent" />
data-type="number"
caption="Jml"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="persen_inproses"
data-type="number"
caption="%"
css-class="custom-table-column"
cell-templete="percent"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Response Time" css-class="custom-table-column"> <DxColumn alignment="center" caption="Response Time" css-class="custom-table-column">
<DxColumn alignment="center" caption="Hari" css-class="custom-table-column"> <DxColumn alignment="center" caption="Hari" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_durasi_response" data-type="number"
:width="150" caption="Total" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="avg_durasi_response" data-type="number"
data-field="total_durasi_response" caption="Rata-Rata" css-class="custom-table-column" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="max_durasi_response" data-type="number" caption="Max"
caption="Total" css-class="custom-table-column" cell-templete="data-waktu" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="min_durasi_response" data-type="number" caption="Min"
/> css-class="custom-table-column" cell-templete="data-waktu" />
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_response"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_response"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-templete="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_response"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-templete="data-waktu"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_response" data-type="number"
:width="150" caption=">SLA" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_response" data-type="number"
data-field="total_diatas_sla_response" caption="≤SLA" css-class="custom-table-column" />
data-type="number"
caption=">SLA"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_response"
data-type="number"
caption="≤SLA"
css-class="custom-table-column"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column"> <DxColumn alignment="center" caption="Penyelesaian" css-class="custom-table-column">
<DxColumn alignment="center" caption="Hari" css-class="custom-table-column"> <DxColumn alignment="center" caption="Hari" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_durasi_recovery" data-type="number"
:width="150" caption="Total" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="avg_durasi_recovery" data-type="number"
data-field="total_durasi_recovery" caption="Rata-Rata" css-class="custom-table-column" />
data-type="number" <DxColumn :width="150" alignment="center" data-field="max_durasi_recovery" data-type="number" caption="Max"
caption="Total" css-class="custom-table-column" cell-templete="data-waktu" />
css-class="custom-table-column" <DxColumn :width="150" alignment="center" data-field="min_durasi_recovery" data-type="number" caption="Min"
/> css-class="custom-table-column" cell-templete="data-waktu" />
<DxColumn
:width="150"
alignment="center"
data-field="avg_durasi_recovery"
data-type="number"
caption="Rata-Rata"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="max_durasi_recovery"
data-type="number"
caption="Max"
css-class="custom-table-column"
cell-templete="data-waktu"
/>
<DxColumn
:width="150"
alignment="center"
data-field="min_durasi_recovery"
data-type="number"
caption="Min"
css-class="custom-table-column"
cell-templete="data-waktu"
/>
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Laporan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Laporan" css-class="custom-table-column">
<DxColumn <DxColumn :width="150" alignment="center" data-field="total_diatas_sla_recovery" data-type="number"
:width="150" caption=">SLA" css-class="custom-table-column" />
alignment="center" <DxColumn :width="150" alignment="center" data-field="total_dibawah_sla_recovery" data-type="number"
data-field="total_diatas_sla_recovery" caption="≤SLA" css-class="custom-table-column" />
data-type="number"
caption=">SLA"
css-class="custom-table-column"
/>
<DxColumn
:width="150"
alignment="center"
data-field="total_dibawah_sla_recovery"
data-type="number"
caption="≤SLA"
css-class="custom-table-column"
/>
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxSummary> <DxSummary>
<DxGroupItem <DxGroupItem summary-type="sum" display-format="Total" show-in-column="no" css-class="text-white"
summary-type="sum" :show-in-group-footer="true" />
display-format="Total" <DxGroupItem summary-type="sum" display-format="{0}" column="total" css-class="text-white"
show-in-column="no" :show-in-group-footer="true" />
css-class="text-white" <DxGroupItem summary-type="sum" display-format="{0}" column="total_selesai" css-class="text-white"
:show-in-group-footer="true" :show-in-group-footer="true" />
/> <DxGroupItem summary-type="sum" display-format="{0}%" column="persen_selesai" css-class="text-white"
<DxGroupItem :show-in-group-footer="true" />
summary-type="sum" <DxGroupItem summary-type="sum" display-format="{0}" column="total_inproses" css-class="text-white"
display-format="{0}" :show-in-group-footer="true" />
column="total" <DxGroupItem summary-type="sum" display-format="{0}%" column="persen_inproses" css-class="text-white"
css-class="text-white" :show-in-group-footer="true" />
:show-in-group-footer="true" <DxGroupItem summary-type="sum" display-format="{0}" column="total_durasi_response" css-class="text-white"
/> :show-in-group-footer="true" />
<DxGroupItem <DxGroupItem summary-type="sum" display-format="{0}" column="avg_durasi_response" css-class="text-white"
summary-type="sum" :show-in-group-footer="true" />
display-format="{0}" <DxGroupItem summary-type="sum" display-format="{0}" column="min_durasi_response" css-class="text-white"
column="total_selesai" :show-in-group-footer="true" />
css-class="text-white" <DxGroupItem summary-type="sum" display-format="{0}" column="max_durasi_response" css-class="text-white"
:show-in-group-footer="true" :show-in-group-footer="true" />
/> <DxGroupItem summary-type="sum" display-format="{0}" column="total_diatas_sla_response" css-class="text-white"
<DxGroupItem :show-in-group-footer="true" />
summary-type="sum" <DxGroupItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_response" css-class="text-white"
display-format="{0}%" :show-in-group-footer="true" />
column="persen_selesai" <DxGroupItem summary-type="sum" display-format="{0}" column="total_durasi_recovery" css-class="text-white"
css-class="text-white" :show-in-group-footer="true" />
:show-in-group-footer="true" <DxGroupItem summary-type="sum" display-format="{0}" column="avg_durasi_recovery" css-class="text-white"
/> :show-in-group-footer="true" />
<DxGroupItem <DxGroupItem summary-type="sum" display-format="{0}" column="min_durasi_recovery" css-class="text-white"
summary-type="sum" :show-in-group-footer="true" />
display-format="{0}" <DxGroupItem summary-type="sum" display-format="{0}" column="max_durasi_recovery" css-class="text-white"
column="total_inproses" :show-in-group-footer="true" />
css-class="text-white" <DxGroupItem summary-type="sum" display-format="{0}" column="total_diatas_sla_recovery" css-class="text-white"
:show-in-group-footer="true" :show-in-group-footer="true" />
/> <DxGroupItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_recovery" css-class="text-white"
<DxGroupItem :show-in-group-footer="true" />
summary-type="sum"
display-format="{0}%"
column="persen_inproses"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="total_durasi_response"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_response"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="min_durasi_response"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="max_durasi_response"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_response"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_response"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="total_durasi_recovery"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_recovery"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="min_durasi_recovery"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="max_durasi_recovery"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_recovery"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxGroupItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_recovery"
css-class="text-white"
:show-in-group-footer="true"
/>
<DxTotalItem <DxTotalItem summary-type="sum" display-format="Total" show-in-column="no" css-class="text-white" />
summary-type="sum" <DxTotalItem summary-type="sum" display-format="{0}" column="total" css-class="text-white" />
display-format="Total" <DxTotalItem summary-type="sum" display-format="{0}" column="total_selesai" css-class="text-white" />
show-in-column="no" <DxTotalItem summary-type="sum" display-format="{0}%" column="persen_selesai" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="total_inproses" css-class="text-white" />
/> <DxTotalItem summary-type="sum" display-format="{0}%" column="persen_inproses" css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_durasi_response" css-class="text-white" />
summary-type="sum" <DxTotalItem summary-type="sum" display-format="{0}" column="avg_durasi_response" css-class="text-white" />
display-format="{0}" <DxTotalItem summary-type="sum" display-format="{0}" column="min_durasi_response" css-class="text-white" />
column="total" <DxTotalItem summary-type="sum" display-format="{0}" column="max_durasi_response" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="total_diatas_sla_response"
/> css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_response"
summary-type="sum" css-class="text-white" />
display-format="{0}" <DxTotalItem summary-type="sum" display-format="{0}" column="total_durasi_recovery" css-class="text-white" />
column="total_selesai" <DxTotalItem summary-type="sum" display-format="{0}" column="avg_durasi_recovery" css-class="text-white" />
css-class="text-white" <DxTotalItem summary-type="sum" display-format="{0}" column="min_durasi_recovery" css-class="text-white" />
/> <DxTotalItem summary-type="sum" display-format="{0}" column="max_durasi_recovery" css-class="text-white" />
<DxTotalItem <DxTotalItem summary-type="sum" display-format="{0}" column="total_diatas_sla_recovery"
summary-type="sum" css-class="text-white" />
display-format="{0}%" <DxTotalItem summary-type="sum" display-format="{0}" column="total_dibawah_sla_recovery"
column="persen_selesai" css-class="text-white" />
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_inproses"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}%"
column="persen_inproses"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="min_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="max_durasi_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_response"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="avg_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="min_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="max_durasi_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_diatas_sla_recovery"
css-class="text-white"
/>
<DxTotalItem
summary-type="sum"
display-format="{0}"
column="total_dibawah_sla_recovery"
css-class="text-white"
/>
</DxSummary> </DxSummary>
<template #data-waktu="{ data }"> <template #data-waktu="{ data }">
@ -475,9 +152,11 @@
{{ parseInt(data.text) ? formatWaktu(data.text) : '-' }} {{ parseInt(data.text) ? formatWaktu(data.text) : '-' }}
</p> </p>
</template> </template>
<template #percent="{ data }"> <template #percent="{ data }">
<p>{{ data.text }}%</p> <p>{{ data.text }}%</p>
</template> </template>
<template #cell-left="{ data }"> <template #cell-left="{ data }">
<p class="text-left"> <p class="text-left">
{{ data.text }} {{ data.text }}
@ -511,11 +190,11 @@ import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-co mposable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: ' #data' }
const showIndicator = ref(true) const showIndicator = ref(t rue)
const shading = ref(true) const shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const onExporting = (e: any) => { const onExporting = (e: any) => {
@ -590,3 +269,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -73,22 +73,22 @@ import Type8 from '@/components/Form/FiltersType/Type8.vue'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -165,3 +165,4 @@ const filterData = (params: any) => {
}) })
} }
</script> </script>
@/utils/api/graphql

View File

@ -49,14 +49,14 @@ import Type2 from '@/components/Form/FiltersType/Type2.vue'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
@ -65,7 +65,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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const currentYear = ref(new Date().getFullYear()) const currentYear = ref(new Date().getFullYear())
const currentMonth = ref(new Date().getMonth()) const currentMonth = ref(new Date().getMonth())
@ -146,3 +146,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -64,7 +64,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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const currentYear = ref(new Date().getFullYear()) const currentYear = ref(new Date().getFullYear())
const currentMonth = ref(new Date().getMonth()) const currentMonth = ref(new Date().getMonth())
@ -146,3 +146,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -50,7 +50,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const currentYear = ref(new Date().getFullYear()) const currentYear = ref(new Date().getFullYear())
const currentMonth = ref(new Date().getMonth()) const currentMonth = ref(new Date().getMonth())
@ -131,3 +131,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -56,7 +56,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const currentYear = ref(new Date().getFullYear()) const currentYear = ref(new Date().getFullYear())
const currentMonth = ref(new Date().getMonth()) const currentMonth = ref(new Date().getMonth())
const lastYear = ref(currentYear.value - 1) const lastYear = ref(currentYear.value - 1)
@ -134,3 +134,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -99,7 +99,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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const currentYear = ref(new Date().getFullYear()) const currentYear = ref(new Date().getFullYear())
const currentMonth = ref(new Date().getMonth()) const currentMonth = ref(new Date().getMonth())
@ -199,3 +199,4 @@ onMounted(() => {
getMonthName(filters.value.bulan.id) getMonthName(filters.value.bulan.id)
}) })
</script> </script>
@/utils/api/graphql

View File

@ -89,8 +89,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/api/api.graphql'
import { queries } from '@/utils/graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -173,3 +172,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -59,12 +59,12 @@ import {
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_export er'
import { saveAs } from 'file-saver' 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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const currentYear = ref(new Date().getFullYear()) const currentYear = ref(new Date().getFullYear())
const currentMonth = ref(new Date().getMonth()) const currentMonth = ref(new Date().getMonth())
@ -145,3 +145,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -49,14 +49,14 @@ import Type2 from '@/components/Form/FiltersType/Type2.vue'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
@ -65,7 +65,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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const currentYear = ref(new Date().getFullYear()) const currentYear = ref(new Date().getFullYear())
const currentMonth = ref(new Date().getMonth()) const currentMonth = ref(new Date().getMonth())
@ -147,3 +147,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -49,14 +49,14 @@ import Type2 from '@/components/Form/FiltersType/Type2.vue'
import { ref } from 'vue' import { ref } from 'vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
@ -65,7 +65,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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const currentYear = ref(new Date().getFullYear()) const currentYear = ref(new Date().getFullYear())
const currentMonth = ref(new Date().getMonth()) const currentMonth = ref(new Date().getMonth())
@ -147,3 +147,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -64,7 +64,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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -145,3 +145,4 @@ onMounted(() => {
}) })
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -64,7 +64,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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -144,3 +144,4 @@ const onSelectionChanged = ({ selectedRowsData }: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -47,6 +47,7 @@
<template #percent="{ data }"> <template #percent="{ data }">
<p>{{ data.text }}%</p> <p>{{ data.text }}%</p>
</template> </template>
<template #cell-left="{ data }"> <template #cell-left="{ data }">
<p class="text-left"> <p class="text-left">
{{ data.text }} {{ data.text }}
@ -62,14 +63,14 @@ import Filters from '@/components/Form/Filters.vue'
import Type2 from '@/components/Form/FiltersType/Type2.vue' import Type2 from '@/components/Form/FiltersType/Type2.vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
@ -77,7 +78,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -162,3 +163,4 @@ const filterData = (params: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -49,22 +49,22 @@ import Filters from '@/components/Form/Filters.vue'
import Type2 from '@/components/Form/FiltersType/Type2.vue' import Type2 from '@/components/Form/FiltersType/Type2.vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_ exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'fi le-saver'
import { Workbook } from 'exceljs' import { Workbook } from 'exceljs'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -147,3 +147,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -27,10 +27,10 @@
caption="Total Gangguan" css-class="custom-table-column" /> caption="Total Gangguan" css-class="custom-table-column" />
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Keluhan Berulang" css-class="custom-table-column"> <DxColumn alignment="center" caption="Keluhan Berulang" css-class="custom-table-column">
<DxColumn :width="150" alignment="center" data-field="komplain_pelanggan" data-type="number" caption="Jan 2020" <DxColumn :width="150" alignment="center" data-field="komplain_pelanggan" data-type="number"
css-class="custom-table-column" /> caption="Jan 2020" css-class="custom-table-column" />
<DxColumn :width="150" alignment="center" data-field="keluhan_total" data-type="number" caption="Total Keluhan" <DxColumn :width="150" alignment="center" data-field="keluhan_total" data-type="number"
css-class="custom-table-column" /> caption="Total Keluhan" css-class="custom-table-column" />
</DxColumn> </DxColumn>
</DxColumn> </DxColumn>
<DxColumn :min-width="150" alignment="center" data-field="komplain_pelanggan" data-type="number" <DxColumn :min-width="150" alignment="center" data-field="komplain_pelanggan" data-type="number"
@ -39,6 +39,7 @@
<template #percent="{ data }"> <template #percent="{ data }">
<p>{{ data.text }}%</p> <p>{{ data.text }}%</p>
</template> </template>
<template #cell-left="{ data }"> <template #cell-left="{ data }">
<p class="text-left"> <p class="text-left">
{{ data.text }} {{ data.text }}
@ -54,22 +55,23 @@ import Filters from '@/components/Form/Filters.vue'
import Type2 from '@/components/Form/FiltersType/Type2.vue' import Type2 from '@/components/Form/FiltersType/Type2.vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from fro
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
'devextreme/excel_exporter'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -160,3 +162,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -17,8 +17,8 @@
<DxExport :enabled="true" :formats="['pdf', 'xlsx', 'document']" :allow-export-selected-data="false" /> <DxExport :enabled="true" :formats="['pdf', 'xlsx', 'document']" :allow-export-selected-data="false" />
<DxColumnFixing :enabled="true" /> <DxColumnFixing :enabled="true" />
<DxColumn :width="170" alignment="center" data-field="nama_ulp" caption="Nama Unit" css-class="custom-table-column" <DxColumn :width="170" alignment="center" data-field="nama_ulp" caption="Nama Unit"
cell-template="cell-left" /> css-class="custom-table-column" cell-template="cell-left" />
<DxColumn alignment="center" :caption="`s.d ${getMonthName(currentMonth - 1)} ${lastYear}`" <DxColumn alignment="center" :caption="`s.d ${getMonthName(currentMonth - 1)} ${lastYear}`"
css-class="custom-table-column"> css-class="custom-table-column">
@ -52,8 +52,8 @@
<DxColumn :width="120" alignment="center" data-field="total_informasi_tahun_ini" data-type="number" <DxColumn :width="120" alignment="center" data-field="total_informasi_tahun_ini" data-type="number"
caption="Total" css-class="custom-table-column" /> caption="Total" css-class="custom-table-column" />
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Total Komplain" css-class="custom-table-column" data-field="total_tahun_ini" <DxColumn alignment="center" caption="Total Komplain" css-class="custom-table-column"
data-type="number" /> data-field="total_tahun_ini" data-type="number" />
</DxColumn> </DxColumn>
<DxColumn alignment="center" caption="Delta Penurunan" css-class="custom-table-column"> <DxColumn alignment="center" caption="Delta Penurunan" css-class="custom-table-column">
@ -68,8 +68,8 @@
<DxColumn alignment="center" caption="% Penurunan YoY" css-class="custom-table-column"> <DxColumn alignment="center" caption="% Penurunan YoY" css-class="custom-table-column">
<DxColumn :width="150" alignment="center" data-field="persen_delta_keluhan" data-type="number" caption="Keluhan" <DxColumn :width="150" alignment="center" data-field="persen_delta_keluhan" data-type="number" caption="Keluhan"
css-class="custom-table-column" cell-template="percent" /> css-class="custom-table-column" cell-template="percent" />
<DxColumn :width="150" alignment="center" data-field="persen_delta_gangguan" data-type="number" caption="Gangguan" <DxColumn :width="150" alignment="center" data-field="persen_delta_gangguan" data-type="number"
css-class="custom-table-column" cell-template="percent" /> caption="Gangguan" css-class="custom-table-column" cell-template="percent" />
<DxColumn :width="150" alignment="center" data-field="persen_delta_informasi" data-type="number" <DxColumn :width="150" alignment="center" data-field="persen_delta_informasi" data-type="number"
caption="Informasi" css-class="custom-table-column" cell-template="percent" /> caption="Informasi" css-class="custom-table-column" cell-template="percent" />
<DxColumn :width="150" alignment="center" data-field="persen_delta_total" data-type="number" caption="% Total" <DxColumn :width="150" alignment="center" data-field="persen_delta_total" data-type="number" caption="% Total"
@ -79,6 +79,7 @@
<template #percent="{ data }"> <template #percent="{ data }">
<p>{{ data.text }}%</p> <p>{{ data.text }}%</p>
</template> </template>
<template #cell-left="{ data }"> <template #cell-left="{ data }">
<p class="text-left"> <p class="text-left">
{{ data.text }} {{ data.text }}
@ -94,14 +95,14 @@ import Filters from '@/components/Form/Filters.vue'
import Type2 from '@/components/Form/FiltersType/Type2.vue' import Type2 from '@/components/Form/FiltersType/Type2.vue'
import { DxDataGrid } from 'devextreme-vue' import { DxDataGrid } from 'devextreme-vue'
import { import {
DxColumn, DxColumn,
DxColumnFixing, DxColumnFixing,
DxExport, DxExport,
DxLoadPanel, DxLoadPanel,
DxPaging, DxPaging,
DxScrolling, DxScrolling,
DxSearchPanel, DxSearchPanel,
DxSelection DxSelection
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
@ -110,7 +111,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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' i mport { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
@ -197,3 +198,4 @@ const filterData = (params: any) => {
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -77,7 +77,7 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -156,3 +156,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -61,9 +61,8 @@ import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' import { saveAs } from 'file-saver'
import { Workbook } from 'exceljs'
import { useQuery } from '@vue/apollo-composable' import { useQuery } from '@vue/apollo-composable'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -84,17 +83,17 @@ const onExporting = (e: any) => {
doc.save(`.pdf`) doc.save(`.pdf`)
}) })
} else { } else {
const workbook = new Workbook() const workbook = new Wor kbook()
const worksheet = workbook.addWorksheet('Employees') const worksheet = workbook.addWorksheet('Employees')
exportToExcel({ exportToExcel({
component: e.component, component: e.component,
worksheet, et,
autoFilterEnabled: true autoFilterEnable
}).then(() => { }).then(() => {
workbook.xlsx.writeBuffer().then((buffer: any) => { workbo ok.xlsx.writeBuffer().then((buffer: any) => {
saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx') saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx')
}) })
}) })
e.cancel = true e.cancel = true
@ -142,3 +141,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -69,13 +69,13 @@ import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter'
import { saveAs } from 'file-saver' 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 { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) co nst shading = ref(true)
const showPane = ref(true) const showPane = ref(true)
const dataDetail = ref<any>() con st dataDetail = ref<any>()
const showDetail = ref(false) const showDetail = ref(fals e)
const data = ref<any[]>([]) const data = ref<any[]>([])
const onExporting = (e: any) => { const onExporting = (e: any) => {
@ -95,53 +95,51 @@ const onExporting = (e: any) => {
exportToExcel({ exportToExcel({
component: e.component, component: e.component,
worksheet, workshe autoFilterEnabled: true
autoFilterEnabled: true
}).then(() => { }).then(() => {
workbook.xlsx.writeBuffer().then((buffer: any) => { book.x eBuffer().then((buffer: any) => {
saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'DataGrid.xlsx') saveAs(new Blob([bu type: 'application/octet-stream' }), 'DataGrid. }
})
})
e.cancel = true e.cancel = true
}
}
const onSelectionChanged = ({ selectedRowsData }: any) => {
const data = selectedRowsData[0]
console.log(data)
}
const { onResult, onError, loading, refetch } = useQuery(queries.monalisa.laporan.kumulatif.kepatuhandanAkurasiDalamPelaporanKumulatif, {
regional: '',
idUlp: 0,
idUid: 0,
idUp3: 0,
bulan: 10,
tahun: 2023
})
const filterData = (params: any) => {
const { regional, ulp, uid, up3, bulan, tahun } = params
refetch({
regional: regional,
idUlp: ulp ? ulp.id : 0,
idUid: uid ? uid.id : 0,
idUp3: up3 ? up3.id : 0,
bulan: bulan ? bulan.id : 10,
tahun: bulan ? tahun.id : 2023
})
onResult((queryResult) => {
if (queryResult.data != undefined) {
data.value = queryResult.data.kepatuhandanAkurasiDalamPelaporanKumulatif
} }
console.log(queryResult.data)
console.log(queryResult.loading)
console.log(queryResult.networkStatus)
})
onError((error) => {
console.log(error)
})
} }
const filters = ref()
const onSelectionChanged = ({ selectedRowsData }: any) => {
const data = selectedRowsData[0]
console.log(data)
}
const { onResult, onError, loading, refetch } = useQuery(queries.monalisa.laporan.kumulatif.kepatuhandanAkurasiDalamPelaporanKumulatif, {
regional: '',
idUlp: 0,
idUid: 0,
idUp3: 0,
bulan: 10,
tahun: 2023
})
const filterData = (params: any) => {
const { regional, ulp, uid, up3, bulan, tahun } = params
refetch({
regional: regional,
idUlp: ulp ? ulp.id : 0,
idUid: uid ? uid.id : 0,
idUp3: up3 ? up3.id : 0,
bulan: bulan ? bulan.id : 10,
tahun: bulan ? tahun.id : 2023
})
onResult((queryResult) => {
if (queryResult.data != undefined) {
data.value = queryResult.data.kepatuhandanAkurasiDalamPelaporanKumulatif
}
console.log(queryResult.data)
console.log(queryResult.loading)
console.log(queryResult.networkStatus)
})
onError((error) => {
console.log(error)
})
}
const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -105,12 +105,12 @@ import {
} from 'devextreme-vue/data-grid' } from 'devextreme-vue/data-grid'
import { jsPDF } from 'jspdf' import { jsPDF } from 'jspdf'
import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter'
import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' import { exportDataGrid as exportToExcel } from 'devextreme/ex cel_exporter'
import { saveAs } from 'file-saver' 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 { getMonthName } from '@/utils/texts' import { getMonthName } from '@/utils/texts'
import { queries } from '@/utils/graphql' import { queries } from '@/utils/api/api.graphql'
const position = { of: '#data' } const position = { of: '#data' }
const showIndicator = ref(true) const showIndicator = ref(true)
const shading = ref(true) const shading = ref(true)
@ -191,3 +191,4 @@ const filterData = (params: any) => {
} }
const filters = ref() const filters = ref()
</script> </script>
@/utils/api/graphql

View File

@ -5,7 +5,7 @@ import App from './App.vue'
import router from './router' import router from './router'
import { createApp, provide, h } from 'vue' import { createApp, provide, h } from 'vue'
import { DefaultApolloClient } from '@vue/apollo-composable' import { DefaultApolloClient } from '@vue/apollo-composable'
import { apolloClient } from './utils/graphql' import { apolloClient } from '@/utils/api/api.graphql'
import { VanillaComponents, defineConfiguration } from '@flavorly/vanilla-components' import { VanillaComponents, defineConfiguration } from '@flavorly/vanilla-components'
const app = createApp({ const app = createApp({

View File

@ -1,4 +1,3 @@
//deploy vm
import axios from 'axios' import axios from 'axios'
const url = import.meta.env.VITE_APP_REST_ENDPOINT const url = import.meta.env.VITE_APP_REST_ENDPOINT