vue移动端提交用户留言信息

2018-09-09  本文已影响0人  冰淇wbq
屏幕快照 2018-09-09 09.53.38.png
<template>
  <div class="bgm page" style="overflow-x: hidden" v-use-lazy>
    <!--病友说-->
    <div class="bgw"><a href="#/patient/details/1" class="db pr cf" style="padding: 3% 3% 1%">
      <div class="patient-flex"><i class="l m patient-pic" :style="getBackground(askData.avatar)"></i>
        <div class="patient-name-flex">
          <div class="expert-list-tit doctor-name">
            {{askData.nickname}}
          </div>
          <div class="c3">{{Date.format("yyyy-MM-dd hh:mm", askData.create_time * 1000)}}</div>
        </div>
      </div>
      <h3 class="cl patient-example-bar-tit"><span class="ask-icon">问</span>
        {{askData.title}}
      </h3>
      <!--<div class="cl">-->
        <!--<div>-->
          <!--<div class="contract-item"><img src=""></div>-->
        <!--</div>-->
      <!--</div>-->
      <div class="live-interact-imgs" @click="viewImageHandle">
        <template>
          <img v-for="(img,index) in (askData.pic).split(',')" :key="index" :src="img" alt="" class="interact-img" style="width: 100px;height: 100px;" v-if="askData.pic.length!==0"/>
        </template>
      </div>
      <!--评论-->
      <div class="cl c3 patient-bar-foot">
      <span class="comment-one-pic" v-if="commentData==1">
        {{commentData}}
      </span>
        <span class="comment-two-pic" v-else-if="commentData>1">
        {{commentData}}
      </span>
        <div class="r">
          <div @click.prevent="addPraiseCount(askData.id);cancelPraiseCount(askData.id)">
            <svg class="patient-list-icon" v-if="isActive">
              <use xlink:href="#on-praise"/>
            </svg>
            <svg class="patient-list-icon" v-else>
              <use xlink:href="#praise"/>
            </svg>
            {{isInit ? praiseCount : askData.praise}}
          </div>
        </div>
      </div>
    </a>
    </div>
    <!--回答列表-->
    <div class="bgw" v-if="answerData.length" style="margin-top: 10px">
      <div v-for="(item,index) in answerData" style="border-bottom: 1px dotted #dddddd" class="con2">
        <div class="patient-flex"><i class="l m patient-pic" :style="getBackground(item.avatar)"></i>
          <div class="patient-name-flex">
            <div class="expert-list-tit doctor-name">
              {{item.nickname}}
            </div>
            <div class="c3">{{Date.format("yyyy-MM-dd hh:mm", item.create_time * 1000)}}</div>
          </div>
        </div>
        <div class="cl patient-example-bar-tit" style="margin-left: 3.3em;width: 85%">
          {{item.title}}
        </div>
      </div>
    </div>
    <!--适症专家-->
    <div v-if="expertData">
      <h2 class="con com-tit bgw">
        适症专家
      </h2>
      <router-link class="bgw doctor-bar-wrap" :to="jump(expertData.id)">
        <div class="cf doctor-bar">
          <i class="l m lazy-load" v-lazy="expertData.pic_circle"></i>
          <div class="oh">
            <h3 class="doctor-bar-name">
              <span class="f1x">{{expertData.name}}&nbsp;</span>
              <span class="tag tag-2">{{expertData.called}}</span>
            </h3>
            {{expertData.department}}&nbsp;&nbsp;{{expertData.disease_name}}
          </div>
        </div>
        <div class="cl c2 doctor-desc">
          <div class="clamp">
            擅长:{{expertData.killed}}
          </div>
        </div>
      </router-link>
    </div>
    <!--提问输入框-->
    <div class="interact-foot" ref="ineractFoot">
      <div class="pf interact-foot-cover" @click="formCloseHandle"></div><!-- 浮层,用于点击关闭 -->
      <div class="pf interact-foot-inner">
        <div class="c3 interact-foot-btn" @click="formOpenHandle">请输入互动内容</div>
        <form class="dn interact-form" ref="form" @submit.prevent="formSubmitHandle">
          <textarea placeholder="请输入互动内容" class="interact-input" style="height: 10em"></textarea>
          <footer class="con interact-form-foot">
            <input type="submit" value="发送" class="interact-send "></footer>
        </form>
      </div>
    </div>
  </div>
