md-lokasi

This commit is contained in:
Sas Andy
2024-11-07 11:45:31 +07:00
parent db335d02b3
commit 0f7bf12ef0
6 changed files with 1104 additions and 0 deletions

View File

@@ -0,0 +1,114 @@
<template>
<v-card class="rounded-lg">
<v-row class="pa-5">
<v-col cols="12">
<!-- Baris 1 -->
<v-row>
<!-- Input Search -->
<v-col cols="11" class="">
<v-text-field
v-model="search"
:label="$t('message.search.keyword')"
variant="outlined"
min-width="auto"
hide-details
>
</v-text-field>
</v-col>
<v-col cols="1" class="d-flex justify-space-between">
<v-btn
variant="flat"
width="50px"
min-width="50px"
size="x-large"
class="bg-primary rounded"
>
<v-icon size="large">mdi-magnify</v-icon>
</v-btn>
<v-btn
@click="openDialogadd()"
variant="flat"
width="50px"
min-width="50px"
size="x-large"
class="bg-secondary text-white rounded"
>
<v-icon size="large">mdi-plus</v-icon>
</v-btn>
</v-col>
</v-row>
</v-col>
</v-row>
</v-card>
</template>
<script type="module">
export default {
name: "FilterFo",
data() {
return {
menuDate: false,
};
},
computed: {
search: {
get() {
return this.$store.state.lokasi.search;
},
set(val) {
console.log(val);
this.$store.commit("lokasi/update_search", val);
},
},
dialogForm: {
get() {
return this.$store.state.lokasi.dialogForm;
},
set(val) {
console.log(val);
this.$store.commit("lokasi/update_dialogForm", val);
},
},
inpLocation: {
get() {
return this.$store.state.lokasi.inpLocation;
},
set(val) {
console.log(val);
this.$store.commit("lokasi/update_inpLocation", val);
},
},
inpPriority: {
get() {
return this.$store.state.lokasi.inpPriority;
},
set(val) {
console.log(val);
this.$store.commit("lokasi/update_inpPriority", val);
},
},
selectedStation: {
get() {
return this.$store.state.lokasi.selectedStation;
},
set(val) {
console.log(val);
this.$store.commit("lokasi/update_selectedStation", val);
},
},
},
methods: {
openDialogadd() {
this.action = "add";
this.dialogForm = true;
this.inpLocation = "";
this.inpPriority = "";
this.selectedStation = null;
},
},
};
</script>
<style scoped></style>

View File

