EarnPoints.vue 54 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481
  1. <template>
  2. <div class="right-wrap">
  3. <div class="myTabs" style="background: #fff;min-height: 500px;">
  4. <el-tabs style="padding: 0 20px 40px 20px;" v-model="activeName" @tab-click="handleClick">
  5. <el-tab-pane label="证书列表" name="first">
  6. <el-button size="small" type="primary" @click="dialogVisible = true">上传证书</el-button>
  7. <el-table size="small" :data="dataList" border style="margin-top: 20px;width: 960px">
  8. <el-table-column align="center" type="index" width="50" label="序号"></el-table-column>
  9. <el-table-column align="center" min-width="200" label="附件">
  10. <template slot-scope="props">
  11. <div v-for="(item, index) in props.row.files" :key="index">
  12. <a style="color: #1e80ff;" target="_blank" :href="item.url">{{ item.oldName }}</a>
  13. </div>
  14. </template>
  15. </el-table-column>
  16. <el-table-column min-width="100" align="center" prop="typeName" label="证书大类"></el-table-column>
  17. <el-table-column align="center" prop="categoryName" min-width="100" label="证书类型"></el-table-column>
  18. <el-table-column align="center" prop="title" min-width="100" label="证书名称"></el-table-column>
  19. <el-table-column align="center" prop="integral" min-width="100" label="积分"></el-table-column>
  20. <el-table-column min-width="60" align="center" prop="statusName" label="状态"></el-table-column>
  21. <el-table-column min-width="150" align="center" prop="createTime" label="上传时间"></el-table-column>
  22. <el-table-column min-width="80" align="center" label="备注">
  23. <template slot-scope="props">
  24. <el-popover width="200" trigger="hover" :content="props.row.content">
  25. <div slot="reference" class="text-overflow">{{ props.row.content }}</div>
  26. </el-popover>
  27. </template>
  28. </el-table-column>
  29. </el-table>
  30. <!-- 分页 -->
  31. <div class="myPage">
  32. <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange"
  33. :current-page="currentPage" :page-sizes="[10, 20, 30, 40]" :page-size="10"
  34. layout="total, sizes, prev, pager, next, jumper" :total="total">
  35. </el-pagination>
  36. </div>
  37. </el-tab-pane>
  38. <el-tab-pane label="表彰列表" name="third">
  39. <el-button size="small" type="primary" @click="handleClickCreate('上传表彰')">上传表彰</el-button>
  40. <el-table size="small" :data="dataListCite" border style="margin-top: 20px;width: 960px">
  41. <el-table-column align="center" type="index" width="50" label="序号"></el-table-column>
  42. <el-table-column align="center" min-width="200" label="附件">
  43. <template slot-scope="props">
  44. <div v-for="(item, index) in props.row.files" :key="index">
  45. <a style="color: #1e80ff;" target="_blank" :href="item.url">{{ item.oldName }}</a>
  46. </div>
  47. </template>
  48. </el-table-column>
  49. <el-table-column align="center" prop="typeName" min-width="80" label="表彰类型"></el-table-column>
  50. <el-table-column align="center" min-width="100" label="表彰人员">
  51. <template slot-scope="props">
  52. <el-popover trigger="hover">
  53. <el-table :data="props.row.groupUsers" border size="mini">
  54. <el-table-column min-width="200" align="center" prop="deptName" label="部门"></el-table-column>
  55. <el-table-column min-width="100" align="center" prop="userName" label="姓名"></el-table-column>
  56. <el-table-column min-width="100" align="center" prop="employeNo" label="员工号"></el-table-column>
  57. </el-table>
  58. <span style="color: #1e80ff;cursor: pointer;" slot="reference">
  59. {{ props.row.userName }}
  60. </span>
  61. </el-popover>
  62. </template>
  63. </el-table-column>
  64. <el-table-column align="center" min-width="100" label="客户名称">
  65. <template slot-scope="props">
  66. <el-popover width="200" trigger="hover" :content="props.row.customerName">
  67. <div slot="reference" class="text-overflow">{{ props.row.customerName }}</div>
  68. </el-popover>
  69. </template>
  70. </el-table-column>
  71. <el-table-column align="center" min-width="100" label="表彰名称">
  72. <template slot-scope="props">
  73. <el-popover width="200" trigger="hover" :content="props.row.title">
  74. <div slot="reference" class="text-overflow">{{ props.row.title }}</div>
  75. </el-popover>
  76. </template>
  77. </el-table-column>
  78. <el-table-column min-width="100" align="center" label="表彰描述">
  79. <template slot-scope="props">
  80. <el-popover width="400" trigger="hover" :content="props.row.content">
  81. <div slot="reference" class="text-overflow">{{ props.row.content }}</div>
  82. </el-popover>
  83. </template>
  84. </el-table-column>
  85. <el-table-column min-width="100" align="center" label="状态">
  86. <template slot-scope="props">
  87. <el-popover trigger="hover">
  88. <el-table :data="props.row.logs" border size="mini">
  89. <el-table-column min-width="120" align="center" prop="auditor" label="处理人"></el-table-column>
  90. <el-table-column min-width="160" align="center" prop="comment" label="处理结果"></el-table-column>
  91. <el-table-column min-width="180" align="center" prop="createTime" label="处理时间"></el-table-column>
  92. </el-table>
  93. <span style="color: #1e80ff;cursor: pointer;" slot="reference">{{ props.row.statusName }}</span>
  94. </el-popover>
  95. </template>
  96. </el-table-column>
  97. <el-table-column min-width="120" align="center" prop="createTime" label="上传时间"></el-table-column>
  98. <el-table-column fixed="right" align="center" label="操作" width="160px"
  99. class-name="small-padding fixed-width">
  100. <template slot-scope="scope">
  101. <el-button type="primary" size="small" @click="handleClickViewCite(scope.row, 'view')">查看</el-button>
  102. <el-button v-if="scope.row.status == '12' || scope.row.status == '22'" type="success" size="small"
  103. @click="handleClickViewCite(scope.row, 'edit')">修改</el-button>
  104. </template>
  105. </el-table-column>
  106. </el-table>
  107. <div class="myPage">
  108. <el-pagination @size-change="handleSizeChangeCite" @current-change="handleCurrentChangeCite"
  109. :current-page="currentPage" :page-sizes="[10, 20, 30, 40]" :page-size="10"
  110. layout="total, sizes, prev, pager, next, jumper" :total="totalCite">
  111. </el-pagination>
  112. </div>
  113. </el-tab-pane>
  114. <el-tab-pane label="培训列表" name="fourth">
  115. <el-button size="small" type="primary" @click="handleClickCreate('上传培训')">上传培训</el-button>
  116. <el-table size="small" :data="dataListTrain" border style="margin-top: 20px;width: 960px">
  117. <el-table-column align="center" type="index" width="50" label="序号"></el-table-column>
  118. <el-table-column align="center" prop="title" min-width="100" label="培训主题">
  119. </el-table-column>
  120. <el-table-column align="center" prop="startTime" min-width="150" label="开始时间">
  121. </el-table-column>
  122. <el-table-column align="center" prop="endTime" min-width="150" label="结束时间">
  123. </el-table-column>
  124. <el-table-column min-width="100" align="center" label="状态">
  125. <template slot-scope="props">
  126. <el-popover trigger="hover">
  127. <el-table :data="props.row.trainLogs" border size="mini">
  128. <el-table-column min-width="120" align="center" prop="auditor" label="处理人"></el-table-column>
  129. <el-table-column min-width="160" align="center" prop="comment" label="处理结果"></el-table-column>
  130. <!-- <el-table-column min-width="120" align="center" prop="statusName" label="状态"></el-table-column> -->
  131. <el-table-column min-width="180" align="center" prop="createTime" label="处理时间"></el-table-column>
  132. </el-table>
  133. <span style="color: #1e80ff;cursor: pointer;" slot="reference">{{ props.row.statusName }}</span>
  134. </el-popover>
  135. </template>
  136. </el-table-column>
  137. <el-table-column align="center" prop="lecturerName" min-width="150" label="培训讲师">
  138. </el-table-column>
  139. <el-table-column align="center" min-width="100" label="参加人员">
  140. <template slot-scope="props">
  141. <el-popover trigger="hover">
  142. <el-table :data="props.row.trainees" border size="mini">
  143. <el-table-column min-width="200" align="center" prop="deptName" label="部门"></el-table-column>
  144. <el-table-column min-width="100" align="center" prop="userName" label="姓名"></el-table-column>
  145. <el-table-column min-width="100" align="center" prop="employeNo" label="员工号"></el-table-column>
  146. </el-table>
  147. <span style="color: #1e80ff;cursor: pointer;" slot="reference">
  148. {{ props.row.trainees[0].userName }}
  149. </span>
  150. </el-popover>
  151. </template>
  152. </el-table-column>
  153. <el-table-column min-width="100" align="center" label="培训描述">
  154. <template slot-scope="props">
  155. <el-popover width="400" trigger="hover" :content="props.row.content">
  156. <div slot="reference" class="text-overflow">{{ props.row.content }}</div>
  157. </el-popover>
  158. </template>
  159. </el-table-column>
  160. <el-table-column align="center" min-width="200" label="培训材料">
  161. <template slot-scope="props">
  162. <div v-for="(item, index) in props.row.materialFiles" :key="index">
  163. <a style="color: #1e80ff;" target="_blank" :href="item.url">{{ item.oldName }}</a>
  164. </div>
  165. </template>
  166. </el-table-column>
  167. <el-table-column align="center" min-width="200" label="签到表照片">
  168. <template slot-scope="props">
  169. <div v-for="(item, index) in props.row.signPhotoFiles" :key="index">
  170. <a style="color: #1e80ff;" target="_blank" :href="item.url">{{ item.oldName }}</a>
  171. </div>
  172. </template>
  173. </el-table-column>
  174. <el-table-column align="center" min-width="200" label="现场照片">
  175. <template slot-scope="props">
  176. <div v-for="(item, index) in props.row.sitePhotoFiles" :key="index">
  177. <a style="color: #1e80ff;" target="_blank" :href="item.url">{{ item.oldName }}</a>
  178. </div>
  179. </template>
  180. </el-table-column>
  181. <el-table-column min-width="150" align="center" prop="createTime" label="上传时间"></el-table-column>
  182. <el-table-column fixed="right" align="center" label="操作" width="160px"
  183. class-name="small-padding fixed-width">
  184. <template slot-scope="scope">
  185. <el-button type="primary" size="small" @click="handleClickView(scope.row, 'view')">查看</el-button>
  186. <el-button v-if="scope.row.status == '21' || scope.row.status == '31'" type="success" size="small"
  187. @click="handleClickView(scope.row, 'edit')">修改</el-button>
  188. </template>
  189. </el-table-column>
  190. </el-table>
  191. <!-- 分页 -->
  192. <div class="myPage">
  193. <el-pagination @size-change="handleSizeChangeTrain" @current-change="handleCurrentChangeTrain"
  194. :current-page="currentPage" :page-sizes="[10, 20, 30, 40]" :page-size="10"
  195. layout="total, sizes, prev, pager, next, jumper" :total="totalTrain">
  196. </el-pagination>
  197. </div>
  198. </el-tab-pane>
  199. <el-tab-pane label="证书积分规则" name="second">
  200. <el-empty v-if="!integralRules" :image-size="200"></el-empty>
  201. <div v-else v-html="integralRules"></div>
  202. </el-tab-pane>
  203. <el-tab-pane label="积分充值" name="fifth">
  204. <Ipay v-if="activeName == 'fifth'"></Ipay>
  205. </el-tab-pane>
  206. <el-tab-pane label="抖音叶盏点赞活动" name="sixth">
  207. <el-table size="small" :data="dataListZan" border style="margin-top: 20px;width: 960px">
  208. <el-table-column type="index" width="50" align="center" label="序号"></el-table-column>
  209. <el-table-column min-width="100" align="center" label="平台" prop="platformName">
  210. </el-table-column>
  211. <el-table-column min-width="100" align="center" label="账号" prop="accountName">
  212. </el-table-column>
  213. <el-table-column min-width="100" align="center" label="视频系列" prop="videoSeries">
  214. </el-table-column>
  215. <el-table-column min-width="100" align="center" label="第几集" prop="episodeNumber">
  216. </el-table-column>
  217. <el-table-column min-width="100" align="center" label="视频名称" prop="videoName">
  218. </el-table-column>
  219. <el-table-column min-width="100" align="center" label="抖音账号" prop="tiktokAccount">
  220. </el-table-column>
  221. <el-table-column min-width="100" align="center" label="状态" prop="uploadStatus">
  222. </el-table-column>
  223. <el-table-column min-width="200" align="center" label="附件">
  224. <template slot-scope="props">
  225. <div v-for="(item, index) in props.row.files" :key="index">
  226. <a style="color: #1e80ff;" target="_blank" :href="item.url">{{ item.oldName }}</a>
  227. </div>
  228. </template>
  229. </el-table-column>
  230. <el-table-column fixed="right" align="center" label="操作" width="80px"
  231. class-name="small-padding fixed-width">
  232. <template slot-scope="scope">
  233. <el-button :disabled="scope.row.uploadStatus == '未上传' ? false : true" type="primary" size="small"
  234. @click="handleClickViewZan(scope.row.id)">上传</el-button>
  235. </template>
  236. </el-table-column>
  237. </el-table>
  238. <!-- 分页 -->
  239. <div class="myPage">
  240. <el-pagination @size-change="handleSizeChangeZan" @current-change="handleCurrentChangeZan"
  241. :current-page="currentPage" :page-sizes="[10, 20, 30, 40]" :page-size="10"
  242. layout="total, sizes, prev, pager, next, jumper" :total="totalZan">
  243. </el-pagination>
  244. </div>
  245. </el-tab-pane>
  246. </el-tabs>
  247. </div>
  248. <el-dialog title="上传证书" :visible.sync="dialogVisible" width="40%">
  249. <el-form :rules="rules" ref="dataForm" :model="dataForm" label-width="100px">
  250. <el-form-item label="证书类别:" prop="type">
  251. <el-cascader clearable size="small" style="width: 95%;" v-model="dataForm.type" :options="typeList"
  252. :props="{ value: 'id', label: 'typeName', children: 'children' }" @change="handleChange"></el-cascader>
  253. </el-form-item>
  254. <el-form-item label="证书名称:" prop="title">
  255. <el-input clearable style="width: 95%;" size="small" v-model="dataForm.title"></el-input>
  256. </el-form-item>
  257. <el-form-item label="证书附件:" prop="fileIds">
  258. <el-upload :action="fileUrl" :file-list="dataForm.files" :on-success="handleAvatarSuccess"
  259. :before-upload="beforeUploadFile" :on-remove="handleRemove">
  260. <el-button size="small" type="primary">点击上传</el-button>
  261. </el-upload>
  262. </el-form-item>
  263. </el-form>
  264. <span slot="footer" class="dialog-footer">
  265. <el-button size="small" type="primary" @click="submitForm">确 定</el-button>
  266. </span>
  267. </el-dialog>
  268. <el-dialog :title="textMap[dialogStatus]" :visible.sync="dialogVisibleCite" width="40%">
  269. <el-form :rules="rulesCite" ref="dataFormCite" :model="dataFormCite" label-width="100px">
  270. <el-form-item label="表彰类型:" prop="type">
  271. <el-select :disabled="dialogStatus == 'view' ? true : false" clearable size="small" style="width: 95%;"
  272. v-model="dataFormCite.type" placeholder="请选择表彰类型">
  273. <el-option v-for="item in typeListCite" :key="item.dictValue" :label="item.dictLabel"
  274. :value="item.dictValue">
  275. </el-option>
  276. </el-select>
  277. </el-form-item>
  278. <el-form-item v-if="dataFormCite.type == '1'" label="集体人员:" prop="groupIds">
  279. <el-select :disabled="dialogStatus == 'view' ? true : false" size="small" v-model="dataFormCite.groupIds" multiple
  280. filterable placeholder="请选择(支持输入姓名检索)" style="width: 95%;">
  281. <el-option :key="item.loginId" v-for="item in recipientsList"
  282. :label="item.deptName + '_' + item.userName + '_' + item.employeNo" :value="item.loginId">
  283. </el-option>
  284. </el-select>
  285. </el-form-item>
  286. <el-form-item label="客户名称:" prop="customerName">
  287. <el-input :disabled="dialogStatus == 'view' ? true : false" clearable style="width: 95%;" size="small"
  288. v-model="dataFormCite.customerName"></el-input>
  289. </el-form-item>
  290. <el-form-item label="表彰名称:" prop="title">
  291. <el-input :disabled="dialogStatus == 'view' ? true : false" clearable style="width: 95%;" size="small"
  292. v-model="dataFormCite.title"></el-input>
  293. </el-form-item>
  294. <el-form-item label="表彰描述:" prop="content">
  295. <el-input :disabled="dialogStatus == 'view' ? true : false" type="textarea" :rows="5" maxlength="500"
  296. show-word-limit style="width: 95%;" size="small" v-model="dataFormCite.content"></el-input>
  297. </el-form-item>
  298. <el-form-item label="表彰附件:" prop="fileIds">
  299. <el-upload :disabled="dialogStatus == 'view' ? true : false" :action="fileUrl" :file-list="dataFormCite.files"
  300. :on-success="handleAvatarSuccessCite" :before-upload="beforeUploadFileCite" :on-remove="handleRemoveCite">
  301. <el-button size="small" type="primary">点击上传</el-button>
  302. </el-upload>
  303. </el-form-item>
  304. <el-table v-if="dialogStatus == 'create' ? false : true" :data="citeLogsList" border size="mini">
  305. <el-table-column min-width="120" align="center" prop="auditor" label="处理人"></el-table-column>
  306. <el-table-column min-width="160" align="center" prop="comment" label="处理结果"></el-table-column>
  307. <el-table-column min-width="180" align="center" prop="createTime" label="处理时间"></el-table-column>
  308. </el-table>
  309. </el-form>
  310. <span v-if="dialogStatus != 'view'" slot="footer" class="dialog-footer">
  311. <el-button size="small" type="primary" @click="submitFormCite">确 定</el-button>
  312. </span>
  313. </el-dialog>
  314. <el-dialog :title="textMap[dialogStatus]" :visible.sync="dialogVisibleTrain" width="40%">
  315. <el-form :rules="rulesTrain" ref="dataFormTrain" :model="dataFormTrain" label-width="100px">
  316. <el-form-item label="培训主题:" prop="title">
  317. <el-input :disabled="dialogStatus == 'view' ? true : false" clearable style="width: 95%;" size="small"
  318. v-model="dataFormTrain.title"></el-input>
  319. </el-form-item>
  320. <el-form-item label="开始时间:" prop="startTime">
  321. <el-date-picker :disabled="dialogStatus == 'view' ? true : false" format="yyyy-MM-dd HH:mm:ss"
  322. value-format="yyyy-MM-dd HH:mm:ss" type="datetime" v-model="dataFormTrain.startTime" placeholder="请选择开始时间"
  323. style="width: 95%">
  324. </el-date-picker>
  325. </el-form-item>
  326. <el-form-item label="结束时间:" prop="endTime">
  327. <el-date-picker :disabled="dialogStatus == 'view' ? true : false" format="yyyy-MM-dd HH:mm:ss"
  328. value-format="yyyy-MM-dd HH:mm:ss" type="datetime" v-model="dataFormTrain.endTime" placeholder="请选择结束时间"
  329. style="width: 95%">
  330. </el-date-picker>
  331. </el-form-item>
  332. <el-form-item label="培训讲师:" prop="lecturer">
  333. <el-select :disabled="dialogStatus == 'view' ? true : false" size="small" v-model="dataFormTrain.lecturer"
  334. filterable placeholder="请选择(支持输入姓名检索)" style="width: 95%;">
  335. <el-option :key="item.loginId" v-for="item in recipientsList"
  336. :label="item.deptName + '_' + item.userName + '_' + item.employeNo" :value="item.loginId">
  337. </el-option>
  338. </el-select>
  339. </el-form-item>
  340. <el-form-item label="参加人员:" prop="traineeIds">
  341. <el-select :disabled="dialogStatus == 'view' ? true : false" size="small" v-model="dataFormTrain.traineeIds"
  342. multiple filterable placeholder="请选择(支持输入姓名检索)" style="width: 95%;">
  343. <el-option :key="item.loginId" v-for="item in recipientsList"
  344. :label="item.deptName + '_' + item.userName + '_' + item.employeNo" :value="item.loginId">
  345. </el-option>
  346. </el-select>
  347. </el-form-item>
  348. <el-form-item label="培训内容:" prop="content">
  349. <el-input :disabled="dialogStatus == 'view' ? true : false" type="textarea" :rows="5" maxlength="500"
  350. show-word-limit style="width: 95%;" size="small" v-model="dataFormTrain.content"></el-input>
  351. </el-form-item>
  352. <el-form-item label="培训材料:" prop="materials">
  353. <el-upload :disabled="dialogStatus == 'view' ? true : false" :action="fileUrl"
  354. :file-list="dataFormTrain.materialFiles" :on-success="handleAvatarSuccessTrain"
  355. :before-upload="beforeUploadFileTrain" :on-remove="handleRemoveTrain">
  356. <el-button size="small" type="primary">点击上传</el-button>
  357. </el-upload>
  358. </el-form-item>
  359. <el-form-item label="签到表:" prop="signPhotos">
  360. <el-upload :disabled="dialogStatus == 'view' ? true : false" :action="fileUrl"
  361. :file-list="dataFormTrain.signPhotoFiles" :on-success="handleAvatarSuccessTrain1"
  362. :before-upload="beforeUploadFileTrain" :on-remove="handleRemoveTrain1">
  363. <el-button size="small" type="primary">点击上传</el-button>
  364. </el-upload>
  365. </el-form-item>
  366. <el-form-item label="现场照片:" prop="sitePhotos">
  367. <el-upload :disabled="dialogStatus == 'view' ? true : false" :action="fileUrl"
  368. :file-list="dataFormTrain.sitePhotoFiles" :on-success="handleAvatarSuccessTrain2"
  369. :before-upload="beforeUploadFileTrain" :on-remove="handleRemoveTrain2">
  370. <el-button size="small" type="primary">点击上传</el-button>
  371. </el-upload>
  372. </el-form-item>
  373. <el-form-item v-if="dialogStatus != 'view'" label="上传说明:">
  374. <el-card shadow="never" style="width: 95%;padding: 0;min-height: 100px;line-height: normal;">
  375. <div v-html="remarkHtml"></div>
  376. </el-card>
  377. </el-form-item>
  378. <el-table v-if="dialogStatus == 'create' ? false : true" :data="trainLogsList" border size="mini">
  379. <el-table-column min-width="120" align="center" prop="auditor" label="处理人"></el-table-column>
  380. <el-table-column min-width="160" align="center" prop="comment" label="处理结果"></el-table-column>
  381. <el-table-column min-width="180" align="center" prop="createTime" label="处理时间"></el-table-column>
  382. </el-table>
  383. </el-form>
  384. <span v-if="dialogStatus != 'view'" slot="footer" class="dialog-footer">
  385. <el-button size="small" type="primary" @click="submitFormTrain">确 定</el-button>
  386. </span>
  387. </el-dialog>
  388. <el-dialog title="上传点赞" :visible.sync="dialogVisibleZan" width="40%">
  389. <el-form :rules="rulesZan" ref="dataFormZan" :model="dataFormZan" label-width="100px">
  390. <el-form-item label="抖音账号:" prop="tiktokAccount">
  391. <el-input clearable style="width: 95%;" size="small" v-model="dataFormZan.tiktokAccount"></el-input>
  392. </el-form-item>
  393. <el-form-item label="事项" prop="matters">
  394. <el-checkbox :indeterminate="isIndeterminate" v-model="checkAll"
  395. @change="handleCheckAllChange">全选</el-checkbox>
  396. <el-checkbox-group v-model="dataFormZan.matters" @change="changeChecked">
  397. <el-checkbox v-for="item in typeListZan" :key="item.dictValue" :label="item.dictValue">{{ item.dictLabel
  398. }}</el-checkbox>
  399. </el-checkbox-group>
  400. </el-form-item>
  401. <el-form-item label="证明附件:" prop="fileIds">
  402. <el-upload :action="fileUrl" :file-list="dataFormZan.files" :on-success="handleAvatarSuccessZan"
  403. :before-upload="beforeUploadFileZan" :on-remove="handleRemoveZan">
  404. <el-button size="small" type="primary">点击上传</el-button>
  405. </el-upload>
  406. </el-form-item>
  407. <el-form-item label="上传说明:">
  408. <el-card shadow="never" style="width: 95%;padding: 0;min-height: 100px;line-height: normal;">
  409. <div v-html="remarkHtml"></div>
  410. </el-card>
  411. </el-form-item>
  412. </el-form>
  413. <span slot="footer" class="dialog-footer">
  414. <el-button size="small" type="primary" @click="submitFormZan">确 定</el-button>
  415. </span>
  416. </el-dialog>
  417. </div>
  418. </template>
  419. <script scoped>
  420. import Ipay from '@/views/Ipay.vue'
  421. import { certificatePage, certificateUpload, notice, certificatType, dictList, allUserList, citeList, uploadCite, editCite, trainList, uploadTrain, editTrain, remarkHtml } from "@/api/allApi";
  422. import { zanList, uploadZan } from "@/api/zanApi";
  423. import { handleTree } from '@/utils/index'
  424. export default {
  425. components: {
  426. Ipay
  427. },
  428. data() {
  429. return {
  430. currentPage: 1,
  431. remarkHtml: '',
  432. citeLogsList: [],
  433. trainLogsList: [],
  434. integralRules: '',
  435. typeList: [],
  436. activeName: 'first',
  437. fileUrl: this.baseUrl,
  438. dataList: [],
  439. dialogVisible: false,
  440. rules: {
  441. type: [{ required: true, message: "请选择证书类别", trigger: "blur" }],
  442. title: [{ required: true, message: "请填写证书名称", trigger: "blur" }],
  443. fileIds: [{ required: true, message: "请上传附件", trigger: "blur" }],
  444. },
  445. total: 0,
  446. listQuery: {
  447. page: 1,
  448. limit: 10,
  449. },
  450. dataForm: {
  451. type: [],
  452. title: '',
  453. fileIds: '',
  454. files: [],
  455. },
  456. typeListCite: [],
  457. recipientsList: [],
  458. dataListCite: [],
  459. dialogVisibleCite: false,
  460. rulesCite: {
  461. type: [{ required: true, message: "请选择表彰类型", trigger: "blur" }],
  462. groupIds: [{ required: true, message: "请选择集体人员", trigger: "blur" }],
  463. customerName: [{ required: true, message: "请填写客户名称", trigger: "blur" }],
  464. title: [{ required: true, message: "请填写表彰名称", trigger: "blur" }],
  465. fileIds: [{ required: true, message: "请上传附件", trigger: "blur" }],
  466. content: [{ required: true, message: '请填写表彰描述', trigger: 'blur' }],
  467. },
  468. totalCite: 0,
  469. listQueryCite: {
  470. page: 1,
  471. limit: 10,
  472. },
  473. dataFormCite: {
  474. type: '',
  475. groupIds: [],
  476. customerName: '',
  477. title: '',
  478. fileIds: '',
  479. files: [],
  480. content: ''
  481. },
  482. dataListTrain: [],
  483. dialogVisibleTrain: false,
  484. rulesTrain: {
  485. title: [{ required: true, message: "请填写培训主题", trigger: "blur" }],
  486. startTime: [
  487. { required: true, message: "请选开始时间", trigger: "change" },
  488. { validator: this.checkStartTime, trigger: 'change' }
  489. ],
  490. endTime: [
  491. { required: true, message: "请选择结束时间", trigger: "change" },
  492. { validator: this.checkEndTime, trigger: 'change' }
  493. ],
  494. lecturer: [{ required: true, message: "请选择培训讲师", trigger: "blur" }],
  495. traineeIds: [{ required: true, message: "请选择参加人员", trigger: "blur" }],
  496. materials: [{ required: true, message: "请上传培训材料", trigger: "blur" }],
  497. signPhotos: [{ required: true, message: "请上传签到表照片", trigger: "blur" }],
  498. sitePhotos: [{ required: true, message: "请上传现场照片", trigger: "blur" }],
  499. content: [
  500. { required: true, message: '请填写培训内容', trigger: 'blur' },
  501. { min: 50, max: 500, message: '培训内容的描述不得低于50字!', trigger: 'blur' }
  502. ],
  503. },
  504. totalTrain: 0,
  505. listQueryTrain: {
  506. page: 1,
  507. limit: 10,
  508. },
  509. dataFormTrain: {
  510. title: '',
  511. startTime: '',
  512. endTime: '',
  513. lecturer: '',
  514. traineeIds: [],
  515. materialFiles: [],
  516. materials: [],
  517. signPhotoFiles: [],
  518. signPhotos: [],
  519. sitePhotoFiles: [],
  520. sitePhotos: [],
  521. content: '',
  522. },
  523. // checkbox全选
  524. isIndeterminate: false,
  525. checkAll: false,
  526. mattersArr: [],
  527. typeListZan: [],
  528. dataListZan: [],
  529. dialogVisibleZan: false,
  530. rulesZan: {
  531. tiktokAccount: [{ required: true, message: "请填写抖音账号", trigger: "blur" }],
  532. matters: [{ required: true, message: "请选择事项", trigger: "blur" }],
  533. fileIds: [{ required: true, message: "请上传附件", trigger: "blur" }],
  534. },
  535. totalZan: 0,
  536. listQueryZan: {
  537. page: 1,
  538. limit: 10,
  539. },
  540. dataFormZan: {
  541. tiktokAccount: '',
  542. matters: [],
  543. fileIds: '',
  544. files: [],
  545. },
  546. dialogStatus: '',
  547. textMap: {
  548. create: "上传",
  549. edit: "修改",
  550. view: "详情",
  551. },
  552. };
  553. },
  554. created() {
  555. this.getTypeListCite();
  556. this.getAllUserList();
  557. this.getDataListCite();
  558. this.getTypeList();
  559. this.getDataList();
  560. this.getIntegralNotice();
  561. },
  562. methods: {
  563. changeChecked(val) {
  564. console.log(val, '勾选val')
  565. let checkedCount = val.length
  566. this.checkAll = checkedCount === this.mattersArr.length
  567. this.isIndeterminate = checkedCount > 0 && checkedCount < this.mattersArr.length
  568. },
  569. handleCheckAllChange(val) {
  570. console.log(val, '全选val')
  571. this.dataFormZan.matters = val ? this.mattersArr : []
  572. this.isIndeterminate = false
  573. },
  574. getRemarkHtml(val) {
  575. remarkHtml({ noticeType: val }).then(response => {
  576. console.log(response.data.data);
  577. this.remarkHtml = response.data.data.content
  578. })
  579. },
  580. handleClickViewZan(id) {
  581. this.isIndeterminate = false;
  582. this.checkAll = false;
  583. this.dialogVisibleZan = true;
  584. this.dataFormZan = {
  585. videoId: id,
  586. tiktokAccount: '',
  587. matters: [],
  588. fileIds: '',
  589. files: [],
  590. }
  591. },
  592. handleClickCreate(val) {
  593. this.dialogStatus = 'create';
  594. if (val == '上传表彰') {
  595. this.dialogVisibleCite = true;
  596. this.dataFormCite = {
  597. type: '',
  598. groupIds: [],
  599. customerName: '',
  600. title: '',
  601. fileIds: '',
  602. files: [],
  603. content: ''
  604. };
  605. } else {
  606. this.dialogVisibleTrain = true;
  607. this.dataFormTrain = {
  608. title: '',
  609. startTime: '',
  610. endTime: '',
  611. lecturer: '',
  612. traineeIds: [],
  613. materialFiles: [],
  614. materials: [],
  615. signPhotoFiles: [],
  616. signPhotos: [],
  617. sitePhotoFiles: [],
  618. sitePhotos: [],
  619. content: '',
  620. };
  621. }
  622. },
  623. handleClickViewCite(row, val) {
  624. this.citeLogsList = row.logs;
  625. if (row.groupUsers && row.groupUsers.length > 0) {
  626. let groupIds = [];
  627. for (let i in row.groupUsers) {
  628. groupIds.push(row.groupUsers[i].loginId);
  629. }
  630. row.groupIds = groupIds;
  631. }
  632. this.dataFormCite = Object.assign({}, row);
  633. if (row.files) {
  634. let files = row.files;
  635. this.dataFormCite.files = [];
  636. for (let i in files) {
  637. let url = files[i].url;
  638. let name = files[i].oldName;
  639. let id = files[i].id;
  640. this.dataFormCite.files.push({
  641. name: name,
  642. url: url,
  643. response: { error: "0", data: { url: url, id: id } },
  644. });
  645. }
  646. }
  647. this.dialogVisibleCite = true;
  648. this.dialogStatus = val;
  649. },
  650. handleClickView(row, val) {
  651. this.trainLogsList = row.trainLogs;
  652. if (row.trainees && row.trainees.length > 0) {
  653. let traineeIds = [];
  654. for (let i in row.trainees) {
  655. traineeIds.push(row.trainees[i].loginId);
  656. }
  657. row.traineeIds = traineeIds;
  658. }
  659. this.dataFormTrain = Object.assign({}, row);
  660. if (row.materialFiles) {
  661. let files = row.materialFiles;
  662. this.dataFormTrain.materialFiles = [];
  663. for (let i in files) {
  664. let url = files[i].url;
  665. let name = files[i].oldName;
  666. let id = files[i].id;
  667. this.dataFormTrain.materialFiles.push({
  668. name: name,
  669. url: url,
  670. response: { error: "0", data: { url: url, id: id } },
  671. });
  672. }
  673. }
  674. if (row.signPhotoFiles) {
  675. let files = row.signPhotoFiles;
  676. this.dataFormTrain.signPhotoFiles = [];
  677. for (let i in files) {
  678. let url = files[i].url;
  679. let name = files[i].oldName;
  680. let id = files[i].id;
  681. this.dataFormTrain.signPhotoFiles.push({
  682. name: name,
  683. url: url,
  684. response: { error: "0", data: { url: url, id: id } },
  685. });
  686. }
  687. }
  688. if (row.sitePhotoFiles) {
  689. let files = row.sitePhotoFiles;
  690. this.dataFormTrain.sitePhotoFiles = [];
  691. for (let i in files) {
  692. let url = files[i].url;
  693. let name = files[i].oldName;
  694. let id = files[i].id;
  695. this.dataFormTrain.sitePhotoFiles.push({
  696. name: name,
  697. url: url,
  698. response: { error: "0", data: { url: url, id: id } },
  699. });
  700. }
  701. }
  702. this.dialogVisibleTrain = true;
  703. this.dialogStatus = val;
  704. },
  705. //校验开始时间
  706. checkStartTime(rule, value, callback) {
  707. if (!value) {
  708. callback(new Error("请选择开始时间!"));
  709. } else {
  710. if (this.dataFormTrain.endTime && Date.parse(value) > Date.parse(this.dataFormTrain.endTime)) {
  711. callback(new Error("开始时间必须小于等于结束时间!"))
  712. this.dataFormTrain.startTime = '';
  713. } else {
  714. callback();
  715. }
  716. }
  717. },
  718. //校验结束时间
  719. checkEndTime(rule, value, callback) {
  720. if (!value) {
  721. callback(new Error("请选择结束时间!"));
  722. } else {
  723. if (!this.dataFormTrain.startTime) {
  724. callback(new Error("请选择开始时间!"))
  725. this.dataFormTrain.endTime = '';
  726. } else if (Date.parse(this.dataFormTrain.startTime) > Date.parse(value)) {
  727. callback(new Error("结束时间必须大于等于开始时间!"))
  728. this.dataFormTrain.endTime = '';
  729. } else {
  730. callback();
  731. }
  732. }
  733. },
  734. getTypeList() {
  735. certificatType().then(response => {
  736. this.typeList = handleTree(response.data.data);
  737. console.log(this.typeList);
  738. })
  739. },
  740. handleClick(tab, event) {
  741. console.log(tab.name, event);
  742. if (tab.name == 'fourth') {
  743. this.getRemarkHtml('trainrule');
  744. this.getDataListTrain();
  745. }
  746. if (tab.name == 'sixth') {
  747. this.getRemarkHtml('interactiveRule');
  748. this.getTypeListZan();
  749. this.getDataListZan()
  750. }
  751. },
  752. getIntegralNotice() {
  753. notice({ noticeType: 'certificatNotice' }).then(response => {
  754. this.integralRules = response.data.data.content;
  755. })
  756. },
  757. handleChange(value) {
  758. console.log(value);
  759. },
  760. handleRemove(file, fileList) {
  761. console.log(file, fileList);
  762. let fileIds = [];
  763. for (let i in fileList) {
  764. let id = fileList[i].response.data.id;
  765. fileIds.push(id);
  766. }
  767. this.dataForm.fileIds = fileIds.join(",");
  768. },
  769. beforeUploadFile(file) {
  770. console.log(file);
  771. const size = file.size / 1024 / 1024;
  772. console.log(size);
  773. if (size > 10) {
  774. this.$message.error("文件大小不能超过10MB!");
  775. return false;
  776. }
  777. },
  778. handleAvatarSuccess(res, file, fileList) {
  779. console.log(file, fileList);
  780. console.log("------", "==========");
  781. console.log("res = ", res);
  782. let fileIds = [];
  783. for (let i in fileList) {
  784. let response = fileList[i].response;
  785. if (response.errno && response.errno != "0") {
  786. this.$message.error("该文件上传失败,已被移除,请重新上传!");
  787. // 上传失败移除该 file 对象
  788. fileList.splice(i, 1);
  789. } else {
  790. let id = fileList[i].response.data.id;
  791. fileIds.push(id);
  792. }
  793. }
  794. this.dataForm.fileIds = fileIds.join(",");
  795. },
  796. resetForm() {
  797. this.$refs['dataForm'].resetFields();
  798. },
  799. submitForm() {
  800. this.$refs['dataForm'].validate((valid) => {
  801. if (valid) {
  802. certificateUpload(this.dataForm)
  803. .then((response) => {
  804. this.dialogVisible = false;
  805. this.$notify({
  806. title: "成功",
  807. message: "证书上传成功",
  808. type: "success",
  809. duration: 2000,
  810. });
  811. this.dataForm.type = [];
  812. this.dataForm.fileIds = '';
  813. this.dataForm.files = [];
  814. this.listQuery.page = 1;
  815. this.getDataList();
  816. })
  817. .catch(() => { });
  818. } else {
  819. return false;
  820. }
  821. });
  822. },
  823. getDataList() {
  824. certificatePage(this.listQuery).then(response => {
  825. this.dataList = response.data.data.items;
  826. this.total = response.data.data.total;
  827. })
  828. },
  829. handleSizeChange(val) {
  830. this.listQuery.limit = val
  831. this.getDataList()
  832. },
  833. handleCurrentChange(val) {
  834. this.listQuery.page = val
  835. this.getDataList()
  836. },
  837. getTypeListCite() {
  838. dictList({ dictType: 'customer_treward_type' }).then(response => {
  839. this.typeListCite = response.data.data;
  840. })
  841. },
  842. getTypeListZan() {
  843. dictList({ dictType: 'matter' }).then(response => {
  844. let dataList = response.data.data;
  845. this.typeListZan = dataList;
  846. // 勾选的数组绑定的是数组中的item.dictValue
  847. let dictValueArr = []
  848. dataList.forEach(item => {
  849. dictValueArr.push(item.dictValue)
  850. })
  851. this.mattersArr = dictValueArr
  852. })
  853. },
  854. getAllUserList() {
  855. allUserList().then(response => {
  856. this.recipientsList = response.data.data;
  857. }).catch(() => { });
  858. },
  859. handleRemoveCite(file, fileList) {
  860. console.log(file, fileList);
  861. let fileIds = [];
  862. for (let i in fileList) {
  863. let id = fileList[i].response.data.id;
  864. fileIds.push(id);
  865. }
  866. this.dataFormCite.fileIds = fileIds.join(",");
  867. },
  868. beforeUploadFileCite(file) {
  869. console.log(file);
  870. const size = file.size / 1024 / 1024;
  871. console.log(size);
  872. if (size > 10) {
  873. this.$message.error("文件大小不能超过10MB!");
  874. return false;
  875. }
  876. },
  877. handleAvatarSuccessCite(res, file, fileList) {
  878. console.log(file, fileList);
  879. console.log("------", "==========");
  880. console.log("res = ", res);
  881. let fileIds = [];
  882. for (let i in fileList) {
  883. let response = fileList[i].response;
  884. if (response.errno && response.errno != "0") {
  885. this.$message.error("该文件上传失败,已被移除,请重新上传!");
  886. // 上传失败移除该 file 对象
  887. fileList.splice(i, 1);
  888. } else {
  889. let id = fileList[i].response.data.id;
  890. fileIds.push(id);
  891. }
  892. }
  893. this.dataFormCite.fileIds = fileIds.join(",");
  894. },
  895. submitFormCite() {
  896. this.$refs['dataFormCite'].validate((valid) => {
  897. if (valid) {
  898. if (this.dialogStatus == 'create') {
  899. uploadCite(this.dataFormCite)
  900. .then((response) => {
  901. this.dialogVisibleCite = false;
  902. this.$notify({
  903. title: "成功",
  904. message: "表彰上传成功",
  905. type: "success",
  906. duration: 2000,
  907. });
  908. this.dataFormCite.type = [];
  909. this.dataFormCite.fileIds = '';
  910. this.dataFormCite.files = [];
  911. this.listQueryCite.page = 1;
  912. this.getDataListCite();
  913. })
  914. .catch(() => { });
  915. }
  916. if (this.dialogStatus == 'edit') {
  917. editCite(this.dataFormCite)
  918. .then((response) => {
  919. this.dialogVisibleCite = false;
  920. this.$notify({
  921. title: "成功",
  922. message: "表彰修改成功",
  923. type: "success",
  924. duration: 2000,
  925. });
  926. this.dataFormCite.type = [];
  927. this.dataFormCite.fileIds = '';
  928. this.dataFormCite.files = [];
  929. this.listQueryCite.page = 1;
  930. this.getDataListCite();
  931. })
  932. .catch(() => { });
  933. }
  934. } else {
  935. return false;
  936. }
  937. });
  938. },
  939. getDataListCite() {
  940. citeList(this.listQueryCite).then(response => {
  941. this.dataListCite = response.data.data.items;
  942. this.totalCite = response.data.data.total;
  943. })
  944. },
  945. handleSizeChangeCite(val) {
  946. this.listQueryCite.limit = val
  947. this.getDataListCite()
  948. },
  949. handleCurrentChangeCite(val) {
  950. this.listQueryCite.page = val
  951. this.getDataListCite()
  952. },
  953. handleRemoveTrain(file, fileList) {
  954. console.log(file, fileList);
  955. let fileIds = [];
  956. for (let i in fileList) {
  957. let id = fileList[i].response.data.id;
  958. fileIds.push(id);
  959. }
  960. this.dataFormTrain.materials = fileIds.join(",");
  961. },
  962. handleRemoveTrain1(file, fileList) {
  963. console.log(file, fileList);
  964. let fileIds = [];
  965. for (let i in fileList) {
  966. let id = fileList[i].response.data.id;
  967. fileIds.push(id);
  968. }
  969. this.dataFormTrain.signPhotos = fileIds.join(",");
  970. },
  971. handleRemoveTrain2(file, fileList) {
  972. console.log(file, fileList);
  973. let fileIds = [];
  974. for (let i in fileList) {
  975. let id = fileList[i].response.data.id;
  976. fileIds.push(id);
  977. }
  978. this.dataFormTrain.sitePhotos = fileIds.join(",");
  979. },
  980. beforeUploadFileTrain(file) {
  981. console.log(file);
  982. const size = file.size / 1024 / 1024;
  983. console.log(size);
  984. if (size > 10) {
  985. this.$message.error("文件大小不能超过10MB!");
  986. return false;
  987. }
  988. },
  989. handleAvatarSuccessTrain(res, file, fileList) {
  990. console.log(file, fileList);
  991. console.log("------", "==========");
  992. console.log("res = ", res);
  993. let fileIds = [];
  994. for (let i in fileList) {
  995. let response = fileList[i].response;
  996. if (response.errno && response.errno != "0") {
  997. this.$message.error("该文件上传失败,已被移除,请重新上传!");
  998. // 上传失败移除该 file 对象
  999. fileList.splice(i, 1);
  1000. } else {
  1001. let id = fileList[i].response.data.id;
  1002. fileIds.push(id);
  1003. }
  1004. }
  1005. this.dataFormTrain.materials = fileIds.join(",");
  1006. },
  1007. handleAvatarSuccessTrain1(res, file, fileList) {
  1008. console.log(file, fileList);
  1009. console.log("------", "==========");
  1010. console.log("res = ", res);
  1011. let fileIds = [];
  1012. for (let i in fileList) {
  1013. let response = fileList[i].response;
  1014. if (response.errno && response.errno != "0") {
  1015. this.$message.error("该文件上传失败,已被移除,请重新上传!");
  1016. // 上传失败移除该 file 对象
  1017. fileList.splice(i, 1);
  1018. } else {
  1019. let id = fileList[i].response.data.id;
  1020. fileIds.push(id);
  1021. }
  1022. }
  1023. this.dataFormTrain.signPhotos = fileIds.join(",");
  1024. },
  1025. handleAvatarSuccessTrain2(res, file, fileList) {
  1026. console.log(file, fileList);
  1027. console.log("------", "==========");
  1028. console.log("res = ", res);
  1029. let fileIds = [];
  1030. for (let i in fileList) {
  1031. let response = fileList[i].response;
  1032. if (response.errno && response.errno != "0") {
  1033. this.$message.error("该文件上传失败,已被移除,请重新上传!");
  1034. // 上传失败移除该 file 对象
  1035. fileList.splice(i, 1);
  1036. } else {
  1037. let id = fileList[i].response.data.id;
  1038. fileIds.push(id);
  1039. }
  1040. }
  1041. this.dataFormTrain.sitePhotos = fileIds.join(",");
  1042. },
  1043. submitFormTrain() {
  1044. this.$refs['dataFormTrain'].validate((valid) => {
  1045. if (valid) {
  1046. if (this.dialogStatus == 'create') {
  1047. uploadTrain(this.dataFormTrain)
  1048. .then((response) => {
  1049. this.dialogVisibleTrain = false;
  1050. this.$notify({
  1051. title: "成功",
  1052. message: "培训上传成功",
  1053. type: "success",
  1054. duration: 2000,
  1055. });
  1056. this.listQueryTrain.page = 1;
  1057. this.getDataListTrain();
  1058. })
  1059. .catch(() => { });
  1060. }
  1061. if (this.dialogStatus == 'edit') {
  1062. editTrain(this.dataFormTrain)
  1063. .then((response) => {
  1064. this.dialogVisibleTrain = false;
  1065. this.$notify({
  1066. title: "成功",
  1067. message: "培训修改成功",
  1068. type: "success",
  1069. duration: 2000,
  1070. });
  1071. this.listQueryTrain.page = 1;
  1072. this.getDataListTrain();
  1073. })
  1074. .catch(() => { });
  1075. }
  1076. } else {
  1077. return false;
  1078. }
  1079. });
  1080. },
  1081. getDataListTrain() {
  1082. trainList(this.listQueryCite).then(response => {
  1083. this.dataListTrain = response.data.data.items;
  1084. this.totalTrain = response.data.data.total;
  1085. })
  1086. },
  1087. handleSizeChangeTrain(val) {
  1088. this.listQueryTrain.limit = val
  1089. this.getDataListTrain()
  1090. },
  1091. handleCurrentChangeTrain(val) {
  1092. this.listQueryTrain.page = val
  1093. this.getDataListTrain()
  1094. },
  1095. handleRemoveZan(file, fileList) {
  1096. console.log(file, fileList);
  1097. let fileIds = [];
  1098. for (let i in fileList) {
  1099. let id = fileList[i].response.data.id;
  1100. fileIds.push(id);
  1101. }
  1102. this.dataFormZan.fileIds = fileIds.join(",");
  1103. },
  1104. beforeUploadFileZan(file) {
  1105. console.log(file);
  1106. const size = file.size / 1024 / 1024;
  1107. console.log(size);
  1108. if (size > 10) {
  1109. this.$message.error("文件大小不能超过10MB!");
  1110. return false;
  1111. }
  1112. },
  1113. handleAvatarSuccessZan(res, file, fileList) {
  1114. console.log(file, fileList);
  1115. console.log("------", "==========");
  1116. console.log("res = ", res);
  1117. let fileIds = [];
  1118. for (let i in fileList) {
  1119. let response = fileList[i].response;
  1120. if (response.errno && response.errno != "0") {
  1121. this.$message.error("该文件上传失败,已被移除,请重新上传!");
  1122. // 上传失败移除该 file 对象
  1123. fileList.splice(i, 1);
  1124. } else {
  1125. let id = fileList[i].response.data.id;
  1126. fileIds.push(id);
  1127. }
  1128. }
  1129. this.dataFormZan.fileIds = fileIds.join(",");
  1130. },
  1131. submitFormZan() {
  1132. this.$refs['dataFormZan'].validate((valid) => {
  1133. if (valid) {
  1134. this.dataFormZan.matters = this.dataFormZan.matters.join(",");
  1135. uploadZan(this.dataFormZan)
  1136. .then((response) => {
  1137. this.dialogVisibleZan = false;
  1138. this.$notify({
  1139. title: "成功",
  1140. message: "上传成功",
  1141. type: "success",
  1142. duration: 2000,
  1143. });
  1144. this.dataFormZan.tiktokAccount = '';
  1145. this.dataFormZan.matters = [];
  1146. this.dataFormZan.fileIds = '';
  1147. this.dataFormZan.files = [];
  1148. this.listQueryZan.page = 1;
  1149. this.getDataListZan();
  1150. })
  1151. .catch(() => { });
  1152. } else {
  1153. return false;
  1154. }
  1155. });
  1156. },
  1157. getDataListZan() {
  1158. zanList(this.listQueryZan).then(response => {
  1159. this.dataListZan = response.data.data.items;
  1160. this.totalZan = response.data.data.total;
  1161. })
  1162. },
  1163. handleSizeChangeZan(val) {
  1164. this.listQueryZan.limit = val
  1165. this.getDataListZan()
  1166. },
  1167. handleCurrentChangeZan(val) {
  1168. this.listQueryZan.page = val
  1169. this.getDataListZan()
  1170. },
  1171. },
  1172. };
  1173. </script>
  1174. <style scoped>
  1175. .text-overflow {
  1176. max-width: 400px;
  1177. overflow: hidden;
  1178. text-overflow: ellipsis;
  1179. display: -webkit-box;
  1180. -webkit-box-orient: vertical;
  1181. -webkit-line-clamp: 1;
  1182. }
  1183. .right-wrap {
  1184. width: 100%;
  1185. }
  1186. .myPage {
  1187. margin-top: 30px;
  1188. display: flex;
  1189. justify-content: center;
  1190. align-items: center;
  1191. }
  1192. .gainList_container {
  1193. min-height: 560px;
  1194. }
  1195. .gainList_container .gains_wrapper {
  1196. position: relative;
  1197. box-sizing: border-box;
  1198. padding-top: 20px;
  1199. padding-left: 20px;
  1200. }
  1201. .gainList_container .gains_wrapper .list {
  1202. display: flex;
  1203. flex-wrap: wrap;
  1204. margin: -20px 0 0 -20px;
  1205. }
  1206. .item.isVirtual {
  1207. background: #f7f8fa;
  1208. border: 1px solid #e5e6eb;
  1209. }
  1210. .item {
  1211. display: flex;
  1212. align-items: center;
  1213. flex: 0 1 auto;
  1214. width: calc(50% - 30px);
  1215. min-width: 410px;
  1216. height: 116px;
  1217. padding-right: 6px;
  1218. background: #fff;
  1219. border: 1px solid #e5e6eb;
  1220. box-sizing: border-box;
  1221. border-radius: 4px;
  1222. margin-right: 20px;
  1223. margin-top: 20px;
  1224. }
  1225. .item .img-wapper {
  1226. width: 114px;
  1227. height: 114px;
  1228. margin-right: 16px;
  1229. background: #f7f8fa;
  1230. display: flex;
  1231. align-items: center;
  1232. justify-content: center;
  1233. }
  1234. .item .img-wapper .item-icon {
  1235. max-width: 72px;
  1236. max-height: 72px;
  1237. }
  1238. .item .main {
  1239. flex: auto;
  1240. }
  1241. .item .date,
  1242. .item .goods_name {
  1243. overflow: hidden;
  1244. text-overflow: ellipsis;
  1245. }
  1246. .item .goods_name {
  1247. display: -webkit-box;
  1248. -webkit-box-orient: vertical;
  1249. -webkit-line-clamp: 1;
  1250. font-size: 16px;
  1251. line-height: 24px;
  1252. color: #252933;
  1253. padding-bottom: 4px;
  1254. }
  1255. .item p {
  1256. margin: 0;
  1257. }
  1258. .item .date {
  1259. white-space: nowrap;
  1260. font-size: 14px;
  1261. line-height: 22px;
  1262. color: #8a919f;
  1263. }
  1264. .item .buttons {
  1265. margin-top: 8px;
  1266. margin-left: -8px;
  1267. display: flex;
  1268. align-items: center;
  1269. }
  1270. .item .button-item.actived {
  1271. background: #f2f3f5;
  1272. color: #8a919f;
  1273. }
  1274. .item .button-item {
  1275. cursor: pointer;
  1276. display: flex;
  1277. align-items: center;
  1278. font-size: 13px;
  1279. padding: 0 8px;
  1280. height: 26px;
  1281. margin-left: 8px;
  1282. font-weight: 500;
  1283. background: #f2f3f5;
  1284. border-radius: 50px;
  1285. color: #8a919f;
  1286. white-space: nowrap;
  1287. border: none;
  1288. }
  1289. .item .arrow {
  1290. width: 12px;
  1291. height: 12px;
  1292. margin-left: 2px;
  1293. transform: rotate(-90deg);
  1294. }
  1295. svg:not(:root) {
  1296. overflow: hidden;
  1297. }
  1298. .item .button-item svg path {
  1299. fill: currentColor;
  1300. }
  1301. .status {
  1302. margin-right: 30px;
  1303. font-size: 13px;
  1304. }
  1305. .status.bottom {
  1306. margin-top: 55px;
  1307. }
  1308. .status .use-btn {
  1309. color: #1e80ff;
  1310. }
  1311. .timeline-container {
  1312. margin: 0 auto;
  1313. }
  1314. .timeline-entry-list {
  1315. margin-right: 17.5rem;
  1316. border-radius: 2px;
  1317. width: 720px;
  1318. position: relative;
  1319. }
  1320. .entry-list-container {
  1321. background-color: #fff;
  1322. border-radius: 4px;
  1323. min-height: 500px;
  1324. }
  1325. .entry-list-container .tab-header {
  1326. display: flex;
  1327. align-items: center;
  1328. justify-content: space-between;
  1329. padding: 20px 20px 16px;
  1330. border-bottom: 1px solid #e5e6eb;
  1331. overflow: hidden;
  1332. }
  1333. .tab-header .tab-title {
  1334. white-space: nowrap;
  1335. font-size: 18px;
  1336. font-weight: 600;
  1337. }
  1338. .content-body {
  1339. padding: 10px 20px 16px;
  1340. }
  1341. .serie {
  1342. margin: 0 0 40px;
  1343. }
  1344. .serie .serie-title {
  1345. height: 32px;
  1346. width: 100%;
  1347. display: flex;
  1348. justify-content: center;
  1349. align-items: center;
  1350. text-align: center;
  1351. margin-bottom: 20px;
  1352. }
  1353. .serie .serie-title .title {
  1354. font-style: normal;
  1355. font-weight: 600;
  1356. font-size: 20px;
  1357. color: #1d2129;
  1358. margin: 0 16px;
  1359. }
  1360. .serie .serie-title .series-left,
  1361. .serie .serie-title .series-right {
  1362. width: 16px;
  1363. height: 2px;
  1364. }
  1365. img {
  1366. border-style: none;
  1367. }
  1368. .serie .badge-icon-list {
  1369. display: grid;
  1370. justify-content: space-between;
  1371. grid-template-columns: repeat(auto-fill, 150px);
  1372. grid-gap: 10px 20px;
  1373. flex-wrap: wrap;
  1374. }
  1375. .serie .badge-icon-list .badge-icon-item {
  1376. -webkit-tap-highlight-color: transparent;
  1377. cursor: pointer;
  1378. width: 150px;
  1379. font-style: normal;
  1380. font-weight: 400;
  1381. display: flex;
  1382. flex-direction: column;
  1383. justify-content: center;
  1384. align-items: center;
  1385. }
  1386. .serie .badge-icon-list .badge-icon-item .badge-item-icon {
  1387. width: 65px;
  1388. height: 65px;
  1389. }
  1390. .serie .badge-icon-list .badge-icon-item .badge-item-icon .not-obtain {
  1391. filter: grayscale(100%);
  1392. }
  1393. .serie .badge-icon-list .badge-icon-item .badge-item-icon img {
  1394. width: 100%;
  1395. height: 100%;
  1396. }
  1397. .serie .badge-icon-list .badge-icon-item .badge-desc {
  1398. /* margin-top: -10px; */
  1399. text-align: center;
  1400. color: #1d2129;
  1401. font-size: 16px;
  1402. line-height: 28px;
  1403. }
  1404. .serie .badge-icon-list .badge-icon-item .obtain-date {
  1405. font-size: 14px;
  1406. text-align: center;
  1407. color: #86909c;
  1408. height: 24px;
  1409. line-height: 24px;
  1410. }
  1411. </style>