44 lines
664 B
Vue
44 lines
664 B
Vue
|
<template>
|
||
|
<div>
|
||
|
<ui-input class="kudkigyw" v-model="v" :type="value.inputType">{{ value.text }}</ui-input>
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<script lang="ts">
|
||
|
import Vue from 'vue';
|
||
|
|
||
|
export default Vue.extend({
|
||
|
props: {
|
||
|
value: {
|
||
|
required: true
|
||
|
},
|
||
|
script: {
|
||
|
required: true
|
||
|
}
|
||
|
},
|
||
|
|
||
|
data() {
|
||
|
return {
|
||
|
v: this.value.default,
|
||
|
};
|
||
|
},
|
||
|
|
||
|
watch: {
|
||
|
v() {
|
||
|
let v = this.v;
|
||
|
if (this.value.inputType === 'number') v = parseInt(v, 10);
|
||
|
this.script.aiScript.updatePageVar(this.value.name, v);
|
||
|
this.script.reEval();
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
</script>
|
||
|
|
||
|
<style lang="stylus" scoped>
|
||
|
.kudkigyw
|
||
|
display inline-block
|
||
|
min-width 300px
|
||
|
max-width 450px
|
||
|
margin 8px 0
|
||
|
</style>
|