Ingen beskrivning
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.

add.htm 31KB

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