utils.js
4 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
/**
* Created by DEV005 on 2017/8/31.
*/
import React, { Component } from 'react';
import { BackHandler,AppState,StyleSheet,View,Text
, NativeModules,AsyncStorage,NavigationActions,
ActivityIndicator,TouchableOpacity,Image,Touch,Platform,Dimensions
} from 'react-native';
import Toast from 'react-native-root-toast';
/**
* 冒一个时间比较短的Toast
* @param content
*/
export const xnToast = (content) => {
if (global.toast !== undefined) {
Toast.hide(toast);
};
global.toast = Toast.show(content.toString(), {
duration: Toast.durations.LONG,
position: Toast.positions.CENTER,
shadow: true,
animation: true,
hideOnPress: true,
delay: 0
});
};
export const formatStringWithHtml = (originString) => {
if (originString === undefined) {
return '';
}
const newString = originString
.replace(/ /g, ' ')
.replace(/"/g, '"')
.replace(/&/g, '&')
.replace(/</g, '<')
.replace(/>/g, '>');
return newString;
};
// 获取主题色
export function getHomeColor(){
if(global.homeColor == undefined){
// #8A0886 紫色测试
global.homeColor = "#3399ff";
return String(global.homeColor);
}else{
return String(global.homeColor);
}
}
// 获取app传入的配置参数,这个方法只需要调用一次
export async function getConfigTheme(){
try {
var result= await NativeModules.system.configTheme();
global.isNew = true;
global.role = (JSON.parse(result).role ||"" ).toString();
global.homeColor = (JSON.parse(result).themeColor ||"#3399ff").toString();
global.weChatBySmallProgramAppId = (JSON.parse(result).WeChatBySmallProgramAppId ||"" ).toString();
if(Platform.OS === 'ios'){
global.showWchatShare = JSON.parse(result).showWchatShare || false;
}else{
global.showWchatShare = JSON.parse(result).showWchatShare || false;
}
// 是否是导航进入
global.navigateMode = JSON.parse(result).navigateMode || false;
if(global.navigateMode === 'true' || global.navigateMode == true){
global.navigateMode = true;
}else{
global.navigateMode = false;
}
// app分支,默认配置为测试环境
global.appTarget = (JSON.parse(result).appTarget ||"xntalkTest" ).toString();
}catch(e){
global.isNew = false;
// #8A0886 紫色测试
global.homeColor = "#3399ff";
global.showWchatShare = false;
global.navigateMode = false;
}finally{
console.log('getConfigTheme 完成!!!');
console.log(global.appTarget);
console.log('-----------------------');
console.log(global);
}
}
export function isIphoneX() {
let dimen = Dimensions.get('window');
return (
Platform.OS === 'ios' &&
!Platform.isPad &&
!Platform.isTVOS &&
(dimen.height >= 812 || dimen.width >= 812)
);
}
export function getHeaderHeight() {
if( Platform.OS === 'android'){
return 48;
}else if(Platform.OS === 'ios') {
if(isIphoneX()){
return 88;
}else {
return 64;
}
}
}
export function xnBorderWidth() {
if(isIphoneX()){
return 1;
}else {
return 0.5;
}
}
export function getHeaderPadding() {
if( Platform.OS === 'android'){
return 0;
}else if(Platform.OS === 'ios') {
if(isIphoneX()){
return 44;
}else {
return 20;
}
}
}
export function getFooterBottom() {
if( Platform.OS === 'android'){
return 0;
}else if(Platform.OS === 'ios') {
if(isIphoneX()){
return 34;
}else {
return 0;
}
}
}
const xnUtils={
xnToast:xnToast,
isIphoneX:isIphoneX,
getHeaderHeight:getHeaderHeight,
getHeaderPadding:getHeaderPadding,
getFooterBottom:getFooterBottom,
xnBorderWidth:xnBorderWidth,
}
export default xnUtils;