]>
git.immae.eu Git - perso/Immae/Projets/packagist/piedsjaloux-ckeditor-component.git/blob - dtd.js
d6dc5a6775b66751b1cf1afc4758c09a6fd6f912
2 * @license Copyright (c) 2003-2016, CKSource - Frederico Knabben. All rights reserved.
3 * For licensing, see LICENSE.md or http://ckeditor.com/license
7 * @fileOverview Defines the {@link CKEDITOR.dtd} object, which holds the DTD
8 * mapping for XHTML 1.0 Transitional. This file was automatically
9 * generated from the file: xhtml1-transitional.dtd.
13 * Holds and object representation of the HTML DTD to be used by the
14 * editor in its internal operations.
16 * Each element in the DTD is represented by a property in this object. Each
17 * property contains the list of elements that can be contained by the element.
18 * Text is represented by the `#` property.
20 * Several special grouping properties are also available. Their names start
21 * with the `$` character.
23 * // Check if <div> can be contained in a <p> element.
24 * alert( !!CKEDITOR.dtd[ 'p' ][ 'div' ] ); // false
26 * // Check if <p> can be contained in a <div> element.
27 * alert( !!CKEDITOR.dtd[ 'div' ][ 'p' ] ); // true
29 * // Check if <p> is a block element.
30 * alert( !!CKEDITOR.dtd.$block[ 'p' ] ); // true
35 CKEDITOR
.dtd
= ( function() {
38 var X
= CKEDITOR
.tools
.extend
,
39 // Subtraction rest of sets, from the first set.
40 Y = function( source
, removed
) {
41 var substracted
= CKEDITOR
.tools
.clone( source
);
42 for ( var i
= 1; i
< arguments
.length
; i
++ ) {
43 removed
= arguments
[ i
];
44 for ( var name
in removed
)
45 delete substracted
[ name
];
51 // P = { a: 1, em: 1, strong: 1, small: 1, abbr: 1, dfn: 1, i: 1, b: 1, s: 1,
52 // u: 1, code: 1, 'var': 1, samp: 1, kbd: 1, sup: 1, sub: 1, q: 1, cite: 1,
53 // span: 1, bdo: 1, bdi: 1, br: 1, wbr: 1, ins: 1, del: 1, img: 1, embed: 1,
54 // object: 1, iframe: 1, map: 1, area: 1, script: 1, noscript: 1, ruby: 1,
55 // video: 1, audio: 1, input: 1, textarea: 1, select: 1, button: 1, label: 1,
56 // output: 1, keygen: 1, progress: 1, command: 1, canvas: 1, time: 1,
57 // meter: 1, detalist: 1 },
60 // F = { a: 1, p: 1, hr: 1, pre: 1, ul: 1, ol: 1, dl: 1, div: 1, h1: 1, h2: 1,
61 // h3: 1, h4: 1, h5: 1, h6: 1, hgroup: 1, address: 1, blockquote: 1, ins: 1,
62 // del: 1, object: 1, map: 1, noscript: 1, section: 1, nav: 1, article: 1,
63 // aside: 1, header: 1, footer: 1, video: 1, audio: 1, figure: 1, table: 1,
64 // form: 1, fieldset: 1, menu: 1, canvas: 1, details:1 },
66 // Text can be everywhere.
68 // Flow elements set consists of phrasing elements set.
72 // Intersection of flow elements set and phrasing elements set.
74 a: 1, abbr: 1, area: 1, audio: 1, b: 1, bdi: 1, bdo: 1, br: 1, button: 1, canvas: 1, cite: 1,
75 code: 1, command: 1, datalist: 1, del: 1, dfn: 1, em: 1, embed: 1, i: 1, iframe: 1, img: 1,
76 input: 1, ins: 1, kbd: 1, keygen: 1, label: 1, map: 1, mark: 1, meter: 1, noscript: 1, object: 1,
77 output: 1, progress: 1, q: 1, ruby: 1, s: 1, samp: 1, script: 1, select: 1, small: 1, span: 1,
78 strong: 1, sub: 1, sup: 1, textarea: 1, time: 1, u: 1, 'var': 1, video: 1, wbr: 1
80 // F - PF (Flow Only).
82 address: 1, article: 1, aside: 1, blockquote: 1, details: 1, div: 1, dl: 1, fieldset: 1,
83 figure: 1, footer: 1, form: 1, h1: 1, h2: 1, h3: 1, h4: 1, h5: 1, h6: 1, header: 1, hgroup: 1,
84 hr: 1, main: 1, menu: 1, nav: 1, ol: 1, p: 1, pre: 1, section: 1, table: 1, ul: 1
87 M
= { command: 1, link: 1, meta: 1, noscript: 1, script: 1, style: 1 },
93 // Deprecated phrasing elements.
94 DP
= { acronym: 1, applet: 1, basefont: 1, big: 1, font: 1, isindex: 1, strike: 1, style: 1, tt: 1 }, // TODO remove "style".
95 // Deprecated flow only elements.
96 DFO
= { center: 1, dir: 1, noframes: 1 };
98 // Phrasing elements := PF + T + DP
100 // Flow elements := FO + P + DFO
104 a: Y( P
, { a: 1, button: 1 } ), // Treat as normal inline element (not a transparent one).
110 audio: X( { source: 1, track: 1 }, F
),
118 button: Y( P
, { a: 1, button: 1 } ),
119 canvas: P
, // Treat as normal inline element (not a transparent one).
124 colgroup: { col: 1 },
126 datalist: X( { option: 1 }, P
),
128 del: P
, // Treat as normal inline element (not a transparent one).
129 details: X( { summary: 1 }, F
),
132 dl: { dt: 1, dd: 1 },
136 fieldset: X( { legend: 1 }, F
),
138 figure: X( { figcaption: 1 }, F
),
147 head: X( { title: 1, base: 1 }, M
),
149 hgroup: { h1: 1, h2: 1, h3: 1, h4: 1, h5: 1, h6: 1 },
151 html: X( { head: 1, body: 1 }, F
, M
), // Head and body are optional...
156 ins: P
, // Treat as normal inline element (not a transparent one).
163 // Can't be a descendant of article, aside, footer, header, nav, but we don't need this
164 // complication. As well as checking if it's used only once.
167 mark: P
, // Treat as normal inline element (not a transparent one).
168 menu: X( { li: 1 }, F
),
170 meter: Y( P
, { meter: 1 } ),
172 noscript: X( { link: 1, meta: 1, style: 1 }, P
), // Treat as normal inline element (not a transparent one).
173 object: X( { param: 1 }, P
), // Treat as normal inline element (not a transparent one).
175 optgroup: { option: 1 },
181 progress: Y( P
, { progress: 1 } ),
185 ruby: X( { rp: 1, rt: 1 }, P
),
190 select: { optgroup: 1, option: 1 },
197 summary: X( { h1: 1, h2: 1, h3: 1, h4: 1, h5: 1, h6: 1 }, P
),
199 table: { caption: 1, colgroup: 1, thead: 1, tfoot: 1, tbody: 1, tr: 1 },
206 time: Y( P
, { time: 1 } ),
208 tr: { th: 1, td: 1 },
213 video: X( { source: 1, track: 1 }, F
),
218 applet: X( { param: 1 }, F
),
233 * List of block elements, like `<p>` or `<div>`.
235 $block: X( { audio: 1, dd: 1, dt: 1, figcaption: 1, li: 1, video: 1 }, FO
, DFO
),
238 * List of elements that contain other blocks, in which block-level operations should be limited,
239 * this property is not intended to be checked directly, use {@link CKEDITOR.dom.elementPath#blockLimit} instead.
241 * Some examples of editor behaviors that are impacted by block limits:
243 * * Enter key never split a block-limit element;
244 * * Style application is constraint by the block limit of the current selection.
245 * * Pasted html will be inserted into the block limit of the current selection.
247 * **Note:** As an exception `<li>` is not considered as a block limit, as it's generally used as a text block.
250 article: 1, aside: 1, audio: 1, body: 1, caption: 1, details: 1, dir: 1, div: 1, dl: 1,
251 fieldset: 1, figcaption: 1, figure: 1, footer: 1, form: 1, header: 1, hgroup: 1, main: 1, menu: 1, nav: 1,
252 ol: 1, section: 1, table: 1, td: 1, th: 1, tr: 1, ul: 1, video: 1
256 * List of elements that contain character data.
258 $cdata: { script: 1, style: 1 },
261 * List of elements that are accepted as inline editing hosts.
264 address: 1, article: 1, aside: 1, blockquote: 1, body: 1, details: 1, div: 1, fieldset: 1,
265 figcaption: 1, footer: 1, form: 1, h1: 1, h2: 1, h3: 1, h4: 1, h5: 1, h6: 1, header: 1, hgroup: 1,
266 main: 1, nav: 1, p: 1, pre: 1, section: 1
270 * List of empty (self-closing) elements, like `<br>` or `<img>`.
273 area: 1, base: 1, basefont: 1, br: 1, col: 1, command: 1, dialog: 1, embed: 1, hr: 1, img: 1,
274 input: 1, isindex: 1, keygen: 1, link: 1, meta: 1, param: 1, source: 1, track: 1, wbr: 1
278 * List of inline (`<span>` like) elements.
283 * List of list root elements.
285 $list: { dl: 1, ol: 1, ul: 1 },
288 * List of list item elements, like `<li>` or `<dd>`.
290 $listItem: { dd: 1, dt: 1, li: 1 },
293 * List of elements which may live outside body.
295 $nonBodyContent: X( { body: 1, head: 1, html: 1 }, dtd
.head
),
298 * Elements that accept text nodes, but are not possible to edit into the browser.
301 applet: 1, audio: 1, button: 1, embed: 1, iframe: 1, map: 1, object: 1, option: 1,
302 param: 1, script: 1, textarea: 1, video: 1
306 * Elements that are considered objects, therefore selected as a whole in the editor.
309 applet: 1, audio: 1, button: 1, hr: 1, iframe: 1, img: 1, input: 1, object: 1, select: 1,
310 table: 1, textarea: 1, video: 1
314 * List of elements that can be ignored if empty, like `<b>` or `<span>`.
317 abbr: 1, acronym: 1, b: 1, bdi: 1, bdo: 1, big: 1, cite: 1, code: 1, del: 1, dfn: 1,
318 em: 1, font: 1, i: 1, ins: 1, label: 1, kbd: 1, mark: 1, meter: 1, output: 1, q: 1, ruby: 1, s: 1,
319 samp: 1, small: 1, span: 1, strike: 1, strong: 1, sub: 1, sup: 1, time: 1, tt: 1, u: 1, 'var': 1
323 * List of elements that have tabindex set to zero by default.
325 $tabIndex: { a: 1, area: 1, button: 1, input: 1, object: 1, select: 1, textarea: 1 },
328 * List of elements used inside the `<table>` element, like `<tbody>` or `<td>`.
330 $tableContent: { caption: 1, col: 1, colgroup: 1, tbody: 1, td: 1, tfoot: 1, th: 1, thead: 1, tr: 1 },
333 * List of "transparent" elements. See [W3C's definition of "transparent" element](http://dev.w3.org/html5/markup/terminology.html#transparent).
335 $transparent: { a: 1, audio: 1, canvas: 1, del: 1, ins: 1, map: 1, noscript: 1, object: 1, video: 1 },
338 * List of elements that are not to exist standalone that must live under it's parent element.
341 caption: 1, colgroup: 1, dd: 1, dt: 1, figcaption: 1, legend: 1, li: 1, optgroup: 1,
342 option: 1, rp: 1, rt: 1, summary: 1, tbody: 1, td: 1, tfoot: 1, th: 1, thead: 1, tr: 1
349 // PACKAGER_RENAME( CKEDITOR.dtd )