lib.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. function upload_icon() {
  2. var upfile = $("#upload_a_icon")[0].files[0];
  3. if (in_login < 1) {
  4. alert("请先登录");
  5. return false;
  6. }
  7. if (upfile.size > 1048576) {
  8. alert("图标不能大于1M");
  9. return false;
  10. }
  11. var fd = new FormData();
  12. fd.append("webview", upfile);
  13. var a_icon_xhr = new XMLHttpRequest();
  14. a_icon_xhr.open("post", in_path + "webview/ajax?fn=" + in_time + "-icon");
  15. a_icon_xhr.onload = complete_a_icon;
  16. a_icon_xhr.onerror = failed_a_icon;
  17. a_icon_xhr.upload.onprogress = progress_a_icon;
  18. a_icon_xhr.send(fd);
  19. }
  20. function progress_a_icon(evt) {
  21. var per = Math.round(evt.loaded / evt.total * 100);
  22. $("#tips_a_icon").text(per + "%");
  23. if (per > 99) {
  24. $("#tips_a_icon").text("请稍等...");
  25. }
  26. }
  27. function complete_a_icon(evt) {
  28. var response = evt.target.responseText;
  29. if (response == "return_0") {
  30. alert("请上传PNG图片");
  31. } else {
  32. $("#preview_a_icon").html('<img width="100" height="100" src="' + in_path + "data/tmp/" + response + '">');
  33. }
  34. }
  35. function failed_a_icon() {
  36. alert("上传异常");
  37. }
  38. function upload_launch() {
  39. var upfile = $("#upload_l_image")[0].files[0];
  40. if (in_login < 1) {
  41. alert("请先登录");
  42. return false;
  43. }
  44. if (upfile.size > 2097152) {
  45. alert("图片不能大于2M");
  46. return false;
  47. }
  48. var fd = new FormData();
  49. fd.append("webview", upfile);
  50. var l_image_xhr = new XMLHttpRequest();
  51. l_image_xhr.open("post", in_path + "webview/ajax?fn=" + in_time + "-launch");
  52. l_image_xhr.onload = complete_l_image;
  53. l_image_xhr.onerror = failed_l_image;
  54. l_image_xhr.upload.onprogress = progress_l_image;
  55. l_image_xhr.send(fd);
  56. }
  57. function progress_l_image(evt) {
  58. var per = Math.round(evt.loaded / evt.total * 100);
  59. $("#tips_l_image").text(per + "%");
  60. if (per > 99) {
  61. $("#tips_l_image").text("请稍等...");
  62. }
  63. }
  64. function complete_l_image(evt) {
  65. var response = evt.target.responseText;
  66. if (response == "return_0") {
  67. alert("请上传PNG图片");
  68. } else {
  69. $("#preview_l_image").html('<img width="200" height="200" src="' + in_path + "data/tmp/" + response + '">');
  70. }
  71. }
  72. function failed_l_image() {
  73. alert("上传异常");
  74. }
  75. function prev_view() {
  76. if (step > 1) {
  77. step--;
  78. $('.step' + step).show().siblings('.step-common').hide();
  79. $("#web_view_btn").text('下一步');
  80. if (step == 1)
  81. $('#prev_view_btn').hide();
  82. $('ul.fz-step-box li').eq(step - 1).addClass('active').siblings().removeClass('active')
  83. }
  84. }
  85. function next_view() {
  86. console.log('下一步');
  87. if (in_login < 1) {
  88. alert("请先登录后再操作!");
  89. return;
  90. }
  91. if (step == 1) {
  92. if ($("#in_title").val() == "") {
  93. $("#in_title").focus();
  94. return;
  95. }
  96. if ($("#in_url").val() == "") {
  97. $("#in_url").focus();
  98. return;
  99. }
  100. if ($("#in_b_color").val() == "") {
  101. $("#in_b_color").focus();
  102. return;
  103. }
  104. if ($("#in_t_color").val() == "") {
  105. $("#in_t_color").focus();
  106. return;
  107. }
  108. step++;
  109. $('.step' + step).show().siblings('.step-common').hide();
  110. $('#prev_view_btn').show();
  111. $('ul.fz-step-box li').eq(step - 1).addClass('active').siblings().removeClass('active')
  112. return;
  113. }
  114. var type = $('input:radio[name=type]:checked').val();
  115. if (step == 2) {
  116. // if ($("#preview_a_icon img").length < 1) {
  117. // alert("请上传应用图标!");
  118. // return;
  119. // }
  120. // if ($("#preview_l_image img").length < 1) {
  121. // alert("请上传启动图片!");
  122. // return;
  123. // }
  124. step++;
  125. $('.step' + step).show().siblings('.step-common').hide();
  126. $('ul.fz-step-box li').eq(step - 1).addClass('active').siblings().removeClass('active')
  127. if (type > 0) $('.ios_unable').hide(); else $('.android_unable').hide();
  128. return;
  129. }
  130. if (step == 3) {
  131. // if (!$('input[name=edit]').val()) {
  132. // step++;
  133. // $('.step' + step).show().siblings('.step-common').hide();
  134. // $('ul.fz-step-box li').eq(step - 1).addClass('active').siblings().removeClass('active')
  135. // return;
  136. // }
  137. step++;
  138. $('.step' + step).show().siblings('.step-common').hide();
  139. $('ul.fz-step-box li').eq(step - 1).addClass('active').siblings().removeClass('active')
  140. if (type > 0) $('.ios_unable').hide(); else $('.android_unable').hide();
  141. return;
  142. }
  143. if (step == 4) {
  144. // if (!$('input[name=edit]').val()) {
  145. // step++;
  146. // $('.step' + step).show().siblings('.step-common').hide();
  147. // $('ul.fz-step-box li').eq(step - 1).addClass('active').siblings().removeClass('active')
  148. // return;
  149. // }
  150. }
  151. var limage = 0;
  152. if($("#preview_l_image img") != undefined && $("#preview_l_image img")[0] != undefined && $("#preview_l_image img")[0].src != undefined)
  153. {
  154. limage = $("#preview_l_image img")[0].src;
  155. }
  156. else
  157. {
  158. }
  159. var param = {
  160. id: $('input[name=id]').val(),
  161. type: type,
  162. title: escape($("#in_title").val()),
  163. url: $("#in_url").val(),
  164. screenOrientation: $("input[name=screenOrientation]:checked").val(),
  165. bundle_id: $("#bundle_id").val(),
  166. version: $("#version").val(),
  167. aicon: $("#preview_a_icon img")[0].src,
  168. limage: limage,
  169. splashTime: $("input[name=splashTime]:checked").val(),
  170. period: $('ul.period>li.active').attr('data-id'),
  171. };
  172. param = getParam(param);
  173. // return console.log(param);
  174. $('.ng-binding').attr("disabled", "disabled");
  175. $("#web_view_btn").text("生成中(勿离开)");
  176. $.post(
  177. in_path + "webview/ajax/webview", param,
  178. function (ret) {
  179. if (ret.code == -1) {
  180. $("#web_view_btn").text("请先登录");
  181. alert("请先登录!");
  182. } else if (ret.code == -2) {
  183. $("#web_view_btn").text("余额不足");
  184. alert("余额不足!", function () {
  185. window.location.href = "/index/item_price";
  186. });
  187. } else if (ret.code == -4) {
  188. $("#web_view_btn").text("应用容量不足!请升级VIP!");
  189. alert("应用容量不足!请升级VIP!", function () {
  190. window.location.href = "/index/item_price?type=2";
  191. });
  192. } else if (ret.data) {
  193. window.location.href = "/index/webview_log?id=" + ret.data.id;
  194. }
  195. }, 'json');
  196. }
  197. function getParam(param) {
  198. param = param || {}
  199. var hasChecked1 = $("#config1").find(".iconfont").hasClass("icon-checkbox-checked1"); // 加载动画
  200. var hasChecked2 = $("#config2").find(".iconfont").hasClass("icon-checkbox-checked1"); // 清理缓存
  201. var hasChecked3 = $("#config3").find(".iconfont").hasClass("icon-checkbox-checked1"); // 浏览器
  202. var hasChecked4 = $("#config4").find(".iconfont").hasClass("icon-checkbox-checked1"); // 退出提示
  203. var hasChecked5 = $("#config5").find(".iconfont").hasClass("icon-checkbox-checked1"); // 第三方分享
  204. var hasChecked6 = $("#config6").find(".iconfont").hasClass("icon-checkbox-checked1"); // 极光推送
  205. var hasChecked7 = $("#config7").find(".iconfont").hasClass("icon-checkbox-checked1"); // 友盟统计
  206. var hasChecked8 = $("#config8").find(".iconfont").hasClass("icon-checkbox-checked1"); // 导航栏
  207. var hasChecked9 = $("#config9").find(".iconfont").hasClass("icon-checkbox-checked1"); // 状态栏
  208. var hasChecked10 = $("#config10").find(".iconfont").hasClass("icon-checkbox-checked1"); // 标题栏
  209. var hasChecked11 = $("#config11").find(".iconfont").hasClass("icon-checkbox-checked1"); // 引导页
  210. var configAsideChecked = $("#configAside").find(".iconfont").hasClass("icon-checkbox-checked1"); // 左侧栏
  211. var longPressSavePictureChecked = $("#configPhotoSave").find(".iconfont").hasClass("icon-checkbox-checked1"); // 长按图片保存
  212. var qrcodeScanChecked = $("#configIdentifyCode").find(".iconfont").hasClass("icon-checkbox-checked1"); // 扫一扫
  213. var webZoomChecked = $("#configWebZoom").find(".iconfont").hasClass("icon-checkbox-checked1"); // 网页缩放
  214. var userAgentChecked = $("#userAgent").find(".iconfont").hasClass("icon-checkbox-checked1");
  215. var isSkidBack = $("#configSkidBack").find(".iconfont").hasClass("icon-checkbox-checked1"); // 侧滑返回
  216. var isNoNet = $("#configNoNet").find(".iconfont").hasClass("icon-checkbox-checked1"); // 无网提示
  217. var isInstallTip = $("#configInstallTip").find(".iconfont").hasClass("icon-checkbox-checked1"); // APK安装器
  218. var isKeepScreen = $("#configKeepScreen").find(".iconfont").hasClass("icon-checkbox-checked1"); // 屏幕常亮
  219. var isHideBottom = $("#configHideBottom").find(".iconfont").hasClass("icon-checkbox-checked1"); // 屏幕常亮
  220. var hasKeystore = $('#configKeystore').find(".iconfont").hasClass("icon-checkbox-checked1"); // 安卓证书
  221. param.supportLongPressSavePicture = 0;
  222. param.supportQrcodeScan = 0;
  223. param.supportZoom = 0;
  224. param.userAgent = {};
  225. param.skidBack = 0;
  226. param.noNet = 0;
  227. param.installTip = 0;
  228. param.keepScreen = 0;
  229. param.hideBottom = 0;
  230. if (longPressSavePictureChecked) param.supportLongPressSavePicture = $("#photoSaveModal").find("ul>li.active").data('photo-save');
  231. if (qrcodeScanChecked) param.supportQrcodeScan = $("#identifyCodeModal").find("ul>li.active").data('identify-code');
  232. if (webZoomChecked) param.supportZoom = $("#webZoomModal").find("ul>li.active").data('web-zoom');
  233. if (userAgentChecked) {
  234. $("#uaModal .plugin-save").trigger('click');
  235. param.userAgent = userAgent;
  236. }
  237. if (isSkidBack) param.skidBack = $("#skidBackModal").find("ul>li.active").data('skid-back');
  238. if (isNoNet) param.noNet = $("#noNetModal").find("ul>li.active").data('no-net');
  239. if (isInstallTip) param.installTip = $("#installTipModal").find("ul>li.active").data('install-tip');
  240. if (isKeepScreen) param.keepScreen = $("#keepScreenModal").find("ul>li.active").data('keep-screen');
  241. if (isHideBottom) param.hideBottom = $("#hideBottomModal").find("ul>li.active").data('hide-bottom');
  242. // 下拉刷新
  243. var hasCheckedRefresh = $("#configRefresh").find(".iconfont").hasClass("icon-checkbox-checked1");
  244. if (hasCheckedRefresh) {
  245. refreshVal = $("#refreshModal").find(".plugin-refresh").find(".active").attr("data-refresh");
  246. param.refresh = refreshVal;
  247. } else {
  248. param.refresh = 0;
  249. }
  250. // URL 拉起APP
  251. var hasCheckedUrlApp = $("#configUrlApp").find(".iconfont").hasClass("icon-checkbox-checked1");
  252. param.urlApp = 0;
  253. if (hasCheckedUrlApp) {
  254. urlAppVal = $("#urlAppModal").find(".plugin-url-app").find(".active").attr("data-url-app");
  255. param.urlApp = urlAppVal;
  256. }
  257. // 加载配置
  258. if (hasChecked1) {
  259. way = $("#loadingModal").find(".plugin-loading").find(".active").attr("data-way");
  260. color = $("#loadingModal").find(".plugin-loading").find(".sp-preview-inner").css("background-color");
  261. color = colorRGB2Hex(color);
  262. param.loading = {way: way, color: color};
  263. } else {
  264. param.loading = {};
  265. }
  266. // 清理缓存
  267. if (hasChecked2) {
  268. param.cache = $("#cacheModal").find(".plugin-cache").find(".active").attr("data-cache");
  269. } else {
  270. param.cache = 0;
  271. }
  272. // 浏览器内核
  273. if (hasChecked3) {
  274. android = $("#browserModal").find("#androidKernel").find(".active").attr("data-android-kernel");
  275. ios = $("#browserModal").find("#iosKernel").find(".active").attr("data-ios-kernel");
  276. param.browser = {android: android, ios: ios}
  277. } else {
  278. param.browser = {};
  279. }
  280. // 退出提示
  281. if (hasChecked4) {
  282. exit = $("#exitModal").find(".plugin-exit").find(".active").attr("data-exit");
  283. param.exit = exit;
  284. } else {
  285. param.exit = 0;
  286. }
  287. // 第三方分享
  288. if (hasChecked5) {
  289. $("#shareModal .plugin-save").trigger('click');
  290. param.share = share;
  291. }
  292. // 极光推送
  293. param.jPushId = '';
  294. if (hasChecked6) {
  295. jPushId = $.trim($('#auroraModal input[name="jPushId"]').val());
  296. if (jPushId) param.jPushId = jPushId;
  297. }
  298. // 友盟统计
  299. param.umengKey = '';
  300. if (hasChecked7) {
  301. umengIosKey = $.trim($('#alliesModal input[name="umeng_ios_key"]').val());
  302. umengAndroidKey = $.trim($('#alliesModal input[name="umeng_android_key"]').val());
  303. param.umengKey = {
  304. ios: umengIosKey,
  305. android: umengAndroidKey
  306. };
  307. }
  308. // 导航栏
  309. param.nav = '';
  310. if (hasChecked8) {
  311. $("#navModal .plugin-save").trigger('click');
  312. param.nav = navData;
  313. }
  314. // 状态标题栏
  315. param.titleBar = '';
  316. param.stateBar = '';
  317. if (hasChecked10) {
  318. $("#titleModal .plugin-save").trigger('click');
  319. param.titleBar = titleBar;
  320. param.stateBar = stateBar;
  321. }
  322. // 侧边栏
  323. param.asideData = '';
  324. if (configAsideChecked) {
  325. $("#asideModal .plugin-save").trigger('click')
  326. param.asideData = asideData;
  327. }
  328. // 引导页
  329. param.guide = {};
  330. if (hasChecked11) {
  331. $("#guideModal .plugin-save").trigger('click');
  332. param.guide = guide;
  333. param.support_guide_enter_main_page_button = supportGuideEnterMainPageButton;
  334. param.guide_enter_main_page_button_color = guideEnterMainPageButtonColor;
  335. }
  336. if (hasKeystore) {
  337. $("#keystoreModal .plugin-save").trigger('click');
  338. delete androidKey.save;
  339. param.androidKey = androidKey;
  340. }
  341. // 是否点击跳过
  342. //var isSkip = $(this).hasClass('skip');
  343. return param;
  344. }