AddVersion.vue 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. <template>
  2. <div>
  3. <crumbs :title="title" linkTo="/admin/LT-YXSJWH-BBXXWH"></crumbs>
  4. <div class="contents">
  5. <div class="content">
  6. <!-- <el-form ref="form" :label-position="labelPosition" label-width="95px" class="add-admin-form" :model="form" :rules="rules"> -->
  7. <el-form ref="form" :label-position="labelPosition" label-width="95px" class="add-version-form" :model="form" :rules="rules">
  8. <el-form-item label="版本号:" prop="name" class="version-num">
  9. <el-input v-model="form.name" placeholder="请输入版本号" maxlength="21"></el-input>
  10. </el-form-item>
  11. <el-form-item label="版本时间:" prop="refreshTime">
  12. <el-date-picker
  13. v-model="form.refreshTime"
  14. type="date"
  15. placeholder="选择日期"
  16. :picker-options="pickerOptions1"
  17. value-format="yyyy-MM-dd"
  18. :clearable='false'>
  19. </el-date-picker>
  20. </el-form-item>
  21. <el-form-item label="版本备注:" prop="remark" class="discDesc">
  22. <el-input type="textarea" :rows="3" placeholder="请输入版本备注" v-model="form.remark" maxlength="121"></el-input>
  23. </el-form-item>
  24. <el-form-item label="版本说明:" v-if="list&&list.length>0">
  25. </el-form-item>
  26. <VersionDesc :detail="list" :versionId="id" :isFirst="isFirst" :isCopy="copy" @func="getDetailList"/>
  27. <el-button class="disclButn" size="small" type="primary" @click="comfirn('form')">确定</el-button>
  28. </el-form>
  29. <!-- <VersionDesc :detail="list" :versionId="id" :isFirst="isFirst" :isCopy="copy" @func="getDetailList"/>
  30. <el-button class="disclButn" size="small" type="primary" @click="comfirn">确定</el-button> -->
  31. </div>
  32. </div>
  33. </div>
  34. </template>
  35. <script type="text/javascript">
  36. import api from '@api/icss.js';
  37. import VersionDesc from './VersionDesc.vue';
  38. export default {
  39. name:'AddVersion',
  40. data(){
  41. const titleVaild = (rule, value, callback) => {
  42. if (!value) {
  43. return callback(new Error('请输入版本号'));
  44. }
  45. if (value.length > 20) {
  46. this.form.name = value.substr(0, 20);
  47. this.$message({
  48. showClose: true,
  49. type: 'warning',
  50. message: '版本号已超过最大限制20字'
  51. })
  52. }
  53. callback();
  54. };
  55. const remarkVaild = (rule, value, callback) => {
  56. if (value.length > 120) {
  57. this.form.remark = value.substr(0, 120);
  58. this.$message({
  59. showClose: true,
  60. type: 'warning',
  61. message: '版本备注已超过最大限制120字'
  62. })
  63. }
  64. callback();
  65. };
  66. return{
  67. // data:{},
  68. list:[],
  69. labelPosition:'left',
  70. isFirst:true,
  71. title:'版本信息维护-添加版本信息',
  72. form:{
  73. name:'',
  74. refreshTime:'',
  75. remark:''
  76. },
  77. id:null,
  78. rules:{
  79. name:[{ required: true, validator: titleVaild, trigger: [ 'change'] },
  80. { required: true, message: '请输入版本号',trigger: ['blur', 'change'] }],
  81. remark:{ required: false, validator: remarkVaild, trigger: [ 'change'] },
  82. refreshTime:{ required: true, message: '请选择时间', trigger: ['blur', 'change'] }
  83. },
  84. pickerOptions1:{
  85. disabledDate(time) {
  86. return time.getTime() < Date.now();
  87. },
  88. },
  89. copy:null
  90. }
  91. },
  92. created(){
  93. let info = this.$route.params.info;
  94. this.copy = this.$route.params.copy;
  95. if(info){
  96. this.id = info.id;
  97. this.form.name = info.name;
  98. this.form.refreshTime = info.refreshTime;
  99. this.form.remark = info.remark;
  100. this.title = this.copy?"版本信息维护-复制版本信息":"版本信息维护-修改版本信息";
  101. // this.getList();
  102. this.list = info.detail;
  103. }
  104. },
  105. methods:{
  106. /*getList(){
  107. api.getVersionDetlInfo({id:this.id}).then((res)=>{
  108. const result = res.data;
  109. if(result.code==0){
  110. this.list = result.data;
  111. }else{
  112. this.$message({
  113. message:result.msg,
  114. type:'warning'
  115. });
  116. }
  117. })
  118. },*/
  119. getDetailList(data){//子组件数据
  120. this.list = data;
  121. },
  122. comfirn(form){
  123. /*if(!this.form.name.trim() || !this.form.refreshTime.trim()){
  124. this.$message({
  125. message:'请填写相关内容',
  126. type:'warning'
  127. });
  128. return
  129. }*/
  130. this.$refs[form].validate((valid) => {
  131. if (valid) {
  132. if(this.id && !this.copy){//修改
  133. const param = Object.assign({},this.form,{id:this.id})
  134. api.updateVersInfo(param).then((res)=>{
  135. if(res.data.code==0){
  136. this.$message({
  137. message:"修改成功",
  138. type:'success'
  139. })
  140. this.$router.push({path: 'LT-YXSJWH-BBXXWH'});
  141. }else{
  142. this.$message({
  143. message:res.data.msg,
  144. type:'warning'
  145. });
  146. }
  147. })
  148. }else{//添加
  149. // 复制时把list多余字段过滤掉,如id等
  150. const detail = this.list;
  151. let copyDetail=[];
  152. let item={};
  153. if(detail && detail.length>0){
  154. for(let i=0; i<detail.length; i++){
  155. item.title = detail[i].title;
  156. item.description = detail[i].description;
  157. copyDetail.push(item);
  158. item={};
  159. }
  160. }
  161. const params = Object.assign({},this.form,{'versionDetail':copyDetail});
  162. // api.addVersInfo(this.form).then((res)=>{
  163. api.addVersInfo(params).then((res)=>{
  164. if(res.data.code==0){
  165. this.$message({
  166. message:"添加成功",
  167. type:'success'
  168. })
  169. this.$router.push({path: 'LT-YXSJWH-BBXXWH'});
  170. }else{
  171. this.$message({
  172. message:res.data.msg,
  173. type:'warning'
  174. });
  175. }
  176. })
  177. }
  178. } else {
  179. return false;
  180. }
  181. });
  182. },
  183. },
  184. components:{
  185. VersionDesc
  186. }
  187. }
  188. </script>
  189. <style lang="less">
  190. @import "../../less/admin.less";
  191. .content{
  192. background: #fff;
  193. // padding: 20px 20px 30px;
  194. padding: 20px 20px 50px;
  195. color: #545455;
  196. min-width: 980px;
  197. position: relative;
  198. .discDesc{
  199. margin-bottom: 20px;
  200. }
  201. .disclButn{
  202. position: absolute;
  203. right: 80px;
  204. bottom: 10px;
  205. }
  206. }
  207. .add-version-form{
  208. .version-num{
  209. width: 500px;
  210. }
  211. }
  212. </style>