UNPKG

ember-legacy-class-transform

Version:
90 lines (86 loc) 12.7 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.domChanges = domChanges; exports.treeConstruction = treeConstruction; var _bounds = require('../bounds'); var _helper = require('../dom/helper'); let innerHTMLWrapper = { colgroup: { depth: 2, before: '<table><colgroup>', after: '</colgroup></table>' }, table: { depth: 1, before: '<table>', after: '</table>' }, tbody: { depth: 2, before: '<table><tbody>', after: '</tbody></table>' }, tfoot: { depth: 2, before: '<table><tfoot>', after: '</tfoot></table>' }, thead: { depth: 2, before: '<table><thead>', after: '</thead></table>' }, tr: { depth: 3, before: '<table><tbody><tr>', after: '</tr></tbody></table>' } }; // Patch: innerHTML Fix // Browsers: IE9 // Reason: IE9 don't allow us to set innerHTML on col, colgroup, frameset, // html, style, table, tbody, tfoot, thead, title, tr. // Fix: Wrap the innerHTML we are about to set in its parents, apply the // wrapped innerHTML on a div, then move the unwrapped nodes into the // target position. function domChanges(document, DOMChangesClass) { if (!document) return DOMChangesClass; if (!shouldApplyFix(document)) { return DOMChangesClass; } let div = document.createElement('div'); return class DOMChangesWithInnerHTMLFix extends DOMChangesClass { insertHTMLBefore(parent, nextSibling, html) { if (html === null || html === '') { return super.insertHTMLBefore(parent, nextSibling, html); } let parentTag = parent.tagName.toLowerCase(); let wrapper = innerHTMLWrapper[parentTag]; if (wrapper === undefined) { return super.insertHTMLBefore(parent, nextSibling, html); } return fixInnerHTML(parent, wrapper, div, html, nextSibling); } }; } function treeConstruction(document, DOMTreeConstructionClass) { if (!document) return DOMTreeConstructionClass; if (!shouldApplyFix(document)) { return DOMTreeConstructionClass; } let div = document.createElement('div'); return class DOMTreeConstructionWithInnerHTMLFix extends DOMTreeConstructionClass { insertHTMLBefore(parent, referenceNode, html) { if (html === null || html === '') { return super.insertHTMLBefore(parent, referenceNode, html); } let parentTag = parent.tagName.toLowerCase(); let wrapper = innerHTMLWrapper[parentTag]; if (wrapper === undefined) { return super.insertHTMLBefore(parent, referenceNode, html); } return fixInnerHTML(parent, wrapper, div, html, referenceNode); } }; } function fixInnerHTML(parent, wrapper, div, html, reference) { let wrappedHtml = wrapper.before + html + wrapper.after; div.innerHTML = wrappedHtml; let parentNode = div; for (let i = 0; i < wrapper.depth; i++) { parentNode = parentNode.childNodes[0]; } let [first, last] = (0, _helper.moveNodesBefore)(parentNode, parent, reference); return new _bounds.ConcreteBounds(parent, first, last); } function shouldApplyFix(document) { let table = document.createElement('table'); try { table.innerHTML = '<tbody></tbody>'; } catch (e) {} finally { if (table.childNodes.length !== 0) { // It worked as expected, no fix required return false; } } return true; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["lib/compat/inner-html-fix.js"],"names":["domChanges","treeConstruction","innerHTMLWrapper","colgroup","depth","before","after","table","tbody","tfoot","thead","tr","document","DOMChangesClass","shouldApplyFix","div","createElement","DOMChangesWithInnerHTMLFix","insertHTMLBefore","parent","nextSibling","html","parentTag","tagName","toLowerCase","wrapper","undefined","fixInnerHTML","DOMTreeConstructionClass","DOMTreeConstructionWithInnerHTMLFix","referenceNode","reference","wrappedHtml","innerHTML","parentNode","i","childNodes","first","last","e","length"],"mappings":"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","file":"lib/compat/inner-html-fix.js","sourcesContent":["import { ConcreteBounds } from '../bounds';\nimport { moveNodesBefore } from '../dom/helper';\nlet innerHTMLWrapper = {\n    colgroup: { depth: 2, before: '<table><colgroup>', after: '</colgroup></table>' },\n    table: { depth: 1, before: '<table>', after: '</table>' },\n    tbody: { depth: 2, before: '<table><tbody>', after: '</tbody></table>' },\n    tfoot: { depth: 2, before: '<table><tfoot>', after: '</tfoot></table>' },\n    thead: { depth: 2, before: '<table><thead>', after: '</thead></table>' },\n    tr: { depth: 3, before: '<table><tbody><tr>', after: '</tr></tbody></table>' }\n};\n// Patch:    innerHTML Fix\n// Browsers: IE9\n// Reason:   IE9 don't allow us to set innerHTML on col, colgroup, frameset,\n//           html, style, table, tbody, tfoot, thead, title, tr.\n// Fix:      Wrap the innerHTML we are about to set in its parents, apply the\n//           wrapped innerHTML on a div, then move the unwrapped nodes into the\n//           target position.\nexport function domChanges(document, DOMChangesClass) {\n    if (!document) return DOMChangesClass;\n    if (!shouldApplyFix(document)) {\n        return DOMChangesClass;\n    }\n    let div = document.createElement('div');\n    return class DOMChangesWithInnerHTMLFix extends DOMChangesClass {\n        insertHTMLBefore(parent, nextSibling, html) {\n            if (html === null || html === '') {\n                return super.insertHTMLBefore(parent, nextSibling, html);\n            }\n            let parentTag = parent.tagName.toLowerCase();\n            let wrapper = innerHTMLWrapper[parentTag];\n            if (wrapper === undefined) {\n                return super.insertHTMLBefore(parent, nextSibling, html);\n            }\n            return fixInnerHTML(parent, wrapper, div, html, nextSibling);\n        }\n    };\n}\nexport function treeConstruction(document, DOMTreeConstructionClass) {\n    if (!document) return DOMTreeConstructionClass;\n    if (!shouldApplyFix(document)) {\n        return DOMTreeConstructionClass;\n    }\n    let div = document.createElement('div');\n    return class DOMTreeConstructionWithInnerHTMLFix extends DOMTreeConstructionClass {\n        insertHTMLBefore(parent, referenceNode, html) {\n            if (html === null || html === '') {\n                return super.insertHTMLBefore(parent, referenceNode, html);\n            }\n            let parentTag = parent.tagName.toLowerCase();\n            let wrapper = innerHTMLWrapper[parentTag];\n            if (wrapper === undefined) {\n                return super.insertHTMLBefore(parent, referenceNode, html);\n            }\n            return fixInnerHTML(parent, wrapper, div, html, referenceNode);\n        }\n    };\n}\nfunction fixInnerHTML(parent, wrapper, div, html, reference) {\n    let wrappedHtml = wrapper.before + html + wrapper.after;\n    div.innerHTML = wrappedHtml;\n    let parentNode = div;\n    for (let i = 0; i < wrapper.depth; i++) {\n        parentNode = parentNode.childNodes[0];\n    }\n    let [first, last] = moveNodesBefore(parentNode, parent, reference);\n    return new ConcreteBounds(parent, first, last);\n}\nfunction shouldApplyFix(document) {\n    let table = document.createElement('table');\n    try {\n        table.innerHTML = '<tbody></tbody>';\n    } catch (e) {} finally {\n        if (table.childNodes.length !== 0) {\n            // It worked as expected, no fix required\n            return false;\n        }\n    }\n    return true;\n}"]}