reply.blade.php 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. @extends('layouts.base')
  2. @section('title', '评论回复')
  3. @section('content')
  4. <link rel="stylesheet" type="text/css" href="{{static_url('yunshop/goods/vue-goods1.css')}}"/>
  5. <style>
  6. .reply-content{width:70%;border:1px solid #dadada;background:#f5f7fa;padding:10px}
  7. .reply-content-li{display:flex;line-height:24px;margin-bottom:5px}
  8. .reply-content-left{max-width:300px;overflow:hidden;display:flex}
  9. .reply-content-left-times{width:130px;font-size:12px;color:#ccc;}
  10. .reply-content-left-user{flex:1;font-weight:500;display:flex}
  11. .reply-content-left-user1{max-width:60px;white-space: nowrap;text-overflow: ellipsis;overflow: hidden;word-break: break-all;}
  12. .reply-content-left-user2{width:40px;white-space: nowrap;text-overflow: ellipsis;overflow: hidden;word-break: break-all;}
  13. .reply-content-left-user3{max-width:70px;white-space: nowrap;text-overflow: ellipsis;overflow: hidden;word-break: break-all;}
  14. .reply-content-middle{flex:1;margin: 0 15px;color: #666;font-size: 12px;font-weight: 500;}
  15. .reply-content-middle-img{margin:5px 2px;display:inline-block}
  16. </style>
  17. <div class="all">
  18. <div id="app" v-cloak>
  19. <div class="vue-main">
  20. <div class="vue-main-title">
  21. <div class="vue-main-title-left"></div>
  22. <div class="vue-main-title-content">回复评论</div>
  23. </div>
  24. <div class="vue-main-form" v-if="comment">
  25. <el-form ref="form" :model="form" label-width="15%">
  26. <el-form-item label="文章标题" prop="goods">
  27. <el-input v-model="comment.article.title" style="width:70%;" disabled></el-input>
  28. </el-form-item>
  29. <el-form-item label="评论者" prop="goods">
  30. <el-input v-model="comment.nick_name" style="width:70%;" disabled></el-input>
  31. <div style="width:150px;height:150px;position:relative;margin-top:10px">
  32. <img :src="comment.member.avatar_image" onerror="this.src='/addons/yun_shop/static/resource/images/nopic.jpg'; this.title='图片未找到.'" style="width:150px;height:150px">
  33. </div>
  34. </el-form-item>
  35. <el-form-item label="评论内容" prop="alias">
  36. <el-input v-model="comment.content" disabled type="textarea" style="width:70%"></el-input>
  37. <div v-if="comment&&comment.images&&comment.images.length>0">
  38. <div v-for="(item1,index1) in comment.images" :key="index1" style="margin:5px 2px;display:inline-block">
  39. <img :src="item1" alt="" style="width:50px;height:50px" @click="openBig(comment.images,index1)">
  40. </div>
  41. </div>
  42. </el-form-item>
  43. <el-form-item label="">
  44. <div class="reply-content">
  45. <div v-for="(item,index) in comment.has_many_reply" :key="index">
  46. <div class="reply-content-li">
  47. <div class="reply-content-left">
  48. <div class="reply-content-left-times">[[item.created_at]]</div>
  49. <div class="reply-content-left-user">
  50. <div class="reply-content-left-user1">[[item.nick_name]]&nbsp;</div>
  51. <div class="reply-content-left-user2">[[item.type_name]]</div>
  52. <div class="reply-content-left-user3" v-if="item.type!=3">&nbsp;&nbsp;[[item.reply_name]]</div>
  53. </div>
  54. </div>
  55. <div class="reply-content-middle">
  56. <div class="reply-content-middle-con" style="line-height:24px">[[item.content]]</div>
  57. <div class="reply-content-middle-img" v-for="(item1,index1) in item.images" :key="index1">
  58. <img :src="item1" alt="" style="width:50px;height:50px" @click="openBig(item.images,index1)">
  59. </div>
  60. </div>
  61. <div style="width:250px;text-align:right">
  62. <el-button size="mini" v-if="item.uid&&item.type!=3" @click="isPass(item)" :type="item.is_pass? 'success':'danger'">[[item.is_pass? '已审核':'待审核']]</el-button>
  63. <el-button size="mini" v-if="item.uid&&item.type!=3" @click="replyCon(item)">回复</el-button>
  64. <el-button size="mini" type="info" @click="del(item.id,index)" plain>删除</el-button>
  65. </div>
  66. </div>
  67. </div>
  68. <div style="margin-top:10px">
  69. <el-form-item :label="'管理员 回复 '+reply_name" prop="content">
  70. <el-input v-model="form.content" type="textarea" rows="5" ref="reply_content"></el-input>
  71. <el-button size="mini" @click="openListUpload('images')">选择图片</el-button>
  72. <div v-if="form.images_url">
  73. <div v-for="(item,index) in form.images_url" :key="index" style="display:inline-block;margin:5px;width:50px;height:50px;position:relative;margin-top:10px">
  74. <img :src="item" alt="" style="width:50px;height:50px">
  75. <i
  76. class="el-icon-circle-close"
  77. @click="clearImg('images','list',index)"
  78. title="点击清除图片"
  79. ></i>
  80. </div>
  81. </div>
  82. </el-form-item>
  83. </div>
  84. </div>
  85. </el-form-item>
  86. </el-form>
  87. <el-dialog :visible.sync="big_img_show" width="60%" height="500px" center>
  88. <div>
  89. <el-carousel trigger="click" height="500px" :initial-index="big_img_index" :autoplay="false">
  90. <el-carousel-item v-for="item in big_img_list" :key="item">
  91. <div style="text-align:center">
  92. <img :src="item" style="max-height:700px;" />
  93. </div>
  94. </el-carousel-item>
  95. </el-carousel>
  96. </div>
  97. </el-dialog>
  98. </div>
  99. </div>
  100. <!-- 分页 -->
  101. <div class="vue-page">
  102. <div class="vue-center">
  103. <el-button type="primary" @click="submitForm('form')">提交</el-button>
  104. <el-button @click="goBack">返回</el-button>
  105. </div>
  106. </div>
  107. <upload-img-list :upload-list-show="uploadListShow" :name="chooseImgListName" @replace="changeListProp" @sure="sureImgList"></upload-img-list>
  108. </div>
  109. </div>
  110. @include('public.admin.uploadImgList')
  111. <script>
  112. let id = {!! $id !!};
  113. var app = new Vue({
  114. el:"#app",
  115. delimiters: ['[[', ']]'],
  116. name: 'test',
  117. data() {
  118. return{
  119. id:id,
  120. form:{
  121. images:[],
  122. images_url:[],
  123. content:'',
  124. },
  125. comment_id:'',
  126. reply_id:'',
  127. reply_name:'',
  128. big_img_show:false,
  129. big_img_list:[],
  130. big_img_index:0,
  131. comment:null,
  132. submit_url:'',
  133. uploadListShow:false,
  134. chooseImgListName:'',
  135. loading: false,
  136. }
  137. },
  138. created() {
  139. },
  140. mounted() {
  141. this.getData();
  142. this.submit_url = '{!! yzWebFullUrl('plugin.article.manager.comment.get-reply') !!}';
  143. },
  144. methods: {
  145. getData() {
  146. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  147. this.$http.post('{!! yzWebFullUrl('plugin.article.manager.comment.get-reply') !!}',{id:this.id}).then(function (response) {
  148. if (response.data.result){
  149. this.comment = response.data.data.comment || {};
  150. this.comment_id = response.data.data.comment.id;
  151. this.reply_id = response.data.data.comment.uid;
  152. this.article_id = response.data.data.comment.article_id;
  153. this.reply_name = response.data.data.comment.nick_name;
  154. }
  155. else {
  156. this.$message({message: response.data.msg,type: 'error'});
  157. }
  158. loading.close();
  159. },function (response) {
  160. this.$message({message: response.data.msg,type: 'error'});
  161. loading.close();
  162. }
  163. );
  164. },
  165. // 回复
  166. replyCon(item) {
  167. this.$refs.reply_content.focus();
  168. this.reply_id = item.uid;
  169. this.reply_name = item.nick_name;
  170. },
  171. isPass(item) {
  172. console.log(item.is_pass);
  173. this.$http.post('{!! yzWebFullUrl('plugin.article.manager.comment.pass') !!}',{ ids: [item.id], is_pass:item.is_pass? 0:1 }).then(function (response) {
  174. if (response.data.result) {
  175. this.$message({type: 'success',message: '修改审核状态成功!'});
  176. item.is_pass = item.is_pass ? 0 : 1;
  177. }
  178. else{
  179. this.$message({type: 'error',message: response.data.msg});
  180. }
  181. },function (response) {
  182. this.$message({type: 'error',message: response.data.msg});
  183. }
  184. );
  185. },
  186. del(id,index) {
  187. this.$confirm('确定删除吗', '提示', {confirmButtonText: '确定',cancelButtonText: '取消',type: 'warning'}).then(() => {
  188. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  189. this.$http.post('{!! yzWebFullUrl('plugin.article.manager.comment.deleted') !!}',{id:id}).then(function (response) {
  190. if (response.data.result) {
  191. this.$message({type: 'success',message: '删除成功!'});
  192. this.getData();
  193. }
  194. else{
  195. this.$message({type: 'error',message: response.data.msg});
  196. }
  197. loading.close();
  198. this.search(this.current_page)
  199. },function (response) {
  200. this.$message({type: 'error',message: response.data.msg});
  201. loading.close();
  202. }
  203. );
  204. }).catch(() => {
  205. this.$message({type: 'info',message: '已取消删除'});
  206. });
  207. },
  208. submitForm(formName) {
  209. let that = this;
  210. let json = {
  211. id:this.id,
  212. reply:{
  213. reply_content:this.form.content,
  214. reply_images:this.form.images,
  215. nick_name:'管理员',
  216. comment_id:this.comment_id,
  217. article_id:this.article_id,
  218. reply_id:this.reply_id,
  219. type:2,
  220. }
  221. };
  222. this.$refs[formName].validate((valid) => {
  223. if (valid) {
  224. let loading = this.$loading({target:document.querySelector(".content"),background: 'rgba(0, 0, 0, 0)'});
  225. this.$http.post(this.submit_url,json).then(response => {
  226. if (response.data.result) {
  227. this.$message({type: 'success',message: '操作成功!'});
  228. this.form.content = "";
  229. this.getData();
  230. } else {
  231. this.$message({message: response.data.msg,type: 'error'});
  232. }
  233. loading.close();
  234. },response => {
  235. loading.close();
  236. });
  237. }
  238. else {
  239. console.log('error submit!!');
  240. return false;
  241. }
  242. });
  243. },
  244. goBack() {
  245. history.go(-1)
  246. },
  247. openBig(item,index) {
  248. this.big_img_index = index;
  249. this.big_img_list = item;
  250. this.big_img_show = true;
  251. },
  252. clearImg(str,type,index) {
  253. if(!type) {
  254. this.form[str] = "";
  255. this.form[str+'_url'] = "";
  256. }
  257. else {
  258. this.form[str].splice(index,1);
  259. this.form[str+'_url'].splice(index,1);
  260. }
  261. this.$forceUpdate();
  262. },
  263. openListUpload(str) {
  264. this.chooseImgListName = str;
  265. this.uploadListShow = true;
  266. },
  267. changeListProp(val) {
  268. if(val == true) {
  269. this.uploadListShow = false;
  270. }
  271. else {
  272. this.uploadListShow = true;
  273. }
  274. },
  275. sureImgList(name,image,image_url) {
  276. console.log(name)
  277. console.log(image)
  278. console.log(image_url)
  279. if(!this.form[name] || !this.form[name+'_url']) {
  280. this.form[name] = [];
  281. this.form[name+'_url'] = [];
  282. }
  283. image.forEach((item,index) => {
  284. this.form[name].push(item);
  285. this.form[name+'_url'].push(image_url[index]);
  286. })
  287. console.log(this.form)
  288. },
  289. },
  290. })
  291. </script>
  292. @endsection