87d4358dce5888bf9251fe39febd266ca751a5e2.svn-base 19 KB

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