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

Trying to import zdog with es6 syntax #10

Closed
sammdec opened this issue May 28, 2019 · 12 comments
Closed

Trying to import zdog with es6 syntax #10

sammdec opened this issue May 28, 2019 · 12 comments
Labels
bug Something isn't working

Comments

@sammdec
Copy link

sammdec commented May 28, 2019

When es6 import syntax none of the modules are exported or available on the Zdog class
Test case: https://codesandbox.io/embed/hungry-darwin-59jh7

@desandro desandro added the bug Something isn't working label May 28, 2019
@desandro
Copy link
Member

This is indeed a bug. I totally forgot to attach the classes to the Zdog namespace for CommonJS

@sammdec
Copy link
Author

sammdec commented May 28, 2019

I know what it’s like trying to do projects in between being a new parent, I think it’s amazing you managed to do all this. A few bugs are bound to slip through! Really awesome project. Would you like me to have a go at a PR?

@desandro
Copy link
Member

I'll take care of this in the next release. Thanks for the offer and the kind words 🐶

desandro added a commit that referenced this issue May 29, 2019
+ pass in window for server-side env
@davekiss
Copy link

Just installed your patch, and I'm seeing an error after calling illo.updateRenderGraph() in a React/babelfied env when attempting to render

Uncaught ReferenceError: Zdog is not defined
    at anchor.js:158
    at Array.forEach (<anonymous>)
    at Item.Anchor.renderGraphCanvas (anchor.js:157)
    at Item.Illustration.renderGraphCanvas (illustration.js:146)
    at Item.Illustration.renderGraph (illustration.js:107)
    at Item.Illustration.updateRenderGraph (illustration.js:116)

I was able to fix by forcing the window variable after import

import Zdog from "zdog";
window.Zdog = Zdog;

@Merak1
Copy link

Merak1 commented May 29, 2019

import Zdog from "zdog";
window.Zdog = Zdog;

Im also trying it on React, although Im not as experienced with neither react nor web development in general,I was having the same issue about Zdog being undefined, then I tried your fixed and worked but now I keep getting this error
Captura de pantalla de 2019-05-29 17-00-59

any Ideas on how to solve this issue?

I installed Zdog with npm

desandro added a commit that referenced this issue May 30, 2019
👕 add .jshintrc js/, demos/, tasks
📦 npm ignore dotfiles
@desandro
Copy link
Member

@davekiss Ah. That looks to be a separate bug. I've pushed up a fix. Thanks so much for reporting that one.

@Merak1 The fix has yet to be released. You'll have to wait a bit before using Zdog with npm & React.

@boardfish
Copy link

@desandro Are there plans for full React compatibility? Right now an Illustration, among other objects, needs to reference an element on the page in order to be rendered. It'd be nice to see them wrapped in React components that can be dropped in as with any other.

@sammdec
Copy link
Author

sammdec commented May 30, 2019

It’s maybe not your ideal solution but I managed to implement it in a react app by using refs in react. You will need to use effect as well as ref is undefined when the page loads

@marcelinollano
Copy link

marcelinollano commented Jun 1, 2019

I'm trying to import Zdog using npm from master and I keep getting the following error when trying to do dragRotate: true:

dragger.js:84 Uncaught TypeError: window.addEventListener is not a function
    at Item.Dragger.dragStart (dragger.js:84)
    at Item.Illustration.dragStart (illustration.js:230)
    at Item.Dragger.onmousedown.Dragger.onpointerdown (dragger.js:73)
    at Item.Dragger.handleEvent (dragger.js:67)

Not sure what's going on 🤔

The same code runs fine with:

<script src="https://unpkg.com/zdog@1.0.1/dist/zdog.dist.min.js"></script>

@desandro
Copy link
Member

desandro commented Jun 4, 2019

v1.0.2 has been released with fixes for these bug. Please update! Closing as fixed.

@desandro desandro closed this as completed Jun 4, 2019
@mkaemmerer
Copy link

I tried out the 1.0.2 release today, and it looks like although the es6 imports are working now, I ran into the same dragger bug @marcelinollano mentioned.

dragger.js:84 Uncaught TypeError: window.addEventListener is not a function
    at Item.Dragger.dragStart (dragger.js:84)
    at Item.Illustration.dragStart (illustration.js:232)
    at Item.Dragger.onmousedown.Dragger.onpointerdown (dragger.js:73)
    at Item.Dragger.handleEvent (dragger.js:67)

@desandro
Copy link
Member

desandro commented Jun 5, 2019

@mkaemmerer I've opened #49 to track this separate issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Development

No branches or pull requests

7 participants