Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature: Layer List Plugin #11

Open
wants to merge 38 commits into
base: main
Choose a base branch
from
Open

Feature: Layer List Plugin #11

wants to merge 38 commits into from

Conversation

mirko314
Copy link
Contributor

@mirko314 mirko314 commented Apr 2, 2024

Adds a layer list panel plugin.
This plugin uses

  • Tailwind
  • React
    to create a highly interactive custom panel for the CE.SDK which allows customers to see all blocks inside the current Scene

@mirko314 mirko314 force-pushed the feature/layer-list branch from ae396a6 to 8803a36 Compare April 2, 2024 10:48
@mirko314 mirko314 changed the title Feature/layer-list Feature: Layer List Plugin Apr 8, 2024
@mirko314 mirko314 force-pushed the feature/layer-list branch from 843127d to 98a91ad Compare April 9, 2024 09:34
await cesdk.unstable_addPlugin(LayerListPlugin());

await cesdk.createDesignScene();
await cesdk.ui.openPanel("@imgly/plugin-layer-list-web.panel"),

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Question – What is the naming convention here? The "." notation at the end is new to me. However, I guess that we have to clarify naming conventions in general.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's a good point. We should think about something. I also thought that it could make sense to export ids from the plugin as constants.

Copy link

vercel bot commented Apr 22, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
plugins-web ❌ Failed (Inspect) May 17, 2024 2:40pm

Copy link
Member

@maerch maerch left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unfortunately, I could not try and test it, since it wasn't build successfully on Vercel and I was not able to build and run it locally without errors.

Could you rebase and fix the build issues so that at least it is build via Vercel?

try {
await Promise.all([
cesdk.unstable_addPlugin(
// @ts-ignore
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Are you sure that this is needed?

BackgroundRemovalPlugin({ ui: { locations: 'canvasMenu' } })
),
...addDemoRemoteAssetSourcesPlugins(cesdk)
...addDemoRemoteAssetSourcesPlugins(cesdk),
// @ts-ignore
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same here...

examples/web/src/addPlugins.ts Outdated Show resolved Hide resolved
});

export const Meta = PLUGIN_META;
export const Apps = [
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems something very specific to this kind of "Apps" view that only the demo uses. I do not think I would like to expose this publicly in the package right now but just implement this on the demo app level and then rethink how we want an interface to look like maybe even in the context of the CE.SDK.

packages/plugin-layer-list-web/README.md Outdated Show resolved Hide resolved
const mode = engine.scene.getMode();
if (mode !== 'Design') {
// eslint-disable-next-line no-console
console.error('The Layer List Panel is only available in Design mode.');
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just out of curiosity. Is there an issue with Video?

callbacks: { onUpload: 'local', onLoad: 'upload' },
// We need to load assets from the same domain to enable custom dom panels (like e.g created in the layer list panel).
// Otherwise, the panel only shows an error message.
baseURL: '/assets',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Don't we have to copy asset from the CE.SDK with this changes? At least I cannot start the app without WASM errors.

return (
<div
className={clsx({
'flex justify-between items-center text-primary-foreground hover:bg-primary-hover pr-4 cursor-move h-8':
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'll never get used to tailwind. :D

{isExpanded ? <ChevronDownIcon /> : <ChevronRightIcon />}
</button>
)}
{childrenCount === 0 && <div style={{ width: '24px' }} />}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it make sense to use our CSS variables instead of hard coding this?

});
};
// Subscribe to history updates to update the block tree when the history changes
const unsubscribe = engine.editor.onHistoryUpdated(() => {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Relying on the history state means that it does not react on changes done with the API (if no history step was added). Maybe we can subscribe to the regular events and wrap it in a debounce?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants