選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

propertyUserField.vue 1.5KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <template>
  2. <div class="form-group row">
  3. <div class="col-md-4 mb-2" v-for="(currentField, i) in fields" :key="i">
  4. <label>{{ currentField.name }}</label>
  5. <input
  6. v-if="currentField.type === 'number'"
  7. class="form-control form-control-lg form-control-a"
  8. type="number"
  9. name="currentField.name"
  10. id="currentField.id"
  11. v-model="setFields[i]"
  12. @change="UpdateSetFields(currentField, i)"
  13. />
  14. <input
  15. v-if="currentField.type === 'text'"
  16. class="form-control form-control-lg form-control-a"
  17. type="text"
  18. name="currentField.name"
  19. id="currentField.id"
  20. v-model="setFields[i]"
  21. @change="UpdateSetFields(currentField, i)"
  22. />
  23. <div v-if="currentField.type === 'yesno'">
  24. <select
  25. class="form-control form-control-lg form-control-a"
  26. id="currentField.id"
  27. v-model="setFields[i]"
  28. @change="UpdateSetFields(currentField, i)"
  29. >
  30. <option value="yes">Yes</option>
  31. <option value="no">No</option>
  32. </select>
  33. </div>
  34. </div>
  35. </div>
  36. </template>
  37. <script>
  38. export default {
  39. name: 'UserDefinedField',
  40. props: {
  41. fields: { type: Array, default: () => [] },
  42. },
  43. data() {
  44. return {
  45. setFields: [],
  46. };
  47. },
  48. methods: {
  49. UpdateSetFields(field, index) {
  50. const item = {
  51. userDefinedFieldId: field.id,
  52. value: this.setFields[index],
  53. };
  54. this.$emit('UpdateUserDefinedFields', item);
  55. },
  56. },
  57. };
  58. </script>