issues-95 Add logic for showing fork vs save and if there are change
This commit is contained in:
@@ -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
|
||||||
|
|||||||
@@ -12,6 +12,9 @@ export const QUERY = gql`
|
|||||||
code
|
code
|
||||||
mainImage
|
mainImage
|
||||||
createdAt
|
createdAt
|
||||||
|
user {
|
||||||
|
id
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
|
|||||||
Reference in New Issue
Block a user