@@ -0,0 +1,439 @@
<template>
<div>
<v-dialog persistent max-width="500" v-model="dialogDelete">
<v-card>
<v-toolbar
elevation="4"
:title="$t('message.deleteTitle')"
color="primary"
></v-toolbar>
<v-card-text>
{{ $t("message.deleteMsg") }}
{{ this.selectedLocation.locationName }} ?</v-card-text
>
<v-card-actions class="px-5">
<v-spacer></v-spacer>
<v-btn
color="error"
size="large"
:text="$t('message.form.close')"
@click="dialogDelete = false"
></v-btn>
<v-btn
size="large"
color="primary"
:text="$t('message.form.deleteBtn')"
@click="dialogDelete = false"
></v-btn>
</v-card-actions>
</v-card>
</v-dialog>
<v-dialog persistent max-width="500" v-model="dialogForm">
<v-card>
<v-toolbar
elevation="4"
:title="action === 'add'? $t('message.form.add'):$t('message.form.edit')"
color="primary"
></v-toolbar>
<v-card-text>
<v-text-field
v-model="inpLocation"
:label="$t('message.form.lokasi')"
variant="outlined"
></v-text-field>
<v-autocomplete
:label="$t('message.form.station')"
:items="stationList"
item-title="name"
return-object
v-model="selectedStation"
item-value="name"
variant="outlined"
></v-autocomplete>
<v-text-field
v-model="inpPriority"
type="number"
:label="$t('message.form.prioritas')"
variant="outlined"
></v-text-field>
</v-card-text>
<v-card-actions class="px-5">
<v-spacer></v-spacer>
<v-btn
color="error"
size="large"
:text="$t('message.form.close')"
@click="dialogForm = false"
></v-btn>
<v-btn
size="large"
color="primary"
:text="action === 'add'? $t('message.form.save'): $t('message.form.saveEdit')"
@click="saveData()"
></v-btn>
</v-card-actions>
</v-card>
</v-dialog>
<v-container class="bg-white rounded-lg" fluid>
<v-data-table-server
:items-per-page-options="itemsPerPageOption"
v-model:items-per-page="itemsPerPage"
:headers="headers"
:items="locationList"
height="63vh"
:items-length="totalItems"
:loading="loading"
:search="search"
@update:options="coba"
>
<template v-slot:item="{ item }">
<tr
@click="selectMe(item)"
v-bind:class="{'bg-secondary-lighten':isSelected(item)}"
>
<td>{{ item.locationName }}</td>
<td>{{ item.stationName }}</td>
<td>{{ item.priority }}</td>
<td class="text-center">
<v-btn
:disabled="loading"
variant="plain"
width="40px"
@click="openDialogEdit(item)"
min-width="40px"
color="primary"
>
<span
class="iconify secondary"
data-icon="fluent:edit-24-regular"
data-inline="false"
style="font-size: 24px;"
></span>
</v-btn>
<!-- <v-btn
color="error"
size="large"
:text="$t('message.form.close')"
@click="openDialogInfo()"
></v-btn> -->
<v-btn
@click="openDialogDelete(item)"
:disabled="loading"
variant="plain"
width="40px"
min-width="40px"
color="error"
>
<span
class="iconify error"
data-icon="fluent:delete-24-regular"
style="font-size: 24px;"
></span>
</v-btn>
</td>
</tr>
</template>
</v-data-table-server>
</v-container>
</div>
</template>
<style scoped>
.row-pointer >>> tbody tr :hover {
cursor: pointer;
}
</style>
<script type="module">
export default {
name: "ListPatient",
data() {
return {
cobaHtml: "coba",
itemsPerPageOption: [
{ value: 2, title: "2" },
{ value: 5, title: "5" },
{ value: 10, title: "10" },
{ value: 25, title: "25" },
{ value: 50, title: "50" },
],
headers: [
{
align: "start",
key: "locationName",
sortable: true,
width: "35%",
title: this.$t("message.tableListPatient.lokasi"),
class: "font-weight-bold",
},
{
align: "start",
key: "stationName",
sortable: true,
width: "35%",
title: this.$t("message.tableListPatient.station"),
class: "font-weight-bold",
},
{
align: "start",
key: "priority",
sortable: true,
width: "20%",
title: this.$t("message.tableListPatient.prioritas"),
class: "font-weight-bold",
},
{
align: "center",
key: "name",
sortable: false,
width: "10%",
title: this.$t("message.tableListPatient.aksi"),
class: "font-weight-bold",
},
],
};
},
mounted() {
// Iconify.scan();
this.$store.dispatch("lokasi/search");
},
computed: {
dialogInfo: {
get() {
return this.$store.state.lokasi.dialogInfo;
},
set(val) {
this.$store.commit("lokasi/update_dialogInfo", val);
},
},
snackbar: {
get() {
return this.$store.state.lokasi.snackbar;
},
set(val) {
this.$store.commit("lokasi/update_snackbar", val);
},
},
dialogDelete: {
get() {
return this.$store.state.lokasi.dialogDelete;
},
set(val) {
this.$store.commit("lokasi/update_dialogDelete", val);
},
},
action: {
get() {
return this.$store.state.lokasi.action;
},
set(val) {
this.$store.commit("lokasi/update_action", val);
},
},
stationList: {
get() {
return this.$store.state.lokasi.stationList;
},
set(val) {
this.$store.commit("lokasi/update_stationList", val);
},
},
selectedStation: {
get() {
return this.$store.state.lokasi.selectedStation;
},
set(val) {
this.$store.commit("lokasi/update_selectedStation", val);
},
},
dialogForm: {
get() {
return this.$store.state.lokasi.dialogForm;
},
set(val) {
this.$store.commit("lokasi/update_dialogForm", val);
},
},
sortBy: {
get() {
return this.$store.state.lokasi.sortBy;
},
set(val) {
this.$store.commit("lokasi/update_sortBy", val);
},
},
orderBy: {
get() {
return this.$store.state.lokasi.orderBy;
},
set(val) {
this.$store.commit("lokasi/update_orderBy", val);
},
},
locationListTmp: {
get() {
return this.$store.state.lokasi.locationListTmp;
},
set(val) {
this.$store.commit("lokasi/update_locationListTmp", val);
},
},
locationList: {
get() {
return this.$store.state.lokasi.locationList;
},
set(val) {
this.$store.commit("lokasi/update_locationList", val);
},
},
totalItems: {
get() {
return this.$store.state.lokasi.totalItems;
},
set(val) {
this.$store.commit("lokasi/update_totalItems", val);
},
},
loading: {
get() {
return this.$store.state.lokasi.loading;
},
set(val) {
this.$store.commit("lokasi/update_loading", val);
},
},
search: {
get() {
return this.$store.state.lokasi.search;
},
set(val) {
this.$store.commit("lokasi/update_search", val);
},
},
itemsPerPage: {
get() {
return this.$store.state.lokasi.itemsPerPage;
},
set(val) {
this.$store.commit("lokasi/update_itemsPerPage", val);
},
},
page: {
get() {
return this.$store.state.lokasi.page;
},
set(val) {
this.$store.commit("lokasi/update_page", val);
},
},
xpatients() {
return this.$store.state.sendtofo.patients;
},
selectedLocation: {
get() {
return this.$store.state.lokasi.selectedLocation;
},
set(val) {
this.$store.commit("lokasi/update_selectedLocation", val);
},
},
inpLocation: {
get() {
return this.$store.state.lokasi.inpLocation;
},
set(val) {
this.$store.commit("lokasi/update_inpLocation", val);
},
},
inpPriority: {
get() {
return this.$store.state.lokasi.inpPriority;
},
set(val) {
this.$store.commit("lokasi/update_inpPriority", val);
},
},
},
methods: {
saveData() {
this.dialogForm = false;
let snackbar = {
model: true,
type: "success",
message: "coba",
multiLine: true,
location: "top",
timeout: 1500,
};
this.snackbar = snackbar;
let df = {
title: "INFORMATION",
model: true,
color: "primary",
message: "information",
};
this.dialogInfo = df;
},
openDialogInfo() {
let df = {
title: "INFORMATION",
model: true,
color: "primary",
message: "information",
};
this.dialogInfo = df;
},
openDialogDelete(data) {
this.selectMe(data);
this.dialogDelete = true;
let snackbar = {
model: true,
type: "success",
message: "coba",
multiLine: true,
location: "top",
timeout: 1500,
};
this.snackbar = snackbar;
},
openDialogEdit(data) {
this.action = "edit";
this.dialogForm = true;
this.inpLocation = data.locationName;
this.inpPriority = data.priority;
this.selectedStation = {
id: 2,
name: data.stationName,
};
},
getIcon(iconName) {
return `<span class="iconify" data-icon="${iconName}" data-inline="false"></span>`;
},
selectMe(item) {
if (this.loading == true) return;
this.selectedLocation = item;
},
async coba({ page, itemsPerPage, sortBy, search }) {
this.page = page;
if (sortBy[0] != undefined) {
this.sortBy = sortBy[0]["key"];
this.orderBy = sortBy[0]["order"];
}
this.$store.dispatch("lokasi/search");
},
isSelected(p) {
return p.id == this.$store.state.lokasi.selectedLocation.id;
},
// selectMe(data) {
// this.$store.commit("sendtofo/setSelectedPatient", data);
// this.$store.commit("sendtofo/setSelectedDetail", data);
// },
},
wacth: {},
};
</script>

