Skip to content

Commit

Permalink
fs / ipfs work
Browse files Browse the repository at this point in the history
  • Loading branch information
TheUltDev committed Aug 17, 2024
1 parent 9d72b25 commit 1cc97e1
Show file tree
Hide file tree
Showing 94 changed files with 7,916 additions and 1,281 deletions.
95 changes: 95 additions & 0 deletions .github/workflows/tauri.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
name: Tauri Workflow Release Process

on:
workflow_dispatch:
inputs:
app-slug:
type: string
description: Slug of the application
required: true

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

env:
CN_APP_SLUG: ${{ github.event.inputs.app-slug }}

jobs:
draft:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4

- name: create draft release
uses: crabnebula-dev/cloud-release@v0.2.0
with:
command: release draft ${{ env.CN_APP_SLUG }} --framework tauri
api-key: ${{ secrets.CN_API_KEY }}

build:
needs: draft

strategy:
fail-fast: false
matrix:
os: [ubuntu-latest, macos-latest, windows-latest]

runs-on: ${{ matrix.os }}

steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
- name: Install stable toolchain
uses: actions-rust-lang/setup-rust-toolchain@v1
with:
toolchain: stable
cache: true

- name: install Linux dependencies
if: matrix.os == 'ubuntu-latest'
run: |
sudo apt-get update
sudo apt-get install -y webkit2gtk-4.0
- name: Install x86_64-apple-darwin for mac and build Tauri binaries
if: matrix.os == 'macos-latest'
run: |
rustup target add x86_64-apple-darwin
npm ci
npm run tauri build -- --target x86_64-apple-darwin
npm run tauri build -- --target aarch64-apple-darwin
env:
TAURI_PRIVATE_KEY: ${{ secrets.TAURI_PRIVATE_KEY }}
TAURI_KEY_PASSWORD: ${{ secrets.TAURI_KEY_PASSWORD }}

- name: build Tauri app for Windows, Linux
if: matrix.os != 'macos-latest'
run: |
npm ci
npm run tauri build
env:
TAURI_PRIVATE_KEY: ${{ secrets.TAURI_PRIVATE_KEY }}
TAURI_KEY_PASSWORD: ${{ secrets.TAURI_KEY_PASSWORD }}

- name: upload assets
uses: crabnebula-dev/cloud-release@v0.2.0
with:
command: release upload ${{ env.CN_APP_SLUG }} --framework tauri
api-key: ${{ secrets.CN_API_KEY }}
path: ./src-tauri

publish:
needs: build

runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4

- name: publish release
uses: crabnebula-dev/cloud-release@v0.2.0
with:
command: release publish ${{ env.CN_APP_SLUG }} --framework tauri
api-key: ${{ secrets.CN_API_KEY }}
5 changes: 5 additions & 0 deletions client/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,8 @@
"@evolu/common-web": "^8.1.1",
"@evolu/react": "^8.1.0",
"@evolu/react-native": "^11.0.0",
"@filebase/sdk": "^1.0.4",
"@helia/verified-fetch": "^1.5.0",
"@lingui/core": "^4.11.2",
"@lingui/macro": "^4.11.2",
"@lingui/react": "^4.11.2",
Expand All @@ -53,8 +55,10 @@
"burnt": "^0.12.2",
"design": "workspace:react-exo-ui@*",
"effect": "^3.5.7",
"file-type": "^19.4.1",
"maplibre-gl": "^4.5.0",
"openmeteo": "^1.1.4",
"pinata": "^0.2.0",
"react": "18.2.0",
"react-dom": "18.2.0",
"react-exo": "workspace:*",
Expand All @@ -69,6 +73,7 @@
"react-native-macos": "^0.73.34",
"react-native-mmkv": "^2.12.2",
"react-native-navigation": "7.40.1",
"react-native-readium": "^2.0.0-rc.2",
"react-native-reanimated": "^3.14.0",
"react-native-screens": "^3.32.0",
"react-native-skottie": "^2.1.4",
Expand Down
11 changes: 9 additions & 2 deletions client/src/app/hooks/useCurrentResource.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,11 @@
import {useState, useEffect} from 'react';
import {useLocation} from 'react-exo/navigation';
import {useLocation, useNavigate} from 'react-exo/navigation';

