6caea054cfec840911b0897050717f69a2657243.svn-base 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335
  1. <template>
  2. <j-modal
  3. :title="title"
  4. :width="width"
  5. :visible="visible"
  6. :confirmLoading="confirmLoading"
  7. switchFullscreen
  8. @ok="handleOk"
  9. :okButtonProps="{ class:{'jee-hidden': disableSubmit} }"
  10. @cancel="handleCancel"
  11. cancelText="关闭">
  12. <a-tabs default-active-key="attrs" >
  13. <a-tab-pane key="attrs" tab="属性信息">
  14. <a-spin :spinning="confirmLoading">
  15. <j-form-container :disabled="disableSubmit">
  16. <a-form-model ref="form" :model="model" :rules="validatorRules" slot="detail">
  17. <a-row>
  18. <a-col :span="12">
  19. <a-form-model-item label="项目名称" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="xmmc">
  20. <a-input v-model="model.xmmc" placeholder="请输入项目名称"></a-input>
  21. </a-form-model-item>
  22. </a-col>
  23. <a-col :span="12">
  24. <a-form-model-item label="所在水系" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="szsx">
  25. <j-dict-select-tag type="list" v-model="model.szsx" dictCode="shuixi"
  26. placeholder="请选择所在水系"/>
  27. </a-form-model-item>
  28. </a-col>
  29. <a-col :span="12">
  30. <a-form-model-item label="项目类型" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="xangmlx">
  31. <j-dict-select-tag type="list" v-model="model.xmlx" dictCode="xangmlx"
  32. placeholder="请选择项目类型"/>
  33. </a-form-model-item>
  34. </a-col>
  35. <a-col :span="12">
  36. <a-form-model-item label="行政区划" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="xzqh">
  37. <!-- <a-input v-model="model.xzqh" placeholder="请输入行政区划" ></a-input>-->
  38. <j-area-linkage type="cascader" v-model="model.xzqh" placeholder="请输入省市区"
  39. @change="xzqhChange"/>
  40. </a-form-model-item>
  41. </a-col>
  42. <a-col :span="12">
  43. <a-form-model-item label="区划代码" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="xjqhdm">
  44. <a-input v-model="model.xjqhdm" placeholder="请输入区划代码" disabled></a-input>
  45. </a-form-model-item>
  46. </a-col>
  47. <a-col :span="12">
  48. <a-form-model-item label="主要工程涉及河道" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="zygcsjhd">
  49. <j-popup placeholder="请选择主要工程涉及河道" v-model="model.zygcsjhd" code="hllist" field="zygcsjhd"
  50. org-fields="hlmc" dest-fields="zygcsjhd"
  51. :multi="true"/>
  52. </a-form-model-item>
  53. </a-col>
  54. <a-col :span="12">
  55. <a-form-model-item label="主要工程位置经度" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="hzb">
  56. <a-input v-model="model.hzb" placeholder="请输入经度" style="width: 100%" />
  57. </a-form-model-item>
  58. </a-col>
  59. <a-col :span="12">
  60. <a-form-model-item label="主要工程位置纬度" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="zzb">
  61. <a-input v-model="model.zzb" placeholder="请输入纬度" style="width: 100%" />
  62. </a-form-model-item>
  63. </a-col>
  64. <a-col :span="12">
  65. <a-form-model-item label="项目负责人" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="xmfzr">
  66. <a-input v-model="model.xmfzr" placeholder="请输入项目负责人"></a-input>
  67. </a-form-model-item>
  68. </a-col>
  69. <a-col :span="12">
  70. <a-form-model-item label="电话" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="dh">
  71. <a-input v-model="model.dh" placeholder="请输入电话"></a-input>
  72. </a-form-model-item>
  73. </a-col>
  74. <a-col :span="12">
  75. <a-form-model-item label="审批文号" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="spwh">
  76. <a-input v-model="model.spwh" placeholder="请输入审批文号"></a-input>
  77. </a-form-model-item>
  78. </a-col>
  79. <a-col :span="12">
  80. <a-form-model-item label="立项情况" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="lxqk">
  81. <a-input v-model="model.lxqk" placeholder="请输入立项情况"></a-input>
  82. </a-form-model-item>
  83. </a-col>
  84. <a-col :span="12">
  85. <a-form-model-item label="审批年度" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="spnd">
  86. <j-year-picker placeholder="请选择审批年度" v-model="model.spnd"
  87. style="width: 100%"></j-year-picker>
  88. </a-form-model-item>
  89. </a-col>
  90. <a-col :span="12">
  91. <a-form-model-item label="防洪标准" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="fhbz">
  92. <a-input v-model="model.fhbz" placeholder="请输入防洪标准"></a-input>
  93. </a-form-model-item>
  94. </a-col>
  95. <a-col :span="12">
  96. <a-form-model-item label="审批单位" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="spdw">
  97. <a-input v-model="model.spdw" placeholder="请输入审批单位"></a-input>
  98. </a-form-model-item>
  99. </a-col>
  100. <a-col :span="12">
  101. <a-form-model-item label="建设状态" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="jszt">
  102. <j-dict-select-tag type="list" v-model="model.jszt" dictCode="gcjsqk"
  103. placeholder="请选择建设状态"/>
  104. </a-form-model-item>
  105. </a-col>
  106. <a-col :span="12">
  107. <a-form-model-item label="审批情况" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="spzt">
  108. <j-dict-select-tag type="list" v-model="model.spzt" dictCode="spzt"
  109. placeholder="请选择审批情况"/>
  110. </a-form-model-item>
  111. </a-col>
  112. <!-- <a-col :span="24">-->
  113. <!-- <a-form-model-item label="是否批建不符" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="sfpjbf">-->
  114. <!-- <j-dict-select-tag type="list" v-model="model.sfpjbf" dictCode="yn" placeholder="请选择是否批建不符" />-->
  115. <!-- </a-form-model-item>-->
  116. <!-- </a-col>-->
  117. <!-- <a-col :span="24">-->
  118. <!-- <a-form-model-item label="是否为无审批" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="sfpjbf">-->
  119. <!-- <j-dict-select-tag type="list" v-model="model.sfwsp" dictCode="yn" placeholder="请选择是否无审批" />-->
  120. <!-- </a-form-model-item>-->
  121. <!-- </a-col>-->
  122. <!-- <a-col :span="24">-->
  123. <!-- <a-form-model-item label="是否补办审批" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="sfbbsp">-->
  124. <!-- <j-dict-select-tag type="list" v-model="model.sfbbsp" dictCode="yn" placeholder="请选择是否补办审批" />-->
  125. <!-- </a-form-model-item>-->
  126. <!-- </a-col>-->
  127. <a-col :span="12">
  128. <a-form-model-item label="总体布置简述" :labelCol="labelCol" :wrapperCol="wrapperCol"
  129. prop="ztbzjs">
  130. <a-input v-model="model.ztbzjs" placeholder="请输入总体布置简述"></a-input>
  131. </a-form-model-item>
  132. </a-col>
  133. <a-col :span="12">
  134. <a-form-model-item label="审批级别" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="spjb">
  135. <j-dict-select-tag type="list" v-model="model.spjb" dictCode="spjb"
  136. placeholder="请选择审批级别"/>
  137. </a-form-model-item>
  138. </a-col>
  139. <a-col :span="12">
  140. <a-form-model-item label="其他" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="qt">
  141. <a-input v-model="model.qt" placeholder="请输入其他" rows="4"></a-input>
  142. </a-form-model-item>
  143. </a-col>
  144. <a-col :span="12">
  145. <a-form-model-item label="审批文件" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="wjsc">
  146. <j-upload biz-path="xmrk" v-model="model.wjsc"></j-upload>
  147. </a-form-model-item>
  148. </a-col>
  149. <a-col :span="12">
  150. <a-form-model-item label="防洪(输水)影响评价报告" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="fhpjbg">
  151. <j-upload biz-path="xmrk" v-model="model.fhpjbg"></j-upload>
  152. </a-form-model-item>
  153. </a-col>
  154. </a-row>
  155. </a-form-model>
  156. </j-form-container>
  157. </a-spin>
  158. </a-tab-pane>
  159. <a-tab-pane key="map" tab="位置信息">
  160. <basic-map ref="locMap" layersUrl='/resManager.catalog/rescatalog/resList' :model="{...model,layerName:'拟建项目,在建项目'}"></basic-map>
  161. </a-tab-pane>
  162. </a-tabs>
  163. <span class="message">注意:填写完项目信息后,请继续填写单位信息,河段主要指标,涉河工程主要指标,涉河工程主要指标,分析计算主要成果,影响情况及消除或减轻影响措施信息表</span>
  164. </j-modal>
  165. </template>
  166. <script>
  167. import {httpAction} from '@/api/manage'
  168. import {validateDuplicateValue} from '@/utils/util'
  169. import JYearPicker from "@comp/jeecg/JYearPicker";
  170. import BasicMap from "../../../../../components/BasicMap/BasicMap";
  171. export default {
  172. name: "RmAxxmxxModal",
  173. components: {
  174. JYearPicker,
  175. BasicMap
  176. },
  177. data() {
  178. return {
  179. title: "操作",
  180. width: 1200,
  181. visible: false,
  182. model: {},
  183. disableSubmit: false,
  184. labelCol: {
  185. xs: {span: 24},
  186. sm: {span: 5},
  187. },
  188. wrapperCol: {
  189. xs: {span: 24},
  190. sm: {span: 16},
  191. },
  192. confirmLoading: false,
  193. validatorRules: {
  194. xmmc: [
  195. { required: true, message: '请输入项目名称!'},
  196. ],
  197. szsx:[
  198. {
  199. required: true, message: '请输入所在水系!'
  200. }
  201. ],
  202. hzb:[
  203. {
  204. required: true, message: '请输入主要工程位置横坐标!'
  205. }
  206. ],
  207. zzb:[
  208. {
  209. required: true, message: '请输入主要工程位置纵坐标!'
  210. }
  211. ],
  212. jszt:[
  213. {
  214. required: true, message: '请输入建设状态!'
  215. }
  216. ],
  217. spnd:[
  218. {
  219. required: true, message: '请输入审批年度!'
  220. }
  221. ],
  222. spjb:[
  223. {
  224. required: true, message: '请输入审批级别!'
  225. }
  226. ],
  227. dh:[
  228. {
  229. required: true, message: '请输入电话!'
  230. }
  231. ],
  232. zygcsjhd:[
  233. {
  234. required: true, message: '请输入主要涉及河道(可多选)!'
  235. }
  236. ],
  237. xmfzr:[
  238. {
  239. required: true, message: '请输入项目负责人!'
  240. }
  241. ],
  242. },
  243. url: {
  244. add: "/hzz.shjsgc.xmrk/rmAxxmxx/add",
  245. edit: "/hzz.shjsgc.xmrk/rmAxxmxx/edit",
  246. }
  247. }
  248. },
  249. created() {
  250. //备份model原始值
  251. this.modelDefault = JSON.parse(JSON.stringify(this.model));
  252. },
  253. methods: {
  254. add() {
  255. this.edit(this.modelDefault);
  256. },
  257. edit(record) {
  258. this.model = Object.assign({}, record);
  259. this.visible = true;
  260. },
  261. close() {
  262. this.$emit('close');
  263. this.visible = false;
  264. this.$refs.form.clearValidate();
  265. },
  266. handleOk() {
  267. const that = this;
  268. // 触发表单验证
  269. this.$refs.form.validate(valid => {
  270. if (valid) {
  271. that.confirmLoading = true;
  272. let httpurl = '';
  273. let method = '';
  274. if (!this.model.id) {
  275. httpurl += this.url.add;
  276. method = 'post';
  277. } else {
  278. httpurl += this.url.edit;
  279. method = 'post';
  280. }
  281. httpAction(httpurl, this.model, method).then((res) => {
  282. if (res.success) {
  283. that.$message.success(res.message);
  284. that.$emit('ok');
  285. } else {
  286. that.$message.warning(res.message);
  287. }
  288. }).finally(() => {
  289. that.confirmLoading = false;
  290. that.close();
  291. })
  292. } else {
  293. return false
  294. }
  295. })
  296. },
  297. handleCancel() {
  298. this.close()
  299. },
  300. tabsChange(key) {
  301. let that = this;
  302. if (key == "map") {
  303. this.$nextTick(() => {
  304. this.$refs.locMap.locateByCoords({...that.model});
  305. })
  306. }
  307. },
  308. locateByCoords() {
  309. let loc_x = this.hzb;
  310. let loc_y = this.zzb;
  311. this.$refs.locMap.locateByCoords(loc_x, loc_y);
  312. },
  313. xzqhChange(value) {
  314. this.model.xjqhdm = value;
  315. },
  316. }
  317. }
  318. </script>
  319. <style type="text/css">
  320. .message {
  321. margin-left: 18%;
  322. font-size: 16px;
  323. color:red
  324. }
  325. </style>