142b6acc41e22fa9322372386d31c563bb4947ea.svn-base 19 KB

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