View File

@@ -0,0 +1,88 @@
<template class="bg-primary-lighten">
<v-app id="inspire">
<one-snackbar
v-model="snackbar.model"
:multi-line="snackbar.multiLine"
:message="snackbar.message"
:timeout="snackbar.timeout"
:location="snackbar.location"
:color="snackbar.type"
></one-snackbar>
<one-dialog
v-model="dialogInfo.model"
:title="dialogInfo.title"
:color="dialogInfo.color"
:message="dialogInfo.message"
:onClose="cobaFunction"
:width="'50vw'"
></one-dialog>
<one-navbar></one-navbar>
<v-main class="mt-3 mb-3 mx-2">
<div class="pa-4 bg-primary-lighten rounded-xl h-100">
<v-row class="">
<v-col cols="12"><filter-fo></filter-fo></v-col>
<v-col cols="12"> <location-component></location-component></v-col>
</v-row>
</div>
</v-main>
</v-app>
</template>
<script type="module">
import FilterFo from "./filter.vue";
import LocationComponent from "./lokasi.vue";
import NavbarComponent from "../../globalcomponent/one-navbar.vue";
import SnackbarComponent from "../../globalcomponent/one-snackbar.vue";
import dialogComponent from "../../globalcomponent/one-dialog.vue";
export default {
name: "component2",
components: {
"filter-fo": FilterFo,
"one-navbar": NavbarComponent,
"location-component": LocationComponent,
"one-snackbar": SnackbarComponent,
"one-dialog": dialogComponent,
},
mounted() {
if (typeof Iconify !== "undefined") {
Iconify.scan(); // Render ikon setelah komponen Vue dimuat
} else {
console.error("Iconify is not loaded.");
}
},
updated() {
if (typeof Iconify !== "undefined") {
Iconify.scan(); // Render ikon setelah komponen diperbarui
}
},
computed: {
dialogInfo: {
get() {
return this.$store.state.lokasi.dialogInfo;
},
set(val) {
this.$store.commit("lokasi/update_dialogInfo", val);
},
},
snackbar: {
get() {
return this.$store.state.lokasi.snackbar;
},
set(val) {
this.$store.commit("lokasi/update_snackbar", val);
},
},
},
methods: {
cobaFunction() {
console.log("coba function");
},
},
};
</script>
<style scoped></style>

