createArticle.vue 18KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494
  1. <template>
  2. <div class="main-contain">
  3. <div class="position">
  4. <bread-crumb :crumbs='crumbs'></bread-crumb>
  5. </div>
  6. <div>
  7. <div class="app-container">
  8. <el-tabs type="border-card">
  9. <el-tab-pane label="文章">
  10. <el-form label-width="80px" class="clearfix" :model="form" ref="form" :element-loading-text="loadingText">
  11. <el-row>
  12. <el-col :span="23">
  13. <el-form-item label="文章标题:">
  14. <el-input v-model="form.act_name" placeholder="文章标题"></el-input>
  15. </el-form-item>
  16. <el-form-item label="文章内容:">
  17. <keep-alive>
  18. <neditor ref="neditor"
  19. id="editor"
  20. v-bind:r_content="form.act_content">
  21. </neditor>
  22. </keep-alive>
  23. </el-form-item>
  24. <el-form-item label="封面图片:">
  25. <el-radio v-model="radio" label="1" @click.native.prevent="select()" >单图</el-radio>
  26. <el-radio v-model="radio" label="2" @click.native.prevent="clickitem()" >三图</el-radio>
  27. </el-form-item>
  28. <el-form-item prop="org_log">
  29. <el-col :span="3">
  30. <div>
  31. <el-upload
  32. v-loading="uploading"
  33. :element-loading-text="loadingText"
  34. class="avatar-uploader"
  35. :data="uploadData"
  36. action="https://upload.qiniup.com"
  37. :show-file-list="false"
  38. :on-error="handleAvatarError"
  39. :on-success="handleAvatarSuccess"
  40. :before-upload="beforeAvatarUpload">
  41. <img v-if="imageUrl" :src="imageUrl" class="avatar">
  42. <i v-else class="el-icon-plus avatar-uploader-icon"></i>
  43. </el-upload>
  44. </div>
  45. </el-col>
  46. <el-col :span="3">
  47. <div v-if="show">
  48. <el-upload
  49. v-loading="guploading"
  50. :element-loading-text="loadingText"
  51. class="avatar-uploader"
  52. :data="uploadData"
  53. action="https://upload.qiniup.com"
  54. :show-file-list="false"
  55. :on-error="handleAvatartwoError"
  56. :on-success="handleAvatartwoSuccess"
  57. :before-upload="beforeAvatartwoUpload">
  58. <img v-if="imageUrlSecond" :src="imageUrlSecond" class="avatar">
  59. <i v-else class="el-icon-plus avatar-uploader-icon"></i>
  60. </el-upload>
  61. </div>
  62. </el-col>
  63. <el-col :span="3">
  64. <div v-if="show">
  65. <el-upload
  66. v-loading="uploading"
  67. :element-loading-text="loadingText"
  68. class="avatar-uploader"
  69. :data="uploadData"
  70. action="https://upload.qiniup.com"
  71. :show-file-list="false"
  72. :on-error="handleAvatarlastError"
  73. :on-success="handleAvatarlastSuccess"
  74. :before-upload="beforeAvatarlastUpload">
  75. <img v-if="imageUrlLast" :src="imageUrlLast" class="avatar">
  76. <i v-else class="el-icon-plus avatar-uploader-icon"></i>
  77. </el-upload>
  78. </div>
  79. </el-col>
  80. </el-form-item>
  81. <el-form-item label="所属分类:">
  82. <el-select v-model="value" placeholder="请先选择文章所属分类" prop="act_type">
  83. <el-option
  84. v-for="item in options"
  85. :key="item.id"
  86. :label="item.Name"
  87. :value="item.id">
  88. </el-option>
  89. </el-select>
  90. </el-form-item>
  91. </el-col>
  92. </el-row>
  93. <el-row :span="24">
  94. <el-col :span="24">
  95. <el-form-item>
  96. <el-button size="small" type="primary" style="width: 100px" @click="submitForm" :disabled="formsubmit">发布</el-button>
  97. <el-button size="small" style="width: 100px">预览</el-button>
  98. <el-button size="small" style="width: 100px">保存草稿</el-button>
  99. <el-button size="small" style="width: 100px">取消</el-button>
  100. </el-form-item>
  101. </el-col>
  102. </el-row>
  103. </el-form>
  104. </el-tab-pane>
  105. <el-tab-pane label="视频">
  106. <el-form label-width="80px" class="clearfix">
  107. <el-row>
  108. <el-col :span="24">
  109. <div style="margin-bottom: 100px">
  110. <el-form-item>
  111. <div class="video-select">
  112. <el-upload
  113. class="upload-demo"
  114. action="https://upload.qiniup.com"
  115. :on-preview="handlePreview"
  116. :on-remove="handleRemove"
  117. :before-remove="beforeRemove"
  118. multiple
  119. :limit="3"
  120. :on-exceed="handleExceed"
  121. :file-list="fileList"
  122. :before-upload="beforeUpload">
  123. <el-button size="small" type="primary">点击上传</el-button>
  124. <div slot="tip" class="el-upload__tip">只能上传jpg/exe文件,且不超过2G</div>
  125. </el-upload>
  126. </div>
  127. <div class="progressbar probar" style="text-align: center">
  128. <span class="videotitle"></span>
  129. <input type="hidden" name="videoUrl" id="videopath">
  130. <div class="barpic"></div>
  131. <span class="chaimg"></span>
  132. <span class="videoupload"></span>
  133. </div>
  134. </el-form-item>
  135. </div>
  136. <el-form-item label="视频标题:">
  137. <el-input placeholder="视频标题"></el-input>
  138. </el-form-item>
  139. <el-form-item label="视频封面:"></el-form-item>
  140. <el-form-item>
  141. <el-upload class="avatar-uploader" :show-file-list="false" :on-success="handleAvatarSuccess" :before-upload="beforeAvatarUpload">
  142. <img v-if="imageUrl" :src="imageUrl" class="avatar">
  143. <i v-else class="el-icon-plus avatar-uploader-icon"></i>
  144. </el-upload>
  145. </el-form-item>
  146. <el-form-item label="所属分类:">
  147. <el-select v-model="form.act_type" placeholder="请选择">
  148. <el-option
  149. v-for="item in options"
  150. :key="item.value"
  151. :label="item.label"
  152. :value="item.value">
  153. </el-option>
  154. </el-select>
  155. </el-form-item>
  156. <el-row :span="24">
  157. <el-col :span="24">
  158. <el-form-item>
  159. <el-button size="small" type="primary" style="width: 100px">发布</el-button>
  160. <el-button size="small" style="width: 100px">保存草稿</el-button>
  161. <el-button size="small" style="width: 100px">取消</el-button>
  162. </el-form-item>
  163. </el-col>
  164. </el-row>
  165. </el-col>
  166. </el-row>
  167. </el-form>
  168. </el-tab-pane>
  169. </el-tabs>
  170. </div>
  171. </div>
  172. </div>
  173. </template>
  174. <script>
  175. import BreadCrumb from '../components/bread-crumb'
  176. import { quillEditor } from 'vue-quill-editor'
  177. import 'quill/dist/quill.core.css'
  178. import 'quill/dist/quill.snow.css'
  179. import 'quill/dist/quill.bubble.css'
  180. import Neditor from '@/components/Neditor'
  181. import {submitForm,getArticleType} from '@/api/act/submitinfo'
  182. import { getToken } from '@/api/qiniu'
  183. import { getFileExtension} from '@/utils/tools'
  184. export default {
  185. name: 'createArticle',
  186. components:{
  187. BreadCrumb,
  188. Neditor,
  189. },
  190. data(){
  191. return {
  192. crumbs: [
  193. { path: false, name: '文章管理' },
  194. { path: '/articles/createArticle', name: '发布文章' }
  195. ],
  196. radio:'1',
  197. options: [],
  198. value: '',
  199. show:false,
  200. content: '',
  201. editorOption: {},
  202. uploadUrl:"",//你要上传视频到你后台的地址
  203. videoFlag:false , //是否显示进度条
  204. videoUploadPercent:"", //进度条的进度,
  205. isShowUploadVideo:false, //显示上传按钮
  206. company:"",
  207. fileList: [{name: '123', url: 'https://fuss10.elemecdn.com/3/63/4e7f3a15429bfda99bce42a18cdd1jpeg.jpeg?imageMogr2/thumbnail/360x360/format/webp/quality/100'}],
  208. form:{
  209. act_name:'',
  210. act_content:'',
  211. act_picture:'',
  212. act_category:'',
  213. org_logo:'',
  214. act_type:'',
  215. },
  216. acttypes:[],
  217. imageUrl:'',
  218. imageUrlSecond:'',
  219. imageUrlLast:'',
  220. formloading:false,
  221. formsubmit:false,
  222. qiniuDomain: 'https://images.shengws.com/',
  223. uploading:false,
  224. loadingText:'',
  225. uploadData: { token: '', key: '' },
  226. myConfig: {
  227. // 如果需要上传功能,找后端小伙伴要服务器接口地址
  228. serverUrl: '/api/web/upload/ueditor',
  229. // 你的UEditor资源存放的路径,相对于打包后的index.html
  230. UEDITOR_HOME_URL: '/NEditor/',
  231. // 编辑器不自动被内容撑高
  232. autoHeightEnabled: false,
  233. // 初始容器高度
  234. initialFrameHeight: 240,
  235. // 初始容器宽度
  236. initialFrameWidth: '100%',
  237. // 关闭自动保存
  238. enableAutoSave: false
  239. },
  240. }
  241. },
  242. created(){
  243. this.getArticleType()
  244. },
  245. methods: {
  246. //第一个图片
  247. handleAvatarSuccess(res, file) {
  248. this.imageUrl = URL.createObjectURL(file.raw);
  249. this.form.org_logo = this.qiniuDomain + res.url;
  250. this.uploading = false
  251. },
  252. handleAvatarError(err, file, fileList) {
  253. this.$message.error(err);
  254. this.uploading = false;
  255. return false
  256. },
  257. beforeAvatarUpload(file) {
  258. const isJPG = file.type === 'image/jpeg';
  259. const isLt2M = file.size / 1024 / 1024 < 2;
  260. if (!isJPG) {
  261. this.$message.error('上传头像图片只能是 JPG 格式!');
  262. }
  263. if (!isLt2M) {
  264. this.$message.error('上传头像图片大小不能超过 2MB!');
  265. }
  266. var date = new Date()
  267. var ext = getFileExtension(file.name)
  268. var key = date.getFullYear() + (date.getMonth() + 1) + date.getDate() + date.getHours() + date.getMinutes() + date.getSeconds() +'_o_' + file.uid + '.' + ext;
  269. this.uploading = true;
  270. this.loadingText = '封面图片上传中'
  271. const _self = this
  272. return new Promise((resolve, reject) => {
  273. getToken().then(response => {
  274. const token = response.data.data.uptoken
  275. console.log("token是什么?",token)
  276. _self._data.uploadData.token = token
  277. _self._data.uploadData.key = key
  278. resolve(true)
  279. }).catch(err => {
  280. reject(false)
  281. this.uploading = false;
  282. })
  283. })
  284. //return isJPG && isLt2M;
  285. },
  286. //第二个图片
  287. handleAvatartwoSuccess(res, file) {
  288. this.imageUrlSecond = URL.createObjectURL(file.raw);
  289. this.form.org_logo = this.qiniuDomain + res.url;
  290. this.uploading = false
  291. },
  292. handleAvatartwoError(err, file, fileList) {
  293. this.$message.error(err);
  294. this.uploading = false;
  295. return false
  296. },
  297. beforeAvatartwoUpload(file) {
  298. const isJPG = file.type === 'image/jpeg';
  299. const isLt2M = file.size / 1024 / 1024 < 2;
  300. if (!isJPG) {
  301. this.$message.error('上传头像图片只能是 JPG 格式!');
  302. }
  303. if (!isLt2M) {
  304. this.$message.error('上传头像图片大小不能超过 2MB!');
  305. }
  306. var date = new Date()
  307. var ext = getFileExtension(file.name)
  308. var key = date.getFullYear() + (date.getMonth() + 1) + date.getDate() + date.getHours() + date.getMinutes() + date.getSeconds() +'_o_' + file.uid + '.' + ext;
  309. this.uploading = true;
  310. this.loadingText = '封面图片上传中'
  311. const _self = this
  312. return new Promise((resolve, reject) => {
  313. getToken().then(response => {
  314. const token = response.data.data.uptoken
  315. console.log("token是什么?",token)
  316. _self._data.uploadData.token = token
  317. _self._data.uploadData.key = key
  318. resolve(true)
  319. }).catch(err => {
  320. reject(false)
  321. this.uploading = false;
  322. })
  323. })
  324. //return isJPG && isLt2M;
  325. },
  326. //第三张图片
  327. //第二个图片
  328. handleAvatarlastSuccess(res, file) {
  329. this.imageUrlLast = URL.createObjectURL(file.raw);
  330. this.form.org_logo = this.qiniuDomain + res.url;
  331. this.uploading = false
  332. },
  333. handleAvatarlastError(err, file, fileList) {
  334. this.$message.error(err);
  335. this.uploading = false;
  336. return false
  337. },
  338. beforeAvatarlastUpload(file) {
  339. const isJPG = file.type === 'image/jpeg';
  340. const isLt2M = file.size / 1024 / 1024 < 2;
  341. if (!isJPG) {
  342. this.$message.error('上传头像图片只能是 JPG 格式!');
  343. }
  344. if (!isLt2M) {
  345. this.$message.error('上传头像图片大小不能超过 2MB!');
  346. }
  347. var date = new Date()
  348. var ext = getFileExtension(file.name)
  349. var key = date.getFullYear() + (date.getMonth() + 1) + date.getDate() + date.getHours() + date.getMinutes() + date.getSeconds() +'_o_' + file.uid + '.' + ext;
  350. this.uploading = true;
  351. this.loadingText = '封面图片上传中'
  352. const _self = this
  353. return new Promise((resolve, reject) => {
  354. getToken().then(response => {
  355. const token = response.data.data.uptoken
  356. console.log("token是什么?",token)
  357. _self._data.uploadData.token = token
  358. _self._data.uploadData.key = key
  359. resolve(true)
  360. }).catch(err => {
  361. reject(false)
  362. this.uploading = false;
  363. })
  364. })
  365. //return isJPG && isLt2M;
  366. },
  367. beforeUpload(file) {
  368. var testmsg=file.name.substring(file.name.lastIndexOf('.')+1)
  369. const extension = testmsg === 'mp4'
  370. const extension2 = testmsg === 'exe'
  371. const isLt2M = file.size / 1024 / 1024 < 2048 //这里做文件大小限制
  372. if(!extension && !extension2) {
  373. this.$message({
  374. message: '上传文件只能是 mp4、exe格式!',
  375. type: 'warning'
  376. });
  377. }
  378. if(!isLt2M) {
  379. this.$message({
  380. message: '上传文件大小不能超过 2G!',
  381. type: 'warning'
  382. });
  383. }
  384. return extension || extension2 && isLt2M
  385. },
  386. select(){
  387. this.show = false
  388. },
  389. clickitem(){
  390. this.show = true
  391. },
  392. handleRemove(file, fileList) {
  393. console.log(file, fileList);
  394. },
  395. handlePreview(file) {
  396. console.log(file);
  397. },
  398. handleExceed(files, fileList) {
  399. this.$message.warning(`当前限制选择 3 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`);
  400. },
  401. beforeRemove(file, fileList) {
  402. return this.$confirm(`确定移除 ${ file.name }?`);
  403. },
  404. submitForm(){
  405. var params = new Object()
  406. params.act_name = this.form.act_name
  407. params.act_content = this.$refs.neditor.content
  408. params.org_logo = this.form.org_logo
  409. this.formloading=true
  410. this.submitForm =true
  411. console.log("文章标题",params.act_name)
  412. console.log("文章内容",params.act_content)
  413. console.log("富文本编辑器的内容",params.act_content)
  414. console.log("图片",params.org_logo)
  415. submitForm(params).then(response => {
  416. if(response.data.state === 1){
  417. this.$message({
  418. type: 'success',
  419. message: '成功!'
  420. })
  421. }
  422. })
  423. },
  424. getArticleType(){
  425. getArticleType().then(response =>{
  426. console.log("好嗨我")
  427. if(response.data.state === 1){
  428. var category = response.data.data.category
  429. this.options = response.data.data.category
  430. console.log("文章内容:",category)
  431. console.log("文章",this.options)
  432. }
  433. })
  434. }
  435. },
  436. }
  437. </script>
  438. <style scoped>
  439. .avatar-uploader{
  440. border: 1px solid #d9d9d9;
  441. border-radius: 6px;
  442. cursor: pointer;
  443. overflow: hidden;
  444. width: 140px;
  445. height: 140px;
  446. }
  447. .avatar-uploader{
  448. border-color: #f0f2f5;
  449. }
  450. .avatar-uploader-icon {
  451. font-size: 25px;
  452. color: #8c939d;
  453. width: 140px;
  454. height: 140px;
  455. line-height: 140px;
  456. text-align: center;
  457. }
  458. .avatar {
  459. width: 178px;
  460. height: 178px;
  461. display: block;
  462. }
  463. /*视频*/
  464. .video-select {
  465. padding: 150px 0 30px;
  466. background: url("/static/images/video_load.png") no-repeat;
  467. background-position: center 0;
  468. background-size: 192px 132px;
  469. text-align: center;
  470. width: 200px;
  471. height: 200px;
  472. position: relative;
  473. left: 500px;
  474. }
  475. </style>