export function useCurrentResource() {
const {pathname, hash} = useLocation();
const [path, setPath] = useState(hash ? `${pathname}/${hash?.slice(1)}` : '');
const [maximized, setMaximized] = useState(true);
const navigate = useNavigate();

useEffect(() => {
if (hash) {
Expand All @@ -18,5 +19,11 @@ export function useCurrentResource() {
}
}, [pathname, hash, path]);

return {path, maximized, setPath, setMaximized};
const close = () => {
setMaximized(false);
setPath('');
navigate(pathname);
};

return {path, maximized, close};
}
Original file line number Diff line number Diff line change
Expand Up @@ -6,14 +6,15 @@ import {useDeviceSession} from 'app/hooks/useDeviceSession';
import {useProfile} from 'app/data';
import {Menu} from 'app/interface/Menu';
import {Tabs} from 'app/interface/Tabs';
import {resolve} from 'media/utils/path';
import {CurrentFile} from 'media/stacks/CurrentFile';

import type {useAppContext} from 'app/hooks/useAppContext';

export const APP_MENU_WIDTH = 146;
export const APP_MENU_TAB_HEIGHT = 64;

export default function MainLayout() {
export default function Layout() {
const {styles, theme} = useStyles(stylesheet);
const resource = useCurrentResource();
const screen = useWindowDimensions();
Expand All @@ -33,6 +34,12 @@ export default function MainLayout() {
device,
};

const parts = resolve(resource.path);
const [name, ext] = parts.slice(-1)[0].split('.') ?? [];
const base = parts.slice(0, -1).join('/');
const path = parts.join('/');
const url = `/browse/${base}#${name}.${ext}`;

return <>
<StatusBar networkActivityIndicatorVisible={!device?.online}/>
<View style={vstyles.root}>
Expand All @@ -41,12 +48,15 @@ export default function MainLayout() {
</View>
<View style={vstyles.content}>
<Outlet {...{context}}/>
{Boolean(resource.path) &&
{Boolean(path) &&
<CurrentFile
path={resource.path}
url={url}
ext={ext}
name={name}
path={path}
vertical={isVertical}
maximized={resource.maximized}
close={() => resource.setPath('')}
close={resource.close}
/>
}
</View>
Expand All @@ -58,7 +68,7 @@ const stylesheet = createStyleSheet(theme => ({
root: {
flex: 1,
flexDirection: 'row',
backgroundColor: theme.colors.background,
backgroundColor: theme.colors.neutral,
},
rootTabs: {
flexDirection: 'column-reverse',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,20 +8,20 @@ export function Router() {
return (
<_ {...{history}}>
<Routes>
<Route path="/" element={<$><Layout.Main/></$>}>
<Route path="/" element={<$><Layout.App/></$>}>
{/* General */}
<Route index element={<$><Screen.Home/></$>}/>
<Route path="inbox" element={<$><Screen.Teaser/></$>}/>
<Route path="settings" element={<$><Screen.Settings/></$>}/>
<Route path="storage" element={<$><Screen.Storage/></$>}/>
{/* Media */}
<Route path="browse/*" element={<$><Screen.Browse/></$>}/>
<Route path=":cid/:ext" element={<$><Screen.View/></$>}/>
{/* World */}
<Route path="world" element={<$><Screen.World/></$>}/>
<Route path="news" element={<$><Screen.Teaser/></$>}/>
<Route path="map" element={<$><Screen.Map/></$>}/>
<Route path="calendar" element={<$><Screen.Calendar/></$>}/>
<Route path="event/:id" element={<$><Screen.Teaser/></$>}/>
{/* Dev */}
<Route path="design" element={<$><Screen.Design/></$>}/>
<Route path="library" element={<$><Screen.Library/></$>}/>
Expand Down
1 change: 1 addition & 0 deletions client/src/app/routes/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export {Router} from './Router';
21 changes: 0 additions & 21 deletions client/src/app/routes/loader.native.tsx

This file was deleted.

23 changes: 0 additions & 23 deletions client/src/app/routes/loader.tsx

This file was deleted.

41 changes: 41 additions & 0 deletions client/src/app/routes/loader/index.native.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
export const Layout = {
get App() {
return require('../Layout').default;
},
}

export const Screen = {
get Settings() {
return require('../ScreenSettings').default;
},
get Storage() {
return require('../ScreenStorage').default;
},
get Teaser() {
return require('../ScreenTeaser').default;
},
get Home() {
return require('../../../home/routes/ScreenHome').default;
},
get Browse() {
return require('../../../media/routes/ScreenBrowse').default;
},
get View() {
return require('../../../media/routes/ScreenView').default;
},
get World() {
return require('../../../world/routes/ScreenWorld').default;
},
get Map() {
return require('../../../world/routes/ScreenMap').default;
},
get Calendar() {
return require('../../../world/routes/ScreenCalendar').default;
},
get Design() {
return require('../../../dev/routes/ScreenDesign').default;
},
get Library() {
return require('../../../dev/routes/ScreenLibrary').default;
},
}
43 changes: 43 additions & 0 deletions client/src/app/routes/loader/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
import {lazy} from 'react';

export const Layout = {
App: lazy(
() => import('../Layout')
),
}

export const Screen = {
Settings: lazy(
() => import('../ScreenSettings')
),
Storage: lazy(
() => import('../ScreenStorage')
),
Teaser: lazy(
() => import('../ScreenTeaser')
),
Home: lazy(
() => import('../../../home/routes/ScreenHome')
),
Browse: lazy(
() => import('../../../media/routes/ScreenBrowse')
),
View: lazy(
() => import('../../../media/routes/ScreenView')
),
World: lazy(
() => import('../../../world/routes/ScreenWorld')
),
Map: lazy(
() => import('../../../world/routes/ScreenMap')
),
Calendar: lazy(
() => import('../../../world/routes/ScreenCalendar')
),
Design: lazy(
() => import('../../../dev/routes/ScreenDesign')
),
Library: lazy(
() => import('../../../dev/routes/ScreenLibrary')
),
}
Loading

0 comments on commit 1cc97e1

Please sign in to comment.