login.vue 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  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">欢迎使用</view>
  5. <view class="title-2">实验室安全智慧化管控系统</view>
  6. <view class="null-p"></view>
  7. <img class="login-img" @click="verificationButton(2)" :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 == 5){
  78. const str = this.verificationList.join('');
  79. if(str === '1122'){
  80. this.$set(this,'verificationList',[]);
  81. uni.navigateTo({
  82. url: '/pages/views/login/accountLogin'
  83. });
  84. }else{
  85. this.$set(this,'verificationList',[]);
  86. }
  87. }
  88. },
  89. },
  90. }
  91. </script>
  92. <style lang="stylus" scoped>
  93. #login{
  94. height: 100%;
  95. width: 100%;
  96. background #fff;
  97. position relative;
  98. display: flex;
  99. flex-direction: column;
  100. position: relative;
  101. .logo-img{
  102. width:370rpx;
  103. height:68rpx;
  104. margin:320rpx 190rpx 0;
  105. }
  106. .position-top-right-box{
  107. position: absolute;
  108. top:0;
  109. right:0;
  110. width:230rpx;
  111. height:230rpx;
  112. border-bottom-left-radius: 100%;
  113. background-color: #E5F2FE;
  114. filter: blur(4px);
  115. }
  116. .position-bottom-left-box{
  117. position: absolute;
  118. bottom:0;
  119. left:0;
  120. width:230rpx;
  121. height:230rpx;
  122. border-top-right-radius: 100%;
  123. background-color: #E5F2FE;
  124. filter: blur(4px);
  125. z-index:0;
  126. }
  127. .title-1{
  128. font-size:38rpx;
  129. line-height:55rpx;
  130. height:55rpx;
  131. text-align: center;
  132. color:#333;
  133. margin:90rpx 0 31rpx;
  134. }
  135. .title-2{
  136. font-size:38rpx;
  137. line-height:55rpx;
  138. height:55rpx;
  139. text-align: center;
  140. color:#0183fa;
  141. }
  142. .null-p{
  143. flex:1;
  144. }
  145. .login-img{
  146. width:600rpx;
  147. height:408rpx;
  148. margin:0 auto 125rpx;
  149. }
  150. .ssoButton{
  151. width:650rpx;
  152. height:80rpx;
  153. line-height:80rpx;
  154. text-align: center;
  155. background-color:#0183fa;
  156. color:#fff;
  157. font-size:32rpx;
  158. margin:0 auto 175rpx;
  159. border-radius:50rpx;
  160. z-index:1;
  161. }
  162. .accountButton{
  163. width:200;
  164. height:80rpx;
  165. line-height:80rpx;
  166. text-align: center;
  167. color:#0183fa;
  168. font-size:28rpx;
  169. margin:0 auto 40rpx;
  170. }
  171. }
  172. </style>