I want to display each user information in the modal in the table.

Asked 2 years ago, Updated 2 years ago, 99 views

I want to get user information by pressing the modal button on each line in the table

I am currently using Vue.FireStore to create a virtual coin throwing app.
Among them, I would like to add a modal function and display the name and balance of each user when I open the screen.

Currently, when you open a modal, all user information that is not logged in is displayed in the same modal.
As I am a beginner, it may be a basic question, but I would appreciate it if you could tell me.

Enter a description of the image here

Source Codes Affected

Home.vue

<template>
  <div class="home">
    <img alt="Vue logo" src="../assets/logo.png"/>
    <button@click="signOut" class="signout">Logout</button>
    <p class="name">{{userName}} Welcome!</p>
    <p class="wallet"> Balance: {{$store.getters.myWallet}}</p>
    <h1>User List</h1>
    <table>
      <thead>
        <tr>
          <th>User</th>
        </tr>
      </thead>
      <tr v-for="(user,index) in userData" v-bind:key="index">
        <td>{{user.name}}</td>
        <td><button class="button2" @click="openModal(index)">View Wallet</button></td>
        <td><button class="button2" @click="openModal2(index)">send</button></td>
      </tr>
    </table>
    <div>
        <transition>
          <Modal
           :val="usersIndex"
            v-show="showContent"
            @click="closeModal"
            @open="showContent=true"
            @close="showContent=false"
          ></Modal>
        </transition>
      </div>
    <div>
        <transition>
          <Modal 2
           :val="usersIndex"
            v-show="showContent2"
            @click="closeModal2"
            @open="showContent2=true"
            @close="showContent2=false"
          >/Modal 2>
        </transition>
      </div>
  </div>
</template>
<script>
import Modal from '../Modal.vue';
importModal2from'../Modal2.vue';
import firebase from "firebase";
export default {
  name: 'Home',
  components: {
    Modal,
    Modal2,
  },
  data(){
    US>return{
      userName: '' ,
      showContent: false,
      showContent2: false,
      usersIndex:',
      userData: [ ],
    };
  },
  methods: {
    openModal(index){
      This.showContent=true
      this.usersIndex=index
      const usersIndex=this.usersIndex
      This.$store.dispatch('modalSet', usersIndex)
    },
    closeModal(){
      This.showContent=false
    },
    openModal2(index){
      This.showContent2 = true
      this.usersIndex=index
      const usersIndex=this.usersIndex
      This.$store.dispatch('modalSet', usersIndex)
    },
    closeModal2(){
      This.showContent2=false
    },

    signOut(){
      firebase
        .auth()
        .signOut()
        .then()=>{
          This.$router.push("/signin");
        });
    },
  },
  computed: {
    name(){
      return this.$store.getters.name;
    },
    myWallet(){
      return this.$store.getters.myWallet;
    },
  },

  mounted() {
    firebase.auth().onAuthStateChanged(user)=>{
      This.userName=user.displayName;
    });

    firebase.auth().onAuthStateChanged(user)=>{
      if(user){
        console.log("true");
      } else{
        location.href="/signin";
      }

      const currentUser=firebase.auth().currentUser;
      this.uid = currentUser.uid;
      firebase
      .firestore()
      .collection("userData")
      .where (firebase.firestore.fieldPath. documentId(), "!=", currentUser.uid)
      .get()
      .then(querySnapshot)=>{
        querySnapshot.forEach(doc)=>{
          let data = {
            name —doc.data().name,
            myWallet: doc.data().myWallet,
          };
          This.userData.push(data);
        });
      });


    });
  },
};
</script>

Modal.vue

<template>
  <div class="overlay" v-show="showContent">
    <div class="main-content">
      <div v-for="(user,index) in userData" v-bind:key="index">
      <p>{{user.name}} balance </p>
      <p>{{user.myWallet}}</p>
      </div>
      <divid="button-content">
        <p>
          <button@click="closeModal" class="modal-button">close</button>
        </p>
      </div>
    </div>
  </div>
</template>



