基础库
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

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