Brak opisu

importCustomers.html 7.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <link href="../js/bootstrap-select/css/bootstrap-select.css" rel="stylesheet" />
  6. <script src="../Script/Common/huayi.load.js"></script>
  7. <script src="../Script/Common/huayi.config.js"></script>
  8. <title>导入客户信息</title>
  9. <style>
  10. .btn-success {
  11. color: #fff;
  12. background-color: #1ab394;
  13. border-color: #4cae4c;
  14. border-radius: 4px;
  15. cursor: pointer;
  16. }
  17. .btn-success.active,
  18. .btn-success:active,
  19. .btn-success:focus,
  20. .btn-success:hover {
  21. border-color: #4cae4c;
  22. background-color: #1ab394;
  23. }
  24. .btn-success[disabled],
  25. .btn-success[disabled]:active,
  26. .btn-success[disabled]:focus,
  27. .btn-success[disabled]:hover {
  28. background-color: #1ab394;
  29. }
  30. #importNum {
  31. width: 130px;
  32. margin: 60px auto 0 auto;
  33. }
  34. .progress {
  35. width: 80%;
  36. margin: 20px auto 0 auto;
  37. display: none;
  38. }
  39. div.drop_down {
  40. position: relative;
  41. line-height: 34px;
  42. }
  43. .drop_down .caret {
  44. position: absolute;
  45. right: 10px;
  46. top: 15px;
  47. }
  48. .form-group {
  49. margin-bottom: 10px!important;
  50. }
  51. @media (min-width: 768px) {
  52. .drop_down .form-control {
  53. width: 818px;
  54. }
  55. }
  56. </style>
  57. </head>
  58. <body>
  59. <div style="padding: 10px; margin-bottom: 20px;">
  60. <div class="alert alert-info" role="alert">
  61. <span class="glyphicon glyphicon-exclamation-sign" aria-hidden="true"></span>
  62. <span class="sr-only">tips:</span> 上传文件需要严格按照下载的EXCEL模板进行填写!上传后点击导入即可!
  63. </div>
  64. <div class="form-inline clearfix">
  65. <!--<div class="form-group">
  66. <select class="form-control selectpicker" id="head_form_rengin" data-live-search="true">
  67. <option value="0">请选择区域</option>
  68. </select>
  69. </div>
  70. <div class="form-group">
  71. <select class="form-control selectpicker" id="head_form_pro" data-live-search="true">
  72. <option value="0">请选择项目</option>
  73. </select>
  74. </div>
  75. <div class="form-group">
  76. <select class="form-control selectpicker" id="head_form_floor" data-live-search="true">
  77. <option value="0">请选择期号</option>
  78. </select>
  79. </div>-->
  80. <div class="form-group">
  81. <a id="excelMod" class="btn btn-success form-control" title="点击下载EXCEL模板" href="javascript:void(0)" onclick="ExcelMod()" rel="nofollow">下载EXCEL模板</a>
  82. </div>
  83. <div class="form-group">
  84. <input class="hidden" type="file" id="upFile" name="upFile" accept=".csv, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel,application/x-xls,application/x-xlsx" />
  85. <input class="form-control btn btn-success" title="点击上传Excel文件" type="button" value="上传Excel文件" id="upFileExcel" />
  86. <span class="excelName"></span>
  87. </div>
  88. </div>
  89. <div class="progress">
  90. <div class="progress-bar progress-bar-striped" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100">
  91. </div>
  92. </div>
  93. <div class="form-group text-center">
  94. <input type="button" id="importNum" class="form-control btn btn-success" value="导入" />
  95. </div>
  96. </div>
  97. <script src="../js/bootstrap-select/js/bootstrap-select.js"></script>
  98. <script src="../js/bootstrap-select/js/i18n/defaults-zh_CN.js"></script>
  99. <script>
  100. var percents = 0; //长传文件进度值
  101. $(document).ready(function() {
  102. //上传EXCEL文件
  103. $("#upFileExcel").click(function() {
  104. $("#upFile").trigger("click");
  105. });
  106. $("#upFile").change(function() {
  107. var Files = document.getElementById("upFile").files;
  108. $('.excelName').html(Files[0].name); //文件名称
  109. });
  110. $("#importNum").click(function() {
  111. uploads();
  112. });
  113. });
  114. //下载模板
  115. function ExcelMod() {
  116. window.location.href = "CustomerList_Excel.xlsx";
  117. }
  118. //上传Excel文件 模拟实时进度
  119. function uploads() {
  120. var txtName = $('.excelName').text();
  121. if(txtName == '') {
  122. layer.confirm('你还没有上传文件', {
  123. icon: 2,
  124. btn: ['确定']
  125. });
  126. return;
  127. }
  128. //一般情况下,excel后缀是".xls",在2007以及以后的版本中又增加了".xlsx"。excel的模板文件后缀名是".xlt",启动宏的工作簿后缀名是".xlsm"。
  129. if(txtName.indexOf('.xls') != -1 ||
  130. txtName.indexOf('.xlsx') != -1 ||
  131. txtName.indexOf('.xlt') != -1 ||
  132. txtName.indexOf('.xlsm') != -1
  133. ) {
  134. var formData = new FormData();
  135. var Files = document.getElementById("upFile").files;
  136. formData.append("upFile", Files[0]); //是 HttpPostedFile Excel文件
  137. formData.append("token", $.cookie("token"));
  138. // alert(JSON.stringify(Files))
  139. $.ajax({
  140. url: huayi.config.callcenter_url + "CustomerNew/ImportExcel",
  141. type: "POST",
  142. data: formData,
  143. /**
  144. *必须false才会自动加上正确的Content-Type
  145. */
  146. contentType: false,
  147. /**
  148. * 必须false才会避开jQuery对 formdata 的默认处理
  149. * XMLHttpRequest会对 formdata 进行正确的处理
  150. */
  151. processData: false,
  152. xhr: function() {
  153. var xhr = jQuery.ajaxSettings.xhr();
  154. xhr.upload.onload = function() {
  155. updateProgress(88);
  156. }
  157. xhr.upload.onprogress = function(ev) {
  158. updateProgress(70);
  159. }
  160. return xhr;
  161. },
  162. beforeSend: function(request) {
  163. $('.progress').show();
  164. $("#importNum").attr("disabled", true);
  165. $("#importNum").val('导入中...');
  166. updateProgress(50);
  167. },
  168. success: function(result) {
  169. updateProgress(100);
  170. var r = $.parseJSON(result);
  171. $("#importNum").attr("disabled", false);
  172. $("#importNum").val('导入');
  173. if(r.state.toLowerCase() == "success") {
  174. var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
  175. parent.layer.close(index); //再执行关闭
  176. parent.$('#cusList').bootstrapTable('refresh');
  177. parent.layer.alert(r.message, {
  178. icon: 1,
  179. btn: ['确定']
  180. });
  181. }
  182. },
  183. error: function(textStatus) {
  184. percents = 0;
  185. $('.progress').hide();
  186. layer.confirm('网络繁忙,请稍后再试...', {
  187. btn: ['确定'] //按钮
  188. });
  189. $("#importNum").attr("disabled", false);
  190. $("#importNum").val('导入');
  191. },
  192. complete: function(XMLHttpRequest, textStatus) {
  193. percents = 0;
  194. $('.progress').hide();
  195. if(textStatus == 'timeout') {
  196. var xmlhttp = window.XMLHttpRequest ? new window.XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHttp");
  197. xmlhttp.abort();
  198. layer.confirm('网络超时,请稍后再试...', {
  199. btn: ['确定'] //按钮
  200. });    
  201. }
  202. $("#importNum").attr("disabled", false);
  203. $("#importNum").val('导入');
  204. },
  205. });
  206. } else {
  207. layer.confirm('请上传EXCEL文件', {
  208. icon: 2,
  209. btn: ['确定']
  210. });
  211. return;
  212. }
  213. }
  214. //更新进度条
  215. function updateProgress(p) {
  216. while(percents < p) {
  217. percents++;
  218. $('.progress-bar').css('width', percents + '%');
  219. $('.progress-bar').text(percents + '%');
  220. }
  221. }
  222. </script>
  223. </body>
  224. </html>