Açıklama Yok
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.

edit.htm 40KB

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