@oxyhq/services
Version:
181 lines (173 loc) • 7.22 kB
JavaScript
"use strict";
import React, { useState, useCallback } from 'react';
import { View, StyleSheet, ScrollView, Linking } from 'react-native';
import { toast } from '../../lib/sonner';
import { Header, Section, GroupedSection, LoadingState } from "../components/index.js";
import { useI18n } from "../hooks/useI18n.js";
import { useThemeStyles } from "../hooks/useThemeStyles.js";
import { useColorScheme } from "../hooks/useColorScheme.js";
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
const LegalDocumentsScreen = ({
onClose,
theme,
goBack,
initialStep
}) => {
const {
t
} = useI18n();
const [loading, setLoading] = useState(false);
const colorScheme = useColorScheme();
const themeStyles = useThemeStyles(theme || 'light', colorScheme);
// Policy URLs from Oxy Transparency Center
const POLICY_URLS = {
privacy: 'https://oxy.so/company/transparency/policies/privacy',
terms: 'https://oxy.so/company/transparency/policies/terms-of-service',
community: 'https://oxy.so/company/transparency/policies/community-guidelines',
dataRetention: 'https://oxy.so/company/transparency/policies/data-retention',
contentModeration: 'https://oxy.so/company/transparency/policies/content-moderation',
childSafety: 'https://oxy.so/company/transparency/policies/child-safety',
cookie: 'https://oxy.so/company/transparency/policies/cookies'
};
// Determine which document to show based on initialStep
const documentType = initialStep === 1 ? 'privacy' : initialStep === 2 ? 'terms' : initialStep === 3 ? 'community' : initialStep === 4 ? 'dataRetention' : initialStep === 5 ? 'contentModeration' : initialStep === 6 ? 'childSafety' : initialStep === 7 ? 'cookie' : null;
// Generic handler to open any policy URL
const handleOpenPolicy = useCallback(policyKey => {
return async () => {
try {
setLoading(true);
const url = POLICY_URLS[policyKey];
const canOpen = await Linking.canOpenURL(url);
if (canOpen) {
await Linking.openURL(url);
} else {
toast.error(t('legal.openError') || 'Failed to open document');
}
} catch (error) {
if (__DEV__) {
console.error(`Failed to open ${policyKey} policy:`, error);
}
toast.error(t('legal.openError') || 'Failed to open document');
} finally {
setLoading(false);
}
};
}, [t]);
// If a specific document type is requested, open it directly
React.useEffect(() => {
if (documentType) {
handleOpenPolicy(documentType)();
}
}, [documentType, handleOpenPolicy]);
// Get policy title for display
const getPolicyTitle = key => {
const titles = {
privacy: t('legal.privacyPolicy.title') || 'Privacy Policy',
terms: t('legal.termsOfService.title') || 'Terms of Service',
community: t('legal.communityGuidelines.title') || 'Community Guidelines',
dataRetention: t('legal.dataRetention.title') || 'Data Retention Policy',
contentModeration: t('legal.contentModeration.title') || 'Content Moderation Policy',
childSafety: t('legal.childSafety.title') || 'Child Safety Policy',
cookie: t('legal.cookiePolicy.title') || 'Cookie Policy'
};
return titles[key] || 'Document';
};
// If a specific document type is requested, show loading state while opening
if (documentType) {
return /*#__PURE__*/_jsxs(View, {
style: [styles.container, {
backgroundColor: themeStyles.backgroundColor
}],
children: [/*#__PURE__*/_jsx(Header, {
title: getPolicyTitle(documentType),
onBack: goBack || onClose,
variant: "minimal",
elevation: "subtle"
}), /*#__PURE__*/_jsx(LoadingState, {
message: t('legal.opening') || 'Opening document...',
color: themeStyles.textColor
})]
});
}
// Default: show both options
return /*#__PURE__*/_jsxs(View, {
style: [styles.container, {
backgroundColor: themeStyles.backgroundColor
}],
children: [/*#__PURE__*/_jsx(Header, {
title: t('legal.title') || 'Legal Documents',
onBack: goBack || onClose,
variant: "minimal",
elevation: "subtle"
}), /*#__PURE__*/_jsx(ScrollView, {
style: styles.content,
children: /*#__PURE__*/_jsx(Section, {
title: t('legal.policies') || 'Policies & Guidelines',
isFirst: true,
children: /*#__PURE__*/_jsx(GroupedSection, {
items: [{
id: 'privacy-policy',
icon: 'shield-check',
iconColor: themeStyles.colors.iconPersonalInfo,
title: t('legal.privacyPolicy.title') || 'Privacy Policy',
subtitle: t('legal.privacyPolicy.subtitle') || 'How we handle your data',
onPress: handleOpenPolicy('privacy')
}, {
id: 'terms-of-service',
icon: 'file-document',
iconColor: themeStyles.colors.iconSecurity,
title: t('legal.termsOfService.title') || 'Terms of Service',
subtitle: t('legal.termsOfService.subtitle') || 'Terms and conditions of use',
onPress: handleOpenPolicy('terms')
}, {
id: 'community-guidelines',
icon: 'account-group',
iconColor: themeStyles.colors.iconData,
title: t('legal.communityGuidelines.title') || 'Community Guidelines',
subtitle: t('legal.communityGuidelines.subtitle') || 'Rules and expectations for our community',
onPress: handleOpenPolicy('community')
}, {
id: 'data-retention',
icon: 'clock',
iconColor: themeStyles.colors.iconStorage,
title: t('legal.dataRetention.title') || 'Data Retention Policy',
subtitle: t('legal.dataRetention.subtitle') || 'How long we keep your data',
onPress: handleOpenPolicy('dataRetention')
}, {
id: 'content-moderation',
icon: 'eye',
iconColor: themeStyles.colors.iconSharing,
title: t('legal.contentModeration.title') || 'Content Moderation Policy',
subtitle: t('legal.contentModeration.subtitle') || 'How we moderate content',
onPress: handleOpenPolicy('contentModeration')
}, {
id: 'child-safety',
icon: 'heart',
iconColor: '#FF2D55',
title: t('legal.childSafety.title') || 'Child Safety Policy',
subtitle: t('legal.childSafety.subtitle') || 'Protecting minors on our platform',
onPress: handleOpenPolicy('childSafety')
}, {
id: 'cookie-policy',
icon: 'cookie',
iconColor: '#8E8E93',
title: t('legal.cookiePolicy.title') || 'Cookie Policy',
subtitle: t('legal.cookiePolicy.subtitle') || 'How we use cookies and similar technologies',
onPress: handleOpenPolicy('cookie')
}]
})
})
})]
});
};
const styles = StyleSheet.create({
container: {
flex: 1
},
content: {
flex: 1,
padding: 16
}
});
export default /*#__PURE__*/React.memo(LegalDocumentsScreen);
//# sourceMappingURL=LegalDocumentsScreen.js.map