md-lokasi
This commit is contained in:
114
md-lokasi/components/filter.vue
Normal file
114
md-lokasi/components/filter.vue
Normal 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>
|
||||||
439
md-lokasi/components/lokasi.vue
Normal file
439
md-lokasi/components/lokasi.vue
Normal 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>
|
||||||
88
md-lokasi/components/main.vue
Normal file
88
md-lokasi/components/main.vue
Normal 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
159
md-lokasi/index.html
Normal 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
57
md-lokasi/language.js
Normal 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
247
md-lokasi/modules/lokasi.js
Normal 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
|
||||||
Reference in New Issue
Block a user