index.vue 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971
  1. <template name="apps">
  2. <view>
  3. <!-- <swiper class="swiper" circular :indicator-dots="true" :autoplay="true" :interval="3000" :duration="800">
  4. <swiper-item>
  5. <image src="../../static/img/titlebg.jpg" class="swiper-item"></image>
  6. </swiper-item>
  7. <swiper-item>
  8. <image src="../../static/img/titlebg.jpg" class="swiper-item"></image>
  9. </swiper-item>
  10. </swiper> -->
  11. <swiper class="swiper" circular :indicator-dots="true" :autoplay="true" :interval="3000" :duration="800">
  12. <swiper-item v-for="(item, index) in picture" :key="index">
  13. <image :src="item" class="swiper-item"></image>
  14. </swiper-item>
  15. </swiper>
  16. <view class="line-box">
  17. <view class="center-box">
  18. <view class="center-left-box">
  19. <view class="btn-box-1 mart-t">
  20. {{pageInfo.enterprisec}}
  21. </view>
  22. <view class="btn-box-2 mart-t" @click="totongxunlu22">
  23. {{pageInfo.todayc}}
  24. </view>
  25. <view class="btn-box-3 mart-t" @click="totongxunlu23">
  26. {{pageInfo.samemonthc}}
  27. </view>
  28. <view class="btn-box-4 mart-t">
  29. {{pageInfo.industryc}}
  30. </view>
  31. </view>
  32. <view class="center-left-box">
  33. <view class="btn-box-text mart-t">
  34. 平台企业数
  35. </view>
  36. <view class="btn-box-text mart-t">
  37. 当日活跃数
  38. </view>
  39. <view class="btn-box-text mart-t">
  40. 当月活跃数
  41. </view>
  42. <view class="btn-box-text mart-t">
  43. 细分行业数
  44. </view>
  45. </view>
  46. </view>
  47. <view class="center-box">
  48. <view class="kuai-text">快捷入口</view>
  49. <view class="center-left-box">
  50. <view class="btn-Imbox" @click="totongxunlu">
  51. <image class="center-img" src="/static/img/icon1.png"></image>
  52. <p>重点园区</p>
  53. </view>
  54. <view class="btn-Imbox" @click="totongxunlu2">
  55. <image class="center-img" src="/static/img/icon2.png"></image>
  56. <p>产业图谱</p>
  57. </view>
  58. <view class="btn-Imbox" @click="totongxunlu6">
  59. <image class="center-img" src="/static/img/icon4.png"></image>
  60. <p>产品分布</p>
  61. </view>
  62. </view>
  63. <view class="center-left-box">
  64. <view class="btn-Imbox" @click="totongxunlu3">
  65. <image class="center-img" src="/static/img/icon3.png"></image>
  66. <p>链主企业</p>
  67. </view>
  68. <view class="btn-Imbox" @click="totongxunlu4">
  69. <image class="center-img" src="/static/img/icon8.png"></image>
  70. <p>产品供需</p>
  71. </view>
  72. <view class="btn-Imbox" @click="totongxunlu5">
  73. <image class="center-img" src="/static/img/icon5.png"></image>
  74. <p>我的发布</p>
  75. </view>
  76. <!-- <view class="btn-Imbox" v-if="isLogin!=null" @click="outlogin">
  77. <image class="center-img" src="/static/img/icon7.png"></image>
  78. <p>退出登录</p>
  79. </view>
  80. <view class="btn-Imbox" v-if="isLogin==null" @click="outlogin">
  81. <image class="center-img" src="/static/img/icon6.png"></image>
  82. <p>立即登录</p>
  83. </view> -->
  84. </view>
  85. </view>
  86. <!-- <view :style="[{top:CustomBar + 'px'}]">
  87. <view class="search-box">
  88. <view class="search-box1">
  89. <view class="choose-box">
  90. <input type="text" placeholder="输入或选择属地" v-model="searchForm.des1" confirm-type="search" style="padding-left: 28rpx;"
  91. ></input>
  92. <jp-picker class="choose-boxp" v-model="searchForm.des1" rangeKey="label" rangeValue="value"
  93. :range="parkList2" >
  94. </jp-picker>
  95. </view>
  96. <view class="choose-box">
  97. <input type="text" placeholder="输入或选择行业" v-model="searchForm.industry" confirm-type="search" style="padding-left: 28rpx;"
  98. ></input>
  99. <jp-picker class="choose-boxp" v-model="searchForm.industry" rangeKey="label" rangeValue="value"
  100. :range="parkList" >
  101. </jp-picker>
  102. </view>
  103. </view>
  104. <view class="choose-box2" style="margin-top: 20rpx;">
  105. <view class="choose-box3">
  106. <view style="width: 300rpx;display: flex;align-items: center;color: #666666;font-size: 33rpx;">
  107. 产业链环节:
  108. </view>
  109. <DoublePicker
  110. :column1Label="''"
  111. :column2Label="''"
  112. :column1Data="parkList3"
  113. :column2Data="parkList4"
  114. v-model="ddd1"
  115. @update:column2Data="updateCities"
  116. />
  117. </view>
  118. </view>
  119. <view class="choose-box2" style="margin-top: 20rpx;">
  120. <view style="width: 520rpx;">
  121. <input type="text" placeholder="输入关键词产品或企业名称" v-model="searchForm.name" confirm-type="search"
  122. ></input>
  123. </view>
  124. <text style="padding-left: 40rpx;flex: 1;" class="cuIcon-search color-white" @click="doSearch"></text>
  125. </view>
  126. </view>
  127. <mescroll-body ref="mescrollRef" @init="mescrollInit" @down="downCallback" :up="upOption" @up="upCallback">
  128. <view class="cu-item" :class="modalName=='move-box-'+ index?'move-cur':''"
  129. v-for="(item, index) in dataList" :key="index" @touchstart="ListTouchStart"
  130. @touchmove="ListTouchMove" @touchend="ListTouchEnd" :data-target="'move-box-' + index">
  131. <view class="item-box" @click="gotoBuildInfo(item.id)">
  132. <view class="item-title">
  133. <view>
  134. {{item.name}}
  135. </view>
  136. </view>
  137. <view class="item-line">
  138. <view v-if="item.bz3!=''&&item.bz3!=undefined" class="item-name">{{item.bz1}}、{{item.bz3}}</view>
  139. <view v-if="item.bz3==''||item.bz3==undefined" class="item-name">{{item.bz1}}</view>
  140. </view>
  141. <view class="item-line">
  142. <view class="item-name2">{{item.industry}}</view>
  143. <view class="item-name3">{{item.des1}}</view>
  144. </view>
  145. </view>
  146. </view>
  147. </mescroll-body>
  148. <uni-fab :pattern=" {
  149. color: '#7A7E83',
  150. backgroundColor: '#fff',
  151. selectedColor: '#007AFF',
  152. buttonColor: '#007AFF'
  153. }" horizontal="right" vertical="bottom" @fabClick="add" v-if="stype == 5"></uni-fab>
  154. </view> -->
  155. <view @click="outlogin" class="fixed-bottom-right" v-if="isLogin!=null">
  156. <image class="center-img2" src="/static/img/icon_logout.png"></image>
  157. </view>
  158. </view>
  159. </view>
  160. </template>
  161. <script>
  162. import loginService from "@/api/auth/loginService";
  163. import uniFab from '@/components/uni-fab/uni-fab.vue';
  164. import DoublePicker from '@/components/DoublePicker/DoublePicker.vue'
  165. import MescrollMixin from "@/components/mescroll-uni/mescroll-mixins.js";
  166. import MescrollMoreItemMixin from "@/components/mescroll-uni/mixins/mescroll-more-item.js";
  167. import {mapActions} from 'vuex'
  168. export default {
  169. mixins: [MescrollMixin, MescrollMoreItemMixin], // 使用mixin (在main.js注册全局组件)
  170. name: "apps",
  171. components: {
  172. uniFab,
  173. DoublePicker
  174. },
  175. data() {
  176. return {
  177. isLogin:"",
  178. pageInfo: {},
  179. loginid:"",
  180. stype: "", // 企业 => 3 楼宇 => 2 园区 => 1 zfadmin => 4 admin=> 5
  181. searchForm: {
  182. des1:"",
  183. industry:"",
  184. name:"",
  185. },
  186. picture:["https://miniapp.huidutech.com.cn/yd_qycpfbH5/bg1.jpg",
  187. "https://miniapp.huidutech.com.cn/yd_qycpfbH5/bg2.jpg",
  188. "https://miniapp.huidutech.com.cn/yd_qycpfbH5/bg3.jpg",
  189. "https://miniapp.huidutech.com.cn/yd_qycpfbH5/bg4.jpg"],
  190. curWord: "", //当前搜索关键词
  191. dataList: [], // 数据列表
  192. modalName: null,
  193. tablePage: {
  194. total: 0,
  195. currentPage: 1,
  196. pageSize: 10,
  197. orders: []
  198. },
  199. loading: false,
  200. parkId: '',
  201. parkList: [],
  202. parkList2: [],
  203. parkList3: [],
  204. parkList4: [],
  205. ddd1:"" ,
  206. };
  207. },
  208. onLoad(query) {
  209. if(query!=undefined&&query!=null&&query!=''){
  210. if(query.loginid!=undefined){
  211. this.loginid=query.loginid
  212. this.autoLogin();
  213. }
  214. }
  215. },
  216. onShow() {
  217. this.isLogin=this.$auth.checkisLogin();
  218. },
  219. created() {
  220. this.getPageInfo();
  221. this.getParkList()
  222. this.getParkList2()
  223. this.getParkList3()
  224. },
  225. methods: {
  226. ...mapActions(['refreshUserInfo']),
  227. //选择产业链环节
  228. getParkList3() {
  229. loginService.getIndustryChainList({
  230. }).then(({
  231. data
  232. }) => {
  233. // this.parkList3 = data.map((item) => {
  234. // return {
  235. // label: item.bz2,
  236. // value: item.bz2
  237. // }
  238. // });
  239. this.parkList3=[{label: '上游',value: '上游'},{label: '中游',value: '中游'},{label: '下游',value: '下游'}]
  240. this.parkList4 = data
  241. .map((item) => {
  242. const match = item.bz2.match(/\((.*?)\)/); // 匹配括号内的内容
  243. if (match) {
  244. return {
  245. label: match[1], // 括号内的内容
  246. value: match[1] // 括号内的内容
  247. };
  248. }
  249. return null; // 如果没有括号,返回 null
  250. })
  251. .filter((item) => item !== null) // 过滤掉 null 值
  252. .reduce((acc, current) => {
  253. // 使用 Set 去重
  254. const existingItem = acc.find((item) => item.value === current.value);
  255. if (!existingItem) {
  256. acc.push(current);
  257. }
  258. return acc;
  259. }, []);
  260. this.parkList3.unshift({
  261. label: "全部",
  262. value: ""
  263. });
  264. this.parkList4.unshift({
  265. label: "全部",
  266. value: ""
  267. });
  268. }).catch(e => {
  269. console.log(e)
  270. })
  271. },
  272. //选择属地
  273. getParkList2() {
  274. loginService.getAreaList({
  275. }).then(({
  276. data
  277. }) => {
  278. this.parkList2 = data.map((item) => {
  279. return {
  280. label: item.des1,
  281. value: item.des1
  282. }
  283. })
  284. this.parkList2.unshift({
  285. label: "盐都区",
  286. value: ""
  287. });
  288. }).catch(e => {
  289. console.log(e)
  290. })
  291. },
  292. //选择行业
  293. getParkList() {
  294. loginService.getHyList({
  295. }).then(({
  296. data
  297. }) => {
  298. this.parkList = data.map((item) => {
  299. return {
  300. label: item.industry,
  301. value: item.industry
  302. }
  303. })
  304. this.parkList.unshift({
  305. label: "全部",
  306. value: ""
  307. });
  308. }).catch(e => {
  309. console.log(e)
  310. })
  311. },
  312. /*获取数据列表 */
  313. upCallback(page) {
  314. this.loading = true
  315. loginService.comlist({
  316. current: page.num,
  317. size: page.size,
  318. name: this.curWord,
  319. des1: this.parkId,
  320. orders: [{ column: 'a.create_date', asc: false }],
  321. ...this.searchForm
  322. }).then(({
  323. data
  324. }) => {
  325. let curPageData = data.records
  326. this.mescroll.endBySize(curPageData.length, data.total);
  327. //如果是第一页需手动制空列表
  328. if (page.num == 1)
  329. this.dataList = [];
  330. //追加新数据
  331. this.dataList = this.dataList.concat(curPageData);
  332. }).catch(e => {
  333. //联网失败, 结束加载
  334. this.mescroll.endErr();
  335. })
  336. },
  337. gotoBuildInfo(id) {
  338. // uni.navigateTo({
  339. // url: `/pages/comEdit/comEdit?id=${id}&ischeck=1`
  340. // })
  341. window.location.href=`/yd_qycpfbH5/#/pages/comEdit/comEdit?id=${id}&ischeck=1`
  342. },
  343. updateCities(newCities) {
  344. this.cities = newCities;
  345. },
  346. // 搜索
  347. doSearch() {
  348. if(this.ddd1.column2!=''&&this.ddd1!=''){
  349. this.searchForm.bz2=this.ddd1.column1+'('+this.ddd1.column2+')';
  350. }else if(this.ddd1!=''){
  351. this.searchForm.bz2=this.ddd1.column1;
  352. }
  353. this.dataList = []; // 先清空列表,显示加载进度
  354. this.mescroll.resetUpScroll();
  355. },
  356. totongxunlu(){
  357. uni.navigateTo({
  358. url: '/pages/comList/comList'
  359. })
  360. },
  361. totongxunlu2(){
  362. uni.navigateTo({
  363. url: '/pages/buildList/buildList2?w=1'
  364. })
  365. },
  366. totongxunlu3(){
  367. uni.navigateTo({
  368. url: '/pages/buildList/buildList?w=2'
  369. })
  370. },
  371. totongxunlu6(){
  372. uni.navigateTo({
  373. url: '/pages/buildList/buildList?w=1'
  374. })
  375. },
  376. totongxunlu4(){
  377. uni.navigateTo({
  378. url: '/pages/product/productList?w=1'
  379. })
  380. },
  381. totongxunlu5(){
  382. if(this.isLogin==null){
  383. uni.showModal({
  384. title: '您还未登录,现在去登录?',
  385. showCancel: true,
  386. success: (res) => {
  387. if (res.confirm) {
  388. uni.showLoading()
  389. uni.reLaunch({
  390. url: '/pages/login/login'
  391. })
  392. }
  393. }
  394. });
  395. }else{
  396. uni.navigateTo({
  397. url: '/pages/product/productList?w=2'
  398. })
  399. }
  400. },
  401. totongxunlu22(){
  402. uni.navigateTo({
  403. url: '/pages/buildList/buildList3?w=1'
  404. })
  405. },
  406. totongxunlu23(){
  407. uni.navigateTo({
  408. url: '/pages/buildList/buildList3?w=2'
  409. })
  410. },
  411. getPageInfo() {
  412. loginService.InfoStatistics({}).then(({ data }) => {
  413. this.pageInfo = data;
  414. //103改为 14/103
  415. //this.pageInfo.industryc="14/"+this.pageInfo.industryc;
  416. });
  417. },
  418. autoLogin(){
  419. console.log("登录id"+this.loginid);
  420. loginService.loginid( this.loginid).then(({data}) => {
  421. this.$store.commit('SET_TOKEN',data.token);
  422. this.refreshUserInfo();
  423. }).catch(e => {
  424. console.error(e)
  425. })
  426. },
  427. getRole() {
  428. let userInfo = uni.getStorageSync('WMS-userinfo')
  429. var officeId = userInfo.officeDTO.id;
  430. var roleIds = userInfo.roleIds;
  431. if (roleIds.indexOf("17bac1f980264e3e8193bc965538e2c6") != -1) {
  432. //// 管理员
  433. this.stype = 5
  434. uni.setStorageSync('stype', this.stype);
  435. } else if (roleIds.indexOf("ade960e8f02544998b07397304c059c1") != -1) {
  436. // 政府管理员
  437. this.stype = 4
  438. uni.setStorageSync('stype', this.stype);
  439. } else {
  440. console.log('==================>这里走了么','================>存一个stape')
  441. loginService
  442. .getOtherIdByOffceid({
  443. officeid: officeId,
  444. })
  445. .then(({
  446. data
  447. }) => {
  448. console.log(data, "====================>getOtherIdByOffceid");
  449. this.stype = data.stype;
  450. uni.setStorageSync('stype', this.stype);
  451. });
  452. }
  453. },
  454. outloginset(){
  455. loginService.logout().then(({
  456. data
  457. }) => {
  458. this.$store.commit('logout');
  459. uni.clearStorage();
  460. })
  461. this.$store.commit('logout');
  462. uni.clearStorage();
  463. this.isLogin=this.$auth.checkisLogin();
  464. uni.hideLoading()
  465. },
  466. outlogin() {
  467. uni.showModal({
  468. title: '您确认退出么?',
  469. showCancel: true,
  470. success: (res) => {
  471. if (res.confirm) {
  472. uni.showLoading()
  473. this.outloginset();
  474. // uni.reLaunch({
  475. // url: '/pages/login/login'
  476. // })
  477. }
  478. }
  479. });
  480. },
  481. tces() {
  482. uni.navigateTo({
  483. url: '/pages/index/AudioToWord'
  484. })
  485. },
  486. // ListTouch触摸开始
  487. ListTouchStart(e) {
  488. this.listTouchStart = e.touches[0].pageX
  489. },
  490. // ListTouch计算方向
  491. ListTouchMove(e) {
  492. this.listTouchDirection = e.touches[0].pageX - this.listTouchStart > -60 ? 'right' : 'left'
  493. },
  494. // ListTouch计算滚动
  495. ListTouchEnd(e) {
  496. if (this.listTouchDirection == 'left') {
  497. this.modalName = e.currentTarget.dataset.target
  498. } else {
  499. this.modalName = null
  500. }
  501. this.listTouchDirection = null
  502. }
  503. }
  504. }
  505. </script>
  506. <style>
  507. .page {
  508. height: 100vh;
  509. }
  510. .line-box {
  511. padding-left: 20rpx;
  512. padding-right: 20rpx;
  513. margin-top: 20rpx;
  514. }
  515. .mart-t {
  516. margin-top: 30rpx;
  517. }
  518. .center-box{
  519. margin-top: 20rpx;
  520. width: 100%;
  521. border-radius: 25rpx;
  522. border-radius: 25rpx;
  523. background: #fff;
  524. box-shadow: 0px 8px 16px 2px rgba(101, 101, 101, 0.2);
  525. padding-bottom: 30rpx;
  526. display: flex;
  527. flex-wrap: wrap;
  528. }
  529. .center-left-box {
  530. width: 100%;
  531. padding-bottom: 30rpx;
  532. display: flex;
  533. flex-wrap: wrap;
  534. }
  535. .btn-box-text {
  536. flex:1;
  537. height: 20rpx;
  538. text-align: center;
  539. color: #000000;
  540. font-size: 14px;
  541. font-weight: 700;
  542. }
  543. .btn-box-1 {
  544. flex:1;
  545. height: 30rpx;
  546. text-align: center;
  547. color: #36A7F3;
  548. font-size: x-large;
  549. font-weight: 700;
  550. }
  551. .btn-box-2 {
  552. flex:1;
  553. height: 30rpx;
  554. text-align: center;
  555. color:#F3365A;
  556. font-size: x-large;
  557. font-weight: 700;
  558. }
  559. .btn-box-3 {
  560. flex:1;
  561. height: 30rpx;
  562. text-align: center;
  563. color:#15D578;
  564. font-size: x-large;
  565. font-weight: 700;
  566. }
  567. .btn-box-4 {
  568. flex:1;
  569. height: 30rpx;
  570. text-align: center;
  571. color:#F1A31B;
  572. font-size: x-large;
  573. font-weight: 700;
  574. }
  575. .btn-Imbox {
  576. flex:1;
  577. height: 150rpx;
  578. padding-top: 8rpx;
  579. text-align: center;
  580. display: flex;
  581. flex-direction: column;
  582. justify-content: center; /* 子元素内部内容竖向居中 */
  583. align-items: center; /* 子元素内部内容水平居中 */
  584. text-align: center; /* 文字居中 */
  585. }
  586. .btn-Imbox p {
  587. font-size: 14px; /* 文字大小,可根据需要调整 */
  588. margin: 0; /* 去掉默认的外边距 */
  589. font-weight: 700;
  590. }
  591. .center-img{
  592. width: 90rpx;
  593. height: 90rpx;
  594. margin-bottom: 10rpx;
  595. text-align: center;
  596. }
  597. .center-img2{
  598. width: 70rpx;
  599. height: 70rpx;
  600. margin-top: 10rpx;
  601. margin-bottom: 20rpx;
  602. text-align: center;
  603. }
  604. .kuai-text{
  605. color: #000000;
  606. font-weight: 900;
  607. font-size: 34rpx;
  608. padding-top: 20rpx;
  609. padding-left: 20rpx;
  610. }
  611. .btn-box-5 {
  612. width: 337rpx;
  613. height: 200rpx;
  614. background-image: url('../../static/img/btn3.png');
  615. background-size: 100% 100%;
  616. }
  617. .btn-box-6 {
  618. width: 337rpx;
  619. height: 200rpx;
  620. background-image: url('../../static/img/btn6.png');
  621. background-size: 100% 100%;
  622. }
  623. .h-200 {
  624. height: 200rpx;
  625. }
  626. .swiper {
  627. width: 750rpx;
  628. height: 310rpx;
  629. }
  630. .swiper-item {
  631. width: 750rpx;
  632. height: 310rpx;
  633. background-color: aliceblue;
  634. }
  635. .font-size-35 {
  636. font-size: 35px !important;
  637. }
  638. .img-size {
  639. width: 80rpx;
  640. height: 80rpx;
  641. }
  642. .content-box {
  643. width: 437rpx;
  644. height: 200rpx;
  645. }
  646. .my-app .padding-sm {
  647. padding: 6px;
  648. }
  649. .grid .padding-sm .bg-white {
  650. box-shadow: 0 1px 4px #f9f9f9, 1px 1px 40px rgba(0, 0, 0, .06);
  651. }
  652. .bg-blue {
  653. background: #fff;
  654. color: #0081ff !important;
  655. }
  656. .text-white,
  657. .line-white,
  658. .lines-white {
  659. color: #0081ff !important;
  660. }
  661. .cu-bar .search-form {
  662. background-color: white;
  663. }
  664. .item-box{
  665. width: 710rpx;
  666. background: #FFFFFF;
  667. box-shadow: 0px 1px 3px 0px rgba(9,2,4,0.1);
  668. border-radius: 10px;
  669. padding-top: 20rpx;
  670. padding-left: 38rpx;
  671. padding-right: 10rpx;
  672. margin-top: 20rpx;
  673. }
  674. .item-title{
  675. position: relative;
  676. display: flex;
  677. justify-content: space-between;
  678. font-size: 30rpx;
  679. color: #010101;
  680. font-weight: bold;
  681. align-items: center;
  682. }
  683. .item-line{
  684. display: flex;
  685. height: 48rpx;
  686. margin-top: 20rpx;
  687. }
  688. .item-line2{
  689. height: 48rpx;
  690. margin-top: 20rpx;
  691. }
  692. .subtitle{
  693. color: #E5880E;
  694. }
  695. .item-name{
  696. margin-top: 5rpx;
  697. font-size: 29rpx;
  698. color: #666666;
  699. }
  700. .item-name2{
  701. font-size: 29rpx;
  702. color: #676D99;
  703. }
  704. .item-name3{
  705. display: flex;
  706. width: 100%;
  707. padding-right: 30rpx;
  708. flex: 1;
  709. justify-content: flex-end;
  710. font-size: 29rpx;
  711. color: #676D99;
  712. }
  713. .item-content{
  714. color: #1497EF;
  715. font-size: 30rpx;
  716. }
  717. .btn-box{
  718. display: flex;
  719. }
  720. .line-zs{
  721. width: 2rpx;
  722. height: 30rpx;
  723. background: #36A7F3;
  724. }
  725. .edit-botton{
  726. width: 100rpx;
  727. height: 48rpx;
  728. line-height: 48rpx;
  729. color: #fff;
  730. font-size: 28rpx;
  731. margin-right: 20rpx;
  732. border-radius: 10rpx;
  733. background: #5A9EE9;
  734. text-align: center;
  735. }
  736. .del-botton{
  737. width: 100rpx;
  738. height: 48rpx;
  739. line-height: 48rpx;
  740. color: #fff;
  741. font-size: 28rpx;
  742. margin-right: 20rpx;
  743. border-radius: 10rpx;
  744. background: #F27C85;
  745. text-align: center;
  746. }
  747. .color-white{
  748. color: #808080;
  749. font-size: 40rpx;
  750. line-height: 60rpx;
  751. }
  752. .search-box{
  753. padding-left: 20rpx;
  754. padding-right: 20rpx;
  755. padding-top: 20rpx;
  756. margin-top: 20rpx;
  757. width: 100%;
  758. border-radius: 25rpx;
  759. border-radius: 25rpx;
  760. background: #fff;
  761. box-shadow: 0px 8px 16px 2px rgba(101, 101, 101, 0.2);
  762. padding-bottom: 30rpx;
  763. display: flex;
  764. flex-wrap: wrap;
  765. }
  766. .search-box1{
  767. display: flex;
  768. }
  769. .input-box{
  770. background: #fff;
  771. height: 65rpx;
  772. width: 640rpx;
  773. display: flex;
  774. align-items: center;
  775. border-radius: 30rpx;
  776. padding-left: 30rpx;
  777. margin-right: 20rpx;
  778. }
  779. .input-boxinput{
  780. height: 75rpx;
  781. font-size: 15rpx;
  782. }
  783. .choose-box{
  784. background: #fff;
  785. width: 325rpx;
  786. border-radius: 23rpx;
  787. height: 70rpx;
  788. display: flex;
  789. align-items: center;
  790. justify-content: center;
  791. margin-right: 20rpx;
  792. border: 1rpx solid #808080;
  793. }
  794. .choose-box2{
  795. background: #fff;
  796. width: 100%;
  797. border-radius: 23rpx;
  798. height: 70rpx;
  799. display: flex;
  800. padding-left: 29rpx;
  801. align-items: center;
  802. border: 1rpx solid #808080;
  803. }
  804. .choose-box3{
  805. display: flex;
  806. }
  807. .choose-boxp{
  808. font-size: 32rpx;
  809. width: 80rpx;
  810. }
  811. .fixed-bottom-right {
  812. padding: 20rpx;
  813. position: fixed;
  814. bottom: 20px; /* 距离底部的距离 */
  815. right: 20px; /* 距离右侧的距离 */
  816. }
  817. </style>