Няма описание
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964
  1. {include file="public/layout" /}
  2. <body class="ad_postion bodystyle" style="overflow-y: scroll;">
  3. <div id="toolTipLayer" style="position: absolute; z-index: 9999; display: none; visibility: visible; left: 95px; top: 573px;"></div>
  4. <div id="append_parent"></div>
  5. <div id="ajaxwaitid"></div>
  6. <div class="page min-hg-c-10">
  7. <form class="form-horizontal" id="post_form" action="{:url('ZcdjPosition/edit')}" method="post">
  8. <div class="ncap-form-default">
  9. <dl class="row">
  10. <dt class="tit"> <label for="title"><em>*</em>等级名称</label> </dt>
  11. <dd class="opt">
  12. <input type="text" name="title" value="{$field.title}" id="title" onkeyup="DetectionTitleRepeat(this);" class="input-txt" autocomplete="off">
  13. <span class="err"></span>
  14. <p class="notic2 red" id="title_tips"></p>
  15. </dd>
  16. </dl>
  17. <dl class="row" style="display: block;">
  18. <dt class="tit"> <label for="type">选择分类</label> </dt>
  19. <dd class="opt">
  20. <?php
  21. /*
  22. *
  23. * <select name="type" class="select" style="margin:0px 5px;height:30px;">
  24. <option value="">--选择地区--</option>
  25. {eyou:foreach name='$pro_list' item='field1'}
  26. <option value="{$field1.id}" {eq name="$curr_id" value="$field1.id"}selected{/eq}>{$field1.name}</option>
  27. {/eyou:foreach}
  28. </select>
  29. <select name="type" class="select" id="selectTest" style="margin:0px 5px;height:30px;">
  30. <option value="0" {eq name="0" value="$field.type"}selected{/eq}>通类</option>
  31. <option value="1" {eq name="1" value="$field.type"}selected{/eq}>计算机科学</option>
  32. <option value="2" {eq name="2" value="$field.type"}selected{/eq}>理学</option>
  33. <option value="3" {eq name="3" value="$field.type"}selected{/eq}>哲学类</option>
  34. <option value="4" {eq name="4" value="$field.type"}selected{/eq}>教育学类</option>
  35. <option value="5" {eq name="5" value="$field.type"}selected{/eq}>医学类</option>
  36. <option value="6" {eq name="6" value="$field.type"}selected{/eq}>中国语言文学类</option>
  37. <option value="7" {eq name="7" value="$field.type"}selected{/eq}>历史学类</option>
  38. <option value="8" {eq name="8" value="$field.type"}selected{/eq}>经济学类</option>
  39. <option value="9" {eq name="9" value="$field.type"}selected{/eq}>法学</option>
  40. <option value="10" {eq name="10" value="$field.type"}selected{/eq}>体育学类</option>
  41. <option value="11" {eq name="11" value="$field.type"}selected{/eq}>工商管理类</option>
  42. <option value="12" {eq name="12" value="$field.type"}selected{/eq}>军事学</option>
  43. <option value="13" {eq name="13" value="$field.type"}selected{/eq}>新闻传播学类</option>
  44. <option value="14" {eq name="14" value="$field.type"}selected{/eq}>公共管理类</option>
  45. <option value="15" {eq name="15" value="$field.type"}selected{/eq}>中医学类</option>
  46. <option value="16" {eq name="16" value="$field.type"}selected{/eq}>药学类</option>
  47. <option value="17" {eq name="17" value="$field.type"}selected{/eq}>政治学类</option>
  48. <option value="18" {eq name="18" value="$field.type"}selected{/eq}>社会学类</option>
  49. <option value="19" {eq name="19" value="$field.type"}selected{/eq}>艺术类</option>
  50. <option value="20" {eq name="20" value="$field.type"}selected{/eq}>生物科学类</option>
  51. <option value="21" {eq name="21" value="$field.type"}selected{/eq}>农学</option>
  52. <option value="22" {eq name="22" value="$field.type"}selected{/eq}>其他</option>
  53. </select>
  54. */
  55. ?>
  56. <select name="type2" class="select" id="selectTest" style="margin:0px 5px;height:30px;">
  57. {eyou:foreach name='$pos_list' item='field1'}
  58. <option value="{$field1.id}" {eq name="$pid" value="$field1.id"}selected{/eq}>{$field1.name}</option>
  59. {/eyou:foreach}
  60. </select>
  61. {eyou:notempty name='$pos_list2' /}
  62. <select name="type" class="select" id="selectTest2" style="margin:0px 5px;height:30px;">
  63. {eyou:foreach name='$pos_list2' item='field1'}
  64. <option value="{$field1.id}" {eq name="$field.type" value="$field1.id"}selected{/eq}>{$field1.name}</option>
  65. {/eyou:foreach}
  66. </select>
  67. {eyou:else /}
  68. <span>请先添加二级分类</span>
  69. <input type="hidden" name="type" value="">
  70. {/eyou:notempty}
  71. <script>
  72. $(function(){
  73. $("#selectTest").change(function(e){
  74. console.log($(this).val());
  75. var v = $(this).val();
  76. if(v == 1){
  77. //$('#citychoose').show();
  78. }else{
  79. //$('#citychoose').hide();
  80. }
  81. //ajax
  82. $.ajax({
  83. type:'POST',
  84. url:"{:url('ZcdjPosition/getType', ['_ajax'=>1])}",
  85. data:{
  86. id: $(this).val()
  87. ,_ajax:1
  88. },
  89. success:function(res){
  90. $('#selectTest2').html(res.data);
  91. }
  92. });
  93. });
  94. });
  95. </script>
  96. </dd>
  97. </dl>
  98. <dl class="row" id="citychoose" style="display: none;" >
  99. <dt class="tit"> <label for="title"><em>*</em>地区选择</label> </dt>
  100. <dd class="opt">
  101. <!---checked $map_list-->
  102. {eyou:foreach name='$pro_list' item='field1'}
  103. <input type="checkbox" name="map[]" value="{$field1.id}" id="category{$field1.id}"
  104. {$field1.is_check}
  105. />{$field1.name}
  106. {/eyou:foreach}
  107. <span class="err"></span>
  108. <p class="notic2 red" id="title_tips"></p>
  109. </dd>
  110. </dl>
  111. <!--暂时找不到控制显示隐藏的地方-->
  112. <dl class="row 1615775137_dl" style="display: none;" id="1615775137_1" style="z-index: 2">
  113. <dt class="tit"> <label>主题背景</label> </dt>
  114. <dd class="opt">
  115. <div class="tab-pane" id="tab_imgupload">
  116. <table class="table table-bordered">
  117. <tbody>
  118. <tr>
  119. <td>
  120. <div class="sort-list">
  121. {volist name="ad_data" id="vo" key="k"}
  122. {eq name="$vo.media_type" value="1"}
  123. <div class="images_upload">
  124. <div class="ic">
  125. <div class='upimg' title="拖动修改排序" onmouseover="upimgMouseover(this);" onmouseout="upimgMouseout(this);">
  126. <div class='icaction' style="display: none" >
  127. <span class="load_images" onclick="Images('{$vo['litpic']}', 900, 600);">
  128. <a href="javascript:void(0);" style="color:white">
  129. <i class='fa fa-search-plus'></i>大图
  130. </a>
  131. </span>
  132. <span class="load_images" onclick="LoadImagesId('{$vo['id']}');">
  133. <i class='fa fa-photo'></i>更换
  134. </span>
  135. <span class="load_images" onclick="ShowInput('{$vo['id']}');">
  136. <i class='fa fa-file-text-o'></i>信息
  137. </span>
  138. </div>
  139. <div class='cover-bg' style="display: none" ></div>
  140. <img id="{$vo['id']}_Id" src="{$vo['litpic']}"/>
  141. {if condition="$main_lang == $admin_lang || !empty($global['language_split'])"}
  142. <a class="delect" href="javascript:void(0);" onclick="ClearPicArr(this,'{$vo['litpic']}','{$vo['id']}');" title="删除">
  143. </a>
  144. {/if}
  145. </div>
  146. <div class="load_input" id="{$vo['id']}_ShowInput" data-showOrHide="hide">
  147. <input type="hidden" name="img_id[]" value="{$vo['id']}"/>
  148. <span class="span_input">
  149. <input type="hidden" id="{$vo['id']}_Litpic" name="img_litpic[]" value="{$vo['litpic']}"/>
  150. </span>
  151. <textarea name="img_title[]" placeholder="请输入标题..." style="height: 28px;">{$vo.title}</textarea>
  152. <textarea name="img_links[]" placeholder="请输入链接网址..." style="height: 28px;">{$vo.links}</textarea>
  153. <textarea name="img_intro[]" placeholder="广告注释:支持HTML代码" style="height: 64px;">{$vo.intro}</textarea>
  154. <div class="operation">
  155. <a href="javascript:void(0);">
  156. <label>
  157. <input type="checkbox" {eq name="$vo['target']" value="1"} checked="checked" {/eq} title="在新窗口打开" onclick="CheckedTarget(this)"/>新窗口
  158. <input type="hidden" name="img_target[]" value="{$vo['target']}">
  159. </label>
  160. </a>
  161. <a href="javascript:void(0);" onclick="copyToClipBoard({$vo['id']});">
  162. <i class="fa fa-file-code-o"></i>标签调用
  163. </a>
  164. <a onclick="HideInput('{$vo['id']}');" style="width: 32%;" href="javascript:void(0);" title="收回"><i style="font-size:16px;" class="fa fa-angle-double-up"></i></a>
  165. </div>
  166. </div>
  167. </div>
  168. </div>
  169. {/eq}
  170. {/volist}
  171. <div class="images_upload"></div>
  172. </div>
  173. {if condition="$main_lang == $admin_lang || !empty($global['language_split'])"}
  174. <a href="javascript:void(0);" onClick="GetUploadify(30,'','allimg','imgupload_call_back');" class="img-upload b-img-upload mb15" title="点击上传">
  175. <div class="y-line"></div>
  176. <div class="x-line"></div>
  177. </a>
  178. {/if}
  179. <input type="hidden" id="ImagesId">
  180. </td>
  181. </tr>
  182. </tbody>
  183. </table>
  184. </div>
  185. <!-- 上传图片显示的样板 start -->
  186. <div class="images_upload_tpl none">
  187. <div class="images_upload ic">
  188. <div class="ic">
  189. <div class='upimg' title="拖动修改排序" onmouseover="upimgMouseover(this);" onmouseout="upimgMouseout(this);">
  190. <div class='icaction' style="display: none">
  191. <span class="load_images" onclick="">
  192. <a href="javascript:void(0);" style="color: white">
  193. <i class='fa fa-search-plus'></i>大图
  194. </a>
  195. </span>
  196. <span class="load_images" onclick="">
  197. <i class='fa fa-file-text-o'></i>信息
  198. </span>
  199. </div>
  200. <div class='cover-bg' style="display: none"></div>
  201. <img src="__STATIC__/admin/images/add-button.jpg"/>
  202. <a class="delect" href="javascript:void(0);" title="删除"></a>
  203. </div>
  204. <div class="load_input" data-showOrHide="hide">
  205. <input type="hidden"/>
  206. <span class="span_input"> <input type="hidden"/> </span>
  207. <textarea placeholder="请输入标题..." style="height: 28px;"></textarea>
  208. <textarea placeholder="请输入链接网址..." style="height: 28px;"></textarea>
  209. <textarea placeholder="广告注释:支持HTML代码" style="height: 64px;"></textarea>
  210. <div class="operation">
  211. <a href="javascript:void(0);">&nbsp;&nbsp;</a>
  212. <a href="javascript:void(0);">&nbsp;&nbsp;</a>
  213. <a style="width: 32%;" href="javascript:void(0);">&nbsp;&nbsp;</a>
  214. </div>
  215. </div>
  216. </div>
  217. </div>
  218. </div>
  219. <!-- 上传图片显示的样板 end -->
  220. </dd>
  221. </dl>
  222. <dl class="row 1615775137_dl" style="display: none;" id="1615775137_2" style="z-index: 2">
  223. <dt class="tit"> <label for="type">广告内容</label> </dt>
  224. <dd class="opt">
  225. <input type="hidden" name="video_id" {eq name="$ad_data.0.media_type" value="2"} value="{$ad_data.0.id}" {/eq} class="input-txt">
  226. <input type="text" name="video_litpic" id="video_litpic" {eq name="$ad_data.0.media_type" value="2"} value="{$ad_data.0.litpic}" {/eq} class="input-txt">
  227. <input type="file" id="courseware_file" data-type='local' onchange="upload_video_litpic_1615775137(this)" style="display: none;">
  228. {eq name="$WeappOpen.qny_open" value="1"}
  229. &nbsp;<a href="javascript:void(0);" class="ncap-btn ncap-btn-green" id="upload_video_litpic_qiniu" onclick="$('#courseware_file').attr('data-type', 'qiniu').trigger('click');">七牛云上传</a>
  230. {/eq}
  231. {eq name="$WeappOpen.oss_open" value="1"}
  232. &nbsp;<a href="javascript:void(0);" class="ncap-btn ncap-btn-green" id="upload_video_litpic_oss" onclick="$('#courseware_file').attr('data-type', 'oss').trigger('click');">oss上传</a>
  233. {/eq}
  234. {eq name="$WeappOpen.cos_open" value="1"}
  235. &nbsp;<a href="javascript:void(0);" class="ncap-btn ncap-btn-green" id="upload_video_litpic_cos" onclick="$('#courseware_file').attr('data-type', 'cos').trigger('click');">cos上传</a>
  236. {/eq}
  237. &nbsp;<a href="javascript:void(0);" class="ncap-btn ncap-btn-green " id="upload_video_litpic_local" onclick="$('#courseware_file').attr('data-type', 'local').trigger('click');">本地上传</a>
  238. <input type="hidden" id="OpenPreviewVideoUrl" value="{:url('ZcdjPosition/open_preview_video')}">
  239. &nbsp;<a href="javascript:void(0);" class="ncap-btn ncap-btn-green" id="PreviewVideo" onclick="OpenPreviewVideo();">预览</a>
  240. </dd>
  241. </dl>
  242. <dl class="row 1615775137_dl" style="display: none;" id="1615775137_3" style="z-index: 2">
  243. <dt class="tit"> <label for="type">广告内容</label> </dt>
  244. <dd class="opt">
  245. <input type="hidden" name="html_id" {eq name="$ad_data.0.media_type" value="3"} value="{$ad_data.0.id}" {/eq} class="input-txt">
  246. <textarea rows="5" cols="60" id="html_intro" name="html_intro" style="height: 200px;">{eq name="$ad_data.0.media_type" value="3"}{$ad_data.0.intro}{/eq}</textarea>
  247. <span class="err"></span>
  248. <p class="notic"></p>
  249. </dd>
  250. </dl>
  251. <dl class="row">
  252. <dt class="tit">
  253. <label>备注信息</label>
  254. </dt>
  255. <dd class="opt">
  256. <textarea rows="5" cols="60" id="intro" name="intro" style="height:60px;">{$field.intro}</textarea>
  257. <span class="err"></span>
  258. <p class="notic"></p>
  259. </dd>
  260. </dl>
  261. <div class="bot">
  262. <input type="hidden" name="id" id="1615775137_id" value="{$field.id}">
  263. <a href="JavaScript:void(0);" onclick="checkForm();" class="ncap-btn-big ncap-btn-green" id="submitBtn">确认提交</a>
  264. </div>
  265. </div>
  266. </form>
  267. </div>
  268. <script type="text/javascript">
  269. var SelectedType = '{$field.type}';
  270. $(function() {
  271. // 新增时,广告类型默认选中图片类型
  272. // $('#type'+SelectedType).prop('checked', 'checked');
  273. // 新增时,默认显示图片上传
  274. //$('#1615775137_'+SelectedType).show();
  275. // 多媒体类型 && 广告内容不为空 则执行显示 否则 执行隐藏
  276. VideoLitpicValue('#video_litpic');
  277. });
  278. // 切换广告类型
  279. function TypeSwitch(typeValue) {
  280. // 隐藏全部类型内容
  281. $('.1615775137_dl').hide();
  282. // 显示指定类型内容
  283. $('#1615775137_'+typeValue).show();
  284. // 切换类型后设置为当前切换的类型
  285. SelectedType = typeValue;
  286. // var ad_type = '{$field.type}';
  287. // if (typeValue != ad_type) {
  288. // // 切换至不同类型则显示
  289. // $('.notic2').show();
  290. // } else {
  291. // // 切换至相同类型则隐藏
  292. // $('.notic2').hide();
  293. // }
  294. }
  295. // 多媒体类型 && 广告内容不为空 则执行显示 否则 执行隐藏
  296. function VideoLitpicValue(obj) {
  297. // 获取广告内容(多媒体为播放链接)
  298. // var video_litpic = $(obj).val();
  299. // 判断隐藏显示预览按钮if (2 == SelectedType && video_litpic)
  300. if (2 == SelectedType) {
  301. $('#PreviewVideo').show();
  302. } else {
  303. $('#PreviewVideo').hide();
  304. }
  305. }
  306. // 打开预览视频
  307. function OpenPreviewVideo() {
  308. // 获取视频链接
  309. var video_litpic = $('#video_litpic').val();
  310. if (video_litpic == '') {
  311. $('#video_litpic').focus();
  312. showErrorMsg('请先上传视频');
  313. return false;
  314. }
  315. /* 视频链接后缀验证处理 */
  316. var fileExt = video_litpic.substr(video_litpic.lastIndexOf('.')).toLowerCase();
  317. var fileExt = judgeExt(fileExt);
  318. if (fileExt == -1) {
  319. $('#video_litpic').focus();
  320. showErrorMsg('不支持的视频格式,可在附件设置中修改');
  321. return false;
  322. }
  323. /* END */
  324. /* 视频链接是否存在斜杠处理 */
  325. var fileInfo = video_litpic.lastIndexOf('/');
  326. if (fileInfo == -1) {
  327. $('#video_litpic').focus();
  328. showErrorMsg('视频链接不完整,无法正常预览');
  329. return false;
  330. }
  331. /* END */
  332. // 打开视频播放
  333. $.ajax({
  334. type : 'post',
  335. url : $('#OpenPreviewVideoUrl').val(),
  336. data : {video_litpic: video_litpic},
  337. dataType : 'json',
  338. success : function(res) {
  339. if (1 == res.code) {
  340. var PreviewVideo = "<video style='width:100%; height:100%;' src='"+res.url+"' controls preload='auto' oncontextmenu='return fase' autoplay></video>";
  341. layer.open({
  342. type: 1,
  343. title: false,
  344. fixed: true, //不固定
  345. shadeClose: false,
  346. shade: layer_shade,
  347. area: ['80%', '80%'],
  348. content: PreviewVideo
  349. });
  350. } else {
  351. showErrorMsg(res.msg);
  352. }
  353. },
  354. error: function(e) {
  355. showErrorAlert(e.responseText);
  356. }
  357. });
  358. }
  359. // 上传媒体文件
  360. function upload_video_litpic_1615775137(e) {
  361. var data_type = $(e).attr('data-type');
  362. if ('qiniu' == data_type) {
  363. // 七牛云上传
  364. upload_video_litpic_qiniu(e);
  365. } else if ('oss' == data_type) {
  366. // OSS上传
  367. upload_video_litpic_oss(e);
  368. } else if ('cos' == data_type) {
  369. // COS上传
  370. upload_video_litpic_cos(e);
  371. } else {
  372. // 本地上传
  373. upload_video_litpic_local(e);
  374. }
  375. }
  376. // 七牛云上传
  377. function upload_video_litpic_qiniu(e) {
  378. // 获取文件路径名
  379. var file = $(e)[0].files[0];
  380. // 验证上传格式
  381. var fileName = file.name;
  382. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  383. var ext = judgeExt(fileExt);
  384. if (ext == -1) {
  385. showErrorMsg('不支持选中的视频格式,可在附件设置中修改');
  386. return false;
  387. }
  388. // 验证上传大小
  389. var size = "{$upload_max_filesize}";
  390. if (file.size > size) {
  391. showErrorMsg('视频大小超过限制,可在附件设置中修改');
  392. return false;
  393. }
  394. // 执行上传
  395. layer_loading('上传七牛云');
  396. $.ajax({
  397. type: 'POST',
  398. url: '__ROOT_DIR__/index.php?m=plugins&c=Qiniuyun&a=qiniu_upload',
  399. data: {_ajax: 1},
  400. dataType: "JSON",
  401. success: function(res1) {
  402. if (1 == res1.code) {
  403. var token = res1.data.token;
  404. var formData = new FormData();
  405. formData.append('file', file);
  406. formData.append('token', token);
  407. fileName = res1.data.filePath + fileExt;
  408. formData.append('key', fileName);
  409. $.ajax({
  410. url: res1.data.uphost,
  411. type: 'POST',
  412. dataType: 'JSON',
  413. data: formData,
  414. timeout: 1200000,
  415. cache: false,
  416. processData: false,
  417. contentType: false,
  418. xhr: function () {
  419. myXhr = $.ajaxSettings.xhr();
  420. if (myXhr.upload) {
  421. myXhr.upload.addEventListener('progress', function(e){
  422. var curr = e.loaded;
  423. var total = e.total;
  424. process = parseInt(curr / total * 100);
  425. $("#upload_video_litpic_qiniu").text('上传中...'+process+"%");
  426. });
  427. }
  428. return myXhr;
  429. },
  430. success: function(res2) {
  431. layer.closeAll();
  432. $("#upload_video_litpic_qiniu").text('上传成功');
  433. setTimeout(function() {
  434. $('#upload_video_litpic_qiniu').text('七牛云上传');
  435. }, 2000);
  436. var video_url = res1.data.domain + "/" + res2.key;
  437. $("#video_litpic").empty().val(video_url);
  438. },
  439. error: function(e) {
  440. layer.closeAll();
  441. showErrorMsg(e.responseText);
  442. return false;
  443. }
  444. });
  445. } else {
  446. layer.closeAll();
  447. showErrorMsg(res1.msg);
  448. }
  449. },
  450. error: function(e) {
  451. layer.closeAll();
  452. showErrorMsg(e.responseText);
  453. }
  454. });
  455. }
  456. // 阿里云OSS上传
  457. function upload_video_litpic_oss(e) {
  458. // 获取文件路径名
  459. var file = $(e)[0].files[0];
  460. // 验证上传格式
  461. var fileName = file.name;
  462. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  463. var ext = judgeExt(fileExt);
  464. if (ext == -1) {
  465. showErrorMsg('不支持选中的视频格式,可在附件设置中修改');
  466. return false;
  467. }
  468. // 验证上传大小
  469. var size = "{$upload_max_filesize}";
  470. if (file.size > size) {
  471. showErrorMsg('视频大小超过限制,可在附件设置中修改');
  472. return false;
  473. }
  474. // 执行上传
  475. layer_loading('上传阿里云OSS');
  476. $.ajax({
  477. type: 'POST',
  478. url: '__ROOT_DIR__/index.php?m=plugins&c=AliyunOss&a=oss_upload',
  479. data: {_ajax: 1},
  480. dataType: "JSON",
  481. success: function(res1){
  482. if (1 == res1.code){
  483. fileName = res1.data.filePath + fileExt;
  484. //组装发送数据
  485. var request = new FormData();
  486. request.append("OSSAccessKeyId",res1.data.accessid);
  487. request.append("policy",res1.data.policy);
  488. request.append("Signature",res1.data.signature);
  489. request.append("key",fileName);
  490. request.append("success_action_status",201);
  491. request.append('file', file);
  492. $.ajax({
  493. url : res1.data.host,
  494. data : request,
  495. processData: false,
  496. cache: false,
  497. contentType: false,
  498. dataType: 'xml',
  499. type : 'post',
  500. xhr: function () {
  501. myXhr = $.ajaxSettings.xhr();
  502. if (myXhr.upload) {
  503. myXhr.upload.addEventListener('progress', function(e){
  504. var curr = e.loaded;
  505. var total = e.total;
  506. var process = parseInt(curr / total * 100);
  507. $("#upload_video_litpic_oss").text('上传中...'+process+"%");
  508. });
  509. }
  510. return myXhr;
  511. },
  512. success : function(data) {
  513. layer.closeAll();
  514. var res = $(data).find('PostResponse');
  515. if (res) {
  516. var key = res.find('Key').text();
  517. $("#upload_video_litpic_oss").text('上传成功');
  518. setTimeout(function() {
  519. $('#upload_video_litpic_oss').text('oss上传');
  520. }, 2000);
  521. var video_url = res1.data.domain + "/" + key;
  522. $("#video_litpic").val(video_url);
  523. } else {
  524. $("#upload_video_litpic_oss").text('上传失败');
  525. setTimeout(function() {
  526. $('#upload_video_litpic_oss').text('oss上传');
  527. }, 2000);
  528. }
  529. },
  530. error : function(e) {
  531. layer.closeAll();
  532. console.log(e.responseText);
  533. }
  534. });
  535. } else {
  536. layer.closeAll();
  537. showErrorMsg(res1.msg);
  538. }
  539. },
  540. error: function(e) {
  541. layer.closeAll();
  542. showErrorMsg(e.responseText);
  543. }
  544. });
  545. }
  546. // 腾讯云COS上传
  547. function upload_video_litpic_cos(e) {
  548. // 获取文件路径名
  549. var file = $(e)[0].files[0];
  550. // 验证上传格式
  551. var fileName = file.name;
  552. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  553. var ext = judgeExt(fileExt);
  554. if (ext == -1) {
  555. showErrorMsg('不支持选中的视频格式,可在附件设置中修改');
  556. return false;
  557. }
  558. // 验证上传大小
  559. var size = "{$upload_max_filesize}";
  560. if (file.size > size) {
  561. showErrorMsg('视频大小超过限制,可在附件设置中修改');
  562. return false;
  563. }
  564. // 上传参数
  565. var formData = new FormData();
  566. formData.append('file', file);
  567. formData.append('file_ext', fileExt);
  568. // 执行上传
  569. $.ajax({
  570. type: 'post',
  571. url: '__ROOT_DIR__/index.php?m=plugins&c=Cos&a=cos_upload&_ajax=1',
  572. data: formData,
  573. contentType: false,
  574. processData: false,
  575. dataType: 'json',
  576. xhr: function () {
  577. myXhr = $.ajaxSettings.xhr();
  578. if (myXhr.upload) {
  579. myXhr.upload.addEventListener('progress', function(e){
  580. var curr = e.loaded;
  581. var total = e.total;
  582. process = parseInt(curr / total * 100);
  583. if (100 == process) {
  584. process = 99;
  585. layer_loading('上传腾讯云COS');
  586. }
  587. $("#upload_video_litpic_cos").text('上传中...'+process+"%");
  588. });
  589. }
  590. return myXhr;
  591. },
  592. success: function(res) {
  593. layer.closeAll();
  594. if (1 == res.code) {
  595. $("#video_litpic").val(res.data.url);
  596. $("#upload_video_litpic_cos").text('上传成功');
  597. } else {
  598. $("#upload_video_litpic_cos").text('上传失败');
  599. }
  600. setTimeout(function() {
  601. $('#upload_video_litpic_cos').text('cos上传');
  602. }, 2000);
  603. },
  604. error: function(e) {
  605. layer.closeAll();
  606. showErrorMsg(e.responseText);
  607. }
  608. });
  609. }
  610. // 本地上传
  611. function upload_video_litpic_local(e) {
  612. // 获取文件路径名
  613. var file = $(e)[0].files[0];
  614. // 验证上传格式
  615. var fileName = file.name;
  616. var fileExt = fileName.substr(fileName.lastIndexOf('.')).toLowerCase();
  617. var ext = judgeExt(fileExt);
  618. if (ext == -1) {
  619. showErrorMsg('不支持选中的视频格式,可在附件设置中修改');
  620. return false;
  621. }
  622. // 验证上传大小
  623. var size = "{$upload_max_filesize}";
  624. if (file.size > size) {
  625. showErrorMsg('视频大小超过限制,可在附件设置中修改');
  626. return false;
  627. }
  628. // 定义上传数据
  629. var formData = new FormData();
  630. formData.append('file', file);
  631. // 执行上传
  632. layer_loading('上传本地');
  633. $.ajax({
  634. type: 'post',
  635. url : "{:url('Ueditor/upVideo', ['savepath'=>'media'])}",
  636. data: formData,
  637. contentType: false,
  638. processData: false,
  639. dataType: 'json',
  640. xhr: function () {
  641. myXhr = $.ajaxSettings.xhr();
  642. if (myXhr.upload) {
  643. myXhr.upload.addEventListener('progress', function(e){
  644. var curr = e.loaded;
  645. var total = e.total;
  646. process = parseInt(curr / total * 100);
  647. $("#upload_video_litpic_local").html('上传中...'+process+"%");
  648. });
  649. }
  650. return myXhr;
  651. },
  652. success: function (res) {
  653. layer.closeAll();
  654. $("#upload_video_litpic_local").html('上传成功');
  655. setTimeout(function() {
  656. $('#upload_video_litpic_local').html('本地上传');
  657. }, 2000);
  658. if ("SUCCESS" == res.state) {
  659. $("#video_litpic").val(res.url);
  660. } else {
  661. showErrorMsg(res.msg);
  662. }
  663. }
  664. });
  665. }
  666. // 验证格式
  667. function judgeExt(ext) {
  668. var type = "{$media_type}";
  669. var extArr = [];
  670. extArr = type.split("|");
  671. var ext = ext.replace(".","");
  672. return extArr.indexOf(ext);
  673. }
  674. </script>
  675. <script type="text/javascript">
  676. // 勾选新窗口打开链接
  677. function CheckedTarget(t){
  678. if ($(t).is(':checked')) {
  679. $(t).parent().find('input[name="img_target[]"]').val(1);
  680. }else{
  681. $(t).parent().find('input[name="img_target[]"]').val(0);
  682. }
  683. }
  684. // 鼠标事件,加载查看大图和更新图片
  685. function upimgMouseover(obj)
  686. {
  687. $(obj).find('div.icaction').show();
  688. $(obj).find('div.cover-bg').show();
  689. }
  690. function upimgMouseout(obj)
  691. {
  692. $(obj).find('div.icaction').hide();
  693. $(obj).find('div.cover-bg').hide();
  694. }
  695. // 检测广告名称是否存在重复
  696. function DetectionTitleRepeat(obj) {
  697. // 当前广告ID
  698. var id = $('#1615775137_id').val();
  699. // 传入的广告名称
  700. var title = $(obj).val();
  701. // 执行检测
  702. $.ajax({
  703. type: 'post',
  704. url : "{:url('ZcdjPosition/detection_title_repeat', ['_ajax'=>1])}",
  705. data: {id: id, title: title},
  706. dataType: 'json',
  707. success: function(res) {
  708. if (0 == res.code) {
  709. $('#title_tips').show().html(res.msg);
  710. } else {
  711. $('#title_tips').hide().html('');
  712. }
  713. },
  714. error: function(e){
  715. layer.closeAll();
  716. showErrorAlert(e.responseText);
  717. }
  718. });
  719. }
  720. // 判断输入框是否为空
  721. function checkForm(){
  722. if($('input[name=title]').val() == ''){
  723. layer.msg('广告位名称不能为空!', {icon: 2,time: 1000});
  724. return false;
  725. }
  726. if($('input[name=type]').val() == ''){
  727. layer.msg('分类不能为空,请添加二级分类!', {icon: 2,time: 1000});
  728. return false;
  729. }
  730. /*if($('#selectTest').val() == '1'){
  731. var checkedValues = [];
  732. $('#post_form input[type=checkbox]:checked').each(function() {
  733. checkedValues.push($(this).val());
  734. });
  735. console.log(checkedValues); // 打印选中的checkbox值
  736. if(checkedValues.length > 0){
  737. }else{
  738. layer.msg('请选择地区!', {icon: 2,time: 1000});
  739. return false;
  740. }
  741. }*/
  742. //打印
  743. /*console.log($('#post_form').serialize());
  744. return false;*/
  745. layer_loading('正在处理');
  746. $.ajax({
  747. type : 'post',
  748. url : "{:url('ZcdjPosition/edit', ['_ajax'=>1])}",
  749. data : $('#post_form').serialize(),
  750. dataType : 'json',
  751. success : function(res){
  752. layer.closeAll();
  753. if (res.code == 1) {
  754. layer.msg(res.msg, {icon: 1, shade: layer_shade, time: 1000}, function(){
  755. window.location.reload();
  756. });
  757. } else {
  758. showErrorMsg(res.msg);
  759. }
  760. },
  761. error: function(e){
  762. layer.closeAll();
  763. showErrorAlert(e.responseText);
  764. }
  765. });
  766. }
  767. // 获取点击更新图片的ID并加载隐藏域
  768. function LoadImagesId(id){
  769. // 加载ID到隐藏域
  770. $('#ImagesId').val(id);
  771. // 调用图片上传JS
  772. GetUploadify(1,'','allimg','UpdataImages');
  773. }
  774. // 更新图片
  775. function UpdataImages(path){
  776. // 获取点击的ID
  777. var id = $('#ImagesId').val();
  778. // 加载图片到显示层
  779. $("#"+id+"_Id").attr('src', path);
  780. // 加载图片到提交的隐藏域
  781. $("#"+id+"_Litpic").val(path);
  782. }
  783. // 显示信息输入框
  784. function ShowInput(id) {
  785. var obj = $("#"+id+"_ShowInput");
  786. var showOrHide = obj.attr('data-showOrHide');
  787. if ('hide' == showOrHide) {
  788. obj.show().attr('data-showOrHide', 'show');
  789. } else {
  790. obj.hide().attr('data-showOrHide', 'hide');
  791. }
  792. }
  793. // 隐藏信息输入
  794. function HideInput(id) {
  795. $("#"+id+"_ShowInput").hide().attr('data-showOrHide', 'hide');
  796. }
  797. // 上传图集相册回调函数
  798. function imgupload_call_back(paths){
  799. var last_div = $(".images_upload_tpl").html();
  800. var inputs = $('.span_input input');
  801. var timestamp = 0;
  802. // 图片数据处理
  803. for (var i=0; i<paths.length; i++) {
  804. // 生成新的时间戳
  805. timestamp = (new Date()).getTime();
  806. // 插入一个 新图片
  807. $(".images_upload:eq(0)").before(last_div);
  808. // 处理他的链接地址
  809. $(".images_upload:eq(0)").find('span:eq(0)').attr('onclick', "Images('"+paths[i]+"', 900, 600);");
  810. // 处理信息显示隐藏按钮
  811. $(".images_upload:eq(0)").find('span:eq(1)').attr('onclick', "ShowInput('"+timestamp+"');");
  812. // 处理他的图片路径
  813. $(".images_upload:eq(0)").find('img').attr('src', paths[i]);
  814. // 处理删除按钮
  815. $(".images_upload:eq(0)").find('a:eq(1)').attr('onclick', "ClearPicArr(this, '"+paths[i]+"', 0);");
  816. // 处理图片信息框ID
  817. $(".images_upload:eq(0)").find('.load_input:eq(0)').attr('id', timestamp+'_ShowInput');
  818. // 处理图片路径及隐藏域
  819. if (inputs.length > 0) {
  820. // 修改隐藏域
  821. $(".images_upload:eq(0)").find('input:eq(0)').attr('name', 'img_id[]').attr('value', '');
  822. $(".span_input:eq(0)").find('input:eq(0)').attr('name', 'img_litpic[]').attr('value', paths[i]);
  823. // 处理标题
  824. $(".images_upload:eq(0)").find('textarea:eq(0)').attr('name', 'img_title[]');
  825. // 处理跳转链接
  826. $(".images_upload:eq(0)").find('textarea:eq(1)').attr('name', 'img_links[]');
  827. // 处理内容描述
  828. $(".images_upload:eq(0)").find('textarea:eq(2)').attr('name', 'img_intro[]');
  829. // 处理新窗口选项
  830. $(".images_upload:eq(0)").find('div.operation a:eq(0)').html("<label><input type='checkbox' title='在新窗口打开' onclick='CheckedTarget(this);'/>新窗口<input type='hidden' name='img_target[]' value='0'></label>");
  831. // 处理收回按钮
  832. $(".images_upload:eq(0)").find('div.operation a:eq(2)').attr('onclick', "HideInput('"+timestamp+"');").attr('title', "收回").html('<i style="font-size:16px;" class="fa fa-angle-double-up"></i>');
  833. }
  834. }
  835. }
  836. // 上传之后删除组图input
  837. function ClearPicArr(obj, path, id) {
  838. // 删除数据库记录
  839. $.ajax({
  840. type:'POST',
  841. url:"{:url('ZcdjPosition/del_imgupload')}",
  842. data:{del_id:id,_ajax:1},
  843. success:function(){
  844. $(obj).parent().parent().parent().remove(); // 删除完服务器的, 再删除 html上的图片
  845. $.ajax({
  846. type:'POST',
  847. url:"{:url('Uploadimgnew/delupload')}",
  848. data:{action:"del", filename:path,_ajax:1},
  849. success:function(){}
  850. });
  851. }
  852. });
  853. }
  854. // 代码调用js
  855. function copyToClipBoard(id) {
  856. var adstr = "{eyou:ad aid='" + id + "'}\r\n <a href='{$"+"field.links}' {$"+"field.target}><img src='{$"+"field.litpic}' alt='{$"+"field.title}' /></a>\r\n 广告注释:{$"+"field.intro}\r\n{/eyou:ad";
  857. var contentdiv = '<div class="dialog_content" style="margin: 0px; padding: 0px;"><dl style="padding:10px 30px;line-height:30px"><dd>标签 ad 调用:</dd>';
  858. contentdiv += '<textarea rows="4" cols="60" style="width:400px;height:100px;">' + adstr + '}</textarea>';
  859. contentdiv += '<dd style="border-top: dotted 1px #E7E7E7; color: #F60;">请将对应标签代码复制并粘贴到对应模板文件中!</dd></dl></div>';
  860. layer.open({
  861. title: '代码调用',
  862. type: 1,
  863. shade: layer_shade,
  864. skin: 'layui-layer-demo',
  865. area: ['480px', '260px'], //宽高
  866. content: contentdiv
  867. });
  868. }
  869. // 图集相册的拖动排序相关 js
  870. $( ".sort-list" ).sortable({
  871. start: function( event, ui) {
  872. }
  873. ,stop: function( event, ui ) {
  874. }
  875. });
  876. //因为他们要拖动,所以尽量设置他们的文字不能选择。
  877. // $( ".sort-list" ).disableSelection();
  878. </script>
  879. {include file="public/footer" /}