Initial import
This commit is contained in:
451
one-ui/masterdata/one-md-menu/components/oneMdDoctorAddress.vue
Normal file
451
one-ui/masterdata/one-md-menu/components/oneMdDoctorAddress.vue
Normal file
@@ -0,0 +1,451 @@
|
||||
<template>
|
||||
<v-layout v-if="xact !== 'new'" column >
|
||||
<v-dialog v-model="dialogconfirmationdeleteaddr" persistent max-width="290">
|
||||
<v-card>
|
||||
<v-card-title
|
||||
dark
|
||||
class="headline error pt-2 pb-2"
|
||||
primary-title
|
||||
style="color:white"
|
||||
>
|
||||
<h4 dark>Konfirmasi</h4>
|
||||
</v-card-title>
|
||||
<v-card-text>
|
||||
{{msgconfirmationdeleteaddr}}
|
||||
</v-card-text>
|
||||
<v-card-actions>
|
||||
<v-spacer></v-spacer>
|
||||
<v-btn small v-if="!checkError('deleteutama')" color="error darken-1 text-sm-left" flat @click="doDeleteAddr()">Hapus</v-btn>
|
||||
<v-btn small color="primary darken-1 text-sm-right" flat @click="dialogconfirmationdeleteaddr = false">Batal</v-btn>
|
||||
</v-card-actions>
|
||||
</v-card>
|
||||
</v-dialog>
|
||||
<v-dialog v-model="dialogformaddress" persistent max-width="650">
|
||||
<v-card>
|
||||
<v-card-title>
|
||||
<span class="headline">Form Alamat Dokter</span>
|
||||
</v-card-title>
|
||||
<v-card-text class="pt-0 pb-0">
|
||||
<v-layout wrap>
|
||||
<v-flex xs8 pa-1>
|
||||
<v-text-field v-model="labeladdress" label="Label"></v-text-field>
|
||||
<p v-if="checkError('requiredlabel')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
<p v-if="checkError('readonlyutama')" class="error pl-2 pr-2" style="color:#fff">Biarkan jadi yang utama</p>
|
||||
</v-flex>
|
||||
|
||||
<v-flex xs4 pa-1>
|
||||
<v-select
|
||||
item-text="Nat_JpaName"
|
||||
return-object
|
||||
:items="xjpas"
|
||||
v-model="jpaaddress"
|
||||
hide-details
|
||||
label="JPA"
|
||||
></v-select>
|
||||
<p v-if="checkError('requiredjpa')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
</v-flex>
|
||||
|
||||
|
||||
<v-flex xs12>
|
||||
<v-layout row>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-autocomplete
|
||||
label="Kota"
|
||||
v-model="cityaddress"
|
||||
:items="xcities"
|
||||
:search-input.sync="search_city"
|
||||
auto-select-first
|
||||
hide-details
|
||||
no-filter
|
||||
item-text="M_CityName"
|
||||
return-object
|
||||
:loading="isLoading"
|
||||
no-data-text="Pilih Kota"
|
||||
>
|
||||
<template
|
||||
slot="item"
|
||||
slot-scope="{ item }"
|
||||
>
|
||||
<v-list-tile-content>
|
||||
<v-list-tile-title v-text="item.M_CityName"></v-list-tile-title>
|
||||
</v-list-tile-content>
|
||||
</template>
|
||||
</v-autocomplete>
|
||||
<p v-if="checkError('requiredcity')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong deh</p>
|
||||
</v-flex>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-select
|
||||
item-text="M_DistrictName"
|
||||
return-object
|
||||
:items="xdistricts"
|
||||
v-model="districtaddress"
|
||||
hide-details
|
||||
label="Kecamatan*"
|
||||
></v-select>
|
||||
<p v-if="checkError('requireddistrict')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
</v-flex>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-select
|
||||
item-text="M_KelurahanName"
|
||||
return-object
|
||||
:items="xkelurahans"
|
||||
v-model="kelurahanaddress"
|
||||
hide-details
|
||||
label="Kelurahan / Desa*"
|
||||
></v-select>
|
||||
<p v-if="checkError('requiredkelurahan')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong deh</p>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-flex>
|
||||
<v-flex xs12>
|
||||
<v-textarea
|
||||
box
|
||||
label="Alamat Lengkap"
|
||||
v-model="descriptionaddress"
|
||||
hide-details
|
||||
></v-textarea>
|
||||
<p v-if="checkError('requireddescription')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
</v-flex>
|
||||
|
||||
</v-layout>
|
||||
</v-card-text>
|
||||
<v-card-actions>
|
||||
<v-spacer></v-spacer>
|
||||
<v-btn color="blue darken-1" flat @click="dialogformaddress = false">Tutup</v-btn>
|
||||
<v-btn v-if="xactaddr === 'new'" color="blue darken-1" flat @click="saveNewAddress()">Simpan</v-btn>
|
||||
<v-btn v-if="xactaddr === 'edit'" color="blue darken-1" flat @click="saveEditAddress()">Simpan</v-btn>
|
||||
</v-card-actions>
|
||||
</v-card>
|
||||
</v-dialog>
|
||||
<v-card>
|
||||
<v-layout row>
|
||||
<v-flex xs12>
|
||||
<v-subheader red--text text--lighten-1> ALAMAT DOKTER
|
||||
<v-flex text-md-right>
|
||||
<v-btn @click="createNewAddress()" small color="info">Baru</v-btn>
|
||||
</v-flex>
|
||||
</v-subheader>
|
||||
<v-divider></v-divider>
|
||||
<v-layout row wrap>
|
||||
<v-flex xs12 pa-2>
|
||||
<v-data-table
|
||||
:headers="headers"
|
||||
:items="xaddresses"
|
||||
:loading="isLoading"
|
||||
hide-actions class="elevation-1">
|
||||
<template slot="items" slot-scope="props">
|
||||
<td class="text-xs-center pa-2">
|
||||
<v-icon color="error" @click="deleteAddress(props.item)">delete</v-icon>
|
||||
<v-icon class="ml-3" color="primary" @click="editAddress(props.item)">edit</v-icon>
|
||||
</td>
|
||||
<td class="text-xs-left pa-2">{{ props.item.M_DoctorAddressNote}}</td>
|
||||
<td class="text-xs-left pa-2">{{ props.item.M_DoctorAddressDescription}}</td>
|
||||
<td class="text-xs-left pa-2">{{ props.item.Nat_JpaName}}</td>
|
||||
</template>
|
||||
</v-data-table>
|
||||
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-card>
|
||||
</v-layout>
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
||||
|
||||
<script>
|
||||
module.exports = {
|
||||
data: () => ({
|
||||
search_city:'',
|
||||
oldlabel:'',
|
||||
headers: [
|
||||
{
|
||||
text: "AKSI",
|
||||
align: "center",
|
||||
sortable: false,
|
||||
value: "action",
|
||||
width: "10%",
|
||||
class: "pa-1 blue lighten-3 white--text"
|
||||
},
|
||||
{
|
||||
text: "LABEL",
|
||||
align: "left",
|
||||
sortable: false,
|
||||
value: "mr",
|
||||
width: "10%",
|
||||
class: "pa-1 blue lighten-3 white--text"
|
||||
},
|
||||
{
|
||||
text: "ALAMAT",
|
||||
align: "left",
|
||||
sortable: false,
|
||||
value: "lab",
|
||||
width: "40%",
|
||||
class: "pa-1 blue lighten-3 white--text"
|
||||
},
|
||||
{
|
||||
text: "JPA",
|
||||
align: "left",
|
||||
sortable: false,
|
||||
value: "lab",
|
||||
width: "20%",
|
||||
class: "pa-1 blue lighten-3 white--text"
|
||||
}
|
||||
]
|
||||
}),
|
||||
computed: {
|
||||
dialogconfirmationdeleteaddr:{
|
||||
get() {
|
||||
return this.$store.state.doctor.dialog_confirmation_delete_addr
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dialog_confirmation_delete_addr",val)
|
||||
}
|
||||
},
|
||||
msgconfirmationdeleteaddr(){
|
||||
return this.$store.state.doctor.msg_confirmation_delete_addr
|
||||
},
|
||||
xact() {
|
||||
return this.$store.state.doctor.act
|
||||
},
|
||||
xactaddr() {
|
||||
return this.$store.state.doctor.act_addr
|
||||
},
|
||||
dialogformaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.dialog_form_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dialog_form_address",val)
|
||||
}
|
||||
},
|
||||
isLoading() {
|
||||
return this.$store.state.doctor.search_status == 1
|
||||
},
|
||||
xaddresses(p) {
|
||||
return this.$store.state.doctor.addresses
|
||||
},
|
||||
xcities(){
|
||||
return this.$store.state.doctor.cities
|
||||
},
|
||||
labeladdress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.label_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_label_address",val)
|
||||
}
|
||||
},
|
||||
cityaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.city_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_city_address",val)
|
||||
this.$store.dispatch("doctor/getdistrict",this.$store.state.doctor.city_address)
|
||||
}
|
||||
},
|
||||
xdistricts(){
|
||||
return this.$store.state.doctor.districts
|
||||
},
|
||||
districtaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.district_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_district_address",val)
|
||||
this.$store.dispatch("doctor/getkelurahan",this.$store.state.doctor.district_address)
|
||||
}
|
||||
},
|
||||
xkelurahans(){
|
||||
return this.$store.state.doctor.kelurahans
|
||||
},
|
||||
kelurahanaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.kelurahan_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_kelurahan_address",val)
|
||||
}
|
||||
},
|
||||
xjpas(){
|
||||
return this.$store.state.doctor.jpas
|
||||
},
|
||||
jpaaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.jpa_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_jpa_address",val)
|
||||
}
|
||||
},
|
||||
descriptionaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.description_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_description_address",val)
|
||||
}
|
||||
},
|
||||
},
|
||||
methods : {
|
||||
createNewAddress(){
|
||||
this.$store.commit("doctor/update_act_addr",'new')
|
||||
this.search_city = ''
|
||||
this.labeladdress = ''
|
||||
this.$store.commit("doctor/update_cities",[])
|
||||
this.cityaddress = {}
|
||||
this.$store.commit("doctor/update_districts",[])
|
||||
this.districtaddress = {}
|
||||
this.$store.commit("doctor/update_kelurahans",[])
|
||||
this.kelurahanaddress = {}
|
||||
//this.$store.commit("doctor/update_jpas",[])
|
||||
this.jpaaddress = {}
|
||||
this.descriptionaddress = ''
|
||||
this.$store.commit("doctor/update_dialog_form_address",true)
|
||||
},
|
||||
thr_search_city: _.debounce( function () {
|
||||
this.$store.dispatch("doctor/searchcity",this.search_city)
|
||||
},2000),
|
||||
checkError(value){
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if(errors.includes(value)){
|
||||
return true
|
||||
}
|
||||
else{
|
||||
return false
|
||||
}
|
||||
},
|
||||
saveNewAddress(){
|
||||
this.$store.commit("doctor/update_errors",[])
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if(this.labeladdress === ''){
|
||||
errors.push("requiredlabel")
|
||||
}
|
||||
if(_.isEmpty(this.cityaddress)){
|
||||
errors.push("requiredcity")
|
||||
}
|
||||
if(_.isEmpty(this.districtaddress)){
|
||||
errors.push("requireddistrict")
|
||||
}
|
||||
if(_.isEmpty(this.kelurahanaddress)){
|
||||
errors.push("requiredkelurahan")
|
||||
}
|
||||
if(_.isEmpty(this.$store.state.doctor.jpa_address)){
|
||||
errors.push("requiredjpa")
|
||||
}
|
||||
if(_.isEmpty(this.descriptionaddress)){
|
||||
errors.push("requireddescription")
|
||||
}
|
||||
|
||||
if(errors.length === 0){
|
||||
var prm = {}
|
||||
prm.M_DoctorAddressM_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorName = this.$store.state.doctor.selected_doctor.M_DoctorName
|
||||
prm.M_DoctorAddressNote = this.labeladdress
|
||||
prm.M_DoctorAddressDescription = this.descriptionaddress
|
||||
prm.M_DoctorAddressM_KelurahanID = this.kelurahanaddress.M_KelurahanID
|
||||
prm.M_DoctorAddressNat_JpaID = this.$store.state.doctor.jpa_address.Nat_JpaID
|
||||
|
||||
this.$store.dispatch("doctor/savenewaddress",prm)
|
||||
}
|
||||
},
|
||||
editAddress(value){
|
||||
console.log("matahasa")
|
||||
this.$store.commit("doctor/update_act_addr",'edit')
|
||||
this.$store.commit("doctor/update_x_addr_id",value.M_DoctorAddressID)
|
||||
this.labeladdress = value.M_DoctorAddressNote
|
||||
this.oldlabel = value.M_DoctorAddressNote
|
||||
this.$store.commit("doctor/update_cities",[{M_CityID:value.M_CityID,M_CityName:value.M_CityName}])
|
||||
this.cityaddress = {M_CityID:value.M_CityID,M_CityName:value.M_CityName}
|
||||
this.$store.commit("doctor/update_districts",[{M_DistrictID:value.M_DistrictID,M_DistrictName:value.M_DistrictName}])
|
||||
this.districtaddress = {M_DistrictID:value.M_DistrictID,M_DistrictName:value.M_DistrictName}
|
||||
this.$store.commit("doctor/update_kelurahans",[{M_KelurahanID:value.M_DoctorAddressM_KelurahanID,M_KelurahanName:value.M_KelurahanName}])
|
||||
this.kelurahanaddress = {M_KelurahanID:value.M_DoctorAddressM_KelurahanID,M_KelurahanName:value.M_KelurahanName}
|
||||
|
||||
//this.$store.commit("doctor/update_jpas",[{Nat_JpaID:value.M_DoctorAddressNat_JpaID,Nat_JpaName:value.Nat_JpaName}])
|
||||
this.jpaaddress = {Nat_JpaID:value.M_DoctorAddressNat_JpaID,Nat_JpaName:value.Nat_JpaName}
|
||||
|
||||
this.descriptionaddress = value.M_DoctorAddressDescription
|
||||
this.$store.commit("doctor/update_dialog_form_address",true)
|
||||
},
|
||||
saveEditAddress(){
|
||||
this.$store.commit("doctor/update_errors",[])
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if(this.labeladdress === ''){
|
||||
errors.push("requiredlabel")
|
||||
}
|
||||
if(this.oldlabel.toLowerCase() === 'utama' && this.labeladdress.toLowerCase() !== 'utama'){
|
||||
errors.push("readonlyutama")
|
||||
}
|
||||
if(_.isEmpty(this.cityaddress)){
|
||||
errors.push("requiredcity")
|
||||
}
|
||||
if(_.isEmpty(this.districtaddress)){
|
||||
errors.push("requireddistrict")
|
||||
}
|
||||
if(_.isEmpty(this.kelurahanaddress)){
|
||||
errors.push("requiredkelurahan")
|
||||
}
|
||||
if(_.isEmpty(this.$store.state.doctor.jpa_address)){
|
||||
errors.push("requiredjpa")
|
||||
}
|
||||
if(_.isEmpty(this.descriptionaddress)){
|
||||
errors.push("requireddescription")
|
||||
}
|
||||
|
||||
if(errors.length === 0){
|
||||
var prm = {}
|
||||
prm.M_DoctorAddressID = this.$store.state.doctor.x_addr_id
|
||||
prm.M_DoctorAddressM_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorName = this.$store.state.doctor.selected_doctor.M_DoctorName
|
||||
prm.M_DoctorAddressNote = this.labeladdress
|
||||
prm.M_DoctorAddressDescription = this.descriptionaddress
|
||||
prm.M_DoctorAddressM_KelurahanID = this.kelurahanaddress.M_KelurahanID
|
||||
prm.M_DoctorAddressNat_JpaID = this.$store.state.doctor.jpa_address.Nat_JpaID
|
||||
this.$store.dispatch("doctor/saveeditaddress",prm)
|
||||
}
|
||||
},
|
||||
deleteAddress(value){
|
||||
this.$store.commit("doctor/update_act_addr",'delete')
|
||||
this.$store.commit("doctor/update_x_addr_id",value.M_DoctorAddressID)
|
||||
this.$store.commit("doctor/update_errors",[])
|
||||
this.oldlabel = value.M_DoctorAddressNote
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if(value.M_DoctorAddressNote.toLowerCase() === 'utama'){
|
||||
errors.push("deleteutama")
|
||||
}
|
||||
var msg = ''
|
||||
if(errors.includes("deleteutama")){
|
||||
msg = "Biarkan yang utama tetap ada"
|
||||
}
|
||||
else{
|
||||
msg = "Yakin, akan menghapus data alamat dokter "+value.M_DoctorAddressNote+" ?"
|
||||
}
|
||||
|
||||
this.$store.commit("doctor/update_msg_confirmation_delete_addr",msg)
|
||||
this.$store.commit("doctor/update_dialog_confirmation_delete_addr",true)
|
||||
},
|
||||
doDeleteAddr(){
|
||||
var prm = {}
|
||||
prm.M_DoctorAddressID = this.$store.state.doctor.x_addr_id
|
||||
prm.M_DoctorAddressM_DoctorOldCode = this.$store.state.doctor.selected_doctor.M_DoctorOldCode
|
||||
prm.M_DoctorName = this.$store.state.doctor.selected_doctor.M_DoctorName
|
||||
prm.M_DoctorAddressNote = this.oldlabel
|
||||
this.$store.dispatch("doctor/deleteaddress",prm)
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
search_city(val,old) {
|
||||
if (val == old ) return
|
||||
if (! val) return
|
||||
if (val.length < 1 ) return
|
||||
if (this.$store.state.doctor.update_autocomplete_status == 1 ) return
|
||||
this.thr_search_city()
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
397
one-ui/masterdata/one-md-menu/components/oneMdDoctorAddress0.vue
Normal file
397
one-ui/masterdata/one-md-menu/components/oneMdDoctorAddress0.vue
Normal file
@@ -0,0 +1,397 @@
|
||||
<template>
|
||||
<v-layout v-if="xact !== 'new'" column >
|
||||
<v-dialog v-model="dialogconfirmationdeleteaddr" persistent max-width="290">
|
||||
<v-card>
|
||||
<v-card-title
|
||||
dark
|
||||
class="headline error pt-2 pb-2"
|
||||
primary-title
|
||||
style="color:white"
|
||||
>
|
||||
<h4 dark>Konfirmasi</h4>
|
||||
</v-card-title>
|
||||
<v-card-text>
|
||||
{{msgconfirmationdeleteaddr}}
|
||||
</v-card-text>
|
||||
<v-card-actions>
|
||||
<v-spacer></v-spacer>
|
||||
<v-btn small v-if="!checkError('deleteutama')" color="error darken-1 text-sm-left" flat @click="doDeleteAddr()">Hapus</v-btn>
|
||||
<v-btn small color="primary darken-1 text-sm-right" flat @click="dialogconfirmationdeleteaddr = false">Batal</v-btn>
|
||||
</v-card-actions>
|
||||
</v-card>
|
||||
</v-dialog>
|
||||
<v-dialog v-model="dialogformaddress" persistent max-width="650">
|
||||
<v-card>
|
||||
<v-card-title>
|
||||
<span class="headline">Form Alamat Dokter</span>
|
||||
</v-card-title>
|
||||
<v-card-text class="pt-0 pb-0">
|
||||
<v-layout wrap>
|
||||
<v-flex xs12>
|
||||
<v-text-field v-model="labeladdress" label="Label"></v-text-field>
|
||||
<p v-if="checkError('requiredlabel')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
<p v-if="checkError('readonlyutama')" class="error pl-2 pr-2" style="color:#fff">Biarkan jadi yang utama</p>
|
||||
</v-flex>
|
||||
<v-flex xs12>
|
||||
<v-layout row>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-autocomplete
|
||||
label="Kota"
|
||||
v-model="cityaddress"
|
||||
:items="xcities"
|
||||
:search-input.sync="search_city"
|
||||
auto-select-first
|
||||
no-filter
|
||||
item-text="M_CityName"
|
||||
return-object
|
||||
:loading="isLoading"
|
||||
no-data-text="Pilih Kota"
|
||||
>
|
||||
<template
|
||||
slot="item"
|
||||
slot-scope="{ item }"
|
||||
>
|
||||
<v-list-tile-content>
|
||||
<v-list-tile-title v-text="item.M_CityName"></v-list-tile-title>
|
||||
</v-list-tile-content>
|
||||
</template>
|
||||
</v-autocomplete>
|
||||
<p v-if="checkError('requiredcity')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
</v-flex>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-select
|
||||
item-text="M_DistrictName"
|
||||
return-object
|
||||
:items="xdistricts"
|
||||
v-model="districtaddress"
|
||||
label="Kecamatan*"
|
||||
></v-select>
|
||||
<p v-if="checkError('requireddistrict')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
</v-flex>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-select
|
||||
item-text="M_KelurahanName"
|
||||
return-object
|
||||
:items="xkelurahans"
|
||||
v-model="kelurahanaddress"
|
||||
label="Kelurahan / Desa*"
|
||||
></v-select>
|
||||
<p v-if="checkError('requiredkelurahan')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-flex>
|
||||
<v-flex xs12>
|
||||
<v-textarea
|
||||
box
|
||||
label="Alamat Lengkap"
|
||||
v-model="descriptionaddress"
|
||||
></v-textarea>
|
||||
<p v-if="checkError('requireddescription')" class="error pl-2 pr-2" style="color:#fff">Jangan kosong dong</p>
|
||||
</v-flex>
|
||||
|
||||
</v-layout>
|
||||
</v-card-text>
|
||||
<v-card-actions>
|
||||
<v-spacer></v-spacer>
|
||||
<v-btn color="blue darken-1" flat @click="dialogformaddress = false">Tutup</v-btn>
|
||||
<v-btn v-if="xactaddr === 'new'" color="blue darken-1" flat @click="saveNewAddress()">Simpan</v-btn>
|
||||
<v-btn v-if="xactaddr === 'edit'" color="blue darken-1" flat @click="saveEditAddress()">Simpan</v-btn>
|
||||
</v-card-actions>
|
||||
</v-card>
|
||||
</v-dialog>
|
||||
<v-card>
|
||||
<v-layout row>
|
||||
<v-flex xs12>
|
||||
<v-subheader red--text text--lighten-1> ALAMAT DOKTER
|
||||
<v-flex text-md-right>
|
||||
<v-btn @click="createNewAddress()" small color="info">Baru</v-btn>
|
||||
</v-flex>
|
||||
</v-subheader>
|
||||
<v-divider></v-divider>
|
||||
<v-layout row wrap>
|
||||
<v-flex xs12 pa-2>
|
||||
<v-data-table
|
||||
:headers="headers"
|
||||
:items="xaddresses"
|
||||
:loading="isLoading"
|
||||
hide-actions class="elevation-1">
|
||||
<template slot="items" slot-scope="props">
|
||||
<td class="text-xs-center pa-2">
|
||||
<v-icon color="error" @click="deleteAddress(props.item)">delete</v-icon>
|
||||
<v-icon class="ml-3" color="primary" @click="editAddress(props.item)">edit</v-icon>
|
||||
</td>
|
||||
<td class="text-xs-left pa-2">{{ props.item.M_DoctorAddressNote}}</td>
|
||||
<td class="text-xs-left pa-2">{{ props.item.M_DoctorAddressDescription}}</td>
|
||||
</template>
|
||||
</v-data-table>
|
||||
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-card>
|
||||
</v-layout>
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
||||
|
||||
<script>
|
||||
module.exports = {
|
||||
data: () => ({
|
||||
search_city:'',
|
||||
oldlabel:'',
|
||||
headers: [
|
||||
{
|
||||
text: "AKSI",
|
||||
align: "center",
|
||||
sortable: false,
|
||||
value: "action",
|
||||
width: "10%",
|
||||
class: "pa-1 blue lighten-3 white--text"
|
||||
},
|
||||
{
|
||||
text: "LABEL",
|
||||
align: "left",
|
||||
sortable: false,
|
||||
value: "mr",
|
||||
width: "20%",
|
||||
class: "pa-1 blue lighten-3 white--text"
|
||||
},
|
||||
{
|
||||
text: "ALAMAT",
|
||||
align: "left",
|
||||
sortable: false,
|
||||
value: "lab",
|
||||
width: "40%",
|
||||
class: "pa-1 blue lighten-3 white--text"
|
||||
}
|
||||
]
|
||||
}),
|
||||
computed: {
|
||||
dialogconfirmationdeleteaddr:{
|
||||
get() {
|
||||
return this.$store.state.doctor.dialog_confirmation_delete_addr
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dialog_confirmation_delete_addr",val)
|
||||
}
|
||||
},
|
||||
msgconfirmationdeleteaddr(){
|
||||
return this.$store.state.doctor.msg_confirmation_delete_addr
|
||||
},
|
||||
xact() {
|
||||
return this.$store.state.doctor.act
|
||||
},
|
||||
xactaddr() {
|
||||
return this.$store.state.doctor.act_addr
|
||||
},
|
||||
dialogformaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.dialog_form_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dialog_form_address",val)
|
||||
}
|
||||
},
|
||||
isLoading() {
|
||||
return this.$store.state.doctor.search_status == 1
|
||||
},
|
||||
xaddresses(p) {
|
||||
return this.$store.state.doctor.addresses
|
||||
},
|
||||
xcities(){
|
||||
return this.$store.state.doctor.cities
|
||||
},
|
||||
labeladdress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.label_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_label_address",val)
|
||||
}
|
||||
},
|
||||
cityaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.city_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_city_address",val)
|
||||
this.$store.dispatch("doctor/getdistrict",this.$store.state.doctor.city_address)
|
||||
}
|
||||
},
|
||||
xdistricts(){
|
||||
return this.$store.state.doctor.districts
|
||||
},
|
||||
districtaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.district_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_district_address",val)
|
||||
this.$store.dispatch("doctor/getkelurahan",this.$store.state.doctor.district_address)
|
||||
}
|
||||
},
|
||||
xkelurahans(){
|
||||
return this.$store.state.doctor.kelurahans
|
||||
},
|
||||
kelurahanaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.kelurahan_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_kelurahan_address",val)
|
||||
}
|
||||
},
|
||||
descriptionaddress:{
|
||||
get() {
|
||||
return this.$store.state.doctor.description_address
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_description_address",val)
|
||||
}
|
||||
},
|
||||
},
|
||||
methods : {
|
||||
createNewAddress(){
|
||||
this.$store.commit("doctor/update_act_addr",'new')
|
||||
this.search_city = ''
|
||||
this.labeladdress = ''
|
||||
this.$store.commit("doctor/update_cities",[])
|
||||
this.cityaddress = {}
|
||||
this.$store.commit("doctor/update_districts",[])
|
||||
this.districtaddress = {}
|
||||
this.$store.commit("doctor/update_kelurahans",[])
|
||||
this.kelurahanaddress = {}
|
||||
this.descriptionaddress = ''
|
||||
this.$store.commit("doctor/update_dialog_form_address",true)
|
||||
},
|
||||
thr_search_city: _.debounce( function () {
|
||||
this.$store.dispatch("doctor/searchcity",this.search_city)
|
||||
},2000),
|
||||
checkError(value){
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if(errors.includes(value)){
|
||||
return true
|
||||
}
|
||||
else{
|
||||
return false
|
||||
}
|
||||
},
|
||||
saveNewAddress(){
|
||||
this.$store.commit("doctor/update_errors",[])
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if(this.labeladdress === ''){
|
||||
errors.push("requiredlabel")
|
||||
}
|
||||
if(_.isEmpty(this.cityaddress)){
|
||||
errors.push("requiredcity")
|
||||
}
|
||||
if(_.isEmpty(this.districtaddress)){
|
||||
errors.push("requireddistrict")
|
||||
}
|
||||
if(_.isEmpty(this.kelurahanaddress)){
|
||||
errors.push("requiredkelurahan")
|
||||
}
|
||||
if(_.isEmpty(this.descriptionaddress)){
|
||||
errors.push("requireddescription")
|
||||
}
|
||||
|
||||
if(errors.length === 0){
|
||||
var prm = {}
|
||||
prm.M_DoctorAddressM_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorName = this.$store.state.doctor.selected_doctor.M_DoctorName
|
||||
prm.M_DoctorAddressNote = this.labeladdress
|
||||
prm.M_DoctorAddressDescription = this.descriptionaddress
|
||||
prm.M_DoctorAddressM_KelurahanID = this.kelurahanaddress.M_KelurahanID
|
||||
this.$store.dispatch("doctor/savenewaddress",prm)
|
||||
}
|
||||
},
|
||||
editAddress(value){
|
||||
this.$store.commit("doctor/update_act_addr",'edit')
|
||||
this.$store.commit("doctor/update_x_addr_id",value.M_DoctorAddressID)
|
||||
this.labeladdress = value.M_DoctorAddressNote
|
||||
this.oldlabel = value.M_DoctorAddressNote
|
||||
this.$store.commit("doctor/update_cities",[{M_CityID:value.M_CityID,M_CityName:value.M_CityName}])
|
||||
this.cityaddress = {M_CityID:value.M_CityID,M_CityName:value.M_CityName}
|
||||
this.$store.commit("doctor/update_districts",[{M_DistrictID:value.M_DistrictID,M_DistrictName:value.M_DistrictName}])
|
||||
this.districtaddress = {M_DistrictID:value.M_DistrictID,M_DistrictName:value.M_DistrictName}
|
||||
this.$store.commit("doctor/update_kelurahans",[{M_KelurahanID:value.M_DoctorAddressM_KelurahanID,M_KelurahanName:value.M_KelurahanName}])
|
||||
this.kelurahanaddress = {M_KelurahanID:value.M_DoctorAddressM_KelurahanID,M_KelurahanName:value.M_KelurahanName}
|
||||
this.descriptionaddress = value.M_DoctorAddressDescription
|
||||
this.$store.commit("doctor/update_dialog_form_address",true)
|
||||
},
|
||||
saveEditAddress(){
|
||||
this.$store.commit("doctor/update_errors",[])
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if(this.labeladdress === ''){
|
||||
errors.push("requiredlabel")
|
||||
}
|
||||
if(this.oldlabel.toLowerCase() === 'utama' && this.labeladdress.toLowerCase() !== 'utama'){
|
||||
errors.push("readonlyutama")
|
||||
}
|
||||
if(_.isEmpty(this.cityaddress)){
|
||||
errors.push("requiredcity")
|
||||
}
|
||||
if(_.isEmpty(this.districtaddress)){
|
||||
errors.push("requireddistrict")
|
||||
}
|
||||
if(_.isEmpty(this.kelurahanaddress)){
|
||||
errors.push("requiredkelurahan")
|
||||
}
|
||||
if(_.isEmpty(this.descriptionaddress)){
|
||||
errors.push("requireddescription")
|
||||
}
|
||||
|
||||
if(errors.length === 0){
|
||||
var prm = {}
|
||||
prm.M_DoctorAddressID = this.$store.state.doctor.x_addr_id
|
||||
prm.M_DoctorAddressM_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorName = this.$store.state.doctor.selected_doctor.M_DoctorName
|
||||
prm.M_DoctorAddressNote = this.labeladdress
|
||||
prm.M_DoctorAddressDescription = this.descriptionaddress
|
||||
prm.M_DoctorAddressM_KelurahanID = this.kelurahanaddress.M_KelurahanID
|
||||
this.$store.dispatch("doctor/saveeditaddress",prm)
|
||||
}
|
||||
},
|
||||
deleteAddress(value){
|
||||
this.$store.commit("doctor/update_act_addr",'delete')
|
||||
this.$store.commit("doctor/update_x_addr_id",value.M_DoctorAddressID)
|
||||
this.$store.commit("doctor/update_errors",[])
|
||||
this.oldlabel = value.M_DoctorAddressNote
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if(value.M_DoctorAddressNote.toLowerCase() === 'utama'){
|
||||
errors.push("deleteutama")
|
||||
}
|
||||
var msg = ''
|
||||
if(errors.includes("deleteutama")){
|
||||
msg = "Biarkan yang utama tetap ada"
|
||||
}
|
||||
else{
|
||||
msg = "Yakin, akan menghapus data alamat dokter "+value.M_DoctorAddressNote+" ?"
|
||||
}
|
||||
|
||||
this.$store.commit("doctor/update_msg_confirmation_delete_addr",msg)
|
||||
this.$store.commit("doctor/update_dialog_confirmation_delete_addr",true)
|
||||
},
|
||||
doDeleteAddr(){
|
||||
var prm = {}
|
||||
prm.M_DoctorAddressID = this.$store.state.doctor.x_addr_id
|
||||
prm.M_DoctorAddressM_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorName = this.$store.state.doctor.selected_doctor.M_DoctorName
|
||||
prm.M_DoctorAddressNote = this.oldlabel
|
||||
this.$store.dispatch("doctor/deleteaddress",prm)
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
search_city(val,old) {
|
||||
if (val == old ) return
|
||||
if (! val) return
|
||||
if (val.length < 1 ) return
|
||||
if (this.$store.state.doctor.update_autocomplete_status == 1 ) return
|
||||
this.thr_search_city()
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
480
one-ui/masterdata/one-md-menu/components/oneMdDoctorDetail.vue
Normal file
480
one-ui/masterdata/one-md-menu/components/oneMdDoctorDetail.vue
Normal file
@@ -0,0 +1,480 @@
|
||||
<template>
|
||||
<v-layout>
|
||||
<v-flex xs12>
|
||||
<v-layout row wrap>
|
||||
<v-flex xs3>
|
||||
<v-card class="mb-2 mr-2" >
|
||||
<v-card-title
|
||||
dark
|
||||
class="headline info pt-2 pb-2"
|
||||
primary-title
|
||||
style="color:white"
|
||||
>
|
||||
<h5 dark>terere</h5>
|
||||
</v-card-title>
|
||||
<v-card-text>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
</v-card-text>
|
||||
</v-card>
|
||||
</v-flex>
|
||||
<v-flex xs3>
|
||||
<v-card class="mb-2 mr-2" >
|
||||
<v-card-title
|
||||
dark
|
||||
class="headline info pt-2 pb-2"
|
||||
primary-title
|
||||
style="color:white"
|
||||
>
|
||||
<h5 dark>terere</h5>
|
||||
</v-card-title>
|
||||
<v-card-text>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
</v-card-text>
|
||||
</v-card>
|
||||
</v-flex>
|
||||
<v-flex xs3>
|
||||
<v-card class="mb-2 mr-2" >
|
||||
<v-card-title
|
||||
dark
|
||||
class="headline info pt-2 pb-2"
|
||||
primary-title
|
||||
style="color:white"
|
||||
>
|
||||
<h5 dark>terere</h5>
|
||||
</v-card-title>
|
||||
<v-card-text>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
</v-card-text>
|
||||
</v-card>
|
||||
</v-flex>
|
||||
<v-flex xs3>
|
||||
<v-card class="mb-2 mr-2" >
|
||||
<v-card-title
|
||||
dark
|
||||
class="headline info pt-2 pb-2"
|
||||
primary-title
|
||||
style="color:white"
|
||||
>
|
||||
<h5 dark>terere</h5>
|
||||
</v-card-title>
|
||||
<v-card-text>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
</v-card-text>
|
||||
</v-card>
|
||||
</v-flex>
|
||||
<v-flex xs3>
|
||||
<v-card class="mb-2 mr-2" >
|
||||
<v-card-title
|
||||
dark
|
||||
class="headline info pt-2 pb-2"
|
||||
primary-title
|
||||
style="color:white"
|
||||
>
|
||||
<h5 dark>terere</h5>
|
||||
</v-card-title>
|
||||
<v-card-text>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
<v-btn small color="error"><v-icon left>close</v-icon>fsafsaf</v-btn>
|
||||
</v-card-text>
|
||||
</v-card>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
||||
|
||||
<script>
|
||||
module.exports = {
|
||||
data: () => ({
|
||||
search_staff: ''
|
||||
}),
|
||||
computed: {
|
||||
dialogconfirmationdelete: {
|
||||
get() {
|
||||
return this.$store.state.doctor.dialog_confirmation_delete
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dialog_confirmation_delete", val)
|
||||
}
|
||||
},
|
||||
isLoading() {
|
||||
return this.$store.state.doctor.search_status == 1
|
||||
},
|
||||
msgconfirmationdelete() {
|
||||
return this.$store.state.doctor.msg_confirmation_delete
|
||||
},
|
||||
xact() {
|
||||
return this.$store.state.doctor.act
|
||||
},
|
||||
detail() {
|
||||
return this.$store.state.doctor.selected_doctor
|
||||
},
|
||||
xpreffix: {
|
||||
get() {
|
||||
return this.$store.state.doctor.preffix
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_preffix", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xpreffix2: {
|
||||
get() {
|
||||
return this.$store.state.doctor.preffix2
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_preffix2", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xdoctorname: {
|
||||
get() {
|
||||
return this.$store.state.doctor.doctor_name
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_doctor_name", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xsuffix: {
|
||||
get() {
|
||||
return this.$store.state.doctor.suffix
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_suffix", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
|
||||
xsuffix2: {
|
||||
get() {
|
||||
return this.$store.state.doctor.suffix2
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_suffix2", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
|
||||
xsuffix3: {
|
||||
get() {
|
||||
return this.$store.state.doctor.suffix3
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_suffix3", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xsexes() {
|
||||
return this.$store.state.doctor.sexes
|
||||
},
|
||||
xsex: {
|
||||
get() {
|
||||
return this.$store.state.doctor.selected_sex
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_selected_sex", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xreligions() {
|
||||
return this.$store.state.doctor.religions
|
||||
},
|
||||
xreligion: {
|
||||
get() {
|
||||
return this.$store.state.doctor.selected_religion
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_selected_religion", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
|
||||
xstaffs() {
|
||||
return this.$store.state.doctor.staffs
|
||||
},
|
||||
xstaff: {
|
||||
get() {
|
||||
return this.$store.state.doctor.staff
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_staff", val)
|
||||
}
|
||||
},
|
||||
|
||||
xphone: {
|
||||
get() {
|
||||
return this.$store.state.doctor.phone
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_phone", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xhp: {
|
||||
get() {
|
||||
return this.$store.state.doctor.hp
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_hp", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xemail: {
|
||||
get() {
|
||||
return this.$store.state.doctor.email
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_email", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xnote: {
|
||||
get() {
|
||||
return this.$store.state.doctor.note
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_note", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xpj: {
|
||||
get() {
|
||||
return this.$store.state.doctor.pj
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_pj", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xpjmcu: {
|
||||
get() {
|
||||
return this.$store.state.doctor.pjmcu
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_pjmcu", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xdpj: {
|
||||
get() {
|
||||
return this.$store.state.doctor.dpj
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dpj", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xclinic: {
|
||||
get() {
|
||||
return this.$store.state.doctor.clinic
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_clinic", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xmarketingconfirm: {
|
||||
get() {
|
||||
return this.$store.state.doctor.marketing_confirm
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_marketing_confirm", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xdefault: {
|
||||
get() {
|
||||
return this.$store.state.doctor.is_default
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_is_default", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
isdefaultemail: {
|
||||
get() {
|
||||
return this.$store.state.doctor.is_default_email
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_is_default_email", val)
|
||||
}
|
||||
},
|
||||
xdob: {
|
||||
get() {
|
||||
return this.$store.state.doctor.dob
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dob", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
selected_specialist: {
|
||||
get() {
|
||||
return this.$store.state.doctor.selected_specialist
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_selected_specialist", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xspecialistes() {
|
||||
return this.$store.state.doctor.specialistes
|
||||
},
|
||||
},
|
||||
methods: {
|
||||
checkError(value) {
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if (errors.includes(value)) {
|
||||
return true
|
||||
} else {
|
||||
return false
|
||||
}
|
||||
},
|
||||
changeBtnFlagPJ(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xpj = newval
|
||||
},
|
||||
changeBtnFlagPJMCU(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xpjmcu = newval
|
||||
},
|
||||
changeBtnFlagDefaultEmail(value) {
|
||||
if (this.xemail !== '') {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.isdefaultemail = newval
|
||||
} else {
|
||||
var msg = "si mail main ayunan, email kosong jangan dibiarkan"
|
||||
this.$store.commit("doctor/update_msg_info", msg)
|
||||
this.$store.commit("doctor/update_open_dialog_info", true)
|
||||
}
|
||||
},
|
||||
changeBtnFlagDefaultPJ(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xdpj = newval
|
||||
},
|
||||
changeBtnFlagDefault(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xdefault = newval
|
||||
},
|
||||
changeBtnFlagClinic(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xclinic = newval
|
||||
},
|
||||
changeBtnFlagMarketing(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xmarketingconfirm = newval
|
||||
},
|
||||
saveData() {
|
||||
this.$store.commit("doctor/update_errors", [])
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if (this.xdoctorname === '') {
|
||||
errors.push("requirename")
|
||||
}
|
||||
if (_.isEmpty(this.xsex)) {
|
||||
errors.push("requiresex")
|
||||
}
|
||||
var xDate = moment(this.$store.state.doctor.M_DoctorDOB, 'DD-MM-YYYY', true)
|
||||
var isValidDate = xDate.isValid()
|
||||
|
||||
if (errors.length === 0) {
|
||||
var prm = {}
|
||||
prm.M_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorPrefix = this.xpreffix
|
||||
prm.M_DoctorPrefix2 = this.xpreffix2
|
||||
prm.M_DoctorName = this.xdoctorname
|
||||
prm.M_DoctorSufix = this.xsuffix
|
||||
prm.M_DoctorSufix2 = this.xsuffix2
|
||||
prm.M_DoctorSufix3 = this.xsuffix3
|
||||
prm.M_DoctorM_SexID = this.$store.state.doctor.selected_sex.M_SexID
|
||||
prm.M_DoctorM_ReligionID = this.$store.state.doctor.selected_religion.M_ReligionID
|
||||
prm.M_DoctorM_StaffID = this.xstaff.Nat_StaffID
|
||||
prm.M_DoctorM_StaffNIK = this.xstaff.Nat_StaffNIK
|
||||
prm.M_DoctorEmail = this.xemail
|
||||
prm.M_DoctorHP = this.xhp
|
||||
prm.M_DoctorNote = this.xnote
|
||||
prm.M_DoctorPhone = this.xphone
|
||||
prm.M_DoctorIsMarketingConfirm = this.xmarketingconfirm
|
||||
prm.M_DoctorEmailIsDefault = this.isdefaultemail
|
||||
prm.M_DoctorM_SpecialistID = this.selected_specialist.id
|
||||
prm.M_DoctorDOB = this.xdob
|
||||
this.$store.dispatch("doctor/save", prm)
|
||||
}
|
||||
},
|
||||
thr_search_staff: _.debounce(function () {
|
||||
this.$store.dispatch("doctor/searchstaff", this.search_staff)
|
||||
}, 2000),
|
||||
saveNewDoctor() {
|
||||
this.$store.commit("doctor/update_errors", [])
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if (this.xdoctorname === '') {
|
||||
errors.push("requirename")
|
||||
}
|
||||
if (_.isEmpty(this.xsex)) {
|
||||
errors.push("requiresex")
|
||||
}
|
||||
if (errors.length === 0) {
|
||||
var prm = {}
|
||||
prm.M_DoctorID = 0
|
||||
prm.M_DoctorPrefix = this.xpreffix
|
||||
prm.M_DoctorPrefi2 = this.xpreffi2
|
||||
prm.M_DoctorName = this.xdoctorname
|
||||
prm.M_DoctorSufix = this.xsuffix
|
||||
prm.M_DoctorSufix2 = this.xsuffix2
|
||||
prm.M_DoctorSufix3 = this.xsuffix3
|
||||
prm.M_DoctorM_SexID = this.$store.state.doctor.selected_sex.M_SexID
|
||||
prm.M_DoctorM_ReligionID = this.$store.state.doctor.selected_religion.M_ReligionID
|
||||
prm.M_DoctorM_StaffID = this.xstaff.Nat_StaffID
|
||||
prm.M_DoctorM_StaffNIK = this.xstaff.Nat_StaffNIK
|
||||
prm.M_DoctorEmail = this.xemail
|
||||
prm.M_DoctorHP = this.xhp
|
||||
prm.M_DoctorNote = this.xnote
|
||||
prm.M_DoctorPhone = this.xphone
|
||||
prm.M_DoctorIsMarketingConfirm = this.xmarketingconfirm
|
||||
prm.M_DoctorEmailIsDefault = this.isdefaultemail
|
||||
prm.M_DoctorM_SpecialistID = this.selected_specialist.id
|
||||
prm.M_DoctorDOB = this.xdob
|
||||
this.$store.dispatch("doctor/newdoctor", prm)
|
||||
}
|
||||
},
|
||||
deleteData() {
|
||||
let msg = "Yakin, akan menghapus data dokter " + this.xdoctorname + " ?"
|
||||
this.$store.commit("doctor/update_msg_confirmation_delete", msg)
|
||||
this.$store.commit("doctor/update_dialog_confirmation_delete", true)
|
||||
},
|
||||
doDeleteData() {
|
||||
var prm = {}
|
||||
prm.M_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorPrefix = this.xpreffix
|
||||
prm.M_DoctorPrefix2 = this.xpreffix2
|
||||
prm.M_DoctorName = this.xdoctorname
|
||||
prm.M_DoctorSufix = this.xsuffix
|
||||
prm.M_DoctorSufix2 = this.xsuffix2
|
||||
prm.M_DoctorSufix3 = this.xsuffix3
|
||||
this.$store.dispatch("doctor/delete", prm)
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
search_staff(val, old) {
|
||||
if (val == old) return
|
||||
if (!val) return
|
||||
if (val.length < 1) return
|
||||
if (this.$store.state.doctor.update_autocomplete_status == 1) return
|
||||
this.thr_search_staff()
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
511
one-ui/masterdata/one-md-menu/components/oneMdDoctorDetail0.vue
Normal file
511
one-ui/masterdata/one-md-menu/components/oneMdDoctorDetail0.vue
Normal file
@@ -0,0 +1,511 @@
|
||||
<template>
|
||||
<v-layout class="mb-2" column>
|
||||
<v-dialog v-model="dialogconfirmationdelete" persistent max-width="290">
|
||||
<v-card>
|
||||
<v-card-title dark class="headline error pt-2 pb-2" primary-title style="color:white">
|
||||
<h4 dark>Konfirmasi</h4>
|
||||
</v-card-title>
|
||||
<v-card-text>
|
||||
{{msgconfirmationdelete}}
|
||||
</v-card-text>
|
||||
<v-card-actions>
|
||||
<v-spacer></v-spacer>
|
||||
<v-btn small color="error darken-1 text-sm-left" flat @click="doDeleteData()">Hapus</v-btn>
|
||||
<v-btn small color="primary darken-1 text-sm-right" flat @click="dialogconfirmationdelete = false">Batal</v-btn>
|
||||
</v-card-actions>
|
||||
</v-card>
|
||||
</v-dialog>
|
||||
<v-card>
|
||||
<v-layout row>
|
||||
<v-flex xs12>
|
||||
<v-subheader red--text text--lighten-1> DETAIL DOKTER
|
||||
<v-flex text-md-right>
|
||||
<v-btn v-if="xact === 'new'" @click="saveNewDoctor()" small color="info">Simpan</v-btn>
|
||||
<v-btn v-if="xact === 'edit'" @click="deleteData()" small color="error">Hapus</v-btn>
|
||||
<v-btn v-if="xact === 'edit'" @click="saveData()" small color="primary">Simpan</v-btn>
|
||||
</v-flex>
|
||||
</v-subheader>
|
||||
<v-divider></v-divider>
|
||||
<v-layout row wrap>
|
||||
<v-flex xs12 pa-2>
|
||||
<v-layout row>
|
||||
<v-flex xs2 pa-1>
|
||||
<v-text-field v-model="xpreffix" label="Imbuhan Awal 1"></v-text-field>
|
||||
</v-flex>
|
||||
<v-flex xs2 pa-1>
|
||||
<v-text-field v-model="xpreffix2" label="Imbuhan Awal 2"></v-text-field>
|
||||
</v-flex>
|
||||
<v-flex xs8 pa-1>
|
||||
<v-text-field v-model="xdoctorname" label="Nama Dokter*"></v-text-field>
|
||||
<p v-if="checkError('requirename')" class="error pl-2 pr-2" style="color:#fff">Nama harus diisi dong</p>
|
||||
</v-flex>
|
||||
|
||||
</v-layout>
|
||||
|
||||
<v-layout row>
|
||||
|
||||
|
||||
<v-flex xs4 pa-1>
|
||||
<v-text-field v-model="xsuffix" label="Akhiran 1"></v-text-field>
|
||||
</v-flex>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-text-field v-model="xsuffix2" label="Akhiran 2"></v-text-field>
|
||||
</v-flex>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-text-field v-model="xsuffix3" label="Akhiran 3"></v-text-field>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
|
||||
<v-layout row>
|
||||
<v-flex xs6 pa-1>
|
||||
<v-select item-text="m_sexname" return-object :items="xsexes" v-model="xsex" label="Jenis Kelamin*"></v-select>
|
||||
<p v-if="checkError('requiresex')" class="error pl-2 pr-2" style="color:#fff">Jenis Kelamin harus diisi dong</p>
|
||||
</v-flex>
|
||||
<v-flex xs6 pa-1>
|
||||
<v-select item-text="M_ReligionName" return-object :items="xreligions" v-model="xreligion" label="Agama"></v-select>
|
||||
<p v-if="checkError('requirereligion')" class="error pl-2 pr-2" style="color:#fff">Agama harus diisi dong</p>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
<v-layout row>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-text-field v-model="xphone" label="Telepon"></v-text-field>
|
||||
</v-flex>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-text-field v-model="xhp" label="HP"></v-text-field>
|
||||
</v-flex>
|
||||
<v-flex xs4 pa-1>
|
||||
<v-text-field v-model="xemail" label="Email"></v-text-field>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
<v-layout row>
|
||||
<v-flex xs12 pa-1>
|
||||
<v-textarea v-model="xnote" label="Catatan"></v-textarea>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
<v-layout row>
|
||||
<v-flex xs6>
|
||||
<div>
|
||||
<v-btn @click="changeBtnFlagPJ(xpj)" v-if="xpj === 'N'" small color="error">
|
||||
<v-icon left>close</v-icon> Penanggung Jawab</v-btn>
|
||||
<v-btn @click="changeBtnFlagPJ(xpj)" v-if="xpj === 'Y'" small color="success">
|
||||
<v-icon left>check</v-icon> Penanggung Jawab</v-btn>
|
||||
</div>
|
||||
<div>
|
||||
<v-btn @click="changeBtnFlagDefaultPJ(xdpj)" v-if="xdpj === 'N'" small color="error">
|
||||
<v-icon left>close</v-icon> Default PJ</v-btn>
|
||||
<v-btn @click="changeBtnFlagDefaultPJ(xdpj)" v-if="xdpj === 'Y'" small color="success">
|
||||
<v-icon left>check</v-icon> Default PJ</v-btn>
|
||||
</div>
|
||||
<div>
|
||||
<v-btn @click="changeBtnFlagDefault(xdefault)" v-if="xdefault === 'N'" small color="error">
|
||||
<v-icon left>close</v-icon> Default Dokter</v-btn>
|
||||
<v-btn @click="changeBtnFlagDefault(xdefault)" v-if="xdefault === 'Y'" small color="success">
|
||||
<v-icon left>check</v-icon> Default Dokter</v-btn>
|
||||
</div>
|
||||
</v-flex>
|
||||
<v-flex xs6 class="text-sm-right align-right">
|
||||
<div>
|
||||
<v-btn @click="changeBtnFlagDefaultEmail(isdefaultemail)" v-if="xemail != '' && isdefaultemail === 'N'" small color="error">
|
||||
<v-icon left>close</v-icon> Otomatis pengiriman email </v-btn>
|
||||
<v-btn @click="changeBtnFlagDefaultEmail(isdefaultemail)" v-if="xemail != '' && isdefaultemail === 'Y'" small color="success">
|
||||
<v-icon left>check</v-icon> Otomatis pengiriman email</v-btn>
|
||||
</div>
|
||||
<div>
|
||||
<v-btn @click="changeBtnFlagClinic(xclinic)" v-if="xclinic === 'N'" small color="error">
|
||||
<v-icon left>close</v-icon> Dokter Klinik</v-btn>
|
||||
<v-btn @click="changeBtnFlagClinic(xclinic)" v-if="xclinic === 'Y'" small color="success">
|
||||
<v-icon left>check</v-icon> Dokter Klinik</v-btn>
|
||||
</div>
|
||||
<div>
|
||||
<v-btn @click="changeBtnFlagMarketing(xmarketingconfirm)" v-if="xmarketingconfirm === 'N'" small color="error">
|
||||
<v-icon left>close</v-icon> Belum dikonfirmasi Marketing</v-btn>
|
||||
<v-btn @click="changeBtnFlagMarketing(xmarketingconfirm)" v-if="xmarketingconfirm === 'Y'" small color="success">
|
||||
<v-icon left>check</v-icon> Sudah dikonfirmasi Marketing</v-btn>
|
||||
</div>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-flex>
|
||||
</v-flex>
|
||||
</v-card>
|
||||
</v-layout>
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
table,
|
||||
td,
|
||||
th {
|
||||
border: 1px solid #ddd;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
table {
|
||||
border-collapse: collapse;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
th,
|
||||
td {
|
||||
padding-top: 5px;
|
||||
padding-bottom: 5px;
|
||||
padding-left: 8px;
|
||||
padding-right: 5px;
|
||||
}
|
||||
|
||||
.mini-input .v-input {
|
||||
margin-top: 0px;
|
||||
}
|
||||
|
||||
.mini-input .v-input,
|
||||
.mini-input .v-input--selection-controls,
|
||||
.mini-input .v-input__slot {
|
||||
margin-top: 0px;
|
||||
margin-bottom: 0px;
|
||||
margin-left: 3px;
|
||||
}
|
||||
|
||||
.mini-input .v-messages {
|
||||
min-height: 0px;
|
||||
}
|
||||
|
||||
input.fhm-input {
|
||||
border: 1px solid black;
|
||||
border-radius: 2px;
|
||||
-webkit-box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1),
|
||||
0 0 4px rgba(0, 0, 0, 0.1);
|
||||
-moz-box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1),
|
||||
0 0 4px rgba(0, 0, 0, 0.1);
|
||||
box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1),
|
||||
0 0 4px rgba(0, 0, 0, 0.1);
|
||||
padding: 2px 4px;
|
||||
background: rgba(255, 255, 255, 0.5);
|
||||
margin: 0 0 1px 0;
|
||||
width: 30px;
|
||||
text-align: center;
|
||||
}
|
||||
</style>
|
||||
|
||||
<script>
|
||||
module.exports = {
|
||||
data: () => ({
|
||||
|
||||
}),
|
||||
computed: {
|
||||
dialogconfirmationdelete: {
|
||||
get() {
|
||||
return this.$store.state.doctor.dialog_confirmation_delete
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dialog_confirmation_delete", val)
|
||||
}
|
||||
},
|
||||
msgconfirmationdelete() {
|
||||
return this.$store.state.doctor.msg_confirmation_delete
|
||||
},
|
||||
xact() {
|
||||
return this.$store.state.doctor.act
|
||||
},
|
||||
detail() {
|
||||
return this.$store.state.doctor.selected_doctor
|
||||
},
|
||||
xpreffix: {
|
||||
get() {
|
||||
return this.$store.state.doctor.preffix
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_preffix", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xpreffix2: {
|
||||
get() {
|
||||
return this.$store.state.doctor.preffix2
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_preffix2", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xdoctorname: {
|
||||
get() {
|
||||
return this.$store.state.doctor.doctor_name
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_doctor_name", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xsuffix: {
|
||||
get() {
|
||||
return this.$store.state.doctor.suffix
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_suffix", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
|
||||
xsuffix2: {
|
||||
get() {
|
||||
return this.$store.state.doctor.suffix2
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_suffix2", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
|
||||
xsuffix3: {
|
||||
get() {
|
||||
return this.$store.state.doctor.suffix3
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_suffix3", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xsexes() {
|
||||
return this.$store.state.doctor.sexes
|
||||
},
|
||||
xsex: {
|
||||
get() {
|
||||
return this.$store.state.doctor.selected_sex
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_selected_sex", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xreligions() {
|
||||
return this.$store.state.doctor.religions
|
||||
},
|
||||
xreligion: {
|
||||
get() {
|
||||
return this.$store.state.doctor.selected_religion
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_selected_religion", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xphone: {
|
||||
get() {
|
||||
return this.$store.state.doctor.phone
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_phone", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xhp: {
|
||||
get() {
|
||||
return this.$store.state.doctor.hp
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_hp", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xemail: {
|
||||
get() {
|
||||
return this.$store.state.doctor.email
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_email", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xnote: {
|
||||
get() {
|
||||
return this.$store.state.doctor.note
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_note", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xpj: {
|
||||
get() {
|
||||
return this.$store.state.doctor.pj
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_pj", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xdpj: {
|
||||
get() {
|
||||
return this.$store.state.doctor.dpj
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dpj", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xclinic: {
|
||||
get() {
|
||||
return this.$store.state.doctor.clinic
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_clinic", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xmarketingconfirm: {
|
||||
get() {
|
||||
return this.$store.state.doctor.marketing_confirm
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_marketing_confirm", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
xdefault: {
|
||||
get() {
|
||||
return this.$store.state.doctor.is_default
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_is_default", val)
|
||||
this.$store.commit("doctor/update_no_save", 1)
|
||||
}
|
||||
},
|
||||
isdefaultemail: {
|
||||
get() {
|
||||
return this.$store.state.doctor.is_default_email
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_is_default_email", val)
|
||||
}
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
checkError(value) {
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if (errors.includes(value)) {
|
||||
return true
|
||||
} else {
|
||||
return false
|
||||
}
|
||||
},
|
||||
changeBtnFlagPJ(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xpj = newval
|
||||
},
|
||||
changeBtnFlagDefaultEmail(value) {
|
||||
if (this.xemail !== '') {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.isdefaultemail = newval
|
||||
} else {
|
||||
var msg = "si mail main ayunan, email kosong jangan dibiarkan"
|
||||
this.$store.commit("doctor/update_msg_info", msg)
|
||||
this.$store.commit("doctor/update_open_dialog_info", true)
|
||||
}
|
||||
},
|
||||
changeBtnFlagDefaultPJ(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xdpj = newval
|
||||
},
|
||||
changeBtnFlagDefault(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xdefault = newval
|
||||
},
|
||||
changeBtnFlagClinic(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xclinic = newval
|
||||
},
|
||||
changeBtnFlagMarketing(value) {
|
||||
var newval = (value === 'Y') ? 'N' : 'Y'
|
||||
this.xmarketingconfirm = newval
|
||||
},
|
||||
saveData() {
|
||||
this.$store.commit("doctor/update_errors", [])
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if (this.xdoctorname === '') {
|
||||
errors.push("requirename")
|
||||
}
|
||||
if (_.isEmpty(this.xsex)) {
|
||||
errors.push("requiresex")
|
||||
}
|
||||
if (_.isEmpty(this.xreligion)) {
|
||||
errors.push("requirereligion")
|
||||
}
|
||||
if (errors.length === 0) {
|
||||
var prm = {}
|
||||
prm.M_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorPrefix = this.xpreffix
|
||||
prm.M_DoctorPrefix2 = this.xpreffix2
|
||||
prm.M_DoctorName = this.xdoctorname
|
||||
prm.M_DoctorSufix = this.xsuffix
|
||||
prm.M_DoctorSufix2 = this.xsuffix2
|
||||
prm.M_DoctorSufix3 = this.xsuffix3
|
||||
prm.M_DoctorM_SexID = this.$store.state.doctor.selected_sex.M_SexID
|
||||
prm.M_DoctorM_ReligionID = this.$store.state.doctor.selected_religion.M_ReligionID
|
||||
prm.M_DoctorEmail = this.xemail
|
||||
prm.M_DoctorHP = this.xhp
|
||||
prm.M_DoctorNote = this.xnote
|
||||
prm.M_DoctorPhone = this.xphone
|
||||
prm.M_DoctorIsMarketingConfirm = this.xmarketingconfirm
|
||||
prm.M_DoctorIsPJ = this.xpj
|
||||
prm.M_DoctorIsDefaultPJ = this.xdpj
|
||||
prm.M_DoctorIsClinic = this.xclinic
|
||||
prm.M_DoctorIsDefault = this.xdefault
|
||||
prm.M_DoctorEmailIsDefault = this.isdefaultemail
|
||||
this.$store.dispatch("doctor/save", prm)
|
||||
}
|
||||
},
|
||||
saveNewDoctor() {
|
||||
this.$store.commit("doctor/update_errors", [])
|
||||
var errors = this.$store.state.doctor.errors
|
||||
if (this.xdoctorname === '') {
|
||||
errors.push("requirename")
|
||||
}
|
||||
if (_.isEmpty(this.xsex)) {
|
||||
errors.push("requiresex")
|
||||
}
|
||||
if (_.isEmpty(this.xreligion)) {
|
||||
errors.push("requirereligion")
|
||||
}
|
||||
if (errors.length === 0) {
|
||||
var prm = {}
|
||||
prm.M_DoctorID = 0
|
||||
prm.M_DoctorPrefix = this.xpreffix
|
||||
prm.M_DoctorPrefi2 = this.xpreffi2
|
||||
prm.M_DoctorName = this.xdoctorname
|
||||
prm.M_DoctorSufix = this.xsuffix
|
||||
prm.M_DoctorSufix2 = this.xsuffix2
|
||||
prm.M_DoctorSufix3 = this.xsuffix3
|
||||
prm.M_DoctorM_SexID = this.$store.state.doctor.selected_sex.M_SexID
|
||||
prm.M_DoctorM_ReligionID = this.$store.state.doctor.selected_religion.M_ReligionID
|
||||
prm.M_DoctorEmail = this.xemail
|
||||
prm.M_DoctorHP = this.xhp
|
||||
prm.M_DoctorNote = this.xnote
|
||||
prm.M_DoctorPhone = this.xphone
|
||||
prm.M_DoctorIsMarketingConfirm = this.xmarketingconfirm
|
||||
prm.M_DoctorIsPJ = this.xpj
|
||||
prm.M_DoctorIsDefaultPJ = this.xdpj
|
||||
prm.M_DoctorIsClinic = this.xclinic
|
||||
prm.M_DoctorIsDefault = this.xdefault
|
||||
prm.M_DoctorEmailIsDefault = this.isdefaultemail
|
||||
this.$store.dispatch("doctor/newdoctor", prm)
|
||||
}
|
||||
},
|
||||
deleteData() {
|
||||
let msg = "Yakin, akan menghapus data dokter " + this.xdoctorname + " ?"
|
||||
this.$store.commit("doctor/update_msg_confirmation_delete", msg)
|
||||
this.$store.commit("doctor/update_dialog_confirmation_delete", true)
|
||||
},
|
||||
doDeleteData() {
|
||||
var prm = {}
|
||||
prm.M_DoctorID = this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
prm.M_DoctorPrefix = this.xpreffix
|
||||
prm.M_DoctorPrefix2 = this.xpreffix2
|
||||
prm.M_DoctorName = this.xdoctorname
|
||||
prm.M_DoctorSufix = this.xsuffix
|
||||
prm.M_DoctorSufix2 = this.xsuffix2
|
||||
prm.M_DoctorSufix3 = this.xsuffix3
|
||||
this.$store.dispatch("doctor/delete", prm)
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
357
one-ui/masterdata/one-md-menu/components/oneMdDoctorList.vue
Normal file
357
one-ui/masterdata/one-md-menu/components/oneMdDoctorList.vue
Normal file
@@ -0,0 +1,357 @@
|
||||
<template>
|
||||
<v-layout class="fill-height" column>
|
||||
<v-dialog v-model="dialogsuccess" persistent max-width="290">
|
||||
<v-card>
|
||||
<v-card-title color="success" class="headline">Berhasil !</v-card-title>
|
||||
<v-card-text>
|
||||
{{msgsuccess}}
|
||||
</v-card-text>
|
||||
<v-card-actions>
|
||||
<v-spacer></v-spacer>
|
||||
<v-btn color="green darken-1" flat @click="closeDialogSuccess">OK</v-btn>
|
||||
</v-card-actions>
|
||||
</v-card>
|
||||
</v-dialog>
|
||||
<v-card class="mb-2 pa-2 searchbox">
|
||||
<v-layout>
|
||||
<v-text-field class="xs4 ma-1" label="Nama" @keyup.enter="searchDoctor" outline v-model="name" hide-details></v-text-field>
|
||||
<v-select item-text="Nat_StaffName" return-object :items="staffs" style="font-size:14px" class="xs4 mini-select ma-1" v-model="selected_filter_staff"
|
||||
outline hide-details label="marketing"></v-select>
|
||||
<v-select class="xs4 mini-select ma-1" :items="xstatuses" style="font-size:14px" item-text="label" return-object v-model="xselectedstatus"
|
||||
label="Status" outline hide-details></v-select>
|
||||
<!--<span @click="searchDoctor" class="icon-medium-fill-base xs1 white--text success iconsearch-search"></span>-->
|
||||
<span @click="setNewDoctor" class="icon-medium-fill-base xs1 white--text primary ml-1 icon-add"></span>
|
||||
</v-layout>
|
||||
</v-card>
|
||||
<v-card>
|
||||
<v-layout row>
|
||||
<v-flex xs12 pt-2 pb-2>
|
||||
<v-data-table :headers="headers" :items="doctors" :loading="isLoading" hide-actions class="elevation-1">
|
||||
<template slot="items" slot-scope="props">
|
||||
<td class="text-xs-left pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item)}" @click="selectMe(props.item)">{{ props.item.M_DoctorCode}}</td>
|
||||
<td class="text-xs-left pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item)}" @click="selectMe(props.item)">{{ props.item.doctor_fullname }}</td>
|
||||
<td class="text-xs-center pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item)}" @click="selectMe(props.item)">{{ props.item.M_DoctorPhone}}</td>
|
||||
<td class="text-xs-center pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item)}" @click="selectMe(props.item)">{{ props.item.M_DoctorHP}}</td>
|
||||
<td class="text-xs-left pa-2" v-bind:class="{'amber lighten-4':isSelected(props.item)}" @click="selectMe(props.item)">{{ props.item.status}}</td>
|
||||
</template>
|
||||
</v-data-table>
|
||||
<v-divider></v-divider>
|
||||
<v-pagination style="margin-top:10px;margin-bottom:10px" v-model="curr_page" :length="xtotal_page"></v-pagination>
|
||||
</v-flex>
|
||||
</v-layout>
|
||||
</v-card>
|
||||
<!--<one-dialog-info :status="opendialoginfo" :msg="msginfo" @close-dialog-info="closeDialogInfo()"></one-dialog-info>
|
||||
<one-dialog-alert :status="openalertconfirmation" :msg="msgalertconfirmation" @forget-dialog-alert="forgetAlertConfirmation()"
|
||||
@close-dialog-alert="closeAlertConfirmation()"></one-dialog-alert>-->
|
||||
</v-layout>
|
||||
</template>
|
||||
|
||||
<style scoped>
|
||||
.searchbox .v-input.v-text-field .v-input__slot {
|
||||
min-height: 60px;
|
||||
}
|
||||
|
||||
.searchbox .v-btn {
|
||||
min-height: 60px;
|
||||
}
|
||||
|
||||
table.v-table tbody td,
|
||||
table.v-table tbody th {
|
||||
height: 40px;
|
||||
}
|
||||
|
||||
table.v-table thead tr {
|
||||
height: 40px;
|
||||
}
|
||||
</style>
|
||||
|
||||
<script>
|
||||
module.exports = {
|
||||
components: {
|
||||
'one-dialog-info': httpVueLoader('../../common/oneDialogInfo.vue'),
|
||||
'one-dialog-alert': httpVueLoader('../../common/oneDialogAlert.vue')
|
||||
},
|
||||
mounted() {
|
||||
this.$store.dispatch("doctor/getsexreg", {
|
||||
name: this.name,
|
||||
status: this.xselectedstatus.value,
|
||||
staff: this.selected_filter_staff.Nat_StaffNIK,
|
||||
current_page: 1,
|
||||
lastid: -1
|
||||
})
|
||||
this.$store.dispatch("doctor/searchstaff", {
|
||||
name: this.search_staff
|
||||
})
|
||||
},
|
||||
methods: {
|
||||
isSelected(p) {
|
||||
return p.M_DoctorID == this.$store.state.doctor.selected_doctor.M_DoctorID
|
||||
},
|
||||
searchDoctor() {
|
||||
this.$store.dispatch("doctor/search", {
|
||||
name: this.name,
|
||||
status: this.xselectedstatus.value,
|
||||
staff: this.selected_filter_staff.Nat_StaffNIK,
|
||||
current_page: 1,
|
||||
lastid: -1
|
||||
})
|
||||
},
|
||||
selectMe(doc) {
|
||||
console.log(doc)
|
||||
console.log(this.$store.state.doctor.no_save)
|
||||
this.$store.commit("doctor/update_act", 'edit')
|
||||
this.$store.commit("doctor/update_selected_doctor", doc)
|
||||
this.$store.commit("doctor/update_preffix", doc.M_DoctorPrefix)
|
||||
this.$store.commit("doctor/update_doctor_name", doc.M_DoctorName)
|
||||
this.$store.commit("doctor/update_suffix", doc.M_DoctorSufix)
|
||||
this.$store.commit("doctor/update_selected_sex", {
|
||||
M_SexID: doc.M_DoctorM_SexID,
|
||||
m_sexname: doc.M_SexName
|
||||
})
|
||||
this.$store.commit("doctor/update_selected_staff", {
|
||||
Nat_StaffNIK: doc.Nat_StaffNIK,
|
||||
Nat_StaffName: doc.Nat_StaffName
|
||||
})
|
||||
this.$store.commit("doctor/update_staffs",[{Nat_StaffID:doc.Nat_StaffID,Nat_StaffNIK:doc.Nat_StaffNIK,Nat_StaffName:doc.Nat_StaffName}])
|
||||
this.$store.commit("doctor/update_staff", {
|
||||
Nat_StaffID:doc.Nat_StaffID,
|
||||
Nat_StaffNIK: doc.Nat_StaffNIK,
|
||||
Nat_StaffName: doc.Nat_StaffName
|
||||
})
|
||||
this.$store.commit("doctor/update_selected_religion", {
|
||||
M_ReligionID: doc.M_DoctorM_ReligionID,
|
||||
M_ReligionName: doc.M_ReligionName
|
||||
})
|
||||
this.$store.commit("doctor/update_dob",doc.M_DoctorDOB)
|
||||
this.$store.commit("doctor/update_selected_specialist",{
|
||||
id:doc.M_DoctorM_SpecialistID,
|
||||
name:doc.M_SpecialistName
|
||||
})
|
||||
this.$store.commit("doctor/update_phone", doc.M_DoctorPhone)
|
||||
this.$store.commit("doctor/update_email", doc.M_DoctorEmail)
|
||||
this.$store.commit("doctor/update_hp", doc.M_DoctorHP)
|
||||
this.$store.commit("doctor/update_note", doc.M_DoctorNote)
|
||||
this.$store.commit("doctor/update_pj", doc.M_DoctorIsPJ)
|
||||
this.$store.commit("doctor/update_pjmcu", doc.M_DoctorIsDefaultMcu)
|
||||
this.$store.commit("doctor/update_dpj", doc.M_DoctorIsDefaultPJ)
|
||||
this.$store.commit("doctor/update_clinic", doc.M_DoctorIsClinic)
|
||||
this.$store.commit("doctor/update_marketing_confirm", doc.M_DoctorIsMarketingConfirm)
|
||||
this.$store.commit("doctor/update_is_default", doc.M_DoctorIsDefault)
|
||||
this.$store.commit("doctor/update_is_default_email", doc.M_DoctorEmailIsDefault)
|
||||
|
||||
|
||||
this.$store.dispatch("doctor/getaddress", {
|
||||
id: doc.M_DoctorID
|
||||
})
|
||||
|
||||
|
||||
|
||||
|
||||
},
|
||||
closeAlertConfirmation() {
|
||||
this.$store.commit("doctor/update_open_alert_confirmation", false)
|
||||
},
|
||||
forgetAlertConfirmation() {
|
||||
this.$store.commit("doctor/update_no_save", 0)
|
||||
this.$store.commit("doctor/update_open_alert_confirmation", false)
|
||||
},
|
||||
updateAlert_success(val) {
|
||||
this.$store.commit("doctor/update_alert_success", val)
|
||||
},
|
||||
setNewDoctor() {
|
||||
this.$store.commit("doctor/update_selected_doctor", {})
|
||||
this.$store.commit("doctor/update_preffix", '')
|
||||
this.$store.commit("doctor/update_doctor_name", '')
|
||||
this.$store.commit("doctor/update_suffix", '')
|
||||
this.$store.commit("doctor/update_selected_sex", {})
|
||||
this.$store.commit("doctor/update_selected_religion", {})
|
||||
this.$store.commit("doctor/update_staff", {})
|
||||
this.$store.commit("doctor/update_phone", '')
|
||||
this.$store.commit("doctor/update_email", '')
|
||||
this.$store.commit("doctor/update_hp", '')
|
||||
this.$store.commit("doctor/update_note", '')
|
||||
this.$store.commit("doctor/update_pj", 'N')
|
||||
this.$store.commit("doctor/update_dpj", 'N')
|
||||
this.$store.commit("doctor/update_clinic", 'N')
|
||||
this.$store.commit("doctor/update_marketing_confirm", 'N')
|
||||
this.$store.commit("doctor/update_is_default", 'N')
|
||||
this.$store.commit("doctor/update_addresses", [])
|
||||
|
||||
this.$store.commit("doctor/update_act", 'new')
|
||||
},
|
||||
closeDialogSuccess() {
|
||||
let arrdoctor = this.$store.state.doctor.doctors
|
||||
var idx = _.findIndex(arrdoctor, item => item.M_DoctorID === this.$store.state.doctor.last_id)
|
||||
console.log(idx)
|
||||
this.$store.dispatch("doctor/search", {
|
||||
name: this.name,
|
||||
status: this.xselectedstatus.value,
|
||||
staff: this.selected_filter_staff.Nat_StaffNIK,
|
||||
current_page: this.curr_page,
|
||||
lastid: idx
|
||||
})
|
||||
this.$store.commit("doctor/update_dialog_success", false)
|
||||
}
|
||||
},
|
||||
computed: {
|
||||
selected_filter_staff: {
|
||||
get() {
|
||||
return this.$store.state.doctor.selected_filter_staff
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_selected_filter_staff", val)
|
||||
this.searchDoctor()
|
||||
}
|
||||
},
|
||||
staffs: {
|
||||
get() {
|
||||
return this.$store.state.doctor.fstaffs
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_fstaffs", val)
|
||||
}
|
||||
},
|
||||
dialogsuccess: {
|
||||
get() {
|
||||
return this.$store.state.doctor.dialog_success
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_dialog_success", val)
|
||||
}
|
||||
},
|
||||
msgsuccess() {
|
||||
return this.$store.state.doctor.msg_success
|
||||
},
|
||||
snackbar: {
|
||||
get() {
|
||||
return this.$store.state.doctor.alert_success
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_alert_success", val)
|
||||
}
|
||||
},
|
||||
isLoading() {
|
||||
return this.$store.state.doctor.search_status == 1
|
||||
},
|
||||
xstatuses() {
|
||||
return this.$store.state.doctor.statuses
|
||||
},
|
||||
xselectedstatus: {
|
||||
get() {
|
||||
return this.$store.state.doctor.selected_status
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_selected_status", val)
|
||||
this.searchDoctor()
|
||||
}
|
||||
},
|
||||
doctors() {
|
||||
return this.$store.state.doctor.doctors
|
||||
},
|
||||
openalertconfirmation: {
|
||||
get() {
|
||||
return this.$store.state.doctor.open_alert_confirmation
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_open_alert_confirmation", val)
|
||||
}
|
||||
},
|
||||
totaldoctor() {
|
||||
return this.$store.state.doctor.total_doctor
|
||||
},
|
||||
curr_page: {
|
||||
get() {
|
||||
return this.$store.state.doctor.current_page
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_current_page", val)
|
||||
this.$store.dispatch("doctor/search", {
|
||||
name: this.name,
|
||||
status: this.xselectedstatus.value,
|
||||
staff: this.selected_filter_staff.Nat_StaffNIK,
|
||||
current_page: val,
|
||||
lastid: -1
|
||||
})
|
||||
}
|
||||
},
|
||||
xtotal_page: {
|
||||
get() {
|
||||
return this.$store.state.doctor.total_doctor
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_total_doctor", val)
|
||||
}
|
||||
},
|
||||
opendialoginfo: {
|
||||
get() {
|
||||
return this.$store.state.doctor.open_dialog_info
|
||||
},
|
||||
set(val) {
|
||||
this.$store.commit("doctor/update_open_dialog_info", val)
|
||||
}
|
||||
},
|
||||
msginfo() {
|
||||
return this.$store.state.doctor.msg_info
|
||||
}
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
msgalertconfirmation: "Perubahan yang telah dilakukan belum disimpan dong !",
|
||||
items: [],
|
||||
name: '',
|
||||
page: 1,
|
||||
total_pages: 5,
|
||||
headers: [
|
||||
{
|
||||
text: "KODE",
|
||||
align: "left",
|
||||
sortable: false,
|
||||
value: "mr",
|
||||
width: "8%",
|
||||
class: "pa-2 blue lighten-3 white--text"
|
||||
},
|
||||
{
|
||||
text: "NAMA",
|
||||
align: "left",
|
||||
sortable: false,
|
||||
value: "mr",
|
||||
width: "25%",
|
||||
class: "pa-2 blue lighten-3 white--text"
|
||||
},
|
||||
{
|
||||
text: "PHONE",
|
||||
align: "center",
|
||||
sortable: false,
|
||||
value: "lab",
|
||||
width: "10%",
|
||||
class: "pa-2 blue lighten-3 white--text"
|
||||
},
|
||||
{
|
||||
text: "HP",
|
||||
align: "center",
|
||||
sortable: false,
|
||||
value: "name",
|
||||
width: "10%",
|
||||
class: "pa-2 blue lighten-3 white--text"
|
||||
},
|
||||
|
||||
{
|
||||
text: "STATUS",
|
||||
align: "left",
|
||||
sortable: false,
|
||||
value: "status",
|
||||
width: "15%",
|
||||
class: "pa-2 blue lighten-3 white--text"
|
||||
}
|
||||
],
|
||||
pagination: {
|
||||
descending: false,
|
||||
page: 1,
|
||||
rowsPerPage: 5,
|
||||
sortBy: 'M_DoctorName',
|
||||
totalItems: this.$store.state.doctor.total_doctor
|
||||
}
|
||||
};
|
||||
}
|
||||
}
|
||||
</script>
|
||||
Reference in New Issue
Block a user