issues-95 Add logic for showing fork vs save and if there are change

This commit is contained in:
Kurt Hutten
2020-11-14 18:00:14 +11:00
parent 0ede0be0b4
commit de7c94e7d6
2 changed files with 14 additions and 3 deletions

View File

@@ -1,4 +1,5 @@
import { useMutation, useFlash } from '@redwoodjs/web' import { useMutation, useFlash } from '@redwoodjs/web'
import { useAuth } from '@redwoodjs/auth'
import { Link, routes, navigate } from '@redwoodjs/router' import { Link, routes, navigate } from '@redwoodjs/router'
import { initialize } from 'src/cascade/js/MainPage/CascadeMain' import { initialize } from 'src/cascade/js/MainPage/CascadeMain'
import CascadeController from 'src/helpers/cascadeController' import CascadeController from 'src/helpers/cascadeController'
@@ -16,6 +17,8 @@ const domNode = document.createElement('div').setAttribute('id', 'sickId')
const IdeCascadeStudio = ({ part, saveCode, loading, error }) => { const IdeCascadeStudio = ({ part, saveCode, loading, error }) => {
const [code, setCode] = useState(part.code) const [code, setCode] = useState(part.code)
const { currentUser } = useAuth()
const canEdit = currentUser?.sub === part?.user?.id
useEffect(() => { useEffect(() => {
const onCodeChange = (code) => setCode(code) const onCodeChange = (code) => setCode(code)
CascadeController.initialise(onCodeChange, part.code, domNode) CascadeController.initialise(onCodeChange, part.code, domNode)
@@ -25,7 +28,7 @@ const IdeCascadeStudio = ({ part, saveCode, loading, error }) => {
element.setAttribute('style', 'display: none; overflow: hidden; height: calc(100vh - 8rem)') // eslint-disable-line element.setAttribute('style', 'display: none; overflow: hidden; height: calc(100vh - 8rem)') // eslint-disable-line
} }
}, []) }, [])
const hasChanges = code !== part.code const isChanges = code !== part.code
const { addMessage } = useFlash() const { addMessage } = useFlash()
const [deletePart] = useMutation(DELETE_PART_MUTATION, { const [deletePart] = useMutation(DELETE_PART_MUTATION, {
onCompleted: () => { onCompleted: () => {
@@ -44,7 +47,7 @@ const IdeCascadeStudio = ({ part, saveCode, loading, error }) => {
<> <>
<nav className="rw-button-group hidden"> <nav className="rw-button-group hidden">
{loading && 'Loading...'} {loading && 'Loading...'}
{hasChanges && !loading && ( {isChanges && !loading && (
<button <button
onClick={() => saveCode({ code }, part.id)} onClick={() => saveCode({ code }, part.id)}
className="rw-button rw-button-blue" className="rw-button rw-button-blue"
@@ -54,7 +57,12 @@ const IdeCascadeStudio = ({ part, saveCode, loading, error }) => {
)} )}
</nav> </nav>
<div> <div>
<IdeToolbar /> <IdeToolbar
canEdit={canEdit}
isChanges={isChanges && !loading}
onSave={() => {}}
onExport={() => {}}
/>
<div id="topnav" className="topnav hidden"> <div id="topnav" className="topnav hidden">
<a href="https://github.com/zalo/CascadeStudio"> <a href="https://github.com/zalo/CascadeStudio">
Cascade Studio 0.0.6 Cascade Studio 0.0.6

View File

@@ -12,6 +12,9 @@ export const QUERY = gql`
code code
mainImage mainImage
createdAt createdAt
user {
id
}
} }
} }
` `