index.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771
  1. <template>
  2. <view class="app-content">
  3. <view class="header">
  4. <view class="log" @tap="fall"></view>
  5. </view>
  6. <!-- <view class="nav">
  7. <view :class="action === index ? 'nav_lists': 'nav_list'" v-for="(item, index) in list" :key="index" @tap="lop(index)">{{item.name}}</view>
  8. </view> -->
  9. <uni-swiper-dot :info="imgList" :current="current" field="content" :mode="mode">
  10. <swiper class="swiper-box" @change="change" style="height:11rem">
  11. <swiper-item v-for="(item ,index) in imgList" :key="index" @tap="openImg(index)">
  12. <view class="swiper-item">
  13. <image style="width:100%" :src="item" mode="scaleToFill"></image>
  14. </view>
  15. </swiper-item>
  16. </swiper>
  17. </uni-swiper-dot>
  18. <view class="content" :style="{top:dataheight}">
  19. <uni-section title="行李详情" type="line"></uni-section>
  20. <view class="choice" @touchmove="movetran" v-if="luggageData">
  21. <scroll-view scroll-y="true" class="scroll-Y">
  22. <view class="list">
  23. <view class="lable">航班号</view>
  24. <span>{{luggageData.carrierFlights}}</span>
  25. <button class="nodeList" @tap="toNode()">路径详情</button>
  26. </view>
  27. <view class="list">
  28. <view class="lable">航班日期</view>
  29. <span>{{luggageData.carrierFlightsDate}}</span>
  30. </view>
  31. <view class="list">
  32. <view class="lable">行李牌号</view>
  33. <span>{{luggageData.luggageNum}}</span>
  34. </view>
  35. <view class="list">
  36. <view class="lable">操作时间</view>
  37. <span>{{luggageData.processing_time}}</span>
  38. </view>
  39. <view class="list">
  40. <view class="lable">操作人</view>
  41. <span>{{luggageData.agentNumber}}</span>
  42. </view>
  43. <view class="list">
  44. <view class="lable">操作节点</view>
  45. <picker @change="bindPickerChange" style="line-height: 2.375rem;background-color: antiquewhite;"
  46. :placeholderStyle="placeholderStyle" :value="index" :range-key="'nodeName'"
  47. :range="nodeList">
  48. <view class="uni-input">{{nodeNameList[index]}}</view>
  49. </picker>
  50. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  51. </view>
  52. <view class="list">
  53. <view class="lable">操作位置</view>
  54. <uni-easyinput :inputBorder="false"
  55. style="line-height: 2.375rem;background-color: antiquewhite;"
  56. :placeholderStyle="placeholderStyle" :clearable="false" :styles="style" :disabled="false"
  57. v-model="luggageData.location_describe" type="text" placeholder="操作位置" />
  58. </uni-forms>
  59. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  60. </view>
  61. <view class="list">
  62. <view class="lable">发往节点</view>
  63. <picker @change="bindPickerChange2"
  64. style="line-height: 2.375rem;background-color: antiquewhite;"
  65. :placeholderStyle="placeholderStyle" :value="index2" :range-key="'nodeName'"
  66. :range="nodeList">
  67. <view class="uni-input">{{nodeNameList[index2]}}</view>
  68. </picker>
  69. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  70. </view>
  71. <view class="list">
  72. <view class="lable">发往位置</view>
  73. <uni-easyinput :inputBorder="false"
  74. style="line-height: 2.375rem;background-color: antiquewhite;"
  75. :placeholderStyle="placeholderStyle" :clearable="false" :styles="style" :disabled="false"
  76. v-model="luggageData.to_location_describe" type="text" placeholder="发往位置" />
  77. </uni-forms>
  78. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  79. </view>
  80. <view class="list">
  81. <view class="lable">特殊行李类型</view>
  82. <picker @change="bindPickerChange3"
  83. style="line-height: 2.375rem;background-color: antiquewhite;"
  84. :placeholderStyle="placeholderStyle" :value="index3" :range-key="'specialTypeName'"
  85. :range="specialTypeList">
  86. <view class="uni-input">
  87. {{specialTypeList[index3].specialType?specialTypeList[index3].specialTypeName:"无"}}
  88. </view>
  89. </picker>
  90. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  91. </view>
  92. <view class="list">
  93. <view class="lable">异常类型</view>
  94. <picker @change="bindPickerChange4"
  95. style="line-height: 2.375rem;background-color: antiquewhite;"
  96. :placeholderStyle="placeholderStyle" :value="index4" :range-key="'name'"
  97. :range="exceptionList">
  98. <view class="uni-input">{{exceptionList[index4].type?exceptionList[index4].name:"无"}}</view>
  99. </picker>
  100. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  101. </view>
  102. <view class="list">
  103. <view class="lable">非正常状态码</view>
  104. <picker @change="bindPickerChange5"
  105. style="line-height: 2.375rem;background-color: antiquewhite;"
  106. :placeholderStyle="placeholderStyle" :value="index5" :range-key="'name'"
  107. :range="abnormalList">
  108. <view class="uni-input">{{abnormalList[index5].type?abnormalList[index5].name:"无"}}</view>
  109. </picker>
  110. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  111. </view>
  112. <view class="list">
  113. <view class="lable">装载序号</view>
  114. <uni-easyinput :inputBorder="false"
  115. style="line-height: 2.375rem;background-color: antiquewhite;"
  116. :placeholderStyle="placeholderStyle" :clearable="false" :styles="style" :disabled="false"
  117. v-model="luggageData.loadNumber" type="text" placeholder="装载序号" />
  118. </uni-forms>
  119. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  120. </view>
  121. <view class="list">
  122. <view class="lable">容器编号</view>
  123. <uni-easyinput :inputBorder="false"
  124. style="line-height: 2.375rem;background-color: antiquewhite;"
  125. :placeholderStyle="placeholderStyle" :clearable="false" :styles="style" :disabled="false"
  126. v-model="luggageData.container_ID" type="text" placeholder="容器编号" />
  127. </uni-forms>
  128. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  129. </view>
  130. <view class="list">
  131. <view class="lable">备注</view>
  132. <uni-easyinput :inputBorder="false"
  133. style="line-height: 2.375rem;background-color: antiquewhite;"
  134. :placeholderStyle="placeholderStyle" :clearable="false" :styles="style" :disabled="false"
  135. v-model="luggageData.luggage_describe" type="text" placeholder="备注" />
  136. </uni-forms>
  137. <!-- <view class="listup"><uni-icons type="gear" size="25"></uni-icons></view> -->
  138. </view>
  139. <mk-upload :imgList="imgList" @onDelete="onDelete" @onChoose="onChoose" />
  140. </scroll-view>
  141. </view>
  142. </view>
  143. <button type="primary" class="send" size="small" v-if="luggageData" @tap="sendData()">提交</button>
  144. <luanqing-date-picker ref="datePickerObj" :isSimple="mode === 'simple'" :isMultiple="mode === 'multiple'"
  145. @finishSelectDate="finishSelectDate" :defaultCheckedList="['2023-03-28','2023-09-25']">
  146. </luanqing-date-picker>
  147. <uv-datetime-picker :show="show" v-model="value1" mode="datetime" @confirm='confirm'
  148. @close='show = false'></uv-datetime-picker>
  149. </view>
  150. </template>
  151. <script>
  152. import mkUpload from "@/components/mk-upload/mk-upload.vue"
  153. import {
  154. translateapp
  155. } from "@/utils/compress.js"
  156. import {
  157. pathToBase64,
  158. base64ToPath
  159. } from 'image-tools'
  160. export default {
  161. data() {
  162. return {
  163. imgList: [],
  164. ImgObjList: [],
  165. placeholderStyle: "color:000",
  166. style: {
  167. disableColor: "#fff",
  168. color: "#000"
  169. },
  170. dataheight: '10.75rem',
  171. datatime: '2023-06-02',
  172. datacontime: '',
  173. luggageData: null,
  174. luggageDataOld: null,
  175. current: 0,
  176. mode: 'round',
  177. show: false,
  178. value1: Number(new Date()),
  179. formatter: 'yy',
  180. index: 0,
  181. index2: 0,
  182. index3: 0,
  183. index4: 0,
  184. index5: 0,
  185. nodeList: [],
  186. nodeNameList: [],
  187. nextNode: null,
  188. luggageNum: null,
  189. specialTypeList: [],
  190. specialTypeNameList: [],
  191. exceptionList: [{
  192. "type": null,
  193. "name": "非异常行李"
  194. },
  195. {
  196. "type": "DPR",
  197. "name": "破损"
  198. },
  199. {
  200. "type": "AHL",
  201. "name": "少收"
  202. },
  203. {
  204. "type": "OHD",
  205. "name": "多收"
  206. }
  207. ],
  208. exceptionNameList: ["非异常行李", "破损", "少收", "多收"],
  209. abnormalList: [{
  210. "type": null,
  211. "name": "无"
  212. },
  213. {
  214. "type": "NAL",
  215. "name": "未授权装载"
  216. },
  217. {
  218. "type": "OFF",
  219. "name": "已卸载"
  220. },
  221. {
  222. "type": "PFF",
  223. "name": "预卸载"
  224. },
  225. {
  226. "type": "UNS",
  227. "name": "未找到"
  228. },
  229. {
  230. "type": "OND",
  231. "name": "在场未装载,未授权"
  232. },
  233. {
  234. "type": "ONA",
  235. "name": "在场未装载,已授权"
  236. }
  237. ],
  238. abnormalNameList: ["无", "未被授权的装载", "已卸载", "未找到", "在场未装载,未被授权", "在场未装载,已授权"],
  239. isShow: true,
  240. sourceData: null
  241. }
  242. },
  243. created(option) {},
  244. onLoad(option) {
  245. this.luggageNum = option.luggageNum
  246. this.getNode()
  247. this.getSpecialTypeList()
  248. this.getDetial(this.luggageNum)
  249. },
  250. onUnload() {
  251. uni.$off("scancodemsg");
  252. },
  253. onShow() {
  254. uni.$on("scancodemsg", (data) => {
  255. if (data.msg.trim().length > 9) {
  256. this.luggageNum = data.msg.trim()
  257. this.getDetial(this.luggageNum)
  258. }
  259. if (data.msg.trim().length < 9) {
  260. this.luggageData.container_ID = data.msg.trim()
  261. }
  262. });
  263. },
  264. onHide() {
  265. uni.$off("scancodemsg");
  266. },
  267. components: {
  268. mkUpload
  269. },
  270. methods: {
  271. async getNode() {
  272. let data = {
  273. "serviceId": 3003,
  274. "dataContent": {},
  275. "event": "0"
  276. }
  277. await this.$http.httpPost('/openApi/query', data).then(res => {
  278. if (res.code == "0") {
  279. this.nodeList = res.returnData;
  280. this.nodeList.map(item => {
  281. this.nodeNameList.push(item.nodeName)
  282. })
  283. }
  284. })
  285. },
  286. async getSpecialTypeList() {
  287. let data = {
  288. "serviceId": 16,
  289. "dataContent": {},
  290. "event": "0"
  291. }
  292. await this.$http.httpPost('/openApi/query', data).then(res => {
  293. if (res.code == "0") {
  294. this.specialTypeList = res.returnData;
  295. this.specialTypeList.unshift({
  296. "specialType": null,
  297. "specialTypeName": "非特殊行李",
  298. })
  299. this.specialTypeList.map(item => {
  300. this.specialTypeNameList.push(item.specialTypeName)
  301. })
  302. }
  303. })
  304. },
  305. async getDetial(num) {
  306. let data = {
  307. "serviceId": 3002,
  308. "page": 1,
  309. "pageSize": 1,
  310. "dataContent": {
  311. "luggageNum": num, //行李号
  312. },
  313. "event": "0"
  314. }
  315. await this.$http.httpPost('/openApi/query', data).then(res => {
  316. this.luggageData = null
  317. if (res.code == "0" && res.returnData.length > 0) {
  318. this.luggageData = res.returnData[0]
  319. this.getImgList()
  320. this.luggageDataOld = JSON.parse(JSON.stringify(res.returnData[0]))
  321. this.nodeList.map((item, index) => {
  322. if (res.returnData[0].nodeCode == item.nodeCode) {
  323. this.index = index
  324. this.index2 = index + 1
  325. if(!this.luggageData.location_describe){
  326. this.luggageData.location_describe = item.nodeDescribe
  327. }
  328. }
  329. })
  330. this.specialTypeList.map((item, index) => {
  331. if (res.returnData[0].specialType == item.specialType) {
  332. this.index3 = index
  333. }
  334. })
  335. this.exceptionList.map((item, index) => {
  336. if (res.returnData[0].exception_type == item.type) {
  337. this.index4 = index
  338. }
  339. })
  340. this.abnormalList.map((item, index) => {
  341. if (res.returnData[0].abnormalState == item.type) {
  342. this.index5 = index
  343. }
  344. })
  345. } else {
  346. this.$scanAudio.src = "../../static/hqxl.mp3"
  347. this.$scanAudio.play()
  348. this.imgList = []
  349. uni.showToast({
  350. icon: 'none',
  351. title: "未查询到该行李信息",
  352. duration: 5000
  353. });
  354. this.fall()
  355. }
  356. })
  357. },
  358. async sendData() {
  359. this.luggageData.sourceAirport = this.$storage.get('airportName');
  360. this.luggageData.ID = null;
  361. this.luggageData.dataType = "BPM";
  362. this.luggageData.agentNumber = this.$storage.getJson("users").user_name;
  363. this.luggageData.device_ID = uni.getDeviceInfo().deviceId;
  364. let data = {
  365. "serviceId": 3005,
  366. "dataContent": [
  367. this.luggageData
  368. ],
  369. "event": "0"
  370. }
  371. await this.$http.httpPost('/openApi/query', data).then(res => {
  372. if (res.code == "0") {
  373. uni.showToast({
  374. icon: 'none',
  375. title: "操作成功",
  376. duration: 5000
  377. });
  378. } else {
  379. this.$scanAudio.src = "../../static/czsb.mp3"
  380. this.$scanAudio.play()
  381. uni.showToast({
  382. icon: 'none',
  383. title: "操作失败",
  384. duration: 5000
  385. });
  386. }
  387. })
  388. },
  389. bindPickerChange(e) {
  390. this.index = e.detail.value
  391. this.luggageData.nodeCode = this.nodeList[this.index].nodeCode;
  392. this.luggageData.location_describe = this.nodeList[this.index].nodeDescribe;
  393. this.index2 = this.index + 1
  394. this.luggageData.to_location_describe = this.nodeList[this.index2].nodeDescribe;
  395. },
  396. bindPickerChange2(e) {
  397. this.index2 = e.detail.value
  398. this.luggageData.to_location_describe = this.nodeList[this.index2].nodeDescribe;
  399. },
  400. bindPickerChange3(e) {
  401. this.index3 = e.detail.value
  402. this.luggageData.specialType = this.specialTypeList[this.index3].specialType;
  403. },
  404. bindPickerChange4(e) {
  405. this.index4 = e.detail.value
  406. this.luggageData.exception_type = this.exceptionList[this.index4].type;
  407. },
  408. bindPickerChange5(e) {
  409. this.index5 = e.detail.value
  410. this.luggageData.abnormalState = this.abnormalList[this.index5].type;
  411. },
  412. confirm(e) {
  413. this.show = false
  414. console.log(e.value)
  415. let timestamp = e.value
  416. // 此处时间戳以毫秒为单位
  417. let date = new Date(parseInt(timestamp));
  418. let Year = date.getFullYear();
  419. let Moth = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1);
  420. let Day = (date.getDate() < 10 ? '0' + date.getDate() : date.getDate());
  421. let Hour = (date.getHours() < 10 ? '0' + date.getHours() : date.getHours());
  422. let Minute = (date.getMinutes() < 10 ? '0' + date.getMinutes() : date.getMinutes());
  423. let Sechond = (date.getSeconds() < 10 ? '0' + date.getSeconds() : date.getSeconds());
  424. let GMT = Year + '-' + Moth + '-' + Day + ' ' + Hour + ':' + Minute
  425. this.datacontime = GMT
  426. },
  427. async sendImg(upImgList) {
  428. let data = {
  429. "serviceId": 30051,
  430. "dataContent": upImgList,
  431. "event": "1"
  432. }
  433. await this.$http.httpPost('/openApi/newdata', data).then(res => {
  434. if (res.code == "0") {
  435. uni.hideLoading();
  436. this.getImgList()
  437. uni.showToast({
  438. icon: 'none',
  439. title: "上传成功",
  440. duration: 5000
  441. });
  442. } else {
  443. uni.showToast({
  444. icon: 'none',
  445. title: "上传失败",
  446. duration: 5000
  447. });
  448. }
  449. })
  450. },
  451. async getImgList() {
  452. let data = {
  453. "serviceId": 30051,
  454. "page": 1,
  455. "pageSize": 999,
  456. "dataContent": {
  457. "carrflights": this.luggageData.carrierFlights,
  458. "carrierFlightsDate": this.luggageData.carrierFlightsDate,
  459. "luggageNum": this.luggageData.luggageNum
  460. },
  461. "event": "0"
  462. }
  463. await this.$http.httpPost('/openApi/query', data).then(res => {
  464. if (res.code == "0") {
  465. this.imgList = [];
  466. this.ImgObjList = res.returnData;
  467. res.returnData.map(item => {
  468. if (item.luggagePic) {
  469. this.imgList.push(item.luggagePic);
  470. }
  471. })
  472. } else {
  473. uni.showToast({
  474. icon: 'none',
  475. title: "获取图片失败",
  476. duration: 5000
  477. });
  478. }
  479. })
  480. },
  481. async deleteImg(index) {
  482. let data = {
  483. "serviceId": 30051,
  484. "dataContent": [{
  485. "filter": [{
  486. "left": "(",
  487. "column": "id",
  488. "comparator": "=",
  489. "value": this.ImgObjList[index].id,
  490. "right": ")",
  491. "connector": "and"
  492. }]
  493. }],
  494. "event": "3"
  495. }
  496. await this.$http.httpPost('/openApi/movedata', data).then(res => {
  497. if (res.code == "0") {
  498. this.getImgList()
  499. wx.showToast({
  500. title: '删除成功',
  501. icon: 'success',
  502. duration: 3000
  503. });
  504. } else {
  505. uni.showToast({
  506. icon: 'none',
  507. title: "删除图片失败",
  508. duration: 5000
  509. });
  510. }
  511. })
  512. },
  513. onDelete(index) {
  514. console.log(index)
  515. //删除成功回调后执行 只做演示
  516. uni.showLoading({
  517. title: '删除中'
  518. });
  519. this.deleteImg(index)
  520. },
  521. onChoose(e) {
  522. console.log(e)
  523. uni.showLoading({
  524. title: '上传中'
  525. });
  526. // let upImgList = []
  527. // this.newImgList = []
  528. e.tempFilePaths.map(item => {
  529. translateapp(item, 70, imgUrl => {
  530. pathToBase64(imgUrl).then(path => {
  531. let upImgList = []
  532. let newData = {
  533. "carrflights": this.luggageData.carrierFlights,
  534. "carrierFlightsDate": this.luggageData.carrierFlightsDate,
  535. "luggageNum": this.luggageData.luggageNum,
  536. "luggagePic": path,
  537. "piclocation":this.luggageData.location_describe
  538. }
  539. upImgList.push(newData)
  540. this.sendImg(upImgList)
  541. }).catch(error => {
  542. uni.hideLoading();
  543. })
  544. })
  545. })
  546. },
  547. onPreviewTake(index) {
  548. console.log(index)
  549. wx.showActionSheet({
  550. itemList: ['预览图片', '删除图片'],
  551. success(res) {
  552. console.log(res.tapIndex)
  553. },
  554. fail(res) {
  555. console.log(res.errMsg)
  556. }
  557. })
  558. },
  559. openImg(index) {
  560. const imgList = this.imgList;
  561. const isReverse = false;
  562. const currentIndex = isReverse ? (imgList.length - index) - 1 : index
  563. const imgLists = isReverse ? imgList.reverse() : imgList;
  564. uni.previewImage({
  565. current: currentIndex,
  566. urls: imgLists
  567. });
  568. },
  569. finishSelectDate(e) {
  570. this.datatime = e[0]
  571. console.error("选择了日期:", e);
  572. },
  573. movetran(e) {
  574. let arr = uni.getSystemInfoSync().windowHeight;
  575. this.dataheight = (e.changedTouches[0].clientY / 16) + 'rem'
  576. if (e.changedTouches[0].clientY / 16 > 10.75) {
  577. this.dataheight = 10.75 + 'rem'
  578. } else if (e.changedTouches[0].clientY / 16 < 3.75) {
  579. this.dataheight = 3.75 + 'rem'
  580. }
  581. },
  582. toNode() {
  583. uni.navigateTo({
  584. url: "/pages/detailNode/index?luggageNum=" + this.luggageData.luggageNum + "&carrierFlights=" +
  585. this.luggageData.carrierFlights + "&carrierFlightsDate=" + this.luggageData
  586. .carrierFlightsDate
  587. })
  588. },
  589. uplist() {
  590. uni.redirectTo({
  591. url: "/pages/loadingdetails/index"
  592. })
  593. },
  594. lop(index) {
  595. this.action = index
  596. },
  597. seach() {
  598. uni.redirectTo({
  599. url: "/pages/search/index"
  600. })
  601. },
  602. fall() {
  603. uni.navigateBack({
  604. delta: 1
  605. })
  606. },
  607. change(e) {
  608. this.current = e.detail.current;
  609. }
  610. },
  611. }
  612. </script>
  613. <style lang="scss" scoped>
  614. .app-content {
  615. >.send {
  616. position: fixed;
  617. bottom: 10px;
  618. left: calc((100% - 20.5625rem) / 2);
  619. width: 20.5625rem;
  620. height: 3rem;
  621. background: linear-gradient(179.10deg, rgba(51, 161, 165, 1.00) 11.326%, rgba(59, 111, 142, 1.00) 119.032%, rgba(59, 111, 142, 1.00) 119.032%, rgba(59, 111, 142, 1.00) 119.032%);
  622. border-radius: .25rem;
  623. color: rgb(255, 255, 255);
  624. font-family: Noto Sans SC;
  625. font-size: 1rem;
  626. margin: 0 auto;
  627. display: flex;
  628. align-items: center;
  629. justify-content: center;
  630. }
  631. >.header {
  632. width: 100%;
  633. height: 4.375rem;
  634. display: flex;
  635. justify-content: space-between;
  636. align-items: center;
  637. // background: rgba(49,85,99,1);
  638. color: rgb(16, 17, 22);
  639. font-family: Noto Sans SC;
  640. font-size: 1rem;
  641. position: fixed;
  642. left: 0;
  643. top: 0;
  644. z-index: 1;
  645. >.log {
  646. width: .375rem;
  647. height: .75rem;
  648. font-size: .75rem;
  649. position: absolute;
  650. left: 1.5rem;
  651. background: url('../../static/ico@1x.png') no-repeat;
  652. background-size: 100% 100%;
  653. }
  654. >.up {
  655. width: .8456rem;
  656. height: .8456rem;
  657. position: absolute;
  658. right: 1.5rem;
  659. background: url('../../static/search.png') no-repeat;
  660. background-size: 100% 100%;
  661. // color: rgb(37, 121, 160);
  662. // font-family: Noto Sans SC;
  663. // font-size: .875rem;
  664. // font-weight: 500;
  665. }
  666. }
  667. >.content {
  668. width: 100%;
  669. // height: calc(100vh - 20.9375rem - 4.375rem);
  670. padding-bottom: 0;
  671. position: absolute;
  672. bottom: 0;
  673. top: 10.75rem;
  674. border-radius: 6px 6px 0px 0px;
  675. overflow: hidden;
  676. background: rgb(255, 255, 255);
  677. >.choice {
  678. width: 100%;
  679. // height: 3.75rem;
  680. display: flex;
  681. align-items: center;
  682. padding: 0 0 0 0.8rem;
  683. box-sizing: border-box;
  684. >.scroll-Y {
  685. // height: calc(100% - 2.5rem - 2.75rem - 2.25rem - 2.25rem);
  686. width: 100%;
  687. height: 27.75rem;
  688. .list {
  689. height: 3.375rem;
  690. display: flex;
  691. align-items: center;
  692. border-bottom: 1px solid rgb(238, 238, 238);
  693. position: relative;
  694. color: rgb(0, 0, 0);
  695. font-family: Noto Sans SC;
  696. font-size: 13px;
  697. font-weight: 400;
  698. .uni-input {
  699. width: 240px;
  700. padding-left: 10px;
  701. }
  702. >.lable {
  703. color: rgb(0, 0, 0);
  704. font-family: Noto Sans SC;
  705. font-size: 13px;
  706. font-weight: 500;
  707. line-height: 19px;
  708. letter-spacing: 0px;
  709. text-align: left;
  710. width: 6rem;
  711. }
  712. >.listup {
  713. // width: .25rem;
  714. // height: .5rem;
  715. // background: url('../../static/icos.png') no-repeat;
  716. // background-size: 100% 100%;
  717. position: absolute;
  718. right: 5px;
  719. }
  720. >.nodeList {
  721. background: linear-gradient(179.10deg, rgba(51, 161, 165, 1.00) 11.326%, rgba(59, 111, 142, 1.00) 119.032%, rgba(59, 111, 142, 1.00) 119.032%, rgba(59, 111, 142, 1.00) 119.032%);
  722. border-radius: .25rem;
  723. color: rgb(255, 255, 255);
  724. font-family: Noto Sans SC;
  725. font-size: 1rem;
  726. float: right;
  727. margin-right: 10px;
  728. }
  729. }
  730. }
  731. }
  732. .but {
  733. width: 20.5625rem;
  734. height: 2.5rem;
  735. background: linear-gradient(179.10deg, rgba(51, 161, 165, 1.00) 11.326%, rgba(59, 111, 142, 1.00) 119.032%, rgba(59, 111, 142, 1.00) 119.032%, rgba(59, 111, 142, 1.00) 119.032%);
  736. border-radius: .25rem;
  737. color: rgb(255, 255, 255);
  738. font-family: Noto Sans SC;
  739. font-size: 1rem;
  740. margin: 0 auto;
  741. display: flex;
  742. align-items: center;
  743. justify-content: center;
  744. margin-top: 0.25rem;
  745. margin-bottom: 2.25rem;
  746. }
  747. }
  748. }
  749. </style>