@oxyhq/services
Version:
168 lines (166 loc) • 5.93 kB
JavaScript
"use strict";
import React, { useState, useEffect } from 'react';
import { View, Text, TouchableOpacity, StyleSheet, ScrollView } from 'react-native';
import { toast } from '../../lib/sonner';
import { Header, Section, GroupedSection, LoadingState, EmptyState } from "../components/index.js";
import { useI18n } from "../hooks/useI18n.js";
import { useThemeStyles } from "../hooks/useThemeStyles.js";
import { useColorScheme } from "../hooks/useColorScheme.js";
import { useOxy } from "../context/OxyContext.js";
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
const SavesCollectionsScreen = ({
onClose,
theme,
goBack
}) => {
// Use useOxy() hook for OxyContext values
const {
oxyServices,
user
} = useOxy();
const {
t
} = useI18n();
const [savedItems, setSavedItems] = useState([]);
const [collections, setCollections] = useState([]);
const [isLoading, setIsLoading] = useState(true);
const [activeTab, setActiveTab] = useState('saves');
const colorScheme = useColorScheme();
const themeStyles = useThemeStyles(theme || 'light', colorScheme);
const tabActiveColor = themeStyles.colors.iconSecurity;
const tabInactiveColor = themeStyles.isDarkTheme ? '#888888' : '#666666';
// Load saved items and collections from API
useEffect(() => {
const loadData = async () => {
try {
setIsLoading(true);
if (user?.id && oxyServices) {
const [saved, cols] = await Promise.all([oxyServices.getSavedItems(user.id), oxyServices.getCollections(user.id)]);
setSavedItems(saved.map(item => ({
id: item.id,
title: item.title,
type: item.itemType === 'post' ? 'post' : 'collection',
savedAt: new Date(item.createdAt),
url: item.url
})));
setCollections(cols.map(col => ({
id: col.id,
name: col.name,
description: col.description,
itemCount: col.itemCount,
createdAt: col.createdAt ? new Date(col.createdAt) : undefined
})));
}
} catch (error) {
toast.error(t('saves.loadError') || 'Failed to load saved items');
} finally {
setIsLoading(false);
}
};
loadData();
}, [user?.id, oxyServices, t]);
const formatDate = date => {
return date.toLocaleDateString();
};
return /*#__PURE__*/_jsxs(View, {
style: [styles.container, {
backgroundColor: themeStyles.backgroundColor
}],
children: [/*#__PURE__*/_jsx(Header, {
title: t('saves.title') || 'Saves & Collections',
onBack: goBack || onClose,
variant: "minimal",
elevation: "subtle"
}), /*#__PURE__*/_jsxs(View, {
style: [styles.tabs, {
borderBottomColor: themeStyles.borderColor
}],
children: [/*#__PURE__*/_jsx(TouchableOpacity, {
style: [styles.tab, activeTab === 'saves' && {
borderBottomColor: tabActiveColor
}],
onPress: () => setActiveTab('saves'),
children: /*#__PURE__*/_jsx(Text, {
style: [styles.tabText, {
color: activeTab === 'saves' ? tabActiveColor : tabInactiveColor,
fontWeight: activeTab === 'saves' ? '600' : '400'
}],
children: t('saves.tabs.saves') || 'Saves'
})
}), /*#__PURE__*/_jsx(TouchableOpacity, {
style: [styles.tab, activeTab === 'collections' && {
borderBottomColor: tabActiveColor
}],
onPress: () => setActiveTab('collections'),
children: /*#__PURE__*/_jsx(Text, {
style: [styles.tabText, {
color: activeTab === 'collections' ? tabActiveColor : tabInactiveColor,
fontWeight: activeTab === 'collections' ? '600' : '400'
}],
children: t('saves.tabs.collections') || 'Collections'
})
})]
}), /*#__PURE__*/_jsx(ScrollView, {
style: styles.content,
children: isLoading ? /*#__PURE__*/_jsx(LoadingState, {
message: t('saves.loading') || 'Loading...',
color: themeStyles.textColor
}) : activeTab === 'saves' ? savedItems.length === 0 ? /*#__PURE__*/_jsx(EmptyState, {
message: t('saves.empty') || 'No saved items yet',
textColor: themeStyles.textColor
}) : /*#__PURE__*/_jsx(Section, {
title: t('saves.savedItems') || 'Saved Items',
isFirst: true,
children: /*#__PURE__*/_jsx(GroupedSection, {
items: savedItems.map(item => ({
id: item.id,
icon: item.type === 'post' ? 'document-text' : 'folder',
iconColor: item.type === 'post' ? themeStyles.colors.iconSecurity : themeStyles.colors.iconStorage,
title: item.title,
subtitle: formatDate(item.savedAt)
}))
})
}) : collections.length === 0 ? /*#__PURE__*/_jsx(EmptyState, {
message: t('saves.noCollections') || 'No collections yet',
textColor: themeStyles.textColor
}) : /*#__PURE__*/_jsx(Section, {
title: t('saves.collections') || 'Collections',
isFirst: true,
children: /*#__PURE__*/_jsx(GroupedSection, {
items: collections.map(collection => ({
id: collection.id,
icon: 'folder',
iconColor: themeStyles.colors.iconStorage,
title: collection.name,
subtitle: `${collection.itemCount || 0} items`
}))
})
})
})]
});
};
const styles = StyleSheet.create({
container: {
flex: 1
},
tabs: {
flexDirection: 'row',
borderBottomWidth: 1
},
tab: {
flex: 1,
paddingVertical: 16,
alignItems: 'center',
borderBottomWidth: 2,
borderBottomColor: 'transparent'
},
tabText: {
fontSize: 16
},
content: {
flex: 1,
padding: 16
}
});
export default /*#__PURE__*/React.memo(SavesCollectionsScreen);
//# sourceMappingURL=SavesCollectionsScreen.js.map