159
md-lokasi/index.html Normal file
View File

@@ -0,0 +1,159 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>WESTONE</title>
<!-- <script src="https://code.iconify.design/iconify-icon/2.1.0/iconify-icon.min.js"></script> -->
<!-- Vuetify CSS -->
<link href="../css/vuetify.css" rel="stylesheet" />
<!-- Local Stylesheet for Fonts -->
<link rel="stylesheet" href="../css/styles.css" />
<link href="../css/materialdesignicon.css" rel="stylesheet" />
</head>
<body>
<div id="app"></div>
<!-- <script src="https://code.iconify.design/3/3.0.1/iconify.min.js"></script> -->
<!-- Moment -->
<script src="../libraries/moment.js"></script>
<script src="../libraries/iconify.min.js"></script>
<!-- Vue.js -->
<!-- DEV -->
<!-- <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script> -->
<script src="../libraries/vue.dev.js"></script>
<!-- PROD -->
<!-- <script src="../libraries/vue3.4.36.global.prod.js"></script> -->
<!-- Vuex -->
<script src="../libraries/vuex.js"></script>
<!-- Vuetify -->
<script src="../libraries/vuetify3.js"></script>
<!-- vue-i18n -->
<script src="../libraries/vue-i18n.global.js"></script>
<!-- Axios -->
<script src="../libraries/axios.js"></script>
<script src="../globalscript/theme.js"></script>
<script src="../globalscript/global.js"></script>
<!-- loader single file component -->
<script src="../libraries/vue3-sfc-loader.js"></script>
<script src="../globaltranslation/language.js"></script>
<script src="./language.js"></script>
<script type="module">
const { loadModule } = window["vue3-sfc-loader"];
import system from "../globalstore/globalstore.js";
import lokasi from "./modules/lokasi.js";
// if (one_token()) {
// let usr = JSON.parse(localStorage.getItem("user"));
// location.replace("/" + usr.M_UserGroupDashboard);
// }
const options = {
moduleCache: {
vue: Vue,
},
getFile(url) {
return fetch(url).then((response) =>
response.ok ? response.text() : Promise.reject(response)
);
},
compilerOptions: {
isCustomElement: (tag) => tag === "iconify-icon",
},
addStyle(textContent) {
const style = document.createElement("style");
style.textContent = textContent;
const ref = document.head.getElementsByTagName("style")[0] || null;
document.head.insertBefore(style, ref);
},
};
console.log(GlobalTranslation);
// Locale messages
let en = {
...CustomMessages.en.message,
...GlobalTranslation.en.message,
};
let id = {
...CustomMessages.id.message,
...GlobalTranslation.id.message,
};
const combinedMessages = {
en: {
message: en,
},
id: {
message: id,
},
};
// console.log(cobaaaa.en.message.search.keyword);
// console.log(CustomMessages);
// console.log(combinedMessages);
// console.log(combinedMessages);
// let messages = CustomMessages;
// Get the browser's preferred language
const browserLocale = navigator.language || navigator.languages[0];
// Initialize vue-i18n
const i18n = VueI18n.createI18n({
locale: browserLocale.startsWith("id") ? "id" : "en", // Set locale based on browser setting
fallbackLocale: "en", // Set fallback locale
messages: combinedMessages, // Set locale messages
});
window.i18n = i18n;
const store = Vuex.createStore({
modules: {
system: system,
lokasi: lokasi,
},
});
// Vue App
const app = Vue.createApp({
data() {
return {
visible: false,
bg_src: "",
loading: false, // Initialize loading state
};
},
template: `
<main-component></main-component>
`,
});
const vuetify = Vuetify.createVuetify({
theme: {
themes: CustomTheme,
},
});
app.use(store);
app.use(vuetify);
app.use(i18n);
const components = {
"main-component": "./components/main.vue",
};
Promise.all(
Object.entries(components).map(([name, path]) => {
return loadModule(path, options).then((component) => {
app.component(name, component);
});
})
)
.then(() => {
app.mount("#app");
})
.catch((error) => {
console.error("Error loading components:", error);
});
</script>
</body>
</html>

