edit.vue 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. <template>
  2. <div class="cmain" style="overflow: hidden">
  3. <div class="fv">
  4. <div class="f">
  5. <el-form ref="form" :model="form" :rules="rules" label-width="80px">
  6. <el-form-item label="模板名称" prop="title">
  7. <el-input v-model="form.title" placeholder="请输入标题" clearable />
  8. </el-form-item>
  9. <el-form-item label="问题选项" prop="op">
  10. <div class="mbg">
  11. <el-form-item :label="'' + (index + 1)" v-for="(item, index) in form.op" :key="item.key" :prop="'op.' + index + '.name'" :rules="rules.dynamic" class="moptions">
  12. <el-input class="minp" v-model="item.name" placeholder="请输入内容" @input="input()" clearable>
  13. <el-select v-model="item.ifnull" slot="prepend" placeholder="是否必填" style="width: 90px">
  14. <el-option :label="s" :value="s" v-for="s in nulls" :key="s"></el-option>
  15. </el-select>
  16. <el-select v-model="item.input" slot="append" placeholder="请选择" style="width: 101px" @change="change($event, item)">
  17. <el-option :label="s" :value="s" v-for="s in selects" :key="s"></el-option>
  18. </el-select>
  19. </el-input>
  20. <!--问题子选项start-->
  21. <el-form-item v-if="item.input == '单选' || item.input == '多选' || item.input == '判断'" :prop="'op.' + index + '.selects'" :rules="rules.selects" class="selects">
  22. <el-tag v-for="(tag, index) in item.selects" :key="index" :closable="item.input != '判断'" @close="tagClose(item, tag)">{{ tag.name }}</el-tag>
  23. <el-input class="input-new-tag" v-if="item.show" v-model="item.s_value" :ref="'tag' + index" @keyup.enter.native="confirm(item)" @input="input()" @blur="confirm(item)"></el-input>
  24. <el-button v-else class="button-new-tag" v-show="item.input != '判断'" size="small" @click="showInput(item, index)">+ 输入选项</el-button>
  25. </el-form-item>
  26. <!--问题子选项end-->
  27. <div class="mdel" @click="del(item)">移除</div>
  28. <div class="mcopy" @click="copy(item)">复制</div>
  29. </el-form-item>
  30. <div class="addBtn">
  31. <el-button icon="el-icon-plus" @click="add()">添加内容</el-button>
  32. </div>
  33. </div>
  34. </el-form-item>
  35. </el-form>
  36. </div>
  37. <div class="f" style="flex: 0.5">
  38. <div class="div-mc">
  39. <div class="guise-mobile guise-mobile-2">
  40. <div class="guise-mobile-show" ref="scrollbar">
  41. <!--手机展示内容放置区-->
  42. <div class="mttv">{{ form.title }}</div>
  43. <el-divider>开始</el-divider>
  44. <div class="items" v-for="(item, index) in form.op" :key="index">
  45. <div class="vtitle" style="font-weight: normal; font-size: 14px">
  46. <span class="ifnull" v-if="item.ifnull == '必填'">*</span>
  47. <span class="index">{{ index + 1 }},</span>
  48. <span class="tm">{{ item.name }} ({{ item.input }})</span>
  49. </div>
  50. <div class="mts">
  51. <input v-if="item.input == '填空'" placeholder="请输入" :disabled="true" />
  52. <textarea v-if="item.input == '多行文本'" :disabled="true" placeholder="请输入"></textarea>
  53. <input type="number" v-if="item.input == '电话'" placeholder="请输入" :disabled="true" />
  54. <div class="mchoice" v-if="item.input == '单选' || item.input == '多选' || item.input == '判断'">
  55. <div v-if="item.selects.length <= 4">
  56. <div v-for="(op, i) in item.selects" :key="op.name">
  57. <div class="op" :class="{ active: op.check }" @click="check(item, op)">{{ op.name }}</div>
  58. <!--如果选项要输入显示手动输入框-->
  59. <textarea v-if="op.input && op.check" v-model="op.s_value" :placeholder="'请输入' + op.name" style="margin-top: 5px; float: left"></textarea>
  60. </div>
  61. </div>
  62. <div v-else>
  63. <span>点击选择</span>
  64. <i class="el-icon-caret-bottom icon"></i>
  65. </div>
  66. </div>
  67. <div v-if="item.input == '附件'"><el-button style="width: 100%" icon="el-icon-upload">选择文件</el-button></div>
  68. </div>
  69. </div>
  70. <el-divider>结束</el-divider>
  71. <el-button type="primary" style="width: 100%; background-color: #4581fb; border: 0px">提交</el-button>
  72. <!--手机展示内容放置区-->
  73. </div>
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. <div class="mfooter">
  79. <el-button type="primary" @click="submitForm">确 定</el-button>
  80. <el-button @click="$layer.close(layerid)">取 消</el-button>
  81. </div>
  82. </div>
  83. </template>
  84. <script>
  85. export default {
  86. data() {
  87. return {
  88. form: { tag: 1, state: 0, op: [] },
  89. nulls: ['必填', '非必填'],
  90. selects: ['填空', '单选', '多选', '判断', '附件', '多行文本', '电话'],
  91. rules: {
  92. title: [{ required: true, message: '标题不能为空', trigger: 'blur' }],
  93. op: [{ required: true, message: '内容不能为空', trigger: 'blur' }],
  94. dynamic: [
  95. { required: true, message: '请输入问题名称', trigger: 'blur' },
  96. {
  97. validator: (rule, value, callback) => {
  98. this.util.checkSame(this.form, value, callback);
  99. }
  100. }
  101. ],
  102. selects: [{ required: true, message: '请输入问题内容', trigger: 'blur' }]
  103. }
  104. };
  105. },
  106. props: {
  107. param: {
  108. type: Object,
  109. default: () => {
  110. return {};
  111. }
  112. },
  113. layerid: {
  114. type: String
  115. }
  116. },
  117. mounted() {
  118. if (this.param.id) {
  119. this.ajax({ url: '/work/follow/template/detail/' + this.param.id }).then((response) => {
  120. response.data.op = JSON.parse(response.data.op);
  121. this.form = response.data;
  122. });
  123. }
  124. },
  125. methods: {
  126. //添加内容
  127. add() {
  128. this.form.op.push({ name: '', ifnull: '必填', input: '填空', selects: [], show: false });
  129. /* this.$nextTick(() => {
  130. let scrollElem = this.$refs.scrollbar;
  131. scrollElem.scrollTo({ top: scrollElem.scrollHeight, behavior: 'smooth' });
  132. }); */
  133. },
  134. //删除问题
  135. del(item) {
  136. this.form.op.splice(this.form.op.indexOf(item), 1);
  137. },
  138. //复制问题
  139. copy(item) {
  140. this.form.op.push(JSON.parse(JSON.stringify(item)));
  141. this.msgSuccess('已复制');
  142. this.$forceUpdate();
  143. },
  144. //判断只能选择是或否
  145. change(e, item) {
  146. if (item.input == '判断') {
  147. item.selects = [{ name: '是' }, { name: '否' }];
  148. } else {
  149. item.selects = [];
  150. }
  151. },
  152. //解决input有时无法输入的问题
  153. input(e) {
  154. this.$forceUpdate();
  155. },
  156. showInput(item, index) {
  157. item.show = true;
  158. this.$nextTick(() => {
  159. this.$refs['tag' + index][0].$refs.input.focus();
  160. });
  161. this.$forceUpdate();
  162. },
  163. //删除问题子选项
  164. tagClose(item, tag) {
  165. item.selects.splice(item.selects.indexOf(tag), 1);
  166. },
  167. confirm(item) {
  168. if (item.s_value) {
  169. item.selects.push({ name: item.s_value });
  170. item.selects = this.util.duplicate(item.selects);
  171. }
  172. item.show = false;
  173. item.s_value = '';
  174. },
  175. submitForm() {
  176. this.$refs['form'].validate((valid) => {
  177. if (valid) {
  178. let data = JSON.parse(JSON.stringify(this.form));
  179. data.op = JSON.stringify(data.op);
  180. if (this.form.id) {
  181. this.ajax({ method: 'post', url: '/work/follow/template/edit', data: data }).then((response) => {
  182. this.$modal.msgSuccess('修改成功');
  183. this.$layer.close(this.layerid);
  184. this.$parent.getList();
  185. });
  186. } else {
  187. this.ajax({ method: 'post', url: '/work/follow/template/add', data: data }).then((response) => {
  188. this.$modal.msgSuccess('新增成功');
  189. this.$layer.close(this.layerid);
  190. this.$parent.getList();
  191. });
  192. }
  193. }
  194. });
  195. }
  196. }
  197. };
  198. </script>