78 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| $(document).on('turbolinks:load', function() {
 | |
|   var $modal = $('.modal.admin-import-course-member-modal');
 | |
|   if ($modal.length > 0) {
 | |
|     var $form = $modal.find('form.admin-import-course-member-form');
 | |
| 
 | |
|     var resetFileInputFunc = function(file){
 | |
|       file.after(file.clone().val(""));
 | |
|       file.remove();
 | |
|     }
 | |
| 
 | |
|     $modal.on('show.bs.modal', function(){
 | |
|       $modal.find('.file-names').html('选择文件');
 | |
|       $modal.find('.upload-file-input').trigger('click');
 | |
|     });
 | |
|     $modal.on('hide.bs.modal', function(){
 | |
|       resetFileInputFunc($modal.find('.upload-file-input'));
 | |
|     });
 | |
|     $modal.on('change', '.upload-file-input', function(e){
 | |
|       var file = $(this)[0].files[0];
 | |
|       $modal.find('.file-names').html(file ? file.name : '请选择文件');
 | |
|     })
 | |
| 
 | |
|     var importFormValid = function(){
 | |
|       if($form.find('input[name="file"]').val() == undefined || $form.find('input[name="file"]').val().length == 0){
 | |
|         $form.find('.error').html('请选择文件');
 | |
|         return false;
 | |
|       }
 | |
| 
 | |
|       return true;
 | |
|     };
 | |
| 
 | |
|     var buildResultMessage = function(data){
 | |
|       var messageHtml = "<div>导入结果:成功" + data.success + "条,失败"+ data.fail.length + "条</div>";
 | |
| 
 | |
|       if(data.fail.length > 0){
 | |
|         messageHtml += '<table class="table"><thead class="thead-light"><tr><th>数据</th><th>失败原因</th></tr></thead><tbody>';
 | |
| 
 | |
|         data.fail.forEach(function(item){
 | |
|           messageHtml += '<tr><td>' + item.data + '</td><td>' + item.message + '</td></tr>';
 | |
|         });
 | |
| 
 | |
|         messageHtml += '</tbody></table>'
 | |
|       }
 | |
| 
 | |
|       return messageHtml;
 | |
|     }
 | |
| 
 | |
|     $modal.on('click', '.submit-btn', function(){
 | |
|       $form.find('.error').html('');
 | |
| 
 | |
|       if (importFormValid()) {
 | |
|         $('body').mLoading({ text: '正在导入...' });
 | |
| 
 | |
|         $.ajax({
 | |
|           method: 'POST',
 | |
|           dataType: 'json',
 | |
|           url: '/admins/import_course_members',
 | |
|           data: new FormData($form[0]),
 | |
|           processData: false,
 | |
|           contentType: false,
 | |
|           success: function(data){
 | |
|             $('body').mLoading('destroy');
 | |
|             $modal.modal('hide');
 | |
| 
 | |
|             showMessageModal(buildResultMessage(data), function(){
 | |
|               window.location.reload();
 | |
|             });
 | |
|           },
 | |
|           error: function(res){
 | |
|             $('body').mLoading('destroy');
 | |
|             var data = res.responseJSON;
 | |
|             $form.find('.error').html(data.message);
 | |
|           }
 | |
|         });
 | |
|       }
 | |
|     });
 | |
|   }
 | |
| }); |