index.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. const verify = require('../../utils/deleteMark');
  2. Component({
  3. externalClasses: [],
  4. properties: {
  5. form: {
  6. type: Array
  7. },
  8. showAll: {
  9. type: Boolean,
  10. value: true
  11. }, //不显示必填项
  12. onConfirm: {
  13. type: Function
  14. },
  15. interrupt: {
  16. type: Function
  17. }, //打断处理,用于条件判断 把form返回到上个页面处理重新传入
  18. },
  19. lifetimes: {
  20. attached: function () {
  21. getApp().globalData.Language.getLanguagePackage(this)
  22. this.setData({
  23. languagecode:wx.getStorageSync('languagecode')
  24. })
  25. },
  26. },
  27. data: {
  28. temporary: null, //route选择暂存选中项
  29. voiceIndex: null,
  30. seconds: 60,
  31. },
  32. options: {
  33. multipleSlots: true //允许使用多个slot
  34. },
  35. methods: {
  36. onVoiceInput(e) {
  37. this.setData({
  38. [`form[${e.currentTarget.dataset.index}].value`]: e.detail
  39. });
  40. this.confirm();
  41. },
  42. toOptions(e) {
  43. const {
  44. item
  45. } = e.currentTarget.dataset;
  46. wx.navigateTo({
  47. url: '/packageA/options/index?data=' + JSON.stringify(item),
  48. })
  49. },
  50. route(e) {
  51. const {
  52. item
  53. } = e.currentTarget.dataset;
  54. if (item.disabled) return;
  55. getApp().globalData.handleSelect = this.handleRoute.bind(this);
  56. let result = (item.query && !item.query.indexOf("radio=true") && item.value[1]) ? `` : `&result=${JSON.stringify(item.value[1])}`
  57. wx.navigateTo({
  58. url: item.url + '?params=' + JSON.stringify(item.params) + (item.query || '') + result,
  59. fail(err) {
  60. console.log(err)
  61. }
  62. });
  63. this.setData({
  64. temporary: {
  65. item: item,
  66. index: this.data.form.findIndex(v => v.valueName == item.valueName)
  67. }
  68. })
  69. },
  70. /* 处理路由返回结果 */
  71. handleRoute(data) {
  72. let temporary = this.data.temporary;
  73. if (temporary.item.interrupt) {
  74. this.triggerEvent("interrupt", {
  75. data,
  76. form: this.data.form,
  77. temporary
  78. });
  79. } else {
  80. wx.navigateBack();
  81. this.setData({
  82. [`form[${temporary.index}].value`]: data.value
  83. });
  84. this.confirm()
  85. };
  86. this.data.temporary = null;
  87. },
  88. onBlur(e) {
  89. let item = e.target.dataset.item,
  90. index = this.data.form.findIndex(v => v.valueName === item.valueName);
  91. if (item.interrupt) this.triggerEvent("interrupt", {
  92. data: this.data.form[index],
  93. form: this.data.form,
  94. temporary: {
  95. item,
  96. index
  97. }
  98. });
  99. },
  100. /* 改变值 */
  101. inputChange(e) {
  102. let item = e.target.dataset.item,
  103. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  104. value = e.detail;
  105. //校验规则 不填:不校验 "base":默认校验 "phone":手机号 "mail":邮箱 "telephone":固定电话 "正则表达式":以自定义内容为校验标准
  106. if (item.checking) {
  107. let reg = item.checking;
  108. switch (item.checking) {
  109. case 'base':
  110. value = verify.queryStr(value);
  111. break;
  112. case 'phone':
  113. reg = /^1(3[0-9]|4[01456879]|5[0-35-9]|6[2567]|7[0-8]|8[0-9]|9[0-35-9])\d{8}$/;
  114. this.setData({
  115. [`form[${index}].errMsg`]: !reg.test(value) ? getApp().globalData.Language.getMapText('号码格式错误') || '请输入正确的11位手机号码!' : ''
  116. });
  117. break;
  118. case "telephone":
  119. let i = e.target.dataset.i;
  120. value = item.value;
  121. value[i] = e.detail.value;
  122. let result = value[0] + "-" + value[1];
  123. reg = /^0\d{2,3}-[1-9]\d{6,7}$/
  124. this.setData({
  125. [`form[${index}].errMsg`]: !reg.test(result) ? getApp().globalData.Language.getMapText('号码格式错误') || '请填写正确的座机电话' : '',
  126. [`form[${index}].result`]: result,
  127. });
  128. break;
  129. case 'mail':
  130. reg = /^([A-Za-z0-9_\-\.])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,4})$/;
  131. this.setData({
  132. [`form[${index}].errMsg`]: !reg.test(value) ? getApp().globalData.Language.getMapText('请输入正确的邮箱格式') : ''
  133. });
  134. break;
  135. case 'twoDecimalPlaces':
  136. reg = /^(\d+(?:\.\d{0,2})?)?$/;
  137. this.setData({
  138. [`form[${index}].errMsg`]: !reg.test(value) ? '仅允许保留2位小数' : ''
  139. });
  140. break;
  141. default:
  142. reg = new RegExp(reg);
  143. this.setData({
  144. [`form[${index}].errMsg`]: !reg.test(value) ? item.hint || getApp().globalData.Language.getMapText('输入文本不符合条件!') || '输入文本不符合条件!' : ''
  145. });
  146. break;
  147. };
  148. };
  149. this.setData({
  150. [`form[${index}].value`]: value,
  151. [`form[${index}].error`]: false,
  152. });
  153. if (!item.required && value == '') this.setData({
  154. [`form[${index}].errMsg`]: "",
  155. });
  156. this.confirm();
  157. },
  158. /* 单列选择器 */
  159. bindSelectorChange(e) {
  160. let {
  161. item,
  162. index
  163. } = e.target.dataset,
  164. value = e.detail.value;
  165. this.setData({
  166. [`form[${index}].value`]: item.range[value][item.selectKey||item.rangeKey],
  167. [`form[${index}].rangeIndex`]: value,
  168. [`form[${index}].error`]: false,
  169. });
  170. if (item.interrupt) this.triggerEvent("interrupt", {
  171. data: this.data.form[index],
  172. form: this.data.form,
  173. temporary: {
  174. item,
  175. index
  176. }
  177. });
  178. this.confirm();
  179. },
  180. /* 日期,时间 选择器 */
  181. bindDateChange(e) {
  182. let item = e.target.dataset.item,
  183. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  184. value = e.detail.value;
  185. this.setData({
  186. [`form[${index}].value`]: value,
  187. [`form[${index}].error`]: false,
  188. });
  189. if (item.interrupt) this.triggerEvent("interrupt", {
  190. data: this.data.form[index],
  191. form: this.data.form,
  192. temporary: {
  193. item,
  194. index
  195. }
  196. });
  197. this.confirm();
  198. },
  199. /* 时间范围选择器 */
  200. rangeDateChange(e) {
  201. let item = e.target.dataset.item,
  202. i = e.target.dataset.index,
  203. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  204. value = e.detail.value;
  205. this.setData({
  206. [`form[${index}].value[${i}]`]: value,
  207. [`form[${index}].error`]: false,
  208. });
  209. this.confirm();
  210. },
  211. /* 省市县 */
  212. bindRegionChange(e) {
  213. let item = e.currentTarget.dataset.item,
  214. index = this.data.form.findIndex(v => v.valueName === item.valueName),
  215. value = e.detail.value;
  216. this.setData({
  217. [`form[${index}].value`]: value,
  218. [`form[${index}].error`]: false,
  219. });
  220. this.confirm();
  221. },
  222. /* 自定义选项 */
  223. setOption(item) {
  224. let i = this.data.form.findIndex(v => v.valueName == item.valueName);
  225. this.setData({
  226. [`form[${i}].value`]: item.value
  227. });
  228. this.confirm();
  229. },
  230. /* 是否完成必填项 */
  231. confirm() {
  232. this.triggerEvent("onConfirm", this.data.form.some(v => {
  233. if (v.type == "dateRange" && v.required) {
  234. return v.value[0] == "" || v.value[1] == "";
  235. } else {
  236. return v.required && v.value == '';
  237. }
  238. }))
  239. },
  240. /* 性别 */
  241. sexChange(e) {
  242. let item = e.currentTarget.dataset.item,
  243. index = this.data.form.findIndex(v => v.valueName === item.valueName);
  244. this.setData({
  245. [`form[${index}].value`]: e.detail,
  246. [`form[${index}].error`]: false,
  247. });
  248. this.confirm();
  249. },
  250. /* 单选 选择器改变 */
  251. radioChange(e) {
  252. let item = e.currentTarget.dataset.item,
  253. index = this.data.form.findIndex(v => v.valueName == item.valueName);
  254. if (this.data.form[index].value == e.detail) return;
  255. this.setData({
  256. [`form[${index}].value`]: e.detail,
  257. [`form[${index}].error`]: false,
  258. });
  259. if (item.interrupt) this.triggerEvent("interrupt", {
  260. data: this.data.form[index],
  261. form: this.data.form,
  262. temporary: {
  263. item,
  264. index
  265. }
  266. });
  267. this.confirm();
  268. },
  269. /* 提交 */
  270. submit() {
  271. let obj = {},
  272. isPass = false;
  273. this.data.form.forEach((v, i) => {
  274. obj[v.valueName] = v.value;
  275. // permit 无视errMsg 允许通过
  276. if (!v.permit && v.errMsg != '') {
  277. this.setData({
  278. [`form[${i}].error`]: true
  279. });
  280. isPass = true;
  281. }
  282. });
  283. if (isPass) {
  284. wx.showToast({
  285. title: getApp().globalData.Language.getMapText('请检查表单内容'),
  286. icon: "none"
  287. })
  288. } else {
  289. return obj;
  290. }
  291. },
  292. /* 查询结果 不验证是否必填 */
  293. query() {
  294. let obj = {};
  295. this.data.form.forEach(v => obj[v.valueName] = v.value);
  296. return obj;
  297. }
  298. }
  299. })