Project.vue 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771
  1. <template>
  2. <div class="create-container" v-loading="loading">
  3. <div class="title h1" v-if="!isModifyMode">项目</div>
  4. <div class="create-body">
  5. <div class="title h2" v-if="!isModifyMode">基本信息</div>
  6. <div v-if="!isModifyMode" class="el-form-item">
  7. <label class="el-form-item__label" style="width: 12%;">编号</label>
  8. <div class="el-form-item__content" style="margin-left: 12%;">
  9. <div>{{projectId}}</div>
  10. </div>
  11. </div>
  12. <el-form :model="project" :rules="rules" ref="project" label-width="12%" class="demo-project">
  13. <el-form-item label="项目名称" prop="name">
  14. <el-input v-if="isModifyMode" v-model="project.name"></el-input>
  15. <span v-if="!isModifyMode">{{project.name}}</span>
  16. </el-form-item>
  17. <el-form-item label="联系人" prop="name">
  18. <el-input v-if="isModifyMode" v-model="project.contactName" placeholder="请输入联系人姓名"></el-input>
  19. <span v-if="!isModifyMode">{{project.contactName}}</span>
  20. </el-form-item>
  21. <el-form-item label="联系人电话" prop="name">
  22. <el-input v-if="isModifyMode" v-model="project.contactPhone" placeholder="请输入联系人电话"></el-input>
  23. <span v-if="!isModifyMode">{{project.contactPhone}}</span>
  24. </el-form-item>
  25. <!--<el-form-item label="联系方式" prop="contact">-->
  26. <!--<div>-->
  27. <!--<el-row :gutter="2">-->
  28. <!--<el-col :span="2">-->
  29. <!--<span>联系人</span>-->
  30. <!--</el-col>-->
  31. <!--<el-col :span="10">-->
  32. <!--<el-input v-if="isModifyMode" v-model="project.contactName" placeholder="请输入联系人姓名"></el-input>-->
  33. <!--<div v-if="!isModifyMode">{{project.contactName}}</div>-->
  34. <!--</el-col>-->
  35. <!--</el-row>-->
  36. <!--<el-row :gutter="2">-->
  37. <!--<el-col :span="2">-->
  38. <!--<span>联系人电话</span>-->
  39. <!--</el-col>-->
  40. <!--<el-col :span="10">-->
  41. <!--<el-input-->
  42. <!--v-if="isModifyMode"-->
  43. <!--v-model="project.contactPhone"-->
  44. <!--placeholder="请输入联系人电话"-->
  45. <!--&gt;</el-input>-->
  46. <!--<div v-if="!isModifyMode">{{project.contactPhone}}</div>-->
  47. <!--</el-col>-->
  48. <!--</el-row>-->
  49. <!--</div>-->
  50. <!--</el-form-item>-->
  51. <el-form-item label="平台" prop="platform">
  52. <el-checkbox-group v-if="isModifyMode" v-model="project.platform">
  53. <span v-for="(item,index) in platforms" :key="index">
  54. <el-checkbox :label="item">{{ item }}&nbsp;&nbsp;&nbsp;&nbsp;</el-checkbox>
  55. </span>
  56. </el-checkbox-group>
  57. <span
  58. v-if="!isModifyMode"
  59. class="badge"
  60. v-for="item in project.platform"
  61. >{{item}}</span>
  62. </el-form-item>
  63. <el-form-item label="需求描述">
  64. <el-input v-if="isModifyMode" type="textarea" v-model="project.desc"></el-input>
  65. <span v-if="!isModifyMode">{{project.desc}}</span>
  66. </el-form-item>
  67. <el-form-item label="价格" prop="price">
  68. <el-input v-if="isModifyMode" type="number" v-model="project.price">
  69. <template slot="append">¥</template>
  70. </el-input>
  71. <span v-if="!isModifyMode">{{project.price}}¥</span>
  72. </el-form-item>
  73. <el-form-item label="服务类型" prop="type">
  74. <el-checkbox-group v-if="isModifyMode" v-model="project.type">
  75. <span v-for="(item,index) in serviceType" :key="index">
  76. <el-checkbox :label="item" name="type">{{ item }}&nbsp;&nbsp;</el-checkbox>
  77. </span>
  78. </el-checkbox-group>
  79. <span v-if="!isModifyMode" class="badge" v-for="item in project.type">{{item}}</span>
  80. </el-form-item>
  81. <!--<el-form-item label="用途" prop="usage">-->
  82. <!--<el-input v-if="isModifyMode" v-model="project.usage"></el-input>-->
  83. <!--<span v-if="!isModifyMode">{{project.usage}}</span>-->
  84. <!--</el-form-item>-->
  85. <el-form-item label="预算" prop="budget">
  86. <el-input v-if="isModifyMode" type="number" v-model="project.budget">
  87. ¥
  88. <template slot="append"></template>
  89. </el-input>
  90. <span v-if="!isModifyMode">{{project.budget}}¥</span>
  91. </el-form-item>
  92. <el-form-item label="项目可见性" prop="resource">
  93. <div v-if="!isModifyMode">
  94. <div v-if="project.resource=='1'">{{updateLocation(project.location)}}</div>
  95. <div v-if="project.resource=='0'">{{project.institution==null?'暂未被接收':project.institution}}</div>
  96. <div v-if="project.resource=='2'">{{resourceType[project.resource]}}</div>
  97. </div>
  98. <el-tabs :tab-position="tabPosition" v-model="project.resource" style="max-height: 200px;"
  99. v-if="isModifyMode">
  100. <el-tab-pane :label="resourceType[0]" name="0">
  101. <el-radio-group v-model="project.institution">
  102. <el-radio :label="item" name="type" v-for="(item,index) in institutionArray" :key="index">
  103. {{item.name}}
  104. </el-radio>
  105. </el-radio-group>
  106. </el-tab-pane>
  107. <el-tab-pane :label="resourceType[1]" name="1">
  108. <provincecity
  109. ref="addFormProvince"
  110. @selectChange="locationChange"
  111. :provinceCode="project.location==null?'3200':project.location.provinceCode"
  112. :cityCode="project.location==null?'3201':project.location.cityCode"
  113. ></provincecity>
  114. </el-tab-pane>
  115. <el-tab-pane :label="resourceType[2]" name="2"></el-tab-pane>
  116. </el-tabs>
  117. </el-form-item>
  118. <el-form-item label="需求文档" prop="doc">
  119. <el-upload
  120. v-if="isModifyMode"
  121. drag
  122. class="upload-demo"
  123. action=""
  124. :on-remove="handleRemove"
  125. :before-remove="beforeRemove"
  126. :limit="1"
  127. :on-exceed="handleExceed"
  128. :before-upload="beforeFileUpload"
  129. :http-request="uploadRequireDoc"
  130. :file-list="project.doc"
  131. >
  132. <i class="el-icon-upload"></i>
  133. <div class="el-upload__text">
  134. 将文件拖到此处,或
  135. <em>点击上传</em>
  136. </div>
  137. <div class="el-upload__tip" slot="tip">请上传需求文档</div>
  138. </el-upload>
  139. <span v-if="!isModifyMode"><a :href="project.requireDocUrl">{{project.requireDocUrl.split('/')[project.requireDocUrl.split('/').length-1]}}</a></span>
  140. </el-form-item>
  141. <el-form-item label="安装包" prop="file">
  142. <el-upload
  143. v-if="isModifyMode"
  144. drag
  145. class="upload-demo"
  146. action=""
  147. :on-remove="handleRemove"
  148. :before-remove="beforeRemove"
  149. :limit="1"
  150. :on-exceed="handleExceed"
  151. :before-upload="beforeApkUpload"
  152. :http-request="uploadApkFile"
  153. :file-list="project.file"
  154. >
  155. <i class="el-icon-upload"></i>
  156. <div class="el-upload__text">
  157. 将文件拖到此处,或
  158. <em>点击上传</em>
  159. </div>
  160. <div class="el-upload__tip" slot="tip">只能上传Android或IOS安装包文件</div>
  161. </el-upload>
  162. <span v-if="!isModifyMode"><a :href="project.fileUrl">{{project.fileUrl.split('/')[project.fileUrl.split('/').length-1]}}</a></span>
  163. </el-form-item>
  164. <el-form-item label="项目截止时间" prop="datetime">
  165. <div class="block" v-if="isModifyMode">
  166. <el-date-picker
  167. v-model="project.datetime"
  168. type="datetime"
  169. placeholder="选择截止时间"
  170. align="right"
  171. :picker-options="pickerOptions"
  172. ></el-date-picker>
  173. </div>
  174. <span v-if="!isModifyMode">{{new Date(project.datetime)}}</span>
  175. </el-form-item>
  176. <el-form-item v-if="isModifyMode">
  177. <div class="btn btn-medium btn-info" @click="submitForm('project')">确认修改</div>
  178. <div class="btn btn-medium" @click="resetForm('project')">重置</div>
  179. <div class="btn btn-medium" @click="cancelMode('project')">取消</div>
  180. </el-form-item>
  181. <el-form-item v-if="!isModifyMode">
  182. <div class="btn btn-medium btn-info" @click="submitProjectRequest()">发布项目</div>
  183. <div class="btn btn-medium btn-info" @click="submitProjectRequest()">提交项目</div>
  184. <div class="btn btn-medium btn-info" @click="applyProject()">接受项目</div>
  185. <div class="btn btn-medium btn-info" @click="modifyForm()">修改</div>
  186. <!--<div class="btn btn-medium btn-info" @click="analyseDemand()">分析需求</div>-->
  187. <div class="btn btn-medium btn-info" @click="createTask()">新建任务</div>
  188. <div class="btn btn-medium btn-info" @click="createReport()">上传报告</div>
  189. </el-form-item>
  190. </el-form>
  191. </div>
  192. <div class="create-body" v-if="!isModifyMode">
  193. <div class="title h2">任务列表</div>
  194. <div class="task-list">
  195. <el-table :showHeader="true" :stripe="true" :data="task" style="width: 100%">
  196. <el-table-column prop="title" label="任务名称" title="任务名称"></el-table-column>
  197. <el-table-column prop="datetime" sortable label="任务截止时间"></el-table-column>
  198. <el-table-column prop="resource" label="任务可见性">
  199. <template slot-scope="scope">
  200. <div v-if="scope.row.resource=='1'">{{scope.row.location.provinceCode}}/{{scope.row.location.cityCode}}
  201. </div>
  202. <div v-if="scope.row.resource=='0'">{{scope.row.institution}}</div>
  203. <div v-if="scope.row.resource=='2'">{{resourceType[scope.row.resource]}}</div>
  204. </template>
  205. </el-table-column>
  206. <el-table-column prop="type" label="业务类型">
  207. <template slot-scope="scope">
  208. <div class="badge">{{scope.row.serviceType}}</div>
  209. </template>
  210. </el-table-column>
  211. <el-table-column align="right" label="操作">
  212. <template slot-scope="scope">
  213. <div
  214. class="btn btn-small btn-info"
  215. @click="goToTaskDetail(projectId, scope.row.id)"
  216. >查看详情
  217. </div>
  218. <div
  219. class="btn btn-small btn-danger"
  220. @click="handleDelete(scope.$index, scope.row.id)"
  221. >删除
  222. </div>
  223. </template>
  224. </el-table-column>
  225. </el-table>
  226. </div>
  227. </div>
  228. <div class="create-body" v-if="!isModifyMode">
  229. <div class="title h2">报告列表</div>
  230. <report-list v-bind:reports="reportList" v-bind:taskId=null v-bind:projectId="projectId"/>
  231. </div>
  232. </div>
  233. </template>
  234. <script>
  235. import ReportList from '@/components/report/ReportList'
  236. import Http from '@/js/http.js'
  237. import Apis from '@/js/api.js'
  238. import ResourceType from '@/constants/enum/resource-type'
  239. import provincecity from '@/components/commons/ProvinceCity'
  240. import {notify} from '@/constants/index'
  241. import {
  242. getAllInstitutions,
  243. getAllPlatformTypes,
  244. getAllServiceTypes,
  245. getProvinceCodeByProvinceName,
  246. getProvinceNameByProvinceCode,
  247. storageGet,
  248. } from '@/js/index'
  249. export default {
  250. name: 'Project',
  251. components: {
  252. provincecity,
  253. ReportList
  254. },
  255. data () {
  256. var validatePass = (rule, value, callback) => {
  257. var reg = /^(0|86|17951)?(13[0-9]|15[012356789]|17[678]|18[0-9]|14[57])[0-9]{8}$/
  258. if (this.project.contactPhone) {
  259. if (!reg.test(this.project.contactPhone)) {
  260. callback(new Error('请检查手机号码'))
  261. } else {
  262. callback()
  263. }
  264. }
  265. }
  266. return {
  267. projectId: 0,
  268. user: {},
  269. loading: false,
  270. tabPosition: 'top',
  271. institutionArray: [],
  272. isModifyMode: false,
  273. platforms: [],
  274. resourceType: ResourceType,
  275. serviceType: [],
  276. project: {
  277. userId: 0,
  278. name: '',
  279. type: '',
  280. platform: '',
  281. desc: '',
  282. resource: '',
  283. location: '',
  284. institution: {},
  285. contactName: '',
  286. contactPhone: '',
  287. doc: [],
  288. requireDocUrl: '',
  289. file: [],
  290. fileUrl: '',
  291. budget: '',
  292. price: '',
  293. datetime: '',
  294. usage: '',
  295. },
  296. task: [],
  297. reportList: [],
  298. pickerOptions: {
  299. shortcuts: [
  300. {
  301. text: '今天',
  302. onClick (picker) {
  303. picker.$emit('pick', new Date())
  304. }
  305. },
  306. {
  307. text: '昨天',
  308. onClick (picker) {
  309. const date = new Date()
  310. date.setTime(date.getTime() - 3600 * 1000 * 24)
  311. picker.$emit('pick', date)
  312. }
  313. },
  314. {
  315. text: '一周前',
  316. onClick (picker) {
  317. const date = new Date()
  318. date.setTime(date.getTime() - 3600 * 1000 * 24 * 7)
  319. picker.$emit('pick', date)
  320. }
  321. }
  322. ]
  323. },
  324. rules: {
  325. // name: [
  326. // {required: true, message: '请输入项目名称', trigger: 'blur'}
  327. // // { min: 3, max: 5, message: "长度在 3 到 5 个字符", trigger: "blur" }
  328. // ],
  329. // type: [
  330. // {
  331. // type: 'array',
  332. // required: true,
  333. // message: '请至少选择一种服务类型',
  334. // trigger: 'change'
  335. // }
  336. // ],
  337. // platform: [
  338. // {
  339. // type: 'array',
  340. // required: true,
  341. // message: '请至少选择一个平台',
  342. // trigger: 'change'
  343. // }
  344. // ],
  345. // desc: [{required: true, message: '请填写活动形式', trigger: 'blur'}],
  346. // contact: [{validator: validatePass, trigger: 'blur'}],
  347. // resource: [
  348. // {
  349. // required: true,
  350. // message: '请选择项目可见性',
  351. // trigger: 'change'
  352. // }
  353. // ]
  354. }
  355. }
  356. },
  357. mounted () {
  358. this.$nextTick(() => {
  359. this.init()
  360. })
  361. },
  362. watch: {
  363. serviceType (val) {
  364. this.serviceType = val
  365. },
  366. institutionArray (val) {
  367. this.institutionArray = val
  368. },
  369. // 'project.institution' () {
  370. // if (this.project.institution) {
  371. // //this.$refs.addFormProvince.resetProviceCity()
  372. // this.project.location = {provinceCode: '', cityCode: ''}
  373. // }
  374. // },
  375. // 'project.location' () {
  376. // if (this.project.location.provinceCode || this.project.location.cityCode) {
  377. // this.project.institution = ''
  378. // }
  379. // },
  380. // 'project.resource' () {
  381. // if (this.project.resource == '2') {
  382. // //this.$refs.addFormProvince.resetProviceCity()
  383. // this.project.institution = ''
  384. // this.project.location = {provinceCode: '', cityCode: ''}
  385. // }
  386. // },
  387. deep: true
  388. },
  389. methods: {
  390. updateLocation (location) {
  391. //console.log(location)
  392. const loactionName = getProvinceNameByProvinceCode(location.provinceCode, location.cityCode)
  393. // var provinceName = ''
  394. // var cityName = ''
  395. // for (var item of provinceCityJSON.provinces) {
  396. // if (item.code === location.provinceCode) {
  397. // provinceName = item.name
  398. // for (var city of item.cities) {
  399. // if (city.code === location.cityCode) {
  400. // cityName = city.name
  401. // break
  402. // }
  403. // }
  404. // }
  405. // }
  406. return loactionName.provinceCode + ' / ' + loactionName.cityCode
  407. },
  408. init () {
  409. this.projectId = this.$route.params.projectId
  410. this.setServiceType()
  411. this.setPlatformType()
  412. this.setInstitutions()
  413. this.setUserInfo()
  414. this.loadData()
  415. // this.project.platform.map(item => {
  416. // this.platformType.push(PlatformType[item])
  417. // })
  418. },
  419. //提交修改
  420. submitForm (formName) {
  421. this.showLoading()
  422. const newProject = {
  423. userId: this.user.userVO.id,
  424. name: this.project.name,
  425. type: this.project.type,
  426. platform: this.project.platform,
  427. desc: this.project.desc,
  428. resource: this.project.resource,
  429. location: getProvinceNameByProvinceCode(this.project.location.provinceCode, this.project.location.cityCode),
  430. institution: this.project.institution == null ? null : this.project.institution.id,
  431. contactName: this.project.contactName,
  432. contactPhone: this.project.contactPhone,
  433. doc: this.project.requireDocUrl,
  434. file: this.project.fileUrl,
  435. budget: this.project.budget,
  436. price: this.project.price,
  437. datetime: this.project.datetime,
  438. usage: this.project.usage,
  439. }
  440. console.log('aa')
  441. console.log(newProject)
  442. Http.put(Apis.PROJECT.UPDATE_PROJECT.replace('{projectId}', this.projectId), newProject).then((res) => {
  443. console.log('bb')
  444. console.log(res)
  445. this.projectId = res.projectDetails.id
  446. this.project.name = res.projectDetails.name
  447. this.project.contactName = res.projectDetails.contactName
  448. this.project.contactPhone = res.projectDetails.contactPhone
  449. this.project.type = res.projectDetails.type
  450. this.project.platform = res.projectDetails.platform
  451. this.project.desc = res.projectDetails.desc
  452. this.project.doc = []
  453. this.project.file = []
  454. this.project.resource = res.projectDetails.resource
  455. this.project.location = getProvinceCodeByProvinceName(res.projectDetails.location.provinceCode, res.projectDetails.location.cityCode)
  456. this.project.institution = res.projectDetails.institution
  457. this.project.datetime = new Date(res.projectDetails.datetime)
  458. this.project.price = res.projectDetails.price
  459. this.project.budget = res.projectDetails.budget
  460. this.project.usage = res.projectDetails.usage
  461. this.project.fileUrl = res.projectDetails.file
  462. this.project.requireDocUrl = res.projectDetails.doc
  463. this.task = res.taskList
  464. this.reportList = res.reportList
  465. this.isModifyMode = false
  466. this.hideLoading()
  467. notify('success', '项目修改成功')
  468. }).catch(error => {
  469. this.hideLoading()
  470. notify('error', error.data)
  471. console.log(error)
  472. })
  473. // this.$refs[formName].validate(valid => {
  474. // if (valid) {
  475. //
  476. // //提交 project
  477. // } else {
  478. // console.log('error submit!!')
  479. // return false
  480. // }
  481. // })
  482. },
  483. //重置表单
  484. resetForm (formName) {
  485. this.$refs[formName].resetFields()
  486. this.project.name = ''
  487. this.project.type = []
  488. this.project.platform = []
  489. this.project.desc = ''
  490. this.project.doc = ''
  491. this.project.file = ''
  492. this.project.contactName = ''
  493. this.project.contactPhone = ''
  494. this.project.resource = '2'
  495. this.project.institution = ''
  496. this.project.datetime = ''
  497. this.project.price = ''
  498. this.project.usage = ''
  499. this.project.budget = ''
  500. },
  501. //进入修改项目页面
  502. modifyForm () {
  503. this.isModifyMode = true
  504. //this.setInstitutions()
  505. //获得update 信息
  506. //this.loadData()
  507. },
  508. //接收项目
  509. submitProjectRequest () {
  510. const data = {
  511. userId: this.user.userVO.id,
  512. projectId: this.projectId
  513. }
  514. Http.post(Apis.USER.SUBMIT_PROJECT_REQUEST, data).then((res) => {
  515. console.log(res)
  516. })
  517. },
  518. //申请项目
  519. applyProject () {
  520. const data = {
  521. userId: this.user.userVO.id,
  522. projectId: this.projectId
  523. }
  524. Http.post(Apis.USER.ACCEPT_PROJECT, data).then((res) => {
  525. console.log(res)
  526. })
  527. },
  528. cancelMode (formName) {
  529. this.isModifyMode = false
  530. this.loadData()
  531. },
  532. goToTaskDetail (projectId, taskId) {
  533. this.$router.push({
  534. name: 'Task',
  535. params: {projectId: projectId, taskId: taskId}
  536. })
  537. },
  538. createTask () {
  539. this.$router.push({name: 'TaskCreate'})
  540. },
  541. createReport () {
  542. this.$router.push({
  543. name: 'ReportCreate',
  544. params: {
  545. scope: 0,
  546. dependencyCode: this.projectId,
  547. projectId: this.projectId,
  548. taskId: null,
  549. }
  550. })
  551. },
  552. handleDelete (index, id) {
  553. this.task.splice(index, 1)
  554. },
  555. beforeApkUpload (file) {
  556. const isAPK = file.type === 'application/vnd.android.package-archive'
  557. const isDMG = file.type === 'application/octet-stream'
  558. if (!isAPK && !isDMG) {
  559. this.$message.error('上传安装包只能是 APK 或 DMG 格式!')
  560. }
  561. return isAPK || isDMG
  562. },
  563. beforeFileUpload (file) {
  564. console.log(file)
  565. const isPDF = file.type === 'application/pdf'
  566. const isDOC = file.type === 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'
  567. const isEXCEL = file.type === 'application/vnd.ms-excel'
  568. const isXLS = file.type === 'application/x-xls'
  569. const isTXT = file.type === 'text/plain'
  570. const isXLSX = file.type === 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
  571. //console.log(file)
  572. if (!(isDOC || isEXCEL || isPDF || isTXT || isXLS || isXLSX)) {
  573. this.$message.error('上传文件只能是 PDF 、 DOC 、DOCX 、XLS、TXT、XLSX 格式!')
  574. }
  575. return isDOC || isEXCEL || isPDF || isTXT || isXLS || isXLSX
  576. },
  577. analyseDemand () {
  578. this.$router.push({name: 'AnalyseDemand'})
  579. },
  580. handleAccept (index, id) {
  581. console.log('接受')
  582. },
  583. handleReject (index, id) {
  584. console.log('拒绝')
  585. },
  586. loadData () {//PROJ--2019073114009
  587. this.showLoading()
  588. Http.get(Apis.PROJECT.GET_PROJECT.replace('{projectId}', this.projectId)).then((res) => {
  589. console.log(res)
  590. this.projectId = res.projectDetails.id
  591. this.project.name = res.projectDetails.name
  592. this.project.contactName = res.projectDetails.contactName
  593. this.project.contactPhone = res.projectDetails.contactPhone
  594. this.project.type = res.projectDetails.type
  595. this.project.platform = res.projectDetails.platform
  596. this.project.desc = res.projectDetails.desc
  597. this.project.doc = []
  598. this.project.file = []
  599. this.project.resource = res.projectDetails.resource
  600. this.project.location = getProvinceCodeByProvinceName(res.projectDetails.location.provinceCode, res.projectDetails.location.cityCode)
  601. this.project.institution = res.projectDetails.institution
  602. this.project.datetime = new Date(res.projectDetails.datetime)
  603. this.project.price = res.projectDetails.price
  604. this.project.budget = res.projectDetails.budget
  605. this.project.usage = res.projectDetails.usage
  606. this.project.fileUrl = res.projectDetails.file
  607. this.project.requireDocUrl = res.projectDetails.doc
  608. this.task = res.taskList
  609. this.reportList = res.reportList
  610. this.hideLoading()
  611. }).catch((error) => {
  612. this.hideLoading()
  613. notify('error', error.data)
  614. })
  615. },
  616. locationChange (provinceId, cityId) {
  617. if (provinceId || cityId) {
  618. this.project.location = {provinceCode: provinceId, cityCode: cityId}
  619. }
  620. },
  621. handleRemove (file, fileList) {
  622. console.log(file, fileList)
  623. },
  624. handleExceed (files, fileList) {
  625. this.$message.warning(
  626. `当前限制选择 1 个文件,本次选择了 ${
  627. files.length
  628. } 个文件,共选择了 ${files.length + fileList.length} 个文件`
  629. )
  630. },
  631. beforeRemove (file, fileList) {
  632. //return this.$confirm(`确定移除 ${file.name}?`)
  633. },
  634. uploadRequireDoc (param) {
  635. const formData = new FormData()
  636. let config = {
  637. //添加请求头
  638. headers: {'Content-Type': 'multipart/form-data'},
  639. }
  640. formData.append('file', param.file)
  641. Http.upload(Apis.FILE.REQUIREMENT_FILE.replace('{userId}', this.user.userVO.id), formData, config).then((res) => {
  642. console.log('上传成功')
  643. this.project.requireDocUrl = res.data
  644. console.log(res.data)
  645. })
  646. },
  647. uploadApkFile (param) {
  648. const formData = new FormData()
  649. let config = {
  650. //添加请求头
  651. headers: {'Content-Type': 'multipart/form-data'},
  652. }
  653. formData.append('file', param.file)
  654. Http.upload(Apis.FILE.APK.replace('{userId}', this.user.userVO.id), formData, config).then((res) => {
  655. console.log('上传成功')
  656. this.project.fileUrl = res.data
  657. console.log(res)
  658. })
  659. },
  660. setServiceType () {
  661. getAllServiceTypes().then((res) => {
  662. this.serviceType = res
  663. }).catch((error) => {
  664. notify('error', '获取项目类型列表失败')
  665. })
  666. },
  667. setPlatformType () {
  668. this.platforms = getAllPlatformTypes()
  669. },
  670. setInstitutions () {
  671. getAllInstitutions().then((res) => {
  672. this.institutionArray = res
  673. }).catch((error) => {
  674. notify('error', '获取institution失败' + error.data)
  675. })
  676. },
  677. setUserInfo () {
  678. this.user = storageGet('user')
  679. },
  680. showLoading () {
  681. this.loading = true
  682. },
  683. hideLoading () {
  684. this.loading = false
  685. }
  686. }
  687. }
  688. </script>
  689. <style lang="less" scoped>
  690. .task-list {
  691. margin: 0 30px;
  692. }
  693. .el-col {
  694. padding: 0 !important;
  695. }
  696. .el-row {
  697. margin-bottom: 10px;
  698. }
  699. .el-input {
  700. width: 400px;
  701. }
  702. </style>
  703. <!--<div class="create-body" v-if="!isModifyMode">-->
  704. <!--<div class="title h2">分析需求</div>-->
  705. <!--<div class="task-list">-->
  706. <!--<el-table :data="analyseDemandList" style="width: 100%" max-height="400">-->
  707. <!--<el-table-column prop="institution" label="承接单位" title="承接单位"></el-table-column>-->
  708. <!--<el-table-column prop="feasibilityReport" sortable label="可行性分析报告">-->
  709. <!--<template slot-scope="scope">-->
  710. <!--<span v-if="!scope.row.feasibilityReport.url">暂无文件</span>-->
  711. <!--<a-->
  712. <!--:href="scope.row.feasibilityReport.url"-->
  713. <!--v-if="scope.row.feasibilityReport.url"-->
  714. <!--target="_blank"-->
  715. <!--&gt;-->
  716. <!--<i class="fa fa-file-text-o"></i>-->
  717. <!--{{scope.row.feasibilityReport.name}}-->
  718. <!--</a>-->
  719. <!--</template>-->
  720. <!--</el-table-column>-->
  721. <!--<el-table-column prop="priceAuditReport" sortable label="可行性分析报告">-->
  722. <!--<template slot-scope="scope">-->
  723. <!--<span v-if="!scope.row.priceAuditReport.url">暂无文件</span>-->
  724. <!--<a-->
  725. <!--:href="scope.row.priceAuditReport.url"-->
  726. <!--v-if="scope.row.priceAuditReport.url"-->
  727. <!--target="_blank"-->
  728. <!--&gt;-->
  729. <!--<i class="fa fa-file-text-o"></i>-->
  730. <!--{{scope.row.priceAuditReport.name}}-->
  731. <!--</a>-->
  732. <!--</template>-->
  733. <!--</el-table-column>-->
  734. <!--<el-table-column align="right" label="操作">-->
  735. <!--<template slot-scope="scope">-->
  736. <!--<div-->
  737. <!--class="btn btn-small btn-info"-->
  738. <!--@click="handleAccept(scope.$index, scope.row.id)"-->
  739. <!--&gt;接受-->
  740. <!--</div>-->
  741. <!--<div-->
  742. <!--class="btn btn-small btn-danger"-->
  743. <!--@click="handleReject(scope.$index, scope.row.id)"-->
  744. <!--&gt;拒绝-->
  745. <!--</div>-->
  746. <!--</template>-->
  747. <!--</el-table-column>-->
  748. <!--</el-table>-->
  749. <!--</div>-->
  750. <!--</div>-->