]>
Commit | Line | Data |
---|---|---|
7adcb81e | 1 | /**\r |
3b35bd27 | 2 | * @license Copyright (c) 2003-2016, CKSource - Frederico Knabben. All rights reserved.\r |
7adcb81e IB |
3 | * For licensing, see LICENSE.md or http://ckeditor.com/license\r |
4 | */\r | |
5 | \r | |
6 | /**\r | |
7 | * @fileOverview The "div" plugin. It wraps the selected block level elements with a 'div' element with specified styles and attributes.\r | |
8 | *\r | |
9 | */\r | |
10 | \r | |
11 | ( function() {\r | |
12 | CKEDITOR.plugins.add( 'div', {\r | |
13 | requires: 'dialog',\r | |
14 | // jscs:disable maximumLineLength\r | |
3b35bd27 | 15 | lang: 'af,ar,bg,bn,bs,ca,cs,cy,da,de,de-ch,el,en,en-au,en-ca,en-gb,eo,es,et,eu,fa,fi,fo,fr,fr-ca,gl,gu,he,hi,hr,hu,id,is,it,ja,ka,km,ko,ku,lt,lv,mk,mn,ms,nb,nl,no,pl,pt,pt-br,ro,ru,si,sk,sl,sq,sr,sr-latn,sv,th,tr,tt,ug,uk,vi,zh,zh-cn', // %REMOVE_LINE_CORE%\r |
7adcb81e IB |
16 | // jscs:enable maximumLineLength\r |
17 | icons: 'creatediv', // %REMOVE_LINE_CORE%\r | |
18 | hidpi: true, // %REMOVE_LINE_CORE%\r | |
19 | init: function( editor ) {\r | |
20 | if ( editor.blockless )\r | |
21 | return;\r | |
22 | \r | |
23 | var lang = editor.lang.div,\r | |
24 | allowed = 'div(*)';\r | |
25 | \r | |
26 | if ( CKEDITOR.dialog.isTabEnabled( editor, 'editdiv', 'advanced' ) )\r | |
27 | allowed += ';div[dir,id,lang,title]{*}';\r | |
28 | \r | |
29 | editor.addCommand( 'creatediv', new CKEDITOR.dialogCommand( 'creatediv', {\r | |
30 | allowedContent: allowed,\r | |
31 | requiredContent: 'div',\r | |
32 | contextSensitive: true,\r | |
33 | refresh: function( editor, path ) {\r | |
34 | var context = editor.config.div_wrapTable ? path.root : path.blockLimit;\r | |
35 | this.setState( 'div' in context.getDtd() ? CKEDITOR.TRISTATE_OFF : CKEDITOR.TRISTATE_DISABLED );\r | |
36 | }\r | |
37 | } ) );\r | |
38 | \r | |
39 | editor.addCommand( 'editdiv', new CKEDITOR.dialogCommand( 'editdiv', { requiredContent: 'div' } ) );\r | |
40 | editor.addCommand( 'removediv', {\r | |
41 | requiredContent: 'div',\r | |
42 | exec: function( editor ) {\r | |
43 | var selection = editor.getSelection(),\r | |
44 | ranges = selection && selection.getRanges(),\r | |
45 | range,\r | |
46 | bookmarks = selection.createBookmarks(),\r | |
47 | walker,\r | |
48 | toRemove = [];\r | |
49 | \r | |
50 | function findDiv( node ) {\r | |
51 | var div = CKEDITOR.plugins.div.getSurroundDiv( editor, node );\r | |
52 | if ( div && !div.data( 'cke-div-added' ) ) {\r | |
53 | toRemove.push( div );\r | |
54 | div.data( 'cke-div-added' );\r | |
55 | }\r | |
56 | }\r | |
57 | \r | |
58 | for ( var i = 0; i < ranges.length; i++ ) {\r | |
59 | range = ranges[ i ];\r | |
60 | if ( range.collapsed )\r | |
61 | findDiv( selection.getStartElement() );\r | |
62 | else {\r | |
63 | walker = new CKEDITOR.dom.walker( range );\r | |
64 | walker.evaluator = findDiv;\r | |
65 | walker.lastForward();\r | |
66 | }\r | |
67 | }\r | |
68 | \r | |
69 | for ( i = 0; i < toRemove.length; i++ )\r | |
70 | toRemove[ i ].remove( true );\r | |
71 | \r | |
72 | selection.selectBookmarks( bookmarks );\r | |
73 | }\r | |
74 | } );\r | |
75 | \r | |
76 | editor.ui.addButton && editor.ui.addButton( 'CreateDiv', {\r | |
77 | label: lang.toolbar,\r | |
78 | command: 'creatediv',\r | |
79 | toolbar: 'blocks,50'\r | |
80 | } );\r | |
81 | \r | |
82 | if ( editor.addMenuItems ) {\r | |
83 | editor.addMenuItems( {\r | |
84 | editdiv: {\r | |
85 | label: lang.edit,\r | |
86 | command: 'editdiv',\r | |
87 | group: 'div',\r | |
88 | order: 1\r | |
89 | },\r | |
90 | \r | |
91 | removediv: {\r | |
92 | label: lang.remove,\r | |
93 | command: 'removediv',\r | |
94 | group: 'div',\r | |
95 | order: 5\r | |
96 | }\r | |
97 | } );\r | |
98 | \r | |
99 | if ( editor.contextMenu ) {\r | |
100 | editor.contextMenu.addListener( function( element ) {\r | |
101 | if ( !element || element.isReadOnly() )\r | |
102 | return null;\r | |
103 | \r | |
104 | \r | |
105 | if ( CKEDITOR.plugins.div.getSurroundDiv( editor ) ) {\r | |
106 | return {\r | |
107 | editdiv: CKEDITOR.TRISTATE_OFF,\r | |
108 | removediv: CKEDITOR.TRISTATE_OFF\r | |
109 | };\r | |
110 | }\r | |
111 | \r | |
112 | return null;\r | |
113 | } );\r | |
114 | }\r | |
115 | }\r | |
116 | \r | |
117 | CKEDITOR.dialog.add( 'creatediv', this.path + 'dialogs/div.js' );\r | |
118 | CKEDITOR.dialog.add( 'editdiv', this.path + 'dialogs/div.js' );\r | |
119 | }\r | |
120 | } );\r | |
121 | \r | |
122 | CKEDITOR.plugins.div = {\r | |
123 | getSurroundDiv: function( editor, start ) {\r | |
124 | var path = editor.elementPath( start );\r | |
125 | return editor.elementPath( path.blockLimit ).contains( function( node ) {\r | |
126 | // Avoid read-only (i.e. contenteditable="false") divs (#11083).\r | |
127 | return node.is( 'div' ) && !node.isReadOnly();\r | |
128 | }, 1 );\r | |
129 | }\r | |
130 | };\r | |
131 | } )();\r |