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

How to use with _WidgetsInTemplateMixin #5

Open
anatoliyarkhipov opened this issue Jul 21, 2016 · 0 comments
Open

How to use with _WidgetsInTemplateMixin #5

anatoliyarkhipov opened this issue Jul 21, 2016 · 0 comments

Comments

@anatoliyarkhipov
Copy link

anatoliyarkhipov commented Jul 21, 2016

Hi! At first, let me say thanks for this awesome package. Our team was happy to find it.

During the migration we encountered some problems with _WidgetsInTemplateMixin. Because the default Dojo loader was not used, _WidgetsInTemplateMixin was not able to get the loaded widgets from the Dojo modules cache.

For example, if we have something like that:

<div class="${rootLayout}">
  <div data-dojo-type="dijit/layout/ContentPane"
       data-dojo-attach-point="toolbarRegion">
    Toolbar
  </div>
</div>

then _WidgetsInTemplateMixin cannot find the ContentPane and gonna try to require it using the default Dojo loader. And it fails for the obvious reasons.

To fix this problem we found the next solution: in widgets that uses _WidgetsInTemplateMixin we just define contextRequire property. It looks like this:

contextRequire: {
  _dojoParserCtorMap: {
    'dijit/layout/ContentPane': require('dijit/layout/ContentPane'),
  },
},

In this case _WidgetsInTemplateMixin doesn't try to load the widgets but just takes them from the _dojoParserCtroMap property. We can just define in this way all widgets that are used in the template, and it works just fine.

Hope this will help someone who got the same problems.

P.S. After writing this message I found in the Readme, that dojo-webpack-loader provides some API to register widgets 😅. @Nordth could you please explain how to use it?

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

No branches or pull requests

1 participant