riot-barcode
is a simple barcode generator for riotjs by using JsBarcode library. For detailed specifications, please refer to this document.
Please see the demo: https://kkeeth.github.io/riot-barcode/
If you want to use riot-barcode with a CDN service, etc., load the JS file in the html file, and place the tag <riot-barcode />
in the component you want to use.
See also the example directory in the github repository.
- index.html
<!DOCTYPE html>
<html>
<head>
<title>riot-barcode</title>
<script src="riot+compiler.js"></script>
<script src="riot-barcode.js"></script>
</head>
<body>
<div is="app"></div>
<script defer src="app.riot" type="riot"></script>
<script>
riot.compile().then(() => {
riot.mount("[is='app']")
})
</script>
</body>
</html>
- app.riot
<app>
<p>
Please input any text:
<input
type="text"
oninput="{ handleChange }"
value="{ state.inputValue }"
/>
</p>
<riot-barcode value="{ state.inputValue }" />
<script>
const initialValue = 'JsBarcode for RiotJS'
export default {
state: {
inputValue: initialValue,
},
handleChange(e) {
this.update({
inputValue: e.target.value ? e.target.value : initialValue,
})
},
}
</script>
</app>
There are several CDN services available, but I'm including two for your reference.
Use whatever bandoliers you want(e.g. webpack, rollup, parcel ... etc). For your reference, here's the code for using webpack
.
- install
$ npm install -S riot-barcode
- index.html
<!DOCTYPE html>
<html>
<head>
<title>My Riot App</title>
</head>
<body>
<div is="app" data-riot-component></div>
<script defer src="dist/bundle.js"></script>
</body>
</html>
- app.riot
<app>
<riot-barcode value="your any text" />
</app>
- app.js (your main js file)
import '@riotjs/hot-reload'
import { component } from 'riot'
import 'riot-barcode'
import App from './app.riot'
component(App)(document.querySelector('[data-riot-component]'))
- webpack.config.js
const path = require('path')
module.exports = {
entry: './src/app.js',
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'bundle.js',
},
devServer: {
open: true,
},
module: {
rules: [
{
test: /\.riot$/,
exclude: /node_modules/,
use: [
{
loader: '@riotjs/webpack-loader',
options: {
hot: true,
},
},
],
},
],
},
}
MIT License
This module has been tested under limited scenarios. If you find any issue please feel free to report via one of the below platforms:
- GitHub: riot-barcode
- Email: zensin0082@gmail.com
- Twitter: @kuwahara_jsri