import {
StyleSheet,
Platform,
Dimensions,
I18nManager,
StatusBar
} from "react-native";
import {getStatusBarHeight} from "react-native-status-bar-height";
import {ifIphoneX} from "react-native-iphone-x-helper";
import {isTabletOrIPad, shadeColor, shadeColorForBackground} from "../utils";
import normalize from "./normalize";
import {fontFamilyMappingFunction, fontWeightMappingFunction} from "../fonts";
import {getExternalCodeSetup} from "../externalCode/externalRepo";
import {configureGlobalStyle} from "../externalCode/configurators";
import {memoize} from "../utils/memoize";
import type {Typography} from "../services/types/branding";
import {Typographies} from "../services/enums/branding";
import FontManager from "../FontManager";
import {BOTTOM_SHEET_HEADER_HEIGHT} from "../components/BottomSheet/BottomSheetHeader";
import {generateAssetsFontCss} from "../utils/jsUtils";
import {useSafeAreaInsets} from "react-native-safe-area-context";
export const LIST_PROGRESS_VIEW_OFFSET_ANDROID = 192;
export const HEADERHEIGHT = Platform.select({ios: 44, android: 56});
export const BARHEIGHT = Platform.OS === "android" ? 0 : getStatusBarHeight();
export const EXPEND_HEIGHT = Platform.select({
android: 40,
ios: 40
});
export const NAV_HEIGHT = HEADERHEIGHT + BARHEIGHT;
export const NAV_HEIGHT_EXPENDED = NAV_HEIGHT + EXPEND_HEIGHT;
export const STATUS_BAR_HEIGHT = Platform.select({
android: StatusBar.currentHeight,
ios: BARHEIGHT
});
const {width, height} = Dimensions.get("window");
export const DEVICE_WIDTH = Platform.isPad
? width > height
? height
: width
: width;
export const DEVICE_HEIGHT = Platform.isPad
? width < height
? height
: width
: height;
export const GUTTER = 17;
export const BOTTOM_SAFE_AREA = ifIphoneX(45, 20);
const minIpadSafeAreaValue = val => (val < 10 ? 10 : val);
export const correctBottomSafeArea = val =>
isTabletOrIPad()
? minIpadSafeAreaValue(val) + 10
: Platform.OS === "android"
? val + 20
: val;
export const TOP_SAFE_AREA = ifIphoneX(44, 0);
export const topSafeAreaWithDynamicIsland = () => {
const insets = useSafeAreaInsets();
return insets.top === 59 ? insets.top : TOP_SAFE_AREA;
};
export const isHaveDynamicIsland = () => {
const insets = useSafeAreaInsets();
return insets.top === 59;
};
export const LIST_FILTER_HEIGHT = 61;
export const SEGMENT_FILTER_HEIGHT = 53;
export const BB_SIGNATURE_FONT_FAMILY = {
medium: "RobotoMedium"
};
export const ACTIVITY_ITEM_IPAD_TABLET_MAX_WIDTH = DEVICE_WIDTH / 1.4;
// const colors
export const WHITE_COLOR = "#FFFFFF";
export const PALE_WHITE_COLOR = "#EDEEF2";
export const BLACK_COLOR = "#000000";
export const DARK_BLUE_COLOR = "#122b46";
export const GREY_COLOR = "rgba(0,0,0,0.33)";
export const LIGHT_WHITE_COLOR = "rgba(255,255,255,0.33)";
export const MEDIUM_WHITE_COLOR = "rgba(255,255,255,0.7)";
export const DARK_GREY_COLOR = "rgba(0,0,0,0.55)";
export const LIGHT_GREY_COLOR = "rgba(70,89,135,0.10)";
export const SUCCESS_COLOR = "#10D639";
export const WARNING_COLOR = "#FF3B30";
export const ERROR_TEXT_COLOR = "#A84B46";
export const XPROFILE_TEXT_COLOR = "#080808";
export const XPROFILE_META_TEXT_COLOR = "#787E8B";
export const FILTER_BG = "rgba(98, 100, 151, 0.11)";
export const LIST_HEADER_BG = "#F9F9F9";
export const TAG_BACKGROUND = "#F7F8F9";
export const BORDER_COLOR_ALT = "#c6c6c8";
export const INPUT_BORDER_COLOR_ALT = "#95A0AC";
export const OPTIONS_INACTIVE_COLOR = "#C3C5CA";
export const HEADER_BORDER_COLOR = "rgba(87, 87, 91,0.4)";
export const DEFAULT_BLOCK_BUTTON_BACKGROUND_COLOR = "#32383B";
export const SHADOW_TEXT = "rgba(0, 0, 0, 0.4)";
export const SHADOW = "rgba(0, 0, 0, 0.05)";
export const BB_DARK_COLOR = "#333659";
export const BB_SIGNATURE_ORANGE_COLOR = "#df613c";
// for quiz question learndash indicator colors
const indicatorColors = {
currentLabel: "#235af3",
reviewLabel: "#ED9615",
answeredLabel: "#a1b6c9",
correctLabel: "#00c349",
incorrectLabel: "#f11414"
};
const localColors = {
shadow: SHADOW,
shadowText: SHADOW_TEXT,
xProfileTextColor: XPROFILE_TEXT_COLOR,
xProfileMetaTextColor: XPROFILE_META_TEXT_COLOR,
filterBg: FILTER_BG,
whiteColor: WHITE_COLOR,
paleWhiteColor: PALE_WHITE_COLOR,
blackColor: BLACK_COLOR,
darkBlueColor: DARK_BLUE_COLOR,
greyColor: GREY_COLOR,
lightWhite: LIGHT_WHITE_COLOR,
mediumWhite: MEDIUM_WHITE_COLOR,
darkGreyColor: DARK_GREY_COLOR,
lightGreyColor: LIGHT_GREY_COLOR,
successColor: SUCCESS_COLOR,
errorTextColor: ERROR_TEXT_COLOR,
warningColor: WARNING_COLOR,
tagBackground: TAG_BACKGROUND,
borderColorAlt: BORDER_COLOR_ALT,
inputBorderColorAlt: INPUT_BORDER_COLOR_ALT,
optionsInactiveColor: OPTIONS_INACTIVE_COLOR,
defaultBlockButtonBackgroundColor: DEFAULT_BLOCK_BUTTON_BACKGROUND_COLOR,
bbDarkColor: BB_DARK_COLOR,
bbSignatureOrangeColor: BB_SIGNATURE_ORANGE_COLOR
};
interface LinearGradientReturnType {
angle: number;
colors: string[];
locations: number[];
}
/**
*
* @param {string} gradientString linear-gradient({angle}deg,{rgba color1} {loc1}%,{rgb color2} {loc2}%, ....)
* @return {LinearGradientReturnType} {angle: string, colors: Array, locations: Array}
*/
export const retrieveLinearGradientPropsFromString = gradientString => {
const angle =
gradientString.match(/[0-9]+deg/gi)?.[0].replace("deg", "") || "0";
const colors =
gradientString.match(/rgb(a)?\((([0-9]+(\.[0-9]+)?),?){4}\)\s[0-9]+\%/gi) ||
[];
const locations = (gradientString.match(/[0-9]+%/gi) || []).map(
loc => Number(loc.replace("%", "")) / 100
);
return {angle: Number(angle), colors, locations};
};
/**
*
* @param {string} gradientString radial-gradient({{rgb color1} {loc1}%,{rgb color2} {loc2}%, ....)
* @return {Object} {colors: Array, stops: Array}
*/
export const retrieveRadialGradientPropsFromString = gradientString => {
const colors =
gradientString.match(/rgb(a)?\((([0-9]+(\.[0-9]+)?),?){4}\)\s[0-9]+\%/gi) ||
[];
const stops = (gradientString.match(/[0-9]+%/gi) || []).map(
loc => Number(loc.replace("%", "")) / 100
);
return {colors, stops};
};
export const textRTLStyleFix = (moreStyle = {}, defaultStyle = {}) =>
I18nManager.isRTL ? {writingDirection: "rtl", ...moreStyle} : defaultStyle;
export const viewRTLStyleFix = (moreStyle = {}, defaultStyle = {}) =>
I18nManager.isRTL ? {transform: [{scaleX: -1}], ...moreStyle} : defaultStyle;
export const gradientViewRTLFix = ({start, end}) =>
I18nManager.isRTL ? {start: end, end: start} : {start, end};
type Weights =
| "normal"
| "bold"
| "100"
| "200"
| "300"
| "400"
| "500"
| "600"
| "700"
| "800"
| "900";
type FontWeightsType = {
thin: Weights,
ultraLight: Weights,
light: Weights,
regular: Weights,
medium: Weights,
semiBold: Weights,
bold: Weights,
heavy: Weights,
black: Weights
};
export let FontWeights: FontWeightsType = {
thin: "100",
ultraLight: "200",
light: "300",
regular: "400",
medium: "500",
semiBold: "600",
bold: "700",
heavy: "800",
black: "900"
};
if (Platform.OS === "android") {
FontWeights = Object.entries(FontWeights).reduce((acc, [key, val]) => {
if (["thin", "ultraLight", "light", "regular"].includes(key)) {
acc[key] = "400";
} else if (key === "medium") {
acc[key] = "500";
} else if (key === "semiBold") {
acc[key] = "600";
} else {
acc[key] = "700";
}
return acc;
}, {});
}
const buildGlobalStyles = (
styles,
fontFamilyMapping = fontFamilyMappingFunction,
fontWeightMapping = fontWeightMappingFunction
) => {
const externalCodeSetup = getExternalCodeSetup();
const externalInputColors = externalCodeSetup.cssApi.inputColors
? externalCodeSetup.cssApi.inputColors
: {};
const inputColors = baseColor => {
return {
inputPlaceholderColor:
externalInputColors.inputPlaceholderColor ||
shadeColor(baseColor, 0.28),
inputBorderColor:
externalInputColors.inputBorderColor || shadeColor(baseColor, 0.12),
inputFocusBorderColor:
externalInputColors.inputFocusBorderColor || baseColor,
inputIconColor:
externalInputColors.inputIconColor || shadeColor(baseColor, 0.28)
};
};
const {
primaryColor,
bodyBg,
bodyFrontBg,
headerBg,
headerColor,
headerIconColor,
textColor,
descTextColor,
descLightTextColor,
headingsColor,
primaryButtonBg,
primaryButtonColor,
secondaryButtonBg,
secondaryButtonColor,
borderColor,
contentLoaderColor,
drawerBg,
drawerColor,
drawerActiveColor,
bottomTabsBg,
bottomTabsColor,
bottomTabsActiveColor,
authBgColor,
regBgColor,
authButtonBgColor,
regButtonBgColor,
authButtonTextColor,
regButtonTextColor,
notifColor,
iapBenefitsCheckmark
} = styles.colors;
const {
filterBg,
greyColor,
lightGreyColor,
whiteColor,
blackColor,
darkBlueColor,
successColor,
warningColor,
errorTextColor,
tagBackground,
borderColorAlt,
inputBorderColorAlt,
optionsInactiveColor
} = localColors;
// derived colors
const searchColor = shadeColor("#000000", 0.9);
const searchPlaceholderColor = shadeColorForBackground(
"#000000",
headerBg,
0.6
);
const searchBgColor = shadeColorForBackground("#000000", headerBg, 0.1);
const lightSearchColor = shadeColor("#FFFFFF", 0.95);
const searchPlaceholderLightColor = shadeColorForBackground(
"#FFFFFF",
headerBg,
0.8
);
const lightSearchBg = shadeColorForBackground("#FFFFFF", headerBg, 0.2);
const authBg = authBgColor;
const regBg = regBgColor;
const linkColor = primaryColor;
const lightTextColor = descLightTextColor;
const iconsColor = greyColor;
const linkArrowColor = shadeColor(linkColor, 0.45);
const textIconColor = shadeColor(textColor, 0.5);
const iapBenefitsCheckmarkBg = shadeColor(iapBenefitsCheckmark, 0.2);
const coursesBg = bodyBg;
const highlightColor = primaryColor;
const filterBottomSheetBg = bodyBg;
const placeholderColor = shadeColor(textColor, 0.5);
const derivedColors = {
searchColor,
searchPlaceholderColor,
searchBgColor,
lightSearchColor,
searchPlaceholderLightColor,
lightSearchBg,
authBg,
regBg,
linkColor,
lightTextColor,
linkArrowColor,
iconsColor,
coursesBg,
highlightColor,
filterBottomSheetBg,
textIconColor,
placeholderColor,
iapBenefitsCheckmarkBg
};
const authInputColors = inputColors(textColor);
const customColors = externalCodeSetup.cssApi.customColors;
const typography: Typography = styles.typography;
/**
*
* @param {[type]} pixels the custom size
* @param {String} key one of
* "bodyText" | "appHeaderTitle" | "appHeadings" | "appTabBar" | "appMenus"
*/
const calcFontSize = (pixels, key = Typographies.bodyText) =>
(pixels * typography[key].scale) / 100;
const _setFont = ({
size,
family,
weight = FontWeights.regular,
color,
typography = Typographies.bodyText,
headingTag
}) => {
let fontStyle = {
fontFamily: fontFamilyMapping(family),
fontWeight: weight
};
if (family !== "Default") {
fontStyle = FontManager.createFontStyles(family, {
weight: Number(weight)
});
const fontWeightKey = Object.keys(FontWeights).filter(weight =>
fontStyle.fontFamily?.match(new RegExp(weight, "i"))
)[0];
if (fontWeightKey) fontStyle["fontWeight"] = FontWeights[fontWeightKey];
}
return Object.assign(
{},
fontStyle,
{
fontSize: headingTag
? calcHeadingFontSize(headingTag, size)
: calcFontSize(size, typography)
},
color && {color},
textRTLStyleFix()
);
};
const setFont = memoize(_setFont, {
normalizer: args => JSON.stringify(args[0])
});
const BASE_HEADING_SIZE = 26;
const calcHeadingFontSize = (headingTag, size = BASE_HEADING_SIZE) => {
const baseFontSize = calcFontSize(size, Typographies.appHeadings);
let scale = 1;
switch (headingTag) {
case "h1":
scale = 2.0;
break;
case "h2":
scale = 1.6;
break;
case "h3":
scale = 1.2;
break;
case "h4":
scale = 1.0;
break;
case "h5":
scale = 0.8;
break;
case "h6":
scale = 0.6;
break;
default:
scale = 1;
}
return Math.floor(baseFontSize * scale);
};
const {
bodyText,
appHeaderTitle: listHeaderTitle,
appHeadings,
appTabBar,
appMenus
} = typography;
const setHeadingFont = args =>
setFont({
...appHeadings,
...args,
weight: args.weight || FontWeights.regular,
typography: Typographies.appHeadings
});
const setListHeaderFont = args =>
setFont({
...listHeaderTitle,
...args,
weight: args.weight || FontWeights.bold,
typography: Typographies.appHeaderTitle
});
const setAppMenusFont = args =>
setFont({
...appMenus,
...args,
weight: args.weight || FontWeights.semiBold,
typography: Typographies.appMenus
});
const globalStylesDefault = {
// Small font style. Used On: Product Price Duration screen and Search screen
smallText: setFont({
size: 12,
color: headingsColor,
weight: FontWeights.regular,
family: bodyText.family
}),
// To show outer area of filter segment for Photos and Album. Used On: Album Screen & Photos screen
photosSegmentFilterWrapper: {
backgroundColor: headerBg,
flexDirection: "row",
justifyContent: "center",
height: FontManager.applyFontHeightAdjustment(
SEGMENT_FILTER_HEIGHT,
Typographies.bodyText
),
borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: borderColor
},
// To show inner area of filter segment for Photos and Album. Used On: Album Screen & Photos screen
photosSegmentFilterInner: {
width: DEVICE_WIDTH - GUTTER * 2,
marginTop: 10,
marginBottom: 20
},
// not used
groupInviteMessageText: setFont({
size: 14,
color: textColor,
weight: FontWeights.regular,
family: bodyText.family
}),
developmentSessionTitle: setHeadingFont({
size: 16,
weight: FontWeights.bold,
color: headingsColor
}),
// Styles to show revoking button of email invites. Used On: Email Invites screen
emailInvitesRevokeButtonText: setHeadingFont({
size: 14,
weight: FontWeights.semiBold,
color: warningColor
}),
// Header font styling of email invite. Used On: Email Invites screen
emailInvitesHeader: setHeadingFont({
size: 20,
weight: FontWeights.bold,
color: headingsColor
}),
// Settings screen list inactive radio button. Used On: Setting Screen
radio: {
height: 25,
width: 25,
borderRadius: 25 / 2,
borderWidth: 1.5,
borderColor: optionsInactiveColor
},
// Setting screen list active radio button. Used On: Setting Screen
activeRadio: {
height: 25,
width: 25,
borderRadius: 25 / 2,
borderWidth: 8,
borderColor: highlightColor
},
// Header font styling for privacy setting screen. Used On: Privacy Setting Screen
privacySettingsHeader: setHeadingFont({
size: 22,
weight: FontWeights.bold,
color: headingsColor
}),
// Text font styling for privacy setting screen. Used On: Privacy Setting Screen
privacySettingsItemText: setFont({
size: 17,
color: textColor,
weight: FontWeights.semiBold,
family: bodyText.family
}),
// Header font styling for privacy setting screen. Used On: Privacy Setting Screen
privacySettingsHeader: setHeadingFont({
size: 22,
weight: FontWeights.bold,
color: headingsColor
}),
// Text font styling for access denied text. Used On: Access Denied Cover
accessDeniedHeader: setHeadingFont({
size: 22,
weight: FontWeights.bold,
color: headingsColor
}),
// Text font styling for access denied header. Used On: Access Denied Cover
accessDeniedText: setFont({
size: 17,
color: textColor,
family: bodyText.family
}),
// Navigation header right icon styles. Used On: Email Invite Message Screen,Group Message Create Postscreen, Email Prefrence Screen,Group Invite Setting Screen,Login Info Screen,Privacy Setting Screen,Cover Photo screen, Photo screen,Setting Screen,Email Invites send Screen,profile Screen
headerRightButton: {
flexDirection: "row",
alignItems: "center",
justifyContent: "center",
paddingHorizontal: 14,
borderRadius: 14,
backgroundColor: headerIconColor,
minWidth: 63,
height: 28
},
// Navigation header right text button font styles. Used On: Email Invite Message Screen,Group Message Create Postscreen, Email Prefrence Screen,Group Invite Setting Screen,Login Info Screen,Privacy Setting Screen,Cover Photo screen, Photo screen,Setting Screen,Email Invites send Screen,profile Screen
headerRightButtonText: setFont({
size: 15,
color: headerBg,
weight: FontWeights.bold,
family: bodyText.family
}),
//Text font styling used for descriptional text. Used On: Email Invite Message Screen, Photo Description screen, Setting About Screen
helperText: setFont({
size: 13,
color: descLightTextColor,
weight: FontWeights.regular,
family: bodyText.family
}),
// Radio font styling on Report Screen. Used On: Report Form Screen
reportRadios: setFont({
size: 15,
color: headingsColor,
weight: FontWeights.bold,
family: bodyText.family
}),
// Text style. Used On: report form screen header title
reportHeaderTitle: {
...setFont({
...bodyText,
size: 20,
color: headingsColor,
weight: FontWeights.semiBold
}),
width: 200,
textAlign: "center"
},
schedulePostHeaderTitle: {
...setFont({
...bodyText,
size: 20,
color: headingsColor,
weight: FontWeights.semiBold
}),
width: 200
},
// Modal handler style. Used On: Options Modal and Schedule Post Modal
modalHandleStyle: {
alignSelf: "center",
top: -15,
width: 45,
height: 5,
borderRadius: 5,
backgroundColor: "rgba(255, 255, 255, 0.8)"
},
// not used
signUpTitle: {
marginBottom: 60,
...setFont({
size: 28,
color: textColor,
weight: FontWeights.semiBold,
family: bodyText.family
})
},
// Confirm text styling. Used On: Edit profile screen
nativeConfirmText: {
...setFont({
size: 17,
color: highlightColor,
weight: FontWeights.regular,
family: bodyText.family
}),
paddingTop: 1,
paddingRight: 2
},
// Cancel text styling. Used On: AppMultiSelectModal
nativeCancelText: {
...setFont({
size: 17,
color: greyColor,
weight: FontWeights.regular,
family: bodyText.family
}),
paddingTop: 1,
paddingRight: 2
},
// Search bar text input style. Used On: Search
searchBarText: {
...setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.regular
}),
flex: 1,
paddingTop: 0,
paddingBottom: 0
},
// Form input label styling. Used On: Signup screen, Advanced search screen
formLabel: setHeadingFont({
size: 20,
weight: FontWeights.bold,
color: headingsColor
}),
// Form sub-label (secondary label) font styling. Used On: Signup screen, Advanced search screen
formSubLabel: setFont({
size: 15,
color: headingsColor,
weight: FontWeights.bold,
family: bodyText.family
}),
// Form input field style. Used On: Privacy setting screen, login info screen, Signup screen, Advanced search screen
formItemContainer: {paddingBottom: 32},
// Form input field style. Used On: Quiz screen, survey screen, Edit profile Screen, Subscription Screen, Signup screen, Advanced search screen, Email Invite Screen, Document Screen, Code Verifcation Screen,Forgot Screen, Login Screen,Activity Screen
formInput: {
paddingHorizontal: 16,
minHeight: 50,
borderRadius: 10,
borderColor: inputBorderColorAlt,
backgroundColor: bodyBg
},
// input for global activity screen
shareThoughtsContainer: {
flexDirection: "row",
alignItems: "center",
paddingHorizontal: 16,
borderColor: borderColor,
backgroundColor: bodyFrontBg,
borderBottomWidth: 3,
borderColor: contentLoaderColor
},
// Form input field text style. Used On: Quiz screen, survey screen, Edit profile Screen, Subscription Screen, Signup screen, Advanced search screen, Email Invite Screen, Document Screen, Code Verifcation Screen,Forgot Screen, Login Screen,Activity Screen
formInputText: setFont({
size: 16,
color: textColor,
weight: Platform.select({
ios: FontWeights.medium,
android: FontWeights.regular
}),
family: bodyText.family
}),
// Textarea style. Used On: Email Invite Screen, Signup screen, Advanced search screen, Document Screen, Edit Profile screen
formTextArea: {minHeight: 150, paddingTop: 12},
// Form dropdown style. Used On: Signup screen, Advanced search screen, Setting screen
formDropdown: {
borderRadius: 10,
minHeight: 48,
paddingHorizontal: 16,
backgroundColor: bodyBg,
borderBottomWidth: 0
},
// Form checkbox outer style. Used On: Signup screen, Advanced search screen
formCheckboxOuter: {paddingLeft: 16},
// Form checkbox inner style. Used On: Signup screen, Advanced search screen
formCheckboxInner: {
borderTopColor: borderColorAlt,
paddingRight: 16,
minHeight: 48
},
// style used for sign up fields checkbox, single checkbox and container component. Used On: Signup screen, Advanced search screen
selectContainer: {backgroundColor: bodyBg, borderRadius: 10},
// not used
selectItemOuter: {paddingLeft: 16},
// style for signup fields like container. Used On: Signup screen, Advanced search screen
selectItemInner: {
borderTopColor: borderColorAlt,
paddingRight: 16,
minHeight: 48
},
// Form picker style. Used On: Signup screen, Advanced search screen
nativeAccessoryText: {color: highlightColor},
// Edit profile's add another button text style. Used On: Edit profile Screen
repeaterButtonText: setFont({
size: 15,
family: bodyText.family,
weight: FontWeights.bold,
color: highlightColor
}),
// View As restore modal header title styles. Used On: Profile Screen
viewAsRestoreHeaderTitle: setFont({
size: 15,
family: bodyText.family,
weight: FontWeights.regular
}),
// View As restore modal header user font styles. Used On: Profile Screen
viewAsRestoreHeaderUser: setFont({
size: 15,
family: bodyText.family,
weight: FontWeights.semiBold
}),
// View As screen title font style. Used On: Profile Screen, Course Screen
viewAsRestoreTitle: setFont({
size: 15,
family: bodyText.family,
weight: FontWeights.regular
}),
// View As screen user name font style. Used On: Profile Screen, Course Screen
viewAsRestoreUser: setFont({
size: 15,
family: bodyText.family,
weight: FontWeights.semiBold
}),
// Points Screen user points title font style. Used On: Points Screen
pointsTitle: setFont({
color: headingsColor,
family: bodyText.family,
weight: FontWeights.bold,
size: 22
}),
// Points Screen awarded points sub title font style. Used On: Points Screen
pointsSubTitle: setFont({
color: descLightTextColor,
family: bodyText.family,
weight: FontWeights.regular,
size: 17
}),
// Achievement Title font style. Used On: Achievement screen, BlockedUser screen
achievementTitle: setFont({
...bodyText,
color: headingsColor,
weight: FontWeights.semiBold,
size: 17
}),
// Achievement SubTitle style. Used On: Achievement screen, BlockedUser screen
achievementSubtitle: setFont({
...bodyText,
color: descLightTextColor,
weight: FontWeights.regular,
size: 13
}),
// Acheivement screen content font style. Used On: Achievement screen
achievementContent: setFont({
...bodyText,
color: textColor,
weight: FontWeights.regular,
size: 15
}),
// Achievement screen required step header font style. Used On: Achievement screen
achievementSheetInnerContent: setFont({
...bodyText,
color: descLightTextColor,
weight: FontWeights.semiBold,
size: 13
}),
// Ranks Screen title style. Used On: Ranks screen
rankTitle: setFont({
size: 19,
weight: FontWeights.semiBold,
family: bodyText.family,
color: textColor
}),
// not used
rankDesc: setFont({
size: 13,
weight: FontWeights.medium,
family: bodyText.family,
color: descLightTextColor
}),
// Profile Cover photo text heading style. Used On: Cover
profileCoverEditTitle: setFont({
size: 19,
weight: FontWeights.semiBold,
family: bodyText.family,
color: textColor
}),
// Profile Cover photo text descriptional style. Used On: Cover screen
profileCoverEditDesc: setFont({
size: 15,
weight: FontWeights.regular,
family: bodyText.family,
color: descLightTextColor
}),
// Profile Display user name style. Used On: App Lock Screen, Profile screen
xProfileNicename: setFont({
size: calcFontSize(14),
weight: FontWeights.regular,
family: bodyText.family,
color: headingsColor
}),
// Profile member joined date style. Used On: Profile screen
xProfileJoined: setFont({
size: 14,
weight: FontWeights.regular,
family: bodyText.family,
color: descLightTextColor
}),
// Profile user name style. Used On: App Lock Screen, Profile screen
xProfileTitle: setFont({
...bodyText,
color: headingsColor,
weight: FontWeights.bold,
size: 22
}),
// Profile followers count style. Used On: Profile screen
xProfileCount: setFont({
...bodyText,
color: headingsColor,
weight: FontWeights.semiBold,
size: 17
}),
// Profile follower title based upon count style. Used On: Profile screen
xProfileCountTitle: setFont({
...bodyText,
color: descLightTextColor,
weight: FontWeights.regular,
size: 13
}),
// Profile group name style. Used On: Profile screen
xProfileSectionText: setFont({
color: headingsColor,
size: 22,
weight: FontWeights.bold,
family: bodyText.family
}),
// profile list field item title style. Used On: Profile screen
xProfileItemTitle: setFont({
color: headingsColor,
size: 13,
family: bodyText.family,
weight: FontWeights.semiBold
}),
// Profile list item fields value style. Used On: Profile screen
xProfileItemValue: {
flexShrink: 1,
...setFont({
color: textColor,
size: 20,
family: bodyText.family,
weight: FontWeights.medium
})
},
// Profile list URL link fields style. Used On: Profile screen
xProfileItemLink: {
flexShrink: 1,
...setFont({
color: linkColor,
size: 20,
family: bodyText.family,
weight: FontWeights.medium
})
},
// Profile list textarea fields style. Used On: Profile screen
xProfileItemTextArea: {
...setFont({
color: textColor,
size: 20,
family: bodyText.family,
weight: FontWeights.medium
}),
flexShrink: 1
},
// Quiz text input style. Used On: Question screen
quizTextInput: setFont({
size: 16,
weight: FontWeights.regular,
family: bodyText.family,
color: textColor
}),
// Style for rendering quiz question. Used On: Question Screen, Quiz Single Screen
quizQuestionText: setFont({
size: 16,
weight: FontWeights.regular,
color: textColor,
family: bodyText.family
}),
// Course title style. Used On: Course screen, Lesson Single Screen
courseHeaderTitle: setFont({
size: 27,
color: headingsColor,
weight: FontWeights.bold,
family: bodyText.family
}),
// Course subtitle Style. Used On: Learn Topic Single Screen, Lesson Single Screen, Quiz Single Screen
courseHeaderSubTitle: setFont({
size: 13,
color: descLightTextColor,
weight: FontWeights.medium,
family: bodyText.family
}),
// General text tyle used in various ways like to show privacy text, group name. Used On: Activity Screen, Document Screen, Group Screen, Add Topic Screen
activityPostInText: setFont({
size: 14,
color: headingsColor,
weight: FontWeights.medium,
family: bodyText.family
}),
// Parent group subtitle style. Used On: App header through out app
parentGroupSubTitle: setFont({
size: 13,
color: descTextColor,
family: bodyText.family,
weight: FontWeights.regular
}),
// Parent group title style. Used On: App header through out app
parentGroupTitle: setFont({
size: 15,
color: headingsColor,
family: bodyText.family,
weight: FontWeights.semiBold
}),
// General Screen title text style. Used On: Forum Single Screen, Blog Screen, Login Screen, Forget Screen, Code Verification Screen
textHeaderTitle: setFont({
size: 28,
color: headingsColor,
family: appHeadings.family,
weight: FontWeights.semiBold
}),
//Screen title for Code verification screen
textHeaderTitleCodeVerification: {
size: 28
},
//Screen title for Forgot password screen
textHeaderTitleForgotPassword: {},
//Confirmation message in code verification screen
codeVerificationConfirmation: {},
// Header title style for display userType, userNickname. Used On: Profile Screen & Group Screen
textHeaderMeta: setFont({
size: 16,
color: descTextColor,
family: bodyText.family,
weight: FontWeights.regular
}),
// Group screen short description text style. Used On: Group Screen
textHeaderShortContent: setFont({
size: 16,
color: headingsColor,
family: bodyText.family,
weight: FontWeights.medium
}),
// Group header action button text style. Used On: Group Screen
textHeaderActionButton: setFont({
size: 12,
color: linkColor,
family: bodyText.family,
weight: FontWeights.semiBold
}),
// Widget title font style. Used On Home screen
textSingleScreenTab: setFont({
size: 17,
color: textColor,
family: bodyText.family,
weight: FontWeights.semiBold
}),
// not used
textGroupBreadCrumb: setFont({
size: 14,
weight: FontWeights.medium,
family: bodyText.family,
color: descTextColor
}),
// Comment text font style. Used On: Blog Screen
textItemSubtitle: setFont({
size: 14,
weight: FontWeights.regular,
family: bodyText.family,
color: descTextColor
}),
// not used
viewAsSwitchButton: {backgroundColor: secondaryButtonBg},
// Not used yet
viewAsSwitchButtonLabel: {
color: secondaryButtonColor,
fontWeight: FontWeights.semiBold
},
// List load more view style. Used On: Album Screen, Photo Screen
loadMoreButton: {
padding: 15,
justifyContent: "center",
flexDirection: "row",
alignItems: "center",
backgroundColor: primaryButtonBg,
borderRadius: 20,
marginHorizontal: GUTTER,
marginTop: 20
},
// List load more text style. Used On: Album Screen, Photo Screen
loadMoreButtonText: {
...setFont({
...bodyText,
size: Platform.select({android: 16, ios: 17}),
weight: FontWeights.medium,
color: primaryButtonColor
}),
backgroundColor: "transparent"
},
// Shadow for the group header avatar. Used On: Group screen
shadow: {
shadowOffset: {width: 0, height: 0},
shadowRadius: 3,
shadowColor: blackColor,
shadowOpacity: 0.15,
elevation: 1,
zIndex: 1
},
// Shadow to provide below in group header avatar. Used On: Group screen
shadowBelow: {
shadowOffset: {width: 0, height: 2},
shadowRadius: 1,
shadowColor: blackColor,
shadowOpacity: 0.12,
elevation: 1,
zIndex: 1
},
// Screen view container style. Used On menu screen and profile Screens
container: {
flex: 1,
backgroundColor: bodyFrontBg
},
// Title style for button and screen item title . Used On Group screen, Course screen, Blog screen
title: setFont({
...bodyText,
size: 18,
color: textColor
}),
// Title style. Used On: Document Screen & Photo Screen
heading: setFont({
...appHeadings,
size: 16,
color: headingsColor,
weight: FontWeights.medium,
typography: Typographies.appHeadings
}),
// Group screen action button style. Used On: Group screen and Delete group screen
boldText: setFont({
...bodyText,
size: 16,
weight: FontWeights.bold,
color: textColor
}),
// General text style used in various screen. File name style in document screen. Used On: Document Screen
semiboldText: setFont({
...bodyText,
size: 16,
weight: FontWeights.semiBold,
color: textColor
}),
// General text style used in various screen. Used On: Many major and minor module such as quiz screen, album create screen, activity screen & Blog screen.
text: setFont({
...bodyText,
size: 16,
weight: FontWeights.regular,
color: textColor
}),
// Descriptional text style for cover photo and setting form screen. Used On: Profile Cover screen & Setting Screen
desc: setFont({
...bodyText,
size: 16,
weight: FontWeights.regular,
color: descTextColor
}),
// Various screen text style used for radio text, label text, title text etc. Used On: Question screen, List screen, Quiz screen, Report Screen, Forum Screen.
textAlt: setFont({
...bodyText,
size: 14,
weight: FontWeights.regular,
color: textColor
}),
// Various screen text style used for radio text, label text, title text etc. Used On: Question screen, List screen, Quiz screen, Report Screen, Forum Screen.
textAltMedium: setFont({
...bodyText,
size: 14,
weight: FontWeights.medium,
color: textColor
}),
// Blog Screen button text style. Used On: Blog Screen
textAltSemi: setFont({
...bodyText,
size: 14,
weight: FontWeights.semiBold,
color: textColor
}),
// Blog screen text style. Used On: Blog screen
textMeta: setFont({
...bodyText,
size: 13,
weight: FontWeights.regular,
color: descLightTextColor
}),
// messages thread date header, Link handling setting header
textMetaSemiBold: setFont({
...bodyText,
size: 14,
weight: FontWeights.semiBold,
color: descLightTextColor
}),
// not used
xProfileSubtitle: setFont({
...bodyText,
size: 13,
weight: FontWeights.regular,
color: headingsColor
}),
// Various screen text style. Used On: Quiz Result screen, Product screen, Question screen, Notification list item
regularText: {
...setFont({
...bodyText,
size: 15,
weight: FontWeights.regular,
color: textColor
}),
backgroundColor: "transparent"
},
// Html Page text style. Used On: Forum screen, Paragraph Screen, Question Essay Screen, Forums topic screen
textHtml: setFont({
...bodyText,
size: 15,
weight: FontWeights.regular,
color: textColor
}),
// Notification content text style. Used On: Notification screen
notificationHtml: setFont({
...bodyText,
size: 15,
weight: FontWeights.medium,
color: textColor
}),
// Activity header Html Style. Used On: Activity screen
activityHtml: setFont({
...bodyText,
size: 15,
weight: FontWeights.regular,
color: textColor
}),
activityHtmlrawtext: setFont({
...bodyText,
size: 15,
weight: FontWeights.regular,
color: textColor
}),
activityHtmlp: setFont({
...bodyText,
size: 15,
weight: FontWeights.regular,
color: textColor
}),
activityHtmla: setFont({
...bodyText,
size: 15,
weight: FontWeights.semiBold,
color: textColor
}),
// not used
countText: setFont({
...bodyText,
size: 34,
weight: FontWeights.regular,
color: textColor
}),
// Small text style. Used On: Various screens like Menu Screen, Forgot password screen & Auth screen
textSmall: {
...setFont({
...bodyText,
size: 14,
weight: FontWeights.regular,
color: shadeColor(textColor, 0.64)
}),
backgroundColor: "transparent"
},
// Button color style. Used On: Export Data Screen, Advanced Search Screen
primaryButtonColor: {
color: primaryButtonColor
},
// Button text color style. Used On: Export Data Screen, Advanced Search Screen
primaryButtonColorText: setFont({
...bodyText,
size: 15,
weight: FontWeights.bold
}),
// Link style. Used On: Filter Screen,Blog Screen, Course screen, Login Screen
link: {
...setFont({
...bodyText,
size: 14,
weight: FontWeights.regular,
color: linkColor
}),
backgroundColor: "transparent"
},
// Blog delete & report button style. Used On: Blog Screen
deleteLink: {
...setFont({
...bodyText,
size: 14,
weight: FontWeights.regular,
color: warningColor
}),
backgroundColor: "transparent"
},
// Cancel search text style. Used On: Search Screen
cancelSearch: {
...setFont({
...bodyText,
size: 17,
weight: FontWeights.regular,
color: linkColor
}),
backgroundColor: "transparent"
},
// Blog screen icon button text style. Used On: Blog Screen
// Group message screen list select unselect text style. Used On: Group Screen
// widget title see more label text style. Used On Home Screen
seeLink: {
...setFont({
...bodyText,
size: Platform.select({ios: 17, android: 16}),
weight: FontWeights.regular,
color: linkColor
}),
backgroundColor: "transparent"
},
// Various screen's label text style. Used On: Profile screen, Edit profile screen, Document screen, Topic screen
linkRegular: setFont({
...bodyText,
size: 16,
weight: FontWeights.regular,
color: linkColor
}),
// not used
linkArrow: {
width: 10,
height: 8,
marginRight: 6
},
// Forward arrow style. Used On: Login screen, Social Login screen, Course screen
linkArrowRight: {
width: 10,
height: 8,
marginLeft: 6
},
// Previous button, Next button, lesson complete button, mark as complete button, login as guest button, login with email button view style.
// Used On: Couuse screen, topic screen, login screen, social login screen.
linkWithArrow: {
flexDirection: "row",
alignItems: "center"
},
// List view style. Used On: Group list and common list screen
listWrap: {
flex: 1,
backgroundColor: bodyFrontBg
},
// Text input style. Used On: quiz form screen, form screen, add topic screen, link account screen, login screen, reply screen
input: setFont({
...bodyText,
size: 16,
weight: FontWeights.regular,
color: textColor
}),
// Quiz form invalid text field style. Used On: Quiz screen
invalidField: setFont({
...bodyText,
size: 12,
weight: FontWeights.regular,
color: warningColor
}),
// Input description. Used on: Advanced search
inputDesc: setFont({
...bodyText,
size: 12,
weight: FontWeights.regular,
color: descTextColor
}),
// not in use
label: {
...setFont({
...bodyText,
size: 12,
weight: FontWeights.regular,
color: textColor
}),
marginBottom: 7
},
// Form page text input wrap view style. Used On: Quiz screen, Link Account screen, Login screen, Reply screen
inputWrap: {
position: "relative",
paddingTop: 0,
paddingBottom: 0,
borderBottomWidth: StyleSheet.hairlineWidth
},
// Matrix Question type style. Used On: Quiz screen
quizInput: {
...setFont({
...bodyText,
size: 14,
weight: FontWeights.regular,
color: textColor
}),
paddingLeft: 10,
paddingRight: 10,
height: 36,
borderRadius: 3,
borderWidth: 1,
borderColor: borderColor
},
// Button label text style. Used On: Menu item screen
buttonLabel: setFont({
...bodyText,
size: 16,
weight: FontWeights.semiBold,
color: secondaryButtonColor
}),
// Input label text style. Used On: Reset password screen
resetPasswordInputLabel: {
...setFont({
...bodyText,
size: 17,
weight: FontWeights.medium,
color: secondaryButtonColor
}),
marginBottom: 10
},
// Reset password instructions text style. Used On: Reset password screen
resetPasswordInstructions: {
...setFont({
...bodyText,
size: 15,
weight: FontWeights.regular,
color: descTextColor
}),
paddingVertical: 10
},
// Reset password instructions steps text style. Used On: Reset password screen
resetPasswordInstructionsSteps: setFont({
...bodyText,
size: 13,
weight: FontWeights.medium,
color: descLightTextColor
}),
// group header member avatar button style. Used On: group screen
singleScreenActionButton: {
paddingHorizontal: 22,
height: 28,
borderRadius: 37 / 2,
backgroundColor: whiteColor
},
// Input text style used in Edit profile screen
// Dropdown text style. Used On setting form screen
profileInputText: setFont({
...bodyText,
size: 16,
weight: FontWeights.medium,
color: textColor
}),
// Date picker view style. Used On: edit profile screen
profileInput: {
paddingHorizontal: 16,
minHeight: 48,
borderRadius: 10,
borderColor: inputBorderColorAlt,
backgroundColor: bodyBg
},
// Dropdown style. Used On: Edit Profile screen
profileDropdown: {
borderRadius: 10,
minHeight: 48,
paddingHorizontal: 16,
backgroundColor: bodyBg,
borderBottomWidth: 0
},
// Profile field label text style. Used On: Edit Profile screen
profileInputLabel: setFont({
...bodyText,
size: 20,
weight: FontWeights.bold,
color: headingsColor
}),
// Form item descriptional field text style. Used On: Email invites screen Edit Profile screen
profileInputDesc: setFont({
...bodyText,
size: 13,
weight: FontWeights.regular,
color: descLightTextColor
}),
// Home page bottom tab icon wrapper style. Used On: Home Screen
profileItemIconWrap: {
width: 22
},
// Home page bottom tab icon style. Used On: Home Screen
profileItemIcon: {
alignSelf: "center"
},
// Global button view style. Used On: almost every screen
button: {
height: 46,
backgroundColor: primaryButtonBg,
alignItems: "center",
justifyContent: "center",
flexDirection: "row",
borderRadius: 12
},
// Global secondary button style. Used On: almost every screen
buttonSecondary: {
height: 46,
backgroundColor: secondaryButtonBg,
alignItems: "center",
justifyContent: "center",
flexDirection: "row",
borderRadius: 12
},
// Global button text style. Used On: almost every screen
buttonPrimaryLabel: setFont({
...bodyText,
size: 16,
weight: FontWeights.bold,
color: primaryButtonColor
}),
// Global secondary button text style. Used On: almost every screen
buttonSecondaryLabel: setFont({
...bodyText,
size: 16,
weight: FontWeights.bold,
color: secondaryButtonColor
}),
// Add item button text style. Used On: email invite composer screen
buttonText: setFont({
...bodyText,
size: 16,
weight: FontWeights.regular,
color: secondaryButtonColor
}),
// List button style. Used On: list screen in the app
listButton: {
height: 50,
backgroundColor: "transparent",
alignItems: "center",
justifyContent: "center",
flexDirection: "row"
},
// product screen button style. Used On: Product screen, subscriptions screen
roundButton: {
height: 38,
borderRadius: 19
},
// Course introductional video play button style. Used On: course screen
playButton: {
width: 38,
height: 38,
borderRadius: 19,
borderStyle: "solid",
borderWidth: 1.2,
borderColor: whiteColor,
padding: 0,
alignItems: "center",
justifyContent: "center"
},
// upload media button style. Used On: Feedback screen, Photo screen, cover screen
primaryButtonContainer: {backgroundColor: primaryButtonBg},
// delete media button style. Used On: Feedback screen, Photo screen, cover screen
secondaryButtonContainer: {backgroundColor: secondaryButtonBg},
// not used
primaryButtonLabel: {color: primaryButtonColor},
// not used
secondaryButtonLabel: {color: secondaryButtonColor},
// Login button, forget button style
// Used On: Login screen, Forgot Passwoard Screen
authButtonContainer: {backgroundColor: authButtonBgColor},
//labels of Login button, forget button style
// Used On: Login screen, Forgot Passwoard Screen
authButtonLabel: setFont({
...bodyText,
size: 16,
weight: FontWeights.semiBold,
color: authButtonTextColor
}),
// Signup button, verification code button
// Used On: Signup screen, Code Verification Screen
regButtonContainer: {backgroundColor: regButtonBgColor},
//labels of Signup button, verification code button
// Used On: Signup screen, Code Verification Screen
regButtonLabel: setFont({
...bodyText,
size: 16,
weight: FontWeights.semiBold,
color: regButtonTextColor
}),
twitterLoginButton: {},
facebookLoginButton: {},
googleLoginButton: {},
appleLoginButton: {},
// Screens bottom button style. Used On: Course screen Style, social login screen, Subscription screen
footerButton: {
height: 48,
backgroundColor: bodyFrontBg,
alignItems: "center",
justifyContent: "center",
flexDirection: "row"
},
// Inner button style. Used On: App Screens, Notiication Screen, Lists Screens
buttonInner: {
flexDirection: "row",
alignItems: "center"
},
mediaItem: {
width: 80,
height: 80,
marginRight: 15,
resizeMode: "cover"
},
// Logo Style. Used On: Social Login screen
logo: {
width: "100%",
height: "100%",
maxHeight: 100,
maxWidth: 150,
resizeMode: "contain"
},
// Header style. Used On: Login Screen, link account screen, code verification screen, forgot password screen
authHeader: {
flex: 1,
marginTop: 50
},
// Screen text style. Used On:login screen, urvey screen, profile block for home screen, link account screen
screenTitle: {
...setFont({
...bodyText,
weight: FontWeights.bold,
color: headingsColor,
size: 20
}),
marginTop: 14,
backgroundColor: "transparent",
marginBottom: 14
},
// Screen header style. Used On: course screen, profile list screen, course material screen, course quizzes screen
iosStyleScreenTitle: {
...setListHeaderFont({
color: headerColor,
weight: FontWeights.bold,
size: 34
})
// marginBottom: 9
},
// Screen subtitle style. Used On: Over the whole app
iosStyleScreenSubtitle: {
...setListHeaderFont({
color: descLightTextColor,
weight: FontWeights.bold,
size: 16
})
},
// Title style. Used On: Single group screen
titleWithButton: {
flexDirection: "row",
alignItems: "center",
marginTop: 14,
marginBottom: 14
},
// Short content text style. Used On: Group screen, Link account screen
screenDescription: {
textAlign: "center",
backgroundColor: "transparent",
width: 279
},
// Group header details text view style. Used On: group screen
// Profile block user points detail view style. Used On: home screen
screenMetas: {
flexDirection: "row",
alignItems: "center",
justifyContent: "center",
marginTop: 12,
backgroundColor: "transparent"
},
// Screens inner text style. Used On: profile blocks home screen, cretificate screen, group screen, more screen
screenMeta: {
...setFont({
...bodyText,
size: 14,
weight: FontWeights.regular,
color: descLightTextColor
}),
backgroundColor: "transparent"
},
// Single group screen admin view style
screenHeaderBottom: {
marginTop: "auto",
flexDirection: "row",
alignItems: "center"
},
// Quiz result list view style. Used On: Quiz details screen
listItem: {
paddingTop: 25,
paddingRight: 16,
paddingBottom: 16,
paddingLeft: 16,
position: "relative"
},
// Forum topic title & sub forum title text style. Used On: single forum screen
forumListTitle: setFont({
...bodyText,
size: 21,
weight: FontWeights.medium,
color: textColor
}),
// Forum item view style. Used On: forum list screen
forumListItem: {
paddingHorizontal: GUTTER,
position: "relative"
},
// reply list item view style. Used On: notification reply item and thoughout the app reply view
replyListItem: {
paddingBottom: 16,
paddingHorizontal: 16
},
// List item header view. Used On: topic single screen, more screen
itemHeader: {
flexDirection: "row",
justifyContent: "space-between",
alignItems: "flex-start"
},
// List item content view. Used On: topic single screen, more screen
itemContent: {
marginTop: 7,
marginLeft: 42,
marginBottom: 12
},
// Topic single screen header's footer view style
// Merge topic screen footer view style
itemFooterMeta: {
flexDirection: "row",
alignItems: "center",
marginLeft: 43
},
// List item footer view style. Used On: document screen, forum single screen, topic single screen
itemFooter: {
flexDirection: "row",
alignItems: "center"
},
// List item left side view style. Used On: more screen, Reply screen
itemLeft: {
flexDirection: "row",
alignItems: "flex-start",
flex: 1
},
// Name text style. Used On: setting screen, merge topic screen, reply screen
itemName: {
...setFont({
...bodyText,
size: 17,
weight: FontWeights.medium,
color: headingsColor
}),
backgroundColor: "transparent"
},
// Course status text style. Used On: course screen
itemText: {
...setFont({
...bodyText,
size: 15,
weight: FontWeights.regular,
color: textColor
}),
backgroundColor: "transparent"
},
// Course header author name text style. Used On: course screen
itemAuthorName: {
...setFont({
...bodyText,
size: 17,
weight: FontWeights.semiBold,
color: headingsColor
}),
backgroundColor: "transparent"
},
// App screens inner text style. Used On: topic screen, group screen, Blog screen, forum screen, result screen, profile screen, Lesson screen
itemMeta: {
...setFont({
...bodyText,
size: 13,
color: descLightTextColor,
weight: FontWeights.regular
}),
backgroundColor: "transparent"
},
// Icon style. Used On: filter list and Topic single screen
optionItemIcon: {
height: 24,
width: 24,
tintColor: textColor,
marginRight: 13
},
// not used
progressCount: {
...setFont({
...bodyText,
size: 17,
color: descLightTextColor,
weight: FontWeights.regular
}),
backgroundColor: "transparent"
},
// Forum header title text style. Used On: Forum screen
linkMeta: setFont({
...bodyText,
size: 16,
color: linkColor,
weight: FontWeights.regular
}),
// Date text style. Used On: message screen, reply screen, notification screen
itemLightMeta: {
...setFont({
...bodyText,
size: 16,
color: descLightTextColor,
weight: FontWeights.regular
}),
backgroundColor: "transparent"
},
// Dot seprator style. Used On: blog screen, course screen, forum screen, group screen, topic screen, document screen
dotSep: {
width: 3,
height: 3,
marginLeft: 8,
marginRight: 8,
backgroundColor: descLightTextColor,
borderRadius: 2
},
// Widget title style. Used On: course widget, group widget
widgetItemTitle: setFont({
...bodyText,
size: 17,
weight: FontWeights.semiBold
}),
// screen inner text and button style. Used On: survet screen, topic screen, forum screen, certificates screen
itemTitle: setFont({
...bodyText,
size: 17,
weight: FontWeights.semiBold,
color: textColor
}),
// Sub forum title text style. Used On: sub forum screen
subForumTitle: setFont({
...bodyText,
size: 13,
color: textColor,
weight: FontWeights.semiBold
}),
// Title text style. Used On: Notification screen, move reply screen, merge topic screen, split reply screen
itemTopicTitle: setFont({
...bodyText,
size: 16,
color: textColor,
weight: FontWeights.regular
}),
// List item descriptional text style. Used On: forum screen, edit profile screen, product single screenemail invites send screen
itemDesc: setFont({
...bodyText,
size: 16,
weight: FontWeights.regular,
color: descTextColor
}),
// Large content text style. Used On: subscription screen, topic single screen, course screen
itemAltDesc: setFont({
...bodyText,
size: 16,
weight: FontWeights.regular,
color: lightTextColor
}),
// Member item view style. Used On: member screen
itemAvatar: {
marginRight: 10,
width: 32,
height: 32,
borderRadius: 15,
backgroundColor: "transparent"
},
// Sub-forum list view style. Used On: forum screen
itemSubforums: {
maxWidth: 260
},
// Topic item parent view style. Used On: topic screen
itemSticky: {
backgroundColor: shadeColor(notifColor, 0.2),
borderLeftColor: notifColor,
borderLeftWidth: 2
},
// Topic item parent view style. Used On: topic screen
itemClosed: {
opacity: 0.6,
backgroundColor: bodyBg,
borderLeftColor: borderColor,
borderLeftWidth: 2
},
// Parent view style. Used On: new reply item and topic single screen
itemSpam: {
backgroundColor: shadeColor(warningColor, 0.3),
borderLeftColor: warningColor,
borderLeftWidth: 2
},
// Popup dialog style. Used On: activity screen
dialogPopup: {
borderRadius: 8,
flexDirection: "column"
},
// Popup dialog inner style. Used On: activity screen
dialogPopupInner: {
paddingVertical: 8
},
// Popup dialog button style. Used On: activity screen
dialogPopupButton: {
paddingVertical: 10
},
// general view style. Used On: various screen in the application
bottomBorder: {
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth
},
// view style. Used On: document screen, block modal, report form screen
topBorder: {
borderTopColor: borderColor,
borderTopWidth: StyleSheet.hairlineWidth
},
// avatar wrapper view. Used On: photo description screen, learn topic single screen, Lesson Single screen
avatarWrap: {
marginRight: 10
},
// not in used yet
listSeparator: {
height: 22,
backgroundColor: bodyBg
},
// Seperator style for activity list screen
listSeparatorBordered: {
borderTopColor: borderColor,
borderTopWidth: StyleSheet.hairlineWidth,
marginHorizontal: GUTTER
},
// Bottom tab bar menu label style. Used On: home screen
menuLabelStyle: setFont({
family: appTabBar.family,
color: appTabBar.color || textColor,
size: appTabBar.size || 10,
weight: FontWeights.regular
}),
// Parent view style. Used On: more screen, setting about screen, setting privacy screen, setting screen, setting push screen
settingsPage: {
backgroundColor: bodyBg,
flex: 1
},
// Separator view style. Used On: group single screen, setting about screen, setting privacy screen, setting push screen, setting screen, email preference screen
settingsSeparator: {
marginTop: 22,
height: 0,
marginBottom: 0
},
// Icon style for group single screen, setting screen
settingsItemIcon: {
alignSelf: "center",
height: 30,
width: 30
},
// More icon style. Used On: more screen
moreItemIcon: {
alignSelf: "center",
height: DEVICE_WIDTH * 0.075,
width: DEVICE_WIDTH * 0.075
},
// Setting list item title style. Used On: group single screen, merge topic screen, more screen, setting screen,
settingsItemTitle: setAppMenusFont({
...appMenus,
size: 17,
color: textColor,
weight: FontWeights.semiBold
}),
// Setting list text style. Used On: Setting screen
settingsTitleInfo: {
...setAppMenusFont({
...appMenus,
size: 16,
weight: FontWeights.semiBold,
color: descLightTextColor
}),
marginRight: 16
},
// Seperator style on forum single screen, select screen
separator: {
backgroundColor: borderColor
},
// Logout view style. Used On: setting screen
logout: {
height: 60,
backgroundColor: bodyFrontBg,
alignItems: "center",
justifyContent: "center"
},
// Logout text style. Used On: setting screen
logoutInner: setFont({
...bodyText,
size: 16,
color: warningColor,
weight: FontWeights.regular
}),
// Icon style for filter dropdown
subFilterIcon: {
width: "100%"
},
// Search wrapper style used on group picker modal
panelSimple: {
backgroundColor: filterBottomSheetBg,
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth,
borderTopRightRadius: 12,
borderTopLeftRadius: 12,
padding: 15
},
// Parent view style. Used On: Modal and bottomsheet header
panelHeader: {
minHeight: BOTTOM_SHEET_HEADER_HEIGHT,
backgroundColor: filterBottomSheetBg,
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth,
justifyContent: "space-between",
paddingLeft: 20,
paddingRight: 16,
borderTopRightRadius: 12,
borderTopLeftRadius: 12
},
// Parent view style. Used On: album single list pure, topic single screen and action sheet button wrapper
panel: {
backgroundColor: filterBottomSheetBg,
paddingTop: 12,
paddingBottom: 20,
shadowColor: whiteColor,
shadowOpacity: 0.1,
shadowRadius: 10,
zIndex: 1,
height: "100%"
},
// View style. Used On: Document screen and filter list
panelInner: {
paddingTop: 12,
paddingHorizontal: 20
},
// sub filter text style. Used On: fitler list
panelSubtitleText: {
...setFont({
...bodyText,
size: 13,
color: descLightTextColor,
weight: FontWeights.semiBold
}),
textTransform: "uppercase",
marginTop: 8
},
// not used
panelSubtitle: {
borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: borderColor,
paddingBottom: 7
},
panelSubtitleAlt: {},
// Text style. Used On: blog screen product screen, my library screen, sign up screen
filterTitle: {
...setFont({
...bodyText,
size: 20,
color: headingsColor,
weight: FontWeights.semiBold
}),
marginRight: 8
},
// Photo delete button text style. Used On: photo screen
bottomSheetAlertTitle: {
...setFont({
...bodyText,
size: 15,
color: headingsColor,
weight: FontWeights.semiBold
}),
marginRight: 8
},
// View style. Used On: topic single screen, more screen, block user screen
roundBox: {
marginTop: 12,
borderRadius: 10,
backgroundColor: bodyFrontBg,
overflow: "hidden"
},
// View style to sgow list item. Used On: topic single screen and filter list
filterListItem: {
marginLeft: 16,
paddingRight: 20,
justifyContent: "center",
borderTopWidth: StyleSheet.hairlineWidth,
borderTopColor: borderColor,
height: 52
},
// Active filter list view style. Used On: filter list
activeListFilter: {
color: textColor
},
// Active background view style. Used On: activity privacy screen and filter list
activeBg: {
backgroundColor: shadeColor(linkColor, 0.08)
},
// Active border view style. Used On: activity privacy screen and filter list
activeBorder: {
borderColor: shadeColor(linkColor, 0.4),
borderWidth: StyleSheet.hairlineWidth
},
// Text style. Used On: profile header
activeText: {
fontWeight: FontWeights["medium"],
color: linkColor
},
// Header view style. Used On: course materials screen, course quizzes screen, course section screen,
iosFilterHeader: {
marginTop: 10,
paddingHorizontal: GUTTER
},
// View style. Used On: activity filter list and filter list
iosFilterWrap: {
borderColor: borderColorAlt
},
// View style. Used On: filter list header
iosFilterWrapInner: {
height: LIST_FILTER_HEIGHT,
paddingLeft: GUTTER,
flexDirection: "row",
alignItems: "center"
},
// Bottom view style. Used On: filter list header
iosFilterBottomBorder: {
marginHorizontal: GUTTER,
borderColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth
},
// Single filter wrap style used for filter list
iosSingleFilterWrap: {
borderRadius: 15,
alignItems: "center",
justifyContent: "center",
height: 30,
borderWidth: 1
},
// Single filter text style used for filter list
iosSingleFilterText: setFont({
...bodyText,
size: 14,
color: textColor,
weight: FontWeights.regular
}),
// Parent view style for tab bar
filter: {
backgroundColor: filterBg,
zIndex: 1
},
// Inner text style. Used On: course single screen
courseExcerpt: {
...setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.regular
}),
lineHeight: 25
},
// Bubble icon view style. Used On: document scren, more screen, profile screen, social group screen
newFilterBubble: {
borderRadius: 10,
height: 20,
minWidth: 30,
paddingHorizontal: 4,
alignItems: "center",
justifyContent: "center",
backgroundColor: shadeColor(primaryColor, 0.1),
marginLeft: 4
},
// Bubble icon text style. Used On: document screen, more screen, profile screen, social group screen
newFilterBubbleText: {
...setFont({
...bodyText,
size: 11,
color: primaryColor,
weight: FontWeights.heavy
}),
marginHorizontal: 3
},
// Filter bubble count style. Used On: tab bar screen
filterBubble: {
borderRadius: 6,
height: 20,
minWidth: 20,
paddingHorizontal: 4,
backgroundColor: filterBg,
alignItems: "center",
justifyContent: "center",
marginLeft: 8
},
// Filter bubble text style. Used On: tab bar screen
filterBubbleText: setFont({
...bodyText,
size: 11,
color: linkColor,
weight: FontWeights.bold
}),
// Filter line style. Used On: tab bar screen
filterLine: {
borderBottomColor: borderColor,
borderBottomWidth: 1
},
// Filter row style. Used On: buddy press filter
filtersRow: {
flexDirection: "row",
alignItems: "flex-end"
},
// not used
filtersMain: {
flex: 1
},
// Active filter view style. Used On: tab bar screen
activeFilter: {
fontWeight: FontWeights.medium,
borderBottomColor: highlightColor,
opacity: 1
},
// Filter text style. Used On: filter list, tab bar screen, topic single screen
filterText: setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.regular
}),
// View style. Used On: merge topic screen, move reply screen, setting push screen, split reply screen
notificationBox: {
backgroundColor: shadeColor(notifColor, 0.2),
paddingVertical: 10,
paddingHorizontal: 16,
borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: borderColor
},
// not used
notificationStatusAccepted: setFont({
...bodyText,
size: 14,
color: successColor,
weight: FontWeights.regular
}),
// not used
notificationStatusRejected: setFont({
...bodyText,
size: 14,
color: warningColor,
weight: FontWeights.regular
}),
// Text style. Used On: merge topic screen, move reply screen, setting push screen, split reply screen
notificationBoxText: {
...setFont({
...bodyText,
size: 12,
color: notifColor,
weight: FontWeights.regular
}),
lineHeight: Math.ceil(calcFontSize(12) * 1.17)
},
// Item view style. Used On: merge topic screen, move reply screen, setting screen, split reply screen
itemBox: {
backgroundColor: bodyBg,
paddingHorizontal: 16,
paddingTop: 15,
paddingBottom: 17,
borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: borderColor
},
// not used
itemBoxInner: {
backgroundColor: bodyFrontBg,
paddingVertical: 20,
paddingHorizontal: 17
},
itemBoxTitle: {},
// row view style. Used On: through out the app
row: {
flexDirection: "row",
alignItems: "center"
},
// not used
widgetNotif: {
paddingTop: 14,
paddingRight: 16,
paddingBottom: 7, //12 - 5
paddingLeft: 16
},
// widget inner style for widget screen. Used On: home screen
widgetInner: {
paddingVertical: 25
},
// widget header style for widget title. Used On: home screen
widgetHeader: {
alignItems: "flex-end",
marginBottom: 18,
paddingHorizontal: GUTTER
},
// widget content style for forum/topic/users widget. Used On: home screen
widgetContent: {
paddingHorizontal: GUTTER
},
// widget border style for activity/notification/progress/forum/topic/users widget. Used On: home screen
widgetBorder: {
marginHorizontal: Platform.select({
ios: GUTTER,
android: GUTTER
}),
borderBottomWidth: StyleSheet.hairlineWidth,
borderBottomColor: borderColor
},
// not used
widgetNotifTitle: setFont({
...bodyText,
size: 14,
color: textColor,
weight: FontWeights.medium
}),
// widget item description. Used On: quiz result screen and home screen
widgetItemDesc: setFont({
...bodyText,
size: 13,
color: descTextColor,
weight: FontWeights.regular
}),
// widget item large description. Used On: course widget screen
widgetItemDescFat: setFont({
...bodyText,
size: 13,
color: textColor,
weight: FontWeights.medium
}),
// widget title style used for widget. Used On: home screen
widgetTitle: {
...setHeadingFont({
color: headingsColor,
size: 26,
weight: FontWeights.semiBold,
headingTag: "h5"
}),
flex: 1,
flexWrap: "wrap"
},
// widget see link style. Used On: home screen
widgetSeeLink: {
paddingLeft: 10
},
// not used
widgetProgressItemText: {
...setFont({
...bodyText,
size: 13 * Math.min(DEVICE_WIDTH / 420, 1),
color: textColor,
weight: FontWeights.bold
}),
backgroundColor: "transparent",
lineHeight: Math.ceil(calcFontSize(11) * 1.46)
},
// action button wrapper view. Used On: Thourgh out the app
actionButtonWrap: {
marginLeft: 16,
paddingVertical: 15,
borderTopColor: borderColor
},
// button view style. Used On: Various menu screens
wrappedButton: {
height: FontManager.applyFontHeightAdjustment(30, Typographies.bodyText),
backgroundColor: secondaryButtonBg,
borderRadius: 15,
alignItems: "center",
justifyContent: "center"
},
// icon button view style. Used On: filter list
wrappedIconButton: {
width: 48,
height: 48,
backgroundColor: shadeColor(whiteColor, 0.18),
borderRadius: 24
},
// Round icon button style. Used On: Throught out the app
wrappedIconButtonHighlight: {
width: 48,
height: 48,
backgroundColor: highlightColor,
borderRadius: 24
},
// button view style
wrappedActionIcon: {
backgroundColor: filterBg,
borderRadius: 15,
alignItems: "center",
justifyContent: "center",
width: 32,
height: 32
},
// action icon text button style
actionIconText: setFont({
...bodyText,
size: 12,
color: textColor,
weight: FontWeights.semiBold
}),
// button text style. Used On: group screen, block user screen,notification screen, profile screen
wrappedTextButton: {
paddingHorizontal: 16,
borderRadius: 14,
height: FontManager.applyFontHeightAdjustment(28, Typographies.bodyText),
minWidth: 50
},
// button text style. Used On: group screen, block user screen,notification screen, profile screen
wrappedTextButtonLabel: setFont({
...bodyText,
size: 15,
color: linkColor,
weight: FontWeights.semiBold
}),
quickLinksContainer: {},
// text style. Used On: members screen
restCount: setFont({
...bodyText,
size: 11,
color: textColor,
weight: FontWeights.regular
}),
// not used
drawerMeta: {
...setFont({
...bodyText,
size: 11,
color: descLightTextColor,
weight: FontWeights.regular
}),
lineHeight: Math.ceil(calcFontSize(11) * 1.45)
},
// not used
sitesTitle: setFont({
...bodyText,
size: 38,
color: textColor,
weight: FontWeights.bold
}),
// blog name style. Used On: Site selection screen and Auth site selection screen, Email invite message screen
siteTitle: {
flex: 1,
...setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.medium
})
},
// not used
userHandle: {
marginBottom: 14,
color: descTextColor
},
// user full name text style. Used On: more screen
moreName: setFont({
...appMenus,
size: 19,
color: textColor,
weight: FontWeights.semiBold
}),
// header title text style used app header
appHeaderTitle: {
...setFont({
...typography.appHeaderTitle,
size: 17,
color: headerColor,
weight: FontWeights.semiBold
}),
marginLeft: "auto",
marginRight: "auto",
backgroundColor: "transparent"
},
// content style. Used On: home screen, Quiz single screen, Blog screen
content: {
...setFont({
...bodyText,
size: 16,
color: textColor,
weight: FontWeights.regular
}),
lineHeight: calcFontSize(16 * 1.47)
},
contentPlain: {
...setFont({
...bodyText,
size: 16,
color: textColor,
weight: FontWeights.regular
})
},
// link content style. Used On: home screen, blog screen
linkContent: {
...setFont({
...bodyText,
size: 16,
color: linkColor,
weight: FontWeights.regular
})
// textDecorationLine: "none"
},
// caption text style. Used On: album screen, course screen, audio block, video block, quote block, lesson single screen
caption: {
...setFont({
...bodyText,
size: 16,
color: descLightTextColor,
weight: FontWeights.regular
}),
textAlign: "center",
marginTop: 10
},
// not used
borderTop: {
borderTopColor: borderColor,
borderTopWidth: StyleSheet.hairlineWidth
},
// global header style. Used On: app header
header: {
backgroundColor: headerBg,
borderBottomColor: "transparent",
elevation: 0,
shadowOpacity: 0,
paddingLeft: 10,
paddingRight: 10
},
// header style. Used On: group single screen and link account screen
headerTransparent: {
borderBottomColor: "transparent",
elevation: 0,
shadowOpacity: 0,
paddingLeft: 10,
paddingRight: 10
},
// header border style. Used On: app header
headerBorder: {
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth
},
// header logo style. Used On: app header
headerLogo: {
width: "100%",
flex: 1,
alignItems: "center"
},
// header title style. Used On: app header
headerCustomTitle: {
marginHorizontal: 16,
maxWidth: DEVICE_WIDTH * 0.39,
alignItems: "center"
},
// header left button view style. Used On: app header
headerButtonLeft: {
position: "absolute",
left: 0,
top: 0,
bottom: 0,
justifyContent: "center",
alignItems: "flex-start",
width: "50%"
},
// header right button view style. Used On: app header
headerButtonRight: {
position: "absolute",
right: 0,
top: 0,
bottom: 0,
justifyContent: "center",
alignItems: "flex-end",
width: "50%"
},
// not used
headerTitle: {
marginLeft: "auto",
marginRight: "auto"
},
// header title text style. Used On: through out app
headerText: {
...setFont({
...bodyText,
size: 17,
color: headerIconColor,
weight: FontWeights.medium
}),
maxWidth: DEVICE_WIDTH * 0.2
},
// save button text style used in app
// cancel button text style used in app
headerTextButton: {
padding: 5
},
// header left text style. Used On: many screens
headerTextButtonLeft: {
padding: 5,
marginLeft: 10
},
// header right text style. Used On: many screens
headerTextButtonRight: {
padding: 5,
marginRight: 10
},
// not used
headerLeft: {
position: "relative",
left: -5
},
// not in used yet
headerRight: {
position: "relative",
right: -5
},
// empty icon style. Used On: empty list screen, quiz offline scree, email invite screen, quiz single screen
emptyIcon: {
marginBottom: 24,
height: 90,
minWidth: 90,
opacity: 0.8,
tintColor: shadeColor(descLightTextColor, 0.4)
},
// empty text style. Used On: empty list screen, quiz offline scree, quiz single screen
emptyTitle: {
...setFont({
...bodyText,
size: 20,
textAlign: "center",
color: descLightTextColor,
weight: FontWeights.semiBold
}),
marginBottom: 1
},
// empty quiz text style. Used On: quiz offline screen and quiz single screen
emptyDesc: {
...setFont({
...bodyText,
size: 15,
textAlign: "center",
color: shadeColor(descLightTextColor, 0.4),
weight: FontWeights.regular
}),
lineHeight: calcFontSize(20),
marginBottom: 1
},
// header cover image style. Used On: group single screen
coverImage: {
flex: 1,
width: "100%"
},
// section header style. Used On: more screen, setting push screen, email preferance screen
sectionHeader: setHeadingFont({
color: shadeColor(headingsColor, 0.4),
size: 13,
weight: FontWeights.semiBold
}),
// overlay view style. Used On: video screen, cover screen, group single screen
overlay: {
position: "absolute",
width: "100%",
height: "100%",
top: 0,
left: 0,
bottom: 0,
right: 0,
backgroundColor: customColors.sectionHeader || primaryColor,
opacity: 0.5
},
// not in used yet
courseOverlay: {
position: "absolute",
width: "100%",
height: "100%",
top: 0,
left: 0,
bottom: 0,
right: 0,
backgroundColor: customColors.sectionHeader || primaryColor,
opacity: 0.5
},
// action button dummy view style
socialProfileButton: {
borderColor: "transparent",
height: 30,
borderRadius: 15,
opacity: 1
},
// not in used yet
socialProfileAvatar: {
width: 80,
height: 80,
borderRadius: 40,
backgroundColor: whiteColor,
shadowColor: shadeColor(darkBlueColor, 0.12),
shadowOffset: {
width: 0,
height: 3
},
shadowRadius: 5,
shadowOpacity: 1,
justifyContent: "center",
alignItems: "center"
},
// input text label style. Used On: quiz form screen
inputLabel:
bodyText.family !== "Default"
? FontManager.createFontStyles(bodyText.family, {
weight: Number(FontWeights.regular)
})
: {fontFamily: fontFamilyMapping(bodyText.family)},
// description title style used for course description screen
courseDescriptionTitle: setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.semiBold
}),
// course date text style. Used On: course screen
courseDate: setFont({
...bodyText,
size: 13,
color: descLightTextColor,
weight: FontWeights.medium
}),
// course includes label text style. Used On: course screen
courseIncludesTitle: {
...setFont({
...bodyText,
size: 13,
color: textColor,
weight: FontWeights.bold
}),
textTransform: "uppercase"
},
// course round view style. Used On: course material screen,course quiz sceen, course single screen, learn topic single screen, lesson single screen
courseRoundBox: {
marginBottom: 16,
borderRadius: 10,
backgroundColor: bodyFrontBg
},
// not used
courseRoundBoxStart: {
borderTopRightRadius: 10,
borderTopLeftRadius: 10,
backgroundColor: bodyFrontBg,
height: 10
},
// not used
courseRoundBoxEnd: {
borderBottomRightRadius: 10,
borderBottomLeftRadius: 10,
backgroundColor: bodyFrontBg,
height: 10
},
// course title style. Used On: course single screen, lesson single screen and learn topic single screen
courseRoundBoxTitleAbove: {
...setFont({
...bodyText,
size: 22,
color: headingsColor,
weight: FontWeights.semiBold
}),
marginBottom: 9
},
// not used
courseRoundBoxTitle: {
...setFont({
...bodyText,
size: 16,
color: descTextColor,
weight: FontWeights.heavy
}),
marginBottom: 8
},
// course quiz text style. Used On: course screen
courseRoundBoxSectionTitle: {
...setFont({
...bodyText,
size: 17,
color: descTextColor,
weight: FontWeights.semiBold
}),
marginBottom: 10
},
// not used
courseRoundP: {
padding: 18
},
// not used
courseContentBoxItem: {
paddingHorizontal: 18,
justifyContent: "center",
flexDirection: "row",
justifyContent: "space-between",
alignItems: "center",
paddingTop: 10,
height: 60
},
// progress list item and learn item parent view style
courseRoundBoxItem: {
paddingHorizontal: 18,
height: 50,
justifyContent: "center"
},
// title text style. Used On: progress list item and learn item
courseRoundBoxItemText: setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.medium
}),
// not used
courseRoundBoxItemCount: setFont({
...bodyText,
size: 17,
color: descLightTextColor,
weight: FontWeights.medium
}),
// course section parent view style. Used On: course section screen
courseRoundBoxSeparator: {
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth
},
// course status tag text style. Used On: course widget
courseStatusTagText: setFont({
...bodyText,
size: 12,
color: whiteColor,
weight: FontWeights.semiBold
}),
// course item view style. Used On: course widget
courseItem: {
overflow: "hidden"
},
// Course item content view. Used On: course widget horizontal list
courseItemContent: {
flex: 1,
marginRight: 5
},
// course item view style. Used On: course widget horizontal list
courseItemWrap: {
flex: 1,
flexDirection: "row",
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth,
paddingBottom: 18
},
// Error text style for IAP courses. Used On: IAP screen
courseIapErrorText: setFont({
...bodyText,
size: 15,
color: descLightTextColor,
weight: FontWeights.medium
}),
// product price text style. Used On: store product dropdown view in IAP screen
courseFooterPriceText: setFont({
...bodyText,
size: 20,
color: textColor,
weight: FontWeights.semiBold
}),
// not used
bigTitle: {
...setFont({
...bodyText,
size: 28,
color: textColor,
weight: FontWeights.bold
}),
backgroundColor: "transparent"
},
// not used
subtitle: {
marginBottom: 10,
...setFont({
...bodyText,
size: 14,
color: highlightColor,
weight: FontWeights.medium
})
},
// not used
lessonTitle: setFont({
...bodyText,
size: 22,
color: headingsColor,
weight: FontWeights.semiBold
}),
// complete lesson style. Used On: lesson single screen
completeButton: setFont({
...bodyText,
size: 16,
weight: FontWeights.semiBold
}),
// Lesson complete button view style. Used On: lesson single screen
completeLessonButtonW: {
height: 40,
alignItems: "center",
justifyContent: "center",
flexDirection: "row",
borderRadius: 10
},
// Topic complete button view style. Used On: learn topic single screen
completeTopicButtonW: {
height: 40,
alignItems: "center",
justifyContent: "center",
flexDirection: "row",
borderRadius: 10
},
// Quiz complete button view style. Used On: quiz results screen
quizResultButton: {
height: 40,
alignItems: "center",
justifyContent: "center",
flexDirection: "row",
borderRadius: 10
},
// Complete Lesson button text style. Used On: Lesson single screen
completeLessonButton: setFont({
...bodyText,
size: 16,
weight: FontWeights.bold
}),
// Complete topic button style. Used On: learn topic single screen
completeTopicButton: setFont({
...bodyText,
size: 16,
weight: FontWeights.semiBold
}),
// Complete quiz text style. Used On: quiz results screen
quizResultButtonLabel: setFont({
...bodyText,
size: 16,
weight: FontWeights.semiBold
}),
// Quiz category tag view style. Used On: quiz single Screen
categoryTag: {
backgroundColor: tagBackground,
height: 27,
borderRadius: 13,
paddingHorizontal: 14,
marginTop: 10,
marginRight: 7,
alignItems: "center",
justifyContent: "center"
},
// certificates and quiz category tag text style. Used On: certificates screen and quiz single screen
categoryTagInner: setFont({
...bodyText,
size: 22,
color: lightTextColor,
weight: FontWeights.medium
}),
// course category tag view style. Used On: single course screen, lesson single screen
courseCategoryTag: {
backgroundColor: secondaryButtonBg,
height: 30,
borderRadius: 16,
paddingHorizontal: 14,
marginTop: 10,
marginRight: 6,
alignItems: "center",
justifyContent: "center"
},
// course category tag text style. Used On: single course screen, lesson single screen
courseCategoryTagInner: setFont({
...bodyText,
size: 14,
color: secondaryButtonColor,
weight: FontWeights.semiBold
}),
// not used
section: {
marginBottom: 30
},
// course menu item title text view wrapper style. Used On: course screen
sectionTitleWrap: {
justifyContent: "center",
marginBottom: 15,
marginLeft: 15
},
// // course menu item title text style. Used On: course screen
sectionTitle: {
...setFont({
...bodyText,
size: 20,
color: headingsColor,
weight: FontWeights.semiBold
}),
letterSpacing: 0.7,
marginRight: 8
},
// course menu view style. Used On: course screen
sectionItem: {
borderLeftColor: "transparent",
borderLeftWidth: 2,
paddingHorizontal: 15
},
// course menu item view style. Used On: course screen
sectionItemInner: {
height: 48,
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth
},
// course menu title text style. Used On: course screen
sectionText: {
...setFont({
...bodyText,
size: 14,
color: headingsColor,
weight: FontWeights.medium
}),
flex: 1,
marginRight: 10
},
// not used
profileHeaderColor: {
color: headingsColor,
fontWeight: FontWeights.medium
},
// Album widget header text style. Used On: album screen
profileAlbumHeaderText: setFont({
...bodyText,
size: 15,
color: headingsColor,
weight: FontWeights.medium
}),
// Album widget text style. Used On: album screen
profileAlbumText: setFont({
...bodyText,
size: 13,
color: descLightTextColor,
weight: FontWeights.regular
}),
// Profile header view style. Used On: Profile screen
flexColumnCenter: {
flexDirection: "column",
justifyContent: "center",
alignItems: "center"
},
// course item locked view style. Used On: course menu list screen
locked: {
opacity: 0.5
},
// Section view to show course progess and labels in course screen
sectionItemDetails: {
marginLeft: "auto"
},
// not in use
lessonTopicCount: {
marginRight: 11
},
// Home page block title text style. Used On: home screen
h5pTitle: {
...setFont({
...bodyText,
size: 18,
color: secondaryButtonColor,
weight: FontWeights.semiBold
}),
backgroundColor: "transparent"
},
// course progression normal text style. Used On: course screen
progressText: {
...setFont({
...bodyText,
size: 17,
color: whiteColor,
weight: FontWeights.heavy
}),
lineHeight: Math.ceil(calcFontSize(12) * 1.42),
backgroundColor: "transparent"
},
// course progression large text style. Used On: course screen
progressLargeText: {
...setFont({
...bodyText,
size: 18,
color: textColor,
weight: FontWeights.semiBold
}),
backgroundColor: "transparent"
},
// check button text style for correct and incorrect answer and for quiz timer. Used On: Quiz screen
quizCheckTitle: {
...setFont({
...bodyText,
size: 18,
color: headingsColor,
weight: FontWeights.semiBold
}),
backgroundColor: "transparent"
},
// not used
quizQuestionStatus: {
...setFont({
...bodyText,
size: 16,
color: descTextColor,
weight: FontWeights.regular
}),
backgroundColor: "transparent"
},
// not used
quizCheckMessage: {
...setFont({
...bodyText,
size: 18,
color: descTextColor,
weight: FontWeights.regular
}),
backgroundColor: "transparent"
},
// Quiz overview & quiz next button style. Used On: Quiz screen
checkDialogButton: setFont({
...bodyText,
size: 15,
color: textColor,
weight: FontWeights.bold
}),
// not used
quizResultsTitle: {
...setFont({
...bodyText,
size: 15,
color: headingsColor,
weight: FontWeights.regular
}),
backgroundColor: "transparent"
},
// Question hint view style. Used On: Quiz screen
quizDetailsButton: {
...setFont({
...bodyText,
size: 15,
color: textColor,
weight: FontWeights.regular
}),
backgroundColor: "transparent"
},
// Quiz start button style. Used On: Quiz screen
quizStartButtonLabel: setFont({
...bodyText,
size: 16,
color: primaryButtonColor,
weight: FontWeights.semiBold
}),
// Quiz submit button style. Used On: Quiz screen
quizSubmitButtonLabel: setFont({
...bodyText,
size: 16,
color: primaryButtonColor,
weight: FontWeights.semiBold
}),
quizTakeAgainButtonLabel: {},
quizReviewButtonLabel: {},
// Couuse Menu Side header bar text style. Course Screen
sideMenuHeader: {
...setFont({
...bodyText,
size: 16,
color: whiteColor,
weight: FontWeights.regular
}),
marginBottom: 30
},
// Screen Scrolling header view style. Used On: Course Screen, Notification Screen, Profile Screen
scrollHeaderContainer: {
flex: 1,
backgroundColor: bodyFrontBg,
...(Platform.OS === "android" ? {paddingTop: NAV_HEIGHT} : {})
},
// Screen header style. Used On: many screens like CodeVerification Screen, Forget Screen, Link Account scrren, Social login screen, Lesson Single screen
fakeHeader: {
backgroundColor: headerBg,
alignItems: "center",
minHeight: HEADERHEIGHT + BARHEIGHT,
paddingTop: BARHEIGHT
},
// List Status bar style. Used On: List Screens
fakeBar: {
height: NAV_HEIGHT,
backgroundColor: headerBg,
position: "absolute",
width: "100%",
top: 0
},
// header container style. Used On: CodeVerification Screen, Forget Screen, Link Account scrren, Social login screen
fakeHeaderOffset: {
marginTop: HEADERHEIGHT + BARHEIGHT
},
//Header styling used in Forgot Password screen
fakeHeaderForgotPassword: {
marginTop: HEADERHEIGHT + BARHEIGHT
},
//Header styling used in Code verification screen
fakeHeaderCodeVerification: {
marginTop: HEADERHEIGHT + BARHEIGHT
},
// not used
fakeBarOffset: {
marginTop: BARHEIGHT
},
// Not in Use yet
fakeHeaderFix: {
position: "absolute",
top: 0,
left: 0,
right: 0
},
// Countdown Timer text style. Used On: Lesson Single Screen, Quiz Single Screen & Topic Single Screen
timer: {
marginLeft: "auto",
marginRight: 18,
...setFont({
...bodyText,
size: 16,
color: headingsColor,
weight: FontWeights.regular
})
},
// not used
placeholder: {
backgroundColor: whiteColor,
opacity: 0.15,
color: "transparent"
},
// not used
placeholderDark: {
backgroundColor: headingsColor,
opacity: 0.1,
color: "transparent"
},
// not used
placeholderDarkTin: {
backgroundColor: headingsColor,
opacity: 0.1,
color: "transparent",
height: 9
},
// Course description video place holder style. Used On: Course Screen
place: {
backgroundColor: shadeColor(whiteColor, 0.15)
},
// Content Place holder Style. Used On: many screens like Quiz screen, lesson screen, Course Screen, Sign up screen
placeDarkTin: {
backgroundColor: shadeColor(headingsColor, 0.05),
height: 9
},
// Place holder text style. Used On: Topic screen, Lesson Screen
placeDark: {
backgroundColor: shadeColor(headingsColor, 0.05)
},
// not used
holderOneLine: {
width: 100
},
// not used
pointTitle: setFont({
...bodyText,
size: 16,
color: headingsColor,
weight: FontWeights.medium
}),
// Result title text style. Used On: Result screen
resultTitle: setFont({
...bodyText,
size: 17,
color: headingsColor,
weight: FontWeights.medium
}),
// not used
footerButtonFixed: {
position: "absolute",
left: 0,
bottom: 0,
width: "100%",
backgroundColor: whiteColor
},
// Quiz result screen sub title text style. Used On: Quiz Result screen
resultsSubTitle: {
...setFont({
...bodyText,
size: 22,
color: headingsColor,
weight: FontWeights.bold
}),
marginBottom: 20
},
// Quiz result screen row header text style. Used On: Quiz Result screen
tableHeaderCell: setFont({
...bodyText,
size: 11,
color: descLightTextColor,
weight: FontWeights.regular
}),
// Quiz result row item text style. Used On: Quiz Result screen
tableCell: setFont({
...bodyText,
size: 13,
color: textColor,
weight: FontWeights.regular
}),
// Quiz Screen save result text style. Used On: Quiz Result screen
saveButton: setFont({
...bodyText,
size: 13,
color: textColor,
weight: FontWeights.regular
}),
// Activity screen Post Date Style. Used On: Activity screen
activityDate: setFont({
...bodyText,
size: 14,
color: textColor,
weight: FontWeights.regular
}),
scheduleActivityDate: setFont({
...bodyText,
size: 15,
color: textIconColor,
weight: FontWeights.medium
}),
// Activity screen Comment Date Style. Used On: Activity screen
activityDateComment: setFont({
...bodyText,
size: 12,
color: textColor,
weight: FontWeights.regular
}),
// Activity screen and Blog screen Comment count & Like count Style. Used On: Activity Screen & Blog screen
activityCount: {
...setFont({
...bodyText,
size: 13,
color: textColor,
weight: FontWeights.medium
}),
marginTop: Platform.select({ios: 1, android: -2, default: 1})
},
activityButtonLabel: {
...setFont({
...bodyText,
size: 13,
color: textColor,
weight: FontWeights.medium
}),
marginTop: Platform.select({ios: 1, android: -2, default: 1})
},
activityButtonLabel: {
...setFont({
...bodyText,
size: 13,
color: textColor,
weight: FontWeights.medium
}),
marginTop: Platform.select({ios: 1, android: -2, default: 1})
},
// Profile activity's header User Full name Style. Used On: profile Activities screen
activityUsername: setFont({
...bodyText,
size: 14,
color: headingsColor,
weight: FontWeights.regular
}),
// Profile activity's header User nickname Style. Used On: profile Activities screen
activityNicename: setFont({
...bodyText,
size: 10,
color: descLightTextColor,
weight: FontWeights.regular
}),
// not used
h1: setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.semiBold,
headingTag: "h1"
}),
// not used
h2: setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.semiBold,
headingTag: "h2"
}),
// not used
h3: setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.semiBold,
headingTag: "h3"
}),
// not used
h4: setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.semiBold,
headingTag: "h4"
}),
// not used
h5: setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.semiBold,
headingTag: "h5"
}),
// not used
h6: setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.semiBold,
headingTag: "h6"
}),
contentText:
bodyText.family !== "Default"
? FontManager.createFontStyles(bodyText.family, {
weight: Number(FontWeights.regular)
})
: {
fontFamily: fontFamilyMapping(bodyText.family)
},
blockListItemContainer: {
overflow: "hidden"
},
// Home Screen visible block List item container style. Used On: Home screen
blockListItemVisibleContainer: {
overflow: "visible",
marginTop: -1
},
// not used
blockScreenBlockWrap: {
marginVertical: 0
},
// Activity screen header style. Used On: Activity screen
actionSheetHeader: {
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth,
alignItems: "center",
paddingLeft: 20,
paddingRight: 14,
paddingBottom: 20,
marginBottom: 6
},
// Action Sheet internal content style. Used On: Group screen, Social group screen & Forum Single screen
actionSheetContent: {
...setFont({
...bodyText,
size: 17,
color: descTextColor,
weight: FontWeights.regular
}),
marginTop: 7,
backgroundColor: "transparent"
},
// action sheet Header content text style. Used On: header section which in turn Used On: many screens.
actionSheetHeaderContent: {
marginTop: 3
},
// action sheet Header title text style. Used On: header section which in turn Used On: many screens.
actionSheetHeaderTitle: setFont({
size: 16,
family: bodyText.family,
weight: FontWeights.semiBold,
color: textColor
}),
// Action Sheet internal content style. Used On: Group screen, Social group screen & Forum Single screen
actionSheetContent: setFont({
size: 17,
family: bodyText.family,
weight: FontWeights.regular,
color: descTextColor
}),
// Message Screen Sender name text. Used On: Message Screen
messageExcerpt: {
...setFont({
...bodyText,
size: calcFontSize(15),
color: descTextColor,
weight: FontWeights.regular
}),
lineHeight: calcFontSize(20),
backgroundColor: "transparent"
},
// Message send to recipeint user in a group text style. Used On: Group message Create Screen
toUserLabel: {
...setFont({
...bodyText,
size: 15,
color: descTextColor,
weight: FontWeights.regular
}),
backgroundColor: "transparent"
},
// Bolded text style on search for users dropdown. Used On: Group message Create Screen
toUserInput: {
...setFont({
...bodyText,
size: 15,
color: textColor,
weight: FontWeights.medium
}),
backgroundColor: "transparent"
},
// not used
accountSettingsModalTitle: setFont({
...bodyText,
size: 19,
color: headingsColor,
weight: FontWeights.medium
}),
// Export Data modal descriptional text style. Used On: Export data screen
accountSettingsModalInfoText: {
...setFont({
...bodyText,
size: 14,
color: descTextColor,
weight: FontWeights.medium
}),
lineHeight: Math.ceil(calcFontSize(15) * 1.2),
textAlign: "center"
},
// Activity indicator style. Used On: Group Inviite Screen, Privacy setting screen & Login info Screen
settingsFormContainer: {
flexGrow: 1,
paddingTop: 20,
paddingHorizontal: GUTTER,
backgroundColor: bodyFrontBg
},
// Activity indicator style. Used On: Group Inviite Screen, Privacy setting screen & Login info Screen
settingsFormLoader: {
flex: 1,
alignItems: "center",
justifyContent: "flex-start",
paddingTop: 20
},
// not used
settingsFormErrorText: {
textAlign: "center",
margin: GUTTER
},
// Group invite and Privacy setting Message View style
settingsFormInfoContainer: {
paddingBottom: 20
},
// Setting List container style. Used On: setting screen
tabLinksContainer: {
backgroundColor: whiteColor,
borderRadius: 10,
overflow: "hidden",
marginHorizontal: GUTTER
},
// not used
tabBarText: {
...setFont({
...bodyText,
size: 10,
color: linkColor,
weight: FontWeights.medium
}),
opacity: 1,
textAlign: "center"
},
// Read more text style generally used in app and also used for photo description screen. Used On: Photo description screen and various screens in app
readMore: {
...setFont({
...bodyText,
size: 13,
color: linkColor,
weight: FontWeights.semiBold
}),
width: 100
},
// Blocked user name text style. Used On: block user screen
boxTitle: setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.semiBold
}),
// Modal title. Used on: Change Video Thumbnail screen
changeVideoThumbTitle: setFont({
...bodyText,
size: 18,
color: textColor,
weight: FontWeights.regular
}),
// Upload area text. Used on: Change Video Thumbnail screen
uploadImageText: setFont({
...bodyText,
size: 17,
color: descLightTextColor,
weight: FontWeights.regular
}),
// Radio button title. Used on: Change Video Thumbnail screen
radioBoxTitle: setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.regular
}),
radioBoxDesc: setFont({
...bodyText,
size: 14,
color: descLightTextColor,
weight: FontWeights.regular
}),
// not used
boxDesc: setFont({
...bodyText,
size: 16,
color: descLightTextColor,
weight: FontWeights.regular
}),
// Topic title Text Style. Used On: Topic single screen
topicSingleTitle: setFont({
...bodyText,
size: 22,
color: textColor,
weight: FontWeights.bold
}),
// Topic Screen Media Style. Used On: Topic single screen
topicMediaItem: {
width: 50,
height: 54,
borderRadius: 8,
marginRight: 8,
resizeMode: "cover"
},
// Forum's topic tag view style. Used On: Forum Topic Screen
topicTag: {
backgroundColor: secondaryButtonBg,
borderRadius: 12,
paddingVertical: 4,
paddingHorizontal: 10
},
// Forum's topic tag text style. Used On: Forum Topic Screen
topicTagText: setFont({
...bodyText,
size: 13,
color: secondaryButtonColor,
weight: FontWeights.medium
}),
// Group name Title style. Used On: Manage Group Screen
groupSelect: setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.semiBold
}),
// Group name and group description text style Used On: Manage Group Screen
// Setting Form Item Component Text Style used in heading and select box. Used On: Setting Screen
groupManageSectionTitle: {
...setFont({
...bodyText,
size: 22,
color: headingsColor,
weight: FontWeights.bold
}),
letterSpacing: 0.25,
marginBottom: 5
},
// Group cover photo text style. Used On: Manage Group screen
groupManageSectionSubtitle: setFont({
...bodyText,
size: 18,
color: textColor,
weight: FontWeights.semiBold
}),
// Advanced Search label text style. Used On: Advance search screen
advancedSearchLabel: {
textTransform: "uppercase",
...setFont({
...bodyText,
size: 14,
weight: FontWeights.semiBold
})
},
// Products description style. Used On: IAP Screen
productDescription: setFont({
...bodyText,
size: 17,
color: textColor,
weight: FontWeights.regular
}),
// Product Title Text Style. Used On: Registration Products screen
iapSelectProductTitle: {
...setFont({
...bodyText,
size: 18,
color: textColor,
weight: FontWeights.bold
}),
textAlign: "center"
},
// Product Price description and Paid Status Text style. Used On: IAP Screen
iapLabelText: {
...setFont({
...bodyText,
size: 14,
color: "#fff",
weight: FontWeights.regular
}),
textAlign: "center",
textAlignVertical: "center"
},
// Product Title Text Style. Used On: IAP screen
iapProductTitle: {
...setFont({
...bodyText,
size: 26,
color: textColor,
weight: FontWeights.bold
}),
textAlign: "center"
},
// Product Price Text Style. Used On: IAP screen
iapProductPrice: {
...setFont({
...bodyText,
size: 16,
color: secondaryButtonColor,
weight: FontWeights.bold
}),
textAlign: "center"
},
iapCollapsableProductPrice: {
...setFont({
...bodyText,
size: 14,
color: secondaryButtonColor,
weight: FontWeights.bold
}),
textAlign: "center"
},
// Product Duration Text Style. Used On: IAP screen
iapProductPriceDescription: {
...setFont({
...bodyText,
size: 15,
color: descTextColor,
weight: FontWeights.regular
}),
textAlign: "center"
},
iapCollapsableProductPriceDescription: {
...setFont({
...bodyText,
size: 10,
color: descTextColor,
weight: FontWeights.regular
}),
textAlign: "center"
},
// Product Missing Duration Text Style. Used On: IAP screen
iapProductMissingPriceDescription: setFont({
...bodyText,
size: 10,
color: descTextColor,
weight: FontWeights.regular
}),
// Product Purchased Text Style. Used On: IAP screen
iapPurchasedLabel: setFont({
...bodyText,
size: 20,
color: textColor,
weight: FontWeights.regular
}),
// Document & Photos Folder Move to destination folder text style. Used On: Document Screen & Photos Screen.
moveToText: setFont({
...bodyText,
size: 15,
color: textColor,
weight: FontWeights.regular
}),
// Group & Photo Document title Style. Used On: Group Screen & Photos Screen
folderTitle: setFont({
...bodyText,
size: 22,
color: headingsColor,
weight: FontWeights.semiBold
}),
// Document screen Filename Text Style. Used On: Document Screen
documentTitle: setFont({
...bodyText,
color: headingsColor,
size: 17,
weight: FontWeights.semiBold
}),
// Document screen list item text style. Used On: Document screen
documentMeta: setFont({
...bodyText,
size: 13,
color: descLightTextColor,
weight: FontWeights.regular
}),
// Profile Cover photo text heading style. Used On: Cover
assignmentHeading: setFont({
size: 25,
weight: FontWeights.bold,
family: bodyText.family,
color: headingsColor
}),
// Lesson or Topic Screen Assignments heading text style
assignmentDesc: {
...setFont({
size: 13,
weight: FontWeights.regular,
family: bodyText.family,
color: descLightTextColor
}),
textAlign: "center"
},
// Lesson or Topic Screen Assignment List item text style
assignmentTitle: setFont({
...bodyText,
color: headingsColor,
size: 17,
weight: FontWeights.semiBold
}),
// Lesson or Topic Screen Assignment List item heading style
videoUploadProgressText: setFont({
...bodyText,
size: 11,
color: whiteColor,
weight: FontWeights.regular
}),
// Used for playing videos using AppWebView such as vimeo and youtube videos
webVideoPlayer: {
borderRadius: 0
},
//Used to add style to the video container of downloaded assets
localVideoContainer: {
borderRadius: 0
},
//Used to add style to the video component of downloaded assets
localVideoPlayer: {
borderRadius: 0
},
//Used for styling the View component when displaying an offline video message
offlineVideoContainer: {
borderRadius: 0
},
//Used for styling lesson button container. Used in lesson single screen
lessonActionButtonContainer: {
zIndex: 1,
paddingHorizontal: 15,
paddingVertical: 15,
borderTopWidth: StyleSheet.hairlineWidth
},
//Used for styling the complete icon. Used in lesson single screen
lessonActionCompleteIcon: {
width: 36,
height: 36
},
//Used for styling the activity indicator of action button in lesson single screen
lessonButtonLoadingIcon: {},
//Used for styling learn topic button container
learnTopicActionButtonContainer: {
zIndex: 1,
paddingHorizontal: 15,
paddingVertical: 15,
borderTopWidth: StyleSheet.hairlineWidth
},
//Used for styling the complete icon. Used in learn topic single screen
learnTopicActionCompleteIcon: {
width: 36,
height: 36
},
//Used for styling the activity indicator of action button in learn topic single screen
learnTopicButtonLoadingContainer: {},
//Used for styling action button container. Used in quiz results screen
quizResultButtonContainer: {
zIndex: 1,
paddingHorizontal: 15,
paddingVertical: 15,
borderTopWidth: StyleSheet.hairlineWidth,
marginBottom: 10
},
//Used for styling quiz start button container
quizStartButtonContainer: {
paddingTop: 16,
paddingHorizontal: 20,
backgroundColor: bodyFrontBg,
borderTopWidth: StyleSheet.hairlineWidth,
borderTopColor: "#C6C6C8"
},
//Used for styling quiz start button
quizStartButton: {
height: 40
},
//Used for styling the activity indicator of start button in quiz single screen
quizStartButtonLoading: {},
//Used for styling quiz submit button in quiz single screen
quizSubmitButton: {
flex: 1
},
//Used for styling quiz submit button container in quiz single screen
quizSubmitButtonContainer: {
flexDirection: "row",
backgroundColor: bodyFrontBg
},
//Used for styling the activity indicator of submit button in quiz single screen
quizSubmitButtonLoading: {},
//Contains the video player. Used on: Screens where the video block is used
videoBlockContainer: {
flex: 1
},
//Contains the block components. Used on: LessonSingleScreen
lessonSingleScreenBlockContainer: {
paddingTop: 5,
paddingHorizontal: 5
},
//Contains the block components. Used on: LearnTopicSingleScreen
learnTopicSingleScreenBlockContainer: {
paddingTop: 5,
paddingHorizontal: 5
},
//Contains the block components. Used on: QuizSingleScreen
quizSingleScreenBlockContainer: {
paddingHorizontal: 5
},
// progress text showing upload percentage for videos. Used On: New Activity, Comment, Topic, Reply Create screen during video upload
bottomSheetSeparator: {
height: StyleSheet.hairlineWidth,
marginLeft: GUTTER,
backgroundColor: borderColor
},
// Add photos to album option modal separator between header and body of modal style
topButton: {
borderTopRightRadius: 12,
borderTopLeftRadius: 12
},
// Add photos to album option top button style
bottomButton: {
borderBottomRightRadius: 12,
borderBottomLeftRadius: 12
},
// Add photos to album option bottom button style
bottomSheetButton: {
paddingVertical: 20,
paddingLeft: GUTTER,
alignItems: "center"
},
// Add photos to album option common button style
bottomSheetButtonText: {
fontSize: 17,
marginLeft: 12,
fontWeight: FontWeights.medium,
color: textColor
},
// Add photos to conversation title style
archiveHeadingText: {
fontSize: 15,
fontWeight: FontWeights.medium,
color: textColor
},
// Add photos to conversation icon style
archiveHeadingIcon: {
width: 20,
height: 20,
marginLeft: GUTTER + 20
},
// Notification subscription item title style
subscriptionHeadingText: {
fontSize: 15,
fontWeight: FontWeights.medium,
color: textColor
},
bottomSheetButtonText: {
fontSize: 17,
marginLeft: 12,
fontWeight: FontWeights.medium,
color: textColor
},
messageActionButton: {
fontSize: 10,
fontWeight: FontWeights.medium,
color: textIconColor
},
messageErrorMessage: {
fontSize: 10,
fontWeight: FontWeights.medium,
color: warningColor,
marginHorizontal: 5
},
messageErrorIcon: {
height: 10,
width: 10
},
messageSpinnerIcon: {
height: 10,
width: 10,
marginRight: 5
},
messageActionButtonSeparator: {
backgroundColor: borderColor,
width: 1.5,
height: 11,
marginHorizontal: 5,
opacity: 0.5
},
restrictionMessage: {
...setFont({
...bodyText,
size: calcFontSize(16),
color: descTextColor,
weight: FontWeights.medium
}),
textAlign: "center"
},
restrictionAction: {
...setFont({
...bodyText,
size: calcFontSize(16),
color: primaryColor,
weight: FontWeights.bold
}),
textAlign: "center"
},
restrictionActionIcon: {
color: descTextColor,
height: 10.5,
width: 15,
paddingHorizontal: 15
},
groupIconThreadItem: {
width: 21,
height: 21,
color: descLightTextColor,
marginRight: 5
},
//Giphy error
errorGiphy: setFont({
...bodyText,
size: 13,
color: textIconColor,
weight: FontWeights.regular
}),
// blog list item title style
blogItemTitle: setFont({
...bodyText,
size: 15,
weight: FontWeights.semiBold,
color: textColor
}),
// blog list item image style
blogItemImageStyle: {
height: 100,
width: 100,
borderRadius: 14,
overflow: "hidden",
borderColor: "rgba(0,0,0,0.08)",
borderWidth: 1
},
// blog list item author title style
blogItemAuthorText: {
...setFont({
...bodyText,
size: 13,
weight: FontWeights.regular,
color: textColor
}),
backgroundColor: "transparent",
marginTop: 8
},
// invite using link label style
inviteLinkLabel: {
...setFont({
...bodyText,
size: 18,
weight: FontWeights.bold,
color: linkColor
})
},
// used in schedule post modal
schedulePostDateGuideline: {
...setFont({
...bodyText,
size: 15,
weight: FontWeights.regular,
color: textColor
})
},
//Used in ActivityContentComment
commentDetailsContainer: {marginLeft: 10, flex: 1},
//Reaction Hint Text Style
reactionHintText: {
...setFont({
...bodyText,
size: 15,
weight: FontWeights.medium,
color: descTextColor
}),
textAlign: "center"
}
};
const globalStyles = configureGlobalStyle(externalCodeSetup)(
globalStylesDefault,
styles.colors
);
const htmlStyles = StyleSheet.create({
strong: {
...setFont({
...bodyText,
size: 14,
color: textColor,
weight: FontWeights.heavy
}),
lineHeight: Math.ceil(calcFontSize(14) * 1.31)
},
b: {
...setFont({
...bodyText,
size: 14,
color: textColor,
weight: FontWeights.heavy
}),
lineHeight: Math.ceil(calcFontSize(14) * 1.31)
},
i: {
...setFont({
...bodyText,
size: 14,
color: lightTextColor,
weight: FontWeights.regular
}),
lineHeight: Math.ceil(calcFontSize(14) * 1.31)
},
a: {
...setFont({
...bodyText,
size: 14,
color: linkColor,
weight: FontWeights.regular
}),
lineHeight: Math.ceil(calcFontSize(14) * 1.31)
},
p: {
...setFont({
...bodyText,
size: 14,
color: lightTextColor,
weight: FontWeights.regular
}),
lineHeight: Math.ceil(calcFontSize(14) * 1.31)
},
h1: {
...setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.heavy,
headingTag: "h1"
}),
marginBottom: 23
},
h2: {
...setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.bold,
headingTag: "h2"
}),
marginBottom: 23
},
h3: {
...setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.semiBold,
headingTag: "h3"
}),
marginBottom: 22
},
h4: {
...setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.medium,
headingTag: "h4"
}),
marginBottom: 22
},
h5: {
...setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.regular,
headingTag: "h5"
}),
marginBottom: 23
},
h6: {
...setHeadingFont({
color: headingsColor,
size: BASE_HEADING_SIZE,
weight: FontWeights.light,
headingTag: "h6"
}),
marginBottom: 23
},
ul: {
...setFont({
...bodyText,
size: 16,
color: shadeColor(textColor, 0.5),
weight: FontWeights.regular
}),
lineHeight: Math.ceil(calcFontSize(16) * 1.31),
marginBottom: 20
},
ol: {
...setFont({
...bodyText,
size: 14,
color: shadeColor(textColor, 0.5),
weight: FontWeights.regular
}),
lineHeight: Math.ceil(calcFontSize(14) * 1.31),
marginBottom: 20
},
li: {
...setFont({
...bodyText,
size: 14,
color: textColor,
weight: FontWeights.regular
}),
lineHeight: Math.ceil(calcFontSize(14) * 1.31)
},
pre: {
...setFont({
...bodyText,
size: 16,
color: textColor,
weight: FontWeights.regular
}),
marginBottom: 20
}
});
const htmlAdjustedCss =
`\n
body {
font-size: ` +
calcFontSize(16) +
`px;
line-height: 1.44;
}`;
const htmlContentCss = `\n
body, p {
font-size: ${calcFontSize(16)}px;
color: ${textColor};
line-height: 1.47;
}
`;
const htmlCourseMaterials =
`\n
a {
text-decoration: none;
font-size: ` +
calcFontSize(15) +
`px;
display: block;
border-bottom-color: ` +
borderColor +
`;
border-bottom-style: solid;
border-bottom-width: ` +
StyleSheet.hairlineWidth +
`px;
padding: 14px 32px 14px 0;
}
body {
margin-bottom: -4px;
}
iframe {
display: none !important;
}
`;
const tagsStyles = {
p: {
color: textColor,
marginBottom: 8
},
a: {
color: linkColor,
textDecorationLine: "none"
},
blockquote: {
whiteSpace: "pre-wrap",
borderLeftWidth: 3,
borderColor: borderColor,
margin: 5,
paddingTop: 5,
paddingLeft: 8
}
};
const baseFontStyle = size =>
setFont({
...bodyText,
size: size === "regular" ? 16 : size,
weight: FontWeights.regular,
color: textColor
});
const classesStyles = {
"activity-discussion-title-wrap": {
...globalStyles.boldText,
fontSize: globalStyles.regularText.fontSize,
padding: 16,
paddingHorizontal: 16,
paddingBottom: 8,
marginBottom: 0,
borderTopLeftRadius: 8,
borderTopRightRadius: 8
},
"bb-reply-lable": {
color: descLightTextColor,
fontWeight: "400"
},
"bb-content-inr-wrap": {
padding: 16,
paddingTop: 0,
marginBottom: -12
},
"bb-post-title": {
...globalStyles.boldText,
fontSize: globalStyles.regularText.fontSize,
color: textColor
},
"bb-content-wrp": {
padding: 16
},
"gamipress-points-award": {
flexDirection: "row",
flexWrap: "wrap",
justifyContent: "center",
alignItems: "center"
},
"user-has-earned": {
padding: 16,
borderRadius: 5,
backgroundColor: bodyFrontBg,
borderWidth: StyleSheet.hairlineWidth,
borderColor: borderColor
},
"wp-post-image": {
width: 50,
height: 50
},
"gamipress-points-type-image": {
width: 50,
marginRight: 15
},
"gamipress-points-type-description": {
flex: 1,
lineHeight: Math.ceil(globalStyles.regularText.fontSize * 1.17),
...globalStyles.regularText.fontSize
}
};
const htmlActivityStylesCss = `
body {
color: ${textColor};
}
p, table {
color: ${textColor};
}
`;
const htmlStylesCss =
normalize +
`\n
${generateAssetsFontCss(bodyText.family)}
\n
body {
font-size: ` +
calcFontSize(16) +
`px;
/*line-height: ` +
Math.ceil(calcFontSize(14) * 1.31) +
`px;*/
color: ` +
textColor +
`;overflow: hidden;
background-color: ` +
bodyFrontBg +
`;
}
p, table {
color: ` +
descTextColor +
`;
margin: 0 0 12px;
}
p br {
line-height: 20px;
}
.wp-video {
max-width: 100%;
height: auto;
}
figure {
vertical-align: bottom;
margin: 0;
margin-bottom: 12px;
}
img {
max-width: 100%;
width: auto !important;
height: auto !important;
vertical-align: bottom;
margin-bottom: 12px;
}
img.alignright {
margin: 12px 0 12px 24px;
}
img.alignleft {
margin: 12px 24px 12px 0;
}
img.aligncenter {
margin-top: 12px;
margin-bottom: 12px;
}
.alignright {
float: right;
}
.alignleft {
float: left;
}
.aligncenter {
display: block;
margin-left: auto;
margin-right: auto;
}
.wp-caption-text {
font-size: ` +
calcFontSize(12) +
`px;
color: ` +
descTextColor +
`;
margin: 0;
}
.wp-caption {
margin-bottom: 1.14em;
max-width: 100%;
}
.wp-caption img {
margin-bottom: 0;
}
strong {
font-weight: "800";
color: ${textColor}
}
b {
font-weight: "800";
color: ${textColor}
}
i {
color: ` +
textColor +
` ;
}
a {
color: ` +
linkColor +
`;
}
pre {
margin-bottom: 12px;
font-size: ` +
calcFontSize(12) +
`px;
max-width: 100%;
white-space: pre-wrap; /* css-3 */
white-space: -moz-pre-wrap; /* Mozilla, since 1999 */
white-space: -pre-wrap; /* Opera 4-6 */
white-space: -o-pre-wrap; /* Opera 7 */
word-wrap: break-word; /* Internet Explorer 5.5+ */
}
h1, h2, h3, h4, h5, h6 {
margin-top: 0;
}
h1 {
font-size: ` +
calcHeadingFontSize("h1") +
`px;
color: ` +
textColor +
`;
margin-bottom: 23px;
}
h2 {
font-size: ` +
calcHeadingFontSize("h2") +
`px;
color: ` +
textColor +
`;
margin-bottom: 23px;
}
h3 {
font-size: ` +
calcHeadingFontSize("h3") +
`px;
color: ` +
textColor +
`;
margin-bottom: 22px;
}
h4 {
font-size: ` +
calcHeadingFontSize("h4") +
`px;
color: ` +
textColor +
`;
margin-bottom: 22px;
}
h5 {
font-size: ` +
calcHeadingFontSize("h5") +
`px;
color: ` +
textColor +
`;
margin-bottom: 23px;
}
h6 {
font-size: ` +
calcHeadingFontSize("h6") +
`px;
color: ` +
textColor +
`;
margin-bottom: 23px;
}
ol, ul {
margin-bottom: 20px;
margin-left: 20px;
}
li {
color: ` +
textColor +
`;
}
iframe.wp-embedded-content {
display: none;
}
blockquote.wp-embedded-content {
padding: 0;
margin: 0;
}
blockquote:not(.wp-embedded-content) {
position: relative;
margin-left: 0;
padding-left: 30px;
}
blockquote:not(.wp-embedded-content):before {
content: "“";
font-size: 60px;
color: ` +
borderColor +
`;
position: absolute;
top: 20px;
left: 0;
}
blockquote p {
margin-bottom: 0;
}
cite {
text-style: normal;
}
cite a {
color: ` +
descLightTextColor +
`;
text-decoration: none;
text-style: normal;
}
table {
border-collapse: collapse;
border-spacing: 0;
}
th, td {
text-align: left;
padding-left: 10px;
padding-right: 10px;
border-bottom: 1px solid ` +
borderColor +
`;
}
th {
padding-top: 10px;
padding-bottom: 9px;
background-color: ` +
bodyBg +
`;
color: ` +
descLightTextColor +
`;
}
td {
padding-top: 15px;
padding-bottom: 15px;
}
input[type="text"] {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
font-size: ` +
calcFontSize(16) +
`px;
box-sizing: border-box;
padding-left: 10px;
padding-right: 10px;
height: 36px;
border-radius: 3px;
border: 1px solid ` +
borderColor +
`;
-webkit-box-shadow: none;
-moz-box-shadow: none;
box-shadow: none;
outline: none;
}
.learner-app-show {
display: block !important;
}
.learner-app-hide {
display: none !important;
}
.app-quiz-shortcode {
font-family: "Sofia";
}
.app-quiz-shortcode h3 {
font-size: 13px;
text-transform: uppercase;
height: 48px;
background-color: ` +
bodyBg +
`;
color: ` +
headingsColor +
`;
letter-spacing: 0.7px;
padding-left: 16px;
padding-top: 14px;
padding-bottom: 14px;
box-sizing: border-box;
margin-bottom: 0;
}
.app-quiz-shortcode a {
border-bottom: 1px solid ` +
borderColor +
`;
height: 48px;
padding-left: 14px;
font-size: 15px;
text-decoration: none;
color: ` +
headingsColor +
`;
padding-top: 14px;
padding-bottom: 14px;
box-sizing: border-box;
display: block;
}
`;
const formStyles = StyleSheet.create({
selectField: {
flexDirection: "row",
alignItems: "center"
},
label: {
marginRight: 10
},
selectIcon: {
marginRight: 15,
width: 17,
height: 17
},
forumIcon: {
marginRight: 15,
width: 17,
height: 16
},
spreadInput: {
marginBottom: 0,
borderBottomWidth: 0
},
formInputWrap: {
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth
},
noPadding: {
paddingLeft: 0,
paddingRight: 0
},
fieldsGroup: {
flexShrink: 1,
flexGrow: 0,
backgroundColor: shadeColor("#EDEEF2", 0.32),
paddingLeft: 16,
paddingRight: 16
},
tagsContainer: {
minHeight: 24,
backgroundColor: secondaryButtonBg,
paddingHorizontal: 8,
borderRadius: 20
},
tags: {
width: 16,
height: 16,
marginRight: 10
},
input: {
flexDirection: "row",
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth,
alignItems: "center",
height: 45
},
border: {
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth
},
tagsInput: {
justifyContent: "flex-start",
alignItems: "flex-start",
paddingTop: 3,
paddingBottom: 0,
height: "auto"
},
checkInput: {
justifyContent: "space-between",
borderBottomWidth: 0,
height: 60
},
icon: {tintColor: textIconColor},
iconButton: {
width: 22,
height: 22,
marginRight: 10
},
preview: {
width: 30,
height: 30,
marginLeft: 15,
alignItems: "center",
justifyContent: "center",
resizeMode: "contain"
},
checkLabel: setFont({
...bodyText,
size: 15,
color: lightTextColor,
weight: FontWeights.regular
}),
footerButton: {
height: 47,
backgroundColor: secondaryButtonBg
},
footerButtonFixed: {
position: "absolute",
left: 0,
bottom: 0,
width: "100%"
},
buttonText: setFont({
...bodyText,
size: 16,
color: secondaryButtonColor,
weight: FontWeights.regular
}),
pickerLabel: {
...setFont({
...bodyText,
size: 17,
color: descLightTextColor,
weight: FontWeights.regular
}),
marginRight: 10
},
picker: setFont({
...bodyText,
size: 15,
color: linkColor,
weight: FontWeights.regular
}),
selectorLabel: {
...setFont({
...bodyText,
size: 13,
color: descLightTextColor,
weight: FontWeights.regular
}),
marginBottom: 8
},
advancedSelector: {
paddingTop: 18,
paddingBottom: 20,
borderBottomColor: borderColor,
borderBottomWidth: StyleSheet.hairlineWidth
},
mergeWarning: setFont({
...bodyText,
size: 13,
color: descLightTextColor,
weight: FontWeights.regular
}),
mergeWarningIcon: {
width: 15,
height: 15,
marginRight: 6
}
});
const cssApiHooks = getExternalCodeSetup().cssApi;
return {
calcFontSize,
global: globalStyles,
_globalStyles: globalStyles, // to avoid conflicts with reanimated 3
htmlStyles,
classesStyles,
htmlStylesCss,
tagsStyles,
htmlActivityStylesCss,
baseFontStyle,
htmlAdjustedCss,
htmlContentCss: cssApiHooks.filterContentCss(htmlContentCss, typography),
htmlCourseMaterials,
formStyles,
typography,
colors: {
...styles.colors,
...localColors,
...derivedColors,
...customColors,
...indicatorColors,
authInputColors
}
};
};
export const globalStyle = memoize(styles => buildGlobalStyles(styles), {
max: 1
});
Global CSS Styles
Global CSS Styles are styles used throughout the app across the app's screens and components. You can overwrite anyone of these styles in your code to change the look of the app.