Skip to content
This repository has been archived by the owner on May 12, 2022. It is now read-only.

Commit

Permalink
Merge branch 'dev'
Browse files Browse the repository at this point in the history
  • Loading branch information
dilan-dio4 committed May 6, 2021
2 parents b7a5e08 + 68d7430 commit ff48920
Show file tree
Hide file tree
Showing 5 changed files with 108 additions and 28 deletions.
57 changes: 36 additions & 21 deletions example/src/App.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/* eslint-disable @typescript-eslint/no-unused-vars */
import React from 'react'
import ebconfig from "./ebconfig.json";
// import ebconfig2 from "./ebconfig2";
import ebconfig2 from "./ebconfig2";
import { EasybaseProvider } from 'easybase-react';
import QueryExample from "./QueryExample";
import FunctionExample from "./CloudFunctionExample";
Expand All @@ -15,28 +15,35 @@ import {
} from "react-router-dom";
import ProjectUser from "./ProjectUser";
import UseReturnExample from './UseReturnExample';
import UseReturnStressTest from './UseReturnStressTest';

const IntegrationExample = () => (
<EasybaseProvider ebconfig={ebconfig} options={{ logging: false }}>
<h2>Visual Query</h2>
<QueryExample />
<hr className="m-4" />
<h2>Function</h2>
<FunctionExample />
<hr className="m-4" />
<h2>Db</h2>
<DbExample />
<hr className="m-4" />
<h2>Use Return</h2>
<UseReturnExample />
</EasybaseProvider>
)
const IntegrationExample = () => {
React.useEffect(() => console.log("MOUNTING INTEGRATION EXAMPLE"), []);
return (
<EasybaseProvider ebconfig={ebconfig} options={{ logging: false }}>
<h2>Visual Query</h2>
<QueryExample />
<hr className="m-4" />
<h2>Function</h2>
<FunctionExample />
<hr className="m-4" />
<h2>Db</h2>
<DbExample />
<hr className="m-4" />
<h2>Use Return</h2>
<UseReturnExample />
</EasybaseProvider>
)
}

const ProjectExample = () => (
<EasybaseProvider ebconfig={ebconfig} options={{ logging: true }}>
<ProjectUser />
</EasybaseProvider>
)
const ProjectExample = () => {
React.useEffect(() => console.log("MOUNTING PROJECT EXAMPLE"), []);
return (
<EasybaseProvider ebconfig={ebconfig2} options={{ logging: true }}>
<ProjectUser />
</EasybaseProvider>
)
}

