| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450 | <template>  <view id="login" class="section">    <view class="bg">      <image class="bgImage" :src="useStore.$state.loginBg" v-if="useStore.$state.loginBg" />    </view>    <view class="middle">      <view class="top">        <image class="logo" mode="heightFix" :src="useStore.$state.loginLogo" v-if="useStore.$state.loginLogo" />        <!-- <image class="logo" mode="heightFix" src="@/static/logo200.png" v-else /> -->        <text class="title" :style="{ color: useStore.$state.loginBg ? '#FFFFFF' : '#000000' }" v-if="useStore.$state.loginTitle">{{ useStore.$state.loginTitle }}</text>        <!-- <text class="title" v-else>移动端登录</text> -->      </view>      <view class="content">        <text class="title" :style="{ color: useStore.$state.loginBg ? '#FFFFFF' : '#000000' }">请登录</text>        <!-- #ifdef APP-PLUS || MP-WEIXIN  -->        <view id="okay" v-if="!linkUrl">首次账号登录请先配置服务器</view>        <view class="setting" @tap="goSeverConfig"> 配置服务器 </view>        <!--#endif-->      </view>      <view id="login-input" v-if="switchText == '账号密码登录'">        <u-input v-model="phone" prefixIcon="phone" placeholder="请输入手机号码" />        <u-input v-model="verify" prefixIcon="email" placeholder="请输入验证码" :maxlength="6">          <template #suffix>            <button class="verify" @click="getVerifyCode">{{ !useStore.codeTime ? "获取验证码" : useStore.codeTime + "s" }}</button>          </template>        </u-input>      </view>      <view id="login-input" v-if="switchText == '验证码登录'">        <u-input type="text" v-model="username" prefixIcon="account" placeholder="请输入账号" />        <u-input v-model="password" prefixIcon="lock" placeholder="请输入密码" :password="inputIconBool">          <template #suffix>            <text :class="!inputIconBool ? 'iconfont ucicon-eye' : 'iconfont ucicon-eye-close'" @click="inputIconBool = !inputIconBool"></text>          </template>        </u-input>      </view>      <button class="submit" @click="submitRes">登 录</button>      <view class="switchText">        <text @click="switchMode">{{ switchText }}</text>      </view>      <!-- #ifdef APP-PLUS || MP-WEIXIN -->      <view class="xieyi text-center">        <u-checkbox-group v-model="userChecked">          <u-checkbox :name="true" shape="circle" inactiveColor="#0081ff" size="13"></u-checkbox>        </u-checkbox-group>        <text>我已阅读并同意</text>        <text @click="handleUserAgrement" class="text-blue">用户协议</text>        <text>和</text>        <text @click="handlePrivacy" class="text-blue">隐私协议</text>      </view>      <!--#endif-->    </view>    <view class="bottom">      <div class="title">{{ useStore.$state.loginBottomTitle }}</div>    </view>  </view></template><script setup>import config from "@/config";import { onLoad, onShow, onHide, onLaunch, onReady } from "@dcloudio/uni-app";import { reactive, getCurrentInstance, toRefs, inject } from "vue";import { publicStores, useStores } from "@/store/modules/index";const useStore = useStores();const publicStore = publicStores();const { proxy } = getCurrentInstance();const data = reactive({  /** login数据 */  phone: undefined,  verify: undefined,  switchText: "验证码登录",  username: undefined,  password: undefined,  inputIconBool: true,  /** 服务器配置数据 */  linkUrl: uni.getStorageSync("serveUrl"),  /** 用户隐私协议数据 */  userChecked: [true],});const { phone, verify, switchText, username, password, inputIconBool, linkUrl, userChecked } = toRefs(data);function goSeverConfig() {  proxy.$tab.navigateTo("/pages/serveConfigSelect");}/**登录方式切换 */function switchMode() {  if (switchText.value == "验证码登录") {    switchText.value = "账号密码登录";  } else {    switchText.value = "验证码登录";  }}/** 点击发送验证码 */function getVerifyCode() {  //#ifdef APP-PLUS || MP-WEIXIN  if (!uni.getStorageSync("serveUrl")) {    proxy.$modal.msg("首次账号登录请先配置服务器");    return;  }  //#endif    verify.value = undefined;  useStore.GetCodeImg({    phone: phone.value,    success: (res) => {      proxy.$modal.msgSuccess("发送成功");    },  });}/** * 判断运行环境 */function env() {  useStore.SET_LOGINMOBILELIST({    loginTitle: "",    loginBottomTitle: "",    loginBg: "",    loginLogo: "",    tenantId: "",  });  //#ifdef H5  if (window.location.host) {    linkUrl.value = window.location.host;    // linkUrl.value='ces.cn';    // linkUrl.value = "172.16.120.165:13207";    // linkUrl.value = "172.16.120.165:13200";    // linkUrl.value = "localhost:81";    useStore.GetMobileTenantConfig({ url: linkUrl.value });  }  //#endif  //#ifdef APP-PLUS || MP-WEIXIN  if (uni.getStorageSync("serveUrl")) {    linkUrl.value = uni.getStorageSync("serveUrl");    useStore.GetMobileTenantConfig({ url: linkUrl.value });  } else {    uni.setStorageSync("serveUrl", "manager.usky.cn");    publicStore.setServeList("manager.usky.cn", "");    linkUrl.value = uni.getStorageSync("serveUrl");    useStore.GetMobileTenantConfig({ url: linkUrl.value });  }  //#endif}/** 点击提交按钮 */function submitRes() {  //#ifdef APP-PLUS || MP-WEIXIN  if (!uni.getStorageSync("serveUrl")) {    proxy.$modal.msg("首次登录请先进行服务器配置");    return;  }  if (!userChecked.value[0]) {    proxy.$modal.msg("请在阅读并同意 用户协议和隐私协议后登录");    return;  }  //#endif  if (switchText.value == "账号密码登录") {    if (!phone.value) {      proxy.$modal.msg("请输入手机号码");      return;    }    if (!/^1(?:3\d|4[4-9]|5[0-35-9]|6[67]|7[013-8]|8\d|9\d)\d{8}$/.test(phone.value)) {      proxy.$modal.msg("请输入正确的手机号码");      return;    }    if (!verify.value) {      proxy.$modal.msg("请输入验证码");      return;    }    login({      phone: phone.value,      verify: verify.value,      tenantId: useStore.$state.tenantId,    });  } else {    if (!username.value) {      proxy.$modal.msg("请输入账户");      return;    }    if (!password.value) {      proxy.$modal.msg("请输入密码");      return;    }    login({      username: username.value,      password: password.value,      tenantId: useStore.$state.tenantId,    });  }}/** 获取登录数据 */function login(data) {  proxy.$modal.loading("登录中,请耐心等待...");  useStore.Login(data).then(() => {    /** 获取用户信息 */    proxy.$modal.closeLoading();    useStore.GetInfo().then((res) => {      proxy.$tab.reLaunch("/pages/index");    });  });}// 用户协议function handleUserAgrement() {  let site = config.appInfo.agreements[0];  proxy.$tab.navigateTo(`/pages/common/webview/index?title=${site.title}&url=${site.url}`);}// 隐私协议function handlePrivacy() {  let site = config.appInfo.agreements[1];  proxy.$tab.navigateTo(`/pages/common/webview/index?title=${site.title}&url=${site.url}`);}onShow(() => {  env();  useStore.SetInterval("codeTime"); //调用倒计时定时器});onLoad((options) => {});</script><style lang="scss" scoped>.section {  position: fixed;  top: 0;  left: 0;  right: 0;  bottom: 0;  display: flex;  width: 100%;  height: 100vh;  background-color: $uni-bg-color;  .bg {    width: 100%;    height: 100%;    position: fixed;    top: 0;    left: 0;    right: 0;    z-index: 0;    .bgImage {      width: 100%;      height: 100%;    }  }  .middle {    position: relative;    z-index: 1;    width: 100%;    padding: 0 30px;    margin: auto;    margin-top: 30%;    .top {      display: flex;      align-items: center;      justify-content: center;      margin-bottom: 60px;      .logo {        height: 40px;        width: auto;        margin-right: 10px;      }      .title {        font-size: 20px;        color: #000;        max-width: 50%;        // white-space: nowrap;        // overflow: hidden; //超出的文本隐藏        // text-overflow: ellipsis; //溢出用省略号显示      }    }    .content {      display: flex;      position: relative;      margin: 30px 0 30px 0;      .title {        margin: auto auto auto 0;        color: #000;        font-size: 18px;      }      .icons {        margin: auto 5px auto 0;      }      .setting {        color: #2a98ff;        margin: auto 0;      }      #okay {        position: absolute;        top: -35px;        right: 0px;        background-color: #2a98ff;        text-align: center;        line-height: 25px;        display: inline-block;        color: #fff;        padding: 3px 5px;        border-radius: 3px;        &::after {          content: "";          position: absolute;          border: 5px solid transparent;          transform: rotate(90deg);          right: 5px;          bottom: -9px;          border-left-color: #2a98ff;        }      }    }    // 登录页-服务器配置样式 开始    #login-input {      :deep(.u-input) {        height: 45px;        border: 0 !important;        border-radius: 8px;        margin-bottom: 15px;        padding: 5px 12px !important;        background-color: #f5f6fa !important;      }      :deep(.input-placeholder) {        color: #c0c4cc !important;      }      :deep(.uni-input-wrapper) {        font-size: 16px;      }      :deep(.u-icon__icon) {        font-size: 24px !important;        line-height: 24px !important;        color: gray !important;      }      :deep(.iconfont) {        color: gray !important;      }      :deep(:-webkit-autofill) {        caret-color: #000; // 设置光标颜色        // -webkit-text-fill-color: gray !important;        -webkit-box-shadow: 0 0 0px 1000px transparent inset !important;        background-color: transparent;        background-image: none;        transition: background-color 50000s ease-in-out 0s; //背景色透明  生效时长  过渡效果  启用时延迟的时间      }      .verify {        color: #2a98ff;        font-size: 14px;        padding-left: 0px;        padding-right: 0px;        background-color: transparent;        &::after {          border: 0px;        }      }    }    .switchText {      color: #96a6b5;      width: 100%;      display: block;      margin-top: 20px;    }    .submit {      height: 45px;      line-height: 45px;      border-radius: 24px;      background: #2a98ff;      color: #fff;      border: 0px;    }    .xieyi {      color: #96a6b5;      margin-top: 30px;      display: flex;      justify-content: center;      > uni-view {        margin: auto 0;      }      > uni-text {        margin: auto 0;      }      // animation: roundRule 0.5s linear infinite;    }    @keyframes roundRule {      0% {        transform: translateX(0);      }      50% {        transform: translateX(-5px);      }      100% {        transform: translateX(0);      }    }  }  .bottom {    position: fixed;    width: 100%;    bottom: 20px;    .title {      text-align: center;      color: #96a6b5;      font-size: 14px;    }  }}</style>
 |