Ei kuvausta

importknowledge.html 6.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  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. <a id="excelMod" class="btn btn-success form-control" title="点击下载EXCEL模板" href="javascript:void(0)" onclick="ExcelMod()" rel="nofollow">下载EXCEL模板</a>
  67. </div>
  68. <div class="form-group">
  69. <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" />
  70. <input class="form-control btn btn-success" title="点击上传Excel文件" type="button" value="上传Excel文件" id="upFileExcel" />
  71. <span class="excelName"></span>
  72. </div>
  73. </div>
  74. <div class="progress">
  75. <div class="progress-bar progress-bar-striped" role="progressbar" aria-valuenow="0" aria-valuemin="0" aria-valuemax="100">
  76. </div>
  77. </div>
  78. <div class="form-group text-center">
  79. <input type="button" id="importNum" class="form-control btn btn-success" value="导入" />
  80. </div>
  81. </div>
  82. <script src="../js/bootstrap-select/js/bootstrap-select.js"></script>
  83. <script src="../js/bootstrap-select/js/i18n/defaults-zh_CN.js"></script>
  84. <script>
  85. var percents = 0; //长传文件进度值
  86. $(document).ready(function() {
  87. //获取 区域 项目 期号下拉
  88. helper.getDropList.getProLocations($('#head_form_rengin'), $('#head_form_pro'), $('#head_form_floor'));
  89. //上传EXCEL文件
  90. $("#upFileExcel").click(function() {
  91. $("#upFile").trigger("click");
  92. });
  93. $("#upFile").change(function() {
  94. var Files = document.getElementById("upFile").files;
  95. $('.excelName').html(Files[0].name); //文件名称
  96. });
  97. $("#importNum").click(function() {
  98. uploads();
  99. });
  100. });
  101. //下载模板
  102. function ExcelMod() {
  103. window.location.href = huayi.config.callcenter_url + "ExcelMod/KnowledgeInformation.xls";
  104. }
  105. //上传Excel文件 模拟实时进度
  106. function uploads() {
  107. var pid = helper.request.queryString('kn_id');
  108. var txtName = $('.excelName').text();
  109. if(txtName == '') {
  110. layer.confirm('你还没有上传文件', {
  111. icon: 2,
  112. btn: ['确定']
  113. });
  114. return;
  115. }
  116. //一般情况下,excel后缀是".xls",在2007以及以后的版本中又增加了".xlsx"。excel的模板文件后缀名是".xlt",启动宏的工作簿后缀名是".xlsm"。
  117. if(txtName.indexOf('.xls') != -1 ||
  118. txtName.indexOf('.xlsx') != -1 ||
  119. txtName.indexOf('.xlt') != -1 ||
  120. txtName.indexOf('.xlsm') != -1
  121. ) {
  122. var formData = new FormData();
  123. var Files = document.getElementById("upFile").files;
  124. formData.append("upFile", Files[0]); //是 HttpPostedFile Excel文件
  125. formData.append("pid", pid); //是 string 知识库分类
  126. formData.append("token", $.cookie("token"));
  127. $.ajax({
  128. url: huayi.config.callcenter_url + "Knowledge/ImportExcel",
  129. type: "POST",
  130. data: formData,
  131. /**
  132. *必须false才会自动加上正确的Content-Type
  133. */
  134. contentType: false,
  135. /**
  136. * 必须false才会避开jQuery对 formdata 的默认处理
  137. * XMLHttpRequest会对 formdata 进行正确的处理
  138. */
  139. processData: false,
  140. xhr: function() {
  141. var xhr = jQuery.ajaxSettings.xhr();
  142. xhr.upload.onload = function() {
  143. updateProgress(88);
  144. }
  145. xhr.upload.onprogress = function(ev) {
  146. updateProgress(70);
  147. }
  148. return xhr;
  149. },
  150. beforeSend: function(request) {
  151. $('.progress').show();
  152. $("#importNum").attr("disabled", true);
  153. $("#importNum").val('导入中...');
  154. updateProgress(50);
  155. },
  156. success: function(result) {
  157. updateProgress(100);
  158. var r = $.parseJSON(result);
  159. $("#importNum").attr("disabled", false);
  160. $("#importNum").val('导入');
  161. if(r.state.toLowerCase() == "success") {
  162. var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
  163. parent.layer.close(index); //再执行关闭
  164. parent.initTable();
  165. parent.layer.alert(r.message, {
  166. icon: 1,
  167. btn: ['确定']
  168. });
  169. }
  170. },
  171. error: function(textStatus) {
  172. percents = 0;
  173. $('.progress').hide();
  174. layer.confirm('网络繁忙,请稍后再试...', {
  175. btn: ['确定'] //按钮
  176. });
  177. $("#importNum").attr("disabled", false);
  178. $("#importNum").val('导入');
  179. },
  180. complete: function(XMLHttpRequest, textStatus) {
  181. percents = 0;
  182. $('.progress').hide();
  183. if(textStatus == 'timeout') {
  184. var xmlhttp = window.XMLHttpRequest ? new window.XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHttp");
  185. xmlhttp.abort();
  186. layer.confirm('网络超时,请稍后再试...', {
  187. btn: ['确定'] //按钮
  188. });    
  189. }
  190. $("#importNum").attr("disabled", false);
  191. $("#importNum").val('导入');
  192. },
  193. });
  194. } else {
  195. layer.confirm('请上传EXCEL文件', {
  196. icon: 2,
  197. btn: ['确定']
  198. });
  199. return;
  200. }
  201. }
  202. //更新进度条
  203. function updateProgress(p) {
  204. while(percents < p) {
  205. percents++;
  206. $('.progress-bar').css('width', percents + '%');
  207. $('.progress-bar').text(percents + '%');
  208. }
  209. }
  210. </script>
  211. </body>
  212. </html>