ai-form-field-number.vue 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <template>
  2. <ie-form-picker :label="rule.label" :placeholder="placeholder" :remark="rule.description"
  3. :model-value="formModel[rule.fieldName]" disable-arrow @click="handleShowKeyboard"/>
  4. <uv-keyboard ref="keyboard" :mode="keyboardMode" :dot-disabled="rule.dotDisable" :tips="localValue"
  5. @confirm="handleValueConfirm" @change="handleValueChange" @backspace="handleValueDelete"/>
  6. </template>
  7. <script>
  8. import AIFormRuleField from "@/pages/ie/components/ai-form/items/templates/AIFormRuleField";
  9. import IeFormPicker from "@/pages/ie/components/picker/ie-form-picker.vue";
  10. export default {
  11. name: "ai-form-field-number",
  12. components: {IeFormPicker},
  13. mixins: [AIFormRuleField],
  14. computed: {
  15. placeholder() {
  16. return this.rule.placeholder || '请输入'
  17. },
  18. keyboardMode() {
  19. const supports = ['number', 'card', 'car']
  20. const {keyboardMode} = this.rule
  21. if (keyboardMode && !supports.includes(keyboardMode)) console.log('error keyboard mode in render rule:', keyboardMode)
  22. return supports.includes(keyboardMode) ? keyboardMode : 'number'
  23. }
  24. },
  25. data() {
  26. return {
  27. localValue: ''
  28. }
  29. },
  30. methods: {
  31. handleShowKeyboard() {
  32. this.localValue = ''
  33. this.$refs.keyboard.open()
  34. },
  35. handleValueChange(val) {
  36. this.localValue += val
  37. },
  38. handleValueDelete() {
  39. const {length} = this.localValue
  40. if (length) this.localValue = this.localValue.substring(0, length - 1)
  41. },
  42. handleValueConfirm() {
  43. this.formModel[this.rule.fieldName] = this.localValue
  44. this.$refs.keyboard.close()
  45. this.clearValidate()
  46. }
  47. }
  48. }
  49. </script>
  50. <style scoped>
  51. </style>