Skip to content

Commit

Permalink
feat(slice-machine-ui): update Slice Builder layout
Browse files Browse the repository at this point in the history
  • Loading branch information
bapmrl committed Oct 20, 2023
1 parent 0f1ad23 commit 1ab3337
Show file tree
Hide file tree
Showing 6 changed files with 40 additions and 140 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
import { Box } from "theme-ui";

import { ensureDnDDestination } from "@lib/utils";
import { transformKeyAccessor } from "@utils/str";

Expand All @@ -10,6 +8,7 @@ import * as Widgets from "@lib/models/common/widgets";
import sliceBuilderWidgetsArray from "@lib/models/common/widgets/sliceBuilderArray";

import { DropResult } from "react-beautiful-dnd";
import { List } from "@src/components/List";
import useSliceMachineActions from "@src/modules/useSliceMachineActions";
import { VariationSM, WidgetsArea } from "@lib/models/common/Slice";

Expand Down Expand Up @@ -118,7 +117,7 @@ const FieldZones: React.FunctionComponent<FieldZonesProps> = ({
};

return (
<>
<List>
<Zone
zoneType="slice"
tabId={undefined}
Expand All @@ -145,7 +144,6 @@ const FieldZones: React.FunctionComponent<FieldZonesProps> = ({
dataCy="slice-non-repeatable-zone"
isRepeatableCustomType={undefined}
/>
<Box mt={4} />
<Zone
zoneType="slice"
tabId={undefined}
Expand All @@ -171,7 +169,7 @@ const FieldZones: React.FunctionComponent<FieldZonesProps> = ({
dataCy="slice-repeatable-zone"
isRepeatableCustomType={undefined}
/>
</>
</List>
);
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,10 @@ import VariationPopover from "./VariationsPopover";
import useSliceMachineActions from "@src/modules/useSliceMachineActions";
import { VariationSM } from "@lib/models/common/Slice";
import { ComponentUI } from "@lib/models/common/ComponentUI";
import { ModelStatus } from "@lib/models/common/ModelStatus";

const Header: React.FC<{
component: ComponentUI;
status: ModelStatus;
variation: VariationSM;
imageLoading?: boolean;
}> = ({ component, variation }) => {
const router = useRouter();
const [showVariationModal, setShowVariationModal] = useState(false);
Expand Down
35 changes: 4 additions & 31 deletions packages/slice-machine/lib/builders/SliceBuilder/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,34 +22,22 @@ import {
AppLayoutHeader,
} from "@components/AppLayout";
import SimulatorButton from "@lib/builders/SliceBuilder/Header/SimulatorButton";
import { SliceSM, VariationSM } from "@lib/models/common/Slice";
import { VariationSM } from "@lib/models/common/Slice";
import { ComponentUI } from "@lib/models/common/ComponentUI";

import { FloatingBackButton } from "@src/features/slices/sliceBuilder/FloatingBackButton";
import { selectIsSimulatorAvailableForFramework } from "@src/modules/environment";
import { isSelectedSliceTouched } from "@src/modules/selectedSlice/selectors";
import { getRemoteSlice } from "@src/modules/slices";
import { useModelStatus } from "@src/hooks/useModelStatus";
import { ComponentWithSliceProps } from "@src/layouts/WithSlice";
import {
LocalAndRemoteSlice,
LocalOnlySlice,
} from "@lib/models/common/ModelData";

export type SliceBuilderState = {
imageLoading: boolean;
loading: boolean;
done: boolean;
error: null | string;
status: number | null;
};

export const initialState: SliceBuilderState = {
imageLoading: false,
loading: false,
done: false,
error: null,
status: null,
};

const SliceBuilder: ComponentWithSliceProps = ({ slice, variation }) => {
Expand All @@ -58,7 +46,7 @@ const SliceBuilder: ComponentWithSliceProps = ({ slice, variation }) => {
(store: SliceMachineStoreType) => ({
isTouched: isSelectedSliceTouched(store, slice.from, slice.model.id),
remoteSlice: getRemoteSlice(store, slice.model.id),

Check failure on line 48 in packages/slice-machine/lib/builders/SliceBuilder/index.tsx

View workflow job for this annotation

GitHub Actions / packages (slice-machine-ui)

Unsafe assignment of an `any` value

Check failure on line 48 in packages/slice-machine/lib/builders/SliceBuilder/index.tsx

View workflow job for this annotation

GitHub Actions / packages (slice-machine-ui)

Unsafe call of an `any` typed value
}),
})
);

// We need to move this state to somewhere global to update the UI if any action from anywhere save or update to the filesystem I'd guess
Expand Down Expand Up @@ -88,7 +76,6 @@ const SliceBuilder: ComponentWithSliceProps = ({ slice, variation }) => {
updateSlice={updateSlice.bind(null, slice, setData)}
slice={slice}
variation={variation}
remoteSlice={remoteSlice}
isTouched={isTouched}
data={data}
/>
Expand All @@ -99,32 +86,23 @@ type SliceBuilderForVariationProps = {
updateSlice: () => void;
slice: ComponentUI;
variation: VariationSM;
remoteSlice: SliceSM | undefined;
isTouched: boolean;
data: SliceBuilderState;
};
const SliceBuilderForVariation: React.FC<SliceBuilderForVariationProps> = ({
updateSlice,
slice,
variation,
remoteSlice,
isTouched,
data,
}) => {
const { isSimulatorAvailableForFramework } = useSelector(
(state: SliceMachineStoreType) => ({
isSimulatorAvailableForFramework:
selectIsSimulatorAvailableForFramework(state),
}),
})
);

const sliceModel: LocalAndRemoteSlice | LocalOnlySlice = {
local: slice.model,
localScreenshots: slice.screenshots,
...(remoteSlice ? { remote: remoteSlice } : {}),
};
const { modelsStatuses } = useModelStatus({ slices: [sliceModel] });

return (
<AppLayout>
<AppLayoutHeader>
Expand All @@ -147,12 +125,7 @@ const SliceBuilderForVariation: React.FC<SliceBuilderForVariationProps> = ({
</AppLayoutHeader>
<AppLayoutContent>
<BaseStyles>
<Header
component={slice}
status={modelsStatuses.slices[slice.model.id]}
variation={variation}
imageLoading={data.imageLoading}
/>
<Header component={slice} variation={variation} />
<Grid columns="1fr 320px" gap="16px" sx={{ pt: 4 }}>
<Box>
<FieldZones variation={variation} />
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ const FieldZone = ({
isRepeatable,
dataCy,
isRepeatableCustomType,
sx,
}) => {
return (
<DragDropContext
Expand All @@ -41,8 +40,7 @@ const FieldZone = ({
{...provided.droppableProps}
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
data-cy={dataCy}
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
sx={sx}
sx={{ paddingInline: "16px !important" }}
>
{
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call
Expand Down

This file was deleted.

100 changes: 32 additions & 68 deletions packages/slice-machine/lib/builders/common/Zone/index.jsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,14 @@
import { Button, ButtonGroup, Switch, Text } from "@prismicio/editor-ui";
import { Button, Switch, Text } from "@prismicio/editor-ui";
import { array, arrayOf, bool, func, object, shape, string } from "prop-types";
import { useState } from "react";
import { BaseStyles, Heading } from "theme-ui";
import { BaseStyles } from "theme-ui";

import { ListHeader } from "@src/components/List";

import SelectFieldTypeModal from "../SelectFieldTypeModal";
import NewField from "./Card/components/NewField";
import Card from "./Card";
import EmptyState from "./components/EmptyState";
import ZoneHeader from "./components/ZoneHeader";

const Zone = ({
zoneType /* type of the zone: customType or slice */,
Expand All @@ -30,8 +29,6 @@ const Zone = ({
dataCy,
isRepeatableCustomType,
}) => {
const isCustomType = zoneType === "customType";

// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
const widgetsArrayWithCondUid = (() => {
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-argument
Expand Down Expand Up @@ -74,68 +71,36 @@ const Zone = ({

return (
<>
{isCustomType ? (
<ListHeader
actions={
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
fields.length > 0 ? (
<>
<Text color="grey11" component="span">
Show code snippets?
</Text>
<Switch
checked={showHints}
onCheckedChange={setShowHints}
size="small"
/>
<Button
data-cy={`add-${
// eslint-disable-next-line @typescript-eslint/strict-boolean-expressions
isRepeatable ? "Repeatable" : "Static"
}-field`}
onClick={enterSelectMode}
startIcon="add"
variant="secondary"
>
Add a new field
</Button>
</>
) : undefined
}
>
{title}
</ListHeader>
) : (
<BaseStyles>
<ZoneHeader
Heading={<Heading as="h6">{title}</Heading>}
Actions={
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
fields.length > 0 ? (
<ButtonGroup size="medium" variant="secondary">
<Button
variant="secondary"
onClick={() => setShowHints(!showHints)}
>
{showHints ? "Hide" : "Show"} code snippets
</Button>
<Button
variant="secondary"
onClick={() => enterSelectMode()}
data-cy={`add-${
// eslint-disable-next-line @typescript-eslint/strict-boolean-expressions
isRepeatable ? "Repeatable" : "Static"
}-field`}
startIcon="add"
>
Add a new field
</Button>
</ButtonGroup>
) : null
}
/>
</BaseStyles>
)}
<ListHeader
actions={
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
fields.length > 0 ? (
<>
<Text color="grey11" component="span">
Show code snippets?
</Text>
<Switch
checked={showHints}
onCheckedChange={setShowHints}
size="small"
/>
<Button
data-cy={`add-${
// eslint-disable-next-line @typescript-eslint/strict-boolean-expressions
isRepeatable ? "Repeatable" : "Static"
}-field`}
onClick={enterSelectMode}
startIcon="add"
variant="secondary"
>
Add a new field
</Button>
</>
) : undefined
}
>
{title}
</ListHeader>
{
// eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/strict-boolean-expressions
fields.length === 0 && !newFieldData ? (
Expand Down Expand Up @@ -191,7 +156,6 @@ const Zone = ({
/>
)
}
sx={isCustomType ? { paddingInline: "16px !important" } : {}}
/>
</BaseStyles>
) : undefined
Expand Down

0 comments on commit 1ab3337

Please sign in to comment.