Merge pull request #26 from gustavo-em/link_demo_server
Implementing link to demo portal when you don't have any portal added
This commit is contained in:
commit
f055fcb0a3
@ -22,6 +22,8 @@ import {IHandles} from 'react-native-modalize/lib/options';
|
||||
import {IItem, IItemDelete, IListPortalsDTO} from './types';
|
||||
import i18next from 'i18next';
|
||||
import {initTranslation} from '../../translations/index';
|
||||
import { TouchableOpacity } from 'react-native';
|
||||
import { new_portal_name_and_url } from '../utils/new_portal_name_and_url';
|
||||
|
||||
export const ListPortals = ({navigation}: IListPortalsDTO) => {
|
||||
initTranslation();
|
||||
@ -78,6 +80,20 @@ export const ListPortals = ({navigation}: IListPortalsDTO) => {
|
||||
};
|
||||
|
||||
const onPress = (namePortal: string) => navigation.navigate(namePortal);
|
||||
|
||||
const onPressTextCreateDemoServer = async ()=>{
|
||||
const nameDemoServer = "Demo Server";
|
||||
const urlDemoServer = "https://bigbluebutton.org"
|
||||
|
||||
const createDemoServerOrError = await new_portal_name_and_url(nameDemoServer, urlDemoServer)
|
||||
console.log(createDemoServerOrError)
|
||||
if(createDemoServerOrError){
|
||||
setPortals(createDemoServerOrError);
|
||||
navigation.navigate(nameDemoServer);
|
||||
} else {
|
||||
console.log("error when go create demo server")
|
||||
}
|
||||
}
|
||||
|
||||
const Item = ({namePortal, url}: IItem) => (
|
||||
<WrapperItemListText onPress={() => onPress(namePortal)}>
|
||||
@ -144,9 +160,16 @@ export const ListPortals = ({navigation}: IListPortalsDTO) => {
|
||||
}}
|
||||
/>
|
||||
) : (
|
||||
<TextWithoutPortal>
|
||||
{i18next.t('mobileApp.portals.list.empty.label')}
|
||||
</TextWithoutPortal>
|
||||
<>
|
||||
<TextWithoutPortal>
|
||||
{i18next.t('mobileApp.portals.list.empty.addFirstPortal.label')}
|
||||
</TextWithoutPortal>
|
||||
<TouchableOpacity onPress={()=>onPressTextCreateDemoServer()}>
|
||||
<TextWithoutPortal color={true}>
|
||||
{i18next.t('mobileApp.portals.list.empty.orUseOurDemoServer.label')}
|
||||
</TextWithoutPortal>
|
||||
</TouchableOpacity>
|
||||
</>
|
||||
)}
|
||||
</WrapperListContainer>
|
||||
);
|
||||
|
@ -85,9 +85,9 @@ export const TextButtonOpen = styled.Text`
|
||||
|
||||
|
||||
export const TextWithoutPortal = styled.Text`
|
||||
color: ${colors.primary};
|
||||
color: ${(props)=> (props.color ? colors.primary_light: colors.primary)};
|
||||
font-size: 20px;
|
||||
|
||||
text-align: center;
|
||||
`
|
||||
|
||||
export const ButtonDelete = styled.TouchableOpacity`
|
||||
|
@ -15,6 +15,7 @@ import {IStore} from './types';
|
||||
import {initTranslation} from '../../translations/index';
|
||||
import i18next from 'i18next';
|
||||
import { BigBlueButtonMobile } from 'bigbluebutton-mobile-sdk';
|
||||
import { new_portal_name_and_url } from '../utils/new_portal_name_and_url';
|
||||
|
||||
export const StorePortals = ({navigation, modalizeRef}: IStore) => {
|
||||
initTranslation();
|
||||
@ -26,15 +27,15 @@ export const StorePortals = ({navigation, modalizeRef}: IStore) => {
|
||||
const [urlInvalid, setUrlInvalid] = React.useState(false);
|
||||
const [loadComponent, setLoadComponent] = React.useState(false);
|
||||
|
||||
async function newPortal(name: string, url: string) {
|
||||
let portalsStorage;
|
||||
portalsStorage = await AsyncStorage.getItem('portal');
|
||||
portalsStorage = portalsStorage ? JSON.parse(portalsStorage) : null;
|
||||
portalsStorage.push({name, url});
|
||||
AsyncStorage.setItem('portal', JSON.stringify(portalsStorage));
|
||||
setPortals(portalsStorage);
|
||||
modalizeRef?.current?.close();
|
||||
navigation.navigate(name);
|
||||
async function afterValidationsToCreatePortalAddANew(name: string, url: string) {
|
||||
const objPortalsOrError = await new_portal_name_and_url(name, url )
|
||||
if(objPortalsOrError){
|
||||
setPortals(objPortalsOrError);
|
||||
modalizeRef?.current?.close();
|
||||
navigation.navigate(name);
|
||||
} else {
|
||||
return Error("Error to create a new portal")
|
||||
}
|
||||
}
|
||||
|
||||
const validateAndCreateNewPortal = async ()=>{
|
||||
@ -50,11 +51,11 @@ export const StorePortals = ({navigation, modalizeRef}: IStore) => {
|
||||
setNameAlreadyUsed(true);
|
||||
return false;
|
||||
}
|
||||
await newPortal(name, url);
|
||||
await afterValidationsToCreatePortalAddANew(name, url);
|
||||
} catch (e) {
|
||||
console.log('error', e);
|
||||
await AsyncStorage.setItem('portal', JSON.stringify([]));
|
||||
newPortal(name, url);
|
||||
afterValidationsToCreatePortalAddANew(name, url);
|
||||
return null;
|
||||
}
|
||||
}
|
||||
@ -146,9 +147,7 @@ export const StorePortals = ({navigation, modalizeRef}: IStore) => {
|
||||
autoCorrect={false}
|
||||
value={url}
|
||||
onChangeText={(e: any) => setUrl(e)}
|
||||
placeholder={i18next.t(
|
||||
'mobileApp.portals.fields.url.placeholder',
|
||||
)}
|
||||
placeholder={"https://demo.bigbluebutton.org"}
|
||||
label={i18next.t('mobileApp.portals.fields.url.label')}
|
||||
/>
|
||||
</WrapperInput>
|
||||
|
15
react-native/app/pages/utils/new_portal_name_and_url.ts
Normal file
15
react-native/app/pages/utils/new_portal_name_and_url.ts
Normal file
@ -0,0 +1,15 @@
|
||||
import AsyncStorage from "@react-native-async-storage/async-storage";
|
||||
import { usePortal } from "../../contexts/portals/hook";
|
||||
|
||||
export async function new_portal_name_and_url(name: string, url: string): Promise<object | Error> {
|
||||
try{
|
||||
let portalsStorage;
|
||||
portalsStorage = await AsyncStorage.getItem('portal');
|
||||
portalsStorage = portalsStorage ? JSON.parse(portalsStorage) : null;
|
||||
portalsStorage.push({name, url});
|
||||
AsyncStorage.setItem('portal', JSON.stringify(portalsStorage));
|
||||
return portalsStorage
|
||||
} catch(error){
|
||||
return Error("Error when try create a new portal")
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user