const App = () => {
return (
Expand All @@ -48,6 +55,9 @@ const App = () => {
<li>
<Link to="/project">Project Example</Link>
</li>
<li>
<Link to="/usereturnstresstest">useReturn Stress Test</Link>
</li>
</ul>

<Switch>
Expand All @@ -57,6 +67,11 @@ const App = () => {
<Route path="/project" exact >
<ProjectExample />
</Route>
<Route path="/usereturnstresstest" exact >
<EasybaseProvider ebconfig={ebconfig} options={{ logging: true }}>
<UseReturnStressTest />
</EasybaseProvider>
</Route>
</Switch>
</HashRouter>
)
Expand Down
6 changes: 3 additions & 3 deletions example/src/DbCardElement.tsx
Original file line number Diff line number Diff line change
@@ -1,18 +1,18 @@
import React, { useRef } from "react";
import { useEasybase } from "easybase-react";

const CardElement = ({ rating, picture, app_name, hq, latest_release, _key }: any) => {
const CardElement = ({ rating, picture, app_name, hq, latest_release, _key, tableName }: any) => {

const inputEl = useRef<HTMLInputElement>(null);

const { db } = useEasybase();

const onRatingChange = (change: number) => {
db().set({ 'rating': rating + change }).where({ _key }).all()
db(tableName || "").set({ 'rating': rating + change }).where({ _key }).all()
}

const onDelete = () => {
db().delete().where({ _key }).one();
db(tableName || "").delete().where({ _key }).one();
}

return (
Expand Down
6 changes: 3 additions & 3 deletions example/src/ProjectUser.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import React, { useState, useEffect } from "react";
import { useEasybase } from "easybase-react";
import CardElement from "./CardElement";
import DbCardElement from "./DbCardElement";

export default function ProjectUser() {

Expand Down Expand Up @@ -60,7 +60,7 @@ export default function ProjectUser() {
<button className="btn orange m-4" onClick={addUserRecord}><span>Add User Record</span></button>
</div>
<div className="d-flex">
{data.map((ele, index) => <CardElement {...ele} index={index} key={index} />)}
{data.map((ele, index) => <DbCardElement {...ele} tableName="REACT TEST" key={index} />)}
</div>
</div>
)
Expand All @@ -76,7 +76,7 @@ export default function ProjectUser() {
<button className="btn orange m-4" onClick={onSignUpClick}><span>Sign Up</span></button>
</div>
<div className="d-flex">
{data.map((ele, index) => <CardElement {...ele} index={index} key={index} />)}
{data.map((ele, index) => <DbCardElement {...ele} tableName="MOBILE APPS" key={index} />)}
</div>
</div>
)
Expand Down
61 changes: 61 additions & 0 deletions example/src/UseReturnStressTest.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
import React, { useState } from "react";
import { useEasybase } from 'easybase-react';
import CardElement from "./DbCardElement";

const ChildUseReturn = () => {
const [ratingState, setRatingState] = useState(50);

const {
db,
useReturn,
e
} = useEasybase();

const { frame, loading } = useReturn(() => db()
.return()
.where(e.lt('rating', ratingState))
.limit(10),
[ratingState]);

return (
<div>
<div style={{ display: "flex", alignItems: "center" }}>
{loading ? <div className="loader"></div> : frame.map((ele, index) => <CardElement {...ele} index={index} key={index} />)}
</div>
<div className="button-row">
<div className="d-flex align-items-center">
<p className="m-4">Edit Rating filter: </p>
<input type="number" onChange={e => setRatingState(+e.target.value)} value={ratingState} />
</div>
</div>
</div>
)
}

const UseReturnStressTest = () => {
const [showChild, setShowChild] = useState(true);

const {
db,
} = useEasybase();

const onAddPage = async () => {
await db().insert({ rating: 68, "app name": "Inserted App", _position: 0 }).all();
}

return (
<div>
<div>
<button className="btn green" onClick={onAddPage}><span>Add<br />Card</span></button>
<label>
Show Child:
<input type="checkbox" onChange={e => setShowChild(e.target.checked)} checked={showChild} />
</label>

{ showChild && <ChildUseReturn /> }
</div>
</div>
)
}

export default UseReturnStressTest;
6 changes: 5 additions & 1 deletion src/EasybaseProvider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -483,7 +483,6 @@ const EasybaseProvider = ({ children, ebconfig, options }: EasybaseProviderProps
const [frame, setFrame] = useState<Record<string, any>[]>([]);
const [error, setError] = useState<any>(null);
const [loading, setLoading] = useState<boolean>(false);

const [dead, setDead] = useState<boolean>(false);

const doFetch = async (): Promise<void> => {
Expand All @@ -500,11 +499,15 @@ const EasybaseProvider = ({ children, ebconfig, options }: EasybaseProviderProps
}

useEffect(() => {
let isAlive = true;
if (!dead) {
const _instanceTableName: string = (dbInstance() as any)._tableName;
(unsubscribe as any)("true");

const _listener = dbEventListener((status?: DB_STATUS, queryType?: string, executeCount?: EXECUTE_COUNT, tableName?: string | null, returned?: any) => {
if (!isAlive) {
return;
}
log(_instanceTableName, status, queryType, executeCount, tableName)
if ((tableName === null && _instanceTableName === "untable") || tableName === _instanceTableName) {
if (status === DB_STATUS.SUCCESS && queryType !== "select") {
Expand All @@ -524,6 +527,7 @@ const EasybaseProvider = ({ children, ebconfig, options }: EasybaseProviderProps

doFetch();
}
return () => { isAlive = false; }
}, deps || []);

return {
Expand Down

0 comments on commit ff48920

Please sign in to comment.