web.bower_components.summernote.README.md Maven / Gradle / Ivy
# Summernote
Super simple WYSIWYG Editor using Bootstrap (3.0 and 2.x).
[![Build Status](https://secure.travis-ci.org/HackerWins/summernote.png)](http://travis-ci.org/HackerWins/summernote)
### Summernote
Summernote is a JavaScript library that helps you create WYSIWYG editors online.
Home Page: http://hackerwins.github.io/summernote/
### Why Summernote?
Summernote has a few special features:
* Paste images from clipboard
* Saves images directly in the content of the field using base64 encoding, so you don't need to implement image handling at all
* Simple UI
* Interactive WYSIWYG editing
* Handy integration with server
#### Inspired by
* Gmail's WYSIWYG editor (http://www.gmail.com)
* Redactor (http://imperavi.com/redactor/)
### Installation and dependencies
Summernote uses opensouce libraries: [jQuery](http://jquery.com/), [Bootstrap](http://getbootstrap.com), [Font Awesome](https://github.com/FortAwesome/Font-Awesome).
For [Meteor](http://github.com/meteor/meteor), just run `meteor add summernote:summernote`. More info in the [Meteor README](meteor/README.md).
For other/no frameworks:
#### 1. include JS/CSS
Include the following code in the `` tag of your HTML:
```html
```
#### 2. target elements
Then place a `div` tag somewhere in the `body` tag. This element will be replaced with the summernote editor.
```html
Hello Summernote
```
#### 3. summernote
Finally, run this script after the DOM is ready:
```javascript
$(document).ready(function() {
$('#summernote').summernote();
});
```
### API
`code` - get the HTML source code underlying the text in the editor:
```javascript
var sHTML = $('#summernote').code();
```
`Destroy` summernote:
```javascript
$('#summernote').destroy();
```
### Supported platforms
Any modern browser: Safari, Chrome, Firefox, Opera, Internet Explorer 9+.
### Upcoming Features
* Responsive toolbar
* Table: Handles (sizing, selection) and popover
* IE8 Support
* Clipboard (you can paste images already)
* Media object selection
### Developer information
#### structure of summernote.js
```
summernote.js - Renderer.js (Generate markup) - Locale.js (Locale object)
ㄴEventHandler.js - Editor.js (Abstract editor)
ㄴStyle.js (Style Getter and Setter)
ㄴHistory.js (Store on jQuery.data)
ㄴToolbar.js (Toolbar module)
ㄴPopover.js (Popover module)
ㄴHandle.js (Handle module)
ㄴDialog.js (Dialog module)
-----------------------------Core Script-----------------------------
agent.js (agent information)
async.js (aysnc utility)
key.js (keycode object)
dom.js (dom functions)
list.js (list functions)
range.js (W3CRange extention)
---------------------------------------------------------------------
```
#### build summernote
```bash
# grunt-cli is need by grunt; you might have this installed already
npm install -g grunt-cli
npm install
# build full version of summernote: dist/summernote.js
grunt build
# generate minified copy: dist/summernote.min.js, dist/summernote.css
grunt dist
```
At this point, you should now have a `build/` directory populated with everything you need to use summernote.
#### test summernote
run tests with PhantomJS
```bash
grunt test
```
#### start local server for developing summernote.
run local server with connect and watch.
```bash
# this will open a browser on http://localhost:3000.
grunt server
# If you change source code, automatically reload your page.
```
#### Coding convention
* JSHint: http://www.jshint.com/about/
* JSHint rule: https://github.com/HackerWins/summernote/blob/master/.jshintrc
### Contacts
* Email: [email protected]
* Twitter: http://twitter.com/hackerwins
### License
summernote may be freely distributed under the MIT license.