57
md-lokasi/language.js Normal file
View File

@@ -0,0 +1,57 @@
var CustomMessages = {
en: {
message: {
search: {
keyword: 'Location Name/Station Name'
},
toolbalTitle: "PASIEN",
tableListPatient: {
lokasi: "LOCATION NAME",
station: "STATION NAME",
prioritas: "PRIORITY",
aksi: "ACTION",
},
form: {
add: "NEW LOCATION",
edit: "CHANGE LOCATION",
lokasi: "LOCATION NAME",
station: "STATION NAME",
prioritas: "PRIORITY",
save: "SAVE",
saveEdit: "SAVE CHANGE",
close: "CLOSE",
deleteBtn: "Delete",
},
deleteTitle: "DELETE LOCATION",
deleteMsg: "Are you sure you want to delete this location",
},
},
id: {
message: {
search: {
keyword: 'Nama Lokasi/Nama Station'
},
toolbalTitle: "PASIEN",
tableListPatient: {
lokasi: "NAMA LOKASI",
station: "NAMA STATION",
prioritas: "PRIORITAS",
aksi: "AKSI",
},
form: {
add: "LOKASI BARU",
edit: "UBAH LOKASI",
lokasi: "NAMA LOKASI",
station: "NAMA STATION",
prioritas: "PRIORITAS",
save: "SIMPAN",
saveEdit: "SIMPAN PERUBAHAN",
close: "TUTUP",
deleteBtn: "Hapus",
},
deleteTitle: "HAPUS LOCATION",
deleteMsg: "Apakah Anda yakin ingin menghapus lokasi ",
},
},
};

247
md-lokasi/modules/lokasi.js Normal file
View File

