summernote-rails 0.6.6.0 → 0.6.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 19b45bb9daa2646246b1105c3bd4b0aa9af022a9
4
- data.tar.gz: 1a4d108c0c78d1087f76f63c8caaff9a369caa21
3
+ metadata.gz: 7c02b349b30cb6166bfedc07dce5d0acae4e3bae
4
+ data.tar.gz: bee6ade51443ad9daf85e2be658a1e52cdf740ea
5
5
  SHA512:
6
- metadata.gz: cd390d9edd16033ecccd36cdbe55e0d19663b1debfc24a6e9820d9cc19b8c969aec92641cc418ae6fd9881bf0c45c996abe5587191495aee7ec36e7de8470571
7
- data.tar.gz: 5ac15a12993e99f3443c6e92ea841e80952edbafcd4dbb42a96a806ac8341c8b8387b6b3f4f114cc7fe169e42a79d34f888dff6ae85f2a79193fd3bd075a6fd7
6
+ metadata.gz: 117085c2a7aa565af37a70dbc9b28eefbd0bcab17e91e1e3c10eca1c4f8ec0d536df1b5d2c487e1c283aa7c303c6bcaccaf0751740808eee8729e8db924b45d7
7
+ data.tar.gz: fcbbc94f20a79ba645c66177ec69cd32113a6cae2cf26b3976b37ef86efd39e1344d7113486fa740d4bee2b46ffa105e62564af5bd20f170ffa38a1ea0532cce
data/README.md CHANGED
@@ -26,21 +26,25 @@ $ bundle install
26
26
 
27
27
  ## Usage
28
28
 
29
- In app/assets/stylesheets/application.css.scss,
29
+ In app/assets/stylesheets/application.scss,
30
30
 
31
31
  ```css
32
- *= require font-awesome
33
- *= require summernote
32
+ @import "bootstrap";
33
+ @import "font-awesome";
34
+ @import "summernote";
34
35
  ```
35
36
 
36
- In app/assets/javascripts/application.js, you should add the following:
37
+ In app/assets/javascripts/application.js, you should add as follows:
37
38
 
38
39
  ```js
40
+ //= require ...
39
41
  //= require bootstrap
40
42
  //= require summernote
43
+ //= require ...
41
44
  ```
42
45
 
43
46
  Basic Example:
47
+
44
48
  ```html
45
49
  <div id="summernote">Hello Summernote</div>
46
50
 
@@ -50,10 +54,16 @@ Basic Example:
50
54
  });
51
55
  </script>
52
56
  ```
57
+ Or, if your want to use javascript with unobtrusive pattern, you can move the javascript script code lines to app/assets/javascripts/summernote_bootstraped.coffee as follows:
58
+
59
+ ```coffee
60
+ $ ->
61
+ $('#summernote').summernote()
62
+ ```
53
63
 
54
64
  Ideally, you would do it like this:
55
65
 
56
- ```
66
+ ```javscript
57
67
  # This goes into your main javascript file. Customize as you need.
58
68
 
