Skip to content
This repository has been archived by the owner on Nov 18, 2018. It is now read-only.

[Deprecated] - Convert webpack's AMD output into a valid Dojo Module, invokable by a 'executeBundle()' method

License

Notifications You must be signed in to change notification settings

innerjoin/dojo-module-wrapper-webpack-plugin

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Deprecated - Do not use this project anymore!

This package has been deprecated as it considered bad practice to do it like this. Use dojo/request/script instead!

Example:

define([
   "dojo/_base/declare",
   "dijit/_WidgetBase",
   "dijit/_TemplatedMixin",
   "dojo/text!com.mymodule/jazz/MyWidget.html",
   "dojo/request/script"
], function(declare, _WidgetBase, _TemplatedMixin, template, script) {
   return declare("com.mymodule.jazz.MyWidget", [_WidgetBase, _TemplatedMixin], {

      templateString: template,

      startup: function() {
         script.get(net.jazz.ajax._contextRoot + "/web/com.mymodule/ui/MyBundle.js");
   });
});

A reference implementation can be found here


npm-v-svg npm-dt-svg issues-svg

Wrap webpack code to run within a Dojo powered Web App

In many enterprise and even open source projects, you will likely stumble across an exising application which is based on the Dojo Toolkit. While (at the time of writing) the whole Web Development world is talking about Angular, React, Webpack, Babel and all those modern web development tools, framworks and platforms, many developers are confronted with extending mature tools using older (and sometimes) not up-to-date libraries. This plug-in aims to help developers to integrate today's web technologies into mature Dojo based applications, which will allow to modernize your application step-by-step.

Installation

The plug-in is being published through npm, so running the following installation command is sufficient to get started using this plug-in npm install --save-dev dojo-module-wrapper-webpack-plugin

Usage

This plug-in requires a valid webpack configuration. It should contain the following information:

const DojoModuleWrapperPlugin = require('dojo-module-wrapper-webpack-plugin');

module.exports = {
    entry: {
        app: '<entry point of main JS class>',
    },
    output: {
        libraryTarget: 'amd',
        filename: '<bundle destination>',
    },
    module: {
        // module transformations
    },

    plugins: [
        new DojoModuleWrapperPlugin({
            app: {
                baseUrl: '<the base URL your app-bundle is running>'
                moduleName: '<the full name of your bundle>'
            },
        }),
    ],

    externals: [
        // exclude dojo, dijit and dojox from bundling
        (context, request, callback) => {
            if (/^dojo/.test(request) ||
                /^dojox/.test(request) ||
                /^dijit/.test(request)
            ) {
                return callback(null, `amd ${request}`);
            }
            callback();
        },
    ],
};

Projects using this plug-in

Stay tuned, the first project using this plug-in will be open-sourced in the nearer future. If you have a project which is using this plug-in successfully, feel free to contribute to this section through a pull request.

Contributing

Please use the Issue Tracker of this repository to report issues or suggest enhancements.

Pull requests are very welcome.

Licensing

Copyright (c) Lukas Steiger. All rights reserved.

Licensed under the MIT License.

About

[Deprecated] - Convert webpack's AMD output into a valid Dojo Module, invokable by a 'executeBundle()' method

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published