lib.js 14 KB

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