Add CTT LaporanCttKwhPeriksa component
This commit is contained in:
		
							
								
								
									
										198
									
								
								src/components/Pages/Ctt/CTT_LaporanCttKwhPeriksa.vue
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										198
									
								
								src/components/Pages/Ctt/CTT_LaporanCttKwhPeriksa.vue
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,198 @@ | ||||
| <template> | ||||
|   <Filters @run-search="() => filterData(filters)" class="mb-4"> | ||||
|     <Type3 @update:filters="(value) => filters = value" /> | ||||
|   </Filters> | ||||
|   <div id="data"> | ||||
|     <DxDataGrid class="max-h-[calc(100vh-140px)]" :show-column-lines="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" /> | ||||
|       <DxPaging :enabled="false" /> | ||||
|       <DxScrolling column-rendering-mode="virtual" mode="virtual" /> | ||||
|       <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" /> | ||||
|       <DxExport :enabled="true" :formats="['pdf', 'xlsx', 'document']" :allow-export-selected-data="false" /> | ||||
|       <DxColumnFixing :enabled="true" /> | ||||
|  | ||||
|       <DxColumn :width="170" alignment="center" data-field="nama_posko" caption="Nama Unit" | ||||
|         css-class="custom-table-column" /> | ||||
|       <DxColumn alignment="center" caption="Total WO" css-class="custom-table-column"> | ||||
|         <DxColumn alignment="center" caption="CC 123" css-class="custom-table-column"> | ||||
|           <DxColumn :width="150" alignment="center" data-field="total_wo_cc123" data-type="number" caption="a" | ||||
|             css-class="custom-table-column" /> | ||||
|         </DxColumn> | ||||
|         <DxColumn alignment="center" caption="PLN Mobile" css-class="custom-table-column"> | ||||
|           <DxColumn :width="150" alignment="center" data-field="total_wo_pln_mobile" data-type="number" caption="b" | ||||
|             css-class="custom-table-column" /> | ||||
|         </DxColumn> | ||||
|         <DxColumn alignment="center" caption="COMCEN" css-class="custom-table-column"> | ||||
|           <DxColumn :width="150" alignment="center" data-field="total_wo_comcen" data-type="number" caption="c" | ||||
|             css-class="custom-table-column" /> | ||||
|         </DxColumn> | ||||
|         <DxColumn alignment="center" caption="Total" css-class="custom-table-column"> | ||||
|           <DxColumn :width="150" alignment="center" data-field="total_wo" data-type="number" caption="d=b+c" | ||||
|             css-class="custom-table-column" /> | ||||
|         </DxColumn> | ||||
|       </DxColumn> | ||||
|       <DxColumn alignment="center" caption="Rekomendasi sistem" css-class="custom-table-column"> | ||||
|         <DxColumn alignment="center" caption="Mendatangkan Petugas" css-class="custom-table-column"> | ||||
|           <DxColumn :width="150" alignment="center" data-field="rekomendasi_sistem_mendatangkan_petugas" | ||||
|             data-type="number" caption="e" css-class="custom-table-column" /> | ||||
|         </DxColumn> | ||||
|         <DxColumn alignment="center" caption="Diberikan ke Pelanggan" css-class="custom-table-column"> | ||||
|           <DxColumn :width="150" alignment="center" data-field="total_wo_loket" data-type="number" caption="f" | ||||
|             css-class="custom-table-column" /> | ||||
|         </DxColumn> | ||||
|       </DxColumn> | ||||
|       <DxColumn alignment="center" caption="DLPD" css-class="custom-table-column"> | ||||
|         <DxColumn :width="150" alignment="center" data-field="dlpd" data-type="number" caption="g" | ||||
|           css-class="custom-table-column" /> | ||||
|       </DxColumn> | ||||
|       <DxColumn alignment="center" caption="Histori P2TL" css-class="custom-table-column"> | ||||
|         <DxColumn :width="150" alignment="center" data-field="history_p2ti" data-type="number" caption="h" | ||||
|           css-class="custom-table-column" /> | ||||
|       </DxColumn> | ||||
|     </DxDataGrid> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script setup lang="ts"> | ||||
| import { onMounted, ref } from 'vue' | ||||
| import { useFiltersStore } from '@/stores/filters' | ||||
| import { DxDataGrid } from 'devextreme-vue' | ||||
| import { | ||||
|   DxColumn, | ||||
|   DxColumnFixing, | ||||
|   DxExport, | ||||
|   DxLoadPanel, | ||||
|   DxPaging, | ||||
|   DxScrolling, | ||||
|   DxSearchPanel, | ||||
|   DxSelection | ||||
| } from 'devextreme-vue/data-grid' | ||||
| import { jsPDF } from 'jspdf' | ||||
| import { exportDataGrid as exportToPdf } from 'devextreme/pdf_exporter' | ||||
| import { exportDataGrid as exportToExcel } from 'devextreme/excel_exporter' | ||||
| import { saveAs } from 'file-saver' | ||||
| import { Workbook } from 'exceljs' | ||||
| import Filters from '@/components/Form/Filters.vue' | ||||
| import { Type3 } from '@/components/Form/FiltersType' | ||||
| import { useQuery } from '@vue/apollo-composable' | ||||
| import gql from 'graphql-tag' | ||||
| const position = { of: '#data' } | ||||
| const showIndicator = ref(true) | ||||
| const shading = ref(true) | ||||
| const showPane = ref(true) | ||||
| const dataDetail = ref<any>() | ||||
| const data = ref<any[]>([]) | ||||
| const showDetail = ref(false) | ||||
|  | ||||
| const onExporting = (e: any) => { | ||||
|   if (e.format === 'pdf') { | ||||
|     const doc = new jsPDF() | ||||
|  | ||||
|     exportToPdf({ | ||||
|       jsPDFDocument: doc, | ||||
|       component: e.component, | ||||
|       indent: 5 | ||||
|     }).then(() => { | ||||
|       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') | ||||
|       }) | ||||
|     }) | ||||
|  | ||||
|     e.cancel = true | ||||
|   } | ||||
| } | ||||
|  | ||||
| const GET_laporanCttKwhPeriksa = gql` | ||||
|   query laporanCttKwhPeriksa( | ||||
|     $dateFrom: Date! | ||||
|     $dateTo: Date! | ||||
|     $posko: String | ||||
|     $idUid: Int | ||||
|     $idUp3: Int | ||||
|   ) { | ||||
|     laporanCttKwhPeriksa( | ||||
|       dateFrom: $dateFrom | ||||
|       dateTo: $dateTo | ||||
|       posko: $posko | ||||
|       idUid: $idUid | ||||
|       idUp3: $idUp3 | ||||
|     ) { | ||||
|       dlpd | ||||
|       history_p2ti | ||||
|       nama_posko | ||||
|       rekomendasi_sistem_mendatangkan_petugas | ||||
|       total_wo | ||||
|       total_wo_cc123 | ||||
|       total_wo_comcen | ||||
|       total_wo_loket | ||||
|       total_wo_pln_mobile | ||||
|     } | ||||
|   } | ||||
| ` | ||||
| const filterData = (params: any) => { | ||||
|   const { posko, uid, up3 } = params | ||||
|   const dateValue = params.periode.split(' s/d ') | ||||
|   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 : '', | ||||
|     idUid: uid ? uid.id : 0, | ||||
|     idUp3: up3 ? up3.id : 0 | ||||
|   }) | ||||
|   onResult((queryResult) => { | ||||
|     if (queryResult.data != undefined) { | ||||
|       queryResult.data.daftarGangguanDialihkanKePoskoLain.forEach((item: any) => { | ||||
|         data.value = [ | ||||
|           ...data.value, | ||||
|           { | ||||
|             ...item | ||||
|           } | ||||
|         ] | ||||
|       }) | ||||
|     } | ||||
|     console.log(queryResult.data) | ||||
|     console.log(queryResult.loading) | ||||
|     console.log(queryResult.networkStatus) | ||||
|   }) | ||||
|   onError((error) => { | ||||
|     console.log(error) | ||||
|   }) | ||||
| } | ||||
| const { onResult, onError, loading, refetch } = useQuery(GET_laporanCttKwhPeriksa, { | ||||
|   dateFrom: new Date().toISOString().slice(0, 10), | ||||
|   dateTo: new Date().toISOString().slice(0, 10), | ||||
|   posko: '', | ||||
|   idUid: 0, | ||||
|   idUp3: 0 | ||||
| }) | ||||
|  | ||||
| const onSelectionChanged = ({ selectedRowsData }: any) => { | ||||
|   const data = selectedRowsData[0] | ||||
|   dataDetail.value = data | ||||
|   console.log(data) | ||||
| } | ||||
| const showData = () => { | ||||
|   showDetail.value = true | ||||
| } | ||||
| const filters = ref() | ||||
| </script> | ||||
		Reference in New Issue
	
	Block a user