add.php 68 KB

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