</template>
<script>
  var three_part_css = [
    "//cdn.bootcss.com/photoswipe/4.1.1/photoswipe.css",
    "//cdn.bootcss.com/photoswipe/4.1.1/default-skin/default-skin.css"
  ];
  var jquery = "//cdn.bootcss.com/jquery/2.1.4/jquery.js";
  var three_part_apis = [
      "//cdn.bootcss.com/photoswipe/4.1.1/photoswipe.js",
      "//cdn.bootcss.com/photoswipe/4.1.1/photoswipe-ui-default.js"
    ],
    _isLoaded = false;

  function loadQueue(cb) {
    if (!jquery) {
      cb && cb();
      return;
    }
    getScript(jquery, function () {
      var list = three_part_apis;
      if (_isLoaded) {
        cb();
        return;
      }
      var len = list.length,
        i = 0,
        c = 0,
        ready = function () {
          if (++c === len) {
            cb && cb();
          }
        };
      _isLoaded = true;
      while (i < len) {
        getScript(list[i++], ready);
      }

      three_part_css.length = three_part_apis.length = 0;
    });
    jquery = null;
  }

  function createCssLink() {
    var d = document, i = three_part_css.length, s, frg = d.createDocumentFragment();
    while (i--) {
      s = d.createElement("link");
      s.rel = "stylesheet";
      s.href = three_part_css[i];
      frg.appendChild(s);
    }
    d.head.appendChild(frg);
  }

  function getScript(src, cb) {
    var d = document,
      s = d.createElement("script");
    s.async = true;
    s.onload = cb;
    s.src = src;
    d.body.appendChild(s);
  }

  if (!Object.assign) {
    Object.assign = function (t, s) {
      for (var o in s) {
        t[o] = s[o];
      }
    }
  }
  import Swiper from 'swiper';
  import "swiper/dist/css/swiper.min.css";
  import user from "../../components/login/user";

  export default {
    data() {
      return {
        expertData: "",
        askData: '',
        commentData: '',
        answerData: '',
        praiseCount: '',
        isActive: false,
        isInit: false
      }
    },
    created() {
      createCssLink();
      loadQueue();
      this.getDetail();
    },
    methods: {
      //留言图片浏览
      viewImageHandle: function (e) {
        e.preventDefault();
        if (e.target.tagName === "IMG") {
          var img = e.target.parentNode.children;
          var items = [];
          var i = img.length;
          var index = 0;
          var t = e.target;
          while (i--) {
            items[i] = {
              src: img[i].src,
              w: img[i].naturalWidth || img[i].width,
              h: img[i].naturalHeight || img[i].height
            };
            if (img[i] === t) {
              index = i;
            }
          }
          require("./PhotoSwipe.js").open(items, index);
        }
      },
      getBackground(avatar){
        return "background-image:url('"+avatar+"')";
      },
      jump(id) {
        return "/expert/" + id;
      },
      getDetail() {
        this.$http.get('api/question-detail?id=' + this.$route.params.id).then(res => {
          let j = res.data;
          if (j.code == 200) {
            this.expertData = j.data.expert;
            this.askData = j.data.data;
            this.answerData = j.data.answer;
            this.commentData = j.data.comment;
          }
        })
      },
      cancelPraiseCount(id) {
        if (this.isActive === true) {
          this.$http.get('api/question-de-praise?id=' + id).then(res => {
            let j = res.data;
            if (j.code === 200) {
              this.praiseCount = j.data;
              this.isActive = false;
            }
          })
        }
      },
      addPraiseCount(id) {
        this.isInit = true;
        if (this.isActive === false) {
          this.$http.get('api/question-praise?id=' + id).then(res => {
              let j = res.data;
              if (j.code === 200) {
                this.isActive = !this.isActive;
                this.praiseCount = j.data
              }
            }
          )
        }
      },
      //我也说几句按钮
      formOpenHandle(e) {
        e.preventDefault();
        if (user.info) {
          this.$refs.ineractFoot.classList.add("show");
        }
        else {
          this.$router.push('/login');
        }
      },
      //关闭留言
      formCloseHandle() {
        this.$refs.ineractFoot.classList.remove("show");
      },
      //留言提交
      formSubmitHandle(e) {
        e.preventDefault();
        let fm=e.currentTarget,
          tx=fm.elements[0],
          value=tx.value.trim();
        if(!value){
          this.$tip("未填写互动信息");
          return false;
        }
        this.$refs.ineractFoot.classList.remove("show");

        this.$http.post('api/question-interaction', {
          pid: this.$route.params.id,
          disease: this.askData.disease,
          title: value
        }).then(res => {
          var j = res.data;
          if (j.code === 200) {
            this.$tip("提交成功,请等待审核");
          }
        })

      }
    }
  }
