Skip to content

A starter kit for creating ThingWorx widgets modern front-end technologies like TypeScript and Webpack

Notifications You must be signed in to change notification settings

thingworx-field-work/ThingworxDemoWebpackWidget

Repository files navigation

Starter kit of a ThingWorx widget using Webpack and TypeScript

This repository contains an example that can act as a starter kit for building widget using modern web development techniques like Webpack and TypeScript and babel.

Why use it

There are many advantages to this, and here's some of them:

Webpack advantages

  • Because of dynamic imports and require calls, webpack can load javascript files and other resources only they are needed. So, if you are using a very big external library, this library is only loaded if the widget is used in a mashup, rather than being always loaded in the CombinedExtensions.js files.
  • Better resource management: You can load a resource (like images, xml files, css) only if it's used in the widget, and you'll no longer have to care about where to put it and how to package it. Also, the webpack loader will inline small files for better network performance.
  • Automatic dependency management: Webpack can be very easily integrated with the npm repositories, so this brings automatic dependency management. You'll no longer have to manually download libraries from the web, struggle to add all the dependencies and so on. Instead, npm, which functions similarly to maven central, handles all of this.
  • Easily develop and test the widget outside of ThingWorx: By doing the initial development and testing in a simple html page, it reduces the waiting times of publishing widget, doing reloads, etc...
  • Allows using of different loaders: You can develop your code in multiple languages, and use transpilers to convert you code javascript code that works in older javascript version. One of this languages, is typescript.

Typescript

  • Typescript is a superscript of javascript with types.
  • Optional static typing (the key here is optional).
  • Type Inference, which gives some of the benefits of types, without actually using them.
  • Access to ES6 and ES7 features, before they become supported by major browsers.
  • The ability to compile down to a version of JavaScript that runs on all browsers.
  • Great tooling support with auto-completion..

Using the widget template

Required software

The following software is required:

  • NodeJS needs to be installed and added to the PATH. You should use the LTS version.

The following software is recommended:

  • Visual Studio Code: An integrated developer environment with great typescript support. You can also use any IDE of your liking, it just that most of the testing was done using VSCode.

Proposed folder structure

demoWebpackTypescriptWidget
│   README.md         // this file
│   package.json      // here you specify project name, homepage and dependencies. This is the only file you should edit to start a new project
│   tsconfig.json     // configuration for the typescript compiler
│   webpack.config.js // configuration for webpack. Can be updated through the use of webpack-merge
│   index.html        // when testing the widget outside of ThingWorx, the index file used.
│   .env.sample       // sample file of how to declare the target ThingWorx server for automatic widget upload. Rename this file to .env
│   .eslintrc.js      // eslint configuration for automatic file formatting
│   .releaserc.json   // semantic-release sample configuration for publishing to GitHub Releases
│   .releaserc-gitlab.json   // semantic-release sample configuration for publishing to GitLab Releases
└───webpack           // Internal webpack configuration and plugins
└───Entities          // ThingWorx XML entities that are part of the widget. This can be Things, StyleDefinitions, etc. They can be exported using the SourceControl export functionality in ThingWorx.
└───src               // main folder where your development will take place
│   └───browser                // If the widget is developed from an external library, or you want to be able to test it outside of thingworx
│   │   │   index.ts           // Typescript file containing the necessary code to run the widget outside of thingworx, inside a browser
│   └───ide                    // Folder containing the code that is used in the Mashup Builder
│   │   │   index.ts           // Contains the widget definition (properties, events, etc) used in the Mashup Builder
│   └───runtime                // Folder containing the code that is used during Mashup Runtime. 
│   │   │   index.ts           // Main file with the widget runtime logic, (eg. what happens when the a property changes)
│   └───common                 // Code that is shared across runtime, browser and ide
│   │   │   file1.ts           // typescript file with internal logic
│   │   │   file2.js           // javascript file in ES2015 with module
│   │   │   ...
│   └───styles        // folder for css styles that you can import into your app using import statements. This can also be within each scope (browser, ide, runtime)
│   └───images        // folder for image resources you are statically including using import statements
│   └───static        // folder for resources that are copied over to the development extension. Think of folder of images that you reference only dynamically
└───build         // temporary folder used during compilation
└───zip               // location of the built extension

Developing a new widget

In order to start developing a new widget using this template you need to do the following:

  1. Clone this repository
    git clone https://github.com/ptc-iot-sharing/ThingworxDemoWebpackWidget
    
    Alternatively, you can also use the link https://github.com/ptc-iot-sharing/ThingworxDemoWebpackWidget/ to directly generate a new GitHub repository using this template.
  2. Open package.json and configure the name, description, and other fields you find relevant
  3. Run yarn install. This will install the development dependencies for this project.
  4. Start working on your widget.

Adding dependencies

Dependencies can be added from npm, using the yarn add DEPENDENCY_NAME command, or by adding them directly to package.json, under dependencies. After adding them to package.json, you should run yarn install. If you are using a javascript library that also has typescript mappings you can install those using yarn add @types/DEPENDENCY_NAME.

Building and publishing

The following commands allow you to build and compile your widget:

  • yarn run build: builds the production version of the widget. Creates a new extension zip file under the zip folder. The production version is optimized for sharing and using in production environments.
  • yarn run upload: creates a build, and uploads the extension zip to the ThingWorx server configured in .env. The build is created for development, with source-maps enabled.
  • yarn run buildDev: builds the development version of the widget. Creates a new extension zip file under the zip folder.The build is created for development, with source-maps enabled.

Example of widgets that use this starter kit

  • SVGViewer: Allows viewing, interacting and manipulating SVG files in ThingWorx. Contains examples of using external libraries.
  • Calendar: A calendar widget for ThingWorx built using the fullcalendar library. Contains examples of using external libraries as well as referencing global external libraries without including them in the built package.
  • BarcodeScanner: A client side widget for scanning barcodes.

Sematic release

The widget uses semantic-release and GitLab CI/CD pipelines for automatic version management and package publishing. This automates the whole widget release workflow including: determining the next version number, generating the release notes, updating the CHANGELOG.MD and publishing a release. Please read through the semantic-release official documentation to better understand how it works.

Because we are using semantic-release the commit messages must follow a specific format called Angular commit conventions or Conventional Commits. It is mandatory that this is followed. To help with this, the project is also setup with commitizen as a dev-dependency. So, you can use git cz instead of git commit to create a new commit.

The repository should have one protected branch:

  • master: This is where the main development takes place. Each push to master is automatically built by the CI/CD pipeline and artifacts are generated.

By default, this repository comes with two samples CI/CD configurations for both GitHub and GitLab. By default, the .releaserc.json triggers a GitHub release. If you want to use GitLab, rename .releaserc-gitlab.json to .releaserc.json.

Support

Feel free to open an issue if you encounter any problem while using this starter kit.

Consulting and custom development can also be supported by contacting me at placatus@iqnox.com.

About

A starter kit for creating ThingWorx widgets modern front-end technologies like TypeScript and Webpack

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published