@@ -0,0 +1,247 @@
// const URL = "/westone-api/v1/system/auth";
// const URL = "https://devcpone.aplikasi.web.id/westone-api/v1/system/auth/";
const store = {
namespaced: true,
state() {
return {
itemsPerPage: 5,
page: 1,
sortBy: 'id',
orderBy: 'asc',
search: '',
loading: false,
totalItems: 0,
action: 'add',
stationList: [
{
id: 1,
name: 'Station A'
},
{
id: 2,
name: 'Station B'
},
{
id: 3,
name: 'Station C'
},
],
selectedStation: null,
inpLocation: '',
inpPriority: '',
locationList: [],
locationListTmp: [
{
id: 1,
locationName: "R. 214-BMD",
stationName: "Sample Station BMD",
priority: "1",
},
{
id: 2,
locationName: "R. 333 Sample 12",
stationName: "Sample Station LAB",
priority: "2",
},
{
id: 3,
locationName: "R. 103 - Sampling 1",
stationName: "Sample Station LAB",
priority: "1",
},
{
id: 4,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
{
id: 5,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
{
id: 6,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
{
id: 7,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
{
id: 8,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
{
id: 9,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
{
id: 10,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
{
id: 11,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
{
id: 12,
locationName: "R. 103 Sampling 2",
stationName: "Sample Station LAB",
priority: "3",
},
],
selectedLocation: {},
dialogForm: false,
dialogDelete: false,
snackbar: {
model: false,
type: "success",
message: "coba",
"multiLine": false,
"location": "top",
timeout: 1500
},
dialogInfo: {
title: 'INFORMATION',
model: false,
color: 'primary',
message: "information"
},
};
},
mutations: {
update_dialogInfo(state, data) {
state.dialogInfo = data
},
update_snackbar(state, data) {
state.snackbar = data
},
update_dialogDelete(state, data) {
state.dialogDelete = data
},
update_action(state, data) {
state.action = data
},
update_inpLocation(state, data) {
state.inpLocation = data
},
update_inpPriority(state, data) {
state.inpPriority = data
},
update_stationList(state, data) {
state.stationList = data
},
update_selectedStation(state, data) {
state.selectedStation = data
},
update_dialogForm(state, data) {
state.dialogForm = data
},
update_dialogForm(state, data) {
state.dialogForm = data
},
update_sortBy(state, data) {
state.sortBy = data
},
update_page(state, data) {
state.page = data
},
update_orderBy(state, data) {
state.orderBy = data
},
update_locationListTmp(state, data) {
state.locationListTmp = data
},
update_totalItems(state, data) {
state.totalItems = data
},
update_loading(state, data) {
state.loading = data
},
update_search(state, data) {
state.search = data
},
update_itemsPerPage(state, data) {
state.itemsPerPage = data
},
update_locationList(state, data) {
state.locationList = data
},
update_selectedLocation(state, data) {
state.selectedLocation = data
},
},
actions: {
async search(context) {
context.commit('update_loading', true)
try {
let result = context.state.locationListTmp;
let sortBy = context.state.sortBy
let orderBy = context.state.orderBy
let search = context.state.search
let page = context.state.page
let itemsPerPage = context.state.itemsPerPage
context.commit('update_totalItems', result.length)
// Pencarian
result = result.filter(item =>
item.locationName.toLowerCase().includes(search.toLowerCase()) ||
item.stationName.toLowerCase().includes(search.toLowerCase())
);
// Sorting
result = result.slice().sort((a, b) => {
if (a[sortBy] < b[sortBy]) return orderBy === 'asc' ? -1 : 1;
if (a[sortBy] > b[sortBy]) return orderBy === 'asc' ? 1 : -1;
return 0;
});
// Pagination
const startIndex = (page - 1) * itemsPerPage;
result = result.slice(startIndex, startIndex + itemsPerPage);
console.log(result)
// this.locationList = result;
context.commit('update_locationList', result)
// return result;
} catch (error) {
console.log(error);
}
setTimeout(() => {
// let snackbar = {
// model: false,
// type: "success",
// message: "ini-coba",
// "multi-line": false,
// "location": "top",
// timeout: 1500
// }
// context.commit('update_snackbar', snackbar)
context.commit('update_loading', false)
}, 100);
}
}
};
export default store