Geen omschrijving

feedback-page-work.js 3.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. (function(mui, window, document, undefined) {
  2. mui.init();
  3. var get = function(id) {
  4. return document.getElementById(id);
  5. };
  6. var qsa = function(sel) {
  7. return [].slice.call(document.querySelectorAll(sel));
  8. };
  9. var ui = {
  10. question: get('question'),
  11. contact: get('contact'),
  12. imageList: get('image-list'),
  13. submit: get('submit')
  14. };
  15. ui.clearForm = function() {
  16. ui.question.value = '';
  17. ui.contact.value = '';
  18. ui.imageList.innerHTML = '';
  19. ui.newPlaceholder();
  20. };
  21. ui.getFileInputArray = function() {
  22. return [].slice.call(ui.imageList.querySelectorAll('input[type="file"]'));
  23. };
  24. ui.getFileInputIdArray = function() {
  25. var fileInputArray = ui.getFileInputArray();
  26. var idArray = [];
  27. fileInputArray.forEach(function(fileInput) {
  28. if(fileInput.value != '') {
  29. idArray.push(fileInput.getAttribute('id'));
  30. }
  31. });
  32. return idArray;
  33. };
  34. var imageIndexIdNum = 0;
  35. ui.newPlaceholder = function() {
  36. var fileInputArray = ui.getFileInputArray();
  37. if(fileInputArray &&
  38. fileInputArray.length > 0 &&
  39. fileInputArray[fileInputArray.length - 1].parentNode.classList.contains('space')) {
  40. return;
  41. }
  42. imageIndexIdNum++;
  43. var placeholder = document.createElement('div');
  44. placeholder.setAttribute('class', 'image-item space');
  45. var closeButton = document.createElement('div');
  46. closeButton.setAttribute('class', 'image-close');
  47. closeButton.innerHTML = 'X';
  48. closeButton.addEventListener('click', function(event) {
  49. event.stopPropagation();
  50. event.cancelBubble = true;
  51. setTimeout(function() {
  52. ui.imageList.removeChild(placeholder);
  53. }, 0);
  54. return false;
  55. }, false);
  56. var fileInput = document.createElement('input');
  57. fileInput.setAttribute('type', 'file');
  58. fileInput.setAttribute('class', 'image-box ');
  59. fileInput.setAttribute('capture', 'camera');
  60. fileInput.setAttribute('accept', 'image/*');
  61. fileInput.setAttribute('id', 'image-' + imageIndexIdNum);
  62. fileInput.addEventListener('change', function(event) {
  63. var file = fileInput.files[0];
  64. var lengh = document.getElementsByClassName("image-item").length;
  65. if(lengh <6) {
  66. if(file) {
  67. var filename = $("#image-" + imageIndexIdNum).val();
  68. fileName = filename.split("\\")[2];
  69. // alert(fileName);
  70. var reader = new FileReader();
  71. reader.onload = function() {
  72. //处理 android 4.1 兼容问题
  73. var base64 = reader.result.split(',')[1];
  74. var dataUrl = 'data:image/png;base64,' + base64;
  75. var usercode = localStorage.getItem("user"); //获取本地存储
  76. placeholder.style.backgroundImage = 'url(' + dataUrl + ')';
  77. $.ajax({
  78. type: "post",
  79. url: huayi.config.callcenter_url + 'Index/UploadCL64',
  80. async: true,
  81. dataType: 'json',
  82. data: {
  83. dataurl: dataUrl,
  84. usercode: localStorage.getItem("user"),
  85. filename:fileName,
  86. token:localStorage.getItem("token")
  87. },
  88. success: function(data) {
  89. if(data.state == "success") {
  90. fileInput.setAttribute('indexs', data.data.F_Id);
  91. mui.toast('上传成功');
  92. } else {
  93. mui.alert(data.message);
  94. }
  95. }
  96. });
  97. }
  98. reader.readAsDataURL(file);
  99. placeholder.classList.remove('space');
  100. ui.newPlaceholder();
  101. }
  102. }else{
  103. mui.toast('最多上传五张');
  104. }
  105. }, false);
  106. placeholder.appendChild(closeButton);
  107. placeholder.appendChild(fileInput);
  108. ui.imageList.appendChild(placeholder);
  109. };
  110. ui.newPlaceholder();
  111. })(mui, window, document, undefined);