index.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. const getTime = require("../../utils/getTime"),
  2. deleteMark = require("../../utils/Check");
  3. Component({
  4. /**
  5. * 组件的属性列表
  6. */
  7. properties: {
  8. fromList: {
  9. type: Array,
  10. value: []
  11. },
  12. CompletedOrNot: Function, //完成与否回调
  13. },
  14. options: {
  15. multipleSlots: true
  16. },
  17. /**
  18. * 组件的初始数据
  19. */
  20. data: {
  21. endTime: "", //结束时间
  22. selectTime: "", //选择时间
  23. sexActions: [{
  24. name: '男'
  25. }, {
  26. name: '女'
  27. }],
  28. seleteSexShow: false
  29. },
  30. lifetimes: {
  31. attached: function () {
  32. this.setData({
  33. endTime: getTime.formatTime(new Date(), '-').split(' ')[0]
  34. })
  35. }
  36. },
  37. /**
  38. * 组件的方法列表
  39. */
  40. methods: {
  41. /* 性别选择器 */
  42. seleteSex(e) {
  43. this.setData({
  44. seleteSexShow: true
  45. })
  46. },
  47. handleSex(e) {
  48. let index = this.data.fromList.findIndex(v => v.type == 'sex');
  49. if (index) this.setData({
  50. ['fromList[' + index + '].value']: e.detail.name,
  51. seleteSexShow: false
  52. })
  53. console.log(this.data.fromList[index])
  54. },
  55. cancel() {
  56. this.setData({
  57. seleteSexShow: false
  58. })
  59. },
  60. /* 输入 */
  61. inputChange(e) {
  62. let {
  63. index,
  64. item
  65. } = e.currentTarget.dataset;
  66. item.value = deleteMark.queryStr(e.detail);
  67. item.error = item.required && item.value == '' ? true : false;
  68. let fromList = this.data.fromList;
  69. fromList[index] = item;
  70. if (item.callback) item.callback(item);
  71. this.setData({
  72. fromList
  73. })
  74. this.statistics();
  75. },
  76. /* 日期选择器 */
  77. bindDateChange(e) {
  78. const {
  79. index
  80. } = e.currentTarget.dataset;
  81. let fromList = this.data.fromList;
  82. fromList[index].value = e.detail.value;
  83. fromList[index].error = false;
  84. this.setData({
  85. fromList
  86. })
  87. this.statistics();
  88. },
  89. /* 清空输入框 */
  90. inputClear(e) {
  91. console.log("清空", e.target.dataset.item.label)
  92. this.statistics();
  93. },
  94. /* 统计是否完成全部必填项 */
  95. statistics() {
  96. let list = this.data.fromList,
  97. sumCount = 0,
  98. count = 0;
  99. for (let i = 0; i < list.length; i++) {
  100. if (list[i].required) {
  101. sumCount++;
  102. if (list[i].value != "") count++;
  103. }
  104. }
  105. // console.log("必填总数", sumCount, '已填', count)
  106. this.triggerEvent("CompletedOrNot", sumCount == count)
  107. },
  108. /* 提交 */
  109. getData() {
  110. let list = this.data.fromList,
  111. returnData = {},
  112. isReturn = true;
  113. for (let i = 0; i < list.length; i++) {
  114. if (list[i].required && list[i].value == "") {
  115. list[i].error = true;
  116. isReturn = false;
  117. } else {
  118. returnData[list[i].valueName] = list[i].value;
  119. }
  120. }
  121. this.setData({
  122. fromList: list
  123. })
  124. return {
  125. returnData,
  126. isReturn
  127. }
  128. }
  129. }
  130. })