</script>
<style lang="less">
  .doctor-bar-wrap {
    display: block;
    padding: 3%;
    font-size: .34rem;
  }

  .doctor-bar {
    display: flex;
    align-items: center;
  }

  .doctor-bar > .m {
    width: 20%;
    height: 0;
    padding-top: 20%;
    margin-right: 1em;
    border-radius: 50%;
    background-size: cover;
  }

  .doctor-bar > .oh {
    flex: 1;
  }

  .doctor-bar-name {
    margin: 0;
    font-weight: 400;
  }

  .doctor-bar .tag {
    display: inline-block;
    margin-left: .6em;
    padding: 0 .5em;
    border-radius: 5px;
    font-size: .7em;
  }

  .doctor-bar .tag-1 {
    color: #19b497;
    background-color: #d8f7f1;
  }

  .doctor-bar .tag-2 {
    color: #5777fd;
    background-color: #e5eafc;
  }

  .doctor-company {
    margin: .5em;
  }

  .doctor-desc {
    margin-top: 3%;
    padding: 3%;
    border-radius: 5px;
    background: #f7fbfe;
  }

  .patient-pic {
    width: 12%;
    height: 0;
    padding-top: 12%;
    margin-right: 1em;
    border-radius: 50%;
    background-size: cover;
  }

  .live-player-wrap {
    height: 5.625rem;
  }

  .live-player-box {
    z-index: 4;
    top: 0;
    width: 10rem;
    text-align: center;
    background: #1a1a1f;
  }

  .live-player-box > div {
    margin: 0 auto;
  }

  .live-fixed-bar {
    z-index: 2;
    width: 10rem;
    height: 3em;
    font-size: .416rem;
    background: #FFF;
  }

  .show-phone-bar,
  .show-phone-bar > .live-fixed-bar {
    height: 6em;
  }

  .show-phone-bar > .live-fixed-bar > .live-contact {
    display: block;
  }

  /* watch-tab */
  .watch-tab {
    display: flex;
    text-align: center;
    height: 3em;
    line-height: 3em;
    border-bottom: 1px solid #dddddd;
  }

  .watch-tab > a {
    flex: 1;
    margin: 0 .5em;
  }

  .watch-tab > .on {
    position: relative;
    color: #00b38b;
  }

  .watch-tab > .on:after {
    position: absolute;
    content: "";
    left: 50%;
    bottom: 0;
    width: 1.4em;
    height: .2em;
    margin-left: -0.7em;
    background: currentColor;
  }

  .live-interact-header > .m {
    display: block;
    width: 12%;
    height: 0;
    padding-top: 12%;
    border-radius: 50%;
    margin-right: .5em;
    background-size: cover;
  }

  .live-interact-header > .r {
    width: 5em;
  }

  .live-interact-header > span.l {
    -webkit-flex: 1;
    flex: 1;
  }

  .interact-foot,
  .interact-foot-inner {
    width: 10rem;
    min-height: 3em;
    font-size: .4rem;
    background: #FFF;
  }

  .interact-foot-inner {
    z-index: 6;
    bottom: 0;
    box-shadow: 0 0 5px #CCC;
  }

  .interact-foot-btn {
    margin: .5em 5%;
    height: 3em;
    line-height: 3em;
    padding-left: 3em;
    border-radius: 1em;
    background: #f0f4f7 url(data:image/svg+xml;charset=utf8,%3C%21DOCTYPE%20svg%20PUBLIC%20%22-//W3C//DTD%20SVG%201.1//EN%22%20%22http%3A//www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd%22%3E%3Csvg%20viewBox%3D%220%200%201147%201024%22%20version%3D%221.1%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%221120.1171875%22%20height%3D%221000%22%3E%3Cpath%20d%3D%22M0%20956.865864%201146.877993%20956.865864%201146.877993%201020.7232%200%201020.7232%200%20956.865864ZM0%20912.775537%20300.529213%20827.452006%2085.868257%20614.103613%200%20912.775537ZM802.673951%20328.370422%20588.010209%20115.019284%20115.744481%20584.378491%20330.405437%20797.708861%20802.673951%20328.370422ZM902.442885%20149.154775%20768.272343%2015.818629C746.042941-6.277693%20708.804076-5.074616%20685.091594%2018.484019L620.682076%2082.476319%20835.34721%20295.826104%20899.75255%20231.814349C923.465032%20208.254362%20924.668109%20171.253883%20902.442885%20149.154775Z%22%20fill%3D%22%23cccccc%22%3E%3C/path%3E%3C/svg%3E) no-repeat 1em 50%;
    background-size: 1.4em;
  }

  .interact-foot.show > .interact-foot-cover {
    z-index: 6;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0);
  }

  .interact-foot.show > .interact-foot-inner > .interact-foot-btn {
    display: none;
  }

  .interact-foot.show > .interact-foot-inner > .interact-form {
    display: block;
  }

  .interact-input {
    display: block;
    margin: 1em auto;
    width: 94%;
    border: none;
    height: 5em;
    resize: none;
    font-size: 14px;
    outline: none;
  }

  .pic-list {
    min-height: 5em;
  }

  .interact-form-foot {
    display: flex;
    height: 3em;
    box-shadow: 0 0 5px #CCC;
    align-items: center;
  }

  .interact-form-foot > .tr {
    margin-right: 1em;
    -webkit-flex: 1;
    flex: 1;
  }

  .interact-form-foot > .tr:before {
    content: "(";
  }

  .interact-form-foot > .tr:after {
    content: ")";
  }

  .interact-send {
    height: 2em;
    line-height: 2em;
    width: 4em;
    border-radius: .2em;
    color: #FFF;
    border: 0;
    background-color: #00b38b;
    position: absolute;
    right: 1em;
  }

  .interact-send:disabled {
    background-color: #CCC;
  }

  .interact-form-foot > .m {
    width: 1.6em;
    height: 1.6em;
    margin-right: 1em;
  }



  .comment-one-pic {
    margin-left: 1.8em;
    padding-left: 2em;
    background-size: contain;
    background-image: url();
    background-repeat: no-repeat;
    display: inline-block;
  }

  .comment-two-pic {
    margin-left: 1.8em;
    padding-left: 3.7em;
    background-size: contain;
    background-image: url();
    background-repeat: no-repeat;
    display: inline-block;
  }

  .patient-example-bar {
    background: #ffffff;
    margin: 1em;
    box-shadow: 0 1px 5px #ccc;
  }

  .patient-example-bar-tit {
    width: 100%;
    margin: 0;
    font-weight: 500;
    font-size: 1.2em;
    margin-bottom: 0.5em;
  }

  .example-bar-pic {
    width: 31.77%;
    height: 0;
    padding-top: 20.42%;
    margin-top: .5em;
  }

  .patient-bar-foot {
    margin-top: 1em;
    left: 3%;
    bottom: 0;
    width: 100%;
    font-size: .9em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .example-bar-foot > .border-btn {
    font-size: .8em;
    height: 1.8em;
    line-height: 1.8em;
    margin-right: 1em;
    padding: 0 .8em;
  }

  .ask-icon {
    display: inline-block;
    background: #ff5946;
    width: 1.6em;
    height: 1.6em;
    text-align: center;
    border-radius: 3px;
    color: #ffffff;
    font-size: .28rem;
    line-height: 1.6em;
  }

  .patient-flex {
    display: flex;
    flex-direction: row;
    justify-content: space-between;;
    & > .db {
      display: flex;
      flex: 1;
    }
    .patient-name-flex {
      flex: 1;
      margin-right: 1em;
    }
  }

  .icon-count {
    width: 30%;
    display: flex;
    justify-content: flex-end;
    div {
      display: flex;
      flex: 1;
      width: 1.4em;
      height: 1.4em;
      .list-icon {
        width: 1.4em;
        height: 1.4em;
      }
    }
  }
  .interact-img{
    width: 32%;
    margin-right: 1%;
    margin-top: 1%;
    object-fit: cover;
  }
  .patient-list-icon {
    position: relative;
    top: .2em;
    width: 1.4em;
    height: 1.4em;
  }
</style>
上一篇下一篇

猜你喜欢

热点阅读