59
69
  $('[data-provider="summernote"]').each(function(){
@@ -61,11 +71,31 @@ $('[data-provider="summernote"]').each(function(){
61
71
  })
62
72
  ```
63
73
 
64
- Then, if you are using simple_form, you can use the `:summernote` input type. This input types simply adds the `data-provider="summernote"` to the field.
74
+ Or, if you want to code in coffeescript,
65
75
 
76
+ ```coffeescript
77
+ $ ->
78
+ $('[data-provider="summernote"]').each ->
79
+ $(this).summernote()
66
80
  ```
67
- = simple_form_for(:example) do |f|
81
+
82
+ Then, if you are using simple_form, you can use the `:summernote` input type. This type simply adds the `data-provider="summernote"` to the field.
83
+
84
+ ```erb
85
+ <%= simple_form_for :example do | f | %>
86
+ ...
87
+ <%= f.input :text, as: :summernote %>
88
+ ...
89
+ <% end %>
90
+ ```
91
+
92
+ Or, if you prefer haml-style,
93
+
94
+ ```haml
95
+ = simple_form_for(:example) do | f |
96
+ ...
68
97
  = f.input :text, as: :summernote
98
+ ...
69
99
  ```
70
100
 
71
101
  If you are not using simple_form, then simply add the `data-provider="summernote"` to the input field yourself.
@@ -74,10 +104,12 @@ If you are not using simple_form, then simply add the `data-provider="summernote
74
104
 
75
105
  If you use i18n, you have to include language files. In `app/assets/javascripts/application.js`, you should add the following:
76
106
 
77
- ```js
107
+ ```javascript
78
108
  // load all locales
79
109
  //= require summernote/locales
80
110
 
111
+ // or
112
+
81
113
  // load specific locale(ko-KR)
82
114
  //= require summernote/locales/ko-KR
83
115
  ```
@@ -96,16 +128,24 @@ and update summernote option
96
128
  </script>
97
129
  ```
98
130
 
131
+ Also, you can move the above javascript code lines to app/assets/javascripts/summernote_bootstraped.coffee and add as follows:
132
+
133
+ ```coffee
134
+ $ ->
135
+ $('#summernote').summernote
136
+ lang: 'ko-KR'
137
+ ```
138
+
99
139
  ### Plugin
100
140
 
101
- If you use Plugin, you have to include plugin files. In `app/assets/javascripts/application.js`, you should add the following:
141
+ If you want to use a plugin, you have to include the corresponding file. In `app/assets/javascripts/application.js`, you should add the following:
102
142
 
103
143
  ```js
104
144
  // load video plugin
105
145
  //= require summernote/plugin/summernote-ext-video.js
106
146
  ```
107
147
 
108
- and update summernote option
148
+ and update summernote option.
109
149
 
110
150
  ```html
111
151
  <div id="summernote">Hello Summernote</div>
@@ -123,6 +163,23 @@ and update summernote option
123
163
  </script>
124
164
  ```
125
165
 
166
+ Also, you can move the above javascript code lines to app/assets/javascripts/summernote_bootstraped.coffee and add as follows:
167
+
168
+ ```coffee
169
+ $ ->
170
+ $('#summernote').summernote
171
+ toolbar : [
172
+ ...
173
+ [
174
+ 'group'
175
+ [
176
+ 'video'
177
+ ]
178
+ ]
179
+ ...
180
+ ]
181
+ ```
182
+
126
183
  * [plugin example](https://github.com/summernote/summernote/blob/develop/examples/plugin-video.html)
127
184
 
128
185
 
@@ -1,5 +1,5 @@
1
1
  module SummernoteRails
2
2
  module Rails
3
- VERSION = "0.6.6.0"
3
+ VERSION = "0.6.7.0"
4
4
  end
5
5
  end
@@ -1,5 +1,4 @@
1
1
  (function ($) {
2
- console.log('hit');
3
2
  $.extend($.summernote.lang, {
4
3
  'ko-KR': {
5
4
  font: {
@@ -0,0 +1,96 @@
1
+ (function ($) {
2
+ $.extend($.summernote.lang, {
3
+ 'pt-PT': {
4
+ font: {
5
+ bold: 'Negrito',
6
+ italic: 'Itálico',
7
+ underline: 'Sublinhado',
8
+ clear: 'Remover estilo da fonte',
9
+ height: 'Altura da linha',
10
+ name: 'Fonte',
11
+ strikethrough: 'Riscado',
12
+ size: 'Tamanho da fonte'
13
+ },
14
+ image: {
15
+ image: 'Imagem',
16
+ insert: 'Inserir imagem',
17
+ resizeFull: 'Redimensionar Completo',
18
+ resizeHalf: 'Redimensionar Metade',
19
+ resizeQuarter: 'Redimensionar Um Quarto',
20
+ floatLeft: 'Float Esquerda',
21
+ floatRight: 'Float Direita',
22
+ floatNone: 'Sem Float',
23
+ dragImageHere: 'Arraste uma imagem para aqui',
24
+ selectFromFiles: 'Selecione a partir dos arquivos',
25
+ url: 'Endereço da imagem'
26
+ },
27
+ link: {
28
+ link: 'Link',
29
+ insert: 'Inserir ligação',
30
+ unlink: 'Remover ligação',
31
+ edit: 'Editar',
32
+ textToDisplay: 'Texto para exibir',
33
+ url: 'Que endereço esta licação leva?',
34
+ openInNewWindow: 'Abrir numa nova janela'
35
+ },
36
+ table: {
37
+ table: 'Tabela'
38
+ },
39
+ hr: {
40
+ insert: 'Inserir linha horizontal'
41
+ },
42
+ style: {
43
+ style: 'Estilo',
44
+ normal: 'Normal',
45
+ blockquote: 'Citação',
46
+ pre: 'Código',
47
+ h1: 'Título 1',
48
+ h2: 'Título 2',
49
+ h3: 'Título 3',
50
+ h4: 'Título 4',
51
+ h5: 'Título 5',
52
+ h6: 'Título 6'
53
+ },
54
+ lists: {
55
+ unordered: 'Lista com marcadores',
56
+ ordered: 'Lista numerada'
57
+ },
58
+ options: {
59
+ help: 'Ajuda',
60
+ fullscreen: 'Janela Completa',
61
+ codeview: 'Ver código-fonte'
62
+ },
63
+ paragraph: {
64
+ paragraph: 'Parágrafo',
65
+ outdent: 'Menor tabulação',
66
+ indent: 'Maior tabulação',
67
+ left: 'Alinhar à esquerda',
68
+ center: 'Alinhar ao centro',
69
+ right: 'Alinha à direita',
70
+ justify: 'Justificado'
71
+ },
72
+ color: {
73
+ recent: 'Cor recente',
74
+ more: 'Mais cores',
75
+ background: 'Fundo',
76
+ foreground: 'Fonte',
77
+ transparent: 'Transparente',
78
+ setTransparent: 'Fundo transparente',
79
+ reset: 'Restaurar',
80
+ resetToDefault: 'Restaurar padrão'
81
+ },
82
+ shortcut: {
83
+ shortcuts: 'Atalhos do teclado',
84
+ close: 'Fechar',
85
+ textFormatting: 'Formatação de texto',
86
+ action: 'Ação',
87
+ paragraphFormatting: 'Formatação de parágrafo',
88
+ documentStyle: 'Estilo de documento'
89
+ },
90
+ history: {
91
+ undo: 'Desfazer',
92
+ redo: 'Refazer'
93
+ }
94
+ }
95
+ });
96
+ })(jQuery);
@@ -0,0 +1,253 @@
1
+ (function (factory) {
2
+ /* global define */
3
+ if (typeof define === 'function' && define.amd) {
4
+ // AMD. Register as an anonymous module.
5
+ define(['jquery'], factory);
6
+ } else {
7
+ // Browser globals: jQuery
8
+ factory(window.jQuery);
9
+ }
10
+ }(function ($) {
11
+ var range = $.summernote.core.range;
12
+ var list = $.summernote.core.list;
13
+
14
+ var KEY = {
15
+ UP: 38,
16
+ DOWN: 40,
17
+ ENTER: 13
18
+ };
19
+
20
+ var DROPDOWN_KEYCODES = [38, 40, 13];
21
+
22
+ /**
23
+ * @class plugin.hint
24
+ *
25
+ * Hello Plugin
26
+ */
27
+ $.summernote.addPlugin({
28
+ /** @property {String} name name of plugin */
29
+ name: 'hint',
30
+
31
+ /**
32
+ * @param {jQuery} $node
33
+ */
34
+ scrollTo: function ($node) {
35
+ var $parent = $node.parent();
36
+ $parent[0].scrollTop = $node[0].offsetTop - ($parent.innerHeight() / 2);
37
+ },
38
+
39
+ /**
40
+ * @param {jQuery} $popover
41
+ */
42
+ moveDown: function ($popover) {
43
+ var index = $popover.find('.active').index();
44
+ this.activate($popover, (index === -1) ? 0 : (index + 1) % $popover.children().length);
45
+ },
46
+
47
+ /**
48
+ * @param {jQuery} $popover
49
+ */
50
+ moveUp: function ($popover) {
51
+ var index = $popover.find('.active').index();
52
+ this.activate($popover, (index === -1) ? 0 : (index - 1) % $popover.children().length);
53
+ },
54
+
55
+ /**
56
+ * @param {jQuery} $popover
57
+ * @param {Number} i
58
+ */
59
+ activate: function ($popover, idx) {
60
+ idx = idx || 0;
61
+
62
+ if (idx < 0) {
63
+ idx = $popover.children().length - 1;
64
+ }
65
+
66
+ $popover.children().removeClass('active');
67
+ var $activeItem = $popover.children().eq(idx);
68
+ $activeItem.addClass('active');
69
+
70
+ this.scrollTo($activeItem);
71
+ },
72
+
73
+ /**
74
+ * @param {jQuery} $popover
75
+ */
76
+ replace: function ($popover) {
77
+ var wordRange = $popover.data('wordRange');
78
+ var $activeItem = $popover.find('.active');
79
+ var content = this.content($activeItem.html(), $activeItem.data('keyword'));
80
+
81
+ if (typeof content === 'string') {
82
+ content = document.createTextNode(content);
83
+ }
84
+
85
+ $popover.removeData('wordRange');
86
+
87
+ wordRange.insertNode(content);
88
+ range.createFromNode(content).collapse().select();
89
+ },
90
+
91
+ /**
92
+ * @param {String} keyword
93
+ * @return {Object|null}
94
+ */
95
+ searchKeyword: function (keyword) {
96
+ var triggerChar = keyword.charAt(0);
97
+
98
+ if (triggerChar === ':' && keyword.length > 1) {
99
+ var trigger = keyword.toLowerCase().replace(':', '');
100
+ return {
101
+ type: 'emoji',
102
+ list: $.grep(this.emojiKeys, function (item) {
103
+ return item.indexOf(trigger) === 0;
104
+ })
105
+ };
106
+ }
107
+
108
+ return null;
109
+ },
110
+
111
+ /**
112
+ * create items
113
+ *
114
+ * @param {Object} searchResult
115
+ * @param {String} searchResult.type
116
+ * @param {String[]} searchResult.list
117
+ * @return {jQuery[]}
118
+ */
119
+ createItems: function (searchResult) {
120
+ var items = [];
121
+ var list = searchResult.list;
122
+
123
+ for (var i = 0, len = list.length; i < len; i++) {
124
+ var $item = $('<a class="list-group-item"></a>');
125
+ $item.append(this.createItem(list[i]));
126
+ $item.data('keyword', list[i]);
127
+ items.push($item);
128
+ }
129
+
130
+ if (items.length) {
131
+ items[0].addClass('active');
132
+ }
133
+
134
+ return items;
135
+ },
136
+
137
+ /**
138
+ * create list item template
139
+ *
140
+ * @param {Object} item
141
+ * @returns {String}
142
+ */
143
+ createItem: function (item) {
144
+ var content = this.emojiInfo[item];
145
+ return '<img src="' + content + '" width="20" /> :' + item + ':';
146
+ },
147
+
148
+ /**
149
+ * create inserted content to add in summernote
150
+ *
151
+ * @param {String} html
152
+ * @param {String} keyword
153
+ * @return {Node|String}
154
+ */
155
+ content: function (html, item) {
156
+ var url = this.emojiInfo[item];
157
+
158
+ if (url) {
159
+ var $img = $('<img />').attr('src', url).css({
160
+ width : 20
161
+ });
162
+ return $img[0];
163
+ }
164
+
165
+ return html;
166
+ },
167
+
168
+ /**
169
+ * @return {Promise}
170
+ */
171
+ loadEmojis: function () {
172
+ var self = this;
173
+ return $.getJSON('https://api.github.com/emojis').then(function (data) {
174
+ self.emojiKeys = Object.keys(data);
175
+ self.emojiInfo = data;
176
+ });
177
+ },
178
+
179
+ init: function (layoutInfo) {
180
+ var self = this;
181
+
182
+ var $note = layoutInfo.holder();
183
+ var $popover = $('<div class="list-group" />').css({
184
+ position: 'absolute',
185
+ 'max-height': 300,
186
+ 'overflow-y': 'scroll',
187
+ 'display': 'none'
188
+ });
189
+
190
+ // FIXME We need a handler for unload resources.
191
+ $popover.on('click', '.list-group-item', function () {
192
+ self.replace($popover);
193
+
194
+ $popover.hide();
195
+ $note.summernote('focus');
196
+ });
197
+
198
+ $(document).on('click', function () {
199
+ $popover.hide();
200
+ });
201
+
202
+ $note.on('summernote.keydown', function (customEvent, nativeEvent) {
203
+ if ($popover.css('display') !== 'block') {
204
+ return;
205
+ }
206
+
207
+ if (nativeEvent.keyCode === KEY.DOWN) {
208
+ nativeEvent.preventDefault();
209
+ self.moveDown($popover);
210
+ } else if (nativeEvent.keyCode === KEY.UP) {
211
+ nativeEvent.preventDefault();
212
+ self.moveUp($popover);
213
+ } else if (nativeEvent.keyCode === KEY.ENTER) {
214
+ nativeEvent.preventDefault();
215
+ self.replace($popover);
216
+
217
+ $popover.hide();
218
+ $note.summernote('focus');
219
+ }
220
+ });
221
+
222
+ $note.on('summernote.keyup', function (customEvent, nativeEvent) {
223
+ if (DROPDOWN_KEYCODES.indexOf(nativeEvent.keyCode) === -1) {
224
+ var wordRange = $(this).summernote('createRange').getWordRange();
225
+ var result = self.searchKeyword(wordRange.toString());
226
+ if (!result || !result.list.length) {
227
+ $popover.hide();
228
+ return;
229
+ }
230
+
231
+ layoutInfo.popover().append($popover);
232
+
233
+ var rect = list.last(wordRange.getClientRects());
234
+ $popover.html(self.createItems(result)).css({
235
+ left: rect.left,
236
+ top: rect.top + rect.height
237
+ }).data('wordRange', wordRange).show();
238
+ }
239
+ });
240
+
241
+ this.loadEmojis();
242
+ },
243
+
244
+ // FIXME Summernote doesn't support event pipeline yet.
245
+ // - Plugin -> Base Code
246
+ events: {
247
+ ENTER: function () {
248
+ // prevent ENTER key
249
+ return false;
250
+ }
251
+ }
252
+ });
253
+ }));
@@ -1,12 +1,12 @@
1
1
  /**
2
- * Super simple wysiwyg editor on Bootstrap v0.6.6
2
+ * Super simple wysiwyg editor on Bootstrap v0.6.7
3
3
  * http://summernote.org/
4
4
  *
5
5
  * summernote.js
6
6
  * Copyright 2013-2015 Alan Hong. and other contributors
7
7
  * summernote may be freely distributed under the MIT license./
8
8
  *
9
- * Date: 2015-04-29T19:41Z
9
+ * Date: 2015-05-17T06:58Z
10
10
  */
11
11
  (function (factory) {
12
12
  /* global define */
@@ -105,6 +105,8 @@
105
105
  return originalWidth !== width;
106
106
  };
107
107
 
108
+ var userAgent = navigator.userAgent;
109
+
108
110
  /**
109
111
  * @class core.agent
110
112
  *
@@ -117,9 +119,12 @@
117
119
  /** @property {Boolean} [isMac=false] true if this agent is Mac */
118
120
  isMac: navigator.appVersion.indexOf('Mac') > -1,
119
121
  /** @property {Boolean} [isMSIE=false] true if this agent is a Internet Explorer */
120
- isMSIE: navigator.userAgent.indexOf('MSIE') > -1 || navigator.userAgent.indexOf('Trident') > -1,
122
+ isMSIE: /MSIE|Trident/i.test(userAgent),
121
123
  /** @property {Boolean} [isFF=false] true if this agent is a Firefox */
122
- isFF: navigator.userAgent.indexOf('Firefox') > -1,
124
+ isFF: /firefox/i.test(userAgent),
125
+ isWebkit: /webkit/i.test(userAgent),
126
+ /** @property {Boolean} [isSafari=false] true if this agent is a Safari */
127
+ isSafari: /safari/i.test(userAgent),
123
128
  /** @property {String} jqueryVersion current jQuery version string */
124
129
  jqueryVersion: parseFloat($.fn.jquery),
125
130
  isSupportAmd: isSupportAmd,
@@ -704,9 +709,12 @@
704
709
 
705
710
  if (len === 0) {
706
711
  return true;
707
- } else if (!dom.isText(node) && len === 1 && node.innerHTML === blankHTML) {
712
+ } else if (!isText(node) && len === 1 && node.innerHTML === blankHTML) {
708
713
  // ex) <p><br></p>, <span><br></span>
709
714
  return true;
715
+ } else if (list.all(node.childNodes, isText) && node.innerHTML === '') {
716
+ // ex) <p></p>, <span></span>
717
+ return true;
710
718
  }
711
719
 
712
720
  return false;
@@ -2128,7 +2136,7 @@
2128
2136
  if (!arguments.length) { // from Browser Selection
2129
2137
  if (agent.isW3CRangeSupport) {
2130
2138
  var selection = document.getSelection();
2131
- if (selection.rangeCount === 0) {
2139
+ if (!selection || selection.rangeCount === 0) {
2132
2140
  return null;
2133
2141
  } else if (dom.isBody(selection.anchorNode)) {
2134
2142
  // Firefox: returns entire body as range on initialization. We won't never need it.
@@ -2199,6 +2207,26 @@
2199
2207
  return this.create(sc, so, ec, eo);
2200
2208
  },
2201
2209
 
2210
+ /**
2211
+ * create WrappedRange from node after position
2212
+ *
2213
+ * @param {Node} node
2214
+ * @return {WrappedRange}
2215
+ */
2216
+ createFromNodeBefore: function (node) {
2217
+ return this.createFromNode(node).collapse(true);
2218
+ },
2219
+
2220
+ /**
2221
+ * create WrappedRange from node after position
2222
+ *
2223
+ * @param {Node} node
2224
+ * @return {WrappedRange}
2225
+ */
2226
+ createFromNodeAfter: function (node) {
2227
+ return this.createFromNode(node).collapse();
2228
+ },
2229
+
2202
2230
  /**
2203
2231
  * @method
2204
2232
  *
@@ -2243,7 +2271,7 @@
2243
2271
  */
2244
2272
  var defaults = {
2245
2273
  /** @property */
2246
- version: '0.6.6',
2274
+ version: '0.6.7',
2247
2275
 
2248
2276
  /**
2249
2277
  *
@@ -2308,7 +2336,7 @@
2308
2336
  ['font', ['bold', 'italic', 'underline', 'clear']],
2309
2337
  // ['font', ['bold', 'italic', 'underline', 'strikethrough', 'superscript', 'subscript', 'clear']],
2310
2338
  ['fontname', ['fontname']],
2311
- // ['fontsize', ['fontsize']],
2339
+ ['fontsize', ['fontsize']],
2312
2340
  ['color', ['color']],
2313
2341
  ['para', ['ul', 'ol', 'paragraph']],
2314
2342
  ['height', ['height']],
@@ -2318,6 +2346,8 @@
2318
2346
  ['help', ['help']]
2319
2347
  ],
2320
2348
 
2349
+ plugin : { },
2350
+
2321
2351
  // air mode: inline editor
2322
2352
  airMode: false,
2323
2353
  // airPopover: [
@@ -2698,6 +2728,15 @@
2698
2728
  isEdit: function (keyCode) {
2699
2729
  return list.contains([8, 9, 13, 32], keyCode);
2700
2730
  },
2731
+ /**
2732
+ * @method isMove
2733
+ *
2734
+ * @param {Number} keyCode
2735
+ * @return {Boolean}
2736
+ */
2737
+ isMove: function (keyCode) {
2738
+ return list.contains([37, 38, 39, 40], keyCode);
2739
+ },
2701
2740
  /**
2702
2741
  * @property {Object} nameFromCode
2703
2742
  * @property {String} nameFromCode.8 "BACKSPACE"
@@ -2838,7 +2877,7 @@
2838
2877
  var onlyPartialContains = !!(options && options.onlyPartialContains);
2839
2878
 
2840
2879
  if (rng.isCollapsed()) {
2841
- return rng.insertNode(dom.create(nodeName));
2880
+ return [rng.insertNode(dom.create(nodeName))];
2842
2881
  }
2843
2882
 
2844
2883
  var pred = dom.makePredByNodeName(nodeName);
@@ -3272,6 +3311,9 @@
3272
3311
  };
3273
3312
  };
3274
3313
 
3314
+
3315
+ var KEY_BOGUS = 'bogus';
3316
+
3275
3317
  /**
3276
3318
  * @class editing.Editor
3277
3319
  *
@@ -3294,7 +3336,7 @@
3294
3336
  * @return {WrappedRange}
3295
3337
  */
3296
3338
  this.createRange = function ($editable) {
3297
- $editable.focus();
3339
+ this.focus($editable);
3298
3340
  return range.create();
3299
3341
  };
3300
3342
 
@@ -3307,7 +3349,7 @@
3307
3349
  * @param {Boolean} [thenCollapse=false]
3308
3350
  */
3309
3351
  this.saveRange = function ($editable, thenCollapse) {
3310
- $editable.focus();
3352
+ this.focus($editable);
3311
3353
  $editable.data('range', range.create());
3312
3354
  if (thenCollapse) {
3313
3355
  range.create().collapse().select();
@@ -3341,7 +3383,7 @@
3341
3383
  var rng = $editable.data('range');
3342
3384
  if (rng) {
3343
3385
  rng.select();
3344
- $editable.focus();
3386
+ this.focus($editable);
3345
3387
  }
3346
3388
  };
3347
3389
 
@@ -3408,6 +3450,7 @@
3408
3450
  triggerOnChange($editable);
3409
3451
  };
3410
3452
 
3453
+ var self = this;
3411
3454
  /**
3412
3455
  * @method beforeCommand
3413
3456
  * before command
@@ -3415,6 +3458,8 @@
3415
3458
  */
3416
3459
  var beforeCommand = this.beforeCommand = function ($editable) {
3417
3460
  triggerOnBeforeChange($editable);
3461
+ // keep focus on editable before command execution
3462
+ self.focus($editable);
3418
3463
  };
3419
3464
 
3420
3465
  /**
@@ -3564,7 +3609,7 @@
3564
3609
  * @param {Object} options
3565
3610
  */
3566
3611
  this.tab = function ($editable, options) {
3567
- var rng = range.create();
3612
+ var rng = this.createRange($editable);
3568
3613
  if (rng.isCollapsed() && rng.isOnCell()) {
3569
3614
  table.tab(rng);
3570
3615
  } else {
@@ -3580,8 +3625,8 @@
3580
3625
  * handle shift+tab key
3581
3626
  *
3582
3627
  */
3583
- this.untab = function () {
3584
- var rng = range.create();
3628
+ this.untab = function ($editable) {
3629
+ var rng = this.createRange($editable);
3585
3630
  if (rng.isCollapsed() && rng.isOnCell()) {
3586
3631
  table.tab(rng, true);
3587
3632
  }
@@ -3652,13 +3697,13 @@
3652
3697
  width: Math.min($editable.width(), $image.width())
3653
3698
  });
3654
3699
  range.create().insertNode($image[0]);
3655
- range.createFromNode($image[0]).collapse().select();
3700
+ range.createFromNodeAfter($image[0]).select();
3656
3701
  afterCommand($editable);
3657
3702
  }).fail(function () {
3658
- var callbacks = $editable.data('callbacks');
3659
- if (callbacks.onImageUploadError) {
3660
- callbacks.onImageUploadError();
3661
- }
3703
+ var $holder = dom.makeLayoutInfo($editable).holder();
3704
+ handler.bindCustomEvent(
3705
+ $holder, $editable.data('callbacks'), 'image.upload.error'
3706
+ )();
3662
3707
  });
3663
3708
  };
3664
3709
 
@@ -3670,9 +3715,8 @@
3670
3715
  */
3671
3716
  this.insertNode = function ($editable, node) {
3672
3717
  beforeCommand($editable);
3673
- var rng = this.createRange($editable);
3674
- rng.insertNode(node);
3675
- range.createFromNode(node).collapse().select();
3718
+ range.create().insertNode(node);
3719
+ range.createFromNodeAfter(node).select();
3676
3720
  afterCommand($editable);
3677
3721
  };
3678
3722
 
@@ -3683,8 +3727,7 @@
3683
3727
  */
3684
3728
  this.insertText = function ($editable, text) {
3685
3729
  beforeCommand($editable);
3686
- var rng = this.createRange($editable);
3687
- var textNode = rng.insertNode(dom.createText(text));
3730
+ var textNode = range.create().insertNode(dom.createText(text));
3688
3731
  range.create(textNode, dom.nodeLength(textNode)).select();
3689
3732
  afterCommand($editable);
3690
3733
  };
@@ -3696,9 +3739,8 @@
3696
3739
  */
3697
3740
  this.pasteHTML = function ($editable, markup) {
3698
3741
  beforeCommand($editable);
3699
- var rng = this.createRange($editable);
3700
- var contents = rng.pasteHTML(markup);
3701
- range.createFromNode(list.last(contents)).collapse().select();
3742
+ var contents = range.create().pasteHTML(markup);
3743
+ range.createFromNodeAfter(list.last(contents)).select();
3702
3744
  afterCommand($editable);
3703
3745
  };
3704
3746
 
@@ -3739,17 +3781,54 @@
3739
3781
  * @param {String} value - px
3740
3782
  */
3741
3783
  this.fontSize = function ($editable, value) {
3742
- beforeCommand($editable);
3784
+ var rng = range.create();
3785
+ var isCollapsed = rng.isCollapsed();
3743
3786
 
3744
- var rng = this.createRange($editable);
3745
- var spans = style.styleNodes(rng);
3746
- $.each(spans, function (idx, span) {
3747
- $(span).css({
3787
+ if (isCollapsed) {
3788
+ var spans = style.styleNodes(rng);
3789
+ var firstSpan = list.head(spans);
3790
+
3791
+ $(spans).css({
3748
3792
  'font-size': value + 'px'
3749
3793
  });
3750
- });
3751
3794
 
3752
- afterCommand($editable);
3795
+ // [workaround] added styled bogus span for style
3796
+ // - also bogus character needed for cursor position
3797
+ if (firstSpan && !dom.nodeLength(firstSpan)) {
3798
+ firstSpan.innerHTML = dom.ZERO_WIDTH_NBSP_CHAR;
3799
+ range.createFromNodeAfter(firstSpan.firstChild).select();
3800
+ $editable.data(KEY_BOGUS, firstSpan);
3801
+ }
3802
+ } else {
3803
+ beforeCommand($editable);
3804
+ $(style.styleNodes(rng)).css({
3805
+ 'font-size': value + 'px'
3806
+ });
3807
+ afterCommand($editable);
3808
+ }
3809
+ };
3810
+
3811
+ /**
3812
+ * remove bogus node and character
3813
+ */
3814
+ this.removeBogus = function ($editable) {
3815
+ var bogusNode = $editable.data(KEY_BOGUS);
3816
+ if (!bogusNode) {
3817
+ return;
3818
+ }
3819
+
3820
+ var textNode = list.find(list.from(bogusNode.childNodes), dom.isText);
3821
+
3822
+ var bogusCharIdx = textNode.nodeValue.indexOf(dom.ZERO_WIDTH_NBSP_CHAR);
3823
+ if (bogusCharIdx !== -1) {
3824
+ textNode.deleteData(bogusCharIdx, 1);
3825
+ }
3826
+
3827
+ if (dom.isEmpty(bogusNode)) {
3828
+ dom.remove(bogusNode);
3829
+ }
3830
+
3831
+ $editable.removeData(KEY_BOGUS);
3753
3832
  };
3754
3833
 
3755
3834
  /**
@@ -3773,7 +3852,7 @@
3773
3852
  * @param {jQuery} $editable
3774
3853
  */
3775
3854
  this.unlink = function ($editable) {
3776
- var rng = range.create();
3855
+ var rng = this.createRange();
3777
3856
  if (rng.isOnAnchor()) {
3778
3857
  var anchor = dom.ancestor(rng.sc, dom.isAnchor);
3779
3858
  rng = range.createFromNode(anchor);
@@ -3805,11 +3884,11 @@
3805
3884
  linkUrl = options.onCreateLink(linkUrl);
3806
3885
  }
3807
3886
 
3808
- var anchors;
3887
+ var anchors = [];
3809
3888
  if (isTextChanged) {
3810
3889
  // Create a new link when text changed.
3811
3890
  var anchor = rng.insertNode($('<A>' + linkText + '</A>')[0]);
3812
- anchors = [anchor];
3891
+ anchors.push(anchor);
3813
3892
  } else {
3814
3893
  anchors = style.styleNodes(rng, {
3815
3894
  nodeName: 'A',
@@ -3827,9 +3906,9 @@
3827
3906
  }
3828
3907
  });
3829
3908
 
3830
- var startRange = range.createFromNode(list.head(anchors)).collapse(true);
3909
+ var startRange = range.createFromNodeBefore(list.head(anchors));
3831
3910
  var startPoint = startRange.getStartPoint();
3832
- var endRange = range.createFromNode(list.last(anchors)).collapse();
3911
+ var endRange = range.createFromNodeAfter(list.last(anchors));
3833
3912
  var endPoint = endRange.getEndPoint();
3834
3913
 
3835
3914
  range.create(
@@ -3852,7 +3931,7 @@
3852
3931
  * @return {String} [return.url=""]
3853
3932
  */
3854
3933
  this.getLinkInfo = function ($editable) {
3855
- $editable.focus();
3934
+ this.focus($editable);
3856
3935
 
3857
3936
  var rng = range.create().expand(dom.isAnchor);
3858
3937
 
@@ -3897,8 +3976,7 @@
3897
3976
  var dimension = sDim.split('x');
3898
3977
  beforeCommand($editable);
3899
3978
 
3900
- var rng = range.create();
3901
- rng = rng.deleteContents();
3979
+ var rng = range.create().deleteContents();
3902
3980
  rng.insertNode(table.createTable(dimension[0], dimension[1]));
3903
3981
  afterCommand($editable);
3904
3982
  };
@@ -3989,7 +4067,7 @@
3989
4067
 
3990
4068
  handler.bindCustomEvent(
3991
4069
  $(), $editable.data('callbacks'), 'media.delete'
3992
- ).call($target, this.$editable);
4070
+ )($target, $editable);
3993
4071
 
3994
4072
  afterCommand($editable);
3995
4073
  };
@@ -4003,8 +4081,11 @@
4003
4081
  $editable.focus();
4004
4082
 
4005
4083
  // [workaround] for firefox bug http://goo.gl/lVfAaI
4006
- if (agent.isFF) {
4007
- range.createFromNode($editable[0].firstChild || $editable[0]).collapse().select();
4084
+ if (agent.isFF && !range.create().isOnEditable()) {
4085
+ range.createFromNode($editable[0])
4086
+ .normalize()
4087
+ .collapse()
4088
+ .select();
4008
4089
  }
4009
4090
  };
4010
4091
  };
@@ -4910,6 +4991,7 @@
4910
4991
  $linkText.val(linkInfo.text);
4911
4992
 
4912
4993
  $linkText.on('input', function () {
4994
+ toggleBtn($linkBtn, $linkText.val() && $linkUrl.val());
4913
4995
  // if linktext was modified by keyup,
4914
4996
  // stop cloning text from linkUrl
4915
4997
  linkInfo.text = $linkText.val();
@@ -4922,7 +5004,7 @@
4922
5004
  }
4923
5005
 
4924
5006
  $linkUrl.on('input', function () {
4925
- toggleBtn($linkBtn, $linkUrl.val());
5007
+ toggleBtn($linkBtn, $linkText.val() && $linkUrl.val());
4926
5008
  // display same link on `Text to display` input
4927
5009
  // when create a new link
4928
5010
  if (!linkInfo.text) {
@@ -5273,6 +5355,12 @@
5273
5355
  }
5274
5356
  };
5275
5357
 
5358
+ var hKeyupAndMouseup = function (event) {
5359
+ var layoutInfo = dom.makeLayoutInfo(event.currentTarget || event.target);
5360
+ modules.editor.removeBogus(layoutInfo.editable());
5361
+ hToolbarAndPopoverUpdate(event);
5362
+ };
5363
+
5276
5364
  var hToolbarAndPopoverUpdate = function (event) {
5277
5365
  // delay for range after mouseup
5278
5366
  setTimeout(function () {
@@ -5290,7 +5378,7 @@
5290
5378
  }, 0);
5291
5379
  };
5292
5380
 
5293
- var hScroll = function (event) {
5381
+ var hScrollAndBlur = function (event) {
5294
5382
  var layoutInfo = dom.makeLayoutInfo(event.currentTarget || event.target);
5295
5383
  //hide popover and handle when scrolled
5296
5384
  modules.popover.hide(layoutInfo.popover());
@@ -5417,13 +5505,23 @@
5417
5505
  keys.push(keyName);
5418
5506
  }
5419
5507
 
5420
- var eventName = keyMap[keys.join('+')];
5508
+ var pluginEvent;
5509
+ var keyString = keys.join('+');
5510
+ var eventName = keyMap[keyString];
5421
5511
  if (eventName) {
5422
- if ($.summernote.pluginEvents[eventName]) {
5423
- var plugin = $.summernote.pluginEvents[eventName];
5424
- if ($.isFunction(plugin)) {
5425
- plugin(event, modules.editor, layoutInfo);
5512
+ // FIXME Summernote doesn't support event pipeline yet.
5513
+ // - Plugin -> Base Code
5514
+ pluginEvent = $.summernote.pluginEvents[keyString];
5515
+ if ($.isFunction(pluginEvent)) {
5516
+ if (pluginEvent(event, modules.editor, layoutInfo)) {
5517
+ return false;
5426
5518
  }
5519
+ }
5520
+
5521
+ pluginEvent = $.summernote.pluginEvents[eventName];
5522
+
5523
+ if ($.isFunction(pluginEvent)) {
5524
+ pluginEvent(event, modules.editor, layoutInfo);
5427
5525
  } else if (modules.editor[eventName]) {
5428
5526
  modules.editor[eventName]($editable, $editor.data('options'));
5429
5527
  event.preventDefault();
@@ -5449,8 +5547,10 @@
5449
5547
  this.bindKeyMap(layoutInfo, options.keyMap[agent.isMac ? 'mac' : 'pc']);
5450
5548
  }
5451
5549
  layoutInfo.editable().on('mousedown', hMousedown);
5452
- layoutInfo.editable().on('keyup mouseup', hToolbarAndPopoverUpdate);
5453
- layoutInfo.editable().on('scroll', hScroll);
5550
+ layoutInfo.editable().on('keyup mouseup', hKeyupAndMouseup);
5551
+ layoutInfo.editable().on('scroll blur', hScrollAndBlur);
5552
+
5553
+ // handler for clipboard
5454
5554
  modules.clipboard.attach(layoutInfo, options);
5455
5555
 
5456
5556
  // handler for handle and popover
@@ -5519,13 +5619,7 @@
5519
5619
  // Textarea: auto filling the code before form submit.
5520
5620
  if (dom.isTextarea(list.head(layoutInfo.holder()))) {
5521
5621
  layoutInfo.holder().closest('form').submit(function () {
5522
- var contents = layoutInfo.holder().code();
5523
- layoutInfo.holder().val(contents);
5524
-
5525
- // callback on submit
5526
- if (options.onsubmit) {
5527
- options.onsubmit(contents);
5528
- }
5622
+ layoutInfo.holder().val(layoutInfo.holder().code());
5529
5623
  });
5530
5624
  }
5531
5625
  };
@@ -5564,7 +5658,6 @@
5564
5658
  bindCustomEvent($holder, callbacks, 'change')($editable.html(), $editable);
5565
5659
  });
5566
5660
 
5567
- // callbacks for advanced features (camel)
5568
5661
  if (!options.airMode) {
5569
5662
  layoutInfo.toolbar().click(bindCustomEvent($holder, callbacks, 'toolbar.click'));
5570
5663
  layoutInfo.popover().click(bindCustomEvent($holder, callbacks, 'popover.click'));
@@ -5774,7 +5867,7 @@
5774
5867
  '</span>';
5775
5868
  return tplButton(label, {
5776
5869
  title: lang.font.name,
5777
- dropdown: '<ul class="dropdown-menu">' + items + '</ul>'
5870
+ dropdown: '<ul class="dropdown-menu note-check">' + items + '</ul>'
5778
5871
  });
5779
5872
  },
5780
5873
  fontsize: function (lang, options) {
@@ -5787,7 +5880,7 @@
5787
5880
  var label = '<span class="note-current-fontsize">11</span>';
5788
5881
  return tplButton(label, {
5789
5882
  title: lang.font.size,
5790
- dropdown: '<ul class="dropdown-menu">' + items + '</ul>'
5883
+ dropdown: '<ul class="dropdown-menu note-check">' + items + '</ul>'
5791
5884
  });
5792
5885
  },
5793
5886
  color: function (lang, options) {
@@ -5930,7 +6023,7 @@
5930
6023
 
5931
6024
  return tplIconButton(options.iconPrefix + 'text-height', {
5932
6025
  title: lang.font.height,
5933
- dropdown: '<ul class="dropdown-menu">' + items + '</ul>'
6026
+ dropdown: '<ul class="dropdown-menu note-check">' + items + '</ul>'
5934
6027
  });
5935
6028
 
5936
6029
  },
@@ -6257,7 +6350,7 @@
6257
6350
  '<div class="title">' + lang.shortcut.shortcuts + '</div>' +
6258
6351
  (agent.isMac ? tplShortcutTable(lang, options) : replaceMacKeys(tplShortcutTable(lang, options))) +
6259
6352
  '<p class="text-center">' +
6260
- '<a href="//summernote.org/" target="_blank">Summernote 0.6.6</a> · ' +
6353
+ '<a href="//summernote.org/" target="_blank">Summernote 0.6.7</a> · ' +
6261
6354
  '<a href="//github.com/summernote/summernote" target="_blank">Project</a> · ' +
6262
6355
  '<a href="//github.com/summernote/summernote/issues" target="_blank">Issues</a>' +
6263
6356
  '</p>';
@@ -6616,6 +6709,7 @@
6616
6709
  */
6617
6710
  core: {
6618
6711
  agent: agent,
6712
+ list : list,
6619
6713
  dom: dom,
6620
6714
  range: range
6621
6715
  },
@@ -6759,16 +6853,28 @@
6759
6853
  // - {Object}: init options
6760
6854
  var type = $.type(list.head(arguments));
6761
6855
  var isExternalAPICalled = type === 'string';
6762
- var isInitOptions = type === 'object';
6856
+ var hasInitOptions = type === 'object';
6763
6857
 
6764
6858
  // extend default options with custom user options
6765
- var options = isInitOptions ? list.head(arguments) : {};
6859
+ var options = hasInitOptions ? list.head(arguments) : {};
6860
+
6766
6861
  options = $.extend({}, $.summernote.options, options);
6767
6862
 
6768
6863
  // Include langInfo in options for later use, e.g. for image drag-n-drop
6769
6864
  // Setup language info with en-US as default
6770
6865
  options.langInfo = $.extend(true, {}, $.summernote.lang['en-US'], $.summernote.lang[options.lang]);
6771
6866
 
6867
+ // override plugin options
6868
+ if (!isExternalAPICalled && hasInitOptions) {
6869
+ for (var i = 0, len = $.summernote.plugins.length; i < len; i++) {
6870
+ var plugin = $.summernote.plugins[i];
6871
+
6872
+ if (options.plugin[plugin.name]) {
6873
+ $.summernote.plugins[i] = $.extend(true, plugin, options.plugin[plugin.name]);
6874
+ }
6875
+ }
6876
+ }
6877
+
6772
6878
  this.each(function (idx, holder) {
6773
6879
  var $holder = $(holder);
6774
6880
 
@@ -6777,6 +6883,7 @@
6777
6883
  renderer.createLayout($holder, options);
6778
6884
 
6779
6885
  var layoutInfo = renderer.layoutInfoFromHolder($holder);
6886
+ $holder.data('layoutInfo', layoutInfo);
6780
6887
 
6781
6888
  eventHandler.attach(layoutInfo, options);
6782
6889
  eventHandler.attachCustomEvent(layoutInfo, options);
@@ -6784,11 +6891,6 @@
6784
6891
  }
6785
6892
  });
6786
6893
 
6787
- // callback on init
6788
- if (!isExternalAPICalled && this.length && options.oninit) {
6789
- options.oninit();
6790
- }
6791
-
6792
6894
  var $first = this.first();
6793
6895
  if ($first.length) {
6794
6896
  var layoutInfo = renderer.layoutInfoFromHolder($first);
@@ -1 +1 @@
1
- .note-editor{position:relative;border:1px solid #a9a9a9}.note-editor .note-dropzone{position:absolute;z-index:100;display:none;color:#87cefa;background-color:white;border:2px dashed #87cefa;opacity:.95;pointer-event:none}.note-editor .note-dropzone .note-dropzone-message{display:table-cell;font-size:28px;font-weight:bold;text-align:center;vertical-align:middle}.note-editor .note-dropzone.hover{color:#098ddf;border:2px dashed #098ddf}.note-editor.dragover .note-dropzone{display:table}.note-editor .note-toolbar{background-color:#f5f5f5;border-bottom:1px solid #a9a9a9}.note-editor.fullscreen{position:fixed;top:0;left:0;z-index:1050;width:100%}.note-editor.fullscreen .note-editable{background-color:white}.note-editor.fullscreen .note-resizebar{display:none}.note-editor.codeview .note-editable{display:none}.note-editor.codeview .note-codable{display:block}.note-editor .note-statusbar{background-color:#f5f5f5}.note-editor .note-statusbar .note-resizebar{width:100%;height:8px;cursor:ns-resize;border-top:1px solid #a9a9a9}.note-editor .note-statusbar .note-resizebar .note-icon-bar{width:20px;margin:1px auto;border-top:1px solid #a9a9a9}.note-editor .note-editable[contenteditable=true]:empty:not(:focus):before{color:#a9a9a9;content:attr(data-placeholder)}.note-editor .note-editable{padding:10px;overflow:auto;outline:0}.note-editor .note-editable[contenteditable="false"]{background-color:#e5e5e5}.note-editor .note-codable{display:none;width:100%;padding:10px;margin-bottom:0;font-family:Menlo,Monaco,monospace,sans-serif;font-size:14px;color:#ccc;background-color:#222;border:0;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;box-shadow:none;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;resize:none}.note-air-editor{outline:0}.note-popover .popover{max-width:none}.note-popover .popover .popover-content a{display:inline-block;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.note-popover .popover .arrow{left:20px}.note-popover .popover .popover-content,.note-toolbar{padding:0 0 5px 5px;margin:0}.note-popover .popover .popover-content>.btn-group,.note-toolbar>.btn-group{margin-top:5px;margin-right:5px;margin-left:0}.note-popover .popover .popover-content .btn-group .note-table,.note-toolbar .btn-group .note-table{min-width:0;padding:5px}.note-popover .popover .popover-content .btn-group .note-table .note-dimension-picker,.note-toolbar .btn-group .note-table .note-dimension-picker{font-size:18px}.note-popover .popover .popover-content .btn-group .note-table .note-dimension-picker .note-dimension-picker-mousecatcher,.note-toolbar .btn-group .note-table .note-dimension-picker .note-dimension-picker-mousecatcher{position:absolute!important;z-index:3;width:10em;height:10em;cursor:pointer}.note-popover .popover .popover-content .btn-group .note-table .note-dimension-picker .note-dimension-picker-unhighlighted,.note-toolbar .btn-group .note-table .note-dimension-picker .note-dimension-picker-unhighlighted{position:relative!important;z-index:1;width:5em;height:5em;background:url('') repeat}.note-popover .popover .popover-content .btn-group .note-table .note-dimension-picker .note-dimension-picker-highlighted,.note-toolbar .btn-group .note-table .note-dimension-picker .note-dimension-picker-highlighted{position:absolute!important;z-index:2;width:1em;height:1em;background:url('') repeat}.note-popover .popover .popover-content .note-style h1,.note-toolbar .note-style h1,.note-popover .popover .popover-content .note-style h2,.note-toolbar .note-style h2,.note-popover .popover .popover-content .note-style h3,.note-toolbar .note-style h3,.note-popover .popover .popover-content .note-style h4,.note-toolbar .note-style h4,.note-popover .popover .popover-content .note-style h5,.note-toolbar .note-style h5,.note-popover .popover .popover-content .note-style h6,.note-toolbar .note-style h6,.note-popover .popover .popover-content .note-style blockquote,.note-toolbar .note-style blockquote{margin:0}.note-popover .popover .popover-content .note-color .dropdown-toggle,.note-toolbar .note-color .dropdown-toggle{width:20px;padding-left:5px}.note-popover .popover .popover-content .note-color .dropdown-menu,.note-toolbar .note-color .dropdown-menu{min-width:340px}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group,.note-toolbar .note-color .dropdown-menu .btn-group{margin:0}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group:first-child,.note-toolbar .note-color .dropdown-menu .btn-group:first-child{margin:0 5px}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group .note-palette-title,.note-toolbar .note-color .dropdown-menu .btn-group .note-palette-title{margin:2px 7px;font-size:12px;text-align:center;border-bottom:1px solid #eee}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group .note-color-reset,.note-toolbar .note-color .dropdown-menu .btn-group .note-color-reset{padding:0 3px;margin:3px;font-size:11px;cursor:pointer;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group .note-color-row,.note-toolbar .note-color .dropdown-menu .btn-group .note-color-row{height:20px}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group .note-color-reset:hover,.note-toolbar .note-color .dropdown-menu .btn-group .note-color-reset:hover{background:#eee}.note-popover .popover .popover-content .note-para .dropdown-menu,.note-toolbar .note-para .dropdown-menu{min-width:216px;padding:5px}.note-popover .popover .popover-content .note-para .dropdown-menu>div:first-child,.note-toolbar .note-para .dropdown-menu>div:first-child{margin-right:5px}.note-popover .popover .popover-content .dropdown-menu,.note-toolbar .dropdown-menu{min-width:90px}.note-popover .popover .popover-content .dropdown-menu.right,.note-toolbar .dropdown-menu.right{right:0;left:auto}.note-popover .popover .popover-content .dropdown-menu.right::before,.note-toolbar .dropdown-menu.right::before{right:9px;left:auto!important}.note-popover .popover .popover-content .dropdown-menu.right::after,.note-toolbar .dropdown-menu.right::after{right:10px;left:auto!important}.note-popover .popover .popover-content .dropdown-menu li a i,.note-toolbar .dropdown-menu li a i{color:deepskyblue;visibility:hidden}.note-popover .popover .popover-content .dropdown-menu li a.checked i,.note-toolbar .dropdown-menu li a.checked i{visibility:visible}.note-popover .popover .popover-content .note-fontsize-10,.note-toolbar .note-fontsize-10{font-size:10px}.note-popover .popover .popover-content .note-color-palette,.note-toolbar .note-color-palette{line-height:1}.note-popover .popover .popover-content .note-color-palette div .note-color-btn,.note-toolbar .note-color-palette div .note-color-btn{width:20px;height:20px;padding:0;margin:0;border:1px solid #fff}.note-popover .popover .popover-content .note-color-palette div .note-color-btn:hover,.note-toolbar .note-color-palette div .note-color-btn:hover{border:1px solid #000}.note-dialog>div{display:none}.note-dialog .form-group{margin-right:0;margin-left:0}.note-dialog .note-modal-form{margin:0}.note-dialog .note-image-dialog .note-dropzone{min-height:100px;margin-bottom:10px;font-size:30px;line-height:4;color:lightgray;text-align:center;border:4px dashed lightgray}.note-dialog .note-help-dialog{font-size:12px;color:#ccc;background:transparent;background-color:#222!important;border:0;-webkit-opacity:.9;-khtml-opacity:.9;-moz-opacity:.9;opacity:.9;-ms-filter:alpha(opacity=90);filter:alpha(opacity=90)}.note-dialog .note-help-dialog .modal-content{background:transparent;border:1px solid white;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.note-dialog .note-help-dialog a{font-size:12px;color:white}.note-dialog .note-help-dialog .title{padding-bottom:5px;margin-bottom:10px;font-size:14px;font-weight:bold;color:white;border-bottom:white 1px solid}.note-dialog .note-help-dialog .modal-close{font-size:14px;color:#dd0;cursor:pointer}.note-dialog .note-help-dialog .text-center{margin:10px 0 0}.note-dialog .note-help-dialog .note-shortcut{padding-top:8px;padding-bottom:8px}.note-dialog .note-help-dialog .note-shortcut-row{margin-right:-5px;margin-left:-5px}.note-dialog .note-help-dialog .note-shortcut-col{padding-right:5px;padding-left:5px}.note-dialog .note-help-dialog .note-shortcut-title{font-size:13px;font-weight:bold;color:#dd0}.note-dialog .note-help-dialog .note-shortcut-key{font-family:"Courier New";color:#dd0;text-align:right}.note-handle .note-control-selection{position:absolute;display:none;border:1px solid black}.note-handle .note-control-selection>div{position:absolute}.note-handle .note-control-selection .note-control-selection-bg{width:100%;height:100%;background-color:black;-webkit-opacity:.3;-khtml-opacity:.3;-moz-opacity:.3;opacity:.3;-ms-filter:alpha(opacity=30);filter:alpha(opacity=30)}.note-handle .note-control-selection .note-control-handle{width:7px;height:7px;border:1px solid black}.note-handle .note-control-selection .note-control-holder{width:7px;height:7px;border:1px solid black}.note-handle .note-control-selection .note-control-sizing{width:7px;height:7px;background-color:white;border:1px solid black}.note-handle .note-control-selection .note-control-nw{top:-5px;left:-5px;border-right:0;border-bottom:0}.note-handle .note-control-selection .note-control-ne{top:-5px;right:-5px;border-bottom:0;border-left:none}.note-handle .note-control-selection .note-control-sw{bottom:-5px;left:-5px;border-top:0;border-right:0}.note-handle .note-control-selection .note-control-se{right:-5px;bottom:-5px;cursor:se-resize}.note-handle .note-control-selection .note-control-selection-info{right:0;bottom:0;padding:5px;margin:5px;font-size:12px;color:white;background-color:black;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;-webkit-opacity:.7;-khtml-opacity:.7;-moz-opacity:.7;opacity:.7;-ms-filter:alpha(opacity=70);filter:alpha(opacity=70)}
1
+ .note-editor{position:relative;border:1px solid #a9a9a9}.note-editor .note-dropzone{position:absolute;z-index:100;display:none;color:#87cefa;background-color:white;border:2px dashed #87cefa;opacity:.95;pointer-event:none}.note-editor .note-dropzone .note-dropzone-message{display:table-cell;font-size:28px;font-weight:bold;text-align:center;vertical-align:middle}.note-editor .note-dropzone.hover{color:#098ddf;border:2px dashed #098ddf}.note-editor.dragover .note-dropzone{display:table}.note-editor .note-toolbar{background-color:#f5f5f5;border-bottom:1px solid #a9a9a9}.note-editor.fullscreen{position:fixed;top:0;left:0;z-index:1050;width:100%}.note-editor.fullscreen .note-editable{background-color:white}.note-editor.fullscreen .note-resizebar{display:none}.note-editor.codeview .note-editable{display:none}.note-editor.codeview .note-codable{display:block}.note-editor .note-statusbar{background-color:#f5f5f5}.note-editor .note-statusbar .note-resizebar{width:100%;height:8px;cursor:ns-resize;border-top:1px solid #a9a9a9}.note-editor .note-statusbar .note-resizebar .note-icon-bar{width:20px;margin:1px auto;border-top:1px solid #a9a9a9}.note-editor .note-editable[contenteditable=true]:empty:not(:focus):before{color:#a9a9a9;content:attr(data-placeholder)}.note-editor .note-editable{padding:10px;overflow:auto;outline:0}.note-editor .note-editable[contenteditable="false"]{background-color:#e5e5e5}.note-editor .note-codable{display:none;width:100%;padding:10px;margin-bottom:0;font-family:Menlo,Monaco,monospace,sans-serif;font-size:14px;color:#ccc;background-color:#222;border:0;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;box-shadow:none;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;resize:none}.note-air-editor{outline:0}.note-popover .popover{max-width:none}.note-popover .popover .popover-content a{display:inline-block;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.note-popover .popover .arrow{left:20px}.note-popover .popover .popover-content,.note-toolbar{padding:0 0 5px 5px;margin:0}.note-popover .popover .popover-content>.btn-group,.note-toolbar>.btn-group{margin-top:5px;margin-right:5px;margin-left:0}.note-popover .popover .popover-content .btn-group .note-table,.note-toolbar .btn-group .note-table{min-width:0;padding:5px}.note-popover .popover .popover-content .btn-group .note-table .note-dimension-picker,.note-toolbar .btn-group .note-table .note-dimension-picker{font-size:18px}.note-popover .popover .popover-content .btn-group .note-table .note-dimension-picker .note-dimension-picker-mousecatcher,.note-toolbar .btn-group .note-table .note-dimension-picker .note-dimension-picker-mousecatcher{position:absolute!important;z-index:3;width:10em;height:10em;cursor:pointer}.note-popover .popover .popover-content .btn-group .note-table .note-dimension-picker .note-dimension-picker-unhighlighted,.note-toolbar .btn-group .note-table .note-dimension-picker .note-dimension-picker-unhighlighted{position:relative!important;z-index:1;width:5em;height:5em;background:url('') repeat}.note-popover .popover .popover-content .btn-group .note-table .note-dimension-picker .note-dimension-picker-highlighted,.note-toolbar .btn-group .note-table .note-dimension-picker .note-dimension-picker-highlighted{position:absolute!important;z-index:2;width:1em;height:1em;background:url('') repeat}.note-popover .popover .popover-content .note-style h1,.note-toolbar .note-style h1,.note-popover .popover .popover-content .note-style h2,.note-toolbar .note-style h2,.note-popover .popover .popover-content .note-style h3,.note-toolbar .note-style h3,.note-popover .popover .popover-content .note-style h4,.note-toolbar .note-style h4,.note-popover .popover .popover-content .note-style h5,.note-toolbar .note-style h5,.note-popover .popover .popover-content .note-style h6,.note-toolbar .note-style h6,.note-popover .popover .popover-content .note-style blockquote,.note-toolbar .note-style blockquote{margin:0}.note-popover .popover .popover-content .note-color .dropdown-toggle,.note-toolbar .note-color .dropdown-toggle{width:20px;padding-left:5px}.note-popover .popover .popover-content .note-color .dropdown-menu,.note-toolbar .note-color .dropdown-menu{min-width:340px}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group,.note-toolbar .note-color .dropdown-menu .btn-group{margin:0}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group:first-child,.note-toolbar .note-color .dropdown-menu .btn-group:first-child{margin:0 5px}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group .note-palette-title,.note-toolbar .note-color .dropdown-menu .btn-group .note-palette-title{margin:2px 7px;font-size:12px;text-align:center;border-bottom:1px solid #eee}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group .note-color-reset,.note-toolbar .note-color .dropdown-menu .btn-group .note-color-reset{padding:0 3px;margin:3px;font-size:11px;cursor:pointer;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group .note-color-row,.note-toolbar .note-color .dropdown-menu .btn-group .note-color-row{height:20px}.note-popover .popover .popover-content .note-color .dropdown-menu .btn-group .note-color-reset:hover,.note-toolbar .note-color .dropdown-menu .btn-group .note-color-reset:hover{background:#eee}.note-popover .popover .popover-content .note-para .dropdown-menu,.note-toolbar .note-para .dropdown-menu{min-width:216px;padding:5px}.note-popover .popover .popover-content .note-para .dropdown-menu>div:first-child,.note-toolbar .note-para .dropdown-menu>div:first-child{margin-right:5px}.note-popover .popover .popover-content .dropdown-menu,.note-toolbar .dropdown-menu{min-width:90px}.note-popover .popover .popover-content .dropdown-menu.right,.note-toolbar .dropdown-menu.right{right:0;left:auto}.note-popover .popover .popover-content .dropdown-menu.right::before,.note-toolbar .dropdown-menu.right::before{right:9px;left:auto!important}.note-popover .popover .popover-content .dropdown-menu.right::after,.note-toolbar .dropdown-menu.right::after{right:10px;left:auto!important}.note-popover .popover .popover-content .dropdown-menu.note-check li a i,.note-toolbar .dropdown-menu.note-check li a i{color:deepskyblue;visibility:hidden}.note-popover .popover .popover-content .dropdown-menu.note-check li a.checked i,.note-toolbar .dropdown-menu.note-check li a.checked i{visibility:visible}.note-popover .popover .popover-content .note-fontsize-10,.note-toolbar .note-fontsize-10{font-size:10px}.note-popover .popover .popover-content .note-color-palette,.note-toolbar .note-color-palette{line-height:1}.note-popover .popover .popover-content .note-color-palette div .note-color-btn,.note-toolbar .note-color-palette div .note-color-btn{width:20px;height:20px;padding:0;margin:0;border:1px solid #fff}.note-popover .popover .popover-content .note-color-palette div .note-color-btn:hover,.note-toolbar .note-color-palette div .note-color-btn:hover{border:1px solid #000}.note-dialog>div{display:none}.note-dialog .form-group{margin-right:0;margin-left:0}.note-dialog .note-modal-form{margin:0}.note-dialog .note-image-dialog .note-dropzone{min-height:100px;margin-bottom:10px;font-size:30px;line-height:4;color:lightgray;text-align:center;border:4px dashed lightgray}.note-dialog .note-help-dialog{font-size:12px;color:#ccc;background:transparent;background-color:#222!important;border:0;-webkit-opacity:.9;-khtml-opacity:.9;-moz-opacity:.9;opacity:.9;-ms-filter:alpha(opacity=90);filter:alpha(opacity=90)}.note-dialog .note-help-dialog .modal-content{background:transparent;border:1px solid white;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.note-dialog .note-help-dialog a{font-size:12px;color:white}.note-dialog .note-help-dialog .title{padding-bottom:5px;margin-bottom:10px;font-size:14px;font-weight:bold;color:white;border-bottom:white 1px solid}.note-dialog .note-help-dialog .modal-close{font-size:14px;color:#dd0;cursor:pointer}.note-dialog .note-help-dialog .text-center{margin:10px 0 0}.note-dialog .note-help-dialog .note-shortcut{padding-top:8px;padding-bottom:8px}.note-dialog .note-help-dialog .note-shortcut-row{margin-right:-5px;margin-left:-5px}.note-dialog .note-help-dialog .note-shortcut-col{padding-right:5px;padding-left:5px}.note-dialog .note-help-dialog .note-shortcut-title{font-size:13px;font-weight:bold;color:#dd0}.note-dialog .note-help-dialog .note-shortcut-key{font-family:"Courier New";color:#dd0;text-align:right}.note-handle .note-control-selection{position:absolute;display:none;border:1px solid black}.note-handle .note-control-selection>div{position:absolute}.note-handle .note-control-selection .note-control-selection-bg{width:100%;height:100%;background-color:black;-webkit-opacity:.3;-khtml-opacity:.3;-moz-opacity:.3;opacity:.3;-ms-filter:alpha(opacity=30);filter:alpha(opacity=30)}.note-handle .note-control-selection .note-control-handle{width:7px;height:7px;border:1px solid black}.note-handle .note-control-selection .note-control-holder{width:7px;height:7px;border:1px solid black}.note-handle .note-control-selection .note-control-sizing{width:7px;height:7px;background-color:white;border:1px solid black}.note-handle .note-control-selection .note-control-nw{top:-5px;left:-5px;border-right:0;border-bottom:0}.note-handle .note-control-selection .note-control-ne{top:-5px;right:-5px;border-bottom:0;border-left:none}.note-handle .note-control-selection .note-control-sw{bottom:-5px;left:-5px;border-top:0;border-right:0}.note-handle .note-control-selection .note-control-se{right:-5px;bottom:-5px;cursor:se-resize}.note-handle .note-control-selection .note-control-selection-info{right:0;bottom:0;padding:5px;margin:5px;font-size:12px;color:white;background-color:black;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;-webkit-opacity:.7;-khtml-opacity:.7;-moz-opacity:.7;opacity:.7;-ms-filter:alpha(opacity=70);filter:alpha(opacity=70)}
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: summernote-rails
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.6.6.0
4
+ version: 0.6.7.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Hyo Seong Choi
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2015-05-12 00:00:00.000000000 Z
11
+ date: 2015-06-16 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: railties
@@ -88,6 +88,7 @@ files:
88
88
  - vendor/assets/javascripts/summernote/locales/nl-NL.js
89
89
  - vendor/assets/javascripts/summernote/locales/pl-PL.js
90
90
  - vendor/assets/javascripts/summernote/locales/pt-BR.js
91
+ - vendor/assets/javascripts/summernote/locales/pt-PT.js
91
92
  - vendor/assets/javascripts/summernote/locales/ro-RO.js
92
93
  - vendor/assets/javascripts/summernote/locales/ru-RU.js
93
94
  - vendor/assets/javascripts/summernote/locales/sk-SK.js
@@ -102,10 +103,10 @@ files:
102
103
  - vendor/assets/javascripts/summernote/locales/zh-CN.js
103
104
  - vendor/assets/javascripts/summernote/locales/zh-TW.js
104
105
  - vendor/assets/javascripts/summernote/plugin/summernote-ext-hello.js
106
+ - vendor/assets/javascripts/summernote/plugin/summernote-ext-hint.js
105
107
  - vendor/assets/javascripts/summernote/plugin/summernote-ext-video.js
106
108
  - vendor/assets/javascripts/summernote/summernote.js
107
- - vendor/assets/stylesheets/summernote/index.css
108
- - vendor/assets/stylesheets/summernote/summernote.css
109
+ - vendor/assets/stylesheets/summernote.css
109
110
  homepage: https://github.com/summernote/summernote-rails
110
111
  licenses:
111
112
  - MIT
@@ -1,3 +0,0 @@
1
- /*
2
- *= require ./summernote
3
- */