add.php 57 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996
  1. {extend name="public/container"}
  2. {block name='head_top'}
  3. <style>
  4. .layui-table {
  5. width: 100%!important;
  6. }
  7. .layui-form-item .special-label {
  8. width: 50px;
  9. float: left;
  10. height: 30px;
  11. line-height: 38px;
  12. margin-left: 10px;
  13. margin-top: 5px;
  14. border-radius: 5px;
  15. background-color: #0092DC;
  16. text-align: center;
  17. }
  18. .layui-form-item .special-label i {
  19. display: inline-block;
  20. width: 18px;
  21. height: 18px;
  22. font-size: 18px;
  23. color: #fff;
  24. }
  25. .layui-form-item .label-box {
  26. border: 1px solid;
  27. border-radius: 10px;
  28. position: relative;
  29. padding: 10px;
  30. height: 30px;
  31. color: #fff;
  32. background-color: #393D49;
  33. text-align: center;
  34. cursor: pointer;
  35. display: inline-block;
  36. line-height: 10px;
  37. }
  38. .layui-form-item .label-box p {
  39. line-height: inherit;
  40. }
  41. .edui-default .edui-for-image .edui-icon {
  42. background-position: -380px 0px;
  43. }
  44. </style>
  45. <script type="text/javascript" charset="utf-8" src="{__ADMIN_PATH}plug/ueditor/third-party/zeroclipboard/ZeroClipboard.js"></script>
  46. <script type="text/javascript" charset="utf-8" src="{__ADMIN_PATH}plug/ueditor/ueditor.config.js?456"></script>
  47. <script type="text/javascript" charset="utf-8" src="{__ADMIN_PATH}plug/ueditor/ueditor.all.min.js"></script>
  48. {/block}
  49. {block name="content"}
  50. <div v-cloak id="app" class="layui-fluid">
  51. <div class="layui-card">
  52. <div class="layui-card-body">
  53. <form class="layui-form" action="">
  54. <div class="layui-tab layui-tab-brief" lay-filter="tab">
  55. <ul class="layui-tab-title">
  56. <li class="layui-this" lay-id="0">基本设置</li>
  57. <li lay-id="1">素材选择</li>
  58. <li lay-id="2">专题配置</li>
  59. <li lay-id="3">价格设置</li>
  60. </ul>
  61. <div class="layui-tab-content">
  62. <div class="layui-tab-item layui-show">
  63. <div class="layui-form-item required">
  64. <label class="layui-form-label">专题名称:</label>
  65. <div class="layui-input-block">
  66. <input type="text" name="title" required v-model.trim="formData.title" autocomplete="off" placeholder="请输入专题名称" maxlength="30" class="layui-input">
  67. </div>
  68. </div>
  69. <div class="layui-form-item required">
  70. <label class="layui-form-label">课程分类:</label>
  71. <div class="layui-input-block">
  72. <select name="subject_id" v-model="formData.subject_id" lay-search="" lay-filter="subject_id" lay-verify="required">
  73. <option value="0">请选分类</option>
  74. <option v-for="item in subject_list" :value="item.id" :disabled="item.grade_id==0 ? true : false">{{item.html}}{{item.name}}</option>
  75. </select>
  76. </div>
  77. </div>
  78. <div class="layui-form-item">
  79. <label class="layui-form-label">讲师:</label>
  80. <div class="layui-input-block">
  81. <select name="lecturer_id" v-model="formData.lecturer_id" lay-search="" lay-filter="lecturer_id">
  82. <option value="0">请选讲师</option>
  83. <option v-for="item in lecturer_list" :value="item.id" :disabled="item.grade_id==0 ? true : false">{{item.html}}{{item.lecturer_name}}</option>
  84. </select>
  85. </div>
  86. </div>
  87. <div class="layui-form-item required">
  88. <label class="layui-form-label">专题简介:</label>
  89. <div class="layui-input-block">
  90. <textarea placeholder="请输入专题简介" v-model="formData.abstract" class="layui-textarea"></textarea>
  91. </div>
  92. </div>
  93. <div class="layui-form-item required">
  94. <label class="layui-form-label">专题标签:</label>
  95. <div class="layui-input-inline">
  96. <input type="text" v-model="label" name="price_min" placeholder="最多6个字" autocomplete="off" maxlength="6" class="layui-input">
  97. </div>
  98. <div class="layui-input-inline" style="width: auto;">
  99. <button type="button" class="layui-btn layui-btn-normal" @click="addLabrl" >
  100. <i class="layui-icon">&#xe654;</i>
  101. </button>
  102. </div>
  103. <div class="layui-form-mid layui-word-aux">输入标签名称后点击”+“号按钮添加;最多写入6个字;点击标签即可删除</div>
  104. </div>
  105. <div v-if="formData.label.length" class="layui-form-item">
  106. <div class="layui-input-block">
  107. <button v-for="(item,index) in formData.label" :key="index" type="button" class="layui-btn layui-btn-normal layui-btn-sm" @click="delLabel(index)">{{item}}</button>
  108. </div>
  109. </div>
  110. <div class="layui-form-item required">
  111. <label class="layui-form-label">专题封面:(250*140)</label>
  112. <div class="layui-input-block">
  113. <div class="upload-image-box" v-if="formData.image">
  114. <img :src="formData.image" alt="">
  115. <div class="mask">
  116. <p>
  117. <i class="fa fa-eye" @click="look(formData.image)"></i>
  118. <i class="fa fa-trash-o" @click="delect('image')"></i>
  119. </p>
  120. </div>
  121. </div>
  122. <div class="upload-image" v-show="!formData.image" @click="upload('image')">
  123. <div class="fiexd"><i class="fa fa-plus"></i></div>
  124. <p>选择图片</p>
  125. </div>
  126. </div>
  127. </div>
  128. <div class="layui-form-item required">
  129. <label class="layui-form-label">专题Banner:(750*420)</label>
  130. <div class="layui-input-block">
  131. <div class="upload-image-box" v-if="formData.banner.length" v-for="(item,index) in formData.banner">
  132. <img :src="item.pic" alt="">
  133. <div class="mask">
  134. <p>
  135. <i class="fa fa-eye" @click="look(item.pic)"></i>
  136. <i class="fa fa-trash-o" @click="delect('banner',index)"></i>
  137. </p>
  138. </div>
  139. </div>
  140. <div class="upload-image" v-show="formData.banner.length < 5" @click="upload('banner',5 - formData.banner.length)">
  141. <div class="fiexd"><i class="fa fa-plus"></i></div>
  142. <p>选择图片</p>
  143. </div>
  144. </div>
  145. </div>
  146. <div class="layui-form-item required">
  147. <label class="layui-form-label">推广海报:(600*740)</label>
  148. <div class="layui-input-block">
  149. <div class="upload-image-box" v-if="formData.poster_image">
  150. <img :src="formData.poster_image" alt="">
  151. <div class="mask">
  152. <p><i class="fa fa-eye" @click="look(formData.poster_image)"></i>
  153. <i class="fa fa-trash-o" @click="delect('poster_image')"></i></p>
  154. </div>
  155. </div>
  156. <div class="upload-image" v-show="!formData.poster_image" @click="upload('poster_image')">
  157. <div class="fiexd"><i class="fa fa-plus"></i></div>
  158. <p>选择图片</p>
  159. </div>
  160. </div>
  161. </div>
  162. <!-- <div class="layui-form-item">
  163. <label class="layui-form-label">客服二维码:(200*200)</label>
  164. <div class="layui-input-block">
  165. <div class="upload-image-box" v-if="formData.service_code">
  166. <img :src="formData.service_code" alt="">
  167. <div class="mask">
  168. <p><i class="fa fa-eye" @click="look(formData.service_code)"></i>
  169. <i class="fa fa-trash-o" @click="delect('service_code')"></i></p>
  170. </div>
  171. </div>
  172. <div class="upload-image" v-show="!formData.service_code" @click="upload('service_code')">
  173. <div class="fiexd"><i class="fa fa-plus"></i></div>
  174. <p>选择图片</p>
  175. </div>
  176. </div>
  177. </div> -->
  178. <div class="layui-form-item">
  179. <label class="layui-form-label">插入{{type_title}}:</label>
  180. <div class="layui-input-block">
  181. <input type="text" name="title" v-model="link" style="width:300px;display:inline-block;margin-right: 10px;" autocomplete="off" placeholder="请输入视频链接" class="layui-input">
  182. <button type="button" class="layui-btn layui-btn-sm layui-btn-normal" @click="uploadVideo">{{confirm_title}}
  183. </button>
  184. <button type="button" class="layui-btn layui-btn-sm layui-btn-normal" id="ossupload">{{but_title}}
  185. </button>
  186. <div class="layui-form-mid layui-word-aux" style="float: none;display: inline-block;">输入链接将视为添加视频直接添加,请确保视频链接的正确性</div>
  187. </div>
  188. <input type="file" name="video" v-show="" ref="video">
  189. <div class="layui-input-block" style="width: 50%;margin-top: 20px" v-show="is_video">
  190. <div class="layui-progress" style="margin-bottom: 10px">
  191. <div class="layui-progress-bar layui-bg-blue" :style="'width:'+videoWidth+'%'"></div>
  192. </div>
  193. <button type="button" class="layui-btn layui-btn-sm layui-btn-danger" @click="cancelUpload">取消
  194. </button>
  195. </div>
  196. </div>
  197. <div class="layui-form-item required">
  198. <label class="layui-form-label">专题详情:</label>
  199. <div class="layui-input-block">
  200. <textarea id="editor">{{formData.content}}</textarea>
  201. </div>
  202. </div>
  203. </div>
  204. <div class="layui-tab-item">
  205. <div class="layui-form-item">
  206. <label class="layui-form-label">素材排序方式:</label>
  207. <div class="layui-input-block">
  208. <input type="radio" name="sort_order" lay-filter="sort_order" v-model="formData.sort_order" value="1" title="正序">
  209. <input type="radio" name="sort_order" lay-filter="sort_order" v-model="formData.sort_order" value="0" title="倒序">
  210. </div>
  211. </div>
  212. <div class="layui-form-item required">
  213. <label class="layui-form-label">选择素材:</label>
  214. <div class="layui-input-block">
  215. <input type="hidden" id="check_source_tmp" name="check_source_tmp"/>
  216. <button type="button" class="layui-btn layui-btn-normal" @click='search_task'>
  217. 选择素材
  218. </button>
  219. <div class="layui-form-mid layui-word-aux" style="float: none;display: inline-block;">如果素材列表中没有你要的素材,请:<a @click='add_source' style="color: #0093dd;">前往添加素材</a></div>
  220. </div>
  221. </div>
  222. <div class="layui-form-item">
  223. <label class="layui-form-label">素材展示:</label>
  224. <div class="layui-input-block">
  225. <input type="hidden" id="check_source_sure" name="check_source_sure"/>
  226. <table class="layui-hide" id="showSourceList" lay-filter="showSourceList"></table>
  227. </div>
  228. </div>
  229. </div>
  230. <div class="layui-tab-item">
  231. <div class="layui-form-item">
  232. <label class="layui-form-label">专题章节:</label>
  233. <div class="layui-input-inline">
  234. <input type="number" name="sum" lay-verify="sum" v-model="formData.sum"
  235. autocomplete="off" class="layui-input" min="0" max="99999">
  236. </div>
  237. <div class="layui-form-mid">节</div>
  238. </div>
  239. <div class="layui-form-item">
  240. <label class="layui-form-label">专题排序:</label>
  241. <div class="layui-input-inline">
  242. <input type="number" name="sort" v-model="formData.sort" autocomplete="off" min="0"
  243. class="layui-input" v-sort>
  244. </div>
  245. </div>
  246. <div class="layui-form-item">
  247. <label class="layui-form-label">虚拟学习人数:</label>
  248. <div class="layui-input-inline">
  249. <input type="number" name="fake_sales" v-model="formData.fake_sales"
  250. autocomplete="off" min="0" class="layui-input">
  251. </div>
  252. </div>
  253. <div class="layui-form-item">
  254. <label class="layui-form-label">有效期:</label>
  255. <div class="layui-input-inline">
  256. <input type="number" name="validity" lay-verify="number" v-model="formData.validity"
  257. autocomplete="off" class="layui-input" min="0" max="99999">
  258. </div>
  259. <div class="layui-form-mid">天</div>
  260. <div class="layui-form-mid layui-word-aux">有效期为用户购买后可以观看时间,0为时间不限;</div>
  261. </div>
  262. <div class="layui-form-item">
  263. <label class="layui-form-label">学分:</label>
  264. <div class="layui-input-inline">
  265. <input type="number" name="xuefen" lay-verify="number" v-model="formData.xuefen"
  266. autocomplete="off" class="layui-input" min="0" max="99999">
  267. </div>
  268. <div class="layui-form-mid">分</div>
  269. <div class="layui-form-mid layui-word-aux">购买学习完成后课获得学分;</div>
  270. </div>
  271. <div class="layui-form-item">
  272. <label class="layui-form-label">热门推荐:</label>
  273. <div class="layui-input-inline">
  274. <input type="radio" name="ishot" lay-filter="ishot" v-model="formData.ishot" value="1" title="是">
  275. <input type="radio" name="ishot" lay-filter="ishot" v-model="formData.ishot" value="0" title="否" checked="">
  276. </div>
  277. <div class="layui-form-mid"></div>
  278. <div class="layui-form-mid layui-word-aux"></div>
  279. </div>
  280. <div class="layui-form-item">
  281. <label class="layui-form-label">最新推荐:</label>
  282. <div class="layui-input-inline">
  283. <input type="radio" name="isnew" lay-filter="isnew" v-model="formData.isnew" value="1" title="是">
  284. <input type="radio" name="isnew" lay-filter="isnew" v-model="formData.isnew" value="0" title="否" checked="">
  285. </div>
  286. <div class="layui-form-mid"></div>
  287. <div class="layui-form-mid layui-word-aux"></div>
  288. </div>
  289. <!-- <div class="layui-form-item">
  290. <label class="layui-form-label">仅会员可见:</label>
  291. <div class="layui-input-block">
  292. <input type="radio" name="is_mer_visible" lay-filter="is_mer_visible"
  293. v-model="formData.is_mer_visible" value="1" title="是">
  294. <input type="radio" name="is_mer_visible" lay-filter="is_mer_visible"
  295. v-model="formData.is_mer_visible" value="0" title="否">
  296. </div>
  297. </div> -->
  298. </div>
  299. <div class="layui-tab-item">
  300. <div class="layui-form-item">
  301. <label class="layui-form-label">付费方式:</label>
  302. <div class="layui-input-block">
  303. <input type="radio" name="pay_type" lay-filter="pay_type" v-model="formData.pay_type" value="1" title="付费">
  304. <input type="radio" name="pay_type" lay-filter="pay_type" v-model="formData.pay_type" value="0" title="免费">
  305. </div>
  306. </div>
  307. <div class="layui-form-item" v-show="formData.pay_type == 1">
  308. <label class="layui-form-label">购买金额:</label>
  309. <div class="layui-input-inline">
  310. <input type="number" name="money" lay-verify="number" v-model="formData.money" autocomplete="off" class="layui-input">
  311. </div>
  312. </div>
  313. <!-- <div class="layui-form-item" v-show="formData.pay_type == 1">
  314. <label class="layui-form-label" style="padding: 9px 0;">会员付费方式:</label>
  315. <div class="layui-input-block">
  316. <input type="radio" name="member_pay_type" lay-filter="member_pay_type" v-model="formData.member_pay_type" value="1" title="付费">
  317. <input type="radio" name="member_pay_type" lay-filter="member_pay_type" v-model="formData.member_pay_type" value="0" title="免费">
  318. </div>
  319. </div>
  320. <div class="layui-form-item" v-show="formData.member_pay_type == 1">
  321. <label class="layui-form-label" style="padding: 9px 0;">会员购买金额:</label>
  322. <div class="layui-input-inline">
  323. <input type="number" name="member_money" lay-verify="number" v-model="formData.member_money" autocomplete="off" class="layui-input" min="0">
  324. </div>
  325. </div>
  326. <div class="layui-form-item" v-show="formData.pay_type == 1">
  327. <label class="layui-form-label">单独分销:</label>
  328. <div class="layui-input-block">
  329. <input type="radio" name="is_alone" lay-filter="is_alone" v-model="formData.is_alone" :disabled="formData.pay_type == 0" value="1" title="开启">
  330. <input type="radio" name="is_alone" lay-filter="is_alone" v-model="formData.is_alone" :disabled="formData.pay_type == 0" value="0" title="关闭">
  331. </div>
  332. </div>
  333. <div class="layui-form-item" v-show="formData.is_alone == 1">
  334. <label class="layui-form-label">一级返佣比例[5%=5]:</label>
  335. <div class="layui-input-block">
  336. <input style="width: 300px" type="number" name="brokerage_ratio" lay-verify="number" v-model="formData.brokerage_ratio" autocomplete="off" class="layui-input" min="0">
  337. </div>
  338. </div>
  339. <div class="layui-form-item" v-show="formData.is_alone == 1">
  340. <label class="layui-form-label">二级返佣比例[5%=5]:</label>
  341. <div class="layui-input-block">
  342. <input style="width: 300px" type="number" name="brokerage_two" lay-verify="number" v-model="formData.brokerage_two" autocomplete="off" class="layui-input" min="0">
  343. </div>
  344. </div>
  345. <div class="layui-form-item" v-show="formData.pay_type == 1">
  346. <label class="layui-form-label">拼团状态:</label>
  347. <div class="layui-input-block">
  348. <input type="radio" name="is_pink" lay-filter="is_pink" v-model="formData.is_pink" value="1" title="开启">
  349. <input type="radio" name="is_pink" lay-filter="is_pink" v-model="formData.is_pink" value="0" title="关闭" checked="">
  350. </div>
  351. </div>
  352. <div class="layui-form-item" v-show="formData.is_pink">
  353. <div class="layui-inline">
  354. <label class="layui-form-label">拼团金额:</label>
  355. <div class="layui-input-inline">
  356. <input type="number" name="pink_money" v-model="formData.pink_money" autocomplete="off" class="layui-input">
  357. </div>
  358. </div>
  359. <div class="layui-inline">
  360. <label class="layui-form-label">拼团人数:</label>
  361. <div class="layui-input-inline">
  362. <input type="number" name="pink_number" v-model="formData.pink_number" autocomplete="off" class="layui-input">
  363. </div>
  364. </div>
  365. </div>
  366. <div class="layui-form-item" v-show="formData.is_pink">
  367. <div class="layui-inline">
  368. <label class="layui-form-label">开始时间:</label>
  369. <div class="layui-input-inline">
  370. <input type="text" name="pink_strar_time" v-model="formData.pink_strar_time" id="start_time" autocomplete="off" class="layui-input">
  371. </div>
  372. </div>
  373. <div class="layui-inline">
  374. <label class="layui-form-label">结束时间:</label>
  375. <div class="layui-input-inline">
  376. <input type="text" name="pink_end_time" v-model="formData.pink_end_time" id="end_time" autocomplete="off" class="layui-input">
  377. </div>
  378. </div>
  379. </div>
  380. <div class="layui-form-item" v-show="formData.is_pink">
  381. <label class="layui-form-label">拼团时间:</label>
  382. <div class="layui-input-inline">
  383. <input type="number" v-model="formData.pink_time" autocomplete="off" class="layui-input">
  384. </div>
  385. <div class="layui-form-mid">小时</div>
  386. </div>
  387. <div class="layui-form-item" v-show="formData.is_pink">
  388. <label class="layui-form-label">模拟成团:</label>
  389. <div class="layui-input-block">
  390. <input type="radio" name="is_fake_pink" lay-filter="is_fake_pink" v-model="formData.is_fake_pink" value="1" title="开启" checked="">
  391. <input type="radio" name="is_fake_pink" lay-filter="is_fake_pink" v-model="formData.is_fake_pink" value="0" title="关闭">
  392. </div>
  393. </div>
  394. <div class="layui-form-item" v-show="formData.is_fake_pink && formData.is_pink">
  395. <label class="layui-form-label">补齐比例:</label>
  396. <div class="layui-input-inline">
  397. <input type="number" v-model="formData.fake_pink_number" autocomplete="off" class="layui-input">
  398. </div>
  399. <div class="layui-form-mid" style="color: red;">注:可设置成团的补齐比例,拼团结束前实际拼团人数达不到拼团要求时,可根据补齐比例自动添加人数,达到拼团成功的目的</div>
  400. </div> -->
  401. </div>
  402. </div>
  403. </div>
  404. <div class="layui-form-item">
  405. <div class="layui-input-block">
  406. <button type="button" class="layui-btn layui-btn-primary" @click="clone_form">取消</button>
  407. <button v-show="tabIndex" type="button" class="layui-btn layui-btn-primary" @click="tabChange(-1)">上一步</button>
  408. <button v-show="tabIndex != 3" type="button" class="layui-btn layui-btn-normal" @click="tabChange(1)">下一步</button>
  409. <button v-show="tabIndex == 3" type="button" class="layui-btn layui-btn-normal" @click="save">{$id ?'确认修改':'立即提交'}</button>
  410. </div>
  411. </div>
  412. </form>
  413. </div>
  414. </div>
  415. </div>
  416. <script type="text/javascript" src="{__ADMIN_PATH}js/layuiList.js"></script>
  417. {/block}
  418. {block name='script'}
  419. <script>
  420. var id = {$id}, special =<?=isset($special) ? $special : "{}"?>, special_type ="{$special_type}";
  421. require(['vue','helper','zh-cn','request','plupload','aliyun-oss','OssUpload'], function (Vue,$h) {
  422. new Vue({
  423. el: "#app",
  424. directives: {
  425. sort: {
  426. bind: function (el, binding, vnode) {
  427. var vm = vnode.context;
  428. el.addEventListener('change', function () {
  429. if (!this.value || this.value < 0) {
  430. vm.formData.sort = 0;
  431. } else if (this.value > 9999) {
  432. vm.formData.sort = 9999;
  433. } else {
  434. vm.formData.sort = parseInt(this.value);
  435. }
  436. });
  437. }
  438. }
  439. },
  440. data: {
  441. subject_list: [],
  442. source_tmp_list:[],//用于子页父业选中素材传值的临时变量
  443. source_list: [],
  444. lecturer_list: [],
  445. formData: {
  446. subjectIds:'',
  447. phrase: special.phrase || '',
  448. label: special.label || [],
  449. abstract: special.abstract || '',
  450. title: special.title || '',
  451. subject_id: special.subject_id || 0,
  452. lecturer_id: special.lecturer_id || 0,
  453. task_id: 0,
  454. sum: special.sum || 0,
  455. image: special.image || '',
  456. banner: special.banner || [],
  457. poster_image: special.poster_image || '',
  458. service_code: special.service_code || '',
  459. money: special.money || 0.00,
  460. pink_money: special.pink_money || 0.00,
  461. pink_number: special.pink_number || 0,
  462. pink_strar_time: special.pink_strar_time || '',
  463. pink_end_time: special.pink_end_time || '',
  464. fake_pink_number: special.fake_pink_number || 0,
  465. sort: special.sort || 0,
  466. is_mer_visible: special.is_mer_visible || 0,
  467. is_pink: special.is_pink || 0,
  468. is_fake_pink: special.is_fake_pink || 1,
  469. fake_sales: special.fake_sales || 0,
  470. validity: special.validity || 0,
  471. browse_count: special.browse_count || 0,
  472. pink_time: special.pink_time || 0,
  473. content: special.profile ? (special.profile.content || '') : '',
  474. pay_type: special.pay_type == 1 ? 1 : 0,
  475. member_pay_type: special.member_pay_type == 1 ? 1 : 0,
  476. member_money: special.member_money || 0.00,
  477. link:special.link || '',
  478. check_source_sure: [],
  479. check_store_sure: [],
  480. sort_order:special.sort_order || 0,
  481. xuefen:special.xuefen || 0,
  482. isnew:special.isnew || 0,
  483. ishot:special.ishot || 0,
  484. is_alone:special.pay_type == 1 ? (special.is_alone == 1 ? 1 : 0) : 0,
  485. brokerage_ratio:special.pay_type == 1 ? (special.brokerage_ratio || 0) : 0,
  486. brokerage_two:special.pay_type == 1 ? (special.brokerage_two || 0) : 0
  487. },
  488. but_title:special_type==2?'上传音频':'上传视频',
  489. type_title: special_type==2?'音频':'视频',
  490. confirm_title: special_type==2?'确认音频':'确认视频',
  491. link: '',
  492. label: '',
  493. host: ossUpload.host + '/',
  494. mask: {
  495. poster_image: false,
  496. image: false,
  497. service_code: false,
  498. },
  499. ue: null,
  500. is_video: false,
  501. //上传类型
  502. mime_types: {
  503. Image: "jpg,gif,png,JPG,GIF,PNG",
  504. Video: "mp4,MP4",
  505. Audio: "mp3,MP3",
  506. },
  507. videoWidth: 0,
  508. uploader: null,
  509. searchTask:false,
  510. tabIndex: 0
  511. },
  512. watch:{
  513. 'formData.validity':function (v) {
  514. if (v.indexOf('.')!=-1) {
  515. return layList.msg('不能输入小数');
  516. }
  517. if(v<0) return layList.msg('不能小于0');
  518. if(v>99999) return layList.msg('不能大于99999');
  519. }
  520. },
  521. methods: {
  522. //取消
  523. cancelUpload: function () {
  524. this.uploader.stop();
  525. this.is_video = false;
  526. this.videoWidth = 0;
  527. },
  528. //删除图片
  529. delect: function (key, index) {
  530. var that = this;
  531. if (index != undefined) {
  532. that.formData[key].splice(index, 1);
  533. that.$set(that.formData, key, that.formData[key]);
  534. } else {
  535. that.$set(that.formData, key, '');
  536. }
  537. },
  538. //查看图片
  539. look: function (pic) {
  540. parent.$eb.openImage(pic);
  541. },
  542. //鼠标移入事件
  543. enter: function (item) {
  544. if (item) {
  545. item.is_show = true;
  546. } else {
  547. this.mask = true;
  548. }
  549. },
  550. //鼠标移出事件
  551. leave: function (item) {
  552. if (item) {
  553. item.is_show = false;
  554. } else {
  555. this.mask = false;
  556. }
  557. },
  558. changeIMG: function (key, value, multiple) {
  559. if (multiple) {
  560. var that = this;
  561. value.map(function (v) {
  562. that.formData[key].push({pic: v, is_show: false});
  563. });
  564. this.$set(this.formData, key, this.formData[key]);
  565. } else {
  566. this.$set(this.formData, key, value);
  567. }
  568. },
  569. uploadVideo: function () {
  570. var link = this.link.trim();
  571. if (link) {
  572. if (link.indexOf('http') || link.indexOf('mp4') !== link.length - 3) {
  573. layui.layer.msg('请输入正确的视频链接', {icon: 5});
  574. } else {
  575. this.setContent(this.link);
  576. }
  577. }
  578. },
  579. setContent: function (link) {
  580. this.formData.link = link;
  581. this.ue.setContent('<div><video style="width: 100%" src="'+link+'" class="video-ue" controls="controls"><source src="'+link+'"></source></video></div><span style="color:white">.</span>',true);
  582. },
  583. //上传图片
  584. upload: function (key, count) {
  585. ossUpload.createFrame('请选择图片', {fodder: key, max_count: count === undefined ? 0 : count},{w:800,h:550});
  586. },
  587. //获取分类
  588. get_subject_list: function () {
  589. var that = this;
  590. layList.baseGet(layList.U({a: 'get_subject_list'}), function (res) {
  591. that.$set(that, 'subject_list', res.data);
  592. that.$nextTick(function () {
  593. layList.form.render('select');
  594. })
  595. });
  596. },
  597. //获取讲师
  598. get_lecturer_list: function () {
  599. var that = this;
  600. layList.baseGet(layList.U({a: 'get_lecturer_list'}), function (res) {
  601. that.$set(that, 'lecturer_list', res.data);
  602. that.$nextTick(function () {
  603. layList.form.render('select');
  604. })
  605. });
  606. },
  607. delLabel: function (index) {
  608. this.formData.label.splice(index, 1);
  609. this.$set(this.formData, 'label', this.formData.label);
  610. },
  611. addLabrl: function () {
  612. if (this.label) {
  613. if (this.label.length > 6) return layList.msg('您输入的标签字数太长');
  614. var length = this.formData.label.length;
  615. if (length >= 2) return layList.msg('标签最多添加2个');
  616. for (var i = 0; i < length; i++) {
  617. if (this.formData.label[i] == this.label) return layList.msg('请勿重复添加');
  618. }
  619. this.formData.label.push(this.label);
  620. this.$set(this.formData, 'label', this.formData.label);
  621. this.label = '';
  622. }
  623. },
  624. save: function () {
  625. var that = this;
  626. that.formData.content = that.ue.getContent();
  627. that.$nextTick(function () {
  628. if (!that.formData.title) return layList.msg('请输入专题标题');
  629. if (!that.formData.subject_id) return layList.msg('请选择分类');
  630. if (!that.formData.abstract) return layList.msg('请输入专题简介');
  631. if (!that.formData.label.length) return layList.msg('请输入标签');
  632. if (!that.formData.image) return layList.msg('请上传专题封面');
  633. if (!that.formData.banner.length) return layList.msg('请上传banner图,最少1张');
  634. if (!that.formData.poster_image) return layList.msg('请上传推广海报');
  635. if (!that.formData.content) return layList.msg('请编辑内容在进行保存');
  636. if (that.formData.validity < 0) return layList.msg('专题有效期不能小于0');
  637. if (that.formData.validity > 99999) return layList.msg('专题有效期不能大于99999');
  638. if ((that.formData.validity+'').indexOf('.')!=-1) return layList.msg('专题有效期不能为小数');
  639. if (that.formData.sum < 0) return layList.msg('专题章节不能小于0');
  640. if (that.formData.sum > 99999) return layList.msg('专题章节不能大于99999');
  641. if ((that.formData.sum + '').indexOf('.') != -1) return layList.msg('专题章节不能为小数');
  642. if (that.formData.is_pink) {
  643. if (!that.formData.pink_money) return layList.msg('请填写拼团金额');
  644. if (!that.formData.pink_number) return layList.msg('请填写拼团人数');
  645. if (!that.formData.pink_strar_time) return layList.msg('请选择拼团开始时间');
  646. if (!that.formData.pink_end_time) return layList.msg('请选择拼团结束时间');
  647. if (!that.formData.pink_time) return layList.msg('请填写拼团时间');
  648. if (that.formData.is_fake_pink && !that.formData.fake_pink_number) return layList.msg('请填写补齐比例');
  649. }
  650. that.formData.subjectIds=JSON.stringify(that.formData.check_source_sure);
  651. if (that.formData.pay_type == 1) {
  652. if (!that.formData.money || that.formData.money == 0.00) return layList.msg('请填写购买金额');
  653. }
  654. if (that.formData.member_pay_type == 1) {
  655. if (!that.formData.member_money || that.formData.member_money == 0.00) return layList.msg('请填写会员购买金额');
  656. }
  657. if (that.formData.is_alone == 1) {
  658. if (that.formData.brokerage_ratio<0 || !that.formData.brokerage_two<0) return layList.msg('推广人返佣比例不能小于0');
  659. if (!that.formData.brokerage_ratio || !that.formData.brokerage_two) return layList.msg('请填写推广人返佣比例');
  660. }
  661. var data={};
  662. for (var key in that.formData) {
  663. if (key !== 'check_source_sure') {
  664. data[key] = that.formData[key]
  665. }
  666. }
  667. layList.loadFFF();
  668. layList.basePost(layList.U({
  669. a: 'save_special',
  670. q: {id: id, special_type: special_type}
  671. }), data, function (res) {
  672. layList.loadClear();
  673. if (parseInt(id) == 0) {
  674. layList.layer.confirm('添加成功,您要继续添加专题吗?', {
  675. btn: ['继续添加', '立即提交'] //按钮
  676. }, function (index) {
  677. layList.layer.close(index);
  678. }, function () {
  679. parent.layer.closeAll();
  680. });
  681. } else {
  682. layList.msg('修改成功', function () {
  683. parent.layer.closeAll();
  684. })
  685. }
  686. }, function (res) {
  687. layList.msg(res.msg);
  688. layList.loadClear();
  689. });
  690. })
  691. },
  692. clone_form: function () {
  693. parent.layer.closeAll();
  694. },
  695. //素材
  696. search_task:function () {
  697. var that=this;
  698. var url="{:Url('special.special_type/searchs_task')}?special_id="+id+"&special_type="+special_type;
  699. var title='选择素材';
  700. that.searchTask=true;
  701. layer.open({
  702. type: 2 //Page层类型
  703. ,area: ['80%', '90%']
  704. ,title: title
  705. ,shade: 0.6 //遮罩透明度
  706. ,maxmin: true //允许全屏最小化
  707. ,anim: 1 //0-6的动画形式,-1不开启
  708. ,content: url,
  709. btn: '确定',
  710. btnAlign: 'c', //按钮居中
  711. closeBtn:1,
  712. yes: function(){
  713. layer.closeAll();
  714. var source_tmp = $("#check_source_tmp").val();
  715. that.source_tmp_list = JSON.parse(source_tmp);
  716. var array=that.formData.check_source_sure;
  717. that.formData.check_source_sure=array.concat(JSON.parse(source_tmp));
  718. that.formData.check_source_sure=that.duplicate_removal(that.formData.check_source_sure);
  719. that.show_source_list();
  720. }
  721. });
  722. },
  723. duplicate_removal:function(array)
  724. {
  725. var new_arr=[];
  726. var check_source_sure=[];
  727. for(var i=0;i<array.length;i++) {
  728. var items=array[i];
  729. var id=array[i].id;
  730. if($.inArray(id,new_arr)==-1) {
  731. new_arr.push(id);
  732. check_source_sure.push(items);
  733. }
  734. }
  735. return check_source_sure;
  736. },
  737. add_source:function(){
  738. var that=this;
  739. var url="{:Url('special.special_type/addSources')}";
  740. var title='添加素材';
  741. layer.open({
  742. type: 2 //Page层类型
  743. ,area: ['80%', '90%']
  744. ,title: title
  745. ,shade: 0.6 //遮罩透明度
  746. ,maxmin: true //允许全屏最小化
  747. ,anim: 1 //0-6的动画形式,-1不开启
  748. ,content: url
  749. ,end:function () {
  750. layer.closeAll();
  751. }
  752. });
  753. },
  754. show_source_list:function () {
  755. var that = this;
  756. var table = layui.table,form = layui.form;
  757. table.render({
  758. elem: '#showSourceList'
  759. ,cols: [[
  760. {field: 'id', title: '编号', align: 'center',width:60},
  761. {field: 'title', title: '素材标题',align: 'center'},
  762. {field: 'image', title: '封面',templet:'<div><img src="{{ d.image }}" style="width: 100%;"></div>',align: 'center'},
  763. {field: 'sort', title: '排序',edit:'sort',align: 'center'},
  764. {field: 'pay_status', title: '收费状态',align: 'center',templet:function(d){
  765. var is_checked = d.pay_status == 1 ? "checked" : "";
  766. return "<input type='checkbox' name='pay_status' lay-skin='switch' value='"+d.id+"' lay-filter='pay_status' lay-text='收费|免费' "+is_checked+">";
  767. }},
  768. {field: 'right', title: '操作',align: 'center',templet:function(d){
  769. return '<div><a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del"><i class="layui-icon">&#xe640;</i> 移除</a></div>';
  770. }}
  771. ]]
  772. ,data: that.formData.check_source_sure
  773. ,page: {
  774. theme: '#0092DC'
  775. }
  776. ,id: 'table'
  777. });
  778. table.on('tool(showSourceList)', function(obj){
  779. var data = obj.data;
  780. if(obj.event === 'del'){
  781. if (that.formData.check_source_sure) {
  782. for(var i=0;i<that.formData.check_source_sure.length;i++){
  783. if(that.formData.check_source_sure[i].id==data.id){
  784. that.formData.check_source_sure.splice(i,1);
  785. }
  786. }
  787. that.formData.check_source_sure=that.formData.check_source_sure;
  788. that.show_source_list();
  789. }
  790. }
  791. });
  792. table.on('edit(showSourceList)', function(obj){
  793. var id=obj.data.id,values=obj.value;
  794. switch (obj.field) {
  795. case 'sort':
  796. if (that.formData.check_source_sure) {
  797. $.each(that.formData.check_source_sure, function(index, value){
  798. if(value.id == id){
  799. that.formData.check_source_sure[index].sort = values;
  800. }
  801. })
  802. }
  803. break;
  804. }
  805. });
  806. //监听素材是否免费操作
  807. form.on('switch(pay_status)', function(obj){
  808. if (that.formData.check_source_sure) {
  809. $.each(that.formData.check_source_sure, function(index, value){
  810. if(value.id == obj.value){
  811. that.formData.check_source_sure[index].pay_status = obj.elem.checked == true ? 0 : 1;
  812. }
  813. })
  814. }
  815. });
  816. //监听素材是否删除
  817. form.on('switch(delect)', function(obj){
  818. if (that.formData.check_source_sure) {
  819. for(var i=0;i<that.formData.check_source_sure.length;i++){
  820. if(that.formData.check_source_sure[i].id==obj.value){
  821. that.formData.check_source_sure.splice(i,1);
  822. }
  823. }
  824. that.formData.check_source_sure=that.formData.check_source_sure;
  825. that.show_source_list();
  826. }
  827. });
  828. },
  829. del:function (e) {
  830. console.log(e);
  831. },
  832. get_check_source_sure:function () {
  833. var that = this;
  834. layList.baseGet(layList.U({a: 'get_check_source_sure',q: {id: id, special_type:special_type}}), function (res) {
  835. that.formData.check_source_sure=res.data.sourceCheckList;
  836. that.formData.check_store_sure=res.data.storeCheckList;
  837. that.show_source_list();
  838. });
  839. },
  840. // 上一步、下一步
  841. tabChange: function (value) {
  842. layui.element.tabChange('tab', this.tabIndex + value);
  843. }
  844. },
  845. mounted: function () {
  846. var that = this;
  847. window.changeIMG = that.changeIMG;
  848. layList.date({
  849. elem: '#start_time',
  850. type: 'datetime',
  851. done: function (value) {
  852. that.formData.pink_strar_time = value;
  853. }
  854. });
  855. layList.date({
  856. elem: '#end_time',
  857. type: 'datetime',
  858. done: function (value) {
  859. that.formData.pink_end_time = value;
  860. }
  861. });
  862. //选择图片
  863. function changeIMG(index, pic) {
  864. $(".image_img").css('background-image', "url(" + pic + ")");
  865. $(".active").css('background-image', "url(" + pic + ")");
  866. $('#image_input').val(pic);
  867. }
  868. //选择图片插入到编辑器中
  869. window.insertEditor = function (list) {
  870. that.ue.execCommand('insertimage', list);
  871. };
  872. this.$nextTick(function () {
  873. layList.form.render();
  874. layui.element.on('tab(tab)', function (data) {
  875. layui.table.resize('table');
  876. that.tabIndex = data.index;
  877. });
  878. //实例化编辑器
  879. UE.registerUI('选择图片', function (editor, uiName) {
  880. var btn = new UE.ui.Button({
  881. name: uiName,
  882. title: uiName,
  883. cssRules: 'background-position: -380px 0;',
  884. onclick: function() {
  885. ossUpload.createFrame(uiName, { fodder: editor.key }, { w: 800, h: 550 });
  886. }
  887. });
  888. return btn;
  889. });
  890. that.ue = UE.getEditor('editor');
  891. });
  892. //获取科目
  893. that.get_subject_list();
  894. //获取讲师列表
  895. that.get_lecturer_list();
  896. //获取已添加的素材
  897. that.get_check_source_sure();
  898. //图片上传和视频上传
  899. layList.form.on('radio(is_pink)', function (data) {
  900. that.formData.is_pink = parseInt(data.value);
  901. });
  902. layList.form.on('radio(ishot)', function (data) {
  903. that.formData.ishot = parseInt(data.value);
  904. });
  905. layList.form.on('radio(isnew)', function (data) {
  906. that.formData.isnew = parseInt(data.value);
  907. });
  908. layList.form.on('radio(is_mer_visible)', function (data) {
  909. that.formData.is_mer_visible = parseInt(data.value);
  910. });
  911. layList.form.on('radio(pay_type)', function (data) {
  912. that.formData.pay_type = parseInt(data.value);
  913. if (that.formData.pay_type != 1) {
  914. that.formData.is_pink = 0;
  915. that.formData.member_pay_type = 0;
  916. that.formData.member_money = 0;
  917. that.formData.is_alone = 0;
  918. that.formData.brokerage_ratio = 0;
  919. that.formData.brokerage_two = 0;
  920. };
  921. that.$nextTick(function () {
  922. layList.form.render('radio');
  923. });
  924. });
  925. layList.form.on('radio(is_alone)', function (data) {
  926. that.formData.is_alone = parseInt(data.value);
  927. if (that.formData.is_alone != 1) {
  928. that.formData.brokerage_ratio = 0;
  929. that.formData.brokerage_two = 0;
  930. };
  931. that.$nextTick(function () {
  932. layList.form.render('radio');
  933. });
  934. });
  935. layList.form.on('radio(sort_order)', function (data) {
  936. that.formData.sort_order = parseInt(data.value);
  937. that.$nextTick(function () {
  938. layList.form.render('radio');
  939. });
  940. });
  941. layList.form.on('radio(member_pay_type)', function (data) {
  942. that.formData.member_pay_type = parseInt(data.value);
  943. if (that.formData.member_pay_type != 1) {
  944. that.formData.member_money = 0;
  945. };
  946. that.$nextTick(function () {
  947. layList.form.render('radio');
  948. });
  949. });
  950. layList.select('subject_id', function (obj) {
  951. that.formData.subject_id = obj.value;
  952. });
  953. layList.select('lecturer_id', function (obj) {
  954. that.formData.lecturer_id = obj.value;
  955. });
  956. layList.form.on('radio(is_fake_pink)', function (data) {
  957. that.formData.is_fake_pink = parseInt(data.value);
  958. });
  959. that.$nextTick(function () {
  960. that.uploader = ossUpload.upload({
  961. id: 'ossupload',
  962. mime_types: [
  963. special_type == 2 ? {title: "Mp3 files", extensions: "mp3"} : {title: "Mp4 files", extensions: "mp4"}
  964. ],
  965. FilesAddedSuccess: function () {
  966. that.is_video = true;
  967. },
  968. uploadIng: function (file) {
  969. that.videoWidth = file.percent;
  970. },
  971. success: function (res) {
  972. layList.msg('上传成功');
  973. that.videoWidth = 0;
  974. that.is_video = false;
  975. that.setContent(res.url);
  976. },
  977. fail: function (err) {
  978. that.videoWidth = 0;
  979. that.is_video = false;
  980. layList.msg(err);
  981. }
  982. })
  983. });
  984. }
  985. })
  986. })
  987. </script>
  988. {/block}