index.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. var component_1 = require('./../common/component.js');
  4. component_1.VantComponent({
  5. field: true,
  6. classes: ['input-class', 'plus-class', 'minus-class'],
  7. props: {
  8. value: null,
  9. integer: Boolean,
  10. disabled: Boolean,
  11. inputWidth: String,
  12. asyncChange: Boolean,
  13. disableInput: Boolean,
  14. min: {
  15. type: null,
  16. value: 1
  17. },
  18. max: {
  19. type: null,
  20. value: Number.MAX_SAFE_INTEGER
  21. },
  22. step: {
  23. type: null,
  24. value: 1
  25. },
  26. showPlus: {
  27. type: Boolean,
  28. value: true
  29. },
  30. showMinus: {
  31. type: Boolean,
  32. value: true
  33. }
  34. },
  35. computed: {
  36. minusDisabled: function minusDisabled() {
  37. return this.data.disabled || this.data.value <= this.data.min;
  38. },
  39. plusDisabled: function plusDisabled() {
  40. return this.data.disabled || this.data.value >= this.data.max;
  41. }
  42. },
  43. watch: {
  44. value: function value(_value) {
  45. if (_value === '') {
  46. return;
  47. }
  48. var newValue = this.range(_value);
  49. if (typeof newValue === 'number' && +this.data.value !== newValue) {
  50. this.set({ value: newValue });
  51. }
  52. }
  53. },
  54. data: {
  55. focus: false
  56. },
  57. created: function created() {
  58. this.set({
  59. value: this.range(this.data.value)
  60. });
  61. },
  62. methods: {
  63. onFocus: function onFocus(event) {
  64. this.$emit('focus', event.detail);
  65. },
  66. onBlur: function onBlur(event) {
  67. var value = this.range(this.data.value);
  68. this.triggerInput(value);
  69. this.$emit('blur', event.detail);
  70. },
  71. // limit value range
  72. range: function range(value) {
  73. value = String(value).replace(/[^0-9.-]/g, '');
  74. return Math.max(Math.min(this.data.max, value), this.data.min);
  75. },
  76. onInput: function onInput(event) {
  77. var _a = (event.detail || {}).value,
  78. value = _a === void 0 ? '' : _a;
  79. this.triggerInput(value);
  80. },
  81. onChange: function onChange(type) {
  82. if (this.data[type + "Disabled"]) {
  83. this.$emit('overlimit', type);
  84. return;
  85. }
  86. var diff = type === 'minus' ? -this.data.step : +this.data.step;
  87. var value = Math.round((+this.data.value + diff) * 100) / 100;
  88. this.triggerInput(this.range(value));
  89. this.$emit(type);
  90. },
  91. onMinus: function onMinus() {
  92. this.onChange('minus');
  93. },
  94. onPlus: function onPlus() {
  95. this.onChange('plus');
  96. },
  97. triggerInput: function triggerInput(value) {
  98. this.set({
  99. value: this.data.asyncChange ? this.data.value : value
  100. });
  101. this.$emit('change', value);
  102. }
  103. }
  104. });
  105. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["Object","value","component_1","require","field","classes","props","integer","disabled","inputWidth","asyncChange","disableInput","min","type","max","Number","MAX_SAFE_INTEGER","step","showPlus","showMinus","computed","minusDisabled","plusDisabled","watch","newValue","data","focus","created","methods","onFocus","event","onBlur","range","String","Math","onInput","_a","onChange","diff","onMinus","onPlus","triggerInput"],"mappings":"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","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar component_1 = require(\"../common/component\");\ncomponent_1.VantComponent({\n    field: true,\n    classes: [\n        'input-class',\n        'plus-class',\n        'minus-class'\n    ],\n    props: {\n        value: null,\n        integer: Boolean,\n        disabled: Boolean,\n        inputWidth: String,\n        asyncChange: Boolean,\n        disableInput: Boolean,\n        min: {\n            type: null,\n            value: 1\n        },\n        max: {\n            type: null,\n            value: Number.MAX_SAFE_INTEGER\n        },\n        step: {\n            type: null,\n            value: 1\n        },\n        showPlus: {\n            type: Boolean,\n            value: true\n        },\n        showMinus: {\n            type: Boolean,\n            value: true\n        }\n    },\n    computed: {\n        minusDisabled: function () {\n            return this.data.disabled || this.data.value <= this.data.min;\n        },\n        plusDisabled: function () {\n            return this.data.disabled || this.data.value >= this.data.max;\n        }\n    },\n    watch: {\n        value: function (value) {\n            if (value === '') {\n                return;\n            }\n            var newValue = this.range(value);\n            if (typeof newValue === 'number' && +this.data.value !== newValue) {\n                this.set({ value: newValue });\n            }\n        }\n    },\n    data: {\n        focus: false\n    },\n    created: function () {\n        this.set({\n            value: this.range(this.data.value)\n        });\n    },\n    methods: {\n        onFocus: function (event) {\n            this.$emit('focus', event.detail);\n        },\n        onBlur: function (event) {\n            var value = this.range(this.data.value);\n            this.triggerInput(value);\n            this.$emit('blur', event.detail);\n        },\n        // limit value range\n        range: function (value) {\n            value = String(value).replace(/[^0-9.-]/g, '');\n            return Math.max(Math.min(this.data.max, value), this.data.min);\n        },\n        onInput: function (event) {\n            var _a = (event.detail || {}).value, value = _a === void 0 ? '' : _a;\n            this.triggerInput(value);\n        },\n        onChange: function (type) {\n            if (this.data[type + \"Disabled\"]) {\n                this.$emit('overlimit', type);\n                return;\n            }\n            var diff = type === 'minus' ? -this.data.step : +this.data.step;\n            var value = Math.round((+this.data.value + diff) * 100) / 100;\n            this.triggerInput(this.range(value));\n            this.$emit(type);\n        },\n        onMinus: function () {\n            this.onChange('minus');\n        },\n        onPlus: function () {\n            this.onChange('plus');\n        },\n        triggerInput: function (value) {\n            this.set({\n                value: this.data.asyncChange ? this.data.value : value\n            });\n            this.$emit('change', value);\n        }\n    }\n});\n"],"file":"index.js"}