The web-js in connection with web component twig extension gives you simple and efficient way to handle your javascript components over twig.
Yarn
yarn add massive-web
NPM
npm install massive-web
A component can be created using different js patterns:
- Revealing pattern
- Prototype pattern
- ECMAScript 2015 class
- and more which works with multiple instances you simple need to create a initialize method
Using Revealing pattern
// js/components/test-revealing-pattern.js
var $ = require('jquery');
module.exports = (function() {
var test = {};
test.initialize = function(el, options) {
test.text = options.text;
$(el).click(test.say.bind(this));
};
test.say = function() {
alert(test.text);
}
return {
initialize: test.initialize,
say: test.say
};
});
Using Prototype pattern
// js/components/test-prototype-pattern.js
var $ = require('jquery');
var test = function() {};
test.prototype.initialize = function(el, options) {
this.text = options.text;
$(el).click(this.say.bind(this));
};
test.prototype.say = function() {
alert(this.test);
};
module.exports = test;
Using ECMAScript 2015 class
// js/components/test-class.js
import $ from 'jquery';
export default class Test {
constructor() {
this.text = '';
}
initialize(el, options) {
this.text = options.text;
$(el).click(this.say);
}
say() {
alert(this.text);
}
}
Sometimes you want just run js code which is not binded to a dom element for this services where created. Typically usages are running tracking code functions.
// js/services/log.js
module.exports = {
log: function(text) {
console.log(text);
}
};
// js/main.js
var web = window.web = require('massive.web');
// services
web.registerService('logger', require('./services/log.js'));
// components
web.registerComponent('test', require('./components/test-revealing-pattern.js'));
web.registerComponent('other', require('./components/test-prototype-pattern.js'));
web.registerComponent('more', require('./components/test-class'), { defaultOption: 'defaultValue' });
When using ES6:
import web from 'massive-web';
import Test from './components/test'
import Other from './components/more'
import Log from './services/log';
// services
web.registerService('logger', Log);
// components
web.registerComponent('test', Test);
web.registerComponent('more', Test, { defaultOption: 'defaultValue' });
For efficient handling its recommended to use it with a template engine like twig.
For twig embedding see the web component twig extension.
You can also use without a template engine and by calling the startComponents and callServices.
<button id="test-1">
Say Hello
</button>
<button id="test-2">
Say Bye
</button>
<script src="js/main.js"></script>
<script>
web.startComponents([
{name: 'test', id: 'test-1', { text: 'Hello' }},
{name: 'test', id: 'test-2', { text: 'Bye' }}
]);
web.callServices([
{name: 'logger', func: 'log', args: ['Hello']}
]);
</script>
Update package.json version on master branch:
git checkout master
git pull origin master
npm version [ major | minor | patch ] --no-git-tag-version
# update version in changelog
git add .
git commit -m "Release <version>"
git push origin master
Generate changelog:
github_changelog_generator --future-release <version>
Copy the text of the last release into github release description and create new release.
git fetch --tags
git checkout <version>
# Test which files get packed by npm
npm pack --dry-run
# Publish package
npm publish