index.js 3.7 KB

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