
Security News
Axios Supply Chain Attack Reaches OpenAI macOS Signing Pipeline, Forces Certificate Rotation
OpenAI rotated macOS signing certificates after a malicious Axios package reached its CI pipeline in a broader software supply chain attack.
react-komik
Advanced tools
ReactJS based comic strip creator using fabric.js canvas rendering. It's like spectacle but for comic. You can edit (positioning, scaling, coloring) the comic after rendering. Reactify anything, reactify comic.


Just install it from npm
npm install react-komik
You can use the component by require it and bundle it with webpack or browserify. Don't forget to import React, ReactDOM, and use Babel/JSX transformer with ES2015 (recommended)
import React from 'react';
import { render } from 'react-dom';
import { Strip, Panel, Character, Balloon } from 'react-komik';
let Comic = (props) => (
<Strip title="Your title here" column="1">
<Panel>
<Character
image="char.png">
<Balloon
text="Reactify Comic!" />
</Character>
</Panel>
</Strip>
);
render(<Comic />, document.getElementById('root'));
Download or include the komik.js file to your HTML. Don't forget to include React, ReactDOM and JSX transformer/Babel. Please use NPM modules instead for production.
<script src="http://sonnylazuardi.github.io/react-komik/dist/komik.js"></script>
<script>
let { Strip, Panel, Character, Balloon } = Komik;
class Comic extends React.Component {
render() {
return (
<Strip title="Your title here" column="1">
<Panel>
<Character
image="char.png">
<Balloon
text="Reactify Comic!" />
</Character>
</Panel>
</Strip>
);
}
}
ReactDOM.render(<Comic />, document.getElementById('root'));
</script>
This demo is using UMD browser, hosted on codepen and jsbin.
http://codepen.io/sonnylazuardi/pen/JGKmGE
http://jsbin.com/zaxabi/edit?html,js,output
There are four main components:
| Attribute | Value Type | Default | Description |
|---|---|---|---|
| title | String | "Comic Title" | Your comic title |
| column | Integer | 2 | Number of comic's column |
| padding | Integer | 0 | Comic padding |
| width | Integer | 500 | Comic's width |
| height | Integer | 500 | Comic's height |
| top | Integer | 0 | Comic's top position |
| left | Integer | 0 | Comic's left position |
| fill | String (Color) | 'white' | Comic's background color |
| stroke | String (Color) | 'black' | Comic's stroke color |
| strokeWidth | Integer | 0 | Comic's stroke width |
| fontFamily | String (Font Name) | "Arial" | Comic's font family |
| fontSize | Integer | 13 | Comic's font size |
| upperCase | Boolan | false | Comic's text upper case |
| Attribute | Value Type | Default | Description |
|---|---|---|---|
| height | Integer | 180 | Panel's height |
| padding | Integer | 20 | Panel's padding |
| fill | String (Color) | 'white' | Panel's background color |
| stroke | Integer | 'black' | Panel's stroke color |
| strokeWidth | Integer | 3 | Panel's stroke width |
| background | String (Image URL) | null | Panel's background image |
| Attribute | Value Type | Default | Description |
|---|---|---|---|
| image | String (Image URL) | 'char1.png' | Character's image |
| scale | Decimal (0 - 1) | 1 | Character's image scale |
| align | String ('center', 'right', 'left') | 'center' | Character's align position |
| left | Integer | null | Character's left position (will overwrite align) |
| bottom | Integer | 0 | Character's bottom position |
| top | Integer | null | Character's top position (will overwrite bottom position) |
| Attribute | Value Type | Default | Description |
|---|---|---|---|
| text | String | 'Hi Bro!' | Balloon's text |
| image | String (SVG URL) | 'chat_right.svg' | Chat balloon SVG images |
| left | Integer | null | Balloon's left position |
| bottom | Integer (from Character's top) | -70 | Balloon's bottom position |
| top | Integer | null | Balloon's top position (will overwrite bottom) |
| scale | Decimal (0 - 1) | 0.8 | Balloon's image scale |
| align | String ('center', 'left', 'right') | 'left' | Balloon's align from character |
| padding | Integer | 12 | Balloon's text padding |
| height | Integer | 150 | Balloon's height |
| textAlign | String ('center', 'left', 'right') | 'center' | Balloon's text align |
| fontFamily | String (Font Name) | (The same with Strip's fontFamily) | Balloon's font family |
| fontSize | Integer | (The same with Strip's fontSize) | Balloon's font size |
Ideas, issues, and PRs are welcomed. You can also directly shoot me an email at sonnylazuardi@gmail.com.
This project is actually an effort to write comic easier for JS Comic. Please follow @jscomicnet or like JS Comic FB page.
MIT @sonnylazuardi
FAQs
ReactJS based comic strip creator
The npm package react-komik receives a total of 5 weekly downloads. As such, react-komik popularity was classified as not popular.
We found that react-komik demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
OpenAI rotated macOS signing certificates after a malicious Axios package reached its CI pipeline in a broader software supply chain attack.

Security News
Open source is under attack because of how much value it creates. It has been the foundation of every major software innovation for the last three decades. This is not the time to walk away from it.

Security News
Socket CEO Feross Aboukhadijeh breaks down how North Korea hijacked Axios and what it means for the future of software supply chain security.