<script>
import firebase from "firebase";
export default {
  data(){
    US>return{
      showContent: false,
      userData: [ ],
    };
  },
  methods: {
    openModal(){
      this.$emit("open", this.showContent);
    },
    closeModal(){
      this.$emit("close", this.showContent);
    },
      returnUserData(id){
      const userData=this.userData.find(user)=>user.uid===id);
      return userData;
    },
  },

  mounted() {
    
    
    firebase.auth().onAuthStateChanged()=>{
      const currentUser=firebase.auth().currentUser;
      this.uid = currentUser.uid;
      firebase
      .firestore()
      .collection("userData")
      .where (firebase.firestore.fieldPath. documentId(), "!=", currentUser.uid)
      .get()
      .then(querySnapshot)=>{
        querySnapshot.forEach(doc)=>{
          let data = {
            name —doc.data().name,
            myWallet: doc.data().myWallet,
          };
          This.userData.push(data);
        });
      });
  
      
    });
  },
};
</script>

index.js

import Vue from 'vue'
import Vuex from 'vuex'
import firebase from 'firebase'
import router from '@/router'


Vue.use (Vuex)

export default newVuex.Store({
  state: {
    user: {
      name: '' ,
      email:',
      password:',
      myWallet:',
    },
    users —[ ],
    modalDatas: [ ],

  },
  getters: {
    email(state){
      return state.user.email;
    },
    password(state){
      return state.user.password;
    },
    name(state){
      return state.user.name;
    },
    myWallet(state){
      return state.user.myWallet;
    },
    users(state){
      return state.users
    },
    modalDatas(state){
      return state.modalDatas
    },
  },
  mutations: {
    setUser(state, payload){
      state.user.email=payload.email
      state.user.password=payload.password
      state.user.name = payload.name
      state.user.myWallet=payload.myWallet

    },
    setUserData(state,doc){
      state.user.name=doc.data().name
      state.user.myWallet=doc.data().myWallet
    },
    setUsersData(state, users){
      state.users=users
    },
    setModalDatas(state,modalDatas){
      state.modalDatas=modalDatas
    },
  },
  actions: {

    signUp(context, payload){
      firebase.auth().createUserWithEmailAndPassword(payload.email,payload.password)
        .then()=>{
          const user=firebase.auth().currentUser
          user.updateProfile({
            displayName: payload.name,
          },
          )
            .then()=>{
              const db = firebase.firestore();
              db.collection("userData").doc(user.uid).set({
                uid: user.uid,
                email:payload.email,
                password —payload.password,
                name: payload.name,
                myWallet:payload.myWallet,
              })
            })
            .then()=>{
              context.commit ('setUser', payload)
            })
            .then()=>{
              router.push ('/home')
            })
        })
        .catch(function(error){
          alert('Error.message+');
        });
    },
    signIn(context, payload){
      firebase.auth().signInWithEmailAndPassword(payload.email,payload.password)
        .then()=>{
          const user=firebase.auth().currentUser
          const docRef=firebase.firestore().collection("userData").doc(user.uid);
          docRef.get()
            .then(doc)=>{
              if(doc.exists){
                context.commit('setUserData',doc)
              } else{
                console.log();
              }
            })
            .then()=>{
              router.push ('/home')
            })
            .catch(function(error){
              alert('Your password or email address is different ('+error.message+')');
            })
        })
    },
    modalSet(context, usersIndex){
      const modalData=[];
      const user=firebase.auth().currentUser
      const db = firebase.firestore();
      db.collection("userData")
          .where (firebase.firestore.fieldPath.documentId(), "!=", user.uid)
          .get()
          .then(querySnapshot)=>{
              querySnapshot.forEach(doc)=>{
                  const modalData={
                      uid —usersIndex,
                      name —doc.data().name,
                      myWallet: doc.data().myWallet
                  }
                  modalData.push (modalData)
                  context.commit('setModalDatas',modalDatas')
                  console.log (modalDatas)
              });
              });
  },
},
  modules: {
  }
})

vue.js firebase vuex

2022-09-30 16:59

1 Answers

.where(firebase.firestore.FieldPath. documentId(), "!=", user.uid)

The operator in the above part is !=, so I think they are acquiring users other than the ones currently logged in.
If the operator is set to == as shown below, I think only the information of the currently logged-in user can be obtained. What do you think?

.where(firebase.firestore.FieldPath. documentId(), "==", user.uid)


2022-09-30 16:59

If you have any answers or tips


© 2024 OneMinuteCode. All rights reserved.