Initial import

This commit is contained in:
sas.fajri
2026-05-25 20:01:37 +07:00
commit 710d7c1b97
10371 changed files with 2381698 additions and 0 deletions

View 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>

View 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>

View 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>

View 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>

View 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>