login.vue 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. <template>
  2. <view id="login">
  3. <img class="logo-img" :src="imagesUrl('commonality/logo%401x.png')" @click="verificationButton(1)">
  4. <view class="title-1" @click="verificationButton(2)">欢迎使用</view>
  5. <view class="title-2" @click="verificationButton(3)">实验室安全智慧化管控系统</view>
  6. <view class="null-p"></view>
  7. <img class="login-img" @click="verificationButton(4)" :src="imagesUrl('commonality/img_tyrzdl_ch%402x.png')">
  8. <view class="ssoButton" @click="goPage('ssoLogin')">统一身份认证登录</view>
  9. <view class="accountButton" v-if="!weChatProgramVersion"
  10. @click="goPage('accountLogin')">账号密码登录</view>
  11. <view class="position-top-right-box"></view>
  12. <view class="position-bottom-left-box" @click="verificationButton(5)"></view>
  13. </view>
  14. </template>
  15. <script>
  16. import {
  17. config
  18. } from '@/api/request/config.js'
  19. import {
  20. configInfo,
  21. getConfigByType
  22. } from '@/pages/api/index.js'
  23. export default {
  24. name: "ssoLogin",
  25. data() {
  26. return {
  27. weChatProgramVersion:true,
  28. verificationList:[],
  29. }
  30. },
  31. onLoad(option) {
  32. },
  33. mounted() {
  34. this.getConfigInfo();
  35. },
  36. methods: {
  37. goPage(type){
  38. if(type == 'ssoLogin'){
  39. uni.navigateTo({
  40. url: '/pages/views/login/ssoLogin'
  41. });
  42. }else if(type == 'accountLogin'){
  43. uni.navigateTo({
  44. url: '/pages/views/login/accountLogin'
  45. });
  46. }
  47. },
  48. //查询公共配置
  49. async getConfigInfo() {
  50. const {
  51. data
  52. } = await configInfo({
  53. type: '5'
  54. });
  55. if (data.code == 200) {
  56. let list = JSON.parse(data.data)
  57. let newData = {};
  58. list.forEach((item) => {
  59. let obj = JSON.parse(item.configValue)
  60. newData = {
  61. ...newData,
  62. ...obj
  63. }
  64. })
  65. if(config.weChatProgramVersion === newData.weChatProgramVersion){
  66. this.$set(this,'weChatProgramVersion',true);
  67. }else{
  68. this.$set(this,'weChatProgramVersion',false);
  69. }
  70. }
  71. },
  72. verificationButton(val){
  73. if(val == 1){
  74. this.verificationList.push(1)
  75. }else if(val == 2){
  76. this.verificationList.push(2)
  77. }else if(val == 3){
  78. this.verificationList.push(3)
  79. }else if(val == 4){
  80. this.verificationList.push(4)
  81. }else if(val == 5){
  82. const str = this.verificationList.join('');
  83. if(str === '1423'){
  84. uni.navigateTo({
  85. url: '/pages/views/login/accountLogin'
  86. });
  87. }else{
  88. this.$set(this,'verificationList',[]);
  89. }
  90. }
  91. },
  92. },
  93. }
  94. </script>
  95. <style lang="stylus" scoped>
  96. #login{
  97. height: 100%;
  98. width: 100%;
  99. background #fff;
  100. position relative;
  101. display: flex;
  102. flex-direction: column;
  103. position: relative;
  104. .logo-img{
  105. width:370rpx;
  106. height:68rpx;
  107. margin:320rpx 190rpx 0;
  108. }
  109. .position-top-right-box{
  110. position: absolute;
  111. top:0;
  112. right:0;
  113. width:230rpx;
  114. height:230rpx;
  115. border-bottom-left-radius: 100%;
  116. background-color: #E5F2FE;
  117. filter: blur(4px);
  118. }
  119. .position-bottom-left-box{
  120. position: absolute;
  121. bottom:0;
  122. left:0;
  123. width:230rpx;
  124. height:230rpx;
  125. border-top-right-radius: 100%;
  126. background-color: #E5F2FE;
  127. filter: blur(4px);
  128. }
  129. .title-1{
  130. font-size:38rpx;
  131. line-height:55rpx;
  132. height:55rpx;
  133. text-align: center;
  134. color:#333;
  135. margin:90rpx 0 31rpx;
  136. }
  137. .title-2{
  138. font-size:38rpx;
  139. line-height:55rpx;
  140. height:55rpx;
  141. text-align: center;
  142. color:#0183fa;
  143. }
  144. .null-p{
  145. flex:1;
  146. }
  147. .login-img{
  148. width:600rpx;
  149. height:408rpx;
  150. margin:0 auto 125rpx;
  151. }
  152. .ssoButton{
  153. width:650rpx;
  154. height:80rpx;
  155. line-height:80rpx;
  156. text-align: center;
  157. background-color:#0183fa;
  158. color:#fff;
  159. font-size:32rpx;
  160. margin:0 auto 175rpx;
  161. border-radius:50rpx;
  162. }
  163. .accountButton{
  164. width:200;
  165. height:80rpx;
  166. line-height:80rpx;
  167. text-align: center;
  168. color:#0183fa;
  169. font-size:28rpx;
  170. margin:0 auto 40rpx;
  171. }
  172. }
  173. </style>