基础库
 
 
 
 
 

666 lines
31 KiB

  1. import 'dart:io';
  2. import 'package:flutter/cupertino.dart';
  3. import 'package:flutter/material.dart';
  4. import 'package:secverify/secverify.dart';
  5. import 'package:zhiying_comm/models/user/user_info_model.dart';
  6. import 'package:zhiying_comm/models/user/user_info_model_notifier.dart';
  7. import 'package:zhiying_comm/pages/login_page/account/login_account_page.dart';
  8. import 'package:zhiying_comm/pages/login_page/invite/login_invite_page.dart';
  9. import 'package:zhiying_comm/pages/login_page/model/login_model.dart';
  10. import 'package:zhiying_comm/util/empty_util.dart';
  11. import 'package:zhiying_comm/util/global_config.dart';
  12. import 'package:zhiying_comm/util/log/let_log.dart';
  13. import 'package:zhiying_comm/util/net_util.dart';
  14. import 'package:provider/provider.dart';
  15. import 'package:fluttertoast/fluttertoast.dart';
  16. import 'package:zhiying_comm/util/router_util.dart';
  17. import '../../page_factory.dart';
  18. class QuickLoginUtil {
  19. // sdk 版本
  20. String _version = "unkown";
  21. // 是否支持
  22. bool _isVerifySupport = true;
  23. /// 单例对象
  24. static QuickLoginUtil _instance;
  25. /// 内部构造方法,可避免外部暴露构造函数,进行实例化
  26. QuickLoginUtil._internal();
  27. /// 工厂构造方法,这里使用命名构造函数方式进行声明
  28. factory QuickLoginUtil.getInstance() => _getInstance();
  29. /// 获取单例内部方法
  30. static _getInstance() {
  31. // 只能有一个实例
  32. if (_instance == null) {
  33. _instance = QuickLoginUtil._internal();
  34. }
  35. return _instance;
  36. }
  37. /// 初始化方法
  38. void init() {
  39. //可选预先设置
  40. _preSettings();
  41. //判断手机本地环境是否支持
  42. isVerifySupport();
  43. if (_isVerifySupport) {
  44. //预取号
  45. _preVerify();
  46. }
  47. }
  48. /// 打开秒验登录页面的方法
  49. void openQuickLogin(BuildContext context, Quick model) {
  50. // 取号前设置
  51. Secverify.autoFinishOauthPage(false);
  52. //设置UI属性
  53. _setPortraitLayout(model);
  54. Secverify.isVerifySupport.then((bool value) {
  55. if (value) {
  56. _verify(context);
  57. } else {
  58. // showAlert("当前环境不支持", context);
  59. Logger.warn("当前环境不支持");
  60. _openSMSLoginPage(context);
  61. }
  62. });
  63. }
  64. /// 打开验证码登录的方法
  65. void _openSMSLoginPage(BuildContext context) {
  66. /// 需要填写注册码再跳首页
  67. Navigator.push(context, CupertinoPageRoute(builder: (_) => LoginAccountPage(null)));
  68. }
  69. /// 打开邀请码页面
  70. void _openInvitePage(BuildContext context) {
  71. print('跳转到邀请码页面');
  72. Navigator.push(context, CupertinoPageRoute(builder: (_) => LoginInvitePage()));
  73. }
  74. /// 打开首页的方法
  75. void _openHomePage(BuildContext context) {
  76. RouterUtil.goBackHomePage(context);
  77. // Navigator.pushAndRemoveUntil(context, MaterialPageRoute(builder: (BuildContext context) => PageFactory.create('homePage', null)), (Route<dynamic> route) => false);
  78. }
  79. // 需要自己实现这部分
  80. void _doLogin(Map ret, BuildContext context) async {
  81. var opToken = ret.containsKey("opToken") ? ret["opToken"] : "";
  82. var token = ret.containsKey("token") ? ret["token"] : "";
  83. var operator = ret.containsKey("operator") ? ret["operator"] : "";
  84. var phoneOperator = ret.containsKey("phoneOperator") ? ret["phoneOperator"] : "";
  85. var md5 = ret.containsKey("md5") ? ret["md5"] : "";
  86. // var appKey = ret.containsKey("appkey") ? ret["appkey"] : "";
  87. var params = Map<String, String>();
  88. params["optoken"] = opToken;
  89. params["operator"] = operator;
  90. params["operator"] = phoneOperator;
  91. params["token"] = token;
  92. if(!EmptyUtil.isEmpty(md5)) params["md5"] = md5;
  93. // params["appkey"] = appKey;
  94. try {
  95. var result = await NetUtil.post('/api/v1/sign/mob/in', params: params, method: NetMethod.POST);
  96. if (NetUtil.isSuccess(result) && !EmptyUtil.isEmpty(result[GlobalConfig.HTTP_RESPONSE_KEY_DATA])) {
  97. UserInfoModel model = UserInfoModel.fromJson(result[GlobalConfig.HTTP_RESPONSE_KEY_DATA]);
  98. if (!EmptyUtil.isEmpty(model)) {
  99. if (model.registerInviteCodeEnable == '1') {
  100. /// 需要填写注册码再跳首页
  101. _openInvitePage(context);
  102. return;
  103. } else {
  104. /// 不需要填写注册码,直接登录
  105. Provider.of<UserInfoNotifier>(context, listen: false).setUserInfo(model);
  106. _openHomePage(context);
  107. return;
  108. }
  109. }
  110. }
  111. } catch (e, s) {
  112. Logger.error(e, s);
  113. }
  114. Fluttertoast.showToast(msg: '登录失败');
  115. }
  116. // 预取号
  117. void _preVerify() {
  118. Secverify.preVerify((Map ret, Map err) {
  119. if (err != null) {
  120. //失败情况下会返回错误信息,可以打印查看
  121. // showAlert(err.toString(),context);
  122. Logger.log('mob 秒验登录失败: ${err?.toString()}, sdk 版本 = ${_version}');
  123. } else {
  124. String rst = ret.toString();
  125. if (ret == null || ret.isEmpty) {
  126. rst = 'mob 秒验 预登录成功!, sdk 版本 = ${_version}, ret = ${rst?.toString()}';
  127. Logger.log(rst);
  128. }
  129. // showAlert(rst,context);
  130. }
  131. });
  132. }
  133. // 预登录
  134. void _preSettings() {
  135. //提交隐私协议结果
  136. Secverify.submitPrivacyGrantResult(true);
  137. //是否自动关闭授权页面,如果不自动关闭,必须在取号回调中调用方法关闭授权页面
  138. Secverify.autoFinishOauthPage(false);
  139. //是否输出运营商控制台日志
  140. Secverify.setDebugMode(false);
  141. //设置超时时间
  142. Secverify.setTimeOut(5000);
  143. //获取当前SDK版本号
  144. getVersion();
  145. }
  146. // 获取SDK版本
  147. Future<String> getVersion() async {
  148. String version;
  149. version = await Secverify.getVersion;
  150. _version = version;
  151. return _version;
  152. }
  153. // 是否支持登录
  154. Future<bool> isVerifySupport() async {
  155. bool isVerifySupport = await Secverify.isVerifySupport;
  156. this._isVerifySupport = isVerifySupport;
  157. return this._isVerifySupport;
  158. }
  159. // 取号接口
  160. void _verify(BuildContext context) {
  161. Secverify.preVerify((ret, err) {
  162. if (err != null) {
  163. // showAlert(err.toString(),context);
  164. Logger.log(err.toString());
  165. _openSMSLoginPage(context);
  166. } else {
  167. Secverify.verify((Map ret, Map err) {
  168. if (err != null) {
  169. //打印错误信息
  170. // showAlert(err.toString(), context);
  171. Logger.log(err.toString());
  172. _openSMSLoginPage(context);
  173. Secverify.finshOauthPage();
  174. // Fluttertoast.showToast(msg: '未知错误 err = ${err?.toString()}');
  175. } else {
  176. String rst = ret.toString();
  177. if (ret == null || ret.isEmpty) {
  178. rst = '登录失败';
  179. // showAlert(rst, context);
  180. Logger.log(rst);
  181. Fluttertoast.showToast(msg: '登录失败');
  182. } else if (ret.containsKey("otherLogin")) {
  183. ///其他登录方式
  184. _openSMSLoginPage(context);
  185. //调用此方法手动关闭授权页面
  186. Secverify.finshOauthPage();
  187. } else if (ret.containsKey("opToken")) {
  188. //如果登录成功,将返回的信息提交给自己的服务器
  189. _doLogin(ret, context);
  190. //调用此方法手动关闭授权页面
  191. Secverify.finshOauthPage();
  192. } else {
  193. //调用此方法手动关闭授权页面
  194. Secverify.finshOauthPage();
  195. }
  196. }
  197. });
  198. }
  199. });
  200. }
  201. // 设置授权页面属性
  202. void _setPortraitLayout(Quick model) {
  203. if (Platform.isAndroid) {
  204. // 以下是 Android 自定义设置
  205. // 导航栏设置
  206. var customNav = {
  207. "navColor": "#FFFFFF", //导航栏背景颜色
  208. // "navText": "一键登录", //导航栏文本内容
  209. "navTextColor": "#ffffff", //导航栏文本颜色
  210. "navHidden": false, //导航栏是否隐藏
  211. "navTransparent": false, //导航栏是否透明
  212. "navCloseImgHidden": false, //导航栏返回图片是否隐藏
  213. "navTextSize": 16, //导航栏文本大小
  214. "navTextBold": false, //导航栏文本是否加粗
  215. "navCloseImgPath": "close.png", //导航栏返回图片地址
  216. "portraitLayout": {
  217. "layoutWidth": 50, //导航栏图片宽度
  218. "layoutHeight": 50, //导航栏图片高度
  219. "layoutLeft": 10, //导航栏图片左间距
  220. // "layoutRight": 30,//导航栏图片右间距
  221. // "layoutTop": 10,//导航栏图片顶部间距
  222. }
  223. };
  224. // 授权页
  225. var customAuthPage = {
  226. // "backgroundImg":"bg.png",//授权页面背景图片地址
  227. "backgroundClickClose": false, //授权页面点击关闭
  228. "fullScreen": false, //是否全屏
  229. "immersiveTheme": true, // 是否沉浸式透明状态栏
  230. "immersiveStatusTextColorBlack": true // 是否修改状态栏意思
  231. };
  232. // 授权页Logo
  233. var customAuthPageLogo = {
  234. "logoImg": "app_icon.png", //logo地址
  235. "logoAlignParentRight": false, //logo是否靠页面右侧
  236. "logoHidden": false, // logo是否隐藏
  237. "portraitLayout": {
  238. "layoutWidth": 80, //logo宽度
  239. "layoutHeight": 80, //logo高度
  240. // "layoutLeft": 30,//logo左间距
  241. // "layoutRight": 30,//logo右间距
  242. "layoutTop": 30, //logo顶部间距
  243. // "layoutBottom": 30,//logo底部间距
  244. }
  245. };
  246. // 手机号码
  247. var customPhoneNumber = {
  248. "numberColor": model?.accountColor ?? "#333333", // 脱敏手机号颜色
  249. "numberSize": 22, //脱敏手机号大小
  250. "numberAlignParentRight": false, //脱敏手机号是否靠页面右侧
  251. "numberHidden": false, //脱敏手机号是否隐藏
  252. "numberBold": true, //脱敏手机号字体是否加粗
  253. "portraitLayout": {
  254. // "layoutLeft": 30,//脱敏手机号左间距
  255. // "layoutRight": 30,//脱敏手机号右间距
  256. // "layoutTop": 130,//脱敏手机号顶部间距
  257. // "layoutBottom": 30,//脱敏手机号底部间距
  258. }
  259. };
  260. // 切换帐号按钮
  261. var customSwitchNumber = {
  262. "switchAccColor": model?.textTipColor ?? '#FF3939', //切换登录文本颜色
  263. "switchAccTextSize": 13, //切换登录文字大小
  264. "switchAccHidden": false, //切换登录是否隐藏
  265. "switchAccAlignParentRight": false, //切换登录是否靠屏幕右侧
  266. "switchAccText": model?.textTip ?? '切换账号', //切换登录文本内容
  267. "switchAccTextBold": false, //切换登录文本是否加粗
  268. "portraitLayout": {
  269. // "layoutLeft": 30,//切换登录左间距
  270. // "layoutRight": 30,//切换登录右间距
  271. // "layoutTop": 170,//切换登录顶部间距
  272. // "layoutBottom": 30,//切换登录底部间距
  273. }
  274. };
  275. // 登陆按钮设置
  276. var customLoginBtn = {
  277. "loginBtnImgArr": [model?.btnSubmitBgColor ?? "#FF0000", model?.btnSubmitBgColor ?? "#FF0000", model?.btnSubmitBgColor ?? "#FF0000"], //登录按钮背景图片或者颜色
  278. "loginBtnText": model?.btnSubmitText ?? "立即登录", //登录按钮文本
  279. "loginBtnTextColor": model?.btnSubmitTextColor ?? "#FFFFFF", //登录按钮文字颜色
  280. "loginBtnTextSize": 15, //登录按钮文本大小
  281. "loginBtnAlignParentRight": false, //登录按钮是否靠屏幕右侧
  282. "loginBtnHidden": false, //登录按钮是否隐藏
  283. "loginBtnTextBold": false, //登录按钮文本是否加粗
  284. "portraitLayout": {
  285. // "layoutWidth": 200,//登录按钮宽度
  286. // "layoutHeight": 30,//登录按钮高度
  287. // "layoutLeft": 30,//登录按钮左间距
  288. // "layoutRight": 30,//登录按钮右间距
  289. // "layoutTop": 200,//登录按钮顶部间距
  290. // "layoutBottom": 30,//登录按钮底部间距
  291. }
  292. };
  293. // 隐私条款设置(切记,不可隐藏)
  294. var customPrivacy = {
  295. "agreementColor": "${model?.protocol[1]?.textColor ?? '#FF3939'}", //运营商隐私条款颜色和自定义隐私条款文本颜色
  296. "agreementBaseTextColor": "${model?.protocol[0]?.textColor ?? '#C0C0C0'}", //隐私条款其他文字颜色
  297. "agreementTextSize": 11, //隐私条款文字大小
  298. "agreementTextStart": "${model?.protocol[0]?.text ?? '同意'} ", //隐私条款开头文本
  299. "agreementTextEnd": " ", //隐私条款结束文本
  300. "agreementAlignParentRight": false, //隐私条款是否靠屏幕右侧
  301. "agreementHidden": false, //隐私条款是否隐藏
  302. 'secPrivacyProtocolMarkArr': ['《', '》'], // 协议文本前后符号(例['<','>'])
  303. "agreementCmccText": "《中国移动服务协议》", //隐私条款 移动运营商显示文本
  304. "agreementCuccText": "《中国联通服务协议》", //隐私条款 联通运营商显示文本
  305. "agreementCtccText": "《中国电信服务协议》", //隐私条款 电信运营商显示文本
  306. "agreementTextBold": false, //隐私条款文本是否加粗
  307. "agreementTextWithUnderLine": false, //隐私条款是否带下划线
  308. "cusAgreementFirstArray": ['${model?.protocol[1]?.text ?? '《用户协议》'}', '${model?.protocol[1]?.url}', ''], //隐私条款 自定义一
  309. "cusAgreementSecondArray": ['${model?.protocol[3]?.text ?? '《隐私政策》'}', '${model?.protocol[3]?.url}', '${model?.protocol[2]?.text ?? '及'}'], //隐私条款 自定义二
  310. "agreementUncheckHintText": "请阅读并勾选隐私协议", //隐私条款 未勾选时提示的文本
  311. "portraitLayout": {
  312. "layoutLeft": 20, //隐私条款左间距
  313. "layoutRight": 20, //隐私条款右间距
  314. // "layoutTop": 250,//隐私条款顶部间距
  315. // "layoutBottom": 20,//隐私条款底部间距
  316. }
  317. };
  318. // 隐私条款复选框
  319. var customCheckBox = {
  320. // "checkboxImg": ["checked.png", "uncheck.png"], // 隐私协议checkbox背景图片
  321. "checkboxDefaultState": true, // 隐私协议checkbox默认状态
  322. "checkboxHidden": false, //隐私协议checkbox是否隐藏
  323. "scale": 1.2,
  324. "portraitLayout": {
  325. // "layoutWidth": 50,//隐私协议checkbox 返回图标宽度
  326. // "layoutHeight": 50,//隐私协议checkbox 返回图标高度
  327. // "layoutLeft": 20,//隐私协议checkbox左间距
  328. // "layoutRight": 20,//隐私协议checkbox右间距
  329. // "layoutTop": 10,//隐私协议checkbox顶部间距
  330. // "layoutBottom": 20,//隐私协议checkbox底部间距
  331. }
  332. };
  333. // 隐私条款具体协议内容页面设置
  334. var customPrivacyContentPage = {
  335. "agreementPageTitle": "隐私协议页", //隐私协议页面 标题
  336. "cusAgreementPageOneTitle": "自定义隐私协议页一", //隐私协议页面 自定义隐私协议一标题
  337. "cusAgreementPageTwoTitle": "自定义隐私协议页二", //隐私协议页面 自定义隐私协议二标题
  338. "cusAgreementPageThreeTitle": "自定义隐私协议页三", //隐私协议页面 自定义隐私协议三标题
  339. "agreementPageCloseImg": "close.png", //隐私协议页面 返回图标名称
  340. "agreementPageTitleTextSize": 16, //隐私协议页面 标题文本大小
  341. "agreementPageTitleTextColor": "#330F33", //隐私协议页面 标题文本颜色
  342. "agreementPageTitleTextBold": true, //隐私协议页面 标题文本是否加粗
  343. "agreementPageTitleHidden": false, //隐私协议页面 标题文本是否隐藏
  344. "agreementPageCloseImgHidden": false, //隐私协议页面 返回图标是否隐藏
  345. "portraitLayout": {
  346. "layoutWidth": 50, //隐私协议页面 返回图标宽度
  347. "layoutHeight": 50, //隐私协议页面 返回图标高度
  348. }
  349. };
  350. // 运营商品牌标签
  351. var customOperatorSlogan = {
  352. "sloganTextSize": 20, // Slogan文本大小
  353. "sloganTextColor": "#330F33", // Slogan文本颜色
  354. "sloganHidden": false, // Slogan是否隐藏
  355. "sloganAlignParentRight": false, // Slogan是否靠屏幕右侧
  356. "sloganTextBold": true, // Slogan文本是否加粗
  357. "portraitLayout": {
  358. // "layoutLeft": 30,//Slogan左间距
  359. // "layoutRight": 30,//Slogan右间距
  360. // "layoutTop": 30,//Slogan顶部间距
  361. "layoutBottom": 30, //Slogan底部间距
  362. }
  363. };
  364. // 弹窗设置
  365. var customDialog = {
  366. "dialogTheme": false, //弹框
  367. "dialogAlignBottom": false, //弹框是否靠底部
  368. // "dialogBackground": "bg.png",//弹框蒙版背景图片名称
  369. "dialogBackgroundClickClose": false, //弹框蒙版背景是否点击关闭
  370. "portraitLayout": {
  371. "layoutWidth": 250, //弹框宽度
  372. "layoutHeight": 400, //弹框高度
  373. "layoutLeft": 30, //弹框左间距
  374. "layoutTop": 30, //弹框顶部间距
  375. }
  376. };
  377. // 自定义控件设置,目前安卓只支持文本TextView和图片ImageView
  378. var customView = {
  379. "customView": [
  380. {
  381. "viewClass": "TextView", //添加的控件类型
  382. "viewText": "测试文本1", // 控件文本
  383. "viewTextColor": "#330F33", // 控件文本颜色
  384. "viewTextFont": 20, // 控件文本大小
  385. "viewTextBold": true, // 控件文本是否加粗
  386. "viewAlignParentRight": false, // 控件是否靠屏幕右侧
  387. "viewHorizontalCenter": true, //控件是否靠屏幕中间
  388. "portraitLayout": {
  389. // "layoutLeft": 30,//控件左间距
  390. // "layoutRight": 30,//控件右间距
  391. // "layoutTop": 30,//控件顶部间距
  392. "layoutBottom": 135, //控件底部间距
  393. }
  394. },
  395. {
  396. "viewClass": "TextView", //添加的控件类型
  397. "viewText": "测试文本2", // 控件文本
  398. "viewTextColor": "#330F33", // 控件文本颜色
  399. "viewTextFont": 16, // 控件文本大小
  400. "viewTextBold": false, // 控件文本是否加粗
  401. "viewAlignParentRight": false, //控件是否靠屏幕右侧
  402. "viewHorizontalCenter": true, //控件是否靠屏幕中间
  403. "portraitLayout": {
  404. // "layoutLeft": 30,//控件左间距
  405. // "layoutRight": 30,//控件右间距
  406. // "layoutTop": 50,//控件顶部间距
  407. "layoutBottom": 115, //控件底部间距
  408. },
  409. },
  410. {
  411. "viewClass": "ImageView", //添加的控件类型
  412. "viewImg": "logo.png", //图片的地址
  413. "viewAlignParentRight": false, //控件是否靠屏幕右侧
  414. "viewHorizontalCenter": true, //控件是否靠屏幕中间
  415. "portraitLayout": {
  416. "layoutWidth": 30, //隐私协议页面 返回图标宽度
  417. "layoutHeight": 30, //隐私协议页面 返回图标高度
  418. // "layoutLeft": 30,//控件左间距
  419. // "layoutRight": 30,//控件右间距
  420. // "layoutTop": 50,//控件顶部间距
  421. "layoutBottom": 75, //控件底部间距
  422. },
  423. }
  424. ]
  425. };
  426. var customParams = {
  427. // 'customNav': customNav,//导航栏设置
  428. 'customAuthPage': customAuthPage, //授权页面设置
  429. // 'customAuthPageLogo': customAuthPageLogo,//logo设置
  430. 'customPhoneNumber': customPhoneNumber, //脱敏手机号设置
  431. 'customSwitchNumber': customSwitchNumber, //切换登录设置
  432. 'customCheckBox': customCheckBox, //复选框设置
  433. 'customPrivacy': customPrivacy, //隐私条款设置
  434. // 'customPrivacyContentPage': customPrivacyContentPage,//隐私协议页面设置
  435. 'customLoginBtn': customLoginBtn, //登录按钮设置
  436. // 'customOperatorSlogan': customOperatorSlogan,//slogan设置
  437. // 'customDialog': customDialog,//弹框设置
  438. // 'customView': customView,//自定义控件设置
  439. };
  440. Secverify.setPortraitLayout(customParams);
  441. // Secverify.setLandscapeLayout(customParams);
  442. } else if (Platform.isIOS) {
  443. // 以下是 iOS 自定义设置
  444. // 自定义动画设置
  445. var customAnimation = {
  446. 'secAnimateType': 1, //动画类型 0:默认 1:水平翻转 2:淡入淡出 3: Alert 4: Push 5:sheet
  447. // 'secShowType': 0, //展示类型 0:默认 1:Alert 2:Push 3: Sheet
  448. // 以下自定义动画设置只针对于Alert/Sheet展示类型
  449. 'secAnimateBgColor': '#F7B376', //弹窗控制器的背景色
  450. 'secLeftControlImage': 'leftImg.png', //左边按钮背景图片名称
  451. 'secLeftControlHidden': true, //左边按钮是否显示
  452. 'secRightControlImage': 'rightImg.png', //右边按钮背景图片名称
  453. 'secRightControlHidden': true, //右边按钮是否显示
  454. 'secBgViewHidden': false, //背景视图是否展示
  455. 'secBgViewCorner': 15, //背景视图的圆角
  456. 'secBgViewColor': '#000000', //背景视图颜色
  457. 'secBgViewImage': 'bgImg.png', //背景视图的背景图片名称
  458. 'secCloseType': true, //关闭按钮显示在左边还是右边 true:左边 false:右边
  459. };
  460. // 导航栏设置
  461. var customNav = {
  462. 'secNavBarTintColor': '#FFFFFF', // 导航栏背景色(default is white)
  463. // 'secNavText': '一键验证', // 导航栏标题
  464. // 'secNavReturnImg': 'close.png', // 导航栏返回按钮图标
  465. // 'secNavBottomLineHidden': true, // 是否隐藏导航栏尾部线条(默认显示,例: true)
  466. // 'secNavBarHidden': false, // 导航栏隐藏(例: false)
  467. // 'secNavStatusBarHidden': false, // 导航栏状态栏隐藏(例: false)
  468. // 'secNavTranslucent': false, // 导航栏透明(例: false)
  469. // 'secNavBackBtnHidden': false, // 导航栏返回按钮隐藏(例: false)
  470. // 'secNavLeftControlHidden': false, // 隐藏导航栏左边按钮
  471. // 'secNavTintColor': '#FF0000', // 导航栏文字颜色
  472. // 'secNavBackgroundClear': false, // 导航栏背景透明(例: false)
  473. };
  474. // 授权页
  475. var customAuthPage = {
  476. // 'secBackgroundColor': '#E5E589', // 授权页背景颜色
  477. 'secBgImg': 'bg.png', // 授权背景图片
  478. 'secCancelBySingleClick': false, //单击页面实现取消操作(例: false)
  479. };
  480. // 授权页Logo
  481. var customAuthPageLogo = {
  482. 'secLogoImg': 'app_icon.png', // Logo图片名称
  483. 'secLogoHidden': false, // Logo是否隐藏(例: false)
  484. // 'secLogoCornerRadius': 10, // Logos圆角(例: 10)
  485. // 'secPortraitLayout': {
  486. // // 针对该控件的竖屏布局(注意: 每个控件的布局字段所表示的含义都相同,下面将不再解释)
  487. // 'secLayoutTop': 100, // 顶部间距
  488. // // 'secLayoutBottom': -40, // 底部间距
  489. // 'secLayoutLeft': 20, // 左边间距
  490. // // 'secLayoutRight': -20, // 右边间距
  491. // 'secLayoutWidth': 80, // 控件宽度
  492. // 'secLayoutHeight': 80, // 控件高度
  493. // 'secLayoutCenterX': 0, // 相对于父视图的CenterX的偏移量,0表示不偏移,即水平居中
  494. // 'secLayoutCenterY': 0, // 相对于父视图的CenterY的偏移量,0表示不偏移,即垂直居中
  495. // },
  496. };
  497. // 手机号码
  498. var customPhoneNumber = {
  499. 'secNumberColor': model?.accountColor ?? '#333333', // 手机号码字体颜色
  500. 'secNumberFont': 25, // 字体大小(例: 18)
  501. 'secNumberTextAlignment': 1, // 手机号对其方式(例: 0-Left, 1-Center, 2-Right)
  502. // 'secNumberBgColor': '#C2F6A3', // 手机号码背景颜色
  503. 'secPhoneHidden': false, //手机号码是否隐藏
  504. // 'secPhoneBorderColor': '#FF0000', //手机号码边框颜色
  505. // 'secPhoneBorderWidth': 2, //手机号码边框宽度
  506. // 'secPhoneCorner': 5, //手机号码圆角
  507. 'secPortraitLayout': {
  508. // 'secLayoutTop': 100 + 10,
  509. // 'secLayoutLeft': 20 + 80 + 15,
  510. // 'secLayoutRight': -20,
  511. // 'secLayoutHeight': 22, // 控件高度
  512. }
  513. };
  514. // 切换帐号按钮
  515. var customSwitchNumber = {
  516. 'secSwitchBgColor': '#FFFFFF', // 切换账号背景颜色
  517. 'secSwitchColor': model?.textTipColor ?? '#FF3939', // 切换账号字体颜色
  518. 'secSwitchFont': 14, // 切换账号字体大小
  519. 'secSwitchTextHorizontalAlignment': 0, // 切换账号对其方式(例: 0-Center, 1-Left, 2-Right)
  520. 'secSwitchHidden': false, // 隐藏切换账号按钮, 默认为false(例: true)
  521. 'secSwitchText': model?.textTip ?? '切换账号', // 切换账号标题
  522. 'secPortraitLayout': {
  523. // 'secLayoutTop': 100 + 80 - 30,
  524. // 'secLayoutLeft': 20 + 80 + 15,
  525. // 'secLayoutRight': -20,
  526. // 'secLayoutHeight': 18, // 控件高度
  527. }
  528. };
  529. // 登陆按钮设置
  530. var customLoginBtn = {
  531. 'secLoginBtnText': model?.btnSubmitText ?? '立即登录', // 登录按钮文本
  532. 'secLoginBtnTextColor': model?.btnSubmitTextColor ?? '#FFFFFF', // 登录按钮文本颜色
  533. 'secLoginBtnBgColor': model?.btnSubmitBgColor ?? '#FF3939', // 登录按钮背景颜色
  534. 'secLoginBtnBorderWidth': 2.0, // 登录按钮边框宽度 (例: 2.0)
  535. 'secLoginBtnBorderColor': '#FF0000', // 登录按钮边框颜色
  536. 'secLoginBtnCornerRadius': 5.5, // 登录按钮圆角(例: 5.0)
  537. 'secLoginBtnTextFont': 15, // 登录按钮文字字体大小
  538. 'secLoginBtnBgImgArr': [
  539. model?.btnSubmitBgColor ?? '#FF3939',
  540. model?.btnSubmitBgColor ?? '#FF3939',
  541. model?.btnSubmitBgColor ?? '#FF3939'
  542. ], //['enabled.png', 'disabled.png', 'highlighted.png'], // 登录按钮背景图片数组(例:['激活状态图片','失效状态图片','高亮状态图片'], 支持颜色数组: ['#FF0000', '#00FF00', '0000FF'])
  543. 'secLoginBtnHidden': false, // 登陆按钮是否隐藏, 不建议隐藏!!!
  544. 'secPortraitLayout': {
  545. // 'secLayoutCenterY': 0,
  546. // 'secLayoutLeft': 20,
  547. // 'secLayoutRight': -20,
  548. // 'secLayoutHeight': 30, // 控件高度
  549. }
  550. };
  551. // 隐私条款设置(切记,不可隐藏)
  552. var customPrivacy = {
  553. 'secPrivacyTextColor': model?.protocol[0]?.textColor ?? '#C0C0C0', // 隐私条款基本文字颜色
  554. 'secPrivacyTextFont': 11, // 隐私条款协议文字字体大小
  555. 'secPrivacyTextAlignment': 0, // 隐私条款对其方式(例: 0-Left, 1-Center, 2-Right)
  556. 'secPrivacyAgreementColor': model?.protocol[1]?.textColor ?? '#FF3939', // 隐私条款协议文字颜色
  557. // 'secPrivacyAgreementBgColor': '#000000', // 隐私条款协议背景颜色
  558. // 'secPrivacyAppName': '秒验Flutter', // 隐私条款应用名称
  559. 'secPrivacyProtocolMarkArr': ['', ''], // 协议文本前后符号(例['<','>'])
  560. 'secPrivacyFirstTextArr': [model?.protocol[1]?.text ?? '用户协议', model?.protocol[1]?.url ?? '', model?.protocol[2]?.text ?? ' '], // 开发者隐私条款第一组协议(例:['名字','url','分割符'])
  561. 'secPrivacySecondTextArr': [model?.protocol[3]?.text ?? '隐私政策', model?.protocol[3]?.url ?? '', '及'], // 开发者隐私条款第二组协议(例:['名字','url','分割符'])
  562. 'secPrivacyLineSpacing': 5.0, // 隐私条款多行时行距(例: 5.0)
  563. // 'secPrivacyDefaultText': '开发者隐私条款', //开发者隐私条款协议默认名称(不建议修改)
  564. 'secPrivacyUnderlineStyle': 0, //隐私协议下划线样式(例: 0-None, 1-Single, 2-Thick, 9-Double)
  565. 'secPrivacyNormalTextFirst': model?.protocol[0]?.text ?? '同意', // 隐私条款开头(例: '登录即同意')
  566. 'secPrivacyNormalTextEnd': ' ', // 隐私条款中间连接文字(例: '并授权')
  567. 'secPrivacyHidden': false, // 隐私条款是否隐藏, 强烈建议不要隐藏!!!
  568. 'isPrivacyOperatorsLast': false, // 运营商协议是否排在最后 默认为false(例: true)
  569. 'secPortraitLayout': {
  570. // 'secLayoutLeft': 50,
  571. // 'secLayoutCenterY': 80,
  572. // 'secLayoutRight': -20,
  573. // 'secLayoutHeight': 70, // 控件高度
  574. }
  575. };
  576. // 隐私条款复选框
  577. var customCheckBox = {
  578. 'secCheckedImg': 'checked.png', // 复选框选中时的图片
  579. 'secUncheckedImg': 'uncheck.png', // 复选框未选中时的图片
  580. 'secCheckDefaultState': false, // 隐私条款check框默认状态,默认为false(例: true)
  581. // secCheckSize: 30, // 复选框尺寸(宽高相同,例: 30)
  582. 'secCheckHidden': false, // 隐私条款check框是否隐藏,默认为false(例: true)
  583. 'secPortraitLayout': {
  584. // !!!! 注意: 这个复选框的布局是相对于隐私条款的,所以建议先把隐私条款布局好再布局这个框
  585. 'secLayoutRight': -10,
  586. 'secLayoutCenterY': -20,
  587. 'secLayoutWidth': 20,
  588. 'secLayoutHeight': 20,
  589. }
  590. };
  591. // 隐私条款具体协议内容页面设置
  592. var customPrivacyContentPage = {
  593. 'secPrivacyWebBackBtnImage': 'close.png', // 隐私条款WEB页面返回按钮图片
  594. 'secPrivacyWebTitle': '隐私条款内容', // 隐私条款WEB页面标题
  595. 'secPrivacyWebNavBarStyle': 0, // 隐私条款导航style (例: 0-Default, 1-Black)
  596. };
  597. // 运营商品牌标签
  598. var customOperatorSlogan = {
  599. 'secSloganTextFont': 13, //运营商品牌文字字体大小
  600. 'secSloganTextColor': '#0099FF', //运营商品牌文字颜色
  601. 'secSloganTextAlignment': 1, //运营商品牌文字对齐方式(例: 0-Left, 1-Center, 2-Right)
  602. 'secSloganBgColor': '#666666', //运营商品牌背景颜色
  603. // 'secSloganText': '运营商品牌文字', //运营商品牌文字(不建议修改)
  604. 'secSloganHidden': false, //运营商品牌是否隐藏
  605. 'secSloganBorderColor': '#FFEEDD', //运营商品牌边框颜色
  606. 'secSloganBorderWidth': 2.0, //运营商品牌边框宽度
  607. 'secSloganCorner': 5.0, //运营商品牌边框圆角
  608. 'secPortraitLayout': {
  609. 'secLayoutLeft': 20,
  610. 'secLayoutRight': -20,
  611. 'secLayoutBottom': -64,
  612. 'secLayoutHeight': 18, // 控件高度
  613. },
  614. };
  615. var customParams = {
  616. // 'customAnimation': customAnimation, // 自定义动画设置
  617. 'customNav': customNav, // 导航栏设置
  618. // 'customAuthPage': customAuthPage, // 授权页
  619. 'customAuthPageLogo': customAuthPageLogo, // 授权页Logo
  620. 'customPhoneNumber': customPhoneNumber, // 手机号码
  621. 'customSwitchNumber': customSwitchNumber, // 切换帐号按钮
  622. // 'customCheckBox': customCheckBox, // 隐私条款复选框
  623. 'customPrivacy': customPrivacy, // 隐私条款设置(切记,不可隐藏)
  624. // 'customPrivacyContentPage': customPrivacyContentPage, // 隐私条款具体协议内容页面设置
  625. 'customLoginBtn': customLoginBtn, // 登陆按钮设置
  626. // 'customOperatorSlogan': customOperatorSlogan, // 运营商品牌标签
  627. };
  628. Secverify.setPortraitLayout(customParams);
  629. // Secverify.setLandscapeLayout(customParams);
  630. }
  631. }
  632. }