newLogin2.vue 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. <template>
  2. <div class="account">
  3. <div class="account-container">
  4. <div class="account-wrap-logo">
  5. <img src="@/assets/images/login/comnova-EYES2.png" alt="" />
  6. </div>
  7. <div class="content-detail">
  8. <div class="account-wrap-login">
  9. <div class="login-pic">
  10. <div>
  11. <img src="~@/assets/images/login/login-pic.png" alt="" />
  12. </div>
  13. </div>
  14. <div class="login-form">
  15. <div class="login-form-container">
  16. <!-- <div class="account-top"> 欢迎您进入<br />安全管控开放平台 </div> -->
  17. <img src="~@/assets/images/login/login-Yubei-admin.png" alt="" />
  18. <LoginForm
  19. v-if="tab === 'login'"
  20. ref="LoginFormRef"
  21. @go-register="changeGoRegister"
  22. />
  23. <RegisterForm v-else ref="RegisterFormRef" @back-login="changeBackLogin" />
  24. </div>
  25. </div>
  26. </div>
  27. </div>
  28. </div>
  29. </div>
  30. </template>
  31. <script lang="ts" setup>
  32. import { ref } from 'vue';
  33. import LoginForm from './LoginForm2.vue';
  34. import RegisterForm from './RegisterForm2.vue';
  35. const tab = ref('login');
  36. function changeBackLogin() {
  37. tab.value = 'login';
  38. }
  39. function changeGoRegister() {
  40. tab.value = 'register';
  41. }
  42. </script>
  43. <style lang="scss" scoped>
  44. .account {
  45. width: 100%;
  46. margin: 0 auto;
  47. &-container {
  48. width: 100%;
  49. min-height: 100vh;
  50. display: flex;
  51. flex-wrap: wrap;
  52. justify-content: flex-start;
  53. flex-direction: column;
  54. align-content: center;
  55. padding: 15px;
  56. background: #fff;
  57. // background: -webkit-linear-gradient(-135deg, #c850c0, #4158d0);
  58. // background: -o-linear-gradient(-135deg, #c850c0, #4158d0);
  59. // background: -moz-linear-gradient(-135deg, #c850c0, #4158d0);
  60. // background: linear-gradient(-135deg, #c850c0, #4158d0);
  61. }
  62. &-wrap-logo {
  63. width: 1280px;
  64. margin-top: 30px;
  65. @media (max-width: 1280px) {
  66. width: 100%;
  67. }
  68. img {
  69. @media (max-width: 450px) {
  70. width: 100px;
  71. }
  72. }
  73. }
  74. &-wrap-login {
  75. width: 1280px;
  76. height: 554px;
  77. background: #fff;
  78. // border-radius: 10px;
  79. overflow: hidden;
  80. display: flex;
  81. flex-wrap: wrap;
  82. justify-content: space-between;
  83. padding: 30px 95px 33px 95px;
  84. .login-pic {
  85. display: flex;
  86. @media (max-width: 1020px) {
  87. display: none;
  88. }
  89. img {
  90. max-width: 100%;
  91. }
  92. }
  93. @media (max-width: 1280px) {
  94. width: 100%;
  95. padding: 30px 0px 33px 0px;
  96. justify-content: center;
  97. }
  98. .login-form {
  99. width: 350px;
  100. @media (max-width: 1020px) {
  101. width: min(100%, 350px);
  102. margin: auto;
  103. }
  104. &-container {
  105. display: flex;
  106. flex-direction: column;
  107. img {
  108. padding: 40px;
  109. // @media (max-width: 400px) {
  110. // padding: 25px;
  111. // }
  112. }
  113. }
  114. }
  115. }
  116. // @media (max-width: 640px) {
  117. // &-wrap-login {
  118. // width: 100%;
  119. // padding: 30px;
  120. // height: auto;
  121. // }
  122. // }
  123. }
  124. .content-detail {
  125. flex: 1;
  126. display: flex;
  127. justify-content: center;
  128. align-items: center;
